The FreeRADIUS server $Id: 15bac2a4c627c01d1aa2047687b3418955ac7f00 $
|
libfreeradius logging functions More...
#include <freeradius-devel/build.h>
#include <freeradius-devel/missing.h>
#include <freeradius-devel/util/event.h>
#include <freeradius-devel/util/fopencookie.h>
#include <freeradius-devel/util/table.h>
#include <freeradius-devel/util/talloc.h>
#include <stdbool.h>
#include <stdint.h>
#include <stdio.h>
#include <string.h>
Go to the source code of this file.
Data Structures | |
struct | fr_log_fd_event_ctx_t |
Context structure for the log fd event function. More... | |
struct | fr_log_perror_format_t |
struct | fr_log_s |
Typedefs | |
typedef struct fr_log_s | fr_log_t |
Enumerations | |
enum | fr_log_dst_t { L_DST_STDOUT = 0 , L_DST_FILES , L_DST_SYSLOG , L_DST_STDERR , L_DST_FUNC , L_DST_NULL , L_DST_NUM_DEST } |
enum | fr_log_lvl_t { L_DBG_LVL_DISABLE = -1 , L_DBG_LVL_OFF = 0 , L_DBG_LVL_1 , L_DBG_LVL_2 , L_DBG_LVL_3 , L_DBG_LVL_4 , L_DBG_LVL_MAX } |
enum | fr_log_timestamp_t { L_TIMESTAMP_AUTO = 0 , L_TIMESTAMP_ON , L_TIMESTAMP_OFF } |
enum | fr_log_type_t { L_INFO = 3 , L_ERR = 4 , L_WARN = 5 , L_AUTH = 6 , L_DBG = 16 , L_DBG_INFO = 17 , L_DBG_WARN = 18 , L_DBG_ERR = 19 , L_DBG_WARN_REQ = 20 , L_DBG_ERR_REQ = 21 } |
Functions | |
void | fr_canonicalize_error (TALLOC_CTX *ctx, char **spaces, char **text, ssize_t slen, char const *fmt) |
Canonicalize error strings, removing tabs, and generate spaces for error marker. | |
void | fr_log (fr_log_t const *log, fr_log_type_t lvl, char const *file, int line, char const *fmt,...)) |
Send a server log message to its destination. | |
int | fr_log_close (fr_log_t *log) |
Universal close function for all logging destinations. | |
void | fr_log_fd_event (UNUSED fr_event_list_t *el, int fd, UNUSED int flags, void *uctx) |
Function to provide as the readable callback to the event loop. | |
void | fr_log_global_free (void) |
Restores the original stdout and stderr FDs, closes the pipes and removes them from the event loop. | |
int | fr_log_global_init (fr_event_list_t *el, bool daemonize) |
Manipulate stderr and stdout so that was capture all data send to it from libraries. | |
void | fr_log_hex (fr_log_t const *log, fr_log_type_t type, char const *file, int line, uint8_t const *data, size_t data_len, char const *line_prefix_fmt,...)) |
Print out hex block. | |
void | fr_log_hex_marker (fr_log_t const *log, fr_log_type_t type, char const *file, int line, uint8_t const *data, size_t data_len, ssize_t marker_idx, char const *marker, char const *line_prefix_fmt,...)) |
Print out hex block. | |
int | fr_log_init_file (fr_log_t *log, char const *file) |
Initialise a file logging destination. | |
int | fr_log_init_fp (fr_log_t *log, FILE *fp) |
Initialise a file logging destination to a FILE*. | |
int | fr_log_init_func (fr_log_t *log, cookie_write_function_t write, cookie_close_function_t close, void *uctx)) |
Initialise a function based logging destination. | |
int | fr_log_init_legacy (fr_log_t *log, bool daemonize) |
Initialise file descriptors based on logging destination. | |
int | fr_log_init_std (fr_log_t *log, fr_log_dst_t dst_type) |
Initialise log dst for stdout, stderr or /dev/null. | |
int | fr_log_init_syslog (fr_log_t *log) |
Initialise a syslog logging destination. | |
void | fr_log_marker (fr_log_t const *log, fr_log_type_t type, char const *file, int line, char const *str, size_t str_len, ssize_t marker_idx, char const *marker, char const *line_prefix_fmt,...)) |
Print out an error marker. | |
void | fr_log_perror (fr_log_t const *log, fr_log_type_t type, char const *file, int line, fr_log_perror_format_t const *rules, char const *fmt,...)) |
Drain any outstanding messages from the fr_strerror buffers. | |
TALLOC_CTX * | fr_log_pool_init (void) |
talloc ctx to use when composing log messages | |
static bool | fr_rate_limit_enabled (void) |
Whether rate limiting is enabled. | |
void | fr_vlog (fr_log_t const *log, fr_log_type_t lvl, char const *file, int line, char const *fmt, va_list ap)) |
Send a server log message to its destination. | |
void | fr_vlog_perror (fr_log_t const *log, fr_log_type_t type, char const *file, int line, fr_log_perror_format_t const *rules, char const *fmt, va_list ap)) |
Drain any outstanding messages from the fr_strerror buffers. | |
Variables | |
fr_log_t | default_log |
int | fr_debug_lvl |
FILE * | fr_log_fp |
fr_table_num_ordered_t const | fr_log_levels [] |
Maps log categories to message prefixes. | |
size_t | fr_log_levels_len |
bool | fr_log_rate_limit |
Whether repeated log entries should be rate limited. | |
bool | log_dates_utc |
libfreeradius logging functions
Definition in file log.h.
struct fr_log_fd_event_ctx_t |
Context structure for the log fd event function.
This enables a file descriptor to be inserted into an event loop and produce log output. It's useful for execd child processes and for capturing stdout/stderr from libraries.
Data Fields | ||
---|---|---|
fr_log_t const * | dst | Where to log to. |
fr_log_lvl_t | lvl | Priority of the message. |
char const * | prefix | To add to log messages. |
fr_log_type_t | type | What type of log message it is. |
struct fr_log_perror_format_t |
enum fr_log_dst_t |
Enumerator | |
---|---|
L_DST_STDOUT | Log to stdout. |
L_DST_FILES | Log to a file on disk. |
L_DST_SYSLOG | Log to syslog. |
L_DST_STDERR | Log to stderr. |
L_DST_FUNC | Send log messages to a FILE*, via fopencookie() |
L_DST_NULL | Discard log messages. |
L_DST_NUM_DEST |
enum fr_log_lvl_t |
enum fr_log_timestamp_t |
enum fr_log_type_t |
void fr_canonicalize_error | ( | TALLOC_CTX * | ctx, |
char ** | sp, | ||
char ** | text, | ||
ssize_t | slen, | ||
char const * | fmt | ||
) |
Canonicalize error strings, removing tabs, and generate spaces for error marker.
Used to produce error messages such as this:
I'm a string with a parser # error ^ Unexpected character in string
With code resembling this:
sp | Where to write a dynamically allocated buffer of spaces used to indent the error text. |
text | Where to write the canonicalized version of fmt (the error text). |
ctx | to allocate the spaces and text buffers in. |
slen | of error marker. Expects negative integer value, as returned by parse functions. |
fmt | to canonicalize. |
Definition at line 90 of file log.c.
void fr_log | ( | fr_log_t const * | log, |
fr_log_type_t | type, | ||
char const * | file, | ||
int | line, | ||
char const * | fmt, | ||
... | |||
) |
Send a server log message to its destination.
log | destination. |
type | of log message. |
file | where the log message originated |
line | where the log message originated |
fmt | with printf style substitution tokens. |
... | Substitution arguments. |
Definition at line 583 of file log.c.
int fr_log_close | ( | fr_log_t * | log | ) |
void fr_log_fd_event | ( | UNUSED fr_event_list_t * | el, |
int | fd, | ||
UNUSED int | flags, | ||
void * | uctx | ||
) |
Function to provide as the readable callback to the event loop.
Writes any data read from a file descriptor to the request log, tries very hard not to chop lines in the middle, but will split at 1024 byte boundaries if forced to.
[in] | el | UNUSED |
[in] | fd | UNUSED |
[in] | flags | UNUSED |
[in] | uctx | Pointer to a log_fd_event_ctx_t |
Definition at line 179 of file log.c.
void fr_log_global_free | ( | void | ) |
int fr_log_global_init | ( | fr_event_list_t * | el, |
bool | daemonize | ||
) |
Manipulate stderr and stdout so that was capture all data send to it from libraries.
[in] | el | The event list we use to process logging data. |
[in] | daemonize | Whether the server is starting as a daemon. |
Definition at line 1225 of file log.c.
void fr_log_hex | ( | fr_log_t const * | log, |
fr_log_type_t | type, | ||
char const * | file, | ||
int | line, | ||
uint8_t const * | data, | ||
size_t | data_len, | ||
char const * | line_prefix_fmt, | ||
... | |||
) |
Print out hex block.
[in] | log | destination. |
[in] | type | of log message. |
[in] | file | src file the log message was generated in. |
[in] | line | number the log message was generated on. |
[in] | data | to print. |
[in] | data_len | length of data. |
[in] | line_prefix_fmt | Prefix to add to the marker messages. |
[in] | ... | Arguments for line_prefix_fmt. |
Definition at line 784 of file log.c.
void fr_log_hex_marker | ( | fr_log_t const * | log, |
fr_log_type_t | type, | ||
char const * | file, | ||
int | line, | ||
uint8_t const * | data, | ||
size_t | data_len, | ||
ssize_t | marker_idx, | ||
char const * | marker, | ||
char const * | line_prefix_fmt, | ||
... | |||
) |
Print out hex block.
[in] | log | destination. |
[in] | type | of log message. |
[in] | file | src file the log message was generated in. |
[in] | line | number the log message was generated on. |
[in] | data | to print. |
[in] | data_len | length of data. |
[in] | marker_idx | Where to place the marker. May be negative. |
[in] | marker | text to print at marker_idx. |
[in] | line_prefix_fmt | Prefix to add to the marker messages. |
[in] | ... | Arguments for line_prefix_fmt. |
Definition at line 831 of file log.c.
int fr_log_init_file | ( | fr_log_t * | log, |
char const * | file | ||
) |
int fr_log_init_fp | ( | fr_log_t * | log, |
FILE * | fp | ||
) |
int fr_log_init_func | ( | fr_log_t * | log, |
cookie_write_function_t | write, | ||
cookie_close_function_t | close, | ||
void * | uctx | ||
) |
Initialise a function based logging destination.
[out] | log | Destination to initialise. |
[in] | write | Called when a complete log line is ready for writing. |
[in] | close | May be NULL. Called when the logging destination has been closed. |
[in] | uctx | for the write and close functions. |
Definition at line 1165 of file log.c.
Initialise file descriptors based on logging destination.
log | Logger to manipulate. |
daemonize | Whether the server is starting as a daemon. |
Definition at line 907 of file log.c.
int fr_log_init_std | ( | fr_log_t * | log, |
fr_log_dst_t | dst_type | ||
) |
int fr_log_init_syslog | ( | fr_log_t * | log | ) |
void fr_log_marker | ( | fr_log_t const * | log, |
fr_log_type_t | type, | ||
char const * | file, | ||
int | line, | ||
char const * | str, | ||
size_t | str_len, | ||
ssize_t | marker_idx, | ||
char const * | marker, | ||
char const * | line_prefix_fmt, | ||
... | |||
) |
Print out an error marker.
[in] | log | destination. |
[in] | type | of log message. |
[in] | file | src file the log message was generated in. |
[in] | line | number the log message was generated on. |
[in] | str | Subject string we're printing a marker for. |
[in] | str_len | Subject string length. Use SIZE_MAX for the length of the string. |
[in] | marker_idx | Where to place the marker. May be negative. |
[in] | marker | text to print at marker_idx. |
[in] | line_prefix_fmt | Prefix to add to the marker messages. |
[in] | ... | Arguments for line_prefix_fmt. |
Definition at line 734 of file log.c.
void fr_log_perror | ( | fr_log_t const * | log, |
fr_log_type_t | type, | ||
char const * | file, | ||
int | line, | ||
fr_log_perror_format_t const * | rules, | ||
char const * | fmt, | ||
... | |||
) |
Drain any outstanding messages from the fr_strerror buffers.
This function drains any messages from fr_strerror buffer adding a prefix (fmt) to the first message.
[in] | log | destination. |
[in] | type | of log message. |
[in] | file | src file the log message was generated in. |
[in] | line | number the log message was generated on. |
[in] | rules | for printing multiline errors. |
[in] | fmt | with printf style substitution tokens. |
[in] | ... | Substitution arguments. |
Definition at line 709 of file log.c.
TALLOC_CTX * fr_log_pool_init | ( | void | ) |
talloc ctx to use when composing log messages
Functions must ensure that they allocate a new ctx from the one returned here, and that this ctx is freed before the function returns.
Definition at line 316 of file log.c.
|
inlinestatic |
void fr_vlog | ( | fr_log_t const * | log, |
fr_log_type_t | type, | ||
char const * | file, | ||
int | line, | ||
char const * | fmt, | ||
va_list | ap | ||
) |
Send a server log message to its destination.
[in] | log | destination. |
[in] | type | of log message. |
[in] | file | src file the log message was generated in. |
[in] | line | number the log message was generated on. |
[in] | fmt | with printf style substitution tokens. |
[in] | ap | Substitution arguments. |
Definition at line 344 of file log.c.
void fr_vlog_perror | ( | fr_log_t const * | log, |
fr_log_type_t | type, | ||
char const * | file, | ||
int | line, | ||
fr_log_perror_format_t const * | f_rules, | ||
char const * | fmt, | ||
va_list | ap | ||
) |
Drain any outstanding messages from the fr_strerror buffers.
This function drains any messages from fr_strerror buffer prefixing the first message with fmt + args.
If a prefix is specified in rules, this is prepended to all lines logged. The prefix is useful for adding context, i.e. configuration file and line number information.
[in] | log | destination. |
[in] | type | of log message. |
[in] | file | src file the log message was generated in. |
[in] | line | number the log message was generated on. |
[in] | f_rules | for printing multiline errors. |
[in] | fmt | with printf style substitution tokens. |
[in] | ap | Substitution arguments. |
Definition at line 614 of file log.c.
|
extern |
|
extern |