summaryrefslogtreecommitdiffstats
path: root/include/clplumbing/cl_log.h
blob: aa30fcd672aabee1b8516340fb0ce71ddc51318c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
/*
 * This library is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2.1 of the License, or (at your option) any later version.
 * 
 * This library is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * Lesser General Public License for more details.
 * 
 * You should have received a copy of the GNU Lesser General Public
 * License along with this library; if not, write to the Free Software
 * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA
 */

#ifndef _CLPLUMBING_CL_LOG_H
#	define _CLPLUMBING_CL_LOG_H
#	include <glib.h>
#	include <syslog.h>

#define TIME_T  unsigned long
#define	HA_FAIL		0
#define	HA_OK		1
#define	MAXLINE		(512*10)

/* this is defined by the caller */
struct logspam {
	const char *id; /* identifier */
	int max; /* maximum number of messages ... */
	time_t window; /* ... within this timeframe */
	time_t reset_time; /* log new messages after this time */
	const char *advice; /* what to log in case messages get suppressed */
};

/* this is internal (oblique to the caller) */
struct msg_ctrl {
	struct logspam *lspam; /*  */
	time_t *msg_slots; /* msg slot root (space for lspam->max) */
	int last; /* last used msg slot [0..lspam->max-1]; -1 on init */
	int cnt; /* current msg count [0..lspam->max] */
	time_t suppress_t; /* messages blocked since this time */
};

struct IPC_CHANNEL;

extern int		debug_level;
#define	ANYDEBUG	(debug_level)
#define	DEBUGDETAILS	(debug_level >= 2)
#define	DEBUGAUTH	(debug_level >=3)
#define	DEBUGMODULE	(debug_level >=3)
#define	DEBUGPKT	(debug_level >= 4)
#define	DEBUGPKTCONT	(debug_level >= 5)

void		cl_direct_log(int priority, const char* buf, gboolean, const char*, int, TIME_T);
void            cl_log(int priority, const char * fmt, ...) G_GNUC_PRINTF(2,3);
void            cl_limit_log(struct msg_ctrl *ml, int priority, const char * fmt, ...) G_GNUC_PRINTF(3,4);
struct msg_ctrl *cl_limit_log_new(struct logspam *lspam);
void            cl_limit_log_destroy(struct msg_ctrl *ml);
void            cl_limit_log_reset(struct msg_ctrl *ml);
void            cl_perror(const char * fmt, ...) G_GNUC_PRINTF(1,2);
void		cl_log_enable_stderr(int truefalse);
void		cl_log_enable_stdout(int truefalse);
gboolean	cl_log_test_logd(void);
void		cl_log_set_uselogd(int truefalse);
void		cl_log_enable_syslog_filefmt(int truefalse);
void		cl_log_use_buffered_io(int truefalse);
gboolean	cl_log_get_uselogd(void);
void		cl_log_set_facility(int facility);
void		cl_log_set_entity(const char *	entity);
void		cl_log_set_syslogprefix(const char *prefix);
void		cl_log_set_logfile(const char *	path);
void		cl_log_set_debugfile(const char * path);
void		cl_inherit_logging_environment(int maxqlen);
int		cl_log_set_logd_channel_source( void (*create_callback)(struct IPC_CHANNEL* chan),
						GDestroyNotify destroy_callback);
int		cl_log_get_logdtime(void);
void		cl_log_set_logdtime(int logdintval);

char *		ha_timestamp(TIME_T t);
void		cl_glib_msg_handler(const gchar *log_domain
,		GLogLevelFlags log_level, const gchar *message
,		gpointer user_data);

void		cl_flush_logs(void);
void		cl_log_args(int argc, char **argv);
int		cl_log_is_logd_fd(int fd);
const char *	prio2str(int priority);

/* cl_log_use_buffered_io and cl_log_do_fflush as optimization for logd,
 * so it may buffer a few message lines, then fflush them out in one write.
 * Set do_fsync != 0, if you even want it to fsync. */
void            cl_log_do_fflush(int do_fsync);
void            cl_log_use_buffered_io(int truefalse);
/* We now keep the file handles open for a potentially very long time.
 * Sometimes we may need to close them explicitly. */
void            cl_log_close_log_files(void);

#endif