Class StorageClient
- All Implemented Interfaces:
com.google.api.gax.core.BackgroundResource,AutoCloseable
The Cloud Storage gRPC API allows applications to read and write data through the abstractions of buckets and objects. For a description of these abstractions please see https://cloud.google.com/storage/docs.
Resources are named as follows: - Projects are referred to as they are defined by the Resource Manager API, using strings like `projects/123456` or `projects/my-string-id`. - Buckets are named using string names of the form: `projects/{project}/buckets/{bucket}` For globally unique buckets, `_` may be substituted for the project. - Objects are uniquely identified by their name along with the name of the bucket they belong to, as separate strings in this API. For example:
ReadObjectRequest { bucket: 'projects/_/buckets/my-bucket' object: 'my-object' } Note that object names can contain `/` characters, which are treated as any other character (no special directory semantics).
This class provides the ability to make remote calls to the backing service through method calls that map to API methods. Sample code to get started:
// This snippet has been automatically generated and should be regarded as a code template only.
// It will require modifications to work:
// - It may require correct/in-range values for request initialization.
// - It may require specifying regional endpoints when creating the service client as shown in
// https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
try (StorageClient storageClient = StorageClient.create()) {
BucketName name = BucketName.of("[PROJECT]", "[BUCKET]");
storageClient.deleteBucket(name);
}
Note: close() needs to be called on the StorageClient object to clean up resources such as threads. In the example above, try-with-resources is used, which automatically calls close().
| Method | Description | Method Variants |
|---|---|---|
DeleteBucket |
Permanently deletes an empty bucket. |
Request object method variants only take one parameter, a request object, which must be constructed before the call.
"Flattened" method variants have converted the fields of the request object into function parameters to enable multiple ways to call the same method.
Callable method variants take no parameters and return an immutable API callable object, which can be used to initiate calls to the service.
|
GetBucket |
Returns metadata for the specified bucket. |
Request object method variants only take one parameter, a request object, which must be constructed before the call.
"Flattened" method variants have converted the fields of the request object into function parameters to enable multiple ways to call the same method.
Callable method variants take no parameters and return an immutable API callable object, which can be used to initiate calls to the service.
|
CreateBucket |
Creates a new bucket. |
Request object method variants only take one parameter, a request object, which must be constructed before the call.
"Flattened" method variants have converted the fields of the request object into function parameters to enable multiple ways to call the same method.
Callable method variants take no parameters and return an immutable API callable object, which can be used to initiate calls to the service.
|
ListBuckets |
Retrieves a list of buckets for a given project. |
Request object method variants only take one parameter, a request object, which must be constructed before the call.
"Flattened" method variants have converted the fields of the request object into function parameters to enable multiple ways to call the same method.
Callable method variants take no parameters and return an immutable API callable object, which can be used to initiate calls to the service.
|
LockBucketRetentionPolicy |
Locks retention policy on a bucket. |
Request object method variants only take one parameter, a request object, which must be constructed before the call.
"Flattened" method variants have converted the fields of the request object into function parameters to enable multiple ways to call the same method.
Callable method variants take no parameters and return an immutable API callable object, which can be used to initiate calls to the service.
|
GetIamPolicy |
Gets the IAM policy for a specified bucket. The `resource` field in the request should be `projects/_/buckets/{bucket}`. |
Request object method variants only take one parameter, a request object, which must be constructed before the call.
"Flattened" method variants have converted the fields of the request object into function parameters to enable multiple ways to call the same method.
Callable method variants take no parameters and return an immutable API callable object, which can be used to initiate calls to the service.
|
SetIamPolicy |
Updates an IAM policy for the specified bucket. The `resource` field in the request should be `projects/_/buckets/{bucket}`. |
Request object method variants only take one parameter, a request object, which must be constructed before the call.
"Flattened" method variants have converted the fields of the request object into function parameters to enable multiple ways to call the same method.
Callable method variants take no parameters and return an immutable API callable object, which can be used to initiate calls to the service.
|
TestIamPermissions |
Tests a set of permissions on the given bucket, object, or managed folder to see which, if any, are held by the caller. The `resource` field in the request should be `projects/_/buckets/{bucket}` for a bucket, `projects/_/buckets/{bucket}/objects/{object}` for an object, or `projects/_/buckets/{bucket}/managedFolders/{managedFolder}` for a managed folder. |
Request object method variants only take one parameter, a request object, which must be constructed before the call.
"Flattened" method variants have converted the fields of the request object into function parameters to enable multiple ways to call the same method.
Callable method variants take no parameters and return an immutable API callable object, which can be used to initiate calls to the service.
|
UpdateBucket |
Updates a bucket. Equivalent to JSON API's storage.buckets.patch method. |
Request object method variants only take one parameter, a request object, which must be constructed before the call.
"Flattened" method variants have converted the fields of the request object into function parameters to enable multiple ways to call the same method.
Callable method variants take no parameters and return an immutable API callable object, which can be used to initiate calls to the service.
|
ComposeObject |
Concatenates a list of existing objects into a new object in the same bucket. |
Request object method variants only take one parameter, a request object, which must be constructed before the call.
Callable method variants take no parameters and return an immutable API callable object, which can be used to initiate calls to the service.
|
DeleteObject |
Deletes an object and its metadata. Deletions are permanent if versioning is not enabled for the bucket, or if the generation parameter is used, or if [soft delete](https://cloud.google.com/storage/docs/soft-delete) is not enabled for the bucket. When this API is used to delete an object from a bucket that has soft delete policy enabled, the object becomes soft deleted, and the `softDeleteTime` and `hardDeleteTime` properties are set on the object. This API cannot be used to permanently delete soft-deleted objects. Soft-deleted objects are permanently deleted according to their `hardDeleteTime`. You can use the [`RestoreObject`][google.storage.v2.Storage.RestoreObject] API to restore soft-deleted objects until the soft delete retention period has passed. **IAM Permissions**: Requires `storage.objects.delete` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) on the bucket. |
Request object method variants only take one parameter, a request object, which must be constructed before the call.
"Flattened" method variants have converted the fields of the request object into function parameters to enable multiple ways to call the same method.
Callable method variants take no parameters and return an immutable API callable object, which can be used to initiate calls to the service.
|
RestoreObject |
Restores a soft-deleted object. |
Request object method variants only take one parameter, a request object, which must be constructed before the call.
"Flattened" method variants have converted the fields of the request object into function parameters to enable multiple ways to call the same method.
Callable method variants take no parameters and return an immutable API callable object, which can be used to initiate calls to the service.
|
CancelResumableWrite |
Cancels an in-progress resumable upload. Any attempts to write to the resumable upload after cancelling the upload will fail. The behavior for currently in progress write operations is not guaranteed - they could either complete before the cancellation or fail if the cancellation completes first. |
Request object method variants only take one parameter, a request object, which must be constructed before the call.
"Flattened" method variants have converted the fields of the request object into function parameters to enable multiple ways to call the same method.
Callable method variants take no parameters and return an immutable API callable object, which can be used to initiate calls to the service.
|
GetObject |
Retrieves object metadata. **IAM Permissions**: Requires `storage.objects.get` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) on the bucket. To return object ACLs, the authenticated user must also have the `storage.objects.getIamPolicy` permission. |
Request object method variants only take one parameter, a request object, which must be constructed before the call.
"Flattened" method variants have converted the fields of the request object into function parameters to enable multiple ways to call the same method.
Callable method variants take no parameters and return an immutable API callable object, which can be used to initiate calls to the service.
|
ReadObject |
Retrieves object data. **IAM Permissions**: Requires `storage.objects.get` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) on the bucket. |
Callable method variants take no parameters and return an immutable API callable object, which can be used to initiate calls to the service.
|
BidiReadObject |
Reads an object's data. This is a bi-directional API with the added support for reading multiple ranges within one stream both within and across multiple messages. If the server encountered an error for any of the inputs, the stream will be closed with the relevant error code. Because the API allows for multiple outstanding requests, when the stream is closed the error response will contain a BidiReadObjectRangesError proto in the error extension describing the error for each outstanding read_id. **IAM Permissions**: Requires `storage.objects.get` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) on the bucket. This API is currently in preview and is not yet available for general use. |
Callable method variants take no parameters and return an immutable API callable object, which can be used to initiate calls to the service.
|
UpdateObject |
Updates an object's metadata. Equivalent to JSON API's storage.objects.patch. |
Request object method variants only take one parameter, a request object, which must be constructed before the call.
"Flattened" method variants have converted the fields of the request object into function parameters to enable multiple ways to call the same method.
Callable method variants take no parameters and return an immutable API callable object, which can be used to initiate calls to the service.
|
WriteObject |
Stores a new object and metadata. An object can be written either in a single message stream or in a resumable sequence of message streams. To write using a single stream, the client should include in the first message of the stream an `WriteObjectSpec` describing the destination bucket, object, and any preconditions. Additionally, the final message must set 'finish_write' to true, or else it is an error. For a resumable write, the client should instead call `StartResumableWrite()`, populating a `WriteObjectSpec` into that request. They should then attach the returned `upload_id` to the first message of each following call to `WriteObject`. If the stream is closed before finishing the upload (either explicitly by the client or due to a network error or an error response from the server), the client should do as follows: - Check the result Status of the stream, to determine if writing can be resumed on this stream or must be restarted from scratch (by calling `StartResumableWrite()`). The resumable errors are DEADLINE_EXCEEDED, INTERNAL, and UNAVAILABLE. For each case, the client should use binary exponential backoff before retrying. Additionally, writes can be resumed after RESOURCE_EXHAUSTED errors, but only after taking appropriate measures, which may include reducing aggregate send rate across clients and/or requesting a quota increase for your project. - If the call to `WriteObject` returns `ABORTED`, that indicates concurrent attempts to update the resumable write, caused either by multiple racing clients or by a single client where the previous request was timed out on the client side but nonetheless reached the server. In this case the client should take steps to prevent further concurrent writes (e.g., increase the timeouts, stop using more than one process to perform the upload, etc.), and then should follow the steps below for resuming the upload. - For resumable errors, the client should call `QueryWriteStatus()` and then continue writing from the returned `persisted_size`. This may be less than the amount of data the client previously sent. Note also that it is acceptable to send data starting at an offset earlier than the returned `persisted_size`; in this case, the service will skip data at offsets that were already persisted (without checking that it matches the previously written data), and write only the data starting from the persisted offset. Even though the data isn't written, it may still incur a performance cost over resuming at the correct write offset. This behavior can make client-side handling simpler in some cases. - Clients must only send data that is a multiple of 256 KiB per message, unless the object is being finished with `finish_write` set to `true`. The service will not view the object as complete until the client has sent a `WriteObjectRequest` with `finish_write` set to `true`. Sending any requests on a stream after sending a request with `finish_write` set to `true` will cause an error. The client **should** check the response it receives to determine how much data the service was able to commit and whether the service views the object as complete. Attempting to resume an already finalized object will result in an OK status, with a `WriteObjectResponse` containing the finalized object's metadata. Alternatively, the BidiWriteObject operation may be used to write an object with controls over flushing and the ability to fetch the ability to determine the current persisted size. **IAM Permissions**: Requires `storage.objects.create` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) on the bucket. |
Callable method variants take no parameters and return an immutable API callable object, which can be used to initiate calls to the service.
|
BidiWriteObject |
Stores a new object and metadata. This is similar to the WriteObject call with the added support for manual flushing of persisted state, and the ability to determine current persisted size without closing the stream. The client may specify one or both of the `state_lookup` and `flush` fields in each BidiWriteObjectRequest. If `flush` is specified, the data written so far will be persisted to storage. If `state_lookup` is specified, the service will respond with a BidiWriteObjectResponse that contains the persisted size. If both `flush` and `state_lookup` are specified, the flush will always occur before a `state_lookup`, so that both may be set in the same request and the returned state will be the state of the object post-flush. When the stream is closed, a BidiWriteObjectResponse will always be sent to the client, regardless of the value of `state_lookup`. |
Callable method variants take no parameters and return an immutable API callable object, which can be used to initiate calls to the service.
|
ListObjects |
Retrieves a list of objects matching the criteria. **IAM Permissions**: The authenticated user requires `storage.objects.list` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) to use this method. To return object ACLs, the authenticated user must also have the `storage.objects.getIamPolicy` permission. |
Request object method variants only take one parameter, a request object, which must be constructed before the call.
"Flattened" method variants have converted the fields of the request object into function parameters to enable multiple ways to call the same method.
Callable method variants take no parameters and return an immutable API callable object, which can be used to initiate calls to the service.
|
RewriteObject |
Rewrites a source object to a destination object. Optionally overrides metadata. |
Request object method variants only take one parameter, a request object, which must be constructed before the call.
Callable method variants take no parameters and return an immutable API callable object, which can be used to initiate calls to the service.
|
StartResumableWrite |
Starts a resumable write operation. This method is part of the [Resumable upload](https://cloud.google.com/storage/docs/resumable-uploads) feature. This allows you to upload large objects in multiple chunks, which is more resilient to network interruptions than a single upload. The validity duration of the write operation, and the consequences of it becoming invalid, are service-dependent. **IAM Permissions**: Requires `storage.objects.create` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) on the bucket. |
Request object method variants only take one parameter, a request object, which must be constructed before the call.
Callable method variants take no parameters and return an immutable API callable object, which can be used to initiate calls to the service.
|
QueryWriteStatus |
Determines the `persisted_size` of an object that is being written. This method is part of the [resumable upload](https://cloud.google.com/storage/docs/resumable-uploads) feature. The returned value is the size of the object that has been persisted so far. The value can be used as the `write_offset` for the next `Write()` call. If the object does not exist, meaning if it was deleted, or the first `Write()` has not yet reached the service, this method returns the error `NOT_FOUND`. This method is useful for clients that buffer data and need to know which data can be safely evicted. The client can call `QueryWriteStatus()` at any time to determine how much data has been logged for this object. For any sequence of `QueryWriteStatus()` calls for a given object name, the sequence of returned `persisted_size` values are non-decreasing. |
Request object method variants only take one parameter, a request object, which must be constructed before the call.
"Flattened" method variants have converted the fields of the request object into function parameters to enable multiple ways to call the same method.
Callable method variants take no parameters and return an immutable API callable object, which can be used to initiate calls to the service.
|
MoveObject |
Moves the source object to the destination object in the same bucket. |
Request object method variants only take one parameter, a request object, which must be constructed before the call.
"Flattened" method variants have converted the fields of the request object into function parameters to enable multiple ways to call the same method.
Callable method variants take no parameters and return an immutable API callable object, which can be used to initiate calls to the service.
|
See the individual methods for example code.
Many parameters require resource names to be formatted in a particular way. To assist with these names, this class includes a format method for each type of name, and additionally a parse method to extract the individual identifiers contained within names that are returned.
This class can be customized by passing in a custom instance of StorageSettings to create(). For example:
To customize credentials:
// This snippet has been automatically generated and should be regarded as a code template only.
// It will require modifications to work:
// - It may require correct/in-range values for request initialization.
// - It may require specifying regional endpoints when creating the service client as shown in
// https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
StorageSettings storageSettings =
StorageSettings.newBuilder()
.setCredentialsProvider(FixedCredentialsProvider.create(myCredentials))
.build();
StorageClient storageClient = StorageClient.create(storageSettings);
To customize the endpoint:
// This snippet has been automatically generated and should be regarded as a code template only.
// It will require modifications to work:
// - It may require correct/in-range values for request initialization.
// - It may require specifying regional endpoints when creating the service client as shown in
// https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library
StorageSettings storageSettings = StorageSettings.newBuilder().setEndpoint(myEndpoint).build();
StorageClient storageClient = StorageClient.create(storageSettings);
Please refer to the GitHub repository's samples for more quickstart code snippets.
-
Nested Class Summary
Nested ClassesModifier and TypeClassDescriptionstatic classstatic classstatic classstatic classstatic classstatic class -
Constructor Summary
ConstructorsModifierConstructorDescriptionprotectedStorageClient(StorageSettings settings) Constructs an instance of StorageClient, using the given settings.protectedStorageClient(StorageStub stub) -
Method Summary
Modifier and TypeMethodDescriptionbooleanawaitTermination(long duration, TimeUnit unit) final com.google.api.gax.rpc.BidiStreamingCallable<BidiReadObjectRequest,BidiReadObjectResponse> Reads an object's data.final com.google.api.gax.rpc.BidiStreamingCallable<BidiWriteObjectRequest,BidiWriteObjectResponse> Stores a new object and metadata.Cancels an in-progress resumable upload.cancelResumableWrite(String uploadId) Cancels an in-progress resumable upload.final com.google.api.gax.rpc.UnaryCallable<CancelResumableWriteRequest,CancelResumableWriteResponse> Cancels an in-progress resumable upload.final voidclose()final ObjectcomposeObject(ComposeObjectRequest request) Concatenates a list of existing objects into a new object in the same bucket.final com.google.api.gax.rpc.UnaryCallable<ComposeObjectRequest,Object> Concatenates a list of existing objects into a new object in the same bucket.static final StorageClientcreate()Constructs an instance of StorageClient with default settings.static final StorageClientcreate(StorageSettings settings) Constructs an instance of StorageClient, using the given settings.static final StorageClientcreate(StorageStub stub) Constructs an instance of StorageClient, using the given stub for making calls.final BucketcreateBucket(CreateBucketRequest request) Creates a new bucket.final BucketcreateBucket(ProjectName parent, Bucket bucket, String bucketId) Creates a new bucket.final BucketcreateBucket(String parent, Bucket bucket, String bucketId) Creates a new bucket.final com.google.api.gax.rpc.UnaryCallable<CreateBucketRequest,Bucket> Creates a new bucket.final voiddeleteBucket(BucketName name) Permanently deletes an empty bucket.final voiddeleteBucket(DeleteBucketRequest request) Permanently deletes an empty bucket.final voiddeleteBucket(String name) Permanently deletes an empty bucket.final com.google.api.gax.rpc.UnaryCallable<DeleteBucketRequest,com.google.protobuf.Empty> Permanently deletes an empty bucket.final voiddeleteObject(BucketName bucket, String object) Deletes an object and its metadata.final voiddeleteObject(BucketName bucket, String object, long generation) Deletes an object and its metadata.final voiddeleteObject(DeleteObjectRequest request) Deletes an object and its metadata.final voiddeleteObject(String bucket, String object) Deletes an object and its metadata.final voiddeleteObject(String bucket, String object, long generation) Deletes an object and its metadata.final com.google.api.gax.rpc.UnaryCallable<DeleteObjectRequest,com.google.protobuf.Empty> Deletes an object and its metadata.final BucketgetBucket(BucketName name) Returns metadata for the specified bucket.final BucketgetBucket(GetBucketRequest request) Returns metadata for the specified bucket.final BucketReturns metadata for the specified bucket.final com.google.api.gax.rpc.UnaryCallable<GetBucketRequest,Bucket> Returns metadata for the specified bucket.final com.google.iam.v1.PolicygetIamPolicy(com.google.api.resourcenames.ResourceName resource) Gets the IAM policy for a specified bucket.final com.google.iam.v1.PolicygetIamPolicy(com.google.iam.v1.GetIamPolicyRequest request) Gets the IAM policy for a specified bucket.final com.google.iam.v1.PolicygetIamPolicy(String resource) Gets the IAM policy for a specified bucket.final com.google.api.gax.rpc.UnaryCallable<com.google.iam.v1.GetIamPolicyRequest,com.google.iam.v1.Policy> Gets the IAM policy for a specified bucket.final ObjectgetObject(BucketName bucket, String object) Retrieves object metadata.final ObjectgetObject(BucketName bucket, String object, long generation) Retrieves object metadata.final ObjectgetObject(GetObjectRequest request) Retrieves object metadata.final ObjectRetrieves object metadata.final ObjectRetrieves object metadata.final com.google.api.gax.rpc.UnaryCallable<GetObjectRequest,Object> Retrieves object metadata.final StorageSettingsgetStub()booleanbooleanlistBuckets(ListBucketsRequest request) Retrieves a list of buckets for a given project.listBuckets(ProjectName parent) Retrieves a list of buckets for a given project.listBuckets(String parent) Retrieves a list of buckets for a given project.final com.google.api.gax.rpc.UnaryCallable<ListBucketsRequest,ListBucketsResponse> Retrieves a list of buckets for a given project.final com.google.api.gax.rpc.UnaryCallable<ListBucketsRequest,StorageClient.ListBucketsPagedResponse> Retrieves a list of buckets for a given project.listObjects(BucketName parent) Retrieves a list of objects matching the criteria.listObjects(ListObjectsRequest request) Retrieves a list of objects matching the criteria.listObjects(String parent) Retrieves a list of objects matching the criteria.final com.google.api.gax.rpc.UnaryCallable<ListObjectsRequest,ListObjectsResponse> Retrieves a list of objects matching the criteria.final com.google.api.gax.rpc.UnaryCallable<ListObjectsRequest,StorageClient.ListObjectsPagedResponse> Retrieves a list of objects matching the criteria.final BucketlockBucketRetentionPolicy(BucketName bucket) Locks retention policy on a bucket.final BucketLocks retention policy on a bucket.final BucketlockBucketRetentionPolicy(String bucket) Locks retention policy on a bucket.final com.google.api.gax.rpc.UnaryCallable<LockBucketRetentionPolicyRequest,Bucket> Locks retention policy on a bucket.final ObjectmoveObject(BucketName bucket, String sourceObject, String destinationObject) Moves the source object to the destination object in the same bucket.final ObjectmoveObject(MoveObjectRequest request) Moves the source object to the destination object in the same bucket.final ObjectmoveObject(String bucket, String sourceObject, String destinationObject) Moves the source object to the destination object in the same bucket.final com.google.api.gax.rpc.UnaryCallable<MoveObjectRequest,Object> Moves the source object to the destination object in the same bucket.final QueryWriteStatusResponsequeryWriteStatus(QueryWriteStatusRequest request) Determines the `persisted_size` of an object that is being written.final QueryWriteStatusResponsequeryWriteStatus(String uploadId) Determines the `persisted_size` of an object that is being written.final com.google.api.gax.rpc.UnaryCallable<QueryWriteStatusRequest,QueryWriteStatusResponse> Determines the `persisted_size` of an object that is being written.final com.google.api.gax.rpc.ServerStreamingCallable<ReadObjectRequest,ReadObjectResponse> Retrieves object data.final ObjectrestoreObject(BucketName bucket, String object, long generation) Restores a soft-deleted object.final ObjectrestoreObject(RestoreObjectRequest request) Restores a soft-deleted object.final ObjectrestoreObject(String bucket, String object, long generation) Restores a soft-deleted object.final com.google.api.gax.rpc.UnaryCallable<RestoreObjectRequest,Object> Restores a soft-deleted object.final RewriteResponserewriteObject(RewriteObjectRequest request) Rewrites a source object to a destination object.final com.google.api.gax.rpc.UnaryCallable<RewriteObjectRequest,RewriteResponse> Rewrites a source object to a destination object.final com.google.iam.v1.PolicysetIamPolicy(com.google.api.resourcenames.ResourceName resource, com.google.iam.v1.Policy policy) Updates an IAM policy for the specified bucket.final com.google.iam.v1.PolicysetIamPolicy(com.google.iam.v1.SetIamPolicyRequest request) Updates an IAM policy for the specified bucket.final com.google.iam.v1.PolicysetIamPolicy(String resource, com.google.iam.v1.Policy policy) Updates an IAM policy for the specified bucket.final com.google.api.gax.rpc.UnaryCallable<com.google.iam.v1.SetIamPolicyRequest,com.google.iam.v1.Policy> Updates an IAM policy for the specified bucket.voidshutdown()voidStarts a resumable write operation.final com.google.api.gax.rpc.UnaryCallable<StartResumableWriteRequest,StartResumableWriteResponse> Starts a resumable write operation.final com.google.iam.v1.TestIamPermissionsResponsetestIamPermissions(com.google.api.resourcenames.ResourceName resource, List<String> permissions) Tests a set of permissions on the given bucket, object, or managed folder to see which, if any, are held by the caller.final com.google.iam.v1.TestIamPermissionsResponsetestIamPermissions(com.google.iam.v1.TestIamPermissionsRequest request) Tests a set of permissions on the given bucket, object, or managed folder to see which, if any, are held by the caller.final com.google.iam.v1.TestIamPermissionsResponsetestIamPermissions(String resource, List<String> permissions) Tests a set of permissions on the given bucket, object, or managed folder to see which, if any, are held by the caller.final com.google.api.gax.rpc.UnaryCallable<com.google.iam.v1.TestIamPermissionsRequest,com.google.iam.v1.TestIamPermissionsResponse> Tests a set of permissions on the given bucket, object, or managed folder to see which, if any, are held by the caller.final BucketupdateBucket(Bucket bucket, com.google.protobuf.FieldMask updateMask) Updates a bucket.final BucketupdateBucket(UpdateBucketRequest request) Updates a bucket.final com.google.api.gax.rpc.UnaryCallable<UpdateBucketRequest,Bucket> Updates a bucket.final ObjectupdateObject(Object object, com.google.protobuf.FieldMask updateMask) Updates an object's metadata.final ObjectupdateObject(UpdateObjectRequest request) Updates an object's metadata.final com.google.api.gax.rpc.UnaryCallable<UpdateObjectRequest,Object> Updates an object's metadata.final com.google.api.gax.rpc.ClientStreamingCallable<WriteObjectRequest,WriteObjectResponse> Stores a new object and metadata.
-
Constructor Details
-
StorageClient
Constructs an instance of StorageClient, using the given settings. This is protected so that it is easy to make a subclass, but otherwise, the static factory methods should be preferred.- Throws:
IOException
-
StorageClient
-
-
Method Details
-
create
Constructs an instance of StorageClient with default settings.- Throws:
IOException
-
create
Constructs an instance of StorageClient, using the given settings. The channels are created based on the settings passed in, or defaults for any settings that are not set.- Throws:
IOException
-
create
Constructs an instance of StorageClient, using the given stub for making calls. This is for advanced usage - prefer using create(StorageSettings). -
getSettings
-
getStub
-
deleteBucket
Permanently deletes an empty bucket.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { BucketName name = BucketName.of("[PROJECT]", "[BUCKET]"); storageClient.deleteBucket(name); }- Parameters:
name- Required. Name of a bucket to delete.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
deleteBucket
Permanently deletes an empty bucket.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { String name = BucketName.of("[PROJECT]", "[BUCKET]").toString(); storageClient.deleteBucket(name); }- Parameters:
name- Required. Name of a bucket to delete.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
deleteBucket
Permanently deletes an empty bucket.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { DeleteBucketRequest request = DeleteBucketRequest.newBuilder() .setName(BucketName.of("[PROJECT]", "[BUCKET]").toString()) .setIfMetagenerationMatch(1043427781) .setIfMetagenerationNotMatch(1025430873) .build(); storageClient.deleteBucket(request); }- Parameters:
request- The request object containing all of the parameters for the API call.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
deleteBucketCallable
public final com.google.api.gax.rpc.UnaryCallable<DeleteBucketRequest,com.google.protobuf.Empty> deleteBucketCallable()Permanently deletes an empty bucket.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { DeleteBucketRequest request = DeleteBucketRequest.newBuilder() .setName(BucketName.of("[PROJECT]", "[BUCKET]").toString()) .setIfMetagenerationMatch(1043427781) .setIfMetagenerationNotMatch(1025430873) .build(); ApiFuture<Empty> future = storageClient.deleteBucketCallable().futureCall(request); // Do something. future.get(); } -
getBucket
Returns metadata for the specified bucket.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { BucketName name = BucketName.of("[PROJECT]", "[BUCKET]"); Bucket response = storageClient.getBucket(name); }- Parameters:
name- Required. Name of a bucket.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
getBucket
Returns metadata for the specified bucket.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { String name = BucketName.of("[PROJECT]", "[BUCKET]").toString(); Bucket response = storageClient.getBucket(name); }- Parameters:
name- Required. Name of a bucket.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
getBucket
Returns metadata for the specified bucket.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { GetBucketRequest request = GetBucketRequest.newBuilder() .setName(BucketName.of("[PROJECT]", "[BUCKET]").toString()) .setIfMetagenerationMatch(1043427781) .setIfMetagenerationNotMatch(1025430873) .setReadMask(FieldMask.newBuilder().build()) .build(); Bucket response = storageClient.getBucket(request); }- Parameters:
request- The request object containing all of the parameters for the API call.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
getBucketCallable
Returns metadata for the specified bucket.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { GetBucketRequest request = GetBucketRequest.newBuilder() .setName(BucketName.of("[PROJECT]", "[BUCKET]").toString()) .setIfMetagenerationMatch(1043427781) .setIfMetagenerationNotMatch(1025430873) .setReadMask(FieldMask.newBuilder().build()) .build(); ApiFuture<Bucket> future = storageClient.getBucketCallable().futureCall(request); // Do something. Bucket response = future.get(); } -
createBucket
Creates a new bucket.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { ProjectName parent = ProjectName.of("[PROJECT]"); Bucket bucket = Bucket.newBuilder().build(); String bucketId = "bucketId-1603305307"; Bucket response = storageClient.createBucket(parent, bucket, bucketId); }- Parameters:
parent- Required. The project to which this bucket will belong.bucket- Properties of the new bucket being inserted. The name of the bucket is specified in the `bucket_id` field. Populating `bucket.name` field will result in an error. The project of the bucket must be specified in the `bucket.project` field. This field must be in `projects/{projectIdentifier}` format, {projectIdentifier} can be the project ID or project number. The `parent` field must be either empty or `projects/_`.bucketId- Required. The ID to use for this bucket, which will become the final component of the bucket's resource name. For example, the value `foo` might result in a bucket with the name `projects/123456/buckets/foo`.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
createBucket
Creates a new bucket.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { String parent = ProjectName.of("[PROJECT]").toString(); Bucket bucket = Bucket.newBuilder().build(); String bucketId = "bucketId-1603305307"; Bucket response = storageClient.createBucket(parent, bucket, bucketId); }- Parameters:
parent- Required. The project to which this bucket will belong.bucket- Properties of the new bucket being inserted. The name of the bucket is specified in the `bucket_id` field. Populating `bucket.name` field will result in an error. The project of the bucket must be specified in the `bucket.project` field. This field must be in `projects/{projectIdentifier}` format, {projectIdentifier} can be the project ID or project number. The `parent` field must be either empty or `projects/_`.bucketId- Required. The ID to use for this bucket, which will become the final component of the bucket's resource name. For example, the value `foo` might result in a bucket with the name `projects/123456/buckets/foo`.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
createBucket
Creates a new bucket.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { CreateBucketRequest request = CreateBucketRequest.newBuilder() .setParent(ProjectName.of("[PROJECT]").toString()) .setBucket(Bucket.newBuilder().build()) .setBucketId("bucketId-1603305307") .setPredefinedAcl("predefinedAcl1207041188") .setPredefinedDefaultObjectAcl("predefinedDefaultObjectAcl2109168048") .build(); Bucket response = storageClient.createBucket(request); }- Parameters:
request- The request object containing all of the parameters for the API call.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
createBucketCallable
public final com.google.api.gax.rpc.UnaryCallable<CreateBucketRequest,Bucket> createBucketCallable()Creates a new bucket.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { CreateBucketRequest request = CreateBucketRequest.newBuilder() .setParent(ProjectName.of("[PROJECT]").toString()) .setBucket(Bucket.newBuilder().build()) .setBucketId("bucketId-1603305307") .setPredefinedAcl("predefinedAcl1207041188") .setPredefinedDefaultObjectAcl("predefinedDefaultObjectAcl2109168048") .build(); ApiFuture<Bucket> future = storageClient.createBucketCallable().futureCall(request); // Do something. Bucket response = future.get(); } -
listBuckets
Retrieves a list of buckets for a given project.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { ProjectName parent = ProjectName.of("[PROJECT]"); for (Bucket element : storageClient.listBuckets(parent).iterateAll()) { // doThingsWith(element); } }- Parameters:
parent- Required. The project whose buckets we are listing.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
listBuckets
Retrieves a list of buckets for a given project.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { String parent = ProjectName.of("[PROJECT]").toString(); for (Bucket element : storageClient.listBuckets(parent).iterateAll()) { // doThingsWith(element); } }- Parameters:
parent- Required. The project whose buckets we are listing.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
listBuckets
Retrieves a list of buckets for a given project.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { ListBucketsRequest request = ListBucketsRequest.newBuilder() .setParent(ProjectName.of("[PROJECT]").toString()) .setPageSize(883849137) .setPageToken("pageToken873572522") .setPrefix("prefix-980110702") .setReadMask(FieldMask.newBuilder().build()) .build(); for (Bucket element : storageClient.listBuckets(request).iterateAll()) { // doThingsWith(element); } }- Parameters:
request- The request object containing all of the parameters for the API call.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
listBucketsPagedCallable
public final com.google.api.gax.rpc.UnaryCallable<ListBucketsRequest,StorageClient.ListBucketsPagedResponse> listBucketsPagedCallable()Retrieves a list of buckets for a given project.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { ListBucketsRequest request = ListBucketsRequest.newBuilder() .setParent(ProjectName.of("[PROJECT]").toString()) .setPageSize(883849137) .setPageToken("pageToken873572522") .setPrefix("prefix-980110702") .setReadMask(FieldMask.newBuilder().build()) .build(); ApiFuture<Bucket> future = storageClient.listBucketsPagedCallable().futureCall(request); // Do something. for (Bucket element : future.get().iterateAll()) { // doThingsWith(element); } } -
listBucketsCallable
public final com.google.api.gax.rpc.UnaryCallable<ListBucketsRequest,ListBucketsResponse> listBucketsCallable()Retrieves a list of buckets for a given project.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { ListBucketsRequest request = ListBucketsRequest.newBuilder() .setParent(ProjectName.of("[PROJECT]").toString()) .setPageSize(883849137) .setPageToken("pageToken873572522") .setPrefix("prefix-980110702") .setReadMask(FieldMask.newBuilder().build()) .build(); while (true) { ListBucketsResponse response = storageClient.listBucketsCallable().call(request); for (Bucket element : response.getBucketsList()) { // doThingsWith(element); } String nextPageToken = response.getNextPageToken(); if (!Strings.isNullOrEmpty(nextPageToken)) { request = request.toBuilder().setPageToken(nextPageToken).build(); } else { break; } } } -
lockBucketRetentionPolicy
Locks retention policy on a bucket.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { BucketName bucket = BucketName.of("[PROJECT]", "[BUCKET]"); Bucket response = storageClient.lockBucketRetentionPolicy(bucket); }- Parameters:
bucket- Required. Name of a bucket.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
lockBucketRetentionPolicy
Locks retention policy on a bucket.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { String bucket = BucketName.of("[PROJECT]", "[BUCKET]").toString(); Bucket response = storageClient.lockBucketRetentionPolicy(bucket); }- Parameters:
bucket- Required. Name of a bucket.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
lockBucketRetentionPolicy
Locks retention policy on a bucket.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { LockBucketRetentionPolicyRequest request = LockBucketRetentionPolicyRequest.newBuilder() .setBucket(BucketName.of("[PROJECT]", "[BUCKET]").toString()) .setIfMetagenerationMatch(1043427781) .build(); Bucket response = storageClient.lockBucketRetentionPolicy(request); }- Parameters:
request- The request object containing all of the parameters for the API call.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
lockBucketRetentionPolicyCallable
public final com.google.api.gax.rpc.UnaryCallable<LockBucketRetentionPolicyRequest,Bucket> lockBucketRetentionPolicyCallable()Locks retention policy on a bucket.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { LockBucketRetentionPolicyRequest request = LockBucketRetentionPolicyRequest.newBuilder() .setBucket(BucketName.of("[PROJECT]", "[BUCKET]").toString()) .setIfMetagenerationMatch(1043427781) .build(); ApiFuture<Bucket> future = storageClient.lockBucketRetentionPolicyCallable().futureCall(request); // Do something. Bucket response = future.get(); } -
getIamPolicy
public final com.google.iam.v1.Policy getIamPolicy(com.google.api.resourcenames.ResourceName resource) Gets the IAM policy for a specified bucket. The `resource` field in the request should be `projects/_/buckets/{bucket}`.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { ResourceName resource = CryptoKeyName.of("[PROJECT]", "[LOCATION]", "[KEY_RING]", "[CRYPTO_KEY]"); Policy response = storageClient.getIamPolicy(resource); }- Parameters:
resource- REQUIRED: The resource for which the policy is being requested. See the operation documentation for the appropriate value for this field.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
getIamPolicy
Gets the IAM policy for a specified bucket. The `resource` field in the request should be `projects/_/buckets/{bucket}`.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { String resource = CryptoKeyName.of("[PROJECT]", "[LOCATION]", "[KEY_RING]", "[CRYPTO_KEY]").toString(); Policy response = storageClient.getIamPolicy(resource); }- Parameters:
resource- REQUIRED: The resource for which the policy is being requested. See the operation documentation for the appropriate value for this field.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
getIamPolicy
public final com.google.iam.v1.Policy getIamPolicy(com.google.iam.v1.GetIamPolicyRequest request) Gets the IAM policy for a specified bucket. The `resource` field in the request should be `projects/_/buckets/{bucket}`.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { GetIamPolicyRequest request = GetIamPolicyRequest.newBuilder() .setResource( CryptoKeyName.of("[PROJECT]", "[LOCATION]", "[KEY_RING]", "[CRYPTO_KEY]") .toString()) .setOptions(GetPolicyOptions.newBuilder().build()) .build(); Policy response = storageClient.getIamPolicy(request); }- Parameters:
request- The request object containing all of the parameters for the API call.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
getIamPolicyCallable
public final com.google.api.gax.rpc.UnaryCallable<com.google.iam.v1.GetIamPolicyRequest,com.google.iam.v1.Policy> getIamPolicyCallable()Gets the IAM policy for a specified bucket. The `resource` field in the request should be `projects/_/buckets/{bucket}`.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { GetIamPolicyRequest request = GetIamPolicyRequest.newBuilder() .setResource( CryptoKeyName.of("[PROJECT]", "[LOCATION]", "[KEY_RING]", "[CRYPTO_KEY]") .toString()) .setOptions(GetPolicyOptions.newBuilder().build()) .build(); ApiFuture<Policy> future = storageClient.getIamPolicyCallable().futureCall(request); // Do something. Policy response = future.get(); } -
setIamPolicy
public final com.google.iam.v1.Policy setIamPolicy(com.google.api.resourcenames.ResourceName resource, com.google.iam.v1.Policy policy) Updates an IAM policy for the specified bucket. The `resource` field in the request should be `projects/_/buckets/{bucket}`.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { ResourceName resource = CryptoKeyName.of("[PROJECT]", "[LOCATION]", "[KEY_RING]", "[CRYPTO_KEY]"); Policy policy = Policy.newBuilder().build(); Policy response = storageClient.setIamPolicy(resource, policy); }- Parameters:
resource- REQUIRED: The resource for which the policy is being specified. See the operation documentation for the appropriate value for this field.policy- REQUIRED: The complete policy to be applied to the `resource`. The size of the policy is limited to a few 10s of KB. An empty policy is a valid policy but certain Cloud Platform services (such as Projects) might reject them.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
setIamPolicy
public final com.google.iam.v1.Policy setIamPolicy(String resource, com.google.iam.v1.Policy policy) Updates an IAM policy for the specified bucket. The `resource` field in the request should be `projects/_/buckets/{bucket}`.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { String resource = CryptoKeyName.of("[PROJECT]", "[LOCATION]", "[KEY_RING]", "[CRYPTO_KEY]").toString(); Policy policy = Policy.newBuilder().build(); Policy response = storageClient.setIamPolicy(resource, policy); }- Parameters:
resource- REQUIRED: The resource for which the policy is being specified. See the operation documentation for the appropriate value for this field.policy- REQUIRED: The complete policy to be applied to the `resource`. The size of the policy is limited to a few 10s of KB. An empty policy is a valid policy but certain Cloud Platform services (such as Projects) might reject them.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
setIamPolicy
public final com.google.iam.v1.Policy setIamPolicy(com.google.iam.v1.SetIamPolicyRequest request) Updates an IAM policy for the specified bucket. The `resource` field in the request should be `projects/_/buckets/{bucket}`.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { SetIamPolicyRequest request = SetIamPolicyRequest.newBuilder() .setResource( CryptoKeyName.of("[PROJECT]", "[LOCATION]", "[KEY_RING]", "[CRYPTO_KEY]") .toString()) .setPolicy(Policy.newBuilder().build()) .setUpdateMask(FieldMask.newBuilder().build()) .build(); Policy response = storageClient.setIamPolicy(request); }- Parameters:
request- The request object containing all of the parameters for the API call.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
setIamPolicyCallable
public final com.google.api.gax.rpc.UnaryCallable<com.google.iam.v1.SetIamPolicyRequest,com.google.iam.v1.Policy> setIamPolicyCallable()Updates an IAM policy for the specified bucket. The `resource` field in the request should be `projects/_/buckets/{bucket}`.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { SetIamPolicyRequest request = SetIamPolicyRequest.newBuilder() .setResource( CryptoKeyName.of("[PROJECT]", "[LOCATION]", "[KEY_RING]", "[CRYPTO_KEY]") .toString()) .setPolicy(Policy.newBuilder().build()) .setUpdateMask(FieldMask.newBuilder().build()) .build(); ApiFuture<Policy> future = storageClient.setIamPolicyCallable().futureCall(request); // Do something. Policy response = future.get(); } -
testIamPermissions
public final com.google.iam.v1.TestIamPermissionsResponse testIamPermissions(com.google.api.resourcenames.ResourceName resource, List<String> permissions) Tests a set of permissions on the given bucket, object, or managed folder to see which, if any, are held by the caller. The `resource` field in the request should be `projects/_/buckets/{bucket}` for a bucket, `projects/_/buckets/{bucket}/objects/{object}` for an object, or `projects/_/buckets/{bucket}/managedFolders/{managedFolder}` for a managed folder.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { ResourceName resource = CryptoKeyName.of("[PROJECT]", "[LOCATION]", "[KEY_RING]", "[CRYPTO_KEY]"); List<String> permissions = new ArrayList<>(); TestIamPermissionsResponse response = storageClient.testIamPermissions(resource, permissions); }- Parameters:
resource- REQUIRED: The resource for which the policy detail is being requested. See the operation documentation for the appropriate value for this field.permissions- The set of permissions to check for the `resource`. Permissions with wildcards (such as '*' or 'storage.*') are not allowed. For more information see [IAM Overview](https://cloud.google.com/iam/docs/overview#permissions).- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
testIamPermissions
public final com.google.iam.v1.TestIamPermissionsResponse testIamPermissions(String resource, List<String> permissions) Tests a set of permissions on the given bucket, object, or managed folder to see which, if any, are held by the caller. The `resource` field in the request should be `projects/_/buckets/{bucket}` for a bucket, `projects/_/buckets/{bucket}/objects/{object}` for an object, or `projects/_/buckets/{bucket}/managedFolders/{managedFolder}` for a managed folder.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { String resource = CryptoKeyName.of("[PROJECT]", "[LOCATION]", "[KEY_RING]", "[CRYPTO_KEY]").toString(); List<String> permissions = new ArrayList<>(); TestIamPermissionsResponse response = storageClient.testIamPermissions(resource, permissions); }- Parameters:
resource- REQUIRED: The resource for which the policy detail is being requested. See the operation documentation for the appropriate value for this field.permissions- The set of permissions to check for the `resource`. Permissions with wildcards (such as '*' or 'storage.*') are not allowed. For more information see [IAM Overview](https://cloud.google.com/iam/docs/overview#permissions).- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
testIamPermissions
public final com.google.iam.v1.TestIamPermissionsResponse testIamPermissions(com.google.iam.v1.TestIamPermissionsRequest request) Tests a set of permissions on the given bucket, object, or managed folder to see which, if any, are held by the caller. The `resource` field in the request should be `projects/_/buckets/{bucket}` for a bucket, `projects/_/buckets/{bucket}/objects/{object}` for an object, or `projects/_/buckets/{bucket}/managedFolders/{managedFolder}` for a managed folder.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { TestIamPermissionsRequest request = TestIamPermissionsRequest.newBuilder() .setResource( CryptoKeyName.of("[PROJECT]", "[LOCATION]", "[KEY_RING]", "[CRYPTO_KEY]") .toString()) .addAllPermissions(new ArrayList<String>()) .build(); TestIamPermissionsResponse response = storageClient.testIamPermissions(request); }- Parameters:
request- The request object containing all of the parameters for the API call.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
testIamPermissionsCallable
public final com.google.api.gax.rpc.UnaryCallable<com.google.iam.v1.TestIamPermissionsRequest,com.google.iam.v1.TestIamPermissionsResponse> testIamPermissionsCallable()Tests a set of permissions on the given bucket, object, or managed folder to see which, if any, are held by the caller. The `resource` field in the request should be `projects/_/buckets/{bucket}` for a bucket, `projects/_/buckets/{bucket}/objects/{object}` for an object, or `projects/_/buckets/{bucket}/managedFolders/{managedFolder}` for a managed folder.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { TestIamPermissionsRequest request = TestIamPermissionsRequest.newBuilder() .setResource( CryptoKeyName.of("[PROJECT]", "[LOCATION]", "[KEY_RING]", "[CRYPTO_KEY]") .toString()) .addAllPermissions(new ArrayList<String>()) .build(); ApiFuture<TestIamPermissionsResponse> future = storageClient.testIamPermissionsCallable().futureCall(request); // Do something. TestIamPermissionsResponse response = future.get(); } -
updateBucket
Updates a bucket. Equivalent to JSON API's storage.buckets.patch method.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { Bucket bucket = Bucket.newBuilder().build(); FieldMask updateMask = FieldMask.newBuilder().build(); Bucket response = storageClient.updateBucket(bucket, updateMask); }- Parameters:
bucket- Required. The bucket to update. The bucket's `name` field will be used to identify the bucket.updateMask- Required. List of fields to be updated.To specify ALL fields, equivalent to the JSON API's "update" function, specify a single field with the value `*`. Note: not recommended. If a new field is introduced at a later time, an older client updating with the `*` may accidentally reset the new field's value.
Not specifying any fields is an error.
- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
updateBucket
Updates a bucket. Equivalent to JSON API's storage.buckets.patch method.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { UpdateBucketRequest request = UpdateBucketRequest.newBuilder() .setBucket(Bucket.newBuilder().build()) .setIfMetagenerationMatch(1043427781) .setIfMetagenerationNotMatch(1025430873) .setPredefinedAcl("predefinedAcl1207041188") .setPredefinedDefaultObjectAcl("predefinedDefaultObjectAcl2109168048") .setUpdateMask(FieldMask.newBuilder().build()) .build(); Bucket response = storageClient.updateBucket(request); }- Parameters:
request- The request object containing all of the parameters for the API call.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
updateBucketCallable
public final com.google.api.gax.rpc.UnaryCallable<UpdateBucketRequest,Bucket> updateBucketCallable()Updates a bucket. Equivalent to JSON API's storage.buckets.patch method.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { UpdateBucketRequest request = UpdateBucketRequest.newBuilder() .setBucket(Bucket.newBuilder().build()) .setIfMetagenerationMatch(1043427781) .setIfMetagenerationNotMatch(1025430873) .setPredefinedAcl("predefinedAcl1207041188") .setPredefinedDefaultObjectAcl("predefinedDefaultObjectAcl2109168048") .setUpdateMask(FieldMask.newBuilder().build()) .build(); ApiFuture<Bucket> future = storageClient.updateBucketCallable().futureCall(request); // Do something. Bucket response = future.get(); } -
composeObject
Concatenates a list of existing objects into a new object in the same bucket.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { ComposeObjectRequest request = ComposeObjectRequest.newBuilder() .setDestination(Object.newBuilder().build()) .addAllSourceObjects(new ArrayList<ComposeObjectRequest.SourceObject>()) .setDestinationPredefinedAcl("destinationPredefinedAcl1111125814") .setIfGenerationMatch(-1086241088) .setIfMetagenerationMatch(1043427781) .setKmsKey( CryptoKeyName.of("[PROJECT]", "[LOCATION]", "[KEY_RING]", "[CRYPTO_KEY]") .toString()) .setCommonObjectRequestParams(CommonObjectRequestParams.newBuilder().build()) .setObjectChecksums(ObjectChecksums.newBuilder().build()) .build(); Object response = storageClient.composeObject(request); }- Parameters:
request- The request object containing all of the parameters for the API call.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
composeObjectCallable
public final com.google.api.gax.rpc.UnaryCallable<ComposeObjectRequest,Object> composeObjectCallable()Concatenates a list of existing objects into a new object in the same bucket.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { ComposeObjectRequest request = ComposeObjectRequest.newBuilder() .setDestination(Object.newBuilder().build()) .addAllSourceObjects(new ArrayList<ComposeObjectRequest.SourceObject>()) .setDestinationPredefinedAcl("destinationPredefinedAcl1111125814") .setIfGenerationMatch(-1086241088) .setIfMetagenerationMatch(1043427781) .setKmsKey( CryptoKeyName.of("[PROJECT]", "[LOCATION]", "[KEY_RING]", "[CRYPTO_KEY]") .toString()) .setCommonObjectRequestParams(CommonObjectRequestParams.newBuilder().build()) .setObjectChecksums(ObjectChecksums.newBuilder().build()) .build(); ApiFuture<Object> future = storageClient.composeObjectCallable().futureCall(request); // Do something. Object response = future.get(); } -
deleteObject
Deletes an object and its metadata. Deletions are permanent if versioning is not enabled for the bucket, or if the generation parameter is used, or if [soft delete](https://cloud.google.com/storage/docs/soft-delete) is not enabled for the bucket. When this API is used to delete an object from a bucket that has soft delete policy enabled, the object becomes soft deleted, and the `softDeleteTime` and `hardDeleteTime` properties are set on the object. This API cannot be used to permanently delete soft-deleted objects. Soft-deleted objects are permanently deleted according to their `hardDeleteTime`.You can use the [`RestoreObject`][google.storage.v2.Storage.RestoreObject] API to restore soft-deleted objects until the soft delete retention period has passed.
**IAM Permissions**:
Requires `storage.objects.delete` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) on the bucket.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { BucketName bucket = BucketName.of("[PROJECT]", "[BUCKET]"); String object = "object-1023368385"; storageClient.deleteObject(bucket, object); }- Parameters:
bucket- Required. Name of the bucket in which the object resides.object- Required. The name of the finalized object to delete. Note: If you want to delete an unfinalized resumable upload please use `CancelResumableWrite`.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
deleteObject
Deletes an object and its metadata. Deletions are permanent if versioning is not enabled for the bucket, or if the generation parameter is used, or if [soft delete](https://cloud.google.com/storage/docs/soft-delete) is not enabled for the bucket. When this API is used to delete an object from a bucket that has soft delete policy enabled, the object becomes soft deleted, and the `softDeleteTime` and `hardDeleteTime` properties are set on the object. This API cannot be used to permanently delete soft-deleted objects. Soft-deleted objects are permanently deleted according to their `hardDeleteTime`.You can use the [`RestoreObject`][google.storage.v2.Storage.RestoreObject] API to restore soft-deleted objects until the soft delete retention period has passed.
**IAM Permissions**:
Requires `storage.objects.delete` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) on the bucket.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { String bucket = BucketName.of("[PROJECT]", "[BUCKET]").toString(); String object = "object-1023368385"; storageClient.deleteObject(bucket, object); }- Parameters:
bucket- Required. Name of the bucket in which the object resides.object- Required. The name of the finalized object to delete. Note: If you want to delete an unfinalized resumable upload please use `CancelResumableWrite`.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
deleteObject
Deletes an object and its metadata. Deletions are permanent if versioning is not enabled for the bucket, or if the generation parameter is used, or if [soft delete](https://cloud.google.com/storage/docs/soft-delete) is not enabled for the bucket. When this API is used to delete an object from a bucket that has soft delete policy enabled, the object becomes soft deleted, and the `softDeleteTime` and `hardDeleteTime` properties are set on the object. This API cannot be used to permanently delete soft-deleted objects. Soft-deleted objects are permanently deleted according to their `hardDeleteTime`.You can use the [`RestoreObject`][google.storage.v2.Storage.RestoreObject] API to restore soft-deleted objects until the soft delete retention period has passed.
**IAM Permissions**:
Requires `storage.objects.delete` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) on the bucket.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { BucketName bucket = BucketName.of("[PROJECT]", "[BUCKET]"); String object = "object-1023368385"; long generation = 305703192; storageClient.deleteObject(bucket, object, generation); }- Parameters:
bucket- Required. Name of the bucket in which the object resides.object- Required. The name of the finalized object to delete. Note: If you want to delete an unfinalized resumable upload please use `CancelResumableWrite`.generation- If present, permanently deletes a specific revision of this object (as opposed to the latest version, the default).- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
deleteObject
Deletes an object and its metadata. Deletions are permanent if versioning is not enabled for the bucket, or if the generation parameter is used, or if [soft delete](https://cloud.google.com/storage/docs/soft-delete) is not enabled for the bucket. When this API is used to delete an object from a bucket that has soft delete policy enabled, the object becomes soft deleted, and the `softDeleteTime` and `hardDeleteTime` properties are set on the object. This API cannot be used to permanently delete soft-deleted objects. Soft-deleted objects are permanently deleted according to their `hardDeleteTime`.You can use the [`RestoreObject`][google.storage.v2.Storage.RestoreObject] API to restore soft-deleted objects until the soft delete retention period has passed.
**IAM Permissions**:
Requires `storage.objects.delete` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) on the bucket.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { String bucket = BucketName.of("[PROJECT]", "[BUCKET]").toString(); String object = "object-1023368385"; long generation = 305703192; storageClient.deleteObject(bucket, object, generation); }- Parameters:
bucket- Required. Name of the bucket in which the object resides.object- Required. The name of the finalized object to delete. Note: If you want to delete an unfinalized resumable upload please use `CancelResumableWrite`.generation- If present, permanently deletes a specific revision of this object (as opposed to the latest version, the default).- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
deleteObject
Deletes an object and its metadata. Deletions are permanent if versioning is not enabled for the bucket, or if the generation parameter is used, or if [soft delete](https://cloud.google.com/storage/docs/soft-delete) is not enabled for the bucket. When this API is used to delete an object from a bucket that has soft delete policy enabled, the object becomes soft deleted, and the `softDeleteTime` and `hardDeleteTime` properties are set on the object. This API cannot be used to permanently delete soft-deleted objects. Soft-deleted objects are permanently deleted according to their `hardDeleteTime`.You can use the [`RestoreObject`][google.storage.v2.Storage.RestoreObject] API to restore soft-deleted objects until the soft delete retention period has passed.
**IAM Permissions**:
Requires `storage.objects.delete` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) on the bucket.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { DeleteObjectRequest request = DeleteObjectRequest.newBuilder() .setBucket(BucketName.of("[PROJECT]", "[BUCKET]").toString()) .setObject("object-1023368385") .setGeneration(305703192) .setIfGenerationMatch(-1086241088) .setIfGenerationNotMatch(1475720404) .setIfMetagenerationMatch(1043427781) .setIfMetagenerationNotMatch(1025430873) .setCommonObjectRequestParams(CommonObjectRequestParams.newBuilder().build()) .build(); storageClient.deleteObject(request); }- Parameters:
request- The request object containing all of the parameters for the API call.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
deleteObjectCallable
public final com.google.api.gax.rpc.UnaryCallable<DeleteObjectRequest,com.google.protobuf.Empty> deleteObjectCallable()Deletes an object and its metadata. Deletions are permanent if versioning is not enabled for the bucket, or if the generation parameter is used, or if [soft delete](https://cloud.google.com/storage/docs/soft-delete) is not enabled for the bucket. When this API is used to delete an object from a bucket that has soft delete policy enabled, the object becomes soft deleted, and the `softDeleteTime` and `hardDeleteTime` properties are set on the object. This API cannot be used to permanently delete soft-deleted objects. Soft-deleted objects are permanently deleted according to their `hardDeleteTime`.You can use the [`RestoreObject`][google.storage.v2.Storage.RestoreObject] API to restore soft-deleted objects until the soft delete retention period has passed.
**IAM Permissions**:
Requires `storage.objects.delete` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) on the bucket.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { DeleteObjectRequest request = DeleteObjectRequest.newBuilder() .setBucket(BucketName.of("[PROJECT]", "[BUCKET]").toString()) .setObject("object-1023368385") .setGeneration(305703192) .setIfGenerationMatch(-1086241088) .setIfGenerationNotMatch(1475720404) .setIfMetagenerationMatch(1043427781) .setIfMetagenerationNotMatch(1025430873) .setCommonObjectRequestParams(CommonObjectRequestParams.newBuilder().build()) .build(); ApiFuture<Empty> future = storageClient.deleteObjectCallable().futureCall(request); // Do something. future.get(); } -
restoreObject
Restores a soft-deleted object.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { BucketName bucket = BucketName.of("[PROJECT]", "[BUCKET]"); String object = "object-1023368385"; long generation = 305703192; Object response = storageClient.restoreObject(bucket, object, generation); }- Parameters:
bucket- Required. Name of the bucket in which the object resides.object- Required. The name of the object to restore.generation- Required. The specific revision of the object to restore.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
restoreObject
Restores a soft-deleted object.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { String bucket = BucketName.of("[PROJECT]", "[BUCKET]").toString(); String object = "object-1023368385"; long generation = 305703192; Object response = storageClient.restoreObject(bucket, object, generation); }- Parameters:
bucket- Required. Name of the bucket in which the object resides.object- Required. The name of the object to restore.generation- Required. The specific revision of the object to restore.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
restoreObject
Restores a soft-deleted object.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { RestoreObjectRequest request = RestoreObjectRequest.newBuilder() .setBucket(BucketName.of("[PROJECT]", "[BUCKET]").toString()) .setObject("object-1023368385") .setGeneration(305703192) .setRestoreToken("restoreToken1638686731") .setIfGenerationMatch(-1086241088) .setIfGenerationNotMatch(1475720404) .setIfMetagenerationMatch(1043427781) .setIfMetagenerationNotMatch(1025430873) .setCopySourceAcl(true) .setCommonObjectRequestParams(CommonObjectRequestParams.newBuilder().build()) .build(); Object response = storageClient.restoreObject(request); }- Parameters:
request- The request object containing all of the parameters for the API call.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
restoreObjectCallable
public final com.google.api.gax.rpc.UnaryCallable<RestoreObjectRequest,Object> restoreObjectCallable()Restores a soft-deleted object.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { RestoreObjectRequest request = RestoreObjectRequest.newBuilder() .setBucket(BucketName.of("[PROJECT]", "[BUCKET]").toString()) .setObject("object-1023368385") .setGeneration(305703192) .setRestoreToken("restoreToken1638686731") .setIfGenerationMatch(-1086241088) .setIfGenerationNotMatch(1475720404) .setIfMetagenerationMatch(1043427781) .setIfMetagenerationNotMatch(1025430873) .setCopySourceAcl(true) .setCommonObjectRequestParams(CommonObjectRequestParams.newBuilder().build()) .build(); ApiFuture<Object> future = storageClient.restoreObjectCallable().futureCall(request); // Do something. Object response = future.get(); } -
cancelResumableWrite
Cancels an in-progress resumable upload.Any attempts to write to the resumable upload after cancelling the upload will fail.
The behavior for currently in progress write operations is not guaranteed - they could either complete before the cancellation or fail if the cancellation completes first.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { String uploadId = "uploadId1563990780"; CancelResumableWriteResponse response = storageClient.cancelResumableWrite(uploadId); }- Parameters:
uploadId- Required. The upload_id of the resumable upload to cancel. This should be copied from the `upload_id` field of `StartResumableWriteResponse`.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
cancelResumableWrite
Cancels an in-progress resumable upload.Any attempts to write to the resumable upload after cancelling the upload will fail.
The behavior for currently in progress write operations is not guaranteed - they could either complete before the cancellation or fail if the cancellation completes first.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { CancelResumableWriteRequest request = CancelResumableWriteRequest.newBuilder().setUploadId("uploadId1563990780").build(); CancelResumableWriteResponse response = storageClient.cancelResumableWrite(request); }- Parameters:
request- The request object containing all of the parameters for the API call.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
cancelResumableWriteCallable
public final com.google.api.gax.rpc.UnaryCallable<CancelResumableWriteRequest,CancelResumableWriteResponse> cancelResumableWriteCallable()Cancels an in-progress resumable upload.Any attempts to write to the resumable upload after cancelling the upload will fail.
The behavior for currently in progress write operations is not guaranteed - they could either complete before the cancellation or fail if the cancellation completes first.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { CancelResumableWriteRequest request = CancelResumableWriteRequest.newBuilder().setUploadId("uploadId1563990780").build(); ApiFuture<CancelResumableWriteResponse> future = storageClient.cancelResumableWriteCallable().futureCall(request); // Do something. CancelResumableWriteResponse response = future.get(); } -
getObject
Retrieves object metadata.**IAM Permissions**:
Requires `storage.objects.get` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) on the bucket. To return object ACLs, the authenticated user must also have the `storage.objects.getIamPolicy` permission.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { BucketName bucket = BucketName.of("[PROJECT]", "[BUCKET]"); String object = "object-1023368385"; Object response = storageClient.getObject(bucket, object); }- Parameters:
bucket- Required. Name of the bucket in which the object resides.object- Required. Name of the object.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
getObject
Retrieves object metadata.**IAM Permissions**:
Requires `storage.objects.get` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) on the bucket. To return object ACLs, the authenticated user must also have the `storage.objects.getIamPolicy` permission.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { String bucket = BucketName.of("[PROJECT]", "[BUCKET]").toString(); String object = "object-1023368385"; Object response = storageClient.getObject(bucket, object); }- Parameters:
bucket- Required. Name of the bucket in which the object resides.object- Required. Name of the object.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
getObject
Retrieves object metadata.**IAM Permissions**:
Requires `storage.objects.get` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) on the bucket. To return object ACLs, the authenticated user must also have the `storage.objects.getIamPolicy` permission.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { BucketName bucket = BucketName.of("[PROJECT]", "[BUCKET]"); String object = "object-1023368385"; long generation = 305703192; Object response = storageClient.getObject(bucket, object, generation); }- Parameters:
bucket- Required. Name of the bucket in which the object resides.object- Required. Name of the object.generation- If present, selects a specific revision of this object (as opposed to the latest version, the default).- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
getObject
Retrieves object metadata.**IAM Permissions**:
Requires `storage.objects.get` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) on the bucket. To return object ACLs, the authenticated user must also have the `storage.objects.getIamPolicy` permission.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { String bucket = BucketName.of("[PROJECT]", "[BUCKET]").toString(); String object = "object-1023368385"; long generation = 305703192; Object response = storageClient.getObject(bucket, object, generation); }- Parameters:
bucket- Required. Name of the bucket in which the object resides.object- Required. Name of the object.generation- If present, selects a specific revision of this object (as opposed to the latest version, the default).- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
getObject
Retrieves object metadata.**IAM Permissions**:
Requires `storage.objects.get` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) on the bucket. To return object ACLs, the authenticated user must also have the `storage.objects.getIamPolicy` permission.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { GetObjectRequest request = GetObjectRequest.newBuilder() .setBucket(BucketName.of("[PROJECT]", "[BUCKET]").toString()) .setObject("object-1023368385") .setGeneration(305703192) .setSoftDeleted(true) .setIfGenerationMatch(-1086241088) .setIfGenerationNotMatch(1475720404) .setIfMetagenerationMatch(1043427781) .setIfMetagenerationNotMatch(1025430873) .setCommonObjectRequestParams(CommonObjectRequestParams.newBuilder().build()) .setReadMask(FieldMask.newBuilder().build()) .setRestoreToken("restoreToken1638686731") .build(); Object response = storageClient.getObject(request); }- Parameters:
request- The request object containing all of the parameters for the API call.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
getObjectCallable
Retrieves object metadata.**IAM Permissions**:
Requires `storage.objects.get` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) on the bucket. To return object ACLs, the authenticated user must also have the `storage.objects.getIamPolicy` permission.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { GetObjectRequest request = GetObjectRequest.newBuilder() .setBucket(BucketName.of("[PROJECT]", "[BUCKET]").toString()) .setObject("object-1023368385") .setGeneration(305703192) .setSoftDeleted(true) .setIfGenerationMatch(-1086241088) .setIfGenerationNotMatch(1475720404) .setIfMetagenerationMatch(1043427781) .setIfMetagenerationNotMatch(1025430873) .setCommonObjectRequestParams(CommonObjectRequestParams.newBuilder().build()) .setReadMask(FieldMask.newBuilder().build()) .setRestoreToken("restoreToken1638686731") .build(); ApiFuture<Object> future = storageClient.getObjectCallable().futureCall(request); // Do something. Object response = future.get(); } -
readObjectCallable
public final com.google.api.gax.rpc.ServerStreamingCallable<ReadObjectRequest,ReadObjectResponse> readObjectCallable()Retrieves object data.**IAM Permissions**:
Requires `storage.objects.get` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) on the bucket.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { ReadObjectRequest request = ReadObjectRequest.newBuilder() .setBucket(BucketName.of("[PROJECT]", "[BUCKET]").toString()) .setObject("object-1023368385") .setGeneration(305703192) .setReadOffset(-715377828) .setReadLimit(-164298798) .setIfGenerationMatch(-1086241088) .setIfGenerationNotMatch(1475720404) .setIfMetagenerationMatch(1043427781) .setIfMetagenerationNotMatch(1025430873) .setCommonObjectRequestParams(CommonObjectRequestParams.newBuilder().build()) .setReadMask(FieldMask.newBuilder().build()) .build(); ServerStream<ReadObjectResponse> stream = storageClient.readObjectCallable().call(request); for (ReadObjectResponse response : stream) { // Do something when a response is received. } } -
bidiReadObjectCallable
public final com.google.api.gax.rpc.BidiStreamingCallable<BidiReadObjectRequest,BidiReadObjectResponse> bidiReadObjectCallable()Reads an object's data.This is a bi-directional API with the added support for reading multiple ranges within one stream both within and across multiple messages. If the server encountered an error for any of the inputs, the stream will be closed with the relevant error code. Because the API allows for multiple outstanding requests, when the stream is closed the error response will contain a BidiReadObjectRangesError proto in the error extension describing the error for each outstanding read_id.
**IAM Permissions**:
Requires `storage.objects.get`
[IAM permission](https://cloud.google.com/iam/docs/overview#permissions) on the bucket.
This API is currently in preview and is not yet available for general use.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { BidiStream<BidiReadObjectRequest, BidiReadObjectResponse> bidiStream = storageClient.bidiReadObjectCallable().call(); BidiReadObjectRequest request = BidiReadObjectRequest.newBuilder() .setReadObjectSpec(BidiReadObjectSpec.newBuilder().build()) .addAllReadRanges(new ArrayList<ReadRange>()) .build(); bidiStream.send(request); for (BidiReadObjectResponse response : bidiStream) { // Do something when a response is received. } } -
updateObject
Updates an object's metadata. Equivalent to JSON API's storage.objects.patch.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { Object object = Object.newBuilder().build(); FieldMask updateMask = FieldMask.newBuilder().build(); Object response = storageClient.updateObject(object, updateMask); }- Parameters:
object- Required. The object to update. The object's bucket and name fields are used to identify the object to update. If present, the object's generation field selects a specific revision of this object whose metadata should be updated. Otherwise, assumes the live version of the object.updateMask- Required. List of fields to be updated.To specify ALL fields, equivalent to the JSON API's "update" function, specify a single field with the value `*`. Note: not recommended. If a new field is introduced at a later time, an older client updating with the `*` may accidentally reset the new field's value.
Not specifying any fields is an error.
- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
updateObject
Updates an object's metadata. Equivalent to JSON API's storage.objects.patch.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { UpdateObjectRequest request = UpdateObjectRequest.newBuilder() .setObject(Object.newBuilder().build()) .setIfGenerationMatch(-1086241088) .setIfGenerationNotMatch(1475720404) .setIfMetagenerationMatch(1043427781) .setIfMetagenerationNotMatch(1025430873) .setPredefinedAcl("predefinedAcl1207041188") .setUpdateMask(FieldMask.newBuilder().build()) .setCommonObjectRequestParams(CommonObjectRequestParams.newBuilder().build()) .build(); Object response = storageClient.updateObject(request); }- Parameters:
request- The request object containing all of the parameters for the API call.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
updateObjectCallable
public final com.google.api.gax.rpc.UnaryCallable<UpdateObjectRequest,Object> updateObjectCallable()Updates an object's metadata. Equivalent to JSON API's storage.objects.patch.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { UpdateObjectRequest request = UpdateObjectRequest.newBuilder() .setObject(Object.newBuilder().build()) .setIfGenerationMatch(-1086241088) .setIfGenerationNotMatch(1475720404) .setIfMetagenerationMatch(1043427781) .setIfMetagenerationNotMatch(1025430873) .setPredefinedAcl("predefinedAcl1207041188") .setUpdateMask(FieldMask.newBuilder().build()) .setCommonObjectRequestParams(CommonObjectRequestParams.newBuilder().build()) .build(); ApiFuture<Object> future = storageClient.updateObjectCallable().futureCall(request); // Do something. Object response = future.get(); } -
writeObjectCallable
public final com.google.api.gax.rpc.ClientStreamingCallable<WriteObjectRequest,WriteObjectResponse> writeObjectCallable()Stores a new object and metadata.An object can be written either in a single message stream or in a resumable sequence of message streams. To write using a single stream, the client should include in the first message of the stream an `WriteObjectSpec` describing the destination bucket, object, and any preconditions. Additionally, the final message must set 'finish_write' to true, or else it is an error.
For a resumable write, the client should instead call `StartResumableWrite()`, populating a `WriteObjectSpec` into that request. They should then attach the returned `upload_id` to the first message of each following call to `WriteObject`. If the stream is closed before finishing the upload (either explicitly by the client or due to a network error or an error response from the server), the client should do as follows: - Check the result Status of the stream, to determine if writing can be resumed on this stream or must be restarted from scratch (by calling `StartResumableWrite()`). The resumable errors are DEADLINE_EXCEEDED, INTERNAL, and UNAVAILABLE. For each case, the client should use binary exponential backoff before retrying. Additionally, writes can be resumed after RESOURCE_EXHAUSTED errors, but only after taking appropriate measures, which may include reducing aggregate send rate across clients and/or requesting a quota increase for your project. - If the call to `WriteObject` returns `ABORTED`, that indicates concurrent attempts to update the resumable write, caused either by multiple racing clients or by a single client where the previous request was timed out on the client side but nonetheless reached the server. In this case the client should take steps to prevent further concurrent writes (e.g., increase the timeouts, stop using more than one process to perform the upload, etc.), and then should follow the steps below for resuming the upload. - For resumable errors, the client should call `QueryWriteStatus()` and then continue writing from the returned `persisted_size`. This may be less than the amount of data the client previously sent. Note also that it is acceptable to send data starting at an offset earlier than the returned `persisted_size`; in this case, the service will skip data at offsets that were already persisted (without checking that it matches the previously written data), and write only the data starting from the persisted offset. Even though the data isn't written, it may still incur a performance cost over resuming at the correct write offset. This behavior can make client-side handling simpler in some cases. - Clients must only send data that is a multiple of 256 KiB per message, unless the object is being finished with `finish_write` set to `true`.
The service will not view the object as complete until the client has sent a `WriteObjectRequest` with `finish_write` set to `true`. Sending any requests on a stream after sending a request with `finish_write` set to `true` will cause an error. The client **should** check the response it receives to determine how much data the service was able to commit and whether the service views the object as complete.
Attempting to resume an already finalized object will result in an OK status, with a `WriteObjectResponse` containing the finalized object's metadata.
Alternatively, the BidiWriteObject operation may be used to write an object with controls over flushing and the ability to fetch the ability to determine the current persisted size.
**IAM Permissions**:
Requires `storage.objects.create` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) on the bucket.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { ApiStreamObserver<WriteObjectRequest> responseObserver = new ApiStreamObserver<WriteObjectRequest>() { {@literal @}Override public void onNext(WriteObjectResponse response) { // Do something when a response is received. } {@literal @}Override public void onError(Throwable t) { // Add error-handling } {@literal @}Override public void onCompleted() { // Do something when complete. } }; ApiStreamObserver<WriteObjectRequest> requestObserver = storageClient.writeObject().clientStreamingCall(responseObserver); WriteObjectRequest request = WriteObjectRequest.newBuilder() .setWriteOffset(-1559543565) .setObjectChecksums(ObjectChecksums.newBuilder().build()) .setFinishWrite(true) .setCommonObjectRequestParams(CommonObjectRequestParams.newBuilder().build()) .build(); requestObserver.onNext(request); } -
bidiWriteObjectCallable
public final com.google.api.gax.rpc.BidiStreamingCallable<BidiWriteObjectRequest,BidiWriteObjectResponse> bidiWriteObjectCallable()Stores a new object and metadata.This is similar to the WriteObject call with the added support for manual flushing of persisted state, and the ability to determine current persisted size without closing the stream.
The client may specify one or both of the `state_lookup` and `flush` fields in each BidiWriteObjectRequest. If `flush` is specified, the data written so far will be persisted to storage. If `state_lookup` is specified, the service will respond with a BidiWriteObjectResponse that contains the persisted size. If both `flush` and `state_lookup` are specified, the flush will always occur before a `state_lookup`, so that both may be set in the same request and the returned state will be the state of the object post-flush. When the stream is closed, a BidiWriteObjectResponse will always be sent to the client, regardless of the value of `state_lookup`.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { BidiStream<BidiWriteObjectRequest, BidiWriteObjectResponse> bidiStream = storageClient.bidiWriteObjectCallable().call(); BidiWriteObjectRequest request = BidiWriteObjectRequest.newBuilder() .setWriteOffset(-1559543565) .setObjectChecksums(ObjectChecksums.newBuilder().build()) .setStateLookup(true) .setFlush(true) .setFinishWrite(true) .setCommonObjectRequestParams(CommonObjectRequestParams.newBuilder().build()) .build(); bidiStream.send(request); for (BidiWriteObjectResponse response : bidiStream) { // Do something when a response is received. } } -
listObjects
Retrieves a list of objects matching the criteria.**IAM Permissions**:
The authenticated user requires `storage.objects.list` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) to use this method. To return object ACLs, the authenticated user must also have the `storage.objects.getIamPolicy` permission.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { BucketName parent = BucketName.of("[PROJECT]", "[BUCKET]"); for (Object element : storageClient.listObjects(parent).iterateAll()) { // doThingsWith(element); } }- Parameters:
parent- Required. Name of the bucket in which to look for objects.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
listObjects
Retrieves a list of objects matching the criteria.**IAM Permissions**:
The authenticated user requires `storage.objects.list` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) to use this method. To return object ACLs, the authenticated user must also have the `storage.objects.getIamPolicy` permission.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { String parent = BucketName.of("[PROJECT]", "[BUCKET]").toString(); for (Object element : storageClient.listObjects(parent).iterateAll()) { // doThingsWith(element); } }- Parameters:
parent- Required. Name of the bucket in which to look for objects.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
listObjects
Retrieves a list of objects matching the criteria.**IAM Permissions**:
The authenticated user requires `storage.objects.list` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) to use this method. To return object ACLs, the authenticated user must also have the `storage.objects.getIamPolicy` permission.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { ListObjectsRequest request = ListObjectsRequest.newBuilder() .setParent(BucketName.of("[PROJECT]", "[BUCKET]").toString()) .setPageSize(883849137) .setPageToken("pageToken873572522") .setDelimiter("delimiter-250518009") .setIncludeTrailingDelimiter(true) .setPrefix("prefix-980110702") .setVersions(true) .setReadMask(FieldMask.newBuilder().build()) .setLexicographicStart("lexicographicStart-2093413008") .setLexicographicEnd("lexicographicEnd1646968169") .setSoftDeleted(true) .setIncludeFoldersAsPrefixes(true) .setMatchGlob("matchGlob613636317") .build(); for (Object element : storageClient.listObjects(request).iterateAll()) { // doThingsWith(element); } }- Parameters:
request- The request object containing all of the parameters for the API call.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
listObjectsPagedCallable
public final com.google.api.gax.rpc.UnaryCallable<ListObjectsRequest,StorageClient.ListObjectsPagedResponse> listObjectsPagedCallable()Retrieves a list of objects matching the criteria.**IAM Permissions**:
The authenticated user requires `storage.objects.list` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) to use this method. To return object ACLs, the authenticated user must also have the `storage.objects.getIamPolicy` permission.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { ListObjectsRequest request = ListObjectsRequest.newBuilder() .setParent(BucketName.of("[PROJECT]", "[BUCKET]").toString()) .setPageSize(883849137) .setPageToken("pageToken873572522") .setDelimiter("delimiter-250518009") .setIncludeTrailingDelimiter(true) .setPrefix("prefix-980110702") .setVersions(true) .setReadMask(FieldMask.newBuilder().build()) .setLexicographicStart("lexicographicStart-2093413008") .setLexicographicEnd("lexicographicEnd1646968169") .setSoftDeleted(true) .setIncludeFoldersAsPrefixes(true) .setMatchGlob("matchGlob613636317") .build(); ApiFuture<Object> future = storageClient.listObjectsPagedCallable().futureCall(request); // Do something. for (Object element : future.get().iterateAll()) { // doThingsWith(element); } } -
listObjectsCallable
public final com.google.api.gax.rpc.UnaryCallable<ListObjectsRequest,ListObjectsResponse> listObjectsCallable()Retrieves a list of objects matching the criteria.**IAM Permissions**:
The authenticated user requires `storage.objects.list` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) to use this method. To return object ACLs, the authenticated user must also have the `storage.objects.getIamPolicy` permission.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { ListObjectsRequest request = ListObjectsRequest.newBuilder() .setParent(BucketName.of("[PROJECT]", "[BUCKET]").toString()) .setPageSize(883849137) .setPageToken("pageToken873572522") .setDelimiter("delimiter-250518009") .setIncludeTrailingDelimiter(true) .setPrefix("prefix-980110702") .setVersions(true) .setReadMask(FieldMask.newBuilder().build()) .setLexicographicStart("lexicographicStart-2093413008") .setLexicographicEnd("lexicographicEnd1646968169") .setSoftDeleted(true) .setIncludeFoldersAsPrefixes(true) .setMatchGlob("matchGlob613636317") .build(); while (true) { ListObjectsResponse response = storageClient.listObjectsCallable().call(request); for (Object element : response.getObjectsList()) { // doThingsWith(element); } String nextPageToken = response.getNextPageToken(); if (!Strings.isNullOrEmpty(nextPageToken)) { request = request.toBuilder().setPageToken(nextPageToken).build(); } else { break; } } } -
rewriteObject
Rewrites a source object to a destination object. Optionally overrides metadata.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { RewriteObjectRequest request = RewriteObjectRequest.newBuilder() .setDestinationName("destinationName-1762755655") .setDestinationBucket(BucketName.of("[PROJECT]", "[BUCKET]").toString()) .setDestinationKmsKey( CryptoKeyName.of("[PROJECT]", "[LOCATION]", "[KEY_RING]", "[CRYPTO_KEY]") .toString()) .setDestination(Object.newBuilder().build()) .setSourceBucket(BucketName.of("[PROJECT]", "[BUCKET]").toString()) .setSourceObject("sourceObject1196439354") .setSourceGeneration(1232209852) .setRewriteToken("rewriteToken80654285") .setDestinationPredefinedAcl("destinationPredefinedAcl1111125814") .setIfGenerationMatch(-1086241088) .setIfGenerationNotMatch(1475720404) .setIfMetagenerationMatch(1043427781) .setIfMetagenerationNotMatch(1025430873) .setIfSourceGenerationMatch(-1427877280) .setIfSourceGenerationNotMatch(1575612532) .setIfSourceMetagenerationMatch(1143319909) .setIfSourceMetagenerationNotMatch(1900822777) .setMaxBytesRewrittenPerCall(1178170730) .setCopySourceEncryptionAlgorithm("copySourceEncryptionAlgorithm-1524952548") .setCopySourceEncryptionKeyBytes(ByteString.EMPTY) .setCopySourceEncryptionKeySha256Bytes(ByteString.EMPTY) .setCommonObjectRequestParams(CommonObjectRequestParams.newBuilder().build()) .setObjectChecksums(ObjectChecksums.newBuilder().build()) .build(); RewriteResponse response = storageClient.rewriteObject(request); }- Parameters:
request- The request object containing all of the parameters for the API call.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
rewriteObjectCallable
public final com.google.api.gax.rpc.UnaryCallable<RewriteObjectRequest,RewriteResponse> rewriteObjectCallable()Rewrites a source object to a destination object. Optionally overrides metadata.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { RewriteObjectRequest request = RewriteObjectRequest.newBuilder() .setDestinationName("destinationName-1762755655") .setDestinationBucket(BucketName.of("[PROJECT]", "[BUCKET]").toString()) .setDestinationKmsKey( CryptoKeyName.of("[PROJECT]", "[LOCATION]", "[KEY_RING]", "[CRYPTO_KEY]") .toString()) .setDestination(Object.newBuilder().build()) .setSourceBucket(BucketName.of("[PROJECT]", "[BUCKET]").toString()) .setSourceObject("sourceObject1196439354") .setSourceGeneration(1232209852) .setRewriteToken("rewriteToken80654285") .setDestinationPredefinedAcl("destinationPredefinedAcl1111125814") .setIfGenerationMatch(-1086241088) .setIfGenerationNotMatch(1475720404) .setIfMetagenerationMatch(1043427781) .setIfMetagenerationNotMatch(1025430873) .setIfSourceGenerationMatch(-1427877280) .setIfSourceGenerationNotMatch(1575612532) .setIfSourceMetagenerationMatch(1143319909) .setIfSourceMetagenerationNotMatch(1900822777) .setMaxBytesRewrittenPerCall(1178170730) .setCopySourceEncryptionAlgorithm("copySourceEncryptionAlgorithm-1524952548") .setCopySourceEncryptionKeyBytes(ByteString.EMPTY) .setCopySourceEncryptionKeySha256Bytes(ByteString.EMPTY) .setCommonObjectRequestParams(CommonObjectRequestParams.newBuilder().build()) .setObjectChecksums(ObjectChecksums.newBuilder().build()) .build(); ApiFuture<RewriteResponse> future = storageClient.rewriteObjectCallable().futureCall(request); // Do something. RewriteResponse response = future.get(); } -
startResumableWrite
Starts a resumable write operation. This method is part of the [Resumable upload](https://cloud.google.com/storage/docs/resumable-uploads) feature. This allows you to upload large objects in multiple chunks, which is more resilient to network interruptions than a single upload. The validity duration of the write operation, and the consequences of it becoming invalid, are service-dependent.**IAM Permissions**:
Requires `storage.objects.create` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) on the bucket.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { StartResumableWriteRequest request = StartResumableWriteRequest.newBuilder() .setWriteObjectSpec(WriteObjectSpec.newBuilder().build()) .setCommonObjectRequestParams(CommonObjectRequestParams.newBuilder().build()) .setObjectChecksums(ObjectChecksums.newBuilder().build()) .build(); StartResumableWriteResponse response = storageClient.startResumableWrite(request); }- Parameters:
request- The request object containing all of the parameters for the API call.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
startResumableWriteCallable
public final com.google.api.gax.rpc.UnaryCallable<StartResumableWriteRequest,StartResumableWriteResponse> startResumableWriteCallable()Starts a resumable write operation. This method is part of the [Resumable upload](https://cloud.google.com/storage/docs/resumable-uploads) feature. This allows you to upload large objects in multiple chunks, which is more resilient to network interruptions than a single upload. The validity duration of the write operation, and the consequences of it becoming invalid, are service-dependent.**IAM Permissions**:
Requires `storage.objects.create` [IAM permission](https://cloud.google.com/iam/docs/overview#permissions) on the bucket.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { StartResumableWriteRequest request = StartResumableWriteRequest.newBuilder() .setWriteObjectSpec(WriteObjectSpec.newBuilder().build()) .setCommonObjectRequestParams(CommonObjectRequestParams.newBuilder().build()) .setObjectChecksums(ObjectChecksums.newBuilder().build()) .build(); ApiFuture<StartResumableWriteResponse> future = storageClient.startResumableWriteCallable().futureCall(request); // Do something. StartResumableWriteResponse response = future.get(); } -
queryWriteStatus
Determines the `persisted_size` of an object that is being written. This method is part of the [resumable upload](https://cloud.google.com/storage/docs/resumable-uploads) feature. The returned value is the size of the object that has been persisted so far. The value can be used as the `write_offset` for the next `Write()` call.If the object does not exist, meaning if it was deleted, or the first `Write()` has not yet reached the service, this method returns the error `NOT_FOUND`.
This method is useful for clients that buffer data and need to know which data can be safely evicted. The client can call `QueryWriteStatus()` at any time to determine how much data has been logged for this object. For any sequence of `QueryWriteStatus()` calls for a given object name, the sequence of returned `persisted_size` values are non-decreasing.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { String uploadId = "uploadId1563990780"; QueryWriteStatusResponse response = storageClient.queryWriteStatus(uploadId); }- Parameters:
uploadId- Required. The name of the resume token for the object whose write status is being requested.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
queryWriteStatus
Determines the `persisted_size` of an object that is being written. This method is part of the [resumable upload](https://cloud.google.com/storage/docs/resumable-uploads) feature. The returned value is the size of the object that has been persisted so far. The value can be used as the `write_offset` for the next `Write()` call.If the object does not exist, meaning if it was deleted, or the first `Write()` has not yet reached the service, this method returns the error `NOT_FOUND`.
This method is useful for clients that buffer data and need to know which data can be safely evicted. The client can call `QueryWriteStatus()` at any time to determine how much data has been logged for this object. For any sequence of `QueryWriteStatus()` calls for a given object name, the sequence of returned `persisted_size` values are non-decreasing.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { QueryWriteStatusRequest request = QueryWriteStatusRequest.newBuilder() .setUploadId("uploadId1563990780") .setCommonObjectRequestParams(CommonObjectRequestParams.newBuilder().build()) .build(); QueryWriteStatusResponse response = storageClient.queryWriteStatus(request); }- Parameters:
request- The request object containing all of the parameters for the API call.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
queryWriteStatusCallable
public final com.google.api.gax.rpc.UnaryCallable<QueryWriteStatusRequest,QueryWriteStatusResponse> queryWriteStatusCallable()Determines the `persisted_size` of an object that is being written. This method is part of the [resumable upload](https://cloud.google.com/storage/docs/resumable-uploads) feature. The returned value is the size of the object that has been persisted so far. The value can be used as the `write_offset` for the next `Write()` call.If the object does not exist, meaning if it was deleted, or the first `Write()` has not yet reached the service, this method returns the error `NOT_FOUND`.
This method is useful for clients that buffer data and need to know which data can be safely evicted. The client can call `QueryWriteStatus()` at any time to determine how much data has been logged for this object. For any sequence of `QueryWriteStatus()` calls for a given object name, the sequence of returned `persisted_size` values are non-decreasing.
Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { QueryWriteStatusRequest request = QueryWriteStatusRequest.newBuilder() .setUploadId("uploadId1563990780") .setCommonObjectRequestParams(CommonObjectRequestParams.newBuilder().build()) .build(); ApiFuture<QueryWriteStatusResponse> future = storageClient.queryWriteStatusCallable().futureCall(request); // Do something. QueryWriteStatusResponse response = future.get(); } -
moveObject
Moves the source object to the destination object in the same bucket.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { BucketName bucket = BucketName.of("[PROJECT]", "[BUCKET]"); String sourceObject = "sourceObject1196439354"; String destinationObject = "destinationObject-1761603347"; Object response = storageClient.moveObject(bucket, sourceObject, destinationObject); }- Parameters:
bucket- Required. Name of the bucket in which the object resides.sourceObject- Required. Name of the source object.destinationObject- Required. Name of the destination object.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
moveObject
Moves the source object to the destination object in the same bucket.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { String bucket = BucketName.of("[PROJECT]", "[BUCKET]").toString(); String sourceObject = "sourceObject1196439354"; String destinationObject = "destinationObject-1761603347"; Object response = storageClient.moveObject(bucket, sourceObject, destinationObject); }- Parameters:
bucket- Required. Name of the bucket in which the object resides.sourceObject- Required. Name of the source object.destinationObject- Required. Name of the destination object.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
moveObject
Moves the source object to the destination object in the same bucket.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { MoveObjectRequest request = MoveObjectRequest.newBuilder() .setBucket(BucketName.of("[PROJECT]", "[BUCKET]").toString()) .setSourceObject("sourceObject1196439354") .setDestinationObject("destinationObject-1761603347") .setIfSourceGenerationMatch(-1427877280) .setIfSourceGenerationNotMatch(1575612532) .setIfSourceMetagenerationMatch(1143319909) .setIfSourceMetagenerationNotMatch(1900822777) .setIfGenerationMatch(-1086241088) .setIfGenerationNotMatch(1475720404) .setIfMetagenerationMatch(1043427781) .setIfMetagenerationNotMatch(1025430873) .build(); Object response = storageClient.moveObject(request); }- Parameters:
request- The request object containing all of the parameters for the API call.- Throws:
com.google.api.gax.rpc.ApiException- if the remote call fails
-
moveObjectCallable
Moves the source object to the destination object in the same bucket.Sample code:
// This snippet has been automatically generated and should be regarded as a code template only. // It will require modifications to work: // - It may require correct/in-range values for request initialization. // - It may require specifying regional endpoints when creating the service client as shown in // https://cloud.google.com/java/docs/setup#configure_endpoints_for_the_client_library try (StorageClient storageClient = StorageClient.create()) { MoveObjectRequest request = MoveObjectRequest.newBuilder() .setBucket(BucketName.of("[PROJECT]", "[BUCKET]").toString()) .setSourceObject("sourceObject1196439354") .setDestinationObject("destinationObject-1761603347") .setIfSourceGenerationMatch(-1427877280) .setIfSourceGenerationNotMatch(1575612532) .setIfSourceMetagenerationMatch(1143319909) .setIfSourceMetagenerationNotMatch(1900822777) .setIfGenerationMatch(-1086241088) .setIfGenerationNotMatch(1475720404) .setIfMetagenerationMatch(1043427781) .setIfMetagenerationNotMatch(1025430873) .build(); ApiFuture<Object> future = storageClient.moveObjectCallable().futureCall(request); // Do something. Object response = future.get(); } -
close
public final void close()- Specified by:
closein interfaceAutoCloseable
-
shutdown
public void shutdown()- Specified by:
shutdownin interfacecom.google.api.gax.core.BackgroundResource
-
isShutdown
public boolean isShutdown()- Specified by:
isShutdownin interfacecom.google.api.gax.core.BackgroundResource
-
isTerminated
public boolean isTerminated()- Specified by:
isTerminatedin interfacecom.google.api.gax.core.BackgroundResource
-
shutdownNow
public void shutdownNow()- Specified by:
shutdownNowin interfacecom.google.api.gax.core.BackgroundResource
-
awaitTermination
- Specified by:
awaitTerminationin interfacecom.google.api.gax.core.BackgroundResource- Throws:
InterruptedException
-