SILENT KILLERPanel

Current Path: > > opt > alt > python27 > lib64 > python2.7


Operation   : Linux premium131.web-hosting.com 4.18.0-553.44.1.lve.el8.x86_64 #1 SMP Thu Mar 13 14:29:12 UTC 2025 x86_64
Software     : Apache
Server IP    : 162.0.232.56 | Your IP: 216.73.216.111
Domains      : 1034 Domain(s)
Permission   : [ 0755 ]

Files and Folders in: //opt/alt/python27/lib64/python2.7

NameTypeSizeLast ModifiedActions
bsddb Directory - -
compiler Directory - -
config Directory - -
ctypes Directory - -
curses Directory - -
distutils Directory - -
email Directory - -
encodings Directory - -
ensurepip Directory - -
hotshot Directory - -
idlelib Directory - -
importlib Directory - -
json Directory - -
lib-dynload Directory - -
lib2to3 Directory - -
logging Directory - -
multiprocessing Directory - -
plat-linux2 Directory - -
pydoc_data Directory - -
site-packages Directory - -
sqlite3 Directory - -
test Directory - -
unittest Directory - -
wsgiref Directory - -
xml Directory - -
BaseHTTPServer.py File 22747 bytes January 08 2025 10:43:40.
BaseHTTPServer.pyc File 21982 bytes January 08 2025 10:43:03.
BaseHTTPServer.pyo File 21982 bytes January 08 2025 10:43:03.
Bastion.py File 5744 bytes January 08 2025 10:43:11.
Bastion.pyc File 6855 bytes January 08 2025 10:42:51.
Bastion.pyo File 6855 bytes January 08 2025 10:42:51.
CGIHTTPServer.py File 13089 bytes January 08 2025 10:43:27.
CGIHTTPServer.pyc File 11187 bytes January 08 2025 10:43:39.
CGIHTTPServer.pyo File 11187 bytes January 08 2025 10:43:39.
ConfigParser.py File 27746 bytes January 08 2025 10:43:11.
ConfigParser.pyc File 25980 bytes January 08 2025 10:43:11.
ConfigParser.pyo File 25980 bytes January 08 2025 10:43:11.
Cookie.py File 26538 bytes January 08 2025 10:43:04.
Cookie.pyc File 23152 bytes January 08 2025 10:43:41.
Cookie.pyo File 23152 bytes January 08 2025 10:43:41.
DocXMLRPCServer.py File 10768 bytes January 08 2025 10:43:11.
DocXMLRPCServer.pyc File 10442 bytes January 08 2025 10:43:35.
DocXMLRPCServer.pyo File 10333 bytes January 08 2025 10:43:08.
HTMLParser.py File 17171 bytes January 08 2025 10:42:55.
HTMLParser.pyc File 14143 bytes January 08 2025 10:42:55.
HTMLParser.pyo File 13838 bytes January 08 2025 10:43:35.
MimeWriter.py File 6482 bytes January 08 2025 10:42:52.
MimeWriter.pyc File 7481 bytes January 08 2025 10:43:04.
MimeWriter.pyo File 7481 bytes January 08 2025 10:43:04.
Queue.py File 8577 bytes January 08 2025 10:43:11.
Queue.pyc File 9788 bytes January 08 2025 10:43:04.
Queue.pyo File 9788 bytes January 08 2025 10:43:04.
SimpleHTTPServer.py File 7997 bytes January 08 2025 10:43:03.
SimpleHTTPServer.pyc File 8153 bytes January 08 2025 10:42:51.
SimpleHTTPServer.pyo File 8153 bytes January 08 2025 10:42:51.
SimpleXMLRPCServer.py File 25812 bytes January 08 2025 10:43:42.
SimpleXMLRPCServer.pyc File 23331 bytes January 08 2025 10:43:05.
SimpleXMLRPCServer.pyo File 23331 bytes January 08 2025 10:43:05.
SocketServer.py File 23948 bytes January 08 2025 10:43:28.
SocketServer.pyc File 24828 bytes January 08 2025 10:43:04.
SocketServer.pyo File 24828 bytes January 08 2025 10:43:04.
StringIO.py File 10662 bytes January 08 2025 10:43:31.
StringIO.pyc File 11727 bytes January 08 2025 10:43:39.
StringIO.pyo File 11727 bytes January 08 2025 10:43:39.
UserDict.py File 7060 bytes January 08 2025 10:43:04.
UserDict.pyc File 10296 bytes January 21 2025 11:47:01.
UserDict.pyo File 10296 bytes January 08 2025 10:43:04.
UserList.py File 3644 bytes January 08 2025 10:43:35.
UserList.pyc File 7019 bytes January 08 2025 10:43:31.
UserList.pyo File 7019 bytes January 08 2025 10:43:31.
UserString.py File 9697 bytes January 08 2025 10:43:35.
UserString.pyc File 15748 bytes January 08 2025 10:43:27.
UserString.pyo File 15748 bytes January 08 2025 10:43:27.
_LWPCookieJar.py File 6553 bytes January 08 2025 10:43:41.
_LWPCookieJar.pyc File 5512 bytes January 08 2025 10:43:11.
_LWPCookieJar.pyo File 5512 bytes January 08 2025 10:43:11.
_MozillaCookieJar.py File 5797 bytes January 08 2025 10:42:58.
_MozillaCookieJar.pyc File 4513 bytes January 08 2025 10:43:04.
_MozillaCookieJar.pyo File 4474 bytes January 08 2025 10:43:35.
__future__.py File 4380 bytes January 08 2025 10:43:39.
__future__.pyc File 4301 bytes January 08 2025 10:43:03.
__future__.pyo File 4301 bytes January 08 2025 10:43:03.
__phello__.foo.py File 64 bytes January 08 2025 10:43:35.
__phello__.foo.pyc File 138 bytes January 08 2025 10:43:05.
__phello__.foo.pyo File 138 bytes January 08 2025 10:43:05.
_abcoll.py File 18619 bytes January 08 2025 10:43:11.
_abcoll.pyc File 27034 bytes January 21 2025 11:47:01.
_abcoll.pyo File 27034 bytes January 08 2025 10:43:35.
_osx_support.py File 19100 bytes January 08 2025 10:43:35.
_osx_support.pyc File 12005 bytes January 08 2025 10:43:04.
_osx_support.pyo File 12005 bytes January 08 2025 10:43:04.
_pyio.py File 69630 bytes January 08 2025 10:43:11.
_pyio.pyc File 66976 bytes January 08 2025 10:43:38.
_pyio.pyo File 66976 bytes January 08 2025 10:43:38.
_strptime.py File 20728 bytes January 08 2025 10:43:38.
_strptime.pyc File 15432 bytes January 08 2025 10:43:35.
_strptime.pyo File 15432 bytes January 08 2025 10:43:35.
_sysconfigdata.py File 21163 bytes January 08 2025 10:43:35.
_sysconfigdata.pyc File 24277 bytes January 21 2025 11:47:01.
_sysconfigdata.pyo File 24277 bytes January 08 2025 10:42:56.
_threading_local.py File 7260 bytes January 08 2025 10:43:03.
_threading_local.pyc File 6490 bytes January 08 2025 10:43:11.
_threading_local.pyo File 6490 bytes January 08 2025 10:43:11.
_weakrefset.py File 5911 bytes January 08 2025 10:42:58.
_weakrefset.pyc File 10302 bytes January 21 2025 11:47:01.
_weakrefset.pyo File 10302 bytes January 08 2025 10:43:40.
abc.py File 7145 bytes January 08 2025 10:43:03.
abc.pyc File 6286 bytes January 21 2025 11:47:01.
abc.pyo File 6230 bytes January 08 2025 10:43:04.
aifc.py File 34579 bytes January 08 2025 10:43:39.
aifc.pyc File 31408 bytes January 08 2025 10:43:42.
aifc.pyo File 31408 bytes January 08 2025 10:43:42.
antigravity.py File 60 bytes January 08 2025 10:43:05.
antigravity.pyc File 216 bytes January 08 2025 10:42:55.
antigravity.pyo File 216 bytes January 08 2025 10:42:55.
anydbm.py File 2663 bytes January 08 2025 10:42:56.
anydbm.pyc File 2839 bytes January 08 2025 10:42:51.
anydbm.pyo File 2839 bytes January 08 2025 10:42:51.
argparse.py File 89228 bytes January 08 2025 10:43:35.
argparse.pyc File 66382 bytes January 08 2025 10:43:01.
argparse.pyo File 66217 bytes January 08 2025 10:43:11.
ast.py File 11805 bytes January 08 2025 10:43:35.
ast.pyc File 13250 bytes January 08 2025 10:42:56.
ast.pyo File 13250 bytes January 08 2025 10:42:56.
asynchat.py File 11581 bytes January 08 2025 10:43:27.
asynchat.pyc File 9200 bytes January 08 2025 10:43:01.
asynchat.pyo File 9200 bytes January 08 2025 10:43:01.
asyncore.py File 20943 bytes January 08 2025 10:43:40.
asyncore.pyc File 19660 bytes January 08 2025 10:43:00.
asyncore.pyo File 19660 bytes January 08 2025 10:43:00.
atexit.py File 1705 bytes January 08 2025 10:43:35.
atexit.pyc File 2281 bytes January 08 2025 10:42:55.
atexit.pyo File 2281 bytes January 08 2025 10:42:55.
audiodev.py File 7597 bytes January 08 2025 10:43:35.
audiodev.pyc File 8820 bytes January 08 2025 10:43:42.
audiodev.pyo File 8820 bytes January 08 2025 10:43:42.
base64.py File 11816 bytes January 08 2025 10:43:08.
base64.pyc File 11531 bytes January 08 2025 10:43:41.
base64.pyo File 11531 bytes January 08 2025 10:43:41.
bdb.py File 21714 bytes January 08 2025 10:43:27.
bdb.pyc File 19894 bytes January 08 2025 10:43:08.
bdb.pyo File 19894 bytes January 08 2025 10:43:08.
binhex.py File 14698 bytes January 08 2025 10:43:03.
binhex.pyc File 16123 bytes January 08 2025 10:43:11.
binhex.pyo File 16123 bytes January 08 2025 10:43:11.
bisect.py File 2595 bytes January 08 2025 10:42:51.
bisect.pyc File 3136 bytes January 08 2025 10:43:27.
bisect.pyo File 3136 bytes January 08 2025 10:43:27.
cProfile.py File 6583 bytes January 08 2025 10:42:56.
cProfile.pyc File 6577 bytes January 08 2025 10:42:56.
cProfile.pyo File 6577 bytes January 08 2025 10:42:56.
calendar.py File 23384 bytes January 08 2025 10:43:31.
calendar.pyc File 28940 bytes January 08 2025 10:43:35.
calendar.pyo File 28940 bytes January 08 2025 10:43:35.
cgi.py File 35807 bytes January 08 2025 10:43:35.
cgi.pyc File 34034 bytes January 08 2025 10:43:00.
cgi.pyo File 34034 bytes January 08 2025 10:43:00.
cgitb.py File 12175 bytes January 08 2025 10:43:40.
cgitb.pyc File 12372 bytes January 08 2025 10:43:35.
cgitb.pyo File 12372 bytes January 08 2025 10:43:35.
chunk.py File 5419 bytes January 08 2025 10:43:11.
chunk.pyc File 5745 bytes January 08 2025 10:43:41.
chunk.pyo File 5745 bytes January 08 2025 10:43:41.
cmd.py File 15026 bytes January 08 2025 10:42:55.
cmd.pyc File 14312 bytes January 08 2025 10:43:35.
cmd.pyo File 14312 bytes January 08 2025 10:43:35.
code.py File 10189 bytes January 08 2025 10:43:05.
code.pyc File 10542 bytes January 08 2025 10:43:27.
code.pyo File 10542 bytes January 08 2025 10:43:27.
codecs.py File 36143 bytes January 08 2025 10:43:04.
codecs.pyc File 38046 bytes January 21 2025 11:47:01.
codecs.pyo File 38046 bytes January 08 2025 10:42:56.
codeop.py File 5999 bytes January 08 2025 10:42:59.
codeop.pyc File 6727 bytes January 08 2025 10:43:04.
codeop.pyo File 6727 bytes January 08 2025 10:43:04.
collections.py File 27798 bytes January 08 2025 10:43:04.
collections.pyc File 26839 bytes January 08 2025 10:43:35.
collections.pyo File 26788 bytes January 08 2025 10:43:03.
colorsys.py File 3691 bytes January 08 2025 10:43:03.
colorsys.pyc File 4095 bytes January 08 2025 10:43:09.
colorsys.pyo File 4095 bytes January 08 2025 10:43:09.
commands.py File 2545 bytes January 08 2025 10:42:58.
commands.pyc File 2547 bytes January 08 2025 10:43:00.
commands.pyo File 2547 bytes January 08 2025 10:43:00.
compileall.py File 7763 bytes January 08 2025 10:42:59.
compileall.pyc File 7095 bytes January 08 2025 10:43:35.
compileall.pyo File 7095 bytes January 08 2025 10:43:35.
contextlib.py File 4424 bytes January 08 2025 10:42:59.
contextlib.pyc File 4610 bytes January 08 2025 10:43:35.
contextlib.pyo File 4610 bytes January 08 2025 10:43:35.
cookielib.py File 65486 bytes January 08 2025 10:43:05.
cookielib.pyc File 55986 bytes January 08 2025 10:43:39.
cookielib.pyo File 55798 bytes January 08 2025 10:43:27.
copy.py File 11533 bytes January 08 2025 10:43:03.
copy.pyc File 12508 bytes January 08 2025 10:43:35.
copy.pyo File 12416 bytes January 08 2025 10:43:27.
copy_reg.py File 6974 bytes January 08 2025 10:43:11.
copy_reg.pyc File 5310 bytes January 21 2025 11:47:01.
copy_reg.pyo File 5266 bytes January 08 2025 10:43:35.
crypt.py File 2291 bytes January 08 2025 10:43:03.
crypt.pyc File 3025 bytes January 08 2025 10:43:00.
crypt.pyo File 3025 bytes January 08 2025 10:43:00.
csv.py File 16708 bytes January 08 2025 10:43:04.
csv.pyc File 13884 bytes January 08 2025 10:43:27.
csv.pyo File 13884 bytes January 08 2025 10:43:27.
dbhash.py File 498 bytes January 08 2025 10:42:55.
dbhash.pyc File 744 bytes January 08 2025 10:43:03.
dbhash.pyo File 744 bytes January 08 2025 10:43:03.
decimal.py File 221933 bytes January 08 2025 10:43:28.
decimal.pyc File 175470 bytes January 08 2025 10:42:55.
decimal.pyo File 175470 bytes January 08 2025 10:42:55.
difflib.py File 82325 bytes January 08 2025 10:43:08.
difflib.pyc File 62600 bytes January 08 2025 10:43:05.
difflib.pyo File 62549 bytes January 08 2025 10:43:41.
dircache.py File 1126 bytes January 08 2025 10:42:55.
dircache.pyc File 1628 bytes January 08 2025 10:43:08.
dircache.pyo File 1628 bytes January 08 2025 10:43:08.
dis.py File 6499 bytes January 08 2025 10:43:04.
dis.pyc File 6332 bytes January 08 2025 10:43:31.
dis.pyo File 6332 bytes January 08 2025 10:43:31.
doctest.py File 105095 bytes January 08 2025 10:43:04.
doctest.pyc File 85210 bytes January 08 2025 10:43:03.
doctest.pyo File 84923 bytes January 08 2025 10:42:56.
dumbdbm.py File 9141 bytes January 08 2025 10:43:04.
dumbdbm.pyc File 6993 bytes January 08 2025 10:43:39.
dumbdbm.pyo File 6993 bytes January 08 2025 10:43:39.
dummy_thread.py File 4418 bytes January 08 2025 10:43:05.
dummy_thread.pyc File 5589 bytes January 08 2025 10:43:05.
dummy_thread.pyo File 5589 bytes January 08 2025 10:43:05.
dummy_threading.py File 2804 bytes January 08 2025 10:43:03.
dummy_threading.pyc File 1298 bytes January 08 2025 10:43:39.
dummy_threading.pyo File 1298 bytes January 08 2025 10:43:39.
filecmp.py File 9588 bytes January 08 2025 10:43:03.
filecmp.pyc File 9882 bytes January 08 2025 10:43:28.
filecmp.pyo File 9882 bytes January 08 2025 10:43:28.
fileinput.py File 13746 bytes January 08 2025 10:43:08.
fileinput.pyc File 14890 bytes January 08 2025 10:43:35.
fileinput.pyo File 14890 bytes January 08 2025 10:43:35.
fnmatch.py File 3315 bytes January 08 2025 10:43:03.
fnmatch.pyc File 3692 bytes January 08 2025 10:43:00.
fnmatch.pyo File 3692 bytes January 08 2025 10:43:00.
formatter.py File 14911 bytes January 08 2025 10:43:04.
formatter.pyc File 20179 bytes January 08 2025 10:43:03.
formatter.pyo File 20179 bytes January 08 2025 10:43:03.
fpformat.py File 4732 bytes January 08 2025 10:43:28.
fpformat.pyc File 4807 bytes January 08 2025 10:43:11.
fpformat.pyo File 4807 bytes January 08 2025 10:43:11.
fractions.py File 22390 bytes January 08 2025 10:42:56.
fractions.pyc File 20218 bytes January 08 2025 10:43:00.
fractions.pyo File 20218 bytes January 08 2025 10:43:00.
ftplib.py File 38194 bytes January 08 2025 10:43:03.
ftplib.pyc File 35652 bytes January 08 2025 10:42:56.
ftplib.pyo File 35652 bytes January 08 2025 10:42:56.
functools.py File 4806 bytes January 08 2025 10:43:42.
functools.pyc File 7019 bytes January 08 2025 10:43:05.
functools.pyo File 7019 bytes January 08 2025 10:43:05.
genericpath.py File 3201 bytes January 08 2025 10:43:41.
genericpath.pyc File 3660 bytes January 21 2025 11:47:01.
genericpath.pyo File 3660 bytes January 08 2025 10:43:35.
getopt.py File 7319 bytes January 08 2025 10:43:35.
getopt.pyc File 6784 bytes January 08 2025 10:43:35.
getopt.pyo File 6739 bytes January 08 2025 10:43:40.
getpass.py File 5563 bytes January 08 2025 10:42:56.
getpass.pyc File 4835 bytes January 08 2025 10:43:35.
getpass.pyo File 4835 bytes January 08 2025 10:43:35.
gettext.py File 22666 bytes January 08 2025 10:43:35.
gettext.pyc File 18602 bytes January 08 2025 10:43:42.
gettext.pyo File 18602 bytes January 08 2025 10:43:42.
glob.py File 3114 bytes January 08 2025 10:42:59.
glob.pyc File 3047 bytes January 08 2025 10:43:03.
glob.pyo File 3047 bytes January 08 2025 10:43:03.
gzip.py File 19028 bytes January 08 2025 10:43:35.
gzip.pyc File 15626 bytes January 08 2025 10:43:04.
gzip.pyo File 15626 bytes January 08 2025 10:43:04.
hashlib.py File 7842 bytes January 08 2025 10:43:39.
hashlib.pyc File 7026 bytes January 08 2025 10:43:39.
hashlib.pyo File 7026 bytes January 08 2025 10:43:39.
heapq.py File 18295 bytes January 08 2025 10:42:52.
heapq.pyc File 14798 bytes January 08 2025 10:43:04.
heapq.pyo File 14798 bytes January 08 2025 10:43:04.
hmac.py File 4588 bytes January 08 2025 10:43:11.
hmac.pyc File 4672 bytes January 08 2025 10:43:35.
hmac.pyo File 4672 bytes January 08 2025 10:43:35.
htmlentitydefs.py File 18056 bytes January 08 2025 10:43:04.
htmlentitydefs.pyc File 6380 bytes January 08 2025 10:43:04.
htmlentitydefs.pyo File 6380 bytes January 08 2025 10:43:04.
htmllib.py File 12869 bytes January 08 2025 10:43:08.
htmllib.pyc File 21492 bytes January 08 2025 10:42:59.
htmllib.pyo File 21492 bytes January 08 2025 10:42:59.
httplib.py File 52300 bytes January 08 2025 10:43:35.
httplib.pyc File 38793 bytes January 08 2025 10:43:11.
httplib.pyo File 38609 bytes January 08 2025 10:43:40.
ihooks.py File 18986 bytes January 08 2025 10:43:11.
ihooks.pyc File 22269 bytes January 08 2025 10:43:04.
ihooks.pyo File 22269 bytes January 08 2025 10:43:04.
imaplib.py File 48366 bytes January 08 2025 10:43:34.
imaplib.pyc File 46272 bytes January 08 2025 10:43:03.
imaplib.pyo File 43506 bytes January 08 2025 10:43:04.
imghdr.py File 3541 bytes January 08 2025 10:43:35.
imghdr.pyc File 5046 bytes January 08 2025 10:43:05.
imghdr.pyo File 5046 bytes January 08 2025 10:43:05.
imputil.py File 25764 bytes January 08 2025 10:43:03.
imputil.pyc File 16117 bytes January 08 2025 10:43:28.
imputil.pyo File 15939 bytes January 08 2025 10:43:31.
inspect.py File 43008 bytes January 08 2025 10:43:27.
inspect.pyc File 41126 bytes January 08 2025 10:43:31.
inspect.pyo File 41126 bytes January 08 2025 10:43:31.
io.py File 3322 bytes January 08 2025 10:43:04.
io.pyc File 3654 bytes January 08 2025 10:43:00.
io.pyo File 3654 bytes January 08 2025 10:43:00.
keyword.py File 2005 bytes January 08 2025 10:43:35.
keyword.pyc File 2131 bytes January 08 2025 10:43:42.
keyword.pyo File 2131 bytes January 08 2025 10:43:42.
linecache.py File 4027 bytes January 08 2025 10:43:05.
linecache.pyc File 3350 bytes January 21 2025 11:47:01.
linecache.pyo File 3350 bytes January 08 2025 10:42:55.
locale.py File 102834 bytes January 08 2025 10:43:27.
locale.pyc File 57026 bytes January 08 2025 10:42:51.
locale.pyo File 57026 bytes January 08 2025 10:42:51.
macpath.py File 6289 bytes January 08 2025 10:43:04.
macpath.pyc File 7928 bytes January 08 2025 10:43:03.
macpath.pyo File 7928 bytes January 08 2025 10:43:03.
macurl2path.py File 2731 bytes January 08 2025 10:43:03.
macurl2path.pyc File 2296 bytes January 08 2025 10:43:27.
macurl2path.pyo File 2296 bytes January 08 2025 10:43:27.
mailbox.py File 81240 bytes January 08 2025 10:43:27.
mailbox.pyc File 79564 bytes January 08 2025 10:43:35.
mailbox.pyo File 79517 bytes January 08 2025 10:43:03.
mailcap.py File 7429 bytes January 08 2025 10:42:56.
mailcap.pyc File 7248 bytes January 08 2025 10:43:08.
mailcap.pyo File 7248 bytes January 08 2025 10:43:08.
markupbase.py File 14643 bytes January 08 2025 10:43:40.
markupbase.pyc File 9488 bytes January 08 2025 10:43:38.
markupbase.pyo File 9292 bytes January 08 2025 10:42:55.
md5.py File 358 bytes January 08 2025 10:43:40.
md5.pyc File 391 bytes January 08 2025 10:43:03.
md5.pyo File 391 bytes January 08 2025 10:43:03.
mhlib.py File 33434 bytes January 08 2025 10:43:28.
mhlib.pyc File 34791 bytes January 08 2025 10:43:28.
mhlib.pyo File 34791 bytes January 08 2025 10:43:28.
mimetools.py File 7168 bytes January 08 2025 10:43:11.
mimetools.pyc File 8461 bytes January 08 2025 10:43:39.
mimetools.pyo File 8461 bytes January 08 2025 10:43:39.
mimetypes.py File 21028 bytes January 08 2025 10:43:27.
mimetypes.pyc File 18736 bytes January 08 2025 10:43:35.
mimetypes.pyo File 18736 bytes January 08 2025 10:43:35.
mimify.py File 15030 bytes January 08 2025 10:43:05.
mimify.pyc File 12196 bytes January 08 2025 10:43:27.
mimify.pyo File 12196 bytes January 08 2025 10:43:27.
modulefinder.py File 24461 bytes January 08 2025 10:43:03.
modulefinder.pyc File 19582 bytes January 08 2025 10:42:56.
modulefinder.pyo File 19500 bytes January 08 2025 10:42:55.
multifile.py File 4820 bytes January 08 2025 10:43:27.
multifile.pyc File 5615 bytes January 08 2025 10:43:31.
multifile.pyo File 5573 bytes January 08 2025 10:42:52.
mutex.py File 1878 bytes January 08 2025 10:43:01.
mutex.pyc File 2607 bytes January 08 2025 10:43:27.
mutex.pyo File 2607 bytes January 08 2025 10:43:27.
netrc.py File 5888 bytes January 08 2025 10:43:11.
netrc.pyc File 4831 bytes January 08 2025 10:43:27.
netrc.pyo File 4831 bytes January 08 2025 10:43:27.
new.py File 610 bytes January 08 2025 10:43:35.
new.pyc File 875 bytes January 08 2025 10:42:58.
new.pyo File 875 bytes January 08 2025 10:42:58.
nntplib.py File 21470 bytes January 08 2025 10:42:55.
nntplib.pyc File 21616 bytes January 08 2025 10:43:31.
nntplib.pyo File 21616 bytes January 08 2025 10:43:31.
ntpath.py File 19429 bytes January 08 2025 10:42:58.
ntpath.pyc File 13415 bytes January 08 2025 10:43:11.
ntpath.pyo File 13415 bytes January 08 2025 10:43:11.
nturl2path.py File 2419 bytes January 08 2025 10:43:35.
nturl2path.pyc File 1854 bytes January 08 2025 10:43:04.
nturl2path.pyo File 1854 bytes January 08 2025 10:43:04.
numbers.py File 10319 bytes January 08 2025 10:43:39.
numbers.pyc File 14818 bytes January 08 2025 10:43:05.
numbers.pyo File 14818 bytes January 08 2025 10:43:05.
opcode.py File 5474 bytes January 08 2025 10:43:41.
opcode.pyc File 6210 bytes January 08 2025 10:42:56.
opcode.pyo File 6210 bytes January 08 2025 10:42:56.
optparse.py File 61203 bytes January 08 2025 10:43:35.
optparse.pyc File 55714 bytes January 08 2025 10:43:35.
optparse.pyo File 55631 bytes January 08 2025 10:43:39.
os.py File 25910 bytes January 08 2025 10:43:00.
os.pyc File 26378 bytes January 21 2025 11:47:01.
os.pyo File 26378 bytes January 08 2025 10:43:31.
os2emxpath.py File 4635 bytes January 08 2025 10:43:04.
os2emxpath.pyc File 4642 bytes January 08 2025 10:43:42.
os2emxpath.pyo File 4642 bytes January 08 2025 10:43:42.
pdb.doc File 7914 bytes January 08 2025 10:43:03.
pdb.py File 46108 bytes January 08 2025 10:43:05.
pdb.pyc File 45151 bytes January 08 2025 10:43:39.
pdb.pyo File 45151 bytes January 08 2025 10:43:39.
pickle.py File 45489 bytes January 08 2025 10:43:11.
pickle.pyc File 39912 bytes January 08 2025 10:43:39.
pickle.pyo File 39716 bytes January 08 2025 10:43:27.
pickletools.py File 74523 bytes January 08 2025 10:43:03.
pickletools.pyc File 57448 bytes January 08 2025 10:43:31.
pickletools.pyo File 56587 bytes January 08 2025 10:42:59.
pipes.py File 9582 bytes January 08 2025 10:43:35.
pipes.pyc File 9516 bytes January 08 2025 10:43:35.
pipes.pyo File 9516 bytes January 08 2025 10:43:35.
pkgutil.py File 20243 bytes January 08 2025 10:43:04.
pkgutil.pyc File 19388 bytes January 08 2025 10:43:04.
pkgutil.pyo File 19388 bytes January 08 2025 10:43:04.
platform.py File 52798 bytes January 08 2025 10:43:04.
platform.pyc File 38602 bytes January 08 2025 10:43:05.
platform.pyo File 38602 bytes January 08 2025 10:43:05.
plistlib.py File 15185 bytes January 08 2025 10:42:51.
plistlib.pyc File 20008 bytes January 08 2025 10:43:35.
plistlib.pyo File 19922 bytes January 08 2025 10:43:11.
popen2.py File 8416 bytes January 08 2025 10:43:39.
popen2.pyc File 9233 bytes January 08 2025 10:43:35.
popen2.pyo File 9191 bytes January 08 2025 10:43:03.
poplib.py File 12824 bytes January 08 2025 10:42:55.
poplib.pyc File 13774 bytes January 08 2025 10:43:04.
poplib.pyo File 13774 bytes January 08 2025 10:43:04.
posixfile.py File 8003 bytes January 08 2025 10:43:11.
posixfile.pyc File 7808 bytes January 08 2025 10:42:59.
posixfile.pyo File 7808 bytes January 08 2025 10:42:59.
posixpath.py File 14293 bytes January 08 2025 10:43:05.
posixpath.pyc File 11761 bytes January 21 2025 11:47:01.
posixpath.pyo File 11761 bytes January 08 2025 10:43:35.
pprint.py File 11777 bytes January 08 2025 10:43:04.
pprint.pyc File 10441 bytes January 08 2025 10:43:28.
pprint.pyo File 10264 bytes January 08 2025 10:43:27.
profile.py File 22791 bytes January 08 2025 10:43:09.
profile.pyc File 16963 bytes January 08 2025 10:43:38.
profile.pyo File 16716 bytes January 08 2025 10:43:09.
pstats.py File 26712 bytes January 08 2025 10:43:01.
pstats.pyc File 25793 bytes January 08 2025 10:42:55.
pstats.pyo File 25793 bytes January 08 2025 10:42:55.
pty.py File 5058 bytes January 08 2025 10:42:55.
pty.pyc File 5096 bytes January 08 2025 10:43:38.
pty.pyo File 5096 bytes January 08 2025 10:43:38.
py_compile.py File 5936 bytes January 08 2025 10:43:28.
py_compile.pyc File 6519 bytes January 08 2025 10:42:55.
py_compile.pyo File 6519 bytes January 08 2025 10:42:55.
pyclbr.py File 13388 bytes January 08 2025 10:42:51.
pyclbr.pyc File 9820 bytes January 08 2025 10:43:39.
pyclbr.pyo File 9820 bytes January 08 2025 10:43:39.
pydoc.py File 95676 bytes January 08 2025 10:43:04.
pydoc.pyc File 94914 bytes January 08 2025 10:43:04.
pydoc.pyo File 94850 bytes January 08 2025 10:43:37.
quopri.py File 6978 bytes January 08 2025 10:43:35.
quopri.pyc File 6717 bytes January 08 2025 10:43:11.
quopri.pyo File 6717 bytes January 08 2025 10:43:11.
random.py File 32457 bytes January 08 2025 10:42:55.
random.pyc File 26263 bytes January 08 2025 10:43:03.
random.pyo File 26263 bytes January 08 2025 10:43:03.
re.py File 13423 bytes January 08 2025 10:43:06.
re.pyc File 13686 bytes January 21 2025 11:47:01.
re.pyo File 13686 bytes January 08 2025 10:43:27.
repr.py File 4296 bytes January 08 2025 10:43:42.
repr.pyc File 5606 bytes January 08 2025 10:43:08.
repr.pyo File 5606 bytes January 08 2025 10:43:08.
rexec.py File 20148 bytes January 08 2025 10:43:05.
rexec.pyc File 24574 bytes January 08 2025 10:43:27.
rexec.pyo File 24574 bytes January 08 2025 10:43:27.
rfc822.py File 33542 bytes January 08 2025 10:43:35.
rfc822.pyc File 32593 bytes January 08 2025 10:43:40.
rfc822.pyo File 32593 bytes January 08 2025 10:43:40.
rlcompleter.py File 5991 bytes January 08 2025 10:43:42.
rlcompleter.pyc File 6182 bytes January 08 2025 10:43:11.
rlcompleter.pyo File 6182 bytes January 08 2025 10:43:11.
robotparser.py File 7695 bytes January 08 2025 10:43:03.
robotparser.pyc File 8315 bytes January 08 2025 10:43:28.
robotparser.pyo File 8315 bytes January 08 2025 10:43:28.
runpy.py File 11081 bytes January 08 2025 10:42:55.
runpy.pyc File 9063 bytes January 08 2025 10:43:27.
runpy.pyo File 9063 bytes January 08 2025 10:43:27.
sched.py File 5088 bytes January 08 2025 10:43:28.
sched.pyc File 5111 bytes January 08 2025 10:42:56.
sched.pyo File 5111 bytes January 08 2025 10:42:56.
sets.py File 19050 bytes January 08 2025 10:43:40.
sets.pyc File 17623 bytes January 08 2025 10:43:05.
sets.pyo File 17623 bytes January 08 2025 10:43:05.
sgmllib.py File 17884 bytes January 08 2025 10:42:55.
sgmllib.pyc File 16047 bytes January 08 2025 10:42:59.
sgmllib.pyo File 16047 bytes January 08 2025 10:42:59.
sha.py File 393 bytes January 08 2025 10:43:27.
sha.pyc File 434 bytes January 08 2025 10:43:00.
sha.pyo File 434 bytes January 08 2025 10:43:00.
shelve.py File 8178 bytes January 08 2025 10:43:35.
shelve.pyc File 10607 bytes January 08 2025 10:43:35.
shelve.pyo File 10607 bytes January 08 2025 10:43:35.
shlex.py File 11164 bytes January 08 2025 10:43:39.
shlex.pyc File 7727 bytes January 08 2025 10:42:51.
shlex.pyo File 7727 bytes January 08 2025 10:42:51.
shutil.py File 19871 bytes January 08 2025 10:43:31.
shutil.pyc File 19649 bytes January 08 2025 10:43:27.
shutil.pyo File 19649 bytes January 08 2025 10:43:27.
site.py File 19637 bytes January 08 2025 10:43:27.
site.pyc File 19819 bytes January 21 2025 11:47:01.
site.pyo File 19819 bytes January 08 2025 10:43:27.
smtpd.py File 18552 bytes January 08 2025 10:43:05.
smtpd.pyc File 16286 bytes January 08 2025 10:43:11.
smtpd.pyo File 16286 bytes January 08 2025 10:43:11.
smtplib.py File 32144 bytes January 08 2025 10:43:03.
smtplib.pyc File 31019 bytes January 08 2025 10:42:59.
smtplib.pyo File 31019 bytes January 08 2025 10:42:59.
sndhdr.py File 5973 bytes January 08 2025 10:43:35.
sndhdr.pyc File 7582 bytes January 08 2025 10:43:34.
sndhdr.pyo File 7582 bytes January 08 2025 10:43:34.
socket.py File 20615 bytes January 08 2025 10:43:39.
socket.pyc File 16542 bytes January 08 2025 10:43:00.
socket.pyo File 16456 bytes January 08 2025 10:43:35.
sre.py File 384 bytes January 08 2025 10:42:59.
sre.pyc File 532 bytes January 08 2025 10:43:00.
sre.pyo File 532 bytes January 08 2025 10:43:00.
sre_compile.py File 19823 bytes January 08 2025 10:43:03.
sre_compile.pyc File 12755 bytes January 21 2025 11:47:01.
sre_compile.pyo File 12599 bytes January 08 2025 10:43:35.
sre_constants.py File 7197 bytes January 08 2025 10:43:00.
sre_constants.pyc File 6260 bytes January 21 2025 11:47:01.
sre_constants.pyo File 6260 bytes January 08 2025 10:43:04.
sre_parse.py File 30700 bytes January 08 2025 10:43:05.
sre_parse.pyc File 21624 bytes January 21 2025 11:47:01.
sre_parse.pyo File 21624 bytes January 08 2025 10:43:09.
ssl.py File 37455 bytes January 08 2025 10:43:27.
ssl.pyc File 33015 bytes January 08 2025 10:43:28.
ssl.pyo File 33015 bytes January 08 2025 10:43:28.
stat.py File 1842 bytes January 08 2025 10:43:28.
stat.pyc File 2881 bytes January 21 2025 11:47:01.
stat.pyo File 2881 bytes January 08 2025 10:43:11.
statvfs.py File 898 bytes January 08 2025 10:43:03.
statvfs.pyc File 633 bytes January 08 2025 10:43:05.
statvfs.pyo File 633 bytes January 08 2025 10:43:05.
string.py File 21548 bytes January 08 2025 10:43:35.
string.pyc File 21122 bytes January 08 2025 10:43:35.
string.pyo File 21122 bytes January 08 2025 10:43:35.
stringold.py File 12449 bytes January 08 2025 10:42:55.
stringold.pyc File 12900 bytes January 08 2025 10:42:55.
stringold.pyo File 12900 bytes January 08 2025 10:42:55.
stringprep.py File 13522 bytes January 08 2025 10:43:11.
stringprep.pyc File 14747 bytes January 08 2025 10:43:05.
stringprep.pyo File 14675 bytes January 08 2025 10:43:11.
struct.py File 82 bytes January 08 2025 10:43:05.
struct.pyc File 252 bytes January 08 2025 10:43:31.
struct.pyo File 252 bytes January 08 2025 10:43:31.
subprocess.py File 50520 bytes January 08 2025 10:42:56.
subprocess.pyc File 33100 bytes January 08 2025 10:43:11.
subprocess.pyo File 33100 bytes January 08 2025 10:43:11.
sunau.py File 17222 bytes January 08 2025 10:43:04.
sunau.pyc File 19018 bytes January 08 2025 10:43:35.
sunau.pyo File 19018 bytes January 08 2025 10:43:35.
sunaudio.py File 1399 bytes January 08 2025 10:43:40.
sunaudio.pyc File 2052 bytes January 08 2025 10:43:35.
sunaudio.pyo File 2052 bytes January 08 2025 10:43:35.
symbol.py File 2067 bytes January 08 2025 10:43:03.
symbol.pyc File 3052 bytes January 08 2025 10:42:55.
symbol.pyo File 3052 bytes January 08 2025 10:42:55.
symtable.py File 7437 bytes January 08 2025 10:43:35.
symtable.pyc File 12436 bytes January 08 2025 10:43:11.
symtable.pyo File 12305 bytes January 08 2025 10:42:55.
sysconfig.py File 22852 bytes January 08 2025 10:43:31.
sysconfig.pyc File 18156 bytes January 21 2025 11:47:01.
sysconfig.pyo File 18153 bytes January 08 2025 10:43:31.
tabnanny.py File 11349 bytes January 08 2025 10:43:35.
tabnanny.pyc File 8507 bytes January 08 2025 10:43:35.
tabnanny.pyo File 8507 bytes January 08 2025 10:43:35.
tarfile.py File 90568 bytes January 08 2025 10:43:04.
tarfile.pyc File 78374 bytes January 08 2025 10:43:35.
tarfile.pyo File 78374 bytes January 08 2025 10:43:35.
telnetlib.py File 27036 bytes January 08 2025 10:43:03.
telnetlib.pyc File 23583 bytes January 08 2025 10:43:38.
telnetlib.pyo File 23583 bytes January 08 2025 10:43:38.
tempfile.py File 19547 bytes January 08 2025 10:42:56.
tempfile.pyc File 21046 bytes January 08 2025 10:43:39.
tempfile.pyo File 21046 bytes January 08 2025 10:43:39.
textwrap.py File 17280 bytes January 08 2025 10:42:58.
textwrap.pyc File 12279 bytes January 08 2025 10:43:28.
textwrap.pyo File 12187 bytes January 08 2025 10:42:55.
this.py File 1002 bytes January 08 2025 10:43:11.
this.pyc File 1233 bytes January 08 2025 10:43:35.
this.pyo File 1233 bytes January 08 2025 10:43:35.
threading.py File 47282 bytes January 08 2025 10:43:27.
threading.pyc File 43999 bytes January 08 2025 10:43:04.
threading.pyo File 41825 bytes January 08 2025 10:42:59.
timeit.py File 12801 bytes January 08 2025 10:43:04.
timeit.pyc File 12352 bytes January 08 2025 10:43:31.
timeit.pyo File 12352 bytes January 08 2025 10:43:31.
toaiff.py File 3142 bytes January 08 2025 10:43:39.
toaiff.pyc File 3158 bytes January 08 2025 10:43:04.
toaiff.pyo File 3158 bytes January 08 2025 10:43:04.
token.py File 2922 bytes January 08 2025 10:42:59.
token.pyc File 3881 bytes January 08 2025 10:42:51.
token.pyo File 3881 bytes January 08 2025 10:42:51.
tokenize.py File 17483 bytes January 08 2025 10:43:31.
tokenize.pyc File 14713 bytes January 08 2025 10:43:41.
tokenize.pyo File 14657 bytes January 08 2025 10:42:59.
trace.py File 29901 bytes January 08 2025 10:42:55.
trace.pyc File 23235 bytes January 08 2025 10:43:03.
trace.pyo File 23172 bytes January 08 2025 10:43:31.
traceback.py File 11285 bytes January 08 2025 10:43:34.
traceback.pyc File 11939 bytes January 21 2025 11:47:01.
traceback.pyo File 11939 bytes January 08 2025 10:43:31.
tty.py File 879 bytes January 08 2025 10:42:55.
tty.pyc File 1356 bytes January 08 2025 10:42:56.
tty.pyo File 1356 bytes January 08 2025 10:42:56.
types.py File 2094 bytes January 08 2025 10:42:56.
types.pyc File 2816 bytes January 21 2025 11:47:01.
types.pyo File 2816 bytes January 08 2025 10:43:04.
urllib.py File 60228 bytes January 08 2025 10:43:03.
urllib.pyc File 52580 bytes January 08 2025 10:43:37.
urllib.pyo File 52485 bytes January 08 2025 10:43:09.
urllib2.py File 52537 bytes January 08 2025 10:43:35.
urllib2.pyc File 48949 bytes January 08 2025 10:43:34.
urllib2.pyo File 48854 bytes January 08 2025 10:43:27.
urlparse.py File 16678 bytes January 08 2025 10:43:11.
urlparse.pyc File 15886 bytes January 08 2025 10:43:08.
urlparse.pyo File 15886 bytes January 08 2025 10:43:08.
user.py File 1627 bytes January 08 2025 10:43:03.
user.pyc File 1737 bytes January 08 2025 10:43:03.
user.pyo File 1737 bytes January 08 2025 10:43:03.
uu.py File 6707 bytes January 08 2025 10:42:59.
uu.pyc File 4455 bytes January 08 2025 10:43:27.
uu.pyo File 4455 bytes January 08 2025 10:43:27.
uuid.py File 23175 bytes January 08 2025 10:43:04.
uuid.pyc File 23778 bytes January 08 2025 10:43:05.
uuid.pyo File 23662 bytes January 08 2025 10:42:56.
warnings.py File 14823 bytes January 08 2025 10:43:04.
warnings.pyc File 13809 bytes January 21 2025 11:47:01.
warnings.pyo File 13020 bytes January 08 2025 10:43:41.
wave.py File 18582 bytes January 08 2025 10:43:03.
wave.pyc File 20676 bytes January 08 2025 10:43:27.
wave.pyo File 20532 bytes January 08 2025 10:43:05.
weakref.py File 14830 bytes January 08 2025 10:43:28.
weakref.pyc File 17130 bytes January 08 2025 10:43:05.
weakref.pyo File 17130 bytes January 08 2025 10:43:05.
webbrowser.py File 22735 bytes January 08 2025 10:43:35.
webbrowser.pyc File 20335 bytes January 08 2025 10:42:55.
webbrowser.pyo File 20290 bytes January 08 2025 10:43:27.
whichdb.py File 3388 bytes January 08 2025 10:43:11.
whichdb.pyc File 2267 bytes January 08 2025 10:43:27.
whichdb.pyo File 2267 bytes January 08 2025 10:43:27.
wsgiref.egg-info File 187 bytes January 08 2025 10:42:51.
xdrlib.py File 6069 bytes January 08 2025 10:43:40.
xdrlib.pyc File 10448 bytes January 08 2025 10:43:38.
xdrlib.pyo File 10448 bytes January 08 2025 10:43:38.
xmllib.py File 34865 bytes January 08 2025 10:42:56.
xmllib.pyc File 27550 bytes January 08 2025 10:43:35.
xmllib.pyo File 27550 bytes January 08 2025 10:43:35.
xmlrpclib.py File 52136 bytes January 08 2025 10:43:31.
xmlrpclib.pyc File 45887 bytes January 08 2025 10:43:27.
xmlrpclib.pyo File 45703 bytes January 08 2025 10:43:04.
zipfile.py File 59477 bytes January 08 2025 10:43:40.
zipfile.pyc File 42930 bytes January 08 2025 10:43:34.
zipfile.pyo File 42930 bytes January 08 2025 10:43:34.

