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

Revision 3133, 1.8 kB (checked in by jerome, 17 years ago)

Changed copyright years.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
Line 
1# PyKota
2# -*- coding: ISO-8859-15 -*-
3#
4# PyKota : Print Quotas for CUPS and LPRng
5#
6# (c) 2003, 2004, 2005, 2006, 2007 Jerome Alet <alet@librelogiciel.com>
7# This program is free software; you can redistribute it and/or modify
8# it under the terms of the GNU General Public License as published by
9# the Free Software Foundation; either version 2 of the License, or
10# (at your option) any later version.
11#
12# This program is distributed in the hope that it will be useful,
13# but WITHOUT ANY WARRANTY; without even the implied warranty of
14# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15# GNU General Public License for more details.
16#
17# You should have received a copy of the GNU General Public License
18# along with this program; if not, write to the Free Software
19# Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
20#
21# $Id$
22#
23#
24
25"""This module defines a class for PyKota logging through syslog."""
26
27import os
28import syslog
29
30__revision__ = "$Id$"
31
32class Logger :
33    """A logger class which logs to syslog."""
34    levels = { "error" : "ERR", "warn": "WARNING", \
35               "info": "INFO", "debug": "DEBUG" }
36    def __init__(self) :
37        """Opens the logging subsystem."""
38        syslog.openlog("PyKota", 0, syslog.LOG_LPR)
39       
40    def __del__(self) :   
41        """Ensures the logging subsystem is closed."""
42        syslog.closelog()
43       
44    def log_message(self, message, level="info") :
45        """Sends the message to syslog."""
46        priority = getattr(syslog, \
47                           "LOG_%s" % self.levels.get(level.lower(), \
48                                                      "DEBUG").upper(), \
49                           syslog.LOG_DEBUG)
50        syslog.syslog(priority, "(PID %s) : %s" \
51                                      % (os.getpid(), message.strip()))
Note: See TracBrowser for help on using the browser.