Compare commits
1 Commits
feat/stow-
...
feat/wireg
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
9fe03c724e |
22
Makefile
22
Makefile
@@ -1,15 +1,10 @@
|
||||
# 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
|
||||
|
||||
# Local stow package directory (installed to ~/.local)
|
||||
STOW_LOCAL_DIR := local
|
||||
CONFIG_DIRS := btop doom hypr kitty nvim rclone starship tmux wallpapers waybar wireplumber wofi yazi zsh
|
||||
|
||||
all: stow_all
|
||||
wal -i ~/.config/wallpapers/green_yellow_forest.jpg -o ~/.config/waybar/launch.sh
|
||||
neofetch
|
||||
|
||||
.PHONY: all stow_all stow_local stow_rclone post_install_rclone clean
|
||||
|
||||
# Main target to handle stowing for all directories except rclone
|
||||
stow_all: $(filter-out rclone, $(CONFIG_DIRS))
|
||||
@echo "Cleaning broken symlinks in ~/.config..."
|
||||
@@ -26,13 +21,6 @@ stow_%:
|
||||
@echo "Stowing $*"
|
||||
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_install_rclone:
|
||||
@echo "Running post-installation script for rclone"
|
||||
@@ -47,11 +35,3 @@ stow_rclone:
|
||||
@echo "Stowing rclone"
|
||||
stow -v -t $(HOME) 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
|
||||
|
||||
@@ -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
|
||||
(map! :leader
|
||||
(:prefix ("w" . "window")
|
||||
:desc "Minimize window" "O" #'minimize-window)
|
||||
(:prefix ("z" . "Personal")
|
||||
:desc "Hermes Agent" "h" #'gortium/hermes-vterm))
|
||||
:desc "Minimize window" "O" #'minimize-window))
|
||||
#+end_src
|
||||
|
||||
** Ultra-scroll
|
||||
@@ -1832,25 +1830,6 @@ Org-AI
|
||||
(org-ai-install-yasnippets)) ; if you are using yasnippet and want `ai` snippets
|
||||
#+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
|
||||
Remote connection to server inside emacs (with all my config) <3
|
||||
|
||||
|
||||
@@ -18,9 +18,7 @@
|
||||
|
||||
(map! :leader
|
||||
(:prefix ("w" . "window")
|
||||
:desc "Minimize window" "O" #'minimize-window)
|
||||
(:prefix ("z" . "Personal")
|
||||
:desc "Hermes Agent" "h" #'gortium/hermes-vterm))
|
||||
:desc "Minimize window" "O" #'minimize-window))
|
||||
|
||||
(use-package! ultra-scroll
|
||||
:init
|
||||
@@ -1055,20 +1053,6 @@ DIFF:
|
||||
:desc "GPT 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
|
||||
(connection-local-set-profile-variables
|
||||
'remote-direct-async-process
|
||||
|
||||
@@ -77,7 +77,6 @@ exec-once = hypridle
|
||||
exec-once = hyprlock
|
||||
exec-once = /usr/bin/emacs --daemon
|
||||
exec-once = dbus-update-activation-environment --systemd HYPRLAND_INSTANCE_SIGNATURE
|
||||
exec-once = $HOME/.config/waybar/scripts/disk-monitor.sh --daemon
|
||||
|
||||
#############################
|
||||
### ENVIRONMENT VARIABLES ###
|
||||
@@ -148,8 +147,7 @@ animations {
|
||||
|
||||
# See https://wiki.hyprland.org/Configuring/Dwindle-Layout/ for more
|
||||
dwindle {
|
||||
# Note: pseudotile variable removed in 0.55+. Use `pseudo` dispatcher to toggle per-window.
|
||||
# Bound to $mainMod + P below.
|
||||
pseudotile = true # Master switch for pseudotiling. Enabling is bound to mainMod + P in the keybinds section below
|
||||
|
||||
# This prevents the layout from collapsing if you close one window
|
||||
preserve_split = true # You probably want this
|
||||
@@ -221,15 +219,14 @@ bind = $mainMod, E, exec, $editor
|
||||
bind = $mainMod, V, togglefloating,
|
||||
bind = $mainMod, R, exec, $menu
|
||||
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 SHIFT, N, movecurrentworkspacetomonitor, +1
|
||||
bind = $mainMod, X, swapwindow
|
||||
bind = $mainMod, B, exec, python /home/tpouplier/ExoKortex/4-Automata/recordntrans/record_transcribe.py
|
||||
# bind = $mainMod, G, exec, nerd-dictation end
|
||||
bind = $mainMod, A, exec, $music
|
||||
bind = $mainMod, C, exec, emacsclient -n -c -e '(gortium/hermes-vterm)'
|
||||
|
||||
# Full screen
|
||||
bind = SUPER, F, fullscreen
|
||||
@@ -320,6 +317,10 @@ bindl = , XF86AudioPause, exec, playerctl play-pause
|
||||
bindl = , XF86AudioPlay, exec, playerctl play-pause
|
||||
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
|
||||
bind = $mainMod, W, exec, emacsclient --eval '(thanos/type)'
|
||||
windowrule {
|
||||
|
||||
@@ -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
|
||||
@@ -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
|
||||
@@ -28,7 +28,17 @@
|
||||
"pulseaudio",
|
||||
"bluetooth",
|
||||
"network",
|
||||
"custom/wireguard",
|
||||
"battery",
|
||||
"custom/exit"
|
||||
]
|
||||
],
|
||||
|
||||
// Custom modules
|
||||
"custom/wireguard": {
|
||||
"exec": "~/.config/waybar/scripts/wireguard-status.sh",
|
||||
"interval": 10,
|
||||
"return-type": "json"
|
||||
},
|
||||
|
||||
// Exit button
|
||||
}
|
||||
|
||||
31
waybar/.config/waybar/scripts/wireguard-status.sh
Executable file
31
waybar/.config/waybar/scripts/wireguard-status.sh
Executable 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
|
||||
@@ -213,28 +213,6 @@ tooltip label {
|
||||
}
|
||||
|
||||
/* custom modules */
|
||||
#custom-disk-monitor {
|
||||
margin: 0px 0px 0px 5px;
|
||||
padding: 1px 8px 0px 8px;
|
||||
font-size: 16px;
|
||||
color: @text;
|
||||
border-radius: 5px;
|
||||
background-color: @set;
|
||||
}
|
||||
#custom-disk-monitor.warning {
|
||||
background-color: #ff9a3c;
|
||||
color: #FFFFFF;
|
||||
}
|
||||
#custom-disk-monitor.critical {
|
||||
background-color: #dc2f2f;
|
||||
color: #FFFFFF;
|
||||
animation-name: blink;
|
||||
animation-duration: 0.5s;
|
||||
animation-timing-function: linear;
|
||||
animation-iteration-count: infinite;
|
||||
animation-direction: alternate;
|
||||
}
|
||||
|
||||
#custom-exit {
|
||||
margin: 0px 18px 0px 5px;
|
||||
padding: 0px;
|
||||
|
||||
32
zsh/.zshrc
32
zsh/.zshrc
@@ -19,33 +19,6 @@ alias emacs="emacsclient -c -a emacs"
|
||||
# Opencode
|
||||
alias oc="opencode"
|
||||
|
||||
# Hermes Agent - SSH directly to remote server
|
||||
alias hermes="ssh -t lazyworkhorse 'docker exec -it hermes /opt/hermes/.venv/bin/hermes'"
|
||||
|
||||
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
|
||||
alias y="yazi"
|
||||
function yy() {
|
||||
@@ -89,6 +62,11 @@ alias dpa="docker ps -a"
|
||||
alias dl="docker ps -l -q"
|
||||
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
|
||||
alias ..="cd .."
|
||||
alias ...="cd ../.."
|
||||
|
||||
Reference in New Issue
Block a user