UNPKG

cloudflare

Version:

The official TypeScript library for the Cloudflare API

119 lines 4.62 kB
import * as Core from 'cloudflare/core'; import { APIResource } from 'cloudflare/resource'; import * as GroupsAPI from 'cloudflare/resources/firewall/waf/packages/groups'; import { V4PagePaginationArray, type V4PagePaginationArrayParams } from 'cloudflare/pagination'; export declare class Groups extends APIResource { /** * Fetches the WAF rule groups 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/). */ list(packageId: string, params: GroupListParams, options?: Core.RequestOptions): Core.PagePromise<WAFManagedRulesGroupsV4PagePaginationArray, WAFManagedRulesGroup>; /** * Updates a WAF rule group. You can update the state (`mode` parameter) of a rule * group. * * **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/). */ edit(packageId: string, groupId: string, params: GroupEditParams, options?: Core.RequestOptions): Core.APIPromise<GroupEditResponse>; /** * Fetches the details of a WAF rule group. * * **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/). */ get(packageId: string, groupId: string, params: GroupGetParams, options?: Core.RequestOptions): Core.APIPromise<GroupGetResponse>; } export declare class WAFManagedRulesGroupsV4PagePaginationArray extends V4PagePaginationArray<WAFManagedRulesGroup> { } export interface WAFManagedRulesGroup { /** * The unique identifier of the rule group. */ id: string; /** * An informative summary of what the rule group does. */ description: string | null; /** * The state of the rules contained in the rule group. When `on`, the rules in the * group are configurable/usable. */ mode: 'on' | 'off'; /** * The name of the rule group. */ name: string; /** * The number of rules in the current rule group. */ rules_count: number; /** * The available states for the rule group. */ allowed_modes?: Array<'on' | 'off'>; /** * The number of rules within the group that have been modified from their default * configuration. */ modified_rules_count?: number; /** * The unique identifier of a WAF package. */ package_id?: string; } export type GroupEditResponse = unknown | Array<unknown> | string; export type GroupGetResponse = unknown | Array<unknown> | string; export interface GroupListParams extends V4PagePaginationArrayParams { /** * Path param: Identifier */ zone_id: string; /** * Query param: The direction used to sort returned rule groups. */ direction?: 'asc' | 'desc'; /** * Query param: When set to `all`, all the search requirements must match. When set * to `any`, only one of the search requirements has to match. */ match?: 'any' | 'all'; /** * Query param: The state of the rules contained in the rule group. When `on`, the * rules in the group are configurable/usable. */ mode?: 'on' | 'off'; /** * Query param: The field used to sort returned rule groups. */ order?: 'mode' | 'rules_count'; } export interface GroupEditParams { /** * Path param: Identifier */ zone_id: string; /** * Body param: The state of the rules contained in the rule group. When `on`, the * rules in the group are configurable/usable. */ mode?: 'on' | 'off'; } export interface GroupGetParams { /** * Identifier */ zone_id: string; } export declare namespace Groups { export import WAFManagedRulesGroup = GroupsAPI.WAFManagedRulesGroup; export import GroupEditResponse = GroupsAPI.GroupEditResponse; export import GroupGetResponse = GroupsAPI.GroupGetResponse; export import WAFManagedRulesGroupsV4PagePaginationArray = GroupsAPI.WAFManagedRulesGroupsV4PagePaginationArray; export import GroupListParams = GroupsAPI.GroupListParams; export import GroupEditParams = GroupsAPI.GroupEditParams; export import GroupGetParams = GroupsAPI.GroupGetParams; } //# sourceMappingURL=groups.d.ts.map