blob: f0109069cb34404b5a1b904f99b7c08f1a1473c5 [file] [log] [blame]
Patrick Williamsb48b7b42016-08-17 15:04:38 -05001SUMMARY = "A full-featured SSL VPN solution via tun device."
2HOMEPAGE = "http://openvpn.sourceforge.net"
3SECTION = "net"
4LICENSE = "GPLv2"
5LIC_FILES_CHKSUM = "file://COPYING;md5=5aac200199fde47501876cba7263cb0c"
6DEPENDS = "lzo openssl iproute2 ${@base_contains('DISTRO_FEATURES', 'pam', 'libpam', '', d)}"
7
8inherit autotools systemd
9
10SRC_URI = "http://swupdate.openvpn.org/community/releases/openvpn-${PV}.tar.gz \
11 file://openvpn \
12 file://openvpn@.service \
13 file://openvpn-volatile.conf"
14
15SRC_URI[md5sum] = "51d996f1f1fc30f501ae251a254effeb"
16SRC_URI[sha256sum] = "532435eff61c14b44a583f27b72f93e7864e96c95fe51134ec0ad4b1b1107c51"
17
18SYSTEMD_SERVICE_${PN} += "openvpn@loopback-server.service openvpn@loopback-client.service"
19SYSTEMD_AUTO_ENABLE = "disable"
20
21CFLAGS += "-fno-inline"
22
23# I want openvpn to be able to read password from file (hrw)
24EXTRA_OECONF += "--enable-password-save --enable-iproute2"
25EXTRA_OECONF += "${@base_contains('DISTRO_FEATURES', 'pam', '', '--disable-plugin-auth-pam', d)}"
26
27# Explicitly specify IPROUTE to bypass the configure-time check for /sbin/ip on the host.
28EXTRA_OECONF += "IPROUTE=/sbin/ip"
29
30do_install_append() {
31 install -d ${D}/${sysconfdir}/init.d
32 install -m 755 ${WORKDIR}/openvpn ${D}/${sysconfdir}/init.d
33
34 install -d ${D}/${sysconfdir}/openvpn
35 install -d ${D}/${sysconfdir}/openvpn/sample
36 install -m 755 ${S}/sample/sample-config-files/loopback-server ${D}${sysconfdir}/openvpn/sample/loopback-server.conf
37 install -m 755 ${S}/sample/sample-config-files/loopback-client ${D}${sysconfdir}/openvpn/sample/loopback-client.conf
38 install -dm 755 ${D}${sysconfdir}/openvpn/sample/sample-keys
39 install -m 644 ${S}/sample/sample-keys/* ${D}${sysconfdir}/openvpn/sample/sample-keys
40
41 if ${@base_contains('DISTRO_FEATURES','systemd','true','false',d)}; then
42 install -d ${D}/${systemd_unitdir}/system
43 install -m 644 ${WORKDIR}/openvpn@.service ${D}/${systemd_unitdir}/system
44 install -m 644 ${WORKDIR}/openvpn@.service ${D}/${systemd_unitdir}/system/openvpn@loopback-server.service
45 install -m 644 ${WORKDIR}/openvpn@.service ${D}/${systemd_unitdir}/system/openvpn@loopback-client.service
46
47 install -d ${D}/${localstatedir}
48 install -d ${D}/${localstatedir}/lib
49 install -d -m 710 ${D}/${localstatedir}/lib/openvpn
50 install -d -m 755 ${D}/${localstatedir}/run/
51 install -d -m 755 ${D}/${localstatedir}/run/openvpn
52
53 install -d ${D}${sysconfdir}/tmpfiles.d
54 install -m 0644 ${WORKDIR}/openvpn-volatile.conf ${D}${sysconfdir}/tmpfiles.d/openvpn.conf
55 fi
56}
57
58PACKAGES =+ " ${PN}-sample "
59
60RRECOMMENDS_${PN} = "kernel-module-tun"
61
62FILES_${PN}-dbg += "${libdir}/openvpn/plugins/.debug"
63FILES_${PN} += "${systemd_unitdir}/system/openvpn@.service \
64 /run"
65FILES_${PN}-sample += "${systemd_unitdir}/system/openvpn@loopback-server.service \
66 ${systemd_unitdir}/system/openvpn@loopback-client.service \
67 ${sysconfdir}/openvpn/sample/"