204 lines
8.9 KiB
Python
204 lines
8.9 KiB
Python
# 文件路径: inventory-backend/app/__init__.py
|
|
|
|
from flask import Flask
|
|
from config import Config
|
|
from app.extensions import db, migrate, cors, jwt
|
|
import os
|
|
|
|
|
|
def create_app():
|
|
app = Flask(__name__)
|
|
app.config.from_object(Config)
|
|
|
|
# =========================================================
|
|
# 1. 初始化插件
|
|
# =========================================================
|
|
db.init_app(app)
|
|
migrate.init_app(app, db)
|
|
jwt.init_app(app) # 初始化 JWT
|
|
|
|
# 允许所有 /api/ 开头的请求跨域,支持 credentials
|
|
cors.init_app(app, resources={r"/*": {"origins": "*"}}, supports_credentials=True)
|
|
|
|
# =========================================================
|
|
# 2. 注册蓝图 (Blueprints)
|
|
# ---------------------------------------------------------
|
|
# 注意:为了解决前端请求不带 /v1 导致的 404 错误,
|
|
# 下面的模块都采用了 "双重注册" 策略:
|
|
# 1. 标准地址: /api/v1/...
|
|
# 2. 兼容地址: /api/... (name 参数必须不同)
|
|
# =========================================================
|
|
|
|
# -----------------------------------------------------
|
|
# 2.0 注册权限与认证模块 (Auth)
|
|
# -----------------------------------------------------
|
|
try:
|
|
from app.api.v1.auth import auth_bp
|
|
# 标准
|
|
app.register_blueprint(auth_bp, url_prefix='/api/v1/auth')
|
|
# 兼容 (防止前端忘记写 v1)
|
|
app.register_blueprint(auth_bp, url_prefix='/api/auth', name='auth_legacy')
|
|
print("✅ Auth 模块注册成功")
|
|
except ImportError as e:
|
|
print(f"❌ 错误: Auth 模块导入失败: {e}")
|
|
|
|
# -----------------------------------------------------
|
|
# 2.1 注册入库聚合模块 (Inbound)
|
|
# -----------------------------------------------------
|
|
try:
|
|
from app.api.v1.inbound import inbound_bp
|
|
# 标准: /api/v1/inbound/base/list
|
|
app.register_blueprint(inbound_bp, url_prefix='/api/v1/inbound')
|
|
|
|
# 兼容: /api/inbound/base/list (修复前端 404)
|
|
app.register_blueprint(inbound_bp, url_prefix='/api/inbound', name='inbound_legacy')
|
|
print("✅ Inbound 模块注册成功 (已启用兼容模式: /api/inbound)")
|
|
except ImportError as e:
|
|
print(f"❌ 错误: Inbound 模块导入失败: {e}")
|
|
|
|
# -----------------------------------------------------
|
|
# 2.2 注册通用打印模块 (Common Print)
|
|
# -----------------------------------------------------
|
|
try:
|
|
from app.api.v1.common.print import print_bp
|
|
app.register_blueprint(print_bp, url_prefix='/api/v1/common/print')
|
|
app.register_blueprint(print_bp, url_prefix='/api/common/print', name='print_legacy')
|
|
print("✅ Print 模块注册成功")
|
|
except ImportError as e:
|
|
print(f"❌ 错误: Print 模块导入失败: {e}")
|
|
|
|
# -----------------------------------------------------
|
|
# 2.3 注册通用上传模块 (Common Upload)
|
|
# -----------------------------------------------------
|
|
try:
|
|
from app.api.v1.common.upload import upload_bp
|
|
app.register_blueprint(upload_bp, url_prefix='/api/v1/common')
|
|
app.register_blueprint(upload_bp, url_prefix='/api/common', name='upload_legacy')
|
|
print("✅ Upload 模块注册成功")
|
|
except ImportError as e:
|
|
print(f"❌ 错误: Upload 模块导入失败: {e}")
|
|
|
|
# -----------------------------------------------------
|
|
# 2.4 注册业务操作模块 (Transactions - 借还/维修/报废)
|
|
# -----------------------------------------------------
|
|
try:
|
|
from app.api.v1.transactions import trans_bp
|
|
# 标准: /api/v1/transactions/borrow
|
|
app.register_blueprint(trans_bp, url_prefix='/api/v1/transactions')
|
|
# 兼容: /api/transactions/borrow
|
|
app.register_blueprint(trans_bp, url_prefix='/api/transactions', name='trans_legacy')
|
|
print("✅ Transactions 模块注册成功")
|
|
except ImportError as e:
|
|
print(f"⚠️ 提示: Transaction 模块导入失败: {e}")
|
|
|
|
# -----------------------------------------------------
|
|
# 2.5 注册出库模块 (Outbound)
|
|
# -----------------------------------------------------
|
|
try:
|
|
from app.api.v1.outbound import outbound_bp
|
|
# 标准: /api/v1/outbound
|
|
app.register_blueprint(outbound_bp, url_prefix='/api/v1/outbound')
|
|
# 兼容: /api/outbound
|
|
app.register_blueprint(outbound_bp, url_prefix='/api/outbound', name='outbound_legacy')
|
|
print("✅ Outbound 模块注册成功")
|
|
except ImportError as e:
|
|
print(f"❌ 错误: Outbound 模块导入失败: {e}")
|
|
|
|
# -----------------------------------------------------
|
|
# 2.6 注册报废模块
|
|
# -----------------------------------------------------
|
|
try:
|
|
from app.api.v1.scrap import scrap_bp
|
|
app.register_blueprint(scrap_bp, url_prefix='/api/v1/scrap')
|
|
print("✅ Scrap 模块注册成功")
|
|
except ImportError as e:
|
|
print(f"❌ 错误: Scrap 模块导入失败: {e}")
|
|
|
|
# -----------------------------------------------------
|
|
# 2.7 注册 BOM 模块
|
|
# -----------------------------------------------------
|
|
try:
|
|
from app.api.v1.bom import bom_bp
|
|
# 标准: /api/v1/bom
|
|
app.register_blueprint(bom_bp, url_prefix='/api/v1/bom')
|
|
# 兼容: /api/bom
|
|
app.register_blueprint(bom_bp, url_prefix='/api/bom', name='bom_legacy')
|
|
print("✅ BOM 模块注册成功")
|
|
except ImportError as e:
|
|
print(f"❌ 错误: BOM 模块导入失败: {e}")
|
|
|
|
# -----------------------------------------------------
|
|
# 2.7 注册权限管理模块 (Permission) - [新增]
|
|
# -----------------------------------------------------
|
|
try:
|
|
from app.api.v1.permission import permission_bp
|
|
# 标准: /api/v1/permissions/tree
|
|
app.register_blueprint(permission_bp, url_prefix='/api/v1/permissions')
|
|
# 兼容: /api/permissions/tree
|
|
app.register_blueprint(permission_bp, url_prefix='/api/permissions', name='permission_legacy')
|
|
print("✅ Permission 模块注册成功")
|
|
except ImportError as e:
|
|
print(f"❌ 错误: Permission 模块导入失败 (请检查 app/api/v1/permission.py 是否存在): {e}")
|
|
|
|
# 2.8 注册审计日志模块 (Audit)
|
|
# -----------------------------------------------------
|
|
try:
|
|
from app.api.v1.audit import audit_bp
|
|
# 标准: /api/v1/audit/logs
|
|
app.register_blueprint(audit_bp, url_prefix='/api/v1/audit')
|
|
# 兼容: /api/audit/logs
|
|
app.register_blueprint(audit_bp, url_prefix='/api/audit', name='audit_legacy')
|
|
print("✅ Audit 模块注册成功")
|
|
except ImportError as e:
|
|
print(f"❌ 错误: Audit 模块导入失败: {e}")
|
|
|
|
# 2.9 初始化审计日志菜单和权限(防重复)
|
|
# -----------------------------------------------------
|
|
try:
|
|
from app.services.permission_service import PermissionService
|
|
with app.app_context():
|
|
PermissionService.init_audit_menu()
|
|
except Exception as e:
|
|
print(f"⚠️ 审计日志菜单初始化跳过: {e}")
|
|
|
|
# -----------------------------------------------------
|
|
# 2.10 注册库位管理模块 (Warehouse)
|
|
# -----------------------------------------------------
|
|
try:
|
|
from app.api.v1.warehouse import warehouse_bp
|
|
# 标准: /api/v1/warehouse/tree
|
|
app.register_blueprint(warehouse_bp, url_prefix='/api/v1/warehouse')
|
|
# 兼容: /api/warehouse/tree
|
|
app.register_blueprint(warehouse_bp, url_prefix='/api/warehouse', name='warehouse_legacy')
|
|
print("✅ Warehouse 模块注册成功")
|
|
except ImportError as e:
|
|
print(f"❌ 错误: Warehouse 模块导入失败: {e}")
|
|
|
|
# =========================================================
|
|
# 3. 预加载数据模型
|
|
# =========================================================
|
|
with app.app_context():
|
|
try:
|
|
# 基础与库存模型
|
|
from app.models.base import MaterialBase
|
|
from app.models.inbound.buy import StockBuy
|
|
from app.models.inbound.semi import StockSemi
|
|
from app.models.inbound.product import StockProduct
|
|
|
|
# 出库模型
|
|
from app.models.outbound import TransOutbound
|
|
|
|
# 系统与业务模型 (SysRolePermission 等在 models.system 中)
|
|
from app.models.system import SysUser, SysLog, SysMenu, SysElement, SysRolePermission, SysWarehouseLocation
|
|
# 确保借还模型被加载
|
|
from app.models.transaction import TransBorrow, TransRepair, TransScrap
|
|
|
|
# 首次运行时可取消注释自动建表 (但在生产环境建议使用 flask db upgrade)
|
|
# db.create_all()
|
|
|
|
except ImportError as e:
|
|
print(f"⚠️ 模型预加载部分失败 (检查是否缺少文件): {e}")
|
|
except Exception as e:
|
|
print(f"⚠️ 模型预加载发生未知错误: {e}")
|
|
|
|
return app |