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.
ServiceDiscovery Class Reference
[Client]
  Host callback types needed by the service discovery procedure. More...
#include <ServiceDiscovery.h>
| Public Types | |
| typedef FunctionPointerWithContext < const DiscoveredService * > | ServiceCallback_t | 
| Service discovered event handler. | |
| typedef FunctionPointerWithContext < const DiscoveredCharacteristic * > | CharacteristicCallback_t | 
| Characteristic discovered event handler. | |
| typedef FunctionPointerWithContext < Gap::Handle_t > | TerminationCallback_t | 
| Service discovery ended event. | |
| Public Member Functions | |
| virtual ble_error_t | launch (Gap::Handle_t connectionHandle, ServiceCallback_t sc=NULL, CharacteristicCallback_t cc=NULL, const UUID &matchingServiceUUID=UUID::ShortUUIDBytes_t(BLE_UUID_UNKNOWN), const UUID &matchingCharacteristicUUIDIn=UUID::ShortUUIDBytes_t(BLE_UUID_UNKNOWN))=0 | 
| Launch service discovery. | |
| virtual bool | isActive (void) const =0 | 
| Check whether service-discovery is currently active. | |
| virtual void | terminate (void)=0 | 
| Terminate an ongoing service discovery. | |
| virtual void | onTermination (TerminationCallback_t callback)=0 | 
| Set up a callback to be invoked when service discovery is terminated. | |
| virtual ble_error_t | reset (void) | 
| Clear all ServiceDiscovery state of the associated object. | |
| Protected Attributes | |
| Gap::Handle_t | connHandle | 
| Connection handle as provided by the SoftDevice. | |
| UUID | matchingServiceUUID | 
| UUID-based filter that specifies the service that the application is interested in. | |
| ServiceCallback_t | serviceCallback | 
| The registered callback handle for when a matching service is found during service-discovery. | |
| UUID | matchingCharacteristicUUID | 
| UUID-based filter that specifies the characteristic that the application is interested in. | |
| CharacteristicCallback_t | characteristicCallback | 
| The registered callback handler for when a matching characteristic is found during service-discovery. | |
Detailed Description
Host callback types needed by the service discovery procedure.
This class is also an interface that may be used in vendor port to model the service discovery process. This interface is not used in user code.
- Attention:
- Implementing this interface is not a requirement for the implementation of the service discover process.
Definition at line 45 of file ServiceDiscovery.h.
Member Typedef Documentation
| typedef FunctionPointerWithContext<const DiscoveredCharacteristic *> CharacteristicCallback_t | 
Characteristic discovered event handler.
The callback accepts a pointer to a DiscoveredCharacteristic as parameter.
- Attention:
- The argument passed to the callback may not persist after the callback invocation; therefore, the callbacks must make a shallow copy of the DiscoveredCharacteristic passed as parameter to access its value beyond the callback scope.
Definition at line 72 of file ServiceDiscovery.h.
| typedef FunctionPointerWithContext<const DiscoveredService *> ServiceCallback_t | 
Service discovered event handler.
The callback accepts a pointer to a DiscoveredService as parameter.
- Attention:
- The argument passed to the callback may not persist after the callback invocation; therefore, the callbacks must make a shallow copy of the DiscoveredService passed as parameter to access its value beyond the callback scope.
Definition at line 58 of file ServiceDiscovery.h.
Service discovery ended event.
The callback accepts a connection handle as parameter. This parameter is used to identify on which connection the service discovery process ended.
Definition at line 81 of file ServiceDiscovery.h.
Member Function Documentation
| virtual bool isActive | ( | void | ) | const  [pure virtual] | 
Check whether service-discovery is currently active.
| virtual ble_error_t launch | ( | Gap::Handle_t | connectionHandle, | 
| ServiceCallback_t | sc = NULL, | ||
| CharacteristicCallback_t | cc = NULL, | ||
| const UUID & | matchingServiceUUID = UUID::ShortUUIDBytes_t(BLE_UUID_UNKNOWN), | ||
| const UUID & | matchingCharacteristicUUIDIn = UUID::ShortUUIDBytes_t(BLE_UUID_UNKNOWN) | ||
| ) |  [pure virtual] | 
Launch service discovery.
Once launched, service discovery remains active with callbacks being issued back into the application for matching services or characteristics. isActive() can be used to determine status, and a termination callback (if set up) is invoked at the end. Service discovery can be terminated prematurely, if needed, using terminate().
- Parameters:
- 
  connectionHandle Handle for the connection with the peer. sc This is the application callback for a matching service. Taken as NULL by default. Note: service discovery may still be active when this callback is issued; calling asynchronous BLE-stack APIs from within this application callback might cause the stack to abort service discovery. If this becomes an issue, it may be better to make a local copy of the discoveredService and wait for service discovery to terminate before operating on the service. cc This is the application callback for a matching characteristic. Taken as NULL by default. Note: service discovery may still be active when this callback is issued; calling asynchronous BLE-stack APIs from within this application callback might cause the stack to abort service discovery. If this becomes an issue, it may be better to make a local copy of the discoveredCharacteristic and wait for service discovery to terminate before operating on the characteristic. matchingServiceUUID UUID-based filter for specifying a service in which the application is interested. By default, it is set as the wildcard UUID_UNKNOWN, in which case it matches all services. If characteristic-UUID filter (below) is set to the wildcard value, then a service callback is invoked for the matching service (or for every service if the service filter is a wildcard). matchingCharacteristicUUIDIn UUID-based filter for specifying a characteristic in which the application is interested. By default, it is set as the wildcard UUID_UKNOWN to match against any characteristic. If both service-UUID filter and characteristic-UUID filter are used with nonwildcard values, then only a single characteristic callback is invoked for the matching characteristic. 
