websoft9/appmanage/api/v1/routers/apps.py
2023-04-18 08:30:47 +08:00

220 lines
9.6 KiB
Python
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

from typing import Optional, List
from fastapi import APIRouter, status, Depends, Query, Request
from pydantic import BaseModel, Field
from starlette.responses import JSONResponse
import os, io, sys, platform, shutil, time, subprocess, json, datetime
from api.model.app import App
from api.model.response import Response
from api.service import manage
from api.utils import shell_execute, const
from api.utils.common_log import myLogger
from api.exception.command_exception import CommandException
router = APIRouter()
rd_s = "ResponseData: 各个接口的业务数据\n\n{\n\n"
rd_m = "  app_id应用ID\n\n}\n\n"
rd_e = "Error错误code和错误信息\n\n{\n\n" \
"  Code错误码,\n\n" \
"  Message错误信息,\n\n" \
"  Detail错误详情\n\n}"
rd_status = "  app_id应用ID\n\n" \
"  status应用运行状态,[installing(创建中)running(运行中)exited(停止)restarting(反复重启)failed(失败)]\n\n" \
"  StatusReason{\n\n" \
"    Code错误代码,\n\n" \
"    Message错误提示信息,\n\n" \
"    Detail错误真实信息\n\n  }\n\n}\n\n"
info = "  app_id应用ID,\n\n  name应用名,\n\n" \
"  customer_name自定义应用名,\n\n  trade_mark应用商标,\n\n" \
"  status应用运行状态,[installing(创建中)running(运行中)exited(停止)restarting(反复重启)failed(失败)]\n\n" \
"  StatusReason{\n\n" \
"    Code错误代码,\n\n" \
"    Message错误提示信息,\n\n" \
"    Detail错误真实信息\n\n  }\n\n" \
"  official_app是否为官方应用,\n\n" \
"  image_url图片路径,\n\n" \
"  running_info{\n\n" \
"    port应用端口,\n\n    compose_filedocker compose 文件路径,\n\n" \
"    url应用网址,\n\n    admin_url管理员网址,\n\n" \
"    user_name用户名,\n\n    password密码,\n\n" \
"    default_domain默认域名,\n\n    set_domain用户自定义域名\n\n  }\n\n"
rd = rd_s + rd_m + rd_e
rd_info = rd_s + info + rd_e
rd_status = rd_s + rd_status + rd_e
@router.api_route("/AppStatus", methods=["GET", "POST"], summary="获取指定APP的信息",
response_description=rd_status,
response_model=Response)
def AppStatus(request: Request,app_id: Optional[str] = Query(default=None, description="应用ID")):
try:
myLogger.info_logger("Receive request: /AppStatus")
get_headers(request)
ret = {}
ret['ResponseData'] = manage.get_app_status(app_id)
except CommandException as ce:
ret = {}
ret['ResponseData'] = None
ret['Error'] = manage.get_error_info(ce.code, ce.message, ce.detail)
except Exception as e:
ret = {}
ret['ResponseData'] = None
ret['Error'] = manage.get_error_info(const.ERROR_SERVER_SYSTEM, "system original error", str(e))
return JSONResponse(ret)
@router.api_route("/AppList", methods=["GET", "POST"], summary="获取所有APP的信息", response_description=rd_info,
response_model=Response)
def AppList(request: Request, app_id: Optional[str] = Query(default=None, description="应用ID")):
try:
myLogger.info_logger("Receive request: /AppList")
get_headers(request)
app_list = manage.get_my_app(app_id)
myLogger.info_logger(len(app_list))
response = JSONResponse({'ResponseData': app_list})
except CommandException as ce:
ret = {}
ret['ResponseData'] = None
ret['Error'] = manage.get_error_info(ce.code, ce.message, ce.detail)
response = JSONResponse(content=ret)
except Exception as e:
ret = {}
ret['ResponseData'] = None
ret['Error'] = manage.get_error_info(const.ERROR_SERVER_SYSTEM, "system original error", str(e))
response = JSONResponse(content=ret)
return response
@router.api_route("/AppInstall", methods=["GET", "POST"], summary="安装APP", response_description=rd,
response_model=Response)
def AppInstall(request: Request, app_name: Optional[str] = Query(default=None, description="应用名称"),
customer_app_name: Optional[str] = Query(default=None, description="用户自定义应用名称"),
app_version: Optional[str] = Query(default=None, description="应用版本")):
try:
myLogger.info_logger("Receive request: /AppInstall")
get_headers(request)
ret = manage.install_app(app_name, customer_app_name, app_version)
except CommandException as ce:
ret = {}
ret['ResponseData'] = {}
ret['ResponseData']['AppID'] = app_name + "_" + customer_name
ret['Error'] = manage.get_error_info(ce.code, ce.message, ce.detail)
myLogger.error_logger("Ready for return fail message")
except Exception as e:
myLogger.error_logger(str(e))
ret = {}
ret['ResponseData']['AppID'] = app_name + "_" + customer_name
ret['Error'] = manage.get_error_info(const.ERROR_SERVER_SYSTEM, "system original error", str(e))
myLogger.info_logger(ret)
return JSONResponse(content=ret)
@router.api_route("/AppStart", methods=["GET", "POST"], summary="启动APP", response_description=rd,
response_model=Response)
def AppStart(request: Request,app_id: Optional[str] = Query(default=None, description="应用ID")):
try:
myLogger.info_logger("Receive request: /AppStart")
get_headers(request)
ret = {}
ret['ResponseData'] = {}
manage.start_app(app_id)
ret['ResponseData']['AppID'] = app_id
except CommandException as ce:
ret = {}
ret['ResponseData'] = {}
ret['ResponseData']['AppID'] = app_id
ret['Error'] = manage.get_error_info(ce.code, ce.message, ce.detail)
except Exception as e:
ret = {}
ret['ResponseData'] = {}
ret['ResponseData']['AppID'] = app_id
ret['Error'] = manage.get_error_info(const.ERROR_SERVER_SYSTEM, "system original error", str(e))
return JSONResponse(content=ret)
@router.api_route("/AppStop", methods=["GET", "POST"], summary="停止APP", response_description=rd,
response_model=Response)
def AppStop(request: Request,app_id: Optional[str] = Query(default=None, description="应用ID")):
try:
myLogger.info_logger("Receive request: /AppStop")
get_headers(request)
ret = {}
ret['ResponseData'] = {}
manage.stop_app(app_id)
ret['ResponseData']['AppID'] = app_id
except CommandException as ce:
ret = {}
ret['ResponseData'] = {}
ret['ResponseData']['AppID'] = app_id
ret['Error'] = manage.get_error_info(ce.code, ce.message, ce.detail)
except Exception as e:
ret = {}
ret['ResponseData'] = {}
ret['ResponseData']['AppID'] = app_id
ret['Error'] = manage.get_error_info(const.ERROR_SERVER_SYSTEM, "system original error", str(e))
return JSONResponse(content=ret)
@router.api_route("/AppRestart", methods=["GET", "POST"], summary="重启APP", response_description=rd,
response_model=Response)
def AppRestart(request: Request,app_id: Optional[str] = Query(default=None, description="应用ID")):
try:
myLogger.info_logger("Receive request: /AppRestart")
get_headers(request)
ret = {}
ret['ResponseData'] = {}
manage.restart_app(app_id)
ret['ResponseData']['AppID'] = app_id
except CommandException as ce:
ret = {}
ret['ResponseData'] = {}
ret['ResponseData']['AppID'] = app_id
ret['Error'] = manage.get_error_info(ce.code, ce.message, ce.detail)
except Exception as e:
ret = {}
ret['ResponseData'] = {}
ret['ResponseData']['AppID'] = app_id
ret['Error'] = manage.get_error_info(const.ERROR_SERVER_SYSTEM, "system original error", str(e))
return JSONResponse(content=ret)
@router.api_route("/AppUninstall", methods=["GET", "POST"], summary="卸载APP", response_description=rd,
response_model=Response)
def AppUninstall(request: Request, app_id: Optional[str] = Query(default=None, description="应用ID")):
try:
myLogger.info_logger("Receive request: /AppUninstall")
get_headers(request)
ret = {}
ret['ResponseData'] = {}
manage.uninstall_app(app_id)
ret['ResponseData']['AppID'] = app_id
except CommandException as ce:
ret = {}
ret['ResponseData'] = {}
ret['ResponseData']['AppID'] = app_id
ret['Error'] = manage.get_error_info(ce.code, ce.message, ce.detail)
except Exception as e:
ret = {}
ret['ResponseData'] = {}
ret['ResponseData']['AppID'] = app_id
ret['Error'] = manage.get_error_info(const.ERROR_SERVER_SYSTEM, "system original error", str(e))
return JSONResponse(content=ret)
def get_headers(request):
headers = request.headers
try:
version = headers.get('Version')
language = headers.get('Language')
myLogger.info_logger("Version: " + version + ", Language: " + language)
except:
pass