aboutsummaryrefslogtreecommitdiff
path: root/qutebrowser/redirects.py
diff options
context:
space:
mode:
authorSn4il <sn4il@thedroth.rocks>2023-11-23 21:28:59 +0300
committerSn4il <sn4il@thedroth.rocks>2023-11-23 21:28:59 +0300
commitcb765ee3197f4647ed96f56057fe3e8284983980 (patch)
treeb5152b2aef03bc5a1b9c04eb5560d1341fcadddf /qutebrowser/redirects.py
parenteedda36c5308b7b7f016525576dbfd204f76aff3 (diff)
downloaddotfiles-cb765ee3197f4647ed96f56057fe3e8284983980.tar.gz
dotfiles-cb765ee3197f4647ed96f56057fe3e8284983980.zip
Qutebrowser - redirects + Dracula theme
Diffstat (limited to 'qutebrowser/redirects.py')
-rw-r--r--qutebrowser/redirects.py180
1 files changed, 180 insertions, 0 deletions
diff --git a/qutebrowser/redirects.py b/qutebrowser/redirects.py
new file mode 100644
index 0000000..ba9aa32
--- /dev/null
+++ b/qutebrowser/redirects.py
@@ -0,0 +1,180 @@
+import random
+import re
+from qutebrowser.api import interceptor
+from qutebrowser.extensions.interceptors import RedirectException
+from qutebrowser.utils import message
+
+def fixScribePath(url):
+ """ Fix external medium blog to scribe translation.
+ Some paths from medium will go through a 'global identity'
+ path which messes up the actual url path we want to go
+ to and puts it in queries. This puts it back on the path.
+ """
+ new_path = f"{url.path()}{url.query()}"
+ url.setQuery("")
+ url.setPath(re.sub(r"m/global-identity-2redirectUrl=", "", new_path))
+
+redirects = {
+ "youtube": {
+ "source": ["youtube.com"],
+ "target": [
+ "piped.thedroth.rocks",
+ ],
+ },
+ "lbry": {
+ "source": ["odysee.com"],
+ "target": [
+ "lbry.bcow.xyz",
+ "odysee.076.ne.jp",
+ "librarian.pussthecat.org",
+ "lbry.mutahar.rocks",
+ "lbry.vern.cc",
+ ],
+ },
+ "reddit": {
+ "source": ["reddit.com"],
+ "target": [
+ "td.vern.cc",
+ "teddit.adminforge.de",
+ "teddit.artemislena.eu",
+ "teddit.bus-hit.me",
+ "teddit.hostux.net",
+ "teddit.namazso.eu",
+ "teddit.net",
+ "teddit.pussthecat.org",
+ "teddit.sethforprivacy.com",
+ "teddit.totaldarkness.net",
+ "teddit.zaggy.nl",
+ ],
+ },
+ "twitter": {
+ "source": ["twitter.com"],
+ "target": [
+ "nitter.net",
+ "nitter.42l.fr",
+ "nitter.fdn.fr",
+ "nitter.1d4.us",
+ "nitter.kavin.rocks",
+ "nitter.unixfox.eu",
+ "nitter.namazso.eu",
+ "nitter.moomoo.me",
+ "bird.trom.tf",
+ "nitter.it",
+ "twitter.censors.us",
+ "nitter.grimneko.de",
+ "twitter.076.ne.jp",
+ "n.l5.ca",
+ "unofficialbird.com",
+ "nitter.ungovernable.men",
+ ],
+ },
+ "imdb": {
+ "source": ["imdb.com"],
+ "target": [
+ "libremdb.iket.me",
+ "libremdb.pussthecat.org",
+ "ld.vern.cc",
+ "binge.whatever.social",
+ "libremdb.lunar.icu",
+ ],
+ },
+ "tiktok": {
+ "source": ["tiktok.com"],
+ "target": [
+ "proxitok.pabloferreiro.es",
+ "proxitok.pussthecat.org",
+ "tok.habedieeh.re",
+ "proxitok.privacydev.net",
+ "proxitok.odyssey346.dev",
+ "tok.artemislena.eu",
+ "tok.adminforge.de",
+ "proxitok.manasiwibi.com",
+ "tik.hostux.net",
+ "tt.vern.cc",
+ "proxitok.mha.fi",
+ "proxitok.pufe.org",
+ "proxitok.marcopisco.com",
+ "cringe.whatever.social",
+ "proxitok.lunar.icu",
+ ],
+ },
+ "imgur": {
+ "source": ["imgur.com"],
+ "target": [
+ "imgur.artemislena.eu",
+ "ri.zzls.xyz",
+ "rimgo.bus-hit.me",
+ "rimgo.fascinated.cc",
+ "rimgo.hostux.net",
+ "rimgo.kling.gg",
+ "rimgo.lunar.icu",
+ "rimgo.marcopisco.com",
+ "rimgo.privacytools.io",
+ "rimgo.projectsegfau.lt",
+ "rimgo.pussthecat.org",
+ "rimgo.totaldarkness.net",
+ "rimgo.whateveritworks.org",
+ ],
+ },
+ "medium": {
+ "source": ["medium.com"],
+ "target": [
+ "scribe.rip",
+ "scribe.nixnet.services",
+ "scribe.citizen4.eu",
+ "scribe.bus-hit.me",
+ "scribe.froth.zone",
+ "scribe.privacydev.net",
+ "sc.vern.cc",
+ ],
+ "postprocess": fixScribePath
+ },
+ "google": {
+ "source": ["google.com"],
+ "target": [
+ "whoogle.dcs0.hu",
+ ],
+ },
+ "wiki-en": {
+ "source": ["en.wikipedia.org"],
+ "target": [
+ "wiki.thedroth.rocks",
+ ],
+ },
+ "wiki-ru": {
+ "source": ["ru.wikipedia.org"],
+ "target": [
+ "wiki.thedroth.rocks",
+ ],
+ },
+}
+
+
+def rewrite(request: interceptor.Request):
+ if (
+ request.resource_type != interceptor.ResourceType.main_frame
+ or request.request_url.scheme() in {"data", "blob"}
+ ):
+ return
+
+ url = request.request_url
+
+ for service in redirects.values():
+ matched = False
+ for source in service["source"]:
+ if re.search(source, url.host()):
+ matched = True
+
+ if matched:
+ target = service["target"][random.randint(0, len(service["target"]) - 1)]
+ if target is not None and url.setHost(target) is not False:
+ if "postprocess" in service:
+ service["postprocess"](url)
+ try:
+ request.redirect(url)
+ except RedirectException as e:
+ message.error(str(e))
+ break
+
+
+interceptor.register(rewrite)