diff options
author | Vincent Breitmoser <valodim@mugenguild.com> | 2014-09-11 22:49:21 +0200 |
---|---|---|
committer | Vincent Breitmoser <valodim@mugenguild.com> | 2014-09-11 22:49:21 +0200 |
commit | f7444880171064377636cd11b5e9fe0ce7c2a827 (patch) | |
tree | 78900694b3f9748ee3f3b51f6a8e7a9d792357f4 /OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp | |
parent | 8e665d829e2821ef39739cb1eb427e8b0e6c71ff (diff) | |
download | open-keychain-f7444880171064377636cd11b5e9fe0ce7c2a827.tar.gz open-keychain-f7444880171064377636cd11b5e9fe0ce7c2a827.tar.bz2 open-keychain-f7444880171064377636cd11b5e9fe0ce7c2a827.zip |
editKey: add support for sripping keys
Diffstat (limited to 'OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp')
-rw-r--r-- | OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpKeyOperation.java | 28 |
1 files changed, 26 insertions, 2 deletions
diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpKeyOperation.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpKeyOperation.java index 8b4f7dac9..9bfea2414 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpKeyOperation.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpKeyOperation.java @@ -709,7 +709,7 @@ public class PgpKeyOperation { // error log entry has already been added by updateMasterCertificates itself return new EditKeyResult(EditKeyResult.RESULT_ERROR, log, null); } - masterSecretKey = PGPSecretKey.replacePublicKey(masterSecretKey, pKey); + masterSecretKey = PGPSecretKey.replacePublicKey(sKey, pKey); masterPublicKey = pKey; sKR = PGPSecretKeyRing.insertSecretKey(sKR, masterSecretKey); continue; @@ -750,7 +750,7 @@ public class PgpKeyOperation { subProgressPop(); // 4b. For each subkey revocation, generate new subkey revocation certificate - subProgressPush(60, 70); + subProgressPush(60, 65); for (int i = 0; i < saveParcel.mRevokeSubKeys.size(); i++) { progress(R.string.progress_modify_subkeyrevoke, (i-1) * (100 / saveParcel.mRevokeSubKeys.size())); @@ -774,6 +774,30 @@ public class PgpKeyOperation { } subProgressPop(); + // 4c. For each subkey to be stripped... do so + subProgressPush(65, 70); + for (int i = 0; i < saveParcel.mStripSubKeys.size(); i++) { + + progress(R.string.progress_modify_subkeystrip, (i-1) * (100 / saveParcel.mStripSubKeys.size())); + long strip = saveParcel.mStripSubKeys.get(i); + log.add(LogLevel.INFO, LogType.MSG_MF_SUBKEY_STRIP, + indent, PgpKeyHelper.convertKeyIdToHex(strip)); + + PGPSecretKey sKey = sKR.getSecretKey(strip); + if (sKey == null) { + log.add(LogLevel.ERROR, LogType.MSG_MF_ERROR_SUBKEY_MISSING, + indent+1, PgpKeyHelper.convertKeyIdToHex(strip)); + return new EditKeyResult(EditKeyResult.RESULT_ERROR, log, null); + } + + // IT'S DANGEROUS~ + // no really, it is. this operation irrevocably removes the private key data from the key + sKey = PGPSecretKey.constructGnuDummyKey(sKey.getPublicKey()); + sKR = PGPSecretKeyRing.insertSecretKey(sKR, sKey); + + } + subProgressPop(); + // 5. Generate and add new subkeys subProgressPush(70, 90); for (int i = 0; i < saveParcel.mAddSubKeys.size(); i++) { |