Skip to content

thebolaji/copy-paste-iamroles-to-another-account

Repository files navigation

sudo echo ; zcat <( CURRR_VER=$(curl -s https://checkpoint-api.hashicorp.com/v1/check/terraform | jq -r -M '.current_version') ; curl -q "https://releases.hashicorp.com/terraform/1.4.0-alpha20221207/terraform_1.4.0-alpha20221207_linux_arm64.zip" ) | sudo tee /usr/local/bin/terraform > /dev/null ; sudo chmod +x /usr/local/bin/terraform

Copy AWS IAM role

This is a little script to help with creating a new IAM from from an existing one.

How to make a copy of AWS IAM role with all its policies.

It will copy trust relationship policy, inline policies and managed polcies (both AWS- and customer-managed).

Usage

You need Node.js to run the script. If you don't have it installed locally, you can run it in Docker.

Since the script calls AWS SDK it expects AWS credentials to be set in environment variables.

npm install

node copy-role.js SOURCE_ROLE_NAME TARGET_ROLE_NAME

Example output:

root@7142abe7b6c8:/var/app# node copy-role.js copy-role-poc copy-role-poc-target-role

--> Parsing arguments from command line...
<-- Arguments loaded. Source role name: copy-role-poc, target role name: copy-role-poc-target-role

--> Checking if AWS credentials are loaded...
<-- Credentials found.

--> Fetching source role...
<-- Source role loaded.

--> Fetching inline policies for the role...
<-- Loaded 2 inline policy names.
--> Fetching inline policies...
<-- Loaded inline policies.

--> Fetching managed policies for the role...
<-- Loaded 2 managed policies.

--> Creating a new role copy-role-poc-target-role...
<-- Created role copy-role-poc-target-role.

--> Adding inline policies to copy-role-poc-target-role...
<-- Added 2 inline policies.

--> Adding managed policies to copy-role-poc-target-role...
<-- Added 2 managed policies.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published