Package io.micronaut.web.router
Interface Router
- All Known Implementing Classes:
- DefaultRouter,- FilteredRouter
public interface Router
Core Router interface that allows discovery of a route given an HTTP method and URI.
- Since:
- 1.0
- Author:
- Graeme Rocher
- 
Method SummaryModifier and TypeMethodDescriptionvoidapplyDefaultPorts(List<Integer> ports) Sets the ports the application will listen to by default.default <T,R> Optional<UriRouteMatch<T, R>> DELETE(@NonNull CharSequence uri) Find the firstRouteMatchroute for anHttpMethod.DELETEmethod and the given URI.<T,R> @NonNull Stream<UriRouteMatch<T, R>> find(@NonNull HttpMethod httpMethod, @NonNull CharSequence uri, @Nullable HttpRequest<?> context) Finds all possible routes for the given HTTP method and URI.default <T,R> @NonNull Stream<UriRouteMatch<T, R>> find(@NonNull HttpMethod httpMethod, @NonNull URI uri, @Nullable HttpRequest<?> context) Finds all possible routes for the given HTTP method and URI.default <T,R> @NonNull Stream<UriRouteMatch<T, R>> find(@NonNull HttpRequest<?> request) Finds all possible routes for the given HTTP request.default <T,R> @NonNull Stream<UriRouteMatch<T, R>> find(@NonNull HttpRequest<?> request, @NonNull CharSequence uri) Find method, that should be used for non-standard http methods.<T,R> @NonNull List<UriRouteMatch<T, R>> findAllClosest(@NonNull HttpRequest<?> request) Finds the closest match for the given request.<T,R> @NonNull List<UriRouteMatch<T, R>> findAny(@NonNull HttpRequest<?> request) Find anyRouteMatchregardless of HTTP method.<T,R> @NonNull Stream<UriRouteMatch<T, R>> findAny(@NonNull CharSequence uri, @Nullable HttpRequest<?> context) Find anyRouteMatchregardless of HTTP method.default <T,R> @Nullable UriRouteMatch<T, R> findClosest(@NonNull HttpRequest<?> request) Finds the closest match for the given request or null if none is found.<R> Optional<RouteMatch<R>>findErrorRoute(@NonNull Class<?> originatingClass, @NonNull Throwable error, HttpRequest<?> request) Match a route to an error.<R> Optional<RouteMatch<R>>findErrorRoute(@NonNull Throwable error, HttpRequest<?> request) Match a route to an error.findFilters(@NonNull HttpRequest<?> request) Find filters for the request.default @NonNull List<GenericHttpFilter>findFilters(@NonNull HttpRequest<?> request, @Nullable RouteMatch<?> routeMatch) Find filters for the request and a route match.default @NonNull List<GenericHttpFilter>findPreMatchingFilters(@NonNull HttpRequest<?> request) Find pre-matching filters for the request.default <R> Optional<RouteMatch<R>>findStatusRoute(int statusCode, HttpRequest<?> request) Found aRouteMatchfor the given status code.<R> Optional<RouteMatch<R>>findStatusRoute(@NonNull HttpStatus status, HttpRequest<?> request) Found aRouteMatchfor the givenHttpStatuscode.default <R> Optional<RouteMatch<R>>findStatusRoute(@NonNull Class<?> originatingClass, int statusCode, HttpRequest<?> request) Found aRouteMatchfor the given status code.<R> Optional<RouteMatch<R>>findStatusRoute(@NonNull Class<?> originatingClass, @NonNull HttpStatus status, HttpRequest<?> request) Found aRouteMatchfor the givenHttpStatuscode.default <T,R> Optional<UriRouteMatch<T, R>> GET(@NonNull CharSequence uri) Find the firstRouteMatchroute for anHttpMethod.GETmethod and the given URI.default <T,R> Optional<UriRouteMatch<T, R>> HEAD(@NonNull CharSequence uri) Find the firstRouteMatchroute for anHttpMethod.HEADmethod and the given URI.default <T,R> Optional<UriRouteMatch<T, R>> OPTIONS(@NonNull CharSequence uri) Find the firstRouteMatchroute for anHttpMethod.OPTIONSmethod and the given URI.default <T,R> Optional<UriRouteMatch<T, R>> PATCH(@NonNull CharSequence uri) Find the firstRouteMatchroute for anHttpMethod.PATCHmethod and the given URI.default <T,R> Optional<UriRouteMatch<T, R>> POST(@NonNull CharSequence uri) Find the firstRouteMatchroute for anHttpMethod.POSTmethod and the given URI.default <T,R> Optional<UriRouteMatch<T, R>> PUT(@NonNull CharSequence uri) Find the firstRouteMatchroute for anHttpMethod.PUTmethod and the given URI.<T,R> Optional<UriRouteMatch<T, R>> route(@NonNull HttpMethod httpMethod, @NonNull CharSequence uri) Finds the first possible route for the given HTTP method and URI.<R> Optional<RouteMatch<R>>route(@NonNull HttpStatus status) Found aRouteMatchfor the givenHttpStatuscode.<R> Optional<RouteMatch<R>>route(@NonNull Class<?> originatingClass, @NonNull HttpStatus status) Found aRouteMatchfor the givenHttpStatuscode.<R> Optional<RouteMatch<R>>Match a route to an error.<R> Optional<RouteMatch<R>>Match a route to an error.@NonNull Stream<UriRouteInfo<?,?>> Returns all UriRoutes.
- 
Method Details- 
findAny@NonNull <T,R> @NonNull Stream<UriRouteMatch<T,R>> findAny(@NonNull @NonNull CharSequence uri, @Nullable @Nullable HttpRequest<?> context) Find anyRouteMatchregardless of HTTP method.- Type Parameters:
- T- The target type
- R- The return type
- Parameters:
- uri- The URI
- context- The optional- HttpRequestcontext information to apply- RouteMatchFilter.
- Returns:
- A stream of route matches
 
