package com.fzzy.async.fzzy35.impl; import com.fzzy.api.Constant; import com.fzzy.api.entity.Api1105; import com.fzzy.api.entity.Api1203; import com.fzzy.api.entity.ApiLog; import com.fzzy.api.entity.GbCheckItem; import com.fzzy.api.service.ApiCommonService; import com.fzzy.api.service.ApiTriggerService; import com.fzzy.api.utils.ContextUtil; import com.fzzy.api.view.repository.Api1203Rep; import com.fzzy.api.view.repository.ApiLogRep; import com.fzzy.api.view.repository.GbCheckItemRep; import com.fzzy.async.fzzy35.entity.InoutRecord; import com.fzzy.async.fzzy35.entity.CheckItem; import com.fzzy.async.fzzy35.repository.Fzzy35Sync1202Rep; import com.fzzy.async.fzzy35.repository.Fzzy35Sync1203Rep; 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 Fzzy35Sync1203 { /** * 入库类型 */ private final static String INOUT_TYPE_IN = "IN"; @Autowired private Fzzy35Sync1202Rep fzzySync1202Rep; @Autowired private Fzzy35Sync1203Rep fzzySync1203Rep; @Autowired private ApiTriggerService apiTriggerService; @Autowired private Api1203Rep api1203Rep; @Autowired private GbCheckItemRep gbCheckItemRep; @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("-------------1203接口数据开始同步------------------"); //同步数据,只记录失败的信息 ApiLog apiLog = new ApiLog(); apiLog.setType(ApiLog.TYPE_SYNC); apiLog.setKqdm(deptId); apiLog.setUploadTime(new Date()); apiLog.setInteId(Constant.API_CODE_1203); apiLog.setStatus(99); apiLog.setId(ContextUtil.getUUID()); try { //获取粮食入库记录信息 List list = fzzySync1202Rep.listInoutRecord(deptId, INOUT_TYPE_IN, start, end); if (null == list || list.isEmpty()) { log.info("-------------没有获取到粮食入库信息------------------"); return; } Api1203 apiData; Api1105 api1105; List checkItems; List gbCheckList; String jyxm; String jyz; String zkj; String zkl; for (InoutRecord sysData : list) { //获取入库质检信息 checkItems = fzzySync1203Rep.listInoutCheckItem(sysData.getCheckId()); if (null == checkItems || checkItems.isEmpty()) { log.info("-------------没有获取到当前入库质检信息--------------"); continue; } //获取货位信息 api1105 = commonService.getApi1105Cache(sysData.getDepotId()); if (null == api1105) { continue; } apiData = new Api1203(); apiData.setId(sysData.getId()); apiData.setRkjydh(Constant.INOUT_TYPE_14 + sysData.getId().substring(4)); //货位代码 apiData.setHwdm(api1105.getHwdm()); apiData.setRkywdh(apiData.getRkjydh()); apiData.setQysj(sysData.getFullWeightTime()); apiData.setQyrxm(sysData.getCheckUser()); //扦样方式 2-智能随机 apiData.setQyfs("2"); //检测项,检测值,增扣价及增扣量 jyxm = ""; jyz = ""; zkj = ""; zkl = ""; for (CheckItem checkItem : checkItems) { gbCheckList = gbCheckItemRep.findByBizCode(checkItem.getStandardId()); if (gbCheckList == null || gbCheckList.isEmpty()) { continue; } jyxm += gbCheckList.get(0).getCode() + ","; jyz += checkItem.getValue() + ","; zkj += "0,"; zkl += "0,"; } apiData.setJyxm(jyxm); apiData.setJyz(jyz); apiData.setZkj(zkj); apiData.setZkl(zkl); apiData.setJyjg("0"); apiData.setJyrxm(sysData.getCheckUser()); apiData.setJysj(sysData.getFullWeightTime()); //apiData.setJyjg(""); //粮食品种 String mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSPZ, sysData.getFoodVariety()); apiData.setLspzdm(mappingCode); //粮食等级 mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSDJ, sysData.getFoodLevel()); apiData.setLsdd(mappingCode); //操作标志及最后更新时间 apiData.setCzbz(Constant.CZBZ_I); apiData.setZhgxsj(sysData.getCompleteTime()); //业务id、库区编码、同步时间 apiData.setBizId(sysData.getId()); apiData.setKqdm(kqdm); apiData.setSyncTime(new Date()); //保存数据 api1203Rep.save(apiData); log.info("1203---同步数据:{}", apiData.toString()); } } catch (Exception e) { log.error("---同步失败----{}", e); apiLog.setResult("同步失败:" + e.getMessage()); apiLogRep.save(apiLog); } } }