package com.fzzy.async.fzzy40.impl; import com.fzzy.api.Constant; import com.fzzy.api.entity.Api1102; import com.fzzy.api.entity.Api1105; import com.fzzy.api.entity.Api1207; 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.Api1102Rep; import com.fzzy.api.view.repository.Api1207Rep; import com.fzzy.api.view.repository.ApiLogRep; import com.fzzy.async.fzzy40.entity.Fz40InoutStockChange; import com.fzzy.async.fzzy40.repository.Fzzy40Sync1202Rep; import com.fzzy.async.fzzy40.repository.Fzzy40Sync1207Rep; 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; /** * 倒仓信息 * * @Author:YAN */ @Slf4j @Component public class Fzzy40Sync1207 { @Autowired private Fzzy40Sync1207Rep fzzySync1207Rep; @Autowired private ApiCommonService commonService; @Autowired private Api1207Rep api1207Rep; @Autowired private ApiLogRep apiLogRep; /** * 倒仓信息同步 * * @param kqdm * @param deptId * @param start * @param end */ public void syncData(String kqdm, String deptId, Date start, Date end) { log.info("-------------1207接口数据开始同步------------------"); //同步数据,只记录失败的信息 ApiLog apiLog = new ApiLog(); apiLog.setType(ApiLog.TYPE_SYNC); apiLog.setKqdm(deptId); apiLog.setUploadTime(new Date()); apiLog.setInteId(Constant.API_CODE_1207); apiLog.setStatus(99); apiLog.setId(ContextUtil.getUUID()); try { List list = fzzySync1207Rep.listStockChange(deptId, start, end); if (null == list || list.isEmpty()) { log.info("-------------没有获取到倒仓信息------------------"); return; } Api1207 apiData; Api1105 api1105In; Api1105 api1105Out; for (Fz40InoutStockChange sysData : list) { //获取货位信息 api1105Out = commonService.getApi1105Cache(sysData.getDepotIdOut()); if (null == api1105Out) { continue; } //获取货位信息 api1105In = commonService.getApi1105Cache(sysData.getDepotIdIn()); if (null == api1105In) { continue; } apiData = new Api1207(); apiData.setDcdh(kqdm + sysData.getId()); apiData.setDclx(sysData.getType()); apiData.setDcjhwjbh(sysData.getPlanCode()); apiData.setTzdh(sysData.getNoticeId()); apiData.setDcdw(kqdm); apiData.setDrdw(kqdm); apiData.setLspzdm(sysData.getFoodVariety()); apiData.setDchwdm(api1105Out.getHwdm()); apiData.setDrhwdm(api1105In.getHwdm()); apiData.setDcrq(sysData.getChangeDate()); apiData.setDcsl(sysData.getNumber()); apiData.setBzw(sysData.getBzw()); apiData.setBzbjs(sysData.getBzbjs()); apiData.setZxzydw(sysData.getZxzydw()); apiData.setCzbz(Constant.CZBZ_I); apiData.setZhgxsj(sysData.getUpdateTime()); apiData.setBizId(sysData.getId()); apiData.setKqdm(kqdm); apiData.setSyncTime(new Date()); //保存数据 api1207Rep.save(apiData); log.info("1207---同步数据:{}", apiData.toString()); } } catch (Exception e) { log.error("---倒仓信息同步失败----{}", e); apiLog.setResult("倒仓信息同步失败:" + e.getMessage()); apiLogRep.save(apiLog); } } }