guohongjin
2024-05-15 5b7639f0bd9e056738ec15100ed0532e965c6cd5
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
117
118
119
120
121
122
package cn.stylefeng.roses.kernel.migration.aggregation.scheduling;
 
import cn.hutool.core.util.ObjectUtil;
import cn.stylefeng.roses.kernel.migration.api.AccessMigrationApi;
import cn.stylefeng.roses.kernel.migration.api.constants.MigrationConstants;
import cn.stylefeng.roses.kernel.migration.api.pojo.MigrationAggregationPOJO;
import cn.stylefeng.roses.kernel.migration.api.pojo.MigrationInfo;
 
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.concurrent.ConcurrentHashMap;
 
/**
 * 调度中心
 *
 * @author majianguo
 * @date 2021/7/6 16:01
 */
public class SchedulingCenter {
 
    /**
     * 迁移数据接入集合
     */
    private static final ConcurrentHashMap<String, AccessMigrationApi> migrationCollection = new ConcurrentHashMap<>();
 
    /**
     * 接入一个迁移类
     *
     * @param accessMigrationApi 迁移接口
     * @author majianguo
     * @date 2021/7/6 17:21
     **/
    public static void addMigration(AccessMigrationApi accessMigrationApi) {
 
        // 拼接key值
        String appAndModuleNameItem = accessMigrationApi.getAppName() + MigrationConstants.NAME_SEPARATOR + accessMigrationApi.getModuleName();
 
        // 存储迁移类
        migrationCollection.put(appAndModuleNameItem, accessMigrationApi);
    }
 
    /**
     * 导入数据
     *
     * @param migrationAggregationPOJO 导入的数据
     * @author majianguo
     * @date 2021/7/6 16:10
     **/
    public static void importData(MigrationAggregationPOJO migrationAggregationPOJO, String type) {
 
        // 所有导入数据集合
        Map<String, MigrationInfo> migrationInfoMap = migrationAggregationPOJO.getData();
 
        // 找到每个应用的处理程序,调用相关方法
        for (String appAndModuleName : migrationAggregationPOJO.getAppAndModuleNameList()) {
            AccessMigrationApi accessMigrationApi = migrationCollection.get(appAndModuleName);
            if (ObjectUtil.isNotEmpty(accessMigrationApi)) {
 
                // 找到数据
                MigrationInfo migrationInfo = migrationInfoMap.get(appAndModuleName);
 
                // 发送给实现类处理
                try {
                    accessMigrationApi.importData(type, migrationInfo);
                } catch (Exception e) {
                    e.printStackTrace();
                }
            }
        }
    }
 
    /**
     * 导出数据
     *
     * @param migrationAggregationPOJO 导出要求
     * @return {@link MigrationAggregationPOJO}
     * @author majianguo
     * @date 2021/7/6 16:11
     **/
    public static MigrationAggregationPOJO exportData(MigrationAggregationPOJO migrationAggregationPOJO) {
        Map<String, MigrationInfo> data = migrationAggregationPOJO.getData();
        if (ObjectUtil.isEmpty(data)) {
            data = new HashMap<>();
            migrationAggregationPOJO.setData(data);
        }
 
        // 导出所有指定项
        for (String appAndModuleName : migrationAggregationPOJO.getAppAndModuleNameList()) {
            // 查找对应的实现类
            AccessMigrationApi accessMigrationApi = migrationCollection.get(appAndModuleName);
            if (ObjectUtil.isNotEmpty(accessMigrationApi)) {
                // 执行导出
                try {
                    // 获取数据
                    MigrationInfo migrationInfo = accessMigrationApi.exportData();
 
                    // 放入返回结果中
                    data.put(appAndModuleName, migrationInfo);
                } catch (Exception e) {
                    e.printStackTrace();
                }
            } else {
                data.put(appAndModuleName, new MigrationInfo());
            }
        }
 
        return migrationAggregationPOJO;
    }
 
    /**
     * 获取所有迁移数据列表
     *
     * @return {@link java.util.List<MigrationInfo>}
     * @author majianguo
     * @date 2021/7/6 16:13
     **/
    public static List<String> getAllMigrationInfo() {
        return new ArrayList<>(migrationCollection.keySet());
    }
}