| | |
| | | import com.sandu.common.enums.RoleLevelStatus; |
| | | import com.sandu.common.execption.BusinessException; |
| | | import com.sandu.common.object.BaseConditionVO; |
| | | import com.sandu.common.redis.RedisService; |
| | | import com.sandu.common.security.LoginUserInfo; |
| | | import com.sandu.common.security.token.TokenProvider; |
| | | import com.sandu.common.service.impl.BaseServiceImpl; |
| | | import com.sandu.common.util.IpUtil; |
| | | import com.sandu.common.util.SpringContextHolder; |
| | | import com.sandu.ximon.admin.param.AddClientPrarm; |
| | | import com.sandu.ximon.admin.param.PwdParam; |
| | |
| | | import com.sandu.ximon.admin.param.UserPwsParm; |
| | | import com.sandu.ximon.admin.security.SecurityUtils; |
| | | import com.sandu.ximon.admin.utils.StoreOperationRecordsUtils; |
| | | import com.sandu.ximon.admin.utils.StringUtil; |
| | | import com.sandu.ximon.dao.bo.MenuNode; |
| | | import com.sandu.ximon.dao.domain.Client; |
| | | import com.sandu.ximon.dao.domain.ClientRoleRelation; |
| | | import com.sandu.ximon.dao.domain.Role; |
| | | import com.sandu.ximon.dao.domain.RoleMenuRelation; |
| | | import com.sandu.ximon.dao.domain.*; |
| | | import com.sandu.ximon.dao.enums.AdministratorEnums; |
| | | import com.sandu.ximon.dao.mapper.ClientMapper; |
| | | import lombok.AllArgsConstructor; |
| | | import org.springframework.security.core.GrantedAuthority; |
| | | import org.springframework.security.crypto.password.PasswordEncoder; |
| | | import org.springframework.stereotype.Service; |
| | | import org.springframework.transaction.annotation.Transactional; |
| | | |
| | | import java.util.ArrayList; |
| | | import java.util.Collection; |
| | | import java.util.List; |
| | | import java.util.stream.Collectors; |
| | | |
| | | @Service |
| | | @AllArgsConstructor |
| | |
| | | private final PasswordEncoder passwordEncoder; |
| | | private final ClientRoleRelationService clientRoleRelationService; |
| | | private final RoleService roleService; |
| | | private final TokenProvider tokenProvider; |
| | | |
| | | |
| | | public boolean addClient(AddClientPrarm addClientPrarm) { |
| | |
| | | return updateById(client); |
| | | } |
| | | |
| | | @Transactional(rollbackFor = Exception.class) |
| | | public boolean deleteClient(Long id) { |
| | | boolean flag = false; |
| | | //判断删除用户是否存在 |
| | | Client one = getById(id); |
| | | if (one == null) { |
| | | Client client = getById(id); |
| | | if (client == null) { |
| | | throw new BusinessException("该客户不存在"); |
| | | } |
| | | |
| | | //只有超管能删除 或 上级客户删除自己的下级用户 |
| | | if (!AdministratorEnums.ADMIN.getCode().equals(SecurityUtils.getUserDetails().getAdministratorType())) { |
| | | Client temp = getOne(Wrappers.lambdaQuery(Client.class).eq(Client::getSuperiorId, SecurityUtils.getUserId()).eq(Client::getId, id)); |
| | | if (temp == null) { |
| | | throw new BusinessException("删除的用户不存在或该用户不是你的下级用户"); |
| | | } |
| | | } |
| | | |
| | | //判断删除的用户有无下级用户 |
| | |
| | | if (list != null && list.size() != 0) { |
| | | throw new BusinessException("删除的用户下有下级用户,不允许删除"); |
| | | } |
| | | |
| | | //管理员角色关系表 |
| | | ClientRoleRelationService clientRoleRelationService = SpringContextHolder.getBean(ClientRoleRelationService.class); |
| | | //有用户必定有用户与角色的关系数据 |
| | | ClientRoleRelation one = clientRoleRelationService.getOne(Wrappers.lambdaQuery(ClientRoleRelation.class).eq(ClientRoleRelation::getClientId, client.getId())); |
| | | |
| | | //删用户 |
| | | if (removeById(id)) { |
| | | //删角色关系表信息 |
| | | flag = clientRoleRelationService.removeById(one); |
| | | //删除失败回滚数据 |
| | | if (!flag) { |
| | | throw new BusinessException("删除用户失败!"); |
| | | } |
| | | } |
| | | |
| | | /** |
| | | * 删除普通用户 日志记录开始 |
| | | */ |
| | | String content = "删除普通用户:" + one.getClientName() + "用户id:" + id; |
| | | String content = "删除普通用户:" + client.getClientName() + "用户id:" + id; |
| | | StoreOperationRecordsUtils.storeOperationData(null, null, "删除普通用户", content); |
| | | /** |
| | | * 删除普通用户 日志记录结束 |
| | | */ |
| | | |
| | | return removeById(id); |
| | | return flag; |
| | | } |
| | | |
| | | public List<Client> clientList(Long userId, BaseConditionVO baseConditionVO) { |
| | |
| | | List<MenuNode> resultList = SpringContextHolder.getBean(MenuService.class).getUserPermissionListById(menuIds); |
| | | return resultList; |
| | | } |
| | | |
| | | /** |
| | | * 生成便捷登录KEY |
| | | */ |
| | | public String creatKeyByLogin(String keyValue) { |
| | | if (keyValue == null) { |
| | | throw new BusinessException("key不能为空!"); |
| | | } |
| | | |
| | | Object object = SpringContextHolder.getBean(RedisService.class).get(keyValue); |
| | | |
| | | if (object != null) { |
| | | return object.toString(); |
| | | } else { |
| | | Client client = getOne(Wrappers.lambdaQuery(Client.class).eq(Client::getUserKey, keyValue)); |
| | | if (client == null) { |
| | | throw new BusinessException("用户不存在,获取信息异常!"); |
| | | } |
| | | |
| | | Collection<GrantedAuthority> grantedAuthorities = roleService.mapToGrantedAuthorities(client.getId(), false); |
| | | |
| | | LoginUserInfo loginUserInfo = new LoginUserInfo(); |
| | | loginUserInfo.setUserId(client.getId()); |
| | | loginUserInfo.setAccount(client.getClientName()); |
| | | loginUserInfo.setIp(IpUtil.getRealIp()); |
| | | loginUserInfo.setAdministratorType(AdministratorEnums.NORMAL.getCode()); |
| | | loginUserInfo.setPermission(grantedAuthorities.stream().map(GrantedAuthority::getAuthority).collect(Collectors.joining(","))); |
| | | |
| | | // 生成令牌 |
| | | String token = tokenProvider.createToken(loginUserInfo); |
| | | return token; |
| | | } |
| | | } |
| | | } |