From 0658d127addfe99dee003c92c4010d1c336677d4 Mon Sep 17 00:00:00 2001
From: haungxing <1203316822@qq.com>
Date: Mon, 29 Apr 2024 16:57:24 +0800
Subject: [PATCH] =?UTF-8?q?add:=E5=A4=A7=E6=A8=A1=E5=9E=8B=E7=AE=A1?=
=?UTF-8?q?=E7=90=86?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
hzims-service-api/big-model-api/pom.xml | 17 ++++
.../com/hnac/hzims/bigmodel/BigModelConstants.java | 14 ++++
.../hzims/bigmodel/entity/FuncParamEntity.java | 38 +++++++++
.../hnac/hzims/bigmodel/entity/FunctionEntity.java | 45 +++++++++++
.../interactive/constants/FunctionConstants.java | 29 +++++++
.../bigmodel/interactive/req/ModelFunctionReq.java | 30 +++++++
.../hzims/bigmodel/interactive/vo/ExtraVO.java | 29 +++++++
hzims-service-api/pom.xml | 1 +
hzims-service/hzims-big-model/pom.xml | 91 ++++++++++++++++++++++
.../hzims/bigmodel/HzimsBigModelApplication.java | 33 ++++++++
.../bigmodel/configuration/BigModelInvokeUrl.java | 18 +++++
.../function/controller/FunctionController.java | 73 +++++++++++++++++
.../controller/FunctionParamController.java | 74 ++++++++++++++++++
.../bigmodel/function/mapper/FuncParamMapper.java | 11 +++
.../bigmodel/function/mapper/FunctionMapper.java | 12 +++
.../function/service/IFuncParamService.java | 21 +++++
.../function/service/IFunctionService.java | 14 ++++
.../service/impl/FuncParamServiceImpl.java | 28 +++++++
.../function/service/impl/FunctionServiceImpl.java | 27 +++++++
.../controller/InteractiveController.java | 45 +++++++++++
.../interactive/service/IInteractiveService.java | 20 +++++
.../interactive/service/IJumpPageService.java | 16 ++++
.../service/impl/InteractiveServiceImpl.java | 85 ++++++++++++++++++++
.../service/impl/JumpPageServiceImpl.java | 54 +++++++++++++
.../bigmodel/schedule/InteractiveSchedule.java | 58 ++++++++++++++
.../bigmodel/schedule/XxlJobHandlerConstant.java | 13 ++++
.../bigmodel/websocket/config/WebSocketConfig.java | 28 +++++++
.../websocket/handler/InteractiveHandler.java | 41 ++++++++++
.../websocket/server/InteractiveWsServer.java | 9 +++
.../websocket/service/InteractiveWsService.java | 32 ++++++++
.../websocket/service/WebSocketService.java | 13 ++++
.../sessionManager/InteractiveSessionManager.java | 56 +++++++++++++
.../src/main/resources/db/1.0.0.sql | 34 ++++++++
.../hnac/hzinfo/inspect/task/mapper/TaskMapper.xml | 3 +
hzims-service/pom.xml | 1 +
35 files changed, 1113 insertions(+)
create mode 100644 hzims-service-api/big-model-api/pom.xml
create mode 100644 hzims-service-api/big-model-api/src/main/java/com/hnac/hzims/bigmodel/BigModelConstants.java
create mode 100644 hzims-service-api/big-model-api/src/main/java/com/hnac/hzims/bigmodel/entity/FuncParamEntity.java
create mode 100644 hzims-service-api/big-model-api/src/main/java/com/hnac/hzims/bigmodel/entity/FunctionEntity.java
create mode 100644 hzims-service-api/big-model-api/src/main/java/com/hnac/hzims/bigmodel/interactive/constants/FunctionConstants.java
create mode 100644 hzims-service-api/big-model-api/src/main/java/com/hnac/hzims/bigmodel/interactive/req/ModelFunctionReq.java
create mode 100644 hzims-service-api/big-model-api/src/main/java/com/hnac/hzims/bigmodel/interactive/vo/ExtraVO.java
create mode 100644 hzims-service/hzims-big-model/pom.xml
create mode 100644 hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/HzimsBigModelApplication.java
create mode 100644 hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/configuration/BigModelInvokeUrl.java
create mode 100644 hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/controller/FunctionController.java
create mode 100644 hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/controller/FunctionParamController.java
create mode 100644 hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/mapper/FuncParamMapper.java
create mode 100644 hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/mapper/FunctionMapper.java
create mode 100644 hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/service/IFuncParamService.java
create mode 100644 hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/service/IFunctionService.java
create mode 100644 hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/service/impl/FuncParamServiceImpl.java
create mode 100644 hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/service/impl/FunctionServiceImpl.java
create mode 100644 hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/interactive/controller/InteractiveController.java
create mode 100644 hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/interactive/service/IInteractiveService.java
create mode 100644 hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/interactive/service/IJumpPageService.java
create mode 100644 hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/interactive/service/impl/InteractiveServiceImpl.java
create mode 100644 hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/interactive/service/impl/JumpPageServiceImpl.java
create mode 100644 hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/schedule/InteractiveSchedule.java
create mode 100644 hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/schedule/XxlJobHandlerConstant.java
create mode 100644 hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/websocket/config/WebSocketConfig.java
create mode 100644 hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/websocket/handler/InteractiveHandler.java
create mode 100644 hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/websocket/server/InteractiveWsServer.java
create mode 100644 hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/websocket/service/InteractiveWsService.java
create mode 100644 hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/websocket/service/WebSocketService.java
create mode 100644 hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/websocket/sessionManager/InteractiveSessionManager.java
create mode 100644 hzims-service/hzims-big-model/src/main/resources/db/1.0.0.sql
diff --git a/hzims-service-api/big-model-api/pom.xml b/hzims-service-api/big-model-api/pom.xml
new file mode 100644
index 0000000..2df887f
--- /dev/null
+++ b/hzims-service-api/big-model-api/pom.xml
@@ -0,0 +1,17 @@
+
+
+
+ hzims-service-api
+ com.hnac.hzims
+ 4.0.0-SNAPSHOT
+
+ 4.0.0
+ big-model-api
+ big-model-api
+
+
+
+
+
+
diff --git a/hzims-service-api/big-model-api/src/main/java/com/hnac/hzims/bigmodel/BigModelConstants.java b/hzims-service-api/big-model-api/src/main/java/com/hnac/hzims/bigmodel/BigModelConstants.java
new file mode 100644
index 0000000..91d93f8
--- /dev/null
+++ b/hzims-service-api/big-model-api/src/main/java/com/hnac/hzims/bigmodel/BigModelConstants.java
@@ -0,0 +1,14 @@
+package com.hnac.hzims.bigmodel;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/26 10:15
+ */
+public interface BigModelConstants {
+
+ /**注册至NACOS服务名**/
+ String APP_NAME = "hzims-big-model";
+ /**前端展示服务名**/
+ String MODULE_NAME = "大模型管理";
+
+}
diff --git a/hzims-service-api/big-model-api/src/main/java/com/hnac/hzims/bigmodel/entity/FuncParamEntity.java b/hzims-service-api/big-model-api/src/main/java/com/hnac/hzims/bigmodel/entity/FuncParamEntity.java
new file mode 100644
index 0000000..99e55ed
--- /dev/null
+++ b/hzims-service-api/big-model-api/src/main/java/com/hnac/hzims/bigmodel/entity/FuncParamEntity.java
@@ -0,0 +1,38 @@
+package com.hnac.hzims.bigmodel.entity;
+
+import com.baomidou.mybatisplus.annotation.TableName;
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import org.springblade.core.mp.support.QueryField;
+import org.springblade.core.mp.support.SqlCondition;
+import org.springblade.core.tenant.mp.TenantEntity;
+
+import javax.validation.constraints.Max;
+import javax.validation.constraints.Size;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/26 10:56
+ */
+@TableName("HZIMS_FUNC_PARAM")
+@ApiModel(value = "大模型函数参数entity",description = "大模型函数参数entity")
+@Data
+public class FuncParamEntity extends TenantEntity {
+
+ @ApiModelProperty(value = "函数表主键ID")
+ @QueryField(condition = SqlCondition.EQUAL)
+ @Max(20)
+ private Long funcId;
+
+ @ApiModelProperty("参数名称")
+ @QueryField(condition = SqlCondition.LIKE)
+ @Size(min = 1,max = 50)
+ private String name;
+
+ @ApiModelProperty(value = "参数别名,传参参数")
+ @QueryField(condition = SqlCondition.EQUAL)
+ @Size(min = 1,max = 25)
+ private String alias;
+
+}
diff --git a/hzims-service-api/big-model-api/src/main/java/com/hnac/hzims/bigmodel/entity/FunctionEntity.java b/hzims-service-api/big-model-api/src/main/java/com/hnac/hzims/bigmodel/entity/FunctionEntity.java
new file mode 100644
index 0000000..af01299
--- /dev/null
+++ b/hzims-service-api/big-model-api/src/main/java/com/hnac/hzims/bigmodel/entity/FunctionEntity.java
@@ -0,0 +1,45 @@
+package com.hnac.hzims.bigmodel.entity;
+
+import com.baomidou.mybatisplus.annotation.TableName;
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+import org.springblade.core.mp.support.QueryField;
+import org.springblade.core.mp.support.SqlCondition;
+import org.springblade.core.tenant.mp.TenantEntity;
+
+import javax.validation.constraints.Max;
+import javax.validation.constraints.Size;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/26 10:46
+ */
+@Data
+@ApiModel(value = "大模型函数entity",description = "大模型函数entity")
+@TableName("HZIMS_FUNCTION")
+public class FunctionEntity extends TenantEntity {
+
+ @ApiModelProperty("函数名称")
+ @QueryField(condition = SqlCondition.LIKE)
+ private String name;
+
+ @ApiModelProperty(value = "函数编号")
+ @QueryField(condition = SqlCondition.EQUAL)
+ private String code;
+
+ @ApiModelProperty("动作类型")
+ @QueryField(condition = SqlCondition.EQUAL)
+ private String type;
+
+ @ApiModelProperty("是否需要确认,0:否,1:是")
+ @QueryField(condition = SqlCondition.EQUAL)
+ private Boolean isConfirm;
+
+ @ApiModelProperty("跳转路径")
+ private String path;
+
+ @ApiModelProperty("描述")
+ private String remake;
+
+}
diff --git a/hzims-service-api/big-model-api/src/main/java/com/hnac/hzims/bigmodel/interactive/constants/FunctionConstants.java b/hzims-service-api/big-model-api/src/main/java/com/hnac/hzims/bigmodel/interactive/constants/FunctionConstants.java
new file mode 100644
index 0000000..7d34a5d
--- /dev/null
+++ b/hzims-service-api/big-model-api/src/main/java/com/hnac/hzims/bigmodel/interactive/constants/FunctionConstants.java
@@ -0,0 +1,29 @@
+package com.hnac.hzims.bigmodel.interactive.constants;
+
+import lombok.AllArgsConstructor;
+import lombok.Getter;
+
+import java.util.Arrays;
+import java.util.Optional;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/26 13:29
+ */
+public interface FunctionConstants {
+
+ @AllArgsConstructor
+ enum TypeEnum {
+ /**跳转页面**/
+ JUMP("1")
+ ;
+ @Getter
+ private String type;
+
+ public static TypeEnum getTypeEnumByType (String type) {
+ Optional typeEnumOptional = Arrays.stream(TypeEnum.class.getEnumConstants()).filter(e -> type.equals(e.getType())).findFirst();
+ return typeEnumOptional.orElse(null);
+ }
+ }
+
+}
diff --git a/hzims-service-api/big-model-api/src/main/java/com/hnac/hzims/bigmodel/interactive/req/ModelFunctionReq.java b/hzims-service-api/big-model-api/src/main/java/com/hnac/hzims/bigmodel/interactive/req/ModelFunctionReq.java
new file mode 100644
index 0000000..a1fe20c
--- /dev/null
+++ b/hzims-service-api/big-model-api/src/main/java/com/hnac/hzims/bigmodel/interactive/req/ModelFunctionReq.java
@@ -0,0 +1,30 @@
+package com.hnac.hzims.bigmodel.interactive.req;
+
+import com.alibaba.fastjson.annotation.JSONField;
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+import java.io.Serializable;
+import java.util.Map;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/26 11:31
+ */
+@Data
+@ApiModel("大模型响应内容")
+public class ModelFunctionReq implements Serializable {
+
+ @ApiModelProperty("类型")
+ private String type;
+
+ @JSONField(name = "function_name")
+ @ApiModelProperty("函数标识")
+ private String functionName;
+
+ @JSONField(name = "function_args")
+ @ApiModelProperty("函数参数")
+ private Map functionArgs;
+
+}
diff --git a/hzims-service-api/big-model-api/src/main/java/com/hnac/hzims/bigmodel/interactive/vo/ExtraVO.java b/hzims-service-api/big-model-api/src/main/java/com/hnac/hzims/bigmodel/interactive/vo/ExtraVO.java
new file mode 100644
index 0000000..303a21e
--- /dev/null
+++ b/hzims-service-api/big-model-api/src/main/java/com/hnac/hzims/bigmodel/interactive/vo/ExtraVO.java
@@ -0,0 +1,29 @@
+package com.hnac.hzims.bigmodel.interactive.vo;
+
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiModelProperty;
+import lombok.Data;
+
+import java.io.Serializable;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/26 13:35
+ */
+@Data
+@ApiModel("响应内容")
+public class ExtraVO implements Serializable {
+
+ @ApiModelProperty("交互类型")
+ private String type;
+
+ @ApiModelProperty("若为弹窗,则返回路由")
+ private String route;
+
+ @ApiModelProperty("链接显示文字")
+ private String label;
+
+ @ApiModelProperty("是否立即跳转")
+ private boolean isImmediatelyJump = true;
+
+}
diff --git a/hzims-service-api/pom.xml b/hzims-service-api/pom.xml
index e3ec04e..9974fff 100644
--- a/hzims-service-api/pom.xml
+++ b/hzims-service-api/pom.xml
@@ -29,6 +29,7 @@
common-api
middle-api
alarm-api
+ big-model-api
diff --git a/hzims-service/hzims-big-model/pom.xml b/hzims-service/hzims-big-model/pom.xml
new file mode 100644
index 0000000..ece5cf6
--- /dev/null
+++ b/hzims-service/hzims-big-model/pom.xml
@@ -0,0 +1,91 @@
+
+
+
+ com.hnac.hzims
+ hzims-service
+ 4.0.0-SNAPSHOT
+
+ 4.0.0
+ hzims-big-model
+ big-model
+ jar
+
+
+
+ org.springblade
+ blade-core-boot
+
+
+ org.springblade
+ blade-starter-redis
+
+
+
+
+
+ org.springblade
+ blade-starter-swagger
+
+
+
+ org.springblade
+ blade-core-test
+ test
+
+
+
+ org.springblade
+ blade-core-cloud
+
+
+ com.hnac.hzims
+ big-model-api
+ 4.0.0-SNAPSHOT
+ compile
+
+
+
+
+ org.springframework.boot
+ spring-boot-starter-websocket
+
+
+ org.springframework.boot
+ spring-boot-starter-tomcat
+
+
+
+
+
+ com.xuxueli
+ xxl-job-core
+
+
+ org.springblade
+ blade-system-api
+
+
+
+
+ ${project.name}-${project.version}
+
+
+ com.spotify
+ dockerfile-maven-plugin
+
+ ${docker.username}
+ ${docker.password}
+ ${docker.registry.url}/${docker.namespace}/${project.artifactId}
+ ${project.version}
+ true
+
+ target/${project.build.finalName}.jar
+
+ false
+
+
+
+
+
+
diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/HzimsBigModelApplication.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/HzimsBigModelApplication.java
new file mode 100644
index 0000000..2709c09
--- /dev/null
+++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/HzimsBigModelApplication.java
@@ -0,0 +1,33 @@
+package com.hnac.hzims.bigmodel;
+
+import org.mybatis.spring.annotation.MapperScan;
+import org.springblade.core.cloud.feign.EnableBladeFeign;
+import org.springblade.core.launch.BladeApplication;
+import org.springframework.boot.SpringApplication;
+import org.springframework.boot.autoconfigure.SpringBootApplication;
+import org.springframework.boot.builder.SpringApplicationBuilder;
+import org.springframework.boot.web.servlet.support.SpringBootServletInitializer;
+import org.springframework.cloud.client.SpringCloudApplication;
+import org.springframework.context.annotation.ComponentScan;
+import org.springframework.scheduling.annotation.EnableScheduling;
+
+import javax.annotation.Resource;
+
+@EnableBladeFeign(basePackages = {"org.springblade","com.hnac"})
+@SpringCloudApplication
+@MapperScan("com.hnac.hzims.**.mapper.**")
+@ComponentScan(basePackages = {"com.hnac.hzims.bigmodel.*"})
+@Resource
+@ComponentScan(basePackages = {"com.hnac.hzims.*"})
+public class HzimsBigModelApplication extends SpringBootServletInitializer {
+
+ public static void main(String[] args) {
+ BladeApplication.run(BigModelConstants.APP_NAME, HzimsBigModelApplication.class, args);
+ }
+
+ @Override
+ protected SpringApplicationBuilder configure(SpringApplicationBuilder builder) {
+ return BladeApplication.createSpringApplicationBuilder(builder, BigModelConstants.APP_NAME, HzimsBigModelApplication.class);
+ }
+
+}
diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/configuration/BigModelInvokeUrl.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/configuration/BigModelInvokeUrl.java
new file mode 100644
index 0000000..5ff1f3e
--- /dev/null
+++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/configuration/BigModelInvokeUrl.java
@@ -0,0 +1,18 @@
+package com.hnac.hzims.bigmodel.configuration;
+
+import lombok.Data;
+import org.springframework.boot.context.properties.ConfigurationProperties;
+import org.springframework.stereotype.Component;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/28 18:20
+ */
+@Data
+@Component
+@ConfigurationProperties(prefix = "fdp.url")
+public class BigModelInvokeUrl {
+
+ private String assistantAsk;
+
+}
diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/controller/FunctionController.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/controller/FunctionController.java
new file mode 100644
index 0000000..bffa1db
--- /dev/null
+++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/controller/FunctionController.java
@@ -0,0 +1,73 @@
+package com.hnac.hzims.bigmodel.function.controller;
+
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
+import com.hnac.hzims.bigmodel.BigModelConstants;
+import com.hnac.hzims.bigmodel.entity.FunctionEntity;
+import com.hnac.hzims.bigmodel.function.service.IFunctionService;
+import com.hnac.hzims.common.utils.Condition;
+import com.hnac.hzinfo.log.annotation.Business;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiModel;
+import io.swagger.annotations.ApiOperation;
+import lombok.AllArgsConstructor;
+import org.springblade.core.mp.support.Query;
+import org.springblade.core.tool.api.R;
+import org.springblade.core.tool.utils.BeanUtil;
+import org.springblade.core.tool.utils.Func;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.*;
+
+import java.util.List;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/29 14:39
+ */
+@RestController
+@RequestMapping("/function")
+@Api(value = "大模型函数管理",tags = "大模型函数管理")
+@Business(module = BigModelConstants.MODULE_NAME,value = "大模型函数管理")
+@AllArgsConstructor
+public class FunctionController {
+
+ private final IFunctionService functionService;
+
+ @PostMapping("/save")
+ @ApiOperation("保存函数")
+ @ApiOperationSupport(order = 1)
+ public R save(@RequestBody @Validated FunctionEntity req) {
+ return R.status(functionService.save(req));
+ }
+
+ @PutMapping("/save")
+ @ApiOperation("编辑函数")
+ @ApiOperationSupport(order = 2)
+ public R updateById(@RequestBody FunctionEntity req) {
+ return R.status(functionService.save(req));
+ }
+
+ @GetMapping("/list")
+ @ApiOperation("列表查询")
+ @ApiOperationSupport(order = 3)
+ public R> list(FunctionEntity req) {
+ return R.data(functionService.list(Condition.getQueryWrapper(BeanUtil.toMap(req),FunctionEntity.class)));
+ }
+
+ @GetMapping("/page")
+ @ApiOperation("分页查询")
+ @ApiOperationSupport(order = 4)
+ public R> page(FunctionEntity req, Query query) {
+ QueryWrapper queryWrapper = Condition.getQueryWrapper(BeanUtil.toMap(req), FunctionEntity.class);
+ return R.data(functionService.page(Condition.getPage(query),queryWrapper));
+ }
+
+ @DeleteMapping("/remove")
+ @ApiOperation("删除函数")
+ @ApiOperationSupport(order = 4)
+ public R remove(String ids) {
+ return R.data(functionService.removeByIds(Func.toLongList(",",ids)));
+ }
+
+}
diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/controller/FunctionParamController.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/controller/FunctionParamController.java
new file mode 100644
index 0000000..0f58067
--- /dev/null
+++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/controller/FunctionParamController.java
@@ -0,0 +1,74 @@
+package com.hnac.hzims.bigmodel.function.controller;
+
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.baomidou.mybatisplus.core.metadata.IPage;
+import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
+import com.hnac.hzims.bigmodel.BigModelConstants;
+import com.hnac.hzims.bigmodel.entity.FuncParamEntity;
+import com.hnac.hzims.bigmodel.entity.FunctionEntity;
+import com.hnac.hzims.bigmodel.function.service.IFuncParamService;
+import com.hnac.hzims.bigmodel.function.service.IFunctionService;
+import com.hnac.hzims.common.utils.Condition;
+import com.hnac.hzinfo.log.annotation.Business;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiOperation;
+import lombok.AllArgsConstructor;
+import org.springblade.core.mp.support.Query;
+import org.springblade.core.tool.api.R;
+import org.springblade.core.tool.utils.BeanUtil;
+import org.springblade.core.tool.utils.Func;
+import org.springframework.validation.annotation.Validated;
+import org.springframework.web.bind.annotation.*;
+
+import java.util.List;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/29 15:46
+ */
+@RestController
+@RequestMapping("/function/param")
+@Api(value = "大模型函数参数管理",tags = "大模型函数参数管理")
+@Business(module = BigModelConstants.MODULE_NAME,value = "大模型函数参数管理")
+@AllArgsConstructor
+public class FunctionParamController {
+
+ private final IFuncParamService funcParamService;
+
+ @PostMapping("/save")
+ @ApiOperation("保存函数参数")
+ @ApiOperationSupport(order = 1)
+ public R save(@RequestBody @Validated FuncParamEntity req) {
+ return R.status(funcParamService.save(req));
+ }
+
+ @PutMapping("/save")
+ @ApiOperation("编辑函数参数")
+ @ApiOperationSupport(order = 2)
+ public R updateById(@RequestBody FuncParamEntity req) {
+ return R.status(funcParamService.save(req));
+ }
+
+ @GetMapping("/list")
+ @ApiOperation("列表查询")
+ @ApiOperationSupport(order = 3)
+ public R> list(FuncParamEntity req) {
+ return R.data(funcParamService.list(Condition.getQueryWrapper(BeanUtil.toMap(req),FuncParamEntity.class)));
+ }
+
+ @GetMapping("/page")
+ @ApiOperation("分页查询")
+ @ApiOperationSupport(order = 4)
+ public R> page(FuncParamEntity req, Query query) {
+ QueryWrapper queryWrapper = Condition.getQueryWrapper(BeanUtil.toMap(req), FuncParamEntity.class);
+ return R.data(funcParamService.page(Condition.getPage(query),queryWrapper));
+ }
+
+ @DeleteMapping("/remove")
+ @ApiOperation("删除函数参数")
+ @ApiOperationSupport(order = 4)
+ public R remove(String ids) {
+ return R.data(funcParamService.removeByIds(Func.toLongList(",",ids)));
+ }
+
+}
diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/mapper/FuncParamMapper.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/mapper/FuncParamMapper.java
new file mode 100644
index 0000000..7a9723e
--- /dev/null
+++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/mapper/FuncParamMapper.java
@@ -0,0 +1,11 @@
+package com.hnac.hzims.bigmodel.function.mapper;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.hnac.hzims.bigmodel.entity.FuncParamEntity;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/26 11:11
+ */
+public interface FuncParamMapper extends BaseMapper {
+}
diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/mapper/FunctionMapper.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/mapper/FunctionMapper.java
new file mode 100644
index 0000000..6d0e1c2
--- /dev/null
+++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/mapper/FunctionMapper.java
@@ -0,0 +1,12 @@
+package com.hnac.hzims.bigmodel.function.mapper;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.hnac.hzims.bigmodel.entity.FunctionEntity;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/26 11:10
+ */
+public interface FunctionMapper extends BaseMapper {
+
+}
diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/service/IFuncParamService.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/service/IFuncParamService.java
new file mode 100644
index 0000000..39fae6a
--- /dev/null
+++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/service/IFuncParamService.java
@@ -0,0 +1,21 @@
+package com.hnac.hzims.bigmodel.function.service;
+
+import com.hnac.hzims.bigmodel.entity.FuncParamEntity;
+import org.springblade.core.mp.base.BaseService;
+
+import java.util.List;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/26 11:12
+ */
+public interface IFuncParamService extends BaseService {
+
+ /**
+ * 根据函数ID获取参数列表
+ * @param funcId 函数ID
+ * @return 参数列表
+ */
+ List getParamsByFuncId(Long funcId);
+
+}
diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/service/IFunctionService.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/service/IFunctionService.java
new file mode 100644
index 0000000..6a9e59d
--- /dev/null
+++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/service/IFunctionService.java
@@ -0,0 +1,14 @@
+package com.hnac.hzims.bigmodel.function.service;
+
+import com.hnac.hzims.bigmodel.entity.FunctionEntity;
+import org.springblade.core.mp.base.BaseService;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/26 11:08
+ */
+public interface IFunctionService extends BaseService {
+
+ FunctionEntity getFunctionByCode(String code);
+
+}
diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/service/impl/FuncParamServiceImpl.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/service/impl/FuncParamServiceImpl.java
new file mode 100644
index 0000000..e7e2dae
--- /dev/null
+++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/service/impl/FuncParamServiceImpl.java
@@ -0,0 +1,28 @@
+package com.hnac.hzims.bigmodel.function.service.impl;
+
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
+import com.hnac.hzims.bigmodel.entity.FuncParamEntity;
+import com.hnac.hzims.bigmodel.function.mapper.FuncParamMapper;
+import com.hnac.hzims.bigmodel.function.service.IFuncParamService;
+import lombok.extern.slf4j.Slf4j;
+import org.springblade.core.mp.base.BaseServiceImpl;
+import org.springframework.stereotype.Service;
+
+import java.util.List;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/26 11:13
+ */
+@Service
+@Slf4j
+public class FuncParamServiceImpl extends BaseServiceImpl implements IFuncParamService {
+
+ @Override
+ public List getParamsByFuncId(Long funcId) {
+ LambdaQueryWrapper queryWrapper = Wrappers.lambdaQuery().eq(FuncParamEntity::getFuncId, funcId);
+ return this.list(queryWrapper);
+ }
+
+}
diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/service/impl/FunctionServiceImpl.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/service/impl/FunctionServiceImpl.java
new file mode 100644
index 0000000..0619ddb
--- /dev/null
+++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/function/service/impl/FunctionServiceImpl.java
@@ -0,0 +1,27 @@
+package com.hnac.hzims.bigmodel.function.service.impl;
+
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.core.toolkit.Wrappers;
+import com.hnac.hzims.bigmodel.entity.FunctionEntity;
+import com.hnac.hzims.bigmodel.function.mapper.FunctionMapper;
+import com.hnac.hzims.bigmodel.function.service.IFunctionService;
+import lombok.AllArgsConstructor;
+import lombok.extern.slf4j.Slf4j;
+import org.springblade.core.mp.base.BaseServiceImpl;
+import org.springframework.stereotype.Service;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/26 11:09
+ */
+@Service
+@Slf4j
+@AllArgsConstructor
+public class FunctionServiceImpl extends BaseServiceImpl implements IFunctionService {
+
+ @Override
+ public FunctionEntity getFunctionByCode(String code) {
+ LambdaQueryWrapper queryWrapper = Wrappers.lambdaQuery().eq(FunctionEntity::getCode, code);
+ return this.getOne(queryWrapper);
+ }
+}
diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/interactive/controller/InteractiveController.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/interactive/controller/InteractiveController.java
new file mode 100644
index 0000000..41f3885
--- /dev/null
+++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/interactive/controller/InteractiveController.java
@@ -0,0 +1,45 @@
+package com.hnac.hzims.bigmodel.interactive.controller;
+
+import com.github.xiaoymin.knife4j.annotations.ApiOperationSupport;
+import com.hnac.hzims.bigmodel.BigModelConstants;
+import com.hnac.hzims.bigmodel.interactive.req.ModelFunctionReq;
+import com.hnac.hzims.bigmodel.interactive.service.IInteractiveService;
+import com.hnac.hzinfo.log.annotation.Business;
+import io.swagger.annotations.Api;
+import io.swagger.annotations.ApiModelProperty;
+import io.swagger.annotations.ApiOperation;
+import io.swagger.annotations.ApiParam;
+import lombok.AllArgsConstructor;
+import org.springblade.core.tool.api.R;
+import org.springframework.web.bind.annotation.*;
+
+import javax.servlet.http.HttpServletRequest;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/26 14:51
+ */
+@RestController
+@AllArgsConstructor
+@Api(value = "FDP大模型交互层",tags = "FDP大模型交互层")
+@RequestMapping("/interactive")
+@Business(module = BigModelConstants.MODULE_NAME,value = "FDP大模型交互层")
+public class InteractiveController {
+
+ private final IInteractiveService interactiveService;
+
+ @ApiOperation("解析大模型函数")
+ @ApiOperationSupport(order = 1)
+ @PostMapping("/resolve")
+ public R resolve(@RequestBody ModelFunctionReq req) {
+ return interactiveService.resolve(req);
+ }
+
+ @ApiOperation("提问")
+ @ApiOperationSupport(order = 2)
+ @GetMapping("/ask")
+ public R ask(@RequestParam @ApiParam("用户提出问题") String question, HttpServletRequest request) {
+ return interactiveService.ask(request, question);
+ }
+
+}
diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/interactive/service/IInteractiveService.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/interactive/service/IInteractiveService.java
new file mode 100644
index 0000000..3fe695e
--- /dev/null
+++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/interactive/service/IInteractiveService.java
@@ -0,0 +1,20 @@
+package com.hnac.hzims.bigmodel.interactive.service;
+
+import com.hnac.hzims.bigmodel.interactive.req.ModelFunctionReq;
+import io.swagger.annotations.ApiParam;
+import org.springblade.core.tool.api.R;
+import org.springframework.web.bind.annotation.RequestParam;
+
+import javax.servlet.http.HttpServletRequest;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/26 14:51
+ */
+public interface IInteractiveService {
+
+ R resolve(ModelFunctionReq req);
+
+ R ask(HttpServletRequest request, String question);
+
+}
diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/interactive/service/IJumpPageService.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/interactive/service/IJumpPageService.java
new file mode 100644
index 0000000..fa4f9d5
--- /dev/null
+++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/interactive/service/IJumpPageService.java
@@ -0,0 +1,16 @@
+package com.hnac.hzims.bigmodel.interactive.service;
+
+import com.hnac.hzims.bigmodel.entity.FunctionEntity;
+import com.hnac.hzims.bigmodel.interactive.vo.ExtraVO;
+
+import java.util.Map;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/26 11:46
+ */
+public interface IJumpPageService {
+
+ String dealJumpTypeFunction(FunctionEntity function, Map args);
+
+}
diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/interactive/service/impl/InteractiveServiceImpl.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/interactive/service/impl/InteractiveServiceImpl.java
new file mode 100644
index 0000000..1a2b719
--- /dev/null
+++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/interactive/service/impl/InteractiveServiceImpl.java
@@ -0,0 +1,85 @@
+package com.hnac.hzims.bigmodel.interactive.service.impl;
+
+import cn.hutool.http.HttpRequest;
+import cn.hutool.http.HttpResponse;
+import com.alibaba.fastjson.JSON;
+import com.alibaba.fastjson.JSONObject;
+import com.hnac.hzims.bigmodel.configuration.BigModelInvokeUrl;
+import com.hnac.hzims.bigmodel.entity.FunctionEntity;
+import com.hnac.hzims.bigmodel.interactive.req.ModelFunctionReq;
+import com.hnac.hzims.bigmodel.interactive.service.IInteractiveService;
+import com.hnac.hzims.bigmodel.interactive.service.IJumpPageService;
+import com.hnac.hzims.bigmodel.function.service.IFunctionService;
+import lombok.AllArgsConstructor;
+import lombok.RequiredArgsConstructor;
+import lombok.extern.slf4j.Slf4j;
+import org.springblade.core.log.exception.ServiceException;
+import org.springblade.core.secure.utils.AuthUtil;
+import org.springblade.core.tool.api.R;
+import org.springblade.core.tool.utils.Func;
+import org.springblade.core.tool.utils.StringUtil;
+import org.springframework.beans.factory.annotation.Value;
+import org.springframework.data.redis.core.RedisTemplate;
+import org.springframework.stereotype.Service;
+import org.springframework.util.Assert;
+
+import javax.servlet.http.HttpServletRequest;
+import javax.servlet.http.HttpServletResponse;
+import javax.servlet.http.HttpSession;
+
+import java.util.HashMap;
+import java.util.Map;
+
+import static com.hnac.hzims.bigmodel.interactive.constants.FunctionConstants.*;
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/26 14:51
+ */
+@Service
+@Slf4j
+@RequiredArgsConstructor
+public class InteractiveServiceImpl implements IInteractiveService {
+
+ private final IJumpPageService jumpPageService;
+ private final IFunctionService functionService;
+ private final BigModelInvokeUrl bigModelInvokeUrl;
+ @Value("${fdp.host}")
+ private String fdpHost;
+
+ @Override
+ public R resolve(ModelFunctionReq req) {
+ //TODO 数据鉴权
+ FunctionEntity function = functionService.getFunctionByCode(req.getFunctionName());
+ TypeEnum typeEnum = TypeEnum.getTypeEnumByType(function.getType());
+ switch (typeEnum) {
+ // 页面跳转
+ case JUMP:
+ String extra = jumpPageService.dealJumpTypeFunction(function, req.getFunctionArgs());
+ Assert.isTrue(StringUtil.isNotBlank(extra) && Func.isNotEmpty(extra), () -> {
+ throw new ServiceException("解析" + function.getName() + "函数失败!");
+ });
+ R.data(extra);
+ default:
+ throw new ServiceException("函数解析失败!");
+ }
+ }
+
+ @Override
+ public R ask(HttpServletRequest request, String question) {
+ HttpSession session = request.getSession(true);
+ String sessionId = session.getId();
+ Long userId = AuthUtil.getUserId();
+ //TODO 保存问题
+ Map params = new HashMap<>();
+ params.put("id",sessionId);
+ params.put("userid",userId.toString());
+ params.put("query",question);
+ HttpResponse response = HttpRequest.post(fdpHost + bigModelInvokeUrl.getAssistantAsk())
+ .body(JSON.toJSONString(params)).execute();
+ Assert.isTrue(response.getStatus() == HttpServletResponse.SC_OK && "1".equals(JSONObject.parseObject(response.body()).getString("success")), () -> {
+ throw new ServiceException("远程调用大模型【发起问答】接口失败!");
+ });
+ return R.data(JSONObject.parseObject(response.body()).getString("data"));
+ }
+
+}
diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/interactive/service/impl/JumpPageServiceImpl.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/interactive/service/impl/JumpPageServiceImpl.java
new file mode 100644
index 0000000..2c95d1c
--- /dev/null
+++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/interactive/service/impl/JumpPageServiceImpl.java
@@ -0,0 +1,54 @@
+package com.hnac.hzims.bigmodel.interactive.service.impl;
+
+import com.alibaba.fastjson.JSON;
+import com.hnac.hzims.bigmodel.entity.FuncParamEntity;
+import com.hnac.hzims.bigmodel.entity.FunctionEntity;
+import com.hnac.hzims.bigmodel.function.service.IFuncParamService;
+import com.hnac.hzims.bigmodel.interactive.constants.FunctionConstants;
+import com.hnac.hzims.bigmodel.interactive.service.IJumpPageService;
+import com.hnac.hzims.bigmodel.interactive.vo.ExtraVO;
+import lombok.AllArgsConstructor;
+import lombok.extern.slf4j.Slf4j;
+import org.springblade.core.log.exception.ServiceException;
+import org.springblade.core.tool.utils.StringUtil;
+import org.springframework.stereotype.Service;
+import org.springframework.util.Assert;
+
+import java.util.List;
+import java.util.Map;
+import java.util.Optional;
+import java.util.Set;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/26 11:46
+ */
+@Service
+@AllArgsConstructor
+@Slf4j
+public class JumpPageServiceImpl implements IJumpPageService {
+
+ private final IFuncParamService paramService;
+
+ @Override
+ public String dealJumpTypeFunction(FunctionEntity function,Map args) {
+ List params = paramService.getParamsByFuncId(function.getId());
+ Optional paramOptional = params.stream().filter(p -> !args.containsKey(p)).findAny();
+ Assert.isTrue(!paramOptional.isPresent(), () -> {
+ throw new ServiceException("解析参数失败,缺少参数:" + paramOptional.get().getName());
+ });
+ // 跳转页面逻辑
+ ExtraVO extraVO = new ExtraVO();
+ String path = function.getPath();
+ Set> entries = args.entrySet();
+ // 替换path中变量
+ for (Map.Entry entry : entries) {
+ String replaceVariables = "{" + entry.getKey() + "}";
+ path = StringUtil.replace(path,replaceVariables,entry.getValue());
+ }
+ extraVO.setType(FunctionConstants.TypeEnum.JUMP.getType());
+ extraVO.setRoute(path);
+ // TODO 将结果存入redis中供前端获取
+ return JSON.toJSONString(extraVO);
+ }
+}
diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/schedule/InteractiveSchedule.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/schedule/InteractiveSchedule.java
new file mode 100644
index 0000000..b50c578
--- /dev/null
+++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/schedule/InteractiveSchedule.java
@@ -0,0 +1,58 @@
+package com.hnac.hzims.bigmodel.schedule;
+
+import com.alibaba.fastjson.JSON;
+import com.hnac.hzims.bigmodel.websocket.server.InteractiveWsServer;
+import com.hnac.hzims.bigmodel.websocket.service.InteractiveWsService;
+import com.hnac.hzims.bigmodel.websocket.sessionManager.InteractiveSessionManager;
+import com.xxl.job.core.biz.model.ReturnT;
+import com.xxl.job.core.handler.annotation.XxlJob;
+import lombok.AllArgsConstructor;
+import org.springblade.core.log.exception.ServiceException;
+import org.springblade.core.tool.utils.Func;
+import org.springblade.system.cache.ParamCache;
+import org.springframework.data.redis.core.RedisTemplate;
+import org.springframework.stereotype.Component;
+import org.springframework.util.Assert;
+import org.springframework.web.socket.TextMessage;
+import org.springframework.web.socket.WebSocketSession;
+
+import java.util.List;
+import java.util.Set;
+
+import static com.hnac.hzims.bigmodel.schedule.XxlJobHandlerConstant.*;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/28 16:18
+ */
+@Component
+@AllArgsConstructor
+public class InteractiveSchedule {
+
+ private final RedisTemplate redisTemplate;
+ private final InteractiveWsService wsService;
+
+ @XxlJob(GET_INTERACTIVE_RESULT)
+ public ReturnT execute(String params) {
+ String resultKey = ParamCache.getValue(GET_INTERACTIVE_RESULT);
+ Set keySet = redisTemplate.keys(resultKey + "*");
+ keySet.parallelStream().forEach(key -> {
+ // 根据Key获取sessionId
+ List keySplits = Func.toStrList(":", key);
+ String sessionId = keySplits.get(2);
+ // 查询websocket是否存在连接session
+ WebSocketSession session = InteractiveSessionManager.get(sessionId);
+ if(session == null) {
+ return;
+ }
+ TextMessage message = new TextMessage(JSON.toJSONString(redisTemplate.opsForValue().get(key)));
+ Boolean sendResult = wsService.sendMessage(sessionId, message);
+ Assert.isTrue(sendResult, () -> {
+ throw new ServiceException(key + "推送消息失败,推送消息体为:" + JSON.toJSONString(redisTemplate.opsForValue().get(key)));
+ });
+ redisTemplate.delete(key);
+ });
+ return ReturnT.SUCCESS;
+ }
+
+}
diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/schedule/XxlJobHandlerConstant.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/schedule/XxlJobHandlerConstant.java
new file mode 100644
index 0000000..708d3e8
--- /dev/null
+++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/schedule/XxlJobHandlerConstant.java
@@ -0,0 +1,13 @@
+package com.hnac.hzims.bigmodel.schedule;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/28 16:19
+ */
+public interface XxlJobHandlerConstant {
+
+ String GET_INTERACTIVE_RESULT = "getInteractiveResult";
+
+ String INTERACTIVE_RESULT_KEY = "hzllm:interactive:result";
+
+}
diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/websocket/config/WebSocketConfig.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/websocket/config/WebSocketConfig.java
new file mode 100644
index 0000000..04a4405
--- /dev/null
+++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/websocket/config/WebSocketConfig.java
@@ -0,0 +1,28 @@
+package com.hnac.hzims.bigmodel.websocket.config;
+
+import com.hnac.hzims.bigmodel.websocket.handler.InteractiveHandler;
+import org.springframework.context.annotation.Bean;
+import org.springframework.context.annotation.Configuration;
+import org.springframework.web.socket.WebSocketHandler;
+import org.springframework.web.socket.config.annotation.EnableWebSocket;
+import org.springframework.web.socket.config.annotation.WebSocketConfigurer;
+import org.springframework.web.socket.config.annotation.WebSocketHandlerRegistry;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/28 13:39
+ */
+@Configuration
+@EnableWebSocket
+public class WebSocketConfig implements WebSocketConfigurer {
+
+ @Override
+ public void registerWebSocketHandlers(WebSocketHandlerRegistry registry) {
+ registry.addHandler(interactiveHandler(), "/interactive/{sessionId}").setAllowedOrigins("*");
+ }
+ @Bean
+ public WebSocketHandler interactiveHandler() {
+ return new InteractiveHandler();
+ }
+
+}
diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/websocket/handler/InteractiveHandler.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/websocket/handler/InteractiveHandler.java
new file mode 100644
index 0000000..1e4aae7
--- /dev/null
+++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/websocket/handler/InteractiveHandler.java
@@ -0,0 +1,41 @@
+package com.hnac.hzims.bigmodel.websocket.handler;
+
+import com.hnac.hzims.bigmodel.websocket.sessionManager.InteractiveSessionManager;
+import lombok.extern.slf4j.Slf4j;
+import org.springframework.web.socket.CloseStatus;
+import org.springframework.web.socket.TextMessage;
+import org.springframework.web.socket.WebSocketSession;
+import org.springframework.web.socket.handler.TextWebSocketHandler;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/28 13:45
+ */
+@Slf4j
+public class InteractiveHandler extends TextWebSocketHandler {
+ @Override
+ public void afterConnectionEstablished(WebSocketSession session) {
+ String[] split = session.getUri().toString().split("/");
+ String sessionId = split[split.length - 1];
+ session.getAttributes().put("sessionId", sessionId);
+ InteractiveSessionManager.add(sessionId, session);
+ log.info("sessionId: " + session.getId());
+ log.info("uri: " + session.getUri());
+ log.info("session connection successful!");
+ }
+
+ @Override
+ public void afterConnectionClosed(WebSocketSession session, CloseStatus status) {
+ String[] split = session.getUri().toString().split("/");
+ String sessionId = split[split.length - 1];
+ InteractiveSessionManager.removeAndClose(sessionId);
+ log.info("sessionId: " + session.getId());
+ log.info("uri: " + session.getUri());
+ log.info("session closed successful!");
+ }
+
+ @Override
+ protected void handleTextMessage(WebSocketSession session, TextMessage message) {
+ log.info("message handle successful!");
+ }
+}
diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/websocket/server/InteractiveWsServer.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/websocket/server/InteractiveWsServer.java
new file mode 100644
index 0000000..fdcd940
--- /dev/null
+++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/websocket/server/InteractiveWsServer.java
@@ -0,0 +1,9 @@
+package com.hnac.hzims.bigmodel.websocket.server;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/28 13:38
+ */
+public class InteractiveWsServer {
+
+}
diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/websocket/service/InteractiveWsService.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/websocket/service/InteractiveWsService.java
new file mode 100644
index 0000000..c7cce27
--- /dev/null
+++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/websocket/service/InteractiveWsService.java
@@ -0,0 +1,32 @@
+package com.hnac.hzims.bigmodel.websocket.service;
+
+import com.alibaba.fastjson.JSON;
+import com.hnac.hzims.bigmodel.websocket.sessionManager.InteractiveSessionManager;
+import lombok.extern.slf4j.Slf4j;
+import org.springblade.core.log.exception.ServiceException;
+import org.springframework.stereotype.Service;
+import org.springframework.web.socket.TextMessage;
+import org.springframework.web.socket.WebSocketSession;
+
+import java.io.IOException;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/28 14:35
+ */
+@Service
+@Slf4j
+public class InteractiveWsService implements WebSocketService {
+
+ @Override
+ public Boolean sendMessage(String signage, TextMessage message) {
+ WebSocketSession session = InteractiveSessionManager.get(signage);
+ try {
+ session.sendMessage(message);
+ return true;
+ } catch (IOException e) {
+ log.error("消息推送失败,推送sessionId为:" + signage + ";消息体为:" + JSON.toJSONString(message));
+ return false;
+ }
+ }
+}
diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/websocket/service/WebSocketService.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/websocket/service/WebSocketService.java
new file mode 100644
index 0000000..f4937ad
--- /dev/null
+++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/websocket/service/WebSocketService.java
@@ -0,0 +1,13 @@
+package com.hnac.hzims.bigmodel.websocket.service;
+
+import org.springframework.web.socket.TextMessage;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/28 14:37
+ */
+public interface WebSocketService {
+
+ Boolean sendMessage(String signage, TextMessage message);
+
+}
diff --git a/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/websocket/sessionManager/InteractiveSessionManager.java b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/websocket/sessionManager/InteractiveSessionManager.java
new file mode 100644
index 0000000..6b13bbf
--- /dev/null
+++ b/hzims-service/hzims-big-model/src/main/java/com/hnac/hzims/bigmodel/websocket/sessionManager/InteractiveSessionManager.java
@@ -0,0 +1,56 @@
+package com.hnac.hzims.bigmodel.websocket.sessionManager;
+
+import org.springframework.web.socket.WebSocketSession;
+
+import java.io.IOException;
+import java.util.concurrent.ConcurrentHashMap;
+import java.util.concurrent.locks.Lock;
+import java.util.concurrent.locks.ReentrantLock;
+
+/**
+ * @Author: huangxing
+ * @Date: 2024/04/28 13:58
+ */
+public class InteractiveSessionManager {
+ /** ws会话池 **/
+ public static ConcurrentHashMap SESSION_POOL = new ConcurrentHashMap<>();
+
+ private static final Lock lock = new ReentrantLock();
+
+ /**
+ * 添加会话
+ * @param sessionId 会话ID
+ * @param session 会话对象
+ */
+ public static void add(String sessionId, WebSocketSession session) {
+ if (SESSION_POOL.containsKey(sessionId)) {
+ InteractiveSessionManager.removeAndClose(sessionId);
+ }
+ SESSION_POOL.put(sessionId, session);
+ }
+
+ /**
+ * 获取ws会话
+ * @param sessionId 会话ID
+ */
+ public static WebSocketSession get(String sessionId) {
+ return SESSION_POOL.get(sessionId);
+ }
+
+ /**
+ * 移除ws会话并关闭会话
+ * @param sessionId 会话ID
+ */
+ public static void removeAndClose(String sessionId) {
+ WebSocketSession session = SESSION_POOL.get(sessionId);
+ if (session != null) {
+ try {
+ //关闭连接
+ session.close();
+ } catch (IOException ex) {
+ throw new RuntimeException("关闭ws会话失败!", ex);
+ }
+ }
+ SESSION_POOL.remove(sessionId);
+ }
+}
diff --git a/hzims-service/hzims-big-model/src/main/resources/db/1.0.0.sql b/hzims-service/hzims-big-model/src/main/resources/db/1.0.0.sql
new file mode 100644
index 0000000..2a0cf7e
--- /dev/null
+++ b/hzims-service/hzims-big-model/src/main/resources/db/1.0.0.sql
@@ -0,0 +1,34 @@
+CREATE TABLE IF NOT EXISTS `hzims_function` (
+ `ID` bigint(20) NOT NULL COMMENT '主键ID',
+ `NAME` varchar(50) COLLATE utf8mb4_bin NOT NULL COMMENT '函数名称',
+ `CODE` varchar(25) COLLATE utf8mb4_bin NOT NULL COMMENT '函数编号',
+ `TYPE` varchar(25) COLLATE utf8mb4_bin NOT NULL COMMENT '动作类型',
+ `IS_CONFIRM` tinyint(1) DEFAULT '0' COMMENT '是否需要确认,0:否,1:是',
+ `PATH` varchar(255) COLLATE utf8mb4_bin DEFAULT NULL COMMENT '跳转路径',
+ `REMAKE` varchar(255) COLLATE utf8mb4_bin DEFAULT NULL COMMENT '描述',
+ `TENANT_ID` varchar(12) CHARACTER SET utf8 DEFAULT NULL COMMENT '租户ID',
+ `STATUS` bigint(1) DEFAULT NULL COMMENT '状态',
+ `CREATE_DEPT` bigint(20) DEFAULT NULL COMMENT '创建单位',
+ `CREATE_USER` bigint(20) DEFAULT NULL COMMENT '创建人',
+ `CREATE_TIME` datetime DEFAULT NULL COMMENT '创建时间',
+ `UPDATE_USER` bigint(20) DEFAULT NULL COMMENT '修改人',
+ `UPDATE_TIME` datetime DEFAULT NULL COMMENT '更新时间',
+ `IS_DELETED` tinyint(4) NOT NULL COMMENT '是否删除',
+ PRIMARY KEY (`ID`) USING BTREE
+) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin COMMENT='模型函数';
+
+CREATE TABLE IF NOT EXISTS `hzims_func_param` (
+ `ID` bigint(20) NOT NULL COMMENT '主键ID',
+ `FUNC_ID` bigint(20) NOT NULL COMMENT '主键ID',
+ `NAME` varchar(50) COLLATE utf8mb4_bin NOT NULL COMMENT '参数名称',
+ `ALIAS` varchar(25) COLLATE utf8mb4_bin NOT NULL COMMENT '参数别名',
+ `TENANT_ID` varchar(12) CHARACTER SET utf8 DEFAULT NULL COMMENT '租户ID',
+ `STATUS` bigint(1) DEFAULT NULL COMMENT '状态',
+ `CREATE_DEPT` bigint(20) DEFAULT NULL COMMENT '创建单位',
+ `CREATE_USER` bigint(20) DEFAULT NULL COMMENT '创建人',
+ `CREATE_TIME` datetime DEFAULT NULL COMMENT '创建时间',
+ `UPDATE_USER` bigint(20) DEFAULT NULL COMMENT '修改人',
+ `UPDATE_TIME` datetime DEFAULT NULL COMMENT '更新时间',
+ `IS_DELETED` tinyint(4) NOT NULL COMMENT '是否删除',
+ PRIMARY KEY (`ID`) USING BTREE
+ ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_bin COMMENT='模型函数参数';
\ No newline at end of file
diff --git a/hzims-service/inspect/src/main/java/com/hnac/hzinfo/inspect/task/mapper/TaskMapper.xml b/hzims-service/inspect/src/main/java/com/hnac/hzinfo/inspect/task/mapper/TaskMapper.xml
index 91b24ec..554313c 100644
--- a/hzims-service/inspect/src/main/java/com/hnac/hzinfo/inspect/task/mapper/TaskMapper.xml
+++ b/hzims-service/inspect/src/main/java/com/hnac/hzinfo/inspect/task/mapper/TaskMapper.xml
@@ -15,6 +15,9 @@
and t.PLAN_START_TIME >= #{task.planStartTime}
+
+ and t.PLAN_START_TIME >= #{task.planStartTime}
+
and t.PLAN_END_TIME <= #{task.planEndTime}
diff --git a/hzims-service/pom.xml b/hzims-service/pom.xml
index 05c9914..3bd858a 100644
--- a/hzims-service/pom.xml
+++ b/hzims-service/pom.xml
@@ -28,6 +28,7 @@
hzims-scheduled
hzims-alarm
hzims-basic
+ hzims-big-model