1*73008250Slneto /* $NetBSD: syslog.c,v 1.2 2015/02/02 14:03:05 lneto Exp $ */
2f9cf0d6eSmbalmer
3f9cf0d6eSmbalmer /*
4f9cf0d6eSmbalmer * Copyright (c) 2013 Marc Balmer <marc@msys.ch>
5f9cf0d6eSmbalmer * All rights reserved.
6f9cf0d6eSmbalmer *
7f9cf0d6eSmbalmer * Redistribution and use in source and binary forms, with or without
8f9cf0d6eSmbalmer * modification, are permitted provided that the following conditions
9f9cf0d6eSmbalmer * are met:
10f9cf0d6eSmbalmer * 1. Redistributions of source code must retain the above copyright
11f9cf0d6eSmbalmer * notice, this list of conditions and the following disclaimer.
12f9cf0d6eSmbalmer * 2. Redistributions in binary form must reproduce the above copyright
13f9cf0d6eSmbalmer * notice, this list of conditions and the following disclaimer in the
14f9cf0d6eSmbalmer * documentation and/or other materials provided with the distribution.
15f9cf0d6eSmbalmer *
16f9cf0d6eSmbalmer * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
17f9cf0d6eSmbalmer * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
18f9cf0d6eSmbalmer * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
19f9cf0d6eSmbalmer * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
20f9cf0d6eSmbalmer * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
21f9cf0d6eSmbalmer * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22f9cf0d6eSmbalmer * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23f9cf0d6eSmbalmer * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24f9cf0d6eSmbalmer * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
25f9cf0d6eSmbalmer * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26f9cf0d6eSmbalmer */
27f9cf0d6eSmbalmer
28f9cf0d6eSmbalmer /* Lua binding for syslog */
29f9cf0d6eSmbalmer
30f9cf0d6eSmbalmer #include <sys/types.h>
31f9cf0d6eSmbalmer
32f9cf0d6eSmbalmer #include <errno.h>
33f9cf0d6eSmbalmer #include <lua.h>
34f9cf0d6eSmbalmer #include <lauxlib.h>
35f9cf0d6eSmbalmer #include <stdlib.h>
36f9cf0d6eSmbalmer #include <syslog.h>
37f9cf0d6eSmbalmer #include <unistd.h>
38f9cf0d6eSmbalmer
39f9cf0d6eSmbalmer int luaopen_syslog(lua_State *);
40f9cf0d6eSmbalmer
41f9cf0d6eSmbalmer static int
syslog_openlog(lua_State * L)42f9cf0d6eSmbalmer syslog_openlog(lua_State *L)
43f9cf0d6eSmbalmer {
44f9cf0d6eSmbalmer const char *ident;
45f9cf0d6eSmbalmer int option;
46f9cf0d6eSmbalmer int facility;
47f9cf0d6eSmbalmer
48f9cf0d6eSmbalmer ident = luaL_checkstring(L, 1);
49f9cf0d6eSmbalmer option = luaL_checkinteger(L, 2);
50f9cf0d6eSmbalmer facility = luaL_checkinteger(L, 3);
51f9cf0d6eSmbalmer openlog(ident, option, facility);
52f9cf0d6eSmbalmer return 0;
53f9cf0d6eSmbalmer }
54f9cf0d6eSmbalmer
55f9cf0d6eSmbalmer static int
syslog_syslog(lua_State * L)56f9cf0d6eSmbalmer syslog_syslog(lua_State *L)
57f9cf0d6eSmbalmer {
58*73008250Slneto syslog((int) luaL_checkinteger(L, 1), "%s", luaL_checkstring(L, 2));
59f9cf0d6eSmbalmer return 0;
60f9cf0d6eSmbalmer }
61f9cf0d6eSmbalmer
62f9cf0d6eSmbalmer static int
syslog_closelog(lua_State * L)63f9cf0d6eSmbalmer syslog_closelog(lua_State *L)
64f9cf0d6eSmbalmer {
65f9cf0d6eSmbalmer closelog();
66f9cf0d6eSmbalmer return 0;
67f9cf0d6eSmbalmer }
68f9cf0d6eSmbalmer
69f9cf0d6eSmbalmer static int
syslog_setlogmask(lua_State * L)70f9cf0d6eSmbalmer syslog_setlogmask(lua_State *L)
71f9cf0d6eSmbalmer {
72*73008250Slneto lua_pushinteger(L, setlogmask((int) luaL_checkinteger(L, 1)));
73f9cf0d6eSmbalmer return 1;
74f9cf0d6eSmbalmer }
75f9cf0d6eSmbalmer
76f9cf0d6eSmbalmer static void
syslog_set_info(lua_State * L)77f9cf0d6eSmbalmer syslog_set_info(lua_State *L)
78f9cf0d6eSmbalmer {
79f9cf0d6eSmbalmer lua_pushliteral(L, "_COPYRIGHT");
80f9cf0d6eSmbalmer lua_pushliteral(L, "Copyright (C) 2013 by "
81f9cf0d6eSmbalmer "Marc Balmer <marc@msys.ch>");
82f9cf0d6eSmbalmer lua_settable(L, -3);
83f9cf0d6eSmbalmer lua_pushliteral(L, "_DESCRIPTION");
84f9cf0d6eSmbalmer lua_pushliteral(L, "syslog binding for Lua");
85f9cf0d6eSmbalmer lua_settable(L, -3);
86f9cf0d6eSmbalmer lua_pushliteral(L, "_VERSION");
87f9cf0d6eSmbalmer lua_pushliteral(L, "syslog 1.0.0");
88f9cf0d6eSmbalmer lua_settable(L, -3);
89f9cf0d6eSmbalmer }
90f9cf0d6eSmbalmer
91f9cf0d6eSmbalmer struct constant {
92f9cf0d6eSmbalmer const char *name;
93f9cf0d6eSmbalmer int value;
94f9cf0d6eSmbalmer };
95f9cf0d6eSmbalmer
96f9cf0d6eSmbalmer #define CONSTANT(NAME) { #NAME, NAME }
97f9cf0d6eSmbalmer
98f9cf0d6eSmbalmer static struct constant syslog_constant[] = {
99f9cf0d6eSmbalmer /* syslog options */
100f9cf0d6eSmbalmer CONSTANT(LOG_CONS),
101f9cf0d6eSmbalmer CONSTANT(LOG_NDELAY),
102f9cf0d6eSmbalmer CONSTANT(LOG_NOWAIT),
103f9cf0d6eSmbalmer CONSTANT(LOG_ODELAY),
104f9cf0d6eSmbalmer CONSTANT(LOG_PERROR),
105f9cf0d6eSmbalmer CONSTANT(LOG_PID),
106f9cf0d6eSmbalmer
107f9cf0d6eSmbalmer /* syslog facilities */
108f9cf0d6eSmbalmer CONSTANT(LOG_AUTH),
109f9cf0d6eSmbalmer CONSTANT(LOG_AUTHPRIV),
110f9cf0d6eSmbalmer CONSTANT(LOG_CRON),
111f9cf0d6eSmbalmer CONSTANT(LOG_DAEMON),
112f9cf0d6eSmbalmer CONSTANT(LOG_FTP),
113f9cf0d6eSmbalmer CONSTANT(LOG_KERN),
114f9cf0d6eSmbalmer CONSTANT(LOG_LOCAL0),
115f9cf0d6eSmbalmer CONSTANT(LOG_LOCAL1),
116f9cf0d6eSmbalmer CONSTANT(LOG_LOCAL2),
117f9cf0d6eSmbalmer CONSTANT(LOG_LOCAL3),
118f9cf0d6eSmbalmer CONSTANT(LOG_LOCAL4),
119f9cf0d6eSmbalmer CONSTANT(LOG_LOCAL5),
120f9cf0d6eSmbalmer CONSTANT(LOG_LOCAL6),
121f9cf0d6eSmbalmer CONSTANT(LOG_LOCAL7),
122f9cf0d6eSmbalmer CONSTANT(LOG_LPR),
123f9cf0d6eSmbalmer CONSTANT(LOG_MAIL),
124f9cf0d6eSmbalmer CONSTANT(LOG_NEWS),
125f9cf0d6eSmbalmer CONSTANT(LOG_SYSLOG),
126f9cf0d6eSmbalmer CONSTANT(LOG_USER),
127f9cf0d6eSmbalmer CONSTANT(LOG_UUCP),
128f9cf0d6eSmbalmer
129f9cf0d6eSmbalmer /* syslog levels */
130f9cf0d6eSmbalmer CONSTANT(LOG_EMERG),
131f9cf0d6eSmbalmer CONSTANT(LOG_ALERT),
132f9cf0d6eSmbalmer CONSTANT(LOG_CRIT),
133f9cf0d6eSmbalmer CONSTANT(LOG_ERR),
134f9cf0d6eSmbalmer CONSTANT(LOG_WARNING),
135f9cf0d6eSmbalmer CONSTANT(LOG_NOTICE),
136f9cf0d6eSmbalmer CONSTANT(LOG_INFO),
137f9cf0d6eSmbalmer CONSTANT(LOG_DEBUG),
138f9cf0d6eSmbalmer
139f9cf0d6eSmbalmer { NULL, 0 }
140f9cf0d6eSmbalmer };
141f9cf0d6eSmbalmer
142f9cf0d6eSmbalmer int
luaopen_syslog(lua_State * L)143f9cf0d6eSmbalmer luaopen_syslog(lua_State *L)
144f9cf0d6eSmbalmer {
145f9cf0d6eSmbalmer int n;
146f9cf0d6eSmbalmer struct luaL_Reg luasyslog[] = {
147f9cf0d6eSmbalmer { "openlog", syslog_openlog },
148f9cf0d6eSmbalmer { "syslog", syslog_syslog },
149f9cf0d6eSmbalmer { "closelog", syslog_closelog },
150f9cf0d6eSmbalmer { "setlogmask", syslog_setlogmask },
151f9cf0d6eSmbalmer { NULL, NULL }
152f9cf0d6eSmbalmer };
153f9cf0d6eSmbalmer
154f9cf0d6eSmbalmer #if LUA_VERSION_NUM >= 502
155f9cf0d6eSmbalmer luaL_newlib(L, luasyslog);
156f9cf0d6eSmbalmer #else
157f9cf0d6eSmbalmer luaL_register(L, "syslog", luasyslog);
158f9cf0d6eSmbalmer #endif
159f9cf0d6eSmbalmer syslog_set_info(L);
160f9cf0d6eSmbalmer for (n = 0; syslog_constant[n].name != NULL; n++) {
161f9cf0d6eSmbalmer lua_pushinteger(L, syslog_constant[n].value);
162f9cf0d6eSmbalmer lua_setfield(L, -2, syslog_constant[n].name);
163f9cf0d6eSmbalmer };
164f9cf0d6eSmbalmer return 1;
165f9cf0d6eSmbalmer }
166