當前位置: 首頁>>代碼示例>>Python>>正文


Python x509.Extension方法代碼示例

本文整理匯總了Python中cryptography.x509.Extension方法的典型用法代碼示例。如果您正苦於以下問題:Python x509.Extension方法的具體用法?Python x509.Extension怎麽用?Python x509.Extension使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在cryptography.x509的用法示例。


在下文中一共展示了x509.Extension方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的Python代碼示例。

示例1: print_extension

# 需要導入模塊: from cryptography import x509 [as 別名]
# 或者: from cryptography.x509 import Extension [as 別名]
def print_extension(self, ext):
        if isinstance(ext, Extension):
            if isinstance(ext, NullExtension):
                if ext.critical:
                    # NOTE: Only PrecertPoison is ever marked as critical
                    self.stdout.write('%s (critical): Yes' % ext.name)
                else:
                    self.stdout.write('%s: Yes' % ext.name)
            else:
                if ext.critical:
                    self.stdout.write('%s (critical):' % ext.name)
                else:
                    self.stdout.write('%s:' % ext.name)

                self.stdout.write(self.indent(ext.as_text()))
        elif isinstance(ext, x509.Extension):
            if ext.critical:  # pragma: no cover - all unrecognized extensions that we have are non-critical
                self.stdout.write('%s (critical): %s' % (ext.oid._name, ext.oid.dotted_string))
            else:
                self.stdout.write('%s: %s' % (ext.oid._name, ext.oid.dotted_string))
        else:  # pragma: no cover
            raise ValueError('Received unknown extension type: %s' % type(ext)) 
開發者ID:mathiasertl,項目名稱:django-ca,代碼行數:24,代碼來源:base.py

示例2: test_config

# 需要導入模塊: from cryptography import x509 [as 別名]
# 或者: from cryptography.x509 import Extension [as 別名]
def test_config(self):
        self.assertTrue(issubclass(self.ext_class, Extension))
        self.assertEqual(self.ext_class.key, self.ext_class_key)
        self.assertEqual(self.ext_class.name, self.ext_class_name)

        # Test some basic properties (just to be sure)
        self.assertIsInstance(self.ext_class.oid, ObjectIdentifier)
        self.assertIsInstance(self.ext_class.key, str)
        self.assertGreater(len(self.ext_class.key), 0)
        self.assertIsInstance(self.ext_class.name, str)
        self.assertGreater(len(self.ext_class.name), 0)

        # Test mapping dicts
        self.assertEqual(KEY_TO_EXTENSION[self.ext_class.key], self.ext_class)
        self.assertEqual(OID_TO_EXTENSION[self.ext_class.oid], self.ext_class)

        # test that the model matches
        self.assertTrue(hasattr(X509CertMixin, self.ext_class.key))
        self.assertIsInstance(getattr(X509CertMixin, self.ext_class.key), cached_property) 
開發者ID:mathiasertl,項目名稱:django-ca,代碼行數:21,代碼來源:tests_extensions.py

示例3: get_readonly_fields

# 需要導入模塊: from cryptography import x509 [as 別名]
# 或者: from cryptography.x509 import Extension [as 別名]
def get_readonly_fields(self, request, obj=None):
        fields = super(CertificateMixin, self).get_readonly_fields(request, obj=obj)

        if not obj.revoked:
            # We can only change the date when the certificate was compromised if it's actually revoked.
            fields.append('compromised')

        if obj is None:  # pragma: no cover
            # This is never True because CertificateAdmin (the only case where objects are added) doesn't call
            # the superclass in this case.
            return fields

        fields = list(fields)
        for field in obj.extension_fields:
            if isinstance(field, x509.Extension):
                field = self.get_oid_name(field.oid)

            fields.append(field)

        return fields 
開發者ID:mathiasertl,項目名稱:django-ca,代碼行數:22,代碼來源:admin.py

示例4: add_extension