Reading File: //opt/alt/python27/lib64/python2.7/ssl.py

# Wrapper module for _ssl, providing some additional facilities
# implemented in Python.  Written by Bill Janssen.

"""This module provides some more Pythonic support for SSL.

Object types:

  SSLSocket -- subtype of socket.socket which does SSL over the socket

Exceptions:

  SSLError -- exception raised for I/O errors

Functions:

  cert_time_to_seconds -- convert time string used for certificate
                          notBefore and notAfter functions to integer
                          seconds past the Epoch (the time values
                          returned from time.time())

  fetch_server_certificate (HOST, PORT) -- fetch the certificate provided
                          by the server running on HOST at port PORT.  No
                          validation of the certificate is performed.

Integer constants:

SSL_ERROR_ZERO_RETURN
SSL_ERROR_WANT_READ
SSL_ERROR_WANT_WRITE
SSL_ERROR_WANT_X509_LOOKUP
SSL_ERROR_SYSCALL
SSL_ERROR_SSL
SSL_ERROR_WANT_CONNECT

SSL_ERROR_EOF
SSL_ERROR_INVALID_ERROR_CODE

The following group define certificate requirements that one side is
allowing/requiring from the other side:

CERT_NONE - no certificates from the other side are required (or will
            be looked at if provided)
CERT_OPTIONAL - certificates are not required, but if provided will be
                validated, and if validation fails, the connection will
                also fail
CERT_REQUIRED - certificates are required, and will be validated, and
                if validation fails, the connection will also fail

The following constants identify various SSL protocol variants:

PROTOCOL_SSLv2
PROTOCOL_SSLv3
PROTOCOL_SSLv23
PROTOCOL_TLS
PROTOCOL_TLSv1
PROTOCOL_TLSv1_1
PROTOCOL_TLSv1_2

The following constants identify various SSL alert message descriptions as per
http://www.iana.org/assignments/tls-parameters/tls-parameters.xml#tls-parameters-6

ALERT_DESCRIPTION_CLOSE_NOTIFY
ALERT_DESCRIPTION_UNEXPECTED_MESSAGE
ALERT_DESCRIPTION_BAD_RECORD_MAC
ALERT_DESCRIPTION_RECORD_OVERFLOW
ALERT_DESCRIPTION_DECOMPRESSION_FAILURE
ALERT_DESCRIPTION_HANDSHAKE_FAILURE
ALERT_DESCRIPTION_BAD_CERTIFICATE
ALERT_DESCRIPTION_UNSUPPORTED_CERTIFICATE
ALERT_DESCRIPTION_CERTIFICATE_REVOKED
ALERT_DESCRIPTION_CERTIFICATE_EXPIRED
ALERT_DESCRIPTION_CERTIFICATE_UNKNOWN
ALERT_DESCRIPTION_ILLEGAL_PARAMETER
ALERT_DESCRIPTION_UNKNOWN_CA
ALERT_DESCRIPTION_ACCESS_DENIED
ALERT_DESCRIPTION_DECODE_ERROR
ALERT_DESCRIPTION_DECRYPT_ERROR
ALERT_DESCRIPTION_PROTOCOL_VERSION
ALERT_DESCRIPTION_INSUFFICIENT_SECURITY
ALERT_DESCRIPTION_INTERNAL_ERROR
ALERT_DESCRIPTION_USER_CANCELLED
ALERT_DESCRIPTION_NO_RENEGOTIATION
ALERT_DESCRIPTION_UNSUPPORTED_EXTENSION
ALERT_DESCRIPTION_CERTIFICATE_UNOBTAINABLE
ALERT_DESCRIPTION_UNRECOGNIZED_NAME
ALERT_DESCRIPTION_BAD_CERTIFICATE_STATUS_RESPONSE
ALERT_DESCRIPTION_BAD_CERTIFICATE_HASH_VALUE
ALERT_DESCRIPTION_UNKNOWN_PSK_IDENTITY
"""

