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

brave.http.HttpServerRequest Maven / Gradle / Ivy

/*
 * Copyright 2013-2020 The OpenZipkin 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 brave.http;

import brave.Span;
import brave.propagation.Propagation.Getter;

/**
 * Marks an interface for use in {@link HttpServerHandler#handleReceive(HttpServerRequest)}. This
 * gives a standard type to consider when parsing an incoming context.
 *
 * @see HttpServerResponse
 * @since 5.7
 */
public abstract class HttpServerRequest extends HttpRequest {
  static final Getter GETTER = new Getter() {
    @Override public String get(HttpServerRequest carrier, String key) {
      return carrier.header(key);
    }

    @Override public String toString() {
      return "HttpServerRequest::header";
    }
  };

  @Override public final Span.Kind spanKind() {
    return Span.Kind.SERVER;
  }

  /**
   * Used by {@link HttpServerHandler#handleReceive(HttpServerRequest)} to add remote socket
   * information about the client from the {@linkplain #unwrap() delegate}.
   *
   * 

By default, this tries to parse the {@linkplain #parseClientIpFromXForwardedFor(Span) * forwarded IP}. Override to add client socket information when forwarded info is not available. * *

Aside: It is more likely a server request object will be able to parse socket information * as opposed to a client object. This is because client requests are often parsed before a * network route is chosen, whereas server requests are parsed after the network layer. * * @return true if parsing was successful. * @since 5.7 */ public boolean parseClientIpAndPort(Span span) { return parseClientIpFromXForwardedFor(span); } /** * Uses the first value in the "X-Forwarded-For" header, or returns false if not present. * * @since 5.10 */ protected boolean parseClientIpFromXForwardedFor(Span span) { String forwardedFor = header("X-Forwarded-For"); if (forwardedFor == null) return false; int indexOfComma = forwardedFor.indexOf(','); if (indexOfComma != -1) forwardedFor = forwardedFor.substring(0, indexOfComma); return span.remoteIpAndPort(forwardedFor, 0); } }





© 2015 - 2025 Weber Informatics LLC | Privacy Policy