2019-01-24 16:38:52 +00:00
|
|
|
from celery import current_app
|
|
|
|
|
from flask import Blueprint, jsonify, request
|
2021-03-10 13:55:06 +00:00
|
|
|
from sqlalchemy.exc import IntegrityError
|
2019-01-24 16:38:52 +00:00
|
|
|
|
|
|
|
|
from app.dao.letter_branding_dao import (
|
2021-03-10 13:55:06 +00:00
|
|
|
dao_create_letter_branding,
|
|
|
|
|
dao_get_all_letter_branding,
|
|
|
|
|
dao_get_letter_branding_by_id,
|
2019-01-25 16:05:55 +00:00
|
|
|
dao_update_letter_branding,
|
2019-01-24 16:38:52 +00:00
|
|
|
)
|
2019-01-24 11:13:50 +00:00
|
|
|
from app.errors import register_errors
|
2021-03-10 13:55:06 +00:00
|
|
|
from app.letter_branding.letter_branding_schema import (
|
|
|
|
|
post_letter_branding_schema,
|
|
|
|
|
)
|
2019-01-24 16:38:52 +00:00
|
|
|
from app.models import LetterBranding
|
|
|
|
|
from app.schema_validation import validate
|
|
|
|
|
|
2019-01-24 17:39:48 +00:00
|
|
|
letter_branding_blueprint = Blueprint('letter_branding', __name__, url_prefix='/letter-branding')
|
2019-01-24 16:38:52 +00:00
|
|
|
register_errors(letter_branding_blueprint)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@letter_branding_blueprint.errorhandler(IntegrityError)
|
|
|
|
|
def handle_integrity_error(exc):
|
|
|
|
|
"""
|
|
|
|
|
Handle integrity errors caused by the unique constraint
|
|
|
|
|
"""
|
2019-04-05 16:26:52 +01:00
|
|
|
for col in {'name', 'filename'}:
|
2019-01-28 17:01:13 +00:00
|
|
|
if 'letter_branding_{}_key'.format(col) in str(exc):
|
|
|
|
|
return jsonify(
|
|
|
|
|
result='error',
|
|
|
|
|
message={col: ["{} already in use".format(col.title())]}
|
|
|
|
|
), 400
|
2019-01-24 16:38:52 +00:00
|
|
|
current_app.logger.exception(exc)
|
|
|
|
|
return jsonify(result='error', message="Internal server error"), 500
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
@letter_branding_blueprint.route('', methods=['GET'])
|
|
|
|
|
def get_all_letter_brands():
|
|
|
|
|
letter_brands = dao_get_all_letter_branding()
|
|
|
|
|
|
|
|
|
|
return jsonify([lb.serialize() for lb in letter_brands])
|
|
|
|
|
|
|
|
|
|
|
2019-01-25 16:05:55 +00:00
|
|
|
@letter_branding_blueprint.route('/<uuid:letter_branding_id>', methods=['GET'])
|
|
|
|
|
def get_letter_brand_by_id(letter_branding_id):
|
|
|
|
|
letter_branding = dao_get_letter_branding_by_id(letter_branding_id)
|
|
|
|
|
|
|
|
|
|
return jsonify(letter_branding.serialize()), 200
|
|
|
|
|
|
|
|
|
|
|
2019-01-24 16:38:52 +00:00
|
|
|
@letter_branding_blueprint.route('', methods=['POST'])
|
|
|
|
|
def create_letter_brand():
|
|
|
|
|
data = request.get_json()
|
|
|
|
|
|
|
|
|
|
validate(data, post_letter_branding_schema)
|
|
|
|
|
|
|
|
|
|
letter_branding = LetterBranding(**data)
|
|
|
|
|
dao_create_letter_branding(letter_branding)
|
|
|
|
|
|
|
|
|
|
return jsonify(letter_branding.serialize()), 201
|
|
|
|
|
|
|
|
|
|
|
2019-01-24 17:39:48 +00:00
|
|
|
@letter_branding_blueprint.route('/<uuid:letter_branding_id>', methods=['POST'])
|
|
|
|
|
def update_letter_branding(letter_branding_id):
|
2019-01-24 16:38:52 +00:00
|
|
|
data = request.get_json()
|
|
|
|
|
|
|
|
|
|
validate(data, post_letter_branding_schema)
|
|
|
|
|
|
2019-01-24 17:39:48 +00:00
|
|
|
letter_branding = dao_update_letter_branding(letter_branding_id, **data)
|
2019-01-24 11:13:50 +00:00
|
|
|
|
2019-01-24 16:38:52 +00:00
|
|
|
return jsonify(letter_branding.serialize()), 201
|