source: main/waeup.sirp/trunk/src/waeup/sirp/hostels/container.py @ 8730

Last change on this file since 8730 was 7652, checked in by Henrik Bettermann, 13 years ago

Do not retrieve current principal in derived logging components. This is now done by the parent Logger class.

  • Property svn:keywords set to Id
File size: 2.0 KB
Line 
1## $Id: container.py 7652 2012-02-15 10:51:53Z henrik $
2##
3## Copyright (C) 2011 Uli Fouquet & Henrik Bettermann
4## This program is free software; you can redistribute it and/or modify
5## it under the terms of the GNU General Public License as published by
6## the Free Software Foundation; either version 2 of the License, or
7## (at your option) any later version.
8##
9## This program is distributed in the hope that it will be useful,
10## but WITHOUT ANY WARRANTY; without even the implied warranty of
11## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12## GNU General Public License for more details.
13##
14## You should have received a copy of the GNU General Public License
15## along with this program; if not, write to the Free Software
16## Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
17##
18"""
19Containers which contain hostels.
20"""
21import grok
22from waeup.sirp.hostels.interfaces import IHostelsContainer, IHostel
23from waeup.sirp.utils.logger import Logger
24
25class HostelsContainer(grok.Container, Logger):
26    """This is a container for all kind of hostels.
27    """
28    grok.implements(IHostelsContainer)
29    grok.provides(IHostelsContainer)
30
31    def __init__(self):
32        super(HostelsContainer, self).__init__()
33        return
34
35    def archive(self, id=None):
36        raise NotImplementedError()
37
38    def clear(self, id=None, archive=True):
39        raise NotImplementedError()
40
41    def addHostel(self, hostel):
42        """Add a hostel.
43        """
44        if not IHostel.providedBy(hostel):
45            raise TypeError(
46                'HostelsContainers contain only IHostel instances')
47        self[hostel.hostel_id] = hostel
48        return
49
50    logger_name = 'waeup.sirp.${sitename}.hostels'
51    logger_filename = 'hostels.log'
52
53    def logger_info(self, ob_class, target, comment=None):
54        """Get the logger's info method.
55        """
56        self.logger.info('%s - %s - %s' % (
57                ob_class, target, comment))
58        return
59
60    def loggerInfo(self, ob_class, comment=None):
61        target = self.__name__
62        return self.logger_info(ob_class,target,comment)
Note: See TracBrowser for help on using the repository browser.