2 ###############################################################################
4 # IPFire.org - A linux based firewall #
5 # Copyright (C) 2010 Michael Tremer & Christian Schmidt #
7 # This program is free software: you can redistribute it and/or modify #
8 # it under the terms of the GNU General Public License as published by #
9 # the Free Software Foundation, either version 3 of the License, or #
10 # (at your option) any later version. #
12 # This program is distributed in the hope that it will be useful, #
13 # but WITHOUT ANY WARRANTY; without even the implied warranty of #
14 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the #
15 # GNU General Public License for more details. #
17 # You should have received a copy of the GNU General Public License #
18 # along with this program. If not, see <http://www.gnu.org/licenses/>. #
20 ###############################################################################
22 .
/usr
/lib
/network
/header-config
29 DEFAULT_ENABLE_IPV6
="on"
30 DEFAULT_ENABLE_IPV4
="on"
32 hook_check_config_settings
() {
33 assert isset ENABLE_IPV6
34 assert isbool ENABLE_IPV6
35 assert isset ENABLE_IPV4
36 assert isbool ENABLE_IPV4
39 hook_parse_cmdline
() {
43 while [ $# -gt 0 ]; do
58 warning
"Ignoring unknown option '${1}'"
64 # Check if the user disabled ipv6 and ipv4
65 if ! enabled ENABLE_IPV6
&& ! enabled ENABLE_IPV4
; then
66 log ERROR
"You disabled IPv6 and IPv4. At least one must be enabled"
75 if zone_config_hook_is_configured
${zone} "dhcp"; then
76 log ERROR
"You can configure the dhcp hook only once for a zone"
80 local id
=$
(zone_config_get_new_id
${zone})
81 log DEBUG
"ID for the config is: ${id}"
86 if ! hook_parse_cmdline
"${id}" "$@"; then
87 # Return an error if the parsing of the cmd line fails
91 zone_config_settings_write
"${zone}" "${HOOK}" "${id}"
101 if ! device_exists
${zone}; then
102 error
"Zone '${zone}' doesn't exist."
106 zone_config_settings_read
"${zone}" "${config}"
108 # Start dhclient for IPv6 on this zone if enabled.
109 if enabled ENABLE_IPV6
; then
110 dhclient_start
${zone} ipv6
113 # Start dhclient for IPv4 on this zone if enabled.
114 if enabled ENABLE_IPV4
; then
115 dhclient_start
${zone} ipv4
126 if ! device_exists
${zone}; then
127 error
"Zone '${zone}' doesn't exist."
131 # Stop dhclient for IPv6 on this zone.
132 dhclient_stop
${zone} ipv6
134 # Stop dhclient for IPv4 on this zone.
135 dhclient_stop
${zone} ipv4
145 if ! device_exists
${zone}; then
146 error
"Zone '${zone}' doesn't exist."
150 zone_config_settings_read
"${zone}" "${config}"
153 if dhclient_status
${zone} ipv4 || dhclient_status
${zone} ipv6
; then
154 status
="${MSG_HOOK_UP}"
156 status
="${MSG_HOOK_DOWN}"
158 cli_statusline
3 "${HOOK}" "${status}"
163 for proto
in "IPv6" "IPv4"; do
164 local _proto
=${proto,,}
166 cli_print_fmt1
3 "${proto}"
168 if enabled ENABLE_
${proto^^}; then
169 cli_print_fmt1
4 "Status" "enabled"
171 local address
="$(db_get "${zone}/${_proto}/local-ip-address
")"
172 if isset address
; then
173 cli_print_fmt1
4 "Address" "${address}"
176 local gateway
="$(db_get "${zone}/${_proto}/remote-ip-address
")"
177 if isset gateway
; then
178 cli_print_fmt1
4 "Gateway" "${gateway}"
181 local dns_servers
="$(db_get "${zone}/${_proto}/domain-name-servers
")"
182 if isset dns_servers
; then
183 cli_print_fmt1
4 "DNS Servers" "${dns_servers}"
186 cli_print_fmt1
4 "Status" "disabled"