# Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or # implied. # See the License for the specific language governing permissions and # limitations under the License. import logging from django.core.urlresolvers import reverse from django.http import Http404 # noqa from django.utils import http from django.utils.translation import ugettext_lazy as _ from django.utils.translation import ungettext_lazy from saharaclient.api import base as api_base from horizon import messages from horizon import tables from openstack_dashboard.api import sahara as saharaclient from openstack_dashboard.dashboards.project.data_processing. \ jobs import tables as j_t LOG = logging.getLogger(__name__) class DeleteJobExecution(tables.DeleteAction): @staticmethod def action_present(count): return ungettext_lazy( u"Delete Job Execution", u"Delete Job Executions", count ) @staticmethod def action_past(count): return ungettext_lazy( u"Deleted Job Execution", u"Deleted Job Executions", count ) def delete(self, request, obj_id): saharaclient.job_execution_delete(request, obj_id) class ReLaunchJobExistingCluster(j_t.ChoosePlugin): @staticmethod def action_present(count): return ungettext_lazy( u"Launch Job", u"Launch Jobs", count ) @staticmethod def action_past(count): return ungettext_lazy( u"Launched Job", u"Launched Jobs", count ) name = "relaunch-job-existing" verbose_name = _("Relaunch On Existing Cluster") url = "horizon:project:data_processing.jobs:launch-job" classes = ('ajax-modal', 'btn-launch') def get_link_url(self, datum): base_url = reverse(self.url) params = http.urlencode({'job_id': datum.job_id, 'job_execution_id': datum.id}) return "?".join([base_url, params]) class ReLaunchJobNewCluster(ReLaunchJobExistingCluster): @staticmethod def action_present(count): return ungettext_lazy( u"Launch Job", u"Launch Jobs", count ) @staticmethod def action_past(count): return ungettext_lazy( u"Launched Job", u"Launched Jobs", count ) name = "relaunch-job-new" verbose_name = _("Relaunch On New Cluster") url = "horizon:project:data_processing.jobs:choose-plugin" classes = ('ajax-modal', 'btn-launch') class UpdateRow(tables.Row): ajax = True def get_data(self, request, job_execution_id): try: return saharaclient.job_execution_get(request, job_execution_id) except api_base.APIException as e: if e.error_code == 404: raise Http404 else: messages.error(request, _("Unable to update row")) def get_job_link(job_execution): return reverse("horizon:project:data_processing.jobs:details", args=(http.urlquote(job_execution.job_id),)) def get_cluster_link(job_execution): return reverse("horizon:project:data_processing.clusters:details", args=(http.urlquote(job_execution.cluster_id),)) class JobExecutionsTable(tables.DataTable): class StatusColumn(tables.Column): def get_raw_data(self, datum): return datum.info['status'] STATUS_CHOICES = ( ("DONEWITHERROR", False), ("FAILED", False), ("KILLED", False), ("SUCCEEDED", True), ) name = tables.Column("id", verbose_name=_("ID"), display_choices=(("id", "ID"), ("name", "Name")), link=("horizon:project:data_processing." "job_executions:details")) job_name = tables.Column( "job_name", verbose_name=_("Job"), link=get_job_link) cluster_name = tables.Column( "cluster_name", verbose_name=_("Cluster"), link=get_cluster_link) status = StatusColumn("info", status=True, status_choices=STATUS_CHOICES, verbose_name=_("Status")) def get_object_display(self, datum): return datum.id class Meta(object): name = "job_executions" row_class = UpdateRow status_columns = ["status"] verbose_name = _("Job Executions") table_actions = [DeleteJobExecution] row_actions = [DeleteJobExecution, ReLaunchJobExistingCluster, ReLaunchJobNewCluster]