15#ifndef MAIN_BLEADVERTISING_H_
16#define MAIN_BLEADVERTISING_H_
18#if (defined(CONFIG_BT_ENABLED) && \
19 defined(CONFIG_BT_NIMBLE_ROLE_BROADCASTER) && \
20 !CONFIG_BT_NIMBLE_EXT_ADV) || defined(_DOXYGEN_)
22#if defined(CONFIG_NIMBLE_CPP_IDF)
23#include "host/ble_gap.h"
25#include "nimble/nimble/host/include/host/ble_gap.h"
33#include "NimBLEUUID.h"
34#include "NimBLEAddress.h"
40#define ESP_BLE_ADV_FLAG_LIMIT_DISC (0x01 << 0)
41#define ESP_BLE_ADV_FLAG_GEN_DISC (0x01 << 1)
42#define ESP_BLE_ADV_FLAG_BREDR_NOT_SPT (0x01 << 2)
43#define ESP_BLE_ADV_FLAG_DMT_CONTROLLER_SPT (0x01 << 3)
44#define ESP_BLE_ADV_FLAG_DMT_HOST_SPT (0x01 << 4)
45#define ESP_BLE_ADV_FLAG_NON_LIMIT_DISC (0x00 )
67 void setURI(
const std::string &uri);
68 void setName(
const std::string &name);
74 void addData(
const std::string &data);
75 void addData(
char * data,
size_t length);
83 void setServices(
const bool complete,
const uint8_t size,
84 const std::vector<NimBLEUUID> &v_uuid);
85 std::string m_payload;
104 void setName(
const std::string &name);
107 void setURI(
const std::string &uri);
113 void setScanFilter(
bool scanRequestWhitelistOnly,
bool connectWhitelistOnly);
128 static int handleGapEvent(
struct ble_gap_event *event,
void *arg);
130 ble_hs_adv_fields m_advData;
131 ble_hs_adv_fields m_scanData;
132 ble_gap_adv_params m_advParams;
133 std::vector<NimBLEUUID> m_serviceUUIDs;
134 bool m_customAdvData;
135 bool m_customScanResponseData;
138 advCompleteCB_t m_advCompCB{
nullptr};
139 uint8_t m_slaveItvl[4];
141 std::vector<uint8_t> m_svcData16;
142 std::vector<uint8_t> m_svcData32;
143 std::vector<uint8_t> m_svcData128;
144 std::vector<uint8_t> m_name;
145 std::vector<uint8_t> m_mfgData;
146 std::vector<uint8_t> m_uri;
A BLE device address.
Definition: NimBLEAddress.h:39
Advertisement data set by the programmer to be published by the BLE server.
Definition: NimBLEAdvertising.h:55
void setAppearance(uint16_t appearance)
Set the appearance.
Definition: NimBLEAdvertising.cpp:817
void setPartialServices32(const std::vector< NimBLEUUID > &v_uuid)
Set the partial list of services to advertise.
Definition: NimBLEAdvertising.cpp:938
void addTxPower()
Adds Tx power level to the advertisement data.
Definition: NimBLEAdvertising.cpp:1048
void setPartialServices16(const std::vector< NimBLEUUID > &v_uuid)
Set the partial list of services to advertise.
Definition: NimBLEAdvertising.cpp:929
void setCompleteServices16(const std::vector< NimBLEUUID > &v_uuid)
Set the complete list of 16 bit services to advertise.
Definition: NimBLEAdvertising.cpp:902
void setPreferredParams(uint16_t min, uint16_t max)
Set the preferred connection interval parameters.
Definition: NimBLEAdvertising.cpp:1062
void setCompleteServices(const NimBLEUUID &uuid)
Set a single service to advertise as a complete list of services.
Definition: NimBLEAdvertising.cpp:893
void setCompleteServices32(const std::vector< NimBLEUUID > &v_uuid)
Set the complete list of 32 bit services to advertise.
Definition: NimBLEAdvertising.cpp:911
void setFlags(uint8_t)
Set the advertisement flags.
Definition: NimBLEAdvertising.cpp:832
void setName(const std::string &name)
Set the complete name of this device.
Definition: NimBLEAdvertising.cpp:881
void setURI(const std::string &uri)
Set the URI to advertise.
Definition: NimBLEAdvertising.cpp:869
void setManufacturerData(const std::string &data)
Set manufacturer specific data.
Definition: NimBLEAdvertising.cpp:845
void clearData()
Clear the advertisement data for reuse.
Definition: NimBLEAdvertising.cpp:1086
std::string getPayload()
Retrieve the payload that is to be advertised.
Definition: NimBLEAdvertising.cpp:1078
void setShortName(const std::string &name)
Set the short name.
Definition: NimBLEAdvertising.cpp:1037
void addData(const std::string &data)
Add data to the payload to be advertised.
Definition: NimBLEAdvertising.cpp:794
void setServiceData(const NimBLEUUID &uuid, const std::string &data)
Set the service data (UUID + data)
Definition: NimBLEAdvertising.cpp:1000
void setPartialServices(const NimBLEUUID &uuid)
Set a single service to advertise as a partial list of services.
Definition: NimBLEAdvertising.cpp:920
Perform and manage BLE advertising.
Definition: NimBLEAdvertising.h:94
void setScanResponseData(NimBLEAdvertisementData &advertisementData)
Set the advertisement data that is to be published in a scan response.
Definition: NimBLEAdvertising.cpp:394
void setMinInterval(uint16_t mininterval)
Set the minimum advertising interval.
Definition: NimBLEAdvertising.cpp:249
void setManufacturerData(const std::string &data)
Set the advertised manufacturer data.
Definition: NimBLEAdvertising.cpp:158
void setMaxPreferred(uint16_t)
Set the advertised max connection interval preferred by this device.
Definition: NimBLEAdvertising.cpp:301
bool stop()
Stop advertising.
Definition: NimBLEAdvertising.cpp:709
void setMinPreferred(uint16_t)
Set the advertised min connection interval preferred by this device.
Definition: NimBLEAdvertising.cpp:269
void advCompleteCB()
Handles the callback when advertising stops.
Definition: NimBLEAdvertising.cpp:727
void addServiceUUID(const NimBLEUUID &serviceUUID)
Add a service uuid to exposed list of services.
Definition: NimBLEAdvertising.cpp:82
void reset()
Stops the current advertising and resets the advertising data to the default values.
Definition: NimBLEAdvertising.cpp:46
void setURI(const std::string &uri)
Set the advertised URI.
Definition: NimBLEAdvertising.cpp:182
void setAdvertisementType(uint8_t adv_type)
Set the type of advertisment to use.
Definition: NimBLEAdvertising.cpp:240
void setScanResponse(bool)
Set if scan response is available.
Definition: NimBLEAdvertising.cpp:329
void removeServiceUUID(const NimBLEUUID &serviceUUID)
Remove a service UUID from the advertisment.
Definition: NimBLEAdvertising.cpp:102
void removeServices()
Remove all service UUIDs from the advertisment.
Definition: NimBLEAdvertising.cpp:116
bool start(uint32_t duration=0, advCompleteCB_t advCompleteCB=nullptr, NimBLEAddress *dirAddr=nullptr)
Start advertising.
Definition: NimBLEAdvertising.cpp:415
void setServiceData(const NimBLEUUID &uuid, const std::string &data)
Set the service data advertised for the UUID.
Definition: NimBLEAdvertising.cpp:196
void setAppearance(uint16_t appearance)
Set the device appearance in the advertising data.
Definition: NimBLEAdvertising.cpp:126
void setScanFilter(bool scanRequestWhitelistOnly, bool connectWhitelistOnly)
Set the filtering for the scan filter.
Definition: NimBLEAdvertising.cpp:340
void setMaxInterval(uint16_t maxinterval)
Set the maximum advertising interval.
Definition: NimBLEAdvertising.cpp:258
NimBLEAdvertising()
Construct a default advertising object.
Definition: NimBLEAdvertising.cpp:38
bool isAdvertising()
Check if currently advertising.
Definition: NimBLEAdvertising.cpp:738
void addTxPower()
Add the transmission power level to the advertisement packet.
Definition: NimBLEAdvertising.cpp:136
void setName(const std::string &name)
Set the advertised name of the device.
Definition: NimBLEAdvertising.cpp:146
void setAdvertisementData(NimBLEAdvertisementData &advertisementData)
Set the advertisement data that is to be published in a regular advertisement.
Definition: NimBLEAdvertising.cpp:374
A model of a BLE Device from which all the BLE roles are created.
Definition: NimBLEDevice.h:96
The model of a BLE server.
Definition: NimBLEServer.h:46
A model of a BLE UUID.
Definition: NimBLEUUID.h:37