]> git.llucax.com Git - software/sercom.git/blob - sercom/controllers.py
Especificar con más detalle TODO del backend.
[software/sercom.git] / sercom / controllers.py
1 # vim: set et sw=4 sts=4 encoding=utf-8 foldmethod=marker :
2
3 from turbogears import controllers, expose, view, url
4 from turbogears import widgets as W, validators as V
5 from turbogears import identity, redirect
6 from cherrypy import request, response
7 from turbogears.toolbox.catwalk import CatWalk
8 import model
9 from model import InstanciaDeEntrega, Correccion, AND, DateTimeCol, Entrega
10 # from sercom import json
11
12 from subcontrollers import *
13
14 import logging
15 log = logging.getLogger("sercom.controllers")
16
17 class LoginForm(W.TableForm):
18     class Fields(W.WidgetsList):
19         login_user = W.TextField(label=_(u'Usuario'),
20             validator=V.NotEmpty())
21         login_password = W.PasswordField(label=_(u'Contraseña'),
22             validator=V.NotEmpty())
23     fields = Fields()
24     javascript = [W.JSSource("MochiKit.DOM.focusOnLoad('form_login_user');")]
25     submit = W.SubmitButton(name='login_submit')
26     submit_text = _(u'Ingresar')
27
28 class Root(controllers.RootController):
29
30     @expose()
31     def index(self):
32         raise redirect(url('/dashboard'))
33
34     @expose(template='.templates.welcome')
35     @identity.require(identity.not_anonymous())
36     def dashboard(self):
37         now = DateTimeCol.now()
38         if 'admin' in identity.current.permissions:
39             # TODO : Fijar el curso !!
40             correcciones = Correccion.selectBy(corrector=identity.current.user,
41                 corregido=None).count()
42             instancias = list(InstanciaDeEntrega.select(
43                 AND(InstanciaDeEntrega.q.inicio <= now,
44                     InstanciaDeEntrega.q.fin > now))
45                         .orderBy(InstanciaDeEntrega.q.fin))
46             return dict(a_corregir=correcciones,
47                 instancias_activas=instancias, now=now)
48         
49         if 'entregar' in identity.current.permissions:
50             # Proximas instancias de entrega
51             instancias = list(InstanciaDeEntrega.select(
52                 AND(InstanciaDeEntrega.q.inicio <= now,
53                     InstanciaDeEntrega.q.fin > now)).orderBy(InstanciaDeEntrega.q.fin))
54             # Ultimas N entregas realizadas
55             entregas = list(Entrega.select(Entrega.q.entregadorID == identity.current.user.id)[:5])
56             return dict(instancias_activas=instancias, now=now, entregas=entregas)
57         return dict()
58
59     @expose(template='.templates.login')
60     def login(self, forward_url=None, previous_url=None, tg_errors=None, *args,
61             **kw):
62
63         if tg_errors:
64             flash(_(u'Hubo un error en el formulario!'))
65
66         if not identity.current.anonymous \
67                 and identity.was_login_attempted() \
68                 and not identity.get_identity_errors():
69             raise redirect(forward_url)
70
71         forward_url = None
72         previous_url = request.path
73
74         if identity.was_login_attempted():
75             msg = _(u'Las credenciales proporcionadas no son correctas o no '
76                     'le dan acceso al recurso solicitado.')
77         elif identity.get_identity_errors():
78             msg = _(u'Debe proveer sus credenciales antes de acceder a este '
79                     'recurso.')
80         else:
81             msg = _(u'Por favor ingrese.')
82             forward_url = request.headers.get('Referer', '/')
83
84         fields = list(LoginForm.fields)
85         if forward_url:
86             fields.append(W.HiddenField(name='forward_url'))
87         fields.extend([W.HiddenField(name=name) for name in request.params
88                 if name not in ('login_user', 'login_password', 'login_submit',
89                                 'forward_url')])
90         login_form = LoginForm(fields=fields, action=previous_url)
91
92         values = dict(forward_url=forward_url)
93         values.update(request.params)
94
95         response.status=403
96         return dict(login_form=login_form, form_data=values, message=msg,
97                 logging_in=True)
98
99     @expose()
100     def logout(self):
101         identity.current.logout()
102         raise redirect(url('/'))
103
104     docente = DocenteController()
105
106     grupo = GrupoController()
107
108     alumno = AlumnoController()
109
110     enunciado = EnunciadoController()
111
112     ejercicio = EjercicioController()
113
114     caso_de_prueba = CasoDePruebaController()
115
116     curso = CursoController()
117
118     docente_inscripto = DocenteInscriptoController()
119
120     alumno_inscripto = AlumnoInscriptoController()
121
122     correccion = CorreccionController()
123
124     admin = identity.SecureObject(CatWalk(model), identity.has_permission('admin'))
125
126     mis_entregas = MisEntregasController()
127
128 #{{{ Agrega summarize a namespace tg de KID
129 def summarize(text, size, concat=True, continuation='...'):
130     """Summarize a string if it's length is greater than a specified size. This
131     is useful for table listings where you don't want the table to grow because
132     of a large field.
133
134     >>> from sercome.controllers
135     >>> text = '''Why is it that nobody remembers the name of Johann
136     ... Gambolputty de von Ausfern-schplenden-schlitter-crasscrenbon-fried-
137     ... digger-dingle-dangle-dongle-dungle-burstein-von-knacker-thrasher-apple-
138     ... banger-horowitz-ticolensic-grander-knotty-spelltinkle-grandlich-
139     ... grumblemeyer-spelterwasser-kurstlich-himbleeisen-bahnwagen-gutenabend-
140     ... bitte-ein-nurnburger-bratwustle-gernspurten-mitz-weimache-luber-
141     ... hundsfut-gumberaber-shonedanker-kalbsfleisch-mittler-aucher von
142     ... Hautkopft of Ulm?'''
143     >>> summarize(text, 30)
144     'Why is it that nobody remem...'
145     >>> summarize(text, 68, False, ' [...]')
146     'Why is it that nobody remembers the name of Johann\nGambolputty [...]'
147     >>> summarize(text, 68, continuation=' >>')
148     'Why is it that nobody remembers the name of Johann Gambolputty de >>'
149     """
150     if text is not None:
151         if concat:
152             text = text.replace('\n', ' ')
153         if len(text) > size:
154             text = text[:size-len(continuation)] + continuation
155     return text
156
157 def add_custom_stdvars(vars):
158     return vars.update(dict(summarize=summarize))
159
160 view.variable_providers.append(add_custom_stdvars)
161 #}}}
162