| package com.fzzy.async.fzzy61.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.fzzy61.entity.Fz61DepotStatusConfirm; | 
| import com.fzzy.async.fzzy61.repository.Fzzy61Sync1213Rep; | 
| 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 Fzzy61Sync1213 { | 
|   | 
|     @Autowired | 
|     private Fzzy61Sync1213Rep fzzy61Sync1213Rep; | 
|     @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<Fz61DepotStatusConfirm> list = fzzy61Sync1213Rep.listData(deptId, start, end); | 
|             if (null == list || list.isEmpty()) { | 
|                 log.info("-------------没有获取到封仓确认信息------------------"); | 
|                 return; | 
|             } | 
|   | 
|             Api1213 apiData; | 
|             Api1105 api1105; | 
|             List<Api1213> api1213List; | 
|             for (Fz61DepotStatusConfirm 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("---1213封仓确认信息同步失败----{}", e.toString()); | 
|             apiLog.setResult("同步失败:" + e.getMessage()); | 
|             apiLogRep.save(apiLog); | 
|         } | 
|     } | 
| } |