blob: e895d03552f38b143e6692d76a1da21b19c433ec [file] [log] [blame]
// Copyright 2017 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_NQE_RTT_THROUGHPUT_ESTIMATES_OBSERVER_H_
#define NET_NQE_RTT_THROUGHPUT_ESTIMATES_OBSERVER_H_
#include "base/compiler_specific.h"
#include "base/macros.h"
#include "base/time/time.h"
#include "net/base/net_export.h"
#include "starboard/types.h"
namespace net {
// Observes changes in the network quality.
class NET_EXPORT RTTAndThroughputEstimatesObserver {
public:
// Notifies the observer when estimated HTTP RTT, estimated transport RTT or
// estimated downstream throughput is computed. NetworkQualityEstimator
// computes the RTT and throughput estimates at regular intervals.
// Additionally, when there is a change in the connection type of the
// device, then the estimates are immediately computed.
//
// |http_rtt|, |transport_rtt| and |downstream_throughput_kbps| are the
// computed estimates of the HTTP RTT, transport RTT and downstream
// throughput (in kilobits per second), respectively. If an estimate of the
// HTTP or transport RTT is unavailable, it will be set to
// nqe::internal::InvalidRTT(). If the throughput estimate is unavailable,
// it will be set to nqe::internal::INVALID_RTT_THROUGHPUT.
virtual void OnRTTOrThroughputEstimatesComputed(
base::TimeDelta http_rtt,
base::TimeDelta transport_rtt,
int32_t downstream_throughput_kbps) = 0;
virtual ~RTTAndThroughputEstimatesObserver() {}
protected:
RTTAndThroughputEstimatesObserver() {}
private:
DISALLOW_COPY_AND_ASSIGN(RTTAndThroughputEstimatesObserver);
};
} // namespace net
#endif // NET_NQE_RTT_THROUGHPUT_ESTIMATES_OBSERVER_H_