source: WAeUP_SRP/base/Payment.py @ 2927

Last change on this file since 2927 was 2926, checked in by Henrik Bettermann, 17 years ago

second trial to fix payment records and objects

  • Property svn:keywords set to Id
File size: 4.8 KB
Line 
1#-*- mode: python; mode: fold -*-
2from Globals import InitializeClass
3from AccessControl import ClassSecurityInfo
4
5from Products.CMFCore.utils import UniqueObject, getToolByName
6from Products.CMFCore.permissions import View
7from Products.CMFCore.permissions import ModifyPortalContent
8from Products.CPSCore.CPSBase import CPSBase_adder, CPSBaseFolder
9#from Products.CPSCore.CPSBase import CPSBaseDocument as BaseDocument
10from Products.CPSDocument.CPSDocument import CPSDocument
11from Products.CPSCore.CPSBase import CPSBaseBTreeFolder as BaseBTreeFolder
12from Products.WAeUP_SRP.WAeUPTables import AccommodationTable
13import Globals
14import DateTime
15import logging
16import re
17p_home = Globals.package_home(globals())
18i_home = Globals.INSTANCE_HOME
19
20class PaymentsFolder(CPSDocument): ###(
21    """
22    WAeUP PaymentsFolder containing Payment objects
23    """
24    meta_type = 'PaymentsFolder'
25    portal_type = meta_type
26    security = ClassSecurityInfo()
27
28    security.declareProtected(View,"Title")
29    def Title(self):
30        """compose title"""
31        return "Payments"
32
33
34    security.declareProtected(View,"updatePayments")
35    def updatePayments(self,force = None):
36        """upgrade all payments in folder"""
37        logger = logging.getLogger('PaymentsFolder.updatePayments')
38        #import pdb;pdb.set_trace()
39        for payment in self.aq_parent.objectValues():
40            student_record = self.students_catalog.getRecordByKey(self.getStudentId())
41            payment['updatePayment'](student_record,force=force)
42
43InitializeClass(PaymentsFolder)
44
45def addPaymentsFolder(container, id, REQUEST=None, **kw):
46    """Add a PaymentsFolder."""
47    ob = PaymentsFolder(id, **kw)
48    return CPSBase_adder(container, ob, REQUEST=REQUEST)
49###)
50
51class Payment(CPSDocument): ###(
52    """
53    WAeUP Payment containing Nothing
54    """
55    meta_type = 'Payment'
56    portal_type = meta_type
57    security = ClassSecurityInfo()
58
59    security.declareProtected(View,"Title") ###(
60    def Title(self):
61        """compose title"""
62        content = self.getContent()
63        description = getattr(content,'type_description','')
64        d = getattr(content,'date','')
65        #pay_date = "%s/%s/%s %s:%s:%s" %(d[:2],d[2:4],d[4:6],d[6:8],d[8:10],d[10:])
66        pay_date = d.strftime("%d/%m/%y %H:%M:%S")
67        amount = getattr(content,'amount','')
68        if not (description or pay_date or amount):
69            return self.getId()
70        return "%(description)s, Naira %(amount)s, %(pay_date)s" % vars()
71    ###)
72
73    security.declareProtected(View,"updatePayment")
74    def updatePayment(self,student_record,force=None):
75        doc = self.getContent()
76        status = getattr(doc,'status',None)
77        if status and status != 'started' and not force:
78            return
79        wftool = self.portal_workflow
80        d = {}
81        d['key'] = self.getId()
82        d['amount'] = doc.amount
83        category = ''
84        if doc.type_description.startswith('School'):
85            category = 'schoolfee'
86            sp = doc.type_description.rfind('/')
87            d['session_id'] = doc.type_description[sp-2:sp]
88            d['category'] = category # zb. schoolfee
89        while True:
90            if doc.resp_code == "SC":
91                p_type = "sc"
92                p_status = "paid"
93                if type(doc.order_id) != type(''):
94                    d['order_id'] = str(doc.order_id)
95                break
96
97            #if self.order_id.startswith('p'):
98            #    try:
99            #        self.payments_catalog.deleteRecord(self.order_id)
100            #    except:
101            #        pass
102            #    d['order_id'] = "%s%s" % (student_record.id[1:],self.aq_parent.getId()[1:])
103
104            p_type = "online"
105            if doc.resp_code in ("00","IP","AP"):
106                p_status = "paid"
107            elif doc.resp_code == '':
108                p_status = "started"
109            else:
110                p_status = "failed"
111            # don't set order_id it is already correct
112            break
113        d['type'] = p_type  # scratch card
114        d['item'] = getattr(student_record,'course','')
115        d['status'] = p_status
116        # d['resp_approved_amount'] = getattr(doc,'resp_approved_amount',None)
117        # d['resp_pay_reference'] = doc.resp_pay_reference
118        # d['resp_desc'] = doc.resp_desc
119        # d['resp_code'] = doc.resp_code
120        # d['resp_card_num'] = doc.resp_card_num
121        # d['date'] = getattr(doc,'date',None)
122
123        review_state = wftool.getInfoFor(self.aq_parent,'review_state',None)
124        if review_state == "closed":
125            wftool.doActionFor(self.aq_parent,'open')
126        doc.edit(mapping = d)
127        if review_state == "closed":
128            wftool.doActionFor(self.aq_parent,'close')
129
130InitializeClass(Payment)
131
132def addPayment(container, id, REQUEST=None, **kw):
133    """Add a Payment."""
134    ob = Payment(id, **kw)
135    return CPSBase_adder(container, ob, REQUEST=REQUEST)
136###)
Note: See TracBrowser for help on using the repository browser.