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

Revision 3489, 1.8 kB (checked in by jerome, 15 years ago)

Removed bad copy and paste artifact.

  • Property svn:eol-style set to native
  • Property svn:keywords set to Author Date Id Revision
RevLine 
[3489]1# -*- coding: utf-8 -*-
[707]2#
[3260]3# PyKota : Print Quotas for CUPS
[707]4#
[3481]5# (c) 2003-2009 Jerome Alet <alet@librelogiciel.com>
[3260]6# This program is free software: you can redistribute it and/or modify
[873]7# it under the terms of the GNU General Public License as published by
[3260]8# the Free Software Foundation, either version 3 of the License, or
[873]9# (at your option) any later version.
[3413]10#
[873]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.
[3413]15#
[873]16# You should have received a copy of the GNU General Public License
[3260]17# along with this program.  If not, see <http://www.gnu.org/licenses/>.
[707]18#
19# $Id$
20#
[1493]21#
[707]22
[2859]23"""This module defines a class for PyKota logging through syslog."""
24
[3306]25import sys
[1457]26import os
[707]27import syslog
28
[2859]29__revision__ = "$Id$"
30
[707]31class Logger :
32    """A logger class which logs to syslog."""
[2859]33    levels = { "error" : "ERR", "warn": "WARNING", \
34               "info": "INFO", "debug": "DEBUG" }
[707]35    def __init__(self) :
36        """Opens the logging subsystem."""
37        syslog.openlog("PyKota", 0, syslog.LOG_LPR)
[3413]38
39    def __del__(self) :
[707]40        """Ensures the logging subsystem is closed."""
41        syslog.closelog()
[3413]42
[710]43    def log_message(self, message, level="info") :
[707]44        """Sends the message to syslog."""
[2859]45        priority = getattr(syslog, \
46                           "LOG_%s" % self.levels.get(level.lower(), \
47                                                      "DEBUG").upper(), \
48                           syslog.LOG_DEBUG)
[3413]49        try :
[3309]50            message = message.strip().encode(sys.stdout.encoding or "UTF-8", \
51                                             "replace")
[3413]52        except UnicodeDecodeError :
[3309]53            pass
54        syslog.syslog(priority, "(PID %s) : %s" % (os.getpid(), message))
Note: See TracBrowser for help on using the browser.