stripe-ruby/lib/stripe/charge.rb

83 lines
2.3 KiB
Ruby

module Stripe
class Charge < APIResource
extend Stripe::APIOperations::List
extend Stripe::APIOperations::Create
include Stripe::APIOperations::Save
OBJECT_NAME = 'charge'
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.
unless self.refunds.is_a?(Array)
self.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
self.refresh
else
resp, opts = request(:post, refund_url, params, opts)
initialize_from(resp.data, opts)
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