2019-04-12 15:43:53 +02:00
|
|
|
/*
|
|
|
|
* BLEEddystoneTLM.cpp
|
|
|
|
*
|
|
|
|
* Created on: Mar 12, 2018
|
|
|
|
* Author: pcbreflux
|
2020-09-30 13:55:58 +02:00
|
|
|
* Edited on: Mar 20, 2020 by beegee-tokyo
|
|
|
|
* Fix temperature value (8.8 fixed format)
|
|
|
|
* Fix time stamp (0.1 second resolution)
|
|
|
|
* Fixes based on EddystoneTLM frame specification https://github.com/google/eddystone/blob/master/eddystone-tlm/tlm-plain.md
|
|
|
|
*
|
2019-04-12 15:43:53 +02:00
|
|
|
*/
|
|
|
|
#include "sdkconfig.h"
|
2021-04-05 13:23:58 +02:00
|
|
|
#if defined(CONFIG_BLUEDROID_ENABLED)
|
2019-04-12 15:43:53 +02:00
|
|
|
#include <string.h>
|
2019-07-09 18:31:17 +02:00
|
|
|
#include <stdio.h>
|
2019-04-15 17:26:35 +02:00
|
|
|
#include "esp32-hal-log.h"
|
2019-04-12 15:43:53 +02:00
|
|
|
#include "BLEEddystoneTLM.h"
|
|
|
|
|
|
|
|
static const char LOG_TAG[] = "BLEEddystoneTLM";
|
|
|
|
#define ENDIAN_CHANGE_U16(x) ((((x)&0xFF00)>>8) + (((x)&0xFF)<<8))
|
|
|
|
#define ENDIAN_CHANGE_U32(x) ((((x)&0xFF000000)>>24) + (((x)&0x00FF0000)>>8)) + ((((x)&0xFF00)<<8) + (((x)&0xFF)<<24))
|
|
|
|
|
|
|
|
BLEEddystoneTLM::BLEEddystoneTLM() {
|
|
|
|
beaconUUID = 0xFEAA;
|
|
|
|
m_eddystoneData.frameType = EDDYSTONE_TLM_FRAME_TYPE;
|
|
|
|
m_eddystoneData.version = 0;
|
|
|
|
m_eddystoneData.volt = 3300; // 3300mV = 3.3V
|
2020-09-30 13:55:58 +02:00
|
|
|
m_eddystoneData.temp = (uint16_t) ((float) 23.00)/256;
|
2019-04-12 15:43:53 +02:00
|
|
|
m_eddystoneData.advCount = 0;
|
|
|
|
m_eddystoneData.tmil = 0;
|
|
|
|
} // BLEEddystoneTLM
|
|
|
|
|
|
|
|
std::string BLEEddystoneTLM::getData() {
|
|
|
|
return std::string((char*) &m_eddystoneData, sizeof(m_eddystoneData));
|
|
|
|
} // getData
|
|
|
|
|
|
|
|
BLEUUID BLEEddystoneTLM::getUUID() {
|
|
|
|
return BLEUUID(beaconUUID);
|
|
|
|
} // getUUID
|
|
|
|
|
|
|
|
uint8_t BLEEddystoneTLM::getVersion() {
|
|
|
|
return m_eddystoneData.version;
|
|
|
|
} // getVersion
|
|
|
|
|
|
|
|
uint16_t BLEEddystoneTLM::getVolt() {
|
2020-09-30 13:55:58 +02:00
|
|
|
return ENDIAN_CHANGE_U16(m_eddystoneData.volt);
|
2019-04-12 15:43:53 +02:00
|
|
|
} // getVolt
|
|
|
|
|
|
|
|
float BLEEddystoneTLM::getTemp() {
|
2020-09-30 13:55:58 +02:00
|
|
|
return ENDIAN_CHANGE_U16(m_eddystoneData.temp) / 256.0f;
|
2019-04-12 15:43:53 +02:00
|
|
|
} // getTemp
|
|
|
|
|
|
|
|
uint32_t BLEEddystoneTLM::getCount() {
|
2020-09-30 13:55:58 +02:00
|
|
|
return ENDIAN_CHANGE_U32(m_eddystoneData.advCount);
|
2019-04-12 15:43:53 +02:00
|
|
|
} // getCount
|
|
|
|
|
|
|
|
uint32_t BLEEddystoneTLM::getTime() {
|
2020-09-30 13:55:58 +02:00
|
|
|
return (ENDIAN_CHANGE_U32(m_eddystoneData.tmil)) / 10;
|
2019-04-12 15:43:53 +02:00
|
|
|
} // getTime
|
|
|
|
|
|
|
|
std::string BLEEddystoneTLM::toString() {
|
2019-07-09 18:31:17 +02:00
|
|
|
std::string out = "";
|
|
|
|
uint32_t rawsec = ENDIAN_CHANGE_U32(m_eddystoneData.tmil);
|
2020-09-30 13:55:58 +02:00
|
|
|
char val[12];
|
2019-07-09 18:31:17 +02:00
|
|
|
|
2020-09-30 13:55:58 +02:00
|
|
|
out += "Version "; // + std::string(m_eddystoneData.version);
|
|
|
|
snprintf(val, sizeof(val), "%d", m_eddystoneData.version);
|
|
|
|
out += val;
|
2019-07-09 18:31:17 +02:00
|
|
|
out += "\n";
|
2020-09-30 13:55:58 +02:00
|
|
|
out += "Battery Voltage "; // + ENDIAN_CHANGE_U16(m_eddystoneData.volt);
|
|
|
|
snprintf(val, sizeof(val), "%d", ENDIAN_CHANGE_U16(m_eddystoneData.volt));
|
|
|
|
out += val;
|
2019-07-09 18:31:17 +02:00
|
|
|
out += " mV\n";
|
|
|
|
|
|
|
|
out += "Temperature ";
|
2020-09-30 13:55:58 +02:00
|
|
|
snprintf(val, sizeof(val), "%.2f", ENDIAN_CHANGE_U16(m_eddystoneData.temp) / 256.0f);
|
2019-07-09 18:31:17 +02:00
|
|
|
out += val;
|
2020-09-30 13:55:58 +02:00
|
|
|
out += " C\n";
|
2019-07-09 18:31:17 +02:00
|
|
|
|
|
|
|
out += "Adv. Count ";
|
|
|
|
snprintf(val, sizeof(val), "%d", ENDIAN_CHANGE_U32(m_eddystoneData.advCount));
|
|
|
|
out += val;
|
|
|
|
out += "\n";
|
|
|
|
|
2020-09-30 13:55:58 +02:00
|
|
|
out += "Time in seconds ";
|
|
|
|
snprintf(val, sizeof(val), "%d", rawsec/10);
|
|
|
|
out += val;
|
|
|
|
out += "\n";
|
|
|
|
|
2019-07-09 18:31:17 +02:00
|
|
|
out += "Time ";
|
|
|
|
|
|
|
|
snprintf(val, sizeof(val), "%04d", rawsec / 864000);
|
|
|
|
out += val;
|
|
|
|
out += ".";
|
|
|
|
|
|
|
|
snprintf(val, sizeof(val), "%02d", (rawsec / 36000) % 24);
|
|
|
|
out += val;
|
|
|
|
out += ":";
|
|
|
|
|
|
|
|
snprintf(val, sizeof(val), "%02d", (rawsec / 600) % 60);
|
|
|
|
out += val;
|
|
|
|
out += ":";
|
|
|
|
|
|
|
|
snprintf(val, sizeof(val), "%02d", (rawsec / 10) % 60);
|
|
|
|
out += val;
|
|
|
|
out += "\n";
|
|
|
|
|
|
|
|
return out;
|
2019-04-12 15:43:53 +02:00
|
|
|
} // toString
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Set the raw data for the beacon record.
|
|
|
|
*/
|
|
|
|
void BLEEddystoneTLM::setData(std::string data) {
|
|
|
|
if (data.length() != sizeof(m_eddystoneData)) {
|
2019-04-15 17:26:35 +02:00
|
|
|
log_e("Unable to set the data ... length passed in was %d and expected %d", data.length(), sizeof(m_eddystoneData));
|
2019-04-12 15:43:53 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
memcpy(&m_eddystoneData, data.data(), data.length());
|
|
|
|
} // setData
|
|
|
|
|
|
|
|
void BLEEddystoneTLM::setUUID(BLEUUID l_uuid) {
|
|
|
|
beaconUUID = l_uuid.getNative()->uuid.uuid16;
|
|
|
|
} // setUUID
|
|
|
|
|
|
|
|
void BLEEddystoneTLM::setVersion(uint8_t version) {
|
|
|
|
m_eddystoneData.version = version;
|
|
|
|
} // setVersion
|
|
|
|
|
|
|
|
void BLEEddystoneTLM::setVolt(uint16_t volt) {
|
|
|
|
m_eddystoneData.volt = volt;
|
|
|
|
} // setVolt
|
|
|
|
|
|
|
|
void BLEEddystoneTLM::setTemp(float temp) {
|
|
|
|
m_eddystoneData.temp = (uint16_t)temp;
|
|
|
|
} // setTemp
|
|
|
|
|
|
|
|
void BLEEddystoneTLM::setCount(uint32_t advCount) {
|
|
|
|
m_eddystoneData.advCount = advCount;
|
|
|
|
} // setCount
|
|
|
|
|
|
|
|
void BLEEddystoneTLM::setTime(uint32_t tmil) {
|
|
|
|
m_eddystoneData.tmil = tmil;
|
|
|
|
} // setTime
|
|
|
|
|
|
|
|
#endif
|