0

Create an Object Storage key

by
Published Oct 17, 2025

Provisions a new Object Storage key for authentication.

Script linode Verified

The script

Submitted by hugo697 Bun
Verified 235 days ago
1
//native
2
type Linode = {
3
  token: string;
4
};
5
/**
6
 * Create an Object Storage key
7
 * Provisions a new Object Storage key for authentication.
8
 */
9
export async function main(
10
  auth: Linode,
11
  apiVersion: "v4" | "v4beta",
12
  body: {
13
    bucket_access?: {
14
      bucket_name?: string;
15
      permissions?: "read_write" | "read_only";
16
      region?: string;
17
    }[];
18
    label?: string;
19
    regions?: string[];
20
  },
21
) {
22
  const url = new URL(
23
    `https://api.linode.com/${apiVersion}/object-storage/keys`,
24
  );
25

26
  const response = await fetch(url, {
27
    method: "POST",
28
    headers: {
29
      "Content-Type": "application/json",
30
      Authorization: "Bearer " + auth.token,
31
    },
32
    body: JSON.stringify(body),
33
  });
34
  if (!response.ok) {
35
    const text = await response.text();
36
    throw new Error(`${response.status} ${text}`);
37
  }
38
  return await response.json();
39
}
40