0

DeleteInvoiceAttachment

by
Published Oct 17, 2025

Removes an attachment from an invoice and permanently deletes the file. Attachments can be removed only from invoices in the `DRAFT`, `SCHEDULED`, `UNPAID`, or `PARTIALLY_PAID` state.

Script square Verified

The script

Submitted by hugo697 Bun
Verified 235 days ago
1
//native
2
type Square = {
3
  token: string;
4
};
5
/**
6
 * DeleteInvoiceAttachment
7
 * Removes an attachment from an invoice and permanently deletes the file. Attachments can be removed only
8
from invoices in the `DRAFT`, `SCHEDULED`, `UNPAID`, or `PARTIALLY_PAID` state.
9
 */
10
export async function main(
11
  auth: Square,
12
  invoice_id: string,
13
  attachment_id: string,
14
) {
15
  const url = new URL(
16
    `https://connect.squareup.com/v2/invoices/${invoice_id}/attachments/${attachment_id}`,
17
  );
18

19
  const response = await fetch(url, {
20
    method: "DELETE",
21
    headers: {
22
      Authorization: "Bearer " + auth.token,
23
    },
24
    body: undefined,
25
  });
26
  if (!response.ok) {
27
    const text = await response.text();
28
    throw new Error(`${response.status} ${text}`);
29
  }
30
  return await response.json();
31
}
32