wuxw лет назад: 6
Родитель
Сommit
daa7b24f0c

+ 230 - 3
Api/src/main/java/com/java110/api/listener/machineTranslate/MachineHeartbeatListener.java

@@ -6,20 +6,30 @@ import com.aliyuncs.utils.StringUtils;
 import com.java110.api.listener.AbstractServiceApiListener;
 import com.java110.core.annotation.Java110Listener;
 import com.java110.core.context.DataFlowContext;
+import com.java110.core.smo.community.ICommunityInnerServiceSMO;
+import com.java110.core.smo.file.IFileInnerServiceSMO;
+import com.java110.core.smo.file.IFileRelInnerServiceSMO;
 import com.java110.core.smo.hardwareAdapation.IMachineInnerServiceSMO;
 import com.java110.core.smo.hardwareAdapation.IMachineTranslateInnerServiceSMO;
+import com.java110.core.smo.owner.IOwnerInnerServiceSMO;
+import com.java110.dto.OwnerDto;
+import com.java110.dto.community.CommunityDto;
+import com.java110.dto.file.FileDto;
+import com.java110.dto.file.FileRelDto;
 import com.java110.dto.hardwareAdapation.MachineDto;
 import com.java110.dto.hardwareAdapation.MachineTranslateDto;
 import com.java110.event.service.api.ServiceDataFlowEvent;
 import com.java110.utils.constant.ServiceCodeMachineTranslateConstant;
 import com.java110.utils.constant.StatusConstant;
 import com.java110.utils.util.Assert;
+import com.java110.utils.util.DateUtil;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.http.HttpHeaders;
 import org.springframework.http.HttpMethod;
 import org.springframework.http.HttpStatus;
 import org.springframework.http.ResponseEntity;
 
+import java.text.ParseException;
 import java.util.List;
 import java.util.Map;
 import java.util.UUID;
