// 
// Decompiled by Procyon v0.6.0
// 

package io.netty.handler.ssl.util;

import java.io.InputStream;
import java.io.ByteArrayInputStream;
import java.util.Set;
import java.security.NoSuchProviderException;
import java.security.cert.CertificateEncodingException;
import java.security.Principal;
import java.math.BigInteger;
import java.security.SignatureException;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
import java.security.cert.CertificateException;
import java.security.Provider;
import java.security.PublicKey;
import java.util.Collection;
import java.security.cert.CertificateParsingException;
import java.util.List;
import javax.security.auth.x500.X500Principal;
import java.util.Date;
import java.security.cert.CertificateNotYetValidException;
import java.security.cert.CertificateExpiredException;
import io.netty.util.internal.ObjectUtil;
import java.security.cert.CertificateFactory;
import java.security.cert.X509Certificate;

public final class LazyX509Certificate extends X509Certificate
{
    static final CertificateFactory X509_CERT_FACTORY;
    private final byte[] bytes;
    private X509Certificate wrapped;
    
    public LazyX509Certificate(final byte[] bytes) {
        this.bytes = ObjectUtil.checkNotNull(bytes, "bytes");
    }
    
    @Override
    public void checkValidity() throws CertificateExpiredException, CertificateNotYetValidException {
        this.unwrap().checkValidity();
    }
    
    @Override
    public void checkValidity(final Date date) throws CertificateExpiredException, CertificateNotYetValidException {
        this.unwrap().checkValidity(date);
    }
    
    @Override
    public X500Principal getIssuerX500Principal() {
        return this.unwrap().getIssuerX500Principal();
    }
    
    @Override
    public X500Principal getSubjectX500Principal() {
        return this.unwrap().getSubjectX500Principal();
    }
    
    @Override
    public List<String> getExtendedKeyUsage() throws CertificateParsingException {
        return this.unwrap().getExtendedKeyUsage();
    }
    
    @Override
    public Collection<List<?>> getSubjectAlternativeNames() throws CertificateParsingException {
        return this.unwrap().getSubjectAlternativeNames();
    }
    
    @Override
    public Collection<List<?>> getIssuerAlternativeNames() throws CertificateParsingException {
        return this.unwrap().getIssuerAlternativeNames();
    }
    
    @Override
    public void verify(final PublicKey key, final Provider sigProvider) throws CertificateException, NoSuchAlgorithmException, InvalidKeyException, SignatureException {
        this.unwrap().verify(key, sigProvider);
    }
    
    @Override
    public int getVersion() {
        return this.unwrap().getVersion();
    }
    
    @Override
    public BigInteger getSerialNumber() {
        return this.unwrap().getSerialNumber();
    }
    
    @Override
    public Principal getIssuerDN() {
        return this.unwrap().getIssuerDN();
    }
    
    @Override
    public Principal getSubjectDN() {
        return this.unwrap().getSubjectDN();
    }
    
    @Override
    public Date getNotBefore() {
        return this.unwrap().getNotBefore();
    }
    
    @Override
    public Date getNotAfter() {
        return this.unwrap().getNotAfter();
    }
    
    @Override
    public byte[] getTBSCertificate() throws CertificateEncodingException {
        return this.unwrap().getTBSCertificate();
    }
    
    @Override
    public byte[] getSignature() {
        return this.unwrap().getSignature();
    }
    
    @Override
    public String getSigAlgName() {
        return this.unwrap().getSigAlgName();
    }
    
    @Override
    public String getSigAlgOID() {
        return this.unwrap().getSigAlgOID();
    }
    
    @Override
    public byte[] getSigAlgParams() {
        return this.unwrap().getSigAlgParams();
    }
    
    @Override
    public boolean[] getIssuerUniqueID() {
        return this.unwrap().getIssuerUniqueID();
    }
    
    @Override
    public boolean[] getSubjectUniqueID() {
        return this.unwrap().getSubjectUniqueID();
    }
    
    @Override
    public boolean[] getKeyUsage() {
        return this.unwrap().getKeyUsage();
    }
    
    @Override
    public int getBasicConstraints() {
        return this.unwrap().getBasicConstraints();
    }
    
    @Override
    public byte[] getEncoded() {
        return this.bytes.clone();
    }
    
    @Override
    public void verify(final PublicKey key) throws CertificateException, NoSuchAlgorithmException, InvalidKeyException, NoSuchProviderException, SignatureException {
        this.unwrap().verify(key);
    }
    
    @Override
    public void verify(final PublicKey key, final String sigProvider) throws CertificateException, NoSuchAlgorithmException, InvalidKeyException, NoSuchProviderException, SignatureException {
        this.unwrap().verify(key, sigProvider);
    }
    
    @Override
    public String toString() {
        return this.unwrap().toString();
    }
    
    @Override
    public PublicKey getPublicKey() {
        return this.unwrap().getPublicKey();
    }
    
    @Override
    public boolean hasUnsupportedCriticalExtension() {
        return this.unwrap().hasUnsupportedCriticalExtension();
    }
    
    @Override
    public Set<String> getCriticalExtensionOIDs() {
        return this.unwrap().getCriticalExtensionOIDs();
    }
    
    @Override
    public Set<String> getNonCriticalExtensionOIDs() {
        return this.unwrap().getNonCriticalExtensionOIDs();
    }
    
    @Override
    public byte[] getExtensionValue(final String oid) {
        return this.unwrap().getExtensionValue(oid);
    }
    
    private X509Certificate unwrap() {
        X509Certificate wrapped = this.wrapped;
        if (wrapped == null) {
            try {
                final X509Certificate wrapped2 = (X509Certificate)LazyX509Certificate.X509_CERT_FACTORY.generateCertificate(new ByteArrayInputStream(this.bytes));
                this.wrapped = wrapped2;
                wrapped = wrapped2;
            }
            catch (final CertificateException e) {
                throw new IllegalStateException(e);
            }
        }
        return wrapped;
    }
    
    static {
        try {
            X509_CERT_FACTORY = CertificateFactory.getInstance("X.509");
        }
        catch (final CertificateException e) {
            throw new ExceptionInInitializerError(e);
        }
    }
}
