View Javadoc

1   //
2   //  ========================================================================
3   //  Copyright (c) 1995-2013 Mort Bay Consulting Pty. Ltd.
4   //  ------------------------------------------------------------------------
5   //  All rights reserved. This program and the accompanying materials
6   //  are made available under the terms of the Eclipse Public License v1.0
7   //  and Apache License v2.0 which accompanies this distribution.
8   //
9   //      The Eclipse Public License is available at
10  //      http://www.eclipse.org/legal/epl-v10.html
11  //
12  //      The Apache License v2.0 is available at
13  //      http://www.opensource.org/licenses/apache2.0.php
14  //
15  //  You may elect to redistribute this code under either of these licenses.
16  //  ========================================================================
17  //
18  
19  package org.eclipse.jetty.websocket.jsr356.server;
20  
21  import java.util.HashMap;
22  import java.util.Map;
23  
24  import javax.websocket.server.ServerEndpointConfig;
25  
26  import org.eclipse.jetty.websocket.jsr356.server.pathmap.WebSocketPathSpec;
27  
28  /**
29   * Wrapper for a {@link ServerEndpointConfig} where there PathParm information from the incoming request.
30   */
31  public class PathParamServerEndpointConfig extends BasicServerEndpointConfig implements ServerEndpointConfig
32  {
33      private final Map<String, String> pathParamMap;
34  
35      public PathParamServerEndpointConfig(ServerEndpointConfig config, WebSocketPathSpec pathSpec, String requestPath)
36      {
37          super(config);
38  
39          Map<String, String> pathMap = pathSpec.getPathParams(requestPath);
40          pathParamMap = new HashMap<String, String>();
41          if (pathMap != null)
42          {
43              pathParamMap.putAll(pathMap);
44          }
45      }
46  
47      public Map<String, String> getPathParamMap()
48      {
49          return pathParamMap;
50      }
51  }