X-Git-Url: https://git.llucax.com/software/sercom.git/blobdiff_plain/73633637cbc5d62f2d1502de89a9723d4dd0d1be..55ad2b439dc03b110ef97eee05dd5e6151b39bf3:/sercom/subcontrollers/misentregas/__init__.py?ds=inline diff --git a/sercom/subcontrollers/misentregas/__init__.py b/sercom/subcontrollers/misentregas/__init__.py index 31c7678..d5ec3e4 100644 --- a/sercom/subcontrollers/misentregas/__init__.py +++ b/sercom/subcontrollers/misentregas/__init__.py @@ -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 Entrega, Correccion, Curso, Ejercicio, InstanciaDeEntrega, Grupo, Miembro, AlumnoInscripto +from sercom.model import ComandoEjecutado, Entrega, Correccion, Curso, Ejercicio, InstanciaDeEntrega, Grupo, Miembro, AlumnoInscripto from sqlobject import * from zipfile import ZipFile, BadZipfile from cStringIO import StringIO @@ -116,11 +116,6 @@ class MisEntregasController(controllers.Controller, identity.SecureResource): 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): @@ -135,6 +130,11 @@ class MisEntregasController(controllers.Controller, identity.SecureResource): 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() @@ -192,12 +192,31 @@ class MisEntregasController(controllers.Controller, identity.SecureResource): 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") + @expose() + def file(self, id): + from cherrypy import request, response + r = ComandoEjecutado.get(id) + response.headers["Content-Type"] = "application/zip" + response.headers["Content-disposition"] = "attachment;filename=comando_ejecutado_%d.zip" % (r.id) + return r.archivos + + @expose() + def diff(self, id): + from cherrypy import request, response + r = ComandoEjecutado.get(id) + response.headers["Content-Type"] = "application/zip" + response.headers["Content-disposition"] = "attachment;filename=diferencias_%d.zip" % (r.id) + return r.diferencias + + @expose('json') 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) #}}}