Project

General

Profile

Download (3.03 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
		ARECORD='A' 
20
		PTRRECORD=$(/bin/echo ${IP} | /usr/bin/awk -F . '{print $4"."$3"."$2"."$1".in-addr.arpa."}')
21
	else
22
		ARECORD='AAAA' 
23
		PTRRECORD=$(/bin/echo ${IP} | /usr/bin/awk -F: 'BEGIN {OFS=""; }{addCount = 9 - NF; for(i=1; i<=NF;i++){if(length($i) == 0){ for(j=1;j<=addCount;j++){$i = ($i "0000");} } else { $i = substr(("0000" $i), length($i)+5-4);}}; print}'| /usr/bin/rev | /usr/bin/sed -e "s/./&./g;s/.*/&ip6.arpa/")
24
	fi
25
	CONF="${DIR}/openvpn.client.${IP}.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
				# do not restart unbound on connect, see https://redmine.pfsense.org/issues/11129
57
				/usr/bin/su -m unbound -c "/usr/local/sbin/unbound-control -c /var/unbound/unbound.conf local_data ${CN}.${DOMAIN} ${ARECORD} ${IP}"
58
				/usr/bin/su -m unbound -c "/usr/local/sbin/unbound-control -c /var/unbound/unbound.conf local_data ${CN} ${ARECORD} ${IP}"
59
				/usr/bin/su -m unbound -c "/usr/local/sbin/unbound-control -c /var/unbound/unbound.conf local_data ${PTRRECORD} PTR ${CN}.${DOMAIN}"
60

    
61
			fi
62

    
63
			/bin/test -f "${TMPCONF}" && /bin/rm "${TMPCONF}"
64
			/bin/test -f "${TMPSRV}" && /bin/rm "${TMPSRV}"
65
		;;
66

    
67
		delete)
68
			# CN is not set on delete
69
			if [ -f "${CONF}" ]; then
70
				CN=`/usr/bin/sed -nr "s/(local-data-ptr\:) "\""(.*) (.*).${DOMAIN}"\""/\3/p" ${CONF}` &&
71
				/usr/bin/su -m unbound -c "/usr/local/sbin/unbound-control -c /var/unbound/unbound.conf local_data_remove ${CN}.${DOMAIN}" &&
72
				/usr/bin/su -m unbound -c "/usr/local/sbin/unbound-control -c /var/unbound/unbound.conf local_data_remove ${CN}" &&
73
				/usr/bin/su -m unbound -c "/usr/local/sbin/unbound-control -c /var/unbound/unbound.conf local_data_remove ${PTRRECORD}"
74
				/bin/rm "${CONF}"
75
			fi
76
		;;
77

    
78
	esac
79
fi
80

    
81
exit 0
(10-10/34)