1 Commits

Author SHA1 Message Date
Thierry Pouplier
9fe03c724e feat: WireGuard VPN integration
- Add wg-up/wg-down/wg-status aliases to zshrc
- Add Super+Ctrl+V / Super+Ctrl+Shift+V keybinds to Hyprland
- Add Waybar custom module showing VPN status + traffic
- Add wireguard-status.sh script
2026-05-05 01:38:07 +00:00
12 changed files with 58 additions and 183 deletions

View File

@@ -1,15 +1,10 @@
# Define list of directories you want to stow # Define list of directories you want to stow
CONFIG_DIRS := btop doom hypr kitty local nvim rclone starship tmux wallpapers waybar wireplumber wofi yazi zsh CONFIG_DIRS := btop doom hypr kitty nvim rclone starship tmux wallpapers waybar wireplumber wofi yazi zsh
# Local stow package directory (installed to ~/.local)
STOW_LOCAL_DIR := local
all: stow_all all: stow_all
wal -i ~/.config/wallpapers/green_yellow_forest.jpg -o ~/.config/waybar/launch.sh wal -i ~/.config/wallpapers/green_yellow_forest.jpg -o ~/.config/waybar/launch.sh
neofetch neofetch
.PHONY: all stow_all stow_local stow_rclone post_install_rclone clean
# Main target to handle stowing for all directories except rclone # Main target to handle stowing for all directories except rclone
stow_all: $(filter-out rclone, $(CONFIG_DIRS)) stow_all: $(filter-out rclone, $(CONFIG_DIRS))
@echo "Cleaning broken symlinks in ~/.config..." @echo "Cleaning broken symlinks in ~/.config..."
@@ -26,13 +21,6 @@ stow_%:
@echo "Stowing $*" @echo "Stowing $*"
stow -v -t $(HOME) $* stow -v -t $(HOME) $*
# Special target for the local stow package
stow_local:
@echo "Cleaning broken symlinks in ~/.local/share/applications..."
find ~/.local/share/applications -xtype l -delete -print
@echo "Stowing local package"
stow -v -t $(HOME) $(STOW_LOCAL_DIR)
# Post-installation script for rclone (executed after stowing) # Post-installation script for rclone (executed after stowing)
post_install_rclone: post_install_rclone:
@echo "Running post-installation script for rclone" @echo "Running post-installation script for rclone"
@@ -47,11 +35,3 @@ stow_rclone:
@echo "Stowing rclone" @echo "Stowing rclone"
stow -v -t $(HOME) rclone stow -v -t $(HOME) rclone
@$(MAKE) post_install_rclone @$(MAKE) post_install_rclone
# Unstow all packages
clean:
@echo "Unstowing all packages..."
@for dir in $(CONFIG_DIRS); do \
echo "Unstowing $$dir..."; \
stow -v -D -t $(HOME) $$dir 2>/dev/null || true; \
done

View File

