mirror of https://gitee.com/stylefeng/roses
【7.2.5】【role】更新新增管理员
parent
57d5005ad3
commit
f25872d6a5
|
@ -24,6 +24,7 @@
|
|||
*/
|
||||
package cn.stylefeng.roses.kernel.system.api;
|
||||
|
||||
import cn.stylefeng.roses.kernel.system.api.pojo.menu.MenuAndButtonTreeResponse;
|
||||
import cn.stylefeng.roses.kernel.system.api.pojo.role.dto.SysRoleDTO;
|
||||
import cn.stylefeng.roses.kernel.system.api.pojo.role.dto.SysRoleMenuButtonDTO;
|
||||
import cn.stylefeng.roses.kernel.system.api.pojo.role.dto.SysRoleMenuDTO;
|
||||
|
@ -126,4 +127,21 @@ public interface RoleServiceApi {
|
|||
* @date 2022/6/8 14:58
|
||||
*/
|
||||
List<SysRoleDTO> getRoleSelectList(SysRoleRequest sysRoleRequest);
|
||||
|
||||
/**
|
||||
* 添加管理员角色
|
||||
*
|
||||
* @author fengshuonan
|
||||
* @date 2022/6/8 14:58
|
||||
*/
|
||||
void addAdminRole(SysRoleRequest sysRoleRequest);
|
||||
|
||||
/**
|
||||
* 角色权限界面,绑定角色的操作权限,全选操作
|
||||
*
|
||||
* @author fengshuonan
|
||||
* @date 2022/9/29 10:46
|
||||
*/
|
||||
List<MenuAndButtonTreeResponse> grantButtonGrantAll(SysRoleRequest sysRoleRequest);
|
||||
|
||||
}
|
||||
|
|
|
@ -0,0 +1,61 @@
|
|||
/*
|
||||
* Copyright [2020-2030] [https://www.stylefeng.cn]
|
||||
*
|
||||
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||
* you may not use this file except in compliance with the License.
|
||||
* You may obtain a copy of the License at
|
||||
*
|
||||
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
*
|
||||
* Unless required by applicable law or agreed to in writing, software
|
||||
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
* See the License for the specific language governing permissions and
|
||||
* limitations under the License.
|
||||
*
|
||||
* Guns采用APACHE LICENSE 2.0开源协议,您在使用过程中,需要注意以下几点:
|
||||
*
|
||||
* 1.请不要删除和修改根目录下的LICENSE文件。
|
||||
* 2.请不要删除和修改Guns源码头部的版权声明。
|
||||
* 3.请保留源码和相关描述文件的项目出处,作者声明等。
|
||||
* 4.分发源码时候,请注明软件出处 https://gitee.com/stylefeng/guns
|
||||
* 5.在修改包名,模块名称,项目代码等时,请注明软件出处 https://gitee.com/stylefeng/guns
|
||||
* 6.若您的项目无法满足以上几点,可申请商业授权
|
||||
*/
|
||||
package cn.stylefeng.roses.kernel.system.api.pojo.user.request;
|
||||
|
||||
import cn.stylefeng.roses.kernel.rule.annotation.ChineseDescription;
|
||||
import cn.stylefeng.roses.kernel.rule.pojo.request.BaseRequest;
|
||||
import lombok.Data;
|
||||
import lombok.EqualsAndHashCode;
|
||||
|
||||
import javax.validation.constraints.NotEmpty;
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 用户管理员相关的请求
|
||||
*
|
||||
* @author fengshuonan
|
||||
* @date 2022/9/30 11:44
|
||||
*/
|
||||
@EqualsAndHashCode(callSuper = true)
|
||||
@Data
|
||||
public class SysAdminRequest extends BaseRequest {
|
||||
|
||||
/**
|
||||
* 用户id集合
|
||||
*/
|
||||
@ChineseDescription("用户id集合")
|
||||
@NotEmpty(message = "用户id集合不能为空", groups = add.class)
|
||||
private List<Long> userIdList;
|
||||
|
||||
/**
|
||||
* 单个用户id
|
||||
*/
|
||||
@ChineseDescription("用户id")
|
||||
@NotEmpty(message = "用户id不能为空", groups = delete.class)
|
||||
private Long userId;
|
||||
|
||||
}
|
||||
|
||||
|
|
@ -184,12 +184,4 @@ public interface SysRoleService extends IService<SysRole>, RoleServiceApi {
|
|||
*/
|
||||
List<MenuAndButtonTreeResponse> grantRoleMenusGrantAll(SysRoleRequest sysRoleRequest);
|
||||
|
||||
/**
|
||||
* 角色权限界面,绑定角色的操作权限,全选操作
|
||||
*
|
||||
* @author fengshuonan
|
||||
* @date 2022/9/29 10:46
|
||||
*/
|
||||
List<MenuAndButtonTreeResponse> grantButtonGrantAll(SysRoleRequest sysRoleRequest);
|
||||
|
||||
}
|
||||
|
|
|
@ -68,6 +68,7 @@ import org.springframework.transaction.annotation.Isolation;
|
|||
import org.springframework.transaction.annotation.Transactional;
|
||||
|
||||
import javax.annotation.Resource;
|
||||
import java.math.BigDecimal;
|
||||
import java.util.ArrayList;
|
||||
import java.util.HashSet;
|
||||
import java.util.List;
|
||||
|
@ -717,6 +718,24 @@ public class SysRoleServiceImpl extends ServiceImpl<SysRoleMapper, SysRole> impl
|
|||
return sysRoleDTOS;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void addAdminRole(SysRoleRequest sysRoleRequest) {
|
||||
SysRole sysRole = new SysRole();
|
||||
|
||||
sysRole.setRoleId(sysRoleRequest.getRoleId());
|
||||
sysRole.setRoleName(sysRoleRequest.getRoleName());
|
||||
sysRole.setRoleCode(sysRoleRequest.getRoleCode());
|
||||
|
||||
sysRole.setRoleSort(new BigDecimal(9999));
|
||||
sysRole.setDataScopeType(DataScopeTypeEnum.ALL.getCode());
|
||||
sysRole.setStatusFlag(StatusEnum.ENABLE.getCode());
|
||||
sysRole.setAdminFlag(YesOrNotEnum.Y.getCode());
|
||||
sysRole.setRoleSystemFlag(YesOrNotEnum.Y.getCode());
|
||||
sysRole.setDelFlag(YesOrNotEnum.N.getCode());
|
||||
|
||||
this.save(sysRole);
|
||||
}
|
||||
|
||||
/**
|
||||
* 获取系统角色
|
||||
*
|
||||
|
|
|
@ -25,14 +25,16 @@
|
|||
package cn.stylefeng.roses.kernel.system.modular.user.controller;
|
||||
|
||||
import cn.stylefeng.roses.kernel.rule.enums.ResBizTypeEnum;
|
||||
import cn.stylefeng.roses.kernel.rule.pojo.request.BaseRequest;
|
||||
import cn.stylefeng.roses.kernel.rule.pojo.response.ResponseData;
|
||||
import cn.stylefeng.roses.kernel.rule.pojo.response.SuccessResponseData;
|
||||
import cn.stylefeng.roses.kernel.scanner.api.annotation.ApiResource;
|
||||
import cn.stylefeng.roses.kernel.scanner.api.annotation.GetResource;
|
||||
import cn.stylefeng.roses.kernel.scanner.api.annotation.PostResource;
|
||||
import cn.stylefeng.roses.kernel.system.api.pojo.user.SysUserAdminDTO;
|
||||
import cn.stylefeng.roses.kernel.system.api.pojo.user.request.SysUserRequest;
|
||||
import cn.stylefeng.roses.kernel.system.api.pojo.user.request.SysAdminRequest;
|
||||
import cn.stylefeng.roses.kernel.system.modular.user.service.SysUserAdminService;
|
||||
import org.springframework.validation.annotation.Validated;
|
||||
import org.springframework.web.bind.annotation.RequestBody;
|
||||
import org.springframework.web.bind.annotation.RestController;
|
||||
|
||||
|
@ -73,8 +75,8 @@ public class SysUserAdminController {
|
|||
* @date 2022/9/28 20:28
|
||||
*/
|
||||
@PostResource(name = "添加后台管理员", path = "/sysUser/backAuth/addAdmin")
|
||||
public ResponseData<?> addAdmin(@RequestBody SysUserRequest sysUserRequest) {
|
||||
|
||||
public ResponseData<?> addAdmin(@RequestBody @Validated(BaseRequest.add.class) SysAdminRequest sysAdminRequest) {
|
||||
this.sysUserAdminService.addAdminUser(sysAdminRequest);
|
||||
return new SuccessResponseData<>();
|
||||
}
|
||||
|
||||
|
@ -85,7 +87,7 @@ public class SysUserAdminController {
|
|||
* @date 2022/9/28 20:28
|
||||
*/
|
||||
@PostResource(name = "删除后台管理员", path = "/sysUser/backAuth/delAdmin")
|
||||
public ResponseData<?> delAdmin(@RequestBody SysUserRequest sysUserRequest) {
|
||||
public ResponseData<?> delAdmin(@RequestBody SysAdminRequest sysAdminRequest) {
|
||||
|
||||
return new SuccessResponseData<>();
|
||||
}
|
||||
|
|
|
@ -24,8 +24,11 @@
|
|||
*/
|
||||
package cn.stylefeng.roses.kernel.system.modular.user.mapper;
|
||||
|
||||
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
|
||||
import cn.stylefeng.roses.kernel.system.modular.user.entity.SysUserRole;
|
||||
import com.baomidou.mybatisplus.core.mapper.BaseMapper;
|
||||
import org.apache.ibatis.annotations.Param;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
/**
|
||||
* 系统用户角色mapper接口
|
||||
|
@ -35,5 +38,13 @@ import cn.stylefeng.roses.kernel.system.modular.user.entity.SysUserRole;
|
|||
*/
|
||||
public interface SysUserRoleMapper extends BaseMapper<SysUserRole> {
|
||||
|
||||
/**
|
||||
* 获取用户的管理员角色列表
|
||||
*
|
||||
* @author fengshuonan
|
||||
* @date 2022/9/30 13:20
|
||||
*/
|
||||
List<SysUserRole> getAdminUserRoleList(@Param("userIdList") List<Long> userIdList);
|
||||
|
||||
}
|
||||
|
||||
|
|
|
@ -2,4 +2,17 @@
|
|||
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd">
|
||||
<mapper namespace="cn.stylefeng.roses.kernel.system.modular.user.mapper.SysUserRoleMapper">
|
||||
|
||||
<select id="getAdminUserRoleList"
|
||||
resultType="cn.stylefeng.roses.kernel.system.modular.user.entity.SysUserRole">
|
||||
select ur.user_id as userId,
|
||||
ur.role_id as roleId,
|
||||
r.admin_flag
|
||||
from sys_user_role ur
|
||||
left join sys_role r on ur.role_id = r.role_id
|
||||
where r.admin_flag = "Y" and ur.user_id in
|
||||
<foreach item="item" collection="userIdList" index="index" open="(" separator="," close=")">
|
||||
#{item}
|
||||
</foreach>
|
||||
</select>
|
||||
|
||||
</mapper>
|
||||
|
|
|
@ -25,6 +25,7 @@
|
|||
package cn.stylefeng.roses.kernel.system.modular.user.service;
|
||||
|
||||
import cn.stylefeng.roses.kernel.system.api.pojo.user.SysUserAdminDTO;
|
||||
import cn.stylefeng.roses.kernel.system.api.pojo.user.request.SysAdminRequest;
|
||||
|
||||
import java.util.List;
|
||||
|
||||
|
@ -45,4 +46,12 @@ public interface SysUserAdminService {
|
|||
*/
|
||||
List<SysUserAdminDTO> getAdminUserList();
|
||||
|
||||
/**
|
||||
* 添加管理员
|
||||
*
|
||||
* @author fengshuonan
|
||||
* @date 2022/9/30 13:12
|
||||
*/
|
||||
void addAdminUser(SysAdminRequest sysAdminRequest);
|
||||
|
||||
}
|
||||
|
|
|
@ -6,18 +6,22 @@ import cn.stylefeng.roses.kernel.system.api.RoleServiceApi;
|
|||
import cn.stylefeng.roses.kernel.system.api.pojo.role.dto.SysRoleDTO;
|
||||
import cn.stylefeng.roses.kernel.system.api.pojo.role.request.SysRoleRequest;
|
||||
import cn.stylefeng.roses.kernel.system.api.pojo.user.SysUserAdminDTO;
|
||||
import cn.stylefeng.roses.kernel.system.api.pojo.user.request.SysAdminRequest;
|
||||
import cn.stylefeng.roses.kernel.system.modular.user.entity.SysUser;
|
||||
import cn.stylefeng.roses.kernel.system.modular.user.entity.SysUserRole;
|
||||
import cn.stylefeng.roses.kernel.system.modular.user.mapper.SysUserRoleMapper;
|
||||
import cn.stylefeng.roses.kernel.system.modular.user.service.SysUserAdminService;
|
||||
import cn.stylefeng.roses.kernel.system.modular.user.service.SysUserRoleService;
|
||||
import cn.stylefeng.roses.kernel.system.modular.user.service.SysUserService;
|
||||
import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
|
||||
import com.baomidou.mybatisplus.core.toolkit.IdWorker;
|
||||
import org.springframework.stereotype.Service;
|
||||
|
||||
import javax.annotation.Resource;
|
||||
import java.util.ArrayList;
|
||||
import java.util.List;
|
||||
import java.util.Map;
|
||||
import java.util.Set;
|
||||
import java.util.stream.Collectors;
|
||||
|
||||
/**
|
||||
|
@ -38,6 +42,9 @@ public class SysUserAdminServiceImpl implements SysUserAdminService {
|
|||
@Resource
|
||||
private SysUserService sysUserService;
|
||||
|
||||
@Resource
|
||||
private SysUserRoleMapper sysUserRoleMapper;
|
||||
|
||||
@Override
|
||||
public List<SysUserAdminDTO> getAdminUserList() {
|
||||
|
||||
|
@ -93,4 +100,49 @@ public class SysUserAdminServiceImpl implements SysUserAdminService {
|
|||
return sysUserAdminDTOS;
|
||||
}
|
||||
|
||||
@Override
|
||||
public void addAdminUser(SysAdminRequest sysAdminRequest) {
|
||||
|
||||
// 获取用户有没有已经绑定管理员角色
|
||||
List<SysUserRole> sysUserRoleList = sysUserRoleMapper.getAdminUserRoleList(sysAdminRequest.getUserIdList());
|
||||
|
||||
// 如果请求参数中已经有绑定的用户id集合
|
||||
Set<Long> haveAlreadyBindUserIds = sysUserRoleList.stream().map(SysUserRole::getUserId).collect(Collectors.toSet());
|
||||
|
||||
// 给用户绑定管理员
|
||||
for (Long userId : sysAdminRequest.getUserIdList()) {
|
||||
if (!haveAlreadyBindUserIds.contains(userId)) {
|
||||
this.addSingleAdminUser(userId);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* 单个添加管理员用户
|
||||
*
|
||||
* @author fengshuonan
|
||||
* @date 2022/9/30 13:29
|
||||
*/
|
||||
private void addSingleAdminUser(Long userId) {
|
||||
|
||||
// 创建用户对应的角色
|
||||
SysRoleRequest sysRoleRequest = new SysRoleRequest();
|
||||
sysRoleRequest.setRoleId(IdWorker.getId());
|
||||
sysRoleRequest.setRoleName("管理员权限-" + userId);
|
||||
sysRoleRequest.setRoleCode("admin-" + userId);
|
||||
this.roleServiceApi.addAdminRole(sysRoleRequest);
|
||||
|
||||
// 创建用户和角色关联
|
||||
SysUserRole sysUserRole = new SysUserRole();
|
||||
sysUserRole.setUserId(userId);
|
||||
sysUserRole.setRoleId(sysRoleRequest.getRoleId());
|
||||
this.sysUserRoleService.save(sysUserRole);
|
||||
|
||||
// 赋予默认的操作后台所有操作权限
|
||||
SysRoleRequest temp = new SysRoleRequest();
|
||||
temp.setRoleId(sysRoleRequest.getRoleId());
|
||||
temp.setTotalSelectFlag(true);
|
||||
this.roleServiceApi.grantButtonGrantAll(temp);
|
||||
}
|
||||
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue