package com.fzzy.async.fzzy35.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.async.fzzy35.entity.Fz35Depot;
|
import com.fzzy.async.fzzy35.repository.Fzzy35Sync1208Rep;
|
import lombok.extern.slf4j.Slf4j;
|
import org.apache.commons.lang.time.DateUtils;
|
import org.springframework.beans.factory.annotation.Autowired;
|
import org.springframework.stereotype.Component;
|
import java.util.Date;
|
import java.util.List;
|
|
/**
|
* 粮食库存
|
*/
|
@Slf4j
|
@Component
|
public class Fzzy35Sync1208 {
|
|
@Autowired
|
private Fzzy35Sync1208Rep fzzySync1208Rep;
|
@Autowired
|
private ApiTriggerService apiTriggerService;
|
@Autowired
|
private Api1208Rep api1208Rep;
|
@Autowired
|
private ApiCommonService commonService;
|
@Autowired
|
private Api1102Rep api1102Rep;
|
@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<Fz35Depot> list = fzzySync1208Rep.listDepot(deptId);
|
|
if (null == list || list.isEmpty()) {
|
|
log.info("-------------没有获取到粮食库存信息------------------");
|
|
return;
|
}
|
|
//根据库区代码获取单位代码
|
Api1102 api1102 = api1102Rep.findById(kqdm).get();
|
|
Api1208 apiData;
|
Api1105 api1105;
|
for (Fz35Depot fz35Depot : list) {
|
|
//获取货位信息
|
api1105 = commonService.getApi1105Cache(fz35Depot.getId());
|
if (null == api1105) {
|
continue;
|
}
|
|
apiData = new Api1208();
|
apiData.setHwdm(api1105.getHwdm());
|
|
//粮食品种
|
String mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSPZ, fz35Depot.getFoodVariety());
|
apiData.setLspzdm(mappingCode);
|
|
//粮食性质
|
mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSXZ, fz35Depot.getFoodType());
|
apiData.setLsxzdm(mappingCode);
|
|
//粮食等级
|
mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSDJ, fz35Depot.getFoodLevel());
|
apiData.setLsdjdm(mappingCode);
|
|
apiData.setShnd(fz35Depot.getFoodYear());
|
|
//产地代码
|
String cd = commonService.getFoodLocationIdFromCache(fz35Depot.getFoodLocation());
|
apiData.setCd(cd);
|
|
apiData.setBgy(fz35Depot.getStoreKeeperName());
|
//粮权归属单位
|
apiData.setLqgsdwdm(api1102.getDwdm());
|
//粮权行政区划代码
|
apiData.setLqxzqhdm(api1102.getDwdm().substring(2, 8));
|
//管理方式-默认直储
|
apiData.setGlfs("01");
|
//收储地点-默认库内
|
apiData.setScdd("1");
|
//储粮方式
|
apiData.setClfs(fz35Depot.getStoreType());
|
|
//货位状态
|
mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_HWZT, fz35Depot.getDepotStatus());
|
apiData.setHwzt(mappingCode);
|
if(null == fz35Depot.getStoreDate()){
|
fz35Depot.setStoreDate(new Date());
|
}
|
//入仓时间
|
apiData.setRcsj(fz35Depot.getStoreDate());
|
//封仓日期
|
if("3".equals(apiData.getHwzt())){
|
apiData.setFcrq(DateUtils.addDays(fz35Depot.getStoreDate(), 10));
|
}
|
//出仓完成时间
|
if("1".equals(apiData.getHwzt())){
|
apiData.setCcwcsj(DateUtils.addDays(fz35Depot.getStoreDate(), 5));
|
}
|
//国别
|
apiData.setGb("156");
|
apiData.setSjsl(fz35Depot.getStorageReal());
|
apiData.setJjsl(fz35Depot.getStorageReal());
|
apiData.setSjzlxg(6);
|
apiData.setLdtj(10000);
|
|
apiData.setZhgxsj(new Date());
|
|
//业务id、库区编码、同步时间
|
apiData.setBizId(fz35Depot.getId());
|
apiData.setKqdm(kqdm);
|
apiData.setSyncTime(new Date());
|
|
//库存每次新增
|
apiData.setCzbz(Constant.CZBZ_I);
|
apiData.setId(ContextUtil.getCurTimeMillis());
|
//保存数据
|
api1208Rep.save(apiData);
|
}
|
} catch (Exception e) {
|
log.error("---同步失败----{}", e);
|
apiLog.setResult("同步失败:" + e.getMessage());
|
apiLogRep.save(apiLog);
|
}
|
}
|
}
|