From a874b928e16320839315b9abcdf2cece1229a424 Mon Sep 17 00:00:00 2001
From: houzhongjian <houzhongyi@126.com>
Date: 星期四, 07 十一月 2024 09:20:38 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 iailab-module-model/iailab-module-model-api/src/main/java/com/iailab/module/model/api/mdk/dto/MdkPredictReqDTO.java           |    2 
 iailab-module-model/iailab-module-model-biz/doc/img_2.png                                                                     |    0 
 iailab-module-model/iailab-module-model-biz/doc/img_7.png                                                                     |    0 
 iailab-module-model/iailab-module-model-biz/doc/img_4.png                                                                     |    0 
 iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/service/impl/PackServiceImpl.java       |   89 ++++++++++++
 iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/entity/PackEntity.java                  |   44 ++++++
 iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/dao/PackDao.java                        |   25 +++
 iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/controller/admin/MpkFileController.java |    6 
 iailab-module-model/iailab-module-model-biz/doc/img_3.png                                                                     |    0 
 iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/controller/admin/PackController.java    |   72 ++++++++++
 iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/vo/PackPageReqVO.java                   |   28 ++++
 iailab-module-model/iailab-module-model-biz/db/mysql.sql                                                                      |   12 +
 iailab-module-model/iailab-module-model-biz/doc/img_5.png                                                                     |    0 
 iailab-module-model/iailab-module-model-biz/doc/img_6.png                                                                     |    0 
 iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/service/PackService.java                |   32 ++++
 iailab-module-model/iailab-module-model-biz/doc/img_1.png                                                                     |    0 
 iailab-module-model/iailab-module-model-biz/src/main/resources/application.yml                                                |    1 
 iailab-module-model/iailab-module-model-biz/src/main/resources/iailmdk.properties                                             |    4 
 iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mdk/predict/PredictModuleHandler.java       |    2 
 iailab-module-model/iailab-module-model-biz/doc/img.png                                                                       |    0 
 iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mdk/factory/PredictItemFactory.java         |    7 
 iailab-module-model/iailab-module-model-biz/doc/c++代码生成.md                                                                    |   71 +++++++++
 22 files changed, 383 insertions(+), 12 deletions(-)

diff --git a/iailab-module-model/iailab-module-model-api/src/main/java/com/iailab/module/model/api/mdk/dto/MdkPredictReqDTO.java b/iailab-module-model/iailab-module-model-api/src/main/java/com/iailab/module/model/api/mdk/dto/MdkPredictReqDTO.java
index c8d1297..6b44ced 100644
--- a/iailab-module-model/iailab-module-model-api/src/main/java/com/iailab/module/model/api/mdk/dto/MdkPredictReqDTO.java
+++ b/iailab-module-model/iailab-module-model-api/src/main/java/com/iailab/module/model/api/mdk/dto/MdkPredictReqDTO.java
@@ -19,7 +19,7 @@
     @NotNull(message="预测时间不能为空")
     private Date predictTime;
 
-    @Schema(description = "预测模块")
+    @Schema(description = "预测模块(管网类型)")
     private String moduleType;
 
     @Schema(description = "预测项编号")
diff --git a/iailab-module-model/iailab-module-model-biz/db/mysql.sql b/iailab-module-model/iailab-module-model-biz/db/mysql.sql
index 9ad3542..9304163 100644
--- a/iailab-module-model/iailab-module-model-biz/db/mysql.sql
+++ b/iailab-module-model/iailab-module-model-biz/db/mysql.sql
@@ -667,3 +667,15 @@
                                  KEY `index_chart_id` (`chart_id`),
                                  CONSTRAINT `chart_id` FOREIGN KEY (`chart_id`) REFERENCES `t_chart` (`id`) ON DELETE CASCADE ON UPDATE RESTRICT
 ) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci COMMENT='图表参数配置';
