Grafana Do

CI

About

Grafana Do lets you run your own scripts in response to key events within Grafana or its plugins. Scripts have built in access to a rich complement of Grafana APIs.

Team

The team

Technical overview

Technical overview

You can also open assets/grafana-do-overview.excalidraw in Excalidraw and continue working from there.

Development

First, get a copy of the source:

git clone git@github.com:grafana/hackathon-2022-08-grafana-do.git

System Dependencies

  1. First, install rustup and make sure to install rust toolkit 1.63 or later. (latest should work)
  2. Have the WasmEdge library installed installed globally.
  3. Make sure docker is set up and working.

Development

Building docker image

Using Flakes for System Dependencies and building/running

You might want to use nix and nix flakes to manage dependencies. This eliminates differences between our systems and enables useful shared tools.

The first step is to install nix in the recommended way if you don't already have it. This works on macOS or Linux.

Once installed, to use flakes on macOS:

With the above steps complete, you can cd into the project and use nix commands to test it out.

Usage

API

Environment Variables

Currently, there are runtime environment variables:

bash export APP_KEY="YOUR_SHARED_SECRET" export APP_ROOT_PATH="/tmp/wasm-scripts" export APP_USER="your-user@grafana.com" export APP_ROLE="Admin" export APP_API_KEY="zjzTah35Tl6bVJfsmg9LCJuIjosdf5ja0="

It's recommended you use a tool like .env or direnv to manage these variables.

Running scripts

See example/README.md for an example of curl commands that exercise the runner.