// Copyright 2021 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_DNS_DNS_CONFIG_SERVICE_ANDROID_H_ #define NET_DNS_DNS_CONFIG_SERVICE_ANDROID_H_ #include #include "base/time/time.h" #include "net/android/network_library.h" #include "net/base/net_export.h" #include "net/base/network_change_notifier.h" #include "net/dns/dns_config_service.h" namespace net { // Use DnsConfigService::CreateSystemService to use it outside of tests. namespace internal { // Service for reading and watching Android system DNS settings. This object is // not thread-safe and methods may perform blocking I/O so methods must be // called on a sequence that allows blocking (i.e. base::MayBlock). It may be // constructed on a different sequence than which it's later called on. class NET_EXPORT_PRIVATE DnsConfigServiceAndroid : public DnsConfigService, public NetworkChangeNotifier::NetworkChangeObserver { public: static constexpr base::TimeDelta kConfigChangeDelay = base::Milliseconds(50); DnsConfigServiceAndroid(); ~DnsConfigServiceAndroid() override; DnsConfigServiceAndroid(const DnsConfigServiceAndroid&) = delete; DnsConfigServiceAndroid& operator=(const DnsConfigServiceAndroid&) = delete; // To be effective, must be called before the first config read. Also, may // outlive `this` and be run on other sequences. void set_dns_server_getter_for_testing( android::DnsServerGetter dns_server_getter) { dns_server_getter_ = std::move(dns_server_getter); } protected: // DnsConfigService: void ReadConfigNow() override; bool StartWatching() override; private: class ConfigReader; // NetworkChangeNotifier::NetworkChangeObserver: void OnNetworkChanged(NetworkChangeNotifier::ConnectionType type) override; bool is_watching_network_change_ = false; std::unique_ptr config_reader_; android::DnsServerGetter dns_server_getter_; }; } // namespace internal } // namespace net #endif // NET_DNS_DNS_CONFIG_SERVICE_ANDROID_H_