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 TareaFuente, ComandoFuente, Comando
14 from sqlobject import *
19 name = 'comando fuente'
20 namepl = 'comandos fuente'
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 ComandoFuenteForm(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(min=3, max=255, strip=True))
40 descripcion = W.TextField(label=_(u'Descripcion'), validator=V.UnicodeString(min=3, max=255, strip=True))
41 retorno = W.TextField(label=_(u'Retorno'), help_text=u"Codigo de retorno esperado",validator=V.Int(if_empty=0))
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'Terminar si falla'), default=1, validator=V.Bool(if_empty=1))
50 archivos_entrada = W.FileField(label=_(u'Archivos Entrada'))
51 archivos_a_comparar = W.FileField(label=_(u'Archivos a Comparar'))
52 archivos_a_guardar = W.TextField(label=_(u'Archivos a Guardar'))
53 activo = W.CheckBox(label=_(u'Activo'), default=1, validator=V.Bool(if_empty=1))
55 javascript = [W.JSSource("MochiKit.DOM.focusOnLoad('form_comando');")]
57 form = ComandoFuenteForm()
61 class ComandoFuenteController(controllers.Controller, identity.SecureResource):
62 """Basic model admin interface"""
63 require = identity.has_permission('admin')
65 @expose(template='kid:%s.templates.list' % __name__)
67 def list(self, tareaID):
68 """List records in model"""
69 r = cls.select(cls.q.tareaID == tareaID)
70 return dict(records=r, name=name, tareaID=int(tareaID),namepl=namepl)
72 @expose(template='kid:%s.templates.new' % __name__)
73 def new(self, tareaID,**kw):
74 """Create new records in model"""
75 form.fields[0].attrs['value'] = tareaID
76 return dict(name=name, namepl=namepl, form=form, values=kw)
81 def create(self, **kw):
82 """Save or create record to model"""
83 t = TareaFuente.get(kw['tareaID'])
87 if kw['archivos_entrada'].filename:
88 kw['archivos_entrada'] = kw['archivos_entrada'].file.read()
90 kw['archivos_entrada'] = None
91 if kw['archivos_a_comparar'].filename:
92 kw['archivos_a_comparar'] = kw['archivos_a_comparar'].file.read()
94 kw['archivos_a_comparar'] = None
95 # TODO : Hacer ventanita mas amigable para cargar esto.
97 kw['archivos_a_guardar'] = tuple(kw['archivos_a_guardar'].split(','))
99 kw['archivos_a_guardar'] = None
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 return dict(name=name, namepl=namepl, record=r, form=form)
113 def update(self, id, **kw):
114 """Save or create record to model"""
115 r = validate_set(id, kw)
116 flash(_(u'El %s fue actualizado.') % name)
117 raise redirect('../list')
119 @expose(template='kid:%s.templates.show' % __name__)
120 def show(self,id, **kw):
121 """Show record in model"""
123 if r.observaciones is None:
126 r.obs = publish_parts(r.observaciones, writer_name='html')['html_body']
127 return dict(name=name, namepl=namepl, record=r)
130 def delete(self, id):
131 """Destroy record in model"""
134 flash(_(u'El %s fue eliminado permanentemente.') % name)
135 raise redirect('../list')
137 @expose(template='kid:%s.templates.from_file' % __name__)
141 @expose(template='kid:%s.templates.import_results' % __name__)
142 def from_file_add(self, archivo):
144 padron,nombre,email,telefono
147 lines = archivo.file.read().split('\n')
150 entregador = Rol.get(2)
152 for row in csv.reader([line]):
156 u = Alumno(row[0], nombre=row[1])
161 u.add_rol(entregador)
166 return dict(ok=ok, fail=fail)
169 def get_alumno(self, padron):
173 # Busco el alumno inscripto
174 alumno = Alumno.byPadron(padron=padron)
176 msg['id'] = alumno.id
177 msg['value'] = alumno.shortrepr()
178 except SQLObjectNotFound:
179 msg = 'No existe el alumno con padron: %s.' % padron
181 except Exception, (inst):
182 msg = u"""Se ha producido un error inesperado al buscar el registro:\n %s""" % str(inst)
184 return dict(msg=msg, error=error)