]> git.llucax.com Git - software/sercom.git/blobdiff - sercom/subcontrollers/alumno/__init__.py
Pongo en color rojo, amarillo o verde a cada fila de las entregas dependiendo como...
[software/sercom.git] / sercom / subcontrollers / alumno / __init__.py
index 7cdb4552ce457489fddde56c7cf027833dc5fdc0..7dd7f015d9e553c79914f7385507aa26077ddaad 100644 (file)
@@ -10,7 +10,8 @@ from turbogears import identity
 from turbogears import paginate
 from docutils.core import publish_parts
 from sercom.subcontrollers import validate as val
 from turbogears import paginate
 from docutils.core import publish_parts
 from sercom.subcontrollers import validate as val
-from sercom.model import Alumno
+from sercom.model import Alumno, Rol
+from sqlobject import *
 #}}}
 
 #{{{ Configuración
 #}}}
 
 #{{{ Configuración
@@ -106,6 +107,7 @@ class AlumnoController(controllers.Controller, identity.SecureResource):
     @expose()
     def create(self, **kw):
         """Save or create record to model"""
     @expose()
     def create(self, **kw):
         """Save or create record to model"""
+        kw['roles'] = [Rol.by_nombre('alumno')]
         validate_new(kw)
         flash(_(u'Se creó un nuevo %s.') % name)
         raise redirect('list')
         validate_new(kw)
         flash(_(u'Se creó un nuevo %s.') % name)
         raise redirect('list')
@@ -156,20 +158,42 @@ class AlumnoController(controllers.Controller, identity.SecureResource):
         lines = archivo.file.read().split('\n')
         ok = []
         fail = []
         lines = archivo.file.read().split('\n')
         ok = []
         fail = []
+        entregador = Rol.get(2)
         for line in lines:
             for row in csv.reader([line]):
                 if row == []:
                     continue
                 try:
         for line in lines:
             for row in csv.reader([line]):
                 if row == []:
                     continue
                 try:
-                    u = Alumno(row[0], nombre=row[1])
+                    u = Alumno(row[0], nombre=row[1], roles=[Rol.by_nombre('alumno')])
                     u.email = row[2]
                     u.telefono = row[3]
                     u.email = row[2]
                     u.telefono = row[3]
-                    u.contrasenia = row[0]
+                    u.password = row[0]
                     u.activo = True
                     u.activo = True
+                    u.add_rol(entregador)
                     ok.append(row)
                 except Exception, e:
                     row.append(str(e))
                     fail.append(row)
         return dict(ok=ok, fail=fail)
                     ok.append(row)
                 except Exception, e:
                     row.append(str(e))
                     fail.append(row)
         return dict(ok=ok, fail=fail)
+    
+    @expose('json')
+    def get_alumno(self, padron):
+        msg = u''
+        error=False
+        try:
+            # Busco el alumno inscripto
+            alumno = Alumno.byPadron(padron=padron)
+            msg = {}
+            msg['id'] = alumno.id
+            msg['value'] = alumno.shortrepr()
+        except SQLObjectNotFound:
+            msg = 'No existe el alumno con padron: %s.' % padron
+            error=True
+        except Exception, (inst):
+            msg = u"""Se ha producido un error inesperado al buscar el registro:\n      %s""" % str(inst)
+            error = True
+        return dict(msg=msg, error=error)
+
+   
 #}}}
 
 #}}}