don't whine if all we need to do is remove a bg job
[oweals/busybox.git] / logger.c
1 /* vi: set sw=4 ts=4: */
2 /*
3  * Mini logger implementation for busybox
4  *
5  * Copyright (C) 1999,2000,2001 by Lineo, inc.
6  * Written by Erik Andersen <andersen@lineo.com>, <andersee@debian.org>
7  *
8  * This program is free software; you can redistribute it and/or modify
9  * it under the terms of the GNU General Public License as published by
10  * the Free Software Foundation; either version 2 of the License, or
11  * (at your option) any later version.
12  *
13  * This program is distributed in the hope that it will be useful,
14  * but WITHOUT ANY WARRANTY; without even the implied warranty of
15  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16  * General Public License for more details.
17  *
18  * You should have received a copy of the GNU General Public License
19  * along with this program; if not, write to the Free Software
20  * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
21  *
22  */
23
24 #include <stdio.h>
25 #include <unistd.h>
26 #include <sys/types.h>
27 #include <fcntl.h>
28 #include <ctype.h>
29 #include <string.h>
30 #include <stdlib.h>
31
32 #include "busybox.h"
33 #if !defined BB_SYSLOGD
34
35 #define SYSLOG_NAMES
36 #include <sys/syslog.h>
37
38 #else
39 /* We have to do this since the header file defines static
40  * structures.  Argh.... bad libc, bad, bad...
41  */
42 #include <sys/syslog.h>
43
44 typedef struct _code {
45         char *c_name;
46         int c_val;
47 } CODE;
48 extern CODE prioritynames[];
49 extern CODE facilitynames[];
50 #endif
51
52 /* Decode a symbolic name to a numeric value 
53  * this function is based on code
54  * Copyright (c) 1983, 1993
55  * The Regents of the University of California.  All rights reserved.
56  *  
57  * Original copyright notice is retained at the end of this file.
58  */
59 static int decode(char *name, CODE * codetab)
60 {
61         CODE *c;
62
63         if (isdigit(*name))
64                 return (atoi(name));
65         for (c = codetab; c->c_name; c++) {
66                 if (!strcasecmp(name, c->c_name)) {
67                         return (c->c_val);
68                 }
69         }
70
71         return (-1);
72 }
73
74 /* Decode a symbolic name to a numeric value 
75  * this function is based on code
76  * Copyright (c) 1983, 1993
77  * The Regents of the University of California.  All rights reserved.
78  *
79  * Original copyright notice is retained at the end of this file.
80  */
81 static int pencode(char *s)
82 {
83         char *save;
84         int lev, fac = LOG_USER;
85
86         for (save = s; *s && *s != '.'; ++s);
87         if (*s) {
88                 *s = '\0';
89                 fac = decode(save, facilitynames);
90                 if (fac < 0)
91                         error_msg_and_die("unknown facility name: %s", save);
92                 *s++ = '.';
93         } else {
94                 s = save;
95         }
96         lev = decode(s, prioritynames);
97         if (lev < 0)
98                 error_msg_and_die("unknown priority name: %s", save);
99         return ((lev & LOG_PRIMASK) | (fac & LOG_FACMASK));
100 }
101
102
103 extern int logger_main(int argc, char **argv)
104 {
105         int pri = LOG_USER | LOG_NOTICE;
106         int option = 0;
107         int c, i, len, opt;
108         char *message=NULL, buf[1024], name[128];
109
110         /* Fill out the name string early (may be overwritten later) */
111         my_getpwuid(name, geteuid());
112
113         /* Parse any options */
114         while ((opt = getopt(argc, argv, "p:st:")) > 0) {
115                 switch (opt) {
116                         case 's':
117                                 option |= LOG_PERROR;
118                                 break;
119                         case 'p':
120                                 pri = pencode(optarg);
121                                 break;
122                         case 't':
123                                 strncpy(name, optarg, sizeof(name));
124                                 break;
125                         default:
126                                 show_usage();
127                 }
128         }
129
130         if (optind == argc) {
131                 /* read from stdin */
132                 i = 0;
133                 while ((c = getc(stdin)) != EOF && i < sizeof(buf)) {
134                         buf[i++] = c;
135                 }
136                 buf[i++] = '\0';
137                 message = buf;
138         } else {
139                 len = 1; /* for the '\0' */
140                 message=xcalloc(1, 1);
141                 for (i = optind; i < argc; i++) {
142                         len += strlen(argv[i]);
143                         len += 1;  /* for the space between the args */
144                         message = xrealloc(message, len);
145                         strcat(message, argv[i]);
146                         strcat(message, " ");
147                 }
148                 message[strlen(message)-1] = '\0';
149         }
150
151         /*openlog(name, option, (pri | LOG_FACMASK));
152         syslog(pri, "%s", message);
153         closelog();*/
154         syslog_msg_with_name(name,(pri | LOG_FACMASK),pri,message);
155         return EXIT_SUCCESS;
156 }
157
158
159 /*-
160  * Copyright (c) 1983, 1993
161  *      The Regents of the University of California.  All rights reserved.
162  *
163  * This is the original license statement for the decode and pencode functions.
164  *
165  * Redistribution and use in source and binary forms, with or without
166  * modification, are permitted provided that the following conditions
167  * are met:
168  * 1. Redistributions of source code must retain the above copyright
169  *    notice, this list of conditions and the following disclaimer.
170  * 2. Redistributions in binary form must reproduce the above copyright
171  *    notice, this list of conditions and the following disclaimer in the
172  *    documentation and/or other materials provided with the distribution.
173  *
174  * 3. <BSD Advertising Clause omitted per the July 22, 1999 licensing change 
175  *              ftp://ftp.cs.berkeley.edu/pub/4bsd/README.Impt.License.Change> 
176  *
177  * 4. Neither the name of the University nor the names of its contributors
178  *    may be used to endorse or promote products derived from this software
179  *    without specific prior written permission.
180  *
181  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
182  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
183  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
184  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
185  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
186  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
187  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
188  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
189  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
190  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
191  * SUCH DAMAGE.
192  */
193
194
195