root / pykota / trunk / pykota / logger.py @ 1144

Revision 1144, 2.7 kB (checked in by jalet, 21 years ago)

Character encoding added to please latest version of Python

  • 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 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., 59 Temple Place, Suite 330, Boston, MA 02111-1307, USA.
20#
21# $Id$
22#
23# $Log$
24# Revision 1.9  2003/10/07 09:07:28  jalet
25# Character encoding added to please latest version of Python
26#
27# Revision 1.8  2003/07/07 11:49:24  jalet
28# Lots of small fixes with the help of PyChecker
29#
30# Revision 1.7  2003/06/10 16:37:54  jalet
31# Deletion of the second user which is not needed anymore.
32# Added a debug configuration field in /etc/pykota.conf
33# All queries can now be sent to the logger in debug mode, this will
34# greatly help improve performance when time for this will come.
35#
36# Revision 1.6  2003/04/23 22:13:57  jalet
37# Preliminary support for LPRng added BUT STILL UNTESTED.
38#
39# Revision 1.5  2003/03/29 13:45:27  jalet
40# GPL paragraphs were incorrectly (from memory) copied into the sources.
41# Two README files were added.
42# Upgrade script for PostgreSQL pre 1.01 schema was added.
43#
44# Revision 1.4  2003/02/09 13:05:43  jalet
45# Internationalization continues...
46#
47# Revision 1.3  2003/02/05 22:10:29  jalet
48# Typos
49#
50# Revision 1.2  2003/02/05 22:02:22  jalet
51# __import__ statement didn't work as expected
52#
53# Revision 1.1  2003/02/05 21:28:17  jalet
54# Initial import into CVS
55#
56#
57#
58
59class PyKotaLoggingError(Exception):
60    """An exception for logging related stuff."""
61    def __init__(self, message = ""):
62        self.message = message
63        Exception.__init__(self, message)
64    def __repr__(self):
65        return self.message
66    __str__ = __repr__
67
68def openLogger(pykotatool) :
69    """Returns the appropriate logger subsystem object."""
70    backend = pykotatool.config.getLoggingBackend()
71    try :
72        if not backend.isalpha() :
73            # don't trust user input
74            raise ImportError
75        exec "from pykota.loggers import %s as loggingbackend" % backend.lower()   
76    except ImportError :
77        raise PyKotaLoggingError, _("Unsupported logging subsystem %s") % backend
78    else :   
79        return getattr(loggingbackend, "Logger")()
Note: See TracBrowser for help on using the browser.