List payments

List all the payments made towards an invoice.

To access this endpoint using an access token you'll need to specify the /accounts/{accountID}/invoices.read scope.

GET
/accounts/{accountID}/invoices/{invoiceID}/payments
cURL Go TypeScript PHP Java Python Ruby .NET
curl -X GET "https://api.moov.io/accounts/{accountID}/invoices/{invoiceID}/payments" \
  -H "Authorization: Bearer {token}" \
  -H "X-Moov-Version: v2026.04.00"
mc, _ := moov.NewClient()

var accountID string
var invoiceID string

mc.ListInvoicePayments(ctx, accountID, invoiceID)
import { Moov } from "@moovio/sdk";

const moov = new Moov({
  security: {
    username: "",
    password: "",
  },
});

async function run() {
  const result = await moov.invoices.listInvoicePayments({
    accountID: "dcfbb04d-465e-4dbc-ad14-420961d94d21",
    invoiceID: "d25d8b7f-bb29-420c-8185-4ed9df60ba13",
  });

  console.log(result);
}

run();
declare(strict_types=1);

require 'vendor/autoload.php';

use Moov\MoovPhp;
use Moov\MoovPhp\Models\Components;

$sdk = MoovPhp\Moov::builder()
    ->setSecurity(
        new Components\Security(
            username: '',
            password: '',
        )
    )
    ->build();



$response = $sdk->invoices->listInvoicePayments(
    accountID: 'dcfbb04d-465e-4dbc-ad14-420961d94d21',
    invoiceID: 'd25d8b7f-bb29-420c-8185-4ed9df60ba13'

);

if ($response->invoicePayments !== null) {
    // handle response
}
package hello.world;

import io.moov.sdk.Moov;
import io.moov.sdk.models.components.Security;
import io.moov.sdk.models.operations.ListInvoicePaymentsResponse;
import java.lang.Exception;

public class Application {

    public static void main(String[] args) throws Exception {

        Moov sdk = Moov.builder()
                .security(Security.builder()
                    .username("")
                    .password("")
                    .build())
            .build();

        ListInvoicePaymentsResponse res = sdk.invoices().listInvoicePayments()
                .accountID("dcfbb04d-465e-4dbc-ad14-420961d94d21")
                .invoiceID("d25d8b7f-bb29-420c-8185-4ed9df60ba13")
                .call();

        if (res.invoicePayments().isPresent()) {
            System.out.println(res.invoicePayments().get());
        }
    }
}
from moovio_sdk import Moov
from moovio_sdk.models import components


with Moov(
    security=components.Security(
        username="",
        password="",
    ),
) as moov:

    res = moov.invoices.list_invoice_payments(account_id="dcfbb04d-465e-4dbc-ad14-420961d94d21", invoice_id="d25d8b7f-bb29-420c-8185-4ed9df60ba13")

    # Handle response
    print(res)
require 'moov_ruby'

Models = ::Moov::Models
s = ::Moov::Client.new(
  security: Models::Components::Security.new(
    username: '',
    password: ''
  )
)
res = s.invoices.list_invoice_payments(account_id: 'dcfbb04d-465e-4dbc-ad14-420961d94d21', invoice_id: 'd25d8b7f-bb29-420c-8185-4ed9df60ba13')

unless res.invoice_payments.nil?
  # handle response
end
using Moov.Sdk;
using Moov.Sdk.Models.Components;

var sdk = new MoovClient(security: new Security() {
    Username = "",
    Password = "",
});

var res = await sdk.Invoices.ListInvoicePaymentsAsync(
    accountID: "dcfbb04d-465e-4dbc-ad14-420961d94d21",
    invoiceID: "d25d8b7f-bb29-420c-8185-4ed9df60ba13"
);

// handle response
200 401 403 429 500 504
The request completed successfully.
application/json
[
  {
    "amount": {
      "currency": "USD",
      "valueDecimal": "500.00"
    },
    "invoicePaymentID": "a1b2c3d4-e5f6-7890-abcd-ef1234567890",
    "invoicePaymentType": "transfer",
    "transfer": {
      "transferID": "ec7e1848-dc80-4ab0-8827-dd7fc0737b43"
    }
  },
  {
    "amount": {
      "currency": "USD",
      "valueDecimal": "500.00"
    },
    "external": {
      "description": "Payment via external system",
      "foreignID": "EXT-PAY-12345",
      "paymentDate": "2026-01-20T14:45:00Z"
    },
    "invoicePaymentID": "a1b2c3d4-e5f6-7890-abcd-ef1234567890",
    "invoicePaymentType": "external"
  }
]

x-request-id

string required
A unique identifier used to trace requests.
The request contained missing or expired authentication.

x-request-id

string required
A unique identifier used to trace requests.
The user is not authorized to make the request.

x-request-id

string required
A unique identifier used to trace requests.
Request was refused due to rate limiting.

x-request-id

string required
A unique identifier used to trace requests.
The request failed due to an unexpected error.

x-request-id

string required
A unique identifier used to trace requests.
The request failed because a downstream service failed to respond.

x-request-id

string required
A unique identifier used to trace requests.

Headers

X-Moov-Version

string
Set this header to v2026.04.00 to use the API described in this specification. When omitted, the server defaults to v2024.01.00, which may not match the behavior documented here.
Possible values: v2026.04.00

Path parameters

accountID

string required

invoiceID

string required

Response

application/json

amount

object
Show child attributes

currency

string required Pattern
A 3-letter ISO 4217 currency code.

valueDecimal

string required Pattern

A decimal-formatted numerical string that represents up to 9 decimal place precision.

For example, $12.987654321 is '12.987654321'.

external

object
Show child attributes

description

string

foreignID

string

paymentDate

string<date-time>

invoicePaymentID

string <=36 characters
A unique identifier for a Moov resource. Supports UUID format (xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx) or typed format with base32-encoded UUID and type suffix (e.g., kuoaydiojf7uszaokc2ggnaaaa_xfer).

invoicePaymentType

string<enum>
Possible values: transfer, external

transfer

object
Show child attributes

transferID

string <=36 characters required
A unique identifier for a Moov resource. Supports UUID format (xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx) or typed format with base32-encoded UUID and type suffix (e.g., kuoaydiojf7uszaokc2ggnaaaa_xfer).