Important: This documentation is about an older version. It's relevant only to the release noted, many of the features and functions have been updated or replaced. Please view the current version.
Developer Guide
From grafana 3.0 it’s very easy to develop your own plugins and share them with other grafana users.
Short version
- Setup grafana
- Clone an example plugin into
/var/lib/grafana/plugins
ordata/plugins
(relative to grafana git repo if your running development version from source dir) - Code away!
What languages?
Since everything turns into javascript it’s up to you to choose which language you want. That said it’s probably a good idea to choose es6 or typescript since we use es6 classes in Grafana. So it’s easier to get inspiration from the Grafana repo is you choose one of those languages.
Buildscript
You can use any build system you like that support systemjs. All the built content should end up in a folder named dist
and committed to the repository.By committing the dist folder the person who installs your plugin does not have to run any buildscript.
All our example plugins have build scripted configured.
module.(js|ts)
This is the entry point for every plugin. This is the place where you should export your plugin implementation. Depending on what kind of plugin you are developing you will be expected to export different things. You can find what’s expected for datasource, panels and apps plugins in the documentation.
Start developing your plugin
There are three ways that you can start developing a Grafana plugin.
- Setup a Grafana development environment. (described here) and place your plugin in the
data/plugins
folder. - Install Grafana and place your plugin in the plugins directory which is set in your config file. By default this is
/var/lib/grafana/plugins
on Linux systems. - Place your plugin directory anywhere you like and specify it grafana.ini.
We encourage people to setup the full Grafana environment so that you can get inspiration from the rest of grafana code base.
When Grafana starts it will scan the plugin folders and mount every folder that contains a plugin.json file unless the folder contains a subfolder named dist. In that case grafana will mount the dist folder instead. This makes it possible to have both built and src content in the same plugin git repo.
Examples
We currently have three different examples that you can fork/download to get started developing your grafana plugin.
- simple-json-datasource (small datasource plugin for querying json data from backends)
- example-app
- clock-panel
- singlestat-panel
- piechart-panel