blob: 588a4a871c8be0edcbf83d2d09bd23a1d27337e0 [file] [log] [blame]
// Copyright 2015 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 REMOTING_PROTOCOL_TRANSPORT_CONTEXT_H_
#define REMOTING_PROTOCOL_TRANSPORT_CONTEXT_H_
#include <list>
#include <memory>
#include <string>
#include "base/macros.h"
#include "base/memory/ref_counted.h"
#include "base/time/time.h"
#include "remoting/protocol/ice_config.h"
#include "remoting/protocol/network_settings.h"
#include "remoting/protocol/transport.h"
namespace network {
class SharedURLLoaderFactory;
} // namespace network
namespace rtc {
class NetworkManager;
} // namespace rtc
namespace remoting {
namespace protocol {
class PortAllocatorFactory;
class IceConfigRequest;
// TransportContext is responsible for storing all parameters required for
// P2P transport initialization. It's also responsible for fetching STUN and
// TURN configuration.
class TransportContext : public base::RefCountedThreadSafe<TransportContext> {
public:
typedef base::OnceCallback<void(const IceConfig& ice_config)>
GetIceConfigCallback;
static scoped_refptr<TransportContext> ForTests(TransportRole role);
TransportContext(
std::unique_ptr<PortAllocatorFactory> port_allocator_factory,
scoped_refptr<network::SharedURLLoaderFactory> url_loader_factory,
const NetworkSettings& network_settings,
TransportRole role);
void set_turn_ice_config(const IceConfig& ice_config) {
// If an external entity is providing the ICE Config, then disable the
// local caching logic and use the provided config.
//
// Note: Using this method to provide a config means the caller is
// responsible for ensuring the ICE config's validity and freshness.
last_request_completion_time_ = base::Time::Max();
ice_config_ = ice_config;
}
// Sets a reference to the NetworkManager that holds the list of
// network interfaces. If the NetworkManager is deleted while this
// TransportContext is live, the caller should set this to nullptr.
// TODO(crbug.com/848045): This should be a singleton - either a global
// instance, or one that is owned by this TransportContext.
void set_network_manager(rtc::NetworkManager* network_manager) {
network_manager_ = network_manager;
}
// Prepares fresh ICE configs. It may be called while connection is being
// negotiated to minimize the chance that the following GetIceConfig() will
// be blocking.
void Prepare();
// Requests fresh STUN and TURN information.
void GetIceConfig(GetIceConfigCallback callback);
PortAllocatorFactory* port_allocator_factory() {
return port_allocator_factory_.get();
}
const NetworkSettings& network_settings() const { return network_settings_; }
TransportRole role() const { return role_; }
rtc::NetworkManager* network_manager() const { return network_manager_; }
// Returns the suggested bandwidth cap for TURN relay connections, or 0 if
// no rate-limit is set in the IceConfig.
int GetTurnMaxRateKbps() const;
private:
friend class base::RefCountedThreadSafe<TransportContext>;
~TransportContext();
void EnsureFreshIceConfig();
void OnIceConfig(const IceConfig& ice_config);
std::unique_ptr<PortAllocatorFactory> port_allocator_factory_;
scoped_refptr<network::SharedURLLoaderFactory> url_loader_factory_;
NetworkSettings network_settings_;
TransportRole role_;
rtc::NetworkManager* network_manager_ = nullptr;
IceConfig ice_config_;
base::Time last_request_completion_time_;
std::unique_ptr<IceConfigRequest> ice_config_request_;
// Called once |ice_config_request_| completes.
std::list<GetIceConfigCallback> pending_ice_config_callbacks_;
DISALLOW_COPY_AND_ASSIGN(TransportContext);
};
} // namespace protocol
} // namespace remoting
#endif // REMOTING_PROTOCOL_TRANSPORT_CONTEXT_H_