/* * Copyright © 2017 the original authors (http://cereebro.io) * * 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 io.cereebro.server.eureka; import org.springframework.boot.autoconfigure.condition.ConditionalOnBean; import org.springframework.boot.autoconfigure.condition.ConditionalOnClass; import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import com.fasterxml.jackson.databind.ObjectMapper; import com.netflix.eureka.EurekaServerContext; import io.cereebro.core.SnitchRegistry; /** * Use Cereebro as a Eureka server add-on instead (or in parallel) of a * standalone application consuming the discovery client. * <p> * Service instances are found using Eureka server internals -- without making * HTTP calls through DiscoveryClient. * </p> * * @author michaeltecourt */ @Configuration @ConditionalOnClass(EurekaServerContext.class) public class CereebroEurekaServerAddOnAutoConfiguration { @Bean @ConditionalOnBean(EurekaServerContext.class) public SnitchRegistry eurekaServerSnitchRegistry(EurekaServerContext eurekaServerContext, ObjectMapper objectMapper) { return new EurekaServerSnitchRegistry(eurekaServerContext, objectMapper); } }