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.apache.commons.lang.StringUtils;
|
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 ApiTriggerService apiTriggerService;
|
@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<Fz40InoutStockChange> 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);
|
String mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSPZ, sysData.getFoodVariety());
|
if(StringUtils.isEmpty(mappingCode)){
|
mappingCode = apiTriggerService.getMappingCode(Constant.TRIGGER_P_LSPZ, sysData.getFoodVariety().substring(0, 3));
|
}
|
apiData.setLspzdm(mappingCode);
|
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);
|
}
|
}
|
}
|