From b6148f118fe8e3cf99a1af6ed2f64ee9146bb05c Mon Sep 17 00:00:00 2001
From: 1098226878 <1098226878@qq.com>
Date: 星期一, 06 九月 2021 19:29:42 +0800
Subject: [PATCH] 完善推送业主

---
 service-job/src/main/java/com/java110/job/adapt/hcGov/HcGovConstant.java              |    5 +
 service-job/src/main/java/com/java110/job/adapt/hcGov/owner/AddOwnerToHcGovAdapt.java |  144 ++++++++++++++++++++++++++++++++++++++++++++++++
 2 files changed, 148 insertions(+), 1 deletions(-)

diff --git a/service-job/src/main/java/com/java110/job/adapt/hcGov/HcGovConstant.java b/service-job/src/main/java/com/java110/job/adapt/hcGov/HcGovConstant.java
index e0dcfe2..393e77a 100644
--- a/service-job/src/main/java/com/java110/job/adapt/hcGov/HcGovConstant.java
+++ b/service-job/src/main/java/com/java110/job/adapt/hcGov/HcGovConstant.java
@@ -48,7 +48,10 @@
     public static final String ADD_ROOM_ACTION = "ADD_ROOM";
     //淇敼鎴垮眿
     public static final String EDIT_ROOM_ACTION = "EDIT_ROOM";
-
+    //娣诲姞涓氫富
+    public static final String ADD_OWNER_ACTION = "ADD_OWNER";
+    //淇敼涓氫富
+    public static final String EDIT_OWNER_ACTION = "EDIT_OWNER";
 
     //娣诲姞浣嶇疆
     public static final String ADD_LOCATION_ACTION = "ADD_LOCATION";
