CZT
2023-08-22 ce9d44e48aa77ebf2537f22ff8bf4a70089d0474
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
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.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 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);
        }
    }
}