mirror of
https://github.com/GSA/notifications-api.git
synced 2026-02-03 01:41:05 -05:00
Service and User API added, working with tests. Still need to polish the edges and add more tests.
This commit is contained in:
@@ -1,8 +1,8 @@
|
||||
from flask import jsonify
|
||||
from flask import (jsonify, request)
|
||||
from sqlalchemy.exc import DataError
|
||||
from sqlalchemy.orm.exc import NoResultFound
|
||||
from app.dao.services_dao import (create_service, get_services)
|
||||
from app.dao.users_dao import (get_users)
|
||||
from app.dao.services_dao import (create_model_service, get_model_services)
|
||||
from app.dao.users_dao import get_model_users
|
||||
from .. import service
|
||||
from app.schemas import (services_schema, service_schema)
|
||||
|
||||
@@ -10,16 +10,19 @@ from app.schemas import (services_schema, service_schema)
|
||||
# TODO auth to be added.
|
||||
@service.route('/', methods=['POST'])
|
||||
def create_service():
|
||||
# Be lenient with args passed in
|
||||
parsed_data = service_schema(request.args)
|
||||
return jsonify(result="created"), 201
|
||||
# TODO what exceptions get passed from schema parsing?
|
||||
service = service_schema.load(request.get_json()).data
|
||||
print(service_schema.dump(service).data)
|
||||
# Some magic here, it automatically creates the service object.
|
||||
# Cool but need to understand how this works.
|
||||
return jsonify(data=service_schema.dump(service).data), 201
|
||||
|
||||
|
||||
# TODO auth to be added
|
||||
@service.route('/<int:service_id>', methods=['PUT'])
|
||||
def update_service(service_id):
|
||||
service = get_services(service_id=service_id)
|
||||
return jsonify(data=service_schema.dump(service))
|
||||
return jsonify(data=service_schema.dump(service).data)
|
||||
|
||||
|
||||
# TODO auth to be added.
|
||||
@@ -27,7 +30,7 @@ def update_service(service_id):
|
||||
@service.route('/', methods=['GET'])
|
||||
def get_service(service_id=None):
|
||||
try:
|
||||
services = get_services(service_id=service_id)
|
||||
services = get_model_services(service_id=service_id)
|
||||
except DataError:
|
||||
return jsonify(result="error", message="Invalid service id"), 400
|
||||
except NoResultFound:
|
||||
|
||||
Reference in New Issue
Block a user