Skip to content

Commit

Permalink
[UNDERTOW-2303] Further improvements to javadoc.
Browse files Browse the repository at this point in the history
  • Loading branch information
dirkroets committed Oct 23, 2024
1 parent 6f6b824 commit c591a97
Show file tree
Hide file tree
Showing 2 changed files with 23 additions and 9 deletions.
28 changes: 21 additions & 7 deletions core/src/main/java/io/undertow/util/PathTemplateRouter.java
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,8 @@
*/
package io.undertow.util;

import io.undertow.server.HttpHandler;

/**
* Routes requested URL paths to sets of underlying URL path templates.
*
Expand Down Expand Up @@ -80,7 +82,7 @@
* <li>It is assumed that most services that use routing based on path templates will setup a router once (when the service
* starts) using a single thread and will then use that router to route millions of inbound requests using multiple concurrent
* threads. Perhaps the setup will not happen exactly once, but the mutation of routes happen very few times when compared to
* the number of times that requests are routed. For this reason this factory is heavily biased towards optimising the
* the number of times that requests are routed. For this reason this design is heavily biased towards optimising the
* performance of routing requests - sometimes at the expense of the performance of mutating routes.</li>
* <li>Taking point (1) above into consideration. Documentation and comments refer to two distinct phases of processing:<ol>
* <li>"Setup phase" as the phase/process during which routes are mutated and a router instance is created.</li>
Expand All @@ -98,19 +100,31 @@
public interface PathTemplateRouter<T> {

/**
* @return The default target for requests that do no match any specific routes.
* @return The default target for requests that do not match any specific routes.
*/
T getDefaultTarget();

/**
* Routes the requested URL path to the set of underlying URL path templates.
*
* @param path The requested URL path.
* Routes the requested URL path to the best available target from the set of underlying URL path templates.
*
* @return The routing result. If the requested URL path matches any of the underlying URL path templates, then the most
* <p>
* If the requested URL path matches any of the underlying URL path templates, then the most
* specific match (target and template) will be returned in the result. If the requested URL path does not match any of the
* underlying URL path templates, then result will contain {@link #getDefaultTarget() } as the target and will contain an
* underlying URL path templates, then the result will contain {@link #getDefaultTarget() } as the target and will contain an
* empty Optional in {@link PathTemplateRouteResult#getPathTemplate() }.
*
* <p>
* On completion of this method, the caller will have the best available target for the specified path. This method
* merely provides the best target and does not call / action the target. That remains the responsibility of the caller.
* This design allows the router to support different use cases, i.e.:
* <ol>
* <li>Determine the best available {@link HttpHandler} to process a client request based on the requested path.</li>
* <li>Summarise HTTP access logs by normalising requested paths to available path templates.</li>
* </ol>
*
* @param path The requested URL path.
*
* @return The routing result.
*/
PathTemplateRouteResult<T> route(String path);
}
Original file line number Diff line number Diff line change
Expand Up @@ -1767,7 +1767,7 @@ public S getTemplateTarget(final PathTemplateParser.PathTemplate<S> template) {
}

/**
* @return A mutable map of {@link PathTemplatePatternEqualsAdapter}s for all templates added to this builder.
* @return A mutable map of {@link PathTemplateParser.PathTemplatePatternEqualsAdapter}s for all templates added to this builder.
*/
public Map<PathTemplateParser.PathTemplatePatternEqualsAdapter<PathTemplateParser.PathTemplate<S>>, S> getTemplates() {
return templates;
Expand Down Expand Up @@ -1936,7 +1936,7 @@ public SimpleBuilder<T> defaultTarget(final T defaultTarget) {
}

/**
* @return A mutable map of {@link PathTemplatePatternEqualsAdapter}s for all templates added to this builder.
* @return A mutable map of {@link PathTemplateParser.PathTemplatePatternEqualsAdapter}s for all templates added to this builder.
*/
public Map<PathTemplateParser.PathTemplatePatternEqualsAdapter<PathTemplateParser.PathTemplate<Supplier<T>>>, Supplier<T>> getTemplates() {
return builder.getTemplates();
Expand Down

0 comments on commit c591a97

Please sign in to comment.