0

Download a cache artifact

by
Published Apr 8, 2025

Downloads a cache artifact indentified by its `hash` specified on the request path. The artifact is downloaded as an octet-stream. The client should verify the content-length header and response body.

Script vercel Verified

The script

Submitted by hugo697 Bun
Verified 428 days ago
1
//native
2
type Vercel = {
3
  token: string;
4
};
5
/**
6
 * Download a cache artifact
7
 * Downloads a cache artifact indentified by its `hash` specified on the request path. The artifact is downloaded as an octet-stream. The client should verify the content-length header and response body.
8
 */
9
export async function main(
10
  auth: Vercel,
11
  hash: string,
12
  teamId: string | undefined,
13
  slug: string | undefined,
14
  x_artifact_client_ci?: string,
15
  x_artifact_client_interactive?: string,
16
) {
17
  const url = new URL(`https://api.vercel.com/v8/artifacts/${hash}`);
18
  for (const [k, v] of [
19
    ["teamId", teamId],
20
    ["slug", slug],
21
  ]) {
22
    if (v !== undefined && v !== "" && k !== undefined) {
23
      url.searchParams.append(k, v);
24
    }
25
  }
26
  const response = await fetch(url, {
27
    method: "GET",
28
    headers: {
29
      ...(x_artifact_client_ci
30
        ? { "x-artifact-client-ci": x_artifact_client_ci }
31
        : {}),
32
      ...(x_artifact_client_interactive
33
        ? { "x-artifact-client-interactive": x_artifact_client_interactive }
34
        : {}),
35
      Authorization: "Bearer " + auth.token,
36
    },
37
    body: undefined,
38
  });
39
  if (!response.ok) {
40
    const text = await response.text();
41
    throw new Error(`${response.status} ${text}`);
42
  }
43
  return await response.json();
44
}
45