Project

General

Profile

Download (1.83 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
IPV4REGEX='^[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}\.[0-9]\{1,3\}$'
16

    
17
if [ -n "${IP}" -a "$(/usr/bin/basename ${IP})" = "${IP}" ]; then
18
	if [ $(expr "${IP}" : ${IPV4REGEX}) -ne 0 ]; then
19
		SUFFIX='ipv4' 
20
		ARECORD='A' 
21
	else
22
		SUFFIX='ipv6' 
23
		ARECORD='AAAA' 
24
	fi
25
	CONF="${DIR}/openvpn.client.${CN}.${SUFFIX}.conf"
26

    
27
	case "${OP}" in
28

    
29
		add|update)
30
			TMPCONF=$(/usr/bin/mktemp "${CONF}.XXXXXX")
31
			TMPSRV=$(/usr/bin/mktemp "${CONF}.XXXXXX")
32

    
33
			if [ -f "${TMPCONF}" -a -f "${TMPSRV}" ]; then
34
				# Remove all configs which mention the FQDN
35
				/usr/bin/grep -l -null "^local-data: \"${CN}.${DOMAIN} ${ARECORD} " ${DIR}/openvpn.client.*.conf | /usr/bin/xargs -0 /bin/rm
36
				/bin/test -f "${CONF}" && /bin/rm "${CONF}"
37

    
38
				# Add new local-data entry.
39
				(
40
					echo "local-data-ptr: \"${IP} ${CN}.${DOMAIN}\"" &&
41
					echo "local-data: \"${CN}.${DOMAIN} ${ARECORD} ${IP}\"" &&
42
					echo "local-data: \"${CN} ${ARECORD} ${IP}\""
43
				) > "${TMPCONF}"
44

    
45
				# Check syntax, install configuration and restart unbound.
46
				(
47
					echo "server:" &&
48
					echo "chroot: ${DIR}" &&
49
					echo "directory: ${DIR}" &&
50
					echo "include: ${TMPCONF}"
51
				) > "${TMPSRV}"
52

    
53
				/bin/chmod 644 "${TMPCONF}" "${TMPSRV}"
54
				/usr/local/sbin/unbound-checkconf "${TMPSRV}" && /bin/mv "${TMPCONF}" "${CONF}"
55

    
56
				/bin/pkill -HUP -F "${PIDFILE}"
57
			fi
58

    
59
			/bin/test -f "${TMPCONF}" && /bin/rm "${TMPCONF}"
60
			/bin/test -f "${TMPSRV}" && /bin/rm "${TMPSRV}"
61
		;;
62

    
63
		delete)
64
			# CN is not set on delete.
65
			/bin/test -f "${CONF}" && /bin/rm "${CONF}" && /bin/pkill -HUP -F "${PIDFILE}"
66
		;;
67

    
68
	esac
69
fi
70

    
71
exit 0
(9-9/32)