Class: Google::Cloud::Storage::Bucket
- Inherits:
- 
      Object
      
        - Object
- Google::Cloud::Storage::Bucket
 
- Defined in:
- lib/google/cloud/storage/bucket.rb,
 lib/google/cloud/storage/bucket/acl.rb,
 lib/google/cloud/storage/bucket/cors.rb,
 lib/google/cloud/storage/bucket/list.rb,
 lib/google/cloud/storage/bucket/lifecycle.rb
Overview
Bucket
Represents a Storage bucket. Belongs to a Project and has many Files.
Direct Known Subclasses
Defined Under Namespace
Classes: Acl, Cors, DefaultAcl, Lifecycle, List, Updater
Instance Attribute Summary collapse
- 
  
    
      #user_project  ⇒ Object 
    
    
  
  
  
  
    
    
  
  
  
  
  
  
    A boolean value or a project ID string to indicate the project to be billed for operations on the bucket and its files. 
Instance Method Summary collapse
- 
  
    
      #acl  ⇒ Bucket::Acl 
    
    
  
  
  
  
  
  
  
  
  
    The Acl instance used to control access to the bucket. 
- 
  
    
      #api_url  ⇒ String 
    
    
  
  
  
  
  
  
  
  
  
    A URL that can be used to access the bucket using the REST API. 
- 
  
    
      #autoclass  ⇒ Google::Apis::StorageV1::Bucket::Autoclass 
    
    
  
  
  
  
  
  
  
  
  
    The autoclass configuration of the bucket. 
- 
  
    
      #autoclass_enabled  ⇒ Boolean 
    
    
  
  
  
  
  
  
  
  
  
    Whether Autoclass is enabled for the bucket. 
- 
  
    
      #autoclass_enabled=(toggle)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Updates bucket's autoclass configuration. 
- 
  
    
      #autoclass_terminal_storage_class  ⇒ String 
    
    
  
  
  
  
  
  
  
  
  
    Terminal Storage class of the autoclass. 
- 
  
    
      #autoclass_terminal_storage_class_update_time  ⇒ DateTime 
    
    
  
  
  
  
  
  
  
  
  
    Update time at which the autoclass terminal storage class was last modified. 
- 
  
    
      #autoclass_toggle_time  ⇒ DateTime 
    
    
  
  
  
  
  
  
  
  
  
    Toggle time of the autoclass. 
