Сценарий вызова после подключения к беспроводной сети
Могу ли я вызвать сценарий оболочки после подключения к определенной беспроводной сети? Причина, по которой я хочу это сделать, заключается в том, что мне нужно войти в сеть, прежде чем я смогу начать его использовать, и я хотел бы автоматизировать это, если это возможно.
Я прочитал этот вопрос: есть ли способ запускать сценарий каждый раз, когда я подключаюсь к определенной беспроводной сети?
Но я действительно не уверен, как использовать выскочку, чтобы сделать это.
3 ответа
Извиняюсь за мой предыдущий ответ, который я бы сделал несколько лет назад. Кажется, все изменилось.
Оказывается, что Network Manager запускает ВСЕ сценарии в /etc/NetworkManager/dispatcher.d/
каталог (принадлежащий root, исполняемый, недоступный для чтения другим пользователям и не настроенный), когда изменяется соединение (up, down, preup, predown).
Переменные среды устанавливаются и передаются в этот сценарий администратором сети. Вас заинтересует переменная окружения CONNECTION_UUID (содержит уникальную строку).
Итак, чтобы решить вашу проблему (выполнить скрипт, когда к определенной беспроводной сети подключено):
1) узнайте UUID беспроводного соединения, в котором вы заинтересованы (заглянув внутрь соответствующего файла подключения в /etc/NetworkManager/system-connections/
каталог).
2) написать сценарий bash (или perl, или python, или любой другой), который делает то, что вы хотите, если переменная окружения CONNECTION_UUID соответствует uuid беспроводной сети в (1) выше.
3) положить этот скрипт в /etc/NetworkManager/dispatcher.d/
и установите владельца и разрешения соответственно.
дальнейшее чтение: man networkmanager (и немного ковыряюсь в скриптах в каталогах, упомянутых выше).
Пример скрипта:
#!/bin/bash
#####################################
# MounterBeast Script
# /etc/NetworkManager/dispatcher.d/02remotemount
# Copyright 2011 Nathan E. Williams
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with this program. If not, see <http://www.gnu.org/licenses/>.
#
# Usage:
# This script must be customized for your configuration.
# By default, the script will attempt to mount a CIFS share
# when a specified MAC address is found at the network gateway,
# or over sshfs if the MAC address of the gateway is not the specified MAC.
# e.g. I mount over CIFS to the servers internal IP when at home, and
# over sshfs when away from home.
#
# id gateway mac without physically checking the sticker:
# $ arp -n -a $(ip route show 0.0.0.0/0 | awk '{print $3}') | awk '{print $4}'
#
# Testing:
# up) sudo /etc/NetworkManager/dispatcher.d/02remotemount wlan0 up
# down) sudo /etc/NetworkManager/dispatcher.d/02remotemount wlan0 down
#####################################
#
# Configuration:
#
targetmac='xx:xx:xx:xx:xx:xx'
mount_user='$USER'
mount_pass='pass'
internal_server_name='192.168.1.102'
external_server_name='my.dyndns.com'
share_name="music"
mount_point='/mnt/remote'
ssh_port='22'
#
# Should not need to edit below
#
gateway=$(ip route show 0.0.0.0/0 | awk '{print $3}')
mactest=$(arp -n -a $gateway | awk '{print $4}')
if [[ "$mactest" == "$targetmac" ]]
then
case "$2" in
up)
sleep 5
mount -t cifs -o username=$mount_user,password=$mount_pass //$internal_server_name/$share_name $mount_point
;;
down)
umount -l $mount_point
;;
esac
else
case "$2" in
up)
sleep 5
sshfs -p $ssh_port $external_server_name:$share_name $mount_point
;;
down)
umount -l $mount_point
;;
esac
fi
exit $?
Я не знаю, есть ли способ сделать это с помощью Network Manager, возможно, есть один, но у меня есть другое решение для вас. Вы можете установить Wicd:
sudo apt-get install wicd
Wicd имеет поддержку непосредственно в интерфейсе gtk для добавления поддержки до и после сценариев в каждую сеть, к которой вы можете подключиться. Позаботьтесь о том, чтобы Wicd деинсталлировал Network-Manager для работы (они оба конфликтуют), поэтому, если что-то пойдет не так, вам нужно скачать.deb Network-Manager или иметь с собой Live-CD/Live-USB.
Wicd прост в использовании и быстрее подключается, но в нем отсутствуют некоторые расширенные функции Network-Manager (например, VPN). Вот скриншот:
Да, сценарии оболочки в /etc/NetworkManager/dispatcher.d/
для NetworkManager это очень хорошая идея.
Существует также метод Dbus с NetworkManager, более увлекательный, более сложный: man nm-settings
,
Резюме аргументов оболочек из Man-страницы NetworkManager о dispatcher
:
Каждый сценарий получает два аргумента, первый - имя интерфейса только что активированного устройства, а второй - действие.
Действие может быть: вверх, вниз, vpn-up, vpn-down, имя хоста, dhcp4-change, dhcp6-change . (Выпуск справочной страницы: 17 января 2012 г.)
Вот очень простой скрипт для перезапуска OpenVPN после того, как сетевой интерфейс был up
:
if [ "$2" = "up" ]; then
/etc/init.d/openvpn restart
fi
exit $?