mirror of
https://github.com/vincentmli/bpfire.git
synced 2026-04-27 19:23:24 +02:00
network: Configure device names from /var/ipfire/ethernet/settings
Instead of creating a copy of the configuration values and for better extensibility, we will have udev execute a script that parses /var/ipfire/ethernet/settings and will return the correct name of the corresponding device (green0, blue0, ...).
This commit is contained in:
3
config/udev/60-net.rules
Normal file
3
config/udev/60-net.rules
Normal file
@@ -0,0 +1,3 @@
|
||||
# Call a script that checks for the right name of the new device.
|
||||
# If it matches the configuration it will be renamed accordingly.
|
||||
ACTION=="add", SUBSYSTEM=="net", PROGRAM="/lib/udev/network-hotplug-rename", RESULT=="?*", NAME="$result"
|
||||
75
config/udev/network-hotplug-rename
Normal file
75
config/udev/network-hotplug-rename
Normal file
@@ -0,0 +1,75 @@
|
||||
#!/bin/bash
|
||||
###############################################################################
|
||||
# #
|
||||
# IPFire.org - A linux based firewall #
|
||||
# Copyright (C) 2015 IPFire Team <info@ipfire.org> #
|
||||
# #
|
||||
# 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/>. #
|
||||
# #
|
||||
###############################################################################
|
||||
|
||||
# Check if all appropriate variables are set
|
||||
[ -n "${INTERFACE}" ] || exit 2
|
||||
|
||||
# Ignore virtual interfaces, etc.
|
||||
case "${INTERFACE}" in
|
||||
lo)
|
||||
exit 0
|
||||
;;
|
||||
tun*)
|
||||
exit 0
|
||||
;;
|
||||
ppp*)
|
||||
exit 0
|
||||
;;
|
||||
esac
|
||||
|
||||
# Check if INTERFACE actually exists
|
||||
[ -d "/sys/class/net/${INTERFACE}" ] || exit 1
|
||||
|
||||
# If the network configuration is not readable,
|
||||
# we cannot go on.
|
||||
if [ ! -r "/var/ipfire/ethernet/settings" ]; then
|
||||
exit 1
|
||||
fi
|
||||
|
||||
# Read network settings
|
||||
eval $(/usr/local/bin/readhash /var/ipfire/ethernet/settings)
|
||||
|
||||
# Standard zones
|
||||
ZONES="RED GREEN ORANGE BLUE"
|
||||
|
||||
# Determine the address of INTERFACE
|
||||
ADDRESS="$(</sys/class/net/${INTERFACE}/address)"
|
||||
|
||||
# Walk through all zones and find the matching interface
|
||||
for zone in ${ZONES}; do
|
||||
address="${zone}_MACADDR"
|
||||
device="${zone}_DEV"
|
||||
|
||||
# Skip if address or device is unset
|
||||
[ -n "${!address}" -a -n "${!device}" ] || continue
|
||||
|
||||
# If a matching interface has been found we will
|
||||
# print the name to which udev will rename it.
|
||||
if [ "${ADDRESS}" = "${!address}" ]; then
|
||||
echo "${!device}"
|
||||
exit 0
|
||||
fi
|
||||
done
|
||||
|
||||
# If we get here we have not found a matching device,
|
||||
# but we won't return an error any way. The new device
|
||||
# will remain with the previous name.
|
||||
exit 0
|
||||
Reference in New Issue
Block a user