Hackfut Security File Manager
Current Path:
/usr/lib64/python2.6
usr
/
lib64
/
python2.6
/
📁
..
📄
BaseHTTPServer.py
(21.46 KB)
📄
BaseHTTPServer.pyc
(21.07 KB)
📄
BaseHTTPServer.pyo
(21.07 KB)
📄
Bastion.py
(5.61 KB)
📄
Bastion.pyc
(6.51 KB)
📄
Bastion.pyo
(6.51 KB)
📄
CGIHTTPServer.py
(12.47 KB)
📄
CGIHTTPServer.pyc
(10.57 KB)
📄
CGIHTTPServer.pyo
(10.57 KB)
📄
ConfigParser.py
(25.38 KB)
📄
ConfigParser.pyc
(23.31 KB)
📄
ConfigParser.pyo
(23.31 KB)
📄
Cookie.py
(25.05 KB)
📄
Cookie.pyc
(21.9 KB)
📄
Cookie.pyo
(21.9 KB)
📁
Demo
📁
Doc
📄
DocXMLRPCServer.py
(10.35 KB)
📄
DocXMLRPCServer.pyc
(9.72 KB)
📄
DocXMLRPCServer.pyo
(9.62 KB)
📄
HTMLParser.py
(13.26 KB)
📄
HTMLParser.pyc
(11.97 KB)
📄
HTMLParser.pyo
(11.67 KB)
📄
MimeWriter.py
(6.33 KB)
📄
MimeWriter.pyc
(7.21 KB)
📄
MimeWriter.pyo
(7.21 KB)
📄
Queue.py
(8.37 KB)
📄
Queue.pyc
(9.23 KB)
📄
Queue.pyo
(9.23 KB)
📄
SimpleHTTPServer.py
(7.25 KB)
📄
SimpleHTTPServer.pyc
(7.58 KB)
📄
SimpleHTTPServer.pyo
(7.58 KB)
📄
SimpleXMLRPCServer.py
(21.48 KB)
📄
SimpleXMLRPCServer.pyc
(19.17 KB)
📄
SimpleXMLRPCServer.pyo
(19.17 KB)
📄
SocketServer.py
(21.8 KB)
📄
SocketServer.pyc
(22.6 KB)
📄
SocketServer.pyo
(22.6 KB)
📄
StringIO.py
(10.37 KB)
📄
StringIO.pyc
(11.26 KB)
📄
StringIO.pyo
(11.26 KB)
📁
Tools
📄
UserDict.py
(5.64 KB)
📄
UserDict.pyc
(8.68 KB)
📄
UserDict.pyo
(8.68 KB)
📄
UserList.py
(3.56 KB)
📄
UserList.pyc
(6.45 KB)
📄
UserList.pyo
(6.45 KB)
📄
UserString.py
(9.46 KB)
📄
UserString.pyc
(14.57 KB)
📄
UserString.pyo
(14.57 KB)
📄
_LWPCookieJar.py
(6.4 KB)
📄
_LWPCookieJar.pyc
(5.47 KB)
📄
_LWPCookieJar.pyo
(5.47 KB)
📄
_MozillaCookieJar.py
(5.67 KB)
📄
_MozillaCookieJar.pyc
(4.41 KB)
📄
_MozillaCookieJar.pyo
(4.37 KB)
📄
__future__.py
(4.28 KB)
📄
__future__.pyc
(4.13 KB)
📄
__future__.pyo
(4.13 KB)
📄
__phello__.foo.py
(64 B)
📄
__phello__.foo.pyc
(125 B)
📄
__phello__.foo.pyo
(125 B)
📄
_abcoll.py
(13.91 KB)
📄
_abcoll.pyc
(21.08 KB)
📄
_abcoll.pyo
(21.08 KB)
📄
_strptime.py
(19.29 KB)
📄
_strptime.pyc
(14.62 KB)
📄
_strptime.pyo
(14.62 KB)
📄
_threading_local.py
(6.95 KB)
📄
_threading_local.pyc
(6.24 KB)
📄
_threading_local.pyo
(6.24 KB)
📄
abc.py
(6.87 KB)
📄
abc.pyc
(5.93 KB)
📄
abc.pyo
(5.87 KB)
📄
aifc.py
(32.41 KB)
📄
aifc.pyc
(28.87 KB)
📄
aifc.pyo
(28.87 KB)
📄
anydbm.py
(2.56 KB)
📄
anydbm.pyc
(2.71 KB)
📄
anydbm.pyo
(2.71 KB)
📄
ast.py
(11.08 KB)
📄
ast.pyc
(12.48 KB)
📄
ast.pyo
(12.48 KB)
📄
asynchat.py
(11.13 KB)
📄
asynchat.pyc
(8.53 KB)
📄
asynchat.pyo
(8.53 KB)
📄
asyncore.py
(19.59 KB)
📄
asyncore.pyc
(18.02 KB)
📄
asyncore.pyo
(18.02 KB)
📄
atexit.py
(1.67 KB)
📄
atexit.pyc
(2.16 KB)
📄
atexit.pyo
(2.16 KB)
📄
audiodev.py
(7.42 KB)
📄
audiodev.pyc
(8.34 KB)
📄
audiodev.pyo
(8.34 KB)
📄
base64.py
(11.07 KB)
📄
base64.pyc
(10.75 KB)
📄
base64.pyo
(10.75 KB)
📄
bdb.py
(20.11 KB)
📄
bdb.pyc
(18.13 KB)
📄
bdb.pyo
(18.13 KB)
📄
binhex.py
(14.53 KB)
📄
binhex.pyc
(15.5 KB)
📄
binhex.pyo
(15.5 KB)
📄
bisect.py
(2.6 KB)
📄
bisect.pyc
(3.1 KB)
📄
bisect.pyo
(3.1 KB)
📁
bsddb
📄
cProfile.py
(6.19 KB)
📄
cProfile.pyc
(6.09 KB)
📄
cProfile.pyo
(6.09 KB)
📄
calendar.py
(22.57 KB)
📄
calendar.pyc
(27.5 KB)
📄
calendar.pyo
(27.5 KB)
📄
cgi.py
(33.67 KB)
📄
cgi.pyc
(32.05 KB)
📄
cgi.pyo
(32.05 KB)
📄
cgitb.py
(11.87 KB)
📄
cgitb.pyc
(12.17 KB)
📄
cgitb.pyo
(12.17 KB)
📄
chunk.py
(5.25 KB)
📄
chunk.pyc
(5.51 KB)
📄
chunk.pyo
(5.51 KB)
📄
cmd.py
(14.61 KB)
📄
cmd.pyc
(13.63 KB)
📄
cmd.pyo
(13.63 KB)
📄
code.py
(9.98 KB)
📄
code.pyc
(10.18 KB)
📄
code.pyo
(10.18 KB)
📄
codecs.py
(34.44 KB)
📄
codecs.pyc
(35.86 KB)
📄
codecs.pyo
(35.86 KB)
📄
codeop.py
(5.86 KB)
📄
codeop.pyc
(6.48 KB)
📄
codeop.pyo
(6.48 KB)
📄
collections.py
(13.41 KB)
📄
collections.pyc
(14.12 KB)
📄
collections.pyo
(14.07 KB)
📄
colorsys.py
(3.38 KB)
📄
colorsys.pyc
(3.95 KB)
📄
colorsys.pyo
(3.95 KB)
📄
commands.py
(2.48 KB)
📄
commands.pyc
(2.43 KB)
📄
commands.pyo
(2.43 KB)
📄
compileall.py
(5.16 KB)
📄
compileall.pyc
(4.88 KB)
📄
compileall.pyo
(4.88 KB)
📁
compiler
📁
config
📄
contextlib.py
(4.04 KB)
📄
contextlib.pyc
(4.05 KB)
📄
contextlib.pyo
(4.05 KB)
📄
cookielib.py
(62.94 KB)
📄
cookielib.pyc
(53.95 KB)
📄
cookielib.pyo
(53.76 KB)
📄
copy.py
(10.92 KB)
📄
copy.pyc
(11.4 KB)
📄
copy.pyo
(11.31 KB)
📄
copy_reg.py
(6.64 KB)
📄
copy_reg.pyc
(5.06 KB)
📄
copy_reg.pyo
(5.01 KB)
📄
crypt.py
(2.18 KB)
📄
crypt.pyc
(2.98 KB)
📄
crypt.pyo
(2.98 KB)
📄
csv.py
(15.36 KB)
📄
csv.pyc
(12.92 KB)
📄
csv.pyo
(12.92 KB)
📁
ctypes
📁
curses
📄
dbhash.py
(535 B)
📄
dbhash.pyc
(760 B)
📄
dbhash.pyo
(760 B)
📄
decimal.py
(194.6 KB)
📄
decimal.pyc
(152.03 KB)
📄
decimal.pyo
(151.97 KB)
📄
difflib.py
(79.18 KB)
📄
difflib.pyc
(59.76 KB)
📄
difflib.pyo
(59.71 KB)
📄
dircache.py
(1.1 KB)
📄
dircache.pyc
(1.55 KB)
📄
dircache.pyo
(1.55 KB)
📄
dis.py
(6.3 KB)
📄
dis.pyc
(6.22 KB)
📄
dis.pyo
(6.22 KB)
📁
distutils
📄
doctest.py
(99.14 KB)
📄
doctest.pyc
(79.1 KB)
📄
doctest.pyo
(78.81 KB)
📄
dumbdbm.py
(8.61 KB)
📄
dumbdbm.pyc
(6.43 KB)
📄
dumbdbm.pyo
(6.43 KB)
📄
dummy_thread.py
(4.31 KB)
📄
dummy_thread.pyc
(5.29 KB)
📄
dummy_thread.pyo
(5.29 KB)
📄
dummy_threading.py
(2.74 KB)
📄
dummy_threading.pyc
(1.27 KB)
📄
dummy_threading.pyo
(1.27 KB)
📁
email
📁
encodings
📄
filecmp.py
(9.25 KB)
📄
filecmp.pyc
(9.41 KB)
📄
filecmp.pyo
(9.41 KB)
📄
fileinput.py
(13.81 KB)
📄
fileinput.pyc
(14.58 KB)
📄
fileinput.pyo
(14.58 KB)
📄
fnmatch.py
(3.16 KB)
📄
fnmatch.pyc
(3.5 KB)
📄
fnmatch.pyo
(3.5 KB)
📄
formatter.py
(14.56 KB)
📄
formatter.pyc
(18.85 KB)
📄
formatter.pyo
(18.85 KB)
📄
fpformat.py
(4.59 KB)
📄
fpformat.pyc
(4.62 KB)
📄
fpformat.pyo
(4.62 KB)
📄
fractions.py
(19.6 KB)
📄
fractions.pyc
(17.69 KB)
📄
fractions.pyo
(17.69 KB)
📄
ftplib.py
(28.51 KB)
📄
ftplib.pyc
(27.83 KB)
📄
ftplib.pyo
(27.83 KB)
📄
functools.py
(2.11 KB)
📄
functools.pyc
(1.88 KB)
📄
functools.pyo
(1.88 KB)
📄
genericpath.py
(2.95 KB)
📄
genericpath.pyc
(3.21 KB)
📄
genericpath.pyo
(3.21 KB)
📄
getopt.py
(7.16 KB)
📄
getopt.pyc
(6.57 KB)
📄
getopt.pyo
(6.53 KB)
📄
getpass.py
(5.4 KB)
📄
getpass.pyc
(4.64 KB)
📄
getpass.pyo
(4.64 KB)
📄
gettext.py
(19.5 KB)
📄
gettext.pyc
(15.39 KB)
📄
gettext.pyo
(15.39 KB)
📄
glob.py
(2.2 KB)
📄
glob.pyc
(2.35 KB)
📄
glob.pyo
(2.35 KB)
📄
gzip.py
(16.36 KB)
📄
gzip.pyc
(14.05 KB)
📄
gzip.pyo
(14.05 KB)
📄
hashlib.py
(4.32 KB)
📄
hashlib.pyc
(3.89 KB)
📄
hashlib.pyo
(3.89 KB)
📄
heapq.py
(15.62 KB)
📄
heapq.pyc
(12.4 KB)
📄
heapq.pyo
(12.4 KB)
📄
hmac.py
(4.42 KB)
📄
hmac.pyc
(4.4 KB)
📄
hmac.pyo
(4.4 KB)
📁
hotshot
📄
htmlentitydefs.py
(17.63 KB)
📄
htmlentitydefs.pyc
(6.22 KB)
📄
htmlentitydefs.pyo
(6.22 KB)
📄
htmllib.py
(12.57 KB)
📄
htmllib.pyc
(19.91 KB)
📄
htmllib.pyo
(19.91 KB)
📄
httplib.py
(46.77 KB)
📄
httplib.pyc
(36.17 KB)
📄
httplib.pyo
(35.98 KB)
📁
idlelib
📄
ihooks.py
(17.04 KB)
📄
ihooks.pyc
(20.35 KB)
📄
ihooks.pyo
(20.27 KB)
📄
imaplib.py
(46.65 KB)
📄
imaplib.pyc
(44.17 KB)
📄
imaplib.pyo
(41.48 KB)
📄
imghdr.py
(3.46 KB)
📄
imghdr.pyc
(4.79 KB)
📄
imghdr.pyo
(4.79 KB)
📄
imputil.py
(25.4 KB)
📄
imputil.pyc
(15.66 KB)
📄
imputil.pyo
(15.49 KB)
📄
inspect.py
(37.29 KB)
📄
inspect.pyc
(36.29 KB)
📄
inspect.pyo
(36.29 KB)
📄
io.py
(64.61 KB)
📄
io.pyc
(61.56 KB)
📄
io.pyo
(61.56 KB)
📁
json
📄
keyword.py
(1.95 KB)
📄
keyword.pyc
(2.07 KB)
📄
keyword.pyo
(2.07 KB)
📁
lib-dynload
📁
lib-tk
📁
lib2to3
📄
linecache.py
(4.03 KB)
📄
linecache.pyc
(3.19 KB)
📄
linecache.pyo
(3.19 KB)
📄
locale.py
(80.74 KB)
📄
locale.pyc
(45.58 KB)
📄
locale.pyo
(45.58 KB)
📁
logging
📄
macpath.py
(6.11 KB)
📄
macpath.pyc
(7.53 KB)
📄
macpath.pyo
(7.53 KB)
📄
macurl2path.py
(3.2 KB)
📄
macurl2path.pyc
(2.76 KB)
📄
macurl2path.pyo
(2.76 KB)
📄
mailbox.py
(74.05 KB)
📄
mailbox.pyc
(74.29 KB)
📄
mailbox.pyo
(74.24 KB)
📄
mailcap.py
(7.25 KB)
📄
mailcap.pyc
(7.02 KB)
📄
mailcap.pyo
(7.02 KB)
📄
markupbase.py
(14.01 KB)
📄
markupbase.pyc
(9.24 KB)
📄
markupbase.pyo
(9.05 KB)
📄
md5.py
(410 B)
📄
md5.pyc
(378 B)
📄
md5.pyo
(378 B)
📄
mhlib.py
(32.65 KB)
📄
mhlib.pyc
(33.34 KB)
📄
mhlib.pyo
(33.34 KB)
📄
mimetools.py
(7 KB)
📄
mimetools.pyc
(8.13 KB)
📄
mimetools.pyo
(8.13 KB)
📄
mimetypes.py
(18.38 KB)
📄
mimetypes.pyc
(16.48 KB)
📄
mimetypes.pyo
(16.48 KB)
📄
mimify.py
(14.67 KB)
📄
mimify.pyc
(11.93 KB)
📄
mimify.pyo
(11.93 KB)
📄
modulefinder.py
(23.71 KB)
📄
modulefinder.pyc
(18.56 KB)
📄
modulefinder.pyo
(18.48 KB)
📄
multifile.py
(4.71 KB)
📄
multifile.pyc
(5.35 KB)
📄
multifile.pyo
(5.31 KB)
📁
multiprocessing
📄
mutex.py
(1.82 KB)
📄
mutex.pyc
(2.47 KB)
📄
mutex.pyo
(2.47 KB)
📄
netrc.py
(4.01 KB)
📄
netrc.pyc
(3.52 KB)
📄
netrc.pyo
(3.52 KB)
📄
new.py
(706 B)
📄
new.pyc
(910 B)
📄
new.pyo
(910 B)
📄
nntplib.py
(20.97 KB)
📄
nntplib.pyc
(20.68 KB)
📄
nntplib.pyo
(20.68 KB)
📄
ntpath.py
(17.34 KB)
📄
ntpath.pyc
(11.35 KB)
📄
ntpath.pyo
(11.3 KB)
📄
nturl2path.py
(2.19 KB)
📄
nturl2path.pyc
(1.74 KB)
📄
nturl2path.pyo
(1.74 KB)
📄
numbers.py
(10.03 KB)
📄
numbers.pyc
(13.64 KB)
📄
numbers.pyo
(13.64 KB)
📄
opcode.py
(5.13 KB)
📄
opcode.pyc
(5.78 KB)
📄
opcode.pyo
(5.78 KB)
📄
optparse.py
(59.42 KB)
📄
optparse.pyc
(52.97 KB)
📄
optparse.pyo
(52.89 KB)
📄
ordereddict.py
(36 B)
📄
ordereddict.pyc
(185 B)
📄
ordereddict.pyo
(185 B)
📄
os.py
(25.2 KB)
📄
os.pyc
(25.2 KB)
📄
os.pyo
(25.2 KB)
📄
os2emxpath.py
(4.5 KB)
📄
os2emxpath.pyc
(4.43 KB)
📄
os2emxpath.pyo
(4.43 KB)
📄
pdb.doc
(7.71 KB)
📄
pdb.py
(44.27 KB)
📄
pdb.pyc
(42.79 KB)
📄
pdb.pyo
(42.79 KB)
📄
pickle.py
(43.76 KB)
📄
pickle.pyc
(37.74 KB)
📄
pickle.pyo
(37.54 KB)
📄
pickletools.py
(72.61 KB)
📄
pickletools.pyc
(55.8 KB)
📄
pickletools.pyo
(54.93 KB)
📄
pipes.py
(9.42 KB)
📄
pipes.pyc
(9.24 KB)
📄
pipes.pyo
(9.24 KB)
📄
pkgutil.py
(19.53 KB)
📄
pkgutil.pyc
(18.57 KB)
📄
pkgutil.pyo
(18.57 KB)
📁
plat-linux2
📄
platform.py
(51.39 KB)
📄
platform.pyc
(37.87 KB)
📄
platform.pyo
(37.87 KB)
📄
plistlib.py
(14.83 KB)
📄
plistlib.pyc
(18.88 KB)
📄
plistlib.pyo
(18.79 KB)
📄
popen2.py
(8.22 KB)
📄
popen2.pyc
(8.85 KB)
📄
popen2.pyo
(8.81 KB)
📄
poplib.py
(12.52 KB)
📄
poplib.pyc
(13.1 KB)
📄
poplib.pyo
(13.1 KB)
📄
posixfile.py
(7.82 KB)
📄
posixfile.pyc
(7.54 KB)
📄
posixfile.pyo
(7.54 KB)
📄
posixpath.py
(12.81 KB)
📄
posixpath.pyc
(10.93 KB)
📄
posixpath.pyo
(10.93 KB)
📄
pprint.py
(11.65 KB)
📄
pprint.pyc
(10.15 KB)
📄
pprint.pyo
(9.98 KB)
📄
profile.py
(22.96 KB)
📄
profile.pyc
(16.29 KB)
📄
profile.pyo
(16.05 KB)
📄
pstats.py
(26.67 KB)
📄
pstats.pyc
(24.75 KB)
📄
pstats.pyo
(24.75 KB)
📄
pty.py
(4.75 KB)
📄
pty.pyc
(4.8 KB)
📄
pty.pyo
(4.8 KB)
📄
py_compile.py
(5.5 KB)
📄
py_compile.pyc
(6.4 KB)
📄
py_compile.pyo
(6.4 KB)
📄
pyclbr.py
(12.97 KB)
📄
pyclbr.pyc
(9.5 KB)
📄
pyclbr.pyo
(9.5 KB)
📄
pydoc.py
(90.27 KB)
📄
pydoc.pyc
(88.92 KB)
📄
pydoc.pyo
(88.85 KB)
📄
pydoc_topics.py
(413.21 KB)
📄
pydoc_topics.pyc
(398.04 KB)
📄
pydoc_topics.pyo
(398.04 KB)
📄
quopri.py
(6.81 KB)
📄
quopri.pyc
(6.53 KB)
📄
quopri.pyo
(6.53 KB)
📄
random.py
(31.22 KB)
📄
random.pyc
(24.52 KB)
📄
random.pyo
(24.52 KB)
📄
re.py
(12.66 KB)
📄
re.pyc
(12.86 KB)
📄
re.pyo
(12.86 KB)
📄
repr.py
(4.2 KB)
📄
repr.pyc
(5.31 KB)
📄
repr.pyo
(5.31 KB)
📄
rexec.py
(19.68 KB)
📄
rexec.pyc
(23.65 KB)
📄
rexec.pyo
(23.65 KB)
📄
rfc822.py
(32.51 KB)
📄
rfc822.pyc
(31.36 KB)
📄
rfc822.pyo
(31.36 KB)
📄
rlcompleter.py
(5.73 KB)
📄
rlcompleter.pyc
(5.93 KB)
📄
rlcompleter.pyo
(5.93 KB)
📄
robotparser.py
(6.85 KB)
📄
robotparser.pyc
(7.67 KB)
📄
robotparser.pyo
(7.67 KB)
📄
runpy.py
(5.29 KB)
📄
runpy.pyc
(3.89 KB)
📄
runpy.pyo
(3.89 KB)
📄
sched.py
(4.97 KB)
📄
sched.pyc
(4.89 KB)
📄
sched.pyo
(4.89 KB)
📄
sets.py
(18.6 KB)
📄
sets.pyc
(16.6 KB)
📄
sets.pyo
(16.6 KB)
📄
sgmllib.py
(17.46 KB)
📄
sgmllib.pyc
(15.23 KB)
📄
sgmllib.pyo
(15.23 KB)
📄
sha.py
(445 B)
📄
sha.pyc
(421 B)
📄
sha.pyo
(421 B)
📄
shelve.py
(7.89 KB)
📄
shelve.pyc
(10.05 KB)
📄
shelve.pyo
(10.05 KB)
📄
shlex.py
(10.88 KB)
📄
shlex.pyc
(7.53 KB)
📄
shlex.pyo
(7.53 KB)
📄
shutil.py
(8.43 KB)
📄
shutil.pyc
(9.33 KB)
📄
shutil.pyo
(9.33 KB)
📁
site-packages
📄
site.py
(18.74 KB)
📄
site.pyc
(18.38 KB)
📄
site.pyo
(18.38 KB)
📄
smtpd.py
(18.48 KB)
📄
smtpd.pyc
(15.81 KB)
📄
smtpd.pyo
(15.81 KB)
📄
smtplib.py
(30.2 KB)
📄
smtplib.pyc
(29.04 KB)
📄
smtplib.pyo
(29.04 KB)
📄
sndhdr.py
(5.83 KB)
📄
sndhdr.pyc
(7.25 KB)
📄
sndhdr.pyo
(7.25 KB)
📄
socket.py
(19.68 KB)
📄
socket.pyc
(15.75 KB)
📄
socket.pyo
(15.67 KB)
📁
sqlite3
📄
sre.py
(384 B)
📄
sre.pyc
(519 B)
📄
sre.pyo
(519 B)
📄
sre_compile.py
(16.12 KB)
📄
sre_compile.pyc
(11.21 KB)
📄
sre_compile.pyo
(11.1 KB)
📄
sre_constants.py
(6.97 KB)
📄
sre_constants.pyc
(5.95 KB)
📄
sre_constants.pyo
(5.95 KB)
📄
sre_parse.py
(26.25 KB)
📄
sre_parse.pyc
(19.23 KB)
📄
sre_parse.pyo
(19.23 KB)
📄
ssl.py
(14.48 KB)
📄
ssl.pyc
(13.35 KB)
📄
ssl.pyo
(13.35 KB)
📄
stat.py
(1.68 KB)
📄
stat.pyc
(2.64 KB)
📄
stat.pyo
(2.64 KB)
📄
statvfs.py
(898 B)
📄
statvfs.pyc
(620 B)
📄
statvfs.pyo
(620 B)
📄
string.py
(20.26 KB)
📄
string.pyc
(19.6 KB)
📄
string.pyo
(19.6 KB)
📄
stringold.py
(12.16 KB)
📄
stringold.pyc
(12.3 KB)
📄
stringold.pyo
(12.3 KB)
📄
stringprep.py
(13.21 KB)
📄
stringprep.pyc
(14.19 KB)
📄
stringprep.pyo
(14.11 KB)
📄
struct.py
(82 B)
📄
struct.pyc
(239 B)
📄
struct.pyo
(239 B)
📄
subprocess.py
(56.59 KB)
📄
subprocess.pyc
(40.11 KB)
📄
subprocess.pyo
(40.05 KB)
📄
sunau.py
(16.15 KB)
📄
sunau.pyc
(17.65 KB)
📄
sunau.pyo
(17.65 KB)
📄
sunaudio.py
(1.37 KB)
📄
sunaudio.pyc
(1.95 KB)
📄
sunaudio.pyo
(1.95 KB)
📄
symbol.py
(2 KB)
📄
symbol.pyc
(2.95 KB)
📄
symbol.pyo
(2.95 KB)
📄
symtable.py
(7.73 KB)
📄
symtable.pyc
(12.31 KB)
📄
symtable.pyo
(12.19 KB)
📄
tabnanny.py
(11.07 KB)
📄
tabnanny.pyc
(8.14 KB)
📄
tabnanny.pyo
(8.14 KB)
📄
tarfile.py
(84.81 KB)
📄
tarfile.pyc
(71.79 KB)
📄
tarfile.pyo
(71.79 KB)
📄
telnetlib.py
(21.3 KB)
📄
telnetlib.pyc
(19.45 KB)
📄
telnetlib.pyo
(19.45 KB)
📄
tempfile.py
(17.36 KB)
📄
tempfile.pyc
(19.11 KB)
📄
tempfile.pyo
(19.11 KB)
📁
test
📄
textwrap.py
(16.49 KB)
📄
textwrap.pyc
(11.52 KB)
📄
textwrap.pyo
(11.43 KB)
📄
this.py
(1002 B)
📄
this.pyc
(1.21 KB)
📄
this.pyo
(1.21 KB)
📄
threading.py
(31.06 KB)
📄
threading.pyc
(27.49 KB)
📄
threading.pyo
(25.47 KB)
📄
timeit.py
(11.72 KB)
📄
timeit.pyc
(11.55 KB)
📄
timeit.pyo
(11.55 KB)
📄
toaiff.py
(3.07 KB)
📄
toaiff.pyc
(3.06 KB)
📄
toaiff.pyo
(3.06 KB)
📄
token.py
(2.88 KB)
📄
token.pyc
(3.75 KB)
📄
token.pyo
(3.75 KB)
📄
tokenize.py
(15.94 KB)
📄
tokenize.pyc
(13.69 KB)
📄
tokenize.pyo
(13.6 KB)
📄
trace.py
(29.61 KB)
📄
trace.pyc
(22.51 KB)
📄
trace.pyo
(22.45 KB)
📄
traceback.py
(10.95 KB)
📄
traceback.pyc
(11.4 KB)
📄
traceback.pyo
(11.4 KB)
📄
tty.py
(879 B)
📄
tty.pyc
(1.29 KB)
📄
tty.pyo
(1.29 KB)
📄
types.py
(2.27 KB)
📄
types.pyc
(2.56 KB)
📄
types.pyo
(2.56 KB)
📄
unittest.py
(30.43 KB)
📄
unittest.pyc
(34.04 KB)
📄
unittest.pyo
(34.04 KB)
📄
urllib.py
(57.64 KB)
📄
urllib.pyc
(50.14 KB)
📄
urllib.pyo
(50.05 KB)
📄
urllib2.py
(49.39 KB)
📄
urllib2.pyc
(44.74 KB)
📄
urllib2.pyo
(44.65 KB)
📄
urlparse.py
(14.16 KB)
📄
urlparse.pyc
(13.72 KB)
📄
urlparse.pyo
(13.72 KB)
📄
user.py
(1.59 KB)
📄
user.pyc
(1.7 KB)
📄
user.pyo
(1.7 KB)
📄
uu.py
(5.8 KB)
📄
uu.pyc
(4.14 KB)
📄
uu.pyo
(4.14 KB)
📄
uuid.py
(20.45 KB)
📄
uuid.pyc
(20.78 KB)
📄
uuid.pyo
(20.78 KB)
📄
warnings.py
(13.84 KB)
📄
warnings.pyc
(12.74 KB)
📄
warnings.pyo
(11.92 KB)
📄
wave.py
(17.53 KB)
📄
wave.pyc
(18.98 KB)
📄
wave.pyo
(18.98 KB)
📄
weakref.py
(9.85 KB)
📄
weakref.pyc
(13.06 KB)
📄
weakref.pyo
(13.06 KB)
📄
webbrowser.py
(20.58 KB)
📄
webbrowser.pyc
(18.32 KB)
📄
webbrowser.pyo
(18.27 KB)
📄
whichdb.py
(3.27 KB)
📄
whichdb.pyc
(2.19 KB)
📄
whichdb.pyo
(2.19 KB)
📁
wsgiref
📄
xdrlib.py
(5.38 KB)
📄
xdrlib.pyc
(8.94 KB)
📄
xdrlib.pyo
(8.94 KB)
📁
xml
📄
xmllib.py
(34.05 KB)
📄
xmllib.pyc
(26.63 KB)
📄
xmllib.pyo
(26.63 KB)
📄
xmlrpclib.py
(46.66 KB)
📄
xmlrpclib.pyc
(40.52 KB)
📄
xmlrpclib.pyo
(40.34 KB)
📄
zipfile.py
(51.85 KB)
📄
zipfile.pyc
(36.77 KB)
📄
zipfile.pyo
(36.77 KB)
Editing: SimpleXMLRPCServer.py
"""Simple XML-RPC Server. This module can be used to create simple XML-RPC servers by creating a server and either installing functions, a class instance, or by extending the SimpleXMLRPCServer class. It can also be used to handle XML-RPC requests in a CGI environment using CGIXMLRPCRequestHandler. A list of possible usage patterns follows: 1. Install functions: server = SimpleXMLRPCServer(("localhost", 8000)) server.register_function(pow) server.register_function(lambda x,y: x+y, 'add') server.serve_forever() 2. Install an instance: class MyFuncs: def __init__(self): # make all of the string functions available through # string.func_name import string self.string = string def _listMethods(self): # implement this method so that system.listMethods # knows to advertise the strings methods return list_public_methods(self) + \ ['string.' + method for method in list_public_methods(self.string)] def pow(self, x, y): return pow(x, y) def add(self, x, y) : return x + y server = SimpleXMLRPCServer(("localhost", 8000)) server.register_introspection_functions() server.register_instance(MyFuncs()) server.serve_forever() 3. Install an instance with custom dispatch method: class Math: def _listMethods(self): # this method must be present for system.listMethods # to work return ['add', 'pow'] def _methodHelp(self, method): # this method must be present for system.methodHelp # to work if method == 'add': return "add(2,3) => 5" elif method == 'pow': return "pow(x, y[, z]) => number" else: # By convention, return empty # string if no help is available return "" def _dispatch(self, method, params): if method == 'pow': return pow(*params) elif method == 'add': return params[0] + params[1] else: raise 'bad method' server = SimpleXMLRPCServer(("localhost", 8000)) server.register_introspection_functions() server.register_instance(Math()) server.serve_forever() 4. Subclass SimpleXMLRPCServer: class MathServer(SimpleXMLRPCServer): def _dispatch(self, method, params): try: # We are forcing the 'export_' prefix on methods that are # callable through XML-RPC to prevent potential security # problems func = getattr(self, 'export_' + method) except AttributeError: raise Exception('method "%s" is not supported' % method) else: return func(*params) def export_add(self, x, y): return x + y server = MathServer(("localhost", 8000)) server.serve_forever() 5. CGI script: server = CGIXMLRPCRequestHandler() server.register_function(pow) server.handle_request() """ # Written by Brian Quinlan (brian@sweetapp.com). # Based on code written by Fredrik Lundh. import xmlrpclib from xmlrpclib import Fault import SocketServer import BaseHTTPServer import sys import os import traceback try: import fcntl except ImportError: fcntl = None def resolve_dotted_attribute(obj, attr, allow_dotted_names=True): """resolve_dotted_attribute(a, 'b.c.d') => a.b.c.d Resolves a dotted attribute name to an object. Raises an AttributeError if any attribute in the chain starts with a '_'. If the optional allow_dotted_names argument is false, dots are not supported and this function operates similar to getattr(obj, attr). """ if allow_dotted_names: attrs = attr.split('.') else: attrs = [attr] for i in attrs: if i.startswith('_'): raise AttributeError( 'attempt to access private attribute "%s"' % i ) else: obj = getattr(obj,i) return obj def list_public_methods(obj): """Returns a list of attribute strings, found in the specified object, which represent callable attributes""" return [member for member in dir(obj) if not member.startswith('_') and hasattr(getattr(obj, member), '__call__')] def remove_duplicates(lst): """remove_duplicates([2,2,2,1,3,3]) => [3,1,2] Returns a copy of a list without duplicates. Every list item must be hashable and the order of the items in the resulting list is not defined. """ u = {} for x in lst: u[x] = 1 return u.keys() class SimpleXMLRPCDispatcher: """Mix-in class that dispatches XML-RPC requests. This class is used to register XML-RPC method handlers and then to dispatch them. There should never be any reason to instantiate this class directly. """ def __init__(self, allow_none=False, encoding=None): self.funcs = {} self.instance = None self.allow_none = allow_none self.encoding = encoding def register_instance(self, instance, allow_dotted_names=False): """Registers an instance to respond to XML-RPC requests. Only one instance can be installed at a time. If the registered instance has a _dispatch method then that method will be called with the name of the XML-RPC method and its parameters as a tuple e.g. instance._dispatch('add',(2,3)) If the registered instance does not have a _dispatch method then the instance will be searched to find a matching method and, if found, will be called. Methods beginning with an '_' are considered private and will not be called by SimpleXMLRPCServer. If a registered function matches a XML-RPC request, then it will be called instead of the registered instance. If the optional allow_dotted_names argument is true and the instance does not have a _dispatch method, method names containing dots are supported and resolved, as long as none of the name segments start with an '_'. *** SECURITY WARNING: *** Enabling the allow_dotted_names options allows intruders to access your module's global variables and may allow intruders to execute arbitrary code on your machine. Only use this option on a secure, closed network. """ self.instance = instance self.allow_dotted_names = allow_dotted_names def register_function(self, function, name = None): """Registers a function to respond to XML-RPC requests. The optional name argument can be used to set a Unicode name for the function. """ if name is None: name = function.__name__ self.funcs[name] = function def register_introspection_functions(self): """Registers the XML-RPC introspection methods in the system namespace. see http://xmlrpc.usefulinc.com/doc/reserved.html """ self.funcs.update({'system.listMethods' : self.system_listMethods, 'system.methodSignature' : self.system_methodSignature, 'system.methodHelp' : self.system_methodHelp}) def register_multicall_functions(self): """Registers the XML-RPC multicall method in the system namespace. see http://www.xmlrpc.com/discuss/msgReader$1208""" self.funcs.update({'system.multicall' : self.system_multicall}) def _marshaled_dispatch(self, data, dispatch_method = None): """Dispatches an XML-RPC method from marshalled (XML) data. XML-RPC methods are dispatched from the marshalled (XML) data using the _dispatch method and the result is returned as marshalled data. For backwards compatibility, a dispatch function can be provided as an argument (see comment in SimpleXMLRPCRequestHandler.do_POST) but overriding the existing method through subclassing is the prefered means of changing method dispatch behavior. """ try: params, method = xmlrpclib.loads(data) # generate response if dispatch_method is not None: response = dispatch_method(method, params) else: response = self._dispatch(method, params) # wrap response in a singleton tuple response = (response,) response = xmlrpclib.dumps(response, methodresponse=1, allow_none=self.allow_none, encoding=self.encoding) except Fault, fault: response = xmlrpclib.dumps(fault, allow_none=self.allow_none, encoding=self.encoding) except: # report exception back to server exc_type, exc_value, exc_tb = sys.exc_info() response = xmlrpclib.dumps( xmlrpclib.Fault(1, "%s:%s" % (exc_type, exc_value)), encoding=self.encoding, allow_none=self.allow_none, ) return response def system_listMethods(self): """system.listMethods() => ['add', 'subtract', 'multiple'] Returns a list of the methods supported by the server.""" methods = self.funcs.keys() if self.instance is not None: # Instance can implement _listMethod to return a list of # methods if hasattr(self.instance, '_listMethods'): methods = remove_duplicates( methods + self.instance._listMethods() ) # if the instance has a _dispatch method then we # don't have enough information to provide a list # of methods elif not hasattr(self.instance, '_dispatch'): methods = remove_duplicates( methods + list_public_methods(self.instance) ) methods.sort() return methods def system_methodSignature(self, method_name): """system.methodSignature('add') => [double, int, int] Returns a list describing the signature of the method. In the above example, the add method takes two integers as arguments and returns a double result. This server does NOT support system.methodSignature.""" # See http://xmlrpc.usefulinc.com/doc/sysmethodsig.html return 'signatures not supported' def system_methodHelp(self, method_name): """system.methodHelp('add') => "Adds two integers together" Returns a string containing documentation for the specified method.""" method = None if method_name in self.funcs: method = self.funcs[method_name] elif self.instance is not None: # Instance can implement _methodHelp to return help for a method if hasattr(self.instance, '_methodHelp'): return self.instance._methodHelp(method_name) # if the instance has a _dispatch method then we # don't have enough information to provide help elif not hasattr(self.instance, '_dispatch'): try: method = resolve_dotted_attribute( self.instance, method_name, self.allow_dotted_names ) except AttributeError: pass # Note that we aren't checking that the method actually # be a callable object of some kind if method is None: return "" else: import pydoc return pydoc.getdoc(method) def system_multicall(self, call_list): """system.multicall([{'methodName': 'add', 'params': [2, 2]}, ...]) => \ [[4], ...] Allows the caller to package multiple XML-RPC calls into a single request. See http://www.xmlrpc.com/discuss/msgReader$1208 """ results = [] for call in call_list: method_name = call['methodName'] params = call['params'] try: # XXX A marshalling error in any response will fail the entire # multicall. If someone cares they should fix this. results.append([self._dispatch(method_name, params)]) except Fault, fault: results.append( {'faultCode' : fault.faultCode, 'faultString' : fault.faultString} ) except: exc_type, exc_value, exc_tb = sys.exc_info() results.append( {'faultCode' : 1, 'faultString' : "%s:%s" % (exc_type, exc_value)} ) return results def _dispatch(self, method, params): """Dispatches the XML-RPC method. XML-RPC calls are forwarded to a registered function that matches the called XML-RPC method name. If no such function exists then the call is forwarded to the registered instance, if available. If the registered instance has a _dispatch method then that method will be called with the name of the XML-RPC method and its parameters as a tuple e.g. instance._dispatch('add',(2,3)) If the registered instance does not have a _dispatch method then the instance will be searched to find a matching method and, if found, will be called. Methods beginning with an '_' are considered private and will not be called. """ func = None try: # check to see if a matching function has been registered func = self.funcs[method] except KeyError: if self.instance is not None: # check for a _dispatch method if hasattr(self.instance, '_dispatch'): return self.instance._dispatch(method, params) else: # call instance method directly try: func = resolve_dotted_attribute( self.instance, method, self.allow_dotted_names ) except AttributeError: pass if func is not None: return func(*params) else: raise Exception('method "%s" is not supported' % method) class SimpleXMLRPCRequestHandler(BaseHTTPServer.BaseHTTPRequestHandler): """Simple XML-RPC request handler class. Handles all HTTP POST requests and attempts to decode them as XML-RPC requests. """ # Class attribute listing the accessible path components; # paths not on this list will result in a 404 error. rpc_paths = ('/', '/RPC2') def is_rpc_path_valid(self): if self.rpc_paths: return self.path in self.rpc_paths else: # If .rpc_paths is empty, just assume all paths are legal return True def do_POST(self): """Handles the HTTP POST request. Attempts to interpret all HTTP POST requests as XML-RPC calls, which are forwarded to the server's _dispatch method for handling. """ # Check that the path is legal if not self.is_rpc_path_valid(): self.report_404() return try: # Get arguments by reading body of request. # We read this in chunks to avoid straining # socket.read(); around the 10 or 15Mb mark, some platforms # begin to have problems (bug #792570). max_chunk_size = 10*1024*1024 size_remaining = int(self.headers["content-length"]) L = [] while size_remaining: chunk_size = min(size_remaining, max_chunk_size) chunk = self.rfile.read(chunk_size) if not chunk: break L.append(chunk) size_remaining -= len(L[-1]) data = ''.join(L) # In previous versions of SimpleXMLRPCServer, _dispatch # could be overridden in this class, instead of in # SimpleXMLRPCDispatcher. To maintain backwards compatibility, # check to see if a subclass implements _dispatch and dispatch # using that method if present. response = self.server._marshaled_dispatch( data, getattr(self, '_dispatch', None) ) except Exception, e: # This should only happen if the module is buggy # internal error, report as HTTP server error self.send_response(500) # Send information about the exception if requested if hasattr(self.server, '_send_traceback_header') and \ self.server._send_traceback_header: self.send_header("X-exception", str(e)) self.send_header("X-traceback", traceback.format_exc()) self.end_headers() else: # got a valid XML RPC response self.send_response(200) self.send_header("Content-type", "text/xml") self.send_header("Content-length", str(len(response))) self.end_headers() self.wfile.write(response) # shut down the connection self.wfile.flush() self.connection.shutdown(1) def report_404 (self): # Report a 404 error self.send_response(404) response = 'No such page' self.send_header("Content-type", "text/plain") self.send_header("Content-length", str(len(response))) self.end_headers() self.wfile.write(response) # shut down the connection self.wfile.flush() self.connection.shutdown(1) def log_request(self, code='-', size='-'): """Selectively log an accepted request.""" if self.server.logRequests: BaseHTTPServer.BaseHTTPRequestHandler.log_request(self, code, size) class SimpleXMLRPCServer(SocketServer.TCPServer, SimpleXMLRPCDispatcher): """Simple XML-RPC server. Simple XML-RPC server that allows functions and a single instance to be installed to handle requests. The default implementation attempts to dispatch XML-RPC calls to the functions or instance installed in the server. Override the _dispatch method inhereted from SimpleXMLRPCDispatcher to change this behavior. """ allow_reuse_address = True # Warning: this is for debugging purposes only! Never set this to True in # production code, as will be sending out sensitive information (exception # and stack trace details) when exceptions are raised inside # SimpleXMLRPCRequestHandler.do_POST _send_traceback_header = False def __init__(self, addr, requestHandler=SimpleXMLRPCRequestHandler, logRequests=True, allow_none=False, encoding=None, bind_and_activate=True): self.logRequests = logRequests SimpleXMLRPCDispatcher.__init__(self, allow_none, encoding) SocketServer.TCPServer.__init__(self, addr, requestHandler, bind_and_activate) # [Bug #1222790] If possible, set close-on-exec flag; if a # method spawns a subprocess, the subprocess shouldn't have # the listening socket open. if fcntl is not None and hasattr(fcntl, 'FD_CLOEXEC'): flags = fcntl.fcntl(self.fileno(), fcntl.F_GETFD) flags |= fcntl.FD_CLOEXEC fcntl.fcntl(self.fileno(), fcntl.F_SETFD, flags) class CGIXMLRPCRequestHandler(SimpleXMLRPCDispatcher): """Simple handler for XML-RPC data passed through CGI.""" def __init__(self, allow_none=False, encoding=None): SimpleXMLRPCDispatcher.__init__(self, allow_none, encoding) def handle_xmlrpc(self, request_text): """Handle a single XML-RPC request""" response = self._marshaled_dispatch(request_text) print 'Content-Type: text/xml' print 'Content-Length: %d' % len(response) print sys.stdout.write(response) def handle_get(self): """Handle a single HTTP GET request. Default implementation indicates an error because XML-RPC uses the POST method. """ code = 400 message, explain = \ BaseHTTPServer.BaseHTTPRequestHandler.responses[code] response = BaseHTTPServer.DEFAULT_ERROR_MESSAGE % \ { 'code' : code, 'message' : message, 'explain' : explain } print 'Status: %d %s' % (code, message) print 'Content-Type: text/html' print 'Content-Length: %d' % len(response) print sys.stdout.write(response) def handle_request(self, request_text = None): """Handle a single XML-RPC request passed through a CGI post method. If no XML data is given then it is read from stdin. The resulting XML-RPC response is printed to stdout along with the correct HTTP headers. """ if request_text is None and \ os.environ.get('REQUEST_METHOD', None) == 'GET': self.handle_get() else: # POST data is normally available through stdin try: length = int(os.environ.get('CONTENT_LENGTH', None)) except (TypeError, ValueError): length = -1 if request_text is None: request_text = sys.stdin.read(length) self.handle_xmlrpc(request_text) if __name__ == '__main__': print 'Running XML-RPC server on port 8000' server = SimpleXMLRPCServer(("localhost", 8000)) server.register_function(pow) server.register_function(lambda x,y: x+y, 'add') server.serve_forever()
Upload File
Create Folder