[1566] | 1 | ## Script (Python) "reallocate_bed"
|
---|
| 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: reallocateBed.py 1206 2007-01-05 18:24:56Z joachim $
|
---|
| 11 | """
|
---|
| 12 | reallocate beds
|
---|
| 13 | """
|
---|
| 14 | import logging
|
---|
| 15 | logger = logging.getLogger('Skins.reallocate_bed')
|
---|
| 16 |
|
---|
| 17 | request = context.REQUEST
|
---|
| 18 | redirect = request.RESPONSE.redirect
|
---|
| 19 | mtool = context.portal_membership
|
---|
| 20 | wf = context.portal_workflow
|
---|
| 21 | member = mtool.getAuthenticatedMember()
|
---|
| 22 | member_id = str(member)
|
---|
| 23 | path_info = request.get('PATH_INFO').split('/')
|
---|
| 24 |
|
---|
| 25 | if mtool.isAnonymousUser():
|
---|
| 26 | return None
|
---|
| 27 | students = context.portal_url.getPortalObject().campus.students
|
---|
| 28 | beds = context.portal_accommodation
|
---|
| 29 | studs = context.students_catalog
|
---|
| 30 | student_id = context.getStudentId()
|
---|
| 31 |
|
---|
| 32 | if student_id is not None:
|
---|
| 33 | logger.info('%s requests bed_change for %s' % (member_id,student_id))
|
---|
| 34 | info = context.getAccommodationInfo(student_id)
|
---|
| 35 | res = beds(student=student_id)
|
---|
| 36 | if len(res) == 0:
|
---|
| 37 | logger.info('No bed found for %s' % (student_id))
|
---|
| 38 | redirect("%s/%s" % (students.absolute_url(),student_id))
|
---|
| 39 | allocated_bed = res[0]
|
---|
| 40 | status = info['student_status']
|
---|
| 41 | student = student_id
|
---|
| 42 | bedtype = context.getBedStatusFromHall(allocated_bed.bed)
|
---|
| 43 | if not bedtype.endswith("reserved"):
|
---|
| 44 | logger.info('%s is NOT a reserved bed' % (bedtype))
|
---|
| 45 | return redirect("%s/%s/%s" % (students.absolute_url(),student,info['acco_id']))
|
---|
| 46 | logger.info('%s reallocate reserved bed %s/%s' % (student_id,bedtype,status))
|
---|
| 47 | beds.modifyRecord(bed=allocated_bed.bed,
|
---|
| 48 | student='',
|
---|
| 49 | bed_type=bedtype)
|
---|
| 50 | code,bed = beds.searchAndReserveBed(student_id,status)
|
---|
| 51 | if code > 0:
|
---|
| 52 | #from Products.zdb import set_trace; set_trace()
|
---|
| 53 | d = {}
|
---|
| 54 | d['bed'] = bed
|
---|
| 55 | d['student_status'] = status
|
---|
[2000] | 56 | acco_info = context.waeup_tool.getHallInfo(bed)
|
---|
[1566] | 57 | d['acco_maint_code'] = acco_info.get('maintenance_code')
|
---|
| 58 | d['acco_maint_fee'] = acco_info.get('maintenance_fee')
|
---|
| 59 | acco_doc = info['acco_doc']
|
---|
| 60 | acco_doc.edit(mapping=d)
|
---|
| 61 | return redirect("%s/%s/%s" % (students.absolute_url(),student,info['acco_id']))
|
---|
| 62 | logger.info('%s new bed allocation failed, code = %s' % (student_id,code))
|
---|
| 63 | return redirect("%s/%s/%s" % (students.absolute_url(),student,info['acco_id']))
|
---|
| 64 |
|
---|
| 65 | info = {}
|
---|
| 66 | #records = [r for r in beds() if r.student]
|
---|
| 67 | records = beds.uniqueValuesFor('bed')
|
---|
| 68 | list = []
|
---|
| 69 | to_modify = []
|
---|
| 70 | for b in records:
|
---|
| 71 | r = beds(bed=b)[0]
|
---|
| 72 | bedtype = context.getBedStatusFromHall(r.bed)
|
---|
| 73 | if not bedtype.endswith("reserved"):
|
---|
| 74 | #logger.info('"%s", "allocated bed is NOT reserved","%s"' % (student_id,bedtype))
|
---|
| 75 | #list.append("Student %s bed_type %s ok" % (r.student,bedtype))
|
---|
| 76 | continue
|
---|
| 77 | if not r.student:
|
---|
| 78 | beds.modifyRecord(bed=b,
|
---|
| 79 | bed_type=bedtype)
|
---|
| 80 | list.append("Empty bed %s set to %s" % (r.bed,bedtype))
|
---|
| 81 | continue
|
---|
| 82 | info = context.getAccommodationInfo(r.student)
|
---|
| 83 | sbt = info.get('student_status',None)
|
---|
| 84 | if sbt is None:
|
---|
| 85 | continue
|
---|
| 86 | list.append("Student %s bed_type %s != %s" % (r.student,
|
---|
| 87 | r.bed_type,
|
---|
| 88 | bedtype))
|
---|
| 89 | to_modify.append((r.bed,r.student,info['student_status'],info['acco_doc'],bedtype))
|
---|
| 90 | for former_bed, student, status,acco_doc,bedtype in to_modify:
|
---|
| 91 | beds.modifyRecord(bed=former_bed,
|
---|
| 92 | student='',
|
---|
| 93 | bed_type=bedtype)
|
---|
| 94 | code,bed = beds.searchAndReserveBed(student,status)
|
---|
| 95 | if code > 0:
|
---|
| 96 | #from Products.zdb import set_trace; set_trace()
|
---|
| 97 | d = {}
|
---|
| 98 | d['bed'] = bed
|
---|
| 99 | d['student_status'] = status
|
---|
[2000] | 100 | acco_info = context.waeup_tool.getHallInfo(bed)
|
---|
[1566] | 101 | d['acco_maint_code'] = acco_info.get('maintenance_code')
|
---|
| 102 | d['acco_maint_fee'] = acco_info.get('maintenance_fee')
|
---|
| 103 | acco_doc.edit(mapping=d)
|
---|
| 104 | list.append("Student %s got bed %s, code = %s" % (student,
|
---|
| 105 | bed,
|
---|
| 106 | code))
|
---|
| 107 | return "\r".join(list) |
---|