mirror of
https://github.com/stripe/stripe-ruby.git
synced 2025-05-28 00:02:13 -04:00
83 lines
2.3 KiB
Ruby
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
|