feat(Users): Implemented Kratos CRUD
This commit is contained in:
parent
a208b5f441
commit
a81d14b4f8
10 changed files with 99 additions and 48 deletions
3
areas/__init__.py
Normal file
3
areas/__init__.py
Normal file
|
|
@ -0,0 +1,3 @@
|
|||
from flask import Blueprint
|
||||
|
||||
api_v1 = Blueprint('api_v1', __name__, url_prefix='/api/v1')
|
||||
1
areas/apps/__init__.py
Normal file
1
areas/apps/__init__.py
Normal file
|
|
@ -0,0 +1 @@
|
|||
from .apps import *
|
||||
66
areas/apps/apps.py
Normal file
66
areas/apps/apps.py
Normal file
|
|
@ -0,0 +1,66 @@
|
|||
from flask import jsonify
|
||||
from flask_jwt_extended import jwt_required
|
||||
from flask_cors import cross_origin
|
||||
|
||||
from areas import api_v1
|
||||
|
||||
CONFIG_DATA = [
|
||||
{
|
||||
"id": "values.yml",
|
||||
"description": "Some user friendly description",
|
||||
"raw": "cronjob:\n # Set curl to accept insecure connections when acme staging is used\n curlInsecure: false",
|
||||
"fields": [
|
||||
{"name": "cronjob", "type": "string", "value": ""},
|
||||
{"name": "curlInsecure", "type": "boolean", "value": "false"}
|
||||
]
|
||||
}
|
||||
]
|
||||
|
||||
APPS_DATA = [
|
||||
{"id": 1, "name": "Nextcloud", "enabled": True, "status": "ON for everyone"},
|
||||
{"id": 2, "name": "Rocketchat", "enabled": True, "status": "ON for everyone"},
|
||||
{"id": 3, "name": "Wordpress", "enabled": False, "status": "ON for everyone"}
|
||||
]
|
||||
|
||||
APP_DATA = {"id": 1, "name": "Nextcloud", "selected": True, "status": "ON for everyone", "config": CONFIG_DATA},
|
||||
|
||||
|
||||
@api_v1.route('/apps', methods=['GET'])
|
||||
@jwt_required()
|
||||
@cross_origin()
|
||||
def get_apps():
|
||||
return jsonify(APPS_DATA)
|
||||
|
||||
|
||||
@api_v1.route('/apps/<string:slug>', methods=['GET'])
|
||||
@jwt_required()
|
||||
def get_app(slug):
|
||||
return jsonify(APPS_DATA[0])
|
||||
|
||||
|
||||
@api_v1.route('/apps', methods=['POST'])
|
||||
@jwt_required()
|
||||
@cross_origin()
|
||||
def post_app():
|
||||
return jsonify(APPS_DATA), 201
|
||||
|
||||
|
||||
@api_v1.route('/apps/<string:slug>', methods=['PUT'])
|
||||
@jwt_required()
|
||||
@cross_origin()
|
||||
def put_app(slug):
|
||||
return jsonify(APPS_DATA)
|
||||
|
||||
|
||||
@api_v1.route('/apps/<string:slug>/config', methods=['GET'])
|
||||
@jwt_required()
|
||||
@cross_origin()
|
||||
def get_config(slug):
|
||||
return jsonify(CONFIG_DATA)
|
||||
|
||||
|
||||
@api_v1.route('/apps/<string:slug>/config', methods=['DELETE'])
|
||||
@jwt_required()
|
||||
@cross_origin()
|
||||
def delete_config(slug):
|
||||
return jsonify(CONFIG_DATA)
|
||||
1
areas/auth/__init__.py
Normal file
1
areas/auth/__init__.py
Normal file
|
|
@ -0,0 +1 @@
|
|||
from .auth import *
|
||||
21
areas/auth/auth.py
Normal file
21
areas/auth/auth.py
Normal file
|
|
@ -0,0 +1,21 @@
|
|||
from flask import request, jsonify
|
||||
from flask_jwt_extended import create_access_token
|
||||
from flask_cors import cross_origin
|
||||
|
||||
from areas import api_v1
|
||||
|
||||
USERNAME = 'admin'
|
||||
PASSWORD = 'admin'
|
||||
|
||||
|
||||
@api_v1.route('/login', methods=['POST'])
|
||||
@cross_origin()
|
||||
def login():
|
||||
username = request.json.get('username')
|
||||
password = request.json.get('password')
|
||||
|
||||
if username != USERNAME or password != PASSWORD:
|
||||
return jsonify({'errorMessage': 'Invalid username or password'}), 401
|
||||
|
||||
access_token = create_access_token(identity=username)
|
||||
return jsonify({'username': USERNAME, 'access_token': access_token})
|
||||
1
areas/users/__init__.py
Normal file
1
areas/users/__init__.py
Normal file
|
|
@ -0,0 +1 @@
|
|||
from .users import *
|
||||
57
areas/users/users.py
Normal file
57
areas/users/users.py
Normal file
|
|
@ -0,0 +1,57 @@
|
|||
from flask import jsonify, request
|
||||
from flask_jwt_extended import jwt_required
|
||||
from flask_cors import cross_origin
|
||||
|
||||
from areas import api_v1
|
||||
from helpers.kratos_api import KratosApi
|
||||
|
||||
|
||||
@api_v1.route('/users', methods=['GET'])
|
||||
@jwt_required()
|
||||
@cross_origin()
|
||||
def get_users():
|
||||
res = KratosApi.get('/identities')
|
||||
return jsonify(res.json())
|
||||
|
||||
@api_v1.route('/users/<string:id>', methods=['GET'])
|
||||
@jwt_required()
|
||||
@cross_origin()
|
||||
def get_user(id):
|
||||
res = KratosApi.get('/identities/{}'.format(id))
|
||||
return jsonify(res.json())
|
||||
|
||||
|
||||
@api_v1.route('/users', methods=['POST'])
|
||||
@jwt_required()
|
||||
@cross_origin()
|
||||
def post_user():
|
||||
data = request.get_json()
|
||||
kratos_data = {
|
||||
"schema_id": "default",
|
||||
"traits": data
|
||||
}
|
||||
res = KratosApi.post('/identities', kratos_data)
|
||||
return jsonify(res.json()), res.status_code
|
||||
|
||||
|
||||
@api_v1.route('/users/<string:id>', methods=['PUT'])
|
||||
@jwt_required()
|
||||
@cross_origin()
|
||||
def put_user(id):
|
||||
data = request.get_json()
|
||||
kratos_data = {
|
||||
"schema_id": "default",
|
||||
"traits": data
|
||||
}
|
||||
res = KratosApi.put('/identities/{}'.format(id), kratos_data)
|
||||
return jsonify(res.json()), res.status_code
|
||||
|
||||
|
||||
@api_v1.route('/users/<string:id>', methods=['DELETE'])
|
||||
@jwt_required()
|
||||
@cross_origin()
|
||||
def delete_user(id):
|
||||
res = KratosApi.delete('/identities/{}'.format(id))
|
||||
if (res.status_code == 204):
|
||||
return jsonify(), res.status_code
|
||||
return jsonify(res.json()), res.status_code
|
||||
Reference in a new issue