diff --git a/src/main/java/org/apache/maven/plugins/gpg/BcSigner.java b/src/main/java/org/apache/maven/plugins/gpg/BcSigner.java index b31623c..83e8229 100644 --- a/src/main/java/org/apache/maven/plugins/gpg/BcSigner.java +++ b/src/main/java/org/apache/maven/plugins/gpg/BcSigner.java @@ -122,9 +122,14 @@ public byte[] loadKeyFingerprint(RepositorySystemSession session) { public final class GpgConfLoader implements Loader { /** - * Maximum key size, see Large Keys. + * Maximum file size allowed to load (as we load it into heap). + *
+ * This barrier exists to prevent us to load big/huge files, if this code is pointed at one + * (by mistake or by malicious intent). + * + * @see Large Keys */ - private static final long MAX_SIZE = 16 * 1024 + 1L; + private static final long MAX_SIZE = 64 * 1024 + 1L; @Override public byte[] loadKeyRingMaterial(RepositorySystemSession session) throws IOException { @@ -138,7 +143,7 @@ public byte[] loadKeyRingMaterial(RepositorySystemSession session) throws IOExce if (Files.size(keyPath) < MAX_SIZE) { return Files.readAllBytes(keyPath); } else { - throw new IOException("Refusing to load key " + keyPath + "; is larger than 16KB"); + throw new IOException("Refusing to load file " + keyPath + "; is larger than 64KB"); } } return null;