UNPKG

cloudflare

Version:

The official TypeScript library for the Cloudflare API

71 lines (63 loc) 2.1 kB
// File generated from our OpenAPI spec by Stainless. See CONTRIBUTING.md for details. import { APIResource } from '../../../resource'; import * as Core from '../../../core'; export class Patterns extends APIResource { /** * Validates whether this pattern is a valid regular expression. Rejects it if the * regular expression is too complex or can match an unbounded-length string. The * regex will be rejected if it uses `*` or `+`. Bound the maximum number of * characters that can be matched using a range, e.g. `{1,100}`. * * @example * ```ts * const response = * await client.zeroTrust.dlp.patterns.validate({ * account_id: 'account_id', * regex: 'regex', * }); * ``` */ validate( params: PatternValidateParams, options?: Core.RequestOptions, ): Core.APIPromise<PatternValidateResponse> { const { account_id, ...body } = params; return ( this._client.post(`/accounts/${account_id}/dlp/patterns/validate`, { body, ...options, }) as Core.APIPromise<{ result: PatternValidateResponse }> )._thenUnwrap((obj) => obj.result); } } export interface PatternValidateResponse { valid: boolean; } export interface PatternValidateParams { /** * Path param: Account ID. */ account_id: string; /** * Body param: */ regex: string; /** * Body param: Maximum number of bytes that the regular expression can match. * * If this is `null` then there is no limit on the length. Patterns can use `*` and * `+`. Otherwise repeats should use a range `{m,n}` to restrict patterns to the * length. If this field is missing, then a default length limit is used. * * Note that the length is specified in bytes. Since regular expressions use UTF-8 * the pattern `.` can match up to 4 bytes. Hence `.{1,256}` has a maximum length * of 1024 bytes. */ max_match_bytes?: number | null; } export declare namespace Patterns { export { type PatternValidateResponse as PatternValidateResponse, type PatternValidateParams as PatternValidateParams, }; }