public class Bucket extends BucketInfo
Objects of this class are immutable. Operations that modify the bucket like update(com.google.cloud.storage.Storage.BucketTargetOption...)
 return a new object. To get a Bucket object with the most recent information use reload(com.google.cloud.storage.Bucket.BucketSourceOption...). Bucket adds a layer of service-related functionality over BucketInfo.
| Modifier and Type | Class and Description | 
|---|---|
| static class  | Bucket.BlobTargetOptionClass for specifying blob target options when  Bucketmethods are used. | 
| static class  | Bucket.BlobWriteOptionClass for specifying blob write options when  Bucketmethods are used. | 
| static class  | Bucket.BucketSourceOptionClass for specifying bucket source options when  Bucketmethods are used. | 
| static class  | Bucket.BuilderBuilder for  Bucket. | 
BucketInfo.AgeDeleteRule, BucketInfo.CreatedBeforeDeleteRule, BucketInfo.DeleteRule, BucketInfo.IamConfiguration, BucketInfo.IsLiveDeleteRule, BucketInfo.LifecycleRule, BucketInfo.Logging, BucketInfo.NumNewerVersionsDeleteRule| Modifier and Type | Method and Description | 
|---|---|
| Blob | create(String blob,
      byte[] content,
      Bucket.BlobTargetOption... options)Creates a new blob in this bucket. | 
| Blob | create(String blob,
      byte[] content,
      String contentType,
      Bucket.BlobTargetOption... options)Creates a new blob in this bucket. | 
| Blob | create(String blob,
      InputStream content,
      Bucket.BlobWriteOption... options)Creates a new blob in this bucket. | 
| Blob | create(String blob,
      InputStream content,
      String contentType,
      Bucket.BlobWriteOption... options)Creates a new blob in this bucket. | 
| Acl | createAcl(Acl acl)Creates a new ACL entry on this bucket. | 
| Acl | createDefaultAcl(Acl acl)Creates a new default blob ACL entry on this bucket. | 
| boolean | delete(Bucket.BucketSourceOption... options)Deletes this bucket. | 
| boolean | deleteAcl(Acl.Entity entity)Deletes the ACL entry for the specified entity on this bucket. | 
| boolean | deleteDefaultAcl(Acl.Entity entity)Deletes the default object ACL entry for the specified entity on this bucket. | 
| boolean | equals(Object obj) | 
| boolean | exists(Bucket.BucketSourceOption... options)Checks if this bucket exists. | 
| List<Blob> | get(Iterable<String> blobNames)Returns a list of requested blobs in this bucket. | 
| Blob | get(String blob,
   Storage.BlobGetOption... options)Returns the requested blob in this bucket or  nullif not found. | 
| List<Blob> | get(String blobName1,
   String blobName2,
   String... blobNames)Returns a list of requested blobs in this bucket. | 
| Acl | getAcl(Acl.Entity entity)Returns the ACL entry for the specified entity on this bucket or  nullif not found. | 
| Acl | getDefaultAcl(Acl.Entity entity)Returns the default object ACL entry for the specified entity on this bucket or  nullif
 not found. | 
| Storage | getStorage()Returns the bucket's  Storageobject used to issue requests. | 
| int | hashCode() | 
| com.google.api.gax.paging.Page<Blob> | list(Storage.BlobListOption... options)Returns the paginated list of  Blobin this bucket. | 
| List<Acl> | listAcls()Lists the ACL entries for this bucket. | 
| List<Acl> | listDefaultAcls()Lists the default blob ACL entries for this bucket. | 
| Bucket | lockRetentionPolicy(Storage.BucketTargetOption... options)Locks bucket retention policy. | 
| Bucket | reload(Bucket.BucketSourceOption... options)Fetches current bucket's latest information. | 
| Bucket.Builder | toBuilder()Returns a builder for the current bucket. | 
| Bucket | update(Storage.BucketTargetOption... options)Updates the bucket's information. | 
| Acl | updateAcl(Acl acl)Updates an ACL entry on this bucket. | 
| Acl | updateDefaultAcl(Acl acl)Updates a default blob ACL entry on this bucket. | 
getAcl, getCors, getCreateTime, getDefaultAcl, getDefaultEventBasedHold, getDefaultKmsKeyName, getDeleteRules, getEtag, getGeneratedId, getIamConfiguration, getIndexPage, getLabels, getLifecycleRules, getLocation, getLocationType, getLogging, getMetageneration, getName, getNotFoundPage, getOwner, getRetentionEffectiveTime, getRetentionPeriod, getSelfLink, getStorageClass, newBuilder, of, requesterPays, retentionPolicyIsLocked, toString, versioningEnabledpublic boolean exists(Bucket.BucketSourceOption... options)
Example of checking if the bucket exists.
 boolean exists = bucket.exists();
 if (exists) {
   // the bucket exists
 } else {
   // the bucket was not found
 }
 StorageException - upon failurepublic Bucket reload(Bucket.BucketSourceOption... options)
null if the bucket does not exist.
 Example of getting the bucket's latest information, if its generation does not match the
 BucketInfo.getMetageneration() value, otherwise a StorageException is thrown.
 
 Bucket latestBucket = bucket.reload(BucketSourceOption.metagenerationMatch());
 if (latestBucket == null) {
   // the bucket was not found
 }
 options - bucket read optionsBucket object with latest information or null if not foundStorageException - upon failurepublic Bucket update(Storage.BucketTargetOption... options)
Bucket object
 is returned. By default no checks are made on the metadata generation of the current bucket. If
 you want to update the information only if the current bucket metadata are at their latest
 version use the metagenerationMatch option: bucket.update(BucketTargetOption.metagenerationMatch())
 Example of updating the bucket's information.
 Bucket updatedBucket = bucket.toBuilder().setVersioningEnabled(true).build().update();
 options - update optionsBucket object with updated informationStorageException - upon failurepublic boolean delete(Bucket.BucketSourceOption... options)
Example of deleting the bucket, if its metageneration matches the BucketInfo.getMetageneration() value, otherwise a StorageException is thrown.
 
 boolean deleted = bucket.delete(BucketSourceOption.metagenerationMatch());
 if (deleted) {
   // the bucket was deleted
 } else {
   // the bucket was not found
 }
 options - bucket delete optionstrue if bucket was deleted, false if it was not foundStorageException - upon failurepublic com.google.api.gax.paging.Page<Blob> list(Storage.BlobListOption... options)
Blob in this bucket.
 Example of listing the blobs in the bucket.
 Page<Blob> blobs = bucket.list();
 Iterator<Blob> blobIterator = blobs.iterateAll();
 while (blobIterator.hasNext()) {
   Blob blob = blobIterator.next();
   // do something with the blob
 }
 options - options for listing blobsStorageException - upon failurepublic Blob get(String blob, Storage.BlobGetOption... options)
null if not found.
 Example of getting a blob in the bucket, only if its metageneration matches a value,
 otherwise a StorageException is thrown.
 
 String blobName = "my_blob_name";
 long generation = 42;
 Blob blob = bucket.get(blobName, BlobGetOption.generationMatch(generation));
 blob - name of the requested bloboptions - blob search optionsStorageException - upon failurepublic List<Blob> get(String blobName1, String blobName2, String... blobNames)
Example of getting some blobs in the bucket, using a batch request.
 String blobName1 = "my_blob_name1";
 String blobName2 = "my_blob_name2";
 List<Blob> blobs = bucket.get(blobName1, blobName2);
 for (Blob blob : blobs) {
   if (blob == null) {
     // the blob was not found
   }
 }
 blobName1 - first blob to getblobName2 - second blob to getblobNames - other blobs to getBlob objectsStorageException - upon failurepublic List<Blob> get(Iterable<String> blobNames)
Example of getting some blobs in the bucket, using a batch request.
 String blobName1 = "my_blob_name1";
 String blobName2 = "my_blob_name2";
 List<String> blobNames = new LinkedList<>();
 blobNames.add(blobName1);
 blobNames.add(blobName2);
 List<Blob> blobs = bucket.get(blobNames);
 for (Blob blob : blobs) {
   if (blob == null) {
     // the blob was not found
   }
 }
 blobNames - blobs to getBlob objectsStorageException - upon failurepublic Blob create(String blob, byte[] content, String contentType, Bucket.BlobTargetOption... options)
content. For large
 content, Blob.writer(com.google.cloud.storage.Storage.BlobWriteOption...) is
 recommended as it uses resumable upload. MD5 and CRC32C hashes of content are computed
 and used for validating transferred data.
 Example of creating a blob in the bucket from a byte array with a content type.
 String blobName = "my_blob_name";
 Blob blob = bucket.create(blobName, "Hello, World!".getBytes(UTF_8), "text/plain");
 blob - a blob namecontent - the blob contentcontentType - the blob content typeoptions - options for blob creationStorageException - upon failurepublic Blob create(String blob, InputStream content, String contentType, Bucket.BlobWriteOption... options)
content. For large
 content, Blob.writer(com.google.cloud.storage.Storage.BlobWriteOption...) is
 recommended as it uses resumable upload.
 Example of creating a blob in the bucket from an input stream with a content type.
 String blobName = "my_blob_name";
 InputStream content = new ByteArrayInputStream("Hello, World!".getBytes(UTF_8));
 Blob blob = bucket.create(blobName, content, "text/plain");
 blob - a blob namecontent - the blob content as a streamcontentType - the blob content typeoptions - options for blob creationStorageException - upon failurepublic Blob create(String blob, byte[] content, Bucket.BlobTargetOption... options)
