Create IAM Role
- In the Identity Providers choose the Provider we just created
data:image/s3,"s3://crabby-images/5b4d3/5b4d30a089ed703f51bfa009bce3acd93dd59e57" alt="4-iam"
- Choose “Assign role”
data:image/s3,"s3://crabby-images/b536d/b536db3d29b6758ee6695b578ddf4d39279b8f02" alt="5-iam"
- Choose “Create a new role” -> “Next”
data:image/s3,"s3://crabby-images/234db/234db311103ab64c61ed2011546fd7240dc5ec8f" alt="6-iam"
- At the Step 1
- At Trusted Entity type we choose “Web identity”
- At Web Identity:
- Choose Identity Provider
https://token.actions.githubusercontent.com
- Choose Audience
sts.amazonaws.com
- Github Organization: Fill your github username (This name is case sensitive)
- Click Next
data:image/s3,"s3://crabby-images/106ea/106eaab325a0a4791a071b920e92bc8821215341" alt="7-iam"
- At the Step 2 is AWS Managed Policy but we will create inline policy so we choose “Next”
data:image/s3,"s3://crabby-images/e7c74/e7c74f9a85e1056f446bc123a7e308042efc4c0f" alt="8-iam"
- At the Step 3 you will fill your role name like images and remember that role for later
data:image/s3,"s3://crabby-images/84768/847685c5a83d72855dcd6f53b04f122224585222" alt="8.1-iam"
- Click “Create role”
data:image/s3,"s3://crabby-images/9c1d7/9c1d7d88356aa496949d0b3c311f82d5f8743c8c" alt="9-iam"
- At the left menu choose “Roles” -> Search your created role -> Choose that role
data:image/s3,"s3://crabby-images/b8277/b82772f7ab46129ab0daafd65dcdda92f830215d" alt="10-iam"
- At the Permission Policies -> Choose “Add permissions” -> Create inline policy
data:image/s3,"s3://crabby-images/c9f02/c9f0225cb2a35121469357308d05b3e98b9ecb88" alt="11-iam"
- At Step 1 choose JSON and copy paste the following policy (Remember change these ID for your case):
{
"Version": "2012-10-17",
"Statement": [
{
"Sid": "SyncToBucket",
"Effect": "Allow",
"Action": [
"s3:PutObject",
"s3:GetObject",
"s3:ListBucket",
"s3:DeleteObject"
],
"Resource": [
"arn:aws:s3:::YOUR_BUCKET_NAME/*",
"arn:aws:s3:::YOUR_BUCKET_NAME"
]
},
{
"Sid": "FlushCache",
"Effect": "Allow",
"Action": "cloudfront:CreateInvalidation",
"Resource": "arn:aws:cloudfront::YOUR_ACCOUNT_ID:distribution/YOUR_CLOUDFRONT_ID"
}
]
}
data:image/s3,"s3://crabby-images/94bf0/94bf090af4deeb360102d61992bb74004c9d06e5" alt="12-iam"
Then click “Next” -> “Save Changes”