summaryrefslogtreecommitdiff
path: root/includes/external/addressbook/node_modules/validator
diff options
context:
space:
mode:
authorRaindropsSys <contact@minteck.org>2023-04-06 22:18:28 +0200
committerRaindropsSys <contact@minteck.org>2023-04-06 22:18:28 +0200
commit83354b2b88218090988dd6e526b0a2505b57e0f1 (patch)
treee3c73c38a122a78bb7e66fbb99056407edd9d4b9 /includes/external/addressbook/node_modules/validator
parent47b8f2299a483024c4a6a8876af825a010954caa (diff)
downloadpluralconnect-83354b2b88218090988dd6e526b0a2505b57e0f1.tar.gz
pluralconnect-83354b2b88218090988dd6e526b0a2505b57e0f1.tar.bz2
pluralconnect-83354b2b88218090988dd6e526b0a2505b57e0f1.zip
Updated 5 files and added 1110 files (automated)
Diffstat (limited to 'includes/external/addressbook/node_modules/validator')
-rw-r--r--includes/external/addressbook/node_modules/validator/LICENSE20
-rw-r--r--includes/external/addressbook/node_modules/validator/README.md305
-rw-r--r--includes/external/addressbook/node_modules/validator/es/index.js204
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/alpha.js140
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/blacklist.js5
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/contains.js17
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/equals.js5
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/escape.js5
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isAfter.js9
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isAlpha.js26
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isAlphanumeric.js26
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isAscii.js10
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isBIC.js16
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isBase32.js23
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isBase58.js12
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isBase64.js23
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isBefore.js9
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isBoolean.js16
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isBtcAddress.js7
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isByteLength.js22
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isCreditCard.js38
-rwxr-xr-xincludes/external/addressbook/node_modules/validator/es/lib/isCurrency.js77
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isDataURI.js39
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isDate.js86
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isDecimal.js26
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isDivisibleBy.js6
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isEAN.js72
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isEmail.js186
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isEmpty.js10
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isEthereumAddress.js6
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isFQDN.js75
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isFloat.js16
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isFullWidth.js6
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isHSL.js14
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isHalfWidth.js6
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isHash.js21
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isHexColor.js6
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isHexadecimal.js6
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isIBAN.js138
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isIMEI.js47
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isIP.js55
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isIPRange.js47
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isISBN.js55
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isISIN.js60
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isISO31661Alpha2.js8
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isISO31661Alpha3.js7
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isISO4217.js8
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isISO6391.js6
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isISO8601.js47
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isISRC.js7
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isISSN.js23
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isIdentityCard.js395
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isIn.js28
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isInt.js16
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isJSON.js26
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isJWT.js17
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isLatLong.js22
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isLength.js24
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isLicensePlate.js56
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isLocale.js11
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isLowercase.js5
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isLuhnNumber.js30
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isLuhnValid.js30
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isMACAddress.js44
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isMD5.js6
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isMagnetURI.js11
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isMimeType.js39
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isMobilePhone.js209
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isMongoId.js6
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isMultibyte.js10
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isNumeric.js12
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isOctal.js6
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isPassportNumber.js144
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isPort.js7
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isPostalCode.js98
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isRFC3339.js20
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isRgbColor.js15
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isSemVer.js14
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isSlug.js6
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isStrongPassword.js101
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isSurrogatePair.js6
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isTaxID.js1543
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isTime.js20
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isURL.js197
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isUUID.js14
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isUppercase.js5
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isVAT.js247
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isVariableWidth.js7
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/isWhitelisted.js12
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/ltrim.js7
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/matches.js10
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/normalizeEmail.js138
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/rtrim.js19
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/stripLow.js7
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/toBoolean.js10
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/toDate.js6
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/toFloat.js5
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/toInt.js5
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/trim.js5
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/unescape.js7
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/util/algorithms.js88
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/util/assertString.js12
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/util/includes.js7
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/util/merge.js12
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/util/multilineRegex.js12
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/util/toString.js15
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/util/typeOf.js10
-rw-r--r--includes/external/addressbook/node_modules/validator/es/lib/whitelist.js5
-rw-r--r--includes/external/addressbook/node_modules/validator/index.js318
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/alpha.js155
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/blacklist.js18
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/contains.js33
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/equals.js18
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/escape.js18
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isAfter.js22
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isAlpha.js40
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isAlphanumeric.js40
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isAscii.js22
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isBIC.js31
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isBase32.js38
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isBase58.js26
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isBase64.js38
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isBefore.js23
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isBoolean.js30
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isBtcAddress.js21
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isByteLength.js34
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isCreditCard.js52
-rwxr-xr-xincludes/external/addressbook/node_modules/validator/lib/isCurrency.js91
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isDataURI.js53
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isDate.js99
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isDecimal.js42
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isDivisibleBy.js20
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isEAN.js85
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isEmail.js203
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isEmpty.js25
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isEthereumAddress.js20
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isFQDN.js90
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isFloat.js29
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isFullWidth.js19
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isHSL.js28
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isHalfWidth.js19
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isHash.js35
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isHexColor.js20
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isHexadecimal.js20
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isIBAN.js150
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isIMEI.js61
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isIP.js68
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isIPRange.js62
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isISBN.js69
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isISIN.js73
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isISO31661Alpha2.js22
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isISO31661Alpha3.js21
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isISO4217.js22
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isISO6391.js20
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isISO8601.js59
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isISRC.js21
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isISSN.js37
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isIdentityCard.js410
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isIn.js42
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isInt.js30
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isJSON.js41
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isJWT.js31
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isLatLong.js37
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isLength.js36
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isLicensePlate.js70
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isLocale.js25
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isLowercase.js18
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isLuhnNumber.js43
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isLuhnValid.js43
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isMACAddress.js58
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isMD5.js20
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isMagnetURI.js25
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isMimeType.js51
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isMobilePhone.js222
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isMongoId.js20
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isMultibyte.js22
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isNumeric.js27
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isOctal.js20
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isPassportNumber.js156
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isPort.js20
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isPostalCode.js111
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isRFC3339.js33
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isRgbColor.js29
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isSemVer.js28
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isSlug.js20
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isStrongPassword.js115
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isSurrogatePair.js20
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isTaxID.js1563
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isTime.js34
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isURL.js212
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isUUID.js28
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isUppercase.js18
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isVAT.js266
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isVariableWidth.js22
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/isWhitelisted.js25
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/ltrim.js20
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/matches.js23
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/normalizeEmail.js151
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/rtrim.js32
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/stripLow.js21
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/toBoolean.js23
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/toDate.js19
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/toFloat.js18
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/toInt.js18
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/trim.js19
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/unescape.js20
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/util/algorithms.js101
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/util/assertString.js22
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/util/includes.js17
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/util/merge.js22
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/util/multilineRegex.js22
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/util/toString.js25
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/util/typeOf.js20
-rw-r--r--includes/external/addressbook/node_modules/validator/lib/whitelist.js18
-rw-r--r--includes/external/addressbook/node_modules/validator/package.json75
-rw-r--r--includes/external/addressbook/node_modules/validator/validator.js5561
-rw-r--r--includes/external/addressbook/node_modules/validator/validator.min.js23
217 files changed, 18764 insertions, 0 deletions
diff --git a/includes/external/addressbook/node_modules/validator/LICENSE b/includes/external/addressbook/node_modules/validator/LICENSE
new file mode 100644
index 0000000..4e49a38
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/LICENSE
@@ -0,0 +1,20 @@
+Copyright (c) 2018 Chris O'Hara <cohara87@gmail.com>
+
+Permission is hereby granted, free of charge, to any person obtaining
+a copy of this software and associated documentation files (the
+"Software"), to deal in the Software without restriction, including
+without limitation the rights to use, copy, modify, merge, publish,
+distribute, sublicense, and/or sell copies of the Software, and to
+permit persons to whom the Software is furnished to do so, subject to
+the following conditions:
+
+The above copyright notice and this permission notice shall be
+included in all copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
+LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
+OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
+WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
diff --git a/includes/external/addressbook/node_modules/validator/README.md b/includes/external/addressbook/node_modules/validator/README.md
new file mode 100644
index 0000000..e4d1d7f
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/README.md
@@ -0,0 +1,305 @@
+# validator.js
+[![NPM version][npm-image]][npm-url]
+[![CI][ci-image]][ci-url]
+[![Coverage][codecov-image]][codecov-url]
+[![Downloads][downloads-image]][npm-url]
+[![Backers on Open Collective](https://opencollective.com/validatorjs/backers/badge.svg)](#backers)
+[![Sponsors on Open Collective](https://opencollective.com/validatorjs/sponsors/badge.svg)](#sponsors)
+[![Gitter][gitter-image]][gitter-url]
+[![Disclose a vulnerability][huntr-image]][huntr-url]
+
+A library of string validators and sanitizers.
+
+## Strings only
+
+**This library validates and sanitizes strings only.**
+
+If you're not sure if your input is a string, coerce it using `input + ''`.
+Passing anything other than a string will result in an error.
+
+## Installation and Usage
+
+### Server-side usage
+
+Install the library with `npm install validator`
+
+#### No ES6
+
+```javascript
+var validator = require('validator');
+
+validator.isEmail('foo@bar.com'); //=> true
+```
+
+#### ES6
+
+```javascript
+import validator from 'validator';
+```
+
+Or, import only a subset of the library:
+
+```javascript
+import isEmail from 'validator/lib/isEmail';
+```
+
+#### Tree-shakeable ES imports
+
+```javascript
+import isEmail from 'validator/es/lib/isEmail';
+```
+
+### Client-side usage
+
+The library can be loaded either as a standalone script, or through an [AMD][amd]-compatible loader
+
+```html
+<script type="text/javascript" src="validator.min.js"></script>
+<script type="text/javascript">
+ validator.isEmail('foo@bar.com'); //=> true
+</script>
+```
+
+The library can also be installed through [bower][bower]
+
+```bash
+$ bower install validator-js
+```
+
+CDN
+
+```html
+<script src="https://unpkg.com/validator@latest/validator.min.js"></script>
+```
+
+## Contributors
+
+[Become a backer](https://opencollective.com/validatorjs#backer)
+
+[Become a sponsor](https://opencollective.com/validatorjs#sponsor)
+
+Thank you to the people who have already contributed:
+
+<a href="https://github.com/validatorjs/validator.js/graphs/contributors"><img src="https://opencollective.com/validatorjs/contributors.svg?width=890" /></a>
+
+## Validators
+
+Here is a list of the validators currently available.
+
+Validator | Description
+--------------------------------------- | --------------------------------------
+**contains(str, seed [, options])** | check if the string contains the seed.<br/><br/>`options` is an object that defaults to `{ ignoreCase: false, minOccurrences: 1 }`.<br />Options: <br/> `ignoreCase`: Ignore case when doing comparison, default false.<br/>`minOccurences`: Minimum number of occurrences for the seed in the string. Defaults to 1.
+**equals(str, comparison)** | check if the string matches the comparison.
+**isAfter(str [, options])** | check if the string is a date that is after the specified date.<br/><br/>`options` is an object that defaults to `{ comparisonDate: Date().toString() }`.<br/>**Options:**<br/>`comparisonDate`: Date to compare to. Defaults to `Date().toString()` (now).
+**isAlpha(str [, locale, options])** | check if the string contains only letters (a-zA-Z).<br/><br/>`locale` is one of `['ar', 'ar-AE', 'ar-BH', 'ar-DZ', 'ar-EG', 'ar-IQ', 'ar-JO', 'ar-KW', 'ar-LB', 'ar-LY', 'ar-MA', 'ar-QA', 'ar-QM', 'ar-SA', 'ar-SD', 'ar-SY', 'ar-TN', 'ar-YE', 'bg-BG', 'bn', 'cs-CZ', 'da-DK', 'de-DE', 'el-GR', 'en-AU', 'en-GB', 'en-HK', 'en-IN', 'en-NZ', 'en-US', 'en-ZA', 'en-ZM', 'es-ES', 'fa-IR', 'fi-FI', 'fr-CA', 'fr-FR', 'he', 'hi-IN', 'hu-HU', 'it-IT', 'ko-KR', 'ja-JP', 'ku-IQ', 'nb-NO', 'nl-NL', 'nn-NO', 'pl-PL', 'pt-BR', 'pt-PT', 'ru-RU', 'si-LK', 'sl-SI', 'sk-SK', 'sr-RS', 'sr-RS@latin', 'sv-SE', 'th-TH', 'tr-TR', 'uk-UA']` and defaults to `en-US`. Locale list is `validator.isAlphaLocales`. `options` is an optional object that can be supplied with the following key(s): `ignore` which can either be a String or RegExp of characters to be ignored e.g. " -" will ignore spaces and -'s.
+**isAlphanumeric(str [, locale, options])** | check if the string contains only letters and numbers (a-zA-Z0-9).<br/><br/>`locale` is one of `['ar', 'ar-AE', 'ar-BH', 'ar-DZ', 'ar-EG', 'ar-IQ', 'ar-JO', 'ar-KW', 'ar-LB', 'ar-LY', 'ar-MA', 'ar-QA', 'ar-QM', 'ar-SA', 'ar-SD', 'ar-SY', 'ar-TN', 'ar-YE', 'bn', 'bg-BG', 'cs-CZ', 'da-DK', 'de-DE', 'el-GR', 'en-AU', 'en-GB', 'en-HK', 'en-IN', 'en-NZ', 'en-US', 'en-ZA', 'en-ZM', 'es-ES', 'fa-IR', 'fi-FI', 'fr-CA', 'fr-FR', 'he', 'hi-IN', 'hu-HU', 'it-IT', 'ko-KR', 'ja-JP','ku-IQ', 'nb-NO', 'nl-NL', 'nn-NO', 'pl-PL', 'pt-BR', 'pt-PT', 'ru-RU', 'si-LK', 'sl-SI', 'sk-SK', 'sr-RS', 'sr-RS@latin', 'sv-SE', 'th-TH', 'tr-TR', 'uk-UA']`) and defaults to `en-US`. Locale list is `validator.isAlphanumericLocales`. `options` is an optional object that can be supplied with the following key(s): `ignore` which can either be a String or RegExp of characters to be ignored e.g. " -" will ignore spaces and -'s.
+**isAscii(str)** | check if the string contains ASCII chars only.
+**isBase32(str [, options])** | check if the string is base32 encoded. `options` is optional and defaults to `{ crockford: false }`.<br/> When `crockford` is true it tests the given base32 encoded string using [Crockford's base32 alternative][Crockford Base32].
+**isBase58(str)** | check if the string is base58 encoded.
+**isBase64(str [, options])** | check if the string is base64 encoded. `options` is optional and defaults to `{ urlSafe: false }`<br/> when `urlSafe` is true it tests the given base64 encoded string is [url safe][Base64 URL Safe].
+**isBefore(str [, date])** | check if the string is a date that is before the specified date.
+**isBIC(str)** | check if the string is a BIC (Bank Identification Code) or SWIFT code.
+**isBoolean(str [, options])** | check if the string is a boolean.<br/>`options` is an object which defaults to `{ loose: false }`. If `loose` is is set to false, the validator will strictly match ['true', 'false', '0', '1']. If `loose` is set to true, the validator will also match 'yes', 'no', and will match a valid boolean string of any case. (e.g.: ['true', 'True', 'TRUE']).
+**isBtcAddress(str)** | check if the string is a valid BTC address.
+**isByteLength(str [, options])** | check if the string's length (in UTF-8 bytes) falls in a range.<br/><br/>`options` is an object which defaults to `{ min: 0, max: undefined }`.
+**isCreditCard(str [, options])** | check if the string is a credit card number.<br/><br/> `options` is an optional object that can be supplied with the following key(s): `provider` is an optional key whose value should be a string, and defines the company issuing the credit card. Valid values include `['amex', 'dinersclub', 'discover', 'jcb', 'mastercard', 'unionpay', 'visa']` or blank will check for any provider.
+**isCurrency(str [, options])** | check if the string is a valid currency amount.<br/><br/>`options` is an object which defaults to `{ symbol: '$', require_symbol: false, allow_space_after_symbol: false, symbol_after_digits: false, allow_negatives: true, parens_for_negatives: false, negative_sign_before_digits: false, negative_sign_after_digits: false, allow_negative_sign_placeholder: false, thousands_separator: ',', decimal_separator: '.', allow_decimal: true, require_decimal: false, digits_after_decimal: [2], allow_space_after_digits: false }`.<br/>**Note:** 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].
+**isDataURI(str)** | check if the string is a [data uri format][Data URI Format].
+**isDate(str [, options])** | check if the string is a valid date. e.g. [`2002-07-15`, new Date()].<br/><br/> `options` is an object which can contain the keys `format`, `strictMode` and/or `delimiters`.<br/><br/>`format` is a string and defaults to `YYYY/MM/DD`.<br/><br/>`strictMode` is a boolean and defaults to `false`. If `strictMode` is set to true, the validator will reject strings different from `format`.<br/><br/> `delimiters` is an array of allowed date delimiters and defaults to `['/', '-']`.
+**isDecimal(str [, options])** | check if the string represents a decimal number, such as 0.1, .3, 1.1, 1.00003, 4.0, etc.<br/><br/>`options` is an object which defaults to `{force_decimal: false, decimal_digits: '1,', locale: 'en-US'}`.<br/><br/>`locale` determines the decimal separator and is one of `['ar', 'ar-AE', 'ar-BH', 'ar-DZ', 'ar-EG', 'ar-IQ', 'ar-JO', 'ar-KW', 'ar-LB', 'ar-LY', 'ar-MA', 'ar-QA', 'ar-QM', 'ar-SA', 'ar-SD', 'ar-SY', 'ar-TN', 'ar-YE', 'bg-BG', 'cs-CZ', 'da-DK', 'de-DE', 'el-GR', 'en-AU', 'en-GB', 'en-HK', 'en-IN', 'en-NZ', 'en-US', 'en-ZA', 'en-ZM', 'es-ES', 'fa', 'fa-AF', 'fa-IR', 'fr-FR', 'fr-CA', 'hu-HU', 'id-ID', 'it-IT', 'ku-IQ', 'nb-NO', 'nl-NL', 'nn-NO', 'pl-PL', 'pl-Pl', 'pt-BR', 'pt-PT', 'ru-RU', 'sl-SI', 'sr-RS', 'sr-RS@latin', 'sv-SE', 'tr-TR', 'uk-UA', 'vi-VN']`.<br/>**Note:** `decimal_digits` is given as a range like '1,3', a specific value like '3' or min like '1,'.
+**isDivisibleBy(str, number)** | check if the string is a number that is divisible by another.
+**isEAN(str)** | check if the string is an [EAN (European Article Number)][European Article Number].
+**isEmail(str [, options])** | check if the string is an email.<br/><br/>`options` is an object which defaults to `{ allow_display_name: false, require_display_name: false, allow_utf8_local_part: true, require_tld: true, allow_ip_domain: false, domain_specific_validation: false, blacklisted_chars: '', host_blacklist: [] }`. If `allow_display_name` is set to true, the validator will also match `Display Name <email-address>`. If `require_display_name` is set to true, the validator will reject strings without the format `Display Name <email-address>`. If `allow_utf8_local_part` is set to false, the validator will not allow any non-English UTF8 character in email address' local part. If `require_tld` is set to false, email addresses without a TLD in their domain will also be matched. If `ignore_max_length` is set to true, the validator will not check for the standard max length of an email. If `allow_ip_domain` is set to true, the validator will allow IP addresses in the host part. If `domain_specific_validation` is true, some additional validation will be enabled, e.g. disallowing certain syntactically valid email addresses that are rejected by Gmail. If `blacklisted_chars` receives a string, then the validator will reject emails that include any of the characters in the string, in the name part. If `host_blacklist` is set to an array of strings and the part of the email after the `@` symbol matches one of the strings defined in it, the validation fails. If `host_whitelist` is set to an array of strings and the part of the email after the `@` symbol matches none of the strings defined in it, the validation fails.
+**isEmpty(str [, options])** | check if the string has a length of zero.<br/><br/>`options` is an object which defaults to `{ ignore_whitespace: false }`.
+**isEthereumAddress(str)** | check if the string is an [Ethereum][Ethereum] address. Does not validate address checksums.
+**isFloat(str [, options])** | check if the string is a float.<br/><br/>`options` is an object which can contain the keys `min`, `max`, `gt`, and/or `lt` to validate the float is within boundaries (e.g. `{ min: 7.22, max: 9.55 }`) it also has `locale` as an option.<br/><br/>`min` and `max` are equivalent to 'greater or equal' and 'less or equal', respectively while `gt` and `lt` are their strict counterparts.<br/><br/>`locale` determines the decimal separator and is one of `['ar', 'ar-AE', 'ar-BH', 'ar-DZ', 'ar-EG', 'ar-IQ', 'ar-JO', 'ar-KW', 'ar-LB', 'ar-LY', 'ar-MA', 'ar-QA', 'ar-QM', 'ar-SA', 'ar-SD', 'ar-SY', 'ar-TN', 'ar-YE', 'bg-BG', 'cs-CZ', 'da-DK', 'de-DE', 'en-AU', 'en-GB', 'en-HK', 'en-IN', 'en-NZ', 'en-US', 'en-ZA', 'en-ZM', 'es-ES', 'fr-CA', 'fr-FR', 'hu-HU', 'it-IT', 'nb-NO', 'nl-NL', 'nn-NO', 'pl-PL', 'pt-BR', 'pt-PT', 'ru-RU', 'sl-SI', 'sr-RS', 'sr-RS@latin', 'sv-SE', 'tr-TR', 'uk-UA']`. Locale list is `validator.isFloatLocales`.
+**isFQDN(str [, options])** | check if the string is a fully qualified domain name (e.g. domain.com).<br/><br/>`options` is an object which defaults to `{ require_tld: true, allow_underscores: false, allow_trailing_dot: false, allow_numeric_tld: false, allow_wildcard: false, ignore_max_length: false }`. If `allow_wildcard` is set to true, the validator will allow domain starting with `*.` (e.g. `*.example.com` or `*.shop.example.com`).
+**isFullWidth(str)** | check if the string contains any full-width chars.
+**isHalfWidth(str)** | check if the string contains any half-width chars.
+**isHash(str, algorithm)** | check if the string is a hash of type algorithm.<br/><br/>Algorithm is one of `['crc32', 'crc32b', 'md4', 'md5', 'ripemd128', 'ripemd160', 'sha1', 'sha256', 'sha384', 'sha512', 'tiger128', 'tiger160', 'tiger192']`.
+**isHexadecimal(str)** | check if the string is a hexadecimal number.
+**isHexColor(str)** | check if the string is a hexadecimal color.
+**isHSL(str)** | check if the string is an HSL (hue, saturation, lightness, optional alpha) color based on [CSS Colors Level 4 specification][CSS Colors Level 4 Specification].<br/><br/>Comma-separated format supported. Space-separated format supported with the exception of a few edge cases (ex: `hsl(200grad+.1%62%/1)`).
+**isIBAN(str)** | check if the string is an IBAN (International Bank Account Number).
+**isIdentityCard(str [, locale])** | check if the string is a valid identity card code.<br/><br/>`locale` is one of `['LK', 'PL', 'ES', 'FI', 'IN', 'IT', 'IR', 'MZ', 'NO', 'TH', 'zh-TW', 'he-IL', 'ar-LY', 'ar-TN', 'zh-CN', 'zh-HK']` OR `'any'`. If 'any' is used, function will check if any of the locales match.<br/><br/>Defaults to 'any'.
+**isIMEI(str [, options]))** | check if the string is a valid [IMEI number][IMEI]. IMEI should be of format `###############` or `##-######-######-#`.<br/><br/>`options` is an object which can contain the keys `allow_hyphens`. Defaults to first format. If `allow_hyphens` is set to true, the validator will validate the second format.
+**isIn(str, values)** | check if the string is in an array of allowed values.
+**isInt(str [, options])** | check if the string is an integer.<br/><br/>`options` is an object which can contain the keys `min` and/or `max` to check the integer is within boundaries (e.g. `{ min: 10, max: 99 }`). `options` can also contain the key `allow_leading_zeroes`, which when set to false will disallow integer values with leading zeroes (e.g. `{ allow_leading_zeroes: false }`). Finally, `options` can contain the keys `gt` and/or `lt` which will enforce integers being greater than or less than, respectively, the value provided (e.g. `{gt: 1, lt: 4}` for a number between 1 and 4).
+**isIP(str [, version])** | check if the string is an IP (version 4 or 6).
+**isIPRange(str [, version])** | check if the string is an IP Range (version 4 or 6).
+**isISBN(str [, options])** | check if the string is an [ISBN][ISBN].<br/><br/>`options` is an object that has no default.<br/>**Options:**<br/>`version`: ISBN version to compare to. Accepted values are '10' and '13'. If none provided, both will be tested.
+**isISIN(str)** | check if the string is an [ISIN][ISIN] (stock/security identifier).
+**isISO6391(str)** | check if the string is a valid [ISO 639-1][ISO 639-1] language code.
+**isISO8601(str [, options])** | check if the string is a valid [ISO 8601][ISO 8601] date. <br/>`options` is an object which defaults to `{ strict: false, strictSeparator: false }`. If `strict` is true, date strings with invalid dates like `2009-02-29` will be invalid. If `strictSeparator` is true, date strings with date and time separated by anything other than a T will be invalid.
+**isISO31661Alpha2(str)** | check if the string is a valid [ISO 3166-1 alpha-2][ISO 3166-1 alpha-2] officially assigned country code.
+**isISO31661Alpha3(str)** | check if the string is a valid [ISO 3166-1 alpha-3][ISO 3166-1 alpha-3] officially assigned country code.
+**isISO4217(str)** | check if the string is a valid [ISO 4217][ISO 4217] officially assigned currency code.
+**isISRC(str)** | check if the string is an [ISRC][ISRC].
+**isISSN(str [, options])** | check if the string is an [ISSN][ISSN].<br/><br/>`options` is an object which defaults to `{ case_sensitive: false, require_hyphen: false }`. If `case_sensitive` is true, ISSNs with a lowercase `'x'` as the check digit are rejected.
+**isJSON(str [, options])** | check if the string is valid JSON (note: uses JSON.parse).<br/><br/>`options` is an object which defaults to `{ allow_primitives: false }`. If `allow_primitives` is true, the primitives 'true', 'false' and 'null' are accepted as valid JSON values.
+**isJWT(str)** | check if the string is valid JWT token.
+**isLatLong(str [, options])** | check if the string is a valid latitude-longitude coordinate in the format `lat,long` or `lat, long`.<br/><br/>`options` is an object that defaults to `{ checkDMS: false }`. Pass `checkDMS` as `true` to validate DMS(degrees, minutes, and seconds) latitude-longitude format.
+**isLength(str [, options])** | check if the string's length falls in a range.<br/><br/>`options` is an object which defaults to `{ min: 0, max: undefined }`. Note: this function takes into account surrogate pairs.
+**isLicensePlate(str, locale)** | check if the string matches the format of a country's license plate.<br/><br/>`locale` is one of `['cs-CZ', 'de-DE', 'de-LI', 'en-IN', 'es-AR', 'hu-HU', 'pt-BR', 'pt-PT', 'sq-AL', 'sv-SE']` or `'any'`.
+**isLocale(str)** | check if the string is a locale.
+**isLowercase(str)** | check if the string is lowercase.
+**isLuhnNumber(str)** | check if the string passes the [Luhn algorithm check](https://en.wikipedia.org/wiki/Luhn_algorithm).
+**isMACAddress(str [, options])** | check if the string is a MAC address.<br/><br/>`options` is an object which defaults to `{ no_separators: false }`. If `no_separators` is true, the validator will allow MAC addresses without separators. Also, it allows the use of hyphens, spaces or dots e.g. '01 02 03 04 05 ab', '01-02-03-04-05-ab' or '0102.0304.05ab'. The options also allow a `eui` property to specify if it needs to be validated against EUI-48 or EUI-64. The accepted values of `eui` are: 48, 64.
+**isMagnetURI(str)** | check if the string is a [Magnet URI format][Magnet URI Format].
+**isMD5(str)** | check if the string is a MD5 hash.<br/><br/>Please note that you can also use the `isHash(str, 'md5')` function. Keep in mind that MD5 has some collision weaknesses compared to other algorithms (e.g., SHA).
+**isMimeType(str)** | check if the string matches to a valid [MIME type][MIME Type] format.
+**isMobilePhone(str [, locale [, options]])** | check if the string is a mobile phone number,<br/><br/>`locale` is either an array of locales (e.g. `['sk-SK', 'sr-RS']`) OR one of `['am-Am', 'ar-AE', 'ar-BH', 'ar-DZ', 'ar-EG', 'ar-EH', 'ar-IQ', 'ar-JO', 'ar-KW', 'ar-PS', 'ar-SA', 'ar-SY', 'ar-TN', 'ar-YE', 'az-AZ', 'az-LB', 'az-LY', 'be-BY', 'bg-BG', 'bn-BD', 'bs-BA', 'ca-AD', 'cs-CZ', 'da-DK', 'de-AT', 'de-CH', 'de-DE', 'de-LU', 'dv-MV', 'dz-BT', 'el-CY', 'el-GR', 'en-AG', 'en-AI', 'en-AU', 'en-BM', 'en-BS', 'en-BW', 'en-CA', 'en-GB', 'en-GG', 'en-GH', 'en-GY', 'en-HK', 'en-IE', 'en-IN', 'en-JM', 'en-KE', 'en-KI', 'en-KN', 'en-LS', 'en-MO', 'en-MT', 'en-MU', 'en-NG', 'en-NZ', 'en-PG', 'en-PH', 'en-PK', 'en-RW', 'en-SG', 'en-SL', 'en-SS', 'en-TZ', 'en-UG', 'en-US', 'en-ZA', 'en-ZM', 'en-ZW', 'es-AR', 'es-BO', 'es-CL', 'es-CO', 'es-CR', 'es-CU', 'es-DO', 'es-EC', 'es-ES', 'es-HN', 'es-MX', 'es-NI', 'es-PA', 'es-PE', 'es-PY', 'es-SV', 'es-UY', 'es-VE', 'et-EE', 'fa-AF', 'fa-IR', 'fi-FI', 'fj-FJ', 'fo-FO', 'fr-BE', 'fr-BF', 'fr-BJ', 'fr-CD', 'fr-FR', 'fr-GF', 'fr-GP', 'fr-MQ', 'fr-PF', 'fr-RE', 'ga-IE', 'he-IL', 'hu-HU', 'id-ID', 'ir-IR', 'it-IT', 'it-SM', 'ja-JP', 'ka-GE', 'kk-KZ', 'kl-GL', 'ko-KR', 'ky-KG', 'lt-LT', 'mg-MG', 'mn-MN', 'ms-MY', 'my-MM', 'mz-MZ', 'nb-NO', 'ne-NP', 'nl-AW', 'nl-BE', 'nl-NL', 'nn-NO', 'pl-PL', 'pt-AO', 'pt-BR', 'pt-PT', 'ro-Md', 'ro-RO', 'ru-RU', 'si-LK', 'sk-SK', 'sl-SI', 'sq-AL', 'sr-RS', 'sv-SE', 'tg-TJ', 'th-TH', 'tk-TM', 'tr-TR', 'uk-UA', 'uz-UZ', 'vi-VN', 'zh-CN', 'zh-HK', 'zh-MO', 'zh-TW']` OR defaults to `'any'`. If 'any' or a falsey value is used, function will check if any of the locales match).<br/><br/>`options` is an optional object that can be supplied with the following keys: `strictMode`, if this is set to `true`, the mobile phone number must be supplied with the country code and therefore must start with `+`. Locale list is `validator.isMobilePhoneLocales`.
+**isMongoId(str)** | check if the string is a valid hex-encoded representation of a [MongoDB ObjectId][mongoid].
+**isMultibyte(str)** | check if the string contains one or more multibyte chars.
+**isNumeric(str [, options])** | check if the string contains only numbers.<br/><br/>`options` is an object which defaults to `{ no_symbols: false }` it also has `locale` as an option. If `no_symbols` is true, the validator will reject numeric strings that feature a symbol (e.g. `+`, `-`, or `.`).<br/><br/>`locale` determines the decimal separator and is one of `['ar', 'ar-AE', 'ar-BH', 'ar-DZ', 'ar-EG', 'ar-IQ', 'ar-JO', 'ar-KW', 'ar-LB', 'ar-LY', 'ar-MA', 'ar-QA', 'ar-QM', 'ar-SA', 'ar-SD', 'ar-SY', 'ar-TN', 'ar-YE', 'bg-BG', 'cs-CZ', 'da-DK', 'de-DE', 'en-AU', 'en-GB', 'en-HK', 'en-IN', 'en-NZ', 'en-US', 'en-ZA', 'en-ZM', 'es-ES', 'fr-FR', 'fr-CA', 'hu-HU', 'it-IT', 'nb-NO', 'nl-NL', 'nn-NO', 'pl-PL', 'pt-BR', 'pt-PT', 'ru-RU', 'sl-SI', 'sr-RS', 'sr-RS@latin', 'sv-SE', 'tr-TR', 'uk-UA']`.
+**isOctal(str)** | check if the string is a valid octal number.
+**isPassportNumber(str, countryCode)** | check if the string is a valid passport number.<br/><br/>`countryCode` is one of `['AM', 'AR', 'AT', 'AU', 'AZ', 'BE', 'BG', 'BY', 'BR', 'CA', 'CH', 'CN', 'CY', 'CZ', 'DE', 'DK', 'DZ', 'EE', 'ES', 'FI', 'FR', 'GB', 'GR', 'HR', 'HU', 'IE', 'IN', 'IR', 'ID', 'IS', 'IT', 'JM', 'JP', 'KR', 'KZ', 'LI', 'LT', 'LU', 'LV', 'LY', 'MT', 'MX', 'MY', 'MZ', 'NL', 'NZ', 'PH', 'PK', 'PL', 'PT', 'RO', 'RU', 'SE', 'SL', 'SK', 'TH', 'TR', 'UA', 'US']`.
+**isPort(str)** | check if the string is a valid port number.
+**isPostalCode(str, locale)** | check if the string is a postal code.<br/><br/>`locale` is one of `['AD', 'AT', 'AU', 'AZ', 'BA', 'BE', 'BG', 'BR', 'BY', 'CA', 'CH', 'CN', 'CZ', 'DE', 'DK', 'DO', 'DZ', 'EE', 'ES', 'FI', 'FR', 'GB', 'GR', 'HR', 'HT', 'HU', 'ID', 'IE', 'IL', 'IN', 'IR', 'IS', 'IT', 'JP', 'KE', 'KR', 'LI', 'LK', 'LT', 'LU', 'LV', 'MG', 'MT', 'MX', 'MY', 'NL', 'NO', 'NP', 'NZ', 'PL', 'PR', 'PT', 'RO', 'RU', 'SA', 'SE', 'SG', 'SI', 'SK', 'TH', 'TN', 'TW', 'UA', 'US', 'ZA', 'ZM']` OR `'any'`. If 'any' is used, function will check if any of the locales match. Locale list is `validator.isPostalCodeLocales`.
+**isRFC3339(str)** | check if the string is a valid [RFC 3339][RFC 3339] date.
+**isRgbColor(str [, includePercentValues])** | check if the string is a rgb or rgba color.<br/><br/>`includePercentValues` defaults to `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.
+**isSemVer(str)** | check if the string is a Semantic Versioning Specification (SemVer).
+**isSurrogatePair(str)** | check if the string contains any surrogate pairs chars.
+**isUppercase(str)** | check if the string is uppercase.
+**isSlug(str)** | check if the string is of type slug.
+**isStrongPassword(str [, options])** | check if the string can be considered a strong password or not. Allows for custom requirements or scoring rules. If `returnScore` is true, then the function returns an integer score for the password rather than a boolean.<br/>Default options: <br/>`{ minLength: 8, minLowercase: 1, minUppercase: 1, minNumbers: 1, minSymbols: 1, returnScore: false, pointsPerUnique: 1, pointsPerRepeat: 0.5, pointsForContainingLower: 10, pointsForContainingUpper: 10, pointsForContainingNumber: 10, pointsForContainingSymbol: 10 }`
+**isTime(str [, options])** | check if the string is a valid time e.g. [`23:01:59`, new Date().toLocaleTimeString()].<br/><br/> `options` is an object which can contain the keys `hourFormat` or `mode`.<br/><br/>`hourFormat` is a key and defaults to `'hour24'`.<br/><br/>`mode` is a key and defaults to `'default'`. <br/><br/>`hourFomat` can contain the values `'hour12'` or `'hour24'`, `'hour24'` will validate hours in 24 format and `'hour12'` will validate hours in 12 format. <br/><br/>`mode` can contain the values `'default'` or `'withSeconds'`, `'default'` will validate `HH:MM` format, `'withSeconds'` will validate the `HH:MM:SS` format.
+**isTaxID(str, locale)** | check if the string is a valid Tax Identification Number. Default locale is `en-US`.<br/><br/>More info about exact TIN support can be found in `src/lib/isTaxID.js`.<br/><br/>Supported locales: `[ 'bg-BG', 'cs-CZ', 'de-AT', 'de-DE', 'dk-DK', 'el-CY', 'el-GR', 'en-CA', 'en-GB', 'en-IE', 'en-US', 'es-ES', 'et-EE', 'fi-FI', 'fr-BE', 'fr-CA', 'fr-FR', 'fr-LU', 'hr-HR', 'hu-HU', 'it-IT', 'lb-LU', 'lt-LT', 'lv-LV', 'mt-MT', 'nl-BE', 'nl-NL', 'pl-PL', 'pt-BR', 'pt-PT', 'ro-RO', 'sk-SK', 'sl-SI', 'sv-SE' ]`.
+**isURL(str [, options])** | check if the string is a URL.<br/><br/>`options` is an object which defaults to `{ protocols: ['http','https','ftp'], require_tld: true, require_protocol: false, require_host: true, require_port: false, require_valid_protocol: true, allow_underscores: false, host_whitelist: false, host_blacklist: false, allow_trailing_dot: false, allow_protocol_relative_urls: false, allow_fragments: true, allow_query_components: true, disallow_auth: false, validate_length: true }`.<br/><br/>`require_protocol` - if set to true isURL will return false if protocol is not present in the URL.<br/>`require_valid_protocol` - isURL will check if the URL's protocol is present in the protocols option.<br/>`protocols` - valid protocols can be modified with this option.<br/>`require_host` - if set to false isURL will not check if host is present in the URL.<br/>`require_port` - if set to true isURL will check if port is present in the URL.<br/>`allow_protocol_relative_urls` - if set to true protocol relative URLs will be allowed.<br/>`allow_fragments` - if set to false isURL will return false if fragments are present.<br/>`allow_query_components` - if set to false isURL will return false if query components are present.<br/>`validate_length` - if set to false isURL will skip string length validation (2083 characters is IE max URL length).
+**isUUID(str [, version])** | check if the string is a UUID (version 1, 2, 3, 4 or 5).
+**isVariableWidth(str)** | check if the string contains a mixture of full and half-width chars.
+**isVAT(str, countryCode)** | check if the string is a [valid VAT number][VAT Number] if validation is available for the given country code matching [ISO 3166-1 alpha-2][ISO 3166-1 alpha-2]. <br/><br/>`countryCode` is one of `['AL', 'AR', 'AT', 'AU', 'BE', 'BG', 'BO', 'BR', 'BY', 'CA', 'CH', 'CL', 'CO', 'CR', 'CY', 'CZ', 'DE', 'DK', 'DO', 'EC', 'EE', 'EL', 'ES', 'FI', 'FR', 'GB', 'GT', 'HN', 'HR', 'HU', 'ID', 'IE', 'IL', 'IN', 'IS', 'IT', 'KZ', 'LT', 'LU', 'LV', 'MK', 'MT', 'MX', 'NG', 'NI', 'NL', 'NO', 'NZ', 'PA', 'PE', 'PH', 'PL', 'PT', 'PY', 'RO', 'RS', 'RU', 'SA', 'SE', 'SI', 'SK', 'SM', 'SV', 'TR', 'UA', 'UY', 'UZ', 'VE']`.
+**isWhitelisted(str, chars)** | check if the string consists only of characters that appear in the whitelist `chars`.
+**matches(str, pattern [, modifiers])** | check if the string matches the pattern.<br/><br/>Either `matches('foo', /foo/i)` or `matches('foo', 'foo', 'i')`.
+
+## Sanitizers
+
+Here is a list of the sanitizers currently available.
+
+Sanitizer | Description
+-------------------------------------- | -------------------------------
+**blacklist(input, chars)** | remove characters that appear in the blacklist. The characters are used in a RegExp and so you will need to escape some chars, e.g. `blacklist(input, '\\[\\]')`.
+**escape(input)** | replace `<`, `>`, `&`, `'`, `"` and `/` with HTML entities.
+**ltrim(input [, chars])** | trim characters from the left-side of the input.
+**normalizeEmail(email [, options])** | canonicalize an email address. (This doesn't validate that the input is an email, if you want to validate the email use isEmail beforehand).<br/><br/>`options` is an object with the following keys and default values:<br/><ul><li>*all_lowercase: true* - 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 is case insensitive per RFC 1035.</li><li>*gmail_lowercase: true* - 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.</li><li>*gmail_remove_dots: true*: Removes dots from the local part of the email address, as Gmail ignores them (e.g. "john.doe" and "johndoe" are considered equal).</li><li>*gmail_remove_subaddress: true*: Normalizes addresses by removing "sub-addresses", which is the part following a "+" sign (e.g. "foo+bar@gmail.com" becomes "foo@gmail.com").</li><li>*gmail_convert_googlemaildotcom: true*: Converts addresses with domain @googlemail.com to @gmail.com, as they're equivalent.</li><li>*outlookdotcom_lowercase: true* - 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.</li><li>*outlookdotcom_remove_subaddress: true*: Normalizes addresses by removing "sub-addresses", which is the part following a "+" sign (e.g. "foo+bar@outlook.com" becomes "foo@outlook.com").</li><li>*yahoo_lowercase: true* - 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.</li><li>*yahoo_remove_subaddress: true*: Normalizes addresses by removing "sub-addresses", which is the part following a "-" sign (e.g. "foo-bar@yahoo.com" becomes "foo@yahoo.com").</li><li>*icloud_lowercase: true* - 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.</li><li>*icloud_remove_subaddress: true*: Normalizes addresses by removing "sub-addresses", which is the part following a "+" sign (e.g. "foo+bar@icloud.com" becomes "foo@icloud.com").</li></ul>
+**rtrim(input [, chars])** | trim characters from the right-side of the input.
+**stripLow(input [, keep_new_lines])** | remove characters with a numerical value < 32 and 127, mostly control characters. If `keep_new_lines` is `true`, newline characters are preserved (`\n` and `\r`, hex `0xA` and `0xD`). Unicode-safe in JavaScript.
+**toBoolean(input [, strict])** | convert the input string to a boolean. Everything except for `'0'`, `'false'` and `''` returns `true`. In strict mode only `'1'` and `'true'` return `true`.
+**toDate(input)** | convert the input string to a date, or `null` if the input is not a date.
+**toFloat(input)** | convert the input string to a float, or `NaN` if the input is not a float.
+**toInt(input [, radix])** | convert the input string to an integer, or `NaN` if the input is not an integer.
+**trim(input [, chars])** | trim characters (whitespace by default) from both sides of the input.
+**unescape(input)** | replace HTML encoded entities with `<`, `>`, `&`, `'`, `"` and `/`.
+**whitelist(input, chars)** | remove characters that do not appear in the whitelist. The characters are used in a RegExp and so you will need to escape some chars, e.g. `whitelist(input, '\\[\\]')`.
+
+### XSS Sanitization
+
+XSS sanitization was removed from the library in [2d5d6999](https://github.com/validatorjs/validator.js/commit/2d5d6999541add350fb396ef02dc42ca3215049e).
+
+For an alternative, have a look at Yahoo's [xss-filters library](https://github.com/yahoo/xss-filters) or at [DOMPurify](https://github.com/cure53/DOMPurify).
+
+## Contributing
+
+In general, we follow the "fork-and-pull" Git workflow.
+
+1. Fork the repo on GitHub
+2. Clone the project to your own machine
+3. Work on your fork
+ 1. Make your changes and additions
+ - Most of your changes should be focused on `src/` and `test/` folders and/or `README.md`.
+ - Files such as `validator.js`, `validator.min.js` and files in `lib/` folder are autogenerated when running tests (`npm test`) and need not to be changed **manually**.
+ 2. Change or add tests if needed
+ 3. Run tests and make sure they pass
+ 4. Add changes to README.md if needed
+4. Commit changes to your own branch
+5. **Make sure** you merge the latest from "upstream" and resolve conflicts if there is any
+6. Repeat step 3(3) above
+7. Push your work back up to your fork
+8. Submit a Pull request so that we can review your changes
+
+## Tests
+
+Tests are using mocha, to run the tests use:
+
+```sh
+$ npm test
+```
+
+## Maintainers
+
+- [chriso](https://github.com/chriso) - **Chris O'Hara** (author)
+- [profnandaa](https://github.com/profnandaa) - **Anthony Nandaa**
+- [ezkemboi](https://github.com/ezkemboi) - **Ezrqn Kemboi**
+- [tux-tn](https://github.com/tux-tn) - **Sarhan Aissi**
+
+## Reading
+
+Remember, validating can be troublesome sometimes. See [A list of articles about programming assumptions commonly made that aren't true](https://github.com/jameslk/awesome-falsehoods).
+
+## License (MIT)
+
+```
+Copyright (c) 2018 Chris O'Hara <cohara87@gmail.com>
+
+Permission is hereby granted, free of charge, to any person obtaining
+a copy of this software and associated documentation files (the
+"Software"), to deal in the Software without restriction, including
+without limitation the rights to use, copy, modify, merge, publish,
+distribute, sublicense, and/or sell copies of the Software, and to
+permit persons to whom the Software is furnished to do so, subject to
+the following conditions:
+
+The above copyright notice and this permission notice shall be
+included in all copies or substantial portions of the Software.
+
+THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
+LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
+OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
+WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+```
+
+[downloads-image]: http://img.shields.io/npm/dm/validator.svg
+
+[npm-url]: https://npmjs.org/package/validator
+[npm-image]: http://img.shields.io/npm/v/validator.svg
+
+[codecov-url]: https://codecov.io/gh/validatorjs/validator.js
+[codecov-image]: https://codecov.io/gh/validatorjs/validator.js/branch/master/graph/badge.svg
+
+[ci-url]: https://github.com/validatorjs/validator.js/actions?query=workflow%3ACI
+[ci-image]: https://github.com/validatorjs/validator.js/workflows/CI/badge.svg?branch=master
+
+[gitter-url]: https://gitter.im/validatorjs/community
+[gitter-image]: https://badges.gitter.im/validatorjs/community.svg
+
+[huntr-url]: https://huntr.dev/bounties/disclose/?target=https://github.com/validatorjs/validator.js
+[huntr-image]: https://cdn.huntr.dev/huntr_security_badge_mono.svg
+
+[amd]: http://requirejs.org/docs/whyamd.html
+[bower]: http://bower.io/
+
+[Crockford Base32]: http://www.crockford.com/base32.html
+[Base64 URL Safe]: https://base64.guru/standards/base64url
+[Data URI Format]: https://developer.mozilla.org/en-US/docs/Web/HTTP/data_URIs
+[European Article Number]: https://en.wikipedia.org/wiki/International_Article_Number
+[Ethereum]: https://ethereum.org/
+[CSS Colors Level 4 Specification]: https://developer.mozilla.org/en-US/docs/Web/CSS/color_value
+[IMEI]: https://en.wikipedia.org/wiki/International_Mobile_Equipment_Identity
+[ISBN]: https://en.wikipedia.org/wiki/ISBN
+[ISIN]: https://en.wikipedia.org/wiki/International_Securities_Identification_Number
+[ISO 639-1]: https://en.wikipedia.org/wiki/List_of_ISO_639-1_codes
+[ISO 8601]: https://en.wikipedia.org/wiki/ISO_8601
+[ISO 3166-1 alpha-2]: https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2
+[ISO 3166-1 alpha-3]: https://en.wikipedia.org/wiki/ISO_3166-1_alpha-3
+[ISO 4217]: https://en.wikipedia.org/wiki/ISO_4217
+[ISRC]: https://en.wikipedia.org/wiki/International_Standard_Recording_Code
+[ISSN]: https://en.wikipedia.org/wiki/International_Standard_Serial_Number
+[Luhn Check]: https://en.wikipedia.org/wiki/Luhn_algorithm
+[Magnet URI Format]: https://en.wikipedia.org/wiki/Magnet_URI_scheme
+[MIME Type]: https://en.wikipedia.org/wiki/Media_type
+[mongoid]: http://docs.mongodb.org/manual/reference/object-id/
+[RFC 3339]: https://tools.ietf.org/html/rfc3339
+[VAT Number]: https://en.wikipedia.org/wiki/VAT_identification_number \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/index.js b/includes/external/addressbook/node_modules/validator/es/index.js
new file mode 100644
index 0000000..803ad36
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/index.js
@@ -0,0 +1,204 @@
+import toDate from './lib/toDate';
+import toFloat from './lib/toFloat';
+import toInt from './lib/toInt';
+import toBoolean from './lib/toBoolean';
+import equals from './lib/equals';
+import contains from './lib/contains';
+import matches from './lib/matches';
+import isEmail from './lib/isEmail';
+import isURL from './lib/isURL';
+import isMACAddress from './lib/isMACAddress';
+import isIP from './lib/isIP';
+import isIPRange from './lib/isIPRange';
+import isFQDN from './lib/isFQDN';
+import isDate from './lib/isDate';
+import isTime from './lib/isTime';
+import isBoolean from './lib/isBoolean';
+import isLocale from './lib/isLocale';
+import isAlpha, { locales as isAlphaLocales } from './lib/isAlpha';
+import isAlphanumeric, { locales as isAlphanumericLocales } from './lib/isAlphanumeric';
+import isNumeric from './lib/isNumeric';
+import isPassportNumber from './lib/isPassportNumber';
+import isPort from './lib/isPort';
+import isLowercase from './lib/isLowercase';
+import isUppercase from './lib/isUppercase';
+import isIMEI from './lib/isIMEI';
+import isAscii from './lib/isAscii';
+import isFullWidth from './lib/isFullWidth';
+import isHalfWidth from './lib/isHalfWidth';
+import isVariableWidth from './lib/isVariableWidth';
+import isMultibyte from './lib/isMultibyte';
+import isSemVer from './lib/isSemVer';
+import isSurrogatePair from './lib/isSurrogatePair';
+import isInt from './lib/isInt';
+import isFloat, { locales as isFloatLocales } from './lib/isFloat';
+import isDecimal from './lib/isDecimal';
+import isHexadecimal from './lib/isHexadecimal';
+import isOctal from './lib/isOctal';
+import isDivisibleBy from './lib/isDivisibleBy';
+import isHexColor from './lib/isHexColor';
+import isRgbColor from './lib/isRgbColor';
+import isHSL from './lib/isHSL';
+import isISRC from './lib/isISRC';
+import isIBAN, { locales as ibanLocales } from './lib/isIBAN';
+import isBIC from './lib/isBIC';
+import isMD5 from './lib/isMD5';
+import isHash from './lib/isHash';
+import isJWT from './lib/isJWT';
+import isJSON from './lib/isJSON';
+import isEmpty from './lib/isEmpty';
+import isLength from './lib/isLength';
+import isByteLength from './lib/isByteLength';
+import isUUID from './lib/isUUID';
+import isMongoId from './lib/isMongoId';
+import isAfter from './lib/isAfter';
+import isBefore from './lib/isBefore';
+import isIn from './lib/isIn';
+import isLuhnNumber from './lib/isLuhnNumber';
+import isCreditCard from './lib/isCreditCard';
+import isIdentityCard from './lib/isIdentityCard';
+import isEAN from './lib/isEAN';
+import isISIN from './lib/isISIN';
+import isISBN from './lib/isISBN';
+import isISSN from './lib/isISSN';
+import isTaxID from './lib/isTaxID';
+import isMobilePhone, { locales as isMobilePhoneLocales } from './lib/isMobilePhone';
+import isEthereumAddress from './lib/isEthereumAddress';
+import isCurrency from './lib/isCurrency';
+import isBtcAddress from './lib/isBtcAddress';
+import isISO6391 from './lib/isISO6391';
+import isISO8601 from './lib/isISO8601';
+import isRFC3339 from './lib/isRFC3339';
+import isISO31661Alpha2 from './lib/isISO31661Alpha2';
+import isISO31661Alpha3 from './lib/isISO31661Alpha3';
+import isISO4217 from './lib/isISO4217';
+import isBase32 from './lib/isBase32';
+import isBase58 from './lib/isBase58';
+import isBase64 from './lib/isBase64';
+import isDataURI from './lib/isDataURI';
+import isMagnetURI from './lib/isMagnetURI';
+import isMimeType from './lib/isMimeType';
+import isLatLong from './lib/isLatLong';
+import isPostalCode, { locales as isPostalCodeLocales } from './lib/isPostalCode';
+import ltrim from './lib/ltrim';
+import rtrim from './lib/rtrim';
+import trim from './lib/trim';
+import escape from './lib/escape';
+import unescape from './lib/unescape';
+import stripLow from './lib/stripLow';
+import whitelist from './lib/whitelist';
+import blacklist from './lib/blacklist';
+import isWhitelisted from './lib/isWhitelisted';
+import normalizeEmail from './lib/normalizeEmail';
+import isSlug from './lib/isSlug';
+import isLicensePlate from './lib/isLicensePlate';
+import isStrongPassword from './lib/isStrongPassword';
+import isVAT from './lib/isVAT';
+var version = '13.9.0';
+var validator = {
+ version: version,
+ toDate: toDate,
+ toFloat: toFloat,
+ toInt: toInt,
+ toBoolean: toBoolean,
+ equals: equals,
+ contains: contains,
+ matches: matches,
+ isEmail: isEmail,
+ isURL: isURL,
+ isMACAddress: isMACAddress,
+ isIP: isIP,
+ isIPRange: isIPRange,
+ isFQDN: isFQDN,
+ isBoolean: isBoolean,
+ isIBAN: isIBAN,
+ isBIC: isBIC,
+ isAlpha: isAlpha,
+ isAlphaLocales: isAlphaLocales,
+ isAlphanumeric: isAlphanumeric,
+ isAlphanumericLocales: isAlphanumericLocales,
+ isNumeric: isNumeric,
+ isPassportNumber: isPassportNumber,
+ isPort: isPort,
+ isLowercase: isLowercase,
+ isUppercase: isUppercase,
+ isAscii: isAscii,
+ isFullWidth: isFullWidth,
+ isHalfWidth: isHalfWidth,
+ isVariableWidth: isVariableWidth,
+ isMultibyte: isMultibyte,
+ isSemVer: isSemVer,
+ isSurrogatePair: isSurrogatePair,
+ isInt: isInt,
+ isIMEI: isIMEI,
+ isFloat: isFloat,
+ isFloatLocales: isFloatLocales,
+ isDecimal: isDecimal,
+ isHexadecimal: isHexadecimal,
+ isOctal: isOctal,
+ isDivisibleBy: isDivisibleBy,
+ isHexColor: isHexColor,
+ isRgbColor: isRgbColor,
+ isHSL: isHSL,
+ isISRC: isISRC,
+ isMD5: isMD5,
+ isHash: isHash,
+ isJWT: isJWT,
+ isJSON: isJSON,
+ isEmpty: isEmpty,
+ isLength: isLength,
+ isLocale: isLocale,
+ isByteLength: isByteLength,
+ isUUID: isUUID,
+ isMongoId: isMongoId,
+ isAfter: isAfter,
+ isBefore: isBefore,
+ isIn: isIn,
+ isLuhnNumber: isLuhnNumber,
+ isCreditCard: isCreditCard,
+ isIdentityCard: isIdentityCard,
+ isEAN: isEAN,
+ isISIN: isISIN,
+ isISBN: isISBN,
+ isISSN: isISSN,
+ isMobilePhone: isMobilePhone,
+ isMobilePhoneLocales: isMobilePhoneLocales,
+ isPostalCode: isPostalCode,
+ isPostalCodeLocales: isPostalCodeLocales,
+ isEthereumAddress: isEthereumAddress,
+ isCurrency: isCurrency,
+ isBtcAddress: isBtcAddress,
+ isISO6391: isISO6391,
+ isISO8601: isISO8601,
+ isRFC3339: isRFC3339,
+ isISO31661Alpha2: isISO31661Alpha2,
+ isISO31661Alpha3: isISO31661Alpha3,
+ isISO4217: isISO4217,
+ isBase32: isBase32,
+ isBase58: isBase58,
+ isBase64: isBase64,
+ isDataURI: isDataURI,
+ isMagnetURI: isMagnetURI,
+ isMimeType: isMimeType,
+ isLatLong: isLatLong,
+ ltrim: ltrim,
+ rtrim: rtrim,
+ trim: trim,
+ escape: escape,
+ unescape: unescape,
+ stripLow: stripLow,
+ whitelist: whitelist,
+ blacklist: blacklist,
+ isWhitelisted: isWhitelisted,
+ normalizeEmail: normalizeEmail,
+ toString: toString,
+ isSlug: isSlug,
+ isStrongPassword: isStrongPassword,
+ isTaxID: isTaxID,
+ isDate: isDate,
+ isTime: isTime,
+ isLicensePlate: isLicensePlate,
+ isVAT: isVAT,
+ ibanLocales: ibanLocales
+};
+export default validator; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/alpha.js b/includes/external/addressbook/node_modules/validator/es/lib/alpha.js
new file mode 100644
index 0000000..c2e9b83
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/alpha.js
@@ -0,0 +1,140 @@
+export var alpha = {
+ 'en-US': /^[A-Z]+$/i,
+ 'az-AZ': /^[A-VXYZÇƏĞİıÖŞÜ]+$/i,
+ 'bg-BG': /^[А-Я]+$/i,
+ 'cs-CZ': /^[A-ZÁČĎÉĚÍŇÓŘŠŤÚŮÝŽ]+$/i,
+ 'da-DK': /^[A-ZÆØÅ]+$/i,
+ 'de-DE': /^[A-ZÄÖÜß]+$/i,
+ 'el-GR': /^[Α-ώ]+$/i,
+ 'es-ES': /^[A-ZÁÉÍÑÓÚÜ]+$/i,
+ 'fa-IR': /^[ابپتثجچحخدذرزژسشصضطظعغفقکگلمنوهی]+$/i,
+ 'fi-FI': /^[A-ZÅÄÖ]+$/i,
+ 'fr-FR': /^[A-ZÀÂÆÇÉÈÊËÏÎÔŒÙÛÜŸ]+$/i,
+ 'it-IT': /^[A-ZÀÉÈÌÎÓÒÙ]+$/i,
+ 'ja-JP': /^[ぁ-んァ-ヶヲ-゚一-龠ー・。、]+$/i,
+ 'nb-NO': /^[A-ZÆØÅ]+$/i,
+ 'nl-NL': /^[A-ZÁÉËÏÓÖÜÚ]+$/i,
+ 'nn-NO': /^[A-ZÆØÅ]+$/i,
+ 'hu-HU': /^[A-ZÁÉÍÓÖŐÚÜŰ]+$/i,
+ 'pl-PL': /^[A-ZĄĆĘŚŁŃÓŻŹ]+$/i,
+ 'pt-PT': /^[A-ZÃÁÀÂÄÇÉÊËÍÏÕÓÔÖÚÜ]+$/i,
+ 'ru-RU': /^[А-ЯЁ]+$/i,
+ 'sl-SI': /^[A-ZČĆĐŠŽ]+$/i,
+ 'sk-SK': /^[A-ZÁČĎÉÍŇÓŠŤÚÝŽĹŔĽÄÔ]+$/i,
+ 'sr-RS@latin': /^[A-ZČĆŽŠĐ]+$/i,
+ 'sr-RS': /^[А-ЯЂЈЉЊЋЏ]+$/i,
+ 'sv-SE': /^[A-ZÅÄÖ]+$/i,
+ 'th-TH': /^[ก-๐\s]+$/i,
+ 'tr-TR': /^[A-ZÇĞİıÖŞÜ]+$/i,
+ 'uk-UA': /^[А-ЩЬЮЯЄIЇҐі]+$/i,
+ 'vi-VN': /^[A-ZÀÁẠẢÃÂẦẤẬẨẪĂẰẮẶẲẴĐÈÉẸẺẼÊỀẾỆỂỄÌÍỊỈĨÒÓỌỎÕÔỒỐỘỔỖƠỜỚỢỞỠÙÚỤỦŨƯỪỨỰỬỮỲÝỴỶỸ]+$/i,
+ 'ko-KR': /^[ㄱ-ㅎㅏ-ㅣ가-힣]*$/,
+ 'ku-IQ': /^[ئابپتجچحخدرڕزژسشعغفڤقکگلڵمنوۆھەیێيطؤثآإأكضصةظذ]+$/i,
+ ar: /^[ءآأؤإئابةتثجحخدذرزسشصضطظعغفقكلمنهوىيًٌٍَُِّْٰ]+$/,
+ he: /^[א-ת]+$/,
+ fa: /^['آاءأؤئبپتثجچحخدذرزژسشصضطظعغفقکگلمنوهةی']+$/i,
+ bn: /^['ঀঁংঃঅআইঈউঊঋঌএঐওঔকখগঘঙচছজঝঞটঠডঢণতথদধনপফবভমযরলশষসহ়ঽািীুূৃৄেৈোৌ্ৎৗড়ঢ়য়ৠৡৢৣৰৱ৲৳৴৵৶৷৸৹৺৻']+$/,
+ 'hi-IN': /^[\u0900-\u0961]+[\u0972-\u097F]*$/i,
+ 'si-LK': /^[\u0D80-\u0DFF]+$/
+};
+export var alphanumeric = {
+ 'en-US': /^[0-9A-Z]+$/i,
+ 'az-AZ': /^[0-9A-VXYZÇƏĞİıÖŞÜ]+$/i,
+ 'bg-BG': /^[0-9А-Я]+$/i,
+ 'cs-CZ': /^[0-9A-ZÁČĎÉĚÍŇÓŘŠŤÚŮÝŽ]+$/i,
+ 'da-DK': /^[0-9A-ZÆØÅ]+$/i,
+ 'de-DE': /^[0-9A-ZÄÖÜß]+$/i,
+ 'el-GR': /^[0-9Α-ω]+$/i,
+ 'es-ES': /^[0-9A-ZÁÉÍÑÓÚÜ]+$/i,
+ 'fi-FI': /^[0-9A-ZÅÄÖ]+$/i,
+ 'fr-FR': /^[0-9A-ZÀÂÆÇÉÈÊËÏÎÔŒÙÛÜŸ]+$/i,
+ 'it-IT': /^[0-9A-ZÀÉÈÌÎÓÒÙ]+$/i,
+ 'ja-JP': /^[0-90-9ぁ-んァ-ヶヲ-゚一-龠ー・。、]+$/i,
+ 'hu-HU': /^[0-9A-ZÁÉÍÓÖŐÚÜŰ]+$/i,
+ 'nb-NO': /^[0-9A-ZÆØÅ]+$/i,
+ 'nl-NL': /^[0-9A-ZÁÉËÏÓÖÜÚ]+$/i,
+ 'nn-NO': /^[0-9A-ZÆØÅ]+$/i,
+ 'pl-PL': /^[0-9A-ZĄĆĘŚŁŃÓŻŹ]+$/i,
+ 'pt-PT': /^[0-9A-ZÃÁÀÂÄÇÉÊËÍÏÕÓÔÖÚÜ]+$/i,
+ 'ru-RU': /^[0-9А-ЯЁ]+$/i,
+ 'sl-SI': /^[0-9A-ZČĆĐŠŽ]+$/i,
+ 'sk-SK': /^[0-9A-ZÁČĎÉÍŇÓŠŤÚÝŽĹŔĽÄÔ]+$/i,
+ 'sr-RS@latin': /^[0-9A-ZČĆŽŠĐ]+$/i,
+ 'sr-RS': /^[0-9А-ЯЂЈЉЊЋЏ]+$/i,
+ 'sv-SE': /^[0-9A-ZÅÄÖ]+$/i,
+ 'th-TH': /^[ก-๙\s]+$/i,
+ 'tr-TR': /^[0-9A-ZÇĞİıÖŞÜ]+$/i,
+ 'uk-UA': /^[0-9А-ЩЬЮЯЄIЇҐі]+$/i,
+ 'ko-KR': /^[0-9ㄱ-ㅎㅏ-ㅣ가-힣]*$/,
+ 'ku-IQ': /^[٠١٢٣٤٥٦٧٨٩0-9ئابپتجچحخدرڕزژسشعغفڤقکگلڵمنوۆھەیێيطؤثآإأكضصةظذ]+$/i,
+ 'vi-VN': /^[0-9A-ZÀÁẠẢÃÂẦẤẬẨẪĂẰẮẶẲẴĐÈÉẸẺẼÊỀẾỆỂỄÌÍỊỈĨÒÓỌỎÕÔỒỐỘỔỖƠỜỚỢỞỠÙÚỤỦŨƯỪỨỰỬỮỲÝỴỶỸ]+$/i,
+ ar: /^[٠١٢٣٤٥٦٧٨٩0-9ءآأؤإئابةتثجحخدذرزسشصضطظعغفقكلمنهوىيًٌٍَُِّْٰ]+$/,
+ he: /^[0-9א-ת]+$/,
+ fa: /^['0-9آاءأؤئبپتثجچحخدذرزژسشصضطظعغفقکگلمنوهةی۱۲۳۴۵۶۷۸۹۰']+$/i,
+ bn: /^['ঀঁংঃঅআইঈউঊঋঌএঐওঔকখগঘঙচছজঝঞটঠডঢণতথদধনপফবভমযরলশষসহ়ঽািীুূৃৄেৈোৌ্ৎৗড়ঢ়য়ৠৡৢৣ০১২৩৪৫৬৭৮৯ৰৱ৲৳৴৵৶৷৸৹৺৻']+$/,
+ 'hi-IN': /^[\u0900-\u0963]+[\u0966-\u097F]*$/i,
+ 'si-LK': /^[0-9\u0D80-\u0DFF]+$/
+};
+export var decimal = {
+ 'en-US': '.',
+ ar: '٫'
+};
+export var englishLocales = ['AU', 'GB', 'HK', 'IN', 'NZ', 'ZA', 'ZM'];
+
+for (var locale, i = 0; i < englishLocales.length; i++) {
+ locale = "en-".concat(englishLocales[i]);
+ alpha[locale] = alpha['en-US'];
+ alphanumeric[locale] = alphanumeric['en-US'];
+ decimal[locale] = decimal['en-US'];
+} // Source: http://www.localeplanet.com/java/
+
+
+export var arabicLocales = ['AE', 'BH', 'DZ', 'EG', 'IQ', 'JO', 'KW', 'LB', 'LY', 'MA', 'QM', 'QA', 'SA', 'SD', 'SY', 'TN', 'YE'];
+
+for (var _locale, _i = 0; _i < arabicLocales.length; _i++) {
+ _locale = "ar-".concat(arabicLocales[_i]);
+ alpha[_locale] = alpha.ar;
+ alphanumeric[_locale] = alphanumeric.ar;
+ decimal[_locale] = decimal.ar;
+}
+
+export var farsiLocales = ['IR', 'AF'];
+
+for (var _locale2, _i2 = 0; _i2 < farsiLocales.length; _i2++) {
+ _locale2 = "fa-".concat(farsiLocales[_i2]);
+ alphanumeric[_locale2] = alphanumeric.fa;
+ decimal[_locale2] = decimal.ar;
+}
+
+export var bengaliLocales = ['BD', 'IN'];
+
+for (var _locale3, _i3 = 0; _i3 < bengaliLocales.length; _i3++) {
+ _locale3 = "bn-".concat(bengaliLocales[_i3]);
+ alpha[_locale3] = alpha.bn;
+ alphanumeric[_locale3] = alphanumeric.bn;
+ decimal[_locale3] = decimal['en-US'];
+} // Source: https://en.wikipedia.org/wiki/Decimal_mark
+
+
+export var dotDecimal = ['ar-EG', 'ar-LB', 'ar-LY'];
+export var commaDecimal = ['bg-BG', 'cs-CZ', 'da-DK', 'de-DE', 'el-GR', 'en-ZM', 'es-ES', 'fr-CA', 'fr-FR', 'id-ID', 'it-IT', 'ku-IQ', 'hi-IN', 'hu-HU', 'nb-NO', 'nn-NO', 'nl-NL', 'pl-PL', 'pt-PT', 'ru-RU', 'si-LK', 'sl-SI', 'sr-RS@latin', 'sr-RS', 'sv-SE', 'tr-TR', 'uk-UA', 'vi-VN'];
+
+for (var _i4 = 0; _i4 < dotDecimal.length; _i4++) {
+ decimal[dotDecimal[_i4]] = decimal['en-US'];
+}
+
+for (var _i5 = 0; _i5 < commaDecimal.length; _i5++) {
+ decimal[commaDecimal[_i5]] = ',';
+}
+
+alpha['fr-CA'] = alpha['fr-FR'];
+alphanumeric['fr-CA'] = alphanumeric['fr-FR'];
+alpha['pt-BR'] = alpha['pt-PT'];
+alphanumeric['pt-BR'] = alphanumeric['pt-PT'];
+decimal['pt-BR'] = decimal['pt-PT']; // see #862
+
+alpha['pl-Pl'] = alpha['pl-PL'];
+alphanumeric['pl-Pl'] = alphanumeric['pl-PL'];
+decimal['pl-Pl'] = decimal['pl-PL']; // see #1455
+
+alpha['fa-AF'] = alpha.fa; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/blacklist.js b/includes/external/addressbook/node_modules/validator/es/lib/blacklist.js
new file mode 100644
index 0000000..77c0e5c
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/blacklist.js
@@ -0,0 +1,5 @@
+import assertString from './util/assertString';
+export default function blacklist(str, chars) {
+ assertString(str);
+ return str.replace(new RegExp("[".concat(chars, "]+"), 'g'), '');
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/contains.js b/includes/external/addressbook/node_modules/validator/es/lib/contains.js
new file mode 100644
index 0000000..bf654b8
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/contains.js
@@ -0,0 +1,17 @@
+import assertString from './util/assertString';
+import toString from './util/toString';
+import merge from './util/merge';
+var defaulContainsOptions = {
+ ignoreCase: false,
+ minOccurrences: 1
+};
+export default function contains(str, elem, options) {
+ assertString(str);
+ options = merge(options, defaulContainsOptions);
+
+ if (options.ignoreCase) {
+ return str.toLowerCase().split(toString(elem).toLowerCase()).length > options.minOccurrences;
+ }
+
+ return str.split(toString(elem)).length > options.minOccurrences;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/equals.js b/includes/external/addressbook/node_modules/validator/es/lib/equals.js
new file mode 100644
index 0000000..87a9ded
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/equals.js
@@ -0,0 +1,5 @@
+import assertString from './util/assertString';
+export default function equals(str, comparison) {
+ assertString(str);
+ return str === comparison;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/escape.js b/includes/external/addressbook/node_modules/validator/es/lib/escape.js
new file mode 100644
index 0000000..e9bb6de
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/escape.js
@@ -0,0 +1,5 @@
+import assertString from './util/assertString';
+export default function escape(str) {
+ assertString(str);
+ return str.replace(/&/g, '&amp;').replace(/"/g, '&quot;').replace(/'/g, '&#x27;').replace(/</g, '&lt;').replace(/>/g, '&gt;').replace(/\//g, '&#x2F;').replace(/\\/g, '&#x5C;').replace(/`/g, '&#96;');
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isAfter.js b/includes/external/addressbook/node_modules/validator/es/lib/isAfter.js
new file mode 100644
index 0000000..d0ac34f
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isAfter.js
@@ -0,0 +1,9 @@
+import toDate from './toDate';
+export default function isAfter(date, options) {
+ // For backwards compatibility:
+ // isAfter(str [, date]), i.e. `options` could be used as argument for the legacy `date`
+ var comparisonDate = (options === null || options === void 0 ? void 0 : options.comparisonDate) || options || Date().toString();
+ var comparison = toDate(comparisonDate);
+ var original = toDate(date);
+ return !!(original && comparison && original > comparison);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isAlpha.js b/includes/external/addressbook/node_modules/validator/es/lib/isAlpha.js
new file mode 100644
index 0000000..5214b74
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isAlpha.js
@@ -0,0 +1,26 @@
+import assertString from './util/assertString';
+import { alpha } from './alpha';
+export default function isAlpha(_str) {
+ var locale = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'en-US';
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ assertString(_str);
+ var str = _str;
+ var ignore = options.ignore;
+
+ if (ignore) {
+ if (ignore instanceof RegExp) {
+ str = str.replace(ignore, '');
+ } else if (typeof ignore === 'string') {
+ str = str.replace(new RegExp("[".concat(ignore.replace(/[-[\]{}()*+?.,\\^$|#\\s]/g, '\\$&'), "]"), 'g'), ''); // escape regex for ignore
+ } else {
+ throw new Error('ignore should be instance of a String or RegExp');
+ }
+ }
+
+ if (locale in alpha) {
+ return alpha[locale].test(str);
+ }
+
+ throw new Error("Invalid locale '".concat(locale, "'"));
+}
+export var locales = Object.keys(alpha); \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isAlphanumeric.js b/includes/external/addressbook/node_modules/validator/es/lib/isAlphanumeric.js
new file mode 100644
index 0000000..b0556e5
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isAlphanumeric.js
@@ -0,0 +1,26 @@
+import assertString from './util/assertString';
+import { alphanumeric } from './alpha';
+export default function isAlphanumeric(_str) {
+ var locale = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'en-US';
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ assertString(_str);
+ var str = _str;
+ var ignore = options.ignore;
+
+ if (ignore) {
+ if (ignore instanceof RegExp) {
+ str = str.replace(ignore, '');
+ } else if (typeof ignore === 'string') {
+ str = str.replace(new RegExp("[".concat(ignore.replace(/[-[\]{}()*+?.,\\^$|#\\s]/g, '\\$&'), "]"), 'g'), ''); // escape regex for ignore
+ } else {
+ throw new Error('ignore should be instance of a String or RegExp');
+ }
+ }
+
+ if (locale in alphanumeric) {
+ return alphanumeric[locale].test(str);
+ }
+
+ throw new Error("Invalid locale '".concat(locale, "'"));
+}
+export var locales = Object.keys(alphanumeric); \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isAscii.js b/includes/external/addressbook/node_modules/validator/es/lib/isAscii.js
new file mode 100644
index 0000000..e322121
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isAscii.js
@@ -0,0 +1,10 @@
+import assertString from './util/assertString';
+/* eslint-disable no-control-regex */
+
+var ascii = /^[\x00-\x7F]+$/;
+/* eslint-enable no-control-regex */
+
+export default function isAscii(str) {
+ assertString(str);
+ return ascii.test(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isBIC.js b/includes/external/addressbook/node_modules/validator/es/lib/isBIC.js
new file mode 100644
index 0000000..a857eac
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isBIC.js
@@ -0,0 +1,16 @@
+import assertString from './util/assertString';
+import { CountryCodes } from './isISO31661Alpha2'; // https://en.wikipedia.org/wiki/ISO_9362
+
+var isBICReg = /^[A-Za-z]{6}[A-Za-z0-9]{2}([A-Za-z0-9]{3})?$/;
+export default function isBIC(str) {
+ assertString(str); // toUpperCase() should be removed when a new major version goes out that changes
+ // the regex to [A-Z] (per the spec).
+
+ var countryCode = str.slice(4, 6).toUpperCase();
+
+ if (!CountryCodes.has(countryCode) && countryCode !== 'XK') {
+ return false;
+ }
+
+ return isBICReg.test(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isBase32.js b/includes/external/addressbook/node_modules/validator/es/lib/isBase32.js
new file mode 100644
index 0000000..d11f0f1
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isBase32.js
@@ -0,0 +1,23 @@
+import assertString from './util/assertString';
+import merge from './util/merge';
+var base32 = /^[A-Z2-7]+=*$/;
+var crockfordBase32 = /^[A-HJKMNP-TV-Z0-9]+$/;
+var defaultBase32Options = {
+ crockford: false
+};
+export default function isBase32(str, options) {
+ assertString(str);
+ options = merge(options, defaultBase32Options);
+
+ if (options.crockford) {
+ return crockfordBase32.test(str);
+ }
+
+ var len = str.length;
+
+ if (len % 8 === 0 && base32.test(str)) {
+ return true;
+ }
+
+ return false;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isBase58.js b/includes/external/addressbook/node_modules/validator/es/lib/isBase58.js
new file mode 100644
index 0000000..863bbe9
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isBase58.js
@@ -0,0 +1,12 @@
+import assertString from './util/assertString'; // Accepted chars - 123456789ABCDEFGH JKLMN PQRSTUVWXYZabcdefghijk mnopqrstuvwxyz
+
+var base58Reg = /^[A-HJ-NP-Za-km-z1-9]*$/;
+export default function isBase58(str) {
+ assertString(str);
+
+ if (base58Reg.test(str)) {
+ return true;
+ }
+
+ return false;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isBase64.js b/includes/external/addressbook/node_modules/validator/es/lib/isBase64.js
new file mode 100644
index 0000000..04467fc
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isBase64.js
@@ -0,0 +1,23 @@
+import assertString from './util/assertString';
+import merge from './util/merge';
+var notBase64 = /[^A-Z0-9+\/=]/i;
+var urlSafeBase64 = /^[A-Z0-9_\-]*$/i;
+var defaultBase64Options = {
+ urlSafe: false
+};
+export default function isBase64(str, options) {
+ assertString(str);
+ options = merge(options, defaultBase64Options);
+ var len = str.length;
+
+ if (options.urlSafe) {
+ return urlSafeBase64.test(str);
+ }
+
+ if (len % 4 !== 0 || notBase64.test(str)) {
+ return false;
+ }
+
+ var firstPaddingChar = str.indexOf('=');
+ return firstPaddingChar === -1 || firstPaddingChar === len - 1 || firstPaddingChar === len - 2 && str[len - 1] === '=';
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isBefore.js b/includes/external/addressbook/node_modules/validator/es/lib/isBefore.js
new file mode 100644
index 0000000..794dbab
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isBefore.js
@@ -0,0 +1,9 @@
+import assertString from './util/assertString';
+import toDate from './toDate';
+export default function isBefore(str) {
+ var date = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : String(new Date());
+ assertString(str);
+ var comparison = toDate(date);
+ var original = toDate(str);
+ return !!(original && comparison && original < comparison);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isBoolean.js b/includes/external/addressbook/node_modules/validator/es/lib/isBoolean.js
new file mode 100644
index 0000000..c0be07a
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isBoolean.js
@@ -0,0 +1,16 @@
+import assertString from './util/assertString';
+var defaultOptions = {
+ loose: false
+};
+var strictBooleans = ['true', 'false', '1', '0'];
+var looseBooleans = [].concat(strictBooleans, ['yes', 'no']);
+export default function isBoolean(str) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : defaultOptions;
+ assertString(str);
+
+ if (options.loose) {
+ return looseBooleans.includes(str.toLowerCase());
+ }
+
+ return strictBooleans.includes(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isBtcAddress.js b/includes/external/addressbook/node_modules/validator/es/lib/isBtcAddress.js
new file mode 100644
index 0000000..377a2f5
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isBtcAddress.js
@@ -0,0 +1,7 @@
+import assertString from './util/assertString';
+var bech32 = /^(bc1)[a-z0-9]{25,39}$/;
+var base58 = /^(1|3)[A-HJ-NP-Za-km-z1-9]{25,39}$/;
+export default function isBtcAddress(str) {
+ assertString(str);
+ return bech32.test(str) || base58.test(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isByteLength.js b/includes/external/addressbook/node_modules/validator/es/lib/isByteLength.js
new file mode 100644
index 0000000..eee2543
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isByteLength.js
@@ -0,0 +1,22 @@
+function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
+
+import assertString from './util/assertString';
+/* eslint-disable prefer-rest-params */
+
+export default function isByteLength(str, options) {
+ assertString(str);
+ var min;
+ var max;
+
+ if (_typeof(options) === 'object') {
+ min = options.min || 0;
+ max = options.max;
+ } else {
+ // backwards compatibility: isByteLength(str, min [, max])
+ min = arguments[1];
+ max = arguments[2];
+ }
+
+ var len = encodeURI(str).split(/%..|./).length - 1;
+ return len >= min && (typeof max === 'undefined' || len <= max);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isCreditCard.js b/includes/external/addressbook/node_modules/validator/es/lib/isCreditCard.js
new file mode 100644
index 0000000..f98ed13
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isCreditCard.js
@@ -0,0 +1,38 @@
+import assertString from './util/assertString';
+import isLuhnValid from './isLuhnNumber';
+var cards = {
+ amex: /^3[47][0-9]{13}$/,
+ dinersclub: /^3(?:0[0-5]|[68][0-9])[0-9]{11}$/,
+ discover: /^6(?:011|5[0-9][0-9])[0-9]{12,15}$/,
+ jcb: /^(?:2131|1800|35\d{3})\d{11}$/,
+ mastercard: /^5[1-5][0-9]{2}|(222[1-9]|22[3-9][0-9]|2[3-6][0-9]{2}|27[01][0-9]|2720)[0-9]{12}$/,
+ // /^[25][1-7][0-9]{14}$/;
+ unionpay: /^(6[27][0-9]{14}|^(81[0-9]{14,17}))$/,
+ visa: /^(?:4[0-9]{12})(?:[0-9]{3,6})?$/
+};
+/* eslint-disable max-len */
+
+var allCards = /^(?:4[0-9]{12}(?:[0-9]{3,6})?|5[1-5][0-9]{14}|(222[1-9]|22[3-9][0-9]|2[3-6][0-9]{2}|27[01][0-9]|2720)[0-9]{12}|6(?:011|5[0-9][0-9])[0-9]{12,15}|3[47][0-9]{13}|3(?:0[0-5]|[68][0-9])[0-9]{11}|(?:2131|1800|35\d{3})\d{11}|6[27][0-9]{14}|^(81[0-9]{14,17}))$/;
+/* eslint-enable max-len */
+
+export default function isCreditCard(card) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ assertString(card);
+ var provider = options.provider;
+ var sanitized = card.replace(/[- ]+/g, '');
+
+ if (provider && provider.toLowerCase() in cards) {
+ // specific provider in the list
+ if (!cards[provider.toLowerCase()].test(sanitized)) {
+ return false;
+ }
+ } else if (provider && !(provider.toLowerCase() in cards)) {
+ /* specific provider not in the list */
+ throw new Error("".concat(provider, " is not a valid credit card provider."));
+ } else if (!allCards.test(sanitized)) {
+ // no specific provider
+ return false;
+ }
+
+ return isLuhnValid(card);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isCurrency.js b/includes/external/addressbook/node_modules/validator/es/lib/isCurrency.js
new file mode 100755
index 0000000..519ee19
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isCurrency.js
@@ -0,0 +1,77 @@
+import merge from './util/merge';
+import assertString from './util/assertString';
+
+function currencyRegex(options) {
+ var decimal_digits = "\\d{".concat(options.digits_after_decimal[0], "}");
+ options.digits_after_decimal.forEach(function (digit, index) {
+ if (index !== 0) decimal_digits = "".concat(decimal_digits, "|\\d{").concat(digit, "}");
+ });
+ var symbol = "(".concat(options.symbol.replace(/\W/, function (m) {
+ return "\\".concat(m);
+ }), ")").concat(options.require_symbol ? '' : '?'),
+ negative = '-?',
+ whole_dollar_amount_without_sep = '[1-9]\\d*',
+ whole_dollar_amount_with_sep = "[1-9]\\d{0,2}(\\".concat(options.thousands_separator, "\\d{3})*"),
+ valid_whole_dollar_amounts = ['0', whole_dollar_amount_without_sep, whole_dollar_amount_with_sep],
+ whole_dollar_amount = "(".concat(valid_whole_dollar_amounts.join('|'), ")?"),
+ decimal_amount = "(\\".concat(options.decimal_separator, "(").concat(decimal_digits, "))").concat(options.require_decimal ? '' : '?');
+ var pattern = whole_dollar_amount + (options.allow_decimal || options.require_decimal ? decimal_amount : ''); // default is negative sign before symbol, but there are two other options (besides parens)
+
+ if (options.allow_negatives && !options.parens_for_negatives) {
+ if (options.negative_sign_after_digits) {
+ pattern += negative;
+ } else if (options.negative_sign_before_digits) {
+ pattern = negative + pattern;
+ }
+ } // South African Rand, for example, uses R 123 (space) and R-123 (no space)
+
+
+ if (options.allow_negative_sign_placeholder) {
+ pattern = "( (?!\\-))?".concat(pattern);
+ } else if (options.allow_space_after_symbol) {
+ pattern = " ?".concat(pattern);
+ } else if (options.allow_space_after_digits) {
+ pattern += '( (?!$))?';
+ }
+
+ if (options.symbol_after_digits) {
+ pattern += symbol;
+ } else {
+ pattern = symbol + pattern;
+ }
+
+ if (options.allow_negatives) {
+ if (options.parens_for_negatives) {
+ pattern = "(\\(".concat(pattern, "\\)|").concat(pattern, ")");
+ } else if (!(options.negative_sign_before_digits || options.negative_sign_after_digits)) {
+ pattern = negative + pattern;
+ }
+ } // ensure there's a dollar and/or decimal amount, and that
+ // it doesn't start with a space or a negative sign followed by a space
+
+
+ return new RegExp("^(?!-? )(?=.*\\d)".concat(pattern, "$"));
+}
+
+var default_currency_options = {
+ symbol: '$',
+ require_symbol: false,
+ allow_space_after_symbol: false,
+ symbol_after_digits: false,
+ allow_negatives: true,
+ parens_for_negatives: false,
+ negative_sign_before_digits: false,
+ negative_sign_after_digits: false,
+ allow_negative_sign_placeholder: false,
+ thousands_separator: ',',
+ decimal_separator: '.',
+ allow_decimal: true,
+ require_decimal: false,
+ digits_after_decimal: [2],
+ allow_space_after_digits: false
+};
+export default function isCurrency(str, options) {
+ assertString(str);
+ options = merge(options, default_currency_options);
+ return currencyRegex(options).test(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isDataURI.js b/includes/external/addressbook/node_modules/validator/es/lib/isDataURI.js
new file mode 100644
index 0000000..a00a8cd
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isDataURI.js
@@ -0,0 +1,39 @@
+import assertString from './util/assertString';
+var validMediaType = /^[a-z]+\/[a-z0-9\-\+\._]+$/i;
+var validAttribute = /^[a-z\-]+=[a-z0-9\-]+$/i;
+var validData = /^[a-z0-9!\$&'\(\)\*\+,;=\-\._~:@\/\?%\s]*$/i;
+export default function isDataURI(str) {
+ assertString(str);
+ var data = str.split(',');
+
+ if (data.length < 2) {
+ return false;
+ }
+
+ var attributes = data.shift().trim().split(';');
+ var schemeAndMediaType = attributes.shift();
+
+ if (schemeAndMediaType.slice(0, 5) !== 'data:') {
+ return false;
+ }
+
+ var mediaType = schemeAndMediaType.slice(5);
+
+ if (mediaType !== '' && !validMediaType.test(mediaType)) {
+ return false;
+ }
+
+ for (var i = 0; i < attributes.length; i++) {
+ if (!(i === attributes.length - 1 && attributes[i].toLowerCase() === 'base64') && !validAttribute.test(attributes[i])) {
+ return false;
+ }
+ }
+
+ for (var _i = 0; _i < data.length; _i++) {
+ if (!validData.test(data[_i])) {
+ return false;
+ }
+ }
+
+ return true;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isDate.js b/includes/external/addressbook/node_modules/validator/es/lib/isDate.js
new file mode 100644
index 0000000..c4d0d08
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isDate.js
@@ -0,0 +1,86 @@
+function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
+
+function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
+
+function _iterableToArrayLimit(arr, i) { if (typeof Symbol === "undefined" || !(Symbol.iterator in Object(arr))) return; var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
+
+function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
+
+function _createForOfIteratorHelper(o, allowArrayLike) { var it; if (typeof Symbol === "undefined" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e2) { throw _e2; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = o[Symbol.iterator](); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e3) { didErr = true; err = _e3; }, f: function f() { try { if (!normalCompletion && it["return"] != null) it["return"](); } finally { if (didErr) throw err; } } }; }
+
+function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
+
+function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
+
+import merge from './util/merge';
+var default_date_options = {
+ format: 'YYYY/MM/DD',
+ delimiters: ['/', '-'],
+ strictMode: false
+};
+
+function isValidFormat(format) {
+ return /(^(y{4}|y{2})[.\/-](m{1,2})[.\/-](d{1,2})$)|(^(m{1,2})[.\/-](d{1,2})[.\/-]((y{4}|y{2})$))|(^(d{1,2})[.\/-](m{1,2})[.\/-]((y{4}|y{2})$))/gi.test(format);
+}
+
+function zip(date, format) {
+ var zippedArr = [],
+ len = Math.min(date.length, format.length);
+
+ for (var i = 0; i < len; i++) {
+ zippedArr.push([date[i], format[i]]);
+ }
+
+ return zippedArr;
+}
+
+export default function isDate(input, options) {
+ if (typeof options === 'string') {
+ // Allow backward compatbility for old format isDate(input [, format])
+ options = merge({
+ format: options
+ }, default_date_options);
+ } else {
+ options = merge(options, default_date_options);
+ }
+
+ if (typeof input === 'string' && isValidFormat(options.format)) {
+ var formatDelimiter = options.delimiters.find(function (delimiter) {
+ return options.format.indexOf(delimiter) !== -1;
+ });
+ var dateDelimiter = options.strictMode ? formatDelimiter : options.delimiters.find(function (delimiter) {
+ return input.indexOf(delimiter) !== -1;
+ });
+ var dateAndFormat = zip(input.split(dateDelimiter), options.format.toLowerCase().split(formatDelimiter));
+ var dateObj = {};
+
+ var _iterator = _createForOfIteratorHelper(dateAndFormat),
+ _step;
+
+ try {
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
+ var _step$value = _slicedToArray(_step.value, 2),
+ dateWord = _step$value[0],
+ formatWord = _step$value[1];
+
+ if (dateWord.length !== formatWord.length) {
+ return false;
+ }
+
+ dateObj[formatWord.charAt(0)] = dateWord;
+ }
+ } catch (err) {
+ _iterator.e(err);
+ } finally {
+ _iterator.f();
+ }
+
+ return new Date("".concat(dateObj.m, "/").concat(dateObj.d, "/").concat(dateObj.y)).getDate() === +dateObj.d;
+ }
+
+ if (!options.strictMode) {
+ return Object.prototype.toString.call(input) === '[object Date]' && isFinite(input);
+ }
+
+ return false;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isDecimal.js b/includes/external/addressbook/node_modules/validator/es/lib/isDecimal.js
new file mode 100644
index 0000000..597f42c
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isDecimal.js
@@ -0,0 +1,26 @@
+import merge from './util/merge';
+import assertString from './util/assertString';
+import includes from './util/includes';
+import { decimal } from './alpha';
+
+function decimalRegExp(options) {
+ var regExp = new RegExp("^[-+]?([0-9]+)?(\\".concat(decimal[options.locale], "[0-9]{").concat(options.decimal_digits, "})").concat(options.force_decimal ? '' : '?', "$"));
+ return regExp;
+}
+
+var default_decimal_options = {
+ force_decimal: false,
+ decimal_digits: '1,',
+ locale: 'en-US'
+};
+var blacklist = ['', '-', '+'];
+export default function isDecimal(str, options) {
+ assertString(str);
+ options = merge(options, default_decimal_options);
+
+ if (options.locale in decimal) {
+ return !includes(blacklist, str.replace(/ /g, '')) && decimalRegExp(options).test(str);
+ }
+
+ throw new Error("Invalid locale '".concat(options.locale, "'"));
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isDivisibleBy.js b/includes/external/addressbook/node_modules/validator/es/lib/isDivisibleBy.js
new file mode 100644
index 0000000..f71d5f4
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isDivisibleBy.js
@@ -0,0 +1,6 @@
+import assertString from './util/assertString';
+import toFloat from './toFloat';
+export default function isDivisibleBy(str, num) {
+ assertString(str);
+ return toFloat(str) % parseInt(num, 10) === 0;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isEAN.js b/includes/external/addressbook/node_modules/validator/es/lib/isEAN.js
new file mode 100644
index 0000000..246db93
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isEAN.js
@@ -0,0 +1,72 @@
+/**
+ * The most commonly used EAN standard is
+ * the thirteen-digit EAN-13, while the
+ * less commonly used 8-digit EAN-8 barcode was
+ * introduced for use on small packages.
+ * Also EAN/UCC-14 is used for Grouping of individual
+ * trade items above unit level(Intermediate, Carton or Pallet).
+ * For more info about EAN-14 checkout: https://www.gtin.info/itf-14-barcodes/
+ * EAN consists of:
+ * GS1 prefix, manufacturer code, product code and check digit
+ * Reference: https://en.wikipedia.org/wiki/International_Article_Number
+ * Reference: https://www.gtin.info/
+ */
+import assertString from './util/assertString';
+/**
+ * Define EAN Lenghts; 8 for EAN-8; 13 for EAN-13; 14 for EAN-14
+ * and Regular Expression for valid EANs (EAN-8, EAN-13, EAN-14),
+ * with exact numberic matching of 8 or 13 or 14 digits [0-9]
+ */
+
+var LENGTH_EAN_8 = 8;
+var LENGTH_EAN_14 = 14;
+var validEanRegex = /^(\d{8}|\d{13}|\d{14})$/;
+/**
+ * Get position weight given:
+ * EAN length and digit index/position
+ *
+ * @param {number} length
+ * @param {number} index
+ * @return {number}
+ */
+
+function getPositionWeightThroughLengthAndIndex(length, index) {
+ if (length === LENGTH_EAN_8 || length === LENGTH_EAN_14) {
+ return index % 2 === 0 ? 3 : 1;
+ }
+
+ return index % 2 === 0 ? 1 : 3;
+}
+/**
+ * Calculate EAN Check Digit
+ * Reference: https://en.wikipedia.org/wiki/International_Article_Number#Calculation_of_checksum_digit
+ *
+ * @param {string} ean
+ * @return {number}
+ */
+
+
+function calculateCheckDigit(ean) {
+ var checksum = ean.slice(0, -1).split('').map(function (_char, index) {
+ return Number(_char) * getPositionWeightThroughLengthAndIndex(ean.length, index);
+ }).reduce(function (acc, partialSum) {
+ return acc + partialSum;
+ }, 0);
+ var remainder = 10 - checksum % 10;
+ return remainder < 10 ? remainder : 0;
+}
+/**
+ * Check if string is valid EAN:
+ * Matches EAN-8/EAN-13/EAN-14 regex
+ * Has valid check digit.
+ *
+ * @param {string} str
+ * @return {boolean}
+ */
+
+
+export default function isEAN(str) {
+ assertString(str);
+ var actualCheckDigit = Number(str.slice(-1));
+ return validEanRegex.test(str) && actualCheckDigit === calculateCheckDigit(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isEmail.js b/includes/external/addressbook/node_modules/validator/es/lib/isEmail.js
new file mode 100644
index 0000000..f76a5b2
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isEmail.js
@@ -0,0 +1,186 @@
+import assertString from './util/assertString';
+import merge from './util/merge';
+import isByteLength from './isByteLength';
+import isFQDN from './isFQDN';
+import isIP from './isIP';
+var default_email_options = {
+ allow_display_name: false,
+ require_display_name: false,
+ allow_utf8_local_part: true,
+ require_tld: true,
+ blacklisted_chars: '',
+ ignore_max_length: false,
+ host_blacklist: [],
+ host_whitelist: []
+};
+/* eslint-disable max-len */
+
+/* eslint-disable no-control-regex */
+
+var splitNameAddress = /^([^\x00-\x1F\x7F-\x9F\cX]+)</i;
+var emailUserPart = /^[a-z\d!#\$%&'\*\+\-\/=\?\^_`{\|}~]+$/i;
+var gmailUserPart = /^[a-z\d]+$/;
+var quotedEmailUser = /^([\s\x01-\x08\x0b\x0c\x0e-\x1f\x7f\x21\x23-\x5b\x5d-\x7e]|(\\[\x01-\x09\x0b\x0c\x0d-\x7f]))*$/i;
+var emailUserUtf8Part = /^[a-z\d!#\$%&'\*\+\-\/=\?\^_`{\|}~\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]+$/i;
+var quotedEmailUserUtf8 = /^([\s\x01-\x08\x0b\x0c\x0e-\x1f\x7f\x21\x23-\x5b\x5d-\x7e\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]|(\\[\x01-\x09\x0b\x0c\x0d-\x7f\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))*$/i;
+var defaultMaxEmailLength = 254;
+/* eslint-enable max-len */
+
+/* eslint-enable no-control-regex */
+
+/**
+ * Validate display name according to the RFC2822: https://tools.ietf.org/html/rfc2822#appendix-A.1.2
+ * @param {String} display_name
+ */
+
+function validateDisplayName(display_name) {
+ var display_name_without_quotes = display_name.replace(/^"(.+)"$/, '$1'); // display name with only spaces is not valid
+
+ if (!display_name_without_quotes.trim()) {
+ return false;
+ } // check whether display name contains illegal character
+
+
+ var contains_illegal = /[\.";<>]/.test(display_name_without_quotes);
+
+ if (contains_illegal) {
+ // if contains illegal characters,
+ // must to be enclosed in double-quotes, otherwise it's not a valid display name
+ if (display_name_without_quotes === display_name) {
+ return false;
+ } // the quotes in display name must start with character symbol \
+
+
+ var all_start_with_back_slash = display_name_without_quotes.split('"').length === display_name_without_quotes.split('\\"').length;
+
+ if (!all_start_with_back_slash) {
+ return false;
+ }
+ }
+
+ return true;
+}
+
+export default function isEmail(str, options) {
+ assertString(str);
+ options = merge(options, default_email_options);
+
+ if (options.require_display_name || options.allow_display_name) {
+ var display_email = str.match(splitNameAddress);
+
+ if (display_email) {
+ var display_name = display_email[1]; // Remove display name and angle brackets to get email address
+ // Can be done in the regex but will introduce a ReDOS (See #1597 for more info)
+
+ str = str.replace(display_name, '').replace(/(^<|>$)/g, ''); // sometimes need to trim the last space to get the display name
+ // because there may be a space between display name and email address
+ // eg. myname <address@gmail.com>
+ // the display name is `myname` instead of `myname `, so need to trim the last space
+
+ if (display_name.endsWith(' ')) {
+ display_name = display_name.slice(0, -1);
+ }
+
+ if (!validateDisplayName(display_name)) {
+ return false;
+ }
+ } else if (options.require_display_name) {
+ return false;
+ }
+ }
+
+ if (!options.ignore_max_length && str.length > defaultMaxEmailLength) {
+ return false;
+ }
+
+ var parts = str.split('@');
+ var domain = parts.pop();
+ var lower_domain = domain.toLowerCase();
+
+ if (options.host_blacklist.includes(lower_domain)) {
+ return false;
+ }
+
+ if (options.host_whitelist.length > 0 && !options.host_whitelist.includes(lower_domain)) {
+ return false;
+ }
+
+ var user = parts.join('@');
+
+ if (options.domain_specific_validation && (lower_domain === 'gmail.com' || lower_domain === 'googlemail.com')) {
+ /*
+ Previously we removed dots for gmail addresses before validating.
+ This was removed because it allows `multiple..dots@gmail.com`
+ to be reported as valid, but it is not.
+ Gmail only normalizes single dots, removing them from here is pointless,
+ should be done in normalizeEmail
+ */
+ user = user.toLowerCase(); // Removing sub-address from username before gmail validation
+
+ var username = user.split('+')[0]; // Dots are not included in gmail length restriction
+
+ if (!isByteLength(username.replace(/\./g, ''), {
+ min: 6,
+ max: 30
+ })) {
+ return false;
+ }
+
+ var _user_parts = username.split('.');
+
+ for (var i = 0; i < _user_parts.length; i++) {
+ if (!gmailUserPart.test(_user_parts[i])) {
+ return false;
+ }
+ }
+ }
+
+ if (options.ignore_max_length === false && (!isByteLength(user, {
+ max: 64
+ }) || !isByteLength(domain, {
+ max: 254
+ }))) {
+ return false;
+ }
+
+ if (!isFQDN(domain, {
+ require_tld: options.require_tld,
+ ignore_max_length: options.ignore_max_length
+ })) {
+ if (!options.allow_ip_domain) {
+ return false;
+ }
+
+ if (!isIP(domain)) {
+ if (!domain.startsWith('[') || !domain.endsWith(']')) {
+ return false;
+ }
+
+ var noBracketdomain = domain.slice(1, -1);
+
+ if (noBracketdomain.length === 0 || !isIP(noBracketdomain)) {
+ return false;
+ }
+ }
+ }
+
+ if (user[0] === '"') {
+ user = user.slice(1, user.length - 1);
+ return options.allow_utf8_local_part ? quotedEmailUserUtf8.test(user) : quotedEmailUser.test(user);
+ }
+
+ var pattern = options.allow_utf8_local_part ? emailUserUtf8Part : emailUserPart;
+ var user_parts = user.split('.');
+
+ for (var _i = 0; _i < user_parts.length; _i++) {
+ if (!pattern.test(user_parts[_i])) {
+ return false;
+ }
+ }
+
+ if (options.blacklisted_chars) {
+ if (user.search(new RegExp("[".concat(options.blacklisted_chars, "]+"), 'g')) !== -1) return false;
+ }
+
+ return true;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isEmpty.js b/includes/external/addressbook/node_modules/validator/es/lib/isEmpty.js
new file mode 100644
index 0000000..79e29f7
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isEmpty.js
@@ -0,0 +1,10 @@
+import assertString from './util/assertString';
+import merge from './util/merge';
+var default_is_empty_options = {
+ ignore_whitespace: false
+};
+export default function isEmpty(str, options) {
+ assertString(str);
+ options = merge(options, default_is_empty_options);
+ return (options.ignore_whitespace ? str.trim().length : str.length) === 0;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isEthereumAddress.js b/includes/external/addressbook/node_modules/validator/es/lib/isEthereumAddress.js
new file mode 100644
index 0000000..9c70f64
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isEthereumAddress.js
@@ -0,0 +1,6 @@
+import assertString from './util/assertString';
+var eth = /^(0x)[0-9a-f]{40}$/i;
+export default function isEthereumAddress(str) {
+ assertString(str);
+ return eth.test(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isFQDN.js b/includes/external/addressbook/node_modules/validator/es/lib/isFQDN.js
new file mode 100644
index 0000000..3f25e96
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isFQDN.js
@@ -0,0 +1,75 @@
+import assertString from './util/assertString';
+import merge from './util/merge';
+var default_fqdn_options = {
+ require_tld: true,
+ allow_underscores: false,
+ allow_trailing_dot: false,
+ allow_numeric_tld: false,
+ allow_wildcard: false,
+ ignore_max_length: false
+};
+export default function isFQDN(str, options) {
+ assertString(str);
+ options = merge(options, default_fqdn_options);
+ /* Remove the optional trailing dot before checking validity */
+
+ if (options.allow_trailing_dot && str[str.length - 1] === '.') {
+ str = str.substring(0, str.length - 1);
+ }
+ /* Remove the optional wildcard before checking validity */
+
+
+ if (options.allow_wildcard === true && str.indexOf('*.') === 0) {
+ str = str.substring(2);
+ }
+
+ var parts = str.split('.');
+ var tld = parts[parts.length - 1];
+
+ if (options.require_tld) {
+ // disallow fqdns without tld
+ if (parts.length < 2) {
+ return false;
+ }
+
+ if (!options.allow_numeric_tld && !/^([a-z\u00A1-\u00A8\u00AA-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]{2,}|xn[a-z0-9-]{2,})$/i.test(tld)) {
+ return false;
+ } // disallow spaces
+
+
+ if (/\s/.test(tld)) {
+ return false;
+ }
+ } // reject numeric TLDs
+
+
+ if (!options.allow_numeric_tld && /^\d+$/.test(tld)) {
+ return false;
+ }
+
+ return parts.every(function (part) {
+ if (part.length > 63 && !options.ignore_max_length) {
+ return false;
+ }
+
+ if (!/^[a-z_\u00a1-\uffff0-9-]+$/i.test(part)) {
+ return false;
+ } // disallow full-width chars
+
+
+ if (/[\uff01-\uff5e]/.test(part)) {
+ return false;
+ } // disallow parts starting or ending with hyphen
+
+
+ if (/^-|-$/.test(part)) {
+ return false;
+ }
+
+ if (!options.allow_underscores && /_/.test(part)) {
+ return false;
+ }
+
+ return true;
+ });
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isFloat.js b/includes/external/addressbook/node_modules/validator/es/lib/isFloat.js
new file mode 100644
index 0000000..43ffe60
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isFloat.js
@@ -0,0 +1,16 @@
+import assertString from './util/assertString';
+import { decimal } from './alpha';
+export default function isFloat(str, options) {
+ assertString(str);
+ options = options || {};
+
+ var _float = new RegExp("^(?:[-+])?(?:[0-9]+)?(?:\\".concat(options.locale ? decimal[options.locale] : '.', "[0-9]*)?(?:[eE][\\+\\-]?(?:[0-9]+))?$"));
+
+ if (str === '' || str === '.' || str === ',' || str === '-' || str === '+') {
+ return false;
+ }
+
+ var value = parseFloat(str.replace(',', '.'));
+ return _float.test(str) && (!options.hasOwnProperty('min') || value >= options.min) && (!options.hasOwnProperty('max') || value <= options.max) && (!options.hasOwnProperty('lt') || value < options.lt) && (!options.hasOwnProperty('gt') || value > options.gt);
+}
+export var locales = Object.keys(decimal); \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isFullWidth.js b/includes/external/addressbook/node_modules/validator/es/lib/isFullWidth.js
new file mode 100644
index 0000000..ae54629
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isFullWidth.js
@@ -0,0 +1,6 @@
+import assertString from './util/assertString';
+export var fullWidth = /[^\u0020-\u007E\uFF61-\uFF9F\uFFA0-\uFFDC\uFFE8-\uFFEE0-9a-zA-Z]/;
+export default function isFullWidth(str) {
+ assertString(str);
+ return fullWidth.test(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isHSL.js b/includes/external/addressbook/node_modules/validator/es/lib/isHSL.js
new file mode 100644
index 0000000..7efe8e9
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isHSL.js
@@ -0,0 +1,14 @@
+import assertString from './util/assertString';
+var hslComma = /^hsla?\(((\+|\-)?([0-9]+(\.[0-9]+)?(e(\+|\-)?[0-9]+)?|\.[0-9]+(e(\+|\-)?[0-9]+)?))(deg|grad|rad|turn)?(,(\+|\-)?([0-9]+(\.[0-9]+)?(e(\+|\-)?[0-9]+)?|\.[0-9]+(e(\+|\-)?[0-9]+)?)%){2}(,((\+|\-)?([0-9]+(\.[0-9]+)?(e(\+|\-)?[0-9]+)?|\.[0-9]+(e(\+|\-)?[0-9]+)?)%?))?\)$/i;
+var hslSpace = /^hsla?\(((\+|\-)?([0-9]+(\.[0-9]+)?(e(\+|\-)?[0-9]+)?|\.[0-9]+(e(\+|\-)?[0-9]+)?))(deg|grad|rad|turn)?(\s(\+|\-)?([0-9]+(\.[0-9]+)?(e(\+|\-)?[0-9]+)?|\.[0-9]+(e(\+|\-)?[0-9]+)?)%){2}\s?(\/\s((\+|\-)?([0-9]+(\.[0-9]+)?(e(\+|\-)?[0-9]+)?|\.[0-9]+(e(\+|\-)?[0-9]+)?)%?)\s?)?\)$/i;
+export default function isHSL(str) {
+ assertString(str); // Strip duplicate spaces before calling the validation regex (See #1598 for more info)
+
+ var strippedStr = str.replace(/\s+/g, ' ').replace(/\s?(hsla?\(|\)|,)\s?/ig, '$1');
+
+ if (strippedStr.indexOf(',') !== -1) {
+ return hslComma.test(strippedStr);
+ }
+
+ return hslSpace.test(strippedStr);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isHalfWidth.js b/includes/external/addressbook/node_modules/validator/es/lib/isHalfWidth.js
new file mode 100644
index 0000000..b0c8795
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isHalfWidth.js
@@ -0,0 +1,6 @@
+import assertString from './util/assertString';
+export var halfWidth = /[\u0020-\u007E\uFF61-\uFF9F\uFFA0-\uFFDC\uFFE8-\uFFEE0-9a-zA-Z]/;
+export default function isHalfWidth(str) {
+ assertString(str);
+ return halfWidth.test(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isHash.js b/includes/external/addressbook/node_modules/validator/es/lib/isHash.js
new file mode 100644
index 0000000..3495486
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isHash.js
@@ -0,0 +1,21 @@
+import assertString from './util/assertString';
+var lengths = {
+ md5: 32,
+ md4: 32,
+ sha1: 40,
+ sha256: 64,
+ sha384: 96,
+ sha512: 128,
+ ripemd128: 32,
+ ripemd160: 40,
+ tiger128: 32,
+ tiger160: 40,
+ tiger192: 48,
+ crc32: 8,
+ crc32b: 8
+};
+export default function isHash(str, algorithm) {
+ assertString(str);
+ var hash = new RegExp("^[a-fA-F0-9]{".concat(lengths[algorithm], "}$"));
+ return hash.test(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isHexColor.js b/includes/external/addressbook/node_modules/validator/es/lib/isHexColor.js
new file mode 100644
index 0000000..72eab2c
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isHexColor.js
@@ -0,0 +1,6 @@
+import assertString from './util/assertString';
+var hexcolor = /^#?([0-9A-F]{3}|[0-9A-F]{4}|[0-9A-F]{6}|[0-9A-F]{8})$/i;
+export default function isHexColor(str) {
+ assertString(str);
+ return hexcolor.test(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isHexadecimal.js b/includes/external/addressbook/node_modules/validator/es/lib/isHexadecimal.js
new file mode 100644
index 0000000..6654de4
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isHexadecimal.js
@@ -0,0 +1,6 @@
+import assertString from './util/assertString';
+var hexadecimal = /^(0x|0h)?[0-9A-F]+$/i;
+export default function isHexadecimal(str) {
+ assertString(str);
+ return hexadecimal.test(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isIBAN.js b/includes/external/addressbook/node_modules/validator/es/lib/isIBAN.js
new file mode 100644
index 0000000..0c97a01
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isIBAN.js
@@ -0,0 +1,138 @@
+import assertString from './util/assertString';
+/**
+ * List of country codes with
+ * corresponding IBAN regular expression
+ * Reference: https://en.wikipedia.org/wiki/International_Bank_Account_Number
+ */
+
+var ibanRegexThroughCountryCode = {
+ AD: /^(AD[0-9]{2})\d{8}[A-Z0-9]{12}$/,
+ AE: /^(AE[0-9]{2})\d{3}\d{16}$/,
+ AL: /^(AL[0-9]{2})\d{8}[A-Z0-9]{16}$/,
+ AT: /^(AT[0-9]{2})\d{16}$/,
+ AZ: /^(AZ[0-9]{2})[A-Z0-9]{4}\d{20}$/,
+ BA: /^(BA[0-9]{2})\d{16}$/,
+ BE: /^(BE[0-9]{2})\d{12}$/,
+ BG: /^(BG[0-9]{2})[A-Z]{4}\d{6}[A-Z0-9]{8}$/,
+ BH: /^(BH[0-9]{2})[A-Z]{4}[A-Z0-9]{14}$/,
+ BR: /^(BR[0-9]{2})\d{23}[A-Z]{1}[A-Z0-9]{1}$/,
+ BY: /^(BY[0-9]{2})[A-Z0-9]{4}\d{20}$/,
+ CH: /^(CH[0-9]{2})\d{5}[A-Z0-9]{12}$/,
+ CR: /^(CR[0-9]{2})\d{18}$/,
+ CY: /^(CY[0-9]{2})\d{8}[A-Z0-9]{16}$/,
+ CZ: /^(CZ[0-9]{2})\d{20}$/,
+ DE: /^(DE[0-9]{2})\d{18}$/,
+ DK: /^(DK[0-9]{2})\d{14}$/,
+ DO: /^(DO[0-9]{2})[A-Z]{4}\d{20}$/,
+ EE: /^(EE[0-9]{2})\d{16}$/,
+ EG: /^(EG[0-9]{2})\d{25}$/,
+ ES: /^(ES[0-9]{2})\d{20}$/,
+ FI: /^(FI[0-9]{2})\d{14}$/,
+ FO: /^(FO[0-9]{2})\d{14}$/,
+ FR: /^(FR[0-9]{2})\d{10}[A-Z0-9]{11}\d{2}$/,
+ GB: /^(GB[0-9]{2})[A-Z]{4}\d{14}$/,
+ GE: /^(GE[0-9]{2})[A-Z0-9]{2}\d{16}$/,
+ GI: /^(GI[0-9]{2})[A-Z]{4}[A-Z0-9]{15}$/,
+ GL: /^(GL[0-9]{2})\d{14}$/,
+ GR: /^(GR[0-9]{2})\d{7}[A-Z0-9]{16}$/,
+ GT: /^(GT[0-9]{2})[A-Z0-9]{4}[A-Z0-9]{20}$/,
+ HR: /^(HR[0-9]{2})\d{17}$/,
+ HU: /^(HU[0-9]{2})\d{24}$/,
+ IE: /^(IE[0-9]{2})[A-Z0-9]{4}\d{14}$/,
+ IL: /^(IL[0-9]{2})\d{19}$/,
+ IQ: /^(IQ[0-9]{2})[A-Z]{4}\d{15}$/,
+ IR: /^(IR[0-9]{2})0\d{2}0\d{18}$/,
+ IS: /^(IS[0-9]{2})\d{22}$/,
+ IT: /^(IT[0-9]{2})[A-Z]{1}\d{10}[A-Z0-9]{12}$/,
+ JO: /^(JO[0-9]{2})[A-Z]{4}\d{22}$/,
+ KW: /^(KW[0-9]{2})[A-Z]{4}[A-Z0-9]{22}$/,
+ KZ: /^(KZ[0-9]{2})\d{3}[A-Z0-9]{13}$/,
+ LB: /^(LB[0-9]{2})\d{4}[A-Z0-9]{20}$/,
+ LC: /^(LC[0-9]{2})[A-Z]{4}[A-Z0-9]{24}$/,
+ LI: /^(LI[0-9]{2})\d{5}[A-Z0-9]{12}$/,
+ LT: /^(LT[0-9]{2})\d{16}$/,
+ LU: /^(LU[0-9]{2})\d{3}[A-Z0-9]{13}$/,
+ LV: /^(LV[0-9]{2})[A-Z]{4}[A-Z0-9]{13}$/,
+ MC: /^(MC[0-9]{2})\d{10}[A-Z0-9]{11}\d{2}$/,
+ MD: /^(MD[0-9]{2})[A-Z0-9]{20}$/,
+ ME: /^(ME[0-9]{2})\d{18}$/,
+ MK: /^(MK[0-9]{2})\d{3}[A-Z0-9]{10}\d{2}$/,
+ MR: /^(MR[0-9]{2})\d{23}$/,
+ MT: /^(MT[0-9]{2})[A-Z]{4}\d{5}[A-Z0-9]{18}$/,
+ MU: /^(MU[0-9]{2})[A-Z]{4}\d{19}[A-Z]{3}$/,
+ MZ: /^(MZ[0-9]{2})\d{21}$/,
+ NL: /^(NL[0-9]{2})[A-Z]{4}\d{10}$/,
+ NO: /^(NO[0-9]{2})\d{11}$/,
+ PK: /^(PK[0-9]{2})[A-Z0-9]{4}\d{16}$/,
+ PL: /^(PL[0-9]{2})\d{24}$/,
+ PS: /^(PS[0-9]{2})[A-Z0-9]{4}\d{21}$/,
+ PT: /^(PT[0-9]{2})\d{21}$/,
+ QA: /^(QA[0-9]{2})[A-Z]{4}[A-Z0-9]{21}$/,
+ RO: /^(RO[0-9]{2})[A-Z]{4}[A-Z0-9]{16}$/,
+ RS: /^(RS[0-9]{2})\d{18}$/,
+ SA: /^(SA[0-9]{2})\d{2}[A-Z0-9]{18}$/,
+ SC: /^(SC[0-9]{2})[A-Z]{4}\d{20}[A-Z]{3}$/,
+ SE: /^(SE[0-9]{2})\d{20}$/,
+ SI: /^(SI[0-9]{2})\d{15}$/,
+ SK: /^(SK[0-9]{2})\d{20}$/,
+ SM: /^(SM[0-9]{2})[A-Z]{1}\d{10}[A-Z0-9]{12}$/,
+ SV: /^(SV[0-9]{2})[A-Z0-9]{4}\d{20}$/,
+ TL: /^(TL[0-9]{2})\d{19}$/,
+ TN: /^(TN[0-9]{2})\d{20}$/,
+ TR: /^(TR[0-9]{2})\d{5}[A-Z0-9]{17}$/,
+ UA: /^(UA[0-9]{2})\d{6}[A-Z0-9]{19}$/,
+ VA: /^(VA[0-9]{2})\d{18}$/,
+ VG: /^(VG[0-9]{2})[A-Z0-9]{4}\d{16}$/,
+ XK: /^(XK[0-9]{2})\d{16}$/
+};
+/**
+ * Check whether string has correct universal IBAN format
+ * The IBAN consists of up to 34 alphanumeric characters, as follows:
+ * Country Code using ISO 3166-1 alpha-2, two letters
+ * check digits, two digits and
+ * Basic Bank Account Number (BBAN), up to 30 alphanumeric characters.
+ * NOTE: Permitted IBAN characters are: digits [0-9] and the 26 latin alphabetic [A-Z]
+ *
+ * @param {string} str - string under validation
+ * @return {boolean}
+ */
+
+function hasValidIbanFormat(str) {
+ // Strip white spaces and hyphens
+ var strippedStr = str.replace(/[\s\-]+/gi, '').toUpperCase();
+ var isoCountryCode = strippedStr.slice(0, 2).toUpperCase();
+ return isoCountryCode in ibanRegexThroughCountryCode && ibanRegexThroughCountryCode[isoCountryCode].test(strippedStr);
+}
+/**
+ * Check whether string has valid IBAN Checksum
+ * by performing basic mod-97 operation and
+ * the remainder should equal 1
+ * -- Start by rearranging the IBAN by moving the four initial characters to the end of the string
+ * -- Replace each letter in the string with two digits, A -> 10, B = 11, Z = 35
+ * -- Interpret the string as a decimal integer and
+ * -- compute the remainder on division by 97 (mod 97)
+ * Reference: https://en.wikipedia.org/wiki/International_Bank_Account_Number
+ *
+ * @param {string} str
+ * @return {boolean}
+ */
+
+
+function hasValidIbanChecksum(str) {
+ var strippedStr = str.replace(/[^A-Z0-9]+/gi, '').toUpperCase(); // Keep only digits and A-Z latin alphabetic
+
+ var rearranged = strippedStr.slice(4) + strippedStr.slice(0, 4);
+ var alphaCapsReplacedWithDigits = rearranged.replace(/[A-Z]/g, function (_char) {
+ return _char.charCodeAt(0) - 55;
+ });
+ var remainder = alphaCapsReplacedWithDigits.match(/\d{1,7}/g).reduce(function (acc, value) {
+ return Number(acc + value) % 97;
+ }, '');
+ return remainder === 1;
+}
+
+export default function isIBAN(str) {
+ assertString(str);
+ return hasValidIbanFormat(str) && hasValidIbanChecksum(str);
+}
+export var locales = Object.keys(ibanRegexThroughCountryCode); \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isIMEI.js b/includes/external/addressbook/node_modules/validator/es/lib/isIMEI.js
new file mode 100644
index 0000000..27bd09d
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isIMEI.js
@@ -0,0 +1,47 @@
+import assertString from './util/assertString';
+var imeiRegexWithoutHypens = /^[0-9]{15}$/;
+var imeiRegexWithHypens = /^\d{2}-\d{6}-\d{6}-\d{1}$/;
+export default function isIMEI(str, options) {
+ assertString(str);
+ options = options || {}; // default regex for checking imei is the one without hyphens
+
+ var imeiRegex = imeiRegexWithoutHypens;
+
+ if (options.allow_hyphens) {
+ imeiRegex = imeiRegexWithHypens;
+ }
+
+ if (!imeiRegex.test(str)) {
+ return false;
+ }
+
+ str = str.replace(/-/g, '');
+ var sum = 0,
+ mul = 2,
+ l = 14;
+
+ for (var i = 0; i < l; i++) {
+ var digit = str.substring(l - i - 1, l - i);
+ var tp = parseInt(digit, 10) * mul;
+
+ if (tp >= 10) {
+ sum += tp % 10 + 1;
+ } else {
+ sum += tp;
+ }
+
+ if (mul === 1) {
+ mul += 1;
+ } else {
+ mul -= 1;
+ }
+ }
+
+ var chk = (10 - sum % 10) % 10;
+
+ if (chk !== parseInt(str.substring(14, 15), 10)) {
+ return false;
+ }
+
+ return true;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isIP.js b/includes/external/addressbook/node_modules/validator/es/lib/isIP.js
new file mode 100644
index 0000000..51826db
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isIP.js
@@ -0,0 +1,55 @@
+import assertString from './util/assertString';
+/**
+11.3. Examples
+
+ The following addresses
+
+ fe80::1234 (on the 1st link of the node)
+ ff02::5678 (on the 5th link of the node)
+ ff08::9abc (on the 10th organization of the node)
+
+ would be represented as follows:
+
+ fe80::1234%1
+ ff02::5678%5
+ ff08::9abc%10
+
+ (Here we assume a natural translation from a zone index to the
+ <zone_id> part, where the Nth zone of any scope is translated into
+ "N".)
+
+ If we use interface names as <zone_id>, those addresses could also be
+ represented as follows:
+
+ fe80::1234%ne0
+ ff02::5678%pvc1.3
+ ff08::9abc%interface10
+
+ where the interface "ne0" belongs to the 1st link, "pvc1.3" belongs
+ to the 5th link, and "interface10" belongs to the 10th organization.
+ * * */
+
+var IPv4SegmentFormat = '(?:[0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])';
+var IPv4AddressFormat = "(".concat(IPv4SegmentFormat, "[.]){3}").concat(IPv4SegmentFormat);
+var IPv4AddressRegExp = new RegExp("^".concat(IPv4AddressFormat, "$"));
+var IPv6SegmentFormat = '(?:[0-9a-fA-F]{1,4})';
+var IPv6AddressRegExp = new RegExp('^(' + "(?:".concat(IPv6SegmentFormat, ":){7}(?:").concat(IPv6SegmentFormat, "|:)|") + "(?:".concat(IPv6SegmentFormat, ":){6}(?:").concat(IPv4AddressFormat, "|:").concat(IPv6SegmentFormat, "|:)|") + "(?:".concat(IPv6SegmentFormat, ":){5}(?::").concat(IPv4AddressFormat, "|(:").concat(IPv6SegmentFormat, "){1,2}|:)|") + "(?:".concat(IPv6SegmentFormat, ":){4}(?:(:").concat(IPv6SegmentFormat, "){0,1}:").concat(IPv4AddressFormat, "|(:").concat(IPv6SegmentFormat, "){1,3}|:)|") + "(?:".concat(IPv6SegmentFormat, ":){3}(?:(:").concat(IPv6SegmentFormat, "){0,2}:").concat(IPv4AddressFormat, "|(:").concat(IPv6SegmentFormat, "){1,4}|:)|") + "(?:".concat(IPv6SegmentFormat, ":){2}(?:(:").concat(IPv6SegmentFormat, "){0,3}:").concat(IPv4AddressFormat, "|(:").concat(IPv6SegmentFormat, "){1,5}|:)|") + "(?:".concat(IPv6SegmentFormat, ":){1}(?:(:").concat(IPv6SegmentFormat, "){0,4}:").concat(IPv4AddressFormat, "|(:").concat(IPv6SegmentFormat, "){1,6}|:)|") + "(?::((?::".concat(IPv6SegmentFormat, "){0,5}:").concat(IPv4AddressFormat, "|(?::").concat(IPv6SegmentFormat, "){1,7}|:))") + ')(%[0-9a-zA-Z-.:]{1,})?$');
+export default function isIP(str) {
+ var version = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';
+ assertString(str);
+ version = String(version);
+
+ if (!version) {
+ return isIP(str, 4) || isIP(str, 6);
+ }
+
+ if (version === '4') {
+ return IPv4AddressRegExp.test(str);
+ }
+
+ if (version === '6') {
+ return IPv6AddressRegExp.test(str);
+ }
+
+ return false;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isIPRange.js b/includes/external/addressbook/node_modules/validator/es/lib/isIPRange.js
new file mode 100644
index 0000000..209efdd
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isIPRange.js
@@ -0,0 +1,47 @@
+import assertString from './util/assertString';
+import isIP from './isIP';
+var subnetMaybe = /^\d{1,3}$/;
+var v4Subnet = 32;
+var v6Subnet = 128;
+export default function isIPRange(str) {
+ var version = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';
+ assertString(str);
+ var parts = str.split('/'); // parts[0] -> ip, parts[1] -> subnet
+
+ if (parts.length !== 2) {
+ return false;
+ }
+
+ if (!subnetMaybe.test(parts[1])) {
+ return false;
+ } // Disallow preceding 0 i.e. 01, 02, ...
+
+
+ if (parts[1].length > 1 && parts[1].startsWith('0')) {
+ return false;
+ }
+
+ var isValidIP = isIP(parts[0], version);
+
+ if (!isValidIP) {
+ return false;
+ } // Define valid subnet according to IP's version
+
+
+ var expectedSubnet = null;
+
+ switch (String(version)) {
+ case '4':
+ expectedSubnet = v4Subnet;
+ break;
+
+ case '6':
+ expectedSubnet = v6Subnet;
+ break;
+
+ default:
+ expectedSubnet = isIP(parts[0], '6') ? v6Subnet : v4Subnet;
+ }
+
+ return parts[1] <= expectedSubnet && parts[1] >= 0;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isISBN.js b/includes/external/addressbook/node_modules/validator/es/lib/isISBN.js
new file mode 100644
index 0000000..5c92870
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isISBN.js
@@ -0,0 +1,55 @@
+import assertString from './util/assertString';
+var possibleIsbn10 = /^(?:[0-9]{9}X|[0-9]{10})$/;
+var possibleIsbn13 = /^(?:[0-9]{13})$/;
+var factor = [1, 3];
+export default function isISBN(isbn, options) {
+ assertString(isbn); // For backwards compatibility:
+ // isISBN(str [, version]), i.e. `options` could be used as argument for the legacy `version`
+
+ var version = String((options === null || options === void 0 ? void 0 : options.version) || options);
+
+ if (!(options !== null && options !== void 0 && options.version || options)) {
+ return isISBN(isbn, {
+ version: 10
+ }) || isISBN(isbn, {
+ version: 13
+ });
+ }
+
+ var sanitizedIsbn = isbn.replace(/[\s-]+/g, '');
+ var checksum = 0;
+
+ if (version === '10') {
+ if (!possibleIsbn10.test(sanitizedIsbn)) {
+ return false;
+ }
+
+ for (var i = 0; i < version - 1; i++) {
+ checksum += (i + 1) * sanitizedIsbn.charAt(i);
+ }
+
+ if (sanitizedIsbn.charAt(9) === 'X') {
+ checksum += 10 * 10;
+ } else {
+ checksum += 10 * sanitizedIsbn.charAt(9);
+ }
+
+ if (checksum % 11 === 0) {
+ return true;
+ }
+ } else if (version === '13') {
+ if (!possibleIsbn13.test(sanitizedIsbn)) {
+ return false;
+ }
+
+ for (var _i = 0; _i < 12; _i++) {
+ checksum += factor[_i % 2] * sanitizedIsbn.charAt(_i);
+ }
+
+ if (sanitizedIsbn.charAt(12) - (10 - checksum % 10) % 10 === 0) {
+ return true;
+ }
+ }
+
+ return false;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isISIN.js b/includes/external/addressbook/node_modules/validator/es/lib/isISIN.js
new file mode 100644
index 0000000..8e5b826
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isISIN.js
@@ -0,0 +1,60 @@
+import assertString from './util/assertString';
+var isin = /^[A-Z]{2}[0-9A-Z]{9}[0-9]$/; // this link details how the check digit is calculated:
+// https://www.isin.org/isin-format/. it is a little bit
+// odd in that it works with digits, not numbers. in order
+// to make only one pass through the ISIN characters, the
+// each alpha character is handled as 2 characters within
+// the loop.
+
+export default function isISIN(str) {
+ assertString(str);
+
+ if (!isin.test(str)) {
+ return false;
+ }
+
+ var _double = true;
+ var sum = 0; // convert values
+
+ for (var i = str.length - 2; i >= 0; i--) {
+ if (str[i] >= 'A' && str[i] <= 'Z') {
+ var value = str[i].charCodeAt(0) - 55;
+ var lo = value % 10;
+ var hi = Math.trunc(value / 10); // letters have two digits, so handle the low order
+ // and high order digits separately.
+
+ for (var _i = 0, _arr = [lo, hi]; _i < _arr.length; _i++) {
+ var digit = _arr[_i];
+
+ if (_double) {
+ if (digit >= 5) {
+ sum += 1 + (digit - 5) * 2;
+ } else {
+ sum += digit * 2;
+ }
+ } else {
+ sum += digit;
+ }
+
+ _double = !_double;
+ }
+ } else {
+ var _digit = str[i].charCodeAt(0) - '0'.charCodeAt(0);
+
+ if (_double) {
+ if (_digit >= 5) {
+ sum += 1 + (_digit - 5) * 2;
+ } else {
+ sum += _digit * 2;
+ }
+ } else {
+ sum += _digit;
+ }
+
+ _double = !_double;
+ }
+ }
+
+ var check = Math.trunc((sum + 9) / 10) * 10 - sum;
+ return +str[str.length - 1] === check;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isISO31661Alpha2.js b/includes/external/addressbook/node_modules/validator/es/lib/isISO31661Alpha2.js
new file mode 100644
index 0000000..e8db93e
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isISO31661Alpha2.js
@@ -0,0 +1,8 @@
+import assertString from './util/assertString'; // from https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2
+
+var validISO31661Alpha2CountriesCodes = new Set(['AD', 'AE', 'AF', 'AG', 'AI', 'AL', 'AM', 'AO', 'AQ', 'AR', 'AS', 'AT', 'AU', 'AW', 'AX', 'AZ', 'BA', 'BB', 'BD', 'BE', 'BF', 'BG', 'BH', 'BI', 'BJ', 'BL', 'BM', 'BN', 'BO', 'BQ', 'BR', 'BS', 'BT', 'BV', 'BW', 'BY', 'BZ', 'CA', 'CC', 'CD', 'CF', 'CG', 'CH', 'CI', 'CK', 'CL', 'CM', 'CN', 'CO', 'CR', 'CU', 'CV', 'CW', 'CX', 'CY', 'CZ', 'DE', 'DJ', 'DK', 'DM', 'DO', 'DZ', 'EC', 'EE', 'EG', 'EH', 'ER', 'ES', 'ET', 'FI', 'FJ', 'FK', 'FM', 'FO', 'FR', 'GA', 'GB', 'GD', 'GE', 'GF', 'GG', 'GH', 'GI', 'GL', 'GM', 'GN', 'GP', 'GQ', 'GR', 'GS', 'GT', 'GU', 'GW', 'GY', 'HK', 'HM', 'HN', 'HR', 'HT', 'HU', 'ID', 'IE', 'IL', 'IM', 'IN', 'IO', 'IQ', 'IR', 'IS', 'IT', 'JE', 'JM', 'JO', 'JP', 'KE', 'KG', 'KH', 'KI', 'KM', 'KN', 'KP', 'KR', 'KW', 'KY', 'KZ', 'LA', 'LB', 'LC', 'LI', 'LK', 'LR', 'LS', 'LT', 'LU', 'LV', 'LY', 'MA', 'MC', 'MD', 'ME', 'MF', 'MG', 'MH', 'MK', 'ML', 'MM', 'MN', 'MO', 'MP', 'MQ', 'MR', 'MS', 'MT', 'MU', 'MV', 'MW', 'MX', 'MY', 'MZ', 'NA', 'NC', 'NE', 'NF', 'NG', 'NI', 'NL', 'NO', 'NP', 'NR', 'NU', 'NZ', 'OM', 'PA', 'PE', 'PF', 'PG', 'PH', 'PK', 'PL', 'PM', 'PN', 'PR', 'PS', 'PT', 'PW', 'PY', 'QA', 'RE', 'RO', 'RS', 'RU', 'RW', 'SA', 'SB', 'SC', 'SD', 'SE', 'SG', 'SH', 'SI', 'SJ', 'SK', 'SL', 'SM', 'SN', 'SO', 'SR', 'SS', 'ST', 'SV', 'SX', 'SY', 'SZ', 'TC', 'TD', 'TF', 'TG', 'TH', 'TJ', 'TK', 'TL', 'TM', 'TN', 'TO', 'TR', 'TT', 'TV', 'TW', 'TZ', 'UA', 'UG', 'UM', 'US', 'UY', 'UZ', 'VA', 'VC', 'VE', 'VG', 'VI', 'VN', 'VU', 'WF', 'WS', 'YE', 'YT', 'ZA', 'ZM', 'ZW']);
+export default function isISO31661Alpha2(str) {
+ assertString(str);
+ return validISO31661Alpha2CountriesCodes.has(str.toUpperCase());
+}
+export var CountryCodes = validISO31661Alpha2CountriesCodes; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isISO31661Alpha3.js b/includes/external/addressbook/node_modules/validator/es/lib/isISO31661Alpha3.js
new file mode 100644
index 0000000..41a615b
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isISO31661Alpha3.js
@@ -0,0 +1,7 @@
+import assertString from './util/assertString'; // from https://en.wikipedia.org/wiki/ISO_3166-1_alpha-3
+
+var validISO31661Alpha3CountriesCodes = new Set(['AFG', 'ALA', 'ALB', 'DZA', 'ASM', 'AND', 'AGO', 'AIA', 'ATA', 'ATG', 'ARG', 'ARM', 'ABW', 'AUS', 'AUT', 'AZE', 'BHS', 'BHR', 'BGD', 'BRB', 'BLR', 'BEL', 'BLZ', 'BEN', 'BMU', 'BTN', 'BOL', 'BES', 'BIH', 'BWA', 'BVT', 'BRA', 'IOT', 'BRN', 'BGR', 'BFA', 'BDI', 'KHM', 'CMR', 'CAN', 'CPV', 'CYM', 'CAF', 'TCD', 'CHL', 'CHN', 'CXR', 'CCK', 'COL', 'COM', 'COG', 'COD', 'COK', 'CRI', 'CIV', 'HRV', 'CUB', 'CUW', 'CYP', 'CZE', 'DNK', 'DJI', 'DMA', 'DOM', 'ECU', 'EGY', 'SLV', 'GNQ', 'ERI', 'EST', 'ETH', 'FLK', 'FRO', 'FJI', 'FIN', 'FRA', 'GUF', 'PYF', 'ATF', 'GAB', 'GMB', 'GEO', 'DEU', 'GHA', 'GIB', 'GRC', 'GRL', 'GRD', 'GLP', 'GUM', 'GTM', 'GGY', 'GIN', 'GNB', 'GUY', 'HTI', 'HMD', 'VAT', 'HND', 'HKG', 'HUN', 'ISL', 'IND', 'IDN', 'IRN', 'IRQ', 'IRL', 'IMN', 'ISR', 'ITA', 'JAM', 'JPN', 'JEY', 'JOR', 'KAZ', 'KEN', 'KIR', 'PRK', 'KOR', 'KWT', 'KGZ', 'LAO', 'LVA', 'LBN', 'LSO', 'LBR', 'LBY', 'LIE', 'LTU', 'LUX', 'MAC', 'MKD', 'MDG', 'MWI', 'MYS', 'MDV', 'MLI', 'MLT', 'MHL', 'MTQ', 'MRT', 'MUS', 'MYT', 'MEX', 'FSM', 'MDA', 'MCO', 'MNG', 'MNE', 'MSR', 'MAR', 'MOZ', 'MMR', 'NAM', 'NRU', 'NPL', 'NLD', 'NCL', 'NZL', 'NIC', 'NER', 'NGA', 'NIU', 'NFK', 'MNP', 'NOR', 'OMN', 'PAK', 'PLW', 'PSE', 'PAN', 'PNG', 'PRY', 'PER', 'PHL', 'PCN', 'POL', 'PRT', 'PRI', 'QAT', 'REU', 'ROU', 'RUS', 'RWA', 'BLM', 'SHN', 'KNA', 'LCA', 'MAF', 'SPM', 'VCT', 'WSM', 'SMR', 'STP', 'SAU', 'SEN', 'SRB', 'SYC', 'SLE', 'SGP', 'SXM', 'SVK', 'SVN', 'SLB', 'SOM', 'ZAF', 'SGS', 'SSD', 'ESP', 'LKA', 'SDN', 'SUR', 'SJM', 'SWZ', 'SWE', 'CHE', 'SYR', 'TWN', 'TJK', 'TZA', 'THA', 'TLS', 'TGO', 'TKL', 'TON', 'TTO', 'TUN', 'TUR', 'TKM', 'TCA', 'TUV', 'UGA', 'UKR', 'ARE', 'GBR', 'USA', 'UMI', 'URY', 'UZB', 'VUT', 'VEN', 'VNM', 'VGB', 'VIR', 'WLF', 'ESH', 'YEM', 'ZMB', 'ZWE']);
+export default function isISO31661Alpha3(str) {
+ assertString(str);
+ return validISO31661Alpha3CountriesCodes.has(str.toUpperCase());
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isISO4217.js b/includes/external/addressbook/node_modules/validator/es/lib/isISO4217.js
new file mode 100644
index 0000000..3033a04
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isISO4217.js
@@ -0,0 +1,8 @@
+import assertString from './util/assertString'; // from https://en.wikipedia.org/wiki/ISO_4217
+
+var validISO4217CurrencyCodes = new Set(['AED', 'AFN', 'ALL', 'AMD', 'ANG', 'AOA', 'ARS', 'AUD', 'AWG', 'AZN', 'BAM', 'BBD', 'BDT', 'BGN', 'BHD', 'BIF', 'BMD', 'BND', 'BOB', 'BOV', 'BRL', 'BSD', 'BTN', 'BWP', 'BYN', 'BZD', 'CAD', 'CDF', 'CHE', 'CHF', 'CHW', 'CLF', 'CLP', 'CNY', 'COP', 'COU', 'CRC', 'CUC', 'CUP', 'CVE', 'CZK', 'DJF', 'DKK', 'DOP', 'DZD', 'EGP', 'ERN', 'ETB', 'EUR', 'FJD', 'FKP', 'GBP', 'GEL', 'GHS', 'GIP', 'GMD', 'GNF', 'GTQ', 'GYD', 'HKD', 'HNL', 'HRK', 'HTG', 'HUF', 'IDR', 'ILS', 'INR', 'IQD', 'IRR', 'ISK', 'JMD', 'JOD', 'JPY', 'KES', 'KGS', 'KHR', 'KMF', 'KPW', 'KRW', 'KWD', 'KYD', 'KZT', 'LAK', 'LBP', 'LKR', 'LRD', 'LSL', 'LYD', 'MAD', 'MDL', 'MGA', 'MKD', 'MMK', 'MNT', 'MOP', 'MRU', 'MUR', 'MVR', 'MWK', 'MXN', 'MXV', 'MYR', 'MZN', 'NAD', 'NGN', 'NIO', 'NOK', 'NPR', 'NZD', 'OMR', 'PAB', 'PEN', 'PGK', 'PHP', 'PKR', 'PLN', 'PYG', 'QAR', 'RON', 'RSD', 'RUB', 'RWF', 'SAR', 'SBD', 'SCR', 'SDG', 'SEK', 'SGD', 'SHP', 'SLL', 'SOS', 'SRD', 'SSP', 'STN', 'SVC', 'SYP', 'SZL', 'THB', 'TJS', 'TMT', 'TND', 'TOP', 'TRY', 'TTD', 'TWD', 'TZS', 'UAH', 'UGX', 'USD', 'USN', 'UYI', 'UYU', 'UYW', 'UZS', 'VES', 'VND', 'VUV', 'WST', 'XAF', 'XAG', 'XAU', 'XBA', 'XBB', 'XBC', 'XBD', 'XCD', 'XDR', 'XOF', 'XPD', 'XPF', 'XPT', 'XSU', 'XTS', 'XUA', 'XXX', 'YER', 'ZAR', 'ZMW', 'ZWL']);
+export default function isISO4217(str) {
+ assertString(str);
+ return validISO4217CurrencyCodes.has(str.toUpperCase());
+}
+export var CurrencyCodes = validISO4217CurrencyCodes; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isISO6391.js b/includes/external/addressbook/node_modules/validator/es/lib/isISO6391.js
new file mode 100644
index 0000000..5f7d4ea
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isISO6391.js
@@ -0,0 +1,6 @@
+import assertString from './util/assertString';
+var isISO6391Set = new Set(['aa', 'ab', 'ae', 'af', 'ak', 'am', 'an', 'ar', 'as', 'av', 'ay', 'az', 'az', 'ba', 'be', 'bg', 'bh', 'bi', 'bm', 'bn', 'bo', 'br', 'bs', 'ca', 'ce', 'ch', 'co', 'cr', 'cs', 'cu', 'cv', 'cy', 'da', 'de', 'dv', 'dz', 'ee', 'el', 'en', 'eo', 'es', 'et', 'eu', 'fa', 'ff', 'fi', 'fj', 'fo', 'fr', 'fy', 'ga', 'gd', 'gl', 'gn', 'gu', 'gv', 'ha', 'he', 'hi', 'ho', 'hr', 'ht', 'hu', 'hy', 'hz', 'ia', 'id', 'ie', 'ig', 'ii', 'ik', 'io', 'is', 'it', 'iu', 'ja', 'jv', 'ka', 'kg', 'ki', 'kj', 'kk', 'kl', 'km', 'kn', 'ko', 'kr', 'ks', 'ku', 'kv', 'kw', 'ky', 'la', 'lb', 'lg', 'li', 'ln', 'lo', 'lt', 'lu', 'lv', 'mg', 'mh', 'mi', 'mk', 'ml', 'mn', 'mr', 'ms', 'mt', 'my', 'na', 'nb', 'nd', 'ne', 'ng', 'nl', 'nn', 'no', 'nr', 'nv', 'ny', 'oc', 'oj', 'om', 'or', 'os', 'pa', 'pi', 'pl', 'ps', 'pt', 'qu', 'rm', 'rn', 'ro', 'ru', 'rw', 'sa', 'sc', 'sd', 'se', 'sg', 'si', 'sk', 'sl', 'sm', 'sn', 'so', 'sq', 'sr', 'ss', 'st', 'su', 'sv', 'sw', 'ta', 'te', 'tg', 'th', 'ti', 'tk', 'tl', 'tn', 'to', 'tr', 'ts', 'tt', 'tw', 'ty', 'ug', 'uk', 'ur', 'uz', 've', 'vi', 'vo', 'wa', 'wo', 'xh', 'yi', 'yo', 'za', 'zh', 'zu']);
+export default function isISO6391(str) {
+ assertString(str);
+ return isISO6391Set.has(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isISO8601.js b/includes/external/addressbook/node_modules/validator/es/lib/isISO8601.js
new file mode 100644
index 0000000..8e71215
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isISO8601.js
@@ -0,0 +1,47 @@
+import assertString from './util/assertString';
+/* eslint-disable max-len */
+// from http://goo.gl/0ejHHW
+
+var iso8601 = /^([\+-]?\d{4}(?!\d{2}\b))((-?)((0[1-9]|1[0-2])(\3([12]\d|0[1-9]|3[01]))?|W([0-4]\d|5[0-3])(-?[1-7])?|(00[1-9]|0[1-9]\d|[12]\d{2}|3([0-5]\d|6[1-6])))([T\s]((([01]\d|2[0-3])((:?)[0-5]\d)?|24:?00)([\.,]\d+(?!:))?)?(\17[0-5]\d([\.,]\d+)?)?([zZ]|([\+-])([01]\d|2[0-3]):?([0-5]\d)?)?)?)?$/; // same as above, except with a strict 'T' separator between date and time
+
+var iso8601StrictSeparator = /^([\+-]?\d{4}(?!\d{2}\b))((-?)((0[1-9]|1[0-2])(\3([12]\d|0[1-9]|3[01]))?|W([0-4]\d|5[0-3])(-?[1-7])?|(00[1-9]|0[1-9]\d|[12]\d{2}|3([0-5]\d|6[1-6])))([T]((([01]\d|2[0-3])((:?)[0-5]\d)?|24:?00)([\.,]\d+(?!:))?)?(\17[0-5]\d([\.,]\d+)?)?([zZ]|([\+-])([01]\d|2[0-3]):?([0-5]\d)?)?)?)?$/;
+/* eslint-enable max-len */
+
+var isValidDate = function isValidDate(str) {
+ // str must have passed the ISO8601 check
+ // this check is meant to catch invalid dates
+ // like 2009-02-31
+ // first check for ordinal dates
+ var ordinalMatch = str.match(/^(\d{4})-?(\d{3})([ T]{1}\.*|$)/);
+
+ if (ordinalMatch) {
+ var oYear = Number(ordinalMatch[1]);
+ var oDay = Number(ordinalMatch[2]); // if is leap year
+
+ if (oYear % 4 === 0 && oYear % 100 !== 0 || oYear % 400 === 0) return oDay <= 366;
+ return oDay <= 365;
+ }
+
+ var match = str.match(/(\d{4})-?(\d{0,2})-?(\d*)/).map(Number);
+ var year = match[1];
+ var month = match[2];
+ var day = match[3];
+ var monthString = month ? "0".concat(month).slice(-2) : month;
+ var dayString = day ? "0".concat(day).slice(-2) : day; // create a date object and compare
+
+ var d = new Date("".concat(year, "-").concat(monthString || '01', "-").concat(dayString || '01'));
+
+ if (month && day) {
+ return d.getUTCFullYear() === year && d.getUTCMonth() + 1 === month && d.getUTCDate() === day;
+ }
+
+ return true;
+};
+
+export default function isISO8601(str) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ assertString(str);
+ var check = options.strictSeparator ? iso8601StrictSeparator.test(str) : iso8601.test(str);
+ if (check && options.strict) return isValidDate(str);
+ return check;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isISRC.js b/includes/external/addressbook/node_modules/validator/es/lib/isISRC.js
new file mode 100644
index 0000000..275c10a
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isISRC.js
@@ -0,0 +1,7 @@
+import assertString from './util/assertString'; // see http://isrc.ifpi.org/en/isrc-standard/code-syntax
+
+var isrc = /^[A-Z]{2}[0-9A-Z]{3}\d{2}\d{5}$/;
+export default function isISRC(str) {
+ assertString(str);
+ return isrc.test(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isISSN.js b/includes/external/addressbook/node_modules/validator/es/lib/isISSN.js
new file mode 100644
index 0000000..bebfa9e
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isISSN.js
@@ -0,0 +1,23 @@
+import assertString from './util/assertString';
+var issn = '^\\d{4}-?\\d{3}[\\dX]$';
+export default function isISSN(str) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ assertString(str);
+ var testIssn = issn;
+ testIssn = options.require_hyphen ? testIssn.replace('?', '') : testIssn;
+ testIssn = options.case_sensitive ? new RegExp(testIssn) : new RegExp(testIssn, 'i');
+
+ if (!testIssn.test(str)) {
+ return false;
+ }
+
+ var digits = str.replace('-', '').toUpperCase();
+ var checksum = 0;
+
+ for (var i = 0; i < digits.length; i++) {
+ var digit = digits[i];
+ checksum += (digit === 'X' ? 10 : +digit) * (8 - i);
+ }
+
+ return checksum % 11 === 0;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isIdentityCard.js b/includes/external/addressbook/node_modules/validator/es/lib/isIdentityCard.js
new file mode 100644
index 0000000..5ddc04b
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isIdentityCard.js
@@ -0,0 +1,395 @@
+import assertString from './util/assertString';
+import isInt from './isInt';
+var validators = {
+ PL: function PL(str) {
+ assertString(str);
+ var weightOfDigits = {
+ 1: 1,
+ 2: 3,
+ 3: 7,
+ 4: 9,
+ 5: 1,
+ 6: 3,
+ 7: 7,
+ 8: 9,
+ 9: 1,
+ 10: 3,
+ 11: 0
+ };
+
+ if (str != null && str.length === 11 && isInt(str, {
+ allow_leading_zeroes: true
+ })) {
+ var digits = str.split('').slice(0, -1);
+ var sum = digits.reduce(function (acc, digit, index) {
+ return acc + Number(digit) * weightOfDigits[index + 1];
+ }, 0);
+ var modulo = sum % 10;
+ var lastDigit = Number(str.charAt(str.length - 1));
+
+ if (modulo === 0 && lastDigit === 0 || lastDigit === 10 - modulo) {
+ return true;
+ }
+ }
+
+ return false;
+ },
+ ES: function ES(str) {
+ assertString(str);
+ var DNI = /^[0-9X-Z][0-9]{7}[TRWAGMYFPDXBNJZSQVHLCKE]$/;
+ var charsValue = {
+ X: 0,
+ Y: 1,
+ Z: 2
+ };
+ var controlDigits = ['T', 'R', 'W', 'A', 'G', 'M', 'Y', 'F', 'P', 'D', 'X', 'B', 'N', 'J', 'Z', 'S', 'Q', 'V', 'H', 'L', 'C', 'K', 'E']; // sanitize user input
+
+ var sanitized = str.trim().toUpperCase(); // validate the data structure
+
+ if (!DNI.test(sanitized)) {
+ return false;
+ } // validate the control digit
+
+
+ var number = sanitized.slice(0, -1).replace(/[X,Y,Z]/g, function (_char) {
+ return charsValue[_char];
+ });
+ return sanitized.endsWith(controlDigits[number % 23]);
+ },
+ FI: function FI(str) {
+ // https://dvv.fi/en/personal-identity-code#:~:text=control%20character%20for%20a-,personal,-identity%20code%20calculated
+ assertString(str);
+
+ if (str.length !== 11) {
+ return false;
+ }
+
+ if (!str.match(/^\d{6}[\-A\+]\d{3}[0-9ABCDEFHJKLMNPRSTUVWXY]{1}$/)) {
+ return false;
+ }
+
+ var checkDigits = '0123456789ABCDEFHJKLMNPRSTUVWXY';
+ var idAsNumber = parseInt(str.slice(0, 6), 10) * 1000 + parseInt(str.slice(7, 10), 10);
+ var remainder = idAsNumber % 31;
+ var checkDigit = checkDigits[remainder];
+ return checkDigit === str.slice(10, 11);
+ },
+ IN: function IN(str) {
+ var DNI = /^[1-9]\d{3}\s?\d{4}\s?\d{4}$/; // multiplication table
+
+ var d = [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9], [1, 2, 3, 4, 0, 6, 7, 8, 9, 5], [2, 3, 4, 0, 1, 7, 8, 9, 5, 6], [3, 4, 0, 1, 2, 8, 9, 5, 6, 7], [4, 0, 1, 2, 3, 9, 5, 6, 7, 8], [5, 9, 8, 7, 6, 0, 4, 3, 2, 1], [6, 5, 9, 8, 7, 1, 0, 4, 3, 2], [7, 6, 5, 9, 8, 2, 1, 0, 4, 3], [8, 7, 6, 5, 9, 3, 2, 1, 0, 4], [9, 8, 7, 6, 5, 4, 3, 2, 1, 0]]; // permutation table
+
+ var p = [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9], [1, 5, 7, 6, 2, 8, 3, 0, 9, 4], [5, 8, 0, 3, 7, 9, 6, 1, 4, 2], [8, 9, 1, 6, 0, 4, 3, 5, 2, 7], [9, 4, 5, 3, 1, 2, 6, 8, 7, 0], [4, 2, 8, 6, 5, 7, 3, 9, 0, 1], [2, 7, 9, 3, 8, 0, 6, 4, 1, 5], [7, 0, 4, 6, 9, 1, 3, 2, 5, 8]]; // sanitize user input
+
+ var sanitized = str.trim(); // validate the data structure
+
+ if (!DNI.test(sanitized)) {
+ return false;
+ }
+
+ var c = 0;
+ var invertedArray = sanitized.replace(/\s/g, '').split('').map(Number).reverse();
+ invertedArray.forEach(function (val, i) {
+ c = d[c][p[i % 8][val]];
+ });
+ return c === 0;
+ },
+ IR: function IR(str) {
+ if (!str.match(/^\d{10}$/)) return false;
+ str = "0000".concat(str).slice(str.length - 6);
+ if (parseInt(str.slice(3, 9), 10) === 0) return false;
+ var lastNumber = parseInt(str.slice(9, 10), 10);
+ var sum = 0;
+
+ for (var i = 0; i < 9; i++) {
+ sum += parseInt(str.slice(i, i + 1), 10) * (10 - i);
+ }
+
+ sum %= 11;
+ return sum < 2 && lastNumber === sum || sum >= 2 && lastNumber === 11 - sum;
+ },
+ IT: function IT(str) {
+ if (str.length !== 9) return false;
+ if (str === 'CA00000AA') return false; // https://it.wikipedia.org/wiki/Carta_d%27identit%C3%A0_elettronica_italiana
+
+ return str.search(/C[A-Z][0-9]{5}[A-Z]{2}/i) > -1;
+ },
+ NO: function NO(str) {
+ var sanitized = str.trim();
+ if (isNaN(Number(sanitized))) return false;
+ if (sanitized.length !== 11) return false;
+ if (sanitized === '00000000000') return false; // https://no.wikipedia.org/wiki/F%C3%B8dselsnummer
+
+ var f = sanitized.split('').map(Number);
+ var k1 = (11 - (3 * f[0] + 7 * f[1] + 6 * f[2] + 1 * f[3] + 8 * f[4] + 9 * f[5] + 4 * f[6] + 5 * f[7] + 2 * f[8]) % 11) % 11;
+ var k2 = (11 - (5 * f[0] + 4 * f[1] + 3 * f[2] + 2 * f[3] + 7 * f[4] + 6 * f[5] + 5 * f[6] + 4 * f[7] + 3 * f[8] + 2 * k1) % 11) % 11;
+ if (k1 !== f[9] || k2 !== f[10]) return false;
+ return true;
+ },
+ TH: function TH(str) {
+ if (!str.match(/^[1-8]\d{12}$/)) return false; // validate check digit
+
+ var sum = 0;
+
+ for (var i = 0; i < 12; i++) {
+ sum += parseInt(str[i], 10) * (13 - i);
+ }
+
+ return str[12] === ((11 - sum % 11) % 10).toString();
+ },
+ LK: function LK(str) {
+ var old_nic = /^[1-9]\d{8}[vx]$/i;
+ var new_nic = /^[1-9]\d{11}$/i;
+ if (str.length === 10 && old_nic.test(str)) return true;else if (str.length === 12 && new_nic.test(str)) return true;
+ return false;
+ },
+ 'he-IL': function heIL(str) {
+ var DNI = /^\d{9}$/; // sanitize user input
+
+ var sanitized = str.trim(); // validate the data structure
+
+ if (!DNI.test(sanitized)) {
+ return false;
+ }
+
+ var id = sanitized;
+ var sum = 0,
+ incNum;
+
+ for (var i = 0; i < id.length; i++) {
+ incNum = Number(id[i]) * (i % 2 + 1); // Multiply number by 1 or 2
+
+ sum += incNum > 9 ? incNum - 9 : incNum; // Sum the digits up and add to total
+ }
+
+ return sum % 10 === 0;
+ },
+ 'ar-LY': function arLY(str) {
+ // Libya National Identity Number NIN is 12 digits, the first digit is either 1 or 2
+ var NIN = /^(1|2)\d{11}$/; // sanitize user input
+
+ var sanitized = str.trim(); // validate the data structure
+
+ if (!NIN.test(sanitized)) {
+ return false;
+ }
+
+ return true;
+ },
+ 'ar-TN': function arTN(str) {
+ var DNI = /^\d{8}$/; // sanitize user input
+
+ var sanitized = str.trim(); // validate the data structure
+
+ if (!DNI.test(sanitized)) {
+ return false;
+ }
+
+ return true;
+ },
+ 'zh-CN': function zhCN(str) {
+ var provincesAndCities = ['11', // 北京
+ '12', // 天津
+ '13', // 河北
+ '14', // 山西
+ '15', // 内蒙古
+ '21', // 辽宁
+ '22', // 吉林
+ '23', // 黑龙江
+ '31', // 上海
+ '32', // 江苏
+ '33', // 浙江
+ '34', // 安徽
+ '35', // 福建
+ '36', // 江西
+ '37', // 山东
+ '41', // 河南
+ '42', // 湖北
+ '43', // 湖南
+ '44', // 广东
+ '45', // 广西
+ '46', // 海南
+ '50', // 重庆
+ '51', // 四川
+ '52', // 贵州
+ '53', // 云南
+ '54', // 西藏
+ '61', // 陕西
+ '62', // 甘肃
+ '63', // 青海
+ '64', // 宁夏
+ '65', // 新疆
+ '71', // 台湾
+ '81', // 香港
+ '82', // 澳门
+ '91' // 国外
+ ];
+ var powers = ['7', '9', '10', '5', '8', '4', '2', '1', '6', '3', '7', '9', '10', '5', '8', '4', '2'];
+ var parityBit = ['1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'];
+
+ var checkAddressCode = function checkAddressCode(addressCode) {
+ return provincesAndCities.includes(addressCode);
+ };
+
+ var checkBirthDayCode = function checkBirthDayCode(birDayCode) {
+ var yyyy = parseInt(birDayCode.substring(0, 4), 10);
+ var mm = parseInt(birDayCode.substring(4, 6), 10);
+ var dd = parseInt(birDayCode.substring(6), 10);
+ var xdata = new Date(yyyy, mm - 1, dd);
+
+ if (xdata > new Date()) {
+ return false; // eslint-disable-next-line max-len
+ } else if (xdata.getFullYear() === yyyy && xdata.getMonth() === mm - 1 && xdata.getDate() === dd) {
+ return true;
+ }
+
+ return false;
+ };
+
+ var getParityBit = function getParityBit(idCardNo) {
+ var id17 = idCardNo.substring(0, 17);
+ var power = 0;
+
+ for (var i = 0; i < 17; i++) {
+ power += parseInt(id17.charAt(i), 10) * parseInt(powers[i], 10);
+ }
+
+ var mod = power % 11;
+ return parityBit[mod];
+ };
+
+ var checkParityBit = function checkParityBit(idCardNo) {
+ return getParityBit(idCardNo) === idCardNo.charAt(17).toUpperCase();
+ };
+
+ var check15IdCardNo = function check15IdCardNo(idCardNo) {
+ var check = /^[1-9]\d{7}((0[1-9])|(1[0-2]))((0[1-9])|([1-2][0-9])|(3[0-1]))\d{3}$/.test(idCardNo);
+ if (!check) return false;
+ var addressCode = idCardNo.substring(0, 2);
+ check = checkAddressCode(addressCode);
+ if (!check) return false;
+ var birDayCode = "19".concat(idCardNo.substring(6, 12));
+ check = checkBirthDayCode(birDayCode);
+ if (!check) return false;
+ return true;
+ };
+
+ var check18IdCardNo = function check18IdCardNo(idCardNo) {
+ var check = /^[1-9]\d{5}[1-9]\d{3}((0[1-9])|(1[0-2]))((0[1-9])|([1-2][0-9])|(3[0-1]))\d{3}(\d|x|X)$/.test(idCardNo);
+ if (!check) return false;
+ var addressCode = idCardNo.substring(0, 2);
+ check = checkAddressCode(addressCode);
+ if (!check) return false;
+ var birDayCode = idCardNo.substring(6, 14);
+ check = checkBirthDayCode(birDayCode);
+ if (!check) return false;
+ return checkParityBit(idCardNo);
+ };
+
+ var checkIdCardNo = function checkIdCardNo(idCardNo) {
+ var check = /^\d{15}|(\d{17}(\d|x|X))$/.test(idCardNo);
+ if (!check) return false;
+
+ if (idCardNo.length === 15) {
+ return check15IdCardNo(idCardNo);
+ }
+
+ return check18IdCardNo(idCardNo);
+ };
+
+ return checkIdCardNo(str);
+ },
+ 'zh-HK': function zhHK(str) {
+ // sanitize user input
+ str = str.trim(); // HKID number starts with 1 or 2 letters, followed by 6 digits,
+ // then a checksum contained in square / round brackets or nothing
+
+ var regexHKID = /^[A-Z]{1,2}[0-9]{6}((\([0-9A]\))|(\[[0-9A]\])|([0-9A]))$/;
+ var regexIsDigit = /^[0-9]$/; // convert the user input to all uppercase and apply regex
+
+ str = str.toUpperCase();
+ if (!regexHKID.test(str)) return false;
+ str = str.replace(/\[|\]|\(|\)/g, '');
+ if (str.length === 8) str = "3".concat(str);
+ var checkSumVal = 0;
+
+ for (var i = 0; i <= 7; i++) {
+ var convertedChar = void 0;
+ if (!regexIsDigit.test(str[i])) convertedChar = (str[i].charCodeAt(0) - 55) % 11;else convertedChar = str[i];
+ checkSumVal += convertedChar * (9 - i);
+ }
+
+ checkSumVal %= 11;
+ var checkSumConverted;
+ if (checkSumVal === 0) checkSumConverted = '0';else if (checkSumVal === 1) checkSumConverted = 'A';else checkSumConverted = String(11 - checkSumVal);
+ if (checkSumConverted === str[str.length - 1]) return true;
+ return false;
+ },
+ 'zh-TW': function zhTW(str) {
+ var ALPHABET_CODES = {
+ A: 10,
+ B: 11,
+ C: 12,
+ D: 13,
+ E: 14,
+ F: 15,
+ G: 16,
+ H: 17,
+ I: 34,
+ J: 18,
+ K: 19,
+ L: 20,
+ M: 21,
+ N: 22,
+ O: 35,
+ P: 23,
+ Q: 24,
+ R: 25,
+ S: 26,
+ T: 27,
+ U: 28,
+ V: 29,
+ W: 32,
+ X: 30,
+ Y: 31,
+ Z: 33
+ };
+ var sanitized = str.trim().toUpperCase();
+ if (!/^[A-Z][0-9]{9}$/.test(sanitized)) return false;
+ return Array.from(sanitized).reduce(function (sum, number, index) {
+ if (index === 0) {
+ var code = ALPHABET_CODES[number];
+ return code % 10 * 9 + Math.floor(code / 10);
+ }
+
+ if (index === 9) {
+ return (10 - sum % 10 - Number(number)) % 10 === 0;
+ }
+
+ return sum + Number(number) * (9 - index);
+ }, 0);
+ }
+};
+export default function isIdentityCard(str, locale) {
+ assertString(str);
+
+ if (locale in validators) {
+ return validators[locale](str);
+ } else if (locale === 'any') {
+ for (var key in validators) {
+ // https://github.com/gotwarlost/istanbul/blob/master/ignoring-code-for-coverage.md#ignoring-code-for-coverage-purposes
+ // istanbul ignore else
+ if (validators.hasOwnProperty(key)) {
+ var validator = validators[key];
+
+ if (validator(str)) {
+ return true;
+ }
+ }
+ }
+
+ return false;
+ }
+
+ throw new Error("Invalid locale '".concat(locale, "'"));
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isIn.js b/includes/external/addressbook/node_modules/validator/es/lib/isIn.js
new file mode 100644
index 0000000..452429d
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isIn.js
@@ -0,0 +1,28 @@
+function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
+
+import assertString from './util/assertString';
+import toString from './util/toString';
+export default function isIn(str, options) {
+ assertString(str);
+ var i;
+
+ if (Object.prototype.toString.call(options) === '[object Array]') {
+ var array = [];
+
+ for (i in options) {
+ // https://github.com/gotwarlost/istanbul/blob/master/ignoring-code-for-coverage.md#ignoring-code-for-coverage-purposes
+ // istanbul ignore else
+ if ({}.hasOwnProperty.call(options, i)) {
+ array[i] = toString(options[i]);
+ }
+ }
+
+ return array.indexOf(str) >= 0;
+ } else if (_typeof(options) === 'object') {
+ return options.hasOwnProperty(str);
+ } else if (options && typeof options.indexOf === 'function') {
+ return options.indexOf(str) >= 0;
+ }
+
+ return false;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isInt.js b/includes/external/addressbook/node_modules/validator/es/lib/isInt.js
new file mode 100644
index 0000000..b58dab4
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isInt.js
@@ -0,0 +1,16 @@
+import assertString from './util/assertString';
+var _int = /^(?:[-+]?(?:0|[1-9][0-9]*))$/;
+var intLeadingZeroes = /^[-+]?[0-9]+$/;
+export default function isInt(str, options) {
+ assertString(str);
+ options = options || {}; // Get the regex to use for testing, based on whether
+ // leading zeroes are allowed or not.
+
+ var regex = options.hasOwnProperty('allow_leading_zeroes') && !options.allow_leading_zeroes ? _int : intLeadingZeroes; // Check min/max/lt/gt
+
+ var minCheckPassed = !options.hasOwnProperty('min') || str >= options.min;
+ var maxCheckPassed = !options.hasOwnProperty('max') || str <= options.max;
+ var ltCheckPassed = !options.hasOwnProperty('lt') || str < options.lt;
+ var gtCheckPassed = !options.hasOwnProperty('gt') || str > options.gt;
+ return regex.test(str) && minCheckPassed && maxCheckPassed && ltCheckPassed && gtCheckPassed;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isJSON.js b/includes/external/addressbook/node_modules/validator/es/lib/isJSON.js
new file mode 100644
index 0000000..bd110cc
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isJSON.js
@@ -0,0 +1,26 @@
+function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
+
+import assertString from './util/assertString';
+import merge from './util/merge';
+var default_json_options = {
+ allow_primitives: false
+};
+export default function isJSON(str, options) {
+ assertString(str);
+
+ try {
+ options = merge(options, default_json_options);
+ var primitives = [];
+
+ if (options.allow_primitives) {
+ primitives = [null, false, true];
+ }
+
+ var obj = JSON.parse(str);
+ return primitives.includes(obj) || !!obj && _typeof(obj) === 'object';
+ } catch (e) {
+ /* ignore */
+ }
+
+ return false;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isJWT.js b/includes/external/addressbook/node_modules/validator/es/lib/isJWT.js
new file mode 100644
index 0000000..c1afb7b
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isJWT.js
@@ -0,0 +1,17 @@
+import assertString from './util/assertString';
+import isBase64 from './isBase64';
+export default function isJWT(str) {
+ assertString(str);
+ var dotSplit = str.split('.');
+ var len = dotSplit.length;
+
+ if (len > 3 || len < 2) {
+ return false;
+ }
+
+ return dotSplit.reduce(function (acc, currElem) {
+ return acc && isBase64(currElem, {
+ urlSafe: true
+ });
+ }, true);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isLatLong.js b/includes/external/addressbook/node_modules/validator/es/lib/isLatLong.js
new file mode 100644
index 0000000..7362c1d
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isLatLong.js
@@ -0,0 +1,22 @@
+import assertString from './util/assertString';
+import merge from './util/merge';
+var lat = /^\(?[+-]?(90(\.0+)?|[1-8]?\d(\.\d+)?)$/;
+var _long = /^\s?[+-]?(180(\.0+)?|1[0-7]\d(\.\d+)?|\d{1,2}(\.\d+)?)\)?$/;
+var latDMS = /^(([1-8]?\d)\D+([1-5]?\d|60)\D+([1-5]?\d|60)(\.\d+)?|90\D+0\D+0)\D+[NSns]?$/i;
+var longDMS = /^\s*([1-7]?\d{1,2}\D+([1-5]?\d|60)\D+([1-5]?\d|60)(\.\d+)?|180\D+0\D+0)\D+[EWew]?$/i;
+var defaultLatLongOptions = {
+ checkDMS: false
+};
+export default function isLatLong(str, options) {
+ assertString(str);
+ options = merge(options, defaultLatLongOptions);
+ if (!str.includes(',')) return false;
+ var pair = str.split(',');
+ if (pair[0].startsWith('(') && !pair[1].endsWith(')') || pair[1].endsWith(')') && !pair[0].startsWith('(')) return false;
+
+ if (options.checkDMS) {
+ return latDMS.test(pair[0]) && longDMS.test(pair[1]);
+ }
+
+ return lat.test(pair[0]) && _long.test(pair[1]);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isLength.js b/includes/external/addressbook/node_modules/validator/es/lib/isLength.js
new file mode 100644
index 0000000..f8eb5ab
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isLength.js
@@ -0,0 +1,24 @@
+function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
+
+import assertString from './util/assertString';
+/* eslint-disable prefer-rest-params */
+
+export default function isLength(str, options) {
+ assertString(str);
+ var min;
+ var max;
+
+ if (_typeof(options) === 'object') {
+ min = options.min || 0;
+ max = options.max;
+ } else {
+ // backwards compatibility: isLength(str, min [, max])
+ min = arguments[1] || 0;
+ max = arguments[2];
+ }
+
+ var presentationSequences = str.match(/(\uFE0F|\uFE0E)/g) || [];
+ var surrogatePairs = str.match(/[\uD800-\uDBFF][\uDC00-\uDFFF]/g) || [];
+ var len = str.length - presentationSequences.length - surrogatePairs.length;
+ return len >= min && (typeof max === 'undefined' || len <= max);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isLicensePlate.js b/includes/external/addressbook/node_modules/validator/es/lib/isLicensePlate.js
new file mode 100644
index 0000000..04eca79
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isLicensePlate.js
@@ -0,0 +1,56 @@
+import assertString from './util/assertString';
+var validators = {
+ 'cs-CZ': function csCZ(str) {
+ return /^(([ABCDEFHIJKLMNPRSTUVXYZ]|[0-9])-?){5,8}$/.test(str);
+ },
+ 'de-DE': function deDE(str) {
+ return /^((A|AA|AB|AC|AE|AH|AK|AM|AN|AÖ|AP|AS|AT|AU|AW|AZ|B|BA|BB|BC|BE|BF|BH|BI|BK|BL|BM|BN|BO|BÖ|BS|BT|BZ|C|CA|CB|CE|CO|CR|CW|D|DA|DD|DE|DH|DI|DL|DM|DN|DO|DU|DW|DZ|E|EA|EB|ED|EE|EF|EG|EH|EI|EL|EM|EN|ER|ES|EU|EW|F|FB|FD|FF|FG|FI|FL|FN|FO|FR|FS|FT|FÜ|FW|FZ|G|GA|GC|GD|GE|GF|GG|GI|GK|GL|GM|GN|GÖ|GP|GR|GS|GT|GÜ|GV|GW|GZ|H|HA|HB|HC|HD|HE|HF|HG|HH|HI|HK|HL|HM|HN|HO|HP|HR|HS|HU|HV|HX|HY|HZ|IK|IL|IN|IZ|J|JE|JL|K|KA|KB|KC|KE|KF|KG|KH|KI|KK|KL|KM|KN|KO|KR|KS|KT|KU|KW|KY|L|LA|LB|LC|LD|LF|LG|LH|LI|LL|LM|LN|LÖ|LP|LR|LU|M|MA|MB|MC|MD|ME|MG|MH|MI|MK|ML|MM|MN|MO|MQ|MR|MS|MÜ|MW|MY|MZ|N|NB|ND|NE|NF|NH|NI|NK|NM|NÖ|NP|NR|NT|NU|NW|NY|NZ|OA|OB|OC|OD|OE|OF|OG|OH|OK|OL|OP|OS|OZ|P|PA|PB|PE|PF|PI|PL|PM|PN|PR|PS|PW|PZ|R|RA|RC|RD|RE|RG|RH|RI|RL|RM|RN|RO|RP|RS|RT|RU|RV|RW|RZ|S|SB|SC|SE|SG|SI|SK|SL|SM|SN|SO|SP|SR|ST|SU|SW|SY|SZ|TE|TF|TG|TO|TP|TR|TS|TT|TÜ|ÜB|UE|UH|UL|UM|UN|V|VB|VG|VK|VR|VS|W|WA|WB|WE|WF|WI|WK|WL|WM|WN|WO|WR|WS|WT|WÜ|WW|WZ|Z|ZE|ZI|ZP|ZR|ZW|ZZ)[- ]?[A-Z]{1,2}[- ]?\d{1,4}|(ABG|ABI|AIB|AIC|ALF|ALZ|ANA|ANG|ANK|APD|ARN|ART|ASL|ASZ|AUR|AZE|BAD|BAR|BBG|BCH|BED|BER|BGD|BGL|BID|BIN|BIR|BIT|BIW|BKS|BLB|BLK|BNA|BOG|BOH|BOR|BOT|BRA|BRB|BRG|BRK|BRL|BRV|BSB|BSK|BTF|BÜD|BUL|BÜR|BÜS|BÜZ|CAS|CHA|CLP|CLZ|COC|COE|CUX|DAH|DAN|DAU|DBR|DEG|DEL|DGF|DIL|DIN|DIZ|DKB|DLG|DON|DUD|DÜW|EBE|EBN|EBS|ECK|EIC|EIL|EIN|EIS|EMD|EMS|ERB|ERH|ERK|ERZ|ESB|ESW|FDB|FDS|FEU|FFB|FKB|FLÖ|FOR|FRG|FRI|FRW|FTL|FÜS|GAN|GAP|GDB|GEL|GEO|GER|GHA|GHC|GLA|GMN|GNT|GOA|GOH|GRA|GRH|GRI|GRM|GRZ|GTH|GUB|GUN|GVM|HAB|HAL|HAM|HAS|HBN|HBS|HCH|HDH|HDL|HEB|HEF|HEI|HER|HET|HGN|HGW|HHM|HIG|HIP|HMÜ|HOG|HOH|HOL|HOM|HOR|HÖS|HOT|HRO|HSK|HST|HVL|HWI|IGB|ILL|JÜL|KEH|KEL|KEM|KIB|KLE|KLZ|KÖN|KÖT|KÖZ|KRU|KÜN|KUS|KYF|LAN|LAU|LBS|LBZ|LDK|LDS|LEO|LER|LEV|LIB|LIF|LIP|LÖB|LOS|LRO|LSZ|LÜN|LUP|LWL|MAB|MAI|MAK|MAL|MED|MEG|MEI|MEK|MEL|MER|MET|MGH|MGN|MHL|MIL|MKK|MOD|MOL|MON|MOS|MSE|MSH|MSP|MST|MTK|MTL|MÜB|MÜR|MYK|MZG|NAB|NAI|NAU|NDH|NEA|NEB|NEC|NEN|NES|NEW|NMB|NMS|NOH|NOL|NOM|NOR|NVP|NWM|OAL|OBB|OBG|OCH|OHA|ÖHR|OHV|OHZ|OPR|OSL|OVI|OVL|OVP|PAF|PAN|PAR|PCH|PEG|PIR|PLÖ|PRÜ|QFT|QLB|RDG|REG|REH|REI|RID|RIE|ROD|ROF|ROK|ROL|ROS|ROT|ROW|RSL|RÜD|RÜG|SAB|SAD|SAN|SAW|SBG|SBK|SCZ|SDH|SDL|SDT|SEB|SEE|SEF|SEL|SFB|SFT|SGH|SHA|SHG|SHK|SHL|SIG|SIM|SLE|SLF|SLK|SLN|SLS|SLÜ|SLZ|SMÜ|SOB|SOG|SOK|SÖM|SON|SPB|SPN|SRB|SRO|STA|STB|STD|STE|STL|SUL|SÜW|SWA|SZB|TBB|TDO|TET|TIR|TÖL|TUT|UEM|UER|UFF|USI|VAI|VEC|VER|VIB|VIE|VIT|VOH|WAF|WAK|WAN|WAR|WAT|WBS|WDA|WEL|WEN|WER|WES|WHV|WIL|WIS|WIT|WIZ|WLG|WMS|WND|WOB|WOH|WOL|WOR|WOS|WRN|WSF|WST|WSW|WTL|WTM|WUG|WÜM|WUN|WUR|WZL|ZEL|ZIG)[- ]?(([A-Z][- ]?\d{1,4})|([A-Z]{2}[- ]?\d{1,3})))[- ]?(E|H)?$/.test(str);
+ },
+ 'de-LI': function deLI(str) {
+ return /^FL[- ]?\d{1,5}[UZ]?$/.test(str);
+ },
+ 'en-IN': function enIN(str) {
+ return /^[A-Z]{2}[ -]?[0-9]{1,2}(?:[ -]?[A-Z])(?:[ -]?[A-Z]*)?[ -]?[0-9]{4}$/.test(str);
+ },
+ 'es-AR': function esAR(str) {
+ return /^(([A-Z]{2} ?[0-9]{3} ?[A-Z]{2})|([A-Z]{3} ?[0-9]{3}))$/.test(str);
+ },
+ 'fi-FI': function fiFI(str) {
+ return /^(?=.{4,7})(([A-Z]{1,3}|[0-9]{1,3})[\s-]?([A-Z]{1,3}|[0-9]{1,5}))$/.test(str);
+ },
+ 'hu-HU': function huHU(str) {
+ return /^((((?!AAA)(([A-NPRSTVZWXY]{1})([A-PR-Z]{1})([A-HJ-NPR-Z]))|(A[ABC]I)|A[ABC]O|A[A-W]Q|BPI|BPO|UCO|UDO|XAO)-(?!000)\d{3})|(M\d{6})|((CK|DT|CD|HC|H[ABEFIKLMNPRSTVX]|MA|OT|R[A-Z]) \d{2}-\d{2})|(CD \d{3}-\d{3})|(C-(C|X) \d{4})|(X-(A|B|C) \d{4})|(([EPVZ]-\d{5}))|(S A[A-Z]{2} \d{2})|(SP \d{2}-\d{2}))$/.test(str);
+ },
+ 'pt-BR': function ptBR(str) {
+ return /^[A-Z]{3}[ -]?[0-9][A-Z][0-9]{2}|[A-Z]{3}[ -]?[0-9]{4}$/.test(str);
+ },
+ 'pt-PT': function ptPT(str) {
+ return /^([A-Z]{2}|[0-9]{2})[ -·]?([A-Z]{2}|[0-9]{2})[ -·]?([A-Z]{2}|[0-9]{2})$/.test(str);
+ },
+ 'sq-AL': function sqAL(str) {
+ return /^[A-Z]{2}[- ]?((\d{3}[- ]?(([A-Z]{2})|T))|(R[- ]?\d{3}))$/.test(str);
+ },
+ 'sv-SE': function svSE(str) {
+ return /^[A-HJ-PR-UW-Z]{3} ?[\d]{2}[A-HJ-PR-UW-Z1-9]$|(^[A-ZÅÄÖ ]{2,7}$)/.test(str.trim());
+ }
+};
+export default function isLicensePlate(str, locale) {
+ assertString(str);
+
+ if (locale in validators) {
+ return validators[locale](str);
+ } else if (locale === 'any') {
+ for (var key in validators) {
+ /* eslint guard-for-in: 0 */
+ var validator = validators[key];
+
+ if (validator(str)) {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ throw new Error("Invalid locale '".concat(locale, "'"));
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isLocale.js b/includes/external/addressbook/node_modules/validator/es/lib/isLocale.js
new file mode 100644
index 0000000..5033392
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isLocale.js
@@ -0,0 +1,11 @@
+import assertString from './util/assertString';
+var localeReg = /^[A-Za-z]{2,4}([_-]([A-Za-z]{4}|[\d]{3}))?([_-]([A-Za-z]{2}|[\d]{3}))?$/;
+export default function isLocale(str) {
+ assertString(str);
+
+ if (str === 'en_US_POSIX' || str === 'ca_ES_VALENCIA') {
+ return true;
+ }
+
+ return localeReg.test(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isLowercase.js b/includes/external/addressbook/node_modules/validator/es/lib/isLowercase.js
new file mode 100644
index 0000000..0347856
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isLowercase.js
@@ -0,0 +1,5 @@
+import assertString from './util/assertString';
+export default function isLowercase(str) {
+ assertString(str);
+ return str === str.toLowerCase();
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isLuhnNumber.js b/includes/external/addressbook/node_modules/validator/es/lib/isLuhnNumber.js
new file mode 100644
index 0000000..ad7dc5e
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isLuhnNumber.js
@@ -0,0 +1,30 @@
+import assertString from './util/assertString';
+export default function isLuhnNumber(str) {
+ assertString(str);
+ var sanitized = str.replace(/[- ]+/g, '');
+ var sum = 0;
+ var digit;
+ var tmpNum;
+ var shouldDouble;
+
+ for (var i = sanitized.length - 1; i >= 0; i--) {
+ digit = sanitized.substring(i, i + 1);
+ tmpNum = parseInt(digit, 10);
+
+ if (shouldDouble) {
+ tmpNum *= 2;
+
+ if (tmpNum >= 10) {
+ sum += tmpNum % 10 + 1;
+ } else {
+ sum += tmpNum;
+ }
+ } else {
+ sum += tmpNum;
+ }
+
+ shouldDouble = !shouldDouble;
+ }
+
+ return !!(sum % 10 === 0 ? sanitized : false);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isLuhnValid.js b/includes/external/addressbook/node_modules/validator/es/lib/isLuhnValid.js
new file mode 100644
index 0000000..f082e34
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isLuhnValid.js
@@ -0,0 +1,30 @@
+import assertString from './util/assertString';
+export default function isLuhnValid(str) {
+ assertString(str);
+ var sanitized = str.replace(/[- ]+/g, '');
+ var sum = 0;
+ var digit;
+ var tmpNum;
+ var shouldDouble;
+
+ for (var i = sanitized.length - 1; i >= 0; i--) {
+ digit = sanitized.substring(i, i + 1);
+ tmpNum = parseInt(digit, 10);
+
+ if (shouldDouble) {
+ tmpNum *= 2;
+
+ if (tmpNum >= 10) {
+ sum += tmpNum % 10 + 1;
+ } else {
+ sum += tmpNum;
+ }
+ } else {
+ sum += tmpNum;
+ }
+
+ shouldDouble = !shouldDouble;
+ }
+
+ return !!(sum % 10 === 0 ? sanitized : false);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isMACAddress.js b/includes/external/addressbook/node_modules/validator/es/lib/isMACAddress.js
new file mode 100644
index 0000000..3591fe3
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isMACAddress.js
@@ -0,0 +1,44 @@
+import assertString from './util/assertString';
+var macAddress48 = /^(?:[0-9a-fA-F]{2}([-:\s]))([0-9a-fA-F]{2}\1){4}([0-9a-fA-F]{2})$/;
+var macAddress48NoSeparators = /^([0-9a-fA-F]){12}$/;
+var macAddress48WithDots = /^([0-9a-fA-F]{4}\.){2}([0-9a-fA-F]{4})$/;
+var macAddress64 = /^(?:[0-9a-fA-F]{2}([-:\s]))([0-9a-fA-F]{2}\1){6}([0-9a-fA-F]{2})$/;
+var macAddress64NoSeparators = /^([0-9a-fA-F]){16}$/;
+var macAddress64WithDots = /^([0-9a-fA-F]{4}\.){3}([0-9a-fA-F]{4})$/;
+export default function isMACAddress(str, options) {
+ assertString(str);
+
+ if (options !== null && options !== void 0 && options.eui) {
+ options.eui = String(options.eui);
+ }
+ /**
+ * @deprecated `no_colons` TODO: remove it in the next major
+ */
+
+
+ if (options !== null && options !== void 0 && options.no_colons || options !== null && options !== void 0 && options.no_separators) {
+ if (options.eui === '48') {
+ return macAddress48NoSeparators.test(str);
+ }
+
+ if (options.eui === '64') {
+ return macAddress64NoSeparators.test(str);
+ }
+
+ return macAddress48NoSeparators.test(str) || macAddress64NoSeparators.test(str);
+ }
+
+ if ((options === null || options === void 0 ? void 0 : options.eui) === '48') {
+ return macAddress48.test(str) || macAddress48WithDots.test(str);
+ }
+
+ if ((options === null || options === void 0 ? void 0 : options.eui) === '64') {
+ return macAddress64.test(str) || macAddress64WithDots.test(str);
+ }
+
+ return isMACAddress(str, {
+ eui: '48'
+ }) || isMACAddress(str, {
+ eui: '64'
+ });
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isMD5.js b/includes/external/addressbook/node_modules/validator/es/lib/isMD5.js
new file mode 100644
index 0000000..701ed7b
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isMD5.js
@@ -0,0 +1,6 @@
+import assertString from './util/assertString';
+var md5 = /^[a-f0-9]{32}$/;
+export default function isMD5(str) {
+ assertString(str);
+ return md5.test(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isMagnetURI.js b/includes/external/addressbook/node_modules/validator/es/lib/isMagnetURI.js
new file mode 100644
index 0000000..9ec1d63
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isMagnetURI.js
@@ -0,0 +1,11 @@
+import assertString from './util/assertString';
+var magnetURIComponent = /(?:^magnet:\?|[^?&]&)xt(?:\.1)?=urn:(?:(?:aich|bitprint|btih|ed2k|ed2khash|kzhash|md5|sha1|tree:tiger):[a-z0-9]{32}(?:[a-z0-9]{8})?|btmh:1220[a-z0-9]{64})(?:$|&)/i;
+export default function isMagnetURI(url) {
+ assertString(url);
+
+ if (url.indexOf('magnet:?') !== 0) {
+ return false;
+ }
+
+ return magnetURIComponent.test(url);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isMimeType.js b/includes/external/addressbook/node_modules/validator/es/lib/isMimeType.js
new file mode 100644
index 0000000..5a3f2c8
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isMimeType.js
@@ -0,0 +1,39 @@
+import assertString from './util/assertString';
+/*
+ Checks if the provided string matches to a correct Media type format (MIME type)
+
+ This function only checks is the string format follows the
+ etablished rules by the according RFC specifications.
+ This function supports 'charset' in textual media types
+ (https://tools.ietf.org/html/rfc6657).
+
+ This function does not check against all the media types listed
+ by the IANA (https://www.iana.org/assignments/media-types/media-types.xhtml)
+ because of lightness purposes : it would require to include
+ all these MIME types in this librairy, which would weigh it
+ significantly. This kind of effort maybe is not worth for the use that
+ this function has in this entire librairy.
+
+ More informations in the RFC specifications :
+ - https://tools.ietf.org/html/rfc2045
+ - https://tools.ietf.org/html/rfc2046
+ - https://tools.ietf.org/html/rfc7231#section-3.1.1.1
+ - https://tools.ietf.org/html/rfc7231#section-3.1.1.5
+*/
+// Match simple MIME types
+// NB :
+// Subtype length must not exceed 100 characters.
+// This rule does not comply to the RFC specs (what is the max length ?).
+
+var mimeTypeSimple = /^(application|audio|font|image|message|model|multipart|text|video)\/[a-zA-Z0-9\.\-\+_]{1,100}$/i; // eslint-disable-line max-len
+// Handle "charset" in "text/*"
+
+var mimeTypeText = /^text\/[a-zA-Z0-9\.\-\+]{1,100};\s?charset=("[a-zA-Z0-9\.\-\+\s]{0,70}"|[a-zA-Z0-9\.\-\+]{0,70})(\s?\([a-zA-Z0-9\.\-\+\s]{1,20}\))?$/i; // eslint-disable-line max-len
+// Handle "boundary" in "multipart/*"
+
+var mimeTypeMultipart = /^multipart\/[a-zA-Z0-9\.\-\+]{1,100}(;\s?(boundary|charset)=("[a-zA-Z0-9\.\-\+\s]{0,70}"|[a-zA-Z0-9\.\-\+]{0,70})(\s?\([a-zA-Z0-9\.\-\+\s]{1,20}\))?){0,2}$/i; // eslint-disable-line max-len
+
+export default function isMimeType(str) {
+ assertString(str);
+ return mimeTypeSimple.test(str) || mimeTypeText.test(str) || mimeTypeMultipart.test(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isMobilePhone.js b/includes/external/addressbook/node_modules/validator/es/lib/isMobilePhone.js
new file mode 100644
index 0000000..e5d0cfc
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isMobilePhone.js
@@ -0,0 +1,209 @@
+import assertString from './util/assertString';
+/* eslint-disable max-len */
+
+var phones = {
+ 'am-AM': /^(\+?374|0)((10|[9|7][0-9])\d{6}$|[2-4]\d{7}$)/,
+ 'ar-AE': /^((\+?971)|0)?5[024568]\d{7}$/,
+ 'ar-BH': /^(\+?973)?(3|6)\d{7}$/,
+ 'ar-DZ': /^(\+?213|0)(5|6|7)\d{8}$/,
+ 'ar-LB': /^(\+?961)?((3|81)\d{6}|7\d{7})$/,
+ 'ar-EG': /^((\+?20)|0)?1[0125]\d{8}$/,
+ 'ar-IQ': /^(\+?964|0)?7[0-9]\d{8}$/,
+ 'ar-JO': /^(\+?962|0)?7[789]\d{7}$/,
+ 'ar-KW': /^(\+?965)([569]\d{7}|41\d{6})$/,
+ 'ar-LY': /^((\+?218)|0)?(9[1-6]\d{7}|[1-8]\d{7,9})$/,
+ 'ar-MA': /^(?:(?:\+|00)212|0)[5-7]\d{8}$/,
+ 'ar-OM': /^((\+|00)968)?(9[1-9])\d{6}$/,
+ 'ar-PS': /^(\+?970|0)5[6|9](\d{7})$/,
+ 'ar-SA': /^(!?(\+?966)|0)?5\d{8}$/,
+ 'ar-SY': /^(!?(\+?963)|0)?9\d{8}$/,
+ 'ar-TN': /^(\+?216)?[2459]\d{7}$/,
+ 'az-AZ': /^(\+994|0)(10|5[015]|7[07]|99)\d{7}$/,
+ 'bs-BA': /^((((\+|00)3876)|06))((([0-3]|[5-6])\d{6})|(4\d{7}))$/,
+ 'be-BY': /^(\+?375)?(24|25|29|33|44)\d{7}$/,
+ 'bg-BG': /^(\+?359|0)?8[789]\d{7}$/,
+ 'bn-BD': /^(\+?880|0)1[13456789][0-9]{8}$/,
+ 'ca-AD': /^(\+376)?[346]\d{5}$/,
+ 'cs-CZ': /^(\+?420)? ?[1-9][0-9]{2} ?[0-9]{3} ?[0-9]{3}$/,
+ 'da-DK': /^(\+?45)?\s?\d{2}\s?\d{2}\s?\d{2}\s?\d{2}$/,
+ 'de-DE': /^((\+49|0)1)(5[0-25-9]\d|6([23]|0\d?)|7([0-57-9]|6\d))\d{7,9}$/,
+ 'de-AT': /^(\+43|0)\d{1,4}\d{3,12}$/,
+ 'de-CH': /^(\+41|0)([1-9])\d{1,9}$/,
+ 'de-LU': /^(\+352)?((6\d1)\d{6})$/,
+ 'dv-MV': /^(\+?960)?(7[2-9]|9[1-9])\d{5}$/,
+ 'el-GR': /^(\+?30|0)?6(8[5-9]|9(?![26])[0-9])\d{7}$/,
+ 'el-CY': /^(\+?357?)?(9(9|6)\d{6})$/,
+ 'en-AI': /^(\+?1|0)264(?:2(35|92)|4(?:6[1-2]|76|97)|5(?:3[6-9]|8[1-4])|7(?:2(4|9)|72))\d{4}$/,
+ 'en-AU': /^(\+?61|0)4\d{8}$/,
+ 'en-AG': /^(?:\+1|1)268(?:464|7(?:1[3-9]|[28]\d|3[0246]|64|7[0-689]))\d{4}$/,
+ 'en-BM': /^(\+?1)?441(((3|7)\d{6}$)|(5[0-3][0-9]\d{4}$)|(59\d{5}$))/,
+ 'en-BS': /^(\+?1[-\s]?|0)?\(?242\)?[-\s]?\d{3}[-\s]?\d{4}$/,
+ 'en-GB': /^(\+?44|0)7\d{9}$/,
+ 'en-GG': /^(\+?44|0)1481\d{6}$/,
+ 'en-GH': /^(\+233|0)(20|50|24|54|27|57|26|56|23|28|55|59)\d{7}$/,
+ 'en-GY': /^(\+592|0)6\d{6}$/,
+ 'en-HK': /^(\+?852[-\s]?)?[456789]\d{3}[-\s]?\d{4}$/,
+ 'en-MO': /^(\+?853[-\s]?)?[6]\d{3}[-\s]?\d{4}$/,
+ 'en-IE': /^(\+?353|0)8[356789]\d{7}$/,
+ 'en-IN': /^(\+?91|0)?[6789]\d{9}$/,
+ 'en-JM': /^(\+?876)?\d{7}$/,
+ 'en-KE': /^(\+?254|0)(7|1)\d{8}$/,
+ 'en-SS': /^(\+?211|0)(9[1257])\d{7}$/,
+ 'en-KI': /^((\+686|686)?)?( )?((6|7)(2|3|8)[0-9]{6})$/,
+ 'en-KN': /^(?:\+1|1)869(?:46\d|48[89]|55[6-8]|66\d|76[02-7])\d{4}$/,
+ 'en-LS': /^(\+?266)(22|28|57|58|59|27|52)\d{6}$/,
+ 'en-MT': /^(\+?356|0)?(99|79|77|21|27|22|25)[0-9]{6}$/,
+ 'en-MU': /^(\+?230|0)?\d{8}$/,
+ 'en-NA': /^(\+?264|0)(6|8)\d{7}$/,
+ 'en-NG': /^(\+?234|0)?[789]\d{9}$/,
+ 'en-NZ': /^(\+?64|0)[28]\d{7,9}$/,
+ 'en-PG': /^(\+?675|0)?(7\d|8[18])\d{6}$/,
+ 'en-PK': /^((00|\+)?92|0)3[0-6]\d{8}$/,
+ 'en-PH': /^(09|\+639)\d{9}$/,
+ 'en-RW': /^(\+?250|0)?[7]\d{8}$/,
+ 'en-SG': /^(\+65)?[3689]\d{7}$/,
+ 'en-SL': /^(\+?232|0)\d{8}$/,
+ 'en-TZ': /^(\+?255|0)?[67]\d{8}$/,
+ 'en-UG': /^(\+?256|0)?[7]\d{8}$/,
+ 'en-US': /^((\+1|1)?( |-)?)?(\([2-9][0-9]{2}\)|[2-9][0-9]{2})( |-)?([2-9][0-9]{2}( |-)?[0-9]{4})$/,
+ 'en-ZA': /^(\+?27|0)\d{9}$/,
+ 'en-ZM': /^(\+?26)?09[567]\d{7}$/,
+ 'en-ZW': /^(\+263)[0-9]{9}$/,
+ 'en-BW': /^(\+?267)?(7[1-8]{1})\d{6}$/,
+ 'es-AR': /^\+?549(11|[2368]\d)\d{8}$/,
+ 'es-BO': /^(\+?591)?(6|7)\d{7}$/,
+ 'es-CO': /^(\+?57)?3(0(0|1|2|4|5)|1\d|2[0-4]|5(0|1))\d{7}$/,
+ 'es-CL': /^(\+?56|0)[2-9]\d{1}\d{7}$/,
+ 'es-CR': /^(\+506)?[2-8]\d{7}$/,
+ 'es-CU': /^(\+53|0053)?5\d{7}/,
+ 'es-DO': /^(\+?1)?8[024]9\d{7}$/,
+ 'es-HN': /^(\+?504)?[9|8|3|2]\d{7}$/,
+ 'es-EC': /^(\+?593|0)([2-7]|9[2-9])\d{7}$/,
+ 'es-ES': /^(\+?34)?[6|7]\d{8}$/,
+ 'es-PE': /^(\+?51)?9\d{8}$/,
+ 'es-MX': /^(\+?52)?(1|01)?\d{10,11}$/,
+ 'es-NI': /^(\+?505)\d{7,8}$/,
+ 'es-PA': /^(\+?507)\d{7,8}$/,
+ 'es-PY': /^(\+?595|0)9[9876]\d{7}$/,
+ 'es-SV': /^(\+?503)?[67]\d{7}$/,
+ 'es-UY': /^(\+598|0)9[1-9][\d]{6}$/,
+ 'es-VE': /^(\+?58)?(2|4)\d{9}$/,
+ 'et-EE': /^(\+?372)?\s?(5|8[1-4])\s?([0-9]\s?){6,7}$/,
+ 'fa-IR': /^(\+?98[\-\s]?|0)9[0-39]\d[\-\s]?\d{3}[\-\s]?\d{4}$/,
+ 'fi-FI': /^(\+?358|0)\s?(4[0-6]|50)\s?(\d\s?){4,8}$/,
+ 'fj-FJ': /^(\+?679)?\s?\d{3}\s?\d{4}$/,
+ 'fo-FO': /^(\+?298)?\s?\d{2}\s?\d{2}\s?\d{2}$/,
+ 'fr-BF': /^(\+226|0)[67]\d{7}$/,
+ 'fr-BJ': /^(\+229)\d{8}$/,
+ 'fr-CD': /^(\+?243|0)?(8|9)\d{8}$/,
+ 'fr-CM': /^(\+?237)6[0-9]{8}$/,
+ 'fr-FR': /^(\+?33|0)[67]\d{8}$/,
+ 'fr-GF': /^(\+?594|0|00594)[67]\d{8}$/,
+ 'fr-GP': /^(\+?590|0|00590)[67]\d{8}$/,
+ 'fr-MQ': /^(\+?596|0|00596)[67]\d{8}$/,
+ 'fr-PF': /^(\+?689)?8[789]\d{6}$/,
+ 'fr-RE': /^(\+?262|0|00262)[67]\d{8}$/,
+ 'he-IL': /^(\+972|0)([23489]|5[012345689]|77)[1-9]\d{6}$/,
+ 'hu-HU': /^(\+?36|06)(20|30|31|50|70)\d{7}$/,
+ 'id-ID': /^(\+?62|0)8(1[123456789]|2[1238]|3[1238]|5[12356789]|7[78]|9[56789]|8[123456789])([\s?|\d]{5,11})$/,
+ 'ir-IR': /^(\+98|0)?9\d{9}$/,
+ 'it-IT': /^(\+?39)?\s?3\d{2} ?\d{6,7}$/,
+ 'it-SM': /^((\+378)|(0549)|(\+390549)|(\+3780549))?6\d{5,9}$/,
+ 'ja-JP': /^(\+81[ \-]?(\(0\))?|0)[6789]0[ \-]?\d{4}[ \-]?\d{4}$/,
+ 'ka-GE': /^(\+?995)?(79\d{7}|5\d{8})$/,
+ 'kk-KZ': /^(\+?7|8)?7\d{9}$/,
+ 'kl-GL': /^(\+?299)?\s?\d{2}\s?\d{2}\s?\d{2}$/,
+ 'ko-KR': /^((\+?82)[ \-]?)?0?1([0|1|6|7|8|9]{1})[ \-]?\d{3,4}[ \-]?\d{4}$/,
+ 'ky-KG': /^(\+?7\s?\+?7|0)\s?\d{2}\s?\d{3}\s?\d{4}$/,
+ 'lt-LT': /^(\+370|8)\d{8}$/,
+ 'lv-LV': /^(\+?371)2\d{7}$/,
+ 'mg-MG': /^((\+?261|0)(2|3)\d)?\d{7}$/,
+ 'mn-MN': /^(\+|00|011)?976(77|81|88|91|94|95|96|99)\d{6}$/,
+ 'my-MM': /^(\+?959|09|9)(2[5-7]|3[1-2]|4[0-5]|6[6-9]|7[5-9]|9[6-9])[0-9]{7}$/,
+ 'ms-MY': /^(\+?60|0)1(([0145](-|\s)?\d{7,8})|([236-9](-|\s)?\d{7}))$/,
+ 'mz-MZ': /^(\+?258)?8[234567]\d{7}$/,
+ 'nb-NO': /^(\+?47)?[49]\d{7}$/,
+ 'ne-NP': /^(\+?977)?9[78]\d{8}$/,
+ 'nl-BE': /^(\+?32|0)4\d{8}$/,
+ 'nl-NL': /^(((\+|00)?31\(0\))|((\+|00)?31)|0)6{1}\d{8}$/,
+ 'nl-AW': /^(\+)?297(56|59|64|73|74|99)\d{5}$/,
+ 'nn-NO': /^(\+?47)?[49]\d{7}$/,
+ 'pl-PL': /^(\+?48)? ?[5-8]\d ?\d{3} ?\d{2} ?\d{2}$/,
+ 'pt-BR': /^((\+?55\ ?[1-9]{2}\ ?)|(\+?55\ ?\([1-9]{2}\)\ ?)|(0[1-9]{2}\ ?)|(\([1-9]{2}\)\ ?)|([1-9]{2}\ ?))((\d{4}\-?\d{4})|(9[1-9]{1}\d{3}\-?\d{4}))$/,
+ 'pt-PT': /^(\+?351)?9[1236]\d{7}$/,
+ 'pt-AO': /^(\+244)\d{9}$/,
+ 'ro-MD': /^(\+?373|0)((6(0|1|2|6|7|8|9))|(7(6|7|8|9)))\d{6}$/,
+ 'ro-RO': /^(\+?40|0)\s?7\d{2}(\/|\s|\.|-)?\d{3}(\s|\.|-)?\d{3}$/,
+ 'ru-RU': /^(\+?7|8)?9\d{9}$/,
+ 'si-LK': /^(?:0|94|\+94)?(7(0|1|2|4|5|6|7|8)( |-)?)\d{7}$/,
+ 'sl-SI': /^(\+386\s?|0)(\d{1}\s?\d{3}\s?\d{2}\s?\d{2}|\d{2}\s?\d{3}\s?\d{3})$/,
+ 'sk-SK': /^(\+?421)? ?[1-9][0-9]{2} ?[0-9]{3} ?[0-9]{3}$/,
+ 'sq-AL': /^(\+355|0)6[789]\d{6}$/,
+ 'sr-RS': /^(\+3816|06)[- \d]{5,9}$/,
+ 'sv-SE': /^(\+?46|0)[\s\-]?7[\s\-]?[02369]([\s\-]?\d){7}$/,
+ 'tg-TJ': /^(\+?992)?[5][5]\d{7}$/,
+ 'th-TH': /^(\+66|66|0)\d{9}$/,
+ 'tr-TR': /^(\+?90|0)?5\d{9}$/,
+ 'tk-TM': /^(\+993|993|8)\d{8}$/,
+ 'uk-UA': /^(\+?38|8)?0\d{9}$/,
+ 'uz-UZ': /^(\+?998)?(6[125-79]|7[1-69]|88|9\d)\d{7}$/,
+ 'vi-VN': /^((\+?84)|0)((3([2-9]))|(5([25689]))|(7([0|6-9]))|(8([1-9]))|(9([0-9])))([0-9]{7})$/,
+ 'zh-CN': /^((\+|00)86)?(1[3-9]|9[28])\d{9}$/,
+ 'zh-TW': /^(\+?886\-?|0)?9\d{8}$/,
+ 'dz-BT': /^(\+?975|0)?(17|16|77|02)\d{6}$/,
+ 'ar-YE': /^(((\+|00)9677|0?7)[0137]\d{7}|((\+|00)967|0)[1-7]\d{6})$/,
+ 'ar-EH': /^(\+?212|0)[\s\-]?(5288|5289)[\s\-]?\d{5}$/,
+ 'fa-AF': /^(\+93|0)?(2{1}[0-8]{1}|[3-5]{1}[0-4]{1})(\d{7})$/
+};
+/* eslint-enable max-len */
+// aliases
+
+phones['en-CA'] = phones['en-US'];
+phones['fr-CA'] = phones['en-CA'];
+phones['fr-BE'] = phones['nl-BE'];
+phones['zh-HK'] = phones['en-HK'];
+phones['zh-MO'] = phones['en-MO'];
+phones['ga-IE'] = phones['en-IE'];
+phones['fr-CH'] = phones['de-CH'];
+phones['it-CH'] = phones['fr-CH'];
+export default function isMobilePhone(str, locale, options) {
+ assertString(str);
+
+ if (options && options.strictMode && !str.startsWith('+')) {
+ return false;
+ }
+
+ if (Array.isArray(locale)) {
+ return locale.some(function (key) {
+ // https://github.com/gotwarlost/istanbul/blob/master/ignoring-code-for-coverage.md#ignoring-code-for-coverage-purposes
+ // istanbul ignore else
+ if (phones.hasOwnProperty(key)) {
+ var phone = phones[key];
+
+ if (phone.test(str)) {
+ return true;
+ }
+ }
+
+ return false;
+ });
+ } else if (locale in phones) {
+ return phones[locale].test(str); // alias falsey locale as 'any'
+ } else if (!locale || locale === 'any') {
+ for (var key in phones) {
+ // istanbul ignore else
+ if (phones.hasOwnProperty(key)) {
+ var phone = phones[key];
+
+ if (phone.test(str)) {
+ return true;
+ }
+ }
+ }
+
+ return false;
+ }
+
+ throw new Error("Invalid locale '".concat(locale, "'"));
+}
+export var locales = Object.keys(phones); \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isMongoId.js b/includes/external/addressbook/node_modules/validator/es/lib/isMongoId.js
new file mode 100644
index 0000000..fc87b89
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isMongoId.js
@@ -0,0 +1,6 @@
+import assertString from './util/assertString';
+import isHexadecimal from './isHexadecimal';
+export default function isMongoId(str) {
+ assertString(str);
+ return isHexadecimal(str) && str.length === 24;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isMultibyte.js b/includes/external/addressbook/node_modules/validator/es/lib/isMultibyte.js
new file mode 100644
index 0000000..7a13857
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isMultibyte.js
@@ -0,0 +1,10 @@
+import assertString from './util/assertString';
+/* eslint-disable no-control-regex */
+
+var multibyte = /[^\x00-\x7F]/;
+/* eslint-enable no-control-regex */
+
+export default function isMultibyte(str) {
+ assertString(str);
+ return multibyte.test(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isNumeric.js b/includes/external/addressbook/node_modules/validator/es/lib/isNumeric.js
new file mode 100644
index 0000000..398fb82
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isNumeric.js
@@ -0,0 +1,12 @@
+import assertString from './util/assertString';
+import { decimal } from './alpha';
+var numericNoSymbols = /^[0-9]+$/;
+export default function isNumeric(str, options) {
+ assertString(str);
+
+ if (options && options.no_symbols) {
+ return numericNoSymbols.test(str);
+ }
+
+ return new RegExp("^[+-]?([0-9]*[".concat((options || {}).locale ? decimal[options.locale] : '.', "])?[0-9]+$")).test(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isOctal.js b/includes/external/addressbook/node_modules/validator/es/lib/isOctal.js
new file mode 100644
index 0000000..3ec51dd
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isOctal.js
@@ -0,0 +1,6 @@
+import assertString from './util/assertString';
+var octal = /^(0o)?[0-7]+$/i;
+export default function isOctal(str) {
+ assertString(str);
+ return octal.test(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isPassportNumber.js b/includes/external/addressbook/node_modules/validator/es/lib/isPassportNumber.js
new file mode 100644
index 0000000..09216f0
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isPassportNumber.js
@@ -0,0 +1,144 @@
+import assertString from './util/assertString';
+/**
+ * Reference:
+ * https://en.wikipedia.org/ -- Wikipedia
+ * https://docs.microsoft.com/en-us/microsoft-365/compliance/eu-passport-number -- EU Passport Number
+ * https://countrycode.org/ -- Country Codes
+ */
+
+var passportRegexByCountryCode = {
+ AM: /^[A-Z]{2}\d{7}$/,
+ // ARMENIA
+ AR: /^[A-Z]{3}\d{6}$/,
+ // ARGENTINA
+ AT: /^[A-Z]\d{7}$/,
+ // AUSTRIA
+ AU: /^[A-Z]\d{7}$/,
+ // AUSTRALIA
+ AZ: /^[A-Z]{2,3}\d{7,8}$/,
+ // AZERBAIJAN
+ BE: /^[A-Z]{2}\d{6}$/,
+ // BELGIUM
+ BG: /^\d{9}$/,
+ // BULGARIA
+ BR: /^[A-Z]{2}\d{6}$/,
+ // BRAZIL
+ BY: /^[A-Z]{2}\d{7}$/,
+ // BELARUS
+ CA: /^[A-Z]{2}\d{6}$/,
+ // CANADA
+ CH: /^[A-Z]\d{7}$/,
+ // SWITZERLAND
+ CN: /^G\d{8}$|^E(?![IO])[A-Z0-9]\d{7}$/,
+ // CHINA [G=Ordinary, E=Electronic] followed by 8-digits, or E followed by any UPPERCASE letter (except I and O) followed by 7 digits
+ CY: /^[A-Z](\d{6}|\d{8})$/,
+ // CYPRUS
+ CZ: /^\d{8}$/,
+ // CZECH REPUBLIC
+ DE: /^[CFGHJKLMNPRTVWXYZ0-9]{9}$/,
+ // GERMANY
+ DK: /^\d{9}$/,
+ // DENMARK
+ DZ: /^\d{9}$/,
+ // ALGERIA
+ EE: /^([A-Z]\d{7}|[A-Z]{2}\d{7})$/,
+ // ESTONIA (K followed by 7-digits), e-passports have 2 UPPERCASE followed by 7 digits
+ ES: /^[A-Z0-9]{2}([A-Z0-9]?)\d{6}$/,
+ // SPAIN
+ FI: /^[A-Z]{2}\d{7}$/,
+ // FINLAND
+ FR: /^\d{2}[A-Z]{2}\d{5}$/,
+ // FRANCE
+ GB: /^\d{9}$/,
+ // UNITED KINGDOM
+ GR: /^[A-Z]{2}\d{7}$/,
+ // GREECE
+ HR: /^\d{9}$/,
+ // CROATIA
+ HU: /^[A-Z]{2}(\d{6}|\d{7})$/,
+ // HUNGARY
+ IE: /^[A-Z0-9]{2}\d{7}$/,
+ // IRELAND
+ IN: /^[A-Z]{1}-?\d{7}$/,
+ // INDIA
+ ID: /^[A-C]\d{7}$/,
+ // INDONESIA
+ IR: /^[A-Z]\d{8}$/,
+ // IRAN
+ IS: /^(A)\d{7}$/,
+ // ICELAND
+ IT: /^[A-Z0-9]{2}\d{7}$/,
+ // ITALY
+ JM: /^[Aa]\d{7}$/,
+ // JAMAICA
+ JP: /^[A-Z]{2}\d{7}$/,
+ // JAPAN
+ KR: /^[MS]\d{8}$/,
+ // SOUTH KOREA, REPUBLIC OF KOREA, [S=PS Passports, M=PM Passports]
+ KZ: /^[a-zA-Z]\d{7}$/,
+ // KAZAKHSTAN
+ LI: /^[a-zA-Z]\d{5}$/,
+ // LIECHTENSTEIN
+ LT: /^[A-Z0-9]{8}$/,
+ // LITHUANIA
+ LU: /^[A-Z0-9]{8}$/,
+ // LUXEMBURG
+ LV: /^[A-Z0-9]{2}\d{7}$/,
+ // LATVIA
+ LY: /^[A-Z0-9]{8}$/,
+ // LIBYA
+ MT: /^\d{7}$/,
+ // MALTA
+ MZ: /^([A-Z]{2}\d{7})|(\d{2}[A-Z]{2}\d{5})$/,
+ // MOZAMBIQUE
+ MY: /^[AHK]\d{8}$/,
+ // MALAYSIA
+ MX: /^\d{10,11}$/,
+ // MEXICO
+ NL: /^[A-Z]{2}[A-Z0-9]{6}\d$/,
+ // NETHERLANDS
+ NZ: /^([Ll]([Aa]|[Dd]|[Ff]|[Hh])|[Ee]([Aa]|[Pp])|[Nn])\d{6}$/,
+ // NEW ZEALAND
+ PH: /^([A-Z](\d{6}|\d{7}[A-Z]))|([A-Z]{2}(\d{6}|\d{7}))$/,
+ // PHILIPPINES
+ PK: /^[A-Z]{2}\d{7}$/,
+ // PAKISTAN
+ PL: /^[A-Z]{2}\d{7}$/,
+ // POLAND
+ PT: /^[A-Z]\d{6}$/,
+ // PORTUGAL
+ RO: /^\d{8,9}$/,
+ // ROMANIA
+ RU: /^\d{9}$/,
+ // RUSSIAN FEDERATION
+ SE: /^\d{8}$/,
+ // SWEDEN
+ SL: /^(P)[A-Z]\d{7}$/,
+ // SLOVENIA
+ SK: /^[0-9A-Z]\d{7}$/,
+ // SLOVAKIA
+ TH: /^[A-Z]{1,2}\d{6,7}$/,
+ // THAILAND
+ TR: /^[A-Z]\d{8}$/,
+ // TURKEY
+ UA: /^[A-Z]{2}\d{6}$/,
+ // UKRAINE
+ US: /^\d{9}$/ // UNITED STATES
+
+};
+/**
+ * Check if str is a valid passport number
+ * relative to provided ISO Country Code.
+ *
+ * @param {string} str
+ * @param {string} countryCode
+ * @return {boolean}
+ */
+
+export default function isPassportNumber(str, countryCode) {
+ assertString(str);
+ /** Remove All Whitespaces, Convert to UPPERCASE */
+
+ var normalizedStr = str.replace(/\s/g, '').toUpperCase();
+ return countryCode.toUpperCase() in passportRegexByCountryCode && passportRegexByCountryCode[countryCode].test(normalizedStr);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isPort.js b/includes/external/addressbook/node_modules/validator/es/lib/isPort.js
new file mode 100644
index 0000000..6490cad
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isPort.js
@@ -0,0 +1,7 @@
+import isInt from './isInt';
+export default function isPort(str) {
+ return isInt(str, {
+ min: 0,
+ max: 65535
+ });
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isPostalCode.js b/includes/external/addressbook/node_modules/validator/es/lib/isPostalCode.js
new file mode 100644
index 0000000..eddf454
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isPostalCode.js
@@ -0,0 +1,98 @@
+import assertString from './util/assertString'; // common patterns
+
+var threeDigit = /^\d{3}$/;
+var fourDigit = /^\d{4}$/;
+var fiveDigit = /^\d{5}$/;
+var sixDigit = /^\d{6}$/;
+var patterns = {
+ AD: /^AD\d{3}$/,
+ AT: fourDigit,
+ AU: fourDigit,
+ AZ: /^AZ\d{4}$/,
+ BA: /^([7-8]\d{4}$)/,
+ BE: fourDigit,
+ BG: fourDigit,
+ BR: /^\d{5}-\d{3}$/,
+ BY: /^2[1-4]\d{4}$/,
+ CA: /^[ABCEGHJKLMNPRSTVXY]\d[ABCEGHJ-NPRSTV-Z][\s\-]?\d[ABCEGHJ-NPRSTV-Z]\d$/i,
+ CH: fourDigit,
+ CN: /^(0[1-7]|1[012356]|2[0-7]|3[0-6]|4[0-7]|5[1-7]|6[1-7]|7[1-5]|8[1345]|9[09])\d{4}$/,
+ CZ: /^\d{3}\s?\d{2}$/,
+ DE: fiveDigit,
+ DK: fourDigit,
+ DO: fiveDigit,
+ DZ: fiveDigit,
+ EE: fiveDigit,
+ ES: /^(5[0-2]{1}|[0-4]{1}\d{1})\d{3}$/,
+ FI: fiveDigit,
+ FR: /^\d{2}\s?\d{3}$/,
+ GB: /^(gir\s?0aa|[a-z]{1,2}\d[\da-z]?\s?(\d[a-z]{2})?)$/i,
+ GR: /^\d{3}\s?\d{2}$/,
+ HR: /^([1-5]\d{4}$)/,
+ HT: /^HT\d{4}$/,
+ HU: fourDigit,
+ ID: fiveDigit,
+ IE: /^(?!.*(?:o))[A-Za-z]\d[\dw]\s\w{4}$/i,
+ IL: /^(\d{5}|\d{7})$/,
+ IN: /^((?!10|29|35|54|55|65|66|86|87|88|89)[1-9][0-9]{5})$/,
+ IR: /^(?!(\d)\1{3})[13-9]{4}[1346-9][013-9]{5}$/,
+ IS: threeDigit,
+ IT: fiveDigit,
+ JP: /^\d{3}\-\d{4}$/,
+ KE: fiveDigit,
+ KR: /^(\d{5}|\d{6})$/,
+ LI: /^(948[5-9]|949[0-7])$/,
+ LT: /^LT\-\d{5}$/,
+ LU: fourDigit,
+ LV: /^LV\-\d{4}$/,
+ LK: fiveDigit,
+ MG: threeDigit,
+ MX: fiveDigit,
+ MT: /^[A-Za-z]{3}\s{0,1}\d{4}$/,
+ MY: fiveDigit,
+ NL: /^\d{4}\s?[a-z]{2}$/i,
+ NO: fourDigit,
+ NP: /^(10|21|22|32|33|34|44|45|56|57)\d{3}$|^(977)$/i,
+ NZ: fourDigit,
+ PL: /^\d{2}\-\d{3}$/,
+ PR: /^00[679]\d{2}([ -]\d{4})?$/,
+ PT: /^\d{4}\-\d{3}?$/,
+ RO: sixDigit,
+ RU: sixDigit,
+ SA: fiveDigit,
+ SE: /^[1-9]\d{2}\s?\d{2}$/,
+ SG: sixDigit,
+ SI: fourDigit,
+ SK: /^\d{3}\s?\d{2}$/,
+ TH: fiveDigit,
+ TN: fourDigit,
+ TW: /^\d{3}(\d{2})?$/,
+ UA: fiveDigit,
+ US: /^\d{5}(-\d{4})?$/,
+ ZA: fourDigit,
+ ZM: fiveDigit
+};
+export var locales = Object.keys(patterns);
+export default function isPostalCode(str, locale) {
+ assertString(str);
+
+ if (locale in patterns) {
+ return patterns[locale].test(str);
+ } else if (locale === 'any') {
+ for (var key in patterns) {
+ // https://github.com/gotwarlost/istanbul/blob/master/ignoring-code-for-coverage.md#ignoring-code-for-coverage-purposes
+ // istanbul ignore else
+ if (patterns.hasOwnProperty(key)) {
+ var pattern = patterns[key];
+
+ if (pattern.test(str)) {
+ return true;
+ }
+ }
+ }
+
+ return false;
+ }
+
+ throw new Error("Invalid locale '".concat(locale, "'"));
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isRFC3339.js b/includes/external/addressbook/node_modules/validator/es/lib/isRFC3339.js
new file mode 100644
index 0000000..b9926ed
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isRFC3339.js
@@ -0,0 +1,20 @@
+import assertString from './util/assertString';
+/* Based on https://tools.ietf.org/html/rfc3339#section-5.6 */
+
+var dateFullYear = /[0-9]{4}/;
+var dateMonth = /(0[1-9]|1[0-2])/;
+var dateMDay = /([12]\d|0[1-9]|3[01])/;
+var timeHour = /([01][0-9]|2[0-3])/;
+var timeMinute = /[0-5][0-9]/;
+var timeSecond = /([0-5][0-9]|60)/;
+var timeSecFrac = /(\.[0-9]+)?/;
+var timeNumOffset = new RegExp("[-+]".concat(timeHour.source, ":").concat(timeMinute.source));
+var timeOffset = new RegExp("([zZ]|".concat(timeNumOffset.source, ")"));
+var partialTime = new RegExp("".concat(timeHour.source, ":").concat(timeMinute.source, ":").concat(timeSecond.source).concat(timeSecFrac.source));
+var fullDate = new RegExp("".concat(dateFullYear.source, "-").concat(dateMonth.source, "-").concat(dateMDay.source));
+var fullTime = new RegExp("".concat(partialTime.source).concat(timeOffset.source));
+var rfc3339 = new RegExp("^".concat(fullDate.source, "[ tT]").concat(fullTime.source, "$"));
+export default function isRFC3339(str) {
+ assertString(str);
+ return rfc3339.test(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isRgbColor.js b/includes/external/addressbook/node_modules/validator/es/lib/isRgbColor.js
new file mode 100644
index 0000000..5b9798d
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isRgbColor.js
@@ -0,0 +1,15 @@
+import assertString from './util/assertString';
+var rgbColor = /^rgb\((([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5]),){2}([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\)$/;
+var rgbaColor = /^rgba\((([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5]),){3}(0?\.\d|1(\.0)?|0(\.0)?)\)$/;
+var rgbColorPercent = /^rgb\((([0-9]%|[1-9][0-9]%|100%),){2}([0-9]%|[1-9][0-9]%|100%)\)$/;
+var rgbaColorPercent = /^rgba\((([0-9]%|[1-9][0-9]%|100%),){3}(0?\.\d|1(\.0)?|0(\.0)?)\)$/;
+export default function isRgbColor(str) {
+ var includePercentValues = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
+ assertString(str);
+
+ if (!includePercentValues) {
+ return rgbColor.test(str) || rgbaColor.test(str);
+ }
+
+ return rgbColor.test(str) || rgbaColor.test(str) || rgbColorPercent.test(str) || rgbaColorPercent.test(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isSemVer.js b/includes/external/addressbook/node_modules/validator/es/lib/isSemVer.js
new file mode 100644
index 0000000..f6dd9bd
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isSemVer.js
@@ -0,0 +1,14 @@
+import assertString from './util/assertString';
+import multilineRegexp from './util/multilineRegex';
+/**
+ * Regular Expression to match
+ * semantic versioning (SemVer)
+ * built from multi-line, multi-parts regexp
+ * Reference: https://semver.org/
+ */
+
+var semanticVersioningRegex = multilineRegexp(['^(0|[1-9]\\d*)\\.(0|[1-9]\\d*)\\.(0|[1-9]\\d*)', '(?:-((?:0|[1-9]\\d*|\\d*[a-z-][0-9a-z-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-z-][0-9a-z-]*))*))', '?(?:\\+([0-9a-z-]+(?:\\.[0-9a-z-]+)*))?$'], 'i');
+export default function isSemVer(str) {
+ assertString(str);
+ return semanticVersioningRegex.test(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isSlug.js b/includes/external/addressbook/node_modules/validator/es/lib/isSlug.js
new file mode 100644
index 0000000..b9659ef
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isSlug.js
@@ -0,0 +1,6 @@
+import assertString from './util/assertString';
+var charsetRegex = /^[^\s-_](?!.*?[-_]{2,})[a-z0-9-\\][^\s]*[^-_\s]$/;
+export default function isSlug(str) {
+ assertString(str);
+ return charsetRegex.test(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isStrongPassword.js b/includes/external/addressbook/node_modules/validator/es/lib/isStrongPassword.js
new file mode 100644
index 0000000..d8673ea
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isStrongPassword.js
@@ -0,0 +1,101 @@
+import merge from './util/merge';
+import assertString from './util/assertString';
+var upperCaseRegex = /^[A-Z]$/;
+var lowerCaseRegex = /^[a-z]$/;
+var numberRegex = /^[0-9]$/;
+var symbolRegex = /^[-#!$@£%^&*()_+|~=`{}\[\]:";'<>?,.\/ ]$/;
+var defaultOptions = {
+ minLength: 8,
+ minLowercase: 1,
+ minUppercase: 1,
+ minNumbers: 1,
+ minSymbols: 1,
+ returnScore: false,
+ pointsPerUnique: 1,
+ pointsPerRepeat: 0.5,
+ pointsForContainingLower: 10,
+ pointsForContainingUpper: 10,
+ pointsForContainingNumber: 10,
+ pointsForContainingSymbol: 10
+};
+/* Counts number of occurrences of each char in a string
+ * could be moved to util/ ?
+*/
+
+function countChars(str) {
+ var result = {};
+ Array.from(str).forEach(function (_char) {
+ var curVal = result[_char];
+
+ if (curVal) {
+ result[_char] += 1;
+ } else {
+ result[_char] = 1;
+ }
+ });
+ return result;
+}
+/* Return information about a password */
+
+
+function analyzePassword(password) {
+ var charMap = countChars(password);
+ var analysis = {
+ length: password.length,
+ uniqueChars: Object.keys(charMap).length,
+ uppercaseCount: 0,
+ lowercaseCount: 0,
+ numberCount: 0,
+ symbolCount: 0
+ };
+ Object.keys(charMap).forEach(function (_char2) {
+ /* istanbul ignore else */
+ if (upperCaseRegex.test(_char2)) {
+ analysis.uppercaseCount += charMap[_char2];
+ } else if (lowerCaseRegex.test(_char2)) {
+ analysis.lowercaseCount += charMap[_char2];
+ } else if (numberRegex.test(_char2)) {
+ analysis.numberCount += charMap[_char2];
+ } else if (symbolRegex.test(_char2)) {
+ analysis.symbolCount += charMap[_char2];
+ }
+ });
+ return analysis;
+}
+
+function scorePassword(analysis, scoringOptions) {
+ var points = 0;
+ points += analysis.uniqueChars * scoringOptions.pointsPerUnique;
+ points += (analysis.length - analysis.uniqueChars) * scoringOptions.pointsPerRepeat;
+
+ if (analysis.lowercaseCount > 0) {
+ points += scoringOptions.pointsForContainingLower;
+ }
+
+ if (analysis.uppercaseCount > 0) {
+ points += scoringOptions.pointsForContainingUpper;
+ }
+
+ if (analysis.numberCount > 0) {
+ points += scoringOptions.pointsForContainingNumber;
+ }
+
+ if (analysis.symbolCount > 0) {
+ points += scoringOptions.pointsForContainingSymbol;
+ }
+
+ return points;
+}
+
+export default function isStrongPassword(str) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;
+ assertString(str);
+ var analysis = analyzePassword(str);
+ options = merge(options || {}, defaultOptions);
+
+ if (options.returnScore) {
+ return scorePassword(analysis, options);
+ }
+
+ return analysis.length >= options.minLength && analysis.lowercaseCount >= options.minLowercase && analysis.uppercaseCount >= options.minUppercase && analysis.numberCount >= options.minNumbers && analysis.symbolCount >= options.minSymbols;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isSurrogatePair.js b/includes/external/addressbook/node_modules/validator/es/lib/isSurrogatePair.js
new file mode 100644
index 0000000..1e0efb2
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isSurrogatePair.js
@@ -0,0 +1,6 @@
+import assertString from './util/assertString';
+var surrogatePair = /[\uD800-\uDBFF][\uDC00-\uDFFF]/;
+export default function isSurrogatePair(str) {
+ assertString(str);
+ return surrogatePair.test(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isTaxID.js b/includes/external/addressbook/node_modules/validator/es/lib/isTaxID.js
new file mode 100644
index 0000000..b5607f4
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isTaxID.js
@@ -0,0 +1,1543 @@
+function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
+
+function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
+
+function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
+
+function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter); }
+
+function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
+
+function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
+
+import assertString from './util/assertString';
+import * as algorithms from './util/algorithms';
+import isDate from './isDate';
+/**
+ * TIN Validation
+ * Validates Tax Identification Numbers (TINs) from the US, EU member states and the United Kingdom.
+ *
+ * EU-UK:
+ * National TIN validity is calculated using public algorithms as made available by DG TAXUD.
+ *
+ * See `https://ec.europa.eu/taxation_customs/tin/specs/FS-TIN%20Algorithms-Public.docx` for more information.
+ *
+ * US:
+ * An Employer Identification Number (EIN), also known as a Federal Tax Identification Number,
+ * is used to identify a business entity.
+ *
+ * NOTES:
+ * - Prefix 47 is being reserved for future use
+ * - Prefixes 26, 27, 45, 46 and 47 were previously assigned by the Philadelphia campus.
+ *
+ * See `http://www.irs.gov/Businesses/Small-Businesses-&-Self-Employed/How-EINs-are-Assigned-and-Valid-EIN-Prefixes`
+ * for more information.
+ */
+// Locale functions
+
+/*
+ * bg-BG validation function
+ * (Edinen graždanski nomer (EGN/ЕГН), persons only)
+ * Checks if birth date (first six digits) is valid and calculates check (last) digit
+ */
+
+function bgBgCheck(tin) {
+ // Extract full year, normalize month and check birth date validity
+ var century_year = tin.slice(0, 2);
+ var month = parseInt(tin.slice(2, 4), 10);
+
+ if (month > 40) {
+ month -= 40;
+ century_year = "20".concat(century_year);
+ } else if (month > 20) {
+ month -= 20;
+ century_year = "18".concat(century_year);
+ } else {
+ century_year = "19".concat(century_year);
+ }
+
+ if (month < 10) {
+ month = "0".concat(month);
+ }
+
+ var date = "".concat(century_year, "/").concat(month, "/").concat(tin.slice(4, 6));
+
+ if (!isDate(date, 'YYYY/MM/DD')) {
+ return false;
+ } // split digits into an array for further processing
+
+
+ var digits = tin.split('').map(function (a) {
+ return parseInt(a, 10);
+ }); // Calculate checksum by multiplying digits with fixed values
+
+ var multip_lookup = [2, 4, 8, 5, 10, 9, 7, 3, 6];
+ var checksum = 0;
+
+ for (var i = 0; i < multip_lookup.length; i++) {
+ checksum += digits[i] * multip_lookup[i];
+ }
+
+ checksum = checksum % 11 === 10 ? 0 : checksum % 11;
+ return checksum === digits[9];
+}
+/**
+ * Check if an input is a valid Canadian SIN (Social Insurance Number)
+ *
+ * The Social Insurance Number (SIN) is a 9 digit number that
+ * you need to work in Canada or to have access to government programs and benefits.
+ *
+ * https://en.wikipedia.org/wiki/Social_Insurance_Number
+ * https://www.canada.ca/en/employment-social-development/services/sin.html
+ * https://www.codercrunch.com/challenge/819302488/sin-validator
+ *
+ * @param {string} input
+ * @return {boolean}
+ */
+
+
+function isCanadianSIN(input) {
+ var digitsArray = input.split('');
+ var even = digitsArray.filter(function (_, idx) {
+ return idx % 2;
+ }).map(function (i) {
+ return Number(i) * 2;
+ }).join('').split('');
+ var total = digitsArray.filter(function (_, idx) {
+ return !(idx % 2);
+ }).concat(even).map(function (i) {
+ return Number(i);
+ }).reduce(function (acc, cur) {
+ return acc + cur;
+ });
+ return total % 10 === 0;
+}
+/*
+ * cs-CZ validation function
+ * (Rodné číslo (RČ), persons only)
+ * Checks if birth date (first six digits) is valid and divisibility by 11
+ * Material not in DG TAXUD document sourced from:
+ * -`https://lorenc.info/3MA381/overeni-spravnosti-rodneho-cisla.htm`
+ * -`https://www.mvcr.cz/clanek/rady-a-sluzby-dokumenty-rodne-cislo.aspx`
+ */
+
+
+function csCzCheck(tin) {
+ tin = tin.replace(/\W/, ''); // Extract full year from TIN length
+
+ var full_year = parseInt(tin.slice(0, 2), 10);
+
+ if (tin.length === 10) {
+ if (full_year < 54) {
+ full_year = "20".concat(full_year);
+ } else {
+ full_year = "19".concat(full_year);
+ }
+ } else {
+ if (tin.slice(6) === '000') {
+ return false;
+ } // Three-zero serial not assigned before 1954
+
+
+ if (full_year < 54) {
+ full_year = "19".concat(full_year);
+ } else {
+ return false; // No 18XX years seen in any of the resources
+ }
+ } // Add missing zero if needed
+
+
+ if (full_year.length === 3) {
+ full_year = [full_year.slice(0, 2), '0', full_year.slice(2)].join('');
+ } // Extract month from TIN and normalize
+
+
+ var month = parseInt(tin.slice(2, 4), 10);
+
+ if (month > 50) {
+ month -= 50;
+ }
+
+ if (month > 20) {
+ // Month-plus-twenty was only introduced in 2004
+ if (parseInt(full_year, 10) < 2004) {
+ return false;
+ }
+
+ month -= 20;
+ }
+
+ if (month < 10) {
+ month = "0".concat(month);
+ } // Check date validity
+
+
+ var date = "".concat(full_year, "/").concat(month, "/").concat(tin.slice(4, 6));
+
+ if (!isDate(date, 'YYYY/MM/DD')) {
+ return false;
+ } // Verify divisibility by 11
+
+
+ if (tin.length === 10) {
+ if (parseInt(tin, 10) % 11 !== 0) {
+ // Some numbers up to and including 1985 are still valid if
+ // check (last) digit equals 0 and modulo of first 9 digits equals 10
+ var checkdigit = parseInt(tin.slice(0, 9), 10) % 11;
+
+ if (parseInt(full_year, 10) < 1986 && checkdigit === 10) {
+ if (parseInt(tin.slice(9), 10) !== 0) {
+ return false;
+ }
+ } else {
+ return false;
+ }
+ }
+ }
+
+ return true;
+}
+/*
+ * de-AT validation function
+ * (Abgabenkontonummer, persons/entities)
+ * Verify TIN validity by calling luhnCheck()
+ */
+
+
+function deAtCheck(tin) {
+ return algorithms.luhnCheck(tin);
+}
+/*
+ * de-DE validation function
+ * (Steueridentifikationsnummer (Steuer-IdNr.), persons only)
+ * Tests for single duplicate/triplicate value, then calculates ISO 7064 check (last) digit
+ * Partial implementation of spec (same result with both algorithms always)
+ */
+
+
+function deDeCheck(tin) {
+ // Split digits into an array for further processing
+ var digits = tin.split('').map(function (a) {
+ return parseInt(a, 10);
+ }); // Fill array with strings of number positions
+
+ var occurences = [];
+
+ for (var i = 0; i < digits.length - 1; i++) {
+ occurences.push('');
+
+ for (var j = 0; j < digits.length - 1; j++) {
+ if (digits[i] === digits[j]) {
+ occurences[i] += j;
+ }
+ }
+ } // Remove digits with one occurence and test for only one duplicate/triplicate
+
+
+ occurences = occurences.filter(function (a) {
+ return a.length > 1;
+ });
+
+ if (occurences.length !== 2 && occurences.length !== 3) {
+ return false;
+ } // In case of triplicate value only two digits are allowed next to each other
+
+
+ if (occurences[0].length === 3) {
+ var trip_locations = occurences[0].split('').map(function (a) {
+ return parseInt(a, 10);
+ });
+ var recurrent = 0; // Amount of neighbour occurences
+
+ for (var _i = 0; _i < trip_locations.length - 1; _i++) {
+ if (trip_locations[_i] + 1 === trip_locations[_i + 1]) {
+ recurrent += 1;
+ }
+ }
+
+ if (recurrent === 2) {
+ return false;
+ }
+ }
+
+ return algorithms.iso7064Check(tin);
+}
+/*
+ * dk-DK validation function
+ * (CPR-nummer (personnummer), persons only)
+ * Checks if birth date (first six digits) is valid and assigned to century (seventh) digit,
+ * and calculates check (last) digit
+ */
+
+
+function dkDkCheck(tin) {
+ tin = tin.replace(/\W/, ''); // Extract year, check if valid for given century digit and add century
+
+ var year = parseInt(tin.slice(4, 6), 10);
+ var century_digit = tin.slice(6, 7);
+
+ switch (century_digit) {
+ case '0':
+ case '1':
+ case '2':
+ case '3':
+ year = "19".concat(year);
+ break;
+
+ case '4':
+ case '9':
+ if (year < 37) {
+ year = "20".concat(year);
+ } else {
+ year = "19".concat(year);
+ }
+
+ break;
+
+ default:
+ if (year < 37) {
+ year = "20".concat(year);
+ } else if (year > 58) {
+ year = "18".concat(year);
+ } else {
+ return false;
+ }
+
+ break;
+ } // Add missing zero if needed
+
+
+ if (year.length === 3) {
+ year = [year.slice(0, 2), '0', year.slice(2)].join('');
+ } // Check date validity
+
+
+ var date = "".concat(year, "/").concat(tin.slice(2, 4), "/").concat(tin.slice(0, 2));
+
+ if (!isDate(date, 'YYYY/MM/DD')) {
+ return false;
+ } // Split digits into an array for further processing
+
+
+ var digits = tin.split('').map(function (a) {
+ return parseInt(a, 10);
+ });
+ var checksum = 0;
+ var weight = 4; // Multiply by weight and add to checksum
+
+ for (var i = 0; i < 9; i++) {
+ checksum += digits[i] * weight;
+ weight -= 1;
+
+ if (weight === 1) {
+ weight = 7;
+ }
+ }
+
+ checksum %= 11;
+
+ if (checksum === 1) {
+ return false;
+ }
+
+ return checksum === 0 ? digits[9] === 0 : digits[9] === 11 - checksum;
+}
+/*
+ * el-CY validation function
+ * (Arithmos Forologikou Mitroou (AFM/ΑΦΜ), persons only)
+ * Verify TIN validity by calculating ASCII value of check (last) character
+ */
+
+
+function elCyCheck(tin) {
+ // split digits into an array for further processing
+ var digits = tin.slice(0, 8).split('').map(function (a) {
+ return parseInt(a, 10);
+ });
+ var checksum = 0; // add digits in even places
+
+ for (var i = 1; i < digits.length; i += 2) {
+ checksum += digits[i];
+ } // add digits in odd places
+
+
+ for (var _i2 = 0; _i2 < digits.length; _i2 += 2) {
+ if (digits[_i2] < 2) {
+ checksum += 1 - digits[_i2];
+ } else {
+ checksum += 2 * (digits[_i2] - 2) + 5;
+
+ if (digits[_i2] > 4) {
+ checksum += 2;
+ }
+ }
+ }
+
+ return String.fromCharCode(checksum % 26 + 65) === tin.charAt(8);
+}
+/*
+ * el-GR validation function
+ * (Arithmos Forologikou Mitroou (AFM/ΑΦΜ), persons/entities)
+ * Verify TIN validity by calculating check (last) digit
+ * Algorithm not in DG TAXUD document- sourced from:
+ * - `http://epixeirisi.gr/%CE%9A%CE%A1%CE%99%CE%A3%CE%99%CE%9C%CE%91-%CE%98%CE%95%CE%9C%CE%91%CE%A4%CE%91-%CE%A6%CE%9F%CE%A1%CE%9F%CE%9B%CE%9F%CE%93%CE%99%CE%91%CE%A3-%CE%9A%CE%91%CE%99-%CE%9B%CE%9F%CE%93%CE%99%CE%A3%CE%A4%CE%99%CE%9A%CE%97%CE%A3/23791/%CE%91%CF%81%CE%B9%CE%B8%CE%BC%CF%8C%CF%82-%CE%A6%CE%BF%CF%81%CE%BF%CE%BB%CE%BF%CE%B3%CE%B9%CE%BA%CE%BF%CF%8D-%CE%9C%CE%B7%CF%84%CF%81%CF%8E%CE%BF%CF%85`
+ */
+
+
+function elGrCheck(tin) {
+ // split digits into an array for further processing
+ var digits = tin.split('').map(function (a) {
+ return parseInt(a, 10);
+ });
+ var checksum = 0;
+
+ for (var i = 0; i < 8; i++) {
+ checksum += digits[i] * Math.pow(2, 8 - i);
+ }
+
+ return checksum % 11 % 10 === digits[8];
+}
+/*
+ * en-GB validation function (should go here if needed)
+ * (National Insurance Number (NINO) or Unique Taxpayer Reference (UTR),
+ * persons/entities respectively)
+ */
+
+/*
+ * en-IE validation function
+ * (Personal Public Service Number (PPS No), persons only)
+ * Verify TIN validity by calculating check (second to last) character
+ */
+
+
+function enIeCheck(tin) {
+ var checksum = algorithms.reverseMultiplyAndSum(tin.split('').slice(0, 7).map(function (a) {
+ return parseInt(a, 10);
+ }), 8);
+
+ if (tin.length === 9 && tin[8] !== 'W') {
+ checksum += (tin[8].charCodeAt(0) - 64) * 9;
+ }
+
+ checksum %= 23;
+
+ if (checksum === 0) {
+ return tin[7].toUpperCase() === 'W';
+ }
+
+ return tin[7].toUpperCase() === String.fromCharCode(64 + checksum);
+} // Valid US IRS campus prefixes
+
+
+var enUsCampusPrefix = {
+ andover: ['10', '12'],
+ atlanta: ['60', '67'],
+ austin: ['50', '53'],
+ brookhaven: ['01', '02', '03', '04', '05', '06', '11', '13', '14', '16', '21', '22', '23', '25', '34', '51', '52', '54', '55', '56', '57', '58', '59', '65'],
+ cincinnati: ['30', '32', '35', '36', '37', '38', '61'],
+ fresno: ['15', '24'],
+ internet: ['20', '26', '27', '45', '46', '47'],
+ kansas: ['40', '44'],
+ memphis: ['94', '95'],
+ ogden: ['80', '90'],
+ philadelphia: ['33', '39', '41', '42', '43', '46', '48', '62', '63', '64', '66', '68', '71', '72', '73', '74', '75', '76', '77', '81', '82', '83', '84', '85', '86', '87', '88', '91', '92', '93', '98', '99'],
+ sba: ['31']
+}; // Return an array of all US IRS campus prefixes
+
+function enUsGetPrefixes() {
+ var prefixes = [];
+
+ for (var location in enUsCampusPrefix) {
+ // https://github.com/gotwarlost/istanbul/blob/master/ignoring-code-for-coverage.md#ignoring-code-for-coverage-purposes
+ // istanbul ignore else
+ if (enUsCampusPrefix.hasOwnProperty(location)) {
+ prefixes.push.apply(prefixes, _toConsumableArray(enUsCampusPrefix[location]));
+ }
+ }
+
+ return prefixes;
+}
+/*
+ * en-US validation function
+ * Verify that the TIN starts with a valid IRS campus prefix
+ */
+
+
+function enUsCheck(tin) {
+ return enUsGetPrefixes().indexOf(tin.slice(0, 2)) !== -1;
+}
+/*
+ * es-ES validation function
+ * (Documento Nacional de Identidad (DNI)
+ * or Número de Identificación de Extranjero (NIE), persons only)
+ * Verify TIN validity by calculating check (last) character
+ */
+
+
+function esEsCheck(tin) {
+ // Split characters into an array for further processing
+ var chars = tin.toUpperCase().split(''); // Replace initial letter if needed
+
+ if (isNaN(parseInt(chars[0], 10)) && chars.length > 1) {
+ var lead_replace = 0;
+
+ switch (chars[0]) {
+ case 'Y':
+ lead_replace = 1;
+ break;
+
+ case 'Z':
+ lead_replace = 2;
+ break;
+
+ default:
+ }
+
+ chars.splice(0, 1, lead_replace); // Fill with zeros if smaller than proper
+ } else {
+ while (chars.length < 9) {
+ chars.unshift(0);
+ }
+ } // Calculate checksum and check according to lookup
+
+
+ var lookup = ['T', 'R', 'W', 'A', 'G', 'M', 'Y', 'F', 'P', 'D', 'X', 'B', 'N', 'J', 'Z', 'S', 'Q', 'V', 'H', 'L', 'C', 'K', 'E'];
+ chars = chars.join('');
+ var checksum = parseInt(chars.slice(0, 8), 10) % 23;
+ return chars[8] === lookup[checksum];
+}
+/*
+ * et-EE validation function
+ * (Isikukood (IK), persons only)
+ * Checks if birth date (century digit and six following) is valid and calculates check (last) digit
+ * Material not in DG TAXUD document sourced from:
+ * - `https://www.oecd.org/tax/automatic-exchange/crs-implementation-and-assistance/tax-identification-numbers/Estonia-TIN.pdf`
+ */
+
+
+function etEeCheck(tin) {
+ // Extract year and add century
+ var full_year = tin.slice(1, 3);
+ var century_digit = tin.slice(0, 1);
+
+ switch (century_digit) {
+ case '1':
+ case '2':
+ full_year = "18".concat(full_year);
+ break;
+
+ case '3':
+ case '4':
+ full_year = "19".concat(full_year);
+ break;
+
+ default:
+ full_year = "20".concat(full_year);
+ break;
+ } // Check date validity
+
+
+ var date = "".concat(full_year, "/").concat(tin.slice(3, 5), "/").concat(tin.slice(5, 7));
+
+ if (!isDate(date, 'YYYY/MM/DD')) {
+ return false;
+ } // Split digits into an array for further processing
+
+
+ var digits = tin.split('').map(function (a) {
+ return parseInt(a, 10);
+ });
+ var checksum = 0;
+ var weight = 1; // Multiply by weight and add to checksum
+
+ for (var i = 0; i < 10; i++) {
+ checksum += digits[i] * weight;
+ weight += 1;
+
+ if (weight === 10) {
+ weight = 1;
+ }
+ } // Do again if modulo 11 of checksum is 10
+
+
+ if (checksum % 11 === 10) {
+ checksum = 0;
+ weight = 3;
+
+ for (var _i3 = 0; _i3 < 10; _i3++) {
+ checksum += digits[_i3] * weight;
+ weight += 1;
+
+ if (weight === 10) {
+ weight = 1;
+ }
+ }
+
+ if (checksum % 11 === 10) {
+ return digits[10] === 0;
+ }
+ }
+
+ return checksum % 11 === digits[10];
+}
+/*
+ * fi-FI validation function
+ * (Henkilötunnus (HETU), persons only)
+ * Checks if birth date (first six digits plus century symbol) is valid
+ * and calculates check (last) digit
+ */
+
+
+function fiFiCheck(tin) {
+ // Extract year and add century
+ var full_year = tin.slice(4, 6);
+ var century_symbol = tin.slice(6, 7);
+
+ switch (century_symbol) {
+ case '+':
+ full_year = "18".concat(full_year);
+ break;
+
+ case '-':
+ full_year = "19".concat(full_year);
+ break;
+
+ default:
+ full_year = "20".concat(full_year);
+ break;
+ } // Check date validity
+
+
+ var date = "".concat(full_year, "/").concat(tin.slice(2, 4), "/").concat(tin.slice(0, 2));
+
+ if (!isDate(date, 'YYYY/MM/DD')) {
+ return false;
+ } // Calculate check character
+
+
+ var checksum = parseInt(tin.slice(0, 6) + tin.slice(7, 10), 10) % 31;
+
+ if (checksum < 10) {
+ return checksum === parseInt(tin.slice(10), 10);
+ }
+
+ checksum -= 10;
+ var letters_lookup = ['A', 'B', 'C', 'D', 'E', 'F', 'H', 'J', 'K', 'L', 'M', 'N', 'P', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y'];
+ return letters_lookup[checksum] === tin.slice(10);
+}
+/*
+ * fr/nl-BE validation function
+ * (Numéro national (N.N.), persons only)
+ * Checks if birth date (first six digits) is valid and calculates check (last two) digits
+ */
+
+
+function frBeCheck(tin) {
+ // Zero month/day value is acceptable
+ if (tin.slice(2, 4) !== '00' || tin.slice(4, 6) !== '00') {
+ // Extract date from first six digits of TIN
+ var date = "".concat(tin.slice(0, 2), "/").concat(tin.slice(2, 4), "/").concat(tin.slice(4, 6));
+
+ if (!isDate(date, 'YY/MM/DD')) {
+ return false;
+ }
+ }
+
+ var checksum = 97 - parseInt(tin.slice(0, 9), 10) % 97;
+ var checkdigits = parseInt(tin.slice(9, 11), 10);
+
+ if (checksum !== checkdigits) {
+ checksum = 97 - parseInt("2".concat(tin.slice(0, 9)), 10) % 97;
+
+ if (checksum !== checkdigits) {
+ return false;
+ }
+ }
+
+ return true;
+}
+/*
+ * fr-FR validation function
+ * (Numéro fiscal de référence (numéro SPI), persons only)
+ * Verify TIN validity by calculating check (last three) digits
+ */
+
+
+function frFrCheck(tin) {
+ tin = tin.replace(/\s/g, '');
+ var checksum = parseInt(tin.slice(0, 10), 10) % 511;
+ var checkdigits = parseInt(tin.slice(10, 13), 10);
+ return checksum === checkdigits;
+}
+/*
+ * fr/lb-LU validation function
+ * (numéro d’identification personnelle, persons only)
+ * Verify birth date validity and run Luhn and Verhoeff checks
+ */
+
+
+function frLuCheck(tin) {
+ // Extract date and check validity
+ var date = "".concat(tin.slice(0, 4), "/").concat(tin.slice(4, 6), "/").concat(tin.slice(6, 8));
+
+ if (!isDate(date, 'YYYY/MM/DD')) {
+ return false;
+ } // Run Luhn check
+
+
+ if (!algorithms.luhnCheck(tin.slice(0, 12))) {
+ return false;
+ } // Remove Luhn check digit and run Verhoeff check
+
+
+ return algorithms.verhoeffCheck("".concat(tin.slice(0, 11)).concat(tin[12]));
+}
+/*
+ * hr-HR validation function
+ * (Osobni identifikacijski broj (OIB), persons/entities)
+ * Verify TIN validity by calling iso7064Check(digits)
+ */
+
+
+function hrHrCheck(tin) {
+ return algorithms.iso7064Check(tin);
+}
+/*
+ * hu-HU validation function
+ * (Adóazonosító jel, persons only)
+ * Verify TIN validity by calculating check (last) digit
+ */
+
+
+function huHuCheck(tin) {
+ // split digits into an array for further processing
+ var digits = tin.split('').map(function (a) {
+ return parseInt(a, 10);
+ });
+ var checksum = 8;
+
+ for (var i = 1; i < 9; i++) {
+ checksum += digits[i] * (i + 1);
+ }
+
+ return checksum % 11 === digits[9];
+}
+/*
+ * lt-LT validation function (should go here if needed)
+ * (Asmens kodas, persons/entities respectively)
+ * Current validation check is alias of etEeCheck- same format applies
+ */
+
+/*
+ * it-IT first/last name validity check
+ * Accepts it-IT TIN-encoded names as a three-element character array and checks their validity
+ * Due to lack of clarity between resources ("Are only Italian consonants used?
+ * What happens if a person has X in their name?" etc.) only two test conditions
+ * have been implemented:
+ * Vowels may only be followed by other vowels or an X character
+ * and X characters after vowels may only be followed by other X characters.
+ */
+
+
+function itItNameCheck(name) {
+ // true at the first occurence of a vowel
+ var vowelflag = false; // true at the first occurence of an X AFTER vowel
+ // (to properly handle last names with X as consonant)
+
+ var xflag = false;
+
+ for (var i = 0; i < 3; i++) {
+ if (!vowelflag && /[AEIOU]/.test(name[i])) {
+ vowelflag = true;
+ } else if (!xflag && vowelflag && name[i] === 'X') {
+ xflag = true;
+ } else if (i > 0) {
+ if (vowelflag && !xflag) {
+ if (!/[AEIOU]/.test(name[i])) {
+ return false;
+ }
+ }
+
+ if (xflag) {
+ if (!/X/.test(name[i])) {
+ return false;
+ }
+ }
+ }
+ }
+
+ return true;
+}
+/*
+ * it-IT validation function
+ * (Codice fiscale (TIN-IT), persons only)
+ * Verify name, birth date and codice catastale validity
+ * and calculate check character.
+ * Material not in DG-TAXUD document sourced from:
+ * `https://en.wikipedia.org/wiki/Italian_fiscal_code`
+ */
+
+
+function itItCheck(tin) {
+ // Capitalize and split characters into an array for further processing
+ var chars = tin.toUpperCase().split(''); // Check first and last name validity calling itItNameCheck()
+
+ if (!itItNameCheck(chars.slice(0, 3))) {
+ return false;
+ }
+
+ if (!itItNameCheck(chars.slice(3, 6))) {
+ return false;
+ } // Convert letters in number spaces back to numbers if any
+
+
+ var number_locations = [6, 7, 9, 10, 12, 13, 14];
+ var number_replace = {
+ L: '0',
+ M: '1',
+ N: '2',
+ P: '3',
+ Q: '4',
+ R: '5',
+ S: '6',
+ T: '7',
+ U: '8',
+ V: '9'
+ };
+
+ for (var _i4 = 0, _number_locations = number_locations; _i4 < _number_locations.length; _i4++) {
+ var i = _number_locations[_i4];
+
+ if (chars[i] in number_replace) {
+ chars.splice(i, 1, number_replace[chars[i]]);
+ }
+ } // Extract month and day, and check date validity
+
+
+ var month_replace = {
+ A: '01',
+ B: '02',
+ C: '03',
+ D: '04',
+ E: '05',
+ H: '06',
+ L: '07',
+ M: '08',
+ P: '09',
+ R: '10',
+ S: '11',
+ T: '12'
+ };
+ var month = month_replace[chars[8]];
+ var day = parseInt(chars[9] + chars[10], 10);
+
+ if (day > 40) {
+ day -= 40;
+ }
+
+ if (day < 10) {
+ day = "0".concat(day);
+ }
+
+ var date = "".concat(chars[6]).concat(chars[7], "/").concat(month, "/").concat(day);
+
+ if (!isDate(date, 'YY/MM/DD')) {
+ return false;
+ } // Calculate check character by adding up even and odd characters as numbers
+
+
+ var checksum = 0;
+
+ for (var _i5 = 1; _i5 < chars.length - 1; _i5 += 2) {
+ var char_to_int = parseInt(chars[_i5], 10);
+
+ if (isNaN(char_to_int)) {
+ char_to_int = chars[_i5].charCodeAt(0) - 65;
+ }
+
+ checksum += char_to_int;
+ }
+
+ var odd_convert = {
+ // Maps of characters at odd places
+ A: 1,
+ B: 0,
+ C: 5,
+ D: 7,
+ E: 9,
+ F: 13,
+ G: 15,
+ H: 17,
+ I: 19,
+ J: 21,
+ K: 2,
+ L: 4,
+ M: 18,
+ N: 20,
+ O: 11,
+ P: 3,
+ Q: 6,
+ R: 8,
+ S: 12,
+ T: 14,
+ U: 16,
+ V: 10,
+ W: 22,
+ X: 25,
+ Y: 24,
+ Z: 23,
+ 0: 1,
+ 1: 0
+ };
+
+ for (var _i6 = 0; _i6 < chars.length - 1; _i6 += 2) {
+ var _char_to_int = 0;
+
+ if (chars[_i6] in odd_convert) {
+ _char_to_int = odd_convert[chars[_i6]];
+ } else {
+ var multiplier = parseInt(chars[_i6], 10);
+ _char_to_int = 2 * multiplier + 1;
+
+ if (multiplier > 4) {
+ _char_to_int += 2;
+ }
+ }
+
+ checksum += _char_to_int;
+ }
+
+ if (String.fromCharCode(65 + checksum % 26) !== chars[15]) {
+ return false;
+ }
+
+ return true;
+}
+/*
+ * lv-LV validation function
+ * (Personas kods (PK), persons only)
+ * Check validity of birth date and calculate check (last) digit
+ * Support only for old format numbers (not starting with '32', issued before 2017/07/01)
+ * Material not in DG TAXUD document sourced from:
+ * `https://boot.ritakafija.lv/forums/index.php?/topic/88314-personas-koda-algoritms-%C4%8Deksumma/`
+ */
+
+
+function lvLvCheck(tin) {
+ tin = tin.replace(/\W/, ''); // Extract date from TIN
+
+ var day = tin.slice(0, 2);
+
+ if (day !== '32') {
+ // No date/checksum check if new format
+ var month = tin.slice(2, 4);
+
+ if (month !== '00') {
+ // No date check if unknown month
+ var full_year = tin.slice(4, 6);
+
+ switch (tin[6]) {
+ case '0':
+ full_year = "18".concat(full_year);
+ break;
+
+ case '1':
+ full_year = "19".concat(full_year);
+ break;
+
+ default:
+ full_year = "20".concat(full_year);
+ break;
+ } // Check date validity
+
+
+ var date = "".concat(full_year, "/").concat(tin.slice(2, 4), "/").concat(day);
+
+ if (!isDate(date, 'YYYY/MM/DD')) {
+ return false;
+ }
+ } // Calculate check digit
+
+
+ var checksum = 1101;
+ var multip_lookup = [1, 6, 3, 7, 9, 10, 5, 8, 4, 2];
+
+ for (var i = 0; i < tin.length - 1; i++) {
+ checksum -= parseInt(tin[i], 10) * multip_lookup[i];
+ }
+
+ return parseInt(tin[10], 10) === checksum % 11;
+ }
+
+ return true;
+}
+/*
+ * mt-MT validation function
+ * (Identity Card Number or Unique Taxpayer Reference, persons/entities)
+ * Verify Identity Card Number structure (no other tests found)
+ */
+
+
+function mtMtCheck(tin) {
+ if (tin.length !== 9) {
+ // No tests for UTR
+ var chars = tin.toUpperCase().split(''); // Fill with zeros if smaller than proper
+
+ while (chars.length < 8) {
+ chars.unshift(0);
+ } // Validate format according to last character
+
+
+ switch (tin[7]) {
+ case 'A':
+ case 'P':
+ if (parseInt(chars[6], 10) === 0) {
+ return false;
+ }
+
+ break;
+
+ default:
+ {
+ var first_part = parseInt(chars.join('').slice(0, 5), 10);
+
+ if (first_part > 32000) {
+ return false;
+ }
+
+ var second_part = parseInt(chars.join('').slice(5, 7), 10);
+
+ if (first_part === second_part) {
+ return false;
+ }
+ }
+ }
+ }
+
+ return true;
+}
+/*
+ * nl-NL validation function
+ * (Burgerservicenummer (BSN) or Rechtspersonen Samenwerkingsverbanden Informatie Nummer (RSIN),
+ * persons/entities respectively)
+ * Verify TIN validity by calculating check (last) digit (variant of MOD 11)
+ */
+
+
+function nlNlCheck(tin) {
+ return algorithms.reverseMultiplyAndSum(tin.split('').slice(0, 8).map(function (a) {
+ return parseInt(a, 10);
+ }), 9) % 11 === parseInt(tin[8], 10);
+}
+/*
+ * pl-PL validation function
+ * (Powszechny Elektroniczny System Ewidencji Ludności (PESEL)
+ * or Numer identyfikacji podatkowej (NIP), persons/entities)
+ * Verify TIN validity by validating birth date (PESEL) and calculating check (last) digit
+ */
+
+
+function plPlCheck(tin) {
+ // NIP
+ if (tin.length === 10) {
+ // Calculate last digit by multiplying with lookup
+ var lookup = [6, 5, 7, 2, 3, 4, 5, 6, 7];
+ var _checksum = 0;
+
+ for (var i = 0; i < lookup.length; i++) {
+ _checksum += parseInt(tin[i], 10) * lookup[i];
+ }
+
+ _checksum %= 11;
+
+ if (_checksum === 10) {
+ return false;
+ }
+
+ return _checksum === parseInt(tin[9], 10);
+ } // PESEL
+ // Extract full year using month
+
+
+ var full_year = tin.slice(0, 2);
+ var month = parseInt(tin.slice(2, 4), 10);
+
+ if (month > 80) {
+ full_year = "18".concat(full_year);
+ month -= 80;
+ } else if (month > 60) {
+ full_year = "22".concat(full_year);
+ month -= 60;
+ } else if (month > 40) {
+ full_year = "21".concat(full_year);
+ month -= 40;
+ } else if (month > 20) {
+ full_year = "20".concat(full_year);
+ month -= 20;
+ } else {
+ full_year = "19".concat(full_year);
+ } // Add leading zero to month if needed
+
+
+ if (month < 10) {
+ month = "0".concat(month);
+ } // Check date validity
+
+
+ var date = "".concat(full_year, "/").concat(month, "/").concat(tin.slice(4, 6));
+
+ if (!isDate(date, 'YYYY/MM/DD')) {
+ return false;
+ } // Calculate last digit by mulitplying with odd one-digit numbers except 5
+
+
+ var checksum = 0;
+ var multiplier = 1;
+
+ for (var _i7 = 0; _i7 < tin.length - 1; _i7++) {
+ checksum += parseInt(tin[_i7], 10) * multiplier % 10;
+ multiplier += 2;
+
+ if (multiplier > 10) {
+ multiplier = 1;
+ } else if (multiplier === 5) {
+ multiplier += 2;
+ }
+ }
+
+ checksum = 10 - checksum % 10;
+ return checksum === parseInt(tin[10], 10);
+}
+/*
+* pt-BR validation function
+* (Cadastro de Pessoas Físicas (CPF, persons)
+* Cadastro Nacional de Pessoas Jurídicas (CNPJ, entities)
+* Both inputs will be validated
+*/
+
+
+function ptBrCheck(tin) {
+ if (tin.length === 11) {
+ var _sum;
+
+ var remainder;
+ _sum = 0;
+ if ( // Reject known invalid CPFs
+ tin === '11111111111' || tin === '22222222222' || tin === '33333333333' || tin === '44444444444' || tin === '55555555555' || tin === '66666666666' || tin === '77777777777' || tin === '88888888888' || tin === '99999999999' || tin === '00000000000') return false;
+
+ for (var i = 1; i <= 9; i++) {
+ _sum += parseInt(tin.substring(i - 1, i), 10) * (11 - i);
+ }
+
+ remainder = _sum * 10 % 11;
+ if (remainder === 10) remainder = 0;
+ if (remainder !== parseInt(tin.substring(9, 10), 10)) return false;
+ _sum = 0;
+
+ for (var _i8 = 1; _i8 <= 10; _i8++) {
+ _sum += parseInt(tin.substring(_i8 - 1, _i8), 10) * (12 - _i8);
+ }
+
+ remainder = _sum * 10 % 11;
+ if (remainder === 10) remainder = 0;
+ if (remainder !== parseInt(tin.substring(10, 11), 10)) return false;
+ return true;
+ }
+
+ if ( // Reject know invalid CNPJs
+ tin === '00000000000000' || tin === '11111111111111' || tin === '22222222222222' || tin === '33333333333333' || tin === '44444444444444' || tin === '55555555555555' || tin === '66666666666666' || tin === '77777777777777' || tin === '88888888888888' || tin === '99999999999999') {
+ return false;
+ }
+
+ var length = tin.length - 2;
+ var identifiers = tin.substring(0, length);
+ var verificators = tin.substring(length);
+ var sum = 0;
+ var pos = length - 7;
+
+ for (var _i9 = length; _i9 >= 1; _i9--) {
+ sum += identifiers.charAt(length - _i9) * pos;
+ pos -= 1;
+
+ if (pos < 2) {
+ pos = 9;
+ }
+ }
+
+ var result = sum % 11 < 2 ? 0 : 11 - sum % 11;
+
+ if (result !== parseInt(verificators.charAt(0), 10)) {
+ return false;
+ }
+
+ length += 1;
+ identifiers = tin.substring(0, length);
+ sum = 0;
+ pos = length - 7;
+
+ for (var _i10 = length; _i10 >= 1; _i10--) {
+ sum += identifiers.charAt(length - _i10) * pos;
+ pos -= 1;
+
+ if (pos < 2) {
+ pos = 9;
+ }
+ }
+
+ result = sum % 11 < 2 ? 0 : 11 - sum % 11;
+
+ if (result !== parseInt(verificators.charAt(1), 10)) {
+ return false;
+ }
+
+ return true;
+}
+/*
+ * pt-PT validation function
+ * (Número de identificação fiscal (NIF), persons/entities)
+ * Verify TIN validity by calculating check (last) digit (variant of MOD 11)
+ */
+
+
+function ptPtCheck(tin) {
+ var checksum = 11 - algorithms.reverseMultiplyAndSum(tin.split('').slice(0, 8).map(function (a) {
+ return parseInt(a, 10);
+ }), 9) % 11;
+
+ if (checksum > 9) {
+ return parseInt(tin[8], 10) === 0;
+ }
+
+ return checksum === parseInt(tin[8], 10);
+}
+/*
+ * ro-RO validation function
+ * (Cod Numeric Personal (CNP) or Cod de înregistrare fiscală (CIF),
+ * persons only)
+ * Verify CNP validity by calculating check (last) digit (test not found for CIF)
+ * Material not in DG TAXUD document sourced from:
+ * `https://en.wikipedia.org/wiki/National_identification_number#Romania`
+ */
+
+
+function roRoCheck(tin) {
+ if (tin.slice(0, 4) !== '9000') {
+ // No test found for this format
+ // Extract full year using century digit if possible
+ var full_year = tin.slice(1, 3);
+
+ switch (tin[0]) {
+ case '1':
+ case '2':
+ full_year = "19".concat(full_year);
+ break;
+
+ case '3':
+ case '4':
+ full_year = "18".concat(full_year);
+ break;
+
+ case '5':
+ case '6':
+ full_year = "20".concat(full_year);
+ break;
+
+ default:
+ } // Check date validity
+
+
+ var date = "".concat(full_year, "/").concat(tin.slice(3, 5), "/").concat(tin.slice(5, 7));
+
+ if (date.length === 8) {
+ if (!isDate(date, 'YY/MM/DD')) {
+ return false;
+ }
+ } else if (!isDate(date, 'YYYY/MM/DD')) {
+ return false;
+ } // Calculate check digit
+
+
+ var digits = tin.split('').map(function (a) {
+ return parseInt(a, 10);
+ });
+ var multipliers = [2, 7, 9, 1, 4, 6, 3, 5, 8, 2, 7, 9];
+ var checksum = 0;
+
+ for (var i = 0; i < multipliers.length; i++) {
+ checksum += digits[i] * multipliers[i];
+ }
+
+ if (checksum % 11 === 10) {
+ return digits[12] === 1;
+ }
+
+ return digits[12] === checksum % 11;
+ }
+
+ return true;
+}
+/*
+ * sk-SK validation function
+ * (Rodné číslo (RČ) or bezvýznamové identifikačné číslo (BIČ), persons only)
+ * Checks validity of pre-1954 birth numbers (rodné číslo) only
+ * Due to the introduction of the pseudo-random BIČ it is not possible to test
+ * post-1954 birth numbers without knowing whether they are BIČ or RČ beforehand
+ */
+
+
+function skSkCheck(tin) {
+ if (tin.length === 9) {
+ tin = tin.replace(/\W/, '');
+
+ if (tin.slice(6) === '000') {
+ return false;
+ } // Three-zero serial not assigned before 1954
+ // Extract full year from TIN length
+
+
+ var full_year = parseInt(tin.slice(0, 2), 10);
+
+ if (full_year > 53) {
+ return false;
+ }
+
+ if (full_year < 10) {
+ full_year = "190".concat(full_year);
+ } else {
+ full_year = "19".concat(full_year);
+ } // Extract month from TIN and normalize
+
+
+ var month = parseInt(tin.slice(2, 4), 10);
+
+ if (month > 50) {
+ month -= 50;
+ }
+
+ if (month < 10) {
+ month = "0".concat(month);
+ } // Check date validity
+
+
+ var date = "".concat(full_year, "/").concat(month, "/").concat(tin.slice(4, 6));
+
+ if (!isDate(date, 'YYYY/MM/DD')) {
+ return false;
+ }
+ }
+
+ return true;
+}
+/*
+ * sl-SI validation function
+ * (Davčna številka, persons/entities)
+ * Verify TIN validity by calculating check (last) digit (variant of MOD 11)
+ */
+
+
+function slSiCheck(tin) {
+ var checksum = 11 - algorithms.reverseMultiplyAndSum(tin.split('').slice(0, 7).map(function (a) {
+ return parseInt(a, 10);
+ }), 8) % 11;
+
+ if (checksum === 10) {
+ return parseInt(tin[7], 10) === 0;
+ }
+
+ return checksum === parseInt(tin[7], 10);
+}
+/*
+ * sv-SE validation function
+ * (Personnummer or samordningsnummer, persons only)
+ * Checks validity of birth date and calls luhnCheck() to validate check (last) digit
+ */
+
+
+function svSeCheck(tin) {
+ // Make copy of TIN and normalize to two-digit year form
+ var tin_copy = tin.slice(0);
+
+ if (tin.length > 11) {
+ tin_copy = tin_copy.slice(2);
+ } // Extract date of birth
+
+
+ var full_year = '';
+ var month = tin_copy.slice(2, 4);
+ var day = parseInt(tin_copy.slice(4, 6), 10);
+
+ if (tin.length > 11) {
+ full_year = tin.slice(0, 4);
+ } else {
+ full_year = tin.slice(0, 2);
+
+ if (tin.length === 11 && day < 60) {
+ // Extract full year from centenarian symbol
+ // Should work just fine until year 10000 or so
+ var current_year = new Date().getFullYear().toString();
+ var current_century = parseInt(current_year.slice(0, 2), 10);
+ current_year = parseInt(current_year, 10);
+
+ if (tin[6] === '-') {
+ if (parseInt("".concat(current_century).concat(full_year), 10) > current_year) {
+ full_year = "".concat(current_century - 1).concat(full_year);
+ } else {
+ full_year = "".concat(current_century).concat(full_year);
+ }
+ } else {
+ full_year = "".concat(current_century - 1).concat(full_year);
+
+ if (current_year - parseInt(full_year, 10) < 100) {
+ return false;
+ }
+ }
+ }
+ } // Normalize day and check date validity
+
+
+ if (day > 60) {
+ day -= 60;
+ }
+
+ if (day < 10) {
+ day = "0".concat(day);
+ }
+
+ var date = "".concat(full_year, "/").concat(month, "/").concat(day);
+
+ if (date.length === 8) {
+ if (!isDate(date, 'YY/MM/DD')) {
+ return false;
+ }
+ } else if (!isDate(date, 'YYYY/MM/DD')) {
+ return false;
+ }
+
+ return algorithms.luhnCheck(tin.replace(/\W/, ''));
+} // Locale lookup objects
+
+/*
+ * Tax id regex formats for various locales
+ *
+ * Where not explicitly specified in DG-TAXUD document both
+ * uppercase and lowercase letters are acceptable.
+ */
+
+
+var taxIdFormat = {
+ 'bg-BG': /^\d{10}$/,
+ 'cs-CZ': /^\d{6}\/{0,1}\d{3,4}$/,
+ 'de-AT': /^\d{9}$/,
+ 'de-DE': /^[1-9]\d{10}$/,
+ 'dk-DK': /^\d{6}-{0,1}\d{4}$/,
+ 'el-CY': /^[09]\d{7}[A-Z]$/,
+ 'el-GR': /^([0-4]|[7-9])\d{8}$/,
+ 'en-CA': /^\d{9}$/,
+ 'en-GB': /^\d{10}$|^(?!GB|NK|TN|ZZ)(?![DFIQUV])[A-Z](?![DFIQUVO])[A-Z]\d{6}[ABCD ]$/i,
+ 'en-IE': /^\d{7}[A-W][A-IW]{0,1}$/i,
+ 'en-US': /^\d{2}[- ]{0,1}\d{7}$/,
+ 'es-ES': /^(\d{0,8}|[XYZKLM]\d{7})[A-HJ-NP-TV-Z]$/i,
+ 'et-EE': /^[1-6]\d{6}(00[1-9]|0[1-9][0-9]|[1-6][0-9]{2}|70[0-9]|710)\d$/,
+ 'fi-FI': /^\d{6}[-+A]\d{3}[0-9A-FHJ-NPR-Y]$/i,
+ 'fr-BE': /^\d{11}$/,
+ 'fr-FR': /^[0-3]\d{12}$|^[0-3]\d\s\d{2}(\s\d{3}){3}$/,
+ // Conforms both to official spec and provided example
+ 'fr-LU': /^\d{13}$/,
+ 'hr-HR': /^\d{11}$/,
+ 'hu-HU': /^8\d{9}$/,
+ 'it-IT': /^[A-Z]{6}[L-NP-V0-9]{2}[A-EHLMPRST][L-NP-V0-9]{2}[A-ILMZ][L-NP-V0-9]{3}[A-Z]$/i,
+ 'lv-LV': /^\d{6}-{0,1}\d{5}$/,
+ // Conforms both to DG TAXUD spec and original research
+ 'mt-MT': /^\d{3,7}[APMGLHBZ]$|^([1-8])\1\d{7}$/i,
+ 'nl-NL': /^\d{9}$/,
+ 'pl-PL': /^\d{10,11}$/,
+ 'pt-BR': /(?:^\d{11}$)|(?:^\d{14}$)/,
+ 'pt-PT': /^\d{9}$/,
+ 'ro-RO': /^\d{13}$/,
+ 'sk-SK': /^\d{6}\/{0,1}\d{3,4}$/,
+ 'sl-SI': /^[1-9]\d{7}$/,
+ 'sv-SE': /^(\d{6}[-+]{0,1}\d{4}|(18|19|20)\d{6}[-+]{0,1}\d{4})$/
+}; // taxIdFormat locale aliases
+
+taxIdFormat['lb-LU'] = taxIdFormat['fr-LU'];
+taxIdFormat['lt-LT'] = taxIdFormat['et-EE'];
+taxIdFormat['nl-BE'] = taxIdFormat['fr-BE'];
+taxIdFormat['fr-CA'] = taxIdFormat['en-CA']; // Algorithmic tax id check functions for various locales
+
+var taxIdCheck = {
+ 'bg-BG': bgBgCheck,
+ 'cs-CZ': csCzCheck,
+ 'de-AT': deAtCheck,
+ 'de-DE': deDeCheck,
+ 'dk-DK': dkDkCheck,
+ 'el-CY': elCyCheck,
+ 'el-GR': elGrCheck,
+ 'en-CA': isCanadianSIN,
+ 'en-IE': enIeCheck,
+ 'en-US': enUsCheck,
+ 'es-ES': esEsCheck,
+ 'et-EE': etEeCheck,
+ 'fi-FI': fiFiCheck,
+ 'fr-BE': frBeCheck,
+ 'fr-FR': frFrCheck,
+ 'fr-LU': frLuCheck,
+ 'hr-HR': hrHrCheck,
+ 'hu-HU': huHuCheck,
+ 'it-IT': itItCheck,
+ 'lv-LV': lvLvCheck,
+ 'mt-MT': mtMtCheck,
+ 'nl-NL': nlNlCheck,
+ 'pl-PL': plPlCheck,
+ 'pt-BR': ptBrCheck,
+ 'pt-PT': ptPtCheck,
+ 'ro-RO': roRoCheck,
+ 'sk-SK': skSkCheck,
+ 'sl-SI': slSiCheck,
+ 'sv-SE': svSeCheck
+}; // taxIdCheck locale aliases
+
+taxIdCheck['lb-LU'] = taxIdCheck['fr-LU'];
+taxIdCheck['lt-LT'] = taxIdCheck['et-EE'];
+taxIdCheck['nl-BE'] = taxIdCheck['fr-BE'];
+taxIdCheck['fr-CA'] = taxIdCheck['en-CA']; // Regexes for locales where characters should be omitted before checking format
+
+var allsymbols = /[-\\\/!@#$%\^&\*\(\)\+\=\[\]]+/g;
+var sanitizeRegexes = {
+ 'de-AT': allsymbols,
+ 'de-DE': /[\/\\]/g,
+ 'fr-BE': allsymbols
+}; // sanitizeRegexes locale aliases
+
+sanitizeRegexes['nl-BE'] = sanitizeRegexes['fr-BE'];
+/*
+ * Validator function
+ * Return true if the passed string is a valid tax identification number
+ * for the specified locale.
+ * Throw an error exception if the locale is not supported.
+ */
+
+export default function isTaxID(str) {
+ var locale = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'en-US';
+ assertString(str); // Copy TIN to avoid replacement if sanitized
+
+ var strcopy = str.slice(0);
+
+ if (locale in taxIdFormat) {
+ if (locale in sanitizeRegexes) {
+ strcopy = strcopy.replace(sanitizeRegexes[locale], '');
+ }
+
+ if (!taxIdFormat[locale].test(strcopy)) {
+ return false;
+ }
+
+ if (locale in taxIdCheck) {
+ return taxIdCheck[locale](strcopy);
+ } // Fallthrough; not all locales have algorithmic checks
+
+
+ return true;
+ }
+
+ throw new Error("Invalid locale '".concat(locale, "'"));
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isTime.js b/includes/external/addressbook/node_modules/validator/es/lib/isTime.js
new file mode 100644
index 0000000..ffa4df4
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isTime.js
@@ -0,0 +1,20 @@
+import merge from './util/merge';
+var default_time_options = {
+ hourFormat: 'hour24',
+ mode: 'default'
+};
+var formats = {
+ hour24: {
+ "default": /^([01]?[0-9]|2[0-3]):([0-5][0-9])$/,
+ withSeconds: /^([01]?[0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])$/
+ },
+ hour12: {
+ "default": /^(0?[1-9]|1[0-2]):([0-5][0-9]) (A|P)M$/,
+ withSeconds: /^(0?[1-9]|1[0-2]):([0-5][0-9]):([0-5][0-9]) (A|P)M$/
+ }
+};
+export default function isTime(input, options) {
+ options = merge(options, default_time_options);
+ if (typeof input !== 'string') return false;
+ return formats[options.hourFormat][options.mode].test(input);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isURL.js b/includes/external/addressbook/node_modules/validator/es/lib/isURL.js
new file mode 100644
index 0000000..1a0497f
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isURL.js
@@ -0,0 +1,197 @@
+function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
+
+function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
+
+function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
+
+function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
+
+function _iterableToArrayLimit(arr, i) { if (typeof Symbol === "undefined" || !(Symbol.iterator in Object(arr))) return; var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
+
+function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
+
+import assertString from './util/assertString';
+import isFQDN from './isFQDN';
+import isIP from './isIP';
+import merge from './util/merge';
+/*
+options for isURL method
+
+require_protocol - if set as true isURL will return false if protocol is not present in the URL
+require_valid_protocol - isURL will check if the URL's protocol is present in the protocols option
+protocols - valid protocols can be modified with this option
+require_host - if set as false isURL will not check if host is present in the URL
+require_port - if set as true isURL will check if port is present in the URL
+allow_protocol_relative_urls - if set as true protocol relative URLs will be allowed
+validate_length - if set as false isURL will skip string length validation (IE maximum is 2083)
+
+*/
+
+var default_url_options = {
+ protocols: ['http', 'https', 'ftp'],
+ require_tld: true,
+ require_protocol: false,
+ require_host: true,
+ require_port: false,
+ require_valid_protocol: true,
+ allow_underscores: false,
+ allow_trailing_dot: false,
+ allow_protocol_relative_urls: false,
+ allow_fragments: true,
+ allow_query_components: true,
+ validate_length: true
+};
+var wrapped_ipv6 = /^\[([^\]]+)\](?::([0-9]+))?$/;
+
+function isRegExp(obj) {
+ return Object.prototype.toString.call(obj) === '[object RegExp]';
+}
+
+function checkHost(host, matches) {
+ for (var i = 0; i < matches.length; i++) {
+ var match = matches[i];
+
+ if (host === match || isRegExp(match) && match.test(host)) {
+ return true;
+ }
+ }
+
+ return false;
+}
+
+export default function isURL(url, options) {
+ assertString(url);
+
+ if (!url || /[\s<>]/.test(url)) {
+ return false;
+ }
+
+ if (url.indexOf('mailto:') === 0) {
+ return false;
+ }
+
+ options = merge(options, default_url_options);
+
+ if (options.validate_length && url.length >= 2083) {
+ return false;
+ }
+
+ if (!options.allow_fragments && url.includes('#')) {
+ return false;
+ }
+
+ if (!options.allow_query_components && (url.includes('?') || url.includes('&'))) {
+ return false;
+ }
+
+ var protocol, auth, host, hostname, port, port_str, split, ipv6;
+ split = url.split('#');
+ url = split.shift();
+ split = url.split('?');
+ url = split.shift();
+ split = url.split('://');
+
+ if (split.length > 1) {
+ protocol = split.shift().toLowerCase();
+
+ if (options.require_valid_protocol && options.protocols.indexOf(protocol) === -1) {
+ return false;
+ }
+ } else if (options.require_protocol) {
+ return false;
+ } else if (url.slice(0, 2) === '//') {
+ if (!options.allow_protocol_relative_urls) {
+ return false;
+ }
+
+ split[0] = url.slice(2);
+ }
+
+ url = split.join('://');
+
+ if (url === '') {
+ return false;
+ }
+
+ split = url.split('/');
+ url = split.shift();
+
+ if (url === '' && !options.require_host) {
+ return true;
+ }
+
+ split = url.split('@');
+
+ if (split.length > 1) {
+ if (options.disallow_auth) {
+ return false;
+ }
+
+ if (split[0] === '') {
+ return false;
+ }
+
+ auth = split.shift();
+
+ if (auth.indexOf(':') >= 0 && auth.split(':').length > 2) {
+ return false;
+ }
+
+ var _auth$split = auth.split(':'),
+ _auth$split2 = _slicedToArray(_auth$split, 2),
+ user = _auth$split2[0],
+ password = _auth$split2[1];
+
+ if (user === '' && password === '') {
+ return false;
+ }
+ }
+
+ hostname = split.join('@');
+ port_str = null;
+ ipv6 = null;
+ var ipv6_match = hostname.match(wrapped_ipv6);
+
+ if (ipv6_match) {
+ host = '';
+ ipv6 = ipv6_match[1];
+ port_str = ipv6_match[2] || null;
+ } else {
+ split = hostname.split(':');
+ host = split.shift();
+
+ if (split.length) {
+ port_str = split.join(':');
+ }
+ }
+
+ if (port_str !== null && port_str.length > 0) {
+ port = parseInt(port_str, 10);
+
+ if (!/^[0-9]+$/.test(port_str) || port <= 0 || port > 65535) {
+ return false;
+ }
+ } else if (options.require_port) {
+ return false;
+ }
+
+ if (options.host_whitelist) {
+ return checkHost(host, options.host_whitelist);
+ }
+
+ if (host === '' && !options.require_host) {
+ return true;
+ }
+
+ if (!isIP(host) && !isFQDN(host, options) && (!ipv6 || !isIP(ipv6, 6))) {
+ return false;
+ }
+
+ host = host || ipv6;
+
+ if (options.host_blacklist && checkHost(host, options.host_blacklist)) {
+ return false;
+ }
+
+ return true;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isUUID.js b/includes/external/addressbook/node_modules/validator/es/lib/isUUID.js
new file mode 100644
index 0000000..33ea146
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isUUID.js
@@ -0,0 +1,14 @@
+import assertString from './util/assertString';
+var uuid = {
+ 1: /^[0-9A-F]{8}-[0-9A-F]{4}-1[0-9A-F]{3}-[0-9A-F]{4}-[0-9A-F]{12}$/i,
+ 2: /^[0-9A-F]{8}-[0-9A-F]{4}-2[0-9A-F]{3}-[0-9A-F]{4}-[0-9A-F]{12}$/i,
+ 3: /^[0-9A-F]{8}-[0-9A-F]{4}-3[0-9A-F]{3}-[0-9A-F]{4}-[0-9A-F]{12}$/i,
+ 4: /^[0-9A-F]{8}-[0-9A-F]{4}-4[0-9A-F]{3}-[89AB][0-9A-F]{3}-[0-9A-F]{12}$/i,
+ 5: /^[0-9A-F]{8}-[0-9A-F]{4}-5[0-9A-F]{3}-[89AB][0-9A-F]{3}-[0-9A-F]{12}$/i,
+ all: /^[0-9A-F]{8}-[0-9A-F]{4}-[0-9A-F]{4}-[0-9A-F]{4}-[0-9A-F]{12}$/i
+};
+export default function isUUID(str, version) {
+ assertString(str);
+ var pattern = uuid[![undefined, null].includes(version) ? version : 'all'];
+ return !!pattern && pattern.test(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isUppercase.js b/includes/external/addressbook/node_modules/validator/es/lib/isUppercase.js
new file mode 100644
index 0000000..fca8790
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isUppercase.js
@@ -0,0 +1,5 @@
+import assertString from './util/assertString';
+export default function isUppercase(str) {
+ assertString(str);
+ return str === str.toUpperCase();
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isVAT.js b/includes/external/addressbook/node_modules/validator/es/lib/isVAT.js
new file mode 100644
index 0000000..46bd3f5
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isVAT.js
@@ -0,0 +1,247 @@
+import assertString from './util/assertString';
+import * as algorithms from './util/algorithms';
+
+var PT = function PT(str) {
+ var match = str.match(/^(PT)?(\d{9})$/);
+
+ if (!match) {
+ return false;
+ }
+
+ var tin = match[2];
+ var checksum = 11 - algorithms.reverseMultiplyAndSum(tin.split('').slice(0, 8).map(function (a) {
+ return parseInt(a, 10);
+ }), 9) % 11;
+
+ if (checksum > 9) {
+ return parseInt(tin[8], 10) === 0;
+ }
+
+ return checksum === parseInt(tin[8], 10);
+};
+
+export var vatMatchers = {
+ /**
+ * European Union VAT identification numbers
+ */
+ AT: function AT(str) {
+ return /^(AT)?U\d{8}$/.test(str);
+ },
+ BE: function BE(str) {
+ return /^(BE)?\d{10}$/.test(str);
+ },
+ BG: function BG(str) {
+ return /^(BG)?\d{9,10}$/.test(str);
+ },
+ HR: function HR(str) {
+ return /^(HR)?\d{11}$/.test(str);
+ },
+ CY: function CY(str) {
+ return /^(CY)?\w{9}$/.test(str);
+ },
+ CZ: function CZ(str) {
+ return /^(CZ)?\d{8,10}$/.test(str);
+ },
+ DK: function DK(str) {
+ return /^(DK)?\d{8}$/.test(str);
+ },
+ EE: function EE(str) {
+ return /^(EE)?\d{9}$/.test(str);
+ },
+ FI: function FI(str) {
+ return /^(FI)?\d{8}$/.test(str);
+ },
+ FR: function FR(str) {
+ return /^(FR)?\w{2}\d{9}$/.test(str);
+ },
+ DE: function DE(str) {
+ return /^(DE)?\d{9}$/.test(str);
+ },
+ EL: function EL(str) {
+ return /^(EL)?\d{9}$/.test(str);
+ },
+ HU: function HU(str) {
+ return /^(HU)?\d{8}$/.test(str);
+ },
+ IE: function IE(str) {
+ return /^(IE)?\d{7}\w{1}(W)?$/.test(str);
+ },
+ IT: function IT(str) {
+ return /^(IT)?\d{11}$/.test(str);
+ },
+ LV: function LV(str) {
+ return /^(LV)?\d{11}$/.test(str);
+ },
+ LT: function LT(str) {
+ return /^(LT)?\d{9,12}$/.test(str);
+ },
+ LU: function LU(str) {
+ return /^(LU)?\d{8}$/.test(str);
+ },
+ MT: function MT(str) {
+ return /^(MT)?\d{8}$/.test(str);
+ },
+ NL: function NL(str) {
+ return /^(NL)?\d{9}B\d{2}$/.test(str);
+ },
+ PL: function PL(str) {
+ return /^(PL)?(\d{10}|(\d{3}-\d{3}-\d{2}-\d{2})|(\d{3}-\d{2}-\d{2}-\d{3}))$/.test(str);
+ },
+ PT: PT,
+ RO: function RO(str) {
+ return /^(RO)?\d{2,10}$/.test(str);
+ },
+ SK: function SK(str) {
+ return /^(SK)?\d{10}$/.test(str);
+ },
+ SI: function SI(str) {
+ return /^(SI)?\d{8}$/.test(str);
+ },
+ ES: function ES(str) {
+ return /^(ES)?\w\d{7}[A-Z]$/.test(str);
+ },
+ SE: function SE(str) {
+ return /^(SE)?\d{12}$/.test(str);
+ },
+
+ /**
+ * VAT numbers of non-EU countries
+ */
+ AL: function AL(str) {
+ return /^(AL)?\w{9}[A-Z]$/.test(str);
+ },
+ MK: function MK(str) {
+ return /^(MK)?\d{13}$/.test(str);
+ },
+ AU: function AU(str) {
+ return /^(AU)?\d{11}$/.test(str);
+ },
+ BY: function BY(str) {
+ return /^(УНП )?\d{9}$/.test(str);
+ },
+ CA: function CA(str) {
+ return /^(CA)?\d{9}$/.test(str);
+ },
+ IS: function IS(str) {
+ return /^(IS)?\d{5,6}$/.test(str);
+ },
+ IN: function IN(str) {
+ return /^(IN)?\d{15}$/.test(str);
+ },
+ ID: function ID(str) {
+ return /^(ID)?(\d{15}|(\d{2}.\d{3}.\d{3}.\d{1}-\d{3}.\d{3}))$/.test(str);
+ },
+ IL: function IL(str) {
+ return /^(IL)?\d{9}$/.test(str);
+ },
+ KZ: function KZ(str) {
+ return /^(KZ)?\d{9}$/.test(str);
+ },
+ NZ: function NZ(str) {
+ return /^(NZ)?\d{9}$/.test(str);
+ },
+ NG: function NG(str) {
+ return /^(NG)?(\d{12}|(\d{8}-\d{4}))$/.test(str);
+ },
+ NO: function NO(str) {
+ return /^(NO)?\d{9}MVA$/.test(str);
+ },
+ PH: function PH(str) {
+ return /^(PH)?(\d{12}|\d{3} \d{3} \d{3} \d{3})$/.test(str);
+ },
+ RU: function RU(str) {
+ return /^(RU)?(\d{10}|\d{12})$/.test(str);
+ },
+ SM: function SM(str) {
+ return /^(SM)?\d{5}$/.test(str);
+ },
+ SA: function SA(str) {
+ return /^(SA)?\d{15}$/.test(str);
+ },
+ RS: function RS(str) {
+ return /^(RS)?\d{9}$/.test(str);
+ },
+ CH: function CH(str) {
+ return /^(CH)?(\d{6}|\d{9}|(\d{3}.\d{3})|(\d{3}.\d{3}.\d{3}))(TVA|MWST|IVA)$/.test(str);
+ },
+ TR: function TR(str) {
+ return /^(TR)?\d{10}$/.test(str);
+ },
+ UA: function UA(str) {
+ return /^(UA)?\d{12}$/.test(str);
+ },
+ GB: function GB(str) {
+ return /^GB((\d{3} \d{4} ([0-8][0-9]|9[0-6]))|(\d{9} \d{3})|(((GD[0-4])|(HA[5-9]))[0-9]{2}))$/.test(str);
+ },
+ UZ: function UZ(str) {
+ return /^(UZ)?\d{9}$/.test(str);
+ },
+
+ /**
+ * VAT numbers of Latin American countries
+ */
+ AR: function AR(str) {
+ return /^(AR)?\d{11}$/.test(str);
+ },
+ BO: function BO(str) {
+ return /^(BO)?\d{7}$/.test(str);
+ },
+ BR: function BR(str) {
+ return /^(BR)?((\d{2}.\d{3}.\d{3}\/\d{4}-\d{2})|(\d{3}.\d{3}.\d{3}-\d{2}))$/.test(str);
+ },
+ CL: function CL(str) {
+ return /^(CL)?\d{8}-\d{1}$/.test(str);
+ },
+ CO: function CO(str) {
+ return /^(CO)?\d{10}$/.test(str);
+ },
+ CR: function CR(str) {
+ return /^(CR)?\d{9,12}$/.test(str);
+ },
+ EC: function EC(str) {
+ return /^(EC)?\d{13}$/.test(str);
+ },
+ SV: function SV(str) {
+ return /^(SV)?\d{4}-\d{6}-\d{3}-\d{1}$/.test(str);
+ },
+ GT: function GT(str) {
+ return /^(GT)?\d{7}-\d{1}$/.test(str);
+ },
+ HN: function HN(str) {
+ return /^(HN)?$/.test(str);
+ },
+ MX: function MX(str) {
+ return /^(MX)?\w{3,4}\d{6}\w{3}$/.test(str);
+ },
+ NI: function NI(str) {
+ return /^(NI)?\d{3}-\d{6}-\d{4}\w{1}$/.test(str);
+ },
+ PA: function PA(str) {
+ return /^(PA)?$/.test(str);
+ },
+ PY: function PY(str) {
+ return /^(PY)?\d{6,8}-\d{1}$/.test(str);
+ },
+ PE: function PE(str) {
+ return /^(PE)?\d{11}$/.test(str);
+ },
+ DO: function DO(str) {
+ return /^(DO)?(\d{11}|(\d{3}-\d{7}-\d{1})|[1,4,5]{1}\d{8}|([1,4,5]{1})-\d{2}-\d{5}-\d{1})$/.test(str);
+ },
+ UY: function UY(str) {
+ return /^(UY)?\d{12}$/.test(str);
+ },
+ VE: function VE(str) {
+ return /^(VE)?[J,G,V,E]{1}-(\d{9}|(\d{8}-\d{1}))$/.test(str);
+ }
+};
+export default function isVAT(str, countryCode) {
+ assertString(str);
+ assertString(countryCode);
+
+ if (countryCode in vatMatchers) {
+ return vatMatchers[countryCode](str);
+ }
+
+ throw new Error("Invalid country code: '".concat(countryCode, "'"));
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isVariableWidth.js b/includes/external/addressbook/node_modules/validator/es/lib/isVariableWidth.js
new file mode 100644
index 0000000..890119e
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isVariableWidth.js
@@ -0,0 +1,7 @@
+import assertString from './util/assertString';
+import { fullWidth } from './isFullWidth';
+import { halfWidth } from './isHalfWidth';
+export default function isVariableWidth(str) {
+ assertString(str);
+ return fullWidth.test(str) && halfWidth.test(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/isWhitelisted.js b/includes/external/addressbook/node_modules/validator/es/lib/isWhitelisted.js
new file mode 100644
index 0000000..2cbb95c
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/isWhitelisted.js
@@ -0,0 +1,12 @@
+import assertString from './util/assertString';
+export default function isWhitelisted(str, chars) {
+ assertString(str);
+
+ for (var i = str.length - 1; i >= 0; i--) {
+ if (chars.indexOf(str[i]) === -1) {
+ return false;
+ }
+ }
+
+ return true;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/ltrim.js b/includes/external/addressbook/node_modules/validator/es/lib/ltrim.js
new file mode 100644
index 0000000..0ca3abb
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/ltrim.js
@@ -0,0 +1,7 @@
+import assertString from './util/assertString';
+export default function ltrim(str, chars) {
+ assertString(str); // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions#Escaping
+
+ var pattern = chars ? new RegExp("^[".concat(chars.replace(/[.*+?^${}()|[\]\\]/g, '\\$&'), "]+"), 'g') : /^\s+/g;
+ return str.replace(pattern, '');
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/matches.js b/includes/external/addressbook/node_modules/validator/es/lib/matches.js
new file mode 100644
index 0000000..02c3c20
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/matches.js
@@ -0,0 +1,10 @@
+import assertString from './util/assertString';
+export default function matches(str, pattern, modifiers) {
+ assertString(str);
+
+ if (Object.prototype.toString.call(pattern) !== '[object RegExp]') {
+ pattern = new RegExp(pattern, modifiers);
+ }
+
+ return !!str.match(pattern);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/normalizeEmail.js b/includes/external/addressbook/node_modules/validator/es/lib/normalizeEmail.js
new file mode 100644
index 0000000..3563982
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/normalizeEmail.js
@@ -0,0 +1,138 @@
+import merge from './util/merge';
+var default_normalize_email_options = {
+ // The following options apply to all email addresses
+ // Lowercases the local part of the email address.
+ // Please note this may violate RFC 5321 as per http://stackoverflow.com/a/9808332/192024).
+ // The domain is always lowercased, as per RFC 1035
+ all_lowercase: true,
+ // The following conversions are specific to GMail
+ // Lowercases the local part of the GMail address (known to be case-insensitive)
+ gmail_lowercase: true,
+ // Removes dots from the local part of the email address, as that's ignored by GMail
+ gmail_remove_dots: true,
+ // Removes the subaddress (e.g. "+foo") from the email address
+ gmail_remove_subaddress: true,
+ // Conversts the googlemail.com domain to gmail.com
+ gmail_convert_googlemaildotcom: true,
+ // The following conversions are specific to Outlook.com / Windows Live / Hotmail
+ // Lowercases the local part of the Outlook.com address (known to be case-insensitive)
+ outlookdotcom_lowercase: true,
+ // Removes the subaddress (e.g. "+foo") from the email address
+ outlookdotcom_remove_subaddress: true,
+ // The following conversions are specific to Yahoo
+ // Lowercases the local part of the Yahoo address (known to be case-insensitive)
+ yahoo_lowercase: true,
+ // Removes the subaddress (e.g. "-foo") from the email address
+ yahoo_remove_subaddress: true,
+ // The following conversions are specific to Yandex
+ // Lowercases the local part of the Yandex address (known to be case-insensitive)
+ yandex_lowercase: true,
+ // The following conversions are specific to iCloud
+ // Lowercases the local part of the iCloud address (known to be case-insensitive)
+ icloud_lowercase: true,
+ // Removes the subaddress (e.g. "+foo") from the email address
+ icloud_remove_subaddress: true
+}; // List of domains used by iCloud
+
+var icloud_domains = ['icloud.com', 'me.com']; // List of domains used by Outlook.com and its predecessors
+// This list is likely incomplete.
+// Partial reference:
+// https://blogs.office.com/2013/04/17/outlook-com-gets-two-step-verification-sign-in-by-alias-and-new-international-domains/
+
+var outlookdotcom_domains = ['hotmail.at', 'hotmail.be', 'hotmail.ca', 'hotmail.cl', 'hotmail.co.il', 'hotmail.co.nz', 'hotmail.co.th', 'hotmail.co.uk', 'hotmail.com', 'hotmail.com.ar', 'hotmail.com.au', 'hotmail.com.br', 'hotmail.com.gr', 'hotmail.com.mx', 'hotmail.com.pe', 'hotmail.com.tr', 'hotmail.com.vn', 'hotmail.cz', 'hotmail.de', 'hotmail.dk', 'hotmail.es', 'hotmail.fr', 'hotmail.hu', 'hotmail.id', 'hotmail.ie', 'hotmail.in', 'hotmail.it', 'hotmail.jp', 'hotmail.kr', 'hotmail.lv', 'hotmail.my', 'hotmail.ph', 'hotmail.pt', 'hotmail.sa', 'hotmail.sg', 'hotmail.sk', 'live.be', 'live.co.uk', 'live.com', 'live.com.ar', 'live.com.mx', 'live.de', 'live.es', 'live.eu', 'live.fr', 'live.it', 'live.nl', 'msn.com', 'outlook.at', 'outlook.be', 'outlook.cl', 'outlook.co.il', 'outlook.co.nz', 'outlook.co.th', 'outlook.com', 'outlook.com.ar', 'outlook.com.au', 'outlook.com.br', 'outlook.com.gr', 'outlook.com.pe', 'outlook.com.tr', 'outlook.com.vn', 'outlook.cz', 'outlook.de', 'outlook.dk', 'outlook.es', 'outlook.fr', 'outlook.hu', 'outlook.id', 'outlook.ie', 'outlook.in', 'outlook.it', 'outlook.jp', 'outlook.kr', 'outlook.lv', 'outlook.my', 'outlook.ph', 'outlook.pt', 'outlook.sa', 'outlook.sg', 'outlook.sk', 'passport.com']; // List of domains used by Yahoo Mail
+// This list is likely incomplete
+
+var yahoo_domains = ['rocketmail.com', 'yahoo.ca', 'yahoo.co.uk', 'yahoo.com', 'yahoo.de', 'yahoo.fr', 'yahoo.in', 'yahoo.it', 'ymail.com']; // List of domains used by yandex.ru
+
+var yandex_domains = ['yandex.ru', 'yandex.ua', 'yandex.kz', 'yandex.com', 'yandex.by', 'ya.ru']; // replace single dots, but not multiple consecutive dots
+
+function dotsReplacer(match) {
+ if (match.length > 1) {
+ return match;
+ }
+
+ return '';
+}
+
+export default function normalizeEmail(email, options) {
+ options = merge(options, default_normalize_email_options);
+ var raw_parts = email.split('@');
+ var domain = raw_parts.pop();
+ var user = raw_parts.join('@');
+ var parts = [user, domain]; // The domain is always lowercased, as it's case-insensitive per RFC 1035
+
+ parts[1] = parts[1].toLowerCase();
+
+ if (parts[1] === 'gmail.com' || parts[1] === 'googlemail.com') {
+ // Address is GMail
+ if (options.gmail_remove_subaddress) {
+ parts[0] = parts[0].split('+')[0];
+ }
+
+ if (options.gmail_remove_dots) {
+ // this does not replace consecutive dots like example..email@gmail.com
+ parts[0] = parts[0].replace(/\.+/g, dotsReplacer);
+ }
+
+ if (!parts[0].length) {
+ return false;
+ }
+
+ if (options.all_lowercase || options.gmail_lowercase) {
+ parts[0] = parts[0].toLowerCase();
+ }
+
+ parts[1] = options.gmail_convert_googlemaildotcom ? 'gmail.com' : parts[1];
+ } else if (icloud_domains.indexOf(parts[1]) >= 0) {
+ // Address is iCloud
+ if (options.icloud_remove_subaddress) {
+ parts[0] = parts[0].split('+')[0];
+ }
+
+ if (!parts[0].length) {
+ return false;
+ }
+
+ if (options.all_lowercase || options.icloud_lowercase) {
+ parts[0] = parts[0].toLowerCase();
+ }
+ } else if (outlookdotcom_domains.indexOf(parts[1]) >= 0) {
+ // Address is Outlook.com
+ if (options.outlookdotcom_remove_subaddress) {
+ parts[0] = parts[0].split('+')[0];
+ }
+
+ if (!parts[0].length) {
+ return false;
+ }
+
+ if (options.all_lowercase || options.outlookdotcom_lowercase) {
+ parts[0] = parts[0].toLowerCase();
+ }
+ } else if (yahoo_domains.indexOf(parts[1]) >= 0) {
+ // Address is Yahoo
+ if (options.yahoo_remove_subaddress) {
+ var components = parts[0].split('-');
+ parts[0] = components.length > 1 ? components.slice(0, -1).join('-') : components[0];
+ }
+
+ if (!parts[0].length) {
+ return false;
+ }
+
+ if (options.all_lowercase || options.yahoo_lowercase) {
+ parts[0] = parts[0].toLowerCase();
+ }
+ } else if (yandex_domains.indexOf(parts[1]) >= 0) {
+ if (options.all_lowercase || options.yandex_lowercase) {
+ parts[0] = parts[0].toLowerCase();
+ }
+
+ parts[1] = 'yandex.ru'; // all yandex domains are equal, 1st preferred
+ } else if (options.all_lowercase) {
+ // Any other address
+ parts[0] = parts[0].toLowerCase();
+ }
+
+ return parts.join('@');
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/rtrim.js b/includes/external/addressbook/node_modules/validator/es/lib/rtrim.js
new file mode 100644
index 0000000..a02f5c4
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/rtrim.js
@@ -0,0 +1,19 @@
+import assertString from './util/assertString';
+export default function rtrim(str, chars) {
+ assertString(str);
+
+ if (chars) {
+ // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions#Escaping
+ var pattern = new RegExp("[".concat(chars.replace(/[.*+?^${}()|[\]\\]/g, '\\$&'), "]+$"), 'g');
+ return str.replace(pattern, '');
+ } // Use a faster and more safe than regex trim method https://blog.stevenlevithan.com/archives/faster-trim-javascript
+
+
+ var strIndex = str.length - 1;
+
+ while (/\s/.test(str.charAt(strIndex))) {
+ strIndex -= 1;
+ }
+
+ return str.slice(0, strIndex + 1);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/stripLow.js b/includes/external/addressbook/node_modules/validator/es/lib/stripLow.js
new file mode 100644
index 0000000..c798425
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/stripLow.js
@@ -0,0 +1,7 @@
+import assertString from './util/assertString';
+import blacklist from './blacklist';
+export default function stripLow(str, keep_new_lines) {
+ assertString(str);
+ var chars = keep_new_lines ? '\\x00-\\x09\\x0B\\x0C\\x0E-\\x1F\\x7F' : '\\x00-\\x1F\\x7F';
+ return blacklist(str, chars);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/toBoolean.js b/includes/external/addressbook/node_modules/validator/es/lib/toBoolean.js
new file mode 100644
index 0000000..25e1eac
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/toBoolean.js
@@ -0,0 +1,10 @@
+import assertString from './util/assertString';
+export default function toBoolean(str, strict) {
+ assertString(str);
+
+ if (strict) {
+ return str === '1' || /^true$/i.test(str);
+ }
+
+ return str !== '0' && !/^false$/i.test(str) && str !== '';
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/toDate.js b/includes/external/addressbook/node_modules/validator/es/lib/toDate.js
new file mode 100644
index 0000000..62422a3
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/toDate.js
@@ -0,0 +1,6 @@
+import assertString from './util/assertString';
+export default function toDate(date) {
+ assertString(date);
+ date = Date.parse(date);
+ return !isNaN(date) ? new Date(date) : null;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/toFloat.js b/includes/external/addressbook/node_modules/validator/es/lib/toFloat.js
new file mode 100644
index 0000000..f21163d
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/toFloat.js
@@ -0,0 +1,5 @@
+import isFloat from './isFloat';
+export default function toFloat(str) {
+ if (!isFloat(str)) return NaN;
+ return parseFloat(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/toInt.js b/includes/external/addressbook/node_modules/validator/es/lib/toInt.js
new file mode 100644
index 0000000..22d566e
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/toInt.js
@@ -0,0 +1,5 @@
+import assertString from './util/assertString';
+export default function toInt(str, radix) {
+ assertString(str);
+ return parseInt(str, radix || 10);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/trim.js b/includes/external/addressbook/node_modules/validator/es/lib/trim.js
new file mode 100644
index 0000000..b9b8fa0
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/trim.js
@@ -0,0 +1,5 @@
+import rtrim from './rtrim';
+import ltrim from './ltrim';
+export default function trim(str, chars) {
+ return rtrim(ltrim(str, chars), chars);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/unescape.js b/includes/external/addressbook/node_modules/validator/es/lib/unescape.js
new file mode 100644
index 0000000..8ff45f5
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/unescape.js
@@ -0,0 +1,7 @@
+import assertString from './util/assertString';
+export default function unescape(str) {
+ assertString(str);
+ return str.replace(/&quot;/g, '"').replace(/&#x27;/g, "'").replace(/&lt;/g, '<').replace(/&gt;/g, '>').replace(/&#x2F;/g, '/').replace(/&#x5C;/g, '\\').replace(/&#96;/g, '`').replace(/&amp;/g, '&'); // &amp; replacement has to be the last one to prevent
+ // bugs with intermediate strings containing escape sequences
+ // See: https://github.com/validatorjs/validator.js/issues/1827
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/util/algorithms.js b/includes/external/addressbook/node_modules/validator/es/lib/util/algorithms.js
new file mode 100644
index 0000000..eca8d6d
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/util/algorithms.js
@@ -0,0 +1,88 @@
+/**
+ * Algorithmic validation functions
+ * May be used as is or implemented in the workflow of other validators.
+ */
+
+/*
+ * ISO 7064 validation function
+ * Called with a string of numbers (incl. check digit)
+ * to validate according to ISO 7064 (MOD 11, 10).
+ */
+export function iso7064Check(str) {
+ var checkvalue = 10;
+
+ for (var i = 0; i < str.length - 1; i++) {
+ checkvalue = (parseInt(str[i], 10) + checkvalue) % 10 === 0 ? 10 * 2 % 11 : (parseInt(str[i], 10) + checkvalue) % 10 * 2 % 11;
+ }
+
+ checkvalue = checkvalue === 1 ? 0 : 11 - checkvalue;
+ return checkvalue === parseInt(str[10], 10);
+}
+/*
+ * Luhn (mod 10) validation function
+ * Called with a string of numbers (incl. check digit)
+ * to validate according to the Luhn algorithm.
+ */
+
+export function luhnCheck(str) {
+ var checksum = 0;
+ var second = false;
+
+ for (var i = str.length - 1; i >= 0; i--) {
+ if (second) {
+ var product = parseInt(str[i], 10) * 2;
+
+ if (product > 9) {
+ // sum digits of product and add to checksum
+ checksum += product.toString().split('').map(function (a) {
+ return parseInt(a, 10);
+ }).reduce(function (a, b) {
+ return a + b;
+ }, 0);
+ } else {
+ checksum += product;
+ }
+ } else {
+ checksum += parseInt(str[i], 10);
+ }
+
+ second = !second;
+ }
+
+ return checksum % 10 === 0;
+}
+/*
+ * Reverse TIN multiplication and summation helper function
+ * Called with an array of single-digit integers and a base multiplier
+ * to calculate the sum of the digits multiplied in reverse.
+ * Normally used in variations of MOD 11 algorithmic checks.
+ */
+
+export function reverseMultiplyAndSum(digits, base) {
+ var total = 0;
+
+ for (var i = 0; i < digits.length; i++) {
+ total += digits[i] * (base - i);
+ }
+
+ return total;
+}
+/*
+ * Verhoeff validation helper function
+ * Called with a string of numbers
+ * to validate according to the Verhoeff algorithm.
+ */
+
+export function verhoeffCheck(str) {
+ var d_table = [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9], [1, 2, 3, 4, 0, 6, 7, 8, 9, 5], [2, 3, 4, 0, 1, 7, 8, 9, 5, 6], [3, 4, 0, 1, 2, 8, 9, 5, 6, 7], [4, 0, 1, 2, 3, 9, 5, 6, 7, 8], [5, 9, 8, 7, 6, 0, 4, 3, 2, 1], [6, 5, 9, 8, 7, 1, 0, 4, 3, 2], [7, 6, 5, 9, 8, 2, 1, 0, 4, 3], [8, 7, 6, 5, 9, 3, 2, 1, 0, 4], [9, 8, 7, 6, 5, 4, 3, 2, 1, 0]];
+ var p_table = [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9], [1, 5, 7, 6, 2, 8, 3, 0, 9, 4], [5, 8, 0, 3, 7, 9, 6, 1, 4, 2], [8, 9, 1, 6, 0, 4, 3, 5, 2, 7], [9, 4, 5, 3, 1, 2, 6, 8, 7, 0], [4, 2, 8, 6, 5, 7, 3, 9, 0, 1], [2, 7, 9, 3, 8, 0, 6, 4, 1, 5], [7, 0, 4, 6, 9, 1, 3, 2, 5, 8]]; // Copy (to prevent replacement) and reverse
+
+ var str_copy = str.split('').reverse().join('');
+ var checksum = 0;
+
+ for (var i = 0; i < str_copy.length; i++) {
+ checksum = d_table[checksum][p_table[i % 8][parseInt(str_copy[i], 10)]];
+ }
+
+ return checksum === 0;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/util/assertString.js b/includes/external/addressbook/node_modules/validator/es/lib/util/assertString.js
new file mode 100644
index 0000000..f7eced5
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/util/assertString.js
@@ -0,0 +1,12 @@
+function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
+
+export default function assertString(input) {
+ var isString = typeof input === 'string' || input instanceof String;
+
+ if (!isString) {
+ var invalidType = _typeof(input);
+
+ if (input === null) invalidType = 'null';else if (invalidType === 'object') invalidType = input.constructor.name;
+ throw new TypeError("Expected a string but received a ".concat(invalidType));
+ }
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/util/includes.js b/includes/external/addressbook/node_modules/validator/es/lib/util/includes.js
new file mode 100644
index 0000000..b01c692
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/util/includes.js
@@ -0,0 +1,7 @@
+var includes = function includes(arr, val) {
+ return arr.some(function (arrVal) {
+ return val === arrVal;
+ });
+};
+
+export default includes; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/util/merge.js b/includes/external/addressbook/node_modules/validator/es/lib/util/merge.js
new file mode 100644
index 0000000..0d1f699
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/util/merge.js
@@ -0,0 +1,12 @@
+export default function merge() {
+ var obj = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
+ var defaults = arguments.length > 1 ? arguments[1] : undefined;
+
+ for (var key in defaults) {
+ if (typeof obj[key] === 'undefined') {
+ obj[key] = defaults[key];
+ }
+ }
+
+ return obj;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/util/multilineRegex.js b/includes/external/addressbook/node_modules/validator/es/lib/util/multilineRegex.js
new file mode 100644
index 0000000..fed25a3
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/util/multilineRegex.js
@@ -0,0 +1,12 @@
+/**
+ * Build RegExp object from an array
+ * of multiple/multi-line regexp parts
+ *
+ * @param {string[]} parts
+ * @param {string} flags
+ * @return {object} - RegExp object
+ */
+export default function multilineRegexp(parts, flags) {
+ var regexpAsStringLiteral = parts.join('');
+ return new RegExp(regexpAsStringLiteral, flags);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/util/toString.js b/includes/external/addressbook/node_modules/validator/es/lib/util/toString.js
new file mode 100644
index 0000000..f483fa4
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/util/toString.js
@@ -0,0 +1,15 @@
+function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
+
+export default function toString(input) {
+ if (_typeof(input) === 'object' && input !== null) {
+ if (typeof input.toString === 'function') {
+ input = input.toString();
+ } else {
+ input = '[object Object]';
+ }
+ } else if (input === null || typeof input === 'undefined' || isNaN(input) && !input.length) {
+ input = '';
+ }
+
+ return String(input);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/util/typeOf.js b/includes/external/addressbook/node_modules/validator/es/lib/util/typeOf.js
new file mode 100644
index 0000000..b2ce41a
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/util/typeOf.js
@@ -0,0 +1,10 @@
+/**
+ * Better way to handle type checking
+ * null, {}, array and date are objects, which confuses
+ */
+export default function typeOf(input) {
+ var rawObject = Object.prototype.toString.call(input).toLowerCase();
+ var typeOfRegex = /\[object (.*)]/g;
+ var type = typeOfRegex.exec(rawObject)[1];
+ return type;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/es/lib/whitelist.js b/includes/external/addressbook/node_modules/validator/es/lib/whitelist.js
new file mode 100644
index 0000000..244881b
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/es/lib/whitelist.js
@@ -0,0 +1,5 @@
+import assertString from './util/assertString';
+export default function whitelist(str, chars) {
+ assertString(str);
+ return str.replace(new RegExp("[^".concat(chars, "]+"), 'g'), '');
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/index.js b/includes/external/addressbook/node_modules/validator/index.js
new file mode 100644
index 0000000..21265a6
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/index.js
@@ -0,0 +1,318 @@
+"use strict";
+
+function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = void 0;
+
+var _toDate = _interopRequireDefault(require("./lib/toDate"));
+
+var _toFloat = _interopRequireDefault(require("./lib/toFloat"));
+
+var _toInt = _interopRequireDefault(require("./lib/toInt"));
+
+var _toBoolean = _interopRequireDefault(require("./lib/toBoolean"));
+
+var _equals = _interopRequireDefault(require("./lib/equals"));
+
+var _contains = _interopRequireDefault(require("./lib/contains"));
+
+var _matches = _interopRequireDefault(require("./lib/matches"));
+
+var _isEmail = _interopRequireDefault(require("./lib/isEmail"));
+
+var _isURL = _interopRequireDefault(require("./lib/isURL"));
+
+var _isMACAddress = _interopRequireDefault(require("./lib/isMACAddress"));
+
+var _isIP = _interopRequireDefault(require("./lib/isIP"));
+
+var _isIPRange = _interopRequireDefault(require("./lib/isIPRange"));
+
+var _isFQDN = _interopRequireDefault(require("./lib/isFQDN"));
+
+var _isDate = _interopRequireDefault(require("./lib/isDate"));
+
+var _isTime = _interopRequireDefault(require("./lib/isTime"));
+
+var _isBoolean = _interopRequireDefault(require("./lib/isBoolean"));
+
+var _isLocale = _interopRequireDefault(require("./lib/isLocale"));
+
+var _isAlpha = _interopRequireWildcard(require("./lib/isAlpha"));
+
+var _isAlphanumeric = _interopRequireWildcard(require("./lib/isAlphanumeric"));
+
+var _isNumeric = _interopRequireDefault(require("./lib/isNumeric"));
+
+var _isPassportNumber = _interopRequireDefault(require("./lib/isPassportNumber"));
+
+var _isPort = _interopRequireDefault(require("./lib/isPort"));
+
+var _isLowercase = _interopRequireDefault(require("./lib/isLowercase"));
+
+var _isUppercase = _interopRequireDefault(require("./lib/isUppercase"));
+
+var _isIMEI = _interopRequireDefault(require("./lib/isIMEI"));
+
+var _isAscii = _interopRequireDefault(require("./lib/isAscii"));
+
+var _isFullWidth = _interopRequireDefault(require("./lib/isFullWidth"));
+
+var _isHalfWidth = _interopRequireDefault(require("./lib/isHalfWidth"));
+
+var _isVariableWidth = _interopRequireDefault(require("./lib/isVariableWidth"));
+
+var _isMultibyte = _interopRequireDefault(require("./lib/isMultibyte"));
+
+var _isSemVer = _interopRequireDefault(require("./lib/isSemVer"));
+
+var _isSurrogatePair = _interopRequireDefault(require("./lib/isSurrogatePair"));
+
+var _isInt = _interopRequireDefault(require("./lib/isInt"));
+
+var _isFloat = _interopRequireWildcard(require("./lib/isFloat"));
+
+var _isDecimal = _interopRequireDefault(require("./lib/isDecimal"));
+
+var _isHexadecimal = _interopRequireDefault(require("./lib/isHexadecimal"));
+
+var _isOctal = _interopRequireDefault(require("./lib/isOctal"));
+
+var _isDivisibleBy = _interopRequireDefault(require("./lib/isDivisibleBy"));
+
+var _isHexColor = _interopRequireDefault(require("./lib/isHexColor"));
+
+var _isRgbColor = _interopRequireDefault(require("./lib/isRgbColor"));
+
+var _isHSL = _interopRequireDefault(require("./lib/isHSL"));
+
+var _isISRC = _interopRequireDefault(require("./lib/isISRC"));
+
+var _isIBAN = _interopRequireWildcard(require("./lib/isIBAN"));
+
+var _isBIC = _interopRequireDefault(require("./lib/isBIC"));
+
+var _isMD = _interopRequireDefault(require("./lib/isMD5"));
+
+var _isHash = _interopRequireDefault(require("./lib/isHash"));
+
+var _isJWT = _interopRequireDefault(require("./lib/isJWT"));
+
+var _isJSON = _interopRequireDefault(require("./lib/isJSON"));
+
+var _isEmpty = _interopRequireDefault(require("./lib/isEmpty"));
+
+var _isLength = _interopRequireDefault(require("./lib/isLength"));
+
+var _isByteLength = _interopRequireDefault(require("./lib/isByteLength"));
+
+var _isUUID = _interopRequireDefault(require("./lib/isUUID"));
+
+var _isMongoId = _interopRequireDefault(require("./lib/isMongoId"));
+
+var _isAfter = _interopRequireDefault(require("./lib/isAfter"));
+
+var _isBefore = _interopRequireDefault(require("./lib/isBefore"));
+
+var _isIn = _interopRequireDefault(require("./lib/isIn"));
+
+var _isLuhnNumber = _interopRequireDefault(require("./lib/isLuhnNumber"));
+
+var _isCreditCard = _interopRequireDefault(require("./lib/isCreditCard"));
+
+var _isIdentityCard = _interopRequireDefault(require("./lib/isIdentityCard"));
+
+var _isEAN = _interopRequireDefault(require("./lib/isEAN"));
+
+var _isISIN = _interopRequireDefault(require("./lib/isISIN"));
+
+var _isISBN = _interopRequireDefault(require("./lib/isISBN"));
+
+var _isISSN = _interopRequireDefault(require("./lib/isISSN"));
+
+var _isTaxID = _interopRequireDefault(require("./lib/isTaxID"));
+
+var _isMobilePhone = _interopRequireWildcard(require("./lib/isMobilePhone"));
+
+var _isEthereumAddress = _interopRequireDefault(require("./lib/isEthereumAddress"));
+
+var _isCurrency = _interopRequireDefault(require("./lib/isCurrency"));
+
+var _isBtcAddress = _interopRequireDefault(require("./lib/isBtcAddress"));
+
+var _isISO = _interopRequireDefault(require("./lib/isISO6391"));
+
+var _isISO2 = _interopRequireDefault(require("./lib/isISO8601"));
+
+var _isRFC = _interopRequireDefault(require("./lib/isRFC3339"));
+
+var _isISO31661Alpha = _interopRequireDefault(require("./lib/isISO31661Alpha2"));
+
+var _isISO31661Alpha2 = _interopRequireDefault(require("./lib/isISO31661Alpha3"));
+
+var _isISO3 = _interopRequireDefault(require("./lib/isISO4217"));
+
+var _isBase = _interopRequireDefault(require("./lib/isBase32"));
+
+var _isBase2 = _interopRequireDefault(require("./lib/isBase58"));
+
+var _isBase3 = _interopRequireDefault(require("./lib/isBase64"));
+
+var _isDataURI = _interopRequireDefault(require("./lib/isDataURI"));
+
+var _isMagnetURI = _interopRequireDefault(require("./lib/isMagnetURI"));
+
+var _isMimeType = _interopRequireDefault(require("./lib/isMimeType"));
+
+var _isLatLong = _interopRequireDefault(require("./lib/isLatLong"));
+
+var _isPostalCode = _interopRequireWildcard(require("./lib/isPostalCode"));
+
+var _ltrim = _interopRequireDefault(require("./lib/ltrim"));
+
+var _rtrim = _interopRequireDefault(require("./lib/rtrim"));
+
+var _trim = _interopRequireDefault(require("./lib/trim"));
+
+var _escape = _interopRequireDefault(require("./lib/escape"));
+
+var _unescape = _interopRequireDefault(require("./lib/unescape"));
+
+var _stripLow = _interopRequireDefault(require("./lib/stripLow"));
+
+var _whitelist = _interopRequireDefault(require("./lib/whitelist"));
+
+var _blacklist = _interopRequireDefault(require("./lib/blacklist"));
+
+var _isWhitelisted = _interopRequireDefault(require("./lib/isWhitelisted"));
+
+var _normalizeEmail = _interopRequireDefault(require("./lib/normalizeEmail"));
+
+var _isSlug = _interopRequireDefault(require("./lib/isSlug"));
+
+var _isLicensePlate = _interopRequireDefault(require("./lib/isLicensePlate"));
+
+var _isStrongPassword = _interopRequireDefault(require("./lib/isStrongPassword"));
+
+var _isVAT = _interopRequireDefault(require("./lib/isVAT"));
+
+function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }
+
+function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var version = '13.9.0';
+var validator = {
+ version: version,
+ toDate: _toDate.default,
+ toFloat: _toFloat.default,
+ toInt: _toInt.default,
+ toBoolean: _toBoolean.default,
+ equals: _equals.default,
+ contains: _contains.default,
+ matches: _matches.default,
+ isEmail: _isEmail.default,
+ isURL: _isURL.default,
+ isMACAddress: _isMACAddress.default,
+ isIP: _isIP.default,
+ isIPRange: _isIPRange.default,
+ isFQDN: _isFQDN.default,
+ isBoolean: _isBoolean.default,
+ isIBAN: _isIBAN.default,
+ isBIC: _isBIC.default,
+ isAlpha: _isAlpha.default,
+ isAlphaLocales: _isAlpha.locales,
+ isAlphanumeric: _isAlphanumeric.default,
+ isAlphanumericLocales: _isAlphanumeric.locales,
+ isNumeric: _isNumeric.default,
+ isPassportNumber: _isPassportNumber.default,
+ isPort: _isPort.default,
+ isLowercase: _isLowercase.default,
+ isUppercase: _isUppercase.default,
+ isAscii: _isAscii.default,
+ isFullWidth: _isFullWidth.default,
+ isHalfWidth: _isHalfWidth.default,
+ isVariableWidth: _isVariableWidth.default,
+ isMultibyte: _isMultibyte.default,
+ isSemVer: _isSemVer.default,
+ isSurrogatePair: _isSurrogatePair.default,
+ isInt: _isInt.default,
+ isIMEI: _isIMEI.default,
+ isFloat: _isFloat.default,
+ isFloatLocales: _isFloat.locales,
+ isDecimal: _isDecimal.default,
+ isHexadecimal: _isHexadecimal.default,
+ isOctal: _isOctal.default,
+ isDivisibleBy: _isDivisibleBy.default,
+ isHexColor: _isHexColor.default,
+ isRgbColor: _isRgbColor.default,
+ isHSL: _isHSL.default,
+ isISRC: _isISRC.default,
+ isMD5: _isMD.default,
+ isHash: _isHash.default,
+ isJWT: _isJWT.default,
+ isJSON: _isJSON.default,
+ isEmpty: _isEmpty.default,
+ isLength: _isLength.default,
+ isLocale: _isLocale.default,
+ isByteLength: _isByteLength.default,
+ isUUID: _isUUID.default,
+ isMongoId: _isMongoId.default,
+ isAfter: _isAfter.default,
+ isBefore: _isBefore.default,
+ isIn: _isIn.default,
+ isLuhnNumber: _isLuhnNumber.default,
+ isCreditCard: _isCreditCard.default,
+ isIdentityCard: _isIdentityCard.default,
+ isEAN: _isEAN.default,
+ isISIN: _isISIN.default,
+ isISBN: _isISBN.default,
+ isISSN: _isISSN.default,
+ isMobilePhone: _isMobilePhone.default,
+ isMobilePhoneLocales: _isMobilePhone.locales,
+ isPostalCode: _isPostalCode.default,
+ isPostalCodeLocales: _isPostalCode.locales,
+ isEthereumAddress: _isEthereumAddress.default,
+ isCurrency: _isCurrency.default,
+ isBtcAddress: _isBtcAddress.default,
+ isISO6391: _isISO.default,
+ isISO8601: _isISO2.default,
+ isRFC3339: _isRFC.default,
+ isISO31661Alpha2: _isISO31661Alpha.default,
+ isISO31661Alpha3: _isISO31661Alpha2.default,
+ isISO4217: _isISO3.default,
+ isBase32: _isBase.default,
+ isBase58: _isBase2.default,
+ isBase64: _isBase3.default,
+ isDataURI: _isDataURI.default,
+ isMagnetURI: _isMagnetURI.default,
+ isMimeType: _isMimeType.default,
+ isLatLong: _isLatLong.default,
+ ltrim: _ltrim.default,
+ rtrim: _rtrim.default,
+ trim: _trim.default,
+ escape: _escape.default,
+ unescape: _unescape.default,
+ stripLow: _stripLow.default,
+ whitelist: _whitelist.default,
+ blacklist: _blacklist.default,
+ isWhitelisted: _isWhitelisted.default,
+ normalizeEmail: _normalizeEmail.default,
+ toString: toString,
+ isSlug: _isSlug.default,
+ isStrongPassword: _isStrongPassword.default,
+ isTaxID: _isTaxID.default,
+ isDate: _isDate.default,
+ isTime: _isTime.default,
+ isLicensePlate: _isLicensePlate.default,
+ isVAT: _isVAT.default,
+ ibanLocales: _isIBAN.locales
+};
+var _default = validator;
+exports.default = _default;
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/alpha.js b/includes/external/addressbook/node_modules/validator/lib/alpha.js
new file mode 100644
index 0000000..2ec6e9b
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/alpha.js
@@ -0,0 +1,155 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.commaDecimal = exports.dotDecimal = exports.bengaliLocales = exports.farsiLocales = exports.arabicLocales = exports.englishLocales = exports.decimal = exports.alphanumeric = exports.alpha = void 0;
+var alpha = {
+ 'en-US': /^[A-Z]+$/i,
+ 'az-AZ': /^[A-VXYZÇƏĞİıÖŞÜ]+$/i,
+ 'bg-BG': /^[А-Я]+$/i,
+ 'cs-CZ': /^[A-ZÁČĎÉĚÍŇÓŘŠŤÚŮÝŽ]+$/i,
+ 'da-DK': /^[A-ZÆØÅ]+$/i,
+ 'de-DE': /^[A-ZÄÖÜß]+$/i,
+ 'el-GR': /^[Α-ώ]+$/i,
+ 'es-ES': /^[A-ZÁÉÍÑÓÚÜ]+$/i,
+ 'fa-IR': /^[ابپتثجچحخدذرزژسشصضطظعغفقکگلمنوهی]+$/i,
+ 'fi-FI': /^[A-ZÅÄÖ]+$/i,
+ 'fr-FR': /^[A-ZÀÂÆÇÉÈÊËÏÎÔŒÙÛÜŸ]+$/i,
+ 'it-IT': /^[A-ZÀÉÈÌÎÓÒÙ]+$/i,
+ 'ja-JP': /^[ぁ-んァ-ヶヲ-゚一-龠ー・。、]+$/i,
+ 'nb-NO': /^[A-ZÆØÅ]+$/i,
+ 'nl-NL': /^[A-ZÁÉËÏÓÖÜÚ]+$/i,
+ 'nn-NO': /^[A-ZÆØÅ]+$/i,
+ 'hu-HU': /^[A-ZÁÉÍÓÖŐÚÜŰ]+$/i,
+ 'pl-PL': /^[A-ZĄĆĘŚŁŃÓŻŹ]+$/i,
+ 'pt-PT': /^[A-ZÃÁÀÂÄÇÉÊËÍÏÕÓÔÖÚÜ]+$/i,
+ 'ru-RU': /^[А-ЯЁ]+$/i,
+ 'sl-SI': /^[A-ZČĆĐŠŽ]+$/i,
+ 'sk-SK': /^[A-ZÁČĎÉÍŇÓŠŤÚÝŽĹŔĽÄÔ]+$/i,
+ 'sr-RS@latin': /^[A-ZČĆŽŠĐ]+$/i,
+ 'sr-RS': /^[А-ЯЂЈЉЊЋЏ]+$/i,
+ 'sv-SE': /^[A-ZÅÄÖ]+$/i,
+ 'th-TH': /^[ก-๐\s]+$/i,
+ 'tr-TR': /^[A-ZÇĞİıÖŞÜ]+$/i,
+ 'uk-UA': /^[А-ЩЬЮЯЄIЇҐі]+$/i,
+ 'vi-VN': /^[A-ZÀÁẠẢÃÂẦẤẬẨẪĂẰẮẶẲẴĐÈÉẸẺẼÊỀẾỆỂỄÌÍỊỈĨÒÓỌỎÕÔỒỐỘỔỖƠỜỚỢỞỠÙÚỤỦŨƯỪỨỰỬỮỲÝỴỶỸ]+$/i,
+ 'ko-KR': /^[ㄱ-ㅎㅏ-ㅣ가-힣]*$/,
+ 'ku-IQ': /^[ئابپتجچحخدرڕزژسشعغفڤقکگلڵمنوۆھەیێيطؤثآإأكضصةظذ]+$/i,
+ ar: /^[ءآأؤإئابةتثجحخدذرزسشصضطظعغفقكلمنهوىيًٌٍَُِّْٰ]+$/,
+ he: /^[א-ת]+$/,
+ fa: /^['آاءأؤئبپتثجچحخدذرزژسشصضطظعغفقکگلمنوهةی']+$/i,
+ bn: /^['ঀঁংঃঅআইঈউঊঋঌএঐওঔকখগঘঙচছজঝঞটঠডঢণতথদধনপফবভমযরলশষসহ়ঽািীুূৃৄেৈোৌ্ৎৗড়ঢ়য়ৠৡৢৣৰৱ৲৳৴৵৶৷৸৹৺৻']+$/,
+ 'hi-IN': /^[\u0900-\u0961]+[\u0972-\u097F]*$/i,
+ 'si-LK': /^[\u0D80-\u0DFF]+$/
+};
+exports.alpha = alpha;
+var alphanumeric = {
+ 'en-US': /^[0-9A-Z]+$/i,
+ 'az-AZ': /^[0-9A-VXYZÇƏĞİıÖŞÜ]+$/i,
+ 'bg-BG': /^[0-9А-Я]+$/i,
+ 'cs-CZ': /^[0-9A-ZÁČĎÉĚÍŇÓŘŠŤÚŮÝŽ]+$/i,
+ 'da-DK': /^[0-9A-ZÆØÅ]+$/i,
+ 'de-DE': /^[0-9A-ZÄÖÜß]+$/i,
+ 'el-GR': /^[0-9Α-ω]+$/i,
+ 'es-ES': /^[0-9A-ZÁÉÍÑÓÚÜ]+$/i,
+ 'fi-FI': /^[0-9A-ZÅÄÖ]+$/i,
+ 'fr-FR': /^[0-9A-ZÀÂÆÇÉÈÊËÏÎÔŒÙÛÜŸ]+$/i,
+ 'it-IT': /^[0-9A-ZÀÉÈÌÎÓÒÙ]+$/i,
+ 'ja-JP': /^[0-90-9ぁ-んァ-ヶヲ-゚一-龠ー・。、]+$/i,
+ 'hu-HU': /^[0-9A-ZÁÉÍÓÖŐÚÜŰ]+$/i,
+ 'nb-NO': /^[0-9A-ZÆØÅ]+$/i,
+ 'nl-NL': /^[0-9A-ZÁÉËÏÓÖÜÚ]+$/i,
+ 'nn-NO': /^[0-9A-ZÆØÅ]+$/i,
+ 'pl-PL': /^[0-9A-ZĄĆĘŚŁŃÓŻŹ]+$/i,
+ 'pt-PT': /^[0-9A-ZÃÁÀÂÄÇÉÊËÍÏÕÓÔÖÚÜ]+$/i,
+ 'ru-RU': /^[0-9А-ЯЁ]+$/i,
+ 'sl-SI': /^[0-9A-ZČĆĐŠŽ]+$/i,
+ 'sk-SK': /^[0-9A-ZÁČĎÉÍŇÓŠŤÚÝŽĹŔĽÄÔ]+$/i,
+ 'sr-RS@latin': /^[0-9A-ZČĆŽŠĐ]+$/i,
+ 'sr-RS': /^[0-9А-ЯЂЈЉЊЋЏ]+$/i,
+ 'sv-SE': /^[0-9A-ZÅÄÖ]+$/i,
+ 'th-TH': /^[ก-๙\s]+$/i,
+ 'tr-TR': /^[0-9A-ZÇĞİıÖŞÜ]+$/i,
+ 'uk-UA': /^[0-9А-ЩЬЮЯЄIЇҐі]+$/i,
+ 'ko-KR': /^[0-9ㄱ-ㅎㅏ-ㅣ가-힣]*$/,
+ 'ku-IQ': /^[٠١٢٣٤٥٦٧٨٩0-9ئابپتجچحخدرڕزژسشعغفڤقکگلڵمنوۆھەیێيطؤثآإأكضصةظذ]+$/i,
+ 'vi-VN': /^[0-9A-ZÀÁẠẢÃÂẦẤẬẨẪĂẰẮẶẲẴĐÈÉẸẺẼÊỀẾỆỂỄÌÍỊỈĨÒÓỌỎÕÔỒỐỘỔỖƠỜỚỢỞỠÙÚỤỦŨƯỪỨỰỬỮỲÝỴỶỸ]+$/i,
+ ar: /^[٠١٢٣٤٥٦٧٨٩0-9ءآأؤإئابةتثجحخدذرزسشصضطظعغفقكلمنهوىيًٌٍَُِّْٰ]+$/,
+ he: /^[0-9א-ת]+$/,
+ fa: /^['0-9آاءأؤئبپتثجچحخدذرزژسشصضطظعغفقکگلمنوهةی۱۲۳۴۵۶۷۸۹۰']+$/i,
+ bn: /^['ঀঁংঃঅআইঈউঊঋঌএঐওঔকখগঘঙচছজঝঞটঠডঢণতথদধনপফবভমযরলশষসহ়ঽািীুূৃৄেৈোৌ্ৎৗড়ঢ়য়ৠৡৢৣ০১২৩৪৫৬৭৮৯ৰৱ৲৳৴৵৶৷৸৹৺৻']+$/,
+ 'hi-IN': /^[\u0900-\u0963]+[\u0966-\u097F]*$/i,
+ 'si-LK': /^[0-9\u0D80-\u0DFF]+$/
+};
+exports.alphanumeric = alphanumeric;
+var decimal = {
+ 'en-US': '.',
+ ar: '٫'
+};
+exports.decimal = decimal;
+var englishLocales = ['AU', 'GB', 'HK', 'IN', 'NZ', 'ZA', 'ZM'];
+exports.englishLocales = englishLocales;
+
+for (var locale, i = 0; i < englishLocales.length; i++) {
+ locale = "en-".concat(englishLocales[i]);
+ alpha[locale] = alpha['en-US'];
+ alphanumeric[locale] = alphanumeric['en-US'];
+ decimal[locale] = decimal['en-US'];
+} // Source: http://www.localeplanet.com/java/
+
+
+var arabicLocales = ['AE', 'BH', 'DZ', 'EG', 'IQ', 'JO', 'KW', 'LB', 'LY', 'MA', 'QM', 'QA', 'SA', 'SD', 'SY', 'TN', 'YE'];
+exports.arabicLocales = arabicLocales;
+
+for (var _locale, _i = 0; _i < arabicLocales.length; _i++) {
+ _locale = "ar-".concat(arabicLocales[_i]);
+ alpha[_locale] = alpha.ar;
+ alphanumeric[_locale] = alphanumeric.ar;
+ decimal[_locale] = decimal.ar;
+}
+
+var farsiLocales = ['IR', 'AF'];
+exports.farsiLocales = farsiLocales;
+
+for (var _locale2, _i2 = 0; _i2 < farsiLocales.length; _i2++) {
+ _locale2 = "fa-".concat(farsiLocales[_i2]);
+ alphanumeric[_locale2] = alphanumeric.fa;
+ decimal[_locale2] = decimal.ar;
+}
+
+var bengaliLocales = ['BD', 'IN'];
+exports.bengaliLocales = bengaliLocales;
+
+for (var _locale3, _i3 = 0; _i3 < bengaliLocales.length; _i3++) {
+ _locale3 = "bn-".concat(bengaliLocales[_i3]);
+ alpha[_locale3] = alpha.bn;
+ alphanumeric[_locale3] = alphanumeric.bn;
+ decimal[_locale3] = decimal['en-US'];
+} // Source: https://en.wikipedia.org/wiki/Decimal_mark
+
+
+var dotDecimal = ['ar-EG', 'ar-LB', 'ar-LY'];
+exports.dotDecimal = dotDecimal;
+var commaDecimal = ['bg-BG', 'cs-CZ', 'da-DK', 'de-DE', 'el-GR', 'en-ZM', 'es-ES', 'fr-CA', 'fr-FR', 'id-ID', 'it-IT', 'ku-IQ', 'hi-IN', 'hu-HU', 'nb-NO', 'nn-NO', 'nl-NL', 'pl-PL', 'pt-PT', 'ru-RU', 'si-LK', 'sl-SI', 'sr-RS@latin', 'sr-RS', 'sv-SE', 'tr-TR', 'uk-UA', 'vi-VN'];
+exports.commaDecimal = commaDecimal;
+
+for (var _i4 = 0; _i4 < dotDecimal.length; _i4++) {
+ decimal[dotDecimal[_i4]] = decimal['en-US'];
+}
+
+for (var _i5 = 0; _i5 < commaDecimal.length; _i5++) {
+ decimal[commaDecimal[_i5]] = ',';
+}
+
+alpha['fr-CA'] = alpha['fr-FR'];
+alphanumeric['fr-CA'] = alphanumeric['fr-FR'];
+alpha['pt-BR'] = alpha['pt-PT'];
+alphanumeric['pt-BR'] = alphanumeric['pt-PT'];
+decimal['pt-BR'] = decimal['pt-PT']; // see #862
+
+alpha['pl-Pl'] = alpha['pl-PL'];
+alphanumeric['pl-Pl'] = alphanumeric['pl-PL'];
+decimal['pl-Pl'] = decimal['pl-PL']; // see #1455
+
+alpha['fa-AF'] = alpha.fa; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/blacklist.js b/includes/external/addressbook/node_modules/validator/lib/blacklist.js
new file mode 100644
index 0000000..5dd42ed
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/blacklist.js
@@ -0,0 +1,18 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = blacklist;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function blacklist(str, chars) {
+ (0, _assertString.default)(str);
+ return str.replace(new RegExp("[".concat(chars, "]+"), 'g'), '');
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/contains.js b/includes/external/addressbook/node_modules/validator/lib/contains.js
new file mode 100644
index 0000000..ee3843b
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/contains.js
@@ -0,0 +1,33 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = contains;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var _toString = _interopRequireDefault(require("./util/toString"));
+
+var _merge = _interopRequireDefault(require("./util/merge"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var defaulContainsOptions = {
+ ignoreCase: false,
+ minOccurrences: 1
+};
+
+function contains(str, elem, options) {
+ (0, _assertString.default)(str);
+ options = (0, _merge.default)(options, defaulContainsOptions);
+
+ if (options.ignoreCase) {
+ return str.toLowerCase().split((0, _toString.default)(elem).toLowerCase()).length > options.minOccurrences;
+ }
+
+ return str.split((0, _toString.default)(elem)).length > options.minOccurrences;
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/equals.js b/includes/external/addressbook/node_modules/validator/lib/equals.js
new file mode 100644
index 0000000..a33c5ab
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/equals.js
@@ -0,0 +1,18 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = equals;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function equals(str, comparison) {
+ (0, _assertString.default)(str);
+ return str === comparison;
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/escape.js b/includes/external/addressbook/node_modules/validator/lib/escape.js
new file mode 100644
index 0000000..05e4220
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/escape.js
@@ -0,0 +1,18 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = escape;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function escape(str) {
+ (0, _assertString.default)(str);
+ return str.replace(/&/g, '&amp;').replace(/"/g, '&quot;').replace(/'/g, '&#x27;').replace(/</g, '&lt;').replace(/>/g, '&gt;').replace(/\//g, '&#x2F;').replace(/\\/g, '&#x5C;').replace(/`/g, '&#96;');
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isAfter.js b/includes/external/addressbook/node_modules/validator/lib/isAfter.js
new file mode 100644
index 0000000..b6cb0d2
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isAfter.js
@@ -0,0 +1,22 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isAfter;
+
+var _toDate = _interopRequireDefault(require("./toDate"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function isAfter(date, options) {
+ // For backwards compatibility:
+ // isAfter(str [, date]), i.e. `options` could be used as argument for the legacy `date`
+ var comparisonDate = (options === null || options === void 0 ? void 0 : options.comparisonDate) || options || Date().toString();
+ var comparison = (0, _toDate.default)(comparisonDate);
+ var original = (0, _toDate.default)(date);
+ return !!(original && comparison && original > comparison);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isAlpha.js b/includes/external/addressbook/node_modules/validator/lib/isAlpha.js
new file mode 100644
index 0000000..bfb0c17
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isAlpha.js
@@ -0,0 +1,40 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isAlpha;
+exports.locales = void 0;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var _alpha = require("./alpha");
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function isAlpha(_str) {
+ var locale = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'en-US';
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ (0, _assertString.default)(_str);
+ var str = _str;
+ var ignore = options.ignore;
+
+ if (ignore) {
+ if (ignore instanceof RegExp) {
+ str = str.replace(ignore, '');
+ } else if (typeof ignore === 'string') {
+ str = str.replace(new RegExp("[".concat(ignore.replace(/[-[\]{}()*+?.,\\^$|#\\s]/g, '\\$&'), "]"), 'g'), ''); // escape regex for ignore
+ } else {
+ throw new Error('ignore should be instance of a String or RegExp');
+ }
+ }
+
+ if (locale in _alpha.alpha) {
+ return _alpha.alpha[locale].test(str);
+ }
+
+ throw new Error("Invalid locale '".concat(locale, "'"));
+}
+
+var locales = Object.keys(_alpha.alpha);
+exports.locales = locales; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isAlphanumeric.js b/includes/external/addressbook/node_modules/validator/lib/isAlphanumeric.js
new file mode 100644
index 0000000..e4d1d44
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isAlphanumeric.js
@@ -0,0 +1,40 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isAlphanumeric;
+exports.locales = void 0;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var _alpha = require("./alpha");
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function isAlphanumeric(_str) {
+ var locale = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'en-US';
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ (0, _assertString.default)(_str);
+ var str = _str;
+ var ignore = options.ignore;
+
+ if (ignore) {
+ if (ignore instanceof RegExp) {
+ str = str.replace(ignore, '');
+ } else if (typeof ignore === 'string') {
+ str = str.replace(new RegExp("[".concat(ignore.replace(/[-[\]{}()*+?.,\\^$|#\\s]/g, '\\$&'), "]"), 'g'), ''); // escape regex for ignore
+ } else {
+ throw new Error('ignore should be instance of a String or RegExp');
+ }
+ }
+
+ if (locale in _alpha.alphanumeric) {
+ return _alpha.alphanumeric[locale].test(str);
+ }
+
+ throw new Error("Invalid locale '".concat(locale, "'"));
+}
+
+var locales = Object.keys(_alpha.alphanumeric);
+exports.locales = locales; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isAscii.js b/includes/external/addressbook/node_modules/validator/lib/isAscii.js
new file mode 100644
index 0000000..3c62271
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isAscii.js
@@ -0,0 +1,22 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isAscii;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/* eslint-disable no-control-regex */
+var ascii = /^[\x00-\x7F]+$/;
+/* eslint-enable no-control-regex */
+
+function isAscii(str) {
+ (0, _assertString.default)(str);
+ return ascii.test(str);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isBIC.js b/includes/external/addressbook/node_modules/validator/lib/isBIC.js
new file mode 100644
index 0000000..e626535
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isBIC.js
@@ -0,0 +1,31 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isBIC;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var _isISO31661Alpha = require("./isISO31661Alpha2");
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+// https://en.wikipedia.org/wiki/ISO_9362
+var isBICReg = /^[A-Za-z]{6}[A-Za-z0-9]{2}([A-Za-z0-9]{3})?$/;
+
+function isBIC(str) {
+ (0, _assertString.default)(str); // toUpperCase() should be removed when a new major version goes out that changes
+ // the regex to [A-Z] (per the spec).
+
+ var countryCode = str.slice(4, 6).toUpperCase();
+
+ if (!_isISO31661Alpha.CountryCodes.has(countryCode) && countryCode !== 'XK') {
+ return false;
+ }
+
+ return isBICReg.test(str);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isBase32.js b/includes/external/addressbook/node_modules/validator/lib/isBase32.js
new file mode 100644
index 0000000..8c1f30d
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isBase32.js
@@ -0,0 +1,38 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isBase32;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var _merge = _interopRequireDefault(require("./util/merge"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var base32 = /^[A-Z2-7]+=*$/;
+var crockfordBase32 = /^[A-HJKMNP-TV-Z0-9]+$/;
+var defaultBase32Options = {
+ crockford: false
+};
+
+function isBase32(str, options) {
+ (0, _assertString.default)(str);
+ options = (0, _merge.default)(options, defaultBase32Options);
+
+ if (options.crockford) {
+ return crockfordBase32.test(str);
+ }
+
+ var len = str.length;
+
+ if (len % 8 === 0 && base32.test(str)) {
+ return true;
+ }
+
+ return false;
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isBase58.js b/includes/external/addressbook/node_modules/validator/lib/isBase58.js
new file mode 100644
index 0000000..a98c82c
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isBase58.js
@@ -0,0 +1,26 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isBase58;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+// Accepted chars - 123456789ABCDEFGH JKLMN PQRSTUVWXYZabcdefghijk mnopqrstuvwxyz
+var base58Reg = /^[A-HJ-NP-Za-km-z1-9]*$/;
+
+function isBase58(str) {
+ (0, _assertString.default)(str);
+
+ if (base58Reg.test(str)) {
+ return true;
+ }
+
+ return false;
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isBase64.js b/includes/external/addressbook/node_modules/validator/lib/isBase64.js
new file mode 100644
index 0000000..6863683
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isBase64.js
@@ -0,0 +1,38 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isBase64;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var _merge = _interopRequireDefault(require("./util/merge"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var notBase64 = /[^A-Z0-9+\/=]/i;
+var urlSafeBase64 = /^[A-Z0-9_\-]*$/i;
+var defaultBase64Options = {
+ urlSafe: false
+};
+
+function isBase64(str, options) {
+ (0, _assertString.default)(str);
+ options = (0, _merge.default)(options, defaultBase64Options);
+ var len = str.length;
+
+ if (options.urlSafe) {
+ return urlSafeBase64.test(str);
+ }
+
+ if (len % 4 !== 0 || notBase64.test(str)) {
+ return false;
+ }
+
+ var firstPaddingChar = str.indexOf('=');
+ return firstPaddingChar === -1 || firstPaddingChar === len - 1 || firstPaddingChar === len - 2 && str[len - 1] === '=';
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isBefore.js b/includes/external/addressbook/node_modules/validator/lib/isBefore.js
new file mode 100644
index 0000000..a54eda8
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isBefore.js
@@ -0,0 +1,23 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isBefore;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var _toDate = _interopRequireDefault(require("./toDate"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function isBefore(str) {
+ var date = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : String(new Date());
+ (0, _assertString.default)(str);
+ var comparison = (0, _toDate.default)(date);
+ var original = (0, _toDate.default)(str);
+ return !!(original && comparison && original < comparison);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isBoolean.js b/includes/external/addressbook/node_modules/validator/lib/isBoolean.js
new file mode 100644
index 0000000..e89a0e4
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isBoolean.js
@@ -0,0 +1,30 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isBoolean;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var defaultOptions = {
+ loose: false
+};
+var strictBooleans = ['true', 'false', '1', '0'];
+var looseBooleans = [].concat(strictBooleans, ['yes', 'no']);
+
+function isBoolean(str) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : defaultOptions;
+ (0, _assertString.default)(str);
+
+ if (options.loose) {
+ return looseBooleans.includes(str.toLowerCase());
+ }
+
+ return strictBooleans.includes(str);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isBtcAddress.js b/includes/external/addressbook/node_modules/validator/lib/isBtcAddress.js
new file mode 100644
index 0000000..af9e6bd
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isBtcAddress.js
@@ -0,0 +1,21 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isBtcAddress;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var bech32 = /^(bc1)[a-z0-9]{25,39}$/;
+var base58 = /^(1|3)[A-HJ-NP-Za-km-z1-9]{25,39}$/;
+
+function isBtcAddress(str) {
+ (0, _assertString.default)(str);
+ return bech32.test(str) || base58.test(str);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isByteLength.js b/includes/external/addressbook/node_modules/validator/lib/isByteLength.js
new file mode 100644
index 0000000..c1370ea
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isByteLength.js
@@ -0,0 +1,34 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isByteLength;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
+
+/* eslint-disable prefer-rest-params */
+function isByteLength(str, options) {
+ (0, _assertString.default)(str);
+ var min;
+ var max;
+
+ if (_typeof(options) === 'object') {
+ min = options.min || 0;
+ max = options.max;
+ } else {
+ // backwards compatibility: isByteLength(str, min [, max])
+ min = arguments[1];
+ max = arguments[2];
+ }
+
+ var len = encodeURI(str).split(/%..|./).length - 1;
+ return len >= min && (typeof max === 'undefined' || len <= max);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isCreditCard.js b/includes/external/addressbook/node_modules/validator/lib/isCreditCard.js
new file mode 100644
index 0000000..43df895
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isCreditCard.js
@@ -0,0 +1,52 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isCreditCard;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var _isLuhnNumber = _interopRequireDefault(require("./isLuhnNumber"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var cards = {
+ amex: /^3[47][0-9]{13}$/,
+ dinersclub: /^3(?:0[0-5]|[68][0-9])[0-9]{11}$/,
+ discover: /^6(?:011|5[0-9][0-9])[0-9]{12,15}$/,
+ jcb: /^(?:2131|1800|35\d{3})\d{11}$/,
+ mastercard: /^5[1-5][0-9]{2}|(222[1-9]|22[3-9][0-9]|2[3-6][0-9]{2}|27[01][0-9]|2720)[0-9]{12}$/,
+ // /^[25][1-7][0-9]{14}$/;
+ unionpay: /^(6[27][0-9]{14}|^(81[0-9]{14,17}))$/,
+ visa: /^(?:4[0-9]{12})(?:[0-9]{3,6})?$/
+};
+/* eslint-disable max-len */
+
+var allCards = /^(?:4[0-9]{12}(?:[0-9]{3,6})?|5[1-5][0-9]{14}|(222[1-9]|22[3-9][0-9]|2[3-6][0-9]{2}|27[01][0-9]|2720)[0-9]{12}|6(?:011|5[0-9][0-9])[0-9]{12,15}|3[47][0-9]{13}|3(?:0[0-5]|[68][0-9])[0-9]{11}|(?:2131|1800|35\d{3})\d{11}|6[27][0-9]{14}|^(81[0-9]{14,17}))$/;
+/* eslint-enable max-len */
+
+function isCreditCard(card) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ (0, _assertString.default)(card);
+ var provider = options.provider;
+ var sanitized = card.replace(/[- ]+/g, '');
+
+ if (provider && provider.toLowerCase() in cards) {
+ // specific provider in the list
+ if (!cards[provider.toLowerCase()].test(sanitized)) {
+ return false;
+ }
+ } else if (provider && !(provider.toLowerCase() in cards)) {
+ /* specific provider not in the list */
+ throw new Error("".concat(provider, " is not a valid credit card provider."));
+ } else if (!allCards.test(sanitized)) {
+ // no specific provider
+ return false;
+ }
+
+ return (0, _isLuhnNumber.default)(card);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isCurrency.js b/includes/external/addressbook/node_modules/validator/lib/isCurrency.js
new file mode 100755
index 0000000..cd7def6
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isCurrency.js
@@ -0,0 +1,91 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isCurrency;
+
+var _merge = _interopRequireDefault(require("./util/merge"));
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function currencyRegex(options) {
+ var decimal_digits = "\\d{".concat(options.digits_after_decimal[0], "}");
+ options.digits_after_decimal.forEach(function (digit, index) {
+ if (index !== 0) decimal_digits = "".concat(decimal_digits, "|\\d{").concat(digit, "}");
+ });
+ var symbol = "(".concat(options.symbol.replace(/\W/, function (m) {
+ return "\\".concat(m);
+ }), ")").concat(options.require_symbol ? '' : '?'),
+ negative = '-?',
+ whole_dollar_amount_without_sep = '[1-9]\\d*',
+ whole_dollar_amount_with_sep = "[1-9]\\d{0,2}(\\".concat(options.thousands_separator, "\\d{3})*"),
+ valid_whole_dollar_amounts = ['0', whole_dollar_amount_without_sep, whole_dollar_amount_with_sep],
+ whole_dollar_amount = "(".concat(valid_whole_dollar_amounts.join('|'), ")?"),
+ decimal_amount = "(\\".concat(options.decimal_separator, "(").concat(decimal_digits, "))").concat(options.require_decimal ? '' : '?');
+ var pattern = whole_dollar_amount + (options.allow_decimal || options.require_decimal ? decimal_amount : ''); // default is negative sign before symbol, but there are two other options (besides parens)
+
+ if (options.allow_negatives && !options.parens_for_negatives) {
+ if (options.negative_sign_after_digits) {
+ pattern += negative;
+ } else if (options.negative_sign_before_digits) {
+ pattern = negative + pattern;
+ }
+ } // South African Rand, for example, uses R 123 (space) and R-123 (no space)
+
+
+ if (options.allow_negative_sign_placeholder) {
+ pattern = "( (?!\\-))?".concat(pattern);
+ } else if (options.allow_space_after_symbol) {
+ pattern = " ?".concat(pattern);
+ } else if (options.allow_space_after_digits) {
+ pattern += '( (?!$))?';
+ }
+
+ if (options.symbol_after_digits) {
+ pattern += symbol;
+ } else {
+ pattern = symbol + pattern;
+ }
+
+ if (options.allow_negatives) {
+ if (options.parens_for_negatives) {
+ pattern = "(\\(".concat(pattern, "\\)|").concat(pattern, ")");
+ } else if (!(options.negative_sign_before_digits || options.negative_sign_after_digits)) {
+ pattern = negative + pattern;
+ }
+ } // ensure there's a dollar and/or decimal amount, and that
+ // it doesn't start with a space or a negative sign followed by a space
+
+
+ return new RegExp("^(?!-? )(?=.*\\d)".concat(pattern, "$"));
+}
+
+var default_currency_options = {
+ symbol: '$',
+ require_symbol: false,
+ allow_space_after_symbol: false,
+ symbol_after_digits: false,
+ allow_negatives: true,
+ parens_for_negatives: false,
+ negative_sign_before_digits: false,
+ negative_sign_after_digits: false,
+ allow_negative_sign_placeholder: false,
+ thousands_separator: ',',
+ decimal_separator: '.',
+ allow_decimal: true,
+ require_decimal: false,
+ digits_after_decimal: [2],
+ allow_space_after_digits: false
+};
+
+function isCurrency(str, options) {
+ (0, _assertString.default)(str);
+ options = (0, _merge.default)(options, default_currency_options);
+ return currencyRegex(options).test(str);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isDataURI.js b/includes/external/addressbook/node_modules/validator/lib/isDataURI.js
new file mode 100644
index 0000000..f1b672a
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isDataURI.js
@@ -0,0 +1,53 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isDataURI;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var validMediaType = /^[a-z]+\/[a-z0-9\-\+\._]+$/i;
+var validAttribute = /^[a-z\-]+=[a-z0-9\-]+$/i;
+var validData = /^[a-z0-9!\$&'\(\)\*\+,;=\-\._~:@\/\?%\s]*$/i;
+
+function isDataURI(str) {
+ (0, _assertString.default)(str);
+ var data = str.split(',');
+
+ if (data.length < 2) {
+ return false;
+ }
+
+ var attributes = data.shift().trim().split(';');
+ var schemeAndMediaType = attributes.shift();
+
+ if (schemeAndMediaType.slice(0, 5) !== 'data:') {
+ return false;
+ }
+
+ var mediaType = schemeAndMediaType.slice(5);
+
+ if (mediaType !== '' && !validMediaType.test(mediaType)) {
+ return false;
+ }
+
+ for (var i = 0; i < attributes.length; i++) {
+ if (!(i === attributes.length - 1 && attributes[i].toLowerCase() === 'base64') && !validAttribute.test(attributes[i])) {
+ return false;
+ }
+ }
+
+ for (var _i = 0; _i < data.length; _i++) {
+ if (!validData.test(data[_i])) {
+ return false;
+ }
+ }
+
+ return true;
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isDate.js b/includes/external/addressbook/node_modules/validator/lib/isDate.js
new file mode 100644
index 0000000..b3d8010
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isDate.js
@@ -0,0 +1,99 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isDate;
+
+var _merge = _interopRequireDefault(require("./util/merge"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
+
+function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
+
+function _iterableToArrayLimit(arr, i) { if (typeof Symbol === "undefined" || !(Symbol.iterator in Object(arr))) return; var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
+
+function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
+
+function _createForOfIteratorHelper(o, allowArrayLike) { var it; if (typeof Symbol === "undefined" || o[Symbol.iterator] == null) { if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") { if (it) o = it; var i = 0; var F = function F() {}; return { s: F, n: function n() { if (i >= o.length) return { done: true }; return { done: false, value: o[i++] }; }, e: function e(_e2) { throw _e2; }, f: F }; } throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); } var normalCompletion = true, didErr = false, err; return { s: function s() { it = o[Symbol.iterator](); }, n: function n() { var step = it.next(); normalCompletion = step.done; return step; }, e: function e(_e3) { didErr = true; err = _e3; }, f: function f() { try { if (!normalCompletion && it.return != null) it.return(); } finally { if (didErr) throw err; } } }; }
+
+function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
+
+function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
+
+var default_date_options = {
+ format: 'YYYY/MM/DD',
+ delimiters: ['/', '-'],
+ strictMode: false
+};
+
+function isValidFormat(format) {
+ return /(^(y{4}|y{2})[.\/-](m{1,2})[.\/-](d{1,2})$)|(^(m{1,2})[.\/-](d{1,2})[.\/-]((y{4}|y{2})$))|(^(d{1,2})[.\/-](m{1,2})[.\/-]((y{4}|y{2})$))/gi.test(format);
+}
+
+function zip(date, format) {
+ var zippedArr = [],
+ len = Math.min(date.length, format.length);
+
+ for (var i = 0; i < len; i++) {
+ zippedArr.push([date[i], format[i]]);
+ }
+
+ return zippedArr;
+}
+
+function isDate(input, options) {
+ if (typeof options === 'string') {
+ // Allow backward compatbility for old format isDate(input [, format])
+ options = (0, _merge.default)({
+ format: options
+ }, default_date_options);
+ } else {
+ options = (0, _merge.default)(options, default_date_options);
+ }
+
+ if (typeof input === 'string' && isValidFormat(options.format)) {
+ var formatDelimiter = options.delimiters.find(function (delimiter) {
+ return options.format.indexOf(delimiter) !== -1;
+ });
+ var dateDelimiter = options.strictMode ? formatDelimiter : options.delimiters.find(function (delimiter) {
+ return input.indexOf(delimiter) !== -1;
+ });
+ var dateAndFormat = zip(input.split(dateDelimiter), options.format.toLowerCase().split(formatDelimiter));
+ var dateObj = {};
+
+ var _iterator = _createForOfIteratorHelper(dateAndFormat),
+ _step;
+
+ try {
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
+ var _step$value = _slicedToArray(_step.value, 2),
+ dateWord = _step$value[0],
+ formatWord = _step$value[1];
+
+ if (dateWord.length !== formatWord.length) {
+ return false;
+ }
+
+ dateObj[formatWord.charAt(0)] = dateWord;
+ }
+ } catch (err) {
+ _iterator.e(err);
+ } finally {
+ _iterator.f();
+ }
+
+ return new Date("".concat(dateObj.m, "/").concat(dateObj.d, "/").concat(dateObj.y)).getDate() === +dateObj.d;
+ }
+
+ if (!options.strictMode) {
+ return Object.prototype.toString.call(input) === '[object Date]' && isFinite(input);
+ }
+
+ return false;
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isDecimal.js b/includes/external/addressbook/node_modules/validator/lib/isDecimal.js
new file mode 100644
index 0000000..d45b05f
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isDecimal.js
@@ -0,0 +1,42 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isDecimal;
+
+var _merge = _interopRequireDefault(require("./util/merge"));
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var _includes = _interopRequireDefault(require("./util/includes"));
+
+var _alpha = require("./alpha");
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function decimalRegExp(options) {
+ var regExp = new RegExp("^[-+]?([0-9]+)?(\\".concat(_alpha.decimal[options.locale], "[0-9]{").concat(options.decimal_digits, "})").concat(options.force_decimal ? '' : '?', "$"));
+ return regExp;
+}
+
+var default_decimal_options = {
+ force_decimal: false,
+ decimal_digits: '1,',
+ locale: 'en-US'
+};
+var blacklist = ['', '-', '+'];
+
+function isDecimal(str, options) {
+ (0, _assertString.default)(str);
+ options = (0, _merge.default)(options, default_decimal_options);
+
+ if (options.locale in _alpha.decimal) {
+ return !(0, _includes.default)(blacklist, str.replace(/ /g, '')) && decimalRegExp(options).test(str);
+ }
+
+ throw new Error("Invalid locale '".concat(options.locale, "'"));
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isDivisibleBy.js b/includes/external/addressbook/node_modules/validator/lib/isDivisibleBy.js
new file mode 100644
index 0000000..02408b3
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isDivisibleBy.js
@@ -0,0 +1,20 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isDivisibleBy;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var _toFloat = _interopRequireDefault(require("./toFloat"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function isDivisibleBy(str, num) {
+ (0, _assertString.default)(str);
+ return (0, _toFloat.default)(str) % parseInt(num, 10) === 0;
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isEAN.js b/includes/external/addressbook/node_modules/validator/lib/isEAN.js
new file mode 100644
index 0000000..d08d78b
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isEAN.js
@@ -0,0 +1,85 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isEAN;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * The most commonly used EAN standard is
+ * the thirteen-digit EAN-13, while the
+ * less commonly used 8-digit EAN-8 barcode was
+ * introduced for use on small packages.
+ * Also EAN/UCC-14 is used for Grouping of individual
+ * trade items above unit level(Intermediate, Carton or Pallet).
+ * For more info about EAN-14 checkout: https://www.gtin.info/itf-14-barcodes/
+ * EAN consists of:
+ * GS1 prefix, manufacturer code, product code and check digit
+ * Reference: https://en.wikipedia.org/wiki/International_Article_Number
+ * Reference: https://www.gtin.info/
+ */
+
+/**
+ * Define EAN Lenghts; 8 for EAN-8; 13 for EAN-13; 14 for EAN-14
+ * and Regular Expression for valid EANs (EAN-8, EAN-13, EAN-14),
+ * with exact numberic matching of 8 or 13 or 14 digits [0-9]
+ */
+var LENGTH_EAN_8 = 8;
+var LENGTH_EAN_14 = 14;
+var validEanRegex = /^(\d{8}|\d{13}|\d{14})$/;
+/**
+ * Get position weight given:
+ * EAN length and digit index/position
+ *
+ * @param {number} length
+ * @param {number} index
+ * @return {number}
+ */
+
+function getPositionWeightThroughLengthAndIndex(length, index) {
+ if (length === LENGTH_EAN_8 || length === LENGTH_EAN_14) {
+ return index % 2 === 0 ? 3 : 1;
+ }
+
+ return index % 2 === 0 ? 1 : 3;
+}
+/**
+ * Calculate EAN Check Digit
+ * Reference: https://en.wikipedia.org/wiki/International_Article_Number#Calculation_of_checksum_digit
+ *
+ * @param {string} ean
+ * @return {number}
+ */
+
+
+function calculateCheckDigit(ean) {
+ var checksum = ean.slice(0, -1).split('').map(function (char, index) {
+ return Number(char) * getPositionWeightThroughLengthAndIndex(ean.length, index);
+ }).reduce(function (acc, partialSum) {
+ return acc + partialSum;
+ }, 0);
+ var remainder = 10 - checksum % 10;
+ return remainder < 10 ? remainder : 0;
+}
+/**
+ * Check if string is valid EAN:
+ * Matches EAN-8/EAN-13/EAN-14 regex
+ * Has valid check digit.
+ *
+ * @param {string} str
+ * @return {boolean}
+ */
+
+
+function isEAN(str) {
+ (0, _assertString.default)(str);
+ var actualCheckDigit = Number(str.slice(-1));
+ return validEanRegex.test(str) && actualCheckDigit === calculateCheckDigit(str);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isEmail.js b/includes/external/addressbook/node_modules/validator/lib/isEmail.js
new file mode 100644
index 0000000..55609ba
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isEmail.js
@@ -0,0 +1,203 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isEmail;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var _merge = _interopRequireDefault(require("./util/merge"));
+
+var _isByteLength = _interopRequireDefault(require("./isByteLength"));
+
+var _isFQDN = _interopRequireDefault(require("./isFQDN"));
+
+var _isIP = _interopRequireDefault(require("./isIP"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var default_email_options = {
+ allow_display_name: false,
+ require_display_name: false,
+ allow_utf8_local_part: true,
+ require_tld: true,
+ blacklisted_chars: '',
+ ignore_max_length: false,
+ host_blacklist: [],
+ host_whitelist: []
+};
+/* eslint-disable max-len */
+
+/* eslint-disable no-control-regex */
+
+var splitNameAddress = /^([^\x00-\x1F\x7F-\x9F\cX]+)</i;
+var emailUserPart = /^[a-z\d!#\$%&'\*\+\-\/=\?\^_`{\|}~]+$/i;
+var gmailUserPart = /^[a-z\d]+$/;
+var quotedEmailUser = /^([\s\x01-\x08\x0b\x0c\x0e-\x1f\x7f\x21\x23-\x5b\x5d-\x7e]|(\\[\x01-\x09\x0b\x0c\x0d-\x7f]))*$/i;
+var emailUserUtf8Part = /^[a-z\d!#\$%&'\*\+\-\/=\?\^_`{\|}~\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]+$/i;
+var quotedEmailUserUtf8 = /^([\s\x01-\x08\x0b\x0c\x0e-\x1f\x7f\x21\x23-\x5b\x5d-\x7e\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]|(\\[\x01-\x09\x0b\x0c\x0d-\x7f\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))*$/i;
+var defaultMaxEmailLength = 254;
+/* eslint-enable max-len */
+
+/* eslint-enable no-control-regex */
+
+/**
+ * Validate display name according to the RFC2822: https://tools.ietf.org/html/rfc2822#appendix-A.1.2
+ * @param {String} display_name
+ */
+
+function validateDisplayName(display_name) {
+ var display_name_without_quotes = display_name.replace(/^"(.+)"$/, '$1'); // display name with only spaces is not valid
+
+ if (!display_name_without_quotes.trim()) {
+ return false;
+ } // check whether display name contains illegal character
+
+
+ var contains_illegal = /[\.";<>]/.test(display_name_without_quotes);
+
+ if (contains_illegal) {
+ // if contains illegal characters,
+ // must to be enclosed in double-quotes, otherwise it's not a valid display name
+ if (display_name_without_quotes === display_name) {
+ return false;
+ } // the quotes in display name must start with character symbol \
+
+
+ var all_start_with_back_slash = display_name_without_quotes.split('"').length === display_name_without_quotes.split('\\"').length;
+
+ if (!all_start_with_back_slash) {
+ return false;
+ }
+ }
+
+ return true;
+}
+
+function isEmail(str, options) {
+ (0, _assertString.default)(str);
+ options = (0, _merge.default)(options, default_email_options);
+
+ if (options.require_display_name || options.allow_display_name) {
+ var display_email = str.match(splitNameAddress);
+
+ if (display_email) {
+ var display_name = display_email[1]; // Remove display name and angle brackets to get email address
+ // Can be done in the regex but will introduce a ReDOS (See #1597 for more info)
+
+ str = str.replace(display_name, '').replace(/(^<|>$)/g, ''); // sometimes need to trim the last space to get the display name
+ // because there may be a space between display name and email address
+ // eg. myname <address@gmail.com>
+ // the display name is `myname` instead of `myname `, so need to trim the last space
+
+ if (display_name.endsWith(' ')) {
+ display_name = display_name.slice(0, -1);
+ }
+
+ if (!validateDisplayName(display_name)) {
+ return false;
+ }
+ } else if (options.require_display_name) {
+ return false;
+ }
+ }
+
+ if (!options.ignore_max_length && str.length > defaultMaxEmailLength) {
+ return false;
+ }
+
+ var parts = str.split('@');
+ var domain = parts.pop();
+ var lower_domain = domain.toLowerCase();
+
+ if (options.host_blacklist.includes(lower_domain)) {
+ return false;
+ }
+
+ if (options.host_whitelist.length > 0 && !options.host_whitelist.includes(lower_domain)) {
+ return false;
+ }
+
+ var user = parts.join('@');
+
+ if (options.domain_specific_validation && (lower_domain === 'gmail.com' || lower_domain === 'googlemail.com')) {
+ /*
+ Previously we removed dots for gmail addresses before validating.
+ This was removed because it allows `multiple..dots@gmail.com`
+ to be reported as valid, but it is not.
+ Gmail only normalizes single dots, removing them from here is pointless,
+ should be done in normalizeEmail
+ */
+ user = user.toLowerCase(); // Removing sub-address from username before gmail validation
+
+ var username = user.split('+')[0]; // Dots are not included in gmail length restriction
+
+ if (!(0, _isByteLength.default)(username.replace(/\./g, ''), {
+ min: 6,
+ max: 30
+ })) {
+ return false;
+ }
+
+ var _user_parts = username.split('.');
+
+ for (var i = 0; i < _user_parts.length; i++) {
+ if (!gmailUserPart.test(_user_parts[i])) {
+ return false;
+ }
+ }
+ }
+
+ if (options.ignore_max_length === false && (!(0, _isByteLength.default)(user, {
+ max: 64
+ }) || !(0, _isByteLength.default)(domain, {
+ max: 254
+ }))) {
+ return false;
+ }
+
+ if (!(0, _isFQDN.default)(domain, {
+ require_tld: options.require_tld,
+ ignore_max_length: options.ignore_max_length
+ })) {
+ if (!options.allow_ip_domain) {
+ return false;
+ }
+
+ if (!(0, _isIP.default)(domain)) {
+ if (!domain.startsWith('[') || !domain.endsWith(']')) {
+ return false;
+ }
+
+ var noBracketdomain = domain.slice(1, -1);
+
+ if (noBracketdomain.length === 0 || !(0, _isIP.default)(noBracketdomain)) {
+ return false;
+ }
+ }
+ }
+
+ if (user[0] === '"') {
+ user = user.slice(1, user.length - 1);
+ return options.allow_utf8_local_part ? quotedEmailUserUtf8.test(user) : quotedEmailUser.test(user);
+ }
+
+ var pattern = options.allow_utf8_local_part ? emailUserUtf8Part : emailUserPart;
+ var user_parts = user.split('.');
+
+ for (var _i = 0; _i < user_parts.length; _i++) {
+ if (!pattern.test(user_parts[_i])) {
+ return false;
+ }
+ }
+
+ if (options.blacklisted_chars) {
+ if (user.search(new RegExp("[".concat(options.blacklisted_chars, "]+"), 'g')) !== -1) return false;
+ }
+
+ return true;
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isEmpty.js b/includes/external/addressbook/node_modules/validator/lib/isEmpty.js
new file mode 100644
index 0000000..26766d5
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isEmpty.js
@@ -0,0 +1,25 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isEmpty;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var _merge = _interopRequireDefault(require("./util/merge"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var default_is_empty_options = {
+ ignore_whitespace: false
+};
+
+function isEmpty(str, options) {
+ (0, _assertString.default)(str);
+ options = (0, _merge.default)(options, default_is_empty_options);
+ return (options.ignore_whitespace ? str.trim().length : str.length) === 0;
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isEthereumAddress.js b/includes/external/addressbook/node_modules/validator/lib/isEthereumAddress.js
new file mode 100644
index 0000000..e6999b9
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isEthereumAddress.js
@@ -0,0 +1,20 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isEthereumAddress;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var eth = /^(0x)[0-9a-f]{40}$/i;
+
+function isEthereumAddress(str) {
+ (0, _assertString.default)(str);
+ return eth.test(str);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isFQDN.js b/includes/external/addressbook/node_modules/validator/lib/isFQDN.js
new file mode 100644
index 0000000..dca1ba3
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isFQDN.js
@@ -0,0 +1,90 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isFQDN;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var _merge = _interopRequireDefault(require("./util/merge"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var default_fqdn_options = {
+ require_tld: true,
+ allow_underscores: false,
+ allow_trailing_dot: false,
+ allow_numeric_tld: false,
+ allow_wildcard: false,
+ ignore_max_length: false
+};
+
+function isFQDN(str, options) {
+ (0, _assertString.default)(str);
+ options = (0, _merge.default)(options, default_fqdn_options);
+ /* Remove the optional trailing dot before checking validity */
+
+ if (options.allow_trailing_dot && str[str.length - 1] === '.') {
+ str = str.substring(0, str.length - 1);
+ }
+ /* Remove the optional wildcard before checking validity */
+
+
+ if (options.allow_wildcard === true && str.indexOf('*.') === 0) {
+ str = str.substring(2);
+ }
+
+ var parts = str.split('.');
+ var tld = parts[parts.length - 1];
+
+ if (options.require_tld) {
+ // disallow fqdns without tld
+ if (parts.length < 2) {
+ return false;
+ }
+
+ if (!options.allow_numeric_tld && !/^([a-z\u00A1-\u00A8\u00AA-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]{2,}|xn[a-z0-9-]{2,})$/i.test(tld)) {
+ return false;
+ } // disallow spaces
+
+
+ if (/\s/.test(tld)) {
+ return false;
+ }
+ } // reject numeric TLDs
+
+
+ if (!options.allow_numeric_tld && /^\d+$/.test(tld)) {
+ return false;
+ }
+
+ return parts.every(function (part) {
+ if (part.length > 63 && !options.ignore_max_length) {
+ return false;
+ }
+
+ if (!/^[a-z_\u00a1-\uffff0-9-]+$/i.test(part)) {
+ return false;
+ } // disallow full-width chars
+
+
+ if (/[\uff01-\uff5e]/.test(part)) {
+ return false;
+ } // disallow parts starting or ending with hyphen
+
+
+ if (/^-|-$/.test(part)) {
+ return false;
+ }
+
+ if (!options.allow_underscores && /_/.test(part)) {
+ return false;
+ }
+
+ return true;
+ });
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isFloat.js b/includes/external/addressbook/node_modules/validator/lib/isFloat.js
new file mode 100644
index 0000000..1b6ad1d
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isFloat.js
@@ -0,0 +1,29 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isFloat;
+exports.locales = void 0;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var _alpha = require("./alpha");
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function isFloat(str, options) {
+ (0, _assertString.default)(str);
+ options = options || {};
+ var float = new RegExp("^(?:[-+])?(?:[0-9]+)?(?:\\".concat(options.locale ? _alpha.decimal[options.locale] : '.', "[0-9]*)?(?:[eE][\\+\\-]?(?:[0-9]+))?$"));
+
+ if (str === '' || str === '.' || str === ',' || str === '-' || str === '+') {
+ return false;
+ }
+
+ var value = parseFloat(str.replace(',', '.'));
+ return float.test(str) && (!options.hasOwnProperty('min') || value >= options.min) && (!options.hasOwnProperty('max') || value <= options.max) && (!options.hasOwnProperty('lt') || value < options.lt) && (!options.hasOwnProperty('gt') || value > options.gt);
+}
+
+var locales = Object.keys(_alpha.decimal);
+exports.locales = locales; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isFullWidth.js b/includes/external/addressbook/node_modules/validator/lib/isFullWidth.js
new file mode 100644
index 0000000..1960f13
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isFullWidth.js
@@ -0,0 +1,19 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isFullWidth;
+exports.fullWidth = void 0;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var fullWidth = /[^\u0020-\u007E\uFF61-\uFF9F\uFFA0-\uFFDC\uFFE8-\uFFEE0-9a-zA-Z]/;
+exports.fullWidth = fullWidth;
+
+function isFullWidth(str) {
+ (0, _assertString.default)(str);
+ return fullWidth.test(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isHSL.js b/includes/external/addressbook/node_modules/validator/lib/isHSL.js
new file mode 100644
index 0000000..0590b3e
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isHSL.js
@@ -0,0 +1,28 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isHSL;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var hslComma = /^hsla?\(((\+|\-)?([0-9]+(\.[0-9]+)?(e(\+|\-)?[0-9]+)?|\.[0-9]+(e(\+|\-)?[0-9]+)?))(deg|grad|rad|turn)?(,(\+|\-)?([0-9]+(\.[0-9]+)?(e(\+|\-)?[0-9]+)?|\.[0-9]+(e(\+|\-)?[0-9]+)?)%){2}(,((\+|\-)?([0-9]+(\.[0-9]+)?(e(\+|\-)?[0-9]+)?|\.[0-9]+(e(\+|\-)?[0-9]+)?)%?))?\)$/i;
+var hslSpace = /^hsla?\(((\+|\-)?([0-9]+(\.[0-9]+)?(e(\+|\-)?[0-9]+)?|\.[0-9]+(e(\+|\-)?[0-9]+)?))(deg|grad|rad|turn)?(\s(\+|\-)?([0-9]+(\.[0-9]+)?(e(\+|\-)?[0-9]+)?|\.[0-9]+(e(\+|\-)?[0-9]+)?)%){2}\s?(\/\s((\+|\-)?([0-9]+(\.[0-9]+)?(e(\+|\-)?[0-9]+)?|\.[0-9]+(e(\+|\-)?[0-9]+)?)%?)\s?)?\)$/i;
+
+function isHSL(str) {
+ (0, _assertString.default)(str); // Strip duplicate spaces before calling the validation regex (See #1598 for more info)
+
+ var strippedStr = str.replace(/\s+/g, ' ').replace(/\s?(hsla?\(|\)|,)\s?/ig, '$1');
+
+ if (strippedStr.indexOf(',') !== -1) {
+ return hslComma.test(strippedStr);
+ }
+
+ return hslSpace.test(strippedStr);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isHalfWidth.js b/includes/external/addressbook/node_modules/validator/lib/isHalfWidth.js
new file mode 100644
index 0000000..55a9e1a
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isHalfWidth.js
@@ -0,0 +1,19 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isHalfWidth;
+exports.halfWidth = void 0;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var halfWidth = /[\u0020-\u007E\uFF61-\uFF9F\uFFA0-\uFFDC\uFFE8-\uFFEE0-9a-zA-Z]/;
+exports.halfWidth = halfWidth;
+
+function isHalfWidth(str) {
+ (0, _assertString.default)(str);
+ return halfWidth.test(str);
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isHash.js b/includes/external/addressbook/node_modules/validator/lib/isHash.js
new file mode 100644
index 0000000..1083966
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isHash.js
@@ -0,0 +1,35 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isHash;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var lengths = {
+ md5: 32,
+ md4: 32,
+ sha1: 40,
+ sha256: 64,
+ sha384: 96,
+ sha512: 128,
+ ripemd128: 32,
+ ripemd160: 40,
+ tiger128: 32,
+ tiger160: 40,
+ tiger192: 48,
+ crc32: 8,
+ crc32b: 8
+};
+
+function isHash(str, algorithm) {
+ (0, _assertString.default)(str);
+ var hash = new RegExp("^[a-fA-F0-9]{".concat(lengths[algorithm], "}$"));
+ return hash.test(str);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isHexColor.js b/includes/external/addressbook/node_modules/validator/lib/isHexColor.js
new file mode 100644
index 0000000..7af3889
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isHexColor.js
@@ -0,0 +1,20 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isHexColor;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var hexcolor = /^#?([0-9A-F]{3}|[0-9A-F]{4}|[0-9A-F]{6}|[0-9A-F]{8})$/i;
+
+function isHexColor(str) {
+ (0, _assertString.default)(str);
+ return hexcolor.test(str);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isHexadecimal.js b/includes/external/addressbook/node_modules/validator/lib/isHexadecimal.js
new file mode 100644
index 0000000..a1cf738
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isHexadecimal.js
@@ -0,0 +1,20 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isHexadecimal;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var hexadecimal = /^(0x|0h)?[0-9A-F]+$/i;
+
+function isHexadecimal(str) {
+ (0, _assertString.default)(str);
+ return hexadecimal.test(str);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isIBAN.js b/includes/external/addressbook/node_modules/validator/lib/isIBAN.js
new file mode 100644
index 0000000..ef804f2
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isIBAN.js
@@ -0,0 +1,150 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isIBAN;
+exports.locales = void 0;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * List of country codes with
+ * corresponding IBAN regular expression
+ * Reference: https://en.wikipedia.org/wiki/International_Bank_Account_Number
+ */
+var ibanRegexThroughCountryCode = {
+ AD: /^(AD[0-9]{2})\d{8}[A-Z0-9]{12}$/,
+ AE: /^(AE[0-9]{2})\d{3}\d{16}$/,
+ AL: /^(AL[0-9]{2})\d{8}[A-Z0-9]{16}$/,
+ AT: /^(AT[0-9]{2})\d{16}$/,
+ AZ: /^(AZ[0-9]{2})[A-Z0-9]{4}\d{20}$/,
+ BA: /^(BA[0-9]{2})\d{16}$/,
+ BE: /^(BE[0-9]{2})\d{12}$/,
+ BG: /^(BG[0-9]{2})[A-Z]{4}\d{6}[A-Z0-9]{8}$/,
+ BH: /^(BH[0-9]{2})[A-Z]{4}[A-Z0-9]{14}$/,
+ BR: /^(BR[0-9]{2})\d{23}[A-Z]{1}[A-Z0-9]{1}$/,
+ BY: /^(BY[0-9]{2})[A-Z0-9]{4}\d{20}$/,
+ CH: /^(CH[0-9]{2})\d{5}[A-Z0-9]{12}$/,
+ CR: /^(CR[0-9]{2})\d{18}$/,
+ CY: /^(CY[0-9]{2})\d{8}[A-Z0-9]{16}$/,
+ CZ: /^(CZ[0-9]{2})\d{20}$/,
+ DE: /^(DE[0-9]{2})\d{18}$/,
+ DK: /^(DK[0-9]{2})\d{14}$/,
+ DO: /^(DO[0-9]{2})[A-Z]{4}\d{20}$/,
+ EE: /^(EE[0-9]{2})\d{16}$/,
+ EG: /^(EG[0-9]{2})\d{25}$/,
+ ES: /^(ES[0-9]{2})\d{20}$/,
+ FI: /^(FI[0-9]{2})\d{14}$/,
+ FO: /^(FO[0-9]{2})\d{14}$/,
+ FR: /^(FR[0-9]{2})\d{10}[A-Z0-9]{11}\d{2}$/,
+ GB: /^(GB[0-9]{2})[A-Z]{4}\d{14}$/,
+ GE: /^(GE[0-9]{2})[A-Z0-9]{2}\d{16}$/,
+ GI: /^(GI[0-9]{2})[A-Z]{4}[A-Z0-9]{15}$/,
+ GL: /^(GL[0-9]{2})\d{14}$/,
+ GR: /^(GR[0-9]{2})\d{7}[A-Z0-9]{16}$/,
+ GT: /^(GT[0-9]{2})[A-Z0-9]{4}[A-Z0-9]{20}$/,
+ HR: /^(HR[0-9]{2})\d{17}$/,
+ HU: /^(HU[0-9]{2})\d{24}$/,
+ IE: /^(IE[0-9]{2})[A-Z0-9]{4}\d{14}$/,
+ IL: /^(IL[0-9]{2})\d{19}$/,
+ IQ: /^(IQ[0-9]{2})[A-Z]{4}\d{15}$/,
+ IR: /^(IR[0-9]{2})0\d{2}0\d{18}$/,
+ IS: /^(IS[0-9]{2})\d{22}$/,
+ IT: /^(IT[0-9]{2})[A-Z]{1}\d{10}[A-Z0-9]{12}$/,
+ JO: /^(JO[0-9]{2})[A-Z]{4}\d{22}$/,
+ KW: /^(KW[0-9]{2})[A-Z]{4}[A-Z0-9]{22}$/,
+ KZ: /^(KZ[0-9]{2})\d{3}[A-Z0-9]{13}$/,
+ LB: /^(LB[0-9]{2})\d{4}[A-Z0-9]{20}$/,
+ LC: /^(LC[0-9]{2})[A-Z]{4}[A-Z0-9]{24}$/,
+ LI: /^(LI[0-9]{2})\d{5}[A-Z0-9]{12}$/,
+ LT: /^(LT[0-9]{2})\d{16}$/,
+ LU: /^(LU[0-9]{2})\d{3}[A-Z0-9]{13}$/,
+ LV: /^(LV[0-9]{2})[A-Z]{4}[A-Z0-9]{13}$/,
+ MC: /^(MC[0-9]{2})\d{10}[A-Z0-9]{11}\d{2}$/,
+ MD: /^(MD[0-9]{2})[A-Z0-9]{20}$/,
+ ME: /^(ME[0-9]{2})\d{18}$/,
+ MK: /^(MK[0-9]{2})\d{3}[A-Z0-9]{10}\d{2}$/,
+ MR: /^(MR[0-9]{2})\d{23}$/,
+ MT: /^(MT[0-9]{2})[A-Z]{4}\d{5}[A-Z0-9]{18}$/,
+ MU: /^(MU[0-9]{2})[A-Z]{4}\d{19}[A-Z]{3}$/,
+ MZ: /^(MZ[0-9]{2})\d{21}$/,
+ NL: /^(NL[0-9]{2})[A-Z]{4}\d{10}$/,
+ NO: /^(NO[0-9]{2})\d{11}$/,
+ PK: /^(PK[0-9]{2})[A-Z0-9]{4}\d{16}$/,
+ PL: /^(PL[0-9]{2})\d{24}$/,
+ PS: /^(PS[0-9]{2})[A-Z0-9]{4}\d{21}$/,
+ PT: /^(PT[0-9]{2})\d{21}$/,
+ QA: /^(QA[0-9]{2})[A-Z]{4}[A-Z0-9]{21}$/,
+ RO: /^(RO[0-9]{2})[A-Z]{4}[A-Z0-9]{16}$/,
+ RS: /^(RS[0-9]{2})\d{18}$/,
+ SA: /^(SA[0-9]{2})\d{2}[A-Z0-9]{18}$/,
+ SC: /^(SC[0-9]{2})[A-Z]{4}\d{20}[A-Z]{3}$/,
+ SE: /^(SE[0-9]{2})\d{20}$/,
+ SI: /^(SI[0-9]{2})\d{15}$/,
+ SK: /^(SK[0-9]{2})\d{20}$/,
+ SM: /^(SM[0-9]{2})[A-Z]{1}\d{10}[A-Z0-9]{12}$/,
+ SV: /^(SV[0-9]{2})[A-Z0-9]{4}\d{20}$/,
+ TL: /^(TL[0-9]{2})\d{19}$/,
+ TN: /^(TN[0-9]{2})\d{20}$/,
+ TR: /^(TR[0-9]{2})\d{5}[A-Z0-9]{17}$/,
+ UA: /^(UA[0-9]{2})\d{6}[A-Z0-9]{19}$/,
+ VA: /^(VA[0-9]{2})\d{18}$/,
+ VG: /^(VG[0-9]{2})[A-Z0-9]{4}\d{16}$/,
+ XK: /^(XK[0-9]{2})\d{16}$/
+};
+/**
+ * Check whether string has correct universal IBAN format
+ * The IBAN consists of up to 34 alphanumeric characters, as follows:
+ * Country Code using ISO 3166-1 alpha-2, two letters
+ * check digits, two digits and
+ * Basic Bank Account Number (BBAN), up to 30 alphanumeric characters.
+ * NOTE: Permitted IBAN characters are: digits [0-9] and the 26 latin alphabetic [A-Z]
+ *
+ * @param {string} str - string under validation
+ * @return {boolean}
+ */
+
+function hasValidIbanFormat(str) {
+ // Strip white spaces and hyphens
+ var strippedStr = str.replace(/[\s\-]+/gi, '').toUpperCase();
+ var isoCountryCode = strippedStr.slice(0, 2).toUpperCase();
+ return isoCountryCode in ibanRegexThroughCountryCode && ibanRegexThroughCountryCode[isoCountryCode].test(strippedStr);
+}
+/**
+ * Check whether string has valid IBAN Checksum
+ * by performing basic mod-97 operation and
+ * the remainder should equal 1
+ * -- Start by rearranging the IBAN by moving the four initial characters to the end of the string
+ * -- Replace each letter in the string with two digits, A -> 10, B = 11, Z = 35
+ * -- Interpret the string as a decimal integer and
+ * -- compute the remainder on division by 97 (mod 97)
+ * Reference: https://en.wikipedia.org/wiki/International_Bank_Account_Number
+ *
+ * @param {string} str
+ * @return {boolean}
+ */
+
+
+function hasValidIbanChecksum(str) {
+ var strippedStr = str.replace(/[^A-Z0-9]+/gi, '').toUpperCase(); // Keep only digits and A-Z latin alphabetic
+
+ var rearranged = strippedStr.slice(4) + strippedStr.slice(0, 4);
+ var alphaCapsReplacedWithDigits = rearranged.replace(/[A-Z]/g, function (char) {
+ return char.charCodeAt(0) - 55;
+ });
+ var remainder = alphaCapsReplacedWithDigits.match(/\d{1,7}/g).reduce(function (acc, value) {
+ return Number(acc + value) % 97;
+ }, '');
+ return remainder === 1;
+}
+
+function isIBAN(str) {
+ (0, _assertString.default)(str);
+ return hasValidIbanFormat(str) && hasValidIbanChecksum(str);
+}
+
+var locales = Object.keys(ibanRegexThroughCountryCode);
+exports.locales = locales; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isIMEI.js b/includes/external/addressbook/node_modules/validator/lib/isIMEI.js
new file mode 100644
index 0000000..aa05178
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isIMEI.js
@@ -0,0 +1,61 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isIMEI;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var imeiRegexWithoutHypens = /^[0-9]{15}$/;
+var imeiRegexWithHypens = /^\d{2}-\d{6}-\d{6}-\d{1}$/;
+
+function isIMEI(str, options) {
+ (0, _assertString.default)(str);
+ options = options || {}; // default regex for checking imei is the one without hyphens
+
+ var imeiRegex = imeiRegexWithoutHypens;
+
+ if (options.allow_hyphens) {
+ imeiRegex = imeiRegexWithHypens;
+ }
+
+ if (!imeiRegex.test(str)) {
+ return false;
+ }
+
+ str = str.replace(/-/g, '');
+ var sum = 0,
+ mul = 2,
+ l = 14;
+
+ for (var i = 0; i < l; i++) {
+ var digit = str.substring(l - i - 1, l - i);
+ var tp = parseInt(digit, 10) * mul;
+
+ if (tp >= 10) {
+ sum += tp % 10 + 1;
+ } else {
+ sum += tp;
+ }
+
+ if (mul === 1) {
+ mul += 1;
+ } else {
+ mul -= 1;
+ }
+ }
+
+ var chk = (10 - sum % 10) % 10;
+
+ if (chk !== parseInt(str.substring(14, 15), 10)) {
+ return false;
+ }
+
+ return true;
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isIP.js b/includes/external/addressbook/node_modules/validator/lib/isIP.js
new file mode 100644
index 0000000..f885cdd
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isIP.js
@@ -0,0 +1,68 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isIP;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+11.3. Examples
+
+ The following addresses
+
+ fe80::1234 (on the 1st link of the node)
+ ff02::5678 (on the 5th link of the node)
+ ff08::9abc (on the 10th organization of the node)
+
+ would be represented as follows:
+
+ fe80::1234%1
+ ff02::5678%5
+ ff08::9abc%10
+
+ (Here we assume a natural translation from a zone index to the
+ <zone_id> part, where the Nth zone of any scope is translated into
+ "N".)
+
+ If we use interface names as <zone_id>, those addresses could also be
+ represented as follows:
+
+ fe80::1234%ne0
+ ff02::5678%pvc1.3
+ ff08::9abc%interface10
+
+ where the interface "ne0" belongs to the 1st link, "pvc1.3" belongs
+ to the 5th link, and "interface10" belongs to the 10th organization.
+ * * */
+var IPv4SegmentFormat = '(?:[0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])';
+var IPv4AddressFormat = "(".concat(IPv4SegmentFormat, "[.]){3}").concat(IPv4SegmentFormat);
+var IPv4AddressRegExp = new RegExp("^".concat(IPv4AddressFormat, "$"));
+var IPv6SegmentFormat = '(?:[0-9a-fA-F]{1,4})';
+var IPv6AddressRegExp = new RegExp('^(' + "(?:".concat(IPv6SegmentFormat, ":){7}(?:").concat(IPv6SegmentFormat, "|:)|") + "(?:".concat(IPv6SegmentFormat, ":){6}(?:").concat(IPv4AddressFormat, "|:").concat(IPv6SegmentFormat, "|:)|") + "(?:".concat(IPv6SegmentFormat, ":){5}(?::").concat(IPv4AddressFormat, "|(:").concat(IPv6SegmentFormat, "){1,2}|:)|") + "(?:".concat(IPv6SegmentFormat, ":){4}(?:(:").concat(IPv6SegmentFormat, "){0,1}:").concat(IPv4AddressFormat, "|(:").concat(IPv6SegmentFormat, "){1,3}|:)|") + "(?:".concat(IPv6SegmentFormat, ":){3}(?:(:").concat(IPv6SegmentFormat, "){0,2}:").concat(IPv4AddressFormat, "|(:").concat(IPv6SegmentFormat, "){1,4}|:)|") + "(?:".concat(IPv6SegmentFormat, ":){2}(?:(:").concat(IPv6SegmentFormat, "){0,3}:").concat(IPv4AddressFormat, "|(:").concat(IPv6SegmentFormat, "){1,5}|:)|") + "(?:".concat(IPv6SegmentFormat, ":){1}(?:(:").concat(IPv6SegmentFormat, "){0,4}:").concat(IPv4AddressFormat, "|(:").concat(IPv6SegmentFormat, "){1,6}|:)|") + "(?::((?::".concat(IPv6SegmentFormat, "){0,5}:").concat(IPv4AddressFormat, "|(?::").concat(IPv6SegmentFormat, "){1,7}|:))") + ')(%[0-9a-zA-Z-.:]{1,})?$');
+
+function isIP(str) {
+ var version = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';
+ (0, _assertString.default)(str);
+ version = String(version);
+
+ if (!version) {
+ return isIP(str, 4) || isIP(str, 6);
+ }
+
+ if (version === '4') {
+ return IPv4AddressRegExp.test(str);
+ }
+
+ if (version === '6') {
+ return IPv6AddressRegExp.test(str);
+ }
+
+ return false;
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isIPRange.js b/includes/external/addressbook/node_modules/validator/lib/isIPRange.js
new file mode 100644
index 0000000..293a1a2
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isIPRange.js
@@ -0,0 +1,62 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isIPRange;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var _isIP = _interopRequireDefault(require("./isIP"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var subnetMaybe = /^\d{1,3}$/;
+var v4Subnet = 32;
+var v6Subnet = 128;
+
+function isIPRange(str) {
+ var version = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';
+ (0, _assertString.default)(str);
+ var parts = str.split('/'); // parts[0] -> ip, parts[1] -> subnet
+
+ if (parts.length !== 2) {
+ return false;
+ }
+
+ if (!subnetMaybe.test(parts[1])) {
+ return false;
+ } // Disallow preceding 0 i.e. 01, 02, ...
+
+
+ if (parts[1].length > 1 && parts[1].startsWith('0')) {
+ return false;
+ }
+
+ var isValidIP = (0, _isIP.default)(parts[0], version);
+
+ if (!isValidIP) {
+ return false;
+ } // Define valid subnet according to IP's version
+
+
+ var expectedSubnet = null;
+
+ switch (String(version)) {
+ case '4':
+ expectedSubnet = v4Subnet;
+ break;
+
+ case '6':
+ expectedSubnet = v6Subnet;
+ break;
+
+ default:
+ expectedSubnet = (0, _isIP.default)(parts[0], '6') ? v6Subnet : v4Subnet;
+ }
+
+ return parts[1] <= expectedSubnet && parts[1] >= 0;
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isISBN.js b/includes/external/addressbook/node_modules/validator/lib/isISBN.js
new file mode 100644
index 0000000..b272b9a
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isISBN.js
@@ -0,0 +1,69 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isISBN;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var possibleIsbn10 = /^(?:[0-9]{9}X|[0-9]{10})$/;
+var possibleIsbn13 = /^(?:[0-9]{13})$/;
+var factor = [1, 3];
+
+function isISBN(isbn, options) {
+ (0, _assertString.default)(isbn); // For backwards compatibility:
+ // isISBN(str [, version]), i.e. `options` could be used as argument for the legacy `version`
+
+ var version = String((options === null || options === void 0 ? void 0 : options.version) || options);
+
+ if (!(options !== null && options !== void 0 && options.version || options)) {
+ return isISBN(isbn, {
+ version: 10
+ }) || isISBN(isbn, {
+ version: 13
+ });
+ }
+
+ var sanitizedIsbn = isbn.replace(/[\s-]+/g, '');
+ var checksum = 0;
+
+ if (version === '10') {
+ if (!possibleIsbn10.test(sanitizedIsbn)) {
+ return false;
+ }
+
+ for (var i = 0; i < version - 1; i++) {
+ checksum += (i + 1) * sanitizedIsbn.charAt(i);
+ }
+
+ if (sanitizedIsbn.charAt(9) === 'X') {
+ checksum += 10 * 10;
+ } else {
+ checksum += 10 * sanitizedIsbn.charAt(9);
+ }
+
+ if (checksum % 11 === 0) {
+ return true;
+ }
+ } else if (version === '13') {
+ if (!possibleIsbn13.test(sanitizedIsbn)) {
+ return false;
+ }
+
+ for (var _i = 0; _i < 12; _i++) {
+ checksum += factor[_i % 2] * sanitizedIsbn.charAt(_i);
+ }
+
+ if (sanitizedIsbn.charAt(12) - (10 - checksum % 10) % 10 === 0) {
+ return true;
+ }
+ }
+
+ return false;
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isISIN.js b/includes/external/addressbook/node_modules/validator/lib/isISIN.js
new file mode 100644
index 0000000..3943890
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isISIN.js
@@ -0,0 +1,73 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isISIN;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var isin = /^[A-Z]{2}[0-9A-Z]{9}[0-9]$/; // this link details how the check digit is calculated:
+// https://www.isin.org/isin-format/. it is a little bit
+// odd in that it works with digits, not numbers. in order
+// to make only one pass through the ISIN characters, the
+// each alpha character is handled as 2 characters within
+// the loop.
+
+function isISIN(str) {
+ (0, _assertString.default)(str);
+
+ if (!isin.test(str)) {
+ return false;
+ }
+
+ var double = true;
+ var sum = 0; // convert values
+
+ for (var i = str.length - 2; i >= 0; i--) {
+ if (str[i] >= 'A' && str[i] <= 'Z') {
+ var value = str[i].charCodeAt(0) - 55;
+ var lo = value % 10;
+ var hi = Math.trunc(value / 10); // letters have two digits, so handle the low order
+ // and high order digits separately.
+
+ for (var _i = 0, _arr = [lo, hi]; _i < _arr.length; _i++) {
+ var digit = _arr[_i];
+
+ if (double) {
+ if (digit >= 5) {
+ sum += 1 + (digit - 5) * 2;
+ } else {
+ sum += digit * 2;
+ }
+ } else {
+ sum += digit;
+ }
+
+ double = !double;
+ }
+ } else {
+ var _digit = str[i].charCodeAt(0) - '0'.charCodeAt(0);
+
+ if (double) {
+ if (_digit >= 5) {
+ sum += 1 + (_digit - 5) * 2;
+ } else {
+ sum += _digit * 2;
+ }
+ } else {
+ sum += _digit;
+ }
+
+ double = !double;
+ }
+ }
+
+ var check = Math.trunc((sum + 9) / 10) * 10 - sum;
+ return +str[str.length - 1] === check;
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isISO31661Alpha2.js b/includes/external/addressbook/node_modules/validator/lib/isISO31661Alpha2.js
new file mode 100644
index 0000000..d15bb5b
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isISO31661Alpha2.js
@@ -0,0 +1,22 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isISO31661Alpha2;
+exports.CountryCodes = void 0;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+// from https://en.wikipedia.org/wiki/ISO_3166-1_alpha-2
+var validISO31661Alpha2CountriesCodes = new Set(['AD', 'AE', 'AF', 'AG', 'AI', 'AL', 'AM', 'AO', 'AQ', 'AR', 'AS', 'AT', 'AU', 'AW', 'AX', 'AZ', 'BA', 'BB', 'BD', 'BE', 'BF', 'BG', 'BH', 'BI', 'BJ', 'BL', 'BM', 'BN', 'BO', 'BQ', 'BR', 'BS', 'BT', 'BV', 'BW', 'BY', 'BZ', 'CA', 'CC', 'CD', 'CF', 'CG', 'CH', 'CI', 'CK', 'CL', 'CM', 'CN', 'CO', 'CR', 'CU', 'CV', 'CW', 'CX', 'CY', 'CZ', 'DE', 'DJ', 'DK', 'DM', 'DO', 'DZ', 'EC', 'EE', 'EG', 'EH', 'ER', 'ES', 'ET', 'FI', 'FJ', 'FK', 'FM', 'FO', 'FR', 'GA', 'GB', 'GD', 'GE', 'GF', 'GG', 'GH', 'GI', 'GL', 'GM', 'GN', 'GP', 'GQ', 'GR', 'GS', 'GT', 'GU', 'GW', 'GY', 'HK', 'HM', 'HN', 'HR', 'HT', 'HU', 'ID', 'IE', 'IL', 'IM', 'IN', 'IO', 'IQ', 'IR', 'IS', 'IT', 'JE', 'JM', 'JO', 'JP', 'KE', 'KG', 'KH', 'KI', 'KM', 'KN', 'KP', 'KR', 'KW', 'KY', 'KZ', 'LA', 'LB', 'LC', 'LI', 'LK', 'LR', 'LS', 'LT', 'LU', 'LV', 'LY', 'MA', 'MC', 'MD', 'ME', 'MF', 'MG', 'MH', 'MK', 'ML', 'MM', 'MN', 'MO', 'MP', 'MQ', 'MR', 'MS', 'MT', 'MU', 'MV', 'MW', 'MX', 'MY', 'MZ', 'NA', 'NC', 'NE', 'NF', 'NG', 'NI', 'NL', 'NO', 'NP', 'NR', 'NU', 'NZ', 'OM', 'PA', 'PE', 'PF', 'PG', 'PH', 'PK', 'PL', 'PM', 'PN', 'PR', 'PS', 'PT', 'PW', 'PY', 'QA', 'RE', 'RO', 'RS', 'RU', 'RW', 'SA', 'SB', 'SC', 'SD', 'SE', 'SG', 'SH', 'SI', 'SJ', 'SK', 'SL', 'SM', 'SN', 'SO', 'SR', 'SS', 'ST', 'SV', 'SX', 'SY', 'SZ', 'TC', 'TD', 'TF', 'TG', 'TH', 'TJ', 'TK', 'TL', 'TM', 'TN', 'TO', 'TR', 'TT', 'TV', 'TW', 'TZ', 'UA', 'UG', 'UM', 'US', 'UY', 'UZ', 'VA', 'VC', 'VE', 'VG', 'VI', 'VN', 'VU', 'WF', 'WS', 'YE', 'YT', 'ZA', 'ZM', 'ZW']);
+
+function isISO31661Alpha2(str) {
+ (0, _assertString.default)(str);
+ return validISO31661Alpha2CountriesCodes.has(str.toUpperCase());
+}
+
+var CountryCodes = validISO31661Alpha2CountriesCodes;
+exports.CountryCodes = CountryCodes; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isISO31661Alpha3.js b/includes/external/addressbook/node_modules/validator/lib/isISO31661Alpha3.js
new file mode 100644
index 0000000..cdb774f
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isISO31661Alpha3.js
@@ -0,0 +1,21 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isISO31661Alpha3;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+// from https://en.wikipedia.org/wiki/ISO_3166-1_alpha-3
+var validISO31661Alpha3CountriesCodes = new Set(['AFG', 'ALA', 'ALB', 'DZA', 'ASM', 'AND', 'AGO', 'AIA', 'ATA', 'ATG', 'ARG', 'ARM', 'ABW', 'AUS', 'AUT', 'AZE', 'BHS', 'BHR', 'BGD', 'BRB', 'BLR', 'BEL', 'BLZ', 'BEN', 'BMU', 'BTN', 'BOL', 'BES', 'BIH', 'BWA', 'BVT', 'BRA', 'IOT', 'BRN', 'BGR', 'BFA', 'BDI', 'KHM', 'CMR', 'CAN', 'CPV', 'CYM', 'CAF', 'TCD', 'CHL', 'CHN', 'CXR', 'CCK', 'COL', 'COM', 'COG', 'COD', 'COK', 'CRI', 'CIV', 'HRV', 'CUB', 'CUW', 'CYP', 'CZE', 'DNK', 'DJI', 'DMA', 'DOM', 'ECU', 'EGY', 'SLV', 'GNQ', 'ERI', 'EST', 'ETH', 'FLK', 'FRO', 'FJI', 'FIN', 'FRA', 'GUF', 'PYF', 'ATF', 'GAB', 'GMB', 'GEO', 'DEU', 'GHA', 'GIB', 'GRC', 'GRL', 'GRD', 'GLP', 'GUM', 'GTM', 'GGY', 'GIN', 'GNB', 'GUY', 'HTI', 'HMD', 'VAT', 'HND', 'HKG', 'HUN', 'ISL', 'IND', 'IDN', 'IRN', 'IRQ', 'IRL', 'IMN', 'ISR', 'ITA', 'JAM', 'JPN', 'JEY', 'JOR', 'KAZ', 'KEN', 'KIR', 'PRK', 'KOR', 'KWT', 'KGZ', 'LAO', 'LVA', 'LBN', 'LSO', 'LBR', 'LBY', 'LIE', 'LTU', 'LUX', 'MAC', 'MKD', 'MDG', 'MWI', 'MYS', 'MDV', 'MLI', 'MLT', 'MHL', 'MTQ', 'MRT', 'MUS', 'MYT', 'MEX', 'FSM', 'MDA', 'MCO', 'MNG', 'MNE', 'MSR', 'MAR', 'MOZ', 'MMR', 'NAM', 'NRU', 'NPL', 'NLD', 'NCL', 'NZL', 'NIC', 'NER', 'NGA', 'NIU', 'NFK', 'MNP', 'NOR', 'OMN', 'PAK', 'PLW', 'PSE', 'PAN', 'PNG', 'PRY', 'PER', 'PHL', 'PCN', 'POL', 'PRT', 'PRI', 'QAT', 'REU', 'ROU', 'RUS', 'RWA', 'BLM', 'SHN', 'KNA', 'LCA', 'MAF', 'SPM', 'VCT', 'WSM', 'SMR', 'STP', 'SAU', 'SEN', 'SRB', 'SYC', 'SLE', 'SGP', 'SXM', 'SVK', 'SVN', 'SLB', 'SOM', 'ZAF', 'SGS', 'SSD', 'ESP', 'LKA', 'SDN', 'SUR', 'SJM', 'SWZ', 'SWE', 'CHE', 'SYR', 'TWN', 'TJK', 'TZA', 'THA', 'TLS', 'TGO', 'TKL', 'TON', 'TTO', 'TUN', 'TUR', 'TKM', 'TCA', 'TUV', 'UGA', 'UKR', 'ARE', 'GBR', 'USA', 'UMI', 'URY', 'UZB', 'VUT', 'VEN', 'VNM', 'VGB', 'VIR', 'WLF', 'ESH', 'YEM', 'ZMB', 'ZWE']);
+
+function isISO31661Alpha3(str) {
+ (0, _assertString.default)(str);
+ return validISO31661Alpha3CountriesCodes.has(str.toUpperCase());
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isISO4217.js b/includes/external/addressbook/node_modules/validator/lib/isISO4217.js
new file mode 100644
index 0000000..fd052f3
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isISO4217.js
@@ -0,0 +1,22 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isISO4217;
+exports.CurrencyCodes = void 0;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+// from https://en.wikipedia.org/wiki/ISO_4217
+var validISO4217CurrencyCodes = new Set(['AED', 'AFN', 'ALL', 'AMD', 'ANG', 'AOA', 'ARS', 'AUD', 'AWG', 'AZN', 'BAM', 'BBD', 'BDT', 'BGN', 'BHD', 'BIF', 'BMD', 'BND', 'BOB', 'BOV', 'BRL', 'BSD', 'BTN', 'BWP', 'BYN', 'BZD', 'CAD', 'CDF', 'CHE', 'CHF', 'CHW', 'CLF', 'CLP', 'CNY', 'COP', 'COU', 'CRC', 'CUC', 'CUP', 'CVE', 'CZK', 'DJF', 'DKK', 'DOP', 'DZD', 'EGP', 'ERN', 'ETB', 'EUR', 'FJD', 'FKP', 'GBP', 'GEL', 'GHS', 'GIP', 'GMD', 'GNF', 'GTQ', 'GYD', 'HKD', 'HNL', 'HRK', 'HTG', 'HUF', 'IDR', 'ILS', 'INR', 'IQD', 'IRR', 'ISK', 'JMD', 'JOD', 'JPY', 'KES', 'KGS', 'KHR', 'KMF', 'KPW', 'KRW', 'KWD', 'KYD', 'KZT', 'LAK', 'LBP', 'LKR', 'LRD', 'LSL', 'LYD', 'MAD', 'MDL', 'MGA', 'MKD', 'MMK', 'MNT', 'MOP', 'MRU', 'MUR', 'MVR', 'MWK', 'MXN', 'MXV', 'MYR', 'MZN', 'NAD', 'NGN', 'NIO', 'NOK', 'NPR', 'NZD', 'OMR', 'PAB', 'PEN', 'PGK', 'PHP', 'PKR', 'PLN', 'PYG', 'QAR', 'RON', 'RSD', 'RUB', 'RWF', 'SAR', 'SBD', 'SCR', 'SDG', 'SEK', 'SGD', 'SHP', 'SLL', 'SOS', 'SRD', 'SSP', 'STN', 'SVC', 'SYP', 'SZL', 'THB', 'TJS', 'TMT', 'TND', 'TOP', 'TRY', 'TTD', 'TWD', 'TZS', 'UAH', 'UGX', 'USD', 'USN', 'UYI', 'UYU', 'UYW', 'UZS', 'VES', 'VND', 'VUV', 'WST', 'XAF', 'XAG', 'XAU', 'XBA', 'XBB', 'XBC', 'XBD', 'XCD', 'XDR', 'XOF', 'XPD', 'XPF', 'XPT', 'XSU', 'XTS', 'XUA', 'XXX', 'YER', 'ZAR', 'ZMW', 'ZWL']);
+
+function isISO4217(str) {
+ (0, _assertString.default)(str);
+ return validISO4217CurrencyCodes.has(str.toUpperCase());
+}
+
+var CurrencyCodes = validISO4217CurrencyCodes;
+exports.CurrencyCodes = CurrencyCodes; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isISO6391.js b/includes/external/addressbook/node_modules/validator/lib/isISO6391.js
new file mode 100644
index 0000000..4badec2
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isISO6391.js
@@ -0,0 +1,20 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isISO6391;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var isISO6391Set = new Set(['aa', 'ab', 'ae', 'af', 'ak', 'am', 'an', 'ar', 'as', 'av', 'ay', 'az', 'az', 'ba', 'be', 'bg', 'bh', 'bi', 'bm', 'bn', 'bo', 'br', 'bs', 'ca', 'ce', 'ch', 'co', 'cr', 'cs', 'cu', 'cv', 'cy', 'da', 'de', 'dv', 'dz', 'ee', 'el', 'en', 'eo', 'es', 'et', 'eu', 'fa', 'ff', 'fi', 'fj', 'fo', 'fr', 'fy', 'ga', 'gd', 'gl', 'gn', 'gu', 'gv', 'ha', 'he', 'hi', 'ho', 'hr', 'ht', 'hu', 'hy', 'hz', 'ia', 'id', 'ie', 'ig', 'ii', 'ik', 'io', 'is', 'it', 'iu', 'ja', 'jv', 'ka', 'kg', 'ki', 'kj', 'kk', 'kl', 'km', 'kn', 'ko', 'kr', 'ks', 'ku', 'kv', 'kw', 'ky', 'la', 'lb', 'lg', 'li', 'ln', 'lo', 'lt', 'lu', 'lv', 'mg', 'mh', 'mi', 'mk', 'ml', 'mn', 'mr', 'ms', 'mt', 'my', 'na', 'nb', 'nd', 'ne', 'ng', 'nl', 'nn', 'no', 'nr', 'nv', 'ny', 'oc', 'oj', 'om', 'or', 'os', 'pa', 'pi', 'pl', 'ps', 'pt', 'qu', 'rm', 'rn', 'ro', 'ru', 'rw', 'sa', 'sc', 'sd', 'se', 'sg', 'si', 'sk', 'sl', 'sm', 'sn', 'so', 'sq', 'sr', 'ss', 'st', 'su', 'sv', 'sw', 'ta', 'te', 'tg', 'th', 'ti', 'tk', 'tl', 'tn', 'to', 'tr', 'ts', 'tt', 'tw', 'ty', 'ug', 'uk', 'ur', 'uz', 've', 'vi', 'vo', 'wa', 'wo', 'xh', 'yi', 'yo', 'za', 'zh', 'zu']);
+
+function isISO6391(str) {
+ (0, _assertString.default)(str);
+ return isISO6391Set.has(str);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isISO8601.js b/includes/external/addressbook/node_modules/validator/lib/isISO8601.js
new file mode 100644
index 0000000..b739606
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isISO8601.js
@@ -0,0 +1,59 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isISO8601;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/* eslint-disable max-len */
+// from http://goo.gl/0ejHHW
+var iso8601 = /^([\+-]?\d{4}(?!\d{2}\b))((-?)((0[1-9]|1[0-2])(\3([12]\d|0[1-9]|3[01]))?|W([0-4]\d|5[0-3])(-?[1-7])?|(00[1-9]|0[1-9]\d|[12]\d{2}|3([0-5]\d|6[1-6])))([T\s]((([01]\d|2[0-3])((:?)[0-5]\d)?|24:?00)([\.,]\d+(?!:))?)?(\17[0-5]\d([\.,]\d+)?)?([zZ]|([\+-])([01]\d|2[0-3]):?([0-5]\d)?)?)?)?$/; // same as above, except with a strict 'T' separator between date and time
+
+var iso8601StrictSeparator = /^([\+-]?\d{4}(?!\d{2}\b))((-?)((0[1-9]|1[0-2])(\3([12]\d|0[1-9]|3[01]))?|W([0-4]\d|5[0-3])(-?[1-7])?|(00[1-9]|0[1-9]\d|[12]\d{2}|3([0-5]\d|6[1-6])))([T]((([01]\d|2[0-3])((:?)[0-5]\d)?|24:?00)([\.,]\d+(?!:))?)?(\17[0-5]\d([\.,]\d+)?)?([zZ]|([\+-])([01]\d|2[0-3]):?([0-5]\d)?)?)?)?$/;
+/* eslint-enable max-len */
+
+var isValidDate = function isValidDate(str) {
+ // str must have passed the ISO8601 check
+ // this check is meant to catch invalid dates
+ // like 2009-02-31
+ // first check for ordinal dates
+ var ordinalMatch = str.match(/^(\d{4})-?(\d{3})([ T]{1}\.*|$)/);
+
+ if (ordinalMatch) {
+ var oYear = Number(ordinalMatch[1]);
+ var oDay = Number(ordinalMatch[2]); // if is leap year
+
+ if (oYear % 4 === 0 && oYear % 100 !== 0 || oYear % 400 === 0) return oDay <= 366;
+ return oDay <= 365;
+ }
+
+ var match = str.match(/(\d{4})-?(\d{0,2})-?(\d*)/).map(Number);
+ var year = match[1];
+ var month = match[2];
+ var day = match[3];
+ var monthString = month ? "0".concat(month).slice(-2) : month;
+ var dayString = day ? "0".concat(day).slice(-2) : day; // create a date object and compare
+
+ var d = new Date("".concat(year, "-").concat(monthString || '01', "-").concat(dayString || '01'));
+
+ if (month && day) {
+ return d.getUTCFullYear() === year && d.getUTCMonth() + 1 === month && d.getUTCDate() === day;
+ }
+
+ return true;
+};
+
+function isISO8601(str) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ (0, _assertString.default)(str);
+ var check = options.strictSeparator ? iso8601StrictSeparator.test(str) : iso8601.test(str);
+ if (check && options.strict) return isValidDate(str);
+ return check;
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isISRC.js b/includes/external/addressbook/node_modules/validator/lib/isISRC.js
new file mode 100644
index 0000000..c5ce1e2
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isISRC.js
@@ -0,0 +1,21 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isISRC;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+// see http://isrc.ifpi.org/en/isrc-standard/code-syntax
+var isrc = /^[A-Z]{2}[0-9A-Z]{3}\d{2}\d{5}$/;
+
+function isISRC(str) {
+ (0, _assertString.default)(str);
+ return isrc.test(str);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isISSN.js b/includes/external/addressbook/node_modules/validator/lib/isISSN.js
new file mode 100644
index 0000000..eee87b3
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isISSN.js
@@ -0,0 +1,37 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isISSN;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var issn = '^\\d{4}-?\\d{3}[\\dX]$';
+
+function isISSN(str) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ (0, _assertString.default)(str);
+ var testIssn = issn;
+ testIssn = options.require_hyphen ? testIssn.replace('?', '') : testIssn;
+ testIssn = options.case_sensitive ? new RegExp(testIssn) : new RegExp(testIssn, 'i');
+
+ if (!testIssn.test(str)) {
+ return false;
+ }
+
+ var digits = str.replace('-', '').toUpperCase();
+ var checksum = 0;
+
+ for (var i = 0; i < digits.length; i++) {
+ var digit = digits[i];
+ checksum += (digit === 'X' ? 10 : +digit) * (8 - i);
+ }
+
+ return checksum % 11 === 0;
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isIdentityCard.js b/includes/external/addressbook/node_modules/validator/lib/isIdentityCard.js
new file mode 100644
index 0000000..e8c8892
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isIdentityCard.js
@@ -0,0 +1,410 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isIdentityCard;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var _isInt = _interopRequireDefault(require("./isInt"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var validators = {
+ PL: function PL(str) {
+ (0, _assertString.default)(str);
+ var weightOfDigits = {
+ 1: 1,
+ 2: 3,
+ 3: 7,
+ 4: 9,
+ 5: 1,
+ 6: 3,
+ 7: 7,
+ 8: 9,
+ 9: 1,
+ 10: 3,
+ 11: 0
+ };
+
+ if (str != null && str.length === 11 && (0, _isInt.default)(str, {
+ allow_leading_zeroes: true
+ })) {
+ var digits = str.split('').slice(0, -1);
+ var sum = digits.reduce(function (acc, digit, index) {
+ return acc + Number(digit) * weightOfDigits[index + 1];
+ }, 0);
+ var modulo = sum % 10;
+ var lastDigit = Number(str.charAt(str.length - 1));
+
+ if (modulo === 0 && lastDigit === 0 || lastDigit === 10 - modulo) {
+ return true;
+ }
+ }
+
+ return false;
+ },
+ ES: function ES(str) {
+ (0, _assertString.default)(str);
+ var DNI = /^[0-9X-Z][0-9]{7}[TRWAGMYFPDXBNJZSQVHLCKE]$/;
+ var charsValue = {
+ X: 0,
+ Y: 1,
+ Z: 2
+ };
+ var controlDigits = ['T', 'R', 'W', 'A', 'G', 'M', 'Y', 'F', 'P', 'D', 'X', 'B', 'N', 'J', 'Z', 'S', 'Q', 'V', 'H', 'L', 'C', 'K', 'E']; // sanitize user input
+
+ var sanitized = str.trim().toUpperCase(); // validate the data structure
+
+ if (!DNI.test(sanitized)) {
+ return false;
+ } // validate the control digit
+
+
+ var number = sanitized.slice(0, -1).replace(/[X,Y,Z]/g, function (char) {
+ return charsValue[char];
+ });
+ return sanitized.endsWith(controlDigits[number % 23]);
+ },
+ FI: function FI(str) {
+ // https://dvv.fi/en/personal-identity-code#:~:text=control%20character%20for%20a-,personal,-identity%20code%20calculated
+ (0, _assertString.default)(str);
+
+ if (str.length !== 11) {
+ return false;
+ }
+
+ if (!str.match(/^\d{6}[\-A\+]\d{3}[0-9ABCDEFHJKLMNPRSTUVWXY]{1}$/)) {
+ return false;
+ }
+
+ var checkDigits = '0123456789ABCDEFHJKLMNPRSTUVWXY';
+ var idAsNumber = parseInt(str.slice(0, 6), 10) * 1000 + parseInt(str.slice(7, 10), 10);
+ var remainder = idAsNumber % 31;
+ var checkDigit = checkDigits[remainder];
+ return checkDigit === str.slice(10, 11);
+ },
+ IN: function IN(str) {
+ var DNI = /^[1-9]\d{3}\s?\d{4}\s?\d{4}$/; // multiplication table
+
+ var d = [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9], [1, 2, 3, 4, 0, 6, 7, 8, 9, 5], [2, 3, 4, 0, 1, 7, 8, 9, 5, 6], [3, 4, 0, 1, 2, 8, 9, 5, 6, 7], [4, 0, 1, 2, 3, 9, 5, 6, 7, 8], [5, 9, 8, 7, 6, 0, 4, 3, 2, 1], [6, 5, 9, 8, 7, 1, 0, 4, 3, 2], [7, 6, 5, 9, 8, 2, 1, 0, 4, 3], [8, 7, 6, 5, 9, 3, 2, 1, 0, 4], [9, 8, 7, 6, 5, 4, 3, 2, 1, 0]]; // permutation table
+
+ var p = [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9], [1, 5, 7, 6, 2, 8, 3, 0, 9, 4], [5, 8, 0, 3, 7, 9, 6, 1, 4, 2], [8, 9, 1, 6, 0, 4, 3, 5, 2, 7], [9, 4, 5, 3, 1, 2, 6, 8, 7, 0], [4, 2, 8, 6, 5, 7, 3, 9, 0, 1], [2, 7, 9, 3, 8, 0, 6, 4, 1, 5], [7, 0, 4, 6, 9, 1, 3, 2, 5, 8]]; // sanitize user input
+
+ var sanitized = str.trim(); // validate the data structure
+
+ if (!DNI.test(sanitized)) {
+ return false;
+ }
+
+ var c = 0;
+ var invertedArray = sanitized.replace(/\s/g, '').split('').map(Number).reverse();
+ invertedArray.forEach(function (val, i) {
+ c = d[c][p[i % 8][val]];
+ });
+ return c === 0;
+ },
+ IR: function IR(str) {
+ if (!str.match(/^\d{10}$/)) return false;
+ str = "0000".concat(str).slice(str.length - 6);
+ if (parseInt(str.slice(3, 9), 10) === 0) return false;
+ var lastNumber = parseInt(str.slice(9, 10), 10);
+ var sum = 0;
+
+ for (var i = 0; i < 9; i++) {
+ sum += parseInt(str.slice(i, i + 1), 10) * (10 - i);
+ }
+
+ sum %= 11;
+ return sum < 2 && lastNumber === sum || sum >= 2 && lastNumber === 11 - sum;
+ },
+ IT: function IT(str) {
+ if (str.length !== 9) return false;
+ if (str === 'CA00000AA') return false; // https://it.wikipedia.org/wiki/Carta_d%27identit%C3%A0_elettronica_italiana
+
+ return str.search(/C[A-Z][0-9]{5}[A-Z]{2}/i) > -1;
+ },
+ NO: function NO(str) {
+ var sanitized = str.trim();
+ if (isNaN(Number(sanitized))) return false;
+ if (sanitized.length !== 11) return false;
+ if (sanitized === '00000000000') return false; // https://no.wikipedia.org/wiki/F%C3%B8dselsnummer
+
+ var f = sanitized.split('').map(Number);
+ var k1 = (11 - (3 * f[0] + 7 * f[1] + 6 * f[2] + 1 * f[3] + 8 * f[4] + 9 * f[5] + 4 * f[6] + 5 * f[7] + 2 * f[8]) % 11) % 11;
+ var k2 = (11 - (5 * f[0] + 4 * f[1] + 3 * f[2] + 2 * f[3] + 7 * f[4] + 6 * f[5] + 5 * f[6] + 4 * f[7] + 3 * f[8] + 2 * k1) % 11) % 11;
+ if (k1 !== f[9] || k2 !== f[10]) return false;
+ return true;
+ },
+ TH: function TH(str) {
+ if (!str.match(/^[1-8]\d{12}$/)) return false; // validate check digit
+
+ var sum = 0;
+
+ for (var i = 0; i < 12; i++) {
+ sum += parseInt(str[i], 10) * (13 - i);
+ }
+
+ return str[12] === ((11 - sum % 11) % 10).toString();
+ },
+ LK: function LK(str) {
+ var old_nic = /^[1-9]\d{8}[vx]$/i;
+ var new_nic = /^[1-9]\d{11}$/i;
+ if (str.length === 10 && old_nic.test(str)) return true;else if (str.length === 12 && new_nic.test(str)) return true;
+ return false;
+ },
+ 'he-IL': function heIL(str) {
+ var DNI = /^\d{9}$/; // sanitize user input
+
+ var sanitized = str.trim(); // validate the data structure
+
+ if (!DNI.test(sanitized)) {
+ return false;
+ }
+
+ var id = sanitized;
+ var sum = 0,
+ incNum;
+
+ for (var i = 0; i < id.length; i++) {
+ incNum = Number(id[i]) * (i % 2 + 1); // Multiply number by 1 or 2
+
+ sum += incNum > 9 ? incNum - 9 : incNum; // Sum the digits up and add to total
+ }
+
+ return sum % 10 === 0;
+ },
+ 'ar-LY': function arLY(str) {
+ // Libya National Identity Number NIN is 12 digits, the first digit is either 1 or 2
+ var NIN = /^(1|2)\d{11}$/; // sanitize user input
+
+ var sanitized = str.trim(); // validate the data structure
+
+ if (!NIN.test(sanitized)) {
+ return false;
+ }
+
+ return true;
+ },
+ 'ar-TN': function arTN(str) {
+ var DNI = /^\d{8}$/; // sanitize user input
+
+ var sanitized = str.trim(); // validate the data structure
+
+ if (!DNI.test(sanitized)) {
+ return false;
+ }
+
+ return true;
+ },
+ 'zh-CN': function zhCN(str) {
+ var provincesAndCities = ['11', // 北京
+ '12', // 天津
+ '13', // 河北
+ '14', // 山西
+ '15', // 内蒙古
+ '21', // 辽宁
+ '22', // 吉林
+ '23', // 黑龙江
+ '31', // 上海
+ '32', // 江苏
+ '33', // 浙江
+ '34', // 安徽
+ '35', // 福建
+ '36', // 江西
+ '37', // 山东
+ '41', // 河南
+ '42', // 湖北
+ '43', // 湖南
+ '44', // 广东
+ '45', // 广西
+ '46', // 海南
+ '50', // 重庆
+ '51', // 四川
+ '52', // 贵州
+ '53', // 云南
+ '54', // 西藏
+ '61', // 陕西
+ '62', // 甘肃
+ '63', // 青海
+ '64', // 宁夏
+ '65', // 新疆
+ '71', // 台湾
+ '81', // 香港
+ '82', // 澳门
+ '91' // 国外
+ ];
+ var powers = ['7', '9', '10', '5', '8', '4', '2', '1', '6', '3', '7', '9', '10', '5', '8', '4', '2'];
+ var parityBit = ['1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'];
+
+ var checkAddressCode = function checkAddressCode(addressCode) {
+ return provincesAndCities.includes(addressCode);
+ };
+
+ var checkBirthDayCode = function checkBirthDayCode(birDayCode) {
+ var yyyy = parseInt(birDayCode.substring(0, 4), 10);
+ var mm = parseInt(birDayCode.substring(4, 6), 10);
+ var dd = parseInt(birDayCode.substring(6), 10);
+ var xdata = new Date(yyyy, mm - 1, dd);
+
+ if (xdata > new Date()) {
+ return false; // eslint-disable-next-line max-len
+ } else if (xdata.getFullYear() === yyyy && xdata.getMonth() === mm - 1 && xdata.getDate() === dd) {
+ return true;
+ }
+
+ return false;
+ };
+
+ var getParityBit = function getParityBit(idCardNo) {
+ var id17 = idCardNo.substring(0, 17);
+ var power = 0;
+
+ for (var i = 0; i < 17; i++) {
+ power += parseInt(id17.charAt(i), 10) * parseInt(powers[i], 10);
+ }
+
+ var mod = power % 11;
+ return parityBit[mod];
+ };
+
+ var checkParityBit = function checkParityBit(idCardNo) {
+ return getParityBit(idCardNo) === idCardNo.charAt(17).toUpperCase();
+ };
+
+ var check15IdCardNo = function check15IdCardNo(idCardNo) {
+ var check = /^[1-9]\d{7}((0[1-9])|(1[0-2]))((0[1-9])|([1-2][0-9])|(3[0-1]))\d{3}$/.test(idCardNo);
+ if (!check) return false;
+ var addressCode = idCardNo.substring(0, 2);
+ check = checkAddressCode(addressCode);
+ if (!check) return false;
+ var birDayCode = "19".concat(idCardNo.substring(6, 12));
+ check = checkBirthDayCode(birDayCode);
+ if (!check) return false;
+ return true;
+ };
+
+ var check18IdCardNo = function check18IdCardNo(idCardNo) {
+ var check = /^[1-9]\d{5}[1-9]\d{3}((0[1-9])|(1[0-2]))((0[1-9])|([1-2][0-9])|(3[0-1]))\d{3}(\d|x|X)$/.test(idCardNo);
+ if (!check) return false;
+ var addressCode = idCardNo.substring(0, 2);
+ check = checkAddressCode(addressCode);
+ if (!check) return false;
+ var birDayCode = idCardNo.substring(6, 14);
+ check = checkBirthDayCode(birDayCode);
+ if (!check) return false;
+ return checkParityBit(idCardNo);
+ };
+
+ var checkIdCardNo = function checkIdCardNo(idCardNo) {
+ var check = /^\d{15}|(\d{17}(\d|x|X))$/.test(idCardNo);
+ if (!check) return false;
+
+ if (idCardNo.length === 15) {
+ return check15IdCardNo(idCardNo);
+ }
+
+ return check18IdCardNo(idCardNo);
+ };
+
+ return checkIdCardNo(str);
+ },
+ 'zh-HK': function zhHK(str) {
+ // sanitize user input
+ str = str.trim(); // HKID number starts with 1 or 2 letters, followed by 6 digits,
+ // then a checksum contained in square / round brackets or nothing
+
+ var regexHKID = /^[A-Z]{1,2}[0-9]{6}((\([0-9A]\))|(\[[0-9A]\])|([0-9A]))$/;
+ var regexIsDigit = /^[0-9]$/; // convert the user input to all uppercase and apply regex
+
+ str = str.toUpperCase();
+ if (!regexHKID.test(str)) return false;
+ str = str.replace(/\[|\]|\(|\)/g, '');
+ if (str.length === 8) str = "3".concat(str);
+ var checkSumVal = 0;
+
+ for (var i = 0; i <= 7; i++) {
+ var convertedChar = void 0;
+ if (!regexIsDigit.test(str[i])) convertedChar = (str[i].charCodeAt(0) - 55) % 11;else convertedChar = str[i];
+ checkSumVal += convertedChar * (9 - i);
+ }
+
+ checkSumVal %= 11;
+ var checkSumConverted;
+ if (checkSumVal === 0) checkSumConverted = '0';else if (checkSumVal === 1) checkSumConverted = 'A';else checkSumConverted = String(11 - checkSumVal);
+ if (checkSumConverted === str[str.length - 1]) return true;
+ return false;
+ },
+ 'zh-TW': function zhTW(str) {
+ var ALPHABET_CODES = {
+ A: 10,
+ B: 11,
+ C: 12,
+ D: 13,
+ E: 14,
+ F: 15,
+ G: 16,
+ H: 17,
+ I: 34,
+ J: 18,
+ K: 19,
+ L: 20,
+ M: 21,
+ N: 22,
+ O: 35,
+ P: 23,
+ Q: 24,
+ R: 25,
+ S: 26,
+ T: 27,
+ U: 28,
+ V: 29,
+ W: 32,
+ X: 30,
+ Y: 31,
+ Z: 33
+ };
+ var sanitized = str.trim().toUpperCase();
+ if (!/^[A-Z][0-9]{9}$/.test(sanitized)) return false;
+ return Array.from(sanitized).reduce(function (sum, number, index) {
+ if (index === 0) {
+ var code = ALPHABET_CODES[number];
+ return code % 10 * 9 + Math.floor(code / 10);
+ }
+
+ if (index === 9) {
+ return (10 - sum % 10 - Number(number)) % 10 === 0;
+ }
+
+ return sum + Number(number) * (9 - index);
+ }, 0);
+ }
+};
+
+function isIdentityCard(str, locale) {
+ (0, _assertString.default)(str);
+
+ if (locale in validators) {
+ return validators[locale](str);
+ } else if (locale === 'any') {
+ for (var key in validators) {
+ // https://github.com/gotwarlost/istanbul/blob/master/ignoring-code-for-coverage.md#ignoring-code-for-coverage-purposes
+ // istanbul ignore else
+ if (validators.hasOwnProperty(key)) {
+ var validator = validators[key];
+
+ if (validator(str)) {
+ return true;
+ }
+ }
+ }
+
+ return false;
+ }
+
+ throw new Error("Invalid locale '".concat(locale, "'"));
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isIn.js b/includes/external/addressbook/node_modules/validator/lib/isIn.js
new file mode 100644
index 0000000..62c5a4d
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isIn.js
@@ -0,0 +1,42 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isIn;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var _toString = _interopRequireDefault(require("./util/toString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
+
+function isIn(str, options) {
+ (0, _assertString.default)(str);
+ var i;
+
+ if (Object.prototype.toString.call(options) === '[object Array]') {
+ var array = [];
+
+ for (i in options) {
+ // https://github.com/gotwarlost/istanbul/blob/master/ignoring-code-for-coverage.md#ignoring-code-for-coverage-purposes
+ // istanbul ignore else
+ if ({}.hasOwnProperty.call(options, i)) {
+ array[i] = (0, _toString.default)(options[i]);
+ }
+ }
+
+ return array.indexOf(str) >= 0;
+ } else if (_typeof(options) === 'object') {
+ return options.hasOwnProperty(str);
+ } else if (options && typeof options.indexOf === 'function') {
+ return options.indexOf(str) >= 0;
+ }
+
+ return false;
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isInt.js b/includes/external/addressbook/node_modules/validator/lib/isInt.js
new file mode 100644
index 0000000..40f776c
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isInt.js
@@ -0,0 +1,30 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isInt;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var int = /^(?:[-+]?(?:0|[1-9][0-9]*))$/;
+var intLeadingZeroes = /^[-+]?[0-9]+$/;
+
+function isInt(str, options) {
+ (0, _assertString.default)(str);
+ options = options || {}; // Get the regex to use for testing, based on whether
+ // leading zeroes are allowed or not.
+
+ var regex = options.hasOwnProperty('allow_leading_zeroes') && !options.allow_leading_zeroes ? int : intLeadingZeroes; // Check min/max/lt/gt
+
+ var minCheckPassed = !options.hasOwnProperty('min') || str >= options.min;
+ var maxCheckPassed = !options.hasOwnProperty('max') || str <= options.max;
+ var ltCheckPassed = !options.hasOwnProperty('lt') || str < options.lt;
+ var gtCheckPassed = !options.hasOwnProperty('gt') || str > options.gt;
+ return regex.test(str) && minCheckPassed && maxCheckPassed && ltCheckPassed && gtCheckPassed;
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isJSON.js b/includes/external/addressbook/node_modules/validator/lib/isJSON.js
new file mode 100644
index 0000000..78c09ef
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isJSON.js
@@ -0,0 +1,41 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isJSON;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var _merge = _interopRequireDefault(require("./util/merge"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
+
+var default_json_options = {
+ allow_primitives: false
+};
+
+function isJSON(str, options) {
+ (0, _assertString.default)(str);
+
+ try {
+ options = (0, _merge.default)(options, default_json_options);
+ var primitives = [];
+
+ if (options.allow_primitives) {
+ primitives = [null, false, true];
+ }
+
+ var obj = JSON.parse(str);
+ return primitives.includes(obj) || !!obj && _typeof(obj) === 'object';
+ } catch (e) {
+ /* ignore */
+ }
+
+ return false;
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isJWT.js b/includes/external/addressbook/node_modules/validator/lib/isJWT.js
new file mode 100644
index 0000000..65d89fc
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isJWT.js
@@ -0,0 +1,31 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isJWT;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var _isBase = _interopRequireDefault(require("./isBase64"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function isJWT(str) {
+ (0, _assertString.default)(str);
+ var dotSplit = str.split('.');
+ var len = dotSplit.length;
+
+ if (len > 3 || len < 2) {
+ return false;
+ }
+
+ return dotSplit.reduce(function (acc, currElem) {
+ return acc && (0, _isBase.default)(currElem, {
+ urlSafe: true
+ });
+ }, true);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isLatLong.js b/includes/external/addressbook/node_modules/validator/lib/isLatLong.js
new file mode 100644
index 0000000..e288812
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isLatLong.js
@@ -0,0 +1,37 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isLatLong;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var _merge = _interopRequireDefault(require("./util/merge"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var lat = /^\(?[+-]?(90(\.0+)?|[1-8]?\d(\.\d+)?)$/;
+var long = /^\s?[+-]?(180(\.0+)?|1[0-7]\d(\.\d+)?|\d{1,2}(\.\d+)?)\)?$/;
+var latDMS = /^(([1-8]?\d)\D+([1-5]?\d|60)\D+([1-5]?\d|60)(\.\d+)?|90\D+0\D+0)\D+[NSns]?$/i;
+var longDMS = /^\s*([1-7]?\d{1,2}\D+([1-5]?\d|60)\D+([1-5]?\d|60)(\.\d+)?|180\D+0\D+0)\D+[EWew]?$/i;
+var defaultLatLongOptions = {
+ checkDMS: false
+};
+
+function isLatLong(str, options) {
+ (0, _assertString.default)(str);
+ options = (0, _merge.default)(options, defaultLatLongOptions);
+ if (!str.includes(',')) return false;
+ var pair = str.split(',');
+ if (pair[0].startsWith('(') && !pair[1].endsWith(')') || pair[1].endsWith(')') && !pair[0].startsWith('(')) return false;
+
+ if (options.checkDMS) {
+ return latDMS.test(pair[0]) && longDMS.test(pair[1]);
+ }
+
+ return lat.test(pair[0]) && long.test(pair[1]);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isLength.js b/includes/external/addressbook/node_modules/validator/lib/isLength.js
new file mode 100644
index 0000000..f93b269
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isLength.js
@@ -0,0 +1,36 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isLength;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
+
+/* eslint-disable prefer-rest-params */
+function isLength(str, options) {
+ (0, _assertString.default)(str);
+ var min;
+ var max;
+
+ if (_typeof(options) === 'object') {
+ min = options.min || 0;
+ max = options.max;
+ } else {
+ // backwards compatibility: isLength(str, min [, max])
+ min = arguments[1] || 0;
+ max = arguments[2];
+ }
+
+ var presentationSequences = str.match(/(\uFE0F|\uFE0E)/g) || [];
+ var surrogatePairs = str.match(/[\uD800-\uDBFF][\uDC00-\uDFFF]/g) || [];
+ var len = str.length - presentationSequences.length - surrogatePairs.length;
+ return len >= min && (typeof max === 'undefined' || len <= max);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isLicensePlate.js b/includes/external/addressbook/node_modules/validator/lib/isLicensePlate.js
new file mode 100644
index 0000000..28b2b91
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isLicensePlate.js
@@ -0,0 +1,70 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isLicensePlate;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var validators = {
+ 'cs-CZ': function csCZ(str) {
+ return /^(([ABCDEFHIJKLMNPRSTUVXYZ]|[0-9])-?){5,8}$/.test(str);
+ },
+ 'de-DE': function deDE(str) {
+ return /^((A|AA|AB|AC|AE|AH|AK|AM|AN|AÖ|AP|AS|AT|AU|AW|AZ|B|BA|BB|BC|BE|BF|BH|BI|BK|BL|BM|BN|BO|BÖ|BS|BT|BZ|C|CA|CB|CE|CO|CR|CW|D|DA|DD|DE|DH|DI|DL|DM|DN|DO|DU|DW|DZ|E|EA|EB|ED|EE|EF|EG|EH|EI|EL|EM|EN|ER|ES|EU|EW|F|FB|FD|FF|FG|FI|FL|FN|FO|FR|FS|FT|FÜ|FW|FZ|G|GA|GC|GD|GE|GF|GG|GI|GK|GL|GM|GN|GÖ|GP|GR|GS|GT|GÜ|GV|GW|GZ|H|HA|HB|HC|HD|HE|HF|HG|HH|HI|HK|HL|HM|HN|HO|HP|HR|HS|HU|HV|HX|HY|HZ|IK|IL|IN|IZ|J|JE|JL|K|KA|KB|KC|KE|KF|KG|KH|KI|KK|KL|KM|KN|KO|KR|KS|KT|KU|KW|KY|L|LA|LB|LC|LD|LF|LG|LH|LI|LL|LM|LN|LÖ|LP|LR|LU|M|MA|MB|MC|MD|ME|MG|MH|MI|MK|ML|MM|MN|MO|MQ|MR|MS|MÜ|MW|MY|MZ|N|NB|ND|NE|NF|NH|NI|NK|NM|NÖ|NP|NR|NT|NU|NW|NY|NZ|OA|OB|OC|OD|OE|OF|OG|OH|OK|OL|OP|OS|OZ|P|PA|PB|PE|PF|PI|PL|PM|PN|PR|PS|PW|PZ|R|RA|RC|RD|RE|RG|RH|RI|RL|RM|RN|RO|RP|RS|RT|RU|RV|RW|RZ|S|SB|SC|SE|SG|SI|SK|SL|SM|SN|SO|SP|SR|ST|SU|SW|SY|SZ|TE|TF|TG|TO|TP|TR|TS|TT|TÜ|ÜB|UE|UH|UL|UM|UN|V|VB|VG|VK|VR|VS|W|WA|WB|WE|WF|WI|WK|WL|WM|WN|WO|WR|WS|WT|WÜ|WW|WZ|Z|ZE|ZI|ZP|ZR|ZW|ZZ)[- ]?[A-Z]{1,2}[- ]?\d{1,4}|(ABG|ABI|AIB|AIC|ALF|ALZ|ANA|ANG|ANK|APD|ARN|ART|ASL|ASZ|AUR|AZE|BAD|BAR|BBG|BCH|BED|BER|BGD|BGL|BID|BIN|BIR|BIT|BIW|BKS|BLB|BLK|BNA|BOG|BOH|BOR|BOT|BRA|BRB|BRG|BRK|BRL|BRV|BSB|BSK|BTF|BÜD|BUL|BÜR|BÜS|BÜZ|CAS|CHA|CLP|CLZ|COC|COE|CUX|DAH|DAN|DAU|DBR|DEG|DEL|DGF|DIL|DIN|DIZ|DKB|DLG|DON|DUD|DÜW|EBE|EBN|EBS|ECK|EIC|EIL|EIN|EIS|EMD|EMS|ERB|ERH|ERK|ERZ|ESB|ESW|FDB|FDS|FEU|FFB|FKB|FLÖ|FOR|FRG|FRI|FRW|FTL|FÜS|GAN|GAP|GDB|GEL|GEO|GER|GHA|GHC|GLA|GMN|GNT|GOA|GOH|GRA|GRH|GRI|GRM|GRZ|GTH|GUB|GUN|GVM|HAB|HAL|HAM|HAS|HBN|HBS|HCH|HDH|HDL|HEB|HEF|HEI|HER|HET|HGN|HGW|HHM|HIG|HIP|HMÜ|HOG|HOH|HOL|HOM|HOR|HÖS|HOT|HRO|HSK|HST|HVL|HWI|IGB|ILL|JÜL|KEH|KEL|KEM|KIB|KLE|KLZ|KÖN|KÖT|KÖZ|KRU|KÜN|KUS|KYF|LAN|LAU|LBS|LBZ|LDK|LDS|LEO|LER|LEV|LIB|LIF|LIP|LÖB|LOS|LRO|LSZ|LÜN|LUP|LWL|MAB|MAI|MAK|MAL|MED|MEG|MEI|MEK|MEL|MER|MET|MGH|MGN|MHL|MIL|MKK|MOD|MOL|MON|MOS|MSE|MSH|MSP|MST|MTK|MTL|MÜB|MÜR|MYK|MZG|NAB|NAI|NAU|NDH|NEA|NEB|NEC|NEN|NES|NEW|NMB|NMS|NOH|NOL|NOM|NOR|NVP|NWM|OAL|OBB|OBG|OCH|OHA|ÖHR|OHV|OHZ|OPR|OSL|OVI|OVL|OVP|PAF|PAN|PAR|PCH|PEG|PIR|PLÖ|PRÜ|QFT|QLB|RDG|REG|REH|REI|RID|RIE|ROD|ROF|ROK|ROL|ROS|ROT|ROW|RSL|RÜD|RÜG|SAB|SAD|SAN|SAW|SBG|SBK|SCZ|SDH|SDL|SDT|SEB|SEE|SEF|SEL|SFB|SFT|SGH|SHA|SHG|SHK|SHL|SIG|SIM|SLE|SLF|SLK|SLN|SLS|SLÜ|SLZ|SMÜ|SOB|SOG|SOK|SÖM|SON|SPB|SPN|SRB|SRO|STA|STB|STD|STE|STL|SUL|SÜW|SWA|SZB|TBB|TDO|TET|TIR|TÖL|TUT|UEM|UER|UFF|USI|VAI|VEC|VER|VIB|VIE|VIT|VOH|WAF|WAK|WAN|WAR|WAT|WBS|WDA|WEL|WEN|WER|WES|WHV|WIL|WIS|WIT|WIZ|WLG|WMS|WND|WOB|WOH|WOL|WOR|WOS|WRN|WSF|WST|WSW|WTL|WTM|WUG|WÜM|WUN|WUR|WZL|ZEL|ZIG)[- ]?(([A-Z][- ]?\d{1,4})|([A-Z]{2}[- ]?\d{1,3})))[- ]?(E|H)?$/.test(str);
+ },
+ 'de-LI': function deLI(str) {
+ return /^FL[- ]?\d{1,5}[UZ]?$/.test(str);
+ },
+ 'en-IN': function enIN(str) {
+ return /^[A-Z]{2}[ -]?[0-9]{1,2}(?:[ -]?[A-Z])(?:[ -]?[A-Z]*)?[ -]?[0-9]{4}$/.test(str);
+ },
+ 'es-AR': function esAR(str) {
+ return /^(([A-Z]{2} ?[0-9]{3} ?[A-Z]{2})|([A-Z]{3} ?[0-9]{3}))$/.test(str);
+ },
+ 'fi-FI': function fiFI(str) {
+ return /^(?=.{4,7})(([A-Z]{1,3}|[0-9]{1,3})[\s-]?([A-Z]{1,3}|[0-9]{1,5}))$/.test(str);
+ },
+ 'hu-HU': function huHU(str) {
+ return /^((((?!AAA)(([A-NPRSTVZWXY]{1})([A-PR-Z]{1})([A-HJ-NPR-Z]))|(A[ABC]I)|A[ABC]O|A[A-W]Q|BPI|BPO|UCO|UDO|XAO)-(?!000)\d{3})|(M\d{6})|((CK|DT|CD|HC|H[ABEFIKLMNPRSTVX]|MA|OT|R[A-Z]) \d{2}-\d{2})|(CD \d{3}-\d{3})|(C-(C|X) \d{4})|(X-(A|B|C) \d{4})|(([EPVZ]-\d{5}))|(S A[A-Z]{2} \d{2})|(SP \d{2}-\d{2}))$/.test(str);
+ },
+ 'pt-BR': function ptBR(str) {
+ return /^[A-Z]{3}[ -]?[0-9][A-Z][0-9]{2}|[A-Z]{3}[ -]?[0-9]{4}$/.test(str);
+ },
+ 'pt-PT': function ptPT(str) {
+ return /^([A-Z]{2}|[0-9]{2})[ -·]?([A-Z]{2}|[0-9]{2})[ -·]?([A-Z]{2}|[0-9]{2})$/.test(str);
+ },
+ 'sq-AL': function sqAL(str) {
+ return /^[A-Z]{2}[- ]?((\d{3}[- ]?(([A-Z]{2})|T))|(R[- ]?\d{3}))$/.test(str);
+ },
+ 'sv-SE': function svSE(str) {
+ return /^[A-HJ-PR-UW-Z]{3} ?[\d]{2}[A-HJ-PR-UW-Z1-9]$|(^[A-ZÅÄÖ ]{2,7}$)/.test(str.trim());
+ }
+};
+
+function isLicensePlate(str, locale) {
+ (0, _assertString.default)(str);
+
+ if (locale in validators) {
+ return validators[locale](str);
+ } else if (locale === 'any') {
+ for (var key in validators) {
+ /* eslint guard-for-in: 0 */
+ var validator = validators[key];
+
+ if (validator(str)) {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ throw new Error("Invalid locale '".concat(locale, "'"));
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isLocale.js b/includes/external/addressbook/node_modules/validator/lib/isLocale.js
new file mode 100644
index 0000000..1a4f609
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isLocale.js
@@ -0,0 +1,25 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isLocale;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var localeReg = /^[A-Za-z]{2,4}([_-]([A-Za-z]{4}|[\d]{3}))?([_-]([A-Za-z]{2}|[\d]{3}))?$/;
+
+function isLocale(str) {
+ (0, _assertString.default)(str);
+
+ if (str === 'en_US_POSIX' || str === 'ca_ES_VALENCIA') {
+ return true;
+ }
+
+ return localeReg.test(str);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isLowercase.js b/includes/external/addressbook/node_modules/validator/lib/isLowercase.js
new file mode 100644
index 0000000..7f412d9
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isLowercase.js
@@ -0,0 +1,18 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isLowercase;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function isLowercase(str) {
+ (0, _assertString.default)(str);
+ return str === str.toLowerCase();
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isLuhnNumber.js b/includes/external/addressbook/node_modules/validator/lib/isLuhnNumber.js
new file mode 100644
index 0000000..8733f10
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isLuhnNumber.js
@@ -0,0 +1,43 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isLuhnNumber;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function isLuhnNumber(str) {
+ (0, _assertString.default)(str);
+ var sanitized = str.replace(/[- ]+/g, '');
+ var sum = 0;
+ var digit;
+ var tmpNum;
+ var shouldDouble;
+
+ for (var i = sanitized.length - 1; i >= 0; i--) {
+ digit = sanitized.substring(i, i + 1);
+ tmpNum = parseInt(digit, 10);
+
+ if (shouldDouble) {
+ tmpNum *= 2;
+
+ if (tmpNum >= 10) {
+ sum += tmpNum % 10 + 1;
+ } else {
+ sum += tmpNum;
+ }
+ } else {
+ sum += tmpNum;
+ }
+
+ shouldDouble = !shouldDouble;
+ }
+
+ return !!(sum % 10 === 0 ? sanitized : false);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isLuhnValid.js b/includes/external/addressbook/node_modules/validator/lib/isLuhnValid.js
new file mode 100644
index 0000000..27f6041
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isLuhnValid.js
@@ -0,0 +1,43 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isLuhnValid;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function isLuhnValid(str) {
+ (0, _assertString.default)(str);
+ var sanitized = str.replace(/[- ]+/g, '');
+ var sum = 0;
+ var digit;
+ var tmpNum;
+ var shouldDouble;
+
+ for (var i = sanitized.length - 1; i >= 0; i--) {
+ digit = sanitized.substring(i, i + 1);
+ tmpNum = parseInt(digit, 10);
+
+ if (shouldDouble) {
+ tmpNum *= 2;
+
+ if (tmpNum >= 10) {
+ sum += tmpNum % 10 + 1;
+ } else {
+ sum += tmpNum;
+ }
+ } else {
+ sum += tmpNum;
+ }
+
+ shouldDouble = !shouldDouble;
+ }
+
+ return !!(sum % 10 === 0 ? sanitized : false);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isMACAddress.js b/includes/external/addressbook/node_modules/validator/lib/isMACAddress.js
new file mode 100644
index 0000000..470f6c0
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isMACAddress.js
@@ -0,0 +1,58 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isMACAddress;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var macAddress48 = /^(?:[0-9a-fA-F]{2}([-:\s]))([0-9a-fA-F]{2}\1){4}([0-9a-fA-F]{2})$/;
+var macAddress48NoSeparators = /^([0-9a-fA-F]){12}$/;
+var macAddress48WithDots = /^([0-9a-fA-F]{4}\.){2}([0-9a-fA-F]{4})$/;
+var macAddress64 = /^(?:[0-9a-fA-F]{2}([-:\s]))([0-9a-fA-F]{2}\1){6}([0-9a-fA-F]{2})$/;
+var macAddress64NoSeparators = /^([0-9a-fA-F]){16}$/;
+var macAddress64WithDots = /^([0-9a-fA-F]{4}\.){3}([0-9a-fA-F]{4})$/;
+
+function isMACAddress(str, options) {
+ (0, _assertString.default)(str);
+
+ if (options !== null && options !== void 0 && options.eui) {
+ options.eui = String(options.eui);
+ }
+ /**
+ * @deprecated `no_colons` TODO: remove it in the next major
+ */
+
+
+ if (options !== null && options !== void 0 && options.no_colons || options !== null && options !== void 0 && options.no_separators) {
+ if (options.eui === '48') {
+ return macAddress48NoSeparators.test(str);
+ }
+
+ if (options.eui === '64') {
+ return macAddress64NoSeparators.test(str);
+ }
+
+ return macAddress48NoSeparators.test(str) || macAddress64NoSeparators.test(str);
+ }
+
+ if ((options === null || options === void 0 ? void 0 : options.eui) === '48') {
+ return macAddress48.test(str) || macAddress48WithDots.test(str);
+ }
+
+ if ((options === null || options === void 0 ? void 0 : options.eui) === '64') {
+ return macAddress64.test(str) || macAddress64WithDots.test(str);
+ }
+
+ return isMACAddress(str, {
+ eui: '48'
+ }) || isMACAddress(str, {
+ eui: '64'
+ });
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isMD5.js b/includes/external/addressbook/node_modules/validator/lib/isMD5.js
new file mode 100644
index 0000000..57f2b0e
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isMD5.js
@@ -0,0 +1,20 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isMD5;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var md5 = /^[a-f0-9]{32}$/;
+
+function isMD5(str) {
+ (0, _assertString.default)(str);
+ return md5.test(str);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isMagnetURI.js b/includes/external/addressbook/node_modules/validator/lib/isMagnetURI.js
new file mode 100644
index 0000000..decf661
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isMagnetURI.js
@@ -0,0 +1,25 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isMagnetURI;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var magnetURIComponent = /(?:^magnet:\?|[^?&]&)xt(?:\.1)?=urn:(?:(?:aich|bitprint|btih|ed2k|ed2khash|kzhash|md5|sha1|tree:tiger):[a-z0-9]{32}(?:[a-z0-9]{8})?|btmh:1220[a-z0-9]{64})(?:$|&)/i;
+
+function isMagnetURI(url) {
+ (0, _assertString.default)(url);
+
+ if (url.indexOf('magnet:?') !== 0) {
+ return false;
+ }
+
+ return magnetURIComponent.test(url);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isMimeType.js b/includes/external/addressbook/node_modules/validator/lib/isMimeType.js
new file mode 100644
index 0000000..b0daddf
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isMimeType.js
@@ -0,0 +1,51 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isMimeType;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/*
+ Checks if the provided string matches to a correct Media type format (MIME type)
+
+ This function only checks is the string format follows the
+ etablished rules by the according RFC specifications.
+ This function supports 'charset' in textual media types
+ (https://tools.ietf.org/html/rfc6657).
+
+ This function does not check against all the media types listed
+ by the IANA (https://www.iana.org/assignments/media-types/media-types.xhtml)
+ because of lightness purposes : it would require to include
+ all these MIME types in this librairy, which would weigh it
+ significantly. This kind of effort maybe is not worth for the use that
+ this function has in this entire librairy.
+
+ More informations in the RFC specifications :
+ - https://tools.ietf.org/html/rfc2045
+ - https://tools.ietf.org/html/rfc2046
+ - https://tools.ietf.org/html/rfc7231#section-3.1.1.1
+ - https://tools.ietf.org/html/rfc7231#section-3.1.1.5
+*/
+// Match simple MIME types
+// NB :
+// Subtype length must not exceed 100 characters.
+// This rule does not comply to the RFC specs (what is the max length ?).
+var mimeTypeSimple = /^(application|audio|font|image|message|model|multipart|text|video)\/[a-zA-Z0-9\.\-\+_]{1,100}$/i; // eslint-disable-line max-len
+// Handle "charset" in "text/*"
+
+var mimeTypeText = /^text\/[a-zA-Z0-9\.\-\+]{1,100};\s?charset=("[a-zA-Z0-9\.\-\+\s]{0,70}"|[a-zA-Z0-9\.\-\+]{0,70})(\s?\([a-zA-Z0-9\.\-\+\s]{1,20}\))?$/i; // eslint-disable-line max-len
+// Handle "boundary" in "multipart/*"
+
+var mimeTypeMultipart = /^multipart\/[a-zA-Z0-9\.\-\+]{1,100}(;\s?(boundary|charset)=("[a-zA-Z0-9\.\-\+\s]{0,70}"|[a-zA-Z0-9\.\-\+]{0,70})(\s?\([a-zA-Z0-9\.\-\+\s]{1,20}\))?){0,2}$/i; // eslint-disable-line max-len
+
+function isMimeType(str) {
+ (0, _assertString.default)(str);
+ return mimeTypeSimple.test(str) || mimeTypeText.test(str) || mimeTypeMultipart.test(str);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isMobilePhone.js b/includes/external/addressbook/node_modules/validator/lib/isMobilePhone.js
new file mode 100644
index 0000000..79c60d3
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isMobilePhone.js
@@ -0,0 +1,222 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isMobilePhone;
+exports.locales = void 0;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/* eslint-disable max-len */
+var phones = {
+ 'am-AM': /^(\+?374|0)((10|[9|7][0-9])\d{6}$|[2-4]\d{7}$)/,
+ 'ar-AE': /^((\+?971)|0)?5[024568]\d{7}$/,
+ 'ar-BH': /^(\+?973)?(3|6)\d{7}$/,
+ 'ar-DZ': /^(\+?213|0)(5|6|7)\d{8}$/,
+ 'ar-LB': /^(\+?961)?((3|81)\d{6}|7\d{7})$/,
+ 'ar-EG': /^((\+?20)|0)?1[0125]\d{8}$/,
+ 'ar-IQ': /^(\+?964|0)?7[0-9]\d{8}$/,
+ 'ar-JO': /^(\+?962|0)?7[789]\d{7}$/,
+ 'ar-KW': /^(\+?965)([569]\d{7}|41\d{6})$/,
+ 'ar-LY': /^((\+?218)|0)?(9[1-6]\d{7}|[1-8]\d{7,9})$/,
+ 'ar-MA': /^(?:(?:\+|00)212|0)[5-7]\d{8}$/,
+ 'ar-OM': /^((\+|00)968)?(9[1-9])\d{6}$/,
+ 'ar-PS': /^(\+?970|0)5[6|9](\d{7})$/,
+ 'ar-SA': /^(!?(\+?966)|0)?5\d{8}$/,
+ 'ar-SY': /^(!?(\+?963)|0)?9\d{8}$/,
+ 'ar-TN': /^(\+?216)?[2459]\d{7}$/,
+ 'az-AZ': /^(\+994|0)(10|5[015]|7[07]|99)\d{7}$/,
+ 'bs-BA': /^((((\+|00)3876)|06))((([0-3]|[5-6])\d{6})|(4\d{7}))$/,
+ 'be-BY': /^(\+?375)?(24|25|29|33|44)\d{7}$/,
+ 'bg-BG': /^(\+?359|0)?8[789]\d{7}$/,
+ 'bn-BD': /^(\+?880|0)1[13456789][0-9]{8}$/,
+ 'ca-AD': /^(\+376)?[346]\d{5}$/,
+ 'cs-CZ': /^(\+?420)? ?[1-9][0-9]{2} ?[0-9]{3} ?[0-9]{3}$/,
+ 'da-DK': /^(\+?45)?\s?\d{2}\s?\d{2}\s?\d{2}\s?\d{2}$/,
+ 'de-DE': /^((\+49|0)1)(5[0-25-9]\d|6([23]|0\d?)|7([0-57-9]|6\d))\d{7,9}$/,
+ 'de-AT': /^(\+43|0)\d{1,4}\d{3,12}$/,
+ 'de-CH': /^(\+41|0)([1-9])\d{1,9}$/,
+ 'de-LU': /^(\+352)?((6\d1)\d{6})$/,
+ 'dv-MV': /^(\+?960)?(7[2-9]|9[1-9])\d{5}$/,
+ 'el-GR': /^(\+?30|0)?6(8[5-9]|9(?![26])[0-9])\d{7}$/,
+ 'el-CY': /^(\+?357?)?(9(9|6)\d{6})$/,
+ 'en-AI': /^(\+?1|0)264(?:2(35|92)|4(?:6[1-2]|76|97)|5(?:3[6-9]|8[1-4])|7(?:2(4|9)|72))\d{4}$/,
+ 'en-AU': /^(\+?61|0)4\d{8}$/,
+ 'en-AG': /^(?:\+1|1)268(?:464|7(?:1[3-9]|[28]\d|3[0246]|64|7[0-689]))\d{4}$/,
+ 'en-BM': /^(\+?1)?441(((3|7)\d{6}$)|(5[0-3][0-9]\d{4}$)|(59\d{5}$))/,
+ 'en-BS': /^(\+?1[-\s]?|0)?\(?242\)?[-\s]?\d{3}[-\s]?\d{4}$/,
+ 'en-GB': /^(\+?44|0)7\d{9}$/,
+ 'en-GG': /^(\+?44|0)1481\d{6}$/,
+ 'en-GH': /^(\+233|0)(20|50|24|54|27|57|26|56|23|28|55|59)\d{7}$/,
+ 'en-GY': /^(\+592|0)6\d{6}$/,
+ 'en-HK': /^(\+?852[-\s]?)?[456789]\d{3}[-\s]?\d{4}$/,
+ 'en-MO': /^(\+?853[-\s]?)?[6]\d{3}[-\s]?\d{4}$/,
+ 'en-IE': /^(\+?353|0)8[356789]\d{7}$/,
+ 'en-IN': /^(\+?91|0)?[6789]\d{9}$/,
+ 'en-JM': /^(\+?876)?\d{7}$/,
+ 'en-KE': /^(\+?254|0)(7|1)\d{8}$/,
+ 'en-SS': /^(\+?211|0)(9[1257])\d{7}$/,
+ 'en-KI': /^((\+686|686)?)?( )?((6|7)(2|3|8)[0-9]{6})$/,
+ 'en-KN': /^(?:\+1|1)869(?:46\d|48[89]|55[6-8]|66\d|76[02-7])\d{4}$/,
+ 'en-LS': /^(\+?266)(22|28|57|58|59|27|52)\d{6}$/,
+ 'en-MT': /^(\+?356|0)?(99|79|77|21|27|22|25)[0-9]{6}$/,
+ 'en-MU': /^(\+?230|0)?\d{8}$/,
+ 'en-NA': /^(\+?264|0)(6|8)\d{7}$/,
+ 'en-NG': /^(\+?234|0)?[789]\d{9}$/,
+ 'en-NZ': /^(\+?64|0)[28]\d{7,9}$/,
+ 'en-PG': /^(\+?675|0)?(7\d|8[18])\d{6}$/,
+ 'en-PK': /^((00|\+)?92|0)3[0-6]\d{8}$/,
+ 'en-PH': /^(09|\+639)\d{9}$/,
+ 'en-RW': /^(\+?250|0)?[7]\d{8}$/,
+ 'en-SG': /^(\+65)?[3689]\d{7}$/,
+ 'en-SL': /^(\+?232|0)\d{8}$/,
+ 'en-TZ': /^(\+?255|0)?[67]\d{8}$/,
+ 'en-UG': /^(\+?256|0)?[7]\d{8}$/,
+ 'en-US': /^((\+1|1)?( |-)?)?(\([2-9][0-9]{2}\)|[2-9][0-9]{2})( |-)?([2-9][0-9]{2}( |-)?[0-9]{4})$/,
+ 'en-ZA': /^(\+?27|0)\d{9}$/,
+ 'en-ZM': /^(\+?26)?09[567]\d{7}$/,
+ 'en-ZW': /^(\+263)[0-9]{9}$/,
+ 'en-BW': /^(\+?267)?(7[1-8]{1})\d{6}$/,
+ 'es-AR': /^\+?549(11|[2368]\d)\d{8}$/,
+ 'es-BO': /^(\+?591)?(6|7)\d{7}$/,
+ 'es-CO': /^(\+?57)?3(0(0|1|2|4|5)|1\d|2[0-4]|5(0|1))\d{7}$/,
+ 'es-CL': /^(\+?56|0)[2-9]\d{1}\d{7}$/,
+ 'es-CR': /^(\+506)?[2-8]\d{7}$/,
+ 'es-CU': /^(\+53|0053)?5\d{7}/,
+ 'es-DO': /^(\+?1)?8[024]9\d{7}$/,
+ 'es-HN': /^(\+?504)?[9|8|3|2]\d{7}$/,
+ 'es-EC': /^(\+?593|0)([2-7]|9[2-9])\d{7}$/,
+ 'es-ES': /^(\+?34)?[6|7]\d{8}$/,
+ 'es-PE': /^(\+?51)?9\d{8}$/,
+ 'es-MX': /^(\+?52)?(1|01)?\d{10,11}$/,
+ 'es-NI': /^(\+?505)\d{7,8}$/,
+ 'es-PA': /^(\+?507)\d{7,8}$/,
+ 'es-PY': /^(\+?595|0)9[9876]\d{7}$/,
+ 'es-SV': /^(\+?503)?[67]\d{7}$/,
+ 'es-UY': /^(\+598|0)9[1-9][\d]{6}$/,
+ 'es-VE': /^(\+?58)?(2|4)\d{9}$/,
+ 'et-EE': /^(\+?372)?\s?(5|8[1-4])\s?([0-9]\s?){6,7}$/,
+ 'fa-IR': /^(\+?98[\-\s]?|0)9[0-39]\d[\-\s]?\d{3}[\-\s]?\d{4}$/,
+ 'fi-FI': /^(\+?358|0)\s?(4[0-6]|50)\s?(\d\s?){4,8}$/,
+ 'fj-FJ': /^(\+?679)?\s?\d{3}\s?\d{4}$/,
+ 'fo-FO': /^(\+?298)?\s?\d{2}\s?\d{2}\s?\d{2}$/,
+ 'fr-BF': /^(\+226|0)[67]\d{7}$/,
+ 'fr-BJ': /^(\+229)\d{8}$/,
+ 'fr-CD': /^(\+?243|0)?(8|9)\d{8}$/,
+ 'fr-CM': /^(\+?237)6[0-9]{8}$/,
+ 'fr-FR': /^(\+?33|0)[67]\d{8}$/,
+ 'fr-GF': /^(\+?594|0|00594)[67]\d{8}$/,
+ 'fr-GP': /^(\+?590|0|00590)[67]\d{8}$/,
+ 'fr-MQ': /^(\+?596|0|00596)[67]\d{8}$/,
+ 'fr-PF': /^(\+?689)?8[789]\d{6}$/,
+ 'fr-RE': /^(\+?262|0|00262)[67]\d{8}$/,
+ 'he-IL': /^(\+972|0)([23489]|5[012345689]|77)[1-9]\d{6}$/,
+ 'hu-HU': /^(\+?36|06)(20|30|31|50|70)\d{7}$/,
+ 'id-ID': /^(\+?62|0)8(1[123456789]|2[1238]|3[1238]|5[12356789]|7[78]|9[56789]|8[123456789])([\s?|\d]{5,11})$/,
+ 'ir-IR': /^(\+98|0)?9\d{9}$/,
+ 'it-IT': /^(\+?39)?\s?3\d{2} ?\d{6,7}$/,
+ 'it-SM': /^((\+378)|(0549)|(\+390549)|(\+3780549))?6\d{5,9}$/,
+ 'ja-JP': /^(\+81[ \-]?(\(0\))?|0)[6789]0[ \-]?\d{4}[ \-]?\d{4}$/,
+ 'ka-GE': /^(\+?995)?(79\d{7}|5\d{8})$/,
+ 'kk-KZ': /^(\+?7|8)?7\d{9}$/,
+ 'kl-GL': /^(\+?299)?\s?\d{2}\s?\d{2}\s?\d{2}$/,
+ 'ko-KR': /^((\+?82)[ \-]?)?0?1([0|1|6|7|8|9]{1})[ \-]?\d{3,4}[ \-]?\d{4}$/,
+ 'ky-KG': /^(\+?7\s?\+?7|0)\s?\d{2}\s?\d{3}\s?\d{4}$/,
+ 'lt-LT': /^(\+370|8)\d{8}$/,
+ 'lv-LV': /^(\+?371)2\d{7}$/,
+ 'mg-MG': /^((\+?261|0)(2|3)\d)?\d{7}$/,
+ 'mn-MN': /^(\+|00|011)?976(77|81|88|91|94|95|96|99)\d{6}$/,
+ 'my-MM': /^(\+?959|09|9)(2[5-7]|3[1-2]|4[0-5]|6[6-9]|7[5-9]|9[6-9])[0-9]{7}$/,
+ 'ms-MY': /^(\+?60|0)1(([0145](-|\s)?\d{7,8})|([236-9](-|\s)?\d{7}))$/,
+ 'mz-MZ': /^(\+?258)?8[234567]\d{7}$/,
+ 'nb-NO': /^(\+?47)?[49]\d{7}$/,
+ 'ne-NP': /^(\+?977)?9[78]\d{8}$/,
+ 'nl-BE': /^(\+?32|0)4\d{8}$/,
+ 'nl-NL': /^(((\+|00)?31\(0\))|((\+|00)?31)|0)6{1}\d{8}$/,
+ 'nl-AW': /^(\+)?297(56|59|64|73|74|99)\d{5}$/,
+ 'nn-NO': /^(\+?47)?[49]\d{7}$/,
+ 'pl-PL': /^(\+?48)? ?[5-8]\d ?\d{3} ?\d{2} ?\d{2}$/,
+ 'pt-BR': /^((\+?55\ ?[1-9]{2}\ ?)|(\+?55\ ?\([1-9]{2}\)\ ?)|(0[1-9]{2}\ ?)|(\([1-9]{2}\)\ ?)|([1-9]{2}\ ?))((\d{4}\-?\d{4})|(9[1-9]{1}\d{3}\-?\d{4}))$/,
+ 'pt-PT': /^(\+?351)?9[1236]\d{7}$/,
+ 'pt-AO': /^(\+244)\d{9}$/,
+ 'ro-MD': /^(\+?373|0)((6(0|1|2|6|7|8|9))|(7(6|7|8|9)))\d{6}$/,
+ 'ro-RO': /^(\+?40|0)\s?7\d{2}(\/|\s|\.|-)?\d{3}(\s|\.|-)?\d{3}$/,
+ 'ru-RU': /^(\+?7|8)?9\d{9}$/,
+ 'si-LK': /^(?:0|94|\+94)?(7(0|1|2|4|5|6|7|8)( |-)?)\d{7}$/,
+ 'sl-SI': /^(\+386\s?|0)(\d{1}\s?\d{3}\s?\d{2}\s?\d{2}|\d{2}\s?\d{3}\s?\d{3})$/,
+ 'sk-SK': /^(\+?421)? ?[1-9][0-9]{2} ?[0-9]{3} ?[0-9]{3}$/,
+ 'sq-AL': /^(\+355|0)6[789]\d{6}$/,
+ 'sr-RS': /^(\+3816|06)[- \d]{5,9}$/,
+ 'sv-SE': /^(\+?46|0)[\s\-]?7[\s\-]?[02369]([\s\-]?\d){7}$/,
+ 'tg-TJ': /^(\+?992)?[5][5]\d{7}$/,
+ 'th-TH': /^(\+66|66|0)\d{9}$/,
+ 'tr-TR': /^(\+?90|0)?5\d{9}$/,
+ 'tk-TM': /^(\+993|993|8)\d{8}$/,
+ 'uk-UA': /^(\+?38|8)?0\d{9}$/,
+ 'uz-UZ': /^(\+?998)?(6[125-79]|7[1-69]|88|9\d)\d{7}$/,
+ 'vi-VN': /^((\+?84)|0)((3([2-9]))|(5([25689]))|(7([0|6-9]))|(8([1-9]))|(9([0-9])))([0-9]{7})$/,
+ 'zh-CN': /^((\+|00)86)?(1[3-9]|9[28])\d{9}$/,
+ 'zh-TW': /^(\+?886\-?|0)?9\d{8}$/,
+ 'dz-BT': /^(\+?975|0)?(17|16|77|02)\d{6}$/,
+ 'ar-YE': /^(((\+|00)9677|0?7)[0137]\d{7}|((\+|00)967|0)[1-7]\d{6})$/,
+ 'ar-EH': /^(\+?212|0)[\s\-]?(5288|5289)[\s\-]?\d{5}$/,
+ 'fa-AF': /^(\+93|0)?(2{1}[0-8]{1}|[3-5]{1}[0-4]{1})(\d{7})$/
+};
+/* eslint-enable max-len */
+// aliases
+
+phones['en-CA'] = phones['en-US'];
+phones['fr-CA'] = phones['en-CA'];
+phones['fr-BE'] = phones['nl-BE'];
+phones['zh-HK'] = phones['en-HK'];
+phones['zh-MO'] = phones['en-MO'];
+phones['ga-IE'] = phones['en-IE'];
+phones['fr-CH'] = phones['de-CH'];
+phones['it-CH'] = phones['fr-CH'];
+
+function isMobilePhone(str, locale, options) {
+ (0, _assertString.default)(str);
+
+ if (options && options.strictMode && !str.startsWith('+')) {
+ return false;
+ }
+
+ if (Array.isArray(locale)) {
+ return locale.some(function (key) {
+ // https://github.com/gotwarlost/istanbul/blob/master/ignoring-code-for-coverage.md#ignoring-code-for-coverage-purposes
+ // istanbul ignore else
+ if (phones.hasOwnProperty(key)) {
+ var phone = phones[key];
+
+ if (phone.test(str)) {
+ return true;
+ }
+ }
+
+ return false;
+ });
+ } else if (locale in phones) {
+ return phones[locale].test(str); // alias falsey locale as 'any'
+ } else if (!locale || locale === 'any') {
+ for (var key in phones) {
+ // istanbul ignore else
+ if (phones.hasOwnProperty(key)) {
+ var phone = phones[key];
+
+ if (phone.test(str)) {
+ return true;
+ }
+ }
+ }
+
+ return false;
+ }
+
+ throw new Error("Invalid locale '".concat(locale, "'"));
+}
+
+var locales = Object.keys(phones);
+exports.locales = locales; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isMongoId.js b/includes/external/addressbook/node_modules/validator/lib/isMongoId.js
new file mode 100644
index 0000000..2e9884d
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isMongoId.js
@@ -0,0 +1,20 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isMongoId;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var _isHexadecimal = _interopRequireDefault(require("./isHexadecimal"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function isMongoId(str) {
+ (0, _assertString.default)(str);
+ return (0, _isHexadecimal.default)(str) && str.length === 24;
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isMultibyte.js b/includes/external/addressbook/node_modules/validator/lib/isMultibyte.js
new file mode 100644
index 0000000..3b4477e
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isMultibyte.js
@@ -0,0 +1,22 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isMultibyte;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/* eslint-disable no-control-regex */
+var multibyte = /[^\x00-\x7F]/;
+/* eslint-enable no-control-regex */
+
+function isMultibyte(str) {
+ (0, _assertString.default)(str);
+ return multibyte.test(str);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isNumeric.js b/includes/external/addressbook/node_modules/validator/lib/isNumeric.js
new file mode 100644
index 0000000..441f30f
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isNumeric.js
@@ -0,0 +1,27 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isNumeric;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var _alpha = require("./alpha");
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var numericNoSymbols = /^[0-9]+$/;
+
+function isNumeric(str, options) {
+ (0, _assertString.default)(str);
+
+ if (options && options.no_symbols) {
+ return numericNoSymbols.test(str);
+ }
+
+ return new RegExp("^[+-]?([0-9]*[".concat((options || {}).locale ? _alpha.decimal[options.locale] : '.', "])?[0-9]+$")).test(str);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isOctal.js b/includes/external/addressbook/node_modules/validator/lib/isOctal.js
new file mode 100644
index 0000000..8d3a1c7
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isOctal.js
@@ -0,0 +1,20 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isOctal;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var octal = /^(0o)?[0-7]+$/i;
+
+function isOctal(str) {
+ (0, _assertString.default)(str);
+ return octal.test(str);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isPassportNumber.js b/includes/external/addressbook/node_modules/validator/lib/isPassportNumber.js
new file mode 100644
index 0000000..3152556
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isPassportNumber.js
@@ -0,0 +1,156 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isPassportNumber;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Reference:
+ * https://en.wikipedia.org/ -- Wikipedia
+ * https://docs.microsoft.com/en-us/microsoft-365/compliance/eu-passport-number -- EU Passport Number
+ * https://countrycode.org/ -- Country Codes
+ */
+var passportRegexByCountryCode = {
+ AM: /^[A-Z]{2}\d{7}$/,
+ // ARMENIA
+ AR: /^[A-Z]{3}\d{6}$/,
+ // ARGENTINA
+ AT: /^[A-Z]\d{7}$/,
+ // AUSTRIA
+ AU: /^[A-Z]\d{7}$/,
+ // AUSTRALIA
+ AZ: /^[A-Z]{2,3}\d{7,8}$/,
+ // AZERBAIJAN
+ BE: /^[A-Z]{2}\d{6}$/,
+ // BELGIUM
+ BG: /^\d{9}$/,
+ // BULGARIA
+ BR: /^[A-Z]{2}\d{6}$/,
+ // BRAZIL
+ BY: /^[A-Z]{2}\d{7}$/,
+ // BELARUS
+ CA: /^[A-Z]{2}\d{6}$/,
+ // CANADA
+ CH: /^[A-Z]\d{7}$/,
+ // SWITZERLAND
+ CN: /^G\d{8}$|^E(?![IO])[A-Z0-9]\d{7}$/,
+ // CHINA [G=Ordinary, E=Electronic] followed by 8-digits, or E followed by any UPPERCASE letter (except I and O) followed by 7 digits
+ CY: /^[A-Z](\d{6}|\d{8})$/,
+ // CYPRUS
+ CZ: /^\d{8}$/,
+ // CZECH REPUBLIC
+ DE: /^[CFGHJKLMNPRTVWXYZ0-9]{9}$/,
+ // GERMANY
+ DK: /^\d{9}$/,
+ // DENMARK
+ DZ: /^\d{9}$/,
+ // ALGERIA
+ EE: /^([A-Z]\d{7}|[A-Z]{2}\d{7})$/,
+ // ESTONIA (K followed by 7-digits), e-passports have 2 UPPERCASE followed by 7 digits
+ ES: /^[A-Z0-9]{2}([A-Z0-9]?)\d{6}$/,
+ // SPAIN
+ FI: /^[A-Z]{2}\d{7}$/,
+ // FINLAND
+ FR: /^\d{2}[A-Z]{2}\d{5}$/,
+ // FRANCE
+ GB: /^\d{9}$/,
+ // UNITED KINGDOM
+ GR: /^[A-Z]{2}\d{7}$/,
+ // GREECE
+ HR: /^\d{9}$/,
+ // CROATIA
+ HU: /^[A-Z]{2}(\d{6}|\d{7})$/,
+ // HUNGARY
+ IE: /^[A-Z0-9]{2}\d{7}$/,
+ // IRELAND
+ IN: /^[A-Z]{1}-?\d{7}$/,
+ // INDIA
+ ID: /^[A-C]\d{7}$/,
+ // INDONESIA
+ IR: /^[A-Z]\d{8}$/,
+ // IRAN
+ IS: /^(A)\d{7}$/,
+ // ICELAND
+ IT: /^[A-Z0-9]{2}\d{7}$/,
+ // ITALY
+ JM: /^[Aa]\d{7}$/,
+ // JAMAICA
+ JP: /^[A-Z]{2}\d{7}$/,
+ // JAPAN
+ KR: /^[MS]\d{8}$/,
+ // SOUTH KOREA, REPUBLIC OF KOREA, [S=PS Passports, M=PM Passports]
+ KZ: /^[a-zA-Z]\d{7}$/,
+ // KAZAKHSTAN
+ LI: /^[a-zA-Z]\d{5}$/,
+ // LIECHTENSTEIN
+ LT: /^[A-Z0-9]{8}$/,
+ // LITHUANIA
+ LU: /^[A-Z0-9]{8}$/,
+ // LUXEMBURG
+ LV: /^[A-Z0-9]{2}\d{7}$/,
+ // LATVIA
+ LY: /^[A-Z0-9]{8}$/,
+ // LIBYA
+ MT: /^\d{7}$/,
+ // MALTA
+ MZ: /^([A-Z]{2}\d{7})|(\d{2}[A-Z]{2}\d{5})$/,
+ // MOZAMBIQUE
+ MY: /^[AHK]\d{8}$/,
+ // MALAYSIA
+ MX: /^\d{10,11}$/,
+ // MEXICO
+ NL: /^[A-Z]{2}[A-Z0-9]{6}\d$/,
+ // NETHERLANDS
+ NZ: /^([Ll]([Aa]|[Dd]|[Ff]|[Hh])|[Ee]([Aa]|[Pp])|[Nn])\d{6}$/,
+ // NEW ZEALAND
+ PH: /^([A-Z](\d{6}|\d{7}[A-Z]))|([A-Z]{2}(\d{6}|\d{7}))$/,
+ // PHILIPPINES
+ PK: /^[A-Z]{2}\d{7}$/,
+ // PAKISTAN
+ PL: /^[A-Z]{2}\d{7}$/,
+ // POLAND
+ PT: /^[A-Z]\d{6}$/,
+ // PORTUGAL
+ RO: /^\d{8,9}$/,
+ // ROMANIA
+ RU: /^\d{9}$/,
+ // RUSSIAN FEDERATION
+ SE: /^\d{8}$/,
+ // SWEDEN
+ SL: /^(P)[A-Z]\d{7}$/,
+ // SLOVENIA
+ SK: /^[0-9A-Z]\d{7}$/,
+ // SLOVAKIA
+ TH: /^[A-Z]{1,2}\d{6,7}$/,
+ // THAILAND
+ TR: /^[A-Z]\d{8}$/,
+ // TURKEY
+ UA: /^[A-Z]{2}\d{6}$/,
+ // UKRAINE
+ US: /^\d{9}$/ // UNITED STATES
+
+};
+/**
+ * Check if str is a valid passport number
+ * relative to provided ISO Country Code.
+ *
+ * @param {string} str
+ * @param {string} countryCode
+ * @return {boolean}
+ */
+
+function isPassportNumber(str, countryCode) {
+ (0, _assertString.default)(str);
+ /** Remove All Whitespaces, Convert to UPPERCASE */
+
+ var normalizedStr = str.replace(/\s/g, '').toUpperCase();
+ return countryCode.toUpperCase() in passportRegexByCountryCode && passportRegexByCountryCode[countryCode].test(normalizedStr);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isPort.js b/includes/external/addressbook/node_modules/validator/lib/isPort.js
new file mode 100644
index 0000000..9274a4c
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isPort.js
@@ -0,0 +1,20 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isPort;
+
+var _isInt = _interopRequireDefault(require("./isInt"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function isPort(str) {
+ return (0, _isInt.default)(str, {
+ min: 0,
+ max: 65535
+ });
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isPostalCode.js b/includes/external/addressbook/node_modules/validator/lib/isPostalCode.js
new file mode 100644
index 0000000..d9798a6
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isPostalCode.js
@@ -0,0 +1,111 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isPostalCode;
+exports.locales = void 0;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+// common patterns
+var threeDigit = /^\d{3}$/;
+var fourDigit = /^\d{4}$/;
+var fiveDigit = /^\d{5}$/;
+var sixDigit = /^\d{6}$/;
+var patterns = {
+ AD: /^AD\d{3}$/,
+ AT: fourDigit,
+ AU: fourDigit,
+ AZ: /^AZ\d{4}$/,
+ BA: /^([7-8]\d{4}$)/,
+ BE: fourDigit,
+ BG: fourDigit,
+ BR: /^\d{5}-\d{3}$/,
+ BY: /^2[1-4]\d{4}$/,
+ CA: /^[ABCEGHJKLMNPRSTVXY]\d[ABCEGHJ-NPRSTV-Z][\s\-]?\d[ABCEGHJ-NPRSTV-Z]\d$/i,
+ CH: fourDigit,
+ CN: /^(0[1-7]|1[012356]|2[0-7]|3[0-6]|4[0-7]|5[1-7]|6[1-7]|7[1-5]|8[1345]|9[09])\d{4}$/,
+ CZ: /^\d{3}\s?\d{2}$/,
+ DE: fiveDigit,
+ DK: fourDigit,
+ DO: fiveDigit,
+ DZ: fiveDigit,
+ EE: fiveDigit,
+ ES: /^(5[0-2]{1}|[0-4]{1}\d{1})\d{3}$/,
+ FI: fiveDigit,
+ FR: /^\d{2}\s?\d{3}$/,
+ GB: /^(gir\s?0aa|[a-z]{1,2}\d[\da-z]?\s?(\d[a-z]{2})?)$/i,
+ GR: /^\d{3}\s?\d{2}$/,
+ HR: /^([1-5]\d{4}$)/,
+ HT: /^HT\d{4}$/,
+ HU: fourDigit,
+ ID: fiveDigit,
+ IE: /^(?!.*(?:o))[A-Za-z]\d[\dw]\s\w{4}$/i,
+ IL: /^(\d{5}|\d{7})$/,
+ IN: /^((?!10|29|35|54|55|65|66|86|87|88|89)[1-9][0-9]{5})$/,
+ IR: /^(?!(\d)\1{3})[13-9]{4}[1346-9][013-9]{5}$/,
+ IS: threeDigit,
+ IT: fiveDigit,
+ JP: /^\d{3}\-\d{4}$/,
+ KE: fiveDigit,
+ KR: /^(\d{5}|\d{6})$/,
+ LI: /^(948[5-9]|949[0-7])$/,
+ LT: /^LT\-\d{5}$/,
+ LU: fourDigit,
+ LV: /^LV\-\d{4}$/,
+ LK: fiveDigit,
+ MG: threeDigit,
+ MX: fiveDigit,
+ MT: /^[A-Za-z]{3}\s{0,1}\d{4}$/,
+ MY: fiveDigit,
+ NL: /^\d{4}\s?[a-z]{2}$/i,
+ NO: fourDigit,
+ NP: /^(10|21|22|32|33|34|44|45|56|57)\d{3}$|^(977)$/i,
+ NZ: fourDigit,
+ PL: /^\d{2}\-\d{3}$/,
+ PR: /^00[679]\d{2}([ -]\d{4})?$/,
+ PT: /^\d{4}\-\d{3}?$/,
+ RO: sixDigit,
+ RU: sixDigit,
+ SA: fiveDigit,
+ SE: /^[1-9]\d{2}\s?\d{2}$/,
+ SG: sixDigit,
+ SI: fourDigit,
+ SK: /^\d{3}\s?\d{2}$/,
+ TH: fiveDigit,
+ TN: fourDigit,
+ TW: /^\d{3}(\d{2})?$/,
+ UA: fiveDigit,
+ US: /^\d{5}(-\d{4})?$/,
+ ZA: fourDigit,
+ ZM: fiveDigit
+};
+var locales = Object.keys(patterns);
+exports.locales = locales;
+
+function isPostalCode(str, locale) {
+ (0, _assertString.default)(str);
+
+ if (locale in patterns) {
+ return patterns[locale].test(str);
+ } else if (locale === 'any') {
+ for (var key in patterns) {
+ // https://github.com/gotwarlost/istanbul/blob/master/ignoring-code-for-coverage.md#ignoring-code-for-coverage-purposes
+ // istanbul ignore else
+ if (patterns.hasOwnProperty(key)) {
+ var pattern = patterns[key];
+
+ if (pattern.test(str)) {
+ return true;
+ }
+ }
+ }
+
+ return false;
+ }
+
+ throw new Error("Invalid locale '".concat(locale, "'"));
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isRFC3339.js b/includes/external/addressbook/node_modules/validator/lib/isRFC3339.js
new file mode 100644
index 0000000..da10790
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isRFC3339.js
@@ -0,0 +1,33 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isRFC3339;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/* Based on https://tools.ietf.org/html/rfc3339#section-5.6 */
+var dateFullYear = /[0-9]{4}/;
+var dateMonth = /(0[1-9]|1[0-2])/;
+var dateMDay = /([12]\d|0[1-9]|3[01])/;
+var timeHour = /([01][0-9]|2[0-3])/;
+var timeMinute = /[0-5][0-9]/;
+var timeSecond = /([0-5][0-9]|60)/;
+var timeSecFrac = /(\.[0-9]+)?/;
+var timeNumOffset = new RegExp("[-+]".concat(timeHour.source, ":").concat(timeMinute.source));
+var timeOffset = new RegExp("([zZ]|".concat(timeNumOffset.source, ")"));
+var partialTime = new RegExp("".concat(timeHour.source, ":").concat(timeMinute.source, ":").concat(timeSecond.source).concat(timeSecFrac.source));
+var fullDate = new RegExp("".concat(dateFullYear.source, "-").concat(dateMonth.source, "-").concat(dateMDay.source));
+var fullTime = new RegExp("".concat(partialTime.source).concat(timeOffset.source));
+var rfc3339 = new RegExp("^".concat(fullDate.source, "[ tT]").concat(fullTime.source, "$"));
+
+function isRFC3339(str) {
+ (0, _assertString.default)(str);
+ return rfc3339.test(str);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isRgbColor.js b/includes/external/addressbook/node_modules/validator/lib/isRgbColor.js
new file mode 100644
index 0000000..10cee51
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isRgbColor.js
@@ -0,0 +1,29 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isRgbColor;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var rgbColor = /^rgb\((([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5]),){2}([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\)$/;
+var rgbaColor = /^rgba\((([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5]),){3}(0?\.\d|1(\.0)?|0(\.0)?)\)$/;
+var rgbColorPercent = /^rgb\((([0-9]%|[1-9][0-9]%|100%),){2}([0-9]%|[1-9][0-9]%|100%)\)$/;
+var rgbaColorPercent = /^rgba\((([0-9]%|[1-9][0-9]%|100%),){3}(0?\.\d|1(\.0)?|0(\.0)?)\)$/;
+
+function isRgbColor(str) {
+ var includePercentValues = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
+ (0, _assertString.default)(str);
+
+ if (!includePercentValues) {
+ return rgbColor.test(str) || rgbaColor.test(str);
+ }
+
+ return rgbColor.test(str) || rgbaColor.test(str) || rgbColorPercent.test(str) || rgbaColorPercent.test(str);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isSemVer.js b/includes/external/addressbook/node_modules/validator/lib/isSemVer.js
new file mode 100644
index 0000000..27355cd
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isSemVer.js
@@ -0,0 +1,28 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isSemVer;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var _multilineRegex = _interopRequireDefault(require("./util/multilineRegex"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+/**
+ * Regular Expression to match
+ * semantic versioning (SemVer)
+ * built from multi-line, multi-parts regexp
+ * Reference: https://semver.org/
+ */
+var semanticVersioningRegex = (0, _multilineRegex.default)(['^(0|[1-9]\\d*)\\.(0|[1-9]\\d*)\\.(0|[1-9]\\d*)', '(?:-((?:0|[1-9]\\d*|\\d*[a-z-][0-9a-z-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-z-][0-9a-z-]*))*))', '?(?:\\+([0-9a-z-]+(?:\\.[0-9a-z-]+)*))?$'], 'i');
+
+function isSemVer(str) {
+ (0, _assertString.default)(str);
+ return semanticVersioningRegex.test(str);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isSlug.js b/includes/external/addressbook/node_modules/validator/lib/isSlug.js
new file mode 100644
index 0000000..c40e6ad
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isSlug.js
@@ -0,0 +1,20 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isSlug;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var charsetRegex = /^[^\s-_](?!.*?[-_]{2,})[a-z0-9-\\][^\s]*[^-_\s]$/;
+
+function isSlug(str) {
+ (0, _assertString.default)(str);
+ return charsetRegex.test(str);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isStrongPassword.js b/includes/external/addressbook/node_modules/validator/lib/isStrongPassword.js
new file mode 100644
index 0000000..93dc33b
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isStrongPassword.js
@@ -0,0 +1,115 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isStrongPassword;
+
+var _merge = _interopRequireDefault(require("./util/merge"));
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var upperCaseRegex = /^[A-Z]$/;
+var lowerCaseRegex = /^[a-z]$/;
+var numberRegex = /^[0-9]$/;
+var symbolRegex = /^[-#!$@£%^&*()_+|~=`{}\[\]:";'<>?,.\/ ]$/;
+var defaultOptions = {
+ minLength: 8,
+ minLowercase: 1,
+ minUppercase: 1,
+ minNumbers: 1,
+ minSymbols: 1,
+ returnScore: false,
+ pointsPerUnique: 1,
+ pointsPerRepeat: 0.5,
+ pointsForContainingLower: 10,
+ pointsForContainingUpper: 10,
+ pointsForContainingNumber: 10,
+ pointsForContainingSymbol: 10
+};
+/* Counts number of occurrences of each char in a string
+ * could be moved to util/ ?
+*/
+
+function countChars(str) {
+ var result = {};
+ Array.from(str).forEach(function (char) {
+ var curVal = result[char];
+
+ if (curVal) {
+ result[char] += 1;
+ } else {
+ result[char] = 1;
+ }
+ });
+ return result;
+}
+/* Return information about a password */
+
+
+function analyzePassword(password) {
+ var charMap = countChars(password);
+ var analysis = {
+ length: password.length,
+ uniqueChars: Object.keys(charMap).length,
+ uppercaseCount: 0,
+ lowercaseCount: 0,
+ numberCount: 0,
+ symbolCount: 0
+ };
+ Object.keys(charMap).forEach(function (char) {
+ /* istanbul ignore else */
+ if (upperCaseRegex.test(char)) {
+ analysis.uppercaseCount += charMap[char];
+ } else if (lowerCaseRegex.test(char)) {
+ analysis.lowercaseCount += charMap[char];
+ } else if (numberRegex.test(char)) {
+ analysis.numberCount += charMap[char];
+ } else if (symbolRegex.test(char)) {
+ analysis.symbolCount += charMap[char];
+ }
+ });
+ return analysis;
+}
+
+function scorePassword(analysis, scoringOptions) {
+ var points = 0;
+ points += analysis.uniqueChars * scoringOptions.pointsPerUnique;
+ points += (analysis.length - analysis.uniqueChars) * scoringOptions.pointsPerRepeat;
+
+ if (analysis.lowercaseCount > 0) {
+ points += scoringOptions.pointsForContainingLower;
+ }
+
+ if (analysis.uppercaseCount > 0) {
+ points += scoringOptions.pointsForContainingUpper;
+ }
+
+ if (analysis.numberCount > 0) {
+ points += scoringOptions.pointsForContainingNumber;
+ }
+
+ if (analysis.symbolCount > 0) {
+ points += scoringOptions.pointsForContainingSymbol;
+ }
+
+ return points;
+}
+
+function isStrongPassword(str) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;
+ (0, _assertString.default)(str);
+ var analysis = analyzePassword(str);
+ options = (0, _merge.default)(options || {}, defaultOptions);
+
+ if (options.returnScore) {
+ return scorePassword(analysis, options);
+ }
+
+ return analysis.length >= options.minLength && analysis.lowercaseCount >= options.minLowercase && analysis.uppercaseCount >= options.minUppercase && analysis.numberCount >= options.minNumbers && analysis.symbolCount >= options.minSymbols;
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isSurrogatePair.js b/includes/external/addressbook/node_modules/validator/lib/isSurrogatePair.js
new file mode 100644
index 0000000..ee5678b
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isSurrogatePair.js
@@ -0,0 +1,20 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isSurrogatePair;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var surrogatePair = /[\uD800-\uDBFF][\uDC00-\uDFFF]/;
+
+function isSurrogatePair(str) {
+ (0, _assertString.default)(str);
+ return surrogatePair.test(str);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isTaxID.js b/includes/external/addressbook/node_modules/validator/lib/isTaxID.js
new file mode 100644
index 0000000..4f696ad
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isTaxID.js
@@ -0,0 +1,1563 @@
+"use strict";
+
+function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isTaxID;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var algorithms = _interopRequireWildcard(require("./util/algorithms"));
+
+var _isDate = _interopRequireDefault(require("./isDate"));
+
+function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }
+
+function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _toConsumableArray(arr) { return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread(); }
+
+function _nonIterableSpread() { throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
+
+function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
+
+function _iterableToArray(iter) { if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter); }
+
+function _arrayWithoutHoles(arr) { if (Array.isArray(arr)) return _arrayLikeToArray(arr); }
+
+function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
+
+/**
+ * TIN Validation
+ * Validates Tax Identification Numbers (TINs) from the US, EU member states and the United Kingdom.
+ *
+ * EU-UK:
+ * National TIN validity is calculated using public algorithms as made available by DG TAXUD.
+ *
+ * See `https://ec.europa.eu/taxation_customs/tin/specs/FS-TIN%20Algorithms-Public.docx` for more information.
+ *
+ * US:
+ * An Employer Identification Number (EIN), also known as a Federal Tax Identification Number,
+ * is used to identify a business entity.
+ *
+ * NOTES:
+ * - Prefix 47 is being reserved for future use
+ * - Prefixes 26, 27, 45, 46 and 47 were previously assigned by the Philadelphia campus.
+ *
+ * See `http://www.irs.gov/Businesses/Small-Businesses-&-Self-Employed/How-EINs-are-Assigned-and-Valid-EIN-Prefixes`
+ * for more information.
+ */
+// Locale functions
+
+/*
+ * bg-BG validation function
+ * (Edinen graždanski nomer (EGN/ЕГН), persons only)
+ * Checks if birth date (first six digits) is valid and calculates check (last) digit
+ */
+function bgBgCheck(tin) {
+ // Extract full year, normalize month and check birth date validity
+ var century_year = tin.slice(0, 2);
+ var month = parseInt(tin.slice(2, 4), 10);
+
+ if (month > 40) {
+ month -= 40;
+ century_year = "20".concat(century_year);
+ } else if (month > 20) {
+ month -= 20;
+ century_year = "18".concat(century_year);
+ } else {
+ century_year = "19".concat(century_year);
+ }
+
+ if (month < 10) {
+ month = "0".concat(month);
+ }
+
+ var date = "".concat(century_year, "/").concat(month, "/").concat(tin.slice(4, 6));
+
+ if (!(0, _isDate.default)(date, 'YYYY/MM/DD')) {
+ return false;
+ } // split digits into an array for further processing
+
+
+ var digits = tin.split('').map(function (a) {
+ return parseInt(a, 10);
+ }); // Calculate checksum by multiplying digits with fixed values
+
+ var multip_lookup = [2, 4, 8, 5, 10, 9, 7, 3, 6];
+ var checksum = 0;
+
+ for (var i = 0; i < multip_lookup.length; i++) {
+ checksum += digits[i] * multip_lookup[i];
+ }
+
+ checksum = checksum % 11 === 10 ? 0 : checksum % 11;
+ return checksum === digits[9];
+}
+/**
+ * Check if an input is a valid Canadian SIN (Social Insurance Number)
+ *
+ * The Social Insurance Number (SIN) is a 9 digit number that
+ * you need to work in Canada or to have access to government programs and benefits.
+ *
+ * https://en.wikipedia.org/wiki/Social_Insurance_Number
+ * https://www.canada.ca/en/employment-social-development/services/sin.html
+ * https://www.codercrunch.com/challenge/819302488/sin-validator
+ *
+ * @param {string} input
+ * @return {boolean}
+ */
+
+
+function isCanadianSIN(input) {
+ var digitsArray = input.split('');
+ var even = digitsArray.filter(function (_, idx) {
+ return idx % 2;
+ }).map(function (i) {
+ return Number(i) * 2;
+ }).join('').split('');
+ var total = digitsArray.filter(function (_, idx) {
+ return !(idx % 2);
+ }).concat(even).map(function (i) {
+ return Number(i);
+ }).reduce(function (acc, cur) {
+ return acc + cur;
+ });
+ return total % 10 === 0;
+}
+/*
+ * cs-CZ validation function
+ * (Rodné číslo (RČ), persons only)
+ * Checks if birth date (first six digits) is valid and divisibility by 11
+ * Material not in DG TAXUD document sourced from:
+ * -`https://lorenc.info/3MA381/overeni-spravnosti-rodneho-cisla.htm`
+ * -`https://www.mvcr.cz/clanek/rady-a-sluzby-dokumenty-rodne-cislo.aspx`
+ */
+
+
+function csCzCheck(tin) {
+ tin = tin.replace(/\W/, ''); // Extract full year from TIN length
+
+ var full_year = parseInt(tin.slice(0, 2), 10);
+
+ if (tin.length === 10) {
+ if (full_year < 54) {
+ full_year = "20".concat(full_year);
+ } else {
+ full_year = "19".concat(full_year);
+ }
+ } else {
+ if (tin.slice(6) === '000') {
+ return false;
+ } // Three-zero serial not assigned before 1954
+
+
+ if (full_year < 54) {
+ full_year = "19".concat(full_year);
+ } else {
+ return false; // No 18XX years seen in any of the resources
+ }
+ } // Add missing zero if needed
+
+
+ if (full_year.length === 3) {
+ full_year = [full_year.slice(0, 2), '0', full_year.slice(2)].join('');
+ } // Extract month from TIN and normalize
+
+
+ var month = parseInt(tin.slice(2, 4), 10);
+
+ if (month > 50) {
+ month -= 50;
+ }
+
+ if (month > 20) {
+ // Month-plus-twenty was only introduced in 2004
+ if (parseInt(full_year, 10) < 2004) {
+ return false;
+ }
+
+ month -= 20;
+ }
+
+ if (month < 10) {
+ month = "0".concat(month);
+ } // Check date validity
+
+
+ var date = "".concat(full_year, "/").concat(month, "/").concat(tin.slice(4, 6));
+
+ if (!(0, _isDate.default)(date, 'YYYY/MM/DD')) {
+ return false;
+ } // Verify divisibility by 11
+
+
+ if (tin.length === 10) {
+ if (parseInt(tin, 10) % 11 !== 0) {
+ // Some numbers up to and including 1985 are still valid if
+ // check (last) digit equals 0 and modulo of first 9 digits equals 10
+ var checkdigit = parseInt(tin.slice(0, 9), 10) % 11;
+
+ if (parseInt(full_year, 10) < 1986 && checkdigit === 10) {
+ if (parseInt(tin.slice(9), 10) !== 0) {
+ return false;
+ }
+ } else {
+ return false;
+ }
+ }
+ }
+
+ return true;
+}
+/*
+ * de-AT validation function
+ * (Abgabenkontonummer, persons/entities)
+ * Verify TIN validity by calling luhnCheck()
+ */
+
+
+function deAtCheck(tin) {
+ return algorithms.luhnCheck(tin);
+}
+/*
+ * de-DE validation function
+ * (Steueridentifikationsnummer (Steuer-IdNr.), persons only)
+ * Tests for single duplicate/triplicate value, then calculates ISO 7064 check (last) digit
+ * Partial implementation of spec (same result with both algorithms always)
+ */
+
+
+function deDeCheck(tin) {
+ // Split digits into an array for further processing
+ var digits = tin.split('').map(function (a) {
+ return parseInt(a, 10);
+ }); // Fill array with strings of number positions
+
+ var occurences = [];
+
+ for (var i = 0; i < digits.length - 1; i++) {
+ occurences.push('');
+
+ for (var j = 0; j < digits.length - 1; j++) {
+ if (digits[i] === digits[j]) {
+ occurences[i] += j;
+ }
+ }
+ } // Remove digits with one occurence and test for only one duplicate/triplicate
+
+
+ occurences = occurences.filter(function (a) {
+ return a.length > 1;
+ });
+
+ if (occurences.length !== 2 && occurences.length !== 3) {
+ return false;
+ } // In case of triplicate value only two digits are allowed next to each other
+
+
+ if (occurences[0].length === 3) {
+ var trip_locations = occurences[0].split('').map(function (a) {
+ return parseInt(a, 10);
+ });
+ var recurrent = 0; // Amount of neighbour occurences
+
+ for (var _i = 0; _i < trip_locations.length - 1; _i++) {
+ if (trip_locations[_i] + 1 === trip_locations[_i + 1]) {
+ recurrent += 1;
+ }
+ }
+
+ if (recurrent === 2) {
+ return false;
+ }
+ }
+
+ return algorithms.iso7064Check(tin);
+}
+/*
+ * dk-DK validation function
+ * (CPR-nummer (personnummer), persons only)
+ * Checks if birth date (first six digits) is valid and assigned to century (seventh) digit,
+ * and calculates check (last) digit
+ */
+
+
+function dkDkCheck(tin) {
+ tin = tin.replace(/\W/, ''); // Extract year, check if valid for given century digit and add century
+
+ var year = parseInt(tin.slice(4, 6), 10);
+ var century_digit = tin.slice(6, 7);
+
+ switch (century_digit) {
+ case '0':
+ case '1':
+ case '2':
+ case '3':
+ year = "19".concat(year);
+ break;
+
+ case '4':
+ case '9':
+ if (year < 37) {
+ year = "20".concat(year);
+ } else {
+ year = "19".concat(year);
+ }
+
+ break;
+
+ default:
+ if (year < 37) {
+ year = "20".concat(year);
+ } else if (year > 58) {
+ year = "18".concat(year);
+ } else {
+ return false;
+ }
+
+ break;
+ } // Add missing zero if needed
+
+
+ if (year.length === 3) {
+ year = [year.slice(0, 2), '0', year.slice(2)].join('');
+ } // Check date validity
+
+
+ var date = "".concat(year, "/").concat(tin.slice(2, 4), "/").concat(tin.slice(0, 2));
+
+ if (!(0, _isDate.default)(date, 'YYYY/MM/DD')) {
+ return false;
+ } // Split digits into an array for further processing
+
+
+ var digits = tin.split('').map(function (a) {
+ return parseInt(a, 10);
+ });
+ var checksum = 0;
+ var weight = 4; // Multiply by weight and add to checksum
+
+ for (var i = 0; i < 9; i++) {
+ checksum += digits[i] * weight;
+ weight -= 1;
+
+ if (weight === 1) {
+ weight = 7;
+ }
+ }
+
+ checksum %= 11;
+
+ if (checksum === 1) {
+ return false;
+ }
+
+ return checksum === 0 ? digits[9] === 0 : digits[9] === 11 - checksum;
+}
+/*
+ * el-CY validation function
+ * (Arithmos Forologikou Mitroou (AFM/ΑΦΜ), persons only)
+ * Verify TIN validity by calculating ASCII value of check (last) character
+ */
+
+
+function elCyCheck(tin) {
+ // split digits into an array for further processing
+ var digits = tin.slice(0, 8).split('').map(function (a) {
+ return parseInt(a, 10);
+ });
+ var checksum = 0; // add digits in even places
+
+ for (var i = 1; i < digits.length; i += 2) {
+ checksum += digits[i];
+ } // add digits in odd places
+
+
+ for (var _i2 = 0; _i2 < digits.length; _i2 += 2) {
+ if (digits[_i2] < 2) {
+ checksum += 1 - digits[_i2];
+ } else {
+ checksum += 2 * (digits[_i2] - 2) + 5;
+
+ if (digits[_i2] > 4) {
+ checksum += 2;
+ }
+ }
+ }
+
+ return String.fromCharCode(checksum % 26 + 65) === tin.charAt(8);
+}
+/*
+ * el-GR validation function
+ * (Arithmos Forologikou Mitroou (AFM/ΑΦΜ), persons/entities)
+ * Verify TIN validity by calculating check (last) digit
+ * Algorithm not in DG TAXUD document- sourced from:
+ * - `http://epixeirisi.gr/%CE%9A%CE%A1%CE%99%CE%A3%CE%99%CE%9C%CE%91-%CE%98%CE%95%CE%9C%CE%91%CE%A4%CE%91-%CE%A6%CE%9F%CE%A1%CE%9F%CE%9B%CE%9F%CE%93%CE%99%CE%91%CE%A3-%CE%9A%CE%91%CE%99-%CE%9B%CE%9F%CE%93%CE%99%CE%A3%CE%A4%CE%99%CE%9A%CE%97%CE%A3/23791/%CE%91%CF%81%CE%B9%CE%B8%CE%BC%CF%8C%CF%82-%CE%A6%CE%BF%CF%81%CE%BF%CE%BB%CE%BF%CE%B3%CE%B9%CE%BA%CE%BF%CF%8D-%CE%9C%CE%B7%CF%84%CF%81%CF%8E%CE%BF%CF%85`
+ */
+
+
+function elGrCheck(tin) {
+ // split digits into an array for further processing
+ var digits = tin.split('').map(function (a) {
+ return parseInt(a, 10);
+ });
+ var checksum = 0;
+
+ for (var i = 0; i < 8; i++) {
+ checksum += digits[i] * Math.pow(2, 8 - i);
+ }
+
+ return checksum % 11 % 10 === digits[8];
+}
+/*
+ * en-GB validation function (should go here if needed)
+ * (National Insurance Number (NINO) or Unique Taxpayer Reference (UTR),
+ * persons/entities respectively)
+ */
+
+/*
+ * en-IE validation function
+ * (Personal Public Service Number (PPS No), persons only)
+ * Verify TIN validity by calculating check (second to last) character
+ */
+
+
+function enIeCheck(tin) {
+ var checksum = algorithms.reverseMultiplyAndSum(tin.split('').slice(0, 7).map(function (a) {
+ return parseInt(a, 10);
+ }), 8);
+
+ if (tin.length === 9 && tin[8] !== 'W') {
+ checksum += (tin[8].charCodeAt(0) - 64) * 9;
+ }
+
+ checksum %= 23;
+
+ if (checksum === 0) {
+ return tin[7].toUpperCase() === 'W';
+ }
+
+ return tin[7].toUpperCase() === String.fromCharCode(64 + checksum);
+} // Valid US IRS campus prefixes
+
+
+var enUsCampusPrefix = {
+ andover: ['10', '12'],
+ atlanta: ['60', '67'],
+ austin: ['50', '53'],
+ brookhaven: ['01', '02', '03', '04', '05', '06', '11', '13', '14', '16', '21', '22', '23', '25', '34', '51', '52', '54', '55', '56', '57', '58', '59', '65'],
+ cincinnati: ['30', '32', '35', '36', '37', '38', '61'],
+ fresno: ['15', '24'],
+ internet: ['20', '26', '27', '45', '46', '47'],
+ kansas: ['40', '44'],
+ memphis: ['94', '95'],
+ ogden: ['80', '90'],
+ philadelphia: ['33', '39', '41', '42', '43', '46', '48', '62', '63', '64', '66', '68', '71', '72', '73', '74', '75', '76', '77', '81', '82', '83', '84', '85', '86', '87', '88', '91', '92', '93', '98', '99'],
+ sba: ['31']
+}; // Return an array of all US IRS campus prefixes
+
+function enUsGetPrefixes() {
+ var prefixes = [];
+
+ for (var location in enUsCampusPrefix) {
+ // https://github.com/gotwarlost/istanbul/blob/master/ignoring-code-for-coverage.md#ignoring-code-for-coverage-purposes
+ // istanbul ignore else
+ if (enUsCampusPrefix.hasOwnProperty(location)) {
+ prefixes.push.apply(prefixes, _toConsumableArray(enUsCampusPrefix[location]));
+ }
+ }
+
+ return prefixes;
+}
+/*
+ * en-US validation function
+ * Verify that the TIN starts with a valid IRS campus prefix
+ */
+
+
+function enUsCheck(tin) {
+ return enUsGetPrefixes().indexOf(tin.slice(0, 2)) !== -1;
+}
+/*
+ * es-ES validation function
+ * (Documento Nacional de Identidad (DNI)
+ * or Número de Identificación de Extranjero (NIE), persons only)
+ * Verify TIN validity by calculating check (last) character
+ */
+
+
+function esEsCheck(tin) {
+ // Split characters into an array for further processing
+ var chars = tin.toUpperCase().split(''); // Replace initial letter if needed
+
+ if (isNaN(parseInt(chars[0], 10)) && chars.length > 1) {
+ var lead_replace = 0;
+
+ switch (chars[0]) {
+ case 'Y':
+ lead_replace = 1;
+ break;
+
+ case 'Z':
+ lead_replace = 2;
+ break;
+
+ default:
+ }
+
+ chars.splice(0, 1, lead_replace); // Fill with zeros if smaller than proper
+ } else {
+ while (chars.length < 9) {
+ chars.unshift(0);
+ }
+ } // Calculate checksum and check according to lookup
+
+
+ var lookup = ['T', 'R', 'W', 'A', 'G', 'M', 'Y', 'F', 'P', 'D', 'X', 'B', 'N', 'J', 'Z', 'S', 'Q', 'V', 'H', 'L', 'C', 'K', 'E'];
+ chars = chars.join('');
+ var checksum = parseInt(chars.slice(0, 8), 10) % 23;
+ return chars[8] === lookup[checksum];
+}
+/*
+ * et-EE validation function
+ * (Isikukood (IK), persons only)
+ * Checks if birth date (century digit and six following) is valid and calculates check (last) digit
+ * Material not in DG TAXUD document sourced from:
+ * - `https://www.oecd.org/tax/automatic-exchange/crs-implementation-and-assistance/tax-identification-numbers/Estonia-TIN.pdf`
+ */
+
+
+function etEeCheck(tin) {
+ // Extract year and add century
+ var full_year = tin.slice(1, 3);
+ var century_digit = tin.slice(0, 1);
+
+ switch (century_digit) {
+ case '1':
+ case '2':
+ full_year = "18".concat(full_year);
+ break;
+
+ case '3':
+ case '4':
+ full_year = "19".concat(full_year);
+ break;
+
+ default:
+ full_year = "20".concat(full_year);
+ break;
+ } // Check date validity
+
+
+ var date = "".concat(full_year, "/").concat(tin.slice(3, 5), "/").concat(tin.slice(5, 7));
+
+ if (!(0, _isDate.default)(date, 'YYYY/MM/DD')) {
+ return false;
+ } // Split digits into an array for further processing
+
+
+ var digits = tin.split('').map(function (a) {
+ return parseInt(a, 10);
+ });
+ var checksum = 0;
+ var weight = 1; // Multiply by weight and add to checksum
+
+ for (var i = 0; i < 10; i++) {
+ checksum += digits[i] * weight;
+ weight += 1;
+
+ if (weight === 10) {
+ weight = 1;
+ }
+ } // Do again if modulo 11 of checksum is 10
+
+
+ if (checksum % 11 === 10) {
+ checksum = 0;
+ weight = 3;
+
+ for (var _i3 = 0; _i3 < 10; _i3++) {
+ checksum += digits[_i3] * weight;
+ weight += 1;
+
+ if (weight === 10) {
+ weight = 1;
+ }
+ }
+
+ if (checksum % 11 === 10) {
+ return digits[10] === 0;
+ }
+ }
+
+ return checksum % 11 === digits[10];
+}
+/*
+ * fi-FI validation function
+ * (Henkilötunnus (HETU), persons only)
+ * Checks if birth date (first six digits plus century symbol) is valid
+ * and calculates check (last) digit
+ */
+
+
+function fiFiCheck(tin) {
+ // Extract year and add century
+ var full_year = tin.slice(4, 6);
+ var century_symbol = tin.slice(6, 7);
+
+ switch (century_symbol) {
+ case '+':
+ full_year = "18".concat(full_year);
+ break;
+
+ case '-':
+ full_year = "19".concat(full_year);
+ break;
+
+ default:
+ full_year = "20".concat(full_year);
+ break;
+ } // Check date validity
+
+
+ var date = "".concat(full_year, "/").concat(tin.slice(2, 4), "/").concat(tin.slice(0, 2));
+
+ if (!(0, _isDate.default)(date, 'YYYY/MM/DD')) {
+ return false;
+ } // Calculate check character
+
+
+ var checksum = parseInt(tin.slice(0, 6) + tin.slice(7, 10), 10) % 31;
+
+ if (checksum < 10) {
+ return checksum === parseInt(tin.slice(10), 10);
+ }
+
+ checksum -= 10;
+ var letters_lookup = ['A', 'B', 'C', 'D', 'E', 'F', 'H', 'J', 'K', 'L', 'M', 'N', 'P', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y'];
+ return letters_lookup[checksum] === tin.slice(10);
+}
+/*
+ * fr/nl-BE validation function
+ * (Numéro national (N.N.), persons only)
+ * Checks if birth date (first six digits) is valid and calculates check (last two) digits
+ */
+
+
+function frBeCheck(tin) {
+ // Zero month/day value is acceptable
+ if (tin.slice(2, 4) !== '00' || tin.slice(4, 6) !== '00') {
+ // Extract date from first six digits of TIN
+ var date = "".concat(tin.slice(0, 2), "/").concat(tin.slice(2, 4), "/").concat(tin.slice(4, 6));
+
+ if (!(0, _isDate.default)(date, 'YY/MM/DD')) {
+ return false;
+ }
+ }
+
+ var checksum = 97 - parseInt(tin.slice(0, 9), 10) % 97;
+ var checkdigits = parseInt(tin.slice(9, 11), 10);
+
+ if (checksum !== checkdigits) {
+ checksum = 97 - parseInt("2".concat(tin.slice(0, 9)), 10) % 97;
+
+ if (checksum !== checkdigits) {
+ return false;
+ }
+ }
+
+ return true;
+}
+/*
+ * fr-FR validation function
+ * (Numéro fiscal de référence (numéro SPI), persons only)
+ * Verify TIN validity by calculating check (last three) digits
+ */
+
+
+function frFrCheck(tin) {
+ tin = tin.replace(/\s/g, '');
+ var checksum = parseInt(tin.slice(0, 10), 10) % 511;
+ var checkdigits = parseInt(tin.slice(10, 13), 10);
+ return checksum === checkdigits;
+}
+/*
+ * fr/lb-LU validation function
+ * (numéro d’identification personnelle, persons only)
+ * Verify birth date validity and run Luhn and Verhoeff checks
+ */
+
+
+function frLuCheck(tin) {
+ // Extract date and check validity
+ var date = "".concat(tin.slice(0, 4), "/").concat(tin.slice(4, 6), "/").concat(tin.slice(6, 8));
+
+ if (!(0, _isDate.default)(date, 'YYYY/MM/DD')) {
+ return false;
+ } // Run Luhn check
+
+
+ if (!algorithms.luhnCheck(tin.slice(0, 12))) {
+ return false;
+ } // Remove Luhn check digit and run Verhoeff check
+
+
+ return algorithms.verhoeffCheck("".concat(tin.slice(0, 11)).concat(tin[12]));
+}
+/*
+ * hr-HR validation function
+ * (Osobni identifikacijski broj (OIB), persons/entities)
+ * Verify TIN validity by calling iso7064Check(digits)
+ */
+
+
+function hrHrCheck(tin) {
+ return algorithms.iso7064Check(tin);
+}
+/*
+ * hu-HU validation function
+ * (Adóazonosító jel, persons only)
+ * Verify TIN validity by calculating check (last) digit
+ */
+
+
+function huHuCheck(tin) {
+ // split digits into an array for further processing
+ var digits = tin.split('').map(function (a) {
+ return parseInt(a, 10);
+ });
+ var checksum = 8;
+
+ for (var i = 1; i < 9; i++) {
+ checksum += digits[i] * (i + 1);
+ }
+
+ return checksum % 11 === digits[9];
+}
+/*
+ * lt-LT validation function (should go here if needed)
+ * (Asmens kodas, persons/entities respectively)
+ * Current validation check is alias of etEeCheck- same format applies
+ */
+
+/*
+ * it-IT first/last name validity check
+ * Accepts it-IT TIN-encoded names as a three-element character array and checks their validity
+ * Due to lack of clarity between resources ("Are only Italian consonants used?
+ * What happens if a person has X in their name?" etc.) only two test conditions
+ * have been implemented:
+ * Vowels may only be followed by other vowels or an X character
+ * and X characters after vowels may only be followed by other X characters.
+ */
+
+
+function itItNameCheck(name) {
+ // true at the first occurence of a vowel
+ var vowelflag = false; // true at the first occurence of an X AFTER vowel
+ // (to properly handle last names with X as consonant)
+
+ var xflag = false;
+
+ for (var i = 0; i < 3; i++) {
+ if (!vowelflag && /[AEIOU]/.test(name[i])) {
+ vowelflag = true;
+ } else if (!xflag && vowelflag && name[i] === 'X') {
+ xflag = true;
+ } else if (i > 0) {
+ if (vowelflag && !xflag) {
+ if (!/[AEIOU]/.test(name[i])) {
+ return false;
+ }
+ }
+
+ if (xflag) {
+ if (!/X/.test(name[i])) {
+ return false;
+ }
+ }
+ }
+ }
+
+ return true;
+}
+/*
+ * it-IT validation function
+ * (Codice fiscale (TIN-IT), persons only)
+ * Verify name, birth date and codice catastale validity
+ * and calculate check character.
+ * Material not in DG-TAXUD document sourced from:
+ * `https://en.wikipedia.org/wiki/Italian_fiscal_code`
+ */
+
+
+function itItCheck(tin) {
+ // Capitalize and split characters into an array for further processing
+ var chars = tin.toUpperCase().split(''); // Check first and last name validity calling itItNameCheck()
+
+ if (!itItNameCheck(chars.slice(0, 3))) {
+ return false;
+ }
+
+ if (!itItNameCheck(chars.slice(3, 6))) {
+ return false;
+ } // Convert letters in number spaces back to numbers if any
+
+
+ var number_locations = [6, 7, 9, 10, 12, 13, 14];
+ var number_replace = {
+ L: '0',
+ M: '1',
+ N: '2',
+ P: '3',
+ Q: '4',
+ R: '5',
+ S: '6',
+ T: '7',
+ U: '8',
+ V: '9'
+ };
+
+ for (var _i4 = 0, _number_locations = number_locations; _i4 < _number_locations.length; _i4++) {
+ var i = _number_locations[_i4];
+
+ if (chars[i] in number_replace) {
+ chars.splice(i, 1, number_replace[chars[i]]);
+ }
+ } // Extract month and day, and check date validity
+
+
+ var month_replace = {
+ A: '01',
+ B: '02',
+ C: '03',
+ D: '04',
+ E: '05',
+ H: '06',
+ L: '07',
+ M: '08',
+ P: '09',
+ R: '10',
+ S: '11',
+ T: '12'
+ };
+ var month = month_replace[chars[8]];
+ var day = parseInt(chars[9] + chars[10], 10);
+
+ if (day > 40) {
+ day -= 40;
+ }
+
+ if (day < 10) {
+ day = "0".concat(day);
+ }
+
+ var date = "".concat(chars[6]).concat(chars[7], "/").concat(month, "/").concat(day);
+
+ if (!(0, _isDate.default)(date, 'YY/MM/DD')) {
+ return false;
+ } // Calculate check character by adding up even and odd characters as numbers
+
+
+ var checksum = 0;
+
+ for (var _i5 = 1; _i5 < chars.length - 1; _i5 += 2) {
+ var char_to_int = parseInt(chars[_i5], 10);
+
+ if (isNaN(char_to_int)) {
+ char_to_int = chars[_i5].charCodeAt(0) - 65;
+ }
+
+ checksum += char_to_int;
+ }
+
+ var odd_convert = {
+ // Maps of characters at odd places
+ A: 1,
+ B: 0,
+ C: 5,
+ D: 7,
+ E: 9,
+ F: 13,
+ G: 15,
+ H: 17,
+ I: 19,
+ J: 21,
+ K: 2,
+ L: 4,
+ M: 18,
+ N: 20,
+ O: 11,
+ P: 3,
+ Q: 6,
+ R: 8,
+ S: 12,
+ T: 14,
+ U: 16,
+ V: 10,
+ W: 22,
+ X: 25,
+ Y: 24,
+ Z: 23,
+ 0: 1,
+ 1: 0
+ };
+
+ for (var _i6 = 0; _i6 < chars.length - 1; _i6 += 2) {
+ var _char_to_int = 0;
+
+ if (chars[_i6] in odd_convert) {
+ _char_to_int = odd_convert[chars[_i6]];
+ } else {
+ var multiplier = parseInt(chars[_i6], 10);
+ _char_to_int = 2 * multiplier + 1;
+
+ if (multiplier > 4) {
+ _char_to_int += 2;
+ }
+ }
+
+ checksum += _char_to_int;
+ }
+
+ if (String.fromCharCode(65 + checksum % 26) !== chars[15]) {
+ return false;
+ }
+
+ return true;
+}
+/*
+ * lv-LV validation function
+ * (Personas kods (PK), persons only)
+ * Check validity of birth date and calculate check (last) digit
+ * Support only for old format numbers (not starting with '32', issued before 2017/07/01)
+ * Material not in DG TAXUD document sourced from:
+ * `https://boot.ritakafija.lv/forums/index.php?/topic/88314-personas-koda-algoritms-%C4%8Deksumma/`
+ */
+
+
+function lvLvCheck(tin) {
+ tin = tin.replace(/\W/, ''); // Extract date from TIN
+
+ var day = tin.slice(0, 2);
+
+ if (day !== '32') {
+ // No date/checksum check if new format
+ var month = tin.slice(2, 4);
+
+ if (month !== '00') {
+ // No date check if unknown month
+ var full_year = tin.slice(4, 6);
+
+ switch (tin[6]) {
+ case '0':
+ full_year = "18".concat(full_year);
+ break;
+
+ case '1':
+ full_year = "19".concat(full_year);
+ break;
+
+ default:
+ full_year = "20".concat(full_year);
+ break;
+ } // Check date validity
+
+
+ var date = "".concat(full_year, "/").concat(tin.slice(2, 4), "/").concat(day);
+
+ if (!(0, _isDate.default)(date, 'YYYY/MM/DD')) {
+ return false;
+ }
+ } // Calculate check digit
+
+
+ var checksum = 1101;
+ var multip_lookup = [1, 6, 3, 7, 9, 10, 5, 8, 4, 2];
+
+ for (var i = 0; i < tin.length - 1; i++) {
+ checksum -= parseInt(tin[i], 10) * multip_lookup[i];
+ }
+
+ return parseInt(tin[10], 10) === checksum % 11;
+ }
+
+ return true;
+}
+/*
+ * mt-MT validation function
+ * (Identity Card Number or Unique Taxpayer Reference, persons/entities)
+ * Verify Identity Card Number structure (no other tests found)
+ */
+
+
+function mtMtCheck(tin) {
+ if (tin.length !== 9) {
+ // No tests for UTR
+ var chars = tin.toUpperCase().split(''); // Fill with zeros if smaller than proper
+
+ while (chars.length < 8) {
+ chars.unshift(0);
+ } // Validate format according to last character
+
+
+ switch (tin[7]) {
+ case 'A':
+ case 'P':
+ if (parseInt(chars[6], 10) === 0) {
+ return false;
+ }
+
+ break;
+
+ default:
+ {
+ var first_part = parseInt(chars.join('').slice(0, 5), 10);
+
+ if (first_part > 32000) {
+ return false;
+ }
+
+ var second_part = parseInt(chars.join('').slice(5, 7), 10);
+
+ if (first_part === second_part) {
+ return false;
+ }
+ }
+ }
+ }
+
+ return true;
+}
+/*
+ * nl-NL validation function
+ * (Burgerservicenummer (BSN) or Rechtspersonen Samenwerkingsverbanden Informatie Nummer (RSIN),
+ * persons/entities respectively)
+ * Verify TIN validity by calculating check (last) digit (variant of MOD 11)
+ */
+
+
+function nlNlCheck(tin) {
+ return algorithms.reverseMultiplyAndSum(tin.split('').slice(0, 8).map(function (a) {
+ return parseInt(a, 10);
+ }), 9) % 11 === parseInt(tin[8], 10);
+}
+/*
+ * pl-PL validation function
+ * (Powszechny Elektroniczny System Ewidencji Ludności (PESEL)
+ * or Numer identyfikacji podatkowej (NIP), persons/entities)
+ * Verify TIN validity by validating birth date (PESEL) and calculating check (last) digit
+ */
+
+
+function plPlCheck(tin) {
+ // NIP
+ if (tin.length === 10) {
+ // Calculate last digit by multiplying with lookup
+ var lookup = [6, 5, 7, 2, 3, 4, 5, 6, 7];
+ var _checksum = 0;
+
+ for (var i = 0; i < lookup.length; i++) {
+ _checksum += parseInt(tin[i], 10) * lookup[i];
+ }
+
+ _checksum %= 11;
+
+ if (_checksum === 10) {
+ return false;
+ }
+
+ return _checksum === parseInt(tin[9], 10);
+ } // PESEL
+ // Extract full year using month
+
+
+ var full_year = tin.slice(0, 2);
+ var month = parseInt(tin.slice(2, 4), 10);
+
+ if (month > 80) {
+ full_year = "18".concat(full_year);
+ month -= 80;
+ } else if (month > 60) {
+ full_year = "22".concat(full_year);
+ month -= 60;
+ } else if (month > 40) {
+ full_year = "21".concat(full_year);
+ month -= 40;
+ } else if (month > 20) {
+ full_year = "20".concat(full_year);
+ month -= 20;
+ } else {
+ full_year = "19".concat(full_year);
+ } // Add leading zero to month if needed
+
+
+ if (month < 10) {
+ month = "0".concat(month);
+ } // Check date validity
+
+
+ var date = "".concat(full_year, "/").concat(month, "/").concat(tin.slice(4, 6));
+
+ if (!(0, _isDate.default)(date, 'YYYY/MM/DD')) {
+ return false;
+ } // Calculate last digit by mulitplying with odd one-digit numbers except 5
+
+
+ var checksum = 0;
+ var multiplier = 1;
+
+ for (var _i7 = 0; _i7 < tin.length - 1; _i7++) {
+ checksum += parseInt(tin[_i7], 10) * multiplier % 10;
+ multiplier += 2;
+
+ if (multiplier > 10) {
+ multiplier = 1;
+ } else if (multiplier === 5) {
+ multiplier += 2;
+ }
+ }
+
+ checksum = 10 - checksum % 10;
+ return checksum === parseInt(tin[10], 10);
+}
+/*
+* pt-BR validation function
+* (Cadastro de Pessoas Físicas (CPF, persons)
+* Cadastro Nacional de Pessoas Jurídicas (CNPJ, entities)
+* Both inputs will be validated
+*/
+
+
+function ptBrCheck(tin) {
+ if (tin.length === 11) {
+ var _sum;
+
+ var remainder;
+ _sum = 0;
+ if ( // Reject known invalid CPFs
+ tin === '11111111111' || tin === '22222222222' || tin === '33333333333' || tin === '44444444444' || tin === '55555555555' || tin === '66666666666' || tin === '77777777777' || tin === '88888888888' || tin === '99999999999' || tin === '00000000000') return false;
+
+ for (var i = 1; i <= 9; i++) {
+ _sum += parseInt(tin.substring(i - 1, i), 10) * (11 - i);
+ }
+
+ remainder = _sum * 10 % 11;
+ if (remainder === 10) remainder = 0;
+ if (remainder !== parseInt(tin.substring(9, 10), 10)) return false;
+ _sum = 0;
+
+ for (var _i8 = 1; _i8 <= 10; _i8++) {
+ _sum += parseInt(tin.substring(_i8 - 1, _i8), 10) * (12 - _i8);
+ }
+
+ remainder = _sum * 10 % 11;
+ if (remainder === 10) remainder = 0;
+ if (remainder !== parseInt(tin.substring(10, 11), 10)) return false;
+ return true;
+ }
+
+ if ( // Reject know invalid CNPJs
+ tin === '00000000000000' || tin === '11111111111111' || tin === '22222222222222' || tin === '33333333333333' || tin === '44444444444444' || tin === '55555555555555' || tin === '66666666666666' || tin === '77777777777777' || tin === '88888888888888' || tin === '99999999999999') {
+ return false;
+ }
+
+ var length = tin.length - 2;
+ var identifiers = tin.substring(0, length);
+ var verificators = tin.substring(length);
+ var sum = 0;
+ var pos = length - 7;
+
+ for (var _i9 = length; _i9 >= 1; _i9--) {
+ sum += identifiers.charAt(length - _i9) * pos;
+ pos -= 1;
+
+ if (pos < 2) {
+ pos = 9;
+ }
+ }
+
+ var result = sum % 11 < 2 ? 0 : 11 - sum % 11;
+
+ if (result !== parseInt(verificators.charAt(0), 10)) {
+ return false;
+ }
+
+ length += 1;
+ identifiers = tin.substring(0, length);
+ sum = 0;
+ pos = length - 7;
+
+ for (var _i10 = length; _i10 >= 1; _i10--) {
+ sum += identifiers.charAt(length - _i10) * pos;
+ pos -= 1;
+
+ if (pos < 2) {
+ pos = 9;
+ }
+ }
+
+ result = sum % 11 < 2 ? 0 : 11 - sum % 11;
+
+ if (result !== parseInt(verificators.charAt(1), 10)) {
+ return false;
+ }
+
+ return true;
+}
+/*
+ * pt-PT validation function
+ * (Número de identificação fiscal (NIF), persons/entities)
+ * Verify TIN validity by calculating check (last) digit (variant of MOD 11)
+ */
+
+
+function ptPtCheck(tin) {
+ var checksum = 11 - algorithms.reverseMultiplyAndSum(tin.split('').slice(0, 8).map(function (a) {
+ return parseInt(a, 10);
+ }), 9) % 11;
+
+ if (checksum > 9) {
+ return parseInt(tin[8], 10) === 0;
+ }
+
+ return checksum === parseInt(tin[8], 10);
+}
+/*
+ * ro-RO validation function
+ * (Cod Numeric Personal (CNP) or Cod de înregistrare fiscală (CIF),
+ * persons only)
+ * Verify CNP validity by calculating check (last) digit (test not found for CIF)
+ * Material not in DG TAXUD document sourced from:
+ * `https://en.wikipedia.org/wiki/National_identification_number#Romania`
+ */
+
+
+function roRoCheck(tin) {
+ if (tin.slice(0, 4) !== '9000') {
+ // No test found for this format
+ // Extract full year using century digit if possible
+ var full_year = tin.slice(1, 3);
+
+ switch (tin[0]) {
+ case '1':
+ case '2':
+ full_year = "19".concat(full_year);
+ break;
+
+ case '3':
+ case '4':
+ full_year = "18".concat(full_year);
+ break;
+
+ case '5':
+ case '6':
+ full_year = "20".concat(full_year);
+ break;
+
+ default:
+ } // Check date validity
+
+
+ var date = "".concat(full_year, "/").concat(tin.slice(3, 5), "/").concat(tin.slice(5, 7));
+
+ if (date.length === 8) {
+ if (!(0, _isDate.default)(date, 'YY/MM/DD')) {
+ return false;
+ }
+ } else if (!(0, _isDate.default)(date, 'YYYY/MM/DD')) {
+ return false;
+ } // Calculate check digit
+
+
+ var digits = tin.split('').map(function (a) {
+ return parseInt(a, 10);
+ });
+ var multipliers = [2, 7, 9, 1, 4, 6, 3, 5, 8, 2, 7, 9];
+ var checksum = 0;
+
+ for (var i = 0; i < multipliers.length; i++) {
+ checksum += digits[i] * multipliers[i];
+ }
+
+ if (checksum % 11 === 10) {
+ return digits[12] === 1;
+ }
+
+ return digits[12] === checksum % 11;
+ }
+
+ return true;
+}
+/*
+ * sk-SK validation function
+ * (Rodné číslo (RČ) or bezvýznamové identifikačné číslo (BIČ), persons only)
+ * Checks validity of pre-1954 birth numbers (rodné číslo) only
+ * Due to the introduction of the pseudo-random BIČ it is not possible to test
+ * post-1954 birth numbers without knowing whether they are BIČ or RČ beforehand
+ */
+
+
+function skSkCheck(tin) {
+ if (tin.length === 9) {
+ tin = tin.replace(/\W/, '');
+
+ if (tin.slice(6) === '000') {
+ return false;
+ } // Three-zero serial not assigned before 1954
+ // Extract full year from TIN length
+
+
+ var full_year = parseInt(tin.slice(0, 2), 10);
+
+ if (full_year > 53) {
+ return false;
+ }
+
+ if (full_year < 10) {
+ full_year = "190".concat(full_year);
+ } else {
+ full_year = "19".concat(full_year);
+ } // Extract month from TIN and normalize
+
+
+ var month = parseInt(tin.slice(2, 4), 10);
+
+ if (month > 50) {
+ month -= 50;
+ }
+
+ if (month < 10) {
+ month = "0".concat(month);
+ } // Check date validity
+
+
+ var date = "".concat(full_year, "/").concat(month, "/").concat(tin.slice(4, 6));
+
+ if (!(0, _isDate.default)(date, 'YYYY/MM/DD')) {
+ return false;
+ }
+ }
+
+ return true;
+}
+/*
+ * sl-SI validation function
+ * (Davčna številka, persons/entities)
+ * Verify TIN validity by calculating check (last) digit (variant of MOD 11)
+ */
+
+
+function slSiCheck(tin) {
+ var checksum = 11 - algorithms.reverseMultiplyAndSum(tin.split('').slice(0, 7).map(function (a) {
+ return parseInt(a, 10);
+ }), 8) % 11;
+
+ if (checksum === 10) {
+ return parseInt(tin[7], 10) === 0;
+ }
+
+ return checksum === parseInt(tin[7], 10);
+}
+/*
+ * sv-SE validation function
+ * (Personnummer or samordningsnummer, persons only)
+ * Checks validity of birth date and calls luhnCheck() to validate check (last) digit
+ */
+
+
+function svSeCheck(tin) {
+ // Make copy of TIN and normalize to two-digit year form
+ var tin_copy = tin.slice(0);
+
+ if (tin.length > 11) {
+ tin_copy = tin_copy.slice(2);
+ } // Extract date of birth
+
+
+ var full_year = '';
+ var month = tin_copy.slice(2, 4);
+ var day = parseInt(tin_copy.slice(4, 6), 10);
+
+ if (tin.length > 11) {
+ full_year = tin.slice(0, 4);
+ } else {
+ full_year = tin.slice(0, 2);
+
+ if (tin.length === 11 && day < 60) {
+ // Extract full year from centenarian symbol
+ // Should work just fine until year 10000 or so
+ var current_year = new Date().getFullYear().toString();
+ var current_century = parseInt(current_year.slice(0, 2), 10);
+ current_year = parseInt(current_year, 10);
+
+ if (tin[6] === '-') {
+ if (parseInt("".concat(current_century).concat(full_year), 10) > current_year) {
+ full_year = "".concat(current_century - 1).concat(full_year);
+ } else {
+ full_year = "".concat(current_century).concat(full_year);
+ }
+ } else {
+ full_year = "".concat(current_century - 1).concat(full_year);
+
+ if (current_year - parseInt(full_year, 10) < 100) {
+ return false;
+ }
+ }
+ }
+ } // Normalize day and check date validity
+
+
+ if (day > 60) {
+ day -= 60;
+ }
+
+ if (day < 10) {
+ day = "0".concat(day);
+ }
+
+ var date = "".concat(full_year, "/").concat(month, "/").concat(day);
+
+ if (date.length === 8) {
+ if (!(0, _isDate.default)(date, 'YY/MM/DD')) {
+ return false;
+ }
+ } else if (!(0, _isDate.default)(date, 'YYYY/MM/DD')) {
+ return false;
+ }
+
+ return algorithms.luhnCheck(tin.replace(/\W/, ''));
+} // Locale lookup objects
+
+/*
+ * Tax id regex formats for various locales
+ *
+ * Where not explicitly specified in DG-TAXUD document both
+ * uppercase and lowercase letters are acceptable.
+ */
+
+
+var taxIdFormat = {
+ 'bg-BG': /^\d{10}$/,
+ 'cs-CZ': /^\d{6}\/{0,1}\d{3,4}$/,
+ 'de-AT': /^\d{9}$/,
+ 'de-DE': /^[1-9]\d{10}$/,
+ 'dk-DK': /^\d{6}-{0,1}\d{4}$/,
+ 'el-CY': /^[09]\d{7}[A-Z]$/,
+ 'el-GR': /^([0-4]|[7-9])\d{8}$/,
+ 'en-CA': /^\d{9}$/,
+ 'en-GB': /^\d{10}$|^(?!GB|NK|TN|ZZ)(?![DFIQUV])[A-Z](?![DFIQUVO])[A-Z]\d{6}[ABCD ]$/i,
+ 'en-IE': /^\d{7}[A-W][A-IW]{0,1}$/i,
+ 'en-US': /^\d{2}[- ]{0,1}\d{7}$/,
+ 'es-ES': /^(\d{0,8}|[XYZKLM]\d{7})[A-HJ-NP-TV-Z]$/i,
+ 'et-EE': /^[1-6]\d{6}(00[1-9]|0[1-9][0-9]|[1-6][0-9]{2}|70[0-9]|710)\d$/,
+ 'fi-FI': /^\d{6}[-+A]\d{3}[0-9A-FHJ-NPR-Y]$/i,
+ 'fr-BE': /^\d{11}$/,
+ 'fr-FR': /^[0-3]\d{12}$|^[0-3]\d\s\d{2}(\s\d{3}){3}$/,
+ // Conforms both to official spec and provided example
+ 'fr-LU': /^\d{13}$/,
+ 'hr-HR': /^\d{11}$/,
+ 'hu-HU': /^8\d{9}$/,
+ 'it-IT': /^[A-Z]{6}[L-NP-V0-9]{2}[A-EHLMPRST][L-NP-V0-9]{2}[A-ILMZ][L-NP-V0-9]{3}[A-Z]$/i,
+ 'lv-LV': /^\d{6}-{0,1}\d{5}$/,
+ // Conforms both to DG TAXUD spec and original research
+ 'mt-MT': /^\d{3,7}[APMGLHBZ]$|^([1-8])\1\d{7}$/i,
+ 'nl-NL': /^\d{9}$/,
+ 'pl-PL': /^\d{10,11}$/,
+ 'pt-BR': /(?:^\d{11}$)|(?:^\d{14}$)/,
+ 'pt-PT': /^\d{9}$/,
+ 'ro-RO': /^\d{13}$/,
+ 'sk-SK': /^\d{6}\/{0,1}\d{3,4}$/,
+ 'sl-SI': /^[1-9]\d{7}$/,
+ 'sv-SE': /^(\d{6}[-+]{0,1}\d{4}|(18|19|20)\d{6}[-+]{0,1}\d{4})$/
+}; // taxIdFormat locale aliases
+
+taxIdFormat['lb-LU'] = taxIdFormat['fr-LU'];
+taxIdFormat['lt-LT'] = taxIdFormat['et-EE'];
+taxIdFormat['nl-BE'] = taxIdFormat['fr-BE'];
+taxIdFormat['fr-CA'] = taxIdFormat['en-CA']; // Algorithmic tax id check functions for various locales
+
+var taxIdCheck = {
+ 'bg-BG': bgBgCheck,
+ 'cs-CZ': csCzCheck,
+ 'de-AT': deAtCheck,
+ 'de-DE': deDeCheck,
+ 'dk-DK': dkDkCheck,
+ 'el-CY': elCyCheck,
+ 'el-GR': elGrCheck,
+ 'en-CA': isCanadianSIN,
+ 'en-IE': enIeCheck,
+ 'en-US': enUsCheck,
+ 'es-ES': esEsCheck,
+ 'et-EE': etEeCheck,
+ 'fi-FI': fiFiCheck,
+ 'fr-BE': frBeCheck,
+ 'fr-FR': frFrCheck,
+ 'fr-LU': frLuCheck,
+ 'hr-HR': hrHrCheck,
+ 'hu-HU': huHuCheck,
+ 'it-IT': itItCheck,
+ 'lv-LV': lvLvCheck,
+ 'mt-MT': mtMtCheck,
+ 'nl-NL': nlNlCheck,
+ 'pl-PL': plPlCheck,
+ 'pt-BR': ptBrCheck,
+ 'pt-PT': ptPtCheck,
+ 'ro-RO': roRoCheck,
+ 'sk-SK': skSkCheck,
+ 'sl-SI': slSiCheck,
+ 'sv-SE': svSeCheck
+}; // taxIdCheck locale aliases
+
+taxIdCheck['lb-LU'] = taxIdCheck['fr-LU'];
+taxIdCheck['lt-LT'] = taxIdCheck['et-EE'];
+taxIdCheck['nl-BE'] = taxIdCheck['fr-BE'];
+taxIdCheck['fr-CA'] = taxIdCheck['en-CA']; // Regexes for locales where characters should be omitted before checking format
+
+var allsymbols = /[-\\\/!@#$%\^&\*\(\)\+\=\[\]]+/g;
+var sanitizeRegexes = {
+ 'de-AT': allsymbols,
+ 'de-DE': /[\/\\]/g,
+ 'fr-BE': allsymbols
+}; // sanitizeRegexes locale aliases
+
+sanitizeRegexes['nl-BE'] = sanitizeRegexes['fr-BE'];
+/*
+ * Validator function
+ * Return true if the passed string is a valid tax identification number
+ * for the specified locale.
+ * Throw an error exception if the locale is not supported.
+ */
+
+function isTaxID(str) {
+ var locale = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'en-US';
+ (0, _assertString.default)(str); // Copy TIN to avoid replacement if sanitized
+
+ var strcopy = str.slice(0);
+
+ if (locale in taxIdFormat) {
+ if (locale in sanitizeRegexes) {
+ strcopy = strcopy.replace(sanitizeRegexes[locale], '');
+ }
+
+ if (!taxIdFormat[locale].test(strcopy)) {
+ return false;
+ }
+
+ if (locale in taxIdCheck) {
+ return taxIdCheck[locale](strcopy);
+ } // Fallthrough; not all locales have algorithmic checks
+
+
+ return true;
+ }
+
+ throw new Error("Invalid locale '".concat(locale, "'"));
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isTime.js b/includes/external/addressbook/node_modules/validator/lib/isTime.js
new file mode 100644
index 0000000..a2e8d1f
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isTime.js
@@ -0,0 +1,34 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isTime;
+
+var _merge = _interopRequireDefault(require("./util/merge"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var default_time_options = {
+ hourFormat: 'hour24',
+ mode: 'default'
+};
+var formats = {
+ hour24: {
+ default: /^([01]?[0-9]|2[0-3]):([0-5][0-9])$/,
+ withSeconds: /^([01]?[0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])$/
+ },
+ hour12: {
+ default: /^(0?[1-9]|1[0-2]):([0-5][0-9]) (A|P)M$/,
+ withSeconds: /^(0?[1-9]|1[0-2]):([0-5][0-9]):([0-5][0-9]) (A|P)M$/
+ }
+};
+
+function isTime(input, options) {
+ options = (0, _merge.default)(options, default_time_options);
+ if (typeof input !== 'string') return false;
+ return formats[options.hourFormat][options.mode].test(input);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isURL.js b/includes/external/addressbook/node_modules/validator/lib/isURL.js
new file mode 100644
index 0000000..5351c5b
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isURL.js
@@ -0,0 +1,212 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isURL;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var _isFQDN = _interopRequireDefault(require("./isFQDN"));
+
+var _isIP = _interopRequireDefault(require("./isIP"));
+
+var _merge = _interopRequireDefault(require("./util/merge"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
+
+function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
+
+function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
+
+function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
+
+function _iterableToArrayLimit(arr, i) { if (typeof Symbol === "undefined" || !(Symbol.iterator in Object(arr))) return; var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
+
+function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
+
+/*
+options for isURL method
+
+require_protocol - if set as true isURL will return false if protocol is not present in the URL
+require_valid_protocol - isURL will check if the URL's protocol is present in the protocols option
+protocols - valid protocols can be modified with this option
+require_host - if set as false isURL will not check if host is present in the URL
+require_port - if set as true isURL will check if port is present in the URL
+allow_protocol_relative_urls - if set as true protocol relative URLs will be allowed
+validate_length - if set as false isURL will skip string length validation (IE maximum is 2083)
+
+*/
+var default_url_options = {
+ protocols: ['http', 'https', 'ftp'],
+ require_tld: true,
+ require_protocol: false,
+ require_host: true,
+ require_port: false,
+ require_valid_protocol: true,
+ allow_underscores: false,
+ allow_trailing_dot: false,
+ allow_protocol_relative_urls: false,
+ allow_fragments: true,
+ allow_query_components: true,
+ validate_length: true
+};
+var wrapped_ipv6 = /^\[([^\]]+)\](?::([0-9]+))?$/;
+
+function isRegExp(obj) {
+ return Object.prototype.toString.call(obj) === '[object RegExp]';
+}
+
+function checkHost(host, matches) {
+ for (var i = 0; i < matches.length; i++) {
+ var match = matches[i];
+
+ if (host === match || isRegExp(match) && match.test(host)) {
+ return true;
+ }
+ }
+
+ return false;
+}
+
+function isURL(url, options) {
+ (0, _assertString.default)(url);
+
+ if (!url || /[\s<>]/.test(url)) {
+ return false;
+ }
+
+ if (url.indexOf('mailto:') === 0) {
+ return false;
+ }
+
+ options = (0, _merge.default)(options, default_url_options);
+
+ if (options.validate_length && url.length >= 2083) {
+ return false;
+ }
+
+ if (!options.allow_fragments && url.includes('#')) {
+ return false;
+ }
+
+ if (!options.allow_query_components && (url.includes('?') || url.includes('&'))) {
+ return false;
+ }
+
+ var protocol, auth, host, hostname, port, port_str, split, ipv6;
+ split = url.split('#');
+ url = split.shift();
+ split = url.split('?');
+ url = split.shift();
+ split = url.split('://');
+
+ if (split.length > 1) {
+ protocol = split.shift().toLowerCase();
+
+ if (options.require_valid_protocol && options.protocols.indexOf(protocol) === -1) {
+ return false;
+ }
+ } else if (options.require_protocol) {
+ return false;
+ } else if (url.slice(0, 2) === '//') {
+ if (!options.allow_protocol_relative_urls) {
+ return false;
+ }
+
+ split[0] = url.slice(2);
+ }
+
+ url = split.join('://');
+
+ if (url === '') {
+ return false;
+ }
+
+ split = url.split('/');
+ url = split.shift();
+
+ if (url === '' && !options.require_host) {
+ return true;
+ }
+
+ split = url.split('@');
+
+ if (split.length > 1) {
+ if (options.disallow_auth) {
+ return false;
+ }
+
+ if (split[0] === '') {
+ return false;
+ }
+
+ auth = split.shift();
+
+ if (auth.indexOf(':') >= 0 && auth.split(':').length > 2) {
+ return false;
+ }
+
+ var _auth$split = auth.split(':'),
+ _auth$split2 = _slicedToArray(_auth$split, 2),
+ user = _auth$split2[0],
+ password = _auth$split2[1];
+
+ if (user === '' && password === '') {
+ return false;
+ }
+ }
+
+ hostname = split.join('@');
+ port_str = null;
+ ipv6 = null;
+ var ipv6_match = hostname.match(wrapped_ipv6);
+
+ if (ipv6_match) {
+ host = '';
+ ipv6 = ipv6_match[1];
+ port_str = ipv6_match[2] || null;
+ } else {
+ split = hostname.split(':');
+ host = split.shift();
+
+ if (split.length) {
+ port_str = split.join(':');
+ }
+ }
+
+ if (port_str !== null && port_str.length > 0) {
+ port = parseInt(port_str, 10);
+
+ if (!/^[0-9]+$/.test(port_str) || port <= 0 || port > 65535) {
+ return false;
+ }
+ } else if (options.require_port) {
+ return false;
+ }
+
+ if (options.host_whitelist) {
+ return checkHost(host, options.host_whitelist);
+ }
+
+ if (host === '' && !options.require_host) {
+ return true;
+ }
+
+ if (!(0, _isIP.default)(host) && !(0, _isFQDN.default)(host, options) && (!ipv6 || !(0, _isIP.default)(ipv6, 6))) {
+ return false;
+ }
+
+ host = host || ipv6;
+
+ if (options.host_blacklist && checkHost(host, options.host_blacklist)) {
+ return false;
+ }
+
+ return true;
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isUUID.js b/includes/external/addressbook/node_modules/validator/lib/isUUID.js
new file mode 100644
index 0000000..f2fdc79
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isUUID.js
@@ -0,0 +1,28 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isUUID;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var uuid = {
+ 1: /^[0-9A-F]{8}-[0-9A-F]{4}-1[0-9A-F]{3}-[0-9A-F]{4}-[0-9A-F]{12}$/i,
+ 2: /^[0-9A-F]{8}-[0-9A-F]{4}-2[0-9A-F]{3}-[0-9A-F]{4}-[0-9A-F]{12}$/i,
+ 3: /^[0-9A-F]{8}-[0-9A-F]{4}-3[0-9A-F]{3}-[0-9A-F]{4}-[0-9A-F]{12}$/i,
+ 4: /^[0-9A-F]{8}-[0-9A-F]{4}-4[0-9A-F]{3}-[89AB][0-9A-F]{3}-[0-9A-F]{12}$/i,
+ 5: /^[0-9A-F]{8}-[0-9A-F]{4}-5[0-9A-F]{3}-[89AB][0-9A-F]{3}-[0-9A-F]{12}$/i,
+ all: /^[0-9A-F]{8}-[0-9A-F]{4}-[0-9A-F]{4}-[0-9A-F]{4}-[0-9A-F]{12}$/i
+};
+
+function isUUID(str, version) {
+ (0, _assertString.default)(str);
+ var pattern = uuid[![undefined, null].includes(version) ? version : 'all'];
+ return !!pattern && pattern.test(str);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isUppercase.js b/includes/external/addressbook/node_modules/validator/lib/isUppercase.js
new file mode 100644
index 0000000..c1c02f9
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isUppercase.js
@@ -0,0 +1,18 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isUppercase;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function isUppercase(str) {
+ (0, _assertString.default)(str);
+ return str === str.toUpperCase();
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isVAT.js b/includes/external/addressbook/node_modules/validator/lib/isVAT.js
new file mode 100644
index 0000000..ce73e09
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isVAT.js
@@ -0,0 +1,266 @@
+"use strict";
+
+function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isVAT;
+exports.vatMatchers = void 0;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var algorithms = _interopRequireWildcard(require("./util/algorithms"));
+
+function _getRequireWildcardCache() { if (typeof WeakMap !== "function") return null; var cache = new WeakMap(); _getRequireWildcardCache = function _getRequireWildcardCache() { return cache; }; return cache; }
+
+function _interopRequireWildcard(obj) { if (obj && obj.__esModule) { return obj; } if (obj === null || _typeof(obj) !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var PT = function PT(str) {
+ var match = str.match(/^(PT)?(\d{9})$/);
+
+ if (!match) {
+ return false;
+ }
+
+ var tin = match[2];
+ var checksum = 11 - algorithms.reverseMultiplyAndSum(tin.split('').slice(0, 8).map(function (a) {
+ return parseInt(a, 10);
+ }), 9) % 11;
+
+ if (checksum > 9) {
+ return parseInt(tin[8], 10) === 0;
+ }
+
+ return checksum === parseInt(tin[8], 10);
+};
+
+var vatMatchers = {
+ /**
+ * European Union VAT identification numbers
+ */
+ AT: function AT(str) {
+ return /^(AT)?U\d{8}$/.test(str);
+ },
+ BE: function BE(str) {
+ return /^(BE)?\d{10}$/.test(str);
+ },
+ BG: function BG(str) {
+ return /^(BG)?\d{9,10}$/.test(str);
+ },
+ HR: function HR(str) {
+ return /^(HR)?\d{11}$/.test(str);
+ },
+ CY: function CY(str) {
+ return /^(CY)?\w{9}$/.test(str);
+ },
+ CZ: function CZ(str) {
+ return /^(CZ)?\d{8,10}$/.test(str);
+ },
+ DK: function DK(str) {
+ return /^(DK)?\d{8}$/.test(str);
+ },
+ EE: function EE(str) {
+ return /^(EE)?\d{9}$/.test(str);
+ },
+ FI: function FI(str) {
+ return /^(FI)?\d{8}$/.test(str);
+ },
+ FR: function FR(str) {
+ return /^(FR)?\w{2}\d{9}$/.test(str);
+ },
+ DE: function DE(str) {
+ return /^(DE)?\d{9}$/.test(str);
+ },
+ EL: function EL(str) {
+ return /^(EL)?\d{9}$/.test(str);
+ },
+ HU: function HU(str) {
+ return /^(HU)?\d{8}$/.test(str);
+ },
+ IE: function IE(str) {
+ return /^(IE)?\d{7}\w{1}(W)?$/.test(str);
+ },
+ IT: function IT(str) {
+ return /^(IT)?\d{11}$/.test(str);
+ },
+ LV: function LV(str) {
+ return /^(LV)?\d{11}$/.test(str);
+ },
+ LT: function LT(str) {
+ return /^(LT)?\d{9,12}$/.test(str);
+ },
+ LU: function LU(str) {
+ return /^(LU)?\d{8}$/.test(str);
+ },
+ MT: function MT(str) {
+ return /^(MT)?\d{8}$/.test(str);
+ },
+ NL: function NL(str) {
+ return /^(NL)?\d{9}B\d{2}$/.test(str);
+ },
+ PL: function PL(str) {
+ return /^(PL)?(\d{10}|(\d{3}-\d{3}-\d{2}-\d{2})|(\d{3}-\d{2}-\d{2}-\d{3}))$/.test(str);
+ },
+ PT: PT,
+ RO: function RO(str) {
+ return /^(RO)?\d{2,10}$/.test(str);
+ },
+ SK: function SK(str) {
+ return /^(SK)?\d{10}$/.test(str);
+ },
+ SI: function SI(str) {
+ return /^(SI)?\d{8}$/.test(str);
+ },
+ ES: function ES(str) {
+ return /^(ES)?\w\d{7}[A-Z]$/.test(str);
+ },
+ SE: function SE(str) {
+ return /^(SE)?\d{12}$/.test(str);
+ },
+
+ /**
+ * VAT numbers of non-EU countries
+ */
+ AL: function AL(str) {
+ return /^(AL)?\w{9}[A-Z]$/.test(str);
+ },
+ MK: function MK(str) {
+ return /^(MK)?\d{13}$/.test(str);
+ },
+ AU: function AU(str) {
+ return /^(AU)?\d{11}$/.test(str);
+ },
+ BY: function BY(str) {
+ return /^(УНП )?\d{9}$/.test(str);
+ },
+ CA: function CA(str) {
+ return /^(CA)?\d{9}$/.test(str);
+ },
+ IS: function IS(str) {
+ return /^(IS)?\d{5,6}$/.test(str);
+ },
+ IN: function IN(str) {
+ return /^(IN)?\d{15}$/.test(str);
+ },
+ ID: function ID(str) {
+ return /^(ID)?(\d{15}|(\d{2}.\d{3}.\d{3}.\d{1}-\d{3}.\d{3}))$/.test(str);
+ },
+ IL: function IL(str) {
+ return /^(IL)?\d{9}$/.test(str);
+ },
+ KZ: function KZ(str) {
+ return /^(KZ)?\d{9}$/.test(str);
+ },
+ NZ: function NZ(str) {
+ return /^(NZ)?\d{9}$/.test(str);
+ },
+ NG: function NG(str) {
+ return /^(NG)?(\d{12}|(\d{8}-\d{4}))$/.test(str);
+ },
+ NO: function NO(str) {
+ return /^(NO)?\d{9}MVA$/.test(str);
+ },
+ PH: function PH(str) {
+ return /^(PH)?(\d{12}|\d{3} \d{3} \d{3} \d{3})$/.test(str);
+ },
+ RU: function RU(str) {
+ return /^(RU)?(\d{10}|\d{12})$/.test(str);
+ },
+ SM: function SM(str) {
+ return /^(SM)?\d{5}$/.test(str);
+ },
+ SA: function SA(str) {
+ return /^(SA)?\d{15}$/.test(str);
+ },
+ RS: function RS(str) {
+ return /^(RS)?\d{9}$/.test(str);
+ },
+ CH: function CH(str) {
+ return /^(CH)?(\d{6}|\d{9}|(\d{3}.\d{3})|(\d{3}.\d{3}.\d{3}))(TVA|MWST|IVA)$/.test(str);
+ },
+ TR: function TR(str) {
+ return /^(TR)?\d{10}$/.test(str);
+ },
+ UA: function UA(str) {
+ return /^(UA)?\d{12}$/.test(str);
+ },
+ GB: function GB(str) {
+ return /^GB((\d{3} \d{4} ([0-8][0-9]|9[0-6]))|(\d{9} \d{3})|(((GD[0-4])|(HA[5-9]))[0-9]{2}))$/.test(str);
+ },
+ UZ: function UZ(str) {
+ return /^(UZ)?\d{9}$/.test(str);
+ },
+
+ /**
+ * VAT numbers of Latin American countries
+ */
+ AR: function AR(str) {
+ return /^(AR)?\d{11}$/.test(str);
+ },
+ BO: function BO(str) {
+ return /^(BO)?\d{7}$/.test(str);
+ },
+ BR: function BR(str) {
+ return /^(BR)?((\d{2}.\d{3}.\d{3}\/\d{4}-\d{2})|(\d{3}.\d{3}.\d{3}-\d{2}))$/.test(str);
+ },
+ CL: function CL(str) {
+ return /^(CL)?\d{8}-\d{1}$/.test(str);
+ },
+ CO: function CO(str) {
+ return /^(CO)?\d{10}$/.test(str);
+ },
+ CR: function CR(str) {
+ return /^(CR)?\d{9,12}$/.test(str);
+ },
+ EC: function EC(str) {
+ return /^(EC)?\d{13}$/.test(str);
+ },
+ SV: function SV(str) {
+ return /^(SV)?\d{4}-\d{6}-\d{3}-\d{1}$/.test(str);
+ },
+ GT: function GT(str) {
+ return /^(GT)?\d{7}-\d{1}$/.test(str);
+ },
+ HN: function HN(str) {
+ return /^(HN)?$/.test(str);
+ },
+ MX: function MX(str) {
+ return /^(MX)?\w{3,4}\d{6}\w{3}$/.test(str);
+ },
+ NI: function NI(str) {
+ return /^(NI)?\d{3}-\d{6}-\d{4}\w{1}$/.test(str);
+ },
+ PA: function PA(str) {
+ return /^(PA)?$/.test(str);
+ },
+ PY: function PY(str) {
+ return /^(PY)?\d{6,8}-\d{1}$/.test(str);
+ },
+ PE: function PE(str) {
+ return /^(PE)?\d{11}$/.test(str);
+ },
+ DO: function DO(str) {
+ return /^(DO)?(\d{11}|(\d{3}-\d{7}-\d{1})|[1,4,5]{1}\d{8}|([1,4,5]{1})-\d{2}-\d{5}-\d{1})$/.test(str);
+ },
+ UY: function UY(str) {
+ return /^(UY)?\d{12}$/.test(str);
+ },
+ VE: function VE(str) {
+ return /^(VE)?[J,G,V,E]{1}-(\d{9}|(\d{8}-\d{1}))$/.test(str);
+ }
+};
+exports.vatMatchers = vatMatchers;
+
+function isVAT(str, countryCode) {
+ (0, _assertString.default)(str);
+ (0, _assertString.default)(countryCode);
+
+ if (countryCode in vatMatchers) {
+ return vatMatchers[countryCode](str);
+ }
+
+ throw new Error("Invalid country code: '".concat(countryCode, "'"));
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isVariableWidth.js b/includes/external/addressbook/node_modules/validator/lib/isVariableWidth.js
new file mode 100644
index 0000000..6bf226e
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isVariableWidth.js
@@ -0,0 +1,22 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isVariableWidth;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var _isFullWidth = require("./isFullWidth");
+
+var _isHalfWidth = require("./isHalfWidth");
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function isVariableWidth(str) {
+ (0, _assertString.default)(str);
+ return _isFullWidth.fullWidth.test(str) && _isHalfWidth.halfWidth.test(str);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/isWhitelisted.js b/includes/external/addressbook/node_modules/validator/lib/isWhitelisted.js
new file mode 100644
index 0000000..5a80a1b
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/isWhitelisted.js
@@ -0,0 +1,25 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = isWhitelisted;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function isWhitelisted(str, chars) {
+ (0, _assertString.default)(str);
+
+ for (var i = str.length - 1; i >= 0; i--) {
+ if (chars.indexOf(str[i]) === -1) {
+ return false;
+ }
+ }
+
+ return true;
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/ltrim.js b/includes/external/addressbook/node_modules/validator/lib/ltrim.js
new file mode 100644
index 0000000..fc39160
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/ltrim.js
@@ -0,0 +1,20 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = ltrim;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function ltrim(str, chars) {
+ (0, _assertString.default)(str); // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions#Escaping
+
+ var pattern = chars ? new RegExp("^[".concat(chars.replace(/[.*+?^${}()|[\]\\]/g, '\\$&'), "]+"), 'g') : /^\s+/g;
+ return str.replace(pattern, '');
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/matches.js b/includes/external/addressbook/node_modules/validator/lib/matches.js
new file mode 100644
index 0000000..4593a57
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/matches.js
@@ -0,0 +1,23 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = matches;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function matches(str, pattern, modifiers) {
+ (0, _assertString.default)(str);
+
+ if (Object.prototype.toString.call(pattern) !== '[object RegExp]') {
+ pattern = new RegExp(pattern, modifiers);
+ }
+
+ return !!str.match(pattern);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/normalizeEmail.js b/includes/external/addressbook/node_modules/validator/lib/normalizeEmail.js
new file mode 100644
index 0000000..990f431
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/normalizeEmail.js
@@ -0,0 +1,151 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = normalizeEmail;
+
+var _merge = _interopRequireDefault(require("./util/merge"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+var default_normalize_email_options = {
+ // The following options apply to all email addresses
+ // Lowercases the local part of the email address.
+ // Please note this may violate RFC 5321 as per http://stackoverflow.com/a/9808332/192024).
+ // The domain is always lowercased, as per RFC 1035
+ all_lowercase: true,
+ // The following conversions are specific to GMail
+ // Lowercases the local part of the GMail address (known to be case-insensitive)
+ gmail_lowercase: true,
+ // Removes dots from the local part of the email address, as that's ignored by GMail
+ gmail_remove_dots: true,
+ // Removes the subaddress (e.g. "+foo") from the email address
+ gmail_remove_subaddress: true,
+ // Conversts the googlemail.com domain to gmail.com
+ gmail_convert_googlemaildotcom: true,
+ // The following conversions are specific to Outlook.com / Windows Live / Hotmail
+ // Lowercases the local part of the Outlook.com address (known to be case-insensitive)
+ outlookdotcom_lowercase: true,
+ // Removes the subaddress (e.g. "+foo") from the email address
+ outlookdotcom_remove_subaddress: true,
+ // The following conversions are specific to Yahoo
+ // Lowercases the local part of the Yahoo address (known to be case-insensitive)
+ yahoo_lowercase: true,
+ // Removes the subaddress (e.g. "-foo") from the email address
+ yahoo_remove_subaddress: true,
+ // The following conversions are specific to Yandex
+ // Lowercases the local part of the Yandex address (known to be case-insensitive)
+ yandex_lowercase: true,
+ // The following conversions are specific to iCloud
+ // Lowercases the local part of the iCloud address (known to be case-insensitive)
+ icloud_lowercase: true,
+ // Removes the subaddress (e.g. "+foo") from the email address
+ icloud_remove_subaddress: true
+}; // List of domains used by iCloud
+
+var icloud_domains = ['icloud.com', 'me.com']; // List of domains used by Outlook.com and its predecessors
+// This list is likely incomplete.
+// Partial reference:
+// https://blogs.office.com/2013/04/17/outlook-com-gets-two-step-verification-sign-in-by-alias-and-new-international-domains/
+
+var outlookdotcom_domains = ['hotmail.at', 'hotmail.be', 'hotmail.ca', 'hotmail.cl', 'hotmail.co.il', 'hotmail.co.nz', 'hotmail.co.th', 'hotmail.co.uk', 'hotmail.com', 'hotmail.com.ar', 'hotmail.com.au', 'hotmail.com.br', 'hotmail.com.gr', 'hotmail.com.mx', 'hotmail.com.pe', 'hotmail.com.tr', 'hotmail.com.vn', 'hotmail.cz', 'hotmail.de', 'hotmail.dk', 'hotmail.es', 'hotmail.fr', 'hotmail.hu', 'hotmail.id', 'hotmail.ie', 'hotmail.in', 'hotmail.it', 'hotmail.jp', 'hotmail.kr', 'hotmail.lv', 'hotmail.my', 'hotmail.ph', 'hotmail.pt', 'hotmail.sa', 'hotmail.sg', 'hotmail.sk', 'live.be', 'live.co.uk', 'live.com', 'live.com.ar', 'live.com.mx', 'live.de', 'live.es', 'live.eu', 'live.fr', 'live.it', 'live.nl', 'msn.com', 'outlook.at', 'outlook.be', 'outlook.cl', 'outlook.co.il', 'outlook.co.nz', 'outlook.co.th', 'outlook.com', 'outlook.com.ar', 'outlook.com.au', 'outlook.com.br', 'outlook.com.gr', 'outlook.com.pe', 'outlook.com.tr', 'outlook.com.vn', 'outlook.cz', 'outlook.de', 'outlook.dk', 'outlook.es', 'outlook.fr', 'outlook.hu', 'outlook.id', 'outlook.ie', 'outlook.in', 'outlook.it', 'outlook.jp', 'outlook.kr', 'outlook.lv', 'outlook.my', 'outlook.ph', 'outlook.pt', 'outlook.sa', 'outlook.sg', 'outlook.sk', 'passport.com']; // List of domains used by Yahoo Mail
+// This list is likely incomplete
+
+var yahoo_domains = ['rocketmail.com', 'yahoo.ca', 'yahoo.co.uk', 'yahoo.com', 'yahoo.de', 'yahoo.fr', 'yahoo.in', 'yahoo.it', 'ymail.com']; // List of domains used by yandex.ru
+
+var yandex_domains = ['yandex.ru', 'yandex.ua', 'yandex.kz', 'yandex.com', 'yandex.by', 'ya.ru']; // replace single dots, but not multiple consecutive dots
+
+function dotsReplacer(match) {
+ if (match.length > 1) {
+ return match;
+ }
+
+ return '';
+}
+
+function normalizeEmail(email, options) {
+ options = (0, _merge.default)(options, default_normalize_email_options);
+ var raw_parts = email.split('@');
+ var domain = raw_parts.pop();
+ var user = raw_parts.join('@');
+ var parts = [user, domain]; // The domain is always lowercased, as it's case-insensitive per RFC 1035
+
+ parts[1] = parts[1].toLowerCase();
+
+ if (parts[1] === 'gmail.com' || parts[1] === 'googlemail.com') {
+ // Address is GMail
+ if (options.gmail_remove_subaddress) {
+ parts[0] = parts[0].split('+')[0];
+ }
+
+ if (options.gmail_remove_dots) {
+ // this does not replace consecutive dots like example..email@gmail.com
+ parts[0] = parts[0].replace(/\.+/g, dotsReplacer);
+ }
+
+ if (!parts[0].length) {
+ return false;
+ }
+
+ if (options.all_lowercase || options.gmail_lowercase) {
+ parts[0] = parts[0].toLowerCase();
+ }
+
+ parts[1] = options.gmail_convert_googlemaildotcom ? 'gmail.com' : parts[1];
+ } else if (icloud_domains.indexOf(parts[1]) >= 0) {
+ // Address is iCloud
+ if (options.icloud_remove_subaddress) {
+ parts[0] = parts[0].split('+')[0];
+ }
+
+ if (!parts[0].length) {
+ return false;
+ }
+
+ if (options.all_lowercase || options.icloud_lowercase) {
+ parts[0] = parts[0].toLowerCase();
+ }
+ } else if (outlookdotcom_domains.indexOf(parts[1]) >= 0) {
+ // Address is Outlook.com
+ if (options.outlookdotcom_remove_subaddress) {
+ parts[0] = parts[0].split('+')[0];
+ }
+
+ if (!parts[0].length) {
+ return false;
+ }
+
+ if (options.all_lowercase || options.outlookdotcom_lowercase) {
+ parts[0] = parts[0].toLowerCase();
+ }
+ } else if (yahoo_domains.indexOf(parts[1]) >= 0) {
+ // Address is Yahoo
+ if (options.yahoo_remove_subaddress) {
+ var components = parts[0].split('-');
+ parts[0] = components.length > 1 ? components.slice(0, -1).join('-') : components[0];
+ }
+
+ if (!parts[0].length) {
+ return false;
+ }
+
+ if (options.all_lowercase || options.yahoo_lowercase) {
+ parts[0] = parts[0].toLowerCase();
+ }
+ } else if (yandex_domains.indexOf(parts[1]) >= 0) {
+ if (options.all_lowercase || options.yandex_lowercase) {
+ parts[0] = parts[0].toLowerCase();
+ }
+
+ parts[1] = 'yandex.ru'; // all yandex domains are equal, 1st preferred
+ } else if (options.all_lowercase) {
+ // Any other address
+ parts[0] = parts[0].toLowerCase();
+ }
+
+ return parts.join('@');
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/rtrim.js b/includes/external/addressbook/node_modules/validator/lib/rtrim.js
new file mode 100644
index 0000000..e056a47
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/rtrim.js
@@ -0,0 +1,32 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = rtrim;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function rtrim(str, chars) {
+ (0, _assertString.default)(str);
+
+ if (chars) {
+ // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions#Escaping
+ var pattern = new RegExp("[".concat(chars.replace(/[.*+?^${}()|[\]\\]/g, '\\$&'), "]+$"), 'g');
+ return str.replace(pattern, '');
+ } // Use a faster and more safe than regex trim method https://blog.stevenlevithan.com/archives/faster-trim-javascript
+
+
+ var strIndex = str.length - 1;
+
+ while (/\s/.test(str.charAt(strIndex))) {
+ strIndex -= 1;
+ }
+
+ return str.slice(0, strIndex + 1);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/stripLow.js b/includes/external/addressbook/node_modules/validator/lib/stripLow.js
new file mode 100644
index 0000000..aec2e0b
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/stripLow.js
@@ -0,0 +1,21 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = stripLow;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+var _blacklist = _interopRequireDefault(require("./blacklist"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function stripLow(str, keep_new_lines) {
+ (0, _assertString.default)(str);
+ var chars = keep_new_lines ? '\\x00-\\x09\\x0B\\x0C\\x0E-\\x1F\\x7F' : '\\x00-\\x1F\\x7F';
+ return (0, _blacklist.default)(str, chars);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/toBoolean.js b/includes/external/addressbook/node_modules/validator/lib/toBoolean.js
new file mode 100644
index 0000000..a1b1fe4
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/toBoolean.js
@@ -0,0 +1,23 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = toBoolean;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function toBoolean(str, strict) {
+ (0, _assertString.default)(str);
+
+ if (strict) {
+ return str === '1' || /^true$/i.test(str);
+ }
+
+ return str !== '0' && !/^false$/i.test(str) && str !== '';
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/toDate.js b/includes/external/addressbook/node_modules/validator/lib/toDate.js
new file mode 100644
index 0000000..cb0756c
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/toDate.js
@@ -0,0 +1,19 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = toDate;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function toDate(date) {
+ (0, _assertString.default)(date);
+ date = Date.parse(date);
+ return !isNaN(date) ? new Date(date) : null;
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/toFloat.js b/includes/external/addressbook/node_modules/validator/lib/toFloat.js
new file mode 100644
index 0000000..96adafd
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/toFloat.js
@@ -0,0 +1,18 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = toFloat;
+
+var _isFloat = _interopRequireDefault(require("./isFloat"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function toFloat(str) {
+ if (!(0, _isFloat.default)(str)) return NaN;
+ return parseFloat(str);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/toInt.js b/includes/external/addressbook/node_modules/validator/lib/toInt.js
new file mode 100644
index 0000000..4c0e7ad
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/toInt.js
@@ -0,0 +1,18 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = toInt;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function toInt(str, radix) {
+ (0, _assertString.default)(str);
+ return parseInt(str, radix || 10);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/trim.js b/includes/external/addressbook/node_modules/validator/lib/trim.js
new file mode 100644
index 0000000..497e3c3
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/trim.js
@@ -0,0 +1,19 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = trim;
+
+var _rtrim = _interopRequireDefault(require("./rtrim"));
+
+var _ltrim = _interopRequireDefault(require("./ltrim"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function trim(str, chars) {
+ return (0, _rtrim.default)((0, _ltrim.default)(str, chars), chars);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/unescape.js b/includes/external/addressbook/node_modules/validator/lib/unescape.js
new file mode 100644
index 0000000..303d20c
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/unescape.js
@@ -0,0 +1,20 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = unescape;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function unescape(str) {
+ (0, _assertString.default)(str);
+ return str.replace(/&quot;/g, '"').replace(/&#x27;/g, "'").replace(/&lt;/g, '<').replace(/&gt;/g, '>').replace(/&#x2F;/g, '/').replace(/&#x5C;/g, '\\').replace(/&#96;/g, '`').replace(/&amp;/g, '&'); // &amp; replacement has to be the last one to prevent
+ // bugs with intermediate strings containing escape sequences
+ // See: https://github.com/validatorjs/validator.js/issues/1827
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/util/algorithms.js b/includes/external/addressbook/node_modules/validator/lib/util/algorithms.js
new file mode 100644
index 0000000..cf8e512
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/util/algorithms.js
@@ -0,0 +1,101 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.iso7064Check = iso7064Check;
+exports.luhnCheck = luhnCheck;
+exports.reverseMultiplyAndSum = reverseMultiplyAndSum;
+exports.verhoeffCheck = verhoeffCheck;
+
+/**
+ * Algorithmic validation functions
+ * May be used as is or implemented in the workflow of other validators.
+ */
+
+/*
+ * ISO 7064 validation function
+ * Called with a string of numbers (incl. check digit)
+ * to validate according to ISO 7064 (MOD 11, 10).
+ */
+function iso7064Check(str) {
+ var checkvalue = 10;
+
+ for (var i = 0; i < str.length - 1; i++) {
+ checkvalue = (parseInt(str[i], 10) + checkvalue) % 10 === 0 ? 10 * 2 % 11 : (parseInt(str[i], 10) + checkvalue) % 10 * 2 % 11;
+ }
+
+ checkvalue = checkvalue === 1 ? 0 : 11 - checkvalue;
+ return checkvalue === parseInt(str[10], 10);
+}
+/*
+ * Luhn (mod 10) validation function
+ * Called with a string of numbers (incl. check digit)
+ * to validate according to the Luhn algorithm.
+ */
+
+
+function luhnCheck(str) {
+ var checksum = 0;
+ var second = false;
+
+ for (var i = str.length - 1; i >= 0; i--) {
+ if (second) {
+ var product = parseInt(str[i], 10) * 2;
+
+ if (product > 9) {
+ // sum digits of product and add to checksum
+ checksum += product.toString().split('').map(function (a) {
+ return parseInt(a, 10);
+ }).reduce(function (a, b) {
+ return a + b;
+ }, 0);
+ } else {
+ checksum += product;
+ }
+ } else {
+ checksum += parseInt(str[i], 10);
+ }
+
+ second = !second;
+ }
+
+ return checksum % 10 === 0;
+}
+/*
+ * Reverse TIN multiplication and summation helper function
+ * Called with an array of single-digit integers and a base multiplier
+ * to calculate the sum of the digits multiplied in reverse.
+ * Normally used in variations of MOD 11 algorithmic checks.
+ */
+
+
+function reverseMultiplyAndSum(digits, base) {
+ var total = 0;
+
+ for (var i = 0; i < digits.length; i++) {
+ total += digits[i] * (base - i);
+ }
+
+ return total;
+}
+/*
+ * Verhoeff validation helper function
+ * Called with a string of numbers
+ * to validate according to the Verhoeff algorithm.
+ */
+
+
+function verhoeffCheck(str) {
+ var d_table = [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9], [1, 2, 3, 4, 0, 6, 7, 8, 9, 5], [2, 3, 4, 0, 1, 7, 8, 9, 5, 6], [3, 4, 0, 1, 2, 8, 9, 5, 6, 7], [4, 0, 1, 2, 3, 9, 5, 6, 7, 8], [5, 9, 8, 7, 6, 0, 4, 3, 2, 1], [6, 5, 9, 8, 7, 1, 0, 4, 3, 2], [7, 6, 5, 9, 8, 2, 1, 0, 4, 3], [8, 7, 6, 5, 9, 3, 2, 1, 0, 4], [9, 8, 7, 6, 5, 4, 3, 2, 1, 0]];
+ var p_table = [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9], [1, 5, 7, 6, 2, 8, 3, 0, 9, 4], [5, 8, 0, 3, 7, 9, 6, 1, 4, 2], [8, 9, 1, 6, 0, 4, 3, 5, 2, 7], [9, 4, 5, 3, 1, 2, 6, 8, 7, 0], [4, 2, 8, 6, 5, 7, 3, 9, 0, 1], [2, 7, 9, 3, 8, 0, 6, 4, 1, 5], [7, 0, 4, 6, 9, 1, 3, 2, 5, 8]]; // Copy (to prevent replacement) and reverse
+
+ var str_copy = str.split('').reverse().join('');
+ var checksum = 0;
+
+ for (var i = 0; i < str_copy.length; i++) {
+ checksum = d_table[checksum][p_table[i % 8][parseInt(str_copy[i], 10)]];
+ }
+
+ return checksum === 0;
+} \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/util/assertString.js b/includes/external/addressbook/node_modules/validator/lib/util/assertString.js
new file mode 100644
index 0000000..2c508af
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/util/assertString.js
@@ -0,0 +1,22 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = assertString;
+
+function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
+
+function assertString(input) {
+ var isString = typeof input === 'string' || input instanceof String;
+
+ if (!isString) {
+ var invalidType = _typeof(input);
+
+ if (input === null) invalidType = 'null';else if (invalidType === 'object') invalidType = input.constructor.name;
+ throw new TypeError("Expected a string but received a ".concat(invalidType));
+ }
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/util/includes.js b/includes/external/addressbook/node_modules/validator/lib/util/includes.js
new file mode 100644
index 0000000..e061828
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/util/includes.js
@@ -0,0 +1,17 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = void 0;
+
+var includes = function includes(arr, val) {
+ return arr.some(function (arrVal) {
+ return val === arrVal;
+ });
+};
+
+var _default = includes;
+exports.default = _default;
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/util/merge.js b/includes/external/addressbook/node_modules/validator/lib/util/merge.js
new file mode 100644
index 0000000..a96c739
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/util/merge.js
@@ -0,0 +1,22 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = merge;
+
+function merge() {
+ var obj = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
+ var defaults = arguments.length > 1 ? arguments[1] : undefined;
+
+ for (var key in defaults) {
+ if (typeof obj[key] === 'undefined') {
+ obj[key] = defaults[key];
+ }
+ }
+
+ return obj;
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/util/multilineRegex.js b/includes/external/addressbook/node_modules/validator/lib/util/multilineRegex.js
new file mode 100644
index 0000000..6980d14
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/util/multilineRegex.js
@@ -0,0 +1,22 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = multilineRegexp;
+
+/**
+ * Build RegExp object from an array
+ * of multiple/multi-line regexp parts
+ *
+ * @param {string[]} parts
+ * @param {string} flags
+ * @return {object} - RegExp object
+ */
+function multilineRegexp(parts, flags) {
+ var regexpAsStringLiteral = parts.join('');
+ return new RegExp(regexpAsStringLiteral, flags);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/util/toString.js b/includes/external/addressbook/node_modules/validator/lib/util/toString.js
new file mode 100644
index 0000000..6295192
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/util/toString.js
@@ -0,0 +1,25 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = toString;
+
+function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
+
+function toString(input) {
+ if (_typeof(input) === 'object' && input !== null) {
+ if (typeof input.toString === 'function') {
+ input = input.toString();
+ } else {
+ input = '[object Object]';
+ }
+ } else if (input === null || typeof input === 'undefined' || isNaN(input) && !input.length) {
+ input = '';
+ }
+
+ return String(input);
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/util/typeOf.js b/includes/external/addressbook/node_modules/validator/lib/util/typeOf.js
new file mode 100644
index 0000000..5bfacdb
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/util/typeOf.js
@@ -0,0 +1,20 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = typeOf;
+
+/**
+ * Better way to handle type checking
+ * null, {}, array and date are objects, which confuses
+ */
+function typeOf(input) {
+ var rawObject = Object.prototype.toString.call(input).toLowerCase();
+ var typeOfRegex = /\[object (.*)]/g;
+ var type = typeOfRegex.exec(rawObject)[1];
+ return type;
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/lib/whitelist.js b/includes/external/addressbook/node_modules/validator/lib/whitelist.js
new file mode 100644
index 0000000..7ae624e
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/lib/whitelist.js
@@ -0,0 +1,18 @@
+"use strict";
+
+Object.defineProperty(exports, "__esModule", {
+ value: true
+});
+exports.default = whitelist;
+
+var _assertString = _interopRequireDefault(require("./util/assertString"));
+
+function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
+
+function whitelist(str, chars) {
+ (0, _assertString.default)(str);
+ return str.replace(new RegExp("[^".concat(chars, "]+"), 'g'), '');
+}
+
+module.exports = exports.default;
+module.exports.default = exports.default; \ No newline at end of file
diff --git a/includes/external/addressbook/node_modules/validator/package.json b/includes/external/addressbook/node_modules/validator/package.json
new file mode 100644
index 0000000..4a10349
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/package.json
@@ -0,0 +1,75 @@
+{
+ "name": "validator",
+ "description": "String validation and sanitization",
+ "version": "13.9.0",
+ "sideEffects": false,
+ "homepage": "https://github.com/validatorjs/validator.js",
+ "files": [
+ "index.js",
+ "es",
+ "lib",
+ "README.md",
+ "LICENCE",
+ "validator.js",
+ "validator.min.js"
+ ],
+ "keywords": [
+ "validator",
+ "validation",
+ "validate",
+ "sanitization",
+ "sanitize",
+ "sanitisation",
+ "sanitise",
+ "assert"
+ ],
+ "author": "Chris O'Hara <cohara87@gmail.com>",
+ "contributors": [
+ "Anthony Nandaa (https://github.com/profnandaa)"
+ ],
+ "main": "index.js",
+ "bugs": {
+ "url": "https://github.com/validatorjs/validator.js/issues"
+ },
+ "repository": {
+ "type": "git",
+ "url": "git+https://github.com/validatorjs/validator.js.git"
+ },
+ "devDependencies": {
+ "@babel/cli": "^7.0.0",
+ "@babel/core": "^7.0.0",
+ "@babel/preset-env": "^7.0.0",
+ "@babel/register": "^7.0.0",
+ "babel-eslint": "^10.0.1",
+ "babel-plugin-add-module-exports": "^1.0.0",
+ "eslint": "^4.19.1",
+ "eslint-config-airbnb-base": "^12.1.0",
+ "eslint-plugin-import": "^2.11.0",
+ "mocha": "^6.2.3",
+ "npm-run-all": "^4.1.5",
+ "nyc": "^14.1.0",
+ "rimraf": "^3.0.0",
+ "rollup": "^0.47.0",
+ "rollup-plugin-babel": "^4.0.1",
+ "uglify-js": "^3.0.19"
+ },
+ "scripts": {
+ "lint": "eslint src test",
+ "lint:fix": "eslint --fix src test",
+ "clean:node": "rimraf index.js lib",
+ "clean:es": "rimraf es",
+ "clean:browser": "rimraf validator*.js",
+ "clean": "run-p clean:*",
+ "minify": "uglifyjs validator.js -o validator.min.js --compress --mangle --comments /Copyright/",
+ "build:browser": "node --require @babel/register build-browser && npm run minify",
+ "build:es": "babel src -d es --env-name=es",
+ "build:node": "babel src -d .",
+ "build": "run-p build:*",
+ "pretest": "npm run build && npm run lint",
+ "test": "nyc --reporter=cobertura --reporter=text-summary mocha --require @babel/register --reporter dot --recursive"
+ },
+ "engines": {
+ "node": ">= 0.10"
+ },
+ "license": "MIT"
+}
diff --git a/includes/external/addressbook/node_modules/validator/validator.js b/includes/external/addressbook/node_modules/validator/validator.js
new file mode 100644
index 0000000..a7f1cfc
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/validator.js
@@ -0,0 +1,5561 @@
+/*!
+ * Copyright (c) 2018 Chris O'Hara <cohara87@gmail.com>
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining
+ * a copy of this software and associated documentation files (the
+ * "Software"), to deal in the Software without restriction, including
+ * without limitation the rights to use, copy, modify, merge, publish,
+ * distribute, sublicense, and/or sell copies of the Software, and to
+ * permit persons to whom the Software is furnished to do so, subject to
+ * the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be
+ * included in all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+ * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+ * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
+ * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
+ * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
+ * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+ */
+(function (global, factory) {
+ typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
+ typeof define === 'function' && define.amd ? define(factory) :
+ (global.validator = factory());
+}(this, (function () { 'use strict';
+
+function _typeof(obj) {
+ "@babel/helpers - typeof";
+
+ if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") {
+ _typeof = function (obj) {
+ return typeof obj;
+ };
+ } else {
+ _typeof = function (obj) {
+ return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj;
+ };
+ }
+
+ return _typeof(obj);
+}
+
+function _slicedToArray(arr, i) {
+ return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest();
+}
+
+function _toConsumableArray(arr) {
+ return _arrayWithoutHoles(arr) || _iterableToArray(arr) || _unsupportedIterableToArray(arr) || _nonIterableSpread();
+}
+
+function _arrayWithoutHoles(arr) {
+ if (Array.isArray(arr)) return _arrayLikeToArray(arr);
+}
+
+function _arrayWithHoles(arr) {
+ if (Array.isArray(arr)) return arr;
+}
+
+function _iterableToArray(iter) {
+ if (typeof Symbol !== "undefined" && Symbol.iterator in Object(iter)) return Array.from(iter);
+}
+
+function _iterableToArrayLimit(arr, i) {
+ if (typeof Symbol === "undefined" || !(Symbol.iterator in Object(arr))) return;
+ var _arr = [];
+ var _n = true;
+ var _d = false;
+ var _e = undefined;
+
+ try {
+ for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) {
+ _arr.push(_s.value);
+
+ if (i && _arr.length === i) break;
+ }
+ } catch (err) {
+ _d = true;
+ _e = err;
+ } finally {
+ try {
+ if (!_n && _i["return"] != null) _i["return"]();
+ } finally {
+ if (_d) throw _e;
+ }
+ }
+
+ return _arr;
+}
+
+function _unsupportedIterableToArray(o, minLen) {
+ if (!o) return;
+ if (typeof o === "string") return _arrayLikeToArray(o, minLen);
+ var n = Object.prototype.toString.call(o).slice(8, -1);
+ if (n === "Object" && o.constructor) n = o.constructor.name;
+ if (n === "Map" || n === "Set") return Array.from(o);
+ if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen);
+}
+
+function _arrayLikeToArray(arr, len) {
+ if (len == null || len > arr.length) len = arr.length;
+
+ for (var i = 0, arr2 = new Array(len); i < len; i++) arr2[i] = arr[i];
+
+ return arr2;
+}
+
+function _nonIterableSpread() {
+ throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
+}
+
+function _nonIterableRest() {
+ throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
+}
+
+function _createForOfIteratorHelper(o, allowArrayLike) {
+ var it;
+
+ if (typeof Symbol === "undefined" || o[Symbol.iterator] == null) {
+ if (Array.isArray(o) || (it = _unsupportedIterableToArray(o)) || allowArrayLike && o && typeof o.length === "number") {
+ if (it) o = it;
+ var i = 0;
+
+ var F = function () {};
+
+ return {
+ s: F,
+ n: function () {
+ if (i >= o.length) return {
+ done: true
+ };
+ return {
+ done: false,
+ value: o[i++]
+ };
+ },
+ e: function (e) {
+ throw e;
+ },
+ f: F
+ };
+ }
+
+ throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.");
+ }
+
+ var normalCompletion = true,
+ didErr = false,
+ err;
+ return {
+ s: function () {
+ it = o[Symbol.iterator]();
+ },
+ n: function () {
+ var step = it.next();
+ normalCompletion = step.done;
+ return step;
+ },
+ e: function (e) {
+ didErr = true;
+ err = e;
+ },
+ f: function () {
+ try {
+ if (!normalCompletion && it.return != null) it.return();
+ } finally {
+ if (didErr) throw err;
+ }
+ }
+ };
+}
+
+function assertString(input) {
+ var isString = typeof input === 'string' || input instanceof String;
+
+ if (!isString) {
+ var invalidType = _typeof(input);
+
+ if (input === null) invalidType = 'null';else if (invalidType === 'object') invalidType = input.constructor.name;
+ throw new TypeError("Expected a string but received a ".concat(invalidType));
+ }
+}
+
+function toDate(date) {
+ assertString(date);
+ date = Date.parse(date);
+ return !isNaN(date) ? new Date(date) : null;
+}
+
+var alpha = {
+ 'en-US': /^[A-Z]+$/i,
+ 'az-AZ': /^[A-VXYZÇƏĞİıÖŞÜ]+$/i,
+ 'bg-BG': /^[А-Я]+$/i,
+ 'cs-CZ': /^[A-ZÁČĎÉĚÍŇÓŘŠŤÚŮÝŽ]+$/i,
+ 'da-DK': /^[A-ZÆØÅ]+$/i,
+ 'de-DE': /^[A-ZÄÖÜß]+$/i,
+ 'el-GR': /^[Α-ώ]+$/i,
+ 'es-ES': /^[A-ZÁÉÍÑÓÚÜ]+$/i,
+ 'fa-IR': /^[ابپتثجچحخدذرزژسشصضطظعغفقکگلمنوهی]+$/i,
+ 'fi-FI': /^[A-ZÅÄÖ]+$/i,
+ 'fr-FR': /^[A-ZÀÂÆÇÉÈÊËÏÎÔŒÙÛÜŸ]+$/i,
+ 'it-IT': /^[A-ZÀÉÈÌÎÓÒÙ]+$/i,
+ 'ja-JP': /^[ぁ-んァ-ヶヲ-゚一-龠ー・。、]+$/i,
+ 'nb-NO': /^[A-ZÆØÅ]+$/i,
+ 'nl-NL': /^[A-ZÁÉËÏÓÖÜÚ]+$/i,
+ 'nn-NO': /^[A-ZÆØÅ]+$/i,
+ 'hu-HU': /^[A-ZÁÉÍÓÖŐÚÜŰ]+$/i,
+ 'pl-PL': /^[A-ZĄĆĘŚŁŃÓŻŹ]+$/i,
+ 'pt-PT': /^[A-ZÃÁÀÂÄÇÉÊËÍÏÕÓÔÖÚÜ]+$/i,
+ 'ru-RU': /^[А-ЯЁ]+$/i,
+ 'sl-SI': /^[A-ZČĆĐŠŽ]+$/i,
+ 'sk-SK': /^[A-ZÁČĎÉÍŇÓŠŤÚÝŽĹŔĽÄÔ]+$/i,
+ 'sr-RS@latin': /^[A-ZČĆŽŠĐ]+$/i,
+ 'sr-RS': /^[А-ЯЂЈЉЊЋЏ]+$/i,
+ 'sv-SE': /^[A-ZÅÄÖ]+$/i,
+ 'th-TH': /^[ก-๐\s]+$/i,
+ 'tr-TR': /^[A-ZÇĞİıÖŞÜ]+$/i,
+ 'uk-UA': /^[А-ЩЬЮЯЄIЇҐі]+$/i,
+ 'vi-VN': /^[A-ZÀÁẠẢÃÂẦẤẬẨẪĂẰẮẶẲẴĐÈÉẸẺẼÊỀẾỆỂỄÌÍỊỈĨÒÓỌỎÕÔỒỐỘỔỖƠỜỚỢỞỠÙÚỤỦŨƯỪỨỰỬỮỲÝỴỶỸ]+$/i,
+ 'ko-KR': /^[ㄱ-ㅎㅏ-ㅣ가-힣]*$/,
+ 'ku-IQ': /^[ئابپتجچحخدرڕزژسشعغفڤقکگلڵمنوۆھەیێيطؤثآإأكضصةظذ]+$/i,
+ ar: /^[ءآأؤإئابةتثجحخدذرزسشصضطظعغفقكلمنهوىيًٌٍَُِّْٰ]+$/,
+ he: /^[א-ת]+$/,
+ fa: /^['آاءأؤئبپتثجچحخدذرزژسشصضطظعغفقکگلمنوهةی']+$/i,
+ bn: /^['ঀঁংঃঅআইঈউঊঋঌএঐওঔকখগঘঙচছজঝঞটঠডঢণতথদধনপফবভমযরলশষসহ়ঽািীুূৃৄেৈোৌ্ৎৗড়ঢ়য়ৠৡৢৣৰৱ৲৳৴৵৶৷৸৹৺৻']+$/,
+ 'hi-IN': /^[\u0900-\u0961]+[\u0972-\u097F]*$/i,
+ 'si-LK': /^[\u0D80-\u0DFF]+$/
+};
+var alphanumeric = {
+ 'en-US': /^[0-9A-Z]+$/i,
+ 'az-AZ': /^[0-9A-VXYZÇƏĞİıÖŞÜ]+$/i,
+ 'bg-BG': /^[0-9А-Я]+$/i,
+ 'cs-CZ': /^[0-9A-ZÁČĎÉĚÍŇÓŘŠŤÚŮÝŽ]+$/i,
+ 'da-DK': /^[0-9A-ZÆØÅ]+$/i,
+ 'de-DE': /^[0-9A-ZÄÖÜß]+$/i,
+ 'el-GR': /^[0-9Α-ω]+$/i,
+ 'es-ES': /^[0-9A-ZÁÉÍÑÓÚÜ]+$/i,
+ 'fi-FI': /^[0-9A-ZÅÄÖ]+$/i,
+ 'fr-FR': /^[0-9A-ZÀÂÆÇÉÈÊËÏÎÔŒÙÛÜŸ]+$/i,
+ 'it-IT': /^[0-9A-ZÀÉÈÌÎÓÒÙ]+$/i,
+ 'ja-JP': /^[0-90-9ぁ-んァ-ヶヲ-゚一-龠ー・。、]+$/i,
+ 'hu-HU': /^[0-9A-ZÁÉÍÓÖŐÚÜŰ]+$/i,
+ 'nb-NO': /^[0-9A-ZÆØÅ]+$/i,
+ 'nl-NL': /^[0-9A-ZÁÉËÏÓÖÜÚ]+$/i,
+ 'nn-NO': /^[0-9A-ZÆØÅ]+$/i,
+ 'pl-PL': /^[0-9A-ZĄĆĘŚŁŃÓŻŹ]+$/i,
+ 'pt-PT': /^[0-9A-ZÃÁÀÂÄÇÉÊËÍÏÕÓÔÖÚÜ]+$/i,
+ 'ru-RU': /^[0-9А-ЯЁ]+$/i,
+ 'sl-SI': /^[0-9A-ZČĆĐŠŽ]+$/i,
+ 'sk-SK': /^[0-9A-ZÁČĎÉÍŇÓŠŤÚÝŽĹŔĽÄÔ]+$/i,
+ 'sr-RS@latin': /^[0-9A-ZČĆŽŠĐ]+$/i,
+ 'sr-RS': /^[0-9А-ЯЂЈЉЊЋЏ]+$/i,
+ 'sv-SE': /^[0-9A-ZÅÄÖ]+$/i,
+ 'th-TH': /^[ก-๙\s]+$/i,
+ 'tr-TR': /^[0-9A-ZÇĞİıÖŞÜ]+$/i,
+ 'uk-UA': /^[0-9А-ЩЬЮЯЄIЇҐі]+$/i,
+ 'ko-KR': /^[0-9ㄱ-ㅎㅏ-ㅣ가-힣]*$/,
+ 'ku-IQ': /^[٠١٢٣٤٥٦٧٨٩0-9ئابپتجچحخدرڕزژسشعغفڤقکگلڵمنوۆھەیێيطؤثآإأكضصةظذ]+$/i,
+ 'vi-VN': /^[0-9A-ZÀÁẠẢÃÂẦẤẬẨẪĂẰẮẶẲẴĐÈÉẸẺẼÊỀẾỆỂỄÌÍỊỈĨÒÓỌỎÕÔỒỐỘỔỖƠỜỚỢỞỠÙÚỤỦŨƯỪỨỰỬỮỲÝỴỶỸ]+$/i,
+ ar: /^[٠١٢٣٤٥٦٧٨٩0-9ءآأؤإئابةتثجحخدذرزسشصضطظعغفقكلمنهوىيًٌٍَُِّْٰ]+$/,
+ he: /^[0-9א-ת]+$/,
+ fa: /^['0-9آاءأؤئبپتثجچحخدذرزژسشصضطظعغفقکگلمنوهةی۱۲۳۴۵۶۷۸۹۰']+$/i,
+ bn: /^['ঀঁংঃঅআইঈউঊঋঌএঐওঔকখগঘঙচছজঝঞটঠডঢণতথদধনপফবভমযরলশষসহ়ঽািীুূৃৄেৈোৌ্ৎৗড়ঢ়য়ৠৡৢৣ০১২৩৪৫৬৭৮৯ৰৱ৲৳৴৵৶৷৸৹৺৻']+$/,
+ 'hi-IN': /^[\u0900-\u0963]+[\u0966-\u097F]*$/i,
+ 'si-LK': /^[0-9\u0D80-\u0DFF]+$/
+};
+var decimal = {
+ 'en-US': '.',
+ ar: '٫'
+};
+var englishLocales = ['AU', 'GB', 'HK', 'IN', 'NZ', 'ZA', 'ZM'];
+
+for (var locale, i = 0; i < englishLocales.length; i++) {
+ locale = "en-".concat(englishLocales[i]);
+ alpha[locale] = alpha['en-US'];
+ alphanumeric[locale] = alphanumeric['en-US'];
+ decimal[locale] = decimal['en-US'];
+} // Source: http://www.localeplanet.com/java/
+
+
+var arabicLocales = ['AE', 'BH', 'DZ', 'EG', 'IQ', 'JO', 'KW', 'LB', 'LY', 'MA', 'QM', 'QA', 'SA', 'SD', 'SY', 'TN', 'YE'];
+
+for (var _locale, _i = 0; _i < arabicLocales.length; _i++) {
+ _locale = "ar-".concat(arabicLocales[_i]);
+ alpha[_locale] = alpha.ar;
+ alphanumeric[_locale] = alphanumeric.ar;
+ decimal[_locale] = decimal.ar;
+}
+
+var farsiLocales = ['IR', 'AF'];
+
+for (var _locale2, _i2 = 0; _i2 < farsiLocales.length; _i2++) {
+ _locale2 = "fa-".concat(farsiLocales[_i2]);
+ alphanumeric[_locale2] = alphanumeric.fa;
+ decimal[_locale2] = decimal.ar;
+}
+
+var bengaliLocales = ['BD', 'IN'];
+
+for (var _locale3, _i3 = 0; _i3 < bengaliLocales.length; _i3++) {
+ _locale3 = "bn-".concat(bengaliLocales[_i3]);
+ alpha[_locale3] = alpha.bn;
+ alphanumeric[_locale3] = alphanumeric.bn;
+ decimal[_locale3] = decimal['en-US'];
+} // Source: https://en.wikipedia.org/wiki/Decimal_mark
+
+
+var dotDecimal = ['ar-EG', 'ar-LB', 'ar-LY'];
+var commaDecimal = ['bg-BG', 'cs-CZ', 'da-DK', 'de-DE', 'el-GR', 'en-ZM', 'es-ES', 'fr-CA', 'fr-FR', 'id-ID', 'it-IT', 'ku-IQ', 'hi-IN', 'hu-HU', 'nb-NO', 'nn-NO', 'nl-NL', 'pl-PL', 'pt-PT', 'ru-RU', 'si-LK', 'sl-SI', 'sr-RS@latin', 'sr-RS', 'sv-SE', 'tr-TR', 'uk-UA', 'vi-VN'];
+
+for (var _i4 = 0; _i4 < dotDecimal.length; _i4++) {
+ decimal[dotDecimal[_i4]] = decimal['en-US'];
+}
+
+for (var _i5 = 0; _i5 < commaDecimal.length; _i5++) {
+ decimal[commaDecimal[_i5]] = ',';
+}
+
+alpha['fr-CA'] = alpha['fr-FR'];
+alphanumeric['fr-CA'] = alphanumeric['fr-FR'];
+alpha['pt-BR'] = alpha['pt-PT'];
+alphanumeric['pt-BR'] = alphanumeric['pt-PT'];
+decimal['pt-BR'] = decimal['pt-PT']; // see #862
+
+alpha['pl-Pl'] = alpha['pl-PL'];
+alphanumeric['pl-Pl'] = alphanumeric['pl-PL'];
+decimal['pl-Pl'] = decimal['pl-PL']; // see #1455
+
+alpha['fa-AF'] = alpha.fa;
+
+function isFloat(str, options) {
+ assertString(str);
+ options = options || {};
+
+ var _float = new RegExp("^(?:[-+])?(?:[0-9]+)?(?:\\".concat(options.locale ? decimal[options.locale] : '.', "[0-9]*)?(?:[eE][\\+\\-]?(?:[0-9]+))?$"));
+
+ if (str === '' || str === '.' || str === ',' || str === '-' || str === '+') {
+ return false;
+ }
+
+ var value = parseFloat(str.replace(',', '.'));
+ return _float.test(str) && (!options.hasOwnProperty('min') || value >= options.min) && (!options.hasOwnProperty('max') || value <= options.max) && (!options.hasOwnProperty('lt') || value < options.lt) && (!options.hasOwnProperty('gt') || value > options.gt);
+}
+var locales = Object.keys(decimal);
+
+function toFloat(str) {
+ if (!isFloat(str)) return NaN;
+ return parseFloat(str);
+}
+
+function toInt(str, radix) {
+ assertString(str);
+ return parseInt(str, radix || 10);
+}
+
+function toBoolean(str, strict) {
+ assertString(str);
+
+ if (strict) {
+ return str === '1' || /^true$/i.test(str);
+ }
+
+ return str !== '0' && !/^false$/i.test(str) && str !== '';
+}
+
+function equals(str, comparison) {
+ assertString(str);
+ return str === comparison;
+}
+
+function toString$1(input) {
+ if (_typeof(input) === 'object' && input !== null) {
+ if (typeof input.toString === 'function') {
+ input = input.toString();
+ } else {
+ input = '[object Object]';
+ }
+ } else if (input === null || typeof input === 'undefined' || isNaN(input) && !input.length) {
+ input = '';
+ }
+
+ return String(input);
+}
+
+function merge() {
+ var obj = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
+ var defaults = arguments.length > 1 ? arguments[1] : undefined;
+
+ for (var key in defaults) {
+ if (typeof obj[key] === 'undefined') {
+ obj[key] = defaults[key];
+ }
+ }
+
+ return obj;
+}
+
+var defaulContainsOptions = {
+ ignoreCase: false,
+ minOccurrences: 1
+};
+function contains(str, elem, options) {
+ assertString(str);
+ options = merge(options, defaulContainsOptions);
+
+ if (options.ignoreCase) {
+ return str.toLowerCase().split(toString$1(elem).toLowerCase()).length > options.minOccurrences;
+ }
+
+ return str.split(toString$1(elem)).length > options.minOccurrences;
+}
+
+function matches(str, pattern, modifiers) {
+ assertString(str);
+
+ if (Object.prototype.toString.call(pattern) !== '[object RegExp]') {
+ pattern = new RegExp(pattern, modifiers);
+ }
+
+ return !!str.match(pattern);
+}
+
+/* eslint-disable prefer-rest-params */
+
+function isByteLength(str, options) {
+ assertString(str);
+ var min;
+ var max;
+
+ if (_typeof(options) === 'object') {
+ min = options.min || 0;
+ max = options.max;
+ } else {
+ // backwards compatibility: isByteLength(str, min [, max])
+ min = arguments[1];
+ max = arguments[2];
+ }
+
+ var len = encodeURI(str).split(/%..|./).length - 1;
+ return len >= min && (typeof max === 'undefined' || len <= max);
+}
+
+var default_fqdn_options = {
+ require_tld: true,
+ allow_underscores: false,
+ allow_trailing_dot: false,
+ allow_numeric_tld: false,
+ allow_wildcard: false,
+ ignore_max_length: false
+};
+function isFQDN(str, options) {
+ assertString(str);
+ options = merge(options, default_fqdn_options);
+ /* Remove the optional trailing dot before checking validity */
+
+ if (options.allow_trailing_dot && str[str.length - 1] === '.') {
+ str = str.substring(0, str.length - 1);
+ }
+ /* Remove the optional wildcard before checking validity */
+
+
+ if (options.allow_wildcard === true && str.indexOf('*.') === 0) {
+ str = str.substring(2);
+ }
+
+ var parts = str.split('.');
+ var tld = parts[parts.length - 1];
+
+ if (options.require_tld) {
+ // disallow fqdns without tld
+ if (parts.length < 2) {
+ return false;
+ }
+
+ if (!options.allow_numeric_tld && !/^([a-z\u00A1-\u00A8\u00AA-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]{2,}|xn[a-z0-9-]{2,})$/i.test(tld)) {
+ return false;
+ } // disallow spaces
+
+
+ if (/\s/.test(tld)) {
+ return false;
+ }
+ } // reject numeric TLDs
+
+
+ if (!options.allow_numeric_tld && /^\d+$/.test(tld)) {
+ return false;
+ }
+
+ return parts.every(function (part) {
+ if (part.length > 63 && !options.ignore_max_length) {
+ return false;
+ }
+
+ if (!/^[a-z_\u00a1-\uffff0-9-]+$/i.test(part)) {
+ return false;
+ } // disallow full-width chars
+
+
+ if (/[\uff01-\uff5e]/.test(part)) {
+ return false;
+ } // disallow parts starting or ending with hyphen
+
+
+ if (/^-|-$/.test(part)) {
+ return false;
+ }
+
+ if (!options.allow_underscores && /_/.test(part)) {
+ return false;
+ }
+
+ return true;
+ });
+}
+
+/**
+11.3. Examples
+
+ The following addresses
+
+ fe80::1234 (on the 1st link of the node)
+ ff02::5678 (on the 5th link of the node)
+ ff08::9abc (on the 10th organization of the node)
+
+ would be represented as follows:
+
+ fe80::1234%1
+ ff02::5678%5
+ ff08::9abc%10
+
+ (Here we assume a natural translation from a zone index to the
+ <zone_id> part, where the Nth zone of any scope is translated into
+ "N".)
+
+ If we use interface names as <zone_id>, those addresses could also be
+ represented as follows:
+
+ fe80::1234%ne0
+ ff02::5678%pvc1.3
+ ff08::9abc%interface10
+
+ where the interface "ne0" belongs to the 1st link, "pvc1.3" belongs
+ to the 5th link, and "interface10" belongs to the 10th organization.
+ * * */
+
+var IPv4SegmentFormat = '(?:[0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])';
+var IPv4AddressFormat = "(".concat(IPv4SegmentFormat, "[.]){3}").concat(IPv4SegmentFormat);
+var IPv4AddressRegExp = new RegExp("^".concat(IPv4AddressFormat, "$"));
+var IPv6SegmentFormat = '(?:[0-9a-fA-F]{1,4})';
+var IPv6AddressRegExp = new RegExp('^(' + "(?:".concat(IPv6SegmentFormat, ":){7}(?:").concat(IPv6SegmentFormat, "|:)|") + "(?:".concat(IPv6SegmentFormat, ":){6}(?:").concat(IPv4AddressFormat, "|:").concat(IPv6SegmentFormat, "|:)|") + "(?:".concat(IPv6SegmentFormat, ":){5}(?::").concat(IPv4AddressFormat, "|(:").concat(IPv6SegmentFormat, "){1,2}|:)|") + "(?:".concat(IPv6SegmentFormat, ":){4}(?:(:").concat(IPv6SegmentFormat, "){0,1}:").concat(IPv4AddressFormat, "|(:").concat(IPv6SegmentFormat, "){1,3}|:)|") + "(?:".concat(IPv6SegmentFormat, ":){3}(?:(:").concat(IPv6SegmentFormat, "){0,2}:").concat(IPv4AddressFormat, "|(:").concat(IPv6SegmentFormat, "){1,4}|:)|") + "(?:".concat(IPv6SegmentFormat, ":){2}(?:(:").concat(IPv6SegmentFormat, "){0,3}:").concat(IPv4AddressFormat, "|(:").concat(IPv6SegmentFormat, "){1,5}|:)|") + "(?:".concat(IPv6SegmentFormat, ":){1}(?:(:").concat(IPv6SegmentFormat, "){0,4}:").concat(IPv4AddressFormat, "|(:").concat(IPv6SegmentFormat, "){1,6}|:)|") + "(?::((?::".concat(IPv6SegmentFormat, "){0,5}:").concat(IPv4AddressFormat, "|(?::").concat(IPv6SegmentFormat, "){1,7}|:))") + ')(%[0-9a-zA-Z-.:]{1,})?$');
+function isIP(str) {
+ var version = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';
+ assertString(str);
+ version = String(version);
+
+ if (!version) {
+ return isIP(str, 4) || isIP(str, 6);
+ }
+
+ if (version === '4') {
+ return IPv4AddressRegExp.test(str);
+ }
+
+ if (version === '6') {
+ return IPv6AddressRegExp.test(str);
+ }
+
+ return false;
+}
+
+var default_email_options = {
+ allow_display_name: false,
+ require_display_name: false,
+ allow_utf8_local_part: true,
+ require_tld: true,
+ blacklisted_chars: '',
+ ignore_max_length: false,
+ host_blacklist: [],
+ host_whitelist: []
+};
+/* eslint-disable max-len */
+
+/* eslint-disable no-control-regex */
+
+var splitNameAddress = /^([^\x00-\x1F\x7F-\x9F\cX]+)</i;
+var emailUserPart = /^[a-z\d!#\$%&'\*\+\-\/=\?\^_`{\|}~]+$/i;
+var gmailUserPart = /^[a-z\d]+$/;
+var quotedEmailUser = /^([\s\x01-\x08\x0b\x0c\x0e-\x1f\x7f\x21\x23-\x5b\x5d-\x7e]|(\\[\x01-\x09\x0b\x0c\x0d-\x7f]))*$/i;
+var emailUserUtf8Part = /^[a-z\d!#\$%&'\*\+\-\/=\?\^_`{\|}~\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]+$/i;
+var quotedEmailUserUtf8 = /^([\s\x01-\x08\x0b\x0c\x0e-\x1f\x7f\x21\x23-\x5b\x5d-\x7e\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]|(\\[\x01-\x09\x0b\x0c\x0d-\x7f\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))*$/i;
+var defaultMaxEmailLength = 254;
+/* eslint-enable max-len */
+
+/* eslint-enable no-control-regex */
+
+/**
+ * Validate display name according to the RFC2822: https://tools.ietf.org/html/rfc2822#appendix-A.1.2
+ * @param {String} display_name
+ */
+
+function validateDisplayName(display_name) {
+ var display_name_without_quotes = display_name.replace(/^"(.+)"$/, '$1'); // display name with only spaces is not valid
+
+ if (!display_name_without_quotes.trim()) {
+ return false;
+ } // check whether display name contains illegal character
+
+
+ var contains_illegal = /[\.";<>]/.test(display_name_without_quotes);
+
+ if (contains_illegal) {
+ // if contains illegal characters,
+ // must to be enclosed in double-quotes, otherwise it's not a valid display name
+ if (display_name_without_quotes === display_name) {
+ return false;
+ } // the quotes in display name must start with character symbol \
+
+
+ var all_start_with_back_slash = display_name_without_quotes.split('"').length === display_name_without_quotes.split('\\"').length;
+
+ if (!all_start_with_back_slash) {
+ return false;
+ }
+ }
+
+ return true;
+}
+
+function isEmail(str, options) {
+ assertString(str);
+ options = merge(options, default_email_options);
+
+ if (options.require_display_name || options.allow_display_name) {
+ var display_email = str.match(splitNameAddress);
+
+ if (display_email) {
+ var display_name = display_email[1]; // Remove display name and angle brackets to get email address
+ // Can be done in the regex but will introduce a ReDOS (See #1597 for more info)
+
+ str = str.replace(display_name, '').replace(/(^<|>$)/g, ''); // sometimes need to trim the last space to get the display name
+ // because there may be a space between display name and email address
+ // eg. myname <address@gmail.com>
+ // the display name is `myname` instead of `myname `, so need to trim the last space
+
+ if (display_name.endsWith(' ')) {
+ display_name = display_name.slice(0, -1);
+ }
+
+ if (!validateDisplayName(display_name)) {
+ return false;
+ }
+ } else if (options.require_display_name) {
+ return false;
+ }
+ }
+
+ if (!options.ignore_max_length && str.length > defaultMaxEmailLength) {
+ return false;
+ }
+
+ var parts = str.split('@');
+ var domain = parts.pop();
+ var lower_domain = domain.toLowerCase();
+
+ if (options.host_blacklist.includes(lower_domain)) {
+ return false;
+ }
+
+ if (options.host_whitelist.length > 0 && !options.host_whitelist.includes(lower_domain)) {
+ return false;
+ }
+
+ var user = parts.join('@');
+
+ if (options.domain_specific_validation && (lower_domain === 'gmail.com' || lower_domain === 'googlemail.com')) {
+ /*
+ Previously we removed dots for gmail addresses before validating.
+ This was removed because it allows `multiple..dots@gmail.com`
+ to be reported as valid, but it is not.
+ Gmail only normalizes single dots, removing them from here is pointless,
+ should be done in normalizeEmail
+ */
+ user = user.toLowerCase(); // Removing sub-address from username before gmail validation
+
+ var username = user.split('+')[0]; // Dots are not included in gmail length restriction
+
+ if (!isByteLength(username.replace(/\./g, ''), {
+ min: 6,
+ max: 30
+ })) {
+ return false;
+ }
+
+ var _user_parts = username.split('.');
+
+ for (var i = 0; i < _user_parts.length; i++) {
+ if (!gmailUserPart.test(_user_parts[i])) {
+ return false;
+ }
+ }
+ }
+
+ if (options.ignore_max_length === false && (!isByteLength(user, {
+ max: 64
+ }) || !isByteLength(domain, {
+ max: 254
+ }))) {
+ return false;
+ }
+
+ if (!isFQDN(domain, {
+ require_tld: options.require_tld,
+ ignore_max_length: options.ignore_max_length
+ })) {
+ if (!options.allow_ip_domain) {
+ return false;
+ }
+
+ if (!isIP(domain)) {
+ if (!domain.startsWith('[') || !domain.endsWith(']')) {
+ return false;
+ }
+
+ var noBracketdomain = domain.slice(1, -1);
+
+ if (noBracketdomain.length === 0 || !isIP(noBracketdomain)) {
+ return false;
+ }
+ }
+ }
+
+ if (user[0] === '"') {
+ user = user.slice(1, user.length - 1);
+ return options.allow_utf8_local_part ? quotedEmailUserUtf8.test(user) : quotedEmailUser.test(user);
+ }
+
+ var pattern = options.allow_utf8_local_part ? emailUserUtf8Part : emailUserPart;
+ var user_parts = user.split('.');
+
+ for (var _i = 0; _i < user_parts.length; _i++) {
+ if (!pattern.test(user_parts[_i])) {
+ return false;
+ }
+ }
+
+ if (options.blacklisted_chars) {
+ if (user.search(new RegExp("[".concat(options.blacklisted_chars, "]+"), 'g')) !== -1) return false;
+ }
+
+ return true;
+}
+
+/*
+options for isURL method
+
+require_protocol - if set as true isURL will return false if protocol is not present in the URL
+require_valid_protocol - isURL will check if the URL's protocol is present in the protocols option
+protocols - valid protocols can be modified with this option
+require_host - if set as false isURL will not check if host is present in the URL
+require_port - if set as true isURL will check if port is present in the URL
+allow_protocol_relative_urls - if set as true protocol relative URLs will be allowed
+validate_length - if set as false isURL will skip string length validation (IE maximum is 2083)
+
+*/
+
+var default_url_options = {
+ protocols: ['http', 'https', 'ftp'],
+ require_tld: true,
+ require_protocol: false,
+ require_host: true,
+ require_port: false,
+ require_valid_protocol: true,
+ allow_underscores: false,
+ allow_trailing_dot: false,
+ allow_protocol_relative_urls: false,
+ allow_fragments: true,
+ allow_query_components: true,
+ validate_length: true
+};
+var wrapped_ipv6 = /^\[([^\]]+)\](?::([0-9]+))?$/;
+
+function isRegExp(obj) {
+ return Object.prototype.toString.call(obj) === '[object RegExp]';
+}
+
+function checkHost(host, matches) {
+ for (var i = 0; i < matches.length; i++) {
+ var match = matches[i];
+
+ if (host === match || isRegExp(match) && match.test(host)) {
+ return true;
+ }
+ }
+
+ return false;
+}
+
+function isURL(url, options) {
+ assertString(url);
+
+ if (!url || /[\s<>]/.test(url)) {
+ return false;
+ }
+
+ if (url.indexOf('mailto:') === 0) {
+ return false;
+ }
+
+ options = merge(options, default_url_options);
+
+ if (options.validate_length && url.length >= 2083) {
+ return false;
+ }
+
+ if (!options.allow_fragments && url.includes('#')) {
+ return false;
+ }
+
+ if (!options.allow_query_components && (url.includes('?') || url.includes('&'))) {
+ return false;
+ }
+
+ var protocol, auth, host, hostname, port, port_str, split, ipv6;
+ split = url.split('#');
+ url = split.shift();
+ split = url.split('?');
+ url = split.shift();
+ split = url.split('://');
+
+ if (split.length > 1) {
+ protocol = split.shift().toLowerCase();
+
+ if (options.require_valid_protocol && options.protocols.indexOf(protocol) === -1) {
+ return false;
+ }
+ } else if (options.require_protocol) {
+ return false;
+ } else if (url.slice(0, 2) === '//') {
+ if (!options.allow_protocol_relative_urls) {
+ return false;
+ }
+
+ split[0] = url.slice(2);
+ }
+
+ url = split.join('://');
+
+ if (url === '') {
+ return false;
+ }
+
+ split = url.split('/');
+ url = split.shift();
+
+ if (url === '' && !options.require_host) {
+ return true;
+ }
+
+ split = url.split('@');
+
+ if (split.length > 1) {
+ if (options.disallow_auth) {
+ return false;
+ }
+
+ if (split[0] === '') {
+ return false;
+ }
+
+ auth = split.shift();
+
+ if (auth.indexOf(':') >= 0 && auth.split(':').length > 2) {
+ return false;
+ }
+
+ var _auth$split = auth.split(':'),
+ _auth$split2 = _slicedToArray(_auth$split, 2),
+ user = _auth$split2[0],
+ password = _auth$split2[1];
+
+ if (user === '' && password === '') {
+ return false;
+ }
+ }
+
+ hostname = split.join('@');
+ port_str = null;
+ ipv6 = null;
+ var ipv6_match = hostname.match(wrapped_ipv6);
+
+ if (ipv6_match) {
+ host = '';
+ ipv6 = ipv6_match[1];
+ port_str = ipv6_match[2] || null;
+ } else {
+ split = hostname.split(':');
+ host = split.shift();
+
+ if (split.length) {
+ port_str = split.join(':');
+ }
+ }
+
+ if (port_str !== null && port_str.length > 0) {
+ port = parseInt(port_str, 10);
+
+ if (!/^[0-9]+$/.test(port_str) || port <= 0 || port > 65535) {
+ return false;
+ }
+ } else if (options.require_port) {
+ return false;
+ }
+
+ if (options.host_whitelist) {
+ return checkHost(host, options.host_whitelist);
+ }
+
+ if (host === '' && !options.require_host) {
+ return true;
+ }
+
+ if (!isIP(host) && !isFQDN(host, options) && (!ipv6 || !isIP(ipv6, 6))) {
+ return false;
+ }
+
+ host = host || ipv6;
+
+ if (options.host_blacklist && checkHost(host, options.host_blacklist)) {
+ return false;
+ }
+
+ return true;
+}
+
+var macAddress48 = /^(?:[0-9a-fA-F]{2}([-:\s]))([0-9a-fA-F]{2}\1){4}([0-9a-fA-F]{2})$/;
+var macAddress48NoSeparators = /^([0-9a-fA-F]){12}$/;
+var macAddress48WithDots = /^([0-9a-fA-F]{4}\.){2}([0-9a-fA-F]{4})$/;
+var macAddress64 = /^(?:[0-9a-fA-F]{2}([-:\s]))([0-9a-fA-F]{2}\1){6}([0-9a-fA-F]{2})$/;
+var macAddress64NoSeparators = /^([0-9a-fA-F]){16}$/;
+var macAddress64WithDots = /^([0-9a-fA-F]{4}\.){3}([0-9a-fA-F]{4})$/;
+function isMACAddress(str, options) {
+ assertString(str);
+
+ if (options !== null && options !== void 0 && options.eui) {
+ options.eui = String(options.eui);
+ }
+ /**
+ * @deprecated `no_colons` TODO: remove it in the next major
+ */
+
+
+ if (options !== null && options !== void 0 && options.no_colons || options !== null && options !== void 0 && options.no_separators) {
+ if (options.eui === '48') {
+ return macAddress48NoSeparators.test(str);
+ }
+
+ if (options.eui === '64') {
+ return macAddress64NoSeparators.test(str);
+ }
+
+ return macAddress48NoSeparators.test(str) || macAddress64NoSeparators.test(str);
+ }
+
+ if ((options === null || options === void 0 ? void 0 : options.eui) === '48') {
+ return macAddress48.test(str) || macAddress48WithDots.test(str);
+ }
+
+ if ((options === null || options === void 0 ? void 0 : options.eui) === '64') {
+ return macAddress64.test(str) || macAddress64WithDots.test(str);
+ }
+
+ return isMACAddress(str, {
+ eui: '48'
+ }) || isMACAddress(str, {
+ eui: '64'
+ });
+}
+
+var subnetMaybe = /^\d{1,3}$/;
+var v4Subnet = 32;
+var v6Subnet = 128;
+function isIPRange(str) {
+ var version = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : '';
+ assertString(str);
+ var parts = str.split('/'); // parts[0] -> ip, parts[1] -> subnet
+
+ if (parts.length !== 2) {
+ return false;
+ }
+
+ if (!subnetMaybe.test(parts[1])) {
+ return false;
+ } // Disallow preceding 0 i.e. 01, 02, ...
+
+
+ if (parts[1].length > 1 && parts[1].startsWith('0')) {
+ return false;
+ }
+
+ var isValidIP = isIP(parts[0], version);
+
+ if (!isValidIP) {
+ return false;
+ } // Define valid subnet according to IP's version
+
+
+ var expectedSubnet = null;
+
+ switch (String(version)) {
+ case '4':
+ expectedSubnet = v4Subnet;
+ break;
+
+ case '6':
+ expectedSubnet = v6Subnet;
+ break;
+
+ default:
+ expectedSubnet = isIP(parts[0], '6') ? v6Subnet : v4Subnet;
+ }
+
+ return parts[1] <= expectedSubnet && parts[1] >= 0;
+}
+
+var default_date_options = {
+ format: 'YYYY/MM/DD',
+ delimiters: ['/', '-'],
+ strictMode: false
+};
+
+function isValidFormat(format) {
+ return /(^(y{4}|y{2})[.\/-](m{1,2})[.\/-](d{1,2})$)|(^(m{1,2})[.\/-](d{1,2})[.\/-]((y{4}|y{2})$))|(^(d{1,2})[.\/-](m{1,2})[.\/-]((y{4}|y{2})$))/gi.test(format);
+}
+
+function zip(date, format) {
+ var zippedArr = [],
+ len = Math.min(date.length, format.length);
+
+ for (var i = 0; i < len; i++) {
+ zippedArr.push([date[i], format[i]]);
+ }
+
+ return zippedArr;
+}
+
+function isDate(input, options) {
+ if (typeof options === 'string') {
+ // Allow backward compatbility for old format isDate(input [, format])
+ options = merge({
+ format: options
+ }, default_date_options);
+ } else {
+ options = merge(options, default_date_options);
+ }
+
+ if (typeof input === 'string' && isValidFormat(options.format)) {
+ var formatDelimiter = options.delimiters.find(function (delimiter) {
+ return options.format.indexOf(delimiter) !== -1;
+ });
+ var dateDelimiter = options.strictMode ? formatDelimiter : options.delimiters.find(function (delimiter) {
+ return input.indexOf(delimiter) !== -1;
+ });
+ var dateAndFormat = zip(input.split(dateDelimiter), options.format.toLowerCase().split(formatDelimiter));
+ var dateObj = {};
+
+ var _iterator = _createForOfIteratorHelper(dateAndFormat),
+ _step;
+
+ try {
+ for (_iterator.s(); !(_step = _iterator.n()).done;) {
+ var _step$value = _slicedToArray(_step.value, 2),
+ dateWord = _step$value[0],
+ formatWord = _step$value[1];
+
+ if (dateWord.length !== formatWord.length) {
+ return false;
+ }
+
+ dateObj[formatWord.charAt(0)] = dateWord;
+ }
+ } catch (err) {
+ _iterator.e(err);
+ } finally {
+ _iterator.f();
+ }
+
+ return new Date("".concat(dateObj.m, "/").concat(dateObj.d, "/").concat(dateObj.y)).getDate() === +dateObj.d;
+ }
+
+ if (!options.strictMode) {
+ return Object.prototype.toString.call(input) === '[object Date]' && isFinite(input);
+ }
+
+ return false;
+}
+
+var default_time_options = {
+ hourFormat: 'hour24',
+ mode: 'default'
+};
+var formats = {
+ hour24: {
+ "default": /^([01]?[0-9]|2[0-3]):([0-5][0-9])$/,
+ withSeconds: /^([01]?[0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])$/
+ },
+ hour12: {
+ "default": /^(0?[1-9]|1[0-2]):([0-5][0-9]) (A|P)M$/,
+ withSeconds: /^(0?[1-9]|1[0-2]):([0-5][0-9]):([0-5][0-9]) (A|P)M$/
+ }
+};
+function isTime(input, options) {
+ options = merge(options, default_time_options);
+ if (typeof input !== 'string') return false;
+ return formats[options.hourFormat][options.mode].test(input);
+}
+
+var defaultOptions = {
+ loose: false
+};
+var strictBooleans = ['true', 'false', '1', '0'];
+var looseBooleans = [].concat(strictBooleans, ['yes', 'no']);
+function isBoolean(str) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : defaultOptions;
+ assertString(str);
+
+ if (options.loose) {
+ return looseBooleans.includes(str.toLowerCase());
+ }
+
+ return strictBooleans.includes(str);
+}
+
+var localeReg = /^[A-Za-z]{2,4}([_-]([A-Za-z]{4}|[\d]{3}))?([_-]([A-Za-z]{2}|[\d]{3}))?$/;
+function isLocale(str) {
+ assertString(str);
+
+ if (str === 'en_US_POSIX' || str === 'ca_ES_VALENCIA') {
+ return true;
+ }
+
+ return localeReg.test(str);
+}
+
+function isAlpha(_str) {
+ var locale = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'en-US';
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ assertString(_str);
+ var str = _str;
+ var ignore = options.ignore;
+
+ if (ignore) {
+ if (ignore instanceof RegExp) {
+ str = str.replace(ignore, '');
+ } else if (typeof ignore === 'string') {
+ str = str.replace(new RegExp("[".concat(ignore.replace(/[-[\]{}()*+?.,\\^$|#\\s]/g, '\\$&'), "]"), 'g'), ''); // escape regex for ignore
+ } else {
+ throw new Error('ignore should be instance of a String or RegExp');
+ }
+ }
+
+ if (locale in alpha) {
+ return alpha[locale].test(str);
+ }
+
+ throw new Error("Invalid locale '".concat(locale, "'"));
+}
+var locales$1 = Object.keys(alpha);
+
+function isAlphanumeric(_str) {
+ var locale = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'en-US';
+ var options = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : {};
+ assertString(_str);
+ var str = _str;
+ var ignore = options.ignore;
+
+ if (ignore) {
+ if (ignore instanceof RegExp) {
+ str = str.replace(ignore, '');
+ } else if (typeof ignore === 'string') {
+ str = str.replace(new RegExp("[".concat(ignore.replace(/[-[\]{}()*+?.,\\^$|#\\s]/g, '\\$&'), "]"), 'g'), ''); // escape regex for ignore
+ } else {
+ throw new Error('ignore should be instance of a String or RegExp');
+ }
+ }
+
+ if (locale in alphanumeric) {
+ return alphanumeric[locale].test(str);
+ }
+
+ throw new Error("Invalid locale '".concat(locale, "'"));
+}
+var locales$2 = Object.keys(alphanumeric);
+
+var numericNoSymbols = /^[0-9]+$/;
+function isNumeric(str, options) {
+ assertString(str);
+
+ if (options && options.no_symbols) {
+ return numericNoSymbols.test(str);
+ }
+
+ return new RegExp("^[+-]?([0-9]*[".concat((options || {}).locale ? decimal[options.locale] : '.', "])?[0-9]+$")).test(str);
+}
+
+/**
+ * Reference:
+ * https://en.wikipedia.org/ -- Wikipedia
+ * https://docs.microsoft.com/en-us/microsoft-365/compliance/eu-passport-number -- EU Passport Number
+ * https://countrycode.org/ -- Country Codes
+ */
+
+var passportRegexByCountryCode = {
+ AM: /^[A-Z]{2}\d{7}$/,
+ // ARMENIA
+ AR: /^[A-Z]{3}\d{6}$/,
+ // ARGENTINA
+ AT: /^[A-Z]\d{7}$/,
+ // AUSTRIA
+ AU: /^[A-Z]\d{7}$/,
+ // AUSTRALIA
+ AZ: /^[A-Z]{2,3}\d{7,8}$/,
+ // AZERBAIJAN
+ BE: /^[A-Z]{2}\d{6}$/,
+ // BELGIUM
+ BG: /^\d{9}$/,
+ // BULGARIA
+ BR: /^[A-Z]{2}\d{6}$/,
+ // BRAZIL
+ BY: /^[A-Z]{2}\d{7}$/,
+ // BELARUS
+ CA: /^[A-Z]{2}\d{6}$/,
+ // CANADA
+ CH: /^[A-Z]\d{7}$/,
+ // SWITZERLAND
+ CN: /^G\d{8}$|^E(?![IO])[A-Z0-9]\d{7}$/,
+ // CHINA [G=Ordinary, E=Electronic] followed by 8-digits, or E followed by any UPPERCASE letter (except I and O) followed by 7 digits
+ CY: /^[A-Z](\d{6}|\d{8})$/,
+ // CYPRUS
+ CZ: /^\d{8}$/,
+ // CZECH REPUBLIC
+ DE: /^[CFGHJKLMNPRTVWXYZ0-9]{9}$/,
+ // GERMANY
+ DK: /^\d{9}$/,
+ // DENMARK
+ DZ: /^\d{9}$/,
+ // ALGERIA
+ EE: /^([A-Z]\d{7}|[A-Z]{2}\d{7})$/,
+ // ESTONIA (K followed by 7-digits), e-passports have 2 UPPERCASE followed by 7 digits
+ ES: /^[A-Z0-9]{2}([A-Z0-9]?)\d{6}$/,
+ // SPAIN
+ FI: /^[A-Z]{2}\d{7}$/,
+ // FINLAND
+ FR: /^\d{2}[A-Z]{2}\d{5}$/,
+ // FRANCE
+ GB: /^\d{9}$/,
+ // UNITED KINGDOM
+ GR: /^[A-Z]{2}\d{7}$/,
+ // GREECE
+ HR: /^\d{9}$/,
+ // CROATIA
+ HU: /^[A-Z]{2}(\d{6}|\d{7})$/,
+ // HUNGARY
+ IE: /^[A-Z0-9]{2}\d{7}$/,
+ // IRELAND
+ IN: /^[A-Z]{1}-?\d{7}$/,
+ // INDIA
+ ID: /^[A-C]\d{7}$/,
+ // INDONESIA
+ IR: /^[A-Z]\d{8}$/,
+ // IRAN
+ IS: /^(A)\d{7}$/,
+ // ICELAND
+ IT: /^[A-Z0-9]{2}\d{7}$/,
+ // ITALY
+ JM: /^[Aa]\d{7}$/,
+ // JAMAICA
+ JP: /^[A-Z]{2}\d{7}$/,
+ // JAPAN
+ KR: /^[MS]\d{8}$/,
+ // SOUTH KOREA, REPUBLIC OF KOREA, [S=PS Passports, M=PM Passports]
+ KZ: /^[a-zA-Z]\d{7}$/,
+ // KAZAKHSTAN
+ LI: /^[a-zA-Z]\d{5}$/,
+ // LIECHTENSTEIN
+ LT: /^[A-Z0-9]{8}$/,
+ // LITHUANIA
+ LU: /^[A-Z0-9]{8}$/,
+ // LUXEMBURG
+ LV: /^[A-Z0-9]{2}\d{7}$/,
+ // LATVIA
+ LY: /^[A-Z0-9]{8}$/,
+ // LIBYA
+ MT: /^\d{7}$/,
+ // MALTA
+ MZ: /^([A-Z]{2}\d{7})|(\d{2}[A-Z]{2}\d{5})$/,
+ // MOZAMBIQUE
+ MY: /^[AHK]\d{8}$/,
+ // MALAYSIA
+ MX: /^\d{10,11}$/,
+ // MEXICO
+ NL: /^[A-Z]{2}[A-Z0-9]{6}\d$/,
+ // NETHERLANDS
+ NZ: /^([Ll]([Aa]|[Dd]|[Ff]|[Hh])|[Ee]([Aa]|[Pp])|[Nn])\d{6}$/,
+ // NEW ZEALAND
+ PH: /^([A-Z](\d{6}|\d{7}[A-Z]))|([A-Z]{2}(\d{6}|\d{7}))$/,
+ // PHILIPPINES
+ PK: /^[A-Z]{2}\d{7}$/,
+ // PAKISTAN
+ PL: /^[A-Z]{2}\d{7}$/,
+ // POLAND
+ PT: /^[A-Z]\d{6}$/,
+ // PORTUGAL
+ RO: /^\d{8,9}$/,
+ // ROMANIA
+ RU: /^\d{9}$/,
+ // RUSSIAN FEDERATION
+ SE: /^\d{8}$/,
+ // SWEDEN
+ SL: /^(P)[A-Z]\d{7}$/,
+ // SLOVENIA
+ SK: /^[0-9A-Z]\d{7}$/,
+ // SLOVAKIA
+ TH: /^[A-Z]{1,2}\d{6,7}$/,
+ // THAILAND
+ TR: /^[A-Z]\d{8}$/,
+ // TURKEY
+ UA: /^[A-Z]{2}\d{6}$/,
+ // UKRAINE
+ US: /^\d{9}$/ // UNITED STATES
+
+};
+/**
+ * Check if str is a valid passport number
+ * relative to provided ISO Country Code.
+ *
+ * @param {string} str
+ * @param {string} countryCode
+ * @return {boolean}
+ */
+
+function isPassportNumber(str, countryCode) {
+ assertString(str);
+ /** Remove All Whitespaces, Convert to UPPERCASE */
+
+ var normalizedStr = str.replace(/\s/g, '').toUpperCase();
+ return countryCode.toUpperCase() in passportRegexByCountryCode && passportRegexByCountryCode[countryCode].test(normalizedStr);
+}
+
+var _int = /^(?:[-+]?(?:0|[1-9][0-9]*))$/;
+var intLeadingZeroes = /^[-+]?[0-9]+$/;
+function isInt(str, options) {
+ assertString(str);
+ options = options || {}; // Get the regex to use for testing, based on whether
+ // leading zeroes are allowed or not.
+
+ var regex = options.hasOwnProperty('allow_leading_zeroes') && !options.allow_leading_zeroes ? _int : intLeadingZeroes; // Check min/max/lt/gt
+
+ var minCheckPassed = !options.hasOwnProperty('min') || str >= options.min;
+ var maxCheckPassed = !options.hasOwnProperty('max') || str <= options.max;
+ var ltCheckPassed = !options.hasOwnProperty('lt') || str < options.lt;
+ var gtCheckPassed = !options.hasOwnProperty('gt') || str > options.gt;
+ return regex.test(str) && minCheckPassed && maxCheckPassed && ltCheckPassed && gtCheckPassed;
+}
+
+function isPort(str) {
+ return isInt(str, {
+ min: 0,
+ max: 65535
+ });
+}
+
+function isLowercase(str) {
+ assertString(str);
+ return str === str.toLowerCase();
+}
+
+function isUppercase(str) {
+ assertString(str);
+ return str === str.toUpperCase();
+}
+
+var imeiRegexWithoutHypens = /^[0-9]{15}$/;
+var imeiRegexWithHypens = /^\d{2}-\d{6}-\d{6}-\d{1}$/;
+function isIMEI(str, options) {
+ assertString(str);
+ options = options || {}; // default regex for checking imei is the one without hyphens
+
+ var imeiRegex = imeiRegexWithoutHypens;
+
+ if (options.allow_hyphens) {
+ imeiRegex = imeiRegexWithHypens;
+ }
+
+ if (!imeiRegex.test(str)) {
+ return false;
+ }
+
+ str = str.replace(/-/g, '');
+ var sum = 0,
+ mul = 2,
+ l = 14;
+
+ for (var i = 0; i < l; i++) {
+ var digit = str.substring(l - i - 1, l - i);
+ var tp = parseInt(digit, 10) * mul;
+
+ if (tp >= 10) {
+ sum += tp % 10 + 1;
+ } else {
+ sum += tp;
+ }
+
+ if (mul === 1) {
+ mul += 1;
+ } else {
+ mul -= 1;
+ }
+ }
+
+ var chk = (10 - sum % 10) % 10;
+
+ if (chk !== parseInt(str.substring(14, 15), 10)) {
+ return false;
+ }
+
+ return true;
+}
+
+/* eslint-disable no-control-regex */
+
+var ascii = /^[\x00-\x7F]+$/;
+/* eslint-enable no-control-regex */
+
+function isAscii(str) {
+ assertString(str);
+ return ascii.test(str);
+}
+
+var fullWidth = /[^\u0020-\u007E\uFF61-\uFF9F\uFFA0-\uFFDC\uFFE8-\uFFEE0-9a-zA-Z]/;
+function isFullWidth(str) {
+ assertString(str);
+ return fullWidth.test(str);
+}
+
+var halfWidth = /[\u0020-\u007E\uFF61-\uFF9F\uFFA0-\uFFDC\uFFE8-\uFFEE0-9a-zA-Z]/;
+function isHalfWidth(str) {
+ assertString(str);
+ return halfWidth.test(str);
+}
+
+function isVariableWidth(str) {
+ assertString(str);
+ return fullWidth.test(str) && halfWidth.test(str);
+}
+
+/* eslint-disable no-control-regex */
+
+var multibyte = /[^\x00-\x7F]/;
+/* eslint-enable no-control-regex */
+
+function isMultibyte(str) {
+ assertString(str);
+ return multibyte.test(str);
+}
+
+/**
+ * Build RegExp object from an array
+ * of multiple/multi-line regexp parts
+ *
+ * @param {string[]} parts
+ * @param {string} flags
+ * @return {object} - RegExp object
+ */
+function multilineRegexp(parts, flags) {
+ var regexpAsStringLiteral = parts.join('');
+ return new RegExp(regexpAsStringLiteral, flags);
+}
+
+/**
+ * Regular Expression to match
+ * semantic versioning (SemVer)
+ * built from multi-line, multi-parts regexp
+ * Reference: https://semver.org/
+ */
+
+var semanticVersioningRegex = multilineRegexp(['^(0|[1-9]\\d*)\\.(0|[1-9]\\d*)\\.(0|[1-9]\\d*)', '(?:-((?:0|[1-9]\\d*|\\d*[a-z-][0-9a-z-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-z-][0-9a-z-]*))*))', '?(?:\\+([0-9a-z-]+(?:\\.[0-9a-z-]+)*))?$'], 'i');
+function isSemVer(str) {
+ assertString(str);
+ return semanticVersioningRegex.test(str);
+}
+
+var surrogatePair = /[\uD800-\uDBFF][\uDC00-\uDFFF]/;
+function isSurrogatePair(str) {
+ assertString(str);
+ return surrogatePair.test(str);
+}
+
+var includes = function includes(arr, val) {
+ return arr.some(function (arrVal) {
+ return val === arrVal;
+ });
+};
+
+function decimalRegExp(options) {
+ var regExp = new RegExp("^[-+]?([0-9]+)?(\\".concat(decimal[options.locale], "[0-9]{").concat(options.decimal_digits, "})").concat(options.force_decimal ? '' : '?', "$"));
+ return regExp;
+}
+
+var default_decimal_options = {
+ force_decimal: false,
+ decimal_digits: '1,',
+ locale: 'en-US'
+};
+var blacklist = ['', '-', '+'];
+function isDecimal(str, options) {
+ assertString(str);
+ options = merge(options, default_decimal_options);
+
+ if (options.locale in decimal) {
+ return !includes(blacklist, str.replace(/ /g, '')) && decimalRegExp(options).test(str);
+ }
+
+ throw new Error("Invalid locale '".concat(options.locale, "'"));
+}
+
+var hexadecimal = /^(0x|0h)?[0-9A-F]+$/i;
+function isHexadecimal(str) {
+ assertString(str);
+ return hexadecimal.test(str);
+}
+
+var octal = /^(0o)?[0-7]+$/i;
+function isOctal(str) {
+ assertString(str);
+ return octal.test(str);
+}
+
+function isDivisibleBy(str, num) {
+ assertString(str);
+ return toFloat(str) % parseInt(num, 10) === 0;
+}
+
+var hexcolor = /^#?([0-9A-F]{3}|[0-9A-F]{4}|[0-9A-F]{6}|[0-9A-F]{8})$/i;
+function isHexColor(str) {
+ assertString(str);
+ return hexcolor.test(str);
+}
+
+var rgbColor = /^rgb\((([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5]),){2}([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\)$/;
+var rgbaColor = /^rgba\((([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5]),){3}(0?\.\d|1(\.0)?|0(\.0)?)\)$/;
+var rgbColorPercent = /^rgb\((([0-9]%|[1-9][0-9]%|100%),){2}([0-9]%|[1-9][0-9]%|100%)\)$/;
+var rgbaColorPercent = /^rgba\((([0-9]%|[1-9][0-9]%|100%),){3}(0?\.\d|1(\.0)?|0(\.0)?)\)$/;
+function isRgbColor(str) {
+ var includePercentValues = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : true;
+ assertString(str);
+
+ if (!includePercentValues) {
+ return rgbColor.test(str) || rgbaColor.test(str);
+ }
+
+ return rgbColor.test(str) || rgbaColor.test(str) || rgbColorPercent.test(str) || rgbaColorPercent.test(str);
+}
+
+var hslComma = /^hsla?\(((\+|\-)?([0-9]+(\.[0-9]+)?(e(\+|\-)?[0-9]+)?|\.[0-9]+(e(\+|\-)?[0-9]+)?))(deg|grad|rad|turn)?(,(\+|\-)?([0-9]+(\.[0-9]+)?(e(\+|\-)?[0-9]+)?|\.[0-9]+(e(\+|\-)?[0-9]+)?)%){2}(,((\+|\-)?([0-9]+(\.[0-9]+)?(e(\+|\-)?[0-9]+)?|\.[0-9]+(e(\+|\-)?[0-9]+)?)%?))?\)$/i;
+var hslSpace = /^hsla?\(((\+|\-)?([0-9]+(\.[0-9]+)?(e(\+|\-)?[0-9]+)?|\.[0-9]+(e(\+|\-)?[0-9]+)?))(deg|grad|rad|turn)?(\s(\+|\-)?([0-9]+(\.[0-9]+)?(e(\+|\-)?[0-9]+)?|\.[0-9]+(e(\+|\-)?[0-9]+)?)%){2}\s?(\/\s((\+|\-)?([0-9]+(\.[0-9]+)?(e(\+|\-)?[0-9]+)?|\.[0-9]+(e(\+|\-)?[0-9]+)?)%?)\s?)?\)$/i;
+function isHSL(str) {
+ assertString(str); // Strip duplicate spaces before calling the validation regex (See #1598 for more info)
+
+ var strippedStr = str.replace(/\s+/g, ' ').replace(/\s?(hsla?\(|\)|,)\s?/ig, '$1');
+
+ if (strippedStr.indexOf(',') !== -1) {
+ return hslComma.test(strippedStr);
+ }
+
+ return hslSpace.test(strippedStr);
+}
+
+var isrc = /^[A-Z]{2}[0-9A-Z]{3}\d{2}\d{5}$/;
+function isISRC(str) {
+ assertString(str);
+ return isrc.test(str);
+}
+
+/**
+ * List of country codes with
+ * corresponding IBAN regular expression
+ * Reference: https://en.wikipedia.org/wiki/International_Bank_Account_Number
+ */
+
+var ibanRegexThroughCountryCode = {
+ AD: /^(AD[0-9]{2})\d{8}[A-Z0-9]{12}$/,
+ AE: /^(AE[0-9]{2})\d{3}\d{16}$/,
+ AL: /^(AL[0-9]{2})\d{8}[A-Z0-9]{16}$/,
+ AT: /^(AT[0-9]{2})\d{16}$/,
+ AZ: /^(AZ[0-9]{2})[A-Z0-9]{4}\d{20}$/,
+ BA: /^(BA[0-9]{2})\d{16}$/,
+ BE: /^(BE[0-9]{2})\d{12}$/,
+ BG: /^(BG[0-9]{2})[A-Z]{4}\d{6}[A-Z0-9]{8}$/,
+ BH: /^(BH[0-9]{2})[A-Z]{4}[A-Z0-9]{14}$/,
+ BR: /^(BR[0-9]{2})\d{23}[A-Z]{1}[A-Z0-9]{1}$/,
+ BY: /^(BY[0-9]{2})[A-Z0-9]{4}\d{20}$/,
+ CH: /^(CH[0-9]{2})\d{5}[A-Z0-9]{12}$/,
+ CR: /^(CR[0-9]{2})\d{18}$/,
+ CY: /^(CY[0-9]{2})\d{8}[A-Z0-9]{16}$/,
+ CZ: /^(CZ[0-9]{2})\d{20}$/,
+ DE: /^(DE[0-9]{2})\d{18}$/,
+ DK: /^(DK[0-9]{2})\d{14}$/,
+ DO: /^(DO[0-9]{2})[A-Z]{4}\d{20}$/,
+ EE: /^(EE[0-9]{2})\d{16}$/,
+ EG: /^(EG[0-9]{2})\d{25}$/,
+ ES: /^(ES[0-9]{2})\d{20}$/,
+ FI: /^(FI[0-9]{2})\d{14}$/,
+ FO: /^(FO[0-9]{2})\d{14}$/,
+ FR: /^(FR[0-9]{2})\d{10}[A-Z0-9]{11}\d{2}$/,
+ GB: /^(GB[0-9]{2})[A-Z]{4}\d{14}$/,
+ GE: /^(GE[0-9]{2})[A-Z0-9]{2}\d{16}$/,
+ GI: /^(GI[0-9]{2})[A-Z]{4}[A-Z0-9]{15}$/,
+ GL: /^(GL[0-9]{2})\d{14}$/,
+ GR: /^(GR[0-9]{2})\d{7}[A-Z0-9]{16}$/,
+ GT: /^(GT[0-9]{2})[A-Z0-9]{4}[A-Z0-9]{20}$/,
+ HR: /^(HR[0-9]{2})\d{17}$/,
+ HU: /^(HU[0-9]{2})\d{24}$/,
+ IE: /^(IE[0-9]{2})[A-Z0-9]{4}\d{14}$/,
+ IL: /^(IL[0-9]{2})\d{19}$/,
+ IQ: /^(IQ[0-9]{2})[A-Z]{4}\d{15}$/,
+ IR: /^(IR[0-9]{2})0\d{2}0\d{18}$/,
+ IS: /^(IS[0-9]{2})\d{22}$/,
+ IT: /^(IT[0-9]{2})[A-Z]{1}\d{10}[A-Z0-9]{12}$/,
+ JO: /^(JO[0-9]{2})[A-Z]{4}\d{22}$/,
+ KW: /^(KW[0-9]{2})[A-Z]{4}[A-Z0-9]{22}$/,
+ KZ: /^(KZ[0-9]{2})\d{3}[A-Z0-9]{13}$/,
+ LB: /^(LB[0-9]{2})\d{4}[A-Z0-9]{20}$/,
+ LC: /^(LC[0-9]{2})[A-Z]{4}[A-Z0-9]{24}$/,
+ LI: /^(LI[0-9]{2})\d{5}[A-Z0-9]{12}$/,
+ LT: /^(LT[0-9]{2})\d{16}$/,
+ LU: /^(LU[0-9]{2})\d{3}[A-Z0-9]{13}$/,
+ LV: /^(LV[0-9]{2})[A-Z]{4}[A-Z0-9]{13}$/,
+ MC: /^(MC[0-9]{2})\d{10}[A-Z0-9]{11}\d{2}$/,
+ MD: /^(MD[0-9]{2})[A-Z0-9]{20}$/,
+ ME: /^(ME[0-9]{2})\d{18}$/,
+ MK: /^(MK[0-9]{2})\d{3}[A-Z0-9]{10}\d{2}$/,
+ MR: /^(MR[0-9]{2})\d{23}$/,
+ MT: /^(MT[0-9]{2})[A-Z]{4}\d{5}[A-Z0-9]{18}$/,
+ MU: /^(MU[0-9]{2})[A-Z]{4}\d{19}[A-Z]{3}$/,
+ MZ: /^(MZ[0-9]{2})\d{21}$/,
+ NL: /^(NL[0-9]{2})[A-Z]{4}\d{10}$/,
+ NO: /^(NO[0-9]{2})\d{11}$/,
+ PK: /^(PK[0-9]{2})[A-Z0-9]{4}\d{16}$/,
+ PL: /^(PL[0-9]{2})\d{24}$/,
+ PS: /^(PS[0-9]{2})[A-Z0-9]{4}\d{21}$/,
+ PT: /^(PT[0-9]{2})\d{21}$/,
+ QA: /^(QA[0-9]{2})[A-Z]{4}[A-Z0-9]{21}$/,
+ RO: /^(RO[0-9]{2})[A-Z]{4}[A-Z0-9]{16}$/,
+ RS: /^(RS[0-9]{2})\d{18}$/,
+ SA: /^(SA[0-9]{2})\d{2}[A-Z0-9]{18}$/,
+ SC: /^(SC[0-9]{2})[A-Z]{4}\d{20}[A-Z]{3}$/,
+ SE: /^(SE[0-9]{2})\d{20}$/,
+ SI: /^(SI[0-9]{2})\d{15}$/,
+ SK: /^(SK[0-9]{2})\d{20}$/,
+ SM: /^(SM[0-9]{2})[A-Z]{1}\d{10}[A-Z0-9]{12}$/,
+ SV: /^(SV[0-9]{2})[A-Z0-9]{4}\d{20}$/,
+ TL: /^(TL[0-9]{2})\d{19}$/,
+ TN: /^(TN[0-9]{2})\d{20}$/,
+ TR: /^(TR[0-9]{2})\d{5}[A-Z0-9]{17}$/,
+ UA: /^(UA[0-9]{2})\d{6}[A-Z0-9]{19}$/,
+ VA: /^(VA[0-9]{2})\d{18}$/,
+ VG: /^(VG[0-9]{2})[A-Z0-9]{4}\d{16}$/,
+ XK: /^(XK[0-9]{2})\d{16}$/
+};
+/**
+ * Check whether string has correct universal IBAN format
+ * The IBAN consists of up to 34 alphanumeric characters, as follows:
+ * Country Code using ISO 3166-1 alpha-2, two letters
+ * check digits, two digits and
+ * Basic Bank Account Number (BBAN), up to 30 alphanumeric characters.
+ * NOTE: Permitted IBAN characters are: digits [0-9] and the 26 latin alphabetic [A-Z]
+ *
+ * @param {string} str - string under validation
+ * @return {boolean}
+ */
+
+function hasValidIbanFormat(str) {
+ // Strip white spaces and hyphens
+ var strippedStr = str.replace(/[\s\-]+/gi, '').toUpperCase();
+ var isoCountryCode = strippedStr.slice(0, 2).toUpperCase();
+ return isoCountryCode in ibanRegexThroughCountryCode && ibanRegexThroughCountryCode[isoCountryCode].test(strippedStr);
+}
+/**
+ * Check whether string has valid IBAN Checksum
+ * by performing basic mod-97 operation and
+ * the remainder should equal 1
+ * -- Start by rearranging the IBAN by moving the four initial characters to the end of the string
+ * -- Replace each letter in the string with two digits, A -> 10, B = 11, Z = 35
+ * -- Interpret the string as a decimal integer and
+ * -- compute the remainder on division by 97 (mod 97)
+ * Reference: https://en.wikipedia.org/wiki/International_Bank_Account_Number
+ *
+ * @param {string} str
+ * @return {boolean}
+ */
+
+
+function hasValidIbanChecksum(str) {
+ var strippedStr = str.replace(/[^A-Z0-9]+/gi, '').toUpperCase(); // Keep only digits and A-Z latin alphabetic
+
+ var rearranged = strippedStr.slice(4) + strippedStr.slice(0, 4);
+ var alphaCapsReplacedWithDigits = rearranged.replace(/[A-Z]/g, function (_char) {
+ return _char.charCodeAt(0) - 55;
+ });
+ var remainder = alphaCapsReplacedWithDigits.match(/\d{1,7}/g).reduce(function (acc, value) {
+ return Number(acc + value) % 97;
+ }, '');
+ return remainder === 1;
+}
+
+function isIBAN(str) {
+ assertString(str);
+ return hasValidIbanFormat(str) && hasValidIbanChecksum(str);
+}
+var locales$3 = Object.keys(ibanRegexThroughCountryCode);
+
+var validISO31661Alpha2CountriesCodes = new Set(['AD', 'AE', 'AF', 'AG', 'AI', 'AL', 'AM', 'AO', 'AQ', 'AR', 'AS', 'AT', 'AU', 'AW', 'AX', 'AZ', 'BA', 'BB', 'BD', 'BE', 'BF', 'BG', 'BH', 'BI', 'BJ', 'BL', 'BM', 'BN', 'BO', 'BQ', 'BR', 'BS', 'BT', 'BV', 'BW', 'BY', 'BZ', 'CA', 'CC', 'CD', 'CF', 'CG', 'CH', 'CI', 'CK', 'CL', 'CM', 'CN', 'CO', 'CR', 'CU', 'CV', 'CW', 'CX', 'CY', 'CZ', 'DE', 'DJ', 'DK', 'DM', 'DO', 'DZ', 'EC', 'EE', 'EG', 'EH', 'ER', 'ES', 'ET', 'FI', 'FJ', 'FK', 'FM', 'FO', 'FR', 'GA', 'GB', 'GD', 'GE', 'GF', 'GG', 'GH', 'GI', 'GL', 'GM', 'GN', 'GP', 'GQ', 'GR', 'GS', 'GT', 'GU', 'GW', 'GY', 'HK', 'HM', 'HN', 'HR', 'HT', 'HU', 'ID', 'IE', 'IL', 'IM', 'IN', 'IO', 'IQ', 'IR', 'IS', 'IT', 'JE', 'JM', 'JO', 'JP', 'KE', 'KG', 'KH', 'KI', 'KM', 'KN', 'KP', 'KR', 'KW', 'KY', 'KZ', 'LA', 'LB', 'LC', 'LI', 'LK', 'LR', 'LS', 'LT', 'LU', 'LV', 'LY', 'MA', 'MC', 'MD', 'ME', 'MF', 'MG', 'MH', 'MK', 'ML', 'MM', 'MN', 'MO', 'MP', 'MQ', 'MR', 'MS', 'MT', 'MU', 'MV', 'MW', 'MX', 'MY', 'MZ', 'NA', 'NC', 'NE', 'NF', 'NG', 'NI', 'NL', 'NO', 'NP', 'NR', 'NU', 'NZ', 'OM', 'PA', 'PE', 'PF', 'PG', 'PH', 'PK', 'PL', 'PM', 'PN', 'PR', 'PS', 'PT', 'PW', 'PY', 'QA', 'RE', 'RO', 'RS', 'RU', 'RW', 'SA', 'SB', 'SC', 'SD', 'SE', 'SG', 'SH', 'SI', 'SJ', 'SK', 'SL', 'SM', 'SN', 'SO', 'SR', 'SS', 'ST', 'SV', 'SX', 'SY', 'SZ', 'TC', 'TD', 'TF', 'TG', 'TH', 'TJ', 'TK', 'TL', 'TM', 'TN', 'TO', 'TR', 'TT', 'TV', 'TW', 'TZ', 'UA', 'UG', 'UM', 'US', 'UY', 'UZ', 'VA', 'VC', 'VE', 'VG', 'VI', 'VN', 'VU', 'WF', 'WS', 'YE', 'YT', 'ZA', 'ZM', 'ZW']);
+function isISO31661Alpha2(str) {
+ assertString(str);
+ return validISO31661Alpha2CountriesCodes.has(str.toUpperCase());
+}
+var CountryCodes = validISO31661Alpha2CountriesCodes;
+
+var isBICReg = /^[A-Za-z]{6}[A-Za-z0-9]{2}([A-Za-z0-9]{3})?$/;
+function isBIC(str) {
+ assertString(str); // toUpperCase() should be removed when a new major version goes out that changes
+ // the regex to [A-Z] (per the spec).
+
+ var countryCode = str.slice(4, 6).toUpperCase();
+
+ if (!CountryCodes.has(countryCode) && countryCode !== 'XK') {
+ return false;
+ }
+
+ return isBICReg.test(str);
+}
+
+var md5 = /^[a-f0-9]{32}$/;
+function isMD5(str) {
+ assertString(str);
+ return md5.test(str);
+}
+
+var lengths = {
+ md5: 32,
+ md4: 32,
+ sha1: 40,
+ sha256: 64,
+ sha384: 96,
+ sha512: 128,
+ ripemd128: 32,
+ ripemd160: 40,
+ tiger128: 32,
+ tiger160: 40,
+ tiger192: 48,
+ crc32: 8,
+ crc32b: 8
+};
+function isHash(str, algorithm) {
+ assertString(str);
+ var hash = new RegExp("^[a-fA-F0-9]{".concat(lengths[algorithm], "}$"));
+ return hash.test(str);
+}
+
+var notBase64 = /[^A-Z0-9+\/=]/i;
+var urlSafeBase64 = /^[A-Z0-9_\-]*$/i;
+var defaultBase64Options = {
+ urlSafe: false
+};
+function isBase64(str, options) {
+ assertString(str);
+ options = merge(options, defaultBase64Options);
+ var len = str.length;
+
+ if (options.urlSafe) {
+ return urlSafeBase64.test(str);
+ }
+
+ if (len % 4 !== 0 || notBase64.test(str)) {
+ return false;
+ }
+
+ var firstPaddingChar = str.indexOf('=');
+ return firstPaddingChar === -1 || firstPaddingChar === len - 1 || firstPaddingChar === len - 2 && str[len - 1] === '=';
+}
+
+function isJWT(str) {
+ assertString(str);
+ var dotSplit = str.split('.');
+ var len = dotSplit.length;
+
+ if (len > 3 || len < 2) {
+ return false;
+ }
+
+ return dotSplit.reduce(function (acc, currElem) {
+ return acc && isBase64(currElem, {
+ urlSafe: true
+ });
+ }, true);
+}
+
+var default_json_options = {
+ allow_primitives: false
+};
+function isJSON(str, options) {
+ assertString(str);
+
+ try {
+ options = merge(options, default_json_options);
+ var primitives = [];
+
+ if (options.allow_primitives) {
+ primitives = [null, false, true];
+ }
+
+ var obj = JSON.parse(str);
+ return primitives.includes(obj) || !!obj && _typeof(obj) === 'object';
+ } catch (e) {
+ /* ignore */
+ }
+
+ return false;
+}
+
+var default_is_empty_options = {
+ ignore_whitespace: false
+};
+function isEmpty(str, options) {
+ assertString(str);
+ options = merge(options, default_is_empty_options);
+ return (options.ignore_whitespace ? str.trim().length : str.length) === 0;
+}
+
+/* eslint-disable prefer-rest-params */
+
+function isLength(str, options) {
+ assertString(str);
+ var min;
+ var max;
+
+ if (_typeof(options) === 'object') {
+ min = options.min || 0;
+ max = options.max;
+ } else {
+ // backwards compatibility: isLength(str, min [, max])
+ min = arguments[1] || 0;
+ max = arguments[2];
+ }
+
+ var presentationSequences = str.match(/(\uFE0F|\uFE0E)/g) || [];
+ var surrogatePairs = str.match(/[\uD800-\uDBFF][\uDC00-\uDFFF]/g) || [];
+ var len = str.length - presentationSequences.length - surrogatePairs.length;
+ return len >= min && (typeof max === 'undefined' || len <= max);
+}
+
+var uuid = {
+ 1: /^[0-9A-F]{8}-[0-9A-F]{4}-1[0-9A-F]{3}-[0-9A-F]{4}-[0-9A-F]{12}$/i,
+ 2: /^[0-9A-F]{8}-[0-9A-F]{4}-2[0-9A-F]{3}-[0-9A-F]{4}-[0-9A-F]{12}$/i,
+ 3: /^[0-9A-F]{8}-[0-9A-F]{4}-3[0-9A-F]{3}-[0-9A-F]{4}-[0-9A-F]{12}$/i,
+ 4: /^[0-9A-F]{8}-[0-9A-F]{4}-4[0-9A-F]{3}-[89AB][0-9A-F]{3}-[0-9A-F]{12}$/i,
+ 5: /^[0-9A-F]{8}-[0-9A-F]{4}-5[0-9A-F]{3}-[89AB][0-9A-F]{3}-[0-9A-F]{12}$/i,
+ all: /^[0-9A-F]{8}-[0-9A-F]{4}-[0-9A-F]{4}-[0-9A-F]{4}-[0-9A-F]{12}$/i
+};
+function isUUID(str, version) {
+ assertString(str);
+ var pattern = uuid[![undefined, null].includes(version) ? version : 'all'];
+ return !!pattern && pattern.test(str);
+}
+
+function isMongoId(str) {
+ assertString(str);
+ return isHexadecimal(str) && str.length === 24;
+}
+
+function isAfter(date, options) {
+ // For backwards compatibility:
+ // isAfter(str [, date]), i.e. `options` could be used as argument for the legacy `date`
+ var comparisonDate = (options === null || options === void 0 ? void 0 : options.comparisonDate) || options || Date().toString();
+ var comparison = toDate(comparisonDate);
+ var original = toDate(date);
+ return !!(original && comparison && original > comparison);
+}
+
+function isBefore(str) {
+ var date = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : String(new Date());
+ assertString(str);
+ var comparison = toDate(date);
+ var original = toDate(str);
+ return !!(original && comparison && original < comparison);
+}
+
+function isIn(str, options) {
+ assertString(str);
+ var i;
+
+ if (Object.prototype.toString.call(options) === '[object Array]') {
+ var array = [];
+
+ for (i in options) {
+ // https://github.com/gotwarlost/istanbul/blob/master/ignoring-code-for-coverage.md#ignoring-code-for-coverage-purposes
+ // istanbul ignore else
+ if ({}.hasOwnProperty.call(options, i)) {
+ array[i] = toString$1(options[i]);
+ }
+ }
+
+ return array.indexOf(str) >= 0;
+ } else if (_typeof(options) === 'object') {
+ return options.hasOwnProperty(str);
+ } else if (options && typeof options.indexOf === 'function') {
+ return options.indexOf(str) >= 0;
+ }
+
+ return false;
+}
+
+function isLuhnNumber(str) {
+ assertString(str);
+ var sanitized = str.replace(/[- ]+/g, '');
+ var sum = 0;
+ var digit;
+ var tmpNum;
+ var shouldDouble;
+
+ for (var i = sanitized.length - 1; i >= 0; i--) {
+ digit = sanitized.substring(i, i + 1);
+ tmpNum = parseInt(digit, 10);
+
+ if (shouldDouble) {
+ tmpNum *= 2;
+
+ if (tmpNum >= 10) {
+ sum += tmpNum % 10 + 1;
+ } else {
+ sum += tmpNum;
+ }
+ } else {
+ sum += tmpNum;
+ }
+
+ shouldDouble = !shouldDouble;
+ }
+
+ return !!(sum % 10 === 0 ? sanitized : false);
+}
+
+var cards = {
+ amex: /^3[47][0-9]{13}$/,
+ dinersclub: /^3(?:0[0-5]|[68][0-9])[0-9]{11}$/,
+ discover: /^6(?:011|5[0-9][0-9])[0-9]{12,15}$/,
+ jcb: /^(?:2131|1800|35\d{3})\d{11}$/,
+ mastercard: /^5[1-5][0-9]{2}|(222[1-9]|22[3-9][0-9]|2[3-6][0-9]{2}|27[01][0-9]|2720)[0-9]{12}$/,
+ // /^[25][1-7][0-9]{14}$/;
+ unionpay: /^(6[27][0-9]{14}|^(81[0-9]{14,17}))$/,
+ visa: /^(?:4[0-9]{12})(?:[0-9]{3,6})?$/
+};
+/* eslint-disable max-len */
+
+var allCards = /^(?:4[0-9]{12}(?:[0-9]{3,6})?|5[1-5][0-9]{14}|(222[1-9]|22[3-9][0-9]|2[3-6][0-9]{2}|27[01][0-9]|2720)[0-9]{12}|6(?:011|5[0-9][0-9])[0-9]{12,15}|3[47][0-9]{13}|3(?:0[0-5]|[68][0-9])[0-9]{11}|(?:2131|1800|35\d{3})\d{11}|6[27][0-9]{14}|^(81[0-9]{14,17}))$/;
+/* eslint-enable max-len */
+
+function isCreditCard(card) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ assertString(card);
+ var provider = options.provider;
+ var sanitized = card.replace(/[- ]+/g, '');
+
+ if (provider && provider.toLowerCase() in cards) {
+ // specific provider in the list
+ if (!cards[provider.toLowerCase()].test(sanitized)) {
+ return false;
+ }
+ } else if (provider && !(provider.toLowerCase() in cards)) {
+ /* specific provider not in the list */
+ throw new Error("".concat(provider, " is not a valid credit card provider."));
+ } else if (!allCards.test(sanitized)) {
+ // no specific provider
+ return false;
+ }
+
+ return isLuhnNumber(card);
+}
+
+var validators = {
+ PL: function PL(str) {
+ assertString(str);
+ var weightOfDigits = {
+ 1: 1,
+ 2: 3,
+ 3: 7,
+ 4: 9,
+ 5: 1,
+ 6: 3,
+ 7: 7,
+ 8: 9,
+ 9: 1,
+ 10: 3,
+ 11: 0
+ };
+
+ if (str != null && str.length === 11 && isInt(str, {
+ allow_leading_zeroes: true
+ })) {
+ var digits = str.split('').slice(0, -1);
+ var sum = digits.reduce(function (acc, digit, index) {
+ return acc + Number(digit) * weightOfDigits[index + 1];
+ }, 0);
+ var modulo = sum % 10;
+ var lastDigit = Number(str.charAt(str.length - 1));
+
+ if (modulo === 0 && lastDigit === 0 || lastDigit === 10 - modulo) {
+ return true;
+ }
+ }
+
+ return false;
+ },
+ ES: function ES(str) {
+ assertString(str);
+ var DNI = /^[0-9X-Z][0-9]{7}[TRWAGMYFPDXBNJZSQVHLCKE]$/;
+ var charsValue = {
+ X: 0,
+ Y: 1,
+ Z: 2
+ };
+ var controlDigits = ['T', 'R', 'W', 'A', 'G', 'M', 'Y', 'F', 'P', 'D', 'X', 'B', 'N', 'J', 'Z', 'S', 'Q', 'V', 'H', 'L', 'C', 'K', 'E']; // sanitize user input
+
+ var sanitized = str.trim().toUpperCase(); // validate the data structure
+
+ if (!DNI.test(sanitized)) {
+ return false;
+ } // validate the control digit
+
+
+ var number = sanitized.slice(0, -1).replace(/[X,Y,Z]/g, function (_char) {
+ return charsValue[_char];
+ });
+ return sanitized.endsWith(controlDigits[number % 23]);
+ },
+ FI: function FI(str) {
+ // https://dvv.fi/en/personal-identity-code#:~:text=control%20character%20for%20a-,personal,-identity%20code%20calculated
+ assertString(str);
+
+ if (str.length !== 11) {
+ return false;
+ }
+
+ if (!str.match(/^\d{6}[\-A\+]\d{3}[0-9ABCDEFHJKLMNPRSTUVWXY]{1}$/)) {
+ return false;
+ }
+
+ var checkDigits = '0123456789ABCDEFHJKLMNPRSTUVWXY';
+ var idAsNumber = parseInt(str.slice(0, 6), 10) * 1000 + parseInt(str.slice(7, 10), 10);
+ var remainder = idAsNumber % 31;
+ var checkDigit = checkDigits[remainder];
+ return checkDigit === str.slice(10, 11);
+ },
+ IN: function IN(str) {
+ var DNI = /^[1-9]\d{3}\s?\d{4}\s?\d{4}$/; // multiplication table
+
+ var d = [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9], [1, 2, 3, 4, 0, 6, 7, 8, 9, 5], [2, 3, 4, 0, 1, 7, 8, 9, 5, 6], [3, 4, 0, 1, 2, 8, 9, 5, 6, 7], [4, 0, 1, 2, 3, 9, 5, 6, 7, 8], [5, 9, 8, 7, 6, 0, 4, 3, 2, 1], [6, 5, 9, 8, 7, 1, 0, 4, 3, 2], [7, 6, 5, 9, 8, 2, 1, 0, 4, 3], [8, 7, 6, 5, 9, 3, 2, 1, 0, 4], [9, 8, 7, 6, 5, 4, 3, 2, 1, 0]]; // permutation table
+
+ var p = [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9], [1, 5, 7, 6, 2, 8, 3, 0, 9, 4], [5, 8, 0, 3, 7, 9, 6, 1, 4, 2], [8, 9, 1, 6, 0, 4, 3, 5, 2, 7], [9, 4, 5, 3, 1, 2, 6, 8, 7, 0], [4, 2, 8, 6, 5, 7, 3, 9, 0, 1], [2, 7, 9, 3, 8, 0, 6, 4, 1, 5], [7, 0, 4, 6, 9, 1, 3, 2, 5, 8]]; // sanitize user input
+
+ var sanitized = str.trim(); // validate the data structure
+
+ if (!DNI.test(sanitized)) {
+ return false;
+ }
+
+ var c = 0;
+ var invertedArray = sanitized.replace(/\s/g, '').split('').map(Number).reverse();
+ invertedArray.forEach(function (val, i) {
+ c = d[c][p[i % 8][val]];
+ });
+ return c === 0;
+ },
+ IR: function IR(str) {
+ if (!str.match(/^\d{10}$/)) return false;
+ str = "0000".concat(str).slice(str.length - 6);
+ if (parseInt(str.slice(3, 9), 10) === 0) return false;
+ var lastNumber = parseInt(str.slice(9, 10), 10);
+ var sum = 0;
+
+ for (var i = 0; i < 9; i++) {
+ sum += parseInt(str.slice(i, i + 1), 10) * (10 - i);
+ }
+
+ sum %= 11;
+ return sum < 2 && lastNumber === sum || sum >= 2 && lastNumber === 11 - sum;
+ },
+ IT: function IT(str) {
+ if (str.length !== 9) return false;
+ if (str === 'CA00000AA') return false; // https://it.wikipedia.org/wiki/Carta_d%27identit%C3%A0_elettronica_italiana
+
+ return str.search(/C[A-Z][0-9]{5}[A-Z]{2}/i) > -1;
+ },
+ NO: function NO(str) {
+ var sanitized = str.trim();
+ if (isNaN(Number(sanitized))) return false;
+ if (sanitized.length !== 11) return false;
+ if (sanitized === '00000000000') return false; // https://no.wikipedia.org/wiki/F%C3%B8dselsnummer
+
+ var f = sanitized.split('').map(Number);
+ var k1 = (11 - (3 * f[0] + 7 * f[1] + 6 * f[2] + 1 * f[3] + 8 * f[4] + 9 * f[5] + 4 * f[6] + 5 * f[7] + 2 * f[8]) % 11) % 11;
+ var k2 = (11 - (5 * f[0] + 4 * f[1] + 3 * f[2] + 2 * f[3] + 7 * f[4] + 6 * f[5] + 5 * f[6] + 4 * f[7] + 3 * f[8] + 2 * k1) % 11) % 11;
+ if (k1 !== f[9] || k2 !== f[10]) return false;
+ return true;
+ },
+ TH: function TH(str) {
+ if (!str.match(/^[1-8]\d{12}$/)) return false; // validate check digit
+
+ var sum = 0;
+
+ for (var i = 0; i < 12; i++) {
+ sum += parseInt(str[i], 10) * (13 - i);
+ }
+
+ return str[12] === ((11 - sum % 11) % 10).toString();
+ },
+ LK: function LK(str) {
+ var old_nic = /^[1-9]\d{8}[vx]$/i;
+ var new_nic = /^[1-9]\d{11}$/i;
+ if (str.length === 10 && old_nic.test(str)) return true;else if (str.length === 12 && new_nic.test(str)) return true;
+ return false;
+ },
+ 'he-IL': function heIL(str) {
+ var DNI = /^\d{9}$/; // sanitize user input
+
+ var sanitized = str.trim(); // validate the data structure
+
+ if (!DNI.test(sanitized)) {
+ return false;
+ }
+
+ var id = sanitized;
+ var sum = 0,
+ incNum;
+
+ for (var i = 0; i < id.length; i++) {
+ incNum = Number(id[i]) * (i % 2 + 1); // Multiply number by 1 or 2
+
+ sum += incNum > 9 ? incNum - 9 : incNum; // Sum the digits up and add to total
+ }
+
+ return sum % 10 === 0;
+ },
+ 'ar-LY': function arLY(str) {
+ // Libya National Identity Number NIN is 12 digits, the first digit is either 1 or 2
+ var NIN = /^(1|2)\d{11}$/; // sanitize user input
+
+ var sanitized = str.trim(); // validate the data structure
+
+ if (!NIN.test(sanitized)) {
+ return false;
+ }
+
+ return true;
+ },
+ 'ar-TN': function arTN(str) {
+ var DNI = /^\d{8}$/; // sanitize user input
+
+ var sanitized = str.trim(); // validate the data structure
+
+ if (!DNI.test(sanitized)) {
+ return false;
+ }
+
+ return true;
+ },
+ 'zh-CN': function zhCN(str) {
+ var provincesAndCities = ['11', // 北京
+ '12', // 天津
+ '13', // 河北
+ '14', // 山西
+ '15', // 内蒙古
+ '21', // 辽宁
+ '22', // 吉林
+ '23', // 黑龙江
+ '31', // 上海
+ '32', // 江苏
+ '33', // 浙江
+ '34', // 安徽
+ '35', // 福建
+ '36', // 江西
+ '37', // 山东
+ '41', // 河南
+ '42', // 湖北
+ '43', // 湖南
+ '44', // 广东
+ '45', // 广西
+ '46', // 海南
+ '50', // 重庆
+ '51', // 四川
+ '52', // 贵州
+ '53', // 云南
+ '54', // 西藏
+ '61', // 陕西
+ '62', // 甘肃
+ '63', // 青海
+ '64', // 宁夏
+ '65', // 新疆
+ '71', // 台湾
+ '81', // 香港
+ '82', // 澳门
+ '91' // 国外
+ ];
+ var powers = ['7', '9', '10', '5', '8', '4', '2', '1', '6', '3', '7', '9', '10', '5', '8', '4', '2'];
+ var parityBit = ['1', '0', 'X', '9', '8', '7', '6', '5', '4', '3', '2'];
+
+ var checkAddressCode = function checkAddressCode(addressCode) {
+ return provincesAndCities.includes(addressCode);
+ };
+
+ var checkBirthDayCode = function checkBirthDayCode(birDayCode) {
+ var yyyy = parseInt(birDayCode.substring(0, 4), 10);
+ var mm = parseInt(birDayCode.substring(4, 6), 10);
+ var dd = parseInt(birDayCode.substring(6), 10);
+ var xdata = new Date(yyyy, mm - 1, dd);
+
+ if (xdata > new Date()) {
+ return false; // eslint-disable-next-line max-len
+ } else if (xdata.getFullYear() === yyyy && xdata.getMonth() === mm - 1 && xdata.getDate() === dd) {
+ return true;
+ }
+
+ return false;
+ };
+
+ var getParityBit = function getParityBit(idCardNo) {
+ var id17 = idCardNo.substring(0, 17);
+ var power = 0;
+
+ for (var i = 0; i < 17; i++) {
+ power += parseInt(id17.charAt(i), 10) * parseInt(powers[i], 10);
+ }
+
+ var mod = power % 11;
+ return parityBit[mod];
+ };
+
+ var checkParityBit = function checkParityBit(idCardNo) {
+ return getParityBit(idCardNo) === idCardNo.charAt(17).toUpperCase();
+ };
+
+ var check15IdCardNo = function check15IdCardNo(idCardNo) {
+ var check = /^[1-9]\d{7}((0[1-9])|(1[0-2]))((0[1-9])|([1-2][0-9])|(3[0-1]))\d{3}$/.test(idCardNo);
+ if (!check) return false;
+ var addressCode = idCardNo.substring(0, 2);
+ check = checkAddressCode(addressCode);
+ if (!check) return false;
+ var birDayCode = "19".concat(idCardNo.substring(6, 12));
+ check = checkBirthDayCode(birDayCode);
+ if (!check) return false;
+ return true;
+ };
+
+ var check18IdCardNo = function check18IdCardNo(idCardNo) {
+ var check = /^[1-9]\d{5}[1-9]\d{3}((0[1-9])|(1[0-2]))((0[1-9])|([1-2][0-9])|(3[0-1]))\d{3}(\d|x|X)$/.test(idCardNo);
+ if (!check) return false;
+ var addressCode = idCardNo.substring(0, 2);
+ check = checkAddressCode(addressCode);
+ if (!check) return false;
+ var birDayCode = idCardNo.substring(6, 14);
+ check = checkBirthDayCode(birDayCode);
+ if (!check) return false;
+ return checkParityBit(idCardNo);
+ };
+
+ var checkIdCardNo = function checkIdCardNo(idCardNo) {
+ var check = /^\d{15}|(\d{17}(\d|x|X))$/.test(idCardNo);
+ if (!check) return false;
+
+ if (idCardNo.length === 15) {
+ return check15IdCardNo(idCardNo);
+ }
+
+ return check18IdCardNo(idCardNo);
+ };
+
+ return checkIdCardNo(str);
+ },
+ 'zh-HK': function zhHK(str) {
+ // sanitize user input
+ str = str.trim(); // HKID number starts with 1 or 2 letters, followed by 6 digits,
+ // then a checksum contained in square / round brackets or nothing
+
+ var regexHKID = /^[A-Z]{1,2}[0-9]{6}((\([0-9A]\))|(\[[0-9A]\])|([0-9A]))$/;
+ var regexIsDigit = /^[0-9]$/; // convert the user input to all uppercase and apply regex
+
+ str = str.toUpperCase();
+ if (!regexHKID.test(str)) return false;
+ str = str.replace(/\[|\]|\(|\)/g, '');
+ if (str.length === 8) str = "3".concat(str);
+ var checkSumVal = 0;
+
+ for (var i = 0; i <= 7; i++) {
+ var convertedChar = void 0;
+ if (!regexIsDigit.test(str[i])) convertedChar = (str[i].charCodeAt(0) - 55) % 11;else convertedChar = str[i];
+ checkSumVal += convertedChar * (9 - i);
+ }
+
+ checkSumVal %= 11;
+ var checkSumConverted;
+ if (checkSumVal === 0) checkSumConverted = '0';else if (checkSumVal === 1) checkSumConverted = 'A';else checkSumConverted = String(11 - checkSumVal);
+ if (checkSumConverted === str[str.length - 1]) return true;
+ return false;
+ },
+ 'zh-TW': function zhTW(str) {
+ var ALPHABET_CODES = {
+ A: 10,
+ B: 11,
+ C: 12,
+ D: 13,
+ E: 14,
+ F: 15,
+ G: 16,
+ H: 17,
+ I: 34,
+ J: 18,
+ K: 19,
+ L: 20,
+ M: 21,
+ N: 22,
+ O: 35,
+ P: 23,
+ Q: 24,
+ R: 25,
+ S: 26,
+ T: 27,
+ U: 28,
+ V: 29,
+ W: 32,
+ X: 30,
+ Y: 31,
+ Z: 33
+ };
+ var sanitized = str.trim().toUpperCase();
+ if (!/^[A-Z][0-9]{9}$/.test(sanitized)) return false;
+ return Array.from(sanitized).reduce(function (sum, number, index) {
+ if (index === 0) {
+ var code = ALPHABET_CODES[number];
+ return code % 10 * 9 + Math.floor(code / 10);
+ }
+
+ if (index === 9) {
+ return (10 - sum % 10 - Number(number)) % 10 === 0;
+ }
+
+ return sum + Number(number) * (9 - index);
+ }, 0);
+ }
+};
+function isIdentityCard(str, locale) {
+ assertString(str);
+
+ if (locale in validators) {
+ return validators[locale](str);
+ } else if (locale === 'any') {
+ for (var key in validators) {
+ // https://github.com/gotwarlost/istanbul/blob/master/ignoring-code-for-coverage.md#ignoring-code-for-coverage-purposes
+ // istanbul ignore else
+ if (validators.hasOwnProperty(key)) {
+ var validator = validators[key];
+
+ if (validator(str)) {
+ return true;
+ }
+ }
+ }
+
+ return false;
+ }
+
+ throw new Error("Invalid locale '".concat(locale, "'"));
+}
+
+/**
+ * The most commonly used EAN standard is
+ * the thirteen-digit EAN-13, while the
+ * less commonly used 8-digit EAN-8 barcode was
+ * introduced for use on small packages.
+ * Also EAN/UCC-14 is used for Grouping of individual
+ * trade items above unit level(Intermediate, Carton or Pallet).
+ * For more info about EAN-14 checkout: https://www.gtin.info/itf-14-barcodes/
+ * EAN consists of:
+ * GS1 prefix, manufacturer code, product code and check digit
+ * Reference: https://en.wikipedia.org/wiki/International_Article_Number
+ * Reference: https://www.gtin.info/
+ */
+/**
+ * Define EAN Lenghts; 8 for EAN-8; 13 for EAN-13; 14 for EAN-14
+ * and Regular Expression for valid EANs (EAN-8, EAN-13, EAN-14),
+ * with exact numberic matching of 8 or 13 or 14 digits [0-9]
+ */
+
+var LENGTH_EAN_8 = 8;
+var LENGTH_EAN_14 = 14;
+var validEanRegex = /^(\d{8}|\d{13}|\d{14})$/;
+/**
+ * Get position weight given:
+ * EAN length and digit index/position
+ *
+ * @param {number} length
+ * @param {number} index
+ * @return {number}
+ */
+
+function getPositionWeightThroughLengthAndIndex(length, index) {
+ if (length === LENGTH_EAN_8 || length === LENGTH_EAN_14) {
+ return index % 2 === 0 ? 3 : 1;
+ }
+
+ return index % 2 === 0 ? 1 : 3;
+}
+/**
+ * Calculate EAN Check Digit
+ * Reference: https://en.wikipedia.org/wiki/International_Article_Number#Calculation_of_checksum_digit
+ *
+ * @param {string} ean
+ * @return {number}
+ */
+
+
+function calculateCheckDigit(ean) {
+ var checksum = ean.slice(0, -1).split('').map(function (_char, index) {
+ return Number(_char) * getPositionWeightThroughLengthAndIndex(ean.length, index);
+ }).reduce(function (acc, partialSum) {
+ return acc + partialSum;
+ }, 0);
+ var remainder = 10 - checksum % 10;
+ return remainder < 10 ? remainder : 0;
+}
+/**
+ * Check if string is valid EAN:
+ * Matches EAN-8/EAN-13/EAN-14 regex
+ * Has valid check digit.
+ *
+ * @param {string} str
+ * @return {boolean}
+ */
+
+
+function isEAN(str) {
+ assertString(str);
+ var actualCheckDigit = Number(str.slice(-1));
+ return validEanRegex.test(str) && actualCheckDigit === calculateCheckDigit(str);
+}
+
+var isin = /^[A-Z]{2}[0-9A-Z]{9}[0-9]$/; // this link details how the check digit is calculated:
+// https://www.isin.org/isin-format/. it is a little bit
+// odd in that it works with digits, not numbers. in order
+// to make only one pass through the ISIN characters, the
+// each alpha character is handled as 2 characters within
+// the loop.
+
+function isISIN(str) {
+ assertString(str);
+
+ if (!isin.test(str)) {
+ return false;
+ }
+
+ var _double = true;
+ var sum = 0; // convert values
+
+ for (var i = str.length - 2; i >= 0; i--) {
+ if (str[i] >= 'A' && str[i] <= 'Z') {
+ var value = str[i].charCodeAt(0) - 55;
+ var lo = value % 10;
+ var hi = Math.trunc(value / 10); // letters have two digits, so handle the low order
+ // and high order digits separately.
+
+ for (var _i = 0, _arr = [lo, hi]; _i < _arr.length; _i++) {
+ var digit = _arr[_i];
+
+ if (_double) {
+ if (digit >= 5) {
+ sum += 1 + (digit - 5) * 2;
+ } else {
+ sum += digit * 2;
+ }
+ } else {
+ sum += digit;
+ }
+
+ _double = !_double;
+ }
+ } else {
+ var _digit = str[i].charCodeAt(0) - '0'.charCodeAt(0);
+
+ if (_double) {
+ if (_digit >= 5) {
+ sum += 1 + (_digit - 5) * 2;
+ } else {
+ sum += _digit * 2;
+ }
+ } else {
+ sum += _digit;
+ }
+
+ _double = !_double;
+ }
+ }
+
+ var check = Math.trunc((sum + 9) / 10) * 10 - sum;
+ return +str[str.length - 1] === check;
+}
+
+var possibleIsbn10 = /^(?:[0-9]{9}X|[0-9]{10})$/;
+var possibleIsbn13 = /^(?:[0-9]{13})$/;
+var factor = [1, 3];
+function isISBN(isbn, options) {
+ assertString(isbn); // For backwards compatibility:
+ // isISBN(str [, version]), i.e. `options` could be used as argument for the legacy `version`
+
+ var version = String((options === null || options === void 0 ? void 0 : options.version) || options);
+
+ if (!(options !== null && options !== void 0 && options.version || options)) {
+ return isISBN(isbn, {
+ version: 10
+ }) || isISBN(isbn, {
+ version: 13
+ });
+ }
+
+ var sanitizedIsbn = isbn.replace(/[\s-]+/g, '');
+ var checksum = 0;
+
+ if (version === '10') {
+ if (!possibleIsbn10.test(sanitizedIsbn)) {
+ return false;
+ }
+
+ for (var i = 0; i < version - 1; i++) {
+ checksum += (i + 1) * sanitizedIsbn.charAt(i);
+ }
+
+ if (sanitizedIsbn.charAt(9) === 'X') {
+ checksum += 10 * 10;
+ } else {
+ checksum += 10 * sanitizedIsbn.charAt(9);
+ }
+
+ if (checksum % 11 === 0) {
+ return true;
+ }
+ } else if (version === '13') {
+ if (!possibleIsbn13.test(sanitizedIsbn)) {
+ return false;
+ }
+
+ for (var _i = 0; _i < 12; _i++) {
+ checksum += factor[_i % 2] * sanitizedIsbn.charAt(_i);
+ }
+
+ if (sanitizedIsbn.charAt(12) - (10 - checksum % 10) % 10 === 0) {
+ return true;
+ }
+ }
+
+ return false;
+}
+
+var issn = '^\\d{4}-?\\d{3}[\\dX]$';
+function isISSN(str) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ assertString(str);
+ var testIssn = issn;
+ testIssn = options.require_hyphen ? testIssn.replace('?', '') : testIssn;
+ testIssn = options.case_sensitive ? new RegExp(testIssn) : new RegExp(testIssn, 'i');
+
+ if (!testIssn.test(str)) {
+ return false;
+ }
+
+ var digits = str.replace('-', '').toUpperCase();
+ var checksum = 0;
+
+ for (var i = 0; i < digits.length; i++) {
+ var digit = digits[i];
+ checksum += (digit === 'X' ? 10 : +digit) * (8 - i);
+ }
+
+ return checksum % 11 === 0;
+}
+
+/**
+ * Algorithmic validation functions
+ * May be used as is or implemented in the workflow of other validators.
+ */
+
+/*
+ * ISO 7064 validation function
+ * Called with a string of numbers (incl. check digit)
+ * to validate according to ISO 7064 (MOD 11, 10).
+ */
+function iso7064Check(str) {
+ var checkvalue = 10;
+
+ for (var i = 0; i < str.length - 1; i++) {
+ checkvalue = (parseInt(str[i], 10) + checkvalue) % 10 === 0 ? 10 * 2 % 11 : (parseInt(str[i], 10) + checkvalue) % 10 * 2 % 11;
+ }
+
+ checkvalue = checkvalue === 1 ? 0 : 11 - checkvalue;
+ return checkvalue === parseInt(str[10], 10);
+}
+/*
+ * Luhn (mod 10) validation function
+ * Called with a string of numbers (incl. check digit)
+ * to validate according to the Luhn algorithm.
+ */
+
+function luhnCheck(str) {
+ var checksum = 0;
+ var second = false;
+
+ for (var i = str.length - 1; i >= 0; i--) {
+ if (second) {
+ var product = parseInt(str[i], 10) * 2;
+
+ if (product > 9) {
+ // sum digits of product and add to checksum
+ checksum += product.toString().split('').map(function (a) {
+ return parseInt(a, 10);
+ }).reduce(function (a, b) {
+ return a + b;
+ }, 0);
+ } else {
+ checksum += product;
+ }
+ } else {
+ checksum += parseInt(str[i], 10);
+ }
+
+ second = !second;
+ }
+
+ return checksum % 10 === 0;
+}
+/*
+ * Reverse TIN multiplication and summation helper function
+ * Called with an array of single-digit integers and a base multiplier
+ * to calculate the sum of the digits multiplied in reverse.
+ * Normally used in variations of MOD 11 algorithmic checks.
+ */
+
+function reverseMultiplyAndSum(digits, base) {
+ var total = 0;
+
+ for (var i = 0; i < digits.length; i++) {
+ total += digits[i] * (base - i);
+ }
+
+ return total;
+}
+/*
+ * Verhoeff validation helper function
+ * Called with a string of numbers
+ * to validate according to the Verhoeff algorithm.
+ */
+
+function verhoeffCheck(str) {
+ var d_table = [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9], [1, 2, 3, 4, 0, 6, 7, 8, 9, 5], [2, 3, 4, 0, 1, 7, 8, 9, 5, 6], [3, 4, 0, 1, 2, 8, 9, 5, 6, 7], [4, 0, 1, 2, 3, 9, 5, 6, 7, 8], [5, 9, 8, 7, 6, 0, 4, 3, 2, 1], [6, 5, 9, 8, 7, 1, 0, 4, 3, 2], [7, 6, 5, 9, 8, 2, 1, 0, 4, 3], [8, 7, 6, 5, 9, 3, 2, 1, 0, 4], [9, 8, 7, 6, 5, 4, 3, 2, 1, 0]];
+ var p_table = [[0, 1, 2, 3, 4, 5, 6, 7, 8, 9], [1, 5, 7, 6, 2, 8, 3, 0, 9, 4], [5, 8, 0, 3, 7, 9, 6, 1, 4, 2], [8, 9, 1, 6, 0, 4, 3, 5, 2, 7], [9, 4, 5, 3, 1, 2, 6, 8, 7, 0], [4, 2, 8, 6, 5, 7, 3, 9, 0, 1], [2, 7, 9, 3, 8, 0, 6, 4, 1, 5], [7, 0, 4, 6, 9, 1, 3, 2, 5, 8]]; // Copy (to prevent replacement) and reverse
+
+ var str_copy = str.split('').reverse().join('');
+ var checksum = 0;
+
+ for (var i = 0; i < str_copy.length; i++) {
+ checksum = d_table[checksum][p_table[i % 8][parseInt(str_copy[i], 10)]];
+ }
+
+ return checksum === 0;
+}
+
+/**
+ * TIN Validation
+ * Validates Tax Identification Numbers (TINs) from the US, EU member states and the United Kingdom.
+ *
+ * EU-UK:
+ * National TIN validity is calculated using public algorithms as made available by DG TAXUD.
+ *
+ * See `https://ec.europa.eu/taxation_customs/tin/specs/FS-TIN%20Algorithms-Public.docx` for more information.
+ *
+ * US:
+ * An Employer Identification Number (EIN), also known as a Federal Tax Identification Number,
+ * is used to identify a business entity.
+ *
+ * NOTES:
+ * - Prefix 47 is being reserved for future use
+ * - Prefixes 26, 27, 45, 46 and 47 were previously assigned by the Philadelphia campus.
+ *
+ * See `http://www.irs.gov/Businesses/Small-Businesses-&-Self-Employed/How-EINs-are-Assigned-and-Valid-EIN-Prefixes`
+ * for more information.
+ */
+// Locale functions
+
+/*
+ * bg-BG validation function
+ * (Edinen graždanski nomer (EGN/ЕГН), persons only)
+ * Checks if birth date (first six digits) is valid and calculates check (last) digit
+ */
+
+function bgBgCheck(tin) {
+ // Extract full year, normalize month and check birth date validity
+ var century_year = tin.slice(0, 2);
+ var month = parseInt(tin.slice(2, 4), 10);
+
+ if (month > 40) {
+ month -= 40;
+ century_year = "20".concat(century_year);
+ } else if (month > 20) {
+ month -= 20;
+ century_year = "18".concat(century_year);
+ } else {
+ century_year = "19".concat(century_year);
+ }
+
+ if (month < 10) {
+ month = "0".concat(month);
+ }
+
+ var date = "".concat(century_year, "/").concat(month, "/").concat(tin.slice(4, 6));
+
+ if (!isDate(date, 'YYYY/MM/DD')) {
+ return false;
+ } // split digits into an array for further processing
+
+
+ var digits = tin.split('').map(function (a) {
+ return parseInt(a, 10);
+ }); // Calculate checksum by multiplying digits with fixed values
+
+ var multip_lookup = [2, 4, 8, 5, 10, 9, 7, 3, 6];
+ var checksum = 0;
+
+ for (var i = 0; i < multip_lookup.length; i++) {
+ checksum += digits[i] * multip_lookup[i];
+ }
+
+ checksum = checksum % 11 === 10 ? 0 : checksum % 11;
+ return checksum === digits[9];
+}
+/**
+ * Check if an input is a valid Canadian SIN (Social Insurance Number)
+ *
+ * The Social Insurance Number (SIN) is a 9 digit number that
+ * you need to work in Canada or to have access to government programs and benefits.
+ *
+ * https://en.wikipedia.org/wiki/Social_Insurance_Number
+ * https://www.canada.ca/en/employment-social-development/services/sin.html
+ * https://www.codercrunch.com/challenge/819302488/sin-validator
+ *
+ * @param {string} input
+ * @return {boolean}
+ */
+
+
+function isCanadianSIN(input) {
+ var digitsArray = input.split('');
+ var even = digitsArray.filter(function (_, idx) {
+ return idx % 2;
+ }).map(function (i) {
+ return Number(i) * 2;
+ }).join('').split('');
+ var total = digitsArray.filter(function (_, idx) {
+ return !(idx % 2);
+ }).concat(even).map(function (i) {
+ return Number(i);
+ }).reduce(function (acc, cur) {
+ return acc + cur;
+ });
+ return total % 10 === 0;
+}
+/*
+ * cs-CZ validation function
+ * (Rodné číslo (RČ), persons only)
+ * Checks if birth date (first six digits) is valid and divisibility by 11
+ * Material not in DG TAXUD document sourced from:
+ * -`https://lorenc.info/3MA381/overeni-spravnosti-rodneho-cisla.htm`
+ * -`https://www.mvcr.cz/clanek/rady-a-sluzby-dokumenty-rodne-cislo.aspx`
+ */
+
+
+function csCzCheck(tin) {
+ tin = tin.replace(/\W/, ''); // Extract full year from TIN length
+
+ var full_year = parseInt(tin.slice(0, 2), 10);
+
+ if (tin.length === 10) {
+ if (full_year < 54) {
+ full_year = "20".concat(full_year);
+ } else {
+ full_year = "19".concat(full_year);
+ }
+ } else {
+ if (tin.slice(6) === '000') {
+ return false;
+ } // Three-zero serial not assigned before 1954
+
+
+ if (full_year < 54) {
+ full_year = "19".concat(full_year);
+ } else {
+ return false; // No 18XX years seen in any of the resources
+ }
+ } // Add missing zero if needed
+
+
+ if (full_year.length === 3) {
+ full_year = [full_year.slice(0, 2), '0', full_year.slice(2)].join('');
+ } // Extract month from TIN and normalize
+
+
+ var month = parseInt(tin.slice(2, 4), 10);
+
+ if (month > 50) {
+ month -= 50;
+ }
+
+ if (month > 20) {
+ // Month-plus-twenty was only introduced in 2004
+ if (parseInt(full_year, 10) < 2004) {
+ return false;
+ }
+
+ month -= 20;
+ }
+
+ if (month < 10) {
+ month = "0".concat(month);
+ } // Check date validity
+
+
+ var date = "".concat(full_year, "/").concat(month, "/").concat(tin.slice(4, 6));
+
+ if (!isDate(date, 'YYYY/MM/DD')) {
+ return false;
+ } // Verify divisibility by 11
+
+
+ if (tin.length === 10) {
+ if (parseInt(tin, 10) % 11 !== 0) {
+ // Some numbers up to and including 1985 are still valid if
+ // check (last) digit equals 0 and modulo of first 9 digits equals 10
+ var checkdigit = parseInt(tin.slice(0, 9), 10) % 11;
+
+ if (parseInt(full_year, 10) < 1986 && checkdigit === 10) {
+ if (parseInt(tin.slice(9), 10) !== 0) {
+ return false;
+ }
+ } else {
+ return false;
+ }
+ }
+ }
+
+ return true;
+}
+/*
+ * de-AT validation function
+ * (Abgabenkontonummer, persons/entities)
+ * Verify TIN validity by calling luhnCheck()
+ */
+
+
+function deAtCheck(tin) {
+ return luhnCheck(tin);
+}
+/*
+ * de-DE validation function
+ * (Steueridentifikationsnummer (Steuer-IdNr.), persons only)
+ * Tests for single duplicate/triplicate value, then calculates ISO 7064 check (last) digit
+ * Partial implementation of spec (same result with both algorithms always)
+ */
+
+
+function deDeCheck(tin) {
+ // Split digits into an array for further processing
+ var digits = tin.split('').map(function (a) {
+ return parseInt(a, 10);
+ }); // Fill array with strings of number positions
+
+ var occurences = [];
+
+ for (var i = 0; i < digits.length - 1; i++) {
+ occurences.push('');
+
+ for (var j = 0; j < digits.length - 1; j++) {
+ if (digits[i] === digits[j]) {
+ occurences[i] += j;
+ }
+ }
+ } // Remove digits with one occurence and test for only one duplicate/triplicate
+
+
+ occurences = occurences.filter(function (a) {
+ return a.length > 1;
+ });
+
+ if (occurences.length !== 2 && occurences.length !== 3) {
+ return false;
+ } // In case of triplicate value only two digits are allowed next to each other
+
+
+ if (occurences[0].length === 3) {
+ var trip_locations = occurences[0].split('').map(function (a) {
+ return parseInt(a, 10);
+ });
+ var recurrent = 0; // Amount of neighbour occurences
+
+ for (var _i = 0; _i < trip_locations.length - 1; _i++) {
+ if (trip_locations[_i] + 1 === trip_locations[_i + 1]) {
+ recurrent += 1;
+ }
+ }
+
+ if (recurrent === 2) {
+ return false;
+ }
+ }
+
+ return iso7064Check(tin);
+}
+/*
+ * dk-DK validation function
+ * (CPR-nummer (personnummer), persons only)
+ * Checks if birth date (first six digits) is valid and assigned to century (seventh) digit,
+ * and calculates check (last) digit
+ */
+
+
+function dkDkCheck(tin) {
+ tin = tin.replace(/\W/, ''); // Extract year, check if valid for given century digit and add century
+
+ var year = parseInt(tin.slice(4, 6), 10);
+ var century_digit = tin.slice(6, 7);
+
+ switch (century_digit) {
+ case '0':
+ case '1':
+ case '2':
+ case '3':
+ year = "19".concat(year);
+ break;
+
+ case '4':
+ case '9':
+ if (year < 37) {
+ year = "20".concat(year);
+ } else {
+ year = "19".concat(year);
+ }
+
+ break;
+
+ default:
+ if (year < 37) {
+ year = "20".concat(year);
+ } else if (year > 58) {
+ year = "18".concat(year);
+ } else {
+ return false;
+ }
+
+ break;
+ } // Add missing zero if needed
+
+
+ if (year.length === 3) {
+ year = [year.slice(0, 2), '0', year.slice(2)].join('');
+ } // Check date validity
+
+
+ var date = "".concat(year, "/").concat(tin.slice(2, 4), "/").concat(tin.slice(0, 2));
+
+ if (!isDate(date, 'YYYY/MM/DD')) {
+ return false;
+ } // Split digits into an array for further processing
+
+
+ var digits = tin.split('').map(function (a) {
+ return parseInt(a, 10);
+ });
+ var checksum = 0;
+ var weight = 4; // Multiply by weight and add to checksum
+
+ for (var i = 0; i < 9; i++) {
+ checksum += digits[i] * weight;
+ weight -= 1;
+
+ if (weight === 1) {
+ weight = 7;
+ }
+ }
+
+ checksum %= 11;
+
+ if (checksum === 1) {
+ return false;
+ }
+
+ return checksum === 0 ? digits[9] === 0 : digits[9] === 11 - checksum;
+}
+/*
+ * el-CY validation function
+ * (Arithmos Forologikou Mitroou (AFM/ΑΦΜ), persons only)
+ * Verify TIN validity by calculating ASCII value of check (last) character
+ */
+
+
+function elCyCheck(tin) {
+ // split digits into an array for further processing
+ var digits = tin.slice(0, 8).split('').map(function (a) {
+ return parseInt(a, 10);
+ });
+ var checksum = 0; // add digits in even places
+
+ for (var i = 1; i < digits.length; i += 2) {
+ checksum += digits[i];
+ } // add digits in odd places
+
+
+ for (var _i2 = 0; _i2 < digits.length; _i2 += 2) {
+ if (digits[_i2] < 2) {
+ checksum += 1 - digits[_i2];
+ } else {
+ checksum += 2 * (digits[_i2] - 2) + 5;
+
+ if (digits[_i2] > 4) {
+ checksum += 2;
+ }
+ }
+ }
+
+ return String.fromCharCode(checksum % 26 + 65) === tin.charAt(8);
+}
+/*
+ * el-GR validation function
+ * (Arithmos Forologikou Mitroou (AFM/ΑΦΜ), persons/entities)
+ * Verify TIN validity by calculating check (last) digit
+ * Algorithm not in DG TAXUD document- sourced from:
+ * - `http://epixeirisi.gr/%CE%9A%CE%A1%CE%99%CE%A3%CE%99%CE%9C%CE%91-%CE%98%CE%95%CE%9C%CE%91%CE%A4%CE%91-%CE%A6%CE%9F%CE%A1%CE%9F%CE%9B%CE%9F%CE%93%CE%99%CE%91%CE%A3-%CE%9A%CE%91%CE%99-%CE%9B%CE%9F%CE%93%CE%99%CE%A3%CE%A4%CE%99%CE%9A%CE%97%CE%A3/23791/%CE%91%CF%81%CE%B9%CE%B8%CE%BC%CF%8C%CF%82-%CE%A6%CE%BF%CF%81%CE%BF%CE%BB%CE%BF%CE%B3%CE%B9%CE%BA%CE%BF%CF%8D-%CE%9C%CE%B7%CF%84%CF%81%CF%8E%CE%BF%CF%85`
+ */
+
+
+function elGrCheck(tin) {
+ // split digits into an array for further processing
+ var digits = tin.split('').map(function (a) {
+ return parseInt(a, 10);
+ });
+ var checksum = 0;
+
+ for (var i = 0; i < 8; i++) {
+ checksum += digits[i] * Math.pow(2, 8 - i);
+ }
+
+ return checksum % 11 % 10 === digits[8];
+}
+/*
+ * en-GB validation function (should go here if needed)
+ * (National Insurance Number (NINO) or Unique Taxpayer Reference (UTR),
+ * persons/entities respectively)
+ */
+
+/*
+ * en-IE validation function
+ * (Personal Public Service Number (PPS No), persons only)
+ * Verify TIN validity by calculating check (second to last) character
+ */
+
+
+function enIeCheck(tin) {
+ var checksum = reverseMultiplyAndSum(tin.split('').slice(0, 7).map(function (a) {
+ return parseInt(a, 10);
+ }), 8);
+
+ if (tin.length === 9 && tin[8] !== 'W') {
+ checksum += (tin[8].charCodeAt(0) - 64) * 9;
+ }
+
+ checksum %= 23;
+
+ if (checksum === 0) {
+ return tin[7].toUpperCase() === 'W';
+ }
+
+ return tin[7].toUpperCase() === String.fromCharCode(64 + checksum);
+} // Valid US IRS campus prefixes
+
+
+var enUsCampusPrefix = {
+ andover: ['10', '12'],
+ atlanta: ['60', '67'],
+ austin: ['50', '53'],
+ brookhaven: ['01', '02', '03', '04', '05', '06', '11', '13', '14', '16', '21', '22', '23', '25', '34', '51', '52', '54', '55', '56', '57', '58', '59', '65'],
+ cincinnati: ['30', '32', '35', '36', '37', '38', '61'],
+ fresno: ['15', '24'],
+ internet: ['20', '26', '27', '45', '46', '47'],
+ kansas: ['40', '44'],
+ memphis: ['94', '95'],
+ ogden: ['80', '90'],
+ philadelphia: ['33', '39', '41', '42', '43', '46', '48', '62', '63', '64', '66', '68', '71', '72', '73', '74', '75', '76', '77', '81', '82', '83', '84', '85', '86', '87', '88', '91', '92', '93', '98', '99'],
+ sba: ['31']
+}; // Return an array of all US IRS campus prefixes
+
+function enUsGetPrefixes() {
+ var prefixes = [];
+
+ for (var location in enUsCampusPrefix) {
+ // https://github.com/gotwarlost/istanbul/blob/master/ignoring-code-for-coverage.md#ignoring-code-for-coverage-purposes
+ // istanbul ignore else
+ if (enUsCampusPrefix.hasOwnProperty(location)) {
+ prefixes.push.apply(prefixes, _toConsumableArray(enUsCampusPrefix[location]));
+ }
+ }
+
+ return prefixes;
+}
+/*
+ * en-US validation function
+ * Verify that the TIN starts with a valid IRS campus prefix
+ */
+
+
+function enUsCheck(tin) {
+ return enUsGetPrefixes().indexOf(tin.slice(0, 2)) !== -1;
+}
+/*
+ * es-ES validation function
+ * (Documento Nacional de Identidad (DNI)
+ * or Número de Identificación de Extranjero (NIE), persons only)
+ * Verify TIN validity by calculating check (last) character
+ */
+
+
+function esEsCheck(tin) {
+ // Split characters into an array for further processing
+ var chars = tin.toUpperCase().split(''); // Replace initial letter if needed
+
+ if (isNaN(parseInt(chars[0], 10)) && chars.length > 1) {
+ var lead_replace = 0;
+
+ switch (chars[0]) {
+ case 'Y':
+ lead_replace = 1;
+ break;
+
+ case 'Z':
+ lead_replace = 2;
+ break;
+
+ default:
+ }
+
+ chars.splice(0, 1, lead_replace); // Fill with zeros if smaller than proper
+ } else {
+ while (chars.length < 9) {
+ chars.unshift(0);
+ }
+ } // Calculate checksum and check according to lookup
+
+
+ var lookup = ['T', 'R', 'W', 'A', 'G', 'M', 'Y', 'F', 'P', 'D', 'X', 'B', 'N', 'J', 'Z', 'S', 'Q', 'V', 'H', 'L', 'C', 'K', 'E'];
+ chars = chars.join('');
+ var checksum = parseInt(chars.slice(0, 8), 10) % 23;
+ return chars[8] === lookup[checksum];
+}
+/*
+ * et-EE validation function
+ * (Isikukood (IK), persons only)
+ * Checks if birth date (century digit and six following) is valid and calculates check (last) digit
+ * Material not in DG TAXUD document sourced from:
+ * - `https://www.oecd.org/tax/automatic-exchange/crs-implementation-and-assistance/tax-identification-numbers/Estonia-TIN.pdf`
+ */
+
+
+function etEeCheck(tin) {
+ // Extract year and add century
+ var full_year = tin.slice(1, 3);
+ var century_digit = tin.slice(0, 1);
+
+ switch (century_digit) {
+ case '1':
+ case '2':
+ full_year = "18".concat(full_year);
+ break;
+
+ case '3':
+ case '4':
+ full_year = "19".concat(full_year);
+ break;
+
+ default:
+ full_year = "20".concat(full_year);
+ break;
+ } // Check date validity
+
+
+ var date = "".concat(full_year, "/").concat(tin.slice(3, 5), "/").concat(tin.slice(5, 7));
+
+ if (!isDate(date, 'YYYY/MM/DD')) {
+ return false;
+ } // Split digits into an array for further processing
+
+
+ var digits = tin.split('').map(function (a) {
+ return parseInt(a, 10);
+ });
+ var checksum = 0;
+ var weight = 1; // Multiply by weight and add to checksum
+
+ for (var i = 0; i < 10; i++) {
+ checksum += digits[i] * weight;
+ weight += 1;
+
+ if (weight === 10) {
+ weight = 1;
+ }
+ } // Do again if modulo 11 of checksum is 10
+
+
+ if (checksum % 11 === 10) {
+ checksum = 0;
+ weight = 3;
+
+ for (var _i3 = 0; _i3 < 10; _i3++) {
+ checksum += digits[_i3] * weight;
+ weight += 1;
+
+ if (weight === 10) {
+ weight = 1;
+ }
+ }
+
+ if (checksum % 11 === 10) {
+ return digits[10] === 0;
+ }
+ }
+
+ return checksum % 11 === digits[10];
+}
+/*
+ * fi-FI validation function
+ * (Henkilötunnus (HETU), persons only)
+ * Checks if birth date (first six digits plus century symbol) is valid
+ * and calculates check (last) digit
+ */
+
+
+function fiFiCheck(tin) {
+ // Extract year and add century
+ var full_year = tin.slice(4, 6);
+ var century_symbol = tin.slice(6, 7);
+
+ switch (century_symbol) {
+ case '+':
+ full_year = "18".concat(full_year);
+ break;
+
+ case '-':
+ full_year = "19".concat(full_year);
+ break;
+
+ default:
+ full_year = "20".concat(full_year);
+ break;
+ } // Check date validity
+
+
+ var date = "".concat(full_year, "/").concat(tin.slice(2, 4), "/").concat(tin.slice(0, 2));
+
+ if (!isDate(date, 'YYYY/MM/DD')) {
+ return false;
+ } // Calculate check character
+
+
+ var checksum = parseInt(tin.slice(0, 6) + tin.slice(7, 10), 10) % 31;
+
+ if (checksum < 10) {
+ return checksum === parseInt(tin.slice(10), 10);
+ }
+
+ checksum -= 10;
+ var letters_lookup = ['A', 'B', 'C', 'D', 'E', 'F', 'H', 'J', 'K', 'L', 'M', 'N', 'P', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y'];
+ return letters_lookup[checksum] === tin.slice(10);
+}
+/*
+ * fr/nl-BE validation function
+ * (Numéro national (N.N.), persons only)
+ * Checks if birth date (first six digits) is valid and calculates check (last two) digits
+ */
+
+
+function frBeCheck(tin) {
+ // Zero month/day value is acceptable
+ if (tin.slice(2, 4) !== '00' || tin.slice(4, 6) !== '00') {
+ // Extract date from first six digits of TIN
+ var date = "".concat(tin.slice(0, 2), "/").concat(tin.slice(2, 4), "/").concat(tin.slice(4, 6));
+
+ if (!isDate(date, 'YY/MM/DD')) {
+ return false;
+ }
+ }
+
+ var checksum = 97 - parseInt(tin.slice(0, 9), 10) % 97;
+ var checkdigits = parseInt(tin.slice(9, 11), 10);
+
+ if (checksum !== checkdigits) {
+ checksum = 97 - parseInt("2".concat(tin.slice(0, 9)), 10) % 97;
+
+ if (checksum !== checkdigits) {
+ return false;
+ }
+ }
+
+ return true;
+}
+/*
+ * fr-FR validation function
+ * (Numéro fiscal de référence (numéro SPI), persons only)
+ * Verify TIN validity by calculating check (last three) digits
+ */
+
+
+function frFrCheck(tin) {
+ tin = tin.replace(/\s/g, '');
+ var checksum = parseInt(tin.slice(0, 10), 10) % 511;
+ var checkdigits = parseInt(tin.slice(10, 13), 10);
+ return checksum === checkdigits;
+}
+/*
+ * fr/lb-LU validation function
+ * (numéro d’identification personnelle, persons only)
+ * Verify birth date validity and run Luhn and Verhoeff checks
+ */
+
+
+function frLuCheck(tin) {
+ // Extract date and check validity
+ var date = "".concat(tin.slice(0, 4), "/").concat(tin.slice(4, 6), "/").concat(tin.slice(6, 8));
+
+ if (!isDate(date, 'YYYY/MM/DD')) {
+ return false;
+ } // Run Luhn check
+
+
+ if (!luhnCheck(tin.slice(0, 12))) {
+ return false;
+ } // Remove Luhn check digit and run Verhoeff check
+
+
+ return verhoeffCheck("".concat(tin.slice(0, 11)).concat(tin[12]));
+}
+/*
+ * hr-HR validation function
+ * (Osobni identifikacijski broj (OIB), persons/entities)
+ * Verify TIN validity by calling iso7064Check(digits)
+ */
+
+
+function hrHrCheck(tin) {
+ return iso7064Check(tin);
+}
+/*
+ * hu-HU validation function
+ * (Adóazonosító jel, persons only)
+ * Verify TIN validity by calculating check (last) digit
+ */
+
+
+function huHuCheck(tin) {
+ // split digits into an array for further processing
+ var digits = tin.split('').map(function (a) {
+ return parseInt(a, 10);
+ });
+ var checksum = 8;
+
+ for (var i = 1; i < 9; i++) {
+ checksum += digits[i] * (i + 1);
+ }
+
+ return checksum % 11 === digits[9];
+}
+/*
+ * lt-LT validation function (should go here if needed)
+ * (Asmens kodas, persons/entities respectively)
+ * Current validation check is alias of etEeCheck- same format applies
+ */
+
+/*
+ * it-IT first/last name validity check
+ * Accepts it-IT TIN-encoded names as a three-element character array and checks their validity
+ * Due to lack of clarity between resources ("Are only Italian consonants used?
+ * What happens if a person has X in their name?" etc.) only two test conditions
+ * have been implemented:
+ * Vowels may only be followed by other vowels or an X character
+ * and X characters after vowels may only be followed by other X characters.
+ */
+
+
+function itItNameCheck(name) {
+ // true at the first occurence of a vowel
+ var vowelflag = false; // true at the first occurence of an X AFTER vowel
+ // (to properly handle last names with X as consonant)
+
+ var xflag = false;
+
+ for (var i = 0; i < 3; i++) {
+ if (!vowelflag && /[AEIOU]/.test(name[i])) {
+ vowelflag = true;
+ } else if (!xflag && vowelflag && name[i] === 'X') {
+ xflag = true;
+ } else if (i > 0) {
+ if (vowelflag && !xflag) {
+ if (!/[AEIOU]/.test(name[i])) {
+ return false;
+ }
+ }
+
+ if (xflag) {
+ if (!/X/.test(name[i])) {
+ return false;
+ }
+ }
+ }
+ }
+
+ return true;
+}
+/*
+ * it-IT validation function
+ * (Codice fiscale (TIN-IT), persons only)
+ * Verify name, birth date and codice catastale validity
+ * and calculate check character.
+ * Material not in DG-TAXUD document sourced from:
+ * `https://en.wikipedia.org/wiki/Italian_fiscal_code`
+ */
+
+
+function itItCheck(tin) {
+ // Capitalize and split characters into an array for further processing
+ var chars = tin.toUpperCase().split(''); // Check first and last name validity calling itItNameCheck()
+
+ if (!itItNameCheck(chars.slice(0, 3))) {
+ return false;
+ }
+
+ if (!itItNameCheck(chars.slice(3, 6))) {
+ return false;
+ } // Convert letters in number spaces back to numbers if any
+
+
+ var number_locations = [6, 7, 9, 10, 12, 13, 14];
+ var number_replace = {
+ L: '0',
+ M: '1',
+ N: '2',
+ P: '3',
+ Q: '4',
+ R: '5',
+ S: '6',
+ T: '7',
+ U: '8',
+ V: '9'
+ };
+
+ for (var _i4 = 0, _number_locations = number_locations; _i4 < _number_locations.length; _i4++) {
+ var i = _number_locations[_i4];
+
+ if (chars[i] in number_replace) {
+ chars.splice(i, 1, number_replace[chars[i]]);
+ }
+ } // Extract month and day, and check date validity
+
+
+ var month_replace = {
+ A: '01',
+ B: '02',
+ C: '03',
+ D: '04',
+ E: '05',
+ H: '06',
+ L: '07',
+ M: '08',
+ P: '09',
+ R: '10',
+ S: '11',
+ T: '12'
+ };
+ var month = month_replace[chars[8]];
+ var day = parseInt(chars[9] + chars[10], 10);
+
+ if (day > 40) {
+ day -= 40;
+ }
+
+ if (day < 10) {
+ day = "0".concat(day);
+ }
+
+ var date = "".concat(chars[6]).concat(chars[7], "/").concat(month, "/").concat(day);
+
+ if (!isDate(date, 'YY/MM/DD')) {
+ return false;
+ } // Calculate check character by adding up even and odd characters as numbers
+
+
+ var checksum = 0;
+
+ for (var _i5 = 1; _i5 < chars.length - 1; _i5 += 2) {
+ var char_to_int = parseInt(chars[_i5], 10);
+
+ if (isNaN(char_to_int)) {
+ char_to_int = chars[_i5].charCodeAt(0) - 65;
+ }
+
+ checksum += char_to_int;
+ }
+
+ var odd_convert = {
+ // Maps of characters at odd places
+ A: 1,
+ B: 0,
+ C: 5,
+ D: 7,
+ E: 9,
+ F: 13,
+ G: 15,
+ H: 17,
+ I: 19,
+ J: 21,
+ K: 2,
+ L: 4,
+ M: 18,
+ N: 20,
+ O: 11,
+ P: 3,
+ Q: 6,
+ R: 8,
+ S: 12,
+ T: 14,
+ U: 16,
+ V: 10,
+ W: 22,
+ X: 25,
+ Y: 24,
+ Z: 23,
+ 0: 1,
+ 1: 0
+ };
+
+ for (var _i6 = 0; _i6 < chars.length - 1; _i6 += 2) {
+ var _char_to_int = 0;
+
+ if (chars[_i6] in odd_convert) {
+ _char_to_int = odd_convert[chars[_i6]];
+ } else {
+ var multiplier = parseInt(chars[_i6], 10);
+ _char_to_int = 2 * multiplier + 1;
+
+ if (multiplier > 4) {
+ _char_to_int += 2;
+ }
+ }
+
+ checksum += _char_to_int;
+ }
+
+ if (String.fromCharCode(65 + checksum % 26) !== chars[15]) {
+ return false;
+ }
+
+ return true;
+}
+/*
+ * lv-LV validation function
+ * (Personas kods (PK), persons only)
+ * Check validity of birth date and calculate check (last) digit
+ * Support only for old format numbers (not starting with '32', issued before 2017/07/01)
+ * Material not in DG TAXUD document sourced from:
+ * `https://boot.ritakafija.lv/forums/index.php?/topic/88314-personas-koda-algoritms-%C4%8Deksumma/`
+ */
+
+
+function lvLvCheck(tin) {
+ tin = tin.replace(/\W/, ''); // Extract date from TIN
+
+ var day = tin.slice(0, 2);
+
+ if (day !== '32') {
+ // No date/checksum check if new format
+ var month = tin.slice(2, 4);
+
+ if (month !== '00') {
+ // No date check if unknown month
+ var full_year = tin.slice(4, 6);
+
+ switch (tin[6]) {
+ case '0':
+ full_year = "18".concat(full_year);
+ break;
+
+ case '1':
+ full_year = "19".concat(full_year);
+ break;
+
+ default:
+ full_year = "20".concat(full_year);
+ break;
+ } // Check date validity
+
+
+ var date = "".concat(full_year, "/").concat(tin.slice(2, 4), "/").concat(day);
+
+ if (!isDate(date, 'YYYY/MM/DD')) {
+ return false;
+ }
+ } // Calculate check digit
+
+
+ var checksum = 1101;
+ var multip_lookup = [1, 6, 3, 7, 9, 10, 5, 8, 4, 2];
+
+ for (var i = 0; i < tin.length - 1; i++) {
+ checksum -= parseInt(tin[i], 10) * multip_lookup[i];
+ }
+
+ return parseInt(tin[10], 10) === checksum % 11;
+ }
+
+ return true;
+}
+/*
+ * mt-MT validation function
+ * (Identity Card Number or Unique Taxpayer Reference, persons/entities)
+ * Verify Identity Card Number structure (no other tests found)
+ */
+
+
+function mtMtCheck(tin) {
+ if (tin.length !== 9) {
+ // No tests for UTR
+ var chars = tin.toUpperCase().split(''); // Fill with zeros if smaller than proper
+
+ while (chars.length < 8) {
+ chars.unshift(0);
+ } // Validate format according to last character
+
+
+ switch (tin[7]) {
+ case 'A':
+ case 'P':
+ if (parseInt(chars[6], 10) === 0) {
+ return false;
+ }
+
+ break;
+
+ default:
+ {
+ var first_part = parseInt(chars.join('').slice(0, 5), 10);
+
+ if (first_part > 32000) {
+ return false;
+ }
+
+ var second_part = parseInt(chars.join('').slice(5, 7), 10);
+
+ if (first_part === second_part) {
+ return false;
+ }
+ }
+ }
+ }
+
+ return true;
+}
+/*
+ * nl-NL validation function
+ * (Burgerservicenummer (BSN) or Rechtspersonen Samenwerkingsverbanden Informatie Nummer (RSIN),
+ * persons/entities respectively)
+ * Verify TIN validity by calculating check (last) digit (variant of MOD 11)
+ */
+
+
+function nlNlCheck(tin) {
+ return reverseMultiplyAndSum(tin.split('').slice(0, 8).map(function (a) {
+ return parseInt(a, 10);
+ }), 9) % 11 === parseInt(tin[8], 10);
+}
+/*
+ * pl-PL validation function
+ * (Powszechny Elektroniczny System Ewidencji Ludności (PESEL)
+ * or Numer identyfikacji podatkowej (NIP), persons/entities)
+ * Verify TIN validity by validating birth date (PESEL) and calculating check (last) digit
+ */
+
+
+function plPlCheck(tin) {
+ // NIP
+ if (tin.length === 10) {
+ // Calculate last digit by multiplying with lookup
+ var lookup = [6, 5, 7, 2, 3, 4, 5, 6, 7];
+ var _checksum = 0;
+
+ for (var i = 0; i < lookup.length; i++) {
+ _checksum += parseInt(tin[i], 10) * lookup[i];
+ }
+
+ _checksum %= 11;
+
+ if (_checksum === 10) {
+ return false;
+ }
+
+ return _checksum === parseInt(tin[9], 10);
+ } // PESEL
+ // Extract full year using month
+
+
+ var full_year = tin.slice(0, 2);
+ var month = parseInt(tin.slice(2, 4), 10);
+
+ if (month > 80) {
+ full_year = "18".concat(full_year);
+ month -= 80;
+ } else if (month > 60) {
+ full_year = "22".concat(full_year);
+ month -= 60;
+ } else if (month > 40) {
+ full_year = "21".concat(full_year);
+ month -= 40;
+ } else if (month > 20) {
+ full_year = "20".concat(full_year);
+ month -= 20;
+ } else {
+ full_year = "19".concat(full_year);
+ } // Add leading zero to month if needed
+
+
+ if (month < 10) {
+ month = "0".concat(month);
+ } // Check date validity
+
+
+ var date = "".concat(full_year, "/").concat(month, "/").concat(tin.slice(4, 6));
+
+ if (!isDate(date, 'YYYY/MM/DD')) {
+ return false;
+ } // Calculate last digit by mulitplying with odd one-digit numbers except 5
+
+
+ var checksum = 0;
+ var multiplier = 1;
+
+ for (var _i7 = 0; _i7 < tin.length - 1; _i7++) {
+ checksum += parseInt(tin[_i7], 10) * multiplier % 10;
+ multiplier += 2;
+
+ if (multiplier > 10) {
+ multiplier = 1;
+ } else if (multiplier === 5) {
+ multiplier += 2;
+ }
+ }
+
+ checksum = 10 - checksum % 10;
+ return checksum === parseInt(tin[10], 10);
+}
+/*
+* pt-BR validation function
+* (Cadastro de Pessoas Físicas (CPF, persons)
+* Cadastro Nacional de Pessoas Jurídicas (CNPJ, entities)
+* Both inputs will be validated
+*/
+
+
+function ptBrCheck(tin) {
+ if (tin.length === 11) {
+ var _sum;
+
+ var remainder;
+ _sum = 0;
+ if ( // Reject known invalid CPFs
+ tin === '11111111111' || tin === '22222222222' || tin === '33333333333' || tin === '44444444444' || tin === '55555555555' || tin === '66666666666' || tin === '77777777777' || tin === '88888888888' || tin === '99999999999' || tin === '00000000000') return false;
+
+ for (var i = 1; i <= 9; i++) {
+ _sum += parseInt(tin.substring(i - 1, i), 10) * (11 - i);
+ }
+
+ remainder = _sum * 10 % 11;
+ if (remainder === 10) remainder = 0;
+ if (remainder !== parseInt(tin.substring(9, 10), 10)) return false;
+ _sum = 0;
+
+ for (var _i8 = 1; _i8 <= 10; _i8++) {
+ _sum += parseInt(tin.substring(_i8 - 1, _i8), 10) * (12 - _i8);
+ }
+
+ remainder = _sum * 10 % 11;
+ if (remainder === 10) remainder = 0;
+ if (remainder !== parseInt(tin.substring(10, 11), 10)) return false;
+ return true;
+ }
+
+ if ( // Reject know invalid CNPJs
+ tin === '00000000000000' || tin === '11111111111111' || tin === '22222222222222' || tin === '33333333333333' || tin === '44444444444444' || tin === '55555555555555' || tin === '66666666666666' || tin === '77777777777777' || tin === '88888888888888' || tin === '99999999999999') {
+ return false;
+ }
+
+ var length = tin.length - 2;
+ var identifiers = tin.substring(0, length);
+ var verificators = tin.substring(length);
+ var sum = 0;
+ var pos = length - 7;
+
+ for (var _i9 = length; _i9 >= 1; _i9--) {
+ sum += identifiers.charAt(length - _i9) * pos;
+ pos -= 1;
+
+ if (pos < 2) {
+ pos = 9;
+ }
+ }
+
+ var result = sum % 11 < 2 ? 0 : 11 - sum % 11;
+
+ if (result !== parseInt(verificators.charAt(0), 10)) {
+ return false;
+ }
+
+ length += 1;
+ identifiers = tin.substring(0, length);
+ sum = 0;
+ pos = length - 7;
+
+ for (var _i10 = length; _i10 >= 1; _i10--) {
+ sum += identifiers.charAt(length - _i10) * pos;
+ pos -= 1;
+
+ if (pos < 2) {
+ pos = 9;
+ }
+ }
+
+ result = sum % 11 < 2 ? 0 : 11 - sum % 11;
+
+ if (result !== parseInt(verificators.charAt(1), 10)) {
+ return false;
+ }
+
+ return true;
+}
+/*
+ * pt-PT validation function
+ * (Número de identificação fiscal (NIF), persons/entities)
+ * Verify TIN validity by calculating check (last) digit (variant of MOD 11)
+ */
+
+
+function ptPtCheck(tin) {
+ var checksum = 11 - reverseMultiplyAndSum(tin.split('').slice(0, 8).map(function (a) {
+ return parseInt(a, 10);
+ }), 9) % 11;
+
+ if (checksum > 9) {
+ return parseInt(tin[8], 10) === 0;
+ }
+
+ return checksum === parseInt(tin[8], 10);
+}
+/*
+ * ro-RO validation function
+ * (Cod Numeric Personal (CNP) or Cod de înregistrare fiscală (CIF),
+ * persons only)
+ * Verify CNP validity by calculating check (last) digit (test not found for CIF)
+ * Material not in DG TAXUD document sourced from:
+ * `https://en.wikipedia.org/wiki/National_identification_number#Romania`
+ */
+
+
+function roRoCheck(tin) {
+ if (tin.slice(0, 4) !== '9000') {
+ // No test found for this format
+ // Extract full year using century digit if possible
+ var full_year = tin.slice(1, 3);
+
+ switch (tin[0]) {
+ case '1':
+ case '2':
+ full_year = "19".concat(full_year);
+ break;
+
+ case '3':
+ case '4':
+ full_year = "18".concat(full_year);
+ break;
+
+ case '5':
+ case '6':
+ full_year = "20".concat(full_year);
+ break;
+
+ default:
+ } // Check date validity
+
+
+ var date = "".concat(full_year, "/").concat(tin.slice(3, 5), "/").concat(tin.slice(5, 7));
+
+ if (date.length === 8) {
+ if (!isDate(date, 'YY/MM/DD')) {
+ return false;
+ }
+ } else if (!isDate(date, 'YYYY/MM/DD')) {
+ return false;
+ } // Calculate check digit
+
+
+ var digits = tin.split('').map(function (a) {
+ return parseInt(a, 10);
+ });
+ var multipliers = [2, 7, 9, 1, 4, 6, 3, 5, 8, 2, 7, 9];
+ var checksum = 0;
+
+ for (var i = 0; i < multipliers.length; i++) {
+ checksum += digits[i] * multipliers[i];
+ }
+
+ if (checksum % 11 === 10) {
+ return digits[12] === 1;
+ }
+
+ return digits[12] === checksum % 11;
+ }
+
+ return true;
+}
+/*
+ * sk-SK validation function
+ * (Rodné číslo (RČ) or bezvýznamové identifikačné číslo (BIČ), persons only)
+ * Checks validity of pre-1954 birth numbers (rodné číslo) only
+ * Due to the introduction of the pseudo-random BIČ it is not possible to test
+ * post-1954 birth numbers without knowing whether they are BIČ or RČ beforehand
+ */
+
+
+function skSkCheck(tin) {
+ if (tin.length === 9) {
+ tin = tin.replace(/\W/, '');
+
+ if (tin.slice(6) === '000') {
+ return false;
+ } // Three-zero serial not assigned before 1954
+ // Extract full year from TIN length
+
+
+ var full_year = parseInt(tin.slice(0, 2), 10);
+
+ if (full_year > 53) {
+ return false;
+ }
+
+ if (full_year < 10) {
+ full_year = "190".concat(full_year);
+ } else {
+ full_year = "19".concat(full_year);
+ } // Extract month from TIN and normalize
+
+
+ var month = parseInt(tin.slice(2, 4), 10);
+
+ if (month > 50) {
+ month -= 50;
+ }
+
+ if (month < 10) {
+ month = "0".concat(month);
+ } // Check date validity
+
+
+ var date = "".concat(full_year, "/").concat(month, "/").concat(tin.slice(4, 6));
+
+ if (!isDate(date, 'YYYY/MM/DD')) {
+ return false;
+ }
+ }
+
+ return true;
+}
+/*
+ * sl-SI validation function
+ * (Davčna številka, persons/entities)
+ * Verify TIN validity by calculating check (last) digit (variant of MOD 11)
+ */
+
+
+function slSiCheck(tin) {
+ var checksum = 11 - reverseMultiplyAndSum(tin.split('').slice(0, 7).map(function (a) {
+ return parseInt(a, 10);
+ }), 8) % 11;
+
+ if (checksum === 10) {
+ return parseInt(tin[7], 10) === 0;
+ }
+
+ return checksum === parseInt(tin[7], 10);
+}
+/*
+ * sv-SE validation function
+ * (Personnummer or samordningsnummer, persons only)
+ * Checks validity of birth date and calls luhnCheck() to validate check (last) digit
+ */
+
+
+function svSeCheck(tin) {
+ // Make copy of TIN and normalize to two-digit year form
+ var tin_copy = tin.slice(0);
+
+ if (tin.length > 11) {
+ tin_copy = tin_copy.slice(2);
+ } // Extract date of birth
+
+
+ var full_year = '';
+ var month = tin_copy.slice(2, 4);
+ var day = parseInt(tin_copy.slice(4, 6), 10);
+
+ if (tin.length > 11) {
+ full_year = tin.slice(0, 4);
+ } else {
+ full_year = tin.slice(0, 2);
+
+ if (tin.length === 11 && day < 60) {
+ // Extract full year from centenarian symbol
+ // Should work just fine until year 10000 or so
+ var current_year = new Date().getFullYear().toString();
+ var current_century = parseInt(current_year.slice(0, 2), 10);
+ current_year = parseInt(current_year, 10);
+
+ if (tin[6] === '-') {
+ if (parseInt("".concat(current_century).concat(full_year), 10) > current_year) {
+ full_year = "".concat(current_century - 1).concat(full_year);
+ } else {
+ full_year = "".concat(current_century).concat(full_year);
+ }
+ } else {
+ full_year = "".concat(current_century - 1).concat(full_year);
+
+ if (current_year - parseInt(full_year, 10) < 100) {
+ return false;
+ }
+ }
+ }
+ } // Normalize day and check date validity
+
+
+ if (day > 60) {
+ day -= 60;
+ }
+
+ if (day < 10) {
+ day = "0".concat(day);
+ }
+
+ var date = "".concat(full_year, "/").concat(month, "/").concat(day);
+
+ if (date.length === 8) {
+ if (!isDate(date, 'YY/MM/DD')) {
+ return false;
+ }
+ } else if (!isDate(date, 'YYYY/MM/DD')) {
+ return false;
+ }
+
+ return luhnCheck(tin.replace(/\W/, ''));
+} // Locale lookup objects
+
+/*
+ * Tax id regex formats for various locales
+ *
+ * Where not explicitly specified in DG-TAXUD document both
+ * uppercase and lowercase letters are acceptable.
+ */
+
+
+var taxIdFormat = {
+ 'bg-BG': /^\d{10}$/,
+ 'cs-CZ': /^\d{6}\/{0,1}\d{3,4}$/,
+ 'de-AT': /^\d{9}$/,
+ 'de-DE': /^[1-9]\d{10}$/,
+ 'dk-DK': /^\d{6}-{0,1}\d{4}$/,
+ 'el-CY': /^[09]\d{7}[A-Z]$/,
+ 'el-GR': /^([0-4]|[7-9])\d{8}$/,
+ 'en-CA': /^\d{9}$/,
+ 'en-GB': /^\d{10}$|^(?!GB|NK|TN|ZZ)(?![DFIQUV])[A-Z](?![DFIQUVO])[A-Z]\d{6}[ABCD ]$/i,
+ 'en-IE': /^\d{7}[A-W][A-IW]{0,1}$/i,
+ 'en-US': /^\d{2}[- ]{0,1}\d{7}$/,
+ 'es-ES': /^(\d{0,8}|[XYZKLM]\d{7})[A-HJ-NP-TV-Z]$/i,
+ 'et-EE': /^[1-6]\d{6}(00[1-9]|0[1-9][0-9]|[1-6][0-9]{2}|70[0-9]|710)\d$/,
+ 'fi-FI': /^\d{6}[-+A]\d{3}[0-9A-FHJ-NPR-Y]$/i,
+ 'fr-BE': /^\d{11}$/,
+ 'fr-FR': /^[0-3]\d{12}$|^[0-3]\d\s\d{2}(\s\d{3}){3}$/,
+ // Conforms both to official spec and provided example
+ 'fr-LU': /^\d{13}$/,
+ 'hr-HR': /^\d{11}$/,
+ 'hu-HU': /^8\d{9}$/,
+ 'it-IT': /^[A-Z]{6}[L-NP-V0-9]{2}[A-EHLMPRST][L-NP-V0-9]{2}[A-ILMZ][L-NP-V0-9]{3}[A-Z]$/i,
+ 'lv-LV': /^\d{6}-{0,1}\d{5}$/,
+ // Conforms both to DG TAXUD spec and original research
+ 'mt-MT': /^\d{3,7}[APMGLHBZ]$|^([1-8])\1\d{7}$/i,
+ 'nl-NL': /^\d{9}$/,
+ 'pl-PL': /^\d{10,11}$/,
+ 'pt-BR': /(?:^\d{11}$)|(?:^\d{14}$)/,
+ 'pt-PT': /^\d{9}$/,
+ 'ro-RO': /^\d{13}$/,
+ 'sk-SK': /^\d{6}\/{0,1}\d{3,4}$/,
+ 'sl-SI': /^[1-9]\d{7}$/,
+ 'sv-SE': /^(\d{6}[-+]{0,1}\d{4}|(18|19|20)\d{6}[-+]{0,1}\d{4})$/
+}; // taxIdFormat locale aliases
+
+taxIdFormat['lb-LU'] = taxIdFormat['fr-LU'];
+taxIdFormat['lt-LT'] = taxIdFormat['et-EE'];
+taxIdFormat['nl-BE'] = taxIdFormat['fr-BE'];
+taxIdFormat['fr-CA'] = taxIdFormat['en-CA']; // Algorithmic tax id check functions for various locales
+
+var taxIdCheck = {
+ 'bg-BG': bgBgCheck,
+ 'cs-CZ': csCzCheck,
+ 'de-AT': deAtCheck,
+ 'de-DE': deDeCheck,
+ 'dk-DK': dkDkCheck,
+ 'el-CY': elCyCheck,
+ 'el-GR': elGrCheck,
+ 'en-CA': isCanadianSIN,
+ 'en-IE': enIeCheck,
+ 'en-US': enUsCheck,
+ 'es-ES': esEsCheck,
+ 'et-EE': etEeCheck,
+ 'fi-FI': fiFiCheck,
+ 'fr-BE': frBeCheck,
+ 'fr-FR': frFrCheck,
+ 'fr-LU': frLuCheck,
+ 'hr-HR': hrHrCheck,
+ 'hu-HU': huHuCheck,
+ 'it-IT': itItCheck,
+ 'lv-LV': lvLvCheck,
+ 'mt-MT': mtMtCheck,
+ 'nl-NL': nlNlCheck,
+ 'pl-PL': plPlCheck,
+ 'pt-BR': ptBrCheck,
+ 'pt-PT': ptPtCheck,
+ 'ro-RO': roRoCheck,
+ 'sk-SK': skSkCheck,
+ 'sl-SI': slSiCheck,
+ 'sv-SE': svSeCheck
+}; // taxIdCheck locale aliases
+
+taxIdCheck['lb-LU'] = taxIdCheck['fr-LU'];
+taxIdCheck['lt-LT'] = taxIdCheck['et-EE'];
+taxIdCheck['nl-BE'] = taxIdCheck['fr-BE'];
+taxIdCheck['fr-CA'] = taxIdCheck['en-CA']; // Regexes for locales where characters should be omitted before checking format
+
+var allsymbols = /[-\\\/!@#$%\^&\*\(\)\+\=\[\]]+/g;
+var sanitizeRegexes = {
+ 'de-AT': allsymbols,
+ 'de-DE': /[\/\\]/g,
+ 'fr-BE': allsymbols
+}; // sanitizeRegexes locale aliases
+
+sanitizeRegexes['nl-BE'] = sanitizeRegexes['fr-BE'];
+/*
+ * Validator function
+ * Return true if the passed string is a valid tax identification number
+ * for the specified locale.
+ * Throw an error exception if the locale is not supported.
+ */
+
+function isTaxID(str) {
+ var locale = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'en-US';
+ assertString(str); // Copy TIN to avoid replacement if sanitized
+
+ var strcopy = str.slice(0);
+
+ if (locale in taxIdFormat) {
+ if (locale in sanitizeRegexes) {
+ strcopy = strcopy.replace(sanitizeRegexes[locale], '');
+ }
+
+ if (!taxIdFormat[locale].test(strcopy)) {
+ return false;
+ }
+
+ if (locale in taxIdCheck) {
+ return taxIdCheck[locale](strcopy);
+ } // Fallthrough; not all locales have algorithmic checks
+
+
+ return true;
+ }
+
+ throw new Error("Invalid locale '".concat(locale, "'"));
+}
+
+/* eslint-disable max-len */
+
+var phones = {
+ 'am-AM': /^(\+?374|0)((10|[9|7][0-9])\d{6}$|[2-4]\d{7}$)/,
+ 'ar-AE': /^((\+?971)|0)?5[024568]\d{7}$/,
+ 'ar-BH': /^(\+?973)?(3|6)\d{7}$/,
+ 'ar-DZ': /^(\+?213|0)(5|6|7)\d{8}$/,
+ 'ar-LB': /^(\+?961)?((3|81)\d{6}|7\d{7})$/,
+ 'ar-EG': /^((\+?20)|0)?1[0125]\d{8}$/,
+ 'ar-IQ': /^(\+?964|0)?7[0-9]\d{8}$/,
+ 'ar-JO': /^(\+?962|0)?7[789]\d{7}$/,
+ 'ar-KW': /^(\+?965)([569]\d{7}|41\d{6})$/,
+ 'ar-LY': /^((\+?218)|0)?(9[1-6]\d{7}|[1-8]\d{7,9})$/,
+ 'ar-MA': /^(?:(?:\+|00)212|0)[5-7]\d{8}$/,
+ 'ar-OM': /^((\+|00)968)?(9[1-9])\d{6}$/,
+ 'ar-PS': /^(\+?970|0)5[6|9](\d{7})$/,
+ 'ar-SA': /^(!?(\+?966)|0)?5\d{8}$/,
+ 'ar-SY': /^(!?(\+?963)|0)?9\d{8}$/,
+ 'ar-TN': /^(\+?216)?[2459]\d{7}$/,
+ 'az-AZ': /^(\+994|0)(10|5[015]|7[07]|99)\d{7}$/,
+ 'bs-BA': /^((((\+|00)3876)|06))((([0-3]|[5-6])\d{6})|(4\d{7}))$/,
+ 'be-BY': /^(\+?375)?(24|25|29|33|44)\d{7}$/,
+ 'bg-BG': /^(\+?359|0)?8[789]\d{7}$/,
+ 'bn-BD': /^(\+?880|0)1[13456789][0-9]{8}$/,
+ 'ca-AD': /^(\+376)?[346]\d{5}$/,
+ 'cs-CZ': /^(\+?420)? ?[1-9][0-9]{2} ?[0-9]{3} ?[0-9]{3}$/,
+ 'da-DK': /^(\+?45)?\s?\d{2}\s?\d{2}\s?\d{2}\s?\d{2}$/,
+ 'de-DE': /^((\+49|0)1)(5[0-25-9]\d|6([23]|0\d?)|7([0-57-9]|6\d))\d{7,9}$/,
+ 'de-AT': /^(\+43|0)\d{1,4}\d{3,12}$/,
+ 'de-CH': /^(\+41|0)([1-9])\d{1,9}$/,
+ 'de-LU': /^(\+352)?((6\d1)\d{6})$/,
+ 'dv-MV': /^(\+?960)?(7[2-9]|9[1-9])\d{5}$/,
+ 'el-GR': /^(\+?30|0)?6(8[5-9]|9(?![26])[0-9])\d{7}$/,
+ 'el-CY': /^(\+?357?)?(9(9|6)\d{6})$/,
+ 'en-AI': /^(\+?1|0)264(?:2(35|92)|4(?:6[1-2]|76|97)|5(?:3[6-9]|8[1-4])|7(?:2(4|9)|72))\d{4}$/,
+ 'en-AU': /^(\+?61|0)4\d{8}$/,
+ 'en-AG': /^(?:\+1|1)268(?:464|7(?:1[3-9]|[28]\d|3[0246]|64|7[0-689]))\d{4}$/,
+ 'en-BM': /^(\+?1)?441(((3|7)\d{6}$)|(5[0-3][0-9]\d{4}$)|(59\d{5}$))/,
+ 'en-BS': /^(\+?1[-\s]?|0)?\(?242\)?[-\s]?\d{3}[-\s]?\d{4}$/,
+ 'en-GB': /^(\+?44|0)7\d{9}$/,
+ 'en-GG': /^(\+?44|0)1481\d{6}$/,
+ 'en-GH': /^(\+233|0)(20|50|24|54|27|57|26|56|23|28|55|59)\d{7}$/,
+ 'en-GY': /^(\+592|0)6\d{6}$/,
+ 'en-HK': /^(\+?852[-\s]?)?[456789]\d{3}[-\s]?\d{4}$/,
+ 'en-MO': /^(\+?853[-\s]?)?[6]\d{3}[-\s]?\d{4}$/,
+ 'en-IE': /^(\+?353|0)8[356789]\d{7}$/,
+ 'en-IN': /^(\+?91|0)?[6789]\d{9}$/,
+ 'en-JM': /^(\+?876)?\d{7}$/,
+ 'en-KE': /^(\+?254|0)(7|1)\d{8}$/,
+ 'en-SS': /^(\+?211|0)(9[1257])\d{7}$/,
+ 'en-KI': /^((\+686|686)?)?( )?((6|7)(2|3|8)[0-9]{6})$/,
+ 'en-KN': /^(?:\+1|1)869(?:46\d|48[89]|55[6-8]|66\d|76[02-7])\d{4}$/,
+ 'en-LS': /^(\+?266)(22|28|57|58|59|27|52)\d{6}$/,
+ 'en-MT': /^(\+?356|0)?(99|79|77|21|27|22|25)[0-9]{6}$/,
+ 'en-MU': /^(\+?230|0)?\d{8}$/,
+ 'en-NA': /^(\+?264|0)(6|8)\d{7}$/,
+ 'en-NG': /^(\+?234|0)?[789]\d{9}$/,
+ 'en-NZ': /^(\+?64|0)[28]\d{7,9}$/,
+ 'en-PG': /^(\+?675|0)?(7\d|8[18])\d{6}$/,
+ 'en-PK': /^((00|\+)?92|0)3[0-6]\d{8}$/,
+ 'en-PH': /^(09|\+639)\d{9}$/,
+ 'en-RW': /^(\+?250|0)?[7]\d{8}$/,
+ 'en-SG': /^(\+65)?[3689]\d{7}$/,
+ 'en-SL': /^(\+?232|0)\d{8}$/,
+ 'en-TZ': /^(\+?255|0)?[67]\d{8}$/,
+ 'en-UG': /^(\+?256|0)?[7]\d{8}$/,
+ 'en-US': /^((\+1|1)?( |-)?)?(\([2-9][0-9]{2}\)|[2-9][0-9]{2})( |-)?([2-9][0-9]{2}( |-)?[0-9]{4})$/,
+ 'en-ZA': /^(\+?27|0)\d{9}$/,
+ 'en-ZM': /^(\+?26)?09[567]\d{7}$/,
+ 'en-ZW': /^(\+263)[0-9]{9}$/,
+ 'en-BW': /^(\+?267)?(7[1-8]{1})\d{6}$/,
+ 'es-AR': /^\+?549(11|[2368]\d)\d{8}$/,
+ 'es-BO': /^(\+?591)?(6|7)\d{7}$/,
+ 'es-CO': /^(\+?57)?3(0(0|1|2|4|5)|1\d|2[0-4]|5(0|1))\d{7}$/,
+ 'es-CL': /^(\+?56|0)[2-9]\d{1}\d{7}$/,
+ 'es-CR': /^(\+506)?[2-8]\d{7}$/,
+ 'es-CU': /^(\+53|0053)?5\d{7}/,
+ 'es-DO': /^(\+?1)?8[024]9\d{7}$/,
+ 'es-HN': /^(\+?504)?[9|8|3|2]\d{7}$/,
+ 'es-EC': /^(\+?593|0)([2-7]|9[2-9])\d{7}$/,
+ 'es-ES': /^(\+?34)?[6|7]\d{8}$/,
+ 'es-PE': /^(\+?51)?9\d{8}$/,
+ 'es-MX': /^(\+?52)?(1|01)?\d{10,11}$/,
+ 'es-NI': /^(\+?505)\d{7,8}$/,
+ 'es-PA': /^(\+?507)\d{7,8}$/,
+ 'es-PY': /^(\+?595|0)9[9876]\d{7}$/,
+ 'es-SV': /^(\+?503)?[67]\d{7}$/,
+ 'es-UY': /^(\+598|0)9[1-9][\d]{6}$/,
+ 'es-VE': /^(\+?58)?(2|4)\d{9}$/,
+ 'et-EE': /^(\+?372)?\s?(5|8[1-4])\s?([0-9]\s?){6,7}$/,
+ 'fa-IR': /^(\+?98[\-\s]?|0)9[0-39]\d[\-\s]?\d{3}[\-\s]?\d{4}$/,
+ 'fi-FI': /^(\+?358|0)\s?(4[0-6]|50)\s?(\d\s?){4,8}$/,
+ 'fj-FJ': /^(\+?679)?\s?\d{3}\s?\d{4}$/,
+ 'fo-FO': /^(\+?298)?\s?\d{2}\s?\d{2}\s?\d{2}$/,
+ 'fr-BF': /^(\+226|0)[67]\d{7}$/,
+ 'fr-BJ': /^(\+229)\d{8}$/,
+ 'fr-CD': /^(\+?243|0)?(8|9)\d{8}$/,
+ 'fr-CM': /^(\+?237)6[0-9]{8}$/,
+ 'fr-FR': /^(\+?33|0)[67]\d{8}$/,
+ 'fr-GF': /^(\+?594|0|00594)[67]\d{8}$/,
+ 'fr-GP': /^(\+?590|0|00590)[67]\d{8}$/,
+ 'fr-MQ': /^(\+?596|0|00596)[67]\d{8}$/,
+ 'fr-PF': /^(\+?689)?8[789]\d{6}$/,
+ 'fr-RE': /^(\+?262|0|00262)[67]\d{8}$/,
+ 'he-IL': /^(\+972|0)([23489]|5[012345689]|77)[1-9]\d{6}$/,
+ 'hu-HU': /^(\+?36|06)(20|30|31|50|70)\d{7}$/,
+ 'id-ID': /^(\+?62|0)8(1[123456789]|2[1238]|3[1238]|5[12356789]|7[78]|9[56789]|8[123456789])([\s?|\d]{5,11})$/,
+ 'ir-IR': /^(\+98|0)?9\d{9}$/,
+ 'it-IT': /^(\+?39)?\s?3\d{2} ?\d{6,7}$/,
+ 'it-SM': /^((\+378)|(0549)|(\+390549)|(\+3780549))?6\d{5,9}$/,
+ 'ja-JP': /^(\+81[ \-]?(\(0\))?|0)[6789]0[ \-]?\d{4}[ \-]?\d{4}$/,
+ 'ka-GE': /^(\+?995)?(79\d{7}|5\d{8})$/,
+ 'kk-KZ': /^(\+?7|8)?7\d{9}$/,
+ 'kl-GL': /^(\+?299)?\s?\d{2}\s?\d{2}\s?\d{2}$/,
+ 'ko-KR': /^((\+?82)[ \-]?)?0?1([0|1|6|7|8|9]{1})[ \-]?\d{3,4}[ \-]?\d{4}$/,
+ 'ky-KG': /^(\+?7\s?\+?7|0)\s?\d{2}\s?\d{3}\s?\d{4}$/,
+ 'lt-LT': /^(\+370|8)\d{8}$/,
+ 'lv-LV': /^(\+?371)2\d{7}$/,
+ 'mg-MG': /^((\+?261|0)(2|3)\d)?\d{7}$/,
+ 'mn-MN': /^(\+|00|011)?976(77|81|88|91|94|95|96|99)\d{6}$/,
+ 'my-MM': /^(\+?959|09|9)(2[5-7]|3[1-2]|4[0-5]|6[6-9]|7[5-9]|9[6-9])[0-9]{7}$/,
+ 'ms-MY': /^(\+?60|0)1(([0145](-|\s)?\d{7,8})|([236-9](-|\s)?\d{7}))$/,
+ 'mz-MZ': /^(\+?258)?8[234567]\d{7}$/,
+ 'nb-NO': /^(\+?47)?[49]\d{7}$/,
+ 'ne-NP': /^(\+?977)?9[78]\d{8}$/,
+ 'nl-BE': /^(\+?32|0)4\d{8}$/,
+ 'nl-NL': /^(((\+|00)?31\(0\))|((\+|00)?31)|0)6{1}\d{8}$/,
+ 'nl-AW': /^(\+)?297(56|59|64|73|74|99)\d{5}$/,
+ 'nn-NO': /^(\+?47)?[49]\d{7}$/,
+ 'pl-PL': /^(\+?48)? ?[5-8]\d ?\d{3} ?\d{2} ?\d{2}$/,
+ 'pt-BR': /^((\+?55\ ?[1-9]{2}\ ?)|(\+?55\ ?\([1-9]{2}\)\ ?)|(0[1-9]{2}\ ?)|(\([1-9]{2}\)\ ?)|([1-9]{2}\ ?))((\d{4}\-?\d{4})|(9[1-9]{1}\d{3}\-?\d{4}))$/,
+ 'pt-PT': /^(\+?351)?9[1236]\d{7}$/,
+ 'pt-AO': /^(\+244)\d{9}$/,
+ 'ro-MD': /^(\+?373|0)((6(0|1|2|6|7|8|9))|(7(6|7|8|9)))\d{6}$/,
+ 'ro-RO': /^(\+?40|0)\s?7\d{2}(\/|\s|\.|-)?\d{3}(\s|\.|-)?\d{3}$/,
+ 'ru-RU': /^(\+?7|8)?9\d{9}$/,
+ 'si-LK': /^(?:0|94|\+94)?(7(0|1|2|4|5|6|7|8)( |-)?)\d{7}$/,
+ 'sl-SI': /^(\+386\s?|0)(\d{1}\s?\d{3}\s?\d{2}\s?\d{2}|\d{2}\s?\d{3}\s?\d{3})$/,
+ 'sk-SK': /^(\+?421)? ?[1-9][0-9]{2} ?[0-9]{3} ?[0-9]{3}$/,
+ 'sq-AL': /^(\+355|0)6[789]\d{6}$/,
+ 'sr-RS': /^(\+3816|06)[- \d]{5,9}$/,
+ 'sv-SE': /^(\+?46|0)[\s\-]?7[\s\-]?[02369]([\s\-]?\d){7}$/,
+ 'tg-TJ': /^(\+?992)?[5][5]\d{7}$/,
+ 'th-TH': /^(\+66|66|0)\d{9}$/,
+ 'tr-TR': /^(\+?90|0)?5\d{9}$/,
+ 'tk-TM': /^(\+993|993|8)\d{8}$/,
+ 'uk-UA': /^(\+?38|8)?0\d{9}$/,
+ 'uz-UZ': /^(\+?998)?(6[125-79]|7[1-69]|88|9\d)\d{7}$/,
+ 'vi-VN': /^((\+?84)|0)((3([2-9]))|(5([25689]))|(7([0|6-9]))|(8([1-9]))|(9([0-9])))([0-9]{7})$/,
+ 'zh-CN': /^((\+|00)86)?(1[3-9]|9[28])\d{9}$/,
+ 'zh-TW': /^(\+?886\-?|0)?9\d{8}$/,
+ 'dz-BT': /^(\+?975|0)?(17|16|77|02)\d{6}$/,
+ 'ar-YE': /^(((\+|00)9677|0?7)[0137]\d{7}|((\+|00)967|0)[1-7]\d{6})$/,
+ 'ar-EH': /^(\+?212|0)[\s\-]?(5288|5289)[\s\-]?\d{5}$/,
+ 'fa-AF': /^(\+93|0)?(2{1}[0-8]{1}|[3-5]{1}[0-4]{1})(\d{7})$/
+};
+/* eslint-enable max-len */
+// aliases
+
+phones['en-CA'] = phones['en-US'];
+phones['fr-CA'] = phones['en-CA'];
+phones['fr-BE'] = phones['nl-BE'];
+phones['zh-HK'] = phones['en-HK'];
+phones['zh-MO'] = phones['en-MO'];
+phones['ga-IE'] = phones['en-IE'];
+phones['fr-CH'] = phones['de-CH'];
+phones['it-CH'] = phones['fr-CH'];
+function isMobilePhone(str, locale, options) {
+ assertString(str);
+
+ if (options && options.strictMode && !str.startsWith('+')) {
+ return false;
+ }
+
+ if (Array.isArray(locale)) {
+ return locale.some(function (key) {
+ // https://github.com/gotwarlost/istanbul/blob/master/ignoring-code-for-coverage.md#ignoring-code-for-coverage-purposes
+ // istanbul ignore else
+ if (phones.hasOwnProperty(key)) {
+ var phone = phones[key];
+
+ if (phone.test(str)) {
+ return true;
+ }
+ }
+
+ return false;
+ });
+ } else if (locale in phones) {
+ return phones[locale].test(str); // alias falsey locale as 'any'
+ } else if (!locale || locale === 'any') {
+ for (var key in phones) {
+ // istanbul ignore else
+ if (phones.hasOwnProperty(key)) {
+ var phone = phones[key];
+
+ if (phone.test(str)) {
+ return true;
+ }
+ }
+ }
+
+ return false;
+ }
+
+ throw new Error("Invalid locale '".concat(locale, "'"));
+}
+var locales$4 = Object.keys(phones);
+
+var eth = /^(0x)[0-9a-f]{40}$/i;
+function isEthereumAddress(str) {
+ assertString(str);
+ return eth.test(str);
+}
+
+function currencyRegex(options) {
+ var decimal_digits = "\\d{".concat(options.digits_after_decimal[0], "}");
+ options.digits_after_decimal.forEach(function (digit, index) {
+ if (index !== 0) decimal_digits = "".concat(decimal_digits, "|\\d{").concat(digit, "}");
+ });
+ var symbol = "(".concat(options.symbol.replace(/\W/, function (m) {
+ return "\\".concat(m);
+ }), ")").concat(options.require_symbol ? '' : '?'),
+ negative = '-?',
+ whole_dollar_amount_without_sep = '[1-9]\\d*',
+ whole_dollar_amount_with_sep = "[1-9]\\d{0,2}(\\".concat(options.thousands_separator, "\\d{3})*"),
+ valid_whole_dollar_amounts = ['0', whole_dollar_amount_without_sep, whole_dollar_amount_with_sep],
+ whole_dollar_amount = "(".concat(valid_whole_dollar_amounts.join('|'), ")?"),
+ decimal_amount = "(\\".concat(options.decimal_separator, "(").concat(decimal_digits, "))").concat(options.require_decimal ? '' : '?');
+ var pattern = whole_dollar_amount + (options.allow_decimal || options.require_decimal ? decimal_amount : ''); // default is negative sign before symbol, but there are two other options (besides parens)
+
+ if (options.allow_negatives && !options.parens_for_negatives) {
+ if (options.negative_sign_after_digits) {
+ pattern += negative;
+ } else if (options.negative_sign_before_digits) {
+ pattern = negative + pattern;
+ }
+ } // South African Rand, for example, uses R 123 (space) and R-123 (no space)
+
+
+ if (options.allow_negative_sign_placeholder) {
+ pattern = "( (?!\\-))?".concat(pattern);
+ } else if (options.allow_space_after_symbol) {
+ pattern = " ?".concat(pattern);
+ } else if (options.allow_space_after_digits) {
+ pattern += '( (?!$))?';
+ }
+
+ if (options.symbol_after_digits) {
+ pattern += symbol;
+ } else {
+ pattern = symbol + pattern;
+ }
+
+ if (options.allow_negatives) {
+ if (options.parens_for_negatives) {
+ pattern = "(\\(".concat(pattern, "\\)|").concat(pattern, ")");
+ } else if (!(options.negative_sign_before_digits || options.negative_sign_after_digits)) {
+ pattern = negative + pattern;
+ }
+ } // ensure there's a dollar and/or decimal amount, and that
+ // it doesn't start with a space or a negative sign followed by a space
+
+
+ return new RegExp("^(?!-? )(?=.*\\d)".concat(pattern, "$"));
+}
+
+var default_currency_options = {
+ symbol: '$',
+ require_symbol: false,
+ allow_space_after_symbol: false,
+ symbol_after_digits: false,
+ allow_negatives: true,
+ parens_for_negatives: false,
+ negative_sign_before_digits: false,
+ negative_sign_after_digits: false,
+ allow_negative_sign_placeholder: false,
+ thousands_separator: ',',
+ decimal_separator: '.',
+ allow_decimal: true,
+ require_decimal: false,
+ digits_after_decimal: [2],
+ allow_space_after_digits: false
+};
+function isCurrency(str, options) {
+ assertString(str);
+ options = merge(options, default_currency_options);
+ return currencyRegex(options).test(str);
+}
+
+var bech32 = /^(bc1)[a-z0-9]{25,39}$/;
+var base58 = /^(1|3)[A-HJ-NP-Za-km-z1-9]{25,39}$/;
+function isBtcAddress(str) {
+ assertString(str);
+ return bech32.test(str) || base58.test(str);
+}
+
+var isISO6391Set = new Set(['aa', 'ab', 'ae', 'af', 'ak', 'am', 'an', 'ar', 'as', 'av', 'ay', 'az', 'az', 'ba', 'be', 'bg', 'bh', 'bi', 'bm', 'bn', 'bo', 'br', 'bs', 'ca', 'ce', 'ch', 'co', 'cr', 'cs', 'cu', 'cv', 'cy', 'da', 'de', 'dv', 'dz', 'ee', 'el', 'en', 'eo', 'es', 'et', 'eu', 'fa', 'ff', 'fi', 'fj', 'fo', 'fr', 'fy', 'ga', 'gd', 'gl', 'gn', 'gu', 'gv', 'ha', 'he', 'hi', 'ho', 'hr', 'ht', 'hu', 'hy', 'hz', 'ia', 'id', 'ie', 'ig', 'ii', 'ik', 'io', 'is', 'it', 'iu', 'ja', 'jv', 'ka', 'kg', 'ki', 'kj', 'kk', 'kl', 'km', 'kn', 'ko', 'kr', 'ks', 'ku', 'kv', 'kw', 'ky', 'la', 'lb', 'lg', 'li', 'ln', 'lo', 'lt', 'lu', 'lv', 'mg', 'mh', 'mi', 'mk', 'ml', 'mn', 'mr', 'ms', 'mt', 'my', 'na', 'nb', 'nd', 'ne', 'ng', 'nl', 'nn', 'no', 'nr', 'nv', 'ny', 'oc', 'oj', 'om', 'or', 'os', 'pa', 'pi', 'pl', 'ps', 'pt', 'qu', 'rm', 'rn', 'ro', 'ru', 'rw', 'sa', 'sc', 'sd', 'se', 'sg', 'si', 'sk', 'sl', 'sm', 'sn', 'so', 'sq', 'sr', 'ss', 'st', 'su', 'sv', 'sw', 'ta', 'te', 'tg', 'th', 'ti', 'tk', 'tl', 'tn', 'to', 'tr', 'ts', 'tt', 'tw', 'ty', 'ug', 'uk', 'ur', 'uz', 've', 'vi', 'vo', 'wa', 'wo', 'xh', 'yi', 'yo', 'za', 'zh', 'zu']);
+function isISO6391(str) {
+ assertString(str);
+ return isISO6391Set.has(str);
+}
+
+/* eslint-disable max-len */
+// from http://goo.gl/0ejHHW
+
+var iso8601 = /^([\+-]?\d{4}(?!\d{2}\b))((-?)((0[1-9]|1[0-2])(\3([12]\d|0[1-9]|3[01]))?|W([0-4]\d|5[0-3])(-?[1-7])?|(00[1-9]|0[1-9]\d|[12]\d{2}|3([0-5]\d|6[1-6])))([T\s]((([01]\d|2[0-3])((:?)[0-5]\d)?|24:?00)([\.,]\d+(?!:))?)?(\17[0-5]\d([\.,]\d+)?)?([zZ]|([\+-])([01]\d|2[0-3]):?([0-5]\d)?)?)?)?$/; // same as above, except with a strict 'T' separator between date and time
+
+var iso8601StrictSeparator = /^([\+-]?\d{4}(?!\d{2}\b))((-?)((0[1-9]|1[0-2])(\3([12]\d|0[1-9]|3[01]))?|W([0-4]\d|5[0-3])(-?[1-7])?|(00[1-9]|0[1-9]\d|[12]\d{2}|3([0-5]\d|6[1-6])))([T]((([01]\d|2[0-3])((:?)[0-5]\d)?|24:?00)([\.,]\d+(?!:))?)?(\17[0-5]\d([\.,]\d+)?)?([zZ]|([\+-])([01]\d|2[0-3]):?([0-5]\d)?)?)?)?$/;
+/* eslint-enable max-len */
+
+var isValidDate = function isValidDate(str) {
+ // str must have passed the ISO8601 check
+ // this check is meant to catch invalid dates
+ // like 2009-02-31
+ // first check for ordinal dates
+ var ordinalMatch = str.match(/^(\d{4})-?(\d{3})([ T]{1}\.*|$)/);
+
+ if (ordinalMatch) {
+ var oYear = Number(ordinalMatch[1]);
+ var oDay = Number(ordinalMatch[2]); // if is leap year
+
+ if (oYear % 4 === 0 && oYear % 100 !== 0 || oYear % 400 === 0) return oDay <= 366;
+ return oDay <= 365;
+ }
+
+ var match = str.match(/(\d{4})-?(\d{0,2})-?(\d*)/).map(Number);
+ var year = match[1];
+ var month = match[2];
+ var day = match[3];
+ var monthString = month ? "0".concat(month).slice(-2) : month;
+ var dayString = day ? "0".concat(day).slice(-2) : day; // create a date object and compare
+
+ var d = new Date("".concat(year, "-").concat(monthString || '01', "-").concat(dayString || '01'));
+
+ if (month && day) {
+ return d.getUTCFullYear() === year && d.getUTCMonth() + 1 === month && d.getUTCDate() === day;
+ }
+
+ return true;
+};
+
+function isISO8601(str) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {};
+ assertString(str);
+ var check = options.strictSeparator ? iso8601StrictSeparator.test(str) : iso8601.test(str);
+ if (check && options.strict) return isValidDate(str);
+ return check;
+}
+
+/* Based on https://tools.ietf.org/html/rfc3339#section-5.6 */
+
+var dateFullYear = /[0-9]{4}/;
+var dateMonth = /(0[1-9]|1[0-2])/;
+var dateMDay = /([12]\d|0[1-9]|3[01])/;
+var timeHour = /([01][0-9]|2[0-3])/;
+var timeMinute = /[0-5][0-9]/;
+var timeSecond = /([0-5][0-9]|60)/;
+var timeSecFrac = /(\.[0-9]+)?/;
+var timeNumOffset = new RegExp("[-+]".concat(timeHour.source, ":").concat(timeMinute.source));
+var timeOffset = new RegExp("([zZ]|".concat(timeNumOffset.source, ")"));
+var partialTime = new RegExp("".concat(timeHour.source, ":").concat(timeMinute.source, ":").concat(timeSecond.source).concat(timeSecFrac.source));
+var fullDate = new RegExp("".concat(dateFullYear.source, "-").concat(dateMonth.source, "-").concat(dateMDay.source));
+var fullTime = new RegExp("".concat(partialTime.source).concat(timeOffset.source));
+var rfc3339 = new RegExp("^".concat(fullDate.source, "[ tT]").concat(fullTime.source, "$"));
+function isRFC3339(str) {
+ assertString(str);
+ return rfc3339.test(str);
+}
+
+var validISO31661Alpha3CountriesCodes = new Set(['AFG', 'ALA', 'ALB', 'DZA', 'ASM', 'AND', 'AGO', 'AIA', 'ATA', 'ATG', 'ARG', 'ARM', 'ABW', 'AUS', 'AUT', 'AZE', 'BHS', 'BHR', 'BGD', 'BRB', 'BLR', 'BEL', 'BLZ', 'BEN', 'BMU', 'BTN', 'BOL', 'BES', 'BIH', 'BWA', 'BVT', 'BRA', 'IOT', 'BRN', 'BGR', 'BFA', 'BDI', 'KHM', 'CMR', 'CAN', 'CPV', 'CYM', 'CAF', 'TCD', 'CHL', 'CHN', 'CXR', 'CCK', 'COL', 'COM', 'COG', 'COD', 'COK', 'CRI', 'CIV', 'HRV', 'CUB', 'CUW', 'CYP', 'CZE', 'DNK', 'DJI', 'DMA', 'DOM', 'ECU', 'EGY', 'SLV', 'GNQ', 'ERI', 'EST', 'ETH', 'FLK', 'FRO', 'FJI', 'FIN', 'FRA', 'GUF', 'PYF', 'ATF', 'GAB', 'GMB', 'GEO', 'DEU', 'GHA', 'GIB', 'GRC', 'GRL', 'GRD', 'GLP', 'GUM', 'GTM', 'GGY', 'GIN', 'GNB', 'GUY', 'HTI', 'HMD', 'VAT', 'HND', 'HKG', 'HUN', 'ISL', 'IND', 'IDN', 'IRN', 'IRQ', 'IRL', 'IMN', 'ISR', 'ITA', 'JAM', 'JPN', 'JEY', 'JOR', 'KAZ', 'KEN', 'KIR', 'PRK', 'KOR', 'KWT', 'KGZ', 'LAO', 'LVA', 'LBN', 'LSO', 'LBR', 'LBY', 'LIE', 'LTU', 'LUX', 'MAC', 'MKD', 'MDG', 'MWI', 'MYS', 'MDV', 'MLI', 'MLT', 'MHL', 'MTQ', 'MRT', 'MUS', 'MYT', 'MEX', 'FSM', 'MDA', 'MCO', 'MNG', 'MNE', 'MSR', 'MAR', 'MOZ', 'MMR', 'NAM', 'NRU', 'NPL', 'NLD', 'NCL', 'NZL', 'NIC', 'NER', 'NGA', 'NIU', 'NFK', 'MNP', 'NOR', 'OMN', 'PAK', 'PLW', 'PSE', 'PAN', 'PNG', 'PRY', 'PER', 'PHL', 'PCN', 'POL', 'PRT', 'PRI', 'QAT', 'REU', 'ROU', 'RUS', 'RWA', 'BLM', 'SHN', 'KNA', 'LCA', 'MAF', 'SPM', 'VCT', 'WSM', 'SMR', 'STP', 'SAU', 'SEN', 'SRB', 'SYC', 'SLE', 'SGP', 'SXM', 'SVK', 'SVN', 'SLB', 'SOM', 'ZAF', 'SGS', 'SSD', 'ESP', 'LKA', 'SDN', 'SUR', 'SJM', 'SWZ', 'SWE', 'CHE', 'SYR', 'TWN', 'TJK', 'TZA', 'THA', 'TLS', 'TGO', 'TKL', 'TON', 'TTO', 'TUN', 'TUR', 'TKM', 'TCA', 'TUV', 'UGA', 'UKR', 'ARE', 'GBR', 'USA', 'UMI', 'URY', 'UZB', 'VUT', 'VEN', 'VNM', 'VGB', 'VIR', 'WLF', 'ESH', 'YEM', 'ZMB', 'ZWE']);
+function isISO31661Alpha3(str) {
+ assertString(str);
+ return validISO31661Alpha3CountriesCodes.has(str.toUpperCase());
+}
+
+var validISO4217CurrencyCodes = new Set(['AED', 'AFN', 'ALL', 'AMD', 'ANG', 'AOA', 'ARS', 'AUD', 'AWG', 'AZN', 'BAM', 'BBD', 'BDT', 'BGN', 'BHD', 'BIF', 'BMD', 'BND', 'BOB', 'BOV', 'BRL', 'BSD', 'BTN', 'BWP', 'BYN', 'BZD', 'CAD', 'CDF', 'CHE', 'CHF', 'CHW', 'CLF', 'CLP', 'CNY', 'COP', 'COU', 'CRC', 'CUC', 'CUP', 'CVE', 'CZK', 'DJF', 'DKK', 'DOP', 'DZD', 'EGP', 'ERN', 'ETB', 'EUR', 'FJD', 'FKP', 'GBP', 'GEL', 'GHS', 'GIP', 'GMD', 'GNF', 'GTQ', 'GYD', 'HKD', 'HNL', 'HRK', 'HTG', 'HUF', 'IDR', 'ILS', 'INR', 'IQD', 'IRR', 'ISK', 'JMD', 'JOD', 'JPY', 'KES', 'KGS', 'KHR', 'KMF', 'KPW', 'KRW', 'KWD', 'KYD', 'KZT', 'LAK', 'LBP', 'LKR', 'LRD', 'LSL', 'LYD', 'MAD', 'MDL', 'MGA', 'MKD', 'MMK', 'MNT', 'MOP', 'MRU', 'MUR', 'MVR', 'MWK', 'MXN', 'MXV', 'MYR', 'MZN', 'NAD', 'NGN', 'NIO', 'NOK', 'NPR', 'NZD', 'OMR', 'PAB', 'PEN', 'PGK', 'PHP', 'PKR', 'PLN', 'PYG', 'QAR', 'RON', 'RSD', 'RUB', 'RWF', 'SAR', 'SBD', 'SCR', 'SDG', 'SEK', 'SGD', 'SHP', 'SLL', 'SOS', 'SRD', 'SSP', 'STN', 'SVC', 'SYP', 'SZL', 'THB', 'TJS', 'TMT', 'TND', 'TOP', 'TRY', 'TTD', 'TWD', 'TZS', 'UAH', 'UGX', 'USD', 'USN', 'UYI', 'UYU', 'UYW', 'UZS', 'VES', 'VND', 'VUV', 'WST', 'XAF', 'XAG', 'XAU', 'XBA', 'XBB', 'XBC', 'XBD', 'XCD', 'XDR', 'XOF', 'XPD', 'XPF', 'XPT', 'XSU', 'XTS', 'XUA', 'XXX', 'YER', 'ZAR', 'ZMW', 'ZWL']);
+function isISO4217(str) {
+ assertString(str);
+ return validISO4217CurrencyCodes.has(str.toUpperCase());
+}
+
+var base32 = /^[A-Z2-7]+=*$/;
+var crockfordBase32 = /^[A-HJKMNP-TV-Z0-9]+$/;
+var defaultBase32Options = {
+ crockford: false
+};
+function isBase32(str, options) {
+ assertString(str);
+ options = merge(options, defaultBase32Options);
+
+ if (options.crockford) {
+ return crockfordBase32.test(str);
+ }
+
+ var len = str.length;
+
+ if (len % 8 === 0 && base32.test(str)) {
+ return true;
+ }
+
+ return false;
+}
+
+var base58Reg = /^[A-HJ-NP-Za-km-z1-9]*$/;
+function isBase58(str) {
+ assertString(str);
+
+ if (base58Reg.test(str)) {
+ return true;
+ }
+
+ return false;
+}
+
+var validMediaType = /^[a-z]+\/[a-z0-9\-\+\._]+$/i;
+var validAttribute = /^[a-z\-]+=[a-z0-9\-]+$/i;
+var validData = /^[a-z0-9!\$&'\(\)\*\+,;=\-\._~:@\/\?%\s]*$/i;
+function isDataURI(str) {
+ assertString(str);
+ var data = str.split(',');
+
+ if (data.length < 2) {
+ return false;
+ }
+
+ var attributes = data.shift().trim().split(';');
+ var schemeAndMediaType = attributes.shift();
+
+ if (schemeAndMediaType.slice(0, 5) !== 'data:') {
+ return false;
+ }
+
+ var mediaType = schemeAndMediaType.slice(5);
+
+ if (mediaType !== '' && !validMediaType.test(mediaType)) {
+ return false;
+ }
+
+ for (var i = 0; i < attributes.length; i++) {
+ if (!(i === attributes.length - 1 && attributes[i].toLowerCase() === 'base64') && !validAttribute.test(attributes[i])) {
+ return false;
+ }
+ }
+
+ for (var _i = 0; _i < data.length; _i++) {
+ if (!validData.test(data[_i])) {
+ return false;
+ }
+ }
+
+ return true;
+}
+
+var magnetURIComponent = /(?:^magnet:\?|[^?&]&)xt(?:\.1)?=urn:(?:(?:aich|bitprint|btih|ed2k|ed2khash|kzhash|md5|sha1|tree:tiger):[a-z0-9]{32}(?:[a-z0-9]{8})?|btmh:1220[a-z0-9]{64})(?:$|&)/i;
+function isMagnetURI(url) {
+ assertString(url);
+
+ if (url.indexOf('magnet:?') !== 0) {
+ return false;
+ }
+
+ return magnetURIComponent.test(url);
+}
+
+/*
+ Checks if the provided string matches to a correct Media type format (MIME type)
+
+ This function only checks is the string format follows the
+ etablished rules by the according RFC specifications.
+ This function supports 'charset' in textual media types
+ (https://tools.ietf.org/html/rfc6657).
+
+ This function does not check against all the media types listed
+ by the IANA (https://www.iana.org/assignments/media-types/media-types.xhtml)
+ because of lightness purposes : it would require to include
+ all these MIME types in this librairy, which would weigh it
+ significantly. This kind of effort maybe is not worth for the use that
+ this function has in this entire librairy.
+
+ More informations in the RFC specifications :
+ - https://tools.ietf.org/html/rfc2045
+ - https://tools.ietf.org/html/rfc2046
+ - https://tools.ietf.org/html/rfc7231#section-3.1.1.1
+ - https://tools.ietf.org/html/rfc7231#section-3.1.1.5
+*/
+// Match simple MIME types
+// NB :
+// Subtype length must not exceed 100 characters.
+// This rule does not comply to the RFC specs (what is the max length ?).
+
+var mimeTypeSimple = /^(application|audio|font|image|message|model|multipart|text|video)\/[a-zA-Z0-9\.\-\+_]{1,100}$/i; // eslint-disable-line max-len
+// Handle "charset" in "text/*"
+
+var mimeTypeText = /^text\/[a-zA-Z0-9\.\-\+]{1,100};\s?charset=("[a-zA-Z0-9\.\-\+\s]{0,70}"|[a-zA-Z0-9\.\-\+]{0,70})(\s?\([a-zA-Z0-9\.\-\+\s]{1,20}\))?$/i; // eslint-disable-line max-len
+// Handle "boundary" in "multipart/*"
+
+var mimeTypeMultipart = /^multipart\/[a-zA-Z0-9\.\-\+]{1,100}(;\s?(boundary|charset)=("[a-zA-Z0-9\.\-\+\s]{0,70}"|[a-zA-Z0-9\.\-\+]{0,70})(\s?\([a-zA-Z0-9\.\-\+\s]{1,20}\))?){0,2}$/i; // eslint-disable-line max-len
+
+function isMimeType(str) {
+ assertString(str);
+ return mimeTypeSimple.test(str) || mimeTypeText.test(str) || mimeTypeMultipart.test(str);
+}
+
+var lat = /^\(?[+-]?(90(\.0+)?|[1-8]?\d(\.\d+)?)$/;
+var _long = /^\s?[+-]?(180(\.0+)?|1[0-7]\d(\.\d+)?|\d{1,2}(\.\d+)?)\)?$/;
+var latDMS = /^(([1-8]?\d)\D+([1-5]?\d|60)\D+([1-5]?\d|60)(\.\d+)?|90\D+0\D+0)\D+[NSns]?$/i;
+var longDMS = /^\s*([1-7]?\d{1,2}\D+([1-5]?\d|60)\D+([1-5]?\d|60)(\.\d+)?|180\D+0\D+0)\D+[EWew]?$/i;
+var defaultLatLongOptions = {
+ checkDMS: false
+};
+function isLatLong(str, options) {
+ assertString(str);
+ options = merge(options, defaultLatLongOptions);
+ if (!str.includes(',')) return false;
+ var pair = str.split(',');
+ if (pair[0].startsWith('(') && !pair[1].endsWith(')') || pair[1].endsWith(')') && !pair[0].startsWith('(')) return false;
+
+ if (options.checkDMS) {
+ return latDMS.test(pair[0]) && longDMS.test(pair[1]);
+ }
+
+ return lat.test(pair[0]) && _long.test(pair[1]);
+}
+
+var threeDigit = /^\d{3}$/;
+var fourDigit = /^\d{4}$/;
+var fiveDigit = /^\d{5}$/;
+var sixDigit = /^\d{6}$/;
+var patterns = {
+ AD: /^AD\d{3}$/,
+ AT: fourDigit,
+ AU: fourDigit,
+ AZ: /^AZ\d{4}$/,
+ BA: /^([7-8]\d{4}$)/,
+ BE: fourDigit,
+ BG: fourDigit,
+ BR: /^\d{5}-\d{3}$/,
+ BY: /^2[1-4]\d{4}$/,
+ CA: /^[ABCEGHJKLMNPRSTVXY]\d[ABCEGHJ-NPRSTV-Z][\s\-]?\d[ABCEGHJ-NPRSTV-Z]\d$/i,
+ CH: fourDigit,
+ CN: /^(0[1-7]|1[012356]|2[0-7]|3[0-6]|4[0-7]|5[1-7]|6[1-7]|7[1-5]|8[1345]|9[09])\d{4}$/,
+ CZ: /^\d{3}\s?\d{2}$/,
+ DE: fiveDigit,
+ DK: fourDigit,
+ DO: fiveDigit,
+ DZ: fiveDigit,
+ EE: fiveDigit,
+ ES: /^(5[0-2]{1}|[0-4]{1}\d{1})\d{3}$/,
+ FI: fiveDigit,
+ FR: /^\d{2}\s?\d{3}$/,
+ GB: /^(gir\s?0aa|[a-z]{1,2}\d[\da-z]?\s?(\d[a-z]{2})?)$/i,
+ GR: /^\d{3}\s?\d{2}$/,
+ HR: /^([1-5]\d{4}$)/,
+ HT: /^HT\d{4}$/,
+ HU: fourDigit,
+ ID: fiveDigit,
+ IE: /^(?!.*(?:o))[A-Za-z]\d[\dw]\s\w{4}$/i,
+ IL: /^(\d{5}|\d{7})$/,
+ IN: /^((?!10|29|35|54|55|65|66|86|87|88|89)[1-9][0-9]{5})$/,
+ IR: /^(?!(\d)\1{3})[13-9]{4}[1346-9][013-9]{5}$/,
+ IS: threeDigit,
+ IT: fiveDigit,
+ JP: /^\d{3}\-\d{4}$/,
+ KE: fiveDigit,
+ KR: /^(\d{5}|\d{6})$/,
+ LI: /^(948[5-9]|949[0-7])$/,
+ LT: /^LT\-\d{5}$/,
+ LU: fourDigit,
+ LV: /^LV\-\d{4}$/,
+ LK: fiveDigit,
+ MG: threeDigit,
+ MX: fiveDigit,
+ MT: /^[A-Za-z]{3}\s{0,1}\d{4}$/,
+ MY: fiveDigit,
+ NL: /^\d{4}\s?[a-z]{2}$/i,
+ NO: fourDigit,
+ NP: /^(10|21|22|32|33|34|44|45|56|57)\d{3}$|^(977)$/i,
+ NZ: fourDigit,
+ PL: /^\d{2}\-\d{3}$/,
+ PR: /^00[679]\d{2}([ -]\d{4})?$/,
+ PT: /^\d{4}\-\d{3}?$/,
+ RO: sixDigit,
+ RU: sixDigit,
+ SA: fiveDigit,
+ SE: /^[1-9]\d{2}\s?\d{2}$/,
+ SG: sixDigit,
+ SI: fourDigit,
+ SK: /^\d{3}\s?\d{2}$/,
+ TH: fiveDigit,
+ TN: fourDigit,
+ TW: /^\d{3}(\d{2})?$/,
+ UA: fiveDigit,
+ US: /^\d{5}(-\d{4})?$/,
+ ZA: fourDigit,
+ ZM: fiveDigit
+};
+var locales$5 = Object.keys(patterns);
+function isPostalCode(str, locale) {
+ assertString(str);
+
+ if (locale in patterns) {
+ return patterns[locale].test(str);
+ } else if (locale === 'any') {
+ for (var key in patterns) {
+ // https://github.com/gotwarlost/istanbul/blob/master/ignoring-code-for-coverage.md#ignoring-code-for-coverage-purposes
+ // istanbul ignore else
+ if (patterns.hasOwnProperty(key)) {
+ var pattern = patterns[key];
+
+ if (pattern.test(str)) {
+ return true;
+ }
+ }
+ }
+
+ return false;
+ }
+
+ throw new Error("Invalid locale '".concat(locale, "'"));
+}
+
+function ltrim(str, chars) {
+ assertString(str); // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions#Escaping
+
+ var pattern = chars ? new RegExp("^[".concat(chars.replace(/[.*+?^${}()|[\]\\]/g, '\\$&'), "]+"), 'g') : /^\s+/g;
+ return str.replace(pattern, '');
+}
+
+function rtrim(str, chars) {
+ assertString(str);
+
+ if (chars) {
+ // https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions#Escaping
+ var pattern = new RegExp("[".concat(chars.replace(/[.*+?^${}()|[\]\\]/g, '\\$&'), "]+$"), 'g');
+ return str.replace(pattern, '');
+ } // Use a faster and more safe than regex trim method https://blog.stevenlevithan.com/archives/faster-trim-javascript
+
+
+ var strIndex = str.length - 1;
+
+ while (/\s/.test(str.charAt(strIndex))) {
+ strIndex -= 1;
+ }
+
+ return str.slice(0, strIndex + 1);
+}
+
+function trim(str, chars) {
+ return rtrim(ltrim(str, chars), chars);
+}
+
+function escape(str) {
+ assertString(str);
+ return str.replace(/&/g, '&amp;').replace(/"/g, '&quot;').replace(/'/g, '&#x27;').replace(/</g, '&lt;').replace(/>/g, '&gt;').replace(/\//g, '&#x2F;').replace(/\\/g, '&#x5C;').replace(/`/g, '&#96;');
+}
+
+function unescape(str) {
+ assertString(str);
+ return str.replace(/&quot;/g, '"').replace(/&#x27;/g, "'").replace(/&lt;/g, '<').replace(/&gt;/g, '>').replace(/&#x2F;/g, '/').replace(/&#x5C;/g, '\\').replace(/&#96;/g, '`').replace(/&amp;/g, '&'); // &amp; replacement has to be the last one to prevent
+ // bugs with intermediate strings containing escape sequences
+ // See: https://github.com/validatorjs/validator.js/issues/1827
+}
+
+function blacklist$1(str, chars) {
+ assertString(str);
+ return str.replace(new RegExp("[".concat(chars, "]+"), 'g'), '');
+}
+
+function stripLow(str, keep_new_lines) {
+ assertString(str);
+ var chars = keep_new_lines ? '\\x00-\\x09\\x0B\\x0C\\x0E-\\x1F\\x7F' : '\\x00-\\x1F\\x7F';
+ return blacklist$1(str, chars);
+}
+
+function whitelist(str, chars) {
+ assertString(str);
+ return str.replace(new RegExp("[^".concat(chars, "]+"), 'g'), '');
+}
+
+function isWhitelisted(str, chars) {
+ assertString(str);
+
+ for (var i = str.length - 1; i >= 0; i--) {
+ if (chars.indexOf(str[i]) === -1) {
+ return false;
+ }
+ }
+
+ return true;
+}
+
+var default_normalize_email_options = {
+ // The following options apply to all email addresses
+ // Lowercases the local part of the email address.
+ // Please note this may violate RFC 5321 as per http://stackoverflow.com/a/9808332/192024).
+ // The domain is always lowercased, as per RFC 1035
+ all_lowercase: true,
+ // The following conversions are specific to GMail
+ // Lowercases the local part of the GMail address (known to be case-insensitive)
+ gmail_lowercase: true,
+ // Removes dots from the local part of the email address, as that's ignored by GMail
+ gmail_remove_dots: true,
+ // Removes the subaddress (e.g. "+foo") from the email address
+ gmail_remove_subaddress: true,
+ // Conversts the googlemail.com domain to gmail.com
+ gmail_convert_googlemaildotcom: true,
+ // The following conversions are specific to Outlook.com / Windows Live / Hotmail
+ // Lowercases the local part of the Outlook.com address (known to be case-insensitive)
+ outlookdotcom_lowercase: true,
+ // Removes the subaddress (e.g. "+foo") from the email address
+ outlookdotcom_remove_subaddress: true,
+ // The following conversions are specific to Yahoo
+ // Lowercases the local part of the Yahoo address (known to be case-insensitive)
+ yahoo_lowercase: true,
+ // Removes the subaddress (e.g. "-foo") from the email address
+ yahoo_remove_subaddress: true,
+ // The following conversions are specific to Yandex
+ // Lowercases the local part of the Yandex address (known to be case-insensitive)
+ yandex_lowercase: true,
+ // The following conversions are specific to iCloud
+ // Lowercases the local part of the iCloud address (known to be case-insensitive)
+ icloud_lowercase: true,
+ // Removes the subaddress (e.g. "+foo") from the email address
+ icloud_remove_subaddress: true
+}; // List of domains used by iCloud
+
+var icloud_domains = ['icloud.com', 'me.com']; // List of domains used by Outlook.com and its predecessors
+// This list is likely incomplete.
+// Partial reference:
+// https://blogs.office.com/2013/04/17/outlook-com-gets-two-step-verification-sign-in-by-alias-and-new-international-domains/
+
+var outlookdotcom_domains = ['hotmail.at', 'hotmail.be', 'hotmail.ca', 'hotmail.cl', 'hotmail.co.il', 'hotmail.co.nz', 'hotmail.co.th', 'hotmail.co.uk', 'hotmail.com', 'hotmail.com.ar', 'hotmail.com.au', 'hotmail.com.br', 'hotmail.com.gr', 'hotmail.com.mx', 'hotmail.com.pe', 'hotmail.com.tr', 'hotmail.com.vn', 'hotmail.cz', 'hotmail.de', 'hotmail.dk', 'hotmail.es', 'hotmail.fr', 'hotmail.hu', 'hotmail.id', 'hotmail.ie', 'hotmail.in', 'hotmail.it', 'hotmail.jp', 'hotmail.kr', 'hotmail.lv', 'hotmail.my', 'hotmail.ph', 'hotmail.pt', 'hotmail.sa', 'hotmail.sg', 'hotmail.sk', 'live.be', 'live.co.uk', 'live.com', 'live.com.ar', 'live.com.mx', 'live.de', 'live.es', 'live.eu', 'live.fr', 'live.it', 'live.nl', 'msn.com', 'outlook.at', 'outlook.be', 'outlook.cl', 'outlook.co.il', 'outlook.co.nz', 'outlook.co.th', 'outlook.com', 'outlook.com.ar', 'outlook.com.au', 'outlook.com.br', 'outlook.com.gr', 'outlook.com.pe', 'outlook.com.tr', 'outlook.com.vn', 'outlook.cz', 'outlook.de', 'outlook.dk', 'outlook.es', 'outlook.fr', 'outlook.hu', 'outlook.id', 'outlook.ie', 'outlook.in', 'outlook.it', 'outlook.jp', 'outlook.kr', 'outlook.lv', 'outlook.my', 'outlook.ph', 'outlook.pt', 'outlook.sa', 'outlook.sg', 'outlook.sk', 'passport.com']; // List of domains used by Yahoo Mail
+// This list is likely incomplete
+
+var yahoo_domains = ['rocketmail.com', 'yahoo.ca', 'yahoo.co.uk', 'yahoo.com', 'yahoo.de', 'yahoo.fr', 'yahoo.in', 'yahoo.it', 'ymail.com']; // List of domains used by yandex.ru
+
+var yandex_domains = ['yandex.ru', 'yandex.ua', 'yandex.kz', 'yandex.com', 'yandex.by', 'ya.ru']; // replace single dots, but not multiple consecutive dots
+
+function dotsReplacer(match) {
+ if (match.length > 1) {
+ return match;
+ }
+
+ return '';
+}
+
+function normalizeEmail(email, options) {
+ options = merge(options, default_normalize_email_options);
+ var raw_parts = email.split('@');
+ var domain = raw_parts.pop();
+ var user = raw_parts.join('@');
+ var parts = [user, domain]; // The domain is always lowercased, as it's case-insensitive per RFC 1035
+
+ parts[1] = parts[1].toLowerCase();
+
+ if (parts[1] === 'gmail.com' || parts[1] === 'googlemail.com') {
+ // Address is GMail
+ if (options.gmail_remove_subaddress) {
+ parts[0] = parts[0].split('+')[0];
+ }
+
+ if (options.gmail_remove_dots) {
+ // this does not replace consecutive dots like example..email@gmail.com
+ parts[0] = parts[0].replace(/\.+/g, dotsReplacer);
+ }
+
+ if (!parts[0].length) {
+ return false;
+ }
+
+ if (options.all_lowercase || options.gmail_lowercase) {
+ parts[0] = parts[0].toLowerCase();
+ }
+
+ parts[1] = options.gmail_convert_googlemaildotcom ? 'gmail.com' : parts[1];
+ } else if (icloud_domains.indexOf(parts[1]) >= 0) {
+ // Address is iCloud
+ if (options.icloud_remove_subaddress) {
+ parts[0] = parts[0].split('+')[0];
+ }
+
+ if (!parts[0].length) {
+ return false;
+ }
+
+ if (options.all_lowercase || options.icloud_lowercase) {
+ parts[0] = parts[0].toLowerCase();
+ }
+ } else if (outlookdotcom_domains.indexOf(parts[1]) >= 0) {
+ // Address is Outlook.com
+ if (options.outlookdotcom_remove_subaddress) {
+ parts[0] = parts[0].split('+')[0];
+ }
+
+ if (!parts[0].length) {
+ return false;
+ }
+
+ if (options.all_lowercase || options.outlookdotcom_lowercase) {
+ parts[0] = parts[0].toLowerCase();
+ }
+ } else if (yahoo_domains.indexOf(parts[1]) >= 0) {
+ // Address is Yahoo
+ if (options.yahoo_remove_subaddress) {
+ var components = parts[0].split('-');
+ parts[0] = components.length > 1 ? components.slice(0, -1).join('-') : components[0];
+ }
+
+ if (!parts[0].length) {
+ return false;
+ }
+
+ if (options.all_lowercase || options.yahoo_lowercase) {
+ parts[0] = parts[0].toLowerCase();
+ }
+ } else if (yandex_domains.indexOf(parts[1]) >= 0) {
+ if (options.all_lowercase || options.yandex_lowercase) {
+ parts[0] = parts[0].toLowerCase();
+ }
+
+ parts[1] = 'yandex.ru'; // all yandex domains are equal, 1st preferred
+ } else if (options.all_lowercase) {
+ // Any other address
+ parts[0] = parts[0].toLowerCase();
+ }
+
+ return parts.join('@');
+}
+
+var charsetRegex = /^[^\s-_](?!.*?[-_]{2,})[a-z0-9-\\][^\s]*[^-_\s]$/;
+function isSlug(str) {
+ assertString(str);
+ return charsetRegex.test(str);
+}
+
+var validators$1 = {
+ 'cs-CZ': function csCZ(str) {
+ return /^(([ABCDEFHIJKLMNPRSTUVXYZ]|[0-9])-?){5,8}$/.test(str);
+ },
+ 'de-DE': function deDE(str) {
+ return /^((A|AA|AB|AC|AE|AH|AK|AM|AN|AÖ|AP|AS|AT|AU|AW|AZ|B|BA|BB|BC|BE|BF|BH|BI|BK|BL|BM|BN|BO|BÖ|BS|BT|BZ|C|CA|CB|CE|CO|CR|CW|D|DA|DD|DE|DH|DI|DL|DM|DN|DO|DU|DW|DZ|E|EA|EB|ED|EE|EF|EG|EH|EI|EL|EM|EN|ER|ES|EU|EW|F|FB|FD|FF|FG|FI|FL|FN|FO|FR|FS|FT|FÜ|FW|FZ|G|GA|GC|GD|GE|GF|GG|GI|GK|GL|GM|GN|GÖ|GP|GR|GS|GT|GÜ|GV|GW|GZ|H|HA|HB|HC|HD|HE|HF|HG|HH|HI|HK|HL|HM|HN|HO|HP|HR|HS|HU|HV|HX|HY|HZ|IK|IL|IN|IZ|J|JE|JL|K|KA|KB|KC|KE|KF|KG|KH|KI|KK|KL|KM|KN|KO|KR|KS|KT|KU|KW|KY|L|LA|LB|LC|LD|LF|LG|LH|LI|LL|LM|LN|LÖ|LP|LR|LU|M|MA|MB|MC|MD|ME|MG|MH|MI|MK|ML|MM|MN|MO|MQ|MR|MS|MÜ|MW|MY|MZ|N|NB|ND|NE|NF|NH|NI|NK|NM|NÖ|NP|NR|NT|NU|NW|NY|NZ|OA|OB|OC|OD|OE|OF|OG|OH|OK|OL|OP|OS|OZ|P|PA|PB|PE|PF|PI|PL|PM|PN|PR|PS|PW|PZ|R|RA|RC|RD|RE|RG|RH|RI|RL|RM|RN|RO|RP|RS|RT|RU|RV|RW|RZ|S|SB|SC|SE|SG|SI|SK|SL|SM|SN|SO|SP|SR|ST|SU|SW|SY|SZ|TE|TF|TG|TO|TP|TR|TS|TT|TÜ|ÜB|UE|UH|UL|UM|UN|V|VB|VG|VK|VR|VS|W|WA|WB|WE|WF|WI|WK|WL|WM|WN|WO|WR|WS|WT|WÜ|WW|WZ|Z|ZE|ZI|ZP|ZR|ZW|ZZ)[- ]?[A-Z]{1,2}[- ]?\d{1,4}|(ABG|ABI|AIB|AIC|ALF|ALZ|ANA|ANG|ANK|APD|ARN|ART|ASL|ASZ|AUR|AZE|BAD|BAR|BBG|BCH|BED|BER|BGD|BGL|BID|BIN|BIR|BIT|BIW|BKS|BLB|BLK|BNA|BOG|BOH|BOR|BOT|BRA|BRB|BRG|BRK|BRL|BRV|BSB|BSK|BTF|BÜD|BUL|BÜR|BÜS|BÜZ|CAS|CHA|CLP|CLZ|COC|COE|CUX|DAH|DAN|DAU|DBR|DEG|DEL|DGF|DIL|DIN|DIZ|DKB|DLG|DON|DUD|DÜW|EBE|EBN|EBS|ECK|EIC|EIL|EIN|EIS|EMD|EMS|ERB|ERH|ERK|ERZ|ESB|ESW|FDB|FDS|FEU|FFB|FKB|FLÖ|FOR|FRG|FRI|FRW|FTL|FÜS|GAN|GAP|GDB|GEL|GEO|GER|GHA|GHC|GLA|GMN|GNT|GOA|GOH|GRA|GRH|GRI|GRM|GRZ|GTH|GUB|GUN|GVM|HAB|HAL|HAM|HAS|HBN|HBS|HCH|HDH|HDL|HEB|HEF|HEI|HER|HET|HGN|HGW|HHM|HIG|HIP|HMÜ|HOG|HOH|HOL|HOM|HOR|HÖS|HOT|HRO|HSK|HST|HVL|HWI|IGB|ILL|JÜL|KEH|KEL|KEM|KIB|KLE|KLZ|KÖN|KÖT|KÖZ|KRU|KÜN|KUS|KYF|LAN|LAU|LBS|LBZ|LDK|LDS|LEO|LER|LEV|LIB|LIF|LIP|LÖB|LOS|LRO|LSZ|LÜN|LUP|LWL|MAB|MAI|MAK|MAL|MED|MEG|MEI|MEK|MEL|MER|MET|MGH|MGN|MHL|MIL|MKK|MOD|MOL|MON|MOS|MSE|MSH|MSP|MST|MTK|MTL|MÜB|MÜR|MYK|MZG|NAB|NAI|NAU|NDH|NEA|NEB|NEC|NEN|NES|NEW|NMB|NMS|NOH|NOL|NOM|NOR|NVP|NWM|OAL|OBB|OBG|OCH|OHA|ÖHR|OHV|OHZ|OPR|OSL|OVI|OVL|OVP|PAF|PAN|PAR|PCH|PEG|PIR|PLÖ|PRÜ|QFT|QLB|RDG|REG|REH|REI|RID|RIE|ROD|ROF|ROK|ROL|ROS|ROT|ROW|RSL|RÜD|RÜG|SAB|SAD|SAN|SAW|SBG|SBK|SCZ|SDH|SDL|SDT|SEB|SEE|SEF|SEL|SFB|SFT|SGH|SHA|SHG|SHK|SHL|SIG|SIM|SLE|SLF|SLK|SLN|SLS|SLÜ|SLZ|SMÜ|SOB|SOG|SOK|SÖM|SON|SPB|SPN|SRB|SRO|STA|STB|STD|STE|STL|SUL|SÜW|SWA|SZB|TBB|TDO|TET|TIR|TÖL|TUT|UEM|UER|UFF|USI|VAI|VEC|VER|VIB|VIE|VIT|VOH|WAF|WAK|WAN|WAR|WAT|WBS|WDA|WEL|WEN|WER|WES|WHV|WIL|WIS|WIT|WIZ|WLG|WMS|WND|WOB|WOH|WOL|WOR|WOS|WRN|WSF|WST|WSW|WTL|WTM|WUG|WÜM|WUN|WUR|WZL|ZEL|ZIG)[- ]?(([A-Z][- ]?\d{1,4})|([A-Z]{2}[- ]?\d{1,3})))[- ]?(E|H)?$/.test(str);
+ },
+ 'de-LI': function deLI(str) {
+ return /^FL[- ]?\d{1,5}[UZ]?$/.test(str);
+ },
+ 'en-IN': function enIN(str) {
+ return /^[A-Z]{2}[ -]?[0-9]{1,2}(?:[ -]?[A-Z])(?:[ -]?[A-Z]*)?[ -]?[0-9]{4}$/.test(str);
+ },
+ 'es-AR': function esAR(str) {
+ return /^(([A-Z]{2} ?[0-9]{3} ?[A-Z]{2})|([A-Z]{3} ?[0-9]{3}))$/.test(str);
+ },
+ 'fi-FI': function fiFI(str) {
+ return /^(?=.{4,7})(([A-Z]{1,3}|[0-9]{1,3})[\s-]?([A-Z]{1,3}|[0-9]{1,5}))$/.test(str);
+ },
+ 'hu-HU': function huHU(str) {
+ return /^((((?!AAA)(([A-NPRSTVZWXY]{1})([A-PR-Z]{1})([A-HJ-NPR-Z]))|(A[ABC]I)|A[ABC]O|A[A-W]Q|BPI|BPO|UCO|UDO|XAO)-(?!000)\d{3})|(M\d{6})|((CK|DT|CD|HC|H[ABEFIKLMNPRSTVX]|MA|OT|R[A-Z]) \d{2}-\d{2})|(CD \d{3}-\d{3})|(C-(C|X) \d{4})|(X-(A|B|C) \d{4})|(([EPVZ]-\d{5}))|(S A[A-Z]{2} \d{2})|(SP \d{2}-\d{2}))$/.test(str);
+ },
+ 'pt-BR': function ptBR(str) {
+ return /^[A-Z]{3}[ -]?[0-9][A-Z][0-9]{2}|[A-Z]{3}[ -]?[0-9]{4}$/.test(str);
+ },
+ 'pt-PT': function ptPT(str) {
+ return /^([A-Z]{2}|[0-9]{2})[ -·]?([A-Z]{2}|[0-9]{2})[ -·]?([A-Z]{2}|[0-9]{2})$/.test(str);
+ },
+ 'sq-AL': function sqAL(str) {
+ return /^[A-Z]{2}[- ]?((\d{3}[- ]?(([A-Z]{2})|T))|(R[- ]?\d{3}))$/.test(str);
+ },
+ 'sv-SE': function svSE(str) {
+ return /^[A-HJ-PR-UW-Z]{3} ?[\d]{2}[A-HJ-PR-UW-Z1-9]$|(^[A-ZÅÄÖ ]{2,7}$)/.test(str.trim());
+ }
+};
+function isLicensePlate(str, locale) {
+ assertString(str);
+
+ if (locale in validators$1) {
+ return validators$1[locale](str);
+ } else if (locale === 'any') {
+ for (var key in validators$1) {
+ /* eslint guard-for-in: 0 */
+ var validator = validators$1[key];
+
+ if (validator(str)) {
+ return true;
+ }
+ }
+
+ return false;
+ }
+
+ throw new Error("Invalid locale '".concat(locale, "'"));
+}
+
+var upperCaseRegex = /^[A-Z]$/;
+var lowerCaseRegex = /^[a-z]$/;
+var numberRegex = /^[0-9]$/;
+var symbolRegex = /^[-#!$@£%^&*()_+|~=`{}\[\]:";'<>?,.\/ ]$/;
+var defaultOptions$1 = {
+ minLength: 8,
+ minLowercase: 1,
+ minUppercase: 1,
+ minNumbers: 1,
+ minSymbols: 1,
+ returnScore: false,
+ pointsPerUnique: 1,
+ pointsPerRepeat: 0.5,
+ pointsForContainingLower: 10,
+ pointsForContainingUpper: 10,
+ pointsForContainingNumber: 10,
+ pointsForContainingSymbol: 10
+};
+/* Counts number of occurrences of each char in a string
+ * could be moved to util/ ?
+*/
+
+function countChars(str) {
+ var result = {};
+ Array.from(str).forEach(function (_char) {
+ var curVal = result[_char];
+
+ if (curVal) {
+ result[_char] += 1;
+ } else {
+ result[_char] = 1;
+ }
+ });
+ return result;
+}
+/* Return information about a password */
+
+
+function analyzePassword(password) {
+ var charMap = countChars(password);
+ var analysis = {
+ length: password.length,
+ uniqueChars: Object.keys(charMap).length,
+ uppercaseCount: 0,
+ lowercaseCount: 0,
+ numberCount: 0,
+ symbolCount: 0
+ };
+ Object.keys(charMap).forEach(function (_char2) {
+ /* istanbul ignore else */
+ if (upperCaseRegex.test(_char2)) {
+ analysis.uppercaseCount += charMap[_char2];
+ } else if (lowerCaseRegex.test(_char2)) {
+ analysis.lowercaseCount += charMap[_char2];
+ } else if (numberRegex.test(_char2)) {
+ analysis.numberCount += charMap[_char2];
+ } else if (symbolRegex.test(_char2)) {
+ analysis.symbolCount += charMap[_char2];
+ }
+ });
+ return analysis;
+}
+
+function scorePassword(analysis, scoringOptions) {
+ var points = 0;
+ points += analysis.uniqueChars * scoringOptions.pointsPerUnique;
+ points += (analysis.length - analysis.uniqueChars) * scoringOptions.pointsPerRepeat;
+
+ if (analysis.lowercaseCount > 0) {
+ points += scoringOptions.pointsForContainingLower;
+ }
+
+ if (analysis.uppercaseCount > 0) {
+ points += scoringOptions.pointsForContainingUpper;
+ }
+
+ if (analysis.numberCount > 0) {
+ points += scoringOptions.pointsForContainingNumber;
+ }
+
+ if (analysis.symbolCount > 0) {
+ points += scoringOptions.pointsForContainingSymbol;
+ }
+
+ return points;
+}
+
+function isStrongPassword(str) {
+ var options = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : null;
+ assertString(str);
+ var analysis = analyzePassword(str);
+ options = merge(options || {}, defaultOptions$1);
+
+ if (options.returnScore) {
+ return scorePassword(analysis, options);
+ }
+
+ return analysis.length >= options.minLength && analysis.lowercaseCount >= options.minLowercase && analysis.uppercaseCount >= options.minUppercase && analysis.numberCount >= options.minNumbers && analysis.symbolCount >= options.minSymbols;
+}
+
+var PT = function PT(str) {
+ var match = str.match(/^(PT)?(\d{9})$/);
+
+ if (!match) {
+ return false;
+ }
+
+ var tin = match[2];
+ var checksum = 11 - reverseMultiplyAndSum(tin.split('').slice(0, 8).map(function (a) {
+ return parseInt(a, 10);
+ }), 9) % 11;
+
+ if (checksum > 9) {
+ return parseInt(tin[8], 10) === 0;
+ }
+
+ return checksum === parseInt(tin[8], 10);
+};
+
+var vatMatchers = {
+ /**
+ * European Union VAT identification numbers
+ */
+ AT: function AT(str) {
+ return /^(AT)?U\d{8}$/.test(str);
+ },
+ BE: function BE(str) {
+ return /^(BE)?\d{10}$/.test(str);
+ },
+ BG: function BG(str) {
+ return /^(BG)?\d{9,10}$/.test(str);
+ },
+ HR: function HR(str) {
+ return /^(HR)?\d{11}$/.test(str);
+ },
+ CY: function CY(str) {
+ return /^(CY)?\w{9}$/.test(str);
+ },
+ CZ: function CZ(str) {
+ return /^(CZ)?\d{8,10}$/.test(str);
+ },
+ DK: function DK(str) {
+ return /^(DK)?\d{8}$/.test(str);
+ },
+ EE: function EE(str) {
+ return /^(EE)?\d{9}$/.test(str);
+ },
+ FI: function FI(str) {
+ return /^(FI)?\d{8}$/.test(str);
+ },
+ FR: function FR(str) {
+ return /^(FR)?\w{2}\d{9}$/.test(str);
+ },
+ DE: function DE(str) {
+ return /^(DE)?\d{9}$/.test(str);
+ },
+ EL: function EL(str) {
+ return /^(EL)?\d{9}$/.test(str);
+ },
+ HU: function HU(str) {
+ return /^(HU)?\d{8}$/.test(str);
+ },
+ IE: function IE(str) {
+ return /^(IE)?\d{7}\w{1}(W)?$/.test(str);
+ },
+ IT: function IT(str) {
+ return /^(IT)?\d{11}$/.test(str);
+ },
+ LV: function LV(str) {
+ return /^(LV)?\d{11}$/.test(str);
+ },
+ LT: function LT(str) {
+ return /^(LT)?\d{9,12}$/.test(str);
+ },
+ LU: function LU(str) {
+ return /^(LU)?\d{8}$/.test(str);
+ },
+ MT: function MT(str) {
+ return /^(MT)?\d{8}$/.test(str);
+ },
+ NL: function NL(str) {
+ return /^(NL)?\d{9}B\d{2}$/.test(str);
+ },
+ PL: function PL(str) {
+ return /^(PL)?(\d{10}|(\d{3}-\d{3}-\d{2}-\d{2})|(\d{3}-\d{2}-\d{2}-\d{3}))$/.test(str);
+ },
+ PT: PT,
+ RO: function RO(str) {
+ return /^(RO)?\d{2,10}$/.test(str);
+ },
+ SK: function SK(str) {
+ return /^(SK)?\d{10}$/.test(str);
+ },
+ SI: function SI(str) {
+ return /^(SI)?\d{8}$/.test(str);
+ },
+ ES: function ES(str) {
+ return /^(ES)?\w\d{7}[A-Z]$/.test(str);
+ },
+ SE: function SE(str) {
+ return /^(SE)?\d{12}$/.test(str);
+ },
+
+ /**
+ * VAT numbers of non-EU countries
+ */
+ AL: function AL(str) {
+ return /^(AL)?\w{9}[A-Z]$/.test(str);
+ },
+ MK: function MK(str) {
+ return /^(MK)?\d{13}$/.test(str);
+ },
+ AU: function AU(str) {
+ return /^(AU)?\d{11}$/.test(str);
+ },
+ BY: function BY(str) {
+ return /^(УНП )?\d{9}$/.test(str);
+ },
+ CA: function CA(str) {
+ return /^(CA)?\d{9}$/.test(str);
+ },
+ IS: function IS(str) {
+ return /^(IS)?\d{5,6}$/.test(str);
+ },
+ IN: function IN(str) {
+ return /^(IN)?\d{15}$/.test(str);
+ },
+ ID: function ID(str) {
+ return /^(ID)?(\d{15}|(\d{2}.\d{3}.\d{3}.\d{1}-\d{3}.\d{3}))$/.test(str);
+ },
+ IL: function IL(str) {
+ return /^(IL)?\d{9}$/.test(str);
+ },
+ KZ: function KZ(str) {
+ return /^(KZ)?\d{9}$/.test(str);
+ },
+ NZ: function NZ(str) {
+ return /^(NZ)?\d{9}$/.test(str);
+ },
+ NG: function NG(str) {
+ return /^(NG)?(\d{12}|(\d{8}-\d{4}))$/.test(str);
+ },
+ NO: function NO(str) {
+ return /^(NO)?\d{9}MVA$/.test(str);
+ },
+ PH: function PH(str) {
+ return /^(PH)?(\d{12}|\d{3} \d{3} \d{3} \d{3})$/.test(str);
+ },
+ RU: function RU(str) {
+ return /^(RU)?(\d{10}|\d{12})$/.test(str);
+ },
+ SM: function SM(str) {
+ return /^(SM)?\d{5}$/.test(str);
+ },
+ SA: function SA(str) {
+ return /^(SA)?\d{15}$/.test(str);
+ },
+ RS: function RS(str) {
+ return /^(RS)?\d{9}$/.test(str);
+ },
+ CH: function CH(str) {
+ return /^(CH)?(\d{6}|\d{9}|(\d{3}.\d{3})|(\d{3}.\d{3}.\d{3}))(TVA|MWST|IVA)$/.test(str);
+ },
+ TR: function TR(str) {
+ return /^(TR)?\d{10}$/.test(str);
+ },
+ UA: function UA(str) {
+ return /^(UA)?\d{12}$/.test(str);
+ },
+ GB: function GB(str) {
+ return /^GB((\d{3} \d{4} ([0-8][0-9]|9[0-6]))|(\d{9} \d{3})|(((GD[0-4])|(HA[5-9]))[0-9]{2}))$/.test(str);
+ },
+ UZ: function UZ(str) {
+ return /^(UZ)?\d{9}$/.test(str);
+ },
+
+ /**
+ * VAT numbers of Latin American countries
+ */
+ AR: function AR(str) {
+ return /^(AR)?\d{11}$/.test(str);
+ },
+ BO: function BO(str) {
+ return /^(BO)?\d{7}$/.test(str);
+ },
+ BR: function BR(str) {
+ return /^(BR)?((\d{2}.\d{3}.\d{3}\/\d{4}-\d{2})|(\d{3}.\d{3}.\d{3}-\d{2}))$/.test(str);
+ },
+ CL: function CL(str) {
+ return /^(CL)?\d{8}-\d{1}$/.test(str);
+ },
+ CO: function CO(str) {
+ return /^(CO)?\d{10}$/.test(str);
+ },
+ CR: function CR(str) {
+ return /^(CR)?\d{9,12}$/.test(str);
+ },
+ EC: function EC(str) {
+ return /^(EC)?\d{13}$/.test(str);
+ },
+ SV: function SV(str) {
+ return /^(SV)?\d{4}-\d{6}-\d{3}-\d{1}$/.test(str);
+ },
+ GT: function GT(str) {
+ return /^(GT)?\d{7}-\d{1}$/.test(str);
+ },
+ HN: function HN(str) {
+ return /^(HN)?$/.test(str);
+ },
+ MX: function MX(str) {
+ return /^(MX)?\w{3,4}\d{6}\w{3}$/.test(str);
+ },
+ NI: function NI(str) {
+ return /^(NI)?\d{3}-\d{6}-\d{4}\w{1}$/.test(str);
+ },
+ PA: function PA(str) {
+ return /^(PA)?$/.test(str);
+ },
+ PY: function PY(str) {
+ return /^(PY)?\d{6,8}-\d{1}$/.test(str);
+ },
+ PE: function PE(str) {
+ return /^(PE)?\d{11}$/.test(str);
+ },
+ DO: function DO(str) {
+ return /^(DO)?(\d{11}|(\d{3}-\d{7}-\d{1})|[1,4,5]{1}\d{8}|([1,4,5]{1})-\d{2}-\d{5}-\d{1})$/.test(str);
+ },
+ UY: function UY(str) {
+ return /^(UY)?\d{12}$/.test(str);
+ },
+ VE: function VE(str) {
+ return /^(VE)?[J,G,V,E]{1}-(\d{9}|(\d{8}-\d{1}))$/.test(str);
+ }
+};
+function isVAT(str, countryCode) {
+ assertString(str);
+ assertString(countryCode);
+
+ if (countryCode in vatMatchers) {
+ return vatMatchers[countryCode](str);
+ }
+
+ throw new Error("Invalid country code: '".concat(countryCode, "'"));
+}
+
+var version = '13.9.0';
+var validator = {
+ version: version,
+ toDate: toDate,
+ toFloat: toFloat,
+ toInt: toInt,
+ toBoolean: toBoolean,
+ equals: equals,
+ contains: contains,
+ matches: matches,
+ isEmail: isEmail,
+ isURL: isURL,
+ isMACAddress: isMACAddress,
+ isIP: isIP,
+ isIPRange: isIPRange,
+ isFQDN: isFQDN,
+ isBoolean: isBoolean,
+ isIBAN: isIBAN,
+ isBIC: isBIC,
+ isAlpha: isAlpha,
+ isAlphaLocales: locales$1,
+ isAlphanumeric: isAlphanumeric,
+ isAlphanumericLocales: locales$2,
+ isNumeric: isNumeric,
+ isPassportNumber: isPassportNumber,
+ isPort: isPort,
+ isLowercase: isLowercase,
+ isUppercase: isUppercase,
+ isAscii: isAscii,
+ isFullWidth: isFullWidth,
+ isHalfWidth: isHalfWidth,
+ isVariableWidth: isVariableWidth,
+ isMultibyte: isMultibyte,
+ isSemVer: isSemVer,
+ isSurrogatePair: isSurrogatePair,
+ isInt: isInt,
+ isIMEI: isIMEI,
+ isFloat: isFloat,
+ isFloatLocales: locales,
+ isDecimal: isDecimal,
+ isHexadecimal: isHexadecimal,
+ isOctal: isOctal,
+ isDivisibleBy: isDivisibleBy,
+ isHexColor: isHexColor,
+ isRgbColor: isRgbColor,
+ isHSL: isHSL,
+ isISRC: isISRC,
+ isMD5: isMD5,
+ isHash: isHash,
+ isJWT: isJWT,
+ isJSON: isJSON,
+ isEmpty: isEmpty,
+ isLength: isLength,
+ isLocale: isLocale,
+ isByteLength: isByteLength,
+ isUUID: isUUID,
+ isMongoId: isMongoId,
+ isAfter: isAfter,
+ isBefore: isBefore,
+ isIn: isIn,
+ isLuhnNumber: isLuhnNumber,
+ isCreditCard: isCreditCard,
+ isIdentityCard: isIdentityCard,
+ isEAN: isEAN,
+ isISIN: isISIN,
+ isISBN: isISBN,
+ isISSN: isISSN,
+ isMobilePhone: isMobilePhone,
+ isMobilePhoneLocales: locales$4,
+ isPostalCode: isPostalCode,
+ isPostalCodeLocales: locales$5,
+ isEthereumAddress: isEthereumAddress,
+ isCurrency: isCurrency,
+ isBtcAddress: isBtcAddress,
+ isISO6391: isISO6391,
+ isISO8601: isISO8601,
+ isRFC3339: isRFC3339,
+ isISO31661Alpha2: isISO31661Alpha2,
+ isISO31661Alpha3: isISO31661Alpha3,
+ isISO4217: isISO4217,
+ isBase32: isBase32,
+ isBase58: isBase58,
+ isBase64: isBase64,
+ isDataURI: isDataURI,
+ isMagnetURI: isMagnetURI,
+ isMimeType: isMimeType,
+ isLatLong: isLatLong,
+ ltrim: ltrim,
+ rtrim: rtrim,
+ trim: trim,
+ escape: escape,
+ unescape: unescape,
+ stripLow: stripLow,
+ whitelist: whitelist,
+ blacklist: blacklist$1,
+ isWhitelisted: isWhitelisted,
+ normalizeEmail: normalizeEmail,
+ toString: toString,
+ isSlug: isSlug,
+ isStrongPassword: isStrongPassword,
+ isTaxID: isTaxID,
+ isDate: isDate,
+ isTime: isTime,
+ isLicensePlate: isLicensePlate,
+ isVAT: isVAT,
+ ibanLocales: locales$3
+};
+
+return validator;
+
+})));
diff --git a/includes/external/addressbook/node_modules/validator/validator.min.js b/includes/external/addressbook/node_modules/validator/validator.min.js
new file mode 100644
index 0000000..fa56637
--- /dev/null
+++ b/includes/external/addressbook/node_modules/validator/validator.min.js
@@ -0,0 +1,23 @@
+/*!
+ * Copyright (c) 2018 Chris O'Hara <cohara87@gmail.com>
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining
+ * a copy of this software and associated documentation files (the
+ * "Software"), to deal in the Software without restriction, including
+ * without limitation the rights to use, copy, modify, merge, publish,
+ * distribute, sublicense, and/or sell copies of the Software, and to
+ * permit persons to whom the Software is furnished to do so, subject to
+ * the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be
+ * included in all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
+ * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
+ * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
+ * LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
+ * OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
+ * WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+ */
+!function(t,e){"object"==typeof exports&&"undefined"!=typeof module?module.exports=e():"function"==typeof define&&define.amd?define(e):t.validator=e()}(this,function(){"use strict";function o(t){return(o="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(t){return typeof t}:function(t){return t&&"function"==typeof Symbol&&t.constructor===Symbol&&t!==Symbol.prototype?"symbol":typeof t})(t)}function l(t,e){return function(t){if(Array.isArray(t))return t}(t)||function(t,e){if("undefined"!=typeof Symbol&&Symbol.iterator in Object(t)){var r=[],n=!0,i=!1,o=void 0;try{for(var a,s=t[Symbol.iterator]();!(n=(a=s.next()).done)&&(r.push(a.value),!e||r.length!==e);n=!0);}catch(t){i=!0,o=t}finally{try{n||null==s.return||s.return()}finally{if(i)throw o}}return r}}(t,e)||d(t,e)||function(){throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function r(t){return function(t){if(Array.isArray(t))return n(t)}(t)||function(t){if("undefined"!=typeof Symbol&&Symbol.iterator in Object(t))return Array.from(t)}(t)||d(t)||function(){throw new TypeError("Invalid attempt to spread non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}()}function d(t,e){if(t){if("string"==typeof t)return n(t,e);var r=Object.prototype.toString.call(t).slice(8,-1);return"Map"===(r="Object"===r&&t.constructor?t.constructor.name:r)||"Set"===r?Array.from(t):"Arguments"===r||/^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(r)?n(t,e):void 0}}function n(t,e){(null==e||e>t.length)&&(e=t.length);for(var r=0,n=new Array(e);r<e;r++)n[r]=t[r];return n}function u(t){if(!("string"==typeof t||t instanceof String)){var e=o(t);throw null===t?e="null":"object"===e&&(e=t.constructor.name),new TypeError("Expected a string but received a ".concat(e))}}function i(t){return u(t),t=Date.parse(t),isNaN(t)?null:new Date(t)}for(var t,a={"en-US":/^[A-Z]+$/i,"az-AZ":/^[A-VXYZÇƏĞİıÖŞÜ]+$/i,"bg-BG":/^[А-Я]+$/i,"cs-CZ":/^[A-ZÁČĎÉĚÍŇÓŘŠŤÚŮÝŽ]+$/i,"da-DK":/^[A-ZÆØÅ]+$/i,"de-DE":/^[A-ZÄÖÜß]+$/i,"el-GR":/^[Α-ώ]+$/i,"es-ES":/^[A-ZÁÉÍÑÓÚÜ]+$/i,"fa-IR":/^[ابپتثجچحخدذرزژسشصضطظعغفقکگلمنوهی]+$/i,"fi-FI":/^[A-ZÅÄÖ]+$/i,"fr-FR":/^[A-ZÀÂÆÇÉÈÊËÏÎÔŒÙÛÜŸ]+$/i,"it-IT":/^[A-ZÀÉÈÌÎÓÒÙ]+$/i,"ja-JP":/^[ぁ-んァ-ヶヲ-゚一-龠ー・。、]+$/i,"nb-NO":/^[A-ZÆØÅ]+$/i,"nl-NL":/^[A-ZÁÉËÏÓÖÜÚ]+$/i,"nn-NO":/^[A-ZÆØÅ]+$/i,"hu-HU":/^[A-ZÁÉÍÓÖŐÚÜŰ]+$/i,"pl-PL":/^[A-ZĄĆĘŚŁŃÓŻŹ]+$/i,"pt-PT":/^[A-ZÃÁÀÂÄÇÉÊËÍÏÕÓÔÖÚÜ]+$/i,"ru-RU":/^[А-ЯЁ]+$/i,"sl-SI":/^[A-ZČĆĐŠŽ]+$/i,"sk-SK":/^[A-ZÁČĎÉÍŇÓŠŤÚÝŽĹŔĽÄÔ]+$/i,"sr-RS@latin":/^[A-ZČĆŽŠĐ]+$/i,"sr-RS":/^[А-ЯЂЈЉЊЋЏ]+$/i,"sv-SE":/^[A-ZÅÄÖ]+$/i,"th-TH":/^[ก-๐\s]+$/i,"tr-TR":/^[A-ZÇĞİıÖŞÜ]+$/i,"uk-UA":/^[А-ЩЬЮЯЄIЇҐі]+$/i,"vi-VN":/^[A-ZÀÁẠẢÃÂẦẤẬẨẪĂẰẮẶẲẴĐÈÉẸẺẼÊỀẾỆỂỄÌÍỊỈĨÒÓỌỎÕÔỒỐỘỔỖƠỜỚỢỞỠÙÚỤỦŨƯỪỨỰỬỮỲÝỴỶỸ]+$/i,"ko-KR":/^[ㄱ-ㅎㅏ-ㅣ가-힣]*$/,"ku-IQ":/^[ئابپتجچحخدرڕزژسشعغفڤقکگلڵمنوۆھەیێيطؤثآإأكضصةظذ]+$/i,ar:/^[ءآأؤإئابةتثجحخدذرزسشصضطظعغفقكلمنهوىيًٌٍَُِّْٰ]+$/,he:/^[א-ת]+$/,fa:/^['آاءأؤئبپتثجچحخدذرزژسشصضطظعغفقکگلمنوهةی']+$/i,bn:/^['ঀঁংঃঅআইঈউঊঋঌএঐওঔকখগঘঙচছজঝঞটঠডঢণতথদধনপফবভমযরলশষসহ়ঽািীুূৃৄেৈোৌ্ৎৗড়ঢ়য়ৠৡৢৣৰৱ৲৳৴৵৶৷৸৹৺৻']+$/,"hi-IN":/^[\u0900-\u0961]+[\u0972-\u097F]*$/i,"si-LK":/^[\u0D80-\u0DFF]+$/},s={"en-US":/^[0-9A-Z]+$/i,"az-AZ":/^[0-9A-VXYZÇƏĞİıÖŞÜ]+$/i,"bg-BG":/^[0-9А-Я]+$/i,"cs-CZ":/^[0-9A-ZÁČĎÉĚÍŇÓŘŠŤÚŮÝŽ]+$/i,"da-DK":/^[0-9A-ZÆØÅ]+$/i,"de-DE":/^[0-9A-ZÄÖÜß]+$/i,"el-GR":/^[0-9Α-ω]+$/i,"es-ES":/^[0-9A-ZÁÉÍÑÓÚÜ]+$/i,"fi-FI":/^[0-9A-ZÅÄÖ]+$/i,"fr-FR":/^[0-9A-ZÀÂÆÇÉÈÊËÏÎÔŒÙÛÜŸ]+$/i,"it-IT":/^[0-9A-ZÀÉÈÌÎÓÒÙ]+$/i,"ja-JP":/^[0-90-9ぁ-んァ-ヶヲ-゚一-龠ー・。、]+$/i,"hu-HU":/^[0-9A-ZÁÉÍÓÖŐÚÜŰ]+$/i,"nb-NO":/^[0-9A-ZÆØÅ]+$/i,"nl-NL":/^[0-9A-ZÁÉËÏÓÖÜÚ]+$/i,"nn-NO":/^[0-9A-ZÆØÅ]+$/i,"pl-PL":/^[0-9A-ZĄĆĘŚŁŃÓŻŹ]+$/i,"pt-PT":/^[0-9A-ZÃÁÀÂÄÇÉÊËÍÏÕÓÔÖÚÜ]+$/i,"ru-RU":/^[0-9А-ЯЁ]+$/i,"sl-SI":/^[0-9A-ZČĆĐŠŽ]+$/i,"sk-SK":/^[0-9A-ZÁČĎÉÍŇÓŠŤÚÝŽĹŔĽÄÔ]+$/i,"sr-RS@latin":/^[0-9A-ZČĆŽŠĐ]+$/i,"sr-RS":/^[0-9А-ЯЂЈЉЊЋЏ]+$/i,"sv-SE":/^[0-9A-ZÅÄÖ]+$/i,"th-TH":/^[ก-๙\s]+$/i,"tr-TR":/^[0-9A-ZÇĞİıÖŞÜ]+$/i,"uk-UA":/^[0-9А-ЩЬЮЯЄIЇҐі]+$/i,"ko-KR":/^[0-9ㄱ-ㅎㅏ-ㅣ가-힣]*$/,"ku-IQ":/^[٠١٢٣٤٥٦٧٨٩0-9ئابپتجچحخدرڕزژسشعغفڤقکگلڵمنوۆھەیێيطؤثآإأكضصةظذ]+$/i,"vi-VN":/^[0-9A-ZÀÁẠẢÃÂẦẤẬẨẪĂẰẮẶẲẴĐÈÉẸẺẼÊỀẾỆỂỄÌÍỊỈĨÒÓỌỎÕÔỒỐỘỔỖƠỜỚỢỞỠÙÚỤỦŨƯỪỨỰỬỮỲÝỴỶỸ]+$/i,ar:/^[٠١٢٣٤٥٦٧٨٩0-9ءآأؤإئابةتثجحخدذرزسشصضطظعغفقكلمنهوىيًٌٍَُِّْٰ]+$/,he:/^[0-9א-ת]+$/,fa:/^['0-9آاءأؤئبپتثجچحخدذرزژسشصضطظعغفقکگلمنوهةی۱۲۳۴۵۶۷۸۹۰']+$/i,bn:/^['ঀঁংঃঅআইঈউঊঋঌএঐওঔকখগঘঙচছজঝঞটঠডঢণতথদধনপফবভমযরলশষসহ়ঽািীুূৃৄেৈোৌ্ৎৗড়ঢ়য়ৠৡৢৣ০১২৩৪৫৬৭৮৯ৰৱ৲৳৴৵৶৷৸৹৺৻']+$/,"hi-IN":/^[\u0900-\u0963]+[\u0966-\u097F]*$/i,"si-LK":/^[0-9\u0D80-\u0DFF]+$/},c={"en-US":".",ar:"٫"},e=["AU","GB","HK","IN","NZ","ZA","ZM"],f=0;f<e.length;f++)t="en-".concat(e[f]),a[t]=a["en-US"],s[t]=s["en-US"],c[t]=c["en-US"];for(var A,$=["AE","BH","DZ","EG","IQ","JO","KW","LB","LY","MA","QM","QA","SA","SD","SY","TN","YE"],p=0;p<$.length;p++)A="ar-".concat($[p]),a[A]=a.ar,s[A]=s.ar,c[A]=c.ar;for(var h,S=["IR","AF"],g=0;g<S.length;g++)h="fa-".concat(S[g]),s[h]=s.fa,c[h]=c.ar;for(var E,m=["BD","IN"],v=0;v<m.length;v++)E="bn-".concat(m[v]),a[E]=a.bn,s[E]=s.bn,c[E]=c["en-US"];for(var I=["ar-EG","ar-LB","ar-LY"],R=["bg-BG","cs-CZ","da-DK","de-DE","el-GR","en-ZM","es-ES","fr-CA","fr-FR","id-ID","it-IT","ku-IQ","hi-IN","hu-HU","nb-NO","nn-NO","nl-NL","pl-PL","pt-PT","ru-RU","si-LK","sl-SI","sr-RS@latin","sr-RS","sv-SE","tr-TR","uk-UA","vi-VN"],Z=0;Z<I.length;Z++)c[I[Z]]=c["en-US"];for(var L=0;L<R.length;L++)c[R[L]]=",";function M(t,e){u(t),e=e||{};var r=new RegExp("^(?:[-+])?(?:[0-9]+)?(?:\\".concat(e.locale?c[e.locale]:".","[0-9]*)?(?:[eE][\\+\\-]?(?:[0-9]+))?$"));if(""===t||"."===t||","===t||"-"===t||"+"===t)return!1;var n=parseFloat(t.replace(",","."));return r.test(t)&&(!e.hasOwnProperty("min")||n>=e.min)&&(!e.hasOwnProperty("max")||n<=e.max)&&(!e.hasOwnProperty("lt")||n<e.lt)&&(!e.hasOwnProperty("gt")||n>e.gt)}a["fr-CA"]=a["fr-FR"],s["fr-CA"]=s["fr-FR"],a["pt-BR"]=a["pt-PT"],s["pt-BR"]=s["pt-PT"],c["pt-BR"]=c["pt-PT"],a["pl-Pl"]=a["pl-PL"],s["pl-Pl"]=s["pl-PL"],c["pl-Pl"]=c["pl-PL"],a["fa-AF"]=a.fa;var B=Object.keys(c);function N(t){return M(t)?parseFloat(t):NaN}function C(t){return"object"===o(t)&&null!==t?t="function"==typeof t.toString?t.toString():"[object Object]":(null==t||isNaN(t)&&!t.length)&&(t=""),String(t)}function F(t,e){var r,n=0<arguments.length&&void 0!==t?t:{},i=1<arguments.length?e:void 0;for(r in i)void 0===n[r]&&(n[r]=i[r]);return n}var D={ignoreCase:!1,minOccurrences:1};function T(t,e){var r;u(t);e="object"===o(e)?(r=e.min||0,e.max):(r=e,arguments[2]),t=encodeURI(t).split(/%..|./).length-1;return r<=t&&(void 0===e||t<=e)}var G={require_tld:!0,allow_underscores:!1,allow_trailing_dot:!1,allow_numeric_tld:!1,allow_wildcard:!1,ignore_max_length:!1};function O(t,e){u(t),(e=F(e,G)).allow_trailing_dot&&"."===t[t.length-1]&&(t=t.substring(0,t.length-1));var r=(t=!0===e.allow_wildcard&&0===t.indexOf("*.")?t.substring(2):t).split("."),t=r[r.length-1];if(e.require_tld){if(r.length<2)return!1;if(!e.allow_numeric_tld&&!/^([a-z\u00A1-\u00A8\u00AA-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]{2,}|xn[a-z0-9-]{2,})$/i.test(t))return!1;if(/\s/.test(t))return!1}return!(!e.allow_numeric_tld&&/^\d+$/.test(t))&&r.every(function(t){return!(63<t.length&&!e.ignore_max_length)&&(!!/^[a-z_\u00a1-\uffff0-9-]+$/i.test(t)&&(!/[\uff01-\uff5e]/.test(t)&&(!/^-|-$/.test(t)&&!(!e.allow_underscores&&/_/.test(t)))))})}var P="(?:[0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])",H="(".concat(P,"[.]){3}").concat(P),_=new RegExp("^".concat(H,"$")),U="(?:[0-9a-fA-F]{1,4})",b=new RegExp("^("+"(?:".concat(U,":){7}(?:").concat(U,"|:)|")+"(?:".concat(U,":){6}(?:").concat(H,"|:").concat(U,"|:)|")+"(?:".concat(U,":){5}(?::").concat(H,"|(:").concat(U,"){1,2}|:)|")+"(?:".concat(U,":){4}(?:(:").concat(U,"){0,1}:").concat(H,"|(:").concat(U,"){1,3}|:)|")+"(?:".concat(U,":){3}(?:(:").concat(U,"){0,2}:").concat(H,"|(:").concat(U,"){1,4}|:)|")+"(?:".concat(U,":){2}(?:(:").concat(U,"){0,3}:").concat(H,"|(:").concat(U,"){1,5}|:)|")+"(?:".concat(U,":){1}(?:(:").concat(U,"){0,4}:").concat(H,"|(:").concat(U,"){1,6}|:)|")+"(?::((?::".concat(U,"){0,5}:").concat(H,"|(?::").concat(U,"){1,7}|:))")+")(%[0-9a-zA-Z-.:]{1,})?$");function K(t){var e=1<arguments.length&&void 0!==arguments[1]?arguments[1]:"";return u(t),(e=String(e))?"4"===e?_.test(t):"6"===e&&b.test(t):K(t,4)||K(t,6)}var w={allow_display_name:!1,require_display_name:!1,allow_utf8_local_part:!0,require_tld:!0,blacklisted_chars:"",ignore_max_length:!1,host_blacklist:[],host_whitelist:[]},y=/^([^\x00-\x1F\x7F-\x9F\cX]+)</i,W=/^[a-z\d!#\$%&'\*\+\-\/=\?\^_`{\|}~]+$/i,Y=/^[a-z\d]+$/,x=/^([\s\x01-\x08\x0b\x0c\x0e-\x1f\x7f\x21\x23-\x5b\x5d-\x7e]|(\\[\x01-\x09\x0b\x0c\x0d-\x7f]))*$/i,k=/^[a-z\d!#\$%&'\*\+\-\/=\?\^_`{\|}~\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]+$/i,V=/^([\s\x01-\x08\x0b\x0c\x0e-\x1f\x7f\x21\x23-\x5b\x5d-\x7e\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]|(\\[\x01-\x09\x0b\x0c\x0d-\x7f\u00A0-\uD7FF\uF900-\uFDCF\uFDF0-\uFFEF]))*$/i;var z={protocols:["http","https","ftp"],require_tld:!0,require_protocol:!1,require_host:!0,require_port:!1,require_valid_protocol:!0,allow_underscores:!1,allow_trailing_dot:!1,allow_protocol_relative_urls:!1,allow_fragments:!0,allow_query_components:!0,validate_length:!0},X=/^\[([^\]]+)\](?::([0-9]+))?$/;function J(t,e){for(var r,n=0;n<e.length;n++){var i=e[n];if(t===i||(r=i,"[object RegExp]"===Object.prototype.toString.call(r)&&i.test(t)))return!0}return!1}var j=/^(?:[0-9a-fA-F]{2}([-:\s]))([0-9a-fA-F]{2}\1){4}([0-9a-fA-F]{2})$/,q=/^([0-9a-fA-F]){12}$/,Q=/^([0-9a-fA-F]{4}\.){2}([0-9a-fA-F]{4})$/,tt=/^(?:[0-9a-fA-F]{2}([-:\s]))([0-9a-fA-F]{2}\1){6}([0-9a-fA-F]{2})$/,et=/^([0-9a-fA-F]){16}$/,rt=/^([0-9a-fA-F]{4}\.){3}([0-9a-fA-F]{4})$/;var nt=/^\d{1,3}$/;var it={format:"YYYY/MM/DD",delimiters:["/","-"],strictMode:!1};function ot(e,r){if(r=F("string"==typeof r?{format:r}:r,it),"string"==typeof e&&/(^(y{4}|y{2})[.\/-](m{1,2})[.\/-](d{1,2})$)|(^(m{1,2})[.\/-](d{1,2})[.\/-]((y{4}|y{2})$))|(^(d{1,2})[.\/-](m{1,2})[.\/-]((y{4}|y{2})$))/gi.test(r.format)){var t,n=r.delimiters.find(function(t){return-1!==r.format.indexOf(t)}),i=r.strictMode?n:r.delimiters.find(function(t){return-1!==e.indexOf(t)}),o={},a=function(t,e){var r;if("undefined"==typeof Symbol||null==t[Symbol.iterator]){if(Array.isArray(t)||(r=d(t))||e&&t&&"number"==typeof t.length){r&&(t=r);var n=0,e=function(){};return{s:e,n:function(){return n>=t.length?{done:!0}:{done:!1,value:t[n++]}},e:function(t){throw t},f:e}}throw new TypeError("Invalid attempt to iterate non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method.")}var i,o=!0,a=!1;return{s:function(){r=t[Symbol.iterator]()},n:function(){var t=r.next();return o=t.done,t},e:function(t){a=!0,i=t},f:function(){try{o||null==r.return||r.return()}finally{if(a)throw i}}}}(function(t,e){for(var r=[],n=Math.min(t.length,e.length),i=0;i<n;i++)r.push([t[i],e[i]]);return r}(e.split(i),r.format.toLowerCase().split(n)));try{for(a.s();!(t=a.n()).done;){var s=l(t.value,2),c=s[0],u=s[1];if(c.length!==u.length)return!1;o[u.charAt(0)]=c}}catch(t){a.e(t)}finally{a.f()}return new Date("".concat(o.m,"/").concat(o.d,"/").concat(o.y)).getDate()===+o.d}return!r.strictMode&&("[object Date]"===Object.prototype.toString.call(e)&&isFinite(e))}var at={hourFormat:"hour24",mode:"default"},st={hour24:{default:/^([01]?[0-9]|2[0-3]):([0-5][0-9])$/,withSeconds:/^([01]?[0-9]|2[0-3]):([0-5][0-9]):([0-5][0-9])$/},hour12:{default:/^(0?[1-9]|1[0-2]):([0-5][0-9]) (A|P)M$/,withSeconds:/^(0?[1-9]|1[0-2]):([0-5][0-9]):([0-5][0-9]) (A|P)M$/}};var ct={loose:!1},ut=["true","false","1","0"],lt=[].concat(ut,["yes","no"]);var dt=/^[A-Za-z]{2,4}([_-]([A-Za-z]{4}|[\d]{3}))?([_-]([A-Za-z]{2}|[\d]{3}))?$/;var ft=Object.keys(a);var At=Object.keys(s),$t=/^[0-9]+$/;var pt={AM:/^[A-Z]{2}\d{7}$/,AR:/^[A-Z]{3}\d{6}$/,AT:/^[A-Z]\d{7}$/,AU:/^[A-Z]\d{7}$/,AZ:/^[A-Z]{2,3}\d{7,8}$/,BE:/^[A-Z]{2}\d{6}$/,BG:/^\d{9}$/,BR:/^[A-Z]{2}\d{6}$/,BY:/^[A-Z]{2}\d{7}$/,CA:/^[A-Z]{2}\d{6}$/,CH:/^[A-Z]\d{7}$/,CN:/^G\d{8}$|^E(?![IO])[A-Z0-9]\d{7}$/,CY:/^[A-Z](\d{6}|\d{8})$/,CZ:/^\d{8}$/,DE:/^[CFGHJKLMNPRTVWXYZ0-9]{9}$/,DK:/^\d{9}$/,DZ:/^\d{9}$/,EE:/^([A-Z]\d{7}|[A-Z]{2}\d{7})$/,ES:/^[A-Z0-9]{2}([A-Z0-9]?)\d{6}$/,FI:/^[A-Z]{2}\d{7}$/,FR:/^\d{2}[A-Z]{2}\d{5}$/,GB:/^\d{9}$/,GR:/^[A-Z]{2}\d{7}$/,HR:/^\d{9}$/,HU:/^[A-Z]{2}(\d{6}|\d{7})$/,IE:/^[A-Z0-9]{2}\d{7}$/,IN:/^[A-Z]{1}-?\d{7}$/,ID:/^[A-C]\d{7}$/,IR:/^[A-Z]\d{8}$/,IS:/^(A)\d{7}$/,IT:/^[A-Z0-9]{2}\d{7}$/,JM:/^[Aa]\d{7}$/,JP:/^[A-Z]{2}\d{7}$/,KR:/^[MS]\d{8}$/,KZ:/^[a-zA-Z]\d{7}$/,LI:/^[a-zA-Z]\d{5}$/,LT:/^[A-Z0-9]{8}$/,LU:/^[A-Z0-9]{8}$/,LV:/^[A-Z0-9]{2}\d{7}$/,LY:/^[A-Z0-9]{8}$/,MT:/^\d{7}$/,MZ:/^([A-Z]{2}\d{7})|(\d{2}[A-Z]{2}\d{5})$/,MY:/^[AHK]\d{8}$/,MX:/^\d{10,11}$/,NL:/^[A-Z]{2}[A-Z0-9]{6}\d$/,NZ:/^([Ll]([Aa]|[Dd]|[Ff]|[Hh])|[Ee]([Aa]|[Pp])|[Nn])\d{6}$/,PH:/^([A-Z](\d{6}|\d{7}[A-Z]))|([A-Z]{2}(\d{6}|\d{7}))$/,PK:/^[A-Z]{2}\d{7}$/,PL:/^[A-Z]{2}\d{7}$/,PT:/^[A-Z]\d{6}$/,RO:/^\d{8,9}$/,RU:/^\d{9}$/,SE:/^\d{8}$/,SL:/^(P)[A-Z]\d{7}$/,SK:/^[0-9A-Z]\d{7}$/,TH:/^[A-Z]{1,2}\d{6,7}$/,TR:/^[A-Z]\d{8}$/,UA:/^[A-Z]{2}\d{6}$/,US:/^\d{9}$/};var ht=/^(?:[-+]?(?:0|[1-9][0-9]*))$/,St=/^[-+]?[0-9]+$/;function gt(t,e){u(t);var r=(e=e||{}).hasOwnProperty("allow_leading_zeroes")&&!e.allow_leading_zeroes?ht:St,n=!e.hasOwnProperty("min")||t>=e.min,i=!e.hasOwnProperty("max")||t<=e.max,o=!e.hasOwnProperty("lt")||t<e.lt,e=!e.hasOwnProperty("gt")||t>e.gt;return r.test(t)&&n&&i&&o&&e}var Et=/^[0-9]{15}$/,mt=/^\d{2}-\d{6}-\d{6}-\d{1}$/;var vt=/^[\x00-\x7F]+$/;var It=/[^\u0020-\u007E\uFF61-\uFF9F\uFFA0-\uFFDC\uFFE8-\uFFEE0-9a-zA-Z]/;var Rt=/[\u0020-\u007E\uFF61-\uFF9F\uFFA0-\uFFDC\uFFE8-\uFFEE0-9a-zA-Z]/;var Zt=/[^\x00-\x7F]/;var Lt,Mt,Bt=(Mt="i",Lt=(Lt=["^(0|[1-9]\\d*)\\.(0|[1-9]\\d*)\\.(0|[1-9]\\d*)","(?:-((?:0|[1-9]\\d*|\\d*[a-z-][0-9a-z-]*)(?:\\.(?:0|[1-9]\\d*|\\d*[a-z-][0-9a-z-]*))*))","?(?:\\+([0-9a-z-]+(?:\\.[0-9a-z-]+)*))?$"]).join(""),new RegExp(Lt,Mt));var Nt=/[\uD800-\uDBFF][\uDC00-\uDFFF]/;var Ct={force_decimal:!1,decimal_digits:"1,",locale:"en-US"},Ft=["","-","+"];var Dt=/^(0x|0h)?[0-9A-F]+$/i;function Tt(t){return u(t),Dt.test(t)}var Gt=/^(0o)?[0-7]+$/i;var Ot=/^#?([0-9A-F]{3}|[0-9A-F]{4}|[0-9A-F]{6}|[0-9A-F]{8})$/i;var Pt=/^rgb\((([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5]),){2}([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5])\)$/,Ht=/^rgba\((([0-9]|[1-9][0-9]|1[0-9][0-9]|2[0-4][0-9]|25[0-5]),){3}(0?\.\d|1(\.0)?|0(\.0)?)\)$/,_t=/^rgb\((([0-9]%|[1-9][0-9]%|100%),){2}([0-9]%|[1-9][0-9]%|100%)\)$/,Ut=/^rgba\((([0-9]%|[1-9][0-9]%|100%),){3}(0?\.\d|1(\.0)?|0(\.0)?)\)$/;var bt=/^hsla?\(((\+|\-)?([0-9]+(\.[0-9]+)?(e(\+|\-)?[0-9]+)?|\.[0-9]+(e(\+|\-)?[0-9]+)?))(deg|grad|rad|turn)?(,(\+|\-)?([0-9]+(\.[0-9]+)?(e(\+|\-)?[0-9]+)?|\.[0-9]+(e(\+|\-)?[0-9]+)?)%){2}(,((\+|\-)?([0-9]+(\.[0-9]+)?(e(\+|\-)?[0-9]+)?|\.[0-9]+(e(\+|\-)?[0-9]+)?)%?))?\)$/i,Kt=/^hsla?\(((\+|\-)?([0-9]+(\.[0-9]+)?(e(\+|\-)?[0-9]+)?|\.[0-9]+(e(\+|\-)?[0-9]+)?))(deg|grad|rad|turn)?(\s(\+|\-)?([0-9]+(\.[0-9]+)?(e(\+|\-)?[0-9]+)?|\.[0-9]+(e(\+|\-)?[0-9]+)?)%){2}\s?(\/\s((\+|\-)?([0-9]+(\.[0-9]+)?(e(\+|\-)?[0-9]+)?|\.[0-9]+(e(\+|\-)?[0-9]+)?)%?)\s?)?\)$/i;var wt=/^[A-Z]{2}[0-9A-Z]{3}\d{2}\d{5}$/;var yt={AD:/^(AD[0-9]{2})\d{8}[A-Z0-9]{12}$/,AE:/^(AE[0-9]{2})\d{3}\d{16}$/,AL:/^(AL[0-9]{2})\d{8}[A-Z0-9]{16}$/,AT:/^(AT[0-9]{2})\d{16}$/,AZ:/^(AZ[0-9]{2})[A-Z0-9]{4}\d{20}$/,BA:/^(BA[0-9]{2})\d{16}$/,BE:/^(BE[0-9]{2})\d{12}$/,BG:/^(BG[0-9]{2})[A-Z]{4}\d{6}[A-Z0-9]{8}$/,BH:/^(BH[0-9]{2})[A-Z]{4}[A-Z0-9]{14}$/,BR:/^(BR[0-9]{2})\d{23}[A-Z]{1}[A-Z0-9]{1}$/,BY:/^(BY[0-9]{2})[A-Z0-9]{4}\d{20}$/,CH:/^(CH[0-9]{2})\d{5}[A-Z0-9]{12}$/,CR:/^(CR[0-9]{2})\d{18}$/,CY:/^(CY[0-9]{2})\d{8}[A-Z0-9]{16}$/,CZ:/^(CZ[0-9]{2})\d{20}$/,DE:/^(DE[0-9]{2})\d{18}$/,DK:/^(DK[0-9]{2})\d{14}$/,DO:/^(DO[0-9]{2})[A-Z]{4}\d{20}$/,EE:/^(EE[0-9]{2})\d{16}$/,EG:/^(EG[0-9]{2})\d{25}$/,ES:/^(ES[0-9]{2})\d{20}$/,FI:/^(FI[0-9]{2})\d{14}$/,FO:/^(FO[0-9]{2})\d{14}$/,FR:/^(FR[0-9]{2})\d{10}[A-Z0-9]{11}\d{2}$/,GB:/^(GB[0-9]{2})[A-Z]{4}\d{14}$/,GE:/^(GE[0-9]{2})[A-Z0-9]{2}\d{16}$/,GI:/^(GI[0-9]{2})[A-Z]{4}[A-Z0-9]{15}$/,GL:/^(GL[0-9]{2})\d{14}$/,GR:/^(GR[0-9]{2})\d{7}[A-Z0-9]{16}$/,GT:/^(GT[0-9]{2})[A-Z0-9]{4}[A-Z0-9]{20}$/,HR:/^(HR[0-9]{2})\d{17}$/,HU:/^(HU[0-9]{2})\d{24}$/,IE:/^(IE[0-9]{2})[A-Z0-9]{4}\d{14}$/,IL:/^(IL[0-9]{2})\d{19}$/,IQ:/^(IQ[0-9]{2})[A-Z]{4}\d{15}$/,IR:/^(IR[0-9]{2})0\d{2}0\d{18}$/,IS:/^(IS[0-9]{2})\d{22}$/,IT:/^(IT[0-9]{2})[A-Z]{1}\d{10}[A-Z0-9]{12}$/,JO:/^(JO[0-9]{2})[A-Z]{4}\d{22}$/,KW:/^(KW[0-9]{2})[A-Z]{4}[A-Z0-9]{22}$/,KZ:/^(KZ[0-9]{2})\d{3}[A-Z0-9]{13}$/,LB:/^(LB[0-9]{2})\d{4}[A-Z0-9]{20}$/,LC:/^(LC[0-9]{2})[A-Z]{4}[A-Z0-9]{24}$/,LI:/^(LI[0-9]{2})\d{5}[A-Z0-9]{12}$/,LT:/^(LT[0-9]{2})\d{16}$/,LU:/^(LU[0-9]{2})\d{3}[A-Z0-9]{13}$/,LV:/^(LV[0-9]{2})[A-Z]{4}[A-Z0-9]{13}$/,MC:/^(MC[0-9]{2})\d{10}[A-Z0-9]{11}\d{2}$/,MD:/^(MD[0-9]{2})[A-Z0-9]{20}$/,ME:/^(ME[0-9]{2})\d{18}$/,MK:/^(MK[0-9]{2})\d{3}[A-Z0-9]{10}\d{2}$/,MR:/^(MR[0-9]{2})\d{23}$/,MT:/^(MT[0-9]{2})[A-Z]{4}\d{5}[A-Z0-9]{18}$/,MU:/^(MU[0-9]{2})[A-Z]{4}\d{19}[A-Z]{3}$/,MZ:/^(MZ[0-9]{2})\d{21}$/,NL:/^(NL[0-9]{2})[A-Z]{4}\d{10}$/,NO:/^(NO[0-9]{2})\d{11}$/,PK:/^(PK[0-9]{2})[A-Z0-9]{4}\d{16}$/,PL:/^(PL[0-9]{2})\d{24}$/,PS:/^(PS[0-9]{2})[A-Z0-9]{4}\d{21}$/,PT:/^(PT[0-9]{2})\d{21}$/,QA:/^(QA[0-9]{2})[A-Z]{4}[A-Z0-9]{21}$/,RO:/^(RO[0-9]{2})[A-Z]{4}[A-Z0-9]{16}$/,RS:/^(RS[0-9]{2})\d{18}$/,SA:/^(SA[0-9]{2})\d{2}[A-Z0-9]{18}$/,SC:/^(SC[0-9]{2})[A-Z]{4}\d{20}[A-Z]{3}$/,SE:/^(SE[0-9]{2})\d{20}$/,SI:/^(SI[0-9]{2})\d{15}$/,SK:/^(SK[0-9]{2})\d{20}$/,SM:/^(SM[0-9]{2})[A-Z]{1}\d{10}[A-Z0-9]{12}$/,SV:/^(SV[0-9]{2})[A-Z0-9]{4}\d{20}$/,TL:/^(TL[0-9]{2})\d{19}$/,TN:/^(TN[0-9]{2})\d{20}$/,TR:/^(TR[0-9]{2})\d{5}[A-Z0-9]{17}$/,UA:/^(UA[0-9]{2})\d{6}[A-Z0-9]{19}$/,VA:/^(VA[0-9]{2})\d{18}$/,VG:/^(VG[0-9]{2})[A-Z0-9]{4}\d{16}$/,XK:/^(XK[0-9]{2})\d{16}$/};var Wt=Object.keys(yt),Yt=new Set(["AD","AE","AF","AG","AI","AL","AM","AO","AQ","AR","AS","AT","AU","AW","AX","AZ","BA","BB","BD","BE","BF","BG","BH","BI","BJ","BL","BM","BN","BO","BQ","BR","BS","BT","BV","BW","BY","BZ","CA","CC","CD","CF","CG","CH","CI","CK","CL","CM","CN","CO","CR","CU","CV","CW","CX","CY","CZ","DE","DJ","DK","DM","DO","DZ","EC","EE","EG","EH","ER","ES","ET","FI","FJ","FK","FM","FO","FR","GA","GB","GD","GE","GF","GG","GH","GI","GL","GM","GN","GP","GQ","GR","GS","GT","GU","GW","GY","HK","HM","HN","HR","HT","HU","ID","IE","IL","IM","IN","IO","IQ","IR","IS","IT","JE","JM","JO","JP","KE","KG","KH","KI","KM","KN","KP","KR","KW","KY","KZ","LA","LB","LC","LI","LK","LR","LS","LT","LU","LV","LY","MA","MC","MD","ME","MF","MG","MH","MK","ML","MM","MN","MO","MP","MQ","MR","MS","MT","MU","MV","MW","MX","MY","MZ","NA","NC","NE","NF","NG","NI","NL","NO","NP","NR","NU","NZ","OM","PA","PE","PF","PG","PH","PK","PL","PM","PN","PR","PS","PT","PW","PY","QA","RE","RO","RS","RU","RW","SA","SB","SC","SD","SE","SG","SH","SI","SJ","SK","SL","SM","SN","SO","SR","SS","ST","SV","SX","SY","SZ","TC","TD","TF","TG","TH","TJ","TK","TL","TM","TN","TO","TR","TT","TV","TW","TZ","UA","UG","UM","US","UY","UZ","VA","VC","VE","VG","VI","VN","VU","WF","WS","YE","YT","ZA","ZM","ZW"]);var xt=Yt,kt=/^[A-Za-z]{6}[A-Za-z0-9]{2}([A-Za-z0-9]{3})?$/;var Vt=/^[a-f0-9]{32}$/;var zt={md5:32,md4:32,sha1:40,sha256:64,sha384:96,sha512:128,ripemd128:32,ripemd160:40,tiger128:32,tiger160:40,tiger192:48,crc32:8,crc32b:8};var Xt=/[^A-Z0-9+\/=]/i,Jt=/^[A-Z0-9_\-]*$/i,jt={urlSafe:!1};function qt(t,e){u(t),e=F(e,jt);var r=t.length;if(e.urlSafe)return Jt.test(t);if(r%4!=0||Xt.test(t))return!1;e=t.indexOf("=");return-1===e||e===r-1||e===r-2&&"="===t[r-1]}var Qt={allow_primitives:!1};var te={ignore_whitespace:!1};var ee={1:/^[0-9A-F]{8}-[0-9A-F]{4}-1[0-9A-F]{3}-[0-9A-F]{4}-[0-9A-F]{12}$/i,2:/^[0-9A-F]{8}-[0-9A-F]{4}-2[0-9A-F]{3}-[0-9A-F]{4}-[0-9A-F]{12}$/i,3:/^[0-9A-F]{8}-[0-9A-F]{4}-3[0-9A-F]{3}-[0-9A-F]{4}-[0-9A-F]{12}$/i,4:/^[0-9A-F]{8}-[0-9A-F]{4}-4[0-9A-F]{3}-[89AB][0-9A-F]{3}-[0-9A-F]{12}$/i,5:/^[0-9A-F]{8}-[0-9A-F]{4}-5[0-9A-F]{3}-[89AB][0-9A-F]{3}-[0-9A-F]{12}$/i,all:/^[0-9A-F]{8}-[0-9A-F]{4}-[0-9A-F]{4}-[0-9A-F]{4}-[0-9A-F]{12}$/i};function re(t){u(t);for(var e,r,n=t.replace(/[- ]+/g,""),i=0,o=n.length-1;0<=o;o--)e=n.substring(o,o+1),e=parseInt(e,10),i+=r&&10<=(e*=2)?e%10+1:e,r=!r;return!(i%10!=0||!n)}var ne={amex:/^3[47][0-9]{13}$/,dinersclub:/^3(?:0[0-5]|[68][0-9])[0-9]{11}$/,discover:/^6(?:011|5[0-9][0-9])[0-9]{12,15}$/,jcb:/^(?:2131|1800|35\d{3})\d{11}$/,mastercard:/^5[1-5][0-9]{2}|(222[1-9]|22[3-9][0-9]|2[3-6][0-9]{2}|27[01][0-9]|2720)[0-9]{12}$/,unionpay:/^(6[27][0-9]{14}|^(81[0-9]{14,17}))$/,visa:/^(?:4[0-9]{12})(?:[0-9]{3,6})?$/},ie=/^(?:4[0-9]{12}(?:[0-9]{3,6})?|5[1-5][0-9]{14}|(222[1-9]|22[3-9][0-9]|2[3-6][0-9]{2}|27[01][0-9]|2720)[0-9]{12}|6(?:011|5[0-9][0-9])[0-9]{12,15}|3[47][0-9]{13}|3(?:0[0-5]|[68][0-9])[0-9]{11}|(?:2131|1800|35\d{3})\d{11}|6[27][0-9]{14}|^(81[0-9]{14,17}))$/;var oe={PL:function(t){u(t);var n={1:1,2:3,3:7,4:9,5:1,6:3,7:7,8:9,9:1,10:3,11:0};if(null!=t&&11===t.length&&gt(t,{allow_leading_zeroes:!0})){var e=t.split("").slice(0,-1).reduce(function(t,e,r){return t+Number(e)*n[r+1]},0)%10,t=Number(t.charAt(t.length-1));if(0==e&&0===t||t===10-e)return!0}return!1},ES:function(t){u(t);var e={X:0,Y:1,Z:2},r=t.trim().toUpperCase();if(!/^[0-9X-Z][0-9]{7}[TRWAGMYFPDXBNJZSQVHLCKE]$/.test(r))return!1;t=r.slice(0,-1).replace(/[X,Y,Z]/g,function(t){return e[t]});return r.endsWith(["T","R","W","A","G","M","Y","F","P","D","X","B","N","J","Z","S","Q","V","H","L","C","K","E"][t%23])},FI:function(t){if(u(t),11!==t.length)return!1;if(!t.match(/^\d{6}[\-A\+]\d{3}[0-9ABCDEFHJKLMNPRSTUVWXY]{1}$/))return!1;return"0123456789ABCDEFHJKLMNPRSTUVWXY"[(1e3*parseInt(t.slice(0,6),10)+parseInt(t.slice(7,10),10))%31]===t.slice(10,11)},IN:function(t){var r=[[0,1,2,3,4,5,6,7,8,9],[1,2,3,4,0,6,7,8,9,5],[2,3,4,0,1,7,8,9,5,6],[3,4,0,1,2,8,9,5,6,7],[4,0,1,2,3,9,5,6,7,8],[5,9,8,7,6,0,4,3,2,1],[6,5,9,8,7,1,0,4,3,2],[7,6,5,9,8,2,1,0,4,3],[8,7,6,5,9,3,2,1,0,4],[9,8,7,6,5,4,3,2,1,0]],n=[[0,1,2,3,4,5,6,7,8,9],[1,5,7,6,2,8,3,0,9,4],[5,8,0,3,7,9,6,1,4,2],[8,9,1,6,0,4,3,5,2,7],[9,4,5,3,1,2,6,8,7,0],[4,2,8,6,5,7,3,9,0,1],[2,7,9,3,8,0,6,4,1,5],[7,0,4,6,9,1,3,2,5,8]],t=t.trim();if(!/^[1-9]\d{3}\s?\d{4}\s?\d{4}$/.test(t))return!1;var i=0;return t.replace(/\s/g,"").split("").map(Number).reverse().forEach(function(t,e){i=r[i][n[e%8][t]]}),0===i},IR:function(t){if(!t.match(/^\d{10}$/))return!1;if(t="0000".concat(t).slice(t.length-6),0===parseInt(t.slice(3,9),10))return!1;for(var e=parseInt(t.slice(9,10),10),r=0,n=0;n<9;n++)r+=parseInt(t.slice(n,n+1),10)*(10-n);return(r%=11)<2&&e===r||2<=r&&e===11-r},IT:function(t){return 9===t.length&&("CA00000AA"!==t&&-1<t.search(/C[A-Z][0-9]{5}[A-Z]{2}/i))},NO:function(t){var e=t.trim();if(isNaN(Number(e)))return!1;if(11!==e.length)return!1;if("00000000000"===e)return!1;var r=e.split("").map(Number),t=(11-(3*r[0]+7*r[1]+6*r[2]+ +r[3]+8*r[4]+9*r[5]+4*r[6]+5*r[7]+2*r[8])%11)%11,e=(11-(5*r[0]+4*r[1]+3*r[2]+2*r[3]+7*r[4]+6*r[5]+5*r[6]+4*r[7]+3*r[8]+2*t)%11)%11;return t===r[9]&&e===r[10]},TH:function(t){if(!t.match(/^[1-8]\d{12}$/))return!1;for(var e=0,r=0;r<12;r++)e+=parseInt(t[r],10)*(13-r);return t[12]===((11-e%11)%10).toString()},LK:function(t){return!(10!==t.length||!/^[1-9]\d{8}[vx]$/i.test(t))||!(12!==t.length||!/^[1-9]\d{11}$/i.test(t))},"he-IL":function(t){t=t.trim();if(!/^\d{9}$/.test(t))return!1;for(var e,r=t,n=0,i=0;i<r.length;i++)n+=9<(e=Number(r[i])*(i%2+1))?e-9:e;return n%10==0},"ar-LY":function(t){t=t.trim();return!!/^(1|2)\d{11}$/.test(t)},"ar-TN":function(t){t=t.trim();return!!/^\d{8}$/.test(t)},"zh-CN":function(t){function n(t){return r.includes(t)}function i(t){var e=parseInt(t.substring(0,4),10),r=parseInt(t.substring(4,6),10),n=parseInt(t.substring(6),10);return!((t=new Date(e,r-1,n))>new Date)&&(t.getFullYear()===e&&t.getMonth()===r-1&&t.getDate()===n)}function o(t){return function(t){for(var e=t.substring(0,17),r=0,n=0;n<17;n++)r+=parseInt(e.charAt(n),10)*parseInt(a[n],10);return s[r%11]}(t)===t.charAt(17).toUpperCase()}var e,r=["11","12","13","14","15","21","22","23","31","32","33","34","35","36","37","41","42","43","44","45","46","50","51","52","53","54","61","62","63","64","65","71","81","82","91"],a=["7","9","10","5","8","4","2","1","6","3","7","9","10","5","8","4","2"],s=["1","0","X","9","8","7","6","5","4","3","2"];return!!/^\d{15}|(\d{17}(\d|x|X))$/.test(e=t)&&(15===e.length?function(t){var e=/^[1-9]\d{7}((0[1-9])|(1[0-2]))((0[1-9])|([1-2][0-9])|(3[0-1]))\d{3}$/.test(t);if(!e)return!1;var r=t.substring(0,2);if(!(e=n(r)))return!1;t="19".concat(t.substring(6,12));return!!(e=i(t))}:function(t){var e=/^[1-9]\d{5}[1-9]\d{3}((0[1-9])|(1[0-2]))((0[1-9])|([1-2][0-9])|(3[0-1]))\d{3}(\d|x|X)$/.test(t);if(!e)return!1;var r=t.substring(0,2);if(!(e=n(r)))return!1;r=t.substring(6,14);return!!(e=i(r))&&o(t)})(e)},"zh-HK":function(t){var e=/^[0-9]$/;if(t=(t=t.trim()).toUpperCase(),!/^[A-Z]{1,2}[0-9]{6}((\([0-9A]\))|(\[[0-9A]\])|([0-9A]))$/.test(t))return!1;8===(t=t.replace(/\[|\]|\(|\)/g,"")).length&&(t="3".concat(t));for(var r=0,n=0;n<=7;n++)r+=(e.test(t[n])?t[n]:(t[n].charCodeAt(0)-55)%11)*(9-n);return(0===(r%=11)?"0":1===r?"A":String(11-r))===t[t.length-1]},"zh-TW":function(t){var n={A:10,B:11,C:12,D:13,E:14,F:15,G:16,H:17,I:34,J:18,K:19,L:20,M:21,N:22,O:35,P:23,Q:24,R:25,S:26,T:27,U:28,V:29,W:32,X:30,Y:31,Z:33},t=t.trim().toUpperCase();return!!/^[A-Z][0-9]{9}$/.test(t)&&Array.from(t).reduce(function(t,e,r){if(0!==r)return 9===r?(10-t%10-Number(e))%10==0:t+Number(e)*(9-r);e=n[e];return e%10*9+Math.floor(e/10)},0)}};var ae=8,se=14,ce=/^(\d{8}|\d{13}|\d{14})$/;function ue(r){var t=10-r.slice(0,-1).split("").map(function(t,e){return Number(t)*(t=r.length,e=e,t===ae||t===se?e%2==0?3:1:e%2==0?1:3)}).reduce(function(t,e){return t+e},0)%10;return t<10?t:0}var le=/^[A-Z]{2}[0-9A-Z]{9}[0-9]$/;var de=/^(?:[0-9]{9}X|[0-9]{10})$/,fe=/^(?:[0-9]{13})$/,Ae=[1,3];function $e(t){for(var e=10,r=0;r<t.length-1;r++)e=(parseInt(t[r],10)+e)%10==0?9:(parseInt(t[r],10)+e)%10*2%11;return(e=1===e?0:11-e)===parseInt(t[10],10)}function pe(t){for(var e,r=0,n=!1,i=t.length-1;0<=i;i--)r+=n?9<(e=2*parseInt(t[i],10))?e.toString().split("").map(function(t){return parseInt(t,10)}).reduce(function(t,e){return t+e},0):e:parseInt(t[i],10),n=!n;return r%10==0}function he(t,e){for(var r=0,n=0;n<t.length;n++)r+=t[n]*(e-n);return r}var Se={andover:["10","12"],atlanta:["60","67"],austin:["50","53"],brookhaven:["01","02","03","04","05","06","11","13","14","16","21","22","23","25","34","51","52","54","55","56","57","58","59","65"],cincinnati:["30","32","35","36","37","38","61"],fresno:["15","24"],internet:["20","26","27","45","46","47"],kansas:["40","44"],memphis:["94","95"],ogden:["80","90"],philadelphia:["33","39","41","42","43","46","48","62","63","64","66","68","71","72","73","74","75","76","77","81","82","83","84","85","86","87","88","91","92","93","98","99"],sba:["31"]};function ge(t){for(var e=!1,r=!1,n=0;n<3;n++)if(!e&&/[AEIOU]/.test(t[n]))e=!0;else if(!r&&e&&"X"===t[n])r=!0;else if(0<n){if(e&&!r&&!/[AEIOU]/.test(t[n]))return;if(r&&!/X/.test(t[n]))return}return 1}var Ee={"bg-BG":/^\d{10}$/,"cs-CZ":/^\d{6}\/{0,1}\d{3,4}$/,"de-AT":/^\d{9}$/,"de-DE":/^[1-9]\d{10}$/,"dk-DK":/^\d{6}-{0,1}\d{4}$/,"el-CY":/^[09]\d{7}[A-Z]$/,"el-GR":/^([0-4]|[7-9])\d{8}$/,"en-CA":/^\d{9}$/,"en-GB":/^\d{10}$|^(?!GB|NK|TN|ZZ)(?![DFIQUV])[A-Z](?![DFIQUVO])[A-Z]\d{6}[ABCD ]$/i,"en-IE":/^\d{7}[A-W][A-IW]{0,1}$/i,"en-US":/^\d{2}[- ]{0,1}\d{7}$/,"es-ES":/^(\d{0,8}|[XYZKLM]\d{7})[A-HJ-NP-TV-Z]$/i,"et-EE":/^[1-6]\d{6}(00[1-9]|0[1-9][0-9]|[1-6][0-9]{2}|70[0-9]|710)\d$/,"fi-FI":/^\d{6}[-+A]\d{3}[0-9A-FHJ-NPR-Y]$/i,"fr-BE":/^\d{11}$/,"fr-FR":/^[0-3]\d{12}$|^[0-3]\d\s\d{2}(\s\d{3}){3}$/,"fr-LU":/^\d{13}$/,"hr-HR":/^\d{11}$/,"hu-HU":/^8\d{9}$/,"it-IT":/^[A-Z]{6}[L-NP-V0-9]{2}[A-EHLMPRST][L-NP-V0-9]{2}[A-ILMZ][L-NP-V0-9]{3}[A-Z]$/i,"lv-LV":/^\d{6}-{0,1}\d{5}$/,"mt-MT":/^\d{3,7}[APMGLHBZ]$|^([1-8])\1\d{7}$/i,"nl-NL":/^\d{9}$/,"pl-PL":/^\d{10,11}$/,"pt-BR":/(?:^\d{11}$)|(?:^\d{14}$)/,"pt-PT":/^\d{9}$/,"ro-RO":/^\d{13}$/,"sk-SK":/^\d{6}\/{0,1}\d{3,4}$/,"sl-SI":/^[1-9]\d{7}$/,"sv-SE":/^(\d{6}[-+]{0,1}\d{4}|(18|19|20)\d{6}[-+]{0,1}\d{4})$/};Ee["lb-LU"]=Ee["fr-LU"],Ee["lt-LT"]=Ee["et-EE"],Ee["nl-BE"]=Ee["fr-BE"],Ee["fr-CA"]=Ee["en-CA"];var me={"bg-BG":function(t){var e=t.slice(0,2),r=parseInt(t.slice(2,4),10),e=40<r?(r-=40,"20".concat(e)):20<r?(r-=20,"18".concat(e)):"19".concat(e);if(r<10&&(r="0".concat(r)),!ot("".concat(e,"/").concat(r,"/").concat(t.slice(4,6)),"YYYY/MM/DD"))return!1;for(var n=t.split("").map(function(t){return parseInt(t,10)}),i=[2,4,8,5,10,9,7,3,6],o=0,a=0;a<i.length;a++)o+=n[a]*i[a];return(o=o%11==10?0:o%11)===n[9]},"cs-CZ":function(t){t=t.replace(/\W/,"");var e=parseInt(t.slice(0,2),10);if(10===t.length)e=(e<54?"20":"19").concat(e);else{if("000"===t.slice(6))return!1;if(!(e<54))return!1;e="19".concat(e)}3===e.length&&(e=[e.slice(0,2),"0",e.slice(2)].join(""));var r=parseInt(t.slice(2,4),10);if(50<r&&(r-=50),20<r){if(parseInt(e,10)<2004)return!1;r-=20}if(r<10&&(r="0".concat(r)),!ot("".concat(e,"/").concat(r,"/").concat(t.slice(4,6)),"YYYY/MM/DD"))return!1;if(10===t.length&&parseInt(t,10)%11!=0){r=parseInt(t.slice(0,9),10)%11;if(!(parseInt(e,10)<1986&&10==r))return!1;if(0!==parseInt(t.slice(9),10))return!1}return!0},"de-AT":pe,"de-DE":function(t){for(var e=t.split("").map(function(t){return parseInt(t,10)}),r=[],n=0;n<e.length-1;n++){r.push("");for(var i=0;i<e.length-1;i++)e[n]===e[i]&&(r[n]+=i)}if(2!==(r=r.filter(function(t){return 1<t.length})).length&&3!==r.length)return!1;if(3===r[0].length){for(var o=r[0].split("").map(function(t){return parseInt(t,10)}),a=0,s=0;s<o.length-1;s++)o[s]+1===o[s+1]&&(a+=1);if(2===a)return!1}return $e(t)},"dk-DK":function(t){t=t.replace(/\W/,"");var e=parseInt(t.slice(4,6),10);switch(t.slice(6,7)){case"0":case"1":case"2":case"3":e="19".concat(e);break;case"4":case"9":e=(e<37?"20":"19").concat(e);break;default:if(e<37)e="20".concat(e);else{if(!(58<e))return!1;e="18".concat(e)}}if(3===e.length&&(e=[e.slice(0,2),"0",e.slice(2)].join("")),!ot("".concat(e,"/").concat(t.slice(2,4),"/").concat(t.slice(0,2)),"YYYY/MM/DD"))return!1;for(var r=t.split("").map(function(t){return parseInt(t,10)}),n=0,i=4,o=0;o<9;o++)n+=r[o]*i,1===--i&&(i=7);return 1!=(n%=11)&&(0===n?0===r[9]:r[9]===11-n)},"el-CY":function(t){for(var e=t.slice(0,8).split("").map(function(t){return parseInt(t,10)}),r=0,n=1;n<e.length;n+=2)r+=e[n];for(var i=0;i<e.length;i+=2)e[i]<2?r+=1-e[i]:(r+=2*(e[i]-2)+5,4<e[i]&&(r+=2));return String.fromCharCode(r%26+65)===t.charAt(8)},"el-GR":function(t){for(var e=t.split("").map(function(t){return parseInt(t,10)}),r=0,n=0;n<8;n++)r+=e[n]*Math.pow(2,8-n);return r%11%10===e[8]},"en-CA":function(t){var e=t.split(""),t=e.filter(function(t,e){return e%2}).map(function(t){return 2*Number(t)}).join("").split("");return e.filter(function(t,e){return!(e%2)}).concat(t).map(function(t){return Number(t)}).reduce(function(t,e){return t+e})%10==0},"en-IE":function(t){var e=he(t.split("").slice(0,7).map(function(t){return parseInt(t,10)}),8);return 9===t.length&&"W"!==t[8]&&(e+=9*(t[8].charCodeAt(0)-64)),0===(e%=23)?"W"===t[7].toUpperCase():t[7].toUpperCase()===String.fromCharCode(64+e)},"en-US":function(t){return-1!==function(){var t,e=[];for(t in Se)Se.hasOwnProperty(t)&&e.push.apply(e,r(Se[t]));return e}().indexOf(t.slice(0,2))},"es-ES":function(t){var e=t.toUpperCase().split("");if(isNaN(parseInt(e[0],10))&&1<e.length){var r=0;switch(e[0]){case"Y":r=1;break;case"Z":r=2}e.splice(0,1,r)}else for(;e.length<9;)e.unshift(0);return e=e.join(""),t=parseInt(e.slice(0,8),10)%23,e[8]===["T","R","W","A","G","M","Y","F","P","D","X","B","N","J","Z","S","Q","V","H","L","C","K","E"][t]},"et-EE":function(t){var e=t.slice(1,3);switch(t.slice(0,1)){case"1":case"2":e="18".concat(e);break;case"3":case"4":e="19".concat(e);break;default:e="20".concat(e)}if(!ot("".concat(e,"/").concat(t.slice(3,5),"/").concat(t.slice(5,7)),"YYYY/MM/DD"))return!1;for(var r=t.split("").map(function(t){return parseInt(t,10)}),n=0,i=1,o=0;o<10;o++)n+=r[o]*i,10===(i+=1)&&(i=1);if(n%11==10){for(var n=0,i=3,a=0;a<10;a++)n+=r[a]*i,10===(i+=1)&&(i=1);if(n%11==10)return 0===r[10]}return n%11===r[10]},"fi-FI":function(t){var e=t.slice(4,6);switch(t.slice(6,7)){case"+":e="18".concat(e);break;case"-":e="19".concat(e);break;default:e="20".concat(e)}if(!ot("".concat(e,"/").concat(t.slice(2,4),"/").concat(t.slice(0,2)),"YYYY/MM/DD"))return!1;var r=parseInt(t.slice(0,6)+t.slice(7,10),10)%31;return r<10?r===parseInt(t.slice(10),10):["A","B","C","D","E","F","H","J","K","L","M","N","P","R","S","T","U","V","W","X","Y"][r-=10]===t.slice(10)},"fr-BE":function(t){if(("00"!==t.slice(2,4)||"00"!==t.slice(4,6))&&!ot("".concat(t.slice(0,2),"/").concat(t.slice(2,4),"/").concat(t.slice(4,6)),"YY/MM/DD"))return!1;var e=97-parseInt(t.slice(0,9),10)%97,r=parseInt(t.slice(9,11),10);return e===r||97-parseInt("2".concat(t.slice(0,9)),10)%97===r},"fr-FR":function(t){return t=t.replace(/\s/g,""),parseInt(t.slice(0,10),10)%511===parseInt(t.slice(10,13),10)},"fr-LU":function(t){return!!ot("".concat(t.slice(0,4),"/").concat(t.slice(4,6),"/").concat(t.slice(6,8)),"YYYY/MM/DD")&&(!!pe(t.slice(0,12))&&function(t){for(var e=[[0,1,2,3,4,5,6,7,8,9],[1,2,3,4,0,6,7,8,9,5],[2,3,4,0,1,7,8,9,5,6],[3,4,0,1,2,8,9,5,6,7],[4,0,1,2,3,9,5,6,7,8],[5,9,8,7,6,0,4,3,2,1],[6,5,9,8,7,1,0,4,3,2],[7,6,5,9,8,2,1,0,4,3],[8,7,6,5,9,3,2,1,0,4],[9,8,7,6,5,4,3,2,1,0]],r=[[0,1,2,3,4,5,6,7,8,9],[1,5,7,6,2,8,3,0,9,4],[5,8,0,3,7,9,6,1,4,2],[8,9,1,6,0,4,3,5,2,7],[9,4,5,3,1,2,6,8,7,0],[4,2,8,6,5,7,3,9,0,1],[2,7,9,3,8,0,6,4,1,5],[7,0,4,6,9,1,3,2,5,8]],n=t.split("").reverse().join(""),i=0,o=0;o<n.length;o++)i=e[i][r[o%8][parseInt(n[o],10)]];return 0===i}("".concat(t.slice(0,11)).concat(t[12])))},"hr-HR":$e,"hu-HU":function(t){for(var e=t.split("").map(function(t){return parseInt(t,10)}),r=8,n=1;n<9;n++)r+=e[n]*(n+1);return r%11===e[9]},"it-IT":function(t){var e=t.toUpperCase().split("");if(!ge(e.slice(0,3)))return!1;if(!ge(e.slice(3,6)))return!1;for(var r={L:"0",M:"1",N:"2",P:"3",Q:"4",R:"5",S:"6",T:"7",U:"8",V:"9"},n=0,i=[6,7,9,10,12,13,14];n<i.length;n++){var o=i[n];e[o]in r&&e.splice(o,1,r[e[o]])}var a={A:"01",B:"02",C:"03",D:"04",E:"05",H:"06",L:"07",M:"08",P:"09",R:"10",S:"11",T:"12"}[e[8]];if(40<(t=parseInt(e[9]+e[10],10))&&(t-=40),t<10&&(t="0".concat(t)),!ot("".concat(e[6]).concat(e[7],"/").concat(a,"/").concat(t),"YY/MM/DD"))return!1;for(var s=0,c=1;c<e.length-1;c+=2){var u=parseInt(e[c],10);s+=u=isNaN(u)?e[c].charCodeAt(0)-65:u}for(var l={A:1,B:0,C:5,D:7,E:9,F:13,G:15,H:17,I:19,J:21,K:2,L:4,M:18,N:20,O:11,P:3,Q:6,R:8,S:12,T:14,U:16,V:10,W:22,X:25,Y:24,Z:23,0:1,1:0},d=0;d<e.length-1;d+=2){var f,A=0;e[d]in l?A=l[e[d]]:(A=2*(f=parseInt(e[d],10))+1,4<f&&(A+=2)),s+=A}return String.fromCharCode(65+s%26)===e[15]},"lv-LV":function(t){var e=(t=t.replace(/\W/,"")).slice(0,2);if("32"===e)return!0;if("00"!==t.slice(2,4)){var r=t.slice(4,6);switch(t[6]){case"0":r="18".concat(r);break;case"1":r="19".concat(r);break;default:r="20".concat(r)}if(!ot("".concat(r,"/").concat(t.slice(2,4),"/").concat(e),"YYYY/MM/DD"))return!1}for(var n=1101,i=[1,6,3,7,9,10,5,8,4,2],o=0;o<t.length-1;o++)n-=parseInt(t[o],10)*i[o];return parseInt(t[10],10)===n%11},"mt-MT":function(t){if(9!==t.length){for(var e=t.toUpperCase().split("");e.length<8;)e.unshift(0);switch(t[7]){case"A":case"P":if(0===parseInt(e[6],10))return!1;break;default:var r=parseInt(e.join("").slice(0,5),10);if(32e3<r)return!1;if(r===parseInt(e.join("").slice(5,7),10))return!1}}return!0},"nl-NL":function(t){return he(t.split("").slice(0,8).map(function(t){return parseInt(t,10)}),9)%11===parseInt(t[8],10)},"pl-PL":function(t){if(10===t.length){for(var e=[6,5,7,2,3,4,5,6,7],r=0,n=0;n<e.length;n++)r+=parseInt(t[n],10)*e[n];return 10===(r%=11)?!1:r===parseInt(t[9],10)}var i=t.slice(0,2),o=parseInt(t.slice(2,4),10);if(80<o?(i="18".concat(i),o-=80):60<o?(i="22".concat(i),o-=60):40<o?(i="21".concat(i),o-=40):20<o?(i="20".concat(i),o-=20):i="19".concat(i),o<10&&(o="0".concat(o)),!ot("".concat(i,"/").concat(o,"/").concat(t.slice(4,6)),"YYYY/MM/DD"))return!1;for(var a=0,s=1,c=0;c<t.length-1;c++)a+=parseInt(t[c],10)*s%10,10<(s+=2)?s=1:5===s&&(s+=2);return(a=10-a%10)===parseInt(t[10],10)},"pt-BR":function(t){if(11===t.length){var e=0;if("11111111111"===t||"22222222222"===t||"33333333333"===t||"44444444444"===t||"55555555555"===t||"66666666666"===t||"77777777777"===t||"88888888888"===t||"99999999999"===t||"00000000000"===t)return!1;for(var r=1;r<=9;r++)e+=parseInt(t.substring(r-1,r),10)*(11-r);if((l=10===(l=10*e%11)?0:l)!==parseInt(t.substring(9,10),10))return!1;e=0;for(var n=1;n<=10;n++)e+=parseInt(t.substring(n-1,n),10)*(12-n);return(l=10===(l=10*e%11)?0:l)!==parseInt(t.substring(10,11),10)?!1:!0}if("00000000000000"===t||"11111111111111"===t||"22222222222222"===t||"33333333333333"===t||"44444444444444"===t||"55555555555555"===t||"66666666666666"===t||"77777777777777"===t||"88888888888888"===t||"99999999999999"===t)return!1;for(var i=t.length-2,o=t.substring(0,i),a=t.substring(i),s=0,c=i-7,u=i;1<=u;u--)s+=o.charAt(i-u)*c,--c<2&&(c=9);var l=s%11<2?0:11-s%11;if(l!==parseInt(a.charAt(0),10))return!1;for(var o=t.substring(0,i+=1),s=0,c=i-7,d=i;1<=d;d--)s+=o.charAt(i-d)*c,--c<2&&(c=9);return(l=s%11<2?0:11-s%11)===parseInt(a.charAt(1),10)},"pt-PT":function(t){var e=11-he(t.split("").slice(0,8).map(function(t){return parseInt(t,10)}),9)%11;return 9<e?0===parseInt(t[8],10):e===parseInt(t[8],10)},"ro-RO":function(t){if("9000"===t.slice(0,4))return!0;var e=t.slice(1,3);switch(t[0]){case"1":case"2":e="19".concat(e);break;case"3":case"4":e="18".concat(e);break;case"5":case"6":e="20".concat(e)}var r="".concat(e,"/").concat(t.slice(3,5),"/").concat(t.slice(5,7));if(8===r.length){if(!ot(r,"YY/MM/DD"))return!1}else if(!ot(r,"YYYY/MM/DD"))return!1;for(var n=t.split("").map(function(t){return parseInt(t,10)}),i=[2,7,9,1,4,6,3,5,8,2,7,9],o=0,a=0;a<i.length;a++)o+=n[a]*i[a];return o%11==10?1===n[12]:n[12]===o%11},"sk-SK":function(t){if(9===t.length){if("000"===(t=t.replace(/\W/,"")).slice(6))return!1;if(53<(e=parseInt(t.slice(0,2),10)))return!1;var e=(e<10?"190":"19").concat(e),r=parseInt(t.slice(2,4),10);if(50<r&&(r-=50),r<10&&(r="0".concat(r)),!ot("".concat(e,"/").concat(r,"/").concat(t.slice(4,6)),"YYYY/MM/DD"))return!1}return!0},"sl-SI":function(t){var e=11-he(t.split("").slice(0,7).map(function(t){return parseInt(t,10)}),8)%11;return 10==e?0===parseInt(t[7],10):e===parseInt(t[7],10)},"sv-SE":function(t){var e=t.slice(0),r="",n=(e=11<t.length?e.slice(2):e).slice(2,4),i=parseInt(e.slice(4,6),10);if(11<t.length)r=t.slice(0,4);else if(r=t.slice(0,2),11===t.length&&i<60){var o=(new Date).getFullYear().toString(),e=parseInt(o.slice(0,2),10),o=parseInt(o,10);if("-"===t[6])r=(parseInt("".concat(e).concat(r),10)>o?"".concat(e-1):"".concat(e)).concat(r);else if(r="".concat(e-1).concat(r),o-parseInt(r,10)<100)return!1}if(60<i&&(i-=60),i<10&&(i="0".concat(i)),8===(i="".concat(r,"/").concat(n,"/").concat(i)).length){if(!ot(i,"YY/MM/DD"))return!1}else if(!ot(i,"YYYY/MM/DD"))return!1;return pe(t.replace(/\W/,""))}};me["lb-LU"]=me["fr-LU"],me["lt-LT"]=me["et-EE"],me["nl-BE"]=me["fr-BE"],me["fr-CA"]=me["en-CA"];var ve=/[-\\\/!@#$%\^&\*\(\)\+\=\[\]]+/g,Ie={"de-AT":ve,"de-DE":/[\/\\]/g,"fr-BE":ve};Ie["nl-BE"]=Ie["fr-BE"];var Re={"am-AM":/^(\+?374|0)((10|[9|7][0-9])\d{6}$|[2-4]\d{7}$)/,"ar-AE":/^((\+?971)|0)?5[024568]\d{7}$/,"ar-BH":/^(\+?973)?(3|6)\d{7}$/,"ar-DZ":/^(\+?213|0)(5|6|7)\d{8}$/,"ar-LB":/^(\+?961)?((3|81)\d{6}|7\d{7})$/,"ar-EG":/^((\+?20)|0)?1[0125]\d{8}$/,"ar-IQ":/^(\+?964|0)?7[0-9]\d{8}$/,"ar-JO":/^(\+?962|0)?7[789]\d{7}$/,"ar-KW":/^(\+?965)([569]\d{7}|41\d{6})$/,"ar-LY":/^((\+?218)|0)?(9[1-6]\d{7}|[1-8]\d{7,9})$/,"ar-MA":/^(?:(?:\+|00)212|0)[5-7]\d{8}$/,"ar-OM":/^((\+|00)968)?(9[1-9])\d{6}$/,"ar-PS":/^(\+?970|0)5[6|9](\d{7})$/,"ar-SA":/^(!?(\+?966)|0)?5\d{8}$/,"ar-SY":/^(!?(\+?963)|0)?9\d{8}$/,"ar-TN":/^(\+?216)?[2459]\d{7}$/,"az-AZ":/^(\+994|0)(10|5[015]|7[07]|99)\d{7}$/,"bs-BA":/^((((\+|00)3876)|06))((([0-3]|[5-6])\d{6})|(4\d{7}))$/,"be-BY":/^(\+?375)?(24|25|29|33|44)\d{7}$/,"bg-BG":/^(\+?359|0)?8[789]\d{7}$/,"bn-BD":/^(\+?880|0)1[13456789][0-9]{8}$/,"ca-AD":/^(\+376)?[346]\d{5}$/,"cs-CZ":/^(\+?420)? ?[1-9][0-9]{2} ?[0-9]{3} ?[0-9]{3}$/,"da-DK":/^(\+?45)?\s?\d{2}\s?\d{2}\s?\d{2}\s?\d{2}$/,"de-DE":/^((\+49|0)1)(5[0-25-9]\d|6([23]|0\d?)|7([0-57-9]|6\d))\d{7,9}$/,"de-AT":/^(\+43|0)\d{1,4}\d{3,12}$/,"de-CH":/^(\+41|0)([1-9])\d{1,9}$/,"de-LU":/^(\+352)?((6\d1)\d{6})$/,"dv-MV":/^(\+?960)?(7[2-9]|9[1-9])\d{5}$/,"el-GR":/^(\+?30|0)?6(8[5-9]|9(?![26])[0-9])\d{7}$/,"el-CY":/^(\+?357?)?(9(9|6)\d{6})$/,"en-AI":/^(\+?1|0)264(?:2(35|92)|4(?:6[1-2]|76|97)|5(?:3[6-9]|8[1-4])|7(?:2(4|9)|72))\d{4}$/,"en-AU":/^(\+?61|0)4\d{8}$/,"en-AG":/^(?:\+1|1)268(?:464|7(?:1[3-9]|[28]\d|3[0246]|64|7[0-689]))\d{4}$/,"en-BM":/^(\+?1)?441(((3|7)\d{6}$)|(5[0-3][0-9]\d{4}$)|(59\d{5}$))/,"en-BS":/^(\+?1[-\s]?|0)?\(?242\)?[-\s]?\d{3}[-\s]?\d{4}$/,"en-GB":/^(\+?44|0)7\d{9}$/,"en-GG":/^(\+?44|0)1481\d{6}$/,"en-GH":/^(\+233|0)(20|50|24|54|27|57|26|56|23|28|55|59)\d{7}$/,"en-GY":/^(\+592|0)6\d{6}$/,"en-HK":/^(\+?852[-\s]?)?[456789]\d{3}[-\s]?\d{4}$/,"en-MO":/^(\+?853[-\s]?)?[6]\d{3}[-\s]?\d{4}$/,"en-IE":/^(\+?353|0)8[356789]\d{7}$/,"en-IN":/^(\+?91|0)?[6789]\d{9}$/,"en-JM":/^(\+?876)?\d{7}$/,"en-KE":/^(\+?254|0)(7|1)\d{8}$/,"en-SS":/^(\+?211|0)(9[1257])\d{7}$/,"en-KI":/^((\+686|686)?)?( )?((6|7)(2|3|8)[0-9]{6})$/,"en-KN":/^(?:\+1|1)869(?:46\d|48[89]|55[6-8]|66\d|76[02-7])\d{4}$/,"en-LS":/^(\+?266)(22|28|57|58|59|27|52)\d{6}$/,"en-MT":/^(\+?356|0)?(99|79|77|21|27|22|25)[0-9]{6}$/,"en-MU":/^(\+?230|0)?\d{8}$/,"en-NA":/^(\+?264|0)(6|8)\d{7}$/,"en-NG":/^(\+?234|0)?[789]\d{9}$/,"en-NZ":/^(\+?64|0)[28]\d{7,9}$/,"en-PG":/^(\+?675|0)?(7\d|8[18])\d{6}$/,"en-PK":/^((00|\+)?92|0)3[0-6]\d{8}$/,"en-PH":/^(09|\+639)\d{9}$/,"en-RW":/^(\+?250|0)?[7]\d{8}$/,"en-SG":/^(\+65)?[3689]\d{7}$/,"en-SL":/^(\+?232|0)\d{8}$/,"en-TZ":/^(\+?255|0)?[67]\d{8}$/,"en-UG":/^(\+?256|0)?[7]\d{8}$/,"en-US":/^((\+1|1)?( |-)?)?(\([2-9][0-9]{2}\)|[2-9][0-9]{2})( |-)?([2-9][0-9]{2}( |-)?[0-9]{4})$/,"en-ZA":/^(\+?27|0)\d{9}$/,"en-ZM":/^(\+?26)?09[567]\d{7}$/,"en-ZW":/^(\+263)[0-9]{9}$/,"en-BW":/^(\+?267)?(7[1-8]{1})\d{6}$/,"es-AR":/^\+?549(11|[2368]\d)\d{8}$/,"es-BO":/^(\+?591)?(6|7)\d{7}$/,"es-CO":/^(\+?57)?3(0(0|1|2|4|5)|1\d|2[0-4]|5(0|1))\d{7}$/,"es-CL":/^(\+?56|0)[2-9]\d{1}\d{7}$/,"es-CR":/^(\+506)?[2-8]\d{7}$/,"es-CU":/^(\+53|0053)?5\d{7}/,"es-DO":/^(\+?1)?8[024]9\d{7}$/,"es-HN":/^(\+?504)?[9|8|3|2]\d{7}$/,"es-EC":/^(\+?593|0)([2-7]|9[2-9])\d{7}$/,"es-ES":/^(\+?34)?[6|7]\d{8}$/,"es-PE":/^(\+?51)?9\d{8}$/,"es-MX":/^(\+?52)?(1|01)?\d{10,11}$/,"es-NI":/^(\+?505)\d{7,8}$/,"es-PA":/^(\+?507)\d{7,8}$/,"es-PY":/^(\+?595|0)9[9876]\d{7}$/,"es-SV":/^(\+?503)?[67]\d{7}$/,"es-UY":/^(\+598|0)9[1-9][\d]{6}$/,"es-VE":/^(\+?58)?(2|4)\d{9}$/,"et-EE":/^(\+?372)?\s?(5|8[1-4])\s?([0-9]\s?){6,7}$/,"fa-IR":/^(\+?98[\-\s]?|0)9[0-39]\d[\-\s]?\d{3}[\-\s]?\d{4}$/,"fi-FI":/^(\+?358|0)\s?(4[0-6]|50)\s?(\d\s?){4,8}$/,"fj-FJ":/^(\+?679)?\s?\d{3}\s?\d{4}$/,"fo-FO":/^(\+?298)?\s?\d{2}\s?\d{2}\s?\d{2}$/,"fr-BF":/^(\+226|0)[67]\d{7}$/,"fr-BJ":/^(\+229)\d{8}$/,"fr-CD":/^(\+?243|0)?(8|9)\d{8}$/,"fr-CM":/^(\+?237)6[0-9]{8}$/,"fr-FR":/^(\+?33|0)[67]\d{8}$/,"fr-GF":/^(\+?594|0|00594)[67]\d{8}$/,"fr-GP":/^(\+?590|0|00590)[67]\d{8}$/,"fr-MQ":/^(\+?596|0|00596)[67]\d{8}$/,"fr-PF":/^(\+?689)?8[789]\d{6}$/,"fr-RE":/^(\+?262|0|00262)[67]\d{8}$/,"he-IL":/^(\+972|0)([23489]|5[012345689]|77)[1-9]\d{6}$/,"hu-HU":/^(\+?36|06)(20|30|31|50|70)\d{7}$/,"id-ID":/^(\+?62|0)8(1[123456789]|2[1238]|3[1238]|5[12356789]|7[78]|9[56789]|8[123456789])([\s?|\d]{5,11})$/,"ir-IR":/^(\+98|0)?9\d{9}$/,"it-IT":/^(\+?39)?\s?3\d{2} ?\d{6,7}$/,"it-SM":/^((\+378)|(0549)|(\+390549)|(\+3780549))?6\d{5,9}$/,"ja-JP":/^(\+81[ \-]?(\(0\))?|0)[6789]0[ \-]?\d{4}[ \-]?\d{4}$/,"ka-GE":/^(\+?995)?(79\d{7}|5\d{8})$/,"kk-KZ":/^(\+?7|8)?7\d{9}$/,"kl-GL":/^(\+?299)?\s?\d{2}\s?\d{2}\s?\d{2}$/,"ko-KR":/^((\+?82)[ \-]?)?0?1([0|1|6|7|8|9]{1})[ \-]?\d{3,4}[ \-]?\d{4}$/,"ky-KG":/^(\+?7\s?\+?7|0)\s?\d{2}\s?\d{3}\s?\d{4}$/,"lt-LT":/^(\+370|8)\d{8}$/,"lv-LV":/^(\+?371)2\d{7}$/,"mg-MG":/^((\+?261|0)(2|3)\d)?\d{7}$/,"mn-MN":/^(\+|00|011)?976(77|81|88|91|94|95|96|99)\d{6}$/,"my-MM":/^(\+?959|09|9)(2[5-7]|3[1-2]|4[0-5]|6[6-9]|7[5-9]|9[6-9])[0-9]{7}$/,"ms-MY":/^(\+?60|0)1(([0145](-|\s)?\d{7,8})|([236-9](-|\s)?\d{7}))$/,"mz-MZ":/^(\+?258)?8[234567]\d{7}$/,"nb-NO":/^(\+?47)?[49]\d{7}$/,"ne-NP":/^(\+?977)?9[78]\d{8}$/,"nl-BE":/^(\+?32|0)4\d{8}$/,"nl-NL":/^(((\+|00)?31\(0\))|((\+|00)?31)|0)6{1}\d{8}$/,"nl-AW":/^(\+)?297(56|59|64|73|74|99)\d{5}$/,"nn-NO":/^(\+?47)?[49]\d{7}$/,"pl-PL":/^(\+?48)? ?[5-8]\d ?\d{3} ?\d{2} ?\d{2}$/,"pt-BR":/^((\+?55\ ?[1-9]{2}\ ?)|(\+?55\ ?\([1-9]{2}\)\ ?)|(0[1-9]{2}\ ?)|(\([1-9]{2}\)\ ?)|([1-9]{2}\ ?))((\d{4}\-?\d{4})|(9[1-9]{1}\d{3}\-?\d{4}))$/,"pt-PT":/^(\+?351)?9[1236]\d{7}$/,"pt-AO":/^(\+244)\d{9}$/,"ro-MD":/^(\+?373|0)((6(0|1|2|6|7|8|9))|(7(6|7|8|9)))\d{6}$/,"ro-RO":/^(\+?40|0)\s?7\d{2}(\/|\s|\.|-)?\d{3}(\s|\.|-)?\d{3}$/,"ru-RU":/^(\+?7|8)?9\d{9}$/,"si-LK":/^(?:0|94|\+94)?(7(0|1|2|4|5|6|7|8)( |-)?)\d{7}$/,"sl-SI":/^(\+386\s?|0)(\d{1}\s?\d{3}\s?\d{2}\s?\d{2}|\d{2}\s?\d{3}\s?\d{3})$/,"sk-SK":/^(\+?421)? ?[1-9][0-9]{2} ?[0-9]{3} ?[0-9]{3}$/,"sq-AL":/^(\+355|0)6[789]\d{6}$/,"sr-RS":/^(\+3816|06)[- \d]{5,9}$/,"sv-SE":/^(\+?46|0)[\s\-]?7[\s\-]?[02369]([\s\-]?\d){7}$/,"tg-TJ":/^(\+?992)?[5][5]\d{7}$/,"th-TH":/^(\+66|66|0)\d{9}$/,"tr-TR":/^(\+?90|0)?5\d{9}$/,"tk-TM":/^(\+993|993|8)\d{8}$/,"uk-UA":/^(\+?38|8)?0\d{9}$/,"uz-UZ":/^(\+?998)?(6[125-79]|7[1-69]|88|9\d)\d{7}$/,"vi-VN":/^((\+?84)|0)((3([2-9]))|(5([25689]))|(7([0|6-9]))|(8([1-9]))|(9([0-9])))([0-9]{7})$/,"zh-CN":/^((\+|00)86)?(1[3-9]|9[28])\d{9}$/,"zh-TW":/^(\+?886\-?|0)?9\d{8}$/,"dz-BT":/^(\+?975|0)?(17|16|77|02)\d{6}$/,"ar-YE":/^(((\+|00)9677|0?7)[0137]\d{7}|((\+|00)967|0)[1-7]\d{6})$/,"ar-EH":/^(\+?212|0)[\s\-]?(5288|5289)[\s\-]?\d{5}$/,"fa-AF":/^(\+93|0)?(2{1}[0-8]{1}|[3-5]{1}[0-4]{1})(\d{7})$/};Re["en-CA"]=Re["en-US"],Re["fr-CA"]=Re["en-CA"],Re["fr-BE"]=Re["nl-BE"],Re["zh-HK"]=Re["en-HK"],Re["zh-MO"]=Re["en-MO"],Re["ga-IE"]=Re["en-IE"],Re["fr-CH"]=Re["de-CH"],Re["it-CH"]=Re["fr-CH"];var Ze=Object.keys(Re),Le=/^(0x)[0-9a-f]{40}$/i;var Me={symbol:"$",require_symbol:!1,allow_space_after_symbol:!1,symbol_after_digits:!1,allow_negatives:!0,parens_for_negatives:!1,negative_sign_before_digits:!1,negative_sign_after_digits:!1,allow_negative_sign_placeholder:!1,thousands_separator:",",decimal_separator:".",allow_decimal:!0,require_decimal:!1,digits_after_decimal:[2],allow_space_after_digits:!1};var Be=/^(bc1)[a-z0-9]{25,39}$/,Ne=/^(1|3)[A-HJ-NP-Za-km-z1-9]{25,39}$/;var Ce=new Set(["aa","ab","ae","af","ak","am","an","ar","as","av","ay","az","az","ba","be","bg","bh","bi","bm","bn","bo","br","bs","ca","ce","ch","co","cr","cs","cu","cv","cy","da","de","dv","dz","ee","el","en","eo","es","et","eu","fa","ff","fi","fj","fo","fr","fy","ga","gd","gl","gn","gu","gv","ha","he","hi","ho","hr","ht","hu","hy","hz","ia","id","ie","ig","ii","ik","io","is","it","iu","ja","jv","ka","kg","ki","kj","kk","kl","km","kn","ko","kr","ks","ku","kv","kw","ky","la","lb","lg","li","ln","lo","lt","lu","lv","mg","mh","mi","mk","ml","mn","mr","ms","mt","my","na","nb","nd","ne","ng","nl","nn","no","nr","nv","ny","oc","oj","om","or","os","pa","pi","pl","ps","pt","qu","rm","rn","ro","ru","rw","sa","sc","sd","se","sg","si","sk","sl","sm","sn","so","sq","sr","ss","st","su","sv","sw","ta","te","tg","th","ti","tk","tl","tn","to","tr","ts","tt","tw","ty","ug","uk","ur","uz","ve","vi","vo","wa","wo","xh","yi","yo","za","zh","zu"]);var Fe=/^([\+-]?\d{4}(?!\d{2}\b))((-?)((0[1-9]|1[0-2])(\3([12]\d|0[1-9]|3[01]))?|W([0-4]\d|5[0-3])(-?[1-7])?|(00[1-9]|0[1-9]\d|[12]\d{2}|3([0-5]\d|6[1-6])))([T\s]((([01]\d|2[0-3])((:?)[0-5]\d)?|24:?00)([\.,]\d+(?!:))?)?(\17[0-5]\d([\.,]\d+)?)?([zZ]|([\+-])([01]\d|2[0-3]):?([0-5]\d)?)?)?)?$/,De=/^([\+-]?\d{4}(?!\d{2}\b))((-?)((0[1-9]|1[0-2])(\3([12]\d|0[1-9]|3[01]))?|W([0-4]\d|5[0-3])(-?[1-7])?|(00[1-9]|0[1-9]\d|[12]\d{2}|3([0-5]\d|6[1-6])))([T]((([01]\d|2[0-3])((:?)[0-5]\d)?|24:?00)([\.,]\d+(?!:))?)?(\17[0-5]\d([\.,]\d+)?)?([zZ]|([\+-])([01]\d|2[0-3]):?([0-5]\d)?)?)?)?$/;var P=/([01][0-9]|2[0-3])/,H=/[0-5][0-9]/,U=new RegExp("[-+]".concat(P.source,":").concat(H.source)),ve=new RegExp("([zZ]|".concat(U.source,")")),U=new RegExp("".concat(P.source,":").concat(H.source,":").concat(/([0-5][0-9]|60)/.source).concat(/(\.[0-9]+)?/.source)),P=new RegExp("".concat(/[0-9]{4}/.source,"-").concat(/(0[1-9]|1[0-2])/.source,"-").concat(/([12]\d|0[1-9]|3[01])/.source)),H=new RegExp("".concat(U.source).concat(ve.source)),Te=new RegExp("^".concat(P.source,"[ tT]").concat(H.source,"$"));var Ge=new Set(["AFG","ALA","ALB","DZA","ASM","AND","AGO","AIA","ATA","ATG","ARG","ARM","ABW","AUS","AUT","AZE","BHS","BHR","BGD","BRB","BLR","BEL","BLZ","BEN","BMU","BTN","BOL","BES","BIH","BWA","BVT","BRA","IOT","BRN","BGR","BFA","BDI","KHM","CMR","CAN","CPV","CYM","CAF","TCD","CHL","CHN","CXR","CCK","COL","COM","COG","COD","COK","CRI","CIV","HRV","CUB","CUW","CYP","CZE","DNK","DJI","DMA","DOM","ECU","EGY","SLV","GNQ","ERI","EST","ETH","FLK","FRO","FJI","FIN","FRA","GUF","PYF","ATF","GAB","GMB","GEO","DEU","GHA","GIB","GRC","GRL","GRD","GLP","GUM","GTM","GGY","GIN","GNB","GUY","HTI","HMD","VAT","HND","HKG","HUN","ISL","IND","IDN","IRN","IRQ","IRL","IMN","ISR","ITA","JAM","JPN","JEY","JOR","KAZ","KEN","KIR","PRK","KOR","KWT","KGZ","LAO","LVA","LBN","LSO","LBR","LBY","LIE","LTU","LUX","MAC","MKD","MDG","MWI","MYS","MDV","MLI","MLT","MHL","MTQ","MRT","MUS","MYT","MEX","FSM","MDA","MCO","MNG","MNE","MSR","MAR","MOZ","MMR","NAM","NRU","NPL","NLD","NCL","NZL","NIC","NER","NGA","NIU","NFK","MNP","NOR","OMN","PAK","PLW","PSE","PAN","PNG","PRY","PER","PHL","PCN","POL","PRT","PRI","QAT","REU","ROU","RUS","RWA","BLM","SHN","KNA","LCA","MAF","SPM","VCT","WSM","SMR","STP","SAU","SEN","SRB","SYC","SLE","SGP","SXM","SVK","SVN","SLB","SOM","ZAF","SGS","SSD","ESP","LKA","SDN","SUR","SJM","SWZ","SWE","CHE","SYR","TWN","TJK","TZA","THA","TLS","TGO","TKL","TON","TTO","TUN","TUR","TKM","TCA","TUV","UGA","UKR","ARE","GBR","USA","UMI","URY","UZB","VUT","VEN","VNM","VGB","VIR","WLF","ESH","YEM","ZMB","ZWE"]);var Oe=new Set(["AED","AFN","ALL","AMD","ANG","AOA","ARS","AUD","AWG","AZN","BAM","BBD","BDT","BGN","BHD","BIF","BMD","BND","BOB","BOV","BRL","BSD","BTN","BWP","BYN","BZD","CAD","CDF","CHE","CHF","CHW","CLF","CLP","CNY","COP","COU","CRC","CUC","CUP","CVE","CZK","DJF","DKK","DOP","DZD","EGP","ERN","ETB","EUR","FJD","FKP","GBP","GEL","GHS","GIP","GMD","GNF","GTQ","GYD","HKD","HNL","HRK","HTG","HUF","IDR","ILS","INR","IQD","IRR","ISK","JMD","JOD","JPY","KES","KGS","KHR","KMF","KPW","KRW","KWD","KYD","KZT","LAK","LBP","LKR","LRD","LSL","LYD","MAD","MDL","MGA","MKD","MMK","MNT","MOP","MRU","MUR","MVR","MWK","MXN","MXV","MYR","MZN","NAD","NGN","NIO","NOK","NPR","NZD","OMR","PAB","PEN","PGK","PHP","PKR","PLN","PYG","QAR","RON","RSD","RUB","RWF","SAR","SBD","SCR","SDG","SEK","SGD","SHP","SLL","SOS","SRD","SSP","STN","SVC","SYP","SZL","THB","TJS","TMT","TND","TOP","TRY","TTD","TWD","TZS","UAH","UGX","USD","USN","UYI","UYU","UYW","UZS","VES","VND","VUV","WST","XAF","XAG","XAU","XBA","XBB","XBC","XBD","XCD","XDR","XOF","XPD","XPF","XPT","XSU","XTS","XUA","XXX","YER","ZAR","ZMW","ZWL"]);var Pe=/^[A-Z2-7]+=*$/,He=/^[A-HJKMNP-TV-Z0-9]+$/,_e={crockford:!1};var Ue=/^[A-HJ-NP-Za-km-z1-9]*$/;var be=/^[a-z]+\/[a-z0-9\-\+\._]+$/i,Ke=/^[a-z\-]+=[a-z0-9\-]+$/i,we=/^[a-z0-9!\$&'\(\)\*\+,;=\-\._~:@\/\?%\s]*$/i;var ye=/(?:^magnet:\?|[^?&]&)xt(?:\.1)?=urn:(?:(?:aich|bitprint|btih|ed2k|ed2khash|kzhash|md5|sha1|tree:tiger):[a-z0-9]{32}(?:[a-z0-9]{8})?|btmh:1220[a-z0-9]{64})(?:$|&)/i;var We=/^(application|audio|font|image|message|model|multipart|text|video)\/[a-zA-Z0-9\.\-\+_]{1,100}$/i,Ye=/^text\/[a-zA-Z0-9\.\-\+]{1,100};\s?charset=("[a-zA-Z0-9\.\-\+\s]{0,70}"|[a-zA-Z0-9\.\-\+]{0,70})(\s?\([a-zA-Z0-9\.\-\+\s]{1,20}\))?$/i,xe=/^multipart\/[a-zA-Z0-9\.\-\+]{1,100}(;\s?(boundary|charset)=("[a-zA-Z0-9\.\-\+\s]{0,70}"|[a-zA-Z0-9\.\-\+]{0,70})(\s?\([a-zA-Z0-9\.\-\+\s]{1,20}\))?){0,2}$/i;var ke=/^\(?[+-]?(90(\.0+)?|[1-8]?\d(\.\d+)?)$/,Ve=/^\s?[+-]?(180(\.0+)?|1[0-7]\d(\.\d+)?|\d{1,2}(\.\d+)?)\)?$/,ze=/^(([1-8]?\d)\D+([1-5]?\d|60)\D+([1-5]?\d|60)(\.\d+)?|90\D+0\D+0)\D+[NSns]?$/i,Xe=/^\s*([1-7]?\d{1,2}\D+([1-5]?\d|60)\D+([1-5]?\d|60)(\.\d+)?|180\D+0\D+0)\D+[EWew]?$/i,Je={checkDMS:!1};var U=/^\d{3}$/,ve=/^\d{4}$/,P=/^\d{5}$/,H=/^\d{6}$/,je={AD:/^AD\d{3}$/,AT:ve,AU:ve,AZ:/^AZ\d{4}$/,BA:/^([7-8]\d{4}$)/,BE:ve,BG:ve,BR:/^\d{5}-\d{3}$/,BY:/^2[1-4]\d{4}$/,CA:/^[ABCEGHJKLMNPRSTVXY]\d[ABCEGHJ-NPRSTV-Z][\s\-]?\d[ABCEGHJ-NPRSTV-Z]\d$/i,CH:ve,CN:/^(0[1-7]|1[012356]|2[0-7]|3[0-6]|4[0-7]|5[1-7]|6[1-7]|7[1-5]|8[1345]|9[09])\d{4}$/,CZ:/^\d{3}\s?\d{2}$/,DE:P,DK:ve,DO:P,DZ:P,EE:P,ES:/^(5[0-2]{1}|[0-4]{1}\d{1})\d{3}$/,FI:P,FR:/^\d{2}\s?\d{3}$/,GB:/^(gir\s?0aa|[a-z]{1,2}\d[\da-z]?\s?(\d[a-z]{2})?)$/i,GR:/^\d{3}\s?\d{2}$/,HR:/^([1-5]\d{4}$)/,HT:/^HT\d{4}$/,HU:ve,ID:P,IE:/^(?!.*(?:o))[A-Za-z]\d[\dw]\s\w{4}$/i,IL:/^(\d{5}|\d{7})$/,IN:/^((?!10|29|35|54|55|65|66|86|87|88|89)[1-9][0-9]{5})$/,IR:/^(?!(\d)\1{3})[13-9]{4}[1346-9][013-9]{5}$/,IS:U,IT:P,JP:/^\d{3}\-\d{4}$/,KE:P,KR:/^(\d{5}|\d{6})$/,LI:/^(948[5-9]|949[0-7])$/,LT:/^LT\-\d{5}$/,LU:ve,LV:/^LV\-\d{4}$/,LK:P,MG:U,MX:P,MT:/^[A-Za-z]{3}\s{0,1}\d{4}$/,MY:P,NL:/^\d{4}\s?[a-z]{2}$/i,NO:ve,NP:/^(10|21|22|32|33|34|44|45|56|57)\d{3}$|^(977)$/i,NZ:ve,PL:/^\d{2}\-\d{3}$/,PR:/^00[679]\d{2}([ -]\d{4})?$/,PT:/^\d{4}\-\d{3}?$/,RO:H,RU:H,SA:P,SE:/^[1-9]\d{2}\s?\d{2}$/,SG:H,SI:ve,SK:/^\d{3}\s?\d{2}$/,TH:P,TN:ve,TW:/^\d{3}(\d{2})?$/,UA:P,US:/^\d{5}(-\d{4})?$/,ZA:ve,ZM:P},P=Object.keys(je);function qe(t,e){u(t);e=e?new RegExp("^[".concat(e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),"]+"),"g"):/^\s+/g;return t.replace(e,"")}function Qe(t,e){if(u(t),e){e=new RegExp("[".concat(e.replace(/[.*+?^${}()|[\]\\]/g,"\\$&"),"]+$"),"g");return t.replace(e,"")}for(var r=t.length-1;/\s/.test(t.charAt(r));)--r;return t.slice(0,r+1)}function tr(t,e){return u(t),t.replace(new RegExp("[".concat(e,"]+"),"g"),"")}var er={all_lowercase:!0,gmail_lowercase:!0,gmail_remove_dots:!0,gmail_remove_subaddress:!0,gmail_convert_googlemaildotcom:!0,outlookdotcom_lowercase:!0,outlookdotcom_remove_subaddress:!0,yahoo_lowercase:!0,yahoo_remove_subaddress:!0,yandex_lowercase:!0,icloud_lowercase:!0,icloud_remove_subaddress:!0},rr=["icloud.com","me.com"],nr=["hotmail.at","hotmail.be","hotmail.ca","hotmail.cl","hotmail.co.il","hotmail.co.nz","hotmail.co.th","hotmail.co.uk","hotmail.com","hotmail.com.ar","hotmail.com.au","hotmail.com.br","hotmail.com.gr","hotmail.com.mx","hotmail.com.pe","hotmail.com.tr","hotmail.com.vn","hotmail.cz","hotmail.de","hotmail.dk","hotmail.es","hotmail.fr","hotmail.hu","hotmail.id","hotmail.ie","hotmail.in","hotmail.it","hotmail.jp","hotmail.kr","hotmail.lv","hotmail.my","hotmail.ph","hotmail.pt","hotmail.sa","hotmail.sg","hotmail.sk","live.be","live.co.uk","live.com","live.com.ar","live.com.mx","live.de","live.es","live.eu","live.fr","live.it","live.nl","msn.com","outlook.at","outlook.be","outlook.cl","outlook.co.il","outlook.co.nz","outlook.co.th","outlook.com","outlook.com.ar","outlook.com.au","outlook.com.br","outlook.com.gr","outlook.com.pe","outlook.com.tr","outlook.com.vn","outlook.cz","outlook.de","outlook.dk","outlook.es","outlook.fr","outlook.hu","outlook.id","outlook.ie","outlook.in","outlook.it","outlook.jp","outlook.kr","outlook.lv","outlook.my","outlook.ph","outlook.pt","outlook.sa","outlook.sg","outlook.sk","passport.com"],ir=["rocketmail.com","yahoo.ca","yahoo.co.uk","yahoo.com","yahoo.de","yahoo.fr","yahoo.in","yahoo.it","ymail.com"],or=["yandex.ru","yandex.ua","yandex.kz","yandex.com","yandex.by","ya.ru"];function ar(t){return 1<t.length?t:""}var sr=/^[^\s-_](?!.*?[-_]{2,})[a-z0-9-\\][^\s]*[^-_\s]$/;var cr={"cs-CZ":function(t){return/^(([ABCDEFHIJKLMNPRSTUVXYZ]|[0-9])-?){5,8}$/.test(t)},"de-DE":function(t){return/^((A|AA|AB|AC|AE|AH|AK|AM|AN|AÖ|AP|AS|AT|AU|AW|AZ|B|BA|BB|BC|BE|BF|BH|BI|BK|BL|BM|BN|BO|BÖ|BS|BT|BZ|C|CA|CB|CE|CO|CR|CW|D|DA|DD|DE|DH|DI|DL|DM|DN|DO|DU|DW|DZ|E|EA|EB|ED|EE|EF|EG|EH|EI|EL|EM|EN|ER|ES|EU|EW|F|FB|FD|FF|FG|FI|FL|FN|FO|FR|FS|FT|FÜ|FW|FZ|G|GA|GC|GD|GE|GF|GG|GI|GK|GL|GM|GN|GÖ|GP|GR|GS|GT|GÜ|GV|GW|GZ|H|HA|HB|HC|HD|HE|HF|HG|HH|HI|HK|HL|HM|HN|HO|HP|HR|HS|HU|HV|HX|HY|HZ|IK|IL|IN|IZ|J|JE|JL|K|KA|KB|KC|KE|KF|KG|KH|KI|KK|KL|KM|KN|KO|KR|KS|KT|KU|KW|KY|L|LA|LB|LC|LD|LF|LG|LH|LI|LL|LM|LN|LÖ|LP|LR|LU|M|MA|MB|MC|MD|ME|MG|MH|MI|MK|ML|MM|MN|MO|MQ|MR|MS|MÜ|MW|MY|MZ|N|NB|ND|NE|NF|NH|NI|NK|NM|NÖ|NP|NR|NT|NU|NW|NY|NZ|OA|OB|OC|OD|OE|OF|OG|OH|OK|OL|OP|OS|OZ|P|PA|PB|PE|PF|PI|PL|PM|PN|PR|PS|PW|PZ|R|RA|RC|RD|RE|RG|RH|RI|RL|RM|RN|RO|RP|RS|RT|RU|RV|RW|RZ|S|SB|SC|SE|SG|SI|SK|SL|SM|SN|SO|SP|SR|ST|SU|SW|SY|SZ|TE|TF|TG|TO|TP|TR|TS|TT|TÜ|ÜB|UE|UH|UL|UM|UN|V|VB|VG|VK|VR|VS|W|WA|WB|WE|WF|WI|WK|WL|WM|WN|WO|WR|WS|WT|WÜ|WW|WZ|Z|ZE|ZI|ZP|ZR|ZW|ZZ)[- ]?[A-Z]{1,2}[- ]?\d{1,4}|(ABG|ABI|AIB|AIC|ALF|ALZ|ANA|ANG|ANK|APD|ARN|ART|ASL|ASZ|AUR|AZE|BAD|BAR|BBG|BCH|BED|BER|BGD|BGL|BID|BIN|BIR|BIT|BIW|BKS|BLB|BLK|BNA|BOG|BOH|BOR|BOT|BRA|BRB|BRG|BRK|BRL|BRV|BSB|BSK|BTF|BÜD|BUL|BÜR|BÜS|BÜZ|CAS|CHA|CLP|CLZ|COC|COE|CUX|DAH|DAN|DAU|DBR|DEG|DEL|DGF|DIL|DIN|DIZ|DKB|DLG|DON|DUD|DÜW|EBE|EBN|EBS|ECK|EIC|EIL|EIN|EIS|EMD|EMS|ERB|ERH|ERK|ERZ|ESB|ESW|FDB|FDS|FEU|FFB|FKB|FLÖ|FOR|FRG|FRI|FRW|FTL|FÜS|GAN|GAP|GDB|GEL|GEO|GER|GHA|GHC|GLA|GMN|GNT|GOA|GOH|GRA|GRH|GRI|GRM|GRZ|GTH|GUB|GUN|GVM|HAB|HAL|HAM|HAS|HBN|HBS|HCH|HDH|HDL|HEB|HEF|HEI|HER|HET|HGN|HGW|HHM|HIG|HIP|HMÜ|HOG|HOH|HOL|HOM|HOR|HÖS|HOT|HRO|HSK|HST|HVL|HWI|IGB|ILL|JÜL|KEH|KEL|KEM|KIB|KLE|KLZ|KÖN|KÖT|KÖZ|KRU|KÜN|KUS|KYF|LAN|LAU|LBS|LBZ|LDK|LDS|LEO|LER|LEV|LIB|LIF|LIP|LÖB|LOS|LRO|LSZ|LÜN|LUP|LWL|MAB|MAI|MAK|MAL|MED|MEG|MEI|MEK|MEL|MER|MET|MGH|MGN|MHL|MIL|MKK|MOD|MOL|MON|MOS|MSE|MSH|MSP|MST|MTK|MTL|MÜB|MÜR|MYK|MZG|NAB|NAI|NAU|NDH|NEA|NEB|NEC|NEN|NES|NEW|NMB|NMS|NOH|NOL|NOM|NOR|NVP|NWM|OAL|OBB|OBG|OCH|OHA|ÖHR|OHV|OHZ|OPR|OSL|OVI|OVL|OVP|PAF|PAN|PAR|PCH|PEG|PIR|PLÖ|PRÜ|QFT|QLB|RDG|REG|REH|REI|RID|RIE|ROD|ROF|ROK|ROL|ROS|ROT|ROW|RSL|RÜD|RÜG|SAB|SAD|SAN|SAW|SBG|SBK|SCZ|SDH|SDL|SDT|SEB|SEE|SEF|SEL|SFB|SFT|SGH|SHA|SHG|SHK|SHL|SIG|SIM|SLE|SLF|SLK|SLN|SLS|SLÜ|SLZ|SMÜ|SOB|SOG|SOK|SÖM|SON|SPB|SPN|SRB|SRO|STA|STB|STD|STE|STL|SUL|SÜW|SWA|SZB|TBB|TDO|TET|TIR|TÖL|TUT|UEM|UER|UFF|USI|VAI|VEC|VER|VIB|VIE|VIT|VOH|WAF|WAK|WAN|WAR|WAT|WBS|WDA|WEL|WEN|WER|WES|WHV|WIL|WIS|WIT|WIZ|WLG|WMS|WND|WOB|WOH|WOL|WOR|WOS|WRN|WSF|WST|WSW|WTL|WTM|WUG|WÜM|WUN|WUR|WZL|ZEL|ZIG)[- ]?(([A-Z][- ]?\d{1,4})|([A-Z]{2}[- ]?\d{1,3})))[- ]?(E|H)?$/.test(t)},"de-LI":function(t){return/^FL[- ]?\d{1,5}[UZ]?$/.test(t)},"en-IN":function(t){return/^[A-Z]{2}[ -]?[0-9]{1,2}(?:[ -]?[A-Z])(?:[ -]?[A-Z]*)?[ -]?[0-9]{4}$/.test(t)},"es-AR":function(t){return/^(([A-Z]{2} ?[0-9]{3} ?[A-Z]{2})|([A-Z]{3} ?[0-9]{3}))$/.test(t)},"fi-FI":function(t){return/^(?=.{4,7})(([A-Z]{1,3}|[0-9]{1,3})[\s-]?([A-Z]{1,3}|[0-9]{1,5}))$/.test(t)},"hu-HU":function(t){return/^((((?!AAA)(([A-NPRSTVZWXY]{1})([A-PR-Z]{1})([A-HJ-NPR-Z]))|(A[ABC]I)|A[ABC]O|A[A-W]Q|BPI|BPO|UCO|UDO|XAO)-(?!000)\d{3})|(M\d{6})|((CK|DT|CD|HC|H[ABEFIKLMNPRSTVX]|MA|OT|R[A-Z]) \d{2}-\d{2})|(CD \d{3}-\d{3})|(C-(C|X) \d{4})|(X-(A|B|C) \d{4})|(([EPVZ]-\d{5}))|(S A[A-Z]{2} \d{2})|(SP \d{2}-\d{2}))$/.test(t)},"pt-BR":function(t){return/^[A-Z]{3}[ -]?[0-9][A-Z][0-9]{2}|[A-Z]{3}[ -]?[0-9]{4}$/.test(t)},"pt-PT":function(t){return/^([A-Z]{2}|[0-9]{2})[ -·]?([A-Z]{2}|[0-9]{2})[ -·]?([A-Z]{2}|[0-9]{2})$/.test(t)},"sq-AL":function(t){return/^[A-Z]{2}[- ]?((\d{3}[- ]?(([A-Z]{2})|T))|(R[- ]?\d{3}))$/.test(t)},"sv-SE":function(t){return/^[A-HJ-PR-UW-Z]{3} ?[\d]{2}[A-HJ-PR-UW-Z1-9]$|(^[A-ZÅÄÖ ]{2,7}$)/.test(t.trim())}};var ur=/^[A-Z]$/,lr=/^[a-z]$/,dr=/^[0-9]$/,fr=/^[-#!$@£%^&*()_+|~=`{}\[\]:";'<>?,.\/ ]$/,Ar={minLength:8,minLowercase:1,minUppercase:1,minNumbers:1,minSymbols:1,returnScore:!1,pointsPerUnique:1,pointsPerRepeat:.5,pointsForContainingLower:10,pointsForContainingUpper:10,pointsForContainingNumber:10,pointsForContainingSymbol:10};function $r(t){var e,r,n=(e=t,r={},Array.from(e).forEach(function(t){r[t]?r[t]+=1:r[t]=1}),r),i={length:t.length,uniqueChars:Object.keys(n).length,uppercaseCount:0,lowercaseCount:0,numberCount:0,symbolCount:0};return Object.keys(n).forEach(function(t){ur.test(t)?i.uppercaseCount+=n[t]:lr.test(t)?i.lowercaseCount+=n[t]:dr.test(t)?i.numberCount+=n[t]:fr.test(t)&&(i.symbolCount+=n[t])}),i}var pr={AT:function(t){return/^(AT)?U\d{8}$/.test(t)},BE:function(t){return/^(BE)?\d{10}$/.test(t)},BG:function(t){return/^(BG)?\d{9,10}$/.test(t)},HR:function(t){return/^(HR)?\d{11}$/.test(t)},CY:function(t){return/^(CY)?\w{9}$/.test(t)},CZ:function(t){return/^(CZ)?\d{8,10}$/.test(t)},DK:function(t){return/^(DK)?\d{8}$/.test(t)},EE:function(t){return/^(EE)?\d{9}$/.test(t)},FI:function(t){return/^(FI)?\d{8}$/.test(t)},FR:function(t){return/^(FR)?\w{2}\d{9}$/.test(t)},DE:function(t){return/^(DE)?\d{9}$/.test(t)},EL:function(t){return/^(EL)?\d{9}$/.test(t)},HU:function(t){return/^(HU)?\d{8}$/.test(t)},IE:function(t){return/^(IE)?\d{7}\w{1}(W)?$/.test(t)},IT:function(t){return/^(IT)?\d{11}$/.test(t)},LV:function(t){return/^(LV)?\d{11}$/.test(t)},LT:function(t){return/^(LT)?\d{9,12}$/.test(t)},LU:function(t){return/^(LU)?\d{8}$/.test(t)},MT:function(t){return/^(MT)?\d{8}$/.test(t)},NL:function(t){return/^(NL)?\d{9}B\d{2}$/.test(t)},PL:function(t){return/^(PL)?(\d{10}|(\d{3}-\d{3}-\d{2}-\d{2})|(\d{3}-\d{2}-\d{2}-\d{3}))$/.test(t)},PT:function(t){var e=t.match(/^(PT)?(\d{9})$/);if(!e)return!1;t=e[2],e=11-he(t.split("").slice(0,8).map(function(t){return parseInt(t,10)}),9)%11;return 9<e?0===parseInt(t[8],10):e===parseInt(t[8],10)},RO:function(t){return/^(RO)?\d{2,10}$/.test(t)},SK:function(t){return/^(SK)?\d{10}$/.test(t)},SI:function(t){return/^(SI)?\d{8}$/.test(t)},ES:function(t){return/^(ES)?\w\d{7}[A-Z]$/.test(t)},SE:function(t){return/^(SE)?\d{12}$/.test(t)},AL:function(t){return/^(AL)?\w{9}[A-Z]$/.test(t)},MK:function(t){return/^(MK)?\d{13}$/.test(t)},AU:function(t){return/^(AU)?\d{11}$/.test(t)},BY:function(t){return/^(УНП )?\d{9}$/.test(t)},CA:function(t){return/^(CA)?\d{9}$/.test(t)},IS:function(t){return/^(IS)?\d{5,6}$/.test(t)},IN:function(t){return/^(IN)?\d{15}$/.test(t)},ID:function(t){return/^(ID)?(\d{15}|(\d{2}.\d{3}.\d{3}.\d{1}-\d{3}.\d{3}))$/.test(t)},IL:function(t){return/^(IL)?\d{9}$/.test(t)},KZ:function(t){return/^(KZ)?\d{9}$/.test(t)},NZ:function(t){return/^(NZ)?\d{9}$/.test(t)},NG:function(t){return/^(NG)?(\d{12}|(\d{8}-\d{4}))$/.test(t)},NO:function(t){return/^(NO)?\d{9}MVA$/.test(t)},PH:function(t){return/^(PH)?(\d{12}|\d{3} \d{3} \d{3} \d{3})$/.test(t)},RU:function(t){return/^(RU)?(\d{10}|\d{12})$/.test(t)},SM:function(t){return/^(SM)?\d{5}$/.test(t)},SA:function(t){return/^(SA)?\d{15}$/.test(t)},RS:function(t){return/^(RS)?\d{9}$/.test(t)},CH:function(t){return/^(CH)?(\d{6}|\d{9}|(\d{3}.\d{3})|(\d{3}.\d{3}.\d{3}))(TVA|MWST|IVA)$/.test(t)},TR:function(t){return/^(TR)?\d{10}$/.test(t)},UA:function(t){return/^(UA)?\d{12}$/.test(t)},GB:function(t){return/^GB((\d{3} \d{4} ([0-8][0-9]|9[0-6]))|(\d{9} \d{3})|(((GD[0-4])|(HA[5-9]))[0-9]{2}))$/.test(t)},UZ:function(t){return/^(UZ)?\d{9}$/.test(t)},AR:function(t){return/^(AR)?\d{11}$/.test(t)},BO:function(t){return/^(BO)?\d{7}$/.test(t)},BR:function(t){return/^(BR)?((\d{2}.\d{3}.\d{3}\/\d{4}-\d{2})|(\d{3}.\d{3}.\d{3}-\d{2}))$/.test(t)},CL:function(t){return/^(CL)?\d{8}-\d{1}$/.test(t)},CO:function(t){return/^(CO)?\d{10}$/.test(t)},CR:function(t){return/^(CR)?\d{9,12}$/.test(t)},EC:function(t){return/^(EC)?\d{13}$/.test(t)},SV:function(t){return/^(SV)?\d{4}-\d{6}-\d{3}-\d{1}$/.test(t)},GT:function(t){return/^(GT)?\d{7}-\d{1}$/.test(t)},HN:function(t){return/^(HN)?$/.test(t)},MX:function(t){return/^(MX)?\w{3,4}\d{6}\w{3}$/.test(t)},NI:function(t){return/^(NI)?\d{3}-\d{6}-\d{4}\w{1}$/.test(t)},PA:function(t){return/^(PA)?$/.test(t)},PY:function(t){return/^(PY)?\d{6,8}-\d{1}$/.test(t)},PE:function(t){return/^(PE)?\d{11}$/.test(t)},DO:function(t){return/^(DO)?(\d{11}|(\d{3}-\d{7}-\d{1})|[1,4,5]{1}\d{8}|([1,4,5]{1})-\d{2}-\d{5}-\d{1})$/.test(t)},UY:function(t){return/^(UY)?\d{12}$/.test(t)},VE:function(t){return/^(VE)?[J,G,V,E]{1}-(\d{9}|(\d{8}-\d{1}))$/.test(t)}};return{version:"13.9.0",toDate:i,toFloat:N,toInt:function(t,e){return u(t),parseInt(t,e||10)},toBoolean:function(t,e){return u(t),e?"1"===t||/^true$/i.test(t):"0"!==t&&!/^false$/i.test(t)&&""!==t},equals:function(t,e){return u(t),t===e},contains:function(t,e,r){return u(t),(r=F(r,D)).ignoreCase?t.toLowerCase().split(C(e).toLowerCase()).length>r.minOccurrences:t.split(C(e)).length>r.minOccurrences},matches:function(t,e,r){return u(t),"[object RegExp]"!==Object.prototype.toString.call(e)&&(e=new RegExp(e,r)),!!t.match(e)},isEmail:function(t,e){if(u(t),(e=F(e,w)).require_display_name||e.allow_display_name){var r=t.match(y);if(r){var n=r[1];if(t=t.replace(n,"").replace(/(^<|>$)/g,""),!function(t){var e=t.replace(/^"(.+)"$/,"$1");if(e.trim()){if(/[\.";<>]/.test(e)){if(e===t)return;if(!(e.split('"').length===e.split('\\"').length))return}return 1}}(n=n.endsWith(" ")?n.slice(0,-1):n))return!1}else if(e.require_display_name)return!1}if(!e.ignore_max_length&&254<t.length)return!1;if(r=t.split("@"),n=r.pop(),t=n.toLowerCase(),e.host_blacklist.includes(t))return!1;if(0<e.host_whitelist.length&&!e.host_whitelist.includes(t))return!1;if(r=r.join("@"),e.domain_specific_validation&&("gmail.com"===t||"googlemail.com"===t)){t=(r=r.toLowerCase()).split("+")[0];if(!T(t.replace(/\./g,""),{min:6,max:30}))return!1;for(var i=t.split("."),o=0;o<i.length;o++)if(!Y.test(i[o]))return!1}if(!(!1!==e.ignore_max_length||T(r,{max:64})&&T(n,{max:254})))return!1;if(!O(n,{require_tld:e.require_tld,ignore_max_length:e.ignore_max_length})){if(!e.allow_ip_domain)return!1;if(!K(n)){if(!n.startsWith("[")||!n.endsWith("]"))return!1;n=n.slice(1,-1);if(0===n.length||!K(n))return!1}}if('"'===r[0])return r=r.slice(1,r.length-1),(e.allow_utf8_local_part?V:x).test(r);for(var a=e.allow_utf8_local_part?k:W,s=r.split("."),c=0;c<s.length;c++)if(!a.test(s[c]))return!1;return!e.blacklisted_chars||-1===r.search(new RegExp("[".concat(e.blacklisted_chars,"]+"),"g"))},isURL:function(t,e){if(u(t),!t||/[\s<>]/.test(t))return!1;if(0===t.indexOf("mailto:"))return!1;if((e=F(e,z)).validate_length&&2083<=t.length)return!1;if(!e.allow_fragments&&t.includes("#"))return!1;if(!e.allow_query_components&&(t.includes("?")||t.includes("&")))return!1;var r,n,i=t.split("#");if(1<(i=(t=(i=(t=i.shift()).split("?")).shift()).split("://")).length){if(r=i.shift().toLowerCase(),e.require_valid_protocol&&-1===e.protocols.indexOf(r))return!1}else{if(e.require_protocol)return!1;if("//"===t.slice(0,2)){if(!e.allow_protocol_relative_urls)return!1;i[0]=t.slice(2)}}if(""===(t=i.join("://")))return!1;if(""===(t=(i=t.split("/")).shift())&&!e.require_host)return!0;if(1<(i=t.split("@")).length){if(e.disallow_auth)return!1;if(""===i[0])return!1;if(0<=(c=i.shift()).indexOf(":")&&2<c.split(":").length)return!1;var o=l(c.split(":"),2),a=o[0],s=o[1];if(""===a&&""===s)return!1}var c=null,o=null;if((s=(a=i.join("@")).match(X))?(n="",o=s[1],c=s[2]||null):(n=(i=a.split(":")).shift(),i.length&&(c=i.join(":"))),null!==c&&0<c.length){if(i=parseInt(c,10),!/^[0-9]+$/.test(c)||i<=0||65535<i)return!1}else if(e.require_port)return!1;return e.host_whitelist?J(n,e.host_whitelist):""===n&&!e.require_host||!!(K(n)||O(n,e)||o&&K(o,6))&&(n=n||o,!e.host_blacklist||!J(n,e.host_blacklist))},isMACAddress:function t(e,r){return u(e),null!=r&&r.eui&&(r.eui=String(r.eui)),null!=r&&r.no_colons||null!=r&&r.no_separators?"48"===r.eui?q.test(e):"64"!==r.eui&&q.test(e)||et.test(e):"48"===(null==r?void 0:r.eui)?j.test(e)||Q.test(e):"64"===(null==r?void 0:r.eui)?tt.test(e)||rt.test(e):t(e,{eui:"48"})||t(e,{eui:"64"})},isIP:K,isIPRange:function(t){var e=1<arguments.length&&void 0!==arguments[1]?arguments[1]:"";u(t);var r=t.split("/");if(2!==r.length)return!1;if(!nt.test(r[1]))return!1;if(1<r[1].length&&r[1].startsWith("0"))return!1;if(!K(r[0],e))return!1;var n=null;switch(String(e)){case"4":n=32;break;case"6":n=128;break;default:n=K(r[0],"6")?128:32}return r[1]<=n&&0<=r[1]},isFQDN:O,isBoolean:function(t){var e=1<arguments.length&&void 0!==arguments[1]?arguments[1]:ct;return u(t),e.loose?lt.includes(t.toLowerCase()):ut.includes(t)},isIBAN:function(t){return u(t),(e=(r=(e=t).replace(/[\s\-]+/gi,"").toUpperCase()).slice(0,2).toUpperCase())in yt&&yt[e].test(r)&&1===((t=(t=t).replace(/[^A-Z0-9]+/gi,"").toUpperCase()).slice(4)+t.slice(0,4)).replace(/[A-Z]/g,function(t){return t.charCodeAt(0)-55}).match(/\d{1,7}/g).reduce(function(t,e){return Number(t+e)%97},"");var e,r},isBIC:function(t){u(t);var e=t.slice(4,6).toUpperCase();return!(!xt.has(e)&&"XK"!==e)&&kt.test(t)},isAlpha:function(t){var e=1<arguments.length&&void 0!==arguments[1]?arguments[1]:"en-US",r=2<arguments.length&&void 0!==arguments[2]?arguments[2]:{};if(u(t),r=r.ignore)if(r instanceof RegExp)t=t.replace(r,"");else{if("string"!=typeof r)throw new Error("ignore should be instance of a String or RegExp");t=t.replace(new RegExp("[".concat(r.replace(/[-[\]{}()*+?.,\\^$|#\\s]/g,"\\$&"),"]"),"g"),"")}if(e in a)return a[e].test(t);throw new Error("Invalid locale '".concat(e,"'"))},isAlphaLocales:ft,isAlphanumeric:function(t){var e=1<arguments.length&&void 0!==arguments[1]?arguments[1]:"en-US",r=2<arguments.length&&void 0!==arguments[2]?arguments[2]:{};if(u(t),r=r.ignore)if(r instanceof RegExp)t=t.replace(r,"");else{if("string"!=typeof r)throw new Error("ignore should be instance of a String or RegExp");t=t.replace(new RegExp("[".concat(r.replace(/[-[\]{}()*+?.,\\^$|#\\s]/g,"\\$&"),"]"),"g"),"")}if(e in s)return s[e].test(t);throw new Error("Invalid locale '".concat(e,"'"))},isAlphanumericLocales:At,isNumeric:function(t,e){return u(t),(e&&e.no_symbols?$t:new RegExp("^[+-]?([0-9]*[".concat((e||{}).locale?c[e.locale]:".","])?[0-9]+$"))).test(t)},isPassportNumber:function(t,e){return u(t),t=t.replace(/\s/g,"").toUpperCase(),e.toUpperCase()in pt&&pt[e].test(t)},isPort:function(t){return gt(t,{min:0,max:65535})},isLowercase:function(t){return u(t),t===t.toLowerCase()},isUppercase:function(t){return u(t),t===t.toUpperCase()},isAscii:function(t){return u(t),vt.test(t)},isFullWidth:function(t){return u(t),It.test(t)},isHalfWidth:function(t){return u(t),Rt.test(t)},isVariableWidth:function(t){return u(t),It.test(t)&&Rt.test(t)},isMultibyte:function(t){return u(t),Zt.test(t)},isSemVer:function(t){return u(t),Bt.test(t)},isSurrogatePair:function(t){return u(t),Nt.test(t)},isInt:gt,isIMEI:function(t,e){if(u(t),!((e=e||{}).allow_hyphens?mt:Et).test(t))return!1;t=t.replace(/-/g,"");for(var r=0,n=2,i=0;i<14;i++){var o=t.substring(14-i-1,14-i),o=parseInt(o,10)*n;r+=10<=o?o%10+1:o,1===n?n+=1:--n}return(10-r%10)%10===parseInt(t.substring(14,15),10)},isFloat:M,isFloatLocales:B,isDecimal:function(t,e){if(u(t),(e=F(e,Ct)).locale in c)return r=Ft,n=t.replace(/ /g,""),!r.some(function(t){return n===t})&&(r=e,new RegExp("^[-+]?([0-9]+)?(\\".concat(c[r.locale],"[0-9]{").concat(r.decimal_digits,"})").concat(r.force_decimal?"":"?","$")).test(t));var r,n;throw new Error("Invalid locale '".concat(e.locale,"'"))},isHexadecimal:Tt,isOctal:function(t){return u(t),Gt.test(t)},isDivisibleBy:function(t,e){return u(t),N(t)%parseInt(e,10)==0},isHexColor:function(t){return u(t),Ot.test(t)},isRgbColor:function(t){var e=!(1<arguments.length&&void 0!==arguments[1])||arguments[1];return u(t),e?Pt.test(t)||Ht.test(t)||_t.test(t)||Ut.test(t):Pt.test(t)||Ht.test(t)},isHSL:function(t){return u(t),(-1!==(t=t.replace(/\s+/g," ").replace(/\s?(hsla?\(|\)|,)\s?/gi,"$1")).indexOf(",")?bt:Kt).test(t)},isISRC:function(t){return u(t),wt.test(t)},isMD5:function(t){return u(t),Vt.test(t)},isHash:function(t,e){return u(t),new RegExp("^[a-fA-F0-9]{".concat(zt[e],"}$")).test(t)},isJWT:function(t){u(t);var e=t.split(".");return!(3<(t=e.length)||t<2)&&e.reduce(function(t,e){return t&&qt(e,{urlSafe:!0})},!0)},isJSON:function(t,e){u(t);try{e=F(e,Qt);var r=[];e.allow_primitives&&(r=[null,!1,!0]);var n=JSON.parse(t);return r.includes(n)||!!n&&"object"===o(n)}catch(t){}return!1},isEmpty:function(t,e){return u(t),0===((e=F(e,te)).ignore_whitespace?t.trim():t).length},isLength:function(t,e){var r;u(t);var n="object"===o(e)?(r=e.min||0,e.max):(r=e||0,arguments[2]),i=t.match(/(\uFE0F|\uFE0E)/g)||[],e=t.match(/[\uD800-\uDBFF][\uDC00-\uDFFF]/g)||[],e=t.length-i.length-e.length;return r<=e&&(void 0===n||e<=n)},isLocale:function(t){return u(t),"en_US_POSIX"===t||"ca_ES_VALENCIA"===t||dt.test(t)},isByteLength:T,isUUID:function(t,e){return u(t),!!(e=ee[[void 0,null].includes(e)?"all":e])&&e.test(t)},isMongoId:function(t){return u(t),Tt(t)&&24===t.length},isAfter:function(t,e){return e=i((null==e?void 0:e.comparisonDate)||e||Date().toString()),!!((t=i(t))&&e&&e<t)},isBefore:function(t){var e=1<arguments.length&&void 0!==arguments[1]?arguments[1]:String(new Date);return u(t),e=i(e),!!((t=i(t))&&e&&t<e)},isIn:function(t,e){if(u(t),"[object Array]"!==Object.prototype.toString.call(e))return"object"===o(e)?e.hasOwnProperty(t):!(!e||"function"!=typeof e.indexOf)&&0<=e.indexOf(t);var r,n=[];for(r in e)!{}.hasOwnProperty.call(e,r)||(n[r]=C(e[r]));return 0<=n.indexOf(t)},isLuhnNumber:re,isCreditCard:function(t){var e=1<arguments.length&&void 0!==arguments[1]?arguments[1]:{};u(t);var r=e.provider,e=t.replace(/[- ]+/g,"");if(r&&r.toLowerCase()in ne){if(!ne[r.toLowerCase()].test(e))return!1}else{if(r&&!(r.toLowerCase()in ne))throw new Error("".concat(r," is not a valid credit card provider."));if(!ie.test(e))return!1}return re(t)},isIdentityCard:function(t,e){if(u(t),e in oe)return oe[e](t);if("any"!==e)throw new Error("Invalid locale '".concat(e,"'"));for(var r in oe)if(oe.hasOwnProperty(r))if((0,oe[r])(t))return!0;return!1},isEAN:function(t){u(t);var e=Number(t.slice(-1));return ce.test(t)&&e===ue(t)},isISIN:function(t){if(u(t),!le.test(t))return!1;for(var e=!0,r=0,n=t.length-2;0<=n;n--)if("A"<=t[n]&&t[n]<="Z")for(var i=t[n].charCodeAt(0)-55,o=0,a=[i%10,Math.trunc(i/10)];o<a.length;o++){var s=a[o];r+=e?5<=s?1+2*(s-5):2*s:s,e=!e}else{i=t[n].charCodeAt(0)-"0".charCodeAt(0);r+=e?5<=i?1+2*(i-5):2*i:i,e=!e}var c=10*Math.trunc((r+9)/10)-r;return+t[t.length-1]==c},isISBN:function t(e,r){u(e);var n=String((null==r?void 0:r.version)||r);if(!(null!=r&&r.version||r))return t(e,{version:10})||t(e,{version:13});var i=e.replace(/[\s-]+/g,""),o=0;if("10"===n){if(!de.test(i))return!1;for(var a=0;a<n-1;a++)o+=(a+1)*i.charAt(a);if("X"===i.charAt(9)?o+=100:o+=10*i.charAt(9),o%11==0)return!0}else if("13"===n){if(!fe.test(i))return!1;for(var s=0;s<12;s++)o+=Ae[s%2]*i.charAt(s);if(i.charAt(12)-(10-o%10)%10==0)return!0}return!1},isISSN:function(t){var e=1<arguments.length&&void 0!==arguments[1]?arguments[1]:{};u(t);var r="^\\d{4}-?\\d{3}[\\dX]$",r=e.require_hyphen?r.replace("?",""):r;if(!(r=e.case_sensitive?new RegExp(r):new RegExp(r,"i")).test(t))return!1;for(var n=t.replace("-","").toUpperCase(),i=0,o=0;o<n.length;o++){var a=n[o];i+=("X"===a?10:+a)*(8-o)}return i%11==0},isMobilePhone:function(e,t,r){if(u(e),r&&r.strictMode&&!e.startsWith("+"))return!1;if(Array.isArray(t))return t.some(function(t){if(Re.hasOwnProperty(t)&&Re[t].test(e))return!0;return!1});if(t in Re)return Re[t].test(e);if(t&&"any"!==t)throw new Error("Invalid locale '".concat(t,"'"));for(var n in Re)if(Re.hasOwnProperty(n))if(Re[n].test(e))return!0;return!1},isMobilePhoneLocales:Ze,isPostalCode:function(t,e){if(u(t),e in je)return je[e].test(t);if("any"!==e)throw new Error("Invalid locale '".concat(e,"'"));for(var r in je)if(je.hasOwnProperty(r))if(je[r].test(t))return!0;return!1},isPostalCodeLocales:P,isEthereumAddress:function(t){return u(t),Le.test(t)},isCurrency:function(t,e){return u(t),function(t){var r="\\d{".concat(t.digits_after_decimal[0],"}");t.digits_after_decimal.forEach(function(t,e){0!==e&&(r="".concat(r,"|\\d{").concat(t,"}"))});var e="(".concat(t.symbol.replace(/\W/,function(t){return"\\".concat(t)}),")").concat(t.require_symbol?"":"?"),n="[1-9]\\d{0,2}(\\".concat(t.thousands_separator,"\\d{3})*"),i="(".concat(["0","[1-9]\\d*",n].join("|"),")?"),n="(\\".concat(t.decimal_separator,"(").concat(r,"))").concat(t.require_decimal?"":"?"),n=i+(t.allow_decimal||t.require_decimal?n:"");return t.allow_negatives&&!t.parens_for_negatives&&(t.negative_sign_after_digits?n+="-?":t.negative_sign_before_digits&&(n="-?"+n)),t.allow_negative_sign_placeholder?n="( (?!\\-))?".concat(n):t.allow_space_after_symbol?n=" ?".concat(n):t.allow_space_after_digits&&(n+="( (?!$))?"),t.symbol_after_digits?n+=e:n=e+n,t.allow_negatives&&(t.parens_for_negatives?n="(\\(".concat(n,"\\)|").concat(n,")"):t.negative_sign_before_digits||t.negative_sign_after_digits||(n="-?"+n)),new RegExp("^(?!-? )(?=.*\\d)".concat(n,"$"))}(e=F(e,Me)).test(t)},isBtcAddress:function(t){return u(t),Be.test(t)||Ne.test(t)},isISO6391:function(t){return u(t),Ce.has(t)},isISO8601:function(t){var e=1<arguments.length&&void 0!==arguments[1]?arguments[1]:{};u(t);var r=(e.strictSeparator?De:Fe).test(t);return r&&e.strict?function(t){var e=t.match(/^(\d{4})-?(\d{3})([ T]{1}\.*|$)/);if(e){var r=Number(e[1]),n=Number(e[2]);return r%4==0&&r%100!=0||r%400==0?n<=366:n<=365}var i=t.match(/(\d{4})-?(\d{0,2})-?(\d*)/).map(Number),e=i[1],r=i[2],n=i[3],t=r&&"0".concat(r).slice(-2),i=n&&"0".concat(n).slice(-2),i=new Date("".concat(e,"-").concat(t||"01","-").concat(i||"01"));return!r||!n||i.getUTCFullYear()===e&&i.getUTCMonth()+1===r&&i.getUTCDate()===n}(t):r},isRFC3339:function(t){return u(t),Te.test(t)},isISO31661Alpha2:function(t){return u(t),Yt.has(t.toUpperCase())},isISO31661Alpha3:function(t){return u(t),Ge.has(t.toUpperCase())},isISO4217:function(t){return u(t),Oe.has(t.toUpperCase())},isBase32:function(t,e){return u(t),(e=F(e,_e)).crockford?He.test(t):!(t.length%8!=0||!Pe.test(t))},isBase58:function(t){return u(t),!!Ue.test(t)},isBase64:qt,isDataURI:function(t){u(t);var e=t.split(",");if(e.length<2)return!1;var r=e.shift().trim().split(";");if("data:"!==(t=r.shift()).slice(0,5))return!1;if(""!==(t=t.slice(5))&&!be.test(t))return!1;for(var n=0;n<r.length;n++)if((n!==r.length-1||"base64"!==r[n].toLowerCase())&&!Ke.test(r[n]))return!1;for(var i=0;i<e.length;i++)if(!we.test(e[i]))return!1;return!0},isMagnetURI:function(t){return u(t),0===t.indexOf("magnet:?")&&ye.test(t)},isMimeType:function(t){return u(t),We.test(t)||Ye.test(t)||xe.test(t)},isLatLong:function(t,e){return u(t),e=F(e,Je),!!t.includes(",")&&(!((t=t.split(","))[0].startsWith("(")&&!t[1].endsWith(")")||t[1].endsWith(")")&&!t[0].startsWith("("))&&(e.checkDMS?ze.test(t[0])&&Xe.test(t[1]):ke.test(t[0])&&Ve.test(t[1])))},ltrim:qe,rtrim:Qe,trim:function(t,e){return Qe(qe(t,e),e)},escape:function(t){return u(t),t.replace(/&/g,"&amp;").replace(/"/g,"&quot;").replace(/'/g,"&#x27;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/\//g,"&#x2F;").replace(/\\/g,"&#x5C;").replace(/`/g,"&#96;")},unescape:function(t){return u(t),t.replace(/&quot;/g,'"').replace(/&#x27;/g,"'").replace(/&lt;/g,"<").replace(/&gt;/g,">").replace(/&#x2F;/g,"/").replace(/&#x5C;/g,"\\").replace(/&#96;/g,"`").replace(/&amp;/g,"&")},stripLow:function(t,e){return u(t),tr(t,e?"\\x00-\\x09\\x0B\\x0C\\x0E-\\x1F\\x7F":"\\x00-\\x1F\\x7F")},whitelist:function(t,e){return u(t),t.replace(new RegExp("[^".concat(e,"]+"),"g"),"")},blacklist:tr,isWhitelisted:function(t,e){u(t);for(var r=t.length-1;0<=r;r--)if(-1===e.indexOf(t[r]))return!1;return!0},normalizeEmail:function(t,e){e=F(e,er);var r=t.split("@"),t=r.pop();if((r=[r.join("@"),t])[1]=r[1].toLowerCase(),"gmail.com"===r[1]||"googlemail.com"===r[1]){if(e.gmail_remove_subaddress&&(r[0]=r[0].split("+")[0]),e.gmail_remove_dots&&(r[0]=r[0].replace(/\.+/g,ar)),!r[0].length)return!1;(e.all_lowercase||e.gmail_lowercase)&&(r[0]=r[0].toLowerCase()),r[1]=e.gmail_convert_googlemaildotcom?"gmail.com":r[1]}else if(0<=rr.indexOf(r[1])){if(e.icloud_remove_subaddress&&(r[0]=r[0].split("+")[0]),!r[0].length)return!1;(e.all_lowercase||e.icloud_lowercase)&&(r[0]=r[0].toLowerCase())}else if(0<=nr.indexOf(r[1])){if(e.outlookdotcom_remove_subaddress&&(r[0]=r[0].split("+")[0]),!r[0].length)return!1;(e.all_lowercase||e.outlookdotcom_lowercase)&&(r[0]=r[0].toLowerCase())}else if(0<=ir.indexOf(r[1])){if(e.yahoo_remove_subaddress&&(t=r[0].split("-"),r[0]=1<t.length?t.slice(0,-1).join("-"):t[0]),!r[0].length)return!1;(e.all_lowercase||e.yahoo_lowercase)&&(r[0]=r[0].toLowerCase())}else 0<=or.indexOf(r[1])?((e.all_lowercase||e.yandex_lowercase)&&(r[0]=r[0].toLowerCase()),r[1]="yandex.ru"):e.all_lowercase&&(r[0]=r[0].toLowerCase());return r.join("@")},toString:toString,isSlug:function(t){return u(t),sr.test(t)},isStrongPassword:function(t){var e=1<arguments.length&&void 0!==arguments[1]?arguments[1]:null;u(t);var r,n,i=$r(t);return(e=F(e||{},Ar)).returnScore?(r=e,n=0,n+=(t=i).uniqueChars*r.pointsPerUnique,n+=(t.length-t.uniqueChars)*r.pointsPerRepeat,0<t.lowercaseCount&&(n+=r.pointsForContainingLower),0<t.uppercaseCount&&(n+=r.pointsForContainingUpper),0<t.numberCount&&(n+=r.pointsForContainingNumber),0<t.symbolCount&&(n+=r.pointsForContainingSymbol),n):i.length>=e.minLength&&i.lowercaseCount>=e.minLowercase&&i.uppercaseCount>=e.minUppercase&&i.numberCount>=e.minNumbers&&i.symbolCount>=e.minSymbols},isTaxID:function(t){var e=1<arguments.length&&void 0!==arguments[1]?arguments[1]:"en-US";if(u(t),t=t.slice(0),e in Ee)return e in Ie&&(t=t.replace(Ie[e],"")),!!Ee[e].test(t)&&(!(e in me)||me[e](t));throw new Error("Invalid locale '".concat(e,"'"))},isDate:ot,isTime:function(t,e){return e=F(e,at),"string"==typeof t&&st[e.hourFormat][e.mode].test(t)},isLicensePlate:function(t,e){if(u(t),e in cr)return cr[e](t);if("any"!==e)throw new Error("Invalid locale '".concat(e,"'"));for(var r in cr)if((0,cr[r])(t))return!0;return!1},isVAT:function(t,e){if(u(t),u(e),e in pr)return pr[e](t);throw new Error("Invalid country code: '".concat(e,"'"))},ibanLocales:Wt}}); \ No newline at end of file