source: main/waeup.kofa/branches/henrik-regista/src/waeup/ikoba/payments/payment.py @ 11962

Last change on this file since 11962 was 11949, checked in by Henrik Bettermann, 10 years ago

Change of name.

  • Property svn:keywords set to Id
File size: 3.4 KB
Line 
1## $Id: payment.py 11949 2014-11-13 14:40:27Z 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.ikoba.interfaces import IIkobaUtils
28from waeup.ikoba.interfaces import MessageFactory as _
29from waeup.ikoba.payments.interfaces import (
30    IPayment, IOnlinePayment,
31    payment_states)
32from waeup.ikoba.utils.helpers import attrs_to_fields, get_current_principal
33from waeup.ikoba.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.ikoba.${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 p_state_title(self):
60        return payment_states.getTermByToken(self.p_state).title
61
62    @property
63    def category(self):
64        utils = getUtility(IIkobaUtils)
65        return utils.PAYMENT_CATEGORIES.get(self.p_category, None)
66
67    @property
68    def display_item(self):
69        ikoba_utils = getUtility(IIkobaUtils)
70        return ikoba_utils.getPaymentItem(self)
71
72class OnlinePayment(Payment):
73    """This is an online payment.
74    """
75    grok.implements(IOnlinePayment)
76    grok.provides(IOnlinePayment)
77
78    def __init__(self):
79        super(OnlinePayment, self).__init__()
80        p_id = None
81        return
82
83    def approve(self):
84        "Approve online payment and set to paid."
85        self.r_amount_approved = self.amount_auth
86        self.r_code = u'AP'
87        self.p_state = 'paid'
88        user = get_current_principal()
89        if user is None:
90            # in tests
91            usertitle = 'system'
92        else:
93            usertitle = getattr(user, 'public_name', None)
94            if not usertitle:
95                usertitle = user.title
96        r_desc = _('Payment approved by ${a}', mapping = {'a': usertitle})
97        portal_language = getUtility(IIkobaUtils).PORTAL_LANGUAGE
98        self.r_desc = translate(r_desc, 'waeup.ikoba',
99            target_language=portal_language)
100        self.payment_date = datetime.utcnow()
101        # Update catalog
102        notify(grok.ObjectModifiedEvent(self))
103        return
104
105OnlinePayment = attrs_to_fields(OnlinePayment, omit=['display_item'])
Note: See TracBrowser for help on using the repository browser.