From c6eb2d4ecd99bee148892abfbdca3e42f3dd6084 Mon Sep 17 00:00:00 2001
From: cuilei <ray_tsu1@163.com>
Date: 星期三, 07 五月 2025 18:08:07 +0800
Subject: [PATCH] 工具管理-仓库管理功能
---
lxzn-module-dnc/src/main/java/org/jeecg/modules/dnc/service/impl/DeviceGroupPermissionServiceImpl.java | 90 ++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 89 insertions(+), 1 deletions(-)
diff --git a/lxzn-module-dnc/src/main/java/org/jeecg/modules/dnc/service/impl/DeviceGroupPermissionServiceImpl.java b/lxzn-module-dnc/src/main/java/org/jeecg/modules/dnc/service/impl/DeviceGroupPermissionServiceImpl.java
index 34577b1..7e9171e 100644
--- a/lxzn-module-dnc/src/main/java/org/jeecg/modules/dnc/service/impl/DeviceGroupPermissionServiceImpl.java
+++ b/lxzn-module-dnc/src/main/java/org/jeecg/modules/dnc/service/impl/DeviceGroupPermissionServiceImpl.java
@@ -4,20 +4,40 @@
import com.baomidou.mybatisplus.core.toolkit.Wrappers;
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
import org.jeecg.modules.dnc.entity.DeviceGroupPermission;
+import org.jeecg.modules.dnc.entity.DevicePermissionStream;
+import org.jeecg.modules.dnc.exception.ExceptionCast;
import org.jeecg.modules.dnc.mapper.DeviceGroupPermissionMapper;
+import org.jeecg.modules.dnc.response.CommonCode;
+import org.jeecg.modules.dnc.response.DeviceGroupCode;
+import org.jeecg.modules.dnc.service.IDevicePermissionStreamService;
import org.jeecg.modules.dnc.ucenter.UserDepartExt;
import org.jeecg.modules.dnc.utils.ValidateUtil;
+import org.jeecg.modules.system.entity.MdcProduction;
+import org.jeecg.modules.system.entity.MdcUserProduction;
import org.jeecg.modules.system.entity.SysUser;
import org.jeecg.modules.dnc.service.IDeviceGroupPermissionService;
+import org.jeecg.modules.system.service.IMdcUserProductionService;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.context.annotation.Lazy;
import org.springframework.stereotype.Service;
import org.springframework.transaction.annotation.Transactional;
import java.util.ArrayList;
+import java.util.Collection;
import java.util.Collections;
import java.util.List;
@Service
public class DeviceGroupPermissionServiceImpl extends ServiceImpl<DeviceGroupPermissionMapper, DeviceGroupPermission> implements IDeviceGroupPermissionService {
+ @Autowired
+ @Lazy
+ private IDeviceGroupPermissionService groupPermissionService;
+ @Autowired
+ @Lazy
+ private IDevicePermissionStreamService devicePermissionStreamService;
+ @Autowired
+ private IMdcUserProductionService mdcUserProductionService;
+
@Override
public List<UserDepartExt> getUserPermsByGroupId(String groupId) {
return super.getBaseMapper().getUserPermsByGroupId(groupId);
@@ -44,7 +64,7 @@
if(permissions == null || permissions.isEmpty())
return false;
if(permissions.size() == 1){
- super.removeById(permissions.get(0).getGroupPermId());
+ return super.removeById(permissions.get(0).getGroupPermId());
}
List<String> ids = new ArrayList<>();
permissions.forEach(item -> {
@@ -68,4 +88,72 @@
list = Collections.emptyList();
return list;
}
+
+ @Override
+ @Transactional(rollbackFor = {Exception.class})
+ public boolean assignAddUser(MdcProduction mdcProduction, Collection<SysUser> userList) {
+ if(mdcProduction == null || userList == null || userList.isEmpty())
+ ExceptionCast.cast(CommonCode.INVALID_PARAM);
+ List<MdcUserProduction> mdcUserProductions=new ArrayList<>();
+ List<DevicePermissionStream> permissionStreamList = new ArrayList<>();
+ userList.forEach(item -> {
+ MdcUserProduction en = mdcUserProductionService.getByUserIdAndGroupId(item.getId(), mdcProduction.getId());
+ if(en == null) {
+ en = new MdcUserProduction(item.getId(),mdcProduction.getId());
+ mdcUserProductions.add(en);
+ }
+ DevicePermissionStream stream = devicePermissionStreamService.getByGroupIdAndUserId(mdcProduction.getId(), item.getId());
+ if(stream == null) {
+ stream = new DevicePermissionStream();
+ stream.setUserId(item.getId());
+ stream.setGroupId(mdcProduction.getId());
+ permissionStreamList.add(stream);
+ }
+ });
+ if(!mdcUserProductions.isEmpty()) {
+ boolean b = mdcUserProductionService.saveBatch(mdcUserProductions);
+ if(!b) {
+ ExceptionCast.cast(DeviceGroupCode.DEVICE_GROUP_PERM_ERROR);
+ }
+ }
+ if(!permissionStreamList.isEmpty()) {
+ boolean b = devicePermissionStreamService.saveBatch(permissionStreamList);
+ if(!b) {
+ ExceptionCast.cast(DeviceGroupCode.DEVICE_GROUP_PERM_ERROR);
+ }
+ }
+ return true;
+ }
+
+ @Override
+ @Transactional(rollbackFor = {Exception.class})
+ public boolean assignRemoveUser(MdcProduction mdcProduction, Collection<SysUser> userList) {
+ if(mdcProduction == null || userList == null || userList.isEmpty())
+ ExceptionCast.cast(CommonCode.INVALID_PARAM);
+ List<MdcUserProduction> mdcUserProductions=new ArrayList<>();
+ List<DevicePermissionStream> permissionStreamList = new ArrayList<>();
+ userList.forEach(item -> {
+ MdcUserProduction en = mdcUserProductionService.getByUserIdAndGroupId(item.getId(), mdcProduction.getId());
+ if(en != null) {
+ mdcUserProductions.add(en);
+ }
+ DevicePermissionStream stream = devicePermissionStreamService.getByGroupIdAndUserId(mdcProduction.getId(), item.getId());
+ if(stream != null) {
+ permissionStreamList.add(stream);
+ }
+ });
+ if(!mdcUserProductions.isEmpty()) {
+ boolean b = mdcUserProductionService.removeByCollection(mdcUserProductions);
+ if(!b) {
+ ExceptionCast.cast(DeviceGroupCode.DEVICE_GROUP_PERM_ERROR);
+ }
+ }
+ if(!permissionStreamList.isEmpty()) {
+ boolean b = devicePermissionStreamService.removeByCollection(permissionStreamList);
+ if(!b) {
+ ExceptionCast.cast(DeviceGroupCode.DEVICE_GROUP_PERM_ERROR);
+ }
+ }
+ return true;
+ }
}
--
Gitblit v1.9.3