0

Void a retainer invoice

by
Published Oct 17, 2025

Mark an invoice status as void. Upon voiding, the payments and credits associated with the retainer invoices will be unassociated and will be under customer credits.

Script zoho Verified

The script

Submitted by hugo697 Bun
Verified 235 days ago
1
//native
2
type Zoho = {
3
  token: string;
4
};
5
/**
6
 * Void a retainer invoice
7
 * Mark an invoice status as void. Upon voiding, the payments and credits associated with the retainer invoices will be unassociated and will be under customer credits.
8
 */
9
export async function main(
10
  auth: Zoho,
11
  retainerinvoice_id: string,
12
  organization_id: string | undefined,
13
) {
14
  const url = new URL(
15
    `https://www.zohoapis.com/inventory/v1/retainerinvoices/${retainerinvoice_id}/status/void`,
16
  );
17
  for (const [k, v] of [["organization_id", organization_id]]) {
18
    if (v !== undefined && v !== "" && k !== undefined) {
19
      url.searchParams.append(k, v);
20
    }
21
  }
22
  const response = await fetch(url, {
23
    method: "POST",
24
    headers: {
25
      Authorization: "Zoho-oauthtoken " + 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