This is a no-op change because rtc::Optional is an alias to absl::optional
This CL generated by running script with parameters 'media ortc p2p':
find $@ -type f \( -name \*.h -o -name \*.cc \) \
-exec sed -i 's|rtc::Optional|absl::optional|g' {} \+ \
-exec sed -i 's|rtc::nullopt|absl::nullopt|g' {} \+ \
-exec sed -i 's|#include "api/optional.h"|#include "absl/types/optional.h"|' {} \+
find $@ -type f -name BUILD.gn \
-exec sed -r -i 's|"(../)*api:optional"|"//third_party/abseil-cpp/absl/types:optional"|' {} \+;
git cl format
Bug: webrtc:9078
Change-Id: I19167714af7cc1436d34cfcba6c8b3718d8e677b
Reviewed-on: https://webrtc-review.googlesource.com/83731
Reviewed-by: Karl Wiberg <kwiberg@webrtc.org>
Commit-Queue: Danil Chapovalov <danilchap@webrtc.org>
Cr-Commit-Position: refs/heads/master@{#23638}
125 lines
5.8 KiB
C++
125 lines
5.8 KiB
C++
/*
|
|
* Copyright 2018 The WebRTC Project Authors. All rights reserved.
|
|
*
|
|
* Use of this source code is governed by a BSD-style license
|
|
* that can be found in the LICENSE file in the root of the source
|
|
* tree. An additional intellectual property rights grant can be found
|
|
* in the file PATENTS. All contributing project authors may
|
|
* be found in the AUTHORS file in the root of the source tree.
|
|
*/
|
|
|
|
#ifndef P2P_BASE_REGATHERINGCONTROLLER_H_
|
|
#define P2P_BASE_REGATHERINGCONTROLLER_H_
|
|
|
|
#include "p2p/base/icetransportinternal.h"
|
|
#include "p2p/base/portallocator.h"
|
|
#include "rtc_base/asyncinvoker.h"
|
|
#include "rtc_base/random.h"
|
|
#include "rtc_base/thread.h"
|
|
|
|
namespace webrtc {
|
|
|
|
// Controls regathering of candidates for the ICE transport passed into it,
|
|
// reacting to signals like SignalWritableState, SignalNetworkRouteChange, etc.,
|
|
// using methods like GetStats to get additional information, and calling
|
|
// methods like RegatherOnAllNetworks on the PortAllocatorSession when
|
|
// regathering is desired.
|
|
//
|
|
// TODO(qingsi): Add the description of behavior when autonomous regathering is
|
|
// implemented.
|
|
//
|
|
// "Regathering" is defined as gathering additional candidates within a single
|
|
// ICE generation (or in other words, PortAllocatorSession), and is possible
|
|
// when "continual gathering" is enabled. This may allow connectivity to be
|
|
// maintained and/or restored without a full ICE restart.
|
|
//
|
|
// Regathering will only begin after PortAllocationSession is set via
|
|
// set_allocator_session. This should be called any time the "active"
|
|
// PortAllocatorSession is changed (in other words, when an ICE restart occurs),
|
|
// so that candidates are gathered for the "current" ICE generation.
|
|
//
|
|
// All methods of BasicRegatheringController should be called on the same
|
|
// thread as the one passed to the constructor, and this thread should be the
|
|
// same one where PortAllocatorSession runs, which is also identical to the
|
|
// network thread of the ICE transport, as given by
|
|
// P2PTransportChannel::thread().
|
|
class BasicRegatheringController : public sigslot::has_slots<> {
|
|
public:
|
|
struct Config {
|
|
Config(const absl::optional<rtc::IntervalRange>&
|
|
regather_on_all_networks_interval_range,
|
|
int regather_on_failed_networks_interval);
|
|
Config(const Config& other);
|
|
~Config();
|
|
Config& operator=(const Config& other);
|
|
absl::optional<rtc::IntervalRange> regather_on_all_networks_interval_range;
|
|
int regather_on_failed_networks_interval;
|
|
};
|
|
|
|
BasicRegatheringController() = delete;
|
|
BasicRegatheringController(const Config& config,
|
|
cricket::IceTransportInternal* ice_transport,
|
|
rtc::Thread* thread);
|
|
~BasicRegatheringController() override;
|
|
// TODO(qingsi): Remove this method after implementing a new signal in
|
|
// P2PTransportChannel and reacting to that signal for the initial schedules
|
|
// of regathering.
|
|
void Start();
|
|
void set_allocator_session(cricket::PortAllocatorSession* allocator_session) {
|
|
allocator_session_ = allocator_session;
|
|
}
|
|
// Setting a different config of the regathering interval range on all
|
|
// networks cancels and reschedules the recurring schedules, if any, of
|
|
// regathering on all networks. The same applies to the change of the
|
|
// regathering interval on the failed networks. This rescheduling behavior is
|
|
// seperately defined for the two config parameters.
|
|
void SetConfig(const Config& config);
|
|
|
|
private:
|
|
// TODO(qingsi): Implement the following methods and use methods from the ICE
|
|
// transport like GetStats to get additional information for the decision
|
|
// making in regathering.
|
|
void OnIceTransportStateChanged(cricket::IceTransportInternal*) {}
|
|
void OnIceTransportWritableState(rtc::PacketTransportInternal*) {}
|
|
void OnIceTransportReceivingState(rtc::PacketTransportInternal*) {}
|
|
void OnIceTransportNetworkRouteChanged(absl::optional<rtc::NetworkRoute>) {}
|
|
// Schedules delayed and repeated regathering of local candidates on all
|
|
// networks, where the delay in milliseconds is randomly sampled from the
|
|
// range in the config. The delay of each repetition is independently sampled
|
|
// from the same range. When scheduled, all previous schedules are canceled.
|
|
void ScheduleRecurringRegatheringOnAllNetworks();
|
|
// Schedules delayed and repeated regathering of local candidates on failed
|
|
// networks, where the delay in milliseconds is given by the config. Each
|
|
// repetition is separated by the same delay. When scheduled, all previous
|
|
// schedules are canceled.
|
|
void ScheduleRecurringRegatheringOnFailedNetworks();
|
|
// Cancels regathering scheduled by ScheduleRecurringRegatheringOnAllNetworks.
|
|
void CancelScheduledRecurringRegatheringOnAllNetworks();
|
|
// Cancels regathering scheduled by
|
|
// ScheduleRecurringRegatheringOnFailedNetworks.
|
|
void CancelScheduledRecurringRegatheringOnFailedNetworks();
|
|
|
|
rtc::Thread* thread() const { return thread_; }
|
|
// The following two methods perform the actual regathering, if the recent
|
|
// port allocator session has done the initial gathering.
|
|
void RegatherOnAllNetworksIfDoneGathering(bool repeated);
|
|
void RegatherOnFailedNetworksIfDoneGathering(bool repeated);
|
|
// Samples a delay from the uniform distribution in the given range.
|
|
int SampleRegatherAllNetworksInterval(const rtc::IntervalRange& range);
|
|
|
|
Config config_;
|
|
cricket::IceTransportInternal* ice_transport_;
|
|
cricket::PortAllocatorSession* allocator_session_ = nullptr;
|
|
bool has_recurring_schedule_on_all_networks_ = false;
|
|
bool has_recurring_schedule_on_failed_networks_ = false;
|
|
rtc::Thread* thread_;
|
|
rtc::AsyncInvoker invoker_for_all_networks_;
|
|
rtc::AsyncInvoker invoker_for_failed_networks_;
|
|
// Used to generate random intervals for regather_all_networks_interval_range.
|
|
Random rand_;
|
|
};
|
|
|
|
} // namespace webrtc
|
|
|
|
#endif // P2P_BASE_REGATHERINGCONTROLLER_H_
|