import textwrap
import re
import sys
import os
from collections import namedtuple
from contextlib import closing

import _ssl             # if we can't import it, let the error propagate

from _ssl import OPENSSL_VERSION_NUMBER, OPENSSL_VERSION_INFO, OPENSSL_VERSION
from _ssl import _SSLContext
from _ssl import (
    SSLError, SSLZeroReturnError, SSLWantReadError, SSLWantWriteError,
    SSLSyscallError, SSLEOFError,
    )
from _ssl import CERT_NONE, CERT_OPTIONAL, CERT_REQUIRED
from _ssl import txt2obj as _txt2obj, nid2obj as _nid2obj
from _ssl import RAND_status, RAND_add
try:
    from _ssl import RAND_egd
except ImportError:
    # LibreSSL does not provide RAND_egd
    pass

def _import_symbols(prefix):
    for n in dir(_ssl):
        if n.startswith(prefix):
            globals()[n] = getattr(_ssl, n)

_import_symbols('OP_')
_import_symbols('ALERT_DESCRIPTION_')
_import_symbols('SSL_ERROR_')
_import_symbols('PROTOCOL_')
_import_symbols('VERIFY_')

from _ssl import HAS_SNI, HAS_ECDH, HAS_NPN, HAS_ALPN, HAS_TLSv1_3

