[BREAKING] Refactor NimBLEBeacon

* General code cleanup
* The internal data struct type `BeaconData` is now public and can be used by the application.
* `NimBLEBeacon::setData` now takes `const NimBLEBeacon::BeaconData&` instead of `std::string`.
* Added overload for `NimBLEBeacon::setData` that takes a pointer to raw `uint8_t` data and length`.
* `NimBLEBeacon::getData` now returns `const NimBLEBeacon::BeaconData&` instead of `std::string`.
This commit is contained in:
h2zero 2024-11-29 10:12:04 -07:00 committed by h2zero
parent ecf1adc4d7
commit 36d27a2413
2 changed files with 72 additions and 79 deletions

View file

@ -1,5 +1,5 @@
/* /*
* NimBLEBeacon2.cpp * NimBLEBeacon.cpp
* *
* Created: on March 15 2020 * Created: on March 15 2020
* Author H2zero * Author H2zero
@ -11,50 +11,33 @@
* Created on: Jan 4, 2018 * Created on: Jan 4, 2018
* Author: kolban * Author: kolban
*/ */
#include "nimconfig.h" #include "nimconfig.h"
#if defined(CONFIG_BT_ENABLED) #if defined(CONFIG_BT_ENABLED) && defined(CONFIG_BT_NIMBLE_ROLE_BROADCASTER)
#include <string.h> # include "NimBLEBeacon.h"
#include <algorithm> # include "NimBLEUUID.h"
#include "NimBLEBeacon.h" # include "NimBLELog.h"
#include "NimBLELog.h"
#define ENDIAN_CHANGE_U16(x) ((((x)&0xFF00)>>8) + (((x)&0xFF)<<8)) # define ENDIAN_CHANGE_U16(x) ((((x) & 0xFF00) >> 8) + (((x) & 0xFF) << 8))
static const char* LOG_TAG = "NimBLEBeacon"; static const char* LOG_TAG = "NimBLEBeacon";
/**
* @brief Construct a default beacon object.
*/
NimBLEBeacon::NimBLEBeacon() {
m_beaconData.manufacturerId = 0x4c00;
m_beaconData.subType = 0x02;
m_beaconData.subTypeLength = 0x15;
m_beaconData.major = 0;
m_beaconData.minor = 0;
m_beaconData.signalPower = 0;
memset(m_beaconData.proximityUUID, 0, sizeof(m_beaconData.proximityUUID));
} // NimBLEBeacon
/** /**
* @brief Retrieve the data that is being advertised. * @brief Retrieve the data that is being advertised.
* @return The advertised data. * @return The advertised data.
*/ */
std::string NimBLEBeacon::getData() { const NimBLEBeacon::BeaconData& NimBLEBeacon::getData() {
return std::string((char*) &m_beaconData, sizeof(m_beaconData)); return m_beaconData;
} // getData } // getData
/** /**
* @brief Get the major value being advertised. * @brief Get the major value being advertised.
* @return The major value advertised. * @return The major value advertised.
*/ */
uint16_t NimBLEBeacon::getMajor() { uint16_t NimBLEBeacon::getMajor() {
return m_beaconData.major; return m_beaconData.major;
} } // getMajor
/** /**
* @brief Get the manufacturer ID being advertised. * @brief Get the manufacturer ID being advertised.
@ -62,8 +45,7 @@ uint16_t NimBLEBeacon::getMajor() {
*/ */
uint16_t NimBLEBeacon::getManufacturerId() { uint16_t NimBLEBeacon::getManufacturerId() {
return m_beaconData.manufacturerId; return m_beaconData.manufacturerId;
} } // getManufacturerId
/** /**
* @brief Get the minor value being advertised. * @brief Get the minor value being advertised.
@ -71,8 +53,7 @@ uint16_t NimBLEBeacon::getManufacturerId() {
*/ */
uint16_t NimBLEBeacon::getMinor() { uint16_t NimBLEBeacon::getMinor() {
return m_beaconData.minor; return m_beaconData.minor;
} } // getMinor
/** /**
* @brief Get the proximity UUID being advertised. * @brief Get the proximity UUID being advertised.
@ -80,8 +61,7 @@ uint16_t NimBLEBeacon::getMinor() {
*/ */
NimBLEUUID NimBLEBeacon::getProximityUUID() { NimBLEUUID NimBLEBeacon::getProximityUUID() {
return NimBLEUUID(m_beaconData.proximityUUID, 16).reverseByteOrder(); return NimBLEUUID(m_beaconData.proximityUUID, 16).reverseByteOrder();
} } // getProximityUUID
/** /**
* @brief Get the signal power being advertised. * @brief Get the signal power being advertised.
@ -89,22 +69,28 @@ NimBLEUUID NimBLEBeacon::getProximityUUID() {
*/ */
int8_t NimBLEBeacon::getSignalPower() { int8_t NimBLEBeacon::getSignalPower() {
return m_beaconData.signalPower; return m_beaconData.signalPower;
} } // getSignalPower
/** /**
* @brief Set the raw data for the beacon record. * @brief Set the beacon data.
* @param [in] data The raw beacon data. * @param [in] data A pointer to the raw data that the beacon should advertise.
* @param [in] length The length of the data.
*/ */
void NimBLEBeacon::setData(const std::string &data) { void NimBLEBeacon::setData(const uint8_t* data, uint8_t length) {
if (data.length() != sizeof(m_beaconData)) { if (length != sizeof(BeaconData)) {
NIMBLE_LOGE(LOG_TAG, "Unable to set the data ... length passed in was %d and expected %d", NIMBLE_LOGE(LOG_TAG, "Data length must be %d bytes, sent: %d", sizeof(BeaconData), length);
data.length(), sizeof(m_beaconData));
return; return;
} }
memcpy(&m_beaconData, data.data(), sizeof(m_beaconData)); memcpy(&m_beaconData, data, length);
} // setData } // setData
/**
* @brief Set the beacon data.
* @param [in] data The data that the beacon should advertise.
*/
void NimBLEBeacon::setData(const NimBLEBeacon::BeaconData& data) {
m_beaconData = data;
} // setData
/** /**
* @brief Set the major value. * @brief Set the major value.
@ -114,7 +100,6 @@ void NimBLEBeacon::setMajor(uint16_t major) {
m_beaconData.major = ENDIAN_CHANGE_U16(major); m_beaconData.major = ENDIAN_CHANGE_U16(major);
} // setMajor } // setMajor
/** /**
* @brief Set the manufacturer ID. * @brief Set the manufacturer ID.
* @param [in] manufacturerId The manufacturer ID value. * @param [in] manufacturerId The manufacturer ID value.
@ -123,7 +108,6 @@ void NimBLEBeacon::setManufacturerId(uint16_t manufacturerId) {
m_beaconData.manufacturerId = ENDIAN_CHANGE_U16(manufacturerId); m_beaconData.manufacturerId = ENDIAN_CHANGE_U16(manufacturerId);
} // setManufacturerId } // setManufacturerId
/** /**
* @brief Set the minor value. * @brief Set the minor value.
* @param [in] minor The minor value. * @param [in] minor The minor value.
@ -132,18 +116,17 @@ void NimBLEBeacon::setMinor(uint16_t minor) {
m_beaconData.minor = ENDIAN_CHANGE_U16(minor); m_beaconData.minor = ENDIAN_CHANGE_U16(minor);
} // setMinor } // setMinor
/** /**
* @brief Set the proximity UUID. * @brief Set the proximity UUID.
* @param [in] uuid The proximity UUID. * @param [in] uuid The proximity UUID.
*/ */
void NimBLEBeacon::setProximityUUID(const NimBLEUUID &uuid) { void NimBLEBeacon::setProximityUUID(const NimBLEUUID& uuid) {
NimBLEUUID temp_uuid = uuid; NimBLEUUID temp_uuid = uuid;
temp_uuid.to128(); temp_uuid.to128();
std::reverse_copy(temp_uuid.getValue(), temp_uuid.getValue() + 16, m_beaconData.proximityUUID); temp_uuid.reverseByteOrder();
memcpy(m_beaconData.proximityUUID, temp_uuid.getValue(), 16);
} // setProximityUUID } // setProximityUUID
/** /**
* @brief Set the signal power. * @brief Set the signal power.
* @param [in] signalPower The signal power value. * @param [in] signalPower The signal power value.
@ -152,4 +135,4 @@ void NimBLEBeacon::setSignalPower(int8_t signalPower) {
m_beaconData.signalPower = signalPower; m_beaconData.signalPower = signalPower;
} // setSignalPower } // setSignalPower
#endif #endif // CONFIG_BT_ENABLED && CONFIG_BT_NIMBLE_ROLE_BROADCASTER

View file

@ -1,51 +1,61 @@
/* /*
* NimBLEBeacon2.h * NimBLEBeacon.h
* *
* Created: on March 15 2020 * Created: on March 15 2020
* Author H2zero * Author H2zero
* *
* Originally: * Originally:
* *
* BLEBeacon2.h * BLEBeacon.h
* *
* Created on: Jan 4, 2018 * Created on: Jan 4, 2018
* Author: kolban * Author: kolban
*/ */
#ifndef MAIN_NIMBLEBEACON_H_ #ifndef NIMBLE_CPP_BEACON_H_
#define MAIN_NIMBLEBEACON_H_ #define NIMBLE_CPP_BEACON_H_
#include "nimconfig.h"
#if defined(CONFIG_BT_ENABLED) && defined(CONFIG_BT_NIMBLE_ROLE_BROADCASTER)
class NimBLEUUID;
# include <cstdint>
#include "NimBLEUUID.h"
/** /**
* @brief Representation of a beacon. * @brief Representation of a beacon.
* See: * See:
* * https://en.wikipedia.org/wiki/IBeacon * * https://en.wikipedia.org/wiki/IBeacon
*/ */
class NimBLEBeacon { class NimBLEBeacon {
private: public:
struct { struct BeaconData {
uint16_t manufacturerId; uint16_t manufacturerId{0x4c00};
uint8_t subType; uint8_t subType{0x02};
uint8_t subTypeLength; uint8_t subTypeLength{0x15};
uint8_t proximityUUID[16]; uint8_t proximityUUID[16]{};
uint16_t major; uint16_t major{};
uint16_t minor; uint16_t minor{};
int8_t signalPower; int8_t signalPower{};
} __attribute__((packed)) m_beaconData; } __attribute__((packed));
public:
NimBLEBeacon(); const BeaconData& getData();
std::string getData();
uint16_t getMajor(); uint16_t getMajor();
uint16_t getMinor(); uint16_t getMinor();
uint16_t getManufacturerId(); uint16_t getManufacturerId();
NimBLEUUID getProximityUUID(); NimBLEUUID getProximityUUID();
int8_t getSignalPower(); int8_t getSignalPower();
void setData(const std::string &data); void setData(const uint8_t* data, uint8_t length);
void setData(const BeaconData& data);
void setMajor(uint16_t major); void setMajor(uint16_t major);
void setMinor(uint16_t minor); void setMinor(uint16_t minor);
void setManufacturerId(uint16_t manufacturerId); void setManufacturerId(uint16_t manufacturerId);
void setProximityUUID(const NimBLEUUID &uuid); void setProximityUUID(const NimBLEUUID& uuid);
void setSignalPower(int8_t signalPower); void setSignalPower(int8_t signalPower);
private:
BeaconData m_beaconData;
}; // NimBLEBeacon }; // NimBLEBeacon
#endif /* MAIN_NIMBLEBEACON_H_ */ #endif // NIMBLE_CPP_BEACON_H_
#endif // CONFIG_BT_ENABLED && CONFIG_BT_NIMBLE_ROLE_PERIPHERAL