## Script (Python) "request_transfer"
##bind container=container
##bind context=context
##bind namespace=
##bind script=script
##bind subpath=traverse_subpath
##parameters=
##title=
##
# $Id: request_transfer.py 1332 2007-01-20 23:53:00Z henrik $
"""
pay online
"""
import logging
from urllib import urlencode
logger = logging.getLogger('EPayment.')
import DateTime
lt = context.portal_layouts
request = context.REQUEST
students = context.portal_url.getPortalObject().campus.students

student_id = context.getStudentId()
if student_id is None:
    return request.RESPONSE.redirect("%s/srp_anonymous_view" % context.portal_url())

student = getattr(students,student_id)
sbrain = context.students_catalog(id=student_id)[0]
payments = getattr(student,'payments').objectIds()
payed = False
for payment in payments:
    if payment.startswith('transfer'):
        payed = True
        break

# for testing of transfer forms
payed = True      
        
if payed:
    return context.request_transfer_form(rendered = None,
                                 psm = None,
                                 payed = True,
                                 )

validate = request.has_key("cpsdocument_create_button")
res,psm,ds = lt.renderLayout(layout_id= 'student_transfer',
                      schema_id= 'epayment',
                      context=context,
                      mapping=validate and request,
                      ob={},
                      layout_mode="create",
                      formaction = "request_transfer",
                      button = 'Start'
                      )
if psm == 'invalid':
    psm = 'Please correct your errors!'
    return context.request_transfer_form(rendered = res,
                                 psm = psm,
                                 mode = 'edit',
                                 ds = ds,
                                 )
elif psm == '':
    return context.request_transfer_form(rendered = res,
                                 psm = None,
                                 mode = 'edit',
                                 ds = ds,
                                 )
elif psm == 'valid':
    pass
if "payments" not in student.objectIds():
    student.invokeFactory('PaymentsFolder','payments')
    payments = getattr(student,'payments')
    d = {}
    d['Title'] = 'Payments'
    payments.getContent().edit(mapping=d)
    wftool.doActionFor(payments,'open')
else:
    payments = getattr(student,'payments')
#from Products.zdb import set_trace; set_trace()
info = {}
order_id = ds.get('pin_n')
p_id = "transfer_%s" % order_id
now = DateTime.DateTime()
info['date'] = now
info['amount'] = "n/a"
pin = info['order_id'] = ds.get('pin')
info['type_code'] = "transfer_%s" % pin
info['type_description'] = 'Transfer Form SC %s' % pin
payments.invokeFactory('Payment', p_id)
payment = getattr(payments,p_id)
wftool = context.portal_workflow
wftool.doActionFor(payment,'open')
payment.getContent().edit(mapping=info)
wftool.doActionFor(payment,'close')
return context.request_transfer_form(rendered = None,
                                 psm = None,
                                 payed = True,
                                 )

