An experimental CLI that generates TF files to manage existing Fastly services with Terraform
https://user-images.githubusercontent.com/30490956/169726673-33ecccf7-ae40-4ebd-acf7-e4d457d4f510.mp4
Installation / Upgrade
go install github.com/hrmsk66/terraformify@latest
Or download the prebuild binary from the latest release.
Configuration
The tool requires read permissions to the target Fastly resource.
Choose one of the following options to give terraformify access to your API token:
- Include the token explicitly on each command you run using the
--api-key
or -k
flags.
- Set a
FASTLY_API_KEY
environment variable.
Usage
Run the command in an empty directory
Importing VCL Service
mkdir test && cd test
terraformify service vcl <service-id>
Importing Compute@Edge Service
To import compute@Edge services, the path to the WASM package is used as an argument in addition to the service ID.
mkdir test && cd test
terraformify service compute <service-id> <path-to-package>
Customizing the Resource Name
The tool uses service
as the default target resource name. To specify a custom name, use the --resource-name
or -n
flag.
terraformify service (vcl|compute) <service-id> [<path-to-package>] -n <resource-name>
Interactive Mode
By default, the tool imports all resources associated with the service, such as ACL entries, dictionary items, WAF..etc. To interactively select which resources to import, use the --interactive
or -i
flag.
terraformify service (vcl|compute) <service-id> [<path-to-package>] -i
Importing Specific Version
By default, either the active version will be imported, or the latest version if no version is active. Alternatively, a specific version of the service can be selected by passing version number to the --version
or -v
flag.
terraformify service (vcl|compute) <service-id> [<path-to-package>] -v <version-number>
force_destroy
By default, force_destroy
is set to false
. To set them to true
and allow Terraform to destroy resources, use the --force-destroy
or -f
flag.
terraformify service (vcl|compute) <service-id> [<path-to-package>] -f
Manage Associated Resources
By default, the manage_*
attribute is not set so that these resources can be managed externally.
To set the attributes to true and manage the resource with Terraform, use the --manage-all
or -m
flag.
terraformify service (vcl|compute) <service-id> [<path-to-package>] -m
Skip Editing the State File
By default, the tool updates terraform.tfstate
directly. To disable this behavior and leave the state file untouched, use the --skip-edit-state
or -s
flag.
Note: Terraform detects diffs without this behavior and terraform apply
may result in the destruction and re-creation of associated resources, such as ACL entries and Dictionary items.
terraformify service (vcl|compute) <service-id> [<path-to-package>] -s
License
MIT License