Server IP : 15.235.198.142 / Your IP : 216.73.216.213 Web Server : Apache/2.4.58 (Ubuntu) System : Linux ballsack 6.8.0-45-generic #45-Ubuntu SMP PREEMPT_DYNAMIC Fri Aug 30 12:02:04 UTC 2024 x86_64 User : www-data ( 33) PHP Version : 8.3.6 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : OFF | Sudo : ON | Pkexec : OFF Directory : /lib/python3/dist-packages/twisted/test/ |
Upload File : |
# Copyright (c) Twisted Matrix Laboratories. # See LICENSE for details. """ Helper classes for twisted.test.test_ssl. They are in a separate module so they will not prevent test_ssl importing if pyOpenSSL is unavailable. """ from __future__ import annotations from OpenSSL import SSL from twisted.internet import ssl from twisted.python.compat import nativeString from twisted.python.filepath import FilePath certPath = nativeString(FilePath(__file__.encode("utf-8")).sibling(b"server.pem").path) class ClientTLSContext(ssl.ClientContextFactory): """ SSL Context Factory for client-side connections. """ isClient = 1 def getContext(self) -> SSL.Context: """ Return an L{SSL.Context} to be use for client-side connections. Will not return a cached context. This is done to improve the test coverage as most implementation are caching the context. """ return SSL.Context(SSL.SSLv23_METHOD) class ServerTLSContext: """ SSL Context Factory for server-side connections. """ isClient = 0 def __init__( self, filename: str | bytes = certPath, method: int | None = None ) -> None: self.filename = filename if method is None: method = SSL.SSLv23_METHOD self._method = method def getContext(self) -> SSL.Context: """ Return an L{SSL.Context} to be use for server-side connections. Will not return a cached context. This is done to improve the test coverage as most implementation are caching the context. """ ctx = SSL.Context(self._method) ctx.use_certificate_file(self.filename) ctx.use_privatekey_file(self.filename) return ctx