From cfe0b79fbea0fb1d7a5a796e71ada7d3b7812046 Mon Sep 17 00:00:00 2001
From: wlzboy <66905212@qq.com>
Date: 星期一, 15 十二月 2025 22:31:33 +0800
Subject: [PATCH] feat: 企业微信发送微信小程序cetd

---
 ruoyi-admin/src/main/java/com/ruoyi/web/controller/task/SysTaskAttachmentController.java |   72 +++++++++++++++++++++++++++++-------
 1 files changed, 58 insertions(+), 14 deletions(-)

diff --git a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/task/SysTaskAttachmentController.java b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/task/SysTaskAttachmentController.java
index d9e5490..d9545fe 100644
--- a/ruoyi-admin/src/main/java/com/ruoyi/web/controller/task/SysTaskAttachmentController.java
+++ b/ruoyi-admin/src/main/java/com/ruoyi/web/controller/task/SysTaskAttachmentController.java
@@ -1,5 +1,6 @@
 package com.ruoyi.web.controller.task;
 
+import java.util.Date;
 import java.util.List;
 import java.io.File;
 import java.io.FileInputStream;
@@ -9,6 +10,12 @@
 import com.ruoyi.common.utils.WechatUtils;
 import com.ruoyi.common.config.WechatConfig;
 import com.ruoyi.system.domain.SysTask;
+import com.ruoyi.system.domain.SysTaskEmergency;
+import com.ruoyi.system.service.ISysTaskEmergencyService;
+import com.ruoyi.system.service.ISysUserService;
+import com.ruoyi.system.service.ITaskAttachmentSyncService;
+import com.ruoyi.system.service.IWechatAccessTokenService;
+import com.ruoyi.system.task.ITaskAttachmentService;
 import org.springframework.security.access.prepost.PreAuthorize;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.GetMapping;
@@ -38,14 +45,30 @@
     
     @Autowired
     private ISysTaskService sysTaskService;
+
+    @Autowired
+    private ISysUserService sysUserService;
+
+    @Autowired
+    private ITaskAttachmentSyncService taskAttachmentSyncService;
+
+    @Autowired
+    private ITaskAttachmentService taskAttachmentService;
     
     @Autowired
     private WechatConfig wechatConfig;
 
+    @Autowired
+    private ISysTaskEmergencyService sysTaskEmergencyService;
+
+    @Autowired
+    private ISysUserService userService;
+
+    @Autowired
+    private IWechatAccessTokenService wechatAccessTokenService;
     /**
      * 鏌ヨ浠诲姟闄勪欢鍒楄〃
      */
-    @PreAuthorize("@ss.hasPermi('task:general:query')")
     @GetMapping("/list/{taskId}")
     public AjaxResult list(@PathVariable("taskId") Long taskId) {
         SysTask task = sysTaskService.getTaskDetail(taskId);
@@ -55,15 +78,17 @@
     /**
      * 涓婁紶浠诲姟闄勪欢
      */
-    @PreAuthorize("@ss.hasPermi('task:general:edit')")
+
     @Log(title = "浠诲姟闄勪欢", businessType = BusinessType.INSERT)
     @PostMapping("/upload/{taskId}")
     public AjaxResult upload(@PathVariable("taskId") Long taskId, 
                             @RequestParam("file") MultipartFile file,
-                            @RequestParam(value = "category", required = false) String category) {
+                            @RequestParam(value = "category", required = true) String category) {
         try {
-            int result = sysTaskService.uploadAttachment(taskId, file, category);
-            if (result > 0) {
+            Long attachmentId= sysTaskService.uploadAttachment(taskId, file, category);
+            if (attachmentId > 0) {
+                //鍦ㄨ繖閲岃繘琛屽悓姝�
+                SyncAttachmentToImageData(taskId,sysTaskService.getTaskDetail(taskId).getCreatorId(),attachmentId);
                 return success("涓婁紶鎴愬姛");
             } else {
                 return error("涓婁紶澶辫触");
@@ -73,10 +98,30 @@
         }
     }
 
+    private void SyncAttachmentToImageData(Long taskId,Long taskCreatorId, Long attachmentId) {
+       Integer oaUserId= sysUserService.selectUserById(taskCreatorId).getOaUserId();
+        SysTaskEmergency taskEmergency= sysTaskEmergencyService.selectSysTaskEmergencyByTaskId(taskId);
+        if(taskEmergency!=null ){
+            Long serviceOrderId= taskEmergency.getLegacyServiceOrdId();
+            Long dispathOrdId=taskEmergency.getLegacyDispatchOrdId();
+
+            if(serviceOrderId!=null && dispathOrdId!=null){
+                SysTaskAttachment attachment=sysTaskService.getAttachmentById(attachmentId);
+               Long imageDataId= taskAttachmentSyncService.syncAttachmentToImageData(attachment, serviceOrderId, dispathOrdId,oaUserId);
+                //鍚屾鎴愬姛
+                if(imageDataId>0){
+                    attachment.setSyncedToImageData(1);
+                    attachment.setSyncTime(new Date());
+                    attachment.setImageDataId(imageDataId);
+                    taskAttachmentService.updateAttachment(attachment);
+                }
+
+            }
+        }
+    }
     /**
      * 鍒犻櫎浠诲姟闄勪欢
      */
-    @PreAuthorize("@ss.hasPermi('task:general:edit')")
     @Log(title = "浠诲姟闄勪欢", businessType = BusinessType.DELETE)
     @DeleteMapping("/{attachmentId}")
     public AjaxResult remove(@PathVariable("attachmentId") Long attachmentId) {
@@ -94,26 +139,25 @@
     
     /**
      * 浠庡井淇ediaId涓婁紶闄勪欢锛堝井淇″皬绋嬪簭涓撶敤锛�
+     * 浣跨敤搴旂敤绾х紦瀛樼殑AccessToken
      */
-    @PreAuthorize("@ss.hasPermi('task:general:edit')")
     @Log(title = "浠诲姟闄勪欢", businessType = BusinessType.INSERT)
     @PostMapping("/uploadFromWechat/{taskId}")
     public AjaxResult uploadFromWechat(@PathVariable("taskId") Long taskId,
                                        @RequestParam("mediaId") String mediaId,
                                        @RequestParam(value = "category", required = false) String category) {
         try {
-            // 鑾峰彇寰俊AccessToken
-            String accessToken = WechatUtils.getAccessToken(
-                wechatConfig.getAppId(), 
-                wechatConfig.getAppSecret()
-            );
+            // 鑾峰彇寰俊AccessToken锛堜娇鐢ㄥ簲鐢ㄧ骇缂撳瓨锛�
+            String accessToken = wechatAccessTokenService.getAppAccessToken();
             if (accessToken == null || accessToken.isEmpty()) {
                 return error("鑾峰彇寰俊AccessToken澶辫触");
             }
             
             // 閫氳繃mediaId涓婁紶闄勪欢
-            int result = sysTaskService.uploadAttachmentFromWechat(taskId, accessToken, mediaId, category);
-            if (result > 0) {
+            Long attachmentId = sysTaskService.uploadAttachmentFromWechat(taskId, accessToken, mediaId, category);
+            SysTask task=sysTaskService.getTaskDetail(taskId);
+            if (attachmentId > 0) {
+                this.SyncAttachmentToImageData(taskId,task.getCreatorId(),attachmentId);
                 return success("涓婁紶鎴愬姛");
             } else {
                 return error("涓婁紶澶辫触");

--
Gitblit v1.9.1