dashboard/areas/users/users.py

61 lines
1.4 KiB
Python
Raw Normal View History

2021-10-28 16:09:10 +02:00
from flask import jsonify, request
from flask_jwt_extended import jwt_required
from flask_cors import cross_origin
from flask_expects_json import expects_json
2021-10-28 16:09:10 +02:00
from areas import api_v1
from helpers import KratosApi
from helpers.auth_guard import admin_required
from .validation import schema
from .user_service import UserService
2021-10-28 16:09:10 +02:00
@api_v1.route("/users", methods=["GET"])
2021-10-28 16:09:10 +02:00
@jwt_required()
@cross_origin()
@admin_required()
2021-10-28 16:09:10 +02:00
def get_users():
res = UserService.get_users()
return jsonify(res)
2021-10-28 16:09:10 +02:00
@api_v1.route("/users/<string:id>", methods=["GET"])
2021-10-28 16:09:10 +02:00
@jwt_required()
@cross_origin()
def get_user(id):
res = UserService.get_user(id)
return jsonify(res)
2021-10-28 16:09:10 +02:00
@api_v1.route("/users", methods=["POST"])
2021-10-28 16:09:10 +02:00
@jwt_required()
@cross_origin()
@expects_json(schema)
2021-10-28 16:09:10 +02:00
def post_user():
data = request.get_json()
res = UserService.post_user(data)
return jsonify(res)
2021-10-28 16:09:10 +02:00
@api_v1.route("/users/<string:id>", methods=["PUT"])
2021-10-28 16:09:10 +02:00
@jwt_required()
@cross_origin()
@expects_json(schema)
2021-10-28 16:09:10 +02:00
def put_user(id):
data = request.get_json()
res = UserService.put_user(id, data)
return jsonify(res)
2021-10-28 16:09:10 +02:00
@api_v1.route("/users/<string:id>", methods=["DELETE"])
2021-10-28 16:09:10 +02:00
@jwt_required()
@cross_origin()
@admin_required()
2021-10-28 16:09:10 +02:00
def delete_user(id):
2022-05-19 19:01:26 +02:00
res = KratosApi.delete("/identities/{}".format(id))
if res.status_code == 204:
UserService.delete_user(id)
return jsonify(), res.status_code
return jsonify(res.json()), res.status_code