package com.fzzy.async.fzzy40.impl; import com.fzzy.api.Constant; import com.fzzy.api.entity.Api1105; import com.fzzy.api.entity.Api1213; import com.fzzy.api.entity.ApiLog; import com.fzzy.api.service.ApiCommonService; import com.fzzy.api.service.ApiTriggerService; import com.fzzy.api.utils.ContextUtil; import com.fzzy.api.view.repository.Api1213Rep; import com.fzzy.api.view.repository.ApiLogRep; import com.fzzy.async.fzzy40.entity.Fz40DepotStatusConfirm; import com.fzzy.async.fzzy40.repository.Fzzy40Sync1213Rep; import lombok.extern.slf4j.Slf4j; import org.apache.commons.lang.StringUtils; import org.springframework.beans.BeanUtils; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; import java.util.Date; import java.util.List; /** * @author czt * 封仓确认单 */ @Slf4j @Component public class Fzzy40Sync1213 { @Autowired private Fzzy40Sync1213Rep fzzy40Sync1213Rep; @Autowired private ApiTriggerService apiTriggerService; @Autowired private Api1213Rep api1213Rep; @Autowired private ApiCommonService commonService; @Autowired private ApiLogRep apiLogRep; /** * 同步封仓确认信息 * * @param deptId * @param start * @param end */ public void syncData(String kqdm, String deptId, Date start, Date end) { log.info("-------------1213接口数据开始同步------------------"); //同步数据,只记录失败的信息 ApiLog apiLog = new ApiLog(); apiLog.setType(ApiLog.TYPE_SYNC); apiLog.setKqdm(deptId); apiLog.setUploadTime(new Date()); apiLog.setInteId(Constant.API_CODE_1208); apiLog.setStatus(99); apiLog.setId(ContextUtil.getUUID()); try { List list = fzzy40Sync1213Rep.listData(deptId, start, end); if (null == list || list.isEmpty()) { log.info("-------------没有获取到封仓确认信息------------------"); return; } Api1213 apiData; Api1105 api1105; List api1213List; for (Fz40DepotStatusConfirm depotStatusConfirm : list) { //获取货位信息 api1105 = commonService.getApi1105Cache(depotStatusConfirm.getDepotId()); if (null == api1105) { continue; } apiData = new Api1213(); BeanUtils.copyProperties(depotStatusConfirm, apiData); apiData.setFcqrdh(depotStatusConfirm.getFcqrdh()); apiData.setBizId(depotStatusConfirm.getFcqrdh()); apiData.setKqdm(kqdm); apiData.setHwdm(api1105.getHwdm()); //粮食品种 String mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSPZ, depotStatusConfirm.getFoodVariety().substring(0, 3)); apiData.setLspzdm(mappingCode); //粮食性质 mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSXZ, depotStatusConfirm.getFoodType()); apiData.setLsxzdm(mappingCode); //粮食等级 mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSDJ, depotStatusConfirm.getFoodLevel()); apiData.setLsdjdm(mappingCode); //产地代码 mappingCode = commonService.getFoodLocationIdFromCache(depotStatusConfirm.getFoodLocation()); if (StringUtils.isEmpty(mappingCode)) { mappingCode = apiData.getHwdm().substring(2, 8); } apiData.setCd(mappingCode); //年度 apiData.setShnd(depotStatusConfirm.getFoodYear()); if(StringUtils.isEmpty(depotStatusConfirm.getCountry())){ apiData.setGb("156"); } apiData.setBgy(depotStatusConfirm.getStoreKeeperName()); apiData.setFcsqr(depotStatusConfirm.getApplyUser()); apiData.setBmshr(depotStatusConfirm.getDeptAuditUser()); apiData.setLdshr(depotStatusConfirm.getLeaderAuditUser()); apiData.setZhgxsj(new Date()); api1213List = api1213Rep.getDataById(apiData.getBizId()); if (null == api1213List || api1213List.isEmpty()) { apiData.setCzbz(Constant.CZBZ_I); } else { apiData.setCzbz(api1213List.get(0).getCzbz()); } //保存数据 api1213Rep.save(apiData); } } catch (Exception e) { log.error("---同步失败----{}", e); apiLog.setResult("同步失败:" + e.getMessage()); apiLogRep.save(apiLog); } } }