Fixes to BLE_API for mbedOS Alpha1 release. Mostly relating to doxygen fixes.
Fork of BLE_API by
public/GattServer.h@116:ca826083980e, 2014-09-02 (annotated)
- Committer:
- Rohit Grover
- Date:
- Tue Sep 02 15:09:46 2014 +0100
- Revision:
- 116:ca826083980e
- Parent:
- 114:f1ede142a78f
- Child:
- 118:620d28e7a1ba
Release 0.1.0
=============
Mostly API changes.
Features
~~~~~~~~
- onConnection() callback now receives connection-parameters applicable to the
new connection.
- onDataSent() callback now receives a count parameter containing the number of
times notifications were sent out since the last callback.
- A 'reason' parameter has been added to Gap::disconnect() to indicate the
reason for disconnection; and also to the onDisconnection callback to
receive a reason from the remote host.
Bugfixes
~~~~~~~~
- onDataWritten() callback now receives an additional parameter
(GattServer::WriteEventCallback_t) encapsulating the update. This avoids
having to re-fetch the updated characteristic's value attribute. It also
fixes a bug where multiple updates to the characteristic's value-attribute
could get clobbered if they occurred in quick succession before the
callbacks could be processed.
Who changed what in which revision?
User | Revision | Line number | New contents of line |
---|---|---|---|
Rohit Grover |
106:a20be740075d | 1 | /* mbed Microcontroller Library |
Rohit Grover |
106:a20be740075d | 2 | * Copyright (c) 2006-2013 ARM Limited |
Rohit Grover |
106:a20be740075d | 3 | * |
Rohit Grover |
106:a20be740075d | 4 | * Licensed under the Apache License, Version 2.0 (the "License"); |
Rohit Grover |
106:a20be740075d | 5 | * you may not use this file except in compliance with the License. |
Rohit Grover |
106:a20be740075d | 6 | * You may obtain a copy of the License at |
Rohit Grover |
106:a20be740075d | 7 | * |
Rohit Grover |
106:a20be740075d | 8 | * http://www.apache.org/licenses/LICENSE-2.0 |
Rohit Grover |
106:a20be740075d | 9 | * |
Rohit Grover |
106:a20be740075d | 10 | * Unless required by applicable law or agreed to in writing, software |
Rohit Grover |
106:a20be740075d | 11 | * distributed under the License is distributed on an "AS IS" BASIS, |
Rohit Grover |
106:a20be740075d | 12 | * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
Rohit Grover |
106:a20be740075d | 13 | * See the License for the specific language governing permissions and |
Rohit Grover |
106:a20be740075d | 14 | * limitations under the License. |
Rohit Grover |
106:a20be740075d | 15 | */ |
Rohit Grover |
106:a20be740075d | 16 | |
Rohit Grover |
106:a20be740075d | 17 | #ifndef __GATT_SERVER_H__ |
Rohit Grover |
106:a20be740075d | 18 | #define __GATT_SERVER_H__ |
Rohit Grover |
106:a20be740075d | 19 | |
Rohit Grover |
106:a20be740075d | 20 | #include "mbed.h" |
Rohit Grover |
106:a20be740075d | 21 | #include "blecommon.h" |
Rohit Grover |
106:a20be740075d | 22 | #include "GattService.h" |
Rohit Grover |
106:a20be740075d | 23 | #include "GattServerEvents.h" |
Rohit Grover |
116:ca826083980e | 24 | #include "GattCharacteristicWriteCBParams.h" |
Rohit Grover |
106:a20be740075d | 25 | |
Rohit Grover |
106:a20be740075d | 26 | /**************************************************************************/ |
Rohit Grover |
106:a20be740075d | 27 | /*! |
Rohit Grover |
106:a20be740075d | 28 | \brief |
Rohit Grover |
106:a20be740075d | 29 | The base class used to abstract GATT Server functionality to a specific |
Rohit Grover |
106:a20be740075d | 30 | radio transceiver, SOC or BLE Stack. |
Rohit Grover |
106:a20be740075d | 31 | */ |
Rohit Grover |
106:a20be740075d | 32 | /**************************************************************************/ |
Rohit Grover |
106:a20be740075d | 33 | class GattServer |
Rohit Grover |
106:a20be740075d | 34 | { |
Rohit Grover |
106:a20be740075d | 35 | public: |
Rohit Grover |
106:a20be740075d | 36 | /* These functions must be defined in the sub-class */ |
Rohit Grover |
106:a20be740075d | 37 | virtual ble_error_t addService(GattService &) = 0; |
Rohit Grover |
106:a20be740075d | 38 | virtual ble_error_t readValue(uint16_t handle, uint8_t buffer[], uint16_t *const lengthP) = 0; |
Rohit Grover |
106:a20be740075d | 39 | virtual ble_error_t updateValue(uint16_t, uint8_t[], uint16_t, bool localOnly = false) = 0; |
Rohit Grover |
106:a20be740075d | 40 | |
Rohit Grover |
106:a20be740075d | 41 | // ToDo: For updateValue, check the CCCD to see if the value we are |
Rohit Grover |
106:a20be740075d | 42 | // updating has the notify or indicate bits sent, and if BOTH are set |
Rohit Grover |
106:a20be740075d | 43 | // be sure to call sd_ble_gatts_hvx() twice with notify then indicate! |
Rohit Grover |
106:a20be740075d | 44 | // Strange use case, but valid and must be covered! |
Rohit Grover |
106:a20be740075d | 45 | |
Rohit Grover |
106:a20be740075d | 46 | /* Event callback handlers. */ |
Rohit Grover |
106:a20be740075d | 47 | typedef void (*EventCallback_t)(uint16_t attributeHandle); |
Rohit Grover |
116:ca826083980e | 48 | typedef void (*WriteEventCallback_t)(uint16_t attributeHandle, const GattCharacteristicWriteCBParams *eventDataP); |
Rohit Grover |
116:ca826083980e | 49 | typedef void (*ServerEventCallback_t)(void); /**< independent of any particular attribute */ |
Rohit Grover |
116:ca826083980e | 50 | typedef void (*ServerEventCallbackWithCount_t)(unsigned count); /**< independent of any particular attribute */ |
Rohit Grover |
116:ca826083980e | 51 | void setOnDataSent(ServerEventCallbackWithCount_t callback) { |
Rohit Grover |
106:a20be740075d | 52 | onDataSent = callback; |
Rohit Grover |
106:a20be740075d | 53 | } |
Rohit Grover |
116:ca826083980e | 54 | void setOnDataWritten(WriteEventCallback_t callback) { |
Rohit Grover |
106:a20be740075d | 55 | onDataWritten = callback; |
Rohit Grover |
106:a20be740075d | 56 | } |
Rohit Grover |
106:a20be740075d | 57 | void setOnUpdatesEnabled(EventCallback_t callback) { |
Rohit Grover |
106:a20be740075d | 58 | onUpdatesEnabled = callback; |
Rohit Grover |
106:a20be740075d | 59 | } |
Rohit Grover |
106:a20be740075d | 60 | void setOnUpdatesDisabled(EventCallback_t callback) { |
Rohit Grover |
106:a20be740075d | 61 | onUpdatesDisabled = callback; |
Rohit Grover |
106:a20be740075d | 62 | } |
Rohit Grover |
106:a20be740075d | 63 | void setOnConfirmationReceived(EventCallback_t callback) { |
Rohit Grover |
106:a20be740075d | 64 | onConfirmationReceived = callback; |
Rohit Grover |
106:a20be740075d | 65 | } |
Rohit Grover |
106:a20be740075d | 66 | |
Rohit Grover |
116:ca826083980e | 67 | void handleDataWrittenEvent(uint16_t charHandle, const GattCharacteristicWriteCBParams *params) { |
Rohit Grover |
116:ca826083980e | 68 | if (onDataWritten) { |
Rohit Grover |
116:ca826083980e | 69 | onDataWritten(charHandle, params); |
Rohit Grover |
116:ca826083980e | 70 | } |
Rohit Grover |
116:ca826083980e | 71 | } |
Rohit Grover |
116:ca826083980e | 72 | |
Rohit Grover |
106:a20be740075d | 73 | void handleEvent(GattServerEvents::gattEvent_e type, uint16_t charHandle) { |
Rohit Grover |
106:a20be740075d | 74 | switch (type) { |
Rohit Grover |
106:a20be740075d | 75 | case GattServerEvents::GATT_EVENT_UPDATES_ENABLED: |
Rohit Grover |
106:a20be740075d | 76 | if (onUpdatesEnabled) { |
Rohit Grover |
106:a20be740075d | 77 | onUpdatesEnabled(charHandle); |
Rohit Grover |
106:a20be740075d | 78 | } |
Rohit Grover |
106:a20be740075d | 79 | break; |
Rohit Grover |
106:a20be740075d | 80 | case GattServerEvents::GATT_EVENT_UPDATES_DISABLED: |
Rohit Grover |
106:a20be740075d | 81 | if (onUpdatesDisabled) { |
Rohit Grover |
106:a20be740075d | 82 | onUpdatesDisabled(charHandle); |
Rohit Grover |
106:a20be740075d | 83 | } |
Rohit Grover |
106:a20be740075d | 84 | break; |
Rohit Grover |
106:a20be740075d | 85 | case GattServerEvents::GATT_EVENT_CONFIRMATION_RECEIVED: |
Rohit Grover |
106:a20be740075d | 86 | if (onConfirmationReceived) { |
Rohit Grover |
106:a20be740075d | 87 | onConfirmationReceived(charHandle); |
Rohit Grover |
106:a20be740075d | 88 | } |
Rohit Grover |
106:a20be740075d | 89 | break; |
Rohit Grover |
106:a20be740075d | 90 | } |
Rohit Grover |
106:a20be740075d | 91 | } |
Rohit Grover |
106:a20be740075d | 92 | |
Rohit Grover |
116:ca826083980e | 93 | void handleDataSentEvent(unsigned count) { |
Rohit Grover |
116:ca826083980e | 94 | if (onDataSent) { |
Rohit Grover |
116:ca826083980e | 95 | onDataSent(count); |
Rohit Grover |
106:a20be740075d | 96 | } |
Rohit Grover |
106:a20be740075d | 97 | } |
Rohit Grover |
106:a20be740075d | 98 | |
Rohit Grover |
106:a20be740075d | 99 | protected: |
Rohit Grover |
106:a20be740075d | 100 | GattServer() : serviceCount(0), characteristicCount(0), onDataSent(NULL), onDataWritten(NULL), onUpdatesEnabled(NULL), onUpdatesDisabled(NULL), onConfirmationReceived(NULL) { |
Rohit Grover |
106:a20be740075d | 101 | /* empty */ |
Rohit Grover |
106:a20be740075d | 102 | } |
Rohit Grover |
106:a20be740075d | 103 | |
Rohit Grover |
106:a20be740075d | 104 | protected: |
Rohit Grover |
106:a20be740075d | 105 | uint8_t serviceCount; |
Rohit Grover |
106:a20be740075d | 106 | uint8_t characteristicCount; |
carlescufi | 114:f1ede142a78f | 107 | uint8_t descriptorCount; |
Rohit Grover |
106:a20be740075d | 108 | |
Rohit Grover |
106:a20be740075d | 109 | private: |
Rohit Grover |
116:ca826083980e | 110 | ServerEventCallbackWithCount_t onDataSent; |
Rohit Grover |
116:ca826083980e | 111 | WriteEventCallback_t onDataWritten; |
Rohit Grover |
116:ca826083980e | 112 | EventCallback_t onUpdatesEnabled; |
Rohit Grover |
116:ca826083980e | 113 | EventCallback_t onUpdatesDisabled; |
Rohit Grover |
116:ca826083980e | 114 | EventCallback_t onConfirmationReceived; |
Rohit Grover |
106:a20be740075d | 115 | }; |
Rohit Grover |
106:a20be740075d | 116 | |
Rohit Grover |
106:a20be740075d | 117 | #endif // ifndef __GATT_SERVER_H__ |