package com.fzzy.async.fzzy30.impl;
|
|
import com.fzzy.api.Constant;
|
import com.fzzy.api.entity.Api1109;
|
import com.fzzy.api.entity.ApiLog;
|
import com.fzzy.api.utils.ContextUtil;
|
import com.fzzy.api.utils.FileUtil;
|
import com.fzzy.api.view.repository.Api1109Rep;
|
import com.fzzy.api.view.repository.ApiLogRep;
|
import com.fzzy.async.fzzy35.entity.FileInfo;
|
import com.fzzy.async.fzzy35.repository.Fzzy35Sync1109Rep;
|
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;
|
import java.util.UUID;
|
|
/**
|
* 文件信息
|
*/
|
@Slf4j
|
@Component
|
public class Fzzy30Sync1109 {
|
|
private final static String IMG_START_C = "C_";
|
private final static String IMG_START_R = "R_";
|
/**
|
* 图片类型
|
*/
|
private final static String IMG_TYPE_2 = "2";
|
private final static String IMG_TYPE_3 = "3";
|
|
@Autowired
|
private Fzzy35Sync1109Rep fzzySync1109Rep;
|
@Autowired
|
private Api1109Rep api1109Rep;
|
@Autowired
|
private ApiLogRep apiLogRep;
|
@Autowired
|
private FileUtil fileUtil;
|
|
/**
|
* 同步文件接口
|
*
|
* @param deptId
|
* @param start
|
* @param end
|
*/
|
public void syncData(String kqdm, String deptId, Date start, Date end) {
|
|
log.info("-------------1109接口数据开始同步------------------");
|
|
//同步数据,只记录失败的信息
|
ApiLog apiLog = new ApiLog();
|
apiLog.setType(ApiLog.TYPE_SYNC);
|
apiLog.setKqdm(deptId);
|
apiLog.setUploadTime(new Date());
|
apiLog.setInteId(Constant.API_CODE_1109);
|
apiLog.setStatus(99);
|
apiLog.setId(ContextUtil.getUUID());
|
try {
|
List<FileInfo> list = fzzySync1109Rep.listFileInfo(start, end);
|
|
if (null == list || list.isEmpty()) {
|
log.info("-------------没有获取到文件信息------------------");
|
return;
|
}
|
|
|
Api1109 apiData;
|
String wjlx = "";
|
for (FileInfo sysData : list) {
|
if(StringUtils.isEmpty(sysData.getBizId())){
|
continue;
|
}else if(sysData.getBizId().startsWith(IMG_START_C)){
|
//出库类型
|
wjlx = IMG_TYPE_3;
|
}else if(sysData.getBizId().startsWith(IMG_START_R)){
|
//入库类型
|
wjlx = IMG_TYPE_2;
|
}else {
|
continue;
|
}
|
apiData = new Api1109();
|
apiData.setId(UUID.randomUUID().toString());
|
//文件路径
|
apiData.setWjdz(fileUtil.getInoutFilePath(sysData.getCreateTime()) + sysData.getFileName());
|
//文件名称
|
apiData.setWjmc(sysData.getFileName());
|
apiData.setKqdm(kqdm);
|
//文件类型
|
apiData.setWjlx(wjlx);
|
|
//操作标志及最后更新时间
|
apiData.setCzbz(Constant.CZBZ_I);
|
apiData.setZhgxsj(new Date());
|
|
//业务id、库区编码、同步时间
|
apiData.setBizId(sysData.getFileId());
|
apiData.setKqdm(kqdm);
|
apiData.setSyncTime(new Date());
|
|
//保存数据
|
api1109Rep.save(apiData);
|
log.info("1109---同步数据:{}", apiData.toString());
|
|
}
|
} catch (Exception e) {
|
log.error("---文件同步执行失败----{}", e);
|
apiLog.setResult("同步文件信息失败:" + e.getMessage());
|
apiLogRep.save(apiLog);
|
}
|
}
|
}
|