package com.fzzy.async.fzzy30.impl; import com.fzzy.api.Constant; import com.fzzy.api.entity.*; import com.fzzy.api.service.ApiCommonService; import com.fzzy.api.service.ApiTriggerService; import com.fzzy.api.utils.ContextUtil; import com.fzzy.api.view.repository.Api1102Rep; import com.fzzy.api.view.repository.Api1208Rep; import com.fzzy.api.view.repository.ApiLogRep; import com.fzzy.api.view.repository.GbAreaRep; import com.fzzy.async.fzzy30.entity.Depot; import com.fzzy.async.fzzy30.repository.FzzySync1208Rep; import lombok.extern.slf4j.Slf4j; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.stereotype.Component; import java.util.Date; import java.util.List; /** * 粮食库存 */ @Slf4j @Component public class Fzzy30Sync1208 { @Autowired private FzzySync1208Rep fzzySync1208Rep; @Autowired private ApiTriggerService apiTriggerService; @Autowired private Api1208Rep api1208Rep; @Autowired private ApiCommonService commonService; @Autowired private Api1102Rep api1102Rep; @Autowired private GbAreaRep gbAreaRep; @Autowired private ApiLogRep apiLogRep; /** * 同步粮食库存 * * @param deptId * @param start * @param end */ public void syncData(String kqdm, String deptId, Date start, Date end) { log.info("-------------1208接口数据开始同步------------------"); //同步数据,只记录失败的信息 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 = fzzySync1208Rep.listDepot(deptId); if (null == list || list.isEmpty()) { log.info("-------------没有获取到粮食库存信息------------------"); return; } //根据库区代码获取单位代码 Api1102 api1201 = api1102Rep.findById(kqdm).get(); Api1208 apiData; Api1105 api1105; List gbAreaList; for (Depot sysData : list) { //获取货位信息 api1105 = commonService.getApi1105Cache(sysData.getId()); if (null == api1105) { continue; } apiData = new Api1208(); apiData.setHwdm(api1105.getHwdm()); //粮食品种 String mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSPZ, sysData.getFoodVariety()); apiData.setLspzdm(mappingCode); //粮食性质 mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSXZ, sysData.getFoodType()); apiData.setLsxzdm(mappingCode); //粮食等级 mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSDJ, sysData.getFoodLevel()); apiData.setLsdjdm(mappingCode); apiData.setShnd(sysData.getFoodYear()); //产地代码 gbAreaList = gbAreaRep.listByName("%" + sysData.getFoodLocation() + "%"); apiData.setCd(gbAreaList.get(0).getCode()); apiData.setBgy(sysData.getStoreKeeperName()); apiData.setLqgsdwdm(api1201.getDwdm()); //货位状态 mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_HWZT, sysData.getDepotStatus()); apiData.setHwzt(mappingCode); //国别 mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_GB, sysData.getFoodLocation()); apiData.setGb(mappingCode); apiData.setRcsj(sysData.getStoreDate()); apiData.setSjsl(sysData.getStorageReal()); apiData.setJjsl(sysData.getStorageReal()); //操作标志及最后更新时间 apiData.setCzbz(Constant.CZBZ_U); apiData.setZhgxsj(new Date()); //业务id、库区编码、同步时间 apiData.setBizId(sysData.getId()); apiData.setKqdm(kqdm); apiData.setSyncTime(new Date()); apiData.setId(api1105.getHwdm()); //保存数据 api1208Rep.delete(apiData); api1208Rep.save(apiData); } } catch (Exception e) { log.error("---同步失败----{}", e); apiLog.setResult("同步失败:" + e.getMessage()); apiLogRep.save(apiLog); } } }