source: main/waeup.sirp/trunk/src/waeup/sirp/jambtables/interfaces.py @ 5472

Last change on this file since 5472 was 5471, checked in by uli, 14 years ago

Use docstrings instead of code.

File size: 17.1 KB
RevLine 
[5247]1##
2## interfaces.py
3## Login : <uli@pu.smp.net>
4## Started on  Sun Jun 27 11:06:23 2010 Uli Fouquet
5## $Id$
6##
7## Copyright (C) 2010 Uli Fouquet
8## This program is free software; you can redistribute it and/or modify
9## it under the terms of the GNU General Public License as published by
10## the Free Software Foundation; either version 2 of the License, or
11## (at your option) any later version.
12##
13## This program is distributed in the hope that it will be useful,
14## but WITHOUT ANY WARRANTY; without even the implied warranty of
15## MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
16## GNU General Public License for more details.
17##
18## You should have received a copy of the GNU General Public License
19## along with this program; if not, write to the Free Software
20## Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
21##
22"""Interfaces for JAMB data tables and related components.
23"""
24from waeup.sirp.interfaces import IWAeUPObject
[5319]25from zc.sourcefactory.basic import BasicSourceFactory
[5251]26from zope import schema
[5432]27from zope.interface import Interface, Attribute
28from zope.pluggableauth.interfaces import IPrincipalInfo
29from zope.security.interfaces import IGroupClosureAwarePrincipal as IPrincipal
[5247]30
[5432]31
[5319]32class GenderSource(BasicSourceFactory):
33    """A gender source delivers basically a mapping
34       ``{'m': 'male', 'f': 'female'}``
[5271]35
[5319]36       Using a source, we make sure that the tokens (which are
37       stored/expected for instance from CSV files) are something one
38       can expect and not cryptic IntIDs.
39    """
40    def getValues(self):
41        return ['m', 'f']
42
43    def getToken(self, value):
44        return value[0].lower()
45       
46    def getTitle(self, value):
47        if value == 'm':
48            return 'male'
49        if value == 'f':
50            return 'female'
51
[5247]52class IJAMBDataTable(IWAeUPObject):
53    """A table containing JAMB data.
54    """
[5251]55    import_datetime = schema.Datetime(
56        title = u'Datetime of import of contained data.',
57        required = False,
58        )
59
60    importer_username = schema.TextLine(
61        title = u'Name of user who initiated import.',
62        required = False,
63        )
64
65    def __iter__():
66        """An iterator over all data elements.
67        """
68
69    def keys():
70        """Get iterator over all registration numbers of data.
71        """
72
73    def items():
74        """Get iterator over tuples of registration numbers and datasets.
75        """
76
77    def clear():
78        """Clear all data contained.
79
80        This will also erase any import data.
81        """
82
[5252]83    def importFromCSV(filepath, username=None):
[5251]84        """Import data from filepath.
[5252]85
86        `filepath` - the path to the CSV file to import data from.
87
88        `username` - the (optional) username of the importing person.
[5251]89        """
[5271]90       
91class IResultEntry(IWAeUPObject):
92    subject = schema.TextLine(
93        title = u'Subject',
94        description = u'The subject',
95        required=False,
96        )
97    score = schema.TextLine(
98        title = u'Score',
99        description = u'The score',
100        required=False,
101        )
[5268]102
[5319]103class IApplicantBaseData(IWAeUPObject):
104    """The data for an applicant.
[5268]105
[5319]106    This is a base interface with no field (except ``reg_no``)
107    required. For use with importers, forms, etc., please use one of
108    the derived interfaces below, which set more fields to required
109    state, depending on use-case.
[5268]110    """
111    reg_no = schema.TextLine(
112        title = u'JAMB Registration Number',
113        )
114    access_code = schema.TextLine(
115        title = u'Access Code',
[5319]116        required = False,
[5268]117        )
118    serial = schema.TextLine(
119        title = u'Serial Number',
120        required = False,
121        )
122    course1 = schema.TextLine(
123        title = u'1st Choice Course of Study',
[5319]124        required = False,
[5268]125        )
126    course2 = schema.TextLine(
127        title = u'2nd Choice Course of Study',
128        required = False,
129        )
130    course3 = schema.TextLine(
131        title = u'3rd Choice Course of Study',
132        required = False,
133        )
134    firstname = schema.TextLine(
135        title = u'First Name',
[5319]136        required = False,
[5268]137        )
138    middlenames = schema.TextLine(
139        title = u'Middle Names',
[5319]140        required = False,
[5268]141        )
142    lastname = schema.TextLine(
143        title = u'Surname/Full Name',
[5319]144        required = False,
[5268]145        )
146    jamb_age = schema.Int(
147        title = u'Age (provided by JAMB)',
148        required = False,
149        )
150    date_of_birth = schema.Date(
151        title = u'Date of Birth',
[5319]152        required = False,
[5268]153        )
154    jamb_state = schema.TextLine(
155        title = u'State (provided by JAMB)',
[5319]156        required = False,
[5268]157        )
158    jamb_lga = schema.TextLine(
159        title = u'LGA (provided by JAMB)',
[5319]160        required = False,
[5268]161        )
162    lga = schema.TextLine(
163        # XXX: should be choice
164        title = u'State/LGA (confirmed by applicant)',
[5319]165        required = False,
[5268]166        )
167    sex = schema.Choice(
168        title = u'Sex',
[5319]169        source = GenderSource(),
170        default = u'm',
171        required = False,
[5268]172        )
173    email = schema.TextLine(
174        title = u'Email',
175        required = False,
176        )
177    phone = schema.TextLine(
178        title = u'Phone',
179        required = False,
180        )
181    passport = schema.Bool(
182        title = u'Passport Photograph',
183        default = True,
[5319]184        required = False,
[5268]185        )
186    aos = schema.TextLine(
187        # XXX: should be choice
188        title = u'Area of Specialisation',
189        required = False,
190        )
191    subj1 = schema.TextLine(
192        # XXX: should be choice
193        title = u'1st Choice of Study',
194        required = False,
195        )
196    subj2 = schema.TextLine(
197        # XXX: should be choice
198        title = u'2nd Choice of Study',
199        required = False,
200        )
201    subj3 = schema.TextLine(
202        # XXX: should be choice
203        title = u'3rd Choice of Study',
204        required = False,
205        )
206    #
207    # Higher Educational Data
208    #
209    hq_matric_no = schema.TextLine(
210        title = u'Former Matric Number',
211        required = False,
212        )
213    hq_type = schema.TextLine(
214        title = u'Higher Qualification',
215        required = False,
216        )
217    hq_grade = schema.TextLine(
218        title = u'Higher Qualification Grade',
219        required = False,
220        )
221    hq_school = schema.TextLine(
222        title = u'School Attended',
223        required = False,
224        )
225    hq_session = schema.TextLine(
226        title = u'Session Obtained',
227        required = False,
228        )
229    hq_disc = schema.TextLine(
230        title = u'Discipline',
231        required = False,
232        )
233    #
234    # First sitting data
235    #
236    fst_sit_fname = schema.TextLine(
237        title = u'Full Name',
[5319]238        required = False,
[5268]239        )
240    fst_sit_no = schema.TextLine(
241        title = u'Exam Number',
242        required = False,
243        )
244    fst_sit_date = schema.Date(
245        title = u'Exam Date (dd/mm/yyyy)',
246        required = False,
247        )
248    fst_sit_type = schema.TextLine(
249        # XXX: Should be choice
250        title = u'Exam Type',
251        required = False,
252        )
[5271]253    fst_sit_results = schema.List(
[5268]254        title = u'Results',
255        required = False,
[5271]256        value_type = schema.Object(
257            title = u'Entries',
258            schema = IResultEntry,
[5319]259            required = False,
[5271]260            )
[5268]261        )
262    scd_sit_fname = schema.TextLine(
263        title = u'Full Name',
[5319]264        required = False,
[5268]265        )
266    scd_sit_no = schema.TextLine(
267        title = u'Exam Number',
268        required = False,
269        )
270    scd_sit_date = schema.Date(
271        title = u'Exam Date (dd/mm/yyyy)',
272        required = False,
273        )
274    scd_sit_type = schema.TextLine(
275        # XXX: Should be choice
276        title = u'Exam Type',
277        required = False,
278        )
279    scd_sit_results = schema.TextLine(
280        # XXX: Should be nested list of choices
281        title = u'Results',
282        required = False,
283        )
284    #
285    # JAMB scores
286    #
287    eng_score = schema.TextLine(
288        title = u"'English' score",
289        required = False,
290        )
291    subj1score = schema.TextLine(
292        title = u'1st Choice of Study Score',
293        required = False,
294        )
295    subj2score = schema.TextLine(
296        title = u'2nd Choice of Study Score',
297        required = False,
298        )
299    subj3score = schema.TextLine(
300        title = u'3rd Choice of Study Score',
301        required = False,
302        )
303    # XXX: Total score???
304   
305    #
306    # Application Data
307    #
308    application_date = schema.Date(
309        title = u'Application Date',
[5319]310        required = False,
[5268]311        )
312    status = schema.TextLine(
313        # XXX: should be 'status' type
314        title = u'Application Status',
[5319]315        required = False,
[5268]316        )
317    screening_date = schema.Date(
318        title = u'Screening Date',
[5319]319        required = False,
[5268]320        )
321    screening_type = schema.TextLine(
322        # XXX: schould be choice
323        title = u'Screening Type',
[5319]324        required = False,
[5268]325        )
326    screening_score = schema.TextLine(
327        title = u'Screening Score',
[5319]328        required = False,
[5268]329        )
330    screening_venue = schema.TextLine(
331        title = u'Screening Venue',
332        required = False,
333        )
334    total_score = schema.TextLine(
335        title = u'Total Score',
336        required = False,
337        )
338    course_admitted = schema.TextLine(
339        # XXX: should be choice
340        title = u'Admitted Course of Study',
341        required = False,
342        )
343    department = schema.TextLine(
344        # XXX: if we have a course, dept. is not necessary
345        title = u'Department',
346        required = False,
347        )
348    faculty = schema.TextLine(
349        # XXX: if we have a course, faculty is not necessary
350        title = u'Faculty',
351        required = False,
352        )
353    entry_session = schema.TextLine(
[5471]354        # XXX: should be choice, should have sensible default: upcoming session
[5269]355        title = u'Entry Session',
[5319]356        required = False,
[5268]357        )
358    notice = schema.Text(
359        title = u'Notice',
360        required = False,
[5269]361        )
362    student_id = schema.TextLine(
[5268]363        title = u'Student ID',
364        required = False,
365        )
366    import_record_no = schema.TextLine(
367        title = u'Import Record No.',
[5319]368        required = False,
[5268]369        )
370    imported_by = schema.TextLine(
371        title = u'Imported By',
[5319]372        required = False,
[5268]373        )
[5269]374    import_date = schema.Datetime(
[5268]375        title = u'Import Date',
[5319]376        required = False,
[5268]377        )
378    import_from = schema.TextLine(
379        title = u'Import Source',
[5319]380        required = False,
[5268]381        )
[5269]382
[5319]383   
384class IApplicant(IApplicantBaseData):
385    """An applicant.
386
387    This is basically the applicant base data. Here we repeat the
388    fields from base data only with the `required` attribute of
389    required attributes set to True (which is the default).
390    """
391    access_code = schema.TextLine(
392        title = u'Access Code',
393        )
394    course1 = schema.TextLine(
395        title = u'1st Choice Course of Study',
396        )
397    firstname = schema.TextLine(
398        title = u'First Name',
399        )
400    middlenames = schema.TextLine(
401        title = u'Middle Names',
402        )
403    lastname = schema.TextLine(
404        title = u'Surname/Full Name',
405        )
406    date_of_birth = schema.Date(
407        title = u'Date of Birth',
408        )
409    jamb_state = schema.TextLine(
410        title = u'State (provided by JAMB)',
411        )
412    jamb_lga = schema.TextLine(
413        title = u'LGA (provided by JAMB)',
414        )
415    lga = schema.TextLine(
416        # XXX: should be choice
417        title = u'State/LGA (confirmed by applicant)',
418        )
419    sex = schema.Choice(
420        title = u'Sex',
421        source = GenderSource(),
422        default = u'm',
423        )
424    passport = schema.Bool(
425        title = u'Passport Photograph',
426        default = True,
427        )
428    #
429    # Higher Educational Data
430    #
431
432    #
433    # First sitting data
434    #
435    fst_sit_fname = schema.TextLine(
436        title = u'Full Name',
437        )
438
439    #
440    # Second sitting data
441    #
442    scd_sit_fname = schema.TextLine(
443        title = u'Full Name',
444        )
445    #
446    # JAMB scores
447    #
448   
449    #
450    # Application Data
451    #
452    application_date = schema.Date(
453        title = u'Application Date',
454        )
455    status = schema.TextLine(
456        # XXX: should be 'status' type
457        title = u'Application Status',
458        )
459    screening_date = schema.Date(
460        title = u'Screening Date',
461        )
462    screening_type = schema.TextLine(
463        # XXX: schould be choice
464        title = u'Screening Type',
465        )
466    screening_score = schema.TextLine(
467        title = u'Screening Score',
468        )
469    entry_session = schema.TextLine(
470        # XXX: should be choice
471        # XXX: should have sensible default: upcoming session
472        title = u'Entry Session',
473        )
474    import_record_no = schema.TextLine(
475        title = u'Import Record No.',
476        )
477    imported_by = schema.TextLine(
478        title = u'Imported By',
479        )
480    import_date = schema.Datetime(
481        title = u'Import Date',
482        )
483    import_from = schema.TextLine(
484        title = u'Import Source',
485        )
486
487class IApplicantPDEImportData(IApplicantBaseData):
488    """Data for applicants, that passed PDE screening.
489
490    This data set should be suitable for imports from JAMB tables. It
491    is also basicall the basic applicant data from
492    :class:`IApplicantBaseData` only with the required fields set.
493
494    """
495    firstname = schema.TextLine(
496        title = u'First Name',
497        required = True,
498        )
499    middlenames = schema.TextLine(
500        title = u'Middle Names',
501        required = True,
502        )
503    lastname = schema.TextLine(
504        title = u'Surname/Full Name',
505        required = True,
506        )
507    date_of_birth = schema.Date(
508        title = u'Date of Birth',
509        required = True,
510        )
511    jamb_state = schema.TextLine(
512        title = u'State (provided by JAMB)',
513        required = True,
514        )
515    jamb_lga = schema.TextLine(
516        title = u'LGA (provided by JAMB)',
517        required = True,
518        )
519    course1 = schema.TextLine(
520        title = u'1st Choice Course of Study',
521        required = True,
522        )
523    screening_date = schema.Date(
524        title = u'Screening Date',
525        required = True,
526        )
527    screening_type = schema.TextLine(
528        # XXX: schould be choice
529        title = u'Screening Type',
530        required = True,
531        )
532    screening_venue = schema.TextLine(
533        title = u'Screening Venue',
534        required = True,
535        )
536    entry_session = schema.TextLine(
537        # XXX: should be choice
538        # XXX: should have sensible default: upcoming session
539        title = u'Entry Session',
540        required = True,
541        )
542   
[5269]543class IApplicantContainer(IWAeUPObject):
544    """A container for applicants.
545    """
[5432]546
547class IApplicantPrincipalInfo(IPrincipalInfo):
548    """Infos about principals that are applicants.
549    """
550    reg_no = Attribute("The JAMB registration no. of the user")
551
552    access_code = Attribute("The Access Code the user purchased")
553
554class IApplicantPrincipal(IPrincipal):
555    """A principal that is an applicant.
556
557    This interface extends zope.security.interfaces.IPrincipal and
558    requires also an `id` and other attributes defined there.
559    """
560    reg_no = schema.TextLine(
561        title = u'Registration number',
562        description = u'The JAMB registration number',
563        required = True,
564        readonly = True)
565
566    access_code = schema.TextLine(
567        title = u'Access Code',
568        description = u'The access code purchased by the user.',
569        required = True,
570        readonly = True)
[5436]571
[5437]572class IApplicantsFormChallenger(Interface):
[5436]573    """A challenger that uses a browser form to collect applicant
574       credentials.
575    """
576    loginpagename = schema.TextLine(
577        title = u'Loginpagename',
578        description = u"""Name of the login form used by challenger.
579
580        The form must provide an ``access_code`` input field.
[5439]581        """)
[5436]582
[5439]583    accesscode_field = schema.TextLine(
[5436]584        title = u'Access code field',
585        description = u'''Field of the login page which is looked up for
586                          access_code''',
587        default = u'access_code',
588        )
589
[5439]590class IJAMBApplicantsFormChallenger(IApplicantsFormChallenger):
[5436]591    """A challenger that uses a browser form to collect applicant
592       credentials for applicants in JAMB process.
593
594       JAMB-screened applicants have to provide an extra registration
595       no. provided by JAMB.
596    """
[5439]597    jamb_reg_no_field = schema.TextLine(
[5436]598        title = u'JAMB registration no.',
599        description = u'''Field of the login page which is looked up for
600                          the JAMB registration number.''',
601        default = u'jamb_reg_no',
602        )
[5438]603
604class IApplicantSessionCredentials(Interface):
605    """Interface for storing and accessing applicant credentials in a
606       session.
607    """
608
609    def __init__(access_code):
[5471]610        """Create applicant session credentials."""
[5438]611
612    def getAccessCode():
613        """Return the access code."""
614
615
616class IJAMBApplicantSessionCredentials(IApplicantSessionCredentials):
617    """Interface for storing and accessing JAMB applicant credentials in a
618       session.
619    """
620
621    def __init__(access_code, jamb_reg_no):
[5471]622        """Create credentials for JAMB screened applicants."""
[5438]623
624    def getJAMBRegNo():
625        """Return the JAMB registration no."""
Note: See TracBrowser for help on using the repository browser.