cloudflare
Version:
The official TypeScript library for the Cloudflare API
62 lines (54 loc) • 1.92 kB
text/typescript
// 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}`.
*/
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,
};
}