Chromium Code Reviews| 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/message_loop/message_loop.h" | |
| 12 #include "base/observer_list.h" | |
| 11 #include "dbus/bus.h" | 13 #include "dbus/bus.h" |
| 12 #include "dbus/message.h" | 14 #include "dbus/message.h" |
| 15 #include "dbus/object_manager.h" | |
| 13 #include "dbus/object_proxy.h" | 16 #include "dbus/object_proxy.h" |
| 14 #include "dbus/values_util.h" | 17 #include "dbus/values_util.h" |
| 15 | 18 |
| 16 namespace chromeos { | 19 namespace chromeos { |
| 17 namespace { | 20 namespace { |
| 18 | 21 |
| 19 // TODO(benchan): Move these constants to system_api. | 22 // TODO(benchan): Move these constants to system_api. |
| 20 namespace peerd { | 23 namespace peerd { |
| 21 const char kPeerdServiceName[] = "org.chromium.peerd"; | 24 const char kPeerdServiceName[] = "org.chromium.peerd"; |
| 25 const char kPeerdObjectManagerServicePath[] = "/org/chromium/peerd"; | |
| 22 const char kPeerdManagerPath[] = "/org/chromium/peerd/Manager"; | 26 const char kPeerdManagerPath[] = "/org/chromium/peerd/Manager"; |
| 23 const char kManagerInterface[] = "org.chromium.peerd.Manager"; | 27 const char kManagerInterface[] = "org.chromium.peerd.Manager"; |
| 28 const char kServiceInterface[] = "org.chromium.peerd.Service"; | |
| 29 const char kPeerInterface[] = "org.chromium.peerd.Peer"; | |
| 24 const char kStartMonitoringMethod[] = "StartMonitoring"; | 30 const char kStartMonitoringMethod[] = "StartMonitoring"; |
| 25 const char kStopMonitoringMethod[] = "StopMonitoring"; | 31 const char kStopMonitoringMethod[] = "StopMonitoring"; |
| 26 const char kExposeServiceMethod[] = "ExposeService"; | 32 const char kExposeServiceMethod[] = "ExposeService"; |
| 27 const char kRemoveExposedServiceMethod[] = "RemoveExposedService"; | 33 const char kRemoveExposedServiceMethod[] = "RemoveExposedService"; |
| 28 const char kPingMethod[] = "Ping"; | 34 const char kPingMethod[] = "Ping"; |
| 29 } // namespace peerd | 35 } // namespace peerd |
| 30 | 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; | |
|
hashimoto
2015/02/06 07:45:11
nit: Please put these overrides in the same order
dtapuska
2015/02/06 15:56:00
Done... Manager, Service, Peer should be the order
| |
| 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 overrides. | |
| 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, | |
|
hashimoto
2015/02/06 07:45:11
nit: Please stick exclusively to one ordering, Man
dtapuska
2015/02/06 15:56:00
Done.
| |
| 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(peerd::kManagerInterface); | |
| 108 object_manager_->UnregisterInterface(peerd::kPeerInterface); | |
| 109 object_manager_->UnregisterInterface(peerd::kServiceInterface); | |
| 110 } | |
| 111 } | |
| 112 | |
| 113 void PeerDaemonManagerClientImpl::AddObserver(Observer* observer) { | |
| 114 DCHECK(observer); | |
| 115 observers_.AddObserver(observer); | |
| 116 } | |
| 117 | |
| 118 void PeerDaemonManagerClientImpl::RemoveObserver(Observer* observer) { | |
| 119 DCHECK(observer); | |
| 120 observers_.RemoveObserver(observer); | |
| 121 } | |
| 122 | |
| 123 std::vector<dbus::ObjectPath> PeerDaemonManagerClientImpl::GetPeers() { | |
| 124 return object_manager_->GetObjectsWithInterface(peerd::kPeerInterface); | |
| 125 } | |
| 126 | |
| 127 std::vector<dbus::ObjectPath> PeerDaemonManagerClientImpl::GetServices() { | |
| 128 return object_manager_->GetObjectsWithInterface(peerd::kServiceInterface); | |
| 129 } | |
| 130 | |
| 131 PeerDaemonManagerClient::PeerProperties* | |
| 132 PeerDaemonManagerClientImpl::GetPeerProperties( | |
| 133 const dbus::ObjectPath& object_path) { | |
| 134 return static_cast<PeerProperties*>( | |
| 135 object_manager_->GetProperties(object_path, peerd::kPeerInterface)); | |
| 136 } | |
| 137 | |
| 138 PeerDaemonManagerClient::ServiceProperties* | |
| 139 PeerDaemonManagerClientImpl::GetServiceProperties( | |
| 140 const dbus::ObjectPath& object_path) { | |
| 141 return static_cast<ServiceProperties*>( | |
| 142 object_manager_->GetProperties(object_path, peerd::kServiceInterface)); | |
| 73 } | 143 } |
| 74 | 144 |
| 75 void PeerDaemonManagerClientImpl::StartMonitoring( | 145 void PeerDaemonManagerClientImpl::StartMonitoring( |
| 76 const std::vector<std::string>& requested_technologies, | 146 const std::vector<std::string>& requested_technologies, |
| 77 const base::DictionaryValue& options, | 147 const base::DictionaryValue& options, |
| 78 const StringDBusMethodCallback& callback) { | 148 const StringDBusMethodCallback& callback) { |
| 149 dbus::ObjectProxy* object_proxy = object_manager_->GetObjectProxy( | |
| 150 dbus::ObjectPath(peerd::kPeerdManagerPath)); | |
| 151 if (!object_proxy) { | |
| 152 base::MessageLoop::current()->PostTask( | |
| 153 FROM_HERE, | |
| 154 base::Bind(&PeerDaemonManagerClientImpl::OnStringDBusMethod, | |
| 155 weak_ptr_factory_.GetWeakPtr(), callback, nullptr)); | |
| 156 return; | |
| 157 } | |
| 158 | |
| 79 dbus::MethodCall method_call(peerd::kManagerInterface, | 159 dbus::MethodCall method_call(peerd::kManagerInterface, |
| 80 peerd::kStartMonitoringMethod); | 160 peerd::kStartMonitoringMethod); |
| 81 dbus::MessageWriter writer(&method_call); | 161 dbus::MessageWriter writer(&method_call); |
| 82 writer.AppendArrayOfStrings(requested_technologies); | 162 writer.AppendArrayOfStrings(requested_technologies); |
| 83 dbus::AppendValueData(&writer, options); | 163 dbus::AppendValueData(&writer, options); |
| 84 peer_daemon_proxy_->CallMethod( | 164 object_proxy->CallMethod( |
| 85 &method_call, | 165 &method_call, dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, |
| 86 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, | |
| 87 base::Bind(&PeerDaemonManagerClientImpl::OnStringDBusMethod, | 166 base::Bind(&PeerDaemonManagerClientImpl::OnStringDBusMethod, |
| 88 weak_ptr_factory_.GetWeakPtr(), | 167 weak_ptr_factory_.GetWeakPtr(), callback)); |
| 89 callback)); | |
| 90 } | 168 } |
| 91 | 169 |
| 92 void PeerDaemonManagerClientImpl::StopMonitoring( | 170 void PeerDaemonManagerClientImpl::StopMonitoring( |
| 93 const std::string& monitoring_token, | 171 const std::string& monitoring_token, |
| 94 const VoidDBusMethodCallback& callback) { | 172 const VoidDBusMethodCallback& callback) { |
| 173 dbus::ObjectProxy* object_proxy = object_manager_->GetObjectProxy( | |
| 174 dbus::ObjectPath(peerd::kPeerdManagerPath)); | |
| 175 if (!object_proxy) { | |
| 176 base::MessageLoop::current()->PostTask( | |
| 177 FROM_HERE, | |
| 178 base::Bind(&PeerDaemonManagerClientImpl::OnVoidDBusMethod, | |
| 179 weak_ptr_factory_.GetWeakPtr(), callback, nullptr)); | |
| 180 return; | |
| 181 } | |
| 182 | |
| 95 dbus::MethodCall method_call(peerd::kManagerInterface, | 183 dbus::MethodCall method_call(peerd::kManagerInterface, |
| 96 peerd::kStopMonitoringMethod); | 184 peerd::kStopMonitoringMethod); |
| 97 dbus::MessageWriter writer(&method_call); | 185 dbus::MessageWriter writer(&method_call); |
| 98 writer.AppendString(monitoring_token); | 186 writer.AppendString(monitoring_token); |
| 99 peer_daemon_proxy_->CallMethod( | 187 object_proxy->CallMethod( |
| 100 &method_call, | 188 &method_call, dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, |
| 101 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, | |
| 102 base::Bind(&PeerDaemonManagerClientImpl::OnVoidDBusMethod, | 189 base::Bind(&PeerDaemonManagerClientImpl::OnVoidDBusMethod, |
| 103 weak_ptr_factory_.GetWeakPtr(), | 190 weak_ptr_factory_.GetWeakPtr(), callback)); |
| 104 callback)); | |
| 105 } | 191 } |
| 106 | 192 |
| 107 void PeerDaemonManagerClientImpl::ExposeService( | 193 void PeerDaemonManagerClientImpl::ExposeService( |
| 108 const std::string& service_id, | 194 const std::string& service_id, |
| 109 const std::map<std::string, std::string>& service_info, | 195 const std::map<std::string, std::string>& service_info, |
| 110 const base::DictionaryValue& options, | 196 const base::DictionaryValue& options, |
| 111 const StringDBusMethodCallback& callback) { | 197 const StringDBusMethodCallback& callback) { |
| 198 dbus::ObjectProxy* object_proxy = object_manager_->GetObjectProxy( | |
| 199 dbus::ObjectPath(peerd::kPeerdManagerPath)); | |
| 200 if (!object_proxy) { | |
| 201 callback.Run(DBUS_METHOD_CALL_FAILURE, ""); | |
|
hashimoto
2015/02/06 07:45:12
Please PostTask() here and use std::string().
The
dtapuska
2015/02/06 15:56:00
Done.
| |
| 202 return; | |
| 203 } | |
| 204 | |
| 112 dbus::MethodCall method_call(peerd::kManagerInterface, | 205 dbus::MethodCall method_call(peerd::kManagerInterface, |
| 113 peerd::kExposeServiceMethod); | 206 peerd::kExposeServiceMethod); |
| 114 dbus::MessageWriter writer(&method_call); | 207 dbus::MessageWriter writer(&method_call); |
| 115 writer.AppendString(service_id); | 208 writer.AppendString(service_id); |
| 116 | 209 |
| 117 dbus::MessageWriter array_writer(nullptr); | 210 dbus::MessageWriter array_writer(nullptr); |
| 118 writer.OpenArray("{ss}", &array_writer); | 211 writer.OpenArray("{ss}", &array_writer); |
| 119 for (const auto& entry : service_info) { | 212 for (const auto& entry : service_info) { |
| 120 dbus::MessageWriter dict_entry_writer(nullptr); | 213 dbus::MessageWriter dict_entry_writer(nullptr); |
| 121 array_writer.OpenDictEntry(&dict_entry_writer); | 214 array_writer.OpenDictEntry(&dict_entry_writer); |
| 122 dict_entry_writer.AppendString(entry.first); | 215 dict_entry_writer.AppendString(entry.first); |
| 123 dict_entry_writer.AppendString(entry.second); | 216 dict_entry_writer.AppendString(entry.second); |
| 124 array_writer.CloseContainer(&dict_entry_writer); | 217 array_writer.CloseContainer(&dict_entry_writer); |
| 125 } | 218 } |
| 126 writer.CloseContainer(&array_writer); | 219 writer.CloseContainer(&array_writer); |
| 127 | 220 |
| 128 dbus::AppendValueData(&writer, options); | 221 dbus::AppendValueData(&writer, options); |
| 129 peer_daemon_proxy_->CallMethod( | 222 object_proxy->CallMethod( |
| 130 &method_call, | 223 &method_call, dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, |
| 131 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, | |
| 132 base::Bind(&PeerDaemonManagerClientImpl::OnStringDBusMethod, | 224 base::Bind(&PeerDaemonManagerClientImpl::OnStringDBusMethod, |
| 133 weak_ptr_factory_.GetWeakPtr(), | 225 weak_ptr_factory_.GetWeakPtr(), callback)); |
| 134 callback)); | |
| 135 } | 226 } |
| 136 | 227 |
| 137 void PeerDaemonManagerClientImpl::RemoveExposedService( | 228 void PeerDaemonManagerClientImpl::RemoveExposedService( |
| 138 const std::string& service_token, | 229 const std::string& service_token, |
| 139 const VoidDBusMethodCallback& callback) { | 230 const VoidDBusMethodCallback& callback) { |
| 140 dbus::MethodCall method_call(peerd::kManagerInterface, | 231 dbus::MethodCall method_call(peerd::kManagerInterface, |
| 141 peerd::kRemoveExposedServiceMethod); | 232 peerd::kRemoveExposedServiceMethod); |
| 233 dbus::ObjectProxy* object_proxy = object_manager_->GetObjectProxy( | |
| 234 dbus::ObjectPath(peerd::kPeerdManagerPath)); | |
| 235 if (!object_proxy) { | |
| 236 callback.Run(DBUS_METHOD_CALL_FAILURE); | |
| 237 return; | |
| 238 } | |
| 142 dbus::MessageWriter writer(&method_call); | 239 dbus::MessageWriter writer(&method_call); |
| 143 writer.AppendString(service_token); | 240 writer.AppendString(service_token); |
| 144 peer_daemon_proxy_->CallMethod( | 241 object_proxy->CallMethod( |
| 145 &method_call, | 242 &method_call, dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, |
| 146 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, | |
| 147 base::Bind(&PeerDaemonManagerClientImpl::OnVoidDBusMethod, | 243 base::Bind(&PeerDaemonManagerClientImpl::OnVoidDBusMethod, |
| 148 weak_ptr_factory_.GetWeakPtr(), | 244 weak_ptr_factory_.GetWeakPtr(), callback)); |
| 149 callback)); | |
| 150 } | 245 } |
| 151 | 246 |
| 152 void PeerDaemonManagerClientImpl::Ping( | 247 void PeerDaemonManagerClientImpl::Ping( |
| 153 const StringDBusMethodCallback& callback) { | 248 const StringDBusMethodCallback& callback) { |
| 154 dbus::MethodCall method_call(peerd::kManagerInterface, | 249 dbus::MethodCall method_call(peerd::kManagerInterface, |
| 155 peerd::kPingMethod); | 250 peerd::kPingMethod); |
| 251 dbus::ObjectProxy* object_proxy = object_manager_->GetObjectProxy( | |
| 252 dbus::ObjectPath(peerd::kPeerdManagerPath)); | |
| 253 if (!object_proxy) { | |
| 254 callback.Run(DBUS_METHOD_CALL_FAILURE, ""); | |
| 255 return; | |
| 256 } | |
| 156 dbus::MessageWriter writer(&method_call); | 257 dbus::MessageWriter writer(&method_call); |
| 157 peer_daemon_proxy_->CallMethod( | 258 object_proxy->CallMethod( |
| 158 &method_call, | 259 &method_call, dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, |
| 159 dbus::ObjectProxy::TIMEOUT_USE_DEFAULT, | |
| 160 base::Bind(&PeerDaemonManagerClientImpl::OnStringDBusMethod, | 260 base::Bind(&PeerDaemonManagerClientImpl::OnStringDBusMethod, |
| 161 weak_ptr_factory_.GetWeakPtr(), | 261 weak_ptr_factory_.GetWeakPtr(), callback)); |
| 162 callback)); | 262 } |
| 263 | |
| 264 dbus::PropertySet* PeerDaemonManagerClientImpl::CreateProperties( | |
| 265 dbus::ObjectProxy* object_proxy, | |
| 266 const dbus::ObjectPath& object_path, | |
| 267 const std::string& interface_name) { | |
| 268 dbus::PropertySet* properties = nullptr; | |
| 269 if (interface_name == peerd::kManagerInterface) { | |
| 270 properties = new ManagerProperties( | |
| 271 object_proxy, | |
| 272 base::Bind(&PeerDaemonManagerClientImpl::OnManagerPropertyChanged, | |
| 273 weak_ptr_factory_.GetWeakPtr())); | |
| 274 } else if (interface_name == peerd::kServiceInterface) { | |
| 275 properties = new ServiceProperties( | |
| 276 object_proxy, | |
| 277 base::Bind(&PeerDaemonManagerClientImpl::OnServicePropertyChanged, | |
| 278 weak_ptr_factory_.GetWeakPtr(), object_path)); | |
| 279 } else if (interface_name == peerd::kPeerInterface) { | |
| 280 properties = new PeerProperties( | |
| 281 object_proxy, | |
| 282 base::Bind(&PeerDaemonManagerClientImpl::OnPeerPropertyChanged, | |
| 283 weak_ptr_factory_.GetWeakPtr(), object_path)); | |
| 284 } else { | |
| 285 NOTREACHED() << "Unhandled interface name " << interface_name; | |
| 286 } | |
| 287 return properties; | |
| 288 } | |
| 289 | |
| 290 void PeerDaemonManagerClientImpl::ObjectAdded( | |
| 291 const dbus::ObjectPath& object_path, | |
| 292 const std::string& interface_name) { | |
| 293 if (interface_name == peerd::kManagerInterface) { | |
| 294 FOR_EACH_OBSERVER(Observer, observers_, ManagerAdded()); | |
| 295 } else if (interface_name == peerd::kServiceInterface) { | |
| 296 FOR_EACH_OBSERVER(Observer, observers_, ServiceAdded(object_path)); | |
| 297 } else if (interface_name == peerd::kPeerInterface) { | |
| 298 FOR_EACH_OBSERVER(Observer, observers_, PeerAdded(object_path)); | |
| 299 } else { | |
| 300 NOTREACHED() << "Unhandled interface name " << interface_name; | |
| 301 } | |
| 302 } | |
| 303 | |
| 304 void PeerDaemonManagerClientImpl::ObjectRemoved( | |
| 305 const dbus::ObjectPath& object_path, | |
| 306 const std::string& interface_name) { | |
| 307 if (interface_name == peerd::kManagerInterface) { | |
| 308 FOR_EACH_OBSERVER(Observer, observers_, ManagerRemoved()); | |
| 309 } else if (interface_name == peerd::kServiceInterface) { | |
| 310 FOR_EACH_OBSERVER(Observer, observers_, ServiceRemoved(object_path)); | |
| 311 } else if (interface_name == peerd::kPeerInterface) { | |
| 312 FOR_EACH_OBSERVER(Observer, observers_, PeerRemoved(object_path)); | |
| 313 } else { | |
| 314 NOTREACHED() << "Unhandled interface name " << interface_name; | |
| 315 } | |
| 163 } | 316 } |
| 164 | 317 |
| 165 void PeerDaemonManagerClientImpl::OnStringDBusMethod( | 318 void PeerDaemonManagerClientImpl::OnStringDBusMethod( |
| 166 const StringDBusMethodCallback& callback, | 319 const StringDBusMethodCallback& callback, |
| 167 dbus::Response* response) { | 320 dbus::Response* response) { |
| 168 if (!response) { | 321 if (!response) { |
| 169 callback.Run(DBUS_METHOD_CALL_FAILURE, std::string()); | 322 callback.Run(DBUS_METHOD_CALL_FAILURE, std::string()); |
| 170 return; | 323 return; |
| 171 } | 324 } |
| 172 | 325 |
| 173 dbus::MessageReader reader(response); | 326 dbus::MessageReader reader(response); |
| 174 std::string result; | 327 std::string result; |
| 175 if (!reader.PopString(&result)) { | 328 if (!reader.PopString(&result)) { |
| 176 callback.Run(DBUS_METHOD_CALL_FAILURE, std::string()); | 329 callback.Run(DBUS_METHOD_CALL_FAILURE, std::string()); |
| 177 return; | 330 return; |
| 178 } | 331 } |
| 179 | 332 |
| 180 callback.Run(DBUS_METHOD_CALL_SUCCESS, result); | 333 callback.Run(DBUS_METHOD_CALL_SUCCESS, result); |
| 181 } | 334 } |
| 182 | 335 |
| 183 void PeerDaemonManagerClientImpl::OnVoidDBusMethod( | 336 void PeerDaemonManagerClientImpl::OnVoidDBusMethod( |
| 184 const VoidDBusMethodCallback& callback, | 337 const VoidDBusMethodCallback& callback, |
| 185 dbus::Response* response) { | 338 dbus::Response* response) { |
| 186 callback.Run(response ? DBUS_METHOD_CALL_SUCCESS : DBUS_METHOD_CALL_FAILURE); | 339 callback.Run(response ? DBUS_METHOD_CALL_SUCCESS : DBUS_METHOD_CALL_FAILURE); |
| 187 } | 340 } |
| 188 | 341 |
| 189 void PeerDaemonManagerClientImpl::Init(dbus::Bus* bus) { | 342 void PeerDaemonManagerClientImpl::Init(dbus::Bus* bus) { |
| 190 peer_daemon_proxy_ = | 343 object_manager_ = bus->GetObjectManager( |
| 191 bus->GetObjectProxy(peerd::kPeerdServiceName, | 344 peerd::kPeerdServiceName, |
| 192 dbus::ObjectPath(peerd::kPeerdManagerPath)); | 345 dbus::ObjectPath(peerd::kPeerdObjectManagerServicePath)); |
| 346 object_manager_->RegisterInterface(peerd::kManagerInterface, this); | |
| 347 object_manager_->RegisterInterface(peerd::kPeerInterface, this); | |
| 348 object_manager_->RegisterInterface(peerd::kServiceInterface, this); | |
| 349 } | |
| 350 | |
| 351 void PeerDaemonManagerClientImpl::OnManagerPropertyChanged( | |
| 352 const std::string& property_name) { | |
| 353 FOR_EACH_OBSERVER(Observer, observers_, | |
| 354 ManagerPropertyChanged(property_name)); | |
| 355 } | |
| 356 | |
| 357 void PeerDaemonManagerClientImpl::OnPeerPropertyChanged( | |
| 358 const dbus::ObjectPath& object_path, | |
| 359 const std::string& property_name) { | |
| 360 FOR_EACH_OBSERVER(Observer, observers_, | |
| 361 PeerPropertyChanged(object_path, property_name)); | |
| 362 } | |
| 363 | |
| 364 void PeerDaemonManagerClientImpl::OnServicePropertyChanged( | |
| 365 const dbus::ObjectPath& object_path, | |
| 366 const std::string& property_name) { | |
| 367 FOR_EACH_OBSERVER(Observer, observers_, | |
| 368 ServicePropertyChanged(object_path, property_name)); | |
| 193 } | 369 } |
| 194 | 370 |
| 195 } // namespace | 371 } // namespace |
| 196 | 372 |
| 373 PeerDaemonManagerClient::ManagerProperties::ManagerProperties( | |
| 374 dbus::ObjectProxy* object_proxy, | |
| 375 const PropertyChangedCallback& callback) | |
| 376 : dbus::PropertySet{object_proxy, peerd::kManagerInterface, callback} { | |
| 377 RegisterProperty("MonitoredTechnologies", &monitored_technologies); | |
| 378 } | |
| 379 | |
| 380 PeerDaemonManagerClient::ManagerProperties::~ManagerProperties() { | |
| 381 } | |
| 382 | |
| 383 PeerDaemonManagerClient::PeerProperties::PeerProperties( | |
|
hashimoto
2015/02/06 07:45:11
Please put methods in the same order as declared i
dtapuska
2015/02/06 15:56:00
Done.
| |
| 384 dbus::ObjectProxy* object_proxy, | |
| 385 const PropertyChangedCallback& callback) | |
| 386 : dbus::PropertySet{object_proxy, peerd::kPeerInterface, callback} { | |
| 387 RegisterProperty("UUID", &uuid); | |
| 388 RegisterProperty("LastSeen", &last_seen); | |
| 389 } | |
| 390 | |
| 391 PeerDaemonManagerClient::PeerProperties::~PeerProperties() { | |
| 392 } | |
| 393 | |
| 394 PeerDaemonManagerClient::ServiceProperties::ServiceProperties( | |
| 395 dbus::ObjectProxy* object_proxy, | |
| 396 const PropertyChangedCallback& callback) | |
| 397 : dbus::PropertySet{object_proxy, peerd::kServiceInterface, callback} { | |
| 398 RegisterProperty("ServiceId", &service_id); | |
| 399 RegisterProperty("ServiceInfo", &service_info); | |
| 400 RegisterProperty("IpInfos", &ip_infos); | |
| 401 } | |
| 402 | |
| 403 PeerDaemonManagerClient::ServiceProperties::~ServiceProperties() { | |
| 404 } | |
| 197 | 405 |
| 198 PeerDaemonManagerClient::PeerDaemonManagerClient() { | 406 PeerDaemonManagerClient::PeerDaemonManagerClient() { |
| 199 } | 407 } |
| 200 | 408 |
| 201 PeerDaemonManagerClient::~PeerDaemonManagerClient() { | 409 PeerDaemonManagerClient::~PeerDaemonManagerClient() { |
| 202 } | 410 } |
| 203 | 411 |
| 204 // static | 412 // static |
| 205 PeerDaemonManagerClient* PeerDaemonManagerClient::Create() { | 413 PeerDaemonManagerClient* PeerDaemonManagerClient::Create() { |
| 206 return new PeerDaemonManagerClientImpl(); | 414 return new PeerDaemonManagerClientImpl(); |
| 207 } | 415 } |
| 208 | 416 |
| 209 } // namespace chromeos | 417 } // namespace chromeos |
| OLD | NEW |