blob: 79d807123ca34c826a8c34da9133f325ea4fb020 (
plain)
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
|
# Copyright 2007-2008 Roy Marples <roy@marples.name>
# All rights reserved. Released under the 2-clause BSD license.
tuntap_depend()
{
before bridge interface macchanger
}
_config_vars="$_config_vars tunctl"
_is_tuntap()
{
[ -n "$(export SVCNAME="net.${IFACE}"; service_get_value tuntap)" ]
}
tuntap_pre_start()
{
local tuntap=
eval tuntap=\$tuntap_${IFVAR}
[ -z "${tuntap}" ] && return 0
if [ ! -e /dev/net/tun ]; then
modprobe tun && sleep 1
if [ ! -e /dev/net/tun ]; then
eerror "TUN/TAP support is not present in this kernel"
return 1
fi
fi
ebegin "Creating Tun/Tap interface ${IFACE}"
# Set the base metric to 1000
metric=1000
if type tunctl >/dev/null 2>&1; then
local opts=
eval opts=\$tunctl_${IFVAR}
tunctl ${opts} -t "${IFACE}" >/dev/null
else
openvpn --mktun --dev-type "${tuntap}" --dev "${IFACE}" >/dev/null
fi
eend $? && _up && service_set_value tuntap "${tuntap}"
}
tuntap_post_stop()
{
_is_tuntap || return 0
ebegin "Destroying Tun/Tap interface ${IFACE}"
if type tunctl >/dev/null 2>&1; then
tunctl -d "${IFACE}" >/dev/null
else
openvpn --rmtun \
--dev-type "$(service_get_value tuntap)" \
--dev "${IFACE}" >/dev/null
fi
eend $?
}
|