Project

General

Profile

Download (1.6 KB) Statistics
| Branch: | Tag: | Revision:
1
#!/bin/sh
2
# openvpn learn-address script maintaining DNS entries of connected clients in
3
# unbound config.
4

    
5
DOMAIN="${1}"
6
OP="${2}"
7
IP="${3}"
8
CN="${4}"
9

    
10
# Trim domain off to avoid duplication if the CN is an FQDN
11
CN=${CN%%.${DOMAIN}}
12

    
13
DIR="/var/unbound"
14
PIDFILE="/var/run/unbound.pid"
15

    
16
if [ -n "${IP}" -a "$(/usr/bin/basename ${IP})" = "${IP}" ]; then
17
	CONF="${DIR}/openvpn.client.${IP}.conf"
18

    
19
	case "${OP}" in
20

    
21
		add|update)
22
			TMPCONF=$(/usr/bin/mktemp "${CONF}.XXXXXX")
23
			TMPSRV=$(/usr/bin/mktemp "${CONF}.XXXXXX")
24

    
25
			if [ -f "${TMPCONF}" -a -f "${TMPSRV}" ]; then
26
				# Remove all configs which mention the FQDN
27
				/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

    
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
				) > "${TMPCONF}"
36

    
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
				) > "${TMPSRV}"
44

    
45
				/bin/chmod 644 "${TMPCONF}" "${TMPSRV}"
46
				/usr/local/sbin/unbound-checkconf "${TMPSRV}" && /bin/mv "${TMPCONF}" "${CONF}"
47

    
48
				/bin/pkill -HUP -F "${PIDFILE}"
49
			fi
50

    
51
			/bin/test -f "${TMPCONF}" && /bin/rm "${TMPCONF}"
52
			/bin/test -f "${TMPSRV}" && /bin/rm "${TMPSRV}"
53
		;;
54

    
55
		delete)
56
			# CN is not set on delete.
57
			/bin/test -f "${CONF}" && /bin/rm "${CONF}" && /bin/pkill -HUP -F "${PIDFILE}"
58
		;;
59

    
60
	esac
61
fi
62

    
63
exit 0
(9-9/31)