Updating trunk VERSION from 2139.0 to 2140.0
[chromium-blink-merge.git] / net / http / http_stream_factory_impl.h
blob7df0a6722cb65a8b63abb86eedd552c93b4c8eeb
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_HTTP_HTTP_STREAM_FACTORY_IMPL_H_
6 #define NET_HTTP_HTTP_STREAM_FACTORY_IMPL_H_
8 #include <map>
9 #include <set>
10 #include <vector>
12 #include "base/gtest_prod_util.h"
13 #include "base/memory/ref_counted.h"
14 #include "net/base/host_port_pair.h"
15 #include "net/base/net_log.h"
16 #include "net/http/http_stream_factory.h"
17 #include "net/proxy/proxy_server.h"
18 #include "net/socket/ssl_client_socket.h"
19 #include "net/spdy/spdy_session_key.h"
21 namespace net {
23 class HttpNetworkSession;
24 class SpdySession;
26 class NET_EXPORT_PRIVATE HttpStreamFactoryImpl : public HttpStreamFactory {
27 public:
28 // RequestStream may only be called if |for_websockets| is false.
29 // RequestWebSocketHandshakeStream may only be called if |for_websockets|
30 // is true.
31 HttpStreamFactoryImpl(HttpNetworkSession* session, bool for_websockets);
32 virtual ~HttpStreamFactoryImpl();
34 // HttpStreamFactory interface
35 virtual HttpStreamRequest* RequestStream(
36 const HttpRequestInfo& info,
37 RequestPriority priority,
38 const SSLConfig& server_ssl_config,
39 const SSLConfig& proxy_ssl_config,
40 HttpStreamRequest::Delegate* delegate,
41 const BoundNetLog& net_log) OVERRIDE;
43 virtual HttpStreamRequest* RequestWebSocketHandshakeStream(
44 const HttpRequestInfo& info,
45 RequestPriority priority,
46 const SSLConfig& server_ssl_config,
47 const SSLConfig& proxy_ssl_config,
48 HttpStreamRequest::Delegate* delegate,
49 WebSocketHandshakeStreamBase::CreateHelper* create_helper,
50 const BoundNetLog& net_log) OVERRIDE;
52 virtual void PreconnectStreams(int num_streams,
53 const HttpRequestInfo& info,
54 RequestPriority priority,
55 const SSLConfig& server_ssl_config,
56 const SSLConfig& proxy_ssl_config) OVERRIDE;
57 virtual const HostMappingRules* GetHostMappingRules() const OVERRIDE;
59 size_t num_orphaned_jobs() const { return orphaned_job_set_.size(); }
61 private:
62 FRIEND_TEST_ALL_PREFIXES(HttpStreamFactoryImplRequestTest, SetPriority);
64 class NET_EXPORT_PRIVATE Request;
65 class NET_EXPORT_PRIVATE Job;
67 typedef std::set<Request*> RequestSet;
68 typedef std::map<SpdySessionKey, RequestSet> SpdySessionRequestMap;
70 HttpStreamRequest* RequestStreamInternal(
71 const HttpRequestInfo& info,
72 RequestPriority priority,
73 const SSLConfig& server_ssl_config,
74 const SSLConfig& proxy_ssl_config,
75 HttpStreamRequest::Delegate* delegate,
76 WebSocketHandshakeStreamBase::CreateHelper* create_helper,
77 const BoundNetLog& net_log);
79 AlternateProtocolInfo GetAlternateProtocolRequestFor(
80 const GURL& original_url,
81 GURL* alternate_url);
83 // Detaches |job| from |request|.
84 void OrphanJob(Job* job, const Request* request);
86 // Called when a SpdySession is ready. It will find appropriate Requests and
87 // fulfill them. |direct| indicates whether or not |spdy_session| uses a
88 // proxy.
89 void OnNewSpdySessionReady(const base::WeakPtr<SpdySession>& spdy_session,
90 bool direct,
91 const SSLConfig& used_ssl_config,
92 const ProxyInfo& used_proxy_info,
93 bool was_npn_negotiated,
94 NextProto protocol_negotiated,
95 bool using_spdy,
96 const BoundNetLog& net_log);
98 // Called when the Job detects that the endpoint indicated by the
99 // Alternate-Protocol does not work. Lets the factory update
100 // HttpAlternateProtocols with the failure and resets the SPDY session key.
101 void OnBrokenAlternateProtocol(const Job*, const HostPortPair& origin);
103 // Invoked when an orphaned Job finishes.
104 void OnOrphanedJobComplete(const Job* job);
106 // Invoked when the Job finishes preconnecting sockets.
107 void OnPreconnectsComplete(const Job* job);
109 // Called when the Preconnect completes. Used for testing.
110 virtual void OnPreconnectsCompleteInternal() {}
112 HttpNetworkSession* const session_;
114 // All Requests are handed out to clients. By the time HttpStreamFactoryImpl
115 // is destroyed, all Requests should be deleted (which should remove them from
116 // |request_map_|. The Requests will delete the corresponding job.
117 std::map<const Job*, Request*> request_map_;
119 SpdySessionRequestMap spdy_session_request_map_;
121 // These jobs correspond to jobs orphaned by Requests and now owned by
122 // HttpStreamFactoryImpl. Since they are no longer tied to Requests, they will
123 // not be canceled when Requests are canceled. Therefore, in
124 // ~HttpStreamFactoryImpl, it is possible for some jobs to still exist in this
125 // set. Leftover jobs will be deleted when the factory is destroyed.
126 std::set<const Job*> orphaned_job_set_;
128 // These jobs correspond to preconnect requests and have no associated Request
129 // object. They're owned by HttpStreamFactoryImpl. Leftover jobs will be
130 // deleted when the factory is destroyed.
131 std::set<const Job*> preconnect_job_set_;
133 const bool for_websockets_;
134 DISALLOW_COPY_AND_ASSIGN(HttpStreamFactoryImpl);
137 } // namespace net
139 #endif // NET_HTTP_HTTP_STREAM_FACTORY_IMPL_H_