commit: 3fa15127a0fa194035847fca2ef56c2553204870 Author: Andreas Sturmlechner <andreas.sturmlechner <AT> gmail <DOT> com> AuthorDate: Wed Apr 20 09:16:24 2016 +0000 Commit: Michael Palimaka <kensington <AT> gentoo <DOT> org> CommitDate: Wed Apr 20 09:28:49 2016 +0000 URL: https://gitweb.gentoo.org/proj/kde.git/commit/?id=3fa15127
kde-plasma/kwallet-pam: Add USE=oldwallet, block kde-apps/kwalletd-pam Improvements to pkg_postinst thx to Arfrever. kde-plasma/kwallet-pam/kwallet-pam-9999.ebuild | 57 ++++++++++++++++++++------ 1 file changed, 45 insertions(+), 12 deletions(-) diff --git a/kde-plasma/kwallet-pam/kwallet-pam-9999.ebuild b/kde-plasma/kwallet-pam/kwallet-pam-9999.ebuild index ce480aa..6c48b49 100644 --- a/kde-plasma/kwallet-pam/kwallet-pam-9999.ebuild +++ b/kde-plasma/kwallet-pam/kwallet-pam-9999.ebuild @@ -5,12 +5,12 @@ EAPI=6 KDE_AUTODEPS="false" -inherit kde5 multilib +inherit kde5 multibuild multilib DESCRIPTION="KWallet PAM module to not enter password again" LICENSE="LGPL-2.1" KEYWORDS="" -IUSE="" +IUSE="+oldwallet" COMMON_DEPEND=" dev-libs/libgcrypt:0= @@ -18,31 +18,60 @@ COMMON_DEPEND=" " DEPEND="${COMMON_DEPEND} $(add_frameworks_dep extra-cmake-modules) + $(add_qt_dep qtcore) " RDEPEND="${COMMON_DEPEND} + !kde-apps/kwalletd-pam net-misc/socat " +pkg_setup() { + kde5_pkg_setup + MULTIBUILD_VARIANTS=( kf5 $(usev oldwallet) ) +} + src_configure() { - local mycmakeargs=( - -DCMAKE_INSTALL_LIBDIR="/$(get_libdir)" - ) + myconfigure() { + local mycmakeargs=( + -DCMAKE_INSTALL_LIBDIR="/$(get_libdir)" + ) + [[ ${MULTIBUILD_VARIANT} = oldwallet ]] && mycmakeargs+=( -DKWALLET4=1 ) + + kde5_src_configure + } + multibuild_foreach_variant myconfigure +} - kde5_src_configure +src_compile() { + multibuild_foreach_variant kde5_src_compile +} + +src_install() { + multibuild_foreach_variant kde5_src_install } pkg_postinst() { check_dm() { - if [[ -e "${ROOT}${2}" ]] && \ - grep -Eq "auth\s+optional\s+pam_kwallet5.so" "${ROOT}${2}" && \ - grep -Eq "session\s+optional\s+pam_kwallet5.so" "${ROOT}${2}" ; then - elog " ${1} - ${2} ...GOOD" - else - ewarn " ${1} - ${2} ...BAD" + local good + if [[ -e "${ROOT}${2}" ]] ; then + if grep -Eq "auth\s+optional\s+pam_kwallet5.so" "${ROOT}${2}" && \ + grep -Eq "session\s+optional\s+pam_kwallet5.so" "${ROOT}${2}" ; then + good=true + fi + if use oldwallet ; then + if ! grep -Eq "auth\s+optional\s+pam_kwallet.so" "${ROOT}${2}" || \ + ! grep -Eq "session\s+optional\s+pam_kwallet.so" "${ROOT}${2}" ; then + good=false + fi + fi fi + [[ "${good}" = true ]] && \ + elog " ${1} - ${2} ...GOOD" || \ + ewarn " ${1} - ${2} ...BAD" } elog elog "This package enables auto-unlocking of kde-frameworks/kwallet:5." + use oldwallet && elog "You have also selected support for legacy kde-apps/kwalletd:4." elog "List of things to make it work:" elog "1. Use standard blowfish encryption instead of GPG" elog "2. Use same password for login and kwallet" @@ -50,6 +79,10 @@ pkg_postinst() { elog "4.a Have the following lines in the display manager's pam.d file:" elog " -auth optional pam_kwallet5.so" elog " -session optional pam_kwallet5.so auto_start" + if use oldwallet ; then + elog " -auth optional pam_kwallet.so kdehome=.kde4" + elog " -session optional pam_kwallet.so" + fi elog "4.b Checking installed DMs..." has_version "x11-misc/sddm" && check_dm "SDDM" "/etc/pam.d/sddm" has_version "x11-misc/lightdm" && check_dm "LightDM" "/etc/pam.d/lightdm"