package org.fnppl.opensdx.security; /* * Copyright (C) 2010-2015 * fine people e.V. <opensdx@fnppl.org> * Henning Thieß <ht@fnppl.org> * * http://fnppl.org */ /* * Software license * * As far as this file or parts of this file is/are software, rather than documentation, this software-license applies / shall be applied. * * This file is part of openSDX * openSDX is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * openSDX is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU Lesser General Public License * and GNU General Public License along with openSDX. * If not, see <http://www.gnu.org/licenses/>. * */ /* * Documentation license * * As far as this file or parts of this file is/are documentation, rather than software, this documentation-license applies / shall be applied. * * This file is part of openSDX. * Permission is granted to copy, distribute and/or modify this document * under the terms of the GNU Free Documentation License, Version 1.3 * or any later version published by the Free Software Foundation; * with no Invariant Sections, no Front-Cover Texts, and no Back-Cover Texts. * A copy of the license is included in the section entitled "GNU * Free Documentation License" resp. in the file called "FDL.txt". * */ public class RevokeKey extends SubKey { protected RevokeKey() { super(); super.setLevel(LEVEL_REVOKE); } public Result uploadToKeyServer(KeyClient client) { // if (!hasPrivateKey()) { // return Result.error("no private key available"); // } // if (!isPrivateKeyUnlocked()) { // return Result.error("private key is locked"); // } // if (authoritativekeyserver.equals("LOCAL")) { // return Result.error("authoritative keyserver can not be LOCAL"); // } // //if (authoritativekeyserverPort<=0) return Result.error("authoritative keyserver port not set"); // if (parentKey==null) return Result.error("missing parent key"); // try { // KeyClient client = new KeyClient(authoritativekeyserver, // 80, // //KeyClient.OSDX_KEYSERVER_DEFAULT_PORT, // "", keyverificator); // boolean ok = client.putRevokeKey(this, parentKey); // if (ok) { // return Result.succeeded(); // } else { // return Result.error(client.getMessage()); // } // } catch (Exception ex) { // return Result.error(ex); // } // if (!hasPrivateKey()) { System.out.println("uploadToKeyServer::!hasprivatekey"); return Result.error("no private key available"); } if (!isPrivateKeyUnlocked()) { System.out.println("uploadToKeyServer::!privatekeyunlocked"); return Result.error("private key is locked"); } if (authoritativekeyserver.equals("LOCAL")) { System.out.println("uploadToKeyServer::authoritativekeyserver==local"); return Result.error("authoritative keyserver can not be LOCAL"); } if (client == null) { System.out.println("uploadToKeyServer::client==null"); return Result.error("keyserver not set."); } if (!client.getHost().equalsIgnoreCase(authoritativekeyserver)) { System.out.println("uploadToKeyServer::client.host != authoritativekeyserver"); return Result.error("keyserver not authoritative."); } //if (authoritativekeyserverPort<=0) return Result.error("authoritative keyserver port not set"); if (parentKey==null) { System.out.println("uploadToKeyServer::parentkey==null"); return Result.error("missing parent key"); } try { //KeyClient client = new KeyClient(authoritativekeyserver, KeyClient.OSDX_KEYSERVER_DEFAULT_PORT, "", keyverificator); // KeyClient client = new KeyClient( // authoritativekeyserver, // 80, //TODO HT 2011-06-26 check me!!! // //KeyClient.OSDX_KEYSERVER_DEFAULT_PORT, // "", // keyverificator // ); //System.out.println("Before RevokeKey.putSubkey..."); boolean ok = client.putRevokeKey(this, parentKey); //System.out.println("AFTER RevokeKey.putSubkey -> "+ok); if (ok) { return Result.succeeded(); } else { return Result.error(client.getMessage()); } } catch (Exception ex) { ex.printStackTrace(); return Result.error(ex); } } public void setLevel(int level) { throw new RuntimeException("ERROR not allowed to set level for RevokeKey"); } }