88e030b7
王彪总
init project
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
|
/*
* Copyright 2017-2020 吴学文 and java110 team.
*
* 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.
*/
package com.java110.user.cmd.role;
import com.alibaba.fastjson.JSONObject;
import com.java110.core.annotation.Java110Cmd;
import com.java110.core.annotation.Java110Transactional;
import com.java110.core.context.ICmdDataFlowContext;
import com.java110.core.event.cmd.Cmd;
import com.java110.core.event.cmd.CmdEvent;
import com.java110.dto.privilege.PrivilegeUserDto;
import com.java110.intf.user.IPrivilegeUserV1InnerServiceSMO;
import com.java110.po.privilege.PrivilegeUserPo;
import com.java110.utils.exception.CmdException;
import com.java110.utils.util.Assert;
import com.java110.vo.ResultVo;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.beans.factory.annotation.Autowired;
import java.util.List;
/**
* 类表述:删除角色员工关系
* 服务编码:roleStaff.deleteRoleStaff
* 请求路劲:/app/roleStaff.DeleteRoleStaff
* add by 吴学文 at 2022-07-25 17:12:49 mail: 928255095@qq.com
* open source address: https://gitee.com/wuxw7/MicroStaff
* 官网:http://www.homecommunity.cn
* 温馨提示:如果您对此文件进行修改 请不要删除原有作者及注释信息,请补充您的 修改的原因以及联系邮箱如下
* // modify by 张三 at 2021-09-12 第10行在某种场景下存在某种bug 需要修复,注释10至20行 加入 20行至30行
*/
/**
* 删除角色员工关系命令类
* 该类负责处理删除角色与员工关联关系的业务逻辑,通过服务编码"role.deleteRoleStaff"对外提供服务
* 主要功能包括参数验证、权限用户关系查询和删除操作
*
* @author 吴学文
* @version 1.0
* @since 2022-07-25
*/
@Java110Cmd(serviceCode = "role.deleteRoleStaff")
public class DeleteRoleStaffCmd extends Cmd {
/**
* 日志记录器
*/
private static Logger logger = LoggerFactory.getLogger(DeleteRoleStaffCmd.class);
/**
* 权限用户服务接口,用于操作权限用户关系数据
*/
@Autowired
private IPrivilegeUserV1InnerServiceSMO privilegeUserV1InnerServiceSMOImpl;
/**
* 参数验证方法
* 验证请求参数中是否包含必要的角色ID和用户ID
*
* @param event 命令事件对象,包含请求相关信息
* @param cmdDataFlowContext 命令数据流上下文,用于获取和设置请求响应数据
* @param reqJson 请求参数的JSON对象
* @throws CmdException 当参数验证失败时抛出异常
*/
@Override
public void validate(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) {
// 验证请求参数中必须包含roleId
Assert.hasKeyAndValue(reqJson, "roleId", "roleId不能为空");
// 验证请求参数中必须包含userId
Assert.hasKeyAndValue(reqJson, "userId", "userId不能为空");
}
/**
* 执行删除角色员工关系命令
* 根据角色ID和用户ID查询权限用户关系,并删除对应的关系记录
* 使用事务注解确保操作的原子性
*
* @param event 命令事件对象
* @param cmdDataFlowContext 命令数据流上下文
* @param reqJson 请求参数的JSON对象
* @throws CmdException 当删除操作失败时抛出异常
*/
@Override
@Java110Transactional
public void doCmd(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) throws CmdException {
// 创建权限用户查询条件对象
PrivilegeUserDto privilegeUserDto = new PrivilegeUserDto();
// 设置角色ID作为查询条件
privilegeUserDto.setpId(reqJson.getString("roleId"));
// 设置用户ID作为查询条件
privilegeUserDto.setUserId(reqJson.getString("userId"));
// 根据条件查询权限用户关系列表
List<PrivilegeUserDto> privilegeUserDtos = privilegeUserV1InnerServiceSMOImpl.queryPrivilegeUsers(privilegeUserDto);
// 如果查询结果为空,直接返回,无需执行删除操作
if (privilegeUserDtos == null || privilegeUserDtos.size() < 1) {
return;
}
// 遍历查询到的权限用户关系列表,逐个删除
for(PrivilegeUserDto tmpPrivilegeUserDto : privilegeUserDtos) {
// 创建权限用户PO对象用于删除操作
PrivilegeUserPo privilegeUserPo = new PrivilegeUserPo();
// 设置要删除的权限用户关系ID
privilegeUserPo.setPuId(tmpPrivilegeUserDto.getPuId());
// 执行删除操作,返回影响的行数
int flag = privilegeUserV1InnerServiceSMOImpl.deletePrivilegeUser(privilegeUserPo);
// 如果删除失败(影响行数小于1),抛出异常
if (flag < 1) {
throw new CmdException("删除数据失败");
}
}
// 设置响应结果为成功
cmdDataFlowContext.setResponseEntity(ResultVo.success());
}
}
|