mirror of
https://github.com/vincentmli/bpfire.git
synced 2026-04-09 18:45:54 +02:00
This is really badly hacky, but I do not know a better way to solve this with our existing "setup" program which would be a nightmare to extend. So we are using the device number to generate a static MAC address which can then be used as usual. I doubt many people will have more than one device. Signed-off-by: Michael Tremer <michael.tremer@ipfire.org>
97 lines
3.1 KiB
Bash
97 lines
3.1 KiB
Bash
#!/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/>. #
|
|
# #
|
|
###############################################################################
|
|
|
|
. /etc/rc.d/init.d/networking/functions.network
|
|
|
|
# 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
|
|
|
|
# Change MAC addresses of QMI interface
|
|
if [ -d "/sys/class/net/${INTERFACE}/qmi" ]; then
|
|
if ! qmi_assign_address "${INTERFACE}"; then
|
|
exit 1
|
|
fi
|
|
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"
|
|
mode="${zone}_MODE"
|
|
slaves="${zone}_SLAVES"
|
|
|
|
# Return DEV when the address matches
|
|
if [ "${!address,,}" = "${ADDRESS,,}" ]; then
|
|
echo "${!device}"
|
|
exit 0
|
|
fi
|
|
|
|
# If a matching interface has been found we will
|
|
# print the name to which udev will rename it.
|
|
case "${!mode}" in
|
|
bridge)
|
|
counter=0
|
|
for slave in ${!slaves}; do
|
|
if [ "${slave,,}" = "${ADDRESS,,}" ]; then
|
|
echo "${!device}p${counter}"
|
|
fi
|
|
(( counter += 1 ))
|
|
done
|
|
;;
|
|
esac
|
|
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
|