This page describes how to attach and manage contexts on Cloud Storage objects in the form of key-value pairs.
Get the required roles
To get the permissions that you need to create and manage object contexts, ask your administrator to grant you the following IAM roles on object:
- 
              Create objects with contexts:
              
  
  
    
      Storage Object Creator     (roles/storage.objectCreator)
- 
              Attach, update, view, and delete contexts from objects:
              
  
  
    
      Storage Object User     (roles/storage.objectUser)
- 
              View context keys and values attached to objects:
              
  
  
    
      Storage Object    Viewer  (roles/storage.objectViewer)
For more information about granting roles, see Manage access to projects, folders, and organizations.
These predefined roles contain the permissions required to create and manage object contexts. To see the exact permissions that are required, expand the Required permissions section:
Required permissions
The following permissions are required to create and manage object contexts:
- 
                  Create an object with object contexts:
                - 
                      storage.objects.create
- 
                      storage.objects.createContext
 
- 
                      
- 
                  Attach, update, and delete object contexts:
                - 
                      storage.objects.update
- 
                      storage.objects.createContext
- 
                      storage.objects.updateContext
- 
                      storage.objects.deleteContext
 
- 
                      
- 
                  View object contexts:
                - 
                      storage.objects.get
- 
                      storage.objects.list
 
- 
                      
You might also be able to get these permissions with custom roles or other predefined roles.
Attach contexts to new objects
Attach contexts to objects when you upload new objects to Cloud Storage buckets. Each context consists of a key and a value.
Command line
To attach contexts when you upload objects with the
gcloud alpha storage cp command, use the --custom-contexts
flag:
gcloud alpha storage cp OBJECT_LOCATION gs://DESTINATION_BUCKET_NAME --custom-contexts=KEY=VALUE,...
Where:
- OBJECT_LOCATIONis the local path to your object. For example,- Desktop/dog.png.
- DESTINATION_BUCKET_NAMEis the name of the bucket to which you are uploading your object. For example,- my-bucket.
- KEYis the context key to attach to an object. For example,- Department. You can specify multiple key-value pairs separated by commas.
- VALUEis the value to associate with the context key. For example,- Human resources.
Alternatively, create a JSON file that contains the contexts you want to
attach to the objects, and use the --custom-contexts-file flag:
{ "KEY": { "value": "VALUE" }, ... }
Where:
- KEYis the context key to attach to an object. For example,- Department. You can specify multiple key-value pairs.
- VALUEis the value to associate with the context key. For example,- Human resources.
To attach contexts when you upload directories with the
gcloud alpha storage rsync command, use the
--custom-contexts flag or the --custom-contexts-file flag:
gcloud alpha storage rsync DIRECTORY_LOCATION gs://DESTINATION_BUCKET_NAME --recursive --custom-contexts=KEY=VALUE,...
Where:
- DIRECTORY_LOCATIONis the local path to your directory. For example,- ~/my_directory.
- DESTINATION_BUCKET_NAMEis the name of the bucket to which you are uploading your directory. For example,- my-bucket.
- KEYis the context key to attach to objects. For example,- Department. You can specify multiple key-value pairs separated by commas.
- VALUEis the value to associate with the context key. For example,- Human resources.
JSON API
To attach contexts to objects when you upload new objects, use any of the following methods:
As part of the object metadata in JSON format, include the contexts field:
{ "contexts": { "custom": { "KEY": { "value": "VALUE" }, ... } } }
Where:
- KEYis the context key to attach to an object. For example,- Department. You can specify multiple key-value pairs in the- customobject.
- VALUEis the value to associate with the context key. For example,- Human resources.
Attach or modify contexts to an existing object
You can attach new contexts to your existing objects in the Cloud Storage buckets.
Command line
Use the gcloud alpha storage objects update command:
gcloud alpha storage objects update gs://BUCKET_NAME/OBJECT_NAME CUSTOM_CONTEXTS_FLAG
Where:
- BUCKET_NAMEis the name of the bucket that contains the object for which you want to edit context. For example,- my-bucket.
- OBJECT_NAMEis the name of the object. For example,- pets/dog.png.
- CUSTOM_CONTEXTS_FLAGis any of the following flags:- To replace all existing contexts, use - --custom-contexts=KEY=VALUE,...or- --custom-contexts-file=CUSTOM_CONTEXTS_FILE- Where: - KEYis the context key to attach to an object. For example,- Department. You can specify multiple key-value pairs separated by commas.
- VALUEis the value to associate with the context key. For example,- Human resources.
- CUSTOM_CONTEXTS_FILEis the path to the JSON or YAML file that contains the contexts you want to attach to the object.
 
- To delete all existing contexts, use - --clear-custom-contexts.
- To add, modify, or delete individual contexts, use a combination of - --update-custom-contexts=KEY=VALUE,...and- --remove-custom-contexts=KEY,...- Where: - KEYis the context key that you want to attach to or delete from an object. For example,- Department.
- VALUEis the value to associate with the context key that you want to attach to an object. For example,- Human resources.
 
 
If successful, the response looks like the following example:
Patching gs://my-bucket/pets/dog.png#1560574162144861... Completed 1
Client libraries
  
  
  
    
  
 
      
      
  For more information, see the
  Cloud Storage Java API
    reference documentation.
  
     
      To authenticate to Cloud Storage, set up Application Default Credentials.
      For more information, see
      
        Set up authentication for client libraries.
      
    Java
  
  
    
    
