Class: Google::Cloud::Storage::File
- Inherits:
-
Object
- Object
- Google::Cloud::Storage::File
- Defined in:
- lib/google/cloud/storage/file.rb,
lib/google/cloud/storage/file/acl.rb,
lib/google/cloud/storage/file/list.rb,
lib/google/cloud/storage/file/verifier.rb,
lib/google/cloud/storage/file/signer_v2.rb,
lib/google/cloud/storage/file/signer_v4.rb
Overview
File
Represents a File (Object) that belongs to a Bucket. Files (Objects) are the individual pieces of data that you store in Google Cloud Storage. A file can be up to 5 TB in size. Files have two components: data and metadata. The data component is the data from an external file or other data source that you want to store in Google Cloud Storage. The metadata component is a collection of name-value pairs that describe various qualities of the data.
Direct Known Subclasses
Defined Under Namespace
Instance Attribute Summary collapse
-
#user_project ⇒ Object
If this attribute is set to
true
, transit costs for operations on the file will be billed to the current project for this client.
Instance Method Summary collapse
-
#acl ⇒ File::Acl
The Acl instance used to control access to the file.
-
#api_url ⇒ String
A URL that can be used to access the file using the REST API.
-
#bucket ⇒ String
The name of the Bucket containing this file.
-
#cache_control ⇒ String
The Cache-Control directive for the file data.
-
#cache_control=(cache_control) ⇒ Object
Updates the Cache-Control directive for the file data.
-
#content_disposition ⇒ String
The Content-Disposition of the file data.
-
#content_disposition=(content_disposition) ⇒ Object
Updates the Content-Disposition of the file data.
-
#content_encoding ⇒ String
The Content-Encoding of the file data.
-
#content_encoding=(content_encoding) ⇒ Object
Updates the Content-Encoding of the file data.
-
#content_language ⇒ String
The Content-Language of the file data.
-
#content_language=(content_language) ⇒ Object
Updates the Content-Language of the file data.
-
#content_type ⇒ String
The Content-Type of the file data.
-
#content_type=(content_type) ⇒ Object
Updates the Content-Type of the file data.
-
#copy(dest_bucket_or_path, dest_path = nil, acl: nil, generation: nil, encryption_key: nil, force_copy_metadata: nil) {|file| ... } ⇒ Google::Cloud::Storage::File
Copies the file to a new location.
-
#crc32c ⇒ String
The CRC32c checksum of the data, as described in RFC 4960, Appendix B.
-
#created_at ⇒ DateTime
Creation time of the file.
-
#custom_time ⇒ DateTime?
A custom time specified by the user for the file, or
nil
. -
#custom_time=(custom_time) ⇒ Object
Updates the custom time specified by the user for the file.
-
#delete(generation: nil, if_generation_match: nil, if_generation_not_match: nil, if_metageneration_match: nil, if_metageneration_not_match: nil) ⇒ Boolean
Permanently deletes the file.
-
#download(path = nil, verify: :md5, encryption_key: nil, range: nil, skip_decompress: nil) ⇒ ::File, StringIO
Downloads the file's contents to a local file or an File-like object.
-
#encryption_key_sha256 ⇒ String?
An RFC 4648 Base64-encoded string of the SHA256 hash of the customer-supplied encryption key.
-
#etag ⇒ String
HTTP 1.1 Entity tag for the file.
-
#event_based_hold? ⇒ Boolean
Whether there is an event-based hold on the file.
-
#exists? ⇒ Boolean
Determines whether the file exists in the Storage service.
-
#generation ⇒ Fixnum
The content generation of this file.
-
#generations ⇒ Array<Google::Cloud::Storage::File>
Retrieves a list of versioned files for the current object.
-
#id ⇒ String
The ID of the file.
-
#kind ⇒ String
The kind of item this is.
-
#kms_key ⇒ String?
The Cloud KMS encryption key that was used to protect the file, or
nil
if none has been configured. -
#md5 ⇒ String
MD5 hash of the data; encoded using base64.
-
#media_url ⇒ String
A URL that can be used to download the file using the REST API.
-
#metadata ⇒ Hash(String => String)
A hash of custom, user-provided web-safe keys and arbitrary string values that will returned with requests for the file as "x-goog-meta-" response headers.
-
#metadata=(metadata) ⇒ Object
Updates the hash of custom, user-provided web-safe keys and arbitrary string values that will returned with requests for the file as "x-goog-meta-" response headers.
-
#metageneration ⇒ Fixnum
The version of the metadata for this file at this generation.
-
#name ⇒ String
The name of this file.
-
#public_url(protocol: :https) ⇒ String
(also: #url)
Public URL to access the file.
-
#release_event_based_hold! ⇒ Object
Sets the event-based hold property of the file to
false
. -
#release_temporary_hold! ⇒ Object
Sets the temporary hold property of the file to
false
. -
#reload!(generation: nil) ⇒ Object
(also: #refresh!)
Reloads the file with current data from the Storage service.
-
#retention ⇒ Google::Apis::StorageV1::Object::Retention
A collection of object level retention parameters.
-
#retention=(new_retention_attributes) ⇒ Object
Update method to update retention parameter of an object / file It accepts params as a Hash of attributes in the following format:.
-
#retention_expires_at ⇒ DateTime?
The retention expiration time of the file.
-
#retention_mode ⇒ String
Mode of object level retention configuration.
-
#retention_retain_until_time ⇒ DateTime
The earliest time in RFC 3339 UTC "Zulu" format that the object can be deleted or replaced.
-
#rewrite(dest_bucket_or_path, dest_path = nil, acl: nil, generation: nil, if_generation_match: nil, if_generation_not_match: nil, if_metageneration_match: nil, if_metageneration_not_match: nil, if_source_generation_match: nil, if_source_generation_not_match: nil, if_source_metageneration_match: nil, if_source_metageneration_not_match: nil, encryption_key: nil, new_encryption_key: nil, new_kms_key: nil, force_copy_metadata: nil) {|file| ... } ⇒ Google::Cloud::Storage::File
Rewrites the file to a new location.
-
#rotate(encryption_key: nil, new_encryption_key: nil, new_kms_key: nil) ⇒ Google::Cloud::Storage::File
Rewrites the file to the same #bucket and #name with a new customer-supplied encryption key.
-
#set_event_based_hold! ⇒ Object
Sets the event-based hold property of the file to
true
. -
#set_temporary_hold! ⇒ Object
Sets the temporary hold property of the file to
true
. -
#signed_url(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 for the file.
-
#size ⇒ Integer
Content-Length of the data in bytes.
-
#storage_class ⇒ String
The file's storage class.
-
#storage_class=(storage_class) ⇒ Object
Rewrites the file with a new storage class, which determines the SLA and the cost of storage.
-
#temporary_hold? ⇒ Boolean
Whether there is a temporary hold on the file.
-
#update(generation: nil, if_generation_match: nil, if_generation_not_match: nil, if_metageneration_match: nil, if_metageneration_not_match: nil, override_unlocked_retention: nil) {|file| ... } ⇒ Object
Updates the file with changes made in the given block in a single PATCH request.
-
#updated_at ⇒ DateTime
The creation or modification time of the file.
Instance Attribute Details
#user_project ⇒ Object
If this attribute is set to true
, transit costs for operations on
the file 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
owning bucket by providing the user_project
option to
Project#bucket or Project#buckets.
See also Bucket#requester_pays= and Bucket#requester_pays.
97 98 99 |
# File 'lib/google/cloud/storage/file.rb', line 97 def user_project @user_project end |
Instance Method Details
#acl ⇒ File::Acl
The Acl instance used to control access to the file.
A file 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.
1938 1939 1940 |
# File 'lib/google/cloud/storage/file.rb', line 1938 def acl @acl ||= File::Acl.new self end |
#api_url ⇒ String
A URL that can be used to access the file using the REST API.
175 176 177 |
# File 'lib/google/cloud/storage/file.rb', line 175 def api_url @gapi.self_link end |
#bucket ⇒ String
The name of the Bucket containing this file.
144 145 146 |
# File 'lib/google/cloud/storage/file.rb', line 144 def bucket @gapi.bucket end |
#cache_control ⇒ String
The Cache-Control
directive for the file data. If omitted, and the file is accessible
to all anonymous users, the default will be public, max-age=3600
.
253 254 255 |
# File 'lib/google/cloud/storage/file.rb', line 253 def cache_control @gapi.cache_control end |
#cache_control=(cache_control) ⇒ Object
Updates the
Cache-Control
directive for the file data. If omitted, and the file is accessible
to all anonymous users, the default will be public, max-age=3600
.
To pass generation and/or metageneration preconditions, call this method within a block passed to #update.
268 269 270 271 |
# File 'lib/google/cloud/storage/file.rb', line 268 def cache_control= cache_control @gapi.cache_control = cache_control update_gapi! :cache_control end |
#content_disposition ⇒ String
The Content-Disposition of the file data.
279 280 281 |
# File 'lib/google/cloud/storage/file.rb', line 279 def content_disposition @gapi.content_disposition end |
#content_disposition=(content_disposition) ⇒ Object
Updates the Content-Disposition of the file data.
To pass generation and/or metageneration preconditions, call this method within a block passed to #update.
293 294 295 296 |
# File 'lib/google/cloud/storage/file.rb', line 293 def content_disposition= content_disposition @gapi.content_disposition = content_disposition update_gapi! :content_disposition end |
#content_encoding ⇒ String
The Content-Encoding of the file data.
305 306 307 |
# File 'lib/google/cloud/storage/file.rb', line 305 def content_encoding @gapi.content_encoding end |
#content_encoding=(content_encoding) ⇒ Object
Updates the Content-Encoding of the file data.
To pass generation and/or metageneration preconditions, call this method within a block passed to #update.
319 320 321 322 |
# File 'lib/google/cloud/storage/file.rb', line 319 def content_encoding= content_encoding @gapi.content_encoding = content_encoding update_gapi! :content_encoding end |
#content_language ⇒ String
The Content-Language of the file data.
330 331 332 |
# File 'lib/google/cloud/storage/file.rb', line 330 def content_language @gapi.content_language end |
#content_language=(content_language) ⇒ Object
Updates the Content-Language of the file data.
To pass generation and/or metageneration preconditions, call this method within a block passed to #update.
343 344 345 346 |
# File 'lib/google/cloud/storage/file.rb', line 343 def content_language= content_language @gapi.content_language = content_language update_gapi! :content_language end |
#content_type ⇒ String
The Content-Type of the file data.
354 355 356 |
# File 'lib/google/cloud/storage/file.rb', line 354 def content_type @gapi.content_type end |
#content_type=(content_type) ⇒ Object
Updates the Content-Type of the file data.
To pass generation and/or metageneration preconditions, call this method within a block passed to #update.
368 369 370 371 |
# File 'lib/google/cloud/storage/file.rb', line 368 def content_type= content_type @gapi.content_type = content_type update_gapi! :content_type end |
#copy(dest_bucket_or_path, dest_path = nil, acl: nil, generation: nil, encryption_key: nil, force_copy_metadata: nil) {|file| ... } ⇒ Google::Cloud::Storage::File
Copies the file to a new location. Metadata excluding ACL from the source object will be copied to the destination object unless a block is provided.
If an optional block for updating is provided, only the updates made in
this block will appear in the destination object, and other metadata
fields in the destination object will not be copied. To copy the other
source file metadata fields while updating destination fields in a
block, use the force_copy_metadata: true
flag, and the client library
will copy metadata from source metadata into the copy request.
If a customer-supplied encryption
key
was used with Bucket#create_file, the encryption_key
option must
be provided.
1166 1167 1168 1169 1170 1171 1172 1173 1174 1175 |
# File 'lib/google/cloud/storage/file.rb', line 1166 def copy dest_bucket_or_path, dest_path = nil, acl: nil, generation: nil, encryption_key: nil, force_copy_metadata: nil rewrite dest_bucket_or_path, dest_path, acl: acl, generation: generation, encryption_key: encryption_key, new_encryption_key: encryption_key, force_copy_metadata: do |updater| yield updater if block_given? end end |
#crc32c ⇒ String
The CRC32c checksum of the data, as described in RFC 4960, Appendix B. Encoded using base64 in big-endian byte order.
233 234 235 |
# File 'lib/google/cloud/storage/file.rb', line 233 def crc32c @gapi.crc32c end |
#created_at ⇒ DateTime
Creation time of the file.
202 203 204 |
# File 'lib/google/cloud/storage/file.rb', line 202 def created_at @gapi.time_created end |
#custom_time ⇒ DateTime?
A custom time specified by the user for the file, or nil
.
378 379 380 |
# File 'lib/google/cloud/storage/file.rb', line 378 def custom_time @gapi.custom_time end |
#custom_time=(custom_time) ⇒ Object
Updates the custom time specified by the user for the file. Once set, custom_time can't be unset, and it can only be changed to a time in the future. If custom_time must be unset, you must either perform a rewrite operation, or upload the data again and create a new file.
To pass generation and/or metageneration preconditions, call this method within a block passed to #update.
394 395 396 397 |
# File 'lib/google/cloud/storage/file.rb', line 394 def custom_time= custom_time @gapi.custom_time = custom_time update_gapi! :custom_time end |
#delete(generation: nil, if_generation_match: nil, if_generation_not_match: nil, if_metageneration_match: nil, if_metageneration_not_match: nil) ⇒ Boolean
Permanently deletes the file.
Raises PermissionDeniedError if the object is subject to an active retention policy or hold. (See #retention_expires_at, Bucket#retention_period, #temporary_hold? and #event_based_hold?.)
1550 1551 1552 1553 1554 1555 1556 1557 1558 1559 1560 1561 1562 1563 1564 1565 1566 |
# File 'lib/google/cloud/storage/file.rb', line 1550 def delete generation: nil, if_generation_match: nil, if_generation_not_match: nil, if_metageneration_match: nil, if_metageneration_not_match: nil generation = self.generation if generation == true ensure_service! service.delete_file bucket, name, generation: generation, 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 true end |
#download(path = nil, verify: :md5, encryption_key: nil, range: nil, skip_decompress: nil) ⇒ ::File, StringIO
Downloads the file's contents to a local file or an File-like object.
By default, the download is verified by calculating the MD5 digest.
If a customer-supplied encryption
key
was used with Bucket#create_file, the encryption_key
option must
be provided.
1038 1039 1040 1041 1042 1043 1044 1045 1046 1047 1048 1049 1050 1051 1052 1053 1054 1055 1056 1057 1058 |
# File 'lib/google/cloud/storage/file.rb', line 1038 def download path = nil, verify: :md5, encryption_key: nil, range: nil, skip_decompress: nil ensure_service! if path.nil? path = StringIO.new path.set_encoding "ASCII-8BIT" end file, resp = service.download_file bucket, name, path, generation: generation, key: encryption_key, range: range, user_project: user_project # FIX: downloading with encryption key will return nil file ||= ::File.new path verify = :none if range verify_file! file, verify if !skip_decompress && Array(resp.header["Content-Encoding"]).include?("gzip") file = gzip_decompress file end file end |
#encryption_key_sha256 ⇒ String?
An RFC 4648 Base64-encoded string of the SHA256 hash of the customer-supplied encryption key. You can use this SHA256 hash to uniquely identify the AES-256 encryption key required to decrypt this file.
439 440 441 442 |
# File 'lib/google/cloud/storage/file.rb', line 439 def encryption_key_sha256 return nil unless @gapi.customer_encryption Base64.decode64 @gapi.customer_encryption.key_sha256 end |
#etag ⇒ String
HTTP 1.1 Entity tag for the file.
242 243 244 |
# File 'lib/google/cloud/storage/file.rb', line 242 def etag @gapi.etag end |
#event_based_hold? ⇒ Boolean
Whether there is an event-based hold on the file. An event-based
hold will be enforced on the file as long as this property is true
,
even if the bucket-level retention policy would normally allow
deletion. Removing the event-based hold extends the retention duration
of the file to the current date plus the bucket-level policy duration.
Removing the event-based hold represents that a retention-related
event has occurred, and thus the retention clock ticks from the moment
of the event as opposed to the creation date of the object. The
default value is configured at the bucket level (which defaults to
false
), and is assigned to newly-created objects.
See #set_event_based_hold!, #release_event_based_hold!, Bucket#default_event_based_hold? and Bucket#default_event_based_hold=.
If a bucket's retention policy duration is modified after the event-based hold flag is unset, the updated retention duration applies retroactively to objects that previously had event-based holds. For example:
- If the bucket's [unlocked] retention policy is removed, objects with event-based holds may be deleted immediately after the hold is removed (the duration of a nonexistent policy for the purpose of event-based holds is considered to be zero).
- If the bucket's [unlocked] policy is reduced, objects with previously released event-based holds will be have their retention expiration dates reduced accordingly.
- If the bucket's policy is extended, objects with previously released event-based holds will have their retention expiration dates extended accordingly. However, note that objects with event-based holds released prior to the effective date of the new policy may have already been deleted by the user.
642 643 644 |
# File 'lib/google/cloud/storage/file.rb', line 642 def event_based_hold? !@gapi.event_based_hold.nil? && @gapi.event_based_hold end |
#exists? ⇒ Boolean
Determines whether the file exists in the Storage service.
1994 1995 1996 1997 1998 1999 2000 2001 2002 2003 |
# File 'lib/google/cloud/storage/file.rb', line 1994 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 |
#generation ⇒ Fixnum
The content generation of this file. Used for object versioning.
154 155 156 |
# File 'lib/google/cloud/storage/file.rb', line 154 def generation @gapi.generation end |
#generations ⇒ Array<Google::Cloud::Storage::File>
Retrieves a list of versioned files for the current object.
Useful for listing archived versions of the file, restoring the live version of the file to an older version, or deleting an archived version. You can turn versioning on or off for a bucket at any time with Bucket#versioning=. Turning versioning off leaves existing file versions in place and causes the bucket to stop accumulating new archived object versions. (See Bucket#versioning? and #generation)
796 797 798 799 800 801 802 803 |
# File 'lib/google/cloud/storage/file.rb', line 796 def generations ensure_service! gapi = service.list_files bucket, prefix: name, versions: true, user_project: user_project File::List.from_gapi gapi, service, bucket, name, nil, nil, true, user_project: user_project end |
#id ⇒ String
The ID of the file.
126 127 128 |
# File 'lib/google/cloud/storage/file.rb', line 126 def id @gapi.id end |
#kind ⇒ String
The kind of item this is. For files, this is always storage#object.
117 118 119 |
# File 'lib/google/cloud/storage/file.rb', line 117 def kind @gapi.kind end |
#kms_key ⇒ String?
The Cloud KMS encryption key that was used to protect the file, or
nil
if none has been configured.
454 455 456 |
# File 'lib/google/cloud/storage/file.rb', line 454 def kms_key @gapi.kms_key_name end |
#md5 ⇒ String
MD5 hash of the data; encoded using base64.
222 223 224 |
# File 'lib/google/cloud/storage/file.rb', line 222 def md5 @gapi.md5_hash end |
#media_url ⇒ String
A URL that can be used to download the file using the REST API.
184 185 186 |
# File 'lib/google/cloud/storage/file.rb', line 184 def media_url @gapi.media_link end |
#metadata ⇒ Hash(String => String)
A hash of custom, user-provided web-safe keys and arbitrary string values that will returned with requests for the file as "x-goog-meta-" response headers.
406 407 408 409 410 |
# File 'lib/google/cloud/storage/file.rb', line 406 def m = @gapi. m = m.to_h if m.respond_to? :to_h m.dup.freeze end |
#metadata=(metadata) ⇒ Object
Updates the hash of custom, user-provided web-safe keys and arbitrary string values that will returned with requests for the file as "x-goog-meta-" response headers.
To pass generation and/or metageneration preconditions, call this method within a block passed to #update.
423 424 425 426 |
# File 'lib/google/cloud/storage/file.rb', line 423 def @gapi. = update_gapi! :metadata end |
#metageneration ⇒ Fixnum
The version of the metadata for this file at this generation. Used for preconditions and for detecting changes in metadata. A metageneration number is only meaningful in the context of a particular generation of a particular file.
166 167 168 |
# File 'lib/google/cloud/storage/file.rb', line 166 def @gapi. end |
#name ⇒ String
The name of this file.
135 136 137 |
# File 'lib/google/cloud/storage/file.rb', line 135 def name @gapi.name end |
#public_url(protocol: :https) ⇒ String Also known as: url
Public URL to access the file. If the file is not public, requests to the URL will return an error. (See Google::Cloud::Storage::File::Acl#public! and Bucket::DefaultAcl#public!) To share a file that is not public see #signed_url.
1658 1659 1660 |
# File 'lib/google/cloud/storage/file.rb', line 1658 def public_url protocol: :https "#{protocol}://storage.googleapis.com/#{bucket}/#{name}" end |
#release_event_based_hold! ⇒ Object
Sets the event-based hold property of the file to false
. Removing
the event-based hold extends the retention duration of the file to the
current date plus the bucket-level policy duration. Removing the
event-based hold represents that a retention-related event has
occurred, and thus the retention clock ticks from the moment of the
event as opposed to the creation date of the object. The default value
is configured at the bucket level (which defaults to false
), and is
assigned to newly-created objects.
See #event_based_hold?, #set_event_based_hold!, Bucket#default_event_based_hold? and Bucket#default_event_based_hold=.
To pass generation and/or metageneration preconditions, call this method within a block passed to #update.
739 740 741 742 |
# File 'lib/google/cloud/storage/file.rb', line 739 def release_event_based_hold! @gapi.event_based_hold = false update_gapi! :event_based_hold end |
#release_temporary_hold! ⇒ Object
Sets the temporary hold property of the file to false
. This property
is used to enforce a temporary hold on a file. While it is set to
true
, the file is protected against deletion and overwrites. Once
removed, the file's retention_expires_at
date is not changed. The
default value is false
.
To pass generation and/or metageneration preconditions, call this method within a block passed to #update.
581 582 583 584 |
# File 'lib/google/cloud/storage/file.rb', line 581 def release_temporary_hold! @gapi.temporary_hold = false update_gapi! :temporary_hold end |
#reload!(generation: nil) ⇒ Object Also known as: refresh!
Reloads the file with current data from the Storage service.
1981 1982 1983 1984 1985 1986 1987 1988 1989 |
# File 'lib/google/cloud/storage/file.rb', line 1981 def reload! generation: nil generation = self.generation if generation == true ensure_service! @gapi = service.get_file bucket, name, generation: generation, user_project: user_project # If NotFound then lazy will never be unset @lazy = nil self end |
#retention ⇒ Google::Apis::StorageV1::Object::Retention
A collection of object level retention parameters. The full list of available options are outlined at the JSON API docs.
1589 1590 1591 |
# File 'lib/google/cloud/storage/file.rb', line 1589 def retention @gapi.retention end |
#retention=(new_retention_attributes) ⇒ Object
Update method to update retention parameter of an object / file It accepts params as a Hash of attributes in the following format:
{ mode: 'Locked|Unlocked', retain_until_time: '2023-12-19T03:22:23+00:00' }
1619 1620 1621 1622 1623 1624 |
# File 'lib/google/cloud/storage/file.rb', line 1619 def retention= new_retention_attributes @gapi.retention ||= Google::Apis::StorageV1::Object::Retention.new @gapi.retention.mode = new_retention_attributes[:mode] @gapi.retention.retain_until_time = new_retention_attributes[:retain_until_time] update_gapi! :retention, override_unlocked_retention: new_retention_attributes[:override_unlocked_retention] end |
#retention_expires_at ⇒ DateTime?
The retention expiration time of the file. This field is indirectly mutable when the retention policy applicable to the object changes. The date represents the earliest time that the object could be deleted, assuming no temporary hold is set. (See #temporary_hold?.) It is provided when both of the following are true:
- There is a retention policy on the bucket.
- The eventBasedHold flag is unset on the object.
Note that it can be provided even when #temporary_hold? is true
(so that the user can reason about policy without having to first
unset the temporary hold).
762 763 764 |
# File 'lib/google/cloud/storage/file.rb', line 762 def retention_expires_at @gapi.retention_expiration_time end |
#retention_mode ⇒ String
Mode of object level retention configuration. Valid values are 'Locked' or 'Unlocked'
1572 1573 1574 |
# File 'lib/google/cloud/storage/file.rb', line 1572 def retention_mode @gapi.retention&.mode end |
#retention_retain_until_time ⇒ DateTime
The earliest time in RFC 3339 UTC "Zulu" format that the object can be deleted or replaced.
1580 1581 1582 |
# File 'lib/google/cloud/storage/file.rb', line 1580 def retention_retain_until_time @gapi.retention&.retain_until_time end |
#rewrite(dest_bucket_or_path, dest_path = nil, acl: nil, generation: nil, if_generation_match: nil, if_generation_not_match: nil, if_metageneration_match: nil, if_metageneration_not_match: nil, if_source_generation_match: nil, if_source_generation_not_match: nil, if_source_metageneration_match: nil, if_source_metageneration_not_match: nil, encryption_key: nil, new_encryption_key: nil, new_kms_key: nil, force_copy_metadata: nil) {|file| ... } ⇒ Google::Cloud::Storage::File
Rewrites the file to a new location. Or the same location can be provided to rewrite the file in place. Metadata from the source object will be copied to the destination object unless a block is provided.
If an optional block for updating is provided, only the updates made in
this block will appear in the destination object, and other metadata
fields in the destination object will not be copied. To copy the other
source file metadata fields while updating destination fields in a
block, use the force_copy_metadata: true
flag, and the client library
will copy metadata from source metadata into the copy request.
If a customer-supplied encryption
key
was used with Bucket#create_file, the encryption_key
option must
be provided. Unlike #copy, separate encryption keys are used to read
(encryption_key) and to write (new_encryption_key) file contents.
1363 1364 1365 1366 1367 1368 1369 1370 1371 1372 1373 1374 1375 1376 1377 1378 1379 1380 1381 1382 1383 1384 1385 1386 1387 1388 1389 1390 1391 1392 1393 1394 1395 1396 1397 1398 1399 1400 1401 1402 1403 1404 1405 1406 1407 1408 1409 1410 1411 1412 1413 1414 |
# File 'lib/google/cloud/storage/file.rb', line 1363 def rewrite dest_bucket_or_path, dest_path = nil, acl: nil, generation: nil, if_generation_match: nil, if_generation_not_match: nil, if_metageneration_match: nil, if_metageneration_not_match: nil, if_source_generation_match: nil, if_source_generation_not_match: nil, if_source_metageneration_match: nil, if_source_metageneration_not_match: nil, encryption_key: nil, new_encryption_key: nil, new_kms_key: nil, force_copy_metadata: nil ensure_service! dest_bucket, dest_path = fix_rewrite_args dest_bucket_or_path, dest_path update_gapi = nil if block_given? updater = Updater.new gapi.dup yield updater updater. if updater.updates.any? attributes = ? (Updater::COPY_ATTRS + updater.updates).uniq : updater.updates update_gapi = self.class.gapi_from_attrs updater.gapi, attributes end end new_gapi = rewrite_gapi bucket, name, update_gapi, new_bucket: dest_bucket, new_name: dest_path, acl: acl, generation: generation, if_generation_match: if_generation_match, if_generation_not_match: if_generation_not_match, if_metageneration_match: , if_metageneration_not_match: , if_source_generation_match: if_source_generation_match, if_source_generation_not_match: if_source_generation_not_match, if_source_metageneration_match: , if_source_metageneration_not_match: , encryption_key: encryption_key, new_encryption_key: new_encryption_key, new_kms_key: new_kms_key, user_project: user_project File.from_gapi new_gapi, service, user_project: user_project end |
#rotate(encryption_key: nil, new_encryption_key: nil, new_kms_key: nil) ⇒ Google::Cloud::Storage::File
Rewrites the file to the same #bucket and #name with a new customer-supplied encryption key.
If a new key is provided to this method, the new key must be used to subsequently download or copy the file. 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.
1484 1485 1486 1487 1488 1489 |
# File 'lib/google/cloud/storage/file.rb', line 1484 def rotate encryption_key: nil, new_encryption_key: nil, new_kms_key: nil rewrite bucket, name, encryption_key: encryption_key, new_encryption_key: new_encryption_key, new_kms_key: new_kms_key end |
#set_event_based_hold! ⇒ Object
Sets the event-based hold property of the file to true
. This
property enforces an event-based hold on the file as long as this
property is true
, even if the bucket-level retention policy would
normally allow deletion. The default value is configured at the
bucket level (which defaults to false
), and is assigned to
newly-created objects.
See #event_based_hold?, #release_event_based_hold!, Bucket#default_event_based_hold? and Bucket#default_event_based_hold=.
If a bucket's retention policy duration is modified after the event-based hold is removed, the updated retention duration applies retroactively to objects that previously had event-based holds. For example:
- If the bucket's [unlocked] retention policy is removed, objects with event-based holds may be deleted immediately after the hold is removed (the duration of a nonexistent policy for the purpose of event-based holds is considered to be zero).
- If the bucket's [unlocked] policy is reduced, objects with previously released event-based holds will be have their retention expiration dates reduced accordingly.
- If the bucket's policy is extended, objects with previously released event-based holds will have their retention expiration dates extended accordingly. However, note that objects with event-based holds released prior to the effective date of the new policy may have already been deleted by the user.
To pass generation and/or metageneration preconditions, call this method within a block passed to #update.
698 699 700 701 |
# File 'lib/google/cloud/storage/file.rb', line 698 def set_event_based_hold! @gapi.event_based_hold = true update_gapi! :event_based_hold end |
#set_temporary_hold! ⇒ Object
Sets the temporary hold property of the file to true
. This property
is used to enforce a temporary hold on a file. While it is set to
true
, the file is protected against deletion and overwrites. Once
removed, the file's retention_expires_at
date is not changed. The
default value is false
.
To pass generation and/or metageneration preconditions, call this method within a block passed to #update.
549 550 551 552 |
# File 'lib/google/cloud/storage/file.rb', line 549 def set_temporary_hold! @gapi.temporary_hold = true update_gapi! :temporary_hold end |
#signed_url(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 for the file. 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.
1844 1845 1846 1847 1848 1849 1850 1851 1852 1853 1854 1855 1856 1857 1858 1859 1860 1861 1862 1863 1864 1865 1866 1867 1868 1869 1870 1871 1872 1873 1874 1875 1876 1877 1878 1879 1880 1881 1882 1883 1884 1885 1886 1887 1888 1889 1890 1891 1892 |
# File 'lib/google/cloud/storage/file.rb', line 1844 def signed_url 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_file self 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_file self 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 |
#size ⇒ Integer
Content-Length of the data in bytes.
193 194 195 |
# File 'lib/google/cloud/storage/file.rb', line 193 def size @gapi.size&.to_i end |
#storage_class ⇒ String
The file's storage class. This defines how the file is stored and determines the SLA and the cost of storage. For more information, see Storage Classes and Per-Object Storage Class.
468 469 470 |
# File 'lib/google/cloud/storage/file.rb', line 468 def storage_class @gapi.storage_class end |
#storage_class=(storage_class) ⇒ Object
Rewrites the file with a new storage class, which determines the SLA and the cost of storage. Accepted values include:
:standard
:nearline
:coldline
:archive
as well as the equivalent strings returned by #storage_class or Bucket#storage_class. For more information, see Storage Classes and Per-Object Storage Class. The default value is the default storage class for the bucket. See Bucket#storage_class.
To pass generation and/or metageneration preconditions, call this method within a block passed to #update.
494 495 496 497 |
# File 'lib/google/cloud/storage/file.rb', line 494 def storage_class= storage_class @gapi.storage_class = storage_class_for storage_class update_gapi! :storage_class end |
#temporary_hold? ⇒ Boolean
Whether there is a temporary hold on the file. A temporary hold will
be enforced on the file as long as this property is true
, even if
the bucket-level retention policy would normally allow deletion. When
the temporary hold is removed, the normal bucket-level policy rules
once again apply. The default value is false
.
521 522 523 |
# File 'lib/google/cloud/storage/file.rb', line 521 def temporary_hold? !@gapi.temporary_hold.nil? && @gapi.temporary_hold end |
#update(generation: nil, if_generation_match: nil, if_generation_not_match: nil, if_metageneration_match: nil, if_metageneration_not_match: nil, override_unlocked_retention: nil) {|file| ... } ⇒ Object
Updates the file with changes made in the given block in a single PATCH request. The following attributes may be set: #cache_control=, #content_disposition=, #content_encoding=, #content_language=, #content_type=, #custom_time= and #metadata=. The #metadata hash accessible in the block is completely mutable and will be included in the request.
867 868 869 870 871 872 873 874 875 876 877 878 879 880 881 882 883 884 |
# File 'lib/google/cloud/storage/file.rb', line 867 def update generation: nil, if_generation_match: nil, if_generation_not_match: nil, if_metageneration_match: nil, if_metageneration_not_match: nil, override_unlocked_retention: nil updater = Updater.new gapi yield updater updater. return if updater.updates.empty? update_gapi! updater.updates, generation: generation, if_generation_match: if_generation_match, if_generation_not_match: if_generation_not_match, if_metageneration_match: , if_metageneration_not_match: , override_unlocked_retention: override_unlocked_retention end |
#updated_at ⇒ DateTime
The creation or modification time of the file. For buckets with versioning enabled, changing an object's metadata does not change this property.
213 214 215 |
# File 'lib/google/cloud/storage/file.rb', line 213 def updated_at @gapi.updated end |