From 6ad5c2cdc193cf7bb02884961b7434cd7f607a0d Mon Sep 17 00:00:00 2001
From: 云 <2163098428@qq.com>
Date: 星期四, 16 四月 2026 10:48:09 +0800
Subject: [PATCH] feat(production): 扩展生产工艺路线支持多产品绑定及工单权限控制

---
 src/main/java/com/ruoyi/production/service/impl/ProductWorkOrderServiceImpl.java |   44 +++++++++++++++++++++++++++++++-------------
 1 files changed, 31 insertions(+), 13 deletions(-)

diff --git a/src/main/java/com/ruoyi/production/service/impl/ProductWorkOrderServiceImpl.java b/src/main/java/com/ruoyi/production/service/impl/ProductWorkOrderServiceImpl.java
index 4a68ce8..91d9639 100644
--- a/src/main/java/com/ruoyi/production/service/impl/ProductWorkOrderServiceImpl.java
+++ b/src/main/java/com/ruoyi/production/service/impl/ProductWorkOrderServiceImpl.java
@@ -1,25 +1,22 @@
 package com.ruoyi.production.service.impl;
 
-
 import com.baomidou.mybatisplus.core.metadata.IPage;
 import com.baomidou.mybatisplus.core.toolkit.CollectionUtils;
 import com.baomidou.mybatisplus.core.toolkit.Wrappers;
 import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.deepoove.poi.XWPFTemplate;
-import com.deepoove.poi.config.Configure;
 import com.deepoove.poi.data.PictureRenderData;
 import com.deepoove.poi.data.Pictures;
-import com.ruoyi.common.utils.HackLoopTableRenderPolicy;
+import com.ruoyi.common.constant.Constants;
 import com.ruoyi.common.utils.MatrixToImageWriter;
+import com.ruoyi.common.utils.SecurityUtils;
 import com.ruoyi.production.dto.ProductWorkOrderDto;
 import com.ruoyi.production.mapper.ProductWorkOrderFileMapper;
 import com.ruoyi.production.mapper.ProductWorkOrderMapper;
 import com.ruoyi.production.pojo.ProductWorkOrder;
 import com.ruoyi.production.pojo.ProductWorkOrderFile;
 import com.ruoyi.production.service.ProductWorkOrderService;
-import com.ruoyi.quality.pojo.QualityInspectParam;
-import lombok.AllArgsConstructor;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.beans.factory.annotation.Value;
 import org.springframework.stereotype.Service;
@@ -48,16 +45,26 @@
 
     @Override
     public IPage<ProductWorkOrderDto> listPage(Page<ProductWorkOrderDto> page, ProductWorkOrderDto productWorkOrder) {
-        return productWorkOrdermapper.pageProductWorkOrder(page, productWorkOrder);
+        Long userId = SecurityUtils.getUserId();
+        boolean isAdmin = SecurityUtils.isAdmin(userId) || SecurityUtils.hasRole(Constants.SUPER_ADMIN);
+        return productWorkOrdermapper.pageProductWorkOrder(page, productWorkOrder, userId, isAdmin);
     }
 
     @Override
     public int updateProductWorkOrder(ProductWorkOrderDto productWorkOrderDto) {
+        checkWorkOrderPermission(productWorkOrderDto.getId());
         return productWorkOrdermapper.updateById(productWorkOrderDto);
     }
 
     @Override
+    public ProductWorkOrder getProductWorkOrderById(Long id) {
+        checkWorkOrderPermission(id);
+        return this.getById(id);
+    }
+
+    @Override
     public void down(HttpServletResponse response, ProductWorkOrder productWorkOrder) {
+        checkWorkOrderPermission(productWorkOrder.getId());
         ProductWorkOrderDto productWorkOrderDto = productWorkOrdermapper.getProductWorkOrderFlowCard(productWorkOrder.getId());
         String codePath;
         try {
@@ -65,13 +72,12 @@
         } catch (Exception e) {
             throw new RuntimeException(e);
         }
-        /*鑾峰彇闄勪欢鍥剧墖绫诲瀷*/
         List<Map<String, Object>> images = new ArrayList<>();
         List<ProductWorkOrderFile> productWorkOrderFiles = productWorkOrderFileMapper.selectList(Wrappers.<ProductWorkOrderFile>lambdaQuery().eq(ProductWorkOrderFile::getWorkOrderId, productWorkOrder.getId()));
         if (CollectionUtils.isNotEmpty(productWorkOrderFiles)) {
             productWorkOrderFiles.forEach(productWorkOrderFile -> {
                 Map<String, Object> image = new HashMap<>();
-                PictureRenderData pictureRenderData = Pictures.ofLocal( productWorkOrderFile.getUrl()).sizeInCm(17, 20).create();
+                PictureRenderData pictureRenderData = Pictures.ofLocal(productWorkOrderFile.getUrl()).sizeInCm(17, 20).create();
                 image.put("url", pictureRenderData);
                 images.add(image);
             });
@@ -92,16 +98,14 @@
                     put("actualStartTime", productWorkOrderDto.getActualStartTime());
                     put("actualEndTime", productWorkOrderDto.getActualEndTime());
                     put("twoCode", Pictures.ofLocal(codePath).create());
-                    put("images", images.isEmpty()?null:images);
+                    put("images", images.isEmpty() ? null : images);
                 }});
 
         try {
             response.setContentType("application/msword");
-            String fileName = URLEncoder.encode(
-                    "娴佽浆鍗�", "UTF-8");
+            String fileName = URLEncoder.encode("娴佽浆鍗�", "UTF-8");
             response.setHeader("Access-Control-Expose-Headers", "Content-Disposition");
-            response.setHeader("Content-disposition",
-                    "attachment;filename=" + fileName + ".docx");
+            response.setHeader("Content-disposition", "attachment;filename=" + fileName + ".docx");
             OutputStream os = response.getOutputStream();
             template.write(os);
             os.flush();
@@ -113,4 +117,18 @@
         }
     }
 
+    private void checkWorkOrderPermission(Long workOrderId) {
+        if (workOrderId == null) {
+            throw new RuntimeException("宸ュ崟ID涓嶈兘涓虹┖");
+        }
+        Long userId = SecurityUtils.getUserId();
+        boolean isAdmin = SecurityUtils.isAdmin(userId) || SecurityUtils.hasRole(Constants.SUPER_ADMIN);
+        if (isAdmin) {
+            return;
+        }
+        Integer count = productWorkOrdermapper.checkUserCanAccess(workOrderId, userId);
+        if (count == null || count == 0) {
+            throw new RuntimeException("鏃犳潈璁块棶璇ュ伐鍗�");
+        }
+    }
 }

--
Gitblit v1.9.3