Library
Module
Module type
Parameter
Class
Class type
X509v3 certificate
val decode_pkcs1_digest_info :
Cstruct.t ->
(Mirage_crypto.Hash.hash * Cstruct.t, [> Rresult.R.msg ]) Rresult.result
decode_pkcs1_digest_info buffer
is hash, signature
, the hash and raw signature of the given buffer
in ASN.1 DER encoding, or an error.
encode_pkcs1_digest_info (hash, signature)
is data
, the ASN.1 DER encoded hash and signature.
type t = X509.Certificate.t
The abstract type of a certificate.
val pp : t Fmt.t
pp ppf cert
pretty-prints the certificate.
val encode_der : t -> Cstruct.t
encode_der certificate
is cstruct
, the ASN.1 encoded representation of the certificate
.
val encode_pem_multiple : t list -> Cstruct.t
encode_pem_multiple certificates
is pem
, the pem encoded certificates.
val encode_pem : t -> Cstruct.t
encode_pem certificate
is pem
, the pem encoded certificate.
val supports_keytype : t -> X509.Key_type.t -> bool
supports_keytype certificate key_type
is result
, whether public key of the certificate
matches the given key_type
.
val public_key : t -> X509.Public_key.t
public_key certificate
is pk
, the public key of the certificate
.
val signature_algorithm :
t ->
(X509.Key_type.signature_scheme * Mirage_crypto.Hash.hash) option
signature_algorithm certificate
is the algorithm used for the signature.
val hostnames : t -> X509.Host.Set.t
hostnames certficate
is the set of domain names this certificate
is valid for. Currently, these are the DNS names of the Subject Alternative Name extension, if present, or otherwise the singleton set containing the common name of the certificate subject.
val supports_hostname : t -> [ `host ] Domain_name.t -> bool
supports_hostname certificate hostname
is result
, whether the certificate
contains the given hostname
, using hostnames
.
val fingerprint : Mirage_crypto.Hash.hash -> t -> Cstruct.t
fingerprint hash cert
is digest
, the digest of cert
using the specified hash
algorithm
val subject : t -> X509.Distinguished_name.t
subject certificate
is dn
, the subject as dn of the certificate
.
val issuer : t -> X509.Distinguished_name.t
issuer certificate
is dn
, the issuer as dn of the certificate
.
val serial : t -> Z.t
serial certificate
is sn
, the serial number of the certificate
.
val validity : t -> Ptime.t * Ptime.t
validity certificate
is from, until
, the validity of the certificate.
val extensions : t -> X509.Extension.t
extensions certificate
is the extension map of certificate
.
val decode_pem_multiple : contents:string -> t list Core.Or_error.t
val decode_pem : contents:string -> t Core.Or_error.t
val decode_der : contents:string -> t Core.Or_error.t
val of_pem_file : Core.Filename.t -> t list Async.Deferred.Or_error.t
val of_pem_directory :
directory:Core.Filename.t ->
t list Async.Deferred.Or_error.t