Austin Schuh | e84c3ed | 2019-12-14 15:29:48 -0800 | [diff] [blame] | 1 | include "aos/configuration.fbs"; |
| 2 | |
| 3 | namespace aos.message_bridge; |
| 4 | |
James Kuszmaul | a6681e2 | 2023-05-26 11:20:40 -0700 | [diff] [blame^] | 5 | // Per-channel statistics for any channels being forwarded to other nodes by the |
| 6 | // message bridge server. |
| 7 | table ServerChannelStatistics { |
| 8 | // Index into the configuration channels list for this channel. |
| 9 | channel_index:uint64 (id: 0); |
| 10 | // Total number of messages that were sent (this does not necessarily |
| 11 | // mean that the message made it to the client). |
| 12 | sent_packets:uint (id: 1); |
| 13 | // Total number of messages that were dropped while sending (e.g., |
| 14 | // those dropped by the kernel). |
| 15 | dropped_packets:uint (id: 2); |
| 16 | } |
| 17 | |
Austin Schuh | e84c3ed | 2019-12-14 15:29:48 -0800 | [diff] [blame] | 18 | // State of the connection. |
| 19 | enum State: ubyte { |
| 20 | CONNECTED, |
| 21 | DISCONNECTED, |
| 22 | } |
| 23 | |
| 24 | // Statistics from a single connection to a client from this server. |
| 25 | table ServerConnection { |
| 26 | // The node that we are connected to. |
Ravago Jones | fb6a7a5 | 2020-11-14 13:47:46 -0800 | [diff] [blame] | 27 | node:Node (id: 0); |
Austin Schuh | e84c3ed | 2019-12-14 15:29:48 -0800 | [diff] [blame] | 28 | |
| 29 | // Health of this connection. Connected or not? |
Ravago Jones | fb6a7a5 | 2020-11-14 13:47:46 -0800 | [diff] [blame] | 30 | state:State (id: 1); |
Austin Schuh | e84c3ed | 2019-12-14 15:29:48 -0800 | [diff] [blame] | 31 | |
| 32 | // Number of packets that have been dropped (if known). |
Ravago Jones | fb6a7a5 | 2020-11-14 13:47:46 -0800 | [diff] [blame] | 33 | dropped_packets:uint (id: 2); |
Austin Schuh | e84c3ed | 2019-12-14 15:29:48 -0800 | [diff] [blame] | 34 | |
Austin Schuh | 40f4c47 | 2021-03-31 21:28:44 -0700 | [diff] [blame] | 35 | // Number of packets sent on all channels. |
Ravago Jones | fb6a7a5 | 2020-11-14 13:47:46 -0800 | [diff] [blame] | 36 | sent_packets:uint (id: 3); |
Austin Schuh | e84c3ed | 2019-12-14 15:29:48 -0800 | [diff] [blame] | 37 | |
Austin Schuh | 7bc5905 | 2020-02-16 23:48:33 -0800 | [diff] [blame] | 38 | // This is the measured monotonic offset for the connected node in |
| 39 | // nanoseconds. Add this to our monotonic time to get their |
| 40 | // monotonic time. |
Ravago Jones | fb6a7a5 | 2020-11-14 13:47:46 -0800 | [diff] [blame] | 41 | monotonic_offset:int64 (id: 4); |
Austin Schuh | 7bc5905 | 2020-02-16 23:48:33 -0800 | [diff] [blame] | 42 | |
Austin Schuh | 20ac95d | 2020-12-05 17:24:19 -0800 | [diff] [blame] | 43 | // Boot UUID of the client. |
| 44 | boot_uuid:string (id: 5); |
| 45 | |
Austin Schuh | 40f4c47 | 2021-03-31 21:28:44 -0700 | [diff] [blame] | 46 | // Number of extra calls needed to receive a single message |
| 47 | // (indicates congestion) |
| 48 | partial_deliveries:uint (id: 6); |
| 49 | |
Austin Schuh | 367a7f4 | 2021-11-23 23:04:36 -0800 | [diff] [blame] | 50 | // Time at which we connected to the client as nanoseconds on the local |
| 51 | // monotonic clock. This is not populated when not connected, and defaults |
| 52 | // to monotonic_clock::min_time. |
| 53 | connected_since_time:int64 = -9223372036854775808 (id: 7); |
| 54 | |
| 55 | // Number of times we've established a connection to the server. |
| 56 | connection_count:uint (id: 8); |
Austin Schuh | b0e439d | 2023-05-15 10:55:40 -0700 | [diff] [blame] | 57 | |
| 58 | // Number of times we've had an invalid connection with something wrong in |
| 59 | // the connection message, but we were able to match which node it was. |
| 60 | invalid_connection_count:uint (id: 9); |
James Kuszmaul | a6681e2 | 2023-05-26 11:20:40 -0700 | [diff] [blame^] | 61 | |
| 62 | // Statistics for every channel being forwarded to this node. Ordering is arbitrary; |
| 63 | // the channels are identified by an index in the ServerChannelStatistics. |
| 64 | channels:[ServerChannelStatistics] (id: 10); |
Austin Schuh | e84c3ed | 2019-12-14 15:29:48 -0800 | [diff] [blame] | 65 | } |
| 66 | |
| 67 | // Statistics for all connections to all the clients. |
| 68 | table ServerStatistics { |
Ravago Jones | fb6a7a5 | 2020-11-14 13:47:46 -0800 | [diff] [blame] | 69 | connections:[ServerConnection] (id: 0); |
milind | 1f1dca3 | 2021-07-03 13:50:07 -0700 | [diff] [blame] | 70 | |
| 71 | // Count of timestamp send failures |
| 72 | timestamp_send_failures:uint64 (id: 1); |
Austin Schuh | b0e439d | 2023-05-15 10:55:40 -0700 | [diff] [blame] | 73 | |
| 74 | // Number of times we've had an invalid connection with something wrong in |
| 75 | // the connection message. The most likely cause is that the config sha256 |
| 76 | // doesn't match between nodes. |
| 77 | invalid_connection_count:uint (id: 2); |
Austin Schuh | e84c3ed | 2019-12-14 15:29:48 -0800 | [diff] [blame] | 78 | } |
| 79 | |
| 80 | root_type ServerStatistics; |