bgpd: tighten bounds checking in RR ORF msg reader
[jleu-quagga.git] / solaris / quagga.init.in
blob8457e990387f2f8e9e546d46e9a76b3ffd9f9b52
1 #!/sbin/sh
3 # Copyright 2007 Sun Microsystems, Inc. All rights reserved.
4 # Use is subject to license terms.
6 # This file is part of Quagga.
8 # Quagga is free software; you can redistribute it and/or modify it
9 # under the terms of the GNU General Public License as published by the
10 # Free Software Foundation; either version 2, or (at your option) any
11 # later version.
13 # Quagga is distributed in the hope that it will be useful, but
14 # WITHOUT ANY WARRANTY; without even the implied warranty of
15 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 # General Public License for more details.
18 # You should have received a copy of the GNU General Public License
19 # along with Quagga; see the file COPYING. If not, write to the Free
20 # Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
21 # 02111-1307, USA.
23 # $Id$
25 # Starts/stops the given daemon
27 SMFINCLUDE=/lib/svc/share/smf_include.sh
28 ROUTEADMINCLUDE=/lib/svc/share/routing_include.sh
29 GLOBAL_OPTIONS="PAfiug"
30 DAEMON_PATH=@sbindir@
31 USER=@enable_user@
32 GROUP=@enable_group@
34 # handle upgrade of daemon-args SMF property to new routeadm properties
35 # used during upgrade too by routeadm.
36 # relevant to S10U4+ only.
37 handle_routeadm_upgrade () {
38 GLOBAL_OPTIONS="PAfiug"
40 daemon_args=`get_daemon_args $SMF_FMRI`
42 if [ -n "$daemon_args" ]; then
43 set_daemon_value_property "$SMF_FMRI" "$daemon_args" \
44 "$GLOBAL_OPTIONS" "P" vty_port 0
45 set_daemon_value_property "$SMF_FMRI" "$daemon_args" \
46 "$GLOBAL_OPTIONS" "A" vty_address
47 set_daemon_value_property "$SMF_FMRI" "$daemon_args" \
48 "$GLOBAL_OPTIONS" "f" config_file
49 set_daemon_value_property "$SMF_FMRI" "$daemon_args" \
50 "$GLOBAL_OPTIONS" "i" pid_file
51 set_daemon_value_property "$SMF_FMRI" "$daemon_args" \
52 "$GLOBAL_OPTIONS" "u" user
53 set_daemon_value_property "$SMF_FMRI" "$daemon_args" \
54 "$GLOBAL_OPTIONS" "g" group
56 case "$1" in
57 zebra)
58 set_daemon_boolean_property "$SMF_FMRI" "$daemon_args" \
59 "${GLOBAL_OPTIONS}b" "b" batch true false
61 ripd|ripngd)
62 set_daemon_boolean_property "$SMF_FMRI" "$daemon_args" \
63 "${GLOBAL_OPTIONS}r" "r" retain true false
65 bgpd)
66 set_daemon_boolean_property "$SMF_FMRI" "$daemon_args" \
67 "${GLOBAL_OPTIONS}rnp" "r" retain true false
68 set_daemon_boolean_property "$SMF_FMRI" "$daemon_args" \
69 "${GLOBAL_OPTIONS}rnp" "n" no_kernel true false
70 set_daemon_value_property "$SMF_FMRI" "$daemon_args" \
71 "${GLOBAL_OPTIONS}rnp" "p" bgp_port
72 esac
73 clear_daemon_args $SMF_FMRI
77 upgrade_config () {
78 DAEMON=$1
79 # handle upgrade of SUNWzebra to Quagga
80 if [ -d "/etc/quagga" -a ! -f "/etc/quagga/${DAEMON}.conf" ] ; then
81 if [ -f "/etc/sfw/zebra/${DAEMON}.conf" ] ; then
82 cp "/etc/sfw/zebra/${DAEMON}.conf" \
83 "/etc/quagga/${DAEMON}.conf.upgrade" \
84 || exit $SMF_EXIT_ERR_FATAL
85 chown "${USER}:${GROUP}" "/etc/quagga/${DAEMON}.conf.upgrade" \
86 || exit $SMF_EXIT_ERR_FATAL
87 chmod 0600 "/etc/quagga/${DAEMON}.conf.upgrade" \
88 || exit $SMF_EXIT_ERR_FATAL
89 mv "/etc/quagga/${DAEMON}.conf.upgrade" "/etc/quagga/${DAEMON}.conf" \
90 || exit $SMF_EXIT_ERR_FATAL
94 if [ ! -f "/etc/quagga/${DAEMON}.conf" ] ; then
95 touch "/etc/quagga/${DAEMON}.conf.new" \
96 || exit $SMF_EXIT_ERR_FATAL
97 chown "${USER}:${GROUP}" "/etc/quagga/${DAEMON}.conf.new" \
98 || exit $SMF_EXIT_ERR_FATAL
99 chmod 0600 "/etc/quagga/${DAEMON}.conf.new" \
100 || exit $SMF_EXIT_ERR_FATAL
101 mv "/etc/quagga/${DAEMON}.conf.new" "/etc/quagga/${DAEMON}.conf" \
102 || exit $SMF_EXIT_ERR_FATAL
106 # Relevant to S10+
107 quagga_is_globalzone () {
108 if [ "${QUAGGA_INIT_ZONENAME:=`/sbin/zonename`}" = "global" \
109 -o `/sbin/zonename -t` = "exclusive" ]; then
110 return 0
111 else
112 return 1
116 routeadm_daemon_args () {
117 # globals
118 args="`get_daemon_option_from_property $SMF_FMRI config_file f`"
119 args="${args} `get_daemon_option_from_property $SMF_FMRI vty_port P`"
120 args="${args} `get_daemon_option_from_property $SMF_FMRI vty_address A`"
121 args="${args} `get_daemon_option_from_property $SMF_FMRI pid_file i`"
123 # user and group we need for config file upgrade..
124 SMF_USER=`get_routeadm_property $SMF_FMRI user`
125 SMF_GROUP=`get_routeadm_property()$SMF_FMRI group`
126 if [ "${SMF_USER}" ] ; then
127 USER="${SMF_USER}"
128 args="${args} -u ${SMF_USER}"
130 if [ "${SMF_GROUP}" ] ; then
131 GROUP="${SMF_GROUP}"
132 args="${args} -g ${SMF_GROUP}"
135 case $1 in
136 zebra)
137 args="${args} `get_daemon_option_from_boolean_property $SMF_FMRI batch -b true`"
139 ripd|ripngd)
140 args="${args} `get_daemon_option_from_boolean_property $SMF_FMRI retain -r true`"
142 bgpd)
143 args="${args} `get_daemon_option_from_boolean_property $SMF_FMRI retain -r true`"
144 args="${args} `get_daemon_option_from_boolean_property $SMF_FMRI no_kernel -n true`"
145 args="${args} `get_daemon_option_from_property $SMF_FMRI bgp_port p 179`"
147 esac
148 echo ${args}
151 # certain daemons need zebra
152 routeadm_zebra_enable () {
154 if [ "$DAEMON" = "zebra" ]; then
155 return
158 enable_zebra=`/usr/bin/svcprop -p \
159 routing/enable_zebra $SMF_FMRI 2> /dev/null`
160 if [ "$enable_zebra" != "false" ]; then
161 zenabled=`/usr/bin/svcprop -p general/enabled zebra:quagga`
162 zenabledt=`/usr/bin/svcprop -p general_ovr/enabled zebra:quagga`
163 if [ "$zenabled" = "true" -o "$zenabledt" = "true" ]; then
164 /usr/sbin/svcadm disable zebra:quagga
165 /usr/sbin/svcadm enable -st zebra:quagga
166 else
167 /usr/sbin/svcadm enable -st zebra:quagga
169 if [ "$?" != "0" ]; then
170 echo "Could not enable zebra:quagga"
171 exit $SMF_EXIT_ERR_FATAL
176 # Include smf functions, if available. If not, define smf_present to indicate
177 # there is no SMF. Should allow this script to work pre-S10.
178 if [ -f "$SMFINCLUDE" ] ; then
179 . "$SMFINCLUDE";
181 # source the SMF-routeadm include if present..
182 if [ -f "$ROUTEADMINCLUDE" ] ; then
183 . "$ROUTEADMINCLUDE"
185 else
186 # pre-SMF system, fake up any functions and exit codes
187 # which SMFINCLUDE usually provides.
188 smf_present () {
189 return 1
191 SMF_EXIT_OK=0;
192 SMF_EXIT_ERR_CONFIG=96;
193 SMF_EXIT_ERR_FATAL=95;
196 # if there's no SMF, set some default DAEMON_ARGS
197 smf_present || DAEMON_ARGS=""
199 usage () {
200 if smf_present ; then
201 echo "Usage: $0 <daemon>";
202 else
203 echo "Usage: $0 <stop|start> <daemon> <daemon arguments>";
205 echo "The --pid_file argument is implied";
206 echo "This help message: $0 <help|usage>";
209 # parse arguments, different according to SMF or not.
210 case $1 in
211 'help' | 'usage')
212 usage
213 exit $SMF_EXIT_OK
215 esac
217 if smf_present ; then
218 QUAGGA_METHOD="start"
219 else
220 QUAGGA_METHOD="$1"
221 shift;
224 DAEMON="$1"
226 # daemon path must be given
227 if [ -z "$DAEMON_PATH/$DAEMON" ]; then
228 usage
229 exit $SMF_EXIT_ERR_FATAL
232 # only bgpd is suitable for running in a non-global zone, at this
233 # time.
234 case "${DAEMON}" in
235 bgpd)
237 zebra | ospfd | ospf6d | ripd | ripngd )
238 quagga_is_globalzone || exit $SMF_EXIT_OK
241 usage
242 exit $SMF_EXIT_ERR_CONFIG;
244 esac
246 # Older Quagga SMF packages pass daemon args on the commandline
247 # Newer SMF routeadm model uses properties for each argument
248 # so we must handle that.
249 if [ smf_present -a -f "$ROUTEADMINCLUDE" ]; then
250 handle_routeadm_upgrade $DAEMON;
251 DAEMON_ARGS=`routeadm_daemon_args`;
252 routeadm_zebra_enable $DAEMON;
253 else
254 if [ $# -gt 0 ] ; then
255 shift
256 DAEMON_ARGS="$@"
260 upgrade_config "$DAEMON"
262 if [ ! -f "@sysconfdir@/${DAEMON}.conf" ] ; then
263 echo "Could not find config file, @sysconfdir@/${DAEMON}.conf"
264 exit $SMF_EXIT_ERR_CONFIG
267 # we need @quagga_statedir@ to exist, it probably is on tmpfs.
268 if [ ! -d @quagga_statedir@ ] ; then
269 mkdir -p @quagga_statedir@
270 chown @enable_user@:@enable_group@ @quagga_statedir@
271 chmod 751 @quagga_statedir@
274 PIDFILE="@quagga_statedir@/${DAEMON}.pid"
276 start () {
277 if [ ! -x "$DAEMON_PATH/$DAEMON" ] ; then
278 echo "Error, could not find daemon, $DAEMON_PATH/$DAEMON"
279 exit $SMF_EXIT_ERR_FATAL
281 eval exec $DAEMON_PATH/$DAEMON $DAEMON_ARGS --pid_file ${PIDFILE} &
284 stop_by_pidfile () {
285 if [ -f "${PIDFILE}" ]; then
286 /usr/bin/kill -TERM `/usr/bin/cat "${PIDFILE}"`
290 case "$QUAGGA_METHOD" in
291 'start')
292 start
294 'stop')
295 stop_by_pidfile
299 usage
300 exit $SMF_EXIT_ERR_FATAL
302 esac
304 exit $SMF_EXIT_OK;