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.FileUtils; import com.fzzy.api.view.repository.Api1109Rep; import com.fzzy.api.view.repository.ApiLogRep; import com.fzzy.async.fzzy30.entity.FileInfo; import com.fzzy.async.fzzy30.repository.FzzySync1109Rep; 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 FzzySync1109Rep fzzySync1109Rep; @Autowired private Api1109Rep api1109Rep; @Autowired private ApiLogRep apiLogRep; @Autowired private FileUtils 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 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); } } }