blob: 4ee881ddd5a657860a3c47b178e40dd960e0072d [file] [log] [blame]
Patrick Williamsb48b7b42016-08-17 15:04:38 -05001SUMMARY = "Very Secure FTP server"
2HOMEPAGE = "https://security.appspot.com/vsftpd.html"
3SECTION = "net"
4LICENSE = "GPLv2"
5LIC_FILES_CHKSUM = "file://COPYING;md5=a6067ad950b28336613aed9dd47b1271"
6
7DEPENDS = "libcap openssl"
8
9SRC_URI = "https://security.appspot.com/downloads/vsftpd-${PV}.tar.gz \
10 file://makefile-destdir.patch \
11 file://makefile-libs.patch \
12 file://makefile-strip.patch \
13 file://init \
14 file://vsftpd.conf \
15 file://vsftpd.user_list \
16 file://vsftpd.ftpusers \
17 file://change-secure_chroot_dir.patch \
18 file://volatiles.99_vsftpd \
19 file://vsftpd.service \
20 file://vsftpd-2.1.0-filter.patch \
21"
22
23LIC_FILES_CHKSUM = "file://COPYING;md5=a6067ad950b28336613aed9dd47b1271 \
24 file://COPYRIGHT;md5=04251b2eb0f298dae376d92454f6f72e \
25 file://LICENSE;md5=654df2042d44b8cac8a5654fc5be63eb"
26SRC_URI[md5sum] = "da119d084bd3f98664636ea05b5bb398"
27SRC_URI[sha256sum] = "9d4d2bf6e6e2884852ba4e69e157a2cecd68c5a7635d66a3a8cf8d898c955ef7"
28
29
30PACKAGECONFIG ??= "tcp-wrappers"
31PACKAGECONFIG[tcp-wrappers] = ",,tcp-wrappers"
32SRC_URI +="${@base_contains('PACKAGECONFIG', 'tcp-wrappers', 'file://vsftpd-tcp_wrappers-support.patch', '', d)}"
33
34DEPENDS += "${@base_contains('DISTRO_FEATURES', 'pam', 'libpam', '', d)}"
35RDEPENDS_${PN} += "${@base_contains('DISTRO_FEATURES', 'pam', 'pam-plugin-listfile', '', d)}"
36PAMLIB = "${@base_contains('DISTRO_FEATURES', 'pam', '-L${STAGING_BASELIBDIR} -lpam', '', d)}"
37NOPAM_SRC ="${@base_contains('PACKAGECONFIG', 'tcp-wrappers', 'file://nopam-with-tcp_wrappers.patch', 'file://nopam.patch', d)}"
38SRC_URI += "${@base_contains('DISTRO_FEATURES', 'pam', '', '${NOPAM_SRC}', d)}"
39
40inherit update-rc.d useradd systemd
41
42CONFFILES_${PN} = "${sysconfdir}/vsftpd.conf"
43LDFLAGS_append =" -lcrypt -lcap"
44
45EXTRA_OEMAKE = "-e MAKEFLAGS="
46
47do_configure() {
48 # Fix hardcoded /usr, /etc, /var mess.
49 cat tunables.c|sed s:\"/usr:\"${prefix}:g|sed s:\"/var:\"${localstatedir}:g \
50 |sed s:\"/etc:\"${sysconfdir}:g > tunables.c.new
51 mv tunables.c.new tunables.c
52}
53
54do_compile() {
55 oe_runmake "LIBS=-L${STAGING_LIBDIR} -lcrypt -lcap ${PAMLIB} -lwrap"
56}
57
58do_install() {
59 install -d ${D}${sbindir}
60 install -d ${D}${mandir}/man8
61 install -d ${D}${mandir}/man5
62 oe_runmake 'DESTDIR=${D}' install
63 install -d ${D}${sysconfdir}
64 install -m 600 ${WORKDIR}/vsftpd.conf ${D}${sysconfdir}/vsftpd.conf
65 install -d ${D}${sysconfdir}/init.d/
66 install -m 755 ${WORKDIR}/init ${D}${sysconfdir}/init.d/vsftpd
67 install -d ${D}/${sysconfdir}/default/volatiles
68 install -m 644 ${WORKDIR}/volatiles.99_vsftpd ${D}/${sysconfdir}/default/volatiles/99_vsftpd
69
70 install -m 600 ${WORKDIR}/vsftpd.ftpusers ${D}${sysconfdir}/
71 install -m 600 ${WORKDIR}/vsftpd.user_list ${D}${sysconfdir}/
72 if ! test -z "${PAMLIB}" ; then
73 install -d ${D}${sysconfdir}/pam.d/
74 cp ${S}/RedHat/vsftpd.pam ${D}${sysconfdir}/pam.d/vsftpd
75 sed -i "s:/lib/security:${base_libdir}/security:" ${D}${sysconfdir}/pam.d/vsftpd
76 sed -i "s:ftpusers:vsftpd.ftpusers:" ${D}${sysconfdir}/pam.d/vsftpd
77 fi
78 if ${@base_contains('DISTRO_FEATURES', 'systemd', 'true', 'false', d)}; then
79 install -d ${D}${sysconfdir}/tmpfiles.d
80 echo "d /var/run/vsftpd/empty 0755 root root -" \
81 > ${D}${sysconfdir}/tmpfiles.d/${BPN}.conf
82 fi
83
84 # Install systemd unit files
85 install -d ${D}${systemd_unitdir}/system
86 install -m 0644 ${WORKDIR}/vsftpd.service ${D}${systemd_unitdir}/system
87 sed -i -e 's#@SBINDIR@#${sbindir}#g' ${D}${systemd_unitdir}/system/vsftpd.service
88}
89
90INITSCRIPT_PACKAGES = "${PN}"
91INITSCRIPT_NAME_${PN} = "vsftpd"
92INITSCRIPT_PARAMS_${PN} = "defaults 80"
93
94USERADD_PACKAGES = "${PN}"
95USERADD_PARAM_${PN} = "--system --home-dir /var/lib/ftp --no-create-home -g ftp \
96 --shell /bin/false ftp "
97GROUPADD_PARAM_${PN} = "-r ftp"
98
99SYSTEMD_SERVICE_${PN} = "vsftpd.service"
100
101pkg_postinst_${PN}() {
102 if [ -z "$D" ]; then
103 if type systemd-tmpfiles >/dev/null; then
104 systemd-tmpfiles --create
105 elif [ -e ${sysconfdir}/init.d/populate-volatile.sh ]; then
106 ${sysconfdir}/init.d/populate-volatile.sh update
107 fi
108 fi
109}