diff options
author | Scott Garman <scott.a.garman@intel.com> | 2011-05-11 20:04:33 -0700 |
---|---|---|
committer | Richard Purdie <richard.purdie@linuxfoundation.org> | 2011-06-06 15:52:18 +0100 |
commit | 4450b73e57bcd73b8d09d8cd898a97bad04ae27b (patch) | |
tree | 3f20108b14eebf749ecfa63aa6f19192fef40924 /meta/recipes-core/base-passwd/base-passwd_3.5.22.bb | |
parent | 37b8c18a3c2f3e77a9810a56a8ee786855ae1ba3 (diff) | |
download | openembedded-core-contrib-4450b73e57bcd73b8d09d8cd898a97bad04ae27b.tar.gz |
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.
Signed-off-by: Scott Garman <scott.a.garman@intel.com>
Diffstat (limited to 'meta/recipes-core/base-passwd/base-passwd_3.5.22.bb')
-rw-r--r-- | meta/recipes-core/base-passwd/base-passwd_3.5.22.bb | 27 |
1 files changed, 25 insertions, 2 deletions
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 +} |