aicheckv2-api/main.py

130 lines
4.3 KiB
Python
Raw Normal View History

2025-04-11 08:54:28 +08:00
# -*- coding: utf-8 -*-
# @version : 1.0
# @Create Time : 2021/10/19 15:47
# @File : main.py
# @IDE : PyCharm
# @desc : 主程序入口
"""
FastApi 更新文档https://github.com/tiangolo/fastapi/releases
FastApi Githubhttps://github.com/tiangolo/fastapi
Typer 官方文档https://typer.tiangolo.com/
"""
from fastapi import FastAPI
import uvicorn
from starlette.middleware.cors import CORSMiddleware
from application import settings
from application import urls
from starlette.staticfiles import StaticFiles # 依赖安装pip install aiofiles
from core.docs import custom_api_docs
from core.exception import register_exception
import typer
from scripts.initialize.initialize import InitializeData, Environment
import asyncio
from scripts.create_app.main import CreateApp
from core.event import lifespan
from utils.tools import import_modules
shell_app = typer.Typer()
def create_app():
"""
启动项目
docs_url配置交互文档的路由地址如果禁用则为None默认为 /docs
redoc_url 配置 Redoc 文档的路由地址如果禁用则为None默认为 /redoc
openapi_url配置接口文件json数据文件路由地址如果禁用则为None默认为/openapi.json
"""
app = FastAPI(
title="aicheckv2-api",
description="aicheckv2.1版本在之前v2.0的版本上找一个框架对项目,用户和部门进行统一管理",
version=settings.VERSION,
lifespan=lifespan,
docs_url=None,
redoc_url=None
)
import_modules(settings.MIDDLEWARES, "中间件", app=app)
# 全局异常捕捉处理
register_exception(app)
# 跨域解决
if settings.CORS_ORIGIN_ENABLE:
app.add_middleware(
CORSMiddleware,
allow_origins=settings.ALLOW_ORIGINS,
allow_credentials=settings.ALLOW_CREDENTIALS,
allow_methods=settings.ALLOW_METHODS,
allow_headers=settings.ALLOW_HEADERS
)
# 挂在静态目录
if settings.STATIC_ENABLE:
app.mount(settings.STATIC_URL, app=StaticFiles(directory=settings.STATIC_ROOT))
# 引入应用中的路由
for url in urls.urlpatterns:
app.include_router(url["ApiRouter"], prefix=url["prefix"], tags=url["tags"])
# 配置接口文档静态资源
custom_api_docs(app)
return app
@shell_app.command()
def run(
host: str = typer.Option(default='0.0.0.0', help='监听主机IP默认开放给本网络所有主机'),
port: int = typer.Option(default=9000, help='监听端口')
):
"""
启动项目
factory: 在使用 uvicorn.run() 启动 ASGI 应用程序时可以通过设置 factory 参数来指定应用程序工厂
应用程序工厂是一个返回 ASGI 应用程序实例的可调用对象它可以在启动时动态创建应用程序实例
"""
uvicorn.run(app='main:create_app', host=host, port=port, lifespan="on", factory=True)
@shell_app.command()
def init(env: Environment = Environment.pro):
"""
初始化数据
在执行前一定要确认要操作的环境与application/settings.DEBUG 设置的环境是一致的
不然会导致创建表和生成数据不在一个数据库中
比如要初始化开发环境那么env参数应该为 dev并且 application/settings.DEBUG 应该 = True
比如要初始化生产环境那么env参数应该为 pro并且 application/settings.DEBUG 应该 = False
:param env: 数据库环境
"""
print("开始初始化数据")
data = InitializeData()
asyncio.run(data.run(env))
@shell_app.command()
def migrate(env: Environment = Environment.pro):
"""
将模型迁移到数据库更新数据库表结构
:param env: 数据库环境
"""
print("开始更新数据库表")
InitializeData.migrate_model(env)
@shell_app.command()
def init_app(path: str):
"""
自动创建初始化 APP 结构
命令例子python main.py init-app vadmin/test
:param path: app 路径根目录为apps填写apps后面路径即可例子vadmin/auth
"""
print(f"开始创建并初始化 {path} APP")
app = CreateApp(path)
app.run()
if __name__ == '__main__':
shell_app()