]> git.llucax.com Git - software/sercom.git/blob - sercom/subcontrollers/docente/__init__.py
Permitir pasar el el archivo de configuración por línea de comandos al tester.
[software/sercom.git] / sercom / subcontrollers / docente / __init__.py
1 # vim: set et sw=4 sts=4 encoding=utf-8 foldmethod=marker :
2
3 #{{{ Imports
4 import cherrypy
5 from turbogears import controllers, expose, redirect
6 from turbogears import validate, flash, error_handler
7 from turbogears import validators as V
8 from turbogears import widgets as W
9 from turbogears import identity
10 from turbogears import paginate
11 from docutils.core import publish_parts
12 from sercom.subcontrollers import validate as val
13 from sercom.model import Docente
14 #}}}
15
16 #{{{ Configuración
17 cls = Docente
18 name = 'docente'
19 namepl = name + 's'
20 #}}}
21
22 #{{{ Validación
23 def validate_get(id):
24     return val.validate_get(cls, name, id)
25
26 def validate_set(id, data):
27     return val.validate_set(cls, name, id, data)
28
29 def validate_new(data):
30     return val.validate_new(cls, name, data)
31 #}}}
32
33 #{{{ Formulario
34 class DocenteForm(W.TableForm):
35     class Fields(W.WidgetsList):
36         usuario = W.TextField(label=_(u'Usuario'),
37             help_text=_(u'Requerido y único.'),
38             validator=V.UnicodeString(min=3, max=10, strip=True))
39         password = W.PasswordField(label=_(u'Contraseña'),
40             help_text=_(u'Requerido (mínimo 5 caracteres).'),
41             attrs=dict(maxlength=255),
42             validator=V.UnicodeString(min=5, max=255, not_empty=False))
43         passwordc = W.PasswordField(label=_(u'Confirmar'),
44             help_text=_(u'Requerido.'),
45             attrs=dict(maxlength=255),
46             validator=V.UnicodeString(min=5, max=255, not_empty=False))
47         nombre = W.TextField(label=_(u'Nombre'),
48             help_text=_(u'Requerido.'),
49             validator=V.UnicodeString(min=10, max=255, strip=True))
50         email = W.TextField(label=_(u'E-Mail'),
51             #help_text=_(u'Dirección de e-mail.'),
52             validator=V.All(
53                 V.Email(not_empty=False, resolve_domain=True),
54                 V.UnicodeString(not_empty=False, max=255, strip=True)))
55         telefono = W.TextField(label=_(u'Teléfono'),
56             #help_text=_(u'Texto libre para teléfono, se puede incluir '
57             #    'horarios o varias entradas.'),
58             validator=V.UnicodeString(not_empty=False, min=7, max=255,
59                 strip=True))
60         observaciones = W.TextArea(label=_(u'Observaciones'),
61             #help_text=_(u'Observaciones.'),
62             validator=V.UnicodeString(not_empty=False, strip=True))
63         nombrado = W.CheckBox(label=_(u'Nombrado'), default=1,
64             #help_text=_(u'Indica si tiene cargo.'),
65             validator=V.Bool(if_empty=1))
66         activo = W.CheckBox(label=_(u'Activo'), default=1,
67             #help_text=_(u'Si no está activo no puede ingresar al sistema.'),
68             validator=V.Bool(if_empty=1))
69     fields = Fields()
70     javascript = [W.JSSource("MochiKit.DOM.focusOnLoad('form_usuario');")]
71     validator = V.Schema(chained_validators=[
72                          V.FieldsMatch('password', 'passwordc') ])
73
74 form = DocenteForm()
75 #}}}
76
77 #{{{ Controlador
78 class DocenteController(controllers.Controller, identity.SecureResource):
79     """Basic model admin interface"""
80     require = identity.has_permission('admin')
81
82     @expose()
83     def default(self, tg_errors=None):
84         """handle non exist urls"""
85         raise redirect('list')
86
87     @expose()
88     def index(self):
89         raise redirect('list')
90
91     @expose(template='kid:%s.templates.list' % __name__)
92     @paginate('records')
93     def list(self):
94         """List records in model"""
95         r = cls.select()
96         return dict(records=r, name=name, namepl=namepl)
97
98     @expose()
99     def activate(self, id, activo):
100         """Save or create record to model"""
101         r = validate_get(id)
102         try:
103             r.activo = bool(int(activo))
104         except ValueError:
105             raise cherrypy.NotFound
106         raise redirect('../../list')
107
108     @expose(template='kid:%s.templates.new' % __name__)
109     def new(self, **kw):
110         """Create new records in model"""
111         return dict(name=name, namepl=namepl, form=form, values=kw)
112
113     @validate(form=form)
114     @error_handler(new)
115     @expose()
116     def create(self, **kw):
117         """Save or create record to model"""
118         if 'passwordc' in kw:
119             del kw['passwordc']
120         validate_new(kw)
121         flash(_(u'Se creó un nuevo %s.') % name)
122         raise redirect('list')
123
124     @expose(template='kid:%s.templates.edit' % __name__)
125     def edit(self, id, **kw):
126         """Edit record in model"""
127         class POD(dict):
128             def __getattr__(self, attrname):
129                 return self[attrname]
130         r = POD(validate_get(id).sqlmeta.asDict())
131         return dict(name=name, namepl=namepl, record=r, form=form)
132
133     @validate(form=form)
134     @error_handler(edit)
135     @expose()
136     def update(self, id, **kw):
137         """Save or create record to model"""
138         if 'password' in kw:
139             if not kw['password']:
140                 del kw['password']
141         if 'passwordc' in kw:
142             del kw['passwordc']
143         r = validate_set(id, kw)
144         flash(_(u'El %s fue actualizado.') % name)
145         raise redirect('../list')
146
147     @expose(template='kid:%s.templates.show' % __name__)
148     def show(self,id, **kw):
149         """Show record in model"""
150         r = validate_get(id)
151         if r.observaciones is None:
152             r.obs = ''
153         else:
154             r.obs = publish_parts(r.observaciones, writer_name='html')['html_body']
155         return dict(name=name, namepl=namepl, record=r)
156
157     @expose()
158     def delete(self, id):
159         """Destroy record in model"""
160         r = validate_get(id)
161         r.destroySelf()
162         flash(_(u'El %s fue eliminado permanentemente.') % name)
163         raise redirect('../list')
164 #}}}
165