Polish "Introduce HealthIndicatorRegistry"
See gh-4965 Co-authored-by: Andy Wilkinson <awilkinson@pivotal.io>pull/13197/head
parent
d829d522be
commit
95b251590e
@ -0,0 +1,66 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2012-2018 the original author or authors.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.springframework.boot.actuate.autoconfigure.health;
|
||||||
|
|
||||||
|
import java.util.LinkedHashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
import org.springframework.boot.actuate.health.HealthIndicator;
|
||||||
|
import org.springframework.boot.actuate.health.HealthIndicatorRegistry;
|
||||||
|
import org.springframework.boot.actuate.health.HealthIndicatorRegistryFactory;
|
||||||
|
import org.springframework.boot.actuate.health.ReactiveHealthIndicator;
|
||||||
|
import org.springframework.context.ApplicationContext;
|
||||||
|
import org.springframework.util.ClassUtils;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a {@link HealthIndicatorRegistry} from beans in the {@link ApplicationContext}.
|
||||||
|
*
|
||||||
|
* @author Phillip Webb
|
||||||
|
* @author Stephane Nicoll
|
||||||
|
*/
|
||||||
|
final class HealthIndicatorRegistryBeans {
|
||||||
|
|
||||||
|
private HealthIndicatorRegistryBeans() {
|
||||||
|
}
|
||||||
|
|
||||||
|
public static HealthIndicatorRegistry get(ApplicationContext applicationContext) {
|
||||||
|
Map<String, HealthIndicator> indicators = new LinkedHashMap<>();
|
||||||
|
indicators.putAll(applicationContext.getBeansOfType(HealthIndicator.class));
|
||||||
|
if (ClassUtils.isPresent("reactor.core.publisher.Flux", null)) {
|
||||||
|
new ReactiveHealthIndicators().get(applicationContext)
|
||||||
|
.forEach(indicators::putIfAbsent);
|
||||||
|
}
|
||||||
|
HealthIndicatorRegistryFactory factory = new HealthIndicatorRegistryFactory();
|
||||||
|
return factory.createHealthIndicatorRegistry(indicators);
|
||||||
|
}
|
||||||
|
|
||||||
|
private static class ReactiveHealthIndicators {
|
||||||
|
|
||||||
|
public Map<String, HealthIndicator> get(ApplicationContext applicationContext) {
|
||||||
|
Map<String, HealthIndicator> indicators = new LinkedHashMap<>();
|
||||||
|
applicationContext.getBeansOfType(ReactiveHealthIndicator.class)
|
||||||
|
.forEach((name, indicator) -> indicators.put(name, adapt(indicator)));
|
||||||
|
return indicators;
|
||||||
|
}
|
||||||
|
|
||||||
|
private HealthIndicator adapt(ReactiveHealthIndicator indicator) {
|
||||||
|
return () -> indicator.health().block();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
@ -0,0 +1,66 @@
|
|||||||
|
/*
|
||||||
|
* Copyright 2012-2018 the original author or authors.
|
||||||
|
*
|
||||||
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
* you may not use this file except in compliance with the License.
|
||||||
|
* You may obtain a copy of the License at
|
||||||
|
*
|
||||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
*
|
||||||
|
* Unless required by applicable law or agreed to in writing, software
|
||||||
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
* See the License for the specific language governing permissions and
|
||||||
|
* limitations under the License.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package org.springframework.boot.actuate.health;
|
||||||
|
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.function.Function;
|
||||||
|
|
||||||
|
import org.springframework.util.Assert;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Factory to create a {@link HealthIndicatorRegistry}.
|
||||||
|
*
|
||||||
|
* @author Stephane Nicoll
|
||||||
|
* @since 2.1.0
|
||||||
|
*/
|
||||||
|
public class HealthIndicatorRegistryFactory {
|
||||||
|
|
||||||
|
private final Function<String, String> healthIndicatorNameFactory;
|
||||||
|
|
||||||
|
public HealthIndicatorRegistryFactory(
|
||||||
|
Function<String, String> healthIndicatorNameFactory) {
|
||||||
|
this.healthIndicatorNameFactory = healthIndicatorNameFactory;
|
||||||
|
}
|
||||||
|
|
||||||
|
public HealthIndicatorRegistryFactory() {
|
||||||
|
this(new HealthIndicatorNameFactory());
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create a {@link HealthIndicatorRegistry} based on the specified health
|
||||||
|
* indicators.
|
||||||
|
* @param healthIndicators the {@link HealthIndicator} instances mapped by
|
||||||
|
* name
|
||||||
|
* @return a {@link HealthIndicator} that delegates to the specified
|
||||||
|
* {@code healthIndicators}.
|
||||||
|
*/
|
||||||
|
public HealthIndicatorRegistry createHealthIndicatorRegistry(
|
||||||
|
Map<String, HealthIndicator> healthIndicators) {
|
||||||
|
Assert.notNull(healthIndicators, "HealthIndicators must not be null");
|
||||||
|
return initialize(new DefaultHealthIndicatorRegistry(), healthIndicators);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected <T extends HealthIndicatorRegistry> T initialize(T registry,
|
||||||
|
Map<String, HealthIndicator> healthIndicators) {
|
||||||
|
for (Map.Entry<String, HealthIndicator> entry : healthIndicators.entrySet()) {
|
||||||
|
String name = this.healthIndicatorNameFactory.apply(entry.getKey());
|
||||||
|
registry.register(name, entry.getValue());
|
||||||
|
}
|
||||||
|
return registry;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue