2016-05-10 09:04:22 +01:00
|
|
|
from flask import Blueprint, jsonify, request
|
|
|
|
|
|
|
|
|
|
from app.dao.provider_details_dao import (
|
2019-05-02 09:26:49 +01:00
|
|
|
dao_get_provider_stats,
|
2021-03-10 13:55:06 +00:00
|
|
|
dao_get_provider_versions,
|
|
|
|
|
dao_update_provider_details,
|
|
|
|
|
get_provider_details_by_id,
|
2016-05-10 09:04:22 +01:00
|
|
|
)
|
2017-03-02 18:10:33 +00:00
|
|
|
from app.dao.users_dao import get_user_by_id
|
2021-03-10 13:55:06 +00:00
|
|
|
from app.errors import InvalidRequest, register_errors
|
|
|
|
|
from app.schemas import provider_details_history_schema, provider_details_schema
|
2016-06-14 15:07:23 +01:00
|
|
|
|
2016-05-10 09:04:22 +01:00
|
|
|
provider_details = Blueprint('provider_details', __name__)
|
2016-06-14 15:07:23 +01:00
|
|
|
register_errors(provider_details)
|
2016-05-10 09:04:22 +01:00
|
|
|
|
|
|
|
|
|
|
|
|
|
@provider_details.route('', methods=['GET'])
|
|
|
|
|
def get_providers():
|
2019-05-02 09:26:49 +01:00
|
|
|
data = dao_get_provider_stats()
|
|
|
|
|
|
|
|
|
|
provider_details = [
|
|
|
|
|
{'id': row.id,
|
|
|
|
|
'display_name': row.display_name,
|
|
|
|
|
'identifier': row.identifier,
|
|
|
|
|
'priority': row.priority,
|
|
|
|
|
'notification_type': row.notification_type,
|
|
|
|
|
'active': row.active,
|
|
|
|
|
'updated_at': row.updated_at,
|
|
|
|
|
'supports_international': row.supports_international,
|
|
|
|
|
'created_by_name': row.created_by_name,
|
|
|
|
|
'current_month_billable_sms': row.current_month_billable_sms}
|
|
|
|
|
for row in data
|
|
|
|
|
]
|
|
|
|
|
|
|
|
|
|
return jsonify(provider_details=provider_details)
|
2016-05-10 09:04:22 +01:00
|
|
|
|
|
|
|
|
|
2016-05-10 15:18:41 +01:00
|
|
|
@provider_details.route('/<uuid:provider_details_id>', methods=['GET'])
|
|
|
|
|
def get_provider_by_id(provider_details_id):
|
2022-05-06 15:52:44 +01:00
|
|
|
data = provider_details_schema.dump(get_provider_details_by_id(provider_details_id))
|
2016-05-10 15:18:41 +01:00
|
|
|
return jsonify(provider_details=data)
|
|
|
|
|
|
|
|
|
|
|
2017-03-02 18:10:33 +00:00
|
|
|
@provider_details.route('/<uuid:provider_details_id>/versions', methods=['GET'])
|
|
|
|
|
def get_provider_versions(provider_details_id):
|
|
|
|
|
versions = dao_get_provider_versions(provider_details_id)
|
|
|
|
|
data = provider_details_history_schema.dump(
|
|
|
|
|
versions,
|
|
|
|
|
many=True
|
2022-05-06 15:52:44 +01:00
|
|
|
)
|
2017-03-02 18:10:33 +00:00
|
|
|
return jsonify(data=data)
|
|
|
|
|
|
|
|
|
|
|
2016-05-10 09:04:22 +01:00
|
|
|
@provider_details.route('/<uuid:provider_details_id>', methods=['POST'])
|
|
|
|
|
def update_provider_details(provider_details_id):
|
2017-03-02 18:10:33 +00:00
|
|
|
valid_keys = {'priority', 'created_by', 'active'}
|
2017-03-08 09:49:47 +00:00
|
|
|
req_json = request.get_json()
|
2016-05-10 09:04:22 +01:00
|
|
|
|
2017-03-08 09:49:47 +00:00
|
|
|
invalid_keys = req_json.keys() - valid_keys
|
2016-12-19 16:53:23 +00:00
|
|
|
if invalid_keys:
|
2016-06-14 15:07:23 +01:00
|
|
|
message = "Not permitted to be updated"
|
2016-12-19 16:53:23 +00:00
|
|
|
errors = {key: [message] for key in invalid_keys}
|
2016-06-14 15:07:23 +01:00
|
|
|
raise InvalidRequest(errors, status_code=400)
|
2016-05-10 15:18:41 +01:00
|
|
|
|
2017-03-02 18:10:33 +00:00
|
|
|
provider = get_provider_details_by_id(provider_details_id)
|
|
|
|
|
|
|
|
|
|
# Handle created_by differently due to how history entry is created
|
|
|
|
|
if 'created_by' in req_json:
|
|
|
|
|
user = get_user_by_id(req_json['created_by'])
|
|
|
|
|
provider.created_by_id = user.id
|
|
|
|
|
req_json.pop('created_by')
|
|
|
|
|
|
|
|
|
|
for key in req_json:
|
|
|
|
|
setattr(provider, key, req_json[key])
|
|
|
|
|
dao_update_provider_details(provider)
|
|
|
|
|
|
2022-05-06 15:52:44 +01:00
|
|
|
return jsonify(provider_details=provider_details_schema.dump(provider)), 200
|