Project

General

Profile

Download (1.6 KB) Statistics
| Branch: | Tag: | Revision:
1 0cc17a06 Lorenz Schori
#!/bin/sh
2
# openvpn learn-address script maintaining DNS entries of connected clients in
3
# unbound config.
4
5 bb38fe11 Lorenz Schori
DOMAIN="${1}"
6
OP="${2}"
7
IP="${3}"
8
CN="${4}"
9 0cc17a06 Lorenz Schori
10 e6e7b00c jim-p
# Trim domain off to avoid duplication if the CN is an FQDN
11
CN=${CN%%.${DOMAIN}}
12
13 de8d3c07 Lorenz Schori
DIR="/var/unbound"
14
PIDFILE="/var/run/unbound.pid"
15
16 a357737c Lorenz Schori
if [ -n "${IP}" -a "$(/usr/bin/basename ${IP})" = "${IP}" ]; then
17 f4e8b87a Lorenz Schori
	CONF="${DIR}/openvpn.client.${IP}.conf"
18
19 bb38fe11 Lorenz Schori
	case "${OP}" in
20 76258fa4 Lorenz Schori
21 f4e8b87a Lorenz Schori
		add|update)
22 a357737c Lorenz Schori
			TMPCONF=$(/usr/bin/mktemp "${CONF}.XXXXXX")
23
			TMPSRV=$(/usr/bin/mktemp "${CONF}.XXXXXX")
24 76258fa4 Lorenz Schori
25 bb38fe11 Lorenz Schori
			if [ -f "${TMPCONF}" -a -f "${TMPSRV}" ]; then
26 5d518166 Lorenz Schori
				# Remove all configs which mention the FQDN
27 bb38fe11 Lorenz Schori
				/usr/bin/grep -l -null "^local-data: \"${CN}.${DOMAIN} A " ${DIR}/openvpn.client.*.conf | /usr/bin/xargs -0 /bin/rm
28
				/bin/test -f "${CONF}" && /bin/rm "${CONF}"
29 5d518166 Lorenz Schori
30
				# Add new local-data entry.
31
				(
32
					echo "local-data-ptr: \"${IP} ${CN}.${DOMAIN}\"" &&
33
					echo "local-data: \"${CN}.${DOMAIN} A ${IP}\"" &&
34
					echo "local-data: \"${CN} A ${IP}\""
35 bb38fe11 Lorenz Schori
				) > "${TMPCONF}"
36 5d518166 Lorenz Schori
37
				# Check syntax, install configuration and restart unbound.
38
				(
39
					echo "server:" &&
40
					echo "chroot: ${DIR}" &&
41
					echo "directory: ${DIR}" &&
42
					echo "include: ${TMPCONF}"
43 bb38fe11 Lorenz Schori
				) > "${TMPSRV}"
44 5d518166 Lorenz Schori
45 bb38fe11 Lorenz Schori
				/bin/chmod 644 "${TMPCONF}" "${TMPSRV}"
46
				/usr/local/sbin/unbound-checkconf "${TMPSRV}" && /bin/mv "${TMPCONF}" "${CONF}"
47 5d518166 Lorenz Schori
48 bb38fe11 Lorenz Schori
				/bin/pkill -HUP -F "${PIDFILE}"
49 5d518166 Lorenz Schori
			fi
50
51 bb38fe11 Lorenz Schori
			/bin/test -f "${TMPCONF}" && /bin/rm "${TMPCONF}"
52
			/bin/test -f "${TMPSRV}" && /bin/rm "${TMPSRV}"
53 f4e8b87a Lorenz Schori
		;;
54 76258fa4 Lorenz Schori
55 f4e8b87a Lorenz Schori
		delete)
56
			# CN is not set on delete.
57 bb38fe11 Lorenz Schori
			/bin/test -f "${CONF}" && /bin/rm "${CONF}" && /bin/pkill -HUP -F "${PIDFILE}"
58 f4e8b87a Lorenz Schori
		;;
59 76258fa4 Lorenz Schori
60 f4e8b87a Lorenz Schori
	esac
61
fi
62 0cc17a06 Lorenz Schori
63
exit 0