Packet #392777 Success

TRACEROUTE_APP packet from art28 πŸŒ‹ (art2) to R4CDZ/h (EIPh)

6
Total Receptions
6
Unique Gateways
0
Hop Count
42
Payload Bytes
Packet Information
Database ID: 392777
Mesh Packet ID: 0x39733551
Used for correlation across gateways
Timestamp: 2025-12-14 21:12:44 UTC
From Node: art28 πŸŒ‹ (art2)
To Node: R4CDZ/h (EIPh)
Success: Processed
Protocol: TRACEROUTE_APP
Port: 70
Gateway: Meshtastic d888 (d888)
Channel: LongFast
RSSI: -91 dBm
SNR: 3.75 dBm
Hop Info: 0/4 hops
Start: 4, Limit: 4
Payload Data
Protocol: TRACEROUTE_APP
Size: 42 bytes
Decoded: Yes
Decoded Data:
Route Information
Route Path: !ffffffff β†’ VinnyPuh 2 (vp2)
Hop Count: 1 hops
Status: Complete
SNR Towards: -32.0 dB -3.5 dB -17.75 dB
Route Visualization
Loading...

Loading route map...

Map shows the geographic path if nodes have shared location data.
Traceroute Steps
Hop From Node To Node Distance SNR (dB) Direction Analysis
1 art28 πŸŒ‹ (art2) !ffffffff Unknown -32.0 dB Origin Hops
2 !ffffffff VinnyPuh 2 (vp2) Unknown -3.5 dB Destination Hops
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...
.traceroute-graph-container { height: 700px; width: 100%; border: 1px solid #dee2e6; border-radius: 0.375rem; position: relative; overflow: hidden; background: linear-gradient(135deg, #f8f9fa 0%, #e9ecef 100%); } /* Mobile responsiveness */ @media (max-width: 768px) { .traceroute-graph-container { height: 500px; } } /* Legend items */ .legend-item { display: flex; align-items: center; padding: 4px 6px; border-radius: 4px; cursor: pointer; transition: background-color 0.2s ease; position: relative; } .legend-item:hover { background-color: rgba(0, 123, 255, 0.1); } .legend-path-item { display: flex; align-items: center; padding: 3px 6px; border-radius: 4px; cursor: pointer; transition: all 0.2s ease; margin-bottom: 2px; border-left: 3px solid transparent; } .legend-path-item:hover { background-color: rgba(0, 0, 0, 0.05); transform: translateX(2px); } .legend-path-item.highlighted { background-color: rgba(0, 123, 255, 0.15); border-left-color: var(--path-color, #007bff); } .legend-path-color { width: 16px; height: 3px; margin-right: 8px; border-radius: 2px; flex-shrink: 0; } .legend-path-info { flex: 1; min-width: 0; } .legend-path-title { font-size: 0.75rem; font-weight: 600; margin-bottom: 1px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; } .legend-path-details { font-size: 0.65rem; color: #6c757d; line-height: 1.2; } /* Tooltip styles */ .legend-tooltip { position: absolute; background: rgba(0, 0, 0, 0.9); color: white; padding: 8px 12px; border-radius: 6px; font-size: 0.75rem; pointer-events: none; z-index: 1000; max-width: 250px; box-shadow: 0 4px 12px rgba(0, 0, 0, 0.3); opacity: 0; transition: opacity 0.2s ease; white-space: nowrap; } .traceroute-graph-container svg { cursor: grab; } .traceroute-graph-container svg:active { cursor: grabbing; } .graph-tooltip { position: absolute; background: rgba(0, 0, 0, 0.95); color: white; padding: 12px 16px; border-radius: 8px; font-size: 13px; pointer-events: none; z-index: 1000; max-width: 400px; box-shadow: 0 8px 32px rgba(0, 0, 0, 0.3); line-height: 1.5; border: 1px solid rgba(255, 255, 255, 0.1); } .graph-tooltip .tooltip-title { font-weight: bold; margin-bottom: 8px; color: #fff; font-size: 14px; border-bottom: 1px solid rgba(255, 255, 255, 0.2); padding-bottom: 4px; } .graph-tooltip .tooltip-content { color: #e0e0e0; } .graph-tooltip .tooltip-badge { display: inline-block; background: rgba(255, 255, 255, 0.2); padding: 2px 6px; border-radius: 4px; font-size: 11px; margin: 2px 4px 2px 0; } .node-circle { cursor: pointer; transition: all 0.3s ease; filter: drop-shadow(2px 2px 4px rgba(0,0,0,0.2)); } .node-circle:hover { stroke-width: 4px !important; filter: drop-shadow(2px 2px 8px rgba(0,0,0,0.4)) brightness(1.1); transform: scale(1.1); } .node-router { fill: #4a90e2; stroke: #2c5aa0; } .node-gateway { fill: #28a745; stroke: #1e7e34; } .node-gateway-router { fill: url(#gatewayRouterGradient); stroke: #1e7e34; } .node-source { fill: #ff6b35 !important; stroke: #d63031 !important; stroke-width: 4px !important; } .node-target { fill: #6c5ce7 !important; stroke: #5f3dc4 !important; stroke-width: 4px !important; } .link-line { transition: all 0.3s ease; cursor: pointer; filter: drop-shadow(1px 1px 2px rgba(0,0,0,0.1)); } .link-line:hover { stroke-width: 8px !important; filter: drop-shadow(2px 2px 4px rgba(0,0,0,0.3)); } .gateway-connection { stroke-dasharray: 5,5; stroke: #17a2b8; stroke-width: 2; opacity: 0.7; } .gateway-connection:hover { opacity: 1; stroke-width: 4; } .gateway-connection-zero-hop { stroke-dasharray: 2,2; stroke: #fd7e14; stroke-width: 2; opacity: 0.7; } .gateway-connection-zero-hop:hover { opacity: 1; stroke-width: 4; } .path-line { fill: none; stroke-width: 4; opacity: 0.8; transition: all 0.3s ease; pointer-events: none; filter: drop-shadow(1px 1px 2px rgba(0,0,0,0.2)); } .path-line:hover { opacity: 1; stroke-width: 6; } .node-label { pointer-events: none; user-select: none; font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif; font-weight: 600; text-shadow: 1px 1px 2px rgba(255,255,255,0.8); font-size: 11px; } .link-label { pointer-events: none; user-select: none; font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif; font-weight: bold; text-shadow: 1px 1px 2px rgba(255,255,255,0.9); font-size: 10px; } /* Old path legend CSS removed - now using sidebar legend */ .modal-backdrop { position: fixed; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.5); z-index: 9999; cursor: pointer; } .modal-content { position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%); background: white; border: 1px solid #ccc; border-radius: 12px; padding: 24px; box-shadow: 0 8px 32px rgba(0,0,0,0.3); z-index: 10000; max-width: 600px; width: 90%; max-height: 80vh; overflow-y: auto; cursor: default; }
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:42 bytes
Gateway:!9e77d888
Channel:LongFast
Payload Type:TRACEROUTE_APP
Hop Count:Unknown / 4
Privacy Summary
Exposure Level:
Direct Message
Privacy Features:
βœ“ Direct LoRa transmission (not via MQTT)
βœ“ Acknowledgment requested
+ 3 more...
Exposure Risks:
⚠ Default channel - no encryption
⚠ Packet visible to MQTT subscribers
+ 1 more...
MQTT ServiceEnvelope Fields

MQTT ServiceEnvelope contains the MeshPacket plus routing metadata

FieldValue
gateway_id !9e77d888
Node ID format
channel_id LongFast
Default public channel
packet MeshPacket (42 bytes)
Contains the actual mesh network packet
MeshPacket Fields

Core mesh packet with routing and payload information

FieldValueType
from 2661460028
Source node ID
uint32
to 3148679876
Target node ID
uint32
decoded.portnum 70
TRACEROUTE_APP
enum
decoded.payload_length 42 bytes size
hop_limit 4
Remaining hops allowed
uint32
hop_start 4
Initial hop limit
uint32
hops_taken 0
Calculated: hop_start - hop_limit
derived
rx_rssi -91.0 dBm
Signal strength at gateway
int32
rx_snr 3.75 dB
Signal quality at gateway
float
rx_time 1765732362
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 60
Relay node ID
uint32
tx_after Not set uint32
timestamp 1765732364.0143795
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
  • βœ“ Gateway node ID tracked
  • βœ“ Zero-hop: direct from source to MQTT gateway
Exposure Risks:
  • ⚠ Default channel - no encryption
  • ⚠ Packet visible to MQTT subscribers
  • ⚠ RF signal metrics exposed (location inference possible)
MQTT-Specific Fields
Want ack: True
Gateway ID: !9e77d888
Zero Hop Policy: Enabled
Direct gateway connection
Signal Metrics: RSSI: -91.0 dBm
SNR: 3.75 dB
Complete Payload Analysis

Detailed breakdown of all payload fields and decoded data

Payload Metadata:
Protocol:TRACEROUTE_APP
Size:42 bytes
Decoded: Yes
Complete Payload Data (JSON):
{ "route_nodes": [ 4294967295, 621110652 ], "snr_towards": [ -32.0, -3.5, -17.75 ], "route_back": [], "snr_back": [], "route_node_names": { "3148679876": "R4CDZ/h (EIPh)", "621110652": "VinnyPuh 2 (vp2)", "2661460028": "art28 πŸŒ‹ (art2)", "4294967295": "!ffffffff" }, "traceroute_packet": { "packet_data": { "id": 392777, "timestamp": 1765732364.0143795, "from_node_id": 2661460028, "to_node_id": 3148679876, "portnum": 70, "portnum_name": "TRACEROUTE_APP", "gateway_id": "!9e77d888", "channel_id": "LongFast", "mesh_packet_id": 963851601, "rssi": -91, "snr": 3.75, "hop_limit": 4, "hop_start": 4, "payload_length": 42, "processed_successfully": 1, "raw_payload": "0a08ffffffff7c650525121e80ffffffffffffffff01f2ffffffffffffffff01b9ffffffffffffffff01", "via_mqtt": 0, "want_ack": 1, "priority": 0, "delayed": 0, "channel_index": null, "rx_time": 1765732362, "pki_encrypted": 0, "next_hop": 0, "relay_node": 60, "tx_after": 0, "timestamp_str": "2025-12-14 21:12:44", "hop_count": 0, "has_payload": true, "success": 1, "from_node_name": "art28 πŸŒ‹ (art2)", "to_node_name": "R4CDZ/h (EIPh)", "gateway_name": "Meshtastic d888 (d888)", "gateway_location": { "node_id": 2658654344, "latitude": 51.6161536, "longitude": 46.006272, "altitude": null, "timestamp": 1768637950.4451828, "timestamp_str": "2026-01-17 12:19:10", "display_name": "Meshtastic d888", "long_name": "Meshtastic d888", "short_name": "d888", "hw_model": "HELTEC_V3" } }, "resolve_names": true, "packet_id": 392777, "from_node_id": 2661460028, "to_node_id": 3148679876, "timestamp": 1765732364.0143795, "gateway_id": "!9e77d888", "raw_payload": "0a08ffffffff7c650525121e80ffffffffffffffff01f2ffffffffffffffff01b9ffffffffffffffff01", "hop_limit": 4, "hop_start": 4, "from_node_name": "art28 πŸŒ‹ (art2)", "to_node_name": "R4CDZ/h (EIPh)", "route_data": { "route_nodes": [ 4294967295, 621110652 ], "snr_towards": [ -32.0, -3.5, -17.75 ], "route_back": [], "snr_back": [] }, "forward_path": { "path_type": "forward", "node_ids": [ 2661460028, 4294967295, 621110652 ], "node_names": [ "art28 πŸŒ‹ (art2)", "!ffffffff", "VinnyPuh 2 (vp2)" ], "snr_values": [ -32.0, -3.5, -17.75 ], "hops": [ { "hop_number": 1, "from_node_id": 2661460028, "to_node_id": 4294967295, "from_node_name": "art28 πŸŒ‹ (art2)", "to_node_name": "!ffffffff", "snr": -32.0, "direction": "forward", "is_target_hop": false, "distance_meters": null, "from_location_timestamp": null, "to_location_timestamp": null, "from_location_age_warning": "No location data available", "to_location_age_warning": "No location data available" }, { "hop_number": 2, "from_node_id": 4294967295, "to_node_id": 621110652, "from_node_name": "!ffffffff", "to_node_name": "VinnyPuh 2 (vp2)", "snr": -3.5, "direction": "forward", "is_target_hop": false, "distance_meters": null, "from_location_timestamp": null, "to_location_timestamp": null, "from_location_age_warning": "No location data available", "to_location_age_warning": "No location data available" } ], "is_complete": false, "total_hops": 2 }, "return_path": null, "actual_rf_path": { "path_type": "forward_rf", "node_ids": [ 3148679876, 4294967295, 621110652, 2661460028 ], "node_names": [ "R4CDZ/h (EIPh)", "!ffffffff", "VinnyPuh 2 (vp2)", "art28 πŸŒ‹ (art2)" ], "snr_values": [ -32.0, -3.5, -17.75 ], "hops": [ { "hop_number": 1, "from_node_id": 3148679876, "to_node_id": 4294967295, "from_node_name": "R4CDZ/h (EIPh)", "to_node_name": "!ffffffff", "snr": -32.0, "direction": "forward_rf", "is_target_hop": false, "distance_meters": null, "from_location_timestamp": null, "to_location_timestamp": null, "from_location_age_warning": "No location data available", "to_location_age_warning": "No location data available" }, { "hop_number": 2, "from_node_id": 4294967295, "to_node_id": 621110652, "from_node_name": "!ffffffff", "to_node_name": "VinnyPuh 2 (vp2)", "snr": -3.5, "direction": "forward_rf", "is_target_hop": false, "distance_meters": null, "from_location_timestamp": null, "to_location_timestamp": null, "from_location_age_warning": "No location data available", "to_location_age_warning": "No location data available" }, { "hop_number": 3, "from_node_id": 621110652, "to_node_id": 2661460028, "from_node_name": "VinnyPuh 2 (vp2)", "to_node_name": "art28 πŸŒ‹ (art2)", "snr": -17.75, "direction": "forward_rf", "is_target_hop": false, "distance_meters": 10125.101553495977, "from_location_timestamp": 1765279976.5212924, "to_location_timestamp": 1765728993.3130398, "from_location_age_warning": "from 5.2d ago", "to_location_age_warning": "from 0.9h ago" } ], "is_complete": true, "total_hops": 3 } }, "has_return_path": false, "is_complete": true, "forward_path_display": "art28 πŸŒ‹ (art2) β†’ !ffffffff β†’ VinnyPuh 2 (vp2)", "return_path_display": null, "actual_rf_path_display": "R4CDZ/h (EIPh) β†’ !ffffffff β†’ VinnyPuh 2 (vp2) β†’ art28 πŸŒ‹ (art2)", "forward_hops": [ { "hop_number": 1, "from_node_id": 2661460028, "to_node_id": 4294967295, "from_node_name": "art28 πŸŒ‹ (art2)", "to_node_name": "!ffffffff", "snr": -32.0, "direction": "forward", "is_target_hop": false, "distance_meters": null, "from_location_timestamp": null, "to_location_timestamp": null, "from_location_age_warning": "No location data available", "to_location_age_warning": "No location data available" }, { "hop_number": 2, "from_node_id": 4294967295, "to_node_id": 621110652, "from_node_name": "!ffffffff", "to_node_name": "VinnyPuh 2 (vp2)", "snr": -3.5, "direction": "forward", "is_target_hop": false, "distance_meters": null, "from_location_timestamp": null, "to_location_timestamp": null, "from_location_age_warning": "No location data available", "to_location_age_warning": "No location data available" } ], "return_hops": [], "total_forward_distance": 0, "total_return_distance": null }
Complete Protobuf Decode (JSON)
{ "service_envelope": { "gateway_id": "!9e77d888", "channel_id": "LongFast", "packet": "MeshPacket (see mesh_packet below)" }, "mesh_packet": { "from": 2661460028, "to": 3148679876, "id": 963851601, "rx_time": 1765732362, "rx_snr": 3.75, "rx_rssi": -91, "hop_limit": 4, "hop_start": 4, "via_mqtt": 0, "want_ack": 1, "priority": 0, "delayed": 0, "channel_index": null, "pki_encrypted": 0, "next_hop": 0, "relay_node": 60, "tx_after": 0, "decoded": { "portnum": 70, "payload": "0a08ffffffff7c650525121e80ffffffffffffffff01f2ffffffffffffffff01b9ffffffffffffffff01", "want_response": null, "dest": null, "source": null, "request_id": null, "reply_id": null, "emoji": null, "parsed_payload": { "route": [ 4294967295, 621110652 ], "snr_towards": [ -128, -14, -71 ], "type": "protobuf", "portnum": "TRACEROUTE_APP", "message_class": "RouteDiscovery" } } } }
Raw Packet Data (42 bytes)
0a08ffffffff7c650525121e80ffffffffffffffff01f2ffffffffffffffff01b9ffffffffffffffff01
Hex Analysis:
Size:42 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
Meshtastic d888 (d888) Primary 0.000s
Reference
-91.0 dBm 3.75 dB 0 LongFast 2025-12-14 21:12:44 Current
Ph-5718 (LR-1121) (B-04) -0.325s
Before
-97.0 dBm -13.25 dB 0 LongFast 2025-12-14 21:12:43 View
art18πŸ€–meshmonitor.websdr64.ru (art1) -0.318s
Before
-84.0 dBm 4.75 dB 0 LongFast 2025-12-14 21:12:43 View
Pepel451 (ad76) +0.140s
After
-128.0 dBm -14.75 dB 0 LongFast 2025-12-14 21:12:44 View
Zodiac (Zdc) +0.344s
After
-120.0 dBm -11.00 dB 0 LongFast 2025-12-14 21:12:44 View
Starfer3 (STR3) +2.007s
After
-82.0 dBm 4.75 dB 1 LongFast 2025-12-14 21:12:46 View
6

Total Receptions

6

Unique Gateways