COMPONENT_TARGETS = $(HARDWARE_INTEL_PC32)
COMPONENT_TARGETS += $(HARDWARE_INTEL_PC64)
COMPONENT_TARGETS += $(HARDWARE_EBOX_3350DX2)
COMPONENT_TARGETS += $(HARDWARE_CB1X)
COMPONENT_TARGETS += $(HARDWARE_CB2X)
COMPONENT_TARGETS += $(HARDWARE_CB3X)
COMPONENT_TARGETS += $(HARDWARE_ORANGE_PP2E)
COMPONENT_TARGETS += $(HARDWARE_NANOPI_NEO)
COMPONENT_TARGETS += $(HARDWARE_ORANGE_PP)
COMPONENT_TARGETS += $(HARDWARE_ORANGE_PL2)
COMPONENT_TARGETS += $(HARDWARE_ORANGE_PI5)
COMPONENT_TARGETS += $(HARDWARE_ORANGE_PI5B)
COMPONENT_TARGETS += $(HARDWARE_ORANGE_PI5P)
COMPONENT_TARGETS += $(HARDWARE_ROCK_5B)
COMPONENT_TARGETS += $(HARDWARE_WECHIP_TX6)
COMPONENT_TARGETS += $(HARDWARE_REPKA_PI3)
COMPONENT_TARGETS += $(HARDWARE_FFRK3288)
COMPONENT_TARGETS += $(HARDWARE_POIN2)
COMPONENT_TARGETS += $(HARDWARE_RK3328_CC)
COMPONENT_TARGETS += $(HARDWARE_KHADAS_EDGE)
COMPONENT_TARGETS += $(HARDWARE_LEEZ_P710)
COMPONENT_TARGETS += $(HARDWARE_M201)
COMPONENT_TARGETS += $(HARDWARE_MXV)
COMPONENT_TARGETS += $(HARDWARE_P201)
COMPONENT_TARGETS += $(HARDWARE_NEXBOX_A95X)
COMPONENT_TARGETS += $(HARDWARE_ODROID_C2)
COMPONENT_TARGETS += $(HARDWARE_P212)
COMPONENT_TARGETS += $(HARDWARE_KHADAS_VIM)
COMPONENT_TARGETS += $(HARDWARE_Q201)
COMPONENT_TARGETS += $(HARDWARE_ENYBOX_X2)
COMPONENT_TARGETS += $(HARDWARE_KHADAS_VIM2)
COMPONENT_TARGETS += $(HARDWARE_NIT6Q)
COMPONENT_TARGETS += $(HARDWARE_OKMX6DL_C)
COMPONENT_TARGETS += $(HARDWARE_OKMX6Q_C)
COMPONENT_TARGETS += $(HARDWARE_BONE_BLACK)
COMPONENT_TARGETS += $(HARDWARE_OMAP5UEVM)
COMPONENT_TARGETS += $(HARDWARE_DRA7XXEVM)
COMPONENT_TARGETS += $(HARDWARE_CI20)
COMPONENT_TARGETS += $(HARDWARE_BAIKAL_T1)
COMPONENT_TARGETS += $(HARDWARE_BAIKAL_M1)
COMPONENT_TARGETS += $(HARDWARE_S824L)
COMPONENT_TARGETS += $(HARDWARE_VESNIN)
COMPONENT_TARGETS += $(HARDWARE_S824L_LSB)
COMPONENT_TARGETS += $(HARDWARE_VESNIN_LSB)
COMPONENT_TARGETS += $(HARDWARE_TL2WK2)
COMPONENT_TARGETS += $(HARDWARE_TL2SV2)
COMPONENT_TARGETS += $(HARDWARE_TL2WK2_LSB)
COMPONENT_TARGETS += $(HARDWARE_TL2SV2_LSB)
COMPONENT_TARGETS += $(HARDWARE_VISIONFIVE2)
COMPONENT_TARGETS += $(HARDWARE_SIFIVE_U740)
NEED_ABS_PATH = true
COMPONENT_IS_3PP = true
include ../../../build-system/constants.mk
SOURCE_REQUIRES = sources/packages/s/shadow
REQUIRES = secure/pam/1.5.1
REQUIRES += app/acl/2.3.1
# ======= __END_OF_REQUIRES__ =======
version = 4.8.1
tar_xz_archive = $(SRC_PACKAGE_PATH)/packages/s/shadow/shadow-$(version).tar.xz
SRC_ARCHIVE = $(tar_xz_archive)
SRC_DIR = $(TARGET_BUILD_DIR)/shadow-$(version)
src_dir_name = shadow-$(version)
src_done = $(TARGET_BUILD_DIR)/.source_done
PATCHES = PATCHES
build_target = $(TARGET_BUILD_DIR)/.build_done
install_target = $(TARGET_BUILD_DIR)/.install_done
####### Targets
PKG_GROUP = app
#
# *PKG_NAME & *PKG_VERSION shouldn't be a reference to value.
#
SHADOW_PKG_NAME = shadow
SHADOW_PKG_VERSION = 4.8.1
SHADOW_PKG_ARCH = $(PKGARCH)
SHADOW_PKG_DISTRO_NAME = $(DISTRO_NAME)
SHADOW_PKG_DISTRO_VERSION = $(DISTRO_VERSION)
SHADOW_PKG_GROUP = $(PKG_GROUP)
### |---handy-ruler-------------------------------|
SHADOW_PKG_SHORT_DESCRIPTION = shadow password suite
SHADOW_PKG_URL = $(BUG_URL)
SHADOW_PKG_LICENSE = BSD
SHADOW_PKG_DESCRIPTION_FILE = $(TARGET_BUILD_DIR)/$(SHADOW_PKG_NAME)-pkg-description
SHADOW_PKG_DESCRIPTION_FILE_IN = $(SHADOW_PKG_NAME)-pkg-description.in
SHADOW_PKG_INSTALL_SCRIPT = $(SHADOW_PKG_NAME)-pkg-install.sh
SHADOW_PKG = $(CURDIR)/$(TARGET_BUILD_DIR)/$(SHADOW_PKG_NAME)-package
pkg_basename = $(SHADOW_PKG_NAME)-$(SHADOW_PKG_VERSION)-$(SHADOW_PKG_ARCH)-$(SHADOW_PKG_DISTRO_NAME)-$(SHADOW_PKG_DISTRO_VERSION)
pkg_archive = $(TARGET_BUILD_DIR)/$(PKG_GROUP)/$(pkg_basename).$(pkg_arch_suffix)
pkg_certificate = $(call cert-name,$(pkg_archive))
pkg_signature = $(call sign-name,$(pkg_archive))
pkg_description = $(call desc-name,$(pkg_archive))
products = $(call pkg-files,$(pkg_archive))
BUILD_TARGETS = $(build_target)
BUILD_TARGETS += $(install_target)
PRODUCT_TARGETS = $(products)
ROOTFS_TARGETS = $(pkg_archive)
include ../../../build-system/core.mk
env_sysroot = DESTDIR=$(SHADOW_PKG)
extra_configure_switches = --libdir=/usr/lib$(LIBSUFFIX)
extra_configure_switches += --mandir=/usr/share/man
extra_configure_switches += --docdir=/usr/share/doc/$(src_dir_name)
extra_configure_switches += --disable-dependency-tracking
extra_configure_switches += --bindir=/usr/bin
extra_configure_switches += --sbindir=/usr/sbin
extra_configure_switches += --sysconfdir=/etc
extra_configure_switches += --with-libpam
extra_configure_switches += --with-acl
extra_configure_switches += --with-attr
extra_configure_switches += --with-group-name-max-length=32
extra_configure_switches += --enable-subordinate-ids
extra_configure_switches += --enable-man
extra_configure_switches += --disable-shared
TARGET_RPATH = /lib$(LIBSUFFIX):/usr/lib$(LIBSUFFIX)
####### Dependencies
$(src_done): $(SRC_ARCHIVE) $(PATCHES_DEP)
$(UNPACK_SRC_ARCHIVE)
$(APPLY_PATCHES)
@( cd $(SRC_DIR) ; autoreconf -v -f --install )
@touch $@
$(build_target): $(src_done)
@cd $(SRC_DIR) && \
$(BUILD_ENVIRONMENT) ../$(src_dir_name)/configure \
--prefix=/usr \
--build=$(BUILD) \
--host=$(TARGET) \
$(extra_configure_switches)
@cd $(SRC_DIR) && $(BUILD_ENVIRONMENT) $(MAKE)
@touch $@
$(install_target): $(build_target)
@mkdir -p $(SHADOW_PKG)
@cd $(SRC_DIR) && $(BUILD_ENVIRONMENT) $(MAKE) -j1 install $(env_sysroot)
# ======= Don't ship the login utilities provided by util-linux and coreutils =======
@( cd $(SHADOW_PKG) ; \
for file in login chfn chsh groups ; do \
rm -f usr/bin/$$file ; \
find ./usr/share/man -type f -name "$${file}.*" -exec rm -f {} \; ; \
done ; \
)
# ======= Put some stuff back in FHS locations =======
@mkdir -p $(SHADOW_PKG)/bin $(SHADOW_PKG)/sbin
@( cd $(SHADOW_PKG)/usr/bin ; \
mv groups ../../bin ; \
mv su ../../bin ; \
mv faillog ../sbin ; \
mv lastlog ../sbin ; \
ln -sf ../sbin/faillog . ; \
ln -sf ../sbin/lastlog . ; \
)
# ======= Set default GID = 100 =======
@sed -i 's,^GROUP=.*,GROUP=100,' $(SHADOW_PKG)/etc/default/useradd
@mv $(SHADOW_PKG)/etc/default/useradd $(SHADOW_PKG)/etc/default/useradd.new
# ======= Install config files in /etc/pam.d/ =======
@rm -rf $(SHADOW_PKG)/etc/pam.d
@mkdir -p $(SHADOW_PKG)/etc/pam.d
@for file in $(CURDIR)/etc/pam.d/* ; do \
cp -a $$file $(SHADOW_PKG)/etc/pam.d/ ; \
done
@chmod 644 $(SHADOW_PKG)/etc/pam.d/*
@find $(SHADOW_PKG)/etc/pam.d -type f -exec mv {} {}.new \;
@rm -f $(SHADOW_PKG)/etc/login.defs
@cat $(CURDIR)/scripts/login.defs.pam > $(SHADOW_PKG)/etc/login.defs.new
# ======= Add the friendly 'adduser' script: =======
@cat $(CURDIR)/scripts/adduser > $(SHADOW_PKG)/usr/sbin/adduser
@chmod 0755 $(SHADOW_PKG)/usr/sbin/adduser
# ======= /etc/suauth doesn't work with PAM: =======
@find $(SHADOW_PKG)/usr/share/man -type f -name "suauth.5" -exec rm -f {} \;
# ======= Add sulogin to the package: =======
@cp -a $(SRC_DIR)/src/sulogin $(SHADOW_PKG)/sbin
@( cd $(SHADOW_PKG)/bin ; ln -s ../sbin/sulogin )
# ======= Add the empty faillog log file: =======
@mkdir -p $(SHADOW_PKG)/var/log
@touch $(SHADOW_PKG)/var/log/faillog.new
# ======= Use 4711 rather than 4755 permissions where setuid root is required: =======
@find $(SHADOW_PKG) -type f -perm 4755 -exec chmod 4711 "{}" \;
# ======= Install Documentation =======
@( cd $(SHADOW_PKG)/usr/share/man ; \
for page in `find . -type f -exec echo {} \;` ; do \
if [ -n "`cat $$page | grep '^\.so '`" ] ; then \
dir=`dirname $$page | sed 's,^\./,,'` ; \
( cd $$dir ; \
for file in * ; do \
ln=`head -n 1 $$file` ; \
if [ "`echo $$ln | grep '^\.so '`" != "" ] ; then \
origin=`echo $$ln | cut -f 2 -d ' '` ; \
origin=`basename $$origin` ; \
rm -f $$file ; \
ln -sf $$origin $$file ; \
fi ; \
done ; \
) ; \
fi ; \
done ; \
)
@if [ -d $(SHADOW_PKG)/usr/share/man ]; then \
( cd $(SHADOW_PKG)/usr/share/man ; \
for manpagedir in `find . -type d -name "man*"` ; do \
( cd $$manpagedir ; \
for eachpage in `find . -type l -maxdepth 1` ; do \
ln -s `readlink $$eachpage`.gz $$eachpage.gz ; \
rm $$eachpage ; \
done ; \
gzip -9 *.? ; \
) \
done \
) \
fi
@mkdir -p $(SHADOW_PKG)/usr/doc/$(src_dir_name)
@cp -a $(CURDIR)/license/* $(SHADOW_PKG)/usr/doc/$(src_dir_name)
@cp -a $(SRC_DIR)/COPYING* \
$(SHADOW_PKG)/usr/doc/$(src_dir_name)
@mkdir -p $(SHADOW_PKG)/usr/share/doc/$(src_dir_name)/{PAM,html}
@( cd $(SRC_DIR) ; \
cp -a COPYING NEWS README TODO doc/{README.limits,HOWTO,WISHLIST} \
$(SHADOW_PKG)/usr/share/doc/$(src_dir_name) \
)
@cp -a $(SRC_DIR)/docs/*.html $(SHADOW_PKG)/usr/share/doc/$(src_dir_name)/html
@cp -a $(CURDIR)/doc/* $(SHADOW_PKG)/usr/share/doc/$(src_dir_name)/PAM
# ======= Install ChangeLog into docdir =======
@( cd $(SRC_DIR) ; \
if [ -r ChangeLog ]; then \
DOCSDIR=`echo $(SHADOW_PKG)/usr/share/doc/$(src_dir_name)` ; \
cat ChangeLog | head -n 1000 > $$DOCSDIR/ChangeLog ; \
touch -r ChangeLog $$DOCSDIR/ChangeLog ; \
fi ; \
)
# ======= Install the same to $(TARGET_DEST_DIR) =======
$(call install-into-devenv, $(SHADOW_PKG))
# ======= Strip binaries =======
@( cd $(SHADOW_PKG) ; \
find . | xargs file | grep "executable" | grep ELF | cut -f 1 -d : | xargs $(STRIP) --strip-unneeded 2> /dev/null \
)
ifneq ($(PATCHELF),)
# ======= Set RPATH/RUNPATH for target binaries =======
@( cd $(SHADOW_PKG) ; \
for file in `find . | xargs file | grep "executable" | grep ELF | cut -f 1 -d : | xargs echo` ; do \
rpath=`$(PATCHELF) --print-rpath $$file 2> /dev/null` ; \
if echo "$$rpath" | grep -q "$(TARGET_DEST_DIR)" ; then \
$(PATCHELF) --set-rpath $(TARGET_RPATH) $$file 1> /dev/null 2> /dev/null ; \
fi ; \
done ; \
)
endif
@touch $@
$(SHADOW_PKG_DESCRIPTION_FILE): $(SHADOW_PKG_DESCRIPTION_FILE_IN)
@cat $< | $(SED) -e "s/@VERSION@/$(version)/g" > $@
$(pkg_certificate) : $(pkg_archive) ;
$(pkg_signature) : $(pkg_archive) ;
$(pkg_description) : $(pkg_archive) ;
$(pkg_archive): $(install_target) $(SHADOW_PKG_DESCRIPTION_FILE) $(SHADOW_PKG_INSTALL_SCRIPT)
@cp $(SHADOW_PKG_DESCRIPTION_FILE) $(SHADOW_PKG)/.DESCRIPTION
@cp $(SHADOW_PKG_INSTALL_SCRIPT) $(SHADOW_PKG)/.INSTALL
@$(BUILD_PKG_REQUIRES) $(SHADOW_PKG)/.REQUIRES
@echo "pkgname=$(SHADOW_PKG_NAME)" > $(SHADOW_PKG)/.PKGINFO ; \
echo "pkgver=$(SHADOW_PKG_VERSION)" >> $(SHADOW_PKG)/.PKGINFO ; \
echo "arch=$(SHADOW_PKG_ARCH)" >> $(SHADOW_PKG)/.PKGINFO ; \
echo "distroname=$(SHADOW_PKG_DISTRO_NAME)" >> $(SHADOW_PKG)/.PKGINFO ; \
echo "distrover=$(SHADOW_PKG_DISTRO_VERSION)" >> $(SHADOW_PKG)/.PKGINFO ; \
echo "group=$(SHADOW_PKG_GROUP)" >> $(SHADOW_PKG)/.PKGINFO ; \
echo "short_description=\"$(SHADOW_PKG_SHORT_DESCRIPTION)\"" >> $(SHADOW_PKG)/.PKGINFO ; \
echo "url=$(SHADOW_PKG_URL)" >> $(SHADOW_PKG)/.PKGINFO ; \
echo "license=$(SHADOW_PKG_LICENSE)" >> $(SHADOW_PKG)/.PKGINFO
@$(PSEUDO) sh -c "cd $(SHADOW_PKG) && \
chown -R root:root . && \
chmod 4711 bin/su && \
chmod 4711 usr/bin/passwd && \
$(MAKE_PACKAGE) -J --linkadd=yes $(GNUPG_OPTIONS) -m -d .. ."