From 3b1be358f4d8709d53901d9e16d4d1552b2d0b4f Mon Sep 17 00:00:00 2001
From: xiaogang <905166056@qq.com>
Date: 星期六, 17 七月 2021 23:07:46 +0800
Subject: [PATCH] 合并远程分支,并处理冲突

---
 service-common/src/main/java/com/java110/common/bmo/machine/impl/MachineOpenDoorBMOImpl.java |   59 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 59 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
index 2a0d66b..ab7b4bc 100755
--- 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,10 +55,57 @@
      */
     @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;
+    }
+
     /**
      * 閲嶅惎璁惧
      *

--
Gitblit v1.8.0