diff options
Diffstat (limited to 'OpenKeychain/src')
88 files changed, 757 insertions, 838 deletions
| diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/keyimport/CloudSearch.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/keyimport/CloudSearch.java index 255ca1cde..3b281876f 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/keyimport/CloudSearch.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/keyimport/CloudSearch.java @@ -32,10 +32,10 @@ public class CloudSearch {      public static ArrayList<ImportKeysListEntry> search(final String query, Preferences.CloudSearchPrefs cloudPrefs)              throws Keyserver.CloudSearchFailureException { -        final ArrayList<Keyserver> servers = new ArrayList<Keyserver>(); +        final ArrayList<Keyserver> servers = new ArrayList<>();          // it's a Vector for sync, multiple threads might report problems -        final Vector<Keyserver.CloudSearchFailureException> problems = new Vector<Keyserver.CloudSearchFailureException>(); +        final Vector<Keyserver.CloudSearchFailureException> problems = new Vector<>();          if (cloudPrefs.searchKeyserver) {              servers.add(new HkpKeyserver(cloudPrefs.keyserver)); diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/keyimport/HkpKeyserver.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/keyimport/HkpKeyserver.java index 7f07b8162..f39c552a3 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/keyimport/HkpKeyserver.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/keyimport/HkpKeyserver.java @@ -234,7 +234,7 @@ public class HkpKeyserver extends Keyserver {      @Override      public ArrayList<ImportKeysListEntry> search(String query) throws QueryFailedException,              QueryNeedsRepairException { -        ArrayList<ImportKeysListEntry> results = new ArrayList<ImportKeysListEntry>(); +        ArrayList<ImportKeysListEntry> results = new ArrayList<>();          if (query.length() < 3) {              throw new QueryTooShortException(); @@ -305,7 +305,7 @@ public class HkpKeyserver extends Keyserver {              entry.setRevoked(matcher.group(6).contains("r"));              entry.setExpired(matcher.group(6).contains("e")); -            ArrayList<String> userIds = new ArrayList<String>(); +            ArrayList<String> userIds = new ArrayList<>();              final String uidLines = matcher.group(7);              final Matcher uidMatcher = UID_LINE.matcher(uidLines);              while (uidMatcher.find()) { diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/keyimport/ImportKeysListEntry.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/keyimport/ImportKeysListEntry.java index d60d7757b..1d5ee76a4 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/keyimport/ImportKeysListEntry.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/keyimport/ImportKeysListEntry.java @@ -89,7 +89,7 @@ public class ImportKeysListEntry implements Serializable, Parcelable {          public ImportKeysListEntry createFromParcel(final Parcel source) {              ImportKeysListEntry vr = new ImportKeysListEntry();              vr.mPrimaryUserId = source.readString(); -            vr.mUserIds = new ArrayList<String>(); +            vr.mUserIds = new ArrayList<>();              source.readStringList(vr.mUserIds);              vr.mMergedUserIds = (HashMap<String, HashSet<String>>) source.readSerializable();              vr.mKeyId = source.readLong(); @@ -103,7 +103,7 @@ public class ImportKeysListEntry implements Serializable, Parcelable {              vr.mSecretKey = source.readByte() == 1;              vr.mSelected = source.readByte() == 1;              vr.mExtraData = source.readString(); -            vr.mOrigins = new ArrayList<String>(); +            vr.mOrigins = new ArrayList<>();              source.readStringList(vr.mOrigins);              return vr; @@ -265,8 +265,8 @@ public class ImportKeysListEntry implements Serializable, Parcelable {          mSecretKey = false;          // do not select by default          mSelected = false; -        mUserIds = new ArrayList<String>(); -        mOrigins = new ArrayList<String>(); +        mUserIds = new ArrayList<>(); +        mOrigins = new ArrayList<>();      }      /** @@ -304,7 +304,7 @@ public class ImportKeysListEntry implements Serializable, Parcelable {      }      public void updateMergedUserIds() { -        mMergedUserIds = new HashMap<String, HashSet<String>>(); +        mMergedUserIds = new HashMap<>();          for (String userId : mUserIds) {              String[] userIdSplit = KeyRing.splitUserId(userId); @@ -315,7 +315,7 @@ public class ImportKeysListEntry implements Serializable, Parcelable {                  // email                  if (userIdSplit[1] != null) {                      if (!mMergedUserIds.containsKey(userIdSplit[0])) { -                        HashSet<String> emails = new HashSet<String>(); +                        HashSet<String> emails = new HashSet<>();                          emails.add(userIdSplit[1]);                          mMergedUserIds.put(userIdSplit[0], emails);                      } else { diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/keyimport/KeybaseKeyserver.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/keyimport/KeybaseKeyserver.java index 2363a40b3..e310e9a3f 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/keyimport/KeybaseKeyserver.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/keyimport/KeybaseKeyserver.java @@ -36,7 +36,7 @@ public class KeybaseKeyserver extends Keyserver {      @Override      public ArrayList<ImportKeysListEntry> search(String query) throws QueryFailedException,              QueryNeedsRepairException { -        ArrayList<ImportKeysListEntry> results = new ArrayList<ImportKeysListEntry>(); +        ArrayList<ImportKeysListEntry> results = new ArrayList<>();          if (query.startsWith("0x")) {              // cut off "0x" if a user is searching for a key id @@ -81,7 +81,7 @@ public class KeybaseKeyserver extends Keyserver {          final int algorithmId = match.getAlgorithmId();          entry.setAlgorithm(KeyFormattingUtils.getAlgorithmInfo(algorithmId, bitStrength, null)); -        ArrayList<String> userIds = new ArrayList<String>(); +        ArrayList<String> userIds = new ArrayList<>();          String name = "<keybase.io/" + username + ">";          if (fullName != null) {              name = fullName + " " + name; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/CertifyOperation.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/CertifyOperation.java index a5eb95b07..3b391814e 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/CertifyOperation.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/CertifyOperation.java @@ -78,7 +78,7 @@ public class CertifyOperation extends BaseOperation {              return new CertifyResult(CertifyResult.RESULT_ERROR, log);          } -        ArrayList<UncachedKeyRing> certifiedKeys = new ArrayList<UncachedKeyRing>(); +        ArrayList<UncachedKeyRing> certifiedKeys = new ArrayList<>();          log.add(LogType.MSG_CRT_CERTIFYING, 1); diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/EditKeyOperation.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/EditKeyOperation.java index ebbd45856..106c62688 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/EditKeyOperation.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/EditKeyOperation.java @@ -11,7 +11,6 @@ import org.sufficientlysecure.keychain.pgp.Progressable;  import org.sufficientlysecure.keychain.pgp.UncachedKeyRing;  import org.sufficientlysecure.keychain.provider.ProviderHelper;  import org.sufficientlysecure.keychain.provider.ProviderHelper.NotFoundException; -import org.sufficientlysecure.keychain.service.CertifyActionsParcel;  import org.sufficientlysecure.keychain.operations.results.OperationResult.LogType;  import org.sufficientlysecure.keychain.operations.results.OperationResult.OperationLog;  import org.sufficientlysecure.keychain.operations.results.SaveKeyringResult; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/ImportExportOperation.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/ImportExportOperation.java index 6ca28142f..cd8a33c20 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/ImportExportOperation.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/ImportExportOperation.java @@ -137,7 +137,7 @@ public class ImportExportOperation extends BaseOperation {          }          int newKeys = 0, oldKeys = 0, badKeys = 0, secret = 0; -        ArrayList<Long> importedMasterKeyIds = new ArrayList<Long>(); +        ArrayList<Long> importedMasterKeyIds = new ArrayList<>();          boolean cancelled = false;          int position = 0; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/results/OperationResult.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/results/OperationResult.java index b30552e49..d025727b5 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/results/OperationResult.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/operations/results/OperationResult.java @@ -735,7 +735,7 @@ public abstract class OperationResult implements Parcelable {      public static class OperationLog implements Iterable<LogEntryParcel> { -        private final List<LogEntryParcel> mParcels = new ArrayList<LogEntryParcel>(); +        private final List<LogEntryParcel> mParcels = new ArrayList<>();          /// Simple convenience method          public void add(LogType type, int indent, Object... parameters) { @@ -760,7 +760,7 @@ public abstract class OperationResult implements Parcelable {          }          public boolean containsType(LogType type) { -            for(LogEntryParcel entry : new IterableIterator<LogEntryParcel>(mParcels.iterator())) { +            for(LogEntryParcel entry : new IterableIterator<>(mParcels.iterator())) {                  if (entry.mType == type) {                      return true;                  } @@ -769,7 +769,7 @@ public abstract class OperationResult implements Parcelable {          }          public boolean containsWarnings() { -            for(LogEntryParcel entry : new IterableIterator<LogEntryParcel>(mParcels.iterator())) { +            for(LogEntryParcel entry : new IterableIterator<>(mParcels.iterator())) {                  if (entry.mType.mLevel == LogLevel.WARN || entry.mType.mLevel == LogLevel.ERROR) {                      return true;                  } diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/CanonicalizedKeyRing.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/CanonicalizedKeyRing.java index db0a9b137..bbf136dac 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/CanonicalizedKeyRing.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/CanonicalizedKeyRing.java @@ -19,7 +19,6 @@  package org.sufficientlysecure.keychain.pgp;  import org.spongycastle.openpgp.PGPKeyRing; -import org.sufficientlysecure.keychain.pgp.exception.PgpGeneralException;  import org.sufficientlysecure.keychain.pgp.exception.PgpKeyNotFoundException;  import org.sufficientlysecure.keychain.util.IterableIterator; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/CanonicalizedPublicKeyRing.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/CanonicalizedPublicKeyRing.java index b8379f007..c2506685d 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/CanonicalizedPublicKeyRing.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/CanonicalizedPublicKeyRing.java @@ -78,7 +78,7 @@ public class CanonicalizedPublicKeyRing extends CanonicalizedKeyRing {      public IterableIterator<CanonicalizedPublicKey> publicKeyIterator() {          @SuppressWarnings("unchecked")          final Iterator<PGPPublicKey> it = getRing().getPublicKeys(); -        return new IterableIterator<CanonicalizedPublicKey>(new Iterator<CanonicalizedPublicKey>() { +        return new IterableIterator<>(new Iterator<CanonicalizedPublicKey>() {              @Override              public boolean hasNext() {                  return it.hasNext(); diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/CanonicalizedSecretKey.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/CanonicalizedSecretKey.java index 6ccadac2e..cac5c1d97 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/CanonicalizedSecretKey.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/CanonicalizedSecretKey.java @@ -182,7 +182,7 @@ public class CanonicalizedSecretKey extends CanonicalizedPublicKey {       * @return       */      public LinkedList<Integer> getSupportedHashAlgorithms() { -        LinkedList<Integer> supported = new LinkedList<Integer>(); +        LinkedList<Integer> supported = new LinkedList<>();          if (mPrivateKeyState == PRIVATE_KEY_STATE_DIVERT_TO_CARD) {              // No support for MD5 @@ -262,11 +262,9 @@ public class CanonicalizedSecretKey extends CanonicalizedPublicKey {              spGen.setSignatureCreationTime(false, nfcCreationTimestamp);              signatureGenerator.setHashedSubpackets(spGen.generate());              return signatureGenerator; -        } catch (PgpKeyNotFoundException e) { +        } catch (PgpKeyNotFoundException | PGPException e) {              // TODO: simply throw PGPException!              throw new PgpGeneralException("Error initializing signature!", e); -        } catch (PGPException e) { -            throw new PgpGeneralException("Error initializing signature!", e);          }      } diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/CanonicalizedSecretKeyRing.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/CanonicalizedSecretKeyRing.java index eb589c3f9..b5f6a5b09 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/CanonicalizedSecretKeyRing.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/CanonicalizedSecretKeyRing.java @@ -18,27 +18,19 @@  package org.sufficientlysecure.keychain.pgp; -import org.spongycastle.bcpg.S2K; -import org.spongycastle.openpgp.PGPException;  import org.spongycastle.openpgp.PGPKeyRing;  import org.spongycastle.openpgp.PGPObjectFactory; -import org.spongycastle.openpgp.PGPPrivateKey;  import org.spongycastle.openpgp.PGPPublicKey;  import org.spongycastle.openpgp.PGPSecretKey;  import org.spongycastle.openpgp.PGPSecretKeyRing;  import org.spongycastle.openpgp.PGPSignature; -import org.spongycastle.openpgp.operator.PBESecretKeyDecryptor; -import org.spongycastle.openpgp.operator.jcajce.JcePBESecretKeyDecryptorBuilder;  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.pgp.exception.PgpGeneralException; -import org.sufficientlysecure.keychain.provider.KeychainContract; -import org.sufficientlysecure.keychain.provider.ProviderHelper;  import org.sufficientlysecure.keychain.util.IterableIterator;  import org.sufficientlysecure.keychain.util.Log;  import java.io.IOException;  import java.util.HashMap; -import java.util.HashSet;  import java.util.Iterator;  public class CanonicalizedSecretKeyRing extends CanonicalizedKeyRing { @@ -94,7 +86,7 @@ public class CanonicalizedSecretKeyRing extends CanonicalizedKeyRing {      public IterableIterator<CanonicalizedSecretKey> secretKeyIterator() {          final Iterator<PGPSecretKey> it = mRing.getSecretKeys(); -        return new IterableIterator<CanonicalizedSecretKey>(new Iterator<CanonicalizedSecretKey>() { +        return new IterableIterator<>(new Iterator<CanonicalizedSecretKey>() {              @Override              public boolean hasNext() {                  return it.hasNext(); @@ -114,7 +106,7 @@ public class CanonicalizedSecretKeyRing extends CanonicalizedKeyRing {      public IterableIterator<CanonicalizedPublicKey> publicKeyIterator() {          final Iterator<PGPPublicKey> it = getRing().getPublicKeys(); -        return new IterableIterator<CanonicalizedPublicKey>(new Iterator<CanonicalizedPublicKey>() { +        return new IterableIterator<>(new Iterator<CanonicalizedPublicKey>() {              @Override              public boolean hasNext() {                  return it.hasNext(); @@ -133,7 +125,7 @@ public class CanonicalizedSecretKeyRing extends CanonicalizedKeyRing {      }      public HashMap<String,String> getLocalNotationData() { -        HashMap<String,String> result = new HashMap<String,String>(); +        HashMap<String,String> result = new HashMap<>();          Iterator<PGPSignature> it = getRing().getPublicKey().getKeySignatures();          while (it.hasNext()) {              WrappedSignature sig = new WrappedSignature(it.next()); diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/OpenPgpSignatureResultBuilder.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/OpenPgpSignatureResultBuilder.java index aa324c7ed..ed4715681 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/OpenPgpSignatureResultBuilder.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/OpenPgpSignatureResultBuilder.java @@ -19,7 +19,6 @@ package org.sufficientlysecure.keychain.pgp;  import org.openintents.openpgp.OpenPgpSignatureResult;  import org.sufficientlysecure.keychain.Constants; -import org.sufficientlysecure.keychain.pgp.exception.PgpGeneralException;  import org.sufficientlysecure.keychain.pgp.exception.PgpKeyNotFoundException;  import org.sufficientlysecure.keychain.util.Log; @@ -33,7 +32,7 @@ public class OpenPgpSignatureResultBuilder {      // OpenPgpSignatureResult      private boolean mSignatureOnly = false;      private String mPrimaryUserId; -    private ArrayList<String> mUserIds = new ArrayList<String>(); +    private ArrayList<String> mUserIds = new ArrayList<>();      private long mKeyId;      // builder 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 bd7759d43..aebb52a03 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpKeyOperation.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpKeyOperation.java @@ -135,7 +135,7 @@ public class PgpKeyOperation {      public PgpKeyOperation(Progressable progress) {          super();          if (progress != null) { -            mProgress = new Stack<Progressable>(); +            mProgress = new Stack<>();              mProgress.push(progress);          }      } @@ -288,13 +288,11 @@ public class PgpKeyOperation {              // build new key pair              return new JcaPGPKeyPair(algorithm, keyGen.generateKeyPair(), new Date()); -        } catch(NoSuchProviderException e) { +        } catch(NoSuchProviderException | InvalidAlgorithmParameterException e) {              throw new RuntimeException(e);          } catch(NoSuchAlgorithmException e) {              log.add(LogType.MSG_CR_ERROR_UNKNOWN_ALGO, indent);              return null; -        } catch(InvalidAlgorithmParameterException e) { -            throw new RuntimeException(e);          } catch(PGPException e) {              Log.e(Constants.TAG, "internal pgp error", e);              log.add(LogType.MSG_CR_ERROR_INTERNAL_PGP, indent); @@ -504,7 +502,7 @@ public class PgpKeyOperation {                      @SuppressWarnings("unchecked")                      Iterator<PGPSignature> it = modifiedPublicKey.getSignaturesForID(userId);                      if (it != null) { -                        for (PGPSignature cert : new IterableIterator<PGPSignature>(it)) { +                        for (PGPSignature cert : new IterableIterator<>(it)) {                              if (cert.getKeyID() != masterPublicKey.getKeyID()) {                                  // foreign certificate?! error error error                                  log.add(LogType.MSG_MF_ERROR_INTEGRITY, indent); 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 04fb955fa..af85bd878 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/UncachedKeyRing.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/UncachedKeyRing.java @@ -445,7 +445,7 @@ public class UncachedKeyRing {                  }              } -            ArrayList<String> processedUserIds = new ArrayList<String>(); +            ArrayList<String> processedUserIds = new ArrayList<>();              for (byte[] rawUserId : new IterableIterator<byte[]>(masterKey.getRawUserIDs())) {                  String userId = Utf8Util.fromUTF8ByteArrayReplaceBadEncoding(rawUserId); @@ -470,7 +470,7 @@ public class UncachedKeyRing {                  @SuppressWarnings("unchecked")                  Iterator<PGPSignature> signaturesIt = masterKey.getSignaturesForID(rawUserId);                  if (signaturesIt != null) { -                    for (PGPSignature zert : new IterableIterator<PGPSignature>(signaturesIt)) { +                    for (PGPSignature zert : new IterableIterator<>(signaturesIt)) {                          WrappedSignature cert = new WrappedSignature(zert);                          long certId = cert.getKeyId(); @@ -635,7 +635,7 @@ public class UncachedKeyRing {                      @SuppressWarnings("unchecked")                      Iterator<PGPSignature> signaturesIt = masterKey.getSignaturesForUserAttribute(userAttribute);                      if (signaturesIt != null) { -                        for (PGPSignature zert : new IterableIterator<PGPSignature>(signaturesIt)) { +                        for (PGPSignature zert : new IterableIterator<>(signaturesIt)) {                              WrappedSignature cert = new WrappedSignature(zert);                              long certId = cert.getKeyId(); @@ -778,7 +778,7 @@ public class UncachedKeyRing {          }          // Keep track of ids we encountered so far -        Set<Long> knownIds = new HashSet<Long>(); +        Set<Long> knownIds = new HashSet<>();          // Process all keys          for (PGPPublicKey key : new IterableIterator<PGPPublicKey>(ring.getPublicKeys())) { @@ -1042,7 +1042,7 @@ public class UncachedKeyRing {          }          // remember which certs we already added. this is cheaper than semantic deduplication -        Set<byte[]> certs = new TreeSet<byte[]>(new Comparator<byte[]>() { +        Set<byte[]> certs = new TreeSet<>(new Comparator<byte[]>() {              public int compare(byte[] left, byte[] right) {                  // check for length equality                  if (left.length != right.length) { @@ -1124,7 +1124,7 @@ public class UncachedKeyRing {                      if (signaturesIt == null) {                          continue;                      } -                    for (PGPSignature cert : new IterableIterator<PGPSignature>(signaturesIt)) { +                    for (PGPSignature cert : new IterableIterator<>(signaturesIt)) {                          // Don't merge foreign stuff into secret keys                          if (cert.getKeyID() != masterKeyId && isSecret()) {                              continue; @@ -1149,7 +1149,7 @@ public class UncachedKeyRing {                      if (signaturesIt == null) {                          continue;                      } -                    for (PGPSignature cert : new IterableIterator<PGPSignature>(signaturesIt)) { +                    for (PGPSignature cert : new IterableIterator<>(signaturesIt)) {                          // Don't merge foreign stuff into secret keys                          if (cert.getKeyID() != masterKeyId && isSecret()) {                              continue; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/UncachedPublicKey.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/UncachedPublicKey.java index 1efc25076..0fe1ccdb6 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/UncachedPublicKey.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/UncachedPublicKey.java @@ -20,7 +20,6 @@ package org.sufficientlysecure.keychain.pgp;  import org.spongycastle.bcpg.ECPublicBCPGKey;  import org.spongycastle.bcpg.SignatureSubpacketTags; -import org.spongycastle.bcpg.sig.KeyFlags;  import org.spongycastle.openpgp.PGPPublicKey;  import org.spongycastle.openpgp.PGPSignature;  import org.spongycastle.openpgp.PGPSignatureSubpacketVector; @@ -136,7 +135,7 @@ public class UncachedPublicKey {                  continue;              } -            for (PGPSignature sig : new IterableIterator<PGPSignature>(signaturesIt)) { +            for (PGPSignature sig : new IterableIterator<>(signaturesIt)) {                  try {                      // if this is a revocation, this is not the user id @@ -200,7 +199,7 @@ public class UncachedPublicKey {      }      public ArrayList<String> getUnorderedUserIds() { -        ArrayList<String> userIds = new ArrayList<String>(); +        ArrayList<String> userIds = new ArrayList<>();          for (byte[] rawUserId : new IterableIterator<byte[]>(mPublicKey.getRawUserIDs())) {              // use our decoding method              userIds.add(Utf8Util.fromUTF8ByteArrayReplaceBadEncoding(rawUserId)); @@ -209,7 +208,7 @@ public class UncachedPublicKey {      }      public ArrayList<byte[]> getUnorderedRawUserIds() { -        ArrayList<byte[]> userIds = new ArrayList<byte[]>(); +        ArrayList<byte[]> userIds = new ArrayList<>();          for (byte[] userId : new IterableIterator<byte[]>(mPublicKey.getRawUserIDs())) {              userIds.add(userId);          } @@ -217,7 +216,7 @@ public class UncachedPublicKey {      }      public ArrayList<WrappedUserAttribute> getUnorderedUserAttributes() { -        ArrayList<WrappedUserAttribute> userAttributes = new ArrayList<WrappedUserAttribute>(); +        ArrayList<WrappedUserAttribute> userAttributes = new ArrayList<>();          for (PGPUserAttributeSubpacketVector userAttribute :                  new IterableIterator<PGPUserAttributeSubpacketVector>(mPublicKey.getUserAttributes())) {              userAttributes.add(new WrappedUserAttribute(userAttribute)); diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/WrappedSignature.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/WrappedSignature.java index cb03970e2..ade075d55 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/WrappedSignature.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/WrappedSignature.java @@ -36,7 +36,6 @@ import org.sufficientlysecure.keychain.pgp.exception.PgpGeneralException;  import org.sufficientlysecure.keychain.util.Log;  import java.io.IOException; -import java.security.SignatureException;  import java.util.ArrayList;  import java.util.Date;  import java.util.HashMap; @@ -80,7 +79,7 @@ public class WrappedSignature {      }      public ArrayList<WrappedSignature> getEmbeddedSignatures() { -        ArrayList<WrappedSignature> sigs = new ArrayList<WrappedSignature>(); +        ArrayList<WrappedSignature> sigs = new ArrayList<>();          if (!mSig.hasSubpackets()) {              return sigs;          } @@ -255,7 +254,7 @@ public class WrappedSignature {      }      public HashMap<String,String> getNotation() { -        HashMap<String,String> result = new HashMap<String,String>(); +        HashMap<String,String> result = new HashMap<>();          // If there is any notation data          if (mSig.getHashedSubPackets() != null diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/provider/KeychainProvider.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/provider/KeychainProvider.java index 29b9c5f9f..72475472e 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/provider/KeychainProvider.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/provider/KeychainProvider.java @@ -248,7 +248,7 @@ public class KeychainProvider extends ContentProvider {              case KEY_RINGS_UNIFIED:              case KEY_RINGS_FIND_BY_EMAIL:              case KEY_RINGS_FIND_BY_SUBKEY: { -                HashMap<String, String> projectionMap = new HashMap<String, String>(); +                HashMap<String, String> projectionMap = new HashMap<>();                  projectionMap.put(KeyRings._ID, Tables.KEYS + ".oid AS _id");                  projectionMap.put(KeyRings.MASTER_KEY_ID, Tables.KEYS + "." + Keys.MASTER_KEY_ID);                  projectionMap.put(KeyRings.KEY_ID, Tables.KEYS + "." + Keys.KEY_ID); @@ -432,7 +432,7 @@ public class KeychainProvider extends ContentProvider {              }              case KEY_RING_KEYS: { -                HashMap<String, String> projectionMap = new HashMap<String, String>(); +                HashMap<String, String> projectionMap = new HashMap<>();                  projectionMap.put(Keys._ID, Tables.KEYS + ".oid AS _id");                  projectionMap.put(Keys.MASTER_KEY_ID, Tables.KEYS + "." + Keys.MASTER_KEY_ID);                  projectionMap.put(Keys.RANK, Tables.KEYS + "." + Keys.RANK); @@ -460,7 +460,7 @@ public class KeychainProvider extends ContentProvider {              case KEY_RINGS_USER_IDS:              case KEY_RING_USER_IDS: { -                HashMap<String, String> projectionMap = new HashMap<String, String>(); +                HashMap<String, String> projectionMap = new HashMap<>();                  projectionMap.put(UserPackets._ID, Tables.USER_PACKETS + ".oid AS _id");                  projectionMap.put(UserPackets.MASTER_KEY_ID, Tables.USER_PACKETS + "." + UserPackets.MASTER_KEY_ID);                  projectionMap.put(UserPackets.TYPE, Tables.USER_PACKETS + "." + UserPackets.TYPE); @@ -507,7 +507,7 @@ public class KeychainProvider extends ContentProvider {              case KEY_RINGS_PUBLIC:              case KEY_RING_PUBLIC: { -                HashMap<String, String> projectionMap = new HashMap<String, String>(); +                HashMap<String, String> projectionMap = new HashMap<>();                  projectionMap.put(KeyRingData._ID, Tables.KEY_RINGS_PUBLIC + ".oid AS _id");                  projectionMap.put(KeyRingData.MASTER_KEY_ID, KeyRingData.MASTER_KEY_ID);                  projectionMap.put(KeyRingData.KEY_RING_DATA, KeyRingData.KEY_RING_DATA); @@ -525,7 +525,7 @@ public class KeychainProvider extends ContentProvider {              case KEY_RINGS_SECRET:              case KEY_RING_SECRET: { -                HashMap<String, String> projectionMap = new HashMap<String, String>(); +                HashMap<String, String> projectionMap = new HashMap<>();                  projectionMap.put(KeyRingData._ID, Tables.KEY_RINGS_SECRET + ".oid AS _id");                  projectionMap.put(KeyRingData.MASTER_KEY_ID, KeyRingData.MASTER_KEY_ID);                  projectionMap.put(KeyRingData.KEY_RING_DATA, KeyRingData.KEY_RING_DATA); @@ -543,7 +543,7 @@ public class KeychainProvider extends ContentProvider {              case KEY_RING_CERTS:              case KEY_RING_CERTS_SPECIFIC: { -                HashMap<String, String> projectionMap = new HashMap<String, String>(); +                HashMap<String, String> projectionMap = new HashMap<>();                  projectionMap.put(Certs._ID, Tables.CERTS + ".oid AS " + Certs._ID);                  projectionMap.put(Certs.MASTER_KEY_ID, Tables.CERTS + "." + Certs.MASTER_KEY_ID);                  projectionMap.put(Certs.RANK, Tables.CERTS + "." + Certs.RANK); diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/provider/ProviderHelper.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/provider/ProviderHelper.java index b2af5a0a0..a229f454f 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/provider/ProviderHelper.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/provider/ProviderHelper.java @@ -170,7 +170,7 @@ public class ProviderHelper {          Cursor cursor = mContentResolver.query(uri, proj, selection, null, null);          try { -            HashMap<String, Object> result = new HashMap<String, Object>(proj.length); +            HashMap<String, Object> result = new HashMap<>(proj.length);              if (cursor != null && cursor.moveToFirst()) {                  int pos = 0;                  for (String p : proj) { @@ -221,7 +221,7 @@ public class ProviderHelper {          }, KeyRings.HAS_ANY_SECRET + " = 1", null, null);          try { -            LongSparseArray<CanonicalizedPublicKey> result = new LongSparseArray<CanonicalizedPublicKey>(); +            LongSparseArray<CanonicalizedPublicKey> result = new LongSparseArray<>();              if (cursor != null && cursor.moveToFirst()) do {                  long masterKeyId = cursor.getLong(0); @@ -350,7 +350,7 @@ public class ProviderHelper {              mIndent += 1;              // save all keys and userIds included in keyRing object in database -            operations = new ArrayList<ContentProviderOperation>(); +            operations = new ArrayList<>();              log(LogType.MSG_IP_INSERT_KEYRING);              { // insert keyring @@ -440,7 +440,7 @@ public class ProviderHelper {              // classify and order user ids. primary are moved to the front, revoked to the back,              // otherwise the order in the keyfile is preserved. -            List<UserPacketItem> uids = new ArrayList<UserPacketItem>(); +            List<UserPacketItem> uids = new ArrayList<>();              if (trustedKeys.size() == 0) {                  log(LogType.MSG_IP_UID_CLASSIFYING_ZERO); @@ -460,7 +460,7 @@ public class ProviderHelper {                  log(LogType.MSG_IP_UID_PROCESSING, userId);                  mIndent += 1;                  // look through signatures for this specific key -                for (WrappedSignature cert : new IterableIterator<WrappedSignature>( +                for (WrappedSignature cert : new IterableIterator<>(                          masterKey.getSignaturesForRawId(rawUserId))) {                      long certId = cert.getKeyId();                      // self signature @@ -560,7 +560,7 @@ public class ProviderHelper {                  }                  mIndent += 1;                  // look through signatures for this specific key -                for (WrappedSignature cert : new IterableIterator<WrappedSignature>( +                for (WrappedSignature cert : new IterableIterator<>(                          masterKey.getSignaturesForUserAttribute(userAttribute))) {                      long certId = cert.getKeyId();                      // self signature @@ -712,7 +712,7 @@ public class ProviderHelper {          boolean isPrimary = false;          boolean isRevoked = false;          WrappedSignature selfCert; -        LongSparseArray<WrappedSignature> trustedCerts = new LongSparseArray<WrappedSignature>(); +        LongSparseArray<WrappedSignature> trustedCerts = new LongSparseArray<>();          @Override          public int compareTo(UserPacketItem o) { @@ -1075,7 +1075,7 @@ public class ProviderHelper {              // No keys existing might be a legitimate option, we write an empty file in that case              cursor.moveToFirst();              ParcelableFileCache<ParcelableKeyRing> cache = -                    new ParcelableFileCache<ParcelableKeyRing>(mContext, "consolidate_secret.pcl"); +                    new ParcelableFileCache<>(mContext, "consolidate_secret.pcl");              cache.writeCache(cursor.getCount(), new Iterator<ParcelableKeyRing>() {                  ParcelableKeyRing ring; @@ -1137,7 +1137,7 @@ public class ProviderHelper {              // No keys existing might be a legitimate option, we write an empty file in that case              cursor.moveToFirst();              ParcelableFileCache<ParcelableKeyRing> cache = -                    new ParcelableFileCache<ParcelableKeyRing>(mContext, "consolidate_public.pcl"); +                    new ParcelableFileCache<>(mContext, "consolidate_public.pcl");              cache.writeCache(cursor.getCount(), new Iterator<ParcelableKeyRing>() {                  ParcelableKeyRing ring; @@ -1220,9 +1220,9 @@ public class ProviderHelper {              mContentResolver.delete(KeyRings.buildUnifiedKeyRingsUri(), null, null);              ParcelableFileCache<ParcelableKeyRing> cacheSecret = -                    new ParcelableFileCache<ParcelableKeyRing>(mContext, "consolidate_secret.pcl"); +                    new ParcelableFileCache<>(mContext, "consolidate_secret.pcl");              ParcelableFileCache<ParcelableKeyRing> cachePublic = -                    new ParcelableFileCache<ParcelableKeyRing>(mContext, "consolidate_public.pcl"); +                    new ParcelableFileCache<>(mContext, "consolidate_public.pcl");              // Set flag that we have a cached consolidation here              try { @@ -1380,7 +1380,7 @@ public class ProviderHelper {      public ArrayList<String> getRegisteredApiApps() {          Cursor cursor = mContentResolver.query(ApiApps.CONTENT_URI, null, null, null, null); -        ArrayList<String> packageNames = new ArrayList<String>(); +        ArrayList<String> packageNames = new ArrayList<>();          try {              if (cursor != null) {                  int packageNameCol = cursor.getColumnIndex(ApiApps.PACKAGE_NAME); @@ -1485,7 +1485,7 @@ public class ProviderHelper {      }      public Set<Long> getAllKeyIdsForApp(Uri uri) { -        Set<Long> keyIds = new HashSet<Long>(); +        Set<Long> keyIds = new HashSet<>();          Cursor cursor = mContentResolver.query(uri, null, null, null, null);          try { @@ -1505,7 +1505,7 @@ public class ProviderHelper {      }      public Set<String> getAllFingerprints(Uri uri) { -         Set<String> fingerprints = new HashSet<String>(); +         Set<String> fingerprints = new HashSet<>();           String[] projection = new String[]{KeyRings.FINGERPRINT};           Cursor cursor = mContentResolver.query(uri, projection, null, null, null);           try { diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/OpenPgpService.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/OpenPgpService.java index a5813567a..9534cc49d 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/OpenPgpService.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/OpenPgpService.java @@ -85,9 +85,9 @@ public class OpenPgpService extends RemoteService {          boolean missingUserIdsCheck = false;          boolean duplicateUserIdsCheck = false; -        ArrayList<Long> keyIds = new ArrayList<Long>(); -        ArrayList<String> missingUserIds = new ArrayList<String>(); -        ArrayList<String> duplicateUserIds = new ArrayList<String>(); +        ArrayList<Long> keyIds = new ArrayList<>(); +        ArrayList<String> missingUserIds = new ArrayList<>(); +        ArrayList<String> duplicateUserIds = new ArrayList<>();          if (!noUserIdsCheck) {              for (String email : encryptionUserIds) {                  // try to find the key for this specific email @@ -718,30 +718,33 @@ public class OpenPgpService extends RemoteService {              }              String action = data.getAction(); -            if (OpenPgpApi.ACTION_SIGN.equals(action)) { -                return signImpl(data, input, output, accSettings); -            } else if (OpenPgpApi.ACTION_ENCRYPT.equals(action)) { -                return encryptAndSignImpl(data, input, output, accSettings, false); -            } else if (OpenPgpApi.ACTION_SIGN_AND_ENCRYPT.equals(action)) { -                return encryptAndSignImpl(data, input, output, accSettings, true); -            } else if (OpenPgpApi.ACTION_DECRYPT_VERIFY.equals(action)) { -                String currentPkg = getCurrentCallingPackage(); -                Set<Long> allowedKeyIds = -                        mProviderHelper.getAllKeyIdsForApp( -                                ApiAccounts.buildBaseUri(currentPkg)); -                return decryptAndVerifyImpl(data, input, output, allowedKeyIds, false); -            } else if (OpenPgpApi.ACTION_DECRYPT_METADATA.equals(action)) { -                String currentPkg = getCurrentCallingPackage(); -                Set<Long> allowedKeyIds = -                        mProviderHelper.getAllKeyIdsForApp( -                                ApiAccounts.buildBaseUri(currentPkg)); -                return decryptAndVerifyImpl(data, input, output, allowedKeyIds, true); -            } else if (OpenPgpApi.ACTION_GET_KEY.equals(action)) { -                return getKeyImpl(data); -            } else if (OpenPgpApi.ACTION_GET_KEY_IDS.equals(action)) { -                return getKeyIdsImpl(data); -            } else { -                return null; +            switch (action) { +                case OpenPgpApi.ACTION_SIGN: +                    return signImpl(data, input, output, accSettings); +                case OpenPgpApi.ACTION_ENCRYPT: +                    return encryptAndSignImpl(data, input, output, accSettings, false); +                case OpenPgpApi.ACTION_SIGN_AND_ENCRYPT: +                    return encryptAndSignImpl(data, input, output, accSettings, true); +                case OpenPgpApi.ACTION_DECRYPT_VERIFY: { +                    String currentPkg = getCurrentCallingPackage(); +                    Set<Long> allowedKeyIds = +                            mProviderHelper.getAllKeyIdsForApp( +                                    ApiAccounts.buildBaseUri(currentPkg)); +                    return decryptAndVerifyImpl(data, input, output, allowedKeyIds, false); +                } +                case OpenPgpApi.ACTION_DECRYPT_METADATA: { +                    String currentPkg = getCurrentCallingPackage(); +                    Set<Long> allowedKeyIds = +                            mProviderHelper.getAllKeyIdsForApp( +                                    ApiAccounts.buildBaseUri(currentPkg)); +                    return decryptAndVerifyImpl(data, input, output, allowedKeyIds, true); +                } +                case OpenPgpApi.ACTION_GET_KEY: +                    return getKeyImpl(data); +                case OpenPgpApi.ACTION_GET_KEY_IDS: +                    return getKeyIdsImpl(data); +                default: +                    return null;              }          } diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/RemoteService.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/RemoteService.java index e71b52ccd..672f59285 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/RemoteService.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/RemoteService.java @@ -27,7 +27,6 @@ import android.content.pm.PackageManager.NameNotFoundException;  import android.content.pm.Signature;  import android.net.Uri;  import android.os.Binder; -import android.text.TextUtils;  import org.openintents.openpgp.OpenPgpError;  import org.openintents.openpgp.util.OpenPgpApi; @@ -216,9 +215,7 @@ public abstract class RemoteService extends Service {          String[] callingPackages = getPackageManager().getPackagesForUid(uid);          // is calling package allowed to use this service? -        for (int i = 0; i < callingPackages.length; i++) { -            String currentPkg = callingPackages[i]; - +        for (String currentPkg : callingPackages) {              if (isPackageAllowed(currentPkg)) {                  return true;              } diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/ui/AccountSettingsActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/ui/AccountSettingsActivity.java index 7d77a989d..2751db370 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/ui/AccountSettingsActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/ui/AccountSettingsActivity.java @@ -20,7 +20,6 @@ package org.sufficientlysecure.keychain.remote.ui;  import android.content.Intent;  import android.net.Uri;  import android.os.Bundle; -import android.support.v7.app.ActionBarActivity;  import android.view.Menu;  import android.view.MenuItem;  import android.view.View; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/ui/AppSettingsActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/ui/AppSettingsActivity.java index d84a03698..e91482e28 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/ui/AppSettingsActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/ui/AppSettingsActivity.java @@ -22,8 +22,6 @@ import android.content.pm.ApplicationInfo;  import android.content.pm.PackageManager;  import android.net.Uri;  import android.os.Bundle; -import android.support.v7.app.ActionBar; -import android.support.v7.app.ActionBarActivity;  import android.view.Menu;  import android.view.MenuItem; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/ui/RemoteServiceActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/ui/RemoteServiceActivity.java index a9a7c75f5..447f02b55 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/ui/RemoteServiceActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/remote/ui/RemoteServiceActivity.java @@ -22,7 +22,6 @@ import android.graphics.Color;  import android.graphics.Typeface;  import android.net.Uri;  import android.os.Bundle; -import android.support.v7.app.ActionBarActivity;  import android.text.Spannable;  import android.text.SpannableString;  import android.text.SpannableStringBuilder; @@ -108,234 +107,244 @@ public class RemoteServiceActivity extends BaseActivity {          final Bundle extras = intent.getExtras(); -        if (ACTION_REGISTER.equals(action)) { -            final String packageName = extras.getString(EXTRA_PACKAGE_NAME); -            final byte[] packageSignature = extras.getByteArray(EXTRA_PACKAGE_SIGNATURE); -            Log.d(Constants.TAG, "ACTION_REGISTER packageName: " + packageName); +        switch (action) { +            case ACTION_REGISTER: { +                final String packageName = extras.getString(EXTRA_PACKAGE_NAME); +                final byte[] packageSignature = extras.getByteArray(EXTRA_PACKAGE_SIGNATURE); +                Log.d(Constants.TAG, "ACTION_REGISTER packageName: " + packageName); -            setContentView(R.layout.api_remote_register_app); -            initToolbar(); +                setContentView(R.layout.api_remote_register_app); +                initToolbar(); -            mAppSettingsFragment = (AppSettingsFragment) getSupportFragmentManager().findFragmentById( -                    R.id.api_app_settings_fragment); +                mAppSettingsFragment = (AppSettingsFragment) getSupportFragmentManager().findFragmentById( +                        R.id.api_app_settings_fragment); -            AppSettings settings = new AppSettings(packageName, packageSignature); -            mAppSettingsFragment.setAppSettings(settings); +                AppSettings settings = new AppSettings(packageName, packageSignature); +                mAppSettingsFragment.setAppSettings(settings); -            // Inflate a "Done"/"Cancel" custom action bar view -            ActionBarHelper.setTwoButtonView(getSupportActionBar(), -                    R.string.api_register_allow, R.drawable.ic_action_done, -                    new View.OnClickListener() { -                        @Override -                        public void onClick(View v) { -                            // Allow +                // Inflate a "Done"/"Cancel" custom action bar view +                ActionBarHelper.setTwoButtonView(getSupportActionBar(), +                        R.string.api_register_allow, R.drawable.ic_action_done, +                        new View.OnClickListener() { +                            @Override +                            public void onClick(View v) { +                                // Allow -                            mProviderHelper.insertApiApp(mAppSettingsFragment.getAppSettings()); +                                mProviderHelper.insertApiApp(mAppSettingsFragment.getAppSettings()); -                            // give data through for new service call -                            Intent resultData = extras.getParcelable(EXTRA_DATA); -                            RemoteServiceActivity.this.setResult(RESULT_OK, resultData); -                            RemoteServiceActivity.this.finish(); -                        } -                    }, R.string.api_register_disallow, R.drawable.ic_action_cancel, -                    new View.OnClickListener() { -                        @Override -                        public void onClick(View v) { -                            // Disallow -                            RemoteServiceActivity.this.setResult(RESULT_CANCELED); -                            RemoteServiceActivity.this.finish(); +                                // give data through for new service call +                                Intent resultData = extras.getParcelable(EXTRA_DATA); +                                RemoteServiceActivity.this.setResult(RESULT_OK, resultData); +                                RemoteServiceActivity.this.finish(); +                            } +                        }, R.string.api_register_disallow, R.drawable.ic_action_cancel, +                        new View.OnClickListener() { +                            @Override +                            public void onClick(View v) { +                                // Disallow +                                RemoteServiceActivity.this.setResult(RESULT_CANCELED); +                                RemoteServiceActivity.this.finish(); +                            }                          } -                    } -            ); -        } else if (ACTION_CREATE_ACCOUNT.equals(action)) { -            final String packageName = extras.getString(EXTRA_PACKAGE_NAME); -            final String accName = extras.getString(EXTRA_ACC_NAME); +                ); +                break; +            } +            case ACTION_CREATE_ACCOUNT: { +                final String packageName = extras.getString(EXTRA_PACKAGE_NAME); +                final String accName = extras.getString(EXTRA_ACC_NAME); -            setContentView(R.layout.api_remote_create_account); -            initToolbar(); +                setContentView(R.layout.api_remote_create_account); +                initToolbar(); -            mAccSettingsFragment = (AccountSettingsFragment) getSupportFragmentManager().findFragmentById( -                    R.id.api_account_settings_fragment); +                mAccSettingsFragment = (AccountSettingsFragment) getSupportFragmentManager().findFragmentById( +                        R.id.api_account_settings_fragment); -            TextView text = (TextView) findViewById(R.id.api_remote_create_account_text); +                TextView text = (TextView) findViewById(R.id.api_remote_create_account_text); -            // update existing? -            Uri uri = KeychainContract.ApiAccounts.buildByPackageAndAccountUri(packageName, accName); -            AccountSettings settings = mProviderHelper.getApiAccountSettings(uri); -            if (settings == null) { -                // create new account -                settings = new AccountSettings(accName); -                mUpdateExistingAccount = false; +                // update existing? +                Uri uri = KeychainContract.ApiAccounts.buildByPackageAndAccountUri(packageName, accName); +                AccountSettings settings = mProviderHelper.getApiAccountSettings(uri); +                if (settings == null) { +                    // create new account +                    settings = new AccountSettings(accName); +                    mUpdateExistingAccount = false; -                text.setText(R.string.api_create_account_text); -            } else { -                // update existing account -                mUpdateExistingAccount = true; +                    text.setText(R.string.api_create_account_text); +                } else { +                    // update existing account +                    mUpdateExistingAccount = true; -                text.setText(R.string.api_update_account_text); -            } -            mAccSettingsFragment.setAccSettings(settings); - -            // Inflate a "Done"/"Cancel" custom action bar view -            ActionBarHelper.setTwoButtonView(getSupportActionBar(), -                    R.string.api_settings_save, R.drawable.ic_action_done, -                    new View.OnClickListener() { -                        @Override -                        public void onClick(View v) { -                            // Save - -                            // user needs to select a key if it has explicitly requested (None is only allowed for new accounts) -                            if (mUpdateExistingAccount && mAccSettingsFragment.getAccSettings().getKeyId() == Constants.key.none) { -                                Notify.showNotify(RemoteServiceActivity.this, getString(R.string.api_register_error_select_key), Notify.Style.ERROR); -                            } else { -                                if (mUpdateExistingAccount) { -                                    Uri baseUri = KeychainContract.ApiAccounts.buildBaseUri(packageName); -                                    Uri accountUri = baseUri.buildUpon().appendEncodedPath(accName).build(); -                                    mProviderHelper.updateApiAccount( -                                            accountUri, -                                            mAccSettingsFragment.getAccSettings()); +                    text.setText(R.string.api_update_account_text); +                } +                mAccSettingsFragment.setAccSettings(settings); + +                // Inflate a "Done"/"Cancel" custom action bar view +                ActionBarHelper.setTwoButtonView(getSupportActionBar(), +                        R.string.api_settings_save, R.drawable.ic_action_done, +                        new View.OnClickListener() { +                            @Override +                            public void onClick(View v) { +                                // Save + +                                // user needs to select a key if it has explicitly requested (None is only allowed for new accounts) +                                if (mUpdateExistingAccount && mAccSettingsFragment.getAccSettings().getKeyId() == Constants.key.none) { +                                    Notify.showNotify(RemoteServiceActivity.this, getString(R.string.api_register_error_select_key), Notify.Style.ERROR);                                  } else { -                                    mProviderHelper.insertApiAccount( -                                            KeychainContract.ApiAccounts.buildBaseUri(packageName), -                                            mAccSettingsFragment.getAccSettings()); +                                    if (mUpdateExistingAccount) { +                                        Uri baseUri = KeychainContract.ApiAccounts.buildBaseUri(packageName); +                                        Uri accountUri = baseUri.buildUpon().appendEncodedPath(accName).build(); +                                        mProviderHelper.updateApiAccount( +                                                accountUri, +                                                mAccSettingsFragment.getAccSettings()); +                                    } else { +                                        mProviderHelper.insertApiAccount( +                                                KeychainContract.ApiAccounts.buildBaseUri(packageName), +                                                mAccSettingsFragment.getAccSettings()); +                                    } + +                                    // give data through for new service call +                                    Intent resultData = extras.getParcelable(EXTRA_DATA); +                                    RemoteServiceActivity.this.setResult(RESULT_OK, resultData); +                                    RemoteServiceActivity.this.finish();                                  } - -                                // give data through for new service call -                                Intent resultData = extras.getParcelable(EXTRA_DATA); -                                RemoteServiceActivity.this.setResult(RESULT_OK, resultData); +                            } +                        }, R.string.api_settings_cancel, R.drawable.ic_action_cancel, +                        new View.OnClickListener() { +                            @Override +                            public void onClick(View v) { +                                // Cancel +                                RemoteServiceActivity.this.setResult(RESULT_CANCELED);                                  RemoteServiceActivity.this.finish();                              }                          } -                    }, R.string.api_settings_cancel, R.drawable.ic_action_cancel, -                    new View.OnClickListener() { -                        @Override -                        public void onClick(View v) { -                            // Cancel -                            RemoteServiceActivity.this.setResult(RESULT_CANCELED); -                            RemoteServiceActivity.this.finish(); -                        } +                ); + +                break; +            } +            case ACTION_SELECT_PUB_KEYS: { +                long[] selectedMasterKeyIds = intent.getLongArrayExtra(EXTRA_SELECTED_MASTER_KEY_IDS); +                boolean noUserIdsCheck = intent.getBooleanExtra(EXTRA_NO_USER_IDS_CHECK, true); +                ArrayList<String> missingUserIds = intent +                        .getStringArrayListExtra(EXTRA_MISSING_USER_IDS); +                ArrayList<String> dublicateUserIds = intent +                        .getStringArrayListExtra(EXTRA_DUPLICATE_USER_IDS); + +                SpannableStringBuilder ssb = new SpannableStringBuilder(); +                final SpannableString textIntro = new SpannableString( +                        noUserIdsCheck ? getString(R.string.api_select_pub_keys_text_no_user_ids) +                                : getString(R.string.api_select_pub_keys_text) +                ); +                textIntro.setSpan(new StyleSpan(Typeface.BOLD), 0, textIntro.length(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE); +                ssb.append(textIntro); + +                if (missingUserIds != null && missingUserIds.size() > 0) { +                    ssb.append("\n\n"); +                    ssb.append(getString(R.string.api_select_pub_keys_missing_text)); +                    ssb.append("\n"); +                    for (String userId : missingUserIds) { +                        SpannableString ss = new SpannableString(userId + "\n"); +                        ss.setSpan(new BulletSpan(15, Color.BLACK), 0, ss.length(), +                                Spannable.SPAN_EXCLUSIVE_EXCLUSIVE); +                        ssb.append(ss);                      } -            ); - -        } else if (ACTION_SELECT_PUB_KEYS.equals(action)) { -            long[] selectedMasterKeyIds = intent.getLongArrayExtra(EXTRA_SELECTED_MASTER_KEY_IDS); -            boolean noUserIdsCheck = intent.getBooleanExtra(EXTRA_NO_USER_IDS_CHECK, true); -            ArrayList<String> missingUserIds = intent -                    .getStringArrayListExtra(EXTRA_MISSING_USER_IDS); -            ArrayList<String> dublicateUserIds = intent -                    .getStringArrayListExtra(EXTRA_DUPLICATE_USER_IDS); - -            SpannableStringBuilder ssb = new SpannableStringBuilder(); -            final SpannableString textIntro = new SpannableString( -                    noUserIdsCheck ? getString(R.string.api_select_pub_keys_text_no_user_ids) -                            : getString(R.string.api_select_pub_keys_text) -            ); -            textIntro.setSpan(new StyleSpan(Typeface.BOLD), 0, textIntro.length(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE); -            ssb.append(textIntro); - -            if (missingUserIds != null && missingUserIds.size() > 0) { -                ssb.append("\n\n"); -                ssb.append(getString(R.string.api_select_pub_keys_missing_text)); -                ssb.append("\n"); -                for (String userId : missingUserIds) { -                    SpannableString ss = new SpannableString(userId + "\n"); -                    ss.setSpan(new BulletSpan(15, Color.BLACK), 0, ss.length(), -                            Spannable.SPAN_EXCLUSIVE_EXCLUSIVE); -                    ssb.append(ss);                  } -            } -            if (dublicateUserIds != null && dublicateUserIds.size() > 0) { -                ssb.append("\n\n"); -                ssb.append(getString(R.string.api_select_pub_keys_dublicates_text)); -                ssb.append("\n"); -                for (String userId : dublicateUserIds) { -                    SpannableString ss = new SpannableString(userId + "\n"); -                    ss.setSpan(new BulletSpan(15, Color.BLACK), 0, ss.length(), -                            Spannable.SPAN_EXCLUSIVE_EXCLUSIVE); -                    ssb.append(ss); +                if (dublicateUserIds != null && dublicateUserIds.size() > 0) { +                    ssb.append("\n\n"); +                    ssb.append(getString(R.string.api_select_pub_keys_dublicates_text)); +                    ssb.append("\n"); +                    for (String userId : dublicateUserIds) { +                        SpannableString ss = new SpannableString(userId + "\n"); +                        ss.setSpan(new BulletSpan(15, Color.BLACK), 0, ss.length(), +                                Spannable.SPAN_EXCLUSIVE_EXCLUSIVE); +                        ssb.append(ss); +                    }                  } -            } -            setContentView(R.layout.api_remote_select_pub_keys); -            initToolbar(); - -            // Inflate a "Done"/"Cancel" custom action bar view -            ActionBarHelper.setTwoButtonView(getSupportActionBar(), -                    R.string.btn_okay, R.drawable.ic_action_done, -                    new View.OnClickListener() { -                        @Override -                        public void onClick(View v) { -                            // add key ids to params Bundle for new request -                            Intent resultData = extras.getParcelable(EXTRA_DATA); -                            resultData.putExtra(OpenPgpApi.EXTRA_KEY_IDS, -                                    mSelectFragment.getSelectedMasterKeyIds()); - -                            RemoteServiceActivity.this.setResult(RESULT_OK, resultData); -                            RemoteServiceActivity.this.finish(); -                        } -                    }, R.string.btn_do_not_save, R.drawable.ic_action_cancel, new View.OnClickListener() { -                        @Override -                        public void onClick(View v) { -                            // cancel -                            RemoteServiceActivity.this.setResult(RESULT_CANCELED); -                            RemoteServiceActivity.this.finish(); +                setContentView(R.layout.api_remote_select_pub_keys); +                initToolbar(); + +                // Inflate a "Done"/"Cancel" custom action bar view +                ActionBarHelper.setTwoButtonView(getSupportActionBar(), +                        R.string.btn_okay, R.drawable.ic_action_done, +                        new View.OnClickListener() { +                            @Override +                            public void onClick(View v) { +                                // add key ids to params Bundle for new request +                                Intent resultData = extras.getParcelable(EXTRA_DATA); +                                resultData.putExtra(OpenPgpApi.EXTRA_KEY_IDS, +                                        mSelectFragment.getSelectedMasterKeyIds()); + +                                RemoteServiceActivity.this.setResult(RESULT_OK, resultData); +                                RemoteServiceActivity.this.finish(); +                            } +                        }, R.string.btn_do_not_save, R.drawable.ic_action_cancel, new View.OnClickListener() { +                            @Override +                            public void onClick(View v) { +                                // cancel +                                RemoteServiceActivity.this.setResult(RESULT_CANCELED); +                                RemoteServiceActivity.this.finish(); +                            }                          } -                    } -            ); +                ); -            // set text on view -            TextView textView = (TextView) findViewById(R.id.api_select_pub_keys_text); -            textView.setText(ssb, TextView.BufferType.SPANNABLE); +                // set text on view +                TextView textView = (TextView) findViewById(R.id.api_select_pub_keys_text); +                textView.setText(ssb, TextView.BufferType.SPANNABLE); -            /* Load select pub keys fragment */ -            // Check that the activity is using the layout version with -            // the fragment_container FrameLayout -            if (findViewById(R.id.api_select_pub_keys_fragment_container) != null) { +                /* Load select pub keys fragment */ +                // Check that the activity is using the layout version with +                // the fragment_container FrameLayout +                if (findViewById(R.id.api_select_pub_keys_fragment_container) != null) { -                // However, if we're being restored from a previous state, -                // then we don't need to do anything and should return or else -                // we could end up with overlapping fragments. -                if (savedInstanceState != null) { -                    return; -                } +                    // However, if we're being restored from a previous state, +                    // then we don't need to do anything and should return or else +                    // we could end up with overlapping fragments. +                    if (savedInstanceState != null) { +                        return; +                    } -                // Create an instance of the fragment -                mSelectFragment = SelectPublicKeyFragment.newInstance(selectedMasterKeyIds); +                    // Create an instance of the fragment +                    mSelectFragment = SelectPublicKeyFragment.newInstance(selectedMasterKeyIds); -                // Add the fragment to the 'fragment_container' FrameLayout -                getSupportFragmentManager().beginTransaction() -                        .add(R.id.api_select_pub_keys_fragment_container, mSelectFragment).commit(); +                    // Add the fragment to the 'fragment_container' FrameLayout +                    getSupportFragmentManager().beginTransaction() +                            .add(R.id.api_select_pub_keys_fragment_container, mSelectFragment).commit(); +                } +                break;              } -        } else if (ACTION_ERROR_MESSAGE.equals(action)) { -            String errorMessage = intent.getStringExtra(EXTRA_ERROR_MESSAGE); +            case ACTION_ERROR_MESSAGE: { +                String errorMessage = intent.getStringExtra(EXTRA_ERROR_MESSAGE); -            Spannable redErrorMessage = new SpannableString(errorMessage); -            redErrorMessage.setSpan(new ForegroundColorSpan(Color.RED), 0, errorMessage.length(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE); +                Spannable redErrorMessage = new SpannableString(errorMessage); +                redErrorMessage.setSpan(new ForegroundColorSpan(Color.RED), 0, errorMessage.length(), Spannable.SPAN_EXCLUSIVE_EXCLUSIVE); -            setContentView(R.layout.api_remote_error_message); -            initToolbar(); +                setContentView(R.layout.api_remote_error_message); +                initToolbar(); -            // Inflate a "Done" custom action bar view -            ActionBarHelper.setOneButtonView(getSupportActionBar(), -                    R.string.btn_okay, R.drawable.ic_action_done, -                    new View.OnClickListener() { +                // Inflate a "Done" custom action bar view +                ActionBarHelper.setOneButtonView(getSupportActionBar(), +                        R.string.btn_okay, R.drawable.ic_action_done, +                        new View.OnClickListener() { -                        @Override -                        public void onClick(View v) { -                            RemoteServiceActivity.this.setResult(RESULT_CANCELED); -                            RemoteServiceActivity.this.finish(); +                            @Override +                            public void onClick(View v) { +                                RemoteServiceActivity.this.setResult(RESULT_CANCELED); +                                RemoteServiceActivity.this.finish(); +                            }                          } -                    } -            ); - -            // set text on view -            TextView textView = (TextView) findViewById(R.id.api_app_error_message_text); -            textView.setText(redErrorMessage); -        } else { -            Log.e(Constants.TAG, "Action does not exist!"); -            setResult(RESULT_CANCELED); -            finish(); +                ); + +                // set text on view +                TextView textView = (TextView) findViewById(R.id.api_app_error_message_text); +                textView.setText(redErrorMessage); +                break; +            } +            default: +                Log.e(Constants.TAG, "Action does not exist!"); +                setResult(RESULT_CANCELED); +                finish(); +                break;          }      }  } diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/CertifyActionsParcel.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/CertifyActionsParcel.java index dd9c0d769..f0dbf0820 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/CertifyActionsParcel.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/CertifyActionsParcel.java @@ -34,7 +34,7 @@ public class CertifyActionsParcel implements Parcelable {      final public long mMasterKeyId;      public CertifyLevel mLevel; -    public ArrayList<CertifyAction> mCertifyActions = new ArrayList<CertifyAction>(); +    public ArrayList<CertifyAction> mCertifyActions = new ArrayList<>();      public CertifyActionsParcel(long masterKeyId) {          mMasterKeyId = masterKeyId; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/KeychainIntentService.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/KeychainIntentService.java index a2172171a..b96d8945c 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/KeychainIntentService.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/KeychainIntentService.java @@ -34,7 +34,6 @@ import org.sufficientlysecure.keychain.operations.PromoteKeyOperation;  import org.sufficientlysecure.keychain.operations.results.DeleteResult;  import org.sufficientlysecure.keychain.operations.results.EditKeyResult;  import org.sufficientlysecure.keychain.operations.results.ExportResult; -import org.sufficientlysecure.keychain.operations.results.PgpEditKeyResult;  import org.sufficientlysecure.keychain.operations.results.PromoteKeyResult;  import org.sufficientlysecure.keychain.pgp.exception.PgpKeyNotFoundException;  import org.sufficientlysecure.keychain.operations.results.CertifyResult; @@ -232,313 +231,331 @@ public class KeychainIntentService extends IntentService implements Progressable          String action = intent.getAction();          // executeServiceMethod action from extra bundle -        if (ACTION_CERTIFY_KEYRING.equals(action)) { +        switch (action) { +            case ACTION_CERTIFY_KEYRING: { -            // Input -            CertifyActionsParcel parcel = data.getParcelable(CERTIFY_PARCEL); -            String keyServerUri = data.getString(UPLOAD_KEY_SERVER); - -            // Operation -            CertifyOperation op = new CertifyOperation(this, providerHelper, this, mActionCanceled); -            CertifyResult result = op.certify(parcel, keyServerUri); +                // Input +                CertifyActionsParcel parcel = data.getParcelable(CERTIFY_PARCEL); +                String keyServerUri = data.getString(UPLOAD_KEY_SERVER); -            // Result -            sendMessageToHandler(KeychainIntentServiceHandler.MESSAGE_OKAY, result); +                // Operation +                CertifyOperation op = new CertifyOperation(this, providerHelper, this, mActionCanceled); +                CertifyResult result = op.certify(parcel, keyServerUri); -        } else if (ACTION_CONSOLIDATE.equals(action)) { +                // Result +                sendMessageToHandler(KeychainIntentServiceHandler.MESSAGE_OKAY, result); -            // Operation -            ConsolidateResult result; -            if (data.containsKey(CONSOLIDATE_RECOVERY) && data.getBoolean(CONSOLIDATE_RECOVERY)) { -                result = new ProviderHelper(this).consolidateDatabaseStep2(this); -            } else { -                result = new ProviderHelper(this).consolidateDatabaseStep1(this); +                break;              } +            case ACTION_CONSOLIDATE: { -            // Result -            sendMessageToHandler(KeychainIntentServiceHandler.MESSAGE_OKAY, result); +                // Operation +                ConsolidateResult result; +                if (data.containsKey(CONSOLIDATE_RECOVERY) && data.getBoolean(CONSOLIDATE_RECOVERY)) { +                    result = new ProviderHelper(this).consolidateDatabaseStep2(this); +                } else { +                    result = new ProviderHelper(this).consolidateDatabaseStep1(this); +                } + +                // Result +                sendMessageToHandler(KeychainIntentServiceHandler.MESSAGE_OKAY, result); -        } else if (ACTION_DECRYPT_METADATA.equals(action)) { +                break; +            } +            case ACTION_DECRYPT_METADATA: -            try { +                try {                  /* Input */ -                String passphrase = data.getString(DECRYPT_PASSPHRASE); -                byte[] nfcDecryptedSessionKey = data.getByteArray(DECRYPT_NFC_DECRYPTED_SESSION_KEY); +                    String passphrase = data.getString(DECRYPT_PASSPHRASE); +                    byte[] nfcDecryptedSessionKey = data.getByteArray(DECRYPT_NFC_DECRYPTED_SESSION_KEY); -                InputData inputData = createDecryptInputData(data); +                    InputData inputData = createDecryptInputData(data);                  /* Operation */ -                Bundle resultData = new Bundle(); +                    Bundle resultData = new Bundle(); -                // verifyText and decrypt returning additional resultData values for the -                // verification of signatures -                PgpDecryptVerify.Builder builder = new PgpDecryptVerify.Builder( -                        this, new ProviderHelper(this), this, inputData, null -                ); -                builder.setAllowSymmetricDecryption(true) -                        .setPassphrase(passphrase) -                        .setDecryptMetadataOnly(true) -                        .setNfcState(nfcDecryptedSessionKey); +                    // verifyText and decrypt returning additional resultData values for the +                    // verification of signatures +                    PgpDecryptVerify.Builder builder = new PgpDecryptVerify.Builder( +                            this, new ProviderHelper(this), this, inputData, null +                    ); +                    builder.setAllowSymmetricDecryption(true) +                            .setPassphrase(passphrase) +                            .setDecryptMetadataOnly(true) +                            .setNfcState(nfcDecryptedSessionKey); -                DecryptVerifyResult decryptVerifyResult = builder.build().execute(); +                    DecryptVerifyResult decryptVerifyResult = builder.build().execute(); -                sendMessageToHandler(KeychainIntentServiceHandler.MESSAGE_OKAY, decryptVerifyResult); -            } catch (Exception e) { -                sendErrorToHandler(e); -            } +                    sendMessageToHandler(KeychainIntentServiceHandler.MESSAGE_OKAY, decryptVerifyResult); +                } catch (Exception e) { +                    sendErrorToHandler(e); +                } -        } else if (ACTION_DECRYPT_VERIFY.equals(action)) { +                break; +            case ACTION_DECRYPT_VERIFY: -            try { +                try {                  /* Input */ -                String passphrase = data.getString(DECRYPT_PASSPHRASE); -                byte[] nfcDecryptedSessionKey = data.getByteArray(DECRYPT_NFC_DECRYPTED_SESSION_KEY); +                    String passphrase = data.getString(DECRYPT_PASSPHRASE); +                    byte[] nfcDecryptedSessionKey = data.getByteArray(DECRYPT_NFC_DECRYPTED_SESSION_KEY); -                InputData inputData = createDecryptInputData(data); -                OutputStream outStream = createCryptOutputStream(data); +                    InputData inputData = createDecryptInputData(data); +                    OutputStream outStream = createCryptOutputStream(data);                  /* Operation */ -                Bundle resultData = new Bundle(); +                    Bundle resultData = new Bundle(); -                // verifyText and decrypt returning additional resultData values for the -                // verification of signatures -                PgpDecryptVerify.Builder builder = new PgpDecryptVerify.Builder( -                        this, new ProviderHelper(this), this, -                        inputData, outStream -                ); -                builder.setAllowSymmetricDecryption(true) -                        .setPassphrase(passphrase) -                        .setNfcState(nfcDecryptedSessionKey); +                    // verifyText and decrypt returning additional resultData values for the +                    // verification of signatures +                    PgpDecryptVerify.Builder builder = new PgpDecryptVerify.Builder( +                            this, new ProviderHelper(this), this, +                            inputData, outStream +                    ); +                    builder.setAllowSymmetricDecryption(true) +                            .setPassphrase(passphrase) +                            .setNfcState(nfcDecryptedSessionKey); -                DecryptVerifyResult decryptVerifyResult = builder.build().execute(); +                    DecryptVerifyResult decryptVerifyResult = builder.build().execute(); -                outStream.close(); +                    outStream.close(); -                resultData.putParcelable(DecryptVerifyResult.EXTRA_RESULT, decryptVerifyResult); +                    resultData.putParcelable(DecryptVerifyResult.EXTRA_RESULT, decryptVerifyResult);                  /* Output */ -                finalizeDecryptOutputStream(data, resultData, outStream); +                    finalizeDecryptOutputStream(data, resultData, outStream); -                Log.logDebugBundle(resultData, "resultData"); +                    Log.logDebugBundle(resultData, "resultData"); -                sendMessageToHandler(KeychainIntentServiceHandler.MESSAGE_OKAY, resultData); -            } catch (Exception e) { -                sendErrorToHandler(e); -            } - -        } else if (ACTION_DELETE.equals(action)) { - -            // Input -            long[] masterKeyIds = data.getLongArray(DELETE_KEY_LIST); -            boolean isSecret = data.getBoolean(DELETE_IS_SECRET); - -            // Operation -            DeleteOperation op = new DeleteOperation(this, new ProviderHelper(this), this); -            DeleteResult result = op.execute(masterKeyIds, isSecret); +                    sendMessageToHandler(KeychainIntentServiceHandler.MESSAGE_OKAY, resultData); +                } catch (Exception e) { +                    sendErrorToHandler(e); +                } -            // Result -            sendMessageToHandler(KeychainIntentServiceHandler.MESSAGE_OKAY, result); +                break; +            case ACTION_DELETE: { -        } else if (ACTION_EDIT_KEYRING.equals(action)) { +                // Input +                long[] masterKeyIds = data.getLongArray(DELETE_KEY_LIST); +                boolean isSecret = data.getBoolean(DELETE_IS_SECRET); -            // Input -            SaveKeyringParcel saveParcel = data.getParcelable(EDIT_KEYRING_PARCEL); -            String passphrase = data.getString(EDIT_KEYRING_PASSPHRASE); +                // Operation +                DeleteOperation op = new DeleteOperation(this, new ProviderHelper(this), this); +                DeleteResult result = op.execute(masterKeyIds, isSecret); -            // Operation -            EditKeyOperation op = new EditKeyOperation(this, providerHelper, this, mActionCanceled); -            EditKeyResult result = op.execute(saveParcel, passphrase); +                // Result +                sendMessageToHandler(KeychainIntentServiceHandler.MESSAGE_OKAY, result); -            // Result -            sendMessageToHandler(KeychainIntentServiceHandler.MESSAGE_OKAY, result); +                break; +            } +            case ACTION_EDIT_KEYRING: { -        } else if (ACTION_PROMOTE_KEYRING.equals(action)) { +                // Input +                SaveKeyringParcel saveParcel = data.getParcelable(EDIT_KEYRING_PARCEL); +                String passphrase = data.getString(EDIT_KEYRING_PASSPHRASE); -            // Input -            long keyRingId = data.getInt(EXPORT_KEY_RING_MASTER_KEY_ID); +                // Operation +                EditKeyOperation op = new EditKeyOperation(this, providerHelper, this, mActionCanceled); +                EditKeyResult result = op.execute(saveParcel, passphrase); -            // Operation -            PromoteKeyOperation op = new PromoteKeyOperation(this, providerHelper, this, mActionCanceled); -            PromoteKeyResult result = op.execute(keyRingId); +                // Result +                sendMessageToHandler(KeychainIntentServiceHandler.MESSAGE_OKAY, result); -            // Result -            sendMessageToHandler(KeychainIntentServiceHandler.MESSAGE_OKAY, result); +                break; +            } +            case ACTION_PROMOTE_KEYRING: { -        } else if (ACTION_EXPORT_KEYRING.equals(action)) { +                // Input +                long keyRingId = data.getInt(EXPORT_KEY_RING_MASTER_KEY_ID); -            // Input -            boolean exportSecret = data.getBoolean(EXPORT_SECRET, false); -            String outputFile = data.getString(EXPORT_FILENAME); -            Uri outputUri = data.getParcelable(EXPORT_URI); +                // Operation +                PromoteKeyOperation op = new PromoteKeyOperation(this, providerHelper, this, mActionCanceled); +                PromoteKeyResult result = op.execute(keyRingId); -            boolean exportAll = data.getBoolean(EXPORT_ALL); -            long[] masterKeyIds = exportAll ? null : data.getLongArray(EXPORT_KEY_RING_MASTER_KEY_ID); +                // Result +                sendMessageToHandler(KeychainIntentServiceHandler.MESSAGE_OKAY, result); -            // Operation -            ImportExportOperation importExportOperation = new ImportExportOperation(this, new ProviderHelper(this), this); -            ExportResult result; -            if (outputFile != null) { -                result = importExportOperation.exportToFile(masterKeyIds, exportSecret, outputFile); -            } else { -                result = importExportOperation.exportToUri(masterKeyIds, exportSecret, outputUri); +                break;              } - -            // Result -            sendMessageToHandler(KeychainIntentServiceHandler.MESSAGE_OKAY, result); - -        } else if (ACTION_IMPORT_KEYRING.equals(action)) { - -            try { +            case ACTION_EXPORT_KEYRING: {                  // Input -                String keyServer = data.getString(IMPORT_KEY_SERVER); -                Iterator<ParcelableKeyRing> entries; -                int numEntries; -                if (data.containsKey(IMPORT_KEY_LIST)) { -                    // get entries from intent -                    ArrayList<ParcelableKeyRing> list = data.getParcelableArrayList(IMPORT_KEY_LIST); -                    entries = list.iterator(); -                    numEntries = list.size(); -                } else { -                    // get entries from cached file -                    ParcelableFileCache<ParcelableKeyRing> cache = -                            new ParcelableFileCache<ParcelableKeyRing>(this, "key_import.pcl"); -                    IteratorWithSize<ParcelableKeyRing> it = cache.readCache(); -                    entries = it; -                    numEntries = it.getSize(); -                } +                boolean exportSecret = data.getBoolean(EXPORT_SECRET, false); +                String outputFile = data.getString(EXPORT_FILENAME); +                Uri outputUri = data.getParcelable(EXPORT_URI); + +                boolean exportAll = data.getBoolean(EXPORT_ALL); +                long[] masterKeyIds = exportAll ? null : data.getLongArray(EXPORT_KEY_RING_MASTER_KEY_ID);                  // Operation -                ImportExportOperation importExportOperation = new ImportExportOperation( -                        this, providerHelper, this, mActionCanceled); -                ImportKeyResult result = importExportOperation.importKeyRings(entries, numEntries, keyServer); - -                // Special: consolidate on secret key import (cannot be cancelled!) -                if (result.mSecret > 0) { -                    // TODO move this into the import operation -                    providerHelper.consolidateDatabaseStep1(this); +                ImportExportOperation importExportOperation = new ImportExportOperation(this, new ProviderHelper(this), this); +                ExportResult result; +                if (outputFile != null) { +                    result = importExportOperation.exportToFile(masterKeyIds, exportSecret, outputFile); +                } else { +                    result = importExportOperation.exportToUri(masterKeyIds, exportSecret, outputUri);                  } -                // Special: make sure new data is synced into contacts -                ContactSyncAdapterService.requestSync(); -                  // Result                  sendMessageToHandler(KeychainIntentServiceHandler.MESSAGE_OKAY, result); -            } catch (Exception e) { -                sendErrorToHandler(e); + +                break;              } +            case ACTION_IMPORT_KEYRING: -        } else if (ACTION_SIGN_ENCRYPT.equals(action)) { +                try { -            try { -                /* Input */ -                int source = data.get(SOURCE) != null ? data.getInt(SOURCE) : data.getInt(TARGET); -                Bundle resultData = new Bundle(); +                    // Input +                    String keyServer = data.getString(IMPORT_KEY_SERVER); +                    Iterator<ParcelableKeyRing> entries; +                    int numEntries; +                    if (data.containsKey(IMPORT_KEY_LIST)) { +                        // get entries from intent +                        ArrayList<ParcelableKeyRing> list = data.getParcelableArrayList(IMPORT_KEY_LIST); +                        entries = list.iterator(); +                        numEntries = list.size(); +                    } else { +                        // get entries from cached file +                        ParcelableFileCache<ParcelableKeyRing> cache = +                                new ParcelableFileCache<>(this, "key_import.pcl"); +                        IteratorWithSize<ParcelableKeyRing> it = cache.readCache(); +                        entries = it; +                        numEntries = it.getSize(); +                    } -                long sigMasterKeyId = data.getLong(ENCRYPT_SIGNATURE_MASTER_ID); -                String sigKeyPassphrase = data.getString(ENCRYPT_SIGNATURE_KEY_PASSPHRASE); +                    // Operation +                    ImportExportOperation importExportOperation = new ImportExportOperation( +                            this, providerHelper, this, mActionCanceled); +                    ImportKeyResult result = importExportOperation.importKeyRings(entries, numEntries, keyServer); -                byte[] nfcHash = data.getByteArray(ENCRYPT_SIGNATURE_NFC_HASH); -                Date nfcTimestamp = (Date) data.getSerializable(ENCRYPT_SIGNATURE_NFC_TIMESTAMP); +                    // Special: consolidate on secret key import (cannot be cancelled!) +                    if (result.mSecret > 0) { +                        // TODO move this into the import operation +                        providerHelper.consolidateDatabaseStep1(this); +                    } -                String symmetricPassphrase = data.getString(ENCRYPT_SYMMETRIC_PASSPHRASE); +                    // Special: make sure new data is synced into contacts +                    ContactSyncAdapterService.requestSync(); -                boolean useAsciiArmor = data.getBoolean(ENCRYPT_USE_ASCII_ARMOR); -                long encryptionKeyIds[] = data.getLongArray(ENCRYPT_ENCRYPTION_KEYS_IDS); -                int compressionId = data.getInt(ENCRYPT_COMPRESSION_ID); -                int urisCount = data.containsKey(ENCRYPT_INPUT_URIS) ? data.getParcelableArrayList(ENCRYPT_INPUT_URIS).size() : 1; -                for (int i = 0; i < urisCount; i++) { -                    data.putInt(SELECTED_URI, i); -                    InputData inputData = createEncryptInputData(data); -                    OutputStream outStream = createCryptOutputStream(data); -                    String originalFilename = getOriginalFilename(data); +                    // Result +                    sendMessageToHandler(KeychainIntentServiceHandler.MESSAGE_OKAY, result); +                } catch (Exception e) { +                    sendErrorToHandler(e); +                } -                    /* Operation */ -                    PgpSignEncrypt.Builder builder = new PgpSignEncrypt.Builder( -                            this, new ProviderHelper(this), this, inputData, outStream -                    ); -                    builder.setEnableAsciiArmorOutput(useAsciiArmor) -                            .setVersionHeader(PgpHelper.getVersionForHeader(this)) -                            .setCompressionId(compressionId) -                            .setSymmetricEncryptionAlgorithm( -                                    Preferences.getPreferences(this).getDefaultEncryptionAlgorithm()) -                            .setEncryptionMasterKeyIds(encryptionKeyIds) -                            .setSymmetricPassphrase(symmetricPassphrase) -                            .setOriginalFilename(originalFilename); +                break; +            case ACTION_SIGN_ENCRYPT: -                    try { +                try { +                /* Input */ +                    int source = data.get(SOURCE) != null ? data.getInt(SOURCE) : data.getInt(TARGET); +                    Bundle resultData = new Bundle(); -                        // Find the appropriate subkey to sign with -                        CachedPublicKeyRing signingRing = -                                new ProviderHelper(this).getCachedPublicKeyRing(sigMasterKeyId); -                        long sigSubKeyId = signingRing.getSecretSignId(); - -                        // Set signature settings -                        builder.setSignatureMasterKeyId(sigMasterKeyId) -                                .setSignatureSubKeyId(sigSubKeyId) -                                .setSignaturePassphrase(sigKeyPassphrase) -                                .setSignatureHashAlgorithm( -                                        Preferences.getPreferences(this).getDefaultHashAlgorithm()) -                                .setAdditionalEncryptId(sigMasterKeyId); -                        if (nfcHash != null && nfcTimestamp != null) { -                            builder.setNfcState(nfcHash, nfcTimestamp); -                        } +                    long sigMasterKeyId = data.getLong(ENCRYPT_SIGNATURE_MASTER_ID); +                    String sigKeyPassphrase = data.getString(ENCRYPT_SIGNATURE_KEY_PASSPHRASE); -                    } catch (PgpKeyNotFoundException e) { -                        // encrypt-only -                        // TODO Just silently drop the requested signature? Shouldn't we throw here? -                    } +                    byte[] nfcHash = data.getByteArray(ENCRYPT_SIGNATURE_NFC_HASH); +                    Date nfcTimestamp = (Date) data.getSerializable(ENCRYPT_SIGNATURE_NFC_TIMESTAMP); -                    // this assumes that the bytes are cleartext (valid for current implementation!) -                    if (source == IO_BYTES) { -                        builder.setCleartextInput(true); -                    } +                    String symmetricPassphrase = data.getString(ENCRYPT_SYMMETRIC_PASSPHRASE); -                    SignEncryptResult result = builder.build().execute(); -                    resultData.putParcelable(SignEncryptResult.EXTRA_RESULT, result); +                    boolean useAsciiArmor = data.getBoolean(ENCRYPT_USE_ASCII_ARMOR); +                    long encryptionKeyIds[] = data.getLongArray(ENCRYPT_ENCRYPTION_KEYS_IDS); +                    int compressionId = data.getInt(ENCRYPT_COMPRESSION_ID); +                    int urisCount = data.containsKey(ENCRYPT_INPUT_URIS) ? data.getParcelableArrayList(ENCRYPT_INPUT_URIS).size() : 1; +                    for (int i = 0; i < urisCount; i++) { +                        data.putInt(SELECTED_URI, i); +                        InputData inputData = createEncryptInputData(data); +                        OutputStream outStream = createCryptOutputStream(data); +                        String originalFilename = getOriginalFilename(data); -                    outStream.close(); +                    /* Operation */ +                        PgpSignEncrypt.Builder builder = new PgpSignEncrypt.Builder( +                                this, new ProviderHelper(this), this, inputData, outStream +                        ); +                        builder.setEnableAsciiArmorOutput(useAsciiArmor) +                                .setVersionHeader(PgpHelper.getVersionForHeader(this)) +                                .setCompressionId(compressionId) +                                .setSymmetricEncryptionAlgorithm( +                                        Preferences.getPreferences(this).getDefaultEncryptionAlgorithm()) +                                .setEncryptionMasterKeyIds(encryptionKeyIds) +                                .setSymmetricPassphrase(symmetricPassphrase) +                                .setOriginalFilename(originalFilename); + +                        try { + +                            // Find the appropriate subkey to sign with +                            CachedPublicKeyRing signingRing = +                                    new ProviderHelper(this).getCachedPublicKeyRing(sigMasterKeyId); +                            long sigSubKeyId = signingRing.getSecretSignId(); + +                            // Set signature settings +                            builder.setSignatureMasterKeyId(sigMasterKeyId) +                                    .setSignatureSubKeyId(sigSubKeyId) +                                    .setSignaturePassphrase(sigKeyPassphrase) +                                    .setSignatureHashAlgorithm( +                                            Preferences.getPreferences(this).getDefaultHashAlgorithm()) +                                    .setAdditionalEncryptId(sigMasterKeyId); +                            if (nfcHash != null && nfcTimestamp != null) { +                                builder.setNfcState(nfcHash, nfcTimestamp); +                            } + +                        } catch (PgpKeyNotFoundException e) { +                            // encrypt-only +                            // TODO Just silently drop the requested signature? Shouldn't we throw here? +                        } + +                        // this assumes that the bytes are cleartext (valid for current implementation!) +                        if (source == IO_BYTES) { +                            builder.setCleartextInput(true); +                        } + +                        SignEncryptResult result = builder.build().execute(); +                        resultData.putParcelable(SignEncryptResult.EXTRA_RESULT, result); + +                        outStream.close();                      /* Output */ -                    finalizeEncryptOutputStream(data, resultData, outStream); +                        finalizeEncryptOutputStream(data, resultData, outStream); -                } +                    } -                Log.logDebugBundle(resultData, "resultData"); +                    Log.logDebugBundle(resultData, "resultData"); -                sendMessageToHandler(KeychainIntentServiceHandler.MESSAGE_OKAY, resultData); -            } catch (Exception e) { -                sendErrorToHandler(e); -            } +                    sendMessageToHandler(KeychainIntentServiceHandler.MESSAGE_OKAY, resultData); +                } catch (Exception e) { +                    sendErrorToHandler(e); +                } -        } else if (ACTION_UPLOAD_KEYRING.equals(action)) { +                break; +            case ACTION_UPLOAD_KEYRING: -            try { +                try {                  /* Input */ -                String keyServer = data.getString(UPLOAD_KEY_SERVER); -                // and dataUri! +                    String keyServer = data.getString(UPLOAD_KEY_SERVER); +                    // and dataUri!                  /* Operation */ -                HkpKeyserver server = new HkpKeyserver(keyServer); +                    HkpKeyserver server = new HkpKeyserver(keyServer); -                CanonicalizedPublicKeyRing keyring = providerHelper.getCanonicalizedPublicKeyRing(dataUri); -                ImportExportOperation importExportOperation = new ImportExportOperation(this, new ProviderHelper(this), this); +                    CanonicalizedPublicKeyRing keyring = providerHelper.getCanonicalizedPublicKeyRing(dataUri); +                    ImportExportOperation importExportOperation = new ImportExportOperation(this, new ProviderHelper(this), this); -                try { -                    importExportOperation.uploadKeyRingToServer(server, keyring); -                } catch (Keyserver.AddKeyException e) { -                    throw new PgpGeneralException("Unable to export key to selected server"); -                } +                    try { +                        importExportOperation.uploadKeyRingToServer(server, keyring); +                    } catch (Keyserver.AddKeyException e) { +                        throw new PgpGeneralException("Unable to export key to selected server"); +                    } -                sendMessageToHandler(KeychainIntentServiceHandler.MESSAGE_OKAY); -            } catch (Exception e) { -                sendErrorToHandler(e); -            } +                    sendMessageToHandler(KeychainIntentServiceHandler.MESSAGE_OKAY); +                } catch (Exception e) { +                    sendErrorToHandler(e); +                } +                break;          }      } diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/PassphraseCacheService.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/PassphraseCacheService.java index 869d2e71b..142814d99 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/PassphraseCacheService.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/PassphraseCacheService.java @@ -39,7 +39,6 @@ import android.support.v4.util.LongSparseArray;  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R; -import org.sufficientlysecure.keychain.pgp.exception.PgpKeyNotFoundException;  import org.sufficientlysecure.keychain.util.Preferences;  import org.sufficientlysecure.keychain.pgp.CanonicalizedSecretKey.SecretKeyType;  import org.sufficientlysecure.keychain.provider.CachedPublicKeyRing; @@ -103,7 +102,7 @@ public class PassphraseCacheService extends Service {      private BroadcastReceiver mIntentReceiver; -    private LongSparseArray<CachedPassphrase> mPassphraseCache = new LongSparseArray<CachedPassphrase>(); +    private LongSparseArray<CachedPassphrase> mPassphraseCache = new LongSparseArray<>();      Context mContext; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/SaveKeyringParcel.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/SaveKeyringParcel.java index 3c78f2c40..f5df5858c 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/SaveKeyringParcel.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/service/SaveKeyringParcel.java @@ -71,13 +71,13 @@ public class SaveKeyringParcel implements Parcelable {      public void reset() {          mNewUnlock = null; -        mAddUserIds = new ArrayList<String>(); -        mAddUserAttribute = new ArrayList<WrappedUserAttribute>(); -        mAddSubKeys = new ArrayList<SubkeyAdd>(); +        mAddUserIds = new ArrayList<>(); +        mAddUserAttribute = new ArrayList<>(); +        mAddSubKeys = new ArrayList<>();          mChangePrimaryUserId = null; -        mChangeSubKeys = new ArrayList<SubkeyChange>(); -        mRevokeUserIds = new ArrayList<String>(); -        mRevokeSubKeys = new ArrayList<Long>(); +        mChangeSubKeys = new ArrayList<>(); +        mRevokeUserIds = new ArrayList<>(); +        mRevokeSubKeys = new ArrayList<>();      }      /** Returns true iff this parcel does not contain any operations which require a passphrase. */ @@ -173,7 +173,7 @@ public class SaveKeyringParcel implements Parcelable {              out += "mFlags: " + mFlags + ", ";              out += "mExpiry: " + mExpiry + ", ";              out += "mDummyStrip: " + mDummyStrip + ", "; -            out += "mDummyDivert: " + mDummyDivert; +            out += "mDummyDivert: [" + (mDummyDivert == null ? 0 : mDummyDivert.length) + " bytes]";              return out;          } diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CertifyKeyActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CertifyKeyActivity.java index 6850eca13..1fb88b182 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CertifyKeyActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CertifyKeyActivity.java @@ -18,9 +18,6 @@  package org.sufficientlysecure.keychain.ui; -import android.os.Bundle; -import android.support.v7.app.ActionBarActivity; -  import org.sufficientlysecure.keychain.R;  /** diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CertifyKeyFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CertifyKeyFragment.java index 841485c7c..50d5e3229 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CertifyKeyFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CertifyKeyFragment.java @@ -234,7 +234,7 @@ public class CertifyKeyFragment extends LoaderFragment          long lastMasterKeyId = 0;          String lastName = ""; -        ArrayList<String> uids = new ArrayList<String>(); +        ArrayList<String> uids = new ArrayList<>();          boolean header = true; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CreateKeyActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CreateKeyActivity.java index 82d3279f4..62c38d136 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CreateKeyActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CreateKeyActivity.java @@ -20,7 +20,6 @@ package org.sufficientlysecure.keychain.ui;  import android.os.Bundle;  import android.support.v4.app.Fragment;  import android.support.v4.app.FragmentTransaction; -import android.support.v7.app.ActionBarActivity;  import org.sufficientlysecure.keychain.R; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CreateKeyFinalFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CreateKeyFinalFragment.java index 2804a5ce6..377a9d1f4 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CreateKeyFinalFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CreateKeyFinalFragment.java @@ -44,7 +44,6 @@ import org.sufficientlysecure.keychain.service.KeychainIntentServiceHandler;  import org.sufficientlysecure.keychain.operations.results.OperationResult;  import org.sufficientlysecure.keychain.service.SaveKeyringParcel;  import org.sufficientlysecure.keychain.service.SaveKeyringParcel.Algorithm; -import org.sufficientlysecure.keychain.operations.results.SaveKeyringResult;  import org.sufficientlysecure.keychain.util.Log;  public class CreateKeyFinalFragment extends Fragment { diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CreateKeyInputFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CreateKeyInputFragment.java index 6079062a7..8aa9fa6db 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CreateKeyInputFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/CreateKeyInputFragment.java @@ -89,7 +89,7 @@ public class CreateKeyInputFragment extends Fragment {          mEmailEdit.setThreshold(1); // Start working from first character          mEmailEdit.setAdapter( -                new ArrayAdapter<String> +                new ArrayAdapter<>                          (getActivity(), android.R.layout.simple_spinner_dropdown_item,                                  ContactHelper.getPossibleUserEmails(getActivity())                          ) @@ -124,7 +124,7 @@ public class CreateKeyInputFragment extends Fragment {          mNameEdit.setThreshold(1); // Start working from first character          mNameEdit.setAdapter( -                new ArrayAdapter<String> +                new ArrayAdapter<>                          (getActivity(), android.R.layout.simple_spinner_dropdown_item,                                  ContactHelper.getPossibleUserNames(getActivity())                          ) diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/DecryptFilesActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/DecryptFilesActivity.java index 59159929c..7e91889b3 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/DecryptFilesActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/DecryptFilesActivity.java @@ -20,7 +20,6 @@ package org.sufficientlysecure.keychain.ui;  import android.content.Intent;  import android.net.Uri;  import android.os.Bundle; -import android.support.v7.app.ActionBarActivity;  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/DecryptTextActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/DecryptTextActivity.java index 285078dbf..2afc4b7b3 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/DecryptTextActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/DecryptTextActivity.java @@ -20,7 +20,6 @@ package org.sufficientlysecure.keychain.ui;  import android.content.Intent;  import android.os.Bundle; -import android.support.v7.app.ActionBarActivity;  import android.text.TextUtils;  import org.sufficientlysecure.keychain.Constants; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EditKeyActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EditKeyActivity.java index 492c81758..6dc2994cf 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EditKeyActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EditKeyActivity.java @@ -19,7 +19,6 @@ package org.sufficientlysecure.keychain.ui;  import android.net.Uri;  import android.os.Bundle; -import android.support.v7.app.ActionBarActivity;  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EditKeyFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EditKeyFragment.java index febda16c3..2e2d26bf0 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EditKeyFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EditKeyFragment.java @@ -231,10 +231,7 @@ public class EditKeyFragment extends LoaderFragment implements              mSaveKeyringParcel = new SaveKeyringParcel(masterKeyId, keyRing.getFingerprint());              mPrimaryUserId = keyRing.getPrimaryUserIdWithFallback(); -        } catch (PgpKeyNotFoundException e) { -            finishWithError(LogType.MSG_EK_ERROR_NOT_FOUND); -            return; -        } catch (NotFoundException e) { +        } catch (PgpKeyNotFoundException | NotFoundException e) {              finishWithError(LogType.MSG_EK_ERROR_NOT_FOUND);              return;          } diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptAsymmetricFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptAsymmetricFragment.java index 2d1b66daa..c5404094a 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptAsymmetricFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptAsymmetricFragment.java @@ -28,7 +28,6 @@ import com.tokenautocomplete.TokenCompleteTextView;  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R; -import org.sufficientlysecure.keychain.pgp.exception.PgpGeneralException;  import org.sufficientlysecure.keychain.pgp.exception.PgpKeyNotFoundException;  import org.sufficientlysecure.keychain.provider.CachedPublicKeyRing;  import org.sufficientlysecure.keychain.provider.KeychainContract.KeyRings; @@ -164,8 +163,8 @@ public class EncryptAsymmetricFragment extends Fragment implements EncryptActivi      private void updateEncryptionKeys() {          List<Object> objects = mEncryptKeyView.getObjects(); -        List<Long> keyIds = new ArrayList<Long>(); -        List<String> userIds = new ArrayList<String>(); +        List<Long> keyIds = new ArrayList<>(); +        List<String> userIds = new ArrayList<>();          for (Object object : objects) {              if (object instanceof EncryptKeyCompletionView.EncryptionKey) {                  keyIds.add(((EncryptKeyCompletionView.EncryptionKey) object).getKeyId()); diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptFilesActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptFilesActivity.java index 1494d05e1..b1da1f2c5 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptFilesActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptFilesActivity.java @@ -122,13 +122,13 @@ public class EncryptFilesActivity extends EncryptActivity implements EncryptActi      @Override      public ArrayList<Uri> getInputUris() { -        if (mInputUris == null) mInputUris = new ArrayList<Uri>(); +        if (mInputUris == null) mInputUris = new ArrayList<>();          return mInputUris;      }      @Override      public ArrayList<Uri> getOutputUris() { -        if (mOutputUris == null) mOutputUris = new ArrayList<Uri>(); +        if (mOutputUris == null) mOutputUris = new ArrayList<>();          return mOutputUris;      } @@ -252,7 +252,7 @@ public class EncryptFilesActivity extends EncryptActivity implements EncryptActi          sendIntent.setType("application/octet-stream");          if (!isModeSymmetric() && mEncryptionUserIds != null) { -            Set<String> users = new HashSet<String>(); +            Set<String> users = new HashSet<>();              for (String user : mEncryptionUserIds) {                  String[] userId = KeyRing.splitUserId(user);                  if (userId[1] != null) { @@ -382,7 +382,7 @@ public class EncryptFilesActivity extends EncryptActivity implements EncryptActi          String action = intent.getAction();          Bundle extras = intent.getExtras();          String type = intent.getType(); -        ArrayList<Uri> uris = new ArrayList<Uri>(); +        ArrayList<Uri> uris = new ArrayList<>();          if (extras == null) {              extras = new Bundle(); diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptFilesFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptFilesFragment.java index 6961f5ee7..be305cc58 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptFilesFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptFilesFragment.java @@ -59,7 +59,7 @@ public class EncryptFilesFragment extends Fragment implements EncryptActivityInt      private View mShareFile;      private ListView mSelectedFiles;      private SelectedFilesAdapter mAdapter = new SelectedFilesAdapter(); -    private final Map<Uri, Bitmap> thumbnailCache = new HashMap<Uri, Bitmap>(); +    private final Map<Uri, Bitmap> thumbnailCache = new HashMap<>();      @Override      public void onAttach(Activity activity) { @@ -224,7 +224,7 @@ public class EncryptFilesFragment extends Fragment implements EncryptActivityInt      @Override      public void onNotifyUpdate() {          // Clear cache if needed -        for (Uri uri : new HashSet<Uri>(thumbnailCache.keySet())) { +        for (Uri uri : new HashSet<>(thumbnailCache.keySet())) {              if (!mEncryptInterface.getInputUris().contains(uri)) {                  thumbnailCache.remove(uri);              } diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptTextActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptTextActivity.java index 9b06a0b75..dabd5ddd5 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptTextActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/EncryptTextActivity.java @@ -121,13 +121,13 @@ public class EncryptTextActivity extends EncryptActivity implements EncryptActiv      @Override      public ArrayList<Uri> getInputUris() { -        if (mInputUris == null) mInputUris = new ArrayList<Uri>(); +        if (mInputUris == null) mInputUris = new ArrayList<>();          return mInputUris;      }      @Override      public ArrayList<Uri> getOutputUris() { -        if (mOutputUris == null) mOutputUris = new ArrayList<Uri>(); +        if (mOutputUris == null) mOutputUris = new ArrayList<>();          return mOutputUris;      } @@ -240,7 +240,7 @@ public class EncryptTextActivity extends EncryptActivity implements EncryptActiv          sendIntent.putExtra(Intent.EXTRA_TEXT, new String(message.getData().getByteArray(KeychainIntentService.RESULT_BYTES)));          if (!isModeSymmetric() && mEncryptionUserIds != null) { -            Set<String> users = new HashSet<String>(); +            Set<String> users = new HashSet<>();              for (String user : mEncryptionUserIds) {                  String[] userId = KeyRing.splitUserId(user);                  if (userId[1] != null) { diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/FirstTimeActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/FirstTimeActivity.java index e487c8947..ce2a049f5 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/FirstTimeActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/FirstTimeActivity.java @@ -19,7 +19,6 @@ package org.sufficientlysecure.keychain.ui;  import android.content.Intent;  import android.os.Bundle; -import android.support.v7.app.ActionBarActivity;  import android.view.KeyEvent;  import android.view.View;  import android.view.Window; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ImportKeysActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ImportKeysActivity.java index f1677cb67..e72e265d4 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ImportKeysActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ImportKeysActivity.java @@ -29,7 +29,6 @@ import android.os.Message;  import android.os.Messenger;  import android.os.Parcelable;  import android.support.v4.app.Fragment; -import android.support.v7.app.ActionBarActivity;  import android.view.View;  import android.view.View.OnClickListener; @@ -122,95 +121,102 @@ public class ImportKeysActivity extends BaseActivity {              action = ACTION_IMPORT_KEY;          } -        if (ACTION_IMPORT_KEY.equals(action)) { +        switch (action) { +            case ACTION_IMPORT_KEY:              /* Keychain's own Actions */ -            startFileFragment(savedInstanceState); +                startFileFragment(savedInstanceState); -            if (dataUri != null) { -                // action: directly load data -                startListFragment(savedInstanceState, null, dataUri, null); -            } else if (extras.containsKey(EXTRA_KEY_BYTES)) { -                byte[] importData = extras.getByteArray(EXTRA_KEY_BYTES); +                if (dataUri != null) { +                    // action: directly load data +                    startListFragment(savedInstanceState, null, dataUri, null); +                } else if (extras.containsKey(EXTRA_KEY_BYTES)) { +                    byte[] importData = extras.getByteArray(EXTRA_KEY_BYTES); -                // action: directly load data -                startListFragment(savedInstanceState, importData, null, null); -            } -        } else if (ACTION_IMPORT_KEY_FROM_KEYSERVER.equals(action) -                || ACTION_IMPORT_KEY_FROM_KEYSERVER_AND_RETURN_TO_SERVICE.equals(action) -                || ACTION_IMPORT_KEY_FROM_KEYSERVER_AND_RETURN_RESULT.equals(action)) { - -            // only used for OpenPgpService -            if (extras.containsKey(EXTRA_PENDING_INTENT_DATA)) { -                mPendingIntentData = extras.getParcelable(EXTRA_PENDING_INTENT_DATA); -            } -            if (extras.containsKey(EXTRA_QUERY) || extras.containsKey(EXTRA_KEY_ID)) { +                    // action: directly load data +                    startListFragment(savedInstanceState, importData, null, null); +                } +                break; +            case ACTION_IMPORT_KEY_FROM_KEYSERVER: +            case ACTION_IMPORT_KEY_FROM_KEYSERVER_AND_RETURN_TO_SERVICE: +            case ACTION_IMPORT_KEY_FROM_KEYSERVER_AND_RETURN_RESULT: + +                // only used for OpenPgpService +                if (extras.containsKey(EXTRA_PENDING_INTENT_DATA)) { +                    mPendingIntentData = extras.getParcelable(EXTRA_PENDING_INTENT_DATA); +                } +                if (extras.containsKey(EXTRA_QUERY) || extras.containsKey(EXTRA_KEY_ID)) {                  /* simple search based on query or key id */ -                String query = null; -                if (extras.containsKey(EXTRA_QUERY)) { -                    query = extras.getString(EXTRA_QUERY); -                } else if (extras.containsKey(EXTRA_KEY_ID)) { -                    long keyId = extras.getLong(EXTRA_KEY_ID, 0); -                    if (keyId != 0) { -                        query = KeyFormattingUtils.convertKeyIdToHex(keyId); +                    String query = null; +                    if (extras.containsKey(EXTRA_QUERY)) { +                        query = extras.getString(EXTRA_QUERY); +                    } else if (extras.containsKey(EXTRA_KEY_ID)) { +                        long keyId = extras.getLong(EXTRA_KEY_ID, 0); +                        if (keyId != 0) { +                            query = KeyFormattingUtils.convertKeyIdToHex(keyId); +                        }                      } -                } -                if (query != null && query.length() > 0) { -                    // display keyserver fragment with query -                    startCloudFragment(savedInstanceState, query, false); +                    if (query != null && query.length() > 0) { +                        // display keyserver fragment with query +                        startCloudFragment(savedInstanceState, query, false); -                    // action: search immediately -                    startListFragment(savedInstanceState, null, null, query); -                } else { -                    Log.e(Constants.TAG, "Query is empty!"); -                    return; -                } -            } else if (extras.containsKey(EXTRA_FINGERPRINT)) { +                        // action: search immediately +                        startListFragment(savedInstanceState, null, null, query); +                    } else { +                        Log.e(Constants.TAG, "Query is empty!"); +                        return; +                    } +                } else if (extras.containsKey(EXTRA_FINGERPRINT)) {                  /*                   * search based on fingerprint, here we can enforce a check in the end                   * if the right key has been downloaded                   */ -                String fingerprint = extras.getString(EXTRA_FINGERPRINT); -                if (isFingerprintValid(fingerprint)) { -                    String query = "0x" + fingerprint; +                    String fingerprint = extras.getString(EXTRA_FINGERPRINT); +                    if (isFingerprintValid(fingerprint)) { +                        String query = "0x" + fingerprint; -                    // display keyserver fragment with query -                    startCloudFragment(savedInstanceState, query, true); +                        // display keyserver fragment with query +                        startCloudFragment(savedInstanceState, query, true); -                    // action: search immediately -                    startListFragment(savedInstanceState, null, null, query); +                        // action: search immediately +                        startListFragment(savedInstanceState, null, null, query); +                    } +                } else { +                    Log.e(Constants.TAG, +                            "IMPORT_KEY_FROM_KEYSERVER action needs to contain the 'query', 'key_id', or " + +                                    "'fingerprint' extra!" +                    ); +                    return;                  } -            } else { -                Log.e(Constants.TAG, -                        "IMPORT_KEY_FROM_KEYSERVER action needs to contain the 'query', 'key_id', or " + -                                "'fingerprint' extra!" -                ); -                return; -            } -        } else if (ACTION_IMPORT_KEY_FROM_FILE.equals(action)) { -            // NOTE: this only displays the appropriate fragment, no actions are taken -            startFileFragment(savedInstanceState); - -            // no immediate actions! -            startListFragment(savedInstanceState, null, null, null); -        } else if (ACTION_IMPORT_KEY_FROM_FILE_AND_RETURN.equals(action)) { -            // NOTE: this only displays the appropriate fragment, no actions are taken -            startFileFragment(savedInstanceState); - -            // no immediate actions! -            startListFragment(savedInstanceState, null, null, null); -        } else if (ACTION_IMPORT_KEY_FROM_NFC.equals(action)) { -            // NOTE: this only displays the appropriate fragment, no actions are taken -            startFileFragment(savedInstanceState); -            // TODO!!!!! - -            // no immediate actions! -            startListFragment(savedInstanceState, null, null, null); -        } else { -            startCloudFragment(savedInstanceState, null, false); -            startListFragment(savedInstanceState, null, null, null); +                break; +            case ACTION_IMPORT_KEY_FROM_FILE: +                // NOTE: this only displays the appropriate fragment, no actions are taken +                startFileFragment(savedInstanceState); + +                // no immediate actions! +                startListFragment(savedInstanceState, null, null, null); +                break; +            case ACTION_IMPORT_KEY_FROM_FILE_AND_RETURN: +                // NOTE: this only displays the appropriate fragment, no actions are taken +                startFileFragment(savedInstanceState); + +                // no immediate actions! +                startListFragment(savedInstanceState, null, null, null); +                break; +            case ACTION_IMPORT_KEY_FROM_NFC: +                // NOTE: this only displays the appropriate fragment, no actions are taken +                startFileFragment(savedInstanceState); +                // TODO!!!!! + +                // no immediate actions! +                startListFragment(savedInstanceState, null, null, null); +                break; +            default: +                startCloudFragment(savedInstanceState, null, false); +                startListFragment(savedInstanceState, null, null, null); +                break;          }      } @@ -356,7 +362,7 @@ public class ImportKeysActivity extends BaseActivity {                  // We parcel this iteratively into a file - anything we can                  // display here, we should be able to import.                  ParcelableFileCache<ParcelableKeyRing> cache = -                        new ParcelableFileCache<ParcelableKeyRing>(this, "key_import.pcl"); +                        new ParcelableFileCache<>(this, "key_import.pcl");                  cache.writeCache(selectedEntries);                  intent.putExtra(KeychainIntentService.EXTRA_DATA, data); @@ -388,7 +394,7 @@ public class ImportKeysActivity extends BaseActivity {              data.putString(KeychainIntentService.IMPORT_KEY_SERVER, sls.mCloudPrefs.keyserver);              // get selected key entries -            ArrayList<ParcelableKeyRing> keys = new ArrayList<ParcelableKeyRing>(); +            ArrayList<ParcelableKeyRing> keys = new ArrayList<>();              {                  // change the format into ParcelableKeyRing                  ArrayList<ImportKeysListEntry> entries = mListFragment.getSelectedEntries(); diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ImportKeysCloudFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ImportKeysCloudFragment.java index 89826b8e9..1d12f49f9 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ImportKeysCloudFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ImportKeysCloudFragment.java @@ -81,7 +81,7 @@ public class ImportKeysCloudFragment extends Fragment {          namesAndEmails.addAll(ContactHelper.getContactMails(getActivity()));          mQueryEditText.setThreshold(3);          mQueryEditText.setAdapter( -                new ArrayAdapter<String> +                new ArrayAdapter<>                          (getActivity(), android.R.layout.simple_spinner_dropdown_item,                                  namesAndEmails                          ) diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ImportKeysListFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ImportKeysListFragment.java index 4fe53fb09..6a6140892 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ImportKeysListFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ImportKeysListFragment.java @@ -113,7 +113,7 @@ public class ImportKeysListFragment extends ListFragment implements              return mAdapter.getSelectedEntries();          } else {              Log.e(Constants.TAG, "Adapter not initialized, returning empty list"); -            return new ArrayList<ImportKeysListEntry>(); +            return new ArrayList<>();          }      } diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/KeyListFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/KeyListFragment.java index 7fa403485..fdc598394 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/KeyListFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/KeyListFragment.java @@ -19,7 +19,6 @@  package org.sufficientlysecure.keychain.ui;  import android.annotation.TargetApi; -import android.app.ProgressDialog;  import android.content.Context;  import android.content.Intent;  import android.database.Cursor; @@ -31,7 +30,6 @@ import android.os.Bundle;  import android.os.Handler;  import android.os.Message;  import android.os.Messenger; -import android.support.v4.app.FragmentActivity;  import android.support.v4.app.LoaderManager;  import android.support.v4.content.CursorLoader;  import android.support.v4.content.Loader; @@ -52,7 +50,6 @@ import android.view.View.OnClickListener;  import android.view.ViewGroup;  import android.widget.AbsListView.MultiChoiceModeListener;  import android.widget.AdapterView; -import android.widget.Button;  import android.widget.ImageButton;  import android.widget.ImageView;  import android.widget.ListView; @@ -60,16 +57,9 @@ import android.widget.TextView;  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R; -import org.sufficientlysecure.keychain.keyimport.ParcelableKeyRing;  import org.sufficientlysecure.keychain.operations.results.DeleteResult; -import org.sufficientlysecure.keychain.provider.KeychainContract; -import org.sufficientlysecure.keychain.provider.ProviderHelper; -import org.sufficientlysecure.keychain.service.KeychainIntentService; -import org.sufficientlysecure.keychain.operations.results.ImportKeyResult; -import org.sufficientlysecure.keychain.operations.results.OperationResult;  import org.sufficientlysecure.keychain.ui.util.KeyFormattingUtils;  import org.sufficientlysecure.keychain.util.ExportHelper; -import org.sufficientlysecure.keychain.util.KeyUpdateHelper;  import org.sufficientlysecure.keychain.pgp.KeyRing;  import org.sufficientlysecure.keychain.provider.KeychainContract.KeyRings;  import org.sufficientlysecure.keychain.service.KeychainIntentServiceHandler; @@ -78,15 +68,10 @@ import org.sufficientlysecure.keychain.ui.widget.ListAwareSwipeRefreshLayout;  import org.sufficientlysecure.keychain.ui.util.Highlighter;  import org.sufficientlysecure.keychain.util.Log;  import org.sufficientlysecure.keychain.ui.util.Notify; -import org.sufficientlysecure.keychain.util.ParcelableFileCache; -import java.io.IOException; -import java.util.ArrayList;  import java.util.Date;  import java.util.HashMap; -import edu.cmu.cylab.starslinger.exchange.ExchangeActivity; -import edu.cmu.cylab.starslinger.exchange.ExchangeConfig;  import se.emilsjolander.stickylistheaders.StickyListHeadersAdapter;  import se.emilsjolander.stickylistheaders.StickyListHeadersListView; @@ -517,7 +502,7 @@ public class KeyListFragment extends LoaderFragment          private String mQuery;          private LayoutInflater mInflater; -        private HashMap<Integer, Boolean> mSelection = new HashMap<Integer, Boolean>(); +        private HashMap<Integer, Boolean> mSelection = new HashMap<>();          public KeyListAdapter(Context context, Cursor c, int flags) {              super(context, c, flags); diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/LogDisplayActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/LogDisplayActivity.java index fd74e1654..21113fb2f 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/LogDisplayActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/LogDisplayActivity.java @@ -19,7 +19,6 @@  package org.sufficientlysecure.keychain.ui;  import android.os.Bundle; -import android.support.v7.app.ActionBarActivity;  import android.view.View;  import org.sufficientlysecure.keychain.R; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/NfcActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/NfcActivity.java index 3a70502ea..7311f4879 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/NfcActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/NfcActivity.java @@ -15,7 +15,6 @@ import android.nfc.Tag;  import android.nfc.tech.IsoDep;  import android.os.Build;  import android.os.Bundle; -import android.support.v7.app.ActionBarActivity;  import android.view.WindowManager;  import android.widget.Toast; @@ -23,13 +22,11 @@ import org.spongycastle.bcpg.HashAlgorithmTags;  import org.spongycastle.util.encoders.Hex;  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R; -import org.sufficientlysecure.keychain.ui.util.KeyFormattingUtils;  import org.sufficientlysecure.keychain.util.Iso7816TLV;  import org.sufficientlysecure.keychain.util.Log;  import java.io.IOException;  import java.nio.ByteBuffer; -import java.util.Locale;  /**   * This class provides a communication interface to OpenPGP applications on ISO SmartCard compliant @@ -91,33 +88,38 @@ public class NfcActivity extends BaseActivity {              mKeyId = data.getLong(EXTRA_KEY_ID);          } -        if (ACTION_SIGN_HASH.equals(action)) { -            mAction = action; -            mPin = data.getString(EXTRA_PIN); -            mHashToSign = data.getByteArray(EXTRA_NFC_HASH_TO_SIGN); -            mHashAlgo = data.getInt(EXTRA_NFC_HASH_ALGO); -            mServiceIntent = data.getParcelable(EXTRA_DATA); - -            Log.d(Constants.TAG, "NfcActivity mAction: " + mAction); -            Log.d(Constants.TAG, "NfcActivity mPin: " + mPin); -            Log.d(Constants.TAG, "NfcActivity mHashToSign as hex: " + getHex(mHashToSign)); -            Log.d(Constants.TAG, "NfcActivity mServiceIntent: " + mServiceIntent.toString()); -        } else if (ACTION_DECRYPT_SESSION_KEY.equals(action)) { -            mAction = action; -            mPin = data.getString(EXTRA_PIN); -            mEncryptedSessionKey = data.getByteArray(EXTRA_NFC_ENC_SESSION_KEY); -            mServiceIntent = data.getParcelable(EXTRA_DATA); - -            Log.d(Constants.TAG, "NfcActivity mAction: " + mAction); -            Log.d(Constants.TAG, "NfcActivity mPin: " + mPin); -            Log.d(Constants.TAG, "NfcActivity mEncryptedSessionKey as hex: " + getHex(mEncryptedSessionKey)); -            Log.d(Constants.TAG, "NfcActivity mServiceIntent: " + mServiceIntent.toString()); -        } else if (NfcAdapter.ACTION_TAG_DISCOVERED.equals(action)) { -            Log.e(Constants.TAG, "This should not happen! NfcActivity.onCreate() is being called instead of onNewIntent()!"); -            toast("This should not happen! Please create a new bug report that the NFC screen is restarted!"); -            finish(); -        } else { -            Log.d(Constants.TAG, "Action not supported: " + action); +        switch (action) { +            case ACTION_SIGN_HASH: +                mAction = action; +                mPin = data.getString(EXTRA_PIN); +                mHashToSign = data.getByteArray(EXTRA_NFC_HASH_TO_SIGN); +                mHashAlgo = data.getInt(EXTRA_NFC_HASH_ALGO); +                mServiceIntent = data.getParcelable(EXTRA_DATA); + +                Log.d(Constants.TAG, "NfcActivity mAction: " + mAction); +                Log.d(Constants.TAG, "NfcActivity mPin: " + mPin); +                Log.d(Constants.TAG, "NfcActivity mHashToSign as hex: " + getHex(mHashToSign)); +                Log.d(Constants.TAG, "NfcActivity mServiceIntent: " + mServiceIntent.toString()); +                break; +            case ACTION_DECRYPT_SESSION_KEY: +                mAction = action; +                mPin = data.getString(EXTRA_PIN); +                mEncryptedSessionKey = data.getByteArray(EXTRA_NFC_ENC_SESSION_KEY); +                mServiceIntent = data.getParcelable(EXTRA_DATA); + +                Log.d(Constants.TAG, "NfcActivity mAction: " + mAction); +                Log.d(Constants.TAG, "NfcActivity mPin: " + mPin); +                Log.d(Constants.TAG, "NfcActivity mEncryptedSessionKey as hex: " + getHex(mEncryptedSessionKey)); +                Log.d(Constants.TAG, "NfcActivity mServiceIntent: " + mServiceIntent.toString()); +                break; +            case NfcAdapter.ACTION_TAG_DISCOVERED: +                Log.e(Constants.TAG, "This should not happen! NfcActivity.onCreate() is being called instead of onNewIntent()!"); +                toast("This should not happen! Please create a new bug report that the NFC screen is restarted!"); +                finish(); +                break; +            default: +                Log.d(Constants.TAG, "Action not supported: " + action); +                break;          }      } diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/NfcIntentActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/NfcIntentActivity.java index 945d98379..3e8d688fa 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/NfcIntentActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/NfcIntentActivity.java @@ -15,7 +15,6 @@ import android.nfc.Tag;  import android.nfc.tech.IsoDep;  import android.os.Build;  import android.os.Bundle; -import android.support.v7.app.ActionBarActivity;  import android.view.WindowManager;  import android.widget.Toast; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/PassphraseWizardActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/PassphraseWizardActivity.java index 93778fd0c..872e888a8 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/PassphraseWizardActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/PassphraseWizardActivity.java @@ -209,9 +209,7 @@ public class PassphraseWizardActivity extends FragmentActivity implements LockPa                          FragmentTransaction transaction = getSupportFragmentManager().beginTransaction();                          transaction.replace(R.id.fragmentContainer, lpf).addToBackStack(null).commit();                      } -                } catch (IOException e) { -                    e.printStackTrace(); -                } catch (FormatException e) { +                } catch (IOException | FormatException e) {                      e.printStackTrace();                  } @@ -236,9 +234,7 @@ public class PassphraseWizardActivity extends FragmentActivity implements LockPa                              nfc.setText(R.string.nfc_wrong_tag);                          }                      } -                } catch (IOException e) { -                    e.printStackTrace(); -                } catch (FormatException e) { +                } catch (IOException | FormatException e) {                      e.printStackTrace();                  }              } diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/QrCodeScanActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/QrCodeScanActivity.java index 28488879b..1a7a028c6 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/QrCodeScanActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/QrCodeScanActivity.java @@ -203,7 +203,7 @@ public class QrCodeScanActivity extends FragmentActivity {          data.putString(KeychainIntentService.IMPORT_KEY_SERVER, cloudPrefs.keyserver);          ParcelableKeyRing keyEntry = new ParcelableKeyRing(fingerprint, null, null); -        ArrayList<ParcelableKeyRing> selectedEntries = new ArrayList<ParcelableKeyRing>(); +        ArrayList<ParcelableKeyRing> selectedEntries = new ArrayList<>();          selectedEntries.add(keyEntry);          data.putParcelableArrayList(KeychainIntentService.IMPORT_KEY_LIST, selectedEntries); diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/QrCodeViewActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/QrCodeViewActivity.java index 42ad2258a..74ca19106 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/QrCodeViewActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/QrCodeViewActivity.java @@ -20,7 +20,6 @@ package org.sufficientlysecure.keychain.ui;  import android.graphics.Bitmap;  import android.net.Uri;  import android.os.Bundle; -import android.support.v7.app.ActionBarActivity;  import android.view.View;  import android.view.ViewTreeObserver.OnGlobalLayoutListener;  import android.widget.ImageView; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/SafeSlingerActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/SafeSlingerActivity.java index d5193b2a2..f95644aff 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/SafeSlingerActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/SafeSlingerActivity.java @@ -27,13 +27,9 @@ import android.os.Bundle;  import android.os.Message;  import android.os.Messenger;  import android.support.v4.app.FragmentActivity; -import android.support.v7.app.ActionBarActivity;  import android.view.View; -import android.widget.AdapterView; -import android.widget.ArrayAdapter;  import android.widget.ImageView;  import android.widget.NumberPicker; -import android.widget.Spinner;  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R; @@ -50,7 +46,6 @@ import org.sufficientlysecure.keychain.util.ParcelableFileCache;  import java.io.IOException;  import java.util.ArrayList; -import java.util.List;  import edu.cmu.cylab.starslinger.exchange.ExchangeActivity;  import edu.cmu.cylab.starslinger.exchange.ExchangeConfig; @@ -192,7 +187,7 @@ public class SafeSlingerActivity extends BaseActivity {                  // We parcel this iteratively into a file - anything we can                  // display here, we should be able to import.                  ParcelableFileCache<ParcelableKeyRing> cache = -                        new ParcelableFileCache<ParcelableKeyRing>(activity, "key_import.pcl"); +                        new ParcelableFileCache<>(activity, "key_import.pcl");                  cache.writeCache(it.size(), it.iterator());                  // fill values for this action @@ -220,7 +215,7 @@ public class SafeSlingerActivity extends BaseActivity {      }      private static ArrayList<ParcelableKeyRing> getSlingedKeys(Bundle extras) { -        ArrayList<ParcelableKeyRing> list = new ArrayList<ParcelableKeyRing>(); +        ArrayList<ParcelableKeyRing> list = new ArrayList<>();          if (extras != null) {              byte[] d; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/SelectPublicKeyActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/SelectPublicKeyActivity.java index f7e19706e..33c4abba3 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/SelectPublicKeyActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/SelectPublicKeyActivity.java @@ -20,7 +20,6 @@ package org.sufficientlysecure.keychain.ui;  import android.content.Intent;  import android.os.Bundle; -import android.support.v7.app.ActionBarActivity;  import android.view.View;  import org.sufficientlysecure.keychain.Constants; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/SelectPublicKeyFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/SelectPublicKeyFragment.java index af583bf89..afec3bf06 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/SelectPublicKeyFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/SelectPublicKeyFragment.java @@ -42,7 +42,6 @@ import android.widget.TextView;  import org.sufficientlysecure.keychain.R;  import org.sufficientlysecure.keychain.compatibility.ListFragmentWorkaround; -import org.sufficientlysecure.keychain.pgp.KeyRing;  import org.sufficientlysecure.keychain.provider.KeychainContract.KeyRings;  import org.sufficientlysecure.keychain.provider.KeychainDatabase.Tables;  import org.sufficientlysecure.keychain.ui.adapter.SelectKeyCursorAdapter; @@ -216,7 +215,7 @@ public class SelectPublicKeyFragment extends ListFragmentWorkaround implements T      public long[] getSelectedMasterKeyIds() {          // mListView.getCheckedItemIds() would give the row ids of the KeyRings not the master key          // ids! -        Vector<Long> vector = new Vector<Long>(); +        Vector<Long> vector = new Vector<>();          for (int i = 0; i < getListView().getCount(); ++i) {              if (getListView().isItemChecked(i)) {                  vector.add(mAdapter.getMasterKeyId(i)); @@ -238,7 +237,7 @@ public class SelectPublicKeyFragment extends ListFragmentWorkaround implements T       * @return       */      public String[] getSelectedUserIds() { -        Vector<String> userIds = new Vector<String>(); +        Vector<String> userIds = new Vector<>();          for (int i = 0; i < getListView().getCount(); ++i) {              if (getListView().isItemChecked(i)) {                  userIds.add(mAdapter.getUserId(i)); diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/SettingsKeyServerActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/SettingsKeyServerActivity.java index 365e8026c..60346c16d 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/SettingsKeyServerActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/SettingsKeyServerActivity.java @@ -20,7 +20,6 @@ package org.sufficientlysecure.keychain.ui;  import android.content.Context;  import android.content.Intent;  import android.os.Bundle; -import android.support.v7.app.ActionBarActivity;  import android.view.LayoutInflater;  import android.view.View;  import android.view.View.OnClickListener; @@ -140,7 +139,7 @@ public class SettingsKeyServerActivity extends BaseActivity implements OnClickLi      }      private Vector<String> serverList() { -        Vector<String> servers = new Vector<String>(); +        Vector<String> servers = new Vector<>();          for (int i = 0; i < mEditors.getChildCount(); ++i) {              KeyServerEditor editor = (KeyServerEditor) mEditors.getChildAt(i);              String tmp = editor.getValue(); @@ -153,7 +152,7 @@ public class SettingsKeyServerActivity extends BaseActivity implements OnClickLi      private void okClicked() {          Intent data = new Intent(); -        Vector<String> servers = new Vector<String>(); +        Vector<String> servers = new Vector<>();          for (int i = 0; i < mEditors.getChildCount(); ++i) {              KeyServerEditor editor = (KeyServerEditor) mEditors.getChildAt(i);              String tmp = editor.getValue(); diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/UploadKeyActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/UploadKeyActivity.java index 6cf346c97..ed86fea0a 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/UploadKeyActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/UploadKeyActivity.java @@ -24,7 +24,6 @@ import android.os.Bundle;  import android.os.Message;  import android.os.Messenger;  import android.support.v4.app.NavUtils; -import android.support.v7.app.ActionBarActivity;  import android.view.MenuItem;  import android.view.View;  import android.view.View.OnClickListener; @@ -57,7 +56,7 @@ public class UploadKeyActivity extends BaseActivity {          mUploadButton = findViewById(R.id.upload_key_action_upload);          mKeyServerSpinner = (Spinner) findViewById(R.id.upload_key_keyserver); -        ArrayAdapter<String> adapter = new ArrayAdapter<String>(this, +        ArrayAdapter<String> adapter = new ArrayAdapter<>(this,                  android.R.layout.simple_spinner_item, Preferences.getPreferences(this)                  .getKeyServers()          ); diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewCertActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewCertActivity.java index a88b0f7cf..05d9dd58e 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewCertActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewCertActivity.java @@ -27,9 +27,6 @@ import android.support.v4.app.NavUtils;  import android.support.v4.content.CursorLoader;  import android.support.v4.content.Loader;  import android.support.v7.app.ActionBar; -import android.support.v7.app.ActionBarActivity; -import android.text.SpannableString; -import android.text.SpannableStringBuilder;  import android.text.format.DateFormat;  import android.view.MenuItem;  import android.view.View; @@ -37,7 +34,6 @@ import android.widget.TextView;  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R; -import org.sufficientlysecure.keychain.pgp.CanonicalizedPublicKeyRing;  import org.sufficientlysecure.keychain.pgp.exception.PgpKeyNotFoundException;  import org.sufficientlysecure.keychain.ui.util.KeyFormattingUtils;  import org.sufficientlysecure.keychain.pgp.WrappedSignature; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyAdvancedActivity.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyAdvancedActivity.java index 7176232c5..4e3c6d2a6 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyAdvancedActivity.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyAdvancedActivity.java @@ -20,8 +20,6 @@ package org.sufficientlysecure.keychain.ui;  import android.net.Uri;  import android.os.Bundle; -import android.support.v7.app.ActionBar; -import android.support.v7.app.ActionBarActivity;  import android.view.View;  import org.sufficientlysecure.keychain.Constants; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyShareFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyShareFragment.java index aa260b654..7c47cbd0d 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyShareFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/ViewKeyShareFragment.java @@ -228,10 +228,7 @@ public class ViewKeyShareFragment extends LoaderFragment implements                  }                  startActivity(Intent.createChooser(sendIntent, title));              } -        } catch (PgpGeneralException e) { -            Log.e(Constants.TAG, "error processing key!", e); -            Notify.showNotify(getActivity(), R.string.error_key_processing, Notify.Style.ERROR); -        } catch (IOException e) { +        } catch (PgpGeneralException | IOException e) {              Log.e(Constants.TAG, "error processing key!", e);              Notify.showNotify(getActivity(), R.string.error_key_processing, Notify.Style.ERROR);          } catch (ProviderHelper.NotFoundException e) { diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/ImportKeysAdapter.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/ImportKeysAdapter.java index 6c81e9193..8e82dd7d0 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/ImportKeysAdapter.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/ImportKeysAdapter.java @@ -95,8 +95,8 @@ public class ImportKeysAdapter extends ArrayAdapter<ImportKeysListEntry> {       * @see org.sufficientlysecure.keychain.operations.ImportExportOperation       */      public ArrayList<ImportKeysListEntry> getSelectedEntries() { -        ArrayList<ImportKeysListEntry> result = new ArrayList<ImportKeysListEntry>(); -        ArrayList<ImportKeysListEntry> secrets = new ArrayList<ImportKeysListEntry>(); +        ArrayList<ImportKeysListEntry> result = new ArrayList<>(); +        ArrayList<ImportKeysListEntry> secrets = new ArrayList<>();          if (mData == null) {              return result;          } diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/ImportKeysListCloudLoader.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/ImportKeysListCloudLoader.java index 176c3ff5b..235fdf1d5 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/ImportKeysListCloudLoader.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/ImportKeysListCloudLoader.java @@ -39,7 +39,7 @@ public class ImportKeysListCloudLoader      Preferences.CloudSearchPrefs mCloudPrefs;      String mServerQuery; -    private ArrayList<ImportKeysListEntry> mEntryList = new ArrayList<ImportKeysListEntry>(); +    private ArrayList<ImportKeysListEntry> mEntryList = new ArrayList<>();      private AsyncTaskResultWrapper<ArrayList<ImportKeysListEntry>> mEntryListWrapper;      public ImportKeysListCloudLoader(Context context, String serverQuery, Preferences.CloudSearchPrefs cloudPrefs) { @@ -51,7 +51,7 @@ public class ImportKeysListCloudLoader      @Override      public AsyncTaskResultWrapper<ArrayList<ImportKeysListEntry>> loadInBackground() { -        mEntryListWrapper = new AsyncTaskResultWrapper<ArrayList<ImportKeysListEntry>>(mEntryList, null); +        mEntryListWrapper = new AsyncTaskResultWrapper<>(mEntryList, null);          if (mServerQuery == null) {              Log.e(Constants.TAG, "mServerQuery is null!"); @@ -119,7 +119,7 @@ public class ImportKeysListCloudLoader                  mEntryList.addAll(searchResult);              }              GetKeyResult getKeyResult = new GetKeyResult(GetKeyResult.RESULT_OK, null); -            mEntryListWrapper = new AsyncTaskResultWrapper<ArrayList<ImportKeysListEntry>>(mEntryList, getKeyResult); +            mEntryListWrapper = new AsyncTaskResultWrapper<>(mEntryList, getKeyResult);          } catch (Keyserver.CloudSearchFailureException e) {              // convert exception to result parcel              int error = GetKeyResult.RESULT_ERROR; @@ -140,7 +140,7 @@ public class ImportKeysListCloudLoader              OperationResult.OperationLog log = new OperationResult.OperationLog();              log.add(logType, 0);              GetKeyResult getKeyResult = new GetKeyResult(error, log); -            mEntryListWrapper = new AsyncTaskResultWrapper<ArrayList<ImportKeysListEntry>>(mEntryList, getKeyResult); +            mEntryListWrapper = new AsyncTaskResultWrapper<>(mEntryList, getKeyResult);          }      }  } diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/ImportKeysListLoader.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/ImportKeysListLoader.java index cecad2716..9d1e8468c 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/ImportKeysListLoader.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/ImportKeysListLoader.java @@ -35,7 +35,6 @@ import org.sufficientlysecure.keychain.util.PositionAwareInputStream;  import java.io.BufferedInputStream;  import java.io.IOException;  import java.util.ArrayList; -import java.util.Iterator;  public class ImportKeysListLoader          extends AsyncTaskLoader<AsyncTaskResultWrapper<ArrayList<ImportKeysListEntry>>> { @@ -55,8 +54,8 @@ public class ImportKeysListLoader      final Context mContext;      final InputData mInputData; -    ArrayList<ImportKeysListEntry> mData = new ArrayList<ImportKeysListEntry>(); -    LongSparseArray<ParcelableKeyRing> mParcelableRings = new LongSparseArray<ParcelableKeyRing>(); +    ArrayList<ImportKeysListEntry> mData = new ArrayList<>(); +    LongSparseArray<ParcelableKeyRing> mParcelableRings = new LongSparseArray<>();      AsyncTaskResultWrapper<ArrayList<ImportKeysListEntry>> mEntryListWrapper;      public ImportKeysListLoader(Context context, InputData inputData) { @@ -73,7 +72,7 @@ public class ImportKeysListLoader          }          GetKeyResult getKeyResult = new GetKeyResult(GetKeyResult.RESULT_OK, null); -        mEntryListWrapper = new AsyncTaskResultWrapper<ArrayList<ImportKeysListEntry>>(mData, getKeyResult); +        mEntryListWrapper = new AsyncTaskResultWrapper<>(mData, getKeyResult);          if (mInputData == null) {              Log.e(Constants.TAG, "Input data is null!"); @@ -140,7 +139,7 @@ public class ImportKeysListLoader              OperationResult.OperationLog log = new OperationResult.OperationLog();              log.add(OperationResult.LogType.MSG_GET_NO_VALID_KEYS, 0);              GetKeyResult getKeyResult = new GetKeyResult(GetKeyResult.RESULT_ERROR_NO_VALID_KEYS, log); -            mEntryListWrapper = new AsyncTaskResultWrapper<ArrayList<ImportKeysListEntry>> +            mEntryListWrapper = new AsyncTaskResultWrapper<>                      (mData, getKeyResult);          }      } diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/KeyValueSpinnerAdapter.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/KeyValueSpinnerAdapter.java index 80d605fb9..b8fe21941 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/KeyValueSpinnerAdapter.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/KeyValueSpinnerAdapter.java @@ -33,7 +33,7 @@ public class KeyValueSpinnerAdapter extends ArrayAdapter<String> {      static <K, V extends Comparable<? super V>> SortedSet<Map.Entry<K, V>> entriesSortedByValues(              Map<K, V> map) { -        SortedSet<Map.Entry<K, V>> sortedEntries = new TreeSet<Map.Entry<K, V>>( +        SortedSet<Map.Entry<K, V>> sortedEntries = new TreeSet<>(                  new Comparator<Map.Entry<K, V>>() {                      @Override                      public int compare(Map.Entry<K, V> e1, Map.Entry<K, V> e2) { diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/MultiUserIdsAdapter.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/MultiUserIdsAdapter.java index 9f29826ef..47ad5e664 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/MultiUserIdsAdapter.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/MultiUserIdsAdapter.java @@ -44,7 +44,7 @@ public class MultiUserIdsAdapter extends CursorAdapter {      public MultiUserIdsAdapter(Context context, Cursor c, int flags) {          super(context, c, flags);          mInflater = LayoutInflater.from(context); -        mCheckStates = new ArrayList<Boolean>(); +        mCheckStates = new ArrayList<>();      }      @Override @@ -148,7 +148,7 @@ public class MultiUserIdsAdapter extends CursorAdapter {      }      public ArrayList<CertifyAction> getSelectedCertifyActions() { -        LongSparseArray<CertifyAction> actions = new LongSparseArray<CertifyAction>(); +        LongSparseArray<CertifyAction> actions = new LongSparseArray<>();          for (int i = 0; i < mCheckStates.size(); i++) {              if (mCheckStates.get(i)) {                  mCursor.moveToPosition(i); @@ -171,7 +171,7 @@ public class MultiUserIdsAdapter extends CursorAdapter {              }          } -        ArrayList<CertifyAction> result = new ArrayList<CertifyAction>(actions.size()); +        ArrayList<CertifyAction> result = new ArrayList<>(actions.size());          for (int i = 0; i < actions.size(); i++) {              result.add(actions.valueAt(i));          } diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/PagerTabStripAdapter.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/PagerTabStripAdapter.java index 330254a8f..963e77fe9 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/PagerTabStripAdapter.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/PagerTabStripAdapter.java @@ -27,7 +27,7 @@ import java.util.ArrayList;  public class PagerTabStripAdapter extends FragmentPagerAdapter {      protected final Activity mActivity; -    protected final ArrayList<TabInfo> mTabs = new ArrayList<TabInfo>(); +    protected final ArrayList<TabInfo> mTabs = new ArrayList<>();      static final class TabInfo {          public final Class<?> clss; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/SubkeysAdapter.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/SubkeysAdapter.java index a8fa3f1aa..431cdc845 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/SubkeysAdapter.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/SubkeysAdapter.java @@ -36,7 +36,6 @@ import android.widget.TextView;  import org.sufficientlysecure.keychain.R;  import org.sufficientlysecure.keychain.service.SaveKeyringParcel.SubkeyChange; -import org.sufficientlysecure.keychain.ui.util.FormattingUtils;  import org.sufficientlysecure.keychain.pgp.CanonicalizedSecretKey.SecretKeyType;  import org.sufficientlysecure.keychain.ui.util.KeyFormattingUtils;  import org.sufficientlysecure.keychain.provider.KeychainContract.Keys; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/TabsAdapter.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/TabsAdapter.java index 9ddfa90be..44afed351 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/TabsAdapter.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/TabsAdapter.java @@ -33,7 +33,7 @@ public class TabsAdapter extends FragmentStatePagerAdapter implements ActionBar.      private final Context mContext;      private final ActionBar mActionBar;      private final ViewPager mViewPager; -    private final ArrayList<TabInfo> mTabs = new ArrayList<TabInfo>(); +    private final ArrayList<TabInfo> mTabs = new ArrayList<>();      static final class TabInfo {          public final Class<?> clss; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/UserIdsAdapter.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/UserIdsAdapter.java index a778c7fa7..52c21e253 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/UserIdsAdapter.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/adapter/UserIdsAdapter.java @@ -221,7 +221,7 @@ public class UserIdsAdapter extends CursorAdapter implements AdapterView.OnItemC      }      public ArrayList<String> getSelectedUserIds() { -        ArrayList<String> result = new ArrayList<String>(); +        ArrayList<String> result = new ArrayList<>();          for (int i = 0; i < mCheckStates.size(); i++) {              if (mCheckStates.get(i)) {                  mCursor.moveToPosition(i); diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/dialog/AddSubkeyDialogFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/dialog/AddSubkeyDialogFragment.java index b4119a5eb..d5376cbdc 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/dialog/AddSubkeyDialogFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/dialog/AddSubkeyDialogFragment.java @@ -145,20 +145,20 @@ public class AddSubkeyDialogFragment extends DialogFragment {          }          { -            ArrayList<Choice<Algorithm>> choices = new ArrayList<Choice<Algorithm>>(); -            choices.add(new Choice<Algorithm>(Algorithm.DSA, getResources().getString( +            ArrayList<Choice<Algorithm>> choices = new ArrayList<>(); +            choices.add(new Choice<>(Algorithm.DSA, getResources().getString(                      R.string.dsa)));              if (!mWillBeMasterKey) { -                choices.add(new Choice<Algorithm>(Algorithm.ELGAMAL, getResources().getString( +                choices.add(new Choice<>(Algorithm.ELGAMAL, getResources().getString(                          R.string.elgamal)));              } -            choices.add(new Choice<Algorithm>(Algorithm.RSA, getResources().getString( +            choices.add(new Choice<>(Algorithm.RSA, getResources().getString(                      R.string.rsa))); -            choices.add(new Choice<Algorithm>(Algorithm.ECDSA, getResources().getString( +            choices.add(new Choice<>(Algorithm.ECDSA, getResources().getString(                      R.string.ecdsa))); -            choices.add(new Choice<Algorithm>(Algorithm.ECDH, getResources().getString( +            choices.add(new Choice<>(Algorithm.ECDH, getResources().getString(                      R.string.ecdh))); -            ArrayAdapter<Choice<Algorithm>> adapter = new ArrayAdapter<Choice<Algorithm>>(context, +            ArrayAdapter<Choice<Algorithm>> adapter = new ArrayAdapter<>(context,                      android.R.layout.simple_spinner_item, choices);              adapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);              mAlgorithmSpinner.setAdapter(adapter); @@ -172,20 +172,20 @@ public class AddSubkeyDialogFragment extends DialogFragment {          }          // dynamic ArrayAdapter must be created (instead of ArrayAdapter.getFromResource), because it's content may change -        ArrayAdapter<CharSequence> keySizeAdapter = new ArrayAdapter<CharSequence>(context, android.R.layout.simple_spinner_item, +        ArrayAdapter<CharSequence> keySizeAdapter = new ArrayAdapter<>(context, android.R.layout.simple_spinner_item,                  new ArrayList<CharSequence>(Arrays.asList(getResources().getStringArray(R.array.rsa_key_size_spinner_values))));          keySizeAdapter.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);          mKeySizeSpinner.setAdapter(keySizeAdapter);          mKeySizeSpinner.setSelection(1); // Default to 4096 for the key length          { -            ArrayList<Choice<Curve>> choices = new ArrayList<Choice<Curve>>(); +            ArrayList<Choice<Curve>> choices = new ArrayList<>(); -            choices.add(new Choice<Curve>(Curve.NIST_P256, getResources().getString( +            choices.add(new Choice<>(Curve.NIST_P256, getResources().getString(                      R.string.key_curve_nist_p256))); -            choices.add(new Choice<Curve>(Curve.NIST_P384, getResources().getString( +            choices.add(new Choice<>(Curve.NIST_P384, getResources().getString(                      R.string.key_curve_nist_p384))); -            choices.add(new Choice<Curve>(Curve.NIST_P521, getResources().getString( +            choices.add(new Choice<>(Curve.NIST_P521, getResources().getString(                      R.string.key_curve_nist_p521)));              /* @see SaveKeyringParcel @@ -197,7 +197,7 @@ public class AddSubkeyDialogFragment extends DialogFragment {                      R.string.key_curve_bp_p512)));              */ -            ArrayAdapter<Choice<Curve>> adapter = new ArrayAdapter<Choice<Curve>>(context, +            ArrayAdapter<Choice<Curve>> adapter = new ArrayAdapter<>(context,                      android.R.layout.simple_spinner_item, choices);              mCurveSpinner.setAdapter(adapter);              // make NIST P-256 the default diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/dialog/AddUserIdDialogFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/dialog/AddUserIdDialogFragment.java index 3eef04aa7..a4ecc7c27 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/dialog/AddUserIdDialogFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/dialog/AddUserIdDialogFragment.java @@ -85,7 +85,7 @@ public class AddUserIdDialogFragment extends DialogFragment implements OnEditorA          mMessenger = getArguments().getParcelable(ARG_MESSENGER);          String predefinedName = getArguments().getString(ARG_NAME); -        ArrayAdapter<String> autoCompleteEmailAdapter = new ArrayAdapter<String> +        ArrayAdapter<String> autoCompleteEmailAdapter = new ArrayAdapter<>                  (getActivity(), android.R.layout.simple_spinner_dropdown_item,                          ContactHelper.getPossibleUserEmails(getActivity())                  ); @@ -150,7 +150,7 @@ public class AddUserIdDialogFragment extends DialogFragment implements OnEditorA          mName.setThreshold(1); // Start working from first character          mName.setAdapter( -                new ArrayAdapter<String> +                new ArrayAdapter<>                          (getActivity(), android.R.layout.simple_spinner_dropdown_item,                                  ContactHelper.getPossibleUserNames(getActivity())                          ) diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/dialog/DeleteFileDialogFragment.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/dialog/DeleteFileDialogFragment.java index 0926de1d0..879e3f6da 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/dialog/DeleteFileDialogFragment.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/dialog/DeleteFileDialogFragment.java @@ -28,7 +28,6 @@ import android.support.v4.app.DialogFragment;  import android.support.v4.app.FragmentActivity;  import android.widget.Toast; -import org.apache.http.conn.scheme.Scheme;  import org.sufficientlysecure.keychain.R;  import org.sufficientlysecure.keychain.util.FileHelper; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/util/QrCodeUtils.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/util/QrCodeUtils.java index 36f38045f..0bb4100c5 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/util/QrCodeUtils.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/util/QrCodeUtils.java @@ -47,7 +47,7 @@ public class QrCodeUtils {       */      public static Bitmap getQRCodeBitmap(final String input, final int size) {          try { -            final Hashtable<EncodeHintType, Object> hints = new Hashtable<EncodeHintType, Object>(); +            final Hashtable<EncodeHintType, Object> hints = new Hashtable<>();              hints.put(EncodeHintType.ERROR_CORRECTION, ErrorCorrectionLevel.M);              final BitMatrix result = new QRCodeWriter().encode(input, BarcodeFormat.QR_CODE, size,                      size, hints); diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/CertifyKeySpinner.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/CertifyKeySpinner.java index 14f42eb04..904cde47e 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/CertifyKeySpinner.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/CertifyKeySpinner.java @@ -29,7 +29,6 @@ import android.widget.ImageView;  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.provider.KeychainContract;  import org.sufficientlysecure.keychain.provider.KeychainDatabase; -import org.sufficientlysecure.keychain.provider.KeychainDatabase.Tables;  import org.sufficientlysecure.keychain.ui.util.KeyFormattingUtils;  public class CertifyKeySpinner extends KeySpinner { diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/EncryptKeyCompletionView.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/EncryptKeyCompletionView.java index e03a14989..5f6f13181 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/EncryptKeyCompletionView.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/EncryptKeyCompletionView.java @@ -28,7 +28,6 @@ import android.support.v4.app.FragmentActivity;  import android.support.v4.app.LoaderManager;  import android.support.v4.content.CursorLoader;  import android.support.v4.content.Loader; -import android.text.SpannableStringBuilder;  import android.util.AttributeSet;  import android.view.LayoutInflater;  import android.view.View; @@ -46,7 +45,6 @@ import org.sufficientlysecure.keychain.pgp.exception.PgpKeyNotFoundException;  import org.sufficientlysecure.keychain.ui.util.KeyFormattingUtils;  import org.sufficientlysecure.keychain.util.ContactHelper;  import org.sufficientlysecure.keychain.pgp.KeyRing; -import org.sufficientlysecure.keychain.pgp.exception.PgpGeneralException;  import org.sufficientlysecure.keychain.provider.CachedPublicKeyRing;  import org.sufficientlysecure.keychain.provider.KeychainContract.KeyRings;  import org.sufficientlysecure.keychain.provider.KeychainDatabase.Tables; @@ -165,7 +163,7 @@ public class EncryptKeyCompletionView extends TokenCompleteTextView {              setAdapter(new EncryptKeyAdapter(Collections.<EncryptionKey>emptyList()));              return;          } -        ArrayList<EncryptionKey> keys = new ArrayList<EncryptionKey>(); +        ArrayList<EncryptionKey> keys = new ArrayList<>();          while (cursor.moveToNext()) {              try {                  EncryptionKey key = new EncryptionKey(cursor); diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/ListAwareSwipeRefreshLayout.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/ListAwareSwipeRefreshLayout.java index b3c3eb417..3403208d7 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/ListAwareSwipeRefreshLayout.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/ListAwareSwipeRefreshLayout.java @@ -20,13 +20,8 @@ package org.sufficientlysecure.keychain.ui.widget;  import android.content.Context;  import android.support.v4.widget.NoScrollableSwipeRefreshLayout;  import android.util.AttributeSet; -import android.view.InputDevice; -import android.view.InputDevice.MotionRange;  import android.view.MotionEvent; -import org.sufficientlysecure.keychain.Constants; -import org.sufficientlysecure.keychain.util.Log; -  import se.emilsjolander.stickylistheaders.StickyListHeadersListView;  public class ListAwareSwipeRefreshLayout extends NoScrollableSwipeRefreshLayout { diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/SignKeySpinner.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/SignKeySpinner.java index 59d05a62e..9c8e4aedb 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/SignKeySpinner.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/ui/widget/SignKeySpinner.java @@ -26,7 +26,6 @@ import android.support.v4.content.Loader;  import android.util.AttributeSet;  import android.widget.ImageView; -import org.sufficientlysecure.keychain.R;  import org.sufficientlysecure.keychain.provider.KeychainContract;  import org.sufficientlysecure.keychain.ui.util.KeyFormattingUtils; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/AlgorithmNames.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/AlgorithmNames.java index 99db634ac..c1955f75b 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/AlgorithmNames.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/AlgorithmNames.java @@ -23,7 +23,6 @@ import android.app.Activity;  import org.spongycastle.bcpg.CompressionAlgorithmTags;  import org.spongycastle.bcpg.HashAlgorithmTags;  import org.spongycastle.openpgp.PGPEncryptedData; -import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R;  import java.util.HashMap; @@ -32,9 +31,9 @@ import java.util.HashMap;  public class AlgorithmNames {      Activity mActivity; -    HashMap<Integer, String> mEncryptionNames = new HashMap<Integer, String>(); -    HashMap<Integer, String> mHashNames = new HashMap<Integer, String>(); -    HashMap<Integer, String> mCompressionNames = new HashMap<Integer, String>(); +    HashMap<Integer, String> mEncryptionNames = new HashMap<>(); +    HashMap<Integer, String> mHashNames = new HashMap<>(); +    HashMap<Integer, String> mCompressionNames = new HashMap<>();      public AlgorithmNames(Activity context) {          super(); diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/ContactHelper.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/ContactHelper.java index 4ce7a1bac..11b29f521 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/ContactHelper.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/ContactHelper.java @@ -73,20 +73,20 @@ public class ContactHelper {              ContactsContract.Data.RAW_CONTACT_ID + "=? AND " + ContactsContract.Data.MIMETYPE + "=?";      public static final String ID_SELECTION = ContactsContract.RawContacts._ID + "=?"; -    private static final Map<String, Bitmap> photoCache = new HashMap<String, Bitmap>(); +    private static final Map<String, Bitmap> photoCache = new HashMap<>();      public static List<String> getPossibleUserEmails(Context context) {          Set<String> accountMails = getAccountEmails(context);          accountMails.addAll(getMainProfileContactEmails(context));          // now return the Set (without duplicates) as a List -        return new ArrayList<String>(accountMails); +        return new ArrayList<>(accountMails);      }      public static List<String> getPossibleUserNames(Context context) {          Set<String> accountMails = getAccountEmails(context);          Set<String> names = getContactNamesFromEmails(context, accountMails);          names.addAll(getMainProfileContactName(context)); -        return new ArrayList<String>(names); +        return new ArrayList<>(names);      }      /** @@ -97,7 +97,7 @@ public class ContactHelper {       */      private static Set<String> getAccountEmails(Context context) {          final Account[] accounts = AccountManager.get(context).getAccounts(); -        final Set<String> emailSet = new HashSet<String>(); +        final Set<String> emailSet = new HashSet<>();          for (Account account : accounts) {              if (Patterns.EMAIL_ADDRESS.matcher(account.name).matches()) {                  emailSet.add(account.name); @@ -116,7 +116,7 @@ public class ContactHelper {       */      private static Set<String> getContactNamesFromEmails(Context context, Set<String> emails) {          if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.ICE_CREAM_SANDWICH) { -            Set<String> names = new HashSet<String>(); +            Set<String> names = new HashSet<>();              for (String email : emails) {                  ContentResolver resolver = context.getContentResolver();                  Cursor profileCursor = resolver.query( @@ -128,7 +128,7 @@ public class ContactHelper {                  );                  if (profileCursor == null) return null; -                Set<String> currNames = new HashSet<String>(); +                Set<String> currNames = new HashSet<>();                  while (profileCursor.moveToNext()) {                      String name = profileCursor.getString(1);                      if (name != null) { @@ -140,7 +140,7 @@ public class ContactHelper {              }              return names;          } else { -            return new HashSet<String>(); +            return new HashSet<>();          }      } @@ -172,7 +172,7 @@ public class ContactHelper {              );              if (profileCursor == null) return null; -            Set<String> emails = new HashSet<String>(); +            Set<String> emails = new HashSet<>();              while (profileCursor.moveToNext()) {                  String email = profileCursor.getString(0);                  if (email != null) { @@ -182,7 +182,7 @@ public class ContactHelper {              profileCursor.close();              return emails;          } else { -            return new HashSet<String>(); +            return new HashSet<>();          }      } @@ -201,7 +201,7 @@ public class ContactHelper {                      null, null, null);              if (profileCursor == null) return null; -            Set<String> names = new HashSet<String>(); +            Set<String> names = new HashSet<>();              // should only contain one entry!              while (profileCursor.moveToNext()) {                  String name = profileCursor.getString(0); @@ -210,9 +210,9 @@ public class ContactHelper {                  }              }              profileCursor.close(); -            return new ArrayList<String>(names); +            return new ArrayList<>(names);          } else { -            return new ArrayList<String>(); +            return new ArrayList<>();          }      } @@ -221,9 +221,9 @@ public class ContactHelper {          Cursor mailCursor = resolver.query(ContactsContract.CommonDataKinds.Email.CONTENT_URI,                  new String[]{ContactsContract.CommonDataKinds.Email.DATA},                  null, null, null); -        if (mailCursor == null) return new ArrayList<String>(); +        if (mailCursor == null) return new ArrayList<>(); -        Set<String> mails = new HashSet<String>(); +        Set<String> mails = new HashSet<>();          while (mailCursor.moveToNext()) {              String email = mailCursor.getString(0);              if (email != null) { @@ -231,7 +231,7 @@ public class ContactHelper {              }          }          mailCursor.close(); -        return new ArrayList<String>(mails); +        return new ArrayList<>(mails);      }      public static List<String> getContactNames(Context context) { @@ -239,9 +239,9 @@ public class ContactHelper {          Cursor cursor = resolver.query(ContactsContract.Contacts.CONTENT_URI,                  new String[]{ContactsContract.Contacts.DISPLAY_NAME},                  null, null, null); -        if (cursor == null) return new ArrayList<String>(); +        if (cursor == null) return new ArrayList<>(); -        Set<String> names = new HashSet<String>(); +        Set<String> names = new HashSet<>();          while (cursor.moveToNext()) {              String name = cursor.getString(0);              if (name != null) { @@ -249,7 +249,7 @@ public class ContactHelper {              }          }          cursor.close(); -        return new ArrayList<String>(names); +        return new ArrayList<>(names);      }      @TargetApi(Build.VERSION_CODES.JELLY_BEAN) @@ -309,7 +309,7 @@ public class ContactHelper {                  boolean isExpired = !cursor.isNull(4) && new Date(cursor.getLong(4) * 1000).before(new Date());                  boolean isRevoked = cursor.getInt(5) > 0;                  int rawContactId = findRawContactId(resolver, fingerprint); -                ArrayList<ContentProviderOperation> ops = new ArrayList<ContentProviderOperation>(); +                ArrayList<ContentProviderOperation> ops = new ArrayList<>();                  // Do not store expired or revoked keys in contact db - and remove them if they already exist                  if (isExpired || isRevoked) { @@ -351,7 +351,7 @@ public class ContactHelper {       * @return a set of all key fingerprints currently present in the contact db       */      private static Set<String> getRawContactFingerprints(ContentResolver resolver) { -        HashSet<String> result = new HashSet<String>(); +        HashSet<String> result = new HashSet<>();          Cursor fingerprints = resolver.query(ContactsContract.RawContacts.CONTENT_URI, SOURCE_ID_PROJECTION,                  ACCOUNT_TYPE_SELECTION, new String[]{Constants.ACCOUNT_TYPE}, null);          if (fingerprints != null) { diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/EmailKeyHelper.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/EmailKeyHelper.java index 49d4d8bf8..8334b37ec 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/EmailKeyHelper.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/EmailKeyHelper.java @@ -42,13 +42,13 @@ public class EmailKeyHelper {      public static void importAll(Context context, Messenger messenger, List<String> mails) {          // Collect all candidates as ImportKeysListEntry (set for deduplication) -        Set<ImportKeysListEntry> entries = new HashSet<ImportKeysListEntry>(); +        Set<ImportKeysListEntry> entries = new HashSet<>();          for (String mail : mails) {              entries.addAll(getEmailKeys(context, mail));          }          // Put them in a list and import -        ArrayList<ParcelableKeyRing> keys = new ArrayList<ParcelableKeyRing>(entries.size()); +        ArrayList<ParcelableKeyRing> keys = new ArrayList<>(entries.size());          for (ImportKeysListEntry entry : entries) {              keys.add(new ParcelableKeyRing(entry.getFingerprintHex(), entry.getKeyIdHex(), null));          } @@ -56,7 +56,7 @@ public class EmailKeyHelper {      }      public static Set<ImportKeysListEntry> getEmailKeys(Context context, String mail) { -        Set<ImportKeysListEntry> keys = new HashSet<ImportKeysListEntry>(); +        Set<ImportKeysListEntry> keys = new HashSet<>();          // Try _hkp._tcp SRV record first          String[] mailparts = mail.split("@"); @@ -90,7 +90,7 @@ public class EmailKeyHelper {      }      public static List<ImportKeysListEntry> getEmailKeys(String mail, Keyserver keyServer) { -        Set<ImportKeysListEntry> keys = new HashSet<ImportKeysListEntry>(); +        Set<ImportKeysListEntry> keys = new HashSet<>();          try {              for (ImportKeysListEntry key : keyServer.search(mail)) {                  if (key.isRevoked() || key.isExpired()) continue; @@ -103,6 +103,6 @@ public class EmailKeyHelper {          } catch (Keyserver.QueryFailedException ignored) {          } catch (Keyserver.QueryNeedsRepairException ignored) {          } -        return new ArrayList<ImportKeysListEntry>(keys); +        return new ArrayList<>(keys);      }  } diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/ExportHelper.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/ExportHelper.java index 7492d95b2..fee9ff487 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/ExportHelper.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/ExportHelper.java @@ -25,12 +25,10 @@ import android.os.Handler;  import android.os.Message;  import android.os.Messenger;  import android.support.v7.app.ActionBarActivity; -import android.widget.Toast;  import org.sufficientlysecure.keychain.Constants;  import org.sufficientlysecure.keychain.R;  import org.sufficientlysecure.keychain.operations.results.ExportResult; -import org.sufficientlysecure.keychain.pgp.exception.PgpGeneralException;  import org.sufficientlysecure.keychain.pgp.exception.PgpKeyNotFoundException;  import org.sufficientlysecure.keychain.provider.ProviderHelper;  import org.sufficientlysecure.keychain.service.KeychainIntentService; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/Iso7816TLV.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/Iso7816TLV.java index 90afd3bc0..c0483ad04 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/Iso7816TLV.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/Iso7816TLV.java @@ -125,7 +125,7 @@ public class Iso7816TLV {      public static Iso7816TLV[] readList(byte[] data, boolean recursive) throws IOException {          ByteBuffer buf = ByteBuffer.wrap(data); -        ArrayList<Iso7816TLV> result = new ArrayList<Iso7816TLV>(); +        ArrayList<Iso7816TLV> result = new ArrayList<>();          // read while data is available. this will fail if there is trailing data!          while (buf.hasRemaining()) { diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/KeyUpdateHelper.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/KeyUpdateHelper.java index 76ec9f75f..943b913d7 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/KeyUpdateHelper.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/KeyUpdateHelper.java @@ -17,21 +17,6 @@  package org.sufficientlysecure.keychain.util; -import android.content.Context; -import android.content.Intent; -import android.os.AsyncTask; -import android.os.Bundle; -import android.os.Messenger; - -import org.sufficientlysecure.keychain.keyimport.ImportKeysListEntry; -import org.sufficientlysecure.keychain.provider.KeychainContract; -import org.sufficientlysecure.keychain.provider.ProviderHelper; -import org.sufficientlysecure.keychain.service.KeychainIntentService; -import org.sufficientlysecure.keychain.service.KeychainIntentServiceHandler; - -import java.util.ArrayList; -import java.util.List; -  public class KeyUpdateHelper {      /* diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/Log.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/Log.java index b4f7c5767..8b165cd57 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/Log.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/Log.java @@ -21,9 +21,6 @@ import android.os.Bundle;  import org.sufficientlysecure.keychain.Constants; -import java.io.IOException; -import java.io.StreamTokenizer; -import java.io.StringReader;  import java.util.Iterator;  import java.util.Set; diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/ParcelableFileCache.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/ParcelableFileCache.java index 3081021cf..5de682fe6 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/ParcelableFileCache.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/ParcelableFileCache.java @@ -32,9 +32,7 @@ import java.io.FileInputStream;  import java.io.FileNotFoundException;  import java.io.FileOutputStream;  import java.io.IOException; -import java.util.ArrayList;  import java.util.Iterator; -import java.util.List;  /**   * When sending large data (over 1MB) through Androids Binder IPC you get diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/Preferences.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/Preferences.java index 5efd6c419..8d4af58d7 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/Preferences.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/Preferences.java @@ -200,7 +200,7 @@ public class Preferences {      public String[] getKeyServers() {          String rawData = mSharedPreferences.getString(Constants.Pref.KEY_SERVERS,                  Constants.Defaults.KEY_SERVERS); -        Vector<String> servers = new Vector<String>(); +        Vector<String> servers = new Vector<>();          String chunks[] = rawData.split(",");          for (String c : chunks) {              String tmp = c.trim(); @@ -281,7 +281,7 @@ public class Preferences {                  case 3: {                      // migrate keyserver to hkps                      String[] serversArray = getKeyServers(); -                    ArrayList<String> servers = new ArrayList<String>(Arrays.asList(serversArray)); +                    ArrayList<String> servers = new ArrayList<>(Arrays.asList(serversArray));                      ListIterator<String> it = servers.listIterator();                      while (it.hasNext()) {                          String server = it.next(); diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/ShareHelper.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/ShareHelper.java index e97438772..120b84a3b 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/ShareHelper.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/ShareHelper.java @@ -51,10 +51,10 @@ public class ShareHelper {              return Intent.createChooser(prototype, title);          } -        List<LabeledIntent> targetedShareIntents = new ArrayList<LabeledIntent>(); +        List<LabeledIntent> targetedShareIntents = new ArrayList<>();          List<ResolveInfo> resInfoList = mContext.getPackageManager().queryIntentActivities(prototype, 0); -        List<ResolveInfo> resInfoListFiltered = new ArrayList<ResolveInfo>(); +        List<ResolveInfo> resInfoListFiltered = new ArrayList<>();          if (!resInfoList.isEmpty()) {              for (ResolveInfo resolveInfo : resInfoList) {                  // do not add blacklisted ones diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/TlsHelper.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/TlsHelper.java index 9946d81aa..7e318281d 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/TlsHelper.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/util/TlsHelper.java @@ -50,7 +50,7 @@ public class TlsHelper {          }      } -    private static Map<String, byte[]> sStaticCA = new HashMap<String, byte[]>(); +    private static Map<String, byte[]> sStaticCA = new HashMap<>();      public static void addStaticCA(String domain, byte[] certificate) {          sStaticCA.put(domain, certificate); @@ -120,13 +120,7 @@ public class TlsHelper {              urlConnection.setSSLSocketFactory(context.getSocketFactory());              return urlConnection; -        } catch (CertificateException e) { -            throw new TlsHelperException(e); -        } catch (NoSuchAlgorithmException e) { -            throw new TlsHelperException(e); -        } catch (KeyStoreException e) { -            throw new TlsHelperException(e); -        } catch (KeyManagementException e) { +        } catch (CertificateException | KeyManagementException | KeyStoreException | NoSuchAlgorithmException e) {              throw new TlsHelperException(e);          }      } | 
