source: WAeUP_SRP/trunk/Academics.py @ 369

Last change on this file since 369 was 369, checked in by joachim, 19 years ago

added fields bank_code and degree_grade, fixed import.

M profiles/default/schemas/faculty.xml
M profiles/default/layouts/faculty.xml
M Academics.py

  • Property svn:keywords set to Id
File size: 27.8 KB
Line 
1#-*- mode: python; mode: fold -*-
2from Globals import InitializeClass
3from AccessControl import ClassSecurityInfo
4
5from Products.CMFCore.utils import UniqueObject, getToolByName
6from Products.CMFCore.permissions import View
7from Products.CMFCore.permissions import ModifyPortalContent
8from Products.CPSCore.CPSBase import CPSBase_adder, CPSBaseFolder
9#from Products.CPSCore.CPSBase import CPSBaseDocument as BaseDocument
10from Products.CPSDocument.CPSDocument import CPSDocument
11#from Products.CPSCore.CPSBase import CPSBaseBTreeFolder as BaseBTreeFolder
12#from Products.CPSCore.CPSBase import CPSBaseBTreeDocument as BaseBTreeDocument
13#from Products.CMFCore.DirectoryView import registerDirectory
14
15#registerDirectory('skins', globals())
16#registerDirectory('skins/waeup_default', globals())
17#registerDirectory('skins/waeup_faculty', globals())
18
19import csv,re
20import logging
21import Globals
22p_home = Globals.package_home(globals())
23i_home = Globals.INSTANCE_HOME
24
25def makeCertificateCode(code):
26    code = code.replace('.','')
27    code = code.replace('(','')
28    code = code.replace(')','')
29    code = code.replace('/','')
30    code = code.replace(' ','')
31    code = code.replace('_','')
32    return code
33
34class AcademicsFolder(CPSDocument): ###(
35    """
36    WAeUP AcademicsFolder containing StudyCourses
37    """
38    meta_type = 'AcademicsFolder'
39    portal_type = meta_type
40    security = ClassSecurityInfo()
41
42    security.declareProtected(View,"Title")
43    def Title(self):
44        """compose title"""
45        return "Academics Section"
46
47    security.declareProtected(ModifyPortalContent,"loadFacultiesFromCSV")###(
48    def loadFacultiesFromCSV(self):
49        """install Universityspecific Faculies from CSV values"""
50        #return
51        name = 'faculty'
52        no_import = False
53        logger = logging.getLogger('%s_import' % name)
54        logger.info('Start loading from %s.csv' % name)
55        academics = self.portal_catalog({'meta_type': 'AcademicsFolder'})[-1].getObject()
56        try:
57            faculties = csv.DictReader(open("%s/import/%s.csv" % (i_home,name),"rb"))
58        except:
59            logger.error('Error reading %s.csv' % name)
60            return
61        l = self.portal_catalog({'meta_type': "Faculty"})
62        facs = {}
63        for f in l:
64            facs[f.id] = f.getObject()
65        for faculty in faculties:
66            logger.info('processing %(Session)s %(FacultyCode)s %(Description)s %(CollegeCode)s %(FacultyKey)s %(Status)s %(degree_grade)s %(Bankcode)s' % faculty)
67            fid = faculty['FacultyCode']
68            f = facs.get(fid,None)
69            if f is None:
70                #self.log('Creating Faculty %(id)s = %(Title)s' % faculty)
71                logger.info('Creating Faculty with ID %(FacultyCode)s %(Description)s' % faculty)
72                academics.invokeFactory('Faculty', fid)
73                f = getattr(self,fid)
74                d = {'Title': faculty['Description']}
75            else:
76                d = {}
77##                if not no_import:
78##                    no_import = open("%s/import/%s_not_imported.csv" % (i_home,name),"w")
79##                    no_import.write('"Session","FacultyCode","Description","CollegeCode","FacultyKey","Status","degree_grade","Bankcode"\n')
80##                logger.info('Faculty with ID %(FacultyCode)s %(Description)s already exists' % faculty)
81##                no_import.write('"%(Session)s","%(FacultyCode)s","%(Description)s","%(CollegeCode)s","%(FacultyKey)s","%(Status)s","%(degree_grade)s","%(Bankcode)s"\n' % faculty)
82            d['bank_code'] = faculty.get("Bankcode")
83            d["degree_grade"] = faculty.get("degree_grade")
84            f.getContent().edit(mapping=d)
85        return self.academics.academics_contents()
86    ###)
87
88    security.declareProtected(ModifyPortalContent,"yamlDumpFaculties")###(
89    def yamlDumpFaculties(self):
90        """dump Faculies to Yaml"""
91        #return
92        import yaml
93        logger = logging.getLogger('dumpfaculties')
94        logger.info('Start dumping Faculties')
95        academics = self.portal_catalog({'meta_type': 'AcademicsFolder'})[-1].getObject()
96        l = self.portal_catalog({'meta_type': "Faculty"})
97        facs = {}
98        for f in l:
99            facs[f.id] = f.getObject()
100        for fid in facs.keys():
101            faculty = facs.get(fid).aq_self
102            logger.info('dumping %s %s ' % (faculty.id, faculty.title))
103            print yaml.dump(faculty)
104        return self.academics.temporary_view_all()
105        return self.temporary_view_all()
106
107    ###)
108
109    security.declareProtected(ModifyPortalContent,"loadDepartmentsFromCSV")###(
110    def loadDepartmentsFromCSV(self):
111        """install Universityspecific Faculies from CSV values"""
112        #return
113        name = 'departments'
114        no_import = False
115        logger = logging.getLogger('loaddepartments')
116        try:
117            deps = csv.DictReader(open("%s/import/departments.csv" % i_home,"rb"))
118        except:
119            logger.error('Error reading departments.csv')
120            return
121        l = self.portal_catalog({'meta_type': "Faculty"})
122        facs = {}
123        for f in l:
124            facs[f.id] = f.getObject()
125        for dep in deps:
126            logger.info('Processing %(Session)s %(DeptCode)s %(Description)s %(FacultyCode)s' % dep)
127            fid = dep['FacultyCode']
128            f = facs.get(fid,None)
129            if f is None:
130                logger.info( "No Faculty with ID: %s" % fid)
131                if not no_import:
132                    no_import = open("%s/import/%s_not_imported.csv" % (i_home,name),"w")
133                    no_import.write('"Session","DeptCode","Description","FacultyCode"\n')
134                no_import.write( "No Faculty with ID: %s\n" % fid)
135                no_import.write('"%(Session)s","%(DeptCode)s","%(Description)s","%(FacultyCode)s"\n' % dep)
136            else:
137                did = dep.get('DeptCode')
138                d = getattr(f,did,None)
139                if d is None or d.portal_type == "Faculty":
140                    logger.info('Creating Department %(DeptCode)s = %(Description)s' % dep)
141                    f.invokeFactory('Department', did)
142                    d = getattr(f,did)
143                    dict = {'Title': dep['Description']}
144                    d.getContent().edit(mapping=dict)
145                    d.invokeFactory('CoursesFolder','courses')
146                    courses = getattr(d,'courses')
147                    dict = {'Title': 'Courses'}
148                    courses.getContent().edit(mapping=dict)
149                    d.invokeFactory('CertificatesFolder','certificates')
150                    certificates = getattr(d,'certificates')
151                    dict = {'Title': 'Certificates'}
152                    certificates.getContent().edit(mapping=dict)
153        return self.academics.academics_contents()
154    ###)
155
156    security.declareProtected(ModifyPortalContent,"loadCoursesFromCSV")###(
157    def loadCoursesFromCSV(self):
158        """install Universityspecific Courses from CSV values"""
159        #return
160        name = 'courses'
161        no_import = False
162        logger = logging.getLogger('loadcourses')
163        try:
164            courses = csv.DictReader(open("%s/import/courses.csv" % i_home,"rb"))
165        except:
166            logger.error('Error reading courses.csv')
167            return
168        l = self.portal_catalog({'meta_type': "Faculty"})
169        facs = {}
170        for f in l:
171            facs[f.id] = f.getObject()
172        dl = self.portal_catalog({'meta_type': "Department"})
173        deps = {}
174        for d in dl:
175            deps[d.id] = d.getObject()
176        cl = self.portal_catalog({'meta_type': "Course"})
177        course_list = [ c.id for c in cl]
178        for course in courses:
179            logger.info('Processing %(CourseCode)s %(Description)s %(Credits)s %(Dept)s %(Semester)s %(Session)s %(PassMark)s %(Category)s %(AdmStatus)s' % course)
180##            if course.get("FORMERCODE").endswith('BITS'):
181##                continue
182            depid = course.get('Dept').upper()
183            if depid in deps.keys():
184                dept= deps.get(depid)
185    ##        elif depid in facs.keys():
186    ##            dept= facs.get(depid)
187            else:
188                logger.info("Dep %(Dept)s for Course %(CourseCode)s not found" % course)
189                if not no_import:
190                    no_import = open("%s/import/%s_not_imported.csv" % (i_home,name),"w")
191                    no_import.write('"CourseCode","Description","Credits","Dept","Semester","Session","PassMark","Category","AdmStatus"\n')
192                no_import.write("Dep %(Dept)s for Course %(CourseCode)s not found\n" % course)
193                no_import.write('"%(CourseCode)s","%(Description)s","%(Credits)s","%(Dept)s","%(Semester)s","%(Session)s","%(PassMark)s","%(Category)s","%(AdmStatus)s"\n' % course)
194                continue
195            course_id = ''.join(re.split('\W+',course.get('CourseCode')))
196            if len(course_id) == 3:
197                course_id = "%s000" % course_id
198##            elif course_id.startswith('CHEM'):
199##                tid = course_id.replace('CHEM','CHE')
200##                logger.info("invalid course_code %(course_id)s renaming to %(tid)s" % vars())
201##                course_id = tid
202##            elif course_id.startswith('DAIC'):
203##                tid = course_id.replace('DAIC','DAC')
204##                logger.info("invalid course_code %(course_id)s renaming to %(tid)s" % vars())
205##                course_id = tid
206##            elif course_id.startswith('DAIM'):
207##                tid = course_id.replace('DAIM','DAM')
208##                logger.info("invalid course_code %(course_id)s renaming to %(tid)s" % vars())
209##                course_id = tid
210            elif len(course_id) > 10:
211                logger.info("invalid course_code %(CourseCode)s" % course)
212                if not no_import:
213                    no_import = open("%s/import/%s_not_imported.csv" % (i_home,name),"w")
214                    no_import.write('"CourseCode","Description","Credits","Dept","Semester","Session","PassMark","Category","AdmStatus"\n')
215                no_import.write("invalid course_code %(CourseCode)s\n" % course)
216                no_import.write('"%(CourseCode)s","%(Description)s","%(Credits)s","%(Dept)s","%(Semester)s","%(Session)s","%(PassMark)s","%(Category)s","%(AdmStatus)s"\n' % course)
217                continue
218            courses = dept.courses
219            c = getattr(courses,course_id,None)
220            if c is None:
221                logger.info('Creating Course %(CourseCode)s  %(Description)s in Department %(Dept)s' % course)
222                courses.invokeFactory('Course', course_id)
223                c = getattr(courses,course_id)
224            dict = {'Title': course['Description']}
225            dict['code'] = course_id
226            dict['org_code'] = course.get('CourseCode')
227            dict['credits'] = course.get('Credits')
228            dict['semester'] = course.get('Semester')
229            dict['session'] = course.get('Session')
230            dict['category'] = course.get('Category')
231            pm = course.get('PassMark')
232            if pm.find(',') > -1:
233                pm.replace(',','.')
234            elif pm == "":
235                pm = "0.0"
236            try:
237                dict['passmark'] = int(float(pm))
238            except:
239                dict['passmark'] = 0
240            c.getContent().edit(mapping=dict)
241        return self.academics.academics_contents()
242    ###)
243
244    security.declareProtected(ModifyPortalContent,"loadCertificatesFromCSV")###(
245
246    def loadCertificatesFromCSV(self):
247        """install Universityspecific Certificates from CSV values"""
248        #return
249        name = 'certificates'
250        no_import = False
251        logger = logging.getLogger('loadcertificates')
252        try:
253            certificates = csv.DictReader(open("%s/import/certificates.csv" % i_home,"rb"))
254        except:
255            logger.error('Error reading certificates.csv')
256            return
257        f_ids = [f.id for f in self.portal_catalog({'meta_type': "Faculty"})]
258        #d_ids = [d.id for d in self.portal_catalog({'meta_type': "Department"})]
259        dl = self.portal_catalog({'meta_type': "Department"})
260        deps = {}
261        for d in dl:
262            deps[d.id] = d.getObject()
263        for certificate in certificates:
264            logger.info('Processing %(CertCode)s %(Description)s %(Faculty)s %(MaxPass)s %(MaxLoad)s %(session)s %(PromotionCredits)s %(Probationcredits)s %(StartLevel)s %(endLevel)s %(Nyears)s %(Ncore)s %(MaxElect)s %(MPREFIX)s %(Dept)s %(Admstatus)s %(category)s' % certificate)
265            depid = certificate.get('Dept')
266            facid = certificate.get('Faculty')
267            if facid not in f_ids:
268                logger.info('Faculty %(Faculty)s for %(CertCode)s %(Description)s not found' % certificate)
269                if not no_import:
270                    no_import = open("%s/import/%s_not_imported.csv" % (i_home,name),"w")
271                    no_import.write('"CertCode","Description","Faculty","MaxPass","MaxLoad","session","PromotionCredits","Probationcredits","StartLevel","endLevel","Nyears","Ncore","MaxElect","MPREFIX","Dept","Admstatus","category"\n')
272                no_import.write('Faculty %(Faculty)s for %(CertCode)s %(Description)s not found\n' % certificate)
273                no_import.write('"%(CertCode)s","%(Description)s","%(Faculty)s","%(MaxPass)s","%(MaxLoad)s","%(session)s","%(PromotionCredits)s","%(Probationcredits)s","%(StartLevel)s","%(endLevel)s","%(Nyears)s","%(Ncore)s","%(MaxElect)s","%(MPREFIX)s","%(Dept)s","%(Admstatus)s","%(category)s"\n' % certificate)
274                continue
275            if not deps.has_key(depid):
276                logger.info('Department %(Dept)s for %(CertCode)s %(Description)s not found' % certificate)
277                if not no_import:
278                    no_import = open("%s/import/%s_not_imported.csv" % (i_home,name),"w")
279                    no_import.write('"CertCode","Description","Faculty","MaxPass","MaxLoad","session","PromotionCredits","Probationcredits","StartLevel","endLevel","Nyears","Ncore","MaxElect","MPREFIX","Dept","Admstatus","category"\n')
280                no_import.write('Department %(Dept)s for %(CertCode)s %(Description)s not found\n' % certificate)
281                no_import.write('"%(CertCode)s","%(Description)s","%(Faculty)s","%(MaxPass)s","%(MaxLoad)s","%(session)s","%(PromotionCredits)s","%(Probationcredits)s","%(StartLevel)s","%(endLevel)s","%(Nyears)s","%(Ncore)s","%(MaxElect)s","%(MPREFIX)s","%(Dept)s","%(Admstatus)s","%(category)s"\n' % certificate)
282                continue
283            #certificate_id = "%(category)s_%(Admstatus)s_%(Dept)s" % certificate
284            dep = deps[depid]
285            certificates = dep.certificates
286            code = makeCertificateCode(certificate.get('CertCode'))
287            certificate_id = code
288            c = getattr(certificates,certificate_id,None)
289            if c is None:
290                #self.log('Creating Department %(DeptCode)s = %(Description)s' % dep)
291                logger.info('Creating certificate %(CertCode)s  %(Description)s in Department %(Dept)s' % certificate)
292                certificates.invokeFactory('Certificate', certificate_id)
293                c = getattr(certificates,certificate_id)
294            dict = {'Title': certificate['Description']}
295            dict['code'] = code
296            dict['org_code'] = certificate.get('CertCode')
297            dict['faculty'] = certificate.get('Faculty')
298            dict['department'] = certificate.get('Dept')
299            dict['max_pass'] = certificate.get('MaxPass')
300            dict['max_load'] = certificate.get('MaxLoad')
301            dict['admin_status'] = certificate.get('Admstatus')
302            dict['category'] = certificate.get('category')
303            dict['m_prefix'] = certificate.get('MPREFIX')
304            dict['nr_years'] = int(certificate.get('Nyears'))
305            nc = certificate.get('Ncore','1')
306            try:
307                dict['n_core'] = int(nc)
308            except:
309                dict['n_core'] = 1
310            dict['start_level'] = certificate.get('StartLevel')
311            dict['end_level'] = certificate.get('endLevel')
312            dict['promotion_credits'] = certificate.get('PromotionCredits')
313            dict['probation_credits'] = certificate.get('ProbationCredits')
314            c.getContent().edit(mapping=dict)
315        return self.academics.academics_contents()
316    ###)
317
318    security.declareProtected(ModifyPortalContent,"loadCertificateCoursesFromCSV")###(
319    def loadCertificateCoursesFromCSV(self):
320        """install Certificate Courses from CSV values"""
321        #return
322        logger = logging.getLogger('loadcertificatecourses')
323        name = 'certificate_courses'
324        no_import = False
325        try:
326            cert_courses = csv.DictReader(open("%s/import/course_level_courses.csv" % i_home,"rb"))
327        except:
328            logger.error('Error reading course_level_courses.csv')
329            return
330        d_ids = [d.id for d in self.portal_catalog({'meta_type': "Department"})]
331        c_ids = [c.id for c in self.portal_catalog({'meta_type': "Course"})]
332        l = self.portal_catalog({'meta_type': "Certificate"})
333        certs = {}
334        for f in l:
335            certs[f.id] = f.getObject()
336        for cert_course in cert_courses:
337            logger.info('Processing %(CosCode)s %(CertCode)s %(Session)s %(Level)s %(Core)s %(Elective)s %(Mandatory)s %(AdmStatus)s %(Dept)s %(Semester)s' % cert_course)
338            depid = cert_course.get('Dept')
339            course_code = cert_course.get('CosCode')
340            code = cert_course.get('CertCode')
341            code = code.replace('.','')
342            code = code.replace('(','')
343            code = code.replace(')','')
344            code = code.replace('/','')
345            code = code.replace(' ','')
346            code = code.replace('_','')
347##            if cert_course.get('Session') != '2002/2003':
348##                continue
349##            certificate = self.portal_catalog({'meta_type': "Certificate",
350##                                               'SearchableText': code})
351##            if not certificate:
352            if not code in certs.keys():
353                #print code
354                em = 'CertCode %(CertCode)s for %(CosCode)s not found\n' % cert_course
355                logger.info(em)
356                if not no_import:
357                    no_import = open("%s/import/%s_not_imported.csv" % (i_home,name),"w")
358                    no_import.write('"CosCode","CertCode","Session","Level","Core","Elective","Mandatory","AdmStatus","Dept","Semester"\n')
359                no_import.write(em)
360                no_import.write('"%(CosCode)s","%(CertCode)s","%(Session)s","%(Level)s","%(Core)s","%(Elective)s","%(Mandatory)s","%(AdmStatus)s","%(Dept)s","%(Semester)s"\n' % cert_course)
361                continue
362            certificate = certs[code]
363            certificate_code = certificate.getId()
364            if course_code not in c_ids:
365                em = 'CorseCode %(CosCode)s for %(CertCode)s not found in Courses\n' % cert_course
366                logger.info(em)
367                if not no_import:
368                    no_import = open("%s/import/%s_not_imported.csv" % (i_home,name),"w")
369                    no_import.write('"CosCode","CertCode","Session","Level","Core","Elective","Mandatory","AdmStatus","Dept","Semester"\n')
370                no_import.write(em)
371                no_import.write('"%(CosCode)s","%(CertCode)s","%(Session)s","%(Level)s","%(Core)s","%(Elective)s","%(Mandatory)s","%(AdmStatus)s","%(Dept)s","%(Semester)s"\n' % cert_course)
372                continue
373            if depid not in d_ids:
374                em = 'Department %(Dept)s for %(CertCode)s not found\n' % cert_course
375                logger.info(em)
376                if not no_import:
377                    no_import = open("%s/import/%s_not_imported.csv" % (i_home,name),"w")
378                    no_import.write('"CosCode","CertCode","Session","Level","Core","Elective","Mandatory","AdmStatus","Dept","Semester"\n')
379                no_import.write(em)
380                no_import.write('"%(CosCode)s","%(CertCode)s","%(Session)s","%(Level)s","%(Core)s","%(Elective)s","%(Mandatory)s","%(AdmStatus)s","%(Dept)s","%(Semester)s"\n' % cert_course)
381                continue
382            level = cert_course.get('Level')
383            l = getattr(certificate,level,None)
384            if l is None:
385                #self.log('Creating Department %(DeptCode)s = %(Description)s' % dep)
386                logger.info('Creating Level %(Level)s in certificate %(CertCode)s' % cert_course)
387                certificate.invokeFactory('StudyLevel', level)
388                l = getattr(certificate, level)
389                l.getContent().edit(mapping={'Title': "Level %s" % level})
390                l.invokeFactory('Semester','first')
391                l.invokeFactory('Semester','second')
392            certificate.orderObjects('id')
393            first_s = getattr(l,'first')
394            first_s.getContent().edit(mapping={'Title': 'First Semester'})
395            second_s = getattr(l,'second')
396            second_s.getContent().edit(mapping={'Title': 'Second Semester'})
397            if cert_course.get('Semester') == '1':
398                semester = first_s
399            else:
400                semester = second_s
401            if hasattr(semester,course_code):
402                logger.info('Duplicate %(CosCode)s in Level %(Level)s' % cert_course)
403                if not no_import:
404                    no_import = open("%s/import/%s_not_imported.csv" % (i_home,name),"w")
405                    no_import.write('"CosCode","CertCode","Session","Level","Core","Elective","Mandatory","AdmStatus","Dept","Semester"\n')
406##                no_import.write('Duplicate %(CosCode)s in Level %(Level)s' % cert_course)
407##                no_import.write('"%(CosCode)s","%(CertCode)s","%(Session)s","%(Level)s","%(Core)s","%(Elective)s","%(Mandatory)s","%(AdmStatus)s","%(Dept)s","%(Semester)s"\n' % cert_course)
408                continue
409            semester.invokeFactory('CertificateCourse',course_code)
410            cc = getattr(semester,course_code)
411            dict = {}
412            dict['code'] = cert_course.get('CosCode')
413            dict['certificate_code'] = code
414            dict['certificate_code_org'] = cert_course.get('CertCode')
415            dict['department'] = cert_course.get('Dept')
416            dict['admin_status'] = cert_course.get('Admstatus')
417            dict['session'] = cert_course.get('Session')
418            if cert_course.get('Core') != '':
419                dict['core_or_elective'] = True
420            else:
421                dict['core_or_elective'] = False
422            dict['level'] = cert_course.get('Level')
423            cc.getContent().edit(mapping=dict)
424        return self.academics.academics_contents()
425    ###)
426
427InitializeClass(AcademicsFolder)
428
429def addAcademicsFolder(container, id, REQUEST=None, **kw):
430    """Add a AcademicsFolder."""
431    ob = AcademicsFolder(id, **kw)
432    return CPSBase_adder(container, ob, REQUEST=REQUEST)
433
434###)
435
436class Certificate(CPSDocument): ###(
437    """
438    WAeUP Certificate
439    """
440    meta_type = 'Certificate'
441    portal_type = meta_type
442    security = ClassSecurityInfo()
443
444    def __init__(self, id, **kw):
445        CPSDocument.__init__(self, id, **kw)
446
447##    security.declareProtected(View,"Title")
448##    def Title(self):
449##        """compose title"""
450##        return "Certificate of %s" % (self.title)
451
452InitializeClass(Certificate)
453
454def addCertificate(container, id, REQUEST=None, **kw):
455    """Add a Certificate."""
456    ob = Certificate(id, **kw)
457    return CPSBase_adder(container, ob, REQUEST=REQUEST)
458
459###)
460
461class CertificateCourse(CPSDocument): ###(
462    """
463    WAeUP CertificateCourse
464    """
465    meta_type = 'CertificateCourse'
466    portal_type = meta_type
467    security = ClassSecurityInfo()
468
469    def getCourseEntry(self,cid):
470        res = self.portal_catalog({'meta_type': "Course",
471                                           'id': cid})
472        if res:
473            return res[-1]
474        else:
475            return None
476
477    security.declareProtected(View,"Title")
478    def Title(self):
479        """compose title"""
480        print self.id.upper()
481        ce = self.getCourseEntry(self.id.upper())
482        if ce:
483            return "%s" % ce.Title
484        return "No such course"
485
486    security.declareProtected(View,"credits")
487    def credits(self):
488        """credits from course"""
489        ce = self.getCourseEntry(self.id)
490        if ce:
491            return "%s" % ce.credits
492        return "0"
493
494    security.declareProtected(View,"passmark")
495    def passmark(self):
496        """passmark from course"""
497        ce = self.getCourseEntry(self.id)
498        if ce is not None and hasattr(ce,"passmark"):
499            return ce.passmark
500
501
502    security.declareProtected(View,"coursepath")
503    def coursepath(self):
504        """coursepath from course"""
505        ce = self.getCourseEntry(self.id)
506        if ce:
507            return ce.getPath()
508        return "?"
509
510
511InitializeClass(CertificateCourse)
512
513def addCertificateCourse(container, id, REQUEST=None, **kw):
514    """Add a CertificateCourse."""
515    ob = CertificateCourse(id, **kw)
516    return CPSBase_adder(container, ob, REQUEST=REQUEST)
517###)
518
519class Faculty(CPSDocument): ###(
520    """
521    WAeUP Faculty containing Departments
522    """
523    meta_type = 'Faculty'
524    portal_type = meta_type
525    security = ClassSecurityInfo()
526
527##    def __init__(self, id, **kw):
528##        CPSDocument.__init__(self, id, **kw)
529
530    security.declareProtected(View,"Title")
531    def Title(self):
532        """compose title"""
533        return "%s" % (self.title)
534
535    security.declareProtected(View,"LongTitle")
536    def LongTitle(self):
537        """compose long_title"""
538        itype = self.portal_vocabularies.institution_types_voc.get(self.institution_type,default="Faculty of")
539
540        return "%s %s" % (itype,self.title)
541
542InitializeClass(Faculty)
543
544def addFaculty(container, id, REQUEST=None, **kw):
545    """Add a Faculty."""
546    ob = Faculty(id, **kw)
547    return CPSBase_adder(container, ob, REQUEST=REQUEST)
548
549###)
550
551class Department(CPSDocument): ###(
552    """
553    WAeUP Department containing the courses and students
554    """
555    meta_type = 'Department'
556    portal_type = meta_type
557    security = ClassSecurityInfo()
558
559##    security.declareProtected(View,"Title")
560##    def Title(self):
561##        """compose title"""
562##        reg_nr = self.getId()[1:]
563##        return "Department of %s" % (self.title)
564
565    security.declareProtected(View,"LongTitle")
566    def LongTitle(self):
567        """compose long_title"""
568        if not hasattr(self,'institution_type'):
569            self.institution_type = "department"
570        itype = self.portal_vocabularies.institution_types_voc.get(self.institution_type,default="Department of")
571
572        return "%s %s" % (itype,self.title)
573
574InitializeClass(Department)
575
576def addDepartment(container, id, REQUEST=None, **kw):
577    """Add a Department."""
578    object = Department(id, **kw)
579    id = object.getId()
580    container._setObject(id, object)
581##    dep = getattr(container,id).getEditableContent()   #getContent()
582##    dep.invokeFactory('CoursesFolder','Courses')
583##    o = getattr(dep,'Courses')
584##    dict = {'Title': 'Courses'}
585##    o.getContent().edit(mapping=dict)
586##    dep.invokeFactory('CertificatesFolder','Certificates')
587##    o = getattr(dep,'Certificates')
588##    dict = {'Title': 'Certificates'}
589##    o.geetContent().edit(mapping=dict)
590    if REQUEST is not None:
591        url = container.absolute_url()
592        REQUEST.RESPONSE.redirect('%s/manage_main' % url)
593
594###)
595
596class Course(CPSDocument): ###(
597    """
598    WAeUP Course
599    """
600    meta_type = 'Course'
601    portal_type = meta_type
602    security = ClassSecurityInfo()
603
604    security.declareProtected(View,"Title")
605    def Title(self):
606        """compose title"""
607        return self.title
608
609InitializeClass(Course)
610
611def addCourse(container, id, REQUEST=None, **kw):
612    """Add a Course."""
613    ob = Course(id, **kw)
614    return CPSBase_adder(container, ob, REQUEST=REQUEST)
615###)
616
617class CourseTicket(CPSDocument): ###(
618    """
619    WAeUP CourseTicket
620    """
621    meta_type = 'CourseTicket'
622    portal_type = meta_type
623    security = ClassSecurityInfo()
624
625InitializeClass(CourseTicket)
626
627def addCourseTicket(container, id, REQUEST=None, **kw):
628    """Add a CourseTicket."""
629    ob = CourseTicket(id, **kw)
630    return CPSBase_adder(container, ob, REQUEST=REQUEST)
631###)
632
Note: See TracBrowser for help on using the repository browser.