Skip to content

Latest commit

 

History

History
136 lines (94 loc) · 4.25 KB

README.md

File metadata and controls

136 lines (94 loc) · 4.25 KB

Created by: Liam Cottle
Forked by: Tilen Komel

Meshtastic Map

A map of all Meshtastic nodes heard via MQTT.

My version of the map is available at https://map.meshnet.si

How does it work?

  • An mqtt client is persistently connected to mqtt.meshnet.si and subscribed to the si/# topic.
  • All messages received are attempted to be decoded as ServiceEnvelope packets.
  • If a packet is encrypted, it attempts to decrypt it with the default AQ== key.
  • If a packet can't be decoded as a ServiceEnvelope, it is ignored.
  • NODEINFO_APP packets add a node to the database.
  • POSITION_APP packets update the position of a node in the database.
  • NEIGHBORINFO_APP packets log neighbours heard by a node to the database.
  • TELEMETRY_APP packets update battery and voltage metrics for a node in the database.
  • TRACEROUTE_APP packets log all trace routes performed by a node to the database.
  • MAP_REPORT_APP packets are stored in the database, but are not widely adopted, so are not used yet.
  • The database is a MySQL server, and a nodejs express server is running an API to serve data to the map interface.

Features

  • Connects to mqtt.meshtastic.org to collect nodes and metrics.
  • Shows nodes on the map if they have reported a valid position.
  • Search bar to find nodes by ID, Hex ID, Short Name and Long Name.
  • Hover over nodes on the map to see basic information and a preview image.
  • Click nodes on the map to show a sidebar with more info such as telemetry graphs and traceroutes.
  • Ability to share a direct link to a node. The map will auto navigate to it.
  • Device list. To see which hardware models are most popular.
  • Mobile optimised layout.
  • Settings available to hide nodes from the map if they haven't been updated in a while.
  • Real-Time message UI to view TEXT_MESSAGE_APP packets as they come in.
  • View position history of a node between a selectable time range.
  • "Neighbours" map layer. Shows blue connection lines between nodes that heard the other node.
    • This information is taken from the NEIGHBORINFO_APP.
    • Some neighbour lines are clearly wrong.
    • Meshtastic firmware older than v2.3.2 reports MQTT nodes as Neighbours.
    • This was fixed in meshtastic/firmware/#3457, but adoption will likely be slow...

Dev

Clone the project repo:

git clone https://github.com/KomelT/meshtastic-map
cd meshtastic-map

Build Docker images:

docker compose -f docker-compose.dev.yaml build

Update environment variables:

nano docker-compose.yaml

ENV lists:

Run:

docker compose -f docker-compose.dev.yaml up

Run

Clone the project repo:

git clone https://github.com/KomelT/meshtastic-map
cd meshtastic-map

Build Docker images:

docker compose build

Update environment variables:

nano docker-compose.yaml

ENV lists:

Run:

docker compose up

Updating

You can just git pull or pull new image from Docekr Hub. Migrations will handle DB update.

Testing

To execute unit tests, run the following;

npm run test

Contributing

If you have a feature request, or find a bug, please open an issue here on GitHub.

License

MIT

Legal

This project is not affiliated with or endorsed by the Meshtastic project. The Meshtastic logo is the trademark of Meshtastic LLC.

THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.