2

Я хотел бы запустить openvpn (или остановить его) в зависимости от того, к какой беспроводной сети я подключен.

Но вывод env из postup() не означает, что ${SSID} был доступен в то время.

Смотреть на net/wpa_supplicant.sh , похоже, не помогает, поэтому я обращаюсь к hivemind за помощью.

1 ответ1

0

Первоначально я хотел не запускать openvpn на основе SSID, к которому я подключался. Но лучшее решение, к которому я пришел, - это посмотреть на IP.

/etc/conf.d/net:

postup() {
    # https://stackoverflow.com/questions/845694/how-do-i-find-my-computers-ip-address-using-the-bash-shell
    IP=$(ifconfig ${IFACE} | sed -n 's/.*inet addr:\([0-9.]\+\)\s.*/\1/p')
    OPENVPN=$(if [[ "${IFACE}" != "tun0" && ${IP%.*} != 192.168.[13] ]]; then echo "YES"; fi)

    sw-notify-send -i "${ICONS}/network-status.png" "${IFACE}" "$(ip addr show dev ${IFACE} | grep inet)"

    if [[ -n ${OPENVPN} ]]; then
        sw-notify-send -i "${ICONS}/network-status.png" "${IFACE}" "No IP range conflict detected for ${IP}, starting openvpn"
        /etc/init.d/openvpn -D restart
    fi
    return 0
}

РЕДАКТИРОВАТЬ Еще дальше, я теперь перенес эту логику на крючок dhcpcd . Чтобы это работало, вы должны отправить уникальное значение опции dhcp со своего специального DHCP-сервера: я использую здесь опцию 114 "default_url".

/etc/dhcpcd.enter-hook:

ACTION="stop"
COMMAND="openvpn.noroutes"    

if [ "$reason" = "BOUND" ]; then
    if [ ! -z ${new_default_url} ]; then
        sw-notify-send $ifname "Detected DHCP default_url $new_default_url, skipping openvpn"
        exit 1
    fi

    OPENVPN=$(if [[ $ifname != "tun0" && ${new_network_number%.*} != 192.168.[13] ]]; then echo "YES"; fi)
    if [[ -n $OPENVPN ]]; then
        sw-notify-send $ifname "IP range for $new_ip_address is free, starting openvpn"
        COMMAND="openvpn"
    fi

    ACTION="restart"

    /etc/init.d/"${COMMAND}" -D "${ACTION}"
fi

Всё ещё ищете ответ? Посмотрите другие вопросы с метками .