summaryrefslogtreecommitdiff
path: root/scripts/quagga-manager
blob: 5beb87806a719d4a65a394dfceb5850297d08a28 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
#! /bin/bash
#
# This is special script for start,stop,restart of quagga daemons
#

# debug
# echo $* | logger -p local7.debug -t quagga-manager

usage() {
    echo "Usage: $0 {check|start|stop|restart} {bgpd|ospfd|ripd|ospf6d|ripngd} ..."
    exit 1
}

if [ $# -lt 1 ]; then
    usage
fi

pid_dir=/var/run/vyatta/quagga
log_dir=/var/log/vyatta/quagga

. /lib/lsb/init-functions

status() {
    local daemon=$1
    local pidfile=${pid_dir}/${daemon}.pid
    local binpath=/usr/sbin/vyatta-$daemon
    status_of_proc -p $pidfile $binpath $daemon && exit 0 || exit $?
}

start() {
    local daemon=$1
    local pidfile=${pid_dir}/${daemon}.pid
    local binpath=/usr/sbin/vyatta-$daemon

    if [ $EUID -ne 0 ]; then
        echo "must be root!"
        exit 1
    fi

    if [ ! -x $binpath ]; then
	echo "Unknown daemon $daemon"
	return 1
    fi

    local -a args=( -d -P 0 -i $pidfile )
    case $daemon in
    zebra)	args+=( -l -S -s 1048576 );;
    bgpd)	args+=( -I );;
    esac

    start-stop-daemon --start --oknodo --quiet \
	--chdir $log_dir --exec $binpath --pidfile $pidfile -- ${args[@]}
}

stop() {
    local daemon=$1
    local pidfile=${pid_dir}/${daemon}.pid
    local binpath=/usr/sbin/vyatta-$daemon

    if [ $EUID -ne 0 ]; then
        echo "must be root!"
        exit 1
    fi
    start-stop-daemon --stop --quiet --oknodo --retry 5 \
	--exec $binpath --pidfile=$pidfile
    rm -f $pidfile
}

get_protocol() {
    local daemon=$1
    case $daemon in
    bgpd|ospfd|ripd|ripngd|isisd)   echo ${daemon/%d/};;
    ospf6d)			    echo "ospfv3";;
    *)  echo "Unknown daemon $daemon" 1>&2; exit 1;;
    esac
}

reload_config() {
    local daemon=$1
    local proto=$(get_protocol $daemon)

    local vyatta_cfg=/opt/vyatta/config/active
    local path=$vyatta_cfg/protocols/$proto

    # If daemon does not have config nothing to do.
    [ -d $path ] || return;

    # Begin reloading transaction
    /opt/vyatta/sbin/vyatta-cfg-cmd-wrapper begin || exit 1

    # In case of error undo
    trap "/opt/vyatta/sbin/vyatta-cfg-cmd-wrapper end" EXIT HUP INT QUIT TERM
    
    # Save current configuration
    tmp=/tmp/${daemon}-restart.$$
    /opt/vyatta/sbin/vyatta-save-config.pl $tmp || exit 1

    # Erase portion of active configuration for that protocol
    rm -fr $path

    # special case for interface, remove parameters force reload
    case $proto in
    rip|ospf)
	    find $vyatta_cfg/interfaces -type d -path "*/ip/$proto" \
		-exec rm -fr '{}' \; ;;
    ripng|ospfv3)
	    find $vyatta_cfg/interfaces -type d -path "*/ipv6/$proto" \
		-exec rm -fr '{}' \; ;;
    esac

    # Reload causing configuration to activate - implies commit
    /opt/vyatta/sbin/vyatta-load-config.pl $tmp || exit 1

    # remove tmp file if successful
    rm $tmp
    trap "" EXIT HUP INT QUIT TERM
}

action=$1
shift

for daemon; do
    case "$action" in
	start)   start $daemon ;;
	stop)    stop $daemon ;;
	status)  status $daemon ;;
	reload)  start $daemon; reload_config $daemon ;;
	restart) stop $daemon; start $daemon ;;
	*)       usage;;
    esac
done