blob: fdaa42028e8da8052f5a137d752c25d6e06c4501 [file] [log] [blame]
/*
* Copyright (C) 2018 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.util.apk;
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.X509Certificate;
import java.util.Date;
import java.util.Set;
class WrappedX509Certificate extends X509Certificate {
private final X509Certificate mWrapped;
WrappedX509Certificate(X509Certificate wrapped) {
this.mWrapped = wrapped;
}
@Override
public Set<String> getCriticalExtensionOIDs() {
return mWrapped.getCriticalExtensionOIDs();
}
@Override
public byte[] getExtensionValue(String oid) {
return mWrapped.getExtensionValue(oid);
}
@Override
public Set<String> getNonCriticalExtensionOIDs() {
return mWrapped.getNonCriticalExtensionOIDs();
}
@Override
public boolean hasUnsupportedCriticalExtension() {
return mWrapped.hasUnsupportedCriticalExtension();
}
@Override
public void checkValidity()
throws CertificateExpiredException, CertificateNotYetValidException {
mWrapped.checkValidity();
}
@Override
public void checkValidity(Date date)
throws CertificateExpiredException, CertificateNotYetValidException {
mWrapped.checkValidity(date);
}
@Override
public int getVersion() {
return mWrapped.getVersion();
}
@Override
public BigInteger getSerialNumber() {
return mWrapped.getSerialNumber();
}
@Override
public Principal getIssuerDN() {
return mWrapped.getIssuerDN();
}
@Override
public Principal getSubjectDN() {
return mWrapped.getSubjectDN();
}
@Override
public Date getNotBefore() {
return mWrapped.getNotBefore();
}
@Override
public Date getNotAfter() {
return mWrapped.getNotAfter();
}
@Override
public byte[] getTBSCertificate() throws CertificateEncodingException {
return mWrapped.getTBSCertificate();
}
@Override
public byte[] getSignature() {
return mWrapped.getSignature();
}
@Override
public String getSigAlgName() {
return mWrapped.getSigAlgName();
}
@Override
public String getSigAlgOID() {
return mWrapped.getSigAlgOID();
}
@Override
public byte[] getSigAlgParams() {
return mWrapped.getSigAlgParams();
}
@Override
public boolean[] getIssuerUniqueID() {
return mWrapped.getIssuerUniqueID();
}
@Override
public boolean[] getSubjectUniqueID() {
return mWrapped.getSubjectUniqueID();
}
@Override
public boolean[] getKeyUsage() {
return mWrapped.getKeyUsage();
}
@Override
public int getBasicConstraints() {
return mWrapped.getBasicConstraints();
}
@Override
public byte[] getEncoded() throws CertificateEncodingException {
return mWrapped.getEncoded();
}
@Override
public void verify(PublicKey key) throws CertificateException, NoSuchAlgorithmException,
InvalidKeyException, NoSuchProviderException, SignatureException {
mWrapped.verify(key);
}
@Override
public void verify(PublicKey key, String sigProvider)
throws CertificateException, NoSuchAlgorithmException, InvalidKeyException,
NoSuchProviderException, SignatureException {
mWrapped.verify(key, sigProvider);
}
@Override
public String toString() {
return mWrapped.toString();
}
@Override
public PublicKey getPublicKey() {
return mWrapped.getPublicKey();
}
}