/* * 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 java.util.Collection; import java.util.List; import java.util.Objects; import java.util.stream.Collectors; import org.springframework.cloud.netflix.eureka.EurekaServiceInstancePublic; import com.fasterxml.jackson.databind.ObjectMapper; import com.netflix.discovery.shared.Application; import com.netflix.eureka.EurekaServerContext; import io.cereebro.core.Snitch; import io.cereebro.core.SnitchRegistry; import io.cereebro.server.discovery.ServiceInstanceSnitch; /** * Snitch registry backed by Eureka server internals. * <p> * When used as an Eureka server add-on, the service instances can be browsed * directly. * </p> * * @author michaeltecourt */ public class EurekaServerSnitchRegistry implements SnitchRegistry { private final EurekaServerContext eurekaServerContext; private final ObjectMapper objectMapper; /** * Snitch registry backed by Eureka server internals. * <p> * When used as an Eureka server add-on, the service instances can be * browsed directly. * </p> * * @param eurekaServerContext * Eureka server context holding service instances. * @param objectMapper * JSON object mapper. */ public EurekaServerSnitchRegistry(EurekaServerContext eurekaServerContext, ObjectMapper objectMapper) { this.eurekaServerContext = Objects.requireNonNull(eurekaServerContext, "Eureka server context required"); this.objectMapper = Objects.requireNonNull(objectMapper, "JSON object mapper required"); } @Override public List<Snitch> getAll() { // @formatter:off return eurekaServerContext.getRegistry().getSortedApplications().stream() .map(Application::getInstances) .flatMap(Collection::stream) .map(EurekaServiceInstancePublic::new) .filter(ServiceInstanceSnitch::hasCereebroMetadata) .map(instance -> new ServiceInstanceSnitch(objectMapper, instance)) .collect(Collectors.toList()); // @formatter:on } }