From 14821e28286d773ad5ff2c13510e39c5eb117daf Mon Sep 17 00:00:00 2001
From: kongzy <kongzy>
Date: Fri, 05 Jul 2024 13:46:32 +0800
Subject: [PATCH] update
---
exam-system/src/main/java/com/gkhy/exam/system/service/impl/ExResourceServiceImpl.java | 91 +++++++++++++++++++++++++++++++++++----------
1 files changed, 71 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..452ec96 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
@@ -5,17 +5,18 @@
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;
@@ -44,42 +45,67 @@
@Override
public ExResource selectResourceById(Long resourceId) {
- return baseMapper.selectResourceById(resourceId);
+ ExResource resource= baseMapper.selectResourceById(resourceId);
+ if(resource==null){
+ return resource;
+ }
+ 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;
+ }
+ 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,6 +113,16 @@
@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("资源名称已存在");
}
@@ -97,16 +133,31 @@
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(!currentUser.getCompanyId().equals(resource.getCompanyId())){
+ throw new ApiException("没有权限操作其他企业资源");
+ }
+ }
+
@Override
+ @Transactional(rollbackFor = RuntimeException.class)
public int deleteResourceById(Long resourceId) {
//校验资源是否绑定
+ checkUserAllowed(baseMapper.selectById(resourceId));
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