Index: device/bluetooth/bluetooth_advertisement_chromeos.cc |
diff --git a/device/bluetooth/bluetooth_advertisement_chromeos.cc b/device/bluetooth/bluetooth_advertisement_chromeos.cc |
index 9b5f1bb682ec30e33911c5ad496beca257959f6b..8cdfe90e876ca3154fc305f58ae6384123943379 100644 |
--- a/device/bluetooth/bluetooth_advertisement_chromeos.cc |
+++ b/device/bluetooth/bluetooth_advertisement_chromeos.cc |
@@ -11,6 +11,7 @@ |
#include "base/guid.h" |
#include "base/logging.h" |
#include "base/memory/scoped_ptr.h" |
+#include "base/strings/string_util.h" |
#include "chromeos/dbus/bluetooth_le_advertising_manager_client.h" |
#include "chromeos/dbus/dbus_thread_manager.h" |
#include "dbus/bus.h" |
@@ -26,28 +27,43 @@ void UnregisterFailure(device::BluetoothAdvertisement::ErrorCode error) { |
<< error; |
} |
-void ErrorCallbackConnector( |
- const device::BluetoothAdapter::CreateAdvertisementErrorCallback& |
- error_callback, |
+device::BluetoothAdvertisement::ErrorCode GetErrorCodeFromErrorStrings( |
const std::string& error_name, |
const std::string& error_message) { |
- LOG(WARNING) << "Error while registering advertisement. error_name = " |
- << error_name << ", error_message = " << error_message; |
- device::BluetoothAdvertisement::ErrorCode error_code; |
if (error_name == bluetooth_advertising_manager::kErrorFailed || |
error_name == bluetooth_advertising_manager::kErrorAlreadyExists) { |
- error_code = device::BluetoothAdvertisement::ErrorCode:: |
+ return device::BluetoothAdvertisement::ErrorCode:: |
ERROR_ADVERTISEMENT_ALREADY_EXISTS; |
} else if (error_name == |
bluetooth_advertising_manager::kErrorInvalidArguments) { |
- error_code = device::BluetoothAdvertisement::ErrorCode:: |
+ return device::BluetoothAdvertisement::ErrorCode:: |
ERROR_ADVERTISEMENT_INVALID_LENGTH; |
} else if (error_name == bluetooth_advertising_manager::kErrorDoesNotExist) { |
- error_code = device::BluetoothAdvertisement::ErrorCode:: |
+ return device::BluetoothAdvertisement::ErrorCode:: |
ERROR_ADVERTISEMENT_DOES_NOT_EXIST; |
} |
+ return device::BluetoothAdvertisement::ErrorCode:: |
+ INVALID_ADVERTISEMENT_ERROR_CODE; |
+} |
+ |
+void RegisterErrorCallbackConnector( |
+ const device::BluetoothAdapter::CreateAdvertisementErrorCallback& |
+ error_callback, |
+ const std::string& error_name, |
+ const std::string& error_message) { |
+ LOG(ERROR) << "Error while registering advertisement. error_name = " |
+ << error_name << ", error_message = " << error_message; |
+ error_callback.Run(GetErrorCodeFromErrorStrings(error_name, error_message)); |
+} |
- error_callback.Run(error_code); |
+void UnregisterErrorCallbackConnector( |
+ const device::BluetoothAdapter::CreateAdvertisementErrorCallback& |
+ error_callback, |
+ const std::string& error_name, |
+ const std::string& error_message) { |
+ LOG(WARNING) << "Error while unregistering advertisement. error_name = " |
+ << error_name << ", error_message = " << error_message; |
+ error_callback.Run(GetErrorCodeFromErrorStrings(error_name, error_message)); |
} |
} // namespace |
@@ -58,8 +74,14 @@ BluetoothAdvertisementChromeOS::BluetoothAdvertisementChromeOS( |
scoped_ptr<device::BluetoothAdvertisement::Data> data, |
scoped_refptr<BluetoothAdapterChromeOS> adapter) |
: adapter_(adapter) { |
- dbus::ObjectPath advertisement_object_path = dbus::ObjectPath( |
- "/org/chromium/bluetooth_advertisement/" + base::GenerateGUID()); |
+ // Generate a new object path - make sure that we strip any -'s from the |
+ // generated GUID string since object paths can only contain alphanumeric |
+ // characters and _ characters. |
+ std::string GuidString = base::GenerateGUID(); |
+ base::RemoveChars(GuidString, "-", &GuidString); |
+ dbus::ObjectPath advertisement_object_path = |
+ dbus::ObjectPath("/org/chromium/bluetooth_advertisement/" + GuidString); |
+ |
DCHECK(DBusThreadManager::Get()); |
provider_ = BluetoothLEAdvertisementServiceProvider::Create( |
DBusThreadManager::Get()->GetSystemBus(), advertisement_object_path, this, |
@@ -78,7 +100,7 @@ void BluetoothAdvertisementChromeOS::Register( |
->GetBluetoothLEAdvertisingManagerClient() |
->RegisterAdvertisement( |
adapter_->object_path(), provider_->object_path(), success_callback, |
- base::Bind(&ErrorCallbackConnector, error_callback)); |
+ base::Bind(&RegisterErrorCallbackConnector, error_callback)); |
} |
BluetoothAdvertisementChromeOS::~BluetoothAdvertisementChromeOS() { |
@@ -101,7 +123,7 @@ void BluetoothAdvertisementChromeOS::Unregister( |
->GetBluetoothLEAdvertisingManagerClient() |
->UnregisterAdvertisement( |
adapter_->object_path(), provider_->object_path(), success_callback, |
- base::Bind(&ErrorCallbackConnector, error_callback)); |
+ base::Bind(&UnregisterErrorCallbackConnector, error_callback)); |
provider_.reset(); |
} |