summaryrefslogtreecommitdiffstats
path: root/luni
diff options
context:
space:
mode:
authorBrian Carlstrom <bdc@google.com>2011-05-21 20:42:22 -0700
committerBrian Carlstrom <bdc@google.com>2011-05-21 20:42:22 -0700
commit4280237a545e7482b6ea954fd862878867b8f896 (patch)
tree5183b26aee9c9e28f487d5c6eeaec76359b8e375 /luni
parent2cff86c0c10588a35036fe5bbca83b07f53e1b1d (diff)
downloadlibcore-4280237a545e7482b6ea954fd862878867b8f896.zip
libcore-4280237a545e7482b6ea954fd862878867b8f896.tar.gz
libcore-4280237a545e7482b6ea954fd862878867b8f896.tar.bz2
Ensure signature verification fast path is used with alternatively formatted signature algorithm names
Change-Id: Icebe7794babfc93592674cc14dd83c2556642fad
Diffstat (limited to 'luni')
-rw-r--r--luni/src/main/java/org/apache/harmony/security/provider/cert/X509CertImpl.java49
1 files changed, 16 insertions, 33 deletions
diff --git a/luni/src/main/java/org/apache/harmony/security/provider/cert/X509CertImpl.java b/luni/src/main/java/org/apache/harmony/security/provider/cert/X509CertImpl.java
index a144727..35bcb39 100644
--- a/luni/src/main/java/org/apache/harmony/security/provider/cert/X509CertImpl.java
+++ b/luni/src/main/java/org/apache/harmony/security/provider/cert/X509CertImpl.java
@@ -90,10 +90,6 @@ public final class X509CertImpl extends X509Certificate {
// encoding of the certificate
private volatile byte[] encoding;
- //
- // ---------------------- Constructors -------------------------------
- //
-
/**
* Constructs the instance on the base of ASN.1 encoded
* form of X.509 certificate provided via stream parameter.
@@ -133,10 +129,6 @@ public final class X509CertImpl extends X509Certificate {
this((Certificate) Certificate.ASN1.decode(encoding));
}
- //
- // ----------------- Public methods implementations ------------------
- //
-
public void checkValidity()
throws CertificateExpiredException, CertificateNotYetValidException {
checkValidity(System.currentTimeMillis());
@@ -351,11 +343,7 @@ public final class X509CertImpl extends X509Certificate {
}
}
- //
- // ----- java.security.cert.Certificate methods implementations ------
- //
-
- public byte[] getEncoded() throws CertificateEncodingException {
+ @Override public byte[] getEncoded() throws CertificateEncodingException {
return getEncodedInternal().clone();
}
private byte[] getEncodedInternal() throws CertificateEncodingException {
@@ -366,7 +354,7 @@ public final class X509CertImpl extends X509Certificate {
return result;
}
- public PublicKey getPublicKey() {
+ @Override public PublicKey getPublicKey() {
PublicKey result = publicKey;
if (result == null) {
publicKey = result = tbsCert.getSubjectPublicKeyInfo().getPublicKey();
@@ -374,15 +362,14 @@ public final class X509CertImpl extends X509Certificate {
return result;
}
- public String toString() {
+ @Override public String toString() {
return certificate.toString();
}
- public void verify(PublicKey key)
- throws CertificateException, NoSuchAlgorithmException,
- InvalidKeyException, NoSuchProviderException,
- SignatureException {
- if (getSigAlgName().endsWith("withRSA")) {
+ @Override public void verify(PublicKey key)
+ throws CertificateException, NoSuchAlgorithmException, InvalidKeyException,
+ NoSuchProviderException, SignatureException {
+ if (getSigAlgName().endsWith("withRSA") || getSigAlgName().endsWith("WithRSAEncryption")) {
fastVerify(key);
return;
}
@@ -398,11 +385,11 @@ public final class X509CertImpl extends X509Certificate {
}
}
- public void verify(PublicKey key, String sigProvider)
- throws CertificateException, NoSuchAlgorithmException,
- InvalidKeyException, NoSuchProviderException,
- SignatureException {
- if (getSigAlgName().endsWith("withRSA") && sigProvider == null) {
+ @Override public void verify(PublicKey key, String sigProvider)
+ throws CertificateException, NoSuchAlgorithmException, InvalidKeyException,
+ NoSuchProviderException, SignatureException {
+ if ((getSigAlgName().endsWith("withRSA") || getSigAlgName().endsWith("WithRSAEncryption"))
+ && sigProvider == null) {
fastVerify(key);
return;
}
@@ -457,11 +444,7 @@ public final class X509CertImpl extends X509Certificate {
}
}
- //
- // ----- java.security.cert.X509Extension methods implementations ----
- //
-
- public Set<String> getNonCriticalExtensionOIDs() {
+ @Override public Set<String> getNonCriticalExtensionOIDs() {
if (extensions == null) {
return null;
}
@@ -469,7 +452,7 @@ public final class X509CertImpl extends X509Certificate {
return extensions.getNonCriticalExtensions();
}
- public Set<String> getCriticalExtensionOIDs() {
+ @Override public Set<String> getCriticalExtensionOIDs() {
if (extensions == null) {
return null;
}
@@ -477,7 +460,7 @@ public final class X509CertImpl extends X509Certificate {
return extensions.getCriticalExtensions();
}
- public byte[] getExtensionValue(String oid) {
+ @Override public byte[] getExtensionValue(String oid) {
if (extensions == null) {
return null;
}
@@ -486,7 +469,7 @@ public final class X509CertImpl extends X509Certificate {
return (ext == null) ? null : ext.getRawExtnValue();
}
- public boolean hasUnsupportedCriticalExtension() {
+ @Override public boolean hasUnsupportedCriticalExtension() {
if (extensions == null) {
return false;
}