- 
findAnyFind anyRouteMatchregardless of HTTP method.- Type Parameters:
- T- The target type
- R- The return type
- Parameters:
- request- The request
- Returns:
- A stream of route matches
- Since:
- 4.0.0
 
- 
getExposedPorts- Returns:
- The exposed ports.
 
- 
applyDefaultPortsSets the ports the application will listen to by default.- Parameters:
- ports- The default ports
 
- 
find@NonNull <T,R> @NonNull Stream<UriRouteMatch<T,R>> find(@NonNull @NonNull HttpMethod httpMethod, @NonNull @NonNull CharSequence uri, @Nullable @Nullable HttpRequest<?> context) Finds all possible routes for the given HTTP method and URI.- Type Parameters:
- T- The target type
- R- The type
- Parameters:
- httpMethod- The HTTP method
- uri- The URI route match
- context- The optional- HttpRequestcontext information to apply- RouteMatchFilter.
- Returns:
- A Streamof possibleRouteinstances.
 
- 
find@NonNull default <T,R> @NonNull Stream<UriRouteMatch<T,R>> find(@NonNull @NonNull HttpMethod httpMethod, @NonNull @NonNull URI uri, @Nullable @Nullable HttpRequest<?> context) Finds all possible routes for the given HTTP method and URI.- Type Parameters:
- T- The target type
- R- The URI route match
- Parameters:
- httpMethod- The HTTP method
- uri- The URI
- context- The optional- HttpRequestcontext
- Returns:
- A Streamof possibleRouteinstances.
 
- 
find@NonNull default <T,R> @NonNull Stream<UriRouteMatch<T,R>> find(@NonNull @NonNull HttpRequest<?> request) Finds all possible routes for the given HTTP request.
- 
find@NonNull default <T,R> @NonNull Stream<UriRouteMatch<T,R>> find(@NonNull @NonNull HttpRequest<?> request, @NonNull @NonNull CharSequence uri) Find method, that should be used for non-standard http methods. For standards, it should act the same asfind(HttpMethod, CharSequence, HttpRequest)- Type Parameters:
- T- The target type.
- R- The type of what
- Parameters:
- request- The request, that can have overridden- HttpRequest.getMethodName()
- uri- The URI route match.
- Returns:
- A Streamof possibleRouteinstances.
 
- 
findAllClosest@NonNull <T,R> @NonNull List<UriRouteMatch<T,R>> findAllClosest(@NonNull @NonNull HttpRequest<?> request) Finds the closest match for the given request.
- 
findClosest@Nullable default <T,R> @Nullable UriRouteMatch<T,R> findClosest(@NonNull @NonNull HttpRequest<?> request) throws DuplicateRouteException Finds the closest match for the given request or null if none is found.- Type Parameters:
- T- The target type
- R- The type
- Parameters:
- request- The request
- Returns:
- A match or null, throws DuplicateRouteExceptionon multiple routes.
- Throws:
- DuplicateRouteException
- Since:
- 4.0.0
 
- 
uriRoutesReturns all UriRoutes.
- 
route<T,R> Optional<UriRouteMatch<T,R>> route(@NonNull @NonNull HttpMethod httpMethod, @NonNull @NonNull CharSequence uri) Finds the first possible route for the given HTTP method and URI.- Type Parameters:
- T- The target type
- R- The URI route match
- Parameters:
- httpMethod- The HTTP method
- uri- The URI
- Returns:
- The route match
 
- 
routeFound aRouteMatchfor the givenHttpStatuscode.- Type Parameters:
- R- The matched route
- Parameters:
- status- The HTTP status
- Returns:
- The RouteMatch
 
- 
route<R> Optional<RouteMatch<R>> route(@NonNull @NonNull Class<?> originatingClass, @NonNull @NonNull HttpStatus status) Found aRouteMatchfor the givenHttpStatuscode.- Type Parameters:
- R- The matched route
- Parameters:
- originatingClass- The class the error originates from
- status- The HTTP status
- Returns:
- The RouteMatch
 
- 
routeMatch a route to an error.- Type Parameters:
- R- The matched route
- Parameters:
- error- The error
- Returns:
- The RouteMatch
 