from _ssl import _OPENSSL_API_VERSION

_PROTOCOL_NAMES = {value: name for name, value in globals().items()
                   if name.startswith('PROTOCOL_')
                       and name != 'PROTOCOL_SSLv23'}
PROTOCOL_SSLv23 = PROTOCOL_TLS

try:
    _SSLv2_IF_EXISTS = PROTOCOL_SSLv2
except NameError:
    _SSLv2_IF_EXISTS = None

from socket import socket, _fileobject, _delegate_methods, error as socket_error
if sys.platform == "win32":
    from _ssl import enum_certificates, enum_crls

from socket import socket, AF_INET, SOCK_STREAM, create_connection
from socket import SOL_SOCKET, SO_TYPE
import base64        # for DER-to-PEM translation
import errno
import warnings

if _ssl.HAS_TLS_UNIQUE:
    CHANNEL_BINDING_TYPES = ['tls-unique']
else:
    CHANNEL_BINDING_TYPES = []


# Disable weak or insecure ciphers by default
# (OpenSSL's default setting is 'DEFAULT:!aNULL:!eNULL')
# Enable a better set of ciphers by default
# This list has been explicitly chosen to:
#   * TLS 1.3 ChaCha20 and AES-GCM cipher suites
#   * Prefer cipher suites that offer perfect forward secrecy (DHE/ECDHE)
#   * Prefer ECDHE over DHE for better performance
#   * Prefer AEAD over CBC for better performance and security
#   * Prefer AES-GCM over ChaCha20 because most platforms have AES-NI
#     (ChaCha20 needs OpenSSL 1.1.0 or patched 1.0.2)
#   * Prefer any AES-GCM and ChaCha20 over any AES-CBC for better
#     performance and security
#   * Then Use HIGH cipher suites as a fallback
#   * Disable NULL authentication, NULL encryption, 3DES and MD5 MACs
#     for security reasons
_DEFAULT_CIPHERS = (
    'TLS13-AES-256-GCM-SHA384:TLS13-CHACHA20-POLY1305-SHA256:'
    'TLS13-AES-128-GCM-SHA256:'
    'ECDH+AESGCM:ECDH+CHACHA20:DH+AESGCM:DH+CHACHA20:ECDH+AES256:DH+AES256:'
    'ECDH+AES128:DH+AES:ECDH+HIGH:DH+HIGH:RSA+AESGCM:RSA+AES:RSA+HIGH:'
    '!aNULL:!eNULL:!MD5:!3DES'
    )

