Packet #3960151 Success

TRACEROUTE_APP packet from [Nevermore] Ceto🗼 (nvm4) to [matto] Base 🗼 (MB)

7
Total Receptions
7
Unique Gateways
3
Hop Count
74
Payload Bytes
Packet Information
Database ID: 3960151
Mesh Packet ID: 0x03a8f360
Used for correlation across gateways
Timestamp: 2025-07-17 10:32:24 UTC
From Node: [Nevermore] Ceto🗼 (nvm4)
To Node: [matto] Base 🗼 (MB)
Success: Processed
Protocol: TRACEROUTE_APP
Port: 70
Gateway: @lazynoda Rooftop 🍹 🌐 (LNRT)
Channel: MediumSlow
RSSI: -104 dBm
SNR: 5.75 dBm
Hop Info: 3/3 hops
Start: 3, Limit: 0
Payload Data
Protocol: TRACEROUTE_APP
Size: 74 bytes
Decoded: Yes
Decoded Data:
Route Information
Route Path: Rigel🗼🌞 (RIG)
Hop Count: 0 hops
Status: Forward incomplete, Return in progress
SNR Towards: -1.5 dB -2.0 dB
Return Path: Malasaña Solar ☀️ (🌇) [Nevermore] Perseo 🗼 (nvm1) @lazynoda Nerdf 🤓 🗼 (LNRF)
SNR Back: -12.75 dB -6.5 dB -0.75 dB
Traceroute Steps
Hop From Node To Node Distance SNR (dB) Direction Analysis
1 [matto] Base 🗼 (MB) Rigel🗼🌞 (RIG) 48.46 km -1.5 dB Origin Hops
2 Rigel🗼🌞 (RIG) [Nevermore] Ceto🗼 (nvm4) 49.93 km -2.0 dB Relay Hops
Traceroute incomplete - Final destination not reached
Return Path Steps
Hop From Node To Node Distance SNR (dB) Direction Analysis
1 [Nevermore] Ceto🗼 (nvm4) Malasaña Solar ☀️ (🌇) 13.50 km -12.75 dB Return Start Hops
2 Malasaña Solar ☀️ (🌇) [Nevermore] Perseo 🗼 (nvm1) 44.27 km -6.5 dB Return Relay Hops
3 [Nevermore] Perseo 🗼 (nvm1) @lazynoda Nerdf 🤓 🗼 (LNRF) 41.03 km -0.75 dB Return End Hops
Total Forward Distance
98.38 km
Total Return Distance
98.79 km
Combined Traceroute Graph
Controls: Drag nodes to rearrange • Mouse wheel to zoom • Click and drag background to pan • Hover for details
Loading graph...

Building graph...

Legend & Paths
Nodes
🔄 Router Node
📡 Gateway Node
🚀 Source Node
🎯 Target Node
Connections
RF Link
Gateway Connection
Direct Reception (0 hops)
Packet Paths
Loading paths...
Raw Packet Analysis
Complete field breakdown and MQTT privacy/exposure analysis
Packet Structure
MQTT Packet Flow:
ServiceEnvelope (MQTT layer) → MeshPacket (Mesh layer) → Decoded Payload (Application data)
Total Size:74 bytes
Gateway:!db2f6dec
Channel:MediumSlow
Payload Type:TRACEROUTE_APP
Hop Count:3 / 3
Privacy Summary
Exposure Level:
Direct Message
Privacy Features:
✓ Direct LoRa transmission (not via MQTT)
✓ Acknowledgment requested
+ 3 more...
Exposure Risks:
⚠ Packet visible to MQTT subscribers
⚠ Multi-hop path visible (3 hops)
+ 1 more...
MQTT ServiceEnvelope Fields

MQTT ServiceEnvelope contains the MeshPacket plus routing metadata

FieldValue
gateway_id !db2f6dec
Node ID format
channel_id MediumSlow
packet MeshPacket (74 bytes)
Contains the actual mesh network packet
MeshPacket Fields

