0

Creative Upscale

by
Published Apr 8, 2025
Script recraft Verified

The script

Submitted by hugo697 Bun
Verified 428 days ago
1
//native
2
type Recraft = {
3
  apiKey: string;
4
};
5
type Base64 = string;
6
/**
7
 * Creative Upscale
8
 *
9
 */
10
export async function main(
11
  auth: Recraft,
12
  body: {
13
    image: {
14
      base64: Base64;
15
      type:
16
        | "image/png"
17
        | "image/jpeg"
18
        | "image/gif"
19
        | "application/pdf"
20
        | "appication/json"
21
        | "text/csv"
22
        | "text/plain"
23
        | "audio/mpeg"
24
        | "audio/wav"
25
        | "video/mp4";
26
      name: string;
27
    };
28
    response_format?: "url" | "b64_json";
29
  },
30
) {
31
  const url = new URL(
32
    `https://external.api.recraft.ai/v1/images/creativeUpscale`,
33
  );
34

35
  const formData = new FormData();
36
  for (const [k, v] of Object.entries(body)) {
37
    if (v !== undefined) {
38
      if (["image"].includes(k)) {
39
        const { base64, type, name } = v as {
40
          base64: Base64;
41
          type: string;
42
          name: string;
43
        };
44
        formData.append(
45
          k,
46
          new Blob([Uint8Array.from(atob(base64), (m) => m.codePointAt(0)!)], {
47
            type,
48
          }),
49
          name,
50
        );
51
      } else {
52
        formData.append(k, String(v));
53
      }
54
    }
55
  }
56
  const response = await fetch(url, {
57
    method: "POST",
58
    headers: {
59
      Authorization: "Bearer " + auth.apiKey,
60
    },
61
    body: formData,
62
  });
63
  if (!response.ok) {
64
    const text = await response.text();
65
    throw new Error(`${response.status} ${text}`);
66
  }
67
  return await response.json();
68
}
69