## Script (Python) "tranzact_cb"
##bind container=container
##bind context=context
##bind namespace=
##bind script=script
##bind subpath=traverse_subpath
##parameters=
##title=
##
# $Id: etranzact_cb.py 8235 2012-04-20 11:48:31Z henrik $
"""
payment callback
"""
import logging
logger = logging.getLogger('Skins.etranzact_cb')
from AccessControl import Unauthorized
import DateTime

if context.portal_membership.isAnonymousUser():
    return None

request = context.REQUEST
students = context.portal_url.getPortalObject().campus.students
wftool = context.portal_workflow
mtool = context.portal_membership
member = mtool.getAuthenticatedMember()
member_id = str(member)
#student_id = context.getStudentId()
access_info = context.waeup_tool.getAccessInfo(context)
student_id = access_info['student_id']
if not context.isSectionOfficer() and (student_id is None or student_id != member_id):
    logger.info('%s tried to access payment object of %s' % (member_id,student_id))
    referer = request.get('HTTP_REFERER','none')
    logger.info('%s:%s illegal access, referer = %s' % (member_id,student_id,referer))
    real_ip = request.get('HTTP_X_REAL_IP',"none")
    logger.info('%s:%s illegal access, real_x_ip = %s' % (member_id,student_id,real_ip))
    return context.REQUEST.RESPONSE.redirect("%s/srp_anonymous_view" % context.portal_url())

referer = request.get('HTTP_REFERER','none')
real_ip = request.get('HTTP_X_REAL_IP',"none")
logger.info('%s, callback referer = %s, IP = %s' % (student_id,referer,real_ip))

ontest = False

if not ontest and not 'etranzact' in referer and not 'waeup.org' in referer:
    logger.info('%s, wrong callback referer %s, callback rejected, IP = %s' % (student_id,referer,real_ip))
    return request.RESPONSE.redirect("%s/waeup_document_view" % context.absolute_url())

student = getattr(students,student_id)

success = request.get('SUCCESS')

logger.info('%s, SUCCESS: %s' % (member,success))

if not 'COL1' in success:
    logger.info('%s requeried payment %s for %s without success' % (member,context.getId(),student_id))
    return request.RESPONSE.redirect("%s/waeup_document_view" % context.absolute_url())

success = request.get('SUCCESS').split('&')
success_dict = dict([tuple(i.split('=')) for i in success])

pay_doc = context.getContent()

oid = pay_doc['order_id']
col1 = success_dict['COL1']

if oid[len(oid)-8:len(oid)] != col1[len(col1)-8:len(col1)] and not ontest :
    logger.info('%s requeried payment %s for %s but wrong COL1 %s returned' % (member,context.getId(),student_id,success_dict['COL1']))
    return request.RESPONSE.redirect("%s/waeup_document_view" % context.absolute_url())

if float(pay_doc['amount']) != float(success_dict['TRANS_AMOUNT']) and not ontest :
    logger.info('%s requeried payment %s for %s but wrong amount %s returned' % (member,context.getId(),student_id,success_dict['TRANS_AMOUNT']))
    return request.RESPONSE.redirect("%s/waeup_document_view" % context.absolute_url())

pd = {}
pd['resp_desc'] = success_dict['TRANS_DESCR'].replace('%20',' ')
pd['resp_pay_reference'] = success_dict['RECEIPT_NO']
pd['resp_code'] = 'ET'
pd['resp_approved_amount'] = success_dict['TRANS_AMOUNT']
pd['status'] = 'paid'

pay_doc.edit(mapping = pd)

s_brain = context.students_catalog(id=student_id)[0]
session = s_brain.session

if pay_doc.category == 'schoolfee':
    next_info = context.getNextInfo(s_brain)
    next_session_id = next_info['next_session_id']
    next_session_str = next_info['next_session_str']
    next_level_id = next_info['next_level_id']
    next_transition = next_info['next_transition']
    next_verdict = next_info['next_verdict']
    next_previous_verdict = next_info['next_previous_verdict']
    if context.getStudentReviewState() == "school_fee_paid":
        logger.info('%s paid school_fee in state school_fee_paid' % (student_id))
    else:
        study_course = getattr(student,'study_course')
        try:
            wftool.doActionFor(study_course,'open')
        except:
            pass
        verdict = s_brain.verdict
        if next_previous_verdict == 'N/A':
            next_previous_verdict = ''
        study_course.getContent().edit(mapping= {'current_level': next_level_id,
                                                 'current_session': next_session_id,
                                                 'current_verdict': next_verdict,
                                                 'previous_verdict': next_previous_verdict,
                                                 })
        if next_transition:
            wftool.doActionFor(student,next_transition)


elif pay_doc.category == 'hostel_maintenance':

    ## callback function for accommodation_catalog method
    data={}
    data['acco_maint_date'] = pay_doc.date
    data['catkey'] =student_id + '|' + pay_doc.session_id
    data['acco_maint_fee'] = pay_doc.amount
    data['acco_maint_pay_id'] = context.getId()
    data['reservation_status'] = 'maintenance_fee_paid'
    context.accommodation_catalog.modifyRecord(**data)

    ## callback function for accommodation object method (deactivated since March 2011)
    #acco_info = context.getAccommodationInfo()
    #d = {}
    #d['acco_maint_date'] = pay_doc.date
    #d['acco_maint_fee'] = pay_doc.amount
    #d['acco_maint_pay_id'] = context.getId()
    #try:
    #    acco_info['acco_doc'].edit(mapping=d)
    #except:
    #    logger.info('%s requeried payment though maintenance already paid' % student_id)
    #try:
    #    wftool.doActionFor(acco_info['acco'],'pay_maintenance_fee',dest_container=acco_info['acco'])
    #except:
    #    logger.info('%s no workflow action pay_maintenance_fee' % student_id)

elif pay_doc.category == 'acceptance':
    if context.getStudentReviewState() in ('admitted', 'objection_raised'):
        logger.info('%s paid acceptance fee' % (student_id))
        current = DateTime.DateTime()
        wf = context.portal_workflow
        info = context.getClearanceInfo()
        wftool.doActionFor(student,'enter_clearance_pin')
        context.waeup_tool.changeWorkflowState(info['clear'], 'opened')
        context.waeup_tool.changeWorkflowState(info['app'], 'closed')
        dc = {}
        app_doc = info['app_doc']
        #dc['clr_ac_pin'] = pay_doc.order_id
        dc['clr_ac_date'] = current
        dc['entry_date'] = current
        info['clear_doc'].edit(mapping = dc)
        if info['penalty']:
            logger.info('%s started late clearance' % (info['id']))
        #return redirect("%s/clearance_edit_form" % info['clear'].absolute_url())

logger.info('%s received valid callback' % student_id)

#review_state = wftool.getInfoFor(context,'review_state',None)
#if review_state == 'opened':
#    wftool.doActionFor(context,'close')
context.waeup_tool.changeWorkflowState(context, 'closed')

return request.RESPONSE.redirect("%s/waeup_document_view" % context.absolute_url())