@@ -38,6 +48,18 @@ public class MachineHeartbeatListener extends AbstractServiceApiListener {
     @Autowired
     private IMachineInnerServiceSMO machineInnerServiceSMOImpl;
 
+    @Autowired
+    private IOwnerInnerServiceSMO ownerInnerServiceSMOImpl;
+
+    @Autowired
+    private ICommunityInnerServiceSMO communityInnerServiceSMOImpl;
+
+    @Autowired
+    private IFileRelInnerServiceSMO fileRelInnerServiceSMOImpl;
+
+    @Autowired
+    private IFileInnerServiceSMO fileInnerServiceSMOImpl;
+
     /**
      * {
      * "machineCode":"test-MachineCode",
@@ -58,9 +80,15 @@ public class MachineHeartbeatListener extends AbstractServiceApiListener {
      */
     @Override
     protected void validate(ServiceDataFlowEvent event, JSONObject reqJson) {
-        Assert.hasKeyAndValue(reqJson, "machineCode", "请求报文中未包含设备编码");
+       /* Assert.hasKeyAndValue(reqJson, "machineCode", "请求报文中未包含设备编码");
         //Assert.hasKeyAndValue(reqJson, "communityId", "请求报文中未包含小区信息");
-        Assert.hasKeyAndValue(reqJson, "authCode", "请求报文中未包含设备鉴权码");
+        Assert.hasKeyAndValue(reqJson, "authCode", "请求报文中未包含设备鉴权码");*/
+        DataFlowContext context = event.getDataFlowContext();
+        Map<String, String> reqHeader = context.getRequestHeaders();
+        Assert.hasKeyAndValue(reqHeader, "machinecode", "请求报文中未包含设备编码");
+        Assert.hasKeyAndValue(reqHeader, "communityId", "请求报文中未包含小区信息");
+        Assert.hasKeyAndValue(reqHeader, "command", "请求报文中未包含设备编码");
+
     }
 
     @Override
@@ -84,13 +112,15 @@ public class MachineHeartbeatListener extends AbstractServiceApiListener {
             return;
         }
         for (String key : reqHeader.keySet()) {
-            if(key.toLowerCase().equals("content-length")){
+            if (key.toLowerCase().equals("content-length")) {
                 continue;
             }
             headers.add(key, reqHeader.get(key));
         }
 
         String communityId = reqHeader.get("communityId");
+        String command = reqHeader.get("communityId");
+
 
         //检查设备是否合法
         MachineDto machineDto = new MachineDto();
@@ -105,7 +135,46 @@ public class MachineHeartbeatListener extends AbstractServiceApiListener {
             return;
         }
 
+        //获取任务
+        if ("gettask".equals(command)) {
+            this.getTask(event, context, reqJson, reqHeader, headers);
+            return;
+        } else if ("getface".equals(command)) {
+            this.getFace(event, context, reqJson, reqHeader, headers);
+            return;
+        } else if ("record".equals(command)) {
+            this.record(event, context, reqJson, reqHeader, headers);
+            return;
+        } else if ("report".equals(command)) {
+            this.report(event, context, reqJson, reqHeader, headers);
+            return;
+        } else {
+            outParam.put("code", -1);
+            outParam.put("message", "当前不支持该命令" + command);
+            responseEntity = new ResponseEntity<>(outParam.toJSONString(), headers, HttpStatus.OK);
+            context.setResponseEntity(responseEntity);
+            return;
+        }
 
+
+    }
+
+    /**
+     * 获取任务
+     *
+     * @param event
+     * @param context
+     * @param reqJson
+     */
+    private void getTask(ServiceDataFlowEvent event, DataFlowContext context, JSONObject reqJson, Map<String, String> reqHeader, HttpHeaders headers) {
+        JSONObject outParam = null;
+        ResponseEntity<String> responseEntity = null;
+
+        outParam = new JSONObject();
+        outParam.put("code", 0);
+        outParam.put("message", "success");
+        JSONArray data = null;
+        String communityId = reqHeader.get("communityId");
         //查询删除的业主信息
         MachineTranslateDto machineTranslateDto = new MachineTranslateDto();
         machineTranslateDto.setMachineCode(reqJson.getString("machineCode"));
@@ -160,6 +229,132 @@ public class MachineHeartbeatListener extends AbstractServiceApiListener {
         context.setResponseEntity(responseEntity);
     }
 
+    private void getFace(ServiceDataFlowEvent event, DataFlowContext context, JSONObject reqJson, Map<String, String> reqHeader, HttpHeaders headers) {
+        JSONObject outParam = null;
+        ResponseEntity<String> responseEntity = null;
+
+        outParam = new JSONObject();
+        outParam.put("code", 0);
+        outParam.put("message", "success");
+        JSONArray data = null;
+        String communityId = reqHeader.get("communityId");
+
+        //检查是否存在该用户
+        OwnerDto ownerDto = new OwnerDto();
+        ownerDto.setCommunityId(communityId);
+        ownerDto.setOwnerId(reqJson.getString("faceid"));
+        List<OwnerDto> ownerDtos = ownerInnerServiceSMOImpl.queryOwners(ownerDto);
+
+        if (ownerDtos == null || ownerDtos.size() != 1) {
+            outParam.put("code", -1);
+            outParam.put("message", "未找到相应业主信息");
+            responseEntity = new ResponseEntity<>(outParam.toJSONString(), headers, HttpStatus.OK);
+            context.setResponseEntity(responseEntity);
+            return;
+        }
+        CommunityDto communityDto = new CommunityDto();
+        communityDto.setCommunityId(communityId);
+        List<CommunityDto> communityDtos = communityInnerServiceSMOImpl.queryCommunitys(communityDto);
+        if (communityDtos == null || communityDtos.size() != 1) {
+            outParam.put("code", -1);
+            outParam.put("message", "未找到相应小区信息");
+            responseEntity = new ResponseEntity<>(outParam.toJSONString(), headers, HttpStatus.OK);
+            context.setResponseEntity(responseEntity);
+            return;
+        }
+        FileRelDto fileRelDto = new FileRelDto();
+        fileRelDto.setObjId(reqJson.getString("faceid"));
+        fileRelDto.setRelTypeCd("10000");
+        List<FileRelDto> fileRelDtos = fileRelInnerServiceSMOImpl.queryFileRels(fileRelDto);
+        if (fileRelDtos == null || fileRelDtos.size() != 1) {
+            outParam.put("code", -1);
+            outParam.put("message", "未找到业主照片,可能未录入照片");
+            responseEntity = new ResponseEntity<>(outParam.toJSONString(), headers, HttpStatus.OK);
+            context.setResponseEntity(responseEntity);
+            return;
+        }
+        FileDto fileDto = new FileDto();
+        fileDto.setFileId(fileRelDtos.get(0).getFileSaveName());
+        fileDto.setCommunityId(communityId);
+        List<FileDto> fileDtos = fileInnerServiceSMOImpl.queryFiles(fileDto);
+        if (fileDtos == null || fileDtos.size() != 1) {
+            outParam.put("code", -1);
+            outParam.put("message", "未找到业主照片,可能未录入照片");
+            responseEntity = new ResponseEntity<>(outParam.toJSONString(), headers, HttpStatus.OK);
+            context.setResponseEntity(responseEntity);
+            return;
+        }
+
+        JSONObject dataObj = new JSONObject();
+        dataObj.put("userid", ownerDtos.get(0).getOwnerId());
+        dataObj.put("groupid", communityId);
+        dataObj.put("group", communityDtos.get(0).getName());
+        dataObj.put("name", ownerDtos.get(0).getName());
+        dataObj.put("faceBase64", fileDtos.get(0).getContext()
+                .replace("data:image/webp;base64,", "")
+                .replace("data:image/png;base64,", "")
+                .replace("data:image/jpeg;base64,", ""));
+        dataObj.put("idNumber", ownerDtos.get(0).getOwnerId());
+        dataObj.put("startTime", ownerDtos.get(0).getCreateTime().getTime());
+        try {
+            dataObj.put("endTime", DateUtil.getLastDate().getTime());
+        } catch (ParseException e) {
+            dataObj.put("endTime", 2145891661);
+        }
+        dataObj.put("remarks", "HC小区管理系统");
+        dataObj.put("reserved", ownerDtos.get(0).getOwnerId());
+        outParam.put("data", dataObj);
+
+        //将 设备 待同步 改为同步中
+        MachineTranslateDto tmpMtDto = new MachineTranslateDto();
+        tmpMtDto.setMachineCode(reqHeader.get("machinecode"));
+        tmpMtDto.setCommunityId(communityId);
+        tmpMtDto.setState("20000");
+        machineTranslateInnerServiceSMOImpl.updateMachineTranslateState(tmpMtDto);
+
+        responseEntity = new ResponseEntity<>(outParam.toJSONString(), headers, HttpStatus.OK);
+        context.setResponseEntity(responseEntity);
+    }
+
+    private void record(ServiceDataFlowEvent event, DataFlowContext context, JSONObject reqJson, Map<String, String> reqHeader, HttpHeaders headers) {
+        JSONObject outParam = null;
+        ResponseEntity<String> responseEntity = null;
+
+        outParam = new JSONObject();
+        outParam.put("code", 0);
+        outParam.put("message", "success");
+        JSONArray data = null;
+        String communityId = reqHeader.get("communityId");
+        outParam.put("data", data);
+
+        responseEntity = new ResponseEntity<>(outParam.toJSONString(), headers, HttpStatus.OK);
+        context.setResponseEntity(responseEntity);
+    }
+
+    /**
+     * 执行结果上报
+     *
+     * @param event
+     * @param context
+     * @param reqJson
+     * @param reqHeader
+     * @param headers
+     */
+    private void report(ServiceDataFlowEvent event, DataFlowContext context, JSONObject reqJson, Map<String, String> reqHeader, HttpHeaders headers) {
+        JSONObject outParam = null;
+        ResponseEntity<String> responseEntity = null;
+
+        outParam = new JSONObject();
+        outParam.put("code", 0);
+        outParam.put("message", "success");
+        JSONArray data = null;
+        String communityId = reqHeader.get("communityId");
+        outParam.put("data", data);
+
+        responseEntity = new ResponseEntity<>(outParam.toJSONString(), headers, HttpStatus.OK);
+        context.setResponseEntity(responseEntity);
+    }
+
     @Override
     public String getServiceCode() {
         return ServiceCodeMachineTranslateConstant.MACHINE_HEARTBEAT;
@@ -190,4 +385,36 @@ public class MachineHeartbeatListener extends AbstractServiceApiListener {
     public void setMachineInnerServiceSMOImpl(IMachineInnerServiceSMO machineInnerServiceSMOImpl) {
         this.machineInnerServiceSMOImpl = machineInnerServiceSMOImpl;
     }
+
+    public IOwnerInnerServiceSMO getOwnerInnerServiceSMOImpl() {
+        return ownerInnerServiceSMOImpl;
+    }
+
+    public void setOwnerInnerServiceSMOImpl(IOwnerInnerServiceSMO ownerInnerServiceSMOImpl) {
+        this.ownerInnerServiceSMOImpl = ownerInnerServiceSMOImpl;
+    }
+
+    public ICommunityInnerServiceSMO getCommunityInnerServiceSMOImpl() {
+        return communityInnerServiceSMOImpl;
+    }
+
+    public void setCommunityInnerServiceSMOImpl(ICommunityInnerServiceSMO communityInnerServiceSMOImpl) {
+        this.communityInnerServiceSMOImpl = communityInnerServiceSMOImpl;
+    }
+
+    public IFileRelInnerServiceSMO getFileRelInnerServiceSMOImpl() {
+        return fileRelInnerServiceSMOImpl;
+    }
+
+    public void setFileRelInnerServiceSMOImpl(IFileRelInnerServiceSMO fileRelInnerServiceSMOImpl) {
+        this.fileRelInnerServiceSMOImpl = fileRelInnerServiceSMOImpl;
+    }
+
+    public IFileInnerServiceSMO getFileInnerServiceSMOImpl() {
+        return fileInnerServiceSMOImpl;
+    }
+
+    public void setFileInnerServiceSMOImpl(IFileInnerServiceSMO fileInnerServiceSMOImpl) {
+        this.fileInnerServiceSMOImpl = fileInnerServiceSMOImpl;
+    }
 }