source: WAeUP_SRP/trunk/skins/waeup_futminna/pay_interswitch.py @ 4900

Last change on this file since 4900 was 4861, checked in by Henrik Bettermann, 15 years ago

changes made for resolving futminna #84

File size: 7.4 KB
Line 
1## Script (Python) "pay_interswitch"
2##bind container=container
3##bind context=context
4##bind namespace=
5##bind script=script
6##bind subpath=traverse_subpath
7##parameters=
8##title=
9##
10# $Id: pay_interswitch.py 2619 2007-11-10 17:39:36Z henrik $
11"""
12pay online
13"""
14from urllib import urlencode
15import logging
16logger = logging.getLogger('Skins.pay_interswitch')
17import DateTime
18
19if context.portal_membership.isAnonymousUser():
20    return None
21
22try:
23    from Products.zdb import set_trace
24except:
25    def set_trace():
26        pass
27request = context.REQUEST
28wftool = context.portal_workflow
29students = context.portal_url.getPortalObject().campus.students
30
31
32student_id = context.getStudentId()
33student = getattr(students,student_id)
34
35student_record = context.students_catalog.getRecordByKey(student_id)
36#amount,description = context.getSchoolFee(student_record.faculty,student_record.session,student_record.course)
37info = {}
38info['student'] = student_record
39info['payment_possible'] = False
40info['amount'] = '0'
41info['bank'] = ''
42info['type_description'] = ''
43info['pay_bill_to'] = ''
44fee_dict = context.getSchoolFee(student_record)
45fulltime = student_record.mode.endswith('_ft')
46
47if not fee_dict:
48    return context.interswitch_form(info=info)
49
50info['site_id'] = '117'
51info['currency_id'] = '566'
52
53if student_record.mode in ('pg_ft'):
54    pay_item_id = "11703"
55elif student_record.review_state == 'cleared_and_validated' and student_record.level in ('100'):
56    pay_item_id = "11700"
57elif student_record.review_state == 'cleared_and_validated' and student_record.level in ('200'):
58    pay_item_id = "11701"   
59elif student_record.review_state == 'returning' and student_record.level in ('100'):
60    pay_item_id = "11701"
61elif student_record.review_state == 'returning' and student_record.level in ('200'):
62    pay_item_id = "11702"
63elif student_record.review_state == 'returning' and student_record.level in ('300'):
64    pay_item_id = "11703"
65elif student_record.review_state == 'returning' and student_record.level in ('400','500'):
66    pay_item_id = "11704"
67else:
68    pay_item_id = ""
69   
70info['bank'] = ''
71info['payment_possible'] = True
72info['type_description'] = fee_dict['description']
73info['pay_bill_to'] = student_record.name
74info['student_id'] = student_id
75info['student_name'] = student_record.name
76info['type'] = 'online'
77info['status'] = 'started'
78info['session_id'] = fee_dict['next_session_id']
79info['item'] = student_record.course
80info['category'] = 'schoolfee'
81info['student_email'] = student_record.email
82now = DateTime.DateTime()
83info['date'] = now
84info['pay_ship_to'] = "Federal University of Technology, Minna, Nigeria"
85timestamp = "%d" % int(now.timeTime()*1000)
86info['order_id'] = "%s%s" % (student_id[1:],timestamp)
87p_id = "p%s" % timestamp
88
89
90info['surcharge'] = 0  # students don't have to pay the surcharge, FUT is paying for them
91interswitch_amount = 300
92info['amount'] = amount = fee_dict['all']
93total_amount = 100*int(amount)
94
95
96if student_id is None:
97    return context.REQUEST.RESPONSE.redirect("%s/srp_anonymous_view" % context.portal_url())
98
99if True:
100    info['action'] = "https://webpay.interswitchng.com/paydirect/webpay/pay.aspx"
101else:
102    info['action'] = "%s/payments/%s/simulate_callback" % (student.absolute_url(),p_id)
103
104
105if "payments" not in student.objectIds():
106    student.invokeFactory('PaymentsFolder','payments')
107    payments = getattr(student,'payments')
108    d = {}
109    d['Title'] = 'Payments'
110    payments.getContent().edit(mapping=d)
111    wftool.doActionFor(payments,'open')
112else:
113    payments = getattr(student,'payments')
114if request.has_key('epayment'):
115    return context.interswitch_form(info=info)
116
117
118payments.invokeFactory('Payment', p_id)
119payment = getattr(payments,p_id)
120wftool.doActionFor(payment,'open')
121d = {}
122d.update(info)
123payment.getContent().edit(mapping=d)
124
125
126info['callback_url'] = "%s/payments/%s/interswitch_cb?echo=%s" % (student.absolute_url(),
127                                                                  p_id,
128                                                                  p_id)
129
130logger.info('%(student_id)s initiated online school fee payment with order_id %(order_id)s and callback url %(callback_url)s' % info)
131payment_fields = (('product_id','site_id'),
132                  ('site_redirect_url','callback_url'),
133                  ('Currency','currency_id'),
134                  ('cust_id','student_id'),
135                  ('cust_id_desc','type_description'),
136                  ('cust_name','student_name'),
137                  ('txn_ref','order_id'),
138                  ('Amount','amount'),
139                  )
140args = {}
141for arg,field in payment_fields:
142    args[arg] = info[field]
143
144bt_amount = 1500
145#fut_split = 0000 #not appicable
146fut_amount = amount - bt_amount - interswitch_amount
147
148xmldict = {}
149xmldict['detail_ref'] = args['txn_ref']
150xmldict['department'] = student_record.department
151xmldict['level'] = student_record.level
152xmldict['faculty'] = student_record.faculty
153xmldict['fut_amount'] = "%d" % int(100*fut_amount)
154xmldict['bt_amount'] = "%d" % int(100*bt_amount)
155#xmldict['fut_split'] = "%d" % int(100*fut_split)
156
157#students at all levels pay their school fees to different banks
158
159if student_record.mode == 'jm_ft':
160    xmldict['fut_acct'] = "000000000000"
161    xmldict['bank_id'] = '0'
162elif student_record.mode in ('pg_ft'):
163    xmldict['fut_acct'] = "2522040000134"
164    xmldict['bank_id'] = '8'
165elif student_record.review_state == 'cleared_and_validated' and student_record.level in ('100'):
166    xmldict['fut_acct'] = "0030001000017110"
167    xmldict['bank_id'] = '89'
168elif student_record.review_state == 'cleared_and_validated' and student_record.level in ('200'):
169    xmldict['fut_acct'] = "0591201005146"
170    xmldict['bank_id'] = '101'
171elif student_record.review_state == 'returning' and student_record.level in ('100'):   
172    xmldict['fut_acct'] = "0591201005146"
173    xmldict['bank_id'] = '101'
174elif student_record.level in ('200'):
175    xmldict['fut_acct'] = "6013803345"
176    xmldict['bank_id'] = '117' 
177elif student_record.level in ('300'):
178    xmldict['fut_acct'] = "2522040000134"
179    xmldict['bank_id'] = '8' 
180elif student_record.level in ('400','500'):
181    xmldict['fut_acct'] = "02530040000664"
182    xmldict['bank_id'] = '7'   
183#remedial students
184#elif student_record.level in ('000'):
185    #xmldict['fut_acct'] = "00000000000"
186    #xmldict['bank_id'] = '0'     
187else:
188    xmldict['fut_acct'] = "0000000000000"
189    xmldict['bank_id'] = '0'
190
191
192xmltext = """<payment_item_detail>
193<item_details detail_ref="%(detail_ref)s" college="FUT Minna" department="%(department)s" faculty="%(faculty)s">
194<item_detail item_id="1" item_name="FUT Minna School Fee" item_amt="%(fut_amount)s" bank_id="%(bank_id)s" acct_num="%(fut_acct)s" />
195<item_detail item_id="2" item_name="BT" item_amt="%(bt_amount)s" bank_id="89" acct_num="0061001000021095" />
196</item_details>
197</payment_item_detail>""" % xmldict
198
199info['xml_data'] = """<input type="hidden" name="xml_data" value='%s'  />""" % xmltext
200
201args['Amount'] = "%d" % (total_amount)
202args['site_name'] = "futminna.waeup.org"
203args['cust_name_desc'] = "Student Name"
204args['pay_item_id'] = pay_item_id
205args['pay_item_name'] = "FUT Minna Tuition Payments"
206args['payment_params'] = 'college_split'
207#args['xml_data'] = ''
208#args['xml_data'] = xmltext   # info['xml_data']can be used instead
209info['args'] = args
210
211return context.goto_interswitch_form(info=info)
Note: See TracBrowser for help on using the repository browser.