List code scanning alerts for a repository

Lists code scanning alerts.

Script github Verified

by hugo697 ยท 10/25/2023

The script

Submitted by hugo697 Typescript (fetch-only)
Verified 366 days ago
1
type Github = {
2
  token: string;
3
};
4
/**
5
 * List code scanning alerts for a repository
6
 * Lists code scanning alerts.
7
 */
8
export async function main(
9
  auth: Github,
10
  owner: string,
11
  repo: string,
12
  tool_name: string | undefined,
13
  tool_guid: string | undefined,
14
  page: string | undefined,
15
  per_page: string | undefined,
16
  ref: string | undefined,
17
  direction: "asc" | "desc" | undefined,
18
  sort: "created" | "updated" | undefined,
19
  state: "open" | "closed" | "dismissed" | "fixed" | undefined,
20
  severity:
21
    | "critical"
22
    | "high"
23
    | "medium"
24
    | "low"
25
    | "warning"
26
    | "note"
27
    | "error"
28
    | undefined
29
) {
30
  const url = new URL(
31
    `https://api.github.com/repos/${owner}/${repo}/code-scanning/alerts`
32
  );
33
  for (const [k, v] of [
34
    ["tool_name", tool_name],
35
    ["tool_guid", tool_guid],
36
    ["page", page],
37
    ["per_page", per_page],
38
    ["ref", ref],
39
    ["direction", direction],
40
    ["sort", sort],
41
    ["state", state],
42
    ["severity", severity],
43
  ]) {
44
    if (v !== undefined && v !== "") {
45
      url.searchParams.append(k, v);
46
    }
47
  }
48
  const response = await fetch(url, {
49
    method: "GET",
50
    headers: {
51
      Authorization: "Bearer " + auth.token,
52
    },
53
    body: undefined,
54
  });
55
  if (!response.ok) {
56
    const text = await response.text();
57
    throw new Error(`${response.status} ${text}`);
58
  }
59
  return await response.json();
60
}
61