Blame view

service-community/src/main/java/com/java110/community/cmd/basePrivilege/CheckUserHasResourceCmd.java 3.96 KB
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
  /**
   * 检查用户是否拥有特定资源权限的命令类
   * 
   * 该类继承自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对象,包含userIdresource字段
       * @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);
      }
  }