0

List invoices

by
Published Apr 8, 2025

Lists invoices. To filter the invoices that appear in the response, you can specify one or more optional query parameters.

Script paypal Verified

The script

Submitted by hugo697 Bun
Verified 427 days ago
1
//native
2
type Paypal = {
3
  clientId: string;
4
  clientSecret: string;
5
};
6

7
async function getToken(auth: Paypal): Promise<string> {
8
  const url = new URL(`https://api-m.paypal.com/v1/oauth2/token`);
9
  const response = await fetch(url, {
10
    method: "POST",
11
    headers: {
12
      Authorization: `Basic ${btoa(`${auth.clientId}:${auth.clientSecret}`)}`,
13
    },
14
    body: new URLSearchParams({
15
      grant_type: "client_credentials",
16
    }),
17
  });
18
  if (!response.ok) {
19
    const text = await response.text();
20
    throw new Error(`Could not get token: ${response.status} ${text}`);
21
  }
22
  const json = await response.json();
23
  return json.access_token;
24
}
25
/**
26
 * List invoices
27
 * Lists invoices. To filter the invoices that appear in the response, you can specify one or more optional query parameters.
28
 */
29
export async function main(
30
  auth: Paypal,
31
  page: string | undefined,
32
  page_size: string | undefined,
33
  total_required: string | undefined,
34
  fields: string | undefined,
35
) {
36
  const token = await getToken(auth);
37
  const url = new URL(`https://api-m.paypal.com/v2/invoicing/invoices`);
38
  for (const [k, v] of [
39
    ["page", page],
40
    ["page_size", page_size],
41
    ["total_required", total_required],
42
    ["fields", fields],
43
  ]) {
44
    if (v !== undefined && v !== "" && k !== undefined) {
45
      url.searchParams.append(k, v);
46
    }
47
  }
48
  const response = await fetch(url, {
49
    method: "GET",
50
    headers: {
51
      Authorization: "Bearer " + token,
52
    },
53
    body: undefined,
54
  });
55
  if (!response.ok) {
56
    const text = await response.text();
57
    throw new Error(`${response.status} ${text}`);
58
  }
59
  return await response.json();
60
}
61