The REST Admin API is a legacy API as of October 1, 2024. All apps and integrations should be built with the GraphQL Admin API. For details and migration steps, visit our migration guide.

Requires ANY of the following access scopes: orders, marketplace_orders.

Transactions are created for every order that results in an exchange of money.

There are five types of transactions:

  • Authorization: An amount reserved against the cardholder's funding source. Money does not change hands until the authorization is captured.
  • Sale: An authorization and capture performed together in a single step.
  • Capture: A transfer of the money that was reserved during the authorization stage.
  • Void: A cancellation of a pending authorization or capture.
  • Refund: A partial or full return of captured funds to the cardholder. A refund can happen only after a capture is processed.

Refund transactions must be created by using the Refund resource.

Note

An order can have more than one authorization transaction associated with it. This might happen when an order is edited or when a post-purchase upsell is added to the order. To be notified when an order is edited subscribe to the OrderEdit webhook.

If your app captures payments, you should make a GET request to the /admin/api/{version}/orders/{order_id}/transactions.json endpoint to retrieve the authorization transactions associated with an order. Then, to complete the full order payment capture, you should use the authorization or parent_id properties in separate capture POST requests to the same endpoint for each authorization transaction.

Note

An order can have no more than 100 transactions associated with it.

Was this section helpful?

Properties

amount
The amount of money included in the transaction. If you don't provide a value for `amount`, then it defaults to the total cost of the order (even if a previous transaction has been made towards it).

amount_rounding
read-only
The rounding adjustment for cash payments, to be applied on the amount to get a rounded amount.

authorization
The authorization code associated with the transaction.

authorization_expires_at
The date and time (ISO 8601 format) when the Shopify Payments authorization expires.

created_at
read-only
The date and time (ISO 8601 format) when the transaction was created.

currency

The three-letter code (ISO 4217 format) for the currency used for the payment.


device_id
read-only
The ID for the device.

error_code
read-only
A standardized error code, independent of the payment provider. Valid values:

extended_authorization_attributes
The attributes associated with a Shopify Payments extended authorization period. It has the following attributes:

gateway
The name of the gateway the transaction was issued through. A list of gateways can be found on Shopify's payment gateways page.

id
read-only
->id
The ID for the transaction.

kind
The transaction's type. Valid values:

