source: WAeUP_SRP/trunk/Students.py @ 773

Last change on this file since 773 was 766, checked in by joachim, 18 years ago

added request_clearance

  • Property svn:keywords set to Id
File size: 38.4 KB
Line 
1#-*- mode: python; mode: fold -*-
2# $Id: Students.py 766 2006-10-27 16:35:27Z joachim $
3from string import Template
4from Globals import InitializeClass
5from AccessControl import ClassSecurityInfo
6from AccessControl.SecurityManagement import newSecurityManager
7from zExceptions import BadRequest
8from Products.ZCatalog.ZCatalog import ZCatalog
9from Products.CMFCore.utils import UniqueObject, getToolByName
10from Products.CMFCore.permissions import View
11from Products.CMFCore.permissions import ModifyPortalContent
12from Products.CPSCore.CPSBase import CPSBase_adder, CPSBaseFolder
13#from Products.CPSCore.CPSBase import CPSBaseDocument as BaseDocument
14from Products.CPSDocument.CPSDocument import CPSDocument
15from Products.CPSCore.CPSBase import CPSBaseBTreeFolder as BaseBTreeFolder
16from Products.CPSCore.CPSMembershipTool import CPSUnrestrictedUser
17from Products.WAeUP_SRP.Academics import makeCertificateCode
18import logging
19import csv,re
20import Globals
21p_home = Globals.package_home(globals())
22i_home = Globals.INSTANCE_HOME
23MAX_TRANS = 1000
24
25def getInt(s):
26    try:
27        return int(s)
28    except:
29        return 0
30
31def getFloat(s):
32    try:
33        return float(s)
34    except:
35        return 0.0
36
37def getStudentByRegNo(self,reg_no): ###(
38    """search student by JAMB Reg No and return StudentFolder"""
39    search = ZCatalog.searchResults(self.portal_catalog,{'meta_type': 'StudentApplication',
40                                  'SearchableText': reg_no,
41                                  })
42    if len(search) < 1:
43        return None
44    return search[0].getObject().aq_parent
45
46###)
47
48class StudentsFolder(CPSDocument): ###(
49    """
50    WAeUP container for the various WAeUP containers data
51    """
52    meta_type = 'StudentsFolder'
53    portal_type = meta_type
54    security = ClassSecurityInfo()
55
56    security.declareProtected(ModifyPortalContent,"loadFullTimeStudentsFromCSV")###(
57    def loadFullTimeStudentsFromCSV(self):
58        """load Fulltime Studentdata from CSV values"""
59        import transaction
60        import random
61        tr_count = 0
62        name = 'short_full_time'
63        no_import = False
64        if not no_import:
65            no_import = open("%s/import/%s_not_imported.csv" % (i_home,name),"w")
66            no_import.write('"MatricNo","EntryRegNo","CurrentSession","StudentLevel","fullname","FirstName","MiddleName","Lastname","FormerSurname","Sex","Nationality","State","LGA","PermanentAddress","PermanentAddressCity","CampusAddress","PhoneNumber","Emailaddress","Mode","CourseMajor","Faculty","Dept"\n')
67        logger = logging.getLogger('%s_import' % name)
68        logger.info('Start loading from %s.csv' % name)
69        pwlist  = []
70        pwlist.append('"student_id","firstname","middlename","lastname","matric_no","jamb_reg_no","access_code"')
71        pwl_template = Template('"$student_id","$firstname","$middlename","$lastname","$matric_no","$jamb_reg_no","$access_code"')
72        students_folder = self.portal_catalog({'meta_type': 'StudentsFolder'})[-1].getObject()
73        try:
74            students = csv.DictReader(open("%s/import/%s.csv" % (i_home,name),"rb"))
75        except:
76            logger.error('Error reading %s.csv' % name)
77            return
78        l = self.portal_catalog({'meta_type': "StudentClearance",})
79        matrics = []
80        for s in l:
81            matrics.append(s.getObject().getContent().matric_no)
82        print matrics
83        l = self.portal_catalog({'meta_type': "Certificate"})
84        certs = {}
85        for c in l:
86            ca,ac,fa,dep_id,co,certcode = c.relative_path.split('/')
87            cid = "%(dep_id)s_%(certcode)s" % vars()
88            certs[cid] = c.getObject()
89        for student in students:
90            logger.info('processing "%(MatricNo)s","%(EntryRegNo)s","%(CurrentSession)s","%(StudentLevel)s","%(fullname)s","%(FirstName)s","%(MiddleName)s","%(Lastname)s","%(FormerSurname)s","%(Sex)s","%(Nationality)s","%(State)s","%(LGA)s","%(PermanentAddress)s","%(PermanentAddressCity)s","%(CampusAddress)s","%(PhoneNumber)s","%(Emailaddress)s","%(Mode)s","%(CourseMajor)s","%(Faculty)s","%(Dept)s"\n' % student)
91            sid = student.get('MatricNo')
92            if sid == "":
93                em = 'Empty MatricNo\n'
94                logger.info(em)
95                no_import.write(em)
96                no_import.write('"%(MatricNo)s","%(EntryRegNo)s","%(CurrentSession)s","%(StudentLevel)s","%(fullname)s","%(FirstName)s","%(MiddleName)s","%(Lastname)s","%(FormerSurname)s","%(Sex)s","%(Nationality)s","%(State)s","%(LGA)s","%(PermanentAddress)s","%(PermanentAddressCity)s","%(CampusAddress)s","%(PhoneNumber)s","%(Emailaddress)s","%(Mode)s","%(CourseMajor)s","%(Faculty)s","%(Dept)s"\n' % student)
97                continue
98            certcode = makeCertificateCode(student.get('CourseMajor'))
99            dep_id = student.get('Dept')
100            fac_id = student.get('Faculty')
101            cid = "%(dep_id)s_%(certcode)s" % vars()
102            if cid not in certs.keys():
103                em = 'Certificate with ID %s %s not found\n' % (certcode, student.get('CourseMajor'))
104                logger.info(em)
105                no_import.write(em)
106                no_import.write('"%(MatricNo)s","%(EntryRegNo)s","%(CurrentSession)s","%(StudentLevel)s","%(fullname)s","%(FirstName)s","%(MiddleName)s","%(Lastname)s","%(FormerSurname)s","%(Sex)s","%(Nationality)s","%(State)s","%(LGA)s","%(PermanentAddress)s","%(PermanentAddressCity)s","%(CampusAddress)s","%(PhoneNumber)s","%(Emailaddress)s","%(Mode)s","%(CourseMajor)s","%(Faculty)s","%(Dept)s"\n' % student)
107                continue
108            certificate_doc = certs[cid].getContent()
109            level = student.get('StudentLevel')
110            try:
111                int(level)
112            except:
113                em = 'Student with ID %(MatricNo)s StudentLevel is empty\n' % student
114                logger.info(em)
115                no_import.write(em)
116                no_import.write('"%(MatricNo)s","%(EntryRegNo)s","%(CurrentSession)s","%(StudentLevel)s","%(fullname)s","%(FirstName)s","%(MiddleName)s","%(Lastname)s","%(FormerSurname)s","%(Sex)s","%(Nationality)s","%(State)s","%(LGA)s","%(PermanentAddress)s","%(PermanentAddressCity)s","%(CampusAddress)s","%(PhoneNumber)s","%(Emailaddress)s","%(Mode)s","%(CourseMajor)s","%(Faculty)s","%(Dept)s"\n' % student)
117                continue
118            matric_no = student.get('MatricNo')
119            if matric_no not in matrics:
120                matrics.append(matric_no)
121                sid = self.generateStudentId(student.get('Lastname')[0])
122                #self.log('Creating Faculty %(id)s = %(Title)s' % faculty)
123                students_folder.invokeFactory('Student', sid)
124                logger.info('%(tr_count)s: Creating Student with ID %(sid)s Matric_no %(matric_no)s ' % vars())
125                student_obj = getattr(self,sid)
126                access_code = "%d" % random.randint(1000000000,9999999999)
127                student_obj.getContent().makeStudentMember(sid,access_code,)
128                pwl_dict = {'student_id': sid,'access_code':access_code}
129                student_obj.invokeFactory('StudentApplication','application')
130                application = student_obj.application
131                da = {'Title': 'Application Data'}
132                student_obj.invokeFactory('StudentPersonal','personal')
133                da['jamb_reg_no'] = student.get('EntryRegNo')
134                personal = student_obj.personal
135                dp = {'Title': 'Personal Data'}
136                student_obj.invokeFactory('StudentClearance','clearance')
137                clearance = student_obj.clearance
138                dc = {'Title': 'Clearance Data'}
139                dc['matric_no'] = matric_no
140                state = student.get('State')
141                lga = student.get('LGA')
142                if state and lga:
143                    lga =  state + ' / ' + lga
144                else:
145                    lga = "None"
146                dc['lga'] = lga
147                dc['nationality'] = student.get('Nationality')
148                dc['email'] = student.get('Emailaddress')
149                dp['firstname'] = student.get('FirstName')
150                dp['middlename'] = student.get('MiddleName')
151                dp['lastname'] = student.get('Lastname')
152                dp['former_surname'] = student.get('FormerSurname')
153                dp['sex'] = student.get('Sex') == 'F'
154                dp['perm_address'] = student.get('PermanentAddress')
155                dp['perm_city'] = student.get('PermanentAddressCity')
156                dp['campus_address'] = student.get('CampusAddress')
157                dp['phone'] = student.get('PhoneNumber')
158                application.getContent().edit(mapping=da)
159                personal.getContent().edit(mapping=dp)
160                clearance.getContent().edit(mapping=dc)
161                #
162                # Study Course
163                #
164                student_obj.invokeFactory('StudentStudyCourse','study_course')
165                studycourse = student_obj.study_course
166                dsc = {}
167                from_certificate = ['title',
168                                   'max_elect',
169                                   'max_pass',
170                                   'n_core',
171                                   'nr_years',
172                                   'probation_credits',
173                                   'promotion_credits',
174                                   'start_level',
175                                  ]
176                for f in from_certificate:
177                    dsc[f] = getattr(certificate_doc,f)
178                dsc['faculty'] = fac_id
179                dsc['department'] = dep_id
180                dsc['study_course'] = certcode
181                css = student.get('CurrentSession') or '2004-2005'
182                cs = int(css.split('-')[0]) - 2000
183                cl = int(student.get('StudentLevel') or '100')/100
184                dsc['entry_session'] = "200%s" % (cs - cl)
185                dsc['clr_ac_pin'] = access_code
186                studycourse.getContent().edit(mapping=dsc)
187                #
188                # Level
189                #
190##                l = getattr(studycourse,level,None)
191##                if 0 and l is None:
192##                    #self.log('Creating Department %(DeptCode)s = %(Description)s' % dep)
193##                    logger.info('Creating Level %(StudentLevel)s for %(fullname)s' % student)
194##                    studycourse.invokeFactory('StudentStudyLevel', level)
195##                    l = getattr(studycourse, level)
196##                    certificate = certs[certcode]
197##                    cert_level = getattr(certificate,level,None)
198##                    if cert_level is None:
199##                        logger.info('Level %(level)s not in %(certcode)s' % vars())
200##                    l.getContent().edit(mapping={'Title': "Level %s" % level})
201            else:
202                em = 'Student with ID %(MatricNo)s %(fullname)s already exists\n' % student
203                logger.info(em)
204                no_import.write(em)
205                no_import.write('"%(MatricNo)s","%(EntryRegNo)s","%(CurrentSession)s","%(StudentLevel)s","%(fullname)s","%(FirstName)s","%(MiddleName)s","%(Lastname)s","%(FormerSurname)s","%(Sex)s","%(Nationality)s","%(State)s","%(LGA)s","%(PermanentAddress)s","%(PermanentAddressCity)s","%(CampusAddress)s","%(PhoneNumber)s","%(Emailaddress)s","%(Mode)s","%(CourseMajor)s","%(Faculty)s","%(Dept)s"\n' % student)
206                continue
207            if tr_count > MAX_TRANS:
208                transaction.commit()
209                em = 'Transaction commited\n' % student
210                logger.info(em)
211                tr_count = 0
212            tr_count += 1
213            pwl_dict.update(dc)
214            pwl_dict.update(da)
215            pwl_dict.update(dp)
216            wftool = self.portal_workflow
217            pwlist.append(pwl_template.substitute(pwl_dict))
218            wftool.doActionFor(student_obj,'clear_and_validate')
219            student_obj.manage_setLocalRoles(sid, ['Owner',])
220            wftool.doActionFor(application,'close')
221            application.manage_setLocalRoles(sid, ['Owner',])
222            wftool.doActionFor(clearance,'close')
223            clearance.manage_setLocalRoles(sid, ['Owner',])
224            wftool.doActionFor(personal,'close')
225            personal.manage_setLocalRoles(sid, ['Owner',])
226            wftool.doActionFor(studycourse,'close_for_edit')
227            studycourse.manage_setLocalRoles(sid, ['Owner',])
228        open("%s/import/pwlist-%s.csv" % (i_home,name),"w+").write('\n'.join(pwlist))
229        return self.REQUEST.RESPONSE.redirect("%s" % self.REQUEST.get('URL1'))
230    ###)
231
232    security.declareProtected(ModifyPortalContent,"loadPumeResultsFromCSV")###(
233    def loadPumeResultsFromCSV(self):
234        """load Fulltime Studentdata from CSV values"""
235        import transaction
236        import random
237        wftool = self.portal_workflow
238        students_folder = self.portal_catalog({'meta_type': 'StudentsFolder'})[-1].getObject()
239        csv_d = {'jamb_reg_no': "Matnumber",
240                 'jamb_lastname': "Surname",
241                 'pume_options': "Options",
242                 'session': "Session",
243                 'days': "Days",
244                 'response': "Responce",
245                 'wrong': "Wrong",
246                 'pume_eng_score': "EngScore",
247                 'pume_gen_score': "GenScore",                 
248                 'pume_tot_score': "Right",
249                 'batch': "Batch",
250                 'serial': "SerialNo",
251                 'jamb_score': "JambScore",
252                 'omitted':"Omitted",
253                 'search_key': "SearchKey",
254                 'jamb_sex': "Sex",
255                 'fac1': "Fac1",
256                 'fac2': "Fac2",
257                 'jamb_first_cos': "CourseofStudy",
258                 'stud_status':"StudStatus",
259                 'registered': "Registered",
260                 'jamb_state': "State",
261                 'eng_fail': "EngFail",
262                 'gen_fail': "GenFail",
263                 'un_ans_eng': "UnAnsEng",
264                 'un_ans_eng': "UnAnsGen",
265                 'total_ans': "TotalUnAns",
266                 'dept': "Dept",
267                 'jamb_second_cos': "Course2",
268                 'jamb_third_cos': "course3",
269                 }
270        csv_fields = [f[1] for f in csv_d.items()]
271        tr_count = 0
272        name = 'pume_results'
273        no_import = []
274        s = ','.join(['"(%s)"' % fn for fn in csv_fields])
275        no_import.append('%s\n' % s)
276        logger = logging.getLogger('%s_import' % name)
277        logger.info('Start loading from %s.csv' % name)
278        try:
279            result = csv.DictReader(open("%s/import/%s.csv" % (i_home,name),"rb"))
280        except:
281            logger.error('Error reading %s.csv' % name)
282            return
283        for jamb in result:
284            format = ','.join(['"%%(%s)s"' % fn for fn in csv_fields])
285            processing = "processing %s" % format
286            logger.info(processing % jamb)
287            jamb_reg_no = jamb.get(csv_d['jamb_reg_no'])
288            #import pdb;pdb.set_trace()
289            res = self.portal_catalog({'portal_type': "StudentApplication",
290                                     'jamb_reg_no': jamb_reg_no })
291            if res:
292                em = 'Student with REG-NO %s already exists\n' % jamb_reg_no
293                logger.info(em)
294                no_import.append(em)
295                no_import.append(format % jamb)
296                continue
297            jamb_name = jamb.get(csv_d['jamb_lastname'])
298            jamb_name.replace('>','')
299            names = jamb_name.split()
300            letter = names[-1][0].upper()
301            sid = self.generateStudentId(letter)
302            not_created = True
303            while not_created:
304                try:
305                    students_folder.invokeFactory('Student', sid)
306                    not_created = False
307                except BadRequest:
308                    sid = self.generateStudentId(letter)
309            logger.info('%(tr_count)s: Creating Student with ID %(sid)s REG-NO %(jamb_reg_no)s ' % vars())
310            student = getattr(self,sid)
311            student.manage_setLocalRoles(sid, ['Owner',])
312            student.invokeFactory('StudentClearance','clearance')
313            wftool.doActionFor(student.clearance,'open')
314            dp = {'Title': 'Clearance Data'}
315            student.clearance.manage_setLocalRoles(sid, ['Owner',])
316            student.invokeFactory('StudentPume','pume')
317            dp = {'Title': 'Pume Data'}
318            student.invokeFactory('StudentApplication','application')
319            da = {'Title': 'Application Data'}
320            da["jamb_lastname"] = jamb_name
321            da_fields = ('jamb_reg_no',
322                         'jamb_sex',
323                         'jamb_state',
324                         'jamb_score',
325                         'jamb_first_cos',
326                         'jamb_sex',
327                         'jamb_state',
328                         'jamb_first_cos',
329                         'jamb_second_cos',
330                         )
331            for f in da_fields:
332                da[f] = jamb.get(csv_d[f])
333            app = student.application
334            app.getContent().edit(mapping=da)
335            app.manage_setLocalRoles(sid, ['Owner',])
336            dp_fields = (
337                         'pume_eng_score',
338                         'pume_gen_score',
339                         'pume_tot_score',
340                         )
341            for f in dp_fields:
342                dp[f] = jamb.get(csv_d[f])
343            pume = student.pume
344            pume.getContent().edit(mapping=dp)
345            wftool.doActionFor(pume,'close',dest_container=app)
346            pume.manage_setLocalRoles(sid, ['Owner',])
347            student.getContent().createSubObjects()
348            wftool.doActionFor(student,'admit',dest_container=student)
349            if len(no_import) > 1:
350                open("%s/import/%s_not_imported.csv" % (i_home,name),"w").write(
351                     '\n'.join(no_import))
352        return self.REQUEST.RESPONSE.redirect("%s" % self.REQUEST.get('URL1'))
353    ###)
354
355    security.declareProtected(ModifyPortalContent,"loadFullTimeStudentsResultsFromCSV") ###(
356    def loadFullTimeStudentsResultsFromCSV(self):
357        """load Fulltime Studentdata from CSV values"""
358        #return
359        level_wf_actions = {}
360        level_wf_actions["SUCCESSFUL STUDENT"] = "pass_A"
361        level_wf_actions["STUDENT WITH CARRYOVER COURSES"] = "pass_B"
362        level_wf_actions["STUDENT FOR PROBATION"] = "probate_C"
363        level_wf_actions["STUDENT ON PROBATION/TRANSFER"] = "reject_D"
364        import transaction
365        wftool = self.portal_workflow
366        tr_count = 0
367        name = 'short_full_time_results_2004_2005'
368        no_import = False
369        if not no_import:
370            no_import = open("%s/import/%s_not_imported.csv" % (i_home,name),"w")
371            no_import.write('"Matnumber","CosCode","Ansbook","CosStuatus","Session","Mat_Cos","Score","CarryLevel","Grade","Weight","Semster","Verdict","Level","id","GPA"\n')
372        logger = logging.getLogger('%s_import' % name)
373        logger.info('Start loading from %s.csv' % name)
374        students_folder = self.portal_catalog({'meta_type': 'StudentsFolder'})[-1].getObject()
375        try:
376            results = csv.DictReader(open("%s/import/%s.csv" % (i_home,name),"rb"))
377        except:
378            logger.error('Error reading %s.csv' % name)
379            return
380        l = self.portal_catalog({'meta_type': "Course"})
381        courses = {}
382        for c in l:
383            courses[c.id] = c.getObject()
384        level_changed = False
385        student_changed = False
386        sid = ''
387        #import pdb;pdb.set_trace()
388        for result in results:
389            temp_sid = result.get('Matnumber')
390            if temp_sid != sid:
391                student_changed = True
392                res = self.portal_catalog({'meta_type': "StudentClearance",
393                                         'SearchableText': temp_sid })
394                if not res:
395                    em = 'Student with ID %(Matnumber)s not found\n' % result
396                    logger.info(em)
397                    no_import.write(em)
398                    no_import.write('"%(Matnumber)s","%(CosCode)s","%(Ansbook)s","%(CosStuatus)s","%(Session)s","%(Mat_Cos)s","%(Score)s","%(CarryLevel)s","%(Grade)s","%(Weight)s","%(Semster)s","%(Verdict)s","%(Level)s","%(id)s","%(GPA)s"\n' % result)
399                    continue
400                elif len(res) > 1:
401                    em = 'More than one Student with ID %(Matnumber)s found\n' % result
402                    logger.info(em)
403                    no_import.write(em)
404                    no_import.write('"%(Matnumber)s","%(CosCode)s","%(Ansbook)s","%(CosStuatus)s","%(Session)s","%(Mat_Cos)s","%(Score)s","%(CarryLevel)s","%(Grade)s","%(Weight)s","%(Semster)s","%(Verdict)s","%(Level)s","%(id)s","%(GPA)s"\n' % result)
405                    continue
406                sid = temp_sid
407                sf = res[0].getObject().aq_parent
408                sc = getattr(sf,'study_course')
409                level = ''
410            else:
411                student_changed = False
412            course = result.get('CosCode')
413            if course not in courses.keys():
414                em = 'Course with ID %(CosCode)s not found\n' % result
415                logger.info(em)
416                no_import.write(em)
417                no_import.write('"%(Matnumber)s","%(CosCode)s","%(Ansbook)s","%(CosStuatus)s","%(Session)s","%(Mat_Cos)s","%(Score)s","%(CarryLevel)s","%(Grade)s","%(Weight)s","%(Semster)s","%(Verdict)s","%(Level)s","%(id)s","%(GPA)s"\n' % result)
418                continue
419            course_doc = courses[course].getContent()
420            temp_level = result.get('Level')
421            student_id = sf.getId()
422            result['StudentId'] = student_id
423            if temp_level != level:
424                try:
425                    int(temp_level)
426                except:
427                    em = 'Result with ID %(Matnumber)s Course %(CosCode)s Level is empty\n' % result
428                    logger.info(em)
429                    no_import.write(em)
430                    no_import.write('"%(Matnumber)s","%(CosCode)s","%(Ansbook)s","%(CosStuatus)s","%(Session)s","%(Mat_Cos)s","%(Score)s","%(CarryLevel)s","%(Grade)s","%(Weight)s","%(Semster)s","%(Verdict)s","%(Level)s","%(id)s","%(GPA)s"\n' % result)
431                    continue
432                level_changed = True
433                if 'dlev' in vars().keys():
434                    wftool.doActionFor(l,level_wf_actions[dlev['verdict']])
435                level = temp_level
436                l = getattr(sc,level,None)
437                if l is None:
438                    logger.info('Creating Level %(Level)s for %(StudentId)s %(Matnumber)s' % result)
439                    sc.invokeFactory('StudentStudyLevel', level)
440                    l = getattr(sc, level)
441                    l.manage_setLocalRoles(student_id, ['Owner',])
442            else:
443                level_changed = False
444            cr = getattr(l,course,None)
445            if cr is None:
446                logger.info('Creating Course %(CosCode)s for %(StudentId)s %(Matnumber)s in Level %(Level)s' % result)
447                l.invokeFactory('StudentCourseResult',course)
448            cr = getattr(l,course)
449            dcr = {}
450            from_course = ['title',
451                           'credits',
452                           'passmark',
453                           ]
454            for f in from_course:
455                dcr[f] = getattr(course_doc,f)
456            dlev = {}
457            dcr['ansbook'] = result.get('Ansbook')
458            dcr['semester'] = getInt(result.get('Semster'))
459            dcr['status'] = result.get('CosStuatus')
460            dcr['score'] = getInt(result.get('Score'))
461            dlev['session'] = result.get('Session')
462            dcr['carry_level'] = result.get('CarryLevel')
463            dcr['grade'] = result.get('Grade')
464            dcr['weight'] = result.get('Weight')
465            dlev['verdict'] = result.get('Verdict')
466            dcr['import_id'] = result.get('id')
467            gpa = result.get('GPA').replace(',','.')
468            dlev['imported_gpa'] = getFloat(gpa)
469            cr.getContent().edit(mapping = dcr)
470            cr.manage_setLocalRoles(student_id, ['Owner',])
471            l.getContent().edit(mapping = dlev)
472            if tr_count > MAX_TRANS:
473                transaction.commit()
474                tr_count = 0
475            tr_count += 1
476            wftool.doActionFor(cr,'close')
477        wftool.doActionFor(l,level_wf_actions[dlev['verdict']])
478        return self.REQUEST.RESPONSE.redirect("%s" % self.REQUEST.get('URL1'))
479
480###)
481
482    security.declareProtected(ModifyPortalContent,"loadJAMBFromCSV")###(
483    def loadJAMBFromCSV(self):
484        """load JAMB data from CSV values"""
485        #return
486        students_folder = self.portal_catalog({'meta_type': 'StudentsFolder'})[-1].getObject()
487        import transaction
488        tr_count = 0
489        name = 'SampleJAMBDataII'
490        wftool = self.portal_workflow
491        no_import = False
492        if not no_import:
493            no_import = open("%s/import/%s_not_imported.csv" % (i_home,name),"w")
494            no_import.write('REG-NO,NAME,SEX,STATE,LGA,ENG-SCORE,SUBJ1,SUBJ1-SCORE,SUBJ2,SUBJ2-SCORE,SUBJ3,SUBJ3-SCORE,AGGREGATE,UNIV1,FACULTY1,COURSE1,UNIV2,FACULTY2,COURSE2')
495        logger = logging.getLogger('%s_import' % name)
496        logger.info('Start loading from %s.csv' % name)
497        try:
498            result = csv.DictReader(open("%s/import/%s.csv" % (i_home,name),"rb"))
499        except:
500            logger.error('Error reading %s.csv' % name)
501            return
502        for jamb in result:
503            logger.info('processing %(REG-NO)s,%(NAME)s,%(SEX)s,%(STATE)s,%(LGA)s,%(ENG-SCORE)s,%(SUBJ1)s,%(SUBJ1-SCORE)s,%(SUBJ2)s,%(SUBJ2-SCORE)s,%(SUBJ3)s,%(SUBJ3-SCORE)s,%(AGGREGATE)s,%(UNIV1)s,%(FACULTY1)s,%(COURSE1)s,%(UNIV2)s,%(FACULTY2)s,%(COURSE2)s\n' % jamb)
504            jamb_reg_no = jamb.get('REG-NO')
505            res = self.portal_catalog({'meta_type': "StudentApplication",
506                                     'jamb_reg_no': jamb_reg_no })
507            if res:
508                em = 'Student with REG-NO %(REG-NO)s already exists\n' % jamb
509                logger.info(em)
510                no_import.write(em)
511                no_import.write('%(REG-NO)s,%(NAME)s,%(SEX)s,%(STATE)s,%(LGA)s,%(ENG-SCORE)s,%(SUBJ1)s,%(SUBJ1-SCORE)s,%(SUBJ2)s,%(SUBJ2-SCORE)s,%(SUBJ3)s,%(SUBJ3-SCORE)s,%(AGGREGATE)s,%(UNIV1)s,%(FACULTY1)s,%(COURSE1)s,%(UNIV2)s,%(FACULTY2)s,%(COURSE2)s\n' % jamb)
512                continue
513            jamb_name = jamb.get("NAME")
514            jamb_name.replace('>','')
515            names = jamb_name.split()
516            letter = names[-1][0].upper()
517            sid = self.generateStudentId(letter)
518            not_created = True
519            while not_created:
520                try:
521                    students_folder.invokeFactory('Student', sid)
522                    not_created = False
523                except BadRequest:
524                    sid = self.generateStudentId(letter)
525            logger.info('%(tr_count)s: Creating Student with ID %(sid)s REG-NO %(jamb_reg_no)s ' % vars())
526            student = getattr(self,sid)
527            student.manage_setLocalRoles(sid, ['Owner',])
528            student.invokeFactory('StudentApplication','application')
529            da = {'Title': 'Application Data'}
530            da["jamb_reg_no"] = jamb.get("REG-NO")
531            da["jamb_lastname"] = jamb_name
532            da["jamb_sex"] = jamb.get("SEX")
533            da["jamb_state"] = jamb.get("STATE")
534            da["jamb_lga"] = jamb.get("LGA")
535            da["jamb_score"] = jamb.get("AGGREGATE")
536            da["jamb_first_cos"] = jamb.get("COURSE1")
537            da["jamb_second_cos"] = jamb.get("COURSE2")
538            da["jamb_first_uni"] = jamb.get("UNIV1")
539            da["jamb_second_uni"] = jamb.get("UNIV2")
540            app = student.application
541            app_doc = app.getContent()
542            app_doc.edit(mapping=da)
543            #wftool.doActionFor(app,'open',dest_container=app)
544            app.manage_setLocalRoles(sid, ['Owner',])
545            student.getContent().createSubObjects()
546        return self.REQUEST.RESPONSE.redirect("%s" % self.REQUEST.get('URL1'))
547    ###)
548
549
550    security.declareProtected(View,"fixOwnership")
551    def fixOwnership(self):
552        """fix Ownership"""
553        for s in self.portal_catalog(meta_type = 'Student'):
554            student = s.getObject()
555            sid = s.getId
556            import pdb;pdb.set_trace()
557            student.application.manage_setLocalRoles(sid, ['Owner',])
558            student.personal.manage_setLocalRoles(sid, ['Owner',])
559
560    security.declareProtected(View,"Title")
561    def Title(self):
562        """compose title"""
563        return "Student Section"
564
565    def generateStudentId(self,letter): ###(
566        import random
567        r = random
568        if letter not in ('ABCDEFGIHKLMNOPQRSTUVWXY'):
569            letter= r.choice('ABCDEFGHKLMNPQRSTUVWXY')
570        students = self.portal_catalog(meta_type = "StudentsFolder")[-1]
571        sid = "%c%d" % (letter,r.randint(99999,1000000))
572        while hasattr(students, sid):
573            sid = "%c%d" % (letter,r.randint(99999,1000000))
574        return sid
575        #return "%c%d" % (r.choice('ABCDEFGHKLMNPQRSTUVWXY'),r.randint(99999,1000000))
576    ###)
577
578InitializeClass(StudentsFolder)
579
580def addStudentsFolder(container, id, REQUEST=None, **kw):
581    """Add a Student."""
582    ob = StudentsFolder(id, **kw)
583    return CPSBase_adder(container, ob, REQUEST=REQUEST)
584###)
585
586class Student(CPSDocument): ###(
587    """
588    WAeUP Student container for the various student data
589    """
590    meta_type = 'Student'
591    portal_type = meta_type
592    security = ClassSecurityInfo()
593
594    security.declareProtected(View,"Title")
595    def Title(self):
596        """compose title"""
597        reg_nr = self.getId()[1:]
598        data = getattr(self,'personal',None)
599        if data:
600            content = data.getContent()
601            return "%s %s" % (content.firstname,content.lastname)
602        data = getattr(self,'application',None)
603        if data:
604            content = data.getContent()
605            return "%s" % (content.jamb_lastname)
606        return self.title
607
608    security.declarePrivate('makeStudentMember') ###(
609    def makeStudentMember(self,sid,password='uNsEt'):
610        """make the student a member"""
611        membership = self.portal_membership
612        membership.addMember(sid,
613                             password ,
614                             roles=('Member',
615                                     'Student',
616                                     ),
617                             domains='',
618                             properties = {'memberareaCreationFlag': False,},)
619        member = membership.getMemberById(sid)
620        self.portal_registration.afterAdd(member, sid, password, None)
621        self.manage_setLocalRoles(sid, ['Owner',])
622
623###)
624
625    security.declareProtected(View,'createSubObjects') ###(
626    def createSubObjects(self):
627        """make the student a member"""
628        dp = {'Title': 'Personal Data'}
629        app_doc = self.application.getContent()
630        names = app_doc.jamb_lastname.split()
631        if len(names) == 3:
632            dp['firstname'] = names[0].capitalize()
633            dp['middlename'] = names[1].capitalize()
634            dp['lastname'] = names[2].capitalize()
635        elif len(names) == 2:
636            dp['firstname'] = names[0].capitalize()
637            dp['lastname'] = names[1].capitalize()
638        else:
639            dp['lastname'] = app_doc.jamb_lastname
640        dp['sex'] = app_doc.jamb_sex == 'F'
641        dp['lga'] = "%s/%s" % (app_doc.jamb_state,app_doc.jamb_lga )
642        proxy = self.aq_parent
643        proxy.invokeFactory('StudentPersonal','personal')
644        per = proxy.personal
645        per_doc = per.getContent()
646        per_doc.edit(mapping = dp)
647        per.manage_setLocalRoles(self.getId(), ['Owner',])
648        #self.portal_workflow.doActionFor(per,'open',dest_container=per)
649
650###)
651
652InitializeClass(Student)
653
654def addStudent(container, id, REQUEST=None, **kw):
655    """Add a Student."""
656    ob = Student(id, **kw)
657    return CPSBase_adder(container, ob, REQUEST=REQUEST)
658
659###)
660
661class StudentAccommodation(CPSDocument): ###(
662    """
663    WAeUP Student container for the various student data
664    """
665    meta_type = 'StudentAccommodation'
666    portal_type = meta_type
667    security = ClassSecurityInfo()
668
669    security.declareProtected(View,"Title")
670    def Title(self):
671        """compose title"""
672        content = self.getContent()
673        #return "Accommodation Data for %s %s" % (content.firstname,content.lastname)
674        return "Accommodation Data for Session %s" % content.session
675
676
677InitializeClass(StudentAccommodation)
678
679def addStudentAccommodation(container, id, REQUEST=None, **kw):
680    """Add a Students personal data."""
681    ob = StudentAccommodation(id, **kw)
682    return CPSBase_adder(container, ob, REQUEST=REQUEST)
683
684###)
685
686class StudentPersonal(CPSDocument): ###(
687    """
688    WAeUP Student container for the various student data
689    """
690    meta_type = 'StudentPersonal'
691    portal_type = meta_type
692    security = ClassSecurityInfo()
693
694    security.declareProtected(View,"Title")
695    def Title(self):
696        """compose title"""
697        content = self.getContent()
698        #return "Personal Data for %s %s" % (content.firstname,content.lastname)
699        return "Personal Data"
700
701
702InitializeClass(StudentPersonal)
703
704def addStudentPersonal(container, id, REQUEST=None, **kw):
705    """Add a Students personal data."""
706    ob = StudentPersonal(id, **kw)
707    return CPSBase_adder(container, ob, REQUEST=REQUEST)
708
709###)
710
711class StudentClearance(CPSDocument): ###(
712    """
713    WAeUP Student container for the various student data
714    """
715    meta_type = 'StudentClearance'
716    portal_type = meta_type
717    security = ClassSecurityInfo()
718
719    security.declareProtected(View,"Title")
720    def Title(self):
721        """compose title"""
722        content = self.getContent()
723        #return "Clearance Data for %s %s" % (content.firstname,content.lastname)
724        return "Clearance Data"
725
726
727InitializeClass(StudentClearance)
728
729def addStudentClearance(container, id, REQUEST=None, **kw):
730    """Add a Students personal data."""
731    ob = StudentClearance(id, **kw)
732    return CPSBase_adder(container, ob, REQUEST=REQUEST)
733
734###)
735
736class StudentStudyLevel(CPSDocument): ###(
737    """
738    WAeUP Student container for the various student data
739    """
740    meta_type = 'StudentStudyLevel'
741    portal_type = meta_type
742    security = ClassSecurityInfo()
743
744    security.declareProtected(View,"Title")
745    def Title(self):
746        """compose title"""
747        return "Level %s" % self.aq_parent.getId()
748
749##    security.declarePublic("gpa")
750##    def gpa(self):
751##        """calculate the gpa"""
752##        sum = 0
753##        course_count = 0
754##        for sc in self.objectValues():
755##            result = sc.getContent()
756##            if not result.grade:
757##                continue
758##            res = self.portal_catalog({'meta_type': 'Course',
759##                                          'id': sc.aq_parent.id})
760##            if len(res) != 1:
761##                continue
762##            course = res[0].getObject().getContent()
763##            sum += course.credits * ['F','E','D','C','B','A'].index(result.grade)
764##            course_count += 1
765##        if course_count:
766##            return sum/course_count
767##        return 0.0
768
769InitializeClass(StudentStudyLevel)
770
771def addStudentStudyLevel(container, id, REQUEST=None, **kw):
772    """Add a Students personal data."""
773    ob = StudentStudyLevel(id, **kw)
774    return CPSBase_adder(container, ob, REQUEST=REQUEST)
775
776###)
777
778class StudentStudyCourse(CPSDocument): ###(
779    """
780    WAeUP Student container for the various student data
781    """
782    meta_type = 'StudentStudyCourse'
783    portal_type = meta_type
784    security = ClassSecurityInfo()
785
786    security.declareProtected(View,"Title")
787    def Title(self):
788        """compose title"""
789        content = self.getContent()
790        return "Study Course"
791
792
793InitializeClass(StudentStudyCourse)
794
795def addStudentStudyCourse(container, id, REQUEST=None, **kw):
796    """Add a Students personal data."""
797    ob = StudentStudyCourse(id, **kw)
798    return CPSBase_adder(container, ob, REQUEST=REQUEST)
799
800###)
801
802class StudentApplication(CPSDocument): ###(
803    """
804    WAeUP Student container for the various student data
805    """
806    meta_type = 'StudentApplication'
807    portal_type = meta_type
808    security = ClassSecurityInfo()
809
810    security.declareProtected(View,"Title")
811    def Title(self):
812        """compose title"""
813        return "Application Data"
814
815
816InitializeClass(StudentApplication)
817
818def addStudentApplication(container, id, REQUEST=None, **kw):
819    """Add a Students eligibility data."""
820    ob = StudentApplication(id, **kw)
821    return CPSBase_adder(container, ob, REQUEST=REQUEST)
822###)
823
824
825class StudentPume(CPSDocument): ###(
826    """
827    WAeUP Student container for the various student data
828    """
829    meta_type = 'StudentPume'
830    portal_type = meta_type
831    security = ClassSecurityInfo()
832
833    security.declareProtected(View,"Title")
834    def Title(self):
835        """compose title"""
836        return "PUME Results"
837
838
839InitializeClass(StudentPume)
840
841def addStudentPume(container, id, REQUEST=None, **kw):
842    """Add a Students PUME data."""
843    ob = StudentPume(id, **kw)
844    return CPSBase_adder(container, ob, REQUEST=REQUEST)
845###)
846
847##class StudentSemester(CPSDocument): ###(
848##    """
849##    WAeUP StudentSemester containing the courses and students
850##    """
851##    meta_type = 'StudentSemester'
852##    portal_type = meta_type
853##    security = ClassSecurityInfo()
854##
855##InitializeClass(StudentSemester)
856##
857##def addStudentSemester(container, id, REQUEST=None, **kw):
858##    """Add a StudentSemester."""
859##    ob = StudentSemester(id, **kw)
860##    return CPSBase_adder(container, ob, REQUEST=REQUEST)
861##
862#####)
863
864##class Semester(CPSDocument): ###(
865##    """
866##    WAeUP Semester containing the courses and students
867##    """
868##    meta_type = 'Semester'
869##    portal_type = meta_type
870##    security = ClassSecurityInfo()
871##
872##InitializeClass(Semester)
873##
874##def addSemester(container, id, REQUEST=None, **kw):
875##    """Add a Semester."""
876##    ob = Semester(id, **kw)
877##    return CPSBase_adder(container, ob, REQUEST=REQUEST)
878##
879#####)
880
881class StudentCourseResult(CPSDocument): ###(
882    """
883    WAeUP StudentCourseResult
884    """
885    meta_type = 'StudentCourseResult'
886    portal_type = meta_type
887    security = ClassSecurityInfo()
888
889    def getCourseEntry(self,cid):
890        res = self.portal_catalog({'meta_type': "Course",
891                                           'id': cid})
892        if res:
893            return res[-1]
894        else:
895            return None
896
897    security.declareProtected(View,"Title")
898    def Title(self):
899        """compose title"""
900        cid = self.aq_parent.getId()
901        ce = self.getCourseEntry(cid)
902        if ce:
903            return "%s" % ce.Title
904        return "No course with id %s" % cid
905
906InitializeClass(StudentCourseResult)
907
908def addStudentCourseResult(container, id, REQUEST=None, **kw):
909    """Add a StudentCourseResult."""
910    ob = StudentCourseResult(id, **kw)
911    return CPSBase_adder(container, ob, REQUEST=REQUEST)
912###)
913
914# Backward Compatibility StudyLevel
915
916from Products.WAeUP_SRP.Academics import StudyLevel
917
918from Products.WAeUP_SRP.Academics import addStudyLevel
919
Note: See TracBrowser for help on using the repository browser.