Rtos API example

Embed: (wiki syntax)

« Back to documentation index

ServiceDiscovery Class Reference

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.

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

Characteristic discovered event handler.

The callback accepts a pointer to a DiscoveredCharacteristic as parameter.

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.

Service discovered event handler.

The callback accepts a pointer to a DiscoveredService as parameter.

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:
connectionHandleHandle for the connection with the peer.
scThis 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.
ccThis 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.
matchingServiceUUIDUUID-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).
matchingCharacteristicUUIDInUUID-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

The registered callback handler for when a matching characteristic is found during service-discovery.

Definition at line 205 of file ServiceDiscovery.h.

Connection handle as provided by the SoftDevice.

Definition at line 185 of file ServiceDiscovery.h.

UUID-based filter that specifies the characteristic that the application is interested in.

Definition at line 200 of file ServiceDiscovery.h.

UUID-based filter that specifies the service that the application is interested in.

Definition at line 190 of file ServiceDiscovery.h.

The registered callback handle for when a matching service is found during service-discovery.

Definition at line 195 of file ServiceDiscovery.h.