source: general/sysutils/elogind.xml@ 4aed078

elogind
Last change on this file since 4aed078 was 4aed078, checked in by DJ Lucas <dj@…>, 5 years ago

Merge to HEAD 21283.
Add systemd compatibility symlinks.

git-svn-id: svn://svn.linuxfromscratch.org/BLFS/branches/BOOK-elogind@21284 af4574ff-66df-0310-9fd7-8a98e5e911e0

  • Property mode set to 100644
File size: 9.4 KB
Line 
1<?xml version="1.0" encoding="ISO-8859-1"?>
2<!DOCTYPE sect1 PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
3 "http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd" [
4 <!ENTITY % general-entities SYSTEM "../../general.ent">
5 %general-entities;
6
7 <!ENTITY elogind-download-http "https://github.com/elogind/elogind/archive/v&elogind-version;/elogind-&elogind-version;.tar.gz">
8 <!ENTITY elogind-download-ftp " ">
9 <!ENTITY elogind-md5sum "468e027997be922aa11bfa395c7f1fb7">
10 <!ENTITY elogind-size "1.1 MB">
11 <!ENTITY elogind-buildsize "47 MB">
12 <!ENTITY elogind-time "0.2 SBU">
13]>
14
15<sect1 id="elogind" revision="sysv" xreflabel="elogind-&elogind-version;">
16 <?dbhtml filename="elogind.html"?>
17
18 <sect1info>
19 <othername>$LastChangedBy$</othername>
20 <date>$Date$</date>
21 </sect1info>
22
23 <title>elogind-&elogind-version;</title>
24
25 <indexterm zone="elogind">
26 <primary sortas="a-elogind">elogind</primary>
27 </indexterm>
28
29 <sect2 role="package">
30 <title>Introduction to elogind</title>
31
32 <para>
33 <application>elogind</application> is the
34 <application>systemd</application> project's "logind", extracted out to
35 be a standalone daemon. It integrates with <xref linkend="linux-pam"/>
36 to know the set of users that are logged in to a system and whether they
37 are logged in graphically, on the console, or remotely.
38 <application>Elogind</application> exposes this information via the
39 standard org.freedesktop.login1 <application>D-Bus</application>
40 interface, as well as through the file system using systemd's standard
41 <filename class="directory">/run/systemd</filename> layout.
42 </para>
43
44 &lfs84_checked;
45
46 <bridgehead renderas="sect3">Package Information</bridgehead>
47 <itemizedlist spacing="compact">
48 <listitem>
49 <para>
50 Download (HTTP): <ulink url="&elogind-download-http;"/>
51 </para>
52 </listitem>
53 <listitem>
54 <para>
55 Download (FTP): <ulink url="&elogind-download-ftp;"/>
56 </para>
57 </listitem>
58 <listitem>
59 <para>
60 Download MD5 sum: &elogind-md5sum;
61 </para>
62 </listitem>
63 <listitem>
64 <para>
65 Download size: &elogind-size;
66 </para>
67 </listitem>
68 <listitem>
69 <para>
70 Estimated disk space required: &elogind-buildsize;
71 </para>
72 </listitem>
73 <listitem>
74 <para>
75 Estimated build time: &elogind-time;
76 </para>
77 </listitem>
78 </itemizedlist>
79
80 <bridgehead renderas="sect3">elogind Dependencies</bridgehead>
81
82 <bridgehead renderas="sect4">Required</bridgehead>
83 <para role="required">
84 <xref linkend="dbus"/>
85 </para>
86
87 <bridgehead renderas="sect4">Recommended</bridgehead>
88 <para role="recommended">
89 <xref linkend="DocBook"/>,
90 <xref linkend="docbook-xsl"/>, and
91 <xref linkend="libxslt"/> (to build the man pages),
92 <xref linkend="linux-pam"/>, and
93 <xref linkend="polkit"/> (runtime)
94 </para>
95
96 <bridgehead renderas="sect4">Optional</bridgehead>
97 <para role="optional">
98 For the tests:
99 <xref linkend="lxml"/>,
100 <xref linkend="gobject-introspection"/>,
101 <xref linkend="zsh"/>,
102 <xref linkend="valgrind"/>,
103 <ulink url="https://github.com/linux-audit/audit-userspace">
104 audit-userspace</ulink>,
105 <ulink url="https://github.com/scop/bash-completion">
106 bash-completion</ulink>,
107 <ulink url="https://mirrors.edge.kernel.org/pub/linux/utils/kernel/kexec/">
108 kexec</ulink>, and
109 <ulink url="http://www.selinuxproject.org/page/Main_Page">
110 SELinux</ulink>
111 </para>
112
113 <para condition="html" role="usernotes">User Notes:
114 <ulink url="&blfs-wiki;/elogind"/>
115 </para>
116 </sect2>
117
118 <sect2 role="installation">
119 <title>Installation of elogind</title>
120
121 <para>
122 Install <application>elogind</application> by running the following
123 commands:
124 </para>
125
126<screen><userinput>mkdir build &amp;&amp;
127cd build &amp;&amp;
128
129meson --prefix=/usr \
130 --sysconfdir=/etc \
131 --localstatedir=/var \
132 -Dcgroup-controller=elogind \
133 -Ddbuspolicydir=/etc/dbus-1/system.d \
134 .. &amp;&amp;
135ninja</userinput></screen>
136
137 <para>
138 This package does not come with a test suite.
139 </para>
140
141 <para>
142 Now, as the <systemitem class="username">root</systemitem> user:
143 </para>
144
145<screen role="root"><userinput>ninja install &amp;&amp;
146ln -sv libelogind.pc /usr/lib/pkgconfig/libsystemd.pc &amp;&amp;
147ln -sv elogind /usr/include/systemd</userinput></screen>
148
149 </sect2>
150
151 <sect2 role="commands">
152 <title>Command Explanations</title>
153
154 <para>
155 <parameter>-Dcgroup-controller=elogind</parameter>: This switch ensures
156 that <application>elogind</application> is selected as the cgroup
157 controller, even if booted with another running cgroup controller.
158 </para>
159
160 <para>
161 <parameter>-Ddbuspolicydir=/etc/dbus-1/system.d</parameter>: This switch
162 sets the location of the <application>D-Bus</application> policy
163 directory.
164 </para>
165
166 <para>
167 <command>ln -s ...</command>: These commands install symlinks so that
168 software packages find systemd compatible library and headers.
169 </para>
170
171 </sect2>
172
173 <sect2 role="configuration">
174 <title>Configuring elogind</title>
175
176 <para revision="sysv">
177 To automatically start <command>elogind</command> when the
178 system is rebooted, install the
179 <filename>/etc/rc.d/init.d/elogind</filename> bootscript from the
180 <xref linkend="bootscripts"/> package.
181 </para>
182
183 <indexterm zone="elogind elogind">
184 <primary sortas="f-elogind">elogind</primary>
185 </indexterm>
186
187<screen role="root"><userinput>make install-elogind</userinput></screen>
188
189 <para>
190 Note that this boot script only starts the system-wide
191 <application>elogind</application> daemon. Each user will also need to
192 register a user session using <application>Linux-PAM</application> at
193 login. The <filename>/etc/pam.d/system-session</filename> file needs to
194 be modified and a new file needs to be created in order for
195 <command>elogind</command> to work correctly. Run the following
196 commands as the <systemitem class="username">root</systemitem> user:
197 </para>
198
199<screen role="root"><userinput>cat &gt;&gt; /etc/pam.d/system-session &lt;&lt; "EOF" &amp;&amp;
200# Begin elogind addition
201
202session required pam_loginuid.so
203session optional pam_elogind.so
204
205# End elogind addition
206EOF
207cat &gt; /etc/pam.d/elogind-user &lt;&lt; "EOF"
208# Begin /etc/pam.d/elogind-user
209
210account required pam_access.so
211account include system-account
212
213session required pam_env.so
214session required pam_limits.so
215session required pam_unix.so
216session required pam_loginuid.so
217session optional pam_keyinit.so force revoke
218session optional pam_elogind.so
219
220auth required pam_deny.so
221password required pam_deny.so
222
223# End /etc/pam.d/elogind-user
224EOF</userinput></screen>
225
226 </sect2>
227
228 <sect2 role="content" revision="sysv">
229 <title>Contents</title>
230
231 <segmentedlist>
232 <segtitle>Installed Programs</segtitle>
233 <segtitle>Installed Library</segtitle>
234 <segtitle>Installed Directories</segtitle>
235
236 <seglistitem>
237 <seg>
238 busctl,
239 elogind-inhibit, and
240 loginctl
241 </seg>
242 <seg>
243 libelogind.so
244 </seg>
245 <seg>
246 /etc/elogind,
247 /usr/include/elogind, and
248 /usr/share/doc/elogind-&elogind-version;
249 </seg>
250 </seglistitem>
251 </segmentedlist>
252
253 <variablelist>
254 <bridgehead renderas="sect3">Short Descriptions</bridgehead>
255 <?dbfo list-presentation="list"?>
256 <?dbhtml list-presentation="table"?>
257
258 <varlistentry id="busctl">
259 <term><command>busctl</command></term>
260 <listitem>
261 <para>
262 is used to introspect and monitor the D-Bus bus.
263 </para>
264 <indexterm zone="elogind busctl">
265 <primary sortas="b-busctl">busctl</primary>
266 </indexterm>
267 </listitem>
268 </varlistentry>
269
270 <varlistentry id="elogind-inhibit">
271 <term><command>elogind-inhibit</command></term>
272 <listitem>
273 <para>
274 is used to execute a program with a shutdown, sleep or idle
275 inhibitor lock taken.
276 </para>
277 <indexterm zone="elogind elogind-inhibit">
278 <primary sortas="b-elogind-inhibit">elogind-inhibit</primary>
279 </indexterm>
280 </listitem>
281 </varlistentry>
282
283 <varlistentry id="loginctl">
284 <term><command>loginctl</command></term>
285 <listitem>
286 <para>
287 is used to introspect and control the state of the elogind Login
288 Manger.
289 </para>
290 <indexterm zone="elogind loginctl">
291 <primary sortas="b-loginctl">loginctl</primary>
292 </indexterm>
293 </listitem>
294 </varlistentry>
295
296 <varlistentry id="libelogind">
297 <term><filename class="libraryfile">libelogind.so</filename></term>
298 <listitem>
299 <para>
300 is the main elogind utility library.
301 </para>
302 <indexterm zone="elogind libelogind">
303 <primary sortas="c-libelogind">libelogind.so</primary>
304 </indexterm>
305 </listitem>
306 </varlistentry>
307
308 </variablelist>
309
310 </sect2>
311
312</sect1>
313
Note: See TracBrowser for help on using the repository browser.