blob: e45ee0ba0f22c3da73a0ca83fd15d4ecdef76ed7 [file] [log] [blame]
Richard Marian Thomaiyar14fddef2018-07-13 23:55:56 +05301SUMMARY = "The eCryptfs mount helper and support libraries"
2DESCRIPTION = "eCryptfs is a stacked cryptographic filesystem \
3 that ships in Linux kernel versions 2.6.19 and above. This \
4 package provides the mount helper and supporting libraries \
5 to perform key management and mount functions."
6HOMEPAGE = "https://launchpad.net/ecryptfs"
7SECTION = "base"
8
9LICENSE = "GPL-2.0"
10LIC_FILES_CHKSUM = "file://COPYING;md5=8ca43cbc842c2336e835926c2166c28b"
11
12DEPENDS = "keyutils libgcrypt intltool-native glib-2.0-native"
13
14SRC_URI = "\
15 https://launchpad.net/ecryptfs/trunk/${PV}/+download/${BPN}_${PV}.orig.tar.gz \
16 file://ecryptfs-utils-CVE-2016-6224.patch \
Brad Bishop49e29a12019-09-01 15:21:06 -040017 file://0001-avoid-race-condition.patch \
Richard Marian Thomaiyar14fddef2018-07-13 23:55:56 +053018 file://ecryptfs.service \
19 "
20
21SRC_URI[md5sum] = "83513228984f671930752c3518cac6fd"
22SRC_URI[sha256sum] = "112cb3e37e81a1ecd8e39516725dec0ce55c5f3df6284e0f4cc0f118750a987f"
23
24inherit autotools pkgconfig systemd
25
26SYSTEMD_PACKAGES = "${PN}"
27SYSTEMD_SERVICE_${PN} = "ecryptfs.service"
28
29EXTRA_OECONF = "\
30 --libdir=${base_libdir} \
31 --disable-pywrap \
32 --disable-nls \
Brad Bishop1a4b7ee2018-12-16 17:11:34 -080033 --with-pamdir=${base_libdir}/security \
Brad Bishop49e29a12019-09-01 15:21:06 -040034 --disable-openssl \
Richard Marian Thomaiyar14fddef2018-07-13 23:55:56 +053035 "
36
37PACKAGECONFIG ??= "nss \
38 ${@bb.utils.filter('DISTRO_FEATURES', 'pam', d)} \
39 "
40PACKAGECONFIG[nss] = "--enable-nss,--disable-nss,nss,"
Richard Marian Thomaiyar14fddef2018-07-13 23:55:56 +053041PACKAGECONFIG[pam] = "--enable-pam,--disable-pam,libpam,"
42
43do_configure_prepend() {
44 export NSS_CFLAGS="-I${STAGING_INCDIR}/nspr4 -I${STAGING_INCDIR}/nss3"
45 export NSS_LIBS="-L${STAGING_BASELIBDIR} -lssl3 -lsmime3 -lnss3 -lsoftokn3 -lnssutil3"
46 export KEYUTILS_CFLAGS="-I${STAGING_INCDIR}"
47 export KEYUTILS_LIBS="-L${STAGING_LIBDIR} -lkeyutils"
Brad Bishop1a4b7ee2018-12-16 17:11:34 -080048 sed -i -e "s;rootsbindir=\"/sbin\";rootsbindir=\"\${base_sbindir}\";g" ${S}/configure.ac
Richard Marian Thomaiyar14fddef2018-07-13 23:55:56 +053049}
50
51do_install_append() {
52 chmod 4755 ${D}${base_sbindir}/mount.ecryptfs_private
Brad Bishop1a4b7ee2018-12-16 17:11:34 -080053 # ${base_libdir} is identical to ${libdir} when usrmerge enabled
54 if ! ${@bb.utils.contains('DISTRO_FEATURES','usrmerge','true','false',d)}; then
55 mkdir -p ${D}/${libdir}
56 mv ${D}/${base_libdir}/pkgconfig ${D}/${libdir}
57 fi
Richard Marian Thomaiyar14fddef2018-07-13 23:55:56 +053058 sed -i -e 's:-I${STAGING_INCDIR}::' \
59 -e 's:-L${STAGING_LIBDIR}::' ${D}/${libdir}/pkgconfig/libecryptfs.pc
60 sed -i -e "s: ${base_sbindir}/cryptsetup: ${sbindir}/cryptsetup:" ${D}${bindir}/ecryptfs-setup-swap
61 if ${@bb.utils.contains('DISTRO_FEATURES','systemd','true','false',d)}; then
62 install -D -m 0644 ${WORKDIR}/ecryptfs.service ${D}${systemd_system_unitdir}/ecryptfs.service
63 fi
64}
65
66FILES_${PN} += "${base_libdir}/security/* ${base_libdir}/ecryptfs/*"
67
68RDEPENDS_${PN} += "cryptsetup"
69RRECOMMENDS_${PN} = "gettext-runtime"