All four http methods working now for user and service restful apis.

This commit is contained in:
Nicholas Staples
2016-01-11 17:19:06 +00:00
parent 49e98c21e7
commit 74547013ba
11 changed files with 114 additions and 53 deletions

View File

@@ -0,0 +1,6 @@
from sqlalchemy.exc import SQLAlchemyError
# Should I use SQLAlchemyError?
class DAOException(SQLAlchemyError):
pass

View File

@@ -1,24 +1,22 @@
import json
from datetime import datetime
from sqlalchemy.orm import load_only
from sqlalchemy.exc import SQLAlchemyError
from . import DAOException
from app import db
from app.models import Service
# Should I use SQLAlchemyError?
class DAOException(SQLAlchemyError):
pass
def create_model_service(service):
users_list = getattr(service, 'users', [])
def save_model_service(service, update_dict=None):
users_list = update_dict.get('users', []) if update_dict else getattr(service, 'users', [])
if not users_list:
error_msg = {'users': 'Missing data for required attribute'}
raise DAOException(json.dumps(error_msg))
db.session.add(service)
if update_dict:
del update_dict['id']
del update_dict['users']
db.session.query(Service).filter_by(id=service.id).update(update_dict)
else:
db.session.add(service)
db.session.commit()

View File

@@ -1,13 +1,17 @@
from datetime import datetime
from . import DAOException
from sqlalchemy.orm import load_only
from app import db
from app.models import User
def create_model_user(usr):
db.session.add(usr)
def save_model_user(usr, update_dict={}):
if update_dict:
del update_dict['id']
db.session.query(User).filter_by(id=usr.id).update(update_dict)
else:
db.session.add(usr)
db.session.commit()

View File

@@ -13,17 +13,6 @@ class UserSchema(ma.ModelSchema):
model = models.User
exclude = ("updated_at", "created_at", "user_to_service")
def make_object(self, data):
# TODO possibly override to handle instance creation
return super(UserSchema, self).make_object(data)
# def dump(self, obj, many=None, update_fields=True, **kwargs):
# retval = super(UserSchema, self).dump(
# obj, many=many, update_fields=update_fields, **kwargs)
# if not many and 'email_address' not in retval.data:
# retval.data['email_address'] = obj.email_address
# return retval
# TODO process users list, to return a list of user.id
# Should that list be restricted by the auth parsed??
@@ -32,10 +21,6 @@ class ServiceSchema(ma.ModelSchema):
model = models.Service
exclude = ("updated_at", "created_at")
def make_object(self, data):
# TODO possibly override to handle instance creation
return super(ServiceSchema, self).make_object(data)
user_schema = UserSchema()
users_schema = UserSchema(many=True)

View File

@@ -1,9 +1,10 @@
from flask import (jsonify, request)
from sqlalchemy.exc import DataError
from sqlalchemy.orm.exc import NoResultFound
from app.dao.services_dao import (create_model_service, get_model_services)
from app.dao.services_dao import (save_model_service, get_model_services)
from app.dao.users_dao import get_model_users
from .. import service
from app import db
from app.schemas import (services_schema, service_schema)
@@ -11,17 +12,29 @@ from app.schemas import (services_schema, service_schema)
@service.route('/', methods=['POST'])
def create_service():
# 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.
service, errors = service_schema.load(request.get_json())
# I believe service is already added to the session but just needs a
# db.session.commit
save_model_service(service)
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)
try:
service = get_model_services(service_id=service_id)
except DataError:
return jsonify(result="error", message="Invalid service id"), 400
except NoResultFound:
return jsonify(result="error", message="Service not found"), 404
# TODO there has got to be a better way to do the next three lines
update_service, errors = service_schema.load(request.get_json())
update_dict, errors = service_schema.dump(update_service)
# TODO FIX ME
# Remove update_service model which is added to db.session
db.session.rollback()
save_model_service(service, update_dict=update_dict)
return jsonify(data=service_schema.dump(service).data)
@@ -34,6 +47,6 @@ def get_service(service_id=None):
except DataError:
return jsonify(result="error", message="Invalid service id"), 400
except NoResultFound:
return jsonify(result="error", message="Service doesn't exist"), 404
result = services_schema.dump(services) if isinstance(services, list) else service_schema.dump(services)
return jsonify(data=result.data)
return jsonify(result="error", message="Service not found"), 404
data, errors = services_schema.dump(services) if isinstance(services, list) else service_schema.dump(services)
return jsonify(data=data)

View File

@@ -2,24 +2,37 @@ from flask import (jsonify, request)
from sqlalchemy.exc import DataError
from sqlalchemy.orm.exc import NoResultFound
from app.dao.services_dao import get_model_services
from app.dao.users_dao import (get_model_users, create_model_user)
from app.dao.users_dao import (get_model_users, save_model_user)
from app.schemas import (
user_schema, users_schema, service_schema, services_schema)
from .. import user
from app import db
# TODO auth to be added
@user.route('/', methods=['POST'])
def create_user():
user = user_schema.load(request.get_json()).data
create_model_user(user)
save_model_user(user)
return jsonify(data=user_schema.dump(user).data), 201
# TODO auth to be added
@user.route('/<int:user_id>', methods=['PUT'])
def update_user(user_id):
user = get_model_users(user_id=user_id)
try:
user = get_model_users(user_id=user_id)
except DataError:
return jsonify(result="error", message="Invalid user id"), 400
except NoResultFound:
return jsonify(result="error", message="User not found"), 404
# TODO there has got to be a better way to do the next three lines
update_user, errors = user_schema.load(request.get_json())
update_dict, errors = user_schema.dump(update_user)
# TODO FIX ME
# Remove update_service model which is added to db.session
db.session.rollback()
save_model_user(user, update_dict=update_dict)
return jsonify(data=user_schema.dump(user).data)