Sha256: 3beac34876a992a71a51d6d5f9da88f19aa1f06209b5ef223f7b3344c8cbf6a5

Contents?: true

Size: 1.28 KB

Versions: 7

Compression:

Stored size: 1.28 KB

Contents

# frozen_string_literal: true

module Stripe
  class File < APIResource
    extend Stripe::APIOperations::Create
    extend Stripe::APIOperations::List

    # This resource can have two different object names. In latter API
    # versions, only `file` is used, but since stripe-ruby may be used with
    # any API version, we need to support deserializing the older
    # `file_upload` object into the same class.
    OBJECT_NAME = "file".freeze
    OBJECT_NAME_ALT = "file_upload".freeze

    def self.resource_url
      "/v1/files"
    end

    def self.create(params = {}, opts = {})
      # rest-client would accept a vanilla `File` for upload, but Faraday does
      # not. Support the old API by wrapping a `File`-like object with an
      # `UploadIO` object if we're given one.
      if params[:file] && !params[:file].is_a?(String)
        unless params[:file].respond_to?(:read)
          raise ArgumentError, "file must respond to `#read`"
        end

        params[:file] = Faraday::UploadIO.new(params[:file], nil)
      end

      opts = {
        api_base: Stripe.uploads_base,
        content_type: "multipart/form-data",
      }.merge(Util.normalize_opts(opts))
      super
    end
  end

  # For backwards compatibility, the `File` class is aliased to `FileUpload`.
  FileUpload = File
end

Version data entries

7 entries across 7 versions & 1 rubygems

Version Path
stripe-4.18.1 lib/stripe/file.rb
stripe-4.18.0 lib/stripe/file.rb
stripe-4.17.0 lib/stripe/file.rb
stripe-4.16.0 lib/stripe/file.rb
stripe-4.15.0 lib/stripe/file.rb
stripe-4.14.0 lib/stripe/file.rb
stripe-4.13.0 lib/stripe/file.rb