xref: /dragonfly/usr.sbin/autofs/log.c (revision 63bc4984)
1e2950f41STomohiro Kusumi /*-
2*63bc4984STomohiro Kusumi  * SPDX-License-Identifier: BSD-2-Clause-FreeBSD
3*63bc4984STomohiro Kusumi  *
4e2950f41STomohiro Kusumi  * Copyright (c) 2016 The DragonFly Project
5e2950f41STomohiro Kusumi  * Copyright (c) 2012 The FreeBSD Foundation
6e2950f41STomohiro Kusumi  * All rights reserved.
7e2950f41STomohiro Kusumi  *
8e2950f41STomohiro Kusumi  * This software was developed by Edward Tomasz Napierala under sponsorship
9e2950f41STomohiro Kusumi  * from the FreeBSD Foundation.
10e2950f41STomohiro Kusumi  *
11e2950f41STomohiro Kusumi  * Redistribution and use in source and binary forms, with or without
12e2950f41STomohiro Kusumi  * modification, are permitted provided that the following conditions
13e2950f41STomohiro Kusumi  * are met:
14e2950f41STomohiro Kusumi  * 1. Redistributions of source code must retain the above copyright
15e2950f41STomohiro Kusumi  *    notice, this list of conditions and the following disclaimer.
16e2950f41STomohiro Kusumi  * 2. Redistributions in binary form must reproduce the above copyright
17e2950f41STomohiro Kusumi  *    notice, this list of conditions and the following disclaimer in the
18e2950f41STomohiro Kusumi  *    documentation and/or other materials provided with the distribution.
19e2950f41STomohiro Kusumi  *
20e2950f41STomohiro Kusumi  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
21e2950f41STomohiro Kusumi  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
22e2950f41STomohiro Kusumi  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
23e2950f41STomohiro Kusumi  * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
24e2950f41STomohiro Kusumi  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
25e2950f41STomohiro Kusumi  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
26e2950f41STomohiro Kusumi  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
27e2950f41STomohiro Kusumi  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
28e2950f41STomohiro Kusumi  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
29e2950f41STomohiro Kusumi  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
30e2950f41STomohiro Kusumi  * SUCH DAMAGE.
31e2950f41STomohiro Kusumi  *
32e2950f41STomohiro Kusumi  */
33e2950f41STomohiro Kusumi 
34e2950f41STomohiro Kusumi #include <errno.h>
35e2950f41STomohiro Kusumi #include <stdarg.h>
36e2950f41STomohiro Kusumi #include <stdio.h>
37e2950f41STomohiro Kusumi #include <stdlib.h>
38e2950f41STomohiro Kusumi #include <string.h>
39e2950f41STomohiro Kusumi #include <syslog.h>
40e2950f41STomohiro Kusumi #include <vis.h>
41e2950f41STomohiro Kusumi 
42e2950f41STomohiro Kusumi #include "common.h"
43e2950f41STomohiro Kusumi 
44e2950f41STomohiro Kusumi static int log_level = 0;
45e2950f41STomohiro Kusumi static char *peer_name = NULL;
46e2950f41STomohiro Kusumi static char *peer_addr = NULL;
47e2950f41STomohiro Kusumi 
48e2950f41STomohiro Kusumi #define	MSGBUF_LEN	1024
49e2950f41STomohiro Kusumi 
50e2950f41STomohiro Kusumi void
log_init(int level)51e2950f41STomohiro Kusumi log_init(int level)
52e2950f41STomohiro Kusumi {
53e2950f41STomohiro Kusumi 
54e2950f41STomohiro Kusumi 	log_level = level;
55e2950f41STomohiro Kusumi 	openlog(getprogname(), LOG_NDELAY | LOG_PID, LOG_DAEMON);
56e2950f41STomohiro Kusumi }
57e2950f41STomohiro Kusumi 
58e2950f41STomohiro Kusumi void
log_set_peer_name(const char * name)59e2950f41STomohiro Kusumi log_set_peer_name(const char *name)
60e2950f41STomohiro Kusumi {
61e2950f41STomohiro Kusumi 
62e2950f41STomohiro Kusumi 	/*
63e2950f41STomohiro Kusumi 	 * XXX: Turn it into assertion?
64e2950f41STomohiro Kusumi 	 */
65e2950f41STomohiro Kusumi 	if (peer_name != NULL)
66e2950f41STomohiro Kusumi 		log_errx(1, "%s called twice", __func__);
67e2950f41STomohiro Kusumi 	if (peer_addr == NULL)
68e2950f41STomohiro Kusumi 		log_errx(1, "%s called before log_set_peer_addr", __func__);
69e2950f41STomohiro Kusumi 
70e2950f41STomohiro Kusumi 	peer_name = checked_strdup(name);
71e2950f41STomohiro Kusumi }
72e2950f41STomohiro Kusumi 
73e2950f41STomohiro Kusumi void
log_set_peer_addr(const char * addr)74e2950f41STomohiro Kusumi log_set_peer_addr(const char *addr)
75e2950f41STomohiro Kusumi {
76e2950f41STomohiro Kusumi 
77e2950f41STomohiro Kusumi 	/*
78e2950f41STomohiro Kusumi 	 * XXX: Turn it into assertion?
79e2950f41STomohiro Kusumi 	 */
80e2950f41STomohiro Kusumi 	if (peer_addr != NULL)
81e2950f41STomohiro Kusumi 		log_errx(1, "%s called twice", __func__);
82e2950f41STomohiro Kusumi 
83e2950f41STomohiro Kusumi 	peer_addr = checked_strdup(addr);
84e2950f41STomohiro Kusumi }
85e2950f41STomohiro Kusumi 
86e2950f41STomohiro Kusumi static void
log_common(int priority,int log_errno,const char * fmt,va_list ap)87e2950f41STomohiro Kusumi log_common(int priority, int log_errno, const char *fmt, va_list ap)
88e2950f41STomohiro Kusumi {
89e2950f41STomohiro Kusumi 	static char msgbuf[MSGBUF_LEN];
90e2950f41STomohiro Kusumi 	static char msgbuf_strvised[MSGBUF_LEN * 4 + 1];
91e2950f41STomohiro Kusumi 	char *errstr;
92e2950f41STomohiro Kusumi 	int ret;
93e2950f41STomohiro Kusumi 
94e2950f41STomohiro Kusumi 	ret = vsnprintf(msgbuf, sizeof(msgbuf), fmt, ap);
95e2950f41STomohiro Kusumi 	if (ret < 0) {
96e2950f41STomohiro Kusumi 		fprintf(stderr, "%s: snprintf failed", getprogname());
97e2950f41STomohiro Kusumi 		syslog(LOG_CRIT, "snprintf failed");
98e2950f41STomohiro Kusumi 		exit(1);
99e2950f41STomohiro Kusumi 	}
100e2950f41STomohiro Kusumi 
101e2950f41STomohiro Kusumi 	ret = strnvis(msgbuf_strvised, msgbuf, sizeof(msgbuf_strvised), VIS_NL);
102e2950f41STomohiro Kusumi 	if (ret < 0) {
103e2950f41STomohiro Kusumi 		fprintf(stderr, "%s: strnvis failed", getprogname());
104e2950f41STomohiro Kusumi 		syslog(LOG_CRIT, "strnvis failed");
105e2950f41STomohiro Kusumi 		exit(1);
106e2950f41STomohiro Kusumi 	}
107e2950f41STomohiro Kusumi 
108e2950f41STomohiro Kusumi 	if (log_errno == -1) {
109e2950f41STomohiro Kusumi 		if (peer_name != NULL) {
110e2950f41STomohiro Kusumi 			fprintf(stderr, "%s: %s (%s): %s\n", getprogname(),
111e2950f41STomohiro Kusumi 			    peer_addr, peer_name, msgbuf_strvised);
112e2950f41STomohiro Kusumi 			syslog(priority, "%s (%s): %s",
113e2950f41STomohiro Kusumi 			    peer_addr, peer_name, msgbuf_strvised);
114e2950f41STomohiro Kusumi 		} else if (peer_addr != NULL) {
115e2950f41STomohiro Kusumi 			fprintf(stderr, "%s: %s: %s\n", getprogname(),
116e2950f41STomohiro Kusumi 			    peer_addr, msgbuf_strvised);
117e2950f41STomohiro Kusumi 			syslog(priority, "%s: %s",
118e2950f41STomohiro Kusumi 			    peer_addr, msgbuf_strvised);
119e2950f41STomohiro Kusumi 		} else {
120e2950f41STomohiro Kusumi 			fprintf(stderr, "%s: %s\n", getprogname(), msgbuf_strvised);
121e2950f41STomohiro Kusumi 			syslog(priority, "%s", msgbuf_strvised);
122e2950f41STomohiro Kusumi 		}
123e2950f41STomohiro Kusumi 
124e2950f41STomohiro Kusumi 	} else {
125e2950f41STomohiro Kusumi 		errstr = strerror(log_errno);
126e2950f41STomohiro Kusumi 
127e2950f41STomohiro Kusumi 		if (peer_name != NULL) {
128e2950f41STomohiro Kusumi 			fprintf(stderr, "%s: %s (%s): %s: %s\n", getprogname(),
129e2950f41STomohiro Kusumi 			    peer_addr, peer_name, msgbuf_strvised, errstr);
130e2950f41STomohiro Kusumi 			syslog(priority, "%s (%s): %s: %s",
131e2950f41STomohiro Kusumi 			    peer_addr, peer_name, msgbuf_strvised, errstr);
132e2950f41STomohiro Kusumi 		} else if (peer_addr != NULL) {
133e2950f41STomohiro Kusumi 			fprintf(stderr, "%s: %s: %s: %s\n", getprogname(),
134e2950f41STomohiro Kusumi 			    peer_addr, msgbuf_strvised, errstr);
135e2950f41STomohiro Kusumi 			syslog(priority, "%s: %s: %s",
136e2950f41STomohiro Kusumi 			    peer_addr, msgbuf_strvised, errstr);
137e2950f41STomohiro Kusumi 		} else {
138e2950f41STomohiro Kusumi 			fprintf(stderr, "%s: %s: %s\n", getprogname(),
139e2950f41STomohiro Kusumi 			    msgbuf_strvised, errstr);
140e2950f41STomohiro Kusumi 			syslog(priority, "%s: %s",
141e2950f41STomohiro Kusumi 			    msgbuf_strvised, errstr);
142e2950f41STomohiro Kusumi 		}
143e2950f41STomohiro Kusumi 	}
144e2950f41STomohiro Kusumi }
145e2950f41STomohiro Kusumi 
146e2950f41STomohiro Kusumi void
log_err(int eval,const char * fmt,...)147e2950f41STomohiro Kusumi log_err(int eval, const char *fmt, ...)
148e2950f41STomohiro Kusumi {
149e2950f41STomohiro Kusumi 	va_list ap;
150e2950f41STomohiro Kusumi 
151e2950f41STomohiro Kusumi 	va_start(ap, fmt);
152e2950f41STomohiro Kusumi 	log_common(LOG_CRIT, errno, fmt, ap);
153e2950f41STomohiro Kusumi 	va_end(ap);
154e2950f41STomohiro Kusumi 
155e2950f41STomohiro Kusumi 	exit(eval);
156e2950f41STomohiro Kusumi }
157e2950f41STomohiro Kusumi 
158e2950f41STomohiro Kusumi void
log_errx(int eval,const char * fmt,...)159e2950f41STomohiro Kusumi log_errx(int eval, const char *fmt, ...)
160e2950f41STomohiro Kusumi {
161e2950f41STomohiro Kusumi 	va_list ap;
162e2950f41STomohiro Kusumi 
163e2950f41STomohiro Kusumi 	va_start(ap, fmt);
164e2950f41STomohiro Kusumi 	log_common(LOG_CRIT, -1, fmt, ap);
165e2950f41STomohiro Kusumi 	va_end(ap);
166e2950f41STomohiro Kusumi 
167e2950f41STomohiro Kusumi 	exit(eval);
168e2950f41STomohiro Kusumi }
169e2950f41STomohiro Kusumi 
170e2950f41STomohiro Kusumi void
log_warn(const char * fmt,...)171e2950f41STomohiro Kusumi log_warn(const char *fmt, ...)
172e2950f41STomohiro Kusumi {
173e2950f41STomohiro Kusumi 	va_list ap;
174e2950f41STomohiro Kusumi 
175e2950f41STomohiro Kusumi 	va_start(ap, fmt);
176e2950f41STomohiro Kusumi 	log_common(LOG_WARNING, errno, fmt, ap);
177e2950f41STomohiro Kusumi 	va_end(ap);
178e2950f41STomohiro Kusumi }
179e2950f41STomohiro Kusumi 
180e2950f41STomohiro Kusumi void
log_warnx(const char * fmt,...)181e2950f41STomohiro Kusumi log_warnx(const char *fmt, ...)
182e2950f41STomohiro Kusumi {
183e2950f41STomohiro Kusumi 	va_list ap;
184e2950f41STomohiro Kusumi 
185e2950f41STomohiro Kusumi 	va_start(ap, fmt);
186e2950f41STomohiro Kusumi 	log_common(LOG_WARNING, -1, fmt, ap);
187e2950f41STomohiro Kusumi 	va_end(ap);
188e2950f41STomohiro Kusumi }
189e2950f41STomohiro Kusumi 
190e2950f41STomohiro Kusumi void
log_debugx(const char * fmt,...)191e2950f41STomohiro Kusumi log_debugx(const char *fmt, ...)
192e2950f41STomohiro Kusumi {
193e2950f41STomohiro Kusumi 	va_list ap;
194e2950f41STomohiro Kusumi 
195e2950f41STomohiro Kusumi 	if (log_level == 0)
196e2950f41STomohiro Kusumi 		return;
197e2950f41STomohiro Kusumi 
198e2950f41STomohiro Kusumi 	va_start(ap, fmt);
199e2950f41STomohiro Kusumi 	log_common(LOG_DEBUG, -1, fmt, ap);
200e2950f41STomohiro Kusumi 	va_end(ap);
201e2950f41STomohiro Kusumi }
202