forked from Apicurio/apicurio-registry
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathHttpEventSinkConfiguration.java
35 lines (26 loc) · 1.18 KB
/
HttpEventSinkConfiguration.java
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
package io.apicurio.registry.events.http;
import java.util.List;
import java.util.Optional;
import java.util.Properties;
import java.util.stream.Collectors;
import jakarta.enterprise.context.ApplicationScoped;
import jakarta.enterprise.inject.Produces;
import org.eclipse.microprofile.config.inject.ConfigProperty;
import io.apicurio.common.apps.config.Info;
import io.apicurio.registry.utils.RegistryProperties;
@ApplicationScoped
public class HttpEventSinkConfiguration {
@ConfigProperty(name = "apicurio.events.ksink")
@Info(category = "events", description = "Events Kafka sink enabled", availableSince = "2.0.0.Final")
Optional<String> ksink;
@Produces
public HttpSinksConfiguration sinkConfig(@RegistryProperties(value = {"apicurio.events.sink"}) Properties properties) {
List<HttpSinkConfiguration> httpSinks = properties.stringPropertyNames().stream()
.map(key -> new HttpSinkConfiguration(key, properties.getProperty(key)))
.collect(Collectors.toList());
if (ksink.isPresent()) {
httpSinks.add(new HttpSinkConfiguration("k_sink", ksink.get()));
}
return new HttpSinksConfiguration(httpSinks);
}
}