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

com.spotify.apollo.RequestMetadata Maven / Gradle / Ivy

/*
 * -\-\-
 * Spotify Apollo API Interfaces
 * --
 * Copyright (C) 2013 - 2016 Spotify AB
 * --
 * 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 com.spotify.apollo;

import java.time.Instant;
import java.util.Optional;

/**
 * Describes an API for retrieving metadata about an incoming request. Implementations that wish to
 * enable tracking of additional metadata are expected to extend this interface with more methods to
 * return this additional data.
 */
public interface RequestMetadata {

  /**
   * Get the arrival time of the incoming request.
   */
  Instant arrivalTime();

  /**
   * Indicates the local address of the connection which the request was received on, if available
   */
  Optional localAddress();

  /**
   * Indicates the remote address of the connection which the request was received on, if available.
   * This may be the address of a proxy address or a direct connection to the caller, depending on
   * the network setup.
   */
  Optional remoteAddress();

  /**
   * Defines an address
   */
  interface HostAndPort {

    /**
     * May be a hostname or an IP address.
     */
    String host();
    int port();
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy