A Python script for generating Terraform configuration from SignalFx dashboard group and dashboard JSON exports.
- Export a SignalFx dashboard group as JSON
-
Move JSON file to project directory
-
Set the following constants to their appropriate values
DASHBOARD_GROUP_PATH
- points to the JSON file
DASHBOARD_GROUP_NAME
- the terraform name of the dashboard group. Only alphanumerics, dash, and underscore are allowed.
DB_GROUP_ID
- The ID of the dashboard group. Can be found under the dashboard group's Info popup.
- Start the generation with
python3 generate_dashboard_group.py
The newly generated terraform files are found in {DASHBOARD_GROUP_NAME}/
.
Move the files to your Terraform project.
- Export a SignalFx dashboard as JSON
-
Move JSON file to project directory
-
Set the following constants to their appropriate values
DASHBOARD_PATH
- points to the JSON file
DASHBOARD_GROUP_NAME
- the terraform name of the dashboard group (purely for folder/file name generation). Only alphanumerics, dash, and underscore are allowed.
- Start the generation with
python3 generate_dashboard.py
The newly generated terraform files are found in {DASHBOARD_GROUP_NAME}/
.
Move the files to your Terraform project.
The terraform import
command allows one to import existing infra to a state file. For each resource to be imported, a resource block must be written first.
The tool takes in a JSON that SignalFx exports and generates a resource block for each dashboard group/dashboard/chart.
The terraform import
command is run for each dashboard group/dashboard/chart resource and imported to a state file (which will be deleted).
The terraform state show
command is run for each resource that was imported. The output, which is the resource block with attributes filled out, is written to output/*.tf
.
There are four transformations that happen to the resource block outputted by terraform state show
before they are written to a file:
- Removing of
id
andurl
attributes - Changing of dashboard's
chart_id
anddashboard_group
from actual ids on SignalFx to a resource reference (e.g.signalfx_single_value_chart.failed_jobs.id
) - Changing of
<<~EOT EOT
to<<-EOF EOF