0

DeleteInvoice

by
Published Oct 17, 2025

Deletes the specified invoice. When an invoice is deleted, the associated order status changes to CANCELED. You can only delete a draft invoice (you cannot delete a published invoice, including one that is scheduled for processing).

Script square Verified

The script

Submitted by hugo697 Bun
Verified 235 days ago
1
//native
2
type Square = {
3
  token: string;
4
};
5
/**
6
 * DeleteInvoice
7
 * Deletes the specified invoice. When an invoice is deleted, the 
8
associated order status changes to CANCELED. You can only delete a draft 
9
invoice (you cannot delete a published invoice, including one that is scheduled for processing).
10
 */
11
export async function main(
12
  auth: Square,
13
  invoice_id: string,
14
  version: string | undefined,
15
) {
16
  const url = new URL(`https://connect.squareup.com/v2/invoices/${invoice_id}`);
17
  for (const [k, v] of [["version", version]]) {
18
    if (v !== undefined && v !== "" && k !== undefined) {
19
      url.searchParams.append(k, v);
20
    }
21
  }
22
  const response = await fetch(url, {
23
    method: "DELETE",
24
    headers: {
25
      Authorization: "Bearer " + auth.token,
26
    },
27
    body: undefined,
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