blob: 0ee60a00dd52697b4adeb09875959f125e1a0585 [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>
33#include <types/session.h>
34
Willy Tarreau332f8bf2007-05-13 21:36:56 +020035extern struct pool_head *pool2_requri;
36
William Lallemand723b73a2012-02-08 16:37:49 +010037extern char *log_format;
William Lallemandbddd4fd2012-02-27 11:23:10 +010038extern char default_tcp_log_format[];
William Lallemand723b73a2012-02-08 16:37:49 +010039extern char default_http_log_format[];
40extern char clf_http_log_format[];
41
William Lallemandbddd4fd2012-02-27 11:23:10 +010042
43/*
44 * send a log for the session when we have enough info about it.
45 * Will not log if the frontend has no log defined.
46 */
47void sess_log(struct session *s);
48
William Lallemand723b73a2012-02-08 16:37:49 +010049/*
50 * Parse args in a logformat_var
51 */
52int parse_logformat_var_args(char *args, struct logformat_node *node);
53
54/*
55 * Parse a variable '%varname' or '%{args}varname' in logformat
56 *
57 */
William Lallemand81f51172012-03-12 11:03:47 +010058int parse_logformat_var(char *str, size_t len, struct proxy *curproxy, int *options);
William Lallemand723b73a2012-02-08 16:37:49 +010059
60/*
61 * add to the logformat linked list
62 */
63void add_to_logformat_list(char *start, char *end, int type, struct proxy *curproxy);
64
65/*
66 * Parse the log_format string and fill a linked list.
67 * Variable name are preceded by % and composed by characters [a-zA-Z0-9]* : %varname
68 * You can set arguments using { } : %{many arguments}varname
69 */
70void parse_logformat_string(char *str, struct proxy *curproxy);
71
Willy Tarreaubaaee002006-06-26 02:48:02 +020072/*
73 * Displays the message on stderr with the date and pid. Overrides the quiet
74 * mode during startup.
75 */
Willy Tarreau40d25162009-04-03 12:01:47 +020076void Alert(const char *fmt, ...)
77 __attribute__ ((format(printf, 1, 2)));
Willy Tarreaubaaee002006-06-26 02:48:02 +020078
79/*
80 * Displays the message on stderr with the date and pid.
81 */
Willy Tarreau40d25162009-04-03 12:01:47 +020082void Warning(const char *fmt, ...)
83 __attribute__ ((format(printf, 1, 2)));
Willy Tarreaubaaee002006-06-26 02:48:02 +020084
85/*
86 * Displays the message on <out> only if quiet mode is not set.
87 */
Willy Tarreau40d25162009-04-03 12:01:47 +020088void qfprintf(FILE *out, const char *fmt, ...)
89 __attribute__ ((format(printf, 2, 3)));
Willy Tarreaubaaee002006-06-26 02:48:02 +020090
William Lallemand2a4a44f2012-02-06 16:00:33 +010091/*
92 * This function adds a header to the message and sends the syslog message
93 * using a printf format string
94 */
95void send_log(struct proxy *p, int level, const char *format, ...)
96 __attribute__ ((format(printf, 3, 4)));
97
Willy Tarreaubaaee002006-06-26 02:48:02 +020098/*
99 * This function sends a syslog message to both log servers of a proxy,
100 * or to global log servers if the proxy is NULL.
101 * It also tries not to waste too much time computing the message header.
102 * It doesn't care about errors nor does it report them.
103 */
Willy Tarreaubaaee002006-06-26 02:48:02 +0200104
William Lallemand2a4a44f2012-02-06 16:00:33 +0100105void __send_log(struct proxy *p, int level, char *message, size_t size);
Willy Tarreaubaaee002006-06-26 02:48:02 +0200106
107/*
108 * returns log level for <lev> or -1 if not found.
109 */
110int get_log_level(const char *lev);
111
112/*
113 * returns log facility for <fac> or -1 if not found.
114 */
115int get_log_facility(const char *fac);
116
William Lallemanda1cc3812012-02-08 16:38:44 +0100117/*
118 * Write a string in the log string
119 * Take cares of mandatory and quote options
120 *
121 * Return the adress of the \0 character, or NULL on error
122 */
123char *logformat_write_string(char *dst, char *src, size_t size, struct logformat_node *node);
124
Willy Tarreaubaaee002006-06-26 02:48:02 +0200125#endif /* _PROTO_LOG_H */
126
127/*
128 * Local variables:
129 * c-indent-level: 8
130 * c-basic-offset: 8
131 * End:
132 */