From 23855599412c4d61b38d78f0f3abd3430a48b5b1 Mon Sep 17 00:00:00 2001 From: zhangherong <571457620@qq.com> Date: 星期三, 25 六月 2025 11:51:38 +0800 Subject: [PATCH] Merge branch 'mdc_hyjs_master' --- lxzn-module-dnc/src/main/java/org/jeecg/modules/dnc/service/impl/DeviceGroupPermissionServiceImpl.java | 159 +++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 files changed, 159 insertions(+), 0 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 new file mode 100644 index 0000000..7e9171e --- /dev/null +++ b/lxzn-module-dnc/src/main/java/org/jeecg/modules/dnc/service/impl/DeviceGroupPermissionServiceImpl.java @@ -0,0 +1,159 @@ +package org.jeecg.modules.dnc.service.impl; + +import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; +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); + } + + @Override + public List<SysUser> getUserNonPermsByGroupId(String groupId) { + return super.getBaseMapper().getUserNonPermsByGroupId(groupId); + } + + @Override + public DeviceGroupPermission getByUserIdAndGroupId(String userId, String groupId) { + if(!ValidateUtil.validateString(userId) || !ValidateUtil.validateString(groupId)) + return null; + List<DeviceGroupPermission> list = super.lambdaQuery().eq(DeviceGroupPermission::getGroupId, groupId).eq(DeviceGroupPermission::getUserId, userId).list(); + if(list == null || list.isEmpty()) + return null; + return list.get(0); + } + + @Override + @Transactional(rollbackFor = {Exception.class}) + public boolean removeByCollection(List<DeviceGroupPermission> permissions) { + if(permissions == null || permissions.isEmpty()) + return false; + if(permissions.size() == 1){ + return super.removeById(permissions.get(0).getGroupPermId()); + } + List<String> ids = new ArrayList<>(); + permissions.forEach(item -> { + ids.add(item.getGroupPermId()); + }); + return super.removeByIds(ids); + } + + @Override + @Transactional(rollbackFor = {Exception.class}) + public boolean deleteByGroupId(String groupId) { + LambdaQueryWrapper<DeviceGroupPermission> lambdaQueryWrapper = Wrappers.lambdaQuery(); + lambdaQueryWrapper.eq(DeviceGroupPermission::getGroupId, groupId); + return super.remove(lambdaQueryWrapper); + } + + @Override + public List<DeviceGroupPermission> getByGroupId(String groupId) { + List<DeviceGroupPermission> list = super.lambdaQuery().eq(DeviceGroupPermission::getGroupId, groupId).list(); + if(list == null) + 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