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
24 HOOK_SETTINGS
="HOOK ADDRESS PREFIX GATEWAY"
26 function hook_check
() {
28 assert isinteger PREFIX
30 if [ ${PREFIX} -gt 30 ]; then
31 error
"PREFIX is greater than 30."
36 function hook_create
() {
40 while [ $# -gt 0 ]; do
43 ADDRESS
=${1#--address=}
46 NETMASK
=${1#--netmask=}
52 GATEWAY
=${1#--gateway=}
58 if [ -z "${PREFIX}" -a -n "${NETMASK}" ]; then
59 PREFIX
=$
(ipv4_mask_to_cidr
${NETMASK})
62 # XXX maybe we can add some hashing to identify a configuration again
63 zone_config_settings_write
"${zone}" "${HOOK}.$(uuid)" ${HOOK_SETTINGS}
73 if ! device_exists ${zone}; then
74 error "Zone
'${zone}' doesn
't exist."
78 zone_config_settings_read "${zone}" "${config}" ${HOOK_SETTINGS}
80 ip_address_add ${zone} ${ADDRESS}/${PREFIX}
83 routing_db_set ${zone} ipv4 type "${HOOK}"
84 routing_db_set ${zone} ipv4 local-ip-address "${ADDRESS}/${PREFIX}"
85 routing_db_set ${zone} ipv4 remote-ip-address "${GATEWAY}"
86 routing_db_set ${zone} ipv4 active 1
88 routing_update ${zone} ipv4
89 routing_default_update
94 function hook_down() {
99 if ! device_exists ${zone}; then
100 error "Zone '${zone}' doesn't exist.
"
104 zone_config_settings_read "${zone}" "${config}" ${HOOK_SETTINGS}
106 ip_address_del
${zone} ${ADDRESS}/${PREFIX}
108 # Update routing tables.
109 routing_default_update
114 function hook_status
() {
119 if ! device_exists
${zone}; then
120 error
"Zone '${zone}' doesn't exist."
124 zone_config_settings_read
"${zone}" "${config}" ${HOOK_SETTINGS}
127 if zone_has_ip ${zone} ${ADDRESS}/${PREFIX}; then
128 status=${MSG_HOOK_UP}
130 status=${MSG_HOOK_DOWN}
132 cli_statusline 3 "${HOOK}" "${status}"
134 cli_print_fmt1 3 "IPv4 address
" "${ADDRESS}/${PREFIX}"
135 if [ -n "${GATEWAY}" ]; then
136 cli_print_fmt1 3 "Gateway
" "${GATEWAY}"
143 function ipv4_mask_to_cidr() {
147 for field in $(tr '.' ' ' <<<${1}); do
148 mask=$(( $(( ${mask} << 8 )) | ${field} ))
152 local x=$(( 128 << 24 )) # 0x80000000
154 while [ $(( ${x} & ${mask} )) -ne 0 ]; do
155 [ ${mask} -eq ${x} ] && mask=0 || mask=$(( ${mask} << 1 ))
156 cidr=$((${cidr} + 1))
159 if [ $(( ${mask} & 2147483647 )) -ne 0 ]; then # 2147483647 = 0x7fffffff
160 echo "Invalid net mask
: $1" >&2