grafana/dashboard-schemas
Chris Trott a6eebc22e8
Dashboard Schemas (#28793)
* cue mod init github.com/grafana/grafana/dashboard-schemas

* dashboard-schemas: Document exporting to OpenAPI

Signed-off-by: Arve Knudsen <arve.knudsen@gmail.com>

Co-authored-by: Arve Knudsen <arve.knudsen@gmail.com>
2020-11-24 08:54:34 +01:00
..
cue.mod Dashboard Schemas (#28793) 2020-11-24 08:54:34 +01:00
panels Dashboard Schemas (#28793) 2020-11-24 08:54:34 +01:00
targets Dashboard Schemas (#28793) 2020-11-24 08:54:34 +01:00
transformations Dashboard Schemas (#28793) 2020-11-24 08:54:34 +01:00
variables Dashboard Schemas (#28793) 2020-11-24 08:54:34 +01:00
Dashboard.cue Dashboard Schemas (#28793) 2020-11-24 08:54:34 +01:00
README.md Dashboard Schemas (#28793) 2020-11-24 08:54:34 +01:00

Dashboard Schemas

Schema description documents for Grafana Dashboard JSON and core panels.

Note: This directory is experimental. The schemas are not currently implemented or enforced in Grafana.

Schemas are defined in Cue. Cue was chosen because it strongly facilitates our primary use cases - schema definition, data validation, and code generation/extraction.

Schema Organization

Each schema describes part of a dashboard. Dashboard.cue is the main dashboard schema object. All other schemas describe nested objects within a dashboard. They are grouped in the following directories:

The following somewhat conveys how they fit together when constructing a dashboard:

+-----------+      +-----------+
| Dashboard +------> Variables |
+---------+-+      +-----------+
          |    +--------+    +---------+
          +----> Panels +----> Targets |
               +------+-+    +---------+
                      |      +-----------------+
                      +------> Transformations |
                             +-----------------+

Definitions

All schemas are Cue definitions. Schemas intended to be exported must begin with a capital letter. For example, Gauge. Definitions beginning with a lowercase letter will not be exported. These are reusable components for constructing the exported definitions. For example, #panel is intended to be a base schema for panels. #Gauge extends #panel with the following:

#Gauge: panel & {
	...
}

Exporting OpenAPI

OpenAPI schemas can be exported from these CUE sources. Use the cue command as follows, to generate OpenAPI JSON to stdout:

cue export --out openapi -o - ./dashboard-schemas/...