__init__.py 7.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267
  1. # This file is dual licensed under the terms of the Apache License, Version
  2. # 2.0, and the BSD License. See the LICENSE file in the root of this repository
  3. # for complete details.
  4. from __future__ import annotations
  5. from cryptography.x509 import certificate_transparency, verification
  6. from cryptography.x509.base import (
  7. Attribute,
  8. AttributeNotFound,
  9. Attributes,
  10. Certificate,
  11. CertificateBuilder,
  12. CertificateRevocationList,
  13. CertificateRevocationListBuilder,
  14. CertificateSigningRequest,
  15. CertificateSigningRequestBuilder,
  16. InvalidVersion,
  17. RevokedCertificate,
  18. RevokedCertificateBuilder,
  19. Version,
  20. load_der_x509_certificate,
  21. load_der_x509_crl,
  22. load_der_x509_csr,
  23. load_pem_x509_certificate,
  24. load_pem_x509_certificates,
  25. load_pem_x509_crl,
  26. load_pem_x509_csr,
  27. random_serial_number,
  28. )
  29. from cryptography.x509.extensions import (
  30. AccessDescription,
  31. Admission,
  32. Admissions,
  33. AuthorityInformationAccess,
  34. AuthorityKeyIdentifier,
  35. BasicConstraints,
  36. CertificateIssuer,
  37. CertificatePolicies,
  38. CRLDistributionPoints,
  39. CRLNumber,
  40. CRLReason,
  41. DeltaCRLIndicator,
  42. DistributionPoint,
  43. DuplicateExtension,
  44. ExtendedKeyUsage,
  45. Extension,
  46. ExtensionNotFound,
  47. Extensions,
  48. ExtensionType,
  49. FreshestCRL,
  50. GeneralNames,
  51. InhibitAnyPolicy,
  52. InvalidityDate,
  53. IssuerAlternativeName,
  54. IssuingDistributionPoint,
  55. KeyUsage,
  56. MSCertificateTemplate,
  57. NameConstraints,
  58. NamingAuthority,
  59. NoticeReference,
  60. OCSPAcceptableResponses,
  61. OCSPNoCheck,
  62. OCSPNonce,
  63. PolicyConstraints,
  64. PolicyInformation,
  65. PrecertificateSignedCertificateTimestamps,
  66. PrecertPoison,
  67. ProfessionInfo,
  68. ReasonFlags,
  69. SignedCertificateTimestamps,
  70. SubjectAlternativeName,
  71. SubjectInformationAccess,
  72. SubjectKeyIdentifier,
  73. TLSFeature,
  74. TLSFeatureType,
  75. UnrecognizedExtension,
  76. UserNotice,
  77. )
  78. from cryptography.x509.general_name import (
  79. DirectoryName,
  80. DNSName,
  81. GeneralName,
  82. IPAddress,
  83. OtherName,
  84. RegisteredID,
  85. RFC822Name,
  86. UniformResourceIdentifier,
  87. UnsupportedGeneralNameType,
  88. )
  89. from cryptography.x509.name import (
  90. Name,
  91. NameAttribute,
  92. RelativeDistinguishedName,
  93. )
  94. from cryptography.x509.oid import (
  95. AuthorityInformationAccessOID,
  96. CertificatePoliciesOID,
  97. CRLEntryExtensionOID,
  98. ExtendedKeyUsageOID,
  99. ExtensionOID,
  100. NameOID,
  101. ObjectIdentifier,
  102. PublicKeyAlgorithmOID,
  103. SignatureAlgorithmOID,
  104. )
  105. OID_AUTHORITY_INFORMATION_ACCESS = ExtensionOID.AUTHORITY_INFORMATION_ACCESS
  106. OID_AUTHORITY_KEY_IDENTIFIER = ExtensionOID.AUTHORITY_KEY_IDENTIFIER
  107. OID_BASIC_CONSTRAINTS = ExtensionOID.BASIC_CONSTRAINTS
  108. OID_CERTIFICATE_POLICIES = ExtensionOID.CERTIFICATE_POLICIES
  109. OID_CRL_DISTRIBUTION_POINTS = ExtensionOID.CRL_DISTRIBUTION_POINTS
  110. OID_EXTENDED_KEY_USAGE = ExtensionOID.EXTENDED_KEY_USAGE
  111. OID_FRESHEST_CRL = ExtensionOID.FRESHEST_CRL
  112. OID_INHIBIT_ANY_POLICY = ExtensionOID.INHIBIT_ANY_POLICY
  113. OID_ISSUER_ALTERNATIVE_NAME = ExtensionOID.ISSUER_ALTERNATIVE_NAME
  114. OID_KEY_USAGE = ExtensionOID.KEY_USAGE
  115. OID_NAME_CONSTRAINTS = ExtensionOID.NAME_CONSTRAINTS
  116. OID_OCSP_NO_CHECK = ExtensionOID.OCSP_NO_CHECK
  117. OID_POLICY_CONSTRAINTS = ExtensionOID.POLICY_CONSTRAINTS
  118. OID_POLICY_MAPPINGS = ExtensionOID.POLICY_MAPPINGS
  119. OID_SUBJECT_ALTERNATIVE_NAME = ExtensionOID.SUBJECT_ALTERNATIVE_NAME
  120. OID_SUBJECT_DIRECTORY_ATTRIBUTES = ExtensionOID.SUBJECT_DIRECTORY_ATTRIBUTES
  121. OID_SUBJECT_INFORMATION_ACCESS = ExtensionOID.SUBJECT_INFORMATION_ACCESS
  122. OID_SUBJECT_KEY_IDENTIFIER = ExtensionOID.SUBJECT_KEY_IDENTIFIER
  123. OID_DSA_WITH_SHA1 = SignatureAlgorithmOID.DSA_WITH_SHA1
  124. OID_DSA_WITH_SHA224 = SignatureAlgorithmOID.DSA_WITH_SHA224
  125. OID_DSA_WITH_SHA256 = SignatureAlgorithmOID.DSA_WITH_SHA256
  126. OID_ECDSA_WITH_SHA1 = SignatureAlgorithmOID.ECDSA_WITH_SHA1
  127. OID_ECDSA_WITH_SHA224 = SignatureAlgorithmOID.ECDSA_WITH_SHA224
  128. OID_ECDSA_WITH_SHA256 = SignatureAlgorithmOID.ECDSA_WITH_SHA256
  129. OID_ECDSA_WITH_SHA384 = SignatureAlgorithmOID.ECDSA_WITH_SHA384
  130. OID_ECDSA_WITH_SHA512 = SignatureAlgorithmOID.ECDSA_WITH_SHA512
  131. OID_RSA_WITH_MD5 = SignatureAlgorithmOID.RSA_WITH_MD5
  132. OID_RSA_WITH_SHA1 = SignatureAlgorithmOID.RSA_WITH_SHA1
  133. OID_RSA_WITH_SHA224 = SignatureAlgorithmOID.RSA_WITH_SHA224
  134. OID_RSA_WITH_SHA256 = SignatureAlgorithmOID.RSA_WITH_SHA256
  135. OID_RSA_WITH_SHA384 = SignatureAlgorithmOID.RSA_WITH_SHA384
  136. OID_RSA_WITH_SHA512 = SignatureAlgorithmOID.RSA_WITH_SHA512
  137. OID_RSASSA_PSS = SignatureAlgorithmOID.RSASSA_PSS
  138. OID_COMMON_NAME = NameOID.COMMON_NAME
  139. OID_COUNTRY_NAME = NameOID.COUNTRY_NAME
  140. OID_DOMAIN_COMPONENT = NameOID.DOMAIN_COMPONENT
  141. OID_DN_QUALIFIER = NameOID.DN_QUALIFIER
  142. OID_EMAIL_ADDRESS = NameOID.EMAIL_ADDRESS
  143. OID_GENERATION_QUALIFIER = NameOID.GENERATION_QUALIFIER
  144. OID_GIVEN_NAME = NameOID.GIVEN_NAME
  145. OID_LOCALITY_NAME = NameOID.LOCALITY_NAME
  146. OID_ORGANIZATIONAL_UNIT_NAME = NameOID.ORGANIZATIONAL_UNIT_NAME
  147. OID_ORGANIZATION_NAME = NameOID.ORGANIZATION_NAME
  148. OID_PSEUDONYM = NameOID.PSEUDONYM
  149. OID_SERIAL_NUMBER = NameOID.SERIAL_NUMBER
  150. OID_STATE_OR_PROVINCE_NAME = NameOID.STATE_OR_PROVINCE_NAME
  151. OID_SURNAME = NameOID.SURNAME
  152. OID_TITLE = NameOID.TITLE
  153. OID_CLIENT_AUTH = ExtendedKeyUsageOID.CLIENT_AUTH
  154. OID_CODE_SIGNING = ExtendedKeyUsageOID.CODE_SIGNING
  155. OID_EMAIL_PROTECTION = ExtendedKeyUsageOID.EMAIL_PROTECTION
  156. OID_OCSP_SIGNING = ExtendedKeyUsageOID.OCSP_SIGNING
  157. OID_SERVER_AUTH = ExtendedKeyUsageOID.SERVER_AUTH
  158. OID_TIME_STAMPING = ExtendedKeyUsageOID.TIME_STAMPING
  159. OID_ANY_POLICY = CertificatePoliciesOID.ANY_POLICY
  160. OID_CPS_QUALIFIER = CertificatePoliciesOID.CPS_QUALIFIER
  161. OID_CPS_USER_NOTICE = CertificatePoliciesOID.CPS_USER_NOTICE
  162. OID_CERTIFICATE_ISSUER = CRLEntryExtensionOID.CERTIFICATE_ISSUER
  163. OID_CRL_REASON = CRLEntryExtensionOID.CRL_REASON
  164. OID_INVALIDITY_DATE = CRLEntryExtensionOID.INVALIDITY_DATE
  165. OID_CA_ISSUERS = AuthorityInformationAccessOID.CA_ISSUERS
  166. OID_OCSP = AuthorityInformationAccessOID.OCSP
  167. __all__ = [
  168. "OID_CA_ISSUERS",
  169. "OID_OCSP",
  170. "AccessDescription",
  171. "Admission",
  172. "Admissions",
  173. "Attribute",
  174. "AttributeNotFound",
  175. "Attributes",
  176. "AuthorityInformationAccess",
  177. "AuthorityKeyIdentifier",
  178. "BasicConstraints",
  179. "CRLDistributionPoints",
  180. "CRLNumber",
  181. "CRLReason",
  182. "Certificate",
  183. "CertificateBuilder",
  184. "CertificateIssuer",
  185. "CertificatePolicies",
  186. "CertificateRevocationList",
  187. "CertificateRevocationListBuilder",
  188. "CertificateSigningRequest",
  189. "CertificateSigningRequestBuilder",
  190. "DNSName",
  191. "DeltaCRLIndicator",
  192. "DirectoryName",
  193. "DistributionPoint",
  194. "DuplicateExtension",
  195. "ExtendedKeyUsage",
  196. "Extension",
  197. "ExtensionNotFound",
  198. "ExtensionType",
  199. "Extensions",
  200. "FreshestCRL",
  201. "GeneralName",
  202. "GeneralNames",
  203. "IPAddress",
  204. "InhibitAnyPolicy",
  205. "InvalidVersion",
  206. "InvalidityDate",
  207. "IssuerAlternativeName",
  208. "IssuingDistributionPoint",
  209. "KeyUsage",
  210. "MSCertificateTemplate",
  211. "Name",
  212. "NameAttribute",
  213. "NameConstraints",
  214. "NameOID",
  215. "NamingAuthority",
  216. "NoticeReference",
  217. "OCSPAcceptableResponses",
  218. "OCSPNoCheck",
  219. "OCSPNonce",
  220. "ObjectIdentifier",
  221. "OtherName",
  222. "PolicyConstraints",
  223. "PolicyInformation",
  224. "PrecertPoison",
  225. "PrecertificateSignedCertificateTimestamps",
  226. "ProfessionInfo",
  227. "PublicKeyAlgorithmOID",
  228. "RFC822Name",
  229. "ReasonFlags",
  230. "RegisteredID",
  231. "RelativeDistinguishedName",
  232. "RevokedCertificate",
  233. "RevokedCertificateBuilder",
  234. "SignatureAlgorithmOID",
  235. "SignedCertificateTimestamps",
  236. "SubjectAlternativeName",
  237. "SubjectInformationAccess",
  238. "SubjectKeyIdentifier",
  239. "TLSFeature",
  240. "TLSFeatureType",
  241. "UniformResourceIdentifier",
  242. "UnrecognizedExtension",
  243. "UnsupportedGeneralNameType",
  244. "UserNotice",
  245. "Version",
  246. "certificate_transparency",
  247. "load_der_x509_certificate",
  248. "load_der_x509_crl",
  249. "load_der_x509_csr",
  250. "load_pem_x509_certificate",
  251. "load_pem_x509_certificates",
  252. "load_pem_x509_crl",
  253. "load_pem_x509_csr",
  254. "random_serial_number",
  255. "verification",
  256. "verification",
  257. ]