Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
ReadWriteArrayGattCharacteristic< T, NUM_ELEMENTS > Class Template Reference
Helper class to construct a readable and writable GattCharacteristic with an array value. More...
#include <GattCharacteristic.h>
Inherits GattCharacteristic.
| Public Types | |
| enum | { BLE_GATT_UNIT_NONE = 0x2700, BLE_GATT_UNIT_LENGTH_METRE = 0x2701, BLE_GATT_UNIT_MASS_KILOGRAM = 0x2702, BLE_GATT_UNIT_TIME_SECOND = 0x2703, BLE_GATT_UNIT_ELECTRIC_CURRENT_AMPERE = 0x2704, BLE_GATT_UNIT_THERMODYNAMIC_TEMPERATURE_KELVIN = 0x2705, BLE_GATT_UNIT_AMOUNT_OF_SUBSTANCE_MOLE = 0x2706, BLE_GATT_UNIT_LUMINOUS_INTENSITY_CANDELA = 0x2707, BLE_GATT_UNIT_AREA_SQUARE_METRES = 0x2710, BLE_GATT_UNIT_VOLUME_CUBIC_METRES = 0x2711, BLE_GATT_UNIT_VELOCITY_METRES_PER_SECOND = 0x2712, BLE_GATT_UNIT_ACCELERATION_METRES_PER_SECOND_SQUARED = 0x2713, BLE_GATT_UNIT_WAVENUMBER_RECIPROCAL_METRE = 0x2714, BLE_GATT_UNIT_DENSITY_KILOGRAM_PER_CUBIC_METRE = 0x2715 , BLE_GATT_UNIT_MAGNETIC_FIELD_STRENGTH_AMPERE_PER_METRE = 0x2719 , BLE_GATT_UNIT_FREQUENCY_HERTZ = 0x2722, BLE_GATT_UNIT_FORCE_NEWTON = 0x2723, BLE_GATT_UNIT_PRESSURE_PASCAL = 0x2724, BLE_GATT_UNIT_ENERGY_JOULE = 0x2725, BLE_GATT_UNIT_POWER_WATT = 0x2726, BLE_GATT_UNIT_ELECTRIC_CHARGE_COULOMB = 0x2727, BLE_GATT_UNIT_ELECTRIC_POTENTIAL_DIFFERENCE_VOLT = 0x2728 , BLE_GATT_UNIT_TIME_MINUTE = 0x2760, BLE_GATT_UNIT_TIME_HOUR = 0x2761, BLE_GATT_UNIT_TIME_DAY = 0x2762 , BLE_GATT_UNIT_PRESSURE_BAR = 0x2780, BLE_GATT_UNIT_PRESSURE_MILLIMETRE_OF_MERCURY = 0x2781 , BLE_GATT_UNIT_LENGTH_YARD = 0x27A0, BLE_GATT_UNIT_LENGTH_PARSEC = 0x27A1, BLE_GATT_UNIT_LENGTH_INCH = 0x27A2, BLE_GATT_UNIT_LENGTH_FOOT = 0x27A3, BLE_GATT_UNIT_LENGTH_MILE = 0x27A4 , BLE_GATT_UNIT_VELOCITY_KILOMETRE_PER_HOUR = 0x27A6, BLE_GATT_UNIT_VELOCITY_MILE_PER_HOUR = 0x27A7, BLE_GATT_UNIT_ANGULAR_VELOCITY_REVOLUTION_PER_MINUTE = 0x27A8, BLE_GATT_UNIT_ENERGY_GRAM_CALORIE = 0x27A9, BLE_GATT_UNIT_ENERGY_KILOGRAM_CALORIE = 0x27AA, BLE_GATT_UNIT_ENERGY_KILOWATT_HOUR = 0x27AB , BLE_GATT_UNIT_PERCENTAGE = 0x27AD , BLE_GATT_UNIT_TIME_YEAR = 0x27B3, BLE_GATT_UNIT_TIME_MONTH = 0x27B4 } | 
| Standard GATT characteristic presentation format unit types.More... | |
| enum | { BLE_GATT_FORMAT_RFU = 0x00, BLE_GATT_FORMAT_BOOLEAN = 0x01, BLE_GATT_FORMAT_2BIT = 0x02, BLE_GATT_FORMAT_NIBBLE = 0x03, BLE_GATT_FORMAT_UINT8 = 0x04, BLE_GATT_FORMAT_UINT12 = 0x05, BLE_GATT_FORMAT_UINT16 = 0x06, BLE_GATT_FORMAT_UINT24 = 0x07, BLE_GATT_FORMAT_UINT32 = 0x08, BLE_GATT_FORMAT_UINT48 = 0x09, BLE_GATT_FORMAT_UINT64 = 0x0A, BLE_GATT_FORMAT_UINT128 = 0x0B, BLE_GATT_FORMAT_SINT8 = 0x0C, BLE_GATT_FORMAT_SINT12 = 0x0D, BLE_GATT_FORMAT_SINT16 = 0x0E, BLE_GATT_FORMAT_SINT24 = 0x0F, BLE_GATT_FORMAT_SINT32 = 0x10, BLE_GATT_FORMAT_SINT48 = 0x11, BLE_GATT_FORMAT_SINT64 = 0x12, BLE_GATT_FORMAT_SINT128 = 0x13, BLE_GATT_FORMAT_FLOAT32 = 0x14, BLE_GATT_FORMAT_FLOAT64 = 0x15, BLE_GATT_FORMAT_SFLOAT = 0x16, BLE_GATT_FORMAT_FLOAT = 0x17, BLE_GATT_FORMAT_DUINT16 = 0x18, BLE_GATT_FORMAT_UTF8S = 0x19, BLE_GATT_FORMAT_UTF16S = 0x1A, BLE_GATT_FORMAT_STRUCT = 0x1B } | 
| Standard GATT number types.More... | |
| enum | Properties_t { , BLE_GATT_CHAR_PROPERTIES_BROADCAST = 0x01, BLE_GATT_CHAR_PROPERTIES_READ = 0x02, BLE_GATT_CHAR_PROPERTIES_WRITE_WITHOUT_RESPONSE = 0x04, BLE_GATT_CHAR_PROPERTIES_WRITE = 0x08, BLE_GATT_CHAR_PROPERTIES_NOTIFY = 0x10, BLE_GATT_CHAR_PROPERTIES_INDICATE = 0x20, BLE_GATT_CHAR_PROPERTIES_AUTHENTICATED_SIGNED_WRITES = 0x40, BLE_GATT_CHAR_PROPERTIES_EXTENDED_PROPERTIES = 0x80 } | 
| Standard GATT characteristic properties.More... | |
| Public Member Functions | |
| ReadWriteArrayGattCharacteristic (const UUID &uuid, T valuePtr[NUM_ELEMENTS], uint8_t additionalProperties=BLE_GATT_CHAR_PROPERTIES_NONE, GattAttribute *descriptors[]=NULL, unsigned numDescriptors=0) | |
| Construct a ReadWriteGattCharacteristic. | |
| void | requireSecurity (SecurityManager::SecurityMode_t securityMode) | 
| Set up the minimum security (mode and level) requirements for access to the characteristic's value attribute. | |
| void | setWriteAuthorizationCallback (void(*callback)(GattWriteAuthCallbackParams *)) | 
| Set up callback that will be triggered before the GATT Client is allowed to write this characteristic. | |
| template<typename T > | |
| void | setWriteAuthorizationCallback (T *object, void(T::*member)(GattWriteAuthCallbackParams *)) | 
| Same as GattCharacrteristic::setWriteAuthorizationCallback(), but allows the possibility to add an object reference and member function as handler for connection event callbacks. | |
| void | setReadAuthorizationCallback (void(*callback)(GattReadAuthCallbackParams *)) | 
| Set up callback that will be triggered before the GATT Client is allowed to read this characteristic. | |
| template<typename T > | |
| void | setReadAuthorizationCallback (T *object, void(T::*member)(GattReadAuthCallbackParams *)) | 
| Same as GattCharacrteristic::setReadAuthorizationCallback(), but allows the possibility to add an object reference and member function as handler for connection event callbacks. | |
| GattAuthCallbackReply_t | authorizeWrite (GattWriteAuthCallbackParams *params) | 
| Helper that calls the registered handler to determine the authorization reply for a write request. | |
| GattAuthCallbackReply_t | authorizeRead (GattReadAuthCallbackParams *params) | 
| Helper that calls the registered handler to determine the authorization reply for a read request. | |
| GattAttribute & | getValueAttribute () | 
| Get the characteristic's value attribute. | |
| const GattAttribute & | getValueAttribute () const | 
| A const alternative to GattCharacteristic::getValueAttribute(). | |
| GattAttribute::Handle_t | getValueHandle (void) const | 
| Get the characteristic's value attribute handle in the ATT table. | |
| uint8_t | getProperties (void) const | 
| Get the characteristic's propertied. | |
| SecurityManager::SecurityMode_t | getRequiredSecurity () const | 
| Get the characteristic's required security. | |
| uint8_t | getDescriptorCount (void) const | 
| Get the total number of descriptors within this characteristic. | |
| bool | isReadAuthorizationEnabled () const | 
| Check whether read authorization is enabled i.e. | |
| bool | isWriteAuthorizationEnabled () const | 
| Check whether write authorization is enabled i.e. | |
| GattAttribute * | getDescriptor (uint8_t index) | 
| Get this characteristic's descriptor at a specific index. | |
Detailed Description
template<typename T, unsigned NUM_ELEMENTS>
 class ReadWriteArrayGattCharacteristic< T, NUM_ELEMENTS >
