dashboard/areas/apps/apps.py

65 lines
1.5 KiB
Python
Raw Normal View History

2022-10-03 06:47:25 +02:00
from flask import jsonify
2021-09-27 12:03:35 +02:00
from flask_jwt_extended import jwt_required
from flask_cors import cross_origin
2022-09-23 19:04:29 +02:00
from sqlalchemy import func
from config import *
from .apps_service import AppsService
from database import db
2021-10-28 16:09:10 +02:00
from areas import api_v1
2021-09-27 12:03:35 +02:00
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"}
]
}
]
@api_v1.route('/apps', methods=['GET'])
@jwt_required()
@cross_origin()
def get_apps():
2022-09-23 19:04:29 +02:00
apps = AppsService.get_all_apps()
return jsonify(apps)
2021-09-27 12:03:35 +02:00
@api_v1.route('/apps/<string:slug>', methods=['GET'])
2022-09-28 10:02:51 +02:00
@jwt_required()
2021-09-27 12:03:35 +02:00
def get_app(slug):
2022-09-23 19:04:29 +02:00
app = AppsService.get_app(slug)
return jsonify(app)
2021-09-27 12:03:35 +02:00
@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)