From cb396d1fc735f73b7ccf33b3be5d9231a8b79dae Mon Sep 17 00:00:00 2001
From: java110 <928255095@qq.com>
Date: 星期二, 07 九月 2021 22:51:17 +0800
Subject: [PATCH] 优化代码
---
service-job/src/main/java/com/java110/job/adapt/hcToTianchuang/PersonToTianchuangAdapt.java | 150 ++++++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 150 insertions(+), 0 deletions(-)
diff --git a/service-job/src/main/java/com/java110/job/adapt/hcToTianchuang/PersonToTianchuangAdapt.java b/service-job/src/main/java/com/java110/job/adapt/hcToTianchuang/PersonToTianchuangAdapt.java
new file mode 100644
index 0000000..a9a104f
--- /dev/null
+++ b/service-job/src/main/java/com/java110/job/adapt/hcToTianchuang/PersonToTianchuangAdapt.java
@@ -0,0 +1,150 @@
+/*
+ * 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.hcToTianchuang;
+
+import com.alibaba.fastjson.JSONArray;
+import com.alibaba.fastjson.JSONObject;
+import com.java110.dto.UnitDto;
+import com.java110.dto.businessDatabus.CustomBusinessDatabusDto;
+import com.java110.dto.community.CommunityAttrDto;
+import com.java110.dto.community.CommunityDto;
+import com.java110.dto.communityLocationAttr.CommunityLocationAttrDto;
+import com.java110.dto.file.FileRelDto;
+import com.java110.dto.machine.MachineDto;
+import com.java110.entity.order.Business;
+import com.java110.intf.common.IFileRelInnerServiceSMO;
+import com.java110.intf.common.IMachineInnerServiceSMO;
+import com.java110.intf.community.ICommunityInnerServiceSMO;
+import com.java110.intf.community.ICommunityLocationAttrInnerServiceSMO;
+import com.java110.intf.community.IUnitInnerServiceSMO;
+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.floor.FloorPo;
+import com.java110.po.machine.MachineRecordPo;
+import com.java110.utils.cache.MappingCache;
+import com.java110.utils.util.Assert;
+import com.java110.utils.util.BeanConvertUtil;
+import com.java110.utils.util.StringUtil;
+import org.springframework.beans.factory.annotation.Autowired;
+import org.springframework.stereotype.Component;
+
+import java.util.List;
+
+/**
+ * 寮�闂ㄨ褰曚俊鎭� 鍚屾澶╃獥鎺ュ彛
+ * <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 = "personToTianchuangAdapt")
+public class PersonToTianchuangAdapt extends DatabusAdaptImpl {
+
+ @Autowired
+ private ICommunityInnerServiceSMO communityInnerServiceSMOImpl;
+
+ @Autowired
+ private BaseHcGovSendAsyn baseHcGovSendAsynImpl;
+
+ @Autowired
+ private IMachineInnerServiceSMO machineInnerServiceSMOImpl;
+
+ @Autowired
+ private ICommunityLocationAttrInnerServiceSMO communityLocationAttrInnerServiceSMOImpl;
+
+ @Autowired
+ private IFileRelInnerServiceSMO fileRelInnerServiceSMOImpl;
+ /**
+ * @param customBusinessDatabusDto 褰撳墠澶勭悊涓氬姟
+ */
+ @Override
+ public void customExchange(CustomBusinessDatabusDto customBusinessDatabusDto) {
+ JSONObject data = customBusinessDatabusDto.getData();
+ doInoutRecord(null, data);
+ }
+
+ private void doInoutRecord(Business business, JSONObject businessInoutRecord) {
+
+ MachineRecordPo machineRecordPo = BeanConvertUtil.covertBean(businessInoutRecord, MachineRecordPo.class);
+ CommunityDto communityDto = new CommunityDto();
+ communityDto.setCommunityId(machineRecordPo.getCommunityId());
+ List<CommunityDto> communityDtos = communityInnerServiceSMOImpl.queryCommunitys(communityDto);
+
+ Assert.listNotNull(communityDtos, "鏈寘鍚皬鍖轰俊鎭�");
+ CommunityDto tmpCommunityDto = communityDtos.get(0);
+ String extCommunityId = "";
+ String communityId = tmpCommunityDto.getCommunityId();
+ String machineRecordId = machineRecordPo.getMachineRecordId();
+
+ for (CommunityAttrDto communityAttrDto : tmpCommunityDto.getCommunityAttrDtos()) {
+ if (HcGovConstant.EXT_COMMUNITY_ID.equals(communityAttrDto.getSpecCd())) {
+ extCommunityId = communityAttrDto.getValue();
+ }
+ }
+
+ //鏌ヨ璁惧瀵瑰簲鐨勪綅缃�
+ MachineDto machineDto = new MachineDto();
+ machineDto.setCommunityId(communityId);
+ machineDto.setMachineId(machineRecordPo.getMachineId());
+ List<MachineDto> machineDtos = machineInnerServiceSMOImpl.queryMachines(machineDto);
+
+ Assert.listOnlyOne(machineDtos, "涓嶅寘鍚� 璁惧淇℃伅");
+
+ String locationId = machineDtos.get(0).getLocationTypeCd();
+
+ CommunityLocationAttrDto communityLocationAttrDto = new CommunityLocationAttrDto();
+ communityLocationAttrDto.setCommunityId(machineDtos.get(0).getCommunityId());
+ communityLocationAttrDto.setLocationId(locationId);
+ communityLocationAttrDto.setSpecCd(HcGovConstant.EXT_COMMUNITY_ID);
+ List<CommunityLocationAttrDto> communityLocationAttrDtos
+ = communityLocationAttrInnerServiceSMOImpl.queryCommunityLocationAttrs(communityLocationAttrDto);
+
+ Assert.listOnlyOne(communityLocationAttrDtos, "鏈壘鍒� 浣嶇疆澶栭儴ID");
+
+ FileRelDto fileRelDto = new FileRelDto();
+ fileRelDto.setRelTypeCd("60000");
+ fileRelDto.setObjId(machineRecordPo.getMachineRecordId());
+ List<FileRelDto> fileRelDtos = fileRelInnerServiceSMOImpl.queryFileRels(fileRelDto);
+ String url = "";
+ String imgUrl = MappingCache.getValue("IMG_PATH");
+ imgUrl += (!StringUtil.isEmpty(imgUrl) && imgUrl.endsWith("/") ? "" : "/");
+ if (fileRelDtos != null && fileRelDtos.size() > 0) {
+ url = imgUrl + fileRelDtos.get(0).getFileRealName();
+ }
+
+ JSONObject body = new JSONObject();
+ body.put("extLocationId", communityLocationAttrDtos.get(0).getValue());
+ body.put("name", machineRecordPo.getName());
+ body.put("openTypeCd", machineRecordPo.getOpenTypeCd());
+ body.put("tel", machineRecordPo.getTel());
+ body.put("idCard", machineRecordPo.getIdCard());
+ body.put("recordTypeCd", machineRecordPo.getRecordTypeCd());
+ body.put("faceUrl", url);
+ String state = "F";
+ if (StringUtil.isNumber(machineRecordPo.getSimilar())) {
+ double similar = Double.parseDouble(machineRecordPo.getSimilar());
+ if (similar > 0.5) {
+ state = "C";
+ }
+ }
+ body.put("state", state);
+
+ JSONObject kafkaData = baseHcGovSendAsynImpl.createHeadersOrBody(body, extCommunityId, HcGovConstant.ADD_INOUT_RECORD_ACTION, HcGovConstant.COMMUNITY_SECURE);
+ baseHcGovSendAsynImpl.sendKafka(HcGovConstant.GOV_TOPIC, kafkaData, communityId, machineRecordId, HcGovConstant.COMMUNITY_SECURE);
+ }
+
+}
--
Gitblit v1.8.0