From 05683f2b2bdbdbe21cf17ad523c21ab338bd1c54 Mon Sep 17 00:00:00 2001
From: wuxw <928255095@qq.com>
Date: 星期二, 19 七月 2022 21:49:55 +0800
Subject: [PATCH] 优化添加设备 功能

---
 service-common/src/main/java/com/java110/common/bmo/machine/impl/MachineOpenDoorBMOImpl.java |   87 +++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 87 insertions(+), 0 deletions(-)

diff --git a/service-common/src/main/java/com/java110/common/bmo/machine/impl/MachineOpenDoorBMOImpl.java b/service-common/src/main/java/com/java110/common/bmo/machine/impl/MachineOpenDoorBMOImpl.java
old mode 100644
new mode 100755
index 4a40330..c5ed56f
--- a/service-common/src/main/java/com/java110/common/bmo/machine/impl/MachineOpenDoorBMOImpl.java
+++ b/service-common/src/main/java/com/java110/common/bmo/machine/impl/MachineOpenDoorBMOImpl.java
@@ -17,11 +17,18 @@
 
 import com.alibaba.fastjson.JSONObject;
 import com.java110.common.bmo.machine.IMachineOpenDoorBMO;
+import com.java110.dto.machine.MachineTranslateDto;
+import com.java110.dto.owner.OwnerAttrDto;
+import com.java110.dto.owner.OwnerDto;
+import com.java110.intf.common.IMachineTranslateInnerServiceSMO;
 import com.java110.intf.job.IDataBusInnerServiceSMO;
+import com.java110.intf.user.IOwnerInnerServiceSMO;
 import com.java110.vo.ResultVo;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.http.ResponseEntity;
 import org.springframework.stereotype.Service;
+
+import java.util.List;
 
 /**
  * 璁惧寮�闂ㄥ姛鑳�
@@ -34,6 +41,11 @@
 
     @Autowired
     IDataBusInnerServiceSMO dataBusInnerServiceSMOImpl;
+    @Autowired
+    private IOwnerInnerServiceSMO ownerInnerServiceSMOImpl;
+
+    @Autowired
+    private IMachineTranslateInnerServiceSMO machineTranslateInnerServiceSMOImpl;
 
     /**
      * 寮�闂ㄥ姛鑳�
@@ -43,8 +55,55 @@
      */
     @Override
     public ResponseEntity<String> openDoor(JSONObject reqJson) {
+        //濡傛灉鏄笟涓� 闄愬埗寮�闂ㄦ鏁�
+        if ("owner".equals(reqJson.getString("userRole"))) {
+            OwnerDto ownerDto = new OwnerDto();
+            ownerDto.setMemberId(reqJson.getString("userId"));
+            ownerDto.setCommunityId(reqJson.getString("communityId"));
+            List<OwnerDto> ownerDtos = ownerInnerServiceSMOImpl.queryOwners(ownerDto);
+            if (ownerDtos == null || ownerDtos.size() < 1) {
+                return ResultVo.error("娌℃湁鏉冮檺寮�闂�");
+            }
+
+            if (!hasOpenDoorPri(ownerDtos.get(0), reqJson.getString("machineCode"))) {
+                return ResultVo.error("浠婃棩寮�闂ㄦ鏁板凡鐢ㄥ畬锛岃鑱旂郴鐗╀笟瀹㈡湇浜哄憳");
+            }
+        }
         ResultVo resultVo = dataBusInnerServiceSMOImpl.openDoor(reqJson);
         return ResultVo.createResponseEntity(resultVo);
+    }
+
+    private boolean hasOpenDoorPri(OwnerDto ownerDto, String machineCode) {
+
+        List<OwnerAttrDto> ownerAttrDtos = ownerDto.getOwnerAttrDtos();
+
+        if (ownerAttrDtos == null || ownerAttrDtos.size() < 1) {
+            return true;
+        }
+        long openDoorCount = -1;
+        for (OwnerAttrDto ownerAttrDto : ownerAttrDtos) {
+            if (OwnerAttrDto.SPEC_CD_MACHINE_OPEN_COUNT.equals(ownerAttrDto.getSpecCd())) {
+                openDoorCount = Long.parseLong(ownerAttrDto.getValue());
+            }
+        }
+
+        if (openDoorCount == -1) { //璇存槑娌℃湁閰嶇疆 涓嶉檺鍒�
+            return true;
+        }
+
+        MachineTranslateDto machineTranslateDto = new MachineTranslateDto();
+        machineTranslateDto.setCommunityId(ownerDto.getCommunityId());
+        machineTranslateDto.setMachineCode(machineCode);
+        machineTranslateDto.setObjBId(ownerDto.getMemberId());
+        machineTranslateDto.setMachineCmd(MachineTranslateDto.CMD_OPEN_DOOR);
+        machineTranslateDto.setIsNow("Y");
+        long count = machineTranslateInnerServiceSMOImpl.queryMachineTranslatesCount(machineTranslateDto);
+
+        if (openDoorCount > count) {
+            return true;
+        }
+
+        return false;
     }
 
     /**
@@ -58,4 +117,32 @@
         ResultVo resultVo = dataBusInnerServiceSMOImpl.restartMachine(reqJson);
         return ResultVo.createResponseEntity(resultVo);
     }
+
+    @Override
+    public ResponseEntity<String> resendIot(JSONObject reqJson) {
+        ResultVo resultVo = dataBusInnerServiceSMOImpl.resendIot(reqJson);
+        return ResultVo.createResponseEntity(resultVo);
+    }
+
+    @Override
+    public ResponseEntity<String> getQRcode(JSONObject reqJson) {
+        //濡傛灉鏄笟涓� 闄愬埗寮�闂ㄦ鏁�
+
+        OwnerDto ownerDto = new OwnerDto();
+        ownerDto.setMemberId(reqJson.getString("userId"));
+        ownerDto.setCommunityId(reqJson.getString("communityId"));
+        List<OwnerDto> ownerDtos = ownerInnerServiceSMOImpl.queryOwners(ownerDto);
+        if (ownerDtos == null || ownerDtos.size() < 1) {
+            return ResultVo.error("娌℃湁鏉冮檺寮�闂�");
+        }
+
+        ResultVo resultVo = dataBusInnerServiceSMOImpl.getQRcode(reqJson);
+        return ResultVo.createResponseEntity(resultVo.getCode(), resultVo.getMsg(), resultVo.getData());
+    }
+
+    @Override
+    public ResponseEntity<String> customCarInOut(JSONObject reqJson) {
+        ResultVo resultVo = dataBusInnerServiceSMOImpl.customCarInOut(reqJson);
+        return ResultVo.createResponseEntity(resultVo);
+    }
 }

--
Gitblit v1.8.0