AWS CookBook 1.1 : Creating and Assuming an IAM Role for Developer Access
#aws/cookbook/security
- AWS CookBook 1.1 : Creating and Assuming an IAM Role for Developer Access
- Problem
-
- Assume the role using MFA
Problem
As an IAM Engineer, it is always our responsibility to ensure high privileged permissions are not always in use.
- Assume the role using MFA
Solution
-
Create a role using an IAM Policy that will allow the role to be assumed later.
Steps
- Create a file named assume-policy-template.json
"Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Principal": { "AWS": "PRINCIPAL_ARN" }, "Action": "sts:AssumeRole" } ] }
- Retrieve the principal ARN
PRINCIPAL_ARN=$(aws sts get-caller-identity --query Arn --output text)
- Replace the Principal_ARN in the
assume-role-policy-template.json
and generate theassume-role-policy.json
. - Create a role policy and specify the assume role policy.
ROLE_ARN=$(aws iam create-role --role-name AWSCookBookSuryenduRole101 \ --assume-role-policy-document file://assume-role-policy.json \ --output text --query Role.Arn )
- Attach the PowerUserAccess policy to the role.
PowerUserAccess policy is designed to grant full access to AWS services and resources for users without giving them permissions to manage IAM users, groups, and roles.
aws iam attach-role-policy --role-name AWSCookBookSuryenduRole101 \ --policy-arn arn:aws:iam::aws:policy/PowerUserAccess
Power User Access Policy JSON
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "NotAction": [ "iam:*", "organizations:*", "account:*" ], "Resource": "*" }, { "Effect": "Allow", "Action": [ "iam:CreateServiceLinkedRole", "iam:DeleteServiceLinkedRole", "iam:ListRoles", "organizations:DescribeOrganization", "account:ListRegions", "account:GetAccountInformation" ], "Resource": "*" } ] }
- Assume the role created in previous steps.
aws sts assume-role --role-arn $ROLE_ARN \ --role-session-name AWSSuryendu101
- We will get output similar to this.
- If we would like to enforce MFA, at the time of Role assumption, we can adda condition in our assume policy.
{ "Version": "2012-10-17", "Statement": [ { "Effect": "Allow", "Principal": { "AWS": "PRINCIPAL_ARN" }, "Action": "sts:AssumeRole", "Condition": { "Bool": { "aws:MultiFactorAuthPresent": "***" } } } ] }
- Update the assume-role-policy.
aws iam update-assume-role-policy --role-name AWSCookBookSuryenduRole101 --policy-document file://assume-role-policy.json --profile root
- Now first we will try to assume the role without MFA token.
aws sts assume-role --role-arn "arn:aws:iam::471112586770:role/AWSCookBookSuryenduRole101" --role-session-name AWSSuryendu101
This will result in error.
An error occurred (AccessDenied) when calling the AssumeRole operation: User: arn:aws:iam::471112586770:user/admin is not authorized to perform: sts:AssumeRole on resource: arn:aws:iam::471112586770:role/AWSCookBookSuryenduRole101
- Create a file named assume-policy-template.json
Assume the role using MFA
To assume the role with MFA using the AWS CLI, you need the serial number of the MFA device and the current MFA token code.
```aws sts assume-role
–role-arn “arn:aws:iam::471112586770:role/AWSCookBookSuryenduRole101”
–role-session-name “SessionName”
–serial-number “arn:aws:iam::471112586770:mfa/admin”
–token-code “767”
```
We will get similar output as we have seen before.