diff options
| author | Vincent Breitmoser <valodim@mugenguild.com> | 2014-07-26 03:56:28 +0200 | 
|---|---|---|
| committer | Vincent Breitmoser <valodim@mugenguild.com> | 2014-07-26 03:56:28 +0200 | 
| commit | 7fe1b00080ad7bcdbda890e9c2c60ad4a1225a9f (patch) | |
| tree | 51be2f9233d6ab12a50497e32f5a58a5dd7c5a29 /OpenKeychain/src/main/java/org | |
| parent | a1c163e993d057aa963960bc1e588ef67be90065 (diff) | |
| download | open-keychain-7fe1b00080ad7bcdbda890e9c2c60ad4a1225a9f.tar.gz open-keychain-7fe1b00080ad7bcdbda890e9c2c60ad4a1225a9f.tar.bz2 open-keychain-7fe1b00080ad7bcdbda890e9c2c60ad4a1225a9f.zip | |
fixes for extractPublicKeyRing, update SpongyCastle
Diffstat (limited to 'OpenKeychain/src/main/java/org')
| -rw-r--r-- | OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/UncachedKeyRing.java | 15 | ||||
| -rw-r--r-- | OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/WrappedPublicKeyRing.java | 18 | 
2 files changed, 18 insertions, 15 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 6020fc084..3b39eb201 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/UncachedKeyRing.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/UncachedKeyRing.java @@ -14,6 +14,7 @@ import org.spongycastle.openpgp.PGPSecretKeyRing;  import org.spongycastle.openpgp.PGPSignature;  import org.spongycastle.openpgp.PGPSignatureList;  import org.spongycastle.openpgp.PGPUtil; +import org.spongycastle.openpgp.operator.jcajce.JcaKeyFingerprintCalculator;  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.pgp.exception.PgpGeneralException;  import org.sufficientlysecure.keychain.service.OperationResultParcel.OperationLog; @@ -24,6 +25,7 @@ import org.sufficientlysecure.keychain.util.Log;  import java.io.BufferedInputStream;  import java.io.ByteArrayInputStream; +import java.io.ByteArrayOutputStream;  import java.io.IOException;  import java.io.InputStream;  import java.io.OutputStream; @@ -193,7 +195,7 @@ public class UncachedKeyRing {       *  - Remove all certificates flagged as "local"       *  - Remove all certificates which are superseded by a newer one on the same target,       *      including revocations with later re-certifications. -     *  - Remove all certificates of unknown type: +     *  - Remove all certificates in other positions if not of known type:       *   - key revocation signatures on the master key       *   - subkey binding signatures for subkeys       *   - certifications and certification revocations for user ids @@ -658,7 +660,7 @@ public class UncachedKeyRing {                      return left.length - right.length;                  }                  // compare byte-by-byte -                for (int i = 0; i < left.length && i < right.length; i++) { +                for (int i = 0; i < left.length; i++) {                      if (left[i] != right[i]) {                          return (left[i] & 0xff) - (right[i] & 0xff);                      } @@ -768,19 +770,20 @@ public class UncachedKeyRing {      } -    public UncachedKeyRing extractPublicKeyRing() { +    public UncachedKeyRing extractPublicKeyRing() throws IOException {          if(!isSecret()) {              throw new RuntimeException("Tried to extract public keyring from non-secret keyring. " +                      "This is a programming error and should never happen!");          } -        ArrayList<PGPPublicKey> keys = new ArrayList();          Iterator<PGPPublicKey> it = mRing.getPublicKeys(); +        ByteArrayOutputStream stream = new ByteArrayOutputStream(2048);          while (it.hasNext()) { -            keys.add(it.next()); +            stream.write(it.next().getEncoded());          } -        return new UncachedKeyRing(new PGPPublicKeyRing(keys)); +        return new UncachedKeyRing( +                new PGPPublicKeyRing(stream.toByteArray(), new JcaKeyFingerprintCalculator()));      }      /** This method replaces a public key in a keyring. diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/WrappedPublicKeyRing.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/WrappedPublicKeyRing.java index 57d84072a..bb1f7d778 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/WrappedPublicKeyRing.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/WrappedPublicKeyRing.java @@ -1,14 +1,11 @@  package org.sufficientlysecure.keychain.pgp;  import org.spongycastle.bcpg.ArmoredOutputStream; -import org.spongycastle.openpgp.PGPKeyRing;  import org.spongycastle.openpgp.PGPObjectFactory;  import org.spongycastle.openpgp.PGPPublicKey;  import org.spongycastle.openpgp.PGPPublicKeyRing; -import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.pgp.exception.PgpGeneralException;  import org.sufficientlysecure.keychain.util.IterableIterator; -import org.sufficientlysecure.keychain.util.Log;  import java.io.IOException;  import java.util.Iterator; @@ -25,17 +22,20 @@ public class WrappedPublicKeyRing extends WrappedKeyRing {      PGPPublicKeyRing getRing() {          if(mRing == null) { +            // get first object in block              PGPObjectFactory factory = new PGPObjectFactory(mPubKey); -            PGPKeyRing keyRing = null;              try { -                if ((keyRing = (PGPKeyRing) factory.nextObject()) == null) { -                    Log.e(Constants.TAG, "No keys given!"); +                Object obj = factory.nextObject(); +                if (! (obj instanceof PGPPublicKeyRing)) { +                    throw new RuntimeException("Error constructing WrappedPublicKeyRing, should never happen!"); +                } +                mRing = (PGPPublicKeyRing) obj; +                if (factory.nextObject() != null) { +                    throw new RuntimeException("Encountered trailing data after keyring, should never happen!");                  }              } catch (IOException e) { -                Log.e(Constants.TAG, "Error while converting to PGPKeyRing!", e); +                throw new RuntimeException("IO Error constructing WrappedPublicKeyRing, should never happen!");              } - -            mRing = (PGPPublicKeyRing) keyRing;          }          return mRing;      } | 
