Skip to content

Commit

Permalink
Traverse PathTrie instead.
Browse files Browse the repository at this point in the history
Signed-off-by: dblock <[email protected]>
  • Loading branch information
dblock committed Jan 11, 2024
1 parent 5cae02a commit de6c3f7
Show file tree
Hide file tree
Showing 3 changed files with 50 additions and 26 deletions.
25 changes: 25 additions & 0 deletions server/src/main/java/org/opensearch/common/path/PathTrie.java
Original file line number Diff line number Diff line change
Expand Up @@ -37,6 +37,7 @@
import java.util.Iterator;
import java.util.Map;
import java.util.NoSuchElementException;
import java.util.Stack;
import java.util.function.BiFunction;
import java.util.function.Supplier;

Expand Down Expand Up @@ -405,4 +406,28 @@ public T next() {
}
};
}

public Iterator<T> retrieveAll() {
Stack<TrieNode> stack = new Stack<>();
stack.add(root);

Check warning on line 412 in server/src/main/java/org/opensearch/common/path/PathTrie.java

View check run for this annotation

Codecov / codecov/patch

server/src/main/java/org/opensearch/common/path/PathTrie.java#L411-L412

Added lines #L411 - L412 were not covered by tests

return new Iterator<T>() {

Check warning on line 414 in server/src/main/java/org/opensearch/common/path/PathTrie.java

View check run for this annotation

Codecov / codecov/patch

server/src/main/java/org/opensearch/common/path/PathTrie.java#L414

Added line #L414 was not covered by tests
@Override
public boolean hasNext() {
return !stack.empty();
}

@Override
public T next() {
while (!stack.empty()) {
TrieNode node = stack.pop();
stack.addAll(node.children.values());

Check warning on line 424 in server/src/main/java/org/opensearch/common/path/PathTrie.java

View check run for this annotation

Codecov / codecov/patch

server/src/main/java/org/opensearch/common/path/PathTrie.java#L423-L424

Added lines #L423 - L424 were not covered by tests
if (node.value != null) {
return node.value;

Check warning on line 426 in server/src/main/java/org/opensearch/common/path/PathTrie.java

View check run for this annotation

Codecov / codecov/patch

server/src/main/java/org/opensearch/common/path/PathTrie.java#L426

Added line #L426 was not covered by tests
}
}
throw new NoSuchElementException("encountered a terminal node without a value");

Check warning on line 429 in server/src/main/java/org/opensearch/common/path/PathTrie.java

View check run for this annotation

Codecov / codecov/patch

server/src/main/java/org/opensearch/common/path/PathTrie.java#L428-L429

Added lines #L428 - L429 were not covered by tests
}
};
}
}
7 changes: 7 additions & 0 deletions server/src/main/java/org/opensearch/rest/MethodHandlers.java
Original file line number Diff line number Diff line change
Expand Up @@ -48,6 +48,13 @@ final class MethodHandlers {
private final String path;
private final Map<RestRequest.Method, RestHandler> methodHandlers;

/**
* Complete path of the method handlers.
*/
public String getPath() {
return path;

Check warning on line 55 in server/src/main/java/org/opensearch/rest/MethodHandlers.java

View check run for this annotation

Codecov / codecov/patch

server/src/main/java/org/opensearch/rest/MethodHandlers.java#L55

Added line #L55 was not covered by tests
}

MethodHandlers(String path, RestHandler handler, RestRequest.Method... methods) {
this.path = path;
this.methodHandlers = new HashMap<>(methods.length);
Expand Down
44 changes: 18 additions & 26 deletions server/src/main/java/org/opensearch/rest/RestController.java
Original file line number Diff line number Diff line change
Expand Up @@ -66,7 +66,13 @@
import java.io.IOException;
import java.io.InputStream;
import java.net.URI;
import java.util.*;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Iterator;
import java.util.List;
import java.util.Locale;
import java.util.Map;
import java.util.Set;
import java.util.concurrent.atomic.AtomicBoolean;
import java.util.function.Supplier;
import java.util.function.UnaryOperator;
Expand Down Expand Up @@ -104,11 +110,6 @@ public class RestController implements HttpServerTransport.Dispatcher, ToXConten
}

private final PathTrie<MethodHandlers> handlers = new PathTrie<>(RestUtils.REST_DECODER);
private final HashMap<String, Set<RestRequest.Method>> apis = new HashMap<>();

public HashMap<String, Set<RestRequest.Method>> getApis() {
return apis;
}

private final UnaryOperator<RestHandler> handlerWrapper;

Expand Down Expand Up @@ -220,15 +221,6 @@ protected void registerHandler(RestRequest.Method method, String path, RestHandl
}

private void registerHandlerNoWrap(RestRequest.Method method, String path, RestHandler maybeWrappedHandler) {

// TODO: traverse pathtrie
Set<RestRequest.Method> methods = apis.getOrDefault(path, null);
if (methods == null) {
methods = new HashSet<RestRequest.Method>();
apis.put(path, methods);
}
methods.add(method);

handlers.insertOrUpdate(
path,
new MethodHandlers(path, maybeWrappedHandler, method),
Expand Down Expand Up @@ -585,17 +577,17 @@ private Set<RestRequest.Method> getValidHandlerMethodSet(String rawPath) {
public XContentBuilder toXContent(XContentBuilder builder, Params params) throws IOException {
builder.startObject("paths");

Check warning on line 578 in server/src/main/java/org/opensearch/rest/RestController.java

View check run for this annotation

Codecov / codecov/patch

server/src/main/java/org/opensearch/rest/RestController.java#L578

Added line #L578 was not covered by tests

for (Map.Entry<String, Set<RestRequest.Method>> entry : getApis().entrySet()) {
String key = entry.getKey();
Set<RestRequest.Method> methods = entry.getValue();
builder.startObject(key.replace("{", ":").replace("}", ""));
for(RestRequest.Method method : methods) {
builder
.startObject(method.name().toLowerCase())
//.field("summary", "")
//.field("description", "")
//.startObject("responses", "")
//.endObject())
Iterator<MethodHandlers> all = handlers.retrieveAll();

Check warning on line 580 in server/src/main/java/org/opensearch/rest/RestController.java

View check run for this annotation

Codecov / codecov/patch

server/src/main/java/org/opensearch/rest/RestController.java#L580

Added line #L580 was not covered by tests

while (all.hasNext()) {
MethodHandlers handlers = all.next();
builder.startObject(handlers.getPath().replace("{", ":").replace("}", ""));

Check warning on line 584 in server/src/main/java/org/opensearch/rest/RestController.java

View check run for this annotation

Codecov / codecov/patch

server/src/main/java/org/opensearch/rest/RestController.java#L583-L584

Added lines #L583 - L584 were not covered by tests
for (RestRequest.Method method : handlers.getValidMethods()) {
builder.startObject(method.name().toLowerCase(Locale.ROOT))

Check warning on line 586 in server/src/main/java/org/opensearch/rest/RestController.java

View check run for this annotation

Codecov / codecov/patch

server/src/main/java/org/opensearch/rest/RestController.java#L586

Added line #L586 was not covered by tests
// .field("summary", "")
// .field("description", "")
// .startObject("responses", "")
// .endObject())
.endObject();
}
builder.endObject();
Expand Down

0 comments on commit de6c3f7

Please sign in to comment.