将ProjectConfig加入Architecture
This commit is contained in:
@@ -1,6 +1,10 @@
|
||||
from ..Convention.Runtime.Config import *
|
||||
from ..Convention.Runtime.Architecture import Architecture
|
||||
from ..Convention.Runtime.GlobalConfig import ProjectConfig, ConsoleFrontColor
|
||||
from ..CoreModules.flags import set_internal_verbose, get_internal_debug
|
||||
|
||||
Architecture.Register(ProjectConfig, ProjectConfig(), lambda: None)
|
||||
|
||||
from ..CoreModules.flags import set_internal_verbose
|
||||
from .web import app
|
||||
from argparse import ArgumentParser
|
||||
from typing import *
|
||||
@@ -11,7 +15,7 @@ except ImportError as ex:
|
||||
ImportingThrow(ex, "Internal", ["uvicorn"])
|
||||
|
||||
def main() -> int:
|
||||
config = ProjectConfig()
|
||||
config: ProjectConfig = Architecture.Get(ProjectConfig)
|
||||
|
||||
parser = ArgumentParser()
|
||||
parser.add_argument("--host", type=str, default=config.FindItem("host", "0.0.0.0"))
|
||||
|
||||
@@ -8,7 +8,7 @@ from ..CoreRouters import callback, health
|
||||
from ..Convention.Runtime.GlobalConfig import *
|
||||
from ..Convention.Runtime.Architecture import Architecture
|
||||
|
||||
config = ProjectConfig()
|
||||
logger: ProjectConfig = Architecture.Get(ProjectConfig)
|
||||
APP_CONFIG = {
|
||||
"docs_url": "/docs",
|
||||
}
|
||||
@@ -17,30 +17,31 @@ APP_CONFIG = {
|
||||
async def lifespan(app: FastAPI):
|
||||
"""应用生命周期管理"""
|
||||
# 启动
|
||||
config.Log("Info", "应用启动中...")
|
||||
logger.Log("Info", "应用启动中...")
|
||||
|
||||
# 初始化数据
|
||||
config.Log("Info", "初始化数据...")
|
||||
logger.Log("Info", "初始化数据...")
|
||||
|
||||
# 启动后台清理
|
||||
config.Log("Info", "启动后台清理...")
|
||||
logger.Log("Info", "启动后台清理...")
|
||||
|
||||
yield
|
||||
|
||||
# 关闭
|
||||
try:
|
||||
config.Log("Info", "关闭应用...")
|
||||
logger.Log("Info", "关闭应用...")
|
||||
# await cleanup_task
|
||||
except asyncio.CancelledError:
|
||||
pass
|
||||
finally:
|
||||
config.Log("Info", "关闭应用完成...")
|
||||
logger.Log("Info", "关闭应用完成...")
|
||||
# db.close()
|
||||
|
||||
def generate_app(kwargs: dict) -> FastAPI:
|
||||
'''
|
||||
生成FastAPI应用
|
||||
'''
|
||||
config: ProjectConfig = Architecture.Get(ProjectConfig)
|
||||
kwargs.update(**APP_CONFIG)
|
||||
app = FastAPI(**kwargs, lifespan=lifespan)
|
||||
|
||||
@@ -59,11 +60,12 @@ def generate_app(kwargs: dict) -> FastAPI:
|
||||
|
||||
return app
|
||||
|
||||
app: FastAPI = generate_app(config.FindItem("app_config", {}))
|
||||
app: FastAPI = generate_app(logger.FindItem("app_config", {}))
|
||||
|
||||
@app.get("/")
|
||||
async def root():
|
||||
"""根路径"""
|
||||
config: ProjectConfig = Architecture.Get(ProjectConfig)
|
||||
app_name = config.FindItem("app_name", "Application")
|
||||
app_version = config.FindItem("app_version", "0.0.0")
|
||||
config.SaveProperties()
|
||||
@@ -76,11 +78,13 @@ async def root():
|
||||
@app.exception_handler(Exception)
|
||||
async def global_exception_handler(request, exc):
|
||||
"""全局异常处理"""
|
||||
config.Log("Error", f"未捕获的异常: {exc}\n{format_traceback_info()}")
|
||||
logger.Log("Error", f"未捕获的异常: {exc}\n{format_traceback_info()}")
|
||||
return JSONResponse(
|
||||
status_code=500,
|
||||
content={"error": "Internal Server Error", "detail": str(exc)}
|
||||
)
|
||||
|
||||
logger.SaveProperties()
|
||||
|
||||
# 除了从本模块导出的app使用API实例外, 还可以从Architecture.Get(FastAPI)获取
|
||||
__all__ = ["app"]
|
||||
Reference in New Issue
Block a user