]> git.llucax.com Git - software/sercom.git/blobdiff - sercom/subcontrollers/misentregas/__init__.py
completo el show de caso de prueba con download de archivos
[software/sercom.git] / sercom / subcontrollers / misentregas / __init__.py
index d5ec3e4f6eb9342b768a5055679f097a44c79376..3cb127b051b83e8c8ccd8f92b69de7451c72b832 100644 (file)
@@ -2,7 +2,7 @@
 
 #{{{ Imports
 import cherrypy
-from turbogears import controllers, expose, redirect
+from turbogears import controllers, expose, redirect, url
 from turbogears import validate, flash, error_handler
 from turbogears import validators as V
 from turbogears import widgets as W
@@ -10,7 +10,7 @@ from turbogears import identity
 from turbogears import paginate
 from docutils.core import publish_parts
 from sercom.subcontrollers import validate as val
-from sercom.model import ComandoEjecutado, Entrega, Correccion, Curso, Ejercicio, InstanciaDeEntrega, Grupo, Miembro, AlumnoInscripto
+from sercom.model import ComandoEjecutado, ComandoPruebaEjecutado, Entrega, Correccion, Curso, Ejercicio, InstanciaDeEntrega, Grupo, Miembro, AlumnoInscripto
 from sqlobject import *
 from zipfile import ZipFile, BadZipfile
 from cStringIO import StringIO
@@ -98,6 +98,7 @@ class EntregaForm(W.TableForm):
     javascript = [W.JSSource("MochiKit.DOM.focusOnLoad('form_ejercicio');"), W.JSSource(ajax)]
 
 form = EntregaForm()
+
 #}}}
 
 #{{{ Controlador
@@ -120,6 +121,11 @@ class MisEntregasController(controllers.Controller, identity.SecureResource):
     @paginate('records')
     def list(self):
         """List records in model"""
+        # Un admin no tiene sentido en este area y por las dudas
+        # lo mando al home.
+        if 'admin' in identity.current.permissions:
+            raise redirect(url("/dashboard"))
+
         # Grupos en los que el usuario formo parte
         m = [i.grupo.id for i in Grupo.selectByAlumno(identity.current.user)]
         try:
@@ -210,6 +216,12 @@ class MisEntregasController(controllers.Controller, identity.SecureResource):
         response.headers["Content-disposition"] = "attachment;filename=diferencias_%d.zip" % (r.id)
         return r.diferencias
 
+    @expose(template='kid:%s.templates.diff' % __name__)
+    def verdiff(self, id):
+        r = ComandoEjecutado.get(id)
+        zip = ZipFile(StringIO(r.diferencias), 'r')
+        return dict(zip=zip)
+
     @expose('json')
     def instancias(self, ejercicio_id):
         instancias = InstanciaDeEntrega.select(AND(