A module to help with creating terraform commands.
apply
fmt
get
graph
import
init
output
plan
providers
refresh
show
taint
untaint
validate
version
workspace
delete
list
new
select
show
Terrajs will run terraform commands from the directory pass in with terraformDir
.
const tf = new Terrajs( { terraformDir: 'path/to/files.tf' } );
const cmdString = tf.init({ backendConfig: { key: 'MY_KEY' } });
To view the generated terraform command without running:
const tf = new Terrajs({ execute: false, terraformDir: 'path/to/files.tf' });
tf.init({ backendConfig: { key: 'MY_KEY' } });
Variables are mapped from JS camelCase convention to Terraform CLI snake_case convention. For example:
tf.plan({
var: {
subscriptionId: '123',
tenantId: 'abc'
}
});
...will be mapped to the following terraform shell command:
terraform plan -var subscription_id=123 -var tenant_id=abc
Passing a list variable requires some additional preparation. For example:
const subnetArray = [ 'subnetA', 'subnetB' ]
const subnetString = subnetArray.length
? `[\\"${subnetArray.join('\\", \\"')}\\"]`
: '';
tf.plan({
var: {
subnets: subnetString
}
});
...will be mapped to the following terraform shell command:
terraform plan -var "subnets=[\"subnetA\", \"subnetB\"]"
npm run test
npm run coverage
Commands live in the templates
dir.
Each command has a line for each partial.
A partial contains the logic for a command line argument.