1 # vim: set et sw=4 sts=4 encoding=utf-8 foldmethod=marker :
5 from turbogears import controllers, expose, redirect
6 from turbogears import validate, flash, error_handler
7 from turbogears import validators as V
8 from turbogears import widgets as W
9 from turbogears import identity
10 from turbogears import paginate
11 from docutils.core import publish_parts
12 from sercom.subcontrollers import validate as val
13 from sercom.model import TareaPrueba, ComandoPrueba, Comando
14 from sqlobject import *
19 name = 'comando prueba'
20 namepl = 'comandos prueba'
25 return val.validate_get(cls, name, id)
27 def validate_set(id, data):
28 return val.validate_set(cls, name, id, data)
30 def validate_new(data):
31 return val.validate_new(cls, name, data)
35 class ComandoPruebaForm(W.TableForm):
36 class Fields(W.WidgetsList):
37 tareaID = W.HiddenField()
38 orden = W.TextField(label=_(u'Orden'), validator=V.Int(not_empty=True))
39 comando = W.TextField(label=_(u'Comando'), validator=V.UnicodeString(max=255, strip=True))
40 descripcion = W.TextField(label=_(u'Descripcion'), validator=V.UnicodeString(min=5, max=255, strip=True))
41 retorno = W.TextField(label=_(u'Retorno'), help_text=u"Codigo de retorno esperado",validator=V.Int(if_empty=ComandoPrueba.RET_PRUEBA))
42 max_tiempo_cpu = W.TextField(label=_(u'CPU'), help_text=u"Maximo tiempo de CPU que puede utilizar [seg]",validator=V.Int())
43 max_memoria = W.TextField(label=_(u'Memoria'), help_text=u"Maximo cantidad de memoria que puede utilizar [MB]",validator=V.Int())
44 max_tam_archivo = W.TextField(label=_(u'Tam. Archivo'), help_text=u"Maximo tamanio de archivo a crear [MB]",validator=V.Int())
45 max_cant_archivos = W.TextField(label=_(u'Archivos'),validator=V.Int())
46 max_cant_procesos = W.TextField(label=_(u'Procesos'),validator=V.Int())
47 max_locks_memoria = W.TextField(label=_(u'Mem. Locks'),validator=V.Int())
48 terminar_si_falla = W.CheckBox(label=_(u'Terminar si falla?'), default=1, validator=V.Bool(if_empty=1))
49 rechazar_si_falla = W.CheckBox(label=_(u'Rechazar si falla?'), default=1, validator=V.Bool(if_empty=1))
50 publico = W.CheckBox(label=_(u'Es público?'), default=1, validator=V.Bool(if_empty=1))
51 los_archivos_entrada = W.FileField(label=_(u'Archivos Entrada'))
52 los_archivos_a_comparar = W.FileField(label=_(u'Archivos a Comparar'))
53 archivos_guardar = W.TextField(label=_(u'Archivos a Guardar'))
54 activo = W.CheckBox(label=_(u'Activo'), default=1, validator=V.Bool(if_empty=1))
56 javascript = [W.JSSource("MochiKit.DOM.focusOnLoad('form_orden');")]
58 form = ComandoPruebaForm()
62 class ComandoPruebaController(controllers.Controller, identity.SecureResource):
63 """Basic model admin interface"""
64 require = identity.has_permission('admin')
66 @expose(template='kid:%s.templates.list' % __name__)
68 def list(self, tareaID):
69 """List records in model"""
70 r = cls.select(cls.q.tareaID == tareaID)
71 return dict(records=r, name=name, tareaID=int(tareaID),namepl=namepl)
73 @expose(template='kid:%s.templates.new' % __name__)
74 def new(self, tareaID,**kw):
75 """Create new records in model"""
76 form.fields[0].attrs['value'] = tareaID
77 return dict(name=name, namepl=namepl, form=form, values=kw)
82 def create(self, **kw):
83 """Save or create record to model"""
84 t = TareaPrueba.get(kw['tareaID'])
88 if kw['los_archivos_entrada'].filename:
89 kw['archivos_entrada'] = kw['los_archivos_entrada'].file.read()
90 del kw['los_archivos_entrada']
91 if kw['los_archivos_a_comparar'].filename:
92 kw['archivos_a_comparar'] = kw['los_archivos_a_comparar'].file.read()
93 del kw['los_archivos_a_comparar']
94 # TODO : Hacer ventanita mas amigable para cargar esto.
96 kw['archivos_a_guardar'] = tuple(kw['archivos_guardar'].split(','))
97 except AttributeError:
99 del kw['archivos_guardar']
100 t.add_comando(orden, **kw)
101 flash(_(u'Se creó un nuevo %s.') % name)
102 raise redirect('list/%d' % t.id)
104 @expose(template='kid:%s.templates.edit' % __name__)
105 def edit(self, id, **kw):
106 """Edit record in model"""
108 r.archivos_guardar = ",".join(r.archivos_a_guardar)
109 return dict(name=name, namepl=namepl, record=r, form=form)
114 def update(self, id, **kw):
115 """Save or create record to model"""
119 if kw['los_archivos_entrada'].filename:
120 kw['archivos_entrada'] = kw['los_archivos_entrada'].file.read()
121 del kw['los_archivos_entrada']
122 if kw['los_archivos_a_comparar'].filename:
123 kw['archivos_a_comparar'] = kw['los_archivos_a_comparar'].file.read()
124 del kw['los_archivos_a_comparar']
125 # TODO : Hacer ventanita mas amigable para cargar esto.
127 kw['archivos_a_guardar'] = tuple(kw['archivos_guardar'].split(','))
128 except AttributeError:
130 del kw['archivos_guardar']
131 r = validate_set(id, kw)
132 flash(_(u'El %s fue actualizado.') % name)
133 raise redirect('../list/%d' % r.tarea.id)
135 @expose(template='kid:%s.templates.show' % __name__)
136 def show(self,id, **kw):
137 """Show record in model"""
139 if r.observaciones is None:
142 r.obs = publish_parts(r.observaciones, writer_name='html')['html_body']
143 return dict(name=name, namepl=namepl, record=r)
146 def delete(self, id):
147 """Destroy record in model"""
151 flash(_(u'El %s fue eliminado permanentemente.') % name)
152 raise redirect('../list/%d' % tareaID)
155 def get_archivos_entrada(self, id):
156 from cherrypy import request, response
158 response.headers["Content-Type"] = "application/zip"
159 response.headers["Content-disposition"] = "attachment;filename=archivos_entrada.zip"
160 return r.archivos_entrada
163 def get_archivos_a_comparar(self, id):
164 from cherrypy import request, response
166 response.headers["Content-Type"] = "application/zip"
167 response.headers["Content-disposition"] = "attachment;filename=archivos_a_comparar.zip"
168 return r.archivos_a_comparar