import * as _isBoolean from "./lib/isBoolean";
import * as _isEmail from "./lib/isEmail";
import * as _isFQDN from "./lib/isFQDN";
import * as _isIBAN from "./lib/isIBAN";
import * as _isISO31661Alpha2 from "./lib/isISO31661Alpha2";
import * as _isISO4217 from "./lib/isISO4217";
import * as _isISO6391 from "./lib/isISO6391";
import * as _isTaxID from "./lib/isTaxID";
import * as _isURL from "./lib/isURL";
declare namespace validator {
export const version: string;
/******************
*** Validators ***
******************/
export interface ContainsOptions {
/**
* @default false
*/
ignoreCase?: boolean | undefined;
/**
* @default 1
*/
minOccurrences?: number | undefined;
}
/**
* Check if the string contains the seed.
*
* @param seed - Seed
*/
export function contains(str: string, seed: any, options?: ContainsOptions): boolean;
/**
* Check if the string matches the comparison.
*
* @param comparison - String to compare
*/
export function equals(str: string, comparison: string): boolean;
/**
* Check if the string is a date that's after the specified date.
*
* @param [date] - Date string (defaults to now)
*/
export function isAfter(str: string, date?: string): boolean;
export type AlphaLocale =
| "en-US"
| "bg-BG"
| "cs-CZ"
| "da-DK"
| "de-DE"
| "el-GR"
| "es-AR"
| "es-ES"
| "fr-FR"
| "it-IT"
| "nb-NO"
| "nl-NL"
| "nn-NO"
| "hu-HU"
| "pl-PL"
| "pt-PT"
| "ru-RU"
| "sl-SI"
| "sk-SK"
| "sr-RS@latin"
| "sr-RS"
| "sv-SE"
| "tr-TR"
| "uk-UA"
| "ku-IQ"
| "ar"
| "he"
| "fa-IR"
| "en-AU"
| "en-GB"
| "en-HK"
| "en-IN"
| "en-NZ"
| "en-ZA"
| "en-ZM"
| "ar-AE"
| "ar-BH"
| "ar-DZ"
| "ar-EG"
| "ar-IQ"
| "ar-JO"
| "ar-KW"
| "ar-LB"
| "ar-LY"
| "ar-MA"
| "ar-QM"
| "ar-QA"
| "ar-SA"
| "ar-SD"
| "ar-SY"
| "ar-TN"
| "ar-YE"
| "pt-BR"
| "pl-Pl";
export const isAlphaLocales: AlphaLocale[];
export interface IsAlphaOptions {
/**
* @default undefined
*/
ignore?: string | RegExp | undefined;
}
/**
* Check if the string contains only letters (a-zA-Z).
*
* @param [locale] - AlphaLocale
* @param [options] - IsAlphaOptions
*/
export function isAlpha(str: string, locale?: AlphaLocale, options?: IsAlphaOptions): boolean;
export type AlphanumericLocale =
| "en-US"
| "bg-BG"
| "cs-CZ"
| "da-DK"
| "de-DE"
| "el-GR"
| "es-AR"
| "es-ES"
| "fr-FR"
| "it-IT"
| "hu-HU"
| "nb-NO"
| "nl-NL"
| "nn-NO"
| "pl-PL"
| "pt-PT"
| "ru-RU"
| "sl-SI"
| "sk-SK"
| "sr-RS@latin"
| "sr-RS"
| "sv-SE"
| "tr-TR"
| "uk-UA"
| "ku-IQ"
| "ar"
| "he"
| "fa-IR"
| "en-AU"
| "en-GB"
| "en-HK"
| "en-IN"
| "en-NZ"
| "en-ZA"
| "en-ZM"
| "ar-AE"
| "ar-BH"
| "ar-DZ"
| "ar-EG"
| "ar-IQ"
| "ar-JO"
| "ar-KW"
| "ar-LB"
| "ar-LY"
| "ar-MA"
| "ar-QM"
| "ar-QA"
| "ar-SA"
| "ar-SD"
| "ar-SY"
| "ar-TN"
| "ar-YE"
| "pt-BR"
| "pl-Pl";
export const isAlphanumericLocales: AlphanumericLocale[];
export interface IsAlphanumericOptions {
/**
* @default undefined
*/
ignore?: string | RegExp | undefined;
}
/**
* Check if the string contains only letters and numbers.
*
* @param [locale] - AlphanumericLocale
* @param [options] - IsAlphanumericOptions
*/
export function isAlphanumeric(str: string, locale?: AlphanumericLocale, options?: IsAlphanumericOptions): boolean;
/**
* Check if the string contains ASCII chars only.
*/
export function isAscii(str: string): boolean;
/**
* Check if a string is base32 encoded.
*/
export function isBase32(str: string): boolean;
/**
* check if a string is base58 encoded
*/
export function isBase58(str: string): boolean;
export interface IsBase64Options {
/**
* @default false
*/
urlSafe?: boolean | undefined;
}
/**
* Check if a string is base64 encoded.
*
* @param [options] - Options
*/
export function isBase64(str: string, options?: IsBase64Options): boolean;
/**
* Check if the string is a date that's before the specified date.
*
* @param [date] - Date string (defaults to now)
*/
export function isBefore(str: string, date?: string): boolean;
export const isIBAN: typeof _isIBAN.default;
export const ibanLocales: typeof _isIBAN.locales;
/**
* Check if a string is a BIC (Bank Identification Code) or SWIFT code.
*/
export function isBIC(str: string): boolean;
export const isBoolean: typeof _isBoolean.default;
export interface IsByteLengthOptions {
/**
* @default 0
*/
min?: number | undefined;
/**
* @default undefined
*/
max?: number | undefined;
}
/**
* Check if the string's length (in UTF-8 bytes) falls in a range.
*
* @param [options] - Options
*/
export function isByteLength(str: string, options?: IsByteLengthOptions): boolean;
export interface IsCreditCardOptions {
/**
* @default undefined
*/
provider?: "amex" | "dinersclub" | "discover" | "jcb" | "mastercard" | "unionpay" | "visa" | "";
}
/**
* Check if the string is a credit card.
*/
export function isCreditCard(str: string, options?: IsCreditCardOptions): boolean;
export interface IsCurrencyOptions {
/**
* @default '$'
*/
symbol?: string | undefined;
/**
* @default false
*/
require_symbol?: boolean | undefined;
/**
* @default false
*/
allow_space_after_symbol?: boolean | undefined;
/**
* @default false
*/
symbol_after_digits?: boolean | undefined;
/**
* @default true
*/
allow_negatives?: boolean | undefined;
/**
* @default false
*/
parens_for_negatives?: boolean | undefined;
/**
* @default false
*/
negative_sign_before_digits?: boolean | undefined;
/**
* @default false
*/
negative_sign_after_digits?: boolean | undefined;
/**
* @default false
*/
allow_negative_sign_placeholder?: boolean | undefined;
/**
* @default ','
*/
thousands_separator?: string | undefined;
/**
* @default '.'
*/
decimal_separator?: string | undefined;
/**
* @default true
*/
allow_decimal?: boolean | undefined;
/**
* @default false
*/
require_decimal?: boolean | undefined;
/**
* The array `digits_after_decimal` is filled with the exact number of digits allowed not a range, for example a range `1` to `3` will be given as `[1, 2, 3]`.
*
* @default [2]
*/
digits_after_decimal?: number[] | undefined;
/**
* @default false
*/
allow_space_after_digits?: boolean | undefined;
}
/**
* Check if the string is a valid currency amount.
*
* @param [options] - Options
*/
export function isCurrency(str: string, options?: IsCurrencyOptions): boolean;
/**
* Check if the string is an [Ethereum](https://ethereum.org/) address using basic regex. Does not validate address checksums.
*/
export function isEthereumAddress(str: string): boolean;
/**
* Check if the string is a valid BTC address.
*/
export function isBtcAddress(str: string): boolean;
/**
* Check if the string is a [data uri format](https://developer.mozilla.org/en-US/docs/Web/HTTP/data_URIs).
*/
export function isDataURI(str: string): boolean;
export interface IsDateOptions {
/**
* @default false
*/
format?: string | undefined;
/**
* If strictMode is set to true,
* the validator will reject inputs different from format.
*
* @default false
*/
strictMode?: boolean | undefined;
/**
* `delimiters` is an array of allowed date delimiters
*
* @default ['/', '-']
*/
delimiters?: string[] | undefined;
}
/**
* Check if the string is a valid date.
*/
export function isDate(str: string, options?: IsDateOptions): boolean;
export type DecimalLocale = FloatLocale;
export interface IsDecimalOptions {
/**
* @default false
*/
force_decimal?: boolean | undefined;
/**
* `decimal_digits` is given as a range like `'1,3'`,
* a specific value like `'3'` or min like `'1,'`
*
* @default '1,'
*/
decimal_digits?: string | undefined;
/**
* DecimalLocale
*
* @default 'en-US'
*/
locale?: DecimalLocale | undefined;
}
/**
* Check if the string represents a decimal number,
* such as `0.1`, `.3`, `1.1`, `1.00003`, `4.0` etc.
*
* @param [options] - Options
*/
export function isDecimal(str: string, options?: IsDecimalOptions): boolean;
/**
* Check if the string is a number that's divisible by another.
*
* @param number - Divider number
*/
export function isDivisibleBy(str: string, number: number): boolean;
export type IsEmailOptions = _isEmail.IsEmailOptions;
export const isEmail: typeof _isEmail.default;
/**
* check if the string is a [Magnet URI format][Mailto URI Format].
`options` is an object of validating emails inside the URI (check `isEmail`s options for details).
* @param str
* @param [options]
*/
export function isMailtoURI(str: string, options?: IsEmailOptions): boolean;
export interface IsEmptyOptions {
/**
* @default false
*/
ignore_whitespace?: boolean | undefined;
}
/**
* Check if the string has a length of zero.
*
* @param [options] - Options
*/
export function isEmpty(str: string, options?: IsEmptyOptions): boolean;
export type FloatLocale =
| "en-US"
| "ar"
| "en-AU"
| "en-GB"
| "en-HK"
| "en-IN"
| "en-NZ"
| "en-ZA"
| "en-ZM"
| "ar-AE"
| "ar-BH"
| "ar-DZ"
| "ar-EG"
| "ar-IQ"
| "ar-JO"
| "ar-KW"
| "ar-LB"
| "ar-LY"
| "ar-MA"
| "ar-QM"
| "ar-QA"
| "ar-SA"
| "ar-SD"
| "ar-SY"
| "ar-TN"
| "ar-YE"
| "bg-BG"
| "cs-CZ"
| "da-DK"
| "de-DE"
| "el-GR"
| "es-ES"
| "fr-FR"
| "it-IT"
| "ku-IQ"
| "hu-HU"
| "nb-NO"
| "nn-NO"
| "nl-NL"
| "pl-PL"
| "pt-PT"
| "ru-RU"
| "sl-SI"
| "sr-RS@latin"
| "sr-RS"
| "sv-SE"
| "tr-TR"
| "uk-UA"
| "pt-BR"
| "pl-Pl";
export const isFloatLocales: FloatLocale[];
export interface IsFloatOptions {
/**
* less or equal
*/
min?: number | undefined;
/**
* greater or equal
*/
max?: number | undefined;
/**
* greater than
*/
gt?: number | undefined;
/**
* less than
*/
lt?: number | undefined;
/**
* FloatLocale
*/
locale?: FloatLocale | undefined;
}
/**
* Check if the string is a float.
*
* @param [options] - Options
*/
export function isFloat(str: string, options?: IsFloatOptions): boolean;
export type IsFQDNOptions = _isFQDN.IsFQDNOptions;
export const isFQDN: typeof _isFQDN.default;
/**
* Check if the string contains any full-width chars.
*/
export function isFullWidth(str: string): boolean;
/**
* Check if the string contains any half-width chars.
*/
export function isHalfWidth(str: string): boolean;
export type HashAlgorithm =
| "md4"
| "md5"
| "sha1"
| "sha256"
| "sha384"
| "sha512"
| "ripemd128"
| "ripemd160"
| "tiger128"
| "tiger160"
| "tiger192"
| "crc32"
| "crc32b";
/**
* Check if the string is a hash of export type algorithm.
*
* @param algorithm - HashAlgorithm
*/
export function isHash(str: string, algorithm: HashAlgorithm): boolean;
/**
* Check if the string is a hexadecimal number.
*/
export function isHexadecimal(str: string): boolean;
/**
* Check if the string is a hexadecimal color.
*/
export function isHexColor(str: string): boolean;
/**
* Check if the string is an HSL (hue, saturation, lightness, optional alpha) color based on CSS Colors Level 4 specification.
* Comma-separated format supported. Space-separated format supported with the exception of a few edge cases (ex: hsl(200grad+.1%62%/1)).
*/
export function isHSL(str: string): boolean;
/**
* Check if the string is a rgb or rgba color.
*
* @param [includePercentValues=true] - If you don't want to allow to set rgb or rgba values with percents, like rgb(5%,5%,5%), or rgba(90%,90%,90%,.3), then set it to false. (defaults to true)
*/
export function isRgbColor(str: string, includePercentValues?: boolean): boolean;
export type IdentityCardLocale =
| "ar-LY"
| "ar-TN"
| "ES"
| "FI"
| "he-IL"
| "IN"
| "IR"
| "IT"
| "LK"
| "NO"
| "PL"
| "TH"
| "zh-CN"
| "zh-HK"
| "zh-TW";
/**
* Check if the string is a valid identity card code.
*
* @param [locale="any"] - IdentityCardLocale
*/
export function isIdentityCard(str: string, locale?: "any" | IdentityCardLocale): boolean;
export interface IsIMEIOptions {
/**
* This value is `false` by default. Set to `true` to allow IMEI with hyphens.
*/
allow_hyphens?: boolean | undefined;
}
/**
* Check if the string is a valid IMEI.
* Non-hyphenated (`###############`) only is supported by default.
* Use the `options` param to enable hyphenated (`##-######-######-#`) support.
*
* @param [options] - Options
*/
export function isIMEI(str: string, options?: IsIMEIOptions): boolean;
/**
* Check if the string is in a array of allowed values.
*
* @param values - Allowed values.
*/
export function isIn(str: string, values: any[]): boolean;
export interface IsIntOptions {
/**
* to check the integer min boundary
*/
min?: number | undefined;
/**
* to check the integer max boundary
*/
max?: number | undefined;
/**
* if `false`, will disallow integer values with leading zeroes
* @default true
*/
allow_leading_zeroes?: boolean | undefined;
/**
* enforce integers being greater than the value provided
*/
lt?: number | undefined;
/**
* enforce integers being less than the value provided
*/
gt?: number | undefined;
}
/**
* Check if the string is an integer.
*
* @param [options] - Options
*/
export function isInt(str: string, options?: IsIntOptions): boolean;
export type IPVersion = "4" | "6" | 4 | 6;
/**
* Check if the string is an IP (version 4 or 6).
*
* @param [version] - IP Version
*/
export function isIP(str: string, version?: IPVersion): boolean;
/**
* Check if the string is an IP Range (version 4 or 6).
*/
export function isIPRange(str: string, version?: IPVersion): boolean;
export type ISBNVersion = "10" | "13" | 10 | 13;
/**
* Check if the string is an ISBN (version 10 or 13).
*
* @param [version] - ISBN Version
*/
export function isISBN(str: string, version?: ISBNVersion): boolean;
/**
* Check if the string is an EAN (European Article Number).
*/
export function isEAN(str: string): boolean;
/**
* Check if the string is an [ISIN](https://en.wikipedia.org/wiki/International_Securities_Identification_Number) (stock/security identifier).
*/
export function isISIN(str: string): boolean;
export const isISO31661Alpha2: typeof _isISO31661Alpha2.default;
/**
* Check if the string is a valid [ISO 3166-1 alpha-3](https://en.wikipedia.org/wiki/ISO_3166-1_alpha-3) officially assigned country code.
*/
export function isISO31661Alpha3(str: string): boolean;
/**
* check if the string is a valid [ISO 6346](https://en.wikipedia.org/wiki/ISO_6346) shipping container identification.
* @param str
*/
export function isISO6346(str: string): boolean;
/**
* alias for `isISO6346`, check if the string is a valid [ISO 6346](https://en.wikipedia.org/wiki/ISO_6346) shipping container identification.
*/
export const isFreightContainerID: typeof isISO6346;
/**
* Check if the string is a valid [ISO 639-1](https://en.wikipedia.org/wiki/ISO_639-1) officially assigned language code.
*/
export const isISO6391: typeof _isISO6391.default;
export interface IsISO8601Options {
/**
* If `strict` is `true`, performs additional checks for valid dates,
* e.g. invalidates dates like `2009-02-29`.
*
* @default false
*/
strict?: boolean | undefined;
/**
* If `strictSeparator` is true, date strings with date and time separated
* by anything other than a T will be invalid
*/
strictSeparator?: boolean | undefined;
}
/**
* Check if the string is a valid [ISO 8601](https://en.wikipedia.org/wiki/ISO_8601) date.
*
* @param [options] - Options
*/
export function isISO8601(str: string, options?: IsISO8601Options): boolean;
export interface IsISSNOptions {
/**
* If `case_sensitive` is `true`, ISSNs with a lowercase `x` as the check digit are rejected.
*
* @default false
*/
case_sensitive?: boolean | undefined;
/**
* @default false
*/
require_hyphen?: boolean | undefined;
}
/**
* Check if the string is an [ISSN](https://en.wikipedia.org/wiki/International_Standard_Serial_Number).
*
* @param [options] - Options
*/
export function isISSN(str: string, options?: IsISSNOptions): boolean;
export const isISO4217: typeof _isISO4217.default;
/**
* Check if the string is a [ISRC](https://en.wikipedia.org/wiki/International_Standard_Recording_Code).
*/
export function isISRC(str: string): boolean;
/**
* Check if the string is a valid [RFC 3339](https://tools.ietf.org/html/rfc3339) date.
*/
export function isRFC3339(str: string): boolean;
/**
* Check if the string is valid JSON (note: uses `JSON.parse`).
*/
export function isJSON(str: string): boolean;
/**
* Check if the string is valid JWT token.
*/
export function isJWT(str: string): boolean;
/**
* Check if the string is a valid latitude-longitude coordinate in the format:
*
* `lat,long` or `lat, long`.
*/
export function isLatLong(str: string): boolean;
export interface IsLengthOptions {
/**
* @default 0
*/
min?: number | undefined;
/**
* @default undefined
*/
max?: number | undefined;
}
/**
* Check if the string's length falls in a range.
*
* Note: this export function takes into account surrogate pairs.
*
* @param [options] - Options
*/
export function isLength(str: string, options?: IsLengthOptions): boolean;
/**
* Check if the string matches the format of a country's license plate.
*/
export function isLicensePlate(
str: string,
locale:
| "cs-CZ"
| "de-DE"
| "de-LI"
| "en-IN"
| "es-AR"
| "hu-HU"
| "pt-BR"
| "pt-PT"
| "sq-AL"
| "sv-SE"
| "any",
): boolean;
/**
* Check if the string passes the [Luhn algorithm check](https://en.m.wikipedia.org/wiki/Luhn_algorithm).
*/
export function isLuhnNumber(str: string): boolean;
/**
* Check if the string is a locale.
*/
export function isLocale(str: string): boolean;
/**
* Check if the string is lowercase.
*/
export function isLowercase(str: string): boolean;
export interface IsMACAddressOptions {
/**
* If `no_colons` is `true`, the validator will allow MAC addresses without the colons.
* Also, it allows the use of hyphens or spaces.
*
* e.g. `01 02 03 04 05 ab` or `01-02-03-04-05-ab`.
*
* @default false
* @deprecated use no_separators instead
*/
no_colons?: boolean | undefined;
/**
* If `no_separators` is `true`, the validator will allow MAC addresses without the colons.
* Also, it allows the use of hyphens or spaces.
*
* e.g. `01 02 03 04 05 ab` or `01-02-03-04-05-ab`.
*
* @default false
*/
no_separators?: boolean | undefined;
/**
* Setting `eui` allows for validation against EUI-48 or EUI-64 instead of both.
*/
eui?: "48" | "64" | undefined;
}
/**
* Check if the string is a MAC address.
*
* @param [options] - Options
*/
export function isMACAddress(str: string, options?: IsMACAddressOptions): boolean;
/**
* Check if the string is a [magnet uri format](https://en.wikipedia.org/wiki/Magnet_URI_scheme).
*/
export function isMagnetURI(str: string): boolean;
/**
* Check if the string is a MD5 hash.
*/
export function isMD5(str: string): boolean;
/**
* Check if the string matches to a valid [MIME export type](https://en.wikipedia.org/wiki/Media_export type) format.
*/
export function isMimeType(str: string): boolean;
export type MobilePhoneLocale = PhoneLocale | PhoneLocaleAlias;
export type PhoneLocale =
| "am-AM"
| "ar-AE"
| "ar-BH"
| "ar-DZ"
| "ar-LB"
| "ar-EG"
| "ar-IQ"
| "ar-JO"
| "ar-KW"
| "ar-LY"
| "ar-MA"
| "ar-OM"
| "ar-SA"
| "ar-SY"
| "ar-TN"
| "az-AZ"
| "bs-BA"
| "be-BY"
| "bg-BG"
| "bn-BD"
| "ca-AD"
| "cs-CZ"
| "da-DK"
| "de-DE"
| "de-AT"
| "de-CH"
| "de-LU"
| "el-GR"
| "en-AU"
| "en-GB"
| "en-GG"
| "en-GH"
| "en-HK"
| "en-MO"
| "en-IE"
| "en-IN"
| "en-KE"
| "en-MT"
| "en-MU"
| "en-NG"
| "en-NZ"
| "en-PK"
| "en-PH"
| "en-RW"
| "en-SG"
| "en-SL"
| "en-TZ"
| "en-UG"
| "en-US"
| "en-ZA"
| "en-ZM"
| "en-ZW"
| "es-AR"
| "es-BO"
| "es-CO"
| "es-CL"
| "es-CR"
| "es-DO"
| "es-HN"
| "es-EC"
| "es-ES"
| "es-PE"
| "es-MX"
| "es-PA"
| "es-PY"
| "es-UY"
| "es-VE"
| "et-EE"
| "fa-IR"
| "fi-FI"
| "fj-FJ"
| "fo-FO"
| "fr-FR"
| "fr-GF"
| "fr-GP"
| "fr-MQ"
| "fr-RE"
| "he-IL"
| "hu-HU"
| "id-ID"
| "it-IT"
| "it-SM"
| "ja-JP"
| "ka-GE"
| "kk-KZ"
| "kl-GL"
| "ko-KR"
| "lt-LT"
| "lv-LV"
| "ms-MY"
| "mz-MZ"
| "nb-NO"
| "ne-NP"
| "nl-BE"
| "nl-NL"
| "nn-NO"
| "pl-PL"
| "pt-BR"
| "pt-PT"
| "pt-AO"
| "ro-RO"
| "ru-RU"
| "si-LK"
| "sl-SI"
| "sk-SK"
| "sq-AL"
| "sr-RS"
| "sv-SE"
| "th-TH"
| "tr-TR"
| "uk-UA"
| "uz-UZ"
| "vi-VN"
| "zh-CN"
| "zh-TW";
export type PhoneLocaleAlias = "en-CA" | "fr-CA" | "fr-BE" | "zh-HK" | "zh-MO" | "ga-IE" | "fr-CH" | "it-CH";
export const isMobilePhoneLocales: MobilePhoneLocale[];
export interface IsMobilePhoneOptions {
/**
* If this is set to `true`, the mobile phone number must be supplied with the country code and therefore must start with `+`.
*
* @default false
*/
strictMode?: boolean | undefined;
}
/**
* Check if the string is a mobile phone number.
*
* @param [locale] - MobilePhoneLocale(s)
* @param [options] - Options
*/
export function isMobilePhone(
str: string,
locale?: "any" | MobilePhoneLocale | MobilePhoneLocale[],
options?: IsMobilePhoneOptions,
): boolean;
/**
* Check if the string is a valid hex-encoded representation of a [MongoDB ObjectId](http://docs.mongodb.org/manual/reference/object-id/).
*/
export function isMongoId(str: string): boolean;
/**
* Check if the string contains one or more multibyte chars.
*/
export function isMultibyte(str: string): boolean;
export interface IsNumericOptions {
/**
* If `no_symbols` is true, the validator will reject numeric strings that feature a symbol (e.g. `+`, `-`, or `.`).
*
* @default false
*/
no_symbols?: boolean | undefined;
locale?: AlphaLocale | undefined;
}
/**
* Check if the string contains only numbers.
*
* @param [options] - Options
*/
export function isNumeric(str: string, options?: IsNumericOptions): boolean;
/**
* Check if the string is a valid octal number.
*/
export function isOctal(str: string): boolean;
/**
* Check if the string is a valid passport number relative to a specific country code.
*
* @param [countryCode] - Country code
*/
export function isPassportNumber(str: string, countryCode?: string): boolean;
/**
* Check if the string is a valid port number.
*/
export function isPort(str: string): boolean;
export type PostalCodeLocale =
| "AD"
| "AT"
| "AU"
| "BE"
| "BG"
| "BR"
| "CA"
| "CH"
| "CN"
| "CZ"
| "DE"
| "DK"
| "DZ"
| "EE"
| "ES"
| "FI"
| "FR"
| "GB"
| "GR"
| "HR"
| "HU"
| "ID"
| "IE"
| "IL"
| "IN"
| "IR"
| "IS"
| "IT"
| "JP"
| "KE"
| "KR"
| "LI"
| "LT"
| "LU"
| "LV"
| "MX"
| "MT"
| "NL"
| "NO"
| "NZ"
| "PL"
| "PR"
| "PT"
| "RO"
| "RU"
| "SA"
| "SE"
| "SI"
| "SK"
| "TN"
| "TW"
| "UA"
| "US"
| "ZA"
| "ZM";
export const isPostalCodeLocales: PostalCodeLocale[];
/**
* Check if the string is a postal code
*
* @param locale - PostalCodeLocale
*/
export function isPostalCode(str: string, locale: "any" | PostalCodeLocale): boolean;
/**
* Check if the string is a Semantic Versioning Specification (SemVer).
*/
export function isSemVer(str: string): boolean;
/**
* Check if string is considered a strong password. Allows options to be added
*/
export interface StrongPasswordOptions {
minLength?: number | undefined;
minLowercase?: number | undefined;
minUppercase?: number | undefined;
minNumbers?: number | undefined;
minSymbols?: number | undefined;
returnScore?: boolean | undefined;
pointsPerUnique?: number | undefined;
pointsPerRepeat?: number | undefined;
pointsForContainingLower?: number | undefined;
pointsForContainingUpper?: number | undefined;
pointsForContainingNumber?: number | undefined;
pointsForContainingSymbol?: number | undefined;
}
export function isStrongPassword(
str: string,
options?: StrongPasswordOptions & { returnScore?: false | undefined },
): boolean;
export function isStrongPassword(str: string, options: StrongPasswordOptions & { returnScore: true }): number;
/**
* Check if the string contains any surrogate pairs chars.
*/
export function isSurrogatePair(str: string): boolean;
export interface IsTimeOptions {
/**
* 'hour24' will validate hours in 24 format and 'hour12' will validate hours in 12 format.
* @default 'hour24'
*/
hourFormat?: "hour12" | "hour24";
/**
* 'default' will validate HH:MM format, 'withSeconds' will validate the HH:MM:SS format
*
* @default 'default'
*/
mode?: "default" | "withSeconds";
}
/**
* Check if the string is a valid time.
*/
export function isTime(str: string, options?: IsTimeOptions): boolean;
export const isURL: typeof _isURL.default;
export type IsURLOptions = _isURL.IsURLOptions;
export const isTaxID: typeof _isTaxID.default;
/**
* Check if the string is uppercase.
*/
export function isUppercase(str: string): boolean;
export type UUIDVersion = "1" | "2" | "3" | "4" | "5" | "all" | 1 | 2 | 3 | 4 | 5;
/**
* Check if the string is a UUID (version 1, 2, 3, 4 or 5).
*
* @param [version="all"] - UUID version
*/
export function isUUID(str: string, version?: UUIDVersion): boolean;
/**
* Check if the string contains a mixture of full and half-width chars.
*/
export function isVariableWidth(str: string): boolean;
/**
* Checks that the string is a [valid VAT number
*/
export function isVAT(str: string, countryCode: string): boolean;
/**
* Checks characters if they appear in the whitelist.
*
* @param chars - whitelist
*/
export function isWhitelisted(str: string, chars: string | string[]): boolean;
/**
* Check if string matches the pattern.
*
* @param pattern - `/foo/i`
*/
export function matches(str: string, pattern: RegExp): boolean;
/**
* Check if string matches the pattern.
*
* @param pattern - `'foo'`
* @param [modifiers] - `'i'`
*/
export function matches(str: string, pattern: string, modifiers?: string): boolean;
/**
* Check if the string is of export type slug.
*/
export function isSlug(str: string): boolean;
/******************
*** Sanitizers ***
******************/
/**
* Remove characters that appear in the blacklist.
*
* @param chars - The characters are used in a `RegExp` and so you will need to escape some chars, e.g. `blacklist(input, '\\[\\]')`.
*/
export function blacklist(input: string, chars: string): string;
/**
* Replace `<`, `>`, `&`, `'`, `"` and `/` with HTML entities.
*/
export function escape(input: string): string;
/**
* Replaces HTML encoded entities with `<`, `>`, `&`, `'`, `"` and `/`.
*/
export function unescape(input: string): string;
/**
* Trim characters from the left-side of the input.
*
* @param [chars] - characters (defaults to whitespace)
*/
export function ltrim(input: string, chars?: string): string;
export interface NormalizeEmailOptions {
/**
* Transforms the local part (before the @ symbol) of all email addresses to lowercase.
* Please note that this may violate RFC 5321, which gives providers the possibility
* to treat the local part of email addresses in a case sensitive way
* (although in practice most - yet not all - providers don't).
* The domain part of the email address is always lowercased, as it's case insensitive per RFC 1035.
*
* @default true
*/
all_lowercase?: boolean | undefined;
/**
* GMail addresses are known to be case-insensitive, so this switch allows lowercasing them even when `all_lowercase` is set to `false`.
* Please note that when `all_lowercase` is `true`, GMail addresses are lowercased regardless of the value of this setting.
*
* @default true
*/
gmail_lowercase?: boolean | undefined;
/**
* Removes dots from the local part of the email address, as GMail ignores them
* (e.g. `"john.doe"` and `"johndoe"` are considered equal).
*
* @default true
*/
gmail_remove_dots?: boolean | undefined;
/**
* Normalizes addresses by removing "sub-addresses", which is the part following a `"+"` sign
* (e.g. `"foo+bar@gmail.com"` becomes `"foo@gmail.com"`).
*
* @default true
*/
gmail_remove_subaddress?: boolean | undefined;
/**
* Converts addresses with domain `@googlemail.com` to `@gmail.com`, as they're equivalent.
*
* @default true
*/
gmail_convert_googlemaildotcom?: boolean | undefined;
/**
* Outlook.com addresses (including Windows Live and Hotmail) are known to be case-insensitive, so this switch allows lowercasing them even when `all_lowercase` is set to `false`.
* Please note that when `all_lowercase` is `true`, Outlook.com addresses are lowercased regardless of the value of this setting.
*
* @default true
*/
outlookdotcom_lowercase?: boolean | undefined;
/**
* Normalizes addresses by removing "sub-addresses", which is the part following a `"+"` sign
* (e.g. `"foo+bar@outlook.com"` becomes `"foo@outlook.com"`).
*
* @default true
*/
outlookdotcom_remove_subaddress?: boolean | undefined;
/**
* Yahoo Mail addresses are known to be case-insensitive, so this switch allows lowercasing them even when `all_lowercase` is set to `false`.
* Please note that when `all_lowercase` is `true`, Yahoo Mail addresses are lowercased regardless of the value of this setting.
*
* @default true
*/
yahoo_lowercase?: boolean | undefined;
/**
* Normalizes addresses by removing "sub-addresses", which is the part following a `"-"` sign
* (e.g. `"foo-bar@yahoo.com"` becomes `"foo@yahoo.com"`).
*
* @default true
*/
yahoo_remove_subaddress?: boolean | undefined;
/**
* iCloud addresses (including MobileMe) are known to be case-insensitive, so this switch allows lowercasing them even when `all_lowercase` is set to `false`.
* Please note that when `all_lowercase` is `true`, iCloud addresses are lowercased regardless of the value of this setting.
*
* @default true
*/
icloud_lowercase?: boolean | undefined;
/**
* Normalizes addresses by removing "sub-addresses", which is the part following a `"+"` sign
* (e.g. `"foo+bar@icloud.com"` becomes `"foo@icloud.com"`).
*
* @default true
*/
icloud_remove_subaddress?: boolean | undefined;
}
/**
* Canonicalizes an email address. (This doesn't validate that the input is an email, if you want to validate the email use `isEmail` beforehand)
*
* @param [options] - Options
*/
export function normalizeEmail(email: string, options?: NormalizeEmailOptions): string | false;
/**
* Trim characters from the right-side of the input.
*
* @param [chars] - characters (defaults to whitespace)
*/
export function rtrim(input: string, chars?: string): string;
/**
* Remove characters with a numerical value < `32` and `127`, mostly control characters.
* Unicode-safe in JavaScript.
*
* @param [keep_new_lines=false] - if `true`, newline characters are preserved (`\n` and `\r`, hex `0xA` and `0xD`).
*/
export function stripLow(input: string, keep_new_lines?: boolean): string;
/**
* Convert the input string to a boolean.
* Everything except for `'0'`, `'false'` and `''` returns `true`.
*
* @param [strict=false] - in `strict` mode, only `'1'` and `'true'` return `true`.
*/
export function toBoolean(input: string, strict?: boolean): boolean;
/**
* Convert the input string to a `Date`, or `null` if the input is not a date.
*/
export function toDate(input: string): Date | null;
/**
* Convert the input string to a float, or `NaN` if the input is not a float.
*/
export function toFloat(input: string): number;
/**
* Convert the input string to an integer, or `NaN` if the input is not an integer.
*
* @param [radix=10] - radix or base (defaults to 10)
*/
export function toInt(input: string, radix?: number): number;
/**
* Trim characters from both sides of the input.
*
* @param [chars] - characters (defaults to whitespace)
*/
export function trim(input: string, chars?: string): string;
/**
* Remove characters that do not appear in the whitelist.
*
* @param chars - The characters are used in a `RegExp` and so you will need to escape some chars, e.g. `whitelist(input, '\\[\\]')`.
*/
export function whitelist(input: string, chars: string): string;
/**
* Converts to string.
*/
export function toString(input: any): string;
export const _default: typeof validator;
export { _default as default };
}
// eslint-disable-next-line @definitelytyped/export-just-namespace
export = validator;
export as namespace validator;