Merge "Limit the number of supported v1 and v2 signers" into rvc-dev

This commit is contained in:
Michael Groover
2023-04-05 00:38:04 +00:00
committed by Android (Google) Code Review
2 changed files with 21 additions and 0 deletions

View File

@@ -75,6 +75,11 @@ public class ApkSignatureSchemeV2Verifier {
private static final int APK_SIGNATURE_SCHEME_V2_BLOCK_ID = 0x7109871a;
/**
* The maximum number of signers supported by the v2 APK signature scheme.
*/
private static final int MAX_V2_SIGNERS = 10;
/**
* Returns {@code true} if the provided APK contains an APK Signature Scheme V2 signature.
*
@@ -183,6 +188,11 @@ public class ApkSignatureSchemeV2Verifier {
}
while (signers.hasRemaining()) {
signerCount++;
if (signerCount > MAX_V2_SIGNERS) {
throw new SecurityException(
"APK Signature Scheme v2 only supports a maximum of " + MAX_V2_SIGNERS
+ " signers");
}
try {
ByteBuffer signer = getLengthPrefixedSlice(signers);
X509Certificate[] certs = verifySigner(signer, contentDigests, certFactory);

View File

@@ -78,6 +78,11 @@ class StrictJarVerifier {
"SHA1",
};
/**
* The maximum number of signers supported by the JAR signature scheme.
*/
private static final int MAX_JAR_SIGNERS = 10;
private final String jarName;
private final StrictJarManifest manifest;
private final HashMap<String, byte[]> metaEntries;
@@ -293,10 +298,16 @@ class StrictJarVerifier {
return false;
}
int signerCount = 0;
Iterator<String> it = metaEntries.keySet().iterator();
while (it.hasNext()) {
String key = it.next();
if (key.endsWith(".DSA") || key.endsWith(".RSA") || key.endsWith(".EC")) {
if (++signerCount > MAX_JAR_SIGNERS) {
throw new SecurityException(
"APK Signature Scheme v1 only supports a maximum of " + MAX_JAR_SIGNERS
+ " signers");
}
verifyCertificate(key);
it.remove();
}