org.bouncycastle.tls.crypto.TlsCertificate Maven / Gradle / Ivy
package org.bouncycastle.tls.crypto;
import java.io.IOException;
import java.math.BigInteger;
import org.bouncycastle.asn1.ASN1Encodable;
import org.bouncycastle.asn1.ASN1ObjectIdentifier;
import org.bouncycastle.tls.ConnectionEnd;
import org.bouncycastle.tls.SignatureAlgorithm;
/**
* Interface providing the functional representation of a single X.509 certificate.
*/
public interface TlsCertificate
{
/**
* @param signatureAlgorithm
* {@link SignatureAlgorithm}
*/
TlsVerifier createVerifier(short signatureAlgorithm) throws IOException;
/**
* @param signatureScheme
* {@link SignatureScheme}
*/
TlsVerifier createVerifier(int signatureScheme) throws IOException;
byte[] getEncoded() throws IOException;
byte[] getExtension(ASN1ObjectIdentifier extensionOID) throws IOException;
BigInteger getSerialNumber();
/**
* @return the OID of this certificate's 'signatureAlgorithm', as a String.
*/
String getSigAlgOID();
ASN1Encodable getSigAlgParams() throws IOException;
/**
* @return {@link SignatureAlgorithm}
*/
short getLegacySignatureAlgorithm() throws IOException;
/**
* @param signatureAlgorithm {@link SignatureAlgorithm}
* @return true if (and only if) this certificate can be used to verify the given signature algorithm.
*/
boolean supportsSignatureAlgorithm(short signatureAlgorithm) throws IOException;
boolean supportsSignatureAlgorithmCA(short signatureAlgorithm) throws IOException;
/**
* @param connectionEnd
* {@link ConnectionEnd}
* @param tlsCertificateRole
* {@link TlsCertificateRole}
*/
TlsCertificate checkUsageInRole(int connectionEnd, int tlsCertificateRole) throws IOException;
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy