CheckUserHasResourceCmd.java
3.96 KB
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
/**
* 检查用户是否拥有特定资源权限的命令类
*
* 该类继承自Cmd基类,用于处理用户权限验证请求。
* 通过调用菜单服务检查指定用户是否具有访问特定资源的权限,
* 并返回权限验证结果。
*
* @author Java110
* @version 1.0
* @since 2023
*/
package com.java110.community.cmd.basePrivilege;
import com.alibaba.fastjson.JSONObject;
import com.java110.core.annotation.Java110Cmd;
import com.java110.core.context.ICmdDataFlowContext;
import com.java110.core.event.cmd.Cmd;
import com.java110.core.event.cmd.CmdEvent;
import com.java110.core.log.LoggerFactory;
import com.java110.dto.privilege.BasePrivilegeDto;
import com.java110.intf.community.IMenuInnerServiceSMO;
import com.java110.utils.exception.CmdException;
import org.slf4j.Logger;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.http.HttpStatus;
import org.springframework.http.ResponseEntity;
import java.util.List;
import java.util.Map;
@Java110Cmd(serviceCode = "basePrivilege.CheckUserHasResourceListener")
public class CheckUserHasResourceCmd extends Cmd {
/**
* 日志记录器
*/
private final static Logger logger = LoggerFactory.getLogger(CheckUserHasResourceCmd.class);
/**
* 菜单内部服务接口,用于权限验证
*/
@Autowired
private IMenuInnerServiceSMO menuInnerServiceSMOImpl;
/**
* 请求参数验证方法
*
* 该方法用于验证传入的请求参数是否合法。
* 当前实现为空,可根据具体业务需求添加参数验证逻辑。
*
* @param event 命令事件对象,包含事件相关信息
* @param context 命令数据流上下文,用于获取和设置请求/响应数据
* @param reqJson 请求参数的JSON对象
* @throws CmdException 当参数验证失败时抛出命令异常
*/
@Override
public void validate(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException {
// 参数验证逻辑可在此处实现
// 当前为空实现,可根据需要添加具体的参数校验规则
}
/**
* 执行权限检查命令的主要业务逻辑
*
* 该方法接收用户ID和资源标识,通过菜单服务检查用户是否拥有该资源的访问权限,
* 并将检查结果封装成HTTP响应返回。
*
* @param event 命令事件对象,包含事件相关信息
* @param context 命令数据流上下文,用于获取和设置请求/响应数据
* @param reqJson 请求参数的JSON对象,包含userId和resource字段
* @throws CmdException 当命令执行过程中发生错误时抛出
*/
@Override
public void doCmd(CmdEvent event, ICmdDataFlowContext context, JSONObject reqJson) throws CmdException {
// 记录请求信息,便于调试和问题排查
logger.debug("请求信息:{}", reqJson);
// 初始化响应实体
ResponseEntity<String> responseEntity = null;
// 创建权限验证数据传输对象
BasePrivilegeDto basePrivilegeDto = new BasePrivilegeDto();
// 从请求中获取资源标识并设置到DTO
basePrivilegeDto.setResource(reqJson.getString("resource"));
// 从请求中获取用户ID并设置到DTO
basePrivilegeDto.setUserId(reqJson.getString("userId"));
// 调用菜单服务检查用户是否拥有指定资源的权限
List<Map> privileges = menuInnerServiceSMOImpl.checkUserHasResource(basePrivilegeDto);
// 创建响应数据对象
JSONObject data = new JSONObject();
// 将权限检查结果放入响应数据
data.put("privileges", privileges);
// 构建成功的HTTP响应
responseEntity = new ResponseEntity<String>(data.toJSONString(), HttpStatus.OK);
// 将响应设置到上下文,供后续处理使用
context.setResponseEntity(responseEntity);
}
}