source: WAeUP_SRP/branches/uli/Students.py @ 1596

Last change on this file since 1596 was 1593, checked in by uli, 18 years ago

Merged current trunk into uli-branch.

  • Property svn:keywords set to Id
File size: 58.5 KB
Line 
1#-*- mode: python; mode: fold -*-
2# $Id: Students.py 1593 2007-03-19 18:57:54Z uli $
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,os
20import Globals
21p_home = Globals.package_home(globals())
22i_home = Globals.INSTANCE_HOME
23MAX_TRANS = 1000
24import DateTime
25# import PIL.Image
26from StringIO import StringIO
27
28def makeCertificateCode(code): ###(
29    code = code.replace('.','')
30    code = code.replace('(','')
31    code = code.replace(')','')
32    code = code.replace('/','')
33    code = code.replace(' ','')
34    code = code.replace('_','')
35    return code
36
37###)
38
39def getInt(s): ###(
40    try:
41        return int(s)
42    except:
43        return 0
44
45def getFloat(s):
46    try:
47        return float(s)
48    except:
49        return 0.0
50
51###)
52
53def getStudentByRegNo(self,reg_no): ###(
54    """search student by JAMB Reg No and return StudentFolder"""
55    search = ZCatalog.searchResults(self.portal_catalog,{'meta_type': 'StudentApplication',
56                                  'SearchableText': reg_no,
57                                  })
58    if len(search) < 1:
59        return None
60    return search[0].getObject().aq_parent
61
62###)
63
64def checkJambNo(jnr):
65    try:
66        if len(jnr) != 10:
67            return False
68    except:
69        return False
70    try:
71        int(jnr[:8])
72        return True
73    except:
74        return False
75
76class StudentsFolder(CPSDocument): ###(
77    """
78    WAeUP container for the various WAeUP containers data
79    """
80    meta_type = 'StudentsFolder'
81    portal_type = meta_type
82    security = ClassSecurityInfo()
83
84
85
86    security.declareProtected(ModifyPortalContent,"createDEStudents")###(
87    def createDEStudents(self):
88        """load Fulltime Studentdata from CSV values"""
89        import transaction
90        import random
91        #from pdb import set_trace
92        wftool = self.portal_workflow
93        students_folder = self.portal_catalog({'meta_type': 'StudentsFolder'})[-1].getObject()
94        csv_d = {'jamb_reg_no': "RegNumber",
95                 'jamb_lastname': "Name",
96                 'session': "Session",
97                 'pume_tot_score': "PUDE SCORE",
98                 ##'jamb_score': "JambScore",
99                 'entry_mode': "EntryMode",
100                 'jamb_sex': "Sex",
101                 'jamb_state': "State",
102                 'jamb_first_cos': "AdminCourse",
103                 'faculty': "AdminFaculty",
104                 'course_code': "AdmitCoscode",
105                 'stud_status':"AdmitStatus",
106                 'department': "AdmitDept",
107                 'jamb_lga': "LGA",
108                 'app_email': "email",
109                 'app_mobile': "PhoneNumbers",
110                 }
111        csv_fields = [f[1] for f in csv_d.items()]
112        tr_count = 0
113        total = 0
114        #name = 'pume_results'
115        name = 'DE_Admitted'
116        no_import = []
117        s = ','.join(['"%s"' % fn for fn in csv_fields])
118        no_import.append('"Error",%s' % s)
119        format = '"%(Error)s",' + ','.join(['"%%(%s)s"' % fn for fn in csv_fields])
120        no_certificate = "no certificate %s" % format
121        open("%s/import/%s_not_imported.csv" % (i_home,name),"w").write('\n'.join(no_import))
122        logger = logging.getLogger('Students.StudentsFolder.createDEStudents')
123        logger.info('Start loading from %s.csv' % name)
124        l = self.portal_catalog({'meta_type': "Certificate"})
125        certs = {}
126        cert_docs = {}
127        for f in l:
128            certs[f.getId] = f.getObject().getContent()
129        try:
130            result = csv.DictReader(open("%s/import/%s.csv" % (i_home,name),"rb"))
131        except:
132            logger.error('Error reading %s.csv' % name)
133            return
134        for jamb in result:
135            jamb['Error'] = "Processing"
136            logger.info(format % jamb)
137            jamb_reg_no = jamb.get(csv_d['jamb_reg_no'])
138            res = self.portal_catalog({'portal_type': "StudentApplication",
139                                     'SearchableText': jamb_reg_no })
140            if res:
141                em = 'Student with RegNo %s already exists\n' % jamb_reg_no
142                logger.info(em)
143                jamb['Error'] = "Student exists"
144                no_import.append(format % jamb)
145                continue
146            cert_id = makeCertificateCode(jamb.get(csv_d['course_code']))
147            if cert_id not in certs.keys():
148                em = 'No Certificate with ID %s \n' % cert_id
149                logger.info(em)
150                jamb['Error'] = "No Certificate %s" % cert_id
151                no_import.append( format % jamb)
152                continue
153            jamb_reg_no =jamb.get(csv_d['jamb_reg_no'])
154            cert_doc = certs[cert_id]
155            catalog_entry = {}
156            catalog_entry['jamb_reg_no'] = jamb_reg_no
157            jamb_name = jamb.get(csv_d['jamb_lastname'])
158            jamb_name.replace('>','')
159            jamb_name.replace('<','')
160            names = jamb_name.split()
161            letter = names[-1][0].upper()
162            sid = self.generateStudentId(letter)
163            not_created = True
164            while not_created:
165                try:
166                    students_folder.invokeFactory('Student', sid)
167                    not_created = False
168                except BadRequest:
169                    sid = self.generateStudentId(letter)
170            catalog_entry['id'] = sid
171            tr_count += 1
172            logger.info('%(total)s+%(tr_count)s: Creating Student with ID %(sid)s REG-NO %(jamb_reg_no)s ' % vars())
173            student = getattr(self,sid)
174            student.manage_setLocalRoles(sid, ['Owner',])
175            student.invokeFactory('StudentPume','pume')
176            dp = {'Title': 'Pume Data'}
177            student.invokeFactory('StudentApplication','application')
178            da = {'Title': 'Application Data'}
179            da["jamb_lastname"] = jamb_name
180            da_fields = ('jamb_reg_no',
181                         'jamb_sex',
182                         'entry_mode',
183                         #'jamb_score',
184                         'jamb_first_cos',
185                         'jamb_sex',
186                         'jamb_state',
187                         'jamb_lga',
188                         'app_email',
189                         'app_mobile',
190                         )
191            for f in da_fields:
192                da[f] = jamb.get(csv_d[f])
193            catalog_entry['email'] = jamb.get(csv_d['app_email'])
194            app = student.application
195            app_doc = app.getContent()
196            picture ="%s/import/pictures/%s.jpg" % (i_home,jamb_reg_no)
197            #import pdb;pdb.set_trace()
198            if os.path.exists(picture):
199                file = open(picture)
200                if False:
201                    img = PIL.Image.open(file)
202                    img.thumbnail((150,200),
203                                  resample=PIL.Image.ANTIALIAS)
204                    # We now need a buffer to write to. It can't be the same
205                    # as the inbuffer as the PNG writer will write over itself.
206                    outfile = StringIO()
207                    img.save(outfile, format=img.format)
208                else:
209                    outfile = file.read()
210                app_doc.manage_addFile('passport',
211                                       file=outfile,
212                                       title="%s.jpg" % jamb_reg_no)
213            app.getContent().edit(mapping=da)
214            app.manage_setLocalRoles(sid, ['Owner',])
215            #wftool.doActionFor(app,'close')
216            dp_fields = (
217                         #'pume_eng_score',
218                         #'pume_gen_score',
219                         'pume_tot_score',
220                         )
221            dp['pume_tot_score'] = jamb.get(csv_d['pume_tot_score']) or "No Option Shaded"
222            pume = student.pume
223            pume.getContent().edit(mapping=dp)
224            #wftool.doActionFor(pume,'close')
225            pume.manage_setLocalRoles(sid, ['Owner',])
226            #student.getContent().createSubObjects()
227            dp = {}
228            if len(names) == 3:
229                dp['firstname'] = names[0].capitalize()
230                dp['middlename'] = names[1].capitalize()
231                dp['lastname'] = names[2].capitalize()
232            elif len(names) == 2:
233                dp['firstname'] = names[0].capitalize()
234                dp['middlename'] = ''
235                dp['lastname'] = names[1].capitalize()
236            else:
237                dp['firstname'] = ''
238                dp['middlename'] = ''
239                dp['lastname'] = jamb_name
240            dp['sex'] = jamb.get(csv_d['jamb_sex']) == 'F'
241            catalog_entry['sex'] = dp['sex']
242            catalog_entry['name'] = "%(firstname)s %(middlename)s %(lastname)s" % dp
243            student.invokeFactory('StudentPersonal','personal')
244            per = student.personal
245            per_doc = per.getContent()
246            per_doc.edit(mapping = dp)
247            per.manage_setLocalRoles(sid, ['Owner',])
248            if jamb.get(csv_d['stud_status']) == "Admitted":
249                wftool.doActionFor(student,'pume_pass')
250                wftool.doActionFor(student,'admit')
251            else:
252                wftool.doActionFor(student,'pume_fail')
253                wftool.doActionFor(student,'reject_admission')
254                continue
255            #
256            # Clearance
257            #
258            student.invokeFactory('StudentClearance','clearance')
259            #wftool.doActionFor(student.clearance,'open')
260            dp = {'Title': 'Clearance/Eligibility Record'}
261            student.clearance.manage_setLocalRoles(sid, ['Owner',])
262            #
263            # Study Course
264            #
265            student.invokeFactory('StudentStudyCourse','study_course')
266            study_course = student.study_course
267            dsc = {}
268            #from_certificate = ['title',
269            #                   'max_elect',
270            #                   'max_pass',
271            #                   'n_core',
272            #                   'nr_years',
273            #                   'probation_credits',
274            #                   'promotion_credits',
275            #                   'start_level',
276            #                  ]
277            #for f in from_certificate:
278            #    dsc[f] = getattr(cert_doc,f)
279            #dsc['faculty'] = jamb.get(csv_d['faculty'])
280            #dsc['department'] = jamb.get(csv_d['department'])
281            catalog_entry['faculty'] = jamb.get(csv_d['faculty'])
282            catalog_entry['department'] = jamb.get(csv_d['department'])
283            catalog_entry['course'] = cert_id
284            #catalog_entry['level'] = getattr(cert_doc,'start_level')
285            catalog_entry['level'] = '200'
286            dsc['study_course'] = cert_id
287            dsc['current_level'] = '200'
288            #dsc['entry_session'] = jamb.get(csv_d['session'])
289            study_course.getContent().edit(mapping=dsc)
290            self.students_catalog.addRecord(**catalog_entry)
291            if tr_count > 10:
292                if len(no_import) > 1:
293                    open("%s/import/%s_not_imported.csv" % (i_home,name),"a").write(
294                             '\n'.join(no_import)+'\n')
295                    no_import = []
296                em = '%d transactions commited\n' % tr_count
297                transaction.commit()
298                logger.info(em)
299                total += tr_count
300                tr_count = 0
301        open("%s/import/%s_not_imported.csv" % (i_home,name),"a").write(
302                                               '\n'.join(no_import))
303        return self.REQUEST.RESPONSE.redirect("%s" % self.REQUEST.get('URL1'))
304    ###)
305
306    security.declareProtected(ModifyPortalContent,"createNewStudents")###(
307    def createNewStudents(self):
308        """load Fulltime Studentdata from CSV values"""
309        import transaction
310        import random
311        #from pdb import set_trace
312        wftool = self.portal_workflow
313        students_folder = self.portal_catalog({'meta_type': 'StudentsFolder'})[-1].getObject()
314        csv_d = {'jamb_reg_no': "RegNumber",
315                 'jamb_lastname': "Name",
316                 'session': "Session",
317                 'pume_tot_score': "PUME SCORE",
318                 'jamb_score': "JambScore",
319                 'jamb_sex': "Sex",
320                 'jamb_state': "State",
321##                 'jamb_first_cos': "AdminCourse",
322                 'faculty': "AdminFaculty",
323                 'course_code': "AdmitCoscode",
324                 'stud_status':"AdmitStatus",
325                 'department': "AdmitDept",
326                 'jamb_lga': "LGA",
327                 'app_email': "email",
328                 'app_mobile': "PhoneNumbers",
329                 }
330        csv_fields = [f[1] for f in csv_d.items()]
331        tr_count = 0
332        total = 0
333        #name = 'pume_results'
334        name = 'Admitted'
335        no_import = []
336        s = ','.join(['"%s"' % fn for fn in csv_fields])
337        no_import.append('"Error",%s' % s)
338        format = '"%(Error)s",' + ','.join(['"%%(%s)s"' % fn for fn in csv_fields])
339        no_certificate = "no certificate %s" % format
340        open("%s/import/%s_not_imported.csv" % (i_home,name),"w").write('\n'.join(no_import))
341        logger = logging.getLogger('Students.StudentsFolder.createNewStudents')
342        logger.info('Start loading from %s.csv' % name)
343        l = self.portal_catalog({'meta_type': "Certificate"})
344        certs = {}
345        cert_docs = {}
346        for f in l:
347            certs[f.getId] = f.getObject().getContent()
348        try:
349            result = csv.DictReader(open("%s/import/%s.csv" % (i_home,name),"rb"))
350        except:
351            logger.error('Error reading %s.csv' % name)
352            return
353        for jamb in result:
354            jamb['Error'] = "Processing "
355            logger.info(format % jamb)
356            jamb_reg_no = jamb.get(csv_d['jamb_reg_no'])
357            res = self.portal_catalog({'portal_type': "StudentApplication",
358                                     'SearchableText': jamb_reg_no })
359            if res:
360                em = 'Student with RegNo %s already exists\n' % jamb_reg_no
361                logger.info(em)
362                jamb['Error'] = "Student exists"
363                no_import.append(format % jamb)
364                continue
365            cert_id = makeCertificateCode(jamb.get(csv_d['course_code']))
366            if cert_id not in certs.keys():
367                em = 'No Certificate with ID %s \n' % cert_id
368                logger.info(em)
369                jamb['Error'] = "No Certificate %s" % cert_id
370                no_import.append( format % jamb)
371                continue
372            res = self.portal_pumeresults(jamb_reg_no = jamb_reg_no)
373            if len(res) == 1:
374                self.portal_pumeresults.modifyRecord(jamb_reg_no = jamb_reg_no,
375                                                     status = jamb.get(csv_d['stud_status']),
376                                                     )
377            jamb_reg_no =jamb.get(csv_d['jamb_reg_no'])
378            cert_doc = certs[cert_id]
379            catalog_entry = {}
380            catalog_entry['jamb_reg_no'] = jamb_reg_no
381            jamb_name = jamb.get(csv_d['jamb_lastname'])
382            jamb_name.replace('>','')
383            jamb_name.replace('<','')
384            names = jamb_name.split()
385            letter = names[-1][0].upper()
386            sid = self.generateStudentId(letter)
387            not_created = True
388            while not_created:
389                try:
390                    students_folder.invokeFactory('Student', sid)
391                    not_created = False
392                except BadRequest:
393                    sid = self.generateStudentId(letter)
394            catalog_entry['id'] = sid
395            tr_count += 1
396            logger.info('%(total)s+%(tr_count)s: Creating Student with ID %(sid)s REG-NO %(jamb_reg_no)s ' % vars())
397            student = getattr(self,sid)
398            student.manage_setLocalRoles(sid, ['Owner',])
399            student.invokeFactory('StudentPume','pume')
400            dp = {'Title': 'Pume Data'}
401            student.invokeFactory('StudentApplication','application')
402            da = {'Title': 'Application Data'}
403            da["jamb_lastname"] = jamb_name
404            da_fields = ('jamb_reg_no',
405                         'jamb_sex',
406                         #'jamb_state',
407                         'jamb_score',
408##                         'jamb_first_cos',
409                         'jamb_sex',
410                         'jamb_state',
411                         'jamb_lga',
412                         'app_email',
413                         'app_mobile',
414                         )
415            for f in da_fields:
416                da[f] = jamb.get(csv_d[f])
417            catalog_entry['email'] = jamb.get(csv_d['app_email'])
418            app = student.application
419            app_doc = app.getContent()
420            picture ="%s/import/pictures/%s.jpg" % (i_home,jamb_reg_no)
421            #import pdb;pdb.set_trace()
422            if os.path.exists(picture):
423                file = open(picture)
424                if False:
425                    img = PIL.Image.open(file)
426                    img.thumbnail((150,200),
427                                  resample=PIL.Image.ANTIALIAS)
428                    # We now need a buffer to write to. It can't be the same
429                    # as the inbuffer as the PNG writer will write over itself.
430                    outfile = StringIO()
431                    img.save(outfile, format=img.format)
432                else:
433                    outfile = file.read()
434                app_doc.manage_addFile('passport',
435                                       file=outfile,
436                                       title="%s.jpg" % jamb_reg_no)
437            app.getContent().edit(mapping=da)
438            app.manage_setLocalRoles(sid, ['Owner',])
439            #wftool.doActionFor(app,'close')
440            dp_fields = (
441                         #'pume_eng_score',
442                         #'pume_gen_score',
443                         'pume_tot_score',
444                         )
445            dp['pume_tot_score'] = jamb.get(csv_d['pume_tot_score']) or "No Option Shaded"
446            pume = student.pume
447            pume.getContent().edit(mapping=dp)
448            #wftool.doActionFor(pume,'close')
449            pume.manage_setLocalRoles(sid, ['Owner',])
450            #student.getContent().createSubObjects()
451            dp = {}
452            if len(names) == 3:
453                dp['firstname'] = names[0].capitalize()
454                dp['middlename'] = names[1].capitalize()
455                dp['lastname'] = names[2].capitalize()
456            elif len(names) == 2:
457                dp['firstname'] = names[0].capitalize()
458                dp['middlename'] = ''
459                dp['lastname'] = names[1].capitalize()
460            else:
461                dp['firstname'] = ''
462                dp['middlename'] = ''
463                dp['lastname'] = jamb_name
464            dp['sex'] = jamb.get(csv_d['jamb_sex']) == 'F'
465            catalog_entry['sex'] = dp['sex']
466            catalog_entry['name'] = "%(firstname)s %(middlename)s %(lastname)s" % dp
467            student.invokeFactory('StudentPersonal','personal')
468            per = student.personal
469            per_doc = per.getContent()
470            per_doc.edit(mapping = dp)
471            per.manage_setLocalRoles(sid, ['Owner',])
472            if jamb.get(csv_d['stud_status']) == "Admitted":
473                wftool.doActionFor(student,'pume_pass')
474                wftool.doActionFor(student,'admit')
475            else:
476                wftool.doActionFor(student,'pume_fail')
477                wftool.doActionFor(student,'reject_admission')
478                continue
479            #
480            # Clearance
481            #
482            student.invokeFactory('StudentClearance','clearance')
483            #wftool.doActionFor(student.clearance,'open')
484            dp = {'Title': 'Clearance/Eligibility Record'}
485            student.clearance.manage_setLocalRoles(sid, ['Owner',])
486            #
487            # Study Course
488            #
489            student.invokeFactory('StudentStudyCourse','study_course')
490            study_course = student.study_course
491            dsc = {}
492            #from_certificate = ['title',
493            #                   'max_elect',
494            #                   'max_pass',
495            #                   'n_core',
496            #                   'nr_years',
497            #                   'probation_credits',
498            #                   'promotion_credits',
499            #                   'start_level',
500            #                  ]
501            #for f in from_certificate:
502            #    dsc[f] = getattr(cert_doc,f)
503            #dsc['faculty'] = jamb.get(csv_d['faculty'])
504            #dsc['department'] = jamb.get(csv_d['department'])
505            catalog_entry['faculty'] = jamb.get(csv_d['faculty'])
506            catalog_entry['department'] = jamb.get(csv_d['department'])
507            catalog_entry['course'] = cert_id
508            #catalog_entry['level'] = getattr(cert_doc,'start_level')
509            catalog_entry['level'] = '100'
510            dsc['study_course'] = cert_id
511            dsc['entry_level'] = '100'
512            #dsc['entry_session'] = jamb.get(csv_d['session'])
513            study_course.getContent().edit(mapping=dsc)
514            self.students_catalog.addRecord(**catalog_entry)
515            if tr_count > 10:
516                if len(no_import) > 0:
517                    open("%s/import/%s_not_imported.csv" % (i_home,name),"a").write(
518                             '\n'.join(no_import) + "\n")
519                    no_import = []
520                em = '%d transactions commited\n' % tr_count
521                transaction.commit()
522                logger.info(em)
523                total += tr_count
524                tr_count = 0
525        open("%s/import/%s_not_imported.csv" % (i_home,name),"a").write(
526                                                '\n'.join(no_import))
527        return self.REQUEST.RESPONSE.redirect("%s" % self.REQUEST.get('URL1'))
528    ###)
529
530    security.declareProtected(ModifyPortalContent,"importReturningStudents")###(
531    def importReturningStudents(self):
532        """load Returning Studentdata from CSV values"""
533        import transaction
534        import random
535        #from pdb import set_trace
536        wftool = self.portal_workflow
537        current = DateTime.DateTime().strftime("%d-%m-%y_%H_%M_%S")
538        students_folder = self.portal_catalog({'meta_type': 'StudentsFolder'})[-1].getObject()
539        tr_count = 1
540        total = 0
541        #name = 'pume_results'
542        name = 'Returning'
543        table = self.returning_import
544        no_import = []
545        imported = []
546        logger = logging.getLogger('Students.StudentsFolder.importReturningStudents')
547        try:
548            returning = csv.DictReader(open("%s/import/%s.csv" % (i_home,name),"rb"))
549        except:
550            logger.error('Error reading %s.csv' % name)
551            return
552        l = self.portal_catalog({'meta_type': "Certificate"})
553        certs = {}
554        cert_docs = {}
555        for f in l:
556            certs[f.getId] = f.getObject().getContent()
557        start = True
558        res = table()
559        regs = []
560        if len(res) > 0:
561            regs = [s.matric_no for s in res]
562        #import pdb;pdb.set_trace()
563        for student in returning:
564            if start:
565                start = False
566                logger.info('Start loading from %s.csv' % name)
567                s = ','.join(['"%s"' % fn for fn in student.keys()])
568                imported.append(s)
569                no_import.append('%s,"Error"' % s)
570                format = ','.join(['"%%(%s)s"' % fn for fn in student.keys()])
571                format_error = format + ',"%(Error)s"'
572                no_certificate = "no certificate %s" % format
573            student['matric_no'] = matric_no = student.get('matric_no').upper()
574            student['Mode_of_Entry'] = entry_mode = student.get('Mode of Entry').upper()
575            student['Permanent_Address'] = perm_address = student.get('Permanent Address')
576            if matric_no == '':
577                student['Error'] = "Empty matric_no"
578                no_import.append( format_error % student)
579                continue
580            if matric_no in regs or self.returning_import(matric_no = matric_no):
581                student['Error'] = "Duplicate"
582                no_import.append( format_error % student)
583                continue
584            cert_id = makeCertificateCode(student.get('Coursemajorcode'))
585            if cert_id not in certs.keys():
586                student['Error'] = "No Certificate %s" % cert_id
587                no_import.append( format_error % student)
588                continue
589            try:
590                table.addRecord(**student)
591            except ValueError:
592                student['Error'] = "Duplicate"
593                no_import.append( format_error % student)
594                continue
595            regs.append(student.get('matric_no'))
596            imported.append(format % student)
597            tr_count += 1
598            if tr_count > 1000:
599                if len(no_import) > 0:
600                    open("%s/import/%s_not_imported%s.csv" % (i_home,name,current),"a").write(
601                             '\n'.join(no_import) + '\n')
602                    no_import = []
603                open("%s/import/%simported%s.csv" % (i_home,name,current),"a").write(
604                                            '\n'.join(no_import) + "\n")
605                imported = []
606                em = '%d transactions commited total %s\n' % (tr_count,total)
607                transaction.commit()
608                regs = []
609                logger.info(em)
610                total += tr_count
611                tr_count = 0
612        open("%s/import/%simported%s.csv" % (i_home,name,current),"a").write(
613                                            '\n'.join(imported))
614        open("%s/import/%s_not_imported%s.csv" % (i_home,name,current),"a").write(
615                                                '\n'.join(no_import))
616        return self.REQUEST.RESPONSE.redirect("%s" % self.REQUEST.get('URL1'))
617    ###)
618
619    security.declareProtected(ModifyPortalContent,"fixVerdicts")###(
620    def fixVerdicts(self,csv_file=None):
621        """fix wrong uploaded verdicts"""
622        import transaction
623        import random
624        wftool = self.portal_workflow
625        current = DateTime.DateTime().strftime("%d-%m-%y_%H_%M_%S")
626        students_folder = self.portal_url.getPortalObject().campus.students
627        tr_count = 1
628        total = 0
629        if csv_file is None:
630            name = 'Verdicts'
631        else:
632            name = csv_file
633        st_cat = self.students_catalog
634        no_import = []
635        verdicts_voc = self.portal_vocabularies.verdicts
636        rverdicts = {}
637        for k,v in verdicts_voc.items():
638            rverdicts[v.upper()] = k
639        rverdicts['STUDENT ON PROBATION'] = 'C'
640        logger = logging.getLogger('Students.StudentsFolder.fixVerdicts')
641        try:
642            verdicts = csv.DictReader(open("%s/import/%s.csv" % (i_home,name),"rb"))
643        except:
644            logger.error('Error reading %s.csv' % name)
645            return
646        start = True
647        #import pdb;pdb.set_trace()
648        for verdict in verdicts:
649            if start:
650                start = False
651                logger.info('Start loading from %s.csv' % name)
652                s = ','.join(['"%s"' % fn for fn in verdict.keys()])
653                no_import.append('%s,"Error"' % s)
654                format = ','.join(['"%%(%s)s"' % fn for fn in verdict.keys()])
655                format_error = format + ',"%(Error)s"'
656            matric_no = verdict.get('MAT NO')
657            if not matric_no:
658                continue
659            matric_no = matric_no.upper()
660            if matric_no == '':
661                continue
662            verdict_code = rverdicts.get(verdict.get('CATEGORY'),None)
663            if verdict_code is None:
664                continue
665            sres = st_cat(matric_no = matric_no)
666            if sres:
667                student_id = sres[0].id
668                student_obj = getattr(students_folder,student_id,None)
669                if student_obj:
670                    study_course = getattr(student_obj,'study_course',None)
671                    if study_course is None:
672                        verdict['Error'] = "Student did not yet log in"
673                        no_import.append( format_error % verdict)
674                        continue
675                st_cat.modifyRecord(id = student_id,
676                                    verdict=verdict_code)
677
678                dsc = {}
679                dsc['current_verdict'] = verdict_code
680                study_course.getContent().edit(mapping=dsc)
681            else:
682                verdict['Error'] = "Not found in students_catalog"
683                no_import.append( format_error % verdict)
684                continue
685            tr_count += 1
686            if tr_count > 1000:
687                if len(no_import) > 0:
688                    open("%s/import/%s_not_imported%s.csv" % (i_home,name,current),"a").write(
689                             '\n'.join(no_import) + '\n')
690                    no_import = []
691                em = '%d transactions commited total %s\n' % (tr_count,total)
692                transaction.commit()
693                regs = []
694                logger.info(em)
695                total += tr_count
696                tr_count = 0
697        open("%s/import/%s_not_imported%s.csv" % (i_home,name,current),"a").write(
698                                                '\n'.join(no_import))
699        total += tr_count
700        em = '%d total transactions commited' % (total)
701        logger.info(em)
702        return self.REQUEST.RESPONSE.redirect("%s" % self.REQUEST.get('URL1'))
703    ###)
704
705    security.declareProtected(ModifyPortalContent,"fixAllEntryModeForReturning")###(
706    def fixAllEntryModeForReturning(self):
707        "read all Returning*.csv"
708        ipath = "%s/import/" % i_home
709        names = os.listdir(ipath)
710        for name in names:
711            head,tail = os.path.splitext(name)
712            if head.startswith('Returning')\
713               and tail == '.csv'\
714               and name.find('imported') < 0:
715                self.fixEntryModeForReturning(csv_file=head)
716    ###)
717
718    security.declareProtected(ModifyPortalContent,"fixEntryModeForReturning")###(
719    def fixEntryModeForReturning(self,csv_file=None):
720        """load Returning Studentdata from CSV values"""
721        import transaction
722        import random
723        wftool = self.portal_workflow
724        current = DateTime.DateTime().strftime("%d-%m-%y_%H_%M_%S")
725        students_folder = self.portal_url.getPortalObject().campus.students
726        tr_count = 1
727        total = 0
728        if csv_file is None:
729            name = 'Returning'
730        else:
731            name = csv_file
732        table = self.returning_import
733        st_cat = self.students_catalog
734        no_import = []
735        logger = logging.getLogger('Students.StudentsFolder.fixEntryModeForReturning')
736        try:
737            returning = csv.DictReader(open("%s/import/%s.csv" % (i_home,name),"rb"))
738        except:
739            logger.error('Error reading %s.csv' % name)
740            return
741        start = True
742        for student in returning:
743            if start:
744                start = False
745                logger.info('Start loading from %s.csv' % name)
746                s = ','.join(['"%s"' % fn for fn in student.keys()])
747                no_import.append('%s,"Error"' % s)
748                format = ','.join(['"%%(%s)s"' % fn for fn in student.keys()])
749                format_error = format + ',"%(Error)s"'
750            matric_no = student.get('matric_no')
751            if not matric_no:
752                continue
753            matric_no = matric_no.upper()
754            student['matric_no'] = matric_no
755            if matric_no == '':
756                continue
757            if not table(matric_no = matric_no):
758                student['Error'] = "Not imported yet"
759                no_import.append( format_error % student)
760                continue
761            student_id = None
762            app = None
763            per = None
764            if st_cat(matric_no = matric_no):
765                student_id = st_cat(matric_no = matric_no)[0].id
766                student_obj = getattr(students_folder,student_id,None)
767                if student_obj:
768                    app = getattr(student_obj,'application',None)
769                    if app is not None:
770                        app_doc = app.getContent()
771                    per = getattr(student_obj,'personal',None)
772                    if per is not None:
773                        per_doc = per.getContent()
774            student['Mode_of_Entry'] = entry_mode = student.get('Mode of Entry').upper()
775            student['Permanent_Address'] = perm_address = student.get('Permanent Address')
776            #import pdb;pdb.set_trace()
777            if not entry_mode:
778                student['Error'] = "'Mode of Entry' empty"
779                no_import.append( format_error % student)
780                continue
781            try:
782                table.modifyRecord(matric_no = matric_no,
783                                   Mode_of_Entry = entry_mode,
784                                   Permanent_Address = perm_address)
785            except KeyError:
786                student['Error'] = "Not found in returning_import"
787                no_import.append( format_error % student)
788                continue
789            if student_id is not None:
790                try:
791                    st_cat.modifyRecord(id = student_id,
792                                        entry_mode=entry_mode)
793                except KeyError:
794                    student['Error'] = "Not found in students_catalog"
795                    no_import.append( format_error % student)
796                    continue
797            if app is not None:
798                da = {}
799                da['entry_mode'] = entry_mode
800                app_doc.edit(mapping=da)
801            if per is not None:
802                dp = {}
803                dp['perm_address'] = perm_address
804                per_doc.edit(mapping=dp)
805            tr_count += 1
806            if tr_count > 1000:
807                if len(no_import) > 0:
808                    open("%s/import/%s_not_imported%s.csv" % (i_home,name,current),"a").write(
809                             '\n'.join(no_import) + '\n')
810                    no_import = []
811                em = '%d transactions commited total %s\n' % (tr_count,total)
812                transaction.commit()
813                regs = []
814                logger.info(em)
815                total += tr_count
816                tr_count = 0
817        open("%s/import/%s_not_imported%s.csv" % (i_home,name,current),"a").write(
818                                                '\n'.join(no_import))
819        return self.REQUEST.RESPONSE.redirect("%s" % self.REQUEST.get('URL1'))
820    ###)
821
822    security.declareProtected(ModifyPortalContent,"updateReturningStudents")###(
823    def updateReturningStudents(self):
824        """load and overwrite Returning Student Data from CSV values"""
825        import transaction
826        import random
827        #from pdb import set_trace
828        wftool = self.portal_workflow
829        current = DateTime.DateTime().strftime("%d-%m-%y_%H_%M_%S")
830        students_folder = self.portal_catalog({'meta_type': 'StudentsFolder'})[-1].getObject()
831        tr_count = 1
832        total = 0
833        #name = 'pume_results'
834        name = 'Returning_update'
835        table = self.returning_import
836        no_import = []
837        imported = []
838        logger = logging.getLogger('Students.StudentsFolder.updateReturningStudents')
839        try:
840            returning = csv.DictReader(open("%s/import/%s.csv" % (i_home,name),"rb"))
841        except:
842            logger.error('Error reading %s.csv' % name)
843            return
844        l = self.portal_catalog({'meta_type': "Certificate"})
845        certs = {}
846        cert_docs = {}
847        for f in l:
848            certs[f.getId] = f.getObject().getContent()
849        start = True
850        res = table()
851        regs = []
852        if len(res) > 0:
853            regs = [s.matric_no for s in res]
854        for student in returning:
855            if start:
856                start = False
857                logger.info('Start loading from %s.csv' % name)
858                s = ','.join(['"%s"' % fn for fn in student.keys()])
859                imported.append(s)
860                no_import.append('%s,"Error"' % s)
861                format = ','.join(['"%%(%s)s"' % fn for fn in student.keys()])
862                format_error = format + ',"%(Error)s"'
863                no_certificate = "no certificate %s" % format
864            matric_no = student.get('matric_no').upper()
865            student['matric_no'] = matric_no
866            if matric_no == '':
867                student['Error'] = "Empty matric_no"
868                no_import.append( format_error % student)
869                continue
870#            if matric_no in regs or self.returning_import(matric_no = matric_no):
871#                student['Error'] = "Duplicate"
872#                no_import.append( format_error % student)
873#                continue
874#            cert_id = makeCertificateCode(student.get('Coursemajorcode'))
875#            if cert_id not in certs.keys():
876#                student['Error'] = "No Certificate %s" % cert_id
877#                no_import.append( format_error % student)
878#                continue
879            try:
880                table.modifyRecord(**student)
881            except KeyError:
882                #import pdb;pdb.set_trace()
883                student['Error'] = "no Student found to update"
884                no_import.append( format_error % student)
885                continue
886            #s = self.students_catalog(matric_no=matric_no)
887            #if s:
888            #    level = "%s" % (int(student.get('Level')) + 100)
889            #    self.students_catalog.modifyRecord(id = s[0].id,
890            #                                           level=level)
891
892            regs.append(student.get('matric_no'))
893            imported.append(format % student)
894            tr_count += 1
895            if tr_count > 1000:
896                if len(no_import) > 0:
897                    open("%s/import/%s_not_imported%s.csv" % (i_home,name,current),"a").write(
898                             '\n'.join(no_import) + '\n')
899                    no_import = []
900                open("%s/import/%simported%s.csv" % (i_home,name,current),"a").write(
901                                            '\n'.join(no_import) + "\n")
902                imported = []
903                em = '%d transactions commited total %s\n' % (tr_count,total)
904                transaction.commit()
905                regs = []
906                logger.info(em)
907                total += tr_count
908                tr_count = 0
909        open("%s/import/%simported%s.csv" % (i_home,name,current),"a").write(
910                                            '\n'.join(imported))
911        open("%s/import/%s_not_imported%s.csv" % (i_home,name,current),"a").write(
912                                                '\n'.join(no_import))
913        return self.REQUEST.RESPONSE.redirect("%s" % self.REQUEST.get('URL1'))
914    ###)
915
916    security.declareProtected(ModifyPortalContent,"importResults")###(
917    def importResults(self):
918        """load Returning Students Results from CSV"""
919        import transaction
920        import random
921        #from pdb import set_trace
922        wftool = self.portal_workflow
923        current = DateTime.DateTime().strftime("%d-%m-%y_%H_%M_%S")
924        students_folder = self.portal_catalog({'meta_type': 'StudentsFolder'})[-1].getObject()
925        tr_count = 1
926        total = 0
927        #name = 'pume_results'
928        name = 'Results'
929        table = self.results_import
930        no_import = []
931        imported = []
932        logger = logging.getLogger('Students.StudentsFolder.importResults')
933        try:
934            results = csv.DictReader(open("%s/import/%s.csv" % (i_home,name),"rb"))
935        except:
936            logger.error('Error reading %s.csv' % name)
937            return
938        l = self.portal_catalog({'meta_type': "Course"})
939        courses = [f.getId for f in l]
940        start = True
941        res = table()
942        regs = []
943        if len(res) > 0:
944            regs = [s.key for s in res]
945        no_course = []
946        no_course_list = []
947        course_count = 0
948        for result in results:
949            if start:
950                start = False
951                logger.info('Start loading from %s.csv' % name)
952                s = ','.join(['"%s"' % fn for fn in result.keys()])
953                imported.append(s)
954                no_import.append('%s,"Error"' % s)
955                format = ','.join(['"%%(%s)s"' % fn for fn in result.keys()])
956                format_error = format + ',"%(Error)s"'
957                no_certificate = "no certificate %s" % format
958            course_id = result.get('CosCode')
959            if not course_id:
960                course_id = 'N/A'
961                result['CosCode'] = course_id
962            matric_no = result.get('matric_no').upper()
963            result['matric_no'] = matric_no
964            key = matric_no+course_id
965            if matric_no == '':
966                result['Error'] = "Empty matric_no"
967                no_import.append( format_error % result)
968                continue
969            if key in regs or self.results_import(key = key):
970                result['Error'] = "Duplicate"
971                no_import.append( format_error % result)
972                continue
973            if course_id not in courses:
974                if course_id not in no_course:
975                    course_count +=1
976                    no_course.append(course_id)
977                    no_course_list.append('"%s"' % course_id)
978                    #result['Error'] = "No Course"
979                    #logger.info(format_error % result)
980            result['key'] = key
981            try:
982                table.addRecord(**result)
983            except ValueError:
984                #import pdb;pdb.set_trace()
985                result['Error'] = "Duplicate"
986                no_import.append( format_error % result)
987                continue
988            regs.append(key)
989            imported.append(format % result)
990            tr_count += 1
991            if tr_count > 1000:
992                if len(no_import) > 0:
993                    open("%s/import/%s_not_imported%s.csv" % (i_home,name,current),"a").write(
994                             '\n'.join(no_import)+'\n')
995                    no_import = []
996                open("%s/import/%simported%s.csv" % (i_home,name,current),"a").write(
997                                            '\n'.join(imported) + '\n')
998                imported = []
999                if no_course_list:
1000                    open("%s/import/%sno_courses%s.csv" % (i_home,name,current),"a").write(
1001                                            '\n'.join(no_course_list) + '\n')
1002                    no_course_list = []
1003                em = '%d transactions commited total %s\n courses not found %s' % (tr_count,total,course_count)
1004                transaction.commit()
1005                logger.info(em)
1006                regs = []
1007                total += tr_count
1008                tr_count = 0
1009        open("%s/import/%simported%s.csv" % (i_home,name,current),"a").write(
1010                                            '\n'.join(imported))
1011        open("%s/import/%s_not_imported%s.csv" % (i_home,name,current),"a").write(
1012                                                '\n'.join(no_import))
1013        if no_course_list:
1014            open("%s/import/%sno_courses%s.csv" % (i_home,name,current),"a").write(
1015                                    '\n'.join(no_course_list))
1016        em = '%d transactions commited total %s\n courses not found %s' % (tr_count,total,course_count)
1017        logger.info(em)
1018        return self.REQUEST.RESPONSE.redirect("%s" % self.REQUEST.get('URL1'))
1019    ###)
1020
1021    security.declareProtected(ModifyPortalContent,"updateStudyCourse")###(
1022    def updateStudyCourse(self):
1023        """update StudyCourse from CSV values"""
1024        import transaction
1025        import random
1026        from pdb import set_trace
1027        wftool = self.portal_workflow
1028        students_folder = self.portal_catalog({'meta_type': 'StudentsFolder'})[-1].getObject()
1029        csv_d = {'jamb_reg_no': "RegNumber",
1030                 'jamb_lastname': "Name",
1031                 'session': "Session",
1032                 'pume_tot_score': "PUME SCORE",
1033                 'jamb_score': "JambScore",
1034                 'jamb_sex': "Sex",
1035                 'jamb_state': "State",
1036##                 'jamb_first_cos': "AdminCourse",
1037                 'faculty': "AdminFaculty",
1038                 'course_code': "AdmitCoscode",
1039                 'stud_status':"AdmitStatus",
1040                 'department': "AdmitDept",
1041                 'jamb_lga': "LGA",
1042                 'app_email': "email",
1043                 'app_mobile': "PhoneNumbers",
1044                 }
1045        csv_fields = [f[1] for f in csv_d.items()]
1046        tr_count = 0
1047        total = 0
1048        #name = 'pume_results'
1049        name = 'StudyCourseChange'
1050        no_import = []
1051        s = ','.join(['"%s"' % fn for fn in csv_fields])
1052        no_import.append('"Error",%s' % s)
1053        format = '"%(Error)s",' + ','.join(['"%%(%s)s"' % fn for fn in csv_fields])
1054        no_certificate = "no certificate %s" % format
1055        open("%s/import/%s_not_imported.csv" % (i_home,name),"w").write(
1056                    '\n'.join(no_import))
1057        logger = logging.getLogger('Students.StudentsFolder.updateStudyCourse')
1058        logger.info('Start loading from %s.csv' % name)
1059        l = self.portal_catalog({'meta_type': "Certificate"})
1060        try:
1061            result = csv.DictReader(open("%s/import/%s.csv" % (i_home,name),"rb"))
1062        except:
1063            logger.error('Error reading %s.csv' % name)
1064            return
1065        for jamb in result:
1066            jamb['Error'] = "Processing "
1067            logger.info(format % jamb)
1068            jamb_reg_no = jamb.get(csv_d['jamb_reg_no'])
1069            res = self.portal_catalog({'portal_type': "StudentApplication",
1070                                     'SearchableText': jamb_reg_no })
1071            if not res:
1072                em = 'Student with jamb_reg_no %s does not exists\n' % jamb_reg_no
1073                logger.info(em)
1074                jamb['Error'] = "Student does not exist"
1075                no_import.append(format % jamb)
1076                continue
1077            sid = res[0].getPath().split('/')[-2]
1078            cert_id = makeCertificateCode(jamb.get(csv_d['course_code']))
1079            res = self.portal_catalog(portal_type = "Certificate", id = cert_id)
1080            if not res:
1081                em = 'No Certificate with ID %s \n' % cert_id
1082                logger.info(em)
1083                jamb['Error'] = "No Certificate %s" % cert_id
1084                no_import.append( format % jamb)
1085                continue
1086            cert_brain = res[0]
1087            catalog_entry = {}
1088            student = getattr(self,sid)
1089            #
1090            # Study Course
1091            #
1092            study_course = student.study_course
1093            dsc = {}
1094            cert_pl = cert_brain.getPath().split('/')
1095            catalog_entry['id'] = sid
1096            catalog_entry['faculty'] = cert_pl[-4]
1097            catalog_entry['department'] = cert_pl[-3]
1098            catalog_entry['course'] = cert_id
1099            dsc['study_course'] = cert_id
1100            study_course.getContent().edit(mapping=dsc)
1101            self.students_catalog.modifyRecord(**catalog_entry)
1102            if tr_count > 10:
1103                if len(no_import) > 1:
1104                    open("%s/import/%s_not_imported.csv" % (i_home,name),"w+").write(
1105                             '\n'.join(no_import))
1106                    no_import = []
1107                em = '%d transactions commited\n' % tr_count
1108                transaction.commit()
1109                logger.info(em)
1110                total += tr_count
1111                tr_count = 0
1112            tr_count += 1
1113        return self.REQUEST.RESPONSE.redirect("%s" % self.REQUEST.get('URL1'))
1114    ###)
1115
1116
1117
1118    security.declareProtected(View,"fixOwnership")
1119    def fixOwnership(self):
1120        """fix Ownership"""
1121        for s in self.portal_catalog(meta_type = 'Student'):
1122            student = s.getObject()
1123            sid = s.getId
1124            import pdb;pdb.set_trace()
1125            student.application.manage_setLocalRoles(sid, ['Owner',])
1126            student.personal.manage_setLocalRoles(sid, ['Owner',])
1127
1128    security.declareProtected(View,"Title")
1129    def Title(self):
1130        """compose title"""
1131        return "Student Section"
1132
1133    def generateStudentId(self,letter): ###(
1134        import random
1135        r = random
1136        if letter not in ('ABCDEFGIHKLMNOPQRSTUVWXY'):
1137            letter= r.choice('ABCDEFGHKLMNPQRSTUVWXY')
1138        students = self.portal_catalog(meta_type = "StudentsFolder")[-1]
1139        sid = "%c%d" % (letter,r.randint(99999,1000000))
1140        while hasattr(students, sid):
1141            sid = "%c%d" % (letter,r.randint(99999,1000000))
1142        return sid
1143        #return "%c%d" % (r.choice('ABCDEFGHKLMNPQRSTUVWXY'),r.randint(99999,1000000))
1144    ###)
1145
1146InitializeClass(StudentsFolder)
1147
1148def addStudentsFolder(container, id, REQUEST=None, **kw):
1149    """Add a Student."""
1150    ob = StudentsFolder(id, **kw)
1151    return CPSBase_adder(container, ob, REQUEST=REQUEST)
1152###)
1153
1154class Student(CPSDocument): ###(
1155    """
1156    WAeUP Student container for the various student data
1157    """
1158    meta_type = 'Student'
1159    portal_type = meta_type
1160    security = ClassSecurityInfo()
1161
1162    security.declareProtected(View,"Title")
1163    def Title(self):
1164        """compose title"""
1165        reg_nr = self.getId()[1:]
1166        data = getattr(self,'personal',None)
1167        if data:
1168            content = data.getContent()
1169            return "%s %s %s" % (content.firstname,content.middlename,content.lastname)
1170        data = getattr(self,'application',None)
1171        if data:
1172            content = data.getContent()
1173            return "%s" % (content.jamb_lastname)
1174        return self.title
1175
1176    security.declarePrivate('makeStudentMember') ###(
1177    def makeStudentMember(self,sid,password='uNsEt'):
1178        """make the student a member"""
1179        membership = self.portal_membership
1180        membership.addMember(sid,
1181                             password ,
1182                             roles=('Member',
1183                                     'Student',
1184                                     ),
1185                             domains='',
1186                             properties = {'memberareaCreationFlag': False,
1187                                           'homeless': True},)
1188        member = membership.getMemberById(sid)
1189        self.portal_registration.afterAdd(member, sid, password, None)
1190        self.manage_setLocalRoles(sid, ['Owner',])
1191
1192###)
1193
1194    security.declareProtected(View,'createSubObjects') ###(
1195    def createSubObjects(self):
1196        """make the student a member"""
1197        dp = {'Title': 'Personal Data'}
1198        app_doc = self.application.getContent()
1199        names = app_doc.jamb_lastname.split()
1200        if len(names) == 3:
1201            dp['firstname'] = names[0].capitalize()
1202            dp['middlename'] = names[1].capitalize()
1203            dp['lastname'] = names[2].capitalize()
1204        elif len(names) == 2:
1205            dp['firstname'] = names[0].capitalize()
1206            dp['lastname'] = names[1].capitalize()
1207        else:
1208            dp['lastname'] = app_doc.jamb_lastname
1209        dp['sex'] = app_doc.jamb_sex == 'F'
1210        dp['lga'] = "%s/%s" % (app_doc.jamb_state,app_doc.jamb_lga )
1211        proxy = self.aq_parent
1212        proxy.invokeFactory('StudentPersonal','personal')
1213        per = proxy.personal
1214        per_doc = per.getContent()
1215        per_doc.edit(mapping = dp)
1216        per.manage_setLocalRoles(proxy.getId(), ['Owner',])
1217        #self.portal_workflow.doActionFor(per,'open',dest_container=per)
1218
1219###)
1220
1221InitializeClass(Student)
1222
1223def addStudent(container, id, REQUEST=None, **kw):
1224    """Add a Student."""
1225    ob = Student(id, **kw)
1226    return CPSBase_adder(container, ob, REQUEST=REQUEST)
1227
1228###)
1229
1230class StudentAccommodation(CPSDocument): ###(
1231    """
1232    WAeUP Student container for the various student data
1233    """
1234    meta_type = 'StudentAccommodation'
1235    portal_type = meta_type
1236    security = ClassSecurityInfo()
1237
1238    security.declareProtected(View,"Title")
1239    def Title(self):
1240        """compose title"""
1241        content = self.getContent()
1242        #return "Accommodation Data for %s %s" % (content.firstname,content.lastname)
1243        return "Accommodation Data for Session %s" % content.session
1244
1245
1246InitializeClass(StudentAccommodation)
1247
1248def addStudentAccommodation(container, id, REQUEST=None, **kw):
1249    """Add a Students personal data."""
1250    ob = StudentAccommodation(id, **kw)
1251    return CPSBase_adder(container, ob, REQUEST=REQUEST)
1252
1253###)
1254
1255class StudentPersonal(CPSDocument): ###(
1256    """
1257    WAeUP Student container for the various student data
1258    """
1259    meta_type = 'StudentPersonal'
1260    portal_type = meta_type
1261    security = ClassSecurityInfo()
1262
1263    security.declareProtected(View,"Title")
1264    def Title(self):
1265        """compose title"""
1266        content = self.getContent()
1267        #return "Personal Data for %s %s" % (content.firstname,content.lastname)
1268        return "Personal Data"
1269
1270
1271InitializeClass(StudentPersonal)
1272
1273def addStudentPersonal(container, id, REQUEST=None, **kw):
1274    """Add a Students personal data."""
1275    ob = StudentPersonal(id, **kw)
1276    return CPSBase_adder(container, ob, REQUEST=REQUEST)
1277
1278###)
1279
1280class StudentClearance(CPSDocument): ###(
1281    """
1282    WAeUP Student container for the various student data
1283    """
1284    meta_type = 'StudentClearance'
1285    portal_type = meta_type
1286    security = ClassSecurityInfo()
1287
1288    security.declareProtected(View,"Title")
1289    def Title(self):
1290        """compose title"""
1291        content = self.getContent()
1292        #return "Clearance/Eligibility Record for %s %s" % (content.firstname,content.lastname)
1293        return "Clearance/Eligibility Record"
1294
1295
1296InitializeClass(StudentClearance)
1297
1298def addStudentClearance(container, id, REQUEST=None, **kw):
1299    """Add a Students personal data."""
1300    ob = StudentClearance(id, **kw)
1301    return CPSBase_adder(container, ob, REQUEST=REQUEST)
1302
1303###)
1304
1305class StudentStudyLevel(CPSDocument): ###(
1306    """
1307    WAeUP Student container for the various student data
1308    """
1309    meta_type = 'StudentStudyLevel'
1310    portal_type = meta_type
1311    security = ClassSecurityInfo()
1312
1313    security.declareProtected(View,"Title")
1314    def Title(self):
1315        """compose title"""
1316        return "Level %s" % self.aq_parent.getId()
1317
1318##    security.declarePublic("gpa")
1319##    def gpa(self):
1320##        """calculate the gpa"""
1321##        sum = 0
1322##        course_count = 0
1323##        for sc in self.objectValues():
1324##            result = sc.getContent()
1325##            if not result.grade:
1326##                continue
1327##            res = self.portal_catalog({'meta_type': 'Course',
1328##                                          'id': sc.aq_parent.id})
1329##            if len(res) != 1:
1330##                continue
1331##            course = res[0].getObject().getContent()
1332##            sum += course.credits * ['F','E','D','C','B','A'].index(result.grade)
1333##            course_count += 1
1334##        if course_count:
1335##            return sum/course_count
1336##        return 0.0
1337
1338InitializeClass(StudentStudyLevel)
1339
1340def addStudentStudyLevel(container, id, REQUEST=None, **kw):
1341    """Add a Students personal data."""
1342    ob = StudentStudyLevel(id, **kw)
1343    return CPSBase_adder(container, ob, REQUEST=REQUEST)
1344
1345###)
1346
1347class StudentStudyCourse(CPSDocument): ###(
1348    """
1349    WAeUP Student container for the various student data
1350    """
1351    meta_type = 'StudentStudyCourse'
1352    portal_type = meta_type
1353    security = ClassSecurityInfo()
1354
1355    security.declareProtected(View,"Title")
1356    def Title(self):
1357        """compose title"""
1358        content = self.getContent()
1359        return "Study Course"
1360
1361
1362InitializeClass(StudentStudyCourse)
1363
1364def addStudentStudyCourse(container, id, REQUEST=None, **kw):
1365    """Add a Students personal data."""
1366    ob = StudentStudyCourse(id, **kw)
1367    return CPSBase_adder(container, ob, REQUEST=REQUEST)
1368
1369###)
1370
1371class StudentApplication(CPSDocument): ###(
1372    """
1373    WAeUP Student container for the various student data
1374    """
1375    meta_type = 'StudentApplication'
1376    portal_type = meta_type
1377    security = ClassSecurityInfo()
1378
1379    security.declareProtected(View,"Title")
1380    def Title(self):
1381        """compose title"""
1382        return "Application Data"
1383
1384
1385InitializeClass(StudentApplication)
1386
1387def addStudentApplication(container, id, REQUEST=None, **kw):
1388    """Add a Students eligibility data."""
1389    ob = StudentApplication(id, **kw)
1390    return CPSBase_adder(container, ob, REQUEST=REQUEST)
1391###)
1392
1393class StudentPume(CPSDocument): ###(
1394    """
1395    WAeUP Student container for the various student data
1396    """
1397    meta_type = 'StudentPume'
1398    portal_type = meta_type
1399    security = ClassSecurityInfo()
1400
1401    security.declareProtected(View,"Title")
1402    def Title(self):
1403        """compose title"""
1404        return "PUME Results"
1405
1406
1407InitializeClass(StudentPume)
1408
1409def addStudentPume(container, id, REQUEST=None, **kw):
1410    """Add a Students PUME data."""
1411    ob = StudentPume(id, **kw)
1412    return CPSBase_adder(container, ob, REQUEST=REQUEST)
1413###)
1414
1415##class StudentSemester(CPSDocument): ###(
1416##    """
1417##    WAeUP StudentSemester containing the courses and students
1418##    """
1419##    meta_type = 'StudentSemester'
1420##    portal_type = meta_type
1421##    security = ClassSecurityInfo()
1422##
1423##InitializeClass(StudentSemester)
1424##
1425##def addStudentSemester(container, id, REQUEST=None, **kw):
1426##    """Add a StudentSemester."""
1427##    ob = StudentSemester(id, **kw)
1428##    return CPSBase_adder(container, ob, REQUEST=REQUEST)
1429##
1430#####)
1431
1432##class Semester(CPSDocument): ###(
1433##    """
1434##    WAeUP Semester containing the courses and students
1435##    """
1436##    meta_type = 'Semester'
1437##    portal_type = meta_type
1438##    security = ClassSecurityInfo()
1439##
1440##InitializeClass(Semester)
1441##
1442##def addSemester(container, id, REQUEST=None, **kw):
1443##    """Add a Semester."""
1444##    ob = Semester(id, **kw)
1445##    return CPSBase_adder(container, ob, REQUEST=REQUEST)
1446##
1447#####)
1448
1449class StudentCourseResult(CPSDocument): ###(
1450    """
1451    WAeUP StudentCourseResult
1452    """
1453    meta_type = 'StudentCourseResult'
1454    portal_type = meta_type
1455    security = ClassSecurityInfo()
1456
1457    def getCourseEntry(self,cid):
1458        res = self.portal_catalog({'meta_type': "Course",
1459                                           'id': cid})
1460        if res:
1461            return res[-1]
1462        else:
1463            return None
1464
1465    security.declareProtected(View,"Title")
1466    def Title(self):
1467        """compose title"""
1468        cid = self.aq_parent.getId()
1469        ce = self.getCourseEntry(cid)
1470        if ce:
1471            return "%s" % ce.Title
1472        return "No course with id %s" % cid
1473
1474InitializeClass(StudentCourseResult)
1475
1476def addStudentCourseResult(container, id, REQUEST=None, **kw):
1477    """Add a StudentCourseResult."""
1478    ob = StudentCourseResult(id, **kw)
1479    return CPSBase_adder(container, ob, REQUEST=REQUEST)
1480###)
1481
1482# Backward Compatibility StudyLevel
1483
1484from Products.WAeUP_SRP.Academics import StudyLevel
1485
1486from Products.WAeUP_SRP.Academics import addStudyLevel
1487
Note: See TracBrowser for help on using the repository browser.