chiark / gitweb /
b07ae6dff383c7eaa57ad35f1a7e87e8190d00a4
[elogind.git] / src / journal / microhttpd-util.c
1 /*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
2
3 /***
4   This file is part of systemd.
5
6   Copyright 2012 Zbigniew JÄ™drzejewski-Szmek
7
8   systemd is free software; you can redistribute it and/or modify it
9   under the terms of the GNU Lesser General Public License as published by
10   the Free Software Foundation; either version 2.1 of the License, or
11   (at your option) any later version.
12
13   systemd is distributed in the hope that it will be useful, but
14   WITHOUT ANY WARRANTY; without even the implied warranty of
15   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16   Lesser General Public License for more details.
17
18   You should have received a copy of the GNU Lesser General Public License
19   along with systemd; If not, see <http://www.gnu.org/licenses/>.
20 ***/
21
22 #include <stddef.h>
23 #include <stdio.h>
24
25 #include "microhttpd-util.h"
26 #include "log.h"
27 #include "macro.h"
28 #include "util.h"
29
30 void microhttpd_logger(void *arg, const char *fmt, va_list ap) {
31         _cleanup_free_ char *f = NULL;
32
33         if (asprintf(&f, "microhttpd: %s", fmt) <= 0) {
34                 log_oom();
35                 return;
36         }
37
38         DISABLE_WARNING_FORMAT_NONLITERAL;
39         log_metav(LOG_INFO, NULL, 0, NULL, f, ap);
40         REENABLE_WARNING;
41 }
42
43 #ifdef HAVE_GNUTLS
44
45 static int log_level_map[] = {
46         LOG_DEBUG,
47         LOG_WARNING, /* gnutls session audit */
48         LOG_DEBUG,   /* gnutls debug log */
49         LOG_WARNING, /* gnutls assert log */
50         LOG_INFO,    /* gnutls handshake log */
51         LOG_DEBUG,   /* gnutls record log */
52         LOG_DEBUG,   /* gnutls dtls log */
53         LOG_DEBUG,
54         LOG_DEBUG,
55         LOG_DEBUG,
56         LOG_DEBUG,   /* gnutls hard log */
57         LOG_DEBUG,   /* gnutls read log */
58         LOG_DEBUG,   /* gnutls write log */
59         LOG_DEBUG,   /* gnutls io log */
60         LOG_DEBUG,   /* gnutls buffers log */
61 };
62
63 void log_func_gnutls(int level, const char *message) {
64         int ourlevel;
65
66         assert_se(message);
67
68         if (0 <= level && level < (int) ELEMENTSOF(log_level_map))
69                 ourlevel = log_level_map[level];
70         else
71                 level = LOG_DEBUG;
72
73         log_meta(ourlevel, NULL, 0, NULL, "gnutls: %s", message);
74 }
75
76 #endif