Core mesh packet with routing and payload information

FieldValueType
from 2222057415
Source node ID
uint32
to 1127941960
Target node ID
uint32
decoded.portnum 70
TRACEROUTE_APP
enum
decoded.payload_length 74 bytes size
hop_limit Not set uint32
hop_start 3
Initial hop limit
uint32
hops_taken 3
Calculated: hop_start - hop_limit
derived
rx_rssi -104.0 dBm
Signal strength at gateway
int32
rx_snr 5.75 dB
Signal quality at gateway
float
rx_time 1752748343
Receive timestamp
fixed32
via_mqtt False
Direct LoRa transmission
bool
want_ack True
Acknowledgment requested
bool
priority Not set enum
delayed Not set enum
channel Not set uint32
pki_encrypted False
Standard encryption
bool
next_hop Not set uint32
relay_node 105
Relay node ID
uint32
tx_after Not set uint32
timestamp 1752748344.8214023
Unix timestamp
uint32
MQTT Privacy & Exposure Analysis

Analysis of privacy features and exposure risks when packet is shared via MQTT

Exposure Level: Direct Message
Privacy Features:
  • ✓ Direct LoRa transmission (not via MQTT)
  • ✓ Acknowledgment requested
  • ✓ Targeted to specific node
  • ✓ Custom channel: MediumSlow
  • ✓ Gateway node ID tracked
Exposure Risks:
  • ⚠ Packet visible to MQTT subscribers
  • ⚠ Multi-hop path visible (3 hops)
  • ⚠ RF signal metrics exposed (location inference possible)
MQTT-Specific Fields
Want ack: True
Gateway ID: !db2f6dec
Signal Metrics: RSSI: -104.0 dBm
SNR: 5.75 dB
Complete Payload Analysis

Detailed breakdown of all payload fields and decoded data

