mirror of
https://github.com/S2-/minifyfromhtml.git
synced 2025-08-02 20:00:05 +02:00
Compare commits
11 Commits
v2.0.1
...
dependabot
Author | SHA1 | Date | |
---|---|---|---|
![]() |
7259093190 | ||
09663a35a5
|
|||
cea9885dde
|
|||
ef3070bdb7
|
|||
3ec373077c
|
|||
d81e8e9fb8
|
|||
2b23424b86
|
|||
783511ce12 | |||
411fa7ff39 | |||
c2f45abf0f | |||
5edcdf96f7 |
2
example/dist/dist.css
vendored
2
example/dist/dist.css
vendored
@@ -1 +1 @@
|
|||||||
#mywidget{border:2px solid red}
|
#mywidget{border:2px solid red}#mywidget{color:#00f}
|
4
example/dist/dist.js
vendored
4
example/dist/dist.js
vendored
File diff suppressed because one or more lines are too long
1
example/dist/dist.js.map
vendored
Normal file
1
example/dist/dist.js.map
vendored
Normal file
File diff suppressed because one or more lines are too long
15
node_modules/.bin/sshpk-conv
generated
vendored
15
node_modules/.bin/sshpk-conv
generated
vendored
@@ -1,15 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
|
||||||
|
|
||||||
case `uname` in
|
|
||||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
if [ -x "$basedir/node" ]; then
|
|
||||||
"$basedir/node" "$basedir/../sshpk/bin/sshpk-conv" "$@"
|
|
||||||
ret=$?
|
|
||||||
else
|
|
||||||
node "$basedir/../sshpk/bin/sshpk-conv" "$@"
|
|
||||||
ret=$?
|
|
||||||
fi
|
|
||||||
exit $ret
|
|
17
node_modules/.bin/sshpk-conv.cmd
generated
vendored
17
node_modules/.bin/sshpk-conv.cmd
generated
vendored
@@ -1,17 +0,0 @@
|
|||||||
@ECHO off
|
|
||||||
SETLOCAL
|
|
||||||
CALL :find_dp0
|
|
||||||
|
|
||||||
IF EXIST "%dp0%\node.exe" (
|
|
||||||
SET "_prog=%dp0%\node.exe"
|
|
||||||
) ELSE (
|
|
||||||
SET "_prog=node"
|
|
||||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
|
||||||
)
|
|
||||||
|
|
||||||
"%_prog%" "%dp0%\..\sshpk\bin\sshpk-conv" %*
|
|
||||||
ENDLOCAL
|
|
||||||
EXIT /b %errorlevel%
|
|
||||||
:find_dp0
|
|
||||||
SET dp0=%~dp0
|
|
||||||
EXIT /b
|
|
18
node_modules/.bin/sshpk-conv.ps1
generated
vendored
18
node_modules/.bin/sshpk-conv.ps1
generated
vendored
@@ -1,18 +0,0 @@
|
|||||||
#!/usr/bin/env pwsh
|
|
||||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
|
||||||
|
|
||||||
$exe=""
|
|
||||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
|
||||||
# Fix case when both the Windows and Linux builds of Node
|
|
||||||
# are installed in the same directory
|
|
||||||
$exe=".exe"
|
|
||||||
}
|
|
||||||
$ret=0
|
|
||||||
if (Test-Path "$basedir/node$exe") {
|
|
||||||
& "$basedir/node$exe" "$basedir/../sshpk/bin/sshpk-conv" $args
|
|
||||||
$ret=$LASTEXITCODE
|
|
||||||
} else {
|
|
||||||
& "node$exe" "$basedir/../sshpk/bin/sshpk-conv" $args
|
|
||||||
$ret=$LASTEXITCODE
|
|
||||||
}
|
|
||||||
exit $ret
|
|
15
node_modules/.bin/sshpk-sign
generated
vendored
15
node_modules/.bin/sshpk-sign
generated
vendored
@@ -1,15 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
|
||||||
|
|
||||||
case `uname` in
|
|
||||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
if [ -x "$basedir/node" ]; then
|
|
||||||
"$basedir/node" "$basedir/../sshpk/bin/sshpk-sign" "$@"
|
|
||||||
ret=$?
|
|
||||||
else
|
|
||||||
node "$basedir/../sshpk/bin/sshpk-sign" "$@"
|
|
||||||
ret=$?
|
|
||||||
fi
|
|
||||||
exit $ret
|
|
17
node_modules/.bin/sshpk-sign.cmd
generated
vendored
17
node_modules/.bin/sshpk-sign.cmd
generated
vendored
@@ -1,17 +0,0 @@
|
|||||||
@ECHO off
|
|
||||||
SETLOCAL
|
|
||||||
CALL :find_dp0
|
|
||||||
|
|
||||||
IF EXIST "%dp0%\node.exe" (
|
|
||||||
SET "_prog=%dp0%\node.exe"
|
|
||||||
) ELSE (
|
|
||||||
SET "_prog=node"
|
|
||||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
|
||||||
)
|
|
||||||
|
|
||||||
"%_prog%" "%dp0%\..\sshpk\bin\sshpk-sign" %*
|
|
||||||
ENDLOCAL
|
|
||||||
EXIT /b %errorlevel%
|
|
||||||
:find_dp0
|
|
||||||
SET dp0=%~dp0
|
|
||||||
EXIT /b
|
|
18
node_modules/.bin/sshpk-sign.ps1
generated
vendored
18
node_modules/.bin/sshpk-sign.ps1
generated
vendored
@@ -1,18 +0,0 @@
|
|||||||
#!/usr/bin/env pwsh
|
|
||||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
|
||||||
|
|
||||||
$exe=""
|
|
||||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
|
||||||
# Fix case when both the Windows and Linux builds of Node
|
|
||||||
# are installed in the same directory
|
|
||||||
$exe=".exe"
|
|
||||||
}
|
|
||||||
$ret=0
|
|
||||||
if (Test-Path "$basedir/node$exe") {
|
|
||||||
& "$basedir/node$exe" "$basedir/../sshpk/bin/sshpk-sign" $args
|
|
||||||
$ret=$LASTEXITCODE
|
|
||||||
} else {
|
|
||||||
& "node$exe" "$basedir/../sshpk/bin/sshpk-sign" $args
|
|
||||||
$ret=$LASTEXITCODE
|
|
||||||
}
|
|
||||||
exit $ret
|
|
15
node_modules/.bin/sshpk-verify
generated
vendored
15
node_modules/.bin/sshpk-verify
generated
vendored
@@ -1,15 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
|
||||||
|
|
||||||
case `uname` in
|
|
||||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
if [ -x "$basedir/node" ]; then
|
|
||||||
"$basedir/node" "$basedir/../sshpk/bin/sshpk-verify" "$@"
|
|
||||||
ret=$?
|
|
||||||
else
|
|
||||||
node "$basedir/../sshpk/bin/sshpk-verify" "$@"
|
|
||||||
ret=$?
|
|
||||||
fi
|
|
||||||
exit $ret
|
|
17
node_modules/.bin/sshpk-verify.cmd
generated
vendored
17
node_modules/.bin/sshpk-verify.cmd
generated
vendored
@@ -1,17 +0,0 @@
|
|||||||
@ECHO off
|
|
||||||
SETLOCAL
|
|
||||||
CALL :find_dp0
|
|
||||||
|
|
||||||
IF EXIST "%dp0%\node.exe" (
|
|
||||||
SET "_prog=%dp0%\node.exe"
|
|
||||||
) ELSE (
|
|
||||||
SET "_prog=node"
|
|
||||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
|
||||||
)
|
|
||||||
|
|
||||||
"%_prog%" "%dp0%\..\sshpk\bin\sshpk-verify" %*
|
|
||||||
ENDLOCAL
|
|
||||||
EXIT /b %errorlevel%
|
|
||||||
:find_dp0
|
|
||||||
SET dp0=%~dp0
|
|
||||||
EXIT /b
|
|
18
node_modules/.bin/sshpk-verify.ps1
generated
vendored
18
node_modules/.bin/sshpk-verify.ps1
generated
vendored
@@ -1,18 +0,0 @@
|
|||||||
#!/usr/bin/env pwsh
|
|
||||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
|
||||||
|
|
||||||
$exe=""
|
|
||||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
|
||||||
# Fix case when both the Windows and Linux builds of Node
|
|
||||||
# are installed in the same directory
|
|
||||||
$exe=".exe"
|
|
||||||
}
|
|
||||||
$ret=0
|
|
||||||
if (Test-Path "$basedir/node$exe") {
|
|
||||||
& "$basedir/node$exe" "$basedir/../sshpk/bin/sshpk-verify" $args
|
|
||||||
$ret=$LASTEXITCODE
|
|
||||||
} else {
|
|
||||||
& "node$exe" "$basedir/../sshpk/bin/sshpk-verify" $args
|
|
||||||
$ret=$LASTEXITCODE
|
|
||||||
}
|
|
||||||
exit $ret
|
|
15
node_modules/.bin/uuid
generated
vendored
15
node_modules/.bin/uuid
generated
vendored
@@ -1,15 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
|
||||||
|
|
||||||
case `uname` in
|
|
||||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
if [ -x "$basedir/node" ]; then
|
|
||||||
"$basedir/node" "$basedir/../uuid/bin/uuid" "$@"
|
|
||||||
ret=$?
|
|
||||||
else
|
|
||||||
node "$basedir/../uuid/bin/uuid" "$@"
|
|
||||||
ret=$?
|
|
||||||
fi
|
|
||||||
exit $ret
|
|
14
node_modules/@tootallnate/once/dist/index.d.ts
generated
vendored
Normal file
14
node_modules/@tootallnate/once/dist/index.d.ts
generated
vendored
Normal file
@@ -0,0 +1,14 @@
|
|||||||
|
/// <reference types="node" />
|
||||||
|
import { EventEmitter } from 'events';
|
||||||
|
declare function once<T>(emitter: EventEmitter, name: string): once.CancelablePromise<T>;
|
||||||
|
declare namespace once {
|
||||||
|
interface CancelFunction {
|
||||||
|
(): void;
|
||||||
|
}
|
||||||
|
interface CancelablePromise<T> extends Promise<T> {
|
||||||
|
cancel: CancelFunction;
|
||||||
|
}
|
||||||
|
type CancellablePromise<T> = CancelablePromise<T>;
|
||||||
|
function spread<T extends any[]>(emitter: EventEmitter, name: string): once.CancelablePromise<T>;
|
||||||
|
}
|
||||||
|
export = once;
|
39
node_modules/@tootallnate/once/dist/index.js
generated
vendored
Normal file
39
node_modules/@tootallnate/once/dist/index.js
generated
vendored
Normal file
@@ -0,0 +1,39 @@
|
|||||||
|
"use strict";
|
||||||
|
function noop() { }
|
||||||
|
function once(emitter, name) {
|
||||||
|
const o = once.spread(emitter, name);
|
||||||
|
const r = o.then((args) => args[0]);
|
||||||
|
r.cancel = o.cancel;
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
(function (once) {
|
||||||
|
function spread(emitter, name) {
|
||||||
|
let c = null;
|
||||||
|
const p = new Promise((resolve, reject) => {
|
||||||
|
function cancel() {
|
||||||
|
emitter.removeListener(name, onEvent);
|
||||||
|
emitter.removeListener('error', onError);
|
||||||
|
p.cancel = noop;
|
||||||
|
}
|
||||||
|
function onEvent(...args) {
|
||||||
|
cancel();
|
||||||
|
resolve(args);
|
||||||
|
}
|
||||||
|
function onError(err) {
|
||||||
|
cancel();
|
||||||
|
reject(err);
|
||||||
|
}
|
||||||
|
c = cancel;
|
||||||
|
emitter.on(name, onEvent);
|
||||||
|
emitter.on('error', onError);
|
||||||
|
});
|
||||||
|
if (!c) {
|
||||||
|
throw new TypeError('Could not get `cancel()` function');
|
||||||
|
}
|
||||||
|
p.cancel = c;
|
||||||
|
return p;
|
||||||
|
}
|
||||||
|
once.spread = spread;
|
||||||
|
})(once || (once = {}));
|
||||||
|
module.exports = once;
|
||||||
|
//# sourceMappingURL=index.js.map
|
1
node_modules/@tootallnate/once/dist/index.js.map
generated
vendored
Normal file
1
node_modules/@tootallnate/once/dist/index.js.map
generated
vendored
Normal file
@@ -0,0 +1 @@
|
|||||||
|
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";AAEA,SAAS,IAAI,KAAI,CAAC;AAElB,SAAS,IAAI,CACZ,OAAqB,EACrB,IAAY;IAEZ,MAAM,CAAC,GAAG,IAAI,CAAC,MAAM,CAAM,OAAO,EAAE,IAAI,CAAC,CAAC;IAC1C,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAA8B,CAAC;IACtE,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,MAAM,CAAC;IACpB,OAAO,CAAC,CAAC;AACV,CAAC;AAED,WAAU,IAAI;IAWb,SAAgB,MAAM,CACrB,OAAqB,EACrB,IAAY;QAEZ,IAAI,CAAC,GAA+B,IAAI,CAAC;QACzC,MAAM,CAAC,GAAG,IAAI,OAAO,CAAI,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YAC5C,SAAS,MAAM;gBACd,OAAO,CAAC,cAAc,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;gBACtC,OAAO,CAAC,cAAc,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;gBACzC,CAAC,CAAC,MAAM,GAAG,IAAI,CAAC;YACjB,CAAC;YACD,SAAS,OAAO,CAAC,GAAG,IAAW;gBAC9B,MAAM,EAAE,CAAC;gBACT,OAAO,CAAC,IAAS,CAAC,CAAC;YACpB,CAAC;YACD,SAAS,OAAO,CAAC,GAAU;gBAC1B,MAAM,EAAE,CAAC;gBACT,MAAM,CAAC,GAAG,CAAC,CAAC;YACb,CAAC;YACD,CAAC,GAAG,MAAM,CAAC;YACX,OAAO,CAAC,EAAE,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;YAC1B,OAAO,CAAC,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;QAC9B,CAAC,CAA8B,CAAC;QAChC,IAAI,CAAC,CAAC,EAAE;YACP,MAAM,IAAI,SAAS,CAAC,mCAAmC,CAAC,CAAC;SACzD;QACD,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC;QACb,OAAO,CAAC,CAAC;IACV,CAAC;IA5Be,WAAM,SA4BrB,CAAA;AACF,CAAC,EAxCS,IAAI,KAAJ,IAAI,QAwCb;AAED,iBAAS,IAAI,CAAC"}
|
76
node_modules/@tootallnate/once/package.json
generated
vendored
Normal file
76
node_modules/@tootallnate/once/package.json
generated
vendored
Normal file
@@ -0,0 +1,76 @@
|
|||||||
|
{
|
||||||
|
"_from": "@tootallnate/once@1",
|
||||||
|
"_id": "@tootallnate/once@1.1.2",
|
||||||
|
"_inBundle": false,
|
||||||
|
"_integrity": "sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==",
|
||||||
|
"_location": "/@tootallnate/once",
|
||||||
|
"_phantomChildren": {},
|
||||||
|
"_requested": {
|
||||||
|
"type": "range",
|
||||||
|
"registry": true,
|
||||||
|
"raw": "@tootallnate/once@1",
|
||||||
|
"name": "@tootallnate/once",
|
||||||
|
"escapedName": "@tootallnate%2fonce",
|
||||||
|
"scope": "@tootallnate",
|
||||||
|
"rawSpec": "1",
|
||||||
|
"saveSpec": null,
|
||||||
|
"fetchSpec": "1"
|
||||||
|
},
|
||||||
|
"_requiredBy": [
|
||||||
|
"/http-proxy-agent"
|
||||||
|
],
|
||||||
|
"_resolved": "https://registry.npmjs.org/@tootallnate/once/-/once-1.1.2.tgz",
|
||||||
|
"_shasum": "ccb91445360179a04e7fe6aff78c00ffc1eeaf82",
|
||||||
|
"_spec": "@tootallnate/once@1",
|
||||||
|
"_where": "D:\\Projects\\minifyfromhtml\\node_modules\\http-proxy-agent",
|
||||||
|
"author": {
|
||||||
|
"name": "Nathan Rajlich",
|
||||||
|
"email": "nathan@tootallnate.net",
|
||||||
|
"url": "http://n8.io/"
|
||||||
|
},
|
||||||
|
"bugs": {
|
||||||
|
"url": "https://github.com/TooTallNate/once/issues"
|
||||||
|
},
|
||||||
|
"bundleDependencies": false,
|
||||||
|
"deprecated": false,
|
||||||
|
"description": "Creates a Promise that waits for a single event",
|
||||||
|
"devDependencies": {
|
||||||
|
"@types/node": "^12.12.11",
|
||||||
|
"@typescript-eslint/eslint-plugin": "1.6.0",
|
||||||
|
"@typescript-eslint/parser": "1.1.0",
|
||||||
|
"eslint": "5.16.0",
|
||||||
|
"eslint-config-airbnb": "17.1.0",
|
||||||
|
"eslint-config-prettier": "4.1.0",
|
||||||
|
"eslint-import-resolver-typescript": "1.1.1",
|
||||||
|
"eslint-plugin-import": "2.16.0",
|
||||||
|
"eslint-plugin-jsx-a11y": "6.2.1",
|
||||||
|
"eslint-plugin-react": "7.12.4",
|
||||||
|
"mocha": "^6.2.2",
|
||||||
|
"rimraf": "^3.0.0",
|
||||||
|
"typescript": "^3.7.3"
|
||||||
|
},
|
||||||
|
"engines": {
|
||||||
|
"node": ">= 6"
|
||||||
|
},
|
||||||
|
"files": [
|
||||||
|
"dist"
|
||||||
|
],
|
||||||
|
"homepage": "https://github.com/TooTallNate/once#readme",
|
||||||
|
"keywords": [],
|
||||||
|
"license": "MIT",
|
||||||
|
"main": "./dist/index.js",
|
||||||
|
"name": "@tootallnate/once",
|
||||||
|
"repository": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "git://github.com/TooTallNate/once.git"
|
||||||
|
},
|
||||||
|
"scripts": {
|
||||||
|
"build": "tsc",
|
||||||
|
"prebuild": "rimraf dist",
|
||||||
|
"prepublishOnly": "npm run build",
|
||||||
|
"test": "mocha --reporter spec",
|
||||||
|
"test-lint": "eslint src --ext .js,.ts"
|
||||||
|
},
|
||||||
|
"types": "./dist/index.d.ts",
|
||||||
|
"version": "1.1.2"
|
||||||
|
}
|
9
node_modules/abab/CHANGELOG.md
generated
vendored
9
node_modules/abab/CHANGELOG.md
generated
vendored
@@ -1,3 +1,12 @@
|
|||||||
|
## 2.0.5
|
||||||
|
|
||||||
|
- Use a lookup string in atobLookup and btoaLookup (@GiovanniFrigo in #38)
|
||||||
|
- Dependency updates
|
||||||
|
|
||||||
|
## 2.0.4
|
||||||
|
|
||||||
|
- Dependency updates
|
||||||
|
|
||||||
## 2.0.3
|
## 2.0.3
|
||||||
|
|
||||||
- Use standard wording for BSD-3-Clause license (@PhilippWendler)
|
- Use standard wording for BSD-3-Clause license (@PhilippWendler)
|
||||||
|
11
node_modules/abab/README.md
generated
vendored
11
node_modules/abab/README.md
generated
vendored
@@ -39,12 +39,13 @@ const atob = require('abab/lib/atob');
|
|||||||
const btoa = require('abab/lib/btoa');
|
const btoa = require('abab/lib/btoa');
|
||||||
```
|
```
|
||||||
|
|
||||||
-----
|
## Development
|
||||||
|
|
||||||
### Checklists
|
If you're **submitting a PR** or **deploying to npm**, please use the [checklists in CONTRIBUTING.md](CONTRIBUTING.md#checklists).
|
||||||
|
|
||||||
If you're **submitting a PR** or **deploying to npm**, please use the [checklists in CONTRIBUTING.md](https://github.com/jsdom/abab/blob/master/CONTRIBUTING.md#checklists)
|
## Remembering what `atob` and `btoa` stand for
|
||||||
|
|
||||||
### Remembering `atob` vs. `btoa`
|
Base64 comes from IETF [RFC 4648](https://tools.ietf.org/html/rfc4648#section-4) (2006).
|
||||||
|
|
||||||
Here's a mnemonic that might be useful: if you have a plain string and want to base64 encode it, then decode it, `btoa` is what you run before (**b**efore - **b**toa), and `atob` is what you run after (**a**fter - **a**tob).
|
- **`btoa`**, the encoder function, stands for **binary** to **ASCII**, meaning it converts any binary input into a subset of **ASCII** (Base64).
|
||||||
|
- **`atob`**, the decoder function, converts **ASCII** (or Base64) to its original **binary** format.
|
||||||
|
24
node_modules/abab/lib/atob.js
generated
vendored
24
node_modules/abab/lib/atob.js
generated
vendored
@@ -84,24 +84,14 @@ function atob(data) {
|
|||||||
* A lookup table for atob(), which converts an ASCII character to the
|
* A lookup table for atob(), which converts an ASCII character to the
|
||||||
* corresponding six-bit number.
|
* corresponding six-bit number.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
const keystr =
|
||||||
|
"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
|
||||||
|
|
||||||
function atobLookup(chr) {
|
function atobLookup(chr) {
|
||||||
if (/[A-Z]/.test(chr)) {
|
const index = keystr.indexOf(chr);
|
||||||
return chr.charCodeAt(0) - "A".charCodeAt(0);
|
// Throw exception if character is not in the lookup string; should not be hit in tests
|
||||||
}
|
return index < 0 ? undefined : index;
|
||||||
if (/[a-z]/.test(chr)) {
|
|
||||||
return chr.charCodeAt(0) - "a".charCodeAt(0) + 26;
|
|
||||||
}
|
|
||||||
if (/[0-9]/.test(chr)) {
|
|
||||||
return chr.charCodeAt(0) - "0".charCodeAt(0) + 52;
|
|
||||||
}
|
|
||||||
if (chr === "+") {
|
|
||||||
return 62;
|
|
||||||
}
|
|
||||||
if (chr === "/") {
|
|
||||||
return 63;
|
|
||||||
}
|
|
||||||
// Throw exception; should not be hit in tests
|
|
||||||
return undefined;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
module.exports = atob;
|
module.exports = atob;
|
||||||
|
22
node_modules/abab/lib/btoa.js
generated
vendored
22
node_modules/abab/lib/btoa.js
generated
vendored
@@ -43,22 +43,14 @@ function btoa(s) {
|
|||||||
* Lookup table for btoa(), which converts a six-bit number into the
|
* Lookup table for btoa(), which converts a six-bit number into the
|
||||||
* corresponding ASCII character.
|
* corresponding ASCII character.
|
||||||
*/
|
*/
|
||||||
function btoaLookup(idx) {
|
const keystr =
|
||||||
if (idx < 26) {
|
"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/";
|
||||||
return String.fromCharCode(idx + "A".charCodeAt(0));
|
|
||||||
}
|
function btoaLookup(index) {
|
||||||
if (idx < 52) {
|
if (index >= 0 && index < 64) {
|
||||||
return String.fromCharCode(idx - 26 + "a".charCodeAt(0));
|
return keystr[index];
|
||||||
}
|
|
||||||
if (idx < 62) {
|
|
||||||
return String.fromCharCode(idx - 52 + "0".charCodeAt(0));
|
|
||||||
}
|
|
||||||
if (idx === 62) {
|
|
||||||
return "+";
|
|
||||||
}
|
|
||||||
if (idx === 63) {
|
|
||||||
return "/";
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Throw INVALID_CHARACTER_ERR exception here -- won't be hit in the tests.
|
// Throw INVALID_CHARACTER_ERR exception here -- won't be hit in the tests.
|
||||||
return undefined;
|
return undefined;
|
||||||
}
|
}
|
||||||
|
22
node_modules/abab/package.json
generated
vendored
22
node_modules/abab/package.json
generated
vendored
@@ -1,28 +1,28 @@
|
|||||||
{
|
{
|
||||||
"_from": "abab@^2.0.0",
|
"_from": "abab@^2.0.5",
|
||||||
"_id": "abab@2.0.3",
|
"_id": "abab@2.0.5",
|
||||||
"_inBundle": false,
|
"_inBundle": false,
|
||||||
"_integrity": "sha512-tsFzPpcttalNjFBCFMqsKYQcWxxen1pgJR56by//QwvJc4/OUS3kPOOttx2tSIfjsylB0pYu7f5D3K1RCxUnUg==",
|
"_integrity": "sha512-9IK9EadsbHo6jLWIpxpR6pL0sazTXV6+SQv25ZB+F7Bj9mJNaOc4nCRabwd5M/JwmUa8idz6Eci6eKfJryPs6Q==",
|
||||||
"_location": "/abab",
|
"_location": "/abab",
|
||||||
"_phantomChildren": {},
|
"_phantomChildren": {},
|
||||||
"_requested": {
|
"_requested": {
|
||||||
"type": "range",
|
"type": "range",
|
||||||
"registry": true,
|
"registry": true,
|
||||||
"raw": "abab@^2.0.0",
|
"raw": "abab@^2.0.5",
|
||||||
"name": "abab",
|
"name": "abab",
|
||||||
"escapedName": "abab",
|
"escapedName": "abab",
|
||||||
"rawSpec": "^2.0.0",
|
"rawSpec": "^2.0.5",
|
||||||
"saveSpec": null,
|
"saveSpec": null,
|
||||||
"fetchSpec": "^2.0.0"
|
"fetchSpec": "^2.0.5"
|
||||||
},
|
},
|
||||||
"_requiredBy": [
|
"_requiredBy": [
|
||||||
"/data-urls",
|
"/data-urls",
|
||||||
"/jsdom"
|
"/jsdom"
|
||||||
],
|
],
|
||||||
"_resolved": "https://registry.npmjs.org/abab/-/abab-2.0.3.tgz",
|
"_resolved": "https://registry.npmjs.org/abab/-/abab-2.0.5.tgz",
|
||||||
"_shasum": "623e2075e02eb2d3f2475e49f99c91846467907a",
|
"_shasum": "c0b678fb32d60fc1219c784d6a826fe385aeb79a",
|
||||||
"_spec": "abab@^2.0.0",
|
"_spec": "abab@^2.0.5",
|
||||||
"_where": "F:\\projects\\p\\minifyfromhtml\\node_modules\\jsdom",
|
"_where": "D:\\Projects\\minifyfromhtml\\node_modules\\jsdom",
|
||||||
"author": {
|
"author": {
|
||||||
"name": "Jeff Carpenter",
|
"name": "Jeff Carpenter",
|
||||||
"email": "gcarpenterv@gmail.com"
|
"email": "gcarpenterv@gmail.com"
|
||||||
@@ -67,5 +67,5 @@
|
|||||||
"mocha": "mocha test/node",
|
"mocha": "mocha test/node",
|
||||||
"test": "npm run lint && npm run mocha && npm run karma"
|
"test": "npm run lint && npm run mocha && npm run karma"
|
||||||
},
|
},
|
||||||
"version": "2.0.3"
|
"version": "2.0.5"
|
||||||
}
|
}
|
||||||
|
15
node_modules/acorn-globals/node_modules/.bin/acorn
generated
vendored
Normal file
15
node_modules/acorn-globals/node_modules/.bin/acorn
generated
vendored
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||||
|
|
||||||
|
case `uname` in
|
||||||
|
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||||
|
esac
|
||||||
|
|
||||||
|
if [ -x "$basedir/node" ]; then
|
||||||
|
"$basedir/node" "$basedir/../acorn/bin/acorn" "$@"
|
||||||
|
ret=$?
|
||||||
|
else
|
||||||
|
node "$basedir/../acorn/bin/acorn" "$@"
|
||||||
|
ret=$?
|
||||||
|
fi
|
||||||
|
exit $ret
|
2
node_modules/.bin/uuid.cmd → node_modules/acorn-globals/node_modules/.bin/acorn.cmd
generated
vendored
2
node_modules/.bin/uuid.cmd → node_modules/acorn-globals/node_modules/.bin/acorn.cmd
generated
vendored
@@ -9,7 +9,7 @@ IF EXIST "%dp0%\node.exe" (
|
|||||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||||
)
|
)
|
||||||
|
|
||||||
"%_prog%" "%dp0%\..\uuid\bin\uuid" %*
|
"%_prog%" "%dp0%\..\acorn\bin\acorn" %*
|
||||||
ENDLOCAL
|
ENDLOCAL
|
||||||
EXIT /b %errorlevel%
|
EXIT /b %errorlevel%
|
||||||
:find_dp0
|
:find_dp0
|
4
node_modules/.bin/uuid.ps1 → node_modules/acorn-globals/node_modules/.bin/acorn.ps1
generated
vendored
4
node_modules/.bin/uuid.ps1 → node_modules/acorn-globals/node_modules/.bin/acorn.ps1
generated
vendored
@@ -9,10 +9,10 @@ if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
|||||||
}
|
}
|
||||||
$ret=0
|
$ret=0
|
||||||
if (Test-Path "$basedir/node$exe") {
|
if (Test-Path "$basedir/node$exe") {
|
||||||
& "$basedir/node$exe" "$basedir/../uuid/bin/uuid" $args
|
& "$basedir/node$exe" "$basedir/../acorn/bin/acorn" $args
|
||||||
$ret=$LASTEXITCODE
|
$ret=$LASTEXITCODE
|
||||||
} else {
|
} else {
|
||||||
& "node$exe" "$basedir/../uuid/bin/uuid" $args
|
& "node$exe" "$basedir/../acorn/bin/acorn" $args
|
||||||
$ret=$LASTEXITCODE
|
$ret=$LASTEXITCODE
|
||||||
}
|
}
|
||||||
exit $ret
|
exit $ret
|
620
node_modules/acorn-globals/node_modules/acorn/CHANGELOG.md
generated
vendored
Normal file
620
node_modules/acorn-globals/node_modules/acorn/CHANGELOG.md
generated
vendored
Normal file
@@ -0,0 +1,620 @@
|
|||||||
|
## 7.4.0 (2020-08-03)
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
Add support for logical assignment operators.
|
||||||
|
|
||||||
|
Add support for numeric separators.
|
||||||
|
|
||||||
|
## 7.3.1 (2020-06-11)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Make the string in the `version` export match the actual library version.
|
||||||
|
|
||||||
|
## 7.3.0 (2020-06-11)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix a bug that caused parsing of object patterns with a property named `set` that had a default value to fail.
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
Add support for optional chaining (`?.`).
|
||||||
|
|
||||||
|
## 7.2.0 (2020-05-09)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix precedence issue in parsing of async arrow functions.
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
Add support for nullish coalescing.
|
||||||
|
|
||||||
|
Add support for `import.meta`.
|
||||||
|
|
||||||
|
Support `export * as ...` syntax.
|
||||||
|
|
||||||
|
Upgrade to Unicode 13.
|
||||||
|
|
||||||
|
## 6.4.1 (2020-03-09)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
More carefully check for valid UTF16 surrogate pairs in regexp validator.
|
||||||
|
|
||||||
|
## 7.1.1 (2020-03-01)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Treat `\8` and `\9` as invalid escapes in template strings.
|
||||||
|
|
||||||
|
Allow unicode escapes in property names that are keywords.
|
||||||
|
|
||||||
|
Don't error on an exponential operator expression as argument to `await`.
|
||||||
|
|
||||||
|
More carefully check for valid UTF16 surrogate pairs in regexp validator.
|
||||||
|
|
||||||
|
## 7.1.0 (2019-09-24)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Disallow trailing object literal commas when ecmaVersion is less than 5.
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
Add a static `acorn` property to the `Parser` class that contains the entire module interface, to allow plugins to access the instance of the library that they are acting on.
|
||||||
|
|
||||||
|
## 7.0.0 (2019-08-13)
|
||||||
|
|
||||||
|
### Breaking changes
|
||||||
|
|
||||||
|
Changes the node format for dynamic imports to use the `ImportExpression` node type, as defined in [ESTree](https://github.com/estree/estree/blob/master/es2020.md#importexpression).
|
||||||
|
|
||||||
|
Makes 10 (ES2019) the default value for the `ecmaVersion` option.
|
||||||
|
|
||||||
|
## 6.3.0 (2019-08-12)
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
`sourceType: "module"` can now be used even when `ecmaVersion` is less than 6, to parse module-style code that otherwise conforms to an older standard.
|
||||||
|
|
||||||
|
## 6.2.1 (2019-07-21)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix bug causing Acorn to treat some characters as identifier characters that shouldn't be treated as such.
|
||||||
|
|
||||||
|
Fix issue where setting the `allowReserved` option to `"never"` allowed reserved words in some circumstances.
|
||||||
|
|
||||||
|
## 6.2.0 (2019-07-04)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Improve valid assignment checking in `for`/`in` and `for`/`of` loops.
|
||||||
|
|
||||||
|
Disallow binding `let` in patterns.
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
Support bigint syntax with `ecmaVersion` >= 11.
|
||||||
|
|
||||||
|
Support dynamic `import` syntax with `ecmaVersion` >= 11.
|
||||||
|
|
||||||
|
Upgrade to Unicode version 12.
|
||||||
|
|
||||||
|
## 6.1.1 (2019-02-27)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix bug that caused parsing default exports of with names to fail.
|
||||||
|
|
||||||
|
## 6.1.0 (2019-02-08)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix scope checking when redefining a `var` as a lexical binding.
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
Split up `parseSubscripts` to use an internal `parseSubscript` method to make it easier to extend with plugins.
|
||||||
|
|
||||||
|
## 6.0.7 (2019-02-04)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Check that exported bindings are defined.
|
||||||
|
|
||||||
|
Don't treat `\u180e` as a whitespace character.
|
||||||
|
|
||||||
|
Check for duplicate parameter names in methods.
|
||||||
|
|
||||||
|
Don't allow shorthand properties when they are generators or async methods.
|
||||||
|
|
||||||
|
Forbid binding `await` in async arrow function's parameter list.
|
||||||
|
|
||||||
|
## 6.0.6 (2019-01-30)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
The content of class declarations and expressions is now always parsed in strict mode.
|
||||||
|
|
||||||
|
Don't allow `let` or `const` to bind the variable name `let`.
|
||||||
|
|
||||||
|
Treat class declarations as lexical.
|
||||||
|
|
||||||
|
Don't allow a generator function declaration as the sole body of an `if` or `else`.
|
||||||
|
|
||||||
|
Ignore `"use strict"` when after an empty statement.
|
||||||
|
|
||||||
|
Allow string line continuations with special line terminator characters.
|
||||||
|
|
||||||
|
Treat `for` bodies as part of the `for` scope when checking for conflicting bindings.
|
||||||
|
|
||||||
|
Fix bug with parsing `yield` in a `for` loop initializer.
|
||||||
|
|
||||||
|
Implement special cases around scope checking for functions.
|
||||||
|
|
||||||
|
## 6.0.5 (2019-01-02)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix TypeScript type for `Parser.extend` and add `allowAwaitOutsideFunction` to options type.
|
||||||
|
|
||||||
|
Don't treat `let` as a keyword when the next token is `{` on the next line.
|
||||||
|
|
||||||
|
Fix bug that broke checking for parentheses around an object pattern in a destructuring assignment when `preserveParens` was on.
|
||||||
|
|
||||||
|
## 6.0.4 (2018-11-05)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Further improvements to tokenizing regular expressions in corner cases.
|
||||||
|
|
||||||
|
## 6.0.3 (2018-11-04)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix bug in tokenizing an expression-less return followed by a function followed by a regular expression.
|
||||||
|
|
||||||
|
Remove stray symlink in the package tarball.
|
||||||
|
|
||||||
|
## 6.0.2 (2018-09-26)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix bug where default expressions could fail to parse inside an object destructuring assignment expression.
|
||||||
|
|
||||||
|
## 6.0.1 (2018-09-14)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix wrong value in `version` export.
|
||||||
|
|
||||||
|
## 6.0.0 (2018-09-14)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Better handle variable-redefinition checks for catch bindings and functions directly under if statements.
|
||||||
|
|
||||||
|
Forbid `new.target` in top-level arrow functions.
|
||||||
|
|
||||||
|
Fix issue with parsing a regexp after `yield` in some contexts.
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
The package now comes with TypeScript definitions.
|
||||||
|
|
||||||
|
### Breaking changes
|
||||||
|
|
||||||
|
The default value of the `ecmaVersion` option is now 9 (2018).
|
||||||
|
|
||||||
|
Plugins work differently, and will have to be rewritten to work with this version.
|
||||||
|
|
||||||
|
The loose parser and walker have been moved into separate packages (`acorn-loose` and `acorn-walk`).
|
||||||
|
|
||||||
|
## 5.7.3 (2018-09-10)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix failure to tokenize regexps after expressions like `x.of`.
|
||||||
|
|
||||||
|
Better error message for unterminated template literals.
|
||||||
|
|
||||||
|
## 5.7.2 (2018-08-24)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Properly handle `allowAwaitOutsideFunction` in for statements.
|
||||||
|
|
||||||
|
Treat function declarations at the top level of modules like let bindings.
|
||||||
|
|
||||||
|
Don't allow async function declarations as the only statement under a label.
|
||||||
|
|
||||||
|
## 5.7.0 (2018-06-15)
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
Upgraded to Unicode 11.
|
||||||
|
|
||||||
|
## 5.6.0 (2018-05-31)
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
Allow U+2028 and U+2029 in string when ECMAVersion >= 10.
|
||||||
|
|
||||||
|
Allow binding-less catch statements when ECMAVersion >= 10.
|
||||||
|
|
||||||
|
Add `allowAwaitOutsideFunction` option for parsing top-level `await`.
|
||||||
|
|
||||||
|
## 5.5.3 (2018-03-08)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
A _second_ republish of the code in 5.5.1, this time with yarn, to hopefully get valid timestamps.
|
||||||
|
|
||||||
|
## 5.5.2 (2018-03-08)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
A republish of the code in 5.5.1 in an attempt to solve an issue with the file timestamps in the npm package being 0.
|
||||||
|
|
||||||
|
## 5.5.1 (2018-03-06)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix misleading error message for octal escapes in template strings.
|
||||||
|
|
||||||
|
## 5.5.0 (2018-02-27)
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
The identifier character categorization is now based on Unicode version 10.
|
||||||
|
|
||||||
|
Acorn will now validate the content of regular expressions, including new ES9 features.
|
||||||
|
|
||||||
|
## 5.4.0 (2018-02-01)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Disallow duplicate or escaped flags on regular expressions.
|
||||||
|
|
||||||
|
Disallow octal escapes in strings in strict mode.
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
Add support for async iteration.
|
||||||
|
|
||||||
|
Add support for object spread and rest.
|
||||||
|
|
||||||
|
## 5.3.0 (2017-12-28)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix parsing of floating point literals with leading zeroes in loose mode.
|
||||||
|
|
||||||
|
Allow duplicate property names in object patterns.
|
||||||
|
|
||||||
|
Don't allow static class methods named `prototype`.
|
||||||
|
|
||||||
|
Disallow async functions directly under `if` or `else`.
|
||||||
|
|
||||||
|
Parse right-hand-side of `for`/`of` as an assignment expression.
|
||||||
|
|
||||||
|
Stricter parsing of `for`/`in`.
|
||||||
|
|
||||||
|
Don't allow unicode escapes in contextual keywords.
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
Parsing class members was factored into smaller methods to allow plugins to hook into it.
|
||||||
|
|
||||||
|
## 5.2.1 (2017-10-30)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix a token context corruption bug.
|
||||||
|
|
||||||
|
## 5.2.0 (2017-10-30)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix token context tracking for `class` and `function` in property-name position.
|
||||||
|
|
||||||
|
Make sure `%*` isn't parsed as a valid operator.
|
||||||
|
|
||||||
|
Allow shorthand properties `get` and `set` to be followed by default values.
|
||||||
|
|
||||||
|
Disallow `super` when not in callee or object position.
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
Support [`directive` property](https://github.com/estree/estree/compare/b3de58c9997504d6fba04b72f76e6dd1619ee4eb...1da8e603237144f44710360f8feb7a9977e905e0) on directive expression statements.
|
||||||
|
|
||||||
|
## 5.1.2 (2017-09-04)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Disable parsing of legacy HTML-style comments in modules.
|
||||||
|
|
||||||
|
Fix parsing of async methods whose names are keywords.
|
||||||
|
|
||||||
|
## 5.1.1 (2017-07-06)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix problem with disambiguating regexp and division after a class.
|
||||||
|
|
||||||
|
## 5.1.0 (2017-07-05)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix tokenizing of regexps in an object-desctructuring `for`/`of` loop and after `yield`.
|
||||||
|
|
||||||
|
Parse zero-prefixed numbers with non-octal digits as decimal.
|
||||||
|
|
||||||
|
Allow object/array patterns in rest parameters.
|
||||||
|
|
||||||
|
Don't error when `yield` is used as a property name.
|
||||||
|
|
||||||
|
Allow `async` as a shorthand object property.
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
Implement the [template literal revision proposal](https://github.com/tc39/proposal-template-literal-revision) for ES9.
|
||||||
|
|
||||||
|
## 5.0.3 (2017-04-01)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix spurious duplicate variable definition errors for named functions.
|
||||||
|
|
||||||
|
## 5.0.2 (2017-03-30)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
A binary operator after a parenthesized arrow expression is no longer incorrectly treated as an error.
|
||||||
|
|
||||||
|
## 5.0.0 (2017-03-28)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Raise an error for duplicated lexical bindings.
|
||||||
|
|
||||||
|
Fix spurious error when an assignement expression occurred after a spread expression.
|
||||||
|
|
||||||
|
Accept regular expressions after `of` (in `for`/`of`), `yield` (in a generator), and braced arrow functions.
|
||||||
|
|
||||||
|
Allow labels in front or `var` declarations, even in strict mode.
|
||||||
|
|
||||||
|
### Breaking changes
|
||||||
|
|
||||||
|
Parse declarations following `export default` as declaration nodes, not expressions. This means that class and function declarations nodes can now have `null` as their `id`.
|
||||||
|
|
||||||
|
## 4.0.11 (2017-02-07)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Allow all forms of member expressions to be parenthesized as lvalue.
|
||||||
|
|
||||||
|
## 4.0.10 (2017-02-07)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Don't expect semicolons after default-exported functions or classes, even when they are expressions.
|
||||||
|
|
||||||
|
Check for use of `'use strict'` directives in non-simple parameter functions, even when already in strict mode.
|
||||||
|
|
||||||
|
## 4.0.9 (2017-02-06)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix incorrect error raised for parenthesized simple assignment targets, so that `(x) = 1` parses again.
|
||||||
|
|
||||||
|
## 4.0.8 (2017-02-03)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Solve spurious parenthesized pattern errors by temporarily erring on the side of accepting programs that our delayed errors don't handle correctly yet.
|
||||||
|
|
||||||
|
## 4.0.7 (2017-02-02)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Accept invalidly rejected code like `(x).y = 2` again.
|
||||||
|
|
||||||
|
Don't raise an error when a function _inside_ strict code has a non-simple parameter list.
|
||||||
|
|
||||||
|
## 4.0.6 (2017-02-02)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix exponential behavior (manifesting itself as a complete hang for even relatively small source files) introduced by the new 'use strict' check.
|
||||||
|
|
||||||
|
## 4.0.5 (2017-02-02)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Disallow parenthesized pattern expressions.
|
||||||
|
|
||||||
|
Allow keywords as export names.
|
||||||
|
|
||||||
|
Don't allow the `async` keyword to be parenthesized.
|
||||||
|
|
||||||
|
Properly raise an error when a keyword contains a character escape.
|
||||||
|
|
||||||
|
Allow `"use strict"` to appear after other string literal expressions.
|
||||||
|
|
||||||
|
Disallow labeled declarations.
|
||||||
|
|
||||||
|
## 4.0.4 (2016-12-19)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix crash when `export` was followed by a keyword that can't be
|
||||||
|
exported.
|
||||||
|
|
||||||
|
## 4.0.3 (2016-08-16)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Allow regular function declarations inside single-statement `if` branches in loose mode. Forbid them entirely in strict mode.
|
||||||
|
|
||||||
|
Properly parse properties named `async` in ES2017 mode.
|
||||||
|
|
||||||
|
Fix bug where reserved words were broken in ES2017 mode.
|
||||||
|
|
||||||
|
## 4.0.2 (2016-08-11)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Don't ignore period or 'e' characters after octal numbers.
|
||||||
|
|
||||||
|
Fix broken parsing for call expressions in default parameter values of arrow functions.
|
||||||
|
|
||||||
|
## 4.0.1 (2016-08-08)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix false positives in duplicated export name errors.
|
||||||
|
|
||||||
|
## 4.0.0 (2016-08-07)
|
||||||
|
|
||||||
|
### Breaking changes
|
||||||
|
|
||||||
|
The default `ecmaVersion` option value is now 7.
|
||||||
|
|
||||||
|
A number of internal method signatures changed, so plugins might need to be updated.
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
The parser now raises errors on duplicated export names.
|
||||||
|
|
||||||
|
`arguments` and `eval` can now be used in shorthand properties.
|
||||||
|
|
||||||
|
Duplicate parameter names in non-simple argument lists now always produce an error.
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
The `ecmaVersion` option now also accepts year-style version numbers
|
||||||
|
(2015, etc).
|
||||||
|
|
||||||
|
Support for `async`/`await` syntax when `ecmaVersion` is >= 8.
|
||||||
|
|
||||||
|
Support for trailing commas in call expressions when `ecmaVersion` is >= 8.
|
||||||
|
|
||||||
|
## 3.3.0 (2016-07-25)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix bug in tokenizing of regexp operator after a function declaration.
|
||||||
|
|
||||||
|
Fix parser crash when parsing an array pattern with a hole.
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
Implement check against complex argument lists in functions that enable strict mode in ES7.
|
||||||
|
|
||||||
|
## 3.2.0 (2016-06-07)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Improve handling of lack of unicode regexp support in host
|
||||||
|
environment.
|
||||||
|
|
||||||
|
Properly reject shorthand properties whose name is a keyword.
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
Visitors created with `visit.make` now have their base as _prototype_, rather than copying properties into a fresh object.
|
||||||
|
|
||||||
|
## 3.1.0 (2016-04-18)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Properly tokenize the division operator directly after a function expression.
|
||||||
|
|
||||||
|
Allow trailing comma in destructuring arrays.
|
||||||
|
|
||||||
|
## 3.0.4 (2016-02-25)
|
||||||
|
|
||||||
|
### Fixes
|
||||||
|
|
||||||
|
Allow update expressions as left-hand-side of the ES7 exponential operator.
|
||||||
|
|
||||||
|
## 3.0.2 (2016-02-10)
|
||||||
|
|
||||||
|
### Fixes
|
||||||
|
|
||||||
|
Fix bug that accidentally made `undefined` a reserved word when parsing ES7.
|
||||||
|
|
||||||
|
## 3.0.0 (2016-02-10)
|
||||||
|
|
||||||
|
### Breaking changes
|
||||||
|
|
||||||
|
The default value of the `ecmaVersion` option is now 6 (used to be 5).
|
||||||
|
|
||||||
|
Support for comprehension syntax (which was dropped from the draft spec) has been removed.
|
||||||
|
|
||||||
|
### Fixes
|
||||||
|
|
||||||
|
`let` and `yield` are now “contextual keywords”, meaning you can mostly use them as identifiers in ES5 non-strict code.
|
||||||
|
|
||||||
|
A parenthesized class or function expression after `export default` is now parsed correctly.
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
When `ecmaVersion` is set to 7, Acorn will parse the exponentiation operator (`**`).
|
||||||
|
|
||||||
|
The identifier character ranges are now based on Unicode 8.0.0.
|
||||||
|
|
||||||
|
Plugins can now override the `raiseRecoverable` method to override the way non-critical errors are handled.
|
||||||
|
|
||||||
|
## 2.7.0 (2016-01-04)
|
||||||
|
|
||||||
|
### Fixes
|
||||||
|
|
||||||
|
Stop allowing rest parameters in setters.
|
||||||
|
|
||||||
|
Disallow `y` rexexp flag in ES5.
|
||||||
|
|
||||||
|
Disallow `\00` and `\000` escapes in strict mode.
|
||||||
|
|
||||||
|
Raise an error when an import name is a reserved word.
|
||||||
|
|
||||||
|
## 2.6.2 (2015-11-10)
|
||||||
|
|
||||||
|
### Fixes
|
||||||
|
|
||||||
|
Don't crash when no options object is passed.
|
||||||
|
|
||||||
|
## 2.6.0 (2015-11-09)
|
||||||
|
|
||||||
|
### Fixes
|
||||||
|
|
||||||
|
Add `await` as a reserved word in module sources.
|
||||||
|
|
||||||
|
Disallow `yield` in a parameter default value for a generator.
|
||||||
|
|
||||||
|
Forbid using a comma after a rest pattern in an array destructuring.
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
Support parsing stdin in command-line tool.
|
||||||
|
|
||||||
|
## 2.5.0 (2015-10-27)
|
||||||
|
|
||||||
|
### Fixes
|
||||||
|
|
||||||
|
Fix tokenizer support in the command-line tool.
|
||||||
|
|
||||||
|
Stop allowing `new.target` outside of functions.
|
||||||
|
|
||||||
|
Remove legacy `guard` and `guardedHandler` properties from try nodes.
|
||||||
|
|
||||||
|
Stop allowing multiple `__proto__` properties on an object literal in strict mode.
|
||||||
|
|
||||||
|
Don't allow rest parameters to be non-identifier patterns.
|
||||||
|
|
||||||
|
Check for duplicate paramter names in arrow functions.
|
@@ -1,6 +1,6 @@
|
|||||||
The MIT License (MIT)
|
MIT License
|
||||||
|
|
||||||
Copyright (c) Feross Aboukhadijeh
|
Copyright (C) 2012-2018 by various contributors (see AUTHORS)
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
of this software and associated documentation files (the "Software"), to deal
|
269
node_modules/acorn-globals/node_modules/acorn/README.md
generated
vendored
Normal file
269
node_modules/acorn-globals/node_modules/acorn/README.md
generated
vendored
Normal file
@@ -0,0 +1,269 @@
|
|||||||
|
# Acorn
|
||||||
|
|
||||||
|
A tiny, fast JavaScript parser written in JavaScript.
|
||||||
|
|
||||||
|
## Community
|
||||||
|
|
||||||
|
Acorn is open source software released under an
|
||||||
|
[MIT license](https://github.com/acornjs/acorn/blob/master/acorn/LICENSE).
|
||||||
|
|
||||||
|
You are welcome to
|
||||||
|
[report bugs](https://github.com/acornjs/acorn/issues) or create pull
|
||||||
|
requests on [github](https://github.com/acornjs/acorn). For questions
|
||||||
|
and discussion, please use the
|
||||||
|
[Tern discussion forum](https://discuss.ternjs.net).
|
||||||
|
|
||||||
|
## Installation
|
||||||
|
|
||||||
|
The easiest way to install acorn is from [`npm`](https://www.npmjs.com/):
|
||||||
|
|
||||||
|
```sh
|
||||||
|
npm install acorn
|
||||||
|
```
|
||||||
|
|
||||||
|
Alternately, you can download the source and build acorn yourself:
|
||||||
|
|
||||||
|
```sh
|
||||||
|
git clone https://github.com/acornjs/acorn.git
|
||||||
|
cd acorn
|
||||||
|
npm install
|
||||||
|
```
|
||||||
|
|
||||||
|
## Interface
|
||||||
|
|
||||||
|
**parse**`(input, options)` is the main interface to the library. The
|
||||||
|
`input` parameter is a string, `options` can be undefined or an object
|
||||||
|
setting some of the options listed below. The return value will be an
|
||||||
|
abstract syntax tree object as specified by the [ESTree
|
||||||
|
spec](https://github.com/estree/estree).
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
let acorn = require("acorn");
|
||||||
|
console.log(acorn.parse("1 + 1"));
|
||||||
|
```
|
||||||
|
|
||||||
|
When encountering a syntax error, the parser will raise a
|
||||||
|
`SyntaxError` object with a meaningful message. The error object will
|
||||||
|
have a `pos` property that indicates the string offset at which the
|
||||||
|
error occurred, and a `loc` object that contains a `{line, column}`
|
||||||
|
object referring to that same position.
|
||||||
|
|
||||||
|
Options can be provided by passing a second argument, which should be
|
||||||
|
an object containing any of these fields:
|
||||||
|
|
||||||
|
- **ecmaVersion**: Indicates the ECMAScript version to parse. Must be
|
||||||
|
either 3, 5, 6 (2015), 7 (2016), 8 (2017), 9 (2018), 10 (2019) or 11
|
||||||
|
(2020, partial support). This influences support for strict mode,
|
||||||
|
the set of reserved words, and support for new syntax features.
|
||||||
|
Default is 10.
|
||||||
|
|
||||||
|
**NOTE**: Only 'stage 4' (finalized) ECMAScript features are being
|
||||||
|
implemented by Acorn. Other proposed new features can be implemented
|
||||||
|
through plugins.
|
||||||
|
|
||||||
|
- **sourceType**: Indicate the mode the code should be parsed in. Can be
|
||||||
|
either `"script"` or `"module"`. This influences global strict mode
|
||||||
|
and parsing of `import` and `export` declarations.
|
||||||
|
|
||||||
|
**NOTE**: If set to `"module"`, then static `import` / `export` syntax
|
||||||
|
will be valid, even if `ecmaVersion` is less than 6.
|
||||||
|
|
||||||
|
- **onInsertedSemicolon**: If given a callback, that callback will be
|
||||||
|
called whenever a missing semicolon is inserted by the parser. The
|
||||||
|
callback will be given the character offset of the point where the
|
||||||
|
semicolon is inserted as argument, and if `locations` is on, also a
|
||||||
|
`{line, column}` object representing this position.
|
||||||
|
|
||||||
|
- **onTrailingComma**: Like `onInsertedSemicolon`, but for trailing
|
||||||
|
commas.
|
||||||
|
|
||||||
|
- **allowReserved**: If `false`, using a reserved word will generate
|
||||||
|
an error. Defaults to `true` for `ecmaVersion` 3, `false` for higher
|
||||||
|
versions. When given the value `"never"`, reserved words and
|
||||||
|
keywords can also not be used as property names (as in Internet
|
||||||
|
Explorer's old parser).
|
||||||
|
|
||||||
|
- **allowReturnOutsideFunction**: By default, a return statement at
|
||||||
|
the top level raises an error. Set this to `true` to accept such
|
||||||
|
code.
|
||||||
|
|
||||||
|
- **allowImportExportEverywhere**: By default, `import` and `export`
|
||||||
|
declarations can only appear at a program's top level. Setting this
|
||||||
|
option to `true` allows them anywhere where a statement is allowed.
|
||||||
|
|
||||||
|
- **allowAwaitOutsideFunction**: By default, `await` expressions can
|
||||||
|
only appear inside `async` functions. Setting this option to
|
||||||
|
`true` allows to have top-level `await` expressions. They are
|
||||||
|
still not allowed in non-`async` functions, though.
|
||||||
|
|
||||||
|
- **allowHashBang**: When this is enabled (off by default), if the
|
||||||
|
code starts with the characters `#!` (as in a shellscript), the
|
||||||
|
first line will be treated as a comment.
|
||||||
|
|
||||||
|
- **locations**: When `true`, each node has a `loc` object attached
|
||||||
|
with `start` and `end` subobjects, each of which contains the
|
||||||
|
one-based line and zero-based column numbers in `{line, column}`
|
||||||
|
form. Default is `false`.
|
||||||
|
|
||||||
|
- **onToken**: If a function is passed for this option, each found
|
||||||
|
token will be passed in same format as tokens returned from
|
||||||
|
`tokenizer().getToken()`.
|
||||||
|
|
||||||
|
If array is passed, each found token is pushed to it.
|
||||||
|
|
||||||
|
Note that you are not allowed to call the parser from the
|
||||||
|
callback—that will corrupt its internal state.
|
||||||
|
|
||||||
|
- **onComment**: If a function is passed for this option, whenever a
|
||||||
|
comment is encountered the function will be called with the
|
||||||
|
following parameters:
|
||||||
|
|
||||||
|
- `block`: `true` if the comment is a block comment, false if it
|
||||||
|
is a line comment.
|
||||||
|
- `text`: The content of the comment.
|
||||||
|
- `start`: Character offset of the start of the comment.
|
||||||
|
- `end`: Character offset of the end of the comment.
|
||||||
|
|
||||||
|
When the `locations` options is on, the `{line, column}` locations
|
||||||
|
of the comment’s start and end are passed as two additional
|
||||||
|
parameters.
|
||||||
|
|
||||||
|
If array is passed for this option, each found comment is pushed
|
||||||
|
to it as object in Esprima format:
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
{
|
||||||
|
"type": "Line" | "Block",
|
||||||
|
"value": "comment text",
|
||||||
|
"start": Number,
|
||||||
|
"end": Number,
|
||||||
|
// If `locations` option is on:
|
||||||
|
"loc": {
|
||||||
|
"start": {line: Number, column: Number}
|
||||||
|
"end": {line: Number, column: Number}
|
||||||
|
},
|
||||||
|
// If `ranges` option is on:
|
||||||
|
"range": [Number, Number]
|
||||||
|
}
|
||||||
|
```
|
||||||
|
|
||||||
|
Note that you are not allowed to call the parser from the
|
||||||
|
callback—that will corrupt its internal state.
|
||||||
|
|
||||||
|
- **ranges**: Nodes have their start and end characters offsets
|
||||||
|
recorded in `start` and `end` properties (directly on the node,
|
||||||
|
rather than the `loc` object, which holds line/column data. To also
|
||||||
|
add a
|
||||||
|
[semi-standardized](https://bugzilla.mozilla.org/show_bug.cgi?id=745678)
|
||||||
|
`range` property holding a `[start, end]` array with the same
|
||||||
|
numbers, set the `ranges` option to `true`.
|
||||||
|
|
||||||
|
- **program**: It is possible to parse multiple files into a single
|
||||||
|
AST by passing the tree produced by parsing the first file as the
|
||||||
|
`program` option in subsequent parses. This will add the toplevel
|
||||||
|
forms of the parsed file to the "Program" (top) node of an existing
|
||||||
|
parse tree.
|
||||||
|
|
||||||
|
- **sourceFile**: When the `locations` option is `true`, you can pass
|
||||||
|
this option to add a `source` attribute in every node’s `loc`
|
||||||
|
object. Note that the contents of this option are not examined or
|
||||||
|
processed in any way; you are free to use whatever format you
|
||||||
|
choose.
|
||||||
|
|
||||||
|
- **directSourceFile**: Like `sourceFile`, but a `sourceFile` property
|
||||||
|
will be added (regardless of the `location` option) directly to the
|
||||||
|
nodes, rather than the `loc` object.
|
||||||
|
|
||||||
|
- **preserveParens**: If this option is `true`, parenthesized expressions
|
||||||
|
are represented by (non-standard) `ParenthesizedExpression` nodes
|
||||||
|
that have a single `expression` property containing the expression
|
||||||
|
inside parentheses.
|
||||||
|
|
||||||
|
**parseExpressionAt**`(input, offset, options)` will parse a single
|
||||||
|
expression in a string, and return its AST. It will not complain if
|
||||||
|
there is more of the string left after the expression.
|
||||||
|
|
||||||
|
**tokenizer**`(input, options)` returns an object with a `getToken`
|
||||||
|
method that can be called repeatedly to get the next token, a `{start,
|
||||||
|
end, type, value}` object (with added `loc` property when the
|
||||||
|
`locations` option is enabled and `range` property when the `ranges`
|
||||||
|
option is enabled). When the token's type is `tokTypes.eof`, you
|
||||||
|
should stop calling the method, since it will keep returning that same
|
||||||
|
token forever.
|
||||||
|
|
||||||
|
In ES6 environment, returned result can be used as any other
|
||||||
|
protocol-compliant iterable:
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
for (let token of acorn.tokenizer(str)) {
|
||||||
|
// iterate over the tokens
|
||||||
|
}
|
||||||
|
|
||||||
|
// transform code to array of tokens:
|
||||||
|
var tokens = [...acorn.tokenizer(str)];
|
||||||
|
```
|
||||||
|
|
||||||
|
**tokTypes** holds an object mapping names to the token type objects
|
||||||
|
that end up in the `type` properties of tokens.
|
||||||
|
|
||||||
|
**getLineInfo**`(input, offset)` can be used to get a `{line,
|
||||||
|
column}` object for a given program string and offset.
|
||||||
|
|
||||||
|
### The `Parser` class
|
||||||
|
|
||||||
|
Instances of the **`Parser`** class contain all the state and logic
|
||||||
|
that drives a parse. It has static methods `parse`,
|
||||||
|
`parseExpressionAt`, and `tokenizer` that match the top-level
|
||||||
|
functions by the same name.
|
||||||
|
|
||||||
|
When extending the parser with plugins, you need to call these methods
|
||||||
|
on the extended version of the class. To extend a parser with plugins,
|
||||||
|
you can use its static `extend` method.
|
||||||
|
|
||||||
|
```javascript
|
||||||
|
var acorn = require("acorn");
|
||||||
|
var jsx = require("acorn-jsx");
|
||||||
|
var JSXParser = acorn.Parser.extend(jsx());
|
||||||
|
JSXParser.parse("foo(<bar/>)");
|
||||||
|
```
|
||||||
|
|
||||||
|
The `extend` method takes any number of plugin values, and returns a
|
||||||
|
new `Parser` class that includes the extra parser logic provided by
|
||||||
|
the plugins.
|
||||||
|
|
||||||
|
## Command line interface
|
||||||
|
|
||||||
|
The `bin/acorn` utility can be used to parse a file from the command
|
||||||
|
line. It accepts as arguments its input file and the following
|
||||||
|
options:
|
||||||
|
|
||||||
|
- `--ecma3|--ecma5|--ecma6|--ecma7|--ecma8|--ecma9|--ecma10`: Sets the ECMAScript version
|
||||||
|
to parse. Default is version 9.
|
||||||
|
|
||||||
|
- `--module`: Sets the parsing mode to `"module"`. Is set to `"script"` otherwise.
|
||||||
|
|
||||||
|
- `--locations`: Attaches a "loc" object to each node with "start" and
|
||||||
|
"end" subobjects, each of which contains the one-based line and
|
||||||
|
zero-based column numbers in `{line, column}` form.
|
||||||
|
|
||||||
|
- `--allow-hash-bang`: If the code starts with the characters #! (as
|
||||||
|
in a shellscript), the first line will be treated as a comment.
|
||||||
|
|
||||||
|
- `--compact`: No whitespace is used in the AST output.
|
||||||
|
|
||||||
|
- `--silent`: Do not output the AST, just return the exit status.
|
||||||
|
|
||||||
|
- `--help`: Print the usage information and quit.
|
||||||
|
|
||||||
|
The utility spits out the syntax tree as JSON data.
|
||||||
|
|
||||||
|
## Existing plugins
|
||||||
|
|
||||||
|
- [`acorn-jsx`](https://github.com/RReverser/acorn-jsx): Parse [Facebook JSX syntax extensions](https://github.com/facebook/jsx)
|
||||||
|
|
||||||
|
Plugins for ECMAScript proposals:
|
||||||
|
|
||||||
|
- [`acorn-stage3`](https://github.com/acornjs/acorn-stage3): Parse most stage 3 proposals, bundling:
|
||||||
|
- [`acorn-class-fields`](https://github.com/acornjs/acorn-class-fields): Parse [class fields proposal](https://github.com/tc39/proposal-class-fields)
|
||||||
|
- [`acorn-import-meta`](https://github.com/acornjs/acorn-import-meta): Parse [import.meta proposal](https://github.com/tc39/proposal-import-meta)
|
||||||
|
- [`acorn-private-methods`](https://github.com/acornjs/acorn-private-methods): parse [private methods, getters and setters proposal](https://github.com/tc39/proposal-private-methods)n
|
4
node_modules/acorn-globals/node_modules/acorn/bin/acorn
generated
vendored
Normal file
4
node_modules/acorn-globals/node_modules/acorn/bin/acorn
generated
vendored
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
#!/usr/bin/env node
|
||||||
|
'use strict';
|
||||||
|
|
||||||
|
require('../dist/bin.js');
|
209
node_modules/acorn-globals/node_modules/acorn/dist/acorn.d.ts
generated
vendored
Normal file
209
node_modules/acorn-globals/node_modules/acorn/dist/acorn.d.ts
generated
vendored
Normal file
@@ -0,0 +1,209 @@
|
|||||||
|
export as namespace acorn
|
||||||
|
export = acorn
|
||||||
|
|
||||||
|
declare namespace acorn {
|
||||||
|
function parse(input: string, options?: Options): Node
|
||||||
|
|
||||||
|
function parseExpressionAt(input: string, pos?: number, options?: Options): Node
|
||||||
|
|
||||||
|
function tokenizer(input: string, options?: Options): {
|
||||||
|
getToken(): Token
|
||||||
|
[Symbol.iterator](): Iterator<Token>
|
||||||
|
}
|
||||||
|
|
||||||
|
interface Options {
|
||||||
|
ecmaVersion?: 3 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 2015 | 2016 | 2017 | 2018 | 2019 | 2020
|
||||||
|
sourceType?: 'script' | 'module'
|
||||||
|
onInsertedSemicolon?: (lastTokEnd: number, lastTokEndLoc?: Position) => void
|
||||||
|
onTrailingComma?: (lastTokEnd: number, lastTokEndLoc?: Position) => void
|
||||||
|
allowReserved?: boolean | 'never'
|
||||||
|
allowReturnOutsideFunction?: boolean
|
||||||
|
allowImportExportEverywhere?: boolean
|
||||||
|
allowAwaitOutsideFunction?: boolean
|
||||||
|
allowHashBang?: boolean
|
||||||
|
locations?: boolean
|
||||||
|
onToken?: ((token: Token) => any) | Token[]
|
||||||
|
onComment?: ((
|
||||||
|
isBlock: boolean, text: string, start: number, end: number, startLoc?: Position,
|
||||||
|
endLoc?: Position
|
||||||
|
) => void) | Comment[]
|
||||||
|
ranges?: boolean
|
||||||
|
program?: Node
|
||||||
|
sourceFile?: string
|
||||||
|
directSourceFile?: string
|
||||||
|
preserveParens?: boolean
|
||||||
|
}
|
||||||
|
|
||||||
|
class Parser {
|
||||||
|
constructor(options: Options, input: string, startPos?: number)
|
||||||
|
parse(this: Parser): Node
|
||||||
|
static parse(this: typeof Parser, input: string, options?: Options): Node
|
||||||
|
static parseExpressionAt(this: typeof Parser, input: string, pos: number, options?: Options): Node
|
||||||
|
static tokenizer(this: typeof Parser, input: string, options?: Options): {
|
||||||
|
getToken(): Token
|
||||||
|
[Symbol.iterator](): Iterator<Token>
|
||||||
|
}
|
||||||
|
static extend(this: typeof Parser, ...plugins: ((BaseParser: typeof Parser) => typeof Parser)[]): typeof Parser
|
||||||
|
}
|
||||||
|
|
||||||
|
interface Position { line: number; column: number; offset: number }
|
||||||
|
|
||||||
|
const defaultOptions: Options
|
||||||
|
|
||||||
|
function getLineInfo(input: string, offset: number): Position
|
||||||
|
|
||||||
|
class SourceLocation {
|
||||||
|
start: Position
|
||||||
|
end: Position
|
||||||
|
source?: string | null
|
||||||
|
constructor(p: Parser, start: Position, end: Position)
|
||||||
|
}
|
||||||
|
|
||||||
|
class Node {
|
||||||
|
type: string
|
||||||
|
start: number
|
||||||
|
end: number
|
||||||
|
loc?: SourceLocation
|
||||||
|
sourceFile?: string
|
||||||
|
range?: [number, number]
|
||||||
|
constructor(parser: Parser, pos: number, loc?: SourceLocation)
|
||||||
|
}
|
||||||
|
|
||||||
|
class TokenType {
|
||||||
|
label: string
|
||||||
|
keyword: string
|
||||||
|
beforeExpr: boolean
|
||||||
|
startsExpr: boolean
|
||||||
|
isLoop: boolean
|
||||||
|
isAssign: boolean
|
||||||
|
prefix: boolean
|
||||||
|
postfix: boolean
|
||||||
|
binop: number
|
||||||
|
updateContext?: (prevType: TokenType) => void
|
||||||
|
constructor(label: string, conf?: any)
|
||||||
|
}
|
||||||
|
|
||||||
|
const tokTypes: {
|
||||||
|
num: TokenType
|
||||||
|
regexp: TokenType
|
||||||
|
string: TokenType
|
||||||
|
name: TokenType
|
||||||
|
eof: TokenType
|
||||||
|
bracketL: TokenType
|
||||||
|
bracketR: TokenType
|
||||||
|
braceL: TokenType
|
||||||
|
braceR: TokenType
|
||||||
|
parenL: TokenType
|
||||||
|
parenR: TokenType
|
||||||
|
comma: TokenType
|
||||||
|
semi: TokenType
|
||||||
|
colon: TokenType
|
||||||
|
dot: TokenType
|
||||||
|
question: TokenType
|
||||||
|
arrow: TokenType
|
||||||
|
template: TokenType
|
||||||
|
ellipsis: TokenType
|
||||||
|
backQuote: TokenType
|
||||||
|
dollarBraceL: TokenType
|
||||||
|
eq: TokenType
|
||||||
|
assign: TokenType
|
||||||
|
incDec: TokenType
|
||||||
|
prefix: TokenType
|
||||||
|
logicalOR: TokenType
|
||||||
|
logicalAND: TokenType
|
||||||
|
bitwiseOR: TokenType
|
||||||
|
bitwiseXOR: TokenType
|
||||||
|
bitwiseAND: TokenType
|
||||||
|
equality: TokenType
|
||||||
|
relational: TokenType
|
||||||
|
bitShift: TokenType
|
||||||
|
plusMin: TokenType
|
||||||
|
modulo: TokenType
|
||||||
|
star: TokenType
|
||||||
|
slash: TokenType
|
||||||
|
starstar: TokenType
|
||||||
|
_break: TokenType
|
||||||
|
_case: TokenType
|
||||||
|
_catch: TokenType
|
||||||
|
_continue: TokenType
|
||||||
|
_debugger: TokenType
|
||||||
|
_default: TokenType
|
||||||
|
_do: TokenType
|
||||||
|
_else: TokenType
|
||||||
|
_finally: TokenType
|
||||||
|
_for: TokenType
|
||||||
|
_function: TokenType
|
||||||
|
_if: TokenType
|
||||||
|
_return: TokenType
|
||||||
|
_switch: TokenType
|
||||||
|
_throw: TokenType
|
||||||
|
_try: TokenType
|
||||||
|
_var: TokenType
|
||||||
|
_const: TokenType
|
||||||
|
_while: TokenType
|
||||||
|
_with: TokenType
|
||||||
|
_new: TokenType
|
||||||
|
_this: TokenType
|
||||||
|
_super: TokenType
|
||||||
|
_class: TokenType
|
||||||
|
_extends: TokenType
|
||||||
|
_export: TokenType
|
||||||
|
_import: TokenType
|
||||||
|
_null: TokenType
|
||||||
|
_true: TokenType
|
||||||
|
_false: TokenType
|
||||||
|
_in: TokenType
|
||||||
|
_instanceof: TokenType
|
||||||
|
_typeof: TokenType
|
||||||
|
_void: TokenType
|
||||||
|
_delete: TokenType
|
||||||
|
}
|
||||||
|
|
||||||
|
class TokContext {
|
||||||
|
constructor(token: string, isExpr: boolean, preserveSpace: boolean, override?: (p: Parser) => void)
|
||||||
|
}
|
||||||
|
|
||||||
|
const tokContexts: {
|
||||||
|
b_stat: TokContext
|
||||||
|
b_expr: TokContext
|
||||||
|
b_tmpl: TokContext
|
||||||
|
p_stat: TokContext
|
||||||
|
p_expr: TokContext
|
||||||
|
q_tmpl: TokContext
|
||||||
|
f_expr: TokContext
|
||||||
|
}
|
||||||
|
|
||||||
|
function isIdentifierStart(code: number, astral?: boolean): boolean
|
||||||
|
|
||||||
|
function isIdentifierChar(code: number, astral?: boolean): boolean
|
||||||
|
|
||||||
|
interface AbstractToken {
|
||||||
|
}
|
||||||
|
|
||||||
|
interface Comment extends AbstractToken {
|
||||||
|
type: string
|
||||||
|
value: string
|
||||||
|
start: number
|
||||||
|
end: number
|
||||||
|
loc?: SourceLocation
|
||||||
|
range?: [number, number]
|
||||||
|
}
|
||||||
|
|
||||||
|
class Token {
|
||||||
|
type: TokenType
|
||||||
|
value: any
|
||||||
|
start: number
|
||||||
|
end: number
|
||||||
|
loc?: SourceLocation
|
||||||
|
range?: [number, number]
|
||||||
|
constructor(p: Parser)
|
||||||
|
}
|
||||||
|
|
||||||
|
function isNewLine(code: number): boolean
|
||||||
|
|
||||||
|
const lineBreak: RegExp
|
||||||
|
|
||||||
|
const lineBreakG: RegExp
|
||||||
|
|
||||||
|
const version: string
|
||||||
|
}
|
5186
node_modules/acorn-globals/node_modules/acorn/dist/acorn.js
generated
vendored
Normal file
5186
node_modules/acorn-globals/node_modules/acorn/dist/acorn.js
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
1
node_modules/acorn-globals/node_modules/acorn/dist/acorn.js.map
generated
vendored
Normal file
1
node_modules/acorn-globals/node_modules/acorn/dist/acorn.js.map
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
5155
node_modules/acorn-globals/node_modules/acorn/dist/acorn.mjs
generated
vendored
Normal file
5155
node_modules/acorn-globals/node_modules/acorn/dist/acorn.mjs
generated
vendored
Normal file
File diff suppressed because it is too large
Load Diff
2
node_modules/acorn-globals/node_modules/acorn/dist/acorn.mjs.d.ts
generated
vendored
Normal file
2
node_modules/acorn-globals/node_modules/acorn/dist/acorn.mjs.d.ts
generated
vendored
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
import * as acorn from "./acorn";
|
||||||
|
export = acorn;
|
1
node_modules/acorn-globals/node_modules/acorn/dist/acorn.mjs.map
generated
vendored
Normal file
1
node_modules/acorn-globals/node_modules/acorn/dist/acorn.mjs.map
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
64
node_modules/acorn-globals/node_modules/acorn/dist/bin.js
generated
vendored
Normal file
64
node_modules/acorn-globals/node_modules/acorn/dist/bin.js
generated
vendored
Normal file
@@ -0,0 +1,64 @@
|
|||||||
|
'use strict';
|
||||||
|
|
||||||
|
var path = require('path');
|
||||||
|
var fs = require('fs');
|
||||||
|
var acorn = require('./acorn.js');
|
||||||
|
|
||||||
|
var infile, forceFile, silent = false, compact = false, tokenize = false;
|
||||||
|
var options = {};
|
||||||
|
|
||||||
|
function help(status) {
|
||||||
|
var print = (status === 0) ? console.log : console.error;
|
||||||
|
print("usage: " + path.basename(process.argv[1]) + " [--ecma3|--ecma5|--ecma6|--ecma7|--ecma8|--ecma9|...|--ecma2015|--ecma2016|--ecma2017|--ecma2018|...]");
|
||||||
|
print(" [--tokenize] [--locations] [---allow-hash-bang] [--compact] [--silent] [--module] [--help] [--] [infile]");
|
||||||
|
process.exit(status);
|
||||||
|
}
|
||||||
|
|
||||||
|
for (var i = 2; i < process.argv.length; ++i) {
|
||||||
|
var arg = process.argv[i];
|
||||||
|
if ((arg === "-" || arg[0] !== "-") && !infile) { infile = arg; }
|
||||||
|
else if (arg === "--" && !infile && i + 2 === process.argv.length) { forceFile = infile = process.argv[++i]; }
|
||||||
|
else if (arg === "--locations") { options.locations = true; }
|
||||||
|
else if (arg === "--allow-hash-bang") { options.allowHashBang = true; }
|
||||||
|
else if (arg === "--silent") { silent = true; }
|
||||||
|
else if (arg === "--compact") { compact = true; }
|
||||||
|
else if (arg === "--help") { help(0); }
|
||||||
|
else if (arg === "--tokenize") { tokenize = true; }
|
||||||
|
else if (arg === "--module") { options.sourceType = "module"; }
|
||||||
|
else {
|
||||||
|
var match = arg.match(/^--ecma(\d+)$/);
|
||||||
|
if (match)
|
||||||
|
{ options.ecmaVersion = +match[1]; }
|
||||||
|
else
|
||||||
|
{ help(1); }
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function run(code) {
|
||||||
|
var result;
|
||||||
|
try {
|
||||||
|
if (!tokenize) {
|
||||||
|
result = acorn.parse(code, options);
|
||||||
|
} else {
|
||||||
|
result = [];
|
||||||
|
var tokenizer = acorn.tokenizer(code, options), token;
|
||||||
|
do {
|
||||||
|
token = tokenizer.getToken();
|
||||||
|
result.push(token);
|
||||||
|
} while (token.type !== acorn.tokTypes.eof)
|
||||||
|
}
|
||||||
|
} catch (e) {
|
||||||
|
console.error(infile && infile !== "-" ? e.message.replace(/\(\d+:\d+\)$/, function (m) { return m.slice(0, 1) + infile + " " + m.slice(1); }) : e.message);
|
||||||
|
process.exit(1);
|
||||||
|
}
|
||||||
|
if (!silent) { console.log(JSON.stringify(result, null, compact ? null : 2)); }
|
||||||
|
}
|
||||||
|
|
||||||
|
if (forceFile || infile && infile !== "-") {
|
||||||
|
run(fs.readFileSync(infile, "utf8"));
|
||||||
|
} else {
|
||||||
|
var code = "";
|
||||||
|
process.stdin.resume();
|
||||||
|
process.stdin.on("data", function (chunk) { return code += chunk; });
|
||||||
|
process.stdin.on("end", function () { return run(code); });
|
||||||
|
}
|
67
node_modules/acorn-globals/node_modules/acorn/package.json
generated
vendored
Normal file
67
node_modules/acorn-globals/node_modules/acorn/package.json
generated
vendored
Normal file
@@ -0,0 +1,67 @@
|
|||||||
|
{
|
||||||
|
"_from": "acorn@^7.1.1",
|
||||||
|
"_id": "acorn@7.4.1",
|
||||||
|
"_inBundle": false,
|
||||||
|
"_integrity": "sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==",
|
||||||
|
"_location": "/acorn-globals/acorn",
|
||||||
|
"_phantomChildren": {},
|
||||||
|
"_requested": {
|
||||||
|
"type": "range",
|
||||||
|
"registry": true,
|
||||||
|
"raw": "acorn@^7.1.1",
|
||||||
|
"name": "acorn",
|
||||||
|
"escapedName": "acorn",
|
||||||
|
"rawSpec": "^7.1.1",
|
||||||
|
"saveSpec": null,
|
||||||
|
"fetchSpec": "^7.1.1"
|
||||||
|
},
|
||||||
|
"_requiredBy": [
|
||||||
|
"/acorn-globals"
|
||||||
|
],
|
||||||
|
"_resolved": "https://registry.npmjs.org/acorn/-/acorn-7.4.1.tgz",
|
||||||
|
"_shasum": "feaed255973d2e77555b83dbc08851a6c63520fa",
|
||||||
|
"_spec": "acorn@^7.1.1",
|
||||||
|
"_where": "D:\\Projects\\minifyfromhtml\\node_modules\\acorn-globals",
|
||||||
|
"bin": {
|
||||||
|
"acorn": "bin/acorn"
|
||||||
|
},
|
||||||
|
"bugs": {
|
||||||
|
"url": "https://github.com/acornjs/acorn/issues"
|
||||||
|
},
|
||||||
|
"bundleDependencies": false,
|
||||||
|
"deprecated": false,
|
||||||
|
"description": "ECMAScript parser",
|
||||||
|
"engines": {
|
||||||
|
"node": ">=0.4.0"
|
||||||
|
},
|
||||||
|
"homepage": "https://github.com/acornjs/acorn",
|
||||||
|
"license": "MIT",
|
||||||
|
"main": "dist/acorn.js",
|
||||||
|
"maintainers": [
|
||||||
|
{
|
||||||
|
"name": "Marijn Haverbeke",
|
||||||
|
"email": "marijnh@gmail.com",
|
||||||
|
"url": "https://marijnhaverbeke.nl"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "Ingvar Stepanyan",
|
||||||
|
"email": "me@rreverser.com",
|
||||||
|
"url": "https://rreverser.com/"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name": "Adrian Heine",
|
||||||
|
"url": "http://adrianheine.de"
|
||||||
|
}
|
||||||
|
],
|
||||||
|
"module": "dist/acorn.mjs",
|
||||||
|
"name": "acorn",
|
||||||
|
"repository": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "git+https://github.com/acornjs/acorn.git"
|
||||||
|
},
|
||||||
|
"scripts": {
|
||||||
|
"prepare": "cd ..; npm run build:main && npm run build:bin"
|
||||||
|
},
|
||||||
|
"types": "dist/acorn.d.ts",
|
||||||
|
"version": "7.4.1"
|
||||||
|
}
|
28
node_modules/acorn-globals/package.json
generated
vendored
28
node_modules/acorn-globals/package.json
generated
vendored
@@ -1,27 +1,27 @@
|
|||||||
{
|
{
|
||||||
"_from": "acorn-globals@^4.3.0",
|
"_from": "acorn-globals@^6.0.0",
|
||||||
"_id": "acorn-globals@4.3.4",
|
"_id": "acorn-globals@6.0.0",
|
||||||
"_inBundle": false,
|
"_inBundle": false,
|
||||||
"_integrity": "sha512-clfQEh21R+D0leSbUdWf3OcfqyaCSAQ8Ryq00bofSekfr9W8u1jyYZo6ir0xu9Gtcf7BjcHJpnbZH7JOCpP60A==",
|
"_integrity": "sha512-ZQl7LOWaF5ePqqcX4hLuv/bLXYQNfNWw2c0/yX/TsPRKamzHcTGQnlCjHT3TsmkOUVEPS3crCxiPfdzE/Trlhg==",
|
||||||
"_location": "/acorn-globals",
|
"_location": "/acorn-globals",
|
||||||
"_phantomChildren": {},
|
"_phantomChildren": {},
|
||||||
"_requested": {
|
"_requested": {
|
||||||
"type": "range",
|
"type": "range",
|
||||||
"registry": true,
|
"registry": true,
|
||||||
"raw": "acorn-globals@^4.3.0",
|
"raw": "acorn-globals@^6.0.0",
|
||||||
"name": "acorn-globals",
|
"name": "acorn-globals",
|
||||||
"escapedName": "acorn-globals",
|
"escapedName": "acorn-globals",
|
||||||
"rawSpec": "^4.3.0",
|
"rawSpec": "^6.0.0",
|
||||||
"saveSpec": null,
|
"saveSpec": null,
|
||||||
"fetchSpec": "^4.3.0"
|
"fetchSpec": "^6.0.0"
|
||||||
},
|
},
|
||||||
"_requiredBy": [
|
"_requiredBy": [
|
||||||
"/jsdom"
|
"/jsdom"
|
||||||
],
|
],
|
||||||
"_resolved": "https://registry.npmjs.org/acorn-globals/-/acorn-globals-4.3.4.tgz",
|
"_resolved": "https://registry.npmjs.org/acorn-globals/-/acorn-globals-6.0.0.tgz",
|
||||||
"_shasum": "9fa1926addc11c97308c4e66d7add0d40c3272e7",
|
"_shasum": "46cdd39f0f8ff08a876619b55f5ac8a6dc770b45",
|
||||||
"_spec": "acorn-globals@^4.3.0",
|
"_spec": "acorn-globals@^6.0.0",
|
||||||
"_where": "F:\\projects\\p\\minifyfromhtml\\node_modules\\jsdom",
|
"_where": "D:\\Projects\\minifyfromhtml\\node_modules\\jsdom",
|
||||||
"author": {
|
"author": {
|
||||||
"name": "ForbesLindesay"
|
"name": "ForbesLindesay"
|
||||||
},
|
},
|
||||||
@@ -30,13 +30,13 @@
|
|||||||
},
|
},
|
||||||
"bundleDependencies": false,
|
"bundleDependencies": false,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"acorn": "^6.0.1",
|
"acorn": "^7.1.1",
|
||||||
"acorn-walk": "^6.0.1"
|
"acorn-walk": "^7.1.1"
|
||||||
},
|
},
|
||||||
"deprecated": false,
|
"deprecated": false,
|
||||||
"description": "Detect global variables in JavaScript using acorn",
|
"description": "Detect global variables in JavaScript using acorn",
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"testit": "^3.0.0"
|
"testit": "^3.1.0"
|
||||||
},
|
},
|
||||||
"files": [
|
"files": [
|
||||||
"index.js",
|
"index.js",
|
||||||
@@ -62,5 +62,5 @@
|
|||||||
"scripts": {
|
"scripts": {
|
||||||
"test": "node test"
|
"test": "node test"
|
||||||
},
|
},
|
||||||
"version": "4.3.4"
|
"version": "6.0.0"
|
||||||
}
|
}
|
||||||
|
28
node_modules/acorn-walk/CHANGELOG.md
generated
vendored
28
node_modules/acorn-walk/CHANGELOG.md
generated
vendored
@@ -1,3 +1,31 @@
|
|||||||
|
## 7.2.0 (2020-06-17)
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
Support optional chaining and nullish coalescing.
|
||||||
|
|
||||||
|
Support `import.meta`.
|
||||||
|
|
||||||
|
Add support for `export * as ns from "source"`.
|
||||||
|
|
||||||
|
## 7.1.1 (2020-02-13)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Clean up the type definitions to actually work well with the main parser.
|
||||||
|
|
||||||
|
## 7.1.0 (2020-02-11)
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
Add a TypeScript definition file for the library.
|
||||||
|
|
||||||
|
## 7.0.0 (2017-08-12)
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
Support walking `ImportExpression` nodes.
|
||||||
|
|
||||||
## 6.2.0 (2017-07-04)
|
## 6.2.0 (2017-07-04)
|
||||||
|
|
||||||
### New features
|
### New features
|
||||||
|
112
node_modules/acorn-walk/dist/walk.d.ts
generated
vendored
Normal file
112
node_modules/acorn-walk/dist/walk.d.ts
generated
vendored
Normal file
@@ -0,0 +1,112 @@
|
|||||||
|
import {Node} from 'acorn';
|
||||||
|
|
||||||
|
declare module "acorn-walk" {
|
||||||
|
type FullWalkerCallback<TState> = (
|
||||||
|
node: Node,
|
||||||
|
state: TState,
|
||||||
|
type: string
|
||||||
|
) => void;
|
||||||
|
|
||||||
|
type FullAncestorWalkerCallback<TState> = (
|
||||||
|
node: Node,
|
||||||
|
state: TState | Node[],
|
||||||
|
ancestors: Node[],
|
||||||
|
type: string
|
||||||
|
) => void;
|
||||||
|
type WalkerCallback<TState> = (node: Node, state: TState) => void;
|
||||||
|
|
||||||
|
type SimpleWalkerFn<TState> = (
|
||||||
|
node: Node,
|
||||||
|
state: TState
|
||||||
|
) => void;
|
||||||
|
|
||||||
|
type AncestorWalkerFn<TState> = (
|
||||||
|
node: Node,
|
||||||
|
state: TState| Node[],
|
||||||
|
ancestors: Node[]
|
||||||
|
) => void;
|
||||||
|
|
||||||
|
type RecursiveWalkerFn<TState> = (
|
||||||
|
node: Node,
|
||||||
|
state: TState,
|
||||||
|
callback: WalkerCallback<TState>
|
||||||
|
) => void;
|
||||||
|
|
||||||
|
type SimpleVisitors<TState> = {
|
||||||
|
[type: string]: SimpleWalkerFn<TState>
|
||||||
|
};
|
||||||
|
|
||||||
|
type AncestorVisitors<TState> = {
|
||||||
|
[type: string]: AncestorWalkerFn<TState>
|
||||||
|
};
|
||||||
|
|
||||||
|
type RecursiveVisitors<TState> = {
|
||||||
|
[type: string]: RecursiveWalkerFn<TState>
|
||||||
|
};
|
||||||
|
|
||||||
|
type FindPredicate = (type: string, node: Node) => boolean;
|
||||||
|
|
||||||
|
interface Found<TState> {
|
||||||
|
node: Node,
|
||||||
|
state: TState
|
||||||
|
}
|
||||||
|
|
||||||
|
export function simple<TState>(
|
||||||
|
node: Node,
|
||||||
|
visitors: SimpleVisitors<TState>,
|
||||||
|
base?: RecursiveVisitors<TState>,
|
||||||
|
state?: TState
|
||||||
|
): void;
|
||||||
|
|
||||||
|
export function ancestor<TState>(
|
||||||
|
node: Node,
|
||||||
|
visitors: AncestorVisitors<TState>,
|
||||||
|
base?: RecursiveVisitors<TState>,
|
||||||
|
state?: TState
|
||||||
|
): void;
|
||||||
|
|
||||||
|
export function recursive<TState>(
|
||||||
|
node: Node,
|
||||||
|
state: TState,
|
||||||
|
functions: RecursiveVisitors<TState>,
|
||||||
|
base?: RecursiveVisitors<TState>
|
||||||
|
): void;
|
||||||
|
|
||||||
|
export function full<TState>(
|
||||||
|
node: Node,
|
||||||
|
callback: FullWalkerCallback<TState>,
|
||||||
|
base?: RecursiveVisitors<TState>,
|
||||||
|
state?: TState
|
||||||
|
): void;
|
||||||
|
|
||||||
|
export function fullAncestor<TState>(
|
||||||
|
node: Node,
|
||||||
|
callback: FullAncestorWalkerCallback<TState>,
|
||||||
|
base?: RecursiveVisitors<TState>,
|
||||||
|
state?: TState
|
||||||
|
): void;
|
||||||
|
|
||||||
|
export function make<TState>(
|
||||||
|
functions: RecursiveVisitors<TState>,
|
||||||
|
base?: RecursiveVisitors<TState>
|
||||||
|
): RecursiveVisitors<TState>;
|
||||||
|
|
||||||
|
export function findNodeAt<TState>(
|
||||||
|
node: Node,
|
||||||
|
start: number | undefined,
|
||||||
|
end?: number | undefined,
|
||||||
|
type?: FindPredicate | string,
|
||||||
|
base?: RecursiveVisitors<TState>,
|
||||||
|
state?: TState
|
||||||
|
): Found<TState> | undefined;
|
||||||
|
|
||||||
|
export function findNodeAround<TState>(
|
||||||
|
node: Node,
|
||||||
|
start: number | undefined,
|
||||||
|
type?: FindPredicate | string,
|
||||||
|
base?: RecursiveVisitors<TState>,
|
||||||
|
state?: TState
|
||||||
|
): Found<TState> | undefined;
|
||||||
|
|
||||||
|
export const findNodeAfter: typeof findNodeAround;
|
||||||
|
}
|
17
node_modules/acorn-walk/dist/walk.js
generated
vendored
17
node_modules/acorn-walk/dist/walk.js
generated
vendored
@@ -2,7 +2,7 @@
|
|||||||
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) :
|
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) :
|
||||||
typeof define === 'function' && define.amd ? define(['exports'], factory) :
|
typeof define === 'function' && define.amd ? define(['exports'], factory) :
|
||||||
(global = global || self, factory((global.acorn = global.acorn || {}, global.acorn.walk = {})));
|
(global = global || self, factory((global.acorn = global.acorn || {}, global.acorn.walk = {})));
|
||||||
}(this, function (exports) { 'use strict';
|
}(this, (function (exports) { 'use strict';
|
||||||
|
|
||||||
// AST walker module for Mozilla Parser API compatible trees
|
// AST walker module for Mozilla Parser API compatible trees
|
||||||
|
|
||||||
@@ -34,7 +34,7 @@
|
|||||||
// An ancestor walk keeps an array of ancestor nodes (including the
|
// An ancestor walk keeps an array of ancestor nodes (including the
|
||||||
// current node) and passes them to the callback as third parameter
|
// current node) and passes them to the callback as third parameter
|
||||||
// (and also as state parameter when no other state is present).
|
// (and also as state parameter when no other state is present).
|
||||||
function ancestor(node, visitors, baseVisitor, state) {
|
function ancestor(node, visitors, baseVisitor, state, override) {
|
||||||
var ancestors = [];
|
var ancestors = [];
|
||||||
if (!baseVisitor) { baseVisitor = base
|
if (!baseVisitor) { baseVisitor = base
|
||||||
; }(function c(node, st, override) {
|
; }(function c(node, st, override) {
|
||||||
@@ -44,7 +44,7 @@
|
|||||||
baseVisitor[type](node, st, c);
|
baseVisitor[type](node, st, c);
|
||||||
if (found) { found(node, st || ancestors, ancestors); }
|
if (found) { found(node, st || ancestors, ancestors); }
|
||||||
if (isNew) { ancestors.pop(); }
|
if (isNew) { ancestors.pop(); }
|
||||||
})(node, state);
|
})(node, state, override);
|
||||||
}
|
}
|
||||||
|
|
||||||
// A recursive walk is one where your functions override the default
|
// A recursive walk is one where your functions override the default
|
||||||
@@ -200,7 +200,7 @@
|
|||||||
};
|
};
|
||||||
base.Statement = skipThrough;
|
base.Statement = skipThrough;
|
||||||
base.EmptyStatement = ignore;
|
base.EmptyStatement = ignore;
|
||||||
base.ExpressionStatement = base.ParenthesizedExpression =
|
base.ExpressionStatement = base.ParenthesizedExpression = base.ChainExpression =
|
||||||
function (node, st, c) { return c(node.expression, st, "Expression"); };
|
function (node, st, c) { return c(node.expression, st, "Expression"); };
|
||||||
base.IfStatement = function (node, st, c) {
|
base.IfStatement = function (node, st, c) {
|
||||||
c(node.test, st, "Expression");
|
c(node.test, st, "Expression");
|
||||||
@@ -405,6 +405,8 @@
|
|||||||
if (node.source) { c(node.source, st, "Expression"); }
|
if (node.source) { c(node.source, st, "Expression"); }
|
||||||
};
|
};
|
||||||
base.ExportAllDeclaration = function (node, st, c) {
|
base.ExportAllDeclaration = function (node, st, c) {
|
||||||
|
if (node.exported)
|
||||||
|
{ c(node.exported, st); }
|
||||||
c(node.source, st, "Expression");
|
c(node.source, st, "Expression");
|
||||||
};
|
};
|
||||||
base.ImportDeclaration = function (node, st, c) {
|
base.ImportDeclaration = function (node, st, c) {
|
||||||
@@ -416,7 +418,10 @@
|
|||||||
}
|
}
|
||||||
c(node.source, st, "Expression");
|
c(node.source, st, "Expression");
|
||||||
};
|
};
|
||||||
base.ImportSpecifier = base.ImportDefaultSpecifier = base.ImportNamespaceSpecifier = base.Identifier = base.Literal = base.Import = ignore;
|
base.ImportExpression = function (node, st, c) {
|
||||||
|
c(node.source, st, "Expression");
|
||||||
|
};
|
||||||
|
base.ImportSpecifier = base.ImportDefaultSpecifier = base.ImportNamespaceSpecifier = base.Identifier = base.Literal = ignore;
|
||||||
|
|
||||||
base.TaggedTemplateExpression = function (node, st, c) {
|
base.TaggedTemplateExpression = function (node, st, c) {
|
||||||
c(node.tag, st, "Expression");
|
c(node.tag, st, "Expression");
|
||||||
@@ -455,4 +460,4 @@
|
|||||||
|
|
||||||
Object.defineProperty(exports, '__esModule', { value: true });
|
Object.defineProperty(exports, '__esModule', { value: true });
|
||||||
|
|
||||||
}));
|
})));
|
||||||
|
13
node_modules/acorn-walk/dist/walk.mjs
generated
vendored
13
node_modules/acorn-walk/dist/walk.mjs
generated
vendored
@@ -28,7 +28,7 @@ function simple(node, visitors, baseVisitor, state, override) {
|
|||||||
// An ancestor walk keeps an array of ancestor nodes (including the
|
// An ancestor walk keeps an array of ancestor nodes (including the
|
||||||
// current node) and passes them to the callback as third parameter
|
// current node) and passes them to the callback as third parameter
|
||||||
// (and also as state parameter when no other state is present).
|
// (and also as state parameter when no other state is present).
|
||||||
function ancestor(node, visitors, baseVisitor, state) {
|
function ancestor(node, visitors, baseVisitor, state, override) {
|
||||||
var ancestors = [];
|
var ancestors = [];
|
||||||
if (!baseVisitor) { baseVisitor = base
|
if (!baseVisitor) { baseVisitor = base
|
||||||
; }(function c(node, st, override) {
|
; }(function c(node, st, override) {
|
||||||
@@ -38,7 +38,7 @@ function ancestor(node, visitors, baseVisitor, state) {
|
|||||||
baseVisitor[type](node, st, c);
|
baseVisitor[type](node, st, c);
|
||||||
if (found) { found(node, st || ancestors, ancestors); }
|
if (found) { found(node, st || ancestors, ancestors); }
|
||||||
if (isNew) { ancestors.pop(); }
|
if (isNew) { ancestors.pop(); }
|
||||||
})(node, state);
|
})(node, state, override);
|
||||||
}
|
}
|
||||||
|
|
||||||
// A recursive walk is one where your functions override the default
|
// A recursive walk is one where your functions override the default
|
||||||
@@ -194,7 +194,7 @@ base.Program = base.BlockStatement = function (node, st, c) {
|
|||||||
};
|
};
|
||||||
base.Statement = skipThrough;
|
base.Statement = skipThrough;
|
||||||
base.EmptyStatement = ignore;
|
base.EmptyStatement = ignore;
|
||||||
base.ExpressionStatement = base.ParenthesizedExpression =
|
base.ExpressionStatement = base.ParenthesizedExpression = base.ChainExpression =
|
||||||
function (node, st, c) { return c(node.expression, st, "Expression"); };
|
function (node, st, c) { return c(node.expression, st, "Expression"); };
|
||||||
base.IfStatement = function (node, st, c) {
|
base.IfStatement = function (node, st, c) {
|
||||||
c(node.test, st, "Expression");
|
c(node.test, st, "Expression");
|
||||||
@@ -399,6 +399,8 @@ base.ExportNamedDeclaration = base.ExportDefaultDeclaration = function (node, st
|
|||||||
if (node.source) { c(node.source, st, "Expression"); }
|
if (node.source) { c(node.source, st, "Expression"); }
|
||||||
};
|
};
|
||||||
base.ExportAllDeclaration = function (node, st, c) {
|
base.ExportAllDeclaration = function (node, st, c) {
|
||||||
|
if (node.exported)
|
||||||
|
{ c(node.exported, st); }
|
||||||
c(node.source, st, "Expression");
|
c(node.source, st, "Expression");
|
||||||
};
|
};
|
||||||
base.ImportDeclaration = function (node, st, c) {
|
base.ImportDeclaration = function (node, st, c) {
|
||||||
@@ -410,7 +412,10 @@ base.ImportDeclaration = function (node, st, c) {
|
|||||||
}
|
}
|
||||||
c(node.source, st, "Expression");
|
c(node.source, st, "Expression");
|
||||||
};
|
};
|
||||||
base.ImportSpecifier = base.ImportDefaultSpecifier = base.ImportNamespaceSpecifier = base.Identifier = base.Literal = base.Import = ignore;
|
base.ImportExpression = function (node, st, c) {
|
||||||
|
c(node.source, st, "Expression");
|
||||||
|
};
|
||||||
|
base.ImportSpecifier = base.ImportDefaultSpecifier = base.ImportNamespaceSpecifier = base.Identifier = base.Literal = ignore;
|
||||||
|
|
||||||
base.TaggedTemplateExpression = function (node, st, c) {
|
base.TaggedTemplateExpression = function (node, st, c) {
|
||||||
c(node.tag, st, "Expression");
|
c(node.tag, st, "Expression");
|
||||||
|
23
node_modules/acorn-walk/package.json
generated
vendored
23
node_modules/acorn-walk/package.json
generated
vendored
@@ -1,27 +1,27 @@
|
|||||||
{
|
{
|
||||||
"_from": "acorn-walk@^6.0.1",
|
"_from": "acorn-walk@^7.1.1",
|
||||||
"_id": "acorn-walk@6.2.0",
|
"_id": "acorn-walk@7.2.0",
|
||||||
"_inBundle": false,
|
"_inBundle": false,
|
||||||
"_integrity": "sha512-7evsyfH1cLOCdAzZAd43Cic04yKydNx0cF+7tiA19p1XnLLPU4dpCQOqpjqwokFe//vS0QqfqqjCS2JkiIs0cA==",
|
"_integrity": "sha512-OPdCF6GsMIP+Az+aWfAAOEt2/+iVDKE7oy6lJ098aoe59oAmK76qV6Gw60SbZ8jHuG2wH058GF4pLFbYamYrVA==",
|
||||||
"_location": "/acorn-walk",
|
"_location": "/acorn-walk",
|
||||||
"_phantomChildren": {},
|
"_phantomChildren": {},
|
||||||
"_requested": {
|
"_requested": {
|
||||||
"type": "range",
|
"type": "range",
|
||||||
"registry": true,
|
"registry": true,
|
||||||
"raw": "acorn-walk@^6.0.1",
|
"raw": "acorn-walk@^7.1.1",
|
||||||
"name": "acorn-walk",
|
"name": "acorn-walk",
|
||||||
"escapedName": "acorn-walk",
|
"escapedName": "acorn-walk",
|
||||||
"rawSpec": "^6.0.1",
|
"rawSpec": "^7.1.1",
|
||||||
"saveSpec": null,
|
"saveSpec": null,
|
||||||
"fetchSpec": "^6.0.1"
|
"fetchSpec": "^7.1.1"
|
||||||
},
|
},
|
||||||
"_requiredBy": [
|
"_requiredBy": [
|
||||||
"/acorn-globals"
|
"/acorn-globals"
|
||||||
],
|
],
|
||||||
"_resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-6.2.0.tgz",
|
"_resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-7.2.0.tgz",
|
||||||
"_shasum": "123cb8f3b84c2171f1f7fb252615b1c78a6b1a8c",
|
"_shasum": "0de889a601203909b0fbe07b8938dc21d2e967bc",
|
||||||
"_spec": "acorn-walk@^6.0.1",
|
"_spec": "acorn-walk@^7.1.1",
|
||||||
"_where": "F:\\projects\\p\\minifyfromhtml\\node_modules\\acorn-globals",
|
"_where": "D:\\Projects\\minifyfromhtml\\node_modules\\acorn-globals",
|
||||||
"bugs": {
|
"bugs": {
|
||||||
"url": "https://github.com/acornjs/acorn/issues"
|
"url": "https://github.com/acornjs/acorn/issues"
|
||||||
},
|
},
|
||||||
@@ -59,5 +59,6 @@
|
|||||||
"scripts": {
|
"scripts": {
|
||||||
"prepare": "cd ..; npm run build:walk"
|
"prepare": "cd ..; npm run build:walk"
|
||||||
},
|
},
|
||||||
"version": "6.2.0"
|
"types": "dist/walk.d.ts",
|
||||||
|
"version": "7.2.0"
|
||||||
}
|
}
|
||||||
|
194
node_modules/acorn/CHANGELOG.md
generated
vendored
194
node_modules/acorn/CHANGELOG.md
generated
vendored
@@ -1,9 +1,197 @@
|
|||||||
## 6.4.0 (2019-11-26)
|
## 8.4.0 (2021-06-11)
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
A new option, `allowSuperOutsideMethod`, can be used to suppress the error when `super` is used in the wrong context.
|
||||||
|
|
||||||
|
## 8.3.0 (2021-05-31)
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
Default `allowAwaitOutsideFunction` to true for ECMAScript 2022 an higher.
|
||||||
|
|
||||||
|
Add support for the `p` ([indices](https://github.com/tc39/proposal-regexp-match-indices)) regexp flag.
|
||||||
|
|
||||||
|
## 8.2.4 (2021-05-04)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix spec conformity in corner case 'for await (async of ...)'.
|
||||||
|
|
||||||
|
## 8.2.3 (2021-05-04)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix an issue where the library couldn't parse 'for (async of ...)'.
|
||||||
|
|
||||||
|
Fix a bug in UTF-16 decoding that would read characters incorrectly in some circumstances.
|
||||||
|
|
||||||
|
## 8.2.2 (2021-04-29)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix a bug where a class field initialized to an async arrow function wouldn't allow await inside it. Same issue existed for generator arrow functions with yield.
|
||||||
|
|
||||||
|
## 8.2.1 (2021-04-24)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix a regression introduced in 8.2.0 where static or async class methods with keyword names fail to parse.
|
||||||
|
|
||||||
|
## 8.2.0 (2021-04-24)
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
Add support for ES2022 class fields and private methods.
|
||||||
|
|
||||||
|
## 8.1.1 (2021-04-12)
|
||||||
|
|
||||||
|
### Various
|
||||||
|
|
||||||
|
Stop shipping source maps in the NPM package.
|
||||||
|
|
||||||
|
## 8.1.0 (2021-03-09)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix a spurious error in nested destructuring arrays.
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
Expose `allowAwaitOutsideFunction` in CLI interface.
|
||||||
|
|
||||||
|
Make `allowImportExportAnywhere` also apply to `import.meta`.
|
||||||
|
|
||||||
|
## 8.0.5 (2021-01-25)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Adjust package.json to work with Node 12.16.0 and 13.0-13.6.
|
||||||
|
|
||||||
|
## 8.0.4 (2020-10-05)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Make `await x ** y` an error, following the spec.
|
||||||
|
|
||||||
|
Fix potentially exponential regular expression.
|
||||||
|
|
||||||
|
## 8.0.3 (2020-10-02)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix a wasteful loop during `Parser` creation when setting `ecmaVersion` to `"latest"`.
|
||||||
|
|
||||||
|
## 8.0.2 (2020-09-30)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Make the TypeScript types reflect the current allowed values for `ecmaVersion`.
|
||||||
|
|
||||||
|
Fix another regexp/division tokenizer issue.
|
||||||
|
|
||||||
|
## 8.0.1 (2020-08-12)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Provide the correct value in the `version` export.
|
||||||
|
|
||||||
|
## 8.0.0 (2020-08-12)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Disallow expressions like `(a = b) = c`.
|
||||||
|
|
||||||
|
Make non-octal escape sequences a syntax error in strict mode.
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
The package can now be loaded directly as an ECMAScript module in node 13+.
|
||||||
|
|
||||||
|
Update to the set of Unicode properties from ES2021.
|
||||||
|
|
||||||
|
### Breaking changes
|
||||||
|
|
||||||
|
The `ecmaVersion` option is now required. For the moment, omitting it will still work with a warning, but that will change in a future release.
|
||||||
|
|
||||||
|
Some changes to method signatures that may be used by plugins.
|
||||||
|
|
||||||
|
## 7.4.0 (2020-08-03)
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
Add support for logical assignment operators.
|
||||||
|
|
||||||
|
Add support for numeric separators.
|
||||||
|
|
||||||
|
## 7.3.1 (2020-06-11)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Make the string in the `version` export match the actual library version.
|
||||||
|
|
||||||
|
## 7.3.0 (2020-06-11)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix a bug that caused parsing of object patterns with a property named `set` that had a default value to fail.
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
Add support for optional chaining (`?.`).
|
||||||
|
|
||||||
|
## 7.2.0 (2020-05-09)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Fix precedence issue in parsing of async arrow functions.
|
||||||
|
|
||||||
|
### New features
|
||||||
|
|
||||||
|
Add support for nullish coalescing.
|
||||||
|
|
||||||
|
Add support for `import.meta`.
|
||||||
|
|
||||||
|
Support `export * as ...` syntax.
|
||||||
|
|
||||||
|
Upgrade to Unicode 13.
|
||||||
|
|
||||||
|
## 6.4.1 (2020-03-09)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
More carefully check for valid UTF16 surrogate pairs in regexp validator.
|
||||||
|
|
||||||
|
## 7.1.1 (2020-03-01)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Treat `\8` and `\9` as invalid escapes in template strings.
|
||||||
|
|
||||||
|
Allow unicode escapes in property names that are keywords.
|
||||||
|
|
||||||
|
Don't error on an exponential operator expression as argument to `await`.
|
||||||
|
|
||||||
|
More carefully check for valid UTF16 surrogate pairs in regexp validator.
|
||||||
|
|
||||||
|
## 7.1.0 (2019-09-24)
|
||||||
|
|
||||||
|
### Bug fixes
|
||||||
|
|
||||||
|
Disallow trailing object literal commas when ecmaVersion is less than 5.
|
||||||
|
|
||||||
### New features
|
### New features
|
||||||
|
|
||||||
Add a static `acorn` property to the `Parser` class that contains the entire module interface, to allow plugins to access the instance of the library that they are acting on.
|
Add a static `acorn` property to the `Parser` class that contains the entire module interface, to allow plugins to access the instance of the library that they are acting on.
|
||||||
|
|
||||||
|
## 7.0.0 (2019-08-13)
|
||||||
|
|
||||||
|
### Breaking changes
|
||||||
|
|
||||||
|
Changes the node format for dynamic imports to use the `ImportExpression` node type, as defined in [ESTree](https://github.com/estree/estree/blob/master/es2020.md#importexpression).
|
||||||
|
|
||||||
|
Makes 10 (ES2019) the default value for the `ecmaVersion` option.
|
||||||
|
|
||||||
## 6.3.0 (2019-08-12)
|
## 6.3.0 (2019-08-12)
|
||||||
|
|
||||||
### New features
|
### New features
|
||||||
@@ -28,9 +216,9 @@ Disallow binding `let` in patterns.
|
|||||||
|
|
||||||
### New features
|
### New features
|
||||||
|
|
||||||
Support bigint syntax with `ecmaVersion` >= 10.
|
Support bigint syntax with `ecmaVersion` >= 11.
|
||||||
|
|
||||||
Support dynamic `import` syntax with `ecmaVersion` >= 10.
|
Support dynamic `import` syntax with `ecmaVersion` >= 11.
|
||||||
|
|
||||||
Upgrade to Unicode version 12.
|
Upgrade to Unicode version 12.
|
||||||
|
|
||||||
|
4
node_modules/acorn/LICENSE
generated
vendored
4
node_modules/acorn/LICENSE
generated
vendored
@@ -1,4 +1,6 @@
|
|||||||
Copyright (C) 2012-2018 by various contributors (see AUTHORS)
|
MIT License
|
||||||
|
|
||||||
|
Copyright (C) 2012-2020 by various contributors (see AUTHORS)
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
of this software and associated documentation files (the "Software"), to deal
|
of this software and associated documentation files (the "Software"), to deal
|
||||||
|
45
node_modules/acorn/README.md
generated
vendored
45
node_modules/acorn/README.md
generated
vendored
@@ -32,14 +32,14 @@ npm install
|
|||||||
## Interface
|
## Interface
|
||||||
|
|
||||||
**parse**`(input, options)` is the main interface to the library. The
|
**parse**`(input, options)` is the main interface to the library. The
|
||||||
`input` parameter is a string, `options` can be undefined or an object
|
`input` parameter is a string, `options` must be an object setting
|
||||||
setting some of the options listed below. The return value will be an
|
some of the options listed below. The return value will be an abstract
|
||||||
abstract syntax tree object as specified by the [ESTree
|
syntax tree object as specified by the [ESTree
|
||||||
spec](https://github.com/estree/estree).
|
spec](https://github.com/estree/estree).
|
||||||
|
|
||||||
```javascript
|
```javascript
|
||||||
let acorn = require("acorn");
|
let acorn = require("acorn");
|
||||||
console.log(acorn.parse("1 + 1"));
|
console.log(acorn.parse("1 + 1", {ecmaVersion: 2020}));
|
||||||
```
|
```
|
||||||
|
|
||||||
When encountering a syntax error, the parser will raise a
|
When encountering a syntax error, the parser will raise a
|
||||||
@@ -48,17 +48,20 @@ have a `pos` property that indicates the string offset at which the
|
|||||||
error occurred, and a `loc` object that contains a `{line, column}`
|
error occurred, and a `loc` object that contains a `{line, column}`
|
||||||
object referring to that same position.
|
object referring to that same position.
|
||||||
|
|
||||||
Options can be provided by passing a second argument, which should be
|
Options are provided by in a second argument, which should be an
|
||||||
an object containing any of these fields:
|
object containing any of these fields (only `ecmaVersion` is
|
||||||
|
required):
|
||||||
|
|
||||||
- **ecmaVersion**: Indicates the ECMAScript version to parse. Must be
|
- **ecmaVersion**: Indicates the ECMAScript version to parse. Must be
|
||||||
either 3, 5, 6 (2015), 7 (2016), 8 (2017), 9 (2018) or 10 (2019, partial
|
either 3, 5, 6 (or 2015), 7 (2016), 8 (2017), 9 (2018), 10 (2019),
|
||||||
support). This influences support for strict mode, the set of
|
11 (2020), 12 (2021, partial support), 13 (2022, partial support)
|
||||||
reserved words, and support for new syntax features. Default is 9.
|
or `"latest"` (the latest the library supports). This influences
|
||||||
|
support for strict mode, the set of reserved words, and support
|
||||||
|
for new syntax features.
|
||||||
|
|
||||||
**NOTE**: Only 'stage 4' (finalized) ECMAScript features are being
|
**NOTE**: Only 'stage 4' (finalized) ECMAScript features are being
|
||||||
implemented by Acorn. Other proposed new features can be implemented
|
implemented by Acorn. Other proposed new features must be
|
||||||
through plugins.
|
implemented through plugins.
|
||||||
|
|
||||||
- **sourceType**: Indicate the mode the code should be parsed in. Can be
|
- **sourceType**: Indicate the mode the code should be parsed in. Can be
|
||||||
either `"script"` or `"module"`. This influences global strict mode
|
either `"script"` or `"module"`. This influences global strict mode
|
||||||
@@ -88,13 +91,19 @@ an object containing any of these fields:
|
|||||||
|
|
||||||
- **allowImportExportEverywhere**: By default, `import` and `export`
|
- **allowImportExportEverywhere**: By default, `import` and `export`
|
||||||
declarations can only appear at a program's top level. Setting this
|
declarations can only appear at a program's top level. Setting this
|
||||||
option to `true` allows them anywhere where a statement is allowed.
|
option to `true` allows them anywhere where a statement is allowed,
|
||||||
|
and also allows `import.meta` expressions to appear in scripts
|
||||||
- **allowAwaitOutsideFunction**: By default, `await` expressions can
|
(when `sourceType` is not `"module"`).
|
||||||
only appear inside `async` functions. Setting this option to
|
|
||||||
|
- **allowAwaitOutsideFunction**: If `false`, `await` expressions can
|
||||||
|
only appear inside `async` functions. Defaults to `true` for
|
||||||
|
`ecmaVersion` 2022 and later, `false` for lower versions. Setting this option to
|
||||||
`true` allows to have top-level `await` expressions. They are
|
`true` allows to have top-level `await` expressions. They are
|
||||||
still not allowed in non-`async` functions, though.
|
still not allowed in non-`async` functions, though.
|
||||||
|
|
||||||
|
- **allowSuperOutsideMethod**: By default, `super` outside a method
|
||||||
|
raises an error. Set this to `true` to accept such code.
|
||||||
|
|
||||||
- **allowHashBang**: When this is enabled (off by default), if the
|
- **allowHashBang**: When this is enabled (off by default), if the
|
||||||
code starts with the characters `#!` (as in a shellscript), the
|
code starts with the characters `#!` (as in a shellscript), the
|
||||||
first line will be treated as a comment.
|
first line will be treated as a comment.
|
||||||
@@ -223,7 +232,7 @@ you can use its static `extend` method.
|
|||||||
var acorn = require("acorn");
|
var acorn = require("acorn");
|
||||||
var jsx = require("acorn-jsx");
|
var jsx = require("acorn-jsx");
|
||||||
var JSXParser = acorn.Parser.extend(jsx());
|
var JSXParser = acorn.Parser.extend(jsx());
|
||||||
JSXParser.parse("foo(<bar/>)");
|
JSXParser.parse("foo(<bar/>)", {ecmaVersion: 2020});
|
||||||
```
|
```
|
||||||
|
|
||||||
The `extend` method takes any number of plugin values, and returns a
|
The `extend` method takes any number of plugin values, and returns a
|
||||||
@@ -248,6 +257,9 @@ options:
|
|||||||
- `--allow-hash-bang`: If the code starts with the characters #! (as
|
- `--allow-hash-bang`: If the code starts with the characters #! (as
|
||||||
in a shellscript), the first line will be treated as a comment.
|
in a shellscript), the first line will be treated as a comment.
|
||||||
|
|
||||||
|
- `--allow-await-outside-function`: Allows top-level `await` expressions.
|
||||||
|
See the `allowAwaitOutsideFunction` option for more information.
|
||||||
|
|
||||||
- `--compact`: No whitespace is used in the AST output.
|
- `--compact`: No whitespace is used in the AST output.
|
||||||
|
|
||||||
- `--silent`: Do not output the AST, just return the exit status.
|
- `--silent`: Do not output the AST, just return the exit status.
|
||||||
@@ -265,5 +277,4 @@ Plugins for ECMAScript proposals:
|
|||||||
- [`acorn-stage3`](https://github.com/acornjs/acorn-stage3): Parse most stage 3 proposals, bundling:
|
- [`acorn-stage3`](https://github.com/acornjs/acorn-stage3): Parse most stage 3 proposals, bundling:
|
||||||
- [`acorn-class-fields`](https://github.com/acornjs/acorn-class-fields): Parse [class fields proposal](https://github.com/tc39/proposal-class-fields)
|
- [`acorn-class-fields`](https://github.com/acornjs/acorn-class-fields): Parse [class fields proposal](https://github.com/tc39/proposal-class-fields)
|
||||||
- [`acorn-import-meta`](https://github.com/acornjs/acorn-import-meta): Parse [import.meta proposal](https://github.com/tc39/proposal-import-meta)
|
- [`acorn-import-meta`](https://github.com/acornjs/acorn-import-meta): Parse [import.meta proposal](https://github.com/tc39/proposal-import-meta)
|
||||||
- [`acorn-numeric-separator`](https://github.com/acornjs/acorn-numeric-separator): Parse [numeric separator proposal](https://github.com/tc39/proposal-numeric-separator)
|
|
||||||
- [`acorn-private-methods`](https://github.com/acornjs/acorn-private-methods): parse [private methods, getters and setters proposal](https://github.com/tc39/proposal-private-methods)n
|
- [`acorn-private-methods`](https://github.com/acornjs/acorn-private-methods): parse [private methods, getters and setters proposal](https://github.com/tc39/proposal-private-methods)n
|
||||||
|
16
node_modules/acorn/dist/acorn.d.ts
generated
vendored
16
node_modules/acorn/dist/acorn.d.ts
generated
vendored
@@ -2,17 +2,17 @@ export as namespace acorn
|
|||||||
export = acorn
|
export = acorn
|
||||||
|
|
||||||
declare namespace acorn {
|
declare namespace acorn {
|
||||||
function parse(input: string, options?: Options): Node
|
function parse(input: string, options: Options): Node
|
||||||
|
|
||||||
function parseExpressionAt(input: string, pos?: number, options?: Options): Node
|
function parseExpressionAt(input: string, pos: number, options: Options): Node
|
||||||
|
|
||||||
function tokenizer(input: string, options?: Options): {
|
function tokenizer(input: string, options: Options): {
|
||||||
getToken(): Token
|
getToken(): Token
|
||||||
[Symbol.iterator](): Iterator<Token>
|
[Symbol.iterator](): Iterator<Token>
|
||||||
}
|
}
|
||||||
|
|
||||||
interface Options {
|
interface Options {
|
||||||
ecmaVersion?: 3 | 5 | 6 | 7 | 8 | 9 | 10 | 2015 | 2016 | 2017 | 2018 | 2019
|
ecmaVersion: 3 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 2015 | 2016 | 2017 | 2018 | 2019 | 2020 | 2021 | 2022 | 'latest'
|
||||||
sourceType?: 'script' | 'module'
|
sourceType?: 'script' | 'module'
|
||||||
onInsertedSemicolon?: (lastTokEnd: number, lastTokEndLoc?: Position) => void
|
onInsertedSemicolon?: (lastTokEnd: number, lastTokEndLoc?: Position) => void
|
||||||
onTrailingComma?: (lastTokEnd: number, lastTokEndLoc?: Position) => void
|
onTrailingComma?: (lastTokEnd: number, lastTokEndLoc?: Position) => void
|
||||||
@@ -20,6 +20,7 @@ declare namespace acorn {
|
|||||||
allowReturnOutsideFunction?: boolean
|
allowReturnOutsideFunction?: boolean
|
||||||
allowImportExportEverywhere?: boolean
|
allowImportExportEverywhere?: boolean
|
||||||
allowAwaitOutsideFunction?: boolean
|
allowAwaitOutsideFunction?: boolean
|
||||||
|
allowSuperOutsideMethod?: boolean
|
||||||
allowHashBang?: boolean
|
allowHashBang?: boolean
|
||||||
locations?: boolean
|
locations?: boolean
|
||||||
onToken?: ((token: Token) => any) | Token[]
|
onToken?: ((token: Token) => any) | Token[]
|
||||||
@@ -37,9 +38,9 @@ declare namespace acorn {
|
|||||||
class Parser {
|
class Parser {
|
||||||
constructor(options: Options, input: string, startPos?: number)
|
constructor(options: Options, input: string, startPos?: number)
|
||||||
parse(this: Parser): Node
|
parse(this: Parser): Node
|
||||||
static parse(this: typeof Parser, input: string, options?: Options): Node
|
static parse(this: typeof Parser, input: string, options: Options): Node
|
||||||
static parseExpressionAt(this: typeof Parser, input: string, pos: number, options?: Options): Node
|
static parseExpressionAt(this: typeof Parser, input: string, pos: number, options: Options): Node
|
||||||
static tokenizer(this: typeof Parser, input: string, options?: Options): {
|
static tokenizer(this: typeof Parser, input: string, options: Options): {
|
||||||
getToken(): Token
|
getToken(): Token
|
||||||
[Symbol.iterator](): Iterator<Token>
|
[Symbol.iterator](): Iterator<Token>
|
||||||
}
|
}
|
||||||
@@ -88,6 +89,7 @@ declare namespace acorn {
|
|||||||
regexp: TokenType
|
regexp: TokenType
|
||||||
string: TokenType
|
string: TokenType
|
||||||
name: TokenType
|
name: TokenType
|
||||||
|
privateId: TokenType
|
||||||
eof: TokenType
|
eof: TokenType
|
||||||
bracketL: TokenType
|
bracketL: TokenType
|
||||||
bracketR: TokenType
|
bracketR: TokenType
|
||||||
|
1107
node_modules/acorn/dist/acorn.js
generated
vendored
1107
node_modules/acorn/dist/acorn.js
generated
vendored
File diff suppressed because it is too large
Load Diff
1
node_modules/acorn/dist/acorn.js.map
generated
vendored
1
node_modules/acorn/dist/acorn.js.map
generated
vendored
File diff suppressed because one or more lines are too long
1103
node_modules/acorn/dist/acorn.mjs
generated
vendored
1103
node_modules/acorn/dist/acorn.mjs
generated
vendored
File diff suppressed because it is too large
Load Diff
2
node_modules/acorn/dist/acorn.mjs.d.ts
generated
vendored
Normal file
2
node_modules/acorn/dist/acorn.mjs.d.ts
generated
vendored
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
import * as acorn from "./acorn";
|
||||||
|
export = acorn;
|
1
node_modules/acorn/dist/acorn.mjs.map
generated
vendored
1
node_modules/acorn/dist/acorn.mjs.map
generated
vendored
File diff suppressed because one or more lines are too long
3
node_modules/acorn/dist/bin.js
generated
vendored
3
node_modules/acorn/dist/bin.js
generated
vendored
@@ -10,7 +10,7 @@ var options = {};
|
|||||||
function help(status) {
|
function help(status) {
|
||||||
var print = (status === 0) ? console.log : console.error;
|
var print = (status === 0) ? console.log : console.error;
|
||||||
print("usage: " + path.basename(process.argv[1]) + " [--ecma3|--ecma5|--ecma6|--ecma7|--ecma8|--ecma9|...|--ecma2015|--ecma2016|--ecma2017|--ecma2018|...]");
|
print("usage: " + path.basename(process.argv[1]) + " [--ecma3|--ecma5|--ecma6|--ecma7|--ecma8|--ecma9|...|--ecma2015|--ecma2016|--ecma2017|--ecma2018|...]");
|
||||||
print(" [--tokenize] [--locations] [---allow-hash-bang] [--compact] [--silent] [--module] [--help] [--] [infile]");
|
print(" [--tokenize] [--locations] [---allow-hash-bang] [--allow-await-outside-function] [--compact] [--silent] [--module] [--help] [--] [infile]");
|
||||||
process.exit(status);
|
process.exit(status);
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -20,6 +20,7 @@ for (var i = 2; i < process.argv.length; ++i) {
|
|||||||
else if (arg === "--" && !infile && i + 2 === process.argv.length) { forceFile = infile = process.argv[++i]; }
|
else if (arg === "--" && !infile && i + 2 === process.argv.length) { forceFile = infile = process.argv[++i]; }
|
||||||
else if (arg === "--locations") { options.locations = true; }
|
else if (arg === "--locations") { options.locations = true; }
|
||||||
else if (arg === "--allow-hash-bang") { options.allowHashBang = true; }
|
else if (arg === "--allow-hash-bang") { options.allowHashBang = true; }
|
||||||
|
else if (arg === "--allow-await-outside-function") { options.allowAwaitOutsideFunction = true; }
|
||||||
else if (arg === "--silent") { silent = true; }
|
else if (arg === "--silent") { silent = true; }
|
||||||
else if (arg === "--compact") { compact = true; }
|
else if (arg === "--compact") { compact = true; }
|
||||||
else if (arg === "--help") { help(0); }
|
else if (arg === "--help") { help(0); }
|
||||||
|
35
node_modules/acorn/package.json
generated
vendored
35
node_modules/acorn/package.json
generated
vendored
@@ -1,28 +1,27 @@
|
|||||||
{
|
{
|
||||||
"_from": "acorn@^6.0.4",
|
"_from": "acorn@^8.2.4",
|
||||||
"_id": "acorn@6.4.0",
|
"_id": "acorn@8.4.0",
|
||||||
"_inBundle": false,
|
"_inBundle": false,
|
||||||
"_integrity": "sha512-gac8OEcQ2Li1dxIEWGZzsp2BitJxwkwcOm0zHAJLcPJaVvm58FRnk6RkuLRpU1EujipU2ZFODv2P9DLMfnV8mw==",
|
"_integrity": "sha512-ULr0LDaEqQrMFGyQ3bhJkLsbtrQ8QibAseGZeaSUiT/6zb9IvIkomWHJIvgvwad+hinRAgsI51JcWk2yvwyL+w==",
|
||||||
"_location": "/acorn",
|
"_location": "/acorn",
|
||||||
"_phantomChildren": {},
|
"_phantomChildren": {},
|
||||||
"_requested": {
|
"_requested": {
|
||||||
"type": "range",
|
"type": "range",
|
||||||
"registry": true,
|
"registry": true,
|
||||||
"raw": "acorn@^6.0.4",
|
"raw": "acorn@^8.2.4",
|
||||||
"name": "acorn",
|
"name": "acorn",
|
||||||
"escapedName": "acorn",
|
"escapedName": "acorn",
|
||||||
"rawSpec": "^6.0.4",
|
"rawSpec": "^8.2.4",
|
||||||
"saveSpec": null,
|
"saveSpec": null,
|
||||||
"fetchSpec": "^6.0.4"
|
"fetchSpec": "^8.2.4"
|
||||||
},
|
},
|
||||||
"_requiredBy": [
|
"_requiredBy": [
|
||||||
"/acorn-globals",
|
|
||||||
"/jsdom"
|
"/jsdom"
|
||||||
],
|
],
|
||||||
"_resolved": "https://registry.npmjs.org/acorn/-/acorn-6.4.0.tgz",
|
"_resolved": "https://registry.npmjs.org/acorn/-/acorn-8.4.0.tgz",
|
||||||
"_shasum": "b659d2ffbafa24baf5db1cdbb2c94a983ecd2784",
|
"_shasum": "af53266e698d7cffa416714b503066a82221be60",
|
||||||
"_spec": "acorn@^6.0.4",
|
"_spec": "acorn@^8.2.4",
|
||||||
"_where": "F:\\projects\\p\\minifyfromhtml\\node_modules\\jsdom",
|
"_where": "D:\\Projects\\minifyfromhtml\\node_modules\\jsdom",
|
||||||
"bin": {
|
"bin": {
|
||||||
"acorn": "bin/acorn"
|
"acorn": "bin/acorn"
|
||||||
},
|
},
|
||||||
@@ -35,6 +34,17 @@
|
|||||||
"engines": {
|
"engines": {
|
||||||
"node": ">=0.4.0"
|
"node": ">=0.4.0"
|
||||||
},
|
},
|
||||||
|
"exports": {
|
||||||
|
".": [
|
||||||
|
{
|
||||||
|
"import": "./dist/acorn.mjs",
|
||||||
|
"require": "./dist/acorn.js",
|
||||||
|
"default": "./dist/acorn.js"
|
||||||
|
},
|
||||||
|
"./dist/acorn.js"
|
||||||
|
],
|
||||||
|
"./package.json": "./package.json"
|
||||||
|
},
|
||||||
"homepage": "https://github.com/acornjs/acorn",
|
"homepage": "https://github.com/acornjs/acorn",
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"main": "dist/acorn.js",
|
"main": "dist/acorn.js",
|
||||||
@@ -63,5 +73,6 @@
|
|||||||
"scripts": {
|
"scripts": {
|
||||||
"prepare": "cd ..; npm run build:main && npm run build:bin"
|
"prepare": "cd ..; npm run build:main && npm run build:bin"
|
||||||
},
|
},
|
||||||
"version": "6.4.0"
|
"types": "dist/acorn.d.ts",
|
||||||
|
"version": "8.4.0"
|
||||||
}
|
}
|
||||||
|
145
node_modules/agent-base/README.md
generated
vendored
Normal file
145
node_modules/agent-base/README.md
generated
vendored
Normal file
@@ -0,0 +1,145 @@
|
|||||||
|
agent-base
|
||||||
|
==========
|
||||||
|
### Turn a function into an [`http.Agent`][http.Agent] instance
|
||||||
|
[](https://github.com/TooTallNate/node-agent-base/actions?workflow=Node+CI)
|
||||||
|
|
||||||
|
This module provides an `http.Agent` generator. That is, you pass it an async
|
||||||
|
callback function, and it returns a new `http.Agent` instance that will invoke the
|
||||||
|
given callback function when sending outbound HTTP requests.
|
||||||
|
|
||||||
|
#### Some subclasses:
|
||||||
|
|
||||||
|
Here's some more interesting uses of `agent-base`.
|
||||||
|
Send a pull request to list yours!
|
||||||
|
|
||||||
|
* [`http-proxy-agent`][http-proxy-agent]: An HTTP(s) proxy `http.Agent` implementation for HTTP endpoints
|
||||||
|
* [`https-proxy-agent`][https-proxy-agent]: An HTTP(s) proxy `http.Agent` implementation for HTTPS endpoints
|
||||||
|
* [`pac-proxy-agent`][pac-proxy-agent]: A PAC file proxy `http.Agent` implementation for HTTP and HTTPS
|
||||||
|
* [`socks-proxy-agent`][socks-proxy-agent]: A SOCKS proxy `http.Agent` implementation for HTTP and HTTPS
|
||||||
|
|
||||||
|
|
||||||
|
Installation
|
||||||
|
------------
|
||||||
|
|
||||||
|
Install with `npm`:
|
||||||
|
|
||||||
|
``` bash
|
||||||
|
$ npm install agent-base
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
Example
|
||||||
|
-------
|
||||||
|
|
||||||
|
Here's a minimal example that creates a new `net.Socket` connection to the server
|
||||||
|
for every HTTP request (i.e. the equivalent of `agent: false` option):
|
||||||
|
|
||||||
|
```js
|
||||||
|
var net = require('net');
|
||||||
|
var tls = require('tls');
|
||||||
|
var url = require('url');
|
||||||
|
var http = require('http');
|
||||||
|
var agent = require('agent-base');
|
||||||
|
|
||||||
|
var endpoint = 'http://nodejs.org/api/';
|
||||||
|
var parsed = url.parse(endpoint);
|
||||||
|
|
||||||
|
// This is the important part!
|
||||||
|
parsed.agent = agent(function (req, opts) {
|
||||||
|
var socket;
|
||||||
|
// `secureEndpoint` is true when using the https module
|
||||||
|
if (opts.secureEndpoint) {
|
||||||
|
socket = tls.connect(opts);
|
||||||
|
} else {
|
||||||
|
socket = net.connect(opts);
|
||||||
|
}
|
||||||
|
return socket;
|
||||||
|
});
|
||||||
|
|
||||||
|
// Everything else works just like normal...
|
||||||
|
http.get(parsed, function (res) {
|
||||||
|
console.log('"response" event!', res.headers);
|
||||||
|
res.pipe(process.stdout);
|
||||||
|
});
|
||||||
|
```
|
||||||
|
|
||||||
|
Returning a Promise or using an `async` function is also supported:
|
||||||
|
|
||||||
|
```js
|
||||||
|
agent(async function (req, opts) {
|
||||||
|
await sleep(1000);
|
||||||
|
// etc…
|
||||||
|
});
|
||||||
|
```
|
||||||
|
|
||||||
|
Return another `http.Agent` instance to "pass through" the responsibility
|
||||||
|
for that HTTP request to that agent:
|
||||||
|
|
||||||
|
```js
|
||||||
|
agent(function (req, opts) {
|
||||||
|
return opts.secureEndpoint ? https.globalAgent : http.globalAgent;
|
||||||
|
});
|
||||||
|
```
|
||||||
|
|
||||||
|
|
||||||
|
API
|
||||||
|
---
|
||||||
|
|
||||||
|
## Agent(Function callback[, Object options]) → [http.Agent][]
|
||||||
|
|
||||||
|
Creates a base `http.Agent` that will execute the callback function `callback`
|
||||||
|
for every HTTP request that it is used as the `agent` for. The callback function
|
||||||
|
is responsible for creating a `stream.Duplex` instance of some kind that will be
|
||||||
|
used as the underlying socket in the HTTP request.
|
||||||
|
|
||||||
|
The `options` object accepts the following properties:
|
||||||
|
|
||||||
|
* `timeout` - Number - Timeout for the `callback()` function in milliseconds. Defaults to Infinity (optional).
|
||||||
|
|
||||||
|
The callback function should have the following signature:
|
||||||
|
|
||||||
|
### callback(http.ClientRequest req, Object options, Function cb) → undefined
|
||||||
|
|
||||||
|
The ClientRequest `req` can be accessed to read request headers and
|
||||||
|
and the path, etc. The `options` object contains the options passed
|
||||||
|
to the `http.request()`/`https.request()` function call, and is formatted
|
||||||
|
to be directly passed to `net.connect()`/`tls.connect()`, or however
|
||||||
|
else you want a Socket to be created. Pass the created socket to
|
||||||
|
the callback function `cb` once created, and the HTTP request will
|
||||||
|
continue to proceed.
|
||||||
|
|
||||||
|
If the `https` module is used to invoke the HTTP request, then the
|
||||||
|
`secureEndpoint` property on `options` _will be set to `true`_.
|
||||||
|
|
||||||
|
|
||||||
|
License
|
||||||
|
-------
|
||||||
|
|
||||||
|
(The MIT License)
|
||||||
|
|
||||||
|
Copyright (c) 2013 Nathan Rajlich <nathan@tootallnate.net>
|
||||||
|
|
||||||
|
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.
|
||||||
|
|
||||||
|
[http-proxy-agent]: https://github.com/TooTallNate/node-http-proxy-agent
|
||||||
|
[https-proxy-agent]: https://github.com/TooTallNate/node-https-proxy-agent
|
||||||
|
[pac-proxy-agent]: https://github.com/TooTallNate/node-pac-proxy-agent
|
||||||
|
[socks-proxy-agent]: https://github.com/TooTallNate/node-socks-proxy-agent
|
||||||
|
[http.Agent]: https://nodejs.org/api/http.html#http_class_http_agent
|
78
node_modules/agent-base/dist/src/index.d.ts
generated
vendored
Normal file
78
node_modules/agent-base/dist/src/index.d.ts
generated
vendored
Normal file
@@ -0,0 +1,78 @@
|
|||||||
|
/// <reference types="node" />
|
||||||
|
import net from 'net';
|
||||||
|
import http from 'http';
|
||||||
|
import https from 'https';
|
||||||
|
import { Duplex } from 'stream';
|
||||||
|
import { EventEmitter } from 'events';
|
||||||
|
declare function createAgent(opts?: createAgent.AgentOptions): createAgent.Agent;
|
||||||
|
declare function createAgent(callback: createAgent.AgentCallback, opts?: createAgent.AgentOptions): createAgent.Agent;
|
||||||
|
declare namespace createAgent {
|
||||||
|
interface ClientRequest extends http.ClientRequest {
|
||||||
|
_last?: boolean;
|
||||||
|
_hadError?: boolean;
|
||||||
|
method: string;
|
||||||
|
}
|
||||||
|
interface AgentRequestOptions {
|
||||||
|
host?: string;
|
||||||
|
path?: string;
|
||||||
|
port: number;
|
||||||
|
}
|
||||||
|
interface HttpRequestOptions extends AgentRequestOptions, Omit<http.RequestOptions, keyof AgentRequestOptions> {
|
||||||
|
secureEndpoint: false;
|
||||||
|
}
|
||||||
|
interface HttpsRequestOptions extends AgentRequestOptions, Omit<https.RequestOptions, keyof AgentRequestOptions> {
|
||||||
|
secureEndpoint: true;
|
||||||
|
}
|
||||||
|
type RequestOptions = HttpRequestOptions | HttpsRequestOptions;
|
||||||
|
type AgentLike = Pick<createAgent.Agent, 'addRequest'> | http.Agent;
|
||||||
|
type AgentCallbackReturn = Duplex | AgentLike;
|
||||||
|
type AgentCallbackCallback = (err?: Error | null, socket?: createAgent.AgentCallbackReturn) => void;
|
||||||
|
type AgentCallbackPromise = (req: createAgent.ClientRequest, opts: createAgent.RequestOptions) => createAgent.AgentCallbackReturn | Promise<createAgent.AgentCallbackReturn>;
|
||||||
|
type AgentCallback = typeof Agent.prototype.callback;
|
||||||
|
type AgentOptions = {
|
||||||
|
timeout?: number;
|
||||||
|
};
|
||||||
|
/**
|
||||||
|
* Base `http.Agent` implementation.
|
||||||
|
* No pooling/keep-alive is implemented by default.
|
||||||
|
*
|
||||||
|
* @param {Function} callback
|
||||||
|
* @api public
|
||||||
|
*/
|
||||||
|
class Agent extends EventEmitter {
|
||||||
|
timeout: number | null;
|
||||||
|
maxFreeSockets: number;
|
||||||
|
maxTotalSockets: number;
|
||||||
|
maxSockets: number;
|
||||||
|
sockets: {
|
||||||
|
[key: string]: net.Socket[];
|
||||||
|
};
|
||||||
|
freeSockets: {
|
||||||
|
[key: string]: net.Socket[];
|
||||||
|
};
|
||||||
|
requests: {
|
||||||
|
[key: string]: http.IncomingMessage[];
|
||||||
|
};
|
||||||
|
options: https.AgentOptions;
|
||||||
|
private promisifiedCallback?;
|
||||||
|
private explicitDefaultPort?;
|
||||||
|
private explicitProtocol?;
|
||||||
|
constructor(callback?: createAgent.AgentCallback | createAgent.AgentOptions, _opts?: createAgent.AgentOptions);
|
||||||
|
get defaultPort(): number;
|
||||||
|
set defaultPort(v: number);
|
||||||
|
get protocol(): string;
|
||||||
|
set protocol(v: string);
|
||||||
|
callback(req: createAgent.ClientRequest, opts: createAgent.RequestOptions, fn: createAgent.AgentCallbackCallback): void;
|
||||||
|
callback(req: createAgent.ClientRequest, opts: createAgent.RequestOptions): createAgent.AgentCallbackReturn | Promise<createAgent.AgentCallbackReturn>;
|
||||||
|
/**
|
||||||
|
* Called by node-core's "_http_client.js" module when creating
|
||||||
|
* a new HTTP request with this Agent instance.
|
||||||
|
*
|
||||||
|
* @api public
|
||||||
|
*/
|
||||||
|
addRequest(req: ClientRequest, _opts: RequestOptions): void;
|
||||||
|
freeSocket(socket: net.Socket, opts: AgentOptions): void;
|
||||||
|
destroy(): void;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
export = createAgent;
|
203
node_modules/agent-base/dist/src/index.js
generated
vendored
Normal file
203
node_modules/agent-base/dist/src/index.js
generated
vendored
Normal file
@@ -0,0 +1,203 @@
|
|||||||
|
"use strict";
|
||||||
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
||||||
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
||||||
|
};
|
||||||
|
const events_1 = require("events");
|
||||||
|
const debug_1 = __importDefault(require("debug"));
|
||||||
|
const promisify_1 = __importDefault(require("./promisify"));
|
||||||
|
const debug = debug_1.default('agent-base');
|
||||||
|
function isAgent(v) {
|
||||||
|
return Boolean(v) && typeof v.addRequest === 'function';
|
||||||
|
}
|
||||||
|
function isSecureEndpoint() {
|
||||||
|
const { stack } = new Error();
|
||||||
|
if (typeof stack !== 'string')
|
||||||
|
return false;
|
||||||
|
return stack.split('\n').some(l => l.indexOf('(https.js:') !== -1 || l.indexOf('node:https:') !== -1);
|
||||||
|
}
|
||||||
|
function createAgent(callback, opts) {
|
||||||
|
return new createAgent.Agent(callback, opts);
|
||||||
|
}
|
||||||
|
(function (createAgent) {
|
||||||
|
/**
|
||||||
|
* Base `http.Agent` implementation.
|
||||||
|
* No pooling/keep-alive is implemented by default.
|
||||||
|
*
|
||||||
|
* @param {Function} callback
|
||||||
|
* @api public
|
||||||
|
*/
|
||||||
|
class Agent extends events_1.EventEmitter {
|
||||||
|
constructor(callback, _opts) {
|
||||||
|
super();
|
||||||
|
let opts = _opts;
|
||||||
|
if (typeof callback === 'function') {
|
||||||
|
this.callback = callback;
|
||||||
|
}
|
||||||
|
else if (callback) {
|
||||||
|
opts = callback;
|
||||||
|
}
|
||||||
|
// Timeout for the socket to be returned from the callback
|
||||||
|
this.timeout = null;
|
||||||
|
if (opts && typeof opts.timeout === 'number') {
|
||||||
|
this.timeout = opts.timeout;
|
||||||
|
}
|
||||||
|
// These aren't actually used by `agent-base`, but are required
|
||||||
|
// for the TypeScript definition files in `@types/node` :/
|
||||||
|
this.maxFreeSockets = 1;
|
||||||
|
this.maxSockets = 1;
|
||||||
|
this.maxTotalSockets = Infinity;
|
||||||
|
this.sockets = {};
|
||||||
|
this.freeSockets = {};
|
||||||
|
this.requests = {};
|
||||||
|
this.options = {};
|
||||||
|
}
|
||||||
|
get defaultPort() {
|
||||||
|
if (typeof this.explicitDefaultPort === 'number') {
|
||||||
|
return this.explicitDefaultPort;
|
||||||
|
}
|
||||||
|
return isSecureEndpoint() ? 443 : 80;
|
||||||
|
}
|
||||||
|
set defaultPort(v) {
|
||||||
|
this.explicitDefaultPort = v;
|
||||||
|
}
|
||||||
|
get protocol() {
|
||||||
|
if (typeof this.explicitProtocol === 'string') {
|
||||||
|
return this.explicitProtocol;
|
||||||
|
}
|
||||||
|
return isSecureEndpoint() ? 'https:' : 'http:';
|
||||||
|
}
|
||||||
|
set protocol(v) {
|
||||||
|
this.explicitProtocol = v;
|
||||||
|
}
|
||||||
|
callback(req, opts, fn) {
|
||||||
|
throw new Error('"agent-base" has no default implementation, you must subclass and override `callback()`');
|
||||||
|
}
|
||||||
|
/**
|
||||||
|
* Called by node-core's "_http_client.js" module when creating
|
||||||
|
* a new HTTP request with this Agent instance.
|
||||||
|
*
|
||||||
|
* @api public
|
||||||
|
*/
|
||||||
|
addRequest(req, _opts) {
|
||||||
|
const opts = Object.assign({}, _opts);
|
||||||
|
if (typeof opts.secureEndpoint !== 'boolean') {
|
||||||
|
opts.secureEndpoint = isSecureEndpoint();
|
||||||
|
}
|
||||||
|
if (opts.host == null) {
|
||||||
|
opts.host = 'localhost';
|
||||||
|
}
|
||||||
|
if (opts.port == null) {
|
||||||
|
opts.port = opts.secureEndpoint ? 443 : 80;
|
||||||
|
}
|
||||||
|
if (opts.protocol == null) {
|
||||||
|
opts.protocol = opts.secureEndpoint ? 'https:' : 'http:';
|
||||||
|
}
|
||||||
|
if (opts.host && opts.path) {
|
||||||
|
// If both a `host` and `path` are specified then it's most
|
||||||
|
// likely the result of a `url.parse()` call... we need to
|
||||||
|
// remove the `path` portion so that `net.connect()` doesn't
|
||||||
|
// attempt to open that as a unix socket file.
|
||||||
|
delete opts.path;
|
||||||
|
}
|
||||||
|
delete opts.agent;
|
||||||
|
delete opts.hostname;
|
||||||
|
delete opts._defaultAgent;
|
||||||
|
delete opts.defaultPort;
|
||||||
|
delete opts.createConnection;
|
||||||
|
// Hint to use "Connection: close"
|
||||||
|
// XXX: non-documented `http` module API :(
|
||||||
|
req._last = true;
|
||||||
|
req.shouldKeepAlive = false;
|
||||||
|
let timedOut = false;
|
||||||
|
let timeoutId = null;
|
||||||
|
const timeoutMs = opts.timeout || this.timeout;
|
||||||
|
const onerror = (err) => {
|
||||||
|
if (req._hadError)
|
||||||
|
return;
|
||||||
|
req.emit('error', err);
|
||||||
|
// For Safety. Some additional errors might fire later on
|
||||||
|
// and we need to make sure we don't double-fire the error event.
|
||||||
|
req._hadError = true;
|
||||||
|
};
|
||||||
|
const ontimeout = () => {
|
||||||
|
timeoutId = null;
|
||||||
|
timedOut = true;
|
||||||
|
const err = new Error(`A "socket" was not created for HTTP request before ${timeoutMs}ms`);
|
||||||
|
err.code = 'ETIMEOUT';
|
||||||
|
onerror(err);
|
||||||
|
};
|
||||||
|
const callbackError = (err) => {
|
||||||
|
if (timedOut)
|
||||||
|
return;
|
||||||
|
if (timeoutId !== null) {
|
||||||
|
clearTimeout(timeoutId);
|
||||||
|
timeoutId = null;
|
||||||
|
}
|
||||||
|
onerror(err);
|
||||||
|
};
|
||||||
|
const onsocket = (socket) => {
|
||||||
|
if (timedOut)
|
||||||
|
return;
|
||||||
|
if (timeoutId != null) {
|
||||||
|
clearTimeout(timeoutId);
|
||||||
|
timeoutId = null;
|
||||||
|
}
|
||||||
|
if (isAgent(socket)) {
|
||||||
|
// `socket` is actually an `http.Agent` instance, so
|
||||||
|
// relinquish responsibility for this `req` to the Agent
|
||||||
|
// from here on
|
||||||
|
debug('Callback returned another Agent instance %o', socket.constructor.name);
|
||||||
|
socket.addRequest(req, opts);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (socket) {
|
||||||
|
socket.once('free', () => {
|
||||||
|
this.freeSocket(socket, opts);
|
||||||
|
});
|
||||||
|
req.onSocket(socket);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const err = new Error(`no Duplex stream was returned to agent-base for \`${req.method} ${req.path}\``);
|
||||||
|
onerror(err);
|
||||||
|
};
|
||||||
|
if (typeof this.callback !== 'function') {
|
||||||
|
onerror(new Error('`callback` is not defined'));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (!this.promisifiedCallback) {
|
||||||
|
if (this.callback.length >= 3) {
|
||||||
|
debug('Converting legacy callback function to promise');
|
||||||
|
this.promisifiedCallback = promisify_1.default(this.callback);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
this.promisifiedCallback = this.callback;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (typeof timeoutMs === 'number' && timeoutMs > 0) {
|
||||||
|
timeoutId = setTimeout(ontimeout, timeoutMs);
|
||||||
|
}
|
||||||
|
if ('port' in opts && typeof opts.port !== 'number') {
|
||||||
|
opts.port = Number(opts.port);
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
debug('Resolving socket for %o request: %o', opts.protocol, `${req.method} ${req.path}`);
|
||||||
|
Promise.resolve(this.promisifiedCallback(req, opts)).then(onsocket, callbackError);
|
||||||
|
}
|
||||||
|
catch (err) {
|
||||||
|
Promise.reject(err).catch(callbackError);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
freeSocket(socket, opts) {
|
||||||
|
debug('Freeing socket %o %o', socket.constructor.name, opts);
|
||||||
|
socket.destroy();
|
||||||
|
}
|
||||||
|
destroy() {
|
||||||
|
debug('Destroying agent %o', this.constructor.name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
createAgent.Agent = Agent;
|
||||||
|
// So that `instanceof` works correctly
|
||||||
|
createAgent.prototype = createAgent.Agent.prototype;
|
||||||
|
})(createAgent || (createAgent = {}));
|
||||||
|
module.exports = createAgent;
|
||||||
|
//# sourceMappingURL=index.js.map
|
1
node_modules/agent-base/dist/src/index.js.map
generated
vendored
Normal file
1
node_modules/agent-base/dist/src/index.js.map
generated
vendored
Normal file
File diff suppressed because one or more lines are too long
4
node_modules/agent-base/dist/src/promisify.d.ts
generated
vendored
Normal file
4
node_modules/agent-base/dist/src/promisify.d.ts
generated
vendored
Normal file
@@ -0,0 +1,4 @@
|
|||||||
|
import { ClientRequest, RequestOptions, AgentCallbackCallback, AgentCallbackPromise } from './index';
|
||||||
|
declare type LegacyCallback = (req: ClientRequest, opts: RequestOptions, fn: AgentCallbackCallback) => void;
|
||||||
|
export default function promisify(fn: LegacyCallback): AgentCallbackPromise;
|
||||||
|
export {};
|
18
node_modules/agent-base/dist/src/promisify.js
generated
vendored
Normal file
18
node_modules/agent-base/dist/src/promisify.js
generated
vendored
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
"use strict";
|
||||||
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
|
function promisify(fn) {
|
||||||
|
return function (req, opts) {
|
||||||
|
return new Promise((resolve, reject) => {
|
||||||
|
fn.call(this, req, opts, (err, rtn) => {
|
||||||
|
if (err) {
|
||||||
|
reject(err);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
resolve(rtn);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
};
|
||||||
|
}
|
||||||
|
exports.default = promisify;
|
||||||
|
//# sourceMappingURL=promisify.js.map
|
1
node_modules/agent-base/dist/src/promisify.js.map
generated
vendored
Normal file
1
node_modules/agent-base/dist/src/promisify.js.map
generated
vendored
Normal file
@@ -0,0 +1 @@
|
|||||||
|
{"version":3,"file":"promisify.js","sourceRoot":"","sources":["../../src/promisify.ts"],"names":[],"mappings":";;AAeA,SAAwB,SAAS,CAAC,EAAkB;IACnD,OAAO,UAAsB,GAAkB,EAAE,IAAoB;QACpE,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACtC,EAAE,CAAC,IAAI,CACN,IAAI,EACJ,GAAG,EACH,IAAI,EACJ,CAAC,GAA6B,EAAE,GAAyB,EAAE,EAAE;gBAC5D,IAAI,GAAG,EAAE;oBACR,MAAM,CAAC,GAAG,CAAC,CAAC;iBACZ;qBAAM;oBACN,OAAO,CAAC,GAAG,CAAC,CAAC;iBACb;YACF,CAAC,CACD,CAAC;QACH,CAAC,CAAC,CAAC;IACJ,CAAC,CAAC;AACH,CAAC;AAjBD,4BAiBC"}
|
95
node_modules/agent-base/package.json
generated
vendored
Normal file
95
node_modules/agent-base/package.json
generated
vendored
Normal file
@@ -0,0 +1,95 @@
|
|||||||
|
{
|
||||||
|
"_from": "agent-base@6",
|
||||||
|
"_id": "agent-base@6.0.2",
|
||||||
|
"_inBundle": false,
|
||||||
|
"_integrity": "sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==",
|
||||||
|
"_location": "/agent-base",
|
||||||
|
"_phantomChildren": {},
|
||||||
|
"_requested": {
|
||||||
|
"type": "range",
|
||||||
|
"registry": true,
|
||||||
|
"raw": "agent-base@6",
|
||||||
|
"name": "agent-base",
|
||||||
|
"escapedName": "agent-base",
|
||||||
|
"rawSpec": "6",
|
||||||
|
"saveSpec": null,
|
||||||
|
"fetchSpec": "6"
|
||||||
|
},
|
||||||
|
"_requiredBy": [
|
||||||
|
"/http-proxy-agent",
|
||||||
|
"/https-proxy-agent"
|
||||||
|
],
|
||||||
|
"_resolved": "https://registry.npmjs.org/agent-base/-/agent-base-6.0.2.tgz",
|
||||||
|
"_shasum": "49fff58577cfee3f37176feab4c22e00f86d7f77",
|
||||||
|
"_spec": "agent-base@6",
|
||||||
|
"_where": "D:\\Projects\\minifyfromhtml\\node_modules\\http-proxy-agent",
|
||||||
|
"author": {
|
||||||
|
"name": "Nathan Rajlich",
|
||||||
|
"email": "nathan@tootallnate.net",
|
||||||
|
"url": "http://n8.io/"
|
||||||
|
},
|
||||||
|
"bugs": {
|
||||||
|
"url": "https://github.com/TooTallNate/node-agent-base/issues"
|
||||||
|
},
|
||||||
|
"bundleDependencies": false,
|
||||||
|
"dependencies": {
|
||||||
|
"debug": "4"
|
||||||
|
},
|
||||||
|
"deprecated": false,
|
||||||
|
"description": "Turn a function into an `http.Agent` instance",
|
||||||
|
"devDependencies": {
|
||||||
|
"@types/debug": "4",
|
||||||
|
"@types/mocha": "^5.2.7",
|
||||||
|
"@types/node": "^14.0.20",
|
||||||
|
"@types/semver": "^7.1.0",
|
||||||
|
"@types/ws": "^6.0.3",
|
||||||
|
"@typescript-eslint/eslint-plugin": "1.6.0",
|
||||||
|
"@typescript-eslint/parser": "1.1.0",
|
||||||
|
"async-listen": "^1.2.0",
|
||||||
|
"cpy-cli": "^2.0.0",
|
||||||
|
"eslint": "5.16.0",
|
||||||
|
"eslint-config-airbnb": "17.1.0",
|
||||||
|
"eslint-config-prettier": "4.1.0",
|
||||||
|
"eslint-import-resolver-typescript": "1.1.1",
|
||||||
|
"eslint-plugin-import": "2.16.0",
|
||||||
|
"eslint-plugin-jsx-a11y": "6.2.1",
|
||||||
|
"eslint-plugin-react": "7.12.4",
|
||||||
|
"mocha": "^6.2.0",
|
||||||
|
"rimraf": "^3.0.0",
|
||||||
|
"semver": "^7.1.2",
|
||||||
|
"typescript": "^3.5.3",
|
||||||
|
"ws": "^3.0.0"
|
||||||
|
},
|
||||||
|
"engines": {
|
||||||
|
"node": ">= 6.0.0"
|
||||||
|
},
|
||||||
|
"files": [
|
||||||
|
"dist/src",
|
||||||
|
"src"
|
||||||
|
],
|
||||||
|
"homepage": "https://github.com/TooTallNate/node-agent-base#readme",
|
||||||
|
"keywords": [
|
||||||
|
"http",
|
||||||
|
"agent",
|
||||||
|
"base",
|
||||||
|
"barebones",
|
||||||
|
"https"
|
||||||
|
],
|
||||||
|
"license": "MIT",
|
||||||
|
"main": "dist/src/index",
|
||||||
|
"name": "agent-base",
|
||||||
|
"repository": {
|
||||||
|
"type": "git",
|
||||||
|
"url": "git://github.com/TooTallNate/node-agent-base.git"
|
||||||
|
},
|
||||||
|
"scripts": {
|
||||||
|
"build": "tsc",
|
||||||
|
"postbuild": "cpy --parents src test '!**/*.ts' dist",
|
||||||
|
"prebuild": "rimraf dist",
|
||||||
|
"prepublishOnly": "npm run build",
|
||||||
|
"test": "mocha --reporter spec dist/test/*.js",
|
||||||
|
"test-lint": "eslint src --ext .js,.ts"
|
||||||
|
},
|
||||||
|
"typings": "dist/src/index",
|
||||||
|
"version": "6.0.2"
|
||||||
|
}
|
345
node_modules/agent-base/src/index.ts
generated
vendored
Normal file
345
node_modules/agent-base/src/index.ts
generated
vendored
Normal file
@@ -0,0 +1,345 @@
|
|||||||
|
import net from 'net';
|
||||||
|
import http from 'http';
|
||||||
|
import https from 'https';
|
||||||
|
import { Duplex } from 'stream';
|
||||||
|
import { EventEmitter } from 'events';
|
||||||
|
import createDebug from 'debug';
|
||||||
|
import promisify from './promisify';
|
||||||
|
|
||||||
|
const debug = createDebug('agent-base');
|
||||||
|
|
||||||
|
function isAgent(v: any): v is createAgent.AgentLike {
|
||||||
|
return Boolean(v) && typeof v.addRequest === 'function';
|
||||||
|
}
|
||||||
|
|
||||||
|
function isSecureEndpoint(): boolean {
|
||||||
|
const { stack } = new Error();
|
||||||
|
if (typeof stack !== 'string') return false;
|
||||||
|
return stack.split('\n').some(l => l.indexOf('(https.js:') !== -1 || l.indexOf('node:https:') !== -1);
|
||||||
|
}
|
||||||
|
|
||||||
|
function createAgent(opts?: createAgent.AgentOptions): createAgent.Agent;
|
||||||
|
function createAgent(
|
||||||
|
callback: createAgent.AgentCallback,
|
||||||
|
opts?: createAgent.AgentOptions
|
||||||
|
): createAgent.Agent;
|
||||||
|
function createAgent(
|
||||||
|
callback?: createAgent.AgentCallback | createAgent.AgentOptions,
|
||||||
|
opts?: createAgent.AgentOptions
|
||||||
|
) {
|
||||||
|
return new createAgent.Agent(callback, opts);
|
||||||
|
}
|
||||||
|
|
||||||
|
namespace createAgent {
|
||||||
|
export interface ClientRequest extends http.ClientRequest {
|
||||||
|
_last?: boolean;
|
||||||
|
_hadError?: boolean;
|
||||||
|
method: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface AgentRequestOptions {
|
||||||
|
host?: string;
|
||||||
|
path?: string;
|
||||||
|
// `port` on `http.RequestOptions` can be a string or undefined,
|
||||||
|
// but `net.TcpNetConnectOpts` expects only a number
|
||||||
|
port: number;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface HttpRequestOptions
|
||||||
|
extends AgentRequestOptions,
|
||||||
|
Omit<http.RequestOptions, keyof AgentRequestOptions> {
|
||||||
|
secureEndpoint: false;
|
||||||
|
}
|
||||||
|
|
||||||
|
export interface HttpsRequestOptions
|
||||||
|
extends AgentRequestOptions,
|
||||||
|
Omit<https.RequestOptions, keyof AgentRequestOptions> {
|
||||||
|
secureEndpoint: true;
|
||||||
|
}
|
||||||
|
|
||||||
|
export type RequestOptions = HttpRequestOptions | HttpsRequestOptions;
|
||||||
|
|
||||||
|
export type AgentLike = Pick<createAgent.Agent, 'addRequest'> | http.Agent;
|
||||||
|
|
||||||
|
export type AgentCallbackReturn = Duplex | AgentLike;
|
||||||
|
|
||||||
|
export type AgentCallbackCallback = (
|
||||||
|
err?: Error | null,
|
||||||
|
socket?: createAgent.AgentCallbackReturn
|
||||||
|
) => void;
|
||||||
|
|
||||||
|
export type AgentCallbackPromise = (
|
||||||
|
req: createAgent.ClientRequest,
|
||||||
|
opts: createAgent.RequestOptions
|
||||||
|
) =>
|
||||||
|
| createAgent.AgentCallbackReturn
|
||||||
|
| Promise<createAgent.AgentCallbackReturn>;
|
||||||
|
|
||||||
|
export type AgentCallback = typeof Agent.prototype.callback;
|
||||||
|
|
||||||
|
export type AgentOptions = {
|
||||||
|
timeout?: number;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Base `http.Agent` implementation.
|
||||||
|
* No pooling/keep-alive is implemented by default.
|
||||||
|
*
|
||||||
|
* @param {Function} callback
|
||||||
|
* @api public
|
||||||
|
*/
|
||||||
|
export class Agent extends EventEmitter {
|
||||||
|
public timeout: number | null;
|
||||||
|
public maxFreeSockets: number;
|
||||||
|
public maxTotalSockets: number;
|
||||||
|
public maxSockets: number;
|
||||||
|
public sockets: {
|
||||||
|
[key: string]: net.Socket[];
|
||||||
|
};
|
||||||
|
public freeSockets: {
|
||||||
|
[key: string]: net.Socket[];
|
||||||
|
};
|
||||||
|
public requests: {
|
||||||
|
[key: string]: http.IncomingMessage[];
|
||||||
|
};
|
||||||
|
public options: https.AgentOptions;
|
||||||
|
private promisifiedCallback?: createAgent.AgentCallbackPromise;
|
||||||
|
private explicitDefaultPort?: number;
|
||||||
|
private explicitProtocol?: string;
|
||||||
|
|
||||||
|
constructor(
|
||||||
|
callback?: createAgent.AgentCallback | createAgent.AgentOptions,
|
||||||
|
_opts?: createAgent.AgentOptions
|
||||||
|
) {
|
||||||
|
super();
|
||||||
|
|
||||||
|
let opts = _opts;
|
||||||
|
if (typeof callback === 'function') {
|
||||||
|
this.callback = callback;
|
||||||
|
} else if (callback) {
|
||||||
|
opts = callback;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Timeout for the socket to be returned from the callback
|
||||||
|
this.timeout = null;
|
||||||
|
if (opts && typeof opts.timeout === 'number') {
|
||||||
|
this.timeout = opts.timeout;
|
||||||
|
}
|
||||||
|
|
||||||
|
// These aren't actually used by `agent-base`, but are required
|
||||||
|
// for the TypeScript definition files in `@types/node` :/
|
||||||
|
this.maxFreeSockets = 1;
|
||||||
|
this.maxSockets = 1;
|
||||||
|
this.maxTotalSockets = Infinity;
|
||||||
|
this.sockets = {};
|
||||||
|
this.freeSockets = {};
|
||||||
|
this.requests = {};
|
||||||
|
this.options = {};
|
||||||
|
}
|
||||||
|
|
||||||
|
get defaultPort(): number {
|
||||||
|
if (typeof this.explicitDefaultPort === 'number') {
|
||||||
|
return this.explicitDefaultPort;
|
||||||
|
}
|
||||||
|
return isSecureEndpoint() ? 443 : 80;
|
||||||
|
}
|
||||||
|
|
||||||
|
set defaultPort(v: number) {
|
||||||
|
this.explicitDefaultPort = v;
|
||||||
|
}
|
||||||
|
|
||||||
|
get protocol(): string {
|
||||||
|
if (typeof this.explicitProtocol === 'string') {
|
||||||
|
return this.explicitProtocol;
|
||||||
|
}
|
||||||
|
return isSecureEndpoint() ? 'https:' : 'http:';
|
||||||
|
}
|
||||||
|
|
||||||
|
set protocol(v: string) {
|
||||||
|
this.explicitProtocol = v;
|
||||||
|
}
|
||||||
|
|
||||||
|
callback(
|
||||||
|
req: createAgent.ClientRequest,
|
||||||
|
opts: createAgent.RequestOptions,
|
||||||
|
fn: createAgent.AgentCallbackCallback
|
||||||
|
): void;
|
||||||
|
callback(
|
||||||
|
req: createAgent.ClientRequest,
|
||||||
|
opts: createAgent.RequestOptions
|
||||||
|
):
|
||||||
|
| createAgent.AgentCallbackReturn
|
||||||
|
| Promise<createAgent.AgentCallbackReturn>;
|
||||||
|
callback(
|
||||||
|
req: createAgent.ClientRequest,
|
||||||
|
opts: createAgent.AgentOptions,
|
||||||
|
fn?: createAgent.AgentCallbackCallback
|
||||||
|
):
|
||||||
|
| createAgent.AgentCallbackReturn
|
||||||
|
| Promise<createAgent.AgentCallbackReturn>
|
||||||
|
| void {
|
||||||
|
throw new Error(
|
||||||
|
'"agent-base" has no default implementation, you must subclass and override `callback()`'
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Called by node-core's "_http_client.js" module when creating
|
||||||
|
* a new HTTP request with this Agent instance.
|
||||||
|
*
|
||||||
|
* @api public
|
||||||
|
*/
|
||||||
|
addRequest(req: ClientRequest, _opts: RequestOptions): void {
|
||||||
|
const opts: RequestOptions = { ..._opts };
|
||||||
|
|
||||||
|
if (typeof opts.secureEndpoint !== 'boolean') {
|
||||||
|
opts.secureEndpoint = isSecureEndpoint();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (opts.host == null) {
|
||||||
|
opts.host = 'localhost';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (opts.port == null) {
|
||||||
|
opts.port = opts.secureEndpoint ? 443 : 80;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (opts.protocol == null) {
|
||||||
|
opts.protocol = opts.secureEndpoint ? 'https:' : 'http:';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (opts.host && opts.path) {
|
||||||
|
// If both a `host` and `path` are specified then it's most
|
||||||
|
// likely the result of a `url.parse()` call... we need to
|
||||||
|
// remove the `path` portion so that `net.connect()` doesn't
|
||||||
|
// attempt to open that as a unix socket file.
|
||||||
|
delete opts.path;
|
||||||
|
}
|
||||||
|
|
||||||
|
delete opts.agent;
|
||||||
|
delete opts.hostname;
|
||||||
|
delete opts._defaultAgent;
|
||||||
|
delete opts.defaultPort;
|
||||||
|
delete opts.createConnection;
|
||||||
|
|
||||||
|
// Hint to use "Connection: close"
|
||||||
|
// XXX: non-documented `http` module API :(
|
||||||
|
req._last = true;
|
||||||
|
req.shouldKeepAlive = false;
|
||||||
|
|
||||||
|
let timedOut = false;
|
||||||
|
let timeoutId: ReturnType<typeof setTimeout> | null = null;
|
||||||
|
const timeoutMs = opts.timeout || this.timeout;
|
||||||
|
|
||||||
|
const onerror = (err: NodeJS.ErrnoException) => {
|
||||||
|
if (req._hadError) return;
|
||||||
|
req.emit('error', err);
|
||||||
|
// For Safety. Some additional errors might fire later on
|
||||||
|
// and we need to make sure we don't double-fire the error event.
|
||||||
|
req._hadError = true;
|
||||||
|
};
|
||||||
|
|
||||||
|
const ontimeout = () => {
|
||||||
|
timeoutId = null;
|
||||||
|
timedOut = true;
|
||||||
|
const err: NodeJS.ErrnoException = new Error(
|
||||||
|
`A "socket" was not created for HTTP request before ${timeoutMs}ms`
|
||||||
|
);
|
||||||
|
err.code = 'ETIMEOUT';
|
||||||
|
onerror(err);
|
||||||
|
};
|
||||||
|
|
||||||
|
const callbackError = (err: NodeJS.ErrnoException) => {
|
||||||
|
if (timedOut) return;
|
||||||
|
if (timeoutId !== null) {
|
||||||
|
clearTimeout(timeoutId);
|
||||||
|
timeoutId = null;
|
||||||
|
}
|
||||||
|
onerror(err);
|
||||||
|
};
|
||||||
|
|
||||||
|
const onsocket = (socket: AgentCallbackReturn) => {
|
||||||
|
if (timedOut) return;
|
||||||
|
if (timeoutId != null) {
|
||||||
|
clearTimeout(timeoutId);
|
||||||
|
timeoutId = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (isAgent(socket)) {
|
||||||
|
// `socket` is actually an `http.Agent` instance, so
|
||||||
|
// relinquish responsibility for this `req` to the Agent
|
||||||
|
// from here on
|
||||||
|
debug(
|
||||||
|
'Callback returned another Agent instance %o',
|
||||||
|
socket.constructor.name
|
||||||
|
);
|
||||||
|
(socket as createAgent.Agent).addRequest(req, opts);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (socket) {
|
||||||
|
socket.once('free', () => {
|
||||||
|
this.freeSocket(socket as net.Socket, opts);
|
||||||
|
});
|
||||||
|
req.onSocket(socket as net.Socket);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
const err = new Error(
|
||||||
|
`no Duplex stream was returned to agent-base for \`${req.method} ${req.path}\``
|
||||||
|
);
|
||||||
|
onerror(err);
|
||||||
|
};
|
||||||
|
|
||||||
|
if (typeof this.callback !== 'function') {
|
||||||
|
onerror(new Error('`callback` is not defined'));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!this.promisifiedCallback) {
|
||||||
|
if (this.callback.length >= 3) {
|
||||||
|
debug('Converting legacy callback function to promise');
|
||||||
|
this.promisifiedCallback = promisify(this.callback);
|
||||||
|
} else {
|
||||||
|
this.promisifiedCallback = this.callback;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (typeof timeoutMs === 'number' && timeoutMs > 0) {
|
||||||
|
timeoutId = setTimeout(ontimeout, timeoutMs);
|
||||||
|
}
|
||||||
|
|
||||||
|
if ('port' in opts && typeof opts.port !== 'number') {
|
||||||
|
opts.port = Number(opts.port);
|
||||||
|
}
|
||||||
|
|
||||||
|
try {
|
||||||
|
debug(
|
||||||
|
'Resolving socket for %o request: %o',
|
||||||
|
opts.protocol,
|
||||||
|
`${req.method} ${req.path}`
|
||||||
|
);
|
||||||
|
Promise.resolve(this.promisifiedCallback(req, opts)).then(
|
||||||
|
onsocket,
|
||||||
|
callbackError
|
||||||
|
);
|
||||||
|
} catch (err) {
|
||||||
|
Promise.reject(err).catch(callbackError);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
freeSocket(socket: net.Socket, opts: AgentOptions) {
|
||||||
|
debug('Freeing socket %o %o', socket.constructor.name, opts);
|
||||||
|
socket.destroy();
|
||||||
|
}
|
||||||
|
|
||||||
|
destroy() {
|
||||||
|
debug('Destroying agent %o', this.constructor.name);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// So that `instanceof` works correctly
|
||||||
|
createAgent.prototype = createAgent.Agent.prototype;
|
||||||
|
}
|
||||||
|
|
||||||
|
export = createAgent;
|
33
node_modules/agent-base/src/promisify.ts
generated
vendored
Normal file
33
node_modules/agent-base/src/promisify.ts
generated
vendored
Normal file
@@ -0,0 +1,33 @@
|
|||||||
|
import {
|
||||||
|
Agent,
|
||||||
|
ClientRequest,
|
||||||
|
RequestOptions,
|
||||||
|
AgentCallbackCallback,
|
||||||
|
AgentCallbackPromise,
|
||||||
|
AgentCallbackReturn
|
||||||
|
} from './index';
|
||||||
|
|
||||||
|
type LegacyCallback = (
|
||||||
|
req: ClientRequest,
|
||||||
|
opts: RequestOptions,
|
||||||
|
fn: AgentCallbackCallback
|
||||||
|
) => void;
|
||||||
|
|
||||||
|
export default function promisify(fn: LegacyCallback): AgentCallbackPromise {
|
||||||
|
return function(this: Agent, req: ClientRequest, opts: RequestOptions) {
|
||||||
|
return new Promise((resolve, reject) => {
|
||||||
|
fn.call(
|
||||||
|
this,
|
||||||
|
req,
|
||||||
|
opts,
|
||||||
|
(err: Error | null | undefined, rtn?: AgentCallbackReturn) => {
|
||||||
|
if (err) {
|
||||||
|
reject(err);
|
||||||
|
} else {
|
||||||
|
resolve(rtn);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
);
|
||||||
|
});
|
||||||
|
};
|
||||||
|
}
|
20
node_modules/ajv/.tonic_example.js
generated
vendored
20
node_modules/ajv/.tonic_example.js
generated
vendored
@@ -1,20 +0,0 @@
|
|||||||
var Ajv = require('ajv');
|
|
||||||
var ajv = new Ajv({allErrors: true});
|
|
||||||
|
|
||||||
var schema = {
|
|
||||||
"properties": {
|
|
||||||
"foo": { "type": "string" },
|
|
||||||
"bar": { "type": "number", "maximum": 3 }
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
var validate = ajv.compile(schema);
|
|
||||||
|
|
||||||
test({"foo": "abc", "bar": 2});
|
|
||||||
test({"foo": 2, "bar": 4});
|
|
||||||
|
|
||||||
function test(data) {
|
|
||||||
var valid = validate(data);
|
|
||||||
if (valid) console.log('Valid!');
|
|
||||||
else console.log('Invalid: ' + ajv.errorsText(validate.errors));
|
|
||||||
}
|
|
1380
node_modules/ajv/README.md
generated
vendored
1380
node_modules/ajv/README.md
generated
vendored
File diff suppressed because it is too large
Load Diff
7163
node_modules/ajv/dist/ajv.bundle.js
generated
vendored
7163
node_modules/ajv/dist/ajv.bundle.js
generated
vendored
File diff suppressed because it is too large
Load Diff
3
node_modules/ajv/dist/ajv.min.js
generated
vendored
3
node_modules/ajv/dist/ajv.min.js
generated
vendored
File diff suppressed because one or more lines are too long
1
node_modules/ajv/dist/ajv.min.js.map
generated
vendored
1
node_modules/ajv/dist/ajv.min.js.map
generated
vendored
File diff suppressed because one or more lines are too long
391
node_modules/ajv/lib/ajv.d.ts
generated
vendored
391
node_modules/ajv/lib/ajv.d.ts
generated
vendored
@@ -1,391 +0,0 @@
|
|||||||
declare var ajv: {
|
|
||||||
(options?: ajv.Options): ajv.Ajv;
|
|
||||||
new(options?: ajv.Options): ajv.Ajv;
|
|
||||||
ValidationError: typeof AjvErrors.ValidationError;
|
|
||||||
MissingRefError: typeof AjvErrors.MissingRefError;
|
|
||||||
$dataMetaSchema: object;
|
|
||||||
}
|
|
||||||
|
|
||||||
declare namespace AjvErrors {
|
|
||||||
class ValidationError extends Error {
|
|
||||||
constructor(errors: Array<ajv.ErrorObject>);
|
|
||||||
|
|
||||||
message: string;
|
|
||||||
errors: Array<ajv.ErrorObject>;
|
|
||||||
ajv: true;
|
|
||||||
validation: true;
|
|
||||||
}
|
|
||||||
|
|
||||||
class MissingRefError extends Error {
|
|
||||||
constructor(baseId: string, ref: string, message?: string);
|
|
||||||
static message: (baseId: string, ref: string) => string;
|
|
||||||
|
|
||||||
message: string;
|
|
||||||
missingRef: string;
|
|
||||||
missingSchema: string;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
declare namespace ajv {
|
|
||||||
type ValidationError = AjvErrors.ValidationError;
|
|
||||||
|
|
||||||
type MissingRefError = AjvErrors.MissingRefError;
|
|
||||||
|
|
||||||
interface Ajv {
|
|
||||||
/**
|
|
||||||
* Validate data using schema
|
|
||||||
* Schema will be compiled and cached (using serialized JSON as key, [fast-json-stable-stringify](https://github.com/epoberezkin/fast-json-stable-stringify) is used to serialize by default).
|
|
||||||
* @param {string|object|Boolean} schemaKeyRef key, ref or schema object
|
|
||||||
* @param {Any} data to be validated
|
|
||||||
* @return {Boolean} validation result. Errors from the last validation will be available in `ajv.errors` (and also in compiled schema: `schema.errors`).
|
|
||||||
*/
|
|
||||||
validate(schemaKeyRef: object | string | boolean, data: any): boolean | PromiseLike<any>;
|
|
||||||
/**
|
|
||||||
* Create validating function for passed schema.
|
|
||||||
* @param {object|Boolean} schema schema object
|
|
||||||
* @return {Function} validating function
|
|
||||||
*/
|
|
||||||
compile(schema: object | boolean): ValidateFunction;
|
|
||||||
/**
|
|
||||||
* Creates validating function for passed schema with asynchronous loading of missing schemas.
|
|
||||||
* `loadSchema` option should be a function that accepts schema uri and node-style callback.
|
|
||||||
* @this Ajv
|
|
||||||
* @param {object|Boolean} schema schema object
|
|
||||||
* @param {Boolean} meta optional true to compile meta-schema; this parameter can be skipped
|
|
||||||
* @param {Function} callback optional node-style callback, it is always called with 2 parameters: error (or null) and validating function.
|
|
||||||
* @return {PromiseLike<ValidateFunction>} validating function
|
|
||||||
*/
|
|
||||||
compileAsync(schema: object | boolean, meta?: Boolean, callback?: (err: Error, validate: ValidateFunction) => any): PromiseLike<ValidateFunction>;
|
|
||||||
/**
|
|
||||||
* Adds schema to the instance.
|
|
||||||
* @param {object|Array} schema schema or array of schemas. If array is passed, `key` and other parameters will be ignored.
|
|
||||||
* @param {string} key Optional schema key. Can be passed to `validate` method instead of schema object or id/ref. One schema per instance can have empty `id` and `key`.
|
|
||||||
* @return {Ajv} this for method chaining
|
|
||||||
*/
|
|
||||||
addSchema(schema: Array<object> | object, key?: string): Ajv;
|
|
||||||
/**
|
|
||||||
* Add schema that will be used to validate other schemas
|
|
||||||
* options in META_IGNORE_OPTIONS are alway set to false
|
|
||||||
* @param {object} schema schema object
|
|
||||||
* @param {string} key optional schema key
|
|
||||||
* @return {Ajv} this for method chaining
|
|
||||||
*/
|
|
||||||
addMetaSchema(schema: object, key?: string): Ajv;
|
|
||||||
/**
|
|
||||||
* Validate schema
|
|
||||||
* @param {object|Boolean} schema schema to validate
|
|
||||||
* @return {Boolean} true if schema is valid
|
|
||||||
*/
|
|
||||||
validateSchema(schema: object | boolean): boolean;
|
|
||||||
/**
|
|
||||||
* Get compiled schema from the instance by `key` or `ref`.
|
|
||||||
* @param {string} keyRef `key` that was passed to `addSchema` or full schema reference (`schema.id` or resolved id).
|
|
||||||
* @return {Function} schema validating function (with property `schema`).
|
|
||||||
*/
|
|
||||||
getSchema(keyRef: string): ValidateFunction;
|
|
||||||
/**
|
|
||||||
* Remove cached schema(s).
|
|
||||||
* If no parameter is passed all schemas but meta-schemas are removed.
|
|
||||||
* If RegExp is passed all schemas with key/id matching pattern but meta-schemas are removed.
|
|
||||||
* Even if schema is referenced by other schemas it still can be removed as other schemas have local references.
|
|
||||||
* @param {string|object|RegExp|Boolean} schemaKeyRef key, ref, pattern to match key/ref or schema object
|
|
||||||
* @return {Ajv} this for method chaining
|
|
||||||
*/
|
|
||||||
removeSchema(schemaKeyRef?: object | string | RegExp | boolean): Ajv;
|
|
||||||
/**
|
|
||||||
* Add custom format
|
|
||||||
* @param {string} name format name
|
|
||||||
* @param {string|RegExp|Function} format string is converted to RegExp; function should return boolean (true when valid)
|
|
||||||
* @return {Ajv} this for method chaining
|
|
||||||
*/
|
|
||||||
addFormat(name: string, format: FormatValidator | FormatDefinition): Ajv;
|
|
||||||
/**
|
|
||||||
* Define custom keyword
|
|
||||||
* @this Ajv
|
|
||||||
* @param {string} keyword custom keyword, should be a valid identifier, should be different from all standard, custom and macro keywords.
|
|
||||||
* @param {object} definition keyword definition object with properties `type` (type(s) which the keyword applies to), `validate` or `compile`.
|
|
||||||
* @return {Ajv} this for method chaining
|
|
||||||
*/
|
|
||||||
addKeyword(keyword: string, definition: KeywordDefinition): Ajv;
|
|
||||||
/**
|
|
||||||
* Get keyword definition
|
|
||||||
* @this Ajv
|
|
||||||
* @param {string} keyword pre-defined or custom keyword.
|
|
||||||
* @return {object|Boolean} custom keyword definition, `true` if it is a predefined keyword, `false` otherwise.
|
|
||||||
*/
|
|
||||||
getKeyword(keyword: string): object | boolean;
|
|
||||||
/**
|
|
||||||
* Remove keyword
|
|
||||||
* @this Ajv
|
|
||||||
* @param {string} keyword pre-defined or custom keyword.
|
|
||||||
* @return {Ajv} this for method chaining
|
|
||||||
*/
|
|
||||||
removeKeyword(keyword: string): Ajv;
|
|
||||||
/**
|
|
||||||
* Validate keyword
|
|
||||||
* @this Ajv
|
|
||||||
* @param {object} definition keyword definition object
|
|
||||||
* @param {boolean} throwError true to throw exception if definition is invalid
|
|
||||||
* @return {boolean} validation result
|
|
||||||
*/
|
|
||||||
validateKeyword(definition: KeywordDefinition, throwError: boolean): boolean;
|
|
||||||
/**
|
|
||||||
* Convert array of error message objects to string
|
|
||||||
* @param {Array<object>} errors optional array of validation errors, if not passed errors from the instance are used.
|
|
||||||
* @param {object} options optional options with properties `separator` and `dataVar`.
|
|
||||||
* @return {string} human readable string with all errors descriptions
|
|
||||||
*/
|
|
||||||
errorsText(errors?: Array<ErrorObject> | null, options?: ErrorsTextOptions): string;
|
|
||||||
errors?: Array<ErrorObject> | null;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface CustomLogger {
|
|
||||||
log(...args: any[]): any;
|
|
||||||
warn(...args: any[]): any;
|
|
||||||
error(...args: any[]): any;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface ValidateFunction {
|
|
||||||
(
|
|
||||||
data: any,
|
|
||||||
dataPath?: string,
|
|
||||||
parentData?: object | Array<any>,
|
|
||||||
parentDataProperty?: string | number,
|
|
||||||
rootData?: object | Array<any>
|
|
||||||
): boolean | PromiseLike<any>;
|
|
||||||
schema?: object | boolean;
|
|
||||||
errors?: null | Array<ErrorObject>;
|
|
||||||
refs?: object;
|
|
||||||
refVal?: Array<any>;
|
|
||||||
root?: ValidateFunction | object;
|
|
||||||
$async?: true;
|
|
||||||
source?: object;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface Options {
|
|
||||||
$data?: boolean;
|
|
||||||
allErrors?: boolean;
|
|
||||||
verbose?: boolean;
|
|
||||||
jsonPointers?: boolean;
|
|
||||||
uniqueItems?: boolean;
|
|
||||||
unicode?: boolean;
|
|
||||||
format?: string;
|
|
||||||
formats?: object;
|
|
||||||
unknownFormats?: true | string[] | 'ignore';
|
|
||||||
schemas?: Array<object> | object;
|
|
||||||
schemaId?: '$id' | 'id' | 'auto';
|
|
||||||
missingRefs?: true | 'ignore' | 'fail';
|
|
||||||
extendRefs?: true | 'ignore' | 'fail';
|
|
||||||
loadSchema?: (uri: string, cb?: (err: Error, schema: object) => void) => PromiseLike<object | boolean>;
|
|
||||||
removeAdditional?: boolean | 'all' | 'failing';
|
|
||||||
useDefaults?: boolean | 'empty' | 'shared';
|
|
||||||
coerceTypes?: boolean | 'array';
|
|
||||||
strictDefaults?: boolean | 'log';
|
|
||||||
strictKeywords?: boolean | 'log';
|
|
||||||
async?: boolean | string;
|
|
||||||
transpile?: string | ((code: string) => string);
|
|
||||||
meta?: boolean | object;
|
|
||||||
validateSchema?: boolean | 'log';
|
|
||||||
addUsedSchema?: boolean;
|
|
||||||
inlineRefs?: boolean | number;
|
|
||||||
passContext?: boolean;
|
|
||||||
loopRequired?: number;
|
|
||||||
ownProperties?: boolean;
|
|
||||||
multipleOfPrecision?: boolean | number;
|
|
||||||
errorDataPath?: string,
|
|
||||||
messages?: boolean;
|
|
||||||
sourceCode?: boolean;
|
|
||||||
processCode?: (code: string) => string;
|
|
||||||
cache?: object;
|
|
||||||
logger?: CustomLogger | false;
|
|
||||||
nullable?: boolean;
|
|
||||||
serialize?: ((schema: object | boolean) => any) | false;
|
|
||||||
}
|
|
||||||
|
|
||||||
type FormatValidator = string | RegExp | ((data: string) => boolean | PromiseLike<any>);
|
|
||||||
type NumberFormatValidator = ((data: number) => boolean | PromiseLike<any>);
|
|
||||||
|
|
||||||
interface NumberFormatDefinition {
|
|
||||||
type: "number",
|
|
||||||
validate: NumberFormatValidator;
|
|
||||||
compare?: (data1: number, data2: number) => number;
|
|
||||||
async?: boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface StringFormatDefinition {
|
|
||||||
type?: "string",
|
|
||||||
validate: FormatValidator;
|
|
||||||
compare?: (data1: string, data2: string) => number;
|
|
||||||
async?: boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
type FormatDefinition = NumberFormatDefinition | StringFormatDefinition;
|
|
||||||
|
|
||||||
interface KeywordDefinition {
|
|
||||||
type?: string | Array<string>;
|
|
||||||
async?: boolean;
|
|
||||||
$data?: boolean;
|
|
||||||
errors?: boolean | string;
|
|
||||||
metaSchema?: object;
|
|
||||||
// schema: false makes validate not to expect schema (ValidateFunction)
|
|
||||||
schema?: boolean;
|
|
||||||
statements?: boolean;
|
|
||||||
dependencies?: Array<string>;
|
|
||||||
modifying?: boolean;
|
|
||||||
valid?: boolean;
|
|
||||||
// one and only one of the following properties should be present
|
|
||||||
validate?: SchemaValidateFunction | ValidateFunction;
|
|
||||||
compile?: (schema: any, parentSchema: object, it: CompilationContext) => ValidateFunction;
|
|
||||||
macro?: (schema: any, parentSchema: object, it: CompilationContext) => object | boolean;
|
|
||||||
inline?: (it: CompilationContext, keyword: string, schema: any, parentSchema: object) => string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface CompilationContext {
|
|
||||||
level: number;
|
|
||||||
dataLevel: number;
|
|
||||||
dataPathArr: string[];
|
|
||||||
schema: any;
|
|
||||||
schemaPath: string;
|
|
||||||
baseId: string;
|
|
||||||
async: boolean;
|
|
||||||
opts: Options;
|
|
||||||
formats: {
|
|
||||||
[index: string]: FormatDefinition | undefined;
|
|
||||||
};
|
|
||||||
compositeRule: boolean;
|
|
||||||
validate: (schema: object) => boolean;
|
|
||||||
util: {
|
|
||||||
copy(obj: any, target?: any): any;
|
|
||||||
toHash(source: string[]): { [index: string]: true | undefined };
|
|
||||||
equal(obj: any, target: any): boolean;
|
|
||||||
getProperty(str: string): string;
|
|
||||||
schemaHasRules(schema: object, rules: any): string;
|
|
||||||
escapeQuotes(str: string): string;
|
|
||||||
toQuotedString(str: string): string;
|
|
||||||
getData(jsonPointer: string, dataLevel: number, paths: string[]): string;
|
|
||||||
escapeJsonPointer(str: string): string;
|
|
||||||
unescapeJsonPointer(str: string): string;
|
|
||||||
escapeFragment(str: string): string;
|
|
||||||
unescapeFragment(str: string): string;
|
|
||||||
};
|
|
||||||
self: Ajv;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface SchemaValidateFunction {
|
|
||||||
(
|
|
||||||
schema: any,
|
|
||||||
data: any,
|
|
||||||
parentSchema?: object,
|
|
||||||
dataPath?: string,
|
|
||||||
parentData?: object | Array<any>,
|
|
||||||
parentDataProperty?: string | number,
|
|
||||||
rootData?: object | Array<any>
|
|
||||||
): boolean | PromiseLike<any>;
|
|
||||||
errors?: Array<ErrorObject>;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface ErrorsTextOptions {
|
|
||||||
separator?: string;
|
|
||||||
dataVar?: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface ErrorObject {
|
|
||||||
keyword: string;
|
|
||||||
dataPath: string;
|
|
||||||
schemaPath: string;
|
|
||||||
params: ErrorParameters;
|
|
||||||
// Added to validation errors of propertyNames keyword schema
|
|
||||||
propertyName?: string;
|
|
||||||
// Excluded if messages set to false.
|
|
||||||
message?: string;
|
|
||||||
// These are added with the `verbose` option.
|
|
||||||
schema?: any;
|
|
||||||
parentSchema?: object;
|
|
||||||
data?: any;
|
|
||||||
}
|
|
||||||
|
|
||||||
type ErrorParameters = RefParams | LimitParams | AdditionalPropertiesParams |
|
|
||||||
DependenciesParams | FormatParams | ComparisonParams |
|
|
||||||
MultipleOfParams | PatternParams | RequiredParams |
|
|
||||||
TypeParams | UniqueItemsParams | CustomParams |
|
|
||||||
PatternRequiredParams | PropertyNamesParams |
|
|
||||||
IfParams | SwitchParams | NoParams | EnumParams;
|
|
||||||
|
|
||||||
interface RefParams {
|
|
||||||
ref: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface LimitParams {
|
|
||||||
limit: number;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface AdditionalPropertiesParams {
|
|
||||||
additionalProperty: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface DependenciesParams {
|
|
||||||
property: string;
|
|
||||||
missingProperty: string;
|
|
||||||
depsCount: number;
|
|
||||||
deps: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface FormatParams {
|
|
||||||
format: string
|
|
||||||
}
|
|
||||||
|
|
||||||
interface ComparisonParams {
|
|
||||||
comparison: string;
|
|
||||||
limit: number | string;
|
|
||||||
exclusive: boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface MultipleOfParams {
|
|
||||||
multipleOf: number;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface PatternParams {
|
|
||||||
pattern: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface RequiredParams {
|
|
||||||
missingProperty: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface TypeParams {
|
|
||||||
type: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface UniqueItemsParams {
|
|
||||||
i: number;
|
|
||||||
j: number;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface CustomParams {
|
|
||||||
keyword: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface PatternRequiredParams {
|
|
||||||
missingPattern: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface PropertyNamesParams {
|
|
||||||
propertyName: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface IfParams {
|
|
||||||
failingKeyword: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface SwitchParams {
|
|
||||||
caseIndex: number;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface NoParams { }
|
|
||||||
|
|
||||||
interface EnumParams {
|
|
||||||
allowedValues: Array<any>;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
export = ajv;
|
|
497
node_modules/ajv/lib/ajv.js
generated
vendored
497
node_modules/ajv/lib/ajv.js
generated
vendored
@@ -1,497 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
var compileSchema = require('./compile')
|
|
||||||
, resolve = require('./compile/resolve')
|
|
||||||
, Cache = require('./cache')
|
|
||||||
, SchemaObject = require('./compile/schema_obj')
|
|
||||||
, stableStringify = require('fast-json-stable-stringify')
|
|
||||||
, formats = require('./compile/formats')
|
|
||||||
, rules = require('./compile/rules')
|
|
||||||
, $dataMetaSchema = require('./data')
|
|
||||||
, util = require('./compile/util');
|
|
||||||
|
|
||||||
module.exports = Ajv;
|
|
||||||
|
|
||||||
Ajv.prototype.validate = validate;
|
|
||||||
Ajv.prototype.compile = compile;
|
|
||||||
Ajv.prototype.addSchema = addSchema;
|
|
||||||
Ajv.prototype.addMetaSchema = addMetaSchema;
|
|
||||||
Ajv.prototype.validateSchema = validateSchema;
|
|
||||||
Ajv.prototype.getSchema = getSchema;
|
|
||||||
Ajv.prototype.removeSchema = removeSchema;
|
|
||||||
Ajv.prototype.addFormat = addFormat;
|
|
||||||
Ajv.prototype.errorsText = errorsText;
|
|
||||||
|
|
||||||
Ajv.prototype._addSchema = _addSchema;
|
|
||||||
Ajv.prototype._compile = _compile;
|
|
||||||
|
|
||||||
Ajv.prototype.compileAsync = require('./compile/async');
|
|
||||||
var customKeyword = require('./keyword');
|
|
||||||
Ajv.prototype.addKeyword = customKeyword.add;
|
|
||||||
Ajv.prototype.getKeyword = customKeyword.get;
|
|
||||||
Ajv.prototype.removeKeyword = customKeyword.remove;
|
|
||||||
Ajv.prototype.validateKeyword = customKeyword.validate;
|
|
||||||
|
|
||||||
var errorClasses = require('./compile/error_classes');
|
|
||||||
Ajv.ValidationError = errorClasses.Validation;
|
|
||||||
Ajv.MissingRefError = errorClasses.MissingRef;
|
|
||||||
Ajv.$dataMetaSchema = $dataMetaSchema;
|
|
||||||
|
|
||||||
var META_SCHEMA_ID = 'http://json-schema.org/draft-07/schema';
|
|
||||||
|
|
||||||
var META_IGNORE_OPTIONS = [ 'removeAdditional', 'useDefaults', 'coerceTypes', 'strictDefaults' ];
|
|
||||||
var META_SUPPORT_DATA = ['/properties'];
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates validator instance.
|
|
||||||
* Usage: `Ajv(opts)`
|
|
||||||
* @param {Object} opts optional options
|
|
||||||
* @return {Object} ajv instance
|
|
||||||
*/
|
|
||||||
function Ajv(opts) {
|
|
||||||
if (!(this instanceof Ajv)) return new Ajv(opts);
|
|
||||||
opts = this._opts = util.copy(opts) || {};
|
|
||||||
setLogger(this);
|
|
||||||
this._schemas = {};
|
|
||||||
this._refs = {};
|
|
||||||
this._fragments = {};
|
|
||||||
this._formats = formats(opts.format);
|
|
||||||
|
|
||||||
this._cache = opts.cache || new Cache;
|
|
||||||
this._loadingSchemas = {};
|
|
||||||
this._compilations = [];
|
|
||||||
this.RULES = rules();
|
|
||||||
this._getId = chooseGetId(opts);
|
|
||||||
|
|
||||||
opts.loopRequired = opts.loopRequired || Infinity;
|
|
||||||
if (opts.errorDataPath == 'property') opts._errorDataPathProperty = true;
|
|
||||||
if (opts.serialize === undefined) opts.serialize = stableStringify;
|
|
||||||
this._metaOpts = getMetaSchemaOptions(this);
|
|
||||||
|
|
||||||
if (opts.formats) addInitialFormats(this);
|
|
||||||
addDefaultMetaSchema(this);
|
|
||||||
if (typeof opts.meta == 'object') this.addMetaSchema(opts.meta);
|
|
||||||
if (opts.nullable) this.addKeyword('nullable', {metaSchema: {type: 'boolean'}});
|
|
||||||
addInitialSchemas(this);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Validate data using schema
|
|
||||||
* Schema will be compiled and cached (using serialized JSON as key. [fast-json-stable-stringify](https://github.com/epoberezkin/fast-json-stable-stringify) is used to serialize.
|
|
||||||
* @this Ajv
|
|
||||||
* @param {String|Object} schemaKeyRef key, ref or schema object
|
|
||||||
* @param {Any} data to be validated
|
|
||||||
* @return {Boolean} validation result. Errors from the last validation will be available in `ajv.errors` (and also in compiled schema: `schema.errors`).
|
|
||||||
*/
|
|
||||||
function validate(schemaKeyRef, data) {
|
|
||||||
var v;
|
|
||||||
if (typeof schemaKeyRef == 'string') {
|
|
||||||
v = this.getSchema(schemaKeyRef);
|
|
||||||
if (!v) throw new Error('no schema with key or ref "' + schemaKeyRef + '"');
|
|
||||||
} else {
|
|
||||||
var schemaObj = this._addSchema(schemaKeyRef);
|
|
||||||
v = schemaObj.validate || this._compile(schemaObj);
|
|
||||||
}
|
|
||||||
|
|
||||||
var valid = v(data);
|
|
||||||
if (v.$async !== true) this.errors = v.errors;
|
|
||||||
return valid;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Create validating function for passed schema.
|
|
||||||
* @this Ajv
|
|
||||||
* @param {Object} schema schema object
|
|
||||||
* @param {Boolean} _meta true if schema is a meta-schema. Used internally to compile meta schemas of custom keywords.
|
|
||||||
* @return {Function} validating function
|
|
||||||
*/
|
|
||||||
function compile(schema, _meta) {
|
|
||||||
var schemaObj = this._addSchema(schema, undefined, _meta);
|
|
||||||
return schemaObj.validate || this._compile(schemaObj);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Adds schema to the instance.
|
|
||||||
* @this Ajv
|
|
||||||
* @param {Object|Array} schema schema or array of schemas. If array is passed, `key` and other parameters will be ignored.
|
|
||||||
* @param {String} key Optional schema key. Can be passed to `validate` method instead of schema object or id/ref. One schema per instance can have empty `id` and `key`.
|
|
||||||
* @param {Boolean} _skipValidation true to skip schema validation. Used internally, option validateSchema should be used instead.
|
|
||||||
* @param {Boolean} _meta true if schema is a meta-schema. Used internally, addMetaSchema should be used instead.
|
|
||||||
* @return {Ajv} this for method chaining
|
|
||||||
*/
|
|
||||||
function addSchema(schema, key, _skipValidation, _meta) {
|
|
||||||
if (Array.isArray(schema)){
|
|
||||||
for (var i=0; i<schema.length; i++) this.addSchema(schema[i], undefined, _skipValidation, _meta);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
var id = this._getId(schema);
|
|
||||||
if (id !== undefined && typeof id != 'string')
|
|
||||||
throw new Error('schema id must be string');
|
|
||||||
key = resolve.normalizeId(key || id);
|
|
||||||
checkUnique(this, key);
|
|
||||||
this._schemas[key] = this._addSchema(schema, _skipValidation, _meta, true);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Add schema that will be used to validate other schemas
|
|
||||||
* options in META_IGNORE_OPTIONS are alway set to false
|
|
||||||
* @this Ajv
|
|
||||||
* @param {Object} schema schema object
|
|
||||||
* @param {String} key optional schema key
|
|
||||||
* @param {Boolean} skipValidation true to skip schema validation, can be used to override validateSchema option for meta-schema
|
|
||||||
* @return {Ajv} this for method chaining
|
|
||||||
*/
|
|
||||||
function addMetaSchema(schema, key, skipValidation) {
|
|
||||||
this.addSchema(schema, key, skipValidation, true);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Validate schema
|
|
||||||
* @this Ajv
|
|
||||||
* @param {Object} schema schema to validate
|
|
||||||
* @param {Boolean} throwOrLogError pass true to throw (or log) an error if invalid
|
|
||||||
* @return {Boolean} true if schema is valid
|
|
||||||
*/
|
|
||||||
function validateSchema(schema, throwOrLogError) {
|
|
||||||
var $schema = schema.$schema;
|
|
||||||
if ($schema !== undefined && typeof $schema != 'string')
|
|
||||||
throw new Error('$schema must be a string');
|
|
||||||
$schema = $schema || this._opts.defaultMeta || defaultMeta(this);
|
|
||||||
if (!$schema) {
|
|
||||||
this.logger.warn('meta-schema not available');
|
|
||||||
this.errors = null;
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
var valid = this.validate($schema, schema);
|
|
||||||
if (!valid && throwOrLogError) {
|
|
||||||
var message = 'schema is invalid: ' + this.errorsText();
|
|
||||||
if (this._opts.validateSchema == 'log') this.logger.error(message);
|
|
||||||
else throw new Error(message);
|
|
||||||
}
|
|
||||||
return valid;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function defaultMeta(self) {
|
|
||||||
var meta = self._opts.meta;
|
|
||||||
self._opts.defaultMeta = typeof meta == 'object'
|
|
||||||
? self._getId(meta) || meta
|
|
||||||
: self.getSchema(META_SCHEMA_ID)
|
|
||||||
? META_SCHEMA_ID
|
|
||||||
: undefined;
|
|
||||||
return self._opts.defaultMeta;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Get compiled schema from the instance by `key` or `ref`.
|
|
||||||
* @this Ajv
|
|
||||||
* @param {String} keyRef `key` that was passed to `addSchema` or full schema reference (`schema.id` or resolved id).
|
|
||||||
* @return {Function} schema validating function (with property `schema`).
|
|
||||||
*/
|
|
||||||
function getSchema(keyRef) {
|
|
||||||
var schemaObj = _getSchemaObj(this, keyRef);
|
|
||||||
switch (typeof schemaObj) {
|
|
||||||
case 'object': return schemaObj.validate || this._compile(schemaObj);
|
|
||||||
case 'string': return this.getSchema(schemaObj);
|
|
||||||
case 'undefined': return _getSchemaFragment(this, keyRef);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function _getSchemaFragment(self, ref) {
|
|
||||||
var res = resolve.schema.call(self, { schema: {} }, ref);
|
|
||||||
if (res) {
|
|
||||||
var schema = res.schema
|
|
||||||
, root = res.root
|
|
||||||
, baseId = res.baseId;
|
|
||||||
var v = compileSchema.call(self, schema, root, undefined, baseId);
|
|
||||||
self._fragments[ref] = new SchemaObject({
|
|
||||||
ref: ref,
|
|
||||||
fragment: true,
|
|
||||||
schema: schema,
|
|
||||||
root: root,
|
|
||||||
baseId: baseId,
|
|
||||||
validate: v
|
|
||||||
});
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function _getSchemaObj(self, keyRef) {
|
|
||||||
keyRef = resolve.normalizeId(keyRef);
|
|
||||||
return self._schemas[keyRef] || self._refs[keyRef] || self._fragments[keyRef];
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Remove cached schema(s).
|
|
||||||
* If no parameter is passed all schemas but meta-schemas are removed.
|
|
||||||
* If RegExp is passed all schemas with key/id matching pattern but meta-schemas are removed.
|
|
||||||
* Even if schema is referenced by other schemas it still can be removed as other schemas have local references.
|
|
||||||
* @this Ajv
|
|
||||||
* @param {String|Object|RegExp} schemaKeyRef key, ref, pattern to match key/ref or schema object
|
|
||||||
* @return {Ajv} this for method chaining
|
|
||||||
*/
|
|
||||||
function removeSchema(schemaKeyRef) {
|
|
||||||
if (schemaKeyRef instanceof RegExp) {
|
|
||||||
_removeAllSchemas(this, this._schemas, schemaKeyRef);
|
|
||||||
_removeAllSchemas(this, this._refs, schemaKeyRef);
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
switch (typeof schemaKeyRef) {
|
|
||||||
case 'undefined':
|
|
||||||
_removeAllSchemas(this, this._schemas);
|
|
||||||
_removeAllSchemas(this, this._refs);
|
|
||||||
this._cache.clear();
|
|
||||||
return this;
|
|
||||||
case 'string':
|
|
||||||
var schemaObj = _getSchemaObj(this, schemaKeyRef);
|
|
||||||
if (schemaObj) this._cache.del(schemaObj.cacheKey);
|
|
||||||
delete this._schemas[schemaKeyRef];
|
|
||||||
delete this._refs[schemaKeyRef];
|
|
||||||
return this;
|
|
||||||
case 'object':
|
|
||||||
var serialize = this._opts.serialize;
|
|
||||||
var cacheKey = serialize ? serialize(schemaKeyRef) : schemaKeyRef;
|
|
||||||
this._cache.del(cacheKey);
|
|
||||||
var id = this._getId(schemaKeyRef);
|
|
||||||
if (id) {
|
|
||||||
id = resolve.normalizeId(id);
|
|
||||||
delete this._schemas[id];
|
|
||||||
delete this._refs[id];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function _removeAllSchemas(self, schemas, regex) {
|
|
||||||
for (var keyRef in schemas) {
|
|
||||||
var schemaObj = schemas[keyRef];
|
|
||||||
if (!schemaObj.meta && (!regex || regex.test(keyRef))) {
|
|
||||||
self._cache.del(schemaObj.cacheKey);
|
|
||||||
delete schemas[keyRef];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* @this Ajv */
|
|
||||||
function _addSchema(schema, skipValidation, meta, shouldAddSchema) {
|
|
||||||
if (typeof schema != 'object' && typeof schema != 'boolean')
|
|
||||||
throw new Error('schema should be object or boolean');
|
|
||||||
var serialize = this._opts.serialize;
|
|
||||||
var cacheKey = serialize ? serialize(schema) : schema;
|
|
||||||
var cached = this._cache.get(cacheKey);
|
|
||||||
if (cached) return cached;
|
|
||||||
|
|
||||||
shouldAddSchema = shouldAddSchema || this._opts.addUsedSchema !== false;
|
|
||||||
|
|
||||||
var id = resolve.normalizeId(this._getId(schema));
|
|
||||||
if (id && shouldAddSchema) checkUnique(this, id);
|
|
||||||
|
|
||||||
var willValidate = this._opts.validateSchema !== false && !skipValidation;
|
|
||||||
var recursiveMeta;
|
|
||||||
if (willValidate && !(recursiveMeta = id && id == resolve.normalizeId(schema.$schema)))
|
|
||||||
this.validateSchema(schema, true);
|
|
||||||
|
|
||||||
var localRefs = resolve.ids.call(this, schema);
|
|
||||||
|
|
||||||
var schemaObj = new SchemaObject({
|
|
||||||
id: id,
|
|
||||||
schema: schema,
|
|
||||||
localRefs: localRefs,
|
|
||||||
cacheKey: cacheKey,
|
|
||||||
meta: meta
|
|
||||||
});
|
|
||||||
|
|
||||||
if (id[0] != '#' && shouldAddSchema) this._refs[id] = schemaObj;
|
|
||||||
this._cache.put(cacheKey, schemaObj);
|
|
||||||
|
|
||||||
if (willValidate && recursiveMeta) this.validateSchema(schema, true);
|
|
||||||
|
|
||||||
return schemaObj;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* @this Ajv */
|
|
||||||
function _compile(schemaObj, root) {
|
|
||||||
if (schemaObj.compiling) {
|
|
||||||
schemaObj.validate = callValidate;
|
|
||||||
callValidate.schema = schemaObj.schema;
|
|
||||||
callValidate.errors = null;
|
|
||||||
callValidate.root = root ? root : callValidate;
|
|
||||||
if (schemaObj.schema.$async === true)
|
|
||||||
callValidate.$async = true;
|
|
||||||
return callValidate;
|
|
||||||
}
|
|
||||||
schemaObj.compiling = true;
|
|
||||||
|
|
||||||
var currentOpts;
|
|
||||||
if (schemaObj.meta) {
|
|
||||||
currentOpts = this._opts;
|
|
||||||
this._opts = this._metaOpts;
|
|
||||||
}
|
|
||||||
|
|
||||||
var v;
|
|
||||||
try { v = compileSchema.call(this, schemaObj.schema, root, schemaObj.localRefs); }
|
|
||||||
catch(e) {
|
|
||||||
delete schemaObj.validate;
|
|
||||||
throw e;
|
|
||||||
}
|
|
||||||
finally {
|
|
||||||
schemaObj.compiling = false;
|
|
||||||
if (schemaObj.meta) this._opts = currentOpts;
|
|
||||||
}
|
|
||||||
|
|
||||||
schemaObj.validate = v;
|
|
||||||
schemaObj.refs = v.refs;
|
|
||||||
schemaObj.refVal = v.refVal;
|
|
||||||
schemaObj.root = v.root;
|
|
||||||
return v;
|
|
||||||
|
|
||||||
|
|
||||||
/* @this {*} - custom context, see passContext option */
|
|
||||||
function callValidate() {
|
|
||||||
/* jshint validthis: true */
|
|
||||||
var _validate = schemaObj.validate;
|
|
||||||
var result = _validate.apply(this, arguments);
|
|
||||||
callValidate.errors = _validate.errors;
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function chooseGetId(opts) {
|
|
||||||
switch (opts.schemaId) {
|
|
||||||
case 'auto': return _get$IdOrId;
|
|
||||||
case 'id': return _getId;
|
|
||||||
default: return _get$Id;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
/* @this Ajv */
|
|
||||||
function _getId(schema) {
|
|
||||||
if (schema.$id) this.logger.warn('schema $id ignored', schema.$id);
|
|
||||||
return schema.id;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* @this Ajv */
|
|
||||||
function _get$Id(schema) {
|
|
||||||
if (schema.id) this.logger.warn('schema id ignored', schema.id);
|
|
||||||
return schema.$id;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function _get$IdOrId(schema) {
|
|
||||||
if (schema.$id && schema.id && schema.$id != schema.id)
|
|
||||||
throw new Error('schema $id is different from id');
|
|
||||||
return schema.$id || schema.id;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Convert array of error message objects to string
|
|
||||||
* @this Ajv
|
|
||||||
* @param {Array<Object>} errors optional array of validation errors, if not passed errors from the instance are used.
|
|
||||||
* @param {Object} options optional options with properties `separator` and `dataVar`.
|
|
||||||
* @return {String} human readable string with all errors descriptions
|
|
||||||
*/
|
|
||||||
function errorsText(errors, options) {
|
|
||||||
errors = errors || this.errors;
|
|
||||||
if (!errors) return 'No errors';
|
|
||||||
options = options || {};
|
|
||||||
var separator = options.separator === undefined ? ', ' : options.separator;
|
|
||||||
var dataVar = options.dataVar === undefined ? 'data' : options.dataVar;
|
|
||||||
|
|
||||||
var text = '';
|
|
||||||
for (var i=0; i<errors.length; i++) {
|
|
||||||
var e = errors[i];
|
|
||||||
if (e) text += dataVar + e.dataPath + ' ' + e.message + separator;
|
|
||||||
}
|
|
||||||
return text.slice(0, -separator.length);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Add custom format
|
|
||||||
* @this Ajv
|
|
||||||
* @param {String} name format name
|
|
||||||
* @param {String|RegExp|Function} format string is converted to RegExp; function should return boolean (true when valid)
|
|
||||||
* @return {Ajv} this for method chaining
|
|
||||||
*/
|
|
||||||
function addFormat(name, format) {
|
|
||||||
if (typeof format == 'string') format = new RegExp(format);
|
|
||||||
this._formats[name] = format;
|
|
||||||
return this;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function addDefaultMetaSchema(self) {
|
|
||||||
var $dataSchema;
|
|
||||||
if (self._opts.$data) {
|
|
||||||
$dataSchema = require('./refs/data.json');
|
|
||||||
self.addMetaSchema($dataSchema, $dataSchema.$id, true);
|
|
||||||
}
|
|
||||||
if (self._opts.meta === false) return;
|
|
||||||
var metaSchema = require('./refs/json-schema-draft-07.json');
|
|
||||||
if (self._opts.$data) metaSchema = $dataMetaSchema(metaSchema, META_SUPPORT_DATA);
|
|
||||||
self.addMetaSchema(metaSchema, META_SCHEMA_ID, true);
|
|
||||||
self._refs['http://json-schema.org/schema'] = META_SCHEMA_ID;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function addInitialSchemas(self) {
|
|
||||||
var optsSchemas = self._opts.schemas;
|
|
||||||
if (!optsSchemas) return;
|
|
||||||
if (Array.isArray(optsSchemas)) self.addSchema(optsSchemas);
|
|
||||||
else for (var key in optsSchemas) self.addSchema(optsSchemas[key], key);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function addInitialFormats(self) {
|
|
||||||
for (var name in self._opts.formats) {
|
|
||||||
var format = self._opts.formats[name];
|
|
||||||
self.addFormat(name, format);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function checkUnique(self, id) {
|
|
||||||
if (self._schemas[id] || self._refs[id])
|
|
||||||
throw new Error('schema with key or id "' + id + '" already exists');
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function getMetaSchemaOptions(self) {
|
|
||||||
var metaOpts = util.copy(self._opts);
|
|
||||||
for (var i=0; i<META_IGNORE_OPTIONS.length; i++)
|
|
||||||
delete metaOpts[META_IGNORE_OPTIONS[i]];
|
|
||||||
return metaOpts;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function setLogger(self) {
|
|
||||||
var logger = self._opts.logger;
|
|
||||||
if (logger === false) {
|
|
||||||
self.logger = {log: noop, warn: noop, error: noop};
|
|
||||||
} else {
|
|
||||||
if (logger === undefined) logger = console;
|
|
||||||
if (!(typeof logger == 'object' && logger.log && logger.warn && logger.error))
|
|
||||||
throw new Error('logger must implement log, warn and error methods');
|
|
||||||
self.logger = logger;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function noop() {}
|
|
26
node_modules/ajv/lib/cache.js
generated
vendored
26
node_modules/ajv/lib/cache.js
generated
vendored
@@ -1,26 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
|
|
||||||
var Cache = module.exports = function Cache() {
|
|
||||||
this._cache = {};
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
Cache.prototype.put = function Cache_put(key, value) {
|
|
||||||
this._cache[key] = value;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
Cache.prototype.get = function Cache_get(key) {
|
|
||||||
return this._cache[key];
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
Cache.prototype.del = function Cache_del(key) {
|
|
||||||
delete this._cache[key];
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
Cache.prototype.clear = function Cache_clear() {
|
|
||||||
this._cache = {};
|
|
||||||
};
|
|
90
node_modules/ajv/lib/compile/async.js
generated
vendored
90
node_modules/ajv/lib/compile/async.js
generated
vendored
@@ -1,90 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
var MissingRefError = require('./error_classes').MissingRef;
|
|
||||||
|
|
||||||
module.exports = compileAsync;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Creates validating function for passed schema with asynchronous loading of missing schemas.
|
|
||||||
* `loadSchema` option should be a function that accepts schema uri and returns promise that resolves with the schema.
|
|
||||||
* @this Ajv
|
|
||||||
* @param {Object} schema schema object
|
|
||||||
* @param {Boolean} meta optional true to compile meta-schema; this parameter can be skipped
|
|
||||||
* @param {Function} callback an optional node-style callback, it is called with 2 parameters: error (or null) and validating function.
|
|
||||||
* @return {Promise} promise that resolves with a validating function.
|
|
||||||
*/
|
|
||||||
function compileAsync(schema, meta, callback) {
|
|
||||||
/* eslint no-shadow: 0 */
|
|
||||||
/* global Promise */
|
|
||||||
/* jshint validthis: true */
|
|
||||||
var self = this;
|
|
||||||
if (typeof this._opts.loadSchema != 'function')
|
|
||||||
throw new Error('options.loadSchema should be a function');
|
|
||||||
|
|
||||||
if (typeof meta == 'function') {
|
|
||||||
callback = meta;
|
|
||||||
meta = undefined;
|
|
||||||
}
|
|
||||||
|
|
||||||
var p = loadMetaSchemaOf(schema).then(function () {
|
|
||||||
var schemaObj = self._addSchema(schema, undefined, meta);
|
|
||||||
return schemaObj.validate || _compileAsync(schemaObj);
|
|
||||||
});
|
|
||||||
|
|
||||||
if (callback) {
|
|
||||||
p.then(
|
|
||||||
function(v) { callback(null, v); },
|
|
||||||
callback
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
return p;
|
|
||||||
|
|
||||||
|
|
||||||
function loadMetaSchemaOf(sch) {
|
|
||||||
var $schema = sch.$schema;
|
|
||||||
return $schema && !self.getSchema($schema)
|
|
||||||
? compileAsync.call(self, { $ref: $schema }, true)
|
|
||||||
: Promise.resolve();
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function _compileAsync(schemaObj) {
|
|
||||||
try { return self._compile(schemaObj); }
|
|
||||||
catch(e) {
|
|
||||||
if (e instanceof MissingRefError) return loadMissingSchema(e);
|
|
||||||
throw e;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function loadMissingSchema(e) {
|
|
||||||
var ref = e.missingSchema;
|
|
||||||
if (added(ref)) throw new Error('Schema ' + ref + ' is loaded but ' + e.missingRef + ' cannot be resolved');
|
|
||||||
|
|
||||||
var schemaPromise = self._loadingSchemas[ref];
|
|
||||||
if (!schemaPromise) {
|
|
||||||
schemaPromise = self._loadingSchemas[ref] = self._opts.loadSchema(ref);
|
|
||||||
schemaPromise.then(removePromise, removePromise);
|
|
||||||
}
|
|
||||||
|
|
||||||
return schemaPromise.then(function (sch) {
|
|
||||||
if (!added(ref)) {
|
|
||||||
return loadMetaSchemaOf(sch).then(function () {
|
|
||||||
if (!added(ref)) self.addSchema(sch, ref, undefined, meta);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
}).then(function() {
|
|
||||||
return _compileAsync(schemaObj);
|
|
||||||
});
|
|
||||||
|
|
||||||
function removePromise() {
|
|
||||||
delete self._loadingSchemas[ref];
|
|
||||||
}
|
|
||||||
|
|
||||||
function added(ref) {
|
|
||||||
return self._refs[ref] || self._schemas[ref];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
5
node_modules/ajv/lib/compile/equal.js
generated
vendored
5
node_modules/ajv/lib/compile/equal.js
generated
vendored
@@ -1,5 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
// do NOT remove this file - it would break pre-compiled schemas
|
|
||||||
// https://github.com/epoberezkin/ajv/issues/889
|
|
||||||
module.exports = require('fast-deep-equal');
|
|
34
node_modules/ajv/lib/compile/error_classes.js
generated
vendored
34
node_modules/ajv/lib/compile/error_classes.js
generated
vendored
@@ -1,34 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
var resolve = require('./resolve');
|
|
||||||
|
|
||||||
module.exports = {
|
|
||||||
Validation: errorSubclass(ValidationError),
|
|
||||||
MissingRef: errorSubclass(MissingRefError)
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
function ValidationError(errors) {
|
|
||||||
this.message = 'validation failed';
|
|
||||||
this.errors = errors;
|
|
||||||
this.ajv = this.validation = true;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
MissingRefError.message = function (baseId, ref) {
|
|
||||||
return 'can\'t resolve reference ' + ref + ' from id ' + baseId;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
function MissingRefError(baseId, ref, message) {
|
|
||||||
this.message = message || MissingRefError.message(baseId, ref);
|
|
||||||
this.missingRef = resolve.url(baseId, ref);
|
|
||||||
this.missingSchema = resolve.normalizeId(resolve.fullPath(this.missingRef));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function errorSubclass(Subclass) {
|
|
||||||
Subclass.prototype = Object.create(Error.prototype);
|
|
||||||
Subclass.prototype.constructor = Subclass;
|
|
||||||
return Subclass;
|
|
||||||
}
|
|
149
node_modules/ajv/lib/compile/formats.js
generated
vendored
149
node_modules/ajv/lib/compile/formats.js
generated
vendored
@@ -1,149 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
var util = require('./util');
|
|
||||||
|
|
||||||
var DATE = /^(\d\d\d\d)-(\d\d)-(\d\d)$/;
|
|
||||||
var DAYS = [0,31,28,31,30,31,30,31,31,30,31,30,31];
|
|
||||||
var TIME = /^(\d\d):(\d\d):(\d\d)(\.\d+)?(z|[+-]\d\d(?::?\d\d)?)?$/i;
|
|
||||||
var HOSTNAME = /^[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?(?:\.[a-z0-9](?:[-0-9a-z]{0,61}[0-9a-z])?)*$/i;
|
|
||||||
var URI = /^(?:[a-z][a-z0-9+\-.]*:)(?:\/?\/(?:(?:[a-z0-9\-._~!$&'()*+,;=:]|%[0-9a-f]{2})*@)?(?:\[(?:(?:(?:(?:[0-9a-f]{1,4}:){6}|::(?:[0-9a-f]{1,4}:){5}|(?:[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){4}|(?:(?:[0-9a-f]{1,4}:){0,1}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){3}|(?:(?:[0-9a-f]{1,4}:){0,2}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){2}|(?:(?:[0-9a-f]{1,4}:){0,3}[0-9a-f]{1,4})?::[0-9a-f]{1,4}:|(?:(?:[0-9a-f]{1,4}:){0,4}[0-9a-f]{1,4})?::)(?:[0-9a-f]{1,4}:[0-9a-f]{1,4}|(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?))|(?:(?:[0-9a-f]{1,4}:){0,5}[0-9a-f]{1,4})?::[0-9a-f]{1,4}|(?:(?:[0-9a-f]{1,4}:){0,6}[0-9a-f]{1,4})?::)|[Vv][0-9a-f]+\.[a-z0-9\-._~!$&'()*+,;=:]+)\]|(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?)|(?:[a-z0-9\-._~!$&'()*+,;=]|%[0-9a-f]{2})*)(?::\d*)?(?:\/(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})*)*|\/(?:(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})+(?:\/(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})*)*)?|(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})+(?:\/(?:[a-z0-9\-._~!$&'()*+,;=:@]|%[0-9a-f]{2})*)*)(?:\?(?:[a-z0-9\-._~!$&'()*+,;=:@/?]|%[0-9a-f]{2})*)?(?:#(?:[a-z0-9\-._~!$&'()*+,;=:@/?]|%[0-9a-f]{2})*)?$/i;
|
|
||||||
var URIREF = /^(?:[a-z][a-z0-9+\-.]*:)?(?:\/?\/(?:(?:[a-z0-9\-._~!$&'()*+,;=:]|%[0-9a-f]{2})*@)?(?:\[(?:(?:(?:(?:[0-9a-f]{1,4}:){6}|::(?:[0-9a-f]{1,4}:){5}|(?:[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){4}|(?:(?:[0-9a-f]{1,4}:){0,1}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){3}|(?:(?:[0-9a-f]{1,4}:){0,2}[0-9a-f]{1,4})?::(?:[0-9a-f]{1,4}:){2}|(?:(?:[0-9a-f]{1,4}:){0,3}[0-9a-f]{1,4})?::[0-9a-f]{1,4}:|(?:(?:[0-9a-f]{1,4}:){0,4}[0-9a-f]{1,4})?::)(?:[0-9a-f]{1,4}:[0-9a-f]{1,4}|(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?))|(?:(?:[0-9a-f]{1,4}:){0,5}[0-9a-f]{1,4})?::[0-9a-f]{1,4}|(?:(?:[0-9a-f]{1,4}:){0,6}[0-9a-f]{1,4})?::)|[Vv][0-9a-f]+\.[a-z0-9\-._~!$&'()*+,;=:]+)\]|(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?)|(?:[a-z0-9\-._~!$&'"()*+,;=]|%[0-9a-f]{2})*)(?::\d*)?(?:\/(?:[a-z0-9\-._~!$&'"()*+,;=:@]|%[0-9a-f]{2})*)*|\/(?:(?:[a-z0-9\-._~!$&'"()*+,;=:@]|%[0-9a-f]{2})+(?:\/(?:[a-z0-9\-._~!$&'"()*+,;=:@]|%[0-9a-f]{2})*)*)?|(?:[a-z0-9\-._~!$&'"()*+,;=:@]|%[0-9a-f]{2})+(?:\/(?:[a-z0-9\-._~!$&'"()*+,;=:@]|%[0-9a-f]{2})*)*)?(?:\?(?:[a-z0-9\-._~!$&'"()*+,;=:@/?]|%[0-9a-f]{2})*)?(?:#(?:[a-z0-9\-._~!$&'"()*+,;=:@/?]|%[0-9a-f]{2})*)?$/i;
|
|
||||||
// uri-template: https://tools.ietf.org/html/rfc6570
|
|
||||||
var URITEMPLATE = /^(?:(?:[^\x00-\x20"'<>%\\^`{|}]|%[0-9a-f]{2})|\{[+#./;?&=,!@|]?(?:[a-z0-9_]|%[0-9a-f]{2})+(?::[1-9][0-9]{0,3}|\*)?(?:,(?:[a-z0-9_]|%[0-9a-f]{2})+(?::[1-9][0-9]{0,3}|\*)?)*\})*$/i;
|
|
||||||
// For the source: https://gist.github.com/dperini/729294
|
|
||||||
// For test cases: https://mathiasbynens.be/demo/url-regex
|
|
||||||
// @todo Delete current URL in favour of the commented out URL rule when this issue is fixed https://github.com/eslint/eslint/issues/7983.
|
|
||||||
// var URL = /^(?:(?:https?|ftp):\/\/)(?:\S+(?::\S*)?@)?(?:(?!10(?:\.\d{1,3}){3})(?!127(?:\.\d{1,3}){3})(?!169\.254(?:\.\d{1,3}){2})(?!192\.168(?:\.\d{1,3}){2})(?!172\.(?:1[6-9]|2\d|3[0-1])(?:\.\d{1,3}){2})(?:[1-9]\d?|1\d\d|2[01]\d|22[0-3])(?:\.(?:1?\d{1,2}|2[0-4]\d|25[0-5])){2}(?:\.(?:[1-9]\d?|1\d\d|2[0-4]\d|25[0-4]))|(?:(?:[a-z\u{00a1}-\u{ffff}0-9]+-?)*[a-z\u{00a1}-\u{ffff}0-9]+)(?:\.(?:[a-z\u{00a1}-\u{ffff}0-9]+-?)*[a-z\u{00a1}-\u{ffff}0-9]+)*(?:\.(?:[a-z\u{00a1}-\u{ffff}]{2,})))(?::\d{2,5})?(?:\/[^\s]*)?$/iu;
|
|
||||||
var URL = /^(?:(?:http[s\u017F]?|ftp):\/\/)(?:(?:[\0-\x08\x0E-\x1F!-\x9F\xA1-\u167F\u1681-\u1FFF\u200B-\u2027\u202A-\u202E\u2030-\u205E\u2060-\u2FFF\u3001-\uD7FF\uE000-\uFEFE\uFF00-\uFFFF]|[\uD800-\uDBFF][\uDC00-\uDFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])+(?::(?:[\0-\x08\x0E-\x1F!-\x9F\xA1-\u167F\u1681-\u1FFF\u200B-\u2027\u202A-\u202E\u2030-\u205E\u2060-\u2FFF\u3001-\uD7FF\uE000-\uFEFE\uFF00-\uFFFF]|[\uD800-\uDBFF][\uDC00-\uDFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])*)?@)?(?:(?!10(?:\.[0-9]{1,3}){3})(?!127(?:\.[0-9]{1,3}){3})(?!169\.254(?:\.[0-9]{1,3}){2})(?!192\.168(?:\.[0-9]{1,3}){2})(?!172\.(?:1[6-9]|2[0-9]|3[01])(?:\.[0-9]{1,3}){2})(?:[1-9][0-9]?|1[0-9][0-9]|2[01][0-9]|22[0-3])(?:\.(?:1?[0-9]{1,2}|2[0-4][0-9]|25[0-5])){2}(?:\.(?:[1-9][0-9]?|1[0-9][0-9]|2[0-4][0-9]|25[0-4]))|(?:(?:(?:[0-9KSa-z\xA1-\uD7FF\uE000-\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])+-?)*(?:[0-9KSa-z\xA1-\uD7FF\uE000-\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])+)(?:\.(?:(?:[0-9KSa-z\xA1-\uD7FF\uE000-\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])+-?)*(?:[0-9KSa-z\xA1-\uD7FF\uE000-\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])+)*(?:\.(?:(?:[KSa-z\xA1-\uD7FF\uE000-\uFFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF]){2,})))(?::[0-9]{2,5})?(?:\/(?:[\0-\x08\x0E-\x1F!-\x9F\xA1-\u167F\u1681-\u1FFF\u200B-\u2027\u202A-\u202E\u2030-\u205E\u2060-\u2FFF\u3001-\uD7FF\uE000-\uFEFE\uFF00-\uFFFF]|[\uD800-\uDBFF][\uDC00-\uDFFF]|[\uD800-\uDBFF](?![\uDC00-\uDFFF])|(?:[^\uD800-\uDBFF]|^)[\uDC00-\uDFFF])*)?$/i;
|
|
||||||
var UUID = /^(?:urn:uuid:)?[0-9a-f]{8}-(?:[0-9a-f]{4}-){3}[0-9a-f]{12}$/i;
|
|
||||||
var JSON_POINTER = /^(?:\/(?:[^~/]|~0|~1)*)*$/;
|
|
||||||
var JSON_POINTER_URI_FRAGMENT = /^#(?:\/(?:[a-z0-9_\-.!$&'()*+,;:=@]|%[0-9a-f]{2}|~0|~1)*)*$/i;
|
|
||||||
var RELATIVE_JSON_POINTER = /^(?:0|[1-9][0-9]*)(?:#|(?:\/(?:[^~/]|~0|~1)*)*)$/;
|
|
||||||
|
|
||||||
|
|
||||||
module.exports = formats;
|
|
||||||
|
|
||||||
function formats(mode) {
|
|
||||||
mode = mode == 'full' ? 'full' : 'fast';
|
|
||||||
return util.copy(formats[mode]);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
formats.fast = {
|
|
||||||
// date: http://tools.ietf.org/html/rfc3339#section-5.6
|
|
||||||
date: /^\d\d\d\d-[0-1]\d-[0-3]\d$/,
|
|
||||||
// date-time: http://tools.ietf.org/html/rfc3339#section-5.6
|
|
||||||
time: /^(?:[0-2]\d:[0-5]\d:[0-5]\d|23:59:60)(?:\.\d+)?(?:z|[+-]\d\d(?::?\d\d)?)?$/i,
|
|
||||||
'date-time': /^\d\d\d\d-[0-1]\d-[0-3]\d[t\s](?:[0-2]\d:[0-5]\d:[0-5]\d|23:59:60)(?:\.\d+)?(?:z|[+-]\d\d(?::?\d\d)?)$/i,
|
|
||||||
// uri: https://github.com/mafintosh/is-my-json-valid/blob/master/formats.js
|
|
||||||
uri: /^(?:[a-z][a-z0-9+-.]*:)(?:\/?\/)?[^\s]*$/i,
|
|
||||||
'uri-reference': /^(?:(?:[a-z][a-z0-9+-.]*:)?\/?\/)?(?:[^\\\s#][^\s#]*)?(?:#[^\\\s]*)?$/i,
|
|
||||||
'uri-template': URITEMPLATE,
|
|
||||||
url: URL,
|
|
||||||
// email (sources from jsen validator):
|
|
||||||
// http://stackoverflow.com/questions/201323/using-a-regular-expression-to-validate-an-email-address#answer-8829363
|
|
||||||
// http://www.w3.org/TR/html5/forms.html#valid-e-mail-address (search for 'willful violation')
|
|
||||||
email: /^[a-z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?(?:\.[a-z0-9](?:[a-z0-9-]{0,61}[a-z0-9])?)*$/i,
|
|
||||||
hostname: HOSTNAME,
|
|
||||||
// optimized https://www.safaribooksonline.com/library/view/regular-expressions-cookbook/9780596802837/ch07s16.html
|
|
||||||
ipv4: /^(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?)$/,
|
|
||||||
// optimized http://stackoverflow.com/questions/53497/regular-expression-that-matches-valid-ipv6-addresses
|
|
||||||
ipv6: /^\s*(?:(?:(?:[0-9a-f]{1,4}:){7}(?:[0-9a-f]{1,4}|:))|(?:(?:[0-9a-f]{1,4}:){6}(?::[0-9a-f]{1,4}|(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(?:(?:[0-9a-f]{1,4}:){5}(?:(?:(?::[0-9a-f]{1,4}){1,2})|:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(?:(?:[0-9a-f]{1,4}:){4}(?:(?:(?::[0-9a-f]{1,4}){1,3})|(?:(?::[0-9a-f]{1,4})?:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?:(?:[0-9a-f]{1,4}:){3}(?:(?:(?::[0-9a-f]{1,4}){1,4})|(?:(?::[0-9a-f]{1,4}){0,2}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?:(?:[0-9a-f]{1,4}:){2}(?:(?:(?::[0-9a-f]{1,4}){1,5})|(?:(?::[0-9a-f]{1,4}){0,3}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?:(?:[0-9a-f]{1,4}:){1}(?:(?:(?::[0-9a-f]{1,4}){1,6})|(?:(?::[0-9a-f]{1,4}){0,4}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?::(?:(?:(?::[0-9a-f]{1,4}){1,7})|(?:(?::[0-9a-f]{1,4}){0,5}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:)))(?:%.+)?\s*$/i,
|
|
||||||
regex: regex,
|
|
||||||
// uuid: http://tools.ietf.org/html/rfc4122
|
|
||||||
uuid: UUID,
|
|
||||||
// JSON-pointer: https://tools.ietf.org/html/rfc6901
|
|
||||||
// uri fragment: https://tools.ietf.org/html/rfc3986#appendix-A
|
|
||||||
'json-pointer': JSON_POINTER,
|
|
||||||
'json-pointer-uri-fragment': JSON_POINTER_URI_FRAGMENT,
|
|
||||||
// relative JSON-pointer: http://tools.ietf.org/html/draft-luff-relative-json-pointer-00
|
|
||||||
'relative-json-pointer': RELATIVE_JSON_POINTER
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
formats.full = {
|
|
||||||
date: date,
|
|
||||||
time: time,
|
|
||||||
'date-time': date_time,
|
|
||||||
uri: uri,
|
|
||||||
'uri-reference': URIREF,
|
|
||||||
'uri-template': URITEMPLATE,
|
|
||||||
url: URL,
|
|
||||||
email: /^[a-z0-9!#$%&'*+/=?^_`{|}~-]+(?:\.[a-z0-9!#$%&'*+/=?^_`{|}~-]+)*@(?:[a-z0-9](?:[a-z0-9-]*[a-z0-9])?\.)+[a-z0-9](?:[a-z0-9-]*[a-z0-9])?$/i,
|
|
||||||
hostname: hostname,
|
|
||||||
ipv4: /^(?:(?:25[0-5]|2[0-4]\d|[01]?\d\d?)\.){3}(?:25[0-5]|2[0-4]\d|[01]?\d\d?)$/,
|
|
||||||
ipv6: /^\s*(?:(?:(?:[0-9a-f]{1,4}:){7}(?:[0-9a-f]{1,4}|:))|(?:(?:[0-9a-f]{1,4}:){6}(?::[0-9a-f]{1,4}|(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(?:(?:[0-9a-f]{1,4}:){5}(?:(?:(?::[0-9a-f]{1,4}){1,2})|:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3})|:))|(?:(?:[0-9a-f]{1,4}:){4}(?:(?:(?::[0-9a-f]{1,4}){1,3})|(?:(?::[0-9a-f]{1,4})?:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?:(?:[0-9a-f]{1,4}:){3}(?:(?:(?::[0-9a-f]{1,4}){1,4})|(?:(?::[0-9a-f]{1,4}){0,2}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?:(?:[0-9a-f]{1,4}:){2}(?:(?:(?::[0-9a-f]{1,4}){1,5})|(?:(?::[0-9a-f]{1,4}){0,3}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?:(?:[0-9a-f]{1,4}:){1}(?:(?:(?::[0-9a-f]{1,4}){1,6})|(?:(?::[0-9a-f]{1,4}){0,4}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:))|(?::(?:(?:(?::[0-9a-f]{1,4}){1,7})|(?:(?::[0-9a-f]{1,4}){0,5}:(?:(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)(?:\.(?:25[0-5]|2[0-4]\d|1\d\d|[1-9]?\d)){3}))|:)))(?:%.+)?\s*$/i,
|
|
||||||
regex: regex,
|
|
||||||
uuid: UUID,
|
|
||||||
'json-pointer': JSON_POINTER,
|
|
||||||
'json-pointer-uri-fragment': JSON_POINTER_URI_FRAGMENT,
|
|
||||||
'relative-json-pointer': RELATIVE_JSON_POINTER
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
function isLeapYear(year) {
|
|
||||||
// https://tools.ietf.org/html/rfc3339#appendix-C
|
|
||||||
return year % 4 === 0 && (year % 100 !== 0 || year % 400 === 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function date(str) {
|
|
||||||
// full-date from http://tools.ietf.org/html/rfc3339#section-5.6
|
|
||||||
var matches = str.match(DATE);
|
|
||||||
if (!matches) return false;
|
|
||||||
|
|
||||||
var year = +matches[1];
|
|
||||||
var month = +matches[2];
|
|
||||||
var day = +matches[3];
|
|
||||||
|
|
||||||
return month >= 1 && month <= 12 && day >= 1 &&
|
|
||||||
day <= (month == 2 && isLeapYear(year) ? 29 : DAYS[month]);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function time(str, full) {
|
|
||||||
var matches = str.match(TIME);
|
|
||||||
if (!matches) return false;
|
|
||||||
|
|
||||||
var hour = matches[1];
|
|
||||||
var minute = matches[2];
|
|
||||||
var second = matches[3];
|
|
||||||
var timeZone = matches[5];
|
|
||||||
return ((hour <= 23 && minute <= 59 && second <= 59) ||
|
|
||||||
(hour == 23 && minute == 59 && second == 60)) &&
|
|
||||||
(!full || timeZone);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
var DATE_TIME_SEPARATOR = /t|\s/i;
|
|
||||||
function date_time(str) {
|
|
||||||
// http://tools.ietf.org/html/rfc3339#section-5.6
|
|
||||||
var dateTime = str.split(DATE_TIME_SEPARATOR);
|
|
||||||
return dateTime.length == 2 && date(dateTime[0]) && time(dateTime[1], true);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function hostname(str) {
|
|
||||||
// https://tools.ietf.org/html/rfc1034#section-3.5
|
|
||||||
// https://tools.ietf.org/html/rfc1123#section-2
|
|
||||||
return str.length <= 255 && HOSTNAME.test(str);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
var NOT_URI_FRAGMENT = /\/|:/;
|
|
||||||
function uri(str) {
|
|
||||||
// http://jmrware.com/articles/2009/uri_regexp/URI_regex.html + optional protocol + required "."
|
|
||||||
return NOT_URI_FRAGMENT.test(str) && URI.test(str);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
var Z_ANCHOR = /[^\\]\\Z/;
|
|
||||||
function regex(str) {
|
|
||||||
if (Z_ANCHOR.test(str)) return false;
|
|
||||||
try {
|
|
||||||
new RegExp(str);
|
|
||||||
return true;
|
|
||||||
} catch(e) {
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
}
|
|
387
node_modules/ajv/lib/compile/index.js
generated
vendored
387
node_modules/ajv/lib/compile/index.js
generated
vendored
@@ -1,387 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
var resolve = require('./resolve')
|
|
||||||
, util = require('./util')
|
|
||||||
, errorClasses = require('./error_classes')
|
|
||||||
, stableStringify = require('fast-json-stable-stringify');
|
|
||||||
|
|
||||||
var validateGenerator = require('../dotjs/validate');
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Functions below are used inside compiled validations function
|
|
||||||
*/
|
|
||||||
|
|
||||||
var ucs2length = util.ucs2length;
|
|
||||||
var equal = require('fast-deep-equal');
|
|
||||||
|
|
||||||
// this error is thrown by async schemas to return validation errors via exception
|
|
||||||
var ValidationError = errorClasses.Validation;
|
|
||||||
|
|
||||||
module.exports = compile;
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Compiles schema to validation function
|
|
||||||
* @this Ajv
|
|
||||||
* @param {Object} schema schema object
|
|
||||||
* @param {Object} root object with information about the root schema for this schema
|
|
||||||
* @param {Object} localRefs the hash of local references inside the schema (created by resolve.id), used for inline resolution
|
|
||||||
* @param {String} baseId base ID for IDs in the schema
|
|
||||||
* @return {Function} validation function
|
|
||||||
*/
|
|
||||||
function compile(schema, root, localRefs, baseId) {
|
|
||||||
/* jshint validthis: true, evil: true */
|
|
||||||
/* eslint no-shadow: 0 */
|
|
||||||
var self = this
|
|
||||||
, opts = this._opts
|
|
||||||
, refVal = [ undefined ]
|
|
||||||
, refs = {}
|
|
||||||
, patterns = []
|
|
||||||
, patternsHash = {}
|
|
||||||
, defaults = []
|
|
||||||
, defaultsHash = {}
|
|
||||||
, customRules = [];
|
|
||||||
|
|
||||||
root = root || { schema: schema, refVal: refVal, refs: refs };
|
|
||||||
|
|
||||||
var c = checkCompiling.call(this, schema, root, baseId);
|
|
||||||
var compilation = this._compilations[c.index];
|
|
||||||
if (c.compiling) return (compilation.callValidate = callValidate);
|
|
||||||
|
|
||||||
var formats = this._formats;
|
|
||||||
var RULES = this.RULES;
|
|
||||||
|
|
||||||
try {
|
|
||||||
var v = localCompile(schema, root, localRefs, baseId);
|
|
||||||
compilation.validate = v;
|
|
||||||
var cv = compilation.callValidate;
|
|
||||||
if (cv) {
|
|
||||||
cv.schema = v.schema;
|
|
||||||
cv.errors = null;
|
|
||||||
cv.refs = v.refs;
|
|
||||||
cv.refVal = v.refVal;
|
|
||||||
cv.root = v.root;
|
|
||||||
cv.$async = v.$async;
|
|
||||||
if (opts.sourceCode) cv.source = v.source;
|
|
||||||
}
|
|
||||||
return v;
|
|
||||||
} finally {
|
|
||||||
endCompiling.call(this, schema, root, baseId);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* @this {*} - custom context, see passContext option */
|
|
||||||
function callValidate() {
|
|
||||||
/* jshint validthis: true */
|
|
||||||
var validate = compilation.validate;
|
|
||||||
var result = validate.apply(this, arguments);
|
|
||||||
callValidate.errors = validate.errors;
|
|
||||||
return result;
|
|
||||||
}
|
|
||||||
|
|
||||||
function localCompile(_schema, _root, localRefs, baseId) {
|
|
||||||
var isRoot = !_root || (_root && _root.schema == _schema);
|
|
||||||
if (_root.schema != root.schema)
|
|
||||||
return compile.call(self, _schema, _root, localRefs, baseId);
|
|
||||||
|
|
||||||
var $async = _schema.$async === true;
|
|
||||||
|
|
||||||
var sourceCode = validateGenerator({
|
|
||||||
isTop: true,
|
|
||||||
schema: _schema,
|
|
||||||
isRoot: isRoot,
|
|
||||||
baseId: baseId,
|
|
||||||
root: _root,
|
|
||||||
schemaPath: '',
|
|
||||||
errSchemaPath: '#',
|
|
||||||
errorPath: '""',
|
|
||||||
MissingRefError: errorClasses.MissingRef,
|
|
||||||
RULES: RULES,
|
|
||||||
validate: validateGenerator,
|
|
||||||
util: util,
|
|
||||||
resolve: resolve,
|
|
||||||
resolveRef: resolveRef,
|
|
||||||
usePattern: usePattern,
|
|
||||||
useDefault: useDefault,
|
|
||||||
useCustomRule: useCustomRule,
|
|
||||||
opts: opts,
|
|
||||||
formats: formats,
|
|
||||||
logger: self.logger,
|
|
||||||
self: self
|
|
||||||
});
|
|
||||||
|
|
||||||
sourceCode = vars(refVal, refValCode) + vars(patterns, patternCode)
|
|
||||||
+ vars(defaults, defaultCode) + vars(customRules, customRuleCode)
|
|
||||||
+ sourceCode;
|
|
||||||
|
|
||||||
if (opts.processCode) sourceCode = opts.processCode(sourceCode);
|
|
||||||
// console.log('\n\n\n *** \n', JSON.stringify(sourceCode));
|
|
||||||
var validate;
|
|
||||||
try {
|
|
||||||
var makeValidate = new Function(
|
|
||||||
'self',
|
|
||||||
'RULES',
|
|
||||||
'formats',
|
|
||||||
'root',
|
|
||||||
'refVal',
|
|
||||||
'defaults',
|
|
||||||
'customRules',
|
|
||||||
'equal',
|
|
||||||
'ucs2length',
|
|
||||||
'ValidationError',
|
|
||||||
sourceCode
|
|
||||||
);
|
|
||||||
|
|
||||||
validate = makeValidate(
|
|
||||||
self,
|
|
||||||
RULES,
|
|
||||||
formats,
|
|
||||||
root,
|
|
||||||
refVal,
|
|
||||||
defaults,
|
|
||||||
customRules,
|
|
||||||
equal,
|
|
||||||
ucs2length,
|
|
||||||
ValidationError
|
|
||||||
);
|
|
||||||
|
|
||||||
refVal[0] = validate;
|
|
||||||
} catch(e) {
|
|
||||||
self.logger.error('Error compiling schema, function code:', sourceCode);
|
|
||||||
throw e;
|
|
||||||
}
|
|
||||||
|
|
||||||
validate.schema = _schema;
|
|
||||||
validate.errors = null;
|
|
||||||
validate.refs = refs;
|
|
||||||
validate.refVal = refVal;
|
|
||||||
validate.root = isRoot ? validate : _root;
|
|
||||||
if ($async) validate.$async = true;
|
|
||||||
if (opts.sourceCode === true) {
|
|
||||||
validate.source = {
|
|
||||||
code: sourceCode,
|
|
||||||
patterns: patterns,
|
|
||||||
defaults: defaults
|
|
||||||
};
|
|
||||||
}
|
|
||||||
|
|
||||||
return validate;
|
|
||||||
}
|
|
||||||
|
|
||||||
function resolveRef(baseId, ref, isRoot) {
|
|
||||||
ref = resolve.url(baseId, ref);
|
|
||||||
var refIndex = refs[ref];
|
|
||||||
var _refVal, refCode;
|
|
||||||
if (refIndex !== undefined) {
|
|
||||||
_refVal = refVal[refIndex];
|
|
||||||
refCode = 'refVal[' + refIndex + ']';
|
|
||||||
return resolvedRef(_refVal, refCode);
|
|
||||||
}
|
|
||||||
if (!isRoot && root.refs) {
|
|
||||||
var rootRefId = root.refs[ref];
|
|
||||||
if (rootRefId !== undefined) {
|
|
||||||
_refVal = root.refVal[rootRefId];
|
|
||||||
refCode = addLocalRef(ref, _refVal);
|
|
||||||
return resolvedRef(_refVal, refCode);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
refCode = addLocalRef(ref);
|
|
||||||
var v = resolve.call(self, localCompile, root, ref);
|
|
||||||
if (v === undefined) {
|
|
||||||
var localSchema = localRefs && localRefs[ref];
|
|
||||||
if (localSchema) {
|
|
||||||
v = resolve.inlineRef(localSchema, opts.inlineRefs)
|
|
||||||
? localSchema
|
|
||||||
: compile.call(self, localSchema, root, localRefs, baseId);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (v === undefined) {
|
|
||||||
removeLocalRef(ref);
|
|
||||||
} else {
|
|
||||||
replaceLocalRef(ref, v);
|
|
||||||
return resolvedRef(v, refCode);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function addLocalRef(ref, v) {
|
|
||||||
var refId = refVal.length;
|
|
||||||
refVal[refId] = v;
|
|
||||||
refs[ref] = refId;
|
|
||||||
return 'refVal' + refId;
|
|
||||||
}
|
|
||||||
|
|
||||||
function removeLocalRef(ref) {
|
|
||||||
delete refs[ref];
|
|
||||||
}
|
|
||||||
|
|
||||||
function replaceLocalRef(ref, v) {
|
|
||||||
var refId = refs[ref];
|
|
||||||
refVal[refId] = v;
|
|
||||||
}
|
|
||||||
|
|
||||||
function resolvedRef(refVal, code) {
|
|
||||||
return typeof refVal == 'object' || typeof refVal == 'boolean'
|
|
||||||
? { code: code, schema: refVal, inline: true }
|
|
||||||
: { code: code, $async: refVal && !!refVal.$async };
|
|
||||||
}
|
|
||||||
|
|
||||||
function usePattern(regexStr) {
|
|
||||||
var index = patternsHash[regexStr];
|
|
||||||
if (index === undefined) {
|
|
||||||
index = patternsHash[regexStr] = patterns.length;
|
|
||||||
patterns[index] = regexStr;
|
|
||||||
}
|
|
||||||
return 'pattern' + index;
|
|
||||||
}
|
|
||||||
|
|
||||||
function useDefault(value) {
|
|
||||||
switch (typeof value) {
|
|
||||||
case 'boolean':
|
|
||||||
case 'number':
|
|
||||||
return '' + value;
|
|
||||||
case 'string':
|
|
||||||
return util.toQuotedString(value);
|
|
||||||
case 'object':
|
|
||||||
if (value === null) return 'null';
|
|
||||||
var valueStr = stableStringify(value);
|
|
||||||
var index = defaultsHash[valueStr];
|
|
||||||
if (index === undefined) {
|
|
||||||
index = defaultsHash[valueStr] = defaults.length;
|
|
||||||
defaults[index] = value;
|
|
||||||
}
|
|
||||||
return 'default' + index;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
function useCustomRule(rule, schema, parentSchema, it) {
|
|
||||||
if (self._opts.validateSchema !== false) {
|
|
||||||
var deps = rule.definition.dependencies;
|
|
||||||
if (deps && !deps.every(function(keyword) {
|
|
||||||
return Object.prototype.hasOwnProperty.call(parentSchema, keyword);
|
|
||||||
}))
|
|
||||||
throw new Error('parent schema must have all required keywords: ' + deps.join(','));
|
|
||||||
|
|
||||||
var validateSchema = rule.definition.validateSchema;
|
|
||||||
if (validateSchema) {
|
|
||||||
var valid = validateSchema(schema);
|
|
||||||
if (!valid) {
|
|
||||||
var message = 'keyword schema is invalid: ' + self.errorsText(validateSchema.errors);
|
|
||||||
if (self._opts.validateSchema == 'log') self.logger.error(message);
|
|
||||||
else throw new Error(message);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var compile = rule.definition.compile
|
|
||||||
, inline = rule.definition.inline
|
|
||||||
, macro = rule.definition.macro;
|
|
||||||
|
|
||||||
var validate;
|
|
||||||
if (compile) {
|
|
||||||
validate = compile.call(self, schema, parentSchema, it);
|
|
||||||
} else if (macro) {
|
|
||||||
validate = macro.call(self, schema, parentSchema, it);
|
|
||||||
if (opts.validateSchema !== false) self.validateSchema(validate, true);
|
|
||||||
} else if (inline) {
|
|
||||||
validate = inline.call(self, it, rule.keyword, schema, parentSchema);
|
|
||||||
} else {
|
|
||||||
validate = rule.definition.validate;
|
|
||||||
if (!validate) return;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (validate === undefined)
|
|
||||||
throw new Error('custom keyword "' + rule.keyword + '"failed to compile');
|
|
||||||
|
|
||||||
var index = customRules.length;
|
|
||||||
customRules[index] = validate;
|
|
||||||
|
|
||||||
return {
|
|
||||||
code: 'customRule' + index,
|
|
||||||
validate: validate
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Checks if the schema is currently compiled
|
|
||||||
* @this Ajv
|
|
||||||
* @param {Object} schema schema to compile
|
|
||||||
* @param {Object} root root object
|
|
||||||
* @param {String} baseId base schema ID
|
|
||||||
* @return {Object} object with properties "index" (compilation index) and "compiling" (boolean)
|
|
||||||
*/
|
|
||||||
function checkCompiling(schema, root, baseId) {
|
|
||||||
/* jshint validthis: true */
|
|
||||||
var index = compIndex.call(this, schema, root, baseId);
|
|
||||||
if (index >= 0) return { index: index, compiling: true };
|
|
||||||
index = this._compilations.length;
|
|
||||||
this._compilations[index] = {
|
|
||||||
schema: schema,
|
|
||||||
root: root,
|
|
||||||
baseId: baseId
|
|
||||||
};
|
|
||||||
return { index: index, compiling: false };
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Removes the schema from the currently compiled list
|
|
||||||
* @this Ajv
|
|
||||||
* @param {Object} schema schema to compile
|
|
||||||
* @param {Object} root root object
|
|
||||||
* @param {String} baseId base schema ID
|
|
||||||
*/
|
|
||||||
function endCompiling(schema, root, baseId) {
|
|
||||||
/* jshint validthis: true */
|
|
||||||
var i = compIndex.call(this, schema, root, baseId);
|
|
||||||
if (i >= 0) this._compilations.splice(i, 1);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Index of schema compilation in the currently compiled list
|
|
||||||
* @this Ajv
|
|
||||||
* @param {Object} schema schema to compile
|
|
||||||
* @param {Object} root root object
|
|
||||||
* @param {String} baseId base schema ID
|
|
||||||
* @return {Integer} compilation index
|
|
||||||
*/
|
|
||||||
function compIndex(schema, root, baseId) {
|
|
||||||
/* jshint validthis: true */
|
|
||||||
for (var i=0; i<this._compilations.length; i++) {
|
|
||||||
var c = this._compilations[i];
|
|
||||||
if (c.schema == schema && c.root == root && c.baseId == baseId) return i;
|
|
||||||
}
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function patternCode(i, patterns) {
|
|
||||||
return 'var pattern' + i + ' = new RegExp(' + util.toQuotedString(patterns[i]) + ');';
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function defaultCode(i) {
|
|
||||||
return 'var default' + i + ' = defaults[' + i + '];';
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function refValCode(i, refVal) {
|
|
||||||
return refVal[i] === undefined ? '' : 'var refVal' + i + ' = refVal[' + i + '];';
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function customRuleCode(i) {
|
|
||||||
return 'var customRule' + i + ' = customRules[' + i + '];';
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function vars(arr, statement) {
|
|
||||||
if (!arr.length) return '';
|
|
||||||
var code = '';
|
|
||||||
for (var i=0; i<arr.length; i++)
|
|
||||||
code += statement(i, arr);
|
|
||||||
return code;
|
|
||||||
}
|
|
270
node_modules/ajv/lib/compile/resolve.js
generated
vendored
270
node_modules/ajv/lib/compile/resolve.js
generated
vendored
@@ -1,270 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
var URI = require('uri-js')
|
|
||||||
, equal = require('fast-deep-equal')
|
|
||||||
, util = require('./util')
|
|
||||||
, SchemaObject = require('./schema_obj')
|
|
||||||
, traverse = require('json-schema-traverse');
|
|
||||||
|
|
||||||
module.exports = resolve;
|
|
||||||
|
|
||||||
resolve.normalizeId = normalizeId;
|
|
||||||
resolve.fullPath = getFullPath;
|
|
||||||
resolve.url = resolveUrl;
|
|
||||||
resolve.ids = resolveIds;
|
|
||||||
resolve.inlineRef = inlineRef;
|
|
||||||
resolve.schema = resolveSchema;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* [resolve and compile the references ($ref)]
|
|
||||||
* @this Ajv
|
|
||||||
* @param {Function} compile reference to schema compilation funciton (localCompile)
|
|
||||||
* @param {Object} root object with information about the root schema for the current schema
|
|
||||||
* @param {String} ref reference to resolve
|
|
||||||
* @return {Object|Function} schema object (if the schema can be inlined) or validation function
|
|
||||||
*/
|
|
||||||
function resolve(compile, root, ref) {
|
|
||||||
/* jshint validthis: true */
|
|
||||||
var refVal = this._refs[ref];
|
|
||||||
if (typeof refVal == 'string') {
|
|
||||||
if (this._refs[refVal]) refVal = this._refs[refVal];
|
|
||||||
else return resolve.call(this, compile, root, refVal);
|
|
||||||
}
|
|
||||||
|
|
||||||
refVal = refVal || this._schemas[ref];
|
|
||||||
if (refVal instanceof SchemaObject) {
|
|
||||||
return inlineRef(refVal.schema, this._opts.inlineRefs)
|
|
||||||
? refVal.schema
|
|
||||||
: refVal.validate || this._compile(refVal);
|
|
||||||
}
|
|
||||||
|
|
||||||
var res = resolveSchema.call(this, root, ref);
|
|
||||||
var schema, v, baseId;
|
|
||||||
if (res) {
|
|
||||||
schema = res.schema;
|
|
||||||
root = res.root;
|
|
||||||
baseId = res.baseId;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (schema instanceof SchemaObject) {
|
|
||||||
v = schema.validate || compile.call(this, schema.schema, root, undefined, baseId);
|
|
||||||
} else if (schema !== undefined) {
|
|
||||||
v = inlineRef(schema, this._opts.inlineRefs)
|
|
||||||
? schema
|
|
||||||
: compile.call(this, schema, root, undefined, baseId);
|
|
||||||
}
|
|
||||||
|
|
||||||
return v;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Resolve schema, its root and baseId
|
|
||||||
* @this Ajv
|
|
||||||
* @param {Object} root root object with properties schema, refVal, refs
|
|
||||||
* @param {String} ref reference to resolve
|
|
||||||
* @return {Object} object with properties schema, root, baseId
|
|
||||||
*/
|
|
||||||
function resolveSchema(root, ref) {
|
|
||||||
/* jshint validthis: true */
|
|
||||||
var p = URI.parse(ref)
|
|
||||||
, refPath = _getFullPath(p)
|
|
||||||
, baseId = getFullPath(this._getId(root.schema));
|
|
||||||
if (Object.keys(root.schema).length === 0 || refPath !== baseId) {
|
|
||||||
var id = normalizeId(refPath);
|
|
||||||
var refVal = this._refs[id];
|
|
||||||
if (typeof refVal == 'string') {
|
|
||||||
return resolveRecursive.call(this, root, refVal, p);
|
|
||||||
} else if (refVal instanceof SchemaObject) {
|
|
||||||
if (!refVal.validate) this._compile(refVal);
|
|
||||||
root = refVal;
|
|
||||||
} else {
|
|
||||||
refVal = this._schemas[id];
|
|
||||||
if (refVal instanceof SchemaObject) {
|
|
||||||
if (!refVal.validate) this._compile(refVal);
|
|
||||||
if (id == normalizeId(ref))
|
|
||||||
return { schema: refVal, root: root, baseId: baseId };
|
|
||||||
root = refVal;
|
|
||||||
} else {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!root.schema) return;
|
|
||||||
baseId = getFullPath(this._getId(root.schema));
|
|
||||||
}
|
|
||||||
return getJsonPointer.call(this, p, baseId, root.schema, root);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* @this Ajv */
|
|
||||||
function resolveRecursive(root, ref, parsedRef) {
|
|
||||||
/* jshint validthis: true */
|
|
||||||
var res = resolveSchema.call(this, root, ref);
|
|
||||||
if (res) {
|
|
||||||
var schema = res.schema;
|
|
||||||
var baseId = res.baseId;
|
|
||||||
root = res.root;
|
|
||||||
var id = this._getId(schema);
|
|
||||||
if (id) baseId = resolveUrl(baseId, id);
|
|
||||||
return getJsonPointer.call(this, parsedRef, baseId, schema, root);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
var PREVENT_SCOPE_CHANGE = util.toHash(['properties', 'patternProperties', 'enum', 'dependencies', 'definitions']);
|
|
||||||
/* @this Ajv */
|
|
||||||
function getJsonPointer(parsedRef, baseId, schema, root) {
|
|
||||||
/* jshint validthis: true */
|
|
||||||
parsedRef.fragment = parsedRef.fragment || '';
|
|
||||||
if (parsedRef.fragment.slice(0,1) != '/') return;
|
|
||||||
var parts = parsedRef.fragment.split('/');
|
|
||||||
|
|
||||||
for (var i = 1; i < parts.length; i++) {
|
|
||||||
var part = parts[i];
|
|
||||||
if (part) {
|
|
||||||
part = util.unescapeFragment(part);
|
|
||||||
schema = schema[part];
|
|
||||||
if (schema === undefined) break;
|
|
||||||
var id;
|
|
||||||
if (!PREVENT_SCOPE_CHANGE[part]) {
|
|
||||||
id = this._getId(schema);
|
|
||||||
if (id) baseId = resolveUrl(baseId, id);
|
|
||||||
if (schema.$ref) {
|
|
||||||
var $ref = resolveUrl(baseId, schema.$ref);
|
|
||||||
var res = resolveSchema.call(this, root, $ref);
|
|
||||||
if (res) {
|
|
||||||
schema = res.schema;
|
|
||||||
root = res.root;
|
|
||||||
baseId = res.baseId;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (schema !== undefined && schema !== root.schema)
|
|
||||||
return { schema: schema, root: root, baseId: baseId };
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
var SIMPLE_INLINED = util.toHash([
|
|
||||||
'type', 'format', 'pattern',
|
|
||||||
'maxLength', 'minLength',
|
|
||||||
'maxProperties', 'minProperties',
|
|
||||||
'maxItems', 'minItems',
|
|
||||||
'maximum', 'minimum',
|
|
||||||
'uniqueItems', 'multipleOf',
|
|
||||||
'required', 'enum'
|
|
||||||
]);
|
|
||||||
function inlineRef(schema, limit) {
|
|
||||||
if (limit === false) return false;
|
|
||||||
if (limit === undefined || limit === true) return checkNoRef(schema);
|
|
||||||
else if (limit) return countKeys(schema) <= limit;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function checkNoRef(schema) {
|
|
||||||
var item;
|
|
||||||
if (Array.isArray(schema)) {
|
|
||||||
for (var i=0; i<schema.length; i++) {
|
|
||||||
item = schema[i];
|
|
||||||
if (typeof item == 'object' && !checkNoRef(item)) return false;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
for (var key in schema) {
|
|
||||||
if (key == '$ref') return false;
|
|
||||||
item = schema[key];
|
|
||||||
if (typeof item == 'object' && !checkNoRef(item)) return false;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function countKeys(schema) {
|
|
||||||
var count = 0, item;
|
|
||||||
if (Array.isArray(schema)) {
|
|
||||||
for (var i=0; i<schema.length; i++) {
|
|
||||||
item = schema[i];
|
|
||||||
if (typeof item == 'object') count += countKeys(item);
|
|
||||||
if (count == Infinity) return Infinity;
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
for (var key in schema) {
|
|
||||||
if (key == '$ref') return Infinity;
|
|
||||||
if (SIMPLE_INLINED[key]) {
|
|
||||||
count++;
|
|
||||||
} else {
|
|
||||||
item = schema[key];
|
|
||||||
if (typeof item == 'object') count += countKeys(item) + 1;
|
|
||||||
if (count == Infinity) return Infinity;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return count;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function getFullPath(id, normalize) {
|
|
||||||
if (normalize !== false) id = normalizeId(id);
|
|
||||||
var p = URI.parse(id);
|
|
||||||
return _getFullPath(p);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function _getFullPath(p) {
|
|
||||||
return URI.serialize(p).split('#')[0] + '#';
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
var TRAILING_SLASH_HASH = /#\/?$/;
|
|
||||||
function normalizeId(id) {
|
|
||||||
return id ? id.replace(TRAILING_SLASH_HASH, '') : '';
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function resolveUrl(baseId, id) {
|
|
||||||
id = normalizeId(id);
|
|
||||||
return URI.resolve(baseId, id);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
/* @this Ajv */
|
|
||||||
function resolveIds(schema) {
|
|
||||||
var schemaId = normalizeId(this._getId(schema));
|
|
||||||
var baseIds = {'': schemaId};
|
|
||||||
var fullPaths = {'': getFullPath(schemaId, false)};
|
|
||||||
var localRefs = {};
|
|
||||||
var self = this;
|
|
||||||
|
|
||||||
traverse(schema, {allKeys: true}, function(sch, jsonPtr, rootSchema, parentJsonPtr, parentKeyword, parentSchema, keyIndex) {
|
|
||||||
if (jsonPtr === '') return;
|
|
||||||
var id = self._getId(sch);
|
|
||||||
var baseId = baseIds[parentJsonPtr];
|
|
||||||
var fullPath = fullPaths[parentJsonPtr] + '/' + parentKeyword;
|
|
||||||
if (keyIndex !== undefined)
|
|
||||||
fullPath += '/' + (typeof keyIndex == 'number' ? keyIndex : util.escapeFragment(keyIndex));
|
|
||||||
|
|
||||||
if (typeof id == 'string') {
|
|
||||||
id = baseId = normalizeId(baseId ? URI.resolve(baseId, id) : id);
|
|
||||||
|
|
||||||
var refVal = self._refs[id];
|
|
||||||
if (typeof refVal == 'string') refVal = self._refs[refVal];
|
|
||||||
if (refVal && refVal.schema) {
|
|
||||||
if (!equal(sch, refVal.schema))
|
|
||||||
throw new Error('id "' + id + '" resolves to more than one schema');
|
|
||||||
} else if (id != normalizeId(fullPath)) {
|
|
||||||
if (id[0] == '#') {
|
|
||||||
if (localRefs[id] && !equal(sch, localRefs[id]))
|
|
||||||
throw new Error('id "' + id + '" resolves to more than one schema');
|
|
||||||
localRefs[id] = sch;
|
|
||||||
} else {
|
|
||||||
self._refs[id] = fullPath;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
baseIds[jsonPtr] = baseId;
|
|
||||||
fullPaths[jsonPtr] = fullPath;
|
|
||||||
});
|
|
||||||
|
|
||||||
return localRefs;
|
|
||||||
}
|
|
66
node_modules/ajv/lib/compile/rules.js
generated
vendored
66
node_modules/ajv/lib/compile/rules.js
generated
vendored
@@ -1,66 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
var ruleModules = require('../dotjs')
|
|
||||||
, toHash = require('./util').toHash;
|
|
||||||
|
|
||||||
module.exports = function rules() {
|
|
||||||
var RULES = [
|
|
||||||
{ type: 'number',
|
|
||||||
rules: [ { 'maximum': ['exclusiveMaximum'] },
|
|
||||||
{ 'minimum': ['exclusiveMinimum'] }, 'multipleOf', 'format'] },
|
|
||||||
{ type: 'string',
|
|
||||||
rules: [ 'maxLength', 'minLength', 'pattern', 'format' ] },
|
|
||||||
{ type: 'array',
|
|
||||||
rules: [ 'maxItems', 'minItems', 'items', 'contains', 'uniqueItems' ] },
|
|
||||||
{ type: 'object',
|
|
||||||
rules: [ 'maxProperties', 'minProperties', 'required', 'dependencies', 'propertyNames',
|
|
||||||
{ 'properties': ['additionalProperties', 'patternProperties'] } ] },
|
|
||||||
{ rules: [ '$ref', 'const', 'enum', 'not', 'anyOf', 'oneOf', 'allOf', 'if' ] }
|
|
||||||
];
|
|
||||||
|
|
||||||
var ALL = [ 'type', '$comment' ];
|
|
||||||
var KEYWORDS = [
|
|
||||||
'$schema', '$id', 'id', '$data', '$async', 'title',
|
|
||||||
'description', 'default', 'definitions',
|
|
||||||
'examples', 'readOnly', 'writeOnly',
|
|
||||||
'contentMediaType', 'contentEncoding',
|
|
||||||
'additionalItems', 'then', 'else'
|
|
||||||
];
|
|
||||||
var TYPES = [ 'number', 'integer', 'string', 'array', 'object', 'boolean', 'null' ];
|
|
||||||
RULES.all = toHash(ALL);
|
|
||||||
RULES.types = toHash(TYPES);
|
|
||||||
|
|
||||||
RULES.forEach(function (group) {
|
|
||||||
group.rules = group.rules.map(function (keyword) {
|
|
||||||
var implKeywords;
|
|
||||||
if (typeof keyword == 'object') {
|
|
||||||
var key = Object.keys(keyword)[0];
|
|
||||||
implKeywords = keyword[key];
|
|
||||||
keyword = key;
|
|
||||||
implKeywords.forEach(function (k) {
|
|
||||||
ALL.push(k);
|
|
||||||
RULES.all[k] = true;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
ALL.push(keyword);
|
|
||||||
var rule = RULES.all[keyword] = {
|
|
||||||
keyword: keyword,
|
|
||||||
code: ruleModules[keyword],
|
|
||||||
implements: implKeywords
|
|
||||||
};
|
|
||||||
return rule;
|
|
||||||
});
|
|
||||||
|
|
||||||
RULES.all.$comment = {
|
|
||||||
keyword: '$comment',
|
|
||||||
code: ruleModules.$comment
|
|
||||||
};
|
|
||||||
|
|
||||||
if (group.type) RULES.types[group.type] = group;
|
|
||||||
});
|
|
||||||
|
|
||||||
RULES.keywords = toHash(ALL.concat(KEYWORDS));
|
|
||||||
RULES.custom = {};
|
|
||||||
|
|
||||||
return RULES;
|
|
||||||
};
|
|
9
node_modules/ajv/lib/compile/schema_obj.js
generated
vendored
9
node_modules/ajv/lib/compile/schema_obj.js
generated
vendored
@@ -1,9 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
var util = require('./util');
|
|
||||||
|
|
||||||
module.exports = SchemaObject;
|
|
||||||
|
|
||||||
function SchemaObject(obj) {
|
|
||||||
util.copy(obj, this);
|
|
||||||
}
|
|
20
node_modules/ajv/lib/compile/ucs2length.js
generated
vendored
20
node_modules/ajv/lib/compile/ucs2length.js
generated
vendored
@@ -1,20 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
// https://mathiasbynens.be/notes/javascript-encoding
|
|
||||||
// https://github.com/bestiejs/punycode.js - punycode.ucs2.decode
|
|
||||||
module.exports = function ucs2length(str) {
|
|
||||||
var length = 0
|
|
||||||
, len = str.length
|
|
||||||
, pos = 0
|
|
||||||
, value;
|
|
||||||
while (pos < len) {
|
|
||||||
length++;
|
|
||||||
value = str.charCodeAt(pos++);
|
|
||||||
if (value >= 0xD800 && value <= 0xDBFF && pos < len) {
|
|
||||||
// high surrogate, and there is a next character
|
|
||||||
value = str.charCodeAt(pos);
|
|
||||||
if ((value & 0xFC00) == 0xDC00) pos++; // low surrogate
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return length;
|
|
||||||
};
|
|
274
node_modules/ajv/lib/compile/util.js
generated
vendored
274
node_modules/ajv/lib/compile/util.js
generated
vendored
@@ -1,274 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
|
|
||||||
module.exports = {
|
|
||||||
copy: copy,
|
|
||||||
checkDataType: checkDataType,
|
|
||||||
checkDataTypes: checkDataTypes,
|
|
||||||
coerceToTypes: coerceToTypes,
|
|
||||||
toHash: toHash,
|
|
||||||
getProperty: getProperty,
|
|
||||||
escapeQuotes: escapeQuotes,
|
|
||||||
equal: require('fast-deep-equal'),
|
|
||||||
ucs2length: require('./ucs2length'),
|
|
||||||
varOccurences: varOccurences,
|
|
||||||
varReplace: varReplace,
|
|
||||||
cleanUpCode: cleanUpCode,
|
|
||||||
finalCleanUpCode: finalCleanUpCode,
|
|
||||||
schemaHasRules: schemaHasRules,
|
|
||||||
schemaHasRulesExcept: schemaHasRulesExcept,
|
|
||||||
schemaUnknownRules: schemaUnknownRules,
|
|
||||||
toQuotedString: toQuotedString,
|
|
||||||
getPathExpr: getPathExpr,
|
|
||||||
getPath: getPath,
|
|
||||||
getData: getData,
|
|
||||||
unescapeFragment: unescapeFragment,
|
|
||||||
unescapeJsonPointer: unescapeJsonPointer,
|
|
||||||
escapeFragment: escapeFragment,
|
|
||||||
escapeJsonPointer: escapeJsonPointer
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
function copy(o, to) {
|
|
||||||
to = to || {};
|
|
||||||
for (var key in o) to[key] = o[key];
|
|
||||||
return to;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function checkDataType(dataType, data, negate) {
|
|
||||||
var EQUAL = negate ? ' !== ' : ' === '
|
|
||||||
, AND = negate ? ' || ' : ' && '
|
|
||||||
, OK = negate ? '!' : ''
|
|
||||||
, NOT = negate ? '' : '!';
|
|
||||||
switch (dataType) {
|
|
||||||
case 'null': return data + EQUAL + 'null';
|
|
||||||
case 'array': return OK + 'Array.isArray(' + data + ')';
|
|
||||||
case 'object': return '(' + OK + data + AND +
|
|
||||||
'typeof ' + data + EQUAL + '"object"' + AND +
|
|
||||||
NOT + 'Array.isArray(' + data + '))';
|
|
||||||
case 'integer': return '(typeof ' + data + EQUAL + '"number"' + AND +
|
|
||||||
NOT + '(' + data + ' % 1)' +
|
|
||||||
AND + data + EQUAL + data + ')';
|
|
||||||
default: return 'typeof ' + data + EQUAL + '"' + dataType + '"';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function checkDataTypes(dataTypes, data) {
|
|
||||||
switch (dataTypes.length) {
|
|
||||||
case 1: return checkDataType(dataTypes[0], data, true);
|
|
||||||
default:
|
|
||||||
var code = '';
|
|
||||||
var types = toHash(dataTypes);
|
|
||||||
if (types.array && types.object) {
|
|
||||||
code = types.null ? '(': '(!' + data + ' || ';
|
|
||||||
code += 'typeof ' + data + ' !== "object")';
|
|
||||||
delete types.null;
|
|
||||||
delete types.array;
|
|
||||||
delete types.object;
|
|
||||||
}
|
|
||||||
if (types.number) delete types.integer;
|
|
||||||
for (var t in types)
|
|
||||||
code += (code ? ' && ' : '' ) + checkDataType(t, data, true);
|
|
||||||
|
|
||||||
return code;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
var COERCE_TO_TYPES = toHash([ 'string', 'number', 'integer', 'boolean', 'null' ]);
|
|
||||||
function coerceToTypes(optionCoerceTypes, dataTypes) {
|
|
||||||
if (Array.isArray(dataTypes)) {
|
|
||||||
var types = [];
|
|
||||||
for (var i=0; i<dataTypes.length; i++) {
|
|
||||||
var t = dataTypes[i];
|
|
||||||
if (COERCE_TO_TYPES[t]) types[types.length] = t;
|
|
||||||
else if (optionCoerceTypes === 'array' && t === 'array') types[types.length] = t;
|
|
||||||
}
|
|
||||||
if (types.length) return types;
|
|
||||||
} else if (COERCE_TO_TYPES[dataTypes]) {
|
|
||||||
return [dataTypes];
|
|
||||||
} else if (optionCoerceTypes === 'array' && dataTypes === 'array') {
|
|
||||||
return ['array'];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function toHash(arr) {
|
|
||||||
var hash = {};
|
|
||||||
for (var i=0; i<arr.length; i++) hash[arr[i]] = true;
|
|
||||||
return hash;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
var IDENTIFIER = /^[a-z$_][a-z$_0-9]*$/i;
|
|
||||||
var SINGLE_QUOTE = /'|\\/g;
|
|
||||||
function getProperty(key) {
|
|
||||||
return typeof key == 'number'
|
|
||||||
? '[' + key + ']'
|
|
||||||
: IDENTIFIER.test(key)
|
|
||||||
? '.' + key
|
|
||||||
: "['" + escapeQuotes(key) + "']";
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function escapeQuotes(str) {
|
|
||||||
return str.replace(SINGLE_QUOTE, '\\$&')
|
|
||||||
.replace(/\n/g, '\\n')
|
|
||||||
.replace(/\r/g, '\\r')
|
|
||||||
.replace(/\f/g, '\\f')
|
|
||||||
.replace(/\t/g, '\\t');
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function varOccurences(str, dataVar) {
|
|
||||||
dataVar += '[^0-9]';
|
|
||||||
var matches = str.match(new RegExp(dataVar, 'g'));
|
|
||||||
return matches ? matches.length : 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function varReplace(str, dataVar, expr) {
|
|
||||||
dataVar += '([^0-9])';
|
|
||||||
expr = expr.replace(/\$/g, '$$$$');
|
|
||||||
return str.replace(new RegExp(dataVar, 'g'), expr + '$1');
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
var EMPTY_ELSE = /else\s*{\s*}/g
|
|
||||||
, EMPTY_IF_NO_ELSE = /if\s*\([^)]+\)\s*\{\s*\}(?!\s*else)/g
|
|
||||||
, EMPTY_IF_WITH_ELSE = /if\s*\(([^)]+)\)\s*\{\s*\}\s*else(?!\s*if)/g;
|
|
||||||
function cleanUpCode(out) {
|
|
||||||
return out.replace(EMPTY_ELSE, '')
|
|
||||||
.replace(EMPTY_IF_NO_ELSE, '')
|
|
||||||
.replace(EMPTY_IF_WITH_ELSE, 'if (!($1))');
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
var ERRORS_REGEXP = /[^v.]errors/g
|
|
||||||
, REMOVE_ERRORS = /var errors = 0;|var vErrors = null;|validate.errors = vErrors;/g
|
|
||||||
, REMOVE_ERRORS_ASYNC = /var errors = 0;|var vErrors = null;/g
|
|
||||||
, RETURN_VALID = 'return errors === 0;'
|
|
||||||
, RETURN_TRUE = 'validate.errors = null; return true;'
|
|
||||||
, RETURN_ASYNC = /if \(errors === 0\) return data;\s*else throw new ValidationError\(vErrors\);/
|
|
||||||
, RETURN_DATA_ASYNC = 'return data;'
|
|
||||||
, ROOTDATA_REGEXP = /[^A-Za-z_$]rootData[^A-Za-z0-9_$]/g
|
|
||||||
, REMOVE_ROOTDATA = /if \(rootData === undefined\) rootData = data;/;
|
|
||||||
|
|
||||||
function finalCleanUpCode(out, async) {
|
|
||||||
var matches = out.match(ERRORS_REGEXP);
|
|
||||||
if (matches && matches.length == 2) {
|
|
||||||
out = async
|
|
||||||
? out.replace(REMOVE_ERRORS_ASYNC, '')
|
|
||||||
.replace(RETURN_ASYNC, RETURN_DATA_ASYNC)
|
|
||||||
: out.replace(REMOVE_ERRORS, '')
|
|
||||||
.replace(RETURN_VALID, RETURN_TRUE);
|
|
||||||
}
|
|
||||||
|
|
||||||
matches = out.match(ROOTDATA_REGEXP);
|
|
||||||
if (!matches || matches.length !== 3) return out;
|
|
||||||
return out.replace(REMOVE_ROOTDATA, '');
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function schemaHasRules(schema, rules) {
|
|
||||||
if (typeof schema == 'boolean') return !schema;
|
|
||||||
for (var key in schema) if (rules[key]) return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function schemaHasRulesExcept(schema, rules, exceptKeyword) {
|
|
||||||
if (typeof schema == 'boolean') return !schema && exceptKeyword != 'not';
|
|
||||||
for (var key in schema) if (key != exceptKeyword && rules[key]) return true;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function schemaUnknownRules(schema, rules) {
|
|
||||||
if (typeof schema == 'boolean') return;
|
|
||||||
for (var key in schema) if (!rules[key]) return key;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function toQuotedString(str) {
|
|
||||||
return '\'' + escapeQuotes(str) + '\'';
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function getPathExpr(currentPath, expr, jsonPointers, isNumber) {
|
|
||||||
var path = jsonPointers // false by default
|
|
||||||
? '\'/\' + ' + expr + (isNumber ? '' : '.replace(/~/g, \'~0\').replace(/\\//g, \'~1\')')
|
|
||||||
: (isNumber ? '\'[\' + ' + expr + ' + \']\'' : '\'[\\\'\' + ' + expr + ' + \'\\\']\'');
|
|
||||||
return joinPaths(currentPath, path);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function getPath(currentPath, prop, jsonPointers) {
|
|
||||||
var path = jsonPointers // false by default
|
|
||||||
? toQuotedString('/' + escapeJsonPointer(prop))
|
|
||||||
: toQuotedString(getProperty(prop));
|
|
||||||
return joinPaths(currentPath, path);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
var JSON_POINTER = /^\/(?:[^~]|~0|~1)*$/;
|
|
||||||
var RELATIVE_JSON_POINTER = /^([0-9]+)(#|\/(?:[^~]|~0|~1)*)?$/;
|
|
||||||
function getData($data, lvl, paths) {
|
|
||||||
var up, jsonPointer, data, matches;
|
|
||||||
if ($data === '') return 'rootData';
|
|
||||||
if ($data[0] == '/') {
|
|
||||||
if (!JSON_POINTER.test($data)) throw new Error('Invalid JSON-pointer: ' + $data);
|
|
||||||
jsonPointer = $data;
|
|
||||||
data = 'rootData';
|
|
||||||
} else {
|
|
||||||
matches = $data.match(RELATIVE_JSON_POINTER);
|
|
||||||
if (!matches) throw new Error('Invalid JSON-pointer: ' + $data);
|
|
||||||
up = +matches[1];
|
|
||||||
jsonPointer = matches[2];
|
|
||||||
if (jsonPointer == '#') {
|
|
||||||
if (up >= lvl) throw new Error('Cannot access property/index ' + up + ' levels up, current level is ' + lvl);
|
|
||||||
return paths[lvl - up];
|
|
||||||
}
|
|
||||||
|
|
||||||
if (up > lvl) throw new Error('Cannot access data ' + up + ' levels up, current level is ' + lvl);
|
|
||||||
data = 'data' + ((lvl - up) || '');
|
|
||||||
if (!jsonPointer) return data;
|
|
||||||
}
|
|
||||||
|
|
||||||
var expr = data;
|
|
||||||
var segments = jsonPointer.split('/');
|
|
||||||
for (var i=0; i<segments.length; i++) {
|
|
||||||
var segment = segments[i];
|
|
||||||
if (segment) {
|
|
||||||
data += getProperty(unescapeJsonPointer(segment));
|
|
||||||
expr += ' && ' + data;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return expr;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function joinPaths (a, b) {
|
|
||||||
if (a == '""') return b;
|
|
||||||
return (a + ' + ' + b).replace(/' \+ '/g, '');
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function unescapeFragment(str) {
|
|
||||||
return unescapeJsonPointer(decodeURIComponent(str));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function escapeFragment(str) {
|
|
||||||
return encodeURIComponent(escapeJsonPointer(str));
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function escapeJsonPointer(str) {
|
|
||||||
return str.replace(/~/g, '~0').replace(/\//g, '~1');
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
function unescapeJsonPointer(str) {
|
|
||||||
return str.replace(/~1/g, '/').replace(/~0/g, '~');
|
|
||||||
}
|
|
49
node_modules/ajv/lib/data.js
generated
vendored
49
node_modules/ajv/lib/data.js
generated
vendored
@@ -1,49 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
var KEYWORDS = [
|
|
||||||
'multipleOf',
|
|
||||||
'maximum',
|
|
||||||
'exclusiveMaximum',
|
|
||||||
'minimum',
|
|
||||||
'exclusiveMinimum',
|
|
||||||
'maxLength',
|
|
||||||
'minLength',
|
|
||||||
'pattern',
|
|
||||||
'additionalItems',
|
|
||||||
'maxItems',
|
|
||||||
'minItems',
|
|
||||||
'uniqueItems',
|
|
||||||
'maxProperties',
|
|
||||||
'minProperties',
|
|
||||||
'required',
|
|
||||||
'additionalProperties',
|
|
||||||
'enum',
|
|
||||||
'format',
|
|
||||||
'const'
|
|
||||||
];
|
|
||||||
|
|
||||||
module.exports = function (metaSchema, keywordsJsonPointers) {
|
|
||||||
for (var i=0; i<keywordsJsonPointers.length; i++) {
|
|
||||||
metaSchema = JSON.parse(JSON.stringify(metaSchema));
|
|
||||||
var segments = keywordsJsonPointers[i].split('/');
|
|
||||||
var keywords = metaSchema;
|
|
||||||
var j;
|
|
||||||
for (j=1; j<segments.length; j++)
|
|
||||||
keywords = keywords[segments[j]];
|
|
||||||
|
|
||||||
for (j=0; j<KEYWORDS.length; j++) {
|
|
||||||
var key = KEYWORDS[j];
|
|
||||||
var schema = keywords[key];
|
|
||||||
if (schema) {
|
|
||||||
keywords[key] = {
|
|
||||||
anyOf: [
|
|
||||||
schema,
|
|
||||||
{ $ref: 'https://raw.githubusercontent.com/epoberezkin/ajv/master/lib/refs/data.json#' }
|
|
||||||
]
|
|
||||||
};
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return metaSchema;
|
|
||||||
};
|
|
37
node_modules/ajv/lib/definition_schema.js
generated
vendored
37
node_modules/ajv/lib/definition_schema.js
generated
vendored
@@ -1,37 +0,0 @@
|
|||||||
'use strict';
|
|
||||||
|
|
||||||
var metaSchema = require('./refs/json-schema-draft-07.json');
|
|
||||||
|
|
||||||
module.exports = {
|
|
||||||
$id: 'https://github.com/epoberezkin/ajv/blob/master/lib/definition_schema.js',
|
|
||||||
definitions: {
|
|
||||||
simpleTypes: metaSchema.definitions.simpleTypes
|
|
||||||
},
|
|
||||||
type: 'object',
|
|
||||||
dependencies: {
|
|
||||||
schema: ['validate'],
|
|
||||||
$data: ['validate'],
|
|
||||||
statements: ['inline'],
|
|
||||||
valid: {not: {required: ['macro']}}
|
|
||||||
},
|
|
||||||
properties: {
|
|
||||||
type: metaSchema.properties.type,
|
|
||||||
schema: {type: 'boolean'},
|
|
||||||
statements: {type: 'boolean'},
|
|
||||||
dependencies: {
|
|
||||||
type: 'array',
|
|
||||||
items: {type: 'string'}
|
|
||||||
},
|
|
||||||
metaSchema: {type: 'object'},
|
|
||||||
modifying: {type: 'boolean'},
|
|
||||||
valid: {type: 'boolean'},
|
|
||||||
$data: {type: 'boolean'},
|
|
||||||
async: {type: 'boolean'},
|
|
||||||
errors: {
|
|
||||||
anyOf: [
|
|
||||||
{type: 'boolean'},
|
|
||||||
{const: 'full'}
|
|
||||||
]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
};
|
|
104
node_modules/ajv/lib/dot/_limit.jst
generated
vendored
104
node_modules/ajv/lib/dot/_limit.jst
generated
vendored
@@ -1,104 +0,0 @@
|
|||||||
{{# def.definitions }}
|
|
||||||
{{# def.errors }}
|
|
||||||
{{# def.setupKeyword }}
|
|
||||||
{{# def.$data }}
|
|
||||||
|
|
||||||
{{## def.setExclusiveLimit:
|
|
||||||
$exclusive = true;
|
|
||||||
$errorKeyword = $exclusiveKeyword;
|
|
||||||
$errSchemaPath = it.errSchemaPath + '/' + $exclusiveKeyword;
|
|
||||||
#}}
|
|
||||||
|
|
||||||
{{
|
|
||||||
var $isMax = $keyword == 'maximum'
|
|
||||||
, $exclusiveKeyword = $isMax ? 'exclusiveMaximum' : 'exclusiveMinimum'
|
|
||||||
, $schemaExcl = it.schema[$exclusiveKeyword]
|
|
||||||
, $isDataExcl = it.opts.$data && $schemaExcl && $schemaExcl.$data
|
|
||||||
, $op = $isMax ? '<' : '>'
|
|
||||||
, $notOp = $isMax ? '>' : '<'
|
|
||||||
, $errorKeyword = undefined;
|
|
||||||
}}
|
|
||||||
|
|
||||||
{{? $isDataExcl }}
|
|
||||||
{{
|
|
||||||
var $schemaValueExcl = it.util.getData($schemaExcl.$data, $dataLvl, it.dataPathArr)
|
|
||||||
, $exclusive = 'exclusive' + $lvl
|
|
||||||
, $exclType = 'exclType' + $lvl
|
|
||||||
, $exclIsNumber = 'exclIsNumber' + $lvl
|
|
||||||
, $opExpr = 'op' + $lvl
|
|
||||||
, $opStr = '\' + ' + $opExpr + ' + \'';
|
|
||||||
}}
|
|
||||||
var schemaExcl{{=$lvl}} = {{=$schemaValueExcl}};
|
|
||||||
{{ $schemaValueExcl = 'schemaExcl' + $lvl; }}
|
|
||||||
|
|
||||||
var {{=$exclusive}};
|
|
||||||
var {{=$exclType}} = typeof {{=$schemaValueExcl}};
|
|
||||||
if ({{=$exclType}} != 'boolean' && {{=$exclType}} != 'undefined' && {{=$exclType}} != 'number') {
|
|
||||||
{{ var $errorKeyword = $exclusiveKeyword; }}
|
|
||||||
{{# def.error:'_exclusiveLimit' }}
|
|
||||||
} else if ({{# def.$dataNotType:'number' }}
|
|
||||||
{{=$exclType}} == 'number'
|
|
||||||
? (
|
|
||||||
({{=$exclusive}} = {{=$schemaValue}} === undefined || {{=$schemaValueExcl}} {{=$op}}= {{=$schemaValue}})
|
|
||||||
? {{=$data}} {{=$notOp}}= {{=$schemaValueExcl}}
|
|
||||||
: {{=$data}} {{=$notOp}} {{=$schemaValue}}
|
|
||||||
)
|
|
||||||
: (
|
|
||||||
({{=$exclusive}} = {{=$schemaValueExcl}} === true)
|
|
||||||
? {{=$data}} {{=$notOp}}= {{=$schemaValue}}
|
|
||||||
: {{=$data}} {{=$notOp}} {{=$schemaValue}}
|
|
||||||
)
|
|
||||||
|| {{=$data}} !== {{=$data}}) {
|
|
||||||
var op{{=$lvl}} = {{=$exclusive}} ? '{{=$op}}' : '{{=$op}}=';
|
|
||||||
{{
|
|
||||||
if ($schema === undefined) {
|
|
||||||
$errorKeyword = $exclusiveKeyword;
|
|
||||||
$errSchemaPath = it.errSchemaPath + '/' + $exclusiveKeyword;
|
|
||||||
$schemaValue = $schemaValueExcl;
|
|
||||||
$isData = $isDataExcl;
|
|
||||||
}
|
|
||||||
}}
|
|
||||||
{{??}}
|
|
||||||
{{
|
|
||||||
var $exclIsNumber = typeof $schemaExcl == 'number'
|
|
||||||
, $opStr = $op; /*used in error*/
|
|
||||||
}}
|
|
||||||
|
|
||||||
{{? $exclIsNumber && $isData }}
|
|
||||||
{{ var $opExpr = '\'' + $opStr + '\''; /*used in error*/ }}
|
|
||||||
if ({{# def.$dataNotType:'number' }}
|
|
||||||
( {{=$schemaValue}} === undefined
|
|
||||||
|| {{=$schemaExcl}} {{=$op}}= {{=$schemaValue}}
|
|
||||||
? {{=$data}} {{=$notOp}}= {{=$schemaExcl}}
|
|
||||||
: {{=$data}} {{=$notOp}} {{=$schemaValue}} )
|
|
||||||
|| {{=$data}} !== {{=$data}}) {
|
|
||||||
{{??}}
|
|
||||||
{{
|
|
||||||
if ($exclIsNumber && $schema === undefined) {
|
|
||||||
{{# def.setExclusiveLimit }}
|
|
||||||
$schemaValue = $schemaExcl;
|
|
||||||
$notOp += '=';
|
|
||||||
} else {
|
|
||||||
if ($exclIsNumber)
|
|
||||||
$schemaValue = Math[$isMax ? 'min' : 'max']($schemaExcl, $schema);
|
|
||||||
|
|
||||||
if ($schemaExcl === ($exclIsNumber ? $schemaValue : true)) {
|
|
||||||
{{# def.setExclusiveLimit }}
|
|
||||||
$notOp += '=';
|
|
||||||
} else {
|
|
||||||
$exclusive = false;
|
|
||||||
$opStr += '=';
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
var $opExpr = '\'' + $opStr + '\''; /*used in error*/
|
|
||||||
}}
|
|
||||||
|
|
||||||
if ({{# def.$dataNotType:'number' }}
|
|
||||||
{{=$data}} {{=$notOp}} {{=$schemaValue}}
|
|
||||||
|| {{=$data}} !== {{=$data}}) {
|
|
||||||
{{?}}
|
|
||||||
{{?}}
|
|
||||||
{{ $errorKeyword = $errorKeyword || $keyword; }}
|
|
||||||
{{# def.error:'_limit' }}
|
|
||||||
} {{? $breakOnError }} else { {{?}}
|
|
10
node_modules/ajv/lib/dot/_limitItems.jst
generated
vendored
10
node_modules/ajv/lib/dot/_limitItems.jst
generated
vendored
@@ -1,10 +0,0 @@
|
|||||||
{{# def.definitions }}
|
|
||||||
{{# def.errors }}
|
|
||||||
{{# def.setupKeyword }}
|
|
||||||
{{# def.$data }}
|
|
||||||
|
|
||||||
{{ var $op = $keyword == 'maxItems' ? '>' : '<'; }}
|
|
||||||
if ({{# def.$dataNotType:'number' }} {{=$data}}.length {{=$op}} {{=$schemaValue}}) {
|
|
||||||
{{ var $errorKeyword = $keyword; }}
|
|
||||||
{{# def.error:'_limitItems' }}
|
|
||||||
} {{? $breakOnError }} else { {{?}}
|
|
10
node_modules/ajv/lib/dot/_limitLength.jst
generated
vendored
10
node_modules/ajv/lib/dot/_limitLength.jst
generated
vendored
@@ -1,10 +0,0 @@
|
|||||||
{{# def.definitions }}
|
|
||||||
{{# def.errors }}
|
|
||||||
{{# def.setupKeyword }}
|
|
||||||
{{# def.$data }}
|
|
||||||
|
|
||||||
{{ var $op = $keyword == 'maxLength' ? '>' : '<'; }}
|
|
||||||
if ({{# def.$dataNotType:'number' }} {{# def.strLength }} {{=$op}} {{=$schemaValue}}) {
|
|
||||||
{{ var $errorKeyword = $keyword; }}
|
|
||||||
{{# def.error:'_limitLength' }}
|
|
||||||
} {{? $breakOnError }} else { {{?}}
|
|
10
node_modules/ajv/lib/dot/_limitProperties.jst
generated
vendored
10
node_modules/ajv/lib/dot/_limitProperties.jst
generated
vendored
@@ -1,10 +0,0 @@
|
|||||||
{{# def.definitions }}
|
|
||||||
{{# def.errors }}
|
|
||||||
{{# def.setupKeyword }}
|
|
||||||
{{# def.$data }}
|
|
||||||
|
|
||||||
{{ var $op = $keyword == 'maxProperties' ? '>' : '<'; }}
|
|
||||||
if ({{# def.$dataNotType:'number' }} Object.keys({{=$data}}).length {{=$op}} {{=$schemaValue}}) {
|
|
||||||
{{ var $errorKeyword = $keyword; }}
|
|
||||||
{{# def.error:'_limitProperties' }}
|
|
||||||
} {{? $breakOnError }} else { {{?}}
|
|
34
node_modules/ajv/lib/dot/allOf.jst
generated
vendored
34
node_modules/ajv/lib/dot/allOf.jst
generated
vendored
@@ -1,34 +0,0 @@
|
|||||||
{{# def.definitions }}
|
|
||||||
{{# def.errors }}
|
|
||||||
{{# def.setupKeyword }}
|
|
||||||
{{# def.setupNextLevel }}
|
|
||||||
|
|
||||||
{{
|
|
||||||
var $currentBaseId = $it.baseId
|
|
||||||
, $allSchemasEmpty = true;
|
|
||||||
}}
|
|
||||||
|
|
||||||
{{~ $schema:$sch:$i }}
|
|
||||||
{{? {{# def.nonEmptySchema:$sch }} }}
|
|
||||||
{{
|
|
||||||
$allSchemasEmpty = false;
|
|
||||||
$it.schema = $sch;
|
|
||||||
$it.schemaPath = $schemaPath + '[' + $i + ']';
|
|
||||||
$it.errSchemaPath = $errSchemaPath + '/' + $i;
|
|
||||||
}}
|
|
||||||
|
|
||||||
{{# def.insertSubschemaCode }}
|
|
||||||
|
|
||||||
{{# def.ifResultValid }}
|
|
||||||
{{?}}
|
|
||||||
{{~}}
|
|
||||||
|
|
||||||
{{? $breakOnError }}
|
|
||||||
{{? $allSchemasEmpty }}
|
|
||||||
if (true) {
|
|
||||||
{{??}}
|
|
||||||
{{= $closingBraces.slice(0,-1) }}
|
|
||||||
{{?}}
|
|
||||||
{{?}}
|
|
||||||
|
|
||||||
{{# def.cleanUp }}
|
|
48
node_modules/ajv/lib/dot/anyOf.jst
generated
vendored
48
node_modules/ajv/lib/dot/anyOf.jst
generated
vendored
@@ -1,48 +0,0 @@
|
|||||||
{{# def.definitions }}
|
|
||||||
{{# def.errors }}
|
|
||||||
{{# def.setupKeyword }}
|
|
||||||
{{# def.setupNextLevel }}
|
|
||||||
|
|
||||||
{{
|
|
||||||
var $noEmptySchema = $schema.every(function($sch) {
|
|
||||||
return {{# def.nonEmptySchema:$sch }};
|
|
||||||
});
|
|
||||||
}}
|
|
||||||
{{? $noEmptySchema }}
|
|
||||||
{{ var $currentBaseId = $it.baseId; }}
|
|
||||||
var {{=$errs}} = errors;
|
|
||||||
var {{=$valid}} = false;
|
|
||||||
|
|
||||||
{{# def.setCompositeRule }}
|
|
||||||
|
|
||||||
{{~ $schema:$sch:$i }}
|
|
||||||
{{
|
|
||||||
$it.schema = $sch;
|
|
||||||
$it.schemaPath = $schemaPath + '[' + $i + ']';
|
|
||||||
$it.errSchemaPath = $errSchemaPath + '/' + $i;
|
|
||||||
}}
|
|
||||||
|
|
||||||
{{# def.insertSubschemaCode }}
|
|
||||||
|
|
||||||
{{=$valid}} = {{=$valid}} || {{=$nextValid}};
|
|
||||||
|
|
||||||
if (!{{=$valid}}) {
|
|
||||||
{{ $closingBraces += '}'; }}
|
|
||||||
{{~}}
|
|
||||||
|
|
||||||
{{# def.resetCompositeRule }}
|
|
||||||
|
|
||||||
{{= $closingBraces }}
|
|
||||||
|
|
||||||
if (!{{=$valid}}) {
|
|
||||||
{{# def.extraError:'anyOf' }}
|
|
||||||
} else {
|
|
||||||
{{# def.resetErrors }}
|
|
||||||
{{? it.opts.allErrors }} } {{?}}
|
|
||||||
|
|
||||||
{{# def.cleanUp }}
|
|
||||||
{{??}}
|
|
||||||
{{? $breakOnError }}
|
|
||||||
if (true) {
|
|
||||||
{{?}}
|
|
||||||
{{?}}
|
|
61
node_modules/ajv/lib/dot/coerce.def
generated
vendored
61
node_modules/ajv/lib/dot/coerce.def
generated
vendored
@@ -1,61 +0,0 @@
|
|||||||
{{## def.coerceType:
|
|
||||||
{{
|
|
||||||
var $dataType = 'dataType' + $lvl
|
|
||||||
, $coerced = 'coerced' + $lvl;
|
|
||||||
}}
|
|
||||||
var {{=$dataType}} = typeof {{=$data}};
|
|
||||||
{{? it.opts.coerceTypes == 'array'}}
|
|
||||||
if ({{=$dataType}} == 'object' && Array.isArray({{=$data}})) {{=$dataType}} = 'array';
|
|
||||||
{{?}}
|
|
||||||
|
|
||||||
var {{=$coerced}} = undefined;
|
|
||||||
|
|
||||||
{{ var $bracesCoercion = ''; }}
|
|
||||||
{{~ $coerceToTypes:$type:$i }}
|
|
||||||
{{? $i }}
|
|
||||||
if ({{=$coerced}} === undefined) {
|
|
||||||
{{ $bracesCoercion += '}'; }}
|
|
||||||
{{?}}
|
|
||||||
|
|
||||||
{{? it.opts.coerceTypes == 'array' && $type != 'array' }}
|
|
||||||
if ({{=$dataType}} == 'array' && {{=$data}}.length == 1) {
|
|
||||||
{{=$coerced}} = {{=$data}} = {{=$data}}[0];
|
|
||||||
{{=$dataType}} = typeof {{=$data}};
|
|
||||||
/*if ({{=$dataType}} == 'object' && Array.isArray({{=$data}})) {{=$dataType}} = 'array';*/
|
|
||||||
}
|
|
||||||
{{?}}
|
|
||||||
|
|
||||||
{{? $type == 'string' }}
|
|
||||||
if ({{=$dataType}} == 'number' || {{=$dataType}} == 'boolean')
|
|
||||||
{{=$coerced}} = '' + {{=$data}};
|
|
||||||
else if ({{=$data}} === null) {{=$coerced}} = '';
|
|
||||||
{{?? $type == 'number' || $type == 'integer' }}
|
|
||||||
if ({{=$dataType}} == 'boolean' || {{=$data}} === null
|
|
||||||
|| ({{=$dataType}} == 'string' && {{=$data}} && {{=$data}} == +{{=$data}}
|
|
||||||
{{? $type == 'integer' }} && !({{=$data}} % 1){{?}}))
|
|
||||||
{{=$coerced}} = +{{=$data}};
|
|
||||||
{{?? $type == 'boolean' }}
|
|
||||||
if ({{=$data}} === 'false' || {{=$data}} === 0 || {{=$data}} === null)
|
|
||||||
{{=$coerced}} = false;
|
|
||||||
else if ({{=$data}} === 'true' || {{=$data}} === 1)
|
|
||||||
{{=$coerced}} = true;
|
|
||||||
{{?? $type == 'null' }}
|
|
||||||
if ({{=$data}} === '' || {{=$data}} === 0 || {{=$data}} === false)
|
|
||||||
{{=$coerced}} = null;
|
|
||||||
{{?? it.opts.coerceTypes == 'array' && $type == 'array' }}
|
|
||||||
if ({{=$dataType}} == 'string' || {{=$dataType}} == 'number' || {{=$dataType}} == 'boolean' || {{=$data}} == null)
|
|
||||||
{{=$coerced}} = [{{=$data}}];
|
|
||||||
{{?}}
|
|
||||||
{{~}}
|
|
||||||
|
|
||||||
{{= $bracesCoercion }}
|
|
||||||
|
|
||||||
if ({{=$coerced}} === undefined) {
|
|
||||||
{{# def.error:'type' }}
|
|
||||||
} else {
|
|
||||||
{{# def.setParentData }}
|
|
||||||
{{=$data}} = {{=$coerced}};
|
|
||||||
{{? !$dataLvl }}if ({{=$parentData}} !== undefined){{?}}
|
|
||||||
{{=$parentData}}[{{=$parentDataProperty}}] = {{=$coerced}};
|
|
||||||
}
|
|
||||||
#}}
|
|
9
node_modules/ajv/lib/dot/comment.jst
generated
vendored
9
node_modules/ajv/lib/dot/comment.jst
generated
vendored
@@ -1,9 +0,0 @@
|
|||||||
{{# def.definitions }}
|
|
||||||
{{# def.setupKeyword }}
|
|
||||||
|
|
||||||
{{ var $comment = it.util.toQuotedString($schema); }}
|
|
||||||
{{? it.opts.$comment === true }}
|
|
||||||
console.log({{=$comment}});
|
|
||||||
{{?? typeof it.opts.$comment == 'function' }}
|
|
||||||
self._opts.$comment({{=$comment}}, {{=it.util.toQuotedString($errSchemaPath)}}, validate.root.schema);
|
|
||||||
{{?}}
|
|
11
node_modules/ajv/lib/dot/const.jst
generated
vendored
11
node_modules/ajv/lib/dot/const.jst
generated
vendored
@@ -1,11 +0,0 @@
|
|||||||
{{# def.definitions }}
|
|
||||||
{{# def.errors }}
|
|
||||||
{{# def.setupKeyword }}
|
|
||||||
{{# def.$data }}
|
|
||||||
|
|
||||||
{{? !$isData }}
|
|
||||||
var schema{{=$lvl}} = validate.schema{{=$schemaPath}};
|
|
||||||
{{?}}
|
|
||||||
var {{=$valid}} = equal({{=$data}}, schema{{=$lvl}});
|
|
||||||
{{# def.checkError:'const' }}
|
|
||||||
{{? $breakOnError }} else { {{?}}
|
|
57
node_modules/ajv/lib/dot/contains.jst
generated
vendored
57
node_modules/ajv/lib/dot/contains.jst
generated
vendored
@@ -1,57 +0,0 @@
|
|||||||
{{# def.definitions }}
|
|
||||||
{{# def.errors }}
|
|
||||||
{{# def.setupKeyword }}
|
|
||||||
{{# def.setupNextLevel }}
|
|
||||||
|
|
||||||
|
|
||||||
{{
|
|
||||||
var $idx = 'i' + $lvl
|
|
||||||
, $dataNxt = $it.dataLevel = it.dataLevel + 1
|
|
||||||
, $nextData = 'data' + $dataNxt
|
|
||||||
, $currentBaseId = it.baseId
|
|
||||||
, $nonEmptySchema = {{# def.nonEmptySchema:$schema }};
|
|
||||||
}}
|
|
||||||
|
|
||||||
var {{=$errs}} = errors;
|
|
||||||
var {{=$valid}};
|
|
||||||
|
|
||||||
{{? $nonEmptySchema }}
|
|
||||||
{{# def.setCompositeRule }}
|
|
||||||
|
|
||||||
{{
|
|
||||||
$it.schema = $schema;
|
|
||||||
$it.schemaPath = $schemaPath;
|
|
||||||
$it.errSchemaPath = $errSchemaPath;
|
|
||||||
}}
|
|
||||||
|
|
||||||
var {{=$nextValid}} = false;
|
|
||||||
|
|
||||||
for (var {{=$idx}} = 0; {{=$idx}} < {{=$data}}.length; {{=$idx}}++) {
|
|
||||||
{{
|
|
||||||
$it.errorPath = it.util.getPathExpr(it.errorPath, $idx, it.opts.jsonPointers, true);
|
|
||||||
var $passData = $data + '[' + $idx + ']';
|
|
||||||
$it.dataPathArr[$dataNxt] = $idx;
|
|
||||||
}}
|
|
||||||
|
|
||||||
{{# def.generateSubschemaCode }}
|
|
||||||
{{# def.optimizeValidate }}
|
|
||||||
|
|
||||||
if ({{=$nextValid}}) break;
|
|
||||||
}
|
|
||||||
|
|
||||||
{{# def.resetCompositeRule }}
|
|
||||||
{{= $closingBraces }}
|
|
||||||
|
|
||||||
if (!{{=$nextValid}}) {
|
|
||||||
{{??}}
|
|
||||||
if ({{=$data}}.length == 0) {
|
|
||||||
{{?}}
|
|
||||||
|
|
||||||
{{# def.error:'contains' }}
|
|
||||||
} else {
|
|
||||||
{{? $nonEmptySchema }}
|
|
||||||
{{# def.resetErrors }}
|
|
||||||
{{?}}
|
|
||||||
{{? it.opts.allErrors }} } {{?}}
|
|
||||||
|
|
||||||
{{# def.cleanUp }}
|
|
191
node_modules/ajv/lib/dot/custom.jst
generated
vendored
191
node_modules/ajv/lib/dot/custom.jst
generated
vendored
@@ -1,191 +0,0 @@
|
|||||||
{{# def.definitions }}
|
|
||||||
{{# def.errors }}
|
|
||||||
{{# def.setupKeyword }}
|
|
||||||
{{# def.$data }}
|
|
||||||
|
|
||||||
{{
|
|
||||||
var $rule = this
|
|
||||||
, $definition = 'definition' + $lvl
|
|
||||||
, $rDef = $rule.definition
|
|
||||||
, $closingBraces = '';
|
|
||||||
var $validate = $rDef.validate;
|
|
||||||
var $compile, $inline, $macro, $ruleValidate, $validateCode;
|
|
||||||
}}
|
|
||||||
|
|
||||||
{{? $isData && $rDef.$data }}
|
|
||||||
{{
|
|
||||||
$validateCode = 'keywordValidate' + $lvl;
|
|
||||||
var $validateSchema = $rDef.validateSchema;
|
|
||||||
}}
|
|
||||||
var {{=$definition}} = RULES.custom['{{=$keyword}}'].definition;
|
|
||||||
var {{=$validateCode}} = {{=$definition}}.validate;
|
|
||||||
{{??}}
|
|
||||||
{{
|
|
||||||
$ruleValidate = it.useCustomRule($rule, $schema, it.schema, it);
|
|
||||||
if (!$ruleValidate) return;
|
|
||||||
$schemaValue = 'validate.schema' + $schemaPath;
|
|
||||||
$validateCode = $ruleValidate.code;
|
|
||||||
$compile = $rDef.compile;
|
|
||||||
$inline = $rDef.inline;
|
|
||||||
$macro = $rDef.macro;
|
|
||||||
}}
|
|
||||||
{{?}}
|
|
||||||
|
|
||||||
{{
|
|
||||||
var $ruleErrs = $validateCode + '.errors'
|
|
||||||
, $i = 'i' + $lvl
|
|
||||||
, $ruleErr = 'ruleErr' + $lvl
|
|
||||||
, $asyncKeyword = $rDef.async;
|
|
||||||
|
|
||||||
if ($asyncKeyword && !it.async)
|
|
||||||
throw new Error('async keyword in sync schema');
|
|
||||||
}}
|
|
||||||
|
|
||||||
|
|
||||||
{{? !($inline || $macro) }}{{=$ruleErrs}} = null;{{?}}
|
|
||||||
var {{=$errs}} = errors;
|
|
||||||
var {{=$valid}};
|
|
||||||
|
|
||||||
{{## def.callRuleValidate:
|
|
||||||
{{=$validateCode}}.call(
|
|
||||||
{{? it.opts.passContext }}this{{??}}self{{?}}
|
|
||||||
{{? $compile || $rDef.schema === false }}
|
|
||||||
, {{=$data}}
|
|
||||||
{{??}}
|
|
||||||
, {{=$schemaValue}}
|
|
||||||
, {{=$data}}
|
|
||||||
, validate.schema{{=it.schemaPath}}
|
|
||||||
{{?}}
|
|
||||||
, {{# def.dataPath }}
|
|
||||||
{{# def.passParentData }}
|
|
||||||
, rootData
|
|
||||||
)
|
|
||||||
#}}
|
|
||||||
|
|
||||||
{{## def.extendErrors:_inline:
|
|
||||||
for (var {{=$i}}={{=$errs}}; {{=$i}}<errors; {{=$i}}++) {
|
|
||||||
var {{=$ruleErr}} = vErrors[{{=$i}}];
|
|
||||||
if ({{=$ruleErr}}.dataPath === undefined)
|
|
||||||
{{=$ruleErr}}.dataPath = (dataPath || '') + {{= it.errorPath }};
|
|
||||||
{{# _inline ? 'if (\{\{=$ruleErr\}\}.schemaPath === undefined) {' : '' }}
|
|
||||||
{{=$ruleErr}}.schemaPath = "{{=$errSchemaPath}}";
|
|
||||||
{{# _inline ? '}' : '' }}
|
|
||||||
{{? it.opts.verbose }}
|
|
||||||
{{=$ruleErr}}.schema = {{=$schemaValue}};
|
|
||||||
{{=$ruleErr}}.data = {{=$data}};
|
|
||||||
{{?}}
|
|
||||||
}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{? $isData && $rDef.$data }}
|
|
||||||
{{ $closingBraces += '}'; }}
|
|
||||||
if ({{=$schemaValue}} === undefined) {
|
|
||||||
{{=$valid}} = true;
|
|
||||||
} else {
|
|
||||||
{{? $validateSchema }}
|
|
||||||
{{ $closingBraces += '}'; }}
|
|
||||||
{{=$valid}} = {{=$definition}}.validateSchema({{=$schemaValue}});
|
|
||||||
if ({{=$valid}}) {
|
|
||||||
{{?}}
|
|
||||||
{{?}}
|
|
||||||
|
|
||||||
{{? $inline }}
|
|
||||||
{{? $rDef.statements }}
|
|
||||||
{{= $ruleValidate.validate }}
|
|
||||||
{{??}}
|
|
||||||
{{=$valid}} = {{= $ruleValidate.validate }};
|
|
||||||
{{?}}
|
|
||||||
{{?? $macro }}
|
|
||||||
{{# def.setupNextLevel }}
|
|
||||||
{{
|
|
||||||
$it.schema = $ruleValidate.validate;
|
|
||||||
$it.schemaPath = '';
|
|
||||||
}}
|
|
||||||
{{# def.setCompositeRule }}
|
|
||||||
{{ var $code = it.validate($it).replace(/validate\.schema/g, $validateCode); }}
|
|
||||||
{{# def.resetCompositeRule }}
|
|
||||||
{{= $code }}
|
|
||||||
{{??}}
|
|
||||||
{{# def.beginDefOut}}
|
|
||||||
{{# def.callRuleValidate }}
|
|
||||||
{{# def.storeDefOut:def_callRuleValidate }}
|
|
||||||
|
|
||||||
{{? $rDef.errors === false }}
|
|
||||||
{{=$valid}} = {{? $asyncKeyword }}await {{?}}{{= def_callRuleValidate }};
|
|
||||||
{{??}}
|
|
||||||
{{? $asyncKeyword }}
|
|
||||||
{{ $ruleErrs = 'customErrors' + $lvl; }}
|
|
||||||
var {{=$ruleErrs}} = null;
|
|
||||||
try {
|
|
||||||
{{=$valid}} = await {{= def_callRuleValidate }};
|
|
||||||
} catch (e) {
|
|
||||||
{{=$valid}} = false;
|
|
||||||
if (e instanceof ValidationError) {{=$ruleErrs}} = e.errors;
|
|
||||||
else throw e;
|
|
||||||
}
|
|
||||||
{{??}}
|
|
||||||
{{=$ruleErrs}} = null;
|
|
||||||
{{=$valid}} = {{= def_callRuleValidate }};
|
|
||||||
{{?}}
|
|
||||||
{{?}}
|
|
||||||
{{?}}
|
|
||||||
|
|
||||||
{{? $rDef.modifying }}
|
|
||||||
if ({{=$parentData}}) {{=$data}} = {{=$parentData}}[{{=$parentDataProperty}}];
|
|
||||||
{{?}}
|
|
||||||
|
|
||||||
{{= $closingBraces }}
|
|
||||||
|
|
||||||
{{## def.notValidationResult:
|
|
||||||
{{? $rDef.valid === undefined }}
|
|
||||||
!{{? $macro }}{{=$nextValid}}{{??}}{{=$valid}}{{?}}
|
|
||||||
{{??}}
|
|
||||||
{{= !$rDef.valid }}
|
|
||||||
{{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
{{? $rDef.valid }}
|
|
||||||
{{? $breakOnError }} if (true) { {{?}}
|
|
||||||
{{??}}
|
|
||||||
if ({{# def.notValidationResult }}) {
|
|
||||||
{{ $errorKeyword = $rule.keyword; }}
|
|
||||||
{{# def.beginDefOut}}
|
|
||||||
{{# def.error:'custom' }}
|
|
||||||
{{# def.storeDefOut:def_customError }}
|
|
||||||
|
|
||||||
{{? $inline }}
|
|
||||||
{{? $rDef.errors }}
|
|
||||||
{{? $rDef.errors != 'full' }}
|
|
||||||
{{# def.extendErrors:true }}
|
|
||||||
{{?}}
|
|
||||||
{{??}}
|
|
||||||
{{? $rDef.errors === false}}
|
|
||||||
{{= def_customError }}
|
|
||||||
{{??}}
|
|
||||||
if ({{=$errs}} == errors) {
|
|
||||||
{{= def_customError }}
|
|
||||||
} else {
|
|
||||||
{{# def.extendErrors:true }}
|
|
||||||
}
|
|
||||||
{{?}}
|
|
||||||
{{?}}
|
|
||||||
{{?? $macro }}
|
|
||||||
{{# def.extraError:'custom' }}
|
|
||||||
{{??}}
|
|
||||||
{{? $rDef.errors === false}}
|
|
||||||
{{= def_customError }}
|
|
||||||
{{??}}
|
|
||||||
if (Array.isArray({{=$ruleErrs}})) {
|
|
||||||
if (vErrors === null) vErrors = {{=$ruleErrs}};
|
|
||||||
else vErrors = vErrors.concat({{=$ruleErrs}});
|
|
||||||
errors = vErrors.length;
|
|
||||||
{{# def.extendErrors:false }}
|
|
||||||
} else {
|
|
||||||
{{= def_customError }}
|
|
||||||
}
|
|
||||||
{{?}}
|
|
||||||
{{?}}
|
|
||||||
|
|
||||||
} {{? $breakOnError }} else { {{?}}
|
|
||||||
{{?}}
|
|
47
node_modules/ajv/lib/dot/defaults.def
generated
vendored
47
node_modules/ajv/lib/dot/defaults.def
generated
vendored
@@ -1,47 +0,0 @@
|
|||||||
{{## def.assignDefault:
|
|
||||||
{{? it.compositeRule }}
|
|
||||||
{{
|
|
||||||
if (it.opts.strictDefaults) {
|
|
||||||
var $defaultMsg = 'default is ignored for: ' + $passData;
|
|
||||||
if (it.opts.strictDefaults === 'log') it.logger.warn($defaultMsg);
|
|
||||||
else throw new Error($defaultMsg);
|
|
||||||
}
|
|
||||||
}}
|
|
||||||
{{??}}
|
|
||||||
if ({{=$passData}} === undefined
|
|
||||||
{{? it.opts.useDefaults == 'empty' }}
|
|
||||||
|| {{=$passData}} === null
|
|
||||||
|| {{=$passData}} === ''
|
|
||||||
{{?}}
|
|
||||||
)
|
|
||||||
{{=$passData}} = {{? it.opts.useDefaults == 'shared' }}
|
|
||||||
{{= it.useDefault($sch.default) }}
|
|
||||||
{{??}}
|
|
||||||
{{= JSON.stringify($sch.default) }}
|
|
||||||
{{?}};
|
|
||||||
{{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.defaultProperties:
|
|
||||||
{{
|
|
||||||
var $schema = it.schema.properties
|
|
||||||
, $schemaKeys = Object.keys($schema); }}
|
|
||||||
{{~ $schemaKeys:$propertyKey }}
|
|
||||||
{{ var $sch = $schema[$propertyKey]; }}
|
|
||||||
{{? $sch.default !== undefined }}
|
|
||||||
{{ var $passData = $data + it.util.getProperty($propertyKey); }}
|
|
||||||
{{# def.assignDefault }}
|
|
||||||
{{?}}
|
|
||||||
{{~}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.defaultItems:
|
|
||||||
{{~ it.schema.items:$sch:$i }}
|
|
||||||
{{? $sch.default !== undefined }}
|
|
||||||
{{ var $passData = $data + '[' + $i + ']'; }}
|
|
||||||
{{# def.assignDefault }}
|
|
||||||
{{?}}
|
|
||||||
{{~}}
|
|
||||||
#}}
|
|
201
node_modules/ajv/lib/dot/definitions.def
generated
vendored
201
node_modules/ajv/lib/dot/definitions.def
generated
vendored
@@ -1,201 +0,0 @@
|
|||||||
{{## def.setupKeyword:
|
|
||||||
{{
|
|
||||||
var $lvl = it.level;
|
|
||||||
var $dataLvl = it.dataLevel;
|
|
||||||
var $schema = it.schema[$keyword];
|
|
||||||
var $schemaPath = it.schemaPath + it.util.getProperty($keyword);
|
|
||||||
var $errSchemaPath = it.errSchemaPath + '/' + $keyword;
|
|
||||||
var $breakOnError = !it.opts.allErrors;
|
|
||||||
var $errorKeyword;
|
|
||||||
|
|
||||||
var $data = 'data' + ($dataLvl || '');
|
|
||||||
var $valid = 'valid' + $lvl;
|
|
||||||
var $errs = 'errs__' + $lvl;
|
|
||||||
}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.setCompositeRule:
|
|
||||||
{{
|
|
||||||
var $wasComposite = it.compositeRule;
|
|
||||||
it.compositeRule = $it.compositeRule = true;
|
|
||||||
}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.resetCompositeRule:
|
|
||||||
{{ it.compositeRule = $it.compositeRule = $wasComposite; }}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.setupNextLevel:
|
|
||||||
{{
|
|
||||||
var $it = it.util.copy(it);
|
|
||||||
var $closingBraces = '';
|
|
||||||
$it.level++;
|
|
||||||
var $nextValid = 'valid' + $it.level;
|
|
||||||
}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.ifValid:
|
|
||||||
{{? $breakOnError }}
|
|
||||||
if ({{=$valid}}) {
|
|
||||||
{{ $closingBraces += '}'; }}
|
|
||||||
{{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.ifResultValid:
|
|
||||||
{{? $breakOnError }}
|
|
||||||
if ({{=$nextValid}}) {
|
|
||||||
{{ $closingBraces += '}'; }}
|
|
||||||
{{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.elseIfValid:
|
|
||||||
{{? $breakOnError }}
|
|
||||||
{{ $closingBraces += '}'; }}
|
|
||||||
else {
|
|
||||||
{{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.nonEmptySchema:_schema:
|
|
||||||
(it.opts.strictKeywords
|
|
||||||
? typeof _schema == 'object' && Object.keys(_schema).length > 0
|
|
||||||
: it.util.schemaHasRules(_schema, it.RULES.all))
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.strLength:
|
|
||||||
{{? it.opts.unicode === false }}
|
|
||||||
{{=$data}}.length
|
|
||||||
{{??}}
|
|
||||||
ucs2length({{=$data}})
|
|
||||||
{{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.willOptimize:
|
|
||||||
it.util.varOccurences($code, $nextData) < 2
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.generateSubschemaCode:
|
|
||||||
{{
|
|
||||||
var $code = it.validate($it);
|
|
||||||
$it.baseId = $currentBaseId;
|
|
||||||
}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.insertSubschemaCode:
|
|
||||||
{{= it.validate($it) }}
|
|
||||||
{{ $it.baseId = $currentBaseId; }}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def._optimizeValidate:
|
|
||||||
it.util.varReplace($code, $nextData, $passData)
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.optimizeValidate:
|
|
||||||
{{? {{# def.willOptimize}} }}
|
|
||||||
{{= {{# def._optimizeValidate }} }}
|
|
||||||
{{??}}
|
|
||||||
var {{=$nextData}} = {{=$passData}};
|
|
||||||
{{= $code }}
|
|
||||||
{{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.cleanUp: {{ out = it.util.cleanUpCode(out); }} #}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.finalCleanUp: {{ out = it.util.finalCleanUpCode(out, $async); }} #}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.$data:
|
|
||||||
{{
|
|
||||||
var $isData = it.opts.$data && $schema && $schema.$data
|
|
||||||
, $schemaValue;
|
|
||||||
}}
|
|
||||||
{{? $isData }}
|
|
||||||
var schema{{=$lvl}} = {{= it.util.getData($schema.$data, $dataLvl, it.dataPathArr) }};
|
|
||||||
{{ $schemaValue = 'schema' + $lvl; }}
|
|
||||||
{{??}}
|
|
||||||
{{ $schemaValue = $schema; }}
|
|
||||||
{{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.$dataNotType:_type:
|
|
||||||
{{?$isData}} ({{=$schemaValue}} !== undefined && typeof {{=$schemaValue}} != _type) || {{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.check$dataIsArray:
|
|
||||||
if (schema{{=$lvl}} === undefined) {{=$valid}} = true;
|
|
||||||
else if (!Array.isArray(schema{{=$lvl}})) {{=$valid}} = false;
|
|
||||||
else {
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.beginDefOut:
|
|
||||||
{{
|
|
||||||
var $$outStack = $$outStack || [];
|
|
||||||
$$outStack.push(out);
|
|
||||||
out = '';
|
|
||||||
}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.storeDefOut:_variable:
|
|
||||||
{{
|
|
||||||
var _variable = out;
|
|
||||||
out = $$outStack.pop();
|
|
||||||
}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.dataPath:(dataPath || ''){{? it.errorPath != '""'}} + {{= it.errorPath }}{{?}}#}}
|
|
||||||
|
|
||||||
{{## def.setParentData:
|
|
||||||
{{
|
|
||||||
var $parentData = $dataLvl ? 'data' + (($dataLvl-1)||'') : 'parentData'
|
|
||||||
, $parentDataProperty = $dataLvl ? it.dataPathArr[$dataLvl] : 'parentDataProperty';
|
|
||||||
}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
{{## def.passParentData:
|
|
||||||
{{# def.setParentData }}
|
|
||||||
, {{= $parentData }}
|
|
||||||
, {{= $parentDataProperty }}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.iterateProperties:
|
|
||||||
{{? $ownProperties }}
|
|
||||||
{{=$dataProperties}} = {{=$dataProperties}} || Object.keys({{=$data}});
|
|
||||||
for (var {{=$idx}}=0; {{=$idx}}<{{=$dataProperties}}.length; {{=$idx}}++) {
|
|
||||||
var {{=$key}} = {{=$dataProperties}}[{{=$idx}}];
|
|
||||||
{{??}}
|
|
||||||
for (var {{=$key}} in {{=$data}}) {
|
|
||||||
{{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.noPropertyInData:
|
|
||||||
{{=$useData}} === undefined
|
|
||||||
{{? $ownProperties }}
|
|
||||||
|| !{{# def.isOwnProperty }}
|
|
||||||
{{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.isOwnProperty:
|
|
||||||
Object.prototype.hasOwnProperty.call({{=$data}}, '{{=it.util.escapeQuotes($propertyKey)}}')
|
|
||||||
#}}
|
|
80
node_modules/ajv/lib/dot/dependencies.jst
generated
vendored
80
node_modules/ajv/lib/dot/dependencies.jst
generated
vendored
@@ -1,80 +0,0 @@
|
|||||||
{{# def.definitions }}
|
|
||||||
{{# def.errors }}
|
|
||||||
{{# def.missing }}
|
|
||||||
{{# def.setupKeyword }}
|
|
||||||
{{# def.setupNextLevel }}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.propertyInData:
|
|
||||||
{{=$data}}{{= it.util.getProperty($property) }} !== undefined
|
|
||||||
{{? $ownProperties }}
|
|
||||||
&& Object.prototype.hasOwnProperty.call({{=$data}}, '{{=it.util.escapeQuotes($property)}}')
|
|
||||||
{{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{
|
|
||||||
var $schemaDeps = {}
|
|
||||||
, $propertyDeps = {}
|
|
||||||
, $ownProperties = it.opts.ownProperties;
|
|
||||||
|
|
||||||
for ($property in $schema) {
|
|
||||||
var $sch = $schema[$property];
|
|
||||||
var $deps = Array.isArray($sch) ? $propertyDeps : $schemaDeps;
|
|
||||||
$deps[$property] = $sch;
|
|
||||||
}
|
|
||||||
}}
|
|
||||||
|
|
||||||
var {{=$errs}} = errors;
|
|
||||||
|
|
||||||
{{ var $currentErrorPath = it.errorPath; }}
|
|
||||||
|
|
||||||
var missing{{=$lvl}};
|
|
||||||
{{ for (var $property in $propertyDeps) { }}
|
|
||||||
{{ $deps = $propertyDeps[$property]; }}
|
|
||||||
{{? $deps.length }}
|
|
||||||
if ({{# def.propertyInData }}
|
|
||||||
{{? $breakOnError }}
|
|
||||||
&& ({{# def.checkMissingProperty:$deps }})) {
|
|
||||||
{{# def.errorMissingProperty:'dependencies' }}
|
|
||||||
{{??}}
|
|
||||||
) {
|
|
||||||
{{~ $deps:$propertyKey }}
|
|
||||||
{{# def.allErrorsMissingProperty:'dependencies' }}
|
|
||||||
{{~}}
|
|
||||||
{{?}}
|
|
||||||
} {{# def.elseIfValid }}
|
|
||||||
{{?}}
|
|
||||||
{{ } }}
|
|
||||||
|
|
||||||
{{
|
|
||||||
it.errorPath = $currentErrorPath;
|
|
||||||
var $currentBaseId = $it.baseId;
|
|
||||||
}}
|
|
||||||
|
|
||||||
|
|
||||||
{{ for (var $property in $schemaDeps) { }}
|
|
||||||
{{ var $sch = $schemaDeps[$property]; }}
|
|
||||||
{{? {{# def.nonEmptySchema:$sch }} }}
|
|
||||||
{{=$nextValid}} = true;
|
|
||||||
|
|
||||||
if ({{# def.propertyInData }}) {
|
|
||||||
{{
|
|
||||||
$it.schema = $sch;
|
|
||||||
$it.schemaPath = $schemaPath + it.util.getProperty($property);
|
|
||||||
$it.errSchemaPath = $errSchemaPath + '/' + it.util.escapeFragment($property);
|
|
||||||
}}
|
|
||||||
|
|
||||||
{{# def.insertSubschemaCode }}
|
|
||||||
}
|
|
||||||
|
|
||||||
{{# def.ifResultValid }}
|
|
||||||
{{?}}
|
|
||||||
{{ } }}
|
|
||||||
|
|
||||||
{{? $breakOnError }}
|
|
||||||
{{= $closingBraces }}
|
|
||||||
if ({{=$errs}} == errors) {
|
|
||||||
{{?}}
|
|
||||||
|
|
||||||
{{# def.cleanUp }}
|
|
30
node_modules/ajv/lib/dot/enum.jst
generated
vendored
30
node_modules/ajv/lib/dot/enum.jst
generated
vendored
@@ -1,30 +0,0 @@
|
|||||||
{{# def.definitions }}
|
|
||||||
{{# def.errors }}
|
|
||||||
{{# def.setupKeyword }}
|
|
||||||
{{# def.$data }}
|
|
||||||
|
|
||||||
{{
|
|
||||||
var $i = 'i' + $lvl
|
|
||||||
, $vSchema = 'schema' + $lvl;
|
|
||||||
}}
|
|
||||||
|
|
||||||
{{? !$isData }}
|
|
||||||
var {{=$vSchema}} = validate.schema{{=$schemaPath}};
|
|
||||||
{{?}}
|
|
||||||
var {{=$valid}};
|
|
||||||
|
|
||||||
{{?$isData}}{{# def.check$dataIsArray }}{{?}}
|
|
||||||
|
|
||||||
{{=$valid}} = false;
|
|
||||||
|
|
||||||
for (var {{=$i}}=0; {{=$i}}<{{=$vSchema}}.length; {{=$i}}++)
|
|
||||||
if (equal({{=$data}}, {{=$vSchema}}[{{=$i}}])) {
|
|
||||||
{{=$valid}} = true;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
{{? $isData }} } {{?}}
|
|
||||||
|
|
||||||
{{# def.checkError:'enum' }}
|
|
||||||
|
|
||||||
{{? $breakOnError }} else { {{?}}
|
|
194
node_modules/ajv/lib/dot/errors.def
generated
vendored
194
node_modules/ajv/lib/dot/errors.def
generated
vendored
@@ -1,194 +0,0 @@
|
|||||||
{{# def.definitions }}
|
|
||||||
|
|
||||||
{{## def._error:_rule:
|
|
||||||
{{ 'istanbul ignore else'; }}
|
|
||||||
{{? it.createErrors !== false }}
|
|
||||||
{
|
|
||||||
keyword: '{{= $errorKeyword || _rule }}'
|
|
||||||
, dataPath: (dataPath || '') + {{= it.errorPath }}
|
|
||||||
, schemaPath: {{=it.util.toQuotedString($errSchemaPath)}}
|
|
||||||
, params: {{# def._errorParams[_rule] }}
|
|
||||||
{{? it.opts.messages !== false }}
|
|
||||||
, message: {{# def._errorMessages[_rule] }}
|
|
||||||
{{?}}
|
|
||||||
{{? it.opts.verbose }}
|
|
||||||
, schema: {{# def._errorSchemas[_rule] }}
|
|
||||||
, parentSchema: validate.schema{{=it.schemaPath}}
|
|
||||||
, data: {{=$data}}
|
|
||||||
{{?}}
|
|
||||||
}
|
|
||||||
{{??}}
|
|
||||||
{}
|
|
||||||
{{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def._addError:_rule:
|
|
||||||
if (vErrors === null) vErrors = [err];
|
|
||||||
else vErrors.push(err);
|
|
||||||
errors++;
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.addError:_rule:
|
|
||||||
var err = {{# def._error:_rule }};
|
|
||||||
{{# def._addError:_rule }}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.error:_rule:
|
|
||||||
{{# def.beginDefOut}}
|
|
||||||
{{# def._error:_rule }}
|
|
||||||
{{# def.storeDefOut:__err }}
|
|
||||||
|
|
||||||
{{? !it.compositeRule && $breakOnError }}
|
|
||||||
{{ 'istanbul ignore if'; }}
|
|
||||||
{{? it.async }}
|
|
||||||
throw new ValidationError([{{=__err}}]);
|
|
||||||
{{??}}
|
|
||||||
validate.errors = [{{=__err}}];
|
|
||||||
return false;
|
|
||||||
{{?}}
|
|
||||||
{{??}}
|
|
||||||
var err = {{=__err}};
|
|
||||||
{{# def._addError:_rule }}
|
|
||||||
{{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.extraError:_rule:
|
|
||||||
{{# def.addError:_rule}}
|
|
||||||
{{? !it.compositeRule && $breakOnError }}
|
|
||||||
{{ 'istanbul ignore if'; }}
|
|
||||||
{{? it.async }}
|
|
||||||
throw new ValidationError(vErrors);
|
|
||||||
{{??}}
|
|
||||||
validate.errors = vErrors;
|
|
||||||
return false;
|
|
||||||
{{?}}
|
|
||||||
{{?}}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.checkError:_rule:
|
|
||||||
if (!{{=$valid}}) {
|
|
||||||
{{# def.error:_rule }}
|
|
||||||
}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.resetErrors:
|
|
||||||
errors = {{=$errs}};
|
|
||||||
if (vErrors !== null) {
|
|
||||||
if ({{=$errs}}) vErrors.length = {{=$errs}};
|
|
||||||
else vErrors = null;
|
|
||||||
}
|
|
||||||
#}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.concatSchema:{{?$isData}}' + {{=$schemaValue}} + '{{??}}{{=$schema}}{{?}}#}}
|
|
||||||
{{## def.appendSchema:{{?$isData}}' + {{=$schemaValue}}{{??}}{{=$schemaValue}}'{{?}}#}}
|
|
||||||
{{## def.concatSchemaEQ:{{?$isData}}' + {{=$schemaValue}} + '{{??}}{{=it.util.escapeQuotes($schema)}}{{?}}#}}
|
|
||||||
|
|
||||||
{{## def._errorMessages = {
|
|
||||||
'false schema': "'boolean schema is false'",
|
|
||||||
$ref: "'can\\\'t resolve reference {{=it.util.escapeQuotes($schema)}}'",
|
|
||||||
additionalItems: "'should NOT have more than {{=$schema.length}} items'",
|
|
||||||
additionalProperties: "'{{? it.opts._errorDataPathProperty }}is an invalid additional property{{??}}should NOT have additional properties{{?}}'",
|
|
||||||
anyOf: "'should match some schema in anyOf'",
|
|
||||||
const: "'should be equal to constant'",
|
|
||||||
contains: "'should contain a valid item'",
|
|
||||||
dependencies: "'should have {{? $deps.length == 1 }}property {{= it.util.escapeQuotes($deps[0]) }}{{??}}properties {{= it.util.escapeQuotes($deps.join(\", \")) }}{{?}} when property {{= it.util.escapeQuotes($property) }} is present'",
|
|
||||||
'enum': "'should be equal to one of the allowed values'",
|
|
||||||
format: "'should match format \"{{#def.concatSchemaEQ}}\"'",
|
|
||||||
'if': "'should match \"' + {{=$ifClause}} + '\" schema'",
|
|
||||||
_limit: "'should be {{=$opStr}} {{#def.appendSchema}}",
|
|
||||||
_exclusiveLimit: "'{{=$exclusiveKeyword}} should be boolean'",
|
|
||||||
_limitItems: "'should NOT have {{?$keyword=='maxItems'}}more{{??}}fewer{{?}} than {{#def.concatSchema}} items'",
|
|
||||||
_limitLength: "'should NOT be {{?$keyword=='maxLength'}}longer{{??}}shorter{{?}} than {{#def.concatSchema}} characters'",
|
|
||||||
_limitProperties:"'should NOT have {{?$keyword=='maxProperties'}}more{{??}}fewer{{?}} than {{#def.concatSchema}} properties'",
|
|
||||||
multipleOf: "'should be multiple of {{#def.appendSchema}}",
|
|
||||||
not: "'should NOT be valid'",
|
|
||||||
oneOf: "'should match exactly one schema in oneOf'",
|
|
||||||
pattern: "'should match pattern \"{{#def.concatSchemaEQ}}\"'",
|
|
||||||
propertyNames: "'property name \\'{{=$invalidName}}\\' is invalid'",
|
|
||||||
required: "'{{? it.opts._errorDataPathProperty }}is a required property{{??}}should have required property \\'{{=$missingProperty}}\\'{{?}}'",
|
|
||||||
type: "'should be {{? $typeIsArray }}{{= $typeSchema.join(\",\") }}{{??}}{{=$typeSchema}}{{?}}'",
|
|
||||||
uniqueItems: "'should NOT have duplicate items (items ## ' + j + ' and ' + i + ' are identical)'",
|
|
||||||
custom: "'should pass \"{{=$rule.keyword}}\" keyword validation'",
|
|
||||||
patternRequired: "'should have property matching pattern \\'{{=$missingPattern}}\\''",
|
|
||||||
switch: "'should pass \"switch\" keyword validation'",
|
|
||||||
_formatLimit: "'should be {{=$opStr}} \"{{#def.concatSchemaEQ}}\"'",
|
|
||||||
_formatExclusiveLimit: "'{{=$exclusiveKeyword}} should be boolean'"
|
|
||||||
} #}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.schemaRefOrVal: {{?$isData}}validate.schema{{=$schemaPath}}{{??}}{{=$schema}}{{?}} #}}
|
|
||||||
{{## def.schemaRefOrQS: {{?$isData}}validate.schema{{=$schemaPath}}{{??}}{{=it.util.toQuotedString($schema)}}{{?}} #}}
|
|
||||||
|
|
||||||
{{## def._errorSchemas = {
|
|
||||||
'false schema': "false",
|
|
||||||
$ref: "{{=it.util.toQuotedString($schema)}}",
|
|
||||||
additionalItems: "false",
|
|
||||||
additionalProperties: "false",
|
|
||||||
anyOf: "validate.schema{{=$schemaPath}}",
|
|
||||||
const: "validate.schema{{=$schemaPath}}",
|
|
||||||
contains: "validate.schema{{=$schemaPath}}",
|
|
||||||
dependencies: "validate.schema{{=$schemaPath}}",
|
|
||||||
'enum': "validate.schema{{=$schemaPath}}",
|
|
||||||
format: "{{#def.schemaRefOrQS}}",
|
|
||||||
'if': "validate.schema{{=$schemaPath}}",
|
|
||||||
_limit: "{{#def.schemaRefOrVal}}",
|
|
||||||
_exclusiveLimit: "validate.schema{{=$schemaPath}}",
|
|
||||||
_limitItems: "{{#def.schemaRefOrVal}}",
|
|
||||||
_limitLength: "{{#def.schemaRefOrVal}}",
|
|
||||||
_limitProperties:"{{#def.schemaRefOrVal}}",
|
|
||||||
multipleOf: "{{#def.schemaRefOrVal}}",
|
|
||||||
not: "validate.schema{{=$schemaPath}}",
|
|
||||||
oneOf: "validate.schema{{=$schemaPath}}",
|
|
||||||
pattern: "{{#def.schemaRefOrQS}}",
|
|
||||||
propertyNames: "validate.schema{{=$schemaPath}}",
|
|
||||||
required: "validate.schema{{=$schemaPath}}",
|
|
||||||
type: "validate.schema{{=$schemaPath}}",
|
|
||||||
uniqueItems: "{{#def.schemaRefOrVal}}",
|
|
||||||
custom: "validate.schema{{=$schemaPath}}",
|
|
||||||
patternRequired: "validate.schema{{=$schemaPath}}",
|
|
||||||
switch: "validate.schema{{=$schemaPath}}",
|
|
||||||
_formatLimit: "{{#def.schemaRefOrQS}}",
|
|
||||||
_formatExclusiveLimit: "validate.schema{{=$schemaPath}}"
|
|
||||||
} #}}
|
|
||||||
|
|
||||||
|
|
||||||
{{## def.schemaValueQS: {{?$isData}}{{=$schemaValue}}{{??}}{{=it.util.toQuotedString($schema)}}{{?}} #}}
|
|
||||||
|
|
||||||
{{## def._errorParams = {
|
|
||||||
'false schema': "{}",
|
|
||||||
$ref: "{ ref: '{{=it.util.escapeQuotes($schema)}}' }",
|
|
||||||
additionalItems: "{ limit: {{=$schema.length}} }",
|
|
||||||
additionalProperties: "{ additionalProperty: '{{=$additionalProperty}}' }",
|
|
||||||
anyOf: "{}",
|
|
||||||
const: "{ allowedValue: schema{{=$lvl}} }",
|
|
||||||
contains: "{}",
|
|
||||||
dependencies: "{ property: '{{= it.util.escapeQuotes($property) }}', missingProperty: '{{=$missingProperty}}', depsCount: {{=$deps.length}}, deps: '{{= it.util.escapeQuotes($deps.length==1 ? $deps[0] : $deps.join(\", \")) }}' }",
|
|
||||||
'enum': "{ allowedValues: schema{{=$lvl}} }",
|
|
||||||
format: "{ format: {{#def.schemaValueQS}} }",
|
|
||||||
'if': "{ failingKeyword: {{=$ifClause}} }",
|
|
||||||
_limit: "{ comparison: {{=$opExpr}}, limit: {{=$schemaValue}}, exclusive: {{=$exclusive}} }",
|
|
||||||
_exclusiveLimit: "{}",
|
|
||||||
_limitItems: "{ limit: {{=$schemaValue}} }",
|
|
||||||
_limitLength: "{ limit: {{=$schemaValue}} }",
|
|
||||||
_limitProperties:"{ limit: {{=$schemaValue}} }",
|
|
||||||
multipleOf: "{ multipleOf: {{=$schemaValue}} }",
|
|
||||||
not: "{}",
|
|
||||||
oneOf: "{ passingSchemas: {{=$passingSchemas}} }",
|
|
||||||
pattern: "{ pattern: {{#def.schemaValueQS}} }",
|
|
||||||
propertyNames: "{ propertyName: '{{=$invalidName}}' }",
|
|
||||||
required: "{ missingProperty: '{{=$missingProperty}}' }",
|
|
||||||
type: "{ type: '{{? $typeIsArray }}{{= $typeSchema.join(\",\") }}{{??}}{{=$typeSchema}}{{?}}' }",
|
|
||||||
uniqueItems: "{ i: i, j: j }",
|
|
||||||
custom: "{ keyword: '{{=$rule.keyword}}' }",
|
|
||||||
patternRequired: "{ missingPattern: '{{=$missingPattern}}' }",
|
|
||||||
switch: "{ caseIndex: {{=$caseIndex}} }",
|
|
||||||
_formatLimit: "{ comparison: {{=$opExpr}}, limit: {{#def.schemaValueQS}}, exclusive: {{=$exclusive}} }",
|
|
||||||
_formatExclusiveLimit: "{}"
|
|
||||||
} #}}
|
|
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user