diff options
| author | Vincent Breitmoser <valodim@mugenguild.com> | 2014-07-31 22:36:04 +0200 | 
|---|---|---|
| committer | Vincent Breitmoser <valodim@mugenguild.com> | 2014-07-31 22:36:25 +0200 | 
| commit | c5ce794ef782b6809c3f0b3cacfa3bcd6a5a85b7 (patch) | |
| tree | 1593f63b8676ce0ab6330926dbfa1f1a15d13951 | |
| parent | 50aea621ba4de844cf6eee077d1f5b14d0247f14 (diff) | |
| download | open-keychain-c5ce794ef782b6809c3f0b3cacfa3bcd6a5a85b7.tar.gz open-keychain-c5ce794ef782b6809c3f0b3cacfa3bcd6a5a85b7.tar.bz2 open-keychain-c5ce794ef782b6809c3f0b3cacfa3bcd6a5a85b7.zip | |
more fixes on canonicalization and progress
| -rw-r--r-- | OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpKeyOperation.java | 8 | ||||
| -rw-r--r-- | OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/UncachedKeyRing.java | 35 | 
2 files changed, 22 insertions, 21 deletions
| diff --git a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpKeyOperation.java b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpKeyOperation.java index b1bd6a77a..861f93446 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpKeyOperation.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpKeyOperation.java @@ -354,7 +354,7 @@ public class PgpKeyOperation {              subProgressPush(15, 25);              for (int i = 0; i < saveParcel.mAddUserIds.size(); i++) { -                progress(R.string.progress_modify_adduid, (i-1) * (100 / saveParcel.mAddSubKeys.size())); +                progress(R.string.progress_modify_adduid, (i-1) * (100 / saveParcel.mAddUserIds.size()));                  String userId = saveParcel.mAddUserIds.get(i);                  log.add(LogLevel.INFO, LogType.MSG_MF_UID_ADD, indent); @@ -399,7 +399,7 @@ public class PgpKeyOperation {              subProgressPush(25, 40);              for (int i = 0; i < saveParcel.mRevokeUserIds.size(); i++) { -                progress(R.string.progress_modify_revokeuid, (i-1) * (100 / saveParcel.mAddSubKeys.size())); +                progress(R.string.progress_modify_revokeuid, (i-1) * (100 / saveParcel.mRevokeUserIds.size()));                  String userId = saveParcel.mRevokeUserIds.get(i);                  log.add(LogLevel.INFO, LogType.MSG_MF_UID_REVOKE, indent, userId); @@ -522,7 +522,7 @@ public class PgpKeyOperation {              subProgressPush(50, 60);              for (int i = 0; i < saveParcel.mChangeSubKeys.size(); i++) { -                progress(R.string.progress_modify_subkeychange, (i-1) * (100 / saveParcel.mAddSubKeys.size())); +                progress(R.string.progress_modify_subkeychange, (i-1) * (100 / saveParcel.mChangeSubKeys.size()));                  SaveKeyringParcel.SubkeyChange change = saveParcel.mChangeSubKeys.get(i);                  log.add(LogLevel.INFO, LogType.MSG_MF_SUBKEY_CHANGE,                          indent, PgpKeyHelper.convertKeyIdToHex(change.mKeyId)); @@ -583,7 +583,7 @@ public class PgpKeyOperation {              subProgressPush(60, 70);              for (int i = 0; i < saveParcel.mRevokeSubKeys.size(); i++) { -                progress(R.string.progress_modify_subkeyrevoke, (i-1) * (100 / saveParcel.mAddSubKeys.size())); +                progress(R.string.progress_modify_subkeyrevoke, (i-1) * (100 / saveParcel.mRevokeSubKeys.size()));                  long revocation = saveParcel.mRevokeSubKeys.get(i);                  log.add(LogLevel.INFO, LogType.MSG_MF_SUBKEY_REVOKE,                          indent, PgpKeyHelper.convertKeyIdToHex(revocation)); 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 502e3a70c..690317170 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/UncachedKeyRing.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/UncachedKeyRing.java @@ -300,14 +300,14 @@ public class UncachedKeyRing {                      revocation = zert;                      // more revocations? at least one is superfluous, then.                  } else if (revocation.getCreationTime().before(zert.getCreationTime())) { +                    log.add(LogLevel.INFO, LogType.MSG_KC_REVOKE_DUP, indent);                      modified = PGPPublicKey.removeCertification(modified, revocation);                      redundantCerts += 1; -                    log.add(LogLevel.INFO, LogType.MSG_KC_REVOKE_DUP, indent);                      revocation = zert;                  } else { +                    log.add(LogLevel.INFO, LogType.MSG_KC_REVOKE_DUP, indent);                      modified = PGPPublicKey.removeCertification(modified, zert);                      redundantCerts += 1; -                    log.add(LogLevel.INFO, LogType.MSG_KC_REVOKE_DUP, indent);                  }              } @@ -331,12 +331,13 @@ public class UncachedKeyRing {                                  indent, "0x" + Integer.toString(zert.getSignatureType(), 16));                          modified = PGPPublicKey.removeCertification(modified, userId, zert);                          badCerts += 1; +                        continue;                      }                      if (cert.getCreationTime().after(now)) {                          // Creation date in the future? No way!                          log.add(LogLevel.WARN, LogType.MSG_KC_UID_BAD_TIME, indent); -                        modified = PGPPublicKey.removeCertification(modified, zert); +                        modified = PGPPublicKey.removeCertification(modified, userId, zert);                          badCerts += 1;                          continue;                      } @@ -344,7 +345,7 @@ public class UncachedKeyRing {                      if (cert.isLocal()) {                          // Creation date in the future? No way!                          log.add(LogLevel.WARN, LogType.MSG_KC_UID_BAD_LOCAL, indent); -                        modified = PGPPublicKey.removeCertification(modified, zert); +                        modified = PGPPublicKey.removeCertification(modified, userId, zert);                          badCerts += 1;                          continue;                      } @@ -387,35 +388,35 @@ public class UncachedKeyRing {                              if (selfCert == null) {                                  selfCert = zert;                              } else if (selfCert.getCreationTime().before(cert.getCreationTime())) { -                                modified = PGPPublicKey.removeCertification(modified, userId, selfCert); -                                redundantCerts += 1;                                  log.add(LogLevel.DEBUG, LogType.MSG_KC_UID_DUP,                                          indent, userId); +                                modified = PGPPublicKey.removeCertification(modified, userId, selfCert); +                                redundantCerts += 1;                                  selfCert = zert;                              } else { -                                modified = PGPPublicKey.removeCertification(modified, userId, zert); -                                redundantCerts += 1;                                  log.add(LogLevel.DEBUG, LogType.MSG_KC_UID_DUP,                                          indent, userId); +                                modified = PGPPublicKey.removeCertification(modified, userId, zert); +                                redundantCerts += 1;                              }                              // If there is a revocation certificate, and it's older than this, drop it                              if (revocation != null                                      && revocation.getCreationTime().before(selfCert.getCreationTime())) { +                                log.add(LogLevel.DEBUG, LogType.MSG_KC_UID_REVOKE_OLD, +                                        indent, userId);                                  modified = PGPPublicKey.removeCertification(modified, userId, revocation);                                  revocation = null;                                  redundantCerts += 1; -                                log.add(LogLevel.DEBUG, LogType.MSG_KC_UID_REVOKE_OLD, -                                        indent, userId);                              }                              break;                          case PGPSignature.CERTIFICATION_REVOCATION:                              // If this is older than the (latest) self cert, drop it                              if (selfCert != null && selfCert.getCreationTime().after(zert.getCreationTime())) { -                                modified = PGPPublicKey.removeCertification(modified, userId, zert); -                                redundantCerts += 1;                                  log.add(LogLevel.DEBUG, LogType.MSG_KC_UID_REVOKE_OLD,                                          indent, userId); +                                modified = PGPPublicKey.removeCertification(modified, userId, zert); +                                redundantCerts += 1;                                  continue;                              }                              // first revocation? remember it. @@ -423,16 +424,16 @@ public class UncachedKeyRing {                                  revocation = zert;                                  // more revocations? at least one is superfluous, then.                              } else if (revocation.getCreationTime().before(cert.getCreationTime())) { -                                modified = PGPPublicKey.removeCertification(modified, userId, revocation); -                                redundantCerts += 1;                                  log.add(LogLevel.DEBUG, LogType.MSG_KC_UID_REVOKE_DUP,                                          indent, userId); +                                modified = PGPPublicKey.removeCertification(modified, userId, revocation); +                                redundantCerts += 1;                                  revocation = zert;                              } else { -                                modified = PGPPublicKey.removeCertification(modified, userId, zert); -                                redundantCerts += 1;                                  log.add(LogLevel.DEBUG, LogType.MSG_KC_UID_REVOKE_DUP,                                          indent, userId); +                                modified = PGPPublicKey.removeCertification(modified, userId, zert); +                                redundantCerts += 1;                              }                              break; @@ -442,9 +443,9 @@ public class UncachedKeyRing {                  // If no valid certificate (if only a revocation) remains, drop it                  if (selfCert == null && revocation == null) { -                    modified = PGPPublicKey.removeCertification(modified, userId);                      log.add(LogLevel.ERROR, LogType.MSG_KC_UID_REMOVE,                              indent, userId); +                    modified = PGPPublicKey.removeCertification(modified, userId);                  }              } | 