- Note:
- Using wildcard values for both service-UUID and characteristic- UUID result in complete service discovery: callbacks being called for every service and characteristic.
- Providing NULL for the characteristic callback results in characteristic discovery being skipped for each matching service. This allows for an inexpensive method to discover only services.
- Returns:
- BLE_ERROR_NONE if service discovery is launched successfully; else an appropriate error.
| virtual void onTermination | ( | TerminationCallback_t | callback ) |  [pure virtual] | 
Set up a callback to be invoked when service discovery is terminated.
| virtual ble_error_t reset | ( | void | ) |  [virtual] | 
Clear all ServiceDiscovery state of the associated object.
This function is meant to be overridden in the platform-specific subclass. Nevertheless, the subclass is only expected to reset its state and not the data held in ServiceDiscovery members. This is achieved by a call to ServiceDiscovery::reset() from the subclass' reset() implementation.
- Returns:
- BLE_ERROR_NONE on success.
Definition at line 171 of file ServiceDiscovery.h.
| virtual void terminate | ( | void | ) |  [pure virtual] | 
Terminate an ongoing service discovery.
This should result in an invocation of the TerminationCallback if service discovery is active.
Field Documentation
| CharacteristicCallback_t characteristicCallback  [protected] | 
The registered callback handler for when a matching characteristic is found during service-discovery.
Definition at line 205 of file ServiceDiscovery.h.
| Gap::Handle_t connHandle  [protected] | 
Connection handle as provided by the SoftDevice.
Definition at line 185 of file ServiceDiscovery.h.
| UUID matchingCharacteristicUUID  [protected] | 
UUID-based filter that specifies the characteristic that the application is interested in.
Definition at line 200 of file ServiceDiscovery.h.
| UUID matchingServiceUUID  [protected] | 
UUID-based filter that specifies the service that the application is interested in.
Definition at line 190 of file ServiceDiscovery.h.
| ServiceCallback_t serviceCallback  [protected] | 
The registered callback handle for when a matching service is found during service-discovery.
Definition at line 195 of file ServiceDiscovery.h.
Generated on Tue Jul 12 2022 13:25:38 by
 1.7.2
 1.7.2