File: gtlslog.c

package info (click to toggle)
glib-networking 2.80.1-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 2,796 kB
  • sloc: ansic: 21,084; sh: 129; python: 51; makefile: 19
file content (81 lines) | stat: -rw-r--r-- 2,489 bytes parent folder | download | duplicates (2)
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
/* -*- Mode: C; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/*
 * GIO - GLib Input, Output and Streaming Library
 *
 * Copyright 2009 Red Hat, Inc
 *
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 *
 * This library 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
 * Lesser General Public License for more details.
 *
 * You should have received a copy of the GNU Lesser General
 * Public License along with this library; if not, see
 * <http://www.gnu.org/licenses/>.
 *
 * In addition, when the library is used with OpenSSL, a special
 * exception applies. Refer to the LICENSE_EXCEPTION file for details.
 */

#include "config.h"

#include <gio/gio.h>
#include <glib.h>
#include <glib/gprintf.h>
#include <stdarg.h>

#include "gtlslog.h"

void g_tls_log (GLogLevelFlags  level,
                gpointer        conn,
                const gchar    *file,
                const gchar    *line,
                const gchar    *func,
                const gchar    *format,
                ...)
{
  if (level < G_LOG_LEVEL_DEBUG || ENABLE_DEBUG_LOGS)
    {
      gchar *header = NULL;
      gchar *message = NULL;
      gchar *thread = NULL;
      va_list args;
      int ret;

      va_start (args, format);
      ret = g_vasprintf (&message, format, args);
      va_end (args);

      if (ret <= 0)
        goto out;

      if (conn && G_IS_TLS_CONNECTION (conn)) {
        if (G_IS_TLS_CLIENT_CONNECTION (conn))
          header = g_strdup_printf ("CLIENT[%p]: ", conn);
        else if (G_IS_TLS_SERVER_CONNECTION (conn))
          header = g_strdup_printf ("SERVER[%p]: ", conn);
        else
          g_assert_not_reached ();
      } else {
        header = g_strdup ("");
      }

      thread = g_strdup_printf ("%p", g_thread_self ());
      g_log_structured (G_LOG_DOMAIN, level,
                        "GLIB_NET_THREAD", thread,
                        "CODE_FILE", file,
                        "CODE_LINE", line,
                        "CODE_FUNC", func,
                        "MESSAGE", "%s%s", header, message);

    out:
      g_free (header);
      g_free (message);
      g_free (thread);
    }
}