blob: 85fb7cb99e8d63d9cbcc909033aa34854a9bc73b (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
|
# Copyright 1999-2019 Gentoo Authors
# Distributed under the terms of the GNU General Public License v2
EAPI=5
inherit autotools eutils linux-info pam systemd
MY_PN=ConsoleKit
MY_P=${MY_PN}-${PV}
DESCRIPTION="Framework for defining and tracking users, login sessions and seats"
HOMEPAGE="https://www.freedesktop.org/wiki/Software/ConsoleKit"
SRC_URI="https://www.freedesktop.org/software/${MY_PN}/dist/${MY_P}.tar.xz
https://launchpad.net/debian/+archive/primary/+files/${PN}_${PV}-4.debian.tar.gz" # for logrotate file
LICENSE="GPL-2"
SLOT="0"
KEYWORDS="~alpha amd64 arm ~arm64 ~hppa ia64 ~mips ppc ppc64 ~s390 ~sh sparc x86 ~amd64-linux ~x86-linux"
IUSE="acl debug doc kernel_linux pam policykit selinux systemd-units test"
RESTRICT="!test? ( test )"
COMMON_DEPEND=">=dev-libs/dbus-glib-0.100:=
>=dev-libs/glib-2.38.2-r1:2=
sys-libs/zlib:=
x11-libs/libX11:=
acl? (
sys-apps/acl:=
>=virtual/udev-200
)
pam? ( sys-libs/pam )
policykit? ( >=sys-auth/polkit-0.110 )"
RDEPEND="${COMMON_DEPEND}
kernel_linux? ( sys-apps/coreutils[acl?] )
selinux? ( sec-policy/selinux-consolekit )"
DEPEND="${COMMON_DEPEND}
dev-libs/libxslt
virtual/pkgconfig
doc? ( app-text/xmlto )
test? (
app-text/docbook-xml-dtd:4.1.2
app-text/xmlto
)"
S=${WORKDIR}/${MY_P}
QA_MULTILIB_PATHS="usr/lib/ConsoleKit/.*"
pkg_setup() {
if use kernel_linux; then
# This is from https://bugs.gentoo.org/376939
use acl && CONFIG_CHECK="~TMPFS_POSIX_ACL"
# This is required to get login-session-id string with pam_ck_connector.so
use pam && CONFIG_CHECK+=" ~AUDITSYSCALL"
linux-info_pkg_setup
fi
}
src_prepare() {
epatch \
"${FILESDIR}"/${PN}-cleanup_console_tags.patch \
"${FILESDIR}"/${PN}-shutdown-reboot-without-policies.patch \
"${FILESDIR}"/${PN}-udev-acl-install_to_usr.patch \
"${FILESDIR}"/${PN}-0.4.5-polkit-automagic.patch
if ! use systemd-units; then
sed -i -e '/SystemdService/d' data/org.freedesktop.ConsoleKit.service.in || die
fi
eautoreconf
}
src_configure() {
local myconf
if use systemd-units; then
myconf="$(systemd_with_unitdir)"
else
myconf="--with-systemdsystemunitdir=/tmp"
fi
econf \
XMLTO_FLAGS='--skip-validation' \
--libexecdir="${EPREFIX}"/usr/lib/${MY_PN} \
--localstatedir="${EPREFIX}"/var \
$(use_enable pam pam-module) \
$(use_enable doc docbook-docs) \
$(use_enable test docbook-docs) \
$(use_enable debug) \
$(use_enable policykit polkit) \
$(use_enable acl udev-acl) \
--with-dbus-services="${EPREFIX}"/usr/share/dbus-1/services \
--with-pam-module-dir="$(getpam_mod_dir)" \
${myconf}
}
src_install() {
emake \
DESTDIR="${D}" \
htmldocdir="${EPREFIX}"/usr/share/doc/${PF}/html \
install
dosym /usr/lib/${MY_PN} /usr/lib/${PN}
dodoc AUTHORS HACKING NEWS README TODO
newinitd "${FILESDIR}"/${PN}-0.2.rc consolekit
keepdir /usr/lib/ConsoleKit/run-seat.d
keepdir /usr/lib/ConsoleKit/run-session.d
keepdir /etc/ConsoleKit/run-session.d
keepdir /var/log/ConsoleKit
exeinto /etc/X11/xinit/xinitrc.d
newexe "${FILESDIR}"/90-consolekit-3 90-consolekit
exeinto /usr/lib/ConsoleKit/run-session.d
doexe "${FILESDIR}"/pam-foreground-compat.ck
prune_libtool_files --all # --all for pam_ck_connector.la
use systemd-units || rm -rf "${ED}"/tmp
rm -rf "${ED}"/var/run # let the init script create the directory
insinto /etc/logrotate.d
newins "${WORKDIR}"/debian/${PN}.logrotate ${PN} #374513
}
|