Helper class to construct a readable and writable GattCharacteristic with an array value.
Definition at line 819 of file GattCharacteristic.h.
Member Enumeration Documentation
| anonymous enum  [inherited] | 
Standard GATT characteristic presentation format unit types.
These unit types are used to describe what the raw numeric data in a characteristic actually represents.
Definition at line 109 of file GattCharacteristic.h.
| anonymous enum  [inherited] | 
Standard GATT number types.
- Note:
- See Bluetooth Specification 4.0 (Vol. 3), Part G, Section 3.3.3.5.2.
- See http://developer.bluetooth.org/gatt/descriptors/Pages/DescriptorViewer.aspx?u=org.bluetooth.descriptor.gatt.characteristic_presentation_format.xml
Definition at line 228 of file GattCharacteristic.h.
| enum Properties_t  [inherited] | 
Standard GATT characteristic properties.
- Note:
- See Bluetooth Specification 4.0 (Vol. 3), Part G, Section 3.3.1.1 and Section 3.3.3.1 for Extended Properties.
Definition at line 265 of file GattCharacteristic.h.
Constructor & Destructor Documentation
| ReadWriteArrayGattCharacteristic | ( | const UUID & | uuid, | 
| T | valuePtr[NUM_ELEMENTS], | ||
| uint8_t | additionalProperties = BLE_GATT_CHAR_PROPERTIES_NONE, | ||
| GattAttribute * | descriptors[] = NULL, | ||
| unsigned | numDescriptors = 0 | ||
| ) | 
Construct a ReadWriteGattCharacteristic.
- Parameters:
- 
  [in] uuid The characteristic's UUID. [in] valuePtr Pointer to an array of length NUM_ELEMENTS containing the characteristic's intitial value. [in] additionalProperties Additional characterisitic properties. By default, the properties are set to Properties_t::BLE_GATT_CHAR_PROPERTIES_WRITE | Properties_t::BLE_GATT_CHAR_PROPERTIES_READ. [in] descriptors An array of pointers to descriptors to be added to the new characteristic. [in] numDescriptors The total number of descriptors in descriptors.
