Use Terraformer with Datadog
This provider uses the terraform-provider-datadog.
First you will need to install Terraformer with the Datadog provider. See the README.
Before you can use Terraformer, you need to create a template workspace so that Terraformer can access the DataDog/datadog provider.
To do this, create a new directory with a basic provider.tf
file:
terraform {
required_providers {
datadog = {
source = "DataDog/datadog"
version = "3.20.0"
}
}
}
provider "datadog" {
# Configuration options
}
then run:
$ terraform init
You should see the output: Terraform has been successfully initialized!
export DATADOG_API_KEY=Datadog API key. More information on this at https://docs.datadoghq.com/account_management/api-app-keys/
export DATADOG_HOST=Datadog API host i.e. https://api.datadoghq.eu which can be found at https://docs.datadoghq.com/getting_started/site/#access-the-datadog-site
export DATADOG_APP_KEY=Datadog APP key. More information on this at https://docs.datadoghq.com/account_management/api-app-keys/
./terraformer import datadog --resources=*
You can also specify only certain kinds of resources to import as well, i.e. --resources=dashboard
.
You should now see a generated/
subdirectory with generated files.
You can now initialize and use your new generated resources:
$ terraform init
$ terraform plan # No changes. Your infrastructure matches the configuration.
You can use the filter
argument to restrict the import of Terraform resources.
Filtering based on Tags follows the convention --filter="Name=tags;Value='your tag'"
.
# Import monitors based on multiple tags
./terraformer import datadog --resources=monitor --filter="Name=tags;Value='foo:bar'" --filter="Name=tags;Value='env:production'"
# Import monitor where tag doesn't include colon
./terraformer import datadog --resources=monitor --filter="Name=tags;Value=anExampleTag"
Filtering based on resource ID:
# Import dashboard based on the dashboard ID
./terraformer import datadog --resource=dashboard --filter=dashboard=some-id
# Import based on multiple resource IDs
./terraformer import datadog --resource=monitor --filter=monitor=id1:id2:id4
Tag filters are order specific. For example, if your monitor has tags (in the order) atag: atagvalue
, foo:bar
but you filter for --filter="Name=tags;Value='foo:bar'" --filter="Name=tags;Value='atag: atagvalue'"
, the monitor would not be imported.
dashboard
datadog_dashboard
dashboard_json
datadog_dashboard_json
dashboard_list
datadog_dashboard_list
downtime
datadog_downtime
logs_archive
datadog_logs_archive
logs_archive_order
datadog_logs_archive_order
logs_custom_pipeline
datadog_logs_custom_pipeline
logs_integration_pipeline
datadog_logs_integration_pipeline
logs_pipeline_order
datadog_logs_pipeline_order
logs_index
datadog_logs_index
logs_index_order
datadog_logs_index_order
integration_aws
datadog_integration_aws
integration_aws_lambda_arn
datadog_integration_aws_lambda_arn
integration_aws_log_collection
datadog_integration_aws_log_collection
integration_azure
datadog_integration_azure
- NOTE: Sensitive field
client_secret
is not generated and needs to be manually set
- NOTE: Sensitive field
integration_gcp
datadog_integration_gcp
- NOTE: Sensitive fields
private_key, private_key_id, client_id
is not generated and needs to be manually set
- NOTE: Sensitive fields
integration_pagerduty
datadog_integration_pagerduty
integration_pagerduty_service_object
datadog_integration_pagerduty_service_object
integration_slack_channel
datadog_integration_slack_channel
- NOTE: Importing resource requires resource ID or
account_name
to be passed via Filter option
- NOTE: Importing resource requires resource ID or
metric_metadata
datadog_metric_metadata
- NOTE: Importing resource requires resource ID's to be passed via Filter option
monitor
datadog_monitor
role
datadog_role
security_monitoring_default_rule
datadog_security_monitoring_default_rule
security_monitoring_rule
datadog_security_monitoring_rule
service_level_objective
datadog_service_level_objective
synthetics_test
datadog_synthetics_test
synthetics_global_variable
datadog_synthetics_global_variable
- NOTE: Importing resource requires resource ID's to be passed via Filter option
synthetics_private_location
datadog_synthetics_private_location
user
datadog_user