Change Security Header (HSTS) setting

Cloudflare security header for a zone.

Script cloudflare Verified

by hugo697 ยท 11/16/2023

The script

Submitted by hugo697 Typescript (fetch-only)
Verified 383 days ago
1
type Cloudflare = {
2
  token: string;
3
  email: string;
4
  key: string;
5
};
6
/**
7
 * Change Security Header (HSTS) setting
8
 * Cloudflare security header for a zone.
9
 */
10
export async function main(
11
  auth: Cloudflare,
12
  zone_identifier: string,
13
  body: {
14
    value: {
15
      strict_transport_security?: {
16
        enabled?: boolean;
17
        include_subdomains?: boolean;
18
        max_age?: number;
19
        nosniff?: boolean;
20
        [k: string]: unknown;
21
      };
22
      [k: string]: unknown;
23
    };
24
    [k: string]: unknown;
25
  }
26
) {
27
  const url = new URL(
28
    `https://api.cloudflare.com/client/v4/zones/${zone_identifier}/settings/security_header`
29
  );
30

31
  const response = await fetch(url, {
32
    method: "PATCH",
33
    headers: {
34
      "X-AUTH-EMAIL": auth.email,
35
      "X-AUTH-KEY": auth.key,
36
      "Content-Type": "application/json",
37
      Authorization: "Bearer " + auth.token,
38
    },
39
    body: JSON.stringify(body),
40
  });
41
  if (!response.ok) {
42
    const text = await response.text();
43
    throw new Error(`${response.status} ${text}`);
44
  }
45
  return await response.json();
46
}
47