terraformify

command module
v0.5.7 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Apr 7, 2023 License: MIT Imports: 1 Imported by: 0

README

terraformify

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 terraformify command in an empty directory or in an existing TF directory.

Note that running the command in an existing TF directory will modify the existing state file and may change the contents of other files(specifically, variables.tf and terraform.tfvars if present). Therefore, it is recommended to make a backup of your TF files before importing a new service.

Importing VCL Service
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.

terraformify service compute <service-id> <path-to-package>
Customizing the Resource Name

By default, service is used as the TF resource name. To customize it, use the --resource-name or -n flag.

terraformify service (vcl|compute) <service-id> [<path-to-package>] -n <resource-name>

The generated files and directories will be named after the TF resource being imported. If multiple services are to be managed, resource names should be specified to distinguish them.

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.

Resource Name Attribute Name
fastly_service_acl_entries manage_entries
fastly_service_dictionary_items manage_items
fastly_service_dynamic_snippet_content manage_snippets

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

Documentation

The Go Gopher

There is no documentation for this package.

Directories

Path Synopsis
pkg
cli

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL