Compare commits
6 Commits
codex/fetc
...
codex/fetc
| Author | SHA1 | Date | |
|---|---|---|---|
| 6c13fbbb2f | |||
| 33282ddbcb | |||
| 7795e22744 | |||
| e83f1323cd | |||
| 194b16e09c | |||
| 423e8e28ec |
@@ -396,29 +396,6 @@ def fetch_proxy_list(url: str) -> str:
|
||||
def build_jdproxies_payload(text: str) -> Dict[str, Any]:
|
||||
if not text.strip():
|
||||
raise ValueError("Keine Proxy-Einträge zum Speichern.")
|
||||
blacklist_filter = {
|
||||
"entries": [
|
||||
"# Dies ist ein Kommentar",
|
||||
"// Dies ist auch ein Kommentar",
|
||||
"# Für jdownloader.org auskommentieren",
|
||||
"# jdownloader.org",
|
||||
"# unten für alle Accounts mit der ID 'test *' @ jdownloader.org auskommentieren",
|
||||
"#test@jdownloader.org",
|
||||
"# Kommentar unten für ein Konto mit der ID 'test' @ jdownloader.org",
|
||||
"#test$@jdownloader.org",
|
||||
"# Sie können Muster für Konto-ID und Host verwenden, z. B. accountPattern @ hostPattern",
|
||||
"",
|
||||
"my.jdownloader.org",
|
||||
"",
|
||||
"api.jdownloader.org",
|
||||
"",
|
||||
"*.jdownloader.org",
|
||||
"",
|
||||
"*.your-server.de",
|
||||
"88.99.115.46",
|
||||
],
|
||||
"type": "BLACKLIST",
|
||||
}
|
||||
entries: List[Dict[str, Any]] = []
|
||||
type_map = {
|
||||
"socks5": "SOCKS5",
|
||||
@@ -453,7 +430,7 @@ def build_jdproxies_payload(text: str) -> Dict[str, Any]:
|
||||
if not proxy_type:
|
||||
continue
|
||||
entries.append({
|
||||
"filter": blacklist_filter,
|
||||
"filter": None,
|
||||
"proxy": {
|
||||
"address": parsed.hostname,
|
||||
"password": None,
|
||||
@@ -1019,7 +996,6 @@ def render_proxies_page(
|
||||
message: str = "",
|
||||
socks5_in: str = "",
|
||||
socks4_in: str = "",
|
||||
http_in: str = "",
|
||||
out_text: str = "",
|
||||
export_path: str = "",
|
||||
) -> str:
|
||||
@@ -1049,16 +1025,11 @@ def render_proxies_page(
|
||||
<textarea name="socks4_in" rows="6" style="width:100%; max-width:860px; padding:10px; border:1px solid #ccc; border-radius:8px;">{socks4_in}</textarea>
|
||||
</div>
|
||||
|
||||
<div class="row">
|
||||
<label>HTTP (ein Proxy pro Zeile, z. B. IP:PORT)</label><br/>
|
||||
<textarea name="http_in" rows="6" style="width:100%; max-width:860px; padding:10px; border:1px solid #ccc; border-radius:8px;">{http_in}</textarea>
|
||||
</div>
|
||||
|
||||
<button type="submit">In JDownloader-Format umwandeln</button>
|
||||
</form>
|
||||
|
||||
<h2 style="margin-top:18px;">JDownloader Import-Liste</h2>
|
||||
<p class="hint">Format: <code>socks5://IP:PORT</code>, <code>socks4://IP:PORT</code>, <code>http://IP:PORT</code>. Keine Prüfung/Validierung.</p>
|
||||
<p class="hint">Format: <code>socks5://IP:PORT</code>, <code>socks4://IP:PORT</code>. Keine Prüfung/Validierung.</p>
|
||||
|
||||
<div class="row">
|
||||
<textarea id="out" rows="12" readonly style="width:100%; max-width:860px; padding:10px; border:1px solid #ccc; border-radius:8px;">{out_text}</textarea>
|
||||
@@ -1072,7 +1043,6 @@ def render_proxies_page(
|
||||
<form method="post" action="/proxies/save">
|
||||
<textarea name="socks5_in" style="display:none;">{socks5_in}</textarea>
|
||||
<textarea name="socks4_in" style="display:none;">{socks4_in}</textarea>
|
||||
<textarea name="http_in" style="display:none;">{http_in}</textarea>
|
||||
<button type="submit">Liste als JDProxies speichern</button>
|
||||
</form>
|
||||
|
||||
@@ -1152,12 +1122,10 @@ def proxies_get():
|
||||
|
||||
s5 = format_proxy_lines(socks5_in, "socks5")
|
||||
s4 = format_proxy_lines(socks4_in, "socks4")
|
||||
hp = format_proxy_lines(http_in, "http")
|
||||
combined = "\n".join([x for x in [s5, s4, hp] if x.strip()])
|
||||
combined = "\n".join([x for x in [s5, s4] if x.strip()])
|
||||
return HTMLResponse(render_proxies_page(
|
||||
socks5_in=socks5_in,
|
||||
socks4_in=socks4_in,
|
||||
http_in=http_in,
|
||||
out_text=combined,
|
||||
export_path=PROXY_EXPORT_PATH,
|
||||
))
|
||||
@@ -1168,18 +1136,15 @@ def proxies_get():
|
||||
def proxies_post(
|
||||
socks5_in: str = Form(""),
|
||||
socks4_in: str = Form(""),
|
||||
http_in: str = Form(""),
|
||||
):
|
||||
try:
|
||||
s5 = format_proxy_lines(socks5_in, "socks5")
|
||||
s4 = format_proxy_lines(socks4_in, "socks4")
|
||||
hp = format_proxy_lines(http_in, "http")
|
||||
|
||||
combined = "\n".join([x for x in [s5, s4, hp] if x.strip()])
|
||||
combined = "\n".join([x for x in [s5, s4] if x.strip()])
|
||||
return HTMLResponse(render_proxies_page(
|
||||
socks5_in=socks5_in,
|
||||
socks4_in=socks4_in,
|
||||
http_in=http_in,
|
||||
out_text=combined,
|
||||
export_path=PROXY_EXPORT_PATH,
|
||||
))
|
||||
@@ -1188,7 +1153,6 @@ def proxies_post(
|
||||
error=str(e),
|
||||
socks5_in=socks5_in,
|
||||
socks4_in=socks4_in,
|
||||
http_in=http_in,
|
||||
out_text="",
|
||||
export_path=PROXY_EXPORT_PATH,
|
||||
), status_code=400)
|
||||
@@ -1197,19 +1161,16 @@ def proxies_post(
|
||||
def proxies_save(
|
||||
socks5_in: str = Form(""),
|
||||
socks4_in: str = Form(""),
|
||||
http_in: str = Form(""),
|
||||
):
|
||||
try:
|
||||
s5 = format_proxy_lines(socks5_in, "socks5")
|
||||
s4 = format_proxy_lines(socks4_in, "socks4")
|
||||
hp = format_proxy_lines(http_in, "http")
|
||||
combined = "\n".join([x for x in [s5, s4, hp] if x.strip()])
|
||||
combined = "\n".join([x for x in [s5, s4] if x.strip()])
|
||||
export_path = save_proxy_export(combined)
|
||||
return HTMLResponse(render_proxies_page(
|
||||
message=f"Proxy-Liste gespeichert: {export_path}",
|
||||
socks5_in=socks5_in,
|
||||
socks4_in=socks4_in,
|
||||
http_in=http_in,
|
||||
out_text=combined,
|
||||
export_path=export_path,
|
||||
))
|
||||
@@ -1218,7 +1179,6 @@ def proxies_save(
|
||||
error=str(e),
|
||||
socks5_in=socks5_in,
|
||||
socks4_in=socks4_in,
|
||||
http_in=http_in,
|
||||
out_text="",
|
||||
export_path=PROXY_EXPORT_PATH,
|
||||
), status_code=400)
|
||||
|
||||
Reference in New Issue
Block a user