t.p.tls : module documentation

Part of twisted.protocols View Source

Implementation of a TLS transport (ISSLTransport) as an IProtocol layered on top of any ITransport implementation, based on OpenSSL's memory BIO features.

TLSMemoryBIOFactory is a WrappingFactory which wraps protocols created by the factory it wraps with TLSMemoryBIOProtocol. TLSMemoryBIOProtocol intercedes between the underlying transport and the wrapped protocol to implement SSL and TLS. Typical usage of this module looks like this:
   from twisted.protocols.tls import TLSMemoryBIOFactory
   from twisted.internet.protocol import ServerFactory
   from twisted.internet.ssl import PrivateCertificate
   from twisted.internet import reactor

   from someapplication import ApplicationProtocol

   serverFactory = ServerFactory()
   serverFactory.protocol = ApplicationProtocol
   certificate = PrivateCertificate.loadPEM(certPEMData)
   contextFactory = certificate.options()
   tlsFactory = TLSMemoryBIOFactory(contextFactory, False, serverFactory)
   reactor.listenTCP(12345, tlsFactory)
   reactor.run()
Because the reactor's SSL and TLS APIs are likely implemented in a more efficient way, it is more common to use them (see IReactorSSL and ITLSTransport). However, this API offers somewhat more flexibility; for example, a TLSMemoryBIOProtocol instance can use another instance of TLSMemoryBIOProtocol as its transport, yielding TLS over TLS - useful to implement onion routing. Or it can be used to run TLS over a UNIX socket, or over stdio to a child process.
Class TLSMemoryBIOProtocol No summary
Class TLSMemoryBIOFactory TLSMemoryBIOFactory adds TLS to connections.
API Documentation for Twisted, generated by pydoctor at 2011-10-27 16:17:34.