mirror of
https://github.com/pgpainless/pgpainless.git
synced 2025-01-09 19:57:57 +01:00
Properly close InputStream in SymmetricEncryptorDecryptor
Although it is possibly not strict required, it is always a good idea to close streams even if the conrete implementation does not cause resource leaks when not closed. After all, the implementation could change at some point in the future.
This commit is contained in:
parent
b6bb395e4f
commit
cfab8a744d
1 changed files with 37 additions and 28 deletions
|
@ -102,9 +102,12 @@ public class SymmetricEncryptorDecryptor {
|
||||||
*/
|
*/
|
||||||
public static byte[] symmetricallyDecrypt(@Nonnull byte[] data, @Nonnull Passphrase password)
|
public static byte[] symmetricallyDecrypt(@Nonnull byte[] data, @Nonnull Passphrase password)
|
||||||
throws IOException, PGPException {
|
throws IOException, PGPException {
|
||||||
InputStream in = new BufferedInputStream(new ByteArrayInputStream(data));
|
PGPPBEEncryptedData pbe;
|
||||||
in = PGPUtil.getDecoderStream(in);
|
ByteArrayOutputStream outputStream = null;
|
||||||
|
BufferedInputStream bis = new BufferedInputStream(new ByteArrayInputStream(data));
|
||||||
|
InputStream in = PGPUtil.getDecoderStream(bis);
|
||||||
|
|
||||||
|
try {
|
||||||
BcPGPObjectFactory pgpF = new BcPGPObjectFactory(in);
|
BcPGPObjectFactory pgpF = new BcPGPObjectFactory(in);
|
||||||
PGPEncryptedDataList enc;
|
PGPEncryptedDataList enc;
|
||||||
Object o = pgpF.nextObject();
|
Object o = pgpF.nextObject();
|
||||||
|
@ -115,11 +118,10 @@ public class SymmetricEncryptorDecryptor {
|
||||||
enc = (PGPEncryptedDataList) pgpF.nextObject();
|
enc = (PGPEncryptedDataList) pgpF.nextObject();
|
||||||
}
|
}
|
||||||
|
|
||||||
PGPPBEEncryptedData pbe = (PGPPBEEncryptedData) enc.get(0);
|
pbe = (PGPPBEEncryptedData) enc.get(0);
|
||||||
|
|
||||||
InputStream clear = pbe.getDataStream(new BcPBEDataDecryptorFactory(
|
|
||||||
password.getChars(), new BcPGPDigestCalculatorProvider()));
|
|
||||||
|
|
||||||
|
InputStream clear = pbe.getDataStream(
|
||||||
|
new BcPBEDataDecryptorFactory(password.getChars(), new BcPGPDigestCalculatorProvider()));
|
||||||
|
|
||||||
BcPGPObjectFactory pgpFact = new BcPGPObjectFactory(clear);
|
BcPGPObjectFactory pgpFact = new BcPGPObjectFactory(clear);
|
||||||
|
|
||||||
|
@ -133,11 +135,18 @@ public class SymmetricEncryptorDecryptor {
|
||||||
PGPLiteralData ld = (PGPLiteralData) o;
|
PGPLiteralData ld = (PGPLiteralData) o;
|
||||||
InputStream unc = ld.getInputStream();
|
InputStream unc = ld.getInputStream();
|
||||||
|
|
||||||
ByteArrayOutputStream outputStream = new ByteArrayOutputStream();
|
try {
|
||||||
|
outputStream = new ByteArrayOutputStream();
|
||||||
|
|
||||||
Streams.pipeAll(unc, outputStream);
|
Streams.pipeAll(unc, outputStream);
|
||||||
|
} finally {
|
||||||
|
if (outputStream != null) {
|
||||||
outputStream.close();
|
outputStream.close();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} finally {
|
||||||
|
in.close();
|
||||||
|
}
|
||||||
|
|
||||||
if (pbe.isIntegrityProtected()) {
|
if (pbe.isIntegrityProtected()) {
|
||||||
if (!pbe.verify()) {
|
if (!pbe.verify()) {
|
||||||
|
|
Loading…
Reference in a new issue