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

com.spotify.apollo.route.Route Maven / Gradle / Ivy

/*
 * -\-\-
 * Spotify Apollo API Interfaces
 * --
 * Copyright (C) 2013 - 2015 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.route;

import com.google.auto.value.AutoValue;

import java.util.Optional;

import javax.annotation.Nullable;

import static com.spotify.apollo.route.Route.DocString.doc;

/**
 * The Route defines an endpoint to the service. There are basically two types of routes based
 * on the type of request handler, synchronous and asynchronous. Each route, apart from defining
 * the basic information like method, uri and handler, can have a reply content type, serializer,
 * documentation string, etc.
 *
 * A route handler might return a Response (or a ListenableFuture), which is a wrapper where you can
 * specify extra information about the reply, or any other type, that will be serialized
 * with AutoSerializer by default or with the explicitly specified one.
 *
 * If the handler returns a Response apollo will unwrap it and use the extra information that can be
 * specified, like headers, and reply with the given status code and serializeed payload if it exists.
 */
public interface Route {

  String method();
  String uri();
  H handler();

  Optional docString();

  ///////////////////////////////////////////////////////

  default  Route withHandler(K handler) {
    return copy(
        method(), uri(), handler, docString().orElse(null));
  }

  default Route withDocString(String summary, String description) {
    return copy(
        method(), uri(), handler(), doc(summary, description));
  }

  default Route withDocString(DocString doc) {
    return copy(
        method(), uri(), handler(), doc);
  }

  default  Route withMiddleware(Middleware middleware) {
    return copy(
        method(), uri(), middleware.apply(handler()), docString().orElse(null));
  }

  default Route withPrefix(String prefix) {
    return copy(
        method(), prefix + uri(), handler(), docString().orElse(null));
  }

   Route copy(
      String method,
      String uri,
      K handler,
      @Nullable DocString docString);

  static  Route create(
      String method,
      String uri,
      H handler,
      @Nullable DocString docString) {
    return new AutoValue_RouteImpl<>(
        method,
        uri,
        handler,
        Optional.ofNullable(docString));
  }

  static  Route create(String method, String uri, H handler) {
    return create(method, uri, handler, null);
  }

  /**
   * Allows creating routes with middleware and lambdas in a type-inference-proof way. This is
   * functionally equivalent to {@code Route.create(method, uri, handler).withMiddleware(m)},
   * but if the handler type isn't concrete, then Java's type inference cannot handle that option.
   */
  static  Route with(Middleware m, String method, String uri, H handler) {
    return create(method, uri, m.apply(handler));
  }

  static  Route> async(String method, String uri, AsyncHandler handler) {
    return create(method, uri, handler);
  }

  static  Route> sync(String method, String uri, SyncHandler handler) {
    return create(method, uri, handler).withMiddleware(Middleware::syncToAsync);
  }

  static  Route> future(String method, String uri,
                                           ListenableFutureHandler handler) {
    return create(method, uri, handler).withMiddleware(Middleware::guavaToAsync);
  }

  @AutoValue
  abstract class DocString {
    public abstract String summary();
    public abstract String description();

    public static DocString doc(String summary, String description) {
      return new AutoValue_Route_DocString(summary, description);
    }
  }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy