2 * Copyright (c) 2021, 2023 Omar Polo <op@omarpolo.com>
4 * Permission to use, copy, modify, and distribute this software for any
5 * purpose with or without fee is hereby granted, provided that the above
6 * copyright notice and this permission notice appear in all copies.
8 * THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
9 * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
10 * MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
11 * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
12 * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
13 * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
14 * OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
19 #include <sys/types.h>
37 #define nitems(_a) (sizeof((_a)) / sizeof((_a)[0]))
40 static int logfd = -1;
41 static int log_to_syslog = 1;
43 static void logger_init(struct privsep *, struct privsep_proc *, void *);
44 static void logger_shutdown(void);
45 static int logger_dispatch_parent(int, struct privsep_proc *, struct imsg *);
46 static int logger_dispatch_server(int, struct privsep_proc *, struct imsg *);
48 static struct privsep_proc procs[] = {
49 { "parent", PROC_PARENT, logger_dispatch_parent },
50 { "server", PROC_SERVER, logger_dispatch_server },
54 logger(struct privsep *ps, struct privsep_proc *p)
56 proc_run(ps, p, procs, nitems(procs), logger_init, NULL);
60 logger_init(struct privsep *ps, struct privsep_proc *p, void *arg)
62 p->p_shutdown = logger_shutdown;
63 sandbox_logger_process();
75 logger_dispatch_parent(int fd, struct privsep_proc *p, struct imsg *imsg)
77 switch (imsg->hdr.type) {
79 if (IMSG_DATA_SIZE(imsg) != sizeof(log_to_syslog))
80 fatal("corrupted IMSG_LOG_SYSLOG");
81 memcpy(&log_to_syslog, imsg->data, sizeof(log_to_syslog));
99 logger_dispatch_server(int fd, struct privsep_proc *p, struct imsg *imsg)
104 switch (imsg->hdr.type) {
105 case IMSG_LOG_REQUEST:
107 datalen = IMSG_DATA_SIZE(imsg);
109 fatal("got invalid IMSG_LOG_REQUEST");
110 msg[datalen - 1] = '\0';
112 dprintf(logfd, "%s\n", msg);
114 syslog(LOG_DAEMON | LOG_NOTICE, "%s", msg);