2020-11-13 10:01:51 +01:00
|
|
|
from flask import (abort, flash, redirect, render_template,
|
2019-11-04 09:03:31 +01:00
|
|
|
send_from_directory, url_for)
|
|
|
|
from flask_login import current_user, login_required
|
2021-09-13 11:45:43 +02:00
|
|
|
from . import bp
|
2020-04-21 18:34:21 +02:00
|
|
|
from . import tasks
|
2020-07-09 09:42:30 +02:00
|
|
|
from ..decorators import admin_required
|
2020-03-27 12:06:11 +01:00
|
|
|
from ..models import Job, JobInput, JobResult
|
2020-12-02 14:26:17 +01:00
|
|
|
import os
|
2019-11-04 09:03:31 +01:00
|
|
|
|
|
|
|
|
2021-11-30 16:22:16 +01:00
|
|
|
@bp.route('/<hashid:job_id>')
|
2019-11-04 09:03:31 +01:00
|
|
|
@login_required
|
|
|
|
def job(job_id):
|
|
|
|
job = Job.query.get_or_404(job_id)
|
2021-11-30 16:22:16 +01:00
|
|
|
if not (job.user == current_user or current_user.is_administrator()):
|
2019-11-04 09:03:31 +01:00
|
|
|
abort(403)
|
2020-11-13 10:01:51 +01:00
|
|
|
job_inputs = [job_input.to_dict() for job_input in job.inputs]
|
|
|
|
return render_template('jobs/job.html.j2', job=job, job_inputs=job_inputs,
|
2020-06-10 14:25:57 +02:00
|
|
|
title='Job')
|
2019-11-04 09:03:31 +01:00
|
|
|
|
|
|
|
|
2021-11-30 16:22:16 +01:00
|
|
|
@bp.route('/<hashid:job_id>/delete')
|
2019-11-04 09:03:31 +01:00
|
|
|
@login_required
|
|
|
|
def delete_job(job_id):
|
2019-11-04 11:04:42 +01:00
|
|
|
job = Job.query.get_or_404(job_id)
|
2021-11-30 16:22:16 +01:00
|
|
|
if not (job.user == current_user or current_user.is_administrator()):
|
2019-11-04 11:04:42 +01:00
|
|
|
abort(403)
|
2020-04-21 18:34:21 +02:00
|
|
|
tasks.delete_job(job_id)
|
2020-11-13 10:01:51 +01:00
|
|
|
flash('Job has been marked for deletion!', 'job')
|
2019-11-04 09:03:31 +01:00
|
|
|
return redirect(url_for('main.dashboard'))
|
|
|
|
|
|
|
|
|
2021-11-30 16:22:16 +01:00
|
|
|
@bp.route('/<hashid:job_id>/inputs/<hashid:job_input_id>/download')
|
2019-11-04 09:03:31 +01:00
|
|
|
@login_required
|
|
|
|
def download_job_input(job_id, job_input_id):
|
2020-12-02 14:26:17 +01:00
|
|
|
job_input = JobInput.query.filter(JobInput.job_id == job_id, JobInput.id == job_input_id).first_or_404() # noqa
|
2021-11-30 16:22:16 +01:00
|
|
|
if not (job_input.job.user == current_user
|
2019-11-04 09:03:31 +01:00
|
|
|
or current_user.is_administrator()):
|
|
|
|
abort(403)
|
2020-11-13 10:01:51 +01:00
|
|
|
return send_from_directory(as_attachment=True,
|
2020-12-02 14:26:17 +01:00
|
|
|
directory=os.path.dirname(job_input.path),
|
2019-11-04 09:03:31 +01:00
|
|
|
filename=job_input.filename)
|
|
|
|
|
|
|
|
|
2021-11-30 16:22:16 +01:00
|
|
|
@bp.route('/<hashid:job_id>/restart')
|
2020-07-09 09:42:30 +02:00
|
|
|
@login_required
|
|
|
|
@admin_required
|
|
|
|
def restart(job_id):
|
|
|
|
job = Job.query.get_or_404(job_id)
|
2021-05-03 11:12:40 +02:00
|
|
|
if job.status not in ['complete', 'failed']:
|
2021-12-08 14:45:05 +01:00
|
|
|
flash(f'Can not restart job "{job.title}": Status is not "complete/failed"', 'error') # noqa
|
2020-07-09 09:42:30 +02:00
|
|
|
else:
|
|
|
|
tasks.restart_job(job_id)
|
2021-12-08 14:45:05 +01:00
|
|
|
flash(f'Job "{job.title}" marked to get restarted!', 'job')
|
2020-11-13 10:01:51 +01:00
|
|
|
return redirect(url_for('.job', job_id=job_id))
|
2020-07-09 09:42:30 +02:00
|
|
|
|
|
|
|
|
2021-11-30 16:22:16 +01:00
|
|
|
@bp.route('/<hashid:job_id>/results/<hashid:job_result_id>/download')
|
2019-11-04 09:03:31 +01:00
|
|
|
@login_required
|
|
|
|
def download_job_result(job_id, job_result_id):
|
2020-12-02 14:26:17 +01:00
|
|
|
job_result = JobResult.query.filter(JobResult.job_id == job_id, JobResult.id == job_result_id).first_or_404() # noqa
|
2021-11-30 16:22:16 +01:00
|
|
|
if not (job_result.job.user == current_user
|
2019-11-04 09:03:31 +01:00
|
|
|
or current_user.is_administrator()):
|
|
|
|
abort(403)
|
2020-11-13 10:01:51 +01:00
|
|
|
return send_from_directory(as_attachment=True,
|
2020-12-02 14:26:17 +01:00
|
|
|
directory=os.path.dirname(job_result.path),
|
2019-11-04 09:03:31 +01:00
|
|
|
filename=job_result.filename)
|