blob: f82107dbee3f9583eb9910e9a3f5cefa0b300375 [file] [log] [blame]
Andrew Geissler82c905d2020-04-13 13:39:40 -05001SUMMARY = "A full-featured SSL VPN solution via tun device."
2HOMEPAGE = "https://openvpn.net/"
3SECTION = "net"
4LICENSE = "GPLv2"
5LIC_FILES_CHKSUM = "file://COPYING;md5=7aee596ed2deefe3e8a861e24292abba"
6DEPENDS = "lzo openssl iproute2 ${@bb.utils.contains('DISTRO_FEATURES', 'pam', 'libpam', '', d)}"
7
8inherit autotools systemd update-rc.d
9
10SRC_URI = "http://swupdate.openvpn.org/community/releases/${BP}.tar.gz \
11 file://openvpn \
12 file://openvpn@.service \
13 file://openvpn-volatile.conf"
14
15UPSTREAM_CHECK_URI = "https://openvpn.net/community-downloads"
16
Andrew Geisslerf103a7f2021-05-07 16:09:40 -050017SRC_URI[md5sum] = "7643f135b49aee49df7d83c1f434dc4e"
18SRC_URI[sha256sum] = "b9d295988b34e39964ac475b619c3585d667b36c350cf1adec19e5e3c843ba11"
Andrew Geissler82c905d2020-04-13 13:39:40 -050019
20SYSTEMD_SERVICE_${PN} += "openvpn@loopback-server.service openvpn@loopback-client.service"
21SYSTEMD_AUTO_ENABLE = "disable"
22
23INITSCRIPT_PACKAGES = "${PN}"
24INITSCRIPT_NAME_${PN} = "openvpn"
25INITSCRIPT_PARAMS_${PN} = "start 10 2 3 4 5 . stop 70 0 1 6 ."
26
27CFLAGS += "-fno-inline"
28
29# I want openvpn to be able to read password from file (hrw)
30EXTRA_OECONF += "--enable-iproute2"
31EXTRA_OECONF += "${@bb.utils.contains('DISTRO_FEATURES', 'pam', '', '--disable-plugin-auth-pam', d)}"
32
33# Explicitly specify IPROUTE to bypass the configure-time check for /sbin/ip on the host.
34EXTRA_OECONF += "IPROUTE=${base_sbindir}/ip"
35
36do_install_append() {
37 install -d ${D}/${sysconfdir}/init.d
38 install -m 755 ${WORKDIR}/openvpn ${D}/${sysconfdir}/init.d
39
40 install -d ${D}/${sysconfdir}/openvpn
41 install -d ${D}/${sysconfdir}/openvpn/sample
42 install -m 755 ${S}/sample/sample-config-files/loopback-server ${D}${sysconfdir}/openvpn/sample/loopback-server.conf
43 install -m 755 ${S}/sample/sample-config-files/loopback-client ${D}${sysconfdir}/openvpn/sample/loopback-client.conf
44 install -dm 755 ${D}${sysconfdir}/openvpn/sample/sample-keys
45 install -m 644 ${S}/sample/sample-keys/* ${D}${sysconfdir}/openvpn/sample/sample-keys
46
47 if ${@bb.utils.contains('DISTRO_FEATURES','systemd','true','false',d)}; then
48 install -d ${D}/${systemd_unitdir}/system
49 install -m 644 ${WORKDIR}/openvpn@.service ${D}/${systemd_unitdir}/system
50 install -m 644 ${WORKDIR}/openvpn@.service ${D}/${systemd_unitdir}/system/openvpn@loopback-server.service
51 install -m 644 ${WORKDIR}/openvpn@.service ${D}/${systemd_unitdir}/system/openvpn@loopback-client.service
52
53 install -d ${D}/${localstatedir}
54 install -d ${D}/${localstatedir}/lib
55 install -d -m 710 ${D}/${localstatedir}/lib/openvpn
56
57 install -d ${D}${sysconfdir}/tmpfiles.d
58 install -m 0644 ${WORKDIR}/openvpn-volatile.conf ${D}${sysconfdir}/tmpfiles.d/openvpn.conf
59 sed -i -e 's#@LOCALSTATEDIR@#${localstatedir}#g' ${D}${sysconfdir}/tmpfiles.d/openvpn.conf
60 fi
61}
62
63PACKAGES =+ " ${PN}-sample "
64
65RRECOMMENDS_${PN} = "kernel-module-tun"
66
67FILES_${PN}-dbg += "${libdir}/openvpn/plugins/.debug"
68FILES_${PN} += "${systemd_unitdir}/system/openvpn@.service \
69 ${sysconfdir}/tmpfiles.d \
70 "
71FILES_${PN}-sample += "${systemd_unitdir}/system/openvpn@loopback-server.service \
72 ${systemd_unitdir}/system/openvpn@loopback-client.service \
73 ${sysconfdir}/openvpn/sample/"