source: WAeUP_SRP/trunk/skins/waeup_student/reserve_accommodation.py @ 1160

Last change on this file since 1160 was 1140, checked in by Henrik Bettermann, 18 years ago

logging messages specified

  • Property svn:keywords set to Id
File size: 4.2 KB
Line 
1##parameters=REQUEST
2# $Id: reserve_accommodation.py 1140 2006-12-27 21:51:27Z henrik $
3"""
4process the the accommodation reservation
5"""
6import DateTime
7current = DateTime.DateTime()
8pr = context.portal_registration
9wftool = context.portal_workflow
10lt = context.portal_layouts
11info = context.getAccommodationInfo()
12
13import logging
14logger = logging.getLogger('Student.Accommodation.Reserve')
15
16#if info is None:
17#    return context.REQUEST.RESPONSE.redirect("%s/srp_anonymous_view" % context.portal_url())
18
19if info is None:
20    member_id = str(context.portal_membership.getAuthenticatedMember())
21    logger.info('"%s","tried to reserve accommodation"' % (member_id))
22    return context.REQUEST.RESPONSE.redirect("%s/srp_invalid_access" % context.portal_url())
23
24student = info['student']
25acco_id = info['acco_id']
26session = acco_id[-4:]
27mode = 'create'
28if info['review_state'] != 'cleared_and_validated':
29    return context.REQUEST.RESPONSE.redirect("%s/no_booking_allowed" % info['student'].absolute_url())
30validate = REQUEST.has_key("cpsdocument_create_button")
31if info.has_key('acco') and info['acco']:
32    validate = REQUEST.has_key("cpsdocument_edit_button")
33    if info['acco_review_state'] == "maintenance_fee_paid":
34        return context.REQUEST.RESPONSE.redirect("%s/accommodation_view" % info['acco'].absolute_url())
35    else:
36        mode = 'edit'
37d = {}
38button = "Book"
39if mode == 'edit':
40    info = context.getStudentInfo()
41    d['acco_res_date'] = info['acco_doc'].acco_res_date
42    d['acco_res_sc_pin'] = info['acco_doc'].acco_res_sc_pin
43    d['student_status'] = info['acco_doc'].student_status
44    d['bed'] = info['acco_doc'].bed
45    d['session'] = info['acco_doc'].session
46    button = "Pay Maintainance Fee"
47res,psm,ds = lt.renderLayout(layout_id= 'student_accommodation_fe',
48                      schema_id= 'student_accommodation',
49                      context=context,
50                      mapping=validate and REQUEST,
51                      ob=d,
52                      layout_mode=mode,
53                      formaction = "reserve_accommodation",
54                      button = button
55                      )
56if psm == 'invalid':
57    return context.accommodation_pin_edit_form(rendered = res,
58                                 psm = "Please correct your input!",
59                                 #psm = "%s, %s" % (psm,ds),
60                                 mode = mode,
61                                 ds = ds,
62                                 )
63elif psm == '':
64    return context.accommodation_pin_edit_form(rendered = res,
65                                 psm = None,
66                                 mode = mode,
67                                 ds = ds,
68                                 )
69elif psm == 'valid':
70    s_id = ds.get('s_id')
71    if mode == 'create':
72        pin = str(ds.get('acco_res_sc_pin'))
73        pa = context.portal_accommodation
74        code,bed = pa.searchAndReserveBed(s_id,"%s" % (info['student_status']))
75        #code,bed = pa.searchAndReserveBed(s_id,"%s_%s" % (info['sex'],ds.get('student_status')))
76        if code < 0:
77            return context.accommodation_pin_edit_form(rendered = res,
78                                 psm = bed,
79                                 mode = mode,
80                                 ds = ds,
81                                 )
82        student.invokeFactory('StudentAccommodation',acco_id)
83        acco = getattr(student,acco_id)
84        acco_info = context.waeup_tool.getAccommodationInfo(bed)
85        ds.set('acco_maint_code', acco_info.get('maintenance_code'))
86        ds.set('acco_maint_fee', acco_info.get('maintenance_fee'))
87        ds.set('acco_res_date', current)
88        ds.set('bed', bed)
89        ds.set('session', session)
90        ds.set('student_status',info['student_status'])
91        acco.getContent().edit(mapping=ds)
92        #wftool.doActionFor(acco,'pay_maintenance_fee',dest_container=acco)
93        return context.REQUEST.RESPONSE.redirect("%s/reserve_accommodation" % student.absolute_url())
94pin = str(ds.get('acco_main_sc_pin'))
95pp = context.portal_pins
96acco = getattr(student,acco_id)
97ds.set('acco_maint_date', current)
98acco.getContent().edit(mapping=ds)
99wftool.doActionFor(acco,'pay_maintenance_fee',dest_container=acco)
100return context.REQUEST.RESPONSE.redirect("%s/accommodation_view" % student.absolute_url())
Note: See TracBrowser for help on using the repository browser.