Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(4)

Side by Side Diff: chromeos/dbus/bluetooth_le_advertisement_service_provider.cc

Issue 1223173008: Fix BLE register Dbus interactions. (Closed) Base URL: https://chromium.googlesource.com/chromium/src.git@master
Patch Set: Created 5 years, 5 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
« no previous file with comments | « no previous file | chromeos/dbus/bluetooth_le_advertising_manager_client.cc » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2015 The Chromium Authors. All rights reserved. 1 // Copyright 2015 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/bluetooth_le_advertisement_service_provider.h" 5 #include "chromeos/dbus/bluetooth_le_advertisement_service_provider.h"
6 6
7 #include "base/bind.h" 7 #include "base/bind.h"
8 #include "base/logging.h" 8 #include "base/logging.h"
9 #include "base/memory/ref_counted.h" 9 #include "base/memory/ref_counted.h"
10 #include "base/stl_util.h" 10 #include "base/stl_util.h"
(...skipping 240 matching lines...) Expand 10 before | Expand all | Expand 10 after
251 dbus::MessageWriter writer(response.get()); 251 dbus::MessageWriter writer(response.get());
252 dbus::MessageWriter variant_writer(NULL); 252 dbus::MessageWriter variant_writer(NULL);
253 253
254 writer.OpenVariant("ay", &variant_writer); 254 writer.OpenVariant("ay", &variant_writer);
255 variant_writer.AppendArrayOfBytes(value.data(), value.size()); 255 variant_writer.AppendArrayOfBytes(value.data(), value.size());
256 writer.CloseContainer(&variant_writer); 256 writer.CloseContainer(&variant_writer);
257 257
258 response_sender.Run(response.Pass()); 258 response_sender.Run(response.Pass());
259 } 259 }
260 260
261 void AppendArrayVariantOfStrings(dbus::MessageWriter* dict_writer,
262 const UUIDList& strings) {
263 dbus::MessageWriter strings_array_variant(nullptr);
264 dict_writer->OpenVariant("as", &strings_array_variant);
265 strings_array_variant.AppendArrayOfStrings(strings);
266 dict_writer->CloseContainer(&strings_array_variant);
267 }
268
261 void AppendType(dbus::MessageWriter* array_writer) { 269 void AppendType(dbus::MessageWriter* array_writer) {
262 dbus::MessageWriter dict_entry_writer(NULL); 270 dbus::MessageWriter dict_entry_writer(NULL);
263 array_writer->OpenDictEntry(&dict_entry_writer); 271 array_writer->OpenDictEntry(&dict_entry_writer);
264 dict_entry_writer.AppendString(bluetooth_advertisement::kTypeProperty); 272 dict_entry_writer.AppendString(bluetooth_advertisement::kTypeProperty);
265 if (type_ == ADVERTISEMENT_TYPE_BROADCAST) { 273 if (type_ == ADVERTISEMENT_TYPE_BROADCAST) {
266 dict_entry_writer.AppendString("broadcast"); 274 dict_entry_writer.AppendVariantOfString("broadcast");
267 } else { 275 } else {
268 dict_entry_writer.AppendString("peripheral"); 276 dict_entry_writer.AppendVariantOfString("peripheral");
269 } 277 }
270 array_writer->CloseContainer(&dict_entry_writer); 278 array_writer->CloseContainer(&dict_entry_writer);
271 } 279 }
272 280
273 void AppendServiceUUIDs(dbus::MessageWriter* array_writer) { 281 void AppendServiceUUIDs(dbus::MessageWriter* array_writer) {
282 if (!service_uuids_)
283 return;
274 dbus::MessageWriter dict_entry_writer(NULL); 284 dbus::MessageWriter dict_entry_writer(NULL);
275 array_writer->OpenDictEntry(&dict_entry_writer); 285 array_writer->OpenDictEntry(&dict_entry_writer);
276 dict_entry_writer.AppendString( 286 dict_entry_writer.AppendString(
277 bluetooth_advertisement::kServiceUUIDsProperty); 287 bluetooth_advertisement::kServiceUUIDsProperty);
278 dict_entry_writer.AppendArrayOfStrings(*service_uuids_); 288 AppendArrayVariantOfStrings(&dict_entry_writer, *service_uuids_);
279 array_writer->CloseContainer(&dict_entry_writer); 289 array_writer->CloseContainer(&dict_entry_writer);
280 } 290 }
281 291
282 void AppendManufacturerData(dbus::MessageWriter* array_writer) { 292 void AppendManufacturerData(dbus::MessageWriter* array_writer) {
293 if (!manufacturer_data_)
294 return;
283 dbus::MessageWriter dict_entry_writer(NULL); 295 dbus::MessageWriter dict_entry_writer(NULL);
284 array_writer->OpenDictEntry(&dict_entry_writer); 296 array_writer->OpenDictEntry(&dict_entry_writer);
285 dict_entry_writer.AppendString( 297 dict_entry_writer.AppendString(
286 bluetooth_advertisement::kManufacturerDataProperty); 298 bluetooth_advertisement::kManufacturerDataProperty);
287 dbus::MessageWriter variant_writer(NULL); 299 dbus::MessageWriter variant_writer(NULL);
288 dict_entry_writer.OpenVariant("a{qay}", &variant_writer); 300 dict_entry_writer.OpenVariant("a{qay}", &variant_writer);
289 AppendManufacturerDataVariant(&variant_writer); 301 AppendManufacturerDataVariant(&variant_writer);
290 dict_entry_writer.CloseContainer(&variant_writer); 302 dict_entry_writer.CloseContainer(&variant_writer);
291 array_writer->CloseContainer(&dict_entry_writer); 303 array_writer->CloseContainer(&dict_entry_writer);
292 } 304 }
293 305
294 void AppendSolicitUUIDs(dbus::MessageWriter* array_writer) { 306 void AppendSolicitUUIDs(dbus::MessageWriter* array_writer) {
307 if (!solicit_uuids_)
308 return;
295 dbus::MessageWriter dict_entry_writer(NULL); 309 dbus::MessageWriter dict_entry_writer(NULL);
296 array_writer->OpenDictEntry(&dict_entry_writer); 310 array_writer->OpenDictEntry(&dict_entry_writer);
297 dict_entry_writer.AppendString( 311 dict_entry_writer.AppendString(
298 bluetooth_advertisement::kSolicitUUIDsProperty); 312 bluetooth_advertisement::kSolicitUUIDsProperty);
299 dict_entry_writer.AppendArrayOfStrings(*solicit_uuids_); 313 AppendArrayVariantOfStrings(&dict_entry_writer, *solicit_uuids_);
300 array_writer->CloseContainer(&dict_entry_writer); 314 array_writer->CloseContainer(&dict_entry_writer);
301 } 315 }
302 316
303 void AppendServiceData(dbus::MessageWriter* array_writer) { 317 void AppendServiceData(dbus::MessageWriter* array_writer) {
318 if (!service_data_)
319 return;
304 dbus::MessageWriter dict_entry_writer(NULL); 320 dbus::MessageWriter dict_entry_writer(NULL);
305 array_writer->OpenDictEntry(&dict_entry_writer); 321 array_writer->OpenDictEntry(&dict_entry_writer);
306 dict_entry_writer.AppendString( 322 dict_entry_writer.AppendString(
307 bluetooth_advertisement::kServiceDataProperty); 323 bluetooth_advertisement::kServiceDataProperty);
308 dbus::MessageWriter variant_writer(NULL); 324 dbus::MessageWriter variant_writer(NULL);
309 dict_entry_writer.OpenVariant("a{say}", &variant_writer); 325 dict_entry_writer.OpenVariant("a{say}", &variant_writer);
310 AppendServiceDataVariant(&variant_writer); 326 AppendServiceDataVariant(&variant_writer);
311 dict_entry_writer.CloseContainer(&variant_writer); 327 dict_entry_writer.CloseContainer(&variant_writer);
312 array_writer->CloseContainer(&dict_entry_writer); 328 array_writer->CloseContainer(&dict_entry_writer);
313 } 329 }
314 330
315 void AppendManufacturerDataVariant(dbus::MessageWriter* writer) { 331 void AppendManufacturerDataVariant(dbus::MessageWriter* writer) {
332 DCHECK(manufacturer_data_);
316 dbus::MessageWriter array_writer(NULL); 333 dbus::MessageWriter array_writer(NULL);
317 writer->OpenArray("{qay}", &array_writer); 334 writer->OpenArray("{qay}", &array_writer);
318 for (const auto& m : *manufacturer_data_) { 335 for (const auto& m : *manufacturer_data_) {
319 dbus::MessageWriter entry_writer(NULL); 336 dbus::MessageWriter entry_writer(NULL);
320 337
321 array_writer.OpenDictEntry(&entry_writer); 338 array_writer.OpenDictEntry(&entry_writer);
322 339
323 entry_writer.AppendUint32(m.first); 340 entry_writer.AppendUint32(m.first);
324 entry_writer.AppendArrayOfBytes(vector_as_array(&m.second), 341 entry_writer.AppendArrayOfBytes(vector_as_array(&m.second),
325 m.second.size()); 342 m.second.size());
326 343
327 array_writer.CloseContainer(&entry_writer); 344 array_writer.CloseContainer(&entry_writer);
328 } 345 }
329 writer->CloseContainer(&array_writer); 346 writer->CloseContainer(&array_writer);
330 } 347 }
331 348
332 void AppendServiceDataVariant(dbus::MessageWriter* writer) { 349 void AppendServiceDataVariant(dbus::MessageWriter* writer) {
350 DCHECK(service_data_);
333 dbus::MessageWriter array_writer(NULL); 351 dbus::MessageWriter array_writer(NULL);
334 writer->OpenArray("{say}", &array_writer); 352 writer->OpenArray("{say}", &array_writer);
335 for (const auto& m : *service_data_) { 353 for (const auto& m : *service_data_) {
336 dbus::MessageWriter entry_writer(NULL); 354 dbus::MessageWriter entry_writer(NULL);
337 355
338 array_writer.OpenDictEntry(&entry_writer); 356 array_writer.OpenDictEntry(&entry_writer);
339 357
340 entry_writer.AppendString(m.first); 358 entry_writer.AppendVariantOfString(m.first);
341 entry_writer.AppendArrayOfBytes(vector_as_array(&m.second), 359 entry_writer.AppendArrayOfBytes(vector_as_array(&m.second),
342 m.second.size()); 360 m.second.size());
343 361
344 array_writer.CloseContainer(&entry_writer); 362 array_writer.CloseContainer(&entry_writer);
345 } 363 }
346 writer->CloseContainer(&array_writer); 364 writer->CloseContainer(&array_writer);
347 } 365 }
348 366
349 // Origin thread (i.e. the UI thread in production). 367 // Origin thread (i.e. the UI thread in production).
350 base::PlatformThreadId origin_thread_id_; 368 base::PlatformThreadId origin_thread_id_;
(...skipping 50 matching lines...) Expand 10 before | Expand all | Expand 10 after
401 return make_scoped_ptr(new BluetoothAdvertisementServiceProviderImpl( 419 return make_scoped_ptr(new BluetoothAdvertisementServiceProviderImpl(
402 bus, object_path, delegate, type, service_uuids.Pass(), 420 bus, object_path, delegate, type, service_uuids.Pass(),
403 manufacturer_data.Pass(), solicit_uuids.Pass(), service_data.Pass())); 421 manufacturer_data.Pass(), solicit_uuids.Pass(), service_data.Pass()));
404 } else { 422 } else {
405 return make_scoped_ptr( 423 return make_scoped_ptr(
406 new FakeBluetoothLEAdvertisementServiceProvider(object_path, delegate)); 424 new FakeBluetoothLEAdvertisementServiceProvider(object_path, delegate));
407 } 425 }
408 } 426 }
409 427
410 } // namespace chromeos 428 } // namespace chromeos
OLDNEW
« no previous file with comments | « no previous file | chromeos/dbus/bluetooth_le_advertising_manager_client.cc » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698