2016-01-15 15:48:05 +00:00
|
|
|
from flask import (
|
|
|
|
|
Blueprint,
|
|
|
|
|
jsonify,
|
|
|
|
|
request
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
from sqlalchemy.exc import DataError
|
|
|
|
|
from sqlalchemy.orm.exc import NoResultFound
|
|
|
|
|
|
|
|
|
|
from app.dao.jobs_dao import (
|
|
|
|
|
save_job,
|
|
|
|
|
get_job_by_id,
|
|
|
|
|
get_jobs
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
from app.schemas import (
|
|
|
|
|
job_schema,
|
|
|
|
|
jobs_schema
|
|
|
|
|
)
|
|
|
|
|
|
|
|
|
|
job = Blueprint('job', __name__)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@job.route('/<job_id>', methods=['GET'])
|
2016-01-15 16:34:48 +00:00
|
|
|
@job.route('', methods=['GET'])
|
2016-01-15 15:48:05 +00:00
|
|
|
def get_job(job_id=None):
|
|
|
|
|
if job_id:
|
|
|
|
|
try:
|
|
|
|
|
job = get_job_by_id(job_id)
|
|
|
|
|
data, errors = job_schema.dump(job)
|
|
|
|
|
return jsonify(data=data)
|
|
|
|
|
except DataError:
|
|
|
|
|
return jsonify(result="error", message="Invalid job id"), 400
|
|
|
|
|
except NoResultFound:
|
|
|
|
|
return jsonify(result="error", message="Job not found"), 404
|
|
|
|
|
else:
|
|
|
|
|
jobs = get_jobs()
|
|
|
|
|
data, errors = jobs_schema.dump(jobs)
|
|
|
|
|
return jsonify(data=data)
|
|
|
|
|
|
|
|
|
|
|
2016-01-15 16:34:48 +00:00
|
|
|
@job.route('', methods=['POST'])
|
2016-01-15 15:48:05 +00:00
|
|
|
def create_job():
|
|
|
|
|
job, errors = job_schema.load(request.get_json())
|
|
|
|
|
if errors:
|
|
|
|
|
return jsonify(result="error", message=errors), 400
|
|
|
|
|
try:
|
|
|
|
|
save_job(job)
|
|
|
|
|
except Exception as e:
|
|
|
|
|
return jsonify(result="error", message=str(e)), 500
|
|
|
|
|
return jsonify(data=job_schema.dump(job).data), 201
|