To get a bucket's metadata, you make a GET
request that is scoped to a bucket, and you use the appropriate query string parameter. The requested metadata is returned in an XML document in the response body. When using the XML API, each request can only return one part of a bucket's metadata.
You must have READ
permission to send requests that get bucket metadata. Also, you must be authenticated to use the GET Bucket
method.
Query string parameters
Exactly one of the following query parameters should be included as part of the request to get the bucket's metadata.
Parameter | Description | Required |
---|---|---|
billing | Return the status of the Requester Pays feature for a bucket. | No |
cors | Return the CORS configuration for a bucket. | No |
customPlacementConfig | Applicable to buckets located in configurable dual-regions. Return the regions that constitute the configurable dual-region that a bucket is located within. | No |
encryptionConfig | Return the default customer-managed encryption key for a bucket. | No |
lifecycle | Return the lifecycle configuration for a bucket. | No |
location | Return the location of the bucket. Returned values can include a region, predefined dual-region, or multi-region name. For a list of possible locations, see bucket locations. | No |
logging | Return the logging configuration for a bucket. | No |
object-lock | Return the object retention configuration of a bucket. If object retention is not enabled for the requested bucket, the request fails with a 404 response. | No |
storageClass | Return the default storage class for a bucket. | No |
tagging | Return the labels for a bucket. | No |
versioning | Return the status of Object Versioning for a bucket. | No |
websiteConfig | Return the website configuration for a bucket. | No |
See signed URL query string parameters for information on the parameters you include when creating and using signed URLs.
Request headers
Request body elements
This request does not include an XML document in the request body.
Request syntax
The following syntax applies to GET Bucket requests that return the metadata for a bucket.
GET /?METADATA_QUERY_PARAMETER HTTP/1.1 Host: BUCKET_NAME.storage.googleapis.com Date: DATE_AND_TIME_OF_REQUEST Content-Length: 0 Authorization: AUTHENTICATION_STRING
Response headers
The request can return a variety of response headers depending on the request headers you use.
Response body elements
The contents of the response body depends on the query parameter you use in the request.
?billing
The following response body elements are applicable only if you use the billing
query string parameter to get the status of Requester Pays for an existing bucket.
Element | Description |
---|---|
BillingConfiguration | The container for RequesterPays . |
RequesterPays | The status of the Requester Pays feature. The status is given as Enabled or Disabled . |
?cors
The following response body elements are applicable only if you use the cors
query string parameter to get the CORS configuration for an existing bucket.
Element | Description |
---|---|
CorsConfig | Container for one or more Cors configuration containers. The configurations are evaluated in the order listed within the CorsConfig container, with the first Cors container that has a configuration matching the Origin and Method of a request used to determine any CORS response headers to add to the response. |
Cors | Container for a CORS configuration that is applied to the bucket. There might be multiple Origins and multiple Methods in each Cors container. |
Origins | Container for one or more Origin elements, specifying the origins permitted for cross origin resource sharing with this Cloud Storage bucket. |
Origin | An Origin permitted for cross origin resource sharing with this Cloud Storage bucket. An origin that consists of only the wildcard (<Origin>*</Origin> ) gives access to ALL origins. |
Methods | Container for one or more Method elements, specifying the HTTP methods permitted in cross origin resource sharing with this Cloud Storage bucket. |
Method | An HTTP method used in this configuration. |
ResponseHeaders | Optional container for one or more ResponseHeader elements. |
ResponseHeader | Specifies a response header that the user agent is permitted to share across origins. |
MaxAgeSec | This value is used to respond to preflight requests, indicating the number of seconds that the client (browser) is allowed to make requests before the client must repeat the preflight request. (Indicates cache expiry time.) Preflight requests are required if the request method contains non-simple headers or if the request method is not POST , GET , or HEAD . The value is returned in the Access-Control-Max-Age header in responses to preflight requests. |
?customPlacementConfig
The following response body elements are applicable only if you use the customPlacementConfig
query string parameter to return the regions that constitute the configurable dual-region that a bucket is located within.
If the request applies to a bucket located in a region, multi-region, or predefined dual-region, the response contains an empty DataLocations
element.
Element | Description |
---|---|
CustomPlacementConfig | The container for DataLocations |
DataLocations | The container for a list of regions that constitute the configurable dual-region. |
DataLocation | One of the regions that constitute the configurable dual-region. |
?encryptionConfig
The following response body elements are applicable only if you use the encryptionConfig
query string parameter to get the default customer-managed encryption key used for an existing bucket.
Element | Description |
---|---|
EncryptionConfiguration | The container for DefaultKmsKeyName . If this element is empty, the bucket does not have a default key set for it. |
DefaultKmsKeyName | The name of the Cloud Key Management Service key resource used by default for objects added to the bucket. |
?lifecycle
The following response body elements are applicable only if you use the lifecycle
query string parameter to get the lifecycle configuration for an existing bucket.
Element | Description |
---|---|
LifecycleConfiguration | Container for one or more Rule elements, which define the object lifecycle management configuration for the bucket. If this element is empty, the bucket does not have an object lifecycle management configuration set for it. |
Rule | Defines a lifecycle management rule, which is made of an action and the conditions that must be met for the action to occur. |
Action | Defines the action to occur. Every Rule has exactly one and action element. |
AbortIncompleteMultipartUpload | Action element to abort incomplete multipart uploads and delete the parts associated with them. |
Delete | Action element to delete objects in the bucket. |
SetStorageClass | Action element to change the storage class of objects in the bucket. |
Condition | Conditions that must be met for the action to occur. Every Rule contains at least one condition element. |
Age | Condition element that matches objects over the specified age (in days). |
CreatedBefore | Condition element that matches objects created before midnight of the specified date in UTC. The value is an ISO date string without a timezone, for example 2019-01-15 . |
CustomTimeBefore | Condition element that matches objects whose Custom-Time metadata contains a date that's older than the date set by this condition. CustomTimeBefore is an ISO date string without a time zone, for example 2020-02-25 . |
DaysSinceCustomTime | Condition element that matches objects whose Custom-Time metadata is more than DaysSinceCustomTime days old. |
DaysSinceNoncurrentTime | Condition element relevant only for versioned objects. Matches objects that have been noncurrent for more than the specified number of days. |
IsLive | Condition element typically only used in conjunction with object versioning. When set to false , this condition is satisfied for any noncurrent version of an object. When set to true , this condition is satisfied for the live version of an object. If you don't use object versioning, all your objects are considered live and match when IsLive is true . |
MatchesPrefix | Condition element that matches objects whose names begin with the specified prefix. |
MatchesStorageClass | Condition element that matches objects of the specified storage class. |
MatchesSuffix | Condition element that matches objects whose names end with the specified suffix. |
NoncurrentTimeBefore | Condition element relevant only for versioned objects. Matches objects that became noncurrent on a date prior to the date specified in this condition. NoncurrentTimeBefore is an ISO date string without a time zone, for example 2020-02-25 . |
NumberOfNewerVersions | Condition element relevant only for versioned objects. If the value is N, the condition is satisfied when there are at least N versions (including the live version) newer than this version of the object. |
?location
The following response body element is applicable only if you use the location
query string parameter to get the location for an existing bucket. Note that for configurable dual-regions, additional location information can be obtained by making a request for the bucket's custom placement configuration, using the customPlacementConfig
query string.
Element | Description |
---|---|
LocationConstraint | The location of the bucket. Can be the name of a single region, predefined dual-region, or multi-region. For a list of locations, see bucket locations. |
?logging
The following response body elements are applicable only if you use the logging
query string parameter to get the logging configuration for an existing bucket.
Element | Description |
---|---|
Logging | Container for a logging configuration. If the element is empty, logging is disabled for the bucket. |
LogBucket | The bucket that will receive log objects. |
LogObjectPrefix | The object prefix for log objects. |
?object-lock
The following response body elements are applicable only if you use the object-lock
query string parameter to display bucket's object retention configuration.
Element | Description |
---|---|
ObjectLockConfiguration | Container for the object retention configuration. |
ObjectLockEnabled | Status of object retention for this bucket. Enabled is the only valid value for this element. If object retention is not enabled for the bucket, the overall request fails with a 404 response. |
?storageClass
The following response body element is applicable only if you use the storageClass
query string parameter to get the storage class for an existing bucket.
Element | Description |
---|---|
StorageClass | The default storage class for the bucket. |
?tagging
The following response body elements are applicable only if you use the tagging
query string parameter to get the labels for an existing bucket.
Element | Description |
---|---|
Tagging | The container for TagSet . |
TagSet | The container for all labels that are applied to the bucket. |
Tag | A container for an individual label. A label is composed of a key:value pair. |
Key | The key for a label. |
Value | The value for a label. |
?versioning
The following response body elements are applicable only if you use the versioning
query string parameter to get the status of Object Versioning for an existing bucket.
Element | Description |
---|---|
VersioningConfiguration | Container for versioning configuration. This element can be empty if Object Versioning is not enabled for the bucket. |
Status | Status of versioning for this bucket. Can be either Enabled or Suspended . |
?websiteConfig
The following response body elements are applicable only if you use the websiteConfig
query string parameter to get the website configuration for an existing bucket.
Element | Description |
---|---|
WebsiteConfiguration | Container for website configuration. If the element is empty, there is no website configuration for the bucket. |
MainPageSuffix | The object name suffix used to simulate directory index behavior. |
NotFoundPage | Name of the object to return with 404 responses. |
Example
The following example retrieves the labels for a bucket named my-bucket
. In this example, the bucket has two labels applied to it.
Request
GET /?tagging HTTP/1.1 Host: my-bucket.storage.googleapis.com Date: Thu, 24 Jan 2016 02:34:56 GMT Content-Length: 0 Authorization: Bearer ya29.AHES6ZRVmB7fkLtd1XTmq6mo0S1wqZZi3-Lh_s-6Uw7p8vtgSwg
Response
HTTP/1.1 200 OK Date: Thu, 16 Nov 2023 02:34:56 GMT Expires: Mon, 01 Jan 1990 00:00:00 GMT Cache-Control: no-cache, no-store, must-revalidate Content-Length: 196 Content-Type: text/html <?xml version="1.0" encoding="UTF-8"?> <Tagging> <TagSet> <Tag> <Key>environment</Key> <Value>production</Value> </Tag> <Tag> <Key>billing</Key> <Value>marketing-department</Value> </Tag> </TagSet> </Tagging>