- 
  
    
      #compose(sources, destination, acl: nil, encryption_key: nil, if_source_generation_match: nil, if_generation_match: nil, if_metageneration_match: nil) {|file| ... } ⇒ Google::Cloud::Storage::File 
    
    
      (also: #compose_file, #combine)
    
  
  
  
  
  
  
  
  
  
    Concatenates a list of existing files in the bucket into a new file in the bucket. 
- 
  
    
      #cors {|cors| ... } ⇒ Bucket::Cors 
    
    
  
  
  
  
  
  
  
  
  
    Returns the current CORS configuration for a static website served from the bucket. 
- 
  
    
      #create_file(file, path = nil, acl: nil, cache_control: nil, content_disposition: nil, content_encoding: nil, content_language: nil, content_type: nil, custom_time: nil, checksum: nil, crc32c: nil, md5: nil, metadata: nil, storage_class: nil, encryption_key: nil, kms_key: nil, temporary_hold: nil, event_based_hold: nil, if_generation_match: nil, if_generation_not_match: nil, if_metageneration_match: nil, if_metageneration_not_match: nil)  ⇒ Google::Cloud::Storage::File 
    
    
      (also: #upload_file, #new_file)
    
  
  
  
  
  
  
  
  
  
    Creates a new File object by providing a path to a local file (or any File-like object such as StringIO) to upload, along with the path at which to store it in the bucket. 
- 
  
    
      #create_notification(topic, custom_attrs: nil, event_types: nil, prefix: nil, payload: nil)  ⇒ Google::Cloud::Storage::Notification 
    
    
      (also: #new_notification)
    
  
  
  
  
  
  
  
  
  
    Creates a new Pub/Sub notification subscription for the bucket. 
- 
  
    
      #created_at  ⇒ DateTime 
    
    
  
  
  
  
  
  
  
  
  
    Creation time of the bucket. 
- #data_locations ⇒ Object
- 
  
    
      #default_acl  ⇒ Bucket::DefaultAcl 
    
    
  
  
  
  
  
  
  
  
  
    The DefaultAcl instance used to control access to the bucket's files. 
- 
  
    
      #default_event_based_hold=(new_default_event_based_hold)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Updates the default event-based hold field for the bucket. 
- 
  
    
      #default_event_based_hold?  ⇒ Boolean 
    
    
  
  
  
  
  
  
  
  
  
    Whether the event_based_holdfield for newly-created files in the bucket will be initially set totrue.
- 
  
    
      #default_kms_key  ⇒ String? 
    
    
  
  
  
  
  
  
  
  
  
    The Cloud KMS encryption key that will be used to protect files. 
- 
  
    
      #default_kms_key=(new_default_kms_key)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Set the Cloud KMS encryption key that will be used to protect files. 
- 
  
    
      #delete(if_metageneration_match: nil, if_metageneration_not_match: nil)  ⇒ Boolean 
    
    
  
  
  
  
  
  
  
  
  
    Permanently deletes the bucket. 
- 
  
    
      #exists?  ⇒ Boolean 
    
    
  
  
  
  
  
  
  
  
  
    Determines whether the bucket exists in the Storage service. 
- 
  
    
      #file(path, generation: nil, if_generation_match: nil, if_generation_not_match: nil, if_metageneration_match: nil, if_metageneration_not_match: nil, skip_lookup: nil, encryption_key: nil, soft_deleted: nil)  ⇒ Google::Cloud::Storage::File? 
    
    
      (also: #find_file)
    
  
  
  
  
  
  
  
  
  
    Retrieves a file matching the path. 
- 
  
    
      #files(prefix: nil, delimiter: nil, token: nil, max: nil, versions: nil, match_glob: nil, include_folders_as_prefixes: nil, soft_deleted: nil)  ⇒ Array<Google::Cloud::Storage::File> 
    
    
      (also: #find_files)
    
  
  
  
  
  
  
  
  
  
    Retrieves a list of files matching the criteria. 
- 
  
    
      #generate_signed_post_policy_v4(path, issuer: nil, client_email: nil, signing_key: nil, private_key: nil, signer: nil, expires: nil, fields: nil, conditions: nil, scheme: "https", virtual_hosted_style: nil, bucket_bound_hostname: nil)  ⇒ PostObject 
    
    
  
  
  
  
  
  
  
  
  
    Generate a PostObjectthat includes the fields and URL to upload objects via HTML forms.
- 
  
    
      #hierarchical_namespace  ⇒ Google::Apis::StorageV1::Bucket::HierarchicalNamespace 
    
    
  
  
  
  
  
  
  
  
  
    The bucket's hierarchical namespace (Folders) configuration. 
- 
  
    
      #hierarchical_namespace=(new_hierarchical_namespace)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Sets the value of Hierarchical Namespace (Folders) for the bucket. 
- 
  
    
      #id  ⇒ String 
    
    
  
  
  
  
  
  
  
  
  
    The ID of the bucket. 
- 
  
    
      #kind  ⇒ String 
    
    
  
  
  
  
  
  
  
  
  
    The kind of item this is. 
- 
  
    
      #labels  ⇒ Hash(String => String) 
    
    
  
  
  
  
  
  
  
  
  
    A hash of user-provided labels. 
- 
  
    
      #labels=(labels)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Updates the hash of user-provided labels. 
- 
  
    
      #lifecycle {|lifecycle| ... } ⇒ Bucket::Lifecycle 
    
    
  
  
  
  
  
  
  
  
  
    Returns the current Object Lifecycle Management rules configuration for the bucket. 
- 
  
    
      #location  ⇒ String 
    
    
  
  
  
  
  
  
  
  
  
    The location of the bucket. 
- 
  
    
      #location_type  ⇒ String 
    
    
  
  
  
  
  
  
  
  
  
    The bucket's location type. 
- 
  
    
      #lock_retention_policy!  ⇒ Boolean 
    
    
  
  
  
  
  
  
  
  
  
    PERMANENTLY locks the retention policy (see #retention_period=) on the bucket if one exists. 
- 
  
    
      #logging_bucket  ⇒ String 
    
    
  
  
  
  
  
  
  
  
  
    The destination bucket name for the bucket's logs. 
- 
  
    
      #logging_bucket=(logging_bucket)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Updates the destination bucket for the bucket's logs. 
- 
  
    
      #logging_prefix  ⇒ String 
    
    
  
  
  
  
  
  
  
  
  
    The logging object prefix for the bucket's logs. 
- 
  
    
      #logging_prefix=(logging_prefix)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Updates the logging object prefix. 
- 
  
    
      #metageneration  ⇒ Integer 
    
    
  
  
  
  
  
  
  
  
  
    The metadata generation of the bucket. 
- 
  
    
      #name  ⇒ String 
    
    
  
  
  
  
  
  
  
  
  
    The name of the bucket. 
- 
  
    
      #notification(id)  ⇒ Google::Cloud::Storage::Notification? 
    
    
      (also: #find_notification)
    
  
  
  
  
  
  
  
  
  
    Retrieves a Pub/Sub notification subscription for the bucket. 
- 
  
    
      #notifications  ⇒ Array<Google::Cloud::Storage::Notification> 
    
    
      (also: #find_notifications)
    
  
  
  
  
  
  
  
  
  
    Retrieves the entire list of Pub/Sub notification subscriptions for the bucket. 
- 
  
    
      #object_retention  ⇒ Google::Apis::StorageV1::Bucket::ObjectRetention 
    
    
  
  
  
  
  
  
  
  
  
    The object retention configuration of the bucket. 
- 
  
    
      #policy(force: nil, requested_policy_version: nil) {|policy| ... } ⇒ Policy 
    
    
  
  
  
  
  
  
  
  
  
    Gets and updates the Cloud IAM access control policy for this bucket. 
- 
  
    
      #policy_only=(new_policy_only)  ⇒ Object 
    
    
  
  
  
  
  
  
  deprecated
  
  
    Deprecated. Use #uniform_bucket_level_access= instead. 
- 
  
    
      #policy_only?  ⇒ Boolean 
    
    
  
  
  
  
  
  
  deprecated
  
  
    Deprecated. Use #uniform_bucket_level_access? instead. 
- 
  
    
      #policy_only_locked_at  ⇒ Object 
    
    
  
  
  
  
  
  
  deprecated
  
  
    Deprecated. Use #uniform_bucket_level_access_locked_at instead. 
- 
  
    
      #post_object(path, policy: nil, issuer: nil, client_email: nil, signing_key: nil, private_key: nil, signer: nil)  ⇒ PostObject 
    
    
  
  
  
  
  
  
  
  
  
    Generate a PostObject that includes the fields and URL to upload objects via HTML forms. 
- 
  
    
      #public_access_prevention  ⇒ String? 
    
    
  
  
  
  
  
  
  
  
  
    The value for Public Access Prevention in the bucket's IAM configuration. 
- 
  
    
      #public_access_prevention=(new_public_access_prevention)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Sets the value for Public Access Prevention in the bucket's IAM configuration. 
- 
  
    
      #public_access_prevention_enforced?  ⇒ Boolean 
    
    
  
  
  
  
  
  
  
  
  
    Whether the bucket's file IAM configuration enforces Public Access Prevention. 
- 
  
    
      #public_access_prevention_inherited?  ⇒ Boolean 
    
    
      (also: #public_access_prevention_unspecified?)
    
  
  
  
  
  
  
  
  
  
    Whether the value for Public Access Prevention in the bucket's IAM configuration is inherited.
- 
  
    
      #reload!  ⇒ Object 
    
    
      (also: #refresh!)
    
  
  
  
  
  
  
  
  
  
    Reloads the bucket with current data from the Storage service. 
- 
  
    
      #requester_pays  ⇒ Boolean? 
    
    
      (also: #requester_pays?)
    
  
  
  
  
  
  
  
  
  
    Indicates that a client accessing the bucket or a file it contains must assume the transit costs related to the access. 
- 
  
    
      #requester_pays=(new_requester_pays)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Enables requester pays for the bucket. 
- 
  
    
      #restore_file(file_path, generation, copy_source_acl: nil, if_generation_match: nil, if_generation_not_match: nil, if_metageneration_match: nil, if_metageneration_not_match: nil, projection: nil, user_project: nil, fields: nil, options: {})  ⇒ Google::Cloud::Storage::File 
    
    
  
  
  
  
  
  
  
  
  
    Restores a soft-deleted object. 
- 
  
    
      #retention_effective_at  ⇒ DateTime? 
    
    
  
  
  
  
  
  
  
  
  
    The time from which the retention policy was effective. 
- 
  
    
      #retention_period  ⇒ Integer? 
    
    
  
  
  
  
  
  
  
  
  
    The period of time (in seconds) that files in the bucket must be retained, and cannot be deleted, overwritten, or archived. 
- 
  
    
      #retention_period=(new_retention_period)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    The period of time (in seconds) that files in the bucket must be retained, and cannot be deleted, overwritten, or archived. 
- 
  
    
      #retention_policy_locked?  ⇒ Boolean 
    
    
  
  
  
  
  
  
  
  
  
    Whether the bucket's file retention policy is locked and its retention period cannot be reduced. 
- 
  
    
      #rpo  ⇒ String? 
    
    
  
  
  
  
  
  
  
  
  
    Recovery Point Objective (RPO) is another attribute of a bucket, it measures how long it takes for a set of updates to be asynchronously copied to the other region. 
- 
  
    
      #rpo=(new_rpo)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Sets the value for Recovery Point Objective (RPO) in the bucket. 
- 
  
    
      #signed_url(path = nil, method: "GET", expires: nil, content_type: nil, content_md5: nil, headers: nil, issuer: nil, client_email: nil, signing_key: nil, private_key: nil, signer: nil, query: nil, scheme: "HTTPS", virtual_hosted_style: nil, bucket_bound_hostname: nil, version: nil)  ⇒ String 
    
    
  
  
  
  
  
  
  
  
  
    Generates a signed URL. 
- 
  
    
      #soft_delete_policy  ⇒ Google::Apis::StorageV1::Bucket::SoftDeletePolicy 
    
    
  
  
  
  
  
  
  
  
  
    The bucket's soft delete policy. 
- 
  
    
      #soft_delete_policy=(new_soft_delete_policy)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Sets the value for Soft Delete Policy in the bucket. 
- 
  
    
      #storage_class  ⇒ String 
    
    
  
  
  
  
  
  
  
  
  
    The bucket's storage class. 
- 
  
    
      #storage_class=(new_storage_class)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Updates the bucket's storage class. 
- 
  
    
      #test_permissions(*permissions)  ⇒ Array<String> 
    
    
  
  
  
  
  
  
  
  
  
    Tests the specified permissions against the Cloud IAM access control policy. 
- 
  
    
      #uniform_bucket_level_access=(new_uniform_bucket_level_access)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Sets whether uniform bucket-level access is enabled for this bucket. 
- 
  
    
      #uniform_bucket_level_access?  ⇒ Boolean 
    
    
  
  
  
  
  
  
  
  
  
    Whether the bucket's file IAM configuration enables uniform bucket-level access. 
- 
  
    
      #uniform_bucket_level_access_locked_at  ⇒ DateTime? 
    
    
  
  
  
  
  
  
  
  
  
    The deadline time for disabling uniform bucket-level access by calling #uniform_bucket_level_access=. 
- 
  
    
      #update(if_metageneration_match: nil, if_metageneration_not_match: nil) {|bucket| ... } ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Updates the bucket with changes made in the given block in a single PATCH request. 
- 
  
    
      #update_autoclass(autoclass_attributes)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Update method to update all attributes of autoclass of a bucket It accepts params as a Hash of attributes in the following format:. 
- 
  
    
      #update_policy(new_policy)  ⇒ Policy 
    
    
      (also: #policy=)
    
  
  
  
  
  
  
  
  
  
    Updates the Cloud IAM access control policy for this bucket. 
- 
  
    
      #versioning=(new_versioning)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Updates whether Object Versioning is enabled for the bucket. 
- 
  
    
      #versioning?  ⇒ Boolean 
    
    
  
  
  
  
  
  
  
  
  
    Whether Object Versioning is enabled for the bucket. 
- 
  
    
      #website_404  ⇒ String 
    
    
  
  
  
  
  
  
  
  
  
    The page returned from a static website served from the bucket when a site visitor requests a resource that does not exist. 
- 
  
    
      #website_404=(website_404)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Updates the page returned from a static website served from the bucket when a site visitor requests a resource that does not exist. 
- 
  
    
      #website_main  ⇒ String 
    
    
  
  
  
  
  
  
  
  
  
    The main page suffix for a static website. 
- 
  
    
      #website_main=(website_main)  ⇒ Object 
    
    
  
  
  
  
  
  
  
  
  
    Updates the main page suffix for a static website. 
Instance Attribute Details
#user_project ⇒ Object
A boolean value or a project ID string to indicate the project to
be billed for operations on the bucket and its files. If this
attribute is set to true, transit costs for operations on the bucket
will be billed to the current project for this client. (See
Project#project for the ID of the current project.) If this
attribute is set to a project ID, and that project is authorized for
the currently authenticated service account, transit costs will be
billed to that project. This attribute is required with requester
pays-enabled buckets. The default is nil.
In general, this attribute should be set when first retrieving the
bucket by providing the user_project option to Project#bucket.
See also #requester_pays= and #requester_pays.
| 83 84 85 | # File 'lib/google/cloud/storage/bucket.rb', line 83 def user_project @user_project end | 
Instance Method Details
#acl ⇒ Bucket::Acl
The Acl instance used to control access to the bucket.
A bucket has owners, writers, and readers. Permissions can be granted to an individual user's email address, a group's email address, as well as many predefined lists.
| 2659 2660 2661 | # File 'lib/google/cloud/storage/bucket.rb', line 2659 def acl @acl ||= Bucket::Acl.new self end | 
#api_url ⇒ String
A URL that can be used to access the bucket using the REST API.
| 144 145 146 | # File 'lib/google/cloud/storage/bucket.rb', line 144 def api_url @gapi.self_link end | 
#autoclass ⇒ Google::Apis::StorageV1::Bucket::Autoclass
The autoclass configuration of the bucket
| 117 118 119 | # File 'lib/google/cloud/storage/bucket.rb', line 117 def autoclass @gapi.autoclass end | 
#autoclass_enabled ⇒ Boolean
Whether Autoclass is enabled for the bucket.
| 433 434 435 | # File 'lib/google/cloud/storage/bucket.rb', line 433 def autoclass_enabled @gapi.autoclass&.enabled? end | 
#autoclass_enabled=(toggle) ⇒ Object
Updates bucket's autoclass configuration. This defines the default class for objects in the
bucket and down/up-grades the storage class of objects based on the access patterns.
Accepted values are :false, and :true.
For more information, see Storage Classes.
| 474 475 476 477 478 | # File 'lib/google/cloud/storage/bucket.rb', line 474 def autoclass_enabled= toggle @gapi.autoclass ||= API::Bucket::Autoclass.new @gapi.autoclass.enabled = toggle patch_gapi! :autoclass end | 
#autoclass_terminal_storage_class ⇒ String
Terminal Storage class of the autoclass
| 451 452 453 | # File 'lib/google/cloud/storage/bucket.rb', line 451 def autoclass_terminal_storage_class @gapi.autoclass&.terminal_storage_class end | 
#autoclass_terminal_storage_class_update_time ⇒ DateTime
Update time at which the autoclass terminal storage class was last modified
| 460 461 462 | # File 'lib/google/cloud/storage/bucket.rb', line 460 def autoclass_terminal_storage_class_update_time @gapi.autoclass&.terminal_storage_class_update_time end | 
#autoclass_toggle_time ⇒ DateTime
Toggle time of the autoclass
| 442 443 444 | # File 'lib/google/cloud/storage/bucket.rb', line 442 def autoclass_toggle_time @gapi.autoclass&.toggle_time end | 
#compose(sources, destination, acl: nil, encryption_key: nil, if_source_generation_match: nil, if_generation_match: nil, if_metageneration_match: nil) {|file| ... } ⇒ Google::Cloud::Storage::File Also known as: compose_file, combine
Concatenates a list of existing files in the bucket into a new file in the bucket. There is a limit (currently 32) to the number of files that can be composed in a single operation.
To compose files encrypted with a customer-supplied encryption key,
use the encryption_key option. All source files must have been
encrypted with the same key, and the resulting destination file will
also be encrypted with the same key.
| 2006 2007 2008 2009 2010 2011 2012 2013 2014 2015 2016 2017 2018 2019 2020 2021 2022 2023 2024 2025 2026 2027 2028 2029 2030 2031 2032 2033 2034 2035 2036 2037 2038 2039 | # File 'lib/google/cloud/storage/bucket.rb', line 2006 def compose sources, destination, acl: nil, encryption_key: nil, if_source_generation_match: nil, if_generation_match: nil, if_metageneration_match: nil ensure_service! sources = Array sources if sources.size < 2 raise ArgumentError, "must provide at least two source files" end destination_gapi = nil if block_given? destination_gapi = API::Object.new updater = File::Updater.new destination_gapi yield updater updater. end acl_rule = File::Acl.predefined_rule_for acl gapi = service.compose_file name, sources, destination, destination_gapi, acl: acl_rule, key: encryption_key, if_source_generation_match: if_source_generation_match, if_generation_match: if_generation_match, if_metageneration_match: , user_project: user_project File.from_gapi gapi, service, user_project: user_project end | 
#cors {|cors| ... } ⇒ Bucket::Cors
Returns the current CORS configuration for a static website served from the bucket.
The return value is a frozen (unmodifiable) array of hashes containing the attributes specified for the Bucket resource field cors.
This method also accepts a block for updating the bucket's CORS rules. See Cors for details.
| 213 214 215 216 217 218 219 220 221 222 223 | # File 'lib/google/cloud/storage/bucket.rb', line 213 def cors cors_builder = Bucket::Cors.from_gapi @gapi.cors_configurations if block_given? yield cors_builder if cors_builder.changed? @gapi.cors_configurations = cors_builder.to_gapi patch_gapi! :cors_configurations end end cors_builder.freeze # always return frozen objects end | 
#create_file(file, path = nil, acl: nil, cache_control: nil, content_disposition: nil, content_encoding: nil, content_language: nil, content_type: nil, custom_time: nil, checksum: nil, crc32c: nil, md5: nil, metadata: nil, storage_class: nil, encryption_key: nil, kms_key: nil, temporary_hold: nil, event_based_hold: nil, if_generation_match: nil, if_generation_not_match: nil, if_metageneration_match: nil, if_metageneration_not_match: nil) ⇒ Google::Cloud::Storage::File Also known as: upload_file, new_file
Creates a new File object by providing a path to a local file (or any File-like object such as StringIO) to upload, along with the path at which to store it in the bucket.
Customer-supplied encryption keys
By default, Google Cloud Storage manages server-side encryption keys
on your behalf. However, a customer-supplied encryption key
can be provided with the encryption_key option. If given, the same
key must be provided to subsequently download or copy the file. If you
use customer-supplied encryption keys, you must securely manage your
keys and ensure that they are not lost. Also, please note that file
metadata is not encrypted, with the exception of the CRC32C checksum
and MD5 hash. The names of files and buckets are also not encrypted,
and you can read or update the metadata of an encrypted file without
providing the encryption key.
| 1781 1782 1783 1784 1785 1786 1787 1788 1789 1790 1791 1792 1793 1794 1795 1796 1797 1798 1799 1800 1801 1802 1803 1804 1805 1806 1807 1808 1809 1810 1811 1812 1813 1814 1815 1816 1817 1818 1819 1820 1821 1822 1823 1824 1825 1826 1827 1828 1829 1830 1831 1832 1833 1834 1835 | # File 'lib/google/cloud/storage/bucket.rb', line 1781 def create_file file, path = nil, acl: nil, cache_control: nil, content_disposition: nil, content_encoding: nil, content_language: nil, content_type: nil, custom_time: nil, checksum: nil, crc32c: nil, md5: nil, metadata: nil, storage_class: nil, encryption_key: nil, kms_key: nil, temporary_hold: nil, event_based_hold: nil, if_generation_match: nil, if_generation_not_match: nil, if_metageneration_match: nil, if_metageneration_not_match: nil ensure_service! ensure_io_or_file_exists! file path ||= file.path if file.respond_to? :path path ||= file if file.is_a? String raise ArgumentError, "must provide path" if path.nil? crc32c = crc32c_for file, checksum, crc32c md5 = md5_for file, checksum, md5 gapi = service.insert_file name, file, path, acl: File::Acl.predefined_rule_for(acl), md5: md5, cache_control: cache_control, content_type: content_type, custom_time: custom_time, content_disposition: content_disposition, crc32c: crc32c, content_encoding: content_encoding, metadata: , content_language: content_language, key: encryption_key, kms_key: kms_key, storage_class: storage_class_for(storage_class), temporary_hold: temporary_hold, event_based_hold: event_based_hold, if_generation_match: if_generation_match, if_generation_not_match: if_generation_not_match, if_metageneration_match: , if_metageneration_not_match: , user_project: user_project File.from_gapi gapi, service, user_project: user_project end | 
#create_notification(topic, custom_attrs: nil, event_types: nil, prefix: nil, payload: nil) ⇒ Google::Cloud::Storage::Notification Also known as: new_notification
Creates a new Pub/Sub notification subscription for the bucket.
| 3096 3097 3098 3099 3100 3101 3102 3103 3104 3105 3106 | # File 'lib/google/cloud/storage/bucket.rb', line 3096 def create_notification topic, custom_attrs: nil, event_types: nil, prefix: nil, payload: nil ensure_service! gapi = service.insert_notification name, topic, custom_attrs: custom_attrs, event_types: event_types, prefix: prefix, payload: payload, user_project: user_project Notification.from_gapi name, gapi, service, user_project: user_project end | 
#created_at ⇒ DateTime
Creation time of the bucket.
| 153 154 155 | # File 'lib/google/cloud/storage/bucket.rb', line 153 def created_at @gapi.time_created end | 
#data_locations ⇒ Object
| 332 333 334 | # File 'lib/google/cloud/storage/bucket.rb', line 332 def data_locations @gapi.custom_placement_config&.data_locations end | 
#default_acl ⇒ Bucket::DefaultAcl
The DefaultAcl instance used to control access to the bucket's files.
A bucket's files have owners, writers, and readers. Permissions can be granted to an individual user's email address, a group's email address, as well as many predefined lists.
| 2705 2706 2707 | # File 'lib/google/cloud/storage/bucket.rb', line 2705 def default_acl @default_acl ||= Bucket::DefaultAcl.new self end | 
#default_event_based_hold=(new_default_event_based_hold) ⇒ Object
Updates the default event-based hold field for the bucket. This field
controls the initial state of the event_based_hold field for
newly-created files in the bucket.
See File#event_based_hold? and File#set_event_based_hold!.
To pass metageneration preconditions, call this method within a block passed to #update.
| 878 879 880 881 | # File 'lib/google/cloud/storage/bucket.rb', line 878 def default_event_based_hold= new_default_event_based_hold @gapi.default_event_based_hold = new_default_event_based_hold patch_gapi! :default_event_based_hold end | 
#default_event_based_hold? ⇒ Boolean
Whether the event_based_hold field for newly-created files in the
bucket will be initially set to true. See
#default_event_based_hold=, File#event_based_hold? and
File#set_event_based_hold!.
| 840 841 842 | # File 'lib/google/cloud/storage/bucket.rb', line 840 def default_event_based_hold? !@gapi.default_event_based_hold.nil? && @gapi.default_event_based_hold end | 
#default_kms_key ⇒ String?
The Cloud KMS encryption key that will be used to protect files.
For example: projects/a/locations/b/keyRings/c/cryptoKeys/d
| 679 680 681 | # File 'lib/google/cloud/storage/bucket.rb', line 679 def default_kms_key @gapi.encryption&.default_kms_key_name end | 
#default_kms_key=(new_default_kms_key) ⇒ Object
Set the Cloud KMS encryption key that will be used to protect files.
For example: projects/a/locations/b/keyRings/c/cryptoKeys/d
To pass metageneration preconditions, call this method within a block passed to #update.
| 714 715 716 717 718 | # File 'lib/google/cloud/storage/bucket.rb', line 714 def default_kms_key= new_default_kms_key @gapi.encryption = API::Bucket::Encryption.new \ default_kms_key_name: new_default_kms_key patch_gapi! :encryption end | 
#delete(if_metageneration_match: nil, if_metageneration_not_match: nil) ⇒ Boolean
Permanently deletes the bucket. The bucket must be empty before it can be deleted.
The API call to delete the bucket may be retried under certain conditions. See Google::Cloud#storage to control this behavior.
| 1405 1406 1407 1408 1409 1410 1411 | # File 'lib/google/cloud/storage/bucket.rb', line 1405 def delete if_metageneration_match: nil, if_metageneration_not_match: nil ensure_service! service.delete_bucket name, if_metageneration_match: , if_metageneration_not_match: , user_project: user_project end | 
#exists? ⇒ Boolean
Determines whether the bucket exists in the Storage service.
| 3126 3127 3128 3129 3130 3131 3132 3133 3134 3135 | # File 'lib/google/cloud/storage/bucket.rb', line 3126 def exists? # Always true if we have a grpc object return true unless lazy? # If we have a value, return it return @exists unless @exists.nil? ensure_gapi! @exists = true rescue Google::Cloud::NotFoundError @exists = false end | 
#file(path, generation: nil, if_generation_match: nil, if_generation_not_match: nil, if_metageneration_match: nil, if_metageneration_not_match: nil, skip_lookup: nil, encryption_key: nil, soft_deleted: nil) ⇒ Google::Cloud::Storage::File? Also known as: find_file
Retrieves a file matching the path.
If a customer-supplied encryption
key
was used with #create_file, the encryption_key option must be
provided or else the file's CRC32C checksum and MD5 hash will not be
returned.
| 1536 1537 1538 1539 1540 1541 1542 1543 1544 1545 1546 1547 1548 1549 1550 1551 1552 1553 1554 1555 1556 1557 1558 1559 1560 1561 1562 | # File 'lib/google/cloud/storage/bucket.rb', line 1536 def file path, generation: nil, if_generation_match: nil, if_generation_not_match: nil, if_metageneration_match: nil, if_metageneration_not_match: nil, skip_lookup: nil, encryption_key: nil, soft_deleted: nil ensure_service! if skip_lookup return File.new_lazy name, path, service, generation: generation, user_project: user_project end gapi = service.get_file name, path, generation: generation, if_generation_match: if_generation_match, if_generation_not_match: if_generation_not_match, if_metageneration_match: , if_metageneration_not_match: , key: encryption_key, user_project: user_project, soft_deleted: soft_deleted File.from_gapi gapi, service, user_project: user_project rescue Google::Cloud::NotFoundError nil end | 
#files(prefix: nil, delimiter: nil, token: nil, max: nil, versions: nil, match_glob: nil, include_folders_as_prefixes: nil, soft_deleted: nil) ⇒ Array<Google::Cloud::Storage::File> Also known as: find_files
Retrieves a list of files matching the criteria.
| 1468 1469 1470 1471 1472 1473 1474 1475 1476 1477 1478 1479 1480 1481 1482 1483 1484 1485 | # File 'lib/google/cloud/storage/bucket.rb', line 1468 def files prefix: nil, delimiter: nil, token: nil, max: nil, versions: nil, match_glob: nil, include_folders_as_prefixes: nil, soft_deleted: nil ensure_service! gapi = service.list_files name, prefix: prefix, delimiter: delimiter, token: token, max: max, versions: versions, user_project: user_project, match_glob: match_glob, include_folders_as_prefixes: include_folders_as_prefixes, soft_deleted: soft_deleted File::List.from_gapi gapi, service, name, prefix, delimiter, max, versions, user_project: user_project, match_glob: match_glob, include_folders_as_prefixes: include_folders_as_prefixes, soft_deleted: soft_deleted end | 
#generate_signed_post_policy_v4(path, issuer: nil, client_email: nil, signing_key: nil, private_key: nil, signer: nil, expires: nil, fields: nil, conditions: nil, scheme: "https", virtual_hosted_style: nil, bucket_bound_hostname: nil) ⇒ PostObject
Generate a PostObject that includes the fields and URL to
upload objects via HTML forms. The resulting PostObject is
based on a policy document created from the method arguments.
This policy provides authorization to ensure that the HTML
form can upload files into the bucket. See Signatures -
Policy document.
Generating a PostObject requires service account credentials,
either by connecting with a service account when calling
Google::Cloud.storage, or by passing in the service account
issuer and signing_key values. Although the private key can
be passed as a string for convenience, creating and storing
an instance of OpenSSL::PKey::RSA is more efficient
when making multiple calls to generate_signed_post_policy_v4.
A SignedUrlUnavailable is raised if the service account credentials are missing. Service account credentials are acquired by following the steps in Service Account Authentication.
| 2591 2592 2593 2594 2595 2596 2597 2598 2599 2600 2601 2602 2603 2604 2605 2606 2607 2608 2609 2610 2611 2612 2613 2614 2615 2616 | # File 'lib/google/cloud/storage/bucket.rb', line 2591 def generate_signed_post_policy_v4 path, issuer: nil, client_email: nil, signing_key: nil, private_key: nil, signer: nil, expires: nil, fields: nil, conditions: nil, scheme: "https", virtual_hosted_style: nil, bucket_bound_hostname: nil ensure_service! sign = File::SignerV4.from_bucket self, path sign.post_object issuer: issuer, client_email: client_email, signing_key: signing_key, private_key: private_key, signer: signer, expires: expires, fields: fields, conditions: conditions, scheme: scheme, virtual_hosted_style: virtual_hosted_style, bucket_bound_hostname: bucket_bound_hostname end | 
#hierarchical_namespace ⇒ Google::Apis::StorageV1::Bucket::HierarchicalNamespace
The bucket's hierarchical namespace (Folders) configuration. This value can be modified by calling #hierarchical_namespace=.
| 1271 1272 1273 | # File 'lib/google/cloud/storage/bucket.rb', line 1271 def hierarchical_namespace @gapi.hierarchical_namespace end | 
#hierarchical_namespace=(new_hierarchical_namespace) ⇒ Object
Sets the value of Hierarchical Namespace (Folders) for the bucket. This can only be enabled at bucket create time. If this is enabled, Uniform Bucket-Level Access must also be enabled. This value can be queried by calling #hierarchical_namespace.
| 1307 1308 1309 1310 | # File 'lib/google/cloud/storage/bucket.rb', line 1307 def hierarchical_namespace= new_hierarchical_namespace @gapi.hierarchical_namespace = new_hierarchical_namespace || {} patch_gapi! :hierarchical_namespace end | 
#id ⇒ String
The ID of the bucket.
| 108 109 110 | # File 'lib/google/cloud/storage/bucket.rb', line 108 def id @gapi.id end | 
#kind ⇒ String
The kind of item this is.
For buckets, this is always storage#bucket.
| 99 100 101 | # File 'lib/google/cloud/storage/bucket.rb', line 99 def kind @gapi.kind end | 
#labels ⇒ Hash(String => String)
A hash of user-provided labels. The hash is frozen and changes are not allowed.
| 579 580 581 582 583 | # File 'lib/google/cloud/storage/bucket.rb', line 579 def labels m = @gapi.labels m = m.to_h if m.respond_to? :to_h m.dup.freeze end | 
#labels=(labels) ⇒ Object
Updates the hash of user-provided labels.
To pass metageneration preconditions, call this method within a block passed to #update.
| 593 594 595 596 | # File 'lib/google/cloud/storage/bucket.rb', line 593 def labels= labels @gapi.labels = labels patch_gapi! :labels end | 
#lifecycle {|lifecycle| ... } ⇒ Bucket::Lifecycle
Returns the current Object Lifecycle Management rules configuration for the bucket.
This method also accepts a block for updating the bucket's Object Lifecycle Management rules. See Lifecycle for details.
| 280 281 282 283 284 285 286 287 288 289 290 | # File 'lib/google/cloud/storage/bucket.rb', line 280 def lifecycle lifecycle_builder = Bucket::Lifecycle.from_gapi @gapi.lifecycle if block_given? yield lifecycle_builder if lifecycle_builder.changed? @gapi.lifecycle = lifecycle_builder.to_gapi patch_gapi! :lifecycle end end lifecycle_builder.freeze # always return frozen objects end | 
#location ⇒ String
The location of the bucket. Object data for objects in the bucket resides in physical storage within this region. Defaults to US. See the developer's guide for the authoritative list.
| 302 303 304 | # File 'lib/google/cloud/storage/bucket.rb', line 302 def location @gapi.location end | 
#location_type ⇒ String
The bucket's location type. Location type defines the geographic placement of the bucket's data and affects cost, performance, and availability. There are three possible values:
- region- Lowest latency within a single region
- multi-region- Highest availability across largest area
- dual-region- High availability and low latency across 2 regions
| 318 319 320 | # File 'lib/google/cloud/storage/bucket.rb', line 318 def location_type @gapi.location_type end | 
#lock_retention_policy! ⇒ Boolean
PERMANENTLY locks the retention policy (see #retention_period=) on the bucket if one exists. The policy is transitioned to a locked state in which its duration cannot be reduced.
Locked policies can be extended in duration by setting #retention_period= to a higher value. Such an extension is permanent, and it cannot later be reduced. The extended duration will apply retroactively to all files currently in the bucket.
This method also creates a
lien
on the resourcemanager.projects.delete permission for the project
containing the bucket.
The bucket's metageneration value is required for the lock policy API
call. Attempting to call this method on a bucket that was loaded with
the skip_lookup: true option will result in an error.
| 921 922 923 924 925 926 | # File 'lib/google/cloud/storage/bucket.rb', line 921 def lock_retention_policy! ensure_service! @gapi = service.lock_bucket_retention_policy \ name, , user_project: user_project true end | 
#logging_bucket ⇒ String
The destination bucket name for the bucket's logs.
| 343 344 345 | # File 'lib/google/cloud/storage/bucket.rb', line 343 def logging_bucket @gapi.logging&.log_bucket end | 
#logging_bucket=(logging_bucket) ⇒ Object
Updates the destination bucket for the bucket's logs.
To pass metageneration preconditions, call this method within a block passed to #update.
| 357 358 359 360 361 | # File 'lib/google/cloud/storage/bucket.rb', line 357 def logging_bucket= logging_bucket @gapi.logging ||= API::Bucket::Logging.new @gapi.logging.log_bucket = logging_bucket patch_gapi! :logging end | 
#logging_prefix ⇒ String
The logging object prefix for the bucket's logs. For more information,
| 370 371 372 | # File 'lib/google/cloud/storage/bucket.rb', line 370 def logging_prefix @gapi.logging&.log_object_prefix end | 
#logging_prefix=(logging_prefix) ⇒ Object
Updates the logging object prefix. This prefix will be used to create log object names for the bucket. It can be at most 900 characters and must be a valid object name. By default, the object prefix is the name of the bucket for which the logs are enabled.
To pass metageneration preconditions, call this method within a block passed to #update.
| 389 390 391 392 393 | # File 'lib/google/cloud/storage/bucket.rb', line 389 def logging_prefix= logging_prefix @gapi.logging ||= API::Bucket::Logging.new @gapi.logging.log_object_prefix = logging_prefix patch_gapi! :logging end | 
#metageneration ⇒ Integer
The metadata generation of the bucket.
| 162 163 164 | # File 'lib/google/cloud/storage/bucket.rb', line 162 def @gapi. end | 
#name ⇒ String
The name of the bucket.
| 135 136 137 | # File 'lib/google/cloud/storage/bucket.rb', line 135 def name @gapi.name end | 
#notification(id) ⇒ Google::Cloud::Storage::Notification? Also known as: find_notification
Retrieves a Pub/Sub notification subscription for the bucket.
| 3018 3019 3020 3021 3022 3023 3024 | # File 'lib/google/cloud/storage/bucket.rb', line 3018 def notification id ensure_service! gapi = service.get_notification name, id, user_project: user_project Notification.from_gapi name, gapi, service, user_project: user_project rescue Google::Cloud::NotFoundError nil end | 
#notifications ⇒ Array<Google::Cloud::Storage::Notification> Also known as: find_notifications
Retrieves the entire list of Pub/Sub notification subscriptions for the bucket.
| 2987 2988 2989 2990 2991 2992 2993 2994 | # File 'lib/google/cloud/storage/bucket.rb', line 2987 def notifications ensure_service! gapi = service.list_notifications name, user_project: user_project Array(gapi.items).map do |gapi_object| Notification.from_gapi name, gapi_object, service, user_project: user_project end end | 
#object_retention ⇒ Google::Apis::StorageV1::Bucket::ObjectRetention
The object retention configuration of the bucket
| 126 127 128 | # File 'lib/google/cloud/storage/bucket.rb', line 126 def object_retention @gapi.object_retention end | 
#policy(force: nil, requested_policy_version: nil) {|policy| ... } ⇒ Policy
Gets and updates the Cloud IAM access control policy for this bucket.
| 2832 2833 2834 2835 2836 2837 2838 2839 2840 2841 2842 2843 2844 2845 | # File 'lib/google/cloud/storage/bucket.rb', line 2832 def policy force: nil, requested_policy_version: nil warn "DEPRECATED: 'force' in Bucket#policy" unless force.nil? ensure_service! gapi = service.get_bucket_policy name, requested_policy_version: requested_policy_version, user_project: user_project policy = if requested_policy_version.nil? || requested_policy_version == 1 PolicyV1.from_gapi gapi else PolicyV3.from_gapi gapi end return policy unless block_given? yield policy update_policy policy end | 
#policy_only=(new_policy_only) ⇒ Object
Use #uniform_bucket_level_access= instead.
| 1026 1027 1028 | # File 'lib/google/cloud/storage/bucket.rb', line 1026 def policy_only= new_policy_only self.uniform_bucket_level_access = new_policy_only end | 
#policy_only? ⇒ Boolean
Use #uniform_bucket_level_access? instead.
| 1019 1020 1021 | # File 'lib/google/cloud/storage/bucket.rb', line 1019 def policy_only? uniform_bucket_level_access? end | 
#policy_only_locked_at ⇒ Object
Use #uniform_bucket_level_access_locked_at instead.
| 1033 1034 1035 | # File 'lib/google/cloud/storage/bucket.rb', line 1033 def policy_only_locked_at uniform_bucket_level_access_locked_at end | 
#post_object(path, policy: nil, issuer: nil, client_email: nil, signing_key: nil, private_key: nil, signer: nil) ⇒ PostObject
Generate a PostObject that includes the fields and URL to upload objects via HTML forms.
Generating a PostObject requires service account credentials,
either by connecting with a service account when calling
Google::Cloud.storage, or by passing in the service account
issuer and signing_key values. Although the private key can
be passed as a string for convenience, creating and storing
an instance of # OpenSSL::PKey::RSA is more efficient
when making multiple calls to post_object.
A SignedUrlUnavailable is raised if the service account credentials are missing. Service account credentials are acquired by following the steps in Service Account Authentication.
| 2436 2437 2438 2439 2440 2441 2442 2443 2444 2445 2446 2447 2448 2449 2450 2451 | # File 'lib/google/cloud/storage/bucket.rb', line 2436 def post_object path, policy: nil, issuer: nil, client_email: nil, signing_key: nil, private_key: nil, signer: nil ensure_service! sign = File::SignerV2.from_bucket self, path sign.post_object issuer: issuer, client_email: client_email, signing_key: signing_key, private_key: private_key, signer: signer, policy: policy end | 
#public_access_prevention ⇒ String?
The value for Public Access Prevention in the bucket's IAM configuration. Currently, inherited and
enforced are supported. When set to enforced, Public Access Prevention is enforced in the bucket's IAM
configuration. This value can be modified by calling #public_access_prevention=.
| 1055 1056 1057 | # File 'lib/google/cloud/storage/bucket.rb', line 1055 def public_access_prevention @gapi.iam_configuration&.public_access_prevention end | 
#public_access_prevention=(new_public_access_prevention) ⇒ Object
Sets the value for Public Access Prevention in the bucket's IAM configuration. This value can be queried by calling #public_access_prevention.
| 1087 1088 1089 1090 1091 | # File 'lib/google/cloud/storage/bucket.rb', line 1087 def public_access_prevention= new_public_access_prevention @gapi.iam_configuration ||= API::Bucket::IamConfiguration.new @gapi.iam_configuration.public_access_prevention = new_public_access_prevention.to_s patch_gapi! :iam_configuration end | 
#public_access_prevention_enforced? ⇒ Boolean
Whether the bucket's file IAM configuration enforces Public Access Prevention. The default is false. This
value can be modified by calling #public_access_prevention=.
| 1111 1112 1113 1114 | # File 'lib/google/cloud/storage/bucket.rb', line 1111 def public_access_prevention_enforced? return false unless @gapi.iam_configuration&.public_access_prevention @gapi.iam_configuration.public_access_prevention.to_s == "enforced" end | 
#public_access_prevention_inherited? ⇒ Boolean Also known as: public_access_prevention_unspecified?
Whether the value for Public Access Prevention in the bucket's IAM configuration is inherited. The default
is false. This value can be modified by calling #public_access_prevention=.
| 1134 1135 1136 1137 | # File 'lib/google/cloud/storage/bucket.rb', line 1134 def public_access_prevention_inherited? return false unless @gapi.iam_configuration&.public_access_prevention ["inherited", "unspecified"].include? @gapi.iam_configuration.public_access_prevention.to_s end | 
#reload! ⇒ Object Also known as: refresh!
Reloads the bucket with current data from the Storage service.
| 3112 3113 3114 3115 3116 3117 3118 | # File 'lib/google/cloud/storage/bucket.rb', line 3112 def reload! ensure_service! @gapi = service.get_bucket name, user_project: user_project # If NotFound then lazy will never be unset @lazy = nil self end | 
#requester_pays ⇒ Boolean? Also known as: requester_pays?
Indicates that a client accessing the bucket or a file it contains
must assume the transit costs related to the access. The requester
must pass the user_project option to Project#bucket and
Project#buckets to indicate the project to which the access costs
should be billed.
| 624 625 626 | # File 'lib/google/cloud/storage/bucket.rb', line 624 def requester_pays @gapi.billing&.requester_pays end | 
#requester_pays=(new_requester_pays) ⇒ Object
Enables requester pays for the bucket. If enabled, a client accessing
the bucket or a file it contains must assume the transit costs related
to the access. The requester must pass the user_project option to
Project#bucket and Project#buckets to indicate the project to
which the access costs should be billed.
To pass metageneration preconditions, call this method within a block passed to #update.
| 653 654 655 656 657 | # File 'lib/google/cloud/storage/bucket.rb', line 653 def requester_pays= new_requester_pays @gapi.billing ||= API::Bucket::Billing.new @gapi.billing.requester_pays = new_requester_pays patch_gapi! :billing end | 
#restore_file(file_path, generation, copy_source_acl: nil, if_generation_match: nil, if_generation_not_match: nil, if_metageneration_match: nil, if_metageneration_not_match: nil, projection: nil, user_project: nil, fields: nil, options: {}) ⇒ Google::Cloud::Storage::File
Restores a soft-deleted object.
| 1883 1884 1885 1886 1887 1888 1889 1890 1891 1892 1893 1894 1895 1896 1897 1898 1899 1900 1901 1902 1903 1904 1905 1906 1907 1908 | # File 'lib/google/cloud/storage/bucket.rb', line 1883 def restore_file file_path, generation, copy_source_acl: nil, if_generation_match: nil, if_generation_not_match: nil, if_metageneration_match: nil, if_metageneration_not_match: nil, projection: nil, user_project: nil, fields: nil, options: {} ensure_service! gapi = service.restore_file name, file_path, generation, copy_source_acl: File::Acl.predefined_rule_for(copy_source_acl), if_generation_match: if_generation_match, if_generation_not_match: if_generation_not_match, if_metageneration_match: , if_metageneration_not_match: , projection: projection, user_project: user_project, fields: fields, options: File.from_gapi gapi, service, user_project: user_project end | 
#retention_effective_at ⇒ DateTime?
The time from which the retention policy was effective. Whenever a retention policy is created or extended, GCS updates the effective date of the policy. The effective date signals the date starting from which objects were guaranteed to be retained for the full duration of the policy.
This field is updated when the retention policy is created or modified, including extension of a locked policy.
| 793 794 795 | # File 'lib/google/cloud/storage/bucket.rb', line 793 def retention_effective_at @gapi.retention_policy&.effective_time end | 
#retention_period ⇒ Integer?
The period of time (in seconds) that files in the bucket must be retained, and cannot be deleted, overwritten, or archived. The value must be between 0 and 100 years (in seconds.)
See also: #retention_period=, #retention_effective_at, and #retention_policy_locked?.
| 731 732 733 | # File 'lib/google/cloud/storage/bucket.rb', line 731 def retention_period @gapi.retention_policy&.retention_period end | 
#retention_period=(new_retention_period) ⇒ Object
The period of time (in seconds) that files in the bucket must be
retained, and cannot be deleted, overwritten, or archived. Passing a
valid Integer value will add a new retention policy to the bucket
if none exists. Passing nil will remove the retention policy from
the bucket if it exists, unless the policy is locked.
Locked policies can be extended in duration by using this method to set a higher value. Such an extension is permanent, and it cannot later be reduced. The extended duration will apply retroactively to all files currently in the bucket.
See also: #lock_retention_policy!, #retention_period, #retention_effective_at, and #retention_policy_locked?.
To pass metageneration preconditions, call this method within a block passed to #update.
| 769 770 771 772 773 774 775 776 777 778 | # File 'lib/google/cloud/storage/bucket.rb', line 769 def retention_period= new_retention_period if new_retention_period.nil? @gapi.retention_policy = nil else @gapi.retention_policy ||= API::Bucket::RetentionPolicy.new @gapi.retention_policy.retention_period = new_retention_period end patch_gapi! :retention_policy end | 
#retention_policy_locked? ⇒ Boolean
Whether the bucket's file retention policy is locked and its retention period cannot be reduced. See #retention_period= and #lock_retention_policy!.
This value can only be set to true by calling
#lock_retention_policy!.
| 824 825 826 827 828 | # File 'lib/google/cloud/storage/bucket.rb', line 824 def retention_policy_locked? return false unless @gapi.retention_policy !@gapi.retention_policy.is_locked.nil? && @gapi.retention_policy.is_locked end | 
#rpo ⇒ String?
Recovery Point Objective (RPO) is another attribute of a bucket, it measures how long it takes for a set of
updates to be asynchronously copied to the other region.
Currently, DEFAULT and ASYNC_TURBO are supported. When set to ASYNC_TURBO, Turbo Replication is enabled
for a bucket. DEFAULT is used to reset rpo on an existing bucket with rpo set to ASYNC_TURBO.
This value can be modified by calling #rpo=.
| 1161 1162 1163 | # File 'lib/google/cloud/storage/bucket.rb', line 1161 def rpo @gapi.rpo end | 
#rpo=(new_rpo) ⇒ Object
Sets the value for Recovery Point Objective (RPO) in the bucket. This value can be queried by calling #rpo.
| 1192 1193 1194 1195 | # File 'lib/google/cloud/storage/bucket.rb', line 1192 def rpo= new_rpo @gapi.rpo = new_rpo&.to_s patch_gapi! :rpo end | 
#signed_url(path = nil, method: "GET", expires: nil, content_type: nil, content_md5: nil, headers: nil, issuer: nil, client_email: nil, signing_key: nil, private_key: nil, signer: nil, query: nil, scheme: "HTTPS", virtual_hosted_style: nil, bucket_bound_hostname: nil, version: nil) ⇒ String
Generates a signed URL. See Signed URLs for more information.
Generating a signed URL requires service account credentials, either
by connecting with a service account when calling
Google::Cloud.storage, or by passing in the service account issuer
and signing_key values. Although the private key can be passed as a
string for convenience, creating and storing an instance of
OpenSSL::PKey::RSA is more efficient when making multiple calls to
signed_url.
A SignedUrlUnavailable is raised if the service account credentials are missing. Service account credentials are acquired by following the steps in Service Account Authentication.
| 2232 2233 2234 2235 2236 2237 2238 2239 2240 2241 2242 2243 2244 2245 2246 2247 2248 2249 2250 2251 2252 2253 2254 2255 2256 2257 2258 2259 2260 2261 2262 2263 2264 2265 2266 2267 2268 2269 2270 2271 2272 2273 2274 2275 2276 2277 2278 2279 2280 2281 | # File 'lib/google/cloud/storage/bucket.rb', line 2232 def signed_url path = nil, method: "GET", expires: nil, content_type: nil, content_md5: nil, headers: nil, issuer: nil, client_email: nil, signing_key: nil, private_key: nil, signer: nil, query: nil, scheme: "HTTPS", virtual_hosted_style: nil, bucket_bound_hostname: nil, version: nil ensure_service! version ||= :v2 case version.to_sym when :v2 sign = File::SignerV2.from_bucket self, path sign.signed_url method: method, expires: expires, headers: headers, content_type: content_type, content_md5: content_md5, issuer: issuer, client_email: client_email, signing_key: signing_key, private_key: private_key, signer: signer, query: query when :v4 sign = File::SignerV4.from_bucket self, path sign.signed_url method: method, expires: expires, headers: headers, issuer: issuer, client_email: client_email, signing_key: signing_key, private_key: private_key, signer: signer, query: query, scheme: scheme, virtual_hosted_style: virtual_hosted_style, bucket_bound_hostname: bucket_bound_hostname else raise ArgumentError, "version '#{version}' not supported" end end | 
#soft_delete_policy ⇒ Google::Apis::StorageV1::Bucket::SoftDeletePolicy
The bucket's soft delete policy. If this policy is set, any deleted objects will be soft-deleted according to the time specified in the policy. This value can be modified by calling #soft_delete_policy=.
days.
| 1215 1216 1217 | # File 'lib/google/cloud/storage/bucket.rb', line 1215 def soft_delete_policy @gapi.soft_delete_policy end | 
#soft_delete_policy=(new_soft_delete_policy) ⇒ Object
Sets the value for Soft Delete Policy in the bucket. This value can be queried by calling #soft_delete_policy.
| 1251 1252 1253 1254 | # File 'lib/google/cloud/storage/bucket.rb', line 1251 def soft_delete_policy= new_soft_delete_policy @gapi.soft_delete_policy = new_soft_delete_policy || {} patch_gapi! :soft_delete_policy end | 
#storage_class ⇒ String
The bucket's storage class. This defines how objects in the bucket are
stored and determines the SLA and the cost of storage. Values include
STANDARD, NEARLINE, COLDLINE, and ARCHIVE. REGIONAL,MULTI_REGIONAL,
and DURABLE_REDUCED_AVAILABILITY are supported as legacy storage
classes.
| 404 405 406 | # File 'lib/google/cloud/storage/bucket.rb', line 404 def storage_class @gapi.storage_class end | 
#storage_class=(new_storage_class) ⇒ Object
Updates the bucket's storage class. This defines how objects in the
bucket are stored and determines the SLA and the cost of storage.
Accepted values include :standard, :nearline, :coldline, and
:archive, as well as the equivalent strings returned by
#storage_class. :multi_regional, :regional, and
durable_reduced_availability are accepted as legacy storage classes.
For more information, see Storage
Classes.
To pass metageneration preconditions, call this method within a block passed to #update.
| 423 424 425 426 | # File 'lib/google/cloud/storage/bucket.rb', line 423 def storage_class= new_storage_class @gapi.storage_class = storage_class_for new_storage_class patch_gapi! :storage_class end | 
#test_permissions(*permissions) ⇒ Array<String>
Tests the specified permissions against the Cloud IAM access control policy.
| 2959 2960 2961 2962 2963 2964 2965 | # File 'lib/google/cloud/storage/bucket.rb', line 2959 def * = Array().flatten ensure_service! gapi = service. name, , user_project: user_project gapi. end | 
#uniform_bucket_level_access=(new_uniform_bucket_level_access) ⇒ Object
Sets whether uniform bucket-level access is enabled for this bucket. When this is enabled, access to the bucket will be configured through IAM, and legacy ACL policies will not work. When it is first enabled, #uniform_bucket_level_access_locked_at will be set by the API automatically. The uniform bucket-level access can then be disabled until the time specified, after which it will become immutable and calls to change it will fail. If uniform bucket-level access is enabled, calls to access legacy ACL information will fail.
Before enabling uniform bucket-level access please review uniform bucket-level access.
To pass metageneration preconditions, call this method within a block passed to #update.
| 983 984 985 986 987 988 989 | # File 'lib/google/cloud/storage/bucket.rb', line 983 def uniform_bucket_level_access= new_uniform_bucket_level_access @gapi.iam_configuration ||= API::Bucket::IamConfiguration.new @gapi.iam_configuration.uniform_bucket_level_access ||= \ API::Bucket::IamConfiguration::UniformBucketLevelAccess.new @gapi.iam_configuration.uniform_bucket_level_access.enabled = new_uniform_bucket_level_access patch_gapi! :iam_configuration end | 
#uniform_bucket_level_access? ⇒ Boolean
Whether the bucket's file IAM configuration enables uniform bucket-level access. The default is false. This value can be modified by calling #uniform_bucket_level_access=.
| 946 947 948 949 950 | # File 'lib/google/cloud/storage/bucket.rb', line 946 def uniform_bucket_level_access? return false unless @gapi.iam_configuration&.uniform_bucket_level_access !@gapi.iam_configuration.uniform_bucket_level_access.enabled.nil? && @gapi.iam_configuration.uniform_bucket_level_access.enabled end | 
#uniform_bucket_level_access_locked_at ⇒ DateTime?
The deadline time for disabling uniform bucket-level access by calling #uniform_bucket_level_access=.
After the locked time the uniform bucket-level access setting cannot be changed from true to false.
Corresponds to the property locked_time.
| 1011 1012 1013 1014 | # File 'lib/google/cloud/storage/bucket.rb', line 1011 def uniform_bucket_level_access_locked_at return nil unless @gapi.iam_configuration&.uniform_bucket_level_access @gapi.iam_configuration.uniform_bucket_level_access.locked_time end | 
#update(if_metageneration_match: nil, if_metageneration_not_match: nil) {|bucket| ... } ⇒ Object
Updates the bucket with changes made in the given block in a single PATCH request. The following attributes may be set: #cors, #logging_bucket=, #logging_prefix=, #versioning=, #website_main=, #website_404=, and #requester_pays=.
In addition, the #cors configuration accessible in the block is completely mutable and will be included in the request. (See Cors)
| 1369 1370 1371 1372 1373 1374 1375 1376 1377 1378 1379 1380 | # File 'lib/google/cloud/storage/bucket.rb', line 1369 def update if_metageneration_match: nil, if_metageneration_not_match: nil updater = Updater.new @gapi yield updater # Add check for mutable cors updater.check_for_changed_labels! updater.check_for_mutable_cors! updater.check_for_mutable_lifecycle! return if updater.updates.empty? update_gapi! updater.updates, if_metageneration_match: , if_metageneration_not_match: end | 
#update_autoclass(autoclass_attributes) ⇒ Object
Update method to update all attributes of autoclass of a bucket It accepts params as a Hash of attributes in the following format:
{ enabled: true, terminal_storage_class: "ARCHIVE" }
terminal_storage_class field is optional. It defaults to NEARLINE.
Valid terminal_storage_class values are NEARLINE and ARCHIVE.
| 491 492 493 494 495 496 497 | # File 'lib/google/cloud/storage/bucket.rb', line 491 def update_autoclass autoclass_attributes @gapi.autoclass ||= API::Bucket::Autoclass.new autoclass_attributes.each do |k, v| @gapi.autoclass.send "#{k}=", v end patch_gapi! :autoclass end | 
#update_policy(new_policy) ⇒ Policy Also known as: policy=
Updates the Cloud IAM access control
policy for this bucket. The policy should be read from #policy. See
Policy for an explanation of the
policy etag property and how to modify policies.
You can also update the policy by passing a block to #policy, which will call this method internally after the block completes.
| 2925 2926 2927 2928 2929 2930 | # File 'lib/google/cloud/storage/bucket.rb', line 2925 def update_policy new_policy ensure_service! gapi = service.set_bucket_policy name, new_policy.to_gapi, user_project: user_project new_policy.class.from_gapi gapi end | 
#versioning=(new_versioning) ⇒ Object
Updates whether Object Versioning is enabled for the bucket.
To pass metageneration preconditions, call this method within a block passed to #update.
| 521 522 523 524 525 | # File 'lib/google/cloud/storage/bucket.rb', line 521 def versioning= new_versioning @gapi.versioning ||= API::Bucket::Versioning.new @gapi.versioning.enabled = new_versioning patch_gapi! :versioning end | 
#versioning? ⇒ Boolean
Whether Object Versioning is enabled for the bucket.
| 506 507 508 | # File 'lib/google/cloud/storage/bucket.rb', line 506 def versioning? @gapi.versioning&.enabled? end | 
#website_404 ⇒ String
The page returned from a static website served from the bucket when a site visitor requests a resource that does not exist.
| 569 570 571 | # File 'lib/google/cloud/storage/bucket.rb', line 569 def website_404 @gapi.website&.not_found_page end | 
#website_404=(website_404) ⇒ Object
Updates the page returned from a static website served from the bucket when a site visitor requests a resource that does not exist.
To pass metageneration preconditions, call this method within a block passed to #update.
| 608 609 610 611 612 | # File 'lib/google/cloud/storage/bucket.rb', line 608 def website_404= website_404 @gapi.website ||= API::Bucket::Website.new @gapi.website.not_found_page = website_404 patch_gapi! :website end | 
#website_main ⇒ String
The main page suffix for a static website. If the requested object path is missing, the service will ensure the path has a trailing '/', append this suffix, and attempt to retrieve the resulting object. This allows the creation of index.html objects to represent directory pages.
| 539 540 541 | # File 'lib/google/cloud/storage/bucket.rb', line 539 def website_main @gapi.website&.main_page_suffix end | 
#website_main=(website_main) ⇒ Object
Updates the main page suffix for a static website.
To pass metageneration preconditions, call this method within a block passed to #update.
| 554 555 556 557 558 | # File 'lib/google/cloud/storage/bucket.rb', line 554 def website_main= website_main @gapi.website ||= API::Bucket::Website.new @gapi.website.main_page_suffix = website_main patch_gapi! :website end |