public interface Router
Core Router interface that allows discovery of a route given an HTTP method and URI.
Modifier and Type | Method and Description |
---|---|
void |
applyDefaultPorts(List<Integer> ports)
Sets the ports the application will listen to by default.
|
default <T,R> Optional<UriRouteMatch<T,R>> |
DELETE(CharSequence uri)
Find the first
RouteMatch route for an HttpMethod.DELETE method and the given URI. |
<T,R> Stream<UriRouteMatch<T,R>> |
find(HttpMethod httpMethod,
CharSequence uri,
HttpRequest<?> context)
Finds all of the possible routes for the given HTTP method and URI.
|
default <T,R> Stream<UriRouteMatch<T,R>> |
find(HttpMethod httpMethod,
URI uri,
HttpRequest<?> context)
Finds all of the possible routes for the given HTTP method and URI.
|
default <T,R> Stream<UriRouteMatch<T,R>> |
find(HttpRequest<?> request)
Finds all of the possible routes for the given HTTP request.
|
default <T,R> Stream<UriRouteMatch<T,R>> |
find(HttpRequest<?> request,
CharSequence uri)
Find method, that should be used for non-standard http methods.
|
<T,R> List<UriRouteMatch<T,R>> |
findAllClosest(HttpRequest<?> request)
Finds the closest match for the given request.
|
<T,R> Stream<UriRouteMatch<T,R>> |
findAny(CharSequence uri,
HttpRequest<?> context)
Find any
RouteMatch regardless of HTTP method. |
<R> Optional<RouteMatch<R>> |
findErrorRoute(Class<?> originatingClass,
Throwable error,
HttpRequest<?> request)
Match a route to an error.
|
<R> Optional<RouteMatch<R>> |
findErrorRoute(Throwable error,
HttpRequest<?> request)
Match a route to an error.
|
List<HttpFilter> |
findFilters(HttpRequest<?> request)
Build a filtered
Publisher for an action. |
<R> Optional<RouteMatch<R>> |
findStatusRoute(Class<?> originatingClass,
HttpStatus status,
HttpRequest<?> request)
Found a
RouteMatch for the given HttpStatus code. |
<R> Optional<RouteMatch<R>> |
findStatusRoute(HttpStatus status,
HttpRequest<?> request)
Found a
RouteMatch for the given HttpStatus code. |
default <T,R> Optional<UriRouteMatch<T,R>> |
GET(CharSequence uri)
Find the first
RouteMatch route for an HttpMethod.GET method and the given URI. |
Set<Integer> |
getExposedPorts() |
default <T,R> Optional<UriRouteMatch<T,R>> |
HEAD(CharSequence uri)
Find the first
RouteMatch route for an HttpMethod.HEAD method and the given URI. |
default <T,R> Optional<UriRouteMatch<T,R>> |
OPTIONS(CharSequence uri)
Find the first
RouteMatch route for an HttpMethod.OPTIONS method and the given URI. |
default <T,R> Optional<UriRouteMatch<T,R>> |
PATCH(CharSequence uri)
Find the first
RouteMatch route for an HttpMethod.PATCH method and the given URI. |
default <T,R> Optional<UriRouteMatch<T,R>> |
POST(CharSequence uri)
Find the first
RouteMatch route for an HttpMethod.POST method and the given URI. |
default <T,R> Optional<UriRouteMatch<T,R>> |
PUT(CharSequence uri)
Find the first
RouteMatch route for an HttpMethod.PUT method and the given URI. |
<R> Optional<RouteMatch<R>> |
route(Class originatingClass,
HttpStatus status)
Found a
RouteMatch for the given HttpStatus code. |
<R> Optional<RouteMatch<R>> |
route(Class originatingClass,
Throwable error)
Match a route to an error.
|
<T,R> Optional<UriRouteMatch<T,R>> |
route(HttpMethod httpMethod,
CharSequence uri)
Finds the first possible route for the given HTTP method and URI.
|
<R> Optional<RouteMatch<R>> |
route(HttpStatus status)
Found a
RouteMatch for the given HttpStatus code. |
<R> Optional<RouteMatch<R>> |
route(Throwable error)
Match a route to an error.
|
Stream<UriRoute> |
uriRoutes()
Returns all UriRoutes.
|
@NonNull <T,R> Stream<UriRouteMatch<T,R>> findAny(@NonNull CharSequence uri, @Nullable HttpRequest<?> context)
RouteMatch
regardless of HTTP method.T
- The target typeR
- The return typeuri
- The URIcontext
- The optional HttpRequest
context information to apply RouteMatchFilter
.void applyDefaultPorts(List<Integer> ports)
ports
- The default ports@NonNull <T,R> Stream<UriRouteMatch<T,R>> find(@NonNull HttpMethod httpMethod, @NonNull CharSequence uri, @Nullable HttpRequest<?> context)
T
- The target typeR
- The typehttpMethod
- The HTTP methoduri
- The URI route matchcontext
- The optional HttpRequest
context information to apply RouteMatchFilter
.Stream
of possible Route
instances.@NonNull default <T,R> Stream<UriRouteMatch<T,R>> find(@NonNull HttpMethod httpMethod, @NonNull URI uri, @Nullable HttpRequest<?> context)
T
- The target typeR
- The URI route matchhttpMethod
- The HTTP methoduri
- The URIcontext
- The optional HttpRequest
contextStream
of possible Route
instances.@NonNull default <T,R> Stream<UriRouteMatch<T,R>> find(@NonNull HttpRequest<?> request)
@NonNull default <T,R> Stream<UriRouteMatch<T,R>> find(@NonNull HttpRequest<?> request, @NonNull CharSequence uri)
find(HttpMethod, CharSequence, HttpRequest)
T
- The target type.R
- The type of whatrequest
- The request, that can have overridden HttpRequest.getMethodName()
uri
- The URI route match.Stream
of possible Route
instances.@NonNull <T,R> List<UriRouteMatch<T,R>> findAllClosest(@NonNull HttpRequest<?> request)
<T,R> Optional<UriRouteMatch<T,R>> route(@NonNull HttpMethod httpMethod, @NonNull CharSequence uri)
T
- The target typeR
- The URI route matchhttpMethod
- The HTTP methoduri
- The URI<R> Optional<RouteMatch<R>> route(@NonNull HttpStatus status)
RouteMatch
for the given HttpStatus
code.R
- The matched routestatus
- The HTTP statusRouteMatch
<R> Optional<RouteMatch<R>> route(@NonNull Class originatingClass, @NonNull HttpStatus status)
RouteMatch
for the given HttpStatus
code.R
- The matched routeoriginatingClass
- The class the error originates fromstatus
- The HTTP statusRouteMatch
<R> Optional<RouteMatch<R>> route(@NonNull Throwable error)
R
- The matched routeerror
- The errorRouteMatch
<R> Optional<RouteMatch<R>> route(@NonNull Class originatingClass, @NonNull Throwable error)
R
- The matched routeoriginatingClass
- The class the error originates fromerror
- The errorRouteMatch
<R> Optional<RouteMatch<R>> findErrorRoute(@NonNull Class<?> originatingClass, @NonNull Throwable error, HttpRequest<?> request)
R
- The matched routeoriginatingClass
- The class the error originates fromerror
- The errorrequest
- The requestRouteMatch
<R> Optional<RouteMatch<R>> findErrorRoute(@NonNull Throwable error, HttpRequest<?> request)
R
- The matched routeerror
- The errorrequest
- The requestRouteMatch
<R> Optional<RouteMatch<R>> findStatusRoute(@NonNull Class<?> originatingClass, @NonNull HttpStatus status, HttpRequest<?> request)
RouteMatch
for the given HttpStatus
code.R
- The matched routeoriginatingClass
- The class the error originates fromstatus
- The HTTP statusrequest
- The requestRouteMatch
<R> Optional<RouteMatch<R>> findStatusRoute(@NonNull HttpStatus status, HttpRequest<?> request)
RouteMatch
for the given HttpStatus
code.R
- The matched routestatus
- The HTTP statusrequest
- The requestRouteMatch
@NonNull List<HttpFilter> findFilters(@NonNull HttpRequest<?> request)
Publisher
for an action.request
- The requestdefault <T,R> Optional<UriRouteMatch<T,R>> GET(@NonNull CharSequence uri)
RouteMatch
route for an HttpMethod.GET
method and the given URI.T
- The target typeR
- The return typeuri
- The URIOptional
of RouteMatch
default <T,R> Optional<UriRouteMatch<T,R>> POST(@NonNull CharSequence uri)
RouteMatch
route for an HttpMethod.POST
method and the given URI.T
- The target typeR
- The return typeuri
- The URIOptional
of RouteMatch
default <T,R> Optional<UriRouteMatch<T,R>> PUT(@NonNull CharSequence uri)
RouteMatch
route for an HttpMethod.PUT
method and the given URI.T
- The target typeR
- The URI route matchuri
- The URIOptional
of RouteMatch
default <T,R> Optional<UriRouteMatch<T,R>> PATCH(@NonNull CharSequence uri)
RouteMatch
route for an HttpMethod.PATCH
method and the given URI.T
- The target typeR
- The return typeuri
- The URIOptional
of RouteMatch
default <T,R> Optional<UriRouteMatch<T,R>> DELETE(@NonNull CharSequence uri)
RouteMatch
route for an HttpMethod.DELETE
method and the given URI.T
- The target typeR
- The return typeuri
- The URIOptional
of RouteMatch
default <T,R> Optional<UriRouteMatch<T,R>> OPTIONS(@NonNull CharSequence uri)
RouteMatch
route for an HttpMethod.OPTIONS
method and the given URI.T
- The target typeR
- The return typeuri
- The URIOptional
of RouteMatch
default <T,R> Optional<UriRouteMatch<T,R>> HEAD(@NonNull CharSequence uri)
RouteMatch
route for an HttpMethod.HEAD
method and the given URI.T
- The target typeR
- The return typeuri
- The URIOptional
of RouteMatch