JSON API
- Have gcloud CLI installed and initialized, which lets you generate an access token for the - Authorizationheader.
- Create a JSON file that contains the settings for the object, which must include the - contextsconfiguration fields for the object.- To add, modify, or overwrite existing contexts, use the following format: - { "contexts": { "custom": { "KEY": { "value": "VALUE" }, ... } } } - Where: - KEYis the context key to attach to an object. For example,- Department. You can specify multiple key-value pairs in the- customobject.
- VALUEis the value to associate with the context key. For example,- Human resources.
 - To delete all existing contexts, use the following format: - { "contexts": { "custom": null } } - To delete a specific key from the context, use the following format: - { "contexts": { "custom": { "KEY": null, ... } } } - Where: - KEYis the context key that you want to delete from an object. For example,- Department. You can specify multiple keys to delete from the- customobject.
- Use - cURLto call the JSON API with a- PATCHObject request:- curl -X PATCH --data-binary @JSON_FILE_NAME \ -H "Authorization: Bearer $(gcloud auth print-access-token)" \ -H "Content-Type: application/json" \ "https://storage.googleapis.com/storage/v1/b/BUCKET_NAME/o/OBJECT_NAME" - Where: - JSON_FILE_NAMEis the path to the file that includes the object contexts information.
- BUCKET_NAMEis the name of the bucket that contains the object for which you want to edit context. For example,- my-bucket.
- OBJECT_NAMEis the URL-encoded name of the object. For example,- pets/dog.pngis URL-encoded as- pets%2Fdog.png.
 
Alternatively, you can replace an object's context with a PUT
Object request. The PUT object request also replaces other
object metadata. Therefore, we don't recommend using the PUT
object request.
View object contexts
You can view an object's contexts by listing object metadata or describing a specific object.
Command line
Use the gcloud alpha storage objects describe command:
gcloud alpha storage objects describe gs://BUCKET_NAME/OBJECT_NAME
Where:
- BUCKET_NAMEis the name of the bucket containing the object whose context you want to view. For example,- my-bucket.
- OBJECT_NAMEis the name of the object whose context you want to view. For example,- pets/dog.png
If successful, the response looks similar to the following example:
bucket: my-bucket
contexts:
  Department:
    createTime: '2023-01-01T00:00:00.000000+00:00'
    type: CUSTOM
    updateTime: '2023-01-01T00:00:00.000000+00:00'
    value: HR
  DataClassification:
    createTime: '2023-01-01T00:00:00.000000+00:00'
    type: CUSTOM
    updateTime: '2023-01-01T00:00:00.000000+00:00'
    value: Confidential
name: employees.txt
Client libraries
  
  
  
    
  
 
      
      
  For more information, see the
  Cloud Storage Java API
    reference documentation.
  
     
      To authenticate to Cloud Storage, set up Application Default Credentials.
      For more information, see
      
        Set up authentication for client libraries.
      
    Java
  
  
    
    
JSON API
- Have gcloud CLI installed and initialized, which lets you generate an access token for the - Authorizationheader.
- Use - cURLto call the JSON API with a- GETObject request:- curl -X GET \ -H "Authorization: Bearer $(gcloud auth print-access-token)" \ "https://storage.googleapis.com/storage/v1/b/BUCKET_NAME/o/OBJECT_NAME" - Where: - BUCKET_NAMEis the name of the bucket containing the object whose context you want to view. For example,- my-bucket.
- OBJECT_NAMEis the URL-encoded name of the object whose context you want to view. For example,- pets/dog.png, URL-encoded as- pets%2Fdog.png.
 - If successful, the response looks similar to the following example: - { "kind": "storage#object", "name": "employees.txt", "bucket": "my-bucket", "contexts": { "custom": { "Department": { "value": "HR", "createTime": "2023-01-01T00:00:00.000Z", "updateTime": "2023-01-01T00:00:00.000Z" }, "DataClassification": { "value": "Confidential", "createTime": "2023-01-01T00:00:00.000Z", "updateTime": "2023-01-01T00:00:00.000Z" } } } } 
Filter objects by contexts
Filter objects by the existence of object context keys or their specific values. Filtering objects by contexts helps to locate and manage particular groups of objects efficiently. For details, see Filter objects by contexts.
Manage object contexts during object operations
Object contexts are preserved by default when you copy, rewrite, compose, move, or restore objects. You can also modify contexts during the copy, rewrite, and compose operations.
Command line
The gcloud alpha storage cp command,
gcloud alpha storage rsync command, and
gcloud alpha storage mv command preserve contexts from the source
object by default. To modify contexts during these operations, use any of
the following flags:
- The --custom-contextsor--custom-contexts-fileflags to set new contexts for the destination object.
- The --clear-custom-contextsflag to prevent contexts from the source object from being attached to the destination object.
- A combination of the --update-custom-contextsand--remove-custom-contextsflags to modify individual contexts from the source object before attaching them to the destination object.
The gcloud alpha storage objects compose command merges contexts
from the source objects and attaches them to the destination objects by
default. Cloud Storage resolves conflicts by prioritizing contexts
from source objects processed later. For more information about the object
context behavior during a compose operation, see
Composite object contexts. You can also specify new contexts for the
destination object using the --custom-contexts or --custom-contexts-file
flags.
JSON API
- To modify contexts during a copy or a rewrite object operation, include the - contexts.customproperty in the request body. If you don't include this property, contexts from the source object are preserved by default.
- When you compose objects, contexts from source objects merge into the destination object by default. Cloud Storage resolves conflicts by prioritizing contexts from source objects processed later. For more information about the object context behavior during a compose operation, see Composite object contexts. You can also specify new contexts for the destination object in the - destination.contexts.customproperty.
What's next
- Learn about the object context properties in the Cloud Storage API documentation.