1 // Copyright (c) 2012 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_SPDY_SPDY_WEBSOCKET_STREAM_H_
6 #define NET_SPDY_SPDY_WEBSOCKET_STREAM_H_
8 #include "base/basictypes.h"
9 #include "base/gtest_prod_util.h"
10 #include "base/memory/ref_counted.h"
11 #include "base/memory/scoped_ptr.h"
12 #include "base/memory/weak_ptr.h"
13 #include "base/time/time.h"
14 #include "net/base/completion_callback.h"
15 #include "net/base/request_priority.h"
16 #include "net/spdy/spdy_framer.h"
17 #include "net/spdy/spdy_header_block.h"
18 #include "net/spdy/spdy_session.h"
19 #include "net/spdy/spdy_stream.h"
23 // The SpdyWebSocketStream is a WebSocket-specific type of stream known to a
24 // SpdySession. WebSocket's opening handshake is converted to SPDY's
25 // SYN_STREAM/SYN_REPLY. WebSocket frames are encapsulated as SPDY data frames.
26 class NET_EXPORT_PRIVATE SpdyWebSocketStream
27 : public SpdyStream::Delegate
{
29 // Delegate handles asynchronous events.
30 class NET_EXPORT_PRIVATE Delegate
{
32 // Called when InitializeStream() finishes asynchronously. This delegate is
33 // called if InitializeStream() returns ERR_IO_PENDING. |status| indicates
35 virtual void OnCreatedSpdyStream(int status
) = 0;
37 // Called on corresponding to OnSendHeadersComplete() or SPDY's SYN frame
39 virtual void OnSentSpdyHeaders() = 0;
41 // Called on corresponding to OnResponseHeadersUpdated() or
42 // SPDY's SYN_STREAM, SYN_REPLY, or HEADERS frames are
43 // received. This callback may be called multiple times as SPDY's
45 virtual void OnSpdyResponseHeadersUpdated(
46 const SpdyHeaderBlock
& response_headers
) = 0;
48 // Called when data is sent.
49 virtual void OnSentSpdyData(size_t bytes_sent
) = 0;
51 // Called when data is received.
52 virtual void OnReceivedSpdyData(scoped_ptr
<SpdyBuffer
> buffer
) = 0;
54 // Called when SpdyStream is closed.
55 virtual void OnCloseSpdyStream() = 0;
58 virtual ~Delegate() {}
61 SpdyWebSocketStream(const base::WeakPtr
<SpdySession
>& spdy_session
,
63 virtual ~SpdyWebSocketStream();
65 // Initializes SPDY stream for the WebSocket.
66 // It might create SPDY stream asynchronously. In this case, this method
67 // returns ERR_IO_PENDING and call OnCreatedSpdyStream delegate with result
68 // after completion. In other cases, delegate does not be called.
69 int InitializeStream(const GURL
& url
,
70 RequestPriority request_priority
,
71 const BoundNetLog
& stream_net_log
);
73 int SendRequest(scoped_ptr
<SpdyHeaderBlock
> headers
);
74 int SendData(const char* data
, int length
);
77 // SpdyStream::Delegate
78 virtual void OnRequestHeadersSent() OVERRIDE
;
79 virtual SpdyResponseHeadersStatus
OnResponseHeadersUpdated(
80 const SpdyHeaderBlock
& response_headers
) OVERRIDE
;
81 virtual void OnDataReceived(scoped_ptr
<SpdyBuffer
> buffer
) OVERRIDE
;
82 virtual void OnDataSent() OVERRIDE
;
83 virtual void OnClose(int status
) OVERRIDE
;
86 friend class SpdyWebSocketStreamTest
;
87 FRIEND_TEST_ALL_PREFIXES(SpdyWebSocketStreamTest
, Basic
);
89 void OnSpdyStreamCreated(int status
);
91 base::WeakPtrFactory
<SpdyWebSocketStream
> weak_ptr_factory_
;
92 SpdyStreamRequest stream_request_
;
93 base::WeakPtr
<SpdyStream
> stream_
;
94 const base::WeakPtr
<SpdySession
> spdy_session_
;
95 size_t pending_send_data_length_
;
98 DISALLOW_COPY_AND_ASSIGN(SpdyWebSocketStream
);
103 #endif // NET_SPDY_SPDY_WEBSOCKET_STREAM_H_