mirror of
https://github.com/pgpainless/pgpainless.git
synced 2025-01-11 04:36:24 +01:00
Improve SignatureUtils.wasIssuedBy() by adding support for v5 fingerprints
This commit is contained in:
parent
9921fc6ff6
commit
70a861611c
1 changed files with 10 additions and 12 deletions
|
@ -14,6 +14,7 @@ import java.util.Date;
|
||||||
import java.util.Iterator;
|
import java.util.Iterator;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
import java.util.Set;
|
import java.util.Set;
|
||||||
|
import javax.annotation.Nonnull;
|
||||||
|
|
||||||
import org.bouncycastle.bcpg.sig.IssuerKeyID;
|
import org.bouncycastle.bcpg.sig.IssuerKeyID;
|
||||||
import org.bouncycastle.bcpg.sig.KeyExpirationTime;
|
import org.bouncycastle.bcpg.sig.KeyExpirationTime;
|
||||||
|
@ -36,14 +37,11 @@ import org.pgpainless.algorithm.SignatureType;
|
||||||
import org.pgpainless.algorithm.negotiation.HashAlgorithmNegotiator;
|
import org.pgpainless.algorithm.negotiation.HashAlgorithmNegotiator;
|
||||||
import org.pgpainless.implementation.ImplementationFactory;
|
import org.pgpainless.implementation.ImplementationFactory;
|
||||||
import org.pgpainless.key.OpenPgpFingerprint;
|
import org.pgpainless.key.OpenPgpFingerprint;
|
||||||
import org.pgpainless.key.OpenPgpV4Fingerprint;
|
|
||||||
import org.pgpainless.key.util.OpenPgpKeyAttributeUtil;
|
import org.pgpainless.key.util.OpenPgpKeyAttributeUtil;
|
||||||
import org.pgpainless.key.util.RevocationAttributes;
|
import org.pgpainless.key.util.RevocationAttributes;
|
||||||
import org.pgpainless.signature.subpackets.SignatureSubpacketsUtil;
|
import org.pgpainless.signature.subpackets.SignatureSubpacketsUtil;
|
||||||
import org.pgpainless.util.ArmorUtils;
|
import org.pgpainless.util.ArmorUtils;
|
||||||
|
|
||||||
import javax.annotation.Nonnull;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Utility methods related to signatures.
|
* Utility methods related to signatures.
|
||||||
*/
|
*/
|
||||||
|
@ -325,17 +323,17 @@ public final class SignatureUtils {
|
||||||
}
|
}
|
||||||
|
|
||||||
public static boolean wasIssuedBy(byte[] fingerprint, PGPSignature signature) {
|
public static boolean wasIssuedBy(byte[] fingerprint, PGPSignature signature) {
|
||||||
if (fingerprint.length != 20) {
|
try {
|
||||||
// Unknown fingerprint length
|
OpenPgpFingerprint fp = OpenPgpFingerprint.parseFromBinary(fingerprint);
|
||||||
return false;
|
|
||||||
}
|
|
||||||
OpenPgpV4Fingerprint fp = new OpenPgpV4Fingerprint(fingerprint);
|
|
||||||
OpenPgpFingerprint issuerFp = SignatureSubpacketsUtil.getIssuerFingerprintAsOpenPgpFingerprint(signature);
|
OpenPgpFingerprint issuerFp = SignatureSubpacketsUtil.getIssuerFingerprintAsOpenPgpFingerprint(signature);
|
||||||
if (issuerFp == null) {
|
if (issuerFp == null) {
|
||||||
return fp.getKeyId() == signature.getKeyID();
|
return fp.getKeyId() == signature.getKeyID();
|
||||||
}
|
}
|
||||||
|
|
||||||
return fp.equals(issuerFp);
|
return fp.equals(issuerFp);
|
||||||
|
} catch (IllegalArgumentException e) {
|
||||||
|
// Unknown fingerprint length
|
||||||
|
return false;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -354,7 +352,7 @@ public final class SignatureUtils {
|
||||||
List<PGPSignature> signaturesByKeyId = new ArrayList<>();
|
List<PGPSignature> signaturesByKeyId = new ArrayList<>();
|
||||||
Iterator<PGPSignature> userIdSignatures = key.getSignaturesForID(userId);
|
Iterator<PGPSignature> userIdSignatures = key.getSignaturesForID(userId);
|
||||||
|
|
||||||
// getSignaturesForID() is nullable -.-
|
// getSignaturesForID() is nullable for some reason -.-
|
||||||
if (userIdSignatures == null) {
|
if (userIdSignatures == null) {
|
||||||
return signaturesByKeyId;
|
return signaturesByKeyId;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue