From 8458e64aab474c0fc2f49ae4ff22fb11ce5cf6e2 Mon Sep 17 00:00:00 2001
From: “djh” <“3298565835@qq.com”>
Date: 星期一, 11 十一月 2024 16:55:28 +0800
Subject: [PATCH] 批次新增学员查询条件,新增题目导入接口

---
 exam-system/src/main/java/com/gkhy/exam/system/service/impl/ExResourceServiceImpl.java |  113 ++++++++++++++++++++++++++++++++++++++++++++++----------
 1 files changed, 93 insertions(+), 20 deletions(-)

diff --git a/exam-system/src/main/java/com/gkhy/exam/system/service/impl/ExResourceServiceImpl.java b/exam-system/src/main/java/com/gkhy/exam/system/service/impl/ExResourceServiceImpl.java
index 1defc76..200e266 100644
--- a/exam-system/src/main/java/com/gkhy/exam/system/service/impl/ExResourceServiceImpl.java
+++ b/exam-system/src/main/java/com/gkhy/exam/system/service/impl/ExResourceServiceImpl.java
@@ -2,20 +2,22 @@
 
 import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
 import com.gkhy.exam.common.api.CommonPage;
+import com.gkhy.exam.common.config.MinioConfig;
 import com.gkhy.exam.common.constant.UserConstant;
 import com.gkhy.exam.common.domain.entity.SysUser;
 import com.gkhy.exam.common.enums.PrivatizeEnum;
+import com.gkhy.exam.common.enums.ResourceTypeEnum;
 import com.gkhy.exam.common.enums.UserTypeEnum;
 import com.gkhy.exam.common.exception.ApiException;
 import com.gkhy.exam.common.utils.PageUtils;
 import com.gkhy.exam.common.utils.SecurityUtils;
 import com.gkhy.exam.system.domain.ExResource;
-import com.gkhy.exam.system.domain.vo.UploadObjectVO;
 import com.gkhy.exam.system.mapper.ExResourceMapper;
 import com.gkhy.exam.system.service.ExResourceService;
 import com.gkhy.exam.system.service.SysCommonService;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
 
 import java.util.List;
 
