0

CompletePayment

by
Published Oct 17, 2025

Completes (captures) a payment. By default, payments are set to complete immediately after they are created. You can use this endpoint to complete a payment with the APPROVED `status`.

Script square Verified

The script

Submitted by hugo697 Bun
Verified 235 days ago
1
//native
2
type Square = {
3
  token: string;
4
};
5
/**
6
 * CompletePayment
7
 * Completes (captures) a payment.
8
By default, payments are set to complete immediately after they are created.
9

10
You can use this endpoint to complete a payment with the APPROVED `status`.
11
 */
12
export async function main(
13
  auth: Square,
14
  payment_id: string,
15
  body: { version_token?: string },
16
) {
17
  const url = new URL(
18
    `https://connect.squareup.com/v2/payments/${payment_id}/complete`,
19
  );
20

21
  const response = await fetch(url, {
22
    method: "POST",
23
    headers: {
24
      "Content-Type": "application/json",
25
      Authorization: "Bearer " + auth.token,
26
    },
27
    body: JSON.stringify(body),
28
  });
29
  if (!response.ok) {
30
    const text = await response.text();
31
    throw new Error(`${response.status} ${text}`);
32
  }
33
  return await response.json();
34
}
35