View Javadoc

1   //
2   //  ========================================================================
3   //  Copyright (c) 1995-2016 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.server;
20  
21  import java.io.IOException;
22  
23  import javax.servlet.ServletException;
24  import javax.servlet.http.HttpServletRequest;
25  import javax.servlet.http.HttpServletResponse;
26  
27  import org.eclipse.jetty.http.pathmap.MappedResource;
28  import org.eclipse.jetty.http.pathmap.PathMappings;
29  import org.eclipse.jetty.http.pathmap.PathSpec;
30  import org.eclipse.jetty.io.ByteBufferPool;
31  import org.eclipse.jetty.io.MappedByteBufferPool;
32  import org.eclipse.jetty.server.Request;
33  import org.eclipse.jetty.server.handler.HandlerWrapper;
34  import org.eclipse.jetty.websocket.servlet.WebSocketCreator;
35  
36  public class WebSocketUpgradeHandlerWrapper extends HandlerWrapper implements MappedWebSocketCreator
37  {
38      private PathMappings<WebSocketCreator> pathmap = new PathMappings<>();
39      private final WebSocketServerFactory factory;
40  
41      public WebSocketUpgradeHandlerWrapper()
42      {
43          this(new MappedByteBufferPool());
44      }
45      
46      public WebSocketUpgradeHandlerWrapper(ByteBufferPool bufferPool)
47      {
48          factory = new WebSocketServerFactory(bufferPool);
49      }
50  
51      @Override
52      public void addMapping(PathSpec spec, WebSocketCreator creator)
53      {
54          pathmap.put(spec,creator);
55      }
56  
57      @Override
58      public PathMappings<WebSocketCreator> getMappings()
59      {
60          return pathmap;
61      }
62  
63      @Override
64      public void handle(String target, Request baseRequest, HttpServletRequest request, HttpServletResponse response) throws IOException, ServletException
65      {
66          if (factory.isUpgradeRequest(request,response))
67          {
68              MappedResource<WebSocketCreator> resource = pathmap.getMatch(target);
69              if (resource == null)
70              {
71                  // no match.
72                  response.sendError(HttpServletResponse.SC_NOT_FOUND,"No websocket endpoint matching path: " + target);
73                  return;
74              }
75  
76              WebSocketCreator creator = resource.getResource();
77  
78              // Store PathSpec resource mapping as request attribute
79              request.setAttribute(PathSpec.class.getName(),resource);
80  
81              // We have an upgrade request
82              if (factory.acceptWebSocket(creator,request,response))
83              {
84                  // We have a socket instance created
85                  return;
86              }
87  
88              // If we reach this point, it means we had an incoming request to upgrade
89              // but it was either not a proper websocket upgrade, or it was possibly rejected
90              // due to incoming request constraints (controlled by WebSocketCreator)
91              if (response.isCommitted())
92              {
93                  // not much we can do at this point.
94                  return;
95              }
96          }
97          super.handle(target,baseRequest,request,response);
98      }
99  }