# Restricted and more secure ciphers for the server side
# This list has been explicitly chosen to:
#   * TLS 1.3 ChaCha20 and AES-GCM cipher suites
#   * Prefer cipher suites that offer perfect forward secrecy (DHE/ECDHE)
#   * Prefer ECDHE over DHE for better performance
#   * Prefer AEAD over CBC for better performance and security
#   * Prefer AES-GCM over ChaCha20 because most platforms have AES-NI
#   * Prefer any AES-GCM and ChaCha20 over any AES-CBC for better
#     performance and security
#   * Then Use HIGH cipher suites as a fallback
#   * Disable NULL authentication, NULL encryption, MD5 MACs, DSS, RC4, and
#     3DES for security reasons
_RESTRICTED_SERVER_CIPHERS = (
    'TLS13-AES-256-GCM-SHA384:TLS13-CHACHA20-POLY1305-SHA256:'
    'TLS13-AES-128-GCM-SHA256:'
    'ECDH+AESGCM:ECDH+CHACHA20:DH+AESGCM:DH+CHACHA20:ECDH+AES256:DH+AES256:'
    'ECDH+AES128:DH+AES:ECDH+HIGH:DH+HIGH:RSA+AESGCM:RSA+AES:RSA+HIGH:'
    '!aNULL:!eNULL:!MD5:!DSS:!RC4:!3DES'
)


