Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(250)

Unified Diff: net/spdy/spdy_session_pool.h

Issue 992733002: Remove //net (except for Android test stuff) and sdch (Closed) Base URL: git@github.com:domokit/mojo.git@master
Patch Set: Created 5 years, 9 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « net/spdy/spdy_session_key.cc ('k') | net/spdy/spdy_session_pool.cc » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: net/spdy/spdy_session_pool.h
diff --git a/net/spdy/spdy_session_pool.h b/net/spdy/spdy_session_pool.h
deleted file mode 100644
index 32b4ee33bde286a3189d1f2c70d0eade17369065..0000000000000000000000000000000000000000
--- a/net/spdy/spdy_session_pool.h
+++ /dev/null
@@ -1,237 +0,0 @@
-// Copyright (c) 2012 The Chromium Authors. All rights reserved.
-// Use of this source code is governed by a BSD-style license that can be
-// found in the LICENSE file.
-
-#ifndef NET_SPDY_SPDY_SESSION_POOL_H_
-#define NET_SPDY_SPDY_SESSION_POOL_H_
-
-#include <map>
-#include <set>
-#include <string>
-#include <vector>
-
-#include "base/basictypes.h"
-#include "base/gtest_prod_util.h"
-#include "base/memory/ref_counted.h"
-#include "base/memory/weak_ptr.h"
-#include "net/base/host_port_pair.h"
-#include "net/base/ip_endpoint.h"
-#include "net/base/net_errors.h"
-#include "net/base/net_export.h"
-#include "net/base/network_change_notifier.h"
-#include "net/cert/cert_database.h"
-#include "net/proxy/proxy_config.h"
-#include "net/proxy/proxy_server.h"
-#include "net/socket/next_proto.h"
-#include "net/spdy/spdy_session_key.h"
-#include "net/ssl/ssl_config_service.h"
-
-namespace net {
-
-class AddressList;
-class BoundNetLog;
-class ClientSocketHandle;
-class HostResolver;
-class HttpServerProperties;
-class SpdySession;
-class TransportSecurityState;
-
-// This is a very simple pool for open SpdySessions.
-class NET_EXPORT SpdySessionPool
- : public NetworkChangeNotifier::IPAddressObserver,
- public SSLConfigService::Observer,
- public CertDatabase::Observer {
- public:
- typedef base::TimeTicks (*TimeFunc)(void);
-
- // |default_protocol| may be kProtoUnknown (e.g., if SPDY is
- // disabled), in which case it's set to a default value. Otherwise,
- // it must be a SPDY protocol.
- SpdySessionPool(
- HostResolver* host_resolver,
- SSLConfigService* ssl_config_service,
- const base::WeakPtr<HttpServerProperties>& http_server_properties,
- TransportSecurityState* transport_security_state,
- bool force_single_domain,
- bool enable_compression,
- bool enable_ping_based_connection_checking,
- NextProto default_protocol,
- size_t stream_initial_recv_window_size,
- size_t initial_max_concurrent_streams,
- size_t max_concurrent_streams_limit,
- SpdySessionPool::TimeFunc time_func,
- const std::string& trusted_spdy_proxy);
- ~SpdySessionPool() override;
-
- // In the functions below, a session is "available" if this pool has
- // a reference to it and there is some SpdySessionKey for which
- // FindAvailableSession() will return it. A session is "unavailable"
- // if this pool has a reference to it but it won't be returned by
- // FindAvailableSession() for any SpdySessionKey; for example, this
- // can happen when a session receives a GOAWAY frame and is still
- // processing existing streams.
-
- // Create a new SPDY session from an existing socket. There must
- // not already be a session for the given key. This pool must have
- // been constructed with a valid |default_protocol| value.
- //
- // |is_secure| can be false for testing or when SPDY is configured
- // to work with non-secure sockets. If |is_secure| is true,
- // |certificate_error_code| indicates that the certificate error
- // encountered when connecting the SSL socket, with OK meaning there
- // was no error.
- //
- // Returns the new SpdySession. Note that the SpdySession begins reading from
- // |connection| on a subsequent event loop iteration, so it may be closed
- // immediately afterwards if the first read of |connection| fails.
- base::WeakPtr<SpdySession> CreateAvailableSessionFromSocket(
- const SpdySessionKey& key,
- scoped_ptr<ClientSocketHandle> connection,
- const BoundNetLog& net_log,
- int certificate_error_code,
- bool is_secure);
-
- // Find an available session for the given key, or NULL if there isn't one.
- base::WeakPtr<SpdySession> FindAvailableSession(const SpdySessionKey& key,
- const BoundNetLog& net_log);
-
- // Remove all mappings and aliases for the given session, which must
- // still be available. Except for in tests, this must be called by
- // the given session itself.
- void MakeSessionUnavailable(
- const base::WeakPtr<SpdySession>& available_session);
-
- // Removes an unavailable session from the pool. Except for in
- // tests, this must be called by the given session itself.
- void RemoveUnavailableSession(
- const base::WeakPtr<SpdySession>& unavailable_session);
-
- // Close only the currently existing SpdySessions with |error|.
- // Let any new ones created while this method is running continue to
- // live.
- void CloseCurrentSessions(net::Error error);
-
- // Close only the currently existing SpdySessions that are idle.
- // Let any new ones created while this method is running continue to
- // live.
- void CloseCurrentIdleSessions();
-
- // Close all SpdySessions, including any new ones created in the process of
- // closing the current ones.
- void CloseAllSessions();
-
- // Creates a Value summary of the state of the spdy session pool. The caller
- // responsible for deleting the returned value.
- base::Value* SpdySessionPoolInfoToValue() const;
-
- base::WeakPtr<HttpServerProperties> http_server_properties() {
- return http_server_properties_;
- }
-
- // NetworkChangeNotifier::IPAddressObserver methods:
-
- // We flush all idle sessions and release references to the active ones so
- // they won't get re-used. The active ones will either complete successfully
- // or error out due to the IP address change.
- void OnIPAddressChanged() override;
-
- // SSLConfigService::Observer methods:
-
- // We perform the same flushing as described above when SSL settings change.
- void OnSSLConfigChanged() override;
-
- // CertDatabase::Observer methods:
-
- // We perform the same flushing as described above when certificate database
- // is changed.
- void OnCertAdded(const X509Certificate* cert) override;
- void OnCACertChanged(const X509Certificate* cert) override;
-
- private:
- friend class SpdySessionPoolPeer; // For testing.
-
- typedef std::set<SpdySession*> SessionSet;
- typedef std::vector<base::WeakPtr<SpdySession> > WeakSessionList;
- typedef std::map<SpdySessionKey, base::WeakPtr<SpdySession> >
- AvailableSessionMap;
- typedef std::map<IPEndPoint, SpdySessionKey> AliasMap;
-
- // Returns true iff |session| is in |available_sessions_|.
- bool IsSessionAvailable(const base::WeakPtr<SpdySession>& session) const;
-
- // Returns a normalized version of the given key suitable for lookup
- // into |available_sessions_|.
- const SpdySessionKey& NormalizeListKey(const SpdySessionKey& key) const;
-
- // Map the given key to the given session. There must not already be
- // a mapping for |key|.
- void MapKeyToAvailableSession(const SpdySessionKey& key,
- const base::WeakPtr<SpdySession>& session);
-
- // Returns an iterator into |available_sessions_| for the given key,
- // which may be equal to |available_sessions_.end()|.
- AvailableSessionMap::iterator LookupAvailableSessionByKey(
- const SpdySessionKey& key);
-
- // Remove the mapping of the given key, which must exist.
- void UnmapKey(const SpdySessionKey& key);
-
- // Remove all aliases for |key| from the aliases table.
- void RemoveAliases(const SpdySessionKey& key);
-
- // Get a copy of the current sessions as a list of WeakPtrs. Used by
- // CloseCurrentSessionsHelper() below.
- WeakSessionList GetCurrentSessions() const;
-
- // Close only the currently existing SpdySessions with |error|. Let
- // any new ones created while this method is running continue to
- // live. If |idle_only| is true only idle sessions are closed.
- void CloseCurrentSessionsHelper(
- Error error,
- const std::string& description,
- bool idle_only);
-
- const base::WeakPtr<HttpServerProperties> http_server_properties_;
-
- TransportSecurityState* transport_security_state_;
-
- // The set of all sessions. This is a superset of the sessions in
- // |available_sessions_|.
- //
- // |sessions_| owns all its SpdySession objects.
- SessionSet sessions_;
-
- // This is a map of available sessions by key. A session may appear
- // more than once in this map if it has aliases.
- AvailableSessionMap available_sessions_;
-
- // A map of IPEndPoint aliases for sessions.
- AliasMap aliases_;
-
- static bool g_force_single_domain;
-
- const scoped_refptr<SSLConfigService> ssl_config_service_;
- HostResolver* const resolver_;
-
- // Defaults to true. May be controlled via SpdySessionPoolPeer for tests.
- bool verify_domain_authentication_;
- bool enable_sending_initial_data_;
- bool force_single_domain_;
- bool enable_compression_;
- bool enable_ping_based_connection_checking_;
- const NextProto default_protocol_;
- size_t stream_initial_recv_window_size_;
- size_t initial_max_concurrent_streams_;
- size_t max_concurrent_streams_limit_;
- TimeFunc time_func_;
-
- // This SPDY proxy is allowed to push resources from origins that are
- // different from those of their associated streams.
- HostPortPair trusted_spdy_proxy_;
-
- DISALLOW_COPY_AND_ASSIGN(SpdySessionPool);
-};
-
-} // namespace net
-
-#endif // NET_SPDY_SPDY_SESSION_POOL_H_
« no previous file with comments | « net/spdy/spdy_session_key.cc ('k') | net/spdy/spdy_session_pool.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698