stripity_stripe v2.7.0 Stripe.Charge View Source
Work with Stripe charge
objects.
You can:
Link to this section Summary
Functions
[DEPRECATED] Capture a charge.
Capture a charge.
Create a charge.
List all charges.
Retrieve a charge.
Update a charge.
Link to this section Types
billing_details() View Source
card_info()
View Source
card_info() :: %{
exp_month: number(),
exp_year: number(),
number: String.t(),
object: String.t(),
cvc: String.t(),
address_city: String.t() | nil,
address_country: String.t() | nil,
address_line1: String.t() | nil,
address_line2: String.t() | nil,
name: String.t() | nil,
address_state: String.t() | nil,
address_zip: String.t() | nil
}
card_info() :: %{ exp_month: number(), exp_year: number(), number: String.t(), object: String.t(), cvc: String.t(), address_city: String.t() | nil, address_country: String.t() | nil, address_line1: String.t() | nil, address_line2: String.t() | nil, name: String.t() | nil, address_state: String.t() | nil, address_zip: String.t() | nil }
charge_outcome() View Source
charge_outcome_rule() View Source
stripe_fraud_report()
View Source
stripe_fraud_report() :: %{stripe_report: String.t()}
stripe_fraud_report() :: %{stripe_report: String.t()}
t()
View Source
t() :: %Stripe.Charge{
amount: non_neg_integer(),
amount_refunded: non_neg_integer(),
application: Stripe.id() | nil,
application_fee: Stripe.id() | Stripe.ApplicationFee.t() | nil,
application_fee_amount: Stripe.id() | Stripe.ApplicationFee.t() | nil,
balance_transaction: Stripe.id() | Stripe.BalanceTransaction.t() | nil,
billing_details: billing_details() | nil,
captured: boolean(),
created: Stripe.timestamp(),
currency: String.t(),
customer: Stripe.id() | Stripe.Customer.t() | nil,
description: String.t() | nil,
dispute: Stripe.id() | Stripe.Dispute.t() | nil,
failure_code: Stripe.Error.card_error_code() | nil,
failure_message: String.t() | nil,
fraud_details: user_fraud_report() | stripe_fraud_report() | %{},
id: Stripe.id(),
invoice: Stripe.id() | Stripe.Invoice.t() | nil,
livemode: boolean(),
metadata: Stripe.Types.metadata(),
object: String.t(),
on_behalf_of: Stripe.id() | Stripe.Account.t() | nil,
order: Stripe.id() | Stripe.Order.t() | nil,
outcome: charge_outcome() | nil,
paid: boolean(),
payment_intent: Stripe.id() | Stripe.PaymentIntent.t() | nil,
payment_method: Stripe.id() | Stripe.PaymentMethod.t() | nil,
payment_method_details: map(),
receipt_email: String.t() | nil,
receipt_number: String.t() | nil,
receipt_url: String.t() | nil,
refunded: boolean(),
refunds: Stripe.List.t(Stripe.Refund.t()),
review: Stripe.id() | Stripe.Review.t() | nil,
shipping: Stripe.Types.shipping() | nil,
source: Stripe.Card.t() | map(),
source_transfer: Stripe.id() | Stripe.Transfer.t() | nil,
statement_descriptor: String.t() | nil,
status: String.t(),
transfer: Stripe.id() | Stripe.Transfer.t() | nil,
transfer_data: transfer_data() | nil,
transfer_group: String.t() | nil
}
t() :: %Stripe.Charge{ amount: non_neg_integer(), amount_refunded: non_neg_integer(), application: Stripe.id() | nil, application_fee: Stripe.id() | Stripe.ApplicationFee.t() | nil, application_fee_amount: Stripe.id() | Stripe.ApplicationFee.t() | nil, balance_transaction: Stripe.id() | Stripe.BalanceTransaction.t() | nil, billing_details: billing_details() | nil, captured: boolean(), created: Stripe.timestamp(), currency: String.t(), customer: Stripe.id() | Stripe.Customer.t() | nil, description: String.t() | nil, dispute: Stripe.id() | Stripe.Dispute.t() | nil, failure_code: Stripe.Error.card_error_code() | nil, failure_message: String.t() | nil, fraud_details: user_fraud_report() | stripe_fraud_report() | %{}, id: Stripe.id(), invoice: Stripe.id() | Stripe.Invoice.t() | nil, livemode: boolean(), metadata: Stripe.Types.metadata(), object: String.t(), on_behalf_of: Stripe.id() | Stripe.Account.t() | nil, order: Stripe.id() | Stripe.Order.t() | nil, outcome: charge_outcome() | nil, paid: boolean(), payment_intent: Stripe.id() | Stripe.PaymentIntent.t() | nil, payment_method: Stripe.id() | Stripe.PaymentMethod.t() | nil, payment_method_details: map(), receipt_email: String.t() | nil, receipt_number: String.t() | nil, receipt_url: String.t() | nil, refunded: boolean(), refunds: Stripe.List.t(Stripe.Refund.t()), review: Stripe.id() | Stripe.Review.t() | nil, shipping: Stripe.Types.shipping() | nil, source: Stripe.Card.t() | map(), source_transfer: Stripe.id() | Stripe.Transfer.t() | nil, statement_descriptor: String.t() | nil, status: String.t(), transfer: Stripe.id() | Stripe.Transfer.t() | nil, transfer_data: transfer_data() | nil, transfer_group: String.t() | nil }
transfer_data()
View Source
transfer_data() :: %{amount: non_neg_integer(), destination: String.t()}
transfer_data() :: %{amount: non_neg_integer(), destination: String.t()}
user_fraud_report()
View Source
user_fraud_report() :: %{user_report: String.t()}
user_fraud_report() :: %{user_report: String.t()}
Link to this section Functions
capture(id)
View Source
capture(Stripe.id() | t()) :: {:ok, t()} | {:error, Stripe.Error.t()}
capture(Stripe.id() | t()) :: {:ok, t()} | {:error, Stripe.Error.t()}
capture(id, opts)
View Source
capture(Stripe.id() | t(), Stripe.options()) ::
{:ok, t()} | {:error, Stripe.Error.t()}
capture(Stripe.id() | t(), map()) ::
{:ok, t()} | {:error, Stripe.Error.t()}
capture(Stripe.id() | t(), Stripe.options()) :: {:ok, t()} | {:error, Stripe.Error.t()}
capture(Stripe.id() | t(), map()) :: {:ok, t()} | {:error, Stripe.Error.t()}
[DEPRECATED] Capture a charge.
This version of the function is deprecated. Please use capture/3
instead.
capture(id, params, opts)
View Source
capture(Stripe.id() | t(), params, Stripe.options()) ::
{:ok, t()} | {:error, Stripe.Error.t()}
when params: %{
optional(:amount) => non_neg_integer(),
optional(:application_fee_amount) => non_neg_integer(),
optional(:receipt_email) => String.t(),
optional(:statement_descriptor) => String.t(),
optional(:transfer_data) => transfer_data(),
optional(:transfer_group) => String.t()
}
capture(Stripe.id() | t(), params, Stripe.options()) :: {:ok, t()} | {:error, Stripe.Error.t()} when params: %{ optional(:amount) => non_neg_integer(), optional(:application_fee_amount) => non_neg_integer(), optional(:receipt_email) => String.t(), optional(:statement_descriptor) => String.t(), optional(:transfer_data) => transfer_data(), optional(:transfer_group) => String.t() }
Capture a charge.
Capture the payment of an existing, uncaptured, charge. This is the second half of the two-step payment flow, where first you created a charge with the capture option set to false.
Uncaptured payments expire exactly seven days after they are created. If they are not captured by that point in time, they will be marked as refunded and will no longer be capturable.
See the Stripe docs.
create(params, opts \\ [])
View Source
create(params, Stripe.options()) :: {:ok, t()} | {:error, Stripe.Error.t()}
when params:
%{
:amount => pos_integer(),
:currency => String.t(),
optional(:application_fee_amount) => non_neg_integer(),
optional(:capture) => boolean(),
optional(:customer) => Stripe.id() | Stripe.Customer.t(),
optional(:description) => String.t(),
optional(:on_behalf_of) => Stripe.id() | Stripe.Account.t(),
optional(:metadata) => map(),
optional(:receipt_email) => String.t(),
optional(:shipping) => Stripe.Types.shipping(),
optional(:source) => Stripe.id() | Stripe.Card.t() | card_info(),
optional(:statement_descriptor) => String.t(),
optional(:transfer_data) => transfer_data(),
optional(:transfer_group) => String.t()
}
| %{}
create(params, Stripe.options()) :: {:ok, t()} | {:error, Stripe.Error.t()} when params: %{ :amount => pos_integer(), :currency => String.t(), optional(:application_fee_amount) => non_neg_integer(), optional(:capture) => boolean(), optional(:customer) => Stripe.id() | Stripe.Customer.t(), optional(:description) => String.t(), optional(:on_behalf_of) => Stripe.id() | Stripe.Account.t(), optional(:metadata) => map(), optional(:receipt_email) => String.t(), optional(:shipping) => Stripe.Types.shipping(), optional(:source) => Stripe.id() | Stripe.Card.t() | card_info(), optional(:statement_descriptor) => String.t(), optional(:transfer_data) => transfer_data(), optional(:transfer_group) => String.t() } | %{}
Create a charge.
If your API key is in test mode, the supplied payment source (e.g., card) won't actually be charged, though everything else will occur as if in live mode. (Stripe assumes that the charge would have completed successfully).
See the Stripe docs.
list(params \\ %{}, opts \\ [])
View Source
list(params, Stripe.options()) ::
{:ok, Stripe.List.t(t())} | {:error, Stripe.Error.t()}
when params: %{
optional(:created) => Stripe.date_query(),
optional(:customer) => Stripe.Customer.t() | Stripe.id(),
optional(:ending_before) => t() | Stripe.id(),
optional(:limit) => 1..100,
optional(:source) => %{optional(:object) => String.t()},
optional(:starting_after) => t() | Stripe.id(),
optional(:transfer_group) => String.t()
}
list(params, Stripe.options()) :: {:ok, Stripe.List.t(t())} | {:error, Stripe.Error.t()} when params: %{ optional(:created) => Stripe.date_query(), optional(:customer) => Stripe.Customer.t() | Stripe.id(), optional(:ending_before) => t() | Stripe.id(), optional(:limit) => 1..100, optional(:source) => %{optional(:object) => String.t()}, optional(:starting_after) => t() | Stripe.id(), optional(:transfer_group) => String.t() }
List all charges.
Returns a list of charges you’ve previously created. The charges are returned in sorted order, with the most recent charges appearing first.
See the Stripe docs.
retrieve(id, opts \\ [])
View Source
retrieve(Stripe.id() | t(), Stripe.options()) ::
{:ok, t()} | {:error, Stripe.Error.t()}
retrieve(Stripe.id() | t(), Stripe.options()) :: {:ok, t()} | {:error, Stripe.Error.t()}
Retrieve a charge.
Retrieves the details of a charge that has previously been created. Supply the unique charge ID that was returned from your previous request, and Stripe will return the corresponding charge information. The same information is returned when creating or refunding the charge.
See the Stripe docs.
update(id, params, opts \\ [])
View Source
update(Stripe.id() | t(), params, Stripe.options()) ::
{:ok, t()} | {:error, Stripe.Error.t()}
when params:
%{
optional(:customer) => Stripe.id() | Stripe.Customer.t(),
optional(:description) => String.t(),
optional(:fraud_details) => user_fraud_report(),
optional(:metadata) => Stripe.Types.metadata(),
optional(:receipt_email) => String.t(),
optional(:shipping) => Stripe.Types.shipping(),
optional(:transfer_group) => String.t()
}
| %{}
update(Stripe.id() | t(), params, Stripe.options()) :: {:ok, t()} | {:error, Stripe.Error.t()} when params: %{ optional(:customer) => Stripe.id() | Stripe.Customer.t(), optional(:description) => String.t(), optional(:fraud_details) => user_fraud_report(), optional(:metadata) => Stripe.Types.metadata(), optional(:receipt_email) => String.t(), optional(:shipping) => Stripe.Types.shipping(), optional(:transfer_group) => String.t() } | %{}
Update a charge.
Updates the specified charge by setting the values of the parameters passed. Any parameters not provided will be left unchanged.
This request accepts only the :description
, :metadata
, :receipt_email
, :fraud_details
,
and :shipping
as arguments, as well as :transfer_group
in some cases.
The charge to be updated may either be passed in as a struct or an ID.
See the Stripe docs.