This document describes the schema of the responses returned by the Archivist's [fuchsia.diagnostics/ArchiveAccessor#StreamDiagnostics][stream-diagnostics].
The Canonical Diagnostics Data schema describes the structure that is shared across all diagnostics data sources, whether they are accessed by streaming or by snapshot. This canonical schema provides some requirements for what we can now call diagnostics data; diagnostics data must:
Diagnostics schemas can be thought of as containing three distinct sections: a namespacing section, a metadata section, and a payload section.
The top-level schema contains the following fields:
1.This would look as follows in JSON:
{ "data_source": "INSPECT", "moniker": "core/foo", "metadata": { ... }, "payload": { ... }, "version": 1, }
The namespacing section consists of the information that can be applied to the entire schema, across all data types; this information serves to describe the namespace of the source that generated this diagnostics data. The namespacing section is made up of two fields:
moniker describing the component that the the diagnostics data contained in the schema applies to.data source describing which diagnostics service generated the data.The metadata section consists of properties with statically known and documented schemas for which a single value cannot be shared across all nested schemas. Each of the data sources adds its own metadata attributes. The metadata section is the location where unique and un-unifiable variations in diagnostics are expressed in the unified schema.
Metadata for Inspect responses contains the following fields:
Errors: Errors that happened while fetching the components Inspect data (optional). The error is an object with a single message string field.
Component URL: The URL with which the component was launched.
Timestamp: The monotonic time when the Inspect data was snapshotted.
Filename: The name of the file where the Inspect data was located inside the component's out/diagnostics directory, if present.
This would look as follows in JSON:
{ ..., "metadata": { "errors": [ { "message": "...", } ], "component_url": "fuchsia-pkg://...", "timestamp": 12345, "filename": "fuchsia.inpsect.Tree" }, }
Metadata for lifecycle responses contains the following fields:
Errors: Errors that happened while fetching the components Inspect data (optional). The error is an object with a single message string field.
Component URL: The URL with which the component was launched.
Timestamp: The monotonic time when the event happened in the framework.
Lifecycle event type: The name of the lifecycle event being encoded in the payload. This can be one of: Started, Stopped, DiagnosticsReady, LogSinkConnected.
This would look as follows in JSON:
{ ..., "metadata": { "errors": [ { "message": "...", } ], "component_url": "fuchsia-pkg://...", "timestamp": 12345, "lifecycle_event_type": "Started" }, }
Metadata for logs responses contains the following fields:
Errors: errors that happened while fetching the components Inspect data (optional). Each error can be one of the following:
Component URL: The URL with which the component was launched.
Timestamp: The monotonic time when the event happened in the framework.
Severity: The severity of the log. One of: Trace, Debug, Info, Warn, Error, Fatal.
Tags: List of string tags associated with the log (optional).
Pid: The process koid that emitted the log (optional).
Tid: The thread koid that emitted the log (optional).
File: The name of the file that emitted the log (optional).
Line: The line number in the file that emitted the log (optional).
This would look as follows in JSON:
{ ..., "metadata": { "errors": [ { "dropped_logs": { "count": 3 }, } ], "component_url": "fuchsia-pkg://...", "timestamp": 12345, "severity": "Info", "tags": ["foo"], "pid": 123, "tid": 456, "file": "lib.rs", "line": 5, }, }
The payload section contains the actual diagnostics data being reported. The payload is structured hierarchically, and the context or ttopic of the data is encoded by its location within the hierarchy (eg, the name of the node it sits on).
The payload of the Inspect response is an object representing the Inspect tree that the component was exposing at the time of snapshotting.
This would look as follows in JSON:
{ ..., "payload": { "root": { "foo": { ... }, "bar": 3, ... } }, }
The payload is empty for lifecycle events.
This would look as follows in JSON:
{ ..., "payload": null, }
The logs payload is an object with the following fields:
For a regular text log (or a structured log without keys), this would look as follows in JSON:
{ ... "payload": { "message": { "value": "my log", } } }
For a structured log with keys, this would look as follows in JSON:
{ ... "payload": { "message": { "value": "my log", }, "keys": { "foo": 3, "bar": "baz", ... } } }
For a printf log, this would look as follows in JSON:
{ ... "payload": { "printf": { "format": "my log %s", "args": ["foo"] } } }
[stream-diagnostics]: https://fuchsia.dev/reference/fidl/fuchsia.diagnostics#ArchiveAccessor.StreamDiagnostics)