]> git.ipfire.org Git - people/stevee/network.git/blame - src/functions/functions.routing
Remove the function keyword which is a bashism
[people/stevee/network.git] / src / functions / functions.routing
CommitLineData
ff8ec5ef
MT
1#!/bin/bash
2###############################################################################
3# #
4# IPFire.org - A linux based firewall #
5# Copyright (C) 2010 Michael Tremer & Christian Schmidt #
6# #
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. #
11# #
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. #
16# #
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/>. #
19# #
20###############################################################################
21
1c6a4e30 22routing_has_default() {
ff8ec5ef
MT
23 ip route | grep -q "^default"
24}
25
1c6a4e30 26routing_default_update() {
ff8ec5ef
MT
27 local routes
28
b816e04b
MT
29 local zones=$(zones_get_nonlocal)
30 if [ -z "${zones}" ]; then
31 zones=$(zones_get_local)
32 fi
33
ff8ec5ef 34 local gateway
201b7dff 35 local proto
ff8ec5ef 36 local weight
b816e04b 37 local zone
e817357d 38 local cmd
ff8ec5ef 39
201b7dff
MT
40 for proto in ${IP_SUPPORTED_PROTOCOLS}; do
41 # Clear routes
42 routes=""
ff8ec5ef 43
e817357d
MT
44 cmd="ip $([ "${proto}" = "ipv6" ] && echo "-6") route"
45
201b7dff
MT
46 for zone in ${zones}; do
47 # Skip if zone is not up
48 routing_db_exists ${zone} ${proto} || continue
ff8ec5ef 49
201b7dff
MT
50 if [ "$(routing_db_get ${zone} ${proto} active)" = "1" ]; then
51 gateway=$(routing_db_get ${zone} ${proto} remote-ip-address)
ff8ec5ef 52
6c74a64c
MT
53 # Go on if the device is not there anymore.
54 device_exists ${zone} || continue
28f0b4ab 55
8fdc3a35
SS
56 # On other devices, we will use the gateway if we got one.
57 if isset gateway; then
58 routes="${routes} nexthop via ${gateway}"
59
00b2c5c9 60 # If we have got a Point-to-Point device, we will directly send all
28f0b4ab 61 # packets into the pipe.
8fdc3a35 62 elif device_is_ptp ${zone}; then
59187e11 63 routes="${routes} dev ${zone}"
28f0b4ab 64
28f0b4ab
MT
65 # If none of the cases above apply, we cannot go on.
66 else
67 continue
e817357d 68 fi
b816e04b 69
28f0b4ab
MT
70 # Apply weight.
71 weight=$(routing_db_get ${zone} ${proto} weight)
72 if isinteger ${weight}; then
201b7dff
MT
73 routes="${routes} weight ${weight}"
74 fi
75 else
76 log DEBUG "Ignoring zone '${zone}' which is not active."
ff8ec5ef 77 fi
201b7dff 78 done
ff8ec5ef 79
e817357d
MT
80 # Remove too much spaces.
81 routes=$(echo ${routes})
b816e04b 82
e817357d
MT
83 # Remove all default routes.
84 while ${cmd} | grep -q "^default"; do
85 ${cmd} del default
86 done
87
88 if [ -z "${routes}" ]; then
89 log INFO "Removed default route for ${proto}."
201b7dff 90 return ${EXIT_OK}
ff8ec5ef 91 fi
ff8ec5ef 92
201b7dff 93 log INFO "Setting default route for ${proto}: ${routes}"
b816e04b 94
28f0b4ab 95 cmd ${cmd} add default ${routes}
201b7dff 96 assert [ $? -eq 0 ]
e817357d
MT
97
98 case "${proto}" in
99 ipv6)
100 # Apply radvd configuration.
101 radvd_update
102 ;;
103 esac
201b7dff 104 done
ff8ec5ef
MT
105}
106
d2021e87 107# XXX deprecated function
1c6a4e30 108routing_table_exists() {
d2021e87 109 route_table_exists $@
ff8ec5ef
MT
110}
111
d2021e87 112# XXX deprecated function
1c6a4e30 113routing_table_create() {
d2021e87 114 route_table_create $@
ff8ec5ef 115}
b816e04b 116
1c6a4e30 117routing_db_path() {
b816e04b
MT
118 local zone=${1}
119 local proto=${2}
120
121 assert isset zone
122 assert isset proto
123 assert isoneof proto ${IP_SUPPORTED_PROTOCOLS}
124
125 echo "${ROUTING_DB_DIR}/${zone}/${proto}"
126}
127
1c6a4e30 128routing_db_exists() {
b816e04b
MT
129 [ -d "$(routing_db_path $@)" ]
130}
131
1c6a4e30 132routing_db_create() {
b816e04b
MT
133 routing_db_exists $@ && return ${EXIT_OK}
134
135 mkdir -p $(routing_db_path $@)
136}
137
1c6a4e30 138routing_db_remove() {
b816e04b
MT
139 rm -rf $(routing_db_path $@)
140}
141
1c6a4e30 142routing_db_set() {
b816e04b
MT
143 local zone=${1}
144 local proto=${2}
145 local parameter=${3}
146 shift 3
147
148 local value="$@"
149
150 log INFO "Updating database (${zone} - ${proto}): ${parameter} = ${value}"
151
152 routing_db_create ${zone} ${proto}
153
154 echo "${value}" > $(routing_db_path ${zone} ${proto})/${parameter}
155}
156
1c6a4e30 157routing_db_get() {
b816e04b
MT
158 local zone=${1}
159 local proto=${2}
160 local parameter=${3}
161 shift 3
162
163 cat $(routing_db_path ${zone} ${proto})/${parameter} 2>/dev/null
164}
165
1c6a4e30 166routing_db_from_ppp() {
b816e04b
MT
167 local zone=${1}
168 local proto=${2}
169
2c973348
MT
170 assert isset zone
171 assert isset proto
172
b816e04b
MT
173 # Save ppp configuration
174 routing_db_set ${zone} ${proto} type "ppp"
201b7dff
MT
175
176 if [ "${proto}" = "ipv6" ]; then
177 routing_db_set ${zone} ${proto} local-ip-address ${PPP_LLLOCAL}
178 routing_db_set ${zone} ${proto} remote-ip-address ${PPP_LLREMOTE}
179 elif [ "${proto}" = "ipv4" ]; then
180 routing_db_set ${zone} ${proto} local-ip-address ${PPP_IPLOCAL}
181 routing_db_set ${zone} ${proto} remote-ip-address ${PPP_IPREMOTE}
182 fi
b816e04b
MT
183
184 routing_db_set ${zone} ${proto} dns ${PPP_DNS1} ${PPP_DNS2}
185
186 routing_db_set ${zone} ${proto} remote-address ${PPP_MACREMOTE,,}
187}
188
1c6a4e30 189routing_update() {
b816e04b 190 local zone=${1}
2c973348 191 assert isset zone
b816e04b
MT
192
193 # Nothing to do for local zones.
194 if zone_is_local ${zone}; then
195 return ${EXIT_OK}
196 fi
197
198 local proto=${2}
199 local table=${zone}
2c973348 200 assert isset proto
b816e04b 201
28f0b4ab
MT
202 local ip_cmd="ip"
203 if [ "${proto}" = "ipv6" ]; then
204 ip_cmd="${ip_cmd} -6"
205 fi
206
b816e04b
MT
207 # Create routing table if not exists
208 routing_table_create ${table}
209
210 log DEBUG "Flushing routing table ${table}"
28f0b4ab 211 cmd ${ip_cmd} route flush table ${table}
b816e04b 212
f5a771cf
MT
213 # Exit here if there is no routing information.
214 if ! routing_db_exists ${zone} ${proto}; then
215 return ${EXIT_OK}
216 fi
217
b816e04b 218 local local_ip_address=$(routing_db_get ${zone} ${proto} local-ip-address)
d5bace8d 219 local remote_ip_address=$(routing_db_get ${zone} ${proto} remote-ip-address)
b816e04b 220
d5bace8d
MT
221 case "${proto}" in
222 ipv4)
223 local net_address=$(ipv4_get_netaddress ${local_ip_address})
224
225 log DEBUG "Adding route for subnet ${local_ip_address} to table ${table}"
28f0b4ab 226 cmd ${ip_cmd} route add table ${table} ${net_address} dev ${zone}
d5bace8d
MT
227 ;;
228 esac
b816e04b 229
28f0b4ab
MT
230 log DEBUG "Adding default route for table ${table}"
231 local routing_cmd="${ip_cmd} route add table ${table} default"
b816e04b 232 if isset remote_ip_address; then
28f0b4ab
MT
233 routing_cmd="${routing_cmd} via ${remote_ip_address}"
234 else
235 routing_cmd="${routing_cmd} dev ${zone}"
b816e04b 236 fi
28f0b4ab 237 cmd ${routing_cmd}
b816e04b 238
28f0b4ab 239 cmd ${ip_cmd} rule add from ${local_ip_address} lookup ${table}
b816e04b 240}