+
+
+DROP TABLE IF EXISTS `t_mpk_pack`;
+CREATE TABLE `t_mpk_pack`  (
+                               `id` varchar(36) NOT NULL COMMENT 'id',
+                               `pack_name` varchar(50) NOT NULL COMMENT '包名称',
+                               `pack_desc` varchar(50) DEFAULT NULL COMMENT '包描述',
+                               `model_path` varchar(50) DEFAULT NULL COMMENT '模型路径',
+                               `sort` integer DEFAULT NULL COMMENT '排序',
+                               PRIMARY KEY (`id`) USING BTREE,
+                               UNIQUE INDEX uk_pack_name (pack_name)
+) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci COMMENT = 'MDK包名管理' ROW_FORMAT = Dynamic;
\ No newline at end of file
diff --git "a/iailab-module-model/iailab-module-model-biz/doc/c++\344\273\243\347\240\201\347\224\237\346\210\220.md" "b/iailab-module-model/iailab-module-model-biz/doc/c++\344\273\243\347\240\201\347\224\237\346\210\220.md"
index 2543c96..39f2003 100644
--- "a/iailab-module-model/iailab-module-model-biz/doc/c++\344\273\243\347\240\201\347\224\237\346\210\220.md"
+++ "b/iailab-module-model/iailab-module-model-biz/doc/c++\344\273\243\347\240\201\347\224\237\346\210\220.md"
@@ -1,18 +1,79 @@
 # 系统要求
-windows
+Windows10 x64
+
+# 安装SmartEnergyStudio
+SmartEnergyStudio提供标准的c++环境,python环境(python3.7.5及相关依赖包)
 
 # 安装VS2017专业版
 
-# 环境变量
-INCLUDE
+## python开发
+![img.png](img.png)
+## C++开发
+![img_1.png](img_1.png)
+## 通用windows平台开发
+![img_5.png](img_5.png)
+## 使用C++的桌面开发
+![img_6.png](img_6.png)
+![img_7.png](img_7.png)
+
+# 配置环境变量
+## 配置INCLUDE
+VS2017 include
 ```
 D:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\include
 ```
-LIB
+python include
+```
+C:\PYTHON\include
+```
+windows include
+```
+D:\Windows Kits\10\Include\10.0.17763.0\shared
+```
+```
+D:\Windows Kits\10\Include\10.0.17763.0\ucrt
+```
+```
+D:\Windows Kits\10\Include\10.0.17763.0\um
+```
+```
+D:\Windows Kits\10\Include\10.0.17763.0\winrt
+```
+
+
+MDK中间层 include
+```
+C:\Program Files (x86)\IAIL.MDK.Midware\include
+```
+
+![img_2.png](img_2.png)
+## 配置LIB
+VS2017 LIB
 ```
 D:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\lib\x64
 ```
