#!/bin/bash ############################################################################### # # # IPFire.org - A linux based firewall # # Copyright (C) 2007-2022 IPFire Team # # # # 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 . # # # ############################################################################### shopt -s nullglob VPN_CONFIG="/var/ipfire/vpn/config" ROUTE_TABLE="220" ROUTE_TABLE_PRIO="128" eval $(/usr/local/bin/readhash /var/ipfire/ethernet/settings) eval $(/usr/local/bin/readhash /var/ipfire/vpn/settings) # Get RED interface name if [ -r "/var/ipfire/red/iface" ]; then RED_INTF="$(/dev/null # Create a new interface and bring it up else log "Creating interface ${intf}" if ! ip link add name "${intf}" type "${interface_mode}" "${args[@]}"; then log "Could not create interface ${intf}" continue fi fi # Add an IP address ip addr flush dev "${intf}" ip addr add "${interface_address}" dev "${intf}" # Disable IPsec policy lookup for VTI if [ "${interface_mode}" = "vti" ]; then sysctl -qw "net.ipv4.conf.${intf}.disable_policy=1" fi # Set MTU ip link set dev "${intf}" mtu "${interface_mtu}" # Bring up the interface ip link set dev "${intf}" up done < "${VPN_CONFIG}" fi # Delete all other interfaces local intf for intf in /sys/class/net/gre[0-9]* /sys/class/net/vti[0-9]*; do intf="$(basename "${intf}")" # Ignore a couple of interfaces that cannot be deleted case "${intf}" in gre0|gretap0) continue ;; esac # Check if interface is on the list local i found="false" for i in ${interfaces[@]}; do if [ "${intf}" = "${i}" ]; then found="true" break fi done # Nothing to do if interface was found ${found} && continue # Delete the interface log "Deleting interface ${intf}" ip link del "${intf}" &>/dev/null done # (Re-)Apply all static routes /etc/init.d/static-routes start } main || exit $?