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 | """ |
---|
12 | remove a list of students |
---|
13 | """ |
---|
14 | try: |
---|
15 | from Products.zdb import set_trace |
---|
16 | except: |
---|
17 | def set_trace(): |
---|
18 | pass |
---|
19 | |
---|
20 | import logging |
---|
21 | logger = logging.getLogger('Skins.remove_students') |
---|
22 | from Products.AdvancedQuery import Eq, Between, Le,In |
---|
23 | aq_students = context.students_catalog.evalAdvancedQuery |
---|
24 | students_folder = context.portal_url.getPortalObject().campus.students |
---|
25 | stdir = context.portal_directories.students |
---|
26 | mtool = context.portal_membership |
---|
27 | member = mtool.getAuthenticatedMember() |
---|
28 | rget = REQUEST.form.get |
---|
29 | info = {} |
---|
30 | info['member'] = member |
---|
31 | info['is_so'] = context.isSectionOfficer() |
---|
32 | ids = info['choosen_ids'] = rget('ids',[]) |
---|
33 | search_list = rget('search_string','') |
---|
34 | delete = rget('delete',None) |
---|
35 | info['search_string'] = search_list |
---|
36 | student_ids = search_list.split() |
---|
37 | students = [] |
---|
38 | #set_trace() |
---|
39 | psm = '' |
---|
40 | deleted_list = [] |
---|
41 | if delete: |
---|
42 | if not ids: |
---|
43 | psm = "Nothing selected!" |
---|
44 | else: |
---|
45 | for student_id in ids: |
---|
46 | logger.info("%s started to remove student record %s" % (member,student_id)) |
---|
47 | if hasattr(students_folder,student_id): |
---|
48 | students_folder.manage_delObjects((student_id),) |
---|
49 | logger.info("%s successfully removed student object %s" % (member,student_id)) |
---|
50 | else: |
---|
51 | logger.info("Student object %s not found" % (student_id)) |
---|
52 | continue |
---|
53 | deleted_list.append(student_id) |
---|
54 | # remove from directory |
---|
55 | if hasattr(stdir, student_id): |
---|
56 | stdir.deleteEntry(student_id) |
---|
57 | logger.info("%s successfully deleted student directory entry %s" % (member,student_id)) |
---|
58 | else: |
---|
59 | logger.info("Student directory entry %s not found" % (student_id)) |
---|
60 | continue |
---|
61 | context.waeup_tool.removePictureFolder(student_id) |
---|
62 | psm = "%s removed" % ' '.join(deleted_list) |
---|
63 | |
---|
64 | if student_ids: |
---|
65 | brains = aq_students(In('id',student_ids) | In('matric_no', student_ids)) |
---|
66 | brains_dict = {} |
---|
67 | if brains: |
---|
68 | for b in brains: |
---|
69 | if b.id in student_ids: |
---|
70 | brains_dict[b.id] = b |
---|
71 | elif b.matric_no in student_ids: |
---|
72 | brains_dict[b.matric_no] = b |
---|
73 | for student_id in student_ids: |
---|
74 | student = {} |
---|
75 | student['deleted'] = delete and student_id in ids |
---|
76 | if student_id in brains_dict.keys(): |
---|
77 | brain = brains_dict[student_id] |
---|
78 | student['id'] = brain.id |
---|
79 | student['review_state'] = brain.review_state |
---|
80 | student['jamb_reg_no'] = brain.jamb_reg_no |
---|
81 | student['name'] = brain.name |
---|
82 | student['matric_no'] = brain.matric_no |
---|
83 | if brain.review_state == "deactivated": |
---|
84 | student['found'] = True |
---|
85 | else: |
---|
86 | student['found'] = False |
---|
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['review_state'] = '' |
---|
94 | student['show_checkbox'] = not student['deleted'] and student['found'] |
---|
95 | students.append(student) |
---|
96 | |
---|
97 | allowed = students_folder.isSectionOfficer() |
---|
98 | |
---|
99 | return context.remove_students_form(info = info, |
---|
100 | students = students, |
---|
101 | allowed = allowed, |
---|
102 | psm = psm, |
---|
103 | ) |
---|