]> git.llucax.com Git - z.facultad/75.52/sercom.git/blobdiff - sercom/subcontrollers/misentregas/__init__.py
Capturar stdout/stderr/stdouterr y guardar en archivos_guardados en formato zip.
[z.facultad/75.52/sercom.git] / sercom / subcontrollers / misentregas / __init__.py
index a7c3c3138285067c13057af809fcee45445bc202..65420c93d818d3361de73f343af7fd08b7a0d616 100644 (file)
@@ -123,7 +123,11 @@ class MisEntregasController(controllers.Controller, identity.SecureResource):
     @paginate('records')
     def list(self):
         """List records in model"""
     @paginate('records')
     def list(self):
         """List records in model"""
-        r = cls.select(cls.q.entregadorID == identity.current.user.id)
+        # Grupos en los que el usuario formo parte
+        m = [i.grupo.id for i in Grupo.selectByAlumno(identity.current.user)]
+        entregador = AlumnoInscripto.selectByAlumno(identity.current.user)
+        m.append(entregador.id)
+        r = cls.select(IN(cls.q.entregadorID, m))
         return dict(records=r, name=name, namepl=namepl)
 
     @validate(form=form)
         return dict(records=r, name=name, namepl=namepl)
 
     @validate(form=form)
@@ -138,7 +142,7 @@ class MisEntregasController(controllers.Controller, identity.SecureResource):
             raise redirect('list')
 
         # por defecto el entregador es el user loggeado
             raise redirect('list')
 
         # por defecto el entregador es el user loggeado
-        entregador = identity.current.user
+        entregador = AlumnoInscripto.selectByAlumno(identity.current.user)
 
         ejercicio = Ejercicio.get(int(ejercicio))
         if ejercicio.grupal:
 
         ejercicio = Ejercicio.get(int(ejercicio))
         if ejercicio.grupal:
@@ -168,6 +172,20 @@ class MisEntregasController(controllers.Controller, identity.SecureResource):
         flash(_(u'Se creó una nueva %s.') % name)
         raise redirect('list')
 
         flash(_(u'Se creó una nueva %s.') % name)
         raise redirect('list')
 
+    @expose(template='kid:%s.templates.corrida' % __name__)
+    def corrida(self, entregaid):
+        e = validate_get(id)
+        return dict(entrega=e)
+
+    @expose()
+    def get_archivo(self, entregaid):
+        from cherrypy import request, response
+        r = validate_get(entregaid)
+        response.headers["Content-Type"] = "application/zip"
+        response.headers["Content-disposition"] = "attachment;filename=Ej_%s-Entrega_%s-%s.zip" % (r.instancia.ejercicio.numero, r.instancia.numero, r.entregador.nombre)
+        flash(_(u'El %s fue eliminado permanentemente.') % name)
+        return r.archivos
+
     @expose("json")
     def instancias(self, ejercicio_id):
         c = Ejercicio.get(ejercicio_id)
     @expose("json")
     def instancias(self, ejercicio_id):
         c = Ejercicio.get(ejercicio_id)