Was this section helpful?
{}The Transaction resource
{
"amount": "10.00",
"amount_rounding": "0.02",
"authorization": "ch_1AtJu6CktlpKSclI4zjeQb2t",
"authorization_expires_at": "2021-03-13T16:09:54-04:00",
"created_at": "2012-03-13T16:09:54-04:00",
"currency": "USD",
"device_id": 1,
"error_code": "invalid_cvc",
"extended_authorization_attributes": {
"standard_authorization_expires_at": "2020-10-08T00:00:00-04:00",
"extended_authorization_expires_at": "2020-10-30T00:00:00-04:00"
},
"gateway": "shopify_payments",
"id": 999225661,
"kind": "capture",
"location_id": {
"id": 49202758
},
"message": "Marked the Stripe payment as received",
"order_id": 450789469,
"payment_details": {
"credit_card_bin": "123456",

Creates a transaction for an order.


api_version
string
required

order_id
string
required

source
An optional origin of the transaction. Set to external to import a cash transaction for the associated order.

Was this section helpful?
Path parameters
orderid=450789469
string
required
Request body
transaction
Transaction resource
Was this section helpful?
post
/admin/api/2025-01/orders/450789469/transactions.json
Copy
curl -d '{"transaction":{"currency":"USD","amount":"10.00","kind":"capture","parent_id":389404469}}' \
-X POST "https://your-development-store.myshopify.com/admin/api/2025-01/orders/450789469/transactions.json" \
-H "X-Shopify-Access-Token: {access_token}" \
-H "Content-Type: application/json"

{}Response
JSON
HTTP/1.1 201 Created
{
"transaction": {
"id": 1068278510,
"order_id": 450789469,
"kind": "capture",
"gateway": "bogus",
"status": "success",
"message": "Bogus Gateway: Forced success",
"created_at": "2025-01-02T11:34:43-05:00",
"test": true,
"authorization": null,
"location_id": null,
"user_id": null,
"parent_id": 389404469,
"processed_at": "2025-01-02T11:34:43-05:00",
"device_id": null,
"error_code": null,
"source_name": "755357713",
"payment_details": {
"credit_card_bin": null,
"avs_result_code": null,
"cvv_result_code": null,
"credit_card_number": "•••• •••• •••• 4242",
"credit_card_company": "Visa",

Retrieves a list of transactions.

Transactions attached to multi-currency orders are in the presentment currency by default. To retrieve transactions in the shop currency, include the URL parameter in_shop_currency=true.


api_version
string
required

order_id
string
required

fields
Show only certain fields, specifed by a comma-separated list of fields names.

in_shop_currency
default false
Show amounts in the shop currency.

since_id
Retrieve only transactions after the specified ID.

Was this section helpful?
Path parameters
orderid=450789469
string
required
Was this section helpful?
get
/admin/api/2025-01/orders/450789469/transactions.json
Copy
curl -X GET "https://your-development-store.myshopify.com/admin/api/2025-01/orders/450789469/transactions.json" \
-H "X-Shopify-Access-Token: {access_token}"

{}Response
JSON
HTTP/1.1 200 OK
{
"transactions": [
{
"id": 179259969,
"order_id": 450789469,
"kind": "refund",
"gateway": "bogus",
"status": "success",
"message": null,
"created_at": "2005-08-05T12:59:12-04:00",
"test": false,
"authorization": "authorization-key",
"location_id": null,
"user_id": null,
"parent_id": 801038806,
"processed_at": "2005-08-05T12:59:12-04:00",
"device_id": null,
"error_code": null,
"source_name": "web",
"receipt": {},
"currency_exchange_adjustment": null,
"amount": "209.00",
"currency": "USD",
"payment_id": "#1001.3",
"total_unsettled_set": {

Retrieves a specific transaction.

Transactions attached to multi-currency orders are in the presentment currency by default. To retrieve transactions in the shop currency, include the URL parameter in_shop_currency=true.

extended_authorization_attributes are available on this endpoint only to stores on the Shopify Plus plan that use Shopify Payments. To learn more about extended authorization periods, refer to Payment authorization.


api_version
string
required

order_id
string
required

transaction_id
string
required

fields
Show only certain fields, specified by a comma-separated list of field names.

in_shop_currency
default false
Show amounts in the shop currency.

Was this section helpful?
Was this section helpful?
get
/admin/api/2025-01/orders/450789469/transactions/389404469.json
Copy
curl -X GET "https://your-development-store.myshopify.com/admin/api/2025-01/orders/450789469/transactions/389404469.json" \
-H "X-Shopify-Access-Token: {access_token}"

{}Response
JSON
HTTP/1.1 200 OK
{
"transaction": {
"id": 389404469,
"order_id": 450789469,
"kind": "authorization",
"gateway": "bogus",
"status": "success",
"message": null,
"created_at": "2005-08-01T11:57:11-04:00",
"test": false,
"authorization": "authorization-key",
"location_id": null,
"user_id": null,
"parent_id": null,
"processed_at": "2005-08-01T11:57:11-04:00",
"device_id": null,
"error_code": null,
"source_name": "web",
"payment_details": {
"credit_card_bin": null,
"avs_result_code": null,
"cvv_result_code": null,
"credit_card_number": "•••• •••• •••• 4242",
"credit_card_company": "Visa",

Retrieves a count of an order's transactions.

api_version
string
required

order_id
string
required

Was this section helpful?
Path parameters
orderid=450789469
string
required
Was this section helpful?
get
/admin/api/2025-01/orders/450789469/transactions/count.json
Copy
curl -X GET "https://your-development-store.myshopify.com/admin/api/2025-01/orders/450789469/transactions/count.json" \
-H "X-Shopify-Access-Token: {access_token}"

{}Response
JSON
HTTP/1.1 200 OK
{
"count": 3
}