diff --git a/README.md b/README.md index 468a413..49a9be9 100644 --- a/README.md +++ b/README.md @@ -208,10 +208,10 @@ Entities are representations of objects in Uploadcare cloud. #### File -File entity contains its metadata. +File entity contains its metadata. It also supports `include` param to include additional fields to the file object, such as: "appdata". ```ruby -@file = Uploadcare::File.file("FILE_ID_IN_YOUR_PROJECT") +@file = Uploadcare::File.file("FILE_ID_IN_YOUR_PROJECT", include: "appdata") { "datetime_removed"=>nil, "datetime_stored"=>"2018-11-26T12:49:10.477888Z", diff --git a/lib/uploadcare/client/file_client.rb b/lib/uploadcare/client/file_client.rb index 9a4f27e..69f14bf 100644 --- a/lib/uploadcare/client/file_client.rb +++ b/lib/uploadcare/client/file_client.rb @@ -16,8 +16,8 @@ def index # Acquire file info # @see https://uploadcare.com/api-refs/rest-api/v0.7.0/#operation/fileInfo - def info(uuid) - get(uri: "/files/#{uuid}/") + def info(uuid, params = {}) + get(uri: "/files/#{uuid}/", params: params) end alias file info diff --git a/lib/uploadcare/client/rest_client.rb b/lib/uploadcare/client/rest_client.rb index e9bbafb..a7ae803 100644 --- a/lib/uploadcare/client/rest_client.rb +++ b/lib/uploadcare/client/rest_client.rb @@ -27,8 +27,11 @@ def request(uri:, method: 'GET', **options) request_headers = Param::AuthenticationHeader.call(method: method.upcase, uri: uri, content_type: headers[:'Content-Type'], **options) handle_throttling do - send("api_struct_#{method.downcase}", path: remove_trailing_slash(uri), - headers: request_headers, body: options[:content]) + send("api_struct_#{method.downcase}", + path: remove_trailing_slash(uri), + headers: request_headers, + body: options[:content], + params: options[:params]) end end diff --git a/lib/uploadcare/param/secure_auth_header.rb b/lib/uploadcare/param/secure_auth_header.rb index e94d553..fb5db9d 100644 --- a/lib/uploadcare/param/secure_auth_header.rb +++ b/lib/uploadcare/param/secure_auth_header.rb @@ -1,26 +1,28 @@ # frozen_string_literal: true require 'digest/md5' +require 'addressable/uri' module Uploadcare module Param # This object returns headers needed for authentication # This authentication method is more secure, but more tedious class SecureAuthHeader - # @see https://uploadcare.com/docs/api_reference/rest/requests_auth/#auth-uploadcare - def self.call(options = {}) - @method = options[:method] - @body = options[:content] || '' - @content_type = options[:content_type] - @uri = options[:uri] - @date_for_header = timestamp - { - Date: @date_for_header, - Authorization: "Uploadcare #{Uploadcare.config.public_key}:#{signature}" - } - end - class << self + # @see https://uploadcare.com/docs/api_reference/rest/requests_auth/#auth-uploadcare + def call(options = {}) + @method = options[:method] + @body = options[:content] || '' + @content_type = options[:content_type] + @uri = make_uri(options) + + @date_for_header = timestamp + { + Date: @date_for_header, + Authorization: "Uploadcare #{Uploadcare.config.public_key}:#{signature}" + } + end + def signature content_md5 = Digest::MD5.hexdigest(@body) sign_string = [@method, content_md5, @content_type, @date_for_header, @uri].join("\n") @@ -31,6 +33,18 @@ def signature def timestamp Time.now.gmtime.strftime('%a, %d %b %Y %H:%M:%S GMT') end + + private + + def make_uri(options) + if options[:params] && !options[:params].empty? + uri = Addressable::URI.parse options[:uri] + uri.query_values = uri.query_values(Array).to_a.concat(options[:params].to_a) + uri.to_s + else + options[:uri] + end + end end end end diff --git a/spec/fixtures/vcr_cassettes/rest_file_info.yml b/spec/fixtures/vcr_cassettes/rest_file_info.yml index 10f49c3..352b303 100644 --- a/spec/fixtures/vcr_cassettes/rest_file_info.yml +++ b/spec/fixtures/vcr_cassettes/rest_file_info.yml @@ -59,4 +59,60 @@ http_interactions: string: '{"datetime_removed":null,"datetime_stored":null,"datetime_uploaded":"2022-09-19T12:29:59.461061Z","is_image":true,"is_ready":true,"mime_type":"application/octet-stream","original_file_url":"https://ucarecdn.com/2e17f5d1-d423-4de6-8ee5-6773cc4a7fa6/kitten.jpeg","original_filename":"kitten.jpeg","size":1290,"url":"https://api.uploadcare.com/files/2e17f5d1-d423-4de6-8ee5-6773cc4a7fa6/","uuid":"2e17f5d1-d423-4de6-8ee5-6773cc4a7fa6","variations":null,"content_info":{"mime":{"mime":"image/jpeg","type":"image","subtype":"jpeg"},"image":{"dpi":[96,96],"width":50,"format":"JPEG","height":50,"sequence":false,"color_mode":"RGB","orientation":null,"geo_location":null,"datetime_original":null}},"metadata":{"subsystem":"new test value"}}' recorded_at: Mon, 19 Sep 2022 17:27:32 GMT -recorded_with: VCR 6.1.0 +- request: + method: get + uri: https://api.uploadcare.com/files/640fe4b7-7352-42ca-8d87-0e4387957157/?include=appdata + body: + encoding: ASCII-8BIT + string: '' + headers: + Content-Type: + - application/json + Accept: + - application/vnd.uploadcare-v0.7+json + User-Agent: + - UploadcareRuby/4.3.6/5d5bb5639e3f2df33674 (Ruby/3.3.0) + Date: + - Sat, 24 Feb 2024 18:59:02 GMT + Authorization: + - Uploadcare 5d5bb5639e3f2df33674:0cd5a6181fa53bc946d83db616e619fa75672634 + Connection: + - close + Host: + - api.uploadcare.com + response: + status: + code: 200 + message: OK + headers: + Date: + - Sat, 24 Feb 2024 18:59:03 GMT + Content-Type: + - application/vnd.uploadcare-v0.7+json + Content-Length: + - '2292' + Connection: + - close + Server: + - nginx + Access-Control-Allow-Origin: + - https://uploadcare.com + Vary: + - Accept + Allow: + - DELETE, GET, HEAD, OPTIONS + X-Xss-Protection: + - 1; mode=block + X-Content-Type-Options: + - nosniff + X-Uploadcare-Request-Id: + - c9e3fc1d-c435-4212-a3ef-0c142f4d2054 + X-Frame-Options: + - SAMEORIGIN + X-Robots-Tag: + - noindex, nofollow, nosnippet, noarchive + body: + encoding: ASCII-8BIT + string: '{"datetime_removed":null,"datetime_stored":"2024-02-16T14:44:29.637342Z","datetime_uploaded":"2024-02-16T14:44:29.395043Z","is_image":true,"is_ready":true,"mime_type":"image/jpeg","original_file_url":"https://ucarecdn.com/640fe4b7-7352-42ca-8d87-0e4387957157/samplefile.jpeg","original_filename":"sample-file.jpeg","size":3518420,"url":"https://api.uploadcare.com/files/640fe4b7-7352-42ca-8d87-0e4387957157/","uuid":"640fe4b7-7352-42ca-8d87-0e4387957157","variations":null,"content_info":{"mime":{"mime":"image/jpeg","type":"image","subtype":"jpeg"},"image":{"dpi":[72,72],"width":3011,"format":"JPEG","height":4516,"sequence":false,"color_mode":"RGB","orientation":1,"geo_location":null,"datetime_original":"2023-03-10T16:23:15"}},"metadata":{},"appdata":{"aws_rekognition_detect_labels":{"data":{"Labels":[{"Name":"Accessories","Parents":[],"Instances":[],"Confidence":99.99993133544922},{"Name":"Strap","Parents":[{"Name":"Accessories"}],"Instances":[],"Confidence":99.99993133544922},{"Name":"Path","Parents":[],"Instances":[],"Confidence":99.9738998413086},{"Name":"Road","Parents":[],"Instances":[],"Confidence":99.55068969726562},{"Name":"Street","Parents":[{"Name":"City"},{"Name":"Road"},{"Name":"Urban"}],"Instances":[],"Confidence":97.583984375},{"Name":"Dog","Parents":[{"Name":"Animal"},{"Name":"Canine"},{"Name":"Mammal"},{"Name":"Pet"}],"Instances":[{"Confidence":97.21764373779297,"BoundingBox":{"Top":0.22813057899475098,"Left":0.20908746123313904,"Width":0.603455662727356,"Height":0.5941042304039001}}],"Confidence":97.41680908203125},{"Name":"Husky","Parents":[{"Name":"Animal"},{"Name":"Canine"},{"Name":"Dog"},{"Name":"Mammal"},{"Name":"Pet"}],"Instances":[],"Confidence":97.41680908203125},{"Name":"Leash","Parents":[],"Instances":[],"Confidence":95.52120971679688},{"Name":"Tarmac","Parents":[{"Name":"Road"}],"Instances":[],"Confidence":93.37832641601562},{"Name":"Walkway","Parents":[{"Name":"Path"}],"Instances":[],"Confidence":90.72362518310547}],"LabelModelVersion":"3.0"},"datetime_created":"2024-02-24T14:00:23.545995Z","datetime_updated":"2024-02-24T14:07:10.598091Z","version":"2016-06-27"},"uc_clamav_virus_scan":{"data":{"infected":false},"datetime_created":"2024-02-16T14:44:29.676188Z","datetime_updated":"2024-02-16T14:44:29.676207Z","version":"1.0.1"}}}' + recorded_at: Sat, 24 Feb 2024 18:59:03 GMT +recorded_with: VCR 6.2.0 diff --git a/spec/uploadcare/client/file_client_spec.rb b/spec/uploadcare/client/file_client_spec.rb index f30fa8a..573b462 100644 --- a/spec/uploadcare/client/file_client_spec.rb +++ b/spec/uploadcare/client/file_client_spec.rb @@ -16,6 +16,15 @@ module Client end end + it 'supports extra params like include' do + VCR.use_cassette('rest_file_info') do + uuid = '640fe4b7-7352-42ca-8d87-0e4387957157' + file = subject.info(uuid, { include: 'appdata' }) + expect(file.value![:uuid]).to eq(uuid) + expect(file.value![:appdata]).not_to be_empty + end + end + it 'shows nothing on invalid file' do VCR.use_cassette('rest_file_info_fail') do uuid = 'nonexistent'