feat: 添加ERP服务和系统服务,完善员工门户功能
## 新增服务模块 ### 1. ERP服务 (hzhub-erp) - 新增独立的ERP数据适配服务 - 支持SQL Server 2008 R2数据源 - 提供动态API配置管理系统 - 包含客户管理、销售数据等业务接口 ### 2. 系统服务 (hzhub-system) - 新增独立的系统管理服务 - 用户、角色、权限、部门、菜单管理 - 租户管理、操作日志、在线用户监控 - 工作流引擎(warm-flow)集成 - 企业微信审批同步功能 ### 3. API网关 (hzhub-gateway) - 新增Spring Cloud Gateway网关服务 - JWT认证、路由分发、限流熔断 - XSS防护、请求日志记录 - 统一入口端口8080 ## 后台管理功能增强 ### ERP动态API管理 - 新增动态API配置管理界面 - API测试、文档预览、统计监控 - 错误日志查看、缓存管理 - 从数据库表自动导入API配置 ### 系统管理增强 - 企业微信配置管理 - 企业微信审批同步配置 - 部门和用户管理优化 ## 员工门户功能完善 ### 业务页面 - 审批中心:工作流审批、待办任务 - CRM管理:客户关系管理 - 经销商管理:经销商数据展示 - 供应链管理:采购、库存、销售 - BI报表:数据可视化分析 - ERP数据探索:SQL Server数据查询 ### 个人中心 - 基本设置:个人信息管理 - 安全设置:密码修改、登录日志 - 锁屏功能:自动锁屏、手动锁屏 ### 其他功能 - 标签页管理:多标签页导航 - 页面缓存:keepAlive缓存机制 - 会话超时:自动检测并提示 ## 经销商门户 ### 页面路由 - 新增经销商管理页面路由 - AI聊天界面完善 ## 文档更新 - ERP API数据库初始化指南 - ERP API前端完整实现文档 - ERP API测试和验证指南 - Gateway路由迁移计划 - 项目配置文档更新 ## 部署脚本 - 统一启动/停止/重启脚本 - Docker Compose配置优化 - Nginx配置文件更新 ## 技术栈 - 后端: Spring Boot 3.5.8, Java 17 - 前端: Vue 3, TypeScript, Element Plus, Vben Admin - 工作流: warm-flow 1.8.2 - 网关: Spring Cloud Gateway - 数据库: MySQL 8.0, SQL Server 2008 R2 - 缓存: Redis 7 - 向量库: Weaviate 1.25.0 Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
89
hzhub-erp/init_tables.py
Normal file
89
hzhub-erp/init_tables.py
Normal file
@@ -0,0 +1,89 @@
|
||||
#!/usr/bin/env python3
|
||||
"""
|
||||
ERP API 配置表初始化脚本
|
||||
执行 SQL Server 表创建脚本
|
||||
"""
|
||||
|
||||
import pymssql
|
||||
import os
|
||||
from pathlib import Path
|
||||
|
||||
# 数据库连接配置(从环境变量或使用默认值)
|
||||
# 使用 .env 文件中的配置
|
||||
DB_HOST = os.getenv('ERP_DB_HOST', '192.168.120.10')
|
||||
DB_PORT = int(os.getenv('ERP_DB_PORT', '8042'))
|
||||
DB_NAME = os.getenv('ERP_DB_NAME', 'DMPF_HY')
|
||||
DB_USER = os.getenv('ERP_DB_USERNAME', 'aiuser')
|
||||
DB_PASSWORD = os.getenv('ERP_DB_PASSWORD', 'aiuser123')
|
||||
|
||||
print(f"Connecting to SQL Server: {DB_HOST}:{DB_PORT}/{DB_NAME}")
|
||||
|
||||
try:
|
||||
# 连接数据库
|
||||
conn = pymssql.connect(
|
||||
server=DB_HOST,
|
||||
port=DB_PORT,
|
||||
database=DB_NAME,
|
||||
user=DB_USER,
|
||||
password=DB_PASSWORD,
|
||||
charset='utf8'
|
||||
)
|
||||
|
||||
cursor = conn.cursor()
|
||||
|
||||
# 读取SQL文件
|
||||
sql_file = Path(__file__).parent / 'docs' / 'sql' / 'erp_api_tables_sqlserver.sql'
|
||||
print(f"Reading SQL file: {sql_file}")
|
||||
|
||||
with open(sql_file, 'r', encoding='utf-8') as f:
|
||||
sql_content = f.read()
|
||||
|
||||
# 分割SQL语句(按GO分割)
|
||||
sql_statements = sql_content.split('GO')
|
||||
|
||||
print(f"Found {len(sql_statements)} SQL statement blocks")
|
||||
|
||||
# 执行每个SQL语句块
|
||||
for i, statement in enumerate(sql_statements, 1):
|
||||
statement = statement.strip()
|
||||
if not statement or statement.startswith('--'):
|
||||
continue
|
||||
|
||||
print(f"Executing statement block {i}...")
|
||||
try:
|
||||
cursor.execute(statement)
|
||||
conn.commit()
|
||||
print(f"✓ Statement block {i} executed successfully")
|
||||
except Exception as e:
|
||||
print(f"✗ Error in statement block {i}: {e}")
|
||||
# 继续执行其他语句
|
||||
conn.rollback()
|
||||
|
||||
# 查询表是否创建成功
|
||||
print("\nVerifying tables...")
|
||||
tables_to_check = ['erp_api_config', 'erp_api_param', 'erp_api_stats']
|
||||
|
||||
for table in tables_to_check:
|
||||
cursor.execute(f"SELECT COUNT(*) FROM sysobjects WHERE name='{table}' AND xtype='U'")
|
||||
count = cursor.fetchone()[0]
|
||||
if count > 0:
|
||||
print(f"✓ Table {table} exists")
|
||||
|
||||
# 显示表的行数
|
||||
cursor.execute(f"SELECT COUNT(*) FROM {table}")
|
||||
rows = cursor.fetchone()[0]
|
||||
print(f" - Rows: {rows}")
|
||||
else:
|
||||
print(f"✗ Table {table} NOT found")
|
||||
|
||||
cursor.close()
|
||||
conn.close()
|
||||
|
||||
print("\n✓ ERP API configuration tables initialized successfully!")
|
||||
|
||||
except pymssql.Error as e:
|
||||
print(f"\n✗ Database error: {e}")
|
||||
exit(1)
|
||||
except Exception as e:
|
||||
print(f"\n✗ Error: {e}")
|
||||
exit(1)
|
||||
Reference in New Issue
Block a user