package org.jeecg.modules.dnc.service.impl; import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper; import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper; import com.baomidou.mybatisplus.core.toolkit.Wrappers; import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; import org.jeecg.modules.dnc.entity.DeviceGroup; 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.SysUser; import org.jeecg.modules.dnc.service.IDeviceGroupPermissionService; 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 implements IDeviceGroupPermissionService { @Autowired @Lazy private IDeviceGroupPermissionService groupPermissionService; @Autowired @Lazy private IDevicePermissionStreamService devicePermissionStreamService; @Override public List getUserPermsByGroupId(String groupId) { return super.getBaseMapper().getUserPermsByGroupId(groupId); } @Override public List 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 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 permissions) { if(permissions == null || permissions.isEmpty()) return false; if(permissions.size() == 1){ return super.removeById(permissions.get(0).getGroupPermId()); } List 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 lambdaQueryWrapper = Wrappers.lambdaQuery(); lambdaQueryWrapper.eq(DeviceGroupPermission::getGroupId, groupId); return super.remove(lambdaQueryWrapper); } @Override public List getByGroupId(String groupId) { List 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 userList) { if(mdcProduction == null || userList == null || userList.isEmpty()) ExceptionCast.cast(CommonCode.INVALID_PARAM); List permissionList = new ArrayList<>(); List permissionStreamList = new ArrayList<>(); userList.forEach(item -> { DeviceGroupPermission en = groupPermissionService.getByUserIdAndGroupId(item.getId(), mdcProduction.getId()); if(en == null) { en = new DeviceGroupPermission(); en.setUserId(item.getId()); en.setGroupId(mdcProduction.getId()); permissionList.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(!permissionList.isEmpty()) { boolean b = groupPermissionService.saveBatch(permissionList); 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 userList) { if(mdcProduction == null || userList == null || userList.isEmpty()) ExceptionCast.cast(CommonCode.INVALID_PARAM); List permissionList = new ArrayList<>(); List permissionStreamList = new ArrayList<>(); userList.forEach(item -> { DeviceGroupPermission en = groupPermissionService.getByUserIdAndGroupId(item.getId(), mdcProduction.getId()); if(en != null) { permissionList.add(en); } DevicePermissionStream stream = devicePermissionStreamService.getByGroupIdAndUserId(mdcProduction.getId(), item.getId()); if(stream != null) { permissionStreamList.add(stream); } }); //校验清空设备分组权限操作 List existList = groupPermissionService.getByGroupId(mdcProduction.getId()); if(existList.size() <= permissionList.size()) ExceptionCast.cast(DeviceGroupCode.DEVICE_GROUP_USER_NONE); if(!permissionList.isEmpty()) { boolean b = groupPermissionService.removeByCollection(permissionList); 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; } }