Adding an IAM role
Add your AWS IAM roles to Opal to allow your developers to request temporary access.
Adding a role
Trust policy
You must use the following trust policy for your role, substituting as follows:
${ACCOUNT_ID}
: The account ID of the account being configured.${IDP_ISSUER_URL}
: The Identity Provider's issuer URL${OPAL_CLIENT_ID}
: The Client ID assigned to Opal via your IdP.
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Principal": {
"Federated": "arn:aws:iam::${ACCOUNT_ID}:oidc-provider/${IDP_ISSUER_URL}"
},
"Action": "sts:AssumeRoleWithWebIdentity",
"Condition": {
"StringEquals": {
"${IDP_ISSUER_URL}:aud": "${OPAL_CLIENT_ID}"
}
}
}
]
}
Creating a role
Here is an example invocation for creating a role with the above trust policy file:
aws iam create-role \
--role-name MyRoleWithPoliciesToBeManagedByOpal \
--assume-role-policy-document file://trust_policy.json \
--tags Key=opal,Value="" \
--description "My role containing policies to be managed by Opal"
Attaching policies to a role
Now attach all the policies you want to show up in Opal under this role. You can do this in the AWS Console below:
data:image/s3,"s3://crabby-images/e5c45/e5c45fd8076e46ab3598e95b2a2f7767ecd8891a" alt="Screen Shot 2020-12-03 at 3.19.33 PM.png 1768"
Attaching policies to an Opal role.
Terraform
If you use Terraform, for an existing aws_iam_role
, you can use the following arguments for the role you want to manage with Opal:
assume_role_policy = <<POLICY
{
"Version": "2012-10-17",
"Statement": [
{
"Effect": "Allow",
"Principal": {
"Federated": "arn:aws:iam::${ACCOUNT_ID}:oidc-provider/${IDP_ISSUER_URL}"
},
"Action": "sts:AssumeRoleWithWebIdentity",
"Condition": {
"StringEquals": {
"${IDP_ISSUER_URL}:aud": "${OPAL_CLIENT_ID}"
}
}
}
]
}
POLICY
tags = {
opal = ""
}
You can add policies to the aws_iam_role
via the aws_iam_role_policy_attachment
resource.
Getting access to roles in Opal
Once you've added roles to Opal, you can find and request them easily in the "Resources" tab.
data:image/s3,"s3://crabby-images/52fe3/52fe3f99dadfd31f1f9692ea4b562d229e24e6aa" alt="SCR-20230313-mke.png 2312"
AWS IAM roles are session based, meaning your developers need to initiate their role-based session by clicking on the Connect button on the resource.
data:image/s3,"s3://crabby-images/7212d/7212ddabab16f82a510ba09624a8afa86eb053c8" alt="SCR-20230313-ml0.png 2312"
Starting an IAM role session.
Once a session is started, you'll be able to access the AWS Console (the Amazon GUI) directly or update your CLI with this role's permissions.
data:image/s3,"s3://crabby-images/d8a83/d8a83a4b592facd18a9a057b21c36efa70969c89" alt="Screenshot 2021-02-15 at 9.14.20 PM.png 584"
Using an AWS IAM role session in Opal.
Updated 6 months ago