summaryrefslogtreecommitdiff
path: root/man/sd_journal_stream_fd.xml
blob: de76cabb4d44c71e0ea7b52d6aae0275fb33602e (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
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
<?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">

<!--
  SPDX-License-Identifier: LGPL-2.1+
-->

<refentry id="sd_journal_stream_fd" xmlns:xi="http://www.w3.org/2001/XInclude">

  <refentryinfo>
    <title>sd_journal_stream_fd</title>
    <productname>systemd</productname>
  </refentryinfo>

  <refmeta>
    <refentrytitle>sd_journal_stream_fd</refentrytitle>
    <manvolnum>3</manvolnum>
  </refmeta>

  <refnamediv>
    <refname>sd_journal_stream_fd</refname>
    <refpurpose>Create log stream file descriptor to the journal</refpurpose>
  </refnamediv>

  <refsynopsisdiv>
    <funcsynopsis>
      <funcsynopsisinfo>#include &lt;systemd/sd-journal.h&gt;</funcsynopsisinfo>

      <funcprototype>
        <funcdef>int <function>sd_journal_stream_fd</function></funcdef>
        <paramdef>const char *<parameter>identifier</parameter></paramdef>
        <paramdef>int <parameter>priority</parameter></paramdef>
        <paramdef>int <parameter>level_prefix</parameter></paramdef>
      </funcprototype>

    </funcsynopsis>
  </refsynopsisdiv>

  <refsect1>
    <title>Description</title>

    <para><function>sd_journal_stream_fd()</function> may be used to
    create a log stream file descriptor. Log messages written to this
    file descriptor as simple newline-separated text strings are
    written to the journal. This file descriptor can be used
    internally by applications or be made standard output or standard
    error of other processes executed.</para>

    <para><function>sd_journal_stream_fd()</function> takes a short
    program identifier string as first argument, which will be written
    to the journal as _SYSLOG_IDENTIFIER= field for each log entry
    (see
    <citerefentry><refentrytitle>systemd.journal-fields</refentrytitle><manvolnum>7</manvolnum></citerefentry>
    for more information). The second argument shall be the default
    priority level for all messages. The priority level is one of
    <constant>LOG_EMERG</constant>, <constant>LOG_ALERT</constant>,
    <constant>LOG_CRIT</constant>, <constant>LOG_ERR</constant>,
    <constant>LOG_WARNING</constant>, <constant>LOG_NOTICE</constant>,
    <constant>LOG_INFO</constant>, <constant>LOG_DEBUG</constant>, as
    defined in <filename>syslog.h</filename>, see
    <citerefentry project='man-pages'><refentrytitle>syslog</refentrytitle><manvolnum>3</manvolnum></citerefentry>
    for details. The third argument is a boolean: if true kernel-style
    log level prefixes (such as <constant>SD_WARNING</constant>) are
    interpreted, see
    <citerefentry><refentrytitle>sd-daemon</refentrytitle><manvolnum>3</manvolnum></citerefentry>
    for more information.</para>

    <para>It is recommended that applications log UTF-8 messages only
    with this API, but this is not enforced.</para>

    <para>Each invocation of <function>sd_journal_stream_fd()</function> allocates a new log stream file descriptor,
    that is not shared with prior or later invocations. The file descriptor is write-only (its reading direction is
    shut down), and <constant>O_NONBLOCK</constant> is turned off initially.</para>
  </refsect1>

  <refsect1>
    <title>Return Value</title>

    <para>The call returns a valid write-only file descriptor on
    success or a negative errno-style error code.</para>
  </refsect1>

  <refsect1>
    <title>Signal safety</title>

    <para><function>sd_journal_stream_fd()</function> is "async signal safe" in the meaning of <citerefentry
    project='man-pages'><refentrytitle>signal-safety</refentrytitle><manvolnum>7</manvolnum></citerefentry>.
    </para>
  </refsect1>

  <refsect1>
    <title>Notes</title>

    <para>Function <function>sd_journal_stream_fd()</function> is thread-safe and may be called
    from multiple threads.</para>

    <xi:include href="libsystemd-pkgconfig.xml" xpointer="pkgconfig-text"/>
  </refsect1>

  <refsect1>
    <title>Examples</title>

    <para>Creating a log stream suitable for
    <citerefentry project='man-pages'><refentrytitle>fprintf</refentrytitle><manvolnum>3</manvolnum></citerefentry>:</para>

    <programlisting>#include &lt;syslog.h&gt;
#include &lt;stdio.h&gt;
#include &lt;string.h&gt;
#include &lt;unistd.h&gt;
#include &lt;systemd/sd-journal.h&gt;
#include &lt;systemd/sd-daemon.h&gt;

int main(int argc, char *argv[]) {
  int fd;
  FILE *log;
  fd = sd_journal_stream_fd("test", LOG_INFO, 1);
  if (fd &lt; 0) {
    fprintf(stderr, "Failed to create stream fd: %s\n", strerror(-fd));
    return 1;
  }
  log = fdopen(fd, "w");
  if (!log) {
    fprintf(stderr, "Failed to create file object: %m\n");
    close(fd);
    return 1;
  }
  fprintf(log, "Hello World!\n");
  fprintf(log, SD_WARNING "This is a warning!\n");
  fclose(log);
  return 0;
}</programlisting>

  </refsect1>

  <refsect1>
    <title>See Also</title>

    <para>
      <citerefentry><refentrytitle>systemd</refentrytitle><manvolnum>1</manvolnum></citerefentry>,
      <citerefentry><refentrytitle>sd-journal</refentrytitle><manvolnum>3</manvolnum></citerefentry>,
      <citerefentry><refentrytitle>sd-daemon</refentrytitle><manvolnum>3</manvolnum></citerefentry>,
      <citerefentry><refentrytitle>sd_journal_print</refentrytitle><manvolnum>3</manvolnum></citerefentry>,
      <citerefentry project='man-pages'><refentrytitle>syslog</refentrytitle><manvolnum>3</manvolnum></citerefentry>,
      <citerefentry project='man-pages'><refentrytitle>fprintf</refentrytitle><manvolnum>3</manvolnum></citerefentry>,
      <citerefentry><refentrytitle>systemd.journal-fields</refentrytitle><manvolnum>7</manvolnum></citerefentry>
    </para>
  </refsect1>

</refentry>