Skip to content

Latest commit

 

History

History
110 lines (78 loc) · 4.93 KB

README.md

File metadata and controls

110 lines (78 loc) · 4.93 KB

SwapForQute

Redirect and clean URLs in qutebrowser.

SwapForQute (or just SFQ) is an userscript for qutebrowser that replaces your URLs with new ones following an easy to set configuration.

diagram

The diagram up here show, as an example, what would happen with this JSON snippet:

{
  "www.reddit.com": {
    "out": "old.reddit.com",
    "force_https": true,
    "clean_queries": true
  },
  "reddit.com": {
    "out": "old.reddit.com",
    "force_https": true,
    "clean_queries": true
  }
}

When you bounce on a www.reddit.com or reddit.com URL, the script automatically tells the browser to search for the corresponding old.reddit.com one. As you can see, you can force HTTPS and clean queries, so that all tracking garbage is wiped out in the process. Therefore, something like "https://www.reddit.com/r/emacs/comments/yubhff/zwitterionic_digressions_get_user_inputs_in_emacs/?utm_source=share&utm_medium=web2x&context=3" magically become "https://old.reddit.com/r/emacs/comments/yubhff/zwitterionic_digressions_get_user_inputs_in_emacs".

Installation and usage

Copy the script under your userscript directory:

git clone --depth 1 https://github.com/gicrisf/swapforqute ~/.config/qutebrowser/userscripts/swapforqute

Give it the permissions to work on your system:

chmod +x ~/.config/qutebrowser/userscripts/swapforqute/main.py

In the end, you should edit the configuration as you please:

vi ~/.config/qutebrowser/userscripts/swapforqute/config.json

For each item, you can set how/if:

  • Replace netloc (with what? Set out)
  • Force HTTPS (yes/no? Set force_https)
  • Delete queries (yes/no? Set clean_queries)
  • Delete fragments (yes/no? Set clean_fragments)

Every element is optional. You can choose to force https requests without touching the other components of the URL or cleaning the fragments without touching the queries.

It's all ready! Set the aliases/keybindings and you're good to go.

Alias and keybindings

It's not feasible to write all the command's clutter everytime. Better writing a simple alias like :sfq in config.py:

# Build the command
sfq_base_dir = "~/.config/qutebrowser/userscripts/swapforqute/"
sfq_script_path = sfq_base_dir + "main.py"
sfq_conf_path = sfq_base_dir + "config.json"
sfq_cmd = "--userscript {} -c {}".format(sfq_script_path, sfq_conf_path)

# Assign the alias
c.aliases['sfq'] = "set-cmd-text -s :spawn {} --cmd 'open' -u ".format(sfq_cmd)

The obvious next step is setting up the keybindings.

# The following are equivalent!
# We can bind to an alias or directly to the command.

# config.bind('o', "set-cmd-text -s :spawn {} --cmd 'open' -u ".format(sfq_cmd))
config.bind('o', ':sfq')

Personally, I prefer leaving the default command for o key and assign :sfq to a special sequence, for f (hint links) and something else. Check my qutebrowser literate configuration for a more extended explanation of command building, keybindings and other tricks.

Of course, you can be creative and came up with your own solutions: the script just process your input to give you an output, but it's up to you where and when to use it.

Why I wrote this

I avoid running javascript on my browser for a lot of reasons: security, minimizing CPU usage, minimizing tracking... But some sites, usually big ones, heavily relies on JS for rendering content. When possible, I wished I could stay on privacy-friendly and js-free alternative frontends. Classic examples are offered by old reddit frontend VS new reddit frontend, nitter VS twitter, invidious VS youtube. With this script, it's possible to easily achieve all those redirects and every other you happen to think of.

How it works

diagram

Alternative ways

Before writing this script, I stepped on another userscript that aims at a similar goal, which is Qutebrowser URL Mutator; it's thought to be configured via regexes, just like Firefox "Redirector" extension. If you're used to this kind of workflow or you simply find it attractive, I suggest you to take a look at it. Mutator was of inspiration for SFQ, so thanks for that!

Requirements

A Python 3.7 (or newer) installation is required to run the script. It depends on standard libraries only (os, json, urllib, argparse). Obviously, being this an userscript for qutebrowser, Qutebrowser is required too.

Support

Why don't you help me keeping myself awake buying me a coffee? I could use the extra time to add more features!

ko-fi

Donate using Liberapay

License

MIT