source: WAeUP_SRP/trunk/skins/waeup_student/remove_students.py @ 4989

Last change on this file since 4989 was 2958, checked in by Henrik Bettermann, 17 years ago

fixed

File size: 3.7 KB
Line 
1## Script (Python) "remove_students"
2##bind container=container
3##bind context=context
4##bind namespace=
5##bind script=script
6##bind subpath=traverse_subpath
7##parameters=REQUEST
8##title=
9##
10# $Id: remove_students.py 2400 2007-10-19 15:36:36Z henrik $
11"""
12remove a list of students
13"""
14try:
15    from Products.zdb import set_trace
16except:
17    def set_trace():
18        pass
19
20import logging
21logger = logging.getLogger('Skins.remove_students')
22from Products.AdvancedQuery import Eq, Between, Le,In
23#aq_portal = context.portal_catalog_real.evalAdvancedQuery
24aq_students = context.students_catalog.evalAdvancedQuery
25students_folder = context.portal_url.getPortalObject().campus.students
26stdir = context.portal_directories.students
27mtool = context.portal_membership
28member = mtool.getAuthenticatedMember()
29rget = REQUEST.form.get
30info = {}
31info['member'] = member
32info['is_so'] = context.isSectionOfficer()
33ids = info['choosen_ids'] = rget('ids',[])
34search_list = rget('search_string','')
35delete = rget('delete',None)
36info['search_string'] = search_list
37student_ids = search_list.split()
38students = []
39#set_trace()
40psm = ''
41deleted_list = []
42if delete:
43    if not ids:
44        psm = "Nothing selected!"
45    else:
46        for student_id in ids:
47            logger.info("%s started to remove student record %s" % (member,student_id))
48            if hasattr(students_folder,student_id):
49                students_folder.manage_delObjects((student_id),)
50                logger.info("%s successfully removed student object %s" % (member,student_id))
51            else:
52                logger.info("Student object %s not found" % (student_id))
53                continue
54            deleted_list.append(student_id)
55            # remove from directory
56            if hasattr(stdir, student_id):
57                stdir.deleteEntry(student_id)
58                logger.info("%s successfully deleted student directory entry %s" % (member,student_id))
59            else:
60                logger.info("Student directory entry %s not found" % (student_id))
61                continue
62            context.waeup_tool.removePictureFolder(student_id)
63        psm = "%s removed" % ' '.join(deleted_list)
64
65if student_ids:
66    brains = aq_students(In('id',student_ids) | In('matric_no', student_ids))
67    brains_dict = {}
68    if brains:
69        for b in brains:
70            if b.id in student_ids:
71                brains_dict[b.id] = b
72            elif b.matric_no in student_ids:
73                brains_dict[b.matric_no] = b
74    for student_id in student_ids:
75        student = {}
76        student['deleted'] = delete and student_id in ids
77        if student_id in brains_dict.keys():
78            brain = brains_dict[student_id]
79            student['id'] = brain.id
80            student['review_state'] = brain.review_state
81            student['jamb_reg_no'] = brain.jamb_reg_no
82            student['name'] = brain.name
83            student['matric_no'] = brain.matric_no
84            if brain.review_state == "deactivated":
85                student['found'] = True
86            else:
87                student['found'] = False
88        else:
89            student['found'] = False
90            student['id'] = student_id
91            student['jamb_reg_no'] = ""
92            student['name'] = "not found"
93            student['matric_no'] = ''
94            student['review_state'] = ''
95        student['show_checkbox'] = not student['deleted'] and student['found']
96        students.append(student)
97
98allowed = students_folder.isSectionOfficer()
99
100return context.remove_students_form(info = info,
101                                    students = students,
102                                    allowed = allowed,
103                                    psm = psm,
104                                    )
Note: See TracBrowser for help on using the repository browser.