sforkowany z mirror/meshtastic-firmware
Moved sender short name method into protobuf module (#1398)
* Moved sender short name method into protobuf module * Correct factory reset code for NRF (from 1.2) * Use the correct fs abstraction Co-authored-by: Ben Meadors <benmmeadors@gmail.com>raytac-diy
rodzic
e7a825d1ba
commit
98c8eaaaf0
|
@ -95,14 +95,16 @@ bool NodeDB::resetRadioConfig()
|
||||||
nvs_flash_erase();
|
nvs_flash_erase();
|
||||||
#endif
|
#endif
|
||||||
#ifdef NRF52_SERIES
|
#ifdef NRF52_SERIES
|
||||||
|
// first, remove the "/prefs" (this removes most prefs)
|
||||||
FSCom.rmdir_r("/prefs");
|
FSCom.rmdir_r("/prefs");
|
||||||
|
// second, install default state (this will deal with the duplicate mac address issue)
|
||||||
|
installDefaultDeviceState();
|
||||||
|
// third, write to disk
|
||||||
|
saveToDisk();
|
||||||
Bluefruit.begin();
|
Bluefruit.begin();
|
||||||
|
|
||||||
DEBUG_MSG("Clearing bluetooth bonds!\n");
|
DEBUG_MSG("Clearing bluetooth bonds!\n");
|
||||||
bond_print_list(BLE_GAP_ROLE_PERIPH);
|
bond_print_list(BLE_GAP_ROLE_PERIPH);
|
||||||
bond_print_list(BLE_GAP_ROLE_CENTRAL);
|
bond_print_list(BLE_GAP_ROLE_CENTRAL);
|
||||||
|
|
||||||
Bluefruit.Periph.clearBonds();
|
Bluefruit.Periph.clearBonds();
|
||||||
Bluefruit.Central.clearBonds();
|
Bluefruit.Central.clearBonds();
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -48,6 +48,17 @@ template <class T> class ProtobufModule : protected SinglePortModule
|
||||||
return p;
|
return p;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Gets the short name from the sender of the mesh packet
|
||||||
|
* Returns "???" if unknown sender
|
||||||
|
*/
|
||||||
|
const char *getSenderShortName(const MeshPacket &mp)
|
||||||
|
{
|
||||||
|
auto node = nodeDB.getNode(getFrom(&mp));
|
||||||
|
const char *sender = (node) ? node->user.short_name : "???";
|
||||||
|
return sender;
|
||||||
|
}
|
||||||
|
|
||||||
private:
|
private:
|
||||||
/** Called to handle a particular incoming message
|
/** Called to handle a particular incoming message
|
||||||
|
|
||||||
|
|
|
@ -27,7 +27,7 @@ int32_t DeviceTelemetryModule::runOnce()
|
||||||
bool DeviceTelemetryModule::handleReceivedProtobuf(const MeshPacket &mp, Telemetry *t)
|
bool DeviceTelemetryModule::handleReceivedProtobuf(const MeshPacket &mp, Telemetry *t)
|
||||||
{
|
{
|
||||||
if (t->which_variant == Telemetry_device_metrics_tag) {
|
if (t->which_variant == Telemetry_device_metrics_tag) {
|
||||||
String sender = getSenderName(mp);
|
const char *sender = getSenderShortName(mp);
|
||||||
|
|
||||||
DEBUG_MSG("-----------------------------------------\n");
|
DEBUG_MSG("-----------------------------------------\n");
|
||||||
DEBUG_MSG("Device Telemetry: Received data from %s\n", sender);
|
DEBUG_MSG("Device Telemetry: Received data from %s\n", sender);
|
||||||
|
@ -44,19 +44,6 @@ bool DeviceTelemetryModule::handleReceivedProtobuf(const MeshPacket &mp, Telemet
|
||||||
return false; // Let others look at this message also if they want
|
return false; // Let others look at this message also if they want
|
||||||
}
|
}
|
||||||
|
|
||||||
String DeviceTelemetryModule::getSenderName(const MeshPacket &mp)
|
|
||||||
{
|
|
||||||
String sender;
|
|
||||||
|
|
||||||
auto node = nodeDB.getNode(getFrom(&mp));
|
|
||||||
if (node) {
|
|
||||||
sender = node->user.short_name;
|
|
||||||
} else {
|
|
||||||
sender = "UNK";
|
|
||||||
}
|
|
||||||
return sender;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool DeviceTelemetryModule::sendOurTelemetry(NodeNum dest, bool wantReplies)
|
bool DeviceTelemetryModule::sendOurTelemetry(NodeNum dest, bool wantReplies)
|
||||||
{
|
{
|
||||||
Telemetry t;
|
Telemetry t;
|
||||||
|
|
|
@ -27,7 +27,6 @@ class DeviceTelemetryModule : private concurrency::OSThread, public ProtobufModu
|
||||||
bool sendOurTelemetry(NodeNum dest = NODENUM_BROADCAST, bool wantReplies = false);
|
bool sendOurTelemetry(NodeNum dest = NODENUM_BROADCAST, bool wantReplies = false);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
String getSenderName(const MeshPacket &mp);
|
|
||||||
bool firstTime = 1;
|
bool firstTime = 1;
|
||||||
const MeshPacket *lastMeasurementPacket;
|
const MeshPacket *lastMeasurementPacket;
|
||||||
};
|
};
|
||||||
|
|
|
@ -149,19 +149,6 @@ int32_t EnvironmentTelemetryModule::runOnce()
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
String GetSenderName(const MeshPacket &mp)
|
|
||||||
{
|
|
||||||
String sender;
|
|
||||||
|
|
||||||
auto node = nodeDB.getNode(getFrom(&mp));
|
|
||||||
if (node) {
|
|
||||||
sender = node->user.short_name;
|
|
||||||
} else {
|
|
||||||
sender = "UNK";
|
|
||||||
}
|
|
||||||
return sender;
|
|
||||||
}
|
|
||||||
|
|
||||||
uint32_t GetTimeSinceMeshPacket(const MeshPacket *mp)
|
uint32_t GetTimeSinceMeshPacket(const MeshPacket *mp)
|
||||||
{
|
{
|
||||||
uint32_t now = getTime();
|
uint32_t now = getTime();
|
||||||
|
@ -198,7 +185,7 @@ void EnvironmentTelemetryModule::drawFrame(OLEDDisplay *display, OLEDDisplayUiSt
|
||||||
Telemetry lastMeasurement;
|
Telemetry lastMeasurement;
|
||||||
|
|
||||||
uint32_t agoSecs = GetTimeSinceMeshPacket(lastMeasurementPacket);
|
uint32_t agoSecs = GetTimeSinceMeshPacket(lastMeasurementPacket);
|
||||||
String lastSender = GetSenderName(*lastMeasurementPacket);
|
const char *lastSender = getSenderShortName(*lastMeasurementPacket);
|
||||||
|
|
||||||
auto &p = lastMeasurementPacket->decoded;
|
auto &p = lastMeasurementPacket->decoded;
|
||||||
if (!pb_decode_from_bytes(p.payload.bytes, p.payload.size, Telemetry_fields, &lastMeasurement)) {
|
if (!pb_decode_from_bytes(p.payload.bytes, p.payload.size, Telemetry_fields, &lastMeasurement)) {
|
||||||
|
@ -213,16 +200,16 @@ void EnvironmentTelemetryModule::drawFrame(OLEDDisplay *display, OLEDDisplayUiSt
|
||||||
if (radioConfig.preferences.telemetry_module_environment_display_fahrenheit) {
|
if (radioConfig.preferences.telemetry_module_environment_display_fahrenheit) {
|
||||||
last_temp = String(CelsiusToFahrenheit(lastMeasurement.variant.environment_metrics.temperature), 0) + "°F";
|
last_temp = String(CelsiusToFahrenheit(lastMeasurement.variant.environment_metrics.temperature), 0) + "°F";
|
||||||
}
|
}
|
||||||
display->drawString(x, y += fontHeight(FONT_MEDIUM) - 2, "From: " + lastSender + "(" + String(agoSecs) + "s)");
|
display->drawString(x, y += fontHeight(FONT_MEDIUM) - 2, "From: " + String(lastSender) + "(" + String(agoSecs) + "s)");
|
||||||
display->drawString(x, y += fontHeight(FONT_SMALL) - 2,"Temp/Hum: " + last_temp + " / " + String(lastMeasurement.variant.environment_metrics.relative_humidity, 0) + "%");
|
display->drawString(x, y += fontHeight(FONT_SMALL) - 2, "Temp/Hum: " + last_temp + " / " + String(lastMeasurement.variant.environment_metrics.relative_humidity, 0) + "%");
|
||||||
if (lastMeasurement.variant.environment_metrics.barometric_pressure != 0)
|
if (lastMeasurement.variant.environment_metrics.barometric_pressure != 0)
|
||||||
display->drawString(x, y += fontHeight(FONT_SMALL),"Press: " + String(lastMeasurement.variant.environment_metrics.barometric_pressure, 0) + "hPA");
|
display->drawString(x, y += fontHeight(FONT_SMALL), "Press: " + String(lastMeasurement.variant.environment_metrics.barometric_pressure, 0) + "hPA");
|
||||||
}
|
}
|
||||||
|
|
||||||
bool EnvironmentTelemetryModule::handleReceivedProtobuf(const MeshPacket &mp, Telemetry *t)
|
bool EnvironmentTelemetryModule::handleReceivedProtobuf(const MeshPacket &mp, Telemetry *t)
|
||||||
{
|
{
|
||||||
if (t->which_variant == Telemetry_environment_metrics_tag) {
|
if (t->which_variant == Telemetry_environment_metrics_tag) {
|
||||||
String sender = GetSenderName(mp);
|
const char *sender = getSenderShortName(mp);
|
||||||
|
|
||||||
DEBUG_MSG("-----------------------------------------\n");
|
DEBUG_MSG("-----------------------------------------\n");
|
||||||
DEBUG_MSG("Environment Telemetry: Received data from %s\n", sender);
|
DEBUG_MSG("Environment Telemetry: Received data from %s\n", sender);
|
||||||
|
|
Ładowanie…
Reference in New Issue