blob: 62b39eab83d04e84cc28d16f0509871a724e73da [file] [log] [blame]
Willy Tarreaubaaee002006-06-26 02:48:02 +02001/*
2 include/proto/log.h
3 This file contains definitions of log-related functions, structures,
4 and macros.
5
Willy Tarreauec6c5df2008-07-15 00:22:45 +02006 Copyright (C) 2000-2008 Willy Tarreau - w@1wt.eu
Willy Tarreaubaaee002006-06-26 02:48:02 +02007
8 This library is free software; you can redistribute it and/or
9 modify it under the terms of the GNU Lesser General Public
10 License as published by the Free Software Foundation, version 2.1
11 exclusively.
12
13 This library is distributed in the hope that it will be useful,
14 but 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
19 License along with this library; if not, write to the Free Software
20 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
21*/
22
23#ifndef _PROTO_LOG_H
24#define _PROTO_LOG_H
25
26#include <stdio.h>
27#include <syslog.h>
28
Willy Tarreaue3ba5f02006-06-29 18:54:54 +020029#include <common/config.h>
Willy Tarreau332f8bf2007-05-13 21:36:56 +020030#include <common/memory.h>
Willy Tarreaubaaee002006-06-26 02:48:02 +020031#include <types/log.h>
32#include <types/proxy.h>
Willy Tarreau87b09662015-04-03 00:22:06 +020033#include <types/stream.h>
Willy Tarreaubaaee002006-06-26 02:48:02 +020034
Willy Tarreau332f8bf2007-05-13 21:36:56 +020035extern struct pool_head *pool2_requri;
William Lallemanda73203e2012-03-12 12:48:57 +010036extern struct pool_head *pool2_uniqueid;
Willy Tarreau332f8bf2007-05-13 21:36:56 +020037
William Lallemand723b73a2012-02-08 16:37:49 +010038extern char *log_format;
William Lallemandbddd4fd2012-02-27 11:23:10 +010039extern char default_tcp_log_format[];
William Lallemand723b73a2012-02-08 16:37:49 +010040extern char default_http_log_format[];
41extern char clf_http_log_format[];
Dragan Dosen1322d092015-09-22 16:05:32 +020042
43extern char default_host_tag_pid_log_format[];
44extern char rfc5424_host_tag_pid_log_format[];
45
Dragan Dosen0b85ece2015-09-25 19:17:44 +020046extern char default_rfc5424_sd_log_format[];
47
Dragan Dosen59cee972015-09-19 22:09:02 +020048extern char *logheader;
Dragan Dosen1322d092015-09-22 16:05:32 +020049extern char *logheader_rfc5424;
Willy Tarreau18324f52014-06-27 18:10:07 +020050extern char *logline;
Dragan Dosen0b85ece2015-09-25 19:17:44 +020051extern char *logline_rfc5424;
William Lallemand723b73a2012-02-08 16:37:49 +010052
William Lallemandbddd4fd2012-02-27 11:23:10 +010053
Willy Tarreau87b09662015-04-03 00:22:06 +020054int build_logline(struct stream *s, char *dst, size_t maxsize, struct list *list_format);
William Lallemand1d705562012-03-12 12:46:41 +010055
William Lallemandbddd4fd2012-02-27 11:23:10 +010056/*
Willy Tarreau87b09662015-04-03 00:22:06 +020057 * send a log for the stream when we have enough info about it.
William Lallemandbddd4fd2012-02-27 11:23:10 +010058 * Will not log if the frontend has no log defined.
59 */
Willy Tarreau87b09662015-04-03 00:22:06 +020060void strm_log(struct stream *s);
William Lallemandbddd4fd2012-02-27 11:23:10 +010061
William Lallemand723b73a2012-02-08 16:37:49 +010062/*
63 * Parse args in a logformat_var
64 */
65int parse_logformat_var_args(char *args, struct logformat_node *node);
66
67/*
Willy Tarreau8a3f52f2012-12-20 21:23:42 +010068 * Parse a variable '%varname' or '%{args}varname' in log-format
William Lallemand723b73a2012-02-08 16:37:49 +010069 *
70 */
Willy Tarreau8a3f52f2012-12-20 21:23:42 +010071int parse_logformat_var(char *arg, int arg_len, char *var, int var_len, struct proxy *curproxy, struct list *list_format, int *defoptions);
William Lallemand723b73a2012-02-08 16:37:49 +010072
73/*
74 * add to the logformat linked list
75 */
William Lallemand1d705562012-03-12 12:46:41 +010076void add_to_logformat_list(char *start, char *end, int type, struct list *list_format);
William Lallemand723b73a2012-02-08 16:37:49 +010077
78/*
79 * Parse the log_format string and fill a linked list.
80 * Variable name are preceded by % and composed by characters [a-zA-Z0-9]* : %varname
81 * You can set arguments using { } : %{many arguments}varname
82 */
Thierry FOURNIEReeaa9512014-02-11 14:00:19 +010083void parse_logformat_string(const char *str, struct proxy *curproxy, struct list *list_format, int options, int cap, const char *file, int line);
Willy Tarreaubaaee002006-06-26 02:48:02 +020084/*
85 * Displays the message on stderr with the date and pid. Overrides the quiet
86 * mode during startup.
87 */
Willy Tarreau40d25162009-04-03 12:01:47 +020088void Alert(const char *fmt, ...)
89 __attribute__ ((format(printf, 1, 2)));
Willy Tarreaubaaee002006-06-26 02:48:02 +020090
91/*
92 * Displays the message on stderr with the date and pid.
93 */
Willy Tarreau40d25162009-04-03 12:01:47 +020094void Warning(const char *fmt, ...)
95 __attribute__ ((format(printf, 1, 2)));
Willy Tarreaubaaee002006-06-26 02:48:02 +020096
97/*
98 * Displays the message on <out> only if quiet mode is not set.
99 */
Willy Tarreau40d25162009-04-03 12:01:47 +0200100void qfprintf(FILE *out, const char *fmt, ...)
101 __attribute__ ((format(printf, 2, 3)));
Willy Tarreaubaaee002006-06-26 02:48:02 +0200102
William Lallemand2a4a44f2012-02-06 16:00:33 +0100103/*
104 * This function adds a header to the message and sends the syslog message
105 * using a printf format string
106 */
107void send_log(struct proxy *p, int level, const char *format, ...)
108 __attribute__ ((format(printf, 3, 4)));
109
Willy Tarreaubaaee002006-06-26 02:48:02 +0200110/*
111 * This function sends a syslog message to both log servers of a proxy,
112 * or to global log servers if the proxy is NULL.
113 * It also tries not to waste too much time computing the message header.
114 * It doesn't care about errors nor does it report them.
115 */
Willy Tarreaubaaee002006-06-26 02:48:02 +0200116
Dragan Dosen0b85ece2015-09-25 19:17:44 +0200117void __send_log(struct proxy *p, int level, char *message, size_t size, char *sd, size_t sd_size);
Willy Tarreaubaaee002006-06-26 02:48:02 +0200118
119/*
Dragan Dosen1322d092015-09-22 16:05:32 +0200120 * returns log format for <fmt> or -1 if not found.
121 */
122int get_log_format(const char *fmt);
123
124/*
Willy Tarreaubaaee002006-06-26 02:48:02 +0200125 * returns log level for <lev> or -1 if not found.
126 */
127int get_log_level(const char *lev);
128
129/*
130 * returns log facility for <fac> or -1 if not found.
131 */
132int get_log_facility(const char *fac);
133
William Lallemanda1cc3812012-02-08 16:38:44 +0100134/*
135 * Write a string in the log string
William Lallemand5f232402012-04-05 18:02:55 +0200136 * Take cares of quote options
William Lallemanda1cc3812012-02-08 16:38:44 +0100137 *
138 * Return the adress of the \0 character, or NULL on error
139 */
Willy Tarreau2b0108a2012-12-21 19:23:44 +0100140char *lf_text_len(char *dst, const char *src, size_t len, size_t size, struct logformat_node *node);
William Lallemand5f232402012-04-05 18:02:55 +0200141
142/*
143 * Write a IP adress to the log string
144 * +X option write in hexadecimal notation, most signifant byte on the left
145 */
146char *lf_ip(char *dst, struct sockaddr *sockaddr, size_t size, struct logformat_node *node);
147
148/*
149 * Write a port to the log
150 * +X option write in hexadecimal notation, most signifant byte on the left
151 */
152char *lf_port(char *dst, struct sockaddr *sockaddr, size_t size, struct logformat_node *node);
153
Dragan Dosen68d2e3a2015-09-19 22:35:44 +0200154/*
155 * Write hostname, log_tag and pid to the log string
156 */
Dragan Dosen1322d092015-09-22 16:05:32 +0200157char *lf_host_tag_pid(char *dst, const char *format, const char *hostname, const char *log_tag, int pid, size_t size);
Dragan Dosen68d2e3a2015-09-19 22:35:44 +0200158
William Lallemanda1cc3812012-02-08 16:38:44 +0100159
Willy Tarreaubaaee002006-06-26 02:48:02 +0200160#endif /* _PROTO_LOG_H */
161
162/*
163 * Local variables:
164 * c-indent-level: 8
165 * c-basic-offset: 8
166 * End:
167 */