Payload Metadata:
Protocol:TRACEROUTE_APP
Size:74 bytes
Decoded: Yes
Complete Payload Data (JSON):
{ "route_nodes": [ 3052529474 ], "snr_towards": [ -1.5, -2.0 ], "route_back": [ 1756190245, 2687838088, 3355341417 ], "snr_back": [ -12.75, -6.5, -0.75 ], "route_node_names": { "3052529474": "Rigel🗼🌞 (RIG)", "1756190245": "Malasaña Solar ☀️ (🌇)", "2222057415": "[Nevermore] Ceto🗼 (nvm4)", "2687838088": "[Nevermore] Perseo 🗼 (nvm1)", "3355341417": "@lazynoda Nerdf 🤓 🗼 (LNRF)", "1127941960": "[matto] Base 🗼 (MB)" }, "traceroute_packet": { "packet_data": { "id": 3960151, "timestamp": 1752748344.8214023, "from_node_id": 2222057415, "to_node_id": 1127941960, "portnum": 70, "portnum_name": "TRACEROUTE_APP", "gateway_id": "!db2f6dec", "channel_id": "MediumSlow", "mesh_packet_id": 61404000, "rssi": -104, "snr": 5.75, "hop_limit": 0, "hop_start": 3, "payload_length": 74, "processed_successfully": 1, "raw_payload": "0a0442e7f1b51214faffffffffffffffff01f8ffffffffffffffff011a0c2556ad68882735a06972fec7221ecdffffffffffffffff01e6ffffffffffffffff01fdffffffffffffffff01", "via_mqtt": 0, "want_ack": 1, "priority": 0, "delayed": 0, "channel_index": null, "rx_time": 1752748343, "pki_encrypted": 0, "next_hop": 0, "relay_node": 105, "tx_after": 0, "timestamp_str": "2025-07-17 10:32:24", "hop_count": 3, "has_payload": true, "success": 1, "from_node_name": "[Nevermore] Ceto🗼 (nvm4)", "to_node_name": "[matto] Base 🗼 (MB)", "gateway_name": "@lazynoda Rooftop 🍹 🌐 (LNRT)", "gateway_location": { "node_id": 3677318636, "latitude": 40.2784256, "longitude": -3.9190528, "altitude": 660, "timestamp": 1752761851.2934413, "timestamp_str": "2025-07-17 14:17:31", "display_name": "@lazynoda Rooftop 🍹 🌐", "long_name": "@lazynoda Rooftop 🍹 🌐", "short_name": "LNRT", "hw_model": "HELTEC_WSL_V3" } }, "resolve_names": true, "packet_id": 3960151, "from_node_id": 2222057415, "to_node_id": 1127941960, "timestamp": 1752748344.8214023, "gateway_id": "!db2f6dec", "raw_payload": "0a0442e7f1b51214faffffffffffffffff01f8ffffffffffffffff011a0c2556ad68882735a06972fec7221ecdffffffffffffffff01e6ffffffffffffffff01fdffffffffffffffff01", "hop_limit": 0, "hop_start": 3, "from_node_name": "[Nevermore] Ceto🗼 (nvm4)", "to_node_name": "[matto] Base 🗼 (MB)", "route_data": { "route_nodes": [ 3052529474 ], "snr_towards": [ -1.5, -2.0 ], "route_back": [ 1756190245, 2687838088, 3355341417 ], "snr_back": [ -12.75, -6.5, -0.75 ] }, "forward_path": { "path_type": "forward_with_return", "node_ids": [ 1127941960, 3052529474, 2222057415 ], "node_names": [ "[matto] Base 🗼 (MB)", "Rigel🗼🌞 (RIG)", "[Nevermore] Ceto🗼 (nvm4)" ], "snr_values": [ -1.5, -2.0 ], "hops": [ { "hop_number": 1, "from_node_id": 1127941960, "to_node_id": 3052529474, "from_node_name": "[matto] Base 🗼 (MB)", "to_node_name": "Rigel🗼🌞 (RIG)", "snr": -1.5, "direction": "forward", "is_target_hop": false, "distance_meters": 48455.14766800926, "from_location_timestamp": 1752748315.5671146, "to_location_timestamp": 1752713672.2684917, "from_location_age_warning": "from 0.0h ago", "to_location_age_warning": "from 9.6h ago" }, { "hop_number": 2, "from_node_id": 3052529474, "to_node_id": 2222057415, "from_node_name": "Rigel🗼🌞 (RIG)", "to_node_name": "[Nevermore] Ceto🗼 (nvm4)", "snr": -2.0, "direction": "forward", "is_target_hop": false, "distance_meters": 49928.58832878598, "from_location_timestamp": 1752713672.2684917, "to_location_timestamp": 1752709748.203101, "from_location_age_warning": "from 9.6h ago", "to_location_age_warning": "from 10.7h ago" } ], "is_complete": false, "total_hops": 2 }, "return_path": { "path_type": "return", "node_ids": [ 2222057415, 1756190245, 2687838088, 3355341417 ], "node_names": [ "[Nevermore] Ceto🗼 (nvm4)", "Malasaña Solar ☀️ (🌇)", "[Nevermore] Perseo 🗼 (nvm1)", "@lazynoda Nerdf 🤓 🗼 (LNRF)" ], "snr_values": [ -12.75, -6.5, -0.75 ], "hops": [ { "hop_number": 1, "from_node_id": 2222057415, "to_node_id": 1756190245, "from_node_name": "[Nevermore] Ceto🗼 (nvm4)", "to_node_name": "Malasaña Solar ☀️ (🌇)", "snr": -12.75, "direction": "return", "is_target_hop": false, "distance_meters": 13496.544851361312, "from_location_timestamp": 1752709748.203101, "to_location_timestamp": 1752744008.3206995, "from_location_age_warning": "from 10.7h ago", "to_location_age_warning": "from 1.2h ago" }, { "hop_number": 2, "from_node_id": 1756190245, "to_node_id": 2687838088, "from_node_name": "Malasaña Solar ☀️ (🌇)", "to_node_name": "[Nevermore] Perseo 🗼 (nvm1)", "snr": -6.5, "direction": "return", "is_target_hop": false, "distance_meters": 44265.58069677956, "from_location_timestamp": 1752744008.3206995, "to_location_timestamp": 1752672163.3665843, "from_location_age_warning": "from 1.2h ago", "to_location_age_warning": "from 21.2h ago" }, { "hop_number": 3, "from_node_id": 2687838088, "to_node_id": 3355341417, "from_node_name": "[Nevermore] Perseo 🗼 (nvm1)", "to_node_name": "@lazynoda Nerdf 🤓 🗼 (LNRF)", "snr": -0.75, "direction": "return", "is_target_hop": false, "distance_meters": 41026.514040311304, "from_location_timestamp": 1752672163.3665843, "to_location_timestamp": 1752705671.6845431, "from_location_age_warning": "from 21.2h ago", "to_location_age_warning": "from 11.9h ago" } ], "is_complete": false, "total_hops": 3 }, "actual_rf_path": { "path_type": "combined_rf", "node_ids": [ 1127941960, 3052529474, 2222057415, 1756190245, 2687838088, 3355341417 ], "node_names": [ "[matto] Base 🗼 (MB)", "Rigel🗼🌞 (RIG)", "[Nevermore] Ceto🗼 (nvm4)", "Malasaña Solar ☀️ (🌇)", "[Nevermore] Perseo 🗼 (nvm1)", "@lazynoda Nerdf 🤓 🗼 (LNRF)" ], "snr_values": [ -1.5, -2.0, -12.75, -6.5, -0.75 ], "hops": [ { "hop_number": 1, "from_node_id": 1127941960, "to_node_id": 3052529474, "from_node_name": "[matto] Base 🗼 (MB)", "to_node_name": "Rigel🗼🌞 (RIG)", "snr": -1.5, "direction": "forward_rf", "is_target_hop": false, "distance_meters": 48455.14766800926, "from_location_timestamp": 1752748315.5671146, "to_location_timestamp": 1752713672.2684917, "from_location_age_warning": "from 0.0h ago", "to_location_age_warning": "from 9.6h ago" }, { "hop_number": 2, "from_node_id": 3052529474, "to_node_id": 2222057415, "from_node_name": "Rigel🗼🌞 (RIG)", "to_node_name": "[Nevermore] Ceto🗼 (nvm4)", "snr": -2.0, "direction": "forward_rf", "is_target_hop": false, "distance_meters": 49928.58832878598, "from_location_timestamp": 1752713672.2684917, "to_location_timestamp": 1752709748.203101, "from_location_age_warning": "from 9.6h ago", "to_location_age_warning": "from 10.7h ago" }, { "hop_number": 3, "from_node_id": 2222057415, "to_node_id": 1756190245, "from_node_name": "[Nevermore] Ceto🗼 (nvm4)", "to_node_name": "Malasaña Solar ☀️ (🌇)", "snr": -12.75, "direction": "return_rf", "is_target_hop": false, "distance_meters": 13496.544851361312, "from_location_timestamp": 1752709748.203101, "to_location_timestamp": 1752744008.3206995, "from_location_age_warning": "from 10.7h ago", "to_location_age_warning": "from 1.2h ago" }, { "hop_number": 4, "from_node_id": 1756190245, "to_node_id": 2687838088, "from_node_name": "Malasaña Solar ☀️ (🌇)", "to_node_name": "[Nevermore] Perseo 🗼 (nvm1)", "snr": -6.5, "direction": "return_rf", "is_target_hop": false, "distance_meters": 44265.58069677956, "from_location_timestamp": 1752744008.3206995, "to_location_timestamp": 1752672163.3665843, "from_location_age_warning": "from 1.2h ago", "to_location_age_warning": "from 21.2h ago" }, { "hop_number": 5, "from_node_id": 2687838088, "to_node_id": 3355341417, "from_node_name": "[Nevermore] Perseo 🗼 (nvm1)", "to_node_name": "@lazynoda Nerdf 🤓 🗼 (LNRF)", "snr": -0.75, "direction": "return_rf", "is_target_hop": false, "distance_meters": 41026.514040311304, "from_location_timestamp": 1752672163.3665843, "to_location_timestamp": 1752705671.6845431, "from_location_age_warning": "from 21.2h ago", "to_location_age_warning": "from 11.9h ago" } ], "is_complete": false, "total_hops": 5 } }, "has_return_path": true, "is_complete": false, "forward_path_display": "[matto] Base 🗼 (MB) → Rigel🗼🌞 (RIG) → [Nevermore] Ceto🗼 (nvm4)", "return_path_display": "[Nevermore] Ceto🗼 (nvm4) → Malasaña Solar ☀️ (🌇) → [Nevermore] Perseo 🗼 (nvm1) → @lazynoda Nerdf 🤓 🗼 (LNRF)", "actual_rf_path_display": "[matto] Base 🗼 (MB) → Rigel🗼🌞 (RIG) → [Nevermore] Ceto🗼 (nvm4) → Malasaña Solar ☀️ (🌇) → [Nevermore] Perseo 🗼 (nvm1) → @lazynoda Nerdf 🤓 🗼 (LNRF)", "forward_hops": [ { "hop_number": 1, "from_node_id": 1127941960, "to_node_id": 3052529474, "from_node_name": "[matto] Base 🗼 (MB)", "to_node_name": "Rigel🗼🌞 (RIG)", "snr": -1.5, "direction": "forward", "is_target_hop": false, "distance_meters": 48455.14766800926, "from_location_timestamp": 1752748315.5671146, "to_location_timestamp": 1752713672.2684917, "from_location_age_warning": "from 0.0h ago", "to_location_age_warning": "from 9.6h ago" }, { "hop_number": 2, "from_node_id": 3052529474, "to_node_id": 2222057415, "from_node_name": "Rigel🗼🌞 (RIG)", "to_node_name": "[Nevermore] Ceto🗼 (nvm4)", "snr": -2.0, "direction": "forward", "is_target_hop": false, "distance_meters": 49928.58832878598, "from_location_timestamp": 1752713672.2684917, "to_location_timestamp": 1752709748.203101, "from_location_age_warning": "from 9.6h ago", "to_location_age_warning": "from 10.7h ago" } ], "return_hops": [ { "hop_number": 1, "from_node_id": 2222057415, "to_node_id": 1756190245, "from_node_name": "[Nevermore] Ceto🗼 (nvm4)", "to_node_name": "Malasaña Solar ☀️ (🌇)", "snr": -12.75, "direction": "return", "is_target_hop": false, "distance_meters": 13496.544851361312, "from_location_timestamp": 1752709748.203101, "to_location_timestamp": 1752744008.3206995, "from_location_age_warning": "from 10.7h ago", "to_location_age_warning": "from 1.2h ago" }, { "hop_number": 2, "from_node_id": 1756190245, "to_node_id": 2687838088, "from_node_name": "Malasaña Solar ☀️ (🌇)", "to_node_name": "[Nevermore] Perseo 🗼 (nvm1)", "snr": -6.5, "direction": "return", "is_target_hop": false, "distance_meters": 44265.58069677956, "from_location_timestamp": 1752744008.3206995, "to_location_timestamp": 1752672163.3665843, "from_location_age_warning": "from 1.2h ago", "to_location_age_warning": "from 21.2h ago" }, { "hop_number": 3, "from_node_id": 2687838088, "to_node_id": 3355341417, "from_node_name": "[Nevermore] Perseo 🗼 (nvm1)", "to_node_name": "@lazynoda Nerdf 🤓 🗼 (LNRF)", "snr": -0.75, "direction": "return", "is_target_hop": false, "distance_meters": 41026.514040311304, "from_location_timestamp": 1752672163.3665843, "to_location_timestamp": 1752705671.6845431, "from_location_age_warning": "from 21.2h ago", "to_location_age_warning": "from 11.9h ago" } ], "total_forward_distance": 98383.73599679524, "total_return_distance": 98788.63958845218 }
Complete Protobuf Decode (JSON)
{ "service_envelope": { "gateway_id": "!db2f6dec", "channel_id": "MediumSlow", "packet": "MeshPacket (see mesh_packet below)" }, "mesh_packet": { "from": 2222057415, "to": 1127941960, "id": 61404000, "rx_time": 1752748343, "rx_snr": 5.75, "rx_rssi": -104, "hop_limit": 0, "hop_start": 3, "via_mqtt": 0, "want_ack": 1, "priority": 0, "delayed": 0, "channel_index": null, "pki_encrypted": 0, "next_hop": 0, "relay_node": 105, "tx_after": 0, "decoded": { "portnum": 70, "payload": "0a0442e7f1b51214faffffffffffffffff01f8ffffffffffffffff011a0c2556ad68882735a06972fec7221ecdffffffffffffffff01e6ffffffffffffffff01fdffffffffffffffff01", "want_response": null, "dest": null, "source": null, "request_id": null, "reply_id": null, "emoji": null, "parsed_payload": { "route": [ 3052529474 ], "snr_towards": [ -6, -8 ], "route_back": [ 1756190245, 2687838088, 3355341417 ], "snr_back": [ -51, -26, -3 ], "type": "protobuf", "portnum": "TRACEROUTE_APP", "message_class": "RouteDiscovery" } } } }
Raw Packet Data (74 bytes)
0a0442e7f1b51214faffffffffffffffff01f8ffffffffffffffff011a0c2556ad68882735a06972fec7221ecdffffffffffffffff01e6ffffffffffffffff01fdffffffffffffffff01
Hex Analysis:
Size:74 bytes
Format:Protobuf (Protocol Buffers)
Encoding:Binary with varint and length-delimited fields
This is the raw protobuf-encoded payload as received from MQTT. The structure follows the Meshtastic protobuf schema definitions.
All Receptions
All gateways that received this packet
Correlation: Using Mesh Packet ID
Reception Locations
Loading...