@@ -112,9 +112,7 @@ My current workflow consist in having the 3-5 files I work on open in vertical s
#+begin_src emacs-lisp #+begin_src emacs-lisp
(map! :leader (map! :leader
(:prefix ("w" . "window") (:prefix ("w" . "window")
:desc "Minimize window" "O" #'minimize-window) :desc "Minimize window" "O" #'minimize-window))
(:prefix ("z" . "Personal")
:desc "Hermes Agent" "h" #'gortium/hermes-vterm))
#+end_src #+end_src
** Ultra-scroll ** Ultra-scroll
@@ -496,19 +494,6 @@ change ~org-directory~. It must be set before org loads!
((org-agenda-tag-filter-preset '("+BA_ON_SITE"))) ((org-agenda-tag-filter-preset '("+BA_ON_SITE")))
) )
("wA" "Projet Airbus Vision"
((agenda ""
((org-agenda-span 150)
(org-agenda-start-day "2026-05-01")
(org-agenda-overriding-header "📅 Projet Airbus Vision")
(org-agenda-prefix-format " %12t") ;; reserve time space
(org-agenda-todo-keyword-format " %-5s") ;; fixed-width TODO
(org-agenda-tags-column -100) ;; right-align tags
(org-agenda-time-grid nil)
)))
((org-agenda-tag-filter-preset '("+airbus")))
)
) )
) )
) )
@@ -1845,25 +1830,6 @@ Org-AI
(org-ai-install-yasnippets)) ; if you are using yasnippet and want `ai` snippets (org-ai-install-yasnippets)) ; if you are using yasnippet and want `ai` snippets
#+end_src #+end_src
** +Hermes Agent+
Hermes Agent runs on lazyworkhorse server. Launched via SSH in a vterm buffer.
#+begin_src emacs-lisp
(after! vterm
(defun gortium/hermes-vterm ()
"Launch Hermes Agent in vterm via SSH to lazyworkhorse (CLI mode)."
(interactive)
(let ((buf (get-buffer-create "*hermes*")))
(switch-to-buffer buf)
(unless (and (eq major-mode 'vterm-mode)
(get-buffer-process buf))
(vterm-mode)
(let ((proc (get-buffer-process buf)))
(when proc
(process-send-string
proc "ssh -t lazyworkhorse 'docker exec -it hermes /opt/hermes/.venv/bin/hermes'\n")))))))
#+end_src
* Tramp * Tramp
Remote connection to server inside emacs (with all my config) <3 Remote connection to server inside emacs (with all my config) <3

View File

@@ -18,9 +18,7 @@
(map! :leader (map! :leader
(:prefix ("w" . "window") (:prefix ("w" . "window")
:desc "Minimize window" "O" #'minimize-window) :desc "Minimize window" "O" #'minimize-window))
(:prefix ("z" . "Personal")
:desc "Hermes Agent" "h" #'gortium/hermes-vterm))
(use-package! ultra-scroll (use-package! ultra-scroll
:init :init
@@ -367,19 +365,6 @@
((org-agenda-tag-filter-preset '("+BA_ON_SITE"))) ((org-agenda-tag-filter-preset '("+BA_ON_SITE")))
) )
("wA" "Projet Airbus Vision"
((agenda ""
((org-agenda-span 150)
(org-agenda-start-day "2026-05-01")
(org-agenda-overriding-header "📅 Projet Airbus Vision")
(org-agenda-prefix-format " %12t") ;; reserve time space
(org-agenda-todo-keyword-format " %-5s") ;; fixed-width TODO
(org-agenda-tags-column -100) ;; right-align tags
(org-agenda-time-grid nil)
)))
((org-agenda-tag-filter-preset '("+airbus")))
)
) )
) )
) )
@@ -1068,20 +1053,6 @@ DIFF:
:desc "GPT generate commit" :desc "GPT generate commit"
"g" #'gortium/magit-gptel-generate-commit) "g" #'gortium/magit-gptel-generate-commit)
(after! vterm
(defun gortium/hermes-vterm ()
"Launch Hermes Agent in vterm via SSH to lazyworkhorse (CLI mode)."
(interactive)
(let ((buf (get-buffer-create "*hermes*")))
(switch-to-buffer buf)
(unless (and (eq major-mode 'vterm-mode)
(get-buffer-process buf))
(vterm-mode)
(let ((proc (get-buffer-process buf)))
(when proc
(process-send-string
proc "ssh -t lazyworkhorse 'docker exec -it hermes /opt/hermes/.venv/bin/hermes'\n")))))))
;; set `tramp-direct-async-process' locally in all ssh connections ;; set `tramp-direct-async-process' locally in all ssh connections
(connection-local-set-profile-variables (connection-local-set-profile-variables
'remote-direct-async-process 'remote-direct-async-process

13
hypr/.config/hypr/hyprland.conf Executable file → Normal file
View File

@@ -8,7 +8,6 @@
# You can split this configuration into multiple files # You can split this configuration into multiple files
# Create your files separately and then link them to this file like this: # Create your files separately and then link them to this file like this:
# source = ~/.config/hypr/myColors.conf # source = ~/.config/hypr/myColors.conf
source = mocha.conf
source = ~/.cache/wal/colors-hyprland.conf source = ~/.cache/wal/colors-hyprland.conf
################ ################
@@ -148,8 +147,7 @@ animations {
# See https://wiki.hyprland.org/Configuring/Dwindle-Layout/ for more # See https://wiki.hyprland.org/Configuring/Dwindle-Layout/ for more
dwindle { dwindle {
# Note: pseudotile variable removed in 0.55+. Use `pseudo` dispatcher to toggle per-window. pseudotile = true # Master switch for pseudotiling. Enabling is bound to mainMod + P in the keybinds section below
# Bound to $mainMod + P below.
# This prevents the layout from collapsing if you close one window # This prevents the layout from collapsing if you close one window
preserve_split = true # You probably want this preserve_split = true # You probably want this
@@ -221,15 +219,14 @@ bind = $mainMod, E, exec, $editor
bind = $mainMod, V, togglefloating, bind = $mainMod, V, togglefloating,
bind = $mainMod, R, exec, $menu bind = $mainMod, R, exec, $menu
bind = $mainMod, Z, exec, $zen bind = $mainMod, Z, exec, $zen
# togglesplit removed as standalone dispatcher in 0.55+; use `layoutmsg togglesplit` instead #bind = $mainMod, P, pseudo, # dwindle
bind = $mainMod, P, pseudo, # dwindle bind = $mainMod, P, togglesplit, # dwindle
bind = $mainMod, N, movecurrentworkspacetomonitor, -1 bind = $mainMod, N, movecurrentworkspacetomonitor, -1
bind = $mainMod SHIFT, N, movecurrentworkspacetomonitor, +1 bind = $mainMod SHIFT, N, movecurrentworkspacetomonitor, +1
bind = $mainMod, X, swapwindow bind = $mainMod, X, swapwindow
bind = $mainMod, B, exec, python /home/tpouplier/ExoKortex/4-Automata/recordntrans/record_transcribe.py bind = $mainMod, B, exec, python /home/tpouplier/ExoKortex/4-Automata/recordntrans/record_transcribe.py
# bind = $mainMod, G, exec, nerd-dictation end # bind = $mainMod, G, exec, nerd-dictation end
bind = $mainMod, A, exec, $music bind = $mainMod, A, exec, $music
bind = $mainMod, C, exec, emacsclient -n -c -e '(gortium/hermes-vterm)'
# Full screen # Full screen
bind = SUPER, F, fullscreen bind = SUPER, F, fullscreen
@@ -320,6 +317,10 @@ bindl = , XF86AudioPause, exec, playerctl play-pause
bindl = , XF86AudioPlay, exec, playerctl play-pause bindl = , XF86AudioPlay, exec, playerctl play-pause
bindl = , XF86AudioPrev, exec, playerctl previous bindl = , XF86AudioPrev, exec, playerctl previous
# WireGuard VPN toggle
bind = $mainMod CTRL, V, exec, sudo wg-quick up ~/ExoKortex/1-Soma/2-Areas/IT/work-laptop.conf
bind = $mainMod CTRL SHIFT, V, exec, sudo wg-quick down work-laptop
# Emacs-everywhere # Emacs-everywhere
bind = $mainMod, W, exec, emacsclient --eval '(thanos/type)' bind = $mainMod, W, exec, emacsclient --eval '(thanos/type)'
windowrule { windowrule {

8
hypr/.config/hypr/mocha.conf Executable file → Normal file
View File

@@ -76,11 +76,3 @@ $mantleAlpha = 181825
$crust = rgb(11111b) $crust = rgb(11111b)
$crustAlpha = 11111b $crustAlpha = 11111b
# Fallback colors for when pywal hasn't generated colors-hyprland.conf
# (sourced by hyprland.conf — $color1/$color2 for active border gradients,
# $background for inactive border and general bg usage)
$color1 = rgb(cba6f7)
$color2 = rgb(f5c2e7)
$color3 = rgb(89b4fa)
$background = rgb(1e1e2e)

View File

@@ -1,8 +0,0 @@
[Desktop Entry]
Name=QET (Xephyr)
Comment=QElectroTech in nested X server for Wayland compatibility
Exec=/home/tpouplier/ExoKortex/4-Automata/dotfiles/scripts/qet-xephyr.sh
Icon=qelectrotech
Type=Application
Categories=Graphics;Engineering;
Terminal=false

View File

@@ -1,21 +0,0 @@
#!/bin/bash
# Launch QElectroTech in a nested Xephyr X server with Openbox
# Works around Wayland drag-and-drop issue in QET
XEPHYR_PID=""
cleanup() {
kill $XEPHYR_PID 2>/dev/null
exit 0
}
trap cleanup SIGINT SIGTERM
Xephyr -screen 1920x1080 :1 -title QET -br &
XEPHYR_PID=$!
sleep 1
DISPLAY=:1 openbox &
sleep 0.5
DISPLAY=:1 qelectrotech &
wait $XEPHYR_PID

View File

@@ -1,16 +0,0 @@
#!/bin/bash
scrot-ocr: Select screen region → OCR → clipboard
Deps: grim, slurp, tesseract, wl-clipboard, libnotify
set -euo pipefail
LANG="${1:-eng}"
IMG="/tmp/scrot-ocr-$(date +%s).png"
grim -g "$(slurp -d)" "$IMG"
TEXT=$(tesseract "$IMG" stdout -l "$LANG" 2>/dev/null | sed '/^[[:space:]]*$/d')
echo -n "$TEXT" | wl-copy --paste-once
echo "$TEXT"
notify-send "scrot-ocr" "$(echo "$TEXT" | wc -l) lines copied to clipboard" -t 3000
rm -f "$IMG"

View File

@@ -28,7 +28,17 @@
"pulseaudio", "pulseaudio",
"bluetooth", "bluetooth",
"network", "network",
"custom/wireguard",
"battery", "battery",
"custom/exit" "custom/exit"
] ],
// Custom modules
"custom/wireguard": {
"exec": "~/.config/waybar/scripts/wireguard-status.sh",
"interval": 10,
"return-type": "json"
},
// Exit button
} }

View File

@@ -0,0 +1,31 @@
#!/bin/bash
# Waybar WireGuard status module
# Checks if the wireguard interface is up by looking at /sys/class/net/
INTERFACE="work-laptop"
if [ -d "/sys/class/net/$INTERFACE" ]; then
# Interface exists - get transfer stats
RX=$(cat /sys/class/net/$INTERFACE/statistics/rx_bytes 2>/dev/null || echo 0)
TX=$(cat /sys/class/net/$INTERFACE/statistics/tx_bytes 2>/dev/null || echo 0)
# Human readable
if [ $RX -gt 1048576 ]; then
RX_STR="$(echo $RX | awk '{printf "%.1f", $1/1048576}')M"
elif [ $RX -gt 1024 ]; then
RX_STR="$(echo $RX | awk '{printf "%.1f", $1/1024}')K"
else
RX_STR="${RX}B"
fi
if [ $TX -gt 1048576 ]; then
TX_STR="$(echo $TX | awk '{printf "%.1f", $1/1048576}')M"
elif [ $TX -gt 1024 ]; then
TX_STR="$(echo $TX | awk '{printf "%.1f", $1/1024}')K"
else
TX_STR="${TX}B"
fi
echo "{\"text\": \"🔒 $RX_STR/$TX_STR\", \"class\": \"connected\", \"tooltip\": \"WireGuard: connected ($INTERFACE)\n▼ $RX_STR$TX_STR\"}"
else
echo "{\"text\": \"🔓\", \"class\": \"disconnected\", \"tooltip\": \"WireGuard: disconnected\"}"
fi

View File

@@ -1,5 +1,6 @@
# A TOML linter such as https://taplo.tamasfe.dev/ can use this schema to validate your config. # A TOML linter such as https://taplo.tamasfe.dev/ can use this schema to validate your config.
# If you encounter any issues, please make an issue at https://github.com/yazi-rs/schemas. # If you encounter any issues, please make an issue at https://github.com/yazi-rs/schemas.
"$schema" = "https://yazi-rs.github.io/schemas/yazi.json"
[mgr] [mgr]
ratio = [ 1, 4, 3 ] ratio = [ 1, 4, 3 ]

View File

@@ -19,43 +19,6 @@ alias emacs="emacsclient -c -a emacs"
# Opencode # Opencode
alias oc="opencode" alias oc="opencode"
# Hermes Agent - SSH directly to remote server
hermes() {
if [[ -n "$1" ]]; then
ssh -t lazyworkhorse \
"docker exec -e HERMES_HONCHO_PEER_NAME=$1 -it hermes \
/opt/hermes/.venv/bin/hermes --profile $1"
else
ssh -t lazyworkhorse \
"docker exec -e HERMES_HONCHO_PEER_NAME=thierry -it hermes \
/opt/hermes/.venv/bin/hermes"
fi
}
hermes-cp() {
if [ $# -eq 0 ]; then
echo "Usage: hermes-cp <file_or_directory> [...]"
echo ""
echo "Copies files/directories from your Arch laptop into the Hermes"
echo "agent container at /opt/data/home/ preserving directory structure."
echo ""
echo "Examples:"
echo " hermes-cp document.pdf # single file"
echo " hermes-cp *.pdf # multiple files (glob)"
echo " hermes-cp manuals/ # whole directory"
echo " hermes-cp manuals/ keyence-docs/ # multiple items"
echo ""
echo "To copy to a different destination inside the container:"
echo " tar -czf - . | ssh gortium@lazyworkhorse \\"
echo " \"docker exec -i hermes sh -c 'cd /opt/data/projects && tar -xzf -'\""
return 1
fi
# tar everything into a single SSH pipe, extract inside container
# Supports: single files, directories, glob patterns, mixed args
tar -czf - "$@" | ssh gortium@lazyworkhorse \
"docker exec -i hermes sh -c 'cd /opt/data/home && tar -xzf -'"
}
# Yazi # Yazi
alias y="yazi" alias y="yazi"
function yy() { function yy() {
@@ -99,6 +62,11 @@ alias dpa="docker ps -a"
alias dl="docker ps -l -q" alias dl="docker ps -l -q"
alias dx="docker exec -it" alias dx="docker exec -it"
# WireGuard VPN
alias wg-up="sudo wg-quick up ~/ExoKortex/1-Soma/2-Areas/IT/work-laptop.conf"
alias wg-down="sudo wg-quick down work-laptop"
alias wg-status="sudo wg show"
# Cd # Cd
alias ..="cd .." alias ..="cd .."
alias ...="cd ../.." alias ...="cd ../.."