diff options
Diffstat (limited to 'OpenKeychain/src/main/java/org')
2 files changed, 7 insertions, 2 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 a54ddff68..9da3b94af 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 @@ -482,6 +482,7 @@ public abstract class OperationResult implements Parcelable {          // secret key modify          MSG_MF (LogLevel.START, R.string.msg_mr),          MSG_MF_DIVERT (LogLevel.DEBUG, R.string.msg_mf_divert), +        MSG_MF_ERROR_DIVERT_NEWSUB (LogLevel.ERROR, R.string.msg_mf_error_divert_newsub),          MSG_MF_ERROR_DIVERT_SERIAL (LogLevel.ERROR, R.string.msg_mf_error_divert_serial),          MSG_MF_ERROR_ENCODE (LogLevel.ERROR, R.string.msg_mf_error_encode),          MSG_MF_ERROR_FINGERPRINT (LogLevel.ERROR, R.string.msg_mf_error_fingerprint), 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 414ed1f62..440d57d36 100644 --- a/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpKeyOperation.java +++ b/OpenKeychain/src/main/java/org/sufficientlysecure/keychain/pgp/PgpKeyOperation.java @@ -976,6 +976,11 @@ public class PgpKeyOperation {                  log.add(LogType.MSG_MF_SUBKEY_NEW, indent,                          KeyFormattingUtils.getAlgorithmInfo(add.mAlgorithm, add.mKeySize, add.mCurve) ); +                if (isDivertToCard(masterSecretKey)) { +                    log.add(LogType.MSG_MF_ERROR_DIVERT_NEWSUB, indent +1); +                    return new PgpEditKeyResult(PgpEditKeyResult.RESULT_CANCELLED, log, null); +                } +                  if (add.mExpiry == null) {                      log.add(LogType.MSG_MF_ERROR_NULL_EXPIRY, indent +1);                      return new PgpEditKeyResult(PgpEditKeyResult.RESULT_ERROR, log, null); @@ -1020,8 +1025,7 @@ public class PgpKeyOperation {                              PgpConstants.SECRET_KEY_ENCRYPTOR_SYMMETRIC_ALGO, encryptorHashCalc,                              PgpConstants.SECRET_KEY_ENCRYPTOR_S2K_COUNT)                              .setProvider(Constants.BOUNCY_CASTLE_PROVIDER_NAME).build( -                                    cryptoInput.hasPassphrase() -                                            ? cryptoInput.getPassphrase().getCharArray() : new char[]{} ); +                                    cryptoInput.getPassphrase().getCharArray());                      PGPDigestCalculator sha1Calc = new JcaPGPDigestCalculatorProviderBuilder()                              .build().get(PgpConstants.SECRET_KEY_SIGNATURE_CHECKSUM_HASH_ALGO); | 
