Made a python script to create posts via meshtastic messages. If you can see this, the test worked! Posting from the park with no mobile data _

    • SalamanderMA
      link
      fedilink
      arrow-up
      2
      ·
      4 hours ago

      Cool, thanks for sharing!

      Where I run into problems is in the following step:

      def on_mqtt_message(client, userdata, msg):
          try:
              message = msg.payload.decode("utf-8", errors="replace")
      
      

      If the message is published by a meshtastic client, then my “message” looks something like:

      ̴=����*!�_��i��}M������jUJC�'�!���c�^5yk�=C��gE�����������LongFast?`

      So, I think that the UTF-8 decoding does not work on the raw payload, and that the payload needs to be processed into a mesh.protobuf. At least that is what I understand so far.

      The messages that you published via MQTT were messages sent from the Meshtastic client, or were they messages that you posted using mosquitto_pub? If this did work on packets that the meshtastic client published to MQTT then I must be overlooking something… Again, thanks for sharing!

        • SalamanderMA
          link
          fedilink
          arrow-up
          1
          ·
          edit-2
          3 hours ago

          I took some inspiration from your code and looked into how to decode the mesh.protobuf packets and managed to decode the MQTT messages! From the raw byte stream I had to remove the first two bytes of the payload and then process it as a MeshPacket to get the data in its readable form.

          Once processed, the payload from MQTT looks like this:

          from: 1501080443
          to: 3294953195
          channel: 8
          encrypted: "u\003\221n\354U\373\257\006["
          id: 882625294
          rx_time: 1739046557
          hop_limit: 3
          priority: HIGH
          hop_start: 3
          

          So, looking at your code, I think that what happened was that the messages were being posted to Mastodon only due to the on_receive() function. The MQTT messages would also trigger this function call when the node downlinks the MQTT message.

          What is useful about triggering the messages directly from the MQTT stream is that it is then possible to create a general application that listens to one or multiple MQTT servers without the need for a node to downlink.

          Here is the MeshPacket code:

          import mesh_pb2 
          import paho.mqtt.client as mqtt
          
          # MQTT Config
          MQTT_BROKER = "MQTT IP"
          MQTT_PORT = 1883
          MQTT_TOPIC = "#"
          
          def onMessage(client, userdata, msg):
              print(f"Received message on {msg.topic}")
              proto_msg = mesh_pb2.MeshPacket()
              print("Raw:\n\n")
              print(msg.payload)
              proto_msg.ParseFromString(msg.payload[2::])
              print("\n\nParsed:\n\n")
              print(proto_msg)
          
          client = mqtt.Client()
          client.on_message = onMessage
          client.connect(MQTT_BROKER, MQTT_PORT, 60)
          client.subscribe(MQTT_TOPIC)
          client.loop_forever()
          
          
        • SalamanderMA
          link
          fedilink
          arrow-up
          1
          ·
          4 hours ago

          Interesting! Thanks, I need to continue testing/studying.