Access Level
When uploading files to S3 bucket, we have 3 levels of access: public, protected and private:
- Public: Accessible by all users of your app. Files are stored under the public/ path in your S3 bucket.
- Protected: Readable by all users, but writable only by the creating user. Files are stored under protected/{user_identity_id}/ where the user_identity_id corresponds to the unique Amazon Cognito Identity ID for that user.
- Private: Only accessible for the individual user. Files are stored under private/{user_identity_id}/ where the user_identity_id corresponds to the unique Amazon Cognito Identity ID for that user.
In this section we will change the user permission to upload files to S3.
-
Open Cognito console
-
Select Federated Identities on the left menu. Then select fcjdms…identitypool…
data:image/s3,"s3://crabby-images/ce896/ce8961f5eeda4b6a74b637a1404ee3cb1ee39bd5" alt="Cognito"
- Click Edit identity pool
data:image/s3,"s3://crabby-images/8173e/8173ebf228b72375d092209325d619e9014991b7" alt="Cognito"
- Note down the name of the Authenticated role
data:image/s3,"s3://crabby-images/1d684/1d684d556efa2640f657a1395b1a364cd83ba356" alt="Cognito"
- Open IAM console
- Select Roles on the left menu
- Enter name of Authenticated role and click to searched role
data:image/s3,"s3://crabby-images/954d2/954d2786453863fe8d5655e4281b78fc4089ba88" alt="Cognito"
- Expand policies to view user permissions
data:image/s3,"s3://crabby-images/dbe61/dbe61785024cc0b5ee24fc8eaadd212f5f0752af" alt="Cognito"
You can see the permission to add, remove and get objects in the S3 bucket for the identity_id folder in the protected folder
- Select Protected_policy_… policy
data:image/s3,"s3://crabby-images/3874f/3874f092ce4f0ec69fd6e7402636a70760f56198" alt="Cognito"
We will remove the access level permission protected because the application is using that level.
- Enter policy name and click Delete
data:image/s3,"s3://crabby-images/978a5/978a57ef42fe6fbe885ca3d6e7056c5c10b0dcae" alt="Cognito"
- You have successfully removed.
data:image/s3,"s3://crabby-images/2ad3d/2ad3dca390a8f190757ed0ddcb25ad2690ffca63" alt="Cognito"
- Back in the application, click Add files and select the file you want to upload. Then click Upload
data:image/s3,"s3://crabby-images/1e739/1e7396a1bbfcee63165171a7590e2a49812b96c9" alt="Cognito"
- The screen still says success, but you should see the error in Inspect | Console mode. They received an Access Denied error.
data:image/s3,"s3://crabby-images/d4e10/d4e1045da5392ea9f08eebf80e1f07dd832f9bd9" alt="Cognito"
- Re-add permissions for the user.
- Click Add permissions
- Select Create inline policy
data:image/s3,"s3://crabby-images/4811b/4811b277a21650aea2ef75ad780cf7929d312986" alt="Cognito"
- Select S3 for service
data:image/s3,"s3://crabby-images/d9886/d9886ca05d989ec75a8bf2db6e6b734725034a30" alt="Cognito"
- In Actions | Read section, select GetObject
data:image/s3,"s3://crabby-images/fc556/fc5562adefb792d4438338d6b723bb0fb8bf45b2" alt="Cognito"
- In Actions | Write section, select PutObject and DeleteObject
data:image/s3,"s3://crabby-images/ba656/ba65622ab44a690febe903f9f5be2a72fb112a07" alt="Cognito"
- In Resources secttion, click Add ARN
data:image/s3,"s3://crabby-images/98da5/98da5f0f9247396056a553c4d4779ed261ac4763" alt="Cognito"
- Click List ARNs manually
data:image/s3,"s3://crabby-images/cb30a/cb30ab5cb6dcbf7a86b50d4e99ac30dfb4f57349" alt="Cognito"
- Enter ARN:
arn:aws:s3:::fcjdmsstore101547-dev/protected/${cognito-identity.amazonaws.com:sub}/*
data:image/s3,"s3://crabby-images/eb37f/eb37f344eeea7a4818096c92b26088dfaa9e468a" alt="Cognito"
- Click Review policy
data:image/s3,"s3://crabby-images/619e8/619e837c0235e95143b994e2dd5e61a3ef26e5aa" alt="Cognito"
- Enter policy name:
Protected_policy
. Then click Create policy
data:image/s3,"s3://crabby-images/06736/06736610d96d6e81f759412a3f3f97d75862f57b" alt="Cognito"
- Go back to the web app, reload the file you just failed
- Click Add files, select the file you want to download
- Click Upload
data:image/s3,"s3://crabby-images/3b476/3b4769a620cef5fb05fcc22f85cff321bc1cf72c" alt="Cognito"
- Open the console of the S3 bucket to see if the file has loaded successfully.
data:image/s3,"s3://crabby-images/d7621/d76210cb388780bf947b23a2dc4a4d80f897e379" alt="Cognito"
We’ve learned about protected access levels. If you want to add permissions for other level or edit any permissions, you can do the same.