[8028] | 1 | ##Script (Python) "pay_online"
|
---|
| 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_etranzact_accept.py 8121 2012-04-12 09:01:44Z henrik $
|
---|
| 11 | """
|
---|
| 12 | pay online
|
---|
| 13 | """
|
---|
| 14 | from urllib import urlencode
|
---|
| 15 | import logging
|
---|
| 16 | logger = logging.getLogger('Skins.pay_etranzact_accept')
|
---|
| 17 | import DateTime
|
---|
| 18 |
|
---|
| 19 | if context.portal_membership.isAnonymousUser():
|
---|
| 20 | return None
|
---|
| 21 |
|
---|
| 22 | try:
|
---|
| 23 | from Products.zdb import set_trace
|
---|
| 24 | except:
|
---|
| 25 | def set_trace():
|
---|
| 26 | pass
|
---|
| 27 | request = context.REQUEST
|
---|
| 28 | wftool = context.portal_workflow
|
---|
| 29 | students = context.portal_url.getPortalObject().campus.students
|
---|
| 30 |
|
---|
| 31 |
|
---|
| 32 | student_id = context.getStudentId()
|
---|
| 33 | student = getattr(students,student_id)
|
---|
| 34 |
|
---|
| 35 | student_record = context.students_catalog.getRecordByKey(student_id)
|
---|
| 36 | #amount,description = context.getSchoolFee(student_record.faculty,student_record.session,student_record.course)
|
---|
| 37 | info = {}
|
---|
| 38 | info['action'] = 'pay_etranzact_accept'
|
---|
| 39 | info['student'] = student_record
|
---|
| 40 | info['payment_possible'] = False
|
---|
| 41 | info['amount'] = '0'
|
---|
| 42 | info['bank'] = ''
|
---|
| 43 | info['type_description'] = ''
|
---|
| 44 | info['pay_bill_to'] = ''
|
---|
| 45 |
|
---|
[8121] | 46 | amount = info['amount'] = 34250
|
---|
[8028] | 47 |
|
---|
| 48 |
|
---|
| 49 | info['surcharge'] = '0' # Uniben doesn't show the surcharge on the slip
|
---|
| 50 | info['payment_possible'] = True
|
---|
| 51 | info['type_description'] = 'Acceptance Fee'
|
---|
| 52 | info['pay_bill_to'] = student_record.name
|
---|
| 53 | info['pay_ship_to'] = "University of Benin"
|
---|
| 54 | info['student_id'] = student_id
|
---|
| 55 | info['student_name'] = student_record.name
|
---|
| 56 | info['student_email'] = student_record.email
|
---|
| 57 | #info['session_id'] = student_record.session # this holds only for new students und must be replaced when also previous session students will pay online !!!!!!
|
---|
| 58 | info['session_id'] = student_record.session
|
---|
| 59 | info['type'] = 'etranzact'
|
---|
| 60 | info['status'] = 'started'
|
---|
| 61 | info['item'] = student_record.course
|
---|
| 62 | info['category'] = 'acceptance'
|
---|
| 63 | now = DateTime.DateTime()
|
---|
| 64 | info['date'] = now
|
---|
| 65 | timestamp = "%d" % int(now.timeTime()*1000)
|
---|
| 66 | info['order_id'] = "%s%s" % (student_id[1:],timestamp)
|
---|
| 67 | p_id = "p%s" % timestamp
|
---|
| 68 |
|
---|
| 69 | if student_id is None:
|
---|
| 70 | return context.REQUEST.RESPONSE.redirect("%s/srp_anonymous_view" % context.portal_url())
|
---|
| 71 |
|
---|
| 72 | if "payments" not in student.objectIds():
|
---|
| 73 | student.invokeFactory('PaymentsFolder','payments')
|
---|
| 74 | payments = getattr(student,'payments')
|
---|
| 75 | d = {}
|
---|
| 76 | d['Title'] = 'Payments'
|
---|
| 77 | payments.getContent().edit(mapping=d)
|
---|
| 78 | wftool.doActionFor(payments,'open')
|
---|
| 79 | else:
|
---|
| 80 | payments = getattr(student,'payments')
|
---|
| 81 | if request.has_key('epayment'):
|
---|
| 82 | return context.etranzact_form(info=info)
|
---|
| 83 |
|
---|
| 84 | payments.invokeFactory('Payment', p_id)
|
---|
| 85 | payment = getattr(payments,p_id)
|
---|
| 86 | wftool.doActionFor(payment,'open')
|
---|
| 87 | d = {}
|
---|
| 88 | d.update(info)
|
---|
| 89 | payment.getContent().edit(mapping=d)
|
---|
| 90 | logger.info('%(student_id)s initiated eTranzact acceptance fee payment with order_id %(order_id)s' % info)
|
---|
| 91 |
|
---|
| 92 | return context.payments_view() |
---|