ed6455da42241d78dc88f7dbee5ad1e8aba8da3e
[packages.git] / net / olsrd / files / olsrd.init
1 #!/bin/sh /etc/rc.common
2 # Copyright (C) 2008-2011 OpenWrt.org 
3
4 START=65
5
6 SERVICE_DAEMONIZE=1
7 SERVICE_WRITE_PID=1
8
9 CONF=/var/etc/olsrd.conf
10 PID=/var/run/olsrd.pid
11 PID6=/var/run/olsrd.ipv6.pid
12
13 OLSRD_OLSRD_SCHEMA='ignore:internal config_file:internal DebugLevel=0 AllowNoInt=yes'
14 OLSRD_IPCCONNECT_SCHEMA='ignore:internal Host:list Net:list2'
15 OLSRD_LOADPLUGIN_SCHEMA='ignore:internal library:internal Host4:list Net4:list2 Host:list Net:list2 Host6:list Net6:list2 Ping:list redistribute:list NonOlsrIf:list name:list lat lon latlon_infile HNA:list2 hosts:list2'
16 OLSRD_INTERFACE_SCHEMA='ignore:internal interface:internal AutoDetectChanges:bool'
17 OLSRD_INTERFACE_DEFAULTS_SCHEMA='AutoDetectChanges:bool'
18
19 T='     '
20 N='
21 '
22
23 validate_varname() {
24         local varname="$1"
25         [ -z "$varname" -o "$varname" != "${varname%%[!A-Za-z0-9_]*}" ] && return 1
26         return 0
27 }
28
29 validate_ifname() {
30         local ifname="$1"
31         [ -z "$ifname" -o "$ifname" != "${ifname%%[!A-Za-z0-9.:_-]*}" ] && return 1
32         return 0
33 }
34
35 validate_olsrd_option() {
36         local str="$1"
37         [ -z "$str" -o "$str" != "${str%%[!     0-9A-Za-z./|:_-]*}" ] && return 1
38         return 0
39 }
40
41 get_ifname() {
42         IFNAME=
43         local interface="$1"
44         validate_varname "$interface" || return 1
45         local ifname
46
47         config_get ifname "$interface" ifname
48         validate_ifname "$ifname" || return 1
49         IFNAME="$ifname"
50         return 0
51 }
52
53 system_config() {
54         local cfg="$1"
55         local cfgt
56         local hostname
57         local latlon
58
59         config_get cfgt "$cfg" TYPE
60
61         if [ "$cfgt" = "system" ]; then
62                 config_get hostname "$cfg" hostname
63                 hostname="${hostname:-OpenWrt}"
64                 SYSTEM_HOSTNAME="$hostname"
65         fi
66
67         if [ -z "$SYSTEM_LAT" -o -z "$SYSTEM_LON" ]; then
68                 config_get latlon "$cfg" latlon
69                 IFS=" ${T}${N},"
70                 set -- $latlon
71                 unset IFS
72                 SYSTEM_LAT="$1"
73                 SYSTEM_LON="$2"
74         fi
75
76         if [ -z "$SYSTEM_LAT" -o -z "$SYSTEM_LON" ]; then
77                 config_get latlon "$cfg" latitude
78                 SYSTEM_LAT="$latlon"
79                 config_get latlon "$cfg" longitude
80                 SYSTEM_LON="$latlon"
81         fi
82 }
83
84 olsrd_find_config_file() {
85         local cfg="$1"
86         validate_varname "$cfg" || return 0
87
88         config_get_bool ignore "$cfg" ignore 0
89         [ "$ignore" -ne 0 ] && return 0
90         config_get OLSRD_CONFIG_FILE "$cfg" config_file
91
92         return 0
93 }
94
95 warning_invalid_value() {
96         local package="$1"
97         validate_varname "$package" || package=
98         local config="$2"
99         validate_varname "$config" || config=
100         local option="$3"
101         validate_varname "$option" || option=
102
103         echo -n "Warning: Invalid value" 1>&2
104
105         if [ -n "$package" -a -n "$config" ]; then
106                 echo -n " in option '$package.$config${option:+.}$option'" 1>&2
107         fi
108
109         echo ", skipped" 1>&2
110
111         return 0
112 }
113
114 olsrd_write_option() {
115         local param="$1"
116         local cfg="$2"
117         validate_varname "$cfg" || return 1
118         local option="$3"
119         validate_varname "$option" || return 1
120         local value="$4"
121         local option_type="$5"
122
123         if [ "$option_type" = bool ]; then
124                 case "$value" in
125                         1|on|true|enabled|yes) value=yes;;
126                         0|off|false|disabled|no) value=no;;
127                         *) warning_invalid_value olsrd "$cfg" "$option"; return 1;;
128                 esac
129         fi
130
131         if ! validate_olsrd_option "$value"; then
132                 warning_invalid_value olsrd "$cfg" "$option"
133                 return 1
134         fi
135
136         if [ "$value" != "${value%%[G-Zg-z_-]*}" ]; then
137                 if [ "$option" != "Ip6AddrType" -a "$option" != "LinkQualityMult" -a "$value" != "yes" -a "$value" != "no" ]; then
138                         value="\"$value\""
139                 fi
140         fi
141
142         echo -n "${N}$param$option $value"
143
144         return 0
145 }
146
147 olsrd_write_plparam() {
148         local param="$1"
149         local cfg="$2"
150         validate_varname "$cfg" || return 1
151         local option="$3"
152         validate_varname "$option" || return 1
153         local value="$4"
154         local option_type="$5"
155         local _option
156
157         if [ "$option_type" = bool ]; then
158                 case "$value" in
159                         1|on|true|enabled|yes) value=yes;;
160                         0|off|false|disabled|no) value=no;;
161                         *) warning_invalid_value olsrd "$cfg" "$option"; return 1;;
162                 esac
163         fi
164
165         if ! validate_olsrd_option "$value"; then
166                 warning_invalid_value olsrd "$cfg" "$option"
167                 return 1
168         fi
169
170         IFS='-_'
171         set -- $option
172         option="$*"
173         unset IFS
174         _option="$option"
175         if [ "$option" = 'hosts' ]; then
176                 set -- $value
177                 option="$1"
178                 shift
179                 value="$*"
180         fi
181         if [ "$option" = 'NonOlsrIf' ]; then
182                 if validate_varname "$value"; then
183                         if get_ifname "$value"; then
184                                 ifname="$IFNAME"
185                                 echo "Info: mdns Interface '$value' ifname '$ifname' found" 1>&2
186                         else
187                                 echo "Warning: mdns Interface '$value' not found, skipped" 1>&2
188                         fi
189                 else
190                         warning_invalid_value olsrd "$cfg" "NonOlsrIf"
191                 fi
192                 [ -z "$ifname" ] || value=$ifname
193         fi
194
195         echo -n "${N}${param}PlParam \"$option\" \"$value\""
196
197         return 0
198 }
199
200 config_update_schema() {
201         unset IFS
202         local schema_varname="$1"
203         validate_varname "$schema_varname" || return 1
204         local command="$2"
205         validate_varname "$command" || return 1
206         local option="$3"
207         validate_varname "$option" || return 1
208         local value="$4"
209         local schema
210         local cur_option
211
212         case "$varname" in
213                 *_LENGTH) return 0;;
214                 *_ITEM*) return 0;;
215         esac
216
217         eval "export -n -- \"schema=\${$schema_varname}\""
218
219         for cur_option in $schema; do
220                 [ "${cur_option%%[:=]*}" = "$option" ] && return 0
221         done
222
223         if [ "$command" = list ]; then
224                 set -- $value
225                 if [ "$#" -ge "3" ]; then
226                         schema_entry="$option:list3"
227                 elif [ "$#" -ge "2" ]; then
228                         schema_entry="$option:list2"
229                 else
230                         schema_entry="$option:list"
231                 fi
232         else
233                 schema_entry="$option"
234         fi
235
236         append "$schema_varname" "$schema_entry"
237
238         return 0
239 }
240
241 config_write_options() {
242         unset IFS
243         local schema="$1"
244         local cfg="$2"
245         validate_varname "$cfg" || return 1
246         local write_func="$3"
247         [ -z "$write_func" ] && output_func=echo
248         local write_param="$4"
249         local schema_entry
250         local option
251         local option_length
252         local option_type
253         local default
254         local value
255         local list_size
256         local list_item
257         local list_value
258         local i
259         local position
260
261         for schema_entry in $schema; do
262                 default="${schema_entry#*[=]}"
263                 [ "$default" = "$schema_entry" ] && default=
264                 option="${schema_entry%%[=]*}"
265                 IFS=':'
266                 set -- $option
267                 unset IFS
268                 option="$1"
269                 option_type="$2"
270                 validate_varname "$option" || continue
271                 [ -z "$option_type" ] || validate_varname "$option_type" || continue
272                 [ "$option_type" = internal ] && continue
273                 config_get value "$cfg" "$option"
274
275                 if [ -z "$value" ]; then
276                         IFS='+'
277                         set -- $default
278                         unset IFS
279                         value=$*
280                 elif [ "$value" = '-' -a -n "$default" ]; then
281                         continue
282                 fi
283
284                 [ -z "$value" ] && continue
285
286                 case "$option_type" in
287                         list) list_size=1;;
288                         list2) list_size=2;;
289                         list3) list_size=3;;
290                         *) list_size=0;;
291                 esac
292
293                 if [ "$list_size" -gt 0 ]; then
294                         config_get option_length "$cfg" "${option}_LENGTH"
295                         if [ -n "$option_length" ]; then
296                                 i=1
297                                 while [ "$i" -le "$option_length" ]; do
298                                         config_get list_value "$cfg" "${option}_ITEM$i"
299                                         "$write_func" "$write_param" "$cfg" "$option" "$list_value" "$option_type" || break
300                                         i=$((i + 1))
301                                 done
302                         else
303                                 list_value=
304                                 i=0
305                                 for list_item in $value; do
306                                         append "list_value" "$list_item"
307                                         i=$((i + 1))
308                                         position=$((i % list_size))
309                                         if [ "$position" -eq 0 ]; then
310                                                 "$write_func" "$write_param" "$cfg" "$option" "$list_value" "$option_type" || break
311                                                 list_value=
312                                         fi
313                                 done
314                                 [ "$position" -ne 0 ] && "$write_func" "$write_param" "$cfg" "$option" "$list_value" "$option_type"
315                         fi
316                 else
317                         "$write_func" "$write_param" "$cfg" "$option" "$value" "$option_type"
318                 fi
319         done
320
321         return 0
322 }
323
324 olsrd_write_olsrd() {
325         local cfg="$1"
326         validate_varname "$cfg" || return 0
327         local ignore
328
329         config_get_bool ignore "$cfg" ignore 0
330         [ "$ignore" -ne 0 ] && return 0
331
332         [ "$OLSRD_COUNT" -gt 0 ] && return 0
333
334         config_get ipversion "$cfg" IpVersion
335         if [ "$ipversion" = "6and4" ]; then
336                 OLSRD_IPVERSION_6AND4=1
337                 config_set "$cfg" IpVersion '6'
338         fi
339         config_get smartgateway "$cfg" SmartGateway
340         config_get smartgatewayuplink "$cfg" SmartGatewayUplink
341
342         config_write_options "$OLSRD_OLSRD_SCHEMA" "$cfg" olsrd_write_option
343         echo
344         OLSRD_COUNT=$((OLSRD_COUNT + 1))
345         return 0
346 }
347
348 olsrd_write_ipcconnect() {
349         local cfg="$1"
350         validate_varname "$cfg" || return 0
351         local ignore
352
353         config_get_bool ignore "$cfg" ignore 0
354         [ "$ignore" -ne 0 ] && return 0
355
356         [ "$IPCCONNECT_COUNT" -gt 0 ] && return 0
357
358         echo -n "${N}IpcConnect${N}{"
359         config_write_options "$OLSRD_IPCCONNECT_SCHEMA" "$cfg" olsrd_write_option "${T}"
360         echo "${N}}"
361         IPCCONNECT_COUNT=$((IPCCONNECT_COUNT + 1))
362
363         return 0
364 }
365
366 olsrd_write_hna4() {
367         local cfg="$1"
368         validate_varname "$cfg" || return 0
369         local ignore
370
371         config_get_bool ignore "$cfg" ignore 0
372         [ "$ignore" -ne 0 ] && return 0
373
374         config_get netaddr "$cfg" netaddr
375         if ! validate_olsrd_option "$netaddr"; then
376                 warning_invalid_value olsrd "$cfg" "netaddr"
377                 return 0
378         fi
379
380         config_get netmask "$cfg" netmask
381         if ! validate_olsrd_option "$netmask"; then
382                 warning_invalid_value olsrd "$cfg" "netmask"
383                 return 0
384         fi
385
386         [ "$HNA4_COUNT" -le 0 ] && echo -n "${N}Hna4${N}{"
387         echo -n "${N}${T}${T}$netaddr $netmask"
388         HNA4_COUNT=$((HNA4_COUNT + 1))
389
390         return 0
391 }
392
393 olsrd_write_hna6() {
394         local cfg="$1"
395         validate_varname "$cfg" || return 0
396         local ignore
397
398         config_get_bool ignore "$cfg" ignore 0
399         [ "$ignore" -ne 0 ] && return 0
400
401         config_get netaddr "$cfg" netaddr
402         if ! validate_olsrd_option "$netaddr"; then
403                 warning_invalid_value olsrd "$cfg" "netaddr"
404                 return 0
405         fi
406
407         config_get prefix "$cfg" prefix
408         if ! validate_olsrd_option "$prefix"; then
409                 warning_invalid_value olsrd "$cfg" "prefix"
410                 return 0
411         fi
412
413         [ "$HNA6_COUNT" -le 0 ] && echo -n "${N}Hna6${N}{"
414         echo -n "${N}${T}${T}$netaddr $prefix"
415         HNA6_COUNT=$((HNA6_COUNT + 1))
416
417         return 0
418 }
419
420 olsrd_write_loadplugin() {
421         local cfg="$1"
422         validate_varname "$cfg" || return 0
423         local ignore
424         local name
425         local suffix
426         local lat
427         local lon
428         local latlon_infile
429
430         config_get_bool ignore "$cfg" ignore 0
431         [ "$ignore" -ne 0 ] && return 0
432
433         config_get library "$cfg" library
434         if ! validate_olsrd_option "$library"; then
435                 warning_invalid_value olsrd "$cfg" "library"
436                 return 0
437         fi
438         if ! [ -x "/lib/$library" -o -x "/usr/lib/$library" -o -x "/usr/local/lib/$library" ]; then
439                 echo "Warning: Plugin library '$library' not found, skipped" 1>&2
440                 return 0
441         fi
442
443         case "$library" in
444                 olsrd_nameservice.*)
445                         config_get name "$cfg" name
446                         [ -z "$name" ] && config_set "$cfg" name $SYSTEM_HOSTNAME
447
448                         config_get suffix "$cfg" suffix
449                         [ -z "$suffix" ] && config_set "$cfg" suffix '.olsr'
450
451                         config_get lat "$cfg" lat
452                         config_get lon "$cfg" lon
453                         config_get latlon_infile "$cfg" latlon_infile
454                         if [ \( -z "$lat" -o -z "$lat" \) -a -z "$latlon_infile" ]; then
455                                 if [ -f '/var/run/latlon.txt' ]; then
456                                         config_set "$cfg" lat ''
457                                         config_set "$cfg" lon ''
458                                         config_set "$cfg" latlon_infile '/var/run/latlon.txt'
459                                 else
460                                         config_set "$cfg" lat "$SYSTEM_LAT"
461                                         config_set "$cfg" lon "$SYSTEM_LON"
462                                 fi
463                         fi
464
465                         for f in latlon_file hosts_file services_file resolv_file macs_file; do
466                                 config_get $f "$cfg" $f
467                         done
468
469                         [ -z "$latlon_file" ] && config_set "$cfg" latlon_file '/var/run/latlon.js'
470                 ;;
471                 olsrd_watchdog.*)
472                         config_get wd_file "$cfg" file
473                 ;;
474         esac
475
476         echo -n "${N}LoadPlugin \"$library\"${N}{"
477         config_write_options "$OLSRD_LOADPLUGIN_SCHEMA" "$cfg" olsrd_write_plparam "${T}"
478         echo "${N}}"
479
480         return 0
481 }
482
483 olsrd_write_interface() {
484         local cfg="$1"
485         validate_varname "$cfg" || return 0
486         local ignore
487         local interfaces
488         local interface
489         local ifnames
490
491         config_get_bool ignore "$cfg" ignore 0
492         [ "$ignore" -ne 0 ] && return 0
493
494         ifnames=
495         config_get interfaces "$cfg" interface
496         for interface in $interfaces; do
497                 if validate_varname "$interface"; then
498                         if get_ifname "$interface"; then
499                                 ifnames="$ifnames \"$IFNAME\""
500                                 ifsglobal="$ifsglobal $IFNAME"
501                         else
502                                 echo "Warning: Interface '$interface' not found, skipped" 1>&2
503                         fi
504                 else
505                         warning_invalid_value olsrd "$cfg" "interface"
506                 fi
507         done
508
509         [ -z "$ifnames" ] && return 0
510
511         echo -n "${N}Interface$ifnames${N}{"
512         config_write_options "$OLSRD_INTERFACE_SCHEMA" "$cfg" olsrd_write_option "${T}"
513         echo "${N}}"
514         INTERFACES_COUNT=$((INTERFACES_COUNT + 1))
515
516         return 0
517 }
518
519 olsrd_write_interface_defaults() {
520         local cfg="$1"
521         validate_varname "$cfg" || return 0
522
523         echo -n "${N}InterfaceDefaults$ifnames${N}{"
524         config_write_options "$OLSRD_INTERFACE_DEFAULTS_SCHEMA" "$cfg" olsrd_write_option "${T}"
525         echo "${N}}"
526
527         return 1
528 }
529
530 olsrd_update_schema() {
531         local command="$1"
532         validate_varname "$command" || return 0
533         local varname="$2"
534         validate_varname "$varname" || return 0
535         local value="$3"
536         local cfg="$CONFIG_SECTION"
537         local cfgt
538         local cur_varname
539
540         config_get cfgt "$cfg" TYPE
541         case "$cfgt" in
542                 olsrd) config_update_schema OLSRD_OLSRD_SCHEMA "$command" "$varname" "$value";;
543                 IpcConnect) config_update_schema OLSRD_IPCCONNECT_SCHEMA "$command" "$varname" "$value";;
544                 LoadPlugin) config_update_schema OLSRD_LOADPLUGIN_SCHEMA "$command" "$varname" "$value";;
545                 Interface) config_update_schema OLSRD_INTERFACE_SCHEMA "$command" "$varname" "$value";;
546                 InterfaceDefaults) config_update_schema OLSRD_INTERFACE_DEFAULTS_SCHEMA "$command" "$varname" "$value";;
547         esac
548
549         return 0
550 }
551
552 olsrd_write_config() {
553         OLSRD_IPVERSION_6AND4=0
554         OLSRD_COUNT=0
555         config_foreach olsrd_write_olsrd olsrd
556         IPCCONNECT_COUNT=0
557         config_foreach olsrd_write_ipcconnect IpcConnect
558         HNA4_COUNT=0
559         config_foreach olsrd_write_hna4 Hna4
560         [ "$HNA4_COUNT" -gt 0 ] && echo "${N}}"
561         HNA6_COUNT=0
562         config_foreach olsrd_write_hna6 Hna6
563         [ "$HNA6_COUNT" -gt 0 ] && echo "${N}}"
564         config_foreach olsrd_write_loadplugin LoadPlugin
565         INTERFACES_COUNT=0
566         config_foreach olsrd_write_interface_defaults InterfaceDefaults
567         config_foreach olsrd_write_interface Interface
568         echo
569
570         return 0
571 }
572
573 olsrd_setup_smartgw_rules() {
574         # Check if ipip is installed
575         [ ! -e /etc/modules.d/[0-9]*-ipip ] && echo "Warning: kmod-ipip is missing. SmartGateway will not work until you install it."
576
577         wanifnames=$(ip r l e 0/0 t all | sed -e 's/^.* dev //' |cut -d " " -f 1 | sort | uniq)
578         nowan=0
579         if [ -z "$wanifnames" ]; then
580                 nowan=1
581         fi
582
583         IP4T=$(which iptables)
584         IP6T=$(which ip6tables)
585
586         # Delete smartgw firewall rules first
587         for IPT in $IP4T $IP6T; do
588                 while $IPT -D forwarding_rule -o tnl_+ -j ACCEPT 2> /dev/null; do :;done
589                 for IFACE in $wanifnames; do
590                         while $IPT -D forwarding_rule -i tunl0 -o $IFACE -j ACCEPT 2> /dev/null; do :; done
591                 done
592                 for IFACE in $ifsglobal; do
593                         while $IPT -D input_rule -i $IFACE -p 4 -j ACCEPT 2> /dev/null; do :; done
594                 done
595         done
596         while $IP4T -t nat -D postrouting_rule -o tnl_+ -j MASQUERADE 2> /dev/null; do :;done
597
598         if [ "$smartgateway" == "yes" ]; then
599                 echo "Notice: Inserting firewall rules for SmartGateway"
600                 if [ ! "$smartgatewayuplink" == "none" ]; then
601                         if [ "$smartgatewayuplink" == "ipv4" ]; then
602                                 # Allow everything to be forwarded to tnl_+ and use NAT for it
603                                 $IP4T -I forwarding_rule -o tnl_+ -j ACCEPT
604                                 $IP4T -t nat -I postrouting_rule -o tnl_+ -j MASQUERADE
605                                 # Allow forwarding from tunl0 to (all) wan-interfaces
606                                 if [ "$nowan"="0" ]; then
607                                         for IFACE in $wanifnames; do
608                                                 $IP4T -A forwarding_rule -i tunl0 -o $IFACE -j ACCEPT
609                                         done
610                                 fi
611                                 # Allow incoming ipip on all olsr-interfaces
612                                 for IFACE in $ifsglobal; do
613                                         $IP4T -I input_rule -i $IFACE -p 4 -j ACCEPT
614                                 done
615                         elif [ "$smartgatewayuplink" == "ipv6" ]; then
616                                 $IP6T -I forwarding_rule -o tnl_+ -j ACCEPT
617                                 if [ "$nowan"="0" ]; then
618                                         for IFACE in $wanifnames; do
619                                                 $IP6T -A forwarding_rule -i tunl0 -o $IFACE -j ACCEPT
620                                         done
621                                 fi
622                                 for IFACE in $ifsglobal; do
623                                         $IP6T -I input_rule -i $IFACE -p 4 -j ACCEPT
624                                 done
625                         else
626                                 for IPT in $IP4T $IP6T; do
627                                         $IPT -I forwarding_rule -o tnl_+ -j ACCEPT
628                                         $IPT -t nat -I postrouting_rule -o tnl_+ -j MASQUERADE
629                                         if [ "$nowan"="0" ]; then
630                                                 for IFACE in $wanifnames; do
631                                                         $IPT -A forwarding_rule -i tunl0 -o $IFACE -j ACCEPT
632                                                 done
633                                         fi
634                                         for IFACE in $ifsglobal; do
635                                                 $IPT -I input_rule -i $IFACE -p 4 -j ACCEPT
636                                         done
637                                 done
638                         fi
639                 fi
640         fi
641 }
642
643 error() {
644         echo "${initscript}:" "$@" 1>&2
645 }
646
647 start() {
648         SYSTEM_HOSTNAME=
649         SYSTEM_LAT=
650         SYSTEM_LON=
651         config_load system
652         config_foreach system_config system
653
654         option_cb() {
655                 olsrd_update_schema "option" "$@"
656         }
657
658         list_cb() {
659                 olsrd_update_schema "list" "$@"
660         }
661
662         include /lib/network
663         scan_interfaces
664         config_load olsrd
665         reset_cb
666
667         OLSRD_CONFIG_FILE=
668         config_foreach olsrd_find_config_file olsrd
669
670         if [ -z "$OLSRD_CONFIG_FILE" ]; then
671                 mkdir -p -- /var/etc/
672                 olsrd_write_config > /var/etc/olsrd.conf
673                 if [ "$INTERFACES_COUNT" -gt 0 -a "$OLSRD_COUNT" -gt 0 ]; then
674                         OLSRD_CONFIG_FILE=/var/etc/olsrd.conf
675                 fi
676         fi
677
678         [ -z "$OLSRD_CONFIG_FILE" ] && return 1
679
680         local bindv6only='0'
681         if [ "$OLSRD_IPVERSION_6AND4" -ne 0 ]; then
682                 bindv6only="$(sysctl -n net.ipv6.bindv6only)"
683                 sysctl -w net.ipv6.bindv6only=1 > /dev/null
684                 sed -e '/[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}/d' < "$OLSRD_CONFIG_FILE" > /var/etc/olsrd.conf.ipv6
685                 sed -e 's/^IpVersion[ ][ ]*6$/IpVersion 4/' -e 's/^\t\t[A-Fa-f0-9.:]*[:][A-Fa-f0-9.:]*[ ][0-9]*$//' < "$OLSRD_CONFIG_FILE" > /var/etc/olsrd.conf.ipv4
686                 rm $OLSRD_CONFIG_FILE
687
688                 # some filenames should get the suffix .ipv6
689                 for file in $latlon_file $hosts_file $services_file $resolv_file $macs_file $wd_file;do
690                         f=$(echo $file|sed 's/\//\\\//g')
691                         sed -i "s/$f/$f.ipv6/g" /var/etc/olsrd.conf.ipv6
692                 done
693
694                 SERVICE_PID_FILE="$PID6"
695                 if service_check /usr/sbin/olsrd; then
696                         error "there already is an IPv6 instance of olsrd running ($(cat $PID6)), not starting."
697                 else
698                         service_start /usr/sbin/olsrd -f /var/etc/olsrd.conf.ipv6 -nofork
699                 fi
700
701                 SERVICE_PID_FILE="$PID"
702                 if service_check /usr/sbin/olsrd; then
703                         error "there already is an IPv4 instance of olsrd running ($(cat $PID)), not starting."
704                 else
705                         service_start /usr/sbin/olsrd -f /var/etc/olsrd.conf.ipv4 -nofork
706                 fi
707
708                 sleep 3
709                 sysctl -w net.ipv6.bindv6only="$bindv6only" > /dev/null
710
711         else
712
713                 if [ "$ipversion" = "6" ]; then
714                         sed -i '/[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}/d' "$OLSRD_CONFIG_FILE"
715                 fi
716
717                 SERVICE_PID_FILE="$PID"
718                 if service_check /usr/sbin/olsrd; then
719                         error "there already is an IPv4 instance of olsrd running ($(cat $PID)), not starting."
720                         return 1
721                 else
722                         service_start /usr/sbin/olsrd -f "$OLSRD_CONFIG_FILE" -nofork
723                 fi
724         fi
725         olsrd_setup_smartgw_rules
726 }
727
728 stop() {
729         SERVICE_PID_FILE="$PID"
730         service_stop /usr/sbin/olsrd
731
732         SERVICE_PID_FILE="$PID6"
733         service_stop /usr/sbin/olsrd
734 }