]> git.llucax.com Git - z.facultad/75.52/sercom.git/blobdiff - sercom/subcontrollers/misentregas/__init__.py
Dejar elegir solo instancias de entrega activas al entregar.
[z.facultad/75.52/sercom.git] / sercom / subcontrollers / misentregas / __init__.py
index 57d7b8a861308732b07d615f052304cca99aefd7..004b9df7ed23c0e146aa420aceeebe4186c1f2d4 100644 (file)
@@ -116,11 +116,6 @@ class MisEntregasController(controllers.Controller, identity.SecureResource):
     def index(self):
         raise redirect('list')
 
     def index(self):
         raise redirect('list')
 
-    @expose(template='kid:%s.templates.new' % __name__)
-    def new(self, **kw):
-        """Create new records in model"""
-        return dict(name=name, namepl=namepl, form=form, values=kw)
-
     @expose(template='kid:%s.templates.list' % __name__)
     @paginate('records')
     def list(self):
     @expose(template='kid:%s.templates.list' % __name__)
     @paginate('records')
     def list(self):
@@ -135,15 +130,24 @@ class MisEntregasController(controllers.Controller, identity.SecureResource):
         r = cls.select(IN(cls.q.entregadorID, m))
         return dict(records=r, name=name, namepl=namepl)
 
         r = cls.select(IN(cls.q.entregadorID, m))
         return dict(records=r, name=name, namepl=namepl)
 
+    @expose(template='kid:%s.templates.new' % __name__)
+    def new(self, **kw):
+        """Create new records in model"""
+        return dict(name=name, namepl=namepl, form=form, values=kw)
+
     @validate(form=form)
     @error_handler(new)
     @expose()
     def create(self, archivo, ejercicio, **kw):
         """Save or create record to model"""
     @validate(form=form)
     @error_handler(new)
     @expose()
     def create(self, archivo, ejercicio, **kw):
         """Save or create record to model"""
+        archivo = archivo.file.read()
         try:
         try:
-            zfile = ZipFile(archivo.file)
+            zfile = ZipFile(StringIO(archivo), 'r')
         except BadZipfile:
         except BadZipfile:
-            flash(_(u'El archivo ZIP no es valido'))
+            flash(_(u'El archivo ZIP no es válido'))
+            raise redirect('list')
+        if zfile.testzip() is not None:
+            flash(_(u'El archivo ZIP tiene errores de CRC'))
             raise redirect('list')
 
         # por defecto el entregador es el user loggeado
             raise redirect('list')
 
         # por defecto el entregador es el user loggeado
@@ -171,7 +175,7 @@ class MisEntregasController(controllers.Controller, identity.SecureResource):
                 raise redirect('list')
 
             entregador = m.grupo
                 raise redirect('list')
 
             entregador = m.grupo
-        kw['archivos'] = archivo.file.read()
+        kw['archivos'] = archivo
         kw['entregador'] = entregador
         validate_new(kw)
         flash(_(u'Se creó una nueva %s.') % name)
         kw['entregador'] = entregador
         validate_new(kw)
         flash(_(u'Se creó una nueva %s.') % name)
@@ -191,9 +195,13 @@ class MisEntregasController(controllers.Controller, identity.SecureResource):
         flash(_(u'El %s fue eliminado permanentemente.') % name)
         return r.archivos
 
         flash(_(u'El %s fue eliminado permanentemente.') % name)
         return r.archivos
 
-    @expose("json")
+    @expose('json')
     def instancias(self, ejercicio_id):
     def instancias(self, ejercicio_id):
-        c = Ejercicio.get(ejercicio_id)
-        return dict(instancias=c.instancias)
+        instancias = InstanciaDeEntrega.select(AND(
+                InstanciaDeEntrega.q.ejercicioID == ejercicio_id,
+                InstanciaDeEntrega.q.activo == True,
+                InstanciaDeEntrega.q.inicio <= DateTimeCol.now(),
+                InstanciaDeEntrega.q.fin >= DateTimeCol.now()))
+        return dict(instancias=instancias)
 #}}}
 
 #}}}