def get_total_users() -> BaseResponse: """ tags: - userAPI summary: Get all system users responses: '200': description: OK '405': description: Wrong method schema: $ref: '#/definitions/Error' '406': description: >- Accept header is provided but 'application/json' type is not present in header schema: $ref: '#/definitions/Error' '415': description: >- Unsupported media type. 'Content-Type' header is provided and it is not the 'application/json' schema: $ref: '#/definitions/Error' """ validate_request( # validation of headers and method request.headers, request.method, SUPPORTED_METHODS['/get_total_users']) if request.method == 'GET': try: # Get all system users users_list = process_list_users() return json_response(users_list) except errors.InternalServerError as e: e.message_json = 'Error while executing find_cursor.' return json_error_response(e)
def count_users() -> Union[int, None, Response]: """Implements GET logic of '/count_users' endpoint""" validate_request(request.headers, request.method, SUPPORTED_METHODS['/count_users']) if request.method == 'GET': try: # Count users result = count_tot_users() return json_response(result) except errors.InternalServerError as e: e.message_json = 'Error while executing count' return json_error_response(e)
def drop_collection() -> Union[BaseResponse, None]: """Drop collection endpoint.""" validate_request( # do the validation request.headers, request.method, SUPPORTED_METHODS['/drop_collection']) if request.method == 'POST': try: result = make_drop() return json_response(result, status=202) except errors.ExternalResource as e: e.message_json = 'External resource error ' \ 'when dropping collection.' log_exception(e) return json_error_response(e) except errors.InternalServerError as e: e.message_json = 'Error while dropping collection.' log_exception(e) return json_error_response(e)
def by_uuid(user_uuid: str) -> Union[Response, None]: """ tags: - userAPI summary: Get's a single user record description: Get single user record by given user_uuid parameters: - name: user_uuid in: path description: UUID of the user to get required: true type: string responses: '200': description: OK '400': description: Validation error schema: $ref: '#/definitions/Error' '404': description: User not found schema: $ref: '#/definitions/Error' '405': description: Wrong method schema: $ref: '#/definitions/Error' '406': description: >- Accept header is provided but 'application/json' type is not present in header schema: $ref: '#/definitions/Error' '415': description: >- Unsupported media type. 'Content-Type' header is provided and it is not the 'application/json' schema: $ref: '#/definitions/Error' """ validate_request(request.headers, request.method, SUPPORTED_METHODS['/get_user_by_uuid']) try: # Validate the UUID parameter validate_user_uuid(user_uuid) except errors.BadRequestQuery as e: e.message_json = f'Wrong user UUID: {user_uuid}' log_exception(e) return json_error_response(e) if request.method == 'GET': try: user = read_by_uuid(user_uuid) return json_response(user) except errors.UserNotFound as e: e.message_json = f'User with this ' \ f'{user_uuid} was not found.' log_exception(e) return json_error_response(e) except errors.InternalServerError as e: log_exception(e) return json_error_response(e)
def update_user(user_uuid: str) -> Union[BaseResponse, None]: """ tags: - userAPI summary: Updates an existing user parameters: - name: user_uuid in: path description: UUID of user to update required: true type: integer - name: body in: body description: User object to update required: true schema: $ref: '#/definitions/User' responses: '200': description: OK '400': description: Validation error schema: $ref: '#/definitions/Error' '404': description: User not found schema: $ref: '#/definitions/Error' '405': description: Wrong method schema: $ref: '#/definitions/Error' '406': description: >- Accept header is provided but 'application/json' type is not present in header schema: $ref: '#/definitions/Error' '415': description: >- Unsupported media type. 'Content-Type' header is provided and it is not the 'application/json' schema: $ref: '#/definitions/Error' """ validate_request( # do the validation request.headers, request.method, SUPPORTED_METHODS['/update_user']) try: # Validate the UUID parameter validate_user_uuid(user_uuid) except errors.BadRequestQuery as e: e.message_json = f'Wrong user UUID: {user_uuid}' log_exception(e) return json_error_response(e) if request.method == 'PUT': # Request new user try: new_user = request.json except Exception as e: log_exception(e) return json_error_response(errors.BadRequestBody()) try: # Validate JSON schema keys_to_digest, user_obj_spec = get_spec_digest() validate_json_object(new_user, user_obj_spec) except errors.BadRequestBody as e: log_exception(e) return json_error_response(e) try: # Update user updated_user = process_update_user(user_uuid, new_user, keys_to_digest) return json_response(updated_user) except errors.InternalServerError as e: log_exception(e) return json_error_response(e)
def post_users() -> Union[BaseResponse, None]: """ tags: - userAPI summary: Adds users to User db. Upload as many as you want. description: 'Add as many users to User db, as want.' parameters: - name: body in: body description: List of users to post required: true schema: $ref: '#/definitions/Users' responses: '200': description: OK '400': description: Validation error schema: $ref: '#/definitions/Error' '404': description: User not found schema: $ref: '#/definitions/Error' '405': description: Wrong method schema: $ref: '#/definitions/Error' '406': description: >- Accept header is provided but 'application/json' type is not present in header schema: $ref: '#/definitions/Error' '415': description: >- Unsupported media type. 'Content-Type' header is provided and it is not the 'application/json' schema: $ref: '#/definitions/Error' """ validate_request( # do the validation request.headers, request.method, SUPPORTED_METHODS['/post_users']) if request.method == 'POST': try: # Load JSON object users_to_create = request.json except Exception as e: log_exception(e) return json_error_response(errors.BadRequestBody()) try: # Validate JSON schema keys_to_digest, user_obj_spec = get_spec_digest() [ validate_json_object(user, user_obj_spec) for user in users_to_create ] except errors.BadRequestBody as e: log_exception(e) return json_error_response(e) try: # Post users new, res = process_post_users(users_to_create, keys_to_digest) status = 201 if new else 200 return json_response(res, status=status) except errors.InternalServerError as e: log_exception(e) return json_error_response(e)
def post_user() -> Optional[BaseResponse]: """ tags: - userAPI summary: Adds a single user record parameters: - in: body name: body description: User object required: true schema: $ref: '#/definitions/User' responses: '200': description: OK '400': description: Validation error schema: $ref: '#/definitions/Error' '404': description: User not found schema: $ref: '#/definitions/Error' '405': description: Wrong method schema: $ref: '#/definitions/Error' '406': description: >- Accept header is provided but 'application/json' type is not present in header schema: $ref: '#/definitions/Error' '415': description: >- Unsupported media type. 'Content-Type' header is provided and it is not the 'application/json' schema: $ref: '#/definitions/Error' """ validate_request( # do the validation request.headers, request.method, SUPPORTED_METHODS['/post_user']) if request.method == 'POST': try: user_to_create = request.json except Exception as e: log_exception(e) return json_error_response(errors.BadRequestBody()) try: # Validate JSON schema keys_to_digest, user_obj_spec = get_spec_digest() validate_json_object(user_to_create, user_obj_spec) except errors.BadRequestBody as e: log_exception(e) return json_error_response(e) try: # Process post user new, result = process_post_user(user_to_create, keys_to_digest) status = 201 if new else 200 return json_response(result, status=status) except errors.InternalServerError as e: log_exception(e) return json_error_response(e)