@@ -31,6 +33,12 @@
 public class ExResourceServiceImpl extends ServiceImpl<ExResourceMapper, ExResource> implements ExResourceService {
     @Autowired
     private SysCommonService commonService;
+
+    @Autowired
+    private MinioConfig minioConfig;
+
+
+
     @Override
     public CommonPage selectResourseList(ExResource resource) {
         SysUser currentUser = SecurityUtils.getLoginUser().getUser();
@@ -39,47 +47,78 @@
         }
         PageUtils.startPage();
         List<ExResource> resourceList=baseMapper.selectResourceList(resource);
+        resourceList.forEach(item -> {
+            item.setResourcePath(minioConfig.getEndpoint()+minioConfig.getBucketName()+"/"+item.getResourcePath());
+        });
         return CommonPage.restPage(resourceList);
     }
 
     @Override
     public ExResource selectResourceById(Long resourceId) {
-        return baseMapper.selectResourceById(resourceId);
+        ExResource resource= baseMapper.selectResourceById(resourceId);
+        if(resource==null){
+            return resource;
+        }
+        resource.setResourcePath(minioConfig.getEndpoint()+minioConfig.getBucketName()+"/"+resource.getResourcePath());
+        if(resource.getPrivatize().equals(PrivatizeEnum.PUBLIC.getCode())){
+            return resource;
+        }
+        SysUser currentUser=SecurityUtils.getLoginUser().getUser();
+        if(currentUser.getUserType().equals(UserTypeEnum.SYSTEM_USER.getCode())){
+            return resource;
+        }
+        if(!resource.getCompanyId().equals(currentUser.getCompanyId())){
+            throw new ApiException("无权限查看其它企业资源");
+        }
+
+        return resource;
     }
 
     @Override
     public ExResource selectResourceByPeriodId(Long periodId) {
-        return baseMapper.selectResourceByPeriodId(periodId);
+        ExResource resource= baseMapper.selectResourceByPeriodId(periodId);
+        if(resource==null){
+            return resource;
+        }
+        resource.setResourcePath(minioConfig.getEndpoint()+minioConfig.getBucketName()+"/"+resource.getResourcePath());
+        if(resource.getPrivatize().equals(PrivatizeEnum.PUBLIC.getCode())){
+            return resource;
+        }
+        SysUser currentUser=SecurityUtils.getLoginUser().getUser();
+        if(currentUser.getUserType().equals(UserTypeEnum.SYSTEM_USER.getCode())){
+            return resource;
+        }
+        if(!resource.getCompanyId().equals(currentUser.getCompanyId())){
+            throw new ApiException("无权限查看其它企业资源");
+        }
+        return resource;
+
     }
 
     @Override
     public int insertResource(ExResource resource) {
-        if(!checkNameUnique(resource)){
-            throw new ApiException("资源名称已存在");
+        if(resource.getResourceType().equals(ResourceTypeEnum.VIDEO.getCode())||resource.getResourceType().equals(ResourceTypeEnum.AUDIO.getCode())){
+            if(resource.getResourceLength()==null){
+                throw new ApiException("视频或者音频时长不能为空");
+            }
+        }else{
+            if(resource.getDocPage()==null){
+                throw new ApiException("文档页数不能为空");
+            }
         }
         SysUser user=SecurityUtils.getLoginUser().getUser();
         if(user.getUserType().equals(UserTypeEnum.SYSTEM_USER.getCode())){
             resource.setPrivatize(PrivatizeEnum.PUBLIC.getCode());
         }else{
-            if(user.getCompanyId()==null){
-                throw new ApiException("获取用户公司id失败");
-            }
             resource.setCompanyId(user.getCompanyId());
-            resource.setPrivatize(PrivatizeEnum.PRIVATE.getCode());
         }
-        UploadObjectVO uploadObjectVO =commonService.doUpload(resource.getFile());
-        resource.setResourceUri(uploadObjectVO.getPath());
-        resource.setVideoVid(uploadObjectVO.getFilename());
-        resource.setResourceSize(uploadObjectVO.getSize());
+        checkUserAllowed(resource);
+        if(!checkNameUnique(resource)){
+            throw new ApiException("资源名称已存在");
+        }
         resource.setCreateBy(SecurityUtils.getUsername());
         int row=baseMapper.insert(resource);
         if(row<1){
-            try {
-                //删除原文件
-                commonService.removeFile(uploadObjectVO.getPath());
-            }catch (Exception e){
-                log.error("新增资源,删除文件失败="+e.getMessage());
-            }
             throw new ApiException("新增资源失败");
         }
         return row;
@@ -87,8 +126,23 @@
 
     @Override
     public int updateResource(ExResource resource) {
+        if(resource.getResourceType().equals(ResourceTypeEnum.VIDEO.getCode())||resource.getResourceType().equals(ResourceTypeEnum.AUDIO.getCode())){
+            if(resource.getResourceLength()==null){
+                throw new ApiException("视频或者音频时长不能为空");
+            }
+        }else{
+            if(resource.getDocPage()==null){
+                throw new ApiException("文档页数不能为空");
+            }
+        }
+        checkUserAllowed(resource);
         if(!checkNameUnique(resource)){
             throw new ApiException("资源名称已存在");
+        }
+        String resourcePath=resource.getResourcePath();
+        if(resourcePath.startsWith(minioConfig.getEndpoint()+minioConfig.getBucketName()+"/")) {
+            resourcePath = resourcePath.replace(minioConfig.getEndpoint()+minioConfig.getBucketName() + "/", "");
+            resource.setResourcePath(resourcePath);
         }
         int row=baseMapper.updateById(resource);
         if(row<1){
@@ -97,16 +151,35 @@
         return row;
     }
 
+    public void checkUserAllowed(ExResource resource) {
+        SysUser currentUser= SecurityUtils.getLoginUser().getUser();
+        if(currentUser.getUserType().equals(UserTypeEnum.SYSTEM_USER.getCode())){
+            return;
+        }
+        if(currentUser.getUserType().equals(UserTypeEnum.STUDENT.getCode())){
+            throw new ApiException("没有权限操作");
+        }
+        if(resource.getCompanyId()!=null&&!currentUser.getCompanyId().equals(resource.getCompanyId())){
+            throw new ApiException("没有权限操作其他企业资源");
+        }
+    }
+
     @Override
+    @Transactional(rollbackFor = RuntimeException.class)
     public int deleteResourceById(Long resourceId) {
+        checkUserAllowed(baseMapper.selectById(resourceId));
         //校验资源是否绑定
+        int count= baseMapper.checkResourceAssign(resourceId);
+        if(count>0){
+            throw new ApiException("资源已跟课时关联,不能删除");
+        }
         ExResource resource=getById(resourceId);
         int row=baseMapper.deleteById(resourceId);
         if(row<1){
             throw new ApiException("删除资源失败");
         }
         //删除文件
-        commonService.removeFile(resource.getResourceUri());
+        commonService.removeMinioFile(resourceId,resource.getResourcePath());
         return row;
     }
 

--
Gitblit v1.9.2