root / pykota / trunk / pykota / loggers / system.py @ 873

Revision 873, 2.0 kB (checked in by jalet, 21 years ago)

GPL paragraphs were incorrectly (from memory) copied into the sources.
Two README files were added.
Upgrade script for PostgreSQL pre 1.01 schema was added.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
Line 
1# PyKota
2#
3# PyKota : Print Quotas for CUPS
4#
5# (c) 2003 Jerome Alet <alet@librelogiciel.com>
6# This program is free software; you can redistribute it and/or modify
7# it under the terms of the GNU General Public License as published by
8# the Free Software Foundation; either version 2 of the License, or
9# (at your option) any later version.
10#
11# This program is distributed in the hope that it will be useful,
12# but WITHOUT ANY WARRANTY; without even the implied warranty of
13# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
14# GNU General Public License for more details.
15#
16# You should have received a copy of the GNU General Public License
17# along with this program; if not, write to the Free Software
18# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
19#
20# $Id$
21#
22# $Log$
23# Revision 1.5  2003/03/29 13:45:27  jalet
24# GPL paragraphs were incorrectly (from memory) copied into the sources.
25# Two README files were added.
26# Upgrade script for PostgreSQL pre 1.01 schema was added.
27#
28# Revision 1.4  2003/02/27 23:48:41  jalet
29# Correctly maps PyKota's log levels to syslog log levels
30#
31# Revision 1.3  2003/02/27 22:55:20  jalet
32# WARN log priority doesn't exist.
33#
34# Revision 1.2  2003/02/05 23:47:54  jalet
35# Forgotten default argument
36#
37# Revision 1.1  2003/02/05 23:09:20  jalet
38# Name conflict
39#
40#
41#
42
43import sys
44import syslog
45
46class Logger :
47    """A logger class which logs to syslog."""
48    levels = { "error" : "ERR", "warn": "WARNING", "info": "INFO", "debug": "DEBUG" }
49    def __init__(self) :
50        """Opens the logging subsystem."""
51        syslog.openlog("PyKota", 0, syslog.LOG_LPR)
52       
53    def __del__(self) :   
54        """Ensures the logging subsystem is closed."""
55        syslog.closelog()
56       
57    def log_message(self, message, level="info") :
58        """Sends the message to syslog."""
59        priority = getattr(syslog, "LOG_%s" % self.levels.get(level.lower(), "DEBUG").upper(), syslog.LOG_DEBUG)
60        syslog.syslog(priority, message)
Note: See TracBrowser for help on using the browser.