/core-server/src/main/java/org/glassfish/jersey/server/internal/routing/PathToRouterBuilder.java

http://github.com/jersey/jersey · Java · 65 lines · 5 code · 3 blank · 57 comment · 0 complexity · f8403bc562e5f8be684b238b38e5c60a MD5 · raw file

  1. /*
  2. * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS HEADER.
  3. *
  4. * Copyright (c) 2012-2017 Oracle and/or its affiliates. All rights reserved.
  5. *
  6. * The contents of this file are subject to the terms of either the GNU
  7. * General Public License Version 2 only ("GPL") or the Common Development
  8. * and Distribution License("CDDL") (collectively, the "License"). You
  9. * may not use this file except in compliance with the License. You can
  10. * obtain a copy of the License at
  11. * https://oss.oracle.com/licenses/CDDL+GPL-1.1
  12. * or LICENSE.txt. See the License for the specific
  13. * language governing permissions and limitations under the License.
  14. *
  15. * When distributing the software, include this License Header Notice in each
  16. * file and include the License file at LICENSE.txt.
  17. *
  18. * GPL Classpath Exception:
  19. * Oracle designates this particular file as subject to the "Classpath"
  20. * exception as provided by Oracle in the GPL Version 2 section of the License
  21. * file that accompanied this code.
  22. *
  23. * Modifications:
  24. * If applicable, add the following below the License Header, with the fields
  25. * enclosed by brackets [] replaced by your own identifying information:
  26. * "Portions Copyright [year] [name of copyright owner]"
  27. *
  28. * Contributor(s):
  29. * If you wish your version of this file to be governed by only the CDDL or
  30. * only the GPL Version 2, indicate your decision by adding "[Contributor]
  31. * elects to include this software in this distribution under the [CDDL or GPL
  32. * Version 2] license." If you don't indicate a single choice of license, a
  33. * recipient has the option to distribute your version of this file under
  34. * either the CDDL, the GPL Version 2 or to extend the choice of license to
  35. * its licensees as provided above. However, if you add GPL Version 2 code
  36. * and therefore, elected the GPL Version 2 license, then the option applies
  37. * only if the new code is made subject to such option by the copyright
  38. * holder.
  39. */
  40. package org.glassfish.jersey.server.internal.routing;
  41. /**
  42. * An intermediate path matching router builder.
  43. *
  44. * This builder completes a routing information for a single routed {@link org.glassfish.jersey.uri.PathPattern}.
  45. * In case the unmatched right-hand part of the request path is matched by the routed path pattern, the request
  46. * processing context will be serially routed to all the child routers attached to the routing pattern using this
  47. * routing completion builder.
  48. *
  49. * @author Marek Potociar (marek.potociar at oracle.com)
  50. */
  51. @SuppressWarnings("ClassReferencesSubclass")
  52. interface PathToRouterBuilder {
  53. /**
  54. * Register a new next-level router to be used for request routing in case the routing pattern matches the
  55. * unmatched right-hand part of the request path.
  56. *
  57. * @param router new next-level router to be registered with the routed path pattern.
  58. * @return updated route builder ready to build a new {@link Router router} instance
  59. * (or add more routes to the currently built one).
  60. */
  61. PathMatchingRouterBuilder to(Router router);
  62. }