UNPKG

cloudflare

Version:

The official TypeScript library for the Cloudflare API

49 lines 2.09 kB
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. import { APIResource } from 'cloudflare/resource'; import { isRequestOptions } from 'cloudflare/core'; import * as AccessRulesAPI from 'cloudflare/resources/user/firewall/access-rules'; import { V4PagePaginationArray } from 'cloudflare/pagination'; export class AccessRules extends APIResource { /** * Creates a new IP Access rule for all zones owned by the current user. * * Note: To create an IP Access rule that applies to a specific zone, refer to the * [IP Access rules for a zone](#ip-access-rules-for-a-zone) endpoints. */ create(body, options) { return this._client.post('/user/firewall/access_rules/rules', { body, ...options })._thenUnwrap((obj) => obj.result); } list(query = {}, options) { if (isRequestOptions(query)) { return this.list({}, query); } return this._client.getAPIList('/user/firewall/access_rules/rules', FirewallRulesV4PagePaginationArray, { query, ...options, }); } /** * Deletes an IP Access rule at the user level. * * Note: Deleting a user-level rule will affect all zones owned by the user. */ delete(identifier, options) { return this._client.delete(`/user/firewall/access_rules/rules/${identifier}`, options)._thenUnwrap((obj) => obj.result); } /** * Updates an IP Access rule defined at the user level. You can only update the * rule action (`mode` parameter) and notes. */ edit(identifier, body, options) { return this._client.patch(`/user/firewall/access_rules/rules/${identifier}`, { body, ...options, })._thenUnwrap((obj) => obj.result); } } export class FirewallRulesV4PagePaginationArray extends V4PagePaginationArray { } (function (AccessRules) { AccessRules.FirewallRulesV4PagePaginationArray = AccessRulesAPI.FirewallRulesV4PagePaginationArray; })(AccessRules || (AccessRules = {})); //# sourceMappingURL=access-rules.mjs.map