class CertificateError(ValueError):
    pass


def _dnsname_match(dn, hostname, max_wildcards=1):
    """Matching according to RFC 6125, section 6.4.3

    http://tools.ietf.org/html/rfc6125#section-6.4.3
    """
    pats = []
    if not dn:
        return False

    pieces = dn.split(r'.')
    leftmost = pieces[0]
    remainder = pieces[1:]

    wildcards = leftmost.count('*')
    if wildcards > max_wildcards:
        # Issue #17980: avoid denials of service by refusing more
        # than one wildcard per fragment.  A survery of established
        # policy among SSL implementations showed it to be a
        # reasonable choice.
        raise CertificateError(
            "too many wildcards in certificate DNS name: " + repr(dn))

    # speed up common case w/o wildcards
    if not wildcards:
        return dn.lower() == hostname.lower()

    # RFC 6125, section 6.4.3, subitem 1.
    # The client SHOULD NOT attempt to match a presented identifier in which
    # the wildcard character comprises a label other than the left-most label.
    if leftmost == '*':
        # When '*' is a fragment by itself, it matches a non-empty dotless
        # fragment.
        pats.append('[^.]+')
    elif leftmost.startswith('xn--') or hostname.startswith('xn--'):
        # RFC 6125, section 6.4.3, subitem 3.
        # The client SHOULD NOT attempt to match a presented identifier
        # where the wildcard character is embedded within an A-label or
        # U-label of an internationalized domain name.
        pats.append(re.escape(leftmost))
    else:
        # Otherwise, '*' matches any dotless string, e.g. www*
        pats.append(re.escape(leftmost).replace(r'\*', '[^.]*'))

    # add the remaining fragments, ignore any wildcards
    for frag in remainder:
        pats.append(re.escape(frag))

    pat = re.compile(r'\A' + r'\.'.join(pats) + r'\Z', re.IGNORECASE)
    return pat.match(hostname)


def match_hostname(cert, hostname):
    """Verify that *cert* (in decoded format as returned by
    SSLSocket.getpeercert()) matches the *hostname*.  RFC 2818 and RFC 6125
    rules are followed, but IP addresses are not accepted for *hostname*.

    CertificateError is raised on failure. On success, the function
    returns nothing.
    """
    if not cert:
        raise ValueError("empty or no certificate, match_hostname needs a "
                         "SSL socket or SSL context with either "
                         "CERT_OPTIONAL or CERT_REQUIRED")
    dnsnames = []
    san = cert.get('subjectAltName', ())
    for key, value in san:
        if key == 'DNS':
            if _dnsname_match(value, hostname):
                return
            dnsnames.append(value)
    if not dnsnames:
        # The subject is only checked when there is no dNSName entry
        # in subjectAltName
        for sub in cert.get('subject', ()):
            for key, value in sub:
                # XXX according to RFC 2818, the most specific Common Name
                # must be used.
                if key == 'commonName':
                    if _dnsname_match(value, hostname):
                        return
                    dnsnames.append(value)
    if len(dnsnames) > 1:
        raise CertificateError("hostname %r "
            "doesn't match either of %s"
            % (hostname, ', '.join(map(repr, dnsnames))))
    elif len(dnsnames) == 1:
        raise CertificateError("hostname %r "
            "doesn't match %r"
            % (hostname, dnsnames[0]))
    else:
        raise CertificateError("no appropriate commonName or "
            "subjectAltName fields were found")


DefaultVerifyPaths = namedtuple("DefaultVerifyPaths",
    "cafile capath openssl_cafile_env openssl_cafile openssl_capath_env "
    "openssl_capath")

def get_default_verify_paths():
    """Return paths to default cafile and capath.
    """
    parts = _ssl.get_default_verify_paths()

    # environment vars shadow paths
    cafile = os.environ.get(parts[0], parts[1])
    capath = os.environ.get(parts[2], parts[3])

    return DefaultVerifyPaths(cafile if os.path.isfile(cafile) else None,
                              capath if os.path.isdir(capath) else None,
                              *parts)


class _ASN1Object(namedtuple("_ASN1Object", "nid shortname longname oid")):
    """ASN.1 object identifier lookup
    """
    __slots__ = ()

    def __new__(cls, oid):
        return super(_ASN1Object, cls).__new__(cls, *_txt2obj(oid, name=False))

    @classmethod
    def fromnid(cls, nid):
        """Create _ASN1Object from OpenSSL numeric ID
        """
        return super(_ASN1Object, cls).__new__(cls, *_nid2obj(nid))

    @classmethod
    def fromname(cls, name):
        """Create _ASN1Object from short name, long name or OID
        """
        return super(_ASN1Object, cls).__new__(cls, *_txt2obj(name, name=True))


class Purpose(_ASN1Object):
    """SSLContext purpose flags with X509v3 Extended Key Usage objects
    """

Purpose.SERVER_AUTH = Purpose('1.3.6.1.5.5.7.3.1')
Purpose.CLIENT_AUTH = Purpose('1.3.6.1.5.5.7.3.2')


class SSLContext(_SSLContext):
    """An SSLContext holds various SSL-related configuration options and
    data, such as certificates and possibly a private key."""

    __slots__ = ('protocol', '__weakref__')
    _windows_cert_stores = ("CA", "ROOT")

    def __new__(cls, protocol, *args, **kwargs):
        self = _SSLContext.__new__(cls, protocol)
        if protocol != _SSLv2_IF_EXISTS:
            self.set_ciphers(_DEFAULT_CIPHERS)
        return self

    def __init__(self, protocol):
        self.protocol = protocol

    def wrap_socket(self, sock, server_side=False,
                    do_handshake_on_connect=True,
                    suppress_ragged_eofs=True,
                    server_hostname=None):
        return SSLSocket(sock=sock, server_side=server_side,
                         do_handshake_on_connect=do_handshake_on_connect,
                         suppress_ragged_eofs=suppress_ragged_eofs,
                         server_hostname=server_hostname,
                         _context=self)

    def set_npn_protocols(self, npn_protocols):
        protos = bytearray()
        for protocol in npn_protocols:
            b = protocol.encode('ascii')
            if len(b) == 0 or len(b) > 255:
                raise SSLError('NPN protocols must be 1 to 255 in length')
            protos.append(len(b))
            protos.extend(b)

        self._set_npn_protocols(protos)

    def set_alpn_protocols(self, alpn_protocols):
        protos = bytearray()
        for protocol in alpn_protocols:
            b = protocol.encode('ascii')
            if len(b) == 0 or len(b) > 255:
                raise SSLError('ALPN protocols must be 1 to 255 in length')
            protos.append(len(b))
            protos.extend(b)

        self._set_alpn_protocols(protos)

    def _load_windows_store_certs(self, storename, purpose):
        certs = bytearray()
        try:
            for cert, encoding, trust in enum_certificates(storename):
                # CA certs are never PKCS#7 encoded
                if encoding == "x509_asn":
                    if trust is True or purpose.oid in trust:
                        certs.extend(cert)
        except OSError:
            warnings.warn("unable to enumerate Windows certificate store")
        if certs:
            self.load_verify_locations(cadata=certs)
        return certs

    def load_default_certs(self, purpose=Purpose.SERVER_AUTH):
        if not isinstance(purpose, _ASN1Object):
            raise TypeError(purpose)
        if sys.platform == "win32":
            for storename in self._windows_cert_stores:
                self._load_windows_store_certs(storename, purpose)
        self.set_default_verify_paths()


