blob: 77d14d7d7666ae2c27e166967ea1bb5863009006 (
plain) (
blame)
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
|
#!/bin/sh
#
# $FreeBSD$
#
# PROVIDE: tac_plus
# REQUIRE: DAEMON
#
# Add the following line to /etc/rc.conf to enable the TACACS+ daemon:
#
# tac_plus_enable (bool): Set to "NO" by default
# Set it to "YES" to enable tac_plus
# tac_plus_flags (str): Set to "" by default
# Extra flags to be passed to start command
# tac_plus_profiles (str): Set to "" by default
# Allows you to run multiple tac_plus daemons with
# different settings
# tac_plus_configfile (str): Set to "%%PREFIX%%/etc/tac_plus.conf" by default
# Allows you to specify a different config file for
# the tac_plus daemon
. %%RC_SUBR%%
name=tac_plus
rcvar=`set_rcvar`
command="%%PREFIX%%/bin/tac_plus"
pidfile="/var/run/${name}.pid"
tac_plus_enable=${tac_plus_enable:-"NO"}
tac_plus_flags=${tac_plus_flags:-}
tac_plus_profiles=${tac_plus_profiles:-}
tac_plus_configfile=${tac_plus_configfile:-"%%PREFIX%%/etc/tac_plus.conf"}
load_rc_config ${name}
if [ -n "$2" ]; then
profile="$2"
if [ "x${tac_plus_profiles}" != "x" ]; then
eval tac_plus_configfile="\${tac_plus_${profile}_configfile:-}"
if [ "x${tac_plus_configfile}" = "x" ]; then
echo "You must define a configuration file (tac_plus_${profile}_configfile)"
exit 1
fi
required_files="${tac_plus_configfile}"
eval tac_plus_enable="\${tac_plus_${profile}_enable:-${tac_plus_enable}}"
eval tac_plus_flags="\${tac_plus_${profile}_flags:-${tac_plus_flags}}"
eval tac_plus_port="\${tac_plus_${profile}_port:-}"
eval tac_plus_ip="\${tac_plus_${profile}_ip:-}"
else
echo "$0: extra argument ignored"
fi
else
if [ "x${tac_plus_profiles}" != "x" -a "x$1" != "x" ]; then
for profile in ${tac_plus_profiles}; do
eval _enable="\${tac_plus_${profile}_enable}"
case "x${_enable:-${tac_plus_enable}}" in
x|x[Nn][Oo]|x[Nn][Oo][Nn][Ee])
continue
;;
x[Yy][Ee][Ss])
;;
*)
if test -z "$_enable"; then
_var=tac_plus_enable
else
_var=tac_plus_"${profile}"_enable
fi
echo "Bad value "\
"'${_enable:-${tac_plus_enable}}' "\
"for ${_var}. "\
"Profile ${profile} skipped."
continue
esac
echo "====> tac_plus profile: ${profile}"
%%PREFIX%%/etc/rc.d/tac_plus $1 ${profile}
retcode="$?"
if [ "0${retcode}" -ne 0 ]; then
failed="${profile} (${retcode}) ${failed:-}"
else
success="${profile} ${success:-}"
fi
done
exit 0
fi
fi
tac_plus_flags="-C ${tac_plus_configfile} ${tac_plus_flags}"
if [ "x${tac_plus_ip}" != "x" ]; then
pidfile="${pidfile}.${tac_plus_ip}"
tac_plus_flags="${tac_plus_flags} -B ${tac_plus_ip}"
fi
if [ "x${tac_plus_port}" != "x" ]; then
pidfile="${pidfile}.${tac_plus_port}"
tac_plus_flags="${tac_plus_flags} -p ${tac_plus_port}"
fi
run_rc_command "$1"
|