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:
108
hzhub-deploy/sql/wecom_all.sql
Normal file
108
hzhub-deploy/sql/wecom_all.sql
Normal file
@@ -0,0 +1,108 @@
|
||||
-- 企业微信审批模块 - 数据库表
|
||||
-- 执行: 在 hzhub 数据库中执行
|
||||
|
||||
-- 1. 企业微信审批单本地缓存
|
||||
CREATE TABLE IF NOT EXISTS `wecom_approval` (
|
||||
`id` BIGINT NOT NULL AUTO_INCREMENT,
|
||||
`tenant_id` VARCHAR(20) DEFAULT '000000' COMMENT '租户ID',
|
||||
`sp_no` VARCHAR(64) NOT NULL COMMENT '审批单号',
|
||||
`sp_name` VARCHAR(128) DEFAULT NULL COMMENT '审批模板名称',
|
||||
`sp_status` TINYINT NOT NULL COMMENT '状态: 1审批中 2已通过 3已驳回 4已撤销 6通过后撤销 7已删除',
|
||||
`template_id` VARCHAR(128) DEFAULT NULL COMMENT '模板ID',
|
||||
`apply_time` BIGINT DEFAULT NULL COMMENT '提交时间(时间戳)',
|
||||
`applyer_userid` VARCHAR(128) DEFAULT NULL COMMENT '申请人userid',
|
||||
`applyer_party` VARCHAR(128) DEFAULT NULL COMMENT '申请人部门',
|
||||
`apply_data` JSON DEFAULT NULL COMMENT '表单数据(原始JSON)',
|
||||
`nodes_data` JSON DEFAULT NULL COMMENT '审批流程节点(原始JSON)',
|
||||
`summary_info` TEXT DEFAULT NULL COMMENT '审批摘要',
|
||||
`amount` DECIMAL(12,2) DEFAULT NULL COMMENT '涉及金额',
|
||||
`sync_time` DATETIME DEFAULT NULL COMMENT '最后同步时间',
|
||||
`create_dept` BIGINT DEFAULT NULL COMMENT '创建部门',
|
||||
`create_by` BIGINT DEFAULT NULL COMMENT '创建者',
|
||||
`create_time` DATETIME DEFAULT CURRENT_TIMESTAMP,
|
||||
`update_by` BIGINT DEFAULT NULL COMMENT '更新者',
|
||||
`update_time` DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
|
||||
PRIMARY KEY (`id`),
|
||||
KEY `idx_tenant_sp_no` (`tenant_id`, `sp_no`),
|
||||
KEY `idx_tenant_status` (`tenant_id`, `sp_status`),
|
||||
KEY `idx_tenant_apply_time` (`tenant_id`, `apply_time`)
|
||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='企业微信审批单本地缓存';
|
||||
|
||||
-- 2. 企业微信审批模板缓存
|
||||
CREATE TABLE IF NOT EXISTS `wecom_approval_template` (
|
||||
`id` BIGINT NOT NULL AUTO_INCREMENT,
|
||||
`tenant_id` VARCHAR(20) DEFAULT '000000' COMMENT '租户ID',
|
||||
`template_id` VARCHAR(128) NOT NULL COMMENT '模板ID',
|
||||
`template_name` VARCHAR(128) DEFAULT NULL COMMENT '模板名称',
|
||||
`template_config` JSON DEFAULT NULL COMMENT '模板配置(控件结构)',
|
||||
`sync_time` DATETIME DEFAULT NULL COMMENT '最后同步时间',
|
||||
`create_dept` BIGINT DEFAULT NULL COMMENT '创建部门',
|
||||
`create_by` BIGINT DEFAULT NULL COMMENT '创建者',
|
||||
`create_time` DATETIME DEFAULT CURRENT_TIMESTAMP,
|
||||
`update_by` BIGINT DEFAULT NULL COMMENT '更新者',
|
||||
`update_time` DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
|
||||
PRIMARY KEY (`id`),
|
||||
UNIQUE KEY `uk_tenant_template` (`tenant_id`, `template_id`)
|
||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='企业微信审批模板缓存';
|
||||
|
||||
-- 3. 企业微信租户配置(每个租户一条记录)
|
||||
CREATE TABLE IF NOT EXISTS `wecom_tenant_config` (
|
||||
`id` BIGINT NOT NULL AUTO_INCREMENT,
|
||||
`tenant_id` VARCHAR(20) NOT NULL COMMENT '租户ID',
|
||||
`corpid` VARCHAR(64) NOT NULL COMMENT '企业微信企业ID',
|
||||
`corpsecret` VARCHAR(128) NOT NULL COMMENT '企业微信应用密钥',
|
||||
`agent_id` VARCHAR(64) DEFAULT NULL COMMENT '应用AgentID',
|
||||
`callback_token` VARCHAR(128) DEFAULT NULL COMMENT '回调Token',
|
||||
`callback_aes_key` VARCHAR(128) DEFAULT NULL COMMENT '回调EncodingAESKey',
|
||||
`enabled` CHAR(1) DEFAULT '0' COMMENT '是否启用(0否 1是)',
|
||||
`remark` VARCHAR(500) DEFAULT NULL COMMENT '备注',
|
||||
`create_dept` BIGINT DEFAULT NULL COMMENT '创建部门',
|
||||
`create_by` BIGINT DEFAULT NULL COMMENT '创建者',
|
||||
`create_time` DATETIME DEFAULT CURRENT_TIMESTAMP,
|
||||
`update_by` BIGINT DEFAULT NULL COMMENT '更新者',
|
||||
`update_time` DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
|
||||
PRIMARY KEY (`id`),
|
||||
UNIQUE KEY `uk_tenant_id` (`tenant_id`)
|
||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='企业微信租户配置';
|
||||
|
||||
-- 4. 企业微信审批同步日志
|
||||
CREATE TABLE IF NOT EXISTS `wecom_approval_sync_log` (
|
||||
`id` BIGINT NOT NULL AUTO_INCREMENT,
|
||||
`tenant_id` VARCHAR(20) DEFAULT '000000' COMMENT '租户ID',
|
||||
`sync_type` VARCHAR(20) NOT NULL COMMENT '同步类型: FULL/INCREMENTAL/MANUAL',
|
||||
`status` VARCHAR(20) DEFAULT 'RUNNING' COMMENT '同步状态: RUNNING运行中 COMPLETED已完成 FAILED失败',
|
||||
`start_time` DATETIME NOT NULL COMMENT '开始时间',
|
||||
`end_time` DATETIME DEFAULT NULL COMMENT '结束时间',
|
||||
`duration` INT DEFAULT NULL COMMENT '耗时(秒)',
|
||||
`added_count` INT DEFAULT 0 COMMENT '新增数量',
|
||||
`updated_count` INT DEFAULT 0 COMMENT '更新数量',
|
||||
`error_count` INT DEFAULT 0 COMMENT '错误数量',
|
||||
`error_msg` TEXT DEFAULT NULL COMMENT '错误信息',
|
||||
`operator` VARCHAR(64) DEFAULT NULL COMMENT '操作人',
|
||||
`create_dept` BIGINT DEFAULT NULL COMMENT '创建部门',
|
||||
`create_by` BIGINT DEFAULT NULL COMMENT '创建者',
|
||||
`create_time` DATETIME DEFAULT CURRENT_TIMESTAMP,
|
||||
`update_by` BIGINT DEFAULT NULL COMMENT '更新者',
|
||||
`update_time` DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
|
||||
PRIMARY KEY (`id`),
|
||||
KEY `idx_tenant_id` (`tenant_id`),
|
||||
KEY `idx_sync_type` (`sync_type`),
|
||||
KEY `idx_start_time` (`start_time`)
|
||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='企业微信审批同步日志';
|
||||
|
||||
-- 5. sys_user 表增加企业微信 userid 字段
|
||||
ALTER TABLE `sys_user` ADD COLUMN `wecom_userid` VARCHAR(64) DEFAULT NULL COMMENT '企业微信userid';
|
||||
|
||||
-- 6. wecom_approval 表增加审批人 userid 字段
|
||||
ALTER TABLE `wecom_approval` ADD COLUMN `approver_userids` VARCHAR(1024) DEFAULT NULL COMMENT '审批人userid列表(逗号分隔)';
|
||||
|
||||
-- 7. wecom_approval 表增加审批类型名称字段
|
||||
ALTER TABLE `wecom_approval` ADD COLUMN `template_name` VARCHAR(128) DEFAULT NULL COMMENT '审批类型名称(模板名称)';
|
||||
|
||||
-- 8. wecom_approval_sync_log 表增加状态字段
|
||||
ALTER TABLE `wecom_approval_sync_log` ADD COLUMN `status` VARCHAR(20) DEFAULT 'RUNNING' COMMENT '同步状态: RUNNING运行中 COMPLETED已完成 FAILED失败';
|
||||
|
||||
-- 9. wecom_approval_template 表增加租户审计字段
|
||||
ALTER TABLE `wecom_approval_template` ADD COLUMN `create_dept` BIGINT DEFAULT NULL COMMENT '创建部门';
|
||||
ALTER TABLE `wecom_approval_template` ADD COLUMN `create_by` BIGINT DEFAULT NULL COMMENT '创建者';
|
||||
ALTER TABLE `wecom_approval_template` ADD COLUMN `update_by` BIGINT DEFAULT NULL COMMENT '更新者';
|
||||
36
hzhub-deploy/sql/wecom_approval.sql
Normal file
36
hzhub-deploy/sql/wecom_approval.sql
Normal file
@@ -0,0 +1,36 @@
|
||||
-- 企业微信审批数据表
|
||||
-- 执行: 在 hzhub 数据库中执行
|
||||
|
||||
-- 审批单本地缓存
|
||||
CREATE TABLE IF NOT EXISTS `wecom_approval` (
|
||||
`id` BIGINT NOT NULL AUTO_INCREMENT,
|
||||
`sp_no` VARCHAR(64) NOT NULL COMMENT '审批单号',
|
||||
`sp_name` VARCHAR(128) DEFAULT NULL COMMENT '审批模板名称',
|
||||
`sp_status` TINYINT NOT NULL COMMENT '状态: 1审批中 2已通过 3已驳回 4已撤销 6通过后撤销 7已删除',
|
||||
`template_id` VARCHAR(128) DEFAULT NULL COMMENT '模板ID',
|
||||
`apply_time` BIGINT DEFAULT NULL COMMENT '提交时间(时间戳)',
|
||||
`applyer_userid` VARCHAR(128) DEFAULT NULL COMMENT '申请人userid',
|
||||
`applyer_party` VARCHAR(128) DEFAULT NULL COMMENT '申请人部门',
|
||||
`apply_data` JSON DEFAULT NULL COMMENT '表单数据(原始JSON)',
|
||||
`nodes_data` JSON DEFAULT NULL COMMENT '审批流程节点(原始JSON)',
|
||||
`summary_info` TEXT DEFAULT NULL COMMENT '审批摘要',
|
||||
`amount` DECIMAL(12,2) DEFAULT NULL COMMENT '涉及金额',
|
||||
`sync_time` DATETIME DEFAULT NULL COMMENT '最后同步时间',
|
||||
`create_time` DATETIME DEFAULT CURRENT_TIMESTAMP,
|
||||
`update_time` DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
|
||||
PRIMARY KEY (`id`),
|
||||
UNIQUE KEY `uk_sp_no` (`sp_no`)
|
||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='企业微信审批单本地缓存';
|
||||
|
||||
-- 审批模板缓存
|
||||
CREATE TABLE IF NOT EXISTS `wecom_approval_template` (
|
||||
`id` BIGINT NOT NULL AUTO_INCREMENT,
|
||||
`template_id` VARCHAR(128) NOT NULL COMMENT '模板ID',
|
||||
`template_name` VARCHAR(128) DEFAULT NULL COMMENT '模板名称',
|
||||
`template_config` JSON DEFAULT NULL COMMENT '模板配置(控件结构)',
|
||||
`sync_time` DATETIME DEFAULT NULL COMMENT '最后同步时间',
|
||||
`create_time` DATETIME DEFAULT CURRENT_TIMESTAMP,
|
||||
`update_time` DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
|
||||
PRIMARY KEY (`id`),
|
||||
UNIQUE KEY `uk_template_id` (`template_id`)
|
||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='企业微信审批模板缓存';
|
||||
9
hzhub-deploy/sql/wecom_menu.sql
Normal file
9
hzhub-deploy/sql/wecom_menu.sql
Normal file
@@ -0,0 +1,9 @@
|
||||
-- 企业微信配置菜单
|
||||
-- 在系统管理(parent_id=1)下添加企业微信配置菜单
|
||||
-- 注意:path 必须是相对路径(如 wecom-config),否则会和父路径叠加成 /system/system/...
|
||||
|
||||
-- 先检查是否已存在
|
||||
DELETE FROM `sys_menu` WHERE menu_name = '企业微信配置';
|
||||
|
||||
INSERT INTO `sys_menu` (menu_name, parent_id, order_num, path, component, query_param, is_frame, is_cache, menu_type, visible, status, perms, icon, create_dept, create_by, create_time, update_by, update_time, remark)
|
||||
VALUES ('企业微信配置', 1, 99, 'wecom-config', 'system/wecom-config/index', '', 1, 0, 'C', '0', '0', 'system:wecom:config', 'simple-icons:wechat', 103, 1, NOW(), NULL, NULL, '企业微信配置菜单');
|
||||
16
hzhub-deploy/sql/wecom_tenant_config.sql
Normal file
16
hzhub-deploy/sql/wecom_tenant_config.sql
Normal file
@@ -0,0 +1,16 @@
|
||||
-- 企业微信租户配置表
|
||||
CREATE TABLE IF NOT EXISTS `wecom_tenant_config` (
|
||||
`id` BIGINT NOT NULL AUTO_INCREMENT,
|
||||
`tenant_id` VARCHAR(20) NOT NULL COMMENT '租户ID',
|
||||
`corpid` VARCHAR(64) NOT NULL COMMENT '企业微信企业ID',
|
||||
`corpsecret` VARCHAR(128) NOT NULL COMMENT '企业微信应用密钥',
|
||||
`agent_id` VARCHAR(64) DEFAULT NULL COMMENT '应用AgentID',
|
||||
`callback_token` VARCHAR(128) DEFAULT NULL COMMENT '回调Token',
|
||||
`callback_aes_key` VARCHAR(128) DEFAULT NULL COMMENT '回调EncodingAESKey',
|
||||
`enabled` CHAR(1) DEFAULT '0' COMMENT '是否启用(0否 1是)',
|
||||
`remark` VARCHAR(500) DEFAULT NULL COMMENT '备注',
|
||||
`create_time` DATETIME DEFAULT CURRENT_TIMESTAMP,
|
||||
`update_time` DATETIME DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
|
||||
PRIMARY KEY (`id`),
|
||||
UNIQUE KEY `uk_tenant_id` (`tenant_id`)
|
||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci COMMENT='企业微信租户配置';
|
||||
Reference in New Issue
Block a user