+
+ def __init__(self, data=None, initial=None, hosts=(), applications=(), modules=(), *args, **kwargs):
+ super(JobDescriptionForm, self).__init__(data, initial=initial, *args, **kwargs)
+
+ self.fields['hosts'].choices = hosts
+ self.fields['application'].choices = applications
+ self.fields['modules'].choices = modules
+
+ if data or initial:
+ self._init_user_choices('queue')
+ self._init_user_choices('arguments')
+ self._init_user_choices('native')
+ self._init_user_choices('stage_in')
+ self._init_user_choices('force_field')
+
+ if not hosts:
+ self._init_user_choices('hosts')
+ self._init_user_choices('application')
+ self._init_user_choices('modules')
+
+
+ self.fields['monitoring'].widget.attrs['disabled'] = True
+
+ def clean(self):
+ data = super(JobDescriptionForm, self).clean()
+
+ force_field = data.get('force_field')
+
+ if force_field == u'GAB':
+ data['application'] = [u'unres-gab']
+ else:
+ data['application'] = [u'unres-e0ll2y']
+
+ if data['pdb_file']== None:
+ self.add_error('pdb_file', u"Należy podać plik PDB.")
+
+ if data['sequence']== '':
+ self.add_error('sequence', u"Należy podać sekwencję aminokwasów.")
+
+ if data['procs'] and data['nodes']:
+ self.add_error(None, u"Zdefiniuj tylko jedno z pól: liczbę procesów lub topologię węzłów")
+
+ notify_type = data.get('notify_type')
+ data['notify'] = u'{}:{}'.format(notify_type, data['notify_address']) if notify_type else ''
+
+ wo_type = data.get('watch_output_type')
+ data['watch_output'] = u'{}:{}'.format(wo_type, data['watch_output_address']) if wo_type else ''
+
+ preprocess_type = data.get('preprocess_type')
+ if preprocess_type == self.Process.CMD:
+ data['preprocess'] = data['preprocess_cmd']
+ elif preprocess_type == self.Process.SCRIPT:
+ data['preprocess'] = data['preprocess_script']
+ else:
+ data['preprocess'] = ''
+
+ postprocess_type = data.get('postprocess_type')
+ if postprocess_type == self.Process.CMD:
+ data['postprocess'] = data['postprocess_cmd']
+ elif postprocess_type == self.Process.SCRIPT:
+ data['postprocess'] = data['postprocess_script']
+ else:
+ data['postprocess'] = ''
+
+ return data
+
+ def clean_application(self):
+ return self.cleaned_data['application'].split('/', 1) if self.cleaned_data['application'] else ''
+
+ def clean_nodes(self):
+ return map(int, self.cleaned_data['nodes'].split(':', 2)) if self.cleaned_data['nodes'] else ''
+
+ def clean_executable(self):
+ return self._gsiftp_suffix(self.cleaned_data['executable'])
+
+ def clean_master_file(self):
+ return self._gsiftp_suffix(self.cleaned_data['master_file'])
+
+ def clean_input(self):
+ return self._gsiftp_suffix(self.cleaned_data['input'])
+
+ def clean_stage_in(self):
+ return [self._gsiftp_suffix(item) for item in self.cleaned_data['stage_in']]
+
+ def clean_preprocess_script(self):
+ return self._gsiftp_suffix(self.cleaned_data['preprocess_script'])
+
+ def clean_postprocess_script(self):
+ return self._gsiftp_suffix(self.cleaned_data['postprocess_script'])
+
+ def clean_pdb_file(self):
+ return self._gsiftp_suffix(self.cleaned_data['pdb_file'])
+
+ def clean_sequence(self):
+ return self.cleaned_data['sequence'].strip(' \t\n\r')
+
+ @staticmethod
+ def _gsiftp_suffix(url):
+ if url:
+ return url if url.startswith('gsiftp://') else 'gsiftp://' + url
+
+ def _init_user_choices(self, name):
+ initial = self.initial.get(name)
+ choices = self.data.getlist(name)[:] if self.data else []
+
+ if initial:
+ choices += initial if isinstance(initial, list) else [initial]
+
+ if choices:
+ self.fields[name].choices += ((v, v) for v in choices)