All Downloads are FREE. Search and download functionalities are using the official Maven repository.

io.micronaut.discovery.eureka.client.v2.ConfigurableInstanceInfo Maven / Gradle / Ivy

/*
 * Copyright 2017-2020 original 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
 *
 * https://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.micronaut.discovery.eureka.client.v2;

import jakarta.validation.constraints.Min;
import jakarta.validation.constraints.NotBlank;
import jakarta.validation.constraints.NotNull;

import java.util.Map;

/**
 * Interface implemented by {@link InstanceInfo} modelling the data returned by the Eureka REST API.
 * 

* See https://github.com/Netflix/eureka/wiki/Eureka-REST-operations * * @author Graeme Rocher * @since 1.0 */ public interface ConfigurableInstanceInfo { /** * The host name of the application instance. * * @return The hostname */ @NotBlank String getHostName(); /** * Returns the unique id of the instance. * (Note) now that id is set at creation time within the instanceProvider, why do the other checks? * This is still necessary for backwards compatibility when upgrading in a deployment with multiple * client versions (some with the change, some without). * * @return the unique id. */ String getId(); /** * The port of the application instance. * * @return The port */ int getPort(); /** * Sets the port of the application instance. * * @param port The port of the application instance */ void setPort(int port); /** * The secure port of the application instance. * * @return The secure port */ int getSecurePort(); /** * Sets the secure port of the application instance. * * @param securePort The secure port of the application instance */ void setSecurePort(int securePort); /** * The application name. * * @return The application name */ @NotBlank String getApp(); /** * The application group name. * * @return The application group name */ String getAppGroupName(); /** * Sets the application group name. * * @param appGroupName The application group name */ void setAppGroupName(String appGroupName); /** * The instance id. * * @return The instance id */ @NotBlank String getInstanceId(); /** * Sets the instance ID. * * @param instanceId The instance ID */ void setInstanceId(String instanceId); /** * The country id. * * @return The country id */ @Min(1L) int getCountryId(); /** * Sets the country id. * * @param countryId The country id */ void setCountryId(int countryId); /** * The IP address of the instance. * * @return The IP address */ @NotBlank String getIpAddr(); /** * Sets the IP address of the instance. * * @param ipAddr The IP address of the instance */ void setIpAddr(String ipAddr); /** * @return The application status */ @NotNull InstanceInfo.Status getStatus(); /** * Sets the application status. * * @param status The application status */ void setStatus(InstanceInfo.Status status); /** * The {@link DataCenterInfo} instance. * * @return The data center info */ @NotNull DataCenterInfo getDataCenterInfo(); /** * Sets the {@link DataCenterInfo}. * * @param dataCenterInfo The {@link DataCenterInfo} */ void setDataCenterInfo(DataCenterInfo dataCenterInfo); /** * The {@link LeaseInfo} instance. * * @return The lease info */ LeaseInfo getLeaseInfo(); /** * Sets the {@link LeaseInfo}. * * @param leaseInfo The {@link LeaseInfo} */ void setLeaseInfo(LeaseInfo leaseInfo); /** * @return The instance metadata */ Map getMetadata(); /** * @return The status page URL */ String getStatusPageUrl(); /** * Sets the status page URL. * * @param statusPageUrl The status page URL */ void setStatusPageUrl(String statusPageUrl); /** * @return The home page URL */ String getHomePageUrl(); /** * Sets the home page URL. * * @param homePageUrl The home page URL */ void setHomePageUrl(String homePageUrl); /** * @return The health check URL */ String getHealthCheckUrl(); /** * Sets the health check URL. * * @param healthCheckUrl The health check URL */ void setHealthCheckUrl(String healthCheckUrl); /** * @return The Virtual Host Address for this instance (defaults to the app name). */ String getVipAddress(); /** * Sets the Virtual Host Address. * * @param vipAddress The Virtual Host Address */ void setVipAddress(String vipAddress); /** * @return The Secure Virtual Host Address for this instance (defaults to the app name) */ String getSecureVipAddress(); /** * Sets the Secure Virtual Host Address. * * @param secureVipAddress The Secure Virtual Host Address */ void setSecureVipAddress(String secureVipAddress); /** * @return The secure health check URL */ String getSecureHealthCheckUrl(); /** * Sets the secure health check URL. * * @param secureHealthCheckUrl The secure health check URL */ void setSecureHealthCheckUrl(String secureHealthCheckUrl); /** * @return The amazon auto scaling group name */ String getAsgName(); /** * Sets the Amazon auto scaling group name to use. * * @param asgName The Amazon auto scaling group name to use */ void setAsgName(String asgName); }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy