diff options
| -rw-r--r-- | docs/hazmat/primitives/interfaces.rst | 44 | ||||
| -rw-r--r-- | src/cryptography/hazmat/primitives/interfaces.py | 33 | 
2 files changed, 77 insertions, 0 deletions
| diff --git a/docs/hazmat/primitives/interfaces.rst b/docs/hazmat/primitives/interfaces.rst index e9e4e77e..888a3403 100644 --- a/docs/hazmat/primitives/interfaces.rst +++ b/docs/hazmat/primitives/interfaces.rst @@ -695,6 +695,50 @@ Key derivation functions          :raises cryptography.exceptions.InvalidSignature: This is raised when              the provided signature does not match the expected signature. + +X509 +---- + +.. class:: X509Certificate + +    .. versionadded:: 0.7 + +    .. method:: fingerprint(algorithm) + +        :param algorithm: A +            :class:`~cryptography.hazmat.primitives.interfaces.HashAlgorithm` +            that will be used by this context. + +        :return: The fingerprint using the supplied hash algorithm as bytes. + +    .. attribute:: serial + +        :type: int + +        The serial as a Python integer. + +    .. method:: public_key() + +        :type: +            :class:`~cryptography.hazmat.primitives.interfaces.RSAPublicKey` or +            :class:`~cryptography.hazmat.primitives.interfaces.DSAPublicKey` or +            :class:`~cryptography.hazmat.primitives.interfaces.EllipticCurvePublicKey` + +        The public key associated with the certificate. + +    .. attribute:: not_before + +        :type: datetime + +    The beginning of the validity period for the certificate (UTC). + +    .. attribute:: not_after + +        :type: datetime + +    The end of the validity period for the certificate (UTC). + +  .. _`RSA`: https://en.wikipedia.org/wiki/RSA_(cryptosystem)  .. _`Chinese remainder theorem`: https://en.wikipedia.org/wiki/Chinese_remainder_theorem  .. _`DSA`: https://en.wikipedia.org/wiki/Digital_Signature_Algorithm diff --git a/src/cryptography/hazmat/primitives/interfaces.py b/src/cryptography/hazmat/primitives/interfaces.py index 7d9fc4fb..561be972 100644 --- a/src/cryptography/hazmat/primitives/interfaces.py +++ b/src/cryptography/hazmat/primitives/interfaces.py @@ -488,3 +488,36 @@ class MACContext(object):  # DeprecatedIn07  CMACContext = MACContext + + +@six.add_metaclass(abc.ABCMeta) +class X509Certificate(object): +    @abc.abstractmethod +    def fingerprint(self, algorithm): +        """ +        Returns bytes using digest passed. +        """ + +    @abc.abstractproperty +    def serial(self): +        """ +        Returns certificate serial number +        """ + +    @abc.abstractmethod +    def public_key(self): +        """ +        Returns the public key +        """ + +    @abc.abstractproperty +    def not_before(self): +        """ +        Not before time (represented as UTC datetime) +        """ + +    @abc.abstractproperty +    def not_after(self): +        """ +        Not after time (represented as UTC datetime) +        """ | 
