# frozen_string_literal: true module Stripe class Charge < APIResource extend Stripe::APIOperations::List extend Stripe::APIOperations::Create include Stripe::APIOperations::Save OBJECT_NAME = "charge".freeze custom_method :capture, http_verb: :post def refund(params = {}, opts = {}) # Old versions of charge objects included a `refunds` field that was just # a vanilla array instead of a Stripe list object. # # Where possible, we'd still like to use the new refund endpoint (thus # `self.refunds.create`), but detect the old API version by looking for # an `Array` and fall back to the old refund URL if necessary so as to # maintain internal compatibility. if refunds.is_a?(Array) resp, opts = request(:post, refund_url, params, opts) initialize_from(resp.data, opts) else refunds.create(params, opts) # now that a refund has been created, we expect the state of this object # to change as well (i.e. `refunded` will now be `true`) so refresh it # from the server refresh end end def capture(params = {}, opts = {}) resp, opts = request(:post, capture_url, params, opts) initialize_from(resp.data, opts) end def update_dispute(params = {}, opts = {}) resp, opts = request(:post, dispute_url, params, opts) initialize_from({ dispute: resp.data }, opts, true) dispute end def close_dispute(params = {}, opts = {}) resp, opts = request(:post, close_dispute_url, params, opts) initialize_from(resp.data, opts) end def mark_as_fraudulent params = { fraud_details: { user_report: "fraudulent" }, } resp, opts = request(:post, resource_url, params) initialize_from(resp.data, opts) end def mark_as_safe params = { fraud_details: { user_report: "safe" }, } resp, opts = request(:post, resource_url, params) initialize_from(resp.data, opts) end private def capture_url resource_url + "/capture" end def dispute_url resource_url + "/dispute" end def close_dispute_url resource_url + "/dispute/close" end # Note that this is actually the *old* refund URL and its use is no longer # preferred. def refund_url resource_url + "/refund" end end end