| /* |
| * Copyright (C) 2015 The Android Open Source Project |
| * |
| * Licensed under the Apache License, Version 2.0 (the "License"); |
| * you may not use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. |
| */ |
| |
| package android.security.keystore; |
| |
| import java.math.BigInteger; |
| import java.security.InvalidKeyException; |
| import java.security.NoSuchAlgorithmException; |
| import java.security.NoSuchProviderException; |
| import java.security.Principal; |
| import java.security.PublicKey; |
| import java.security.SignatureException; |
| import java.security.cert.CertificateEncodingException; |
| import java.security.cert.CertificateException; |
| import java.security.cert.CertificateExpiredException; |
| import java.security.cert.CertificateNotYetValidException; |
| import java.security.cert.CertificateParsingException; |
| import java.security.cert.X509Certificate; |
| import java.util.Collection; |
| import java.util.Date; |
| import java.util.List; |
| import java.util.Set; |
| |
| import javax.security.auth.x500.X500Principal; |
| |
| class DelegatingX509Certificate extends X509Certificate { |
| private final X509Certificate mDelegate; |
| |
| DelegatingX509Certificate(X509Certificate delegate) { |
| mDelegate = delegate; |
| } |
| |
| @Override |
| public Set<String> getCriticalExtensionOIDs() { |
| return mDelegate.getCriticalExtensionOIDs(); |
| } |
| |
| @Override |
| public byte[] getExtensionValue(String oid) { |
| return mDelegate.getExtensionValue(oid); |
| } |
| |
| @Override |
| public Set<String> getNonCriticalExtensionOIDs() { |
| return mDelegate.getNonCriticalExtensionOIDs(); |
| } |
| |
| @Override |
| public boolean hasUnsupportedCriticalExtension() { |
| return mDelegate.hasUnsupportedCriticalExtension(); |
| } |
| |
| @Override |
| public void checkValidity() throws CertificateExpiredException, |
| CertificateNotYetValidException { |
| mDelegate.checkValidity(); |
| } |
| |
| @Override |
| public void checkValidity(Date date) throws CertificateExpiredException, |
| CertificateNotYetValidException { |
| mDelegate.checkValidity(date); |
| } |
| |
| @Override |
| public int getBasicConstraints() { |
| return mDelegate.getBasicConstraints(); |
| } |
| |
| @Override |
| public Principal getIssuerDN() { |
| return mDelegate.getIssuerDN(); |
| } |
| |
| @Override |
| public boolean[] getIssuerUniqueID() { |
| return mDelegate.getIssuerUniqueID(); |
| } |
| |
| @Override |
| public boolean[] getKeyUsage() { |
| return mDelegate.getKeyUsage(); |
| } |
| |
| @Override |
| public Date getNotAfter() { |
| return mDelegate.getNotAfter(); |
| } |
| |
| @Override |
| public Date getNotBefore() { |
| return mDelegate.getNotBefore(); |
| } |
| |
| @Override |
| public BigInteger getSerialNumber() { |
| return mDelegate.getSerialNumber(); |
| } |
| |
| @Override |
| public String getSigAlgName() { |
| return mDelegate.getSigAlgName(); |
| } |
| |
| @Override |
| public String getSigAlgOID() { |
| return mDelegate.getSigAlgOID(); |
| } |
| |
| @Override |
| public byte[] getSigAlgParams() { |
| return mDelegate.getSigAlgParams(); |
| } |
| |
| @Override |
| public byte[] getSignature() { |
| return mDelegate.getSignature(); |
| } |
| |
| @Override |
| public Principal getSubjectDN() { |
| return mDelegate.getSubjectDN(); |
| } |
| |
| @Override |
| public boolean[] getSubjectUniqueID() { |
| return mDelegate.getSubjectUniqueID(); |
| } |
| |
| @Override |
| public byte[] getTBSCertificate() throws CertificateEncodingException { |
| return mDelegate.getTBSCertificate(); |
| } |
| |
| @Override |
| public int getVersion() { |
| return mDelegate.getVersion(); |
| } |
| |
| @Override |
| public byte[] getEncoded() throws CertificateEncodingException { |
| return mDelegate.getEncoded(); |
| } |
| |
| @Override |
| public PublicKey getPublicKey() { |
| return mDelegate.getPublicKey(); |
| } |
| |
| @Override |
| public String toString() { |
| return mDelegate.toString(); |
| } |
| |
| @Override |
| public void verify(PublicKey key) |
| throws CertificateException, |
| NoSuchAlgorithmException, |
| InvalidKeyException, |
| NoSuchProviderException, |
| SignatureException { |
| mDelegate.verify(key); |
| } |
| |
| @Override |
| public void verify(PublicKey key, String sigProvider) |
| throws CertificateException, |
| NoSuchAlgorithmException, |
| InvalidKeyException, |
| NoSuchProviderException, |
| SignatureException { |
| mDelegate.verify(key, sigProvider); |
| } |
| |
| @Override |
| public List<String> getExtendedKeyUsage() throws CertificateParsingException { |
| return mDelegate.getExtendedKeyUsage(); |
| } |
| |
| @Override |
| public Collection<List<?>> getIssuerAlternativeNames() throws CertificateParsingException { |
| return mDelegate.getIssuerAlternativeNames(); |
| } |
| |
| @Override |
| public X500Principal getIssuerX500Principal() { |
| return mDelegate.getIssuerX500Principal(); |
| } |
| |
| @Override |
| public Collection<List<?>> getSubjectAlternativeNames() throws CertificateParsingException { |
| return mDelegate.getSubjectAlternativeNames(); |
| } |
| |
| @Override |
| public X500Principal getSubjectX500Principal() { |
| return mDelegate.getSubjectX500Principal(); |
| } |
| } |