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.
Dependents: microbit-dal microbit-dal microbit-ble-open microbit-dal ... more
Fork of BLE_API by
Diff: public/GattCharacteristic.h
- Revision:
- 249:5d9118449482
- Parent:
- 247:0aa24096bec1
- Child:
- 252:69d049317cae
diff -r 792e326c2dfd -r 5d9118449482 public/GattCharacteristic.h
--- a/public/GattCharacteristic.h Fri Dec 12 13:32:23 2014 +0000
+++ b/public/GattCharacteristic.h Fri Dec 12 13:32:24 2014 +0000
@@ -18,6 +18,8 @@
#define __GATT_CHARACTERISTIC_H__
#include "GattAttribute.h"
+#include "GattCharacteristicWriteCBParams.h"
+#include "FunctionPointerWithContext.h"
class GattCharacteristic {
public:
@@ -310,24 +312,65 @@
* A pointer to an array of descriptors to be included within this characteristic
* @param[in] numDescriptors
* The number of descriptors
+ * @param[in] writeAuthorizationIn
+ * Do the attribute(s) of this characteristic have write
+ * authorization enabled? if so, Write Authorization will be
+ * requested from the application on every write request
+ * operation (but not write command).
*
* @NOTE: If valuePtr == NULL, initialLength == 0, and properties == READ
* for the value attribute of a characteristic, then that particular
* characteristic may be considered optional and dropped while
* instantiating the service with the underlying BLE stack.
*/
- GattCharacteristic(const UUID &uuid, uint8_t *valuePtr = NULL, uint16_t initialLen = 0, uint16_t maxLen = 0,
- uint8_t props = BLE_GATT_CHAR_PROPERTIES_NONE,
- GattAttribute *descriptors[] = NULL, unsigned numDescriptors = 0) :
- _valueAttribute(uuid, valuePtr, initialLen, maxLen), _properties(props), _descriptors(descriptors), _descriptorCount(numDescriptors) {
+ GattCharacteristic(const UUID &uuid,
+ uint8_t *valuePtr = NULL,
+ uint16_t initialLen = 0,
+ uint16_t maxLen = 0,
+ uint8_t props = BLE_GATT_CHAR_PROPERTIES_NONE,
+ GattAttribute *descriptors[] = NULL,
+ unsigned numDescriptors = 0) :
+ _valueAttribute(uuid, valuePtr, initialLen, maxLen),
+ _properties(props),
+ _descriptors(descriptors),
+ _descriptorCount(numDescriptors),
+ enableWriteAuthorization(false),
+ writeAuthorizationCallback() {
+ /* empty */
}
public:
- GattAttribute& getValueAttribute() {return _valueAttribute; }
- const GattAttribute& getValueAttribute() const {return _valueAttribute; }
- GattAttribute::Handle_t getValueHandle(void) const {return getValueAttribute().getHandle();}
- uint8_t getProperties(void) const {return _properties; }
- uint8_t getDescriptorCount(void) const {return _descriptorCount;}
+ /**
+ * Setup write authorization.
+ */
+ void setWriteAuthorizationCallback(void (*callback)(GattCharacteristicWriteAuthCBParams *)) {
+ enableWriteAuthorization = true;
+ writeAuthorizationCallback.attach(callback);
+ }
+ template <typename T>
+ void setWriteAuthorizationCallback(T *object, void (T::*member)(GattCharacteristicWriteAuthCBParams *)) {
+ enableWriteAuthorization = true;
+ writeAuthorizationCallback.attach(object, member);
+ }
+
+ /**
+ * Helper function meant to be called from the guts of the BLE stack to
+ * determine the authorization reply for a write request.
+ * @param params to capture the context of the write-auth request; and also contains an out-parameter for reply.
+ * @return true if the write is authorized to proceed.
+ */
+ bool authorizeWrite(GattCharacteristicWriteAuthCBParams *params) {
+ params->authorizationReply = true; /* initialized to true by default */
+ writeAuthorizationCallback.call(params);
+ return params->authorizationReply;
+ }
+
+ GattAttribute& getValueAttribute() {return _valueAttribute; }
+ const GattAttribute& getValueAttribute() const {return _valueAttribute; }
+ GattAttribute::Handle_t getValueHandle(void) const {return getValueAttribute().getHandle();}
+ uint8_t getProperties(void) const {return _properties; }
+ uint8_t getDescriptorCount(void) const {return _descriptorCount;}
+ bool isWriteAuthorizationEnabled() const {return enableWriteAuthorization;}
GattAttribute *getDescriptor(uint8_t index) {
if (index >= _descriptorCount) {
@@ -342,6 +385,8 @@
uint8_t _properties;
GattAttribute **_descriptors;
uint8_t _descriptorCount;
+ bool enableWriteAuthorization;
+ FunctionPointerWithContext<GattCharacteristicWriteAuthCBParams *> writeAuthorizationCallback;
private:
/* disallow copy and assignment */
