1 /* -*- Mode: C; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
3 * GIO - GLib Input, Output and Streaming Library
5 * Copyright 2009 Red Hat, Inc
7 * This library is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU Lesser General Public
9 * License as published by the Free Software Foundation; either
10 * version 2.1 of the License, or (at your option) any later version.
12 * This library is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15 * Lesser General Public License for more details.
17 * You should have received a copy of the GNU Lesser General
18 * Public License along with this library; if not, see
19 * <http://www.gnu.org/licenses/>.
21 * In addition, when the library is used with OpenSSL, a special
22 * exception applies. Refer to the LICENSE_EXCEPTION file for details.
29 #include <glib/gprintf.h>
34 void g_tls_log (GLogLevelFlags level,
42 if (level < G_LOG_LEVEL_DEBUG || ENABLE_DEBUG_LOGS)
45 gchar *message = NULL;
50 va_start (args, format);
51 ret = g_vasprintf (&message, format, args);
57 if (conn && G_IS_TLS_CONNECTION (conn)) {
58 if (G_IS_TLS_CLIENT_CONNECTION (conn))
59 header = g_strdup_printf ("CLIENT[%p]: ", conn);
60 else if (G_IS_TLS_SERVER_CONNECTION (conn))
61 header = g_strdup_printf ("SERVER[%p]: ", conn);
63 g_assert_not_reached ();
65 header = g_strdup ("");
68 thread = g_strdup_printf ("%p", g_thread_self ());
69 g_log_structured (G_LOG_DOMAIN, level,
70 "GLIB_NET_THREAD", thread,
74 "MESSAGE", "%s%s", header, message);