diff options
| author | 2026-05-14 10:58:38 +0100 | |
|---|---|---|
| committer | 2026-05-14 10:58:38 +0100 | |
| commit | ec3fa96850ff534a241f7ebf2e4cdc13efdf3891 (patch) | |
| tree | 66eb4670d4309d1d1b764befde7e7d15a0ab91f5 /dot_config/waybar/executable_snx-vpn-toggle.sh | |
| parent | 0b506ac67c33939732bdd91d39a8a632bcbe0841 (diff) | |
| download | dotfiles-ec3fa96850ff534a241f7ebf2e4cdc13efdf3891.tar.gz dotfiles-ec3fa96850ff534a241f7ebf2e4cdc13efdf3891.tar.bz2 dotfiles-ec3fa96850ff534a241f7ebf2e4cdc13efdf3891.zip | |
feat(waybar): snx-rs VPN status indicator + click toggle
New custom/snx-vpn module sits next to custom/vpn (the wireguard one):
- snx-vpn-status.sh shells out to `snxctl status` (timeout 2s) and maps
the output to three states: down (grey strikethrough), connecting/MFA
(amber), up (green). Tooltip shows the full status block when up.
- snx-vpn-toggle.sh disconnects when up, runs snxctl-chromium detached
when down (so SAML lands in the flatpak ungoogled-chromium without
blocking waybar). Both paths refresh the module via SIGRTMIN+9.
Diffstat (limited to 'dot_config/waybar/executable_snx-vpn-toggle.sh')
| -rw-r--r-- | dot_config/waybar/executable_snx-vpn-toggle.sh | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/dot_config/waybar/executable_snx-vpn-toggle.sh b/dot_config/waybar/executable_snx-vpn-toggle.sh new file mode 100644 index 0000000..f42690d --- /dev/null +++ b/dot_config/waybar/executable_snx-vpn-toggle.sh @@ -0,0 +1,28 @@ +#!/bin/sh +# Toggle the snx-rs (Check Point) tunnel. Connect goes through the +# snxctl-chromium wrapper so SAML lands in the flatpak ungoogled +# chromium (LibreWolf blocks the 127.0.0.1:7779 callback). +# +# Refresh the waybar custom/snx-vpn module immediately with SIGRTMIN+9. +set -eu + +state=$(timeout 2 snxctl status 2>/dev/null || echo Disconnected) + +case "$state" in + *"Disconnected"*) + # Detach so waybar doesn't block waiting for SAML. The inner script + # re-signals waybar when the connect attempt finishes so the badge + # flips immediately to its final state. + # shellcheck disable=SC2016 + setsid -f sh -c ' + "$HOME/.local/bin/snxctl-chromium" >/tmp/snxctl-chromium.log 2>&1 + pid=$(pidof waybar) && kill -SIGRTMIN+9 $pid 2>/dev/null || true + ' + ;; + *) + snxctl disconnect >/dev/null 2>&1 || true + ;; +esac + +pid=$(pidof waybar || true) +[ -n "$pid" ] && kill -SIGRTMIN+9 "$pid" 2>/dev/null || true |
