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
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 Method Summary collapse
-
#acl ⇒ Object
The Acl instance used to control access to the file.
-
#api_url ⇒ Object
A URL that can be used to access the file using the REST API.
-
#bucket ⇒ Object
The name of the Bucket containing this file.
-
#cache_control ⇒ Object
The Cache-Control directive for the file data.
-
#cache_control=(cache_control) ⇒ Object
Updates the Cache-Control directive for the file data.
-
#content_disposition ⇒ Object
The Content-Disposition of the file data.
-
#content_disposition=(content_disposition) ⇒ Object
Updates the Content-Disposition of the file data.
-
#content_encoding ⇒ Object
The Content-Encoding of the file data.
-
#content_encoding=(content_encoding) ⇒ Object
Updates the Content-Encoding of the file data.
-
#content_language ⇒ Object
The Content-Language of the file data.
-
#content_language=(content_language) ⇒ Object
Updates the Content-Language of the file data.
-
#content_type ⇒ Object
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, encryption_key_sha256: nil) ⇒ Google::Cloud::Storage::File
Copy the file to a new location.
-
#crc32c ⇒ Object
The CRC32c checksum of the data, as described in RFC 4960, Appendix B.
-
#created_at ⇒ Object
Creation time of the file.
-
#delete ⇒ Boolean
Permanently deletes the file.
-
#download(path, verify: :md5, encryption_key: nil, encryption_key_sha256: nil) ⇒ File
Download the file's contents to a local file.
-
#encryption_key_sha256 ⇒ Object
An RFC 4648 Base64-encoded string of the SHA256 hash of the customer-supplied encryption key.
-
#etag ⇒ Object
HTTP 1.1 Entity tag for the file.
-
#generation ⇒ Object
The content generation of this file.
-
#id ⇒ Object
The ID of the file.
-
#kind ⇒ Object
The kind of item this is.
-
#md5 ⇒ Object
MD5 hash of the data; encoded using base64.
-
#media_url ⇒ Object
A URL that can be used to download the file using the REST API.
-
#metadata ⇒ Object
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 ⇒ Object
The version of the metadata for this file at this generation.
-
#name ⇒ Object
The name of this file.
-
#public_url(protocol: :https) ⇒ Object
(also: #url)
Public URL to access the file.
-
#reload! ⇒ Object
(also: #refresh!)
Reloads the file with current data from the Storage service.
-
#signed_url(method: nil, expires: nil, content_type: nil, content_md5: nil, issuer: nil, client_email: nil, signing_key: nil, private_key: nil) ⇒ Object
Access without authentication can be granted to a File for a specified period of time.
-
#size ⇒ Object
Content-Length of the data in bytes.
-
#update {|file| ... } ⇒ Object
Updates the file with changes made in the given block in a single PATCH request.
-
#updated_at ⇒ Object
The creation or modification time of the file.
Instance Method Details
#acl ⇒ Object
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.
662 663 664 |
# File 'lib/google/cloud/storage/file.rb', line 662 def acl @acl ||= File::Acl.new self end |
#api_url ⇒ Object
A URL that can be used to access the file using the REST API.
109 110 111 |
# File 'lib/google/cloud/storage/file.rb', line 109 def api_url @gapi.self_link end |
#bucket ⇒ Object
The name of the Bucket containing this file.
87 88 89 |
# File 'lib/google/cloud/storage/file.rb', line 87 def bucket @gapi.bucket end |
#cache_control ⇒ Object
The Cache-Control directive for the file data.
162 163 164 |
# File 'lib/google/cloud/storage/file.rb', line 162 def cache_control @gapi.cache_control end |
#cache_control=(cache_control) ⇒ Object
Updates the Cache-Control directive for the file data.
170 171 172 173 |
# File 'lib/google/cloud/storage/file.rb', line 170 def cache_control= cache_control @gapi.cache_control = cache_control patch_gapi! :cache_control end |
#content_disposition ⇒ Object
The Content-Disposition of the file data.
178 179 180 |
# File 'lib/google/cloud/storage/file.rb', line 178 def content_disposition @gapi.content_disposition end |
#content_disposition=(content_disposition) ⇒ Object
Updates the Content-Disposition of the file data.
185 186 187 188 |
# File 'lib/google/cloud/storage/file.rb', line 185 def content_disposition= content_disposition @gapi.content_disposition = content_disposition patch_gapi! :content_disposition end |
#content_encoding ⇒ Object
The Content-Encoding of the file data.
194 195 196 |
# File 'lib/google/cloud/storage/file.rb', line 194 def content_encoding @gapi.content_encoding end |
#content_encoding=(content_encoding) ⇒ Object
Updates the Content-Encoding of the file data.
202 203 204 205 |
# File 'lib/google/cloud/storage/file.rb', line 202 def content_encoding= content_encoding @gapi.content_encoding = content_encoding patch_gapi! :content_encoding end |
#content_language ⇒ Object
The Content-Language of the file data.
210 211 212 |
# File 'lib/google/cloud/storage/file.rb', line 210 def content_language @gapi.content_language end |
#content_language=(content_language) ⇒ Object
Updates the Content-Language of the file data.
217 218 219 220 |
# File 'lib/google/cloud/storage/file.rb', line 217 def content_language= content_language @gapi.content_language = content_language patch_gapi! :content_language end |
#content_type ⇒ Object
The Content-Type of the file data.
225 226 227 |
# File 'lib/google/cloud/storage/file.rb', line 225 def content_type @gapi.content_type end |
#content_type=(content_type) ⇒ Object
Updates the Content-Type of the file data.
233 234 235 236 |
# File 'lib/google/cloud/storage/file.rb', line 233 def content_type= content_type @gapi.content_type = content_type patch_gapi! :content_type end |
#copy(dest_bucket_or_path, dest_path = nil, acl: nil, generation: nil, encryption_key: nil, encryption_key_sha256: nil) ⇒ Google::Cloud::Storage::File
Copy the file to a new location.
If a customer-supplied encryption
key
was used with Bucket#create_file, the encryption_key
and
encryption_key_sha256
options must be provided.
462 463 464 465 466 467 468 469 470 471 472 473 474 |
# File 'lib/google/cloud/storage/file.rb', line 462 def copy dest_bucket_or_path, dest_path = nil, acl: nil, generation: nil, encryption_key: nil, encryption_key_sha256: nil ensure_service! = { acl: acl, generation: generation, key: encryption_key, key_sha256: encryption_key_sha256 } dest_bucket, dest_path, = fix_copy_args dest_bucket_or_path, dest_path, gapi = service.copy_file bucket, name, dest_bucket, dest_path, File.from_gapi gapi, service end |
#crc32c ⇒ Object
The CRC32c checksum of the data, as described in RFC 4960, Appendix B. Encoded using base64 in big-endian byte order.
149 150 151 |
# File 'lib/google/cloud/storage/file.rb', line 149 def crc32c @gapi.crc32c end |
#created_at ⇒ Object
Creation time of the file.
127 128 129 |
# File 'lib/google/cloud/storage/file.rb', line 127 def created_at @gapi.time_created end |
#delete ⇒ Boolean
Permanently deletes the file.
492 493 494 495 496 |
# File 'lib/google/cloud/storage/file.rb', line 492 def delete ensure_service! service.delete_file bucket, name true end |
#download(path, verify: :md5, encryption_key: nil, encryption_key_sha256: nil) ⇒ File
Download the file's contents to a local file.
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
and
encryption_key_sha256
options must be provided.
382 383 384 385 386 387 388 389 |
# File 'lib/google/cloud/storage/file.rb', line 382 def download path, verify: :md5, encryption_key: nil, encryption_key_sha256: nil ensure_service! service.download_file \ bucket, name, path, key: encryption_key, key_sha256: encryption_key_sha256 verify_file! ::File.new(path), verify end |
#encryption_key_sha256 ⇒ Object
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.
264 265 266 267 |
# File 'lib/google/cloud/storage/file.rb', line 264 def encryption_key_sha256 return nil unless @gapi.customer_encryption Base64.decode64 @gapi.customer_encryption.key_sha256 end |
#etag ⇒ Object
HTTP 1.1 Entity tag for the file.
155 156 157 |
# File 'lib/google/cloud/storage/file.rb', line 155 def etag @gapi.etag end |
#generation ⇒ Object
The content generation of this file. Used for object versioning.
94 95 96 |
# File 'lib/google/cloud/storage/file.rb', line 94 def generation @gapi.generation end |
#id ⇒ Object
The ID of the file.
75 76 77 |
# File 'lib/google/cloud/storage/file.rb', line 75 def id @gapi.id end |
#kind ⇒ Object
The kind of item this is. For files, this is always storage#object.
69 70 71 |
# File 'lib/google/cloud/storage/file.rb', line 69 def kind @gapi.kind end |
#md5 ⇒ Object
MD5 hash of the data; encoded using base64.
141 142 143 |
# File 'lib/google/cloud/storage/file.rb', line 141 def md5 @gapi.md5_hash end |
#media_url ⇒ Object
A URL that can be used to download the file using the REST API.
115 116 117 |
# File 'lib/google/cloud/storage/file.rb', line 115 def media_url @gapi.media_link end |
#metadata ⇒ Object
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.
242 243 244 245 246 |
# File 'lib/google/cloud/storage/file.rb', line 242 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.
252 253 254 255 |
# File 'lib/google/cloud/storage/file.rb', line 252 def @gapi. = patch_gapi! :metadata end |
#metageneration ⇒ Object
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.
103 104 105 |
# File 'lib/google/cloud/storage/file.rb', line 103 def @gapi. end |
#name ⇒ Object
The name of this file.
81 82 83 |
# File 'lib/google/cloud/storage/file.rb', line 81 def name @gapi.name end |
#public_url(protocol: :https) ⇒ Object 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.
530 531 532 |
# File 'lib/google/cloud/storage/file.rb', line 530 def public_url protocol: :https "#{protocol}://storage.googleapis.com/#{bucket}/#{name}" end |
#reload! ⇒ Object Also known as: refresh!
Reloads the file with current data from the Storage service.
668 669 670 671 |
# File 'lib/google/cloud/storage/file.rb', line 668 def reload! ensure_service! @gapi = service.get_file bucket, name end |
#signed_url(method: nil, expires: nil, content_type: nil, content_md5: nil, issuer: nil, client_email: nil, signing_key: nil, private_key: nil) ⇒ Object
Access without authentication can be granted to a File for a specified period of time. This URL uses a cryptographic signature of your credentials to access the file.
Generating a 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.
605 606 607 608 609 610 611 612 613 614 615 |
# File 'lib/google/cloud/storage/file.rb', line 605 def signed_url method: nil, expires: nil, content_type: nil, content_md5: nil, issuer: nil, client_email: nil, signing_key: nil, private_key: nil ensure_service! = { method: method, expires: expires, content_type: content_type, content_md5: content_md5, issuer: issuer, client_email: client_email, signing_key: signing_key, private_key: private_key } signer = File::Signer.new self signer.signed_url end |
#size ⇒ Object
Content-Length of the data in bytes.
121 122 123 |
# File 'lib/google/cloud/storage/file.rb', line 121 def size @gapi.size.to_i if @gapi.size end |
#update {|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=, and #metadata=. The #metadata hash accessible in the block is completely mutable and will be included in the request.
298 299 300 301 302 303 |
# File 'lib/google/cloud/storage/file.rb', line 298 def update updater = Updater.new gapi yield updater updater. patch_gapi! updater.updates unless updater.updates.empty? end |
#updated_at ⇒ Object
The creation or modification time of the file. For buckets with versioning enabled, changing an object's metadata does not change this property.
135 136 137 |
# File 'lib/google/cloud/storage/file.rb', line 135 def updated_at @gapi.updated end |