"""Basic model admin interface"""
require = identity.has_permission('entregar')
+ hide_to_admin = 1
+
@expose()
def default(self, tg_errors=None):
"""handle non exist urls"""
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):
"""List records in model"""
# 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)
+ try:
+ entregador = AlumnoInscripto.selectByAlumno(identity.current.user)
+ m.append(entregador.id)
+ except:
+ pass
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"""
+ archivo = archivo.file.read()
try:
- zfile = ZipFile(archivo.file)
+ zfile = ZipFile(StringIO(archivo), 'r')
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')
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)
flash(_(u'El %s fue eliminado permanentemente.') % name)
return r.archivos
- @expose("json")
+ @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)
#}}}