// 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. #include "components/cryptauth/bluetooth_throttler_impl.h" #include #include "base/memory/ptr_util.h" #include "base/stl_util.h" #include "base/time/default_tick_clock.h" #include "base/time/tick_clock.h" #include "components/cryptauth/connection.h" namespace cryptauth { namespace { // Time to wait after disconnect before reconnecting. const int kCooldownTimeSecs = 1; } // namespace // static BluetoothThrottlerImpl* BluetoothThrottlerImpl::GetInstance() { return base::Singleton::get(); } BluetoothThrottlerImpl::BluetoothThrottlerImpl() : BluetoothThrottlerImpl(base::MakeUnique()) {} BluetoothThrottlerImpl::BluetoothThrottlerImpl( std::unique_ptr clock) : clock_(std::move(clock)) {} BluetoothThrottlerImpl::~BluetoothThrottlerImpl() { for (Connection* connection : connections_) { connection->RemoveObserver(this); } } base::TimeDelta BluetoothThrottlerImpl::GetDelay() const { if (last_disconnect_time_.is_null()) return base::TimeDelta(); base::TimeTicks now = clock_->NowTicks(); base::TimeTicks throttled_start_time = last_disconnect_time_ + GetCooldownTimeDelta(); if (now >= throttled_start_time) return base::TimeDelta(); return throttled_start_time - now; } void BluetoothThrottlerImpl::OnConnection(Connection* connection) { DCHECK(!base::ContainsKey(connections_, connection)); connections_.insert(connection); connection->AddObserver(this); } base::TimeDelta BluetoothThrottlerImpl::GetCooldownTimeDelta() const { return base::TimeDelta::FromSeconds(kCooldownTimeSecs); } void BluetoothThrottlerImpl::OnConnectionStatusChanged( Connection* connection, Connection::Status old_status, Connection::Status new_status) { DCHECK(base::ContainsKey(connections_, connection)); if (new_status == Connection::DISCONNECTED) { last_disconnect_time_ = clock_->NowTicks(); connection->RemoveObserver(this); connections_.erase(connection); } } } // namespace cryptauth