From c7e6ba17f269695459d7008c7fb4cd9fb817401f Mon Sep 17 00:00:00 2001 From: GUVWAF Date: Mon, 24 Jul 2023 20:56:08 +0200 Subject: [PATCH 1/7] Update MQTT "Software Integrations" section --- docs/software/mqtt/index.mdx | 68 +++++++++++++++++------------------- 1 file changed, 33 insertions(+), 35 deletions(-) diff --git a/docs/software/mqtt/index.mdx b/docs/software/mqtt/index.mdx index 125afba1..88272e92 100644 --- a/docs/software/mqtt/index.mdx +++ b/docs/software/mqtt/index.mdx @@ -25,22 +25,34 @@ IMPORTANT: When MQTT is turned on, you are potentially broadcasting your entire ### MQTT Topics -The device will uplink and downlink raw ([protobuf](https://developers.google.com/protocol-buffers)) packets to the `msh/` prefix: +If no specific [root topic](/docs/settings/moduleconfig/mqtt#root-topic) is configured, the default root topic will be `msh/`. +Each device that is connected to MQTT will publish its MQTT state ("`online`"/"`offline`") to: -`msh/2/c/ShortFast/!12345678` where +`msh/2/stat/USERID`, where `USERID` is the user ID of the gateway device (the one connected to MQTT). -- `!12345678` is the address of the gateway device. -- `ShortFast` is the channel name. +For each channel where uplink and/or downlink is enabled two other topics might be used. + +#### Protobufs topic +A gateway node will uplink and/or downlink raw ([protobuf](https://developers.google.com/protocol-buffers)) packets to the topic: + +`msh/2/c/CHANNELNAME/USERID`, where `CHANNELNAME` is the name of the channel. + +For example: `msh/2/c/LongFast/!abcd1234` The payload is a raw protobuf. Looking at the MQTT traffic with a program like `mosquitto_sub` will tell you it's working, but you won't get much useful information out of it. For example: ```text 苓????"! - !937bed1cTanksTnk"D???05??=???aP` - ShortFast !937bed1c +!937bed1cTanksTnk"D???05??=???aP` +ShortFast !937bed1c ``` -Packets from the following [port numbers](/docs/development/firmware/portnum) are serialized to JSON and then forwarded to the `msh/2/json/CHANNELID/DEVICEID` topic: `TEXT_MESSAGE_APP`, `ENVIRONMENTAL_MEASUREMENT_APP`, `NODEINFO_APP` and `POSITION_APP`. +If [encryption_enabled](/docs/settings/moduleconfig/mqtt#encryption-enabled) is set to true, the packet will remain encrypted with the key for the specified channel. + +#### JSON topic +If [JSON is enabled](/docs/settings/moduleconfig/mqtt/#json-enabled), packets from the following [port numbers](/docs/development/firmware/portnum) are serialized to JSON: `TEXT_MESSAGE_APP`, `ENVIRONMENTAL_MEASUREMENT_APP`, `NODEINFO_APP` and `POSITION_APP`. These are then forwarded to the topic: + +`msh/2/json/CHANNELNAME/USERID`. An example of a received `NODEINFO_APP` message: @@ -62,6 +74,20 @@ An example of a received `NODEINFO_APP` message: } ``` +The meaning of these fields is as follows: + +- "`id`" is the unique ID for this message. +- "`channel`" is the channel index this message was received on. +- "`from`" is the unique node number of the node on the mesh that sent this message. +- "`id`" inside the payload of a `NODEINFO_APP` message is the user ID of the node that sent it, which is currently just the hexadecimal representation of the node number. +- "`hardware`" is the [hardware model](https://github.com/meshtastic/protobufs/blob/master/meshtastic/mesh.proto#L215) of the node sending the `NODEINFO_APP` message. +- "`longname`" is the long name of the device that sent the `NODEINFO_APP` message. +- "`shortname`" is the short name of the device that sent the `NODEINFO_APP` message. +- "`sender`" is the user ID of the gateway device, which is in this case the same node that sent the `NODEINFO_APP` message (the hexadecimal value `7efeee00` represented by an integer in decimal is `2130636288`). +- "`timestamp`" is the Unix Epoch when the message was received, represented as an integer in decimal. +- "`to`" is the node number of the destination of the message. In this case, "-1" means it was a broadcast message (this is the decimal integer representation of `0xFFFFFFFF`). +- "`type`" is the type of the message, in this case it was a `NODEINFO_APP` message. + If the message received contains valid JSON in the payload, the JSON is deserialized and added as a JSON object rather than a string containing the serialized JSON. **Sent messages** will be checked if the MQTT payload contains a valid JSON-encoded envelope: @@ -90,34 +116,6 @@ Check out [MQTT Settings](/docs/settings/moduleconfig/mqtt) for full information `uplink_enabled` will tell the device to publish mesh packets to MQTT. `downlink_enabled` will tell the device to subscribe to MQTT, and forward any packets from there onto the mesh. -### Topics - -The "mesh/crypt/CHANNELID/NODEID/PORTID" [topic](https://www.hivemq.com/blog/mqtt-essentials-part-5-mqtt-topics-best-practices) will be used for messages sent from/to a mesh. - -Gateway nodes will forward any MeshPacket from a local mesh channel with uplink_enabled. The packet (encapsulated in a ServiceEnvelope) will remain encrypted with the key for the specified channel. - -For any channels in the local node with downlink_enabled, the gateway node will forward packets from MQTT to the local mesh. It will do this by subscribing to mesh/crypt/CHANNELID/# and forwarding relevant packets. - -If the channelid 'well known'/public it could be decrypted by a web service (if the web service was provided with the associated channel key), in which case it will be decrypted by a web service and appear at "mesh/clear/CHANNELID/NODEID/PORTID". Note: This is not in the initial deliverable. - -#### Service Envelope - -The payload published on mesh/... will always be wrapped in a [ServiceEnvelope protobuf](https://buf.build/meshtastic/protobufs/docs/main:meshtastic#meshtastic.ServiceEnvelope). - -ServiceEnvelope will include the message, and full information about arrival time, who forwarded it, source channel, source mesh id, etc... - -#### NODEID - -The unique ID for a node. A hex string that starts with an ! symbol. - -#### USERID - -A user ID string. This string is either a user ID if known or a nodeid to simply deliver the message to whoever the local user is of a particular device (i.e. person who might see the screen). FIXME, see what riot.im uses and perhaps use that convention? Or use the signal +phone number convention? Or the email address? - -#### CHANNELID - -FIXME, figure out how channelids work - ### Gateway nodes Any meshtastic node that has a direct connection to the internet (either via a helper app or installed WiFi/4G/satellite hardware) can function as a "Gateway node". From 740ac50764f94fcfb5a40ece8c279366da524a3f Mon Sep 17 00:00:00 2001 From: GUVWAF Date: Tue, 25 Jul 2023 20:57:16 +0200 Subject: [PATCH 2/7] Add note about 'from' field being signed in JSON --- docs/software/mqtt/index.mdx | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/docs/software/mqtt/index.mdx b/docs/software/mqtt/index.mdx index 88272e92..b3d8d3ed 100644 --- a/docs/software/mqtt/index.mdx +++ b/docs/software/mqtt/index.mdx @@ -78,7 +78,7 @@ The meaning of these fields is as follows: - "`id`" is the unique ID for this message. - "`channel`" is the channel index this message was received on. -- "`from`" is the unique node number of the node on the mesh that sent this message. +- "`from`" is the unique node number of the node on the mesh that sent this message, represented as a signed decimal number. - "`id`" inside the payload of a `NODEINFO_APP` message is the user ID of the node that sent it, which is currently just the hexadecimal representation of the node number. - "`hardware`" is the [hardware model](https://github.com/meshtastic/protobufs/blob/master/meshtastic/mesh.proto#L215) of the node sending the `NODEINFO_APP` message. - "`longname`" is the long name of the device that sent the `NODEINFO_APP` message. @@ -88,6 +88,8 @@ The meaning of these fields is as follows: - "`to`" is the node number of the destination of the message. In this case, "-1" means it was a broadcast message (this is the decimal integer representation of `0xFFFFFFFF`). - "`type`" is the type of the message, in this case it was a `NODEINFO_APP` message. +The "from" field can thus be used as a stable identifier for a specific node. Note that (like the "`id`" and "`to`" fields) in JSON this is a signed value, whereas in protobufs it is unsigned. + If the message received contains valid JSON in the payload, the JSON is deserialized and added as a JSON object rather than a string containing the serialized JSON. **Sent messages** will be checked if the MQTT payload contains a valid JSON-encoded envelope: From ca2365b6509d25e486b3bc0937b07d3739b7c10b Mon Sep 17 00:00:00 2001 From: GUVWAF Date: Tue, 25 Jul 2023 20:57:58 +0200 Subject: [PATCH 3/7] MeshPacket is encapsulated in a ServiceEnvelope --- docs/software/mqtt/index.mdx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/software/mqtt/index.mdx b/docs/software/mqtt/index.mdx index b3d8d3ed..70a88b25 100644 --- a/docs/software/mqtt/index.mdx +++ b/docs/software/mqtt/index.mdx @@ -17,7 +17,7 @@ You can find the settings available for MQTT [here](/docs/settings/moduleconfig/ Using or emitting packets directly in/from smart home control software such as Home Assistant or other consumers that can work with JSON messages. -When MQTT is enabled, the Meshtastic device simply uplinks and/or downlinks every raw protobuf packet that it sees to the MQTT broker. In addition, some packet types are serialized or deserialized from/to JSON messages for easier use in consumers. All packets are sent to the broker, whether they originate from another device on the mesh, or the gateway node itself. +When MQTT is enabled, the Meshtastic device simply uplinks and/or downlinks every raw protobuf MeshPacket that it sees to the MQTT broker, encapsulated in a [ServiceEnvelope protobuf](https://buf.build/meshtastic/protobufs/docs/main:meshtastic#meshtastic.ServiceEnvelope). In addition, some packet types are serialized or deserialized from/to JSON messages for easier use in consumers. All packets are sent to the broker, whether they originate from another device on the mesh, or the gateway node itself. Packets may be encrypted. If you use the default meshtastic MQTT server, packets are always encrypted. If you use a custom MQTT broker (ie set `mqtt.address`), the `mqtt.encryption_enabled` setting applies, which by default is false. From ee40ecec4ddbaa3a125be2bf1b77fabd720c3c45 Mon Sep 17 00:00:00 2001 From: GUVWAF Date: Tue, 25 Jul 2023 20:59:18 +0200 Subject: [PATCH 4/7] Some information for how to use the protobufs topic --- docs/software/mqtt/index.mdx | 10 +++++----- 1 file changed, 5 insertions(+), 5 deletions(-) diff --git a/docs/software/mqtt/index.mdx b/docs/software/mqtt/index.mdx index 70a88b25..e0d47f05 100644 --- a/docs/software/mqtt/index.mdx +++ b/docs/software/mqtt/index.mdx @@ -23,7 +23,7 @@ Packets may be encrypted. If you use the default meshtastic MQTT server, packets IMPORTANT: When MQTT is turned on, you are potentially broadcasting your entire mesh traffic onto the public internet. This includes messages and position information. -### MQTT Topics +### MQTT [Topics](https://www.hivemq.com/blog/mqtt-essentials-part-5-mqtt-topics-best-practices) If no specific [root topic](/docs/settings/moduleconfig/mqtt#root-topic) is configured, the default root topic will be `msh/`. Each device that is connected to MQTT will publish its MQTT state ("`online`"/"`offline`") to: @@ -33,18 +33,18 @@ Each device that is connected to MQTT will publish its MQTT state ("`online`"/"` For each channel where uplink and/or downlink is enabled two other topics might be used. #### Protobufs topic -A gateway node will uplink and/or downlink raw ([protobuf](https://developers.google.com/protocol-buffers)) packets to the topic: +A gateway node will uplink and/or downlink raw ([protobuf](https://developers.google.com/protocol-buffers)) MeshPackets to the topic: `msh/2/c/CHANNELNAME/USERID`, where `CHANNELNAME` is the name of the channel. For example: `msh/2/c/LongFast/!abcd1234` -The payload is a raw protobuf. Looking at the MQTT traffic with a program like `mosquitto_sub` will tell you it's working, but you won't get much useful information out of it. For example: +The payload is a raw protobuf, whose definitions for Meshtastic can be found [here](https://github.com/meshtastic/protobufs/blob/master/meshtastic). Reference guides for working with protobufs in several popular programming languages can be found [here](https://protobuf.dev/reference/). Looking at the MQTT traffic with a program like `mosquitto_sub` will tell you it's working, but you won't get much useful information out of it. For example: ```text 苓????"! -!937bed1cTanksTnk"D???05??=???aP` -ShortFast !937bed1c + !937bed1cTanksTnk"D???05??=???aP` + ShortFast !937bed1c ``` If [encryption_enabled](/docs/settings/moduleconfig/mqtt#encryption-enabled) is set to true, the packet will remain encrypted with the key for the specified channel. From b8b3c4144e3da9090284185c2a3a3fad91ec9042 Mon Sep 17 00:00:00 2001 From: GUVWAF Date: Wed, 26 Jul 2023 18:54:11 +0200 Subject: [PATCH 5/7] Only the payload is encrypted --- docs/software/mqtt/index.mdx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/software/mqtt/index.mdx b/docs/software/mqtt/index.mdx index e0d47f05..a47854f0 100644 --- a/docs/software/mqtt/index.mdx +++ b/docs/software/mqtt/index.mdx @@ -47,7 +47,7 @@ The payload is a raw protobuf, whose definitions for Meshtastic can be found [he ShortFast !937bed1c ``` -If [encryption_enabled](/docs/settings/moduleconfig/mqtt#encryption-enabled) is set to true, the packet will remain encrypted with the key for the specified channel. +If [encryption_enabled](/docs/settings/moduleconfig/mqtt#encryption-enabled) is set to true, the payload of the MeshPacket will remain encrypted with the key for the specified channel. #### JSON topic If [JSON is enabled](/docs/settings/moduleconfig/mqtt/#json-enabled), packets from the following [port numbers](/docs/development/firmware/portnum) are serialized to JSON: `TEXT_MESSAGE_APP`, `ENVIRONMENTAL_MEASUREMENT_APP`, `NODEINFO_APP` and `POSITION_APP`. These are then forwarded to the topic: From 153ede2f1eae9f84e741ed67c6dbf40ba879e506 Mon Sep 17 00:00:00 2001 From: Neil Hao Date: Fri, 28 Jul 2023 14:28:36 +0800 Subject: [PATCH 6/7] Update Neil to trademark-grants.mdx --- docs/legal/trademark-grants.mdx | 2 ++ 1 file changed, 2 insertions(+) diff --git a/docs/legal/trademark-grants.mdx b/docs/legal/trademark-grants.mdx index 15d9014b..d1d667f0 100644 --- a/docs/legal/trademark-grants.mdx +++ b/docs/legal/trademark-grants.mdx @@ -22,3 +22,5 @@ sidebar_label: Trademark Grants - Details: Paul primarily designs enclosures and assembles complete Meshtastic Radios for sale using modules from TTGO, Heltec and RAK. He runs an online shop for Meshtastic powered devices which carry the "Meshtastic" and M logos. The use of the Meshtastic Logo and Trademarks does not imply Paul is sponsored or endorsed by Meshtastic. Paul also agrees to maintain compliance with the Meshtastic Legal requirements. This grant is revokable at any time for any reason. - Grant: [Keith Monaghan](http://voltaicenclosures.com/) - Details: Keith is a contributer of computer aided design (CAD)/3D designs primarily for device enclosures and accessories, and runs an online shop for Meshtastic powered devices which carry the "Meshtastic" and "M" logos. The use of the Meshtastic Logo and Trademarks does not imply Keith is sponsored or endorsed by Meshtastic. Keith also agrees to maintain compliance with the Meshtastic Legal requirements. This grant is revokable at any time for any reason. +- Grant: [Neil Hao](https://shop.uniteng.com/) + - Details: Neil is a contributer of hardware designs, and runs an online shop for Meshtastic powered devices which carry the "Meshtastic" and "M" logos. The use of the Meshtastic Logo and Trademarks does not imply Neil is sponsored or endorsed by Meshtastic. Neil also agrees to maintain compliance with the Meshtastic Legal requirements. This grant is revokable at any time for any reason. From 811dfdf7e3fbcf71f036fc36c95685bbcc6631f2 Mon Sep 17 00:00:00 2001 From: rcarteraz Date: Fri, 28 Jul 2023 08:57:58 -0700 Subject: [PATCH 7/7] add clarifying message --- docs/getting-started/flashing-firmware/nrf52/ota.mdx | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/docs/getting-started/flashing-firmware/nrf52/ota.mdx b/docs/getting-started/flashing-firmware/nrf52/ota.mdx index 87378489..941f9769 100644 --- a/docs/getting-started/flashing-firmware/nrf52/ota.mdx +++ b/docs/getting-started/flashing-firmware/nrf52/ota.mdx @@ -21,7 +21,7 @@ values={[ :::info -As of this writing, the current Android release of the nRF DFU app (v2.3.0) is not compatible with Meshtastic firmware updates. +As of this writing, the current Android release of the nRF DFU app (v2.3.0) is not compatible with Meshtastic firmware updates. Please use the instructions below for updating via OTA with the nRF Connect App. ::: OTA firmware updates are available for Android using an older release of the more advanced nRF Connect App __version 4.24.3__ which is available for download from the [Nordic Semiconductor GitHub page](https://github.com/NordicSemiconductor/Android-nRF-Connect/releases/tag/v4.24.3).