0

Create one or more environment variables

by
Published Apr 8, 2025

Create one or more environment variables for a project by passing its `key`, `value`, `type` and `target` and by specifying the project by either passing the project `id` or `name` in the URL. If you include `upsert=true` as a query parameter, a new environment variable will not be created if it already exists but, the existing variable's value will be updated.

Script vercel Verified

The script

Submitted by hugo697 Bun
Verified 428 days ago
1
//native
2
type Vercel = {
3
  token: string;
4
};
5
/**
6
 * Create one or more environment variables
7
 * Create one or more environment variables for a project by passing its `key`, `value`, `type` and `target` and by specifying the project by either passing the project `id` or `name` in the URL. If you include `upsert=true` as a query parameter, a new environment variable will not be created if it already exists but, the existing variable's value will be updated.
8
 */
9
export async function main(
10
  auth: Vercel,
11
  idOrName: string,
12
  upsert: string | undefined,
13
  teamId: string | undefined,
14
  slug: string | undefined,
15
  body: {} | {} | {}[],
16
) {
17
  const url = new URL(`https://api.vercel.com/v10/projects/${idOrName}/env`);
18
  for (const [k, v] of [
19
    ["upsert", upsert],
20
    ["teamId", teamId],
21
    ["slug", slug],
22
  ]) {
23
    if (v !== undefined && v !== "" && k !== undefined) {
24
      url.searchParams.append(k, v);
25
    }
26
  }
27
  const response = await fetch(url, {
28
    method: "POST",
29
    headers: {
30
      "Content-Type": "application/json",
31
      Authorization: "Bearer " + auth.token,
32
    },
33
    body: JSON.stringify(body),
34
  });
35
  if (!response.ok) {
36
    const text = await response.text();
37
    throw new Error(`${response.status} ${text}`);
38
  }
39
  return await response.json();
40
}
41