# 需要導入模塊: from cryptography import x509 [as 別名]
# 或者: from cryptography.x509 import Extension [as 別名]
def add_extension(self, extension, critical):
        if not isinstance(extension, x509.ExtensionType):
            raise TypeError("extension must be an ExtensionType")

        extension = x509.Extension(extension.oid, critical, extension)
        _reject_duplicate_extension(extension, self._extensions)

        return OCSPRequestBuilder(
            self._request, self._extensions + [extension]
        ) 
開發者ID:tp4a,項目名稱:teleport,代碼行數:12,代碼來源:ocsp.py

示例5: _build_key_usage

# 需要導入模塊: from cryptography import x509 [as 別名]
# 或者: from cryptography.x509 import Extension [as 別名]
def _build_key_usage(self, critical=False):
        # Digital Signature and Key Encipherment are enabled
        key_usage = c_x509.KeyUsage(
            True, False, True, False, False, False, False, False, False)
        return c_x509.Extension(key_usage.oid, critical, key_usage) 
開發者ID:openstack,項目名稱:magnum,代碼行數:7,代碼來源:test_validator.py

示例6: _build_basic_constraints

# 需要導入模塊: from cryptography import x509 [as 別名]
# 或者: from cryptography.x509 import Extension [as 別名]
def _build_basic_constraints(self, ca=False, critical=False):
        bc = c_x509.BasicConstraints(ca, None)
        return c_x509.Extension(bc.oid, critical, bc) 
開發者ID:openstack,項目名稱:magnum,代碼行數:5,代碼來源:test_validator.py

示例7: test_merge_key_usage_disallowed_but_not_critical

# 需要導入模塊: from cryptography import x509 [as 別名]
# 或者: from cryptography.x509 import Extension [as 別名]
def test_merge_key_usage_disallowed_but_not_critical(self):
        key_usage = self._build_key_usage()
        expected = c_x509.KeyUsage(
            True, False, False, False, False, False, False, False, False)
        expected = c_x509.Extension(expected.oid, False, expected)

        self.assertEqual(expected,
                         v._merge_key_usage(key_usage,
                                            ['Digital Signature'])) 
開發者ID:openstack,項目名稱:magnum,代碼行數:11,代碼來源:test_validator.py

示例8: assertInClientExtensions

# 需要導入模塊: from cryptography import x509 [as 別名]
# 或者: from cryptography.x509 import Extension [as 別名]
def assertInClientExtensions(self, cert):
        key_usage = c_x509.KeyUsage(True, False, True, False, False, False,
                                    False, False, False)
        key_usage = c_x509.Extension(key_usage.oid, True, key_usage)
        extended_key_usage = c_x509.ExtendedKeyUsage([c_x509.OID_CLIENT_AUTH])
        extended_key_usage = c_x509.Extension(extended_key_usage.oid, False,
                                              extended_key_usage)
        basic_constraints = c_x509.BasicConstraints(ca=False, path_length=None)
        basic_constraints = c_x509.Extension(basic_constraints.oid, True,
                                             basic_constraints)

        self.assertIn(key_usage, cert.extensions)
        self.assertIn(extended_key_usage, cert.extensions)
        self.assertIn(basic_constraints, cert.extensions) 
開發者ID:openstack,項目名稱:magnum,代碼行數:16,代碼來源:test_sign.py

示例9: test_generate_ca_certificate_set_extentions_as_ca

# 需要導入模塊: from cryptography import x509 [as 別名]
# 或者: from cryptography.x509 import Extension [as 別名]
def test_generate_ca_certificate_set_extentions_as_ca(self):
        cert, _ = self._generate_ca_certificate(self.issuer_name)

        key_usage = c_x509.KeyUsage(False, False, False, False, False, True,
                                    False, False, False)
        key_usage = c_x509.Extension(key_usage.oid, True, key_usage)
        basic_constraints = c_x509.BasicConstraints(ca=True, path_length=0)
        basic_constraints = c_x509.Extension(basic_constraints.oid, True,
                                             basic_constraints)

        self.assertIn(key_usage, cert.extensions)
        self.assertIn(basic_constraints, cert.extensions) 
開發者ID:openstack,項目名稱:magnum,代碼行數:14,代碼來源:test_sign.py

