1
0
Fork 0
mirror of https://github.com/pgpainless/pgpainless.git synced 2025-01-24 19:06:24 +01:00

return null-cryptors for unprotected keys

This commit is contained in:
Paul Schaub 2020-01-14 22:10:07 +01:00
parent 4b61745c46
commit 9c1f6fc812
Signed by: vanitasvitae
GPG key ID: 62BEE9264BF17311

View file

@ -55,18 +55,20 @@ public class PasswordBasedSecretKeyRingProtector implements SecretKeyRingProtect
@Nullable @Nullable
public PBESecretKeyDecryptor getDecryptor(Long keyId) { public PBESecretKeyDecryptor getDecryptor(Long keyId) {
Passphrase passphrase = passphraseProvider.getPassphraseFor(keyId); Passphrase passphrase = passphraseProvider.getPassphraseFor(keyId);
return new BcPBESecretKeyDecryptorBuilder(calculatorProvider) return passphrase == null ? null :
.build(passphrase != null ? passphrase.getChars() : null); new BcPBESecretKeyDecryptorBuilder(calculatorProvider)
.build(passphrase.getChars());
} }
@Override @Override
@Nullable @Nullable
public PBESecretKeyEncryptor getEncryptor(Long keyId) throws PGPException { public PBESecretKeyEncryptor getEncryptor(Long keyId) throws PGPException {
Passphrase passphrase = passphraseProvider.getPassphraseFor(keyId); Passphrase passphrase = passphraseProvider.getPassphraseFor(keyId);
return new BcPBESecretKeyEncryptorBuilder( return passphrase == null ? null :
new BcPBESecretKeyEncryptorBuilder(
protectionSettings.getEncryptionAlgorithm().getAlgorithmId(), protectionSettings.getEncryptionAlgorithm().getAlgorithmId(),
calculatorProvider.get(protectionSettings.getHashAlgorithm().getAlgorithmId()), calculatorProvider.get(protectionSettings.getHashAlgorithm().getAlgorithmId()),
protectionSettings.getS2kCount()) protectionSettings.getS2kCount())
.build(passphrase != null ? passphrase.getChars() : null); .build(passphrase.getChars());
} }
} }