]> git.llucax.com Git - z.facultad/75.52/sercom.git/commitdiff
Bugfix: El zip se subía roto en las entregas.
authorLeandro Lucarella <llucax@gmail.com>
Tue, 13 Mar 2007 18:53:49 +0000 (18:53 +0000)
committerLeandro Lucarella <llucax@gmail.com>
Tue, 13 Mar 2007 18:53:49 +0000 (18:53 +0000)
Al parecer al usar el ZipFile con el file object que viene por request, le leía
las cabeceras, avanzando el puntero, y lo rompía. Para evitarlo se lee el
archivo una vez en memoria y se opera con el buffer en memoria. Además se agrega
chequeo de CRC.

sercom/subcontrollers/misentregas/__init__.py
sercom/subcontrollers/validate.py

index 57d7b8a861308732b07d615f052304cca99aefd7..31c76783293a28a790a810ad1a978e2550fb3d22 100644 (file)
@@ -140,10 +140,14 @@ class MisEntregasController(controllers.Controller, identity.SecureResource):
     @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
@@ -171,7 +175,7 @@ class MisEntregasController(controllers.Controller, identity.SecureResource):
                 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)
index 9b4a96a2c962308096032003bfda949db08f3a97..614619c21b2f47bf8889b92bfb3f7901311476af 100644 (file)
@@ -51,3 +51,4 @@ def validate_del(cls, name, id):
     except Exception, e:
         flash(_(u'No se pudo eliminar el %s: %s' % (name, e)))
         raise redirect('../list')
+