Create AWS IAM Roles from a Terraform Script
Introduction
This document will show you how to create the AWS IAM roles from a Terraform Script. This document is based on the idea to automatize this manual process Deploying to AWS from Spinnaker (using IAM instance roles) using a terraform script. That means you have two options to create the AWS IAM roles.
Prerequisites
Terraform should be installed:
https://learn.hashicorp.com/tutorials/terraform/install-cli
You should have a profile configured in your ~/.aws/credentials
file.
Instructions
Variables
In the file terraform.tfvars
you need to set some variables in order to execute properly.
- provider-region = The region* provider-profile = the name of the profile in
~/.aws/credentials
* node-name = Find one of the nodes which is part of your EKS or other Kubernetes cluster and get the name Role i.earn:aws:iam::0123456789:role/armory-spin-hal-aws-dev-node
and copy just the namearmory-spin-hal-aws-dev-node
* managed-role-name = The name of the managed role, whatever you want e.g.TestSpinnakerManagedRole
* managing-policy = The name of the managed policy, whatever you want e.g.TestDevSpinnakerManagingPolicy
* pass-role-name = The name of the pass-role, whatever you want e.g.TestPassRole
* base-role-name = The name of the base-role, whatever you want e.g.TestBaseIAMRole
* role-policy = The name of the role-policy, whatever you want e.g.TestEc2CloudForm
* managing-role-instance-profile = the name of the Managing Role Instance Profile, whatever you want e.g.TestInstanceProfile
How to Use - Download the terraform script from: https://github.com/armory/terraform.git and open the
aws-roles
folder* Edit theterraform.tfvars
and fill with the corresponding values as explained above. Run the follow commands:
terraform init
terraform plan -var-file=terraform.tfvars
terraform apply -var-file=terraform.tfvars
Result After running the script the roles and policies should be created and the output of the script is the instructions that you will need to execute in order to enable the aws account in halyard. Outputs:
commands = Run this commands in order:
export AWS_ACCOUNT_NAME=aws-dev-1
export ACCOUNT_ID=569630529054
export ROLE_NAME=role/SpinnakerManagedRoleTerraform
hal config provider aws account add $AWS_ACCOUNT_NAME --account-id $ACCOUNT_ID --assume-role $ROLE_NAME
hal config provider aws enable
hal config provider aws account edit $AWS_ACCOUNT_NAME --regions us-east-1,us-west-2
hal deploy apply