1 ###############################################################################
3 # IPFire.org - A linux based firewall #
4 # Copyright (C) 2007-2022 IPFire Team <info@ipfire.org> #
6 # This program is free software: you can redistribute it and/or modify #
7 # it under the terms of the GNU General Public License as published by #
8 # the Free Software Foundation, either version 3 of the License, or #
9 # (at your option) any later version. #
11 # This program is distributed in the hope that it will be useful, #
12 # but WITHOUT ANY WARRANTY; without even the implied warranty of #
13 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
14 # GNU General Public License for more details. #
16 # You should have received a copy of the GNU General Public License #
17 # along with this program. If not, see <http://www.gnu.org/licenses/>. #
19 ###############################################################################
23 . /etc/init.d/networking/functions.network
25 eval $(/usr/local/bin/readhash /var/ipfire/ethernet/settings)
29 set | grep "^new_" | sed "s|^new_||g" | \
30 sort > /var/ipfire/dhcpc/dhcpcd-$interface.info
32 #Check if this was the Red device...
33 if [ ! "$interface" == "$RED_DEV" ]; then
37 # Only if RED_TYPE=DHCP update /var/ipfire/red
38 # Check if we have to restart the services at update
39 [ ! -e "/var/ipfire/red/active" ] && update=1;
40 if [ "$old_domain_name_service" != "$new_domain_name_service" ]; then
43 if [ "$old_ip_address" != "$new_ip_address" ]; then
46 if [ "$old_routers" != "$new_routers" ]; then
51 /etc/rc.d/helper/getdnsfromdhcpc.pl 1 > /var/run/dns1
52 /etc/rc.d/helper/getdnsfromdhcpc.pl 2 > /var/run/dns2
55 echo -n "$new_ip_address" > /var/ipfire/red/local-ipaddress
58 if [ -n "${new_routers}" ]; then
59 grep -v -E "\<gateway\>" /etc/hosts > /tmp/hosts
60 echo "$new_routers gateway" >> /tmp/hosts
61 mv /tmp/hosts /etc/hosts
65 [ -e "/var/ipfire/red/active" ] || touch /var/ipfire/red/active
67 if [ -n "${new_routers}" ]; then
68 echo -n "${new_routers}" > /var/ipfire/red/remote-ipaddress
71 logger -p local0.info -t dhcpcd.exe[$$] "$interface has been (re)configured with IP=$new_ip_address"
72 run_subdir ${rc_base}/init.d/networking/red.up/
73 touch /var/ipfire/red/active
79 set | grep "^new_" | sed "s|^new_||g" | \
80 sort > /var/ipfire/dhcpc/dhcpcd-$interface.info
83 rm -f /var/run/dns1 /var/run/dns2
85 # Only if RED_TYPE=DHCP update /var/ipfire/red
86 if [ "$RED_TYPE" == "DHCP" ]; then
87 rm -f /var/ipfire/red/active
88 if [ ! $reason == "PREINIT" ]; then
89 logger -p local0.info -t dhcpcd.exe[$$] "${interface} has been brought down ($reason)"
90 run_subdir ${rc_base}/init.d/networking/red.down/
94 # Remove any configured IP address from the device
95 ip addr flush dev "${interface}" &>/dev/null
100 # Called when dhcpcd relies on a third party to configure an IP address
102 local qmi_device="$(qmi_find_device "${interface}")"
104 if [ -n "${qmi_device}" ]; then
105 setup_qmi "${qmi_device}" || return $?
122 while read -r line; do
130 *IPv4\ subnet\ mask:*)
133 *IPv4\ gateway\ address:*)
136 *IPv4\ primary\ DNS:*)
139 *IPv4\ secondary\ DNS:*)
146 done <<< "$(qmicli --device="${device}" --wds-get-current-settings)"
148 if [ -z "${address}" ] || [ -z "${netmask}" ] || [ -z "${gateway}" ]; then
149 logger -p "local0.info" -t "dhcpcd.exe[$$]" \
150 "Could not retrieve all information from the QMI interface"
154 # Flush any previous configuration
155 ip addr flush dev "${interface}"
157 # Configure the IP address
158 ip addr add "${address}/${netmask}" dev "${interface}"
160 # Configure the default route
161 if [ -n "${gateway}" ]; then
162 # Store the default gateway
163 echo -n "${gateway}" > /var/ipfire/red/remote-ipaddress
165 # Configure the default route
166 ip route add default via "${gateway}" mtu "${mtu}"
169 # Store and DNS servers
170 if [ -n "${dns1}" ]; then
171 echo -n "${dns1}" > /var/ipfire/red/dns1
173 if [ -n "${dns2}" ]; then
174 echo n "${dns2}" > /var/ipfire/red/dns2
181 BOUND|INFORM|REBIND|REBOOT|RENEW|TIMEOUT|STATIC) dhcpcd_up;;
182 PREINIT|EXPIRE|FAIL|IPV4LL|NAK|RELEASE|STOP) dhcpcd_down;;
187 logger -p "local0.info" -t "dhcpcd.exe[$$]" "Unhandled DHCP event: ${reason}"