OLD | NEW |
---|---|
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 //////////////////////////////////////////////////////////////////////////////// | 5 //////////////////////////////////////////////////////////////////////////////// |
6 // Threading considerations: | 6 // Threading considerations: |
7 // | 7 // |
8 // This class is designed to meet various threading guarantees starting from the | 8 // This class is designed to meet various threading guarantees starting from the |
9 // ones imposed by NetworkChangeNotifier: | 9 // ones imposed by NetworkChangeNotifier: |
10 // - The notifier can be constructed on any thread. | 10 // - The notifier can be constructed on any thread. |
(...skipping 41 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
52 // delegate then forwards these notifications to the threads of each observer | 52 // delegate then forwards these notifications to the threads of each observer |
53 // (network change notifier). The network change notifier than processes the | 53 // (network change notifier). The network change notifier than processes the |
54 // state change, and notifies each of its observers on their threads. | 54 // state change, and notifies each of its observers on their threads. |
55 // | 55 // |
56 // This can also be seen as: | 56 // This can also be seen as: |
57 // Android platform -> NetworkChangeNotifier (Java) -> | 57 // Android platform -> NetworkChangeNotifier (Java) -> |
58 // NetworkChangeNotifierDelegateAndroid -> NetworkChangeNotifierAndroid. | 58 // NetworkChangeNotifierDelegateAndroid -> NetworkChangeNotifierAndroid. |
59 | 59 |
60 #include "net/android/network_change_notifier_android.h" | 60 #include "net/android/network_change_notifier_android.h" |
61 | 61 |
62 #include "base/memory/weak_ptr.h" | |
63 #include "base/single_thread_task_runner.h" | |
64 #include "base/thread_task_runner_handle.h" | |
62 #include "base/threading/thread.h" | 65 #include "base/threading/thread.h" |
63 #include "net/base/address_tracker_linux.h" | 66 #include "net/base/address_tracker_linux.h" |
64 #include "net/dns/dns_config_service_posix.h" | 67 #include "net/dns/dns_config_service_posix.h" |
65 | 68 |
66 namespace net { | 69 namespace net { |
67 | 70 |
68 // Thread on which we can run DnsConfigService, which requires a TYPE_IO | 71 // Thread on which we can run DnsConfigService, which requires a TYPE_IO |
69 // message loop to monitor /system/etc/hosts. | 72 // message loop to monitor /system/etc/hosts. |
70 class NetworkChangeNotifierAndroid::DnsConfigServiceThread | 73 class NetworkChangeNotifierAndroid::DnsConfigServiceThread |
71 : public base::Thread, | 74 : public base::Thread, |
72 public NetworkChangeNotifier::NetworkChangeObserver { | 75 public NetworkChangeNotifier::NetworkChangeObserver { |
73 public: | 76 public: |
74 DnsConfigServiceThread(const DnsConfig* dns_config_for_testing) | 77 DnsConfigServiceThread(const DnsConfig* dns_config_for_testing) |
75 : base::Thread("DnsConfigService"), | 78 : base::Thread("DnsConfigService"), |
79 calling_task_runner_(base::ThreadTaskRunnerHandle::Get()), | |
76 dns_config_for_testing_(dns_config_for_testing), | 80 dns_config_for_testing_(dns_config_for_testing), |
77 creation_time_(base::Time::Now()), | 81 creation_time_(base::Time::Now()), |
78 address_tracker_(base::Bind(base::DoNothing), | 82 address_tracker_(base::Bind(base::DoNothing), |
79 base::Bind(base::DoNothing), | 83 base::Bind(base::DoNothing), |
80 // We're only interested in tunnel interface changes. | 84 // We're only interested in tunnel interface changes. |
81 base::Bind(NotifyNetworkChangeNotifierObservers)) {} | 85 base::Bind(NotifyNetworkChangeNotifierObservers)), |
86 weak_ptr_factory_(this) { | |
87 weak_ptr_ = weak_ptr_factory_.GetWeakPtr(); | |
88 } | |
82 | 89 |
83 ~DnsConfigServiceThread() override { | 90 ~DnsConfigServiceThread() override { |
84 NetworkChangeNotifier::RemoveNetworkChangeObserver(this); | 91 NetworkChangeNotifier::RemoveNetworkChangeObserver(this); |
85 Stop(); | 92 Stop(); |
86 } | 93 } |
87 | 94 |
88 void InitAfterStart() { | 95 void InitAfterStart() { |
89 DCHECK(IsRunning()); | 96 DCHECK(IsRunning()); |
90 NetworkChangeNotifier::AddNetworkChangeObserver(this); | 97 NetworkChangeNotifier::AddNetworkChangeObserver(this); |
91 } | 98 } |
92 | 99 |
93 void Init() override { | 100 void Init() override { |
94 address_tracker_.Init(); | 101 address_tracker_.Init(); |
95 dns_config_service_.reset(new internal::DnsConfigServicePosix()); | 102 dns_config_service_.reset(new internal::DnsConfigServicePosix()); |
96 if (dns_config_for_testing_) | 103 if (dns_config_for_testing_) |
97 dns_config_service_->SetDnsConfigForTesting(dns_config_for_testing_); | 104 dns_config_service_->SetDnsConfigForTesting(dns_config_for_testing_); |
98 dns_config_service_->WatchConfig( | 105 dns_config_service_->WatchConfig( |
99 base::Bind(&DnsConfigServiceThread::DnsConfigChangeCallback, | 106 base::Bind(&DnsConfigServiceThread::DnsConfigChangeCallback, |
100 base::Unretained(this))); | 107 base::Unretained(this))); |
108 calling_task_runner_->PostTask( | |
109 FROM_HERE, | |
110 base::Bind(&DnsConfigServiceThread::InitAfterStart, weak_ptr_)); | |
pauljensen
2015/05/01 11:54:44
This is not good. This will allow changes to esca
kinuko
2015/05/01 13:58:05
Ok thanks, I suspected it might be the case. I can
| |
101 } | 111 } |
102 | 112 |
103 void CleanUp() override { dns_config_service_.reset(); } | 113 void CleanUp() override { dns_config_service_.reset(); } |
104 | 114 |
105 static void NotifyNetworkChangeNotifierObservers() { | 115 static void NotifyNetworkChangeNotifierObservers() { |
106 NetworkChangeNotifier::NotifyObserversOfIPAddressChange(); | 116 NetworkChangeNotifier::NotifyObserversOfIPAddressChange(); |
107 NetworkChangeNotifier::NotifyObserversOfConnectionTypeChange(); | 117 NetworkChangeNotifier::NotifyObserversOfConnectionTypeChange(); |
108 } | 118 } |
109 | 119 |
110 private: | 120 private: |
111 void DnsConfigChangeCallback(const DnsConfig& config) { | 121 void DnsConfigChangeCallback(const DnsConfig& config) { |
112 DCHECK(task_runner()->BelongsToCurrentThread()); | 122 DCHECK(task_runner()->BelongsToCurrentThread()); |
113 if (dns_config_service_->SeenChangeSince(creation_time_)) { | 123 if (dns_config_service_->SeenChangeSince(creation_time_)) { |
114 NetworkChangeNotifier::SetDnsConfig(config); | 124 NetworkChangeNotifier::SetDnsConfig(config); |
115 } else { | 125 } else { |
116 NetworkChangeNotifier::SetInitialDnsConfig(config); | 126 NetworkChangeNotifier::SetInitialDnsConfig(config); |
117 } | 127 } |
118 } | 128 } |
119 | 129 |
120 // NetworkChangeNotifier::NetworkChangeObserver implementation: | 130 // NetworkChangeNotifier::NetworkChangeObserver implementation: |
121 void OnNetworkChanged(NetworkChangeNotifier::ConnectionType type) override { | 131 void OnNetworkChanged(NetworkChangeNotifier::ConnectionType type) override { |
122 task_runner()->PostTask( | 132 task_runner()->PostTask( |
123 FROM_HERE, | 133 FROM_HERE, |
124 base::Bind(&internal::DnsConfigServicePosix::OnNetworkChanged, | 134 base::Bind(&internal::DnsConfigServicePosix::OnNetworkChanged, |
125 base::Unretained(dns_config_service_.get()), type)); | 135 base::Unretained(dns_config_service_.get()), type)); |
126 } | 136 } |
127 | 137 |
138 scoped_refptr<base::SingleThreadTaskRunner> calling_task_runner_; | |
128 const DnsConfig* dns_config_for_testing_; | 139 const DnsConfig* dns_config_for_testing_; |
129 const base::Time creation_time_; | 140 const base::Time creation_time_; |
130 scoped_ptr<internal::DnsConfigServicePosix> dns_config_service_; | 141 scoped_ptr<internal::DnsConfigServicePosix> dns_config_service_; |
131 // Used to detect tunnel state changes. | 142 // Used to detect tunnel state changes. |
132 internal::AddressTrackerLinux address_tracker_; | 143 internal::AddressTrackerLinux address_tracker_; |
133 | 144 |
145 // Used only on the calling thread that created this thread. | |
146 base::WeakPtr<DnsConfigServiceThread> weak_ptr_; | |
147 base::WeakPtrFactory<DnsConfigServiceThread> weak_ptr_factory_; | |
148 | |
134 DISALLOW_COPY_AND_ASSIGN(DnsConfigServiceThread); | 149 DISALLOW_COPY_AND_ASSIGN(DnsConfigServiceThread); |
135 }; | 150 }; |
136 | 151 |
137 NetworkChangeNotifierAndroid::~NetworkChangeNotifierAndroid() { | 152 NetworkChangeNotifierAndroid::~NetworkChangeNotifierAndroid() { |
138 delegate_->RemoveObserver(this); | 153 delegate_->RemoveObserver(this); |
139 } | 154 } |
140 | 155 |
141 NetworkChangeNotifier::ConnectionType | 156 NetworkChangeNotifier::ConnectionType |
142 NetworkChangeNotifierAndroid::GetCurrentConnectionType() const { | 157 NetworkChangeNotifierAndroid::GetCurrentConnectionType() const { |
143 return delegate_->GetCurrentConnectionType(); | 158 return delegate_->GetCurrentConnectionType(); |
(...skipping 21 matching lines...) Expand all Loading... | |
165 NetworkChangeNotifierAndroid::NetworkChangeNotifierAndroid( | 180 NetworkChangeNotifierAndroid::NetworkChangeNotifierAndroid( |
166 NetworkChangeNotifierDelegateAndroid* delegate, | 181 NetworkChangeNotifierDelegateAndroid* delegate, |
167 const DnsConfig* dns_config_for_testing) | 182 const DnsConfig* dns_config_for_testing) |
168 : NetworkChangeNotifier(NetworkChangeCalculatorParamsAndroid()), | 183 : NetworkChangeNotifier(NetworkChangeCalculatorParamsAndroid()), |
169 delegate_(delegate), | 184 delegate_(delegate), |
170 dns_config_service_thread_( | 185 dns_config_service_thread_( |
171 new DnsConfigServiceThread(dns_config_for_testing)) { | 186 new DnsConfigServiceThread(dns_config_for_testing)) { |
172 delegate_->AddObserver(this); | 187 delegate_->AddObserver(this); |
173 dns_config_service_thread_->StartWithOptions( | 188 dns_config_service_thread_->StartWithOptions( |
174 base::Thread::Options(base::MessageLoop::TYPE_IO, 0)); | 189 base::Thread::Options(base::MessageLoop::TYPE_IO, 0)); |
175 dns_config_service_thread_->InitAfterStart(); | |
176 } | 190 } |
177 | 191 |
178 // static | 192 // static |
179 NetworkChangeNotifier::NetworkChangeCalculatorParams | 193 NetworkChangeNotifier::NetworkChangeCalculatorParams |
180 NetworkChangeNotifierAndroid::NetworkChangeCalculatorParamsAndroid() { | 194 NetworkChangeNotifierAndroid::NetworkChangeCalculatorParamsAndroid() { |
181 NetworkChangeCalculatorParams params; | 195 NetworkChangeCalculatorParams params; |
182 // IPAddressChanged is produced immediately prior to ConnectionTypeChanged | 196 // IPAddressChanged is produced immediately prior to ConnectionTypeChanged |
183 // so delay IPAddressChanged so they get merged with the following | 197 // so delay IPAddressChanged so they get merged with the following |
184 // ConnectionTypeChanged signal. | 198 // ConnectionTypeChanged signal. |
185 params.ip_address_offline_delay_ = base::TimeDelta::FromSeconds(1); | 199 params.ip_address_offline_delay_ = base::TimeDelta::FromSeconds(1); |
186 params.ip_address_online_delay_ = base::TimeDelta::FromSeconds(1); | 200 params.ip_address_online_delay_ = base::TimeDelta::FromSeconds(1); |
187 params.connection_type_offline_delay_ = base::TimeDelta::FromSeconds(0); | 201 params.connection_type_offline_delay_ = base::TimeDelta::FromSeconds(0); |
188 params.connection_type_online_delay_ = base::TimeDelta::FromSeconds(0); | 202 params.connection_type_online_delay_ = base::TimeDelta::FromSeconds(0); |
189 return params; | 203 return params; |
190 } | 204 } |
191 | 205 |
192 } // namespace net | 206 } // namespace net |
OLD | NEW |