1 e9864467 2021-08-08 xhr /* $OpenBSD: log.c,v 1.1 2018/07/10 16:39:54 florian Exp $ */
4 edc334c2 2021-08-05 xhr * Copyright (c) 2003, 2004 Henning Brauer <henning@openbsd.org>
6 edc334c2 2021-08-05 xhr * Permission to use, copy, modify, and distribute this software for any
7 edc334c2 2021-08-05 xhr * purpose with or without fee is hereby granted, provided that the above
8 edc334c2 2021-08-05 xhr * copyright notice and this permission notice appear in all copies.
10 edc334c2 2021-08-05 xhr * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
11 edc334c2 2021-08-05 xhr * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
12 edc334c2 2021-08-05 xhr * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
13 edc334c2 2021-08-05 xhr * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
14 edc334c2 2021-08-05 xhr * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
15 edc334c2 2021-08-05 xhr * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
16 edc334c2 2021-08-05 xhr * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
19 fb797bf6 2021-08-06 xhr #define _GNU_SOURCE
21 edc334c2 2021-08-05 xhr #include <stdio.h>
22 edc334c2 2021-08-05 xhr #include <stdlib.h>
23 edc334c2 2021-08-05 xhr #include <stdarg.h>
24 edc334c2 2021-08-05 xhr #include <string.h>
25 edc334c2 2021-08-05 xhr #include <syslog.h>
26 edc334c2 2021-08-05 xhr #include <errno.h>
27 edc334c2 2021-08-05 xhr #include <time.h>
29 edc334c2 2021-08-05 xhr #include "log.h"
31 edc334c2 2021-08-05 xhr static int debug;
32 edc334c2 2021-08-05 xhr static int verbose;
33 edc334c2 2021-08-05 xhr static const char *log_procname;
36 e9864467 2021-08-08 xhr log_init(int n_debug, int facility)
38 edc334c2 2021-08-05 xhr extern char *__progname;
40 edc334c2 2021-08-05 xhr debug = n_debug;
41 edc334c2 2021-08-05 xhr verbose = n_debug;
42 edc334c2 2021-08-05 xhr log_procinit(__progname);
45 edc334c2 2021-08-05 xhr openlog(__progname, LOG_PID | LOG_NDELAY, facility);
51 edc334c2 2021-08-05 xhr log_procinit(const char *procname)
53 edc334c2 2021-08-05 xhr if (procname != NULL)
54 edc334c2 2021-08-05 xhr log_procname = procname;
58 edc334c2 2021-08-05 xhr log_setverbose(int v)
64 edc334c2 2021-08-05 xhr log_getverbose(void)
66 edc334c2 2021-08-05 xhr return (verbose);
70 edc334c2 2021-08-05 xhr logit(int pri, const char *fmt, ...)
74 edc334c2 2021-08-05 xhr va_start(ap, fmt);
75 edc334c2 2021-08-05 xhr vlog(pri, fmt, ap);
80 edc334c2 2021-08-05 xhr vlog(int pri, const char *fmt, va_list ap)
83 edc334c2 2021-08-05 xhr int saved_errno = errno;
86 edc334c2 2021-08-05 xhr /* best effort in out of mem situations */
87 edc334c2 2021-08-05 xhr if (asprintf(&nfmt, "%s\n", fmt) == -1) {
88 edc334c2 2021-08-05 xhr vfprintf(stderr, fmt, ap);
89 edc334c2 2021-08-05 xhr fprintf(stderr, "\n");
91 edc334c2 2021-08-05 xhr vfprintf(stderr, nfmt, ap);
94 edc334c2 2021-08-05 xhr fflush(stderr);
96 edc334c2 2021-08-05 xhr vsyslog(pri, fmt, ap);
98 edc334c2 2021-08-05 xhr errno = saved_errno;
102 e9864467 2021-08-08 xhr log_warn(const char *emsg, ...)
106 edc334c2 2021-08-05 xhr int saved_errno = errno;
108 edc334c2 2021-08-05 xhr /* best effort to even work in out of memory situations */
109 edc334c2 2021-08-05 xhr if (emsg == NULL)
110 edc334c2 2021-08-05 xhr logit(LOG_ERR, "%s", strerror(saved_errno));
112 edc334c2 2021-08-05 xhr va_start(ap, emsg);
114 edc334c2 2021-08-05 xhr if (asprintf(&nfmt, "%s: %s", emsg,
115 edc334c2 2021-08-05 xhr strerror(saved_errno)) == -1) {
116 edc334c2 2021-08-05 xhr /* we tried it... */
117 edc334c2 2021-08-05 xhr vlog(LOG_ERR, emsg, ap);
118 edc334c2 2021-08-05 xhr logit(LOG_ERR, "%s", strerror(saved_errno));
120 edc334c2 2021-08-05 xhr vlog(LOG_ERR, nfmt, ap);
126 edc334c2 2021-08-05 xhr errno = saved_errno;
130 edc334c2 2021-08-05 xhr log_warnx(const char *emsg, ...)
134 edc334c2 2021-08-05 xhr va_start(ap, emsg);
135 edc334c2 2021-08-05 xhr vlog(LOG_ERR, emsg, ap);
140 e9864467 2021-08-08 xhr log_info(const char *emsg, ...)
144 edc334c2 2021-08-05 xhr va_start(ap, emsg);
145 edc334c2 2021-08-05 xhr vlog(LOG_INFO, emsg, ap);
150 edc334c2 2021-08-05 xhr log_debug(const char *emsg, ...)
154 edc334c2 2021-08-05 xhr if (verbose) {
155 edc334c2 2021-08-05 xhr va_start(ap, emsg);
156 edc334c2 2021-08-05 xhr vlog(LOG_DEBUG, emsg, ap);
162 edc334c2 2021-08-05 xhr vfatalc(int code, const char *emsg, va_list ap)
164 edc334c2 2021-08-05 xhr static char s[BUFSIZ];
165 edc334c2 2021-08-05 xhr const char *sep;
167 edc334c2 2021-08-05 xhr if (emsg != NULL) {
168 edc334c2 2021-08-05 xhr (void)vsnprintf(s, sizeof(s), emsg, ap);
171 edc334c2 2021-08-05 xhr s[0] = '\0';
175 edc334c2 2021-08-05 xhr logit(LOG_CRIT, "fatal in %s: %s%s%s",
176 edc334c2 2021-08-05 xhr log_procname, s, sep, strerror(code));
178 edc334c2 2021-08-05 xhr logit(LOG_CRIT, "fatal in %s%s%s", log_procname, sep, s);
182 edc334c2 2021-08-05 xhr fatal(const char *emsg, ...)
186 edc334c2 2021-08-05 xhr va_start(ap, emsg);
187 edc334c2 2021-08-05 xhr vfatalc(errno, emsg, ap);
193 edc334c2 2021-08-05 xhr fatalx(const char *emsg, ...)
197 edc334c2 2021-08-05 xhr va_start(ap, emsg);
198 edc334c2 2021-08-05 xhr vfatalc(0, emsg, ap);