Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/k-phoen/grabana
User-friendly Go library for building Grafana dashboards
https://github.com/k-phoen/grabana
builder dashboard-configuration dashboards golang grafana grafana-dashboard grafana-dashboards hacktoberfest library yaml
Last synced: 5 days ago
JSON representation
User-friendly Go library for building Grafana dashboards
- Host: GitHub
- URL: https://github.com/k-phoen/grabana
- Owner: K-Phoen
- License: mit
- Created: 2020-01-30T18:43:13.000Z (almost 5 years ago)
- Default Branch: master
- Last Pushed: 2024-08-02T13:33:58.000Z (6 months ago)
- Last Synced: 2025-01-02T16:05:46.990Z (19 days ago)
- Topics: builder, dashboard-configuration, dashboards, golang, grafana, grafana-dashboard, grafana-dashboards, hacktoberfest, library, yaml
- Language: Go
- Homepage:
- Size: 2.92 MB
- Stars: 699
- Watchers: 8
- Forks: 70
- Open Issues: 31
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
# Grabana
[![Go Report Card](https://goreportcard.com/badge/github.com/K-Phoen/grabana)](https://goreportcard.com/report/github.com/K-Phoen/grabana) ![CI](https://github.com/K-Phoen/grabana/workflows/CI/badge.svg) [![codecov](https://codecov.io/gh/K-Phoen/grabana/branch/master/graph/badge.svg)](https://codecov.io/gh/K-Phoen/grabana) [![GoDoc](https://godoc.org/github.com/K-Phoen/grabana?status.svg)](https://godoc.org/github.com/K-Phoen/grabana)
Grabana provides a developer-friendly way of creating Grafana dashboards.
Whether you prefer writing **code or YAML**, if you are looking for a way to
version your dashboards configuration or automate tedious and error-prone
creation of dashboards, this library is meant for you.## Design goals
* provide an understandable abstraction over dashboards configuration
* expose a **developer-friendly API**
* allow IDE assistance and **auto-completion**
* **generate Go code** from existing dashboards**Note**: Grafana 8+ is required, with [unified alerting](https://grafana.com/blog/2021/06/14/the-new-unified-alerting-system-for-grafana-everything-you-need-to-know/) enabled.
## See also
* [`grafana-foundation-sdk`](https://github.com/grafana/grafana-foundation-sdk): A set of tools, types and libraries for building and manipulating Grafana objects – built by Grafana Labs
* [`dark`](https://github.com/K-Phoen/dark): (grafana) Dashboards As Resources in Kubernetes## Dashboard as code
Dashboard configuration:
```go
builder := dashboard.New(
"Awesome dashboard",
dashboard.AutoRefresh("5s"),
dashboard.Tags([]string{"generated"}),
dashboard.VariableAsInterval(
"interval",
interval.Values([]string{"30s", "1m", "5m", "10m", "30m", "1h", "6h", "12h"}),
),
dashboard.Row(
"Prometheus",
row.WithGraph(
"HTTP Rate",
graph.DataSource("prometheus-default"),
graph.WithPrometheusTarget(
"rate(prometheus_http_requests_total[30s])",
prometheus.Legend("{{handler}} - {{ code }}"),
),
),
),
)
```> **Note**
> Existing dashboards can be converted to Go code using the `grabana convert-go` CLI command.Dashboard creation:
```go
ctx := context.Background()
client := grabana.NewClient(&http.Client{}, grafanaHost, grabana.WithAPIToken("such secret, much wow"))// create the folder holding the dashboard for the service
folder, err := client.FindOrCreateFolder(ctx, "Test Folder")
if err != nil {
fmt.Printf("Could not find or create folder: %s\n", err)
os.Exit(1)
}if _, err := client.UpsertDashboard(ctx, folder, builder); err != nil {
fmt.Printf("Could not create dashboard: %s\n", err)
os.Exit(1)
}
```For a more complete example, see the [`example`](cmd/builder-example/) directory.
## Dashboard as YAML
Dashboard configuration:
```yaml
# dashboard.yaml
title: Awesome dashboardeditable: true
tags: [generated]
auto_refresh: 5svariables:
- interval:
name: interval
label: Interval
values: ["30s", "1m", "5m", "10m", "30m", "1h", "6h", "12h"]rows:
- name: Prometheus
panels:
- graph:
title: HTTP Rate
height: 400px
datasource: prometheus-default
targets:
- prometheus:
query: "rate(promhttp_metric_handler_requests_total[$interval])"
legend: "{{handler}} - {{ code }}"
```Dashboard creation (or [automatically as a Kubernetes Resource, using DARK](https://github.com/K-Phoen/dark)):
```go
content, err := os.ReadFile("dashboard.yaml")
if err != nil {
fmt.Fprintf(os.Stderr, "Could not read file: %s\n", err)
os.Exit(1)
}dashboard, err := decoder.UnmarshalYAML(bytes.NewBuffer(content))
if err != nil {
fmt.Fprintf(os.Stderr, "Could not parse file: %s\n", err)
os.Exit(1)
}ctx := context.Background()
client := grabana.NewClient(&http.Client{}, grafanaHost, grabana.WithAPIToken("such secret, much wow"))// create the folder holding the dashboard for the service
folder, err := client.FindOrCreateFolder(ctx, "Test Folder")
if err != nil {
fmt.Printf("Could not find or create folder: %s\n", err)
os.Exit(1)
}if _, err := client.UpsertDashboard(ctx, folder, dashboard); err != nil {
fmt.Printf("Could not create dashboard: %s\n", err)
os.Exit(1)
}
```## Going further
Check out [the documentation](doc/index.md) to discover what Grabana can do for
you.## License
This library is under the [MIT](LICENSE) license.