- Note:
- Instances of ReadWriteGattCharacteristic have variable length attribute value with maximum size equal to sizeof(T) * NUM_ELEMENTS. For a fixed length alternative use GattCharacteristic directly.
Definition at line 844 of file GattCharacteristic.h.
Member Function Documentation
| GattAuthCallbackReply_t authorizeRead | ( | GattReadAuthCallbackParams * | params ) |  [inherited] | 
Helper that calls the registered handler to determine the authorization reply for a read request.
This function is meant to be called from the BLE stack specific implementation.
- Parameters:
- 
  [in] params To capture the context of the read-auth request. 
- Returns:
- A GattAuthCallbackReply_t value indicating whether authorization is granted.
- Note:
- To authorize or deny the read the params->authorizationReply field should be set to true (authorize) or false (deny).
- If the read is approved and params->data is unchanged (NULL), the current characteristic value will be used.
- If the read is approved, a new value can be provided by setting the params->data pointer and params->len fields.
Definition at line 463 of file GattCharacteristic.h.
| GattAuthCallbackReply_t authorizeWrite | ( | GattWriteAuthCallbackParams * | params ) |  [inherited] | 
Helper that calls the registered handler to determine the authorization reply for a write request.
This function is meant to be called from the BLE stack specific implementation.
- Parameters:
- 
  [in] params To capture the context of the write-auth request. Also contains an out-parameter for reply. 
- Returns:
- A GattAuthCallbackReply_t value indicating whether authorization is granted.
Definition at line 433 of file GattCharacteristic.h.
| GattAttribute* getDescriptor | ( | uint8_t | index ) |  [inherited] | 
Get this characteristic's descriptor at a specific index.
- Parameters:
- 
  [in] index The descriptor's index. 
