Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

provider/aws: Add support for AssumeRole prior to operations #8638

Merged
merged 3 commits into from
Sep 3, 2016

Conversation

jen20
Copy link
Contributor

@jen20 jen20 commented Sep 2, 2016

This PR builds on the work of @imduffy15 in #8506, adding in support for Session Name and External ID, and changing around the configuration block a bit.

There is still a case which needs fixing regarding the error message when no valid source credentials are passed in, and also if the source credentials are valid but the role cannot be assumed.

Automated testing is left as a follow-up to this - we have a strategy in place but it requires some (more broadly useful) changes to the acceptance testing harness to be feasible.

Fixes #1275.

imduffy15 and others added 2 commits September 2, 2016 10:22
This commit enables terraform to utilise the assume role functionality
of sts to execute commands with different privileges than the API
keys specified.

Signed-off-by: Ian Duffy <[email protected]>
Remove unnecessary &schema.Schema from the AWS provider schema
definition.
@@ -75,7 +78,7 @@ func GetAccountId(iamconn *iam.IAM, stsconn *sts.STS, authProviderName string) (
}

if len(outRoles.Roles) < 1 {
return "", fmt.Errorf("Failed getting account ID via 'iam:ListRoles': No roles available")
return "", errors.New("Failed getting account ID via 'iam:ListRoles': No roles available")
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

why errors.New and not errWrap?

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

We are generating a new error rather than wrapping one produced by an upstream API?

@stack72
Copy link
Contributor

stack72 commented Sep 3, 2016

@jen20 so pleased to see this included. I left a few nit picks about the ordering of error checking and about what way we throw errors. These are not show stoppers at all :) More nit picks

@jen20 jen20 force-pushed the f-aws-assume-role branch 4 times, most recently from d0418cc to 305f114 Compare September 3, 2016 19:54
This replaces the previous `role_arn` with a block which looks like
this:

```
provider "aws" {
        // secret key, access key etc

	assume_role {
	        role_arn = "<Role ARN>"
		session_name = "<Session Name>"
		external_id = "<External ID>"
	}
}
```

We also modify the configuration structure and read the values from the
block if present into those values and adjust the call to AssumeRole to
include the SessionName and ExternalID based on the values set in the
configuration block.

Finally we clean up the tests and add in missing error checks, and clean
up the error handling logic in the Auth helper functions.
@jen20 jen20 force-pushed the f-aws-assume-role branch from 305f114 to e3ccb51 Compare September 3, 2016 19:54
@stack72
Copy link
Contributor

stack72 commented Sep 3, 2016

LGTM! Nice work :)

@jen20 jen20 merged commit 94ca84e into master Sep 3, 2016
@jen20 jen20 deleted the f-aws-assume-role branch September 3, 2016 20:04
@imduffy15
Copy link
Contributor

Thanks for making this happen @stack72 and @jen20

@bentterp
Copy link

I totally don't understand how to use this, could somebody please explain? I've read through #1275 as well, without any light bulbs going off.

Until now, we've been using a script that does STS::AssumeRole with MFA, obtains the temporary credentials, exports them as environment variables. After that, we happily continue with terraform plan and apply.

Is there now a smarter way of doing this?

@imduffy15
Copy link
Contributor

Hi @benttrep,
There is indeed, there's no more need for assume role scripts.

Authenticate to your account that has the assume role privilege using any of the standard authentication methods(env vars, profile, ec2 IAM role etc).

Then just follow the docs at https://www.terraform.io/docs/providers/aws/

@bentterp
Copy link

bentterp commented Sep 14, 2016

Aaah 😲 This is awesome ❗

And the docs were updated as part of the release 👍

A suggestion: could we have a link to the updated docs included in the changelog? As the documentation grows, it becomes harder and harder to spot the changes in the docs.

E.g. https://www.terraform.io/docs/providers/aws/index.html#Assume_role - and yes, anchors in the docs would be great.

@drdamour
Copy link

i'm probably missing something but the docs aren't really followable...i have the arn_role block in my assume role...but it's not working. always get

Error refreshing state: 1 error(s) occurred:

* The role "arn:aws:iam:::role/devops" cannot be assumed.

  There are a number of possible causes of this - the most common are:
    * The credentials used in order to assume the role are invalid
    * The credentials do not have appropriate permission to assume the role
    * The role ARN is not valid

how would i know what value to put in session_id and external_id? i expected terraform to prompt me for my MFA value.

@jen20
Copy link
Contributor Author

jen20 commented Dec 28, 2016

Hi @drdamour! There are a few different issues in your example:

Firstly the role ARN is indeed not valid - they have an account ID in them. The IAM console will show you the correct ARN for a given role. This covers the third error.

Secondly, Assuming a role has two aspects:

  • the first is acquiring a session token - the sts:GetSessionToken API operation. This is where an MFA code is typically specified. Terraform does not do this for you (though if running as part of Terraform Enterprise it can be configured).
  • the second is assuming a role - the sts:AssumeRole operation. Roles may specify as part of the specification that in order to be assumed, the session token provided must have an MFA token attached. This is the part that Terraform does for you if the role_arn option is specified.

In order to fix your example you'll need to do the following:

  1. Fix the role ARN so it is valid
  2. Make a call to sts:GetSessionToken via whatever mechanism you would use for the CLI (likely aws sts get-session-token) and use the credentials returned as the values to AWS_ACCESS_KEY_ID, AWS_SECRET_ACCESS_KEY and AWS_SESSION_TOKEN.

@drdamour
Copy link

thanks, i was obfuscating my role id...i'm using a valid one. the whole reason we had the script was to get the session token. i suspect that's what @bentterp 's script was doing as well...so alas you still need a wrapper script to do stuff with MFA..that sucks.

thanks for confirming.

@ghost
Copy link

ghost commented Apr 18, 2020

I'm going to lock this issue because it has been closed for 30 days ⏳. This helps our maintainers find and focus on the active issues.

If you have found a problem that seems similar to this, please open a new issue and complete the issue template so we can capture all the details necessary to investigate further.

@ghost ghost locked and limited conversation to collaborators Apr 18, 2020
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Support for AWS access via IAM - AssumeRole
5 participants