content. For large
 content, Blob.writer(com.google.cloud.storage.Storage.BlobWriteOption...) is
 recommended as it uses resumable upload. MD5 and CRC32C hashes of content are computed
 and used for validating transferred data.
 Example of creating a blob in the bucket from a byte array.
 String blobName = "my_blob_name";
 Blob blob = bucket.create(blobName, "Hello, World!".getBytes(UTF_8));
 blob - a blob namecontent - the blob contentoptions - options for blob creationStorageException - upon failurepublic Blob create(String blob, InputStream content, Bucket.BlobWriteOption... options)
content. For large
 content, Blob.writer(com.google.cloud.storage.Storage.BlobWriteOption...) is
 recommended as it uses resumable upload.
 Example of creating a blob in the bucket from an input stream.
 String blobName = "my_blob_name";
 InputStream content = new ByteArrayInputStream("Hello, World!".getBytes(UTF_8));
 Blob blob = bucket.create(blobName, content);
 blob - a blob namecontent - the blob content as a streamoptions - options for blob creationStorageException - upon failurepublic Acl getAcl(Acl.Entity entity)
null if not found.
 Example of getting the ACL entry for an entity.
 Acl acl = bucket.getAcl(User.ofAllAuthenticatedUsers());
 StorageException - upon failurepublic boolean deleteAcl(Acl.Entity entity)
Example of deleting the ACL entry for an entity.
 boolean deleted = bucket.deleteAcl(User.ofAllAuthenticatedUsers());
 if (deleted) {
   // the acl entry was deleted
 } else {
   // the acl entry was not found
 }
 true if the ACL was deleted, false if it was not foundStorageException - upon failurepublic Acl createAcl(Acl acl)
Example of creating a new ACL entry.
 Acl acl = bucket.createAcl(Acl.of(User.ofAllAuthenticatedUsers(), Acl.Role.READER));
 StorageException - upon failurepublic Acl updateAcl(Acl acl)
Example of updating a new ACL entry.
 Acl acl = bucket.updateAcl(Acl.of(User.ofAllAuthenticatedUsers(), Acl.Role.OWNER));
 StorageException - upon failurepublic List<Acl> listAcls()
Example of listing the ACL entries.
 List<Acl> acls = bucket.listAcls();
 for (Acl acl : acls) {
   // do something with ACL entry
 }
 StorageException - upon failurepublic Acl getDefaultAcl(Acl.Entity entity)
null if
 not found.
 Default ACLs are applied to a new blob within the bucket when no ACL was provided for that blob.
Example of getting the default ACL entry for an entity.
 Acl acl = bucket.getDefaultAcl(User.ofAllAuthenticatedUsers());
 StorageException - upon failurepublic boolean deleteDefaultAcl(Acl.Entity entity)
Default ACLs are applied to a new blob within the bucket when no ACL was provided for that blob.
Example of deleting the default ACL entry for an entity.
 boolean deleted = bucket.deleteDefaultAcl(User.ofAllAuthenticatedUsers());
 if (deleted) {
   // the acl entry was deleted
 } else {
   // the acl entry was not found
 }
 true if the ACL was deleted, false if it was not foundStorageException - upon failurepublic Acl createDefaultAcl(Acl acl)
Default ACLs are applied to a new blob within the bucket when no ACL was provided for that blob.
Example of creating a new default ACL entry.
 Acl acl = bucket.createDefaultAcl(Acl.of(User.ofAllAuthenticatedUsers(), Acl.Role.READER));
 StorageException - upon failurepublic Acl updateDefaultAcl(Acl acl)
Default ACLs are applied to a new blob within the bucket when no ACL was provided for that blob.
Example of updating a new default ACL entry.
 Acl acl = bucket.updateDefaultAcl(Acl.of(User.ofAllAuthenticatedUsers(), Acl.Role.OWNER));
 StorageException - upon failurepublic List<Acl> listDefaultAcls()
Default ACLs are applied to a new blob within the bucket when no ACL was provided for that blob.
Example of listing the default ACL entries.
 List<Acl> acls = bucket.listDefaultAcls();
 for (Acl acl : acls) {
   // do something with ACL entry
 }
 StorageException - upon failurepublic Bucket lockRetentionPolicy(Storage.BucketTargetOption... options)
Accepts an optional userProject Storage.BucketTargetOption option which defines the project
 id to assign operational costs.
 
Warning: Once a retention policy is locked, it can't be unlocked, removed, or shortened.
Example of locking a retention policy on a bucket, only if its local metageneration value
 matches the bucket's service metageneration otherwise a StorageException is thrown.
 
 String bucketName = "my_unique_bucket";
 Bucket bucket = storage.get(bucketName, BucketGetOption.fields(BucketField.METAGENERATION));
 storage.lockRetentionPolicy(bucket, BucketTargetOption.metagenerationMatch());
 Bucket object of the locked bucketStorageException - upon failurepublic Storage getStorage()
Storage object used to issue requests.public Bucket.Builder toBuilder()
BucketInfotoBuilder in class BucketInfopublic final boolean equals(Object obj)
equals in class BucketInfopublic final int hashCode()
hashCode in class BucketInfoCopyright © 2019 Google LLC. All rights reserved.