]> git.ipfire.org Git - thirdparty/systemd.git/blob - src/journal-remote/microhttpd-util.h
Merge pull request #2071 from chaloulo/journal-upload-miss-logs
[thirdparty/systemd.git] / src / journal-remote / microhttpd-util.h
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 #pragma once
23
24 #include <microhttpd.h>
25 #include <stdarg.h>
26
27 #include "macro.h"
28
29 /* Compatiblity with libmicrohttpd < 0.9.38 */
30 #ifndef MHD_HTTP_NOT_ACCEPTABLE
31 #define MHD_HTTP_NOT_ACCEPTABLE MHD_HTTP_METHOD_NOT_ACCEPTABLE
32 #endif
33
34 #if MHD_VERSION < 0x00094203
35 #define MHD_create_response_from_fd_at_offset64 MHD_create_response_from_fd_at_offset
36 #endif
37
38 void microhttpd_logger(void *arg, const char *fmt, va_list ap) _printf_(2, 0);
39
40 /* respond_oom() must be usable with return, hence this form. */
41 #define respond_oom(connection) log_oom(), mhd_respond_oom(connection)
42
43 int mhd_respondf(struct MHD_Connection *connection,
44 unsigned code,
45 const char *format, ...) _printf_(3,4);
46
47 int mhd_respond(struct MHD_Connection *connection,
48 unsigned code,
49 const char *message);
50
51 int mhd_respond_oom(struct MHD_Connection *connection);
52
53 int check_permissions(struct MHD_Connection *connection, int *code, char **hostname);
54
55 /* Set gnutls internal logging function to a callback which uses our
56 * own logging framework.
57 *
58 * gnutls categories are additionally filtered by our internal log
59 * level, so it should be set fairly high to capture all potentially
60 * interesting events without overwhelming detail.
61 */
62 int setup_gnutls_logger(char **categories);