## $Id: browser.py 18034 2025-03-10 16:40:53Z henrik $
##
## Copyright (C) 2012 Uli Fouquet & Henrik Bettermann
## This program is free software; you can redistribute it and/or modify
## it under the terms of the GNU General Public License as published by
## the Free Software Foundation; either version 2 of the License, or
## (at your option) any later version.
##
## This program is distributed in the hope that it will be useful,
## but WITHOUT ANY WARRANTY; without even the implied warranty of
## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
## GNU General Public License for more details.
##
## You should have received a copy of the GNU General Public License
## along with this program; if not, write to the Free Software
## Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
##
import httplib
import hashlib
import grok
from waeup.kofa.students.interfaces import IStudentsUtils
from zope.component import getUtility
from kofacustom.nigeria.interswitch.browser import (
module_activated,
InterswitchPaymentRequestWebservicePageApplicant,
InterswitchPaymentRequestWebservicePageStudent,
InterswitchPaymentVerifyWebservicePageApplicant,
InterswitchPaymentVerifyWebservicePageStudent,
InterswitchPageStudent, InterswitchPageApplicant,
)
from kofacustom.iuokada.students.interfaces import ICustomStudentOnlinePayment
from kofacustom.iuokada.applicants.interfaces import ICustomApplicantOnlinePayment
from kofacustom.iuokada.interfaces import MessageFactory as _
PRODUCT_ID = '7922'
SITE_NAME = 'iuokada.waeup.org'
PROVIDER_ACCT = '0773411069'
PROVIDER_BANK_ID = '31'
PROVIDER_ITEM_NAME = 'WAeAC'
INSTITUTION_NAME = 'IUOkada'
CURRENCY = '566'
GATEWAY_AMT = 250.0
#MAC = 'CEF793CBBE838AA0CBB29B74D571113B4EA6586D3BA77E7CFA0B95E278364EFC4526ED7BD255A366CDDE11F1F607F0F844B09D93B16F7CFE87563B2272007AB3' # must be provided by Interswitch
MAC = '4D8723F33D728BE3F4A77B2DFB3F57B0BCF2DD818759D54A87B2A60874067F28D94F2B91E29BFB884F920F48E0973D826835A8F2D6F74220C64EDE4DE00E45AA'
POST_ACTION = 'https://webpay.interswitchng.com/paydirect/pay'
#POST_ACTION = 'https://sandbox.interswitchng.com/webpay/pay'
HOST = 'webpay.interswitchng.com'
#HOST = 'sandbox.interswitchng.com'
URL = '/paydirect/api/v1/gettransaction.json'
#URL = '/webpay/api/v1/gettransaction.json'
httplib.HTTPSConnection.debuglevel = 0
HTTPS = True
BANK_ACCOUNTS = {
'access': ('1228744877', '117'),
'parentsconsult': ('1228747029', '117'),
'health_insurance': ('1228744884', '117'),
'municipal_returning': ('0040621193','31'),
'clearance': ('0040621193','31'),
'develop': ('0040621193','31'),
'medical_screening': ('1311220657','117'),
'conv': ('0040621193','31'),
'registration_fresh': ('0040621193','31'),
'science': ('0040621193','31'),
'id_card': ('0040621193','31'),
'alumni': ('1311974981','117'),
'lab_support': ('0040621193','31'),
'registration_return': ('0040621193','31'),
'book': ('1228744877','117'),
'waecneco': ('0040621193','31'),
'jambver': ('0040621193','31'),
'pg_other': ('0040621193','31'),
'municipal_fresh': ('0040621193','31'),
'matric': ('0040621193','31')
}
class CustomInterswitchPageStudent(InterswitchPageStudent):
""" View which sends a POST request to the Interswitch
CollegePAY payment gateway.
"""
grok.context(ICustomStudentOnlinePayment)
action = POST_ACTION
site_name = SITE_NAME
currency = CURRENCY
product_id = PRODUCT_ID
mac = MAC
gateway_amt = GATEWAY_AMT
def update(self):
student_utils = getUtility(IStudentsUtils)
if not module_activated(
self.context.student.current_session, self.context):
self.flash(_('Forbidden'), type='danger')
self.redirect(self.url(self.context, '@@index'))
return
error = self.init_update()
if error:
self.flash(error, type='danger')
self.redirect(self.url(self.context, '@@index'))
return
# Already now it becomes an Interswitch payment. We set the net amount
# and add the gateway amount.
if not self.context.r_company:
self.context.net_amt = self.context.amount_auth
self.context.amount_auth += self.gateway_amt
self.context.gateway_amt = self.gateway_amt
self.context.r_company = u'interswitch'
student = self.student
xmldict = self.xmldict
# Provider data
xmldict['detail_ref'] = self.context.p_id
xmldict['provider_acct'] = PROVIDER_ACCT
xmldict['provider_bank_id'] = PROVIDER_BANK_ID
xmldict['provider_item_name'] = PROVIDER_ITEM_NAME
xmldict['institution_acct'] = ''
xmldict['institution_bank_id'] = ''
provider_amt = 0.0
self.pay_item_id = ''
# Institution data
if self.context.p_category in (
'schoolfee', 'schoolfee40', 'secondinstal'):
self.pay_item_id = '101'
else:
# we use the same item_id for all sundry payments
self.pay_item_id = '102'
if self.context.p_category in (
'registration', 'registration_fresh', 'registration_return',
'required_combi', 'pg_other', 'jupeb_reg'):
provider_amt = 5000.0
if self.context.p_category in (
'schoolfee', 'schoolfee40') and student.is_jupeb:
provider_amt = 5000.0
if self.context.p_category.startswith('jupeb'):
self.pay_item_id = '102'
xmldict['provider_amt'] = 100 * provider_amt
xmldict['institution_item_name'] = self.context.category
xmldict['institution_name'] = INSTITUTION_NAME
xmldict['institution_amt'] = 100 * self.context.net_amt - (
100 * provider_amt)
if grok.getSite().__name__ == 'iuokada-cdl':
xmldict['institution_acct'] = '1229771245'
xmldict['institution_bank_id'] = '117'
if self.context.p_category.startswith('schoolfee'):
xmldict['institution_acct'] = '1828332878'
xmldict['institution_bank_id'] = '31'
else:
if self.context.p_option == 'access':
xmldict['institution_acct'] = '0040484781'
xmldict['institution_bank_id'] = '31'
elif self.context.p_option == 'first':
xmldict['institution_acct'] = '2021420049'
xmldict['institution_bank_id'] = '8'
elif self.context.p_option == 'zenith':
xmldict['institution_acct'] = '1011005811'
xmldict['institution_bank_id'] = '117'
else:
xmldict['institution_acct'] = '0040484781'
xmldict['institution_bank_id'] = '31'
# Overwrite above selection
sundry_acct = BANK_ACCOUNTS.get(self.context.p_category, None)
if sundry_acct is True:
xmldict['institution_acct'] = sundry_acct[0]
xmldict['institution_bank_id'] = sundry_acct[0]
if provider_amt == 0:
xmltext = """
""" % xmldict
else:
xmltext = """
""" % xmldict
# Overwrite xmltext above because we have to split required combi
if self.context.p_category == 'required_combi':
rp = student_utils._collect_required_payment_items(self.context.student)
academic_session = student_utils._getSessionConfiguration(self.context.p_session)
xmltext = """
""" % xmldict
item_id = 2
for cat in rp:
fee_name = cat + '_fee'
item_name = cat
item_amt = 100 * getattr(academic_session, fee_name, 0.0)
if item_name.startswith('registration'):
item_amt -= 100 * provider_amt
bank_id = BANK_ACCOUNTS[cat][1]
acct_num = BANK_ACCOUNTS[cat][0]
xmltext += """
""" % (item_id, item_name, item_amt, bank_id, acct_num)
item_id += 1
xmltext += """
""" % xmldict
self.xml_data = """""" % xmltext
self.amount_auth = int(100 * self.context.amount_auth)
hashargs = (
self.context.p_id +
PRODUCT_ID +
self.pay_item_id +
str(int(self.amount_auth)) +
self.site_redirect_url +
self.mac)
self.hashvalue = hashlib.sha512(hashargs).hexdigest()
return
class CustomInterswitchPageApplicant(InterswitchPageApplicant):
""" View which sends a POST request to the Interswitch
CollegePAY payment gateway.
"""
grok.context(ICustomApplicantOnlinePayment)
action = POST_ACTION
site_name = SITE_NAME
currency = CURRENCY
product_id = PRODUCT_ID
mac = MAC
gateway_amt = GATEWAY_AMT
def update(self):
if not module_activated(
self.context.__parent__.__parent__.year, self.context):
self.flash(_('Forbidden'), type='danger')
self.redirect(self.url(self.context, '@@index'))
return
error = self.init_update()
if error:
self.flash(error, type='danger')
self.redirect(self.url(self.context, '@@index'))
return
# Already now it becomes an Interswitch payment. We set the net amount
# and add the gateway amount.
if not self.context.r_company:
self.context.net_amt = self.context.amount_auth
self.context.amount_auth += self.gateway_amt
self.context.gateway_amt = self.gateway_amt
self.context.r_company = u'interswitch'
self.amount_auth = int(100 * self.context.amount_auth)
xmldict = {}
provider_amt = 0.0
self.pay_item_id = '101'
xmldict['institution_acct'] = '1011005811'
xmldict['institution_bank_id'] = '117'
if grok.getSite().__name__ == 'iuokada-cdl':
xmldict['institution_acct'] = '1229774710'
xmldict['institution_bank_id'] = '117'
xmldict['detail_ref'] = self.context.p_id
xmldict['provider_amt'] = 100 * provider_amt
xmldict['provider_acct'] = PROVIDER_ACCT
xmldict['provider_bank_id'] = PROVIDER_BANK_ID
xmldict['provider_item_name'] = PROVIDER_ITEM_NAME
xmldict['institution_item_name'] = self.context.category
xmldict['institution_name'] = INSTITUTION_NAME
xmldict['institution_amt'] = 100 * self.context.net_amt
if not self.context.provider_amt:
self.context.provider_amt = provider_amt
self.context.amount_auth += provider_amt
if provider_amt == 0:
xmltext = """
""" % xmldict
else:
xmltext = """
""" % xmldict
self.xml_data = """""" % xmltext
self.amount_auth = int(100 * self.context.amount_auth)
hashargs = (
self.context.p_id +
PRODUCT_ID +
self.pay_item_id +
str(int(self.amount_auth)) +
self.site_redirect_url +
self.mac)
self.hashvalue = hashlib.sha512(hashargs).hexdigest()
return
class CustomInterswitchPaymentRequestWebservicePageStudent(
InterswitchPaymentRequestWebservicePageStudent):
"""Request webservice view for the CollegePAY gateway
"""
grok.context(ICustomStudentOnlinePayment)
product_id = PRODUCT_ID
gateway_host = HOST
gateway_url = URL
mac = MAC
class CustomInterswitchPaymentVerifyWebservicePageStudent(
InterswitchPaymentVerifyWebservicePageStudent):
"""Payment verify view for the CollegePAY gateway
"""
grok.context(ICustomStudentOnlinePayment)
product_id = PRODUCT_ID
gateway_host = HOST
gateway_url = URL
mac = MAC
class CustomInterswitchPaymentRequestWebservicePageApplicant(
InterswitchPaymentRequestWebservicePageApplicant):
"""Request webservice view for the CollegePAY gateway
"""
grok.context(ICustomApplicantOnlinePayment)
product_id = PRODUCT_ID
gateway_host = HOST
gateway_url = URL
mac = MAC
class CustomInterswitchPaymentVerifyWebservicePageApplicant(
InterswitchPaymentVerifyWebservicePageApplicant):
"""Payment verify view for the CollegePAY gateway
"""
grok.context(ICustomApplicantOnlinePayment)
product_id = PRODUCT_ID
gateway_host = HOST
gateway_url = URL
mac = MAC
# PAYDirect added on 19/05/2021
from kofacustom.nigeria.interswitch.paydirectbrowser import (
PAYDirectPageStudent, PAYDirectPageApplicant,
StudentRefNumberSlip, ApplicantRefNumberSlip,
)
PAYDIRECT_HOST = 'orion.interswitchng.com'
PAYDIRECT_URL = '/bookonhold/bookonhold.asmx'
MERCHANT_ID = '8124'
class CustomPAYDirectPageStudent(PAYDirectPageStudent):
"""Inform student how to proceed
"""
grok.context(ICustomStudentOnlinePayment)
gateway_amt = GATEWAY_AMT
merchant_id = MERCHANT_ID
gateway_url = PAYDIRECT_URL
gateway_host = PAYDIRECT_HOST
https = True
class CustomPAYDirectPageApplicant(PAYDirectPageApplicant):
""" Inform applicant how to proceed.
"""
grok.context(ICustomApplicantOnlinePayment)
gateway_amt = GATEWAY_AMT
merchant_id = MERCHANT_ID
gateway_url = PAYDIRECT_URL
gateway_host = PAYDIRECT_HOST
https = True
class CustomStudentRefNumberSlip(StudentRefNumberSlip):
"""Deliver a PDF slip of the context.
"""
merchant_id = MERCHANT_ID
class CustomApplicantRefNumberSlip(ApplicantRefNumberSlip):
"""Deliver a PDF slip of the context.
"""
merchant_id = MERCHANT_ID