blob: ba1786104df03fb39afc46eb6e09f9515f3987c8 [file]
// Copyright 2016 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef NET_NQE_SOCKET_WATCHER_FACTORY_H_
#define NET_NQE_SOCKET_WATCHER_FACTORY_H_
#include <memory>
#include <optional>
#include "base/functional/callback.h"
#include "base/memory/raw_ptr.h"
#include "base/memory/scoped_refptr.h"
#include "base/sequence_checker.h"
#include "base/task/single_thread_task_runner.h"
#include "base/time/time.h"
#include "net/nqe/network_quality_estimator_util.h"
#include "net/socket/socket_performance_watcher.h"
#include "net/socket/socket_performance_watcher_factory.h"
namespace base {
class TickClock;
class TimeDelta;
} // namespace base
namespace net {
namespace {
typedef base::RepeatingCallback<void(
SocketPerformanceWatcherFactory::Protocol protocol,
const base::TimeDelta& rtt,
const std::optional<nqe::internal::IPHash>& host)>
OnUpdatedRTTAvailableCallback;
typedef base::RepeatingCallback<bool(base::TimeTicks)> ShouldNotifyRTTCallback;
} // namespace
namespace nqe::internal {
// SocketWatcherFactory implements SocketPerformanceWatcherFactory.
// SocketWatcherFactory is thread safe.
class SocketWatcherFactory : public SocketPerformanceWatcherFactory {
public:
// Creates a SocketWatcherFactory. All socket watchers created by
// SocketWatcherFactory call `updated_rtt_observation_callback` on
// `task_runner` every time a new RTT observation is available.
// `min_notification_interval` is the minimum interval between consecutive
// notifications to the socket watchers created by this factory. `tick_clock`
// is guaranteed to be non-null. `should_notify_rtt_callback` is the callback
// that should be called back on `task_runner` to check if RTT observation
// should be taken and notified.
SocketWatcherFactory(
scoped_refptr<base::SingleThreadTaskRunner> task_runner,
base::TimeDelta min_notification_interval,
OnUpdatedRTTAvailableCallback updated_rtt_observation_callback,
ShouldNotifyRTTCallback should_notify_rtt_callback,
const base::TickClock* tick_clock);
SocketWatcherFactory(const SocketWatcherFactory&) = delete;
SocketWatcherFactory& operator=(const SocketWatcherFactory&) = delete;
~SocketWatcherFactory() override;
// SocketPerformanceWatcherFactory implementation:
std::unique_ptr<SocketPerformanceWatcher> CreateSocketPerformanceWatcher(
const Protocol protocol,
const IPAddress& address) override;
void SetUseLocalHostRequestsForTesting(bool use_localhost_requests) {
allow_rtt_private_address_ = use_localhost_requests;
}
// Overrides the tick clock used by `this` for testing.
void SetTickClockForTesting(const base::TickClock* tick_clock);
private:
scoped_refptr<base::SingleThreadTaskRunner> task_runner_;
// Minimum interval betweeen consecutive notifications to the socket watchers
// created by this factory.
const base::TimeDelta min_notification_interval_;
// True if socket watchers constructed by this factory can use the RTT from
// the sockets that are connected to the private addresses.
bool allow_rtt_private_address_ = false;
// Called every time a new RTT observation is available.
OnUpdatedRTTAvailableCallback updated_rtt_observation_callback_;
// Callback that should be called by socket watchers to determine if the RTT
// notification should be notified using `updated_rtt_observation_callback_`.
ShouldNotifyRTTCallback should_notify_rtt_callback_;
raw_ptr<const base::TickClock> tick_clock_;
};
} // namespace nqe::internal
} // namespace net
#endif // NET_NQE_SOCKET_WATCHER_FACTORY_H_