|
1 | 1 | package org.dataloader; |
2 | 2 |
|
3 | 3 | import java.util.ArrayList; |
| 4 | +import java.util.HashSet; |
4 | 5 | import java.util.List; |
5 | | -import java.util.concurrent.CopyOnWriteArrayList; |
| 6 | +import java.util.Map; |
| 7 | +import java.util.Set; |
| 8 | +import java.util.concurrent.ConcurrentHashMap; |
6 | 9 |
|
7 | 10 | /** |
8 | 11 | * This allows data loaders to be registered together into a single place so |
9 | | - * they can be dispatched as one. |
| 12 | + * they can be dispatched as one. It also allows you to retrieve data loaders by |
| 13 | + * name from a central place |
10 | 14 | */ |
11 | 15 | public class DataLoaderRegistry { |
12 | | - private final List<DataLoader<?, ?>> dataLoaders = new CopyOnWriteArrayList<>(); |
| 16 | + private final Map<String, DataLoader<?, ?>> dataLoaders = new ConcurrentHashMap<>(); |
| 17 | + |
| 18 | + /** |
| 19 | + * This will register a new dataloader |
| 20 | + * |
| 21 | + * @param key the key to put the data loader under |
| 22 | + * @param dataLoader the data loader to register |
| 23 | + * |
| 24 | + * @return this registry |
| 25 | + */ |
| 26 | + public DataLoaderRegistry register(String key, DataLoader<?, ?> dataLoader) { |
| 27 | + dataLoaders.put(key, dataLoader); |
| 28 | + return this; |
| 29 | + } |
| 30 | + |
| 31 | + /** |
| 32 | + * This will combine all the current data loaders in this registry and all the data loaders from the specified registry |
| 33 | + * and return a new combined registry |
| 34 | + * |
| 35 | + * @param registry the registry to combine into this registry |
| 36 | + * |
| 37 | + * @return a new combined registry |
| 38 | + */ |
| 39 | + public DataLoaderRegistry combine(DataLoaderRegistry registry) { |
| 40 | + DataLoaderRegistry combined = new DataLoaderRegistry(); |
| 41 | + |
| 42 | + this.dataLoaders.forEach(combined::register); |
| 43 | + registry.dataLoaders.forEach(combined::register); |
| 44 | + return combined; |
| 45 | + } |
13 | 46 |
|
14 | 47 | /** |
15 | 48 | * @return the currently registered data loaders |
16 | 49 | */ |
17 | 50 | public List<DataLoader<?, ?>> getDataLoaders() { |
18 | | - return new ArrayList<>(dataLoaders); |
| 51 | + return new ArrayList<>(dataLoaders.values()); |
19 | 52 | } |
20 | 53 |
|
21 | 54 | /** |
22 | | - * This will register a new dataloader |
| 55 | + * This will unregister a new dataloader |
23 | 56 | * |
24 | | - * @param dataLoader the data loader to register |
| 57 | + * @param key the key of the data loader to unregister |
25 | 58 | * |
26 | 59 | * @return this registry |
27 | 60 | */ |
28 | | - public DataLoaderRegistry register(DataLoader<?, ?> dataLoader) { |
29 | | - if (!dataLoaders.contains(dataLoader)) { |
30 | | - dataLoaders.add(dataLoader); |
31 | | - } |
| 61 | + public DataLoaderRegistry unregister(String key) { |
| 62 | + dataLoaders.remove(key); |
32 | 63 | return this; |
33 | 64 | } |
34 | 65 |
|
35 | 66 | /** |
36 | | - * This will unregister a new dataloader |
| 67 | + * Returns the dataloader that was registered under the specified key |
37 | 68 | * |
38 | | - * @param dataLoader the data loader to unregister |
| 69 | + * @param key the key of the data loader |
39 | 70 | * |
40 | | - * @return this registry |
| 71 | + * @return a data loader or null if its not present |
41 | 72 | */ |
42 | | - public DataLoaderRegistry unregister(DataLoader<?, ?> dataLoader) { |
43 | | - dataLoaders.remove(dataLoader); |
44 | | - return this; |
| 73 | + public <K, V> DataLoader<K, V> getDataLoader(String key) { |
| 74 | + //noinspection unchecked |
| 75 | + return (DataLoader<K, V>) dataLoaders.get(key); |
| 76 | + } |
| 77 | + |
| 78 | + /** |
| 79 | + * @return the keys of the data loaders in this registry |
| 80 | + */ |
| 81 | + public Set<String> getKeys() { |
| 82 | + return new HashSet<>(dataLoaders.keySet()); |
45 | 83 | } |
46 | 84 |
|
47 | 85 | /** |
48 | 86 | * This will called {@link org.dataloader.DataLoader#dispatch()} on each of the registered |
49 | 87 | * {@link org.dataloader.DataLoader}s |
50 | 88 | */ |
51 | 89 | public void dispatchAll() { |
52 | | - dataLoaders.forEach(DataLoader::dispatch); |
| 90 | + getDataLoaders().forEach(DataLoader::dispatch); |
53 | 91 | } |
54 | 92 | } |
0 commit comments