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 3 // found in the LICENSE file. 4 5 #ifndef DEVICE_BLUETOOTH_BLUETOOTH_UUID_H_ 6 #define DEVICE_BLUETOOTH_BLUETOOTH_UUID_H_ 7 8 #include <string> 9 10 #include "build/build_config.h" 11 #include "device/bluetooth/bluetooth_export.h" 12 13 #if defined(OS_WIN) 14 #include <rpc.h> 15 16 #include "base/strings/string_piece_forward.h" 17 #endif // defined(OS_WIN) 18 19 namespace device { 20 21 // Opaque wrapper around a Bluetooth UUID. Instances of UUID represent the 22 // 128-bit universally unique identifiers (UUIDs) of profiles and attributes 23 // used in Bluetooth based communication, such as a peripheral's services, 24 // characteristics, and characteristic descriptors. An instance are 25 // constructed using a string representing 16, 32, or 128 bit UUID formats. 26 class DEVICE_BLUETOOTH_EXPORT BluetoothUUID { 27 public: 28 // Possible representation formats used during construction. 29 enum Format { 30 kFormatInvalid, 31 kFormat16Bit, 32 kFormat32Bit, 33 kFormat128Bit 34 }; 35 36 // Single argument constructor. |uuid| can be a 16, 32, or 128 bit UUID 37 // represented as a 4, 8, or 36 character string with the following 38 // formats: 39 // xxxx 40 // 0xxxxx 41 // xxxxxxxx 42 // 0xxxxxxxxx 43 // xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx 44 // 45 // 16 and 32 bit UUIDs will be internally converted to a 128 bit UUID using 46 // the base UUID defined in the Bluetooth specification, hence custom UUIDs 47 // should be provided in the 128-bit format. If |uuid| is in an unsupported 48 // format, the result might be invalid. Use IsValid to check for validity 49 // after construction. 50 explicit BluetoothUUID(const std::string& uuid); 51 52 #if defined(OS_WIN) 53 // Windows exclusive constructor converting a GUID structure to a 54 // BluetoothUUID. This will always result in a 128 bit Format. 55 explicit BluetoothUUID(GUID uuid); 56 #endif // defined(OS_WIN) 57 58 // Default constructor does nothing. Since BluetoothUUID is copyable, this 59 // constructor is useful for initializing member variables and assigning a 60 // value to them later. The default constructor will initialize an invalid 61 // UUID by definition and the string accessors will return an empty string. 62 BluetoothUUID(); 63 virtual ~BluetoothUUID(); 64 65 #if defined(OS_WIN) 66 // The canonical UUID string format is device::BluetoothUUID.value(). 67 static GUID GetCanonicalValueAsGUID(base::StringPiece uuid); 68 #endif // defined(OS_WIN) 69 70 // Returns true, if the UUID is in a valid canonical format. 71 bool IsValid() const; 72 73 // Returns the representation format of the UUID. This reflects the format 74 // that was provided during construction. 75 Format format() const { return format_; } 76 77 // Returns the value of the UUID as a string. The representation format is 78 // based on what was passed in during construction. For the supported sizes, 79 // this representation can have the following formats: 80 // - 16 bit: xxxx 81 // - 32 bit: xxxxxxxx 82 // - 128 bit: xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx 83 // where x is a lowercase hex digit. 84 const std::string& value() const { return value_; } 85 86 // Returns the underlying 128-bit value as a string in the following format: 87 // xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx 88 // where x is a lowercase hex digit. 89 const std::string& canonical_value() const { return canonical_value_; } 90 91 // Permit sufficient comparison to allow a UUID to be used as a key in a 92 // std::map. 93 bool operator<(const BluetoothUUID& uuid) const; 94 95 // Equality operators. 96 bool operator==(const BluetoothUUID& uuid) const; 97 bool operator!=(const BluetoothUUID& uuid) const; 98 99 private: 100 // String representation of the UUID that was used during construction. For 101 // the supported sizes, this representation can have the following formats: 102 // - 16 bit: xxxx 103 // - 32 bit: xxxxxxxx 104 // - 128 bit: xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx 105 Format format_; 106 std::string value_; 107 108 // The 128-bit string representation of the UUID. 109 std::string canonical_value_; 110 }; 111 112 // This is required by gtest to print a readable output on test failures. 113 void DEVICE_BLUETOOTH_EXPORT 114 PrintTo(const BluetoothUUID& uuid, std::ostream* out); 115 116 struct BluetoothUUIDHash { 117 size_t operator()(const device::BluetoothUUID& uuid) const { 118 return std::hash<std::string>()(uuid.canonical_value()); 119 } 120 }; 121 122 } // namespace device 123 124 #endif // DEVICE_BLUETOOTH_BLUETOOTH_UUID_H_ 125