Blame view

service-acct/src/main/java/com/java110/acct/cmd/account/DeleteAccountCmd.java 3.22 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
  package com.java110.acct.cmd.account;
  
  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.intf.acct.IAccountInnerServiceSMO;
  import com.java110.intf.acct.IAccountDetailInnerServiceSMO;
  import com.java110.po.account.AccountPo;
  import com.java110.utils.constant.StatusConstant;
  import com.java110.utils.exception.CmdException;
  import com.java110.utils.util.Assert;
  import com.java110.vo.ResultVo;
  import org.springframework.beans.factory.annotation.Autowired;
  
  /**
   * 删除账户命令类
   * 
   * 该类负责处理账户删除相关的业务逻辑,通过将账户状态标记为无效来实现逻辑删除
   * 采用命令模式设计,遵循Java110框架规范
   * 
   * @author Java110
   * @version 1.0
   * @serviceCode account.deleteAccount
   */
  @Java110Cmd(serviceCode = "account.deleteAccount")
  public class DeleteAccountCmd extends Cmd {
  
      /**
       * 账户内部服务接口,用于操作账户数据
       */
      @Autowired
      private IAccountInnerServiceSMO accountInnerServiceSMOImpl;
  
      /**
       * 账户明细内部服务接口(当前类中未使用,但保留以备后续扩展)
       */
      @Autowired
      private IAccountDetailInnerServiceSMO accountDetailInnerServiceSMOImpl;
  
      /**
       * 参数验证方法
       * 
       * 验证请求参数中是否包含必要的acctId字段
       * 
       * @param event 命令事件对象,包含事件相关信息
       * @param cmdDataFlowContext 命令数据流上下文,用于获取和设置请求响应数据
       * @param reqJson 请求参数的JSON对象
       * @throws CmdException 当参数验证失败时抛出异常
       */
      @Override
      public void validate(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) throws CmdException {
          // 验证请求JSON中必须包含acctId字段
          Assert.hasKeyAndValue(reqJson, "acctId", "acctId不能为空");
      }
  
      /**
       * 执行删除账户命令
       * 
       * 通过将账户状态更新为无效状态来实现逻辑删除
       * 如果更新失败则抛出异常
       * 
       * @param event 命令事件对象
       * @param cmdDataFlowContext 命令数据流上下文
       * @param reqJson 请求参数的JSON对象
       * @throws CmdException 当账户更新失败时抛出异常
       */
      @Override
      public void doCmd(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) throws CmdException {
          // 创建账户PO对象并设置参数
          AccountPo accountPo = new AccountPo();
          // 设置要删除的账户ID
          accountPo.setAcctId(reqJson.getString("acctId"));
          // 将账户状态设置为无效状态,实现逻辑删除
          accountPo.setStatusCd(StatusConstant.STATUS_CD_INVALID);
          
          // 调用服务更新账户状态
          int flag = accountInnerServiceSMOImpl.updateAccount(accountPo);
  
          // 检查更新结果,如果影响行数小于1表示更新失败
          if (flag < 1) {
              throw new CmdException("更新失败");
          }
  
          // 设置成功响应
          cmdDataFlowContext.setResponseEntity(ResultVo.success());
      }
  }