type Cloudflare = {
token: string;
email: string;
key: string;
};
/**
* Get Managed Rules Summary
* Percentage distribution of attacks by managed rules used.
*/
export async function main(
auth: Cloudflare,
name: string | undefined,
dateRange: string | undefined,
dateStart: string | undefined,
dateEnd: string | undefined,
asn: string | undefined,
location: string | undefined,
ipVersion: string | undefined,
httpVersion: string | undefined,
httpMethod: string | undefined,
mitigationProduct: string | undefined,
format: "JSON" | "CSV" | undefined
) {
const url = new URL(
`https://api.cloudflare.com/client/v4/radar/attacks/layer7/summary/managed_rules`
);
for (const [k, v] of [
["name", name],
["dateRange", dateRange],
["dateStart", dateStart],
["dateEnd", dateEnd],
["asn", asn],
["location", location],
["ipVersion", ipVersion],
["httpVersion", httpVersion],
["httpMethod", httpMethod],
["mitigationProduct", mitigationProduct],
["format", format],
]) {
if (v !== undefined && v !== "") {
url.searchParams.append(k, v);
}
}
const response = await fetch(url, {
method: "GET",
headers: {
"X-AUTH-EMAIL": auth.email,
"X-AUTH-KEY": auth.key,
Authorization: "Bearer " + auth.token,
},
body: undefined,
});
if (!response.ok) {
const text = await response.text();
throw new Error(`${response.status} ${text}`);
}
return await response.json();
}
Submitted by hugo697 402 days ago