]> git.llucax.com Git - z.facultad/75.52/sercom.git/blob - sercom/subcontrollers/alumno/__init__.py
Enlace de Volver desde Entregas a Ejercicio.
[z.facultad/75.52/sercom.git] / sercom / subcontrollers / alumno / __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 Alumno, Rol
14 from sqlobject import *
15 #}}}
16
17 #{{{ Configuración
18 cls = Alumno
19 name = 'alumno'
20 namepl = name + 's'
21 #}}}
22
23 #{{{ Validación
24 def validate_get(id):
25     return val.validate_get(cls, name, id)
26
27 def validate_set(id, data):
28     return val.validate_set(cls, name, id, data)
29
30 def validate_new(data):
31     return val.validate_new(cls, name, data)
32 #}}}
33
34 #{{{ Formulario
35 class AlumnoForm(W.TableForm):
36     class Fields(W.WidgetsList):
37         padron = W.TextField(label=_(u'Padrón'),
38             help_text=_(u'Requerido y único.'),
39             validator=V.UnicodeString(min=3, max=10, strip=True))
40         nombre = W.TextField(label=_(u'Nombre'),
41             help_text=_(u'Requerido.'),
42             validator=V.UnicodeString(min=10, max=255, strip=True))
43         email = W.TextField(label=_(u'E-Mail'),
44             #help_text=_(u'Dirección de e-mail.'),
45             validator=V.All(
46                 V.Email(not_empty=False, resolve_domain=True),
47                 V.UnicodeString(not_empty=False, max=255, strip=True)))
48         telefono = W.TextField(label=_(u'Teléfono'),
49             #help_text=_(u'Texto libre para teléfono, se puede incluir '
50             #    'horarios o varias entradas.'),
51             validator=V.UnicodeString(not_empty=False, min=7, max=255,
52                 strip=True))
53         nota = W.TextField(label=_(u'Nota'),
54             #help_text=_(u'Texto libre para teléfono, se puede incluir '
55             #    'horarios o varias entradas.'),
56             validator=V.Number(not_empty=False, strip=True))
57         observaciones = W.TextArea(label=_(u'Observaciones'),
58             #help_text=_(u'Observaciones.'),
59             validator=V.UnicodeString(not_empty=False, strip=True))
60         activo = W.CheckBox(label=_(u'Activo'), default=1,
61             #help_text=_(u'Si no está activo no puede ingresar al sistema.'),
62             validator=V.Bool(if_empty=1))
63     fields = Fields()
64     javascript = [W.JSSource("MochiKit.DOM.focusOnLoad('form_padron');")]
65
66 form = AlumnoForm()
67 #}}}
68
69 #{{{ Controlador
70 class AlumnoController(controllers.Controller, identity.SecureResource):
71     """Basic model admin interface"""
72     require = identity.has_permission('admin')
73
74     @expose()
75     def default(self, tg_errors=None):
76         """handle non exist urls"""
77         raise redirect('list')
78
79     @expose()
80     def index(self):
81         raise redirect('list')
82
83     @expose(template='kid:%s.templates.list' % __name__)
84     @paginate('records')
85     def list(self):
86         """List records in model"""
87         r = cls.select()
88         return dict(records=r, name=name, namepl=namepl)
89
90     @expose()
91     def activate(self, id, activo):
92         """Save or create record to model"""
93         r = validate_get(id)
94         try:
95             r.activo = bool(int(activo))
96         except ValueError:
97             raise cherrypy.NotFound
98         raise redirect('../../list')
99
100     @expose(template='kid:%s.templates.new' % __name__)
101     def new(self, **kw):
102         """Create new records in model"""
103         return dict(name=name, namepl=namepl, form=form, values=kw)
104
105     @validate(form=form)
106     @error_handler(new)
107     @expose()
108     def create(self, **kw):
109         """Save or create record to model"""
110         kw['roles'] = [Rol.by_nombre('alumno')]
111         validate_new(kw)
112         flash(_(u'Se creó un nuevo %s.') % name)
113         raise redirect('list')
114
115     @expose(template='kid:%s.templates.edit' % __name__)
116     def edit(self, id, **kw):
117         """Edit record in model"""
118         r = validate_get(id)
119         return dict(name=name, namepl=namepl, record=r, form=form)
120
121     @validate(form=form)
122     @error_handler(edit)
123     @expose()
124     def update(self, id, **kw):
125         """Save or create record to model"""
126         r = validate_set(id, kw)
127         flash(_(u'El %s fue actualizado.') % name)
128         raise redirect('../list')
129
130     @expose(template='kid:%s.templates.show' % __name__)
131     def show(self,id, **kw):
132         """Show record in model"""
133         r = validate_get(id)
134         if r.observaciones is None:
135             r.obs = ''
136         else:
137             r.obs = publish_parts(r.observaciones, writer_name='html')['html_body']
138         return dict(name=name, namepl=namepl, record=r)
139
140     @expose()
141     def delete(self, id):
142         """Destroy record in model"""
143         r = validate_get(id)
144         r.destroySelf()
145         flash(_(u'El %s fue eliminado permanentemente.') % name)
146         raise redirect('../list')
147
148     @expose(template='kid:%s.templates.from_file' % __name__)
149     def from_file(self):
150         return dict()
151
152     @expose(template='kid:%s.templates.import_results' % __name__)
153     def from_file_add(self, archivo):
154         """ Se espera :
155              padron,nombre,email,telefono
156         """
157         import csv
158         lines = archivo.file.read().split('\n')
159         ok = []
160         fail = []
161         entregador = Rol.get(2)
162         for line in lines:
163             for row in csv.reader([line]):
164                 if row == []:
165                     continue
166                 try:
167                     u = Alumno(row[0], nombre=row[1], roles=[Rol.by_nombre('alumno')])
168                     u.email = row[2]
169                     u.telefono = row[3]
170                     u.password = row[0]
171                     u.activo = True
172                     u.add_rol(entregador)
173                     ok.append(row)
174                 except Exception, e:
175                     row.append(str(e))
176                     fail.append(row)
177         return dict(ok=ok, fail=fail)
178     
179     @expose('json')
180     def get_alumno(self, padron):
181         msg = u''
182         error=False
183         try:
184             # Busco el alumno inscripto
185             alumno = Alumno.byPadron(padron=padron)
186             msg = {}
187             msg['id'] = alumno.id
188             msg['value'] = alumno.shortrepr()
189         except SQLObjectNotFound:
190             msg = 'No existe el alumno con padron: %s.' % padron
191             error=True
192         except Exception, (inst):
193             msg = u"""Se ha producido un error inesperado al buscar el registro:\n      %s""" % str(inst)
194             error = True
195         return dict(msg=msg, error=error)
196
197    
198 #}}}
199