def create_default_context(purpose=Purpose.SERVER_AUTH, cafile=None,
                           capath=None, cadata=None):
    """Create a SSLContext object with default settings.

    NOTE: The protocol and settings may change anytime without prior
          deprecation. The values represent a fair balance between maximum
          compatibility and security.
    """
    if not isinstance(purpose, _ASN1Object):
        raise TypeError(purpose)

    # SSLContext sets OP_NO_SSLv2, OP_NO_SSLv3, OP_NO_COMPRESSION,
    # OP_CIPHER_SERVER_PREFERENCE, OP_SINGLE_DH_USE and OP_SINGLE_ECDH_USE
    # by default.
    context = SSLContext(PROTOCOL_TLS)

    if purpose == Purpose.SERVER_AUTH:
        # verify certs and host name in client mode
        context.verify_mode = CERT_REQUIRED
        context.check_hostname = True
    elif purpose == Purpose.CLIENT_AUTH:
        context.set_ciphers(_RESTRICTED_SERVER_CIPHERS)

    if cafile or capath or cadata:
        context.load_verify_locations(cafile, capath, cadata)
    elif context.verify_mode != CERT_NONE:
        # no explicit cafile, capath or cadata but the verify mode is
        # CERT_OPTIONAL or CERT_REQUIRED. Let's try to load default system
        # root CA certificates for the given purpose. This may fail silently.
        context.load_default_certs(purpose)
    return context

def _create_unverified_context(protocol=PROTOCOL_TLS, cert_reqs=None,
                           check_hostname=False, purpose=Purpose.SERVER_AUTH,
                           certfile=None, keyfile=None,
                           cafile=None, capath=None, cadata=None):
    """Create a SSLContext object for Python stdlib modules

    All Python stdlib modules shall use this function to create SSLContext
    objects in order to keep common settings in one place. The configuration
    is less restrict than create_default_context()'s to increase backward
    compatibility.
    """
    if not isinstance(purpose, _ASN1Object):
        raise TypeError(purpose)

    # SSLContext sets OP_NO_SSLv2, OP_NO_SSLv3, OP_NO_COMPRESSION,
    # OP_CIPHER_SERVER_PREFERENCE, OP_SINGLE_DH_USE and OP_SINGLE_ECDH_USE
    # by default.
    context = SSLContext(protocol)

    if cert_reqs is not None:
        context.verify_mode = cert_reqs
    context.check_hostname = check_hostname

    if keyfile and not certfile:
        raise ValueError("certfile must be specified")
    if certfile or keyfile:
        context.load_cert_chain(certfile, keyfile)

    # load CA root certs
    if cafile or capath or cadata:
        context.load_verify_locations(cafile, capath, cadata)
    elif context.verify_mode != CERT_NONE:
        # no explicit cafile, capath or cadata but the verify mode is
        # CERT_OPTIONAL or CERT_REQUIRED. Let's try to load default system
        # root CA certificates for the given purpose. This may fail silently.
        context.load_default_certs(purpose)

    return context

# Backwards compatibility alias, even though it's not a public name.
_create_stdlib_context = _create_unverified_context

# PEP 493: Verify HTTPS by default, but allow envvar to override that
_https_verify_envvar = 'PYTHONHTTPSVERIFY'

def _get_https_context_factory():
    if not sys.flags.ignore_environment:
        config_setting = os.environ.get(_https_verify_envvar)
        if config_setting == '0':
            return _create_unverified_context
    return create_default_context

_create_default_https_context = _get_https_context_factory()

# PEP 493: "private" API to configure HTTPS defaults without monkeypatching
def _https_verify_certificates(enable=True):
    """Verify server HTTPS certificates by default?"""
    global _create_default_https_context
    if enable:
        _create_default_https_context = create_default_context
    else:
        _create_default_https_context = _create_unverified_context


class SSLSocket(socket):
    """This class implements a subtype of socket.socket that wraps
    the underlying OS socket in an SSL context when necessary, and
    provides read and write methods over that channel."""

    def __init__(self, sock=None, keyfile=None, certfile=None,
                 server_side=False, cert_reqs=CERT_NONE,
                 ssl_version=PROTOCOL_TLS, ca_certs=None,
                 do_handshake_on_connect=True,
                 family=AF_INET, type=SOCK_STREAM, proto=0, fileno=None,
                 suppress_ragged_eofs=True, npn_protocols=None, ciphers=None,
                 server_hostname=None,
                 _context=None):

        self._makefile_refs = 0
        if _context:
            self._context = _context
        else:
            if server_side and not certfile:
                raise ValueError("certfile must be specified for server-side "
                                 "operations")
            if keyfile and not certfile:
                raise ValueError("certfile must be specified")
            if certfile and not keyfile:
                keyfile = certfile
            self._context = SSLContext(ssl_version)
            self._context.verify_mode = cert_reqs
            if ca_certs:
                self._context.load_verify_locations(ca_certs)
            if certfile:
                self._context.load_cert_chain(certfile, keyfile)
            if npn_protocols:
                self._context.set_npn_protocols(npn_protocols)
            if ciphers:
                self._context.set_ciphers(ciphers)
            self.keyfile = keyfile
            self.certfile = certfile
            self.cert_reqs = cert_reqs
            self.ssl_version = ssl_version
            self.ca_certs = ca_certs
            self.ciphers = ciphers
        # Can't use sock.type as other flags (such as SOCK_NONBLOCK) get
        # mixed in.
        if sock.getsockopt(SOL_SOCKET, SO_TYPE) != SOCK_STREAM:
            raise NotImplementedError("only stream sockets are supported")
        socket.__init__(self, _sock=sock._sock)
        # The initializer for socket overrides the methods send(), recv(), etc.
        # in the instancce, which we don't need -- but we want to provide the
        # methods defined in SSLSocket.
        for attr in _delegate_methods:
            try:
                delattr(self, attr)
            except AttributeError:
                pass
        if server_side and server_hostname:
            raise ValueError("server_hostname can only be specified "
                             "in client mode")
        if self._context.check_hostname and not server_hostname:
            raise ValueError("check_hostname requires server_hostname")
        self.server_side = server_side
        self.server_hostname = server_hostname
        self.do_handshake_on_connect = do_handshake_on_connect
        self.suppress_ragged_eofs = suppress_ragged_eofs

        # See if we are connected
        try:
            self.getpeername()
        except socket_error as e:
            if e.errno != errno.ENOTCONN:
                raise
            connected = False
        else:
            connected = True

        self._closed = False
        self._sslobj = None
        self._connected = connected
        if connected:
            # create the SSL object
            try:
                self._sslobj = self._context._wrap_socket(self._sock, server_side,
                                                          server_hostname, ssl_sock=self)
                if do_handshake_on_connect:
                    timeout = self.gettimeout()
                    if timeout == 0.0:
                        # non-blocking
                        raise ValueError("do_handshake_on_connect should not be specified for non-blocking sockets")
                    self.do_handshake()

            except (OSError, ValueError):
                self.close()
                raise

    @property
    def context(self):
        return self._context

    @context.setter
    def context(self, ctx):
        self._context = ctx
        self._sslobj.context = ctx

    def dup(self):
        raise NotImplementedError("Can't dup() %s instances" %
                                  self.__class__.__name__)

    def _checkClosed(self, msg=None):
        # raise an exception here if you wish to check for spurious closes
        pass

    def _check_connected(self):
        if not self._connected:
            # getpeername() will raise ENOTCONN if the socket is really
            # not connected; note that we can be connected even without
            # _connected being set, e.g. if connect() first returned
            # EAGAIN.
            self.getpeername()

    def read(self, len=1024, buffer=None):
        """Read up to LEN bytes and return them.
        Return zero-length string on EOF."""

        self._checkClosed()
        if not self._sslobj:
            raise ValueError("Read on closed or unwrapped SSL socket.")
        try:
            if buffer is not None:
                v = self._sslobj.read(len, buffer)
            else:
                v = self._sslobj.read(len)
            return v
        except SSLError as x:
            if x.args[0] == SSL_ERROR_EOF and self.suppress_ragged_eofs:
                if buffer is not None:
                    return 0
                else:
                    return b''
            else:
                raise

    def write(self, data):
        """Write DATA to the underlying SSL channel.  Returns
        number of bytes of DATA actually transmitted."""

        self._checkClosed()
        if not self._sslobj:
            raise ValueError("Write on closed or unwrapped SSL socket.")
        return self._sslobj.write(data)

    def getpeercert(self, binary_form=False):
        """Returns a formatted version of the data in the
        certificate provided by the other end of the SSL channel.
        Return None if no certificate was provided, {} if a
        certificate was provided, but not validated."""

        self._checkClosed()
        self._check_connected()
        return self._sslobj.peer_certificate(binary_form)

    def selected_npn_protocol(self):
        self._checkClosed()
        if not self._sslobj or not _ssl.HAS_NPN:
            return None
        else:
            return self._sslobj.selected_npn_protocol()

    def selected_alpn_protocol(self):
        self._checkClosed()
        if not self._sslobj or not _ssl.HAS_ALPN:
            return None
        else:
            return self._sslobj.selected_alpn_protocol()

    def cipher(self):
        self._checkClosed()
        if not self._sslobj:
            return None
        else:
            return self._sslobj.cipher()

    def compression(self):
        self._checkClosed()
        if not self._sslobj:
            return None
        else:
            return self._sslobj.compression()

    def send(self, data, flags=0):
        self._checkClosed()
        if self._sslobj:
            if flags != 0:
                raise ValueError(
                    "non-zero flags not allowed in calls to send() on %s" %
                    self.__class__)
            try:
                v = self._sslobj.write(data)
            except SSLError as x:
                if x.args[0] == SSL_ERROR_WANT_READ:
                    return 0
                elif x.args[0] == SSL_ERROR_WANT_WRITE:
                    return 0
                else:
                    raise
            else:
                return v
        else:
            return self._sock.send(data, flags)

    def sendto(self, data, flags_or_addr, addr=None):
        self._checkClosed()
        if self._sslobj:
            raise ValueError("sendto not allowed on instances of %s" %
                             self.__class__)
        elif addr is None:
            return self._sock.sendto(data, flags_or_addr)
        else:
            return self._sock.sendto(data, flags_or_addr, addr)


    def sendall(self, data, flags=0):
        self._checkClosed()
        if self._sslobj:
            if flags != 0:
                raise ValueError(
                    "non-zero flags not allowed in calls to sendall() on %s" %
                    self.__class__)
            amount = len(data)
            count = 0
            while (count < amount):
                v = self.send(data[count:])
                count += v
            return amount
        else:
            return socket.sendall(self, data, flags)

    def recv(self, buflen=1024, flags=0):
        self._checkClosed()
        if self._sslobj:
            if flags != 0:
                raise ValueError(
                    "non-zero flags not allowed in calls to recv() on %s" %
                    self.__class__)
            return self.read(buflen)
        else:
            return self._sock.recv(buflen, flags)

    def recv_into(self, buffer, nbytes=None, flags=0):
        self._checkClosed()
        if buffer and (nbytes is None):
            nbytes = len(buffer)
        elif nbytes is None:
            nbytes = 1024
        if self._sslobj:
            if flags != 0:
                raise ValueError(
                  "non-zero flags not allowed in calls to recv_into() on %s" %
                  self.__class__)
            return self.read(nbytes, buffer)
        else:
            return self._sock.recv_into(buffer, nbytes, flags)

    def recvfrom(self, buflen=1024, flags=0):
        self._checkClosed()
        if self._sslobj:
            raise ValueError("recvfrom not allowed on instances of %s" %
                             self.__class__)
        else:
            return self._sock.recvfrom(buflen, flags)

    def recvfrom_into(self, buffer, nbytes=None, flags=0):
        self._checkClosed()
        if self._sslobj:
            raise ValueError("recvfrom_into not allowed on instances of %s" %
                             self.__class__)
        else:
            return self._sock.recvfrom_into(buffer, nbytes, flags)


    def pending(self):
        self._checkClosed()
        if self._sslobj:
            return self._sslobj.pending()
        else:
            return 0

    def shutdown(self, how):
        self._checkClosed()
        self._sslobj = None
        socket.shutdown(self, how)

    def close(self):
        if self._makefile_refs < 1:
            self._sslobj = None
            socket.close(self)
        else:
            self._makefile_refs -= 1

    def unwrap(self):
        if self._sslobj:
            s = self._sslobj.shutdown()
            self._sslobj = None
            return s
        else:
            raise ValueError("No SSL wrapper around " + str(self))

    def _real_close(self):
        self._sslobj = None
        socket._real_close(self)

    def do_handshake(self, block=False):
        """Perform a TLS/SSL handshake."""
        self._check_connected()
        timeout = self.gettimeout()
        try:
            if timeout == 0.0 and block:
                self.settimeout(None)
            self._sslobj.do_handshake()
        finally:
            self.settimeout(timeout)

        if self.context.check_hostname:
            if not self.server_hostname:
                raise ValueError("check_hostname needs server_hostname "
                                 "argument")
            match_hostname(self.getpeercert(), self.server_hostname)

    def _real_connect(self, addr, connect_ex):
        if self.server_side:
            raise ValueError("can't connect in server-side mode")
        # Here we assume that the socket is client-side, and not
        # connected at the time of the call.  We connect it, then wrap it.
        if self._connected:
            raise ValueError("attempt to connect already-connected SSLSocket!")
        self._sslobj = self.context._wrap_socket(self._sock, False, self.server_hostname, ssl_sock=self)
        try:
            if connect_ex:
                rc = socket.connect_ex(self, addr)
            else:
                rc = None
                socket.connect(self, addr)
            if not rc:
                self._connected = True
                if self.do_handshake_on_connect:
                    self.do_handshake()
            return rc
        except (OSError, ValueError):
            self._sslobj = None
            raise

    def connect(self, addr):
        """Connects to remote ADDR, and then wraps the connection in
        an SSL channel."""
        self._real_connect(addr, False)

    def connect_ex(self, addr):
        """Connects to remote ADDR, and then wraps the connection in
        an SSL channel."""
        return self._real_connect(addr, True)

    def accept(self):
        """Accepts a new connection from a remote client, and returns
        a tuple containing that new connection wrapped with a server-side
        SSL channel, and the address of the remote client."""

        newsock, addr = socket.accept(self)
        newsock = self.context.wrap_socket(newsock,
                    do_handshake_on_connect=self.do_handshake_on_connect,
                    suppress_ragged_eofs=self.suppress_ragged_eofs,
                    server_side=True)
        return newsock, addr

    def makefile(self, mode='r', bufsize=-1):

        """Make and return a file-like object that
        works with the SSL connection.  Just use the code
        from the socket module."""

        self._makefile_refs += 1
        # close=True so as to decrement the reference count when done with
        # the file-like object.
        return _fileobject(self, mode, bufsize, close=True)

    def get_channel_binding(self, cb_type="tls-unique"):
        """Get channel binding data for current connection.  Raise ValueError
        if the requested `cb_type` is not supported.  Return bytes of the data
        or None if the data is not available (e.g. before the handshake).
        """
        if cb_type not in CHANNEL_BINDING_TYPES:
            raise ValueError("Unsupported channel binding type")
        if cb_type != "tls-unique":
            raise NotImplementedError(
                            "{0} channel binding type not implemented"
                            .format(cb_type))
        if self._sslobj is None:
            return None
        return self._sslobj.tls_unique_cb()

    def version(self):
        """
        Return a string identifying the protocol version used by the
        current SSL channel, or None if there is no established channel.
        """
        if self._sslobj is None:
            return None
        return self._sslobj.version()


