2018-07-02 23:15:39 +02:00
<?xml version='1.0'?>
2019-03-14 14:40:58 +01:00
< !DOCTYPE refentry PUBLIC "-//OASIS//DTD DocBook XML V4.5//EN"
2023-12-25 15:48:33 +01:00
"http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd">
2020-11-09 13:23:58 +09:00
<!-- SPDX - License - Identifier: LGPL - 2.1 - or - later -->
2017-12-20 16:31:58 +01:00
2018-08-03 17:34:40 +02:00
<refentry id= "sd_bus_set_watch_bind"
xmlns:xi="http://www.w3.org/2001/XInclude">
2017-12-20 16:31:58 +01:00
<refentryinfo >
<title > sd_bus_set_watch_bind</title>
<productname > systemd</productname>
</refentryinfo>
<refmeta >
<refentrytitle > sd_bus_set_watch_bind</refentrytitle>
<manvolnum > 3</manvolnum>
</refmeta>
<refnamediv >
<refname > sd_bus_set_watch_bind</refname>
<refname > sd_bus_get_watch_bind</refname>
<refpurpose > Control socket binding watching on bus connections</refpurpose>
</refnamediv>
<refsynopsisdiv >
<funcsynopsis >
<funcsynopsisinfo > #include < systemd/sd-bus.h> </funcsynopsisinfo>
<funcprototype >
<funcdef > int <function > sd_bus_set_watch_bind</function> </funcdef>
<paramdef > sd_bus *<parameter > bus</parameter> </paramdef>
<paramdef > int <parameter > b</parameter> </paramdef>
</funcprototype>
<funcprototype >
<funcdef > int <function > sd_bus_get_watch_bind</function> </funcdef>
<paramdef > sd_bus *<parameter > bus</parameter> </paramdef>
</funcprototype>
</funcsynopsis>
</refsynopsisdiv>
<refsect1 >
<title > Description</title>
<para > <function > sd_bus_set_watch_bind()</function> may be used to enable or disable client-side watching of server
socket binding for a bus connection object. If the <parameter > b</parameter> is true, the feature is enabled,
otherwise disabled (which is the default). When enabled, and the selected bus address refers to an
<filename > AF_UNIX</filename> socket in the file system which does not exist while the connection attempt is made an
2020-06-25 14:37:24 +02:00
<citerefentry project= 'man-pages' > <refentrytitle > inotify</refentrytitle> <manvolnum > 7</manvolnum> </citerefentry> watch is installed on
2017-12-20 16:31:58 +01:00
it, waiting for the socket to appear. As soon as the socket appears the connection is made. This functionality is
useful in particular in early-boot programs that need to run before the system bus is available, but want to
connect to it the instant it may be connected to.</para>
<para > <function > sd_bus_get_watch_bind()</function> may be used to query the current setting of this feature. It
returns zero when the feature is disabled, and positive if enabled.</para>
2020-06-25 14:41:05 +02:00
<para > Note that no timeout is applied while we wait for the socket to appear. This means that any
synchronous remote operation (such as
2017-12-20 16:31:58 +01:00
<citerefentry > <refentrytitle > sd_bus_call</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> ,
<citerefentry > <refentrytitle > sd_bus_add_match</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> or
2020-06-25 14:41:05 +02:00
<citerefentry > <refentrytitle > sd_bus_request_name</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> ),
that is used on a connection with this feature enabled that hasn't been established yet, might block
forever if the socket is never created. However, asynchronous remote operations (such as
2017-12-20 16:31:58 +01:00
<citerefentry > <refentrytitle > sd_bus_send</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> ,
2020-06-25 14:38:21 +02:00
<citerefentry > <refentrytitle > sd_bus_call_async</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> ,
2020-06-25 14:41:05 +02:00
<citerefentry > <refentrytitle > sd_bus_add_match_async</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> )
do not block in this case, and safely enqueue the requested operations to be dispatched the instant the
connection is set up.</para>
2017-12-20 16:31:58 +01:00
<para > Use <citerefentry > <refentrytitle > sd_bus_is_ready</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> to
determine whether the connection is fully established, i.e. whether the peer socket has been bound, connected to
and authenticated. Use
<citerefentry > <refentrytitle > sd_bus_set_connected_signal</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> to
be notified when the connection is fully established.</para>
</refsect1>
<refsect1 >
<title > Return Value</title>
2019-03-21 14:53:00 +01:00
<para > On success, these functions return 0 or a positive integer. On failure, they return a negative
errno-style error code.</para>
2017-12-20 16:31:58 +01:00
2019-03-21 14:53:00 +01:00
<refsect2 >
<title > Errors</title>
2017-12-20 16:31:58 +01:00
2019-03-21 14:53:00 +01:00
<para > Returned errors may indicate the following problems:</para>
2017-12-20 16:31:58 +01:00
2019-03-21 14:53:00 +01:00
<variablelist >
<varlistentry >
<term > <constant > -ECHILD</constant> </term>
2017-12-20 16:31:58 +01:00
2023-04-25 00:56:06 +01:00
<listitem > <para > The bus connection has been created in a different process, library or module instance.</para> </listitem>
2019-03-21 14:53:00 +01:00
</varlistentry>
</variablelist>
</refsect2>
2017-12-20 16:31:58 +01:00
</refsect1>
2018-08-03 17:34:40 +02:00
<xi:include href= "libsystemd-pkgconfig.xml" />
2017-12-20 16:31:58 +01:00
2023-12-13 14:01:17 +00:00
<refsect1 >
<title > Example</title>
<example >
<title > Create a simple system service that publishes a property on the system bus and can reconnect
when D-Bus disconnects and reconnects</title>
<programlisting > <xi:include href= "sd_bus_service_reconnect.c" parse= "text" /> </programlisting>
<para > This is particularly useful for services that are configured to survive a soft-reboot, see
<citerefentry > <refentrytitle > systemd-soft-reboot.service</refentrytitle> <manvolnum > 8</manvolnum> </citerefentry>
for more details.</para>
</example>
</refsect1>
2023-09-04 13:46:35 +01:00
<refsect1 >
<title > History</title>
2023-09-18 17:44:26 +01:00
<para > <function > sd_bus_set_watch_bind()</function> and
<function > sd_bus_get_watch_bind()</function> were added in version 237.</para>
2023-09-04 13:46:35 +01:00
</refsect1>
2017-12-20 16:31:58 +01:00
<refsect1 >
<title > See Also</title>
2023-12-22 19:09:32 +01:00
<para > <simplelist type= "inline" >
<member > <citerefentry > <refentrytitle > systemd</refentrytitle> <manvolnum > 1</manvolnum> </citerefentry> </member>
<member > <citerefentry > <refentrytitle > sd-bus</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> </member>
<member > <citerefentry project= 'man-pages' > <refentrytitle > inotify</refentrytitle> <manvolnum > 7</manvolnum> </citerefentry> </member>
<member > <citerefentry > <refentrytitle > sd_bus_call</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> </member>
<member > <citerefentry > <refentrytitle > sd_bus_add_match</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> </member>
<member > <citerefentry > <refentrytitle > sd_bus_request_name</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> </member>
<member > <citerefentry > <refentrytitle > sd_bus_is_ready</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> </member>
<member > <citerefentry > <refentrytitle > sd_bus_set_connected_signal</refentrytitle> <manvolnum > 3</manvolnum> </citerefentry> </member>
</simplelist> </para>
2017-12-20 16:31:58 +01:00
</refsect1>
</refentry>