Current Path: > > lib64 > python2.7
Operation : Linux premium107.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 : 198.54.126.246 | Your IP: 216.73.216.181 Domains : 1034 Domain(s) Permission : [ 0755 ]
| Name | Type | Size | Last Modified | Actions |
|---|---|---|---|---|
| Demo | Directory | - | - | |
| Doc | Directory | - | - | |
| Tools | Directory | - | - | |
| bsddb | Directory | - | - | |
| compiler | Directory | - | - | |
| config | Directory | - | - | |
| ctypes | Directory | - | - | |
| curses | Directory | - | - | |
| distutils | Directory | - | - | |
| Directory | - | - | ||
| encodings | Directory | - | - | |
| ensurepip | Directory | - | - | |
| hotshot | Directory | - | - | |
| idlelib | Directory | - | - | |
| importlib | Directory | - | - | |
| json | Directory | - | - | |
| lib-dynload | Directory | - | - | |
| lib-tk | 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 | April 10 2024 04:58:34. | |
| BaseHTTPServer.pyc | File | 21722 bytes | April 10 2024 04:58:47. | |
| BaseHTTPServer.pyo | File | 21722 bytes | April 10 2024 04:58:47. | |
| Bastion.py | File | 5744 bytes | April 10 2024 04:58:34. | |
| Bastion.pyc | File | 6660 bytes | April 10 2024 04:58:47. | |
| Bastion.pyo | File | 6660 bytes | April 10 2024 04:58:47. | |
| CGIHTTPServer.py | File | 13089 bytes | April 10 2024 04:58:34. | |
| CGIHTTPServer.pyc | File | 11018 bytes | April 10 2024 04:58:47. | |
| CGIHTTPServer.pyo | File | 11018 bytes | April 10 2024 04:58:47. | |
| ConfigParser.py | File | 27746 bytes | April 10 2024 04:58:34. | |
| ConfigParser.pyc | File | 25213 bytes | April 10 2024 04:58:47. | |
| ConfigParser.pyo | File | 25213 bytes | April 10 2024 04:58:47. | |
| Cookie.py | File | 26538 bytes | April 10 2024 04:58:34. | |
| Cookie.pyc | File | 22658 bytes | April 10 2024 04:58:47. | |
| Cookie.pyo | File | 22658 bytes | April 10 2024 04:58:47. | |
| DocXMLRPCServer.py | File | 10768 bytes | April 10 2024 04:58:34. | |
| DocXMLRPCServer.pyc | File | 10195 bytes | April 10 2024 04:58:47. | |
| DocXMLRPCServer.pyo | File | 10086 bytes | April 10 2024 04:58:44. | |
| HTMLParser.py | File | 17171 bytes | April 10 2024 04:58:34. | |
| HTMLParser.pyc | File | 13727 bytes | April 10 2024 04:58:47. | |
| HTMLParser.pyo | File | 13422 bytes | April 10 2024 04:58:44. | |
| MimeWriter.py | File | 6482 bytes | April 10 2024 04:58:34. | |
| MimeWriter.pyc | File | 7364 bytes | April 10 2024 04:58:47. | |
| MimeWriter.pyo | File | 7364 bytes | April 10 2024 04:58:47. | |
| Queue.py | File | 8577 bytes | April 10 2024 04:58:34. | |
| Queue.pyc | File | 9424 bytes | April 10 2024 04:58:47. | |
| Queue.pyo | File | 9424 bytes | April 10 2024 04:58:47. | |
| SimpleHTTPServer.py | File | 7997 bytes | April 10 2024 04:58:34. | |
| SimpleHTTPServer.pyc | File | 8010 bytes | April 10 2024 04:58:47. | |
| SimpleHTTPServer.pyo | File | 8010 bytes | April 10 2024 04:58:47. | |
| SimpleXMLRPCServer.py | File | 25812 bytes | April 10 2024 04:58:34. | |
| SimpleXMLRPCServer.pyc | File | 22863 bytes | April 10 2024 04:58:47. | |
| SimpleXMLRPCServer.pyo | File | 22863 bytes | April 10 2024 04:58:47. | |
| SocketServer.py | File | 23948 bytes | April 10 2024 04:58:34. | |
| SocketServer.pyc | File | 24087 bytes | April 10 2024 04:58:47. | |
| SocketServer.pyo | File | 24087 bytes | April 10 2024 04:58:47. | |
| StringIO.py | File | 10662 bytes | April 10 2024 04:58:34. | |
| StringIO.pyc | File | 11480 bytes | April 10 2024 04:58:47. | |
| StringIO.pyo | File | 11480 bytes | April 10 2024 04:58:47. | |
| UserDict.py | File | 7060 bytes | April 10 2024 04:58:34. | |
| UserDict.pyc | File | 9711 bytes | April 10 2024 04:58:47. | |
| UserDict.pyo | File | 9711 bytes | April 10 2024 04:58:47. | |
| UserList.py | File | 3644 bytes | April 10 2024 04:58:34. | |
| UserList.pyc | File | 6577 bytes | April 10 2024 04:58:47. | |
| UserList.pyo | File | 6577 bytes | April 10 2024 04:58:47. | |
| UserString.py | File | 9687 bytes | April 10 2024 04:58:34. | |
| UserString.pyc | File | 14864 bytes | April 10 2024 04:58:47. | |
| UserString.pyo | File | 14864 bytes | April 10 2024 04:58:47. | |
| _LWPCookieJar.py | File | 6553 bytes | April 10 2024 04:58:34. | |
| _LWPCookieJar.pyc | File | 5434 bytes | April 10 2024 04:58:47. | |
| _LWPCookieJar.pyo | File | 5434 bytes | April 10 2024 04:58:47. | |
| _MozillaCookieJar.py | File | 5797 bytes | April 10 2024 04:58:34. | |
| _MozillaCookieJar.pyc | File | 4461 bytes | April 10 2024 04:58:47. | |
| _MozillaCookieJar.pyo | File | 4422 bytes | April 10 2024 04:58:44. | |
| __future__.py | File | 4380 bytes | April 10 2024 04:58:34. | |
| __future__.pyc | File | 4223 bytes | April 10 2024 04:58:47. | |
| __future__.pyo | File | 4223 bytes | April 10 2024 04:58:47. | |
| __phello__.foo.py | File | 64 bytes | April 10 2024 04:58:34. | |
| __phello__.foo.pyc | File | 125 bytes | April 10 2024 04:58:47. | |
| __phello__.foo.pyo | File | 125 bytes | April 10 2024 04:58:47. | |
| _abcoll.py | File | 18619 bytes | April 10 2024 04:58:34. | |
| _abcoll.pyc | File | 25682 bytes | April 10 2024 04:58:47. | |
| _abcoll.pyo | File | 25682 bytes | April 10 2024 04:58:47. | |
| _osx_support.py | File | 19100 bytes | April 10 2024 04:58:34. | |
| _osx_support.pyc | File | 11758 bytes | April 10 2024 04:58:47. | |
| _osx_support.pyo | File | 11758 bytes | April 10 2024 04:58:47. | |
| _pyio.py | File | 69630 bytes | April 10 2024 04:58:34. | |
| _pyio.pyc | File | 64701 bytes | April 10 2024 04:58:47. | |
| _pyio.pyo | File | 64701 bytes | April 10 2024 04:58:47. | |
| _strptime.py | File | 20728 bytes | April 10 2024 04:58:34. | |
| _strptime.pyc | File | 15172 bytes | April 10 2024 04:58:47. | |
| _strptime.pyo | File | 15172 bytes | April 10 2024 04:58:47. | |
| _sysconfigdata.py | File | 19732 bytes | April 10 2024 04:58:34. | |
| _sysconfigdata.pyc | File | 22968 bytes | April 10 2024 04:58:46. | |
| _sysconfigdata.pyo | File | 22968 bytes | April 10 2024 04:58:46. | |
| _threading_local.py | File | 7260 bytes | April 10 2024 04:58:34. | |
| _threading_local.pyc | File | 6373 bytes | April 10 2024 04:58:47. | |
| _threading_local.pyo | File | 6373 bytes | April 10 2024 04:58:47. | |
| _weakrefset.py | File | 5911 bytes | April 10 2024 04:58:34. | |
| _weakrefset.pyc | File | 9678 bytes | April 10 2024 04:58:47. | |
| _weakrefset.pyo | File | 9678 bytes | April 10 2024 04:58:47. | |
| abc.py | File | 7145 bytes | April 10 2024 04:58:34. | |
| abc.pyc | File | 6143 bytes | April 10 2024 04:58:47. | |
| abc.pyo | File | 6087 bytes | April 10 2024 04:58:44. | |
| aifc.py | File | 34579 bytes | April 10 2024 04:58:34. | |
| aifc.pyc | File | 30459 bytes | April 10 2024 04:58:47. | |
| aifc.pyo | File | 30459 bytes | April 10 2024 04:58:47. | |
| antigravity.py | File | 60 bytes | April 10 2024 04:58:34. | |
| antigravity.pyc | File | 203 bytes | April 10 2024 04:58:47. | |
| antigravity.pyo | File | 203 bytes | April 10 2024 04:58:47. | |
| anydbm.py | File | 2663 bytes | April 10 2024 04:58:34. | |
| anydbm.pyc | File | 2800 bytes | April 10 2024 04:58:47. | |
| anydbm.pyo | File | 2800 bytes | April 10 2024 04:58:47. | |
| argparse.py | File | 89228 bytes | April 10 2024 04:58:34. | |
| argparse.pyc | File | 64367 bytes | April 10 2024 04:58:47. | |
| argparse.pyo | File | 64202 bytes | April 10 2024 04:58:44. | |
| ast.py | File | 11805 bytes | April 10 2024 04:58:34. | |
| ast.pyc | File | 12938 bytes | April 10 2024 04:58:47. | |
| ast.pyo | File | 12938 bytes | April 10 2024 04:58:47. | |
| asynchat.py | File | 11581 bytes | April 10 2024 04:58:34. | |
| asynchat.pyc | File | 8810 bytes | April 10 2024 04:58:47. | |
| asynchat.pyo | File | 8810 bytes | April 10 2024 04:58:47. | |
| asyncore.py | File | 20943 bytes | April 10 2024 04:58:34. | |
| asyncore.pyc | File | 18893 bytes | April 10 2024 04:58:47. | |
| asyncore.pyo | File | 18893 bytes | April 10 2024 04:58:47. | |
| atexit.py | File | 1705 bytes | April 10 2024 04:58:34. | |
| atexit.pyc | File | 2203 bytes | April 10 2024 04:58:47. | |
| atexit.pyo | File | 2203 bytes | April 10 2024 04:58:47. | |
| audiodev.py | File | 7597 bytes | April 10 2024 04:58:34. | |
| audiodev.pyc | File | 8469 bytes | April 10 2024 04:58:47. | |
| audiodev.pyo | File | 8469 bytes | April 10 2024 04:58:47. | |
| base64.py | File | 11806 bytes | April 10 2024 04:58:34. | |
| base64.pyc | File | 11297 bytes | April 10 2024 04:58:47. | |
| base64.pyo | File | 11297 bytes | April 10 2024 04:58:47. | |
| bdb.py | File | 21714 bytes | April 10 2024 04:58:34. | |
| bdb.pyc | File | 19101 bytes | April 10 2024 04:58:47. | |
| bdb.pyo | File | 19101 bytes | April 10 2024 04:58:47. | |
| binhex.py | File | 14698 bytes | April 10 2024 04:58:34. | |
| binhex.pyc | File | 15460 bytes | April 10 2024 04:58:47. | |
| binhex.pyo | File | 15460 bytes | April 10 2024 04:58:47. | |
| bisect.py | File | 2595 bytes | April 10 2024 04:58:34. | |
| bisect.pyc | File | 3071 bytes | April 10 2024 04:58:47. | |
| bisect.pyo | File | 3071 bytes | April 10 2024 04:58:47. | |
| cProfile.py | File | 6573 bytes | April 10 2024 04:58:34. | |
| cProfile.pyc | File | 6395 bytes | April 10 2024 04:58:47. | |
| cProfile.pyo | File | 6395 bytes | April 10 2024 04:58:47. | |
| calendar.py | File | 23384 bytes | April 10 2024 04:58:34. | |
| calendar.pyc | File | 27913 bytes | April 10 2024 04:58:47. | |
| calendar.pyo | File | 27913 bytes | April 10 2024 04:58:47. | |
| cgi.py | File | 36308 bytes | April 10 2024 04:58:34. | |
| cgi.pyc | File | 33366 bytes | April 10 2024 04:58:47. | |
| cgi.pyo | File | 33366 bytes | April 10 2024 04:58:47. | |
| cgitb.py | File | 12175 bytes | April 10 2024 04:58:34. | |
| cgitb.pyc | File | 12138 bytes | April 10 2024 04:58:47. | |
| cgitb.pyo | File | 12138 bytes | April 10 2024 04:58:47. | |
| chunk.py | File | 5419 bytes | April 10 2024 04:58:34. | |
| chunk.pyc | File | 5602 bytes | April 10 2024 04:58:47. | |
| chunk.pyo | File | 5602 bytes | April 10 2024 04:58:47. | |
| cmd.py | File | 15026 bytes | April 10 2024 04:58:34. | |
| cmd.pyc | File | 14039 bytes | April 10 2024 04:58:47. | |
| cmd.pyo | File | 14039 bytes | April 10 2024 04:58:47. | |
| code.py | File | 10189 bytes | April 10 2024 04:58:34. | |
| code.pyc | File | 10334 bytes | April 10 2024 04:58:47. | |
| code.pyo | File | 10334 bytes | April 10 2024 04:58:47. | |
| codecs.py | File | 36143 bytes | April 10 2024 04:58:34. | |
| codecs.pyc | File | 36824 bytes | April 10 2024 04:58:47. | |
| codecs.pyo | File | 36824 bytes | April 10 2024 04:58:47. | |
| codeop.py | File | 5999 bytes | April 10 2024 04:58:34. | |
| codeop.pyc | File | 6597 bytes | April 10 2024 04:58:47. | |
| codeop.pyo | File | 6597 bytes | April 10 2024 04:58:47. | |
| collections.py | File | 27798 bytes | April 10 2024 04:58:34. | |
| collections.pyc | File | 26163 bytes | April 10 2024 04:58:47. | |
| collections.pyo | File | 26112 bytes | April 10 2024 04:58:44. | |
| colorsys.py | File | 3691 bytes | April 10 2024 04:58:34. | |
| colorsys.pyc | File | 3991 bytes | April 10 2024 04:58:47. | |
| colorsys.pyo | File | 3991 bytes | April 10 2024 04:58:47. | |
| commands.py | File | 2545 bytes | April 10 2024 04:58:34. | |
| commands.pyc | File | 2469 bytes | April 10 2024 04:58:47. | |
| commands.pyo | File | 2469 bytes | April 10 2024 04:58:47. | |
| compileall.py | File | 7763 bytes | April 10 2024 04:58:34. | |
| compileall.pyc | File | 7017 bytes | April 10 2024 04:58:47. | |
| compileall.pyo | File | 7017 bytes | April 10 2024 04:58:47. | |
| contextlib.py | File | 4424 bytes | April 10 2024 04:58:34. | |
| contextlib.pyc | File | 4454 bytes | April 10 2024 04:58:47. | |
| contextlib.pyo | File | 4454 bytes | April 10 2024 04:58:47. | |
| cookielib.py | File | 65486 bytes | April 10 2024 04:58:34. | |
| cookielib.pyc | File | 54725 bytes | April 10 2024 04:58:47. | |
| cookielib.pyo | File | 54537 bytes | April 10 2024 04:58:44. | |
| copy.py | File | 11533 bytes | April 10 2024 04:58:34. | |
| copy.pyc | File | 12170 bytes | April 10 2024 04:58:47. | |
| copy.pyo | File | 12078 bytes | April 10 2024 04:58:44. | |
| copy_reg.py | File | 6974 bytes | April 10 2024 04:58:34. | |
| copy_reg.pyc | File | 5167 bytes | April 10 2024 04:58:47. | |
| copy_reg.pyo | File | 5123 bytes | April 10 2024 04:58:44. | |
| crypt.py | File | 2292 bytes | April 10 2024 04:58:34. | |
| crypt.pyc | File | 2960 bytes | April 10 2024 04:58:47. | |
| crypt.pyo | File | 2960 bytes | April 10 2024 04:58:47. | |
| csv.py | File | 16708 bytes | April 10 2024 04:58:34. | |
| csv.pyc | File | 13507 bytes | April 10 2024 04:58:47. | |
| csv.pyo | File | 13507 bytes | April 10 2024 04:58:47. | |
| dbhash.py | File | 498 bytes | April 10 2024 04:58:34. | |
| dbhash.pyc | File | 718 bytes | April 10 2024 04:58:47. | |
| dbhash.pyo | File | 718 bytes | April 10 2024 04:58:47. | |
| decimal.py | File | 221933 bytes | April 10 2024 04:58:34. | |
| decimal.pyc | File | 172155 bytes | April 10 2024 04:58:47. | |
| decimal.pyo | File | 172155 bytes | April 10 2024 04:58:47. | |
| difflib.py | File | 82325 bytes | April 10 2024 04:58:34. | |
| difflib.pyc | File | 61898 bytes | April 10 2024 04:58:47. | |
| difflib.pyo | File | 61847 bytes | April 10 2024 04:58:44. | |
| dircache.py | File | 1126 bytes | April 10 2024 04:58:34. | |
| dircache.pyc | File | 1576 bytes | April 10 2024 04:58:47. | |
| dircache.pyo | File | 1576 bytes | April 10 2024 04:58:47. | |
| dis.py | File | 6499 bytes | April 10 2024 04:58:34. | |
| dis.pyc | File | 6228 bytes | April 10 2024 04:58:47. | |
| dis.pyo | File | 6228 bytes | April 10 2024 04:58:47. | |
| doctest.py | File | 105095 bytes | April 10 2024 04:58:34. | |
| doctest.pyc | File | 83637 bytes | April 10 2024 04:58:47. | |
| doctest.pyo | File | 83350 bytes | April 10 2024 04:58:44. | |
| dumbdbm.py | File | 9141 bytes | April 10 2024 04:58:34. | |
| dumbdbm.pyc | File | 6746 bytes | April 10 2024 04:58:47. | |
| dumbdbm.pyo | File | 6746 bytes | April 10 2024 04:58:47. | |
| dummy_thread.py | File | 4418 bytes | April 10 2024 04:58:34. | |
| dummy_thread.pyc | File | 5394 bytes | April 10 2024 04:58:47. | |
| dummy_thread.pyo | File | 5394 bytes | April 10 2024 04:58:47. | |
| dummy_threading.py | File | 2804 bytes | April 10 2024 04:58:34. | |
| dummy_threading.pyc | File | 1285 bytes | April 10 2024 04:58:47. | |
| dummy_threading.pyo | File | 1285 bytes | April 10 2024 04:58:47. | |
| filecmp.py | File | 9588 bytes | April 10 2024 04:58:34. | |
| filecmp.pyc | File | 9622 bytes | April 10 2024 04:58:47. | |
| filecmp.pyo | File | 9622 bytes | April 10 2024 04:58:47. | |
| fileinput.py | File | 13746 bytes | April 10 2024 04:58:34. | |
| fileinput.pyc | File | 14500 bytes | April 10 2024 04:58:47. | |
| fileinput.pyo | File | 14500 bytes | April 10 2024 04:58:47. | |
| fnmatch.py | File | 3315 bytes | April 10 2024 04:58:34. | |
| fnmatch.pyc | File | 3614 bytes | April 10 2024 04:58:47. | |
| fnmatch.pyo | File | 3614 bytes | April 10 2024 04:58:47. | |
| formatter.py | File | 14911 bytes | April 10 2024 04:58:34. | |
| formatter.pyc | File | 19178 bytes | April 10 2024 04:58:47. | |
| formatter.pyo | File | 19178 bytes | April 10 2024 04:58:47. | |
| fpformat.py | File | 4732 bytes | April 10 2024 04:58:34. | |
| fpformat.pyc | File | 4703 bytes | April 10 2024 04:58:47. | |
| fpformat.pyo | File | 4703 bytes | April 10 2024 04:58:47. | |
| fractions.py | File | 22390 bytes | April 10 2024 04:58:34. | |
| fractions.pyc | File | 19711 bytes | April 10 2024 04:58:47. | |
| fractions.pyo | File | 19711 bytes | April 10 2024 04:58:47. | |
| ftplib.py | File | 38555 bytes | April 10 2024 04:58:34. | |
| ftplib.pyc | File | 34939 bytes | April 10 2024 04:58:47. | |
| ftplib.pyo | File | 34939 bytes | April 10 2024 04:58:47. | |
| functools.py | File | 4806 bytes | April 10 2024 04:58:34. | |
| functools.pyc | File | 6629 bytes | April 10 2024 04:58:47. | |
| functools.pyo | File | 6629 bytes | April 10 2024 04:58:47. | |
| genericpath.py | File | 3201 bytes | April 10 2024 04:58:34. | |
| genericpath.pyc | File | 3517 bytes | April 10 2024 04:58:47. | |
| genericpath.pyo | File | 3517 bytes | April 10 2024 04:58:47. | |
| getopt.py | File | 7319 bytes | April 10 2024 04:58:34. | |
| getopt.pyc | File | 6654 bytes | April 10 2024 04:58:47. | |
| getopt.pyo | File | 6609 bytes | April 10 2024 04:58:44. | |
| getpass.py | File | 5563 bytes | April 10 2024 04:58:34. | |
| getpass.pyc | File | 4744 bytes | April 10 2024 04:58:47. | |
| getpass.pyo | File | 4744 bytes | April 10 2024 04:58:47. | |
| gettext.py | File | 22666 bytes | April 10 2024 04:58:34. | |
| gettext.pyc | File | 18004 bytes | April 10 2024 04:58:47. | |
| gettext.pyo | File | 18004 bytes | April 10 2024 04:58:47. | |
| glob.py | File | 3114 bytes | April 10 2024 04:58:34. | |
| glob.pyc | File | 2943 bytes | April 10 2024 04:58:47. | |
| glob.pyo | File | 2943 bytes | April 10 2024 04:58:47. | |
| gzip.py | File | 19028 bytes | April 10 2024 04:58:34. | |
| gzip.pyc | File | 15236 bytes | April 10 2024 04:58:47. | |
| gzip.pyo | File | 15236 bytes | April 10 2024 04:58:47. | |
| hashlib.py | File | 7841 bytes | April 10 2024 04:58:34. | |
| hashlib.pyc | File | 6919 bytes | April 10 2024 04:58:47. | |
| hashlib.pyo | File | 6919 bytes | April 10 2024 04:58:47. | |
| heapq.py | File | 18295 bytes | April 10 2024 04:58:34. | |
| heapq.pyc | File | 14564 bytes | April 10 2024 04:58:47. | |
| heapq.pyo | File | 14564 bytes | April 10 2024 04:58:47. | |
| hmac.py | File | 4588 bytes | April 10 2024 04:58:34. | |
| hmac.pyc | File | 4542 bytes | April 10 2024 04:58:47. | |
| hmac.pyo | File | 4542 bytes | April 10 2024 04:58:47. | |
| htmlentitydefs.py | File | 18056 bytes | April 10 2024 04:58:34. | |
| htmlentitydefs.pyc | File | 6367 bytes | April 10 2024 04:58:47. | |
| htmlentitydefs.pyo | File | 6367 bytes | April 10 2024 04:58:47. | |
| htmllib.py | File | 12869 bytes | April 10 2024 04:58:34. | |
| htmllib.pyc | File | 20309 bytes | April 10 2024 04:58:47. | |
| htmllib.pyo | File | 20309 bytes | April 10 2024 04:58:47. | |
| httplib.py | File | 53306 bytes | April 10 2024 04:58:34. | |
| httplib.pyc | File | 38724 bytes | April 10 2024 04:58:47. | |
| httplib.pyo | File | 38540 bytes | April 10 2024 04:58:44. | |
| ihooks.py | File | 18986 bytes | April 10 2024 04:58:34. | |
| ihooks.pyc | File | 21372 bytes | April 10 2024 04:58:47. | |
| ihooks.pyo | File | 21372 bytes | April 10 2024 04:58:47. | |
| imaplib.py | File | 48366 bytes | April 10 2024 04:58:34. | |
| imaplib.pyc | File | 45011 bytes | April 10 2024 04:58:47. | |
| imaplib.pyo | File | 42310 bytes | April 10 2024 04:58:44. | |
| imghdr.py | File | 3541 bytes | April 10 2024 04:58:34. | |
| imghdr.pyc | File | 4838 bytes | April 10 2024 04:58:47. | |
| imghdr.pyo | File | 4838 bytes | April 10 2024 04:58:47. | |
| imputil.py | File | 25764 bytes | April 10 2024 04:58:34. | |
| imputil.pyc | File | 15623 bytes | April 10 2024 04:58:47. | |
| imputil.pyo | File | 15445 bytes | April 10 2024 04:58:44. | |
| inspect.py | File | 43008 bytes | April 10 2024 04:58:34. | |
| inspect.pyc | File | 40229 bytes | April 10 2024 04:58:47. | |
| inspect.pyo | File | 40229 bytes | April 10 2024 04:58:47. | |
| io.py | File | 3322 bytes | April 10 2024 04:58:34. | |
| io.pyc | File | 3589 bytes | April 10 2024 04:58:47. | |
| io.pyo | File | 3589 bytes | April 10 2024 04:58:47. | |
| keyword.py | File | 1995 bytes | April 10 2024 04:58:34. | |
| keyword.pyc | File | 2105 bytes | April 10 2024 04:58:47. | |
| keyword.pyo | File | 2105 bytes | April 10 2024 04:58:47. | |
| linecache.py | File | 4027 bytes | April 10 2024 04:58:34. | |
| linecache.pyc | File | 3272 bytes | April 10 2024 04:58:47. | |
| linecache.pyo | File | 3272 bytes | April 10 2024 04:58:47. | |
| locale.py | File | 102834 bytes | April 10 2024 04:58:34. | |
| locale.pyc | File | 56610 bytes | April 10 2024 04:58:47. | |
| locale.pyo | File | 56610 bytes | April 10 2024 04:58:47. | |
| macpath.py | File | 6289 bytes | April 10 2024 04:58:34. | |
| macpath.pyc | File | 7681 bytes | April 10 2024 04:58:47. | |
| macpath.pyo | File | 7681 bytes | April 10 2024 04:58:47. | |
| macurl2path.py | File | 2731 bytes | April 10 2024 04:58:34. | |
| macurl2path.pyc | File | 2244 bytes | April 10 2024 04:58:47. | |
| macurl2path.pyo | File | 2244 bytes | April 10 2024 04:58:47. | |
| mailbox.py | File | 81240 bytes | April 10 2024 04:58:34. | |
| mailbox.pyc | File | 76717 bytes | April 10 2024 04:58:47. | |
| mailbox.pyo | File | 76670 bytes | April 10 2024 04:58:44. | |
| mailcap.py | File | 8404 bytes | April 10 2024 04:58:34. | |
| mailcap.pyc | File | 7955 bytes | April 10 2024 04:58:47. | |
| mailcap.pyo | File | 7955 bytes | April 10 2024 04:58:47. | |
| markupbase.py | File | 14643 bytes | April 10 2024 04:58:34. | |
| markupbase.pyc | File | 9267 bytes | April 10 2024 04:58:47. | |
| markupbase.pyo | File | 9071 bytes | April 10 2024 04:58:44. | |
| md5.py | File | 358 bytes | April 10 2024 04:58:34. | |
| md5.pyc | File | 378 bytes | April 10 2024 04:58:47. | |
| md5.pyo | File | 378 bytes | April 10 2024 04:58:47. | |
| mhlib.py | File | 33434 bytes | April 10 2024 04:58:34. | |
| mhlib.pyc | File | 33777 bytes | April 10 2024 04:58:47. | |
| mhlib.pyo | File | 33777 bytes | April 10 2024 04:58:47. | |
| mimetools.py | File | 7168 bytes | April 10 2024 04:58:34. | |
| mimetools.pyc | File | 8201 bytes | April 10 2024 04:58:47. | |
| mimetools.pyo | File | 8201 bytes | April 10 2024 04:58:47. | |
| mimetypes.py | File | 21028 bytes | April 10 2024 04:58:34. | |
| mimetypes.pyc | File | 18489 bytes | April 10 2024 04:58:47. | |
| mimetypes.pyo | File | 18489 bytes | April 10 2024 04:58:47. | |
| mimify.py | File | 15020 bytes | April 10 2024 04:58:34. | |
| mimify.pyc | File | 12001 bytes | April 10 2024 04:58:47. | |
| mimify.pyo | File | 12001 bytes | April 10 2024 04:58:47. | |
| modulefinder.py | File | 24461 bytes | April 10 2024 04:58:34. | |
| modulefinder.pyc | File | 19127 bytes | April 10 2024 04:58:47. | |
| modulefinder.pyo | File | 19045 bytes | April 10 2024 04:58:44. | |
| multifile.py | File | 4820 bytes | April 10 2024 04:58:34. | |
| multifile.pyc | File | 5420 bytes | April 10 2024 04:58:47. | |
| multifile.pyo | File | 5378 bytes | April 10 2024 04:58:44. | |
| mutex.py | File | 1878 bytes | April 10 2024 04:58:34. | |
| mutex.pyc | File | 2516 bytes | April 10 2024 04:58:47. | |
| mutex.pyo | File | 2516 bytes | April 10 2024 04:58:47. | |
| netrc.py | File | 5888 bytes | April 10 2024 04:58:34. | |
| netrc.pyc | File | 4714 bytes | April 10 2024 04:58:47. | |
| netrc.pyo | File | 4714 bytes | April 10 2024 04:58:47. | |
| new.py | File | 610 bytes | April 10 2024 04:58:34. | |
| new.pyc | File | 862 bytes | April 10 2024 04:58:47. | |
| new.pyo | File | 862 bytes | April 10 2024 04:58:47. | |
| nntplib.py | File | 21470 bytes | April 10 2024 04:58:34. | |
| nntplib.pyc | File | 21044 bytes | April 10 2024 04:58:47. | |
| nntplib.pyo | File | 21044 bytes | April 10 2024 04:58:47. | |
| ntpath.py | File | 19429 bytes | April 10 2024 04:58:34. | |
| ntpath.pyc | File | 13129 bytes | April 10 2024 04:58:47. | |
| ntpath.pyo | File | 13129 bytes | April 10 2024 04:58:47. | |
| nturl2path.py | File | 2419 bytes | April 10 2024 04:58:34. | |
| nturl2path.pyc | File | 1815 bytes | April 10 2024 04:58:47. | |
| nturl2path.pyo | File | 1815 bytes | April 10 2024 04:58:47. | |
| numbers.py | File | 10319 bytes | April 10 2024 04:58:34. | |
| numbers.pyc | File | 14012 bytes | April 10 2024 04:58:47. | |
| numbers.pyo | File | 14012 bytes | April 10 2024 04:58:47. | |
| opcode.py | File | 5474 bytes | April 10 2024 04:58:34. | |
| opcode.pyc | File | 6145 bytes | April 10 2024 04:58:47. | |
| opcode.pyo | File | 6145 bytes | April 10 2024 04:58:47. | |
| optparse.py | File | 61203 bytes | April 10 2024 04:58:34. | |
| optparse.pyc | File | 53894 bytes | April 10 2024 04:58:47. | |
| optparse.pyo | File | 53811 bytes | April 10 2024 04:58:44. | |
| os.py | File | 25910 bytes | April 10 2024 04:58:34. | |
| os.pyc | File | 25689 bytes | April 10 2024 04:58:47. | |
| os.pyo | File | 25689 bytes | April 10 2024 04:58:47. | |
| os2emxpath.py | File | 4635 bytes | April 10 2024 04:58:34. | |
| os2emxpath.pyc | File | 4525 bytes | April 10 2024 04:58:47. | |
| os2emxpath.pyo | File | 4525 bytes | April 10 2024 04:58:47. | |
| pdb.doc | File | 7914 bytes | April 10 2024 04:58:34. | |
| pdb.py | File | 46098 bytes | April 10 2024 04:58:34. | |
| pdb.pyc | File | 43669 bytes | April 10 2024 04:58:47. | |
| pdb.pyo | File | 43669 bytes | April 10 2024 04:58:47. | |
| pickle.py | File | 45489 bytes | April 10 2024 04:58:34. | |
| pickle.pyc | File | 38560 bytes | April 10 2024 04:58:47. | |
| pickle.pyo | File | 38364 bytes | April 10 2024 04:58:44. | |
| pickletools.py | File | 74523 bytes | April 10 2024 04:58:34. | |
| pickletools.pyc | File | 57032 bytes | April 10 2024 04:58:46. | |
| pickletools.pyo | File | 56171 bytes | April 10 2024 04:58:44. | |
| pipes.py | File | 9582 bytes | April 10 2024 04:58:34. | |
| pipes.pyc | File | 9308 bytes | April 10 2024 04:58:46. | |
| pipes.pyo | File | 9308 bytes | April 10 2024 04:58:46. | |
| pkgutil.py | File | 20243 bytes | April 10 2024 04:58:34. | |
| pkgutil.pyc | File | 18959 bytes | April 10 2024 04:58:46. | |
| pkgutil.pyo | File | 18959 bytes | April 10 2024 04:58:46. | |
| platform.py | File | 52801 bytes | April 10 2024 04:58:34. | |
| platform.pyc | File | 37971 bytes | April 10 2024 04:58:46. | |
| platform.pyo | File | 37971 bytes | April 10 2024 04:58:46. | |
| plistlib.py | File | 15810 bytes | April 10 2024 04:58:34. | |
| plistlib.pyc | File | 19963 bytes | April 10 2024 04:58:46. | |
| plistlib.pyo | File | 19877 bytes | April 10 2024 04:58:44. | |
| popen2.py | File | 8416 bytes | April 10 2024 04:58:34. | |
| popen2.pyc | File | 9025 bytes | April 10 2024 04:58:46. | |
| popen2.pyo | File | 8983 bytes | April 10 2024 04:58:44. | |
| poplib.py | File | 12824 bytes | April 10 2024 04:58:34. | |
| poplib.pyc | File | 13345 bytes | April 10 2024 04:58:46. | |
| poplib.pyo | File | 13345 bytes | April 10 2024 04:58:46. | |
| posixfile.py | File | 8003 bytes | April 10 2024 04:58:34. | |
| posixfile.pyc | File | 7652 bytes | April 10 2024 04:58:46. | |
| posixfile.pyo | File | 7652 bytes | April 10 2024 04:58:46. | |
| posixpath.py | File | 14293 bytes | April 10 2024 04:58:34. | |
| posixpath.pyc | File | 11462 bytes | April 10 2024 04:58:46. | |
| posixpath.pyo | File | 11462 bytes | April 10 2024 04:58:46. | |
| pprint.py | File | 11777 bytes | April 10 2024 04:58:34. | |
| pprint.pyc | File | 10194 bytes | April 10 2024 04:58:46. | |
| pprint.pyo | File | 10017 bytes | April 10 2024 04:58:44. | |
| profile.py | File | 22781 bytes | April 10 2024 04:58:34. | |
| profile.pyc | File | 16456 bytes | April 10 2024 04:58:46. | |
| profile.pyo | File | 16209 bytes | April 10 2024 04:58:44. | |
| pstats.py | File | 26712 bytes | April 10 2024 04:58:34. | |
| pstats.pyc | File | 25013 bytes | April 10 2024 04:58:46. | |
| pstats.pyo | File | 25013 bytes | April 10 2024 04:58:46. | |
| pty.py | File | 5058 bytes | April 10 2024 04:58:34. | |
| pty.pyc | File | 4966 bytes | April 10 2024 04:58:46. | |
| pty.pyo | File | 4966 bytes | April 10 2024 04:58:46. | |
| py_compile.py | File | 5936 bytes | April 10 2024 04:58:34. | |
| py_compile.pyc | File | 6428 bytes | April 10 2024 04:58:46. | |
| py_compile.pyo | File | 6428 bytes | April 10 2024 04:58:46. | |
| pyclbr.py | File | 13388 bytes | April 10 2024 04:58:34. | |
| pyclbr.pyc | File | 9651 bytes | April 10 2024 04:58:46. | |
| pyclbr.pyo | File | 9651 bytes | April 10 2024 04:58:46. | |
| pydoc.py | File | 95739 bytes | April 10 2024 04:58:34. | |
| pydoc.pyc | File | 92342 bytes | April 10 2024 04:58:46. | |
| pydoc.pyo | File | 92278 bytes | April 10 2024 04:58:44. | |
| quopri.py | File | 6968 bytes | April 10 2024 04:58:34. | |
| quopri.pyc | File | 6574 bytes | April 10 2024 04:58:46. | |
| quopri.pyo | File | 6574 bytes | April 10 2024 04:58:46. | |
| random.py | File | 32457 bytes | April 10 2024 04:58:34. | |
| random.pyc | File | 25704 bytes | April 10 2024 04:58:46. | |
| random.pyo | File | 25704 bytes | April 10 2024 04:58:46. | |
| re.py | File | 13423 bytes | April 10 2024 04:58:34. | |
| re.pyc | File | 13413 bytes | April 10 2024 04:58:46. | |
| re.pyo | File | 13413 bytes | April 10 2024 04:58:46. | |
| repr.py | File | 4296 bytes | April 10 2024 04:58:34. | |
| repr.pyc | File | 5385 bytes | April 10 2024 04:58:46. | |
| repr.pyo | File | 5385 bytes | April 10 2024 04:58:46. | |
| rexec.py | File | 20148 bytes | April 10 2024 04:58:34. | |
| rexec.pyc | File | 23807 bytes | April 10 2024 04:58:46. | |
| rexec.pyo | File | 23807 bytes | April 10 2024 04:58:46. | |
| rfc822.py | File | 33542 bytes | April 10 2024 04:58:34. | |
| rfc822.pyc | File | 31813 bytes | April 10 2024 04:58:46. | |
| rfc822.pyo | File | 31813 bytes | April 10 2024 04:58:46. | |
| rlcompleter.py | File | 5991 bytes | April 10 2024 04:58:34. | |
| rlcompleter.pyc | File | 6078 bytes | April 10 2024 04:58:46. | |
| rlcompleter.pyo | File | 6078 bytes | April 10 2024 04:58:46. | |
| robotparser.py | File | 7695 bytes | April 10 2024 04:58:34. | |
| robotparser.pyc | File | 8003 bytes | April 10 2024 04:58:46. | |
| robotparser.pyo | File | 8003 bytes | April 10 2024 04:58:46. | |
| runpy.py | File | 11081 bytes | April 10 2024 04:58:34. | |
| runpy.pyc | File | 8803 bytes | April 10 2024 04:58:46. | |
| runpy.pyo | File | 8803 bytes | April 10 2024 04:58:46. | |
| sched.py | File | 5088 bytes | April 10 2024 04:58:34. | |
| sched.pyc | File | 4994 bytes | April 10 2024 04:58:46. | |
| sched.pyo | File | 4994 bytes | April 10 2024 04:58:46. | |
| sets.py | File | 19050 bytes | April 10 2024 04:58:34. | |
| sets.pyc | File | 16895 bytes | April 10 2024 04:58:46. | |
| sets.pyo | File | 16895 bytes | April 10 2024 04:58:46. | |
| sgmllib.py | File | 17884 bytes | April 10 2024 04:58:34. | |
| sgmllib.pyc | File | 15436 bytes | April 10 2024 04:58:46. | |
| sgmllib.pyo | File | 15436 bytes | April 10 2024 04:58:46. | |
| sha.py | File | 393 bytes | April 10 2024 04:58:34. | |
| sha.pyc | File | 421 bytes | April 10 2024 04:58:46. | |
| sha.pyo | File | 421 bytes | April 10 2024 04:58:46. | |
| shelve.py | File | 8178 bytes | April 10 2024 04:58:34. | |
| shelve.pyc | File | 10256 bytes | April 10 2024 04:58:46. | |
| shelve.pyo | File | 10256 bytes | April 10 2024 04:58:46. | |
| shlex.py | File | 11164 bytes | April 10 2024 04:58:34. | |
| shlex.pyc | File | 7558 bytes | April 10 2024 04:58:46. | |
| shlex.pyo | File | 7558 bytes | April 10 2024 04:58:46. | |
| shutil.py | File | 19871 bytes | April 10 2024 04:58:34. | |
| shutil.pyc | File | 19259 bytes | April 10 2024 04:58:46. | |
| shutil.pyo | File | 19259 bytes | April 10 2024 04:58:46. | |
| site.py | File | 21296 bytes | April 10 2024 04:58:34. | |
| site.pyc | File | 20786 bytes | April 10 2024 04:58:46. | |
| site.pyo | File | 20786 bytes | April 10 2024 04:58:46. | |
| smtpd.py | File | 18542 bytes | April 10 2024 04:58:34. | |
| smtpd.pyc | File | 15883 bytes | April 10 2024 04:58:46. | |
| smtpd.pyo | File | 15883 bytes | April 10 2024 04:58:46. | |
| smtplib.py | File | 32134 bytes | April 10 2024 04:58:34. | |
| smtplib.pyc | File | 30304 bytes | April 10 2024 04:58:46. | |
| smtplib.pyo | File | 30304 bytes | April 10 2024 04:58:46. | |
| sndhdr.py | File | 5973 bytes | April 10 2024 04:58:34. | |
| sndhdr.pyc | File | 7361 bytes | April 10 2024 04:58:46. | |
| sndhdr.pyo | File | 7361 bytes | April 10 2024 04:58:46. | |
| socket.py | File | 20615 bytes | April 10 2024 04:58:34. | |
| socket.pyc | File | 16152 bytes | April 10 2024 04:58:46. | |
| socket.pyo | File | 16066 bytes | April 10 2024 04:58:44. | |
| sre.py | File | 384 bytes | April 10 2024 04:58:34. | |
| sre.pyc | File | 519 bytes | April 10 2024 04:58:46. | |
| sre.pyo | File | 519 bytes | April 10 2024 04:58:46. | |
| sre_compile.py | File | 19823 bytes | April 10 2024 04:58:34. | |
| sre_compile.pyc | File | 12560 bytes | April 10 2024 04:58:46. | |
| sre_compile.pyo | File | 12404 bytes | April 10 2024 04:58:44. | |
| sre_constants.py | File | 7197 bytes | April 10 2024 04:58:34. | |
| sre_constants.pyc | File | 6195 bytes | April 10 2024 04:58:46. | |
| sre_constants.pyo | File | 6195 bytes | April 10 2024 04:58:46. | |
| sre_parse.py | File | 30700 bytes | April 10 2024 04:58:34. | |
| sre_parse.pyc | File | 21156 bytes | April 10 2024 04:58:46. | |
| sre_parse.pyo | File | 21156 bytes | April 10 2024 04:58:46. | |
| ssl.py | File | 39310 bytes | April 10 2024 04:58:34. | |
| ssl.pyc | File | 32716 bytes | April 10 2024 04:58:46. | |
| ssl.pyo | File | 32716 bytes | April 10 2024 04:58:46. | |
| stat.py | File | 1842 bytes | April 10 2024 04:58:34. | |
| stat.pyc | File | 2751 bytes | April 10 2024 04:58:46. | |
| stat.pyo | File | 2751 bytes | April 10 2024 04:58:46. | |
| statvfs.py | File | 898 bytes | April 10 2024 04:58:34. | |
| statvfs.pyc | File | 620 bytes | April 10 2024 04:58:46. | |
| statvfs.pyo | File | 620 bytes | April 10 2024 04:58:46. | |
| string.py | File | 21548 bytes | April 10 2024 04:58:34. | |
| string.pyc | File | 20459 bytes | April 10 2024 04:58:46. | |
| string.pyo | File | 20459 bytes | April 10 2024 04:58:46. | |
| stringold.py | File | 12449 bytes | April 10 2024 04:58:34. | |
| stringold.pyc | File | 12549 bytes | April 10 2024 04:58:46. | |
| stringold.pyo | File | 12549 bytes | April 10 2024 04:58:46. | |
| stringprep.py | File | 13522 bytes | April 10 2024 04:58:34. | |
| stringprep.pyc | File | 14487 bytes | April 10 2024 04:58:46. | |
| stringprep.pyo | File | 14415 bytes | April 10 2024 04:58:44. | |
| struct.py | File | 82 bytes | April 10 2024 04:58:34. | |
| struct.pyc | File | 239 bytes | April 10 2024 04:58:46. | |
| struct.pyo | File | 239 bytes | April 10 2024 04:58:46. | |
| subprocess.py | File | 50520 bytes | April 10 2024 04:58:34. | |
| subprocess.pyc | File | 32398 bytes | April 10 2024 04:58:46. | |
| subprocess.pyo | File | 32398 bytes | April 10 2024 04:58:46. | |
| sunau.py | File | 17222 bytes | April 10 2024 04:58:34. | |
| sunau.pyc | File | 18394 bytes | April 10 2024 04:58:46. | |
| sunau.pyo | File | 18394 bytes | April 10 2024 04:58:46. | |
| sunaudio.py | File | 1399 bytes | April 10 2024 04:58:34. | |
| sunaudio.pyc | File | 1987 bytes | April 10 2024 04:58:46. | |
| sunaudio.pyo | File | 1987 bytes | April 10 2024 04:58:46. | |
| symbol.py | File | 2057 bytes | April 10 2024 04:58:34. | |
| symbol.pyc | File | 3026 bytes | April 10 2024 04:58:46. | |
| symbol.pyo | File | 3026 bytes | April 10 2024 04:58:46. | |
| symtable.py | File | 7437 bytes | April 10 2024 04:58:34. | |
| symtable.pyc | File | 11786 bytes | April 10 2024 04:58:46. | |
| symtable.pyo | File | 11655 bytes | April 10 2024 04:58:44. | |
| sysconfig.py | File | 22852 bytes | April 10 2024 04:58:41. | |
| sysconfig.pyc | File | 17818 bytes | April 10 2024 04:58:46. | |
| sysconfig.pyo | File | 17818 bytes | April 10 2024 04:58:46. | |
| tabnanny.py | File | 11339 bytes | April 10 2024 04:58:34. | |
| tabnanny.pyc | File | 8247 bytes | April 10 2024 04:58:46. | |
| tabnanny.pyo | File | 8247 bytes | April 10 2024 04:58:46. | |
| tarfile.py | File | 90655 bytes | April 10 2024 04:58:34. | |
| tarfile.pyc | File | 76193 bytes | April 10 2024 04:58:46. | |
| tarfile.pyo | File | 76193 bytes | April 10 2024 04:58:46. | |
| telnetlib.py | File | 27036 bytes | April 10 2024 04:58:34. | |
| telnetlib.pyc | File | 23154 bytes | April 10 2024 04:58:46. | |
| telnetlib.pyo | File | 23154 bytes | April 10 2024 04:58:46. | |
| tempfile.py | File | 19547 bytes | April 10 2024 04:58:34. | |
| tempfile.pyc | File | 20344 bytes | April 10 2024 04:58:46. | |
| tempfile.pyo | File | 20344 bytes | April 10 2024 04:58:46. | |
| textwrap.py | File | 17280 bytes | April 10 2024 04:58:34. | |
| textwrap.pyc | File | 12097 bytes | April 10 2024 04:58:46. | |
| textwrap.pyo | File | 12005 bytes | April 10 2024 04:58:44. | |
| this.py | File | 1002 bytes | April 10 2024 04:58:34. | |
| this.pyc | File | 1220 bytes | April 10 2024 04:58:46. | |
| this.pyo | File | 1220 bytes | April 10 2024 04:58:46. | |
| threading.py | File | 47377 bytes | April 10 2024 04:58:34. | |
| threading.pyc | File | 42726 bytes | April 10 2024 04:58:46. | |
| threading.pyo | File | 40552 bytes | April 10 2024 04:58:44. | |
| timeit.py | File | 12791 bytes | April 10 2024 04:58:34. | |
| timeit.pyc | File | 12183 bytes | April 10 2024 04:58:46. | |
| timeit.pyo | File | 12183 bytes | April 10 2024 04:58:46. | |
| toaiff.py | File | 3142 bytes | April 10 2024 04:58:34. | |
| toaiff.pyc | File | 3106 bytes | April 10 2024 04:58:46. | |
| toaiff.pyo | File | 3106 bytes | April 10 2024 04:58:46. | |
| token.py | File | 2922 bytes | April 10 2024 04:58:34. | |
| token.pyc | File | 3816 bytes | April 10 2024 04:58:46. | |
| token.pyo | File | 3816 bytes | April 10 2024 04:58:46. | |
| tokenize.py | File | 17483 bytes | April 10 2024 04:58:34. | |
| tokenize.pyc | File | 14505 bytes | April 10 2024 04:58:46. | |
| tokenize.pyo | File | 14449 bytes | April 10 2024 04:58:44. | |
| trace.py | File | 29891 bytes | April 10 2024 04:58:34. | |
| trace.pyc | File | 22793 bytes | April 10 2024 04:58:46. | |
| trace.pyo | File | 22730 bytes | April 10 2024 04:58:44. | |
| traceback.py | File | 11285 bytes | April 10 2024 04:58:34. | |
| traceback.pyc | File | 11679 bytes | April 10 2024 04:58:46. | |
| traceback.pyo | File | 11679 bytes | April 10 2024 04:58:46. | |
| tty.py | File | 879 bytes | April 10 2024 04:58:34. | |
| tty.pyc | File | 1317 bytes | April 10 2024 04:58:46. | |
| tty.pyo | File | 1317 bytes | April 10 2024 04:58:46. | |
| types.py | File | 2094 bytes | April 10 2024 04:58:34. | |
| types.pyc | File | 2725 bytes | April 10 2024 04:58:46. | |
| types.pyo | File | 2725 bytes | April 10 2024 04:58:46. | |
| urllib.py | File | 60228 bytes | April 10 2024 04:58:34. | |
| urllib.pyc | File | 51241 bytes | April 10 2024 04:58:46. | |
| urllib.pyo | File | 51146 bytes | April 10 2024 04:58:44. | |
| urllib2.py | File | 52541 bytes | April 10 2024 04:58:34. | |
| urllib2.pyc | File | 47302 bytes | April 10 2024 04:58:46. | |
| urllib2.pyo | File | 47207 bytes | April 10 2024 04:58:44. | |
| urlparse.py | File | 20461 bytes | April 10 2024 04:58:34. | |
| urlparse.pyc | File | 18015 bytes | April 10 2024 04:58:46. | |
| urlparse.pyo | File | 18015 bytes | April 10 2024 04:58:46. | |
| user.py | File | 1627 bytes | April 10 2024 04:58:34. | |
| user.pyc | File | 1724 bytes | April 10 2024 04:58:46. | |
| user.pyo | File | 1724 bytes | April 10 2024 04:58:46. | |
| uu.py | File | 6697 bytes | April 10 2024 04:58:34. | |
| uu.pyc | File | 4390 bytes | April 10 2024 04:58:46. | |
| uu.pyo | File | 4390 bytes | April 10 2024 04:58:46. | |
| uuid.py | File | 23530 bytes | April 10 2024 04:58:34. | |
| uuid.pyc | File | 23366 bytes | April 10 2024 04:58:46. | |
| uuid.pyo | File | 23250 bytes | April 10 2024 04:58:44. | |
| warnings.py | File | 14823 bytes | April 10 2024 04:58:34. | |
| warnings.pyc | File | 13510 bytes | April 10 2024 04:58:46. | |
| warnings.pyo | File | 12721 bytes | April 10 2024 04:58:44. | |
| wave.py | File | 18582 bytes | April 10 2024 04:58:34. | |
| wave.pyc | File | 20013 bytes | April 10 2024 04:58:46. | |
| wave.pyo | File | 19869 bytes | April 10 2024 04:58:44. | |
| weakref.py | File | 14830 bytes | April 10 2024 04:58:34. | |
| weakref.pyc | File | 16441 bytes | April 10 2024 04:58:46. | |
| weakref.pyo | File | 16441 bytes | April 10 2024 04:58:46. | |
| webbrowser.py | File | 22725 bytes | April 10 2024 04:58:34. | |
| webbrowser.pyc | File | 19750 bytes | April 10 2024 04:58:46. | |
| webbrowser.pyo | File | 19705 bytes | April 10 2024 04:58:44. | |
| whichdb.py | File | 3379 bytes | April 10 2024 04:58:34. | |
| whichdb.pyc | File | 2241 bytes | April 10 2024 04:58:46. | |
| whichdb.pyo | File | 2241 bytes | April 10 2024 04:58:46. | |
| wsgiref.egg-info | File | 187 bytes | April 10 2024 04:58:34. | |
| xdrlib.py | File | 6069 bytes | April 10 2024 04:58:34. | |
| xdrlib.pyc | File | 9902 bytes | April 10 2024 04:58:46. | |
| xdrlib.pyo | File | 9902 bytes | April 10 2024 04:58:46. | |
| xmllib.py | File | 34865 bytes | April 10 2024 04:58:34. | |
| xmllib.pyc | File | 26848 bytes | April 10 2024 04:58:46. | |
| xmllib.pyo | File | 26848 bytes | April 10 2024 04:58:46. | |
| xmlrpclib.py | File | 52136 bytes | April 10 2024 04:58:34. | |
| xmlrpclib.pyc | File | 44106 bytes | April 10 2024 04:58:46. | |
| xmlrpclib.pyo | File | 43922 bytes | April 10 2024 04:58:44. | |
| zipfile.py | File | 59477 bytes | April 10 2024 04:58:34. | |
| zipfile.pyc | File | 42137 bytes | April 10 2024 04:58:46. | |
| zipfile.pyo | File | 42137 bytes | April 10 2024 04:58:46. |
r"""HTTP/1.1 client library
<intro stuff goes here>
<other stuff, too>
HTTPConnection goes through a number of "states", which define when a client
may legally make another request or fetch the response for a particular
request. This diagram details these state transitions:
(null)
|
| HTTPConnection()
v
Idle
|
| putrequest()
v
Request-started
|
| ( putheader() )* endheaders()
v
Request-sent
|
| response = getresponse()
v
Unread-response [Response-headers-read]
|\____________________
| |
| response.read() | putrequest()
v v
Idle Req-started-unread-response
______/|
/ |
response.read() | | ( putheader() )* endheaders()
v v
Request-started Req-sent-unread-response
|
| response.read()
v
Request-sent
This diagram presents the following rules:
-- a second request may not be started until {response-headers-read}
-- a response [object] cannot be retrieved until {request-sent}
-- there is no differentiation between an unread response body and a
partially read response body
Note: this enforcement is applied by the HTTPConnection class. The
HTTPResponse class does not enforce this state machine, which
implies sophisticated clients may accelerate the request/response
pipeline. Caution should be taken, though: accelerating the states
beyond the above pattern may imply knowledge of the server's
connection-close behavior for certain requests. For example, it
is impossible to tell whether the server will close the connection
UNTIL the response headers have been read; this means that further
requests cannot be placed into the pipeline until it is known that
the server will NOT be closing the connection.
Logical State __state __response
------------- ------- ----------
Idle _CS_IDLE None
Request-started _CS_REQ_STARTED None
Request-sent _CS_REQ_SENT None
Unread-response _CS_IDLE <response_class>
Req-started-unread-response _CS_REQ_STARTED <response_class>
Req-sent-unread-response _CS_REQ_SENT <response_class>
"""
from array import array
import os
import re
import socket
from sys import py3kwarning
from urlparse import urlsplit
import warnings
with warnings.catch_warnings():
if py3kwarning:
warnings.filterwarnings("ignore", ".*mimetools has been removed",
DeprecationWarning)
import mimetools
try:
from cStringIO import StringIO
except ImportError:
from StringIO import StringIO
__all__ = ["HTTP", "HTTPResponse", "HTTPConnection",
"HTTPException", "NotConnected", "UnknownProtocol",
"UnknownTransferEncoding", "UnimplementedFileMode",
"IncompleteRead", "InvalidURL", "ImproperConnectionState",
"CannotSendRequest", "CannotSendHeader", "ResponseNotReady",
"BadStatusLine", "error", "responses"]
HTTP_PORT = 80
HTTPS_PORT = 443
_UNKNOWN = 'UNKNOWN'
# connection states
_CS_IDLE = 'Idle'
_CS_REQ_STARTED = 'Request-started'
_CS_REQ_SENT = 'Request-sent'
# status codes
# informational
CONTINUE = 100
SWITCHING_PROTOCOLS = 101
PROCESSING = 102
# successful
OK = 200
CREATED = 201
ACCEPTED = 202
NON_AUTHORITATIVE_INFORMATION = 203
NO_CONTENT = 204
RESET_CONTENT = 205
PARTIAL_CONTENT = 206
MULTI_STATUS = 207
IM_USED = 226
# redirection
MULTIPLE_CHOICES = 300
MOVED_PERMANENTLY = 301
FOUND = 302
SEE_OTHER = 303
NOT_MODIFIED = 304
USE_PROXY = 305
TEMPORARY_REDIRECT = 307
# client error
BAD_REQUEST = 400
UNAUTHORIZED = 401
PAYMENT_REQUIRED = 402
FORBIDDEN = 403
NOT_FOUND = 404
METHOD_NOT_ALLOWED = 405
NOT_ACCEPTABLE = 406
PROXY_AUTHENTICATION_REQUIRED = 407
REQUEST_TIMEOUT = 408
CONFLICT = 409
GONE = 410
LENGTH_REQUIRED = 411
PRECONDITION_FAILED = 412
REQUEST_ENTITY_TOO_LARGE = 413
REQUEST_URI_TOO_LONG = 414
UNSUPPORTED_MEDIA_TYPE = 415
REQUESTED_RANGE_NOT_SATISFIABLE = 416
EXPECTATION_FAILED = 417
UNPROCESSABLE_ENTITY = 422
LOCKED = 423
FAILED_DEPENDENCY = 424
UPGRADE_REQUIRED = 426
# server error
INTERNAL_SERVER_ERROR = 500
NOT_IMPLEMENTED = 501
BAD_GATEWAY = 502
SERVICE_UNAVAILABLE = 503
GATEWAY_TIMEOUT = 504
HTTP_VERSION_NOT_SUPPORTED = 505
INSUFFICIENT_STORAGE = 507
NOT_EXTENDED = 510
# Mapping status codes to official W3C names
responses = {
100: 'Continue',
101: 'Switching Protocols',
200: 'OK',
201: 'Created',
202: 'Accepted',
203: 'Non-Authoritative Information',
204: 'No Content',
205: 'Reset Content',
206: 'Partial Content',
300: 'Multiple Choices',
301: 'Moved Permanently',
302: 'Found',
303: 'See Other',
304: 'Not Modified',
305: 'Use Proxy',
306: '(Unused)',
307: 'Temporary Redirect',
400: 'Bad Request',
401: 'Unauthorized',
402: 'Payment Required',
403: 'Forbidden',
404: 'Not Found',
405: 'Method Not Allowed',
406: 'Not Acceptable',
407: 'Proxy Authentication Required',
408: 'Request Timeout',
409: 'Conflict',
410: 'Gone',
411: 'Length Required',
412: 'Precondition Failed',
413: 'Request Entity Too Large',
414: 'Request-URI Too Long',
415: 'Unsupported Media Type',
416: 'Requested Range Not Satisfiable',
417: 'Expectation Failed',
500: 'Internal Server Error',
501: 'Not Implemented',
502: 'Bad Gateway',
503: 'Service Unavailable',
504: 'Gateway Timeout',
505: 'HTTP Version Not Supported',
}
# maximal amount of data to read at one time in _safe_read
MAXAMOUNT = 1048576
# maximal line length when calling readline().
_MAXLINE = 65536
# maximum amount of headers accepted
_MAXHEADERS = 100
# Header name/value ABNF (http://tools.ietf.org/html/rfc7230#section-3.2)
#
# VCHAR = %x21-7E
# obs-text = %x80-FF
# header-field = field-name ":" OWS field-value OWS
# field-name = token
# field-value = *( field-content / obs-fold )
# field-content = field-vchar [ 1*( SP / HTAB ) field-vchar ]
# field-vchar = VCHAR / obs-text
#
# obs-fold = CRLF 1*( SP / HTAB )
# ; obsolete line folding
# ; see Section 3.2.4
# token = 1*tchar
#
# tchar = "!" / "#" / "$" / "%" / "&" / "'" / "*"
# / "+" / "-" / "." / "^" / "_" / "`" / "|" / "~"
# / DIGIT / ALPHA
# ; any VCHAR, except delimiters
#
# VCHAR defined in http://tools.ietf.org/html/rfc5234#appendix-B.1
# the patterns for both name and value are more lenient than RFC
# definitions to allow for backwards compatibility
_is_legal_header_name = re.compile(r'\A[^:\s][^:\r\n]*\Z').match
_is_illegal_header_value = re.compile(r'\n(?![ \t])|\r(?![ \t\n])').search
# These characters are not allowed within HTTP URL paths.
# See https://tools.ietf.org/html/rfc3986#section-3.3 and the
# https://tools.ietf.org/html/rfc3986#appendix-A pchar definition.
# Prevents CVE-2019-9740. Includes control characters such as \r\n.
# Restrict non-ASCII characters above \x7f (0x80-0xff).
_contains_disallowed_url_pchar_re = re.compile('[\x00-\x20\x7f-\xff]')
# Arguably only these _should_ allowed:
# _is_allowed_url_pchars_re = re.compile(r"^[/!$&'()*+,;=:@%a-zA-Z0-9._~-]+$")
# We are more lenient for assumed real world compatibility purposes.
# These characters are not allowed within HTTP method names
# to prevent http header injection.
_contains_disallowed_method_pchar_re = re.compile('[\x00-\x1f]')
# We always set the Content-Length header for these methods because some
# servers will otherwise respond with a 411
_METHODS_EXPECTING_BODY = {'PATCH', 'POST', 'PUT'}
class HTTPMessage(mimetools.Message):
def addheader(self, key, value):
"""Add header for field key handling repeats."""
prev = self.dict.get(key)
if prev is None:
self.dict[key] = value
else:
combined = ", ".join((prev, value))
self.dict[key] = combined
def addcontinue(self, key, more):
"""Add more field data from a continuation line."""
prev = self.dict[key]
self.dict[key] = prev + "\n " + more
def readheaders(self):
"""Read header lines.
Read header lines up to the entirely blank line that terminates them.
The (normally blank) line that ends the headers is skipped, but not
included in the returned list. If an invalid line is found in the
header section, it is skipped, and further lines are processed.
The variable self.status is set to the empty string if all went well,
otherwise it is an error message. The variable self.headers is a
completely uninterpreted list of lines contained in the header (so
printing them will reproduce the header exactly as it appears in the
file).
If multiple header fields with the same name occur, they are combined
according to the rules in RFC 2616 sec 4.2:
Appending each subsequent field-value to the first, each separated
by a comma. The order in which header fields with the same field-name
are received is significant to the interpretation of the combined
field value.
"""
# XXX The implementation overrides the readheaders() method of
# rfc822.Message. The base class design isn't amenable to
# customized behavior here so the method here is a copy of the
# base class code with a few small changes.
self.dict = {}
self.unixfrom = ''
self.headers = hlist = []
self.status = ''
headerseen = ""
firstline = 1
tell = None
if not hasattr(self.fp, 'unread') and self.seekable:
tell = self.fp.tell
while True:
if len(hlist) > _MAXHEADERS:
raise HTTPException("got more than %d headers" % _MAXHEADERS)
if tell:
try:
tell()
except IOError:
tell = None
self.seekable = 0
line = self.fp.readline(_MAXLINE + 1)
if len(line) > _MAXLINE:
raise LineTooLong("header line")
if not line:
self.status = 'EOF in headers'
break
# Skip unix From name time lines
if firstline and line.startswith('From '):
self.unixfrom = self.unixfrom + line
continue
firstline = 0
if headerseen and line[0] in ' \t':
# XXX Not sure if continuation lines are handled properly
# for http and/or for repeating headers
# It's a continuation line.
hlist.append(line)
self.addcontinue(headerseen, line.strip())
continue
elif self.iscomment(line):
# It's a comment. Ignore it.
continue
elif self.islast(line):
# Note! No pushback here! The delimiter line gets eaten.
break
headerseen = self.isheader(line)
if headerseen:
# It's a legal header line, save it.
hlist.append(line)
self.addheader(headerseen, line[len(headerseen)+1:].strip())
elif headerseen is not None:
# An empty header name. These aren't allowed in HTTP, but it's
# probably a benign mistake. Don't add the header, just keep
# going.
pass
else:
# It's not a header line; skip it and try the next line.
self.status = 'Non-header line where header expected'
def _read_headers(fp):
"""Reads potential header lines into a list from a file pointer.
Length of line is limited by _MAXLINE, and number of
headers is limited by _MAXHEADERS.
"""
headers = []
while True:
line = fp.readline(_MAXLINE + 1)
if len(line) > _MAXLINE:
raise LineTooLong("header line")
headers.append(line)
if len(headers) > _MAXHEADERS:
raise HTTPException("got more than %d headers" % _MAXHEADERS)
if line in (b'\r\n', b'\n', b''):
break
return headers
class HTTPResponse:
# strict: If true, raise BadStatusLine if the status line can't be
# parsed as a valid HTTP/1.0 or 1.1 status line. By default it is
# false because it prevents clients from talking to HTTP/0.9
# servers. Note that a response with a sufficiently corrupted
# status line will look like an HTTP/0.9 response.
# See RFC 2616 sec 19.6 and RFC 1945 sec 6 for details.
def __init__(self, sock, debuglevel=0, strict=0, method=None, buffering=False):
if buffering:
# The caller won't be using any sock.recv() calls, so buffering
# is fine and recommended for performance.
self.fp = sock.makefile('rb')
else:
# The buffer size is specified as zero, because the headers of
# the response are read with readline(). If the reads were
# buffered the readline() calls could consume some of the
# response, which make be read via a recv() on the underlying
# socket.
self.fp = sock.makefile('rb', 0)
self.debuglevel = debuglevel
self.strict = strict
self._method = method
self.msg = None
# from the Status-Line of the response
self.version = _UNKNOWN # HTTP-Version
self.status = _UNKNOWN # Status-Code
self.reason = _UNKNOWN # Reason-Phrase
self.chunked = _UNKNOWN # is "chunked" being used?
self.chunk_left = _UNKNOWN # bytes left to read in current chunk
self.length = _UNKNOWN # number of bytes left in response
self.will_close = _UNKNOWN # conn will close at end of response
def _read_status(self):
# Initialize with Simple-Response defaults
line = self.fp.readline(_MAXLINE + 1)
if len(line) > _MAXLINE:
raise LineTooLong("header line")
if self.debuglevel > 0:
print "reply:", repr(line)
if not line:
# Presumably, the server closed the connection before
# sending a valid response.
raise BadStatusLine("No status line received - the server has closed the connection")
try:
[version, status, reason] = line.split(None, 2)
except ValueError:
try:
[version, status] = line.split(None, 1)
reason = ""
except ValueError:
# empty version will cause next test to fail and status
# will be treated as 0.9 response.
version = ""
if not version.startswith('HTTP/'):
if self.strict:
self.close()
raise BadStatusLine(line)
else:
# assume it's a Simple-Response from an 0.9 server
self.fp = LineAndFileWrapper(line, self.fp)
return "HTTP/0.9", 200, ""
# The status code is a three-digit number
try:
status = int(status)
if status < 100 or status > 999:
raise BadStatusLine(line)
except ValueError:
raise BadStatusLine(line)
return version, status, reason
def begin(self):
if self.msg is not None:
# we've already started reading the response
return
# read until we get a non-100 response
while True:
version, status, reason = self._read_status()
if status != CONTINUE:
break
# skip the header from the 100 response
skipped_headers = _read_headers(self.fp)
if self.debuglevel > 0:
print("headers:", skipped_headers)
del skipped_headers
self.status = status
self.reason = reason.strip()
if version == 'HTTP/1.0':
self.version = 10
elif version.startswith('HTTP/1.'):
self.version = 11 # use HTTP/1.1 code for HTTP/1.x where x>=1
elif version == 'HTTP/0.9':
self.version = 9
else:
raise UnknownProtocol(version)
if self.version == 9:
self.length = None
self.chunked = 0
self.will_close = 1
self.msg = HTTPMessage(StringIO())
return
self.msg = HTTPMessage(self.fp, 0)
if self.debuglevel > 0:
for hdr in self.msg.headers:
print "header:", hdr,
# don't let the msg keep an fp
self.msg.fp = None
# are we using the chunked-style of transfer encoding?
tr_enc = self.msg.getheader('transfer-encoding')
if tr_enc and tr_enc.lower() == "chunked":
self.chunked = 1
self.chunk_left = None
else:
self.chunked = 0
# will the connection close at the end of the response?
self.will_close = self._check_close()
# do we have a Content-Length?
# NOTE: RFC 2616, S4.4, #3 says we ignore this if tr_enc is "chunked"
length = self.msg.getheader('content-length')
if length and not self.chunked:
try:
self.length = int(length)
except ValueError:
self.length = None
else:
if self.length < 0: # ignore nonsensical negative lengths
self.length = None
else:
self.length = None
# does the body have a fixed length? (of zero)
if (status == NO_CONTENT or status == NOT_MODIFIED or
100 <= status < 200 or # 1xx codes
self._method == 'HEAD'):
self.length = 0
# if the connection remains open, and we aren't using chunked, and
# a content-length was not provided, then assume that the connection
# WILL close.
if not self.will_close and \
not self.chunked and \
self.length is None:
self.will_close = 1
def _check_close(self):
conn = self.msg.getheader('connection')
if self.version == 11:
# An HTTP/1.1 proxy is assumed to stay open unless
# explicitly closed.
conn = self.msg.getheader('connection')
if conn and "close" in conn.lower():
return True
return False
# Some HTTP/1.0 implementations have support for persistent
# connections, using rules different than HTTP/1.1.
# For older HTTP, Keep-Alive indicates persistent connection.
if self.msg.getheader('keep-alive'):
return False
# At least Akamai returns a "Connection: Keep-Alive" header,
# which was supposed to be sent by the client.
if conn and "keep-alive" in conn.lower():
return False
# Proxy-Connection is a netscape hack.
pconn = self.msg.getheader('proxy-connection')
if pconn and "keep-alive" in pconn.lower():
return False
# otherwise, assume it will close
return True
def close(self):
fp = self.fp
if fp:
self.fp = None
fp.close()
def isclosed(self):
# NOTE: it is possible that we will not ever call self.close(). This
# case occurs when will_close is TRUE, length is None, and we
# read up to the last byte, but NOT past it.
#
# IMPLIES: if will_close is FALSE, then self.close() will ALWAYS be
# called, meaning self.isclosed() is meaningful.
return self.fp is None
# XXX It would be nice to have readline and __iter__ for this, too.
def read(self, amt=None):
if self.fp is None:
return ''
if self._method == 'HEAD':
self.close()
return ''
if self.chunked:
return self._read_chunked(amt)
if amt is None:
# unbounded read
if self.length is None:
s = self.fp.read()
else:
try:
s = self._safe_read(self.length)
except IncompleteRead:
self.close()
raise
self.length = 0
self.close() # we read everything
return s
if self.length is not None:
if amt > self.length:
# clip the read to the "end of response"
amt = self.length
# we do not use _safe_read() here because this may be a .will_close
# connection, and the user is reading more bytes than will be provided
# (for example, reading in 1k chunks)
s = self.fp.read(amt)
if not s and amt:
# Ideally, we would raise IncompleteRead if the content-length
# wasn't satisfied, but it might break compatibility.
self.close()
if self.length is not None:
self.length -= len(s)
if not self.length:
self.close()
return s
def _read_chunked(self, amt):
assert self.chunked != _UNKNOWN
chunk_left = self.chunk_left
value = []
while True:
if chunk_left is None:
line = self.fp.readline(_MAXLINE + 1)
if len(line) > _MAXLINE:
raise LineTooLong("chunk size")
i = line.find(';')
if i >= 0:
line = line[:i] # strip chunk-extensions
try:
chunk_left = int(line, 16)
except ValueError:
# close the connection as protocol synchronisation is
# probably lost
self.close()
raise IncompleteRead(''.join(value))
if chunk_left == 0:
break
if amt is None:
value.append(self._safe_read(chunk_left))
elif amt < chunk_left:
value.append(self._safe_read(amt))
self.chunk_left = chunk_left - amt
return ''.join(value)
elif amt == chunk_left:
value.append(self._safe_read(amt))
self._safe_read(2) # toss the CRLF at the end of the chunk
self.chunk_left = None
return ''.join(value)
else:
value.append(self._safe_read(chunk_left))
amt -= chunk_left
# we read the whole chunk, get another
self._safe_read(2) # toss the CRLF at the end of the chunk
chunk_left = None
# read and discard trailer up to the CRLF terminator
### note: we shouldn't have any trailers!
while True:
line = self.fp.readline(_MAXLINE + 1)
if len(line) > _MAXLINE:
raise LineTooLong("trailer line")
if not line:
# a vanishingly small number of sites EOF without
# sending the trailer
break
if line == '\r\n':
break
# we read everything; close the "file"
self.close()
return ''.join(value)
def _safe_read(self, amt):
"""Read the number of bytes requested, compensating for partial reads.
Normally, we have a blocking socket, but a read() can be interrupted
by a signal (resulting in a partial read).
Note that we cannot distinguish between EOF and an interrupt when zero
bytes have been read. IncompleteRead() will be raised in this
situation.
This function should be used when <amt> bytes "should" be present for
reading. If the bytes are truly not available (due to EOF), then the
IncompleteRead exception can be used to detect the problem.
"""
# NOTE(gps): As of svn r74426 socket._fileobject.read(x) will never
# return less than x bytes unless EOF is encountered. It now handles
# signal interruptions (socket.error EINTR) internally. This code
# never caught that exception anyways. It seems largely pointless.
# self.fp.read(amt) will work fine.
s = []
while amt > 0:
chunk = self.fp.read(min(amt, MAXAMOUNT))
if not chunk:
raise IncompleteRead(''.join(s), amt)
s.append(chunk)
amt -= len(chunk)
return ''.join(s)
def fileno(self):
return self.fp.fileno()
def getheader(self, name, default=None):
if self.msg is None:
raise ResponseNotReady()
return self.msg.getheader(name, default)
def getheaders(self):
"""Return list of (header, value) tuples."""
if self.msg is None:
raise ResponseNotReady()
return self.msg.items()
class HTTPConnection:
_http_vsn = 11
_http_vsn_str = 'HTTP/1.1'
response_class = HTTPResponse
default_port = HTTP_PORT
auto_open = 1
debuglevel = 0
strict = 0
def __init__(self, host, port=None, strict=None,
timeout=socket._GLOBAL_DEFAULT_TIMEOUT, source_address=None):
self.timeout = timeout
self.source_address = source_address
self.sock = None
self._buffer = []
self.__response = None
self.__state = _CS_IDLE
self._method = None
self._tunnel_host = None
self._tunnel_port = None
self._tunnel_headers = {}
if strict is not None:
self.strict = strict
(self.host, self.port) = self._get_hostport(host, port)
self._validate_host(self.host)
# This is stored as an instance variable to allow unittests
# to replace with a suitable mock
self._create_connection = socket.create_connection
def set_tunnel(self, host, port=None, headers=None):
""" Set up host and port for HTTP CONNECT tunnelling.
In a connection that uses HTTP Connect tunneling, the host passed to the
constructor is used as proxy server that relays all communication to the
endpoint passed to set_tunnel. This is done by sending a HTTP CONNECT
request to the proxy server when the connection is established.
This method must be called before the HTTP connection has been
established.
The headers argument should be a mapping of extra HTTP headers
to send with the CONNECT request.
"""
# Verify if this is required.
if self.sock:
raise RuntimeError("Can't setup tunnel for established connection.")
self._tunnel_host, self._tunnel_port = self._get_hostport(host, port)
if headers:
self._tunnel_headers = headers
else:
self._tunnel_headers.clear()
def _get_hostport(self, host, port):
if port is None:
i = host.rfind(':')
j = host.rfind(']') # ipv6 addresses have [...]
if i > j:
try:
port = int(host[i+1:])
except ValueError:
if host[i+1:] == "": # http://foo.com:/ == http://foo.com/
port = self.default_port
else:
raise InvalidURL("nonnumeric port: '%s'" % host[i+1:])
host = host[:i]
else:
port = self.default_port
if host and host[0] == '[' and host[-1] == ']':
host = host[1:-1]
return (host, port)
def set_debuglevel(self, level):
self.debuglevel = level
def _tunnel(self):
self.send("CONNECT %s:%d HTTP/1.0\r\n" % (self._tunnel_host,
self._tunnel_port))
for header, value in self._tunnel_headers.iteritems():
self.send("%s: %s\r\n" % (header, value))
self.send("\r\n")
response = self.response_class(self.sock, strict = self.strict,
method = self._method)
(version, code, message) = response._read_status()
if version == "HTTP/0.9":
# HTTP/0.9 doesn't support the CONNECT verb, so if httplib has
# concluded HTTP/0.9 is being used something has gone wrong.
self.close()
raise socket.error("Invalid response from tunnel request")
if code != 200:
self.close()
raise socket.error("Tunnel connection failed: %d %s" % (code,
message.strip()))
while True:
line = response.fp.readline(_MAXLINE + 1)
if len(line) > _MAXLINE:
raise LineTooLong("header line")
if not line:
# for sites which EOF without sending trailer
break
if line == '\r\n':
break
def connect(self):
"""Connect to the host and port specified in __init__."""
self.sock = self._create_connection((self.host,self.port),
self.timeout, self.source_address)
if self._tunnel_host:
self._tunnel()
def close(self):
"""Close the connection to the HTTP server."""
self.__state = _CS_IDLE
try:
sock = self.sock
if sock:
self.sock = None
sock.close() # close it manually... there may be other refs
finally:
response = self.__response
if response:
self.__response = None
response.close()
def send(self, data):
"""Send `data' to the server."""
if self.sock is None:
if self.auto_open:
self.connect()
else:
raise NotConnected()
if self.debuglevel > 0:
print "send:", repr(data)
blocksize = 8192
if hasattr(data,'read') and not isinstance(data, array):
if self.debuglevel > 0: print "sendIng a read()able"
datablock = data.read(blocksize)
while datablock:
self.sock.sendall(datablock)
datablock = data.read(blocksize)
else:
self.sock.sendall(data)
def _output(self, s):
"""Add a line of output to the current request buffer.
Assumes that the line does *not* end with \\r\\n.
"""
self._buffer.append(s)
def _send_output(self, message_body=None):
"""Send the currently buffered request and clear the buffer.
Appends an extra \\r\\n to the buffer.
A message_body may be specified, to be appended to the request.
"""
self._buffer.extend(("", ""))
msg = "\r\n".join(self._buffer)
del self._buffer[:]
# If msg and message_body are sent in a single send() call,
# it will avoid performance problems caused by the interaction
# between delayed ack and the Nagle algorithm.
if isinstance(message_body, str):
msg += message_body
message_body = None
self.send(msg)
if message_body is not None:
#message_body was not a string (i.e. it is a file) and
#we must run the risk of Nagle
self.send(message_body)
def putrequest(self, method, url, skip_host=0, skip_accept_encoding=0):
"""Send a request to the server.
`method' specifies an HTTP request method, e.g. 'GET'.
`url' specifies the object being requested, e.g. '/index.html'.
`skip_host' if True does not add automatically a 'Host:' header
`skip_accept_encoding' if True does not add automatically an
'Accept-Encoding:' header
"""
# if a prior response has been completed, then forget about it.
if self.__response and self.__response.isclosed():
self.__response = None
# in certain cases, we cannot issue another request on this connection.
# this occurs when:
# 1) we are in the process of sending a request. (_CS_REQ_STARTED)
# 2) a response to a previous request has signalled that it is going
# to close the connection upon completion.
# 3) the headers for the previous response have not been read, thus
# we cannot determine whether point (2) is true. (_CS_REQ_SENT)
#
# if there is no prior response, then we can request at will.
#
# if point (2) is true, then we will have passed the socket to the
# response (effectively meaning, "there is no prior response"), and
# will open a new one when a new request is made.
#
# Note: if a prior response exists, then we *can* start a new request.
# We are not allowed to begin fetching the response to this new
# request, however, until that prior response is complete.
#
if self.__state == _CS_IDLE:
self.__state = _CS_REQ_STARTED
else:
raise CannotSendRequest()
self._validate_method(method)
# Save the method for use later in the response phase
self._method = method
url = url or '/'
self._validate_path(url)
request = '%s %s %s' % (method, url, self._http_vsn_str)
self._output(self._encode_request(request))
if self._http_vsn == 11:
# Issue some standard headers for better HTTP/1.1 compliance
if not skip_host:
# this header is issued *only* for HTTP/1.1
# connections. more specifically, this means it is
# only issued when the client uses the new
# HTTPConnection() class. backwards-compat clients
# will be using HTTP/1.0 and those clients may be
# issuing this header themselves. we should NOT issue
# it twice; some web servers (such as Apache) barf
# when they see two Host: headers
# If we need a non-standard port,include it in the
# header. If the request is going through a proxy,
# but the host of the actual URL, not the host of the
# proxy.
netloc = ''
if url.startswith('http'):
nil, netloc, nil, nil, nil = urlsplit(url)
if netloc:
try:
netloc_enc = netloc.encode("ascii")
except UnicodeEncodeError:
netloc_enc = netloc.encode("idna")
self.putheader('Host', netloc_enc)
else:
if self._tunnel_host:
host = self._tunnel_host
port = self._tunnel_port
else:
host = self.host
port = self.port
try:
host_enc = host.encode("ascii")
except UnicodeEncodeError:
host_enc = host.encode("idna")
# Wrap the IPv6 Host Header with [] (RFC 2732)
if host_enc.find(':') >= 0:
host_enc = "[" + host_enc + "]"
if port == self.default_port:
self.putheader('Host', host_enc)
else:
self.putheader('Host', "%s:%s" % (host_enc, port))
# note: we are assuming that clients will not attempt to set these
# headers since *this* library must deal with the
# consequences. this also means that when the supporting
# libraries are updated to recognize other forms, then this
# code should be changed (removed or updated).
# we only want a Content-Encoding of "identity" since we don't
# support encodings such as x-gzip or x-deflate.
if not skip_accept_encoding:
self.putheader('Accept-Encoding', 'identity')
# we can accept "chunked" Transfer-Encodings, but no others
# NOTE: no TE header implies *only* "chunked"
#self.putheader('TE', 'chunked')
# if TE is supplied in the header, then it must appear in a
# Connection header.
#self.putheader('Connection', 'TE')
else:
# For HTTP/1.0, the server will assume "not chunked"
pass
def _encode_request(self, request):
# On Python 2, request is already encoded (default)
return request
def _validate_method(self, method):
"""Validate a method name for putrequest."""
# prevent http header injection
match = _contains_disallowed_method_pchar_re.search(method)
if match:
raise ValueError(
"method can't contain control characters. %r "
"(found at least %r)"
% (method, match.group()))
def _validate_path(self, url):
"""Validate a url for putrequest."""
# Prevent CVE-2019-9740.
match = _contains_disallowed_url_pchar_re.search(url)
if match:
msg = (
"URL can't contain control characters. {url!r} "
"(found at least {matched!r})"
).format(matched=match.group(), url=url)
raise InvalidURL(msg)
def _validate_host(self, host):
"""Validate a host so it doesn't contain control characters."""
# Prevent CVE-2019-18348.
match = _contains_disallowed_url_pchar_re.search(host)
if match:
msg = (
"URL can't contain control characters. {host!r} "
"(found at least {matched!r})"
).format(matched=match.group(), host=host)
raise InvalidURL(msg)
def putheader(self, header, *values):
"""Send a request header line to the server.
For example: h.putheader('Accept', 'text/html')
"""
if self.__state != _CS_REQ_STARTED:
raise CannotSendHeader()
header = '%s' % header
if not _is_legal_header_name(header):
raise ValueError('Invalid header name %r' % (header,))
values = [str(v) for v in values]
for one_value in values:
if _is_illegal_header_value(one_value):
raise ValueError('Invalid header value %r' % (one_value,))
hdr = '%s: %s' % (header, '\r\n\t'.join(values))
self._output(hdr)
def endheaders(self, message_body=None):
"""Indicate that the last header line has been sent to the server.
This method sends the request to the server. The optional
message_body argument can be used to pass a message body
associated with the request. The message body will be sent in
the same packet as the message headers if it is string, otherwise it is
sent as a separate packet.
"""
if self.__state == _CS_REQ_STARTED:
self.__state = _CS_REQ_SENT
else:
raise CannotSendHeader()
self._send_output(message_body)
def request(self, method, url, body=None, headers={}):
"""Send a complete request to the server."""
self._send_request(method, url, body, headers)
def _set_content_length(self, body, method):
# Set the content-length based on the body. If the body is "empty", we
# set Content-Length: 0 for methods that expect a body (RFC 7230,
# Section 3.3.2). If the body is set for other methods, we set the
# header provided we can figure out what the length is.
thelen = None
if body is None and method.upper() in _METHODS_EXPECTING_BODY:
thelen = '0'
elif body is not None:
try:
thelen = str(len(body))
except (TypeError, AttributeError):
# If this is a file-like object, try to
# fstat its file descriptor
try:
thelen = str(os.fstat(body.fileno()).st_size)
except (AttributeError, OSError):
# Don't send a length if this failed
if self.debuglevel > 0: print "Cannot stat!!"
if thelen is not None:
self.putheader('Content-Length', thelen)
def _send_request(self, method, url, body, headers):
# Honor explicitly requested Host: and Accept-Encoding: headers.
header_names = dict.fromkeys([k.lower() for k in headers])
skips = {}
if 'host' in header_names:
skips['skip_host'] = 1
if 'accept-encoding' in header_names:
skips['skip_accept_encoding'] = 1
self.putrequest(method, url, **skips)
if 'content-length' not in header_names:
self._set_content_length(body, method)
for hdr, value in headers.iteritems():
self.putheader(hdr, value)
self.endheaders(body)
def getresponse(self, buffering=False):
"Get the response from the server."
# if a prior response has been completed, then forget about it.
if self.__response and self.__response.isclosed():
self.__response = None
#
# if a prior response exists, then it must be completed (otherwise, we
# cannot read this response's header to determine the connection-close
# behavior)
#
# note: if a prior response existed, but was connection-close, then the
# socket and response were made independent of this HTTPConnection
# object since a new request requires that we open a whole new
# connection
#
# this means the prior response had one of two states:
# 1) will_close: this connection was reset and the prior socket and
# response operate independently
# 2) persistent: the response was retained and we await its
# isclosed() status to become true.
#
if self.__state != _CS_REQ_SENT or self.__response:
raise ResponseNotReady()
args = (self.sock,)
kwds = {"strict":self.strict, "method":self._method}
if self.debuglevel > 0:
args += (self.debuglevel,)
if buffering:
#only add this keyword if non-default, for compatibility with
#other response_classes.
kwds["buffering"] = True;
response = self.response_class(*args, **kwds)
try:
response.begin()
assert response.will_close != _UNKNOWN
self.__state = _CS_IDLE
if response.will_close:
# this effectively passes the connection to the response
self.close()
else:
# remember this, so we can tell when it is complete
self.__response = response
return response
except:
response.close()
raise
class HTTP:
"Compatibility class with httplib.py from 1.5."
_http_vsn = 10
_http_vsn_str = 'HTTP/1.0'
debuglevel = 0
_connection_class = HTTPConnection
def __init__(self, host='', port=None, strict=None):
"Provide a default host, since the superclass requires one."
# some joker passed 0 explicitly, meaning default port
if port == 0:
port = None
# Note that we may pass an empty string as the host; this will raise
# an error when we attempt to connect. Presumably, the client code
# will call connect before then, with a proper host.
self._setup(self._connection_class(host, port, strict))
def _setup(self, conn):
self._conn = conn
# set up delegation to flesh out interface
self.send = conn.send
self.putrequest = conn.putrequest
self.putheader = conn.putheader
self.endheaders = conn.endheaders
self.set_debuglevel = conn.set_debuglevel
conn._http_vsn = self._http_vsn
conn._http_vsn_str = self._http_vsn_str
self.file = None
def connect(self, host=None, port=None):
"Accept arguments to set the host/port, since the superclass doesn't."
if host is not None:
(self._conn.host, self._conn.port) = self._conn._get_hostport(host, port)
self._conn.connect()
def getfile(self):
"Provide a getfile, since the superclass' does not use this concept."
return self.file
def getreply(self, buffering=False):
"""Compat definition since superclass does not define it.
Returns a tuple consisting of:
- server status code (e.g. '200' if all goes well)
- server "reason" corresponding to status code
- any RFC822 headers in the response from the server
"""
try:
if not buffering:
response = self._conn.getresponse()
else:
#only add this keyword if non-default for compatibility
#with other connection classes
response = self._conn.getresponse(buffering)
except BadStatusLine, e:
### hmm. if getresponse() ever closes the socket on a bad request,
### then we are going to have problems with self.sock
### should we keep this behavior? do people use it?
# keep the socket open (as a file), and return it
self.file = self._conn.sock.makefile('rb', 0)
# close our socket -- we want to restart after any protocol error
self.close()
self.headers = None
return -1, e.line, None
self.headers = response.msg
self.file = response.fp
return response.status, response.reason, response.msg
def close(self):
self._conn.close()
# note that self.file == response.fp, which gets closed by the
# superclass. just clear the object ref here.
### hmm. messy. if status==-1, then self.file is owned by us.
### well... we aren't explicitly closing, but losing this ref will
### do it
self.file = None
try:
import ssl
except ImportError:
pass
else:
class HTTPSConnection(HTTPConnection):
"This class allows communication via SSL."
default_port = HTTPS_PORT
def __init__(self, host, port=None, key_file=None, cert_file=None,
strict=None, timeout=socket._GLOBAL_DEFAULT_TIMEOUT,
source_address=None, context=None):
HTTPConnection.__init__(self, host, port, strict, timeout,
source_address)
self.key_file = key_file
self.cert_file = cert_file
if context is None:
context = ssl._create_default_https_context()
if key_file or cert_file:
context.load_cert_chain(cert_file, key_file)
self._context = context
def connect(self):
"Connect to a host on a given (SSL) port."
HTTPConnection.connect(self)
if self._tunnel_host:
server_hostname = self._tunnel_host
else:
server_hostname = self.host
self.sock = self._context.wrap_socket(self.sock,
server_hostname=server_hostname)
__all__.append("HTTPSConnection")
class HTTPS(HTTP):
"""Compatibility with 1.5 httplib interface
Python 1.5.2 did not have an HTTPS class, but it defined an
interface for sending http requests that is also useful for
https.
"""
_connection_class = HTTPSConnection
def __init__(self, host='', port=None, key_file=None, cert_file=None,
strict=None, context=None):
# provide a default host, pass the X509 cert info
# urf. compensate for bad input.
if port == 0:
port = None
self._setup(self._connection_class(host, port, key_file,
cert_file, strict,
context=context))
# we never actually use these for anything, but we keep them
# here for compatibility with post-1.5.2 CVS.
self.key_file = key_file
self.cert_file = cert_file
def FakeSocket (sock, sslobj):
warnings.warn("FakeSocket is deprecated, and won't be in 3.x. " +
"Use the result of ssl.wrap_socket() directly instead.",
DeprecationWarning, stacklevel=2)
return sslobj
class HTTPException(Exception):
# Subclasses that define an __init__ must call Exception.__init__
# or define self.args. Otherwise, str() will fail.
pass
class NotConnected(HTTPException):
pass
class InvalidURL(HTTPException):
pass
class UnknownProtocol(HTTPException):
def __init__(self, version):
self.args = version,
self.version = version
class UnknownTransferEncoding(HTTPException):
pass
class UnimplementedFileMode(HTTPException):
pass
class IncompleteRead(HTTPException):
def __init__(self, partial, expected=None):
self.args = partial,
self.partial = partial
self.expected = expected
def __repr__(self):
if self.expected is not None:
e = ', %i more expected' % self.expected
else:
e = ''
return 'IncompleteRead(%i bytes read%s)' % (len(self.partial), e)
def __str__(self):
return repr(self)
class ImproperConnectionState(HTTPException):
pass
class CannotSendRequest(ImproperConnectionState):
pass
class CannotSendHeader(ImproperConnectionState):
pass
class ResponseNotReady(ImproperConnectionState):
pass
class BadStatusLine(HTTPException):
def __init__(self, line):
if not line:
line = repr(line)
self.args = line,
self.line = line
class LineTooLong(HTTPException):
def __init__(self, line_type):
HTTPException.__init__(self, "got more than %d bytes when reading %s"
% (_MAXLINE, line_type))
# for backwards compatibility
error = HTTPException
class LineAndFileWrapper:
"""A limited file-like object for HTTP/0.9 responses."""
# The status-line parsing code calls readline(), which normally
# get the HTTP status line. For a 0.9 response, however, this is
# actually the first line of the body! Clients need to get a
# readable file object that contains that line.
def __init__(self, line, file):
self._line = line
self._file = file
self._line_consumed = 0
self._line_offset = 0
self._line_left = len(line)
def __getattr__(self, attr):
return getattr(self._file, attr)
def _done(self):
# called when the last byte is read from the line. After the
# call, all read methods are delegated to the underlying file
# object.
self._line_consumed = 1
self.read = self._file.read
self.readline = self._file.readline
self.readlines = self._file.readlines
def read(self, amt=None):
if self._line_consumed:
return self._file.read(amt)
assert self._line_left
if amt is None or amt > self._line_left:
s = self._line[self._line_offset:]
self._done()
if amt is None:
return s + self._file.read()
else:
return s + self._file.read(amt - len(s))
else:
assert amt <= self._line_left
i = self._line_offset
j = i + amt
s = self._line[i:j]
self._line_offset = j
self._line_left -= amt
if self._line_left == 0:
self._done()
return s
def readline(self):
if self._line_consumed:
return self._file.readline()
assert self._line_left
s = self._line[self._line_offset:]
self._done()
return s
def readlines(self, size=None):
if self._line_consumed:
return self._file.readlines(size)
assert self._line_left
L = [self._line[self._line_offset:]]
self._done()
if size is None:
return L + self._file.readlines()
else:
return L + self._file.readlines(size)
SILENT KILLER Tool