75 lines
2.5 KiB
YAML
75 lines
2.5 KiB
YAML
title: Payment Session
|
|
description: >-
|
|
Payment Sessions are created when a Customer initilizes the checkout flow, and
|
|
can be used to hold the state of a payment flow. Each Payment Session is
|
|
controlled by a Payment Provider, who is responsible for the communication
|
|
with external payment services. Authorized Payment Sessions will eventually
|
|
get promoted to Payments to indicate that they are authorized for
|
|
capture/refunds/etc.
|
|
x-resourceId: payment_session
|
|
required:
|
|
- cart_id
|
|
- provider_id
|
|
- status
|
|
properties:
|
|
id:
|
|
type: string
|
|
description: The payment session's ID
|
|
example: ps_01G901XNSRM2YS3ASN9H5KG3FZ
|
|
cart_id:
|
|
description: The id of the Cart that the Payment Session is created for.
|
|
type: string
|
|
example: cart_01G8ZH853Y6TFXWPG5EYE81X63
|
|
cart:
|
|
description: A cart object. Available if the relation `cart` is expanded.
|
|
type: object
|
|
provider_id:
|
|
description: The id of the Payment Provider that is responsible for the Payment Session
|
|
type: string
|
|
example: manual
|
|
is_selected:
|
|
description: >-
|
|
A flag to indicate if the Payment Session has been selected as the method
|
|
that will be used to complete the purchase.
|
|
type: boolean
|
|
example: true
|
|
status:
|
|
description: >-
|
|
Indicates the status of the Payment Session. Will default to `pending`,
|
|
and will eventually become `authorized`. Payment Sessions may have the
|
|
status of `requires_more` to indicate that further actions are to be
|
|
completed by the Customer.
|
|
type: string
|
|
enum:
|
|
- authorized
|
|
- pending
|
|
- requires_more
|
|
- error
|
|
- canceled
|
|
example: pending
|
|
data:
|
|
description: >-
|
|
The data required for the Payment Provider to identify, modify and process
|
|
the Payment Session. Typically this will be an object that holds an id to
|
|
the external payment session, but can be an empty object if the Payment
|
|
Provider doesn't hold any state.
|
|
type: object
|
|
example: {}
|
|
idempotency_key:
|
|
type: string
|
|
description: >-
|
|
Randomly generated key used to continue the completion of a cart in case
|
|
of failure.
|
|
externalDocs:
|
|
url: >-
|
|
https://docs.medusajs.com/advanced/backend/payment/overview#idempotency-key
|
|
description: Learn more how to use the idempotency key.
|
|
created_at:
|
|
type: string
|
|
description: The date with timezone at which the resource was created.
|
|
format: date-time
|
|
updated_at:
|
|
type: string
|
|
description: The date with timezone at which the resource was updated.
|
|
format: date-time
|