]> git.llucax.com Git - z.facultad/75.52/sercom.git/blob - sercom/controllers.py
Agrega DERs.
[z.facultad/75.52/sercom.git] / sercom / controllers.py
1 # vim: set et sw=4 sts=4 encoding=utf-8 :
2
3 from turbogears import controllers, expose
4 from turbogears import widgets as w, validators
5 from turbogears import identity, redirect
6 from cherrypy import request, response
7 from model import *
8 # from sercom import json
9
10 import logging
11 log = logging.getLogger("sercom.controllers")
12
13 class Root(controllers.RootController):
14
15     @expose(template='.templates.welcome')
16     @identity.require(identity.has_permission('entregar'))
17     def index(self):
18         import time
19         log.debug('Happy TurboGears Controller Responding For Duty')
20         return dict(now=time.ctime())
21
22     @expose(template='.templates.login')
23     def login(self, forward_url=None, previous_url=None, tg_errors=None, *args,
24             **kw):
25
26         if tg_errors:
27             flash(_(u'Hubo un error en el formulario!'))
28
29         if not identity.current.anonymous \
30                 and identity.was_login_attempted() \
31                 and not identity.get_identity_errors():
32             raise redirect(forward_url)
33
34         forward_url = None
35         previous_url = request.path
36
37         if identity.was_login_attempted():
38             msg = _(u'Las credenciales proporcionadas no son correctas o no '
39                     'le dan acceso al recurso solicitado.')
40         elif identity.get_identity_errors():
41             msg = _(u'Debe proveer sus credenciales antes de acceder a este '
42                     'recurso.')
43         else:
44             msg = _(u'Por favor ingrese.')
45             forward_url = request.headers.get('Referer', '/')
46
47         fields = [
48             w.TextField(name='login_user', label=_(u'Usuario'),
49                 validator=validators.NotEmpty()),
50             w.PasswordField(name='login_password', label=_(u'Contraseña'),
51                 validator=validators.NotEmpty())
52         ]
53         if forward_url:
54             fields.append(w.HiddenField(name='forward_url'))
55         fields.extend([w.HiddenField(name=name) for name in request.params
56                 if name not in ('login_user', 'login_password', 'login_submit',
57                                 'forward_url')])
58
59         submit = w.SubmitButton(name='login_submit')
60
61         login_form = w.TableForm(fields=fields, action=previous_url,
62                         submit_text=_(u'Ingresar'), submit=submit)
63
64         values = dict(forward_url=forward_url)
65         values.update(request.params)
66
67         response.status=403
68         return dict(login_form=login_form, form_data=values, message=msg,
69                 logging_in=True)
70
71     @expose()
72     def logout(self):
73         identity.current.logout()
74         raise redirect('/')
75