def wrap_socket(sock, keyfile=None, certfile=None,
                server_side=False, cert_reqs=CERT_NONE,
                ssl_version=PROTOCOL_TLS, ca_certs=None,
                do_handshake_on_connect=True,
                suppress_ragged_eofs=True,
                ciphers=None):

    return SSLSocket(sock=sock, keyfile=keyfile, certfile=certfile,
                     server_side=server_side, cert_reqs=cert_reqs,
                     ssl_version=ssl_version, ca_certs=ca_certs,
                     do_handshake_on_connect=do_handshake_on_connect,
                     suppress_ragged_eofs=suppress_ragged_eofs,
                     ciphers=ciphers)

# some utility functions

def cert_time_to_seconds(cert_time):
    """Return the time in seconds since the Epoch, given the timestring
    representing the "notBefore" or "notAfter" date from a certificate
    in ``"%b %d %H:%M:%S %Y %Z"`` strptime format (C locale).

    "notBefore" or "notAfter" dates must use UTC (RFC 5280).

    Month is one of: Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec
    UTC should be specified as GMT (see ASN1_TIME_print())
    """
    from time import strptime
    from calendar import timegm

    months = (
        "Jan","Feb","Mar","Apr","May","Jun",
        "Jul","Aug","Sep","Oct","Nov","Dec"
    )
    time_format = ' %d %H:%M:%S %Y GMT' # NOTE: no month, fixed GMT
    try:
        month_number = months.index(cert_time[:3].title()) + 1
    except ValueError:
        raise ValueError('time data %r does not match '
                         'format "%%b%s"' % (cert_time, time_format))
    else:
        # found valid month
        tt = strptime(cert_time[3:], time_format)
        # return an integer, the previous mktime()-based implementation
        # returned a float (fractional seconds are always zero here).
        return timegm((tt[0], month_number) + tt[2:6])

PEM_HEADER = "-----BEGIN CERTIFICATE-----"
PEM_FOOTER = "-----END CERTIFICATE-----"

def DER_cert_to_PEM_cert(der_cert_bytes):
    """Takes a certificate in binary DER format and returns the
    PEM version of it as a string."""

    f = base64.standard_b64encode(der_cert_bytes).decode('ascii')
    return (PEM_HEADER + '\n' +
            textwrap.fill(f, 64) + '\n' +
            PEM_FOOTER + '\n')

def PEM_cert_to_DER_cert(pem_cert_string):
    """Takes a certificate in ASCII PEM format and returns the
    DER-encoded version of it as a byte sequence"""

    if not pem_cert_string.startswith(PEM_HEADER):
        raise ValueError("Invalid PEM encoding; must start with %s"
                         % PEM_HEADER)
    if not pem_cert_string.strip().endswith(PEM_FOOTER):
        raise ValueError("Invalid PEM encoding; must end with %s"
                         % PEM_FOOTER)
    d = pem_cert_string.strip()[len(PEM_HEADER):-len(PEM_FOOTER)]
    return base64.decodestring(d.encode('ASCII', 'strict'))

def get_server_certificate(addr, ssl_version=PROTOCOL_TLS, ca_certs=None):
    """Retrieve the certificate from the server at the specified address,
    and return it as a PEM-encoded string.
    If 'ca_certs' is specified, validate the server cert against it.
    If 'ssl_version' is specified, use it in the connection attempt."""

    host, port = addr
    if ca_certs is not None:
        cert_reqs = CERT_REQUIRED
    else:
        cert_reqs = CERT_NONE
    context = _create_stdlib_context(ssl_version,
                                     cert_reqs=cert_reqs,
                                     cafile=ca_certs)
    with closing(create_connection(addr)) as sock:
        with closing(context.wrap_socket(sock)) as sslsock:
            dercert = sslsock.getpeercert(True)
    return DER_cert_to_PEM_cert(dercert)

def get_protocol_name(protocol_code):
    return _PROTOCOL_NAMES.get(protocol_code, '<unknown>')


# a replacement for the old socket.ssl function

def sslwrap_simple(sock, keyfile=None, certfile=None):
    """A replacement for the old socket.ssl function.  Designed
    for compability with Python 2.5 and earlier.  Will disappear in
    Python 3.0."""
    if hasattr(sock, "_sock"):
        sock = sock._sock

    ctx = SSLContext(PROTOCOL_SSLv23)
    if keyfile or certfile:
        ctx.load_cert_chain(certfile, keyfile)
    ssl_sock = ctx._wrap_socket(sock, server_side=False)
    try:
        sock.getpeername()
    except socket_error:
        # no, no connection yet
        pass
    else:
        # yes, do the handshake
        ssl_sock.do_handshake()

    return ssl_sock

SILENT KILLER Tool