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.
-
#compose(sources, destination, acl: nil, encryption_key: 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, crc32c: nil, md5: nil, metadata: nil, storage_class: nil, encryption_key: nil, kms_key: nil, temporary_hold: nil, event_based_hold: 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.
-
#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_hold
field 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 ⇒ Boolean
Permanently deletes the bucket.
-
#exists? ⇒ Boolean
Determines whether the bucket exists in the Storage service.
-
#file(path, generation: nil, skip_lookup: nil, encryption_key: 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) ⇒ Array<Google::Cloud::Storage::File>
(also: #find_files)
Retrieves a list of files matching the criteria.
-
#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.
-
#policy(force: nil) {|policy| ... } ⇒ Policy
Gets and updates the Cloud IAM access control policy for this bucket.
-
#policy_only=(new_policy_only) ⇒ Object
If enabled, access checks only use bucket-level IAM policies or above, all object ACLs within the bucket are no longer evaluated, and access-control is configured solely through the bucket's IAM policy.
-
#policy_only? ⇒ Boolean
Whether the bucket's file IAM configuration enables Bucket Policy Only.
-
#policy_only_locked_at ⇒ DateTime?
The deadline time for disabling Bucket Policy Only by calling #policy_only=.
-
#post_object(path, policy: nil, issuer: nil, client_email: nil, signing_key: nil, private_key: nil) ⇒ PostObject
Generate a PostObject that includes the fields and url to upload objects via html forms.
-
#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.
-
#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.
-
#signed_url(path = nil, method: nil, expires: nil, content_type: nil, content_md5: nil, headers: nil, issuer: nil, client_email: nil, signing_key: nil, private_key: nil, query: nil, version: nil) ⇒ String
Generates a signed URL.
-
#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.
-
#update {|bucket| ... } ⇒ Object
Updates the bucket with changes made in the given block in a single PATCH request.
-
#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.
1676 1677 1678 |
# File 'lib/google/cloud/storage/bucket.rb', line 1676 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.
126 127 128 |
# File 'lib/google/cloud/storage/bucket.rb', line 126 def api_url @gapi.self_link end |
#compose(sources, destination, acl: nil, encryption_key: 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.
1352 1353 1354 1355 1356 1357 1358 1359 1360 1361 1362 1363 1364 1365 1366 1367 1368 1369 1370 1371 1372 |
# File 'lib/google/cloud/storage/bucket.rb', line 1352 def compose sources, destination, acl: nil, encryption_key: nil ensure_service! sources = Array sources if sources.size < 2 raise ArgumentError, "must provide at least two source files" end = { acl: File::Acl.predefined_rule_for(acl), key: encryption_key, user_project: user_project } destination_gapi = nil if block_given? destination_gapi = API::Object.new updater = File::Updater.new destination_gapi yield updater updater. end gapi = service.compose_file name, sources, destination, destination_gapi, 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.
195 196 197 198 199 200 201 202 203 204 205 |
# File 'lib/google/cloud/storage/bucket.rb', line 195 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, crc32c: nil, md5: nil, metadata: nil, storage_class: nil, encryption_key: nil, kms_key: nil, temporary_hold: nil, event_based_hold: 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.
1238 1239 1240 1241 1242 1243 1244 1245 1246 1247 1248 1249 1250 1251 1252 1253 1254 1255 1256 1257 1258 1259 1260 1261 1262 |
# File 'lib/google/cloud/storage/bucket.rb', line 1238 def create_file file, path = nil, acl: nil, cache_control: nil, content_disposition: nil, content_encoding: nil, content_language: nil, content_type: nil, crc32c: nil, md5: nil, metadata: nil, storage_class: nil, encryption_key: nil, kms_key: nil, temporary_hold: nil, event_based_hold: nil ensure_service! = { acl: File::Acl.predefined_rule_for(acl), md5: md5, cache_control: cache_control, content_type: content_type, 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, user_project: user_project } 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? gapi = service.insert_file name, file, path, 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.
1980 1981 1982 1983 1984 1985 1986 1987 1988 1989 |
# File 'lib/google/cloud/storage/bucket.rb', line 1980 def create_notification topic, custom_attrs: nil, event_types: nil, prefix: nil, payload: nil ensure_service! = { custom_attrs: custom_attrs, event_types: event_types, prefix: prefix, payload: payload, user_project: user_project } gapi = service.insert_notification name, topic, Notification.from_gapi name, gapi, service, user_project: user_project end |
#created_at ⇒ DateTime
Creation time of the bucket.
135 136 137 |
# File 'lib/google/cloud/storage/bucket.rb', line 135 def created_at @gapi.time_created 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.
1722 1723 1724 |
# File 'lib/google/cloud/storage/bucket.rb', line 1722 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.
729 730 731 732 |
# File 'lib/google/cloud/storage/bucket.rb', line 729 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!.
694 695 696 |
# File 'lib/google/cloud/storage/bucket.rb', line 694 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
549 550 551 |
# File 'lib/google/cloud/storage/bucket.rb', line 549 def default_kms_key @gapi.encryption && @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
571 572 573 574 575 |
# File 'lib/google/cloud/storage/bucket.rb', line 571 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 ⇒ 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.
946 947 948 949 950 |
# File 'lib/google/cloud/storage/bucket.rb', line 946 def delete ensure_service! service.delete_bucket name, user_project: user_project true end |
#exists? ⇒ Boolean
Determines whether the bucket exists in the Storage service.
2009 2010 2011 2012 2013 2014 2015 2016 2017 2018 |
# File 'lib/google/cloud/storage/bucket.rb', line 2009 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, skip_lookup: nil, encryption_key: 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.
1044 1045 1046 1047 1048 1049 1050 1051 1052 1053 1054 1055 1056 1057 |
# File 'lib/google/cloud/storage/bucket.rb', line 1044 def file path, generation: nil, skip_lookup: nil, encryption_key: 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, key: encryption_key, user_project: user_project 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) ⇒ Array<Google::Cloud::Storage::File> Also known as: find_files
Retrieves a list of files matching the criteria.
999 1000 1001 1002 1003 1004 1005 1006 1007 1008 |
# File 'lib/google/cloud/storage/bucket.rb', line 999 def files prefix: nil, delimiter: nil, token: nil, max: nil, versions: nil ensure_service! gapi = service.list_files name, prefix: prefix, delimiter: delimiter, token: token, max: max, versions: versions, user_project: user_project File::List.from_gapi gapi, service, name, prefix, delimiter, max, versions, user_project: user_project 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.
458 459 460 461 462 |
# File 'lib/google/cloud/storage/bucket.rb', line 458 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.
469 470 471 472 |
# File 'lib/google/cloud/storage/bucket.rb', line 469 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.
262 263 264 265 266 267 268 269 270 271 272 |
# File 'lib/google/cloud/storage/bucket.rb', line 262 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.
284 285 286 |
# File 'lib/google/cloud/storage/bucket.rb', line 284 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 regionmulti-region
- Highest availability across largest areadual-region
- High availability and low latency across 2 regions
300 301 302 |
# File 'lib/google/cloud/storage/bucket.rb', line 300 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.
772 773 774 775 776 777 |
# File 'lib/google/cloud/storage/bucket.rb', line 772 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.
311 312 313 |
# File 'lib/google/cloud/storage/bucket.rb', line 311 def logging_bucket @gapi.logging.log_bucket if @gapi.logging end |
#logging_bucket=(logging_bucket) ⇒ Object
Updates the destination bucket for the bucket's logs.
322 323 324 325 326 |
# File 'lib/google/cloud/storage/bucket.rb', line 322 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,
335 336 337 |
# File 'lib/google/cloud/storage/bucket.rb', line 335 def logging_prefix @gapi.logging.log_object_prefix if @gapi.logging 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.
351 352 353 354 355 |
# File 'lib/google/cloud/storage/bucket.rb', line 351 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.
144 145 146 |
# File 'lib/google/cloud/storage/bucket.rb', line 144 def @gapi. end |
#name ⇒ String
The name of the bucket.
117 118 119 |
# File 'lib/google/cloud/storage/bucket.rb', line 117 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.
1902 1903 1904 1905 1906 1907 1908 |
# File 'lib/google/cloud/storage/bucket.rb', line 1902 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.
1871 1872 1873 1874 1875 1876 1877 1878 |
# File 'lib/google/cloud/storage/bucket.rb', line 1871 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 |
#policy(force: nil) {|policy| ... } ⇒ Policy
Gets and updates the Cloud IAM access control policy for this bucket.
1767 1768 1769 1770 1771 1772 1773 1774 1775 |
# File 'lib/google/cloud/storage/bucket.rb', line 1767 def policy force: nil warn "DEPRECATED: 'force' in Bucket#policy" unless force.nil? ensure_service! gapi = service.get_bucket_policy name, user_project: user_project policy = Policy.from_gapi gapi return policy unless block_given? yield policy update_policy policy end |
#policy_only=(new_policy_only) ⇒ Object
If enabled, access checks only use bucket-level IAM policies or above, all object ACLs within the bucket are no longer evaluated, and access-control is configured solely through the bucket's IAM policy. Any requests which attempt to use the ACL API to view or manipulate ACLs will fail with 400 errors.
Before enabling Bucket Policy Only please review feature documentation, as well as Should you use Bucket Policy Only?.
842 843 844 845 846 847 848 |
# File 'lib/google/cloud/storage/bucket.rb', line 842 def policy_only= new_policy_only @gapi.iam_configuration ||= API::Bucket::IamConfiguration.new \ bucket_policy_only: \ API::Bucket::IamConfiguration::BucketPolicyOnly.new @gapi.iam_configuration.bucket_policy_only.enabled = new_policy_only patch_gapi! :iam_configuration end |
#policy_only? ⇒ Boolean
Whether the bucket's file IAM configuration enables Bucket Policy Only. The default is false. This value can be modified by calling #policy_only=.
If true, access checks only use bucket-level IAM policies or above, all object ACLs within the bucket are no longer evaluated, and access-control is configured solely through the bucket's IAM policy. Any requests which attempt to use the ACL API to view or manipulate ACLs will fail with 400 errors.
805 806 807 808 809 810 |
# File 'lib/google/cloud/storage/bucket.rb', line 805 def policy_only? return false unless @gapi.iam_configuration && @gapi.iam_configuration.bucket_policy_only !@gapi.iam_configuration.bucket_policy_only.enabled.nil? && @gapi.iam_configuration.bucket_policy_only.enabled end |
#policy_only_locked_at ⇒ DateTime?
The deadline time for disabling Bucket Policy Only by calling
#policy_only=. After the locked time the Bucket Policy Only
setting cannot be changed from true to false. Corresponds to the
property locked_time
.
872 873 874 875 876 |
# File 'lib/google/cloud/storage/bucket.rb', line 872 def policy_only_locked_at return nil unless @gapi.iam_configuration && @gapi.iam_configuration.bucket_policy_only @gapi.iam_configuration.bucket_policy_only.locked_time end |
#post_object(path, policy: nil, issuer: nil, client_email: nil, signing_key: nil, private_key: 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.
1624 1625 1626 1627 1628 1629 1630 1631 1632 1633 |
# File 'lib/google/cloud/storage/bucket.rb', line 1624 def post_object path, policy: nil, issuer: nil, client_email: nil, signing_key: nil, private_key: nil ensure_service! signer = File::SignerV2.from_bucket self, path signer.post_object issuer: issuer, client_email: client_email, signing_key: signing_key, private_key: private_key, policy: policy end |
#reload! ⇒ Object Also known as: refresh!
Reloads the bucket with current data from the Storage service.
1995 1996 1997 1998 1999 2000 2001 |
# File 'lib/google/cloud/storage/bucket.rb', line 1995 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.
497 498 499 |
# File 'lib/google/cloud/storage/bucket.rb', line 497 def requester_pays @gapi.billing.requester_pays if @gapi.billing 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.
523 524 525 526 527 |
# File 'lib/google/cloud/storage/bucket.rb', line 523 def requester_pays= new_requester_pays @gapi.billing ||= API::Bucket::Billing.new @gapi.billing.requester_pays = new_requester_pays patch_gapi! :billing 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.
647 648 649 |
# File 'lib/google/cloud/storage/bucket.rb', line 647 def retention_effective_at @gapi.retention_policy && @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?.
588 589 590 |
# File 'lib/google/cloud/storage/bucket.rb', line 588 def retention_period @gapi.retention_policy && @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?.
623 624 625 626 627 628 629 630 631 632 |
# File 'lib/google/cloud/storage/bucket.rb', line 623 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!.
678 679 680 681 682 |
# File 'lib/google/cloud/storage/bucket.rb', line 678 def retention_policy_locked? return false unless @gapi.retention_policy !@gapi.retention_policy.is_locked.nil? && @gapi.retention_policy.is_locked end |
#signed_url(path = nil, method: nil, expires: nil, content_type: nil, content_md5: nil, headers: nil, issuer: nil, client_email: nil, signing_key: nil, private_key: nil, query: 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.
1501 1502 1503 1504 1505 1506 1507 1508 1509 1510 1511 1512 1513 1514 1515 1516 1517 1518 1519 1520 1521 1522 1523 1524 1525 1526 |
# File 'lib/google/cloud/storage/bucket.rb', line 1501 def signed_url path = nil, method: nil, expires: nil, content_type: nil, content_md5: nil, headers: nil, issuer: nil, client_email: nil, signing_key: nil, private_key: nil, query: nil, version: nil ensure_service! version ||= :v2 case version.to_sym when :v2 signer = File::SignerV2.from_bucket self, path signer.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, query: query when :v4 signer = File::SignerV4.from_bucket self, path signer.signed_url method: method, expires: expires, headers: headers, issuer: issuer, client_email: client_email, signing_key: signing_key, private_key: private_key, query: query else raise ArgumentError, "version '#{version}' not supported" end 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
MULTI_REGIONAL
, REGIONAL
, NEARLINE
, COLDLINE
, and
DURABLE_REDUCED_AVAILABILITY
.
365 366 367 |
# File 'lib/google/cloud/storage/bucket.rb', line 365 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
, and :coldline
, as
well as the equivalent strings returned by #storage_class. For
more information, see Storage
Classes.
379 380 381 382 |
# File 'lib/google/cloud/storage/bucket.rb', line 379 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.
1843 1844 1845 1846 1847 1848 1849 |
# File 'lib/google/cloud/storage/bucket.rb', line 1843 def * = Array().flatten ensure_service! gapi = service. name, , user_project: user_project gapi. end |
#update {|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)
919 920 921 922 923 924 925 926 927 |
# File 'lib/google/cloud/storage/bucket.rb', line 919 def update 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! patch_gapi! updater.updates unless updater.updates.empty? 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.
1809 1810 1811 1812 1813 1814 |
# File 'lib/google/cloud/storage/bucket.rb', line 1809 def update_policy new_policy ensure_service! gapi = service.set_bucket_policy name, new_policy.to_gapi, user_project: user_project Policy.from_gapi gapi end |
#versioning=(new_versioning) ⇒ Object
Updates whether Object Versioning is enabled for the bucket.
403 404 405 406 407 |
# File 'lib/google/cloud/storage/bucket.rb', line 403 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.
391 392 393 |
# File 'lib/google/cloud/storage/bucket.rb', line 391 def versioning? @gapi.versioning.enabled? unless @gapi.versioning.nil? 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.
448 449 450 |
# File 'lib/google/cloud/storage/bucket.rb', line 448 def website_404 @gapi.website.not_found_page if @gapi.website 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.
481 482 483 484 485 |
# File 'lib/google/cloud/storage/bucket.rb', line 481 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.
421 422 423 |
# File 'lib/google/cloud/storage/bucket.rb', line 421 def website_main @gapi.website.main_page_suffix if @gapi.website end |
#website_main=(website_main) ⇒ Object
Updates the main page suffix for a static website.
433 434 435 436 437 |
# File 'lib/google/cloud/storage/bucket.rb', line 433 def website_main= website_main @gapi.website ||= API::Bucket::Website.new @gapi.website.main_page_suffix = website_main patch_gapi! :website end |