aboutsummaryrefslogtreecommitdiff
path: root/external/unbound/contrib/validation-reporter.sh
blob: 7c1a4218bd148453673ecf818d7a6c8bc1d35adb (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
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
#!/bin/sh
# validation reporter - reports validation failures to a collection server.
# Copyright NLnet Labs, 2010
# BSD license.


###
# Here is the configuration for the validation reporter
# it greps the failure lines out of the log and sends them to a server.

# The pidfile for the reporter daemon.
pidfile="/var/run/validation-reporter.pid"

# The logfile to watch for logged validation failures.
logfile="/var/log/unbound.log"

# how to notify the upstream 
# nc is netcat, it sends tcp to given host port.  It makes a tcp connection
# and writes one log-line to it (grepped from the logfile).
# the notify command can be: "nc the.server.name.org 1234"
# the listening daemon could be:  nc -lk 127.0.0.1 1234 >> outputfile &
notify_cmd="nc localhost 1234"


###
# Below this line is the code for the validation reporter,
# first the daemon itself, then the controller for the daemon.
reporter_daemon() {
	trap "rm -f \"$pidfile\"" EXIT
	tail -F $logfile | grep --line-buffered "unbound.*info: validation failure" | \
	while read x; do
		echo "$x" | $notify_cmd
	done
}


###
# controller for daemon.
start_daemon() {
	echo "starting reporter"
	nohup $0 rundaemon </dev/null >/dev/null 2>&1 &
	echo $! > "$pidfile"
}

kill_daemon() {
	echo "stopping reporter"
	if test -s "$pidfile"; then
		kill `cat "$pidfile"`
		# check it is really dead
		if kill -0 `cat "$pidfile"` >/dev/null 2>&1; then
			sleep 1
			while kill -0 `cat "$pidfile"` >/dev/null 2>&1; do
				kill `cat "$pidfile"` >/dev/null 2>&1
				echo "waiting for reporter to stop"
				sleep 1
			done
		fi
	fi
}

get_status_daemon() {
	if test -s "$pidfile"; then
		if kill -0 `cat "$pidfile"`; then
			return 0;
		fi
	fi
	return 1;
}

restart_daemon() {
	kill_daemon
	start_daemon
}

condrestart_daemon() {
	if get_status_daemon; then
		echo "reporter ("`cat "$pidfile"`") is running"
		exit 0
	fi
	start_daemon
	exit 0
}

status_daemon() {
	if get_status_daemon; then
		echo "reporter ("`cat "$pidfile"`") is running"
		exit 0
	fi
	echo "reporter is not running"
	exit 1
}

case "$1" in
	rundaemon)
		reporter_daemon
	;;
	start)
		start_daemon
	;;
	stop)
		kill_daemon
	;;
	restart)
		restart_daemon
	;;
	condrestart)
		condrestart_daemon
	;;
	status)
		status_daemon
	;;
	*)
		echo "Usage: $0 {start|stop|restart|condrestart|status}"
		exit 2
	;;
esac
exit $?