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

Last change on this file since 9840 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
Line 
1## $Id: payment.py 9769 2012-12-05 08:32:11Z 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"""
19These are the payment tickets.
20"""
21import grok
22from datetime import datetime
23from grok import index
24from zope.event import notify
25from zope.component import getUtility
26from zope.i18n import translate
27from waeup.kofa.interfaces import IKofaUtils
28from waeup.kofa.interfaces import MessageFactory as _
29from waeup.kofa.payments.interfaces import (
30    IPayment, IOnlinePayment,
31    payment_states)
32from waeup.kofa.utils.helpers import attrs_to_fields, get_current_principal
33from waeup.kofa.utils.logger import Logger
34
35class Payment(grok.Container, Logger):
36    """This is a payment.
37    """
38    grok.implements(IPayment)
39    grok.provides(IPayment)
40    grok.baseclass()
41
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
52    def __init__(self):
53        super(Payment, self).__init__()
54        self.creation_date = datetime.utcnow()
55        self.p_id = None
56        return
57
58    @property
59    def state(self):
60        return payment_states.getTermByToken(self.p_state).title
61
62    @property
63    def category(self):
64        utils = getUtility(IKofaUtils)
65        return utils.PAYMENT_CATEGORIES[self.p_category]
66
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__()
75        p_id = None
76        return
77
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'
83        user = get_current_principal()
84        if user is None:
85            # in tests
86            usertitle = 'system'
87        else:
88            usertitle = getattr(user, 'public_name', None)
89            if not usertitle:
90                usertitle = user.title
91        r_desc = _('Payment approved by ${a}', mapping = {'a': usertitle})
92        portal_language = getUtility(IKofaUtils).PORTAL_LANGUAGE
93        self.r_desc = translate(r_desc, 'waeup.kofa',
94            target_language=portal_language)
95        self.payment_date = datetime.utcnow()
96        # Update catalog
97        notify(grok.ObjectModifiedEvent(self))
98        return
99
100OnlinePayment = attrs_to_fields(OnlinePayment)
Note: See TracBrowser for help on using the repository browser.