source: main/waeup.kofa/trunk/src/waeup/kofa/payments/payment.py @ 9857

Last change on this file since 9857 was 9769, checked in by Henrik Bettermann, 12 years ago

Ease customization of logging format. We use this for the new payments logger.

Do not show payments.log on logfile search page.

  • Property svn:keywords set to Id
File size: 3.2 KB
RevLine 
[7195]1## $Id: payment.py 9769 2012-12-05 08:32:11Z henrik $
2##
[6864]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"""
19These are the payment tickets.
20"""
21import grok
[6869]22from datetime import datetime
[6864]23from grok import index
[9505]24from zope.event import notify
[8182]25from zope.component import getUtility
[8429]26from zope.i18n import translate
[8182]27from waeup.kofa.interfaces import IKofaUtils
[8420]28from waeup.kofa.interfaces import MessageFactory as _
[7811]29from waeup.kofa.payments.interfaces import (
[9469]30    IPayment, IOnlinePayment,
[9405]31    payment_states)
[8420]32from waeup.kofa.utils.helpers import attrs_to_fields, get_current_principal
[9769]33from waeup.kofa.utils.logger import Logger
[6864]34
[9769]35class Payment(grok.Container, Logger):
[6864]36    """This is a payment.
37    """
38    grok.implements(IPayment)
39    grok.provides(IPayment)
40    grok.baseclass()
41
[9769]42    logger_name = 'waeup.kofa.${sitename}.payments'
43    logger_filename = 'payments.log'
44    logger_format_str = '"%(asctime)s","%(user)s",%(message)s'
45
46    def logger_info(self, comment=None):
47        """Get the logger's info method.
48        """
49        self.logger.info('%s' % comment)
50        return
51
[6864]52    def __init__(self):
53        super(Payment, self).__init__()
[8194]54        self.creation_date = datetime.utcnow()
[6869]55        self.p_id = None
[6864]56        return
57
[6869]58    @property
59    def state(self):
60        return payment_states.getTermByToken(self.p_state).title
61
62    @property
63    def category(self):
[9405]64        utils = getUtility(IKofaUtils)
65        return utils.PAYMENT_CATEGORIES[self.p_category]
[6869]66
[6864]67class OnlinePayment(Payment):
68    """This is an online payment.
69    """
70    grok.implements(IOnlinePayment)
71    grok.provides(IOnlinePayment)
72
73    def __init__(self):
74        super(OnlinePayment, self).__init__()
[6869]75        p_id = None
[6864]76        return
77
[8420]78    def approve(self):
79        "Approve online payment and set to paid."
80        self.r_amount_approved = self.amount_auth
81        self.r_code = u'AP'
82        self.p_state = 'paid'
[8429]83        user = get_current_principal()
[8434]84        if user is None:
85            # in tests
86            usertitle = 'system'
87        else:
[8758]88            usertitle = getattr(user, 'public_name', None)
89            if not usertitle:
90                usertitle = user.title
[8434]91        r_desc = _('Payment approved by ${a}', mapping = {'a': usertitle})
[8429]92        portal_language = getUtility(IKofaUtils).PORTAL_LANGUAGE
93        self.r_desc = translate(r_desc, 'waeup.kofa',
94            target_language=portal_language)
[8420]95        self.payment_date = datetime.utcnow()
[9505]96        # Update catalog
97        notify(grok.ObjectModifiedEvent(self))
[8420]98        return
99
[7811]100OnlinePayment = attrs_to_fields(OnlinePayment)
Note: See TracBrowser for help on using the repository browser.