From 14b7db0c493ab863db826dac27137234cb1d2f16 Mon Sep 17 00:00:00 2001 From: Xiao Pan Date: Fri, 11 Jul 2025 11:36:34 +0800 Subject: cfg: ib cfgs use 10.0.0.1 as remote need to be ran in a netns because wg is in that netns --- sh/cfg | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/sh/cfg b/sh/cfg index 92a097e..bf05ebc 100755 --- a/sh/cfg +++ b/sh/cfg @@ -1,5 +1,6 @@ #!/bin/sh +hostname="$(hostname)" umask 077 while getopts lsmM opt; do case $opt in @@ -11,7 +12,13 @@ while getopts lsmM opt; do l|s) work_tree_dir=/ meta_file="/etc/myconf/cfg${opt}_meta" - cmd="sudo -E git --git-dir=/etc/.cfg$opt/ --work-tree=/" + # ib cfgs use 10.0.0.1 as remote but its wg is in a netns, so need `ip netns exec ns0` + # note `sudo -E` seems needed for `gita -s`, but `cfg -s add` and then `cfg -s commit` seems no need `sudo -E` here and only sudo works fine, not sure why, need more test + if [ "$opt" = s ] && [ "$hostname" = xyzib ]; then + cmd="sudo -E ip netns exec ns0 git --git-dir=/etc/.cfg$opt/ --work-tree=/" + else + cmd="sudo -E git --git-dir=/etc/.cfg$opt/ --work-tree=/" + fi ;; m) sudo gitmetap "$cmd" "$work_tree_dir" "$meta_file" -- cgit v1.2.3-70-g09d2