Roll WebRTC 9745:9761, Libjingle 9742:9761
[chromium-blink-merge.git] / net / spdy / spdy_http_stream.h
blob0aa54f056863bb607c6ff5c87b8a26b3a9be2bd8
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_HTTP_STREAM_H_
6 #define NET_SPDY_SPDY_HTTP_STREAM_H_
8 #include <list>
10 #include "base/basictypes.h"
11 #include "base/memory/ref_counted.h"
12 #include "base/memory/weak_ptr.h"
13 #include "net/base/completion_callback.h"
14 #include "net/http/http_stream.h"
15 #include "net/log/net_log.h"
16 #include "net/spdy/spdy_read_queue.h"
17 #include "net/spdy/spdy_session.h"
18 #include "net/spdy/spdy_stream.h"
20 namespace net {
22 class DrainableIOBuffer;
23 struct HttpRequestInfo;
24 class HttpResponseInfo;
25 class IOBuffer;
26 class SpdySession;
27 class UploadDataStream;
29 // The SpdyHttpStream is a HTTP-specific type of stream known to a SpdySession.
30 class NET_EXPORT_PRIVATE SpdyHttpStream : public SpdyStream::Delegate,
31 public HttpStream {
32 public:
33 // |spdy_session| must not be NULL.
34 SpdyHttpStream(const base::WeakPtr<SpdySession>& spdy_session, bool direct);
35 ~SpdyHttpStream() override;
37 SpdyStream* stream() { return stream_.get(); }
39 // Cancels any callbacks from being invoked and deletes the stream.
40 void Cancel();
42 // HttpStream implementation.
44 int InitializeStream(const HttpRequestInfo* request_info,
45 RequestPriority priority,
46 const BoundNetLog& net_log,
47 const CompletionCallback& callback) override;
49 int SendRequest(const HttpRequestHeaders& headers,
50 HttpResponseInfo* response,
51 const CompletionCallback& callback) override;
52 UploadProgress GetUploadProgress() const override;
53 int ReadResponseHeaders(const CompletionCallback& callback) override;
54 int ReadResponseBody(IOBuffer* buf,
55 int buf_len,
56 const CompletionCallback& callback) override;
57 void Close(bool not_reusable) override;
58 HttpStream* RenewStreamForAuth() override;
59 bool IsResponseBodyComplete() const override;
60 bool CanFindEndOfResponse() const override;
62 // Must not be called if a NULL SpdySession was pssed into the
63 // constructor.
64 bool IsConnectionReused() const override;
66 void SetConnectionReused() override;
67 bool IsConnectionReusable() const override;
68 int64 GetTotalReceivedBytes() const override;
69 bool GetLoadTimingInfo(LoadTimingInfo* load_timing_info) const override;
70 void GetSSLInfo(SSLInfo* ssl_info) override;
71 void GetSSLCertRequestInfo(SSLCertRequestInfo* cert_request_info) override;
72 bool IsSpdyHttpStream() const override;
73 void Drain(HttpNetworkSession* session) override;
74 void SetPriority(RequestPriority priority) override;
76 // SpdyStream::Delegate implementation.
77 void OnRequestHeadersSent() override;
78 SpdyResponseHeadersStatus OnResponseHeadersUpdated(
79 const SpdyHeaderBlock& response_headers) override;
80 void OnDataReceived(scoped_ptr<SpdyBuffer> buffer) override;
81 void OnDataSent() override;
82 void OnTrailers(const SpdyHeaderBlock& trailers) override;
83 void OnClose(int status) override;
85 private:
86 // Must be called only when |request_info_| is non-NULL.
87 bool HasUploadData() const;
89 void OnStreamCreated(const CompletionCallback& callback, int rv);
91 // Reads the remaining data (whether chunked or not) from the
92 // request body stream and sends it if there's any. The read and
93 // subsequent sending may happen asynchronously. Must be called only
94 // when HasUploadData() is true.
95 void ReadAndSendRequestBodyData();
97 // Called when data has just been read from the request body stream;
98 // does the actual sending of data.
99 void OnRequestBodyReadCompleted(int status);
101 // Call the user callback.
102 void DoCallback(int rv);
104 void ScheduleBufferedReadCallback();
106 // Returns true if the callback is invoked.
107 bool DoBufferedReadCallback();
108 bool ShouldWaitForMoreBufferedData() const;
110 const base::WeakPtr<SpdySession> spdy_session_;
111 bool is_reused_;
112 SpdyStreamRequest stream_request_;
113 base::WeakPtr<SpdyStream> stream_;
115 bool stream_closed_;
117 // Set only when |stream_closed_| is true.
118 int closed_stream_status_;
119 SpdyStreamId closed_stream_id_;
120 bool closed_stream_has_load_timing_info_;
121 LoadTimingInfo closed_stream_load_timing_info_;
122 int64 closed_stream_received_bytes_;
124 // The request to send.
125 const HttpRequestInfo* request_info_;
127 // |response_info_| is the HTTP response data object which is filled in
128 // when a SYN_REPLY comes in for the stream.
129 // It is not owned by this stream object, or point to |push_response_info_|.
130 HttpResponseInfo* response_info_;
132 scoped_ptr<HttpResponseInfo> push_response_info_;
134 // We don't use SpdyStream's |response_header_status_| as we
135 // sometimes call back into our delegate before it is updated.
136 SpdyResponseHeadersStatus response_headers_status_;
138 // We buffer the response body as it arrives asynchronously from the stream.
139 SpdyReadQueue response_body_queue_;
141 CompletionCallback callback_;
143 // User provided buffer for the ReadResponseBody() response.
144 scoped_refptr<IOBuffer> user_buffer_;
145 int user_buffer_len_;
147 // Temporary buffer used to read the request body from UploadDataStream.
148 scoped_refptr<IOBufferWithSize> request_body_buf_;
149 int request_body_buf_size_;
151 // Is there a scheduled read callback pending.
152 bool buffered_read_callback_pending_;
153 // Has more data been received from the network during the wait for the
154 // scheduled read callback.
155 bool more_read_data_pending_;
157 // Is this spdy stream direct to the origin server (or to a proxy).
158 bool direct_;
160 base::WeakPtrFactory<SpdyHttpStream> weak_factory_;
162 DISALLOW_COPY_AND_ASSIGN(SpdyHttpStream);
165 } // namespace net
167 #endif // NET_SPDY_SPDY_HTTP_STREAM_H_