source: WAeUP_SRP/base/skins/waeup_student/remove_students.py @ 2416

Last change on this file since 2416 was 2416, checked in by joachim, 17 years ago

mixed search for student_id and matric_no

File size: 3.6 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    #matno_brains = aq_students(In('matric_no', student_ids))
68    brains_dict = {}
69    #id_brains_dict = {}
70    #matno_brains_dict = {}
71    if brains:
72        for b in brains:
73            if b.id in student_ids:
74                brains_dict[b.id] = b
75            elif b.matric_no in student_ids:
76                brains_dict[b.matric_no] = b
77    #set_trace()
78    for student_id in student_ids:
79        student = {}
80        student['deleted'] = delete and student_id in ids
81        if student_id in brains_dict.keys():
82            student['found'] = True
83            student['id'] = brains_dict[student_id].id
84            student['jamb_reg_no'] = brains_dict[student_id].jamb_reg_no
85            student['name'] = brains_dict[student_id].name
86            student['matric_no'] = brains_dict[student_id].matric_no
87        else:
88            student['found'] = False
89            student['id'] = student_id
90            student['jamb_reg_no'] = ""
91            student['name'] = "not found"
92            student['matric_no'] = ''
93        student['show_checkbox'] = not student['deleted'] and student['found']
94        students.append(student)
95
96allowed = students_folder.isSectionOfficer()
97
98return context.remove_students_form(info = info,
99                                    students = students,
100                                    allowed = allowed,
101                                    psm = psm,
102                                    )
Note: See TracBrowser for help on using the repository browser.