Loading reception map...

Map shows gateway locations that received this packet. Hop counts are displayed if available.
Gateway Time Offset RSSI SNR Hops Channel Timestamp Actions
@lazynoda Rooftop 🍹 🌐 (LNRT) Primary 0.000s
Reference
-104.0 dBm 5.75 dB 3 MediumSlow 2025-07-17 10:32:24 Current
Venturada2🗼🌐☀️ (Vb2) -5.647s
Before
-110.0 dBm -10.25 dB 0 MediumSlow 2025-07-17 10:32:19 View
Ocumare_Base1_🗼🌐 (CATA) -4.964s
Before
-124.0 dBm -15.25 dB 1 MediumSlow 2025-07-17 10:32:19 View
Alvaro (Alv) -4.204s
Before
-106.0 dBm 4.25 dB 1 MediumSlow 2025-07-17 10:32:20 View
GRN1-Base📡🌐 (GRN1) -4.088s
Before
-107.0 dBm -2.00 dB 1 MediumSlow 2025-07-17 10:32:20 View
@lazynoda cocidito 🥵 🗼🌐 (LNCM) -2.355s
Before
-116.0 dBm -5.25 dB 2 MediumSlow 2025-07-17 10:32:22 View
Wake Up, Neo...📡 (NEO) -1.580s
Before
-93.0 dBm Unknown 2 MediumSlow 2025-07-17 10:32:23 View
7

Total Receptions

7

Unique Gateways