714 lines
22 KiB
Org Mode
714 lines
22 KiB
Org Mode
#+TITLE: Qutebrowser Configuration
|
|
#+SETUPFILE: ./setup/org-setup-file.org
|
|
#+PROPERTY: header-args+ :comments none
|
|
#+PROPERTY: header-args+ :mkdirp yes
|
|
#+PROPERTY: header-args+ :tangle ~/.config/qutebrowser/config.py
|
|
|
|
* Import
|
|
#+begin_src python
|
|
from qutebrowser.config.configfiles import ConfigAPI
|
|
from qutebrowser.config.config import ConfigContainer
|
|
|
|
import sys, os
|
|
#+end_src
|
|
|
|
* Auto Config
|
|
Do not load config set with =:set= command in qutebrowser.
|
|
#+begin_src python
|
|
config.load_autoconfig(True)
|
|
#+end_src
|
|
|
|
* General config
|
|
#+begin_src python
|
|
c.aliases = {'w': 'session-save', 'q': 'quit', 'wq': 'quit --save'}
|
|
c.auto_save.session = False
|
|
c.backend = 'webengine'
|
|
c.confirm_quit = ['downloads']
|
|
#+END_SRC
|
|
|
|
#+begin_src python
|
|
c.aliases['paywall'] = "open https://www.google.com/search?q=cache:{url}"
|
|
#+end_src
|
|
|
|
* Qt
|
|
Linked to [[https://github.com/qutebrowser/qutebrowser/issues/6401][issue]].
|
|
#+begin_src python
|
|
c.qt.workarounds.remove_service_workers = True
|
|
#+end_src
|
|
|
|
* Content
|
|
#+begin_src python
|
|
c.content.autoplay = False
|
|
c.content.notifications.enabled = False
|
|
c.content.geolocation = 'ask'
|
|
c.content.javascript.alert = True
|
|
c.content.javascript.can_access_clipboard = True
|
|
c.content.pdfjs = False
|
|
c.content.proxy = 'system'
|
|
c.content.blocking.method = 'both'
|
|
c.content.blocking.adblock.lists = ['https://easylist.to/easylist/easylist.txt', 'https://easylist.to/easylist/easyprivacy.txt', 'https://secure.fanboy.co.nz/fanboy-cookiemonster.txt']
|
|
#+END_SRC
|
|
|
|
* Editor
|
|
#+begin_src python
|
|
c.editor.command = ['/usr/bin/alacritty', '--class', 'terminal,Floating', '-e', 'nvim', '{}']
|
|
#+end_src
|
|
|
|
* Downloads
|
|
#+begin_src python
|
|
c.downloads.location.directory = '$HOME/Downloads/'
|
|
c.downloads.location.prompt = True
|
|
c.downloads.location.remember = True
|
|
c.downloads.location.suggestion = 'path'
|
|
c.downloads.position = 'bottom'
|
|
c.downloads.remove_finished = 10000
|
|
# c.downloads.open_dispatcher = 'linkhandler'
|
|
#+END_SRC
|
|
|
|
* File Select
|
|
#+begin_src python
|
|
c.fileselect.handler = "default"
|
|
# c.fileselect.single_file.command = ['termine', '-e', 'ranger', '--choosefile', '{}']
|
|
# c.fileselect.multiple_files.command = ['alacritty', '-e', 'ranger', '--choosefiles', '{}']
|
|
#+end_src
|
|
|
|
* Colors
|
|
#+begin_src python
|
|
# c.colors.webpage.darkmode.enabled = True
|
|
#+end_src
|
|
|
|
* Fonts
|
|
#+begin_src python
|
|
c.fonts.default_family = ["Hack Nerd Font Mono", "DejaVu Sans Mono", "Monaco"]
|
|
c.fonts.prompts = '10pt monospace'
|
|
c.fonts.statusbar = '10pt monospace'
|
|
#+END_SRC
|
|
|
|
* Input
|
|
#+begin_src python
|
|
c.input.insert_mode.auto_enter = True
|
|
# Very annoying when automatically leave insert mode
|
|
c.input.insert_mode.auto_leave = False
|
|
c.input.insert_mode.auto_load = False
|
|
c.input.insert_mode.plugins = True
|
|
#+END_SRC
|
|
|
|
* New Instance Options
|
|
#+begin_src python
|
|
c.new_instance_open_target = 'tab'
|
|
c.new_instance_open_target_window = 'last-focused'
|
|
#+END_SRC
|
|
|
|
* Spell Check
|
|
#+begin_src python
|
|
c.spellcheck.languages = ['en-US', 'fr-FR']
|
|
#+END_SRC
|
|
|
|
* Status Bar
|
|
#+begin_src python
|
|
# Hide the statusbar unless a message is shown.
|
|
c.statusbar.position = 'bottom'
|
|
|
|
# List of widgets displayed in the statusbar.
|
|
# Valid values:
|
|
# - url: Current page URL.
|
|
# - scroll: Percentage of the current page position like `10%`.
|
|
# - scroll_raw: Raw percentage of the current page position like `10`.
|
|
# - history: Display an arrow when possible to go back/forward in history.
|
|
# - tabs: Current active tab, e.g. `2`.
|
|
# - keypress: Display pressed keys when composing a vi command.
|
|
# - progress: Progress bar for the current page loading.
|
|
c.statusbar.widgets = ['keypress', 'url', 'scroll', 'history', 'progress']
|
|
#+END_SRC
|
|
|
|
* Tabs
|
|
#+begin_src python
|
|
# Open new tabs (middleclick/ctrl+click) in the background.
|
|
c.tabs.background = True
|
|
|
|
# Mouse button with which to close tabs.
|
|
c.tabs.close_mouse_button = 'right'
|
|
|
|
# How to behave when the last tab is closed.
|
|
c.tabs.last_close = 'close'
|
|
|
|
# Switch between tabs using the mouse wheel.
|
|
c.tabs.mousewheel_switching = False
|
|
|
|
# Position of new tabs opened from another tab.
|
|
# Valid values:
|
|
# - prev: Before the current tab.
|
|
# - next: After the current tab.
|
|
# - first: At the beginning.
|
|
# - last: At the end.
|
|
c.tabs.new_position.related = 'next'
|
|
|
|
# Position of new tabs which aren't opened from another tab.
|
|
# Valid values:
|
|
# - prev: Before the current tab.
|
|
# - next: After the current tab.
|
|
# - first: At the beginning.
|
|
# - last: At the end.
|
|
c.tabs.new_position.unrelated = 'last'
|
|
|
|
# Position of the tab bar.
|
|
c.tabs.position = 'left'
|
|
|
|
# Which tab to select when the focused tab is removed.
|
|
c.tabs.select_on_remove = 'next'
|
|
|
|
# Width (in pixels or as percentage of the window) of the tab bar if it's vertical.
|
|
c.tabs.width = 30
|
|
|
|
# Wrap when changing tabs.
|
|
c.tabs.wrap = False
|
|
#+END_SRC
|
|
|
|
* Urls and Search Engines
|
|
#+begin_src python
|
|
c.url.searchengines = {
|
|
'DEFAULT': 'https://www.duckduckgo.org/?q={}',
|
|
'wi': 'https://en.wikipedia.org/wiki/Special:Search?search={}',
|
|
'go': 'https://www.google.com/search?q={}',
|
|
'gc': 'https://scholar.google.fr/scholar?hl=fr&as_sdt=0%2C5&q={}&btnG=',
|
|
'gm': 'https://www.google.com/maps/search/{}/',
|
|
'yt': 'https://www.youtube.com/results?search_query={}',
|
|
'gh': 'https://github.com/search?q={}',
|
|
're': 'https://www.reddit.com/search?q={}',
|
|
'lb': 'http://gen.lib.rus.ec/search.php?req={}',
|
|
'la': 'http://gen.lib.rus.ec/scimag/index.php?s={}',
|
|
'sm': 'https://www.openstreetmap.org/search?query={}',
|
|
'am': 'https://www.amazon.fr/s?k={}',
|
|
'md': 'https://fr.mathworks.com/help/search.html?qdoc={}&submitsearch=',
|
|
'tf': 'https://translate.google.com/#view=home&op=translate&sl=en&tl=fr&text={}',
|
|
'te': 'https://translate.google.com/#view=home&op=translate&sl=fr&tl=en&text={}',
|
|
'lb': 'https://www.leboncoin.fr/recherche?text={}',
|
|
}
|
|
#+end_src
|
|
|
|
#+begin_src python
|
|
c.url.start_pages = ['https://homer.tdehaeze.xyz/']
|
|
c.url.default_page = 'https://homer.tdehaeze.xyz/'
|
|
#+END_SRC
|
|
|
|
* Normal Bindings
|
|
Zooming
|
|
#+begin_src python
|
|
config.bind('+', 'zoom-in')
|
|
config.bind('-', 'zoom-out')
|
|
config.bind('=', 'zoom')
|
|
#+end_src
|
|
|
|
Inputs blocks
|
|
#+begin_src python
|
|
config.bind(';t', 'hint inputs')
|
|
config.bind('gi', 'hint inputs --first')
|
|
#+end_src
|
|
|
|
Opening New Window
|
|
#+begin_src python
|
|
config.bind('<Ctrl-N>', 'open -w')
|
|
#+end_src
|
|
|
|
History
|
|
#+begin_src python
|
|
config.bind('H', 'back')
|
|
config.bind('L', 'forward')
|
|
#+end_src
|
|
|
|
Move tabs around
|
|
#+begin_src python
|
|
config.bind('d', 'tab-close')
|
|
config.bind('<', 'tab-move -')
|
|
config.bind('>', 'tab-move +')
|
|
config.bind('gO', 'tab-give') # Open current tab in a new window
|
|
config.bind('J', 'tab-next')
|
|
config.bind('K', 'tab-prev')
|
|
#+end_src
|
|
|
|
Bookmarks and Quickmark
|
|
#+begin_src python
|
|
config.bind('M', 'bookmark-add')
|
|
config.bind('m', 'quickmark-save')
|
|
#+end_src
|
|
|
|
Open New Pages/Tabs
|
|
#+begin_src python
|
|
config.bind('o', 'set-cmd-text -s :open')
|
|
config.bind('O', 'set-cmd-text -s :open -t')
|
|
#+end_src
|
|
|
|
Open new page/tab with clipboard content
|
|
#+begin_src python
|
|
config.bind('pp', 'open -- {clipboard}')
|
|
config.bind('pP', 'open -t -- {clipboard}')
|
|
#+end_src
|
|
|
|
Link Hinting
|
|
#+begin_src python
|
|
config.bind('f', 'hint')
|
|
config.bind('F', 'hint all tab')
|
|
#+end_src
|
|
|
|
Yanking url
|
|
#+begin_src python
|
|
config.bind('yy', 'yank')
|
|
#+END_SRC
|
|
|
|
Go to specific websites
|
|
#+begin_src python
|
|
config.bind('gy', 'open -t https://www.youtube.com/feed/subscriptions')
|
|
config.bind('gf', 'open -t https://rss.tdehaeze.xyz/')
|
|
config.bind('gr', 'open -t https://www.reddit.com/')
|
|
|
|
config.bind('gh', 'open -t https://homer.tdehaeze.xyz/')
|
|
|
|
config.bind('gb', 'open -t qute://bookmarks')
|
|
config.bind('gH', 'open -t qute://history')
|
|
config.bind('gs', 'open -t qute://settings')
|
|
#+end_src
|
|
|
|
* Custom Bindings
|
|
Create a Password for the current website
|
|
#+begin_src python
|
|
c.aliases['Password_Add'] = 'spawn --userscript ~/.config/qutebrowser/userscripts/add-passowrd.sh'
|
|
config.bind(',P', 'Password_Add')
|
|
#+end_src
|
|
|
|
Use Pass to fill password and username (configuration is done in =~/.config/qutebrowser/password_fill_rc=)
|
|
#+begin_src python
|
|
c.aliases['Password_Fill'] = 'spawn --userscript password_fill'
|
|
config.bind(',p', 'Password_Fill')
|
|
#+END_SRC
|
|
|
|
Get Two Factor Authentication number.
|
|
#+begin_src python
|
|
c.aliases['OTP'] = 'spawn --userscript ~/.config/qutebrowser/userscripts/get-otp.sh'
|
|
config.bind(',2', 'OTP')
|
|
#+END_SRC
|
|
|
|
Open Youtube video using =mpv=
|
|
#+begin_src python
|
|
c.aliases['MPV_view'] = 'spawn --detach mpv --force-window yes {url}'
|
|
config.bind(',m', 'MPV_view')
|
|
|
|
c.aliases['MPV_view_hint'] = 'hint links spawn --detach mpv --force-window yes {hint-url}'
|
|
config.bind(';m', 'MPV_view_hint')
|
|
#+END_SRC
|
|
|
|
Download Youtube video / entire playlist
|
|
#+begin_src python
|
|
c.aliases['Download_Youtube'] = 'spawn --userscript ~/.config/qutebrowser/userscripts/yt-download.sh {url}'
|
|
config.bind(',v', 'Download_Youtube')
|
|
|
|
c.aliases['Download_Youtube_hint'] = 'hint links spawn --userscript ~/.config/qutebrowser/userscripts/yt-download.sh {hint-url}'
|
|
config.bind(';v', 'Download_Youtube_hint')
|
|
#+END_SRC
|
|
|
|
Add page to Bookmarks using =linkding=
|
|
#+begin_src python
|
|
c.aliases['Bookmark_Add'] = 'spawn --userscript ~/.config/qutebrowser/userscripts/linkding-add.sh'
|
|
config.bind(',b', 'Bookmark_Add')
|
|
#+end_src
|
|
|
|
Download with =aria2c=
|
|
#+begin_src python
|
|
c.aliases['Download_Local'] = 'hint links spawn --userscript ~/.config/qutebrowser/userscripts/aria2c-add.sh {hint-url}'
|
|
config.bind(',d', 'Download_Local')
|
|
|
|
c.aliases['Download_Homelab'] = 'hint links spawn --userscript ~/.config/qutebrowser/userscripts/aria2c-add-homelab.sh {hint-url}'
|
|
config.bind(',D', 'Download_Homelab')
|
|
#+end_src
|
|
|
|
Open bookmark using =linkding=
|
|
#+begin_src python
|
|
c.aliases['Open_Bookmark'] = 'spawn --userscript ~/.config/qutebrowser/userscripts/linkding-open.sh'
|
|
config.bind(',o', 'Open_Bookmark')
|
|
#+end_src
|
|
|
|
Open with =linkhandler=
|
|
#+begin_src python
|
|
c.aliases['Open_Default'] = 'hint links spawn --detach linkhandler {hint-url}'
|
|
config.bind(',O', 'Open_Default')
|
|
#+end_src
|
|
|
|
Org Capture
|
|
#+begin_src python
|
|
c.aliases['Org_Capture'] = 'spawn --userscript ~/.config/qutebrowser/userscripts/org-capture.sh'
|
|
config.bind(',r', 'Org_Capture')
|
|
|
|
c.aliases['Org_Capture_hint'] = 'hint links userscript ~/.config/qutebrowser/userscripts/org-capture.sh'
|
|
config.bind(';R', 'Org_Capture_hint')
|
|
#+end_src
|
|
|
|
Screenshot of webpage to png
|
|
#+begin_src python
|
|
c.aliases['Save_PDF'] = 'spawn --userscript html-to-pdf.sh'
|
|
config.bind(',s', 'Save_PDF')
|
|
|
|
c.aliases['Save_PNG'] = 'spawn --userscript html-to-png.sh'
|
|
config.bind(',S', 'Save_PNG')
|
|
#+end_src
|
|
|
|
Download AES video
|
|
#+begin_src python
|
|
c.aliases['Download_AES'] = 'spawn --userscript aes-download.sh'
|
|
config.bind(',E', 'Download_AES')
|
|
#+end_src
|
|
|
|
Download a torrent
|
|
#+begin_src python
|
|
c.aliases['Download_Torrent_Homelab'] = 'hint links spawn torrent-add {hint-url}'
|
|
config.bind(',t', 'Download_Torrent_Homelab')
|
|
#+end_src
|
|
|
|
See Amazon price history using CamelCamelCamel
|
|
#+begin_src python
|
|
c.aliases['CamelCamelCamel'] = 'open -t https://fr.camelcamelcamel.com/search?sq={url}'
|
|
config.bind(',A', 'CamelCamelCamel')
|
|
#+end_src
|
|
|
|
Org Roam Entry for the current page
|
|
#+begin_src python
|
|
c.aliases['Org_Roam_Save'] = "open javascript:void(location.href='org-protocol://roam-ref?template=r&ref='+encodeURIComponent(location.href)+'&title='+encodeURIComponent(document.title))"
|
|
config.bind(',R', 'Org_Roam_Save')
|
|
#+end_src
|
|
|
|
Display Current URL as a QRcode (useful to open in on a phone).
|
|
#+begin_src python
|
|
c.aliases['QRcode'] = "spawn --userscript ~/.config/qutebrowser/userscripts/url-to-qrcode.sh {url}"
|
|
config.bind(',q', 'QRcode')
|
|
#+end_src
|
|
|
|
* Userscripts
|
|
:PROPERTIES:
|
|
:header-args:bash: :shebang "#!/usr/bin/env bash"
|
|
:header-args:bash+: :comments both :mkdirp yes
|
|
:header-args:python: :shebang "#!/usr/bin/env python3"
|
|
:header-args:python+: :comments both :mkdirp yes
|
|
:END:
|
|
|
|
[[https://qutebrowser.org/doc/userscripts.html][Here]] is the documentation related to userscripts.
|
|
|
|
** Create a new password
|
|
#+begin_src bash :tangle ~/.config/qutebrowser/userscripts/add-passowrd.sh
|
|
url=$(echo "$QUTE_URL" | awk -F[/:] '{print $4}' | rofi -p "URL" -dmenu -lines 1)
|
|
username=$(echo -e "dehaeze.thomas@gmail.com\nthomas.dehaeze@esrf.fr\ntdehaeze" | rofi -p "Username" -dmenu -lines 5)
|
|
password=$(rofi -p "Password" -dmenu -password -lines 1)
|
|
|
|
if [ -z "$url" ] || [ -z "$username" ] || [ -z "$password" ]; then
|
|
dunstify --urgency=critical "Pass" "Failed to Add Password"
|
|
else
|
|
echo -e "$password\nlogin: $username\nurl: $QUTE_URL" > /tmp/add-password.txt
|
|
pass insert --multiline "$url/$username" < /tmp/add-password.txt;
|
|
rm /tmp/add-password.txt
|
|
dunstify "Pass " "Password Added"
|
|
fi
|
|
#+end_src
|
|
|
|
** Download Youtube Video
|
|
#+begin_src bash :tangle ~/.config/qutebrowser/userscripts/yt-download.sh
|
|
cd ~/Documents/to-watch/ || exit;
|
|
|
|
if [[ "$1" == *"list"* ]]; then
|
|
choice=$(echo -e "Video\nPlaylist" | rofi -dmenu -only-match -i)
|
|
fi
|
|
|
|
if [ -n "$choice" ] && [ "$choice" = "Playlist" ]; then
|
|
dunstify --replace=19243 "Youtube " "Downloading Playlist...";
|
|
youtube-dl -i -f 'bestvideo[height<=720]+bestaudio/best[height<=720]' "$1" -o "%(playlist_title)s/%(playlist_index)s-%(title)s.%(ext)s" && \
|
|
dunstify --replace=19243 "Youtube " "Downloaded" || \
|
|
dunstify --replace=19243 --urgency=critical "Youtube " "Failed to download"
|
|
else
|
|
dunstify --replace=19243 "Youtube " "Downloading Video...";
|
|
youtube-dl --no-playlist -f 'bestvideo[height<=720]+bestaudio/best[height<=720]' "$1" && \
|
|
dunstify --replace=19243 "Youtube " "Downloaded" || \
|
|
dunstify --replace=19243 --urgency=critical "Youtube " "Failed to download"
|
|
fi
|
|
#+end_src
|
|
|
|
** Password_fill_rc
|
|
#+begin_src bash :tangle ~/.config/qutebrowser/password_fill_rc
|
|
# Show all password fields in the menu
|
|
query_entries() {
|
|
# safe queried url for choose_entry
|
|
# the subdomains are removed
|
|
export queried_url=$(expr match ".$1" '.*\.\(.*\..*\)')
|
|
mapfile -t files < <(find -L "$PREFIX" -iname '*.gpg' -printf '%P\n' |sed 's,\.gpg$,,')
|
|
}
|
|
|
|
# Even if there is only one entry, always show a menu
|
|
# for user confirmation.
|
|
choose_entry() {
|
|
MENU_COMMAND=(
|
|
rofi -dmenu
|
|
-p "qutebrowser> "
|
|
-filter "$queried_url"
|
|
-mesg $'Pick a password entry for <b>'"${QUTE_URL//&/&}"'</b>'
|
|
)
|
|
file=$( printf "%s\n" "${files[@]}" | "${MENU_COMMAND[@]}" )
|
|
}
|
|
#+end_src
|
|
|
|
** Org-Capture
|
|
#+begin_src bash :tangle ~/.config/qutebrowser/userscripts/org-capture.sh
|
|
readonly CAPTURE_SCRIPT=~/.config/qutebrowser/userscripts/org-protocol-capture-html.sh
|
|
|
|
if [[ "$QUTE_MODE" = "hints" ]]; then
|
|
# if we start with hints, we juste want to capture the URL
|
|
$CAPTURE_SCRIPT --template "pu" --url "${QUTE_URL}"
|
|
elif [[ -n "$QUTE_SELECTED_TEXT" ]]; then
|
|
# if text is selected, we want to capture the text
|
|
$CAPTURE_SCRIPT --template "pt" --heading "${QUTE_TITLE}" --url "${QUTE_URL}" "${QUTE_SELECTED_TEXT}"
|
|
else
|
|
# if no text is selected, we want to capture the url
|
|
$CAPTURE_SCRIPT --template "pu" --heading "${QUTE_TITLE}" --url "${QUTE_URL}"
|
|
fi
|
|
#+end_src
|
|
|
|
** Org-Protocol-Capture-HTML
|
|
:PROPERTIES:
|
|
:header-args: :tangle ~/.config/qutebrowser/userscripts/org-protocol-capture-html.sh
|
|
:END:
|
|
|
|
Defaults
|
|
#+begin_src bash
|
|
heading="link"
|
|
template="pu"
|
|
url="https://google.com/"
|
|
#+end_src
|
|
|
|
Functions
|
|
#+begin_src bash
|
|
function debug {
|
|
if [[ -n $debug ]]
|
|
then
|
|
function debug {
|
|
echo "DEBUG: $@" >&2
|
|
}
|
|
debug "$@"
|
|
else
|
|
function debug {
|
|
true
|
|
}
|
|
fi
|
|
}
|
|
function die {
|
|
echo "$@" >&2
|
|
exit 1
|
|
}
|
|
function urlencode {
|
|
python -c "
|
|
from __future__ import print_function
|
|
try:
|
|
from urllib import quote # Python 2
|
|
except ImportError:
|
|
from urllib.parse import quote # Python 3
|
|
import sys
|
|
print(quote(sys.stdin.read()[:-1], safe=''))"
|
|
}
|
|
#+end_src
|
|
|
|
Documentation
|
|
#+begin_src bash
|
|
function usage {
|
|
cat <<EOF
|
|
$0 [OPTIONS] [HTML]
|
|
html | $0 [OPTIONS]
|
|
Send HTML to Emacs through org-protocol, passing it through Pandoc to
|
|
convert HTML to Org-mode. HTML may be passed as an argument or
|
|
through STDIN. If only URL is given, it will be downloaded and its
|
|
contents used.
|
|
Options:
|
|
-h, --heading HEADING Heading
|
|
-t, --template TEMPLATE org-capture template key (default: pu)
|
|
-u, --url URL URL
|
|
--debug Print debug info
|
|
--help I need somebody!
|
|
EOF
|
|
}
|
|
#+end_src
|
|
|
|
Arguments
|
|
#+begin_src bash
|
|
args=$(getopt -n "$0" -o dh:rt:u: -l debug,help,heading:,template:,url: -- "$@") \
|
|
|| die "Unable to parse args. Is getopt installed?"
|
|
eval set -- "$args"
|
|
|
|
while true
|
|
do
|
|
case "$1" in
|
|
-d|--debug)
|
|
debug=true
|
|
debug "Debugging on"
|
|
;;
|
|
--help)
|
|
usage
|
|
exit
|
|
;;
|
|
-h|--heading)
|
|
shift
|
|
heading="$1"
|
|
;;
|
|
-t|--template)
|
|
shift
|
|
template="$1"
|
|
;;
|
|
-u|--url)
|
|
shift
|
|
url="$1"
|
|
;;
|
|
--)
|
|
# Remaining args
|
|
shift
|
|
rest=("$@")
|
|
break
|
|
;;
|
|
esac
|
|
|
|
shift
|
|
done
|
|
|
|
debug "ARGS: $args"
|
|
debug "Remaining args: ${rest[@]}"
|
|
#+end_src
|
|
|
|
Get HTML
|
|
#+begin_src bash
|
|
if [[ -n $@ ]]
|
|
then
|
|
debug "Text from args"
|
|
|
|
body="$@"
|
|
fi
|
|
#+end_src
|
|
|
|
URL-encode
|
|
#+begin_src bash
|
|
heading=$(urlencode <<<"$heading") || die "Unable to urlencode heading."
|
|
url=$(urlencode <<<"$url") || die "Unable to urlencode URL."
|
|
body=$(urlencode <<<"$body") || die "Unable to urlencode text."
|
|
#+end_src
|
|
|
|
Send to Emacs
|
|
#+begin_src bash
|
|
emacsclient "org-protocol://capture?template=$template&url=$url&title=$heading&body=$body"
|
|
#+end_src
|
|
|
|
** Open Bookmark with Linkding
|
|
#+begin_src bash :tangle ~/.config/qutebrowser/userscripts/linkding-open.sh
|
|
# Verify that environment variable are set
|
|
if [[ -z "${LINKDING_URL}" ]]; then
|
|
LINKDING_URL=$(pass nas/linkding_url)
|
|
fi
|
|
|
|
if [[ -z "${LINKDING_TOKEN}" ]]; then
|
|
LINKDING_TOKEN=$(pass nas/linkding_token)
|
|
fi
|
|
|
|
curl -H "Authorization: Token ${LINKDING_TOKEN}" ${LINKDING_URL}/api/bookmarks/ | jq '.results[] | "\(.title) - \(.url) - [#\((.tag_names | join(", #")))]"' -r | rofi -dmenu -no-custom | grep -Eo 'https?://[^ ]+' | head -1 | xargs -I {} echo "open -t {}" >> "$QUTE_FIFO"
|
|
#+end_src
|
|
|
|
** Add Url to Linkding
|
|
#+begin_src bash :tangle ~/.config/qutebrowser/userscripts/linkding-add.sh
|
|
# Verify that environment variable are set
|
|
if [[ -z "${LINKDING_URL}" ]]; then
|
|
LINKDING_URL=$(pass nas/linkding_url)
|
|
fi
|
|
|
|
if [[ -z "${LINKDING_TOKEN}" ]]; then
|
|
LINKDING_TOKEN=$(pass nas/linkding_token)
|
|
fi
|
|
|
|
title=$(echo "$QUTE_TITLE" | rofi -p "Title" -dmenu -lines 1)
|
|
existing_tags=$(curl -H "Authorization: Token ${LINKDING_TOKEN}" ${LINKDING_URL}/api/tags/ | jq '.results[].name' -r | rofi -multi-select -p "Existing tags" -dmenu)
|
|
new_tags=$(rofi -p "New tags" -dmenu)
|
|
|
|
formated_tags=$(echo $existing_tags $new_tags | sed -E 's/(\w+)/"\1"/g;s/\s/,/g')
|
|
|
|
curl -H "Authorization: Token ${LINKDING_TOKEN}" -H "Content-Type: application/json" -d "{\"url\": \"$QUTE_URL\", \"title\": \"$title\", \"tag_names\": [$formated_tags]}" ${LINKDING_URL}/api/bookmarks/ && \
|
|
dunstify "Linkding" " Bookmark Added" || \
|
|
dunstify --urgency=critical "Linkding" "Failed"
|
|
#+end_src
|
|
|
|
** Add Url to Buku using Rofi
|
|
#+begin_src bash :tangle ~/.config/qutebrowser/userscripts/buku-rofi.sh
|
|
title=$(echo "$QUTE_TITLE" | rofi -p "Title" -dmenu -lines 1)
|
|
tags=$(buku -t --nc --np | sed -e 's/\s*[[:digit:]]*\.\s*\(.*\)\s*([[:digit:]]*)\s*/\1/' -e '/^\s*$/d' | sort | uniq | rofi -multi-select -p "Tags" -dmenu | tr "\n" "," | sed 's/\s*,\s*$//')
|
|
|
|
buku --add "$QUTE_URL" --tag "$tags" --title "$title" && \
|
|
dunstify "Buku" "Bookmark Added" || \
|
|
dunstify --urgency=critical "Buku" " Bookmark Added"
|
|
#+end_src
|
|
|
|
** Add Url to Buku without asking for information
|
|
#+begin_src bash :tangle ~/.config/qutebrowser/userscripts/buku-add.sh
|
|
buku --add $QUTE_URL --title "$QUTE_TITLE" && \
|
|
dunstify "Buku" "📑 Bookmark Added"
|
|
#+end_src
|
|
|
|
** Download with aria2c
|
|
#+begin_src bash :tangle ~/.config/qutebrowser/userscripts/aria2c-add.sh
|
|
aria2p add "$1" && \
|
|
dunstify "Aria2" "Download Started" || \
|
|
dunstify "Aria2" "Error"
|
|
#+end_src
|
|
|
|
** Download with aria2c on the Homelab
|
|
#+begin_src bash :tangle ~/.config/qutebrowser/userscripts/aria2c-add-homelab.sh
|
|
dl-add $(echo "$1" | sed 's/\&af=.*$//g') && \
|
|
dunstify "Aria2" "Download Started" || \
|
|
dunstify "Aria2" "Error"
|
|
#+end_src
|
|
|
|
** Save to PNG
|
|
#+begin_src bash :tangle ~/.config/qutebrowser/userscripts/html-to-png.sh
|
|
filename=$(rofi -p "filename" -dmenu -lines 1)
|
|
|
|
if [ -n "filename" ]; then
|
|
cd ~/Pictures/ && \
|
|
firefox-developer-edition -P default -headless --screenshot "$filename.png" "$QUTE_URL" && \
|
|
dunstify "Screenshot" "Taken successfully"
|
|
fi
|
|
#+end_src
|
|
|
|
** Save to PDF
|
|
#+begin_src bash :tangle ~/.config/qutebrowser/userscripts/html-to-pdf.sh
|
|
filename=$(rofi -p "filename" -dmenu -lines 1)
|
|
|
|
if [ -n "$filename" ]; then
|
|
cd ~/Pictures/ && \
|
|
percollate pdf --css "@page { size: A4 portrait }" --output "$filename.pdf" "$QUTE_URL" && \
|
|
dunstify "Percollate" "Successfully saved to pdf"
|
|
fi
|
|
#+end_src
|
|
|
|
** Get OTP number
|
|
#+begin_src bash :tangle ~/.config/qutebrowser/userscripts/get-otp.sh
|
|
passname=$(ls ~/.password-store/totp-* | xargs -n 1 basename | sed -e 's/\..*$//' | rofi -p "TOPT" -dmenu)
|
|
|
|
if [ -n "$passname" ]; then
|
|
pass otp $passname | xsel -ib && \
|
|
dunstify 'OTP' 'copied to clipboard.' &
|
|
fi
|
|
#+end_src
|
|
|
|
** Download AES video
|
|
#+begin_src bash :tangle ~/.config/qutebrowser/userscripts/aes-download.sh
|
|
m3u8_path=`curl -L -s "$QUTE_URL" | pcregrep -o1 "file = \"\/(.*aes.*mp4)\""`
|
|
|
|
if [ -z "$m3u8_path" ]; then
|
|
dunstify --urgency=critical "Qutebrowser" "No m3u8 playlist found"
|
|
else
|
|
dunstify "Qutebrowser" "Downloads..." && \
|
|
cd ~/Downloads/ && \
|
|
ffmpeg -user_agent "Mozilla/5.0 (X11; Linux x86_64; rv:84.0) Gecko/20100101 Firefox/84.0" -referer "$QUTE_URL" -i "https://cdn2.digitellinc.com/play/_definst_/mp4:$m3u8_path/playlist.m3u8" -c copy "$QUTE_TITLE.mp4" && \
|
|
dunstify "Qutebrowser" "$QUTE_TITLE Downloaded"
|
|
fi
|
|
#+end_src
|
|
|
|
** Display URL as a QRcode
|
|
#+begin_src bash :tangle ~/.config/qutebrowser/userscripts/url-to-qrcode.sh
|
|
qrencode -o /tmp/qrcode.png "$1" && sxiv /tmp/qrcode.png
|
|
#+end_src
|