|
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