From 4e12aa79fa3affb0d0dc3e5f9d368814702f8d2b Mon Sep 17 00:00:00 2001
From: java110 <928255095@qq.com>
Date: 星期五, 31 三月 2023 16:22:14 +0800
Subject: [PATCH] optimize owner member
---
service-common/src/main/java/com/java110/common/cmd/machine/UpdateMachineCmd.java | 83 ++++++++++++++++++++++++++++++++++++++---
1 files changed, 76 insertions(+), 7 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..4e5c24b 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,31 @@
*/
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.dto.community.CommunityLocationDto;
+import com.java110.dto.machine.MachineDto;
+import com.java110.intf.common.IMachineAttrInnerServiceSMO;
import com.java110.intf.common.IMachineV1InnerServiceSMO;
+import com.java110.intf.community.ICommunityLocationV1InnerServiceSMO;
+import com.java110.po.machine.MachineAttrPo;
import com.java110.po.machine.MachinePo;
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;
+
+import java.util.List;
/**
@@ -45,30 +55,89 @@
@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;
+
+ @Autowired
+ private ICommunityLocationV1InnerServiceSMO communityLocationV1InnerServiceSMOImpl;
+
@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", "蹇呭~锛岃閫夋嫨浣嶇疆绫诲瀷");
+
+ MachineDto machineDto = new MachineDto();
+ machineDto.setMachineCode(reqJson.getString("machineCode"));
+ List<MachineDto> machineDtos = machineV1InnerServiceSMOImpl.queryMachines(machineDto);
+
+ if (machineDtos != null && machineDtos.size() > 0 && !reqJson.getString("machineId").equals(machineDtos.get(0).getMachineId())) {
+ throw new CmdException("璁惧宸插瓨鍦�");
+ }
+
+ Assert.judgeAttrValue(reqJson);
}
@Override
@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);
+ if (!MachineDto.MACHINE_TYPE_MONITOR.equals(reqJson.getString("machineTypeCd"))
+ && !MachineDto.MACHINE_TYPE_ATTENDANCE.equals(reqJson.getString("machineTypeCd"))
+ ) {
+ CommunityLocationDto communityLocationDto = new CommunityLocationDto();
+ communityLocationDto.setCommunityId(reqJson.getString("communityId"));
+ communityLocationDto.setLocationId(reqJson.getString("locationTypeCd"));
+ List<CommunityLocationDto> locationDtos = communityLocationV1InnerServiceSMOImpl.queryCommunityLocations(communityLocationDto);
+ Assert.listOnlyOne(locationDtos, "浣嶇疆涓嶅瓨鍦�");
+ machinePo.setLocationObjId(locationDtos.get(0).getLocationObjId());
+ }
+
int flag = machineV1InnerServiceSMOImpl.updateMachine(machinePo);
-
if (flag < 1) {
throw new CmdException("鏇存柊鏁版嵁澶辫触");
}
+ JSONArray attrs = reqJson.getJSONArray("attrs");
+ if (attrs == null || 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