diff --git a/scripts/ru-bypass.sh b/scripts/ru-bypass.sh index 995e914..751c37c 100644 --- a/scripts/ru-bypass.sh +++ b/scripts/ru-bypass.sh @@ -11,11 +11,38 @@ # # Использование: sudo bash ru-bypass.sh +# Сохраняем env-переменные до загрузки конфига (env имеет приоритет) +_env_gw="${GATEWAY:-}" +_env_dev="${DEV:-}" +_env_local_dns="${LOCAL_DNS:-}" +_env_amn_srv="${AMNEZIA_SERVER:-}" +_env_ks_exc="${KILL_SWITCH_EXCEPTIONS:-}" + +# Загружаем сохранённый конфиг (для запуска из systemd/NM dispatcher без env) +[ -f /etc/ru-bypass.conf ] && . /etc/ru-bypass.conf + +# ENV-переменные имеют приоритет над конфигом +[ -n "$_env_gw" ] && GATEWAY="$_env_gw" +[ -n "$_env_dev" ] && DEV="$_env_dev" +[ -n "$_env_local_dns" ] && LOCAL_DNS="$_env_local_dns" +[ -n "$_env_amn_srv" ] && AMNEZIA_SERVER="$_env_amn_srv" +[ -n "$_env_ks_exc" ] && KILL_SWITCH_EXCEPTIONS="$_env_ks_exc" + +# Дефолты (если ни конфиг, ни env не задали значение) GATEWAY="${GATEWAY:-192.168.1.1}" DEV="${DEV:-wlp1s0}" LOCAL_DNS="${LOCAL_DNS:-}" AMNEZIA_SERVER="${AMNEZIA_SERVER:-}" KILL_SWITCH_EXCEPTIONS="${KILL_SWITCH_EXCEPTIONS:-}" + +# Сохраняем конфиг для будущих запусков (systemd, NM dispatcher) +cat > /etc/ru-bypass.conf <<_CONF +GATEWAY="$GATEWAY" +DEV="$DEV" +LOCAL_DNS="$LOCAL_DNS" +AMNEZIA_SERVER="$AMNEZIA_SERVER" +KILL_SWITCH_EXCEPTIONS="$KILL_SWITCH_EXCEPTIONS" +_CONF SETNAME="ru-direct" CACHE="/var/cache/ru-delegations.txt" IPSET_SAVE="/etc/ipset.conf" diff --git a/setup.sh b/setup.sh index 683ea76..bd1b438 100755 --- a/setup.sh +++ b/setup.sh @@ -113,7 +113,7 @@ case "$choice" in read -rp "DEV (интерфейс) [${auto_dev}]: " dev read -rp "LOCAL_DNS (DNS для *.loc) [${saved_local_dns:-пусто}]: " local_dns read -rp "AMNEZIA_SERVER (IP/домен сервера Amnezia) [${saved_amn_srv:-пусто}]: " amn_srv - read -rp "KS_EXCEPTIONS (исключения kill switch: IP/домены через пробел) [${saved_ks_exc:-пусто}]: " ks_exc + read -e -rp "KS_EXCEPTIONS (исключения kill switch: IP/домены через пробел): " -i "${saved_ks_exc}" ks_exc gw="${gw:-$auto_gw}" dev="${dev:-$auto_dev}" [ "$local_dns" = "пусто" ] && local_dns="" @@ -121,7 +121,6 @@ case "$choice" in [ "$amn_srv" = "пусто" ] && amn_srv="" amn_srv="${amn_srv:-$saved_amn_srv}" [ "$ks_exc" = "пусто" ] && ks_exc="" - ks_exc="${ks_exc:-$saved_ks_exc}" printf 'GATEWAY=%s\nDEV=%s\nLOCAL_DNS=%s\nAMNEZIA_SERVER=%s\nKILL_SWITCH_EXCEPTIONS=%s\n' "$gw" "$dev" "$local_dns" "$amn_srv" "$ks_exc" > "$net_conf" echo "" sudo GATEWAY="$gw" DEV="$dev" LOCAL_DNS="$local_dns" AMNEZIA_SERVER="$amn_srv" KILL_SWITCH_EXCEPTIONS="$ks_exc" USER_HOME="$HOME" bash scripts/ru-bypass.sh