- 
route<R> Optional<RouteMatch<R>> route(@NonNull @NonNull Class<?> originatingClass, @NonNull @NonNull Throwable error) Match a route to an error.- Type Parameters:
- R- The matched route
- Parameters:
- originatingClass- The class the error originates from
- error- The error
- Returns:
- The RouteMatch
 
- 
findErrorRoute<R> Optional<RouteMatch<R>> findErrorRoute(@NonNull @NonNull Class<?> originatingClass, @NonNull @NonNull Throwable error, HttpRequest<?> request) Match a route to an error.- Type Parameters:
- R- The matched route
- Parameters:
- originatingClass- The class the error originates from
- error- The error
- request- The request
- Returns:
- The RouteMatch
 
- 
findErrorRoute<R> Optional<RouteMatch<R>> findErrorRoute(@NonNull @NonNull Throwable error, HttpRequest<?> request) Match a route to an error.- Type Parameters:
- R- The matched route
- Parameters:
- error- The error
- request- The request
- Returns:
- The RouteMatch
 
- 
findStatusRoute<R> Optional<RouteMatch<R>> findStatusRoute(@NonNull @NonNull Class<?> originatingClass, @NonNull @NonNull HttpStatus status, HttpRequest<?> request) Found aRouteMatchfor the givenHttpStatuscode.- Type Parameters:
- R- The matched route
- Parameters:
- originatingClass- The class the error originates from
- status- The HTTP status
- request- The request
- Returns:
- The RouteMatch
 
- 
findStatusRoutedefault <R> Optional<RouteMatch<R>> findStatusRoute(@NonNull @NonNull Class<?> originatingClass, int statusCode, HttpRequest<?> request) Found aRouteMatchfor the given status code.- Type Parameters:
- R- The matched route
- Parameters:
- originatingClass- The class the error originates from
- statusCode- The HTTP status
- request- The request
- Returns:
- The RouteMatch
 
- 
findStatusRoute<R> Optional<RouteMatch<R>> findStatusRoute(@NonNull @NonNull HttpStatus status, HttpRequest<?> request) Found aRouteMatchfor the givenHttpStatuscode.- Type Parameters:
- R- The matched route
- Parameters:
- status- The HTTP status
- request- The request
- Returns:
- The RouteMatch
 
- 
findStatusRouteFound aRouteMatchfor the given status code.- Type Parameters:
- R- The matched route
- Parameters:
- statusCode- The HTTP status code
- request- The request
- Returns:
- The RouteMatch
 
- 
findFiltersFind filters for the request.- Parameters:
- request- The request
- Returns:
- filters
 
- 
findFilters@NonNull default @NonNull List<GenericHttpFilter> findFilters(@NonNull @NonNull HttpRequest<?> request, @Nullable @Nullable RouteMatch<?> routeMatch) Find filters for the request and a route match.- Parameters:
- request- The request
- routeMatch- The route match
- Returns:
- filters
- Since:
- 4.6
 
- 
findPreMatchingFilters@NonNull default @NonNull List<GenericHttpFilter> findPreMatchingFilters(@NonNull @NonNull HttpRequest<?> request) Find pre-matching filters for the request.- Parameters:
- request- The request
- Returns:
- filters
- Since:
- 4.6
 
- 
GETFind the firstRouteMatchroute for anHttpMethod.GETmethod and the given URI.- Type Parameters:
- T- The target type
- R- The return type
- Parameters:
- uri- The URI
- Returns:
- An OptionalofRouteMatch
 
- 
POSTFind the firstRouteMatchroute for anHttpMethod.POSTmethod and the given URI.- Type Parameters:
- T- The target type
- R- The return type
- Parameters:
- uri- The URI
- Returns:
- An OptionalofRouteMatch
 
- 
PUTFind the firstRouteMatchroute for anHttpMethod.PUTmethod and the given URI.- Type Parameters:
- T- The target type
- R- The URI route match
- Parameters:
- uri- The URI
- Returns:
- An OptionalofRouteMatch
 
- 
PATCHFind the firstRouteMatchroute for anHttpMethod.PATCHmethod and the given URI.- Type Parameters:
- T- The target type
- R- The return type
- Parameters:
- uri- The URI
- Returns:
- An OptionalofRouteMatch
 
- 
DELETEFind the firstRouteMatchroute for anHttpMethod.DELETEmethod and the given URI.- Type Parameters:
- T- The target type
- R- The return type
- Parameters:
- uri- The URI
- Returns:
- An OptionalofRouteMatch
 
- 
OPTIONSFind the firstRouteMatchroute for anHttpMethod.OPTIONSmethod and the given URI.- Type Parameters:
- T- The target type
- R- The return type
- Parameters:
- uri- The URI
- Returns:
- An OptionalofRouteMatch
 
- 
HEADFind the firstRouteMatchroute for anHttpMethod.HEADmethod and the given URI.- Type Parameters:
- T- The target type
- R- The return type
- Parameters:
- uri- The URI
- Returns:
- An OptionalofRouteMatch
 
 
-