S3 / Client / get_object_tagging

get_object_tagging#

S3.Client.get_object_tagging(**kwargs)#

Note

This operation is not supported by directory buckets.

Returns the tag-set of an object. You send the GET request against the tagging subresource associated with the object.

To use this operation, you must have permission to perform the s3:GetObjectTagging action. By default, the GET action returns information about current version of an object. For a versioned bucket, you can have multiple versions of an object in your bucket. To retrieve tags of any other version, use the versionId query parameter. You also need permission for the s3:GetObjectVersionTagging action.

By default, the bucket owner has this permission and can grant this permission to others.

For information about the Amazon S3 object tagging feature, see Object Tagging.

The following actions are related to GetObjectTagging:

See also: AWS API Documentation

Request Syntax

response = client.get_object_tagging(
    Bucket='string',
    Key='string',
    VersionId='string',
    ExpectedBucketOwner='string',
    RequestPayer='requester'
)
Parameters:
  • Bucket (string) –

    [REQUIRED]

    The bucket name containing the object for which to get the tagging information.

    Access points - When you use this action with an access point, you must provide the alias of the access point in place of the bucket name or specify the access point ARN. When using the access point ARN, you must direct requests to the access point hostname. The access point hostname takes the form AccessPointName-AccountId.s3-accesspoint.*Region*.amazonaws.com. When using this action with an access point through the Amazon Web Services SDKs, you provide the access point ARN in place of the bucket name. For more information about access point ARNs, see Using access points in the Amazon S3 User Guide.

    S3 on Outposts - When you use this action with Amazon S3 on Outposts, you must direct requests to the S3 on Outposts hostname. The S3 on Outposts hostname takes the form AccessPointName-AccountId.outpostID.s3-outposts.Region.amazonaws.com. When you use this action with S3 on Outposts through the Amazon Web Services SDKs, you provide the Outposts access point ARN in place of the bucket name. For more information about S3 on Outposts ARNs, see What is S3 on Outposts? in the Amazon S3 User Guide.

  • Key (string) –

    [REQUIRED]

    Object key for which to get the tagging information.

  • VersionId (string) – The versionId of the object for which to get the tagging information.

  • ExpectedBucketOwner (string) – The account ID of the expected bucket owner. If the account ID that you provide does not match the actual owner of the bucket, the request fails with the HTTP status code 403 Forbidden (access denied).

  • RequestPayer (string) –

    Confirms that the requester knows that they will be charged for the request. Bucket owners need not specify this parameter in their requests. If either the source or destination S3 bucket has Requester Pays enabled, the requester will pay for corresponding charges to copy the object. For information about downloading objects from Requester Pays buckets, see Downloading Objects in Requester Pays Buckets in the Amazon S3 User Guide.

    Note

    This functionality is not supported for directory buckets.

Return type:

dict

Returns:

Response Syntax

{
    'VersionId': 'string',
    'TagSet': [
        {
            'Key': 'string',
            'Value': 'string'
        },
    ]
}

Response Structure

  • (dict) –

    • VersionId (string) –

      The versionId of the object for which you got the tagging information.

    • TagSet (list) –

      Contains the tag set.

      • (dict) –

        A container of a key value name pair.

        • Key (string) –

          Name of the object key.

        • Value (string) –

          Value of the tag.

Examples

The following example retrieves tag set of an object.

response = client.get_object_tagging(
    Bucket='examplebucket',
    Key='HappyFace.jpg',
)

print(response)

Expected Output:

{
    'TagSet': [
        {
            'Key': 'Key4',
            'Value': 'Value4',
        },
        {
            'Key': 'Key3',
            'Value': 'Value3',
        },
    ],
    'VersionId': 'null',
    'ResponseMetadata': {
        '...': '...',
    },
}

The following example retrieves tag set of an object. The request specifies object version.

response = client.get_object_tagging(
    Bucket='examplebucket',
    Key='exampleobject',
    VersionId='ydlaNkwWm0SfKJR.T1b1fIdPRbldTYRI',
)

print(response)

Expected Output:

{
    'TagSet': [
        {
            'Key': 'Key1',
            'Value': 'Value1',
        },
    ],
    'VersionId': 'ydlaNkwWm0SfKJR.T1b1fIdPRbldTYRI',
    'ResponseMetadata': {
        '...': '...',
    },
}