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


Python PrivateCertificate.fromCertificateAndKeyPair方法代碼示例

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


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

示例1: clientCertFor

# 需要導入模塊: from twisted.internet.ssl import PrivateCertificate [as 別名]
# 或者: from twisted.internet.ssl.PrivateCertificate import fromCertificateAndKeyPair [as 別名]
def clientCertFor(name):
    signingCert = getCAPrivateCert()
    clientKey = KeyPair.generate(size=4096)
    csr = clientKey.requestObject(DN(CN=name), "sha1")
    clientCert = signingCert.signRequestObject(
        csr, serialNumber=1, digestAlgorithm="sha1")
    return PrivateCertificate.fromCertificateAndKeyPair(clientCert, clientKey)
開發者ID:damouse,項目名稱:pdservertemp,代碼行數:9,代碼來源:newcert.py

示例2: clientCertFor

# 需要導入模塊: from twisted.internet.ssl import PrivateCertificate [as 別名]
# 或者: from twisted.internet.ssl.PrivateCertificate import fromCertificateAndKeyPair [as 別名]
def clientCertFor(p_name):
    l_signingCert = getCAPrivateCert()
    l_clientKey = KeyPair.generate(size = 4096)
    l_csr = l_clientKey.requestObject(DN(CN = p_name), "sha1")
    l_clientCert = l_signingCert.signRequestObject(
        l_csr, serialNumber = 1, digestAlgorithm = "sha1")
    return PrivateCertificate.fromCertificateAndKeyPair(l_clientCert, l_clientKey)
開發者ID:DBrianKimmel,項目名稱:PyHouse,代碼行數:9,代碼來源:newcert.py

示例3: private_certificate

# 需要導入模塊: from twisted.internet.ssl import PrivateCertificate [as 別名]
# 或者: from twisted.internet.ssl.PrivateCertificate import fromCertificateAndKeyPair [as 別名]
    def private_certificate(self):
        """
        Combine private key and certificate into a ``PrivateCertificate``.

        :return: ``PrivateCertificate`` instance.
        """
        return PrivateCertificate.fromCertificateAndKeyPair(
            self.certificate, self.keypair.keypair)
開發者ID:gideonmay,項目名稱:flocker,代碼行數:10,代碼來源:_ca.py

示例4: _create_tls_client_context

# 需要導入模塊: from twisted.internet.ssl import PrivateCertificate [as 別名]
# 或者: from twisted.internet.ssl.PrivateCertificate import fromCertificateAndKeyPair [as 別名]
def _create_tls_client_context(config, cbdir, log):
    """
    Create a CertificateOptions object for use with TLS listening endpoints.
    """
    # server hostname: The expected name of the remote host.
    hostname = config['hostname']

    # explicit trust (certificate) root
    ca_certs = None
    if 'ca_certificates' in config:
        log.info("TLS client using explicit trust ({cnt_certs} certificates)", cnt_certs=len(config['ca_certificates']))
        ca_certs = []
        for cert_fname in [os.path.abspath(os.path.join(cbdir, x)) for x in (config['ca_certificates'])]:
            cert = crypto.load_certificate(
                crypto.FILETYPE_PEM,
                six.u(open(cert_fname, 'r').read())
            )
            log.info("TLS client trust root CA certificate loaded from '{fname}'", fname=cert_fname)
            ca_certs.append(cert)
        ca_certs = OpenSSLCertificateAuthorities(ca_certs)
    else:
        log.info("TLS client using platform trust")

    # client key/cert to use
    client_cert = None
    if 'key' in config:
        if 'certificate' not in config:
            raise Exception('TLS client key present, but certificate missing')

        key_fname = os.path.abspath(os.path.join(cbdir, config['key']))
        with open(key_fname, 'r') as f:
            private_key = KeyPair.load(f.read(), format=crypto.FILETYPE_PEM)
            log.info("Loaded client TLS key from '{key_fname}'", key_fname=key_fname)

        cert_fname = os.path.abspath(os.path.join(cbdir, config['certificate']))
        with open(cert_fname, 'r') as f:
            cert = Certificate.loadPEM(f.read(),)
            log.info("Loaded client TLS certificate from '{cert_fname}' (cn='{cert_cn}', sha256={cert_sha256}..)",
                     cert_fname=cert_fname,
                     cert_cn=cert.getSubject().CN,
                     cert_sha256=cert.digest('sha256')[:12])

        client_cert = PrivateCertificate.fromCertificateAndKeyPair(cert, private_key)
    else:
        if 'certificate' in config:
            log.warn('TLS client certificate present, but key is missing')

    # create TLS client context
    ctx = optionsForClientTLS(hostname, trustRoot=ca_certs, clientCertificate=client_cert)

    return ctx
開發者ID:FirefighterBlu3,項目名稱:crossbar,代碼行數:53,代碼來源:endpoint.py

示例5: actualTest

# 需要導入模塊: from twisted.internet.ssl import PrivateCertificate [as 別名]
# 或者: from twisted.internet.ssl.PrivateCertificate import fromCertificateAndKeyPair [as 別名]
        def actualTest(result):
            ponged = defer.Deferred()
            signer = self.serverService2.certificateStorage.getPrivateCertificate(
                self.fromDomain).privateKey
            req = signer.requestObject(DistinguishedName(commonName=self.toDomain))
            sreq = signer.signRequestObject(
                DistinguishedName(commonName=self.fromDomain), req, 12345)
            selfSignedLie = PrivateCertificate.fromCertificateAndKeyPair(
                sreq, signer)
            self.serverService2.connectQ2Q(self.fromAddress,
                                          self.toAddress,
                                          'pony',
                                          OneTrickPonyClientFactory(ponged),
                                          selfSignedLie,
                                          fakeFromDomain=self.toDomain).addErrback(
                lambda e: e.trap(q2q.VerifyError))

            return self.assertFailure(ponged, q2q.VerifyError)
開發者ID:exarkun,項目名稱:vertex,代碼行數:20,代碼來源:test_q2q.py

示例6: __init__

# 需要導入模塊: from twisted.internet.ssl import PrivateCertificate [as 別名]
# 或者: from twisted.internet.ssl.PrivateCertificate import fromCertificateAndKeyPair [as 別名]
 def __init__(self, publicPath, privatePath, csrPath, key, cert, issuer):
     self.publicPath = publicPath
     self.privatePath = privatePath
     self.csrPath = csrPath
     self.cert = PrivateCertificate.fromCertificateAndKeyPair(cert, key)
     self.issuer = issuer
開發者ID:tomprince,項目名稱:deed,代碼行數:8,代碼來源:authority.py

示例7: pems

# 需要導入模塊: from twisted.internet.ssl import PrivateCertificate [as 別名]
# 或者: from twisted.internet.ssl.PrivateCertificate import fromCertificateAndKeyPair [as 別名]
 def pems():
     for i in count():
         key = KeyPair.generate()
         cert = key.selfSignedCert(i, commonName=u"lae_automation testing")
         pem = PrivateCertificate.fromCertificateAndKeyPair(cert, key).dumpPEM()
         yield pem.decode("ascii")
開發者ID:LeastAuthority,項目名稱:leastauthority.com,代碼行數:8,代碼來源:strategies.py


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