__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
from __future__ import annotations
from collections.abc import Sequence
import functools
import re
DECODE_DEFAULT_CHARS = ";/?:@&=+$,#"
DECODE_COMPONENT_CHARS = ""
decode_cache: dict[str, list[str]] = {}
def get_decode_cache(exclude: str) -> Sequence[str]:
if exclude in decode_cache:
return decode_cache[exclude]
cache: list[str] = []
decode_cache[exclude] = cache
for i in range(128):
ch = chr(i)
cache.append(ch)
for i in range(len(exclude)):
ch_code = ord(exclude[i])
cache[ch_code] = "%" + ("0" + hex(ch_code)[2:].upper())[-2:]
return cache
# Decode percent-encoded string.
#
def decode(string: str, exclude: str = DECODE_DEFAULT_CHARS) -> str:
cache = get_decode_cache(exclude)
repl_func = functools.partial(repl_func_with_cache, cache=cache)
return re.sub(r"(%[a-f0-9]{2})+", repl_func, string, flags=re.IGNORECASE)
def repl_func_with_cache(match: re.Match, cache: Sequence[str]) -> str:
seq = match.group()
result = ""
i = 0
l = len(seq) # noqa: E741
while i < l:
b1 = int(seq[i + 1 : i + 3], 16)
if b1 < 0x80:
result += cache[b1]
i += 3 # emulate JS for loop statement3
continue
if (b1 & 0xE0) == 0xC0 and (i + 3 < l):
# 110xxxxx 10xxxxxx
b2 = int(seq[i + 4 : i + 6], 16)
if (b2 & 0xC0) == 0x80:
all_bytes = bytes((b1, b2))
try:
result += all_bytes.decode()
except UnicodeDecodeError:
result += "\ufffd" * 2
i += 3
i += 3 # emulate JS for loop statement3
continue
if (b1 & 0xF0) == 0xE0 and (i + 6 < l):
# 1110xxxx 10xxxxxx 10xxxxxx
b2 = int(seq[i + 4 : i + 6], 16)
b3 = int(seq[i + 7 : i + 9], 16)
if (b2 & 0xC0) == 0x80 and (b3 & 0xC0) == 0x80:
all_bytes = bytes((b1, b2, b3))
try:
result += all_bytes.decode()
except UnicodeDecodeError:
result += "\ufffd" * 3
i += 6
i += 3 # emulate JS for loop statement3
continue
if (b1 & 0xF8) == 0xF0 and (i + 9 < l):
# 111110xx 10xxxxxx 10xxxxxx 10xxxxxx
b2 = int(seq[i + 4 : i + 6], 16)
b3 = int(seq[i + 7 : i + 9], 16)
b4 = int(seq[i + 10 : i + 12], 16)
if (b2 & 0xC0) == 0x80 and (b3 & 0xC0) == 0x80 and (b4 & 0xC0) == 0x80:
all_bytes = bytes((b1, b2, b3, b4))
try:
result += all_bytes.decode()
except UnicodeDecodeError:
result += "\ufffd" * 4
i += 9
i += 3 # emulate JS for loop statement3
continue
result += "\ufffd"
i += 3 # emulate JS for loop statement3
return result
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| __pycache__ | Folder | 0755 |
|
|
| __init__.py | File | 547 B | 0644 |
|
| _decode.py | File | 2.93 KB | 0644 |
|
| _encode.py | File | 2.54 KB | 0644 |
|
| _format.py | File | 626 B | 0644 |
|
| _parse.py | File | 11.11 KB | 0644 |
|
| _url.py | File | 284 B | 0644 |
|
| py.typed | File | 26 B | 0644 |
|