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