1 | |
2 | type Netlify = { |
3 | token: string; |
4 | }; |
5 | |
6 | * Create site asset |
7 | * |
8 | */ |
9 | export async function main( |
10 | auth: Netlify, |
11 | site_id: string, |
12 | name: string | undefined, |
13 | size: string | undefined, |
14 | content_type: string | undefined, |
15 | visibility: string | undefined, |
16 | ) { |
17 | const url = new URL(`https://api.netlify.com/api/v1/sites/${site_id}/assets`); |
18 | for (const [k, v] of [ |
19 | ["name", name], |
20 | ["size", size], |
21 | ["content_type", content_type], |
22 | ["visibility", visibility], |
23 | ]) { |
24 | if (v !== undefined && v !== "" && k !== undefined) { |
25 | url.searchParams.append(k, v); |
26 | } |
27 | } |
28 | const response = await fetch(url, { |
29 | method: "POST", |
30 | headers: { |
31 | Authorization: "Bearer " + auth.token, |
32 | }, |
33 | body: undefined, |
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 |
|