summaryrefslogtreecommitdiff
path: root/security/opendnssec/files/opendnssec.sh
blob: 369aab00b0717217e2faf24de6385af2eddf1eb8 (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
133
134
135
#!/bin/sh
#
# $NetBSD: opendnssec.sh,v 1.1 2014/10/28 13:26:37 he Exp $
#

# PROVIDE: opendnssec
# REQUIRE: NETWORKING mountcritremote syslogd
# BEFORE:  DAEMON

$_rc_subr_loaded . /etc/rc.subr

name="opendnssec"
rcvar=$name

start_cmd=ods_start
stop_cmd=ods_stop
restart_cmd=ods_restart
status_cmd=ods_status
poll_cmd=ods_poll

enforcer_pidfile=/var/run/opendnssec/enforcerd.pid
signerd_pidfile=/var/run/opendnssec/signerd.pid

enforcer=/usr/pkg/sbin/ods-enforcerd
signer=/usr/pkg/sbin/ods-signerd

ods_control=/usr/pkg/sbin/ods-control

# Gain PID related commands
pidfile=$enforcer_pidfile
procname=$enforcer

ods_start () {

	rv=0
	if [ -f $enforcer_pidfile ]; then
		ep=$(check_pidfile $enforcer_pidfile $enforcer)

		if [ "$ep" != "" ]; then
			echo 1>&2 "$enforcer already running (pid=$ep)"
			rv=$(($rv + 1))
		fi
	fi

	if [ -f $signerd_pidfile ]; then
		sp=$(check_pidfile $signerd_pidfile $signer)
		if [ "$sp" != "" ]; then
			echo 1>&2 "$signer already running (pid=$sp)"
			rv=$(($rv + 1))
		fi
	fi
	if [ $rv != 0 ]; then
		exit $rv
	fi

	$ods_control start
}

ods_stop () {

	rv=0
	pids=""
	if [ -f $enforcer_pidfile ]; then
		ep=$(check_pidfile $enforcer_pidfile $enforcer)
		if [ "$ep" != "" ]; then
			pids="$pids $ep"
		else
			echo 1>&2 \
			    "$enforcer not running (check $enforcer_pidfile)"
			rv=$(($rv + 1))
		fi
	else
		echo 1>&2 "$enforcer not running (no $enforcer_pidfile file)"
		rv=$(($rv + 1))
	fi
	if [ -f $signerd_pidfile ]; then
		sp=$(check_pidfile $signerd_pidfile $signer)
		if [ "$sp" != "" ]; then
			pids="$pids $sp"
		else
			echo 1>&2 "$signer not running (check $signerd_pidfile)"
			rv=$(($rv + 1))
		fi
	else
		echo 1>&2 "$signer not running (no $signerd_pidfile file)"
		rv=$(($rv + 1))
	fi
	if [ $rv != 0 ]; then
		exit $rv
	fi

	$ods_control stop

	wait_for_pids $pids
}

ods_restart () {

	ods_stop
	ods_start
}

ods_status () {

	ep=$(check_pidfile $enforcer_pidfile $enforcer)
	sp=$(check_pidfile $signerd_pidfile $signer)

	rv=0
	if [ "$ep" != "" ]; then
		echo "$enforcer running as PID $ep"
	else
		echo "$enforcer not running"
		rv=$(($rv + 1))
	fi
	if [ "$sp" != "" ]; then
		echo "$signer running as PID $sp"
	else
		echo "$signer not running"
		rv=$(($rv + 1))
	fi
	return $rv
}

ods_poll () {

	ep=$(check_pidfile $enforcer_pidfile $enforcer)
	sp=$(check_pidfile $signerd_pidfile $signer)

	if [ "$ep" != "" -o "$sp" != "" ]; then
		wait_for_pids $ep $sp
	fi
}

load_rc_config $name
run_rc_command "$1"