Linux ip-148-66-134-25.ip.secureserver.net 3.10.0-1160.119.1.el7.tuxcare.els10.x86_64 #1 SMP Fri Oct 11 21:40:41 UTC 2024 x86_64
Apache
: 148.66.134.25 | : 18.216.70.205
66 Domain
8.0.30
amvm
www.github.com/MadExploits
Terminal
AUTO ROOT
Adminer
Backdoor Destroyer
Linux Exploit
Lock Shell
Lock File
Create User
CREATE RDP
PHP Mailer
BACKCONNECT
UNLOCK SHELL
HASH IDENTIFIER
CPANEL RESET
BLACK DEFEND!
README
+ Create Folder
+ Create File
/
usr /
share /
doc /
libxml2-python-2.9.1 /
[ HOME SHELL ]
Name
Size
Permission
Action
TODO
1.58
KB
-rw-r--r--
apibuild.py
79.75
KB
-rwxr-xr-x
attribs.py
819
B
-rwxr-xr-x
build.py
1.51
KB
-rwxr-xr-x
compareNodes.py
1.48
KB
-rwxr-xr-x
ctxterror.py
1.29
KB
-rwxr-xr-x
cutnpaste.py
1.26
KB
-rwxr-xr-x
dtdvalid.py
619
B
-rwxr-xr-x
error.py
1.04
KB
-rwxr-xr-x
inbuf.py
498
B
-rwxr-xr-x
index.py
32.14
KB
-rwxr-xr-x
indexes.py
2.9
KB
-rwxr-xr-x
input_callback.py
5.01
KB
-rwxr-xr-x
libxml2class.txt
22.42
KB
-rw-r--r--
nsdel.py
1.55
KB
-rwxr-xr-x
outbuf.py
3.07
KB
-rwxr-xr-x
push.py
769
B
-rwxr-xr-x
pushSAX.py
1.46
KB
-rwxr-xr-x
pushSAXhtml.py
1.57
KB
-rwxr-xr-x
python.html
19.46
KB
-rw-r--r--
reader.py
12.23
KB
-rwxr-xr-x
reader2.py
5.22
KB
-rwxr-xr-x
reader3.py
4.06
KB
-rwxr-xr-x
reader4.py
1.15
KB
-rwxr-xr-x
reader5.py
1.22
KB
-rwxr-xr-x
reader6.py
2.61
KB
-rwxr-xr-x
reader7.py
1.72
KB
-rwxr-xr-x
reader8.py
683
B
-rwxr-xr-x
readererr.py
1.25
KB
-rwxr-xr-x
readernext.py
2.43
KB
-rwxr-xr-x
regexp.py
716
B
-rwxr-xr-x
relaxng.py
1.17
KB
-rwxr-xr-x
resolver.py
857
B
-rwxr-xr-x
schema.py
1.28
KB
-rwxr-xr-x
serialize.py
4.18
KB
-rwxr-xr-x
sync.py
3.44
KB
-rwxr-xr-x
thread2.py
2.25
KB
-rwxr-xr-x
tst.py
587
B
-rwxr-xr-x
tstLastError.py
2.83
KB
-rwxr-xr-x
tstURI.py
1.08
KB
-rwxr-xr-x
tstmem.py
720
B
-rwxr-xr-x
tstxpath.py
1.43
KB
-rwxr-xr-x
validDTD.py
1.2
KB
-rwxr-xr-x
validRNG.py
1.9
KB
-rwxr-xr-x
validSchemas.py
2.02
KB
-rwxr-xr-x
validate.py
1.68
KB
-rwxr-xr-x
walker.py
2.35
KB
-rwxr-xr-x
xpath.py
1.17
KB
-rwxr-xr-x
xpathext.py
1.1
KB
-rwxr-xr-x
xpathleak.py
1.53
KB
-rwxr-xr-x
xpathns.py
552
B
-rwxr-xr-x
xpathret.py
1.29
KB
-rwxr-xr-x
Delete
Unzip
Zip
${this.title}
Close
Code Editor : input_callback.py
#!/usr/bin/python -u # # This tests custom input callbacks # import sys import libxml2 try: import StringIO str_io = StringIO.StringIO except: import io str_io = io.StringIO # We implement a new scheme, py://strings/ that will reference this dictionary pystrings = { 'catalogs/catalog.xml' : '''<?xml version="1.0" encoding="utf-8"?> <!DOCTYPE catalog PUBLIC "-//OASIS//DTD Entity Resolution XML Catalog V1.0//EN" "http://www.oasis-open.org/committees/entity/release/1.0/catalog.dtd"> <catalog xmlns="urn:oasis:names:tc:entity:xmlns:xml:catalog"> <rewriteSystem systemIdStartString="http://example.com/dtds/" rewritePrefix="../dtds/"/> </catalog>''', 'xml/sample.xml' : '''<?xml version="1.0" encoding="utf-8"?> <!DOCTYPE root SYSTEM "http://example.com/dtds/sample.dtd"> <root>&sample.entity;</root>''', 'dtds/sample.dtd' : ''' <!ELEMENT root (#PCDATA)> <!ENTITY sample.entity "replacement text">''' } prefix = "py://strings/" startURL = prefix + "xml/sample.xml" catURL = prefix + "catalogs/catalog.xml" def my_input_cb(URI): if not(URI.startswith(prefix)): return None path = URI[len(prefix):] if path not in pystrings: return None return str_io(pystrings[path]) def run_test(desc, docpath, catalog, exp_status="verified", exp_err=[], test_callback=None, root_name="root", root_content="replacement text"): opts = libxml2.XML_PARSE_DTDLOAD | libxml2.XML_PARSE_NONET | libxml2.XML_PARSE_COMPACT actual_err = [] def my_global_error_cb(ctx, msg): actual_err.append((-1, msg)) def my_ctx_error_cb(arg, msg, severity, reserved): actual_err.append((severity, msg)) libxml2.registerErrorHandler(my_global_error_cb, None) try: parser = libxml2.createURLParserCtxt(docpath, opts) parser.setErrorHandler(my_ctx_error_cb, None) if catalog is not None: parser.addLocalCatalog(catalog) if test_callback is not None: test_callback() parser.parseDocument() doc = parser.doc() actual_status = "loaded" e = doc.getRootElement() if e.name == root_name and e.content == root_content: actual_status = "verified" doc.freeDoc() except libxml2.parserError: actual_status = "not loaded" if actual_status != exp_status: print("Test '%s' failed: expect status '%s', actual '%s'" % (desc, exp_status, actual_status)) sys.exit(1) elif actual_err != exp_err: print("Test '%s' failed" % desc) print("Expect errors:") for s,m in exp_err: print(" [%2d] '%s'" % (s,m)) print("Actual errors:") for s,m in actual_err: print(" [%2d] '%s'" % (s,m)) sys.exit(1) # Check that we cannot read custom schema without custom callback run_test(desc="Loading entity without custom callback", docpath=startURL, catalog=None, exp_status="not loaded", exp_err=[ (-1, "I/O "), (-1, "warning : "), (-1, "failed to load external entity \"py://strings/xml/sample.xml\"\n") ]) # Register handler and try to load the same entity libxml2.registerInputCallback(my_input_cb) run_test(desc="Loading entity with custom callback", docpath=startURL, catalog=None, exp_status="loaded", exp_err=[ (-1, "Attempt to load network entity http://example.com/dtds/sample.dtd"), ( 4, "Entity 'sample.entity' not defined\n") ]) # Register a catalog (also accessible via pystr://) and retry run_test(desc="Loading entity with custom callback and catalog", docpath=startURL, catalog=catURL) # Unregister custom callback when parser is already created run_test(desc="Loading entity and unregistering callback", docpath=startURL, catalog=catURL, test_callback=lambda: libxml2.popInputCallbacks(), exp_status="loaded", exp_err=[ ( 3, "failed to load external entity \"py://strings/dtds/sample.dtd\"\n"), ( 4, "Entity 'sample.entity' not defined\n") ]) # Try to load the document again run_test(desc="Retry loading document after unregistering callback", docpath=startURL, catalog=catURL, exp_status="not loaded", exp_err=[ (-1, "I/O "), (-1, "warning : "), (-1, "failed to load external entity \"py://strings/xml/sample.xml\"\n") ]) # But should be able to read standard I/O yet... run_test(desc="Loading using standard i/o after unregistering callback", docpath="tst.xml", catalog=None, root_name='doc', root_content='bar') # Now pop ALL input callbacks, should fail to load even standard I/O try: while True: libxml2.popInputCallbacks() except IndexError: pass run_test(desc="Loading using standard i/o after unregistering all callbacks", docpath="tst.xml", catalog=None, exp_status="not loaded", exp_err=[ (-1, "I/O "), (-1, "warning : "), (-1, "failed to load external entity \"tst.xml\"\n") ]) print("OK") sys.exit(0);
Close