diff options
Diffstat (limited to 'OpenKeychain/src/main/java')
2 files changed, 38 insertions, 0 deletions
| 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 f14589774..7f36aeb08 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 @@ -495,6 +495,8 @@ public abstract class OperationResult implements Parcelable {          MSG_MF_ERROR_SIG (LogLevel.ERROR, R.string.msg_mf_error_sig),          MSG_MF_ERROR_SUBKEY_MISSING(LogLevel.ERROR, R.string.msg_mf_error_subkey_missing),          MSG_MF_ERROR_CONFLICTING_NFC_COMMANDS(LogLevel.ERROR, R.string.msg_mf_error_conflicting_nfc_commands), +        MSG_MF_ERROR_DUPLICATE_KEYTOCARD_FOR_SLOT(LogLevel.ERROR, R.string.msg_mf_error_duplicate_keytocard_for_slot), +        MSG_MF_ERROR_INVALID_FLAGS_FOR_KEYTOCARD(LogLevel.ERROR, R.string.msg_mf_error_invalid_flags_for_keytocard),          MSG_MF_ERROR_BAD_NFC_ALGO(LogLevel.ERROR, R.string.edit_key_error_bad_nfc_algo),          MSG_MF_ERROR_BAD_NFC_SIZE(LogLevel.ERROR, R.string.edit_key_error_bad_nfc_size),          MSG_MF_ERROR_BAD_NFC_STRIPPED(LogLevel.ERROR, R.string.edit_key_error_bad_nfc_stripped), 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 566ffd44b..62809ca6b 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpKeyOperation.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpKeyOperation.java @@ -410,6 +410,10 @@ public class PgpKeyOperation {              return new PgpEditKeyResult(PgpEditKeyResult.RESULT_ERROR, log, null);          } +        // Ensure we don't have multiple keys for the same slot. +        boolean hasSign = false; +        boolean hasEncrypt = false; +        boolean hasAuth = false;          for(SaveKeyringParcel.SubkeyChange change : saveParcel.mChangeSubKeys) {              if (change.mMoveKeyToCard) {                  // If this is a keytocard operation, see if it was completed: look for a hash @@ -424,6 +428,38 @@ public class PgpKeyOperation {                      change.mDummyDivert = serialNumber;                  }              } + +            if (change.mMoveKeyToCard) { +                // Pending keytocard operation. Need to make sure that we don't have multiple +                // subkeys pending for the same slot. +                CanonicalizedSecretKey wsK = wsKR.getSecretKey(change.mKeyId); + +                if ((wsK.canSign() || wsK.canCertify())) { +                    if (hasSign) { +                        log.add(LogType.MSG_MF_ERROR_DUPLICATE_KEYTOCARD_FOR_SLOT, indent + 1); +                        return new PgpEditKeyResult(PgpEditKeyResult.RESULT_ERROR, log, null); +                    } else { +                        hasSign = true; +                    } +                } else if ((wsK.canEncrypt())) { +                    if (hasEncrypt) { +                        log.add(LogType.MSG_MF_ERROR_DUPLICATE_KEYTOCARD_FOR_SLOT, indent + 1); +                        return new PgpEditKeyResult(PgpEditKeyResult.RESULT_ERROR, log, null); +                    } else { +                        hasEncrypt = true; +                    } +                } else if ((wsK.canAuthenticate())) { +                    if (hasAuth) { +                        log.add(LogType.MSG_MF_ERROR_DUPLICATE_KEYTOCARD_FOR_SLOT, indent + 1); +                        return new PgpEditKeyResult(PgpEditKeyResult.RESULT_ERROR, log, null); +                    } else { +                        hasAuth = true; +                    } +                } else { +                    log.add(LogType.MSG_MF_ERROR_INVALID_FLAGS_FOR_KEYTOCARD, indent + 1); +                    return new PgpEditKeyResult(PgpEditKeyResult.RESULT_ERROR, log, null); +                } +            }          }          if (isDummy(masterSecretKey) || saveParcel.isRestrictedOnly()) { | 