-path
+python LIB
+```
+C:\PYTHON\libs
+```
+
+```
+windows LIB
+```
+D:\Windows Kits\10\Lib\10.0.17763.0\ucrt\x64
+```
+```
+D:\Windows Kits\10\Lib\10.0.17763.0\um\x64
+```
+
+MDK中间层 LIB
+```
+C:\Program Files (x86)\IAIL.MDK.Midware\lib
+```
+
+![img_3.png](img_3.png)
+## 修改path配置cl
 ```
 D:\Program Files (x86)\Microsoft Visual Studio\2017\Professional\VC\Tools\MSVC\14.16.27023\bin\Hostx64\x64
 ```
+![img_4.png](img_4.png)
\ No newline at end of file
diff --git a/iailab-module-model/iailab-module-model-biz/doc/img.png b/iailab-module-model/iailab-module-model-biz/doc/img.png
new file mode 100644
index 0000000..02f576c
--- /dev/null
+++ b/iailab-module-model/iailab-module-model-biz/doc/img.png
Binary files differ
diff --git a/iailab-module-model/iailab-module-model-biz/doc/img_1.png b/iailab-module-model/iailab-module-model-biz/doc/img_1.png
new file mode 100644
index 0000000..8d1335f
--- /dev/null
+++ b/iailab-module-model/iailab-module-model-biz/doc/img_1.png
Binary files differ
diff --git a/iailab-module-model/iailab-module-model-biz/doc/img_2.png b/iailab-module-model/iailab-module-model-biz/doc/img_2.png
new file mode 100644
index 0000000..02978f6
--- /dev/null
+++ b/iailab-module-model/iailab-module-model-biz/doc/img_2.png
Binary files differ
diff --git a/iailab-module-model/iailab-module-model-biz/doc/img_3.png b/iailab-module-model/iailab-module-model-biz/doc/img_3.png
new file mode 100644
index 0000000..cf854c8
--- /dev/null
+++ b/iailab-module-model/iailab-module-model-biz/doc/img_3.png
Binary files differ
diff --git a/iailab-module-model/iailab-module-model-biz/doc/img_4.png b/iailab-module-model/iailab-module-model-biz/doc/img_4.png
new file mode 100644
index 0000000..dd32f89
--- /dev/null
+++ b/iailab-module-model/iailab-module-model-biz/doc/img_4.png
Binary files differ
diff --git a/iailab-module-model/iailab-module-model-biz/doc/img_5.png b/iailab-module-model/iailab-module-model-biz/doc/img_5.png
new file mode 100644
index 0000000..57a42ba
--- /dev/null
+++ b/iailab-module-model/iailab-module-model-biz/doc/img_5.png
Binary files differ
diff --git a/iailab-module-model/iailab-module-model-biz/doc/img_6.png b/iailab-module-model/iailab-module-model-biz/doc/img_6.png
new file mode 100644
index 0000000..ce50a46
--- /dev/null
+++ b/iailab-module-model/iailab-module-model-biz/doc/img_6.png
Binary files differ
diff --git a/iailab-module-model/iailab-module-model-biz/doc/img_7.png b/iailab-module-model/iailab-module-model-biz/doc/img_7.png
new file mode 100644
index 0000000..a90d314
--- /dev/null
+++ b/iailab-module-model/iailab-module-model-biz/doc/img_7.png
Binary files differ
diff --git a/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mdk/factory/PredictItemFactory.java b/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mdk/factory/PredictItemFactory.java
index 1290ff6..0095127 100644
--- a/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mdk/factory/PredictItemFactory.java
+++ b/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mdk/factory/PredictItemFactory.java
@@ -1,6 +1,7 @@
 package com.iailab.module.model.mdk.factory;
 
 import com.iailab.module.model.mcs.pre.entity.MmItemTypeEntity;
+import com.iailab.module.model.mdk.predict.PredictItemHandler;
 import lombok.extern.slf4j.Slf4j;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.context.ApplicationContext;
@@ -25,16 +26,16 @@
      * @param itemId
      * @return
      */
-    public Object create(String itemId) {
+    public PredictItemHandler create(String itemId) {
         MmItemTypeEntity itemTypeEntity = itemEntityFactory.getMmItemTypeEntity(itemId);
         //获取预测项的预测程序的类
         Object itemObject = null;
         try {
-            Class clazz = Class.forName(itemTypeEntity.getItemclasstype());
+            Class<?> clazz = Class.forName(itemTypeEntity.getItemclasstype());
             itemObject = applicationContext.getBean(clazz);
         } catch (Exception e) {
             log.error("exception message : {}", e.getMessage());
         }
-        return itemObject;
+        return (PredictItemHandler) itemObject;
     }
 }
diff --git a/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mdk/predict/PredictModuleHandler.java b/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mdk/predict/PredictModuleHandler.java
index a43780e..d5f4515 100644
--- a/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mdk/predict/PredictModuleHandler.java
+++ b/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mdk/predict/PredictModuleHandler.java
@@ -42,7 +42,7 @@
                 continue;
             }
             try {
-                PredictItemHandler predictItemHandler = (PredictItemHandler)predictItemFactory.create(predictItem.getId());
+                PredictItemHandler predictItemHandler = predictItemFactory.create(predictItem.getId());
                 Instant start = Instant.now();
                 try {
                     predictResult = predictItemHandler.predict(predictTime, predictItem);
diff --git a/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/controller/admin/MpkFileController.java b/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/controller/admin/MpkFileController.java
index 8f8ebed..74f7a1b 100644
--- a/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/controller/admin/MpkFileController.java
+++ b/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/controller/admin/MpkFileController.java
@@ -4,6 +4,7 @@
 import com.iailab.framework.common.pojo.CommonResult;
 import com.iailab.module.model.mpk.dto.MpkFileDTO;
 import com.iailab.module.model.mpk.service.MpkFileService;
+import com.iailab.module.model.mpk.service.PackService;
 import io.swagger.v3.oas.annotations.Operation;
 import org.apache.commons.io.IOUtils;
 import org.springframework.beans.factory.annotation.Autowired;
@@ -29,6 +30,9 @@
 public class MpkFileController {
     @Autowired
     private MpkFileService mpkFileService;
+
+    @Autowired
+    private PackService packService;
 
     @GetMapping("page")
     @Operation(summary = "分页")
@@ -66,6 +70,7 @@
                 dto.setGroupName(dto.getMenuAndGroup().get(1));
             }
         }
+        dto.setPyModule(packService.getModelPath(dto.getClassName()));
         mpkFileService.save(dto);
         return CommonResult.success(true);
     }
@@ -86,6 +91,7 @@
                 dto.setGroupName(dto.getMenuAndGroup().get(1));
             }
         }
+        dto.setPyModule(packService.getModelPath(dto.getClassName()));
         mpkFileService.update(dto);
         return CommonResult.success(true);
     }
diff --git a/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/controller/admin/PackController.java b/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/controller/admin/PackController.java
new file mode 100644
index 0000000..86ea0e9
--- /dev/null
+++ b/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/controller/admin/PackController.java
@@ -0,0 +1,72 @@
+package com.iailab.module.model.mpk.controller.admin;
+
+import com.iailab.framework.common.pojo.CommonResult;
+import com.iailab.framework.common.pojo.PageResult;
+import com.iailab.framework.common.util.object.BeanUtils;
+import com.iailab.module.model.mpk.entity.PackEntity;
+import com.iailab.module.model.mpk.service.PackService;
+import com.iailab.module.model.mpk.vo.PackPageReqVO;
+import io.swagger.v3.oas.annotations.Operation;
+import io.swagger.v3.oas.annotations.tags.Tag;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.web.bind.annotation.*;
+
+import javax.validation.Valid;
+import java.util.List;
+
+import static com.iailab.framework.common.pojo.CommonResult.success;
+
+/**
+ * @author PanZhibao
+ * @Description
+ * @createTime 2024年11月05日
+ */
+@Tag(name = "模型服务 - MDK包名管理")
+@RestController
+@RequestMapping("/model/mpk/pack")
+public class PackController {
+
+    @Autowired
+    private PackService packService;
+
+    @GetMapping("/page")
+    @Operation(summary = "获得分页")
+    public CommonResult<PageResult<PackEntity>> page(@Valid PackPageReqVO reqVO) {
+        PageResult<PackEntity> page = packService.page(reqVO);
+        return success(BeanUtils.toBean(page, PackEntity.class));
+    }
+
+    @GetMapping("/list")
+    @Operation(summary = "获得列表")
+    public CommonResult<List<PackEntity>> list() {
+        List<PackEntity> list = packService.list();
+        return success(list);
+    }
+
+    @GetMapping("/get")
+    @Operation(summary = "获得详情")
+    public CommonResult<PackEntity> get(@RequestParam("id") String id) {
+        PackEntity data = packService.get(id);
+        return success(data);
+    }
+
+    @PostMapping("/create")
+    @Operation(summary = "创建")
+    public CommonResult<Boolean> save(@Valid @RequestBody PackEntity entity) {
+        packService.create(entity);
+        return success(true);
+    }
+
+    @PutMapping("/update")
+    @Operation(summary = "更新")
+    public CommonResult<Boolean> update(@Valid @RequestBody PackEntity entity) {
+        packService.update(entity);
+        return success(true);
+    }
+
+    @DeleteMapping("/delete")
+    public CommonResult<Boolean> delete(@RequestParam("id") String id) {
+        packService.delete(id);
+        return success(true);
+    }
+}
\ No newline at end of file
diff --git a/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/dao/PackDao.java b/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/dao/PackDao.java
new file mode 100644
index 0000000..d0e212d
--- /dev/null
+++ b/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/dao/PackDao.java
@@ -0,0 +1,25 @@
+package com.iailab.module.model.mpk.dao;
+
+import com.iailab.framework.common.pojo.PageResult;
+import com.iailab.framework.mybatis.core.mapper.BaseMapperX;
+import com.iailab.framework.mybatis.core.query.LambdaQueryWrapperX;
+import com.iailab.framework.tenant.core.db.dynamic.TenantDS;
+import com.iailab.module.model.mpk.entity.PackEntity;
+import com.iailab.module.model.mpk.vo.PackPageReqVO;
+import org.apache.ibatis.annotations.Mapper;
+
+/**
+ * @author PanZhibao
+ * @Description
+ * @createTime 2024年11月05日
+ */
+@TenantDS
+@Mapper
+public interface PackDao extends BaseMapperX<PackEntity> {
+
+    default PageResult<PackEntity> selectPage(PackPageReqVO reqVO) {
+        return selectPage(reqVO, new LambdaQueryWrapperX<PackEntity>()
+                .likeIfPresent(PackEntity::getPackName, reqVO.getPackName())
+                .orderByDesc(PackEntity::getSort).orderByAsc(PackEntity::getPackName));
+    }
+}
\ No newline at end of file
diff --git a/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/entity/PackEntity.java b/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/entity/PackEntity.java
new file mode 100644
index 0000000..addf9fa
--- /dev/null
+++ b/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/entity/PackEntity.java
@@ -0,0 +1,44 @@
+package com.iailab.module.model.mpk.entity;
+
+import com.baomidou.mybatisplus.annotation.TableId;
+import com.baomidou.mybatisplus.annotation.TableName;
+import lombok.Data;
+
+import java.io.Serializable;
+
+/**
+ * @author PanZhibao
+ * @Description
+ * @createTime 2024年11月05日
+ */
+@Data
+@TableName("t_mpk_pack")
+public class PackEntity implements Serializable {
+    private static final long serialVersionUID = 1L;
+
+    /**
+     * id
+     */
+    @TableId
+    private String id;
+
+    /**
+     * 包名称
+     */
+    private String packName;
+
+    /**
+     * 包描述
+     */
+    private String packDesc;
+
+    /**
+     * 模型路径
+     */
+    private String modelPath;
+
+    /**
+     * 排序
+     */
+    private Integer sort;
+}
\ No newline at end of file
diff --git a/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/service/PackService.java b/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/service/PackService.java
new file mode 100644
index 0000000..a9c660b
--- /dev/null
+++ b/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/service/PackService.java
@@ -0,0 +1,32 @@
+package com.iailab.module.model.mpk.service;
+
+import com.iailab.framework.common.pojo.PageResult;
+import com.iailab.module.model.mpk.entity.PackEntity;
+import com.iailab.module.model.mpk.vo.PackPageReqVO;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * @author PanZhibao
+ * @Description
+ * @createTime 2024年11月05日
+ */
+public interface PackService {
+
+    PageResult<PackEntity> page(PackPageReqVO reqVO);
+
+    List<PackEntity> list();
+
+    void create(PackEntity entity);
+
+    void update(PackEntity entity);
+
+    PackEntity get(String id);
+
+    void delete(String id);
+
+    Map<String, PackEntity> getNameMap();
+
+    String getModelPath(String packName);
+}
diff --git a/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/service/impl/PackServiceImpl.java b/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/service/impl/PackServiceImpl.java
new file mode 100644
index 0000000..2816e08
--- /dev/null
+++ b/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/service/impl/PackServiceImpl.java
@@ -0,0 +1,89 @@
+package com.iailab.module.model.mpk.service.impl;
+
+import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
+import com.iailab.framework.common.pojo.PageResult;
+import com.iailab.module.model.mpk.dao.PackDao;
+import com.iailab.module.model.mpk.entity.PackEntity;
+import com.iailab.module.model.mpk.service.PackService;
+import com.iailab.module.model.mpk.vo.PackPageReqVO;
+import lombok.extern.slf4j.Slf4j;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Service;
+import org.springframework.util.CollectionUtils;
+
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
+import java.util.UUID;
+
+/**
+ * @author PanZhibao
+ * @Description
+ * @createTime 2024年11月05日
+ */
+@Slf4j
+@Service
+public class PackServiceImpl implements PackService {
+
+    @Autowired
+    private PackDao iconDao;
+
+    @Override
+    public PageResult<PackEntity> page(PackPageReqVO reqVO) {
+        return iconDao.selectPage(reqVO);
+    }
+
+    @Override
+    public List<PackEntity> list() {
+        QueryWrapper<PackEntity> qw = new QueryWrapper<>();
+        qw.orderByAsc("sort");
+        return iconDao.selectList(qw);
+    }
+
+    @Override
+    public Map<String, PackEntity> getNameMap() {
+        Map<String, PackEntity> map = new HashMap<>();
+        QueryWrapper<PackEntity> qw = new QueryWrapper<>();
+        List<PackEntity> list = iconDao.selectList(qw);
+        if (CollectionUtils.isEmpty(list)) {
+            return map;
+        }
+        list.forEach(packEntity -> {
+            map.put(packEntity.getPackName(), packEntity);
+        });
+        return map;
+    }
+
+    @Override
+    public String getModelPath(String packName) {
+        QueryWrapper<PackEntity> qw = new QueryWrapper<>();
+        qw.eq("pack_name", packName);
+        PackEntity packEntity = iconDao.selectOne(qw);
+
+        if (packEntity == null) {
+            return null;
+        }
+        return packEntity.getModelPath();
+    }
+
+    @Override
+    public void create(PackEntity entity) {
+        entity.setId(UUID.randomUUID().toString());
+        iconDao.insert(entity);
+    }
+
+    @Override
+    public void update(PackEntity entity) {
+        iconDao.updateById(entity);
+    }
+
+    @Override
+    public PackEntity get(String id) {
+        return iconDao.selectById(id);
+    }
+
+    @Override
+    public void delete(String id) {
+        iconDao.deleteById(id);
+    }
+}
\ No newline at end of file
diff --git a/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/vo/PackPageReqVO.java b/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/vo/PackPageReqVO.java
new file mode 100644
index 0000000..3e5d4f2
--- /dev/null
+++ b/iailab-module-model/iailab-module-model-biz/src/main/java/com/iailab/module/model/mpk/vo/PackPageReqVO.java
@@ -0,0 +1,28 @@
+package com.iailab.module.model.mpk.vo;
+
+/**
+ * @author PanZhibao
+ * @Description
+ * @createTime 2024年11月05日
+ */
+
+import com.iailab.framework.common.pojo.PageParam;
+import io.swagger.v3.oas.annotations.media.Schema;
+import lombok.Data;
+import lombok.EqualsAndHashCode;
+import lombok.ToString;
+
+/**
+ * @author PanZhibao
+ * @Description
+ * @createTime 2024年09月22日
+ */
+@Schema(description = "模型服务 - MDK包名称分页 Request VO")
+@Data
+@EqualsAndHashCode(callSuper = true)
+@ToString(callSuper = true)
+public class PackPageReqVO extends PageParam {
+
+    @Schema(description = "包名称名称,模糊匹配", example = "")
+    private String packName;
+}
\ No newline at end of file
diff --git a/iailab-module-model/iailab-module-model-biz/src/main/resources/application.yml b/iailab-module-model/iailab-module-model-biz/src/main/resources/application.yml
index 2ff033f..b5c27ae 100644
--- a/iailab-module-model/iailab-module-model-biz/src/main/resources/application.yml
+++ b/iailab-module-model/iailab-module-model-biz/src/main/resources/application.yml
@@ -217,6 +217,7 @@
       - t_mpk_file_group
       - t_chart_param
       - t_chart
+      - t_mpk_pack
   app:
     app-key: model
     app-secret: 85b0df7edc3df3611913df34ed695011
diff --git a/iailab-module-model/iailab-module-model-biz/src/main/resources/iailmdk.properties b/iailab-module-model/iailab-module-model-biz/src/main/resources/iailmdk.properties
index 29be6da..faf65b9 100644
--- a/iailab-module-model/iailab-module-model-biz/src/main/resources/iailmdk.properties
+++ b/iailab-module-model/iailab-module-model-biz/src/main/resources/iailmdk.properties
@@ -1,4 +1,4 @@
 #dev
-#mdk-init-path = D:\\SmartEnergyStudio\\IAILMDK\\libs\\
+mdk-init-path = D:\\DLUT\\mpkResources\\libs\\
 #prod
-mdk-init-path = D:\\SmartEnergyStudio\\IAILMDK\\libs\\
\ No newline at end of file
+#mdk-init-path = D:\\SmartEnergyStudio\\IAILMDK\\libs\\
\ No newline at end of file

--
Gitblit v1.9.3