148 lines
3.6 KiB
Bash
148 lines
3.6 KiB
Bash
# 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"
|
|
|
|
LICENSE="LGPL-2"
|
|
SLOT="0"
|
|
KEYWORDS="~amd64 ~arm ~arm64 ~mips ~ppc64 ~s390 ~x86"
|
|
IUSE="duktape consolekit elogind examples gtk +introspection jit 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:78[-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 )
|
|
|
|
QA_MULTILIB_PATHS="
|
|
usr/lib/polkit-1/polkit-agent-helper-1
|
|
usr/lib/polkit-1/polkitd"
|
|
|
|
PATCHES=(
|
|
# bug 660880
|
|
"${FILESDIR}"/polkit-0.115-elogind.patch
|
|
|
|
# musl https://gitlab.freedesktop.org/polkit/polkit/-/issues/14
|
|
"${FILESDIR}"/polkit-0.116-make-netgroup-support-optional-2.patch
|
|
)
|
|
|
|
src_prepare() {
|
|
if use duktape ; then
|
|
PATCHES+=(
|
|
"${FILESDIR}"/polkit-0.118-duktape.patch
|
|
"${FILESDIR}"/polkit-0.118-duktape-posix.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
|
|
docinto examples
|
|
dodoc 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
|
|
}
|