| | |
| | | import com.sandu.common.execption.BusinessException; |
| | | import com.sandu.common.object.BaseConditionVO; |
| | | import com.sandu.common.service.impl.BaseServiceImpl; |
| | | 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.UpdateClientPrarm; |
| | | import com.sandu.ximon.admin.param.UserPwsParm; |
| | | import com.sandu.ximon.admin.security.SecurityUtils; |
| | | 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.admin.utils.StoreOperationRecordsUtils; |
| | | import com.sandu.ximon.dao.bo.MenuNode; |
| | | import com.sandu.ximon.dao.domain.*; |
| | | import com.sandu.ximon.dao.mapper.AdminMapper; |
| | | import com.sandu.ximon.dao.mapper.ClientMapper; |
| | | import lombok.AllArgsConstructor; |
| | | import org.springframework.beans.BeanUtils; |
| | | import org.springframework.security.crypto.password.PasswordEncoder; |
| | | import org.springframework.stereotype.Service; |
| | | |
| | | import java.util.ArrayList; |
| | | import java.util.List; |
| | | import java.util.Objects; |
| | | import java.util.stream.Collectors; |
| | | |
| | | @Service |
| | | @AllArgsConstructor |
| | |
| | | if (getOne(Wrappers.lambdaQuery(Client.class).eq(Client::getClientName, addClientPrarm.getClientName().trim())) != null) { |
| | | throw new BusinessException("该用户名已存在!"); |
| | | } |
| | | // Long userId = SecurityUtils.getUserId(); |
| | | Long userId = SecurityUtils.getUserId(); |
| | | boolean clientId = findClientId(); |
| | | //判断是否为二级客户 如果是二级客户则不能继续添加 |
| | | if (SecurityUtils.getClientId() != null && !clientId) { |
| | | //判断是否为二级客户 如果是二级客户则不能继续添加 一级客户为FALSE |
| | | if (SecurityUtils.getClientId() != null && clientId) { |
| | | throw new BusinessException("权限不足,二级客户不能新增用户!"); |
| | | } |
| | | |
| | | |
| | | Client client = new Client(); |
| | | |
| | | if (SecurityUtils.getClientId() != null && clientId) { |
| | | if (SecurityUtils.getClientId() != null && !clientId) { |
| | | //一级客户新增用户时 默认为自己名下的二级客户 |
| | | client.setSuperiorId(SecurityUtils.getUserId()); |
| | | client.setClientSuperior(addClientPrarm.getClientSuperior()); |
| | |
| | | throw new BusinessException("添加管理员角色失败"); |
| | | } |
| | | |
| | | /** |
| | | * 添加管理员日志记录开始 |
| | | */ |
| | | String content = "新注册用户:" + addClientPrarm.getClientName(); |
| | | StoreOperationRecordsUtils.storeOperationData(null, null, "添加普通用户", content); |
| | | /** |
| | | * 添加管理员日志记录结束 |
| | | */ |
| | | |
| | | return flag; |
| | | } |
| | | |
| | |
| | | if (client1 != null && !client1.getId().equals(one.getId())) { |
| | | throw new BusinessException("该用户名已存在!"); |
| | | } |
| | | |
| | | //判断上级用户是否存在 |
| | | boolean clientId = findClientId(); |
| | | |
| | | Long userId = SecurityUtils.getUserId(); |
| | | //判断更改的用户是否是属于自己名下的二级客户 |
| | | if(SecurityUtils.getClientId() != null && clientId){ |
| | | if(!Objects.equals(one.getSuperiorId(), SecurityUtils.getUserId())){ |
| | | if (SecurityUtils.getClientId() != null && !clientId) { |
| | | if (SecurityUtils.getUserId() != one.getSuperiorId()) { |
| | | throw new BusinessException("权限不足,不能更改其他客户的所属客户信息!"); |
| | | } |
| | | } |
| | | |
| | | Client client = new Client(); |
| | | client.setClientName(updateClientPrarm.getClientName()); |
| | | if (SecurityUtils.getClientId() != null && clientId) { |
| | | //一级客户新增用户时 默认为自己名下的二级客户 |
| | | client.setSuperiorId(SecurityUtils.getUserId()); |
| | |
| | | client.setLinkMan(updateClientPrarm.getLinkMan()); |
| | | client.setMobile(updateClientPrarm.getMobile()); |
| | | |
| | | // update(client); |
| | | return updateById(client); |
| | | } |
| | | |
| | |
| | | one.setIcon(IconUrl); |
| | | return updateById(one); |
| | | } |
| | | |
| | | /** |
| | | * 获取用户权限列表地 |
| | | */ |
| | | public List<MenuNode> getUserPermissionList() { |
| | | //通过用户UserID获取用户角色 |
| | | ClientRoleRelation one = SpringContextHolder.getBean(ClientRoleRelationService.class). |
| | | getOne(Wrappers.lambdaQuery(ClientRoleRelation.class).eq(ClientRoleRelation::getClientId, SecurityUtils.getUserId())); |
| | | //判空 |
| | | if (one == null) { |
| | | throw new BusinessException("该用户未绑定角色"); |
| | | } |
| | | |
| | | //通过RoleID获取MeunId列表 |
| | | List<RoleMenuRelation> menuIdList = SpringContextHolder.getBean(RoleMenuRelationService.class) |
| | | .list(Wrappers.lambdaQuery(RoleMenuRelation.class).eq(RoleMenuRelation::getRoleId, one.getRoleId())); |
| | | |
| | | //判空 |
| | | if (menuIdList.isEmpty()) { |
| | | return new ArrayList<>(); |
| | | } |
| | | |
| | | List<Long> menuIds = new ArrayList<>(menuIdList.size()); |
| | | for (RoleMenuRelation bean : menuIdList) { |
| | | menuIds.add(bean.getMenuId()); |
| | | } |
| | | |
| | | List<MenuNode> resultList = SpringContextHolder.getBean(MenuService.class).getUserPermissionListById(menuIds); |
| | | return resultList; |
| | | } |
| | | } |