- Returns:
- A pointer the requested descriptor if indexcontains a valid descriptor, or NULL otherwise.
Definition at line 563 of file GattCharacteristic.h.
| uint8_t getDescriptorCount | ( | void | ) | const  [inherited] | 
Get the total number of descriptors within this characteristic.
- Returns:
- The total number of descriptors.
Definition at line 528 of file GattCharacteristic.h.
| uint8_t getProperties | ( | void | ) | const  [inherited] | 
Get the characteristic's propertied.
Refer to GattCharacteristic::Properties_t.
- Returns:
- The characteristic's properties.
Definition at line 510 of file GattCharacteristic.h.
| SecurityManager::SecurityMode_t getRequiredSecurity | ( | ) | const  [inherited] | 
Get the characteristic's required security.
- Returns:
- The characteristic's required security.
Definition at line 519 of file GattCharacteristic.h.
| const GattAttribute& getValueAttribute | ( | ) | const  [inherited] | 
A const alternative to GattCharacteristic::getValueAttribute().
- Returns:
- A const reference to the characteristic's value attribute.
Definition at line 488 of file GattCharacteristic.h.
| GattAttribute& getValueAttribute | ( | ) |  [inherited] | 
Get the characteristic's value attribute.
- Returns:
- A reference to the characteristic's value attribute.
Definition at line 479 of file GattCharacteristic.h.
| GattAttribute::Handle_t getValueHandle | ( | void | ) | const  [inherited] | 
Get the characteristic's value attribute handle in the ATT table.
- Returns:
- The value attribute handle.
- Note:
- The attribute handle is typically assigned by the underlying BLE stack.
Definition at line 500 of file GattCharacteristic.h.
| bool isReadAuthorizationEnabled | ( | ) | const  [inherited] | 
Check whether read authorization is enabled i.e.
check whether a read authorization callback was previously registered. Refer to GattCharacteristic::setReadAuthorizationCallback().
- Returns:
- true if read authorization is enabled, false otherwise.
Definition at line 539 of file GattCharacteristic.h.
| bool isWriteAuthorizationEnabled | ( | ) | const  [inherited] | 
Check whether write authorization is enabled i.e.
check whether a write authorization callback was previously registered. Refer to GattCharacteristic::setReadAuthorizationCallback().
- Returns:
- true if write authorization is enabled, false otherwise.
Definition at line 550 of file GattCharacteristic.h.
| void requireSecurity | ( | SecurityManager::SecurityMode_t | securityMode ) |  [inherited] | 
Set up the minimum security (mode and level) requirements for access to the characteristic's value attribute.
- Parameters:
- 
  [in] securityMode Can be one of encryption or signing, with or without protection for man in the middle attacks (MITM). 
Definition at line 354 of file GattCharacteristic.h.
| void setReadAuthorizationCallback | ( | T * | object, | 
| void(T::*)(GattReadAuthCallbackParams *) | member | ||
| ) |  [inherited] | 
Same as GattCharacrteristic::setReadAuthorizationCallback(), but allows the possibility to add an object reference and member function as handler for connection event callbacks.
- Parameters:
- 
  [in] object Pointer to the object of a class defining the member callback function ( member).[in] member The member callback (within the context of an object) to be invoked. 
Definition at line 416 of file GattCharacteristic.h.
| void setReadAuthorizationCallback | ( | void(*)(GattReadAuthCallbackParams *) | callback ) |  [inherited] | 
Set up callback that will be triggered before the GATT Client is allowed to read this characteristic.
The handler will determine the authorizaion reply for the read.
- Parameters:
- 
  [in] callback Event handler being registered. 
Definition at line 398 of file GattCharacteristic.h.
| void setWriteAuthorizationCallback | ( | void(*)(GattWriteAuthCallbackParams *) | callback ) |  [inherited] | 
Set up callback that will be triggered before the GATT Client is allowed to write this characteristic.
The handler will determine the authorization reply for the write.
- Parameters:
- 
  [in] callback Event handler being registered. 
Definition at line 367 of file GattCharacteristic.h.
| void setWriteAuthorizationCallback | ( | T * | object, | 
| void(T::*)(GattWriteAuthCallbackParams *) | member | ||
| ) |  [inherited] | 
Same as GattCharacrteristic::setWriteAuthorizationCallback(), but allows the possibility to add an object reference and member function as handler for connection event callbacks.
- Parameters:
- 
  [in] object Pointer to the object of a class defining the member callback function ( member).[in] member The member callback (within the context of an object) to be invoked. 
Definition at line 385 of file GattCharacteristic.h.
Generated on Tue Jul 12 2022 13:06:10 by
 1.7.2
 1.7.2