stripity_stripe v2.7.0 Stripe.API behaviour View Source

Low-level utilities for interacting with the Stripe API.

Usually the utilities in Stripe.Request are a better way to write custom interactions with the API.

Link to this section Summary

Functions

Returns backoff in milliseconds.

A low level utility function to generate a new idempotency key for Idempotency-Key request header value.

In config.exs your implicit or expicit configuration is: config :stripity_stripe,

A low level utility function to make an OAuth request to the Stripe API

A low level utility function to make a direct request to the Stripe API

A low level utility function to make a direct request to the files Stripe API

Checks if an error is a problem that we should retry on. This includes both socket errors that may represent an intermittent problem and some special HTTP statuses.

Link to this section Types

Link to this type

body() View Source
body() :: iodata() | {:multipart, list()}

Link to this type

headers() View Source
headers() :: %{required(String.t()) => String.t()} | %{}

Link to this type

method() View Source
method() :: :get | :post | :put | :delete | :patch

Link to this section Functions

Link to this function

backoff(attempts, config) View Source
backoff(attempts :: non_neg_integer(), config :: Keyword.t()) ::
  non_neg_integer()

Returns backoff in milliseconds.

Link to this function

generate_idempotency_key() View Source
generate_idempotency_key() :: binary()

A low level utility function to generate a new idempotency key for Idempotency-Key request header value.

Link to this function

json_library() View Source
json_library() :: module()

In config.exs your implicit or expicit configuration is: config :stripity_stripe,

json_library: Poison # defaults to Jason but can be configured to Poison
Link to this function

oauth_request(method, endpoint, body, api_key \\ nil, opts \\ []) View Source

A low level utility function to make an OAuth request to the Stripe API

Link to this function

request(body, method, endpoint, headers, opts) View Source
request(body(), method(), String.t(), headers(), list()) ::
  {:ok, map()} | {:error, Stripe.Error.t()}

A low level utility function to make a direct request to the Stripe API

Setting the api key

request(%{}, :get, "/customers", %{}, api_key: "bogus key")

Setting api version

The api version defaults to 2019-05-16 but a custom version can be passed in as follows:

request(%{}, :get, "/customers", %{}, api_version: "2018-11-04")

Connect Accounts

If you'd like to make a request on behalf of another Stripe account utilizing the Connect program, you can pass the other Stripe account's ID to the request function as follows:

request(%{}, :get, "/customers", %{}, connect_account: "acc_134151")
Link to this function

request_file_upload(body, method, endpoint, headers, opts) View Source
request_file_upload(body(), method(), String.t(), headers(), list()) ::
  {:ok, map()} | {:error, Stripe.Error.t()}

A low level utility function to make a direct request to the files Stripe API

Link to this function

should_retry?(response, attempts \\ 0, config \\ []) View Source
should_retry?(
  http_success() | http_failure(),
  attempts :: non_neg_integer(),
  config :: Keyword.t()
) :: boolean()

Checks if an error is a problem that we should retry on. This includes both socket errors that may represent an intermittent problem and some special HTTP statuses.

Link to this section Callbacks

Link to this callback

oauth_request(method, arg2, map) View Source
oauth_request(method(), String.t(), map()) :: {:ok, map()}