| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | /***********************************************************
 | 
					
						
							| 
									
										
										
										
											1994-08-30 12:25:20 +00:00
										 |  |  | Copyright 1994 by Lance Ellinghouse, | 
					
						
							|  |  |  | Cathedral City, California Republic, United States of America. | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |                         All Rights Reserved | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Permission to use, copy, modify, and distribute this software and its  | 
					
						
							|  |  |  | documentation for any purpose and without fee is hereby granted,  | 
					
						
							|  |  |  | provided that the above copyright notice appear in all copies and that | 
					
						
							|  |  |  | both that copyright notice and this permission notice appear in  | 
					
						
							| 
									
										
										
										
											1994-08-30 12:25:20 +00:00
										 |  |  | supporting documentation, and that the name of Lance Ellinghouse | 
					
						
							|  |  |  | not be used in advertising or publicity pertaining to distribution  | 
					
						
							|  |  |  | of the software without specific, written prior permission. | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1994-08-30 12:25:20 +00:00
										 |  |  | LANCE ELLINGHOUSE DISCLAIMS ALL WARRANTIES WITH REGARD TO | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND | 
					
						
							| 
									
										
										
										
											1994-08-30 12:25:20 +00:00
										 |  |  | FITNESS, IN NO EVENT SHALL LANCE ELLINGHOUSE BE LIABLE FOR ANY SPECIAL,  | 
					
						
							|  |  |  | INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING  | 
					
						
							|  |  |  | FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT,  | 
					
						
							|  |  |  | NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION  | 
					
						
							|  |  |  | WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | ******************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1995-10-11 16:15:28 +00:00
										 |  |  | /******************************************************************
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Revision history: | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 95/06/29 (Steve Clift) | 
					
						
							|  |  |  |   - Changed arg parsing to use PyArg_ParseTuple. | 
					
						
							|  |  |  |   - Added PyErr_Clear() call(s) where needed. | 
					
						
							|  |  |  |   - Fix core dumps if user message contains format specifiers. | 
					
						
							|  |  |  |   - Change openlog arg defaults to match normal syslog behaviour. | 
					
						
							|  |  |  |   - Plug memory leak in openlog(). | 
					
						
							|  |  |  |   - Fix setlogmask() to return previous mask value. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ******************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | /* syslog module */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1995-01-10 20:56:29 +00:00
										 |  |  | #include "Python.h"
 | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include <syslog.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1994-08-30 12:25:20 +00:00
										 |  |  | static PyObject *  | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | syslog_openlog(self, args) | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	PyObject * self; | 
					
						
							|  |  |  | 	PyObject * args; | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	long logopt = 0; | 
					
						
							|  |  |  | 	long facility = LOG_USER; | 
					
						
							| 
									
										
										
										
											1995-10-11 16:15:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	static PyObject *ident_o = NULL; | 
					
						
							| 
									
										
										
										
											1995-10-11 16:15:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	Py_XDECREF(ident_o); | 
					
						
							|  |  |  | 	if (!PyArg_ParseTuple(args, | 
					
						
							|  |  |  | 			      "S|ll;ident string [, logoption [, facility]]", | 
					
						
							|  |  |  | 			      &ident_o, &logopt, &facility)) | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* This is needed because openlog() does NOT make a copy
 | 
					
						
							|  |  |  | 	 * and syslog() later uses it.. cannot trash it. | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	Py_INCREF(ident_o); | 
					
						
							| 
									
										
										
										
											1995-10-11 16:15:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	openlog(PyString_AsString(ident_o), logopt, facility); | 
					
						
							| 
									
										
										
										
											1995-10-11 16:15:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	Py_INCREF(Py_None); | 
					
						
							|  |  |  | 	return Py_None; | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1994-08-30 12:25:20 +00:00
										 |  |  | static PyObject *  | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | syslog_syslog(self, args) | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	PyObject * self; | 
					
						
							|  |  |  | 	PyObject * args; | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	char *message; | 
					
						
							|  |  |  | 	int   priority = LOG_INFO | LOG_USER; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (!PyArg_ParseTuple(args, "is;[priority,] message string", | 
					
						
							|  |  |  | 			      &priority, &message)) { | 
					
						
							|  |  |  | 		PyErr_Clear(); | 
					
						
							|  |  |  | 		if (!PyArg_ParseTuple(args, "s;[priority,] message string", | 
					
						
							|  |  |  | 				      &message)) | 
					
						
							|  |  |  | 			return NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	syslog(priority, "%s", message); | 
					
						
							|  |  |  | 	Py_INCREF(Py_None); | 
					
						
							|  |  |  | 	return Py_None; | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1994-08-30 12:25:20 +00:00
										 |  |  | static PyObject *  | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | syslog_closelog(self, args) | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	PyObject * self; | 
					
						
							|  |  |  | 	PyObject * args; | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											1995-10-11 16:15:28 +00:00
										 |  |  | 	if (!PyArg_ParseTuple(args, "")) | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | 		return NULL; | 
					
						
							|  |  |  | 	closelog(); | 
					
						
							| 
									
										
										
										
											1994-08-30 12:25:20 +00:00
										 |  |  | 	Py_INCREF(Py_None); | 
					
						
							|  |  |  | 	return Py_None; | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1994-08-30 12:25:20 +00:00
										 |  |  | static PyObject *  | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | syslog_setlogmask(self, args) | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	PyObject * self; | 
					
						
							|  |  |  | 	PyObject * args; | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	long maskpri, omaskpri; | 
					
						
							| 
									
										
										
										
											1995-10-11 16:15:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	if (!PyArg_ParseTuple(args, "l;mask for priority", &maskpri)) | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							|  |  |  | 	omaskpri = setlogmask(maskpri); | 
					
						
							|  |  |  | 	return PyInt_FromLong(omaskpri); | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1994-08-30 12:25:20 +00:00
										 |  |  | static PyObject *  | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | syslog_log_mask(self, args) | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	PyObject * self; | 
					
						
							|  |  |  | 	PyObject * args; | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	long mask; | 
					
						
							|  |  |  | 	long pri; | 
					
						
							|  |  |  | 	if (!PyArg_ParseTuple(args, "l", &pri)) | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							|  |  |  | 	mask = LOG_MASK(pri); | 
					
						
							|  |  |  | 	return PyInt_FromLong(mask); | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1994-08-30 12:25:20 +00:00
										 |  |  | static PyObject *  | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | syslog_log_upto(self, args) | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	PyObject * self; | 
					
						
							|  |  |  | 	PyObject * args; | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	long mask; | 
					
						
							|  |  |  | 	long pri; | 
					
						
							|  |  |  | 	if (!PyArg_ParseTuple(args, "l", &pri)) | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							|  |  |  | 	mask = LOG_UPTO(pri); | 
					
						
							|  |  |  | 	return PyInt_FromLong(mask); | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* List of functions defined in the module */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1994-08-30 12:25:20 +00:00
										 |  |  | static PyMethodDef syslog_methods[] = { | 
					
						
							| 
									
										
										
										
											1995-10-11 16:15:28 +00:00
										 |  |  | 	{"openlog",	syslog_openlog,		METH_VARARGS}, | 
					
						
							|  |  |  | 	{"closelog",	syslog_closelog,	METH_VARARGS}, | 
					
						
							|  |  |  | 	{"syslog",	syslog_syslog,		METH_VARARGS}, | 
					
						
							|  |  |  | 	{"setlogmask",	syslog_setlogmask,	METH_VARARGS}, | 
					
						
							|  |  |  | 	{"LOG_MASK",	syslog_log_mask,	METH_VARARGS}, | 
					
						
							|  |  |  | 	{"LOG_UPTO",	syslog_log_upto,	METH_VARARGS}, | 
					
						
							|  |  |  | 	{NULL,		NULL,			0} | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Initialization function for the module */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | void ins(d, s, x) | 
					
						
							|  |  |  | 	PyObject *d; | 
					
						
							|  |  |  | 	char *s; | 
					
						
							|  |  |  | 	long x; | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	PyObject *xl = PyInt_FromLong(x); | 
					
						
							|  |  |  | 	PyDict_SetItemString(d, s, xl); | 
					
						
							|  |  |  | 	Py_XDECREF(xl); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											1995-10-11 16:15:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | void | 
					
						
							|  |  |  | initsyslog() | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											1995-10-11 16:15:28 +00:00
										 |  |  | 	PyObject *m, *d; | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* Create the module and add the functions */ | 
					
						
							| 
									
										
										
										
											1994-08-30 12:25:20 +00:00
										 |  |  | 	m = Py_InitModule("syslog", syslog_methods); | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* Add some symbolic constants to the module */ | 
					
						
							| 
									
										
										
										
											1994-08-30 12:25:20 +00:00
										 |  |  | 	d = PyModule_GetDict(m); | 
					
						
							| 
									
										
										
										
											1995-10-11 16:15:28 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* Priorities */ | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	ins(d, "LOG_EMERG",	LOG_EMERG); | 
					
						
							|  |  |  | 	ins(d, "LOG_ALERT",	LOG_ALERT); | 
					
						
							|  |  |  | 	ins(d, "LOG_CRIT",	LOG_CRIT); | 
					
						
							|  |  |  | 	ins(d, "LOG_ERR",	LOG_ERR); | 
					
						
							|  |  |  | 	ins(d, "LOG_WARNING",	LOG_WARNING); | 
					
						
							|  |  |  | 	ins(d, "LOG_NOTICE",	LOG_NOTICE); | 
					
						
							|  |  |  | 	ins(d, "LOG_INFO",	LOG_INFO); | 
					
						
							|  |  |  | 	ins(d, "LOG_DEBUG",	LOG_DEBUG); | 
					
						
							| 
									
										
										
										
											1995-10-11 16:15:28 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* openlog() option flags */ | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	ins(d, "LOG_PID",	LOG_PID); | 
					
						
							|  |  |  | 	ins(d, "LOG_CONS",	LOG_CONS); | 
					
						
							|  |  |  | 	ins(d, "LOG_NDELAY",	LOG_NDELAY); | 
					
						
							|  |  |  | 	ins(d, "LOG_NOWAIT",	LOG_NOWAIT); | 
					
						
							| 
									
										
										
										
											1995-10-11 16:15:28 +00:00
										 |  |  | #ifdef LOG_PERROR
 | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	ins(d, "LOG_PERROR",	LOG_PERROR); | 
					
						
							| 
									
										
										
										
											1995-10-11 16:15:28 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Facilities */ | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	ins(d, "LOG_KERN",	LOG_KERN); | 
					
						
							|  |  |  | 	ins(d, "LOG_USER",	LOG_USER); | 
					
						
							|  |  |  | 	ins(d, "LOG_MAIL",	LOG_MAIL); | 
					
						
							|  |  |  | 	ins(d, "LOG_DAEMON",	LOG_DAEMON); | 
					
						
							|  |  |  | 	ins(d, "LOG_AUTH",	LOG_AUTH); | 
					
						
							|  |  |  | 	ins(d, "LOG_LPR",	LOG_LPR); | 
					
						
							| 
									
										
										
										
											1996-07-30 16:55:34 +00:00
										 |  |  | #ifdef LOG_NEWS
 | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	ins(d, "LOG_NEWS",	LOG_NEWS); | 
					
						
							| 
									
										
										
										
											1996-07-30 16:55:34 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	ins(d, "LOG_NEWS",	LOG_MAIL); | 
					
						
							| 
									
										
										
										
											1996-07-30 16:55:34 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef LOG_UUCP
 | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	ins(d, "LOG_UUCP",	LOG_UUCP); | 
					
						
							| 
									
										
										
										
											1996-07-30 16:55:34 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	ins(d, "LOG_UUCP",	LOG_MAIL); | 
					
						
							| 
									
										
										
										
											1996-07-30 16:55:34 +00:00
										 |  |  | #endif
 | 
					
						
							|  |  |  | #ifdef LOG_CRON
 | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	ins(d, "LOG_CRON",	LOG_CRON); | 
					
						
							| 
									
										
										
										
											1996-07-30 16:55:34 +00:00
										 |  |  | #else
 | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	ins(d, "LOG_CRON",	LOG_DAEMON); | 
					
						
							| 
									
										
										
										
											1996-07-30 16:55:34 +00:00
										 |  |  | #endif
 | 
					
						
							| 
									
										
										
										
											1997-01-09 23:51:21 +00:00
										 |  |  | 	ins(d, "LOG_LOCAL0",	LOG_LOCAL0); | 
					
						
							|  |  |  | 	ins(d, "LOG_LOCAL1",	LOG_LOCAL1); | 
					
						
							|  |  |  | 	ins(d, "LOG_LOCAL2",	LOG_LOCAL2); | 
					
						
							|  |  |  | 	ins(d, "LOG_LOCAL3",	LOG_LOCAL3); | 
					
						
							|  |  |  | 	ins(d, "LOG_LOCAL4",	LOG_LOCAL4); | 
					
						
							|  |  |  | 	ins(d, "LOG_LOCAL5",	LOG_LOCAL5); | 
					
						
							|  |  |  | 	ins(d, "LOG_LOCAL6",	LOG_LOCAL6); | 
					
						
							|  |  |  | 	ins(d, "LOG_LOCAL7",	LOG_LOCAL7); | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* Check for errors */ | 
					
						
							| 
									
										
										
										
											1994-08-30 12:25:20 +00:00
										 |  |  | 	if (PyErr_Occurred()) | 
					
						
							|  |  |  | 		Py_FatalError("can't initialize module syslog"); | 
					
						
							| 
									
										
										
										
											1994-07-14 13:56:50 +00:00
										 |  |  | } |