OLD | NEW |
---|---|
1 // Copyright 2014 The Chromium Authors. All rights reserved. | 1 // Copyright 2014 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 #include "chromeos/dbus/peer_daemon_manager_client.h" | 5 #include "chromeos/dbus/peer_daemon_manager_client.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/callback.h" | 8 #include "base/callback.h" |
9 #include "base/logging.h" | 9 #include "base/logging.h" |
10 #include "base/memory/weak_ptr.h" | 10 #include "base/memory/weak_ptr.h" |
11 #include "base/observer_list.h" | |
11 #include "dbus/bus.h" | 12 #include "dbus/bus.h" |
12 #include "dbus/message.h" | 13 #include "dbus/message.h" |
14 #include "dbus/object_manager.h" | |
13 #include "dbus/object_proxy.h" | 15 #include "dbus/object_proxy.h" |
14 #include "dbus/values_util.h" | 16 #include "dbus/values_util.h" |
15 | 17 |
16 namespace chromeos { | 18 namespace chromeos { |
17 namespace { | |
18 | 19 |
19 // TODO(benchan): Move these constants to system_api. | 20 // TODO(benchan): Move these constants to system_api. |
20 namespace peerd { | 21 namespace peerd { |
21 const char kPeerdServiceName[] = "org.chromium.peerd"; | 22 const char kPeerdServiceName[] = "org.chromium.peerd"; |
23 const char kPeerdObjectManagerServicePath[] = "/org/chromium/peerd"; | |
22 const char kPeerdManagerPath[] = "/org/chromium/peerd/Manager"; | 24 const char kPeerdManagerPath[] = "/org/chromium/peerd/Manager"; |
23 const char kManagerInterface[] = "org.chromium.peerd.Manager"; | 25 const char kManagerInterface[] = "org.chromium.peerd.Manager"; |
26 const char kPeerInterface[] = "org.chromium.peerd.Peer"; | |
27 const char kServiceInterface[] = "org.chromium.peerd.Service"; | |
hashimoto
2015/02/05 09:51:11
nit: As noted in the header, please be consistent
dtapuska
2015/02/05 19:51:16
Done.
| |
24 const char kStartMonitoringMethod[] = "StartMonitoring"; | 28 const char kStartMonitoringMethod[] = "StartMonitoring"; |
25 const char kStopMonitoringMethod[] = "StopMonitoring"; | 29 const char kStopMonitoringMethod[] = "StopMonitoring"; |
26 const char kExposeServiceMethod[] = "ExposeService"; | 30 const char kExposeServiceMethod[] = "ExposeService"; |
27 const char kRemoveExposedServiceMethod[] = "RemoveExposedService"; | 31 const char kRemoveExposedServiceMethod[] = "RemoveExposedService"; |
28 const char kPingMethod[] = "Ping"; | 32 const char kPingMethod[] = "Ping"; |
29 } // namespace peerd | 33 } // namespace peerd |
30 | 34 |
35 namespace { | |
hashimoto
2015/02/05 09:51:11
unnamed namespace should start from before string
dtapuska
2015/02/05 19:51:16
Done.
| |
36 | |
31 // The PeerDaemonManagerClient implementation used in production. | 37 // The PeerDaemonManagerClient implementation used in production. |
32 class PeerDaemonManagerClientImpl : public PeerDaemonManagerClient { | 38 class PeerDaemonManagerClientImpl : public PeerDaemonManagerClient, |
39 public dbus::ObjectManager::Interface { | |
33 public: | 40 public: |
34 PeerDaemonManagerClientImpl(); | 41 PeerDaemonManagerClientImpl(); |
35 ~PeerDaemonManagerClientImpl() override; | 42 ~PeerDaemonManagerClientImpl() override; |
36 | 43 |
37 // DBusClient overrides: | 44 // DBusClient overrides: |
38 void Init(dbus::Bus* bus) override; | 45 void Init(dbus::Bus* bus) override; |
39 | 46 |
40 // PeerDaemonManagerClient overrides: | 47 // PeerDaemonManagerClient overrides: |
48 void AddObserver(Observer* observer) override; | |
49 void RemoveObserver(Observer* observer) override; | |
50 std::vector<dbus::ObjectPath> GetPeers() override; | |
51 std::vector<dbus::ObjectPath> GetServices() override; | |
52 PeerProperties* GetPeerProperties( | |
53 const dbus::ObjectPath& object_path) override; | |
54 ServiceProperties* GetServiceProperties( | |
55 const dbus::ObjectPath& object_path) override; | |
41 void StartMonitoring( | 56 void StartMonitoring( |
42 const std::vector<std::string>& requested_technologies, | 57 const std::vector<std::string>& requested_technologies, |
43 const base::DictionaryValue& options, | 58 const base::DictionaryValue& options, |
44 const StringDBusMethodCallback& callback) override; | 59 const StringDBusMethodCallback& callback) override; |
45 void StopMonitoring(const std::string& monitoring_token, | 60 void StopMonitoring(const std::string& monitoring_token, |
46 const VoidDBusMethodCallback& callback) override; | 61 const VoidDBusMethodCallback& callback) override; |
47 void ExposeService( | 62 void ExposeService( |
48 const std::string& service_id, | 63 const std::string& service_id, |
49 const std::map<std::string, std::string>& service_info, | 64 const std::map<std::string, std::string>& service_info, |
50 const base::DictionaryValue& options, | 65 const base::DictionaryValue& options, |
51 const StringDBusMethodCallback& callback) override; | 66 const StringDBusMethodCallback& callback) override; |
52 void RemoveExposedService(const std::string& service_token, | 67 void RemoveExposedService(const std::string& service_token, |
53 const VoidDBusMethodCallback& callback) override; | 68 const VoidDBusMethodCallback& callback) override; |
54 void Ping(const StringDBusMethodCallback& callback) override; | 69 void Ping(const StringDBusMethodCallback& callback) override; |
55 | 70 |
71 // dbus::ObjectManager::Interface override. | |
hashimoto
2015/02/05 09:51:11
nit: "overrides:" instead of "override." to be con
dtapuska
2015/02/05 19:51:16
Done.
| |
72 dbus::PropertySet* CreateProperties( | |
73 dbus::ObjectProxy* object_proxy, | |
74 const dbus::ObjectPath& object_path, | |
75 const std::string& interface_name) override; | |
76 void ObjectAdded(const dbus::ObjectPath& object_path, | |
77 const std::string& interface_name) override; | |
78 void ObjectRemoved(const dbus::ObjectPath& object_path, | |
79 const std::string& interface_name) override; | |
80 | |
56 private: | 81 private: |
57 void OnStringDBusMethod(const StringDBusMethodCallback& callback, | 82 void OnStringDBusMethod(const StringDBusMethodCallback& callback, |
58 dbus::Response* response); | 83 dbus::Response* response); |
59 void OnVoidDBusMethod(const VoidDBusMethodCallback& callback, | 84 void OnVoidDBusMethod(const VoidDBusMethodCallback& callback, |
60 dbus::Response* response); | 85 dbus::Response* response); |
86 void OnManagerPropertyChanged(const std::string& property_name); | |
87 void OnPeerPropertyChanged(const dbus::ObjectPath& object_path, | |
88 const std::string& property_name); | |
89 void OnServicePropertyChanged(const dbus::ObjectPath& object_path, | |
90 const std::string& property_name); | |
61 | 91 |
62 dbus::ObjectProxy* peer_daemon_proxy_; | 92 // List of observers interested in event notifications from us. |
93 ObserverList<Observer> observers_; | |
94 dbus::ObjectManager* object_manager_; | |
95 | |
63 base::WeakPtrFactory<PeerDaemonManagerClientImpl> weak_ptr_factory_; | 96 base::WeakPtrFactory<PeerDaemonManagerClientImpl> weak_ptr_factory_; |
64 | 97 |
65 DISALLOW_COPY_AND_ASSIGN(PeerDaemonManagerClientImpl); | 98 DISALLOW_COPY_AND_ASSIGN(PeerDaemonManagerClientImpl); |
66 }; | 99 }; |
67 | 100 |
68 PeerDaemonManagerClientImpl::PeerDaemonManagerClientImpl() | 101 PeerDaemonManagerClientImpl::PeerDaemonManagerClientImpl() |
69 : peer_daemon_proxy_(nullptr), weak_ptr_factory_(this) { | 102 : object_manager_(nullptr), weak_ptr_factory_(this) { |
70 } | 103 } |
71 | 104 |
72 PeerDaemonManagerClientImpl::~PeerDaemonManagerClientImpl() { | 105 PeerDaemonManagerClientImpl::~PeerDaemonManagerClientImpl() { |
106 if (object_manager_) { | |
107 object_manager_->UnregisterInterface("org.chromium.leaderd.Manager"); | |
hashimoto
2015/02/05 09:51:11
This code doesn't match with RegisterInterface() c
dtapuska
2015/02/05 19:51:16
Done.
| |
108 object_manager_->UnregisterInterface("org.chromium.leaderd.Group"); | |
109 } | |
110 } | |
111 | |
112 void PeerDaemonManagerClientImpl::AddObserver(Observer* observer) { | |
113 DCHECK(observer); | |
114 observers_.AddObserver(observer); | |
115 } | |
116 | |
117 void PeerDaemonManagerClientImpl::RemoveObserver(Observer* observer) { | |
118 DCHECK(observer); | |
119 observers_.RemoveObserver(observer); | |
120 } | |
121 | |
122 std::vector<dbus::ObjectPath> PeerDaemonManagerClientImpl::GetPeers() { | |
123 return object_manager_->GetObjectsWithInterface(peerd::kPeerInterface); | |
124 } | |
125 | |
126 std::vector<dbus::ObjectPath> PeerDaemonManagerClientImpl::GetServices() { | |
127 return object_manager_->GetObjectsWithInterface(peerd::kServiceInterface); | |
128 } | |
129 | |
130 PeerDaemonManagerClient::PeerProperties* | |
131 PeerDaemonManagerClientImpl::GetPeerProperties( | |
132 const dbus::ObjectPath& object_path) { | |
133 return static_cast<PeerProperties*>( | |
134 object_manager_->GetProperties(object_path, peerd::kPeerInterface)); | |
135 } | |
136 | |
137 PeerDaemonManagerClient::ServiceProperties* | |
138 PeerDaemonManagerClientImpl::GetServiceProperties( | |
139 const dbus::ObjectPath& object_path) { | |
140 return static_cast<ServiceProperties*>( | |
141 object_manager_->GetProperties(object_path, peerd::kServiceInterface)); | |
73 } | 142 } |
74 | 143 |
75 void PeerDaemonManagerClientImpl::StartMonitoring( | 144 void PeerDaemonManagerClientImpl::StartMonitoring( |
76 const std::vector<std::string>& requested_technologies, | 145 const std::vector<std::string>& requested_technologies, |
77 const base::DictionaryValue& options, | 146 const base::DictionaryValue& options, |
78 const StringDBusMethodCallback& callback) { | 147 const StringDBusMethodCallback& callback) { |
148 dbus::ObjectProxy* object_proxy = object_manager_->GetObjectProxy( | |
149 dbus::ObjectPath(peerd::kPeerdManagerPath)); | |
150 if (!object_proxy) { | |
151 callback.Run(DBUS_METHOD_CALL_FAILURE, ""); | |
hashimoto
2015/02/05 09:51:11
nit: Please use std::string() instead of "" (cf. h
dtapuska
2015/02/05 19:51:16
Done.
| |
152 return; | |
153 } | |
154 | |
79 dbus::MethodCall method_call(peerd::kManagerInterface, | 155 dbus::MethodCall method_call(peerd::kManagerInterface, |
80 peerd::kStartMonitoringMethod); | 156 peerd::kStartMonitoringMethod); |
81 dbus::MessageWriter writer(&method_call); | 157 dbus::MessageWriter writer(&method_call); |
82 writer.AppendArrayOfStrings(requested_technologies); | 158 writer.AppendArrayOfStrings(requested_technologies); |
83 dbus::AppendValueData(&writer, options); | 159 dbus::AppendValueData(&writer, options); |
84 peer_daemon_proxy_->CallMethod( | 160 object_proxy->CallMethod( |
85 &method_call, | 161 &method_call, dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, |
86 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, | |
87 base::Bind(&PeerDaemonManagerClientImpl::OnStringDBusMethod, | 162 base::Bind(&PeerDaemonManagerClientImpl::OnStringDBusMethod, |
88 weak_ptr_factory_.GetWeakPtr(), | 163 weak_ptr_factory_.GetWeakPtr(), callback)); |
89 callback)); | |
90 } | 164 } |
91 | 165 |
92 void PeerDaemonManagerClientImpl::StopMonitoring( | 166 void PeerDaemonManagerClientImpl::StopMonitoring( |
93 const std::string& monitoring_token, | 167 const std::string& monitoring_token, |
94 const VoidDBusMethodCallback& callback) { | 168 const VoidDBusMethodCallback& callback) { |
169 dbus::ObjectProxy* object_proxy = object_manager_->GetObjectProxy( | |
170 dbus::ObjectPath(peerd::kPeerdManagerPath)); | |
171 if (!object_proxy) { | |
172 callback.Run(DBUS_METHOD_CALL_FAILURE); | |
173 return; | |
174 } | |
175 | |
95 dbus::MethodCall method_call(peerd::kManagerInterface, | 176 dbus::MethodCall method_call(peerd::kManagerInterface, |
96 peerd::kStopMonitoringMethod); | 177 peerd::kStopMonitoringMethod); |
97 dbus::MessageWriter writer(&method_call); | 178 dbus::MessageWriter writer(&method_call); |
98 writer.AppendString(monitoring_token); | 179 writer.AppendString(monitoring_token); |
99 peer_daemon_proxy_->CallMethod( | 180 object_proxy->CallMethod( |
100 &method_call, | 181 &method_call, dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, |
101 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, | |
102 base::Bind(&PeerDaemonManagerClientImpl::OnVoidDBusMethod, | 182 base::Bind(&PeerDaemonManagerClientImpl::OnVoidDBusMethod, |
103 weak_ptr_factory_.GetWeakPtr(), | 183 weak_ptr_factory_.GetWeakPtr(), callback)); |
104 callback)); | |
105 } | 184 } |
106 | 185 |
107 void PeerDaemonManagerClientImpl::ExposeService( | 186 void PeerDaemonManagerClientImpl::ExposeService( |
108 const std::string& service_id, | 187 const std::string& service_id, |
109 const std::map<std::string, std::string>& service_info, | 188 const std::map<std::string, std::string>& service_info, |
110 const base::DictionaryValue& options, | 189 const base::DictionaryValue& options, |
111 const StringDBusMethodCallback& callback) { | 190 const StringDBusMethodCallback& callback) { |
191 dbus::ObjectProxy* object_proxy = object_manager_->GetObjectProxy( | |
192 dbus::ObjectPath(peerd::kPeerdManagerPath)); | |
193 if (!object_proxy) { | |
194 callback.Run(DBUS_METHOD_CALL_FAILURE, ""); | |
195 return; | |
196 } | |
197 | |
112 dbus::MethodCall method_call(peerd::kManagerInterface, | 198 dbus::MethodCall method_call(peerd::kManagerInterface, |
113 peerd::kExposeServiceMethod); | 199 peerd::kExposeServiceMethod); |
114 dbus::MessageWriter writer(&method_call); | 200 dbus::MessageWriter writer(&method_call); |
115 writer.AppendString(service_id); | 201 writer.AppendString(service_id); |
116 | 202 |
117 dbus::MessageWriter array_writer(nullptr); | 203 dbus::MessageWriter array_writer(nullptr); |
118 writer.OpenArray("{ss}", &array_writer); | 204 writer.OpenArray("{ss}", &array_writer); |
119 for (const auto& entry : service_info) { | 205 for (const auto& entry : service_info) { |
120 dbus::MessageWriter dict_entry_writer(nullptr); | 206 dbus::MessageWriter dict_entry_writer(nullptr); |
121 array_writer.OpenDictEntry(&dict_entry_writer); | 207 array_writer.OpenDictEntry(&dict_entry_writer); |
122 dict_entry_writer.AppendString(entry.first); | 208 dict_entry_writer.AppendString(entry.first); |
123 dict_entry_writer.AppendString(entry.second); | 209 dict_entry_writer.AppendString(entry.second); |
124 array_writer.CloseContainer(&dict_entry_writer); | 210 array_writer.CloseContainer(&dict_entry_writer); |
125 } | 211 } |
126 writer.CloseContainer(&array_writer); | 212 writer.CloseContainer(&array_writer); |
127 | 213 |
128 dbus::AppendValueData(&writer, options); | 214 dbus::AppendValueData(&writer, options); |
129 peer_daemon_proxy_->CallMethod( | 215 object_proxy->CallMethod( |
130 &method_call, | 216 &method_call, dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, |
131 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, | |
132 base::Bind(&PeerDaemonManagerClientImpl::OnStringDBusMethod, | 217 base::Bind(&PeerDaemonManagerClientImpl::OnStringDBusMethod, |
133 weak_ptr_factory_.GetWeakPtr(), | 218 weak_ptr_factory_.GetWeakPtr(), callback)); |
134 callback)); | |
135 } | 219 } |
136 | 220 |
137 void PeerDaemonManagerClientImpl::RemoveExposedService( | 221 void PeerDaemonManagerClientImpl::RemoveExposedService( |
138 const std::string& service_token, | 222 const std::string& service_token, |
139 const VoidDBusMethodCallback& callback) { | 223 const VoidDBusMethodCallback& callback) { |
140 dbus::MethodCall method_call(peerd::kManagerInterface, | 224 dbus::MethodCall method_call(peerd::kManagerInterface, |
141 peerd::kRemoveExposedServiceMethod); | 225 peerd::kRemoveExposedServiceMethod); |
226 dbus::ObjectProxy* object_proxy = object_manager_->GetObjectProxy( | |
227 dbus::ObjectPath(peerd::kPeerdManagerPath)); | |
228 if (!object_proxy) { | |
229 callback.Run(DBUS_METHOD_CALL_FAILURE); | |
230 return; | |
231 } | |
142 dbus::MessageWriter writer(&method_call); | 232 dbus::MessageWriter writer(&method_call); |
143 writer.AppendString(service_token); | 233 writer.AppendString(service_token); |
144 peer_daemon_proxy_->CallMethod( | 234 object_proxy->CallMethod( |
145 &method_call, | 235 &method_call, dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, |
146 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, | |
147 base::Bind(&PeerDaemonManagerClientImpl::OnVoidDBusMethod, | 236 base::Bind(&PeerDaemonManagerClientImpl::OnVoidDBusMethod, |
148 weak_ptr_factory_.GetWeakPtr(), | 237 weak_ptr_factory_.GetWeakPtr(), callback)); |
149 callback)); | |
150 } | 238 } |
151 | 239 |
152 void PeerDaemonManagerClientImpl::Ping( | 240 void PeerDaemonManagerClientImpl::Ping( |
153 const StringDBusMethodCallback& callback) { | 241 const StringDBusMethodCallback& callback) { |
154 dbus::MethodCall method_call(peerd::kManagerInterface, | 242 dbus::MethodCall method_call(peerd::kManagerInterface, |
155 peerd::kPingMethod); | 243 peerd::kPingMethod); |
244 dbus::ObjectProxy* object_proxy = object_manager_->GetObjectProxy( | |
245 dbus::ObjectPath(peerd::kPeerdManagerPath)); | |
246 if (!object_proxy) { | |
247 callback.Run(DBUS_METHOD_CALL_FAILURE, ""); | |
248 return; | |
249 } | |
156 dbus::MessageWriter writer(&method_call); | 250 dbus::MessageWriter writer(&method_call); |
157 peer_daemon_proxy_->CallMethod( | 251 object_proxy->CallMethod( |
158 &method_call, | 252 &method_call, dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, |
159 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, | |
160 base::Bind(&PeerDaemonManagerClientImpl::OnStringDBusMethod, | 253 base::Bind(&PeerDaemonManagerClientImpl::OnStringDBusMethod, |
161 weak_ptr_factory_.GetWeakPtr(), | 254 weak_ptr_factory_.GetWeakPtr(), callback)); |
162 callback)); | 255 } |
256 | |
257 dbus::PropertySet* PeerDaemonManagerClientImpl::CreateProperties( | |
258 dbus::ObjectProxy* object_proxy, | |
259 const dbus::ObjectPath& object_path, | |
260 const std::string& interface_name) { | |
261 dbus::PropertySet* properties = nullptr; | |
262 if (interface_name == peerd::kManagerInterface) { | |
263 properties = new ManagerProperties( | |
264 object_proxy, | |
265 base::Bind(&PeerDaemonManagerClientImpl::OnManagerPropertyChanged, | |
266 weak_ptr_factory_.GetWeakPtr())); | |
267 } else if (interface_name == peerd::kServiceInterface) { | |
268 properties = new ServiceProperties( | |
269 object_proxy, | |
270 base::Bind(&PeerDaemonManagerClientImpl::OnServicePropertyChanged, | |
271 weak_ptr_factory_.GetWeakPtr(), object_path)); | |
272 } else if (interface_name == peerd::kPeerInterface) { | |
273 properties = new PeerProperties( | |
274 object_proxy, | |
275 base::Bind(&PeerDaemonManagerClientImpl::OnPeerPropertyChanged, | |
276 weak_ptr_factory_.GetWeakPtr(), object_path)); | |
277 } | |
hashimoto
2015/02/05 09:51:11
How about leaving a log when interface_name is an
dtapuska
2015/02/05 19:51:16
Done.
| |
278 return properties; | |
279 } | |
280 | |
281 void PeerDaemonManagerClientImpl::ObjectAdded( | |
282 const dbus::ObjectPath& object_path, | |
283 const std::string& interface_name) { | |
284 if (interface_name == peerd::kManagerInterface) { | |
285 FOR_EACH_OBSERVER(Observer, observers_, ManagerAdded()); | |
286 } else if (interface_name == peerd::kServiceInterface) { | |
287 FOR_EACH_OBSERVER(Observer, observers_, ServiceAdded(object_path)); | |
288 } else if (interface_name == peerd::kPeerInterface) { | |
289 FOR_EACH_OBSERVER(Observer, observers_, PeerAdded(object_path)); | |
290 } | |
291 } | |
292 | |
293 void PeerDaemonManagerClientImpl::ObjectRemoved( | |
294 const dbus::ObjectPath& object_path, | |
295 const std::string& interface_name) { | |
296 if (interface_name == peerd::kManagerInterface) { | |
297 FOR_EACH_OBSERVER(Observer, observers_, ManagerRemoved()); | |
298 } else if (interface_name == peerd::kServiceInterface) { | |
299 FOR_EACH_OBSERVER(Observer, observers_, ServiceRemoved(object_path)); | |
300 } else if (interface_name == peerd::kPeerInterface) { | |
301 FOR_EACH_OBSERVER(Observer, observers_, PeerRemoved(object_path)); | |
302 } | |
163 } | 303 } |
164 | 304 |
165 void PeerDaemonManagerClientImpl::OnStringDBusMethod( | 305 void PeerDaemonManagerClientImpl::OnStringDBusMethod( |
166 const StringDBusMethodCallback& callback, | 306 const StringDBusMethodCallback& callback, |
167 dbus::Response* response) { | 307 dbus::Response* response) { |
168 if (!response) { | 308 if (!response) { |
169 callback.Run(DBUS_METHOD_CALL_FAILURE, std::string()); | 309 callback.Run(DBUS_METHOD_CALL_FAILURE, std::string()); |
170 return; | 310 return; |
171 } | 311 } |
172 | 312 |
173 dbus::MessageReader reader(response); | 313 dbus::MessageReader reader(response); |
174 std::string result; | 314 std::string result; |
175 if (!reader.PopString(&result)) { | 315 if (!reader.PopString(&result)) { |
176 callback.Run(DBUS_METHOD_CALL_FAILURE, std::string()); | 316 callback.Run(DBUS_METHOD_CALL_FAILURE, std::string()); |
177 return; | 317 return; |
178 } | 318 } |
179 | 319 |
180 callback.Run(DBUS_METHOD_CALL_SUCCESS, result); | 320 callback.Run(DBUS_METHOD_CALL_SUCCESS, result); |
181 } | 321 } |
182 | 322 |
183 void PeerDaemonManagerClientImpl::OnVoidDBusMethod( | 323 void PeerDaemonManagerClientImpl::OnVoidDBusMethod( |
184 const VoidDBusMethodCallback& callback, | 324 const VoidDBusMethodCallback& callback, |
185 dbus::Response* response) { | 325 dbus::Response* response) { |
186 callback.Run(response ? DBUS_METHOD_CALL_SUCCESS : DBUS_METHOD_CALL_FAILURE); | 326 callback.Run(response ? DBUS_METHOD_CALL_SUCCESS : DBUS_METHOD_CALL_FAILURE); |
187 } | 327 } |
188 | 328 |
189 void PeerDaemonManagerClientImpl::Init(dbus::Bus* bus) { | 329 void PeerDaemonManagerClientImpl::Init(dbus::Bus* bus) { |
190 peer_daemon_proxy_ = | 330 object_manager_ = bus->GetObjectManager( |
191 bus->GetObjectProxy(peerd::kPeerdServiceName, | 331 peerd::kPeerdServiceName, |
192 dbus::ObjectPath(peerd::kPeerdManagerPath)); | 332 dbus::ObjectPath(peerd::kPeerdObjectManagerServicePath)); |
333 object_manager_->RegisterInterface(peerd::kManagerInterface, this); | |
334 object_manager_->RegisterInterface(peerd::kPeerInterface, this); | |
335 object_manager_->RegisterInterface(peerd::kServiceInterface, this); | |
336 } | |
337 | |
338 void PeerDaemonManagerClientImpl::OnManagerPropertyChanged( | |
339 const std::string& property_name) { | |
340 FOR_EACH_OBSERVER(Observer, observers_, | |
341 ManagerPropertyChanged(property_name)); | |
342 } | |
343 | |
344 void PeerDaemonManagerClientImpl::OnPeerPropertyChanged( | |
345 const dbus::ObjectPath& object_path, | |
346 const std::string& property_name) { | |
347 FOR_EACH_OBSERVER(Observer, observers_, | |
348 PeerPropertyChanged(object_path, property_name)); | |
349 } | |
350 | |
351 void PeerDaemonManagerClientImpl::OnServicePropertyChanged( | |
352 const dbus::ObjectPath& object_path, | |
353 const std::string& property_name) { | |
354 FOR_EACH_OBSERVER(Observer, observers_, | |
355 ServicePropertyChanged(object_path, property_name)); | |
193 } | 356 } |
194 | 357 |
195 } // namespace | 358 } // namespace |
196 | 359 |
360 PeerDaemonManagerClient::ManagerProperties::ManagerProperties( | |
361 dbus::ObjectProxy* object_proxy, | |
362 const PropertyChangedCallback& callback) | |
363 : dbus::PropertySet{object_proxy, peerd::kManagerInterface, callback} { | |
364 RegisterProperty("MonitoredTechnologies", &monitored_technologies); | |
365 } | |
366 | |
367 PeerDaemonManagerClient::ManagerProperties::~ManagerProperties() { | |
368 } | |
369 | |
370 PeerDaemonManagerClient::PeerProperties::PeerProperties( | |
371 dbus::ObjectProxy* object_proxy, | |
372 const PropertyChangedCallback& callback) | |
373 : dbus::PropertySet{object_proxy, peerd::kPeerInterface, callback} { | |
374 RegisterProperty("UUID", &u_u_i_d); | |
375 RegisterProperty("LastSeen", &last_seen); | |
376 } | |
377 | |
378 PeerDaemonManagerClient::PeerProperties::~PeerProperties() { | |
379 } | |
380 | |
381 PeerDaemonManagerClient::ServiceProperties::ServiceProperties( | |
382 dbus::ObjectProxy* object_proxy, | |
383 const PropertyChangedCallback& callback) | |
384 : dbus::PropertySet{object_proxy, peerd::kServiceInterface, callback} { | |
385 RegisterProperty("ServiceId", &service_id); | |
386 RegisterProperty("ServiceInfo", &service_info); | |
387 RegisterProperty("IpInfos", &ip_infos); | |
388 } | |
389 | |
390 PeerDaemonManagerClient::ServiceProperties::~ServiceProperties() { | |
391 } | |
197 | 392 |
198 PeerDaemonManagerClient::PeerDaemonManagerClient() { | 393 PeerDaemonManagerClient::PeerDaemonManagerClient() { |
199 } | 394 } |
200 | 395 |
201 PeerDaemonManagerClient::~PeerDaemonManagerClient() { | 396 PeerDaemonManagerClient::~PeerDaemonManagerClient() { |
202 } | 397 } |
203 | 398 |
204 // static | 399 // static |
205 PeerDaemonManagerClient* PeerDaemonManagerClient::Create() { | 400 PeerDaemonManagerClient* PeerDaemonManagerClient::Create() { |
206 return new PeerDaemonManagerClientImpl(); | 401 return new PeerDaemonManagerClientImpl(); |
207 } | 402 } |
208 | 403 |
209 } // namespace chromeos | 404 } // namespace chromeos |
OLD | NEW |