0

Update board

by
Published Dec 20, 2024

Update a board owned by the "operating user_account". - Optional: Business Access: Specify an ad_account_id to use the owner of that ad_account as the "operation user_account". - By default, the "operation user_account" is the token user_account.

Script pinterest Verified

The script

Submitted by hugo697 Bun
Verified 536 days ago
1
//native
2
type Pinterest = {
3
  token: string;
4
};
5
/**
6
 * Update board
7
 * Update a board owned by the "operating user_account".
8
- Optional: Business Access: Specify an ad_account_id to use the owner of that ad_account as the "operation user_account".
9
- By default, the "operation user_account" is the token user_account.
10
 */
11
export async function main(
12
  auth: Pinterest,
13
  board_id: string,
14
  ad_account_id: string | undefined,
15
  body: { name?: string; description?: string; privacy?: "PUBLIC" | "SECRET" },
16
) {
17
  const url = new URL(`https://api.pinterest.com/v5/boards/${board_id}`);
18
  for (const [k, v] of [["ad_account_id", ad_account_id]]) {
19
    if (v !== undefined && v !== "" && k !== undefined) {
20
      url.searchParams.append(k, v);
21
    }
22
  }
23
  const response = await fetch(url, {
24
    method: "PATCH",
25
    headers: {
26
      "Content-Type": "application/json",
27
      Authorization: "Bearer " + auth.token,
28
    },
29
    body: JSON.stringify(body),
30
  });
31
  if (!response.ok) {
32
    const text = await response.text();
33
    throw new Error(`${response.status} ${text}`);
34
  }
35
  return await response.json();
36
}
37