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);
|
}
|
}
|
}
|