Using tags with S3 Access Points for general purpose buckets
An AWS tag is a key-value pair that holds metadata about resources, in this case Amazon S3 Access Points. You can tag access points when you create them or manage tags on existing access points. For general information about tags, see Tagging for cost allocation or attribute-based access control (ABAC).
Note
There is no additional charge for using tags on access points beyond the standard S3 API request rates. For more information, see Amazon S3 pricing
Common ways to use tags with access points
Attribute-based access control (ABAC) allows you to scale access permissions and grant access to access points based on their tags. For more information about ABAC in Amazon S3, see Using tags for ABAC.
ABAC for S3 Access Points
Amazon S3 Access Points support attribute-based access control (ABAC) using tags. Use tag-based condition keys in your AWS organizations, IAM, and Access Points policies. For enterprises, ABAC in Amazon S3 supports authorization across multiple AWS accounts.
In your IAM policies, you can control access to access points based on the access points's tags by using the following global condition keys:
- 
            aws:ResourceTag/key-nameImportantThe aws:ResourceTagcondition key can only be used for S3 actions performed via an access point ARN for general purpose buckets and covers the underlying access point tags only.- 
                  Use this key to compare the tag key-value pair that you specify in the policy with the key-value pair attached to the resource. For example, you could require that access to a resource is allowed only if the resource has the attached tag key Deptwith the valueMarketing. For more information, see Controlling access to AWS resources.
 
- 
                  
- 
            aws:RequestTag/key-name- 
                  Use this key to compare the tag key-value pair that was passed in the request with the tag pair that you specify in the policy. For example, you could check whether the request includes the tag key Deptand that it has the valueAccounting. For more information, see Controlling access during AWS requests. You can use this condition key to restrict which tag key-value pairs can be passed during theTagResourceandCreateAccessPointAPI operations.
 
- 
                  
- 
            aws:TagKeys- 
                  Use this key to compare the tag keys in a request with the keys that you specify in the policy. We recommend that when you use policies to control access using tags, use the aws:TagKeyscondition key to define what tag keys are allowed. For example policies and more information, see Controlling access based on tag keys. You can create an access point with tags. To allow tagging during theCreateAccessPointAPI operation, you must create a policy that includes both thes3:TagResourceands3:CreateAccessPointactions. You can then use theaws:TagKeyscondition key to enforce using specific tags in theCreateAccessPointrequest.
 
- 
                  
- 
            s3:AccessPointTag/tag-key- 
                  Use this condition key to grant permissions to specific data via access points using tags. When using aws:ResourceTag/tag-keyin an IAM policy, both the access point as well as the bucket to which the access point points to are required to have the same tag as they are both considered during authorization. If you want to control access to your data specifically via the access-point tag only, you can uses3:AccessPointTag/tag-keycondition key.
 
- 
                  
Example ABAC policies for access points
See the following example ABAC policies for Amazon S3 Access Points.
1.1 - IAM policy to create or modify buckets with specific tags
In this IAM policy, users or roles with this policy can only create access points if they tag the access points with the tag key project and tag value Trinity in the access points creation request. They can also add or modify tags on existing access points as long as the TagResource request includes the tag key-value pair project:Trinity. 
{ "Version": "2012-10-17", "Statement": [ { "Sid": "CreateAccessPointWithTags", "Effect": "Allow", "Action": [ "s3:CreateAccessPoint", "s3:TagResource" ], "Resource": "*", "Condition": { "StringEquals": { "aws:RequestTag/project": [ "Trinity" ] } } } ] }
1.2 - Access Point policy to restrict operations on the access point using tags
In this Access Point policy, IAM principals (users and roles) can perform operations using the GetObject action on the access point only if the value of the access point's project tag matches the value of the principal's project tag.
{ "Version": "2012-10-17", "Statement": [ { "Sid": "AllowObjectOperations", "Effect": "Allow", "Principal": { "AWS": "111122223333" }, "Action": "s3:GetObject", "Resource": "arn:aws::s3:region:111122223333:accesspoint/", "Condition": { "StringEquals": { "aws:ResourceTag/project": "${aws:PrincipalTag/project}" } } } ] }my-access-point
1.3 - IAM policy to modify tags on existing resources maintaining tagging governence
In this IAM policy, IAM principals (users or roles) can modify tags on an access point only if the value of the access point's project tag matches the value of the principal's project tag. Only the four tags project, environment, owner, and cost-center specified in the aws:TagKeys condition keys are permitted for these access points. This helps enforce tag governance, prevents unauthorized tag modifications, and keeps the tagging schema consistent across your access points.
{ "Version": "2012-10-17", "Statement": [ { "Sid": "EnforceTaggingRulesOnModification", "Effect": "Allow", "Action": [ "s3:TagResource" ], "Resource": "arn:aws::s3:region:111122223333:accesspoint/", "Condition": { "StringEquals": { "aws:ResourceTag/project": "${aws:PrincipalTag/project}" }, "ForAllValues:StringEquals": { "aws:TagKeys": [ "my-access-pointproject", "environment", "owner", "cost-center" ] } } } ] }
1.4 - Using the s3:AccessPointTag condition key
In this IAM policy, the condition statement allows access to the bucket's data if the access point has the tag key Environment and tag value Production. 
{ "Version": "2012-10-17", "Statement": [ { "Sid": "AllowAccessToSpecificAccessPoint", "Effect": "Allow", "Action": "*", "Resource": "arn:aws::s3:region:111122223333:accesspoint/", "Condition": { "StringEquals": { "s3:AccessPointTag/Environment": "Production" } } } ] }my-access-point
1.5 - Using a bucket delegate policy
In Amazon S3, you can delegate access to or control of your S3 bucket policy to another AWS account or to a specific AWS Identity and Access Management (IAM) user or role in the other account. The delegate bucket policy grants this other account, user, or role permission to your bucket and its objects. For more information, see Permission delegation.
If using a delegate bucket policy, such as the following:
{ "Version": "2012-10-17", "Statement": { "Principal": {"AWS": "*"}, "Effect": "Allow", "Action": ["s3:*"], "Resource":["arn:aws::s3:::/*", "arn:aws::s3:::amzn-s3-demo-bucketamzn-s3-demo-bucket"], "Condition": { "StringEquals" : { "s3:DataAccessPointAccount" : "111122223333" } } } }
In the following IAM policy, the condition statement allows access to the bucket's data if the access point has the tag key Environment and tag value Production. 
{ "Version": "2012-10-17", "Statement": [ { "Sid": "AllowAccessToSpecificAccessPoint", "Effect": "Allow", "Action": "*", "Resource": "arn:aws::s3:region:111122223333:accesspoint/", "Condition": { "StringEquals": { "s3:AccessPointTag/Environment": "Production" } } } ] }my-access-point
Working with tags for access points for general purpose buckets
You can add or manage tags for access points using the Amazon S3 Console, the AWS Command Line Interface (CLI), the AWS SDKs, or using the S3 APIs: TagResource, UntagResource, and ListTagsForResource. For more information, see: