forked from pub-solar/os
feat: init working prison-break
This commit is contained in:
parent
8d0837d781
commit
182138d33c
|
@ -21,6 +21,7 @@ with prev; {
|
||||||
drone-docker-runner = writeShellScriptBin "drone-docker-runner" (import ./drone-docker-runner.nix final);
|
drone-docker-runner = writeShellScriptBin "drone-docker-runner" (import ./drone-docker-runner.nix final);
|
||||||
record-screen = writeShellScriptBin "record-screen" (import ./record-screen.nix final);
|
record-screen = writeShellScriptBin "record-screen" (import ./record-screen.nix final);
|
||||||
cockroach-bin = import ./cockroach.nix final;
|
cockroach-bin = import ./cockroach.nix final;
|
||||||
|
prison-break = import ./prison-break.nix final;
|
||||||
|
|
||||||
# ps-fixes
|
# ps-fixes
|
||||||
}
|
}
|
||||||
|
|
84
pkgs/prison-break-url.patch
Normal file
84
pkgs/prison-break-url.patch
Normal file
|
@ -0,0 +1,84 @@
|
||||||
|
diff --git a/prisonbreak/cli.py b/prisonbreak/cli.py
|
||||||
|
index 0add782..10eda94 100755
|
||||||
|
--- a/prisonbreak/cli.py
|
||||||
|
+++ b/prisonbreak/cli.py
|
||||||
|
@@ -31,7 +31,7 @@ from straight.plugin import load
|
||||||
|
|
||||||
|
|
||||||
|
def configure_debug(debug: bool) -> None:
|
||||||
|
- if debug:
|
||||||
|
+ if True:
|
||||||
|
logging.basicConfig(level=logging.DEBUG)
|
||||||
|
from http.client import HTTPConnection
|
||||||
|
|
||||||
|
@@ -57,7 +57,7 @@ def send_notify(message,title="Prison-Break",icon="dialog-warning-symbolic",do_n
|
||||||
|
|
||||||
|
def main():
|
||||||
|
args = docopt(__doc__)
|
||||||
|
- secret_url = "http://krebsco.de/secret" # return 1337
|
||||||
|
+ check_online_url = "http://detectportal.firefox.com/canonical.html"
|
||||||
|
profile = environ.get("CONNECTION_FILENAME", None)
|
||||||
|
timeout = float(args['--timeout'])
|
||||||
|
tries = int(args['--retry'])
|
||||||
|
@@ -123,8 +123,8 @@ def main():
|
||||||
|
s = requests.Session()
|
||||||
|
s.headers.update(
|
||||||
|
{
|
||||||
|
- "User-Agent": "Mozilla/5.0 (X11; Linux x86_64; rv:65.0)"
|
||||||
|
- "Gecko/20100101 Firefox/65.0"
|
||||||
|
+ "User-Agent": "Mozilla/5.0 (X11; Linux x86_64; rv:122.0)"
|
||||||
|
+ "Gecko/20100101 Firefox/122.0"
|
||||||
|
}
|
||||||
|
)
|
||||||
|
if wait:
|
||||||
|
@@ -133,7 +133,7 @@ def main():
|
||||||
|
|
||||||
|
for n in range(tries):
|
||||||
|
try:
|
||||||
|
- initial_response = s.get(secret_url,timeout=timeout)
|
||||||
|
+ initial_response = s.get(check_online_url,timeout=timeout)
|
||||||
|
except Timeout as t:
|
||||||
|
log.info(f"Timeout number {n+1}, waiting {timeout_wait} seconds")
|
||||||
|
continue
|
||||||
|
@@ -144,12 +144,12 @@ def main():
|
||||||
|
break
|
||||||
|
sleep(timeout_wait)
|
||||||
|
else:
|
||||||
|
- log.error(f'Unable to Retrieve the initial response after {tries} tires')
|
||||||
|
+ log.error(f'Unable to Retrieve the initial response after {tries} tries')
|
||||||
|
exit(1)
|
||||||
|
|
||||||
|
|
||||||
|
- if initial_response.text.startswith("1337"):
|
||||||
|
- log.info("Received the correct challenge token"
|
||||||
|
+ if 'nginx' == initial_response.headers.get('Server'):
|
||||||
|
+ log.info("Received the correct server header"
|
||||||
|
", assuming no captive portal")
|
||||||
|
if args['--force-token']:
|
||||||
|
log.info("Continuing even though we got the correct token!")
|
||||||
|
@@ -171,8 +171,9 @@ def main():
|
||||||
|
note("Trying to accept AGBs for you now!",title=f"Prison-Break Plugin {name}")
|
||||||
|
#notify2.Notification("Summary", "Some body text", "notification-message-im").show()
|
||||||
|
if plug.accept(initial_response, s):
|
||||||
|
+ log.debug(s.get(check_online_url,timeout=timeout).headers)
|
||||||
|
log.info(f"{name} successful?")
|
||||||
|
- if s.get(secret_url,timeout=timeout).text.startswith("1337"):
|
||||||
|
+ if 'nginx' == s.get(check_online_url,timeout=timeout).headers.get('Server'):
|
||||||
|
#notify2.Notification("Prison-Break", "Plugin {name} successful", "notification-message-im").show()
|
||||||
|
|
||||||
|
log.info(f"{name} successful!")
|
||||||
|
diff --git a/prisonbreak/plugins/wifionice.py b/prisonbreak/plugins/wifionice.py
|
||||||
|
index 1cee64d..38e5c74 100644
|
||||||
|
--- a/prisonbreak/plugins/wifionice.py
|
||||||
|
+++ b/prisonbreak/plugins/wifionice.py
|
||||||
|
@@ -58,8 +58,8 @@ def accept(resp: requests.Response, s: requests.Session) -> bool:
|
||||||
|
log.debug(f"data: {postdata}")
|
||||||
|
|
||||||
|
# TODO: detect the correct URL to query based on form path and url
|
||||||
|
- # The URL changed from http to http, and wifionice.de is now wifi.bahn.de
|
||||||
|
- resp = s.post("https://wifi.bahn.de/de/?url=http%3A%2F%2Fkrebsco.de%2Fsecret", data=postdata)
|
||||||
|
+ # The URL changed from wifi.bahn.de to login.wifionice.de
|
||||||
|
+ resp = s.post("https://login.wifionice.de/en/?url=http%3A%2F%2Fdetectportal.firefox.com%2Fcanonical.html", data=postdata)
|
||||||
|
log.debug(f"Return code: {resp.status_code}")
|
||||||
|
log.debug(resp.headers)
|
||||||
|
return resp.ok
|
41
pkgs/prison-break.nix
Normal file
41
pkgs/prison-break.nix
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
self:
|
||||||
|
with self;
|
||||||
|
let
|
||||||
|
straight-plugin = python3.pkgs.buildPythonPackage rec {
|
||||||
|
pname = "straight-plugin";
|
||||||
|
version = "1.5.0";
|
||||||
|
|
||||||
|
src = fetchPypi {
|
||||||
|
pname = "straight.plugin";
|
||||||
|
inherit version;
|
||||||
|
sha256 = "818a7641068932ed6436d0af0a3bb77bbbde29df0a7142c8bd1a249e7c2f0d38";
|
||||||
|
};
|
||||||
|
|
||||||
|
meta = with lib; {
|
||||||
|
description = "A simple namespaced plugin facility";
|
||||||
|
homepage = https://github.com/ironfroggy/straight.plugin;
|
||||||
|
license = licenses.mit;
|
||||||
|
maintainers = [ maintainers.makefu ];
|
||||||
|
};
|
||||||
|
};
|
||||||
|
in
|
||||||
|
python3.pkgs.buildPythonPackage {
|
||||||
|
name = "env";
|
||||||
|
src = fetchFromGitHub {
|
||||||
|
owner = "makefu";
|
||||||
|
repo = "prison-break";
|
||||||
|
rev = "15079bb094d37eeba92e17abfb98523076c5800c";
|
||||||
|
sha256 = "sha256-MDzAmeJ6wsTm5+unIsYAZmErVN4sEAfih3YwbXkVIPg=";
|
||||||
|
};
|
||||||
|
propagatedBuildInputs = with python3.pkgs;[
|
||||||
|
docopt
|
||||||
|
requests
|
||||||
|
beautifulsoup4
|
||||||
|
notify2
|
||||||
|
straight-plugin
|
||||||
|
];
|
||||||
|
patches = [
|
||||||
|
./prison-break-url.patch
|
||||||
|
];
|
||||||
|
checkInputs = [ python3.pkgs.black ];
|
||||||
|
}
|
Loading…
Reference in a new issue