| Index: chrome/browser/net/nqe/ui_network_quality_estimator_service.h
|
| diff --git a/chrome/browser/net/nqe/ui_network_quality_estimator_service.h b/chrome/browser/net/nqe/ui_network_quality_estimator_service.h
|
| index 9d336f4f85cfe2fa8e36f417544559fbaab3d12e..324e37b7a398b0d09e3759b584376d025be2e003 100644
|
| --- a/chrome/browser/net/nqe/ui_network_quality_estimator_service.h
|
| +++ b/chrome/browser/net/nqe/ui_network_quality_estimator_service.h
|
| @@ -5,20 +5,35 @@
|
| #ifndef CHROME_BROWSER_NET_NQE_UI_NETWORK_QUALITY_ESTIMATOR_SERVICE_H_
|
| #define CHROME_BROWSER_NET_NQE_UI_NETWORK_QUALITY_ESTIMATOR_SERVICE_H_
|
|
|
| +#include <map>
|
| +#include <memory>
|
| +
|
| #include "base/macros.h"
|
| #include "base/memory/weak_ptr.h"
|
| #include "components/keyed_service/core/keyed_service.h"
|
| +#include "net/nqe/cached_network_quality.h"
|
| #include "net/nqe/effective_connection_type.h"
|
| +#include "net/nqe/network_id.h"
|
| #include "net/nqe/network_quality_estimator.h"
|
|
|
| +class PrefRegistrySimple;
|
| +class Profile;
|
| +
|
| +namespace net {
|
| +class NetworkQualitiesPrefsManager;
|
| +}
|
| +
|
| // UI service to determine the current EffectiveConnectionType.
|
| class UINetworkQualityEstimatorService
|
| : public KeyedService,
|
| public net::NetworkQualityEstimator::NetworkQualityProvider {
|
| public:
|
| - UINetworkQualityEstimatorService();
|
| + explicit UINetworkQualityEstimatorService(Profile* profile);
|
| ~UINetworkQualityEstimatorService() override;
|
|
|
| + // Registers the profile-specific network quality estimator prefs.
|
| + static void RegisterProfilePrefs(PrefRegistrySimple* registry);
|
| +
|
| // The current EffectiveConnectionType.
|
| net::EffectiveConnectionType GetEffectiveConnectionType() const override;
|
|
|
| @@ -26,6 +41,12 @@ class UINetworkQualityEstimatorService
|
| // expect that the EffectiveConnectionType could change.
|
| void SetEffectiveConnectionTypeForTesting(net::EffectiveConnectionType type);
|
|
|
| + // Reads the prefs from the disk, parses them into a map of NetworkIDs and
|
| + // CachedNetworkQualities, and returns the map.
|
| + std::map<net::nqe::internal::NetworkID,
|
| + net::nqe::internal::CachedNetworkQuality>
|
| + ForceReadPrefsForTesting() const;
|
| +
|
| private:
|
| class IONetworkQualityObserver;
|
|
|
| @@ -43,7 +64,11 @@ class UINetworkQualityEstimatorService
|
|
|
| // IO thread based observer that is owned by this service. Created on the UI
|
| // thread, but used and deleted on the IO thread.
|
| - IONetworkQualityObserver* io_observer_;
|
| + std::unique_ptr<IONetworkQualityObserver> io_observer_;
|
| +
|
| + // Prefs manager that is owned by this service. Created on the UI thread, but
|
| + // used and deleted on the IO thread.
|
| + std::unique_ptr<net::NetworkQualitiesPrefsManager> prefs_manager_;
|
|
|
| base::WeakPtrFactory<UINetworkQualityEstimatorService> weak_factory_;
|
|
|
|
|