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 #include "chromeos/dbus/shill_profile_client.h" | 5 #include "chromeos/dbus/shill_profile_client.h" |
6 | 6 |
7 #include "base/bind.h" | 7 #include "base/bind.h" |
8 #include "base/message_loop.h" | 8 #include "base/message_loop.h" |
9 #include "base/stl_util.h" | 9 #include "base/stl_util.h" |
10 #include "base/values.h" | 10 #include "base/values.h" |
(...skipping 19 matching lines...) Expand all Loading... |
30 const dbus::ObjectPath& profile_path, | 30 const dbus::ObjectPath& profile_path, |
31 ShillPropertyChangedObserver* observer) OVERRIDE { | 31 ShillPropertyChangedObserver* observer) OVERRIDE { |
32 GetHelper(profile_path)->AddPropertyChangedObserver(observer); | 32 GetHelper(profile_path)->AddPropertyChangedObserver(observer); |
33 } | 33 } |
34 | 34 |
35 virtual void RemovePropertyChangedObserver( | 35 virtual void RemovePropertyChangedObserver( |
36 const dbus::ObjectPath& profile_path, | 36 const dbus::ObjectPath& profile_path, |
37 ShillPropertyChangedObserver* observer) OVERRIDE { | 37 ShillPropertyChangedObserver* observer) OVERRIDE { |
38 GetHelper(profile_path)->RemovePropertyChangedObserver(observer); | 38 GetHelper(profile_path)->RemovePropertyChangedObserver(observer); |
39 } | 39 } |
40 virtual void GetProperties(const dbus::ObjectPath& profile_path, | 40 virtual void GetProperties( |
41 const DictionaryValueCallback& callback) OVERRIDE; | 41 const dbus::ObjectPath& profile_path, |
| 42 const DictionaryValueCallbackWithoutStatus& callback, |
| 43 const ErrorCallback& error_callback) OVERRIDE; |
42 virtual void GetEntry(const dbus::ObjectPath& profile_path, | 44 virtual void GetEntry(const dbus::ObjectPath& profile_path, |
43 const std::string& entry_path, | 45 const std::string& entry_path, |
44 const DictionaryValueCallback& callback) OVERRIDE; | 46 const DictionaryValueCallbackWithoutStatus& callback, |
| 47 const ErrorCallback& error_callback) OVERRIDE; |
45 virtual void DeleteEntry(const dbus::ObjectPath& profile_path, | 48 virtual void DeleteEntry(const dbus::ObjectPath& profile_path, |
46 const std::string& entry_path, | 49 const std::string& entry_path, |
47 const VoidDBusMethodCallback& callback) OVERRIDE; | 50 const base::Closure& callback, |
| 51 const ErrorCallback& error_callback) OVERRIDE; |
48 | 52 |
49 private: | 53 private: |
50 typedef std::map<std::string, ShillClientHelper*> HelperMap; | 54 typedef std::map<std::string, ShillClientHelper*> HelperMap; |
51 | 55 |
52 // Returns the corresponding ShillClientHelper for the profile. | 56 // Returns the corresponding ShillClientHelper for the profile. |
53 ShillClientHelper* GetHelper(const dbus::ObjectPath& profile_path); | 57 ShillClientHelper* GetHelper(const dbus::ObjectPath& profile_path); |
54 | 58 |
55 dbus::Bus* bus_; | 59 dbus::Bus* bus_; |
56 HelperMap helpers_; | 60 HelperMap helpers_; |
57 STLValueDeleter<HelperMap> helpers_deleter_; | 61 STLValueDeleter<HelperMap> helpers_deleter_; |
(...skipping 16 matching lines...) Expand all Loading... |
74 dbus::ObjectProxy* object_proxy = | 78 dbus::ObjectProxy* object_proxy = |
75 bus_->GetObjectProxy(flimflam::kFlimflamServiceName, profile_path); | 79 bus_->GetObjectProxy(flimflam::kFlimflamServiceName, profile_path); |
76 ShillClientHelper* helper = new ShillClientHelper(bus_, object_proxy); | 80 ShillClientHelper* helper = new ShillClientHelper(bus_, object_proxy); |
77 helper->MonitorPropertyChanged(flimflam::kFlimflamProfileInterface); | 81 helper->MonitorPropertyChanged(flimflam::kFlimflamProfileInterface); |
78 helpers_.insert(HelperMap::value_type(profile_path.value(), helper)); | 82 helpers_.insert(HelperMap::value_type(profile_path.value(), helper)); |
79 return helper; | 83 return helper; |
80 } | 84 } |
81 | 85 |
82 void ShillProfileClientImpl::GetProperties( | 86 void ShillProfileClientImpl::GetProperties( |
83 const dbus::ObjectPath& profile_path, | 87 const dbus::ObjectPath& profile_path, |
84 const DictionaryValueCallback& callback) { | 88 const DictionaryValueCallbackWithoutStatus& callback, |
| 89 const ErrorCallback& error_callback) { |
85 dbus::MethodCall method_call(flimflam::kFlimflamProfileInterface, | 90 dbus::MethodCall method_call(flimflam::kFlimflamProfileInterface, |
86 flimflam::kGetPropertiesFunction); | 91 flimflam::kGetPropertiesFunction); |
87 GetHelper(profile_path)->CallDictionaryValueMethod(&method_call, callback); | 92 GetHelper(profile_path)->CallDictionaryValueMethodWithErrorCallback( |
| 93 &method_call, callback, error_callback); |
88 } | 94 } |
89 | 95 |
90 void ShillProfileClientImpl::GetEntry( | 96 void ShillProfileClientImpl::GetEntry( |
91 const dbus::ObjectPath& profile_path, | 97 const dbus::ObjectPath& profile_path, |
92 const std::string& entry_path, | 98 const std::string& entry_path, |
93 const DictionaryValueCallback& callback) { | 99 const DictionaryValueCallbackWithoutStatus& callback, |
| 100 const ErrorCallback& error_callback) { |
94 dbus::MethodCall method_call(flimflam::kFlimflamProfileInterface, | 101 dbus::MethodCall method_call(flimflam::kFlimflamProfileInterface, |
95 flimflam::kGetEntryFunction); | 102 flimflam::kGetEntryFunction); |
96 dbus::MessageWriter writer(&method_call); | 103 dbus::MessageWriter writer(&method_call); |
97 writer.AppendString(entry_path); | 104 writer.AppendString(entry_path); |
98 GetHelper(profile_path)->CallDictionaryValueMethod(&method_call, callback); | 105 GetHelper(profile_path)->CallDictionaryValueMethodWithErrorCallback( |
| 106 &method_call, callback, error_callback); |
99 } | 107 } |
100 | 108 |
101 void ShillProfileClientImpl::DeleteEntry( | 109 void ShillProfileClientImpl::DeleteEntry( |
102 const dbus::ObjectPath& profile_path, | 110 const dbus::ObjectPath& profile_path, |
103 const std::string& entry_path, | 111 const std::string& entry_path, |
104 const VoidDBusMethodCallback& callback) { | 112 const base::Closure& callback, |
| 113 const ErrorCallback& error_callback) { |
105 dbus::MethodCall method_call(flimflam::kFlimflamProfileInterface, | 114 dbus::MethodCall method_call(flimflam::kFlimflamProfileInterface, |
106 flimflam::kDeleteEntryFunction); | 115 flimflam::kDeleteEntryFunction); |
107 dbus::MessageWriter writer(&method_call); | 116 dbus::MessageWriter writer(&method_call); |
108 writer.AppendString(entry_path); | 117 writer.AppendString(entry_path); |
109 GetHelper(profile_path)->CallVoidMethod(&method_call, callback); | 118 GetHelper(profile_path)->CallVoidMethodWithErrorCallback( |
| 119 &method_call, callback, error_callback); |
110 } | 120 } |
111 | 121 |
112 // A stub implementation of ShillProfileClient. | 122 // A stub implementation of ShillProfileClient. |
113 class ShillProfileClientStubImpl : public ShillProfileClient { | 123 class ShillProfileClientStubImpl : public ShillProfileClient { |
114 public: | 124 public: |
115 ShillProfileClientStubImpl() : weak_ptr_factory_(this) {} | 125 ShillProfileClientStubImpl() : weak_ptr_factory_(this) {} |
116 | 126 |
117 virtual ~ShillProfileClientStubImpl() {} | 127 virtual ~ShillProfileClientStubImpl() {} |
118 | 128 |
119 ////////////////////////////////////// | 129 ////////////////////////////////////// |
120 // ShillProfileClient overrides. | 130 // ShillProfileClient overrides. |
121 virtual void AddPropertyChangedObserver( | 131 virtual void AddPropertyChangedObserver( |
122 const dbus::ObjectPath& profile_path, | 132 const dbus::ObjectPath& profile_path, |
123 ShillPropertyChangedObserver* observer) OVERRIDE {} | 133 ShillPropertyChangedObserver* observer) OVERRIDE {} |
124 | 134 |
125 virtual void RemovePropertyChangedObserver( | 135 virtual void RemovePropertyChangedObserver( |
126 const dbus::ObjectPath& profile_path, | 136 const dbus::ObjectPath& profile_path, |
127 ShillPropertyChangedObserver* observer) OVERRIDE {} | 137 ShillPropertyChangedObserver* observer) OVERRIDE {} |
128 | 138 |
129 // ShillProfileClient override. | 139 virtual void GetProperties( |
130 virtual void GetProperties(const dbus::ObjectPath& profile_path, | 140 const dbus::ObjectPath& profile_path, |
131 const DictionaryValueCallback& callback) OVERRIDE { | 141 const DictionaryValueCallbackWithoutStatus& callback, |
| 142 const ErrorCallback& error_callback) OVERRIDE { |
132 MessageLoop::current()->PostTask( | 143 MessageLoop::current()->PostTask( |
133 FROM_HERE, | 144 FROM_HERE, |
134 base::Bind(&ShillProfileClientStubImpl::PassEmptyDictionaryValue, | 145 base::Bind(&ShillProfileClientStubImpl::PassEmptyDictionaryValue, |
135 weak_ptr_factory_.GetWeakPtr(), | 146 weak_ptr_factory_.GetWeakPtr(), |
136 callback)); | 147 callback)); |
137 } | 148 } |
138 | 149 |
139 virtual void GetEntry(const dbus::ObjectPath& profile_path, | 150 virtual void GetEntry(const dbus::ObjectPath& profile_path, |
140 const std::string& entry_path, | 151 const std::string& entry_path, |
141 const DictionaryValueCallback& callback) OVERRIDE { | 152 const DictionaryValueCallbackWithoutStatus& callback, |
| 153 const ErrorCallback& error_callback) OVERRIDE { |
142 MessageLoop::current()->PostTask( | 154 MessageLoop::current()->PostTask( |
143 FROM_HERE, | 155 FROM_HERE, |
144 base::Bind(&ShillProfileClientStubImpl::PassEmptyDictionaryValue, | 156 base::Bind(&ShillProfileClientStubImpl::PassEmptyDictionaryValue, |
145 weak_ptr_factory_.GetWeakPtr(), | 157 weak_ptr_factory_.GetWeakPtr(), |
146 callback)); | 158 callback)); |
147 } | 159 } |
148 | 160 |
149 virtual void DeleteEntry(const dbus::ObjectPath& profile_path, | 161 virtual void DeleteEntry(const dbus::ObjectPath& profile_path, |
150 const std::string& entry_path, | 162 const std::string& entry_path, |
151 const VoidDBusMethodCallback& callback) OVERRIDE { | 163 const base::Closure& callback, |
152 MessageLoop::current()->PostTask(FROM_HERE, | 164 const ErrorCallback& error_callback) OVERRIDE { |
153 base::Bind(callback, | 165 MessageLoop::current()->PostTask(FROM_HERE, callback); |
154 DBUS_METHOD_CALL_SUCCESS)); | |
155 } | 166 } |
156 | 167 |
157 private: | 168 private: |
158 void PassEmptyDictionaryValue(const DictionaryValueCallback& callback) const { | 169 void PassEmptyDictionaryValue( |
| 170 const DictionaryValueCallbackWithoutStatus& callback) const { |
159 base::DictionaryValue dictionary; | 171 base::DictionaryValue dictionary; |
160 callback.Run(DBUS_METHOD_CALL_SUCCESS, dictionary); | 172 callback.Run(dictionary); |
161 } | 173 } |
162 | 174 |
163 // Note: This should remain the last member so it'll be destroyed and | 175 // Note: This should remain the last member so it'll be destroyed and |
164 // invalidate its weak pointers before any other members are destroyed. | 176 // invalidate its weak pointers before any other members are destroyed. |
165 base::WeakPtrFactory<ShillProfileClientStubImpl> weak_ptr_factory_; | 177 base::WeakPtrFactory<ShillProfileClientStubImpl> weak_ptr_factory_; |
166 | 178 |
167 DISALLOW_COPY_AND_ASSIGN(ShillProfileClientStubImpl); | 179 DISALLOW_COPY_AND_ASSIGN(ShillProfileClientStubImpl); |
168 }; | 180 }; |
169 | 181 |
170 } // namespace | 182 } // namespace |
171 | 183 |
172 ShillProfileClient::ShillProfileClient() {} | 184 ShillProfileClient::ShillProfileClient() {} |
173 | 185 |
174 ShillProfileClient::~ShillProfileClient() {} | 186 ShillProfileClient::~ShillProfileClient() {} |
175 | 187 |
176 // static | 188 // static |
177 ShillProfileClient* ShillProfileClient::Create( | 189 ShillProfileClient* ShillProfileClient::Create( |
178 DBusClientImplementationType type, | 190 DBusClientImplementationType type, |
179 dbus::Bus* bus) { | 191 dbus::Bus* bus) { |
180 if (type == REAL_DBUS_CLIENT_IMPLEMENTATION) | 192 if (type == REAL_DBUS_CLIENT_IMPLEMENTATION) |
181 return new ShillProfileClientImpl(bus); | 193 return new ShillProfileClientImpl(bus); |
182 DCHECK_EQ(STUB_DBUS_CLIENT_IMPLEMENTATION, type); | 194 DCHECK_EQ(STUB_DBUS_CLIENT_IMPLEMENTATION, type); |
183 return new ShillProfileClientStubImpl(); | 195 return new ShillProfileClientStubImpl(); |
184 } | 196 } |
185 | 197 |
186 } // namespace chromeos | 198 } // namespace chromeos |
OLD | NEW |