diff --git a/service-job/src/main/java/com/java110/job/adapt/hcGov/owner/AddOwnerToHcGovAdapt.java b/service-job/src/main/java/com/java110/job/adapt/hcGov/owner/AddOwnerToHcGovAdapt.java
new file mode 100644
index 0000000..6f41b62
--- /dev/null
+++ b/service-job/src/main/java/com/java110/job/adapt/hcGov/owner/AddOwnerToHcGovAdapt.java
@@ -0,0 +1,144 @@
+/*
+ * Copyright 2017-2020 鍚村鏂� and java110 team.
+ *
+ * Licensed under the Apache License, Version 2.0 (the "License");
+ * you may not use this file except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ *      http://www.apache.org/licenses/LICENSE-2.0
+ *
+ * Unless required by applicable law or agreed to in writing, software
+ * distributed under the License is distributed on an "AS IS" BASIS,
+ * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
+ * See the License for the specific language governing permissions and
+ * limitations under the License.
+ */
+package com.java110.job.adapt.hcGov.owner;
+
+import com.alibaba.fastjson.JSONArray;
+import com.alibaba.fastjson.JSONObject;
+import com.java110.dto.FloorDto;
+import com.java110.dto.RoomAttrDto;
+import com.java110.dto.RoomDto;
+import com.java110.dto.UnitDto;
+import com.java110.dto.community.CommunityAttrDto;
+import com.java110.dto.community.CommunityDto;
+import com.java110.dto.floorAttr.FloorAttrDto;
+import com.java110.dto.owner.OwnerRoomRelDto;
+import com.java110.entity.order.Business;
+import com.java110.intf.community.*;
+import com.java110.intf.user.IOwnerRoomRelInnerServiceSMO;
+import com.java110.job.adapt.DatabusAdaptImpl;
+import com.java110.job.adapt.hcGov.HcGovConstant;
+import com.java110.job.adapt.hcGov.asyn.BaseHcGovSendAsyn;
+import com.java110.po.owner.OwnerPo;
+import com.java110.po.room.RoomPo;
+import com.java110.utils.util.Assert;
+import com.java110.utils.util.BeanConvertUtil;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Component;
+
+import java.util.List;
+
+/**
+ * 鏂板涓氫富淇℃伅鍚屾HC鏀垮姟鎺ュ彛
+ * <p>
+ * 鎺ュ彛鍗忚鍦板潃锛� https://gitee.com/java110/microCommunityInformation/tree/master/info-doc#1%E6%A5%BC%E6%A0%8B%E4%B8%8A%E4%BC%A0
+ *
+ * @desc add by 鍚村鏂� 16:20
+ */
+@Component(value = "addOwnerToHcGovAdapt")
+public class AddOwnerToHcGovAdapt extends DatabusAdaptImpl {
+
+    @Autowired
+    private ICommunityInnerServiceSMO communityInnerServiceSMOImpl;
+    @Autowired
+    private IRoomAttrInnerServiceSMO roomAttrInnerServiceSMOImpl;
+    @Autowired
+    private IOwnerRoomRelInnerServiceSMO ownerRoomRelInnerServiceSMOImpl;
+    @Autowired
+    private BaseHcGovSendAsyn baseHcGovSendAsynImpl;
+
+
+    /**
+     * @param business   褰撳墠澶勭悊涓氬姟
+     * @param businesses 鎵�鏈変笟鍔′俊鎭�
+     */
+    @Override
+    public void execute(Business business, List<Business> businesses) {
+        JSONObject data = business.getData();
+        if (data.containsKey(OwnerPo.class.getSimpleName())) {
+            Object bObj = data.get(OwnerPo.class.getSimpleName());
+            JSONArray businessOwner = null;
+            if (bObj instanceof JSONObject) {
+                businessOwner = new JSONArray();
+                businessOwner.add(bObj);
+            } else if (bObj instanceof List) {
+                businessOwner = JSONArray.parseArray(JSONObject.toJSONString(bObj));
+            } else {
+                businessOwner = (JSONArray) bObj;
+            }
+            //JSONObject businessOwnerCar = data.getJSONObject("businessOwnerCar");
+            for (int bOwnerIndex = 0; bOwnerIndex < businessOwner.size(); bOwnerIndex++) {
+                JSONObject businessOwnerCar = businessOwner.getJSONObject(bOwnerIndex);
+                doAddOwner(business, businessOwnerCar);
+
+            }
+        }
+    }
+
+    private void doAddOwner(Business business, JSONObject businessOwner) {
+
+        OwnerPo ownerPo = BeanConvertUtil.covertBean(businessOwner, OwnerPo.class);
+
+        CommunityDto communityDto = new CommunityDto();
+        communityDto.setCommunityId(ownerPo.getCommunityId());
+        List<CommunityDto> communityDtos = communityInnerServiceSMOImpl.queryCommunitys(communityDto);
+        Assert.listNotNull(communityDtos, "鏈寘鍚皬鍖轰俊鎭�");
+
+        CommunityDto tmpCommunityDto = communityDtos.get(0);
+        String extCommunityId = "";
+        JSONArray extRoomId = null;
+        String communityId = tmpCommunityDto.getCommunityId();
+        String ownerId = ownerPo.getOwnerId();
+
+        for (CommunityAttrDto communityAttrDto : tmpCommunityDto.getCommunityAttrDtos()) {
+            if (HcGovConstant.EXT_COMMUNITY_ID.equals(communityAttrDto.getSpecCd())) {
+                extCommunityId = communityAttrDto.getValue();
+            }
+        }
+        OwnerRoomRelDto ownerRoomRelDto = new OwnerRoomRelDto();
+        ownerRoomRelDto.setOwnerId(ownerId);
+        List<OwnerRoomRelDto> ownerRoomRelDtos = ownerRoomRelInnerServiceSMOImpl.queryOwnerRoomRels(ownerRoomRelDto);
+        if (ownerRoomRelDtos != null && ownerRoomRelDtos.size() > 0) {
+
+            RoomAttrDto roomAttrDto = new RoomAttrDto();
+            roomAttrDto.setRoomId(ownerRoomRelDtos.get(0).getRoomId());
+            roomAttrDto.setSpecCd(HcGovConstant.EXT_COMMUNITY_ID);
+            List<RoomAttrDto> roomAttrDtos = roomAttrInnerServiceSMOImpl.queryRoomAttrs(roomAttrDto);
+            if (roomAttrDtos != null && roomAttrDtos.size() > 0) {
+                extRoomId = new JSONArray();
+                for (RoomAttrDto roomAttr : roomAttrDtos) {
+                    if (HcGovConstant.EXT_COMMUNITY_ID.equals(roomAttr.getSpecCd())) {
+                        extRoomId.add(roomAttr.getValue());
+                    }
+                }
+            }
+        }
+
+
+        JSONObject body = new JSONObject();
+        body.put("idType", "1");
+        body.put("idCard", ownerPo.getIdCard());
+        body.put("personName", ownerPo.getName());
+        body.put("personTel", ownerPo.getLink());
+        body.put("personSex", ownerPo.getSex());
+        body.put("prePersonName", ownerPo.getName());
+        body.put("birthday", ownerPo.getIdCard());
+
+
+        JSONObject kafkaData = baseHcGovSendAsynImpl.createHeadersOrBody(body, extCommunityId, HcGovConstant.ADD_OWNER_ACTION, HcGovConstant.COMMUNITY_SECURE);
+        baseHcGovSendAsynImpl.sendKafka(HcGovConstant.GOV_TOPIC, kafkaData, communityId, ownerId, HcGovConstant.COMMUNITY_SECURE);
+    }
+
+}

--
Gitblit v1.8.0