From 6f6e5c91056f0d5ebde632f27443b76bffac1aef Mon Sep 17 00:00:00 2001
From: 2369059705@qq.com <2369059705@qq.com>
Date: 星期六, 27 五月 2023 15:36:20 +0800
Subject: [PATCH] 解决了文档权限问题

---
 src/main/java/com/product/file/service/DocumentService.java |   43 ++++++++++++++++++++++++++++++++-----------
 1 files changed, 32 insertions(+), 11 deletions(-)

diff --git a/src/main/java/com/product/file/service/DocumentService.java b/src/main/java/com/product/file/service/DocumentService.java
index b4032a7..526e10c 100644
--- a/src/main/java/com/product/file/service/DocumentService.java
+++ b/src/main/java/com/product/file/service/DocumentService.java
@@ -17,11 +17,12 @@
 import com.product.file.config.CmnConst;
 import com.product.file.service.ide.IDocumentService;
 import com.product.module.sys.entity.SystemUser;
-import com.product.org.admin.service.OrganizationServiceV2;
 import com.product.util.BaseUtil;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Component;
 
+import java.util.ArrayList;
+import java.util.Arrays;
 import java.util.List;
 import java.util.Map;
 
@@ -48,8 +49,6 @@
 
     @Autowired
     DocumentDirectoryService documentDirectoryService;
-    @Autowired
-    OrganizationServiceV2 organizationServiceV2;
 
     @Override
     @Transactional
@@ -225,9 +224,17 @@
         baseDao.add(dataTableEntity);
     }
 
-    public boolean verifyOrgExist(String org, Integer user_id) {
+    public boolean verifyOrgExist(String org) {
+        Integer user_id = SpringMVCContextHolder.getCurrentUser().getUser_id();
+        String code = SpringMVCContextHolder.getCurrentUser().getCurrentStaff().getString("tricode");
+        //鑾峰彇鎵�鏈変笂绾х紪鐮�
+        String[] superior_code = new String[code.split("-").length - 1];
+        for (int i = 0; i < code.split("-").length - 1; i++) {
+            superior_code[i] = code.substring(0, code.length() - ((i + 1) * 4));
+        }
         String this_user = String.valueOf(user_id);
-        String[][] orgArr = organizationServiceV2.decomposesMultipleTypeValues(org);
+        SpringMVCContextHolder.getCurrentUser().getLanguageCode();
+        String[][] orgArr = BaseUtil.decomposesMultipleTypeValues(org);
         String[] user = orgArr[3];
         if (null != user) {
             for (int i = 0; i < user.length; i++) {
@@ -238,14 +245,28 @@
         }
         String[] level = orgArr[0];
         String[] dept = orgArr[1];
-        String[] post = orgArr[2];
+        // List<String> list = Arrays.asList(a);  --OK
+        // List<String> list = Arrays.asList("A","B","C"); --OK
+        // list.add("F"); --UnsupportedOperationException
+        // list.remove("A"); --UnsupportedOperationException
+        // list.set(1,"javaee");--OK (鍥犱负鏄妸鏁扮粍杞负闆嗗悎锛屽叾鏈川杩樻槸鏁扮粍锛屾暟缁勯暱搴﹀浐瀹氫笉鍙橈紝浣嗗唴瀹瑰彲浠ユ敼鍙�)
+        // 缁撹锛氳櫧鐒跺彲浠ユ妸鏁扮粍杞负闆嗗悎锛屼絾鏄泦鍚堥暱搴︿笉鑳芥敼鍙�
+        List list = new ArrayList();
+        ;
         if (null != level) {
-            DataTableEntity org_level_uuid = baseDao.listTable(CmnConst.PRODUCT_SYS_STAFFS, BaseUtil.buildQuestionMarkFilter("org_level_uuid", level, true) + " and user_id=?", new String[]{this_user});
-            if (org_level_uuid.getRows() > 0) return true;
+            list.addAll(Arrays.asList(level));
         }
         if (null != dept) {
-            DataTableEntity dept_uuid = baseDao.listTable(CmnConst.PRODUCT_SYS_STAFFS, BaseUtil.buildQuestionMarkFilter("dept_uuid", dept, true) + " and user_id=?", new String[]{this_user});
-            if (dept_uuid.getRows() > 0) return true;
+            list.addAll(Arrays.asList(dept));
+        }
+        String[] level_dept = new String[list.size()];
+        list.toArray(level_dept);
+
+
+        String[] post = orgArr[2];
+        if (level_dept.length != 0) {
+            DataTableEntity org_level_uuid = baseDao.listTable(CmnConst.TABLE_PRODUCT_SYS_ORG_LEVELS, BaseUtil.buildQuestionMarkFilter("uuid", level_dept, true) + " and " + BaseUtil.buildQuestionMarkFilter("org_level_code", superior_code, true), new String[]{});
+            if (org_level_uuid.getRows() > 0) return true;
         }
         if (null != post) {
             DataTableEntity post_uuid = baseDao.listTable(CmnConst.PRODUCT_SYS_STAFFS, BaseUtil.buildQuestionMarkFilter("job_post_uuid", post, true) + " and user_id=?", new String[]{this_user});
@@ -268,7 +289,7 @@
             //String key = "%,140,%";
             DataTableEntity dataTableEntity = new DataTableEntity();
             FieldSetEntity org = baseDao.getFieldSetByFilter(CmnConst.product_oa_DIRECTORY_RIGHTS, "directory_uuid=?", new String[]{directory_uuid}, false);
-            if (verifyOrgExist(org.getString("storage_uuid"), user_id)) {
+            if (verifyOrgExist(org.getString("storage_uuid"))) {
                 StringBuffer sql = new StringBuffer();
                 sql.append(" SELECT  substring_index(substring_index(a.rigths,',',b.help_topic_id+1),',',-1) fun FROM  product_oa_directory_rights a ")
                         .append(" INNER join   mysql.help_topic b on b.help_topic_id < (length(a.rigths) - length(replace(a.rigths,',',''))+1) ")

--
Gitblit v1.9.2