kopia lustrzana https://github.com/meshtastic/firmware
Send own node-info earlier and move others to the end of want-config flow (#3949)
* Send own node-info earlier and move others to the end of want-config flow * Special nonce skips other nodeinfos * Missed itpull/3980/head^2
rodzic
038413f46f
commit
af9d825266
|
@ -140,16 +140,18 @@ bool PhoneAPI::handleToRadio(const uint8_t *buf, size_t bufLength)
|
||||||
*
|
*
|
||||||
* We assume buf is at least FromRadio_size bytes long.
|
* We assume buf is at least FromRadio_size bytes long.
|
||||||
*
|
*
|
||||||
* Our sending states progress in the following sequence (the client app ASSUMES THIS SEQUENCE, DO NOT CHANGE IT):
|
* Our sending states progress in the following sequence (the client apps ASSUME THIS SEQUENCE, DO NOT CHANGE IT):
|
||||||
* STATE_SEND_MY_INFO, // send our my info record
|
STATE_SEND_MY_INFO, // send our my info record
|
||||||
* STATE_SEND_CHANNELS
|
STATE_SEND_OWN_NODEINFO,
|
||||||
* STATE_SEND_NODEINFO, // states progress in this order as the device sends to the client
|
STATE_SEND_METADATA,
|
||||||
|
STATE_SEND_CHANNELS
|
||||||
STATE_SEND_CONFIG,
|
STATE_SEND_CONFIG,
|
||||||
STATE_SEND_MODULE_CONFIG,
|
STATE_SEND_MODULE_CONFIG,
|
||||||
STATE_SEND_METADATA,
|
STATE_SEND_OTHER_NODEINFOS, // states progress in this order as the device sends to the client
|
||||||
STATE_SEND_COMPLETE_ID,
|
STATE_SEND_COMPLETE_ID,
|
||||||
STATE_SEND_PACKETS // send packets or debug strings
|
STATE_SEND_PACKETS // send packets or debug strings
|
||||||
*/
|
*/
|
||||||
|
|
||||||
size_t PhoneAPI::getFromRadio(uint8_t *buf)
|
size_t PhoneAPI::getFromRadio(uint8_t *buf)
|
||||||
{
|
{
|
||||||
if (!available()) {
|
if (!available()) {
|
||||||
|
@ -171,36 +173,31 @@ size_t PhoneAPI::getFromRadio(uint8_t *buf)
|
||||||
// app not to send locations on our behalf.
|
// app not to send locations on our behalf.
|
||||||
fromRadioScratch.which_payload_variant = meshtastic_FromRadio_my_info_tag;
|
fromRadioScratch.which_payload_variant = meshtastic_FromRadio_my_info_tag;
|
||||||
fromRadioScratch.my_info = myNodeInfo;
|
fromRadioScratch.my_info = myNodeInfo;
|
||||||
state = STATE_SEND_METADATA;
|
state = STATE_SEND_OWN_NODEINFO;
|
||||||
|
|
||||||
service.refreshLocalMeshNode(); // Update my NodeInfo because the client will be asking for it soon.
|
service.refreshLocalMeshNode(); // Update my NodeInfo because the client will be asking for it soon.
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case STATE_SEND_OWN_NODEINFO: {
|
||||||
|
LOG_INFO("getFromRadio=STATE_SEND_OWN_NODEINFO\n");
|
||||||
|
auto us = nodeDB->readNextMeshNode(readIndex);
|
||||||
|
if (us) {
|
||||||
|
nodeInfoForPhone = TypeConversions::ConvertToNodeInfo(us);
|
||||||
|
fromRadioScratch.which_payload_variant = meshtastic_FromRadio_node_info_tag;
|
||||||
|
fromRadioScratch.node_info = nodeInfoForPhone;
|
||||||
|
// Should allow us to resume sending NodeInfo in STATE_SEND_OTHER_NODEINFOS
|
||||||
|
nodeInfoForPhone.num = 0;
|
||||||
|
}
|
||||||
|
state = STATE_SEND_METADATA;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
case STATE_SEND_METADATA:
|
case STATE_SEND_METADATA:
|
||||||
LOG_INFO("getFromRadio=STATE_SEND_METADATA\n");
|
LOG_INFO("getFromRadio=STATE_SEND_METADATA\n");
|
||||||
fromRadioScratch.which_payload_variant = meshtastic_FromRadio_metadata_tag;
|
fromRadioScratch.which_payload_variant = meshtastic_FromRadio_metadata_tag;
|
||||||
fromRadioScratch.metadata = getDeviceMetadata();
|
fromRadioScratch.metadata = getDeviceMetadata();
|
||||||
state = STATE_SEND_NODEINFO;
|
|
||||||
break;
|
|
||||||
|
|
||||||
case STATE_SEND_NODEINFO: {
|
|
||||||
LOG_INFO("getFromRadio=STATE_SEND_NODEINFO\n");
|
|
||||||
|
|
||||||
if (nodeInfoForPhone.num != 0) {
|
|
||||||
LOG_INFO("nodeinfo: num=0x%x, lastseen=%u, id=%s, name=%s\n", nodeInfoForPhone.num, nodeInfoForPhone.last_heard,
|
|
||||||
nodeInfoForPhone.user.id, nodeInfoForPhone.user.long_name);
|
|
||||||
fromRadioScratch.which_payload_variant = meshtastic_FromRadio_node_info_tag;
|
|
||||||
fromRadioScratch.node_info = nodeInfoForPhone;
|
|
||||||
// Stay in current state until done sending nodeinfos
|
|
||||||
nodeInfoForPhone.num = 0; // We just consumed a nodeinfo, will need a new one next time
|
|
||||||
} else {
|
|
||||||
LOG_INFO("Done sending nodeinfos\n");
|
|
||||||
state = STATE_SEND_CHANNELS;
|
state = STATE_SEND_CHANNELS;
|
||||||
// Go ahead and send that ID right now
|
|
||||||
return getFromRadio(buf);
|
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
}
|
|
||||||
|
|
||||||
case STATE_SEND_CHANNELS:
|
case STATE_SEND_CHANNELS:
|
||||||
LOG_INFO("getFromRadio=STATE_SEND_CHANNELS\n");
|
LOG_INFO("getFromRadio=STATE_SEND_CHANNELS\n");
|
||||||
|
@ -325,11 +322,30 @@ size_t PhoneAPI::getFromRadio(uint8_t *buf)
|
||||||
config_state++;
|
config_state++;
|
||||||
// Advance when we have sent all of our ModuleConfig objects
|
// Advance when we have sent all of our ModuleConfig objects
|
||||||
if (config_state > (_meshtastic_AdminMessage_ModuleConfigType_MAX + 1)) {
|
if (config_state > (_meshtastic_AdminMessage_ModuleConfigType_MAX + 1)) {
|
||||||
state = STATE_SEND_COMPLETE_ID;
|
// Clients sending special nonce don't want to see other nodeinfos
|
||||||
|
state = config_nonce == SPECIAL_NONCE ? STATE_SEND_COMPLETE_ID : STATE_SEND_OTHER_NODEINFOS;
|
||||||
config_state = 0;
|
config_state = 0;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case STATE_SEND_OTHER_NODEINFOS: {
|
||||||
|
LOG_INFO("getFromRadio=STATE_SEND_OTHER_NODEINFOS\n");
|
||||||
|
if (nodeInfoForPhone.num != 0) {
|
||||||
|
LOG_INFO("nodeinfo: num=0x%x, lastseen=%u, id=%s, name=%s\n", nodeInfoForPhone.num, nodeInfoForPhone.last_heard,
|
||||||
|
nodeInfoForPhone.user.id, nodeInfoForPhone.user.long_name);
|
||||||
|
fromRadioScratch.which_payload_variant = meshtastic_FromRadio_node_info_tag;
|
||||||
|
fromRadioScratch.node_info = nodeInfoForPhone;
|
||||||
|
// Stay in current state until done sending nodeinfos
|
||||||
|
nodeInfoForPhone.num = 0; // We just consumed a nodeinfo, will need a new one next time
|
||||||
|
} else {
|
||||||
|
LOG_INFO("Done sending nodeinfos\n");
|
||||||
|
state = STATE_SEND_COMPLETE_ID;
|
||||||
|
// Go ahead and send that ID right now
|
||||||
|
return getFromRadio(buf);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
case STATE_SEND_COMPLETE_ID:
|
case STATE_SEND_COMPLETE_ID:
|
||||||
LOG_INFO("getFromRadio=STATE_SEND_COMPLETE_ID\n");
|
LOG_INFO("getFromRadio=STATE_SEND_COMPLETE_ID\n");
|
||||||
fromRadioScratch.which_payload_variant = meshtastic_FromRadio_config_complete_id_tag;
|
fromRadioScratch.which_payload_variant = meshtastic_FromRadio_config_complete_id_tag;
|
||||||
|
@ -422,10 +438,11 @@ bool PhoneAPI::available()
|
||||||
case STATE_SEND_CONFIG:
|
case STATE_SEND_CONFIG:
|
||||||
case STATE_SEND_MODULECONFIG:
|
case STATE_SEND_MODULECONFIG:
|
||||||
case STATE_SEND_METADATA:
|
case STATE_SEND_METADATA:
|
||||||
|
case STATE_SEND_OWN_NODEINFO:
|
||||||
case STATE_SEND_COMPLETE_ID:
|
case STATE_SEND_COMPLETE_ID:
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
case STATE_SEND_NODEINFO:
|
case STATE_SEND_OTHER_NODEINFOS:
|
||||||
if (nodeInfoForPhone.num == 0) {
|
if (nodeInfoForPhone.num == 0) {
|
||||||
auto nextNode = nodeDB->readNextMeshNode(readIndex);
|
auto nextNode = nodeDB->readNextMeshNode(readIndex);
|
||||||
if (nextNode) {
|
if (nextNode) {
|
||||||
|
|
|
@ -6,6 +6,7 @@
|
||||||
|
|
||||||
// Make sure that we never let our packets grow too large for one BLE packet
|
// Make sure that we never let our packets grow too large for one BLE packet
|
||||||
#define MAX_TO_FROM_RADIO_SIZE 512
|
#define MAX_TO_FROM_RADIO_SIZE 512
|
||||||
|
#define SPECIAL_NONCE 69420
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Provides our protobuf based API which phone/PC clients can use to talk to our device
|
* Provides our protobuf based API which phone/PC clients can use to talk to our device
|
||||||
|
@ -22,11 +23,12 @@ class PhoneAPI
|
||||||
enum State {
|
enum State {
|
||||||
STATE_SEND_NOTHING, // Initial state, don't send anything until the client starts asking for config
|
STATE_SEND_NOTHING, // Initial state, don't send anything until the client starts asking for config
|
||||||
STATE_SEND_MY_INFO, // send our my info record
|
STATE_SEND_MY_INFO, // send our my info record
|
||||||
STATE_SEND_NODEINFO, // states progress in this order as the device sends to to the client
|
STATE_SEND_OWN_NODEINFO,
|
||||||
|
STATE_SEND_METADATA,
|
||||||
STATE_SEND_CHANNELS, // Send all channels
|
STATE_SEND_CHANNELS, // Send all channels
|
||||||
STATE_SEND_CONFIG, // Replacement for the old Radioconfig
|
STATE_SEND_CONFIG, // Replacement for the old Radioconfig
|
||||||
STATE_SEND_MODULECONFIG, // Send Module specific config
|
STATE_SEND_MODULECONFIG, // Send Module specific config
|
||||||
STATE_SEND_METADATA,
|
STATE_SEND_OTHER_NODEINFOS, // states progress in this order as the device sends to to the client
|
||||||
STATE_SEND_COMPLETE_ID,
|
STATE_SEND_COMPLETE_ID,
|
||||||
STATE_SEND_PACKETS // send packets or debug strings
|
STATE_SEND_PACKETS // send packets or debug strings
|
||||||
};
|
};
|
||||||
|
|
Ładowanie…
Reference in New Issue