diff options
Diffstat (limited to 'man')
| -rw-r--r-- | man/custom-html.xsl | 29 | ||||
| -rw-r--r-- | man/sd-daemon.xml | 2 | ||||
| -rw-r--r-- | man/sd-login.xml | 146 | ||||
| -rw-r--r-- | man/sd_booted.xml | 2 | ||||
| -rw-r--r-- | man/sd_get_seats.xml | 127 | ||||
| -rw-r--r-- | man/sd_is_fifo.xml | 2 | ||||
| -rw-r--r-- | man/sd_listen_fds.xml | 2 | ||||
| -rw-r--r-- | man/sd_login_monitor_new.xml | 172 | ||||
| -rw-r--r-- | man/sd_notify.xml | 2 | ||||
| -rw-r--r-- | man/sd_pid_get_session.xml | 135 | ||||
| -rw-r--r-- | man/sd_readahead.xml | 28 | ||||
| -rw-r--r-- | man/sd_seat_get_active.xml | 152 | ||||
| -rw-r--r-- | man/sd_session_is_active.xml | 134 | ||||
| -rw-r--r-- | man/sd_uid_get_state.xml | 185 | 
14 files changed, 1096 insertions, 22 deletions
| diff --git a/man/custom-html.xsl b/man/custom-html.xsl new file mode 100644 index 0000000000..2d2f458793 --- /dev/null +++ b/man/custom-html.xsl @@ -0,0 +1,29 @@ +<?xml version='1.0'?> <!--*-nxml-*--> + +<!-- +  This file is part of systemd. + +  Copyright 2011 Lennart Poettering + +  systemd is free software; you can redistribute it and/or modify it +  under the terms of the GNU General Public License as published by +  the Free Software Foundation; either version 2 of the License, or +  (at your option) any later version. + +  systemd is distributed in the hope that it will be useful, but +  WITHOUT ANY WARRANTY; without even the implied warranty of +  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +  General Public License for more details. + +  You should have received a copy of the GNU General Public License +  along with systemd; If not, see <http://www.gnu.org/licenses/>. +--> + +<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0"> + +<xsl:import href="http://docbook.sourceforge.net/release/xsl/current/html/docbook.xsl"/> + +<!-- Switch things to UTF-8, ISO-8859-1 is soo yesteryear --> +<xsl:output method="html" encoding="UTF-8" indent="no"/> + +</xsl:stylesheet> diff --git a/man/sd-daemon.xml b/man/sd-daemon.xml index cd67d9992a..383d77f595 100644 --- a/man/sd-daemon.xml +++ b/man/sd-daemon.xml @@ -50,7 +50,7 @@          <refsynopsisdiv>                  <funcsynopsis> -                        <funcsynopsisinfo>#include "sd-daemon.h"</funcsynopsisinfo> +                        <funcsynopsisinfo>#include <systemd/sd-daemon.h></funcsynopsisinfo>                  </funcsynopsis>                  <cmdsynopsis> diff --git a/man/sd-login.xml b/man/sd-login.xml new file mode 100644 index 0000000000..3fc0e16f69 --- /dev/null +++ b/man/sd-login.xml @@ -0,0 +1,146 @@ +<?xml version='1.0'?> <!--*-nxml-*--> +<!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN" +        "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd"> + +<!-- +  This file is part of systemd. + +  Copyright 2010 Lennart Poettering + +  systemd is free software; you can redistribute it and/or modify it +  under the terms of the GNU General Public License as published by +  the Free Software Foundation; either version 2 of the License, or +  (at your option) any later version. + +  systemd is distributed in the hope that it will be useful, but +  WITHOUT ANY WARRANTY; without even the implied warranty of +  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +  General Public License for more details. + +  You should have received a copy of the GNU General Public License +  along with systemd; If not, see <http://www.gnu.org/licenses/>. +--> + +<refentry id="sd-login"> + +        <refentryinfo> +                <title>sd-login</title> +                <productname>systemd</productname> + +                <authorgroup> +                        <author> +                                <contrib>Developer</contrib> +                                <firstname>Lennart</firstname> +                                <surname>Poettering</surname> +                                <email>lennart@poettering.net</email> +                        </author> +                </authorgroup> +        </refentryinfo> + +        <refmeta> +                <refentrytitle>sd-login</refentrytitle> +                <manvolnum>7</manvolnum> +        </refmeta> + +        <refnamediv> +                <refname>sd-login</refname> +                <refpurpose>APIs for +                tracking logins</refpurpose> +        </refnamediv> + +        <refsynopsisdiv> +                <funcsynopsis> +                        <funcsynopsisinfo>#include <systemd/sd-login.h></funcsynopsisinfo> +                </funcsynopsis> + +                <cmdsynopsis> +                        <command>pkg-config --cflags --libs libsystemd-login</command> +                </cmdsynopsis> +        </refsynopsisdiv> + +        <refsect1> +                <title>Description</title> + +                <para><filename>sd-login.h</filename> provides APIs to +                introspect and monitor seat, login session and user +                status information on the local system. </para> + +                <para>See <ulink +                url="http://www.freedesktop.org/wiki/Software/systemd/multiseat">Multi-Seat +                on Linux</ulink> for an introduction into multi-seat +                support on Linux, the background for this set of APIs.</para> + +                <para>Note that these APIs only allow purely passive access +                and monitoring of seats, sessions and users. To +                actively make changes to the seat configuration, +                terminate login sessions, or switch session on a seat +                you need to utilize the D-Bus API of +                systemd-logind, instead.</para> + +                <para>These functions synchronously access data in +                <filename>/proc</filename>, +                <filename>/sys/fs/cgroup</filename> and +                <filename>/run</filename>. All of these are virtual +                file systems, hence the runtime cost of the accesses +                is relatively cheap.</para> + +                <para>It is possible (and often a very good choice) to +                mix calls to the synchronous interface of +                <filename>sd-login.h</filename> with the asynchronous +                D-Bus interface of systemd-logind. However, if this is +                done you need to think a bit about possible races +                since the stream of events from D-Bus and from +                <filename>sd-login.h</filename> interfaces such as the +                login monitor are asynchronous and not ordered against +                each other.</para> + +                <para>If the functions return string arrays, these are +                generally NULL terminated and need to be freed by the +                caller with the libc +                <citerefentry><refentrytitle>free</refentrytitle><manvolnum>3</manvolnum></citerefentry> +                call after use, including the strings referenced +                therein. Similar, individual strings returned need to +                be freed, as well.</para> + +                <para>As a special exception, instead of an empty +                string array NULL may be returned, which should be +                treated equivalent to an empty string array.</para> + +                <para>See +                <citerefentry><refentrytitle>sd_pid_get_session</refentrytitle><manvolnum>3</manvolnum></citerefentry>, +                <citerefentry><refentrytitle>sd_uid_get_state</refentrytitle><manvolnum>3</manvolnum></citerefentry>, +                <citerefentry><refentrytitle>sd_session_is_active</refentrytitle><manvolnum>3</manvolnum></citerefentry>, +                <citerefentry><refentrytitle>sd_seat_get_active</refentrytitle><manvolnum>3</manvolnum></citerefentry>, +                <citerefentry><refentrytitle>sd_get_seats</refentrytitle><manvolnum>3</manvolnum></citerefentry>, +                <citerefentry><refentrytitle>sd_login_monitor_new</refentrytitle><manvolnum>3</manvolnum></citerefentry> +                for more information about the functions +                implemented.</para> +        </refsect1> + +        <refsect1> +                <title>Notes</title> + +                <para>These APIs are implemented as shared library, +                which can be compiled and linked to with the +                <literal>libsystemd-login</literal> +                <citerefentry><refentrytitle>pkg-config</refentrytitle><manvolnum>1</manvolnum></citerefentry> +                file.</para> +        </refsect1> + +        <refsect1> +                <title>See Also</title> +                <para> +                        <citerefentry><refentrytitle>systemd</refentrytitle><manvolnum>1</manvolnum></citerefentry>, +                        <citerefentry><refentrytitle>sd_pid_get_session</refentrytitle><manvolnum>3</manvolnum></citerefentry>, +                        <citerefentry><refentrytitle>sd_uid_get_state</refentrytitle><manvolnum>3</manvolnum></citerefentry>, +                        <citerefentry><refentrytitle>sd_session_is_active</refentrytitle><manvolnum>3</manvolnum></citerefentry>, +                        <citerefentry><refentrytitle>sd_seat_get_active</refentrytitle><manvolnum>3</manvolnum></citerefentry>, +                        <citerefentry><refentrytitle>sd_get_seats</refentrytitle><manvolnum>3</manvolnum></citerefentry>, +                        <citerefentry><refentrytitle>sd_login_monitor_new</refentrytitle><manvolnum>3</manvolnum></citerefentry>, +                        <citerefentry><refentrytitle>sd-daemon</refentrytitle><manvolnum>7</manvolnum></citerefentry>, +                        <citerefentry><refentrytitle>sd-readahead</refentrytitle><manvolnum>7</manvolnum></citerefentry>, +                        <citerefentry><refentrytitle>pkg-config</refentrytitle><manvolnum>1</manvolnum></citerefentry> +                </para> +        </refsect1> + +</refentry> diff --git a/man/sd_booted.xml b/man/sd_booted.xml index ebcde36b48..c9f538a3e6 100644 --- a/man/sd_booted.xml +++ b/man/sd_booted.xml @@ -49,7 +49,7 @@          <refsynopsisdiv>                  <funcsynopsis> -                        <funcsynopsisinfo>#include "sd-daemon.h"</funcsynopsisinfo> +                        <funcsynopsisinfo>#include <systemd/sd-daemon.h></funcsynopsisinfo>                          <funcprototype>                                  <funcdef>int <function>sd_booted</function></funcdef> diff --git a/man/sd_get_seats.xml b/man/sd_get_seats.xml new file mode 100644 index 0000000000..2ac76500ec --- /dev/null +++ b/man/sd_get_seats.xml @@ -0,0 +1,127 @@ +<?xml version='1.0'?> <!--*-nxml-*--> +<!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN" +        "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd"> + +<!-- +  This file is part of systemd. + +  Copyright 2010 Lennart Poettering + +  systemd is free software; you can redistribute it and/or modify it +  under the terms of the GNU General Public License as published by +  the Free Software Foundation; either version 2 of the License, or +  (at your option) any later version. + +  systemd is distributed in the hope that it will be useful, but +  WITHOUT ANY WARRANTY; without even the implied warranty of +  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +  General Public License for more details. + +  You should have received a copy of the GNU General Public License +  along with systemd; If not, see <http://www.gnu.org/licenses/>. +--> + +<refentry id="sd_get_seats"> + +        <refentryinfo> +                <title>sd_get_seats</title> +                <productname>systemd</productname> + +                <authorgroup> +                        <author> +                                <contrib>Developer</contrib> +                                <firstname>Lennart</firstname> +                                <surname>Poettering</surname> +                                <email>lennart@poettering.net</email> +                        </author> +                </authorgroup> +        </refentryinfo> + +        <refmeta> +                <refentrytitle>sd_get_seats</refentrytitle> +                <manvolnum>3</manvolnum> +        </refmeta> + +        <refnamediv> +                <refname>sd_get_seats</refname> +                <refname>sd_get_sessions</refname> +                <refname>sd_get_uids</refname> +                <refpurpose>Determine available seats, sessions and logged in users</refpurpose> +        </refnamediv> + +        <refsynopsisdiv> +                <funcsynopsis> +                        <funcsynopsisinfo>#include <systemd/sd-login.h></funcsynopsisinfo> + +                        <funcprototype> +                                <funcdef>int <function>sd_get_seats</function></funcdef> +                                <paramdef>char*** <parameter>seats</parameter></paramdef> +                        </funcprototype> + +                        <funcprototype> +                                <funcdef>int <function>sd_get_sessions</function></funcdef> +                                <paramdef>char*** <parameter>sessions</parameter></paramdef> +                        </funcprototype> + +                        <funcprototype> +                                <funcdef>int <function>sd_get_uids</function></funcdef> +                                <paramdef>char*** <parameter>sessions</parameter></paramdef> +                        </funcprototype> + +                </funcsynopsis> +        </refsynopsisdiv> + +        <refsect1> +                <title>Description</title> + +                <para><function>sd_get_seats()</function> may be used +                to determine all currently available local +                seats. Returns a NULL terminated array of seat +                identifiers. The returned array and all strings it +                references need to be freed with the libc +                <citerefentry><refentrytitle>free</refentrytitle><manvolnum>3</manvolnum></citerefentry> +                call after use. Note that instead of an empty array +                NULL may be returned and should be considered +                equivalent to an empty array.</para> + +                <para>Similar, <function>sd_get_sessions()</function> may +                be used to determine all current login sessions.</para> + +                <para>Similar, <function>sd_get_uids()</function> may +                be used to determine all Unix users who currently have login sessions.</para> +        </refsect1> + +        <refsect1> +                <title>Return Value</title> + +                <para>On success <function>sd_get_seats()</function>, +                <function>sd_get_sessions()</function> and +                <function>sd_get_uids()</function> return the number +                of entries in the arrays. On failure, these calls +                return a negative errno-style error code.</para> +        </refsect1> + +        <refsect1> +                <title>Notes</title> + +                <para>The <function>sd_get_seats()</function>, +                <function>sd_get_sessions()</function> and +                <function>sd_get_uids()</function> interfaces +                are available as shared library, which can be compiled +                and linked to with the +                <literal>libsystemd-login</literal> +                <citerefentry><refentrytitle>pkg-config</refentrytitle><manvolnum>1</manvolnum></citerefentry> +                file.</para> +        </refsect1> + +        <refsect1> +                <title>See Also</title> + +                <para> +                        <citerefentry><refentrytitle>systemd</refentrytitle><manvolnum>1</manvolnum></citerefentry>, +                        <citerefentry><refentrytitle>sd-login</refentrytitle><manvolnum>7</manvolnum></citerefentry>, +                        <citerefentry><refentrytitle>sd_session_get_seat</refentrytitle><manvolnum>3</manvolnum></citerefentry> +                </para> +        </refsect1> + +</refentry> diff --git a/man/sd_is_fifo.xml b/man/sd_is_fifo.xml index f6fafabc39..82b89bb290 100644 --- a/man/sd_is_fifo.xml +++ b/man/sd_is_fifo.xml @@ -53,7 +53,7 @@          <refsynopsisdiv>                  <funcsynopsis> -                        <funcsynopsisinfo>#include "sd-daemon.h"</funcsynopsisinfo> +                        <funcsynopsisinfo>#include <systemd/sd-daemon.h></funcsynopsisinfo>                          <funcprototype>                                  <funcdef>int <function>sd_is_fifo</function></funcdef> diff --git a/man/sd_listen_fds.xml b/man/sd_listen_fds.xml index 3276aff63d..68a45cd766 100644 --- a/man/sd_listen_fds.xml +++ b/man/sd_listen_fds.xml @@ -49,7 +49,7 @@          <refsynopsisdiv>                  <funcsynopsis> -                        <funcsynopsisinfo>#include "sd-daemon.h"</funcsynopsisinfo> +                        <funcsynopsisinfo>#include <systemd/sd-daemon.h></funcsynopsisinfo>                          <funcsynopsisinfo>#define SD_LISTEN_FDS_START 3</funcsynopsisinfo> diff --git a/man/sd_login_monitor_new.xml b/man/sd_login_monitor_new.xml new file mode 100644 index 0000000000..de484329a9 --- /dev/null +++ b/man/sd_login_monitor_new.xml @@ -0,0 +1,172 @@ +<?xml version='1.0'?> <!--*-nxml-*--> +<!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN" +        "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd"> + +<!-- +  This file is part of systemd. + +  Copyright 2010 Lennart Poettering + +  systemd is free software; you can redistribute it and/or modify it +  under the terms of the GNU General Public License as published by +  the Free Software Foundation; either version 2 of the License, or +  (at your option) any later version. + +  systemd is distributed in the hope that it will be useful, but +  WITHOUT ANY WARRANTY; without even the implied warranty of +  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +  General Public License for more details. + +  You should have received a copy of the GNU General Public License +  along with systemd; If not, see <http://www.gnu.org/licenses/>. +--> + +<refentry id="sd_login_monitor_new"> + +        <refentryinfo> +                <title>sd_login_monitor_new</title> +                <productname>systemd</productname> + +                <authorgroup> +                        <author> +                                <contrib>Developer</contrib> +                                <firstname>Lennart</firstname> +                                <surname>Poettering</surname> +                                <email>lennart@poettering.net</email> +                        </author> +                </authorgroup> +        </refentryinfo> + +        <refmeta> +                <refentrytitle>sd_login_monitor_new</refentrytitle> +                <manvolnum>3</manvolnum> +        </refmeta> + +        <refnamediv> +                <refname>sd_login_monitor_new</refname> +                <refname>sd_login_monitor_unref</refname> +                <refname>sd_login_monitor_flush</refname> +                <refname>sd_login_monitor_get_fd</refname> +                <refpurpose>Monitor login sessions, seats and users</refpurpose> +        </refnamediv> + +        <refsynopsisdiv> +                <funcsynopsis> +                        <funcsynopsisinfo>#include <systemd/sd-login.h></funcsynopsisinfo> + +                        <funcprototype> +                                <funcdef>int <function>sd_login_monitor_new</function></funcdef> +                                <paramdef>const char* <parameter>category</parameter></paramdef> +                                <paramdef>sd_login_monitor** <parameter>ret</parameter></paramdef> +                        </funcprototype> + +                        <funcprototype> +                                <funcdef>sd_login_monitor* <function>sd_login_monitor_unref</function></funcdef> +                                <paramdef>sd_login_monitor* <parameter>m</parameter></paramdef> +                        </funcprototype> + +                        <funcprototype> +                                <funcdef>int <function>sd_login_monitor_flush</function></funcdef> +                                <paramdef>sd_login_monitor* <parameter>m</parameter></paramdef> +                        </funcprototype> + +                        <funcprototype> +                                <funcdef>int <function>sd_login_monitor_get_fd</function></funcdef> +                                <paramdef>sd_login_monitor* <parameter>m</parameter></paramdef> +                        </funcprototype> + +                </funcsynopsis> +        </refsynopsisdiv> + +        <refsect1> +                <title>Description</title> + +                <para><function>sd_login_monitor_new()</function> may +                be used to monitor login session, users and seats. Via +                a monitor object a file descriptor can be integrated +                into an application defined event loop which is woken +                up each time a user logs in, logs out or a seat is +                added or removed, or a session, user, or seat changes +                state otherwise. The first parameter takes a string +                which can be either <literal>seat</literal> (to get +                only notifications about seats being added, removed or +                changed), <literal>session</literal> (to get only +                notifications about sessions being created or removed +                or changed) or <literal>uid</literal> (to get only +                notifications when a user changes state in respect to +                logins). If notifications shall be generated in all +                these conditions, NULL may be passed. Note that in +                future additional categories may be defined. The +                second parameter returns a monitor object and needs to +                be freed with the +                <function>sd_login_monitor_unref()</function> call +                after use.</para> + +                <para><function>sd_login_monitor_unref()</function> +                may be used to destroy a monitor object. Note that +                this will invalidate any file descriptor returned by +                <function>sd_login_monitor_get_fd()</function>.</para> + +                <para><function>sd_login_monitor_flush()</function> +                may be used to reset the wakeup state of the monitor +                object. Whenever an event causes the monitor to wake +                up the event loop via the file descriptor this +                function needs to be called to reset the wake-up +                state. If this call is not invoked the file descriptor +                will immediately wake up the event loop again.</para> + +                <para><function>sd_login_monitor_get_fd()</function> +                may be used to retrieve the file descriptor of the +                monitor object that may be integrated in an +                application defined event loop, based around +                <citerefentry><refentrytitle>poll</refentrytitle><manvolnum>2</manvolnum></citerefentry> +                or a similar interface. The application should include +                the returned file descriptor as wake up source for +                POLLIN events. Whenever a wake-up is triggered the +                file descriptor needs to be reset via +                <function>sd_login_monitor_flush()</function>. An +                application needs to reread the login state with a +                function like +                <citerefentry><refentrytitle>sd_get_seats</refentrytitle><manvolnum>3</manvolnum></citerefentry> +                or similar to determine what changed.</para> +        </refsect1> + +        <refsect1> +                <title>Return Value</title> + +                <para>On success +                <function>sd_login_monitor_new()</function> and +                <function>sd_login_monitor_flush()</function> return 0 +                or a positive integer. On success +                <function>sd_login_monitor_get_fd()</function> returns +                a Unix file descriptor. On failure, these calls return +                a negative errno-style error code.</para> + +                <para><function>sd_login_monitor_unref()</function> +                always returns NULL.</para> +        </refsect1> + +        <refsect1> +                <title>Notes</title> + +                <para>The <function>sd_login_monitor_new()</function>, +                <function>sd_login_monitor_unref()</function>, <function>sd_login_monitor_flush()</function> and +                <function>sd_login_monitor_get_fd()</function> interfaces +                are available as shared library, which can be compiled +                and linked to with the +                <literal>libsystemd-login</literal> +                <citerefentry><refentrytitle>pkg-config</refentrytitle><manvolnum>1</manvolnum></citerefentry> +                file.</para> +        </refsect1> + +        <refsect1> +                <title>See Also</title> + +                <para> +                        <citerefentry><refentrytitle>systemd</refentrytitle><manvolnum>1</manvolnum></citerefentry>, +                        <citerefentry><refentrytitle>sd-login</refentrytitle><manvolnum>7</manvolnum></citerefentry>, +                        <citerefentry><refentrytitle>sd_get_seats</refentrytitle><manvolnum>3</manvolnum></citerefentry> +                </para> +        </refsect1> + +</refentry> diff --git a/man/sd_notify.xml b/man/sd_notify.xml index 62347f8ab0..c3791ce39f 100644 --- a/man/sd_notify.xml +++ b/man/sd_notify.xml @@ -50,7 +50,7 @@          <refsynopsisdiv>                  <funcsynopsis> -                        <funcsynopsisinfo>#include "sd-daemon.h"</funcsynopsisinfo> +                        <funcsynopsisinfo>#include <systemd/sd-daemon.h></funcsynopsisinfo>                          <funcprototype>                                  <funcdef>int <function>sd_notify</function></funcdef> diff --git a/man/sd_pid_get_session.xml b/man/sd_pid_get_session.xml new file mode 100644 index 0000000000..24e468015f --- /dev/null +++ b/man/sd_pid_get_session.xml @@ -0,0 +1,135 @@ +<?xml version='1.0'?> <!--*-nxml-*--> +<!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN" +        "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd"> + +<!-- +  This file is part of systemd. + +  Copyright 2010 Lennart Poettering + +  systemd is free software; you can redistribute it and/or modify it +  under the terms of the GNU General Public License as published by +  the Free Software Foundation; either version 2 of the License, or +  (at your option) any later version. + +  systemd is distributed in the hope that it will be useful, but +  WITHOUT ANY WARRANTY; without even the implied warranty of +  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +  General Public License for more details. + +  You should have received a copy of the GNU General Public License +  along with systemd; If not, see <http://www.gnu.org/licenses/>. +--> + +<refentry id="sd_pid_get_session"> + +        <refentryinfo> +                <title>sd_pid_get_session</title> +                <productname>systemd</productname> + +                <authorgroup> +                        <author> +                                <contrib>Developer</contrib> +                                <firstname>Lennart</firstname> +                                <surname>Poettering</surname> +                                <email>lennart@poettering.net</email> +                        </author> +                </authorgroup> +        </refentryinfo> + +        <refmeta> +                <refentrytitle>sd_pid_get_session</refentrytitle> +                <manvolnum>3</manvolnum> +        </refmeta> + +        <refnamediv> +                <refname>sd_pid_get_session</refname> +                <refname>sd_pid_get_owner_uid</refname> +                <refpurpose>Determine session or owner of a session of a specific PID</refpurpose> +        </refnamediv> + +        <refsynopsisdiv> +                <funcsynopsis> +                        <funcsynopsisinfo>#include <systemd/sd-login.h></funcsynopsisinfo> + +                        <funcprototype> +                                <funcdef>int <function>sd_pid_get_session</function></funcdef> +                                <paramdef>pid_t <parameter>pid</parameter></paramdef> +                                <paramdef>char** <parameter>session</parameter></paramdef> +                        </funcprototype> + +                        <funcprototype> +                                <funcdef>int <function>sd_pid_get_owner_uid</function></funcdef> +                                <paramdef>pid_t <parameter>pid</parameter></paramdef> +                                <paramdef>uid_t* <parameter>uid</parameter></paramdef> +                        </funcprototype> +                </funcsynopsis> +        </refsynopsisdiv> + +        <refsect1> +                <title>Description</title> + +                <para><function>sd_pid_get_session()</function> may be +                used to determine the login session identifier of a +                process identified by the specified process +                identifier. The session identifier is a short string, +                suitable for usage in file system paths. Note that not +                all processes are part of a login session (e.g. system +                service processes and user processes that are shared +                between multiple sessions of the same user). For +                processes not being part of a login session this +                function will fail. The returned string needs to be +                freed with the libc +                <citerefentry><refentrytitle>free</refentrytitle><manvolnum>3</manvolnum></citerefentry> +                call after use.</para> + +                <para><function>sd_pid_get_owner_uid()</function> may +                be used to determine the Unix user identifier of the +                owner of the session of a process identified the +                specified PID. Note that this function will succeed +                for user processes which are shared between multiple +                login sessions of the same user, where +                <function>sd_pid_get_session()</function> will +                fail. For processes not being part of a login session +                and not being a shared process of a user this function +                will fail.</para> +        </refsect1> + +        <refsect1> +                <title>Return Value</title> + +                <para>On success these calls return 0 or a positive +                integer. On failure, these calls return a negative +                errno-style error code.</para> +        </refsect1> + +        <refsect1> +                <title>Notes</title> + +                <para>The <function>sd_pid_get_session()</function> +                and <function>sd_pid_get_owner_uid()</function> +                interfaces are available as shared library, which can +                be compiled and linked to with the +                <literal>libsystemd-login</literal> +                <citerefentry><refentrytitle>pkg-config</refentrytitle><manvolnum>1</manvolnum></citerefentry> +                file.</para> + +                <para>Note that the login session identifier as +                returned by <function>sd_pid_get_session()</function> +                is completely unrelated to the process session +                identifier as returned by +                <citerefentry><refentrytitle>getsid</refentrytitle><manvolnum>2</manvolnum></citerefentry>.</para> +        </refsect1> + +        <refsect1> +                <title>See Also</title> + +                <para> +                        <citerefentry><refentrytitle>systemd</refentrytitle><manvolnum>1</manvolnum></citerefentry>, +                        <citerefentry><refentrytitle>sd-login</refentrytitle><manvolnum>7</manvolnum></citerefentry>, +                        <citerefentry><refentrytitle>sd_session_is_active</refentrytitle><manvolnum>3</manvolnum></citerefentry>, +                        <citerefentry><refentrytitle>getsid</refentrytitle><manvolnum>2</manvolnum></citerefentry> +                </para> +        </refsect1> + +</refentry> diff --git a/man/sd_readahead.xml b/man/sd_readahead.xml index 88b135b7ec..25fe5b2fc6 100644 --- a/man/sd_readahead.xml +++ b/man/sd_readahead.xml @@ -49,7 +49,7 @@          <refsynopsisdiv>                  <funcsynopsis> -                        <funcsynopsisinfo>#include "sd-daemon.h"</funcsynopsisinfo> +                        <funcsynopsisinfo>#include "sd-readahead.h"</funcsynopsisinfo>                          <funcprototype>                                  <funcdef>int <function>sd_readahead</function></funcdef> @@ -134,23 +134,17 @@                  url="http://cgit.freedesktop.org/systemd/tree/src/sd-readahead.h"/></para>                  <para><function>sd_readahead()</function> is -                implemented in the reference implementation's +                implemented in the reference implementation's drop-in                  <filename>sd-readahead.c</filename> and -                <filename>sd-readahead.h</filename> files. These -                interfaces are available as shared library, which can -                be compiled and linked to with the -                <literal>libsystemd-daemon</literal> -                <citerefentry><refentrytitle>pkg-config</refentrytitle><manvolnum>1</manvolnum></citerefentry> -                file. Alternatively, applications consuming this API -                may copy the implementation into their source -                tree. For more details about the reference -                implementation see -                <citerefentry><refentrytitle>sd-readahead</refentrytitle><manvolnum>7</manvolnum></citerefentry>.</para> - -                <para>If the reference implementation is used as -                drop-in files and -DDISABLE_SYSTEMD is set during -                compilation this function will always return 0 and -                otherwise become a NOP.</para> +                <filename>sd-readahead.h</filename> files. It is +                recommended that applications consuming this API copy +                the implementation into their source tree. For more +                details about the reference implementation see +                <citerefentry><refentrytitle>sd-readahead</refentrytitle><manvolnum>7</manvolnum></citerefentry></para> + +                <para>If -DDISABLE_SYSTEMD is set during compilation +                this function will always return 0 and otherwise +                become a NOP.</para>          </refsect1>          <refsect1> diff --git a/man/sd_seat_get_active.xml b/man/sd_seat_get_active.xml new file mode 100644 index 0000000000..14cda60a56 --- /dev/null +++ b/man/sd_seat_get_active.xml @@ -0,0 +1,152 @@ +<?xml version='1.0'?> <!--*-nxml-*--> +<!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN" +        "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd"> + +<!-- +  This file is part of systemd. + +  Copyright 2010 Lennart Poettering + +  systemd is free software; you can redistribute it and/or modify it +  under the terms of the GNU General Public License as published by +  the Free Software Foundation; either version 2 of the License, or +  (at your option) any later version. + +  systemd is distributed in the hope that it will be useful, but +  WITHOUT ANY WARRANTY; without even the implied warranty of +  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +  General Public License for more details. + +  You should have received a copy of the GNU General Public License +  along with systemd; If not, see <http://www.gnu.org/licenses/>. +--> + +<refentry id="sd_seat_get_active"> + +        <refentryinfo> +                <title>sd_seat_get_active</title> +                <productname>systemd</productname> + +                <authorgroup> +                        <author> +                                <contrib>Developer</contrib> +                                <firstname>Lennart</firstname> +                                <surname>Poettering</surname> +                                <email>lennart@poettering.net</email> +                        </author> +                </authorgroup> +        </refentryinfo> + +        <refmeta> +                <refentrytitle>sd_seat_get_active</refentrytitle> +                <manvolnum>3</manvolnum> +        </refmeta> + +        <refnamediv> +                <refname>sd_seat_get_active</refname> +                <refname>sd_seat_get_sessions</refname> +                <refname>sd_seat_can_multi_session</refname> +                <refpurpose>Determine state of a specific seat</refpurpose> +        </refnamediv> + +        <refsynopsisdiv> +                <funcsynopsis> +                        <funcsynopsisinfo>#include <systemd/sd-login.h></funcsynopsisinfo> + +                        <funcprototype> +                                <funcdef>int <function>sd_seat_get_active</function></funcdef> +                                <paramdef>const char* <parameter>seat</parameter></paramdef> +                                <paramdef>char** <parameter>session</parameter></paramdef> +                                <paramdef>uid_t* <parameter>uid</parameter></paramdef> +                        </funcprototype> + +                        <funcprototype> +                                <funcdef>int <function>sd_seat_get_sessions</function></funcdef> +                                <paramdef>const char* <parameter>seat</parameter></paramdef> +                                <paramdef>char*** <parameter>sessions</parameter></paramdef> +                                <paramdef>uid_t** <parameter>uid</parameter></paramdef> +                                <paramdef>unsigned* <parameter>n_uids</parameter></paramdef> +                        </funcprototype> + +                        <funcprototype> +                                <funcdef>int <function>sd_seat_can_multi_session</function></funcdef> +                                <paramdef>const char* <parameter>session</parameter></paramdef> +                        </funcprototype> +                </funcsynopsis> +        </refsynopsisdiv> + +        <refsect1> +                <title>Description</title> + +                <para><function>sd_seat_get_active()</function> may be +                used to determine which session is currently active on +                a seat, if there is any. Returns the session +                identifier and the user identifier of the Unix user +                the session is belonging to. Either the session or the +                user identifier parameter can be be passed NULL, in +                case only one of the parameters shall be queried. The +                returned string needs to be freed with the libc +                <citerefentry><refentrytitle>free</refentrytitle><manvolnum>3</manvolnum></citerefentry> +                call after use.</para> + +                <para><function>sd_seat_get_sessions()</function> may +                be used to determine all sessions on the specified +                seat. Returns two arrays, one (NULL terminated) with +                the session identifiers of the sessions and one with +                the user identifiers of the Unix users the sessions +                belong to. An additional parameter may be used to +                return the number of entries in the latter array. The +                two arrays and the latter parameter may be passed as +                NULL in case these values need not to be +                determined. The arrays and the strings referenced by +                them need to be freed with the libc +                <citerefentry><refentrytitle>free</refentrytitle><manvolnum>3</manvolnum></citerefentry> +                call after use. Note that instead of an empty array +                NULL may be returned and should be considered +                equivalent to an empty array.</para> + +                <para><function>sd_seat_can_multi_session()</function> +                may be used to determine whether a specific seat is +                capable of multi-session, i.e. allows multiple login +                sessions in parallel (whith only one being active at a +                time).</para> +        </refsect1> + +        <refsect1> +                <title>Return Value</title> + +                <para> On success +                <function>sd_seat_get_active()</function> return +                return 0 or a positive integer. On success +                <function>sd_seat_get_sessions()</function> returns +                the number of entries in the session identifier +                array. If the test succeeds +                <function>sd_seat_can_multi_session</function> returns +                a positive integer, if it fails 0. On failure, these +                calls return a negative errno-style error code.</para> +        </refsect1> + +        <refsect1> +                <title>Notes</title> + +                <para>The <function>sd_seat_get_active()</function>, +                <function>sd_seat_get_sessions()</function>, and +                <function>sd_seat_can_multi_session()</function> interfaces +                are available as shared library, which can be compiled +                and linked to with the +                <literal>libsystemd-login</literal> +                <citerefentry><refentrytitle>pkg-config</refentrytitle><manvolnum>1</manvolnum></citerefentry> +                file.</para> +        </refsect1> + +        <refsect1> +                <title>See Also</title> + +                <para> +                        <citerefentry><refentrytitle>systemd</refentrytitle><manvolnum>1</manvolnum></citerefentry>, +                        <citerefentry><refentrytitle>sd-login</refentrytitle><manvolnum>7</manvolnum></citerefentry>, +                        <citerefentry><refentrytitle>sd_session_get_seat</refentrytitle><manvolnum>3</manvolnum></citerefentry> +                </para> +        </refsect1> + +</refentry> diff --git a/man/sd_session_is_active.xml b/man/sd_session_is_active.xml new file mode 100644 index 0000000000..88b22fd9f8 --- /dev/null +++ b/man/sd_session_is_active.xml @@ -0,0 +1,134 @@ +<?xml version='1.0'?> <!--*-nxml-*--> +<!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN" +        "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd"> + +<!-- +  This file is part of systemd. + +  Copyright 2010 Lennart Poettering + +  systemd is free software; you can redistribute it and/or modify it +  under the terms of the GNU General Public License as published by +  the Free Software Foundation; either version 2 of the License, or +  (at your option) any later version. + +  systemd is distributed in the hope that it will be useful, but +  WITHOUT ANY WARRANTY; without even the implied warranty of +  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +  General Public License for more details. + +  You should have received a copy of the GNU General Public License +  along with systemd; If not, see <http://www.gnu.org/licenses/>. +--> + +<refentry id="sd_session_is_active"> + +        <refentryinfo> +                <title>sd_session_is_active</title> +                <productname>systemd</productname> + +                <authorgroup> +                        <author> +                                <contrib>Developer</contrib> +                                <firstname>Lennart</firstname> +                                <surname>Poettering</surname> +                                <email>lennart@poettering.net</email> +                        </author> +                </authorgroup> +        </refentryinfo> + +        <refmeta> +                <refentrytitle>sd_session_is_active</refentrytitle> +                <manvolnum>3</manvolnum> +        </refmeta> + +        <refnamediv> +                <refname>sd_session_is_active</refname> +                <refname>sd_session_get_uid</refname> +                <refname>sd_session_get_seat</refname> +                <refpurpose>Determine state of a specific session</refpurpose> +        </refnamediv> + +        <refsynopsisdiv> +                <funcsynopsis> +                        <funcsynopsisinfo>#include <systemd/sd-login.h></funcsynopsisinfo> + +                        <funcprototype> +                                <funcdef>int <function>sd_session_is_active</function></funcdef> +                                <paramdef>const char* <parameter>session</parameter></paramdef> +                        </funcprototype> + +                        <funcprototype> +                                <funcdef>int <function>sd_session_get_uid</function></funcdef> +                                <paramdef>const char* <parameter>session</parameter></paramdef> +                                <paramdef>uid_t* <parameter>uid</parameter></paramdef> +                        </funcprototype> + +                        <funcprototype> +                                <funcdef>int <function>sd_session_get_seat</function></funcdef> +                                <paramdef>const char* <parameter>session</parameter></paramdef> +                                <paramdef>char** <parameter>seat</parameter></paramdef> +                        </funcprototype> +                </funcsynopsis> +        </refsynopsisdiv> + +        <refsect1> +                <title>Description</title> + +                <para><function>sd_session_is_active()</function> may +                be used to determine whether the session identified by +                the specified session identifier is currently active +                (i.e. currently in the foreground and available for +                user input) or not.</para> + +                <para><function>sd_session_get_uid()</function> may be +                used to determine the user identifier of the Unix user the session +                identified by the specified session identifier belongs +                to.</para> + +                <para><function>sd_session_get_seat()</function> may +                be used to determine the seat identifier of the seat +                the session identified by the specified session +                identifier belongs to. Note that not all sessions are +                attached to a seat, this call will fail for them. The +                returned string needs to be freed with the libc +                <citerefentry><refentrytitle>free</refentrytitle><manvolnum>3</manvolnum></citerefentry> +                call after use.</para> +        </refsect1> + +        <refsect1> +                <title>Return Value</title> + +                <para>If the test succeeds +                <function>sd_session_is_active()</function> returns a +                positive integer, if it fails 0.  On success +                <function>sd_session_get_uid()</function> and +                <function>sd_session_get_seat()</function> return 0 or +                a positive integer. On failure, these calls return a +                negative errno-style error code.</para> +        </refsect1> + +        <refsect1> +                <title>Notes</title> + +                <para>The <function>sd_session_is_active()</function>, +                <function>sd_session_get_uid()</function>, and +                <function>sd_session_get_seat()</function> interfaces +                are available as shared library, which can be compiled +                and linked to with the +                <literal>libsystemd-login</literal> +                <citerefentry><refentrytitle>pkg-config</refentrytitle><manvolnum>1</manvolnum></citerefentry> +                file.</para> +        </refsect1> + +        <refsect1> +                <title>See Also</title> + +                <para> +                        <citerefentry><refentrytitle>systemd</refentrytitle><manvolnum>1</manvolnum></citerefentry>, +                        <citerefentry><refentrytitle>sd-login</refentrytitle><manvolnum>7</manvolnum></citerefentry>, +                        <citerefentry><refentrytitle>sd_pid_get_session</refentrytitle><manvolnum>3</manvolnum></citerefentry> +                </para> +        </refsect1> + +</refentry> diff --git a/man/sd_uid_get_state.xml b/man/sd_uid_get_state.xml new file mode 100644 index 0000000000..67776257db --- /dev/null +++ b/man/sd_uid_get_state.xml @@ -0,0 +1,185 @@ +<?xml version='1.0'?> <!--*-nxml-*--> +<!DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN" +        "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd"> + +<!-- +  This file is part of systemd. + +  Copyright 2010 Lennart Poettering + +  systemd is free software; you can redistribute it and/or modify it +  under the terms of the GNU General Public License as published by +  the Free Software Foundation; either version 2 of the License, or +  (at your option) any later version. + +  systemd is distributed in the hope that it will be useful, but +  WITHOUT ANY WARRANTY; without even the implied warranty of +  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU +  General Public License for more details. + +  You should have received a copy of the GNU General Public License +  along with systemd; If not, see <http://www.gnu.org/licenses/>. +--> + +<refentry id="sd_uid_get_state"> + +        <refentryinfo> +                <title>sd_uid_get_state</title> +                <productname>systemd</productname> + +                <authorgroup> +                        <author> +                                <contrib>Developer</contrib> +                                <firstname>Lennart</firstname> +                                <surname>Poettering</surname> +                                <email>lennart@poettering.net</email> +                        </author> +                </authorgroup> +        </refentryinfo> + +        <refmeta> +                <refentrytitle>sd_uid_get_state</refentrytitle> +                <manvolnum>3</manvolnum> +        </refmeta> + +        <refnamediv> +                <refname>sd_uid_get_state</refname> +                <refname>sd_uid_is_on_seat</refname> +                <refname>sd_uid_get_sessions</refname> +                <refname>sd_uid_get_seats</refname> +                <refpurpose>Determine login state of a specific Unix user ID</refpurpose> +        </refnamediv> + +        <refsynopsisdiv> +                <funcsynopsis> +                        <funcsynopsisinfo>#include <systemd/sd-login.h></funcsynopsisinfo> + +                        <funcprototype> +                                <funcdef>int <function>sd_uid_get_state</function></funcdef> +                                <paramdef>uid_t <parameter>pid</parameter></paramdef> +                                <paramdef>char** <parameter>state</parameter></paramdef> +                        </funcprototype> + +                        <funcprototype> +                                <funcdef>int <function>sd_uid_is_on_seat</function></funcdef> +                                <paramdef>uid_t <parameter>pid</parameter></paramdef> +                                <paramdef>int <parameter>require_active</parameter></paramdef> +                                <paramdef>const char* <parameter>seat</parameter></paramdef> +                        </funcprototype> + +                        <funcprototype> +                                <funcdef>int <function>sd_uid_get_sessions</function></funcdef> +                                <paramdef>uid_t <parameter>pid</parameter></paramdef> +                                <paramdef>int <parameter>require_active</parameter></paramdef> +                                <paramdef>char*** <parameter>sessions</parameter></paramdef> +                        </funcprototype> + +                        <funcprototype> +                                <funcdef>int <function>sd_uid_get_seats</function></funcdef> +                                <paramdef>uid_t <parameter>pid</parameter></paramdef> +                                <paramdef>int <parameter>require_active</parameter></paramdef> +                                <paramdef>char*** <parameter>seats</parameter></paramdef> +                        </funcprototype> +                </funcsynopsis> +        </refsynopsisdiv> + +        <refsect1> +                <title>Description</title> + +                <para><function>sd_uid_get_state()</function> may be +                used to determine the login state of a specific Unix +                user identifier. The following states are currently +                known: <literal>offline</literal> (user not logged in +                at all), <literal>lingering</literal> (user not logged +                in, but some user services running), +                <literal>online</literal> (user logged in, but not +                active), <literal>active</literal> (user logged in on +                an active seat). In the future additional states might +                be defined, client code should be written to be robust +                in regards to additional state strings being +                returned. The returned string needs to be freed with +                the libc +                <citerefentry><refentrytitle>free</refentrytitle><manvolnum>3</manvolnum></citerefentry> +                call after use.</para> + +                <para><function>sd_uid_is_on_seat()</function> may be +                used to determine whether a specific user is logged in +                or active on a specific seat. Accepts a Unix user +                identifier and a seat identifier string as +                parameters. The <parameter>require_active</parameter> +                parameter is a boolean. If non-zero (true) this +                function will test if the user is active (i.e. has a +                session that is in the foreground and accepting user +                input) on the specified seat, otherwise (false) only +                if the user is logged in (and possibly inactive) on +                the specified seat.</para> + +                <para><function>sd_uid_get_sessions()</function> may +                be used to determine the current sessions of the +                specified user. Acceptes a Unix user identifier as +                parameter. The <parameter>require_active</parameter> +                boolean parameter controls whether the returned list +                shall consist of only those sessions where the user is +                currently active (true) or where the user is currently +                logged in at all, possibly inactive (false). The call +                returns a NULL terminated string array of session +                identifiers in <parameter>sessions</parameter> which +                needs to be freed by the caller with the libc +                <citerefentry><refentrytitle>free</refentrytitle><manvolnum>3</manvolnum></citerefentry> +                call after use, including all the strings +                referenced. If the string array parameter is passed as +                NULL the array will not be filled in, but the return +                code still indicates the number of current +                sessions. Note that instead of an empty array NULL may +                be returned and should be considered equivalent to an +                empty array.</para> + +                <para>Similar, <function>sd_uid_get_seats()</function> +                may be used to determine the list of seats on which +                the user currently has sessions. Similar semantics +                apply, however note that the user may have +                multiple sessions on the same seat as well as sessions +                with no attached seat and hence the number of entries +                in the returned array may differ from the one returned +                by <function>sd_uid_get_sessions()</function>.</para> +        </refsect1> + +        <refsect1> +                <title>Return Value</title> + +                <para>On success +                <function>sd_uid_get_state()</function> returns 0 or a +                positive integer. If the test succeeds +                <function>sd_uid_is_on_seat()</function> returns a +                positive integer, if it fails +                0. <function>sd_uid_get_sessions()</function> and +                <function>sd_uid_get_seats()</function> return the +                number of entries in the returned arrays. On failure, +                these calls return a negative errno-style error +                code.</para> +        </refsect1> + +        <refsect1> +                <title>Notes</title> + +                <para>The <function>sd_uid_get_state()</function>, +                <function>sd_uid_is_on_seat()</function>, +                <function>sd_uid_get_sessions()</function>, and +                <function>sd_uid_get_seats()</function> interfaces are +                available as shared library, which can be compiled and +                linked to with the <literal>libsystemd-login</literal> +                <citerefentry><refentrytitle>pkg-config</refentrytitle><manvolnum>1</manvolnum></citerefentry> +                file.</para> +        </refsect1> + +        <refsect1> +                <title>See Also</title> + +                <para> +                        <citerefentry><refentrytitle>systemd</refentrytitle><manvolnum>1</manvolnum></citerefentry>, +                        <citerefentry><refentrytitle>sd-login</refentrytitle><manvolnum>7</manvolnum></citerefentry>, +                        <citerefentry><refentrytitle>sd_pid_get_owner_uid</refentrytitle><manvolnum>3</manvolnum></citerefentry> +                </para> +        </refsect1> + +</refentry> | 
