Skip to main content

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.e arn:aws:iam::0123456789:role/armory-spin-hal-aws-dev-node and copy just the name armory-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 the terraform.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