diff options
| author | Vincent Breitmoser <valodim@mugenguild.com> | 2014-07-26 03:57:54 +0200 | 
|---|---|---|
| committer | Vincent Breitmoser <valodim@mugenguild.com> | 2014-07-26 03:57:54 +0200 | 
| commit | 7296ac484914bbe5cec90b37cc1319db49f7d9b8 (patch) | |
| tree | 7cc9ee2686020541676f8badc0db491afb47565a /OpenKeychain/src/main/java/org | |
| parent | 7fe1b00080ad7bcdbda890e9c2c60ad4a1225a9f (diff) | |
| download | open-keychain-7296ac484914bbe5cec90b37cc1319db49f7d9b8.tar.gz open-keychain-7296ac484914bbe5cec90b37cc1319db49f7d9b8.tar.bz2 open-keychain-7296ac484914bbe5cec90b37cc1319db49f7d9b8.zip | |
UncachedKeyRing.merge: copy over new secret subkeys into secret keyrings
Diffstat (limited to 'OpenKeychain/src/main/java/org')
| -rw-r--r-- | OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/UncachedKeyRing.java | 21 | 
1 files changed, 9 insertions, 12 deletions
| diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/UncachedKeyRing.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/UncachedKeyRing.java index 3b39eb201..91b06324a 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/UncachedKeyRing.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/UncachedKeyRing.java @@ -688,7 +688,14 @@ public class UncachedKeyRing {                  final PGPPublicKey resultKey = result.getPublicKey(key.getKeyID());                  if (resultKey == null) {                      log.add(LogLevel.DEBUG, LogType.MSG_MG_NEW_SUBKEY, indent); -                    result = replacePublicKey(result, key); +                    // special case: if both rings are secret, copy over the secret key +                    if (isSecret() && other.isSecret()) { +                        PGPSecretKey sKey = ((PGPSecretKeyRing) candidate).getSecretKey(key.getKeyID()); +                        result = PGPSecretKeyRing.insertSecretKey((PGPSecretKeyRing) result, sKey); +                    } else { +                        // otherwise, just insert the public key +                        result = replacePublicKey(result, key); +                    }                      continue;                  } @@ -696,17 +703,7 @@ public class UncachedKeyRing {                  PGPPublicKey modified = resultKey;                  // Iterate certifications -                for (PGPSignature cert : new IterableIterator<PGPSignature>(key.getSignatures())) { -                    int type = cert.getSignatureType(); -                    // Disregard certifications on user ids, we will deal with those later -                    if (type == PGPSignature.NO_CERTIFICATION -                            || type == PGPSignature.DEFAULT_CERTIFICATION -                            || type == PGPSignature.CASUAL_CERTIFICATION -                            || type == PGPSignature.POSITIVE_CERTIFICATION -                            || type == PGPSignature.CERTIFICATION_REVOCATION) { -                        continue; -                    } - +                for (PGPSignature cert : new IterableIterator<PGPSignature>(key.getKeySignatures())) {                      // Don't merge foreign stuff into secret keys                      if (cert.getKeyID() != masterKeyId && isSecret()) {                          continue; | 
