Updating trunk VERSION from 2139.0 to 2140.0
[chromium-blink-merge.git] / net / websockets / websocket_basic_handshake_stream.h
blob51f0c4db1c57c78e098c09d750abcc0a34824f1d
1 // Copyright 2013 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
5 #ifndef NET_WEBSOCKETS_WEBSOCKET_BASIC_HANDSHAKE_STREAM_H_
6 #define NET_WEBSOCKETS_WEBSOCKET_BASIC_HANDSHAKE_STREAM_H_
8 #include <string>
9 #include <vector>
11 #include "base/memory/ref_counted.h"
12 #include "base/memory/scoped_ptr.h"
13 #include "net/base/net_export.h"
14 #include "net/http/http_basic_state.h"
15 #include "net/websockets/websocket_handshake_stream_base.h"
16 #include "url/gurl.h"
18 namespace net {
20 class ClientSocketHandle;
21 class HttpResponseHeaders;
22 class HttpResponseInfo;
23 class HttpStreamParser;
25 struct WebSocketExtensionParams;
27 class NET_EXPORT_PRIVATE WebSocketBasicHandshakeStream
28 : public WebSocketHandshakeStreamBase {
29 public:
30 // |connect_delegate| and |failure_message| must out-live this object.
31 WebSocketBasicHandshakeStream(
32 scoped_ptr<ClientSocketHandle> connection,
33 WebSocketStream::ConnectDelegate* connect_delegate,
34 bool using_proxy,
35 std::vector<std::string> requested_sub_protocols,
36 std::vector<std::string> requested_extensions,
37 std::string* failure_message);
39 virtual ~WebSocketBasicHandshakeStream();
41 // HttpStreamBase methods
42 virtual int InitializeStream(const HttpRequestInfo* request_info,
43 RequestPriority priority,
44 const BoundNetLog& net_log,
45 const CompletionCallback& callback) OVERRIDE;
46 virtual int SendRequest(const HttpRequestHeaders& request_headers,
47 HttpResponseInfo* response,
48 const CompletionCallback& callback) OVERRIDE;
49 virtual int ReadResponseHeaders(const CompletionCallback& callback) OVERRIDE;
50 virtual int ReadResponseBody(IOBuffer* buf,
51 int buf_len,
52 const CompletionCallback& callback) OVERRIDE;
53 virtual void Close(bool not_reusable) OVERRIDE;
54 virtual bool IsResponseBodyComplete() const OVERRIDE;
55 virtual bool CanFindEndOfResponse() const OVERRIDE;
56 virtual bool IsConnectionReused() const OVERRIDE;
57 virtual void SetConnectionReused() OVERRIDE;
58 virtual bool IsConnectionReusable() const OVERRIDE;
59 virtual int64 GetTotalReceivedBytes() const OVERRIDE;
60 virtual bool GetLoadTimingInfo(LoadTimingInfo* load_timing_info) const
61 OVERRIDE;
62 virtual void GetSSLInfo(SSLInfo* ssl_info) OVERRIDE;
63 virtual void GetSSLCertRequestInfo(
64 SSLCertRequestInfo* cert_request_info) OVERRIDE;
65 virtual bool IsSpdyHttpStream() const OVERRIDE;
66 virtual void Drain(HttpNetworkSession* session) OVERRIDE;
67 virtual void SetPriority(RequestPriority priority) OVERRIDE;
69 // This is called from the top level once correct handshake response headers
70 // have been received. It creates an appropriate subclass of WebSocketStream
71 // depending on what extensions were negotiated. This object is unusable after
72 // Upgrade() has been called and should be disposed of as soon as possible.
73 virtual scoped_ptr<WebSocketStream> Upgrade() OVERRIDE;
75 // Set the value used for the next Sec-WebSocket-Key header
76 // deterministically. The key is only used once, and then discarded.
77 // For tests only.
78 void SetWebSocketKeyForTesting(const std::string& key);
80 private:
81 // A wrapper for the ReadResponseHeaders callback that checks whether or not
82 // the connection has been accepted.
83 void ReadResponseHeadersCallback(const CompletionCallback& callback,
84 int result);
86 void OnFinishOpeningHandshake();
88 // Validates the response and sends the finished handshake event.
89 int ValidateResponse(int rv);
91 // Check that the headers are well-formed for a 101 response, and returns
92 // OK if they are, otherwise returns ERR_INVALID_RESPONSE.
93 int ValidateUpgradeResponse(const HttpResponseHeaders* headers);
95 HttpStreamParser* parser() const { return state_.parser(); }
97 void set_failure_message(const std::string& failure_message);
99 // The request URL.
100 GURL url_;
102 // HttpBasicState holds most of the handshake-related state.
103 HttpBasicState state_;
105 // Owned by another object.
106 // |connect_delegate| will live during the lifetime of this object.
107 WebSocketStream::ConnectDelegate* connect_delegate_;
109 // This is stored in SendRequest() for use by ReadResponseHeaders().
110 HttpResponseInfo* http_response_info_;
112 // The key to be sent in the next Sec-WebSocket-Key header. Usually NULL (the
113 // key is generated on the fly).
114 scoped_ptr<std::string> handshake_challenge_for_testing_;
116 // The required value for the Sec-WebSocket-Accept header.
117 std::string handshake_challenge_response_;
119 // The sub-protocols we requested.
120 std::vector<std::string> requested_sub_protocols_;
122 // The extensions we requested.
123 std::vector<std::string> requested_extensions_;
125 // The sub-protocol selected by the server.
126 std::string sub_protocol_;
128 // The extension(s) selected by the server.
129 std::string extensions_;
131 // The extension parameters. The class is defined in the implementation file
132 // to avoid including extension-related header files here.
133 scoped_ptr<WebSocketExtensionParams> extension_params_;
135 std::string* failure_message_;
137 DISALLOW_COPY_AND_ASSIGN(WebSocketBasicHandshakeStream);
140 } // namespace net
142 #endif // NET_WEBSOCKETS_WEBSOCKET_BASIC_HANDSHAKE_STREAM_H_