示例10: _disallow_ca_in_basic_constraints

# 需要導入模塊: from cryptography import x509 [as 別名]
# 或者: from cryptography.x509 import Extension [as 別名]
def _disallow_ca_in_basic_constraints(basic_constraints):
    if basic_constraints.value.ca:
        if basic_constraints.critical:
            raise exception.CertificateValidationError(
                extension=basic_constraints)

        bc = x509.BasicConstraints(False, None)
        return x509.Extension(bc.oid, False, bc)

    return basic_constraints 
開發者ID:openstack,項目名稱:magnum,代碼行數:12,代碼來源:validator.py

示例11: _build_client_extentions

# 需要導入模塊: from cryptography import x509 [as 別名]
# 或者: from cryptography.x509 import Extension [as 別名]
def _build_client_extentions():
    # Digital Signature and Key Encipherment are enabled
    key_usage = x509.KeyUsage(True, False, True, False, False, False, False,
                              False, False)
    key_usage = x509.Extension(key_usage.oid, True, key_usage)
    extended_key_usage = x509.ExtendedKeyUsage([x509.OID_CLIENT_AUTH])
    extended_key_usage = x509.Extension(extended_key_usage.oid, False,
                                        extended_key_usage)
    basic_constraints = x509.BasicConstraints(ca=False, path_length=None)
    basic_constraints = x509.Extension(basic_constraints.oid, True,
                                       basic_constraints)

    return [key_usage, extended_key_usage, basic_constraints] 
開發者ID:openstack,項目名稱:magnum,代碼行數:15,代碼來源:operations.py

示例12: _build_ca_extentions

# 需要導入模塊: from cryptography import x509 [as 別名]
# 或者: from cryptography.x509 import Extension [as 別名]
def _build_ca_extentions():
    # Certificate Sign is enabled
    key_usage = x509.KeyUsage(False, False, False, False, False, True, False,
                              False, False)
    key_usage = x509.Extension(key_usage.oid, True, key_usage)

    basic_constraints = x509.BasicConstraints(ca=True, path_length=0)
    basic_constraints = x509.Extension(basic_constraints.oid, True,
                                       basic_constraints)

    return [basic_constraints, key_usage] 
開發者ID:openstack,項目名稱:magnum,代碼行數:13,代碼來源:operations.py

示例13: get_authority_key_identifier_extension

# 需要導入模塊: from cryptography import x509 [as 別名]
# 或者: from cryptography.x509 import Extension [as 別名]
def get_authority_key_identifier_extension(self):
        return AuthorityKeyIdentifier(x509.Extension(
            critical=AuthorityKeyIdentifier.default_critical,
            oid=AuthorityKeyIdentifier.oid,
            value=self.get_authority_key_identifier()
        )) 
開發者ID:mathiasertl,項目名稱:django-ca,代碼行數:8,代碼來源:models.py

示例14: ext

# 需要導入模塊: from cryptography import x509 [as 別名]
# 或者: from cryptography.x509 import Extension [as 別名]
def ext(self, value=None, critical=None):
        if value is None:
            value = {}

        if isinstance(value, x509.extensions.ExtensionType):
            if critical is None:
                critical = self.ext_class.default_critical
            ext = x509.extensions.Extension(oid=self.ext_class.oid, critical=critical, value=value)
            return self.ext_class(ext)
        else:
            d = {'value': value}
            if critical is not None:
                d['critical'] = critical
            return self.ext_class(d) 
開發者ID:mathiasertl,項目名稱:django-ca,代碼行數:16,代碼來源:tests_extensions.py

示例15: test_as_extension

# 需要導入模塊: from cryptography import x509 [as 別名]
# 或者: from cryptography.x509 import Extension [as 別名]
def test_as_extension(self):
        for config in self.test_values.values():
            with self.assertRaises(NotImplementedError):
                Extension({'value': config['expected']}).as_extension() 
開發者ID:mathiasertl,項目名稱:django-ca,代碼行數:6,代碼來源:tests_extensions.py


注:本文中的cryptography.x509.Extension方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。