From f498c77c01ea479fa67663286fbbb3cf8b66e689 Mon Sep 17 00:00:00 2001
From: java110 <928255095@qq.com>
Date: 星期二, 19 七月 2022 18:34:20 +0800
Subject: [PATCH] 优化设备 调整为cmd 模式

---
 service-common/src/main/java/com/java110/common/cmd/machine/UpdateMachineCmd.java |   58 ++++++++++++++++++++++++++++++++++++++++++++++++++++------
 1 files changed, 52 insertions(+), 6 deletions(-)

diff --git a/service-common/src/main/java/com/java110/common/cmd/machine/UpdateMachineCmd.java b/service-common/src/main/java/com/java110/common/cmd/machine/UpdateMachineCmd.java
index 0e6b8f7..e08daae 100644
--- a/service-common/src/main/java/com/java110/common/cmd/machine/UpdateMachineCmd.java
+++ b/service-common/src/main/java/com/java110/common/cmd/machine/UpdateMachineCmd.java
@@ -15,21 +15,27 @@
  */
 package com.java110.common.cmd.machine;
 
+import com.alibaba.fastjson.JSONArray;
 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.core.factory.GenerateCodeFactory;
+import com.java110.core.log.LoggerFactory;
+import com.java110.intf.common.IMachineAttrInnerServiceSMO;
 import com.java110.intf.common.IMachineV1InnerServiceSMO;
+import com.java110.po.machine.MachineAttrPo;
 import com.java110.po.machine.MachinePo;
+import com.java110.utils.constant.BusinessTypeConstant;
 import com.java110.utils.exception.CmdException;
 import com.java110.utils.util.Assert;
 import com.java110.utils.util.BeanConvertUtil;
+import com.java110.utils.util.StringUtil;
 import com.java110.vo.ResultVo;
-import org.springframework.beans.factory.annotation.Autowired;
 import org.slf4j.Logger;
-import com.java110.core.log.LoggerFactory;
+import org.springframework.beans.factory.annotation.Autowired;
 
 
 /**
@@ -45,16 +51,28 @@
 @Java110Cmd(serviceCode = "machine.updateMachine")
 public class UpdateMachineCmd extends Cmd {
 
-  private static Logger logger = LoggerFactory.getLogger(UpdateMachineCmd.class);
+    private static Logger logger = LoggerFactory.getLogger(UpdateMachineCmd.class);
 
 
     @Autowired
     private IMachineV1InnerServiceSMO machineV1InnerServiceSMOImpl;
 
+    @Autowired
+    private IMachineAttrInnerServiceSMO machineAttrInnerServiceSMOImpl;
+
     @Override
     public void validate(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) {
-        Assert.hasKeyAndValue(reqJson, "machineId", "machineId涓嶈兘涓虹┖");
-Assert.hasKeyAndValue(reqJson, "communityId", "communityId涓嶈兘涓虹┖");
+        Assert.hasKeyAndValue(reqJson, "machineId", "璁惧ID涓嶈兘涓虹┖");
+        Assert.hasKeyAndValue(reqJson, "machineCode", "蹇呭~锛岃濉啓璁惧缂栫爜");
+        Assert.hasKeyAndValue(reqJson, "machineVersion", "蹇呭~锛岃濉啓璁惧鐗堟湰鍙�");
+        Assert.hasKeyAndValue(reqJson, "machineName", "蹇呭~锛岃濉啓璁惧鍚嶇О");
+        Assert.hasKeyAndValue(reqJson, "machineTypeCd", "蹇呭~锛岃閫夋嫨璁惧绫诲瀷");
+        Assert.hasKeyAndValue(reqJson, "direction", "蹇呭~锛岃閫夋嫨璁惧鏂瑰悜");
+        Assert.hasKeyAndValue(reqJson, "authCode", "蹇呭~锛岃濉啓閴存潈缂栫爜");
+        Assert.hasKeyAndValue(reqJson, "locationTypeCd", "蹇呭~锛岃閫夋嫨浣嶇疆绫诲瀷");
+        Assert.hasKeyAndValue(reqJson, "locationObjId", "蹇呭~锛岃濉啓浣嶇疆瀵硅薄ID");
+
+        Assert.judgeAttrValue(reqJson);
 
     }
 
@@ -62,13 +80,41 @@
     @Java110Transactional
     public void doCmd(CmdEvent event, ICmdDataFlowContext cmdDataFlowContext, JSONObject reqJson) throws CmdException {
 
-       MachinePo machinePo = BeanConvertUtil.covertBean(reqJson, MachinePo.class);
+        MachinePo machinePo = BeanConvertUtil.covertBean(reqJson, MachinePo.class);
         int flag = machineV1InnerServiceSMOImpl.updateMachine(machinePo);
 
         if (flag < 1) {
             throw new CmdException("鏇存柊鏁版嵁澶辫触");
         }
 
+        JSONArray attrs = reqJson.getJSONArray("attrs");
+        if (attrs.size() < 1) {
+            return;
+        }
+
+
+        MachineAttrPo attr = null;
+        JSONObject aObj = null;
+        for (int attrIndex = 0; attrIndex < attrs.size(); attrIndex++) {
+            aObj = attrs.getJSONObject(attrIndex);
+            attr = BeanConvertUtil.covertBean(aObj, MachineAttrPo.class);
+            attr.setCommunityId(reqJson.getString("communityId"));
+            attr.setMachineId(reqJson.getString("machineId"));
+            if (!aObj.containsKey("attrId") || aObj.getString("attrId").startsWith("-") || StringUtil.isEmpty(aObj.getString("attrId"))) {
+                attr.setAttrId(GenerateCodeFactory.getGeneratorId("11"));
+                flag = machineAttrInnerServiceSMOImpl.saveMachineAttrs(attr);
+                if (flag < 1) {
+                    throw new CmdException("娣诲姞鏁版嵁澶辫触");
+                }
+                continue;
+            }
+            attr.setAttrId(aObj.getString("attrId"));
+            flag = machineAttrInnerServiceSMOImpl.updateMachineAttrs(attr);
+            if (flag < 1) {
+                throw new CmdException("鏇存柊鏁版嵁澶辫触");
+            }
+        }
+
         cmdDataFlowContext.setResponseEntity(ResultVo.success());
     }
 }

--
Gitblit v1.8.0