type Cloudflare = {
token: string;
email: string;
key: string;
};
/**
* Get a WAF rule
* Fetches the details of a WAF rule in a WAF package.
**Note:** Applies only to the [previous version of WAF managed rules](https://developers.cloudflare.com/support/firewall/managed-rules-web-application-firewall-waf/understanding-waf-managed-rules-web-application-firewall/).
*/
export async function main(
auth: Cloudflare,
identifier: string,
package_id: string,
zone_id: string
) {
const url = new URL(
`https://api.cloudflare.com/client/v4/zones/${zone_id}/firewall/waf/packages/${package_id}/rules/${identifier}`
);
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 383 days ago
type Cloudflare = {
token: string;
email: string;
key: string;
};
/**
* Get a WAF rule
* Fetches the details of a WAF rule in a WAF package.
**Note:** Applies only to the [previous version of WAF managed rules](https://developers.cloudflare.com/support/firewall/managed-rules-web-application-firewall-waf/understanding-waf-managed-rules-web-application-firewall/).
*/
export async function main(
auth: Cloudflare,
identifier: string,
package_id: string,
zone_id: string
) {
const url = new URL(
`https://api.cloudflare.com/client/v4/zones/${zone_id}/firewall/waf/packages/${package_id}/rules/${identifier}`
);
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 920 days ago