# Copyright 1999-2020 Gentoo Authors # Distributed under the terms of the GNU General Public License v2 EAPI=7 inherit autotools pam pax-utils systemd xdg-utils DESCRIPTION="Policy framework for controlling privileges for system-wide services" HOMEPAGE="https://www.freedesktop.org/wiki/Software/polkit https://gitlab.freedesktop.org/polkit/polkit" SRC_URI=" https://www.freedesktop.org/software/${PN}/releases/${P}.tar.gz https://github.com/ferion11/danrepo/releases/download/polkit_patchs/polkit-0.116-duktape.patch.gz " LICENSE="LGPL-2" SLOT="0" KEYWORDS="amd64 x86" IUSE="consolekit duktape elogind examples gtk +introspection kde nls pam selinux systemd test" RESTRICT="!test? ( test )" REQUIRED_USE="^^ ( consolekit elogind systemd )" BDEPEND=" acct-user/polkitd app-text/docbook-xml-dtd:4.1.2 app-text/docbook-xsl-stylesheets dev-libs/gobject-introspection-common dev-libs/libxslt dev-util/glib-utils dev-util/gtk-doc-am dev-util/intltool sys-devel/gettext virtual/pkgconfig introspection? ( dev-libs/gobject-introspection ) " DEPEND=" !duktape? ( dev-lang/spidermonkey:60[-debug] ) duktape? ( dev-lang/duktape ) dev-libs/glib:2 dev-libs/expat elogind? ( sys-auth/elogind ) pam? ( sys-auth/pambase sys-libs/pam ) systemd? ( sys-apps/systemd:0=[policykit] ) " RDEPEND="${DEPEND} acct-user/polkitd selinux? ( sec-policy/selinux-policykit ) " PDEPEND=" consolekit? ( sys-auth/consolekit[policykit] ) gtk? ( || ( >=gnome-extra/polkit-gnome-0.105 >=lxde-base/lxsession-0.5.2 ) ) kde? ( kde-plasma/polkit-kde-agent ) " DOCS=( docs/TODO HACKING NEWS README ) PATCHES=( # bug 660880 "${FILESDIR}"/polkit-0.115-elogind.patch ) QA_MULTILIB_PATHS=" usr/lib/polkit-1/polkit-agent-helper-1 usr/lib/polkit-1/polkitd" src_prepare() { if use duktape ; then PATCHES+=( #from https://gitlab.freedesktop.org/polkit/polkit/merge_requests/35 "${WORKDIR}"/polkit-0.116-duktape.patch ) fi default sed -i -e 's|unix-group:wheel|unix-user:0|' src/polkitbackend/*-default.rules || die #401513 # Workaround upstream hack around standard gtk-doc behavior, bug #552170 sed -i -e 's/@ENABLE_GTK_DOC_TRUE@\(TARGET_DIR\)/\1/' \ -e '/install-data-local:/,/uninstall-local:/ s/@ENABLE_GTK_DOC_TRUE@//' \ -e 's/@ENABLE_GTK_DOC_FALSE@install-data-local://' \ docs/polkit/Makefile.in || die # disable broken test - bug #624022 sed -i -e "/^SUBDIRS/s/polkitbackend//" test/Makefile.am || die # Fix cross-building, bug #590764, elogind patch, bug #598615 eautoreconf } src_configure() { xdg_environment_reset local myeconfargs=( --localstatedir="${EPREFIX}"/var --disable-static --enable-man-pages --disable-gtk-doc --disable-examples $(use_enable elogind libelogind) $(use_enable introspection) $(use_enable nls) $(usex pam "--with-pam-module-dir=$(getpam_mod_dir)" '') --with-authfw=$(usex pam pam shadow) $(use_enable systemd libsystemd-login) --with-systemdsystemunitdir="$(systemd_get_systemunitdir)" $(use_enable test) --with-os-type=gentoo ) if use duktape ; then myeconfargs+=( --with-duktape ) fi econf "${myeconfargs[@]}" } src_compile() { default # Required for polkitd on hardened/PaX due to spidermonkey's JIT pax-mark mr src/polkitbackend/.libs/polkitd test/polkitbackend/.libs/polkitbackendjsauthoritytest } src_install() { default if use examples; then insinto /usr/share/doc/${PF}/examples doins src/examples/{*.c,*.policy*} fi diropts -m 0700 -o polkitd keepdir /usr/share/polkit-1/rules.d find "${ED}" -name '*.la' -delete || die } pkg_postinst() { chmod 0700 "${EROOT}"/{etc,usr/share}/polkit-1/rules.d chown polkitd "${EROOT}"/{etc,usr/share}/polkit-1/rules.d }