From 133691ce920e7ff39dbebe80227e58a7aac9e3d1 Mon Sep 17 00:00:00 2001 From: Scott Garman Date: Wed, 11 May 2011 20:04:33 -0700 Subject: base-passwd: populate the target sysroot with passwd/group/login.defs The passwd, group, and login.defs files in the target sysroot will be used when recipes create custom user and group permissions in their packages. (From OE-Core rev: 4450b73e57bcd73b8d09d8cd898a97bad04ae27b) Signed-off-by: Scott Garman Signed-off-by: Richard Purdie --- .../recipes-core/base-passwd/base-passwd_3.5.22.bb | 27 ++++++++++++++++++++-- 1 file changed, 25 insertions(+), 2 deletions(-) (limited to 'meta/recipes-core/base-passwd/base-passwd_3.5.22.bb') diff --git a/meta/recipes-core/base-passwd/base-passwd_3.5.22.bb b/meta/recipes-core/base-passwd/base-passwd_3.5.22.bb index 6f768ca972..3315c68196 100644 --- a/meta/recipes-core/base-passwd/base-passwd_3.5.22.bb +++ b/meta/recipes-core/base-passwd/base-passwd_3.5.22.bb @@ -1,13 +1,14 @@ SUMMARY = "Base system master password/group files." DESCRIPTION = "The master copies of the user database files (/etc/passwd and /etc/group). The update-passwd tool is also provided to keep the system databases synchronized with these master files." SECTION = "base" -PR = "r1" +PR = "r2" LICENSE = "GPLv2+" LIC_FILES_CHKSUM = "file://COPYING;md5=eb723b61539feef013de476e68b5c50a" SRC_URI = "${DEBIAN_MIRROR}/main/b/base-passwd/base-passwd_${PV}.tar.gz \ file://nobash.patch \ - file://root-home.patch" + file://root-home.patch \ + file://login.defs" SRC_URI[md5sum] = "47f22ab6b572d0133409ff6ad1fab402" SRC_URI[sha256sum] = "d34acb35a9f9f221e7e4f642b9ef4b22083dd77bb2fc7216756f445316d842fc" @@ -16,6 +17,8 @@ S = "${WORKDIR}/base-passwd" inherit autotools +SSTATEPOSTINSTFUNCS += "base_passwd_sstate_postinst" + do_install () { install -d -m 755 ${D}${sbindir} install -p -m 755 update-passwd ${D}${sbindir}/ @@ -27,6 +30,7 @@ do_install () { install -d -m 755 ${D}${datadir}/base-passwd install -p -m 644 passwd.master ${D}${datadir}/base-passwd/ install -p -m 644 group.master ${D}${datadir}/base-passwd/ + install -p -m 644 ${S}/../login.defs ${D}${datadir}/base-passwd/login.defs install -d -m 755 ${D}${docdir}/${PN} install -p -m 644 debian/changelog ${D}${docdir}/${PN}/ @@ -45,5 +49,24 @@ pkg_postinst_${PN} () { if [ ! -e $D${sysconfdir}/group ] ; then cp $D${datadir}/base-passwd/group.master $D${sysconfdir}/group fi + + if [ ! -e $D{sysconfdir}/login.defs ] ; then + cp $D${datadir}/base-passwd/login.defs $D${sysconfdir}/login.defs + fi exit 0 } + +base_passwd_sstate_postinst() { + if [ "${BB_CURRENTTASK}" = "populate_sysroot" -o "${BB_CURRENTTASK}" = "populate_sysroot_setscene" ] + then + # Staging does not copy ${sysconfdir} files into the + # target sysroot, so we need to do so manually. We + # put these files in the target sysroot so they can + # be used by recipes which use custom user/group + # permissions. + install -d -m 755 ${STAGING_DIR_TARGET}${sysconfdir} + install -p -m 644 ${STAGING_DIR_TARGET}${datadir}/base-passwd/passwd.master ${STAGING_DIR_TARGET}${sysconfdir}/passwd + install -p -m 644 ${STAGING_DIR_TARGET}${datadir}/base-passwd/group.master ${STAGING_DIR_TARGET}${sysconfdir}/group + install -p -m 644 ${STAGING_DIR_TARGET}${datadir}/base-passwd/login.defs ${STAGING_DIR_TARGET}/${sysconfdir}/login.defs + fi +} -- cgit v1.2.3-54-g00ecf