Ether Framework
Unified API docs for Ether modules
Loading...
Searching...
No Matches
WebSocketRouteMatcher.java
Go to the documentation of this file.
1package dev.rafex.ether.websocket.core;
2
3/*-
4 * #%L
5 * ether-websocket-core
6 * %%
7 * Copyright (C) 2025 - 2026 Raúl Eduardo González Argote
8 * %%
9 * Permission is hereby granted, free of charge, to any person obtaining a copy
10 * of this software and associated documentation files (the "Software"), to deal
11 * in the Software without restriction, including without limitation the rights
12 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
13 * copies of the Software, and to permit persons to whom the Software is
14 * furnished to do so, subject to the following conditions:
15 *
16 * The above copyright notice and this permission notice shall be included in
17 * all copies or substantial portions of the Software.
18 *
19 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
20 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
21 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
22 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
23 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
24 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
25 * THE SOFTWARE.
26 * #L%
27 */
28
29import java.util.List;
30import java.util.Optional;
31
32/**
33 * Utilidad que resuelve la primera {@link WebSocketRoute} que coincide con un path dado.
34 * Recorre la lista de rutas en orden y retorna la primera coincidencia encontrada.
35 */
36public final class WebSocketRouteMatcher {
37
38 private WebSocketRouteMatcher() {
39 }
40
41 /**
42 * Busca la primera ruta de la lista cuyo patrón coincida con el path especificado.
43 *
44 * @param path path entrante de la conexión WebSocket
45 * @param routes lista de rutas registradas; se evalúan en orden de inserción
46 * @return un {@link Optional} con el {@link WebSocketRouteMatch} si se encontró coincidencia;
47 * {@link Optional#empty()} si la lista es nula, vacía o ninguna ruta coincide
48 */
49 public static Optional<WebSocketRouteMatch> match(final String path, final List<WebSocketRoute> routes) {
50 if (routes == null || routes.isEmpty()) {
51 return Optional.empty();
52 }
53 for (final var route : routes) {
54 final var match = WebSocketPatterns.match(route.pattern(), path);
55 if (match.isPresent()) {
56 return Optional.of(new WebSocketRouteMatch(route, match.get()));
57 }
58 }
59 return Optional.empty();
60 }
61}
Utilidad para el matching de patrones de rutas WebSocket.
static Optional< Map< String, String > > match(final String pattern, final String path)
Comprueba si el path dado coincide con el patrón de ruta especificado.
static Optional< WebSocketRouteMatch > match(final String path, final List< WebSocketRoute > routes)
Busca la primera ruta de la lista cuyo patrón coincida con el path especificado.
record WebSocketRouteMatch(WebSocketRoute route, Map< String, String > pathParams)
Representa el resultado de una coincidencia exitosa entre un path entrante y una WebSocketRoute.