# Copyright 1999-2014 Gentoo Foundation # Distributed under the terms of the GNU General Public License v2 # $Header: /var/cvsroot/gentoo-x86/sys-libs/pam/pam-1.1.8-r2.ebuild,v 1.7 2014/08/07 19:27:50 jer Exp $ EAPI=5 inherit libtool multilib multilib-minimal eutils pam toolchain-funcs flag-o-matic db-use MY_PN="Linux-PAM" MY_P="${MY_PN}-${PV}" HOMEPAGE="https://fedorahosted.org/linux-pam/" DESCRIPTION="Linux-PAM (Pluggable Authentication Modules)" SRC_URI="http://www.linux-pam.org/library/${MY_P}.tar.bz2 http://www.linux-pam.org/documentation/${MY_P}-docs.tar.bz2" LICENSE="|| ( BSD GPL-2 )" SLOT="0" KEYWORDS="~alpha amd64 ~arm ~arm64 hppa ~ia64 ~m68k ~mips ppc ~ppc64 ~s390 ~sh ~sparc x86 ~amd64-linux ~ia64-linux ~x86-linux" IUSE="cracklib nls elibc_FreeBSD selinux vim-syntax audit test elibc_glibc debug berkdb nis" RDEPEND="nls? ( >=virtual/libintl-0-r1[${MULTILIB_USEDEP}] ) cracklib? ( >=sys-libs/cracklib-2.9.1-r1[${MULTILIB_USEDEP}] ) audit? ( >=sys-process/audit-2.2.2[${MULTILIB_USEDEP}] ) selinux? ( >=sys-libs/libselinux-2.2.2-r4[${MULTILIB_USEDEP}] ) berkdb? ( >=sys-libs/db-4.8.30-r1[${MULTILIB_USEDEP}] ) elibc_glibc? ( >=sys-libs/glibc-2.7 nis? ( || ( >=net-libs/libtirpc-0.2.4-r2[${MULTILIB_USEDEP}] /dev/null | fgrep -q pam_stack.so; then eerror "" eerror "Your current setup is using the pam_stack module." eerror "This module is deprecated and no longer supported, and since version" eerror "0.99 is no longer installed, nor provided by any other package." eerror "The package will be built (to allow binary package builds), but will" eerror "not be installed." eerror "Please replace pam_stack usage with proper include directive usage," eerror "following the PAM Upgrade guide at the following URL" eerror " http://www.gentoo.org/proj/en/base/pam/upgrade-0.99.xml" eerror "" retval=1 fi if sed -e 's:#.*::' "${EROOT}"/etc/pam.d/* 2>/dev/null | egrep -q 'pam_(pwdb|console)'; then eerror "" eerror "Your current setup is using one or more of the following modules," eerror "that are not built or supported anymore:" eerror "pam_pwdb, pam_console" eerror "If you are in real need for these modules, please contact the maintainers" eerror "of PAM through http://bugs.gentoo.org/ providing information about its" eerror "use cases." eerror "Please also make sure to read the PAM Upgrade guide at the following URL:" eerror " http://www.gentoo.org/proj/en/base/pam/upgrade-0.99.xml" eerror "" retval=1 fi return $retval } pkg_pretend() { # do not error out, this is just a warning, one could build a binpkg # with old modules enabled. check_old_modules } src_prepare() { epatch "${FILESDIR}"/${PN}-1.1.8-doc-install.patch #473650 elibtoolize } multilib_src_configure() { # Disable automatic detection of libxcrypt; we _don't_ want the # user to link libxcrypt in by default, since we won't track the # dependency and allow to break PAM this way. export ac_cv_header_xcrypt_h=no local myconf=( --htmldir="${EPREFIX}"/usr/share/doc/${PF}/html --libdir="${EPREFIX}"/usr/$(get_libdir) \ --enable-securedir="${EPREFIX}"/$(get_libdir)/security --enable-isadir="${EPREFIX}"/$(get_libdir)/security $(use_enable nls) $(use_enable selinux) $(use_enable cracklib) $(use_enable audit) $(use_enable debug) $(use_enable berkdb db) $(use_enable nis) --with-db-uniquename=-$(db_findver sys-libs/db) --disable-prelude ) if use hppa || use elibc_FreeBSD; then myconf+=( --disable-pie ) fi ECONF_SOURCE=${S} \ econf "${myconf[@]}" } multilib_src_compile() { emake sepermitlockdir="${EPREFIX}/run/sepermit" } multilib_src_install() { emake DESTDIR="${D}" install \ sepermitlockdir="${EPREFIX}/run/sepermit" local prefix if multilib_is_native_abi; then prefix= gen_usr_ldscript -a pam pamc pam_misc else prefix=/usr fi # create extra symlinks just in case something depends on them... local lib for lib in pam pamc pam_misc; do if ! [[ -f "${ED}"${prefix}/$(get_libdir)/lib${lib}$(get_libname) ]]; then dosym lib${lib}$(get_libname 0) ${prefix}/$(get_libdir)/lib${lib}$(get_libname) fi done } DOCS=( CHANGELOG ChangeLog README AUTHORS Copyright NEWS ) multilib_src_install_all() { einstalldocs prune_libtool_files --all # Need to be suid fperms u+s /sbin/unix_chkpwd docinto modules for dir in modules/pam_*; do newdoc "${dir}"/README README."$(basename "${dir}")" done if use selinux; then dodir /usr/lib/tmpfiles.d cat - > "${D}"/usr/lib/tmpfiles.d/${CATEGORY}:${PN}:${SLOT}.conf <