mirror of
https://github.com/github/codeql-action.git
synced 2026-01-06 22:50:17 +08:00
Compare commits
49 Commits
codeql-bun
...
v1.1.13
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
614d63af76 | ||
|
|
c053e94e7d | ||
|
|
e47f040350 | ||
|
|
4d013d7594 | ||
|
|
3b2cf8914c | ||
|
|
9d650fdc1f | ||
|
|
a6611b8691 | ||
|
|
6efabfeaef | ||
|
|
24d91cb4e9 | ||
|
|
b6b48ceae3 | ||
|
|
af390c0075 | ||
|
|
4c3af19a40 | ||
|
|
0e9acb6e5c | ||
|
|
459cf02690 | ||
|
|
acc7a4bc97 | ||
|
|
d25b8aca1b | ||
|
|
c6fc792e04 | ||
|
|
d28ac7880b | ||
|
|
5e59d8eec4 | ||
|
|
ec7fba1280 | ||
|
|
46d6a93dcc | ||
|
|
ab69202a0b | ||
|
|
93c20939ac | ||
|
|
c1672e532f | ||
|
|
6c3ae45f3a | ||
|
|
8371fda073 | ||
|
|
e3983ef751 | ||
|
|
e34f3ea243 | ||
|
|
d9937ad6ad | ||
|
|
f703d1ca07 | ||
|
|
acf17f7547 | ||
|
|
e2cc7cc006 | ||
|
|
c7b049b347 | ||
|
|
f679ec9aa9 | ||
|
|
d9f89b3dfd | ||
|
|
0ab00f44cb | ||
|
|
026ff35db0 | ||
|
|
1fc1008278 | ||
|
|
7eac76fcb4 | ||
|
|
3d10ffe493 | ||
|
|
f5e5590fc8 | ||
|
|
380041ed00 | ||
|
|
8165d30832 | ||
|
|
4c1021c504 | ||
|
|
9da34a6ec6 | ||
|
|
f83be76fd8 | ||
|
|
b45efc9e42 | ||
|
|
75743c96fc | ||
|
|
03a275bc11 |
2
.github/query-filter-test/action.yml
vendored
2
.github/query-filter-test/action.yml
vendored
@@ -1,5 +1,5 @@
|
|||||||
name: Query Filter Test
|
name: Query Filter Test
|
||||||
description: Runs a test of query filters using the check sarif action
|
description: Runs a test of query filters using the check SARIF action
|
||||||
inputs:
|
inputs:
|
||||||
sarif-file:
|
sarif-file:
|
||||||
required: true
|
required: true
|
||||||
|
|||||||
2
.github/workflows/check-for-conflicts.yml
vendored
2
.github/workflows/check-for-conflicts.yml
vendored
@@ -4,7 +4,7 @@ name: Check for conflicts
|
|||||||
|
|
||||||
on:
|
on:
|
||||||
pull_request:
|
pull_request:
|
||||||
branches: [main, releases/v1, releases/v2]
|
branches: [main, v1, v2]
|
||||||
# Run checks on reopened draft PRs to support triggering PR checks on draft PRs that were opened
|
# Run checks on reopened draft PRs to support triggering PR checks on draft PRs that were opened
|
||||||
# by other workflows.
|
# by other workflows.
|
||||||
types: [opened, synchronize, reopened, ready_for_review]
|
types: [opened, synchronize, reopened, ready_for_review]
|
||||||
|
|||||||
4
.github/workflows/expected-queries-runs.yml
vendored
4
.github/workflows/expected-queries-runs.yml
vendored
@@ -1,6 +1,4 @@
|
|||||||
name: Expected queries runs
|
name: Check queries that ran
|
||||||
env:
|
|
||||||
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }}
|
|
||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
|
|||||||
10
.github/workflows/pr-checks.yml
vendored
10
.github/workflows/pr-checks.yml
vendored
@@ -90,18 +90,14 @@ jobs:
|
|||||||
needs: [check-js, check-node-modules]
|
needs: [check-js, check-node-modules]
|
||||||
strategy:
|
strategy:
|
||||||
matrix:
|
matrix:
|
||||||
os: [ubuntu-latest, macos-latest, windows-latest]
|
os: [ubuntu-latest, macos-latest]
|
||||||
runs-on: ${{ matrix.os }}
|
runs-on: ${{ matrix.os }}
|
||||||
timeout-minutes: 45
|
timeout-minutes: 45
|
||||||
|
|
||||||
steps:
|
steps:
|
||||||
- uses: actions/checkout@v3
|
- uses: actions/checkout@v3
|
||||||
- name: npm test
|
- name: npm run-script test
|
||||||
run: |
|
run: npm run-script test
|
||||||
# Run any commands referenced in package.json using Bash, otherwise
|
|
||||||
# we won't be able to find them on Windows.
|
|
||||||
npm config set script-shell bash
|
|
||||||
npm test
|
|
||||||
|
|
||||||
runner-analyze-javascript-ubuntu:
|
runner-analyze-javascript-ubuntu:
|
||||||
name: Runner ubuntu JS analyze
|
name: Runner ubuntu JS analyze
|
||||||
|
|||||||
9
.github/workflows/python-deps.yml
vendored
9
.github/workflows/python-deps.yml
vendored
@@ -18,11 +18,6 @@ jobs:
|
|||||||
os: [ubuntu-latest, macos-latest]
|
os: [ubuntu-latest, macos-latest]
|
||||||
python_deps_type: [pipenv, poetry, requirements, setup_py]
|
python_deps_type: [pipenv, poetry, requirements, setup_py]
|
||||||
python_version: [2, 3]
|
python_version: [2, 3]
|
||||||
exclude:
|
|
||||||
# Python2 and poetry are not supported. See https://github.com/actions/setup-python/issues/374
|
|
||||||
- python_version: 2
|
|
||||||
python_deps_type: poetry
|
|
||||||
|
|
||||||
|
|
||||||
env:
|
env:
|
||||||
PYTHON_DEPS_TYPE: ${{ matrix.python_deps_type }}
|
PYTHON_DEPS_TYPE: ${{ matrix.python_deps_type }}
|
||||||
@@ -120,10 +115,6 @@ jobs:
|
|||||||
matrix:
|
matrix:
|
||||||
python_deps_type: [pipenv, poetry, requirements, setup_py]
|
python_deps_type: [pipenv, poetry, requirements, setup_py]
|
||||||
python_version: [2, 3]
|
python_version: [2, 3]
|
||||||
exclude:
|
|
||||||
# Python2 and poetry are not supported. See https://github.com/actions/setup-python/issues/374
|
|
||||||
- python_version: 2
|
|
||||||
python_deps_type: poetry
|
|
||||||
|
|
||||||
env:
|
env:
|
||||||
PYTHON_DEPS_TYPE: ${{ matrix.python_deps_type }}
|
PYTHON_DEPS_TYPE: ${{ matrix.python_deps_type }}
|
||||||
|
|||||||
56
.github/workflows/query-filters.yml
vendored
Normal file
56
.github/workflows/query-filters.yml
vendored
Normal file
@@ -0,0 +1,56 @@
|
|||||||
|
name: Query filters tests
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches:
|
||||||
|
- main
|
||||||
|
- releases/v1
|
||||||
|
- releases/v2
|
||||||
|
pull_request:
|
||||||
|
types:
|
||||||
|
- opened
|
||||||
|
- synchronize
|
||||||
|
- reopened
|
||||||
|
- ready_for_review
|
||||||
|
workflow_dispatch: {}
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
query-filters:
|
||||||
|
name: Query Filters Tests
|
||||||
|
timeout-minutes: 45
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- name: Check out repository
|
||||||
|
uses: actions/checkout@v3
|
||||||
|
- name: Prepare test
|
||||||
|
id: prepare-test
|
||||||
|
uses: ./.github/prepare-test
|
||||||
|
with:
|
||||||
|
version: latest
|
||||||
|
|
||||||
|
- name: Check SARIF for default queries with Single include, Single exclude
|
||||||
|
uses: ./../action/.github/query-filter-test
|
||||||
|
with:
|
||||||
|
sarif-file: ${{ runner.temp }}/results/javascript.sarif
|
||||||
|
queries-run: js/zipslip
|
||||||
|
queries-not-run: js/path-injection
|
||||||
|
config-file: ./.github/codeql/codeql-config-query-filters1.yml
|
||||||
|
tools: ${{ steps.prepare-test.outputs.tools-url }}
|
||||||
|
|
||||||
|
- name: Check SARIF for query packs with Single include, Single exclude
|
||||||
|
uses: ./../action/.github/query-filter-test
|
||||||
|
with:
|
||||||
|
sarif-file: ${{ runner.temp }}/results/javascript.sarif
|
||||||
|
queries-run: js/zipslip,javascript/example/empty-or-one-block
|
||||||
|
queries-not-run: js/path-injection
|
||||||
|
config-file: ./.github/codeql/codeql-config-query-filters2.yml
|
||||||
|
tools: ${{ steps.prepare-test.outputs.tools-url }}
|
||||||
|
|
||||||
|
- name: Check SARIF for query packs and local queries with Single include, Single exclude
|
||||||
|
uses: ./../action/.github/query-filter-test
|
||||||
|
with:
|
||||||
|
sarif-file: ${{ runner.temp }}/results/javascript.sarif
|
||||||
|
queries-run: js/zipslip,javascript/example/empty-or-one-block,inrepo-javascript-querypack/show-ifs
|
||||||
|
queries-not-run: js/path-injection,complex-python-querypack/show-ifs,complex-python-querypack/foo/bar/show-ifs
|
||||||
|
config-file: ./.github/codeql/codeql-config-query-filters3.yml
|
||||||
|
tools: ${{ steps.prepare-test.outputs.tools-url }}
|
||||||
4
.github/workflows/script/check-js.sh
vendored
4
.github/workflows/script/check-js.sh
vendored
@@ -14,8 +14,8 @@ npm run-script build
|
|||||||
# Check that repo is still clean
|
# Check that repo is still clean
|
||||||
if [ ! -z "$(git status --porcelain)" ]; then
|
if [ ! -z "$(git status --porcelain)" ]; then
|
||||||
# If we get a fail here then the PR needs attention
|
# If we get a fail here then the PR needs attention
|
||||||
>&2 echo "Failed: JavaScript files are not up to date. Run 'rm -rf lib && npm run-script build' to update"
|
>&2 echo "Failed: JavaScript files are not up to date. Run 'npm run-script build' to update"
|
||||||
git status
|
git status
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
echo "Success: JavaScript files are up to date"
|
echo "Success: JavaScript files are up to date"
|
||||||
@@ -2,19 +2,17 @@
|
|||||||
# Update the required checks based on the current branch.
|
# Update the required checks based on the current branch.
|
||||||
# Typically, this will be main.
|
# Typically, this will be main.
|
||||||
|
|
||||||
if ! gh auth status 2>/dev/null; then
|
if [ -z "$GITHUB_TOKEN" ]; then
|
||||||
gh auth status
|
echo "Failed: No GitHub token found. This script requires admin access to `github/codeql-action`."
|
||||||
echo "Failed: Not authorized. This script requires admin access to github/codeql-action through the gh CLI."
|
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$#" -eq 1 ]; then
|
if [ "$#" -eq 1 ]; then
|
||||||
# If we were passed an argument, use that as the SHA
|
# If we were passed an argument, pass it as a query to fzf
|
||||||
GITHUB_SHA="$0"
|
GITHUB_SHA="$@"
|
||||||
elif [ "$#" -gt 1 ]; then
|
elif [ "$#" -gt 1 ]; then
|
||||||
echo "Usage: $0 [SHA]"
|
echo "Usage: $0 [SHA]"
|
||||||
echo "Update the required checks based on the SHA, or main."
|
echo "Update the required checks based on the SHA, or main."
|
||||||
exit 1
|
|
||||||
elif [ -z "$GITHUB_SHA" ]; then
|
elif [ -z "$GITHUB_SHA" ]; then
|
||||||
# If we don't have a SHA, use main
|
# If we don't have a SHA, use main
|
||||||
GITHUB_SHA="$(git rev-parse main)"
|
GITHUB_SHA="$(git rev-parse main)"
|
||||||
@@ -23,7 +21,7 @@ fi
|
|||||||
echo "Getting checks for $GITHUB_SHA"
|
echo "Getting checks for $GITHUB_SHA"
|
||||||
|
|
||||||
# Ignore any checks with "https://", CodeQL, LGTM, and Update checks.
|
# Ignore any checks with "https://", CodeQL, LGTM, and Update checks.
|
||||||
CHECKS="$(gh api repos/github/codeql-action/commits/"${GITHUB_SHA}"/check-runs --paginate | jq --slurp --compact-output --raw-output '[.[].check_runs | .[].name | select(contains("https://") or . == "CodeQL" or . == "LGTM.com" or contains("Update") or contains("update") | not)] | unique | sort')"
|
CHECKS="$(gh api repos/github/codeql-action/commits/${GITHUB_SHA}/check-runs --paginate | jq --slurp --compact-output --raw-output '[.[].check_runs | .[].name | select(contains("https://") or . == "CodeQL" or . == "LGTM.com" or contains("Update") | not)] | unique | sort')"
|
||||||
|
|
||||||
echo "$CHECKS" | jq
|
echo "$CHECKS" | jq
|
||||||
|
|
||||||
|
|||||||
37
CHANGELOG.md
37
CHANGELOG.md
@@ -1,60 +1,41 @@
|
|||||||
# CodeQL Action Changelog
|
# CodeQL Action Changelog
|
||||||
|
|
||||||
## [UNRELEASED]
|
## 1.1.13 - 21 Jun 2022
|
||||||
|
|
||||||
No user facing changes.
|
|
||||||
|
|
||||||
## 2.1.16 - 13 Jul 2022
|
|
||||||
|
|
||||||
- You can now quickly debug a job that uses the CodeQL Action by re-running the job from the GitHub UI and selecting the "Enable debug logging" option. [#1132](https://github.com/github/codeql-action/pull/1132)
|
|
||||||
- You can now see diagnostic messages produced by the analysis in the logs of the `analyze` Action by enabling debug mode. To enable debug mode, pass `debug: true` to the `init` Action, or [enable step debug logging](https://docs.github.com/en/actions/monitoring-and-troubleshooting-workflows/enabling-debug-logging#enabling-step-debug-logging). This feature is available for CodeQL CLI version 2.10.0 and later. [#1133](https://github.com/github/codeql-action/pull/1133)
|
|
||||||
|
|
||||||
## 2.1.15 - 28 Jun 2022
|
|
||||||
|
|
||||||
- CodeQL query packs listed in the `packs` configuration field will be skipped if their target language is not being analyzed in the current Actions job. Previously, this would throw an error. [#1116](https://github.com/github/codeql-action/pull/1116)
|
|
||||||
- The combination of python2 and poetry is no longer supported. See https://github.com/actions/setup-python/issues/374 for more details. [#1124](https://github.com/github/codeql-action/pull/1124)
|
|
||||||
- Update default CodeQL bundle version to 2.10.0. [#1123](https://github.com/github/codeql-action/pull/1123)
|
|
||||||
|
|
||||||
## 2.1.14 - 22 Jun 2022
|
|
||||||
|
|
||||||
No user facing changes.
|
|
||||||
|
|
||||||
## 2.1.13 - 21 Jun 2022
|
|
||||||
|
|
||||||
|
- Add the ability to filter queries from a code scanning run by using the `query-filters` option in the code scanning configuration file. [#1098](https://github.com/github/codeql-action/pull/1098)
|
||||||
- Update default CodeQL bundle version to 2.9.4. [#1100](https://github.com/github/codeql-action/pull/1100)
|
- Update default CodeQL bundle version to 2.9.4. [#1100](https://github.com/github/codeql-action/pull/1100)
|
||||||
|
|
||||||
## 2.1.12 - 01 Jun 2022
|
## 1.1.12 - 01 Jun 2022
|
||||||
|
|
||||||
- Update default CodeQL bundle version to 2.9.3. [#1084](https://github.com/github/codeql-action/pull/1084)
|
- Update default CodeQL bundle version to 2.9.3. [#1084](https://github.com/github/codeql-action/pull/1084)
|
||||||
|
|
||||||
## 2.1.11 - 17 May 2022
|
## 1.1.11 - 17 May 2022
|
||||||
|
|
||||||
- Update default CodeQL bundle version to 2.9.2. [#1074](https://github.com/github/codeql-action/pull/1074)
|
- Update default CodeQL bundle version to 2.9.2. [#1074](https://github.com/github/codeql-action/pull/1074)
|
||||||
|
|
||||||
## 2.1.10 - 10 May 2022
|
## 1.1.10 - 10 May 2022
|
||||||
|
|
||||||
- Update default CodeQL bundle version to 2.9.1. [#1056](https://github.com/github/codeql-action/pull/1056)
|
- Update default CodeQL bundle version to 2.9.1. [#1056](https://github.com/github/codeql-action/pull/1056)
|
||||||
- When `wait-for-processing` is enabled, the workflow will now fail if there were any errors that occurred during processing of the analysis results.
|
- When `wait-for-processing` is enabled, the workflow will now fail if there were any errors that occurred during processing of the analysis results.
|
||||||
|
|
||||||
## 2.1.9 - 27 Apr 2022
|
## 1.1.9 - 27 Apr 2022
|
||||||
|
|
||||||
- Add `working-directory` input to the `autobuild` action. [#1024](https://github.com/github/codeql-action/pull/1024)
|
- Add `working-directory` input to the `autobuild` action. [#1024](https://github.com/github/codeql-action/pull/1024)
|
||||||
- The `analyze` and `upload-sarif` actions will now wait up to 2 minutes for processing to complete after they have uploaded the results so they can report any processing errors that occurred. This behavior can be disabled by setting the `wait-for-processing` action input to `"false"`. [#1007](https://github.com/github/codeql-action/pull/1007)
|
- The `analyze` and `upload-sarif` actions will now wait up to 2 minutes for processing to complete after they have uploaded the results so they can report any processing errors that occurred. This behavior can be disabled by setting the `wait-for-processing` action input to `"false"`. [#1007](https://github.com/github/codeql-action/pull/1007)
|
||||||
- Update default CodeQL bundle version to 2.9.0.
|
- Update default CodeQL bundle version to 2.9.0.
|
||||||
- Fix a bug where [status reporting fails on Windows](https://github.com/github/codeql-action/issues/1041). [#1042](https://github.com/github/codeql-action/pull/1042)
|
- Fix a bug where [status reporting fails on Windows](https://github.com/github/codeql-action/issues/1041). [#1042](https://github.com/github/codeql-action/pull/1042)
|
||||||
|
|
||||||
## 2.1.8 - 08 Apr 2022
|
## 1.1.8 - 08 Apr 2022
|
||||||
|
|
||||||
- Update default CodeQL bundle version to 2.8.5. [#1014](https://github.com/github/codeql-action/pull/1014)
|
- Update default CodeQL bundle version to 2.8.5. [#1014](https://github.com/github/codeql-action/pull/1014)
|
||||||
- Fix error where the init action would fail due to a GitHub API request that was taking too long to complete [#1025](https://github.com/github/codeql-action/pull/1025)
|
- Fix error where the init action would fail due to a GitHub API request that was taking too long to complete [#1025](https://github.com/github/codeql-action/pull/1025)
|
||||||
|
|
||||||
## 2.1.7 - 05 Apr 2022
|
## 1.1.7 - 05 Apr 2022
|
||||||
|
|
||||||
- A bug where additional queries specified in the workflow file would sometimes not be respected has been fixed. [#1018](https://github.com/github/codeql-action/pull/1018)
|
- A bug where additional queries specified in the workflow file would sometimes not be respected has been fixed. [#1018](https://github.com/github/codeql-action/pull/1018)
|
||||||
|
|
||||||
## 2.1.6 - 30 Mar 2022
|
## 1.1.6 - 30 Mar 2022
|
||||||
|
|
||||||
- [v2+ only] The CodeQL Action now runs on Node.js v16. [#1000](https://github.com/github/codeql-action/pull/1000)
|
|
||||||
- Update default CodeQL bundle version to 2.8.4. [#990](https://github.com/github/codeql-action/pull/990)
|
- Update default CodeQL bundle version to 2.8.4. [#990](https://github.com/github/codeql-action/pull/990)
|
||||||
- Fix a bug where an invalid `commit_oid` was being sent to code scanning when a custom checkout path was being used. [#956](https://github.com/github/codeql-action/pull/956)
|
- Fix a bug where an invalid `commit_oid` was being sent to code scanning when a custom checkout path was being used. [#956](https://github.com/github/codeql-action/pull/956)
|
||||||
|
|
||||||
|
|||||||
@@ -72,5 +72,5 @@ outputs:
|
|||||||
sarif-id:
|
sarif-id:
|
||||||
description: The ID of the uploaded SARIF file.
|
description: The ID of the uploaded SARIF file.
|
||||||
runs:
|
runs:
|
||||||
using: "node16"
|
using: "node12"
|
||||||
main: "../lib/analyze-action.js"
|
main: "../lib/analyze-action.js"
|
||||||
|
|||||||
@@ -13,5 +13,5 @@ inputs:
|
|||||||
$GITHUB_WORKSPACE as its working directory.
|
$GITHUB_WORKSPACE as its working directory.
|
||||||
required: false
|
required: false
|
||||||
runs:
|
runs:
|
||||||
using: 'node16'
|
using: 'node12'
|
||||||
main: '../lib/autobuild-action.js'
|
main: '../lib/autobuild-action.js'
|
||||||
|
|||||||
@@ -56,10 +56,7 @@ inputs:
|
|||||||
This input also sets the number of threads that can later be used by the "analyze" action.
|
This input also sets the number of threads that can later be used by the "analyze" action.
|
||||||
required: false
|
required: false
|
||||||
debug:
|
debug:
|
||||||
description: >-
|
description: Enable debugging mode. This will result in more output being produced which may be useful when debugging certain issues.
|
||||||
Enable debugging mode.
|
|
||||||
This will result in more output being produced which may be useful when debugging certain issues.
|
|
||||||
Debugging mode is enabled automatically when step debug logging is turned on.
|
|
||||||
required: false
|
required: false
|
||||||
default: 'false'
|
default: 'false'
|
||||||
debug-artifact-name:
|
debug-artifact-name:
|
||||||
@@ -76,5 +73,5 @@ outputs:
|
|||||||
codeql-path:
|
codeql-path:
|
||||||
description: The path of the CodeQL binary used for analysis
|
description: The path of the CodeQL binary used for analysis
|
||||||
runs:
|
runs:
|
||||||
using: 'node16'
|
using: 'node12'
|
||||||
main: '../lib/init-action.js'
|
main: '../lib/init-action.js'
|
||||||
|
|||||||
9
lib/actions-util.js
generated
9
lib/actions-util.js
generated
@@ -19,7 +19,7 @@ var __importStar = (this && this.__importStar) || function (mod) {
|
|||||||
return result;
|
return result;
|
||||||
};
|
};
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
exports.sanitizeArifactName = exports.isAnalyzingDefaultBranch = exports.getRelativeScriptPath = exports.isRunningLocalAction = exports.sendStatusReport = exports.createStatusReportBase = exports.getActionsStatus = exports.getRef = exports.computeAutomationID = exports.getAutomationID = exports.getAnalysisKey = exports.getWorkflowRunID = exports.getWorkflow = exports.formatWorkflowCause = exports.formatWorkflowErrors = exports.validateWorkflow = exports.getWorkflowErrors = exports.WorkflowErrors = exports.patternIsSuperset = exports.determineMergeBaseCommitOid = exports.getCommitOid = exports.getTemporaryDirectory = exports.getOptionalInput = exports.getRequiredInput = void 0;
|
exports.sanitizeArifactName = exports.isAnalyzingDefaultBranch = exports.getRelativeScriptPath = exports.isRunningLocalAction = exports.sendStatusReport = exports.createStatusReportBase = exports.getActionsStatus = exports.getRef = exports.computeAutomationID = exports.getAutomationID = exports.getAnalysisKey = exports.getWorkflowRunID = exports.getWorkflow = exports.formatWorkflowCause = exports.formatWorkflowErrors = exports.validateWorkflow = exports.getWorkflowErrors = exports.WorkflowErrors = exports.patternIsSuperset = exports.determineMergeBaseCommitOid = exports.getCommitOid = exports.getToolCacheDirectory = exports.getTemporaryDirectory = exports.getOptionalInput = exports.getRequiredInput = void 0;
|
||||||
const fs = __importStar(require("fs"));
|
const fs = __importStar(require("fs"));
|
||||||
const os = __importStar(require("os"));
|
const os = __importStar(require("os"));
|
||||||
const path = __importStar(require("path"));
|
const path = __importStar(require("path"));
|
||||||
@@ -66,6 +66,13 @@ function getTemporaryDirectory() {
|
|||||||
: (0, util_1.getRequiredEnvParam)("RUNNER_TEMP");
|
: (0, util_1.getRequiredEnvParam)("RUNNER_TEMP");
|
||||||
}
|
}
|
||||||
exports.getTemporaryDirectory = getTemporaryDirectory;
|
exports.getTemporaryDirectory = getTemporaryDirectory;
|
||||||
|
function getToolCacheDirectory() {
|
||||||
|
const value = process.env["CODEQL_ACTION_TOOL_CACHE"];
|
||||||
|
return value !== undefined && value !== ""
|
||||||
|
? value
|
||||||
|
: (0, util_1.getRequiredEnvParam)("RUNNER_TOOL_CACHE");
|
||||||
|
}
|
||||||
|
exports.getToolCacheDirectory = getToolCacheDirectory;
|
||||||
/**
|
/**
|
||||||
* Gets the SHA of the commit that is currently checked out.
|
* Gets the SHA of the commit that is currently checked out.
|
||||||
*/
|
*/
|
||||||
|
|||||||
File diff suppressed because one or more lines are too long
7
lib/analysis-paths.js
generated
7
lib/analysis-paths.js
generated
@@ -58,11 +58,14 @@ function includeAndExcludeAnalysisPaths(config) {
|
|||||||
}
|
}
|
||||||
// If the temporary or tools directory is in the working directory ignore that too.
|
// If the temporary or tools directory is in the working directory ignore that too.
|
||||||
const tempRelativeToWorking = path.relative(process.cwd(), config.tempDir);
|
const tempRelativeToWorking = path.relative(process.cwd(), config.tempDir);
|
||||||
|
const toolsRelativeToWorking = path.relative(process.cwd(), config.toolCacheDir);
|
||||||
let pathsIgnore = config.pathsIgnore;
|
let pathsIgnore = config.pathsIgnore;
|
||||||
if (!tempRelativeToWorking.startsWith("..") &&
|
if (!tempRelativeToWorking.startsWith("..")) {
|
||||||
!path.isAbsolute(tempRelativeToWorking)) {
|
|
||||||
pathsIgnore = pathsIgnore.concat(tempRelativeToWorking);
|
pathsIgnore = pathsIgnore.concat(tempRelativeToWorking);
|
||||||
}
|
}
|
||||||
|
if (!toolsRelativeToWorking.startsWith("..")) {
|
||||||
|
pathsIgnore = pathsIgnore.concat(toolsRelativeToWorking);
|
||||||
|
}
|
||||||
if (pathsIgnore.length !== 0) {
|
if (pathsIgnore.length !== 0) {
|
||||||
process.env["LGTM_INDEX_EXCLUDE"] = buildIncludeExcludeEnvVar(pathsIgnore);
|
process.env["LGTM_INDEX_EXCLUDE"] = buildIncludeExcludeEnvVar(pathsIgnore);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
{"version":3,"file":"analysis-paths.js","sourceRoot":"","sources":["../src/analysis-paths.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAAA,2CAA6B;AAK7B,SAAS,qBAAqB,CAAC,QAAQ;IACrC,OAAO,CACL,QAAQ,KAAK,YAAY,IAAI,QAAQ,KAAK,QAAQ,IAAI,QAAQ,KAAK,MAAM,CAC1E,CAAC;AACJ,CAAC;AAED,6FAA6F;AAChF,QAAA,+BAA+B,GAAG,cAAc,CAAC;AAE9D,uFAAuF;AACvF,SAAS,yBAAyB,CAAC,KAAe;IAChD,iCAAiC;IACjC,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAEnD,uDAAuD;IACvD,IAAI,OAAO,CAAC,QAAQ,KAAK,OAAO,EAAE;QAChC,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,uCAA+B,CAAC,CAAC,CAAC;KACvE;IAED,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAC1B,CAAC;AAED,SAAgB,uBAAuB,CACrC,MAA0B,EAC1B,MAAc;IAEd,qEAAqE;IACrE,sEAAsE;IACtE,IACE,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,IAAI,MAAM,CAAC,WAAW,CAAC,MAAM,KAAK,CAAC,CAAC;QAC9D,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,qBAAqB,CAAC,EAC9C;QACA,MAAM,CAAC,OAAO,CACZ,mGAAmG,CACpG,CAAC;KACH;AACH,CAAC;AAdD,0DAcC;AAED,SAAgB,8BAA8B,CAAC,MAA0B;IACvE,0EAA0E;IAC1E,+DAA+D;IAC/D,sEAAsE;IACtE,qDAAqD;IACrD,gFAAgF;IAChF,sEAAsE;IACtE,sDAAsD;IACtD,IAAI,MAAM,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;QAC7B,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,GAAG,yBAAyB,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;KAC7E;IACD,mFAAmF;IACnF,MAAM,qBAAqB,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC;IAC3E,IAAI,WAAW,GAAG,MAAM,CAAC,WAAW,CAAC;IACrC,IACE,CAAC,qBAAqB,CAAC,UAAU,CAAC,IAAI,CAAC;QACvC,CAAC,IAAI,CAAC,UAAU,CAAC,qBAAqB,CAAC,EACvC;QACA,WAAW,GAAG,WAAW,CAAC,MAAM,CAAC,qBAAqB,CAAC,CAAC;KACzD;IACD,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE;QAC5B,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,GAAG,yBAAyB,CAAC,WAAW,CAAC,CAAC;KAC5E;IAED,yEAAyE;IACzE,6EAA6E;IAC7E,wDAAwD;IACxD,MAAM,OAAO,GAAa,EAAE,CAAC;IAC7B,OAAO,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,CAAC;IACzD,OAAO,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,CAAC;IAC/D,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE;QACxB,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;KACxD;AACH,CAAC;AAjCD,wEAiCC"}
|
{"version":3,"file":"analysis-paths.js","sourceRoot":"","sources":["../src/analysis-paths.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAAA,2CAA6B;AAK7B,SAAS,qBAAqB,CAAC,QAAQ;IACrC,OAAO,CACL,QAAQ,KAAK,YAAY,IAAI,QAAQ,KAAK,QAAQ,IAAI,QAAQ,KAAK,MAAM,CAC1E,CAAC;AACJ,CAAC;AAED,6FAA6F;AAChF,QAAA,+BAA+B,GAAG,cAAc,CAAC;AAE9D,uFAAuF;AACvF,SAAS,yBAAyB,CAAC,KAAe;IAChD,iCAAiC;IACjC,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;IAEnD,uDAAuD;IACvD,IAAI,OAAO,CAAC,QAAQ,KAAK,OAAO,EAAE;QAChC,KAAK,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,uCAA+B,CAAC,CAAC,CAAC;KACvE;IAED,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;AAC1B,CAAC;AAED,SAAgB,uBAAuB,CACrC,MAA0B,EAC1B,MAAc;IAEd,qEAAqE;IACrE,sEAAsE;IACtE,IACE,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,IAAI,MAAM,CAAC,WAAW,CAAC,MAAM,KAAK,CAAC,CAAC;QAC9D,CAAC,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,qBAAqB,CAAC,EAC9C;QACA,MAAM,CAAC,OAAO,CACZ,mGAAmG,CACpG,CAAC;KACH;AACH,CAAC;AAdD,0DAcC;AAED,SAAgB,8BAA8B,CAAC,MAA0B;IACvE,0EAA0E;IAC1E,+DAA+D;IAC/D,sEAAsE;IACtE,qDAAqD;IACrD,gFAAgF;IAChF,sEAAsE;IACtE,sDAAsD;IACtD,IAAI,MAAM,CAAC,KAAK,CAAC,MAAM,KAAK,CAAC,EAAE;QAC7B,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,GAAG,yBAAyB,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;KAC7E;IACD,mFAAmF;IACnF,MAAM,qBAAqB,GAAG,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,MAAM,CAAC,OAAO,CAAC,CAAC;IAC3E,MAAM,sBAAsB,GAAG,IAAI,CAAC,QAAQ,CAC1C,OAAO,CAAC,GAAG,EAAE,EACb,MAAM,CAAC,YAAY,CACpB,CAAC;IACF,IAAI,WAAW,GAAG,MAAM,CAAC,WAAW,CAAC;IACrC,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE;QAC3C,WAAW,GAAG,WAAW,CAAC,MAAM,CAAC,qBAAqB,CAAC,CAAC;KACzD;IACD,IAAI,CAAC,sBAAsB,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE;QAC5C,WAAW,GAAG,WAAW,CAAC,MAAM,CAAC,sBAAsB,CAAC,CAAC;KAC1D;IACD,IAAI,WAAW,CAAC,MAAM,KAAK,CAAC,EAAE;QAC5B,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,GAAG,yBAAyB,CAAC,WAAW,CAAC,CAAC;KAC5E;IAED,yEAAyE;IACzE,6EAA6E;IAC7E,wDAAwD;IACxD,MAAM,OAAO,GAAa,EAAE,CAAC;IAC7B,OAAO,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,CAAC;IACzD,OAAO,CAAC,IAAI,CAAC,GAAG,MAAM,CAAC,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC,CAAC;IAC/D,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE;QACxB,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;KACxD;AACH,CAAC;AArCD,wEAqCC"}
|
||||||
47
lib/analysis-paths.test.js
generated
47
lib/analysis-paths.test.js
generated
@@ -37,6 +37,7 @@ const util = __importStar(require("./util"));
|
|||||||
paths: [],
|
paths: [],
|
||||||
originalUserInput: {},
|
originalUserInput: {},
|
||||||
tempDir: tmpDir,
|
tempDir: tmpDir,
|
||||||
|
toolCacheDir: tmpDir,
|
||||||
codeQLCmd: "",
|
codeQLCmd: "",
|
||||||
gitHubVersion: { type: util.GitHubVariant.DOTCOM },
|
gitHubVersion: { type: util.GitHubVariant.DOTCOM },
|
||||||
dbLocation: path.resolve(tmpDir, "codeql_databases"),
|
dbLocation: path.resolve(tmpDir, "codeql_databases"),
|
||||||
@@ -61,6 +62,7 @@ const util = __importStar(require("./util"));
|
|||||||
pathsIgnore: ["path4", "path5", "path6/**"],
|
pathsIgnore: ["path4", "path5", "path6/**"],
|
||||||
originalUserInput: {},
|
originalUserInput: {},
|
||||||
tempDir: tmpDir,
|
tempDir: tmpDir,
|
||||||
|
toolCacheDir: tmpDir,
|
||||||
codeQLCmd: "",
|
codeQLCmd: "",
|
||||||
gitHubVersion: { type: util.GitHubVariant.DOTCOM },
|
gitHubVersion: { type: util.GitHubVariant.DOTCOM },
|
||||||
dbLocation: path.resolve(tmpDir, "codeql_databases"),
|
dbLocation: path.resolve(tmpDir, "codeql_databases"),
|
||||||
@@ -77,26 +79,29 @@ const util = __importStar(require("./util"));
|
|||||||
});
|
});
|
||||||
});
|
});
|
||||||
(0, ava_1.default)("exclude temp dir", async (t) => {
|
(0, ava_1.default)("exclude temp dir", async (t) => {
|
||||||
const tempDir = path.join(process.cwd(), "codeql-runner-temp");
|
return await util.withTmpDir(async (toolCacheDir) => {
|
||||||
const config = {
|
const tempDir = path.join(process.cwd(), "codeql-runner-temp");
|
||||||
languages: [],
|
const config = {
|
||||||
queries: {},
|
languages: [],
|
||||||
pathsIgnore: [],
|
queries: {},
|
||||||
paths: [],
|
pathsIgnore: [],
|
||||||
originalUserInput: {},
|
paths: [],
|
||||||
tempDir,
|
originalUserInput: {},
|
||||||
codeQLCmd: "",
|
tempDir,
|
||||||
gitHubVersion: { type: util.GitHubVariant.DOTCOM },
|
toolCacheDir,
|
||||||
dbLocation: path.resolve(tempDir, "codeql_databases"),
|
codeQLCmd: "",
|
||||||
packs: {},
|
gitHubVersion: { type: util.GitHubVariant.DOTCOM },
|
||||||
debugMode: false,
|
dbLocation: path.resolve(tempDir, "codeql_databases"),
|
||||||
debugArtifactName: util.DEFAULT_DEBUG_ARTIFACT_NAME,
|
packs: {},
|
||||||
debugDatabaseName: util.DEFAULT_DEBUG_DATABASE_NAME,
|
debugMode: false,
|
||||||
injectedMlQueries: false,
|
debugArtifactName: util.DEFAULT_DEBUG_ARTIFACT_NAME,
|
||||||
};
|
debugDatabaseName: util.DEFAULT_DEBUG_DATABASE_NAME,
|
||||||
analysisPaths.includeAndExcludeAnalysisPaths(config);
|
injectedMlQueries: false,
|
||||||
t.is(process.env["LGTM_INDEX_INCLUDE"], undefined);
|
};
|
||||||
t.is(process.env["LGTM_INDEX_EXCLUDE"], "codeql-runner-temp");
|
analysisPaths.includeAndExcludeAnalysisPaths(config);
|
||||||
t.is(process.env["LGTM_INDEX_FILTERS"], undefined);
|
t.is(process.env["LGTM_INDEX_INCLUDE"], undefined);
|
||||||
|
t.is(process.env["LGTM_INDEX_EXCLUDE"], "codeql-runner-temp");
|
||||||
|
t.is(process.env["LGTM_INDEX_FILTERS"], undefined);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
//# sourceMappingURL=analysis-paths.test.js.map
|
//# sourceMappingURL=analysis-paths.test.js.map
|
||||||
@@ -1 +1 @@
|
|||||||
{"version":3,"file":"analysis-paths.test.js","sourceRoot":"","sources":["../src/analysis-paths.test.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAAA,2CAA6B;AAE7B,8CAAuB;AAEvB,gEAAkD;AAClD,mDAA6C;AAC7C,6CAA+B;AAE/B,IAAA,0BAAU,EAAC,aAAI,CAAC,CAAC;AAEjB,IAAA,aAAI,EAAC,YAAY,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;IAC7B,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE;QAC5C,MAAM,MAAM,GAAG;YACb,SAAS,EAAE,EAAE;YACb,OAAO,EAAE,EAAE;YACX,WAAW,EAAE,EAAE;YACf,KAAK,EAAE,EAAE;YACT,iBAAiB,EAAE,EAAE;YACrB,OAAO,EAAE,MAAM;YACf,SAAS,EAAE,EAAE;YACb,aAAa,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,aAAa,CAAC,MAAM,EAAwB;YACxE,UAAU,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,kBAAkB,CAAC;YACpD,KAAK,EAAE,EAAE;YACT,SAAS,EAAE,KAAK;YAChB,iBAAiB,EAAE,IAAI,CAAC,2BAA2B;YACnD,iBAAiB,EAAE,IAAI,CAAC,2BAA2B;YACnD,iBAAiB,EAAE,KAAK;SACzB,CAAC;QACF,aAAa,CAAC,8BAA8B,CAAC,MAAM,CAAC,CAAC;QACrD,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,EAAE,SAAS,CAAC,CAAC;QACnD,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,EAAE,SAAS,CAAC,CAAC;QACnD,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,EAAE,SAAS,CAAC,CAAC;IACrD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAA,aAAI,EAAC,eAAe,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;IAChC,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE;QAC5C,MAAM,MAAM,GAAG;YACb,SAAS,EAAE,EAAE;YACb,OAAO,EAAE,EAAE;YACX,KAAK,EAAE,CAAC,OAAO,EAAE,OAAO,EAAE,UAAU,CAAC;YACrC,WAAW,EAAE,CAAC,OAAO,EAAE,OAAO,EAAE,UAAU,CAAC;YAC3C,iBAAiB,EAAE,EAAE;YACrB,OAAO,EAAE,MAAM;YACf,SAAS,EAAE,EAAE;YACb,aAAa,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,aAAa,CAAC,MAAM,EAAwB;YACxE,UAAU,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,kBAAkB,CAAC;YACpD,KAAK,EAAE,EAAE;YACT,SAAS,EAAE,KAAK;YAChB,iBAAiB,EAAE,IAAI,CAAC,2BAA2B;YACnD,iBAAiB,EAAE,IAAI,CAAC,2BAA2B;YACnD,iBAAiB,EAAE,KAAK;SACzB,CAAC;QACF,aAAa,CAAC,8BAA8B,CAAC,MAAM,CAAC,CAAC;QACrD,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,EAAE,cAAc,CAAC,CAAC;QACxD,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,EAAE,cAAc,CAAC,CAAC;QACxD,CAAC,CAAC,EAAE,CACF,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,EACjC,gGAAgG,CACjG,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAA,aAAI,EAAC,kBAAkB,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;IACnC,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,oBAAoB,CAAC,CAAC;IAC/D,MAAM,MAAM,GAAG;QACb,SAAS,EAAE,EAAE;QACb,OAAO,EAAE,EAAE;QACX,WAAW,EAAE,EAAE;QACf,KAAK,EAAE,EAAE;QACT,iBAAiB,EAAE,EAAE;QACrB,OAAO;QACP,SAAS,EAAE,EAAE;QACb,aAAa,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,aAAa,CAAC,MAAM,EAAwB;QACxE,UAAU,EAAE,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,kBAAkB,CAAC;QACrD,KAAK,EAAE,EAAE;QACT,SAAS,EAAE,KAAK;QAChB,iBAAiB,EAAE,IAAI,CAAC,2BAA2B;QACnD,iBAAiB,EAAE,IAAI,CAAC,2BAA2B;QACnD,iBAAiB,EAAE,KAAK;KACzB,CAAC;IACF,aAAa,CAAC,8BAA8B,CAAC,MAAM,CAAC,CAAC;IACrD,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,EAAE,SAAS,CAAC,CAAC;IACnD,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,EAAE,oBAAoB,CAAC,CAAC;IAC9D,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,EAAE,SAAS,CAAC,CAAC;AACrD,CAAC,CAAC,CAAC"}
|
{"version":3,"file":"analysis-paths.test.js","sourceRoot":"","sources":["../src/analysis-paths.test.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;AAAA,2CAA6B;AAE7B,8CAAuB;AAEvB,gEAAkD;AAClD,mDAA6C;AAC7C,6CAA+B;AAE/B,IAAA,0BAAU,EAAC,aAAI,CAAC,CAAC;AAEjB,IAAA,aAAI,EAAC,YAAY,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;IAC7B,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE;QAC5C,MAAM,MAAM,GAAG;YACb,SAAS,EAAE,EAAE;YACb,OAAO,EAAE,EAAE;YACX,WAAW,EAAE,EAAE;YACf,KAAK,EAAE,EAAE;YACT,iBAAiB,EAAE,EAAE;YACrB,OAAO,EAAE,MAAM;YACf,YAAY,EAAE,MAAM;YACpB,SAAS,EAAE,EAAE;YACb,aAAa,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,aAAa,CAAC,MAAM,EAAwB;YACxE,UAAU,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,kBAAkB,CAAC;YACpD,KAAK,EAAE,EAAE;YACT,SAAS,EAAE,KAAK;YAChB,iBAAiB,EAAE,IAAI,CAAC,2BAA2B;YACnD,iBAAiB,EAAE,IAAI,CAAC,2BAA2B;YACnD,iBAAiB,EAAE,KAAK;SACzB,CAAC;QACF,aAAa,CAAC,8BAA8B,CAAC,MAAM,CAAC,CAAC;QACrD,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,EAAE,SAAS,CAAC,CAAC;QACnD,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,EAAE,SAAS,CAAC,CAAC;QACnD,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,EAAE,SAAS,CAAC,CAAC;IACrD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAA,aAAI,EAAC,eAAe,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;IAChC,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,MAAM,EAAE,EAAE;QAC5C,MAAM,MAAM,GAAG;YACb,SAAS,EAAE,EAAE;YACb,OAAO,EAAE,EAAE;YACX,KAAK,EAAE,CAAC,OAAO,EAAE,OAAO,EAAE,UAAU,CAAC;YACrC,WAAW,EAAE,CAAC,OAAO,EAAE,OAAO,EAAE,UAAU,CAAC;YAC3C,iBAAiB,EAAE,EAAE;YACrB,OAAO,EAAE,MAAM;YACf,YAAY,EAAE,MAAM;YACpB,SAAS,EAAE,EAAE;YACb,aAAa,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,aAAa,CAAC,MAAM,EAAwB;YACxE,UAAU,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,kBAAkB,CAAC;YACpD,KAAK,EAAE,EAAE;YACT,SAAS,EAAE,KAAK;YAChB,iBAAiB,EAAE,IAAI,CAAC,2BAA2B;YACnD,iBAAiB,EAAE,IAAI,CAAC,2BAA2B;YACnD,iBAAiB,EAAE,KAAK;SACzB,CAAC;QACF,aAAa,CAAC,8BAA8B,CAAC,MAAM,CAAC,CAAC;QACrD,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,EAAE,cAAc,CAAC,CAAC;QACxD,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,EAAE,cAAc,CAAC,CAAC;QACxD,CAAC,CAAC,EAAE,CACF,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,EACjC,gGAAgG,CACjG,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC;AAEH,IAAA,aAAI,EAAC,kBAAkB,EAAE,KAAK,EAAE,CAAC,EAAE,EAAE;IACnC,OAAO,MAAM,IAAI,CAAC,UAAU,CAAC,KAAK,EAAE,YAAY,EAAE,EAAE;QAClD,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,oBAAoB,CAAC,CAAC;QAC/D,MAAM,MAAM,GAAG;YACb,SAAS,EAAE,EAAE;YACb,OAAO,EAAE,EAAE;YACX,WAAW,EAAE,EAAE;YACf,KAAK,EAAE,EAAE;YACT,iBAAiB,EAAE,EAAE;YACrB,OAAO;YACP,YAAY;YACZ,SAAS,EAAE,EAAE;YACb,aAAa,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,aAAa,CAAC,MAAM,EAAwB;YACxE,UAAU,EAAE,IAAI,CAAC,OAAO,CAAC,OAAO,EAAE,kBAAkB,CAAC;YACrD,KAAK,EAAE,EAAE;YACT,SAAS,EAAE,KAAK;YAChB,iBAAiB,EAAE,IAAI,CAAC,2BAA2B;YACnD,iBAAiB,EAAE,IAAI,CAAC,2BAA2B;YACnD,iBAAiB,EAAE,KAAK;SACzB,CAAC;QACF,aAAa,CAAC,8BAA8B,CAAC,MAAM,CAAC,CAAC;QACrD,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,EAAE,SAAS,CAAC,CAAC;QACnD,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,EAAE,oBAAoB,CAAC,CAAC;QAC9D,CAAC,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,EAAE,SAAS,CAAC,CAAC;IACrD,CAAC,CAAC,CAAC;AACL,CAAC,CAAC,CAAC"}
|
||||||
20
lib/analyze-action.js
generated
20
lib/analyze-action.js
generated
@@ -26,11 +26,9 @@ const artifact = __importStar(require("@actions/artifact"));
|
|||||||
const core = __importStar(require("@actions/core"));
|
const core = __importStar(require("@actions/core"));
|
||||||
const actionsUtil = __importStar(require("./actions-util"));
|
const actionsUtil = __importStar(require("./actions-util"));
|
||||||
const analyze_1 = require("./analyze");
|
const analyze_1 = require("./analyze");
|
||||||
const api_client_1 = require("./api-client");
|
|
||||||
const codeql_1 = require("./codeql");
|
const codeql_1 = require("./codeql");
|
||||||
const config_utils_1 = require("./config-utils");
|
const config_utils_1 = require("./config-utils");
|
||||||
const database_upload_1 = require("./database-upload");
|
const database_upload_1 = require("./database-upload");
|
||||||
const feature_flags_1 = require("./feature-flags");
|
|
||||||
const logging_1 = require("./logging");
|
const logging_1 = require("./logging");
|
||||||
const repository_1 = require("./repository");
|
const repository_1 = require("./repository");
|
||||||
const upload_lib = __importStar(require("./upload-lib"));
|
const upload_lib = __importStar(require("./upload-lib"));
|
||||||
@@ -78,9 +76,7 @@ async function run() {
|
|||||||
const threads = util.getThreadsFlag(actionsUtil.getOptionalInput("threads") || process.env["CODEQL_THREADS"], logger);
|
const threads = util.getThreadsFlag(actionsUtil.getOptionalInput("threads") || process.env["CODEQL_THREADS"], logger);
|
||||||
const memory = util.getMemoryFlag(actionsUtil.getOptionalInput("ram") || process.env["CODEQL_RAM"]);
|
const memory = util.getMemoryFlag(actionsUtil.getOptionalInput("ram") || process.env["CODEQL_RAM"]);
|
||||||
const repositoryNwo = (0, repository_1.parseRepositoryNwo)(util.getRequiredEnvParam("GITHUB_REPOSITORY"));
|
const repositoryNwo = (0, repository_1.parseRepositoryNwo)(util.getRequiredEnvParam("GITHUB_REPOSITORY"));
|
||||||
const gitHubVersion = await (0, api_client_1.getGitHubVersionActionsOnly)();
|
await (0, analyze_1.runFinalize)(outputDir, threads, memory, config, logger);
|
||||||
const featureFlags = new feature_flags_1.GitHubFeatureFlags(gitHubVersion, apiDetails, repositoryNwo, logger);
|
|
||||||
await (0, analyze_1.runFinalize)(outputDir, threads, memory, config, logger, featureFlags);
|
|
||||||
if (actionsUtil.getRequiredInput("skip-queries") !== "true") {
|
if (actionsUtil.getRequiredInput("skip-queries") !== "true") {
|
||||||
runStats = await (0, analyze_1.runQueries)(outputDir, memory, util.getAddSnippetsFlag(actionsUtil.getRequiredInput("add-snippets")), threads, actionsUtil.getOptionalInput("category"), config, logger);
|
runStats = await (0, analyze_1.runQueries)(outputDir, memory, util.getAddSnippetsFlag(actionsUtil.getRequiredInput("add-snippets")), threads, actionsUtil.getOptionalInput("category"), config, logger);
|
||||||
if (config.debugMode) {
|
if (config.debugMode) {
|
||||||
@@ -91,13 +87,13 @@ async function run() {
|
|||||||
const codeql = await (0, codeql_1.getCodeQL)(config.codeQLCmd);
|
const codeql = await (0, codeql_1.getCodeQL)(config.codeQLCmd);
|
||||||
if (config.debugMode) {
|
if (config.debugMode) {
|
||||||
// Upload the logs as an Actions artifact for debugging
|
// Upload the logs as an Actions artifact for debugging
|
||||||
let toUpload = [];
|
const toUpload = [];
|
||||||
for (const language of config.languages) {
|
for (const language of config.languages) {
|
||||||
toUpload = toUpload.concat(listFolder(path.resolve(util.getCodeQLDatabasePath(config, language), "log")));
|
toUpload.push(...listFolder(path.resolve(util.getCodeQLDatabasePath(config, language), "log")));
|
||||||
}
|
}
|
||||||
if (await (0, util_1.codeQlVersionAbove)(codeql, codeql_1.CODEQL_VERSION_NEW_TRACING)) {
|
if (await (0, util_1.codeQlVersionAbove)(codeql, codeql_1.CODEQL_VERSION_NEW_TRACING)) {
|
||||||
// Multilanguage tracing: there are additional logs in the root of the cluster
|
// Multilanguage tracing: there are additional logs in the root of the cluster
|
||||||
toUpload = toUpload.concat(listFolder(path.resolve(config.dbLocation, "log")));
|
toUpload.push(...listFolder(path.resolve(config.dbLocation, "log")));
|
||||||
}
|
}
|
||||||
await uploadDebugArtifacts(toUpload, config.dbLocation, config.debugArtifactName);
|
await uploadDebugArtifacts(toUpload, config.dbLocation, config.debugArtifactName);
|
||||||
if (!(await (0, util_1.codeQlVersionAbove)(codeql, codeql_1.CODEQL_VERSION_NEW_TRACING))) {
|
if (!(await (0, util_1.codeQlVersionAbove)(codeql, codeql_1.CODEQL_VERSION_NEW_TRACING))) {
|
||||||
@@ -145,7 +141,7 @@ async function run() {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
finally {
|
finally {
|
||||||
if (config === null || config === void 0 ? void 0 : config.debugMode) {
|
if (config !== undefined && config.debugMode) {
|
||||||
try {
|
try {
|
||||||
// Upload the database bundles as an Actions artifact for debugging
|
// Upload the database bundles as an Actions artifact for debugging
|
||||||
const toUpload = [];
|
const toUpload = [];
|
||||||
@@ -158,7 +154,7 @@ async function run() {
|
|||||||
console.log(`Failed to upload database debug bundles: ${error}`);
|
console.log(`Failed to upload database debug bundles: ${error}`);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (config === null || config === void 0 ? void 0 : config.debugMode) {
|
if (core.isDebug() && config !== undefined) {
|
||||||
core.info("Debug mode is on. Printing CodeQL debug logs...");
|
core.info("Debug mode is on. Printing CodeQL debug logs...");
|
||||||
for (const language of config.languages) {
|
for (const language of config.languages) {
|
||||||
const databaseDirectory = util.getCodeQLDatabasePath(config, language);
|
const databaseDirectory = util.getCodeQLDatabasePath(config, language);
|
||||||
@@ -204,13 +200,13 @@ async function uploadDebugArtifacts(toUpload, rootDir, artifactName) {
|
|||||||
}
|
}
|
||||||
function listFolder(dir) {
|
function listFolder(dir) {
|
||||||
const entries = fs.readdirSync(dir, { withFileTypes: true });
|
const entries = fs.readdirSync(dir, { withFileTypes: true });
|
||||||
let files = [];
|
const files = [];
|
||||||
for (const entry of entries) {
|
for (const entry of entries) {
|
||||||
if (entry.isFile()) {
|
if (entry.isFile()) {
|
||||||
files.push(path.resolve(dir, entry.name));
|
files.push(path.resolve(dir, entry.name));
|
||||||
}
|
}
|
||||||
else if (entry.isDirectory()) {
|
else if (entry.isDirectory()) {
|
||||||
files = files.concat(listFolder(path.resolve(dir, entry.name)));
|
files.push(...listFolder(path.resolve(dir, entry.name)));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return files;
|
return files;
|
||||||
|
|||||||
File diff suppressed because one or more lines are too long
118
lib/analyze.js
generated
118
lib/analyze.js
generated
@@ -22,7 +22,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|||||||
return (mod && mod.__esModule) ? mod : { "default": mod };
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
||||||
};
|
};
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
exports.runCleanup = exports.runFinalize = exports.runQueries = exports.createdDBForScannedLanguages = exports.CodeQLAnalysisError = void 0;
|
exports.validateQueryFilters = exports.runCleanup = exports.runFinalize = exports.createQuerySuiteContents = exports.convertPackToQuerySuiteEntry = exports.runQueries = exports.CodeQLAnalysisError = void 0;
|
||||||
const fs = __importStar(require("fs"));
|
const fs = __importStar(require("fs"));
|
||||||
const path = __importStar(require("path"));
|
const path = __importStar(require("path"));
|
||||||
const toolrunner = __importStar(require("@actions/exec/lib/toolrunner"));
|
const toolrunner = __importStar(require("@actions/exec/lib/toolrunner"));
|
||||||
@@ -30,6 +30,7 @@ const del_1 = __importDefault(require("del"));
|
|||||||
const yaml = __importStar(require("js-yaml"));
|
const yaml = __importStar(require("js-yaml"));
|
||||||
const analysisPaths = __importStar(require("./analysis-paths"));
|
const analysisPaths = __importStar(require("./analysis-paths"));
|
||||||
const codeql_1 = require("./codeql");
|
const codeql_1 = require("./codeql");
|
||||||
|
const configUtils = __importStar(require("./config-utils"));
|
||||||
const count_loc_1 = require("./count-loc");
|
const count_loc_1 = require("./count-loc");
|
||||||
const languages_1 = require("./languages");
|
const languages_1 = require("./languages");
|
||||||
const sharedEnv = __importStar(require("./shared-environment"));
|
const sharedEnv = __importStar(require("./shared-environment"));
|
||||||
@@ -68,10 +69,11 @@ async function setupPythonExtractor(logger) {
|
|||||||
logger.info(`Setting LGTM_PYTHON_SETUP_VERSION=${output}`);
|
logger.info(`Setting LGTM_PYTHON_SETUP_VERSION=${output}`);
|
||||||
process.env["LGTM_PYTHON_SETUP_VERSION"] = output;
|
process.env["LGTM_PYTHON_SETUP_VERSION"] = output;
|
||||||
}
|
}
|
||||||
async function createdDBForScannedLanguages(codeql, config, logger, featureFlags) {
|
async function createdDBForScannedLanguages(config, logger) {
|
||||||
// Insert the LGTM_INDEX_X env vars at this point so they are set when
|
// Insert the LGTM_INDEX_X env vars at this point so they are set when
|
||||||
// we extract any scanned languages.
|
// we extract any scanned languages.
|
||||||
analysisPaths.includeAndExcludeAnalysisPaths(config);
|
analysisPaths.includeAndExcludeAnalysisPaths(config);
|
||||||
|
const codeql = await (0, codeql_1.getCodeQL)(config.codeQLCmd);
|
||||||
for (const language of config.languages) {
|
for (const language of config.languages) {
|
||||||
if ((0, languages_1.isScannedLanguage)(language) &&
|
if ((0, languages_1.isScannedLanguage)(language) &&
|
||||||
!dbIsFinalized(config, language, logger)) {
|
!dbIsFinalized(config, language, logger)) {
|
||||||
@@ -79,12 +81,11 @@ async function createdDBForScannedLanguages(codeql, config, logger, featureFlags
|
|||||||
if (language === languages_1.Language.python) {
|
if (language === languages_1.Language.python) {
|
||||||
await setupPythonExtractor(logger);
|
await setupPythonExtractor(logger);
|
||||||
}
|
}
|
||||||
await codeql.extractScannedLanguage(util.getCodeQLDatabasePath(config, language), language, featureFlags);
|
await codeql.extractScannedLanguage(util.getCodeQLDatabasePath(config, language), language);
|
||||||
logger.endGroup();
|
logger.endGroup();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
exports.createdDBForScannedLanguages = createdDBForScannedLanguages;
|
|
||||||
function dbIsFinalized(config, language, logger) {
|
function dbIsFinalized(config, language, logger) {
|
||||||
const dbPath = util.getCodeQLDatabasePath(config, language);
|
const dbPath = util.getCodeQLDatabasePath(config, language);
|
||||||
try {
|
try {
|
||||||
@@ -96,9 +97,9 @@ function dbIsFinalized(config, language, logger) {
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
async function finalizeDatabaseCreation(config, threadsFlag, memoryFlag, logger, featureFlags) {
|
async function finalizeDatabaseCreation(config, threadsFlag, memoryFlag, logger) {
|
||||||
|
await createdDBForScannedLanguages(config, logger);
|
||||||
const codeql = await (0, codeql_1.getCodeQL)(config.codeQLCmd);
|
const codeql = await (0, codeql_1.getCodeQL)(config.codeQLCmd);
|
||||||
await createdDBForScannedLanguages(codeql, config, logger, featureFlags);
|
|
||||||
for (const language of config.languages) {
|
for (const language of config.languages) {
|
||||||
if (dbIsFinalized(config, language, logger)) {
|
if (dbIsFinalized(config, language, logger)) {
|
||||||
logger.info(`There is already a finalized database for ${language} at the location where the CodeQL Action places databases, so we did not create one.`);
|
logger.info(`There is already a finalized database for ${language} at the location where the CodeQL Action places databases, so we did not create one.`);
|
||||||
@@ -115,8 +116,10 @@ async function runQueries(sarifFolder, memoryFlag, addSnippetsFlag, threadsFlag,
|
|||||||
const statusReport = {};
|
const statusReport = {};
|
||||||
let locPromise = Promise.resolve({});
|
let locPromise = Promise.resolve({});
|
||||||
const cliCanCountBaseline = await cliCanCountLoC();
|
const cliCanCountBaseline = await cliCanCountLoC();
|
||||||
const countLocDebugMode = process.env["INTERNAL_CODEQL_ACTION_DEBUG_LOC"] || config.debugMode;
|
const debugMode = process.env["INTERNAL_CODEQL_ACTION_DEBUG_LOC"] ||
|
||||||
if (!cliCanCountBaseline || countLocDebugMode) {
|
process.env["ACTIONS_RUNNER_DEBUG"] ||
|
||||||
|
process.env["ACTIONS_STEP_DEBUG"];
|
||||||
|
if (!cliCanCountBaseline || debugMode) {
|
||||||
// count the number of lines in the background
|
// count the number of lines in the background
|
||||||
locPromise = (0, count_loc_1.countLoc)(path.resolve(),
|
locPromise = (0, count_loc_1.countLoc)(path.resolve(),
|
||||||
// config.paths specifies external directories. the current
|
// config.paths specifies external directories. the current
|
||||||
@@ -126,6 +129,7 @@ async function runQueries(sarifFolder, memoryFlag, addSnippetsFlag, threadsFlag,
|
|||||||
}
|
}
|
||||||
for (const language of config.languages) {
|
for (const language of config.languages) {
|
||||||
const queries = config.queries[language];
|
const queries = config.queries[language];
|
||||||
|
const queryFilters = validateQueryFilters(config.originalUserInput["query-filters"]);
|
||||||
const packsWithVersion = config.packs[language] || [];
|
const packsWithVersion = config.packs[language] || [];
|
||||||
const hasBuiltinQueries = (queries === null || queries === void 0 ? void 0 : queries.builtin.length) > 0;
|
const hasBuiltinQueries = (queries === null || queries === void 0 ? void 0 : queries.builtin.length) > 0;
|
||||||
const hasCustomQueries = (queries === null || queries === void 0 ? void 0 : queries.custom.length) > 0;
|
const hasCustomQueries = (queries === null || queries === void 0 ? void 0 : queries.custom.length) > 0;
|
||||||
@@ -148,7 +152,7 @@ async function runQueries(sarifFolder, memoryFlag, addSnippetsFlag, threadsFlag,
|
|||||||
const querySuitePaths = [];
|
const querySuitePaths = [];
|
||||||
if (queries["builtin"].length > 0) {
|
if (queries["builtin"].length > 0) {
|
||||||
const startTimeBuiltIn = new Date().getTime();
|
const startTimeBuiltIn = new Date().getTime();
|
||||||
querySuitePaths.push(await runQueryGroup(language, "builtin", createQuerySuiteContents(queries["builtin"]), undefined));
|
querySuitePaths.push(await runQueryGroup(language, "builtin", createQuerySuiteContents(queries["builtin"], queryFilters), undefined));
|
||||||
statusReport[`analyze_builtin_queries_${language}_duration_ms`] =
|
statusReport[`analyze_builtin_queries_${language}_duration_ms`] =
|
||||||
new Date().getTime() - startTimeBuiltIn;
|
new Date().getTime() - startTimeBuiltIn;
|
||||||
}
|
}
|
||||||
@@ -156,12 +160,12 @@ async function runQueries(sarifFolder, memoryFlag, addSnippetsFlag, threadsFlag,
|
|||||||
let ranCustom = false;
|
let ranCustom = false;
|
||||||
for (let i = 0; i < queries["custom"].length; ++i) {
|
for (let i = 0; i < queries["custom"].length; ++i) {
|
||||||
if (queries["custom"][i].queries.length > 0) {
|
if (queries["custom"][i].queries.length > 0) {
|
||||||
querySuitePaths.push(await runQueryGroup(language, `custom-${i}`, createQuerySuiteContents(queries["custom"][i].queries), queries["custom"][i].searchPath));
|
querySuitePaths.push(await runQueryGroup(language, `custom-${i}`, createQuerySuiteContents(queries["custom"][i].queries, queryFilters), queries["custom"][i].searchPath));
|
||||||
ranCustom = true;
|
ranCustom = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (packsWithVersion.length > 0) {
|
if (packsWithVersion.length > 0) {
|
||||||
querySuitePaths.push(...(await runQueryPacks(language, "packs", packsWithVersion, undefined)));
|
querySuitePaths.push(await runQueryPacks(language, "packs", packsWithVersion, queryFilters));
|
||||||
ranCustom = true;
|
ranCustom = true;
|
||||||
}
|
}
|
||||||
if (ranCustom) {
|
if (ranCustom) {
|
||||||
@@ -172,14 +176,14 @@ async function runQueries(sarifFolder, memoryFlag, addSnippetsFlag, threadsFlag,
|
|||||||
logger.startGroup(`Interpreting results for ${language}`);
|
logger.startGroup(`Interpreting results for ${language}`);
|
||||||
const startTimeInterpretResults = new Date().getTime();
|
const startTimeInterpretResults = new Date().getTime();
|
||||||
const sarifFile = path.join(sarifFolder, `${language}.sarif`);
|
const sarifFile = path.join(sarifFolder, `${language}.sarif`);
|
||||||
const analysisSummary = await runInterpretResults(language, querySuitePaths, sarifFile, config.debugMode);
|
const analysisSummary = await runInterpretResults(language, querySuitePaths, sarifFile);
|
||||||
if (!cliCanCountBaseline)
|
if (!cliCanCountBaseline)
|
||||||
await injectLinesOfCode(sarifFile, language, locPromise);
|
await injectLinesOfCode(sarifFile, language, locPromise);
|
||||||
statusReport[`interpret_results_${language}_duration_ms`] =
|
statusReport[`interpret_results_${language}_duration_ms`] =
|
||||||
new Date().getTime() - startTimeInterpretResults;
|
new Date().getTime() - startTimeInterpretResults;
|
||||||
logger.endGroup();
|
logger.endGroup();
|
||||||
logger.info(analysisSummary);
|
logger.info(analysisSummary);
|
||||||
if (!cliCanCountBaseline || countLocDebugMode)
|
if (!cliCanCountBaseline || debugMode)
|
||||||
printLinesOfCodeSummary(logger, language, await locPromise);
|
printLinesOfCodeSummary(logger, language, await locPromise);
|
||||||
if (cliCanCountBaseline)
|
if (cliCanCountBaseline)
|
||||||
logger.info(await runPrintLinesOfCode(language));
|
logger.info(await runPrintLinesOfCode(language));
|
||||||
@@ -194,10 +198,10 @@ async function runQueries(sarifFolder, memoryFlag, addSnippetsFlag, threadsFlag,
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
return statusReport;
|
return statusReport;
|
||||||
async function runInterpretResults(language, queries, sarifFile, enableDebugLogging) {
|
async function runInterpretResults(language, queries, sarifFile) {
|
||||||
const databasePath = util.getCodeQLDatabasePath(config, language);
|
const databasePath = util.getCodeQLDatabasePath(config, language);
|
||||||
const codeql = await (0, codeql_1.getCodeQL)(config.codeQLCmd);
|
const codeql = await (0, codeql_1.getCodeQL)(config.codeQLCmd);
|
||||||
return await codeql.databaseInterpretResults(databasePath, queries, sarifFile, addSnippetsFlag, threadsFlag, enableDebugLogging ? "-vv" : "-v", automationDetailsId);
|
return await codeql.databaseInterpretResults(databasePath, queries, sarifFile, addSnippetsFlag, threadsFlag, automationDetailsId);
|
||||||
}
|
}
|
||||||
async function cliCanCountLoC() {
|
async function cliCanCountLoC() {
|
||||||
return await util.codeQlVersionAbove(await (0, codeql_1.getCodeQL)(config.codeQLCmd), codeql_1.CODEQL_VERSION_COUNTS_LINES);
|
return await util.codeQlVersionAbove(await (0, codeql_1.getCodeQL)(config.codeQLCmd), codeql_1.CODEQL_VERSION_COUNTS_LINES);
|
||||||
@@ -219,24 +223,51 @@ async function runQueries(sarifFolder, memoryFlag, addSnippetsFlag, threadsFlag,
|
|||||||
logger.debug(`BQRS results produced for ${language} (queries: ${type})"`);
|
logger.debug(`BQRS results produced for ${language} (queries: ${type})"`);
|
||||||
return querySuitePath;
|
return querySuitePath;
|
||||||
}
|
}
|
||||||
async function runQueryPacks(language, type, packs, searchPath) {
|
async function runQueryPacks(language, type, packs, queryFilters) {
|
||||||
const databasePath = util.getCodeQLDatabasePath(config, language);
|
const databasePath = util.getCodeQLDatabasePath(config, language);
|
||||||
// Run the queries individually instead of all at once to avoid command
|
|
||||||
// line length restrictions, particularly on windows.
|
|
||||||
for (const pack of packs) {
|
for (const pack of packs) {
|
||||||
logger.debug(`Running query pack for ${language}-${type}: ${pack}`);
|
logger.debug(`Running query pack for ${language}-${type}: ${pack}`);
|
||||||
const codeql = await (0, codeql_1.getCodeQL)(config.codeQLCmd);
|
|
||||||
await codeql.databaseRunQueries(databasePath, searchPath, pack, memoryFlag, threadsFlag);
|
|
||||||
logger.debug(`BQRS results produced for ${language} (queries: ${type})"`);
|
|
||||||
}
|
}
|
||||||
return packs;
|
// combine the list of packs into a query suite in order to run them all simultaneously.
|
||||||
|
const querySuite = packs.map(convertPackToQuerySuiteEntry).concat(queryFilters);
|
||||||
|
const querySuitePath = `${databasePath}-queries-${type}.qls`;
|
||||||
|
fs.writeFileSync(querySuitePath, yaml.dump(querySuite));
|
||||||
|
logger.debug(`BQRS results produced for ${language} (queries: ${type})"`);
|
||||||
|
const codeql = await (0, codeql_1.getCodeQL)(config.codeQLCmd);
|
||||||
|
await codeql.databaseRunQueries(databasePath, undefined, querySuitePath, memoryFlag, threadsFlag);
|
||||||
|
return querySuitePath;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
exports.runQueries = runQueries;
|
exports.runQueries = runQueries;
|
||||||
function createQuerySuiteContents(queries) {
|
function convertPackToQuerySuiteEntry(packStr) {
|
||||||
return queries.map((q) => `- query: ${q}`).join("\n");
|
var _a, _b, _c, _d;
|
||||||
|
const pack = configUtils.parsePacksSpecification(packStr);
|
||||||
|
return {
|
||||||
|
qlpack: !pack.path ? pack.name : undefined,
|
||||||
|
from: pack.path ? pack.name : undefined,
|
||||||
|
version: pack.version,
|
||||||
|
query: ((_a = pack.path) === null || _a === void 0 ? void 0 : _a.endsWith(".ql")) ? pack.path : undefined,
|
||||||
|
queries: !((_b = pack.path) === null || _b === void 0 ? void 0 : _b.endsWith(".ql")) && !((_c = pack.path) === null || _c === void 0 ? void 0 : _c.endsWith(".qls"))
|
||||||
|
? pack.path
|
||||||
|
: undefined,
|
||||||
|
apply: ((_d = pack.path) === null || _d === void 0 ? void 0 : _d.endsWith(".qls")) ? pack.path : undefined,
|
||||||
|
};
|
||||||
}
|
}
|
||||||
async function runFinalize(outputDir, threadsFlag, memoryFlag, config, logger, featureFlags) {
|
exports.convertPackToQuerySuiteEntry = convertPackToQuerySuiteEntry;
|
||||||
|
function createQuerySuiteContents(queries, queryFilters) {
|
||||||
|
return yaml.dump(queries.map((q) => ({ query: q })).concat(queryFilters));
|
||||||
|
}
|
||||||
|
exports.createQuerySuiteContents = createQuerySuiteContents;
|
||||||
|
async function runFinalize(outputDir, threadsFlag, memoryFlag, config, logger) {
|
||||||
|
const codeql = await (0, codeql_1.getCodeQL)(config.codeQLCmd);
|
||||||
|
if (await util.codeQlVersionAbove(codeql, codeql_1.CODEQL_VERSION_NEW_TRACING)) {
|
||||||
|
// Delete variables as specified by the end-tracing script
|
||||||
|
await (0, tracer_config_1.endTracingForCluster)(config);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// Delete the tracer config env var to avoid tracing ourselves
|
||||||
|
delete process.env[sharedEnv.ODASA_TRACER_CONFIGURATION];
|
||||||
|
}
|
||||||
try {
|
try {
|
||||||
await (0, del_1.default)(outputDir, { force: true });
|
await (0, del_1.default)(outputDir, { force: true });
|
||||||
}
|
}
|
||||||
@@ -246,21 +277,7 @@ async function runFinalize(outputDir, threadsFlag, memoryFlag, config, logger, f
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
await fs.promises.mkdir(outputDir, { recursive: true });
|
await fs.promises.mkdir(outputDir, { recursive: true });
|
||||||
await finalizeDatabaseCreation(config, threadsFlag, memoryFlag, logger, featureFlags);
|
await finalizeDatabaseCreation(config, threadsFlag, memoryFlag, logger);
|
||||||
const codeql = await (0, codeql_1.getCodeQL)(config.codeQLCmd);
|
|
||||||
// WARNING: This does not _really_ end tracing, as the tracer will restore its
|
|
||||||
// critical environment variables and it'll still be active for all processes
|
|
||||||
// launched from this build step.
|
|
||||||
// However, it will stop tracing for all steps past the codeql-action/analyze
|
|
||||||
// step.
|
|
||||||
if (await util.codeQlVersionAbove(codeql, codeql_1.CODEQL_VERSION_NEW_TRACING)) {
|
|
||||||
// Delete variables as specified by the end-tracing script
|
|
||||||
await (0, tracer_config_1.endTracingForCluster)(config);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
// Delete the tracer config env var to avoid tracing ourselves
|
|
||||||
delete process.env[sharedEnv.ODASA_TRACER_CONFIGURATION];
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
exports.runFinalize = runFinalize;
|
exports.runFinalize = runFinalize;
|
||||||
async function runCleanup(config, cleanupLevel, logger) {
|
async function runCleanup(config, cleanupLevel, logger) {
|
||||||
@@ -301,4 +318,25 @@ function printLinesOfCodeSummary(logger, language, lineCounts) {
|
|||||||
logger.info(`Counted a baseline of ${lineCounts[language]} lines of code for ${language}.`);
|
logger.info(`Counted a baseline of ${lineCounts[language]} lines of code for ${language}.`);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
// exported for testing
|
||||||
|
function validateQueryFilters(queryFilters) {
|
||||||
|
if (!queryFilters) {
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
const errors = [];
|
||||||
|
for (const qf of queryFilters) {
|
||||||
|
const keys = Object.keys(qf);
|
||||||
|
if (keys.length !== 1) {
|
||||||
|
errors.push(`Query filter must have exactly one key: ${JSON.stringify(qf)}`);
|
||||||
|
}
|
||||||
|
if (!["exclude", "include"].includes(keys[0])) {
|
||||||
|
errors.push(`Only "include" or "exclude" filters are allowed:\n${JSON.stringify(qf)}`);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (errors.length) {
|
||||||
|
throw new Error(`Invalid query filter.\n${errors.join("\n")}`);
|
||||||
|
}
|
||||||
|
return queryFilters;
|
||||||
|
}
|
||||||
|
exports.validateQueryFilters = validateQueryFilters;
|
||||||
//# sourceMappingURL=analyze.js.map
|
//# sourceMappingURL=analyze.js.map
|
||||||
File diff suppressed because one or more lines are too long
200
lib/analyze.test.js
generated
200
lib/analyze.test.js
generated
@@ -29,9 +29,7 @@ const yaml = __importStar(require("js-yaml"));
|
|||||||
const sinon = __importStar(require("sinon"));
|
const sinon = __importStar(require("sinon"));
|
||||||
const analyze_1 = require("./analyze");
|
const analyze_1 = require("./analyze");
|
||||||
const codeql_1 = require("./codeql");
|
const codeql_1 = require("./codeql");
|
||||||
const codeql_test_1 = require("./codeql.test");
|
|
||||||
const count = __importStar(require("./count-loc"));
|
const count = __importStar(require("./count-loc"));
|
||||||
const feature_flags_1 = require("./feature-flags");
|
|
||||||
const languages_1 = require("./languages");
|
const languages_1 = require("./languages");
|
||||||
const logging_1 = require("./logging");
|
const logging_1 = require("./logging");
|
||||||
const testing_utils_1 = require("./testing-utils");
|
const testing_utils_1 = require("./testing-utils");
|
||||||
@@ -109,6 +107,7 @@ const util = __importStar(require("./util"));
|
|||||||
paths: [],
|
paths: [],
|
||||||
originalUserInput: {},
|
originalUserInput: {},
|
||||||
tempDir: tmpDir,
|
tempDir: tmpDir,
|
||||||
|
toolCacheDir: tmpDir,
|
||||||
codeQLCmd: "",
|
codeQLCmd: "",
|
||||||
gitHubVersion: {
|
gitHubVersion: {
|
||||||
type: util.GitHubVariant.DOTCOM,
|
type: util.GitHubVariant.DOTCOM,
|
||||||
@@ -211,71 +210,136 @@ const util = __importStar(require("./util"));
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
const stubConfig = {
|
(0, ava_1.default)("validateQueryFilters", (t) => {
|
||||||
languages: [languages_1.Language.cpp, languages_1.Language.go],
|
t.notThrows(() => (0, analyze_1.validateQueryFilters)([]));
|
||||||
queries: {},
|
t.notThrows(() => (0, analyze_1.validateQueryFilters)(undefined));
|
||||||
pathsIgnore: [],
|
t.notThrows(() => {
|
||||||
paths: [],
|
return (0, analyze_1.validateQueryFilters)([
|
||||||
originalUserInput: {},
|
{
|
||||||
tempDir: "",
|
exclude: {
|
||||||
codeQLCmd: "",
|
"problem.severity": "recommendation",
|
||||||
gitHubVersion: {
|
},
|
||||||
type: util.GitHubVariant.DOTCOM,
|
},
|
||||||
},
|
{
|
||||||
dbLocation: "",
|
exclude: {
|
||||||
packs: {},
|
"tags contain": ["foo", "bar"],
|
||||||
debugMode: false,
|
},
|
||||||
debugArtifactName: util.DEFAULT_DEBUG_ARTIFACT_NAME,
|
},
|
||||||
debugDatabaseName: util.DEFAULT_DEBUG_DATABASE_NAME,
|
{
|
||||||
injectedMlQueries: false,
|
include: {
|
||||||
};
|
"problem.severity": "something-to-think-about",
|
||||||
for (const options of [
|
},
|
||||||
{
|
},
|
||||||
name: "Lua feature flag enabled, but old CLI",
|
{
|
||||||
version: "2.9.0",
|
include: {
|
||||||
featureFlags: [feature_flags_1.FeatureFlag.LuaTracerConfigEnabled],
|
"tags contain": ["baz", "bop"],
|
||||||
yesFlagSet: false,
|
},
|
||||||
noFlagSet: false,
|
},
|
||||||
},
|
]);
|
||||||
{
|
|
||||||
name: "Lua feature flag disabled, with old CLI",
|
|
||||||
version: "2.9.0",
|
|
||||||
featureFlags: [],
|
|
||||||
yesFlagSet: false,
|
|
||||||
noFlagSet: false,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: "Lua feature flag enabled, with new CLI",
|
|
||||||
version: "2.10.0",
|
|
||||||
featureFlags: [feature_flags_1.FeatureFlag.LuaTracerConfigEnabled],
|
|
||||||
yesFlagSet: true,
|
|
||||||
noFlagSet: false,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
name: "Lua feature flag disabled, with new CLI",
|
|
||||||
version: "2.10.0",
|
|
||||||
featureFlags: [],
|
|
||||||
yesFlagSet: false,
|
|
||||||
noFlagSet: true,
|
|
||||||
},
|
|
||||||
]) {
|
|
||||||
(0, ava_1.default)(`createdDBForScannedLanguages() ${options.name}`, async (t) => {
|
|
||||||
const runnerConstructorStub = (0, codeql_test_1.stubToolRunnerConstructor)();
|
|
||||||
const codeqlObject = await (0, codeql_1.getCodeQLForTesting)("codeql/for-testing");
|
|
||||||
sinon.stub(codeqlObject, "getVersion").resolves(options.version);
|
|
||||||
const promise = (0, analyze_1.createdDBForScannedLanguages)(codeqlObject, stubConfig, (0, logging_1.getRunnerLogger)(true), (0, feature_flags_1.createFeatureFlags)(options.featureFlags));
|
|
||||||
// call listener on `codeql resolve extractor`
|
|
||||||
const mockToolRunner = runnerConstructorStub.getCall(0);
|
|
||||||
mockToolRunner.args[2].listeners.stdout('"/path/to/extractor"');
|
|
||||||
await promise;
|
|
||||||
if (options.yesFlagSet)
|
|
||||||
t.true(runnerConstructorStub.secondCall.args[1].includes("--internal-use-lua-tracing"), "--internal-use-lua-tracing should be present, but it is absent");
|
|
||||||
else
|
|
||||||
t.false(runnerConstructorStub.secondCall.args[1].includes("--internal-use-lua-tracing"), "--internal-use-lua-tracing should be absent, but it is present");
|
|
||||||
if (options.noFlagSet)
|
|
||||||
t.true(runnerConstructorStub.secondCall.args[1].includes("--no-internal-use-lua-tracing"), "--no-internal-use-lua-tracing should be present, but it is absent");
|
|
||||||
else
|
|
||||||
t.false(runnerConstructorStub.secondCall.args[1].includes("--no-internal-use-lua-tracing"), "--no-internal-use-lua-tracing should be absent, but it is present");
|
|
||||||
});
|
});
|
||||||
}
|
t.throws(() => {
|
||||||
|
return (0, analyze_1.validateQueryFilters)([
|
||||||
|
{
|
||||||
|
exclude: {
|
||||||
|
"tags contain": ["foo", "bar"],
|
||||||
|
},
|
||||||
|
include: {
|
||||||
|
"tags contain": ["baz", "bop"],
|
||||||
|
},
|
||||||
|
},
|
||||||
|
]);
|
||||||
|
}, { message: /Query filter must have exactly one key/ });
|
||||||
|
t.throws(() => {
|
||||||
|
return (0, analyze_1.validateQueryFilters)([{ xxx: "foo" }]);
|
||||||
|
}, { message: /Only "include" or "exclude" filters are allowed/ });
|
||||||
|
});
|
||||||
|
const convertPackToQuerySuiteEntryMacro = ava_1.default.macro({
|
||||||
|
exec: (t, packSpec, suiteEntry) => t.deepEqual((0, analyze_1.convertPackToQuerySuiteEntry)(packSpec), suiteEntry),
|
||||||
|
title: (_providedTitle, packSpec) => `Query Suite Entry: ${packSpec}`,
|
||||||
|
});
|
||||||
|
(0, ava_1.default)(convertPackToQuerySuiteEntryMacro, "a/b", {
|
||||||
|
qlpack: "a/b",
|
||||||
|
from: undefined,
|
||||||
|
version: undefined,
|
||||||
|
query: undefined,
|
||||||
|
queries: undefined,
|
||||||
|
apply: undefined,
|
||||||
|
});
|
||||||
|
(0, ava_1.default)(convertPackToQuerySuiteEntryMacro, "a/b@~1.2.3", {
|
||||||
|
qlpack: "a/b",
|
||||||
|
from: undefined,
|
||||||
|
version: "~1.2.3",
|
||||||
|
query: undefined,
|
||||||
|
queries: undefined,
|
||||||
|
apply: undefined,
|
||||||
|
});
|
||||||
|
(0, ava_1.default)(convertPackToQuerySuiteEntryMacro, "a/b:my/path", {
|
||||||
|
qlpack: undefined,
|
||||||
|
from: "a/b",
|
||||||
|
version: undefined,
|
||||||
|
query: undefined,
|
||||||
|
queries: "my/path",
|
||||||
|
apply: undefined,
|
||||||
|
});
|
||||||
|
(0, ava_1.default)(convertPackToQuerySuiteEntryMacro, "a/b@~1.2.3:my/path", {
|
||||||
|
qlpack: undefined,
|
||||||
|
from: "a/b",
|
||||||
|
version: "~1.2.3",
|
||||||
|
query: undefined,
|
||||||
|
queries: "my/path",
|
||||||
|
apply: undefined,
|
||||||
|
});
|
||||||
|
(0, ava_1.default)(convertPackToQuerySuiteEntryMacro, "a/b:my/path/query.ql", {
|
||||||
|
qlpack: undefined,
|
||||||
|
from: "a/b",
|
||||||
|
version: undefined,
|
||||||
|
query: "my/path/query.ql",
|
||||||
|
queries: undefined,
|
||||||
|
apply: undefined,
|
||||||
|
});
|
||||||
|
(0, ava_1.default)(convertPackToQuerySuiteEntryMacro, "a/b@~1.2.3:my/path/query.ql", {
|
||||||
|
qlpack: undefined,
|
||||||
|
from: "a/b",
|
||||||
|
version: "~1.2.3",
|
||||||
|
query: "my/path/query.ql",
|
||||||
|
queries: undefined,
|
||||||
|
apply: undefined,
|
||||||
|
});
|
||||||
|
(0, ava_1.default)(convertPackToQuerySuiteEntryMacro, "a/b:my/path/suite.qls", {
|
||||||
|
qlpack: undefined,
|
||||||
|
from: "a/b",
|
||||||
|
version: undefined,
|
||||||
|
query: undefined,
|
||||||
|
queries: undefined,
|
||||||
|
apply: "my/path/suite.qls",
|
||||||
|
});
|
||||||
|
(0, ava_1.default)(convertPackToQuerySuiteEntryMacro, "a/b@~1.2.3:my/path/suite.qls", {
|
||||||
|
qlpack: undefined,
|
||||||
|
from: "a/b",
|
||||||
|
version: "~1.2.3",
|
||||||
|
query: undefined,
|
||||||
|
queries: undefined,
|
||||||
|
apply: "my/path/suite.qls",
|
||||||
|
});
|
||||||
|
(0, ava_1.default)("convertPackToQuerySuiteEntry Failure", (t) => {
|
||||||
|
t.throws(() => (0, analyze_1.convertPackToQuerySuiteEntry)("this-is-not-a-pack"));
|
||||||
|
});
|
||||||
|
(0, ava_1.default)("createQuerySuiteContents", (t) => {
|
||||||
|
const yamlResult = (0, analyze_1.createQuerySuiteContents)(["query1.ql", "query2.ql"], [
|
||||||
|
{
|
||||||
|
exclude: { "problem.severity": "recommendation" },
|
||||||
|
},
|
||||||
|
{
|
||||||
|
include: { "problem.severity": "recommendation" },
|
||||||
|
},
|
||||||
|
]);
|
||||||
|
const expected = `- query: query1.ql
|
||||||
|
- query: query2.ql
|
||||||
|
- exclude:
|
||||||
|
problem.severity: recommendation
|
||||||
|
- include:
|
||||||
|
problem.severity: recommendation
|
||||||
|
`;
|
||||||
|
t.deepEqual(yamlResult, expected);
|
||||||
|
});
|
||||||
//# sourceMappingURL=analyze.test.js.map
|
//# sourceMappingURL=analyze.test.js.map
|
||||||
File diff suppressed because one or more lines are too long
44
lib/codeql.js
generated
44
lib/codeql.js
generated
@@ -26,17 +26,16 @@ exports.getExtraOptions = exports.getCodeQLForTesting = exports.getCachedCodeQL
|
|||||||
const fs = __importStar(require("fs"));
|
const fs = __importStar(require("fs"));
|
||||||
const path = __importStar(require("path"));
|
const path = __importStar(require("path"));
|
||||||
const toolrunner = __importStar(require("@actions/exec/lib/toolrunner"));
|
const toolrunner = __importStar(require("@actions/exec/lib/toolrunner"));
|
||||||
const toolcache = __importStar(require("@actions/tool-cache"));
|
|
||||||
const fast_deep_equal_1 = __importDefault(require("fast-deep-equal"));
|
const fast_deep_equal_1 = __importDefault(require("fast-deep-equal"));
|
||||||
const query_string_1 = __importDefault(require("query-string"));
|
const query_string_1 = __importDefault(require("query-string"));
|
||||||
const semver = __importStar(require("semver"));
|
const semver = __importStar(require("semver"));
|
||||||
const uuid_1 = require("uuid");
|
|
||||||
const actions_util_1 = require("./actions-util");
|
const actions_util_1 = require("./actions-util");
|
||||||
const api = __importStar(require("./api-client"));
|
const api = __importStar(require("./api-client"));
|
||||||
const defaults = __importStar(require("./defaults.json")); // Referenced from codeql-action-sync-tool!
|
const defaults = __importStar(require("./defaults.json")); // Referenced from codeql-action-sync-tool!
|
||||||
const error_matcher_1 = require("./error-matcher");
|
const error_matcher_1 = require("./error-matcher");
|
||||||
const feature_flags_1 = require("./feature-flags");
|
const feature_flags_1 = require("./feature-flags");
|
||||||
const languages_1 = require("./languages");
|
const languages_1 = require("./languages");
|
||||||
|
const toolcache = __importStar(require("./toolcache"));
|
||||||
const toolrunner_error_catcher_1 = require("./toolrunner-error-catcher");
|
const toolrunner_error_catcher_1 = require("./toolrunner-error-catcher");
|
||||||
const util = __importStar(require("./util"));
|
const util = __importStar(require("./util"));
|
||||||
const util_1 = require("./util");
|
const util_1 = require("./util");
|
||||||
@@ -78,7 +77,7 @@ const CODEQL_VERSION_SARIF_GROUP = "2.5.3";
|
|||||||
exports.CODEQL_VERSION_COUNTS_LINES = "2.6.2";
|
exports.CODEQL_VERSION_COUNTS_LINES = "2.6.2";
|
||||||
const CODEQL_VERSION_CUSTOM_QUERY_HELP = "2.7.1";
|
const CODEQL_VERSION_CUSTOM_QUERY_HELP = "2.7.1";
|
||||||
exports.CODEQL_VERSION_ML_POWERED_QUERIES = "2.7.5";
|
exports.CODEQL_VERSION_ML_POWERED_QUERIES = "2.7.5";
|
||||||
const CODEQL_VERSION_LUA_TRACER_CONFIG = "2.10.0";
|
const CODEQL_VERSION_LUA_TRACER_CONFIG = "2.9.3";
|
||||||
/**
|
/**
|
||||||
* This variable controls using the new style of tracing from the CodeQL
|
* This variable controls using the new style of tracing from the CodeQL
|
||||||
* CLI. In particular, with versions above this we will use both indirect
|
* CLI. In particular, with versions above this we will use both indirect
|
||||||
@@ -209,13 +208,14 @@ async function getCodeQLBundleDownloadURL(apiDetails, variant, logger) {
|
|||||||
* @param codeqlURL
|
* @param codeqlURL
|
||||||
* @param apiDetails
|
* @param apiDetails
|
||||||
* @param tempDir
|
* @param tempDir
|
||||||
|
* @param toolCacheDir
|
||||||
* @param variant
|
* @param variant
|
||||||
* @param logger
|
* @param logger
|
||||||
* @param checkVersion Whether to check that CodeQL CLI meets the minimum
|
* @param checkVersion Whether to check that CodeQL CLI meets the minimum
|
||||||
* version requirement. Must be set to true outside tests.
|
* version requirement. Must be set to true outside tests.
|
||||||
* @returns
|
* @returns
|
||||||
*/
|
*/
|
||||||
async function setupCodeQL(codeqlURL, apiDetails, tempDir, variant, logger, checkVersion) {
|
async function setupCodeQL(codeqlURL, apiDetails, tempDir, toolCacheDir, variant, logger, checkVersion) {
|
||||||
try {
|
try {
|
||||||
// We use the special value of 'latest' to prioritize the version in the
|
// We use the special value of 'latest' to prioritize the version in the
|
||||||
// defaults over any pinned cached version.
|
// defaults over any pinned cached version.
|
||||||
@@ -226,21 +226,21 @@ async function setupCodeQL(codeqlURL, apiDetails, tempDir, variant, logger, chec
|
|||||||
let codeqlFolder;
|
let codeqlFolder;
|
||||||
let codeqlURLVersion;
|
let codeqlURLVersion;
|
||||||
if (codeqlURL && !codeqlURL.startsWith("http")) {
|
if (codeqlURL && !codeqlURL.startsWith("http")) {
|
||||||
codeqlFolder = await toolcache.extractTar(codeqlURL);
|
codeqlFolder = await toolcache.extractTar(codeqlURL, tempDir, logger);
|
||||||
codeqlURLVersion = "local";
|
codeqlURLVersion = "local";
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
codeqlURLVersion = getCodeQLURLVersion(codeqlURL || `/${CODEQL_BUNDLE_VERSION}/`);
|
codeqlURLVersion = getCodeQLURLVersion(codeqlURL || `/${CODEQL_BUNDLE_VERSION}/`);
|
||||||
const codeqlURLSemVer = convertToSemVer(codeqlURLVersion, logger);
|
const codeqlURLSemVer = convertToSemVer(codeqlURLVersion, logger);
|
||||||
// If we find the specified version, we always use that.
|
// If we find the specified version, we always use that.
|
||||||
codeqlFolder = toolcache.find("CodeQL", codeqlURLSemVer);
|
codeqlFolder = toolcache.find("CodeQL", codeqlURLSemVer, toolCacheDir, logger);
|
||||||
// If we don't find the requested version, in some cases we may allow a
|
// If we don't find the requested version, in some cases we may allow a
|
||||||
// different version to save download time if the version hasn't been
|
// different version to save download time if the version hasn't been
|
||||||
// specified explicitly (in which case we always honor it).
|
// specified explicitly (in which case we always honor it).
|
||||||
if (!codeqlFolder && !codeqlURL && !forceLatest) {
|
if (!codeqlFolder && !codeqlURL && !forceLatest) {
|
||||||
const codeqlVersions = toolcache.findAllVersions("CodeQL");
|
const codeqlVersions = toolcache.findAllVersions("CodeQL", toolCacheDir, logger);
|
||||||
if (codeqlVersions.length === 1 && (0, util_1.isGoodVersion)(codeqlVersions[0])) {
|
if (codeqlVersions.length === 1 && (0, util_1.isGoodVersion)(codeqlVersions[0])) {
|
||||||
const tmpCodeqlFolder = toolcache.find("CodeQL", codeqlVersions[0]);
|
const tmpCodeqlFolder = toolcache.find("CodeQL", codeqlVersions[0], toolCacheDir, logger);
|
||||||
if (fs.existsSync(path.join(tmpCodeqlFolder, "pinned-version"))) {
|
if (fs.existsSync(path.join(tmpCodeqlFolder, "pinned-version"))) {
|
||||||
logger.debug(`CodeQL in cache overriding the default ${CODEQL_BUNDLE_VERSION}`);
|
logger.debug(`CodeQL in cache overriding the default ${CODEQL_BUNDLE_VERSION}`);
|
||||||
codeqlFolder = tmpCodeqlFolder;
|
codeqlFolder = tmpCodeqlFolder;
|
||||||
@@ -272,12 +272,10 @@ async function setupCodeQL(codeqlURL, apiDetails, tempDir, variant, logger, chec
|
|||||||
logger.debug("Downloading CodeQL bundle without token.");
|
logger.debug("Downloading CodeQL bundle without token.");
|
||||||
}
|
}
|
||||||
logger.info(`Downloading CodeQL tools from ${codeqlURL}. This may take a while.`);
|
logger.info(`Downloading CodeQL tools from ${codeqlURL}. This may take a while.`);
|
||||||
const dest = path.join(tempDir, (0, uuid_1.v4)());
|
const codeqlPath = await toolcache.downloadTool(codeqlURL, tempDir, headers);
|
||||||
const finalHeaders = Object.assign({ "User-Agent": "CodeQL Action" }, headers);
|
|
||||||
const codeqlPath = await toolcache.downloadTool(codeqlURL, dest, undefined, finalHeaders);
|
|
||||||
logger.debug(`CodeQL bundle download to ${codeqlPath} complete.`);
|
logger.debug(`CodeQL bundle download to ${codeqlPath} complete.`);
|
||||||
const codeqlExtracted = await toolcache.extractTar(codeqlPath);
|
const codeqlExtracted = await toolcache.extractTar(codeqlPath, tempDir, logger);
|
||||||
codeqlFolder = await toolcache.cacheDir(codeqlExtracted, "CodeQL", codeqlURLSemVer);
|
codeqlFolder = await toolcache.cacheDir(codeqlExtracted, "CodeQL", codeqlURLSemVer, toolCacheDir, logger);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
let codeqlCmd = path.join(codeqlFolder, "codeql", "codeql");
|
let codeqlCmd = path.join(codeqlFolder, "codeql", "codeql");
|
||||||
@@ -386,8 +384,8 @@ exports.getCachedCodeQL = getCachedCodeQL;
|
|||||||
* a non-existent placeholder codeql command, so tests that use this function
|
* a non-existent placeholder codeql command, so tests that use this function
|
||||||
* should also stub the toolrunner.ToolRunner constructor.
|
* should also stub the toolrunner.ToolRunner constructor.
|
||||||
*/
|
*/
|
||||||
async function getCodeQLForTesting(cmd = "codeql-for-testing") {
|
async function getCodeQLForTesting() {
|
||||||
return getCodeQLForCmd(cmd, false);
|
return getCodeQLForCmd("codeql-for-testing", false);
|
||||||
}
|
}
|
||||||
exports.getCodeQLForTesting = getCodeQLForTesting;
|
exports.getCodeQLForTesting = getCodeQLForTesting;
|
||||||
/**
|
/**
|
||||||
@@ -512,7 +510,7 @@ async function getCodeQLForCmd(cmd, checkVersion) {
|
|||||||
].join(" ");
|
].join(" ");
|
||||||
await runTool(autobuildCmd);
|
await runTool(autobuildCmd);
|
||||||
},
|
},
|
||||||
async extractScannedLanguage(databasePath, language, featureFlags) {
|
async extractScannedLanguage(databasePath, language) {
|
||||||
// Get extractor location
|
// Get extractor location
|
||||||
let extractorPath = "";
|
let extractorPath = "";
|
||||||
await new toolrunner.ToolRunner(cmd, [
|
await new toolrunner.ToolRunner(cmd, [
|
||||||
@@ -535,20 +533,10 @@ async function getCodeQLForCmd(cmd, checkVersion) {
|
|||||||
// Set trace command
|
// Set trace command
|
||||||
const ext = process.platform === "win32" ? ".cmd" : ".sh";
|
const ext = process.platform === "win32" ? ".cmd" : ".sh";
|
||||||
const traceCommand = path.resolve(JSON.parse(extractorPath), "tools", `autobuild${ext}`);
|
const traceCommand = path.resolve(JSON.parse(extractorPath), "tools", `autobuild${ext}`);
|
||||||
const extraArgs = [];
|
|
||||||
if (await util.codeQlVersionAbove(this, CODEQL_VERSION_LUA_TRACER_CONFIG)) {
|
|
||||||
if (await featureFlags.getValue(feature_flags_1.FeatureFlag.LuaTracerConfigEnabled)) {
|
|
||||||
extraArgs.push("--internal-use-lua-tracing");
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
extraArgs.push("--no-internal-use-lua-tracing");
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// Run trace command
|
// Run trace command
|
||||||
await (0, toolrunner_error_catcher_1.toolrunnerErrorCatcher)(cmd, [
|
await (0, toolrunner_error_catcher_1.toolrunnerErrorCatcher)(cmd, [
|
||||||
"database",
|
"database",
|
||||||
"trace-command",
|
"trace-command",
|
||||||
...extraArgs,
|
|
||||||
...getExtraOptionsFromEnv(["database", "trace-command"]),
|
...getExtraOptionsFromEnv(["database", "trace-command"]),
|
||||||
databasePath,
|
databasePath,
|
||||||
"--",
|
"--",
|
||||||
@@ -619,13 +607,13 @@ async function getCodeQLForCmd(cmd, checkVersion) {
|
|||||||
codeqlArgs.push(querySuitePath);
|
codeqlArgs.push(querySuitePath);
|
||||||
await runTool(cmd, codeqlArgs);
|
await runTool(cmd, codeqlArgs);
|
||||||
},
|
},
|
||||||
async databaseInterpretResults(databasePath, querySuitePaths, sarifFile, addSnippetsFlag, threadsFlag, verbosityFlag, automationDetailsId) {
|
async databaseInterpretResults(databasePath, querySuitePaths, sarifFile, addSnippetsFlag, threadsFlag, automationDetailsId) {
|
||||||
const codeqlArgs = [
|
const codeqlArgs = [
|
||||||
"database",
|
"database",
|
||||||
"interpret-results",
|
"interpret-results",
|
||||||
threadsFlag,
|
threadsFlag,
|
||||||
"--format=sarif-latest",
|
"--format=sarif-latest",
|
||||||
verbosityFlag,
|
"-v",
|
||||||
`--output=${sarifFile}`,
|
`--output=${sarifFile}`,
|
||||||
addSnippetsFlag,
|
addSnippetsFlag,
|
||||||
...getExtraOptionsFromEnv(["database", "interpret-results"]),
|
...getExtraOptionsFromEnv(["database", "interpret-results"]),
|
||||||
|
|||||||
File diff suppressed because one or more lines are too long
27
lib/codeql.test.js
generated
27
lib/codeql.test.js
generated
@@ -22,7 +22,6 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|||||||
return (mod && mod.__esModule) ? mod : { "default": mod };
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
||||||
};
|
};
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
exports.stubToolRunnerConstructor = void 0;
|
|
||||||
const path = __importStar(require("path"));
|
const path = __importStar(require("path"));
|
||||||
const toolrunner = __importStar(require("@actions/exec/lib/toolrunner"));
|
const toolrunner = __importStar(require("@actions/exec/lib/toolrunner"));
|
||||||
const toolcache = __importStar(require("@actions/tool-cache"));
|
const toolcache = __importStar(require("@actions/tool-cache"));
|
||||||
@@ -58,7 +57,7 @@ ava_1.default.beforeEach(() => {
|
|||||||
(0, nock_1.default)("https://example.com")
|
(0, nock_1.default)("https://example.com")
|
||||||
.get(`/download/codeql-bundle-${version}/codeql-bundle.tar.gz`)
|
.get(`/download/codeql-bundle-${version}/codeql-bundle.tar.gz`)
|
||||||
.replyWithFile(200, path.join(__dirname, `/../src/testdata/codeql-bundle.tar.gz`));
|
.replyWithFile(200, path.join(__dirname, `/../src/testdata/codeql-bundle.tar.gz`));
|
||||||
await codeql.setupCodeQL(`https://example.com/download/codeql-bundle-${version}/codeql-bundle.tar.gz`, sampleApiDetails, tmpDir, util.GitHubVariant.DOTCOM, (0, logging_1.getRunnerLogger)(true), false);
|
await codeql.setupCodeQL(`https://example.com/download/codeql-bundle-${version}/codeql-bundle.tar.gz`, sampleApiDetails, tmpDir, tmpDir, util.GitHubVariant.DOTCOM, (0, logging_1.getRunnerLogger)(true), false);
|
||||||
t.assert(toolcache.find("CodeQL", `0.0.0-${version}`));
|
t.assert(toolcache.find("CodeQL", `0.0.0-${version}`));
|
||||||
}
|
}
|
||||||
const cachedVersions = toolcache.findAllVersions("CodeQL");
|
const cachedVersions = toolcache.findAllVersions("CodeQL");
|
||||||
@@ -71,12 +70,12 @@ ava_1.default.beforeEach(() => {
|
|||||||
(0, nock_1.default)("https://example.com")
|
(0, nock_1.default)("https://example.com")
|
||||||
.get(`/download/codeql-bundle-20200601/codeql-bundle.tar.gz`)
|
.get(`/download/codeql-bundle-20200601/codeql-bundle.tar.gz`)
|
||||||
.replyWithFile(200, path.join(__dirname, `/../src/testdata/codeql-bundle-pinned.tar.gz`));
|
.replyWithFile(200, path.join(__dirname, `/../src/testdata/codeql-bundle-pinned.tar.gz`));
|
||||||
await codeql.setupCodeQL("https://example.com/download/codeql-bundle-20200601/codeql-bundle.tar.gz", sampleApiDetails, tmpDir, util.GitHubVariant.DOTCOM, (0, logging_1.getRunnerLogger)(true), false);
|
await codeql.setupCodeQL("https://example.com/download/codeql-bundle-20200601/codeql-bundle.tar.gz", sampleApiDetails, tmpDir, tmpDir, util.GitHubVariant.DOTCOM, (0, logging_1.getRunnerLogger)(true), false);
|
||||||
t.assert(toolcache.find("CodeQL", "0.0.0-20200601"));
|
t.assert(toolcache.find("CodeQL", "0.0.0-20200601"));
|
||||||
(0, nock_1.default)("https://example.com")
|
(0, nock_1.default)("https://example.com")
|
||||||
.get(`/download/codeql-bundle-20200610/codeql-bundle.tar.gz`)
|
.get(`/download/codeql-bundle-20200610/codeql-bundle.tar.gz`)
|
||||||
.replyWithFile(200, path.join(__dirname, `/../src/testdata/codeql-bundle.tar.gz`));
|
.replyWithFile(200, path.join(__dirname, `/../src/testdata/codeql-bundle.tar.gz`));
|
||||||
await codeql.setupCodeQL("https://example.com/download/codeql-bundle-20200610/codeql-bundle.tar.gz", sampleApiDetails, tmpDir, util.GitHubVariant.DOTCOM, (0, logging_1.getRunnerLogger)(true), false);
|
await codeql.setupCodeQL("https://example.com/download/codeql-bundle-20200610/codeql-bundle.tar.gz", sampleApiDetails, tmpDir, tmpDir, util.GitHubVariant.DOTCOM, (0, logging_1.getRunnerLogger)(true), false);
|
||||||
t.assert(toolcache.find("CodeQL", "0.0.0-20200610"));
|
t.assert(toolcache.find("CodeQL", "0.0.0-20200610"));
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
@@ -86,9 +85,9 @@ ava_1.default.beforeEach(() => {
|
|||||||
(0, nock_1.default)("https://example.com")
|
(0, nock_1.default)("https://example.com")
|
||||||
.get(`/download/codeql-bundle-20200601/codeql-bundle.tar.gz`)
|
.get(`/download/codeql-bundle-20200601/codeql-bundle.tar.gz`)
|
||||||
.replyWithFile(200, path.join(__dirname, `/../src/testdata/codeql-bundle-pinned.tar.gz`));
|
.replyWithFile(200, path.join(__dirname, `/../src/testdata/codeql-bundle-pinned.tar.gz`));
|
||||||
await codeql.setupCodeQL("https://example.com/download/codeql-bundle-20200601/codeql-bundle.tar.gz", sampleApiDetails, tmpDir, util.GitHubVariant.DOTCOM, (0, logging_1.getRunnerLogger)(true), false);
|
await codeql.setupCodeQL("https://example.com/download/codeql-bundle-20200601/codeql-bundle.tar.gz", sampleApiDetails, tmpDir, tmpDir, util.GitHubVariant.DOTCOM, (0, logging_1.getRunnerLogger)(true), false);
|
||||||
t.assert(toolcache.find("CodeQL", "0.0.0-20200601"));
|
t.assert(toolcache.find("CodeQL", "0.0.0-20200601"));
|
||||||
await codeql.setupCodeQL(undefined, sampleApiDetails, tmpDir, util.GitHubVariant.DOTCOM, (0, logging_1.getRunnerLogger)(true), false);
|
await codeql.setupCodeQL(undefined, sampleApiDetails, tmpDir, tmpDir, util.GitHubVariant.DOTCOM, (0, logging_1.getRunnerLogger)(true), false);
|
||||||
const cachedVersions = toolcache.findAllVersions("CodeQL");
|
const cachedVersions = toolcache.findAllVersions("CodeQL");
|
||||||
t.is(cachedVersions.length, 1);
|
t.is(cachedVersions.length, 1);
|
||||||
});
|
});
|
||||||
@@ -99,7 +98,7 @@ ava_1.default.beforeEach(() => {
|
|||||||
(0, nock_1.default)("https://example.com")
|
(0, nock_1.default)("https://example.com")
|
||||||
.get(`/download/codeql-bundle-20200601/codeql-bundle.tar.gz`)
|
.get(`/download/codeql-bundle-20200601/codeql-bundle.tar.gz`)
|
||||||
.replyWithFile(200, path.join(__dirname, `/../src/testdata/codeql-bundle.tar.gz`));
|
.replyWithFile(200, path.join(__dirname, `/../src/testdata/codeql-bundle.tar.gz`));
|
||||||
await codeql.setupCodeQL("https://example.com/download/codeql-bundle-20200601/codeql-bundle.tar.gz", sampleApiDetails, tmpDir, util.GitHubVariant.DOTCOM, (0, logging_1.getRunnerLogger)(true), false);
|
await codeql.setupCodeQL("https://example.com/download/codeql-bundle-20200601/codeql-bundle.tar.gz", sampleApiDetails, tmpDir, tmpDir, util.GitHubVariant.DOTCOM, (0, logging_1.getRunnerLogger)(true), false);
|
||||||
t.assert(toolcache.find("CodeQL", "0.0.0-20200601"));
|
t.assert(toolcache.find("CodeQL", "0.0.0-20200601"));
|
||||||
const platform = process.platform === "win32"
|
const platform = process.platform === "win32"
|
||||||
? "win64"
|
? "win64"
|
||||||
@@ -109,7 +108,7 @@ ava_1.default.beforeEach(() => {
|
|||||||
(0, nock_1.default)("https://github.com")
|
(0, nock_1.default)("https://github.com")
|
||||||
.get(`/github/codeql-action/releases/download/${defaults.bundleVersion}/codeql-bundle-${platform}.tar.gz`)
|
.get(`/github/codeql-action/releases/download/${defaults.bundleVersion}/codeql-bundle-${platform}.tar.gz`)
|
||||||
.replyWithFile(200, path.join(__dirname, `/../src/testdata/codeql-bundle.tar.gz`));
|
.replyWithFile(200, path.join(__dirname, `/../src/testdata/codeql-bundle.tar.gz`));
|
||||||
await codeql.setupCodeQL(undefined, sampleApiDetails, tmpDir, util.GitHubVariant.DOTCOM, (0, logging_1.getRunnerLogger)(true), false);
|
await codeql.setupCodeQL(undefined, sampleApiDetails, tmpDir, tmpDir, util.GitHubVariant.DOTCOM, (0, logging_1.getRunnerLogger)(true), false);
|
||||||
const cachedVersions = toolcache.findAllVersions("CodeQL");
|
const cachedVersions = toolcache.findAllVersions("CodeQL");
|
||||||
t.is(cachedVersions.length, 2);
|
t.is(cachedVersions.length, 2);
|
||||||
});
|
});
|
||||||
@@ -120,7 +119,7 @@ ava_1.default.beforeEach(() => {
|
|||||||
(0, nock_1.default)("https://example.com")
|
(0, nock_1.default)("https://example.com")
|
||||||
.get(`/download/codeql-bundle-20200601/codeql-bundle.tar.gz`)
|
.get(`/download/codeql-bundle-20200601/codeql-bundle.tar.gz`)
|
||||||
.replyWithFile(200, path.join(__dirname, `/../src/testdata/codeql-bundle-pinned.tar.gz`));
|
.replyWithFile(200, path.join(__dirname, `/../src/testdata/codeql-bundle-pinned.tar.gz`));
|
||||||
await codeql.setupCodeQL("https://example.com/download/codeql-bundle-20200601/codeql-bundle.tar.gz", sampleApiDetails, tmpDir, util.GitHubVariant.DOTCOM, (0, logging_1.getRunnerLogger)(true), false);
|
await codeql.setupCodeQL("https://example.com/download/codeql-bundle-20200601/codeql-bundle.tar.gz", sampleApiDetails, tmpDir, tmpDir, util.GitHubVariant.DOTCOM, (0, logging_1.getRunnerLogger)(true), false);
|
||||||
t.assert(toolcache.find("CodeQL", "0.0.0-20200601"));
|
t.assert(toolcache.find("CodeQL", "0.0.0-20200601"));
|
||||||
const platform = process.platform === "win32"
|
const platform = process.platform === "win32"
|
||||||
? "win64"
|
? "win64"
|
||||||
@@ -130,7 +129,7 @@ ava_1.default.beforeEach(() => {
|
|||||||
(0, nock_1.default)("https://github.com")
|
(0, nock_1.default)("https://github.com")
|
||||||
.get(`/github/codeql-action/releases/download/${defaults.bundleVersion}/codeql-bundle-${platform}.tar.gz`)
|
.get(`/github/codeql-action/releases/download/${defaults.bundleVersion}/codeql-bundle-${platform}.tar.gz`)
|
||||||
.replyWithFile(200, path.join(__dirname, `/../src/testdata/codeql-bundle.tar.gz`));
|
.replyWithFile(200, path.join(__dirname, `/../src/testdata/codeql-bundle.tar.gz`));
|
||||||
await codeql.setupCodeQL("latest", sampleApiDetails, tmpDir, util.GitHubVariant.DOTCOM, (0, logging_1.getRunnerLogger)(true), false);
|
await codeql.setupCodeQL("latest", sampleApiDetails, tmpDir, tmpDir, util.GitHubVariant.DOTCOM, (0, logging_1.getRunnerLogger)(true), false);
|
||||||
const cachedVersions = toolcache.findAllVersions("CodeQL");
|
const cachedVersions = toolcache.findAllVersions("CodeQL");
|
||||||
t.is(cachedVersions.length, 2);
|
t.is(cachedVersions.length, 2);
|
||||||
});
|
});
|
||||||
@@ -158,7 +157,7 @@ ava_1.default.beforeEach(() => {
|
|||||||
(0, nock_1.default)("https://example.githubenterprise.com")
|
(0, nock_1.default)("https://example.githubenterprise.com")
|
||||||
.get(`/github/codeql-action/releases/download/${defaults.bundleVersion}/${codeQLBundleName}`)
|
.get(`/github/codeql-action/releases/download/${defaults.bundleVersion}/${codeQLBundleName}`)
|
||||||
.replyWithFile(200, path.join(__dirname, `/../src/testdata/codeql-bundle-pinned.tar.gz`));
|
.replyWithFile(200, path.join(__dirname, `/../src/testdata/codeql-bundle-pinned.tar.gz`));
|
||||||
await codeql.setupCodeQL(undefined, sampleGHAEApiDetails, tmpDir, util.GitHubVariant.GHAE, (0, logging_1.getRunnerLogger)(true), false);
|
await codeql.setupCodeQL(undefined, sampleGHAEApiDetails, tmpDir, tmpDir, util.GitHubVariant.GHAE, (0, logging_1.getRunnerLogger)(true), false);
|
||||||
const cachedVersions = toolcache.findAllVersions("CodeQL");
|
const cachedVersions = toolcache.findAllVersions("CodeQL");
|
||||||
t.is(cachedVersions.length, 1);
|
t.is(cachedVersions.length, 1);
|
||||||
});
|
});
|
||||||
@@ -226,14 +225,14 @@ ava_1.default.beforeEach(() => {
|
|||||||
const runnerConstructorStub = stubToolRunnerConstructor();
|
const runnerConstructorStub = stubToolRunnerConstructor();
|
||||||
const codeqlObject = await codeql.getCodeQLForTesting();
|
const codeqlObject = await codeql.getCodeQLForTesting();
|
||||||
sinon.stub(codeqlObject, "getVersion").resolves("2.7.0");
|
sinon.stub(codeqlObject, "getVersion").resolves("2.7.0");
|
||||||
await codeqlObject.databaseInterpretResults("", [], "", "", "", "-v", "");
|
await codeqlObject.databaseInterpretResults("", [], "", "", "", "");
|
||||||
t.false(runnerConstructorStub.firstCall.args[1].includes("--sarif-add-query-help"), "--sarif-add-query-help should be absent, but it is present");
|
t.false(runnerConstructorStub.firstCall.args[1].includes("--sarif-add-query-help"), "--sarif-add-query-help should be absent, but it is present");
|
||||||
});
|
});
|
||||||
(0, ava_1.default)("databaseInterpretResults() sets --sarif-add-query-help for 2.7.1", async (t) => {
|
(0, ava_1.default)("databaseInterpretResults() sets --sarif-add-query-help for 2.7.1", async (t) => {
|
||||||
const runnerConstructorStub = stubToolRunnerConstructor();
|
const runnerConstructorStub = stubToolRunnerConstructor();
|
||||||
const codeqlObject = await codeql.getCodeQLForTesting();
|
const codeqlObject = await codeql.getCodeQLForTesting();
|
||||||
sinon.stub(codeqlObject, "getVersion").resolves("2.7.1");
|
sinon.stub(codeqlObject, "getVersion").resolves("2.7.1");
|
||||||
await codeqlObject.databaseInterpretResults("", [], "", "", "", "-v", "");
|
await codeqlObject.databaseInterpretResults("", [], "", "", "", "");
|
||||||
t.true(runnerConstructorStub.firstCall.args[1].includes("--sarif-add-query-help"), "--sarif-add-query-help should be present, but it is absent");
|
t.true(runnerConstructorStub.firstCall.args[1].includes("--sarif-add-query-help"), "--sarif-add-query-help should be present, but it is absent");
|
||||||
});
|
});
|
||||||
const stubConfig = {
|
const stubConfig = {
|
||||||
@@ -243,6 +242,7 @@ const stubConfig = {
|
|||||||
paths: [],
|
paths: [],
|
||||||
originalUserInput: {},
|
originalUserInput: {},
|
||||||
tempDir: "",
|
tempDir: "",
|
||||||
|
toolCacheDir: "",
|
||||||
codeQLCmd: "",
|
codeQLCmd: "",
|
||||||
gitHubVersion: {
|
gitHubVersion: {
|
||||||
type: util.GitHubVariant.DOTCOM,
|
type: util.GitHubVariant.DOTCOM,
|
||||||
@@ -291,5 +291,4 @@ function stubToolRunnerConstructor() {
|
|||||||
runnerConstructorStub.returns(runnerObjectStub);
|
runnerConstructorStub.returns(runnerObjectStub);
|
||||||
return runnerConstructorStub;
|
return runnerConstructorStub;
|
||||||
}
|
}
|
||||||
exports.stubToolRunnerConstructor = stubToolRunnerConstructor;
|
|
||||||
//# sourceMappingURL=codeql.test.js.map
|
//# sourceMappingURL=codeql.test.js.map
|
||||||
File diff suppressed because one or more lines are too long
72
lib/config-utils.js
generated
72
lib/config-utils.js
generated
@@ -19,7 +19,7 @@ var __importStar = (this && this.__importStar) || function (mod) {
|
|||||||
return result;
|
return result;
|
||||||
};
|
};
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
exports.getConfig = exports.getPathToParsedConfigFile = exports.initConfig = exports.parsePacks = exports.validatePacksSpecification = exports.parsePacksFromConfig = exports.getDefaultConfig = exports.getUnknownLanguagesError = exports.getNoLanguagesError = exports.getConfigFileDirectoryGivenMessage = exports.getConfigFileFormatInvalidMessage = exports.getConfigFileRepoFormatInvalidMessage = exports.getConfigFileDoesNotExistErrorMessage = exports.getConfigFileOutsideWorkspaceErrorMessage = exports.getLocalPathDoesNotExist = exports.getLocalPathOutsideOfRepository = exports.getPacksStrInvalid = exports.getPacksInvalid = exports.getPacksInvalidSplit = exports.getPathsInvalid = exports.getPathsIgnoreInvalid = exports.getQueryUsesInvalid = exports.getQueriesInvalid = exports.getDisableDefaultQueriesInvalid = exports.getNameInvalid = exports.validateAndSanitisePath = void 0;
|
exports.getConfig = exports.getPathToParsedConfigFile = exports.initConfig = exports.parsePacks = exports.validatePackSpecification = exports.prettyPrintPack = exports.parsePacksSpecification = exports.parsePacksFromConfig = exports.getDefaultConfig = exports.getUnknownLanguagesError = exports.getNoLanguagesError = exports.getConfigFileDirectoryGivenMessage = exports.getConfigFileFormatInvalidMessage = exports.getConfigFileRepoFormatInvalidMessage = exports.getConfigFileDoesNotExistErrorMessage = exports.getConfigFileOutsideWorkspaceErrorMessage = exports.getLocalPathDoesNotExist = exports.getLocalPathOutsideOfRepository = exports.getPacksStrInvalid = exports.getPacksInvalid = exports.getPacksInvalidSplit = exports.getPacksRequireLanguage = exports.getPathsInvalid = exports.getPathsIgnoreInvalid = exports.getQueryUsesInvalid = exports.getQueriesInvalid = exports.getDisableDefaultQueriesInvalid = exports.getNameInvalid = exports.validateAndSanitisePath = void 0;
|
||||||
const fs = __importStar(require("fs"));
|
const fs = __importStar(require("fs"));
|
||||||
const path = __importStar(require("path"));
|
const path = __importStar(require("path"));
|
||||||
const yaml = __importStar(require("js-yaml"));
|
const yaml = __importStar(require("js-yaml"));
|
||||||
@@ -150,9 +150,7 @@ async function addBuiltinSuiteQueries(languages, codeQL, resultMap, packs, suite
|
|||||||
return injectedMlQueries;
|
return injectedMlQueries;
|
||||||
}
|
}
|
||||||
function isMlPoweredJsQueriesPack(pack) {
|
function isMlPoweredJsQueriesPack(pack) {
|
||||||
return (pack === util_1.ML_POWERED_JS_QUERIES_PACK_NAME ||
|
return parsePacksSpecification(pack).name === util_1.ML_POWERED_JS_QUERIES_PACK_NAME;
|
||||||
pack.startsWith(`${util_1.ML_POWERED_JS_QUERIES_PACK_NAME}@`) ||
|
|
||||||
pack.startsWith(`${util_1.ML_POWERED_JS_QUERIES_PACK_NAME}:`));
|
|
||||||
}
|
}
|
||||||
/**
|
/**
|
||||||
* Retrieve the set of queries at localQueryPath and add them to resultMap.
|
* Retrieve the set of queries at localQueryPath and add them to resultMap.
|
||||||
@@ -306,8 +304,9 @@ function getPathsInvalid(configFile) {
|
|||||||
}
|
}
|
||||||
exports.getPathsInvalid = getPathsInvalid;
|
exports.getPathsInvalid = getPathsInvalid;
|
||||||
function getPacksRequireLanguage(lang, configFile) {
|
function getPacksRequireLanguage(lang, configFile) {
|
||||||
return getConfigFilePropertyError(configFile, PACKS_PROPERTY, `has "${lang}", but it is not a valid language.`);
|
return getConfigFilePropertyError(configFile, PACKS_PROPERTY, `has "${lang}", but it is not one of the languages to analyze`);
|
||||||
}
|
}
|
||||||
|
exports.getPacksRequireLanguage = getPacksRequireLanguage;
|
||||||
function getPacksInvalidSplit(configFile) {
|
function getPacksInvalidSplit(configFile) {
|
||||||
return getConfigFilePropertyError(configFile, PACKS_PROPERTY, "must split packages by language");
|
return getConfigFilePropertyError(configFile, PACKS_PROPERTY, "must split packages by language");
|
||||||
}
|
}
|
||||||
@@ -462,7 +461,7 @@ function shouldAddConfigFileQueries(queriesInput) {
|
|||||||
/**
|
/**
|
||||||
* Get the default config for when the user has not supplied one.
|
* Get the default config for when the user has not supplied one.
|
||||||
*/
|
*/
|
||||||
async function getDefaultConfig(languagesInput, queriesInput, packsInput, dbLocation, debugMode, debugArtifactName, debugDatabaseName, repository, tempDir, codeQL, workspacePath, gitHubVersion, apiDetails, featureFlags, logger) {
|
async function getDefaultConfig(languagesInput, queriesInput, packsInput, dbLocation, debugMode, debugArtifactName, debugDatabaseName, repository, tempDir, toolCacheDir, codeQL, workspacePath, gitHubVersion, apiDetails, featureFlags, logger) {
|
||||||
var _a;
|
var _a;
|
||||||
const languages = await getLanguages(codeQL, languagesInput, repository, apiDetails, logger);
|
const languages = await getLanguages(codeQL, languagesInput, repository, apiDetails, logger);
|
||||||
const queries = {};
|
const queries = {};
|
||||||
@@ -486,6 +485,7 @@ async function getDefaultConfig(languagesInput, queriesInput, packsInput, dbLoca
|
|||||||
packs,
|
packs,
|
||||||
originalUserInput: {},
|
originalUserInput: {},
|
||||||
tempDir,
|
tempDir,
|
||||||
|
toolCacheDir,
|
||||||
codeQLCmd: codeQL.getPath(),
|
codeQLCmd: codeQL.getPath(),
|
||||||
gitHubVersion,
|
gitHubVersion,
|
||||||
dbLocation: dbLocationOrDefault(dbLocation, tempDir),
|
dbLocation: dbLocationOrDefault(dbLocation, tempDir),
|
||||||
@@ -499,7 +499,7 @@ exports.getDefaultConfig = getDefaultConfig;
|
|||||||
/**
|
/**
|
||||||
* Load the config from the given file.
|
* Load the config from the given file.
|
||||||
*/
|
*/
|
||||||
async function loadConfig(languagesInput, queriesInput, packsInput, configFile, dbLocation, debugMode, debugArtifactName, debugDatabaseName, repository, tempDir, codeQL, workspacePath, gitHubVersion, apiDetails, featureFlags, logger) {
|
async function loadConfig(languagesInput, queriesInput, packsInput, configFile, dbLocation, debugMode, debugArtifactName, debugDatabaseName, repository, tempDir, toolCacheDir, codeQL, workspacePath, gitHubVersion, apiDetails, featureFlags, logger) {
|
||||||
var _a;
|
var _a;
|
||||||
let parsedYAML;
|
let parsedYAML;
|
||||||
if (isLocal(configFile)) {
|
if (isLocal(configFile)) {
|
||||||
@@ -540,7 +540,7 @@ async function loadConfig(languagesInput, queriesInput, packsInput, configFile,
|
|||||||
if (!disableDefaultQueries) {
|
if (!disableDefaultQueries) {
|
||||||
await addDefaultQueries(codeQL, languages, queries);
|
await addDefaultQueries(codeQL, languages, queries);
|
||||||
}
|
}
|
||||||
const packs = parsePacks((_a = parsedYAML[PACKS_PROPERTY]) !== null && _a !== void 0 ? _a : {}, packsInput, languages, configFile, logger);
|
const packs = parsePacks((_a = parsedYAML[PACKS_PROPERTY]) !== null && _a !== void 0 ? _a : {}, packsInput, languages, configFile);
|
||||||
// If queries were provided using `with` in the action configuration,
|
// If queries were provided using `with` in the action configuration,
|
||||||
// they should take precedence over the queries in the config file
|
// they should take precedence over the queries in the config file
|
||||||
// unless they're prefixed with "+", in which case they supplement those
|
// unless they're prefixed with "+", in which case they supplement those
|
||||||
@@ -593,6 +593,7 @@ async function loadConfig(languagesInput, queriesInput, packsInput, configFile,
|
|||||||
packs,
|
packs,
|
||||||
originalUserInput: parsedYAML,
|
originalUserInput: parsedYAML,
|
||||||
tempDir,
|
tempDir,
|
||||||
|
toolCacheDir,
|
||||||
codeQLCmd: codeQL.getPath(),
|
codeQLCmd: codeQL.getPath(),
|
||||||
gitHubVersion,
|
gitHubVersion,
|
||||||
dbLocation: dbLocationOrDefault(dbLocation, tempDir),
|
dbLocation: dbLocationOrDefault(dbLocation, tempDir),
|
||||||
@@ -613,7 +614,7 @@ const PACK_IDENTIFIER_PATTERN = (function () {
|
|||||||
return new RegExp(`^${component}/${component}$`);
|
return new RegExp(`^${component}/${component}$`);
|
||||||
})();
|
})();
|
||||||
// Exported for testing
|
// Exported for testing
|
||||||
function parsePacksFromConfig(packsByLanguage, languages, configFile, logger) {
|
function parsePacksFromConfig(packsByLanguage, languages, configFile) {
|
||||||
const packs = {};
|
const packs = {};
|
||||||
if (Array.isArray(packsByLanguage)) {
|
if (Array.isArray(packsByLanguage)) {
|
||||||
if (languages.length === 1) {
|
if (languages.length === 1) {
|
||||||
@@ -633,20 +634,9 @@ function parsePacksFromConfig(packsByLanguage, languages, configFile, logger) {
|
|||||||
throw new Error(getPacksInvalid(configFile));
|
throw new Error(getPacksInvalid(configFile));
|
||||||
}
|
}
|
||||||
if (!languages.includes(lang)) {
|
if (!languages.includes(lang)) {
|
||||||
// This particular language is not being analyzed in this run.
|
throw new Error(getPacksRequireLanguage(lang, configFile));
|
||||||
if (languages_1.Language[lang]) {
|
|
||||||
logger.info(`Ignoring packs for ${lang} since this language is not being analyzed in this run.`);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
// This language is invalid, probably a misspelling
|
|
||||||
throw new Error(getPacksRequireLanguage(configFile, lang));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
packs[lang] = [];
|
|
||||||
for (const packStr of packsArr) {
|
|
||||||
packs[lang].push(validatePacksSpecification(packStr, configFile));
|
|
||||||
}
|
}
|
||||||
|
packs[lang] = packsArr.map((packStr) => validatePackSpecification(packStr, configFile));
|
||||||
}
|
}
|
||||||
return packs;
|
return packs;
|
||||||
}
|
}
|
||||||
@@ -670,7 +660,7 @@ function parsePacksFromInput(packsInput, languages) {
|
|||||||
}
|
}
|
||||||
return {
|
return {
|
||||||
[languages[0]]: packsInput.split(",").reduce((packs, pack) => {
|
[languages[0]]: packsInput.split(",").reduce((packs, pack) => {
|
||||||
packs.push(validatePacksSpecification(pack, ""));
|
packs.push(validatePackSpecification(pack));
|
||||||
return packs;
|
return packs;
|
||||||
}, []),
|
}, []),
|
||||||
};
|
};
|
||||||
@@ -693,7 +683,7 @@ function parsePacksFromInput(packsInput, languages) {
|
|||||||
* @param packStr the package specification to verify.
|
* @param packStr the package specification to verify.
|
||||||
* @param configFile Config file to use for error reporting
|
* @param configFile Config file to use for error reporting
|
||||||
*/
|
*/
|
||||||
function validatePacksSpecification(packStr, configFile) {
|
function parsePacksSpecification(packStr, configFile) {
|
||||||
if (typeof packStr !== "string") {
|
if (typeof packStr !== "string") {
|
||||||
throw new Error(getPacksStrInvalid(packStr, configFile));
|
throw new Error(getPacksStrInvalid(packStr, configFile));
|
||||||
}
|
}
|
||||||
@@ -728,26 +718,32 @@ function validatePacksSpecification(packStr, configFile) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (packPath &&
|
if (packPath &&
|
||||||
(path.isAbsolute(packPath) ||
|
(path.isAbsolute(packPath) || path.normalize(packPath) !== packPath)) {
|
||||||
// Permit using "/" instead of "\" on Windows
|
|
||||||
// Use `x.split(y).join(z)` as a polyfill for `x.replaceAll(y, z)` since
|
|
||||||
// if we used a regex we'd need to escape the path separator on Windows
|
|
||||||
// which seems more awkward.
|
|
||||||
path.normalize(packPath).split(path.sep).join("/") !==
|
|
||||||
packPath.split(path.sep).join("/"))) {
|
|
||||||
throw new Error(getPacksStrInvalid(packStr, configFile));
|
throw new Error(getPacksStrInvalid(packStr, configFile));
|
||||||
}
|
}
|
||||||
if (!packPath && pathStart) {
|
if (!packPath && pathStart) {
|
||||||
// 0 length path
|
// 0 length path
|
||||||
throw new Error(getPacksStrInvalid(packStr, configFile));
|
throw new Error(getPacksStrInvalid(packStr, configFile));
|
||||||
}
|
}
|
||||||
return (packName + (version ? `@${version}` : "") + (packPath ? `:${packPath}` : ""));
|
return {
|
||||||
|
name: packName,
|
||||||
|
version,
|
||||||
|
path: packPath,
|
||||||
|
};
|
||||||
}
|
}
|
||||||
exports.validatePacksSpecification = validatePacksSpecification;
|
exports.parsePacksSpecification = parsePacksSpecification;
|
||||||
|
function prettyPrintPack(pack) {
|
||||||
|
return `${pack.name}${pack.version ? `@${pack.version}` : ""}${pack.path ? `:${pack.path}` : ""}`;
|
||||||
|
}
|
||||||
|
exports.prettyPrintPack = prettyPrintPack;
|
||||||
|
function validatePackSpecification(pack, configFile) {
|
||||||
|
return prettyPrintPack(parsePacksSpecification(pack, configFile));
|
||||||
|
}
|
||||||
|
exports.validatePackSpecification = validatePackSpecification;
|
||||||
// exported for testing
|
// exported for testing
|
||||||
function parsePacks(rawPacksFromConfig, rawPacksInput, languages, configFile, logger) {
|
function parsePacks(rawPacksFromConfig, rawPacksInput, languages, configFile) {
|
||||||
const packsFromInput = parsePacksFromInput(rawPacksInput, languages);
|
const packsFromInput = parsePacksFromInput(rawPacksInput, languages);
|
||||||
const packsFomConfig = parsePacksFromConfig(rawPacksFromConfig, languages, configFile, logger);
|
const packsFomConfig = parsePacksFromConfig(rawPacksFromConfig, languages, configFile);
|
||||||
if (!packsFromInput) {
|
if (!packsFromInput) {
|
||||||
return packsFomConfig;
|
return packsFomConfig;
|
||||||
}
|
}
|
||||||
@@ -781,16 +777,16 @@ function dbLocationOrDefault(dbLocation, tempDir) {
|
|||||||
* This will parse the config from the user input if present, or generate
|
* This will parse the config from the user input if present, or generate
|
||||||
* a default config. The parsed config is then stored to a known location.
|
* a default config. The parsed config is then stored to a known location.
|
||||||
*/
|
*/
|
||||||
async function initConfig(languagesInput, queriesInput, packsInput, configFile, dbLocation, debugMode, debugArtifactName, debugDatabaseName, repository, tempDir, codeQL, workspacePath, gitHubVersion, apiDetails, featureFlags, logger) {
|
async function initConfig(languagesInput, queriesInput, packsInput, configFile, dbLocation, debugMode, debugArtifactName, debugDatabaseName, repository, tempDir, toolCacheDir, codeQL, workspacePath, gitHubVersion, apiDetails, featureFlags, logger) {
|
||||||
var _a, _b, _c;
|
var _a, _b, _c;
|
||||||
let config;
|
let config;
|
||||||
// If no config file was provided create an empty one
|
// If no config file was provided create an empty one
|
||||||
if (!configFile) {
|
if (!configFile) {
|
||||||
logger.debug("No configuration file was provided");
|
logger.debug("No configuration file was provided");
|
||||||
config = await getDefaultConfig(languagesInput, queriesInput, packsInput, dbLocation, debugMode, debugArtifactName, debugDatabaseName, repository, tempDir, codeQL, workspacePath, gitHubVersion, apiDetails, featureFlags, logger);
|
config = await getDefaultConfig(languagesInput, queriesInput, packsInput, dbLocation, debugMode, debugArtifactName, debugDatabaseName, repository, tempDir, toolCacheDir, codeQL, workspacePath, gitHubVersion, apiDetails, featureFlags, logger);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
config = await loadConfig(languagesInput, queriesInput, packsInput, configFile, dbLocation, debugMode, debugArtifactName, debugDatabaseName, repository, tempDir, codeQL, workspacePath, gitHubVersion, apiDetails, featureFlags, logger);
|
config = await loadConfig(languagesInput, queriesInput, packsInput, configFile, dbLocation, debugMode, debugArtifactName, debugDatabaseName, repository, tempDir, toolCacheDir, codeQL, workspacePath, gitHubVersion, apiDetails, featureFlags, logger);
|
||||||
}
|
}
|
||||||
// The list of queries should not be empty for any language. If it is then
|
// The list of queries should not be empty for any language. If it is then
|
||||||
// it is a user configuration error.
|
// it is a user configuration error.
|
||||||
|
|||||||
File diff suppressed because one or more lines are too long
147
lib/config-utils.test.js
generated
147
lib/config-utils.test.js
generated
@@ -88,8 +88,8 @@ function mockListLanguages(languages) {
|
|||||||
};
|
};
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
const config = await configUtils.initConfig(languages, undefined, undefined, undefined, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), logger);
|
const config = await configUtils.initConfig(languages, undefined, undefined, undefined, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), logger);
|
||||||
t.deepEqual(config, await configUtils.getDefaultConfig(languages, undefined, undefined, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), logger));
|
t.deepEqual(config, await configUtils.getDefaultConfig(languages, undefined, undefined, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), logger));
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
(0, ava_1.default)("loading config saves config", async (t) => {
|
(0, ava_1.default)("loading config saves config", async (t) => {
|
||||||
@@ -111,7 +111,7 @@ function mockListLanguages(languages) {
|
|||||||
t.false(fs.existsSync(configUtils.getPathToParsedConfigFile(tmpDir)));
|
t.false(fs.existsSync(configUtils.getPathToParsedConfigFile(tmpDir)));
|
||||||
// Sanity check that getConfig returns undefined before we have called initConfig
|
// Sanity check that getConfig returns undefined before we have called initConfig
|
||||||
t.deepEqual(await configUtils.getConfig(tmpDir, logger), undefined);
|
t.deepEqual(await configUtils.getConfig(tmpDir, logger), undefined);
|
||||||
const config1 = await configUtils.initConfig("javascript,python", undefined, undefined, undefined, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), logger);
|
const config1 = await configUtils.initConfig("javascript,python", undefined, undefined, undefined, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), logger);
|
||||||
// The saved config file should now exist
|
// The saved config file should now exist
|
||||||
t.true(fs.existsSync(configUtils.getPathToParsedConfigFile(tmpDir)));
|
t.true(fs.existsSync(configUtils.getPathToParsedConfigFile(tmpDir)));
|
||||||
// And that same newly-initialised config should now be returned by getConfig
|
// And that same newly-initialised config should now be returned by getConfig
|
||||||
@@ -125,7 +125,7 @@ function mockListLanguages(languages) {
|
|||||||
(0, ava_1.default)("load input outside of workspace", async (t) => {
|
(0, ava_1.default)("load input outside of workspace", async (t) => {
|
||||||
return await util.withTmpDir(async (tmpDir) => {
|
return await util.withTmpDir(async (tmpDir) => {
|
||||||
try {
|
try {
|
||||||
await configUtils.initConfig(undefined, undefined, undefined, "../input", undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, (0, codeql_1.getCachedCodeQL)(), tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
await configUtils.initConfig(undefined, undefined, undefined, "../input", undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, tmpDir, (0, codeql_1.getCachedCodeQL)(), tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
||||||
throw new Error("initConfig did not throw error");
|
throw new Error("initConfig did not throw error");
|
||||||
}
|
}
|
||||||
catch (err) {
|
catch (err) {
|
||||||
@@ -138,7 +138,7 @@ function mockListLanguages(languages) {
|
|||||||
// no filename given, just a repo
|
// no filename given, just a repo
|
||||||
const configFile = "octo-org/codeql-config@main";
|
const configFile = "octo-org/codeql-config@main";
|
||||||
try {
|
try {
|
||||||
await configUtils.initConfig(undefined, undefined, undefined, configFile, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, (0, codeql_1.getCachedCodeQL)(), tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
await configUtils.initConfig(undefined, undefined, undefined, configFile, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, tmpDir, (0, codeql_1.getCachedCodeQL)(), tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
||||||
throw new Error("initConfig did not throw error");
|
throw new Error("initConfig did not throw error");
|
||||||
}
|
}
|
||||||
catch (err) {
|
catch (err) {
|
||||||
@@ -152,7 +152,7 @@ function mockListLanguages(languages) {
|
|||||||
const configFile = "input";
|
const configFile = "input";
|
||||||
t.false(fs.existsSync(path.join(tmpDir, configFile)));
|
t.false(fs.existsSync(path.join(tmpDir, configFile)));
|
||||||
try {
|
try {
|
||||||
await configUtils.initConfig(languages, undefined, undefined, configFile, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, (0, codeql_1.getCachedCodeQL)(), tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
await configUtils.initConfig(languages, undefined, undefined, configFile, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, tmpDir, (0, codeql_1.getCachedCodeQL)(), tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
||||||
throw new Error("initConfig did not throw error");
|
throw new Error("initConfig did not throw error");
|
||||||
}
|
}
|
||||||
catch (err) {
|
catch (err) {
|
||||||
@@ -212,6 +212,7 @@ function mockListLanguages(languages) {
|
|||||||
paths: ["c/d"],
|
paths: ["c/d"],
|
||||||
},
|
},
|
||||||
tempDir: tmpDir,
|
tempDir: tmpDir,
|
||||||
|
toolCacheDir: tmpDir,
|
||||||
codeQLCmd: codeQL.getPath(),
|
codeQLCmd: codeQL.getPath(),
|
||||||
gitHubVersion,
|
gitHubVersion,
|
||||||
dbLocation: path.resolve(tmpDir, "codeql_databases"),
|
dbLocation: path.resolve(tmpDir, "codeql_databases"),
|
||||||
@@ -223,7 +224,7 @@ function mockListLanguages(languages) {
|
|||||||
};
|
};
|
||||||
const languages = "javascript";
|
const languages = "javascript";
|
||||||
const configFilePath = createConfigFile(inputFileContents, tmpDir);
|
const configFilePath = createConfigFile(inputFileContents, tmpDir);
|
||||||
const actualConfig = await configUtils.initConfig(languages, undefined, undefined, configFilePath, undefined, false, "my-artifact", "my-db", { owner: "github", repo: "example " }, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
const actualConfig = await configUtils.initConfig(languages, undefined, undefined, configFilePath, undefined, false, "my-artifact", "my-db", { owner: "github", repo: "example " }, tmpDir, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
||||||
// Should exactly equal the object we constructed earlier
|
// Should exactly equal the object we constructed earlier
|
||||||
t.deepEqual(actualConfig, expectedConfig);
|
t.deepEqual(actualConfig, expectedConfig);
|
||||||
});
|
});
|
||||||
@@ -259,7 +260,7 @@ function mockListLanguages(languages) {
|
|||||||
fs.mkdirSync(path.join(tmpDir, "foo"));
|
fs.mkdirSync(path.join(tmpDir, "foo"));
|
||||||
const languages = "javascript";
|
const languages = "javascript";
|
||||||
const configFilePath = createConfigFile(inputFileContents, tmpDir);
|
const configFilePath = createConfigFile(inputFileContents, tmpDir);
|
||||||
await configUtils.initConfig(languages, undefined, undefined, configFilePath, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
await configUtils.initConfig(languages, undefined, undefined, configFilePath, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
||||||
// Check resolve queries was called correctly
|
// Check resolve queries was called correctly
|
||||||
t.deepEqual(resolveQueriesArgs.length, 1);
|
t.deepEqual(resolveQueriesArgs.length, 1);
|
||||||
t.deepEqual(resolveQueriesArgs[0].queries, [
|
t.deepEqual(resolveQueriesArgs[0].queries, [
|
||||||
@@ -302,18 +303,18 @@ function queriesToResolvedQueryForm(queries) {
|
|||||||
},
|
},
|
||||||
});
|
});
|
||||||
const languages = "javascript";
|
const languages = "javascript";
|
||||||
const config = await configUtils.initConfig(languages, undefined, undefined, configFilePath, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
const config = await configUtils.initConfig(languages, undefined, undefined, configFilePath, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
||||||
// Check resolveQueries was called correctly
|
// Check resolveQueries was called correctly
|
||||||
// It'll be called once for the default queries
|
// It'll be called once for the default queries
|
||||||
// and once for `./foo` from the config file.
|
// and once for `./foo` from the config file.
|
||||||
t.deepEqual(resolveQueriesArgs.length, 2);
|
t.deepEqual(resolveQueriesArgs.length, 2);
|
||||||
t.deepEqual(resolveQueriesArgs[1].queries.length, 1);
|
t.deepEqual(resolveQueriesArgs[1].queries.length, 1);
|
||||||
t.true(resolveQueriesArgs[1].queries[0].endsWith(`${path.sep}foo`));
|
t.regex(resolveQueriesArgs[1].queries[0], /.*\/foo$/);
|
||||||
// Now check that the end result contains the default queries and the query from config
|
// Now check that the end result contains the default queries and the query from config
|
||||||
t.deepEqual(config.queries["javascript"].builtin.length, 1);
|
t.deepEqual(config.queries["javascript"].builtin.length, 1);
|
||||||
t.deepEqual(config.queries["javascript"].custom.length, 1);
|
t.deepEqual(config.queries["javascript"].custom.length, 1);
|
||||||
t.true(config.queries["javascript"].builtin[0].endsWith("javascript-code-scanning.qls"));
|
t.regex(config.queries["javascript"].builtin[0], /javascript-code-scanning.qls$/);
|
||||||
t.true(config.queries["javascript"].custom[0].queries[0].endsWith(`${path.sep}foo`));
|
t.regex(config.queries["javascript"].custom[0].queries[0], /.*\/foo$/);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
(0, ava_1.default)("Queries from config file can be overridden in workflow file", async (t) => {
|
(0, ava_1.default)("Queries from config file can be overridden in workflow file", async (t) => {
|
||||||
@@ -335,18 +336,18 @@ function queriesToResolvedQueryForm(queries) {
|
|||||||
},
|
},
|
||||||
});
|
});
|
||||||
const languages = "javascript";
|
const languages = "javascript";
|
||||||
const config = await configUtils.initConfig(languages, testQueries, undefined, configFilePath, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
const config = await configUtils.initConfig(languages, testQueries, undefined, configFilePath, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
||||||
// Check resolveQueries was called correctly
|
// Check resolveQueries was called correctly
|
||||||
// It'll be called once for the default queries and once for `./override`,
|
// It'll be called once for the default queries and once for `./override`,
|
||||||
// but won't be called for './foo' from the config file.
|
// but won't be called for './foo' from the config file.
|
||||||
t.deepEqual(resolveQueriesArgs.length, 2);
|
t.deepEqual(resolveQueriesArgs.length, 2);
|
||||||
t.deepEqual(resolveQueriesArgs[1].queries.length, 1);
|
t.deepEqual(resolveQueriesArgs[1].queries.length, 1);
|
||||||
t.true(resolveQueriesArgs[1].queries[0].endsWith(`${path.sep}override`));
|
t.regex(resolveQueriesArgs[1].queries[0], /.*\/override$/);
|
||||||
// Now check that the end result contains only the default queries and the override query
|
// Now check that the end result contains only the default queries and the override query
|
||||||
t.deepEqual(config.queries["javascript"].builtin.length, 1);
|
t.deepEqual(config.queries["javascript"].builtin.length, 1);
|
||||||
t.deepEqual(config.queries["javascript"].custom.length, 1);
|
t.deepEqual(config.queries["javascript"].custom.length, 1);
|
||||||
t.true(config.queries["javascript"].builtin[0].endsWith("javascript-code-scanning.qls"));
|
t.regex(config.queries["javascript"].builtin[0], /javascript-code-scanning.qls$/);
|
||||||
t.true(config.queries["javascript"].custom[0].queries[0].endsWith(`${path.sep}override`));
|
t.regex(config.queries["javascript"].custom[0].queries[0], /.*\/override$/);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
(0, ava_1.default)("Queries in workflow file can be used in tandem with the 'disable default queries' option", async (t) => {
|
(0, ava_1.default)("Queries in workflow file can be used in tandem with the 'disable default queries' option", async (t) => {
|
||||||
@@ -367,17 +368,17 @@ function queriesToResolvedQueryForm(queries) {
|
|||||||
},
|
},
|
||||||
});
|
});
|
||||||
const languages = "javascript";
|
const languages = "javascript";
|
||||||
const config = await configUtils.initConfig(languages, testQueries, undefined, configFilePath, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
const config = await configUtils.initConfig(languages, testQueries, undefined, configFilePath, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
||||||
// Check resolveQueries was called correctly
|
// Check resolveQueries was called correctly
|
||||||
// It'll be called once for `./workflow-query`,
|
// It'll be called once for `./workflow-query`,
|
||||||
// but won't be called for the default one since that was disabled
|
// but won't be called for the default one since that was disabled
|
||||||
t.deepEqual(resolveQueriesArgs.length, 1);
|
t.deepEqual(resolveQueriesArgs.length, 1);
|
||||||
t.deepEqual(resolveQueriesArgs[0].queries.length, 1);
|
t.deepEqual(resolveQueriesArgs[0].queries.length, 1);
|
||||||
t.true(resolveQueriesArgs[0].queries[0].endsWith(`${path.sep}workflow-query`));
|
t.regex(resolveQueriesArgs[0].queries[0], /.*\/workflow-query$/);
|
||||||
// Now check that the end result contains only the workflow query, and not the default one
|
// Now check that the end result contains only the workflow query, and not the default one
|
||||||
t.deepEqual(config.queries["javascript"].builtin.length, 0);
|
t.deepEqual(config.queries["javascript"].builtin.length, 0);
|
||||||
t.deepEqual(config.queries["javascript"].custom.length, 1);
|
t.deepEqual(config.queries["javascript"].custom.length, 1);
|
||||||
t.true(config.queries["javascript"].custom[0].queries[0].endsWith(`${path.sep}workflow-query`));
|
t.regex(config.queries["javascript"].custom[0].queries[0], /.*\/workflow-query$/);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
(0, ava_1.default)("Multiple queries can be specified in workflow file, no config file required", async (t) => {
|
(0, ava_1.default)("Multiple queries can be specified in workflow file, no config file required", async (t) => {
|
||||||
@@ -393,21 +394,21 @@ function queriesToResolvedQueryForm(queries) {
|
|||||||
},
|
},
|
||||||
});
|
});
|
||||||
const languages = "javascript";
|
const languages = "javascript";
|
||||||
const config = await configUtils.initConfig(languages, testQueries, undefined, undefined, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
const config = await configUtils.initConfig(languages, testQueries, undefined, undefined, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
||||||
// Check resolveQueries was called correctly:
|
// Check resolveQueries was called correctly:
|
||||||
// It'll be called once for the default queries,
|
// It'll be called once for the default queries,
|
||||||
// and then once for each of the two queries from the workflow
|
// and then once for each of the two queries from the workflow
|
||||||
t.deepEqual(resolveQueriesArgs.length, 3);
|
t.deepEqual(resolveQueriesArgs.length, 3);
|
||||||
t.deepEqual(resolveQueriesArgs[1].queries.length, 1);
|
t.deepEqual(resolveQueriesArgs[1].queries.length, 1);
|
||||||
t.deepEqual(resolveQueriesArgs[2].queries.length, 1);
|
t.deepEqual(resolveQueriesArgs[2].queries.length, 1);
|
||||||
t.true(resolveQueriesArgs[1].queries[0].endsWith(`${path.sep}override1`));
|
t.regex(resolveQueriesArgs[1].queries[0], /.*\/override1$/);
|
||||||
t.true(resolveQueriesArgs[2].queries[0].endsWith(`${path.sep}override2`));
|
t.regex(resolveQueriesArgs[2].queries[0], /.*\/override2$/);
|
||||||
// Now check that the end result contains both the queries from the workflow, as well as the defaults
|
// Now check that the end result contains both the queries from the workflow, as well as the defaults
|
||||||
t.deepEqual(config.queries["javascript"].builtin.length, 1);
|
t.deepEqual(config.queries["javascript"].builtin.length, 1);
|
||||||
t.deepEqual(config.queries["javascript"].custom.length, 2);
|
t.deepEqual(config.queries["javascript"].custom.length, 2);
|
||||||
t.true(config.queries["javascript"].builtin[0].endsWith("javascript-code-scanning.qls"));
|
t.regex(config.queries["javascript"].builtin[0], /javascript-code-scanning.qls$/);
|
||||||
t.true(config.queries["javascript"].custom[0].queries[0].endsWith(`${path.sep}override1`));
|
t.regex(config.queries["javascript"].custom[0].queries[0], /.*\/override1$/);
|
||||||
t.true(config.queries["javascript"].custom[1].queries[0].endsWith(`${path.sep}override2`));
|
t.regex(config.queries["javascript"].custom[1].queries[0], /.*\/override2$/);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
(0, ava_1.default)("Queries in workflow file can be added to the set of queries without overriding config file", async (t) => {
|
(0, ava_1.default)("Queries in workflow file can be added to the set of queries without overriding config file", async (t) => {
|
||||||
@@ -432,25 +433,25 @@ function queriesToResolvedQueryForm(queries) {
|
|||||||
},
|
},
|
||||||
});
|
});
|
||||||
const languages = "javascript";
|
const languages = "javascript";
|
||||||
const config = await configUtils.initConfig(languages, testQueries, undefined, configFilePath, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
const config = await configUtils.initConfig(languages, testQueries, undefined, configFilePath, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
||||||
// Check resolveQueries was called correctly
|
// Check resolveQueries was called correctly
|
||||||
// It'll be called once for the default queries,
|
// It'll be called once for the default queries,
|
||||||
// once for each of additional1 and additional2,
|
// once for each of additional1 and additional2,
|
||||||
// and once for './foo' from the config file
|
// and once for './foo' from the config file
|
||||||
t.deepEqual(resolveQueriesArgs.length, 4);
|
t.deepEqual(resolveQueriesArgs.length, 4);
|
||||||
t.deepEqual(resolveQueriesArgs[1].queries.length, 1);
|
t.deepEqual(resolveQueriesArgs[1].queries.length, 1);
|
||||||
t.true(resolveQueriesArgs[1].queries[0].endsWith(`${path.sep}additional1`));
|
t.regex(resolveQueriesArgs[1].queries[0], /.*\/additional1$/);
|
||||||
t.deepEqual(resolveQueriesArgs[2].queries.length, 1);
|
t.deepEqual(resolveQueriesArgs[2].queries.length, 1);
|
||||||
t.true(resolveQueriesArgs[2].queries[0].endsWith(`${path.sep}additional2`));
|
t.regex(resolveQueriesArgs[2].queries[0], /.*\/additional2$/);
|
||||||
t.deepEqual(resolveQueriesArgs[3].queries.length, 1);
|
t.deepEqual(resolveQueriesArgs[3].queries.length, 1);
|
||||||
t.true(resolveQueriesArgs[3].queries[0].endsWith(`${path.sep}foo`));
|
t.regex(resolveQueriesArgs[3].queries[0], /.*\/foo$/);
|
||||||
// Now check that the end result contains all the queries
|
// Now check that the end result contains all the queries
|
||||||
t.deepEqual(config.queries["javascript"].builtin.length, 1);
|
t.deepEqual(config.queries["javascript"].builtin.length, 1);
|
||||||
t.deepEqual(config.queries["javascript"].custom.length, 3);
|
t.deepEqual(config.queries["javascript"].custom.length, 3);
|
||||||
t.true(config.queries["javascript"].builtin[0].endsWith("javascript-code-scanning.qls"));
|
t.regex(config.queries["javascript"].builtin[0], /javascript-code-scanning.qls$/);
|
||||||
t.true(config.queries["javascript"].custom[0].queries[0].endsWith(`${path.sep}additional1`));
|
t.regex(config.queries["javascript"].custom[0].queries[0], /.*\/additional1$/);
|
||||||
t.true(config.queries["javascript"].custom[1].queries[0].endsWith(`${path.sep}additional2`));
|
t.regex(config.queries["javascript"].custom[1].queries[0], /.*\/additional2$/);
|
||||||
t.true(config.queries["javascript"].custom[2].queries[0].endsWith(`${path.sep}foo`));
|
t.regex(config.queries["javascript"].custom[2].queries[0], /.*\/foo$/);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
(0, ava_1.default)("Invalid queries in workflow file handled correctly", async (t) => {
|
(0, ava_1.default)("Invalid queries in workflow file handled correctly", async (t) => {
|
||||||
@@ -471,7 +472,7 @@ function queriesToResolvedQueryForm(queries) {
|
|||||||
},
|
},
|
||||||
});
|
});
|
||||||
try {
|
try {
|
||||||
await configUtils.initConfig(languages, queries, undefined, undefined, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
await configUtils.initConfig(languages, queries, undefined, undefined, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
||||||
t.fail("initConfig did not throw error");
|
t.fail("initConfig did not throw error");
|
||||||
}
|
}
|
||||||
catch (err) {
|
catch (err) {
|
||||||
@@ -514,7 +515,7 @@ function queriesToResolvedQueryForm(queries) {
|
|||||||
fs.mkdirSync(path.join(tmpDir, "foo/bar/dev"), { recursive: true });
|
fs.mkdirSync(path.join(tmpDir, "foo/bar/dev"), { recursive: true });
|
||||||
const configFile = "octo-org/codeql-config/config.yaml@main";
|
const configFile = "octo-org/codeql-config/config.yaml@main";
|
||||||
const languages = "javascript";
|
const languages = "javascript";
|
||||||
await configUtils.initConfig(languages, undefined, undefined, configFile, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
await configUtils.initConfig(languages, undefined, undefined, configFile, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
||||||
t.assert(spyGetContents.called);
|
t.assert(spyGetContents.called);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
@@ -524,7 +525,7 @@ function queriesToResolvedQueryForm(queries) {
|
|||||||
mockGetContents(dummyResponse);
|
mockGetContents(dummyResponse);
|
||||||
const repoReference = "octo-org/codeql-config/config.yaml@main";
|
const repoReference = "octo-org/codeql-config/config.yaml@main";
|
||||||
try {
|
try {
|
||||||
await configUtils.initConfig(undefined, undefined, undefined, repoReference, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, (0, codeql_1.getCachedCodeQL)(), tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
await configUtils.initConfig(undefined, undefined, undefined, repoReference, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, tmpDir, (0, codeql_1.getCachedCodeQL)(), tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
||||||
throw new Error("initConfig did not throw error");
|
throw new Error("initConfig did not throw error");
|
||||||
}
|
}
|
||||||
catch (err) {
|
catch (err) {
|
||||||
@@ -540,7 +541,7 @@ function queriesToResolvedQueryForm(queries) {
|
|||||||
mockGetContents(dummyResponse);
|
mockGetContents(dummyResponse);
|
||||||
const repoReference = "octo-org/codeql-config/config.yaml@main";
|
const repoReference = "octo-org/codeql-config/config.yaml@main";
|
||||||
try {
|
try {
|
||||||
await configUtils.initConfig(undefined, undefined, undefined, repoReference, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, (0, codeql_1.getCachedCodeQL)(), tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
await configUtils.initConfig(undefined, undefined, undefined, repoReference, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, tmpDir, (0, codeql_1.getCachedCodeQL)(), tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
||||||
throw new Error("initConfig did not throw error");
|
throw new Error("initConfig did not throw error");
|
||||||
}
|
}
|
||||||
catch (err) {
|
catch (err) {
|
||||||
@@ -557,7 +558,7 @@ function queriesToResolvedQueryForm(queries) {
|
|||||||
},
|
},
|
||||||
});
|
});
|
||||||
try {
|
try {
|
||||||
await configUtils.initConfig(undefined, undefined, undefined, undefined, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
await configUtils.initConfig(undefined, undefined, undefined, undefined, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
||||||
throw new Error("initConfig did not throw error");
|
throw new Error("initConfig did not throw error");
|
||||||
}
|
}
|
||||||
catch (err) {
|
catch (err) {
|
||||||
@@ -569,7 +570,7 @@ function queriesToResolvedQueryForm(queries) {
|
|||||||
return await util.withTmpDir(async (tmpDir) => {
|
return await util.withTmpDir(async (tmpDir) => {
|
||||||
const languages = "rubbish,english";
|
const languages = "rubbish,english";
|
||||||
try {
|
try {
|
||||||
await configUtils.initConfig(languages, undefined, undefined, undefined, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, (0, codeql_1.getCachedCodeQL)(), tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
await configUtils.initConfig(languages, undefined, undefined, undefined, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, tmpDir, (0, codeql_1.getCachedCodeQL)(), tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
||||||
throw new Error("initConfig did not throw error");
|
throw new Error("initConfig did not throw error");
|
||||||
}
|
}
|
||||||
catch (err) {
|
catch (err) {
|
||||||
@@ -597,7 +598,7 @@ function queriesToResolvedQueryForm(queries) {
|
|||||||
const configFile = path.join(tmpDir, "codeql-config.yaml");
|
const configFile = path.join(tmpDir, "codeql-config.yaml");
|
||||||
fs.writeFileSync(configFile, inputFileContents);
|
fs.writeFileSync(configFile, inputFileContents);
|
||||||
const languages = "javascript";
|
const languages = "javascript";
|
||||||
const { packs } = await configUtils.initConfig(languages, undefined, undefined, configFile, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
const { packs } = await configUtils.initConfig(languages, undefined, undefined, configFile, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
||||||
t.deepEqual(packs, {
|
t.deepEqual(packs, {
|
||||||
[languages_1.Language.javascript]: ["a/b@1.2.3"],
|
[languages_1.Language.javascript]: ["a/b@1.2.3"],
|
||||||
});
|
});
|
||||||
@@ -631,7 +632,7 @@ function queriesToResolvedQueryForm(queries) {
|
|||||||
fs.writeFileSync(configFile, inputFileContents);
|
fs.writeFileSync(configFile, inputFileContents);
|
||||||
fs.mkdirSync(path.join(tmpDir, "foo"));
|
fs.mkdirSync(path.join(tmpDir, "foo"));
|
||||||
const languages = "javascript,python,cpp";
|
const languages = "javascript,python,cpp";
|
||||||
const { packs, queries } = await configUtils.initConfig(languages, undefined, undefined, configFile, undefined, false, "", "", { owner: "github", repo: "example" }, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
const { packs, queries } = await configUtils.initConfig(languages, undefined, undefined, configFile, undefined, false, "", "", { owner: "github", repo: "example" }, tmpDir, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
||||||
t.deepEqual(packs, {
|
t.deepEqual(packs, {
|
||||||
[languages_1.Language.javascript]: ["a/b@1.2.3"],
|
[languages_1.Language.javascript]: ["a/b@1.2.3"],
|
||||||
[languages_1.Language.python]: ["c/d@1.2.3"],
|
[languages_1.Language.python]: ["c/d@1.2.3"],
|
||||||
@@ -674,7 +675,7 @@ function doInvalidInputTest(testName, inputFileContents, expectedErrorMessageGen
|
|||||||
const inputFile = path.join(tmpDir, configFile);
|
const inputFile = path.join(tmpDir, configFile);
|
||||||
fs.writeFileSync(inputFile, inputFileContents, "utf8");
|
fs.writeFileSync(inputFile, inputFileContents, "utf8");
|
||||||
try {
|
try {
|
||||||
await configUtils.initConfig(languages, undefined, undefined, configFile, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
await configUtils.initConfig(languages, undefined, undefined, configFile, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)([]), (0, logging_1.getRunnerLogger)(true));
|
||||||
throw new Error("initConfig did not throw error");
|
throw new Error("initConfig did not throw error");
|
||||||
}
|
}
|
||||||
catch (err) {
|
catch (err) {
|
||||||
@@ -748,14 +749,14 @@ const invalidPaths = ["a/***/b", "a/**b", "a/b**", "**"];
|
|||||||
* Test macro for ensuring the packs block is valid
|
* Test macro for ensuring the packs block is valid
|
||||||
*/
|
*/
|
||||||
const parsePacksMacro = ava_1.default.macro({
|
const parsePacksMacro = ava_1.default.macro({
|
||||||
exec: (t, packsByLanguage, languages, expected) => t.deepEqual(configUtils.parsePacksFromConfig(packsByLanguage, languages, "/a/b", mockLogger), expected),
|
exec: (t, packsByLanguage, languages, expected) => t.deepEqual(configUtils.parsePacksFromConfig(packsByLanguage, languages, "/a/b"), expected),
|
||||||
title: (providedTitle = "") => `Parse Packs: ${providedTitle}`,
|
title: (providedTitle = "") => `Parse Packs: ${providedTitle}`,
|
||||||
});
|
});
|
||||||
/**
|
/**
|
||||||
* Test macro for testing when the packs block is invalid
|
* Test macro for testing when the packs block is invalid
|
||||||
*/
|
*/
|
||||||
const parsePacksErrorMacro = ava_1.default.macro({
|
const parsePacksErrorMacro = ava_1.default.macro({
|
||||||
exec: (t, packsByLanguage, languages, expected) => t.throws(() => configUtils.parsePacksFromConfig(packsByLanguage, languages, "/a/b", {}), {
|
exec: (t, packsByLanguage, languages, expected) => t.throws(() => configUtils.parsePacksFromConfig(packsByLanguage, languages, "/a/b"), {
|
||||||
message: expected,
|
message: expected,
|
||||||
}),
|
}),
|
||||||
title: (providedTitle = "") => `Parse Packs Error: ${providedTitle}`,
|
title: (providedTitle = "") => `Parse Packs Error: ${providedTitle}`,
|
||||||
@@ -781,12 +782,6 @@ const invalidPackNameMacro = ava_1.default.macro({
|
|||||||
[languages_1.Language.cpp]: ["a/b", "c/d@1.2.3"],
|
[languages_1.Language.cpp]: ["a/b", "c/d@1.2.3"],
|
||||||
[languages_1.Language.java]: ["d/e", "f/g@1.2.3"],
|
[languages_1.Language.java]: ["d/e", "f/g@1.2.3"],
|
||||||
});
|
});
|
||||||
(0, ava_1.default)("two packs with unused language in config", parsePacksMacro, {
|
|
||||||
[languages_1.Language.cpp]: ["a/b", "c/d@1.2.3"],
|
|
||||||
[languages_1.Language.java]: ["d/e", "f/g@1.2.3"],
|
|
||||||
}, [languages_1.Language.cpp, languages_1.Language.csharp], {
|
|
||||||
[languages_1.Language.cpp]: ["a/b", "c/d@1.2.3"],
|
|
||||||
});
|
|
||||||
(0, ava_1.default)("packs with other valid names", parsePacksMacro, [
|
(0, ava_1.default)("packs with other valid names", parsePacksMacro, [
|
||||||
// ranges are ok
|
// ranges are ok
|
||||||
"c/d@1.0",
|
"c/d@1.0",
|
||||||
@@ -819,6 +814,7 @@ const invalidPackNameMacro = ava_1.default.macro({
|
|||||||
],
|
],
|
||||||
});
|
});
|
||||||
(0, ava_1.default)("no language", parsePacksErrorMacro, ["a/b@1.2.3"], [languages_1.Language.java, languages_1.Language.python], /The configuration file "\/a\/b" is invalid: property "packs" must split packages by language/);
|
(0, ava_1.default)("no language", parsePacksErrorMacro, ["a/b@1.2.3"], [languages_1.Language.java, languages_1.Language.python], /The configuration file "\/a\/b" is invalid: property "packs" must split packages by language/);
|
||||||
|
(0, ava_1.default)("invalid language", parsePacksErrorMacro, { [languages_1.Language.java]: ["c/d"] }, [languages_1.Language.cpp], /The configuration file "\/a\/b" is invalid: property "packs" has "java", but it is not one of the languages to analyze/);
|
||||||
(0, ava_1.default)("not an array", parsePacksErrorMacro, { [languages_1.Language.cpp]: "c/d" }, [languages_1.Language.cpp], /The configuration file "\/a\/b" is invalid: property "packs" must be an array of non-empty strings/);
|
(0, ava_1.default)("not an array", parsePacksErrorMacro, { [languages_1.Language.cpp]: "c/d" }, [languages_1.Language.cpp], /The configuration file "\/a\/b" is invalid: property "packs" must be an array of non-empty strings/);
|
||||||
(0, ava_1.default)(invalidPackNameMacro, "c"); // all packs require at least a scope and a name
|
(0, ava_1.default)(invalidPackNameMacro, "c"); // all packs require at least a scope and a name
|
||||||
(0, ava_1.default)(invalidPackNameMacro, "c-/d");
|
(0, ava_1.default)(invalidPackNameMacro, "c-/d");
|
||||||
@@ -832,21 +828,56 @@ const invalidPackNameMacro = ava_1.default.macro({
|
|||||||
(0, ava_1.default)(invalidPackNameMacro, "c/d@../a");
|
(0, ava_1.default)(invalidPackNameMacro, "c/d@../a");
|
||||||
(0, ava_1.default)(invalidPackNameMacro, "c/d@b/../a");
|
(0, ava_1.default)(invalidPackNameMacro, "c/d@b/../a");
|
||||||
(0, ava_1.default)(invalidPackNameMacro, "c/d:z@1");
|
(0, ava_1.default)(invalidPackNameMacro, "c/d:z@1");
|
||||||
|
/**
|
||||||
|
* Test macro for pretty printing pack specs
|
||||||
|
*/
|
||||||
|
const packSpecPrettyPrintingMacro = ava_1.default.macro({
|
||||||
|
exec: (t, packStr, packObj) => {
|
||||||
|
const parsed = configUtils.parsePacksSpecification(packStr);
|
||||||
|
t.deepEqual(parsed, packObj, "parsed pack spec is correct");
|
||||||
|
const stringified = configUtils.prettyPrintPack(packObj);
|
||||||
|
t.deepEqual(stringified, packStr.trim(), "pretty-printed pack spec is correct");
|
||||||
|
t.deepEqual(configUtils.validatePackSpecification(packStr), packStr.trim(), "pack spec is valid");
|
||||||
|
},
|
||||||
|
title: (_providedTitle, packStr,
|
||||||
|
// eslint-disable-next-line @typescript-eslint/no-unused-vars
|
||||||
|
_packObj) => `Prettyprint pack spec: '${packStr}'`,
|
||||||
|
});
|
||||||
|
(0, ava_1.default)(packSpecPrettyPrintingMacro, "a/b", {
|
||||||
|
name: "a/b",
|
||||||
|
version: undefined,
|
||||||
|
path: undefined,
|
||||||
|
});
|
||||||
|
(0, ava_1.default)(packSpecPrettyPrintingMacro, "a/b@~1.2.3", {
|
||||||
|
name: "a/b",
|
||||||
|
version: "~1.2.3",
|
||||||
|
path: undefined,
|
||||||
|
});
|
||||||
|
(0, ava_1.default)(packSpecPrettyPrintingMacro, "a/b@~1.2.3:abc/def", {
|
||||||
|
name: "a/b",
|
||||||
|
version: "~1.2.3",
|
||||||
|
path: "abc/def",
|
||||||
|
});
|
||||||
|
(0, ava_1.default)(packSpecPrettyPrintingMacro, "a/b:abc/def", {
|
||||||
|
name: "a/b",
|
||||||
|
version: undefined,
|
||||||
|
path: "abc/def",
|
||||||
|
});
|
||||||
|
(0, ava_1.default)(packSpecPrettyPrintingMacro, " a/b:abc/def ", {
|
||||||
|
name: "a/b",
|
||||||
|
version: undefined,
|
||||||
|
path: "abc/def",
|
||||||
|
});
|
||||||
/**
|
/**
|
||||||
* Test macro for testing the packs block and the packs input
|
* Test macro for testing the packs block and the packs input
|
||||||
*/
|
*/
|
||||||
function parseInputAndConfigMacro(t, packsFromConfig, packsFromInput, languages, expected) {
|
function parseInputAndConfigMacro(t, packsFromConfig, packsFromInput, languages, expected) {
|
||||||
t.deepEqual(configUtils.parsePacks(packsFromConfig, packsFromInput, languages, "/a/b", mockLogger), expected);
|
t.deepEqual(configUtils.parsePacks(packsFromConfig, packsFromInput, languages, "/a/b"), expected);
|
||||||
}
|
}
|
||||||
parseInputAndConfigMacro.title = (providedTitle) => `Parse Packs input and config: ${providedTitle}`;
|
parseInputAndConfigMacro.title = (providedTitle) => `Parse Packs input and config: ${providedTitle}`;
|
||||||
const mockLogger = {
|
|
||||||
info: (message) => {
|
|
||||||
console.log(message);
|
|
||||||
},
|
|
||||||
};
|
|
||||||
function parseInputAndConfigErrorMacro(t, packsFromConfig, packsFromInput, languages, expected) {
|
function parseInputAndConfigErrorMacro(t, packsFromConfig, packsFromInput, languages, expected) {
|
||||||
t.throws(() => {
|
t.throws(() => {
|
||||||
configUtils.parsePacks(packsFromConfig, packsFromInput, languages, "/a/b", mockLogger);
|
configUtils.parsePacks(packsFromConfig, packsFromInput, languages, "/a/b");
|
||||||
}, {
|
}, {
|
||||||
message: expected,
|
message: expected,
|
||||||
});
|
});
|
||||||
@@ -891,7 +922,7 @@ const mlPoweredQueriesMacro = ava_1.default.macro({
|
|||||||
};
|
};
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
const { packs } = await configUtils.initConfig("javascript", queriesInput, packsInput, undefined, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)(isMlPoweredQueriesFlagEnabled
|
const { packs } = await configUtils.initConfig("javascript", queriesInput, packsInput, undefined, undefined, false, "", "", { owner: "github", repo: "example " }, tmpDir, tmpDir, codeQL, tmpDir, gitHubVersion, sampleApiDetails, (0, feature_flags_1.createFeatureFlags)(isMlPoweredQueriesFlagEnabled
|
||||||
? [feature_flags_1.FeatureFlag.MlPoweredQueriesEnabled]
|
? [feature_flags_1.FeatureFlag.MlPoweredQueriesEnabled]
|
||||||
: []), (0, logging_1.getRunnerLogger)(true));
|
: []), (0, logging_1.getRunnerLogger)(true));
|
||||||
if (expectedVersionString !== undefined) {
|
if (expectedVersionString !== undefined) {
|
||||||
|
|||||||
File diff suppressed because one or more lines are too long
1
lib/database-upload.test.js
generated
1
lib/database-upload.test.js
generated
@@ -50,6 +50,7 @@ function getTestConfig(tmpDir) {
|
|||||||
paths: [],
|
paths: [],
|
||||||
originalUserInput: {},
|
originalUserInput: {},
|
||||||
tempDir: tmpDir,
|
tempDir: tmpDir,
|
||||||
|
toolCacheDir: tmpDir,
|
||||||
codeQLCmd: "foo",
|
codeQLCmd: "foo",
|
||||||
gitHubVersion: { type: util_1.GitHubVariant.DOTCOM },
|
gitHubVersion: { type: util_1.GitHubVariant.DOTCOM },
|
||||||
dbLocation: tmpDir,
|
dbLocation: tmpDir,
|
||||||
|
|||||||
File diff suppressed because one or more lines are too long
@@ -1,3 +1,3 @@
|
|||||||
{
|
{
|
||||||
"bundleVersion": "codeql-bundle-20220623"
|
"bundleVersion": "codeql-bundle-20220615"
|
||||||
}
|
}
|
||||||
|
|||||||
3
lib/fingerprints.js
generated
3
lib/fingerprints.js
generated
@@ -24,7 +24,6 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
exports.addFingerprints = exports.resolveUriToFile = exports.hash = void 0;
|
exports.addFingerprints = exports.resolveUriToFile = exports.hash = void 0;
|
||||||
const fs = __importStar(require("fs"));
|
const fs = __importStar(require("fs"));
|
||||||
const path_1 = __importDefault(require("path"));
|
|
||||||
const long_1 = __importDefault(require("long"));
|
const long_1 = __importDefault(require("long"));
|
||||||
const tab = "\t".charCodeAt(0);
|
const tab = "\t".charCodeAt(0);
|
||||||
const space = " ".charCodeAt(0);
|
const space = " ".charCodeAt(0);
|
||||||
@@ -210,7 +209,7 @@ function resolveUriToFile(location, artifacts, sourceRoot, logger) {
|
|||||||
// Just assume a relative path is relative to the src root.
|
// Just assume a relative path is relative to the src root.
|
||||||
// This is not necessarily true but should be a good approximation
|
// This is not necessarily true but should be a good approximation
|
||||||
// and here we likely want to err on the side of handling more cases.
|
// and here we likely want to err on the side of handling more cases.
|
||||||
if (!path_1.default.isAbsolute(uri)) {
|
if (!uri.startsWith("/")) {
|
||||||
uri = srcRootPrefix + uri;
|
uri = srcRootPrefix + uri;
|
||||||
}
|
}
|
||||||
// Check the file exists
|
// Check the file exists
|
||||||
|
|||||||
File diff suppressed because one or more lines are too long
14
lib/fingerprints.test.js
generated
14
lib/fingerprints.test.js
generated
@@ -131,22 +131,20 @@ function testResolveUriToFile(uri, index, artifactsURIs) {
|
|||||||
return fingerprints.resolveUriToFile(location, artifacts, process.cwd(), (0, logging_1.getRunnerLogger)(true));
|
return fingerprints.resolveUriToFile(location, artifacts, process.cwd(), (0, logging_1.getRunnerLogger)(true));
|
||||||
}
|
}
|
||||||
(0, ava_1.default)("resolveUriToFile", (t) => {
|
(0, ava_1.default)("resolveUriToFile", (t) => {
|
||||||
var _a, _b;
|
|
||||||
// The resolveUriToFile method checks that the file exists and is in the right directory
|
// The resolveUriToFile method checks that the file exists and is in the right directory
|
||||||
// so we need to give it real files to look at. We will use this file as an example.
|
// so we need to give it real files to look at. We will use this file as an example.
|
||||||
// For this to work we require the current working directory to be a parent, but this
|
// For this to work we require the current working directory to be a parent, but this
|
||||||
// should generally always be the case so this is fine.
|
// should generally always be the case so this is fine.
|
||||||
const filepath = __filename.split(path.sep).join("/");
|
const cwd = process.cwd();
|
||||||
const relativeFilepath = path
|
const filepath = __filename;
|
||||||
.relative(process.cwd(), __filename)
|
t.true(filepath.startsWith(`${cwd}/`));
|
||||||
.split(path.sep)
|
const relativeFilepath = filepath.substring(cwd.length + 1);
|
||||||
.join("/");
|
|
||||||
// Absolute paths are unmodified
|
// Absolute paths are unmodified
|
||||||
t.is(testResolveUriToFile(filepath, undefined, []), filepath);
|
t.is(testResolveUriToFile(filepath, undefined, []), filepath);
|
||||||
t.is(testResolveUriToFile(`file://${filepath}`, undefined, []), filepath);
|
t.is(testResolveUriToFile(`file://${filepath}`, undefined, []), filepath);
|
||||||
// Relative paths are made absolute
|
// Relative paths are made absolute
|
||||||
t.is((_a = testResolveUriToFile(relativeFilepath, undefined, [])) === null || _a === void 0 ? void 0 : _a.split(path.sep).join("/"), filepath);
|
t.is(testResolveUriToFile(relativeFilepath, undefined, []), filepath);
|
||||||
t.is((_b = testResolveUriToFile(`file://${relativeFilepath}`, undefined, [])) === null || _b === void 0 ? void 0 : _b.split(path.sep).join("/"), filepath);
|
t.is(testResolveUriToFile(`file://${relativeFilepath}`, undefined, []), filepath);
|
||||||
// Absolute paths outside the src root are discarded
|
// Absolute paths outside the src root are discarded
|
||||||
t.is(testResolveUriToFile("/src/foo/bar.js", undefined, []), undefined);
|
t.is(testResolveUriToFile("/src/foo/bar.js", undefined, []), undefined);
|
||||||
t.is(testResolveUriToFile("file:///src/foo/bar.js", undefined, []), undefined);
|
t.is(testResolveUriToFile("file:///src/foo/bar.js", undefined, []), undefined);
|
||||||
|
|||||||
File diff suppressed because one or more lines are too long
9
lib/init-action.js
generated
9
lib/init-action.js
generated
@@ -89,16 +89,11 @@ async function run() {
|
|||||||
if (!(await (0, actions_util_1.sendStatusReport)(await (0, actions_util_1.createStatusReportBase)("init", "starting", startedAt, workflowErrors)))) {
|
if (!(await (0, actions_util_1.sendStatusReport)(await (0, actions_util_1.createStatusReportBase)("init", "starting", startedAt, workflowErrors)))) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
const initCodeQLResult = await (0, init_1.initCodeQL)((0, actions_util_1.getOptionalInput)("tools"), apiDetails, (0, actions_util_1.getTemporaryDirectory)(), gitHubVersion.type, logger);
|
const initCodeQLResult = await (0, init_1.initCodeQL)((0, actions_util_1.getOptionalInput)("tools"), apiDetails, (0, actions_util_1.getTemporaryDirectory)(), (0, actions_util_1.getToolCacheDirectory)(), gitHubVersion.type, logger);
|
||||||
codeql = initCodeQLResult.codeql;
|
codeql = initCodeQLResult.codeql;
|
||||||
toolsVersion = initCodeQLResult.toolsVersion;
|
toolsVersion = initCodeQLResult.toolsVersion;
|
||||||
await (0, util_1.enrichEnvironment)(util_1.Mode.actions, codeql);
|
await (0, util_1.enrichEnvironment)(util_1.Mode.actions, codeql);
|
||||||
config = await (0, init_1.initConfig)((0, actions_util_1.getOptionalInput)("languages"), (0, actions_util_1.getOptionalInput)("queries"), (0, actions_util_1.getOptionalInput)("packs"), (0, actions_util_1.getOptionalInput)("config-file"), (0, actions_util_1.getOptionalInput)("db-location"),
|
config = await (0, init_1.initConfig)((0, actions_util_1.getOptionalInput)("languages"), (0, actions_util_1.getOptionalInput)("queries"), (0, actions_util_1.getOptionalInput)("packs"), (0, actions_util_1.getOptionalInput)("config-file"), (0, actions_util_1.getOptionalInput)("db-location"), (0, actions_util_1.getOptionalInput)("debug") === "true", (0, actions_util_1.getOptionalInput)("debug-artifact-name") || util_1.DEFAULT_DEBUG_ARTIFACT_NAME, (0, actions_util_1.getOptionalInput)("debug-database-name") || util_1.DEFAULT_DEBUG_DATABASE_NAME, repositoryNwo, (0, actions_util_1.getTemporaryDirectory)(), (0, util_1.getRequiredEnvParam)("RUNNER_TOOL_CACHE"), codeql, (0, util_1.getRequiredEnvParam)("GITHUB_WORKSPACE"), gitHubVersion, apiDetails, featureFlags, logger);
|
||||||
// Debug mode is enabled if:
|
|
||||||
// - The `init` Action is passed `debug: true`.
|
|
||||||
// - Actions step debugging is enabled (e.g. by [enabling debug logging for a rerun](https://docs.github.com/en/actions/managing-workflow-runs/re-running-workflows-and-jobs#re-running-all-the-jobs-in-a-workflow),
|
|
||||||
// or by setting the `ACTIONS_STEP_DEBUG` secret to `true`).
|
|
||||||
(0, actions_util_1.getOptionalInput)("debug") === "true" || core.isDebug(), (0, actions_util_1.getOptionalInput)("debug-artifact-name") || util_1.DEFAULT_DEBUG_ARTIFACT_NAME, (0, actions_util_1.getOptionalInput)("debug-database-name") || util_1.DEFAULT_DEBUG_DATABASE_NAME, repositoryNwo, (0, actions_util_1.getTemporaryDirectory)(), codeql, (0, util_1.getRequiredEnvParam)("GITHUB_WORKSPACE"), gitHubVersion, apiDetails, featureFlags, logger);
|
|
||||||
if (config.languages.includes(languages_1.Language.python) &&
|
if (config.languages.includes(languages_1.Language.python) &&
|
||||||
(0, actions_util_1.getRequiredInput)("setup-python-dependencies") === "true") {
|
(0, actions_util_1.getRequiredInput)("setup-python-dependencies") === "true") {
|
||||||
try {
|
try {
|
||||||
|
|||||||
File diff suppressed because one or more lines are too long
13
lib/init.js
generated
13
lib/init.js
generated
@@ -30,17 +30,17 @@ const configUtils = __importStar(require("./config-utils"));
|
|||||||
const tracer_config_1 = require("./tracer-config");
|
const tracer_config_1 = require("./tracer-config");
|
||||||
const util = __importStar(require("./util"));
|
const util = __importStar(require("./util"));
|
||||||
const util_1 = require("./util");
|
const util_1 = require("./util");
|
||||||
async function initCodeQL(codeqlURL, apiDetails, tempDir, variant, logger) {
|
async function initCodeQL(codeqlURL, apiDetails, tempDir, toolCacheDir, variant, logger) {
|
||||||
logger.startGroup("Setup CodeQL tools");
|
logger.startGroup("Setup CodeQL tools");
|
||||||
const { codeql, toolsVersion } = await (0, codeql_1.setupCodeQL)(codeqlURL, apiDetails, tempDir, variant, logger, true);
|
const { codeql, toolsVersion } = await (0, codeql_1.setupCodeQL)(codeqlURL, apiDetails, tempDir, toolCacheDir, variant, logger, true);
|
||||||
await codeql.printVersion();
|
await codeql.printVersion();
|
||||||
logger.endGroup();
|
logger.endGroup();
|
||||||
return { codeql, toolsVersion };
|
return { codeql, toolsVersion };
|
||||||
}
|
}
|
||||||
exports.initCodeQL = initCodeQL;
|
exports.initCodeQL = initCodeQL;
|
||||||
async function initConfig(languagesInput, queriesInput, packsInput, configFile, dbLocation, debugMode, debugArtifactName, debugDatabaseName, repository, tempDir, codeQL, workspacePath, gitHubVersion, apiDetails, featureFlags, logger) {
|
async function initConfig(languagesInput, queriesInput, packsInput, configFile, dbLocation, debugMode, debugArtifactName, debugDatabaseName, repository, tempDir, toolCacheDir, codeQL, workspacePath, gitHubVersion, apiDetails, featureFlags, logger) {
|
||||||
logger.startGroup("Load language configuration");
|
logger.startGroup("Load language configuration");
|
||||||
const config = await configUtils.initConfig(languagesInput, queriesInput, packsInput, configFile, dbLocation, debugMode, debugArtifactName, debugDatabaseName, repository, tempDir, codeQL, workspacePath, gitHubVersion, apiDetails, featureFlags, logger);
|
const config = await configUtils.initConfig(languagesInput, queriesInput, packsInput, configFile, dbLocation, debugMode, debugArtifactName, debugDatabaseName, repository, tempDir, toolCacheDir, codeQL, workspacePath, gitHubVersion, apiDetails, featureFlags, logger);
|
||||||
analysisPaths.printPathFiltersWarning(config, logger);
|
analysisPaths.printPathFiltersWarning(config, logger);
|
||||||
logger.endGroup();
|
logger.endGroup();
|
||||||
return config;
|
return config;
|
||||||
@@ -179,15 +179,12 @@ async function installPythonDeps(codeql, logger) {
|
|||||||
if (process.platform === "win32") {
|
if (process.platform === "win32") {
|
||||||
await new toolrunner.ToolRunner(await safeWhich.safeWhich("py"), [
|
await new toolrunner.ToolRunner(await safeWhich.safeWhich("py"), [
|
||||||
"-3",
|
"-3",
|
||||||
"-B",
|
|
||||||
path.join(scriptsFolder, script),
|
path.join(scriptsFolder, script),
|
||||||
path.dirname(codeql.getPath()),
|
path.dirname(codeql.getPath()),
|
||||||
]).exec();
|
]).exec();
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
await new toolrunner.ToolRunner(await safeWhich.safeWhich("python3"), [
|
await new toolrunner.ToolRunner(path.join(scriptsFolder, script), [
|
||||||
"-B",
|
|
||||||
path.join(scriptsFolder, script),
|
|
||||||
path.dirname(codeql.getPath()),
|
path.dirname(codeql.getPath()),
|
||||||
]).exec();
|
]).exec();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
{"version":3,"file":"init.js","sourceRoot":"","sources":["../src/init.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAAA,uCAAyB;AACzB,2CAA6B;AAE7B,yEAA2D;AAC3D,kEAAoD;AAEpD,gEAAkD;AAElD,qCAA2E;AAC3E,4DAA8C;AAI9C,mDAAwE;AACxE,6CAA+B;AAC/B,iCAA4C;AAErC,KAAK,UAAU,UAAU,CAC9B,SAA6B,EAC7B,UAA4B,EAC5B,OAAe,EACf,OAA2B,EAC3B,MAAc;IAEd,MAAM,CAAC,UAAU,CAAC,oBAAoB,CAAC,CAAC;IACxC,MAAM,EAAE,MAAM,EAAE,YAAY,EAAE,GAAG,MAAM,IAAA,oBAAW,EAChD,SAAS,EACT,UAAU,EACV,OAAO,EACP,OAAO,EACP,MAAM,EACN,IAAI,CACL,CAAC;IACF,MAAM,MAAM,CAAC,YAAY,EAAE,CAAC;IAC5B,MAAM,CAAC,QAAQ,EAAE,CAAC;IAClB,OAAO,EAAE,MAAM,EAAE,YAAY,EAAE,CAAC;AAClC,CAAC;AAnBD,gCAmBC;AAEM,KAAK,UAAU,UAAU,CAC9B,cAAkC,EAClC,YAAgC,EAChC,UAA8B,EAC9B,UAA8B,EAC9B,UAA8B,EAC9B,SAAkB,EAClB,iBAAyB,EACzB,iBAAyB,EACzB,UAAyB,EACzB,OAAe,EACf,MAAc,EACd,aAAqB,EACrB,aAAiC,EACjC,UAAoC,EACpC,YAA0B,EAC1B,MAAc;IAEd,MAAM,CAAC,UAAU,CAAC,6BAA6B,CAAC,CAAC;IACjD,MAAM,MAAM,GAAG,MAAM,WAAW,CAAC,UAAU,CACzC,cAAc,EACd,YAAY,EACZ,UAAU,EACV,UAAU,EACV,UAAU,EACV,SAAS,EACT,iBAAiB,EACjB,iBAAiB,EACjB,UAAU,EACV,OAAO,EACP,MAAM,EACN,aAAa,EACb,aAAa,EACb,UAAU,EACV,YAAY,EACZ,MAAM,CACP,CAAC;IACF,aAAa,CAAC,uBAAuB,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACtD,MAAM,CAAC,QAAQ,EAAE,CAAC;IAClB,OAAO,MAAM,CAAC;AAChB,CAAC;AAxCD,gCAwCC;AAEM,KAAK,UAAU,OAAO,CAC3B,MAAc,EACd,MAA0B,EAC1B,UAAkB,EAClB,WAA+B,EAC/B,YAAgC,EAChC,YAA0B;;IAE1B,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAErD,IAAI;QACF,IAAI,MAAM,IAAA,yBAAkB,EAAC,MAAM,EAAE,mCAA0B,CAAC,EAAE;YAChE,0BAA0B;YAC1B,MAAM,MAAM,CAAC,mBAAmB,CAC9B,MAAM,EACN,UAAU,EACV,WAAW,EACX,YAAY,EACZ,YAAY,CACb,CAAC;SACH;aAAM;YACL,KAAK,MAAM,QAAQ,IAAI,MAAM,CAAC,SAAS,EAAE;gBACvC,yBAAyB;gBACzB,MAAM,MAAM,CAAC,YAAY,CACvB,IAAI,CAAC,qBAAqB,CAAC,MAAM,EAAE,QAAQ,CAAC,EAC5C,QAAQ,EACR,UAAU,CACX,CAAC;aACH;SACF;KACF;IAAC,OAAO,CAAC,EAAE;QACV,kDAAkD;QAClD,yCAAyC;QACzC,IACE,CAAC,YAAY,KAAK;aAClB,MAAA,CAAC,CAAC,OAAO,0CAAE,QAAQ,CAAC,8BAA8B,CAAC,CAAA;YACnD,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,uCAAuC,CAAC,EAC3D;YACA,MAAM,IAAI,IAAI,CAAC,SAAS,CACtB,sDAAsD,CAAC,CAAC,OAAO,EAAE,CAClE,CAAC;SACH;aAAM,IACL,CAAC,YAAY,KAAK;aAClB,MAAA,CAAC,CAAC,OAAO,0CAAE,QAAQ,CAAC,wCAAwC,CAAC,CAAA,EAC7D;YACA,MAAM,IAAI,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;SACrC;aAAM;YACL,MAAM,CAAC,CAAC;SACT;KACF;IACD,OAAO,MAAM,IAAA,uCAAuB,EAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AACvD,CAAC;AAnDD,0BAmDC;AAED,sEAAsE;AACtE,4EAA4E;AAC5E,4EAA4E;AAC5E,6EAA6E;AAC7E,+CAA+C;AACxC,KAAK,UAAU,mBAAmB,CACvC,WAA+B,EAC/B,YAAgC,EAChC,MAA0B,EAC1B,MAAc,EACd,YAA0B;IAE1B,IAAI,MAAc,CAAC;IACnB,IAAI,WAAW,KAAK,SAAS,EAAE;QAC7B,MAAM,GAAG;;;;;;;;;;;;uCAY0B,WAAW;;8BAEpB,WAAW;;;;;;;;gDAQO,CAAC;KAC9C;SAAM;QACL,oEAAoE;QACpE,mFAAmF;QACnF,+EAA+E;QAC/E,kFAAkF;QAClF,6EAA6E;QAC7E,oFAAoF;QACpF,6CAA6C;QAC7C,YAAY,GAAG,YAAY,IAAI,CAAC,CAAC;QACjC,MAAM,GAAG;;;;;;;;4BAQe,YAAY;;;;;;;;;;;;;;;;;;;;;gDAqBQ,CAAC;KAC9C;IAED,MAAM,gBAAgB,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,mBAAmB,CAAC,CAAC;IACxE,EAAE,CAAC,aAAa,CAAC,gBAAgB,EAAE,MAAM,CAAC,CAAC;IAE3C,MAAM,IAAI,UAAU,CAAC,UAAU,CAC7B,MAAM,SAAS,CAAC,SAAS,CAAC,YAAY,CAAC,EACvC;QACE,kBAAkB;QAClB,QAAQ;QACR,OAAO;QACP,gBAAgB;QAChB,IAAI,CAAC,OAAO,CACV,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,EAC9B,OAAO,EACP,OAAO,EACP,YAAY,CACb;KACF,EACD,EAAE,GAAG,EAAE,EAAE,0BAA0B,EAAE,YAAY,CAAC,IAAI,EAAE,EAAE,CAC3D,CAAC,IAAI,EAAE,CAAC;AACX,CAAC;AA5FD,kDA4FC;AAEM,KAAK,UAAU,iBAAiB,CAAC,MAAc,EAAE,MAAc;IACpE,MAAM,CAAC,UAAU,CAAC,2BAA2B,CAAC,CAAC;IAE/C,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,iBAAiB,CAAC,CAAC;IAEjE,IAAI;QACF,IAAI,OAAO,CAAC,QAAQ,KAAK,OAAO,EAAE;YAChC,MAAM,IAAI,UAAU,CAAC,UAAU,CAAC,MAAM,SAAS,CAAC,SAAS,CAAC,YAAY,CAAC,EAAE;gBACvE,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,mBAAmB,CAAC;aAC9C,CAAC,CAAC,IAAI,EAAE,CAAC;SACX;aAAM;YACL,MAAM,IAAI,UAAU,CAAC,UAAU,CAC7B,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,kBAAkB,CAAC,CAC7C,CAAC,IAAI,EAAE,CAAC;SACV;QACD,MAAM,MAAM,GAAG,0BAA0B,CAAC;QAC1C,IAAI,OAAO,CAAC,QAAQ,KAAK,OAAO,EAAE;YAChC,MAAM,IAAI,UAAU,CAAC,UAAU,CAAC,MAAM,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE;gBAC/D,IAAI;gBACJ,IAAI;gBACJ,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,MAAM,CAAC;gBAChC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;aAC/B,CAAC,CAAC,IAAI,EAAE,CAAC;SACX;aAAM;YACL,MAAM,IAAI,UAAU,CAAC,UAAU,CAAC,MAAM,SAAS,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE;gBACpE,IAAI;gBACJ,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,MAAM,CAAC;gBAChC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;aAC/B,CAAC,CAAC,IAAI,EAAE,CAAC;SACX;KACF;IAAC,OAAO,CAAC,EAAE;QACV,MAAM,CAAC,QAAQ,EAAE,CAAC;QAClB,MAAM,CAAC,OAAO,CACZ,gFAAgF,CAAC,IAAI;YACnF,qGAAqG;YACrG,oGAAoG;YACpG,iDAAiD,CACpD,CAAC;QACF,OAAO;KACR;IACD,MAAM,CAAC,QAAQ,EAAE,CAAC;AACpB,CAAC;AAzCD,8CAyCC"}
|
{"version":3,"file":"init.js","sourceRoot":"","sources":["../src/init.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAAA,uCAAyB;AACzB,2CAA6B;AAE7B,yEAA2D;AAC3D,kEAAoD;AAEpD,gEAAkD;AAElD,qCAA2E;AAC3E,4DAA8C;AAI9C,mDAAwE;AACxE,6CAA+B;AAC/B,iCAA4C;AAErC,KAAK,UAAU,UAAU,CAC9B,SAA6B,EAC7B,UAA4B,EAC5B,OAAe,EACf,YAAoB,EACpB,OAA2B,EAC3B,MAAc;IAEd,MAAM,CAAC,UAAU,CAAC,oBAAoB,CAAC,CAAC;IACxC,MAAM,EAAE,MAAM,EAAE,YAAY,EAAE,GAAG,MAAM,IAAA,oBAAW,EAChD,SAAS,EACT,UAAU,EACV,OAAO,EACP,YAAY,EACZ,OAAO,EACP,MAAM,EACN,IAAI,CACL,CAAC;IACF,MAAM,MAAM,CAAC,YAAY,EAAE,CAAC;IAC5B,MAAM,CAAC,QAAQ,EAAE,CAAC;IAClB,OAAO,EAAE,MAAM,EAAE,YAAY,EAAE,CAAC;AAClC,CAAC;AArBD,gCAqBC;AAEM,KAAK,UAAU,UAAU,CAC9B,cAAkC,EAClC,YAAgC,EAChC,UAA8B,EAC9B,UAA8B,EAC9B,UAA8B,EAC9B,SAAkB,EAClB,iBAAyB,EACzB,iBAAyB,EACzB,UAAyB,EACzB,OAAe,EACf,YAAoB,EACpB,MAAc,EACd,aAAqB,EACrB,aAAiC,EACjC,UAAoC,EACpC,YAA0B,EAC1B,MAAc;IAEd,MAAM,CAAC,UAAU,CAAC,6BAA6B,CAAC,CAAC;IACjD,MAAM,MAAM,GAAG,MAAM,WAAW,CAAC,UAAU,CACzC,cAAc,EACd,YAAY,EACZ,UAAU,EACV,UAAU,EACV,UAAU,EACV,SAAS,EACT,iBAAiB,EACjB,iBAAiB,EACjB,UAAU,EACV,OAAO,EACP,YAAY,EACZ,MAAM,EACN,aAAa,EACb,aAAa,EACb,UAAU,EACV,YAAY,EACZ,MAAM,CACP,CAAC;IACF,aAAa,CAAC,uBAAuB,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACtD,MAAM,CAAC,QAAQ,EAAE,CAAC;IAClB,OAAO,MAAM,CAAC;AAChB,CAAC;AA1CD,gCA0CC;AAEM,KAAK,UAAU,OAAO,CAC3B,MAAc,EACd,MAA0B,EAC1B,UAAkB,EAClB,WAA+B,EAC/B,YAAgC,EAChC,YAA0B;;IAE1B,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,UAAU,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;IAErD,IAAI;QACF,IAAI,MAAM,IAAA,yBAAkB,EAAC,MAAM,EAAE,mCAA0B,CAAC,EAAE;YAChE,0BAA0B;YAC1B,MAAM,MAAM,CAAC,mBAAmB,CAC9B,MAAM,EACN,UAAU,EACV,WAAW,EACX,YAAY,EACZ,YAAY,CACb,CAAC;SACH;aAAM;YACL,KAAK,MAAM,QAAQ,IAAI,MAAM,CAAC,SAAS,EAAE;gBACvC,yBAAyB;gBACzB,MAAM,MAAM,CAAC,YAAY,CACvB,IAAI,CAAC,qBAAqB,CAAC,MAAM,EAAE,QAAQ,CAAC,EAC5C,QAAQ,EACR,UAAU,CACX,CAAC;aACH;SACF;KACF;IAAC,OAAO,CAAC,EAAE;QACV,kDAAkD;QAClD,yCAAyC;QACzC,IACE,CAAC,YAAY,KAAK;aAClB,MAAA,CAAC,CAAC,OAAO,0CAAE,QAAQ,CAAC,8BAA8B,CAAC,CAAA;YACnD,CAAC,CAAC,OAAO,CAAC,QAAQ,CAAC,uCAAuC,CAAC,EAC3D;YACA,MAAM,IAAI,IAAI,CAAC,SAAS,CACtB,sDAAsD,CAAC,CAAC,OAAO,EAAE,CAClE,CAAC;SACH;aAAM,IACL,CAAC,YAAY,KAAK;aAClB,MAAA,CAAC,CAAC,OAAO,0CAAE,QAAQ,CAAC,wCAAwC,CAAC,CAAA,EAC7D;YACA,MAAM,IAAI,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;SACrC;aAAM;YACL,MAAM,CAAC,CAAC;SACT;KACF;IACD,OAAO,MAAM,IAAA,uCAAuB,EAAC,MAAM,EAAE,MAAM,CAAC,CAAC;AACvD,CAAC;AAnDD,0BAmDC;AAED,sEAAsE;AACtE,4EAA4E;AAC5E,4EAA4E;AAC5E,6EAA6E;AAC7E,+CAA+C;AACxC,KAAK,UAAU,mBAAmB,CACvC,WAA+B,EAC/B,YAAgC,EAChC,MAA0B,EAC1B,MAAc,EACd,YAA0B;IAE1B,IAAI,MAAc,CAAC;IACnB,IAAI,WAAW,KAAK,SAAS,EAAE;QAC7B,MAAM,GAAG;;;;;;;;;;;;uCAY0B,WAAW;;8BAEpB,WAAW;;;;;;;;gDAQO,CAAC;KAC9C;SAAM;QACL,oEAAoE;QACpE,mFAAmF;QACnF,+EAA+E;QAC/E,kFAAkF;QAClF,6EAA6E;QAC7E,oFAAoF;QACpF,6CAA6C;QAC7C,YAAY,GAAG,YAAY,IAAI,CAAC,CAAC;QACjC,MAAM,GAAG;;;;;;;;4BAQe,YAAY;;;;;;;;;;;;;;;;;;;;;gDAqBQ,CAAC;KAC9C;IAED,MAAM,gBAAgB,GAAG,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,EAAE,mBAAmB,CAAC,CAAC;IACxE,EAAE,CAAC,aAAa,CAAC,gBAAgB,EAAE,MAAM,CAAC,CAAC;IAE3C,MAAM,IAAI,UAAU,CAAC,UAAU,CAC7B,MAAM,SAAS,CAAC,SAAS,CAAC,YAAY,CAAC,EACvC;QACE,kBAAkB;QAClB,QAAQ;QACR,OAAO;QACP,gBAAgB;QAChB,IAAI,CAAC,OAAO,CACV,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC,EAC9B,OAAO,EACP,OAAO,EACP,YAAY,CACb;KACF,EACD,EAAE,GAAG,EAAE,EAAE,0BAA0B,EAAE,YAAY,CAAC,IAAI,EAAE,EAAE,CAC3D,CAAC,IAAI,EAAE,CAAC;AACX,CAAC;AA5FD,kDA4FC;AAEM,KAAK,UAAU,iBAAiB,CAAC,MAAc,EAAE,MAAc;IACpE,MAAM,CAAC,UAAU,CAAC,2BAA2B,CAAC,CAAC;IAE/C,MAAM,aAAa,GAAG,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE,iBAAiB,CAAC,CAAC;IAEjE,IAAI;QACF,IAAI,OAAO,CAAC,QAAQ,KAAK,OAAO,EAAE;YAChC,MAAM,IAAI,UAAU,CAAC,UAAU,CAAC,MAAM,SAAS,CAAC,SAAS,CAAC,YAAY,CAAC,EAAE;gBACvE,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,mBAAmB,CAAC;aAC9C,CAAC,CAAC,IAAI,EAAE,CAAC;SACX;aAAM;YACL,MAAM,IAAI,UAAU,CAAC,UAAU,CAC7B,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,kBAAkB,CAAC,CAC7C,CAAC,IAAI,EAAE,CAAC;SACV;QACD,MAAM,MAAM,GAAG,0BAA0B,CAAC;QAC1C,IAAI,OAAO,CAAC,QAAQ,KAAK,OAAO,EAAE;YAChC,MAAM,IAAI,UAAU,CAAC,UAAU,CAAC,MAAM,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE;gBAC/D,IAAI;gBACJ,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,MAAM,CAAC;gBAChC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;aAC/B,CAAC,CAAC,IAAI,EAAE,CAAC;SACX;aAAM;YACL,MAAM,IAAI,UAAU,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,MAAM,CAAC,EAAE;gBAChE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,EAAE,CAAC;aAC/B,CAAC,CAAC,IAAI,EAAE,CAAC;SACX;KACF;IAAC,OAAO,CAAC,EAAE;QACV,MAAM,CAAC,QAAQ,EAAE,CAAC;QAClB,MAAM,CAAC,OAAO,CACZ,gFAAgF,CAAC,IAAI;YACnF,qGAAqG;YACrG,oGAAoG;YACpG,iDAAiD,CACpD,CAAC;QACF,OAAO;KACR;IACD,MAAM,CAAC,QAAQ,EAAE,CAAC;AACpB,CAAC;AAtCD,8CAsCC"}
|
||||||
15
lib/runner.js
generated
15
lib/runner.js
generated
@@ -23,6 +23,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|||||||
};
|
};
|
||||||
Object.defineProperty(exports, "__esModule", { value: true });
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
const fs = __importStar(require("fs"));
|
const fs = __importStar(require("fs"));
|
||||||
|
const os = __importStar(require("os"));
|
||||||
const path = __importStar(require("path"));
|
const path = __importStar(require("path"));
|
||||||
const commander_1 = require("commander");
|
const commander_1 = require("commander");
|
||||||
const del_1 = __importDefault(require("del"));
|
const del_1 = __importDefault(require("del"));
|
||||||
@@ -50,6 +51,13 @@ function getTempDir(userInput) {
|
|||||||
}
|
}
|
||||||
return tempDir;
|
return tempDir;
|
||||||
}
|
}
|
||||||
|
function getToolsDir(userInput) {
|
||||||
|
const toolsDir = userInput || path.join(os.homedir(), "codeql-runner-tools");
|
||||||
|
if (!fs.existsSync(toolsDir)) {
|
||||||
|
fs.mkdirSync(toolsDir, { recursive: true });
|
||||||
|
}
|
||||||
|
return toolsDir;
|
||||||
|
}
|
||||||
const codeqlEnvJsonFilename = "codeql-env.json";
|
const codeqlEnvJsonFilename = "codeql-env.json";
|
||||||
function loadTracerEnvironment(config) {
|
function loadTracerEnvironment(config) {
|
||||||
const jsonEnvFile = path.join(config.tempDir, codeqlEnvJsonFilename);
|
const jsonEnvFile = path.join(config.tempDir, codeqlEnvJsonFilename);
|
||||||
@@ -126,6 +134,7 @@ program
|
|||||||
const logger = (0, logging_1.getRunnerLogger)(cmd.debug);
|
const logger = (0, logging_1.getRunnerLogger)(cmd.debug);
|
||||||
try {
|
try {
|
||||||
const tempDir = getTempDir(cmd.tempDir);
|
const tempDir = getTempDir(cmd.tempDir);
|
||||||
|
const toolsDir = getToolsDir(cmd.toolsDir);
|
||||||
const checkoutPath = cmd.checkoutPath || process.cwd();
|
const checkoutPath = cmd.checkoutPath || process.cwd();
|
||||||
// Wipe the temp dir
|
// Wipe the temp dir
|
||||||
logger.info(`Cleaning temp directory ${tempDir}`);
|
logger.info(`Cleaning temp directory ${tempDir}`);
|
||||||
@@ -151,11 +160,11 @@ program
|
|||||||
codeql = await (0, codeql_1.getCodeQL)(cmd.codeqlPath);
|
codeql = await (0, codeql_1.getCodeQL)(cmd.codeqlPath);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
codeql = (await (0, init_1.initCodeQL)(undefined, apiDetails, tempDir, gitHubVersion.type, logger)).codeql;
|
codeql = (await (0, init_1.initCodeQL)(undefined, apiDetails, tempDir, toolsDir, gitHubVersion.type, logger)).codeql;
|
||||||
}
|
}
|
||||||
await (0, util_1.enrichEnvironment)(util_1.Mode.runner, codeql);
|
await (0, util_1.enrichEnvironment)(util_1.Mode.runner, codeql);
|
||||||
const workspacePath = checkoutPath;
|
const workspacePath = checkoutPath;
|
||||||
const config = await (0, init_1.initConfig)(cmd.languages, cmd.queries, cmd.packs, cmd.configFile, undefined, false, "", "", (0, repository_1.parseRepositoryNwo)(cmd.repository), tempDir, codeql, workspacePath, gitHubVersion, apiDetails, (0, feature_flags_1.createFeatureFlags)([]), logger);
|
const config = await (0, init_1.initConfig)(cmd.languages, cmd.queries, cmd.packs, cmd.configFile, undefined, false, "", "", (0, repository_1.parseRepositoryNwo)(cmd.repository), tempDir, toolsDir, codeql, workspacePath, gitHubVersion, apiDetails, (0, feature_flags_1.createFeatureFlags)([]), logger);
|
||||||
const sourceRoot = checkoutPath;
|
const sourceRoot = checkoutPath;
|
||||||
const tracerConfig = await (0, init_1.runInit)(codeql, config, sourceRoot, parseTraceProcessName(), parseTraceProcessLevel(), (0, feature_flags_1.createFeatureFlags)([]));
|
const tracerConfig = await (0, init_1.runInit)(codeql, config, sourceRoot, parseTraceProcessName(), parseTraceProcessLevel(), (0, feature_flags_1.createFeatureFlags)([]));
|
||||||
if (tracerConfig === undefined) {
|
if (tracerConfig === undefined) {
|
||||||
@@ -288,7 +297,7 @@ program
|
|||||||
}
|
}
|
||||||
const threads = (0, util_1.getThreadsFlag)(cmd.threads || initEnv["CODEQL_THREADS"], logger);
|
const threads = (0, util_1.getThreadsFlag)(cmd.threads || initEnv["CODEQL_THREADS"], logger);
|
||||||
const memory = (0, util_1.getMemoryFlag)(cmd.ram || initEnv["CODEQL_RAM"]);
|
const memory = (0, util_1.getMemoryFlag)(cmd.ram || initEnv["CODEQL_RAM"]);
|
||||||
await (0, analyze_1.runFinalize)(outputDir, threads, memory, config, logger, (0, feature_flags_1.createFeatureFlags)([]));
|
await (0, analyze_1.runFinalize)(outputDir, threads, memory, config, logger);
|
||||||
await (0, analyze_1.runQueries)(outputDir, memory, (0, util_1.getAddSnippetsFlag)(cmd.addSnippets), threads, cmd.category, config, logger);
|
await (0, analyze_1.runQueries)(outputDir, memory, (0, util_1.getAddSnippetsFlag)(cmd.addSnippets), threads, cmd.category, config, logger);
|
||||||
if (!cmd.upload) {
|
if (!cmd.upload) {
|
||||||
logger.info("Not uploading results");
|
logger.info("Not uploading results");
|
||||||
|
|||||||
File diff suppressed because one or more lines are too long
7
lib/testing-utils.js
generated
7
lib/testing-utils.js
generated
@@ -64,13 +64,6 @@ function setupTests(test) {
|
|||||||
const processStderrWrite = process.stderr.write.bind(process.stderr);
|
const processStderrWrite = process.stderr.write.bind(process.stderr);
|
||||||
t.context.stderrWrite = processStderrWrite;
|
t.context.stderrWrite = processStderrWrite;
|
||||||
process.stderr.write = wrapOutput(t.context);
|
process.stderr.write = wrapOutput(t.context);
|
||||||
// Workaround an issue in tests where the case insensitivity of the `$PATH`
|
|
||||||
// environment variable on Windows isn't preserved, i.e. `process.env.PATH`
|
|
||||||
// is not the same as `process.env.Path`.
|
|
||||||
const pathKeys = Object.keys(process.env).filter((k) => k.toLowerCase() === "path");
|
|
||||||
if (pathKeys.length > 0) {
|
|
||||||
process.env.PATH = process.env[pathKeys[0]];
|
|
||||||
}
|
|
||||||
// Many tests modify environment variables. Take a copy now so that
|
// Many tests modify environment variables. Take a copy now so that
|
||||||
// we reset them after the test to keep tests independent of each other.
|
// we reset them after the test to keep tests independent of each other.
|
||||||
// process.env only has strings fields, so a shallow copy is fine.
|
// process.env only has strings fields, so a shallow copy is fine.
|
||||||
|
|||||||
@@ -1 +1 @@
|
|||||||
{"version":3,"file":"testing-utils.js","sourceRoot":"","sources":["../src/testing-utils.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAAA,wDAA0C;AAE1C,6CAA+B;AAE/B,wDAA0C;AAC1C,iDAAmC;AAEnC,iCAAmC;AASnC,SAAS,UAAU,CAAC,OAAoB;IACtC,8CAA8C;IAC9C,gCAAgC;IAChC,2EAA2E;IAC3E,2FAA2F;IAC3F,OAAO,CACL,KAA0B,EAC1B,QAAiB,EACjB,EAA0B,EACjB,EAAE;QACX,2CAA2C;QAC3C,IAAI,EAAE,KAAK,SAAS,IAAI,OAAO,QAAQ,KAAK,UAAU,EAAE;YACtD,EAAE,GAAG,QAAQ,CAAC;YACd,QAAQ,GAAG,SAAS,CAAC;SACtB;QAED,oBAAoB;QACpB,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;YAC7B,OAAO,CAAC,UAAU,IAAI,KAAK,CAAC;SAC7B;aAAM;YACL,OAAO,CAAC,UAAU,IAAI,IAAI,WAAW,CAAC,QAAQ,IAAI,OAAO,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;SAC1E;QAED,iDAAiD;QACjD,IAAI,EAAE,KAAK,SAAS,IAAI,OAAO,EAAE,KAAK,UAAU,EAAE;YAChD,EAAE,EAAE,CAAC;SACN;QAED,OAAO,IAAI,CAAC;IACd,CAAC,CAAC;AACJ,CAAC;AAED,SAAgB,UAAU,CAAC,IAAiB;IAC1C,MAAM,SAAS,GAAG,IAA2B,CAAC;IAE9C,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,EAAE;QACzB,gEAAgE;QAChE,0CAA0C;QAC1C,MAAM,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;QAErB,iEAAiE;QACjE,CAAC,CAAC,OAAO,CAAC,UAAU,GAAG,EAAE,CAAC;QAC1B,MAAM,kBAAkB,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QACrE,CAAC,CAAC,OAAO,CAAC,WAAW,GAAG,kBAAkB,CAAC;QAC3C,OAAO,CAAC,MAAM,CAAC,KAAK,GAAG,UAAU,CAAC,CAAC,CAAC,OAAO,CAAQ,CAAC;QACpD,MAAM,kBAAkB,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QACrE,CAAC,CAAC,OAAO,CAAC,WAAW,GAAG,kBAAkB,CAAC;QAC3C,OAAO,CAAC,MAAM,CAAC,KAAK,GAAG,UAAU,CAAC,CAAC,CAAC,OAAO,CAAQ,CAAC;QAEpD,2EAA2E;QAC3E,2EAA2E;QAC3E,yCAAyC;QACzC,MAAM,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,MAAM,CAC9C,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,EAAE,KAAK,MAAM,CAClC,CAAC;QACF,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;YACvB,OAAO,CAAC,GAAG,CAAC,IAAI,GAAG,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;SAC7C;QAED,mEAAmE;QACnE,wEAAwE;QACxE,kEAAkE;QAClE,CAAC,CAAC,OAAO,CAAC,GAAG,GAAG,EAAE,CAAC;QACnB,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;IAC5C,CAAC,CAAC,CAAC;IAEH,SAAS,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE;QAC/B,4BAA4B;QAC5B,0DAA0D;QAC1D,OAAO,CAAC,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC;QAC7C,OAAO,CAAC,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC;QAC7C,IAAI,CAAC,CAAC,CAAC,MAAM,EAAE;YACb,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;SAC5C;QAED,uCAAuC;QACvC,KAAK,CAAC,OAAO,EAAE,CAAC;QAEhB,oCAAoC;QACpC,OAAO,CAAC,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC;IAC9B,CAAC,CAAC,CAAC;AACL,CAAC;AAjDD,gCAiDC;AAED,yEAAyE;AACzE,sDAAsD;AACtD,SAAgB,gBAAgB,CAAC,OAAe,EAAE,QAAgB;IAChE,OAAO,CAAC,GAAG,CAAC,aAAa,CAAC,GAAG,OAAO,CAAC;IACrC,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAC,GAAG,QAAQ,CAAC;IAC5C,OAAO,CAAC,GAAG,CAAC,kBAAkB,CAAC,GAAG,OAAO,CAAC;AAC5C,CAAC;AAJD,4CAIC;AAOD,SAAgB,kBAAkB,CAAC,QAAyB;IAC1D,OAAO;QACL,KAAK,EAAE,CAAC,OAAe,EAAE,EAAE;YACzB,QAAQ,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC,CAAC;YAC1C,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QACzB,CAAC;QACD,IAAI,EAAE,CAAC,OAAe,EAAE,EAAE;YACxB,QAAQ,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC,CAAC;YACzC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACxB,CAAC;QACD,OAAO,EAAE,CAAC,OAAuB,EAAE,EAAE;YACnC,QAAQ,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,CAAC,CAAC;YAC5C,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACxB,CAAC;QACD,KAAK,EAAE,CAAC,OAAuB,EAAE,EAAE;YACjC,QAAQ,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC,CAAC;YAC1C,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QACzB,CAAC;QACD,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI;QACnB,UAAU,EAAE,GAAG,EAAE,CAAC,SAAS;QAC3B,QAAQ,EAAE,GAAG,EAAE,CAAC,SAAS;KAC1B,CAAC;AACJ,CAAC;AAtBD,gDAsBC;AAED,0EAA0E;AAC1E,SAAgB,0BAA0B,CACxC,kBAA0B,EAC1B,QAAyC;IAEzC,kEAAkE;IAClE,MAAM,MAAM,GAAG,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;IAExC,MAAM,UAAU,GAAG,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IAEjD,MAAM,QAAQ,GAAG,UAAU,CAAC,QAAQ,CAClC,8DAA8D,CAC/D,CAAC;IACF,IAAI,kBAAkB,GAAG,GAAG,EAAE;QAC5B,QAAQ,CAAC,QAAQ,CAAC;YAChB,MAAM,EAAE,kBAAkB;YAC1B,IAAI,EAAE,QAAQ;YACd,OAAO,EAAE,EAAE;YACX,GAAG,EAAE,8DAA8D;SACpE,CAAC,CAAC;KACJ;SAAM;QACL,QAAQ,CAAC,MAAM,CAAC,IAAI,gBAAS,CAAC,oBAAoB,EAAE,kBAAkB,CAAC,CAAC,CAAC;KAC1E;IAED,KAAK,CAAC,IAAI,CAAC,SAAS,EAAE,cAAc,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,CAAC;AAC5D,CAAC;AAxBD,gEAwBC"}
|
{"version":3,"file":"testing-utils.js","sourceRoot":"","sources":["../src/testing-utils.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;AAAA,wDAA0C;AAE1C,6CAA+B;AAE/B,wDAA0C;AAC1C,iDAAmC;AAEnC,iCAAmC;AASnC,SAAS,UAAU,CAAC,OAAoB;IACtC,8CAA8C;IAC9C,gCAAgC;IAChC,2EAA2E;IAC3E,2FAA2F;IAC3F,OAAO,CACL,KAA0B,EAC1B,QAAiB,EACjB,EAA0B,EACjB,EAAE;QACX,2CAA2C;QAC3C,IAAI,EAAE,KAAK,SAAS,IAAI,OAAO,QAAQ,KAAK,UAAU,EAAE;YACtD,EAAE,GAAG,QAAQ,CAAC;YACd,QAAQ,GAAG,SAAS,CAAC;SACtB;QAED,oBAAoB;QACpB,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE;YAC7B,OAAO,CAAC,UAAU,IAAI,KAAK,CAAC;SAC7B;aAAM;YACL,OAAO,CAAC,UAAU,IAAI,IAAI,WAAW,CAAC,QAAQ,IAAI,OAAO,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;SAC1E;QAED,iDAAiD;QACjD,IAAI,EAAE,KAAK,SAAS,IAAI,OAAO,EAAE,KAAK,UAAU,EAAE;YAChD,EAAE,EAAE,CAAC;SACN;QAED,OAAO,IAAI,CAAC;IACd,CAAC,CAAC;AACJ,CAAC;AAED,SAAgB,UAAU,CAAC,IAAiB;IAC1C,MAAM,SAAS,GAAG,IAA2B,CAAC;IAE9C,SAAS,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,EAAE;QACzB,gEAAgE;QAChE,0CAA0C;QAC1C,MAAM,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC;QAErB,iEAAiE;QACjE,CAAC,CAAC,OAAO,CAAC,UAAU,GAAG,EAAE,CAAC;QAC1B,MAAM,kBAAkB,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QACrE,CAAC,CAAC,OAAO,CAAC,WAAW,GAAG,kBAAkB,CAAC;QAC3C,OAAO,CAAC,MAAM,CAAC,KAAK,GAAG,UAAU,CAAC,CAAC,CAAC,OAAO,CAAQ,CAAC;QACpD,MAAM,kBAAkB,GAAG,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC;QACrE,CAAC,CAAC,OAAO,CAAC,WAAW,GAAG,kBAAkB,CAAC;QAC3C,OAAO,CAAC,MAAM,CAAC,KAAK,GAAG,UAAU,CAAC,CAAC,CAAC,OAAO,CAAQ,CAAC;QAEpD,mEAAmE;QACnE,wEAAwE;QACxE,kEAAkE;QAClE,CAAC,CAAC,OAAO,CAAC,GAAG,GAAG,EAAE,CAAC;QACnB,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,OAAO,CAAC,GAAG,EAAE,OAAO,CAAC,GAAG,CAAC,CAAC;IAC5C,CAAC,CAAC,CAAC;IAEH,SAAS,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE;QAC/B,4BAA4B;QAC5B,0DAA0D;QAC1D,OAAO,CAAC,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC;QAC7C,OAAO,CAAC,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC,OAAO,CAAC,WAAW,CAAC;QAC7C,IAAI,CAAC,CAAC,CAAC,MAAM,EAAE;YACb,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;SAC5C;QAED,uCAAuC;QACvC,KAAK,CAAC,OAAO,EAAE,CAAC;QAEhB,oCAAoC;QACpC,OAAO,CAAC,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC;IAC9B,CAAC,CAAC,CAAC;AACL,CAAC;AAvCD,gCAuCC;AAED,yEAAyE;AACzE,sDAAsD;AACtD,SAAgB,gBAAgB,CAAC,OAAe,EAAE,QAAgB;IAChE,OAAO,CAAC,GAAG,CAAC,aAAa,CAAC,GAAG,OAAO,CAAC;IACrC,OAAO,CAAC,GAAG,CAAC,mBAAmB,CAAC,GAAG,QAAQ,CAAC;IAC5C,OAAO,CAAC,GAAG,CAAC,kBAAkB,CAAC,GAAG,OAAO,CAAC;AAC5C,CAAC;AAJD,4CAIC;AAOD,SAAgB,kBAAkB,CAAC,QAAyB;IAC1D,OAAO;QACL,KAAK,EAAE,CAAC,OAAe,EAAE,EAAE;YACzB,QAAQ,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC,CAAC;YAC1C,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QACzB,CAAC;QACD,IAAI,EAAE,CAAC,OAAe,EAAE,EAAE;YACxB,QAAQ,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC,CAAC;YACzC,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACxB,CAAC;QACD,OAAO,EAAE,CAAC,OAAuB,EAAE,EAAE;YACnC,QAAQ,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,OAAO,EAAE,CAAC,CAAC;YAC5C,OAAO,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QACxB,CAAC;QACD,KAAK,EAAE,CAAC,OAAuB,EAAE,EAAE;YACjC,QAAQ,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,CAAC,CAAC;YAC1C,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QACzB,CAAC;QACD,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI;QACnB,UAAU,EAAE,GAAG,EAAE,CAAC,SAAS;QAC3B,QAAQ,EAAE,GAAG,EAAE,CAAC,SAAS;KAC1B,CAAC;AACJ,CAAC;AAtBD,gDAsBC;AAED,0EAA0E;AAC1E,SAAgB,0BAA0B,CACxC,kBAA0B,EAC1B,QAAyC;IAEzC,kEAAkE;IAClE,MAAM,MAAM,GAAG,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,CAAC;IAExC,MAAM,UAAU,GAAG,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,SAAS,CAAC,CAAC;IAEjD,MAAM,QAAQ,GAAG,UAAU,CAAC,QAAQ,CAClC,8DAA8D,CAC/D,CAAC;IACF,IAAI,kBAAkB,GAAG,GAAG,EAAE;QAC5B,QAAQ,CAAC,QAAQ,CAAC;YAChB,MAAM,EAAE,kBAAkB;YAC1B,IAAI,EAAE,QAAQ;YACd,OAAO,EAAE,EAAE;YACX,GAAG,EAAE,8DAA8D;SACpE,CAAC,CAAC;KACJ;SAAM;QACL,QAAQ,CAAC,MAAM,CAAC,IAAI,gBAAS,CAAC,oBAAoB,EAAE,kBAAkB,CAAC,CAAC,CAAC;KAC1E;IAED,KAAK,CAAC,IAAI,CAAC,SAAS,EAAE,cAAc,CAAC,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,CAAC;AAC5D,CAAC;AAxBD,gEAwBC"}
|
||||||
286
lib/toolcache.js
generated
Normal file
286
lib/toolcache.js
generated
Normal file
@@ -0,0 +1,286 @@
|
|||||||
|
"use strict";
|
||||||
|
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
||||||
|
if (k2 === undefined) k2 = k;
|
||||||
|
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
|
||||||
|
}) : (function(o, m, k, k2) {
|
||||||
|
if (k2 === undefined) k2 = k;
|
||||||
|
o[k2] = m[k];
|
||||||
|
}));
|
||||||
|
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
||||||
|
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
||||||
|
}) : function(o, v) {
|
||||||
|
o["default"] = v;
|
||||||
|
});
|
||||||
|
var __importStar = (this && this.__importStar) || function (mod) {
|
||||||
|
if (mod && mod.__esModule) return mod;
|
||||||
|
var result = {};
|
||||||
|
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
||||||
|
__setModuleDefault(result, mod);
|
||||||
|
return result;
|
||||||
|
};
|
||||||
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
||||||
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
||||||
|
};
|
||||||
|
Object.defineProperty(exports, "__esModule", { value: true });
|
||||||
|
exports.downloadTool = exports.findAllVersions = exports.find = exports.cacheDir = exports.extractTar = void 0;
|
||||||
|
const fs = __importStar(require("fs"));
|
||||||
|
const os = __importStar(require("os"));
|
||||||
|
const path = __importStar(require("path"));
|
||||||
|
const toolrunner = __importStar(require("@actions/exec/lib/toolrunner"));
|
||||||
|
const io = __importStar(require("@actions/io"));
|
||||||
|
const actionsToolcache = __importStar(require("@actions/tool-cache"));
|
||||||
|
const safeWhich = __importStar(require("@chrisgavin/safe-which"));
|
||||||
|
const del_1 = __importDefault(require("del"));
|
||||||
|
const semver = __importStar(require("semver"));
|
||||||
|
const uuid_1 = require("uuid");
|
||||||
|
const util_1 = require("./util");
|
||||||
|
/*
|
||||||
|
* This file acts as an interface to the functionality of the actions toolcache.
|
||||||
|
* That library is not safe to use outside of actions as it makes assumptions about
|
||||||
|
* the state of the filesystem and available environment variables.
|
||||||
|
*
|
||||||
|
* On actions we can just delegate to the toolcache library, however outside of
|
||||||
|
* actions we provide our own implementation.
|
||||||
|
*/
|
||||||
|
/**
|
||||||
|
* Extract a compressed tar archive.
|
||||||
|
*
|
||||||
|
* See extractTar function from node_modules/@actions/tool-cache/lib/tool-cache.d.ts
|
||||||
|
*
|
||||||
|
* @param file path to the tar
|
||||||
|
* @param mode should run the actions or runner implementation
|
||||||
|
* @param tempDir path to the temporary directory
|
||||||
|
* @param logger logger to use
|
||||||
|
* @returns path to the destination directory
|
||||||
|
*/
|
||||||
|
async function extractTar(file, tempDir, logger) {
|
||||||
|
if ((0, util_1.isActions)()) {
|
||||||
|
return await actionsToolcache.extractTar(file);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// Initial implementation copied from node_modules/@actions/tool-cache/lib/tool-cache.js
|
||||||
|
if (!file) {
|
||||||
|
throw new Error("parameter 'file' is required");
|
||||||
|
}
|
||||||
|
// Create dest
|
||||||
|
const dest = createExtractFolder(tempDir);
|
||||||
|
// Determine whether GNU tar
|
||||||
|
logger.debug("Checking tar --version");
|
||||||
|
let versionOutput = "";
|
||||||
|
await new toolrunner.ToolRunner(await safeWhich.safeWhich("tar"), ["--version"], {
|
||||||
|
ignoreReturnCode: true,
|
||||||
|
silent: true,
|
||||||
|
listeners: {
|
||||||
|
stdout: (data) => (versionOutput += data.toString()),
|
||||||
|
stderr: (data) => (versionOutput += data.toString()),
|
||||||
|
},
|
||||||
|
}).exec();
|
||||||
|
logger.debug(versionOutput.trim());
|
||||||
|
const isGnuTar = versionOutput.toUpperCase().includes("GNU TAR");
|
||||||
|
// Initialize args
|
||||||
|
const args = ["xz"];
|
||||||
|
if (logger.isDebug()) {
|
||||||
|
args.push("-v");
|
||||||
|
}
|
||||||
|
let destArg = dest;
|
||||||
|
let fileArg = file;
|
||||||
|
if (process.platform === "win32" && isGnuTar) {
|
||||||
|
args.push("--force-local");
|
||||||
|
destArg = dest.replace(/\\/g, "/");
|
||||||
|
// Technically only the dest needs to have `/` but for aesthetic consistency
|
||||||
|
// convert slashes in the file arg too.
|
||||||
|
fileArg = file.replace(/\\/g, "/");
|
||||||
|
}
|
||||||
|
if (isGnuTar) {
|
||||||
|
// Suppress warnings when using GNU tar to extract archives created by BSD tar
|
||||||
|
args.push("--warning=no-unknown-keyword");
|
||||||
|
}
|
||||||
|
args.push("-C", destArg, "-f", fileArg);
|
||||||
|
await new toolrunner.ToolRunner(`tar`, args).exec();
|
||||||
|
return dest;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
exports.extractTar = extractTar;
|
||||||
|
/**
|
||||||
|
* Caches a directory and installs it into the tool cacheDir.
|
||||||
|
*
|
||||||
|
* Also see cacheDir function from node_modules/@actions/tool-cache/lib/tool-cache.d.ts
|
||||||
|
*
|
||||||
|
* @param sourceDir the directory to cache into tools
|
||||||
|
* @param tool tool name
|
||||||
|
* @param version version of the tool. semver format
|
||||||
|
* @param mode should run the actions or runner implementation
|
||||||
|
* @param toolCacheDir path to the tool cache directory
|
||||||
|
* @param logger logger to use
|
||||||
|
*/
|
||||||
|
async function cacheDir(sourceDir, tool, version, toolCacheDir, logger) {
|
||||||
|
if ((0, util_1.isActions)()) {
|
||||||
|
return await actionsToolcache.cacheDir(sourceDir, tool, version);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// Initial implementation copied from node_modules/@actions/tool-cache/lib/tool-cache.js
|
||||||
|
version = semver.clean(version) || version;
|
||||||
|
const arch = os.arch();
|
||||||
|
logger.debug(`Caching tool ${tool} ${version} ${arch}`);
|
||||||
|
logger.debug(`source dir: ${sourceDir}`);
|
||||||
|
if (!fs.statSync(sourceDir).isDirectory()) {
|
||||||
|
throw new Error("sourceDir is not a directory");
|
||||||
|
}
|
||||||
|
// Create the tool dir
|
||||||
|
const destPath = await createToolPath(tool, version, arch, toolCacheDir, logger);
|
||||||
|
// copy each child item. do not move. move can fail on Windows
|
||||||
|
// due to anti-virus software having an open handle on a file.
|
||||||
|
for (const itemName of fs.readdirSync(sourceDir)) {
|
||||||
|
const s = path.join(sourceDir, itemName);
|
||||||
|
await io.cp(s, destPath, { recursive: true });
|
||||||
|
}
|
||||||
|
// write .complete
|
||||||
|
completeToolPath(tool, version, arch, toolCacheDir, logger);
|
||||||
|
return destPath;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
exports.cacheDir = cacheDir;
|
||||||
|
/**
|
||||||
|
* Finds the path to a tool version in the local installed tool cache.
|
||||||
|
*
|
||||||
|
* Also see find function from node_modules/@actions/tool-cache/lib/tool-cache.d.ts
|
||||||
|
*
|
||||||
|
* @param toolName name of the tool
|
||||||
|
* @param versionSpec version of the tool
|
||||||
|
* @param mode should run the actions or runner implementation
|
||||||
|
* @param toolCacheDir path to the tool cache directory
|
||||||
|
* @param logger logger to use
|
||||||
|
*/
|
||||||
|
function find(toolName, versionSpec, toolCacheDir, logger) {
|
||||||
|
if ((0, util_1.isActions)()) {
|
||||||
|
return actionsToolcache.find(toolName, versionSpec);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// Initial implementation copied from node_modules/@actions/tool-cache/lib/tool-cache.js
|
||||||
|
if (!toolName) {
|
||||||
|
throw new Error("toolName parameter is required");
|
||||||
|
}
|
||||||
|
if (!versionSpec) {
|
||||||
|
throw new Error("versionSpec parameter is required");
|
||||||
|
}
|
||||||
|
const arch = os.arch();
|
||||||
|
// attempt to resolve an explicit version
|
||||||
|
if (!isExplicitVersion(versionSpec, logger)) {
|
||||||
|
const localVersions = findAllVersions(toolName, toolCacheDir, logger);
|
||||||
|
const match = evaluateVersions(localVersions, versionSpec, logger);
|
||||||
|
versionSpec = match;
|
||||||
|
}
|
||||||
|
// check for the explicit version in the cache
|
||||||
|
let toolPath = "";
|
||||||
|
if (versionSpec) {
|
||||||
|
versionSpec = semver.clean(versionSpec) || "";
|
||||||
|
const cachePath = path.join(toolCacheDir, toolName, versionSpec, arch);
|
||||||
|
logger.debug(`checking cache: ${cachePath}`);
|
||||||
|
if (fs.existsSync(cachePath) && fs.existsSync(`${cachePath}.complete`)) {
|
||||||
|
logger.debug(`Found tool in cache ${toolName} ${versionSpec} ${arch}`);
|
||||||
|
toolPath = cachePath;
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
logger.debug("not found");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return toolPath;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
exports.find = find;
|
||||||
|
/**
|
||||||
|
* Finds the paths to all versions of a tool that are installed in the local tool cache.
|
||||||
|
*
|
||||||
|
* Also see findAllVersions function from node_modules/@actions/tool-cache/lib/tool-cache.d.ts
|
||||||
|
*
|
||||||
|
* @param toolName name of the tool
|
||||||
|
* @param toolCacheDir path to the tool cache directory
|
||||||
|
* @param logger logger to use
|
||||||
|
*/
|
||||||
|
function findAllVersions(toolName, toolCacheDir, logger) {
|
||||||
|
if ((0, util_1.isActions)()) {
|
||||||
|
return actionsToolcache.findAllVersions(toolName);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
// Initial implementation copied from node_modules/@actions/tool-cache/lib/tool-cache.js
|
||||||
|
const versions = [];
|
||||||
|
const arch = os.arch();
|
||||||
|
const toolPath = path.join(toolCacheDir, toolName);
|
||||||
|
if (fs.existsSync(toolPath)) {
|
||||||
|
const children = fs.readdirSync(toolPath);
|
||||||
|
for (const child of children) {
|
||||||
|
if (isExplicitVersion(child, logger)) {
|
||||||
|
const fullPath = path.join(toolPath, child, arch || "");
|
||||||
|
if (fs.existsSync(fullPath) &&
|
||||||
|
fs.existsSync(`${fullPath}.complete`)) {
|
||||||
|
versions.push(child);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return versions;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
exports.findAllVersions = findAllVersions;
|
||||||
|
async function downloadTool(url, tempDir, headers) {
|
||||||
|
const dest = path.join(tempDir, (0, uuid_1.v4)());
|
||||||
|
const finalHeaders = Object.assign({ "User-Agent": "CodeQL Action" }, headers);
|
||||||
|
return await actionsToolcache.downloadTool(url, dest, undefined, finalHeaders);
|
||||||
|
}
|
||||||
|
exports.downloadTool = downloadTool;
|
||||||
|
function createExtractFolder(tempDir) {
|
||||||
|
// create a temp dir
|
||||||
|
const dest = path.join(tempDir, "toolcache-temp");
|
||||||
|
if (!fs.existsSync(dest)) {
|
||||||
|
fs.mkdirSync(dest);
|
||||||
|
}
|
||||||
|
return dest;
|
||||||
|
}
|
||||||
|
async function createToolPath(tool, version, arch, toolCacheDir, logger) {
|
||||||
|
const folderPath = path.join(toolCacheDir, tool, semver.clean(version) || version, arch || "");
|
||||||
|
logger.debug(`destination ${folderPath}`);
|
||||||
|
const markerPath = `${folderPath}.complete`;
|
||||||
|
await (0, del_1.default)(folderPath, { force: true });
|
||||||
|
await (0, del_1.default)(markerPath, { force: true });
|
||||||
|
fs.mkdirSync(folderPath, { recursive: true });
|
||||||
|
return folderPath;
|
||||||
|
}
|
||||||
|
function completeToolPath(tool, version, arch, toolCacheDir, logger) {
|
||||||
|
const folderPath = path.join(toolCacheDir, tool, semver.clean(version) || version, arch || "");
|
||||||
|
const markerPath = `${folderPath}.complete`;
|
||||||
|
fs.writeFileSync(markerPath, "");
|
||||||
|
logger.debug("finished caching tool");
|
||||||
|
}
|
||||||
|
function isExplicitVersion(versionSpec, logger) {
|
||||||
|
const c = semver.clean(versionSpec) || "";
|
||||||
|
logger.debug(`isExplicit: ${c}`);
|
||||||
|
const valid = semver.valid(c) != null;
|
||||||
|
logger.debug(`explicit? ${valid}`);
|
||||||
|
return valid;
|
||||||
|
}
|
||||||
|
function evaluateVersions(versions, versionSpec, logger) {
|
||||||
|
let version = "";
|
||||||
|
logger.debug(`evaluating ${versions.length} versions`);
|
||||||
|
versions = versions.sort((a, b) => {
|
||||||
|
if (semver.gt(a, b)) {
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
return -1;
|
||||||
|
});
|
||||||
|
for (let i = versions.length - 1; i >= 0; i--) {
|
||||||
|
const potential = versions[i];
|
||||||
|
const satisfied = semver.satisfies(potential, versionSpec);
|
||||||
|
if (satisfied) {
|
||||||
|
version = potential;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (version) {
|
||||||
|
logger.debug(`matched: ${version}`);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
logger.debug("match not found");
|
||||||
|
}
|
||||||
|
return version;
|
||||||
|
}
|
||||||
|
//# sourceMappingURL=toolcache.js.map
|
||||||
1
lib/toolcache.js.map
Normal file
1
lib/toolcache.js.map
Normal file
File diff suppressed because one or more lines are too long
1
lib/tracer-config.test.js
generated
1
lib/tracer-config.test.js
generated
@@ -39,6 +39,7 @@ function getTestConfig(tmpDir) {
|
|||||||
paths: [],
|
paths: [],
|
||||||
originalUserInput: {},
|
originalUserInput: {},
|
||||||
tempDir: tmpDir,
|
tempDir: tmpDir,
|
||||||
|
toolCacheDir: tmpDir,
|
||||||
codeQLCmd: "",
|
codeQLCmd: "",
|
||||||
gitHubVersion: { type: util.GitHubVariant.DOTCOM },
|
gitHubVersion: { type: util.GitHubVariant.DOTCOM },
|
||||||
dbLocation: path.resolve(tmpDir, "codeql_databases"),
|
dbLocation: path.resolve(tmpDir, "codeql_databases"),
|
||||||
|
|||||||
File diff suppressed because one or more lines are too long
19
lib/util.js
generated
19
lib/util.js
generated
@@ -33,6 +33,7 @@ const api = __importStar(require("./api-client"));
|
|||||||
const api_client_1 = require("./api-client");
|
const api_client_1 = require("./api-client");
|
||||||
const apiCompatibility = __importStar(require("./api-compatibility.json"));
|
const apiCompatibility = __importStar(require("./api-compatibility.json"));
|
||||||
const codeql_1 = require("./codeql");
|
const codeql_1 = require("./codeql");
|
||||||
|
const config_utils_1 = require("./config-utils");
|
||||||
/**
|
/**
|
||||||
* Specifies bundle versions that are known to be broken
|
* Specifies bundle versions that are known to be broken
|
||||||
* and will not be used if found in the toolcache.
|
* and will not be used if found in the toolcache.
|
||||||
@@ -89,7 +90,11 @@ exports.getToolNames = getToolNames;
|
|||||||
// Mostly intended for use within tests.
|
// Mostly intended for use within tests.
|
||||||
async function withTmpDir(body) {
|
async function withTmpDir(body) {
|
||||||
const tmpDir = fs.mkdtempSync(path.join(os.tmpdir(), "codeql-action-"));
|
const tmpDir = fs.mkdtempSync(path.join(os.tmpdir(), "codeql-action-"));
|
||||||
const result = await body(tmpDir);
|
const realSubdir = path.join(tmpDir, "real");
|
||||||
|
fs.mkdirSync(realSubdir);
|
||||||
|
const symlinkSubdir = path.join(tmpDir, "symlink");
|
||||||
|
fs.symlinkSync(realSubdir, symlinkSubdir, "dir");
|
||||||
|
const result = await body(symlinkSubdir);
|
||||||
await (0, del_1.default)(tmpDir, { force: true });
|
await (0, del_1.default)(tmpDir, { force: true });
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
@@ -558,7 +563,10 @@ async function getMlPoweredJsQueriesPack(codeQL) {
|
|||||||
else {
|
else {
|
||||||
version = `~0.1.0`;
|
version = `~0.1.0`;
|
||||||
}
|
}
|
||||||
return `${exports.ML_POWERED_JS_QUERIES_PACK_NAME}@${version}`;
|
return (0, config_utils_1.prettyPrintPack)({
|
||||||
|
name: exports.ML_POWERED_JS_QUERIES_PACK_NAME,
|
||||||
|
version,
|
||||||
|
});
|
||||||
}
|
}
|
||||||
exports.getMlPoweredJsQueriesPack = getMlPoweredJsQueriesPack;
|
exports.getMlPoweredJsQueriesPack = getMlPoweredJsQueriesPack;
|
||||||
/**
|
/**
|
||||||
@@ -584,9 +592,8 @@ exports.getMlPoweredJsQueriesPack = getMlPoweredJsQueriesPack;
|
|||||||
*/
|
*/
|
||||||
function getMlPoweredJsQueriesStatus(config) {
|
function getMlPoweredJsQueriesStatus(config) {
|
||||||
const mlPoweredJsQueryPacks = (config.packs.javascript || [])
|
const mlPoweredJsQueryPacks = (config.packs.javascript || [])
|
||||||
.map((pack) => pack.split("@"))
|
.map((p) => (0, config_utils_1.parsePacksSpecification)(p))
|
||||||
.filter((packNameVersion) => packNameVersion[0] === "codeql/javascript-experimental-atm-queries" &&
|
.filter((pack) => pack.name === "codeql/javascript-experimental-atm-queries" && !pack.path);
|
||||||
packNameVersion.length <= 2);
|
|
||||||
switch (mlPoweredJsQueryPacks.length) {
|
switch (mlPoweredJsQueryPacks.length) {
|
||||||
case 1:
|
case 1:
|
||||||
// We should always specify an explicit version string in `getMlPoweredJsQueriesPack`,
|
// We should always specify an explicit version string in `getMlPoweredJsQueriesPack`,
|
||||||
@@ -594,7 +601,7 @@ function getMlPoweredJsQueriesStatus(config) {
|
|||||||
// with each version of the CodeQL Action. Therefore in practice we should only hit the
|
// with each version of the CodeQL Action. Therefore in practice we should only hit the
|
||||||
// `latest` case here when customers have explicitly added the ML-powered query pack to their
|
// `latest` case here when customers have explicitly added the ML-powered query pack to their
|
||||||
// CodeQL config.
|
// CodeQL config.
|
||||||
return mlPoweredJsQueryPacks[0][1] || "latest";
|
return mlPoweredJsQueryPacks[0].version || "latest";
|
||||||
case 0:
|
case 0:
|
||||||
return "false";
|
return "false";
|
||||||
default:
|
default:
|
||||||
|
|||||||
File diff suppressed because one or more lines are too long
7
lib/util.test.js
generated
7
lib/util.test.js
generated
@@ -209,13 +209,13 @@ const ML_POWERED_JS_STATUS_TESTS = [
|
|||||||
// If no packs are loaded, status is false.
|
// If no packs are loaded, status is false.
|
||||||
[[], "false"],
|
[[], "false"],
|
||||||
// If another pack is loaded but not the ML-powered query pack, status is false.
|
// If another pack is loaded but not the ML-powered query pack, status is false.
|
||||||
[["someOtherPack"], "false"],
|
[["some-other/pack"], "false"],
|
||||||
// If the ML-powered query pack is loaded with a specific version, status is that version.
|
// If the ML-powered query pack is loaded with a specific version, status is that version.
|
||||||
[[`${util.ML_POWERED_JS_QUERIES_PACK_NAME}@~0.1.0`], "~0.1.0"],
|
[[`${util.ML_POWERED_JS_QUERIES_PACK_NAME}@~0.1.0`], "~0.1.0"],
|
||||||
// If the ML-powered query pack is loaded with a specific version and another pack is loaded, the
|
// If the ML-powered query pack is loaded with a specific version and another pack is loaded, the
|
||||||
// status is the version of the ML-powered query pack.
|
// status is the version of the ML-powered query pack.
|
||||||
[
|
[
|
||||||
["someOtherPack", `${util.ML_POWERED_JS_QUERIES_PACK_NAME}@~0.1.0`],
|
["some-other/pack", `${util.ML_POWERED_JS_QUERIES_PACK_NAME}@~0.1.0`],
|
||||||
"~0.1.0",
|
"~0.1.0",
|
||||||
],
|
],
|
||||||
// If the ML-powered query pack is loaded without a version, the status is "latest".
|
// If the ML-powered query pack is loaded without a version, the status is "latest".
|
||||||
@@ -230,7 +230,7 @@ const ML_POWERED_JS_STATUS_TESTS = [
|
|||||||
],
|
],
|
||||||
// If the ML-powered query pack is loaded with no specific version, and another pack is loaded,
|
// If the ML-powered query pack is loaded with no specific version, and another pack is loaded,
|
||||||
// the status is "latest".
|
// the status is "latest".
|
||||||
[["someOtherPack", util.ML_POWERED_JS_QUERIES_PACK_NAME], "latest"],
|
[["some-other/pack", util.ML_POWERED_JS_QUERIES_PACK_NAME], "latest"],
|
||||||
];
|
];
|
||||||
for (const [packs, expectedStatus] of ML_POWERED_JS_STATUS_TESTS) {
|
for (const [packs, expectedStatus] of ML_POWERED_JS_STATUS_TESTS) {
|
||||||
const packDescriptions = `[${packs
|
const packDescriptions = `[${packs
|
||||||
@@ -245,6 +245,7 @@ for (const [packs, expectedStatus] of ML_POWERED_JS_STATUS_TESTS) {
|
|||||||
pathsIgnore: [],
|
pathsIgnore: [],
|
||||||
originalUserInput: {},
|
originalUserInput: {},
|
||||||
tempDir: tmpDir,
|
tempDir: tmpDir,
|
||||||
|
toolCacheDir: tmpDir,
|
||||||
codeQLCmd: "",
|
codeQLCmd: "",
|
||||||
gitHubVersion: {
|
gitHubVersion: {
|
||||||
type: util.GitHubVariant.DOTCOM,
|
type: util.GitHubVariant.DOTCOM,
|
||||||
|
|||||||
File diff suppressed because one or more lines are too long
8
node_modules/.package-lock.json
generated
vendored
8
node_modules/.package-lock.json
generated
vendored
@@ -1,6 +1,6 @@
|
|||||||
{
|
{
|
||||||
"name": "codeql",
|
"name": "codeql",
|
||||||
"version": "2.1.17",
|
"version": "1.1.13",
|
||||||
"lockfileVersion": 2,
|
"lockfileVersion": 2,
|
||||||
"requires": true,
|
"requires": true,
|
||||||
"packages": {
|
"packages": {
|
||||||
@@ -493,9 +493,9 @@
|
|||||||
"dev": true
|
"dev": true
|
||||||
},
|
},
|
||||||
"node_modules/@types/node": {
|
"node_modules/@types/node": {
|
||||||
"version": "16.11.22",
|
"version": "12.12.70",
|
||||||
"resolved": "https://registry.npmjs.org/@types/node/-/node-16.11.22.tgz",
|
"resolved": "https://registry.npmjs.org/@types/node/-/node-12.12.70.tgz",
|
||||||
"integrity": "sha512-DYNtJWauMQ9RNpesl4aVothr97/tIJM8HbyOXJ0AYT1Z2bEjLHyfjOBPAQQVMLf8h3kSShYfNk8Wnto8B2zHUA=="
|
"integrity": "sha512-i5y7HTbvhonZQE+GnUM2rz1Bi8QkzxdQmEv1LKOv4nWyaQk/gdeiTApuQR3PDJHX7WomAbpx2wlWSEpxXGZ/UQ=="
|
||||||
},
|
},
|
||||||
"node_modules/@types/semver": {
|
"node_modules/@types/semver": {
|
||||||
"version": "7.3.8",
|
"version": "7.3.8",
|
||||||
|
|||||||
0
node_modules/@types/node/LICENSE
generated
vendored
Executable file → Normal file
0
node_modules/@types/node/LICENSE
generated
vendored
Executable file → Normal file
10
node_modules/@types/node/README.md
generated
vendored
Executable file → Normal file
10
node_modules/@types/node/README.md
generated
vendored
Executable file → Normal file
@@ -2,15 +2,15 @@
|
|||||||
> `npm install --save @types/node`
|
> `npm install --save @types/node`
|
||||||
|
|
||||||
# Summary
|
# Summary
|
||||||
This package contains type definitions for Node.js (https://nodejs.org/).
|
This package contains type definitions for Node.js (http://nodejs.org/).
|
||||||
|
|
||||||
# Details
|
# Details
|
||||||
Files were exported from https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/node/v16.
|
Files were exported from https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/node/v12.
|
||||||
|
|
||||||
### Additional Details
|
### Additional Details
|
||||||
* Last updated: Tue, 01 Feb 2022 08:31:30 GMT
|
* Last updated: Wed, 21 Oct 2020 17:47:46 GMT
|
||||||
* Dependencies: none
|
* Dependencies: none
|
||||||
* Global values: `AbortController`, `AbortSignal`, `__dirname`, `__filename`, `console`, `exports`, `gc`, `global`, `module`, `process`, `require`
|
* Global values: `Buffer`, `NodeJS`, `__dirname`, `__filename`, `clearImmediate`, `clearInterval`, `clearTimeout`, `console`, `exports`, `global`, `module`, `process`, `queueMicrotask`, `require`, `setImmediate`, `setInterval`, `setTimeout`
|
||||||
|
|
||||||
# Credits
|
# Credits
|
||||||
These definitions were written by [Microsoft TypeScript](https://github.com/Microsoft), [DefinitelyTyped](https://github.com/DefinitelyTyped), [Alberto Schiabel](https://github.com/jkomyno), [Alvis HT Tang](https://github.com/alvis), [Andrew Makarov](https://github.com/r3nya), [Benjamin Toueg](https://github.com/btoueg), [Chigozirim C.](https://github.com/smac89), [David Junger](https://github.com/touffy), [Deividas Bakanas](https://github.com/DeividasBakanas), [Eugene Y. Q. Shen](https://github.com/eyqs), [Hannes Magnusson](https://github.com/Hannes-Magnusson-CK), [Huw](https://github.com/hoo29), [Kelvin Jin](https://github.com/kjin), [Klaus Meinhardt](https://github.com/ajafff), [Lishude](https://github.com/islishude), [Mariusz Wiktorczyk](https://github.com/mwiktorczyk), [Mohsen Azimi](https://github.com/mohsen1), [Nicolas Even](https://github.com/n-e), [Nikita Galkin](https://github.com/galkin), [Parambir Singh](https://github.com/parambirs), [Sebastian Silbermann](https://github.com/eps1lon), [Seth Westphal](https://github.com/westy92), [Simon Schick](https://github.com/SimonSchick), [Thomas den Hollander](https://github.com/ThomasdenH), [Wilco Bakker](https://github.com/WilcoBakker), [wwwy3y3](https://github.com/wwwy3y3), [Samuel Ainsworth](https://github.com/samuela), [Kyle Uehlein](https://github.com/kuehlein), [Thanik Bhongbhibhat](https://github.com/bhongy), [Marcin Kopacz](https://github.com/chyzwar), [Trivikram Kamat](https://github.com/trivikr), [Junxiao Shi](https://github.com/yoursunny), [Ilia Baryshnikov](https://github.com/qwelias), [ExE Boss](https://github.com/ExE-Boss), [Piotr Błażejewicz](https://github.com/peterblazejewicz), [Anna Henningsen](https://github.com/addaleax), [Victor Perin](https://github.com/victorperin), [Yongsheng Zhang](https://github.com/ZYSzys), [NodeJS Contributors](https://github.com/NodeJS), [Linus Unnebäck](https://github.com/LinusU), and [wafuwafu13](https://github.com/wafuwafu13).
|
These definitions were written by [Microsoft TypeScript](https://github.com/Microsoft), [DefinitelyTyped](https://github.com/DefinitelyTyped), [Alberto Schiabel](https://github.com/jkomyno), [Alexander T.](https://github.com/a-tarasyuk), [Alvis HT Tang](https://github.com/alvis), [Andrew Makarov](https://github.com/r3nya), [Benjamin Toueg](https://github.com/btoueg), [Bruno Scheufler](https://github.com/brunoscheufler), [Chigozirim C.](https://github.com/smac89), [David Junger](https://github.com/touffy), [Deividas Bakanas](https://github.com/DeividasBakanas), [Eugene Y. Q. Shen](https://github.com/eyqs), [Flarna](https://github.com/Flarna), [Hannes Magnusson](https://github.com/Hannes-Magnusson-CK), [Hoàng Văn Khải](https://github.com/KSXGitHub), [Huw](https://github.com/hoo29), [Kelvin Jin](https://github.com/kjin), [Klaus Meinhardt](https://github.com/ajafff), [Lishude](https://github.com/islishude), [Mariusz Wiktorczyk](https://github.com/mwiktorczyk), [Mohsen Azimi](https://github.com/mohsen1), [Nicolas Even](https://github.com/n-e), [Nikita Galkin](https://github.com/galkin), [Parambir Singh](https://github.com/parambirs), [Sebastian Silbermann](https://github.com/eps1lon), [Simon Schick](https://github.com/SimonSchick), [Thomas den Hollander](https://github.com/ThomasdenH), [Wilco Bakker](https://github.com/WilcoBakker), [wwwy3y3](https://github.com/wwwy3y3), [Zane Hannan AU](https://github.com/ZaneHannanAU), [Samuel Ainsworth](https://github.com/samuela), [Kyle Uehlein](https://github.com/kuehlein), [Jordi Oliveras Rovira](https://github.com/j-oliveras), [Thanik Bhongbhibhat](https://github.com/bhongy), [Marcin Kopacz](https://github.com/chyzwar), [Trivikram Kamat](https://github.com/trivikr), [Minh Son Nguyen](https://github.com/nguymin4), [Junxiao Shi](https://github.com/yoursunny), [Ilia Baryshnikov](https://github.com/qwelias), [ExE Boss](https://github.com/ExE-Boss), and [Jason Kwok](https://github.com/JasonHK).
|
||||||
|
|||||||
963
node_modules/@types/node/assert.d.ts
generated
vendored
Executable file → Normal file
963
node_modules/@types/node/assert.d.ts
generated
vendored
Executable file → Normal file
@@ -1,912 +1,91 @@
|
|||||||
/**
|
|
||||||
* The `assert` module provides a set of assertion functions for verifying
|
|
||||||
* invariants.
|
|
||||||
* @see [source](https://github.com/nodejs/node/blob/v16.9.0/lib/assert.js)
|
|
||||||
*/
|
|
||||||
declare module 'assert' {
|
declare module 'assert' {
|
||||||
/**
|
function assert(value: any, message?: string | Error): asserts value;
|
||||||
* An alias of {@link ok}.
|
|
||||||
* @since v0.5.9
|
|
||||||
* @param value The input that is checked for being truthy.
|
|
||||||
*/
|
|
||||||
function assert(value: unknown, message?: string | Error): asserts value;
|
|
||||||
namespace assert {
|
namespace assert {
|
||||||
/**
|
class AssertionError implements Error {
|
||||||
* Indicates the failure of an assertion. All errors thrown by the `assert` module
|
name: string;
|
||||||
* will be instances of the `AssertionError` class.
|
message: string;
|
||||||
*/
|
actual: any;
|
||||||
class AssertionError extends Error {
|
expected: any;
|
||||||
actual: unknown;
|
|
||||||
expected: unknown;
|
|
||||||
operator: string;
|
operator: string;
|
||||||
generatedMessage: boolean;
|
generatedMessage: boolean;
|
||||||
code: 'ERR_ASSERTION';
|
code: 'ERR_ASSERTION';
|
||||||
|
|
||||||
constructor(options?: {
|
constructor(options?: {
|
||||||
/** If provided, the error message is set to this value. */
|
message?: string;
|
||||||
message?: string | undefined;
|
actual?: any;
|
||||||
/** The `actual` property on the error instance. */
|
expected?: any;
|
||||||
actual?: unknown | undefined;
|
operator?: string;
|
||||||
/** The `expected` property on the error instance. */
|
stackStartFn?: Function;
|
||||||
expected?: unknown | undefined;
|
|
||||||
/** The `operator` property on the error instance. */
|
|
||||||
operator?: string | undefined;
|
|
||||||
/** If provided, the generated stack trace omits frames before this function. */
|
|
||||||
// tslint:disable-next-line:ban-types
|
|
||||||
stackStartFn?: Function | undefined;
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
/**
|
|
||||||
* This feature is currently experimental and behavior might still change.
|
|
||||||
* @since v14.2.0, v12.19.0
|
|
||||||
* @experimental
|
|
||||||
*/
|
|
||||||
class CallTracker {
|
|
||||||
/**
|
|
||||||
* The wrapper function is expected to be called exactly `exact` times. If the
|
|
||||||
* function has not been called exactly `exact` times when `tracker.verify()` is called, then `tracker.verify()` will throw an
|
|
||||||
* error.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import assert from 'assert';
|
|
||||||
*
|
|
||||||
* // Creates call tracker.
|
|
||||||
* const tracker = new assert.CallTracker();
|
|
||||||
*
|
|
||||||
* function func() {}
|
|
||||||
*
|
|
||||||
* // Returns a function that wraps func() that must be called exact times
|
|
||||||
* // before tracker.verify().
|
|
||||||
* const callsfunc = tracker.calls(func);
|
|
||||||
* ```
|
|
||||||
* @since v14.2.0, v12.19.0
|
|
||||||
* @param [fn='A no-op function']
|
|
||||||
* @param [exact=1]
|
|
||||||
* @return that wraps `fn`.
|
|
||||||
*/
|
|
||||||
calls(exact?: number): () => void;
|
|
||||||
calls<Func extends (...args: any[]) => any>(fn?: Func, exact?: number): Func;
|
|
||||||
/**
|
|
||||||
* The arrays contains information about the expected and actual number of calls of
|
|
||||||
* the functions that have not been called the expected number of times.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import assert from 'assert';
|
|
||||||
*
|
|
||||||
* // Creates call tracker.
|
|
||||||
* const tracker = new assert.CallTracker();
|
|
||||||
*
|
|
||||||
* function func() {}
|
|
||||||
*
|
|
||||||
* function foo() {}
|
|
||||||
*
|
|
||||||
* // Returns a function that wraps func() that must be called exact times
|
|
||||||
* // before tracker.verify().
|
|
||||||
* const callsfunc = tracker.calls(func, 2);
|
|
||||||
*
|
|
||||||
* // Returns an array containing information on callsfunc()
|
|
||||||
* tracker.report();
|
|
||||||
* // [
|
|
||||||
* // {
|
|
||||||
* // message: 'Expected the func function to be executed 2 time(s) but was
|
|
||||||
* // executed 0 time(s).',
|
|
||||||
* // actual: 0,
|
|
||||||
* // expected: 2,
|
|
||||||
* // operator: 'func',
|
|
||||||
* // stack: stack trace
|
|
||||||
* // }
|
|
||||||
* // ]
|
|
||||||
* ```
|
|
||||||
* @since v14.2.0, v12.19.0
|
|
||||||
* @return of objects containing information about the wrapper functions returned by `calls`.
|
|
||||||
*/
|
|
||||||
report(): CallTrackerReportInformation[];
|
|
||||||
/**
|
|
||||||
* Iterates through the list of functions passed to `tracker.calls()` and will throw an error for functions that
|
|
||||||
* have not been called the expected number of times.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import assert from 'assert';
|
|
||||||
*
|
|
||||||
* // Creates call tracker.
|
|
||||||
* const tracker = new assert.CallTracker();
|
|
||||||
*
|
|
||||||
* function func() {}
|
|
||||||
*
|
|
||||||
* // Returns a function that wraps func() that must be called exact times
|
|
||||||
* // before tracker.verify().
|
|
||||||
* const callsfunc = tracker.calls(func, 2);
|
|
||||||
*
|
|
||||||
* callsfunc();
|
|
||||||
*
|
|
||||||
* // Will throw an error since callsfunc() was only called once.
|
|
||||||
* tracker.verify();
|
|
||||||
* ```
|
|
||||||
* @since v14.2.0, v12.19.0
|
|
||||||
*/
|
|
||||||
verify(): void;
|
|
||||||
}
|
|
||||||
interface CallTrackerReportInformation {
|
|
||||||
message: string;
|
|
||||||
/** The actual number of times the function was called. */
|
|
||||||
actual: number;
|
|
||||||
/** The number of times the function was expected to be called. */
|
|
||||||
expected: number;
|
|
||||||
/** The name of the function that is wrapped. */
|
|
||||||
operator: string;
|
|
||||||
/** A stack trace of the function. */
|
|
||||||
stack: object;
|
|
||||||
}
|
|
||||||
type AssertPredicate = RegExp | (new () => object) | ((thrown: unknown) => boolean) | object | Error;
|
|
||||||
/**
|
|
||||||
* Throws an `AssertionError` with the provided error message or a default
|
|
||||||
* error message. If the `message` parameter is an instance of an `Error` then
|
|
||||||
* it will be thrown instead of the `AssertionError`.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import assert from 'assert/strict';
|
|
||||||
*
|
|
||||||
* assert.fail();
|
|
||||||
* // AssertionError [ERR_ASSERTION]: Failed
|
|
||||||
*
|
|
||||||
* assert.fail('boom');
|
|
||||||
* // AssertionError [ERR_ASSERTION]: boom
|
|
||||||
*
|
|
||||||
* assert.fail(new TypeError('need array'));
|
|
||||||
* // TypeError: need array
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Using `assert.fail()` with more than two arguments is possible but deprecated.
|
|
||||||
* See below for further details.
|
|
||||||
* @since v0.1.21
|
|
||||||
* @param [message='Failed']
|
|
||||||
*/
|
|
||||||
function fail(message?: string | Error): never;
|
function fail(message?: string | Error): never;
|
||||||
/** @deprecated since v10.0.0 - use fail([message]) or other assert functions instead. */
|
/** @deprecated since v10.0.0 - use fail([message]) or other assert functions instead. */
|
||||||
function fail(
|
function fail(
|
||||||
actual: unknown,
|
actual: any,
|
||||||
expected: unknown,
|
expected: any,
|
||||||
message?: string | Error,
|
message?: string | Error,
|
||||||
operator?: string,
|
operator?: string,
|
||||||
// tslint:disable-next-line:ban-types
|
stackStartFn?: Function,
|
||||||
stackStartFn?: Function
|
|
||||||
): never;
|
): never;
|
||||||
/**
|
function ok(value: any, message?: string | Error): asserts value;
|
||||||
* Tests if `value` is truthy. It is equivalent to`assert.equal(!!value, true, message)`.
|
/** @deprecated since v9.9.0 - use strictEqual() instead. */
|
||||||
*
|
function equal(actual: any, expected: any, message?: string | Error): void;
|
||||||
* If `value` is not truthy, an `AssertionError` is thrown with a `message`property set equal to the value of the `message` parameter. If the `message`parameter is `undefined`, a default
|
/** @deprecated since v9.9.0 - use notStrictEqual() instead. */
|
||||||
* error message is assigned. If the `message`parameter is an instance of an `Error` then it will be thrown instead of the`AssertionError`.
|
function notEqual(actual: any, expected: any, message?: string | Error): void;
|
||||||
* If no arguments are passed in at all `message` will be set to the string:`` 'No value argument passed to `assert.ok()`' ``.
|
/** @deprecated since v9.9.0 - use deepStrictEqual() instead. */
|
||||||
*
|
function deepEqual(actual: any, expected: any, message?: string | Error): void;
|
||||||
* Be aware that in the `repl` the error message will be different to the one
|
/** @deprecated since v9.9.0 - use notDeepStrictEqual() instead. */
|
||||||
* thrown in a file! See below for further details.
|
function notDeepEqual(actual: any, expected: any, message?: string | Error): void;
|
||||||
*
|
function strictEqual<T>(actual: any, expected: T, message?: string | Error): asserts actual is T;
|
||||||
* ```js
|
function notStrictEqual(actual: any, expected: any, message?: string | Error): void;
|
||||||
* import assert from 'assert/strict';
|
function deepStrictEqual<T>(actual: any, expected: T, message?: string | Error): asserts actual is T;
|
||||||
*
|
function notDeepStrictEqual(actual: any, expected: any, message?: string | Error): void;
|
||||||
* assert.ok(true);
|
|
||||||
* // OK
|
function throws(block: () => any, message?: string | Error): void;
|
||||||
* assert.ok(1);
|
function throws(block: () => any, error: RegExp | Function | Object | Error, message?: string | Error): void;
|
||||||
* // OK
|
function doesNotThrow(block: () => any, message?: string | Error): void;
|
||||||
*
|
function doesNotThrow(block: () => any, error: RegExp | Function, message?: string | Error): void;
|
||||||
* assert.ok();
|
|
||||||
* // AssertionError: No value argument passed to `assert.ok()`
|
function ifError(value: any): asserts value is null | undefined;
|
||||||
*
|
|
||||||
* assert.ok(false, 'it\'s false');
|
function rejects(block: (() => Promise<any>) | Promise<any>, message?: string | Error): Promise<void>;
|
||||||
* // AssertionError: it's false
|
function rejects(
|
||||||
*
|
block: (() => Promise<any>) | Promise<any>,
|
||||||
* // In the repl:
|
error: RegExp | Function | Object | Error,
|
||||||
* assert.ok(typeof 123 === 'string');
|
message?: string | Error,
|
||||||
* // AssertionError: false == true
|
): Promise<void>;
|
||||||
*
|
function doesNotReject(block: (() => Promise<any>) | Promise<any>, message?: string | Error): Promise<void>;
|
||||||
* // In a file (e.g. test.js):
|
function doesNotReject(
|
||||||
* assert.ok(typeof 123 === 'string');
|
block: (() => Promise<any>) | Promise<any>,
|
||||||
* // AssertionError: The expression evaluated to a falsy value:
|
error: RegExp | Function,
|
||||||
* //
|
message?: string | Error,
|
||||||
* // assert.ok(typeof 123 === 'string')
|
): Promise<void>;
|
||||||
*
|
|
||||||
* assert.ok(false);
|
const strict: Omit<
|
||||||
* // AssertionError: The expression evaluated to a falsy value:
|
typeof assert,
|
||||||
* //
|
| 'strict'
|
||||||
* // assert.ok(false)
|
| 'deepEqual'
|
||||||
*
|
| 'notDeepEqual'
|
||||||
* assert.ok(0);
|
| 'equal'
|
||||||
* // AssertionError: The expression evaluated to a falsy value:
|
| 'notEqual'
|
||||||
* //
|
| 'ok'
|
||||||
* // assert.ok(0)
|
| 'strictEqual'
|
||||||
* ```
|
| 'deepStrictEqual'
|
||||||
*
|
| 'ifError'
|
||||||
* ```js
|
> & {
|
||||||
* import assert from 'assert/strict';
|
(value: any, message?: string | Error): asserts value;
|
||||||
*
|
strict: typeof strict;
|
||||||
* // Using `assert()` works the same:
|
|
||||||
* assert(0);
|
|
||||||
* // AssertionError: The expression evaluated to a falsy value:
|
|
||||||
* //
|
|
||||||
* // assert(0)
|
|
||||||
* ```
|
|
||||||
* @since v0.1.21
|
|
||||||
*/
|
|
||||||
function ok(value: unknown, message?: string | Error): asserts value;
|
|
||||||
/**
|
|
||||||
* **Strict assertion mode**
|
|
||||||
*
|
|
||||||
* An alias of {@link strictEqual}.
|
|
||||||
*
|
|
||||||
* **Legacy assertion mode**
|
|
||||||
*
|
|
||||||
* > Stability: 3 - Legacy: Use {@link strictEqual} instead.
|
|
||||||
*
|
|
||||||
* Tests shallow, coercive equality between the `actual` and `expected` parameters
|
|
||||||
* using the [Abstract Equality Comparison](https://tc39.github.io/ecma262/#sec-abstract-equality-comparison) ( `==` ). `NaN` is special handled
|
|
||||||
* and treated as being identical in case both sides are `NaN`.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import assert from 'assert';
|
|
||||||
*
|
|
||||||
* assert.equal(1, 1);
|
|
||||||
* // OK, 1 == 1
|
|
||||||
* assert.equal(1, '1');
|
|
||||||
* // OK, 1 == '1'
|
|
||||||
* assert.equal(NaN, NaN);
|
|
||||||
* // OK
|
|
||||||
*
|
|
||||||
* assert.equal(1, 2);
|
|
||||||
* // AssertionError: 1 == 2
|
|
||||||
* assert.equal({ a: { b: 1 } }, { a: { b: 1 } });
|
|
||||||
* // AssertionError: { a: { b: 1 } } == { a: { b: 1 } }
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* If the values are not equal, an `AssertionError` is thrown with a `message`property set equal to the value of the `message` parameter. If the `message`parameter is undefined, a default
|
|
||||||
* error message is assigned. If the `message`parameter is an instance of an `Error` then it will be thrown instead of the`AssertionError`.
|
|
||||||
* @since v0.1.21
|
|
||||||
*/
|
|
||||||
function equal(actual: unknown, expected: unknown, message?: string | Error): void;
|
|
||||||
/**
|
|
||||||
* **Strict assertion mode**
|
|
||||||
*
|
|
||||||
* An alias of {@link notStrictEqual}.
|
|
||||||
*
|
|
||||||
* **Legacy assertion mode**
|
|
||||||
*
|
|
||||||
* > Stability: 3 - Legacy: Use {@link notStrictEqual} instead.
|
|
||||||
*
|
|
||||||
* Tests shallow, coercive inequality with the [Abstract Equality Comparison](https://tc39.github.io/ecma262/#sec-abstract-equality-comparison)(`!=` ). `NaN` is special handled and treated as
|
|
||||||
* being identical in case both
|
|
||||||
* sides are `NaN`.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import assert from 'assert';
|
|
||||||
*
|
|
||||||
* assert.notEqual(1, 2);
|
|
||||||
* // OK
|
|
||||||
*
|
|
||||||
* assert.notEqual(1, 1);
|
|
||||||
* // AssertionError: 1 != 1
|
|
||||||
*
|
|
||||||
* assert.notEqual(1, '1');
|
|
||||||
* // AssertionError: 1 != '1'
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* If the values are equal, an `AssertionError` is thrown with a `message`property set equal to the value of the `message` parameter. If the `message`parameter is undefined, a default error
|
|
||||||
* message is assigned. If the `message`parameter is an instance of an `Error` then it will be thrown instead of the`AssertionError`.
|
|
||||||
* @since v0.1.21
|
|
||||||
*/
|
|
||||||
function notEqual(actual: unknown, expected: unknown, message?: string | Error): void;
|
|
||||||
/**
|
|
||||||
* **Strict assertion mode**
|
|
||||||
*
|
|
||||||
* An alias of {@link deepStrictEqual}.
|
|
||||||
*
|
|
||||||
* **Legacy assertion mode**
|
|
||||||
*
|
|
||||||
* > Stability: 3 - Legacy: Use {@link deepStrictEqual} instead.
|
|
||||||
*
|
|
||||||
* Tests for deep equality between the `actual` and `expected` parameters. Consider
|
|
||||||
* using {@link deepStrictEqual} instead. {@link deepEqual} can have
|
|
||||||
* surprising results.
|
|
||||||
*
|
|
||||||
* _Deep equality_ means that the enumerable "own" properties of child objects
|
|
||||||
* are also recursively evaluated by the following rules.
|
|
||||||
* @since v0.1.21
|
|
||||||
*/
|
|
||||||
function deepEqual(actual: unknown, expected: unknown, message?: string | Error): void;
|
|
||||||
/**
|
|
||||||
* **Strict assertion mode**
|
|
||||||
*
|
|
||||||
* An alias of {@link notDeepStrictEqual}.
|
|
||||||
*
|
|
||||||
* **Legacy assertion mode**
|
|
||||||
*
|
|
||||||
* > Stability: 3 - Legacy: Use {@link notDeepStrictEqual} instead.
|
|
||||||
*
|
|
||||||
* Tests for any deep inequality. Opposite of {@link deepEqual}.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import assert from 'assert';
|
|
||||||
*
|
|
||||||
* const obj1 = {
|
|
||||||
* a: {
|
|
||||||
* b: 1
|
|
||||||
* }
|
|
||||||
* };
|
|
||||||
* const obj2 = {
|
|
||||||
* a: {
|
|
||||||
* b: 2
|
|
||||||
* }
|
|
||||||
* };
|
|
||||||
* const obj3 = {
|
|
||||||
* a: {
|
|
||||||
* b: 1
|
|
||||||
* }
|
|
||||||
* };
|
|
||||||
* const obj4 = Object.create(obj1);
|
|
||||||
*
|
|
||||||
* assert.notDeepEqual(obj1, obj1);
|
|
||||||
* // AssertionError: { a: { b: 1 } } notDeepEqual { a: { b: 1 } }
|
|
||||||
*
|
|
||||||
* assert.notDeepEqual(obj1, obj2);
|
|
||||||
* // OK
|
|
||||||
*
|
|
||||||
* assert.notDeepEqual(obj1, obj3);
|
|
||||||
* // AssertionError: { a: { b: 1 } } notDeepEqual { a: { b: 1 } }
|
|
||||||
*
|
|
||||||
* assert.notDeepEqual(obj1, obj4);
|
|
||||||
* // OK
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* If the values are deeply equal, an `AssertionError` is thrown with a`message` property set equal to the value of the `message` parameter. If the`message` parameter is undefined, a default
|
|
||||||
* error message is assigned. If the`message` parameter is an instance of an `Error` then it will be thrown
|
|
||||||
* instead of the `AssertionError`.
|
|
||||||
* @since v0.1.21
|
|
||||||
*/
|
|
||||||
function notDeepEqual(actual: unknown, expected: unknown, message?: string | Error): void;
|
|
||||||
/**
|
|
||||||
* Tests strict equality between the `actual` and `expected` parameters as
|
|
||||||
* determined by the [SameValue Comparison](https://tc39.github.io/ecma262/#sec-samevalue).
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import assert from 'assert/strict';
|
|
||||||
*
|
|
||||||
* assert.strictEqual(1, 2);
|
|
||||||
* // AssertionError [ERR_ASSERTION]: Expected inputs to be strictly equal:
|
|
||||||
* //
|
|
||||||
* // 1 !== 2
|
|
||||||
*
|
|
||||||
* assert.strictEqual(1, 1);
|
|
||||||
* // OK
|
|
||||||
*
|
|
||||||
* assert.strictEqual('Hello foobar', 'Hello World!');
|
|
||||||
* // AssertionError [ERR_ASSERTION]: Expected inputs to be strictly equal:
|
|
||||||
* // + actual - expected
|
|
||||||
* //
|
|
||||||
* // + 'Hello foobar'
|
|
||||||
* // - 'Hello World!'
|
|
||||||
* // ^
|
|
||||||
*
|
|
||||||
* const apples = 1;
|
|
||||||
* const oranges = 2;
|
|
||||||
* assert.strictEqual(apples, oranges, `apples ${apples} !== oranges ${oranges}`);
|
|
||||||
* // AssertionError [ERR_ASSERTION]: apples 1 !== oranges 2
|
|
||||||
*
|
|
||||||
* assert.strictEqual(1, '1', new TypeError('Inputs are not identical'));
|
|
||||||
* // TypeError: Inputs are not identical
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* If the values are not strictly equal, an `AssertionError` is thrown with a`message` property set equal to the value of the `message` parameter. If the`message` parameter is undefined, a
|
|
||||||
* default error message is assigned. If the`message` parameter is an instance of an `Error` then it will be thrown
|
|
||||||
* instead of the `AssertionError`.
|
|
||||||
* @since v0.1.21
|
|
||||||
*/
|
|
||||||
function strictEqual<T>(actual: unknown, expected: T, message?: string | Error): asserts actual is T;
|
|
||||||
/**
|
|
||||||
* Tests strict inequality between the `actual` and `expected` parameters as
|
|
||||||
* determined by the [SameValue Comparison](https://tc39.github.io/ecma262/#sec-samevalue).
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import assert from 'assert/strict';
|
|
||||||
*
|
|
||||||
* assert.notStrictEqual(1, 2);
|
|
||||||
* // OK
|
|
||||||
*
|
|
||||||
* assert.notStrictEqual(1, 1);
|
|
||||||
* // AssertionError [ERR_ASSERTION]: Expected "actual" to be strictly unequal to:
|
|
||||||
* //
|
|
||||||
* // 1
|
|
||||||
*
|
|
||||||
* assert.notStrictEqual(1, '1');
|
|
||||||
* // OK
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* If the values are strictly equal, an `AssertionError` is thrown with a`message` property set equal to the value of the `message` parameter. If the`message` parameter is undefined, a
|
|
||||||
* default error message is assigned. If the`message` parameter is an instance of an `Error` then it will be thrown
|
|
||||||
* instead of the `AssertionError`.
|
|
||||||
* @since v0.1.21
|
|
||||||
*/
|
|
||||||
function notStrictEqual(actual: unknown, expected: unknown, message?: string | Error): void;
|
|
||||||
/**
|
|
||||||
* Tests for deep equality between the `actual` and `expected` parameters.
|
|
||||||
* "Deep" equality means that the enumerable "own" properties of child objects
|
|
||||||
* are recursively evaluated also by the following rules.
|
|
||||||
* @since v1.2.0
|
|
||||||
*/
|
|
||||||
function deepStrictEqual<T>(actual: unknown, expected: T, message?: string | Error): asserts actual is T;
|
|
||||||
/**
|
|
||||||
* Tests for deep strict inequality. Opposite of {@link deepStrictEqual}.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import assert from 'assert/strict';
|
|
||||||
*
|
|
||||||
* assert.notDeepStrictEqual({ a: 1 }, { a: '1' });
|
|
||||||
* // OK
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* If the values are deeply and strictly equal, an `AssertionError` is thrown
|
|
||||||
* with a `message` property set equal to the value of the `message` parameter. If
|
|
||||||
* the `message` parameter is undefined, a default error message is assigned. If
|
|
||||||
* the `message` parameter is an instance of an `Error` then it will be thrown
|
|
||||||
* instead of the `AssertionError`.
|
|
||||||
* @since v1.2.0
|
|
||||||
*/
|
|
||||||
function notDeepStrictEqual(actual: unknown, expected: unknown, message?: string | Error): void;
|
|
||||||
/**
|
|
||||||
* Expects the function `fn` to throw an error.
|
|
||||||
*
|
|
||||||
* If specified, `error` can be a [`Class`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Classes),
|
|
||||||
* [`RegExp`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions), a validation function,
|
|
||||||
* a validation object where each property will be tested for strict deep equality,
|
|
||||||
* or an instance of error where each property will be tested for strict deep
|
|
||||||
* equality including the non-enumerable `message` and `name` properties. When
|
|
||||||
* using an object, it is also possible to use a regular expression, when
|
|
||||||
* validating against a string property. See below for examples.
|
|
||||||
*
|
|
||||||
* If specified, `message` will be appended to the message provided by the`AssertionError` if the `fn` call fails to throw or in case the error validation
|
|
||||||
* fails.
|
|
||||||
*
|
|
||||||
* Custom validation object/error instance:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import assert from 'assert/strict';
|
|
||||||
*
|
|
||||||
* const err = new TypeError('Wrong value');
|
|
||||||
* err.code = 404;
|
|
||||||
* err.foo = 'bar';
|
|
||||||
* err.info = {
|
|
||||||
* nested: true,
|
|
||||||
* baz: 'text'
|
|
||||||
* };
|
|
||||||
* err.reg = /abc/i;
|
|
||||||
*
|
|
||||||
* assert.throws(
|
|
||||||
* () => {
|
|
||||||
* throw err;
|
|
||||||
* },
|
|
||||||
* {
|
|
||||||
* name: 'TypeError',
|
|
||||||
* message: 'Wrong value',
|
|
||||||
* info: {
|
|
||||||
* nested: true,
|
|
||||||
* baz: 'text'
|
|
||||||
* }
|
|
||||||
* // Only properties on the validation object will be tested for.
|
|
||||||
* // Using nested objects requires all properties to be present. Otherwise
|
|
||||||
* // the validation is going to fail.
|
|
||||||
* }
|
|
||||||
* );
|
|
||||||
*
|
|
||||||
* // Using regular expressions to validate error properties:
|
|
||||||
* throws(
|
|
||||||
* () => {
|
|
||||||
* throw err;
|
|
||||||
* },
|
|
||||||
* {
|
|
||||||
* // The `name` and `message` properties are strings and using regular
|
|
||||||
* // expressions on those will match against the string. If they fail, an
|
|
||||||
* // error is thrown.
|
|
||||||
* name: /^TypeError$/,
|
|
||||||
* message: /Wrong/,
|
|
||||||
* foo: 'bar',
|
|
||||||
* info: {
|
|
||||||
* nested: true,
|
|
||||||
* // It is not possible to use regular expressions for nested properties!
|
|
||||||
* baz: 'text'
|
|
||||||
* },
|
|
||||||
* // The `reg` property contains a regular expression and only if the
|
|
||||||
* // validation object contains an identical regular expression, it is going
|
|
||||||
* // to pass.
|
|
||||||
* reg: /abc/i
|
|
||||||
* }
|
|
||||||
* );
|
|
||||||
*
|
|
||||||
* // Fails due to the different `message` and `name` properties:
|
|
||||||
* throws(
|
|
||||||
* () => {
|
|
||||||
* const otherErr = new Error('Not found');
|
|
||||||
* // Copy all enumerable properties from `err` to `otherErr`.
|
|
||||||
* for (const [key, value] of Object.entries(err)) {
|
|
||||||
* otherErr[key] = value;
|
|
||||||
* }
|
|
||||||
* throw otherErr;
|
|
||||||
* },
|
|
||||||
* // The error's `message` and `name` properties will also be checked when using
|
|
||||||
* // an error as validation object.
|
|
||||||
* err
|
|
||||||
* );
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Validate instanceof using constructor:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import assert from 'assert/strict';
|
|
||||||
*
|
|
||||||
* assert.throws(
|
|
||||||
* () => {
|
|
||||||
* throw new Error('Wrong value');
|
|
||||||
* },
|
|
||||||
* Error
|
|
||||||
* );
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Validate error message using [`RegExp`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions):
|
|
||||||
*
|
|
||||||
* Using a regular expression runs `.toString` on the error object, and will
|
|
||||||
* therefore also include the error name.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import assert from 'assert/strict';
|
|
||||||
*
|
|
||||||
* assert.throws(
|
|
||||||
* () => {
|
|
||||||
* throw new Error('Wrong value');
|
|
||||||
* },
|
|
||||||
* /^Error: Wrong value$/
|
|
||||||
* );
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Custom error validation:
|
|
||||||
*
|
|
||||||
* The function must return `true` to indicate all internal validations passed.
|
|
||||||
* It will otherwise fail with an `AssertionError`.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import assert from 'assert/strict';
|
|
||||||
*
|
|
||||||
* assert.throws(
|
|
||||||
* () => {
|
|
||||||
* throw new Error('Wrong value');
|
|
||||||
* },
|
|
||||||
* (err) => {
|
|
||||||
* assert(err instanceof Error);
|
|
||||||
* assert(/value/.test(err));
|
|
||||||
* // Avoid returning anything from validation functions besides `true`.
|
|
||||||
* // Otherwise, it's not clear what part of the validation failed. Instead,
|
|
||||||
* // throw an error about the specific validation that failed (as done in this
|
|
||||||
* // example) and add as much helpful debugging information to that error as
|
|
||||||
* // possible.
|
|
||||||
* return true;
|
|
||||||
* },
|
|
||||||
* 'unexpected error'
|
|
||||||
* );
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* `error` cannot be a string. If a string is provided as the second
|
|
||||||
* argument, then `error` is assumed to be omitted and the string will be used for`message` instead. This can lead to easy-to-miss mistakes. Using the same
|
|
||||||
* message as the thrown error message is going to result in an`ERR_AMBIGUOUS_ARGUMENT` error. Please read the example below carefully if using
|
|
||||||
* a string as the second argument gets considered:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import assert from 'assert/strict';
|
|
||||||
*
|
|
||||||
* function throwingFirst() {
|
|
||||||
* throw new Error('First');
|
|
||||||
* }
|
|
||||||
*
|
|
||||||
* function throwingSecond() {
|
|
||||||
* throw new Error('Second');
|
|
||||||
* }
|
|
||||||
*
|
|
||||||
* function notThrowing() {}
|
|
||||||
*
|
|
||||||
* // The second argument is a string and the input function threw an Error.
|
|
||||||
* // The first case will not throw as it does not match for the error message
|
|
||||||
* // thrown by the input function!
|
|
||||||
* assert.throws(throwingFirst, 'Second');
|
|
||||||
* // In the next example the message has no benefit over the message from the
|
|
||||||
* // error and since it is not clear if the user intended to actually match
|
|
||||||
* // against the error message, Node.js throws an `ERR_AMBIGUOUS_ARGUMENT` error.
|
|
||||||
* assert.throws(throwingSecond, 'Second');
|
|
||||||
* // TypeError [ERR_AMBIGUOUS_ARGUMENT]
|
|
||||||
*
|
|
||||||
* // The string is only used (as message) in case the function does not throw:
|
|
||||||
* assert.throws(notThrowing, 'Second');
|
|
||||||
* // AssertionError [ERR_ASSERTION]: Missing expected exception: Second
|
|
||||||
*
|
|
||||||
* // If it was intended to match for the error message do this instead:
|
|
||||||
* // It does not throw because the error messages match.
|
|
||||||
* assert.throws(throwingSecond, /Second$/);
|
|
||||||
*
|
|
||||||
* // If the error message does not match, an AssertionError is thrown.
|
|
||||||
* assert.throws(throwingFirst, /Second$/);
|
|
||||||
* // AssertionError [ERR_ASSERTION]
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Due to the confusing error-prone notation, avoid a string as the second
|
|
||||||
* argument.
|
|
||||||
* @since v0.1.21
|
|
||||||
*/
|
|
||||||
function throws(block: () => unknown, message?: string | Error): void;
|
|
||||||
function throws(block: () => unknown, error: AssertPredicate, message?: string | Error): void;
|
|
||||||
/**
|
|
||||||
* Asserts that the function `fn` does not throw an error.
|
|
||||||
*
|
|
||||||
* Using `assert.doesNotThrow()` is actually not useful because there
|
|
||||||
* is no benefit in catching an error and then rethrowing it. Instead, consider
|
|
||||||
* adding a comment next to the specific code path that should not throw and keep
|
|
||||||
* error messages as expressive as possible.
|
|
||||||
*
|
|
||||||
* When `assert.doesNotThrow()` is called, it will immediately call the `fn`function.
|
|
||||||
*
|
|
||||||
* If an error is thrown and it is the same type as that specified by the `error`parameter, then an `AssertionError` is thrown. If the error is of a
|
|
||||||
* different type, or if the `error` parameter is undefined, the error is
|
|
||||||
* propagated back to the caller.
|
|
||||||
*
|
|
||||||
* If specified, `error` can be a [`Class`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Classes),
|
|
||||||
* [`RegExp`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions) or a validation
|
|
||||||
* function. See {@link throws} for more details.
|
|
||||||
*
|
|
||||||
* The following, for instance, will throw the `TypeError` because there is no
|
|
||||||
* matching error type in the assertion:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import assert from 'assert/strict';
|
|
||||||
*
|
|
||||||
* assert.doesNotThrow(
|
|
||||||
* () => {
|
|
||||||
* throw new TypeError('Wrong value');
|
|
||||||
* },
|
|
||||||
* SyntaxError
|
|
||||||
* );
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* However, the following will result in an `AssertionError` with the message
|
|
||||||
* 'Got unwanted exception...':
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import assert from 'assert/strict';
|
|
||||||
*
|
|
||||||
* assert.doesNotThrow(
|
|
||||||
* () => {
|
|
||||||
* throw new TypeError('Wrong value');
|
|
||||||
* },
|
|
||||||
* TypeError
|
|
||||||
* );
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* If an `AssertionError` is thrown and a value is provided for the `message`parameter, the value of `message` will be appended to the `AssertionError` message:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import assert from 'assert/strict';
|
|
||||||
*
|
|
||||||
* assert.doesNotThrow(
|
|
||||||
* () => {
|
|
||||||
* throw new TypeError('Wrong value');
|
|
||||||
* },
|
|
||||||
* /Wrong value/,
|
|
||||||
* 'Whoops'
|
|
||||||
* );
|
|
||||||
* // Throws: AssertionError: Got unwanted exception: Whoops
|
|
||||||
* ```
|
|
||||||
* @since v0.1.21
|
|
||||||
*/
|
|
||||||
function doesNotThrow(block: () => unknown, message?: string | Error): void;
|
|
||||||
function doesNotThrow(block: () => unknown, error: AssertPredicate, message?: string | Error): void;
|
|
||||||
/**
|
|
||||||
* Throws `value` if `value` is not `undefined` or `null`. This is useful when
|
|
||||||
* testing the `error` argument in callbacks. The stack trace contains all frames
|
|
||||||
* from the error passed to `ifError()` including the potential new frames for`ifError()` itself.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import assert from 'assert/strict';
|
|
||||||
*
|
|
||||||
* assert.ifError(null);
|
|
||||||
* // OK
|
|
||||||
* assert.ifError(0);
|
|
||||||
* // AssertionError [ERR_ASSERTION]: ifError got unwanted exception: 0
|
|
||||||
* assert.ifError('error');
|
|
||||||
* // AssertionError [ERR_ASSERTION]: ifError got unwanted exception: 'error'
|
|
||||||
* assert.ifError(new Error());
|
|
||||||
* // AssertionError [ERR_ASSERTION]: ifError got unwanted exception: Error
|
|
||||||
*
|
|
||||||
* // Create some random error frames.
|
|
||||||
* let err;
|
|
||||||
* (function errorFrame() {
|
|
||||||
* err = new Error('test error');
|
|
||||||
* })();
|
|
||||||
*
|
|
||||||
* (function ifErrorFrame() {
|
|
||||||
* assert.ifError(err);
|
|
||||||
* })();
|
|
||||||
* // AssertionError [ERR_ASSERTION]: ifError got unwanted exception: test error
|
|
||||||
* // at ifErrorFrame
|
|
||||||
* // at errorFrame
|
|
||||||
* ```
|
|
||||||
* @since v0.1.97
|
|
||||||
*/
|
|
||||||
function ifError(value: unknown): asserts value is null | undefined;
|
|
||||||
/**
|
|
||||||
* Awaits the `asyncFn` promise or, if `asyncFn` is a function, immediately
|
|
||||||
* calls the function and awaits the returned promise to complete. It will then
|
|
||||||
* check that the promise is rejected.
|
|
||||||
*
|
|
||||||
* If `asyncFn` is a function and it throws an error synchronously,`assert.rejects()` will return a rejected `Promise` with that error. If the
|
|
||||||
* function does not return a promise, `assert.rejects()` will return a rejected`Promise` with an `ERR_INVALID_RETURN_VALUE` error. In both cases the error
|
|
||||||
* handler is skipped.
|
|
||||||
*
|
|
||||||
* Besides the async nature to await the completion behaves identically to {@link throws}.
|
|
||||||
*
|
|
||||||
* If specified, `error` can be a [`Class`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Classes),
|
|
||||||
* [`RegExp`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions), a validation function,
|
|
||||||
* an object where each property will be tested for, or an instance of error where
|
|
||||||
* each property will be tested for including the non-enumerable `message` and`name` properties.
|
|
||||||
*
|
|
||||||
* If specified, `message` will be the message provided by the `AssertionError` if the `asyncFn` fails to reject.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import assert from 'assert/strict';
|
|
||||||
*
|
|
||||||
* await assert.rejects(
|
|
||||||
* async () => {
|
|
||||||
* throw new TypeError('Wrong value');
|
|
||||||
* },
|
|
||||||
* {
|
|
||||||
* name: 'TypeError',
|
|
||||||
* message: 'Wrong value'
|
|
||||||
* }
|
|
||||||
* );
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import assert from 'assert/strict';
|
|
||||||
*
|
|
||||||
* await assert.rejects(
|
|
||||||
* async () => {
|
|
||||||
* throw new TypeError('Wrong value');
|
|
||||||
* },
|
|
||||||
* (err) => {
|
|
||||||
* assert.strictEqual(err.name, 'TypeError');
|
|
||||||
* assert.strictEqual(err.message, 'Wrong value');
|
|
||||||
* return true;
|
|
||||||
* }
|
|
||||||
* );
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import assert from 'assert/strict';
|
|
||||||
*
|
|
||||||
* assert.rejects(
|
|
||||||
* Promise.reject(new Error('Wrong value')),
|
|
||||||
* Error
|
|
||||||
* ).then(() => {
|
|
||||||
* // ...
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* `error` cannot be a string. If a string is provided as the second
|
|
||||||
* argument, then `error` is assumed to be omitted and the string will be used for`message` instead. This can lead to easy-to-miss mistakes. Please read the
|
|
||||||
* example in {@link throws} carefully if using a string as the second
|
|
||||||
* argument gets considered.
|
|
||||||
* @since v10.0.0
|
|
||||||
*/
|
|
||||||
function rejects(block: (() => Promise<unknown>) | Promise<unknown>, message?: string | Error): Promise<void>;
|
|
||||||
function rejects(block: (() => Promise<unknown>) | Promise<unknown>, error: AssertPredicate, message?: string | Error): Promise<void>;
|
|
||||||
/**
|
|
||||||
* Awaits the `asyncFn` promise or, if `asyncFn` is a function, immediately
|
|
||||||
* calls the function and awaits the returned promise to complete. It will then
|
|
||||||
* check that the promise is not rejected.
|
|
||||||
*
|
|
||||||
* If `asyncFn` is a function and it throws an error synchronously,`assert.doesNotReject()` will return a rejected `Promise` with that error. If
|
|
||||||
* the function does not return a promise, `assert.doesNotReject()` will return a
|
|
||||||
* rejected `Promise` with an `ERR_INVALID_RETURN_VALUE` error. In both cases
|
|
||||||
* the error handler is skipped.
|
|
||||||
*
|
|
||||||
* Using `assert.doesNotReject()` is actually not useful because there is little
|
|
||||||
* benefit in catching a rejection and then rejecting it again. Instead, consider
|
|
||||||
* adding a comment next to the specific code path that should not reject and keep
|
|
||||||
* error messages as expressive as possible.
|
|
||||||
*
|
|
||||||
* If specified, `error` can be a [`Class`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Classes),
|
|
||||||
* [`RegExp`](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Guide/Regular_Expressions) or a validation
|
|
||||||
* function. See {@link throws} for more details.
|
|
||||||
*
|
|
||||||
* Besides the async nature to await the completion behaves identically to {@link doesNotThrow}.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import assert from 'assert/strict';
|
|
||||||
*
|
|
||||||
* await assert.doesNotReject(
|
|
||||||
* async () => {
|
|
||||||
* throw new TypeError('Wrong value');
|
|
||||||
* },
|
|
||||||
* SyntaxError
|
|
||||||
* );
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import assert from 'assert/strict';
|
|
||||||
*
|
|
||||||
* assert.doesNotReject(Promise.reject(new TypeError('Wrong value')))
|
|
||||||
* .then(() => {
|
|
||||||
* // ...
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
* @since v10.0.0
|
|
||||||
*/
|
|
||||||
function doesNotReject(block: (() => Promise<unknown>) | Promise<unknown>, message?: string | Error): Promise<void>;
|
|
||||||
function doesNotReject(block: (() => Promise<unknown>) | Promise<unknown>, error: AssertPredicate, message?: string | Error): Promise<void>;
|
|
||||||
/**
|
|
||||||
* Expects the `string` input to match the regular expression.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import assert from 'assert/strict';
|
|
||||||
*
|
|
||||||
* assert.match('I will fail', /pass/);
|
|
||||||
* // AssertionError [ERR_ASSERTION]: The input did not match the regular ...
|
|
||||||
*
|
|
||||||
* assert.match(123, /pass/);
|
|
||||||
* // AssertionError [ERR_ASSERTION]: The "string" argument must be of type string.
|
|
||||||
*
|
|
||||||
* assert.match('I will pass', /pass/);
|
|
||||||
* // OK
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* If the values do not match, or if the `string` argument is of another type than`string`, an `AssertionError` is thrown with a `message` property set equal
|
|
||||||
* to the value of the `message` parameter. If the `message` parameter is
|
|
||||||
* undefined, a default error message is assigned. If the `message` parameter is an
|
|
||||||
* instance of an `Error` then it will be thrown instead of the `AssertionError`.
|
|
||||||
* @since v13.6.0, v12.16.0
|
|
||||||
*/
|
|
||||||
function match(value: string, regExp: RegExp, message?: string | Error): void;
|
|
||||||
/**
|
|
||||||
* Expects the `string` input not to match the regular expression.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import assert from 'assert/strict';
|
|
||||||
*
|
|
||||||
* assert.doesNotMatch('I will fail', /fail/);
|
|
||||||
* // AssertionError [ERR_ASSERTION]: The input was expected to not match the ...
|
|
||||||
*
|
|
||||||
* assert.doesNotMatch(123, /pass/);
|
|
||||||
* // AssertionError [ERR_ASSERTION]: The "string" argument must be of type string.
|
|
||||||
*
|
|
||||||
* assert.doesNotMatch('I will pass', /different/);
|
|
||||||
* // OK
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* If the values do match, or if the `string` argument is of another type than`string`, an `AssertionError` is thrown with a `message` property set equal
|
|
||||||
* to the value of the `message` parameter. If the `message` parameter is
|
|
||||||
* undefined, a default error message is assigned. If the `message` parameter is an
|
|
||||||
* instance of an `Error` then it will be thrown instead of the `AssertionError`.
|
|
||||||
* @since v13.6.0, v12.16.0
|
|
||||||
*/
|
|
||||||
function doesNotMatch(value: string, regExp: RegExp, message?: string | Error): void;
|
|
||||||
const strict: Omit<typeof assert, 'equal' | 'notEqual' | 'deepEqual' | 'notDeepEqual' | 'ok' | 'strictEqual' | 'deepStrictEqual' | 'ifError' | 'strict'> & {
|
|
||||||
(value: unknown, message?: string | Error): asserts value;
|
|
||||||
equal: typeof strictEqual;
|
|
||||||
notEqual: typeof notStrictEqual;
|
|
||||||
deepEqual: typeof deepStrictEqual;
|
deepEqual: typeof deepStrictEqual;
|
||||||
notDeepEqual: typeof notDeepStrictEqual;
|
notDeepEqual: typeof notDeepStrictEqual;
|
||||||
// Mapped types and assertion functions are incompatible?
|
equal: typeof strictEqual;
|
||||||
// TS2775: Assertions require every name in the call target
|
notEqual: typeof notStrictEqual;
|
||||||
// to be declared with an explicit type annotation.
|
ok(value: any, message?: string | Error): asserts value;
|
||||||
ok: typeof ok;
|
strictEqual<T>(actual: any, expected: T, message?: string | Error): asserts actual is T;
|
||||||
strictEqual: typeof strictEqual;
|
deepStrictEqual<T>(actual: any, expected: T, message?: string | Error): asserts actual is T;
|
||||||
deepStrictEqual: typeof deepStrictEqual;
|
ifError(value: any): asserts value is null | undefined;
|
||||||
ifError: typeof ifError;
|
|
||||||
strict: typeof strict;
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
export = assert;
|
|
||||||
}
|
|
||||||
declare module 'node:assert' {
|
|
||||||
import assert = require('assert');
|
|
||||||
export = assert;
|
export = assert;
|
||||||
}
|
}
|
||||||
|
|||||||
8
node_modules/@types/node/assert/strict.d.ts
generated
vendored
8
node_modules/@types/node/assert/strict.d.ts
generated
vendored
@@ -1,8 +0,0 @@
|
|||||||
declare module 'assert/strict' {
|
|
||||||
import { strict } from 'node:assert';
|
|
||||||
export = strict;
|
|
||||||
}
|
|
||||||
declare module 'node:assert/strict' {
|
|
||||||
import { strict } from 'node:assert';
|
|
||||||
export = strict;
|
|
||||||
}
|
|
||||||
498
node_modules/@types/node/async_hooks.d.ts
generated
vendored
Executable file → Normal file
498
node_modules/@types/node/async_hooks.d.ts
generated
vendored
Executable file → Normal file
@@ -1,47 +1,16 @@
|
|||||||
/**
|
/**
|
||||||
* The `async_hooks` module provides an API to track asynchronous resources. It
|
* Async Hooks module: https://nodejs.org/api/async_hooks.html
|
||||||
* can be accessed using:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import async_hooks from 'async_hooks';
|
|
||||||
* ```
|
|
||||||
* @experimental
|
|
||||||
* @see [source](https://github.com/nodejs/node/blob/v16.9.0/lib/async_hooks.js)
|
|
||||||
*/
|
*/
|
||||||
declare module 'async_hooks' {
|
declare module "async_hooks" {
|
||||||
/**
|
/**
|
||||||
* ```js
|
* Returns the asyncId of the current execution context.
|
||||||
* import { executionAsyncId } from 'async_hooks';
|
|
||||||
*
|
|
||||||
* console.log(executionAsyncId()); // 1 - bootstrap
|
|
||||||
* fs.open(path, 'r', (err, fd) => {
|
|
||||||
* console.log(executionAsyncId()); // 6 - open()
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* The ID returned from `executionAsyncId()` is related to execution timing, not
|
|
||||||
* causality (which is covered by `triggerAsyncId()`):
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const server = net.createServer((conn) => {
|
|
||||||
* // Returns the ID of the server, not of the new connection, because the
|
|
||||||
* // callback runs in the execution scope of the server's MakeCallback().
|
|
||||||
* async_hooks.executionAsyncId();
|
|
||||||
*
|
|
||||||
* }).listen(port, () => {
|
|
||||||
* // Returns the ID of a TickObject (process.nextTick()) because all
|
|
||||||
* // callbacks passed to .listen() are wrapped in a nextTick().
|
|
||||||
* async_hooks.executionAsyncId();
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Promise contexts may not get precise `executionAsyncIds` by default.
|
|
||||||
* See the section on `promise execution tracking`.
|
|
||||||
* @since v8.1.0
|
|
||||||
* @return The `asyncId` of the current execution context. Useful to track when something calls.
|
|
||||||
*/
|
*/
|
||||||
function executionAsyncId(): number;
|
function executionAsyncId(): number;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
* The resource representing the current execution.
|
||||||
|
* Useful to store data within the resource.
|
||||||
|
*
|
||||||
* Resource objects returned by `executionAsyncResource()` are most often internal
|
* Resource objects returned by `executionAsyncResource()` are most often internal
|
||||||
* Node.js handle objects with undocumented APIs. Using any functions or properties
|
* Node.js handle objects with undocumented APIs. Using any functions or properties
|
||||||
* on the object is likely to crash your application and should be avoided.
|
* on the object is likely to crash your application and should be avoided.
|
||||||
@@ -49,70 +18,14 @@ declare module 'async_hooks' {
|
|||||||
* Using `executionAsyncResource()` in the top-level execution context will
|
* Using `executionAsyncResource()` in the top-level execution context will
|
||||||
* return an empty object as there is no handle or request object to use,
|
* return an empty object as there is no handle or request object to use,
|
||||||
* but having an object representing the top-level can be helpful.
|
* but having an object representing the top-level can be helpful.
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import { open } from 'fs';
|
|
||||||
* import { executionAsyncId, executionAsyncResource } from 'async_hooks';
|
|
||||||
*
|
|
||||||
* console.log(executionAsyncId(), executionAsyncResource()); // 1 {}
|
|
||||||
* open(new URL(import.meta.url), 'r', (err, fd) => {
|
|
||||||
* console.log(executionAsyncId(), executionAsyncResource()); // 7 FSReqWrap
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* This can be used to implement continuation local storage without the
|
|
||||||
* use of a tracking `Map` to store the metadata:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import { createServer } from 'http';
|
|
||||||
* import {
|
|
||||||
* executionAsyncId,
|
|
||||||
* executionAsyncResource,
|
|
||||||
* createHook
|
|
||||||
* } from 'async_hooks';
|
|
||||||
* const sym = Symbol('state'); // Private symbol to avoid pollution
|
|
||||||
*
|
|
||||||
* createHook({
|
|
||||||
* init(asyncId, type, triggerAsyncId, resource) {
|
|
||||||
* const cr = executionAsyncResource();
|
|
||||||
* if (cr) {
|
|
||||||
* resource[sym] = cr[sym];
|
|
||||||
* }
|
|
||||||
* }
|
|
||||||
* }).enable();
|
|
||||||
*
|
|
||||||
* const server = createServer((req, res) => {
|
|
||||||
* executionAsyncResource()[sym] = { state: req.url };
|
|
||||||
* setTimeout(function() {
|
|
||||||
* res.end(JSON.stringify(executionAsyncResource()[sym]));
|
|
||||||
* }, 100);
|
|
||||||
* }).listen(3000);
|
|
||||||
* ```
|
|
||||||
* @since v13.9.0, v12.17.0
|
|
||||||
* @return The resource representing the current execution. Useful to store data within the resource.
|
|
||||||
*/
|
*/
|
||||||
function executionAsyncResource(): object;
|
function executionAsyncResource(): object;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* ```js
|
* Returns the ID of the resource responsible for calling the callback that is currently being executed.
|
||||||
* const server = net.createServer((conn) => {
|
|
||||||
* // The resource that caused (or triggered) this callback to be called
|
|
||||||
* // was that of the new connection. Thus the return value of triggerAsyncId()
|
|
||||||
* // is the asyncId of "conn".
|
|
||||||
* async_hooks.triggerAsyncId();
|
|
||||||
*
|
|
||||||
* }).listen(port, () => {
|
|
||||||
* // Even though all callbacks passed to .listen() are wrapped in a nextTick()
|
|
||||||
* // the callback itself exists because the call to the server's .listen()
|
|
||||||
* // was made. So the return value would be the ID of the server.
|
|
||||||
* async_hooks.triggerAsyncId();
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Promise contexts may not get valid `triggerAsyncId`s by default. See
|
|
||||||
* the section on `promise execution tracking`.
|
|
||||||
* @return The ID of the resource responsible for calling the callback that is currently being executed.
|
|
||||||
*/
|
*/
|
||||||
function triggerAsyncId(): number;
|
function triggerAsyncId(): number;
|
||||||
|
|
||||||
interface HookCallbacks {
|
interface HookCallbacks {
|
||||||
/**
|
/**
|
||||||
* Called when a class is constructed that has the possibility to emit an asynchronous event.
|
* Called when a class is constructed that has the possibility to emit an asynchronous event.
|
||||||
@@ -122,133 +35,73 @@ declare module 'async_hooks' {
|
|||||||
* @param resource reference to the resource representing the async operation, needs to be released during destroy
|
* @param resource reference to the resource representing the async operation, needs to be released during destroy
|
||||||
*/
|
*/
|
||||||
init?(asyncId: number, type: string, triggerAsyncId: number, resource: object): void;
|
init?(asyncId: number, type: string, triggerAsyncId: number, resource: object): void;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* When an asynchronous operation is initiated or completes a callback is called to notify the user.
|
* When an asynchronous operation is initiated or completes a callback is called to notify the user.
|
||||||
* The before callback is called just before said callback is executed.
|
* The before callback is called just before said callback is executed.
|
||||||
* @param asyncId the unique identifier assigned to the resource about to execute the callback.
|
* @param asyncId the unique identifier assigned to the resource about to execute the callback.
|
||||||
*/
|
*/
|
||||||
before?(asyncId: number): void;
|
before?(asyncId: number): void;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Called immediately after the callback specified in before is completed.
|
* Called immediately after the callback specified in before is completed.
|
||||||
* @param asyncId the unique identifier assigned to the resource which has executed the callback.
|
* @param asyncId the unique identifier assigned to the resource which has executed the callback.
|
||||||
*/
|
*/
|
||||||
after?(asyncId: number): void;
|
after?(asyncId: number): void;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Called when a promise has resolve() called. This may not be in the same execution id
|
* Called when a promise has resolve() called. This may not be in the same execution id
|
||||||
* as the promise itself.
|
* as the promise itself.
|
||||||
* @param asyncId the unique id for the promise that was resolve()d.
|
* @param asyncId the unique id for the promise that was resolve()d.
|
||||||
*/
|
*/
|
||||||
promiseResolve?(asyncId: number): void;
|
promiseResolve?(asyncId: number): void;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Called after the resource corresponding to asyncId is destroyed
|
* Called after the resource corresponding to asyncId is destroyed
|
||||||
* @param asyncId a unique ID for the async resource
|
* @param asyncId a unique ID for the async resource
|
||||||
*/
|
*/
|
||||||
destroy?(asyncId: number): void;
|
destroy?(asyncId: number): void;
|
||||||
}
|
}
|
||||||
|
|
||||||
interface AsyncHook {
|
interface AsyncHook {
|
||||||
/**
|
/**
|
||||||
* Enable the callbacks for a given AsyncHook instance. If no callbacks are provided enabling is a noop.
|
* Enable the callbacks for a given AsyncHook instance. If no callbacks are provided enabling is a noop.
|
||||||
*/
|
*/
|
||||||
enable(): this;
|
enable(): this;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Disable the callbacks for a given AsyncHook instance from the global pool of AsyncHook callbacks to be executed. Once a hook has been disabled it will not be called again until enabled.
|
* Disable the callbacks for a given AsyncHook instance from the global pool of AsyncHook callbacks to be executed. Once a hook has been disabled it will not be called again until enabled.
|
||||||
*/
|
*/
|
||||||
disable(): this;
|
disable(): this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Registers functions to be called for different lifetime events of each async
|
* Registers functions to be called for different lifetime events of each async operation.
|
||||||
* operation.
|
* @param options the callbacks to register
|
||||||
*
|
* @return an AsyncHooks instance used for disabling and enabling hooks
|
||||||
* The callbacks `init()`/`before()`/`after()`/`destroy()` are called for the
|
|
||||||
* respective asynchronous event during a resource's lifetime.
|
|
||||||
*
|
|
||||||
* All callbacks are optional. For example, if only resource cleanup needs to
|
|
||||||
* be tracked, then only the `destroy` callback needs to be passed. The
|
|
||||||
* specifics of all functions that can be passed to `callbacks` is in the `Hook Callbacks` section.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import { createHook } from 'async_hooks';
|
|
||||||
*
|
|
||||||
* const asyncHook = createHook({
|
|
||||||
* init(asyncId, type, triggerAsyncId, resource) { },
|
|
||||||
* destroy(asyncId) { }
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* The callbacks will be inherited via the prototype chain:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* class MyAsyncCallbacks {
|
|
||||||
* init(asyncId, type, triggerAsyncId, resource) { }
|
|
||||||
* destroy(asyncId) {}
|
|
||||||
* }
|
|
||||||
*
|
|
||||||
* class MyAddedCallbacks extends MyAsyncCallbacks {
|
|
||||||
* before(asyncId) { }
|
|
||||||
* after(asyncId) { }
|
|
||||||
* }
|
|
||||||
*
|
|
||||||
* const asyncHook = async_hooks.createHook(new MyAddedCallbacks());
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Because promises are asynchronous resources whose lifecycle is tracked
|
|
||||||
* via the async hooks mechanism, the `init()`, `before()`, `after()`, and`destroy()` callbacks _must not_ be async functions that return promises.
|
|
||||||
* @since v8.1.0
|
|
||||||
* @param callbacks The `Hook Callbacks` to register
|
|
||||||
* @return Instance used for disabling and enabling hooks
|
|
||||||
*/
|
*/
|
||||||
function createHook(callbacks: HookCallbacks): AsyncHook;
|
function createHook(options: HookCallbacks): AsyncHook;
|
||||||
|
|
||||||
interface AsyncResourceOptions {
|
interface AsyncResourceOptions {
|
||||||
/**
|
/**
|
||||||
* The ID of the execution context that created this async event.
|
* The ID of the execution context that created this async event.
|
||||||
* @default executionAsyncId()
|
* Default: `executionAsyncId()`
|
||||||
*/
|
*/
|
||||||
triggerAsyncId?: number | undefined;
|
triggerAsyncId?: number;
|
||||||
/**
|
|
||||||
* Disables automatic `emitDestroy` when the object is garbage collected.
|
/**
|
||||||
* This usually does not need to be set (even if `emitDestroy` is called
|
* Disables automatic `emitDestroy` when the object is garbage collected.
|
||||||
* manually), unless the resource's `asyncId` is retrieved and the
|
* This usually does not need to be set (even if `emitDestroy` is called
|
||||||
* sensitive API's `emitDestroy` is called with it.
|
* manually), unless the resource's `asyncId` is retrieved and the
|
||||||
* @default false
|
* sensitive API's `emitDestroy` is called with it.
|
||||||
*/
|
* Default: `false`
|
||||||
requireManualDestroy?: boolean | undefined;
|
*/
|
||||||
|
requireManualDestroy?: boolean;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The class `AsyncResource` is designed to be extended by the embedder's async
|
* The class AsyncResource was designed to be extended by the embedder's async resources.
|
||||||
* resources. Using this, users can easily trigger the lifetime events of their
|
* Using this users can easily trigger the lifetime events of their own resources.
|
||||||
* own resources.
|
|
||||||
*
|
|
||||||
* The `init` hook will trigger when an `AsyncResource` is instantiated.
|
|
||||||
*
|
|
||||||
* The following is an overview of the `AsyncResource` API.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import { AsyncResource, executionAsyncId } from 'async_hooks';
|
|
||||||
*
|
|
||||||
* // AsyncResource() is meant to be extended. Instantiating a
|
|
||||||
* // new AsyncResource() also triggers init. If triggerAsyncId is omitted then
|
|
||||||
* // async_hook.executionAsyncId() is used.
|
|
||||||
* const asyncResource = new AsyncResource(
|
|
||||||
* type, { triggerAsyncId: executionAsyncId(), requireManualDestroy: false }
|
|
||||||
* );
|
|
||||||
*
|
|
||||||
* // Run a function in the execution context of the resource. This will
|
|
||||||
* // * establish the context of the resource
|
|
||||||
* // * trigger the AsyncHooks before callbacks
|
|
||||||
* // * call the provided function `fn` with the supplied arguments
|
|
||||||
* // * trigger the AsyncHooks after callbacks
|
|
||||||
* // * restore the original execution context
|
|
||||||
* asyncResource.runInAsyncScope(fn, thisArg, ...args);
|
|
||||||
*
|
|
||||||
* // Call AsyncHooks destroy callbacks.
|
|
||||||
* asyncResource.emitDestroy();
|
|
||||||
*
|
|
||||||
* // Return the unique ID assigned to the AsyncResource instance.
|
|
||||||
* asyncResource.asyncId();
|
|
||||||
*
|
|
||||||
* // Return the trigger ID for the AsyncResource instance.
|
|
||||||
* asyncResource.triggerAsyncId();
|
|
||||||
* ```
|
|
||||||
*/
|
*/
|
||||||
class AsyncResource {
|
class AsyncResource {
|
||||||
/**
|
/**
|
||||||
@@ -260,238 +113,135 @@ declare module 'async_hooks' {
|
|||||||
* this async event (default: `executionAsyncId()`), or an
|
* this async event (default: `executionAsyncId()`), or an
|
||||||
* AsyncResourceOptions object (since 9.3)
|
* AsyncResourceOptions object (since 9.3)
|
||||||
*/
|
*/
|
||||||
constructor(type: string, triggerAsyncId?: number | AsyncResourceOptions);
|
constructor(type: string, triggerAsyncId?: number|AsyncResourceOptions);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Binds the given function to the current execution context.
|
* Call the provided function with the provided arguments in the
|
||||||
*
|
* execution context of the async resource. This will establish the
|
||||||
* The returned function will have an `asyncResource` property referencing
|
* context, trigger the AsyncHooks before callbacks, call the function,
|
||||||
* the `AsyncResource` to which the function is bound.
|
* trigger the AsyncHooks after callbacks, and then restore the original
|
||||||
* @since v14.8.0, v12.19.0
|
* execution context.
|
||||||
* @param fn The function to bind to the current execution context.
|
* @param fn The function to call in the execution context of this
|
||||||
* @param type An optional name to associate with the underlying `AsyncResource`.
|
* async resource.
|
||||||
*/
|
|
||||||
static bind<Func extends (this: ThisArg, ...args: any[]) => any, ThisArg>(
|
|
||||||
fn: Func,
|
|
||||||
type?: string,
|
|
||||||
thisArg?: ThisArg
|
|
||||||
): Func & {
|
|
||||||
asyncResource: AsyncResource;
|
|
||||||
};
|
|
||||||
/**
|
|
||||||
* Binds the given function to execute to this `AsyncResource`'s scope.
|
|
||||||
*
|
|
||||||
* The returned function will have an `asyncResource` property referencing
|
|
||||||
* the `AsyncResource` to which the function is bound.
|
|
||||||
* @since v14.8.0, v12.19.0
|
|
||||||
* @param fn The function to bind to the current `AsyncResource`.
|
|
||||||
*/
|
|
||||||
bind<Func extends (...args: any[]) => any>(
|
|
||||||
fn: Func
|
|
||||||
): Func & {
|
|
||||||
asyncResource: AsyncResource;
|
|
||||||
};
|
|
||||||
/**
|
|
||||||
* Call the provided function with the provided arguments in the execution context
|
|
||||||
* of the async resource. This will establish the context, trigger the AsyncHooks
|
|
||||||
* before callbacks, call the function, trigger the AsyncHooks after callbacks, and
|
|
||||||
* then restore the original execution context.
|
|
||||||
* @since v9.6.0
|
|
||||||
* @param fn The function to call in the execution context of this async resource.
|
|
||||||
* @param thisArg The receiver to be used for the function call.
|
* @param thisArg The receiver to be used for the function call.
|
||||||
* @param args Optional arguments to pass to the function.
|
* @param args Optional arguments to pass to the function.
|
||||||
*/
|
*/
|
||||||
runInAsyncScope<This, Result>(fn: (this: This, ...args: any[]) => Result, thisArg?: This, ...args: any[]): Result;
|
runInAsyncScope<This, Result>(fn: (this: This, ...args: any[]) => Result, thisArg?: This, ...args: any[]): Result;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Call all `destroy` hooks. This should only ever be called once. An error will
|
* Call AsyncHooks destroy callbacks.
|
||||||
* be thrown if it is called more than once. This **must** be manually called. If
|
|
||||||
* the resource is left to be collected by the GC then the `destroy` hooks will
|
|
||||||
* never be called.
|
|
||||||
* @return A reference to `asyncResource`.
|
|
||||||
*/
|
*/
|
||||||
emitDestroy(): this;
|
emitDestroy(): void;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return The unique `asyncId` assigned to the resource.
|
* @return the unique ID assigned to this AsyncResource instance.
|
||||||
*/
|
*/
|
||||||
asyncId(): number;
|
asyncId(): number;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
*
|
* @return the trigger ID for this AsyncResource instance.
|
||||||
* @return The same `triggerAsyncId` that is passed to the `AsyncResource` constructor.
|
|
||||||
*/
|
*/
|
||||||
triggerAsyncId(): number;
|
triggerAsyncId(): number;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This class creates stores that stay coherent through asynchronous operations.
|
* When having multiple instances of `AsyncLocalStorage`, they are independent
|
||||||
*
|
* from each other. It is safe to instantiate this class multiple times.
|
||||||
* While you can create your own implementation on top of the `async_hooks` module,`AsyncLocalStorage` should be preferred as it is a performant and memory safe
|
|
||||||
* implementation that involves significant optimizations that are non-obvious to
|
|
||||||
* implement.
|
|
||||||
*
|
|
||||||
* The following example uses `AsyncLocalStorage` to build a simple logger
|
|
||||||
* that assigns IDs to incoming HTTP requests and includes them in messages
|
|
||||||
* logged within each request.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import http from 'http';
|
|
||||||
* import { AsyncLocalStorage } from 'async_hooks';
|
|
||||||
*
|
|
||||||
* const asyncLocalStorage = new AsyncLocalStorage();
|
|
||||||
*
|
|
||||||
* function logWithId(msg) {
|
|
||||||
* const id = asyncLocalStorage.getStore();
|
|
||||||
* console.log(`${id !== undefined ? id : '-'}:`, msg);
|
|
||||||
* }
|
|
||||||
*
|
|
||||||
* let idSeq = 0;
|
|
||||||
* http.createServer((req, res) => {
|
|
||||||
* asyncLocalStorage.run(idSeq++, () => {
|
|
||||||
* logWithId('start');
|
|
||||||
* // Imagine any chain of async operations here
|
|
||||||
* setImmediate(() => {
|
|
||||||
* logWithId('finish');
|
|
||||||
* res.end();
|
|
||||||
* });
|
|
||||||
* });
|
|
||||||
* }).listen(8080);
|
|
||||||
*
|
|
||||||
* http.get('http://localhost:8080');
|
|
||||||
* http.get('http://localhost:8080');
|
|
||||||
* // Prints:
|
|
||||||
* // 0: start
|
|
||||||
* // 1: start
|
|
||||||
* // 0: finish
|
|
||||||
* // 1: finish
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Each instance of `AsyncLocalStorage` maintains an independent storage context.
|
|
||||||
* Multiple instances can safely exist simultaneously without risk of interfering
|
|
||||||
* with each other data.
|
|
||||||
* @since v13.10.0, v12.17.0
|
|
||||||
*/
|
*/
|
||||||
class AsyncLocalStorage<T> {
|
class AsyncLocalStorage<T> {
|
||||||
/**
|
/**
|
||||||
* Disables the instance of `AsyncLocalStorage`. All subsequent calls
|
* This method disables the instance of `AsyncLocalStorage`. All subsequent calls
|
||||||
* to `asyncLocalStorage.getStore()` will return `undefined` until`asyncLocalStorage.run()` or `asyncLocalStorage.enterWith()` is called again.
|
* to `asyncLocalStorage.getStore()` will return `undefined` until
|
||||||
|
* `asyncLocalStorage.run()` or `asyncLocalStorage.runSyncAndReturn()`
|
||||||
|
* is called again.
|
||||||
*
|
*
|
||||||
* When calling `asyncLocalStorage.disable()`, all current contexts linked to the
|
* When calling `asyncLocalStorage.disable()`, all current contexts linked to the
|
||||||
* instance will be exited.
|
* instance will be exited.
|
||||||
*
|
*
|
||||||
* Calling `asyncLocalStorage.disable()` is required before the`asyncLocalStorage` can be garbage collected. This does not apply to stores
|
* Calling `asyncLocalStorage.disable()` is required before the
|
||||||
|
* `asyncLocalStorage` can be garbage collected. This does not apply to stores
|
||||||
* provided by the `asyncLocalStorage`, as those objects are garbage collected
|
* provided by the `asyncLocalStorage`, as those objects are garbage collected
|
||||||
* along with the corresponding async resources.
|
* along with the corresponding async resources.
|
||||||
*
|
*
|
||||||
* Use this method when the `asyncLocalStorage` is not in use anymore
|
* This method is to be used when the `asyncLocalStorage` is not in use anymore
|
||||||
* in the current process.
|
* in the current process.
|
||||||
* @since v13.10.0, v12.17.0
|
|
||||||
* @experimental
|
|
||||||
*/
|
*/
|
||||||
disable(): void;
|
disable(): void;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns the current store.
|
* This method returns the current store.
|
||||||
* If called outside of an asynchronous context initialized by
|
* If this method is called outside of an asynchronous context initialized by
|
||||||
* calling `asyncLocalStorage.run()` or `asyncLocalStorage.enterWith()`, it
|
* calling `asyncLocalStorage.run` or `asyncLocalStorage.runAndReturn`, it will
|
||||||
* returns `undefined`.
|
* return `undefined`.
|
||||||
* @since v13.10.0, v12.17.0
|
|
||||||
*/
|
*/
|
||||||
getStore(): T | undefined;
|
getStore(): T | undefined;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Runs a function synchronously within a context and returns its
|
* Calling `asyncLocalStorage.run(callback)` will create a new asynchronous
|
||||||
|
* context.
|
||||||
|
* Within the callback function and the asynchronous operations from the callback,
|
||||||
|
* `asyncLocalStorage.getStore()` will return an instance of `Map` known as
|
||||||
|
* "the store". This store will be persistent through the following
|
||||||
|
* asynchronous calls.
|
||||||
|
*
|
||||||
|
* The callback will be ran asynchronously. Optionally, arguments can be passed
|
||||||
|
* to the function. They will be passed to the callback function.
|
||||||
|
*
|
||||||
|
* If an error is thrown by the callback function, it will not be caught by
|
||||||
|
* a `try/catch` block as the callback is ran in a new asynchronous resource.
|
||||||
|
* Also, the stacktrace will be impacted by the asynchronous call.
|
||||||
|
*/
|
||||||
|
// TODO: Apply generic vararg once available
|
||||||
|
run(store: T, callback: (...args: any[]) => void, ...args: any[]): void;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Calling `asyncLocalStorage.exit(callback)` will create a new asynchronous
|
||||||
|
* context.
|
||||||
|
* Within the callback function and the asynchronous operations from the callback,
|
||||||
|
* `asyncLocalStorage.getStore()` will return `undefined`.
|
||||||
|
*
|
||||||
|
* The callback will be ran asynchronously. Optionally, arguments can be passed
|
||||||
|
* to the function. They will be passed to the callback function.
|
||||||
|
*
|
||||||
|
* If an error is thrown by the callback function, it will not be caught by
|
||||||
|
* a `try/catch` block as the callback is ran in a new asynchronous resource.
|
||||||
|
* Also, the stacktrace will be impacted by the asynchronous call.
|
||||||
|
*/
|
||||||
|
exit(callback: (...args: any[]) => void, ...args: any[]): void;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This methods runs a function synchronously within a context and return its
|
||||||
* return value. The store is not accessible outside of the callback function or
|
* return value. The store is not accessible outside of the callback function or
|
||||||
* the asynchronous operations created within the callback.
|
* the asynchronous operations created within the callback.
|
||||||
*
|
*
|
||||||
* The optional `args` are passed to the callback function.
|
* Optionally, arguments can be passed to the function. They will be passed to
|
||||||
|
* the callback function.
|
||||||
*
|
*
|
||||||
* If the callback function throws an error, the error is thrown by `run()` too.
|
* If the callback function throws an error, it will be thrown by
|
||||||
* The stacktrace is not impacted by this call and the context is exited.
|
* `runSyncAndReturn` too. The stacktrace will not be impacted by this call and
|
||||||
*
|
* the context will be exited.
|
||||||
* Example:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const store = { id: 2 };
|
|
||||||
* try {
|
|
||||||
* asyncLocalStorage.run(store, () => {
|
|
||||||
* asyncLocalStorage.getStore(); // Returns the store object
|
|
||||||
* throw new Error();
|
|
||||||
* });
|
|
||||||
* } catch (e) {
|
|
||||||
* asyncLocalStorage.getStore(); // Returns undefined
|
|
||||||
* // The error will be caught here
|
|
||||||
* }
|
|
||||||
* ```
|
|
||||||
* @since v13.10.0, v12.17.0
|
|
||||||
*/
|
*/
|
||||||
run<R, TArgs extends any[]>(store: T, callback: (...args: TArgs) => R, ...args: TArgs): R;
|
runSyncAndReturn<R>(store: T, callback: (...args: any[]) => R, ...args: any[]): R;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Runs a function synchronously outside of a context and returns its
|
* This methods runs a function synchronously outside of a context and return its
|
||||||
* return value. The store is not accessible within the callback function or
|
* return value. The store is not accessible within the callback function or
|
||||||
* the asynchronous operations created within the callback. Any `getStore()`call done within the callback function will always return `undefined`.
|
* the asynchronous operations created within the callback.
|
||||||
*
|
*
|
||||||
* The optional `args` are passed to the callback function.
|
* Optionally, arguments can be passed to the function. They will be passed to
|
||||||
|
* the callback function.
|
||||||
*
|
*
|
||||||
* If the callback function throws an error, the error is thrown by `exit()` too.
|
* If the callback function throws an error, it will be thrown by
|
||||||
* The stacktrace is not impacted by this call and the context is re-entered.
|
* `exitSyncAndReturn` too. The stacktrace will not be impacted by this call and
|
||||||
*
|
* the context will be re-entered.
|
||||||
* Example:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* // Within a call to run
|
|
||||||
* try {
|
|
||||||
* asyncLocalStorage.getStore(); // Returns the store object or value
|
|
||||||
* asyncLocalStorage.exit(() => {
|
|
||||||
* asyncLocalStorage.getStore(); // Returns undefined
|
|
||||||
* throw new Error();
|
|
||||||
* });
|
|
||||||
* } catch (e) {
|
|
||||||
* asyncLocalStorage.getStore(); // Returns the same object or value
|
|
||||||
* // The error will be caught here
|
|
||||||
* }
|
|
||||||
* ```
|
|
||||||
* @since v13.10.0, v12.17.0
|
|
||||||
* @experimental
|
|
||||||
*/
|
*/
|
||||||
exit<R, TArgs extends any[]>(callback: (...args: TArgs) => R, ...args: TArgs): R;
|
exitSyncAndReturn<R>(callback: (...args: any[]) => R, ...args: any[]): R;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Transitions into the context for the remainder of the current
|
* Calling `asyncLocalStorage.enterWith(store)` will transition into the context
|
||||||
* synchronous execution and then persists the store through any following
|
* for the remainder of the current synchronous execution and will persist
|
||||||
* asynchronous calls.
|
* through any following asynchronous calls.
|
||||||
*
|
|
||||||
* Example:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const store = { id: 1 };
|
|
||||||
* // Replaces previous store with the given store object
|
|
||||||
* asyncLocalStorage.enterWith(store);
|
|
||||||
* asyncLocalStorage.getStore(); // Returns the store object
|
|
||||||
* someAsyncOperation(() => {
|
|
||||||
* asyncLocalStorage.getStore(); // Returns the same object
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* This transition will continue for the _entire_ synchronous execution.
|
|
||||||
* This means that if, for example, the context is entered within an event
|
|
||||||
* handler subsequent event handlers will also run within that context unless
|
|
||||||
* specifically bound to another context with an `AsyncResource`. That is why`run()` should be preferred over `enterWith()` unless there are strong reasons
|
|
||||||
* to use the latter method.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const store = { id: 1 };
|
|
||||||
*
|
|
||||||
* emitter.on('my-event', () => {
|
|
||||||
* asyncLocalStorage.enterWith(store);
|
|
||||||
* });
|
|
||||||
* emitter.on('my-event', () => {
|
|
||||||
* asyncLocalStorage.getStore(); // Returns the same object
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* asyncLocalStorage.getStore(); // Returns undefined
|
|
||||||
* emitter.emit('my-event');
|
|
||||||
* asyncLocalStorage.getStore(); // Returns the same object
|
|
||||||
* ```
|
|
||||||
* @since v13.11.0, v12.17.0
|
|
||||||
* @experimental
|
|
||||||
*/
|
*/
|
||||||
enterWith(store: T): void;
|
enterWith(store: T): void;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
declare module 'node:async_hooks' {
|
|
||||||
export * from 'async_hooks';
|
|
||||||
}
|
|
||||||
|
|||||||
20
node_modules/@types/node/base.d.ts
generated
vendored
Normal file
20
node_modules/@types/node/base.d.ts
generated
vendored
Normal file
@@ -0,0 +1,20 @@
|
|||||||
|
// NOTE: These definitions support NodeJS and TypeScript 3.7.
|
||||||
|
|
||||||
|
// NOTE: TypeScript version-specific augmentations can be found in the following paths:
|
||||||
|
// - ~/base.d.ts - Shared definitions common to all TypeScript versions
|
||||||
|
// - ~/index.d.ts - Definitions specific to TypeScript 2.1
|
||||||
|
// - ~/ts3.7/base.d.ts - Definitions specific to TypeScript 3.7
|
||||||
|
// - ~/ts3.7/index.d.ts - Definitions specific to TypeScript 3.7 with assert pulled in
|
||||||
|
|
||||||
|
// Reference required types from the default lib:
|
||||||
|
/// <reference lib="es2018" />
|
||||||
|
/// <reference lib="esnext.asynciterable" />
|
||||||
|
/// <reference lib="esnext.intl" />
|
||||||
|
/// <reference lib="esnext.bigint" />
|
||||||
|
|
||||||
|
// Base definitions for all NodeJS modules that are not specific to any version of TypeScript:
|
||||||
|
// tslint:disable-next-line:no-bad-reference
|
||||||
|
/// <reference path="ts3.6/base.d.ts" />
|
||||||
|
|
||||||
|
// TypeScript 3.7-specific augmentations:
|
||||||
|
/// <reference path="assert.d.ts" />
|
||||||
2140
node_modules/@types/node/buffer.d.ts
generated
vendored
Executable file → Normal file
2140
node_modules/@types/node/buffer.d.ts
generated
vendored
Executable file → Normal file
File diff suppressed because it is too large
Load Diff
1494
node_modules/@types/node/child_process.d.ts
generated
vendored
Executable file → Normal file
1494
node_modules/@types/node/child_process.d.ts
generated
vendored
Executable file → Normal file
File diff suppressed because it is too large
Load Diff
574
node_modules/@types/node/cluster.d.ts
generated
vendored
Executable file → Normal file
574
node_modules/@types/node/cluster.d.ts
generated
vendored
Executable file → Normal file
@@ -1,278 +1,37 @@
|
|||||||
/**
|
declare module "cluster" {
|
||||||
* A single instance of Node.js runs in a single thread. To take advantage of
|
import * as child from "child_process";
|
||||||
* multi-core systems, the user will sometimes want to launch a cluster of Node.js
|
import * as events from "events";
|
||||||
* processes to handle the load.
|
import * as net from "net";
|
||||||
*
|
|
||||||
* The cluster module allows easy creation of child processes that all share
|
// interfaces
|
||||||
* server ports.
|
interface ClusterSettings {
|
||||||
*
|
execArgv?: string[]; // default: process.execArgv
|
||||||
* ```js
|
exec?: string;
|
||||||
* import cluster from 'cluster';
|
args?: string[];
|
||||||
* import http from 'http';
|
silent?: boolean;
|
||||||
* import { cpus } from 'os';
|
stdio?: any[];
|
||||||
* import process from 'process';
|
uid?: number;
|
||||||
*
|
gid?: number;
|
||||||
* const numCPUs = cpus().length;
|
inspectPort?: number | (() => number);
|
||||||
*
|
|
||||||
* if (cluster.isPrimary) {
|
|
||||||
* console.log(`Primary ${process.pid} is running`);
|
|
||||||
*
|
|
||||||
* // Fork workers.
|
|
||||||
* for (let i = 0; i < numCPUs; i++) {
|
|
||||||
* cluster.fork();
|
|
||||||
* }
|
|
||||||
*
|
|
||||||
* cluster.on('exit', (worker, code, signal) => {
|
|
||||||
* console.log(`worker ${worker.process.pid} died`);
|
|
||||||
* });
|
|
||||||
* } else {
|
|
||||||
* // Workers can share any TCP connection
|
|
||||||
* // In this case it is an HTTP server
|
|
||||||
* http.createServer((req, res) => {
|
|
||||||
* res.writeHead(200);
|
|
||||||
* res.end('hello world\n');
|
|
||||||
* }).listen(8000);
|
|
||||||
*
|
|
||||||
* console.log(`Worker ${process.pid} started`);
|
|
||||||
* }
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Running Node.js will now share port 8000 between the workers:
|
|
||||||
*
|
|
||||||
* ```console
|
|
||||||
* $ node server.js
|
|
||||||
* Primary 3596 is running
|
|
||||||
* Worker 4324 started
|
|
||||||
* Worker 4520 started
|
|
||||||
* Worker 6056 started
|
|
||||||
* Worker 5644 started
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* On Windows, it is not yet possible to set up a named pipe server in a worker.
|
|
||||||
* @see [source](https://github.com/nodejs/node/blob/v16.9.0/lib/cluster.js)
|
|
||||||
*/
|
|
||||||
declare module 'cluster' {
|
|
||||||
import * as child from 'node:child_process';
|
|
||||||
import EventEmitter = require('node:events');
|
|
||||||
import * as net from 'node:net';
|
|
||||||
export interface ClusterSettings {
|
|
||||||
execArgv?: string[] | undefined; // default: process.execArgv
|
|
||||||
exec?: string | undefined;
|
|
||||||
args?: string[] | undefined;
|
|
||||||
silent?: boolean | undefined;
|
|
||||||
stdio?: any[] | undefined;
|
|
||||||
uid?: number | undefined;
|
|
||||||
gid?: number | undefined;
|
|
||||||
inspectPort?: number | (() => number) | undefined;
|
|
||||||
}
|
}
|
||||||
export interface Address {
|
|
||||||
|
interface Address {
|
||||||
address: string;
|
address: string;
|
||||||
port: number;
|
port: number;
|
||||||
addressType: number | 'udp4' | 'udp6'; // 4, 6, -1, "udp4", "udp6"
|
addressType: number | "udp4" | "udp6"; // 4, 6, -1, "udp4", "udp6"
|
||||||
}
|
}
|
||||||
/**
|
|
||||||
* A `Worker` object contains all public information and method about a worker.
|
class Worker extends events.EventEmitter {
|
||||||
* In the primary it can be obtained using `cluster.workers`. In a worker
|
|
||||||
* it can be obtained using `cluster.worker`.
|
|
||||||
* @since v0.7.0
|
|
||||||
*/
|
|
||||||
export class Worker extends EventEmitter {
|
|
||||||
/**
|
|
||||||
* Each new worker is given its own unique id, this id is stored in the`id`.
|
|
||||||
*
|
|
||||||
* While a worker is alive, this is the key that indexes it in`cluster.workers`.
|
|
||||||
* @since v0.8.0
|
|
||||||
*/
|
|
||||||
id: number;
|
id: number;
|
||||||
/**
|
|
||||||
* All workers are created using `child_process.fork()`, the returned object
|
|
||||||
* from this function is stored as `.process`. In a worker, the global `process`is stored.
|
|
||||||
*
|
|
||||||
* See: `Child Process module`.
|
|
||||||
*
|
|
||||||
* Workers will call `process.exit(0)` if the `'disconnect'` event occurs
|
|
||||||
* on `process` and `.exitedAfterDisconnect` is not `true`. This protects against
|
|
||||||
* accidental disconnection.
|
|
||||||
* @since v0.7.0
|
|
||||||
*/
|
|
||||||
process: child.ChildProcess;
|
process: child.ChildProcess;
|
||||||
/**
|
send(message: any, sendHandle?: any, callback?: (error: Error | null) => void): boolean;
|
||||||
* Send a message to a worker or primary, optionally with a handle.
|
|
||||||
*
|
|
||||||
* In the primary this sends a message to a specific worker. It is identical to `ChildProcess.send()`.
|
|
||||||
*
|
|
||||||
* In a worker this sends a message to the primary. It is identical to`process.send()`.
|
|
||||||
*
|
|
||||||
* This example will echo back all messages from the primary:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* if (cluster.isPrimary) {
|
|
||||||
* const worker = cluster.fork();
|
|
||||||
* worker.send('hi there');
|
|
||||||
*
|
|
||||||
* } else if (cluster.isWorker) {
|
|
||||||
* process.on('message', (msg) => {
|
|
||||||
* process.send(msg);
|
|
||||||
* });
|
|
||||||
* }
|
|
||||||
* ```
|
|
||||||
* @since v0.7.0
|
|
||||||
* @param options The `options` argument, if present, is an object used to parameterize the sending of certain types of handles. `options` supports the following properties:
|
|
||||||
*/
|
|
||||||
send(message: child.Serializable, callback?: (error: Error | null) => void): boolean;
|
|
||||||
send(message: child.Serializable, sendHandle: child.SendHandle, callback?: (error: Error | null) => void): boolean;
|
|
||||||
send(message: child.Serializable, sendHandle: child.SendHandle, options?: child.MessageOptions, callback?: (error: Error | null) => void): boolean;
|
|
||||||
/**
|
|
||||||
* This function will kill the worker. In the primary, it does this
|
|
||||||
* by disconnecting the `worker.process`, and once disconnected, killing
|
|
||||||
* with `signal`. In the worker, it does it by disconnecting the channel,
|
|
||||||
* and then exiting with code `0`.
|
|
||||||
*
|
|
||||||
* Because `kill()` attempts to gracefully disconnect the worker process, it is
|
|
||||||
* susceptible to waiting indefinitely for the disconnect to complete. For example,
|
|
||||||
* if the worker enters an infinite loop, a graceful disconnect will never occur.
|
|
||||||
* If the graceful disconnect behavior is not needed, use `worker.process.kill()`.
|
|
||||||
*
|
|
||||||
* Causes `.exitedAfterDisconnect` to be set.
|
|
||||||
*
|
|
||||||
* This method is aliased as `worker.destroy()` for backward compatibility.
|
|
||||||
*
|
|
||||||
* In a worker, `process.kill()` exists, but it is not this function;
|
|
||||||
* it is `kill()`.
|
|
||||||
* @since v0.9.12
|
|
||||||
* @param [signal='SIGTERM'] Name of the kill signal to send to the worker process.
|
|
||||||
*/
|
|
||||||
kill(signal?: string): void;
|
kill(signal?: string): void;
|
||||||
destroy(signal?: string): void;
|
destroy(signal?: string): void;
|
||||||
/**
|
|
||||||
* In a worker, this function will close all servers, wait for the `'close'` event
|
|
||||||
* on those servers, and then disconnect the IPC channel.
|
|
||||||
*
|
|
||||||
* In the primary, an internal message is sent to the worker causing it to call`.disconnect()` on itself.
|
|
||||||
*
|
|
||||||
* Causes `.exitedAfterDisconnect` to be set.
|
|
||||||
*
|
|
||||||
* After a server is closed, it will no longer accept new connections,
|
|
||||||
* but connections may be accepted by any other listening worker. Existing
|
|
||||||
* connections will be allowed to close as usual. When no more connections exist,
|
|
||||||
* see `server.close()`, the IPC channel to the worker will close allowing it
|
|
||||||
* to die gracefully.
|
|
||||||
*
|
|
||||||
* The above applies _only_ to server connections, client connections are not
|
|
||||||
* automatically closed by workers, and disconnect does not wait for them to close
|
|
||||||
* before exiting.
|
|
||||||
*
|
|
||||||
* In a worker, `process.disconnect` exists, but it is not this function;
|
|
||||||
* it is `disconnect()`.
|
|
||||||
*
|
|
||||||
* Because long living server connections may block workers from disconnecting, it
|
|
||||||
* may be useful to send a message, so application specific actions may be taken to
|
|
||||||
* close them. It also may be useful to implement a timeout, killing a worker if
|
|
||||||
* the `'disconnect'` event has not been emitted after some time.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* if (cluster.isPrimary) {
|
|
||||||
* const worker = cluster.fork();
|
|
||||||
* let timeout;
|
|
||||||
*
|
|
||||||
* worker.on('listening', (address) => {
|
|
||||||
* worker.send('shutdown');
|
|
||||||
* worker.disconnect();
|
|
||||||
* timeout = setTimeout(() => {
|
|
||||||
* worker.kill();
|
|
||||||
* }, 2000);
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* worker.on('disconnect', () => {
|
|
||||||
* clearTimeout(timeout);
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* } else if (cluster.isWorker) {
|
|
||||||
* const net = require('net');
|
|
||||||
* const server = net.createServer((socket) => {
|
|
||||||
* // Connections never end
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* server.listen(8000);
|
|
||||||
*
|
|
||||||
* process.on('message', (msg) => {
|
|
||||||
* if (msg === 'shutdown') {
|
|
||||||
* // Initiate graceful close of any connections to server
|
|
||||||
* }
|
|
||||||
* });
|
|
||||||
* }
|
|
||||||
* ```
|
|
||||||
* @since v0.7.7
|
|
||||||
* @return A reference to `worker`.
|
|
||||||
*/
|
|
||||||
disconnect(): void;
|
disconnect(): void;
|
||||||
/**
|
|
||||||
* This function returns `true` if the worker is connected to its primary via its
|
|
||||||
* IPC channel, `false` otherwise. A worker is connected to its primary after it
|
|
||||||
* has been created. It is disconnected after the `'disconnect'` event is emitted.
|
|
||||||
* @since v0.11.14
|
|
||||||
*/
|
|
||||||
isConnected(): boolean;
|
isConnected(): boolean;
|
||||||
/**
|
|
||||||
* This function returns `true` if the worker's process has terminated (either
|
|
||||||
* because of exiting or being signaled). Otherwise, it returns `false`.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import cluster from 'cluster';
|
|
||||||
* import http from 'http';
|
|
||||||
* import { cpus } from 'os';
|
|
||||||
* import process from 'process';
|
|
||||||
*
|
|
||||||
* const numCPUs = cpus().length;
|
|
||||||
*
|
|
||||||
* if (cluster.isPrimary) {
|
|
||||||
* console.log(`Primary ${process.pid} is running`);
|
|
||||||
*
|
|
||||||
* // Fork workers.
|
|
||||||
* for (let i = 0; i < numCPUs; i++) {
|
|
||||||
* cluster.fork();
|
|
||||||
* }
|
|
||||||
*
|
|
||||||
* cluster.on('fork', (worker) => {
|
|
||||||
* console.log('worker is dead:', worker.isDead());
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* cluster.on('exit', (worker, code, signal) => {
|
|
||||||
* console.log('worker is dead:', worker.isDead());
|
|
||||||
* });
|
|
||||||
* } else {
|
|
||||||
* // Workers can share any TCP connection. In this case, it is an HTTP server.
|
|
||||||
* http.createServer((req, res) => {
|
|
||||||
* res.writeHead(200);
|
|
||||||
* res.end(`Current process\n ${process.pid}`);
|
|
||||||
* process.kill(process.pid);
|
|
||||||
* }).listen(8000);
|
|
||||||
* }
|
|
||||||
* ```
|
|
||||||
* @since v0.11.14
|
|
||||||
*/
|
|
||||||
isDead(): boolean;
|
isDead(): boolean;
|
||||||
/**
|
|
||||||
* This property is `true` if the worker exited due to `.kill()` or`.disconnect()`. If the worker exited any other way, it is `false`. If the
|
|
||||||
* worker has not exited, it is `undefined`.
|
|
||||||
*
|
|
||||||
* The boolean `worker.exitedAfterDisconnect` allows distinguishing between
|
|
||||||
* voluntary and accidental exit, the primary may choose not to respawn a worker
|
|
||||||
* based on this value.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* cluster.on('exit', (worker, code, signal) => {
|
|
||||||
* if (worker.exitedAfterDisconnect === true) {
|
|
||||||
* console.log('Oh, it was just voluntary – no need to worry');
|
|
||||||
* }
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* // kill worker
|
|
||||||
* worker.kill();
|
|
||||||
* ```
|
|
||||||
* @since v6.0.0
|
|
||||||
*/
|
|
||||||
exitedAfterDisconnect: boolean;
|
exitedAfterDisconnect: boolean;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* events.EventEmitter
|
* events.EventEmitter
|
||||||
* 1. disconnect
|
* 1. disconnect
|
||||||
@@ -283,67 +42,68 @@ declare module 'cluster' {
|
|||||||
* 6. online
|
* 6. online
|
||||||
*/
|
*/
|
||||||
addListener(event: string, listener: (...args: any[]) => void): this;
|
addListener(event: string, listener: (...args: any[]) => void): this;
|
||||||
addListener(event: 'disconnect', listener: () => void): this;
|
addListener(event: "disconnect", listener: () => void): this;
|
||||||
addListener(event: 'error', listener: (error: Error) => void): this;
|
addListener(event: "error", listener: (error: Error) => void): this;
|
||||||
addListener(event: 'exit', listener: (code: number, signal: string) => void): this;
|
addListener(event: "exit", listener: (code: number, signal: string) => void): this;
|
||||||
addListener(event: 'listening', listener: (address: Address) => void): this;
|
addListener(event: "listening", listener: (address: Address) => void): this;
|
||||||
addListener(event: 'message', listener: (message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined.
|
addListener(event: "message", listener: (message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined.
|
||||||
addListener(event: 'online', listener: () => void): this;
|
addListener(event: "online", listener: () => void): this;
|
||||||
|
|
||||||
emit(event: string | symbol, ...args: any[]): boolean;
|
emit(event: string | symbol, ...args: any[]): boolean;
|
||||||
emit(event: 'disconnect'): boolean;
|
emit(event: "disconnect"): boolean;
|
||||||
emit(event: 'error', error: Error): boolean;
|
emit(event: "error", error: Error): boolean;
|
||||||
emit(event: 'exit', code: number, signal: string): boolean;
|
emit(event: "exit", code: number, signal: string): boolean;
|
||||||
emit(event: 'listening', address: Address): boolean;
|
emit(event: "listening", address: Address): boolean;
|
||||||
emit(event: 'message', message: any, handle: net.Socket | net.Server): boolean;
|
emit(event: "message", message: any, handle: net.Socket | net.Server): boolean;
|
||||||
emit(event: 'online'): boolean;
|
emit(event: "online"): boolean;
|
||||||
|
|
||||||
on(event: string, listener: (...args: any[]) => void): this;
|
on(event: string, listener: (...args: any[]) => void): this;
|
||||||
on(event: 'disconnect', listener: () => void): this;
|
on(event: "disconnect", listener: () => void): this;
|
||||||
on(event: 'error', listener: (error: Error) => void): this;
|
on(event: "error", listener: (error: Error) => void): this;
|
||||||
on(event: 'exit', listener: (code: number, signal: string) => void): this;
|
on(event: "exit", listener: (code: number, signal: string) => void): this;
|
||||||
on(event: 'listening', listener: (address: Address) => void): this;
|
on(event: "listening", listener: (address: Address) => void): this;
|
||||||
on(event: 'message', listener: (message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined.
|
on(event: "message", listener: (message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined.
|
||||||
on(event: 'online', listener: () => void): this;
|
on(event: "online", listener: () => void): this;
|
||||||
|
|
||||||
once(event: string, listener: (...args: any[]) => void): this;
|
once(event: string, listener: (...args: any[]) => void): this;
|
||||||
once(event: 'disconnect', listener: () => void): this;
|
once(event: "disconnect", listener: () => void): this;
|
||||||
once(event: 'error', listener: (error: Error) => void): this;
|
once(event: "error", listener: (error: Error) => void): this;
|
||||||
once(event: 'exit', listener: (code: number, signal: string) => void): this;
|
once(event: "exit", listener: (code: number, signal: string) => void): this;
|
||||||
once(event: 'listening', listener: (address: Address) => void): this;
|
once(event: "listening", listener: (address: Address) => void): this;
|
||||||
once(event: 'message', listener: (message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined.
|
once(event: "message", listener: (message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined.
|
||||||
once(event: 'online', listener: () => void): this;
|
once(event: "online", listener: () => void): this;
|
||||||
|
|
||||||
prependListener(event: string, listener: (...args: any[]) => void): this;
|
prependListener(event: string, listener: (...args: any[]) => void): this;
|
||||||
prependListener(event: 'disconnect', listener: () => void): this;
|
prependListener(event: "disconnect", listener: () => void): this;
|
||||||
prependListener(event: 'error', listener: (error: Error) => void): this;
|
prependListener(event: "error", listener: (error: Error) => void): this;
|
||||||
prependListener(event: 'exit', listener: (code: number, signal: string) => void): this;
|
prependListener(event: "exit", listener: (code: number, signal: string) => void): this;
|
||||||
prependListener(event: 'listening', listener: (address: Address) => void): this;
|
prependListener(event: "listening", listener: (address: Address) => void): this;
|
||||||
prependListener(event: 'message', listener: (message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined.
|
prependListener(event: "message", listener: (message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined.
|
||||||
prependListener(event: 'online', listener: () => void): this;
|
prependListener(event: "online", listener: () => void): this;
|
||||||
|
|
||||||
prependOnceListener(event: string, listener: (...args: any[]) => void): this;
|
prependOnceListener(event: string, listener: (...args: any[]) => void): this;
|
||||||
prependOnceListener(event: 'disconnect', listener: () => void): this;
|
prependOnceListener(event: "disconnect", listener: () => void): this;
|
||||||
prependOnceListener(event: 'error', listener: (error: Error) => void): this;
|
prependOnceListener(event: "error", listener: (error: Error) => void): this;
|
||||||
prependOnceListener(event: 'exit', listener: (code: number, signal: string) => void): this;
|
prependOnceListener(event: "exit", listener: (code: number, signal: string) => void): this;
|
||||||
prependOnceListener(event: 'listening', listener: (address: Address) => void): this;
|
prependOnceListener(event: "listening", listener: (address: Address) => void): this;
|
||||||
prependOnceListener(event: 'message', listener: (message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined.
|
prependOnceListener(event: "message", listener: (message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined.
|
||||||
prependOnceListener(event: 'online', listener: () => void): this;
|
prependOnceListener(event: "online", listener: () => void): this;
|
||||||
}
|
}
|
||||||
export interface Cluster extends EventEmitter {
|
|
||||||
|
interface Cluster extends events.EventEmitter {
|
||||||
|
Worker: Worker;
|
||||||
disconnect(callback?: () => void): void;
|
disconnect(callback?: () => void): void;
|
||||||
fork(env?: any): Worker;
|
fork(env?: any): Worker;
|
||||||
/** @deprecated since v16.0.0 - use isPrimary. */
|
isMaster: boolean;
|
||||||
readonly isMaster: boolean;
|
isWorker: boolean;
|
||||||
readonly isPrimary: boolean;
|
// TODO: cluster.schedulingPolicy
|
||||||
readonly isWorker: boolean;
|
settings: ClusterSettings;
|
||||||
schedulingPolicy: number;
|
|
||||||
readonly settings: ClusterSettings;
|
|
||||||
/** @deprecated since v16.0.0 - use setupPrimary. */
|
|
||||||
setupMaster(settings?: ClusterSettings): void;
|
setupMaster(settings?: ClusterSettings): void;
|
||||||
/**
|
worker?: Worker;
|
||||||
* `setupPrimary` is used to change the default 'fork' behavior. Once called, the settings will be present in cluster.settings.
|
workers?: {
|
||||||
*/
|
[index: string]: Worker | undefined
|
||||||
setupPrimary(settings?: ClusterSettings): void;
|
};
|
||||||
readonly worker?: Worker | undefined;
|
|
||||||
readonly workers?: NodeJS.Dict<Worker> | undefined;
|
|
||||||
readonly SCHED_NONE: number;
|
|
||||||
readonly SCHED_RR: number;
|
|
||||||
/**
|
/**
|
||||||
* events.EventEmitter
|
* events.EventEmitter
|
||||||
* 1. disconnect
|
* 1. disconnect
|
||||||
@@ -355,60 +115,146 @@ declare module 'cluster' {
|
|||||||
* 7. setup
|
* 7. setup
|
||||||
*/
|
*/
|
||||||
addListener(event: string, listener: (...args: any[]) => void): this;
|
addListener(event: string, listener: (...args: any[]) => void): this;
|
||||||
addListener(event: 'disconnect', listener: (worker: Worker) => void): this;
|
addListener(event: "disconnect", listener: (worker: Worker) => void): this;
|
||||||
addListener(event: 'exit', listener: (worker: Worker, code: number, signal: string) => void): this;
|
addListener(event: "exit", listener: (worker: Worker, code: number, signal: string) => void): this;
|
||||||
addListener(event: 'fork', listener: (worker: Worker) => void): this;
|
addListener(event: "fork", listener: (worker: Worker) => void): this;
|
||||||
addListener(event: 'listening', listener: (worker: Worker, address: Address) => void): this;
|
addListener(event: "listening", listener: (worker: Worker, address: Address) => void): this;
|
||||||
addListener(event: 'message', listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined.
|
addListener(event: "message", listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined.
|
||||||
addListener(event: 'online', listener: (worker: Worker) => void): this;
|
addListener(event: "online", listener: (worker: Worker) => void): this;
|
||||||
addListener(event: 'setup', listener: (settings: ClusterSettings) => void): this;
|
addListener(event: "setup", listener: (settings: ClusterSettings) => void): this;
|
||||||
|
|
||||||
emit(event: string | symbol, ...args: any[]): boolean;
|
emit(event: string | symbol, ...args: any[]): boolean;
|
||||||
emit(event: 'disconnect', worker: Worker): boolean;
|
emit(event: "disconnect", worker: Worker): boolean;
|
||||||
emit(event: 'exit', worker: Worker, code: number, signal: string): boolean;
|
emit(event: "exit", worker: Worker, code: number, signal: string): boolean;
|
||||||
emit(event: 'fork', worker: Worker): boolean;
|
emit(event: "fork", worker: Worker): boolean;
|
||||||
emit(event: 'listening', worker: Worker, address: Address): boolean;
|
emit(event: "listening", worker: Worker, address: Address): boolean;
|
||||||
emit(event: 'message', worker: Worker, message: any, handle: net.Socket | net.Server): boolean;
|
emit(event: "message", worker: Worker, message: any, handle: net.Socket | net.Server): boolean;
|
||||||
emit(event: 'online', worker: Worker): boolean;
|
emit(event: "online", worker: Worker): boolean;
|
||||||
emit(event: 'setup', settings: ClusterSettings): boolean;
|
emit(event: "setup", settings: ClusterSettings): boolean;
|
||||||
|
|
||||||
on(event: string, listener: (...args: any[]) => void): this;
|
on(event: string, listener: (...args: any[]) => void): this;
|
||||||
on(event: 'disconnect', listener: (worker: Worker) => void): this;
|
on(event: "disconnect", listener: (worker: Worker) => void): this;
|
||||||
on(event: 'exit', listener: (worker: Worker, code: number, signal: string) => void): this;
|
on(event: "exit", listener: (worker: Worker, code: number, signal: string) => void): this;
|
||||||
on(event: 'fork', listener: (worker: Worker) => void): this;
|
on(event: "fork", listener: (worker: Worker) => void): this;
|
||||||
on(event: 'listening', listener: (worker: Worker, address: Address) => void): this;
|
on(event: "listening", listener: (worker: Worker, address: Address) => void): this;
|
||||||
on(event: 'message', listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined.
|
on(event: "message", listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined.
|
||||||
on(event: 'online', listener: (worker: Worker) => void): this;
|
on(event: "online", listener: (worker: Worker) => void): this;
|
||||||
on(event: 'setup', listener: (settings: ClusterSettings) => void): this;
|
on(event: "setup", listener: (settings: ClusterSettings) => void): this;
|
||||||
|
|
||||||
once(event: string, listener: (...args: any[]) => void): this;
|
once(event: string, listener: (...args: any[]) => void): this;
|
||||||
once(event: 'disconnect', listener: (worker: Worker) => void): this;
|
once(event: "disconnect", listener: (worker: Worker) => void): this;
|
||||||
once(event: 'exit', listener: (worker: Worker, code: number, signal: string) => void): this;
|
once(event: "exit", listener: (worker: Worker, code: number, signal: string) => void): this;
|
||||||
once(event: 'fork', listener: (worker: Worker) => void): this;
|
once(event: "fork", listener: (worker: Worker) => void): this;
|
||||||
once(event: 'listening', listener: (worker: Worker, address: Address) => void): this;
|
once(event: "listening", listener: (worker: Worker, address: Address) => void): this;
|
||||||
once(event: 'message', listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined.
|
once(event: "message", listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined.
|
||||||
once(event: 'online', listener: (worker: Worker) => void): this;
|
once(event: "online", listener: (worker: Worker) => void): this;
|
||||||
once(event: 'setup', listener: (settings: ClusterSettings) => void): this;
|
once(event: "setup", listener: (settings: ClusterSettings) => void): this;
|
||||||
|
|
||||||
prependListener(event: string, listener: (...args: any[]) => void): this;
|
prependListener(event: string, listener: (...args: any[]) => void): this;
|
||||||
prependListener(event: 'disconnect', listener: (worker: Worker) => void): this;
|
prependListener(event: "disconnect", listener: (worker: Worker) => void): this;
|
||||||
prependListener(event: 'exit', listener: (worker: Worker, code: number, signal: string) => void): this;
|
prependListener(event: "exit", listener: (worker: Worker, code: number, signal: string) => void): this;
|
||||||
prependListener(event: 'fork', listener: (worker: Worker) => void): this;
|
prependListener(event: "fork", listener: (worker: Worker) => void): this;
|
||||||
prependListener(event: 'listening', listener: (worker: Worker, address: Address) => void): this;
|
prependListener(event: "listening", listener: (worker: Worker, address: Address) => void): this;
|
||||||
// the handle is a net.Socket or net.Server object, or undefined.
|
prependListener(event: "message", listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void): this; // the handle is a net.Socket or net.Server object, or undefined.
|
||||||
prependListener(event: 'message', listener: (worker: Worker, message: any, handle?: net.Socket | net.Server) => void): this;
|
prependListener(event: "online", listener: (worker: Worker) => void): this;
|
||||||
prependListener(event: 'online', listener: (worker: Worker) => void): this;
|
prependListener(event: "setup", listener: (settings: ClusterSettings) => void): this;
|
||||||
prependListener(event: 'setup', listener: (settings: ClusterSettings) => void): this;
|
|
||||||
prependOnceListener(event: string, listener: (...args: any[]) => void): this;
|
prependOnceListener(event: string, listener: (...args: any[]) => void): this;
|
||||||
prependOnceListener(event: 'disconnect', listener: (worker: Worker) => void): this;
|
prependOnceListener(event: "disconnect", listener: (worker: Worker) => void): this;
|
||||||
prependOnceListener(event: 'exit', listener: (worker: Worker, code: number, signal: string) => void): this;
|
prependOnceListener(event: "exit", listener: (worker: Worker, code: number, signal: string) => void): this;
|
||||||
prependOnceListener(event: 'fork', listener: (worker: Worker) => void): this;
|
prependOnceListener(event: "fork", listener: (worker: Worker) => void): this;
|
||||||
prependOnceListener(event: 'listening', listener: (worker: Worker, address: Address) => void): this;
|
prependOnceListener(event: "listening", listener: (worker: Worker, address: Address) => void): this;
|
||||||
// the handle is a net.Socket or net.Server object, or undefined.
|
// the handle is a net.Socket or net.Server object, or undefined.
|
||||||
prependOnceListener(event: 'message', listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void): this;
|
prependOnceListener(event: "message", listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void): this;
|
||||||
prependOnceListener(event: 'online', listener: (worker: Worker) => void): this;
|
prependOnceListener(event: "online", listener: (worker: Worker) => void): this;
|
||||||
prependOnceListener(event: 'setup', listener: (settings: ClusterSettings) => void): this;
|
prependOnceListener(event: "setup", listener: (settings: ClusterSettings) => void): this;
|
||||||
}
|
}
|
||||||
const cluster: Cluster;
|
|
||||||
export default cluster;
|
function disconnect(callback?: () => void): void;
|
||||||
}
|
function fork(env?: any): Worker;
|
||||||
declare module 'node:cluster' {
|
const isMaster: boolean;
|
||||||
export * from 'cluster';
|
const isWorker: boolean;
|
||||||
export { default as default } from 'cluster';
|
// TODO: cluster.schedulingPolicy
|
||||||
|
const settings: ClusterSettings;
|
||||||
|
function setupMaster(settings?: ClusterSettings): void;
|
||||||
|
const worker: Worker;
|
||||||
|
const workers: {
|
||||||
|
[index: string]: Worker | undefined
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* events.EventEmitter
|
||||||
|
* 1. disconnect
|
||||||
|
* 2. exit
|
||||||
|
* 3. fork
|
||||||
|
* 4. listening
|
||||||
|
* 5. message
|
||||||
|
* 6. online
|
||||||
|
* 7. setup
|
||||||
|
*/
|
||||||
|
function addListener(event: string, listener: (...args: any[]) => void): Cluster;
|
||||||
|
function addListener(event: "disconnect", listener: (worker: Worker) => void): Cluster;
|
||||||
|
function addListener(event: "exit", listener: (worker: Worker, code: number, signal: string) => void): Cluster;
|
||||||
|
function addListener(event: "fork", listener: (worker: Worker) => void): Cluster;
|
||||||
|
function addListener(event: "listening", listener: (worker: Worker, address: Address) => void): Cluster;
|
||||||
|
// the handle is a net.Socket or net.Server object, or undefined.
|
||||||
|
function addListener(event: "message", listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void): Cluster;
|
||||||
|
function addListener(event: "online", listener: (worker: Worker) => void): Cluster;
|
||||||
|
function addListener(event: "setup", listener: (settings: ClusterSettings) => void): Cluster;
|
||||||
|
|
||||||
|
function emit(event: string | symbol, ...args: any[]): boolean;
|
||||||
|
function emit(event: "disconnect", worker: Worker): boolean;
|
||||||
|
function emit(event: "exit", worker: Worker, code: number, signal: string): boolean;
|
||||||
|
function emit(event: "fork", worker: Worker): boolean;
|
||||||
|
function emit(event: "listening", worker: Worker, address: Address): boolean;
|
||||||
|
function emit(event: "message", worker: Worker, message: any, handle: net.Socket | net.Server): boolean;
|
||||||
|
function emit(event: "online", worker: Worker): boolean;
|
||||||
|
function emit(event: "setup", settings: ClusterSettings): boolean;
|
||||||
|
|
||||||
|
function on(event: string, listener: (...args: any[]) => void): Cluster;
|
||||||
|
function on(event: "disconnect", listener: (worker: Worker) => void): Cluster;
|
||||||
|
function on(event: "exit", listener: (worker: Worker, code: number, signal: string) => void): Cluster;
|
||||||
|
function on(event: "fork", listener: (worker: Worker) => void): Cluster;
|
||||||
|
function on(event: "listening", listener: (worker: Worker, address: Address) => void): Cluster;
|
||||||
|
function on(event: "message", listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void): Cluster; // the handle is a net.Socket or net.Server object, or undefined.
|
||||||
|
function on(event: "online", listener: (worker: Worker) => void): Cluster;
|
||||||
|
function on(event: "setup", listener: (settings: ClusterSettings) => void): Cluster;
|
||||||
|
|
||||||
|
function once(event: string, listener: (...args: any[]) => void): Cluster;
|
||||||
|
function once(event: "disconnect", listener: (worker: Worker) => void): Cluster;
|
||||||
|
function once(event: "exit", listener: (worker: Worker, code: number, signal: string) => void): Cluster;
|
||||||
|
function once(event: "fork", listener: (worker: Worker) => void): Cluster;
|
||||||
|
function once(event: "listening", listener: (worker: Worker, address: Address) => void): Cluster;
|
||||||
|
function once(event: "message", listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void): Cluster; // the handle is a net.Socket or net.Server object, or undefined.
|
||||||
|
function once(event: "online", listener: (worker: Worker) => void): Cluster;
|
||||||
|
function once(event: "setup", listener: (settings: ClusterSettings) => void): Cluster;
|
||||||
|
|
||||||
|
function removeListener(event: string, listener: (...args: any[]) => void): Cluster;
|
||||||
|
function removeAllListeners(event?: string): Cluster;
|
||||||
|
function setMaxListeners(n: number): Cluster;
|
||||||
|
function getMaxListeners(): number;
|
||||||
|
function listeners(event: string): Function[];
|
||||||
|
function listenerCount(type: string): number;
|
||||||
|
|
||||||
|
function prependListener(event: string, listener: (...args: any[]) => void): Cluster;
|
||||||
|
function prependListener(event: "disconnect", listener: (worker: Worker) => void): Cluster;
|
||||||
|
function prependListener(event: "exit", listener: (worker: Worker, code: number, signal: string) => void): Cluster;
|
||||||
|
function prependListener(event: "fork", listener: (worker: Worker) => void): Cluster;
|
||||||
|
function prependListener(event: "listening", listener: (worker: Worker, address: Address) => void): Cluster;
|
||||||
|
// the handle is a net.Socket or net.Server object, or undefined.
|
||||||
|
function prependListener(event: "message", listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void): Cluster;
|
||||||
|
function prependListener(event: "online", listener: (worker: Worker) => void): Cluster;
|
||||||
|
function prependListener(event: "setup", listener: (settings: ClusterSettings) => void): Cluster;
|
||||||
|
|
||||||
|
function prependOnceListener(event: string, listener: (...args: any[]) => void): Cluster;
|
||||||
|
function prependOnceListener(event: "disconnect", listener: (worker: Worker) => void): Cluster;
|
||||||
|
function prependOnceListener(event: "exit", listener: (worker: Worker, code: number, signal: string) => void): Cluster;
|
||||||
|
function prependOnceListener(event: "fork", listener: (worker: Worker) => void): Cluster;
|
||||||
|
function prependOnceListener(event: "listening", listener: (worker: Worker, address: Address) => void): Cluster;
|
||||||
|
// the handle is a net.Socket or net.Server object, or undefined.
|
||||||
|
function prependOnceListener(event: "message", listener: (worker: Worker, message: any, handle: net.Socket | net.Server) => void): Cluster;
|
||||||
|
function prependOnceListener(event: "online", listener: (worker: Worker) => void): Cluster;
|
||||||
|
function prependOnceListener(event: "setup", listener: (settings: ClusterSettings) => void): Cluster;
|
||||||
|
|
||||||
|
function eventNames(): string[];
|
||||||
}
|
}
|
||||||
|
|||||||
411
node_modules/@types/node/console.d.ts
generated
vendored
Executable file → Normal file
411
node_modules/@types/node/console.d.ts
generated
vendored
Executable file → Normal file
@@ -1,412 +1,3 @@
|
|||||||
/**
|
declare module "console" {
|
||||||
* The `console` module provides a simple debugging console that is similar to the
|
|
||||||
* JavaScript console mechanism provided by web browsers.
|
|
||||||
*
|
|
||||||
* The module exports two specific components:
|
|
||||||
*
|
|
||||||
* * A `Console` class with methods such as `console.log()`, `console.error()` and`console.warn()` that can be used to write to any Node.js stream.
|
|
||||||
* * A global `console` instance configured to write to `process.stdout` and `process.stderr`. The global `console` can be used without calling`require('console')`.
|
|
||||||
*
|
|
||||||
* _**Warning**_: The global console object's methods are neither consistently
|
|
||||||
* synchronous like the browser APIs they resemble, nor are they consistently
|
|
||||||
* asynchronous like all other Node.js streams. See the `note on process I/O` for
|
|
||||||
* more information.
|
|
||||||
*
|
|
||||||
* Example using the global `console`:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* console.log('hello world');
|
|
||||||
* // Prints: hello world, to stdout
|
|
||||||
* console.log('hello %s', 'world');
|
|
||||||
* // Prints: hello world, to stdout
|
|
||||||
* console.error(new Error('Whoops, something bad happened'));
|
|
||||||
* // Prints error message and stack trace to stderr:
|
|
||||||
* // Error: Whoops, something bad happened
|
|
||||||
* // at [eval]:5:15
|
|
||||||
* // at Script.runInThisContext (node:vm:132:18)
|
|
||||||
* // at Object.runInThisContext (node:vm:309:38)
|
|
||||||
* // at node:internal/process/execution:77:19
|
|
||||||
* // at [eval]-wrapper:6:22
|
|
||||||
* // at evalScript (node:internal/process/execution:76:60)
|
|
||||||
* // at node:internal/main/eval_string:23:3
|
|
||||||
*
|
|
||||||
* const name = 'Will Robinson';
|
|
||||||
* console.warn(`Danger ${name}! Danger!`);
|
|
||||||
* // Prints: Danger Will Robinson! Danger!, to stderr
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Example using the `Console` class:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const out = getStreamSomehow();
|
|
||||||
* const err = getStreamSomehow();
|
|
||||||
* const myConsole = new console.Console(out, err);
|
|
||||||
*
|
|
||||||
* myConsole.log('hello world');
|
|
||||||
* // Prints: hello world, to out
|
|
||||||
* myConsole.log('hello %s', 'world');
|
|
||||||
* // Prints: hello world, to out
|
|
||||||
* myConsole.error(new Error('Whoops, something bad happened'));
|
|
||||||
* // Prints: [Error: Whoops, something bad happened], to err
|
|
||||||
*
|
|
||||||
* const name = 'Will Robinson';
|
|
||||||
* myConsole.warn(`Danger ${name}! Danger!`);
|
|
||||||
* // Prints: Danger Will Robinson! Danger!, to err
|
|
||||||
* ```
|
|
||||||
* @see [source](https://github.com/nodejs/node/blob/v16.9.0/lib/console.js)
|
|
||||||
*/
|
|
||||||
declare module 'console' {
|
|
||||||
import console = require('node:console');
|
|
||||||
export = console;
|
export = console;
|
||||||
}
|
}
|
||||||
declare module 'node:console' {
|
|
||||||
import { InspectOptions } from 'node:util';
|
|
||||||
global {
|
|
||||||
// This needs to be global to avoid TS2403 in case lib.dom.d.ts is present in the same build
|
|
||||||
interface Console {
|
|
||||||
Console: console.ConsoleConstructor;
|
|
||||||
/**
|
|
||||||
* `console.assert()` writes a message if `value` is [falsy](https://developer.mozilla.org/en-US/docs/Glossary/Falsy) or omitted. It only
|
|
||||||
* writes a message and does not otherwise affect execution. The output always
|
|
||||||
* starts with `"Assertion failed"`. If provided, `message` is formatted using `util.format()`.
|
|
||||||
*
|
|
||||||
* If `value` is [truthy](https://developer.mozilla.org/en-US/docs/Glossary/Truthy), nothing happens.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* console.assert(true, 'does nothing');
|
|
||||||
*
|
|
||||||
* console.assert(false, 'Whoops %s work', 'didn\'t');
|
|
||||||
* // Assertion failed: Whoops didn't work
|
|
||||||
*
|
|
||||||
* console.assert();
|
|
||||||
* // Assertion failed
|
|
||||||
* ```
|
|
||||||
* @since v0.1.101
|
|
||||||
* @param value The value tested for being truthy.
|
|
||||||
* @param message All arguments besides `value` are used as error message.
|
|
||||||
*/
|
|
||||||
assert(value: any, message?: string, ...optionalParams: any[]): void;
|
|
||||||
/**
|
|
||||||
* When `stdout` is a TTY, calling `console.clear()` will attempt to clear the
|
|
||||||
* TTY. When `stdout` is not a TTY, this method does nothing.
|
|
||||||
*
|
|
||||||
* The specific operation of `console.clear()` can vary across operating systems
|
|
||||||
* and terminal types. For most Linux operating systems, `console.clear()`operates similarly to the `clear` shell command. On Windows, `console.clear()`will clear only the output in the
|
|
||||||
* current terminal viewport for the Node.js
|
|
||||||
* binary.
|
|
||||||
* @since v8.3.0
|
|
||||||
*/
|
|
||||||
clear(): void;
|
|
||||||
/**
|
|
||||||
* Maintains an internal counter specific to `label` and outputs to `stdout` the
|
|
||||||
* number of times `console.count()` has been called with the given `label`.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* > console.count()
|
|
||||||
* default: 1
|
|
||||||
* undefined
|
|
||||||
* > console.count('default')
|
|
||||||
* default: 2
|
|
||||||
* undefined
|
|
||||||
* > console.count('abc')
|
|
||||||
* abc: 1
|
|
||||||
* undefined
|
|
||||||
* > console.count('xyz')
|
|
||||||
* xyz: 1
|
|
||||||
* undefined
|
|
||||||
* > console.count('abc')
|
|
||||||
* abc: 2
|
|
||||||
* undefined
|
|
||||||
* > console.count()
|
|
||||||
* default: 3
|
|
||||||
* undefined
|
|
||||||
* >
|
|
||||||
* ```
|
|
||||||
* @since v8.3.0
|
|
||||||
* @param label The display label for the counter.
|
|
||||||
*/
|
|
||||||
count(label?: string): void;
|
|
||||||
/**
|
|
||||||
* Resets the internal counter specific to `label`.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* > console.count('abc');
|
|
||||||
* abc: 1
|
|
||||||
* undefined
|
|
||||||
* > console.countReset('abc');
|
|
||||||
* undefined
|
|
||||||
* > console.count('abc');
|
|
||||||
* abc: 1
|
|
||||||
* undefined
|
|
||||||
* >
|
|
||||||
* ```
|
|
||||||
* @since v8.3.0
|
|
||||||
* @param label The display label for the counter.
|
|
||||||
*/
|
|
||||||
countReset(label?: string): void;
|
|
||||||
/**
|
|
||||||
* The `console.debug()` function is an alias for {@link log}.
|
|
||||||
* @since v8.0.0
|
|
||||||
*/
|
|
||||||
debug(message?: any, ...optionalParams: any[]): void;
|
|
||||||
/**
|
|
||||||
* Uses `util.inspect()` on `obj` and prints the resulting string to `stdout`.
|
|
||||||
* This function bypasses any custom `inspect()` function defined on `obj`.
|
|
||||||
* @since v0.1.101
|
|
||||||
*/
|
|
||||||
dir(obj: any, options?: InspectOptions): void;
|
|
||||||
/**
|
|
||||||
* This method calls `console.log()` passing it the arguments received.
|
|
||||||
* This method does not produce any XML formatting.
|
|
||||||
* @since v8.0.0
|
|
||||||
*/
|
|
||||||
dirxml(...data: any[]): void;
|
|
||||||
/**
|
|
||||||
* Prints to `stderr` with newline. Multiple arguments can be passed, with the
|
|
||||||
* first used as the primary message and all additional used as substitution
|
|
||||||
* values similar to [`printf(3)`](http://man7.org/linux/man-pages/man3/printf.3.html) (the arguments are all passed to `util.format()`).
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const code = 5;
|
|
||||||
* console.error('error #%d', code);
|
|
||||||
* // Prints: error #5, to stderr
|
|
||||||
* console.error('error', code);
|
|
||||||
* // Prints: error 5, to stderr
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* If formatting elements (e.g. `%d`) are not found in the first string then `util.inspect()` is called on each argument and the resulting string
|
|
||||||
* values are concatenated. See `util.format()` for more information.
|
|
||||||
* @since v0.1.100
|
|
||||||
*/
|
|
||||||
error(message?: any, ...optionalParams: any[]): void;
|
|
||||||
/**
|
|
||||||
* Increases indentation of subsequent lines by spaces for `groupIndentation`length.
|
|
||||||
*
|
|
||||||
* If one or more `label`s are provided, those are printed first without the
|
|
||||||
* additional indentation.
|
|
||||||
* @since v8.5.0
|
|
||||||
*/
|
|
||||||
group(...label: any[]): void;
|
|
||||||
/**
|
|
||||||
* An alias for {@link group}.
|
|
||||||
* @since v8.5.0
|
|
||||||
*/
|
|
||||||
groupCollapsed(...label: any[]): void;
|
|
||||||
/**
|
|
||||||
* Decreases indentation of subsequent lines by spaces for `groupIndentation`length.
|
|
||||||
* @since v8.5.0
|
|
||||||
*/
|
|
||||||
groupEnd(): void;
|
|
||||||
/**
|
|
||||||
* The `console.info()` function is an alias for {@link log}.
|
|
||||||
* @since v0.1.100
|
|
||||||
*/
|
|
||||||
info(message?: any, ...optionalParams: any[]): void;
|
|
||||||
/**
|
|
||||||
* Prints to `stdout` with newline. Multiple arguments can be passed, with the
|
|
||||||
* first used as the primary message and all additional used as substitution
|
|
||||||
* values similar to [`printf(3)`](http://man7.org/linux/man-pages/man3/printf.3.html) (the arguments are all passed to `util.format()`).
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const count = 5;
|
|
||||||
* console.log('count: %d', count);
|
|
||||||
* // Prints: count: 5, to stdout
|
|
||||||
* console.log('count:', count);
|
|
||||||
* // Prints: count: 5, to stdout
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* See `util.format()` for more information.
|
|
||||||
* @since v0.1.100
|
|
||||||
*/
|
|
||||||
log(message?: any, ...optionalParams: any[]): void;
|
|
||||||
/**
|
|
||||||
* Try to construct a table with the columns of the properties of `tabularData`(or use `properties`) and rows of `tabularData` and log it. Falls back to just
|
|
||||||
* logging the argument if it can’t be parsed as tabular.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* // These can't be parsed as tabular data
|
|
||||||
* console.table(Symbol());
|
|
||||||
* // Symbol()
|
|
||||||
*
|
|
||||||
* console.table(undefined);
|
|
||||||
* // undefined
|
|
||||||
*
|
|
||||||
* console.table([{ a: 1, b: 'Y' }, { a: 'Z', b: 2 }]);
|
|
||||||
* // ┌─────────┬─────┬─────┐
|
|
||||||
* // │ (index) │ a │ b │
|
|
||||||
* // ├─────────┼─────┼─────┤
|
|
||||||
* // │ 0 │ 1 │ 'Y' │
|
|
||||||
* // │ 1 │ 'Z' │ 2 │
|
|
||||||
* // └─────────┴─────┴─────┘
|
|
||||||
*
|
|
||||||
* console.table([{ a: 1, b: 'Y' }, { a: 'Z', b: 2 }], ['a']);
|
|
||||||
* // ┌─────────┬─────┐
|
|
||||||
* // │ (index) │ a │
|
|
||||||
* // ├─────────┼─────┤
|
|
||||||
* // │ 0 │ 1 │
|
|
||||||
* // │ 1 │ 'Z' │
|
|
||||||
* // └─────────┴─────┘
|
|
||||||
* ```
|
|
||||||
* @since v10.0.0
|
|
||||||
* @param properties Alternate properties for constructing the table.
|
|
||||||
*/
|
|
||||||
table(tabularData: any, properties?: ReadonlyArray<string>): void;
|
|
||||||
/**
|
|
||||||
* Starts a timer that can be used to compute the duration of an operation. Timers
|
|
||||||
* are identified by a unique `label`. Use the same `label` when calling {@link timeEnd} to stop the timer and output the elapsed time in
|
|
||||||
* suitable time units to `stdout`. For example, if the elapsed
|
|
||||||
* time is 3869ms, `console.timeEnd()` displays "3.869s".
|
|
||||||
* @since v0.1.104
|
|
||||||
*/
|
|
||||||
time(label?: string): void;
|
|
||||||
/**
|
|
||||||
* Stops a timer that was previously started by calling {@link time} and
|
|
||||||
* prints the result to `stdout`:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* console.time('100-elements');
|
|
||||||
* for (let i = 0; i < 100; i++) {}
|
|
||||||
* console.timeEnd('100-elements');
|
|
||||||
* // prints 100-elements: 225.438ms
|
|
||||||
* ```
|
|
||||||
* @since v0.1.104
|
|
||||||
*/
|
|
||||||
timeEnd(label?: string): void;
|
|
||||||
/**
|
|
||||||
* For a timer that was previously started by calling {@link time}, prints
|
|
||||||
* the elapsed time and other `data` arguments to `stdout`:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* console.time('process');
|
|
||||||
* const value = expensiveProcess1(); // Returns 42
|
|
||||||
* console.timeLog('process', value);
|
|
||||||
* // Prints "process: 365.227ms 42".
|
|
||||||
* doExpensiveProcess2(value);
|
|
||||||
* console.timeEnd('process');
|
|
||||||
* ```
|
|
||||||
* @since v10.7.0
|
|
||||||
*/
|
|
||||||
timeLog(label?: string, ...data: any[]): void;
|
|
||||||
/**
|
|
||||||
* Prints to `stderr` the string `'Trace: '`, followed by the `util.format()` formatted message and stack trace to the current position in the code.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* console.trace('Show me');
|
|
||||||
* // Prints: (stack trace will vary based on where trace is called)
|
|
||||||
* // Trace: Show me
|
|
||||||
* // at repl:2:9
|
|
||||||
* // at REPLServer.defaultEval (repl.js:248:27)
|
|
||||||
* // at bound (domain.js:287:14)
|
|
||||||
* // at REPLServer.runBound [as eval] (domain.js:300:12)
|
|
||||||
* // at REPLServer.<anonymous> (repl.js:412:12)
|
|
||||||
* // at emitOne (events.js:82:20)
|
|
||||||
* // at REPLServer.emit (events.js:169:7)
|
|
||||||
* // at REPLServer.Interface._onLine (readline.js:210:10)
|
|
||||||
* // at REPLServer.Interface._line (readline.js:549:8)
|
|
||||||
* // at REPLServer.Interface._ttyWrite (readline.js:826:14)
|
|
||||||
* ```
|
|
||||||
* @since v0.1.104
|
|
||||||
*/
|
|
||||||
trace(message?: any, ...optionalParams: any[]): void;
|
|
||||||
/**
|
|
||||||
* The `console.warn()` function is an alias for {@link error}.
|
|
||||||
* @since v0.1.100
|
|
||||||
*/
|
|
||||||
warn(message?: any, ...optionalParams: any[]): void;
|
|
||||||
// --- Inspector mode only ---
|
|
||||||
/**
|
|
||||||
* This method does not display anything unless used in the inspector.
|
|
||||||
* Starts a JavaScript CPU profile with an optional label.
|
|
||||||
*/
|
|
||||||
profile(label?: string): void;
|
|
||||||
/**
|
|
||||||
* This method does not display anything unless used in the inspector.
|
|
||||||
* Stops the current JavaScript CPU profiling session if one has been started and prints the report to the Profiles panel of the inspector.
|
|
||||||
*/
|
|
||||||
profileEnd(label?: string): void;
|
|
||||||
/**
|
|
||||||
* This method does not display anything unless used in the inspector.
|
|
||||||
* Adds an event with the label `label` to the Timeline panel of the inspector.
|
|
||||||
*/
|
|
||||||
timeStamp(label?: string): void;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* The `console` module provides a simple debugging console that is similar to the
|
|
||||||
* JavaScript console mechanism provided by web browsers.
|
|
||||||
*
|
|
||||||
* The module exports two specific components:
|
|
||||||
*
|
|
||||||
* * A `Console` class with methods such as `console.log()`, `console.error()` and`console.warn()` that can be used to write to any Node.js stream.
|
|
||||||
* * A global `console` instance configured to write to `process.stdout` and `process.stderr`. The global `console` can be used without calling`require('console')`.
|
|
||||||
*
|
|
||||||
* _**Warning**_: The global console object's methods are neither consistently
|
|
||||||
* synchronous like the browser APIs they resemble, nor are they consistently
|
|
||||||
* asynchronous like all other Node.js streams. See the `note on process I/O` for
|
|
||||||
* more information.
|
|
||||||
*
|
|
||||||
* Example using the global `console`:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* console.log('hello world');
|
|
||||||
* // Prints: hello world, to stdout
|
|
||||||
* console.log('hello %s', 'world');
|
|
||||||
* // Prints: hello world, to stdout
|
|
||||||
* console.error(new Error('Whoops, something bad happened'));
|
|
||||||
* // Prints error message and stack trace to stderr:
|
|
||||||
* // Error: Whoops, something bad happened
|
|
||||||
* // at [eval]:5:15
|
|
||||||
* // at Script.runInThisContext (node:vm:132:18)
|
|
||||||
* // at Object.runInThisContext (node:vm:309:38)
|
|
||||||
* // at node:internal/process/execution:77:19
|
|
||||||
* // at [eval]-wrapper:6:22
|
|
||||||
* // at evalScript (node:internal/process/execution:76:60)
|
|
||||||
* // at node:internal/main/eval_string:23:3
|
|
||||||
*
|
|
||||||
* const name = 'Will Robinson';
|
|
||||||
* console.warn(`Danger ${name}! Danger!`);
|
|
||||||
* // Prints: Danger Will Robinson! Danger!, to stderr
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Example using the `Console` class:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const out = getStreamSomehow();
|
|
||||||
* const err = getStreamSomehow();
|
|
||||||
* const myConsole = new console.Console(out, err);
|
|
||||||
*
|
|
||||||
* myConsole.log('hello world');
|
|
||||||
* // Prints: hello world, to out
|
|
||||||
* myConsole.log('hello %s', 'world');
|
|
||||||
* // Prints: hello world, to out
|
|
||||||
* myConsole.error(new Error('Whoops, something bad happened'));
|
|
||||||
* // Prints: [Error: Whoops, something bad happened], to err
|
|
||||||
*
|
|
||||||
* const name = 'Will Robinson';
|
|
||||||
* myConsole.warn(`Danger ${name}! Danger!`);
|
|
||||||
* // Prints: Danger Will Robinson! Danger!, to err
|
|
||||||
* ```
|
|
||||||
* @see [source](https://github.com/nodejs/node/blob/v16.4.2/lib/console.js)
|
|
||||||
*/
|
|
||||||
namespace console {
|
|
||||||
interface ConsoleConstructorOptions {
|
|
||||||
stdout: NodeJS.WritableStream;
|
|
||||||
stderr?: NodeJS.WritableStream | undefined;
|
|
||||||
ignoreErrors?: boolean | undefined;
|
|
||||||
colorMode?: boolean | 'auto' | undefined;
|
|
||||||
inspectOptions?: InspectOptions | undefined;
|
|
||||||
/**
|
|
||||||
* Set group indentation
|
|
||||||
* @default 2
|
|
||||||
*/
|
|
||||||
groupIndentation?: number | undefined;
|
|
||||||
}
|
|
||||||
interface ConsoleConstructor {
|
|
||||||
prototype: Console;
|
|
||||||
new (stdout: NodeJS.WritableStream, stderr?: NodeJS.WritableStream, ignoreErrors?: boolean): Console;
|
|
||||||
new (options: ConsoleConstructorOptions): Console;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
var console: Console;
|
|
||||||
}
|
|
||||||
export = globalThis.console;
|
|
||||||
}
|
|
||||||
|
|||||||
462
node_modules/@types/node/constants.d.ts
generated
vendored
Executable file → Normal file
462
node_modules/@types/node/constants.d.ts
generated
vendored
Executable file → Normal file
@@ -1,18 +1,448 @@
|
|||||||
/** @deprecated since v6.3.0 - use constants property exposed by the relevant module instead. */
|
/** @deprecated since v6.3.0 - use constants property exposed by the relevant module instead. */
|
||||||
declare module 'constants' {
|
declare module "constants" {
|
||||||
import { constants as osConstants, SignalConstants } from 'node:os';
|
/** @deprecated since v6.3.0 - use `os.constants.errno.E2BIG` instead. */
|
||||||
import { constants as cryptoConstants } from 'node:crypto';
|
const E2BIG: number;
|
||||||
import { constants as fsConstants } from 'node:fs';
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EACCES` instead. */
|
||||||
|
const EACCES: number;
|
||||||
const exp: typeof osConstants.errno &
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EADDRINUSE` instead. */
|
||||||
typeof osConstants.priority &
|
const EADDRINUSE: number;
|
||||||
SignalConstants &
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EADDRNOTAVAIL` instead. */
|
||||||
typeof cryptoConstants &
|
const EADDRNOTAVAIL: number;
|
||||||
typeof fsConstants;
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EAFNOSUPPORT` instead. */
|
||||||
export = exp;
|
const EAFNOSUPPORT: number;
|
||||||
}
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EAGAIN` instead. */
|
||||||
|
const EAGAIN: number;
|
||||||
declare module 'node:constants' {
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EALREADY` instead. */
|
||||||
import constants = require('constants');
|
const EALREADY: number;
|
||||||
export = constants;
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EBADF` instead. */
|
||||||
|
const EBADF: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EBADMSG` instead. */
|
||||||
|
const EBADMSG: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EBUSY` instead. */
|
||||||
|
const EBUSY: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ECANCELED` instead. */
|
||||||
|
const ECANCELED: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ECHILD` instead. */
|
||||||
|
const ECHILD: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ECONNABORTED` instead. */
|
||||||
|
const ECONNABORTED: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ECONNREFUSED` instead. */
|
||||||
|
const ECONNREFUSED: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ECONNRESET` instead. */
|
||||||
|
const ECONNRESET: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EDEADLK` instead. */
|
||||||
|
const EDEADLK: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EDESTADDRREQ` instead. */
|
||||||
|
const EDESTADDRREQ: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EDOM` instead. */
|
||||||
|
const EDOM: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EEXIST` instead. */
|
||||||
|
const EEXIST: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EFAULT` instead. */
|
||||||
|
const EFAULT: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EFBIG` instead. */
|
||||||
|
const EFBIG: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EHOSTUNREACH` instead. */
|
||||||
|
const EHOSTUNREACH: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EIDRM` instead. */
|
||||||
|
const EIDRM: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EILSEQ` instead. */
|
||||||
|
const EILSEQ: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EINPROGRESS` instead. */
|
||||||
|
const EINPROGRESS: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EINTR` instead. */
|
||||||
|
const EINTR: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EINVAL` instead. */
|
||||||
|
const EINVAL: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EIO` instead. */
|
||||||
|
const EIO: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EISCONN` instead. */
|
||||||
|
const EISCONN: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EISDIR` instead. */
|
||||||
|
const EISDIR: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ELOOP` instead. */
|
||||||
|
const ELOOP: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EMFILE` instead. */
|
||||||
|
const EMFILE: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EMLINK` instead. */
|
||||||
|
const EMLINK: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EMSGSIZE` instead. */
|
||||||
|
const EMSGSIZE: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ENAMETOOLONG` instead. */
|
||||||
|
const ENAMETOOLONG: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ENETDOWN` instead. */
|
||||||
|
const ENETDOWN: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ENETRESET` instead. */
|
||||||
|
const ENETRESET: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ENETUNREACH` instead. */
|
||||||
|
const ENETUNREACH: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ENFILE` instead. */
|
||||||
|
const ENFILE: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ENOBUFS` instead. */
|
||||||
|
const ENOBUFS: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ENODATA` instead. */
|
||||||
|
const ENODATA: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ENODEV` instead. */
|
||||||
|
const ENODEV: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ENOENT` instead. */
|
||||||
|
const ENOENT: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ENOEXEC` instead. */
|
||||||
|
const ENOEXEC: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ENOLCK` instead. */
|
||||||
|
const ENOLCK: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ENOLINK` instead. */
|
||||||
|
const ENOLINK: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ENOMEM` instead. */
|
||||||
|
const ENOMEM: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ENOMSG` instead. */
|
||||||
|
const ENOMSG: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ENOPROTOOPT` instead. */
|
||||||
|
const ENOPROTOOPT: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ENOSPC` instead. */
|
||||||
|
const ENOSPC: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ENOSR` instead. */
|
||||||
|
const ENOSR: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ENOSTR` instead. */
|
||||||
|
const ENOSTR: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ENOSYS` instead. */
|
||||||
|
const ENOSYS: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ENOTCONN` instead. */
|
||||||
|
const ENOTCONN: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ENOTDIR` instead. */
|
||||||
|
const ENOTDIR: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ENOTEMPTY` instead. */
|
||||||
|
const ENOTEMPTY: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ENOTSOCK` instead. */
|
||||||
|
const ENOTSOCK: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ENOTSUP` instead. */
|
||||||
|
const ENOTSUP: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ENOTTY` instead. */
|
||||||
|
const ENOTTY: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ENXIO` instead. */
|
||||||
|
const ENXIO: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EOPNOTSUPP` instead. */
|
||||||
|
const EOPNOTSUPP: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EOVERFLOW` instead. */
|
||||||
|
const EOVERFLOW: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EPERM` instead. */
|
||||||
|
const EPERM: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EPIPE` instead. */
|
||||||
|
const EPIPE: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EPROTO` instead. */
|
||||||
|
const EPROTO: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EPROTONOSUPPORT` instead. */
|
||||||
|
const EPROTONOSUPPORT: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EPROTOTYPE` instead. */
|
||||||
|
const EPROTOTYPE: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ERANGE` instead. */
|
||||||
|
const ERANGE: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EROFS` instead. */
|
||||||
|
const EROFS: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ESPIPE` instead. */
|
||||||
|
const ESPIPE: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ESRCH` instead. */
|
||||||
|
const ESRCH: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ETIME` instead. */
|
||||||
|
const ETIME: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ETIMEDOUT` instead. */
|
||||||
|
const ETIMEDOUT: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.ETXTBSY` instead. */
|
||||||
|
const ETXTBSY: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EWOULDBLOCK` instead. */
|
||||||
|
const EWOULDBLOCK: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.EXDEV` instead. */
|
||||||
|
const EXDEV: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEINTR` instead. */
|
||||||
|
const WSAEINTR: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEBADF` instead. */
|
||||||
|
const WSAEBADF: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEACCES` instead. */
|
||||||
|
const WSAEACCES: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEFAULT` instead. */
|
||||||
|
const WSAEFAULT: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEINVAL` instead. */
|
||||||
|
const WSAEINVAL: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEMFILE` instead. */
|
||||||
|
const WSAEMFILE: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEWOULDBLOCK` instead. */
|
||||||
|
const WSAEWOULDBLOCK: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEINPROGRESS` instead. */
|
||||||
|
const WSAEINPROGRESS: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEALREADY` instead. */
|
||||||
|
const WSAEALREADY: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAENOTSOCK` instead. */
|
||||||
|
const WSAENOTSOCK: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEDESTADDRREQ` instead. */
|
||||||
|
const WSAEDESTADDRREQ: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEMSGSIZE` instead. */
|
||||||
|
const WSAEMSGSIZE: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEPROTOTYPE` instead. */
|
||||||
|
const WSAEPROTOTYPE: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAENOPROTOOPT` instead. */
|
||||||
|
const WSAENOPROTOOPT: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEPROTONOSUPPORT` instead. */
|
||||||
|
const WSAEPROTONOSUPPORT: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAESOCKTNOSUPPORT` instead. */
|
||||||
|
const WSAESOCKTNOSUPPORT: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEOPNOTSUPP` instead. */
|
||||||
|
const WSAEOPNOTSUPP: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEPFNOSUPPORT` instead. */
|
||||||
|
const WSAEPFNOSUPPORT: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEAFNOSUPPORT` instead. */
|
||||||
|
const WSAEAFNOSUPPORT: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEADDRINUSE` instead. */
|
||||||
|
const WSAEADDRINUSE: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEADDRNOTAVAIL` instead. */
|
||||||
|
const WSAEADDRNOTAVAIL: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAENETDOWN` instead. */
|
||||||
|
const WSAENETDOWN: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAENETUNREACH` instead. */
|
||||||
|
const WSAENETUNREACH: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAENETRESET` instead. */
|
||||||
|
const WSAENETRESET: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAECONNABORTED` instead. */
|
||||||
|
const WSAECONNABORTED: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAECONNRESET` instead. */
|
||||||
|
const WSAECONNRESET: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAENOBUFS` instead. */
|
||||||
|
const WSAENOBUFS: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEISCONN` instead. */
|
||||||
|
const WSAEISCONN: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAENOTCONN` instead. */
|
||||||
|
const WSAENOTCONN: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAESHUTDOWN` instead. */
|
||||||
|
const WSAESHUTDOWN: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAETOOMANYREFS` instead. */
|
||||||
|
const WSAETOOMANYREFS: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAETIMEDOUT` instead. */
|
||||||
|
const WSAETIMEDOUT: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAECONNREFUSED` instead. */
|
||||||
|
const WSAECONNREFUSED: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAELOOP` instead. */
|
||||||
|
const WSAELOOP: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAENAMETOOLONG` instead. */
|
||||||
|
const WSAENAMETOOLONG: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEHOSTDOWN` instead. */
|
||||||
|
const WSAEHOSTDOWN: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEHOSTUNREACH` instead. */
|
||||||
|
const WSAEHOSTUNREACH: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAENOTEMPTY` instead. */
|
||||||
|
const WSAENOTEMPTY: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEPROCLIM` instead. */
|
||||||
|
const WSAEPROCLIM: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEUSERS` instead. */
|
||||||
|
const WSAEUSERS: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEDQUOT` instead. */
|
||||||
|
const WSAEDQUOT: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAESTALE` instead. */
|
||||||
|
const WSAESTALE: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEREMOTE` instead. */
|
||||||
|
const WSAEREMOTE: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSASYSNOTREADY` instead. */
|
||||||
|
const WSASYSNOTREADY: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAVERNOTSUPPORTED` instead. */
|
||||||
|
const WSAVERNOTSUPPORTED: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSANOTINITIALISED` instead. */
|
||||||
|
const WSANOTINITIALISED: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEDISCON` instead. */
|
||||||
|
const WSAEDISCON: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAENOMORE` instead. */
|
||||||
|
const WSAENOMORE: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAECANCELLED` instead. */
|
||||||
|
const WSAECANCELLED: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEINVALIDPROCTABLE` instead. */
|
||||||
|
const WSAEINVALIDPROCTABLE: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEINVALIDPROVIDER` instead. */
|
||||||
|
const WSAEINVALIDPROVIDER: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEPROVIDERFAILEDINIT` instead. */
|
||||||
|
const WSAEPROVIDERFAILEDINIT: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSASYSCALLFAILURE` instead. */
|
||||||
|
const WSASYSCALLFAILURE: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSASERVICE_NOT_FOUND` instead. */
|
||||||
|
const WSASERVICE_NOT_FOUND: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSATYPE_NOT_FOUND` instead. */
|
||||||
|
const WSATYPE_NOT_FOUND: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSA_E_NO_MORE` instead. */
|
||||||
|
const WSA_E_NO_MORE: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSA_E_CANCELLED` instead. */
|
||||||
|
const WSA_E_CANCELLED: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.errno.WSAEREFUSED` instead. */
|
||||||
|
const WSAEREFUSED: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGHUP` instead. */
|
||||||
|
const SIGHUP: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGINT` instead. */
|
||||||
|
const SIGINT: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGILL` instead. */
|
||||||
|
const SIGILL: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGABRT` instead. */
|
||||||
|
const SIGABRT: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGFPE` instead. */
|
||||||
|
const SIGFPE: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGKILL` instead. */
|
||||||
|
const SIGKILL: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGSEGV` instead. */
|
||||||
|
const SIGSEGV: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGTERM` instead. */
|
||||||
|
const SIGTERM: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGBREAK` instead. */
|
||||||
|
const SIGBREAK: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGWINCH` instead. */
|
||||||
|
const SIGWINCH: number;
|
||||||
|
const SSL_OP_ALL: number;
|
||||||
|
const SSL_OP_ALLOW_UNSAFE_LEGACY_RENEGOTIATION: number;
|
||||||
|
const SSL_OP_CIPHER_SERVER_PREFERENCE: number;
|
||||||
|
const SSL_OP_CISCO_ANYCONNECT: number;
|
||||||
|
const SSL_OP_COOKIE_EXCHANGE: number;
|
||||||
|
const SSL_OP_CRYPTOPRO_TLSEXT_BUG: number;
|
||||||
|
const SSL_OP_DONT_INSERT_EMPTY_FRAGMENTS: number;
|
||||||
|
const SSL_OP_EPHEMERAL_RSA: number;
|
||||||
|
const SSL_OP_LEGACY_SERVER_CONNECT: number;
|
||||||
|
const SSL_OP_MICROSOFT_BIG_SSLV3_BUFFER: number;
|
||||||
|
const SSL_OP_MICROSOFT_SESS_ID_BUG: number;
|
||||||
|
const SSL_OP_MSIE_SSLV2_RSA_PADDING: number;
|
||||||
|
const SSL_OP_NETSCAPE_CA_DN_BUG: number;
|
||||||
|
const SSL_OP_NETSCAPE_CHALLENGE_BUG: number;
|
||||||
|
const SSL_OP_NETSCAPE_DEMO_CIPHER_CHANGE_BUG: number;
|
||||||
|
const SSL_OP_NETSCAPE_REUSE_CIPHER_CHANGE_BUG: number;
|
||||||
|
const SSL_OP_NO_COMPRESSION: number;
|
||||||
|
const SSL_OP_NO_QUERY_MTU: number;
|
||||||
|
const SSL_OP_NO_SESSION_RESUMPTION_ON_RENEGOTIATION: number;
|
||||||
|
const SSL_OP_NO_SSLv2: number;
|
||||||
|
const SSL_OP_NO_SSLv3: number;
|
||||||
|
const SSL_OP_NO_TICKET: number;
|
||||||
|
const SSL_OP_NO_TLSv1: number;
|
||||||
|
const SSL_OP_NO_TLSv1_1: number;
|
||||||
|
const SSL_OP_NO_TLSv1_2: number;
|
||||||
|
const SSL_OP_PKCS1_CHECK_1: number;
|
||||||
|
const SSL_OP_PKCS1_CHECK_2: number;
|
||||||
|
const SSL_OP_SINGLE_DH_USE: number;
|
||||||
|
const SSL_OP_SINGLE_ECDH_USE: number;
|
||||||
|
const SSL_OP_SSLEAY_080_CLIENT_DH_BUG: number;
|
||||||
|
const SSL_OP_SSLREF2_REUSE_CERT_TYPE_BUG: number;
|
||||||
|
const SSL_OP_TLS_BLOCK_PADDING_BUG: number;
|
||||||
|
const SSL_OP_TLS_D5_BUG: number;
|
||||||
|
const SSL_OP_TLS_ROLLBACK_BUG: number;
|
||||||
|
const ENGINE_METHOD_DSA: number;
|
||||||
|
const ENGINE_METHOD_DH: number;
|
||||||
|
const ENGINE_METHOD_RAND: number;
|
||||||
|
const ENGINE_METHOD_ECDH: number;
|
||||||
|
const ENGINE_METHOD_ECDSA: number;
|
||||||
|
const ENGINE_METHOD_CIPHERS: number;
|
||||||
|
const ENGINE_METHOD_DIGESTS: number;
|
||||||
|
const ENGINE_METHOD_STORE: number;
|
||||||
|
const ENGINE_METHOD_PKEY_METHS: number;
|
||||||
|
const ENGINE_METHOD_PKEY_ASN1_METHS: number;
|
||||||
|
const ENGINE_METHOD_ALL: number;
|
||||||
|
const ENGINE_METHOD_NONE: number;
|
||||||
|
const DH_CHECK_P_NOT_SAFE_PRIME: number;
|
||||||
|
const DH_CHECK_P_NOT_PRIME: number;
|
||||||
|
const DH_UNABLE_TO_CHECK_GENERATOR: number;
|
||||||
|
const DH_NOT_SUITABLE_GENERATOR: number;
|
||||||
|
const RSA_PKCS1_PADDING: number;
|
||||||
|
const RSA_SSLV23_PADDING: number;
|
||||||
|
const RSA_NO_PADDING: number;
|
||||||
|
const RSA_PKCS1_OAEP_PADDING: number;
|
||||||
|
const RSA_X931_PADDING: number;
|
||||||
|
const RSA_PKCS1_PSS_PADDING: number;
|
||||||
|
const POINT_CONVERSION_COMPRESSED: number;
|
||||||
|
const POINT_CONVERSION_UNCOMPRESSED: number;
|
||||||
|
const POINT_CONVERSION_HYBRID: number;
|
||||||
|
const O_RDONLY: number;
|
||||||
|
const O_WRONLY: number;
|
||||||
|
const O_RDWR: number;
|
||||||
|
const S_IFMT: number;
|
||||||
|
const S_IFREG: number;
|
||||||
|
const S_IFDIR: number;
|
||||||
|
const S_IFCHR: number;
|
||||||
|
const S_IFBLK: number;
|
||||||
|
const S_IFIFO: number;
|
||||||
|
const S_IFSOCK: number;
|
||||||
|
const S_IRWXU: number;
|
||||||
|
const S_IRUSR: number;
|
||||||
|
const S_IWUSR: number;
|
||||||
|
const S_IXUSR: number;
|
||||||
|
const S_IRWXG: number;
|
||||||
|
const S_IRGRP: number;
|
||||||
|
const S_IWGRP: number;
|
||||||
|
const S_IXGRP: number;
|
||||||
|
const S_IRWXO: number;
|
||||||
|
const S_IROTH: number;
|
||||||
|
const S_IWOTH: number;
|
||||||
|
const S_IXOTH: number;
|
||||||
|
const S_IFLNK: number;
|
||||||
|
const O_CREAT: number;
|
||||||
|
const O_EXCL: number;
|
||||||
|
const O_NOCTTY: number;
|
||||||
|
const O_DIRECTORY: number;
|
||||||
|
const O_NOATIME: number;
|
||||||
|
const O_NOFOLLOW: number;
|
||||||
|
const O_SYNC: number;
|
||||||
|
const O_DSYNC: number;
|
||||||
|
const O_SYMLINK: number;
|
||||||
|
const O_DIRECT: number;
|
||||||
|
const O_NONBLOCK: number;
|
||||||
|
const O_TRUNC: number;
|
||||||
|
const O_APPEND: number;
|
||||||
|
const F_OK: number;
|
||||||
|
const R_OK: number;
|
||||||
|
const W_OK: number;
|
||||||
|
const X_OK: number;
|
||||||
|
const COPYFILE_EXCL: number;
|
||||||
|
const COPYFILE_FICLONE: number;
|
||||||
|
const COPYFILE_FICLONE_FORCE: number;
|
||||||
|
const UV_UDP_REUSEADDR: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGQUIT` instead. */
|
||||||
|
const SIGQUIT: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGTRAP` instead. */
|
||||||
|
const SIGTRAP: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGIOT` instead. */
|
||||||
|
const SIGIOT: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGBUS` instead. */
|
||||||
|
const SIGBUS: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGUSR1` instead. */
|
||||||
|
const SIGUSR1: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGUSR2` instead. */
|
||||||
|
const SIGUSR2: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGPIPE` instead. */
|
||||||
|
const SIGPIPE: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGALRM` instead. */
|
||||||
|
const SIGALRM: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGCHLD` instead. */
|
||||||
|
const SIGCHLD: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGSTKFLT` instead. */
|
||||||
|
const SIGSTKFLT: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGCONT` instead. */
|
||||||
|
const SIGCONT: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGSTOP` instead. */
|
||||||
|
const SIGSTOP: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGTSTP` instead. */
|
||||||
|
const SIGTSTP: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGTTIN` instead. */
|
||||||
|
const SIGTTIN: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGTTOU` instead. */
|
||||||
|
const SIGTTOU: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGURG` instead. */
|
||||||
|
const SIGURG: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGXCPU` instead. */
|
||||||
|
const SIGXCPU: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGXFSZ` instead. */
|
||||||
|
const SIGXFSZ: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGVTALRM` instead. */
|
||||||
|
const SIGVTALRM: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGPROF` instead. */
|
||||||
|
const SIGPROF: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGIO` instead. */
|
||||||
|
const SIGIO: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGPOLL` instead. */
|
||||||
|
const SIGPOLL: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGPWR` instead. */
|
||||||
|
const SIGPWR: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGSYS` instead. */
|
||||||
|
const SIGSYS: number;
|
||||||
|
/** @deprecated since v6.3.0 - use `os.constants.signals.SIGUNUSED` instead. */
|
||||||
|
const SIGUNUSED: number;
|
||||||
|
const defaultCoreCipherList: string;
|
||||||
|
const defaultCipherList: string;
|
||||||
|
const ENGINE_METHOD_RSA: number;
|
||||||
|
const ALPN_ENABLED: number;
|
||||||
}
|
}
|
||||||
|
|||||||
3184
node_modules/@types/node/crypto.d.ts
generated
vendored
Executable file → Normal file
3184
node_modules/@types/node/crypto.d.ts
generated
vendored
Executable file → Normal file
File diff suppressed because it is too large
Load Diff
559
node_modules/@types/node/dgram.d.ts
generated
vendored
Executable file → Normal file
559
node_modules/@types/node/dgram.d.ts
generated
vendored
Executable file → Normal file
@@ -1,499 +1,70 @@
|
|||||||
/**
|
declare module "dgram" {
|
||||||
* The `dgram` module provides an implementation of UDP datagram sockets.
|
import { AddressInfo } from "net";
|
||||||
*
|
import * as dns from "dns";
|
||||||
* ```js
|
import * as events from "events";
|
||||||
* import dgram from 'dgram';
|
|
||||||
*
|
|
||||||
* const server = dgram.createSocket('udp4');
|
|
||||||
*
|
|
||||||
* server.on('error', (err) => {
|
|
||||||
* console.log(`server error:\n${err.stack}`);
|
|
||||||
* server.close();
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* server.on('message', (msg, rinfo) => {
|
|
||||||
* console.log(`server got: ${msg} from ${rinfo.address}:${rinfo.port}`);
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* server.on('listening', () => {
|
|
||||||
* const address = server.address();
|
|
||||||
* console.log(`server listening ${address.address}:${address.port}`);
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* server.bind(41234);
|
|
||||||
* // Prints: server listening 0.0.0.0:41234
|
|
||||||
* ```
|
|
||||||
* @see [source](https://github.com/nodejs/node/blob/v16.9.0/lib/dgram.js)
|
|
||||||
*/
|
|
||||||
declare module 'dgram' {
|
|
||||||
import { AddressInfo } from 'node:net';
|
|
||||||
import * as dns from 'node:dns';
|
|
||||||
import { EventEmitter, Abortable } from 'node:events';
|
|
||||||
interface RemoteInfo {
|
interface RemoteInfo {
|
||||||
address: string;
|
address: string;
|
||||||
family: 'IPv4' | 'IPv6';
|
family: 'IPv4' | 'IPv6';
|
||||||
port: number;
|
port: number;
|
||||||
size: number;
|
size: number;
|
||||||
}
|
}
|
||||||
|
|
||||||
interface BindOptions {
|
interface BindOptions {
|
||||||
port?: number | undefined;
|
port?: number;
|
||||||
address?: string | undefined;
|
address?: string;
|
||||||
exclusive?: boolean | undefined;
|
exclusive?: boolean;
|
||||||
fd?: number | undefined;
|
fd?: number;
|
||||||
}
|
}
|
||||||
type SocketType = 'udp4' | 'udp6';
|
|
||||||
interface SocketOptions extends Abortable {
|
type SocketType = "udp4" | "udp6";
|
||||||
|
|
||||||
|
interface SocketOptions {
|
||||||
type: SocketType;
|
type: SocketType;
|
||||||
reuseAddr?: boolean | undefined;
|
reuseAddr?: boolean;
|
||||||
/**
|
/**
|
||||||
* @default false
|
* @default false
|
||||||
*/
|
*/
|
||||||
ipv6Only?: boolean | undefined;
|
ipv6Only?: boolean;
|
||||||
recvBufferSize?: number | undefined;
|
recvBufferSize?: number;
|
||||||
sendBufferSize?: number | undefined;
|
sendBufferSize?: number;
|
||||||
lookup?: ((hostname: string, options: dns.LookupOneOptions, callback: (err: NodeJS.ErrnoException | null, address: string, family: number) => void) => void) | undefined;
|
lookup?: (hostname: string, options: dns.LookupOneOptions, callback: (err: NodeJS.ErrnoException | null, address: string, family: number) => void) => void;
|
||||||
}
|
}
|
||||||
/**
|
|
||||||
* Creates a `dgram.Socket` object. Once the socket is created, calling `socket.bind()` will instruct the socket to begin listening for datagram
|
|
||||||
* messages. When `address` and `port` are not passed to `socket.bind()` the
|
|
||||||
* method will bind the socket to the "all interfaces" address on a random port
|
|
||||||
* (it does the right thing for both `udp4` and `udp6` sockets). The bound address
|
|
||||||
* and port can be retrieved using `socket.address().address` and `socket.address().port`.
|
|
||||||
*
|
|
||||||
* If the `signal` option is enabled, calling `.abort()` on the corresponding`AbortController` is similar to calling `.close()` on the socket:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const controller = new AbortController();
|
|
||||||
* const { signal } = controller;
|
|
||||||
* const server = dgram.createSocket({ type: 'udp4', signal });
|
|
||||||
* server.on('message', (msg, rinfo) => {
|
|
||||||
* console.log(`server got: ${msg} from ${rinfo.address}:${rinfo.port}`);
|
|
||||||
* });
|
|
||||||
* // Later, when you want to close the server.
|
|
||||||
* controller.abort();
|
|
||||||
* ```
|
|
||||||
* @since v0.11.13
|
|
||||||
* @param options Available options are:
|
|
||||||
* @param callback Attached as a listener for `'message'` events. Optional.
|
|
||||||
*/
|
|
||||||
function createSocket(type: SocketType, callback?: (msg: Buffer, rinfo: RemoteInfo) => void): Socket;
|
function createSocket(type: SocketType, callback?: (msg: Buffer, rinfo: RemoteInfo) => void): Socket;
|
||||||
function createSocket(options: SocketOptions, callback?: (msg: Buffer, rinfo: RemoteInfo) => void): Socket;
|
function createSocket(options: SocketOptions, callback?: (msg: Buffer, rinfo: RemoteInfo) => void): Socket;
|
||||||
/**
|
|
||||||
* Encapsulates the datagram functionality.
|
class Socket extends events.EventEmitter {
|
||||||
*
|
|
||||||
* New instances of `dgram.Socket` are created using {@link createSocket}.
|
|
||||||
* The `new` keyword is not to be used to create `dgram.Socket` instances.
|
|
||||||
* @since v0.1.99
|
|
||||||
*/
|
|
||||||
class Socket extends EventEmitter {
|
|
||||||
/**
|
|
||||||
* Tells the kernel to join a multicast group at the given `multicastAddress` and`multicastInterface` using the `IP_ADD_MEMBERSHIP` socket option. If the`multicastInterface` argument is not
|
|
||||||
* specified, the operating system will choose
|
|
||||||
* one interface and will add membership to it. To add membership to every
|
|
||||||
* available interface, call `addMembership` multiple times, once per interface.
|
|
||||||
*
|
|
||||||
* When called on an unbound socket, this method will implicitly bind to a random
|
|
||||||
* port, listening on all interfaces.
|
|
||||||
*
|
|
||||||
* When sharing a UDP socket across multiple `cluster` workers, the`socket.addMembership()` function must be called only once or an`EADDRINUSE` error will occur:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import cluster from 'cluster';
|
|
||||||
* import dgram from 'dgram';
|
|
||||||
*
|
|
||||||
* if (cluster.isPrimary) {
|
|
||||||
* cluster.fork(); // Works ok.
|
|
||||||
* cluster.fork(); // Fails with EADDRINUSE.
|
|
||||||
* } else {
|
|
||||||
* const s = dgram.createSocket('udp4');
|
|
||||||
* s.bind(1234, () => {
|
|
||||||
* s.addMembership('224.0.0.114');
|
|
||||||
* });
|
|
||||||
* }
|
|
||||||
* ```
|
|
||||||
* @since v0.6.9
|
|
||||||
*/
|
|
||||||
addMembership(multicastAddress: string, multicastInterface?: string): void;
|
addMembership(multicastAddress: string, multicastInterface?: string): void;
|
||||||
/**
|
|
||||||
* Returns an object containing the address information for a socket.
|
|
||||||
* For UDP sockets, this object will contain `address`, `family` and `port`properties.
|
|
||||||
*
|
|
||||||
* This method throws `EBADF` if called on an unbound socket.
|
|
||||||
* @since v0.1.99
|
|
||||||
*/
|
|
||||||
address(): AddressInfo;
|
address(): AddressInfo;
|
||||||
/**
|
bind(port?: number, address?: string, callback?: () => void): void;
|
||||||
* For UDP sockets, causes the `dgram.Socket` to listen for datagram
|
bind(port?: number, callback?: () => void): void;
|
||||||
* messages on a named `port` and optional `address`. If `port` is not
|
bind(callback?: () => void): void;
|
||||||
* specified or is `0`, the operating system will attempt to bind to a
|
bind(options: BindOptions, callback?: () => void): void;
|
||||||
* random port. If `address` is not specified, the operating system will
|
close(callback?: () => void): void;
|
||||||
* attempt to listen on all addresses. Once binding is complete, a`'listening'` event is emitted and the optional `callback` function is
|
|
||||||
* called.
|
|
||||||
*
|
|
||||||
* Specifying both a `'listening'` event listener and passing a`callback` to the `socket.bind()` method is not harmful but not very
|
|
||||||
* useful.
|
|
||||||
*
|
|
||||||
* A bound datagram socket keeps the Node.js process running to receive
|
|
||||||
* datagram messages.
|
|
||||||
*
|
|
||||||
* If binding fails, an `'error'` event is generated. In rare case (e.g.
|
|
||||||
* attempting to bind with a closed socket), an `Error` may be thrown.
|
|
||||||
*
|
|
||||||
* Example of a UDP server listening on port 41234:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import dgram from 'dgram';
|
|
||||||
*
|
|
||||||
* const server = dgram.createSocket('udp4');
|
|
||||||
*
|
|
||||||
* server.on('error', (err) => {
|
|
||||||
* console.log(`server error:\n${err.stack}`);
|
|
||||||
* server.close();
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* server.on('message', (msg, rinfo) => {
|
|
||||||
* console.log(`server got: ${msg} from ${rinfo.address}:${rinfo.port}`);
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* server.on('listening', () => {
|
|
||||||
* const address = server.address();
|
|
||||||
* console.log(`server listening ${address.address}:${address.port}`);
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* server.bind(41234);
|
|
||||||
* // Prints: server listening 0.0.0.0:41234
|
|
||||||
* ```
|
|
||||||
* @since v0.1.99
|
|
||||||
* @param callback with no parameters. Called when binding is complete.
|
|
||||||
*/
|
|
||||||
bind(port?: number, address?: string, callback?: () => void): this;
|
|
||||||
bind(port?: number, callback?: () => void): this;
|
|
||||||
bind(callback?: () => void): this;
|
|
||||||
bind(options: BindOptions, callback?: () => void): this;
|
|
||||||
/**
|
|
||||||
* Close the underlying socket and stop listening for data on it. If a callback is
|
|
||||||
* provided, it is added as a listener for the `'close'` event.
|
|
||||||
* @since v0.1.99
|
|
||||||
* @param callback Called when the socket has been closed.
|
|
||||||
*/
|
|
||||||
close(callback?: () => void): this;
|
|
||||||
/**
|
|
||||||
* Associates the `dgram.Socket` to a remote address and port. Every
|
|
||||||
* message sent by this handle is automatically sent to that destination. Also,
|
|
||||||
* the socket will only receive messages from that remote peer.
|
|
||||||
* Trying to call `connect()` on an already connected socket will result
|
|
||||||
* in an `ERR_SOCKET_DGRAM_IS_CONNECTED` exception. If `address` is not
|
|
||||||
* provided, `'127.0.0.1'` (for `udp4` sockets) or `'::1'` (for `udp6` sockets)
|
|
||||||
* will be used by default. Once the connection is complete, a `'connect'` event
|
|
||||||
* is emitted and the optional `callback` function is called. In case of failure,
|
|
||||||
* the `callback` is called or, failing this, an `'error'` event is emitted.
|
|
||||||
* @since v12.0.0
|
|
||||||
* @param callback Called when the connection is completed or on error.
|
|
||||||
*/
|
|
||||||
connect(port: number, address?: string, callback?: () => void): void;
|
connect(port: number, address?: string, callback?: () => void): void;
|
||||||
connect(port: number, callback: () => void): void;
|
connect(port: number, callback: () => void): void;
|
||||||
/**
|
|
||||||
* A synchronous function that disassociates a connected `dgram.Socket` from
|
|
||||||
* its remote address. Trying to call `disconnect()` on an unbound or already
|
|
||||||
* disconnected socket will result in an `ERR_SOCKET_DGRAM_NOT_CONNECTED` exception.
|
|
||||||
* @since v12.0.0
|
|
||||||
*/
|
|
||||||
disconnect(): void;
|
disconnect(): void;
|
||||||
/**
|
|
||||||
* Instructs the kernel to leave a multicast group at `multicastAddress` using the`IP_DROP_MEMBERSHIP` socket option. This method is automatically called by the
|
|
||||||
* kernel when the socket is closed or the process terminates, so most apps will
|
|
||||||
* never have reason to call this.
|
|
||||||
*
|
|
||||||
* If `multicastInterface` is not specified, the operating system will attempt to
|
|
||||||
* drop membership on all valid interfaces.
|
|
||||||
* @since v0.6.9
|
|
||||||
*/
|
|
||||||
dropMembership(multicastAddress: string, multicastInterface?: string): void;
|
dropMembership(multicastAddress: string, multicastInterface?: string): void;
|
||||||
/**
|
|
||||||
* This method throws `ERR_SOCKET_BUFFER_SIZE` if called on an unbound socket.
|
|
||||||
* @since v8.7.0
|
|
||||||
* @return the `SO_RCVBUF` socket receive buffer size in bytes.
|
|
||||||
*/
|
|
||||||
getRecvBufferSize(): number;
|
getRecvBufferSize(): number;
|
||||||
/**
|
|
||||||
* This method throws `ERR_SOCKET_BUFFER_SIZE` if called on an unbound socket.
|
|
||||||
* @since v8.7.0
|
|
||||||
* @return the `SO_SNDBUF` socket send buffer size in bytes.
|
|
||||||
*/
|
|
||||||
getSendBufferSize(): number;
|
getSendBufferSize(): number;
|
||||||
/**
|
|
||||||
* By default, binding a socket will cause it to block the Node.js process from
|
|
||||||
* exiting as long as the socket is open. The `socket.unref()` method can be used
|
|
||||||
* to exclude the socket from the reference counting that keeps the Node.js
|
|
||||||
* process active. The `socket.ref()` method adds the socket back to the reference
|
|
||||||
* counting and restores the default behavior.
|
|
||||||
*
|
|
||||||
* Calling `socket.ref()` multiples times will have no additional effect.
|
|
||||||
*
|
|
||||||
* The `socket.ref()` method returns a reference to the socket so calls can be
|
|
||||||
* chained.
|
|
||||||
* @since v0.9.1
|
|
||||||
*/
|
|
||||||
ref(): this;
|
ref(): this;
|
||||||
/**
|
|
||||||
* Returns an object containing the `address`, `family`, and `port` of the remote
|
|
||||||
* endpoint. This method throws an `ERR_SOCKET_DGRAM_NOT_CONNECTED` exception
|
|
||||||
* if the socket is not connected.
|
|
||||||
* @since v12.0.0
|
|
||||||
*/
|
|
||||||
remoteAddress(): AddressInfo;
|
remoteAddress(): AddressInfo;
|
||||||
/**
|
|
||||||
* Broadcasts a datagram on the socket.
|
|
||||||
* For connectionless sockets, the destination `port` and `address` must be
|
|
||||||
* specified. Connected sockets, on the other hand, will use their associated
|
|
||||||
* remote endpoint, so the `port` and `address` arguments must not be set.
|
|
||||||
*
|
|
||||||
* The `msg` argument contains the message to be sent.
|
|
||||||
* Depending on its type, different behavior can apply. If `msg` is a `Buffer`,
|
|
||||||
* any `TypedArray` or a `DataView`,
|
|
||||||
* the `offset` and `length` specify the offset within the `Buffer` where the
|
|
||||||
* message begins and the number of bytes in the message, respectively.
|
|
||||||
* If `msg` is a `String`, then it is automatically converted to a `Buffer`with `'utf8'` encoding. With messages that
|
|
||||||
* contain multi-byte characters, `offset` and `length` will be calculated with
|
|
||||||
* respect to `byte length` and not the character position.
|
|
||||||
* If `msg` is an array, `offset` and `length` must not be specified.
|
|
||||||
*
|
|
||||||
* The `address` argument is a string. If the value of `address` is a host name,
|
|
||||||
* DNS will be used to resolve the address of the host. If `address` is not
|
|
||||||
* provided or otherwise falsy, `'127.0.0.1'` (for `udp4` sockets) or `'::1'`(for `udp6` sockets) will be used by default.
|
|
||||||
*
|
|
||||||
* If the socket has not been previously bound with a call to `bind`, the socket
|
|
||||||
* is assigned a random port number and is bound to the "all interfaces" address
|
|
||||||
* (`'0.0.0.0'` for `udp4` sockets, `'::0'` for `udp6` sockets.)
|
|
||||||
*
|
|
||||||
* An optional `callback` function may be specified to as a way of reporting
|
|
||||||
* DNS errors or for determining when it is safe to reuse the `buf` object.
|
|
||||||
* DNS lookups delay the time to send for at least one tick of the
|
|
||||||
* Node.js event loop.
|
|
||||||
*
|
|
||||||
* The only way to know for sure that the datagram has been sent is by using a`callback`. If an error occurs and a `callback` is given, the error will be
|
|
||||||
* passed as the first argument to the `callback`. If a `callback` is not given,
|
|
||||||
* the error is emitted as an `'error'` event on the `socket` object.
|
|
||||||
*
|
|
||||||
* Offset and length are optional but both _must_ be set if either are used.
|
|
||||||
* They are supported only when the first argument is a `Buffer`, a `TypedArray`,
|
|
||||||
* or a `DataView`.
|
|
||||||
*
|
|
||||||
* This method throws `ERR_SOCKET_BAD_PORT` if called on an unbound socket.
|
|
||||||
*
|
|
||||||
* Example of sending a UDP packet to a port on `localhost`;
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import dgram from 'dgram';
|
|
||||||
* import { Buffer } from 'buffer';
|
|
||||||
*
|
|
||||||
* const message = Buffer.from('Some bytes');
|
|
||||||
* const client = dgram.createSocket('udp4');
|
|
||||||
* client.send(message, 41234, 'localhost', (err) => {
|
|
||||||
* client.close();
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Example of sending a UDP packet composed of multiple buffers to a port on`127.0.0.1`;
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import dgram from 'dgram';
|
|
||||||
* import { Buffer } from 'buffer';
|
|
||||||
*
|
|
||||||
* const buf1 = Buffer.from('Some ');
|
|
||||||
* const buf2 = Buffer.from('bytes');
|
|
||||||
* const client = dgram.createSocket('udp4');
|
|
||||||
* client.send([buf1, buf2], 41234, (err) => {
|
|
||||||
* client.close();
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Sending multiple buffers might be faster or slower depending on the
|
|
||||||
* application and operating system. Run benchmarks to
|
|
||||||
* determine the optimal strategy on a case-by-case basis. Generally speaking,
|
|
||||||
* however, sending multiple buffers is faster.
|
|
||||||
*
|
|
||||||
* Example of sending a UDP packet using a socket connected to a port on`localhost`:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import dgram from 'dgram';
|
|
||||||
* import { Buffer } from 'buffer';
|
|
||||||
*
|
|
||||||
* const message = Buffer.from('Some bytes');
|
|
||||||
* const client = dgram.createSocket('udp4');
|
|
||||||
* client.connect(41234, 'localhost', (err) => {
|
|
||||||
* client.send(message, (err) => {
|
|
||||||
* client.close();
|
|
||||||
* });
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
* @since v0.1.99
|
|
||||||
* @param msg Message to be sent.
|
|
||||||
* @param offset Offset in the buffer where the message starts.
|
|
||||||
* @param length Number of bytes in the message.
|
|
||||||
* @param port Destination port.
|
|
||||||
* @param address Destination host name or IP address.
|
|
||||||
* @param callback Called when the message has been sent.
|
|
||||||
*/
|
|
||||||
send(msg: string | Uint8Array | ReadonlyArray<any>, port?: number, address?: string, callback?: (error: Error | null, bytes: number) => void): void;
|
send(msg: string | Uint8Array | ReadonlyArray<any>, port?: number, address?: string, callback?: (error: Error | null, bytes: number) => void): void;
|
||||||
send(msg: string | Uint8Array | ReadonlyArray<any>, port?: number, callback?: (error: Error | null, bytes: number) => void): void;
|
send(msg: string | Uint8Array | ReadonlyArray<any>, port?: number, callback?: (error: Error | null, bytes: number) => void): void;
|
||||||
send(msg: string | Uint8Array | ReadonlyArray<any>, callback?: (error: Error | null, bytes: number) => void): void;
|
send(msg: string | Uint8Array | ReadonlyArray<any>, callback?: (error: Error | null, bytes: number) => void): void;
|
||||||
send(msg: string | Uint8Array, offset: number, length: number, port?: number, address?: string, callback?: (error: Error | null, bytes: number) => void): void;
|
send(msg: string | Uint8Array, offset: number, length: number, port?: number, address?: string, callback?: (error: Error | null, bytes: number) => void): void;
|
||||||
send(msg: string | Uint8Array, offset: number, length: number, port?: number, callback?: (error: Error | null, bytes: number) => void): void;
|
send(msg: string | Uint8Array, offset: number, length: number, port?: number, callback?: (error: Error | null, bytes: number) => void): void;
|
||||||
send(msg: string | Uint8Array, offset: number, length: number, callback?: (error: Error | null, bytes: number) => void): void;
|
send(msg: string | Uint8Array, offset: number, length: number, callback?: (error: Error | null, bytes: number) => void): void;
|
||||||
/**
|
|
||||||
* Sets or clears the `SO_BROADCAST` socket option. When set to `true`, UDP
|
|
||||||
* packets may be sent to a local interface's broadcast address.
|
|
||||||
*
|
|
||||||
* This method throws `EBADF` if called on an unbound socket.
|
|
||||||
* @since v0.6.9
|
|
||||||
*/
|
|
||||||
setBroadcast(flag: boolean): void;
|
setBroadcast(flag: boolean): void;
|
||||||
/**
|
|
||||||
* _All references to scope in this section are referring to [IPv6 Zone Indices](https://en.wikipedia.org/wiki/IPv6_address#Scoped_literal_IPv6_addresses), which are defined by [RFC
|
|
||||||
* 4007](https://tools.ietf.org/html/rfc4007). In string form, an IP_
|
|
||||||
* _with a scope index is written as `'IP%scope'` where scope is an interface name_
|
|
||||||
* _or interface number._
|
|
||||||
*
|
|
||||||
* Sets the default outgoing multicast interface of the socket to a chosen
|
|
||||||
* interface or back to system interface selection. The `multicastInterface` must
|
|
||||||
* be a valid string representation of an IP from the socket's family.
|
|
||||||
*
|
|
||||||
* For IPv4 sockets, this should be the IP configured for the desired physical
|
|
||||||
* interface. All packets sent to multicast on the socket will be sent on the
|
|
||||||
* interface determined by the most recent successful use of this call.
|
|
||||||
*
|
|
||||||
* For IPv6 sockets, `multicastInterface` should include a scope to indicate the
|
|
||||||
* interface as in the examples that follow. In IPv6, individual `send` calls can
|
|
||||||
* also use explicit scope in addresses, so only packets sent to a multicast
|
|
||||||
* address without specifying an explicit scope are affected by the most recent
|
|
||||||
* successful use of this call.
|
|
||||||
*
|
|
||||||
* This method throws `EBADF` if called on an unbound socket.
|
|
||||||
*
|
|
||||||
* #### Example: IPv6 outgoing multicast interface
|
|
||||||
*
|
|
||||||
* On most systems, where scope format uses the interface name:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const socket = dgram.createSocket('udp6');
|
|
||||||
*
|
|
||||||
* socket.bind(1234, () => {
|
|
||||||
* socket.setMulticastInterface('::%eth1');
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* On Windows, where scope format uses an interface number:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const socket = dgram.createSocket('udp6');
|
|
||||||
*
|
|
||||||
* socket.bind(1234, () => {
|
|
||||||
* socket.setMulticastInterface('::%2');
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* #### Example: IPv4 outgoing multicast interface
|
|
||||||
*
|
|
||||||
* All systems use an IP of the host on the desired physical interface:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const socket = dgram.createSocket('udp4');
|
|
||||||
*
|
|
||||||
* socket.bind(1234, () => {
|
|
||||||
* socket.setMulticastInterface('10.0.0.2');
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
* @since v8.6.0
|
|
||||||
*/
|
|
||||||
setMulticastInterface(multicastInterface: string): void;
|
setMulticastInterface(multicastInterface: string): void;
|
||||||
/**
|
setMulticastLoopback(flag: boolean): void;
|
||||||
* Sets or clears the `IP_MULTICAST_LOOP` socket option. When set to `true`,
|
setMulticastTTL(ttl: number): void;
|
||||||
* multicast packets will also be received on the local interface.
|
|
||||||
*
|
|
||||||
* This method throws `EBADF` if called on an unbound socket.
|
|
||||||
* @since v0.3.8
|
|
||||||
*/
|
|
||||||
setMulticastLoopback(flag: boolean): boolean;
|
|
||||||
/**
|
|
||||||
* Sets the `IP_MULTICAST_TTL` socket option. While TTL generally stands for
|
|
||||||
* "Time to Live", in this context it specifies the number of IP hops that a
|
|
||||||
* packet is allowed to travel through, specifically for multicast traffic. Each
|
|
||||||
* router or gateway that forwards a packet decrements the TTL. If the TTL is
|
|
||||||
* decremented to 0 by a router, it will not be forwarded.
|
|
||||||
*
|
|
||||||
* The `ttl` argument may be between 0 and 255\. The default on most systems is `1`.
|
|
||||||
*
|
|
||||||
* This method throws `EBADF` if called on an unbound socket.
|
|
||||||
* @since v0.3.8
|
|
||||||
*/
|
|
||||||
setMulticastTTL(ttl: number): number;
|
|
||||||
/**
|
|
||||||
* Sets the `SO_RCVBUF` socket option. Sets the maximum socket receive buffer
|
|
||||||
* in bytes.
|
|
||||||
*
|
|
||||||
* This method throws `ERR_SOCKET_BUFFER_SIZE` if called on an unbound socket.
|
|
||||||
* @since v8.7.0
|
|
||||||
*/
|
|
||||||
setRecvBufferSize(size: number): void;
|
setRecvBufferSize(size: number): void;
|
||||||
/**
|
|
||||||
* Sets the `SO_SNDBUF` socket option. Sets the maximum socket send buffer
|
|
||||||
* in bytes.
|
|
||||||
*
|
|
||||||
* This method throws `ERR_SOCKET_BUFFER_SIZE` if called on an unbound socket.
|
|
||||||
* @since v8.7.0
|
|
||||||
*/
|
|
||||||
setSendBufferSize(size: number): void;
|
setSendBufferSize(size: number): void;
|
||||||
/**
|
setTTL(ttl: number): void;
|
||||||
* Sets the `IP_TTL` socket option. While TTL generally stands for "Time to Live",
|
|
||||||
* in this context it specifies the number of IP hops that a packet is allowed to
|
|
||||||
* travel through. Each router or gateway that forwards a packet decrements the
|
|
||||||
* TTL. If the TTL is decremented to 0 by a router, it will not be forwarded.
|
|
||||||
* Changing TTL values is typically done for network probes or when multicasting.
|
|
||||||
*
|
|
||||||
* The `ttl` argument may be between between 1 and 255\. The default on most systems
|
|
||||||
* is 64.
|
|
||||||
*
|
|
||||||
* This method throws `EBADF` if called on an unbound socket.
|
|
||||||
* @since v0.1.101
|
|
||||||
*/
|
|
||||||
setTTL(ttl: number): number;
|
|
||||||
/**
|
|
||||||
* By default, binding a socket will cause it to block the Node.js process from
|
|
||||||
* exiting as long as the socket is open. The `socket.unref()` method can be used
|
|
||||||
* to exclude the socket from the reference counting that keeps the Node.js
|
|
||||||
* process active, allowing the process to exit even if the socket is still
|
|
||||||
* listening.
|
|
||||||
*
|
|
||||||
* Calling `socket.unref()` multiple times will have no addition effect.
|
|
||||||
*
|
|
||||||
* The `socket.unref()` method returns a reference to the socket so calls can be
|
|
||||||
* chained.
|
|
||||||
* @since v0.9.1
|
|
||||||
*/
|
|
||||||
unref(): this;
|
unref(): this;
|
||||||
/**
|
|
||||||
* Tells the kernel to join a source-specific multicast channel at the given`sourceAddress` and `groupAddress`, using the `multicastInterface` with the`IP_ADD_SOURCE_MEMBERSHIP` socket
|
|
||||||
* option. If the `multicastInterface` argument
|
|
||||||
* is not specified, the operating system will choose one interface and will add
|
|
||||||
* membership to it. To add membership to every available interface, call`socket.addSourceSpecificMembership()` multiple times, once per interface.
|
|
||||||
*
|
|
||||||
* When called on an unbound socket, this method will implicitly bind to a random
|
|
||||||
* port, listening on all interfaces.
|
|
||||||
* @since v13.1.0, v12.16.0
|
|
||||||
*/
|
|
||||||
addSourceSpecificMembership(sourceAddress: string, groupAddress: string, multicastInterface?: string): void;
|
|
||||||
/**
|
|
||||||
* Instructs the kernel to leave a source-specific multicast channel at the given`sourceAddress` and `groupAddress` using the `IP_DROP_SOURCE_MEMBERSHIP`socket option. This method is
|
|
||||||
* automatically called by the kernel when the
|
|
||||||
* socket is closed or the process terminates, so most apps will never have
|
|
||||||
* reason to call this.
|
|
||||||
*
|
|
||||||
* If `multicastInterface` is not specified, the operating system will attempt to
|
|
||||||
* drop membership on all valid interfaces.
|
|
||||||
* @since v13.1.0, v12.16.0
|
|
||||||
*/
|
|
||||||
dropSourceSpecificMembership(sourceAddress: string, groupAddress: string, multicastInterface?: string): void;
|
|
||||||
/**
|
/**
|
||||||
* events.EventEmitter
|
* events.EventEmitter
|
||||||
* 1. close
|
* 1. close
|
||||||
@@ -503,43 +74,45 @@ declare module 'dgram' {
|
|||||||
* 5. message
|
* 5. message
|
||||||
*/
|
*/
|
||||||
addListener(event: string, listener: (...args: any[]) => void): this;
|
addListener(event: string, listener: (...args: any[]) => void): this;
|
||||||
addListener(event: 'close', listener: () => void): this;
|
addListener(event: "close", listener: () => void): this;
|
||||||
addListener(event: 'connect', listener: () => void): this;
|
addListener(event: "connect", listener: () => void): this;
|
||||||
addListener(event: 'error', listener: (err: Error) => void): this;
|
addListener(event: "error", listener: (err: Error) => void): this;
|
||||||
addListener(event: 'listening', listener: () => void): this;
|
addListener(event: "listening", listener: () => void): this;
|
||||||
addListener(event: 'message', listener: (msg: Buffer, rinfo: RemoteInfo) => void): this;
|
addListener(event: "message", listener: (msg: Buffer, rinfo: RemoteInfo) => void): this;
|
||||||
|
|
||||||
emit(event: string | symbol, ...args: any[]): boolean;
|
emit(event: string | symbol, ...args: any[]): boolean;
|
||||||
emit(event: 'close'): boolean;
|
emit(event: "close"): boolean;
|
||||||
emit(event: 'connect'): boolean;
|
emit(event: "connect"): boolean;
|
||||||
emit(event: 'error', err: Error): boolean;
|
emit(event: "error", err: Error): boolean;
|
||||||
emit(event: 'listening'): boolean;
|
emit(event: "listening"): boolean;
|
||||||
emit(event: 'message', msg: Buffer, rinfo: RemoteInfo): boolean;
|
emit(event: "message", msg: Buffer, rinfo: RemoteInfo): boolean;
|
||||||
|
|
||||||
on(event: string, listener: (...args: any[]) => void): this;
|
on(event: string, listener: (...args: any[]) => void): this;
|
||||||
on(event: 'close', listener: () => void): this;
|
on(event: "close", listener: () => void): this;
|
||||||
on(event: 'connect', listener: () => void): this;
|
on(event: "connect", listener: () => void): this;
|
||||||
on(event: 'error', listener: (err: Error) => void): this;
|
on(event: "error", listener: (err: Error) => void): this;
|
||||||
on(event: 'listening', listener: () => void): this;
|
on(event: "listening", listener: () => void): this;
|
||||||
on(event: 'message', listener: (msg: Buffer, rinfo: RemoteInfo) => void): this;
|
on(event: "message", listener: (msg: Buffer, rinfo: RemoteInfo) => void): this;
|
||||||
|
|
||||||
once(event: string, listener: (...args: any[]) => void): this;
|
once(event: string, listener: (...args: any[]) => void): this;
|
||||||
once(event: 'close', listener: () => void): this;
|
once(event: "close", listener: () => void): this;
|
||||||
once(event: 'connect', listener: () => void): this;
|
once(event: "connect", listener: () => void): this;
|
||||||
once(event: 'error', listener: (err: Error) => void): this;
|
once(event: "error", listener: (err: Error) => void): this;
|
||||||
once(event: 'listening', listener: () => void): this;
|
once(event: "listening", listener: () => void): this;
|
||||||
once(event: 'message', listener: (msg: Buffer, rinfo: RemoteInfo) => void): this;
|
once(event: "message", listener: (msg: Buffer, rinfo: RemoteInfo) => void): this;
|
||||||
|
|
||||||
prependListener(event: string, listener: (...args: any[]) => void): this;
|
prependListener(event: string, listener: (...args: any[]) => void): this;
|
||||||
prependListener(event: 'close', listener: () => void): this;
|
prependListener(event: "close", listener: () => void): this;
|
||||||
prependListener(event: 'connect', listener: () => void): this;
|
prependListener(event: "connect", listener: () => void): this;
|
||||||
prependListener(event: 'error', listener: (err: Error) => void): this;
|
prependListener(event: "error", listener: (err: Error) => void): this;
|
||||||
prependListener(event: 'listening', listener: () => void): this;
|
prependListener(event: "listening", listener: () => void): this;
|
||||||
prependListener(event: 'message', listener: (msg: Buffer, rinfo: RemoteInfo) => void): this;
|
prependListener(event: "message", listener: (msg: Buffer, rinfo: RemoteInfo) => void): this;
|
||||||
|
|
||||||
prependOnceListener(event: string, listener: (...args: any[]) => void): this;
|
prependOnceListener(event: string, listener: (...args: any[]) => void): this;
|
||||||
prependOnceListener(event: 'close', listener: () => void): this;
|
prependOnceListener(event: "close", listener: () => void): this;
|
||||||
prependOnceListener(event: 'connect', listener: () => void): this;
|
prependOnceListener(event: "connect", listener: () => void): this;
|
||||||
prependOnceListener(event: 'error', listener: (err: Error) => void): this;
|
prependOnceListener(event: "error", listener: (err: Error) => void): this;
|
||||||
prependOnceListener(event: 'listening', listener: () => void): this;
|
prependOnceListener(event: "listening", listener: () => void): this;
|
||||||
prependOnceListener(event: 'message', listener: (msg: Buffer, rinfo: RemoteInfo) => void): this;
|
prependOnceListener(event: "message", listener: (msg: Buffer, rinfo: RemoteInfo) => void): this;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
declare module 'node:dgram' {
|
|
||||||
export * from 'dgram';
|
|
||||||
}
|
|
||||||
|
|||||||
134
node_modules/@types/node/diagnostics_channel.d.ts
generated
vendored
134
node_modules/@types/node/diagnostics_channel.d.ts
generated
vendored
@@ -1,134 +0,0 @@
|
|||||||
/**
|
|
||||||
* The `diagnostics_channel` module provides an API to create named channels
|
|
||||||
* to report arbitrary message data for diagnostics purposes.
|
|
||||||
*
|
|
||||||
* It can be accessed using:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import diagnostics_channel from 'diagnostics_channel';
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* It is intended that a module writer wanting to report diagnostics messages
|
|
||||||
* will create one or many top-level channels to report messages through.
|
|
||||||
* Channels may also be acquired at runtime but it is not encouraged
|
|
||||||
* due to the additional overhead of doing so. Channels may be exported for
|
|
||||||
* convenience, but as long as the name is known it can be acquired anywhere.
|
|
||||||
*
|
|
||||||
* If you intend for your module to produce diagnostics data for others to
|
|
||||||
* consume it is recommended that you include documentation of what named
|
|
||||||
* channels are used along with the shape of the message data. Channel names
|
|
||||||
* should generally include the module name to avoid collisions with data from
|
|
||||||
* other modules.
|
|
||||||
* @experimental
|
|
||||||
* @see [source](https://github.com/nodejs/node/blob/v16.9.0/lib/diagnostics_channel.js)
|
|
||||||
*/
|
|
||||||
declare module 'diagnostics_channel' {
|
|
||||||
/**
|
|
||||||
* Check if there are active subscribers to the named channel. This is helpful if
|
|
||||||
* the message you want to send might be expensive to prepare.
|
|
||||||
*
|
|
||||||
* This API is optional but helpful when trying to publish messages from very
|
|
||||||
* performance-sensitive code.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import diagnostics_channel from 'diagnostics_channel';
|
|
||||||
*
|
|
||||||
* if (diagnostics_channel.hasSubscribers('my-channel')) {
|
|
||||||
* // There are subscribers, prepare and publish message
|
|
||||||
* }
|
|
||||||
* ```
|
|
||||||
* @since v15.1.0, v14.17.0
|
|
||||||
* @param name The channel name
|
|
||||||
* @return If there are active subscribers
|
|
||||||
*/
|
|
||||||
function hasSubscribers(name: string): boolean;
|
|
||||||
/**
|
|
||||||
* This is the primary entry-point for anyone wanting to interact with a named
|
|
||||||
* channel. It produces a channel object which is optimized to reduce overhead at
|
|
||||||
* publish time as much as possible.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import diagnostics_channel from 'diagnostics_channel';
|
|
||||||
*
|
|
||||||
* const channel = diagnostics_channel.channel('my-channel');
|
|
||||||
* ```
|
|
||||||
* @since v15.1.0, v14.17.0
|
|
||||||
* @param name The channel name
|
|
||||||
* @return The named channel object
|
|
||||||
*/
|
|
||||||
function channel(name: string): Channel;
|
|
||||||
type ChannelListener = (name: string, message: unknown) => void;
|
|
||||||
/**
|
|
||||||
* The class `Channel` represents an individual named channel within the data
|
|
||||||
* pipeline. It is use to track subscribers and to publish messages when there
|
|
||||||
* are subscribers present. It exists as a separate object to avoid channel
|
|
||||||
* lookups at publish time, enabling very fast publish speeds and allowing
|
|
||||||
* for heavy use while incurring very minimal cost. Channels are created with {@link channel}, constructing a channel directly
|
|
||||||
* with `new Channel(name)` is not supported.
|
|
||||||
* @since v15.1.0, v14.17.0
|
|
||||||
*/
|
|
||||||
class Channel {
|
|
||||||
readonly name: string;
|
|
||||||
/**
|
|
||||||
* Check if there are active subscribers to this channel. This is helpful if
|
|
||||||
* the message you want to send might be expensive to prepare.
|
|
||||||
*
|
|
||||||
* This API is optional but helpful when trying to publish messages from very
|
|
||||||
* performance-sensitive code.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import diagnostics_channel from 'diagnostics_channel';
|
|
||||||
*
|
|
||||||
* const channel = diagnostics_channel.channel('my-channel');
|
|
||||||
*
|
|
||||||
* if (channel.hasSubscribers) {
|
|
||||||
* // There are subscribers, prepare and publish message
|
|
||||||
* }
|
|
||||||
* ```
|
|
||||||
* @since v15.1.0, v14.17.0
|
|
||||||
*/
|
|
||||||
readonly hasSubscribers: boolean;
|
|
||||||
private constructor(name: string);
|
|
||||||
/**
|
|
||||||
* Register a message handler to subscribe to this channel. This message handler
|
|
||||||
* will be run synchronously whenever a message is published to the channel. Any
|
|
||||||
* errors thrown in the message handler will trigger an `'uncaughtException'`.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import diagnostics_channel from 'diagnostics_channel';
|
|
||||||
*
|
|
||||||
* const channel = diagnostics_channel.channel('my-channel');
|
|
||||||
*
|
|
||||||
* channel.subscribe((message, name) => {
|
|
||||||
* // Received data
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
* @since v15.1.0, v14.17.0
|
|
||||||
* @param onMessage The handler to receive channel messages
|
|
||||||
*/
|
|
||||||
subscribe(onMessage: ChannelListener): void;
|
|
||||||
/**
|
|
||||||
* Remove a message handler previously registered to this channel with `channel.subscribe(onMessage)`.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* import diagnostics_channel from 'diagnostics_channel';
|
|
||||||
*
|
|
||||||
* const channel = diagnostics_channel.channel('my-channel');
|
|
||||||
*
|
|
||||||
* function onMessage(message, name) {
|
|
||||||
* // Received data
|
|
||||||
* }
|
|
||||||
*
|
|
||||||
* channel.subscribe(onMessage);
|
|
||||||
*
|
|
||||||
* channel.unsubscribe(onMessage);
|
|
||||||
* ```
|
|
||||||
* @since v15.1.0, v14.17.0
|
|
||||||
* @param onMessage The previous subscribed handler to remove
|
|
||||||
*/
|
|
||||||
unsubscribe(onMessage: ChannelListener): void;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
declare module 'node:diagnostics_channel' {
|
|
||||||
export * from 'diagnostics_channel';
|
|
||||||
}
|
|
||||||
810
node_modules/@types/node/dns.d.ts
generated
vendored
Executable file → Normal file
810
node_modules/@types/node/dns.d.ts
generated
vendored
Executable file → Normal file
@@ -1,191 +1,81 @@
|
|||||||
/**
|
declare module "dns" {
|
||||||
* The `dns` module enables name resolution. For example, use it to look up IP
|
|
||||||
* addresses of host names.
|
|
||||||
*
|
|
||||||
* Although named for the [Domain Name System (DNS)](https://en.wikipedia.org/wiki/Domain_Name_System), it does not always use the
|
|
||||||
* DNS protocol for lookups. {@link lookup} uses the operating system
|
|
||||||
* facilities to perform name resolution. It may not need to perform any network
|
|
||||||
* communication. To perform name resolution the way other applications on the same
|
|
||||||
* system do, use {@link lookup}.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const dns = require('dns');
|
|
||||||
*
|
|
||||||
* dns.lookup('example.org', (err, address, family) => {
|
|
||||||
* console.log('address: %j family: IPv%s', address, family);
|
|
||||||
* });
|
|
||||||
* // address: "93.184.216.34" family: IPv4
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* All other functions in the `dns` module connect to an actual DNS server to
|
|
||||||
* perform name resolution. They will always use the network to perform DNS
|
|
||||||
* queries. These functions do not use the same set of configuration files used by {@link lookup} (e.g. `/etc/hosts`). Use these functions to always perform
|
|
||||||
* DNS queries, bypassing other name-resolution facilities.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const dns = require('dns');
|
|
||||||
*
|
|
||||||
* dns.resolve4('archive.org', (err, addresses) => {
|
|
||||||
* if (err) throw err;
|
|
||||||
*
|
|
||||||
* console.log(`addresses: ${JSON.stringify(addresses)}`);
|
|
||||||
*
|
|
||||||
* addresses.forEach((a) => {
|
|
||||||
* dns.reverse(a, (err, hostnames) => {
|
|
||||||
* if (err) {
|
|
||||||
* throw err;
|
|
||||||
* }
|
|
||||||
* console.log(`reverse for ${a}: ${JSON.stringify(hostnames)}`);
|
|
||||||
* });
|
|
||||||
* });
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* See the `Implementation considerations section` for more information.
|
|
||||||
* @see [source](https://github.com/nodejs/node/blob/v16.9.0/lib/dns.js)
|
|
||||||
*/
|
|
||||||
declare module 'dns' {
|
|
||||||
import * as dnsPromises from 'node:dns/promises';
|
|
||||||
// Supported getaddrinfo flags.
|
// Supported getaddrinfo flags.
|
||||||
export const ADDRCONFIG: number;
|
const ADDRCONFIG: number;
|
||||||
export const V4MAPPED: number;
|
const V4MAPPED: number;
|
||||||
/**
|
|
||||||
* If `dns.V4MAPPED` is specified, return resolved IPv6 addresses as
|
interface LookupOptions {
|
||||||
* well as IPv4 mapped IPv6 addresses.
|
family?: number;
|
||||||
*/
|
hints?: number;
|
||||||
export const ALL: number;
|
all?: boolean;
|
||||||
export interface LookupOptions {
|
verbatim?: boolean;
|
||||||
family?: number | undefined;
|
|
||||||
hints?: number | undefined;
|
|
||||||
all?: boolean | undefined;
|
|
||||||
verbatim?: boolean | undefined;
|
|
||||||
}
|
}
|
||||||
export interface LookupOneOptions extends LookupOptions {
|
|
||||||
all?: false | undefined;
|
interface LookupOneOptions extends LookupOptions {
|
||||||
|
all?: false;
|
||||||
}
|
}
|
||||||
export interface LookupAllOptions extends LookupOptions {
|
|
||||||
|
interface LookupAllOptions extends LookupOptions {
|
||||||
all: true;
|
all: true;
|
||||||
}
|
}
|
||||||
export interface LookupAddress {
|
|
||||||
|
interface LookupAddress {
|
||||||
address: string;
|
address: string;
|
||||||
family: number;
|
family: number;
|
||||||
}
|
}
|
||||||
/**
|
|
||||||
* Resolves a host name (e.g. `'nodejs.org'`) into the first found A (IPv4) or
|
function lookup(hostname: string, family: number, callback: (err: NodeJS.ErrnoException | null, address: string, family: number) => void): void;
|
||||||
* AAAA (IPv6) record. All `option` properties are optional. If `options` is an
|
function lookup(hostname: string, options: LookupOneOptions, callback: (err: NodeJS.ErrnoException | null, address: string, family: number) => void): void;
|
||||||
* integer, then it must be `4` or `6` – if `options` is not provided, then IPv4
|
function lookup(hostname: string, options: LookupAllOptions, callback: (err: NodeJS.ErrnoException | null, addresses: LookupAddress[]) => void): void;
|
||||||
* and IPv6 addresses are both returned if found.
|
function lookup(hostname: string, options: LookupOptions, callback: (err: NodeJS.ErrnoException | null, address: string | LookupAddress[], family: number) => void): void;
|
||||||
*
|
function lookup(hostname: string, callback: (err: NodeJS.ErrnoException | null, address: string, family: number) => void): void;
|
||||||
* With the `all` option set to `true`, the arguments for `callback` change to`(err, addresses)`, with `addresses` being an array of objects with the
|
|
||||||
* properties `address` and `family`.
|
// NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime.
|
||||||
*
|
namespace lookup {
|
||||||
* On error, `err` is an `Error` object, where `err.code` is the error code.
|
|
||||||
* Keep in mind that `err.code` will be set to `'ENOTFOUND'` not only when
|
|
||||||
* the host name does not exist but also when the lookup fails in other ways
|
|
||||||
* such as no available file descriptors.
|
|
||||||
*
|
|
||||||
* `dns.lookup()` does not necessarily have anything to do with the DNS protocol.
|
|
||||||
* The implementation uses an operating system facility that can associate names
|
|
||||||
* with addresses, and vice versa. This implementation can have subtle but
|
|
||||||
* important consequences on the behavior of any Node.js program. Please take some
|
|
||||||
* time to consult the `Implementation considerations section` before using`dns.lookup()`.
|
|
||||||
*
|
|
||||||
* Example usage:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const dns = require('dns');
|
|
||||||
* const options = {
|
|
||||||
* family: 6,
|
|
||||||
* hints: dns.ADDRCONFIG | dns.V4MAPPED,
|
|
||||||
* };
|
|
||||||
* dns.lookup('example.com', options, (err, address, family) =>
|
|
||||||
* console.log('address: %j family: IPv%s', address, family));
|
|
||||||
* // address: "2606:2800:220:1:248:1893:25c8:1946" family: IPv6
|
|
||||||
*
|
|
||||||
* // When options.all is true, the result will be an Array.
|
|
||||||
* options.all = true;
|
|
||||||
* dns.lookup('example.com', options, (err, addresses) =>
|
|
||||||
* console.log('addresses: %j', addresses));
|
|
||||||
* // addresses: [{"address":"2606:2800:220:1:248:1893:25c8:1946","family":6}]
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* If this method is invoked as its `util.promisify()` ed version, and `all`is not set to `true`, it returns a `Promise` for an `Object` with `address` and`family` properties.
|
|
||||||
* @since v0.1.90
|
|
||||||
*/
|
|
||||||
export function lookup(hostname: string, family: number, callback: (err: NodeJS.ErrnoException | null, address: string, family: number) => void): void;
|
|
||||||
export function lookup(hostname: string, options: LookupOneOptions, callback: (err: NodeJS.ErrnoException | null, address: string, family: number) => void): void;
|
|
||||||
export function lookup(hostname: string, options: LookupAllOptions, callback: (err: NodeJS.ErrnoException | null, addresses: LookupAddress[]) => void): void;
|
|
||||||
export function lookup(hostname: string, options: LookupOptions, callback: (err: NodeJS.ErrnoException | null, address: string | LookupAddress[], family: number) => void): void;
|
|
||||||
export function lookup(hostname: string, callback: (err: NodeJS.ErrnoException | null, address: string, family: number) => void): void;
|
|
||||||
export namespace lookup {
|
|
||||||
function __promisify__(hostname: string, options: LookupAllOptions): Promise<LookupAddress[]>;
|
function __promisify__(hostname: string, options: LookupAllOptions): Promise<LookupAddress[]>;
|
||||||
function __promisify__(hostname: string, options?: LookupOneOptions | number): Promise<LookupAddress>;
|
function __promisify__(hostname: string, options?: LookupOneOptions | number): Promise<LookupAddress>;
|
||||||
function __promisify__(hostname: string, options: LookupOptions): Promise<LookupAddress | LookupAddress[]>;
|
function __promisify__(hostname: string, options: LookupOptions): Promise<LookupAddress | LookupAddress[]>;
|
||||||
}
|
}
|
||||||
/**
|
|
||||||
* Resolves the given `address` and `port` into a host name and service using
|
function lookupService(address: string, port: number, callback: (err: NodeJS.ErrnoException | null, hostname: string, service: string) => void): void;
|
||||||
* the operating system's underlying `getnameinfo` implementation.
|
|
||||||
*
|
namespace lookupService {
|
||||||
* If `address` is not a valid IP address, a `TypeError` will be thrown.
|
function __promisify__(address: string, port: number): Promise<{ hostname: string, service: string }>;
|
||||||
* The `port` will be coerced to a number. If it is not a legal port, a `TypeError`will be thrown.
|
|
||||||
*
|
|
||||||
* On an error, `err` is an `Error` object, where `err.code` is the error code.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const dns = require('dns');
|
|
||||||
* dns.lookupService('127.0.0.1', 22, (err, hostname, service) => {
|
|
||||||
* console.log(hostname, service);
|
|
||||||
* // Prints: localhost ssh
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* If this method is invoked as its `util.promisify()` ed version, it returns a`Promise` for an `Object` with `hostname` and `service` properties.
|
|
||||||
* @since v0.11.14
|
|
||||||
*/
|
|
||||||
export function lookupService(address: string, port: number, callback: (err: NodeJS.ErrnoException | null, hostname: string, service: string) => void): void;
|
|
||||||
export namespace lookupService {
|
|
||||||
function __promisify__(
|
|
||||||
address: string,
|
|
||||||
port: number
|
|
||||||
): Promise<{
|
|
||||||
hostname: string;
|
|
||||||
service: string;
|
|
||||||
}>;
|
|
||||||
}
|
}
|
||||||
export interface ResolveOptions {
|
|
||||||
|
interface ResolveOptions {
|
||||||
ttl: boolean;
|
ttl: boolean;
|
||||||
}
|
}
|
||||||
export interface ResolveWithTtlOptions extends ResolveOptions {
|
|
||||||
|
interface ResolveWithTtlOptions extends ResolveOptions {
|
||||||
ttl: true;
|
ttl: true;
|
||||||
}
|
}
|
||||||
export interface RecordWithTtl {
|
|
||||||
|
interface RecordWithTtl {
|
||||||
address: string;
|
address: string;
|
||||||
ttl: number;
|
ttl: number;
|
||||||
}
|
}
|
||||||
/** @deprecated Use `AnyARecord` or `AnyAaaaRecord` instead. */
|
|
||||||
export type AnyRecordWithTtl = AnyARecord | AnyAaaaRecord;
|
/** @deprecated Use AnyARecord or AnyAaaaRecord instead. */
|
||||||
export interface AnyARecord extends RecordWithTtl {
|
type AnyRecordWithTtl = AnyARecord | AnyAaaaRecord;
|
||||||
type: 'A';
|
|
||||||
|
interface AnyARecord extends RecordWithTtl {
|
||||||
|
type: "A";
|
||||||
}
|
}
|
||||||
export interface AnyAaaaRecord extends RecordWithTtl {
|
|
||||||
type: 'AAAA';
|
interface AnyAaaaRecord extends RecordWithTtl {
|
||||||
|
type: "AAAA";
|
||||||
}
|
}
|
||||||
export interface CaaRecord {
|
|
||||||
critial: number;
|
interface MxRecord {
|
||||||
issue?: string | undefined;
|
|
||||||
issuewild?: string | undefined;
|
|
||||||
iodef?: string | undefined;
|
|
||||||
contactemail?: string | undefined;
|
|
||||||
contactphone?: string | undefined;
|
|
||||||
}
|
|
||||||
export interface MxRecord {
|
|
||||||
priority: number;
|
priority: number;
|
||||||
exchange: string;
|
exchange: string;
|
||||||
}
|
}
|
||||||
export interface AnyMxRecord extends MxRecord {
|
|
||||||
type: 'MX';
|
interface AnyMxRecord extends MxRecord {
|
||||||
|
type: "MX";
|
||||||
}
|
}
|
||||||
export interface NaptrRecord {
|
|
||||||
|
interface NaptrRecord {
|
||||||
flags: string;
|
flags: string;
|
||||||
service: string;
|
service: string;
|
||||||
regexp: string;
|
regexp: string;
|
||||||
@@ -193,10 +83,12 @@ declare module 'dns' {
|
|||||||
order: number;
|
order: number;
|
||||||
preference: number;
|
preference: number;
|
||||||
}
|
}
|
||||||
export interface AnyNaptrRecord extends NaptrRecord {
|
|
||||||
type: 'NAPTR';
|
interface AnyNaptrRecord extends NaptrRecord {
|
||||||
|
type: "NAPTR";
|
||||||
}
|
}
|
||||||
export interface SoaRecord {
|
|
||||||
|
interface SoaRecord {
|
||||||
nsname: string;
|
nsname: string;
|
||||||
hostmaster: string;
|
hostmaster: string;
|
||||||
serial: number;
|
serial: number;
|
||||||
@@ -205,417 +97,183 @@ declare module 'dns' {
|
|||||||
expire: number;
|
expire: number;
|
||||||
minttl: number;
|
minttl: number;
|
||||||
}
|
}
|
||||||
export interface AnySoaRecord extends SoaRecord {
|
|
||||||
type: 'SOA';
|
interface AnySoaRecord extends SoaRecord {
|
||||||
|
type: "SOA";
|
||||||
}
|
}
|
||||||
export interface SrvRecord {
|
|
||||||
|
interface SrvRecord {
|
||||||
priority: number;
|
priority: number;
|
||||||
weight: number;
|
weight: number;
|
||||||
port: number;
|
port: number;
|
||||||
name: string;
|
name: string;
|
||||||
}
|
}
|
||||||
export interface AnySrvRecord extends SrvRecord {
|
|
||||||
type: 'SRV';
|
interface AnySrvRecord extends SrvRecord {
|
||||||
|
type: "SRV";
|
||||||
}
|
}
|
||||||
export interface AnyTxtRecord {
|
|
||||||
type: 'TXT';
|
interface AnyTxtRecord {
|
||||||
|
type: "TXT";
|
||||||
entries: string[];
|
entries: string[];
|
||||||
}
|
}
|
||||||
export interface AnyNsRecord {
|
|
||||||
type: 'NS';
|
interface AnyNsRecord {
|
||||||
|
type: "NS";
|
||||||
value: string;
|
value: string;
|
||||||
}
|
}
|
||||||
export interface AnyPtrRecord {
|
|
||||||
type: 'PTR';
|
interface AnyPtrRecord {
|
||||||
|
type: "PTR";
|
||||||
value: string;
|
value: string;
|
||||||
}
|
}
|
||||||
export interface AnyCnameRecord {
|
|
||||||
type: 'CNAME';
|
interface AnyCnameRecord {
|
||||||
|
type: "CNAME";
|
||||||
value: string;
|
value: string;
|
||||||
}
|
}
|
||||||
export type AnyRecord = AnyARecord | AnyAaaaRecord | AnyCnameRecord | AnyMxRecord | AnyNaptrRecord | AnyNsRecord | AnyPtrRecord | AnySoaRecord | AnySrvRecord | AnyTxtRecord;
|
|
||||||
/**
|
type AnyRecord = AnyARecord |
|
||||||
* Uses the DNS protocol to resolve a host name (e.g. `'nodejs.org'`) into an array
|
AnyAaaaRecord |
|
||||||
* of the resource records. The `callback` function has arguments`(err, records)`. When successful, `records` will be an array of resource
|
AnyCnameRecord |
|
||||||
* records. The type and structure of individual results varies based on `rrtype`:
|
AnyMxRecord |
|
||||||
*
|
AnyNaptrRecord |
|
||||||
* <omitted>
|
AnyNsRecord |
|
||||||
*
|
AnyPtrRecord |
|
||||||
* On error, `err` is an `Error` object, where `err.code` is one of the `DNS error codes`.
|
AnySoaRecord |
|
||||||
* @since v0.1.27
|
AnySrvRecord |
|
||||||
* @param hostname Host name to resolve.
|
AnyTxtRecord;
|
||||||
* @param [rrtype='A'] Resource record type.
|
|
||||||
*/
|
function resolve(hostname: string, callback: (err: NodeJS.ErrnoException | null, addresses: string[]) => void): void;
|
||||||
export function resolve(hostname: string, callback: (err: NodeJS.ErrnoException | null, addresses: string[]) => void): void;
|
function resolve(hostname: string, rrtype: "A", callback: (err: NodeJS.ErrnoException | null, addresses: string[]) => void): void;
|
||||||
export function resolve(hostname: string, rrtype: 'A', callback: (err: NodeJS.ErrnoException | null, addresses: string[]) => void): void;
|
function resolve(hostname: string, rrtype: "AAAA", callback: (err: NodeJS.ErrnoException | null, addresses: string[]) => void): void;
|
||||||
export function resolve(hostname: string, rrtype: 'AAAA', callback: (err: NodeJS.ErrnoException | null, addresses: string[]) => void): void;
|
function resolve(hostname: string, rrtype: "ANY", callback: (err: NodeJS.ErrnoException | null, addresses: AnyRecord[]) => void): void;
|
||||||
export function resolve(hostname: string, rrtype: 'ANY', callback: (err: NodeJS.ErrnoException | null, addresses: AnyRecord[]) => void): void;
|
function resolve(hostname: string, rrtype: "CNAME", callback: (err: NodeJS.ErrnoException | null, addresses: string[]) => void): void;
|
||||||
export function resolve(hostname: string, rrtype: 'CNAME', callback: (err: NodeJS.ErrnoException | null, addresses: string[]) => void): void;
|
function resolve(hostname: string, rrtype: "MX", callback: (err: NodeJS.ErrnoException | null, addresses: MxRecord[]) => void): void;
|
||||||
export function resolve(hostname: string, rrtype: 'MX', callback: (err: NodeJS.ErrnoException | null, addresses: MxRecord[]) => void): void;
|
function resolve(hostname: string, rrtype: "NAPTR", callback: (err: NodeJS.ErrnoException | null, addresses: NaptrRecord[]) => void): void;
|
||||||
export function resolve(hostname: string, rrtype: 'NAPTR', callback: (err: NodeJS.ErrnoException | null, addresses: NaptrRecord[]) => void): void;
|
function resolve(hostname: string, rrtype: "NS", callback: (err: NodeJS.ErrnoException | null, addresses: string[]) => void): void;
|
||||||
export function resolve(hostname: string, rrtype: 'NS', callback: (err: NodeJS.ErrnoException | null, addresses: string[]) => void): void;
|
function resolve(hostname: string, rrtype: "PTR", callback: (err: NodeJS.ErrnoException | null, addresses: string[]) => void): void;
|
||||||
export function resolve(hostname: string, rrtype: 'PTR', callback: (err: NodeJS.ErrnoException | null, addresses: string[]) => void): void;
|
function resolve(hostname: string, rrtype: "SOA", callback: (err: NodeJS.ErrnoException | null, addresses: SoaRecord) => void): void;
|
||||||
export function resolve(hostname: string, rrtype: 'SOA', callback: (err: NodeJS.ErrnoException | null, addresses: SoaRecord) => void): void;
|
function resolve(hostname: string, rrtype: "SRV", callback: (err: NodeJS.ErrnoException | null, addresses: SrvRecord[]) => void): void;
|
||||||
export function resolve(hostname: string, rrtype: 'SRV', callback: (err: NodeJS.ErrnoException | null, addresses: SrvRecord[]) => void): void;
|
function resolve(hostname: string, rrtype: "TXT", callback: (err: NodeJS.ErrnoException | null, addresses: string[][]) => void): void;
|
||||||
export function resolve(hostname: string, rrtype: 'TXT', callback: (err: NodeJS.ErrnoException | null, addresses: string[][]) => void): void;
|
function resolve(
|
||||||
export function resolve(
|
|
||||||
hostname: string,
|
hostname: string,
|
||||||
rrtype: string,
|
rrtype: string,
|
||||||
callback: (err: NodeJS.ErrnoException | null, addresses: string[] | MxRecord[] | NaptrRecord[] | SoaRecord | SrvRecord[] | string[][] | AnyRecord[]) => void
|
callback: (err: NodeJS.ErrnoException | null, addresses: string[] | MxRecord[] | NaptrRecord[] | SoaRecord | SrvRecord[] | string[][] | AnyRecord[]) => void,
|
||||||
): void;
|
): void;
|
||||||
export namespace resolve {
|
|
||||||
function __promisify__(hostname: string, rrtype?: 'A' | 'AAAA' | 'CNAME' | 'NS' | 'PTR'): Promise<string[]>;
|
// NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime.
|
||||||
function __promisify__(hostname: string, rrtype: 'ANY'): Promise<AnyRecord[]>;
|
namespace resolve {
|
||||||
function __promisify__(hostname: string, rrtype: 'MX'): Promise<MxRecord[]>;
|
function __promisify__(hostname: string, rrtype?: "A" | "AAAA" | "CNAME" | "NS" | "PTR"): Promise<string[]>;
|
||||||
function __promisify__(hostname: string, rrtype: 'NAPTR'): Promise<NaptrRecord[]>;
|
function __promisify__(hostname: string, rrtype: "ANY"): Promise<AnyRecord[]>;
|
||||||
function __promisify__(hostname: string, rrtype: 'SOA'): Promise<SoaRecord>;
|
function __promisify__(hostname: string, rrtype: "MX"): Promise<MxRecord[]>;
|
||||||
function __promisify__(hostname: string, rrtype: 'SRV'): Promise<SrvRecord[]>;
|
function __promisify__(hostname: string, rrtype: "NAPTR"): Promise<NaptrRecord[]>;
|
||||||
function __promisify__(hostname: string, rrtype: 'TXT'): Promise<string[][]>;
|
function __promisify__(hostname: string, rrtype: "SOA"): Promise<SoaRecord>;
|
||||||
|
function __promisify__(hostname: string, rrtype: "SRV"): Promise<SrvRecord[]>;
|
||||||
|
function __promisify__(hostname: string, rrtype: "TXT"): Promise<string[][]>;
|
||||||
function __promisify__(hostname: string, rrtype: string): Promise<string[] | MxRecord[] | NaptrRecord[] | SoaRecord | SrvRecord[] | string[][] | AnyRecord[]>;
|
function __promisify__(hostname: string, rrtype: string): Promise<string[] | MxRecord[] | NaptrRecord[] | SoaRecord | SrvRecord[] | string[][] | AnyRecord[]>;
|
||||||
}
|
}
|
||||||
/**
|
|
||||||
* Uses the DNS protocol to resolve a IPv4 addresses (`A` records) for the`hostname`. The `addresses` argument passed to the `callback` function
|
function resolve4(hostname: string, callback: (err: NodeJS.ErrnoException | null, addresses: string[]) => void): void;
|
||||||
* will contain an array of IPv4 addresses (e.g.`['74.125.79.104', '74.125.79.105', '74.125.79.106']`).
|
function resolve4(hostname: string, options: ResolveWithTtlOptions, callback: (err: NodeJS.ErrnoException | null, addresses: RecordWithTtl[]) => void): void;
|
||||||
* @since v0.1.16
|
function resolve4(hostname: string, options: ResolveOptions, callback: (err: NodeJS.ErrnoException | null, addresses: string[] | RecordWithTtl[]) => void): void;
|
||||||
* @param hostname Host name to resolve.
|
|
||||||
*/
|
// NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime.
|
||||||
export function resolve4(hostname: string, callback: (err: NodeJS.ErrnoException | null, addresses: string[]) => void): void;
|
namespace resolve4 {
|
||||||
export function resolve4(hostname: string, options: ResolveWithTtlOptions, callback: (err: NodeJS.ErrnoException | null, addresses: RecordWithTtl[]) => void): void;
|
|
||||||
export function resolve4(hostname: string, options: ResolveOptions, callback: (err: NodeJS.ErrnoException | null, addresses: string[] | RecordWithTtl[]) => void): void;
|
|
||||||
export namespace resolve4 {
|
|
||||||
function __promisify__(hostname: string): Promise<string[]>;
|
function __promisify__(hostname: string): Promise<string[]>;
|
||||||
function __promisify__(hostname: string, options: ResolveWithTtlOptions): Promise<RecordWithTtl[]>;
|
function __promisify__(hostname: string, options: ResolveWithTtlOptions): Promise<RecordWithTtl[]>;
|
||||||
function __promisify__(hostname: string, options?: ResolveOptions): Promise<string[] | RecordWithTtl[]>;
|
function __promisify__(hostname: string, options?: ResolveOptions): Promise<string[] | RecordWithTtl[]>;
|
||||||
}
|
}
|
||||||
/**
|
|
||||||
* Uses the DNS protocol to resolve a IPv6 addresses (`AAAA` records) for the`hostname`. The `addresses` argument passed to the `callback` function
|
function resolve6(hostname: string, callback: (err: NodeJS.ErrnoException | null, addresses: string[]) => void): void;
|
||||||
* will contain an array of IPv6 addresses.
|
function resolve6(hostname: string, options: ResolveWithTtlOptions, callback: (err: NodeJS.ErrnoException | null, addresses: RecordWithTtl[]) => void): void;
|
||||||
* @since v0.1.16
|
function resolve6(hostname: string, options: ResolveOptions, callback: (err: NodeJS.ErrnoException | null, addresses: string[] | RecordWithTtl[]) => void): void;
|
||||||
* @param hostname Host name to resolve.
|
|
||||||
*/
|
// NOTE: This namespace provides design-time support for util.promisify. Exported members do not exist at runtime.
|
||||||
export function resolve6(hostname: string, callback: (err: NodeJS.ErrnoException | null, addresses: string[]) => void): void;
|
namespace resolve6 {
|
||||||
export function resolve6(hostname: string, options: ResolveWithTtlOptions, callback: (err: NodeJS.ErrnoException | null, addresses: RecordWithTtl[]) => void): void;
|
|
||||||
export function resolve6(hostname: string, options: ResolveOptions, callback: (err: NodeJS.ErrnoException | null, addresses: string[] | RecordWithTtl[]) => void): void;
|
|
||||||
export namespace resolve6 {
|
|
||||||
function __promisify__(hostname: string): Promise<string[]>;
|
function __promisify__(hostname: string): Promise<string[]>;
|
||||||
function __promisify__(hostname: string, options: ResolveWithTtlOptions): Promise<RecordWithTtl[]>;
|
function __promisify__(hostname: string, options: ResolveWithTtlOptions): Promise<RecordWithTtl[]>;
|
||||||
function __promisify__(hostname: string, options?: ResolveOptions): Promise<string[] | RecordWithTtl[]>;
|
function __promisify__(hostname: string, options?: ResolveOptions): Promise<string[] | RecordWithTtl[]>;
|
||||||
}
|
}
|
||||||
/**
|
|
||||||
* Uses the DNS protocol to resolve `CNAME` records for the `hostname`. The`addresses` argument passed to the `callback` function
|
function resolveCname(hostname: string, callback: (err: NodeJS.ErrnoException | null, addresses: string[]) => void): void;
|
||||||
* will contain an array of canonical name records available for the `hostname`(e.g. `['bar.example.com']`).
|
namespace resolveCname {
|
||||||
* @since v0.3.2
|
|
||||||
*/
|
|
||||||
export function resolveCname(hostname: string, callback: (err: NodeJS.ErrnoException | null, addresses: string[]) => void): void;
|
|
||||||
export namespace resolveCname {
|
|
||||||
function __promisify__(hostname: string): Promise<string[]>;
|
function __promisify__(hostname: string): Promise<string[]>;
|
||||||
}
|
}
|
||||||
/**
|
|
||||||
* Uses the DNS protocol to resolve `CAA` records for the `hostname`. The`addresses` argument passed to the `callback` function
|
function resolveMx(hostname: string, callback: (err: NodeJS.ErrnoException | null, addresses: MxRecord[]) => void): void;
|
||||||
* will contain an array of certification authority authorization records
|
namespace resolveMx {
|
||||||
* available for the `hostname` (e.g. `[{critical: 0, iodef: 'mailto:pki@example.com'}, {critical: 128, issue: 'pki.example.com'}]`).
|
|
||||||
* @since v15.0.0
|
|
||||||
*/
|
|
||||||
export function resolveCaa(hostname: string, callback: (err: NodeJS.ErrnoException | null, records: CaaRecord[]) => void): void;
|
|
||||||
export namespace resolveCaa {
|
|
||||||
function __promisify__(hostname: string): Promise<CaaRecord[]>;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* Uses the DNS protocol to resolve mail exchange records (`MX` records) for the`hostname`. The `addresses` argument passed to the `callback` function will
|
|
||||||
* contain an array of objects containing both a `priority` and `exchange`property (e.g. `[{priority: 10, exchange: 'mx.example.com'}, ...]`).
|
|
||||||
* @since v0.1.27
|
|
||||||
*/
|
|
||||||
export function resolveMx(hostname: string, callback: (err: NodeJS.ErrnoException | null, addresses: MxRecord[]) => void): void;
|
|
||||||
export namespace resolveMx {
|
|
||||||
function __promisify__(hostname: string): Promise<MxRecord[]>;
|
function __promisify__(hostname: string): Promise<MxRecord[]>;
|
||||||
}
|
}
|
||||||
/**
|
|
||||||
* Uses the DNS protocol to resolve regular expression based records (`NAPTR`records) for the `hostname`. The `addresses` argument passed to the `callback`function will contain an array of
|
function resolveNaptr(hostname: string, callback: (err: NodeJS.ErrnoException | null, addresses: NaptrRecord[]) => void): void;
|
||||||
* objects with the following properties:
|
namespace resolveNaptr {
|
||||||
*
|
|
||||||
* * `flags`
|
|
||||||
* * `service`
|
|
||||||
* * `regexp`
|
|
||||||
* * `replacement`
|
|
||||||
* * `order`
|
|
||||||
* * `preference`
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* {
|
|
||||||
* flags: 's',
|
|
||||||
* service: 'SIP+D2U',
|
|
||||||
* regexp: '',
|
|
||||||
* replacement: '_sip._udp.example.com',
|
|
||||||
* order: 30,
|
|
||||||
* preference: 100
|
|
||||||
* }
|
|
||||||
* ```
|
|
||||||
* @since v0.9.12
|
|
||||||
*/
|
|
||||||
export function resolveNaptr(hostname: string, callback: (err: NodeJS.ErrnoException | null, addresses: NaptrRecord[]) => void): void;
|
|
||||||
export namespace resolveNaptr {
|
|
||||||
function __promisify__(hostname: string): Promise<NaptrRecord[]>;
|
function __promisify__(hostname: string): Promise<NaptrRecord[]>;
|
||||||
}
|
}
|
||||||
/**
|
|
||||||
* Uses the DNS protocol to resolve name server records (`NS` records) for the`hostname`. The `addresses` argument passed to the `callback` function will
|
function resolveNs(hostname: string, callback: (err: NodeJS.ErrnoException | null, addresses: string[]) => void): void;
|
||||||
* contain an array of name server records available for `hostname`(e.g. `['ns1.example.com', 'ns2.example.com']`).
|
namespace resolveNs {
|
||||||
* @since v0.1.90
|
|
||||||
*/
|
|
||||||
export function resolveNs(hostname: string, callback: (err: NodeJS.ErrnoException | null, addresses: string[]) => void): void;
|
|
||||||
export namespace resolveNs {
|
|
||||||
function __promisify__(hostname: string): Promise<string[]>;
|
function __promisify__(hostname: string): Promise<string[]>;
|
||||||
}
|
}
|
||||||
/**
|
|
||||||
* Uses the DNS protocol to resolve pointer records (`PTR` records) for the`hostname`. The `addresses` argument passed to the `callback` function will
|
function resolvePtr(hostname: string, callback: (err: NodeJS.ErrnoException | null, addresses: string[]) => void): void;
|
||||||
* be an array of strings containing the reply records.
|
namespace resolvePtr {
|
||||||
* @since v6.0.0
|
|
||||||
*/
|
|
||||||
export function resolvePtr(hostname: string, callback: (err: NodeJS.ErrnoException | null, addresses: string[]) => void): void;
|
|
||||||
export namespace resolvePtr {
|
|
||||||
function __promisify__(hostname: string): Promise<string[]>;
|
function __promisify__(hostname: string): Promise<string[]>;
|
||||||
}
|
}
|
||||||
/**
|
|
||||||
* Uses the DNS protocol to resolve a start of authority record (`SOA` record) for
|
function resolveSoa(hostname: string, callback: (err: NodeJS.ErrnoException | null, address: SoaRecord) => void): void;
|
||||||
* the `hostname`. The `address` argument passed to the `callback` function will
|
namespace resolveSoa {
|
||||||
* be an object with the following properties:
|
|
||||||
*
|
|
||||||
* * `nsname`
|
|
||||||
* * `hostmaster`
|
|
||||||
* * `serial`
|
|
||||||
* * `refresh`
|
|
||||||
* * `retry`
|
|
||||||
* * `expire`
|
|
||||||
* * `minttl`
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* {
|
|
||||||
* nsname: 'ns.example.com',
|
|
||||||
* hostmaster: 'root.example.com',
|
|
||||||
* serial: 2013101809,
|
|
||||||
* refresh: 10000,
|
|
||||||
* retry: 2400,
|
|
||||||
* expire: 604800,
|
|
||||||
* minttl: 3600
|
|
||||||
* }
|
|
||||||
* ```
|
|
||||||
* @since v0.11.10
|
|
||||||
*/
|
|
||||||
export function resolveSoa(hostname: string, callback: (err: NodeJS.ErrnoException | null, address: SoaRecord) => void): void;
|
|
||||||
export namespace resolveSoa {
|
|
||||||
function __promisify__(hostname: string): Promise<SoaRecord>;
|
function __promisify__(hostname: string): Promise<SoaRecord>;
|
||||||
}
|
}
|
||||||
/**
|
|
||||||
* Uses the DNS protocol to resolve service records (`SRV` records) for the`hostname`. The `addresses` argument passed to the `callback` function will
|
function resolveSrv(hostname: string, callback: (err: NodeJS.ErrnoException | null, addresses: SrvRecord[]) => void): void;
|
||||||
* be an array of objects with the following properties:
|
namespace resolveSrv {
|
||||||
*
|
|
||||||
* * `priority`
|
|
||||||
* * `weight`
|
|
||||||
* * `port`
|
|
||||||
* * `name`
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* {
|
|
||||||
* priority: 10,
|
|
||||||
* weight: 5,
|
|
||||||
* port: 21223,
|
|
||||||
* name: 'service.example.com'
|
|
||||||
* }
|
|
||||||
* ```
|
|
||||||
* @since v0.1.27
|
|
||||||
*/
|
|
||||||
export function resolveSrv(hostname: string, callback: (err: NodeJS.ErrnoException | null, addresses: SrvRecord[]) => void): void;
|
|
||||||
export namespace resolveSrv {
|
|
||||||
function __promisify__(hostname: string): Promise<SrvRecord[]>;
|
function __promisify__(hostname: string): Promise<SrvRecord[]>;
|
||||||
}
|
}
|
||||||
/**
|
|
||||||
* Uses the DNS protocol to resolve text queries (`TXT` records) for the`hostname`. The `records` argument passed to the `callback` function is a
|
function resolveTxt(hostname: string, callback: (err: NodeJS.ErrnoException | null, addresses: string[][]) => void): void;
|
||||||
* two-dimensional array of the text records available for `hostname` (e.g.`[ ['v=spf1 ip4:0.0.0.0 ', '~all' ] ]`). Each sub-array contains TXT chunks of
|
namespace resolveTxt {
|
||||||
* one record. Depending on the use case, these could be either joined together or
|
|
||||||
* treated separately.
|
|
||||||
* @since v0.1.27
|
|
||||||
*/
|
|
||||||
export function resolveTxt(hostname: string, callback: (err: NodeJS.ErrnoException | null, addresses: string[][]) => void): void;
|
|
||||||
export namespace resolveTxt {
|
|
||||||
function __promisify__(hostname: string): Promise<string[][]>;
|
function __promisify__(hostname: string): Promise<string[][]>;
|
||||||
}
|
}
|
||||||
/**
|
|
||||||
* Uses the DNS protocol to resolve all records (also known as `ANY` or `*` query).
|
function resolveAny(hostname: string, callback: (err: NodeJS.ErrnoException | null, addresses: AnyRecord[]) => void): void;
|
||||||
* The `ret` argument passed to the `callback` function will be an array containing
|
namespace resolveAny {
|
||||||
* various types of records. Each object has a property `type` that indicates the
|
|
||||||
* type of the current record. And depending on the `type`, additional properties
|
|
||||||
* will be present on the object:
|
|
||||||
*
|
|
||||||
* <omitted>
|
|
||||||
*
|
|
||||||
* Here is an example of the `ret` object passed to the callback:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* [ { type: 'A', address: '127.0.0.1', ttl: 299 },
|
|
||||||
* { type: 'CNAME', value: 'example.com' },
|
|
||||||
* { type: 'MX', exchange: 'alt4.aspmx.l.example.com', priority: 50 },
|
|
||||||
* { type: 'NS', value: 'ns1.example.com' },
|
|
||||||
* { type: 'TXT', entries: [ 'v=spf1 include:_spf.example.com ~all' ] },
|
|
||||||
* { type: 'SOA',
|
|
||||||
* nsname: 'ns1.example.com',
|
|
||||||
* hostmaster: 'admin.example.com',
|
|
||||||
* serial: 156696742,
|
|
||||||
* refresh: 900,
|
|
||||||
* retry: 900,
|
|
||||||
* expire: 1800,
|
|
||||||
* minttl: 60 } ]
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* DNS server operators may choose not to respond to `ANY`queries. It may be better to call individual methods like {@link resolve4},{@link resolveMx}, and so on. For more details, see [RFC
|
|
||||||
* 8482](https://tools.ietf.org/html/rfc8482).
|
|
||||||
*/
|
|
||||||
export function resolveAny(hostname: string, callback: (err: NodeJS.ErrnoException | null, addresses: AnyRecord[]) => void): void;
|
|
||||||
export namespace resolveAny {
|
|
||||||
function __promisify__(hostname: string): Promise<AnyRecord[]>;
|
function __promisify__(hostname: string): Promise<AnyRecord[]>;
|
||||||
}
|
}
|
||||||
/**
|
|
||||||
* Performs a reverse DNS query that resolves an IPv4 or IPv6 address to an
|
function reverse(ip: string, callback: (err: NodeJS.ErrnoException | null, hostnames: string[]) => void): void;
|
||||||
* array of host names.
|
function setServers(servers: ReadonlyArray<string>): void;
|
||||||
*
|
function getServers(): string[];
|
||||||
* On error, `err` is an `Error` object, where `err.code` is
|
|
||||||
* one of the `DNS error codes`.
|
|
||||||
* @since v0.1.16
|
|
||||||
*/
|
|
||||||
export function reverse(ip: string, callback: (err: NodeJS.ErrnoException | null, hostnames: string[]) => void): void;
|
|
||||||
/**
|
|
||||||
* Sets the IP address and port of servers to be used when performing DNS
|
|
||||||
* resolution. The `servers` argument is an array of [RFC 5952](https://tools.ietf.org/html/rfc5952#section-6) formatted
|
|
||||||
* addresses. If the port is the IANA default DNS port (53) it can be omitted.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* dns.setServers([
|
|
||||||
* '4.4.4.4',
|
|
||||||
* '[2001:4860:4860::8888]',
|
|
||||||
* '4.4.4.4:1053',
|
|
||||||
* '[2001:4860:4860::8888]:1053',
|
|
||||||
* ]);
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* An error will be thrown if an invalid address is provided.
|
|
||||||
*
|
|
||||||
* The `dns.setServers()` method must not be called while a DNS query is in
|
|
||||||
* progress.
|
|
||||||
*
|
|
||||||
* The {@link setServers} method affects only {@link resolve},`dns.resolve*()` and {@link reverse} (and specifically _not_ {@link lookup}).
|
|
||||||
*
|
|
||||||
* This method works much like [resolve.conf](https://man7.org/linux/man-pages/man5/resolv.conf.5.html).
|
|
||||||
* That is, if attempting to resolve with the first server provided results in a`NOTFOUND` error, the `resolve()` method will _not_ attempt to resolve with
|
|
||||||
* subsequent servers provided. Fallback DNS servers will only be used if the
|
|
||||||
* earlier ones time out or result in some other error.
|
|
||||||
* @since v0.11.3
|
|
||||||
* @param servers array of `RFC 5952` formatted addresses
|
|
||||||
*/
|
|
||||||
export function setServers(servers: ReadonlyArray<string>): void;
|
|
||||||
/**
|
|
||||||
* Returns an array of IP address strings, formatted according to [RFC 5952](https://tools.ietf.org/html/rfc5952#section-6),
|
|
||||||
* that are currently configured for DNS resolution. A string will include a port
|
|
||||||
* section if a custom port is used.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* [
|
|
||||||
* '4.4.4.4',
|
|
||||||
* '2001:4860:4860::8888',
|
|
||||||
* '4.4.4.4:1053',
|
|
||||||
* '[2001:4860:4860::8888]:1053',
|
|
||||||
* ]
|
|
||||||
* ```
|
|
||||||
* @since v0.11.3
|
|
||||||
*/
|
|
||||||
export function getServers(): string[];
|
|
||||||
/**
|
|
||||||
* Set the default value of `verbatim` in {@link lookup}. The value could be:
|
|
||||||
* - `ipv4first`: sets default `verbatim` `false`.
|
|
||||||
* - `verbatim`: sets default `verbatim` `true`.
|
|
||||||
*
|
|
||||||
* The default is `ipv4first` and {@link setDefaultResultOrder} have higher priority than `--dns-result-order`.
|
|
||||||
* When using worker threads, {@link setDefaultResultOrder} from the main thread won't affect the default dns orders in workers.
|
|
||||||
* @since v14.18.0
|
|
||||||
* @param order must be 'ipv4first' or 'verbatim'.
|
|
||||||
*/
|
|
||||||
export function setDefaultResultOrder(order: 'ipv4first' | 'verbatim'): void;
|
|
||||||
// Error codes
|
// Error codes
|
||||||
export const NODATA: string;
|
const NODATA: string;
|
||||||
export const FORMERR: string;
|
const FORMERR: string;
|
||||||
export const SERVFAIL: string;
|
const SERVFAIL: string;
|
||||||
export const NOTFOUND: string;
|
const NOTFOUND: string;
|
||||||
export const NOTIMP: string;
|
const NOTIMP: string;
|
||||||
export const REFUSED: string;
|
const REFUSED: string;
|
||||||
export const BADQUERY: string;
|
const BADQUERY: string;
|
||||||
export const BADNAME: string;
|
const BADNAME: string;
|
||||||
export const BADFAMILY: string;
|
const BADFAMILY: string;
|
||||||
export const BADRESP: string;
|
const BADRESP: string;
|
||||||
export const CONNREFUSED: string;
|
const CONNREFUSED: string;
|
||||||
export const TIMEOUT: string;
|
const TIMEOUT: string;
|
||||||
export const EOF: string;
|
const EOF: string;
|
||||||
export const FILE: string;
|
const FILE: string;
|
||||||
export const NOMEM: string;
|
const NOMEM: string;
|
||||||
export const DESTRUCTION: string;
|
const DESTRUCTION: string;
|
||||||
export const BADSTR: string;
|
const BADSTR: string;
|
||||||
export const BADFLAGS: string;
|
const BADFLAGS: string;
|
||||||
export const NONAME: string;
|
const NONAME: string;
|
||||||
export const BADHINTS: string;
|
const BADHINTS: string;
|
||||||
export const NOTINITIALIZED: string;
|
const NOTINITIALIZED: string;
|
||||||
export const LOADIPHLPAPI: string;
|
const LOADIPHLPAPI: string;
|
||||||
export const ADDRGETNETWORKPARAMS: string;
|
const ADDRGETNETWORKPARAMS: string;
|
||||||
export const CANCELLED: string;
|
const CANCELLED: string;
|
||||||
export interface ResolverOptions {
|
|
||||||
timeout?: number | undefined;
|
class Resolver {
|
||||||
/**
|
|
||||||
* @default 4
|
|
||||||
*/
|
|
||||||
tries?: number;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* An independent resolver for DNS requests.
|
|
||||||
*
|
|
||||||
* Creating a new resolver uses the default server settings. Setting
|
|
||||||
* the servers used for a resolver using `resolver.setServers()` does not affect
|
|
||||||
* other resolvers:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const { Resolver } = require('dns');
|
|
||||||
* const resolver = new Resolver();
|
|
||||||
* resolver.setServers(['4.4.4.4']);
|
|
||||||
*
|
|
||||||
* // This request will use the server at 4.4.4.4, independent of global settings.
|
|
||||||
* resolver.resolve4('example.org', (err, addresses) => {
|
|
||||||
* // ...
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* The following methods from the `dns` module are available:
|
|
||||||
*
|
|
||||||
* * `resolver.getServers()`
|
|
||||||
* * `resolver.resolve()`
|
|
||||||
* * `resolver.resolve4()`
|
|
||||||
* * `resolver.resolve6()`
|
|
||||||
* * `resolver.resolveAny()`
|
|
||||||
* * `resolver.resolveCaa()`
|
|
||||||
* * `resolver.resolveCname()`
|
|
||||||
* * `resolver.resolveMx()`
|
|
||||||
* * `resolver.resolveNaptr()`
|
|
||||||
* * `resolver.resolveNs()`
|
|
||||||
* * `resolver.resolvePtr()`
|
|
||||||
* * `resolver.resolveSoa()`
|
|
||||||
* * `resolver.resolveSrv()`
|
|
||||||
* * `resolver.resolveTxt()`
|
|
||||||
* * `resolver.reverse()`
|
|
||||||
* * `resolver.setServers()`
|
|
||||||
* @since v8.3.0
|
|
||||||
*/
|
|
||||||
export class Resolver {
|
|
||||||
constructor(options?: ResolverOptions);
|
|
||||||
/**
|
|
||||||
* Cancel all outstanding DNS queries made by this resolver. The corresponding
|
|
||||||
* callbacks will be called with an error with code `ECANCELLED`.
|
|
||||||
* @since v8.3.0
|
|
||||||
*/
|
|
||||||
cancel(): void;
|
|
||||||
getServers: typeof getServers;
|
getServers: typeof getServers;
|
||||||
|
setServers: typeof setServers;
|
||||||
resolve: typeof resolve;
|
resolve: typeof resolve;
|
||||||
resolve4: typeof resolve4;
|
resolve4: typeof resolve4;
|
||||||
resolve6: typeof resolve6;
|
resolve6: typeof resolve6;
|
||||||
@@ -629,26 +287,80 @@ declare module 'dns' {
|
|||||||
resolveSrv: typeof resolveSrv;
|
resolveSrv: typeof resolveSrv;
|
||||||
resolveTxt: typeof resolveTxt;
|
resolveTxt: typeof resolveTxt;
|
||||||
reverse: typeof reverse;
|
reverse: typeof reverse;
|
||||||
/**
|
cancel(): void;
|
||||||
* The resolver instance will send its requests from the specified IP address.
|
}
|
||||||
* This allows programs to specify outbound interfaces when used on multi-homed
|
|
||||||
* systems.
|
namespace promises {
|
||||||
*
|
function getServers(): string[];
|
||||||
* If a v4 or v6 address is not specified, it is set to the default, and the
|
|
||||||
* operating system will choose a local address automatically.
|
function lookup(hostname: string, family: number): Promise<LookupAddress>;
|
||||||
*
|
function lookup(hostname: string, options: LookupOneOptions): Promise<LookupAddress>;
|
||||||
* The resolver will use the v4 local address when making requests to IPv4 DNS
|
function lookup(hostname: string, options: LookupAllOptions): Promise<LookupAddress[]>;
|
||||||
* servers, and the v6 local address when making requests to IPv6 DNS servers.
|
function lookup(hostname: string, options: LookupOptions): Promise<LookupAddress | LookupAddress[]>;
|
||||||
* The `rrtype` of resolution requests has no impact on the local address used.
|
function lookup(hostname: string): Promise<LookupAddress>;
|
||||||
* @since v15.1.0
|
|
||||||
* @param [ipv4='0.0.0.0'] A string representation of an IPv4 address.
|
function lookupService(address: string, port: number): Promise<{ hostname: string, service: string }>;
|
||||||
* @param [ipv6='::0'] A string representation of an IPv6 address.
|
|
||||||
*/
|
function resolve(hostname: string): Promise<string[]>;
|
||||||
setLocalAddress(ipv4?: string, ipv6?: string): void;
|
function resolve(hostname: string, rrtype: "A"): Promise<string[]>;
|
||||||
setServers: typeof setServers;
|
function resolve(hostname: string, rrtype: "AAAA"): Promise<string[]>;
|
||||||
|
function resolve(hostname: string, rrtype: "ANY"): Promise<AnyRecord[]>;
|
||||||
|
function resolve(hostname: string, rrtype: "CNAME"): Promise<string[]>;
|
||||||
|
function resolve(hostname: string, rrtype: "MX"): Promise<MxRecord[]>;
|
||||||
|
function resolve(hostname: string, rrtype: "NAPTR"): Promise<NaptrRecord[]>;
|
||||||
|
function resolve(hostname: string, rrtype: "NS"): Promise<string[]>;
|
||||||
|
function resolve(hostname: string, rrtype: "PTR"): Promise<string[]>;
|
||||||
|
function resolve(hostname: string, rrtype: "SOA"): Promise<SoaRecord>;
|
||||||
|
function resolve(hostname: string, rrtype: "SRV"): Promise<SrvRecord[]>;
|
||||||
|
function resolve(hostname: string, rrtype: "TXT"): Promise<string[][]>;
|
||||||
|
function resolve(hostname: string, rrtype: string): Promise<string[] | MxRecord[] | NaptrRecord[] | SoaRecord | SrvRecord[] | string[][] | AnyRecord[]>;
|
||||||
|
|
||||||
|
function resolve4(hostname: string): Promise<string[]>;
|
||||||
|
function resolve4(hostname: string, options: ResolveWithTtlOptions): Promise<RecordWithTtl[]>;
|
||||||
|
function resolve4(hostname: string, options: ResolveOptions): Promise<string[] | RecordWithTtl[]>;
|
||||||
|
|
||||||
|
function resolve6(hostname: string): Promise<string[]>;
|
||||||
|
function resolve6(hostname: string, options: ResolveWithTtlOptions): Promise<RecordWithTtl[]>;
|
||||||
|
function resolve6(hostname: string, options: ResolveOptions): Promise<string[] | RecordWithTtl[]>;
|
||||||
|
|
||||||
|
function resolveAny(hostname: string): Promise<AnyRecord[]>;
|
||||||
|
|
||||||
|
function resolveCname(hostname: string): Promise<string[]>;
|
||||||
|
|
||||||
|
function resolveMx(hostname: string): Promise<MxRecord[]>;
|
||||||
|
|
||||||
|
function resolveNaptr(hostname: string): Promise<NaptrRecord[]>;
|
||||||
|
|
||||||
|
function resolveNs(hostname: string): Promise<string[]>;
|
||||||
|
|
||||||
|
function resolvePtr(hostname: string): Promise<string[]>;
|
||||||
|
|
||||||
|
function resolveSoa(hostname: string): Promise<SoaRecord>;
|
||||||
|
|
||||||
|
function resolveSrv(hostname: string): Promise<SrvRecord[]>;
|
||||||
|
|
||||||
|
function resolveTxt(hostname: string): Promise<string[][]>;
|
||||||
|
|
||||||
|
function reverse(ip: string): Promise<string[]>;
|
||||||
|
|
||||||
|
function setServers(servers: ReadonlyArray<string>): void;
|
||||||
|
|
||||||
|
class Resolver {
|
||||||
|
getServers: typeof getServers;
|
||||||
|
resolve: typeof resolve;
|
||||||
|
resolve4: typeof resolve4;
|
||||||
|
resolve6: typeof resolve6;
|
||||||
|
resolveAny: typeof resolveAny;
|
||||||
|
resolveCname: typeof resolveCname;
|
||||||
|
resolveMx: typeof resolveMx;
|
||||||
|
resolveNaptr: typeof resolveNaptr;
|
||||||
|
resolveNs: typeof resolveNs;
|
||||||
|
resolvePtr: typeof resolvePtr;
|
||||||
|
resolveSoa: typeof resolveSoa;
|
||||||
|
resolveSrv: typeof resolveSrv;
|
||||||
|
resolveTxt: typeof resolveTxt;
|
||||||
|
reverse: typeof reverse;
|
||||||
|
setServers: typeof setServers;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
export { dnsPromises as promises };
|
|
||||||
}
|
|
||||||
declare module 'node:dns' {
|
|
||||||
export * from 'dns';
|
|
||||||
}
|
}
|
||||||
|
|||||||
368
node_modules/@types/node/dns/promises.d.ts
generated
vendored
368
node_modules/@types/node/dns/promises.d.ts
generated
vendored
@@ -1,368 +0,0 @@
|
|||||||
/**
|
|
||||||
* The `dns.promises` API provides an alternative set of asynchronous DNS methods
|
|
||||||
* that return `Promise` objects rather than using callbacks. The API is accessible
|
|
||||||
* via `require('dns').promises` or `require('dns/promises')`.
|
|
||||||
* @since v10.6.0
|
|
||||||
*/
|
|
||||||
declare module 'dns/promises' {
|
|
||||||
import {
|
|
||||||
LookupAddress,
|
|
||||||
LookupOneOptions,
|
|
||||||
LookupAllOptions,
|
|
||||||
LookupOptions,
|
|
||||||
AnyRecord,
|
|
||||||
CaaRecord,
|
|
||||||
MxRecord,
|
|
||||||
NaptrRecord,
|
|
||||||
SoaRecord,
|
|
||||||
SrvRecord,
|
|
||||||
ResolveWithTtlOptions,
|
|
||||||
RecordWithTtl,
|
|
||||||
ResolveOptions,
|
|
||||||
ResolverOptions,
|
|
||||||
} from 'node:dns';
|
|
||||||
/**
|
|
||||||
* Returns an array of IP address strings, formatted according to [RFC 5952](https://tools.ietf.org/html/rfc5952#section-6),
|
|
||||||
* that are currently configured for DNS resolution. A string will include a port
|
|
||||||
* section if a custom port is used.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* [
|
|
||||||
* '4.4.4.4',
|
|
||||||
* '2001:4860:4860::8888',
|
|
||||||
* '4.4.4.4:1053',
|
|
||||||
* '[2001:4860:4860::8888]:1053',
|
|
||||||
* ]
|
|
||||||
* ```
|
|
||||||
* @since v10.6.0
|
|
||||||
*/
|
|
||||||
function getServers(): string[];
|
|
||||||
/**
|
|
||||||
* Resolves a host name (e.g. `'nodejs.org'`) into the first found A (IPv4) or
|
|
||||||
* AAAA (IPv6) record. All `option` properties are optional. If `options` is an
|
|
||||||
* integer, then it must be `4` or `6` – if `options` is not provided, then IPv4
|
|
||||||
* and IPv6 addresses are both returned if found.
|
|
||||||
*
|
|
||||||
* With the `all` option set to `true`, the `Promise` is resolved with `addresses`being an array of objects with the properties `address` and `family`.
|
|
||||||
*
|
|
||||||
* On error, the `Promise` is rejected with an `Error` object, where `err.code`is the error code.
|
|
||||||
* Keep in mind that `err.code` will be set to `'ENOTFOUND'` not only when
|
|
||||||
* the host name does not exist but also when the lookup fails in other ways
|
|
||||||
* such as no available file descriptors.
|
|
||||||
*
|
|
||||||
* `dnsPromises.lookup()` does not necessarily have anything to do with the DNS
|
|
||||||
* protocol. The implementation uses an operating system facility that can
|
|
||||||
* associate names with addresses, and vice versa. This implementation can have
|
|
||||||
* subtle but important consequences on the behavior of any Node.js program. Please
|
|
||||||
* take some time to consult the `Implementation considerations section` before
|
|
||||||
* using `dnsPromises.lookup()`.
|
|
||||||
*
|
|
||||||
* Example usage:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const dns = require('dns');
|
|
||||||
* const dnsPromises = dns.promises;
|
|
||||||
* const options = {
|
|
||||||
* family: 6,
|
|
||||||
* hints: dns.ADDRCONFIG | dns.V4MAPPED,
|
|
||||||
* };
|
|
||||||
*
|
|
||||||
* dnsPromises.lookup('example.com', options).then((result) => {
|
|
||||||
* console.log('address: %j family: IPv%s', result.address, result.family);
|
|
||||||
* // address: "2606:2800:220:1:248:1893:25c8:1946" family: IPv6
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* // When options.all is true, the result will be an Array.
|
|
||||||
* options.all = true;
|
|
||||||
* dnsPromises.lookup('example.com', options).then((result) => {
|
|
||||||
* console.log('addresses: %j', result);
|
|
||||||
* // addresses: [{"address":"2606:2800:220:1:248:1893:25c8:1946","family":6}]
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
* @since v10.6.0
|
|
||||||
*/
|
|
||||||
function lookup(hostname: string, family: number): Promise<LookupAddress>;
|
|
||||||
function lookup(hostname: string, options: LookupOneOptions): Promise<LookupAddress>;
|
|
||||||
function lookup(hostname: string, options: LookupAllOptions): Promise<LookupAddress[]>;
|
|
||||||
function lookup(hostname: string, options: LookupOptions): Promise<LookupAddress | LookupAddress[]>;
|
|
||||||
function lookup(hostname: string): Promise<LookupAddress>;
|
|
||||||
/**
|
|
||||||
* Resolves the given `address` and `port` into a host name and service using
|
|
||||||
* the operating system's underlying `getnameinfo` implementation.
|
|
||||||
*
|
|
||||||
* If `address` is not a valid IP address, a `TypeError` will be thrown.
|
|
||||||
* The `port` will be coerced to a number. If it is not a legal port, a `TypeError`will be thrown.
|
|
||||||
*
|
|
||||||
* On error, the `Promise` is rejected with an `Error` object, where `err.code`is the error code.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const dnsPromises = require('dns').promises;
|
|
||||||
* dnsPromises.lookupService('127.0.0.1', 22).then((result) => {
|
|
||||||
* console.log(result.hostname, result.service);
|
|
||||||
* // Prints: localhost ssh
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
* @since v10.6.0
|
|
||||||
*/
|
|
||||||
function lookupService(
|
|
||||||
address: string,
|
|
||||||
port: number
|
|
||||||
): Promise<{
|
|
||||||
hostname: string;
|
|
||||||
service: string;
|
|
||||||
}>;
|
|
||||||
/**
|
|
||||||
* Uses the DNS protocol to resolve a host name (e.g. `'nodejs.org'`) into an array
|
|
||||||
* of the resource records. When successful, the `Promise` is resolved with an
|
|
||||||
* array of resource records. The type and structure of individual results vary
|
|
||||||
* based on `rrtype`:
|
|
||||||
*
|
|
||||||
* <omitted>
|
|
||||||
*
|
|
||||||
* On error, the `Promise` is rejected with an `Error` object, where `err.code`is one of the `DNS error codes`.
|
|
||||||
* @since v10.6.0
|
|
||||||
* @param hostname Host name to resolve.
|
|
||||||
* @param [rrtype='A'] Resource record type.
|
|
||||||
*/
|
|
||||||
function resolve(hostname: string): Promise<string[]>;
|
|
||||||
function resolve(hostname: string, rrtype: 'A'): Promise<string[]>;
|
|
||||||
function resolve(hostname: string, rrtype: 'AAAA'): Promise<string[]>;
|
|
||||||
function resolve(hostname: string, rrtype: 'ANY'): Promise<AnyRecord[]>;
|
|
||||||
function resolve(hostname: string, rrtype: 'CAA'): Promise<CaaRecord[]>;
|
|
||||||
function resolve(hostname: string, rrtype: 'CNAME'): Promise<string[]>;
|
|
||||||
function resolve(hostname: string, rrtype: 'MX'): Promise<MxRecord[]>;
|
|
||||||
function resolve(hostname: string, rrtype: 'NAPTR'): Promise<NaptrRecord[]>;
|
|
||||||
function resolve(hostname: string, rrtype: 'NS'): Promise<string[]>;
|
|
||||||
function resolve(hostname: string, rrtype: 'PTR'): Promise<string[]>;
|
|
||||||
function resolve(hostname: string, rrtype: 'SOA'): Promise<SoaRecord>;
|
|
||||||
function resolve(hostname: string, rrtype: 'SRV'): Promise<SrvRecord[]>;
|
|
||||||
function resolve(hostname: string, rrtype: 'TXT'): Promise<string[][]>;
|
|
||||||
function resolve(hostname: string, rrtype: string): Promise<string[] | MxRecord[] | NaptrRecord[] | SoaRecord | SrvRecord[] | string[][] | AnyRecord[]>;
|
|
||||||
/**
|
|
||||||
* Uses the DNS protocol to resolve IPv4 addresses (`A` records) for the`hostname`. On success, the `Promise` is resolved with an array of IPv4
|
|
||||||
* addresses (e.g. `['74.125.79.104', '74.125.79.105', '74.125.79.106']`).
|
|
||||||
* @since v10.6.0
|
|
||||||
* @param hostname Host name to resolve.
|
|
||||||
*/
|
|
||||||
function resolve4(hostname: string): Promise<string[]>;
|
|
||||||
function resolve4(hostname: string, options: ResolveWithTtlOptions): Promise<RecordWithTtl[]>;
|
|
||||||
function resolve4(hostname: string, options: ResolveOptions): Promise<string[] | RecordWithTtl[]>;
|
|
||||||
/**
|
|
||||||
* Uses the DNS protocol to resolve IPv6 addresses (`AAAA` records) for the`hostname`. On success, the `Promise` is resolved with an array of IPv6
|
|
||||||
* addresses.
|
|
||||||
* @since v10.6.0
|
|
||||||
* @param hostname Host name to resolve.
|
|
||||||
*/
|
|
||||||
function resolve6(hostname: string): Promise<string[]>;
|
|
||||||
function resolve6(hostname: string, options: ResolveWithTtlOptions): Promise<RecordWithTtl[]>;
|
|
||||||
function resolve6(hostname: string, options: ResolveOptions): Promise<string[] | RecordWithTtl[]>;
|
|
||||||
/**
|
|
||||||
* Uses the DNS protocol to resolve all records (also known as `ANY` or `*` query).
|
|
||||||
* On success, the `Promise` is resolved with an array containing various types of
|
|
||||||
* records. Each object has a property `type` that indicates the type of the
|
|
||||||
* current record. And depending on the `type`, additional properties will be
|
|
||||||
* present on the object:
|
|
||||||
*
|
|
||||||
* <omitted>
|
|
||||||
*
|
|
||||||
* Here is an example of the result object:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* [ { type: 'A', address: '127.0.0.1', ttl: 299 },
|
|
||||||
* { type: 'CNAME', value: 'example.com' },
|
|
||||||
* { type: 'MX', exchange: 'alt4.aspmx.l.example.com', priority: 50 },
|
|
||||||
* { type: 'NS', value: 'ns1.example.com' },
|
|
||||||
* { type: 'TXT', entries: [ 'v=spf1 include:_spf.example.com ~all' ] },
|
|
||||||
* { type: 'SOA',
|
|
||||||
* nsname: 'ns1.example.com',
|
|
||||||
* hostmaster: 'admin.example.com',
|
|
||||||
* serial: 156696742,
|
|
||||||
* refresh: 900,
|
|
||||||
* retry: 900,
|
|
||||||
* expire: 1800,
|
|
||||||
* minttl: 60 } ]
|
|
||||||
* ```
|
|
||||||
* @since v10.6.0
|
|
||||||
*/
|
|
||||||
function resolveAny(hostname: string): Promise<AnyRecord[]>;
|
|
||||||
/**
|
|
||||||
* Uses the DNS protocol to resolve `CAA` records for the `hostname`. On success,
|
|
||||||
* the `Promise` is resolved with an array of objects containing available
|
|
||||||
* certification authority authorization records available for the `hostname`(e.g. `[{critical: 0, iodef: 'mailto:pki@example.com'},{critical: 128, issue: 'pki.example.com'}]`).
|
|
||||||
* @since v15.0.0
|
|
||||||
*/
|
|
||||||
function resolveCaa(hostname: string): Promise<CaaRecord[]>;
|
|
||||||
/**
|
|
||||||
* Uses the DNS protocol to resolve `CNAME` records for the `hostname`. On success,
|
|
||||||
* the `Promise` is resolved with an array of canonical name records available for
|
|
||||||
* the `hostname` (e.g. `['bar.example.com']`).
|
|
||||||
* @since v10.6.0
|
|
||||||
*/
|
|
||||||
function resolveCname(hostname: string): Promise<string[]>;
|
|
||||||
/**
|
|
||||||
* Uses the DNS protocol to resolve mail exchange records (`MX` records) for the`hostname`. On success, the `Promise` is resolved with an array of objects
|
|
||||||
* containing both a `priority` and `exchange` property (e.g.`[{priority: 10, exchange: 'mx.example.com'}, ...]`).
|
|
||||||
* @since v10.6.0
|
|
||||||
*/
|
|
||||||
function resolveMx(hostname: string): Promise<MxRecord[]>;
|
|
||||||
/**
|
|
||||||
* Uses the DNS protocol to resolve regular expression based records (`NAPTR`records) for the `hostname`. On success, the `Promise` is resolved with an array
|
|
||||||
* of objects with the following properties:
|
|
||||||
*
|
|
||||||
* * `flags`
|
|
||||||
* * `service`
|
|
||||||
* * `regexp`
|
|
||||||
* * `replacement`
|
|
||||||
* * `order`
|
|
||||||
* * `preference`
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* {
|
|
||||||
* flags: 's',
|
|
||||||
* service: 'SIP+D2U',
|
|
||||||
* regexp: '',
|
|
||||||
* replacement: '_sip._udp.example.com',
|
|
||||||
* order: 30,
|
|
||||||
* preference: 100
|
|
||||||
* }
|
|
||||||
* ```
|
|
||||||
* @since v10.6.0
|
|
||||||
*/
|
|
||||||
function resolveNaptr(hostname: string): Promise<NaptrRecord[]>;
|
|
||||||
/**
|
|
||||||
* Uses the DNS protocol to resolve name server records (`NS` records) for the`hostname`. On success, the `Promise` is resolved with an array of name server
|
|
||||||
* records available for `hostname` (e.g.`['ns1.example.com', 'ns2.example.com']`).
|
|
||||||
* @since v10.6.0
|
|
||||||
*/
|
|
||||||
function resolveNs(hostname: string): Promise<string[]>;
|
|
||||||
/**
|
|
||||||
* Uses the DNS protocol to resolve pointer records (`PTR` records) for the`hostname`. On success, the `Promise` is resolved with an array of strings
|
|
||||||
* containing the reply records.
|
|
||||||
* @since v10.6.0
|
|
||||||
*/
|
|
||||||
function resolvePtr(hostname: string): Promise<string[]>;
|
|
||||||
/**
|
|
||||||
* Uses the DNS protocol to resolve a start of authority record (`SOA` record) for
|
|
||||||
* the `hostname`. On success, the `Promise` is resolved with an object with the
|
|
||||||
* following properties:
|
|
||||||
*
|
|
||||||
* * `nsname`
|
|
||||||
* * `hostmaster`
|
|
||||||
* * `serial`
|
|
||||||
* * `refresh`
|
|
||||||
* * `retry`
|
|
||||||
* * `expire`
|
|
||||||
* * `minttl`
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* {
|
|
||||||
* nsname: 'ns.example.com',
|
|
||||||
* hostmaster: 'root.example.com',
|
|
||||||
* serial: 2013101809,
|
|
||||||
* refresh: 10000,
|
|
||||||
* retry: 2400,
|
|
||||||
* expire: 604800,
|
|
||||||
* minttl: 3600
|
|
||||||
* }
|
|
||||||
* ```
|
|
||||||
* @since v10.6.0
|
|
||||||
*/
|
|
||||||
function resolveSoa(hostname: string): Promise<SoaRecord>;
|
|
||||||
/**
|
|
||||||
* Uses the DNS protocol to resolve service records (`SRV` records) for the`hostname`. On success, the `Promise` is resolved with an array of objects with
|
|
||||||
* the following properties:
|
|
||||||
*
|
|
||||||
* * `priority`
|
|
||||||
* * `weight`
|
|
||||||
* * `port`
|
|
||||||
* * `name`
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* {
|
|
||||||
* priority: 10,
|
|
||||||
* weight: 5,
|
|
||||||
* port: 21223,
|
|
||||||
* name: 'service.example.com'
|
|
||||||
* }
|
|
||||||
* ```
|
|
||||||
* @since v10.6.0
|
|
||||||
*/
|
|
||||||
function resolveSrv(hostname: string): Promise<SrvRecord[]>;
|
|
||||||
/**
|
|
||||||
* Uses the DNS protocol to resolve text queries (`TXT` records) for the`hostname`. On success, the `Promise` is resolved with a two-dimensional array
|
|
||||||
* of the text records available for `hostname` (e.g.`[ ['v=spf1 ip4:0.0.0.0 ', '~all' ] ]`). Each sub-array contains TXT chunks of
|
|
||||||
* one record. Depending on the use case, these could be either joined together or
|
|
||||||
* treated separately.
|
|
||||||
* @since v10.6.0
|
|
||||||
*/
|
|
||||||
function resolveTxt(hostname: string): Promise<string[][]>;
|
|
||||||
/**
|
|
||||||
* Performs a reverse DNS query that resolves an IPv4 or IPv6 address to an
|
|
||||||
* array of host names.
|
|
||||||
*
|
|
||||||
* On error, the `Promise` is rejected with an `Error` object, where `err.code`is one of the `DNS error codes`.
|
|
||||||
* @since v10.6.0
|
|
||||||
*/
|
|
||||||
function reverse(ip: string): Promise<string[]>;
|
|
||||||
/**
|
|
||||||
* Sets the IP address and port of servers to be used when performing DNS
|
|
||||||
* resolution. The `servers` argument is an array of [RFC 5952](https://tools.ietf.org/html/rfc5952#section-6) formatted
|
|
||||||
* addresses. If the port is the IANA default DNS port (53) it can be omitted.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* dnsPromises.setServers([
|
|
||||||
* '4.4.4.4',
|
|
||||||
* '[2001:4860:4860::8888]',
|
|
||||||
* '4.4.4.4:1053',
|
|
||||||
* '[2001:4860:4860::8888]:1053',
|
|
||||||
* ]);
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* An error will be thrown if an invalid address is provided.
|
|
||||||
*
|
|
||||||
* The `dnsPromises.setServers()` method must not be called while a DNS query is in
|
|
||||||
* progress.
|
|
||||||
*
|
|
||||||
* This method works much like [resolve.conf](https://man7.org/linux/man-pages/man5/resolv.conf.5.html).
|
|
||||||
* That is, if attempting to resolve with the first server provided results in a`NOTFOUND` error, the `resolve()` method will _not_ attempt to resolve with
|
|
||||||
* subsequent servers provided. Fallback DNS servers will only be used if the
|
|
||||||
* earlier ones time out or result in some other error.
|
|
||||||
* @since v10.6.0
|
|
||||||
* @param servers array of `RFC 5952` formatted addresses
|
|
||||||
*/
|
|
||||||
function setServers(servers: ReadonlyArray<string>): void;
|
|
||||||
/**
|
|
||||||
* Set the default value of `verbatim` in {@link lookup}. The value could be:
|
|
||||||
* - `ipv4first`: sets default `verbatim` `false`.
|
|
||||||
* - `verbatim`: sets default `verbatim` `true`.
|
|
||||||
*
|
|
||||||
* The default is `ipv4first` and {@link setDefaultResultOrder} have higher priority than `--dns-result-order`.
|
|
||||||
* When using worker threads, {@link setDefaultResultOrder} from the main thread won't affect the default dns orders in workers.
|
|
||||||
* @since v14.18.0
|
|
||||||
* @param order must be 'ipv4first' or 'verbatim'.
|
|
||||||
*/
|
|
||||||
function setDefaultResultOrder(order: 'ipv4first' | 'verbatim'): void;
|
|
||||||
class Resolver {
|
|
||||||
constructor(options?: ResolverOptions);
|
|
||||||
cancel(): void;
|
|
||||||
getServers: typeof getServers;
|
|
||||||
resolve: typeof resolve;
|
|
||||||
resolve4: typeof resolve4;
|
|
||||||
resolve6: typeof resolve6;
|
|
||||||
resolveAny: typeof resolveAny;
|
|
||||||
resolveCname: typeof resolveCname;
|
|
||||||
resolveMx: typeof resolveMx;
|
|
||||||
resolveNaptr: typeof resolveNaptr;
|
|
||||||
resolveNs: typeof resolveNs;
|
|
||||||
resolvePtr: typeof resolvePtr;
|
|
||||||
resolveSoa: typeof resolveSoa;
|
|
||||||
resolveSrv: typeof resolveSrv;
|
|
||||||
resolveTxt: typeof resolveTxt;
|
|
||||||
reverse: typeof reverse;
|
|
||||||
setLocalAddress(ipv4?: string, ipv6?: string): void;
|
|
||||||
setServers: typeof setServers;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
declare module 'node:dns/promises' {
|
|
||||||
export * from 'dns/promises';
|
|
||||||
}
|
|
||||||
177
node_modules/@types/node/domain.d.ts
generated
vendored
Executable file → Normal file
177
node_modules/@types/node/domain.d.ts
generated
vendored
Executable file → Normal file
@@ -1,169 +1,16 @@
|
|||||||
/**
|
declare module "domain" {
|
||||||
* **This module is pending deprecation.** Once a replacement API has been
|
import * as events from "events";
|
||||||
* finalized, this module will be fully deprecated. Most developers should**not** have cause to use this module. Users who absolutely must have
|
|
||||||
* the functionality that domains provide may rely on it for the time being
|
class Domain extends events.EventEmitter implements NodeJS.Domain {
|
||||||
* but should expect to have to migrate to a different solution
|
|
||||||
* in the future.
|
|
||||||
*
|
|
||||||
* Domains provide a way to handle multiple different IO operations as a
|
|
||||||
* single group. If any of the event emitters or callbacks registered to a
|
|
||||||
* domain emit an `'error'` event, or throw an error, then the domain object
|
|
||||||
* will be notified, rather than losing the context of the error in the`process.on('uncaughtException')` handler, or causing the program to
|
|
||||||
* exit immediately with an error code.
|
|
||||||
* @deprecated Since v1.4.2 - Deprecated
|
|
||||||
* @see [source](https://github.com/nodejs/node/blob/v16.9.0/lib/domain.js)
|
|
||||||
*/
|
|
||||||
declare module 'domain' {
|
|
||||||
import EventEmitter = require('node:events');
|
|
||||||
/**
|
|
||||||
* The `Domain` class encapsulates the functionality of routing errors and
|
|
||||||
* uncaught exceptions to the active `Domain` object.
|
|
||||||
*
|
|
||||||
* To handle the errors that it catches, listen to its `'error'` event.
|
|
||||||
*/
|
|
||||||
class Domain extends EventEmitter {
|
|
||||||
/**
|
|
||||||
* An array of timers and event emitters that have been explicitly added
|
|
||||||
* to the domain.
|
|
||||||
*/
|
|
||||||
members: Array<EventEmitter | NodeJS.Timer>;
|
|
||||||
/**
|
|
||||||
* The `enter()` method is plumbing used by the `run()`, `bind()`, and`intercept()` methods to set the active domain. It sets `domain.active` and`process.domain` to the domain, and implicitly
|
|
||||||
* pushes the domain onto the domain
|
|
||||||
* stack managed by the domain module (see {@link exit} for details on the
|
|
||||||
* domain stack). The call to `enter()` delimits the beginning of a chain of
|
|
||||||
* asynchronous calls and I/O operations bound to a domain.
|
|
||||||
*
|
|
||||||
* Calling `enter()` changes only the active domain, and does not alter the domain
|
|
||||||
* itself. `enter()` and `exit()` can be called an arbitrary number of times on a
|
|
||||||
* single domain.
|
|
||||||
*/
|
|
||||||
enter(): void;
|
|
||||||
/**
|
|
||||||
* The `exit()` method exits the current domain, popping it off the domain stack.
|
|
||||||
* Any time execution is going to switch to the context of a different chain of
|
|
||||||
* asynchronous calls, it's important to ensure that the current domain is exited.
|
|
||||||
* The call to `exit()` delimits either the end of or an interruption to the chain
|
|
||||||
* of asynchronous calls and I/O operations bound to a domain.
|
|
||||||
*
|
|
||||||
* If there are multiple, nested domains bound to the current execution context,`exit()` will exit any domains nested within this domain.
|
|
||||||
*
|
|
||||||
* Calling `exit()` changes only the active domain, and does not alter the domain
|
|
||||||
* itself. `enter()` and `exit()` can be called an arbitrary number of times on a
|
|
||||||
* single domain.
|
|
||||||
*/
|
|
||||||
exit(): void;
|
|
||||||
/**
|
|
||||||
* Run the supplied function in the context of the domain, implicitly
|
|
||||||
* binding all event emitters, timers, and lowlevel requests that are
|
|
||||||
* created in that context. Optionally, arguments can be passed to
|
|
||||||
* the function.
|
|
||||||
*
|
|
||||||
* This is the most basic way to use a domain.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const domain = require('domain');
|
|
||||||
* const fs = require('fs');
|
|
||||||
* const d = domain.create();
|
|
||||||
* d.on('error', (er) => {
|
|
||||||
* console.error('Caught error!', er);
|
|
||||||
* });
|
|
||||||
* d.run(() => {
|
|
||||||
* process.nextTick(() => {
|
|
||||||
* setTimeout(() => { // Simulating some various async stuff
|
|
||||||
* fs.open('non-existent file', 'r', (er, fd) => {
|
|
||||||
* if (er) throw er;
|
|
||||||
* // proceed...
|
|
||||||
* });
|
|
||||||
* }, 100);
|
|
||||||
* });
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* In this example, the `d.on('error')` handler will be triggered, rather
|
|
||||||
* than crashing the program.
|
|
||||||
*/
|
|
||||||
run<T>(fn: (...args: any[]) => T, ...args: any[]): T;
|
run<T>(fn: (...args: any[]) => T, ...args: any[]): T;
|
||||||
/**
|
add(emitter: events.EventEmitter | NodeJS.Timer): void;
|
||||||
* Explicitly adds an emitter to the domain. If any event handlers called by
|
remove(emitter: events.EventEmitter | NodeJS.Timer): void;
|
||||||
* the emitter throw an error, or if the emitter emits an `'error'` event, it
|
bind<T extends Function>(cb: T): T;
|
||||||
* will be routed to the domain's `'error'` event, just like with implicit
|
intercept<T extends Function>(cb: T): T;
|
||||||
* binding.
|
members: Array<events.EventEmitter | NodeJS.Timer>;
|
||||||
*
|
enter(): void;
|
||||||
* This also works with timers that are returned from `setInterval()` and `setTimeout()`. If their callback function throws, it will be caught by
|
exit(): void;
|
||||||
* the domain `'error'` handler.
|
|
||||||
*
|
|
||||||
* If the Timer or `EventEmitter` was already bound to a domain, it is removed
|
|
||||||
* from that one, and bound to this one instead.
|
|
||||||
* @param emitter emitter or timer to be added to the domain
|
|
||||||
*/
|
|
||||||
add(emitter: EventEmitter | NodeJS.Timer): void;
|
|
||||||
/**
|
|
||||||
* The opposite of {@link add}. Removes domain handling from the
|
|
||||||
* specified emitter.
|
|
||||||
* @param emitter emitter or timer to be removed from the domain
|
|
||||||
*/
|
|
||||||
remove(emitter: EventEmitter | NodeJS.Timer): void;
|
|
||||||
/**
|
|
||||||
* The returned function will be a wrapper around the supplied callback
|
|
||||||
* function. When the returned function is called, any errors that are
|
|
||||||
* thrown will be routed to the domain's `'error'` event.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const d = domain.create();
|
|
||||||
*
|
|
||||||
* function readSomeFile(filename, cb) {
|
|
||||||
* fs.readFile(filename, 'utf8', d.bind((er, data) => {
|
|
||||||
* // If this throws, it will also be passed to the domain.
|
|
||||||
* return cb(er, data ? JSON.parse(data) : null);
|
|
||||||
* }));
|
|
||||||
* }
|
|
||||||
*
|
|
||||||
* d.on('error', (er) => {
|
|
||||||
* // An error occurred somewhere. If we throw it now, it will crash the program
|
|
||||||
* // with the normal line number and stack message.
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
* @param callback The callback function
|
|
||||||
* @return The bound function
|
|
||||||
*/
|
|
||||||
bind<T extends Function>(callback: T): T;
|
|
||||||
/**
|
|
||||||
* This method is almost identical to {@link bind}. However, in
|
|
||||||
* addition to catching thrown errors, it will also intercept `Error` objects sent as the first argument to the function.
|
|
||||||
*
|
|
||||||
* In this way, the common `if (err) return callback(err);` pattern can be replaced
|
|
||||||
* with a single error handler in a single place.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const d = domain.create();
|
|
||||||
*
|
|
||||||
* function readSomeFile(filename, cb) {
|
|
||||||
* fs.readFile(filename, 'utf8', d.intercept((data) => {
|
|
||||||
* // Note, the first argument is never passed to the
|
|
||||||
* // callback since it is assumed to be the 'Error' argument
|
|
||||||
* // and thus intercepted by the domain.
|
|
||||||
*
|
|
||||||
* // If this throws, it will also be passed to the domain
|
|
||||||
* // so the error-handling logic can be moved to the 'error'
|
|
||||||
* // event on the domain instead of being repeated throughout
|
|
||||||
* // the program.
|
|
||||||
* return cb(null, JSON.parse(data));
|
|
||||||
* }));
|
|
||||||
* }
|
|
||||||
*
|
|
||||||
* d.on('error', (er) => {
|
|
||||||
* // An error occurred somewhere. If we throw it now, it will crash the program
|
|
||||||
* // with the normal line number and stack message.
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
* @param callback The callback function
|
|
||||||
* @return The intercepted function
|
|
||||||
*/
|
|
||||||
intercept<T extends Function>(callback: T): T;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function create(): Domain;
|
function create(): Domain;
|
||||||
}
|
}
|
||||||
declare module 'node:domain' {
|
|
||||||
export * from 'domain';
|
|
||||||
}
|
|
||||||
|
|||||||
642
node_modules/@types/node/events.d.ts
generated
vendored
Executable file → Normal file
642
node_modules/@types/node/events.d.ts
generated
vendored
Executable file → Normal file
@@ -1,265 +1,18 @@
|
|||||||
/**
|
declare module "events" {
|
||||||
* Much of the Node.js core API is built around an idiomatic asynchronous
|
class internal extends NodeJS.EventEmitter { }
|
||||||
* event-driven architecture in which certain kinds of objects (called "emitters")
|
|
||||||
* emit named events that cause `Function` objects ("listeners") to be called.
|
|
||||||
*
|
|
||||||
* For instance: a `net.Server` object emits an event each time a peer
|
|
||||||
* connects to it; a `fs.ReadStream` emits an event when the file is opened;
|
|
||||||
* a `stream` emits an event whenever data is available to be read.
|
|
||||||
*
|
|
||||||
* All objects that emit events are instances of the `EventEmitter` class. These
|
|
||||||
* objects expose an `eventEmitter.on()` function that allows one or more
|
|
||||||
* functions to be attached to named events emitted by the object. Typically,
|
|
||||||
* event names are camel-cased strings but any valid JavaScript property key
|
|
||||||
* can be used.
|
|
||||||
*
|
|
||||||
* When the `EventEmitter` object emits an event, all of the functions attached
|
|
||||||
* to that specific event are called _synchronously_. Any values returned by the
|
|
||||||
* called listeners are _ignored_ and discarded.
|
|
||||||
*
|
|
||||||
* The following example shows a simple `EventEmitter` instance with a single
|
|
||||||
* listener. The `eventEmitter.on()` method is used to register listeners, while
|
|
||||||
* the `eventEmitter.emit()` method is used to trigger the event.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const EventEmitter = require('events');
|
|
||||||
*
|
|
||||||
* class MyEmitter extends EventEmitter {}
|
|
||||||
*
|
|
||||||
* const myEmitter = new MyEmitter();
|
|
||||||
* myEmitter.on('event', () => {
|
|
||||||
* console.log('an event occurred!');
|
|
||||||
* });
|
|
||||||
* myEmitter.emit('event');
|
|
||||||
* ```
|
|
||||||
* @see [source](https://github.com/nodejs/node/blob/v16.9.0/lib/events.js)
|
|
||||||
*/
|
|
||||||
declare module 'events' {
|
|
||||||
interface EventEmitterOptions {
|
|
||||||
/**
|
|
||||||
* Enables automatic capturing of promise rejection.
|
|
||||||
*/
|
|
||||||
captureRejections?: boolean | undefined;
|
|
||||||
}
|
|
||||||
interface NodeEventTarget {
|
interface NodeEventTarget {
|
||||||
once(eventName: string | symbol, listener: (...args: any[]) => void): this;
|
once(event: string | symbol, listener: (...args: any[]) => void): this;
|
||||||
}
|
}
|
||||||
|
|
||||||
interface DOMEventTarget {
|
interface DOMEventTarget {
|
||||||
addEventListener(
|
addEventListener(event: string, listener: (...args: any[]) => void, opts?: { once: boolean }): any;
|
||||||
eventName: string,
|
|
||||||
listener: (...args: any[]) => void,
|
|
||||||
opts?: {
|
|
||||||
once: boolean;
|
|
||||||
}
|
|
||||||
): any;
|
|
||||||
}
|
}
|
||||||
interface StaticEventEmitterOptions {
|
|
||||||
signal?: AbortSignal | undefined;
|
namespace internal {
|
||||||
}
|
function once(emitter: NodeEventTarget, event: string | symbol): Promise<any[]>;
|
||||||
interface EventEmitter extends NodeJS.EventEmitter {}
|
function once(emitter: DOMEventTarget, event: string): Promise<any[]>;
|
||||||
/**
|
|
||||||
* The `EventEmitter` class is defined and exposed by the `events` module:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const EventEmitter = require('events');
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* All `EventEmitter`s emit the event `'newListener'` when new listeners are
|
|
||||||
* added and `'removeListener'` when existing listeners are removed.
|
|
||||||
*
|
|
||||||
* It supports the following option:
|
|
||||||
* @since v0.1.26
|
|
||||||
*/
|
|
||||||
class EventEmitter {
|
|
||||||
constructor(options?: EventEmitterOptions);
|
|
||||||
/**
|
|
||||||
* Creates a `Promise` that is fulfilled when the `EventEmitter` emits the given
|
|
||||||
* event or that is rejected if the `EventEmitter` emits `'error'` while waiting.
|
|
||||||
* The `Promise` will resolve with an array of all the arguments emitted to the
|
|
||||||
* given event.
|
|
||||||
*
|
|
||||||
* This method is intentionally generic and works with the web platform [EventTarget](https://dom.spec.whatwg.org/#interface-eventtarget) interface, which has no special`'error'` event
|
|
||||||
* semantics and does not listen to the `'error'` event.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const { once, EventEmitter } = require('events');
|
|
||||||
*
|
|
||||||
* async function run() {
|
|
||||||
* const ee = new EventEmitter();
|
|
||||||
*
|
|
||||||
* process.nextTick(() => {
|
|
||||||
* ee.emit('myevent', 42);
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* const [value] = await once(ee, 'myevent');
|
|
||||||
* console.log(value);
|
|
||||||
*
|
|
||||||
* const err = new Error('kaboom');
|
|
||||||
* process.nextTick(() => {
|
|
||||||
* ee.emit('error', err);
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* try {
|
|
||||||
* await once(ee, 'myevent');
|
|
||||||
* } catch (err) {
|
|
||||||
* console.log('error happened', err);
|
|
||||||
* }
|
|
||||||
* }
|
|
||||||
*
|
|
||||||
* run();
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* The special handling of the `'error'` event is only used when `events.once()`is used to wait for another event. If `events.once()` is used to wait for the
|
|
||||||
* '`error'` event itself, then it is treated as any other kind of event without
|
|
||||||
* special handling:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const { EventEmitter, once } = require('events');
|
|
||||||
*
|
|
||||||
* const ee = new EventEmitter();
|
|
||||||
*
|
|
||||||
* once(ee, 'error')
|
|
||||||
* .then(([err]) => console.log('ok', err.message))
|
|
||||||
* .catch((err) => console.log('error', err.message));
|
|
||||||
*
|
|
||||||
* ee.emit('error', new Error('boom'));
|
|
||||||
*
|
|
||||||
* // Prints: ok boom
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* An `AbortSignal` can be used to cancel waiting for the event:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const { EventEmitter, once } = require('events');
|
|
||||||
*
|
|
||||||
* const ee = new EventEmitter();
|
|
||||||
* const ac = new AbortController();
|
|
||||||
*
|
|
||||||
* async function foo(emitter, event, signal) {
|
|
||||||
* try {
|
|
||||||
* await once(emitter, event, { signal });
|
|
||||||
* console.log('event emitted!');
|
|
||||||
* } catch (error) {
|
|
||||||
* if (error.name === 'AbortError') {
|
|
||||||
* console.error('Waiting for the event was canceled!');
|
|
||||||
* } else {
|
|
||||||
* console.error('There was an error', error.message);
|
|
||||||
* }
|
|
||||||
* }
|
|
||||||
* }
|
|
||||||
*
|
|
||||||
* foo(ee, 'foo', ac.signal);
|
|
||||||
* ac.abort(); // Abort waiting for the event
|
|
||||||
* ee.emit('foo'); // Prints: Waiting for the event was canceled!
|
|
||||||
* ```
|
|
||||||
* @since v11.13.0, v10.16.0
|
|
||||||
*/
|
|
||||||
static once(emitter: NodeEventTarget, eventName: string | symbol, options?: StaticEventEmitterOptions): Promise<any[]>;
|
|
||||||
static once(emitter: DOMEventTarget, eventName: string, options?: StaticEventEmitterOptions): Promise<any[]>;
|
|
||||||
/**
|
|
||||||
* ```js
|
|
||||||
* const { on, EventEmitter } = require('events');
|
|
||||||
*
|
|
||||||
* (async () => {
|
|
||||||
* const ee = new EventEmitter();
|
|
||||||
*
|
|
||||||
* // Emit later on
|
|
||||||
* process.nextTick(() => {
|
|
||||||
* ee.emit('foo', 'bar');
|
|
||||||
* ee.emit('foo', 42);
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* for await (const event of on(ee, 'foo')) {
|
|
||||||
* // The execution of this inner block is synchronous and it
|
|
||||||
* // processes one event at a time (even with await). Do not use
|
|
||||||
* // if concurrent execution is required.
|
|
||||||
* console.log(event); // prints ['bar'] [42]
|
|
||||||
* }
|
|
||||||
* // Unreachable here
|
|
||||||
* })();
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Returns an `AsyncIterator` that iterates `eventName` events. It will throw
|
|
||||||
* if the `EventEmitter` emits `'error'`. It removes all listeners when
|
|
||||||
* exiting the loop. The `value` returned by each iteration is an array
|
|
||||||
* composed of the emitted event arguments.
|
|
||||||
*
|
|
||||||
* An `AbortSignal` can be used to cancel waiting on events:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const { on, EventEmitter } = require('events');
|
|
||||||
* const ac = new AbortController();
|
|
||||||
*
|
|
||||||
* (async () => {
|
|
||||||
* const ee = new EventEmitter();
|
|
||||||
*
|
|
||||||
* // Emit later on
|
|
||||||
* process.nextTick(() => {
|
|
||||||
* ee.emit('foo', 'bar');
|
|
||||||
* ee.emit('foo', 42);
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* for await (const event of on(ee, 'foo', { signal: ac.signal })) {
|
|
||||||
* // The execution of this inner block is synchronous and it
|
|
||||||
* // processes one event at a time (even with await). Do not use
|
|
||||||
* // if concurrent execution is required.
|
|
||||||
* console.log(event); // prints ['bar'] [42]
|
|
||||||
* }
|
|
||||||
* // Unreachable here
|
|
||||||
* })();
|
|
||||||
*
|
|
||||||
* process.nextTick(() => ac.abort());
|
|
||||||
* ```
|
|
||||||
* @since v13.6.0, v12.16.0
|
|
||||||
* @param eventName The name of the event being listened for
|
|
||||||
* @return that iterates `eventName` events emitted by the `emitter`
|
|
||||||
*/
|
|
||||||
static on(emitter: NodeJS.EventEmitter, eventName: string, options?: StaticEventEmitterOptions): AsyncIterableIterator<any>;
|
|
||||||
/**
|
|
||||||
* A class method that returns the number of listeners for the given `eventName`registered on the given `emitter`.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const { EventEmitter, listenerCount } = require('events');
|
|
||||||
* const myEmitter = new EventEmitter();
|
|
||||||
* myEmitter.on('event', () => {});
|
|
||||||
* myEmitter.on('event', () => {});
|
|
||||||
* console.log(listenerCount(myEmitter, 'event'));
|
|
||||||
* // Prints: 2
|
|
||||||
* ```
|
|
||||||
* @since v0.9.12
|
|
||||||
* @deprecated Since v3.2.0 - Use `listenerCount` instead.
|
|
||||||
* @param emitter The emitter to query
|
|
||||||
* @param eventName The event name
|
|
||||||
*/
|
|
||||||
static listenerCount(emitter: NodeJS.EventEmitter, eventName: string | symbol): number;
|
|
||||||
/**
|
|
||||||
* Returns a copy of the array of listeners for the event named `eventName`.
|
|
||||||
*
|
|
||||||
* For `EventEmitter`s this behaves exactly the same as calling `.listeners` on
|
|
||||||
* the emitter.
|
|
||||||
*
|
|
||||||
* For `EventTarget`s this is the only way to get the event listeners for the
|
|
||||||
* event target. This is useful for debugging and diagnostic purposes.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const { getEventListeners, EventEmitter } = require('events');
|
|
||||||
*
|
|
||||||
* {
|
|
||||||
* const ee = new EventEmitter();
|
|
||||||
* const listener = () => console.log('Events are fun');
|
|
||||||
* ee.on('foo', listener);
|
|
||||||
* getEventListeners(ee, 'foo'); // [listener]
|
|
||||||
* }
|
|
||||||
* {
|
|
||||||
* const et = new EventTarget();
|
|
||||||
* const listener = () => console.log('Events are fun');
|
|
||||||
* et.addEventListener('foo', listener);
|
|
||||||
* getEventListeners(et, 'foo'); // [listener]
|
|
||||||
* }
|
|
||||||
* ```
|
|
||||||
* @since v15.2.0
|
|
||||||
*/
|
|
||||||
static getEventListeners(emitter: DOMEventTarget | NodeJS.EventEmitter, name: string | symbol): Function[];
|
|
||||||
/**
|
/**
|
||||||
* This symbol shall be used to install a listener for only monitoring `'error'`
|
* This symbol shall be used to install a listener for only monitoring `'error'`
|
||||||
* events. Listeners installed using this symbol are called before the regular
|
* events. Listeners installed using this symbol are called before the regular
|
||||||
@@ -269,355 +22,30 @@ declare module 'events' {
|
|||||||
* `'error'` event is emitted, therefore the process will still crash if no
|
* `'error'` event is emitted, therefore the process will still crash if no
|
||||||
* regular `'error'` listener is installed.
|
* regular `'error'` listener is installed.
|
||||||
*/
|
*/
|
||||||
static readonly errorMonitor: unique symbol;
|
const errorMonitor: unique symbol;
|
||||||
static readonly captureRejectionSymbol: unique symbol;
|
|
||||||
/**
|
class EventEmitter extends internal {
|
||||||
* Sets or gets the default captureRejection value for all emitters.
|
/** @deprecated since v4.0.0 */
|
||||||
*/
|
static listenerCount(emitter: EventEmitter, event: string | symbol): number;
|
||||||
// TODO: These should be described using static getter/setter pairs:
|
static defaultMaxListeners: number;
|
||||||
static captureRejections: boolean;
|
|
||||||
static defaultMaxListeners: number;
|
addListener(event: string | symbol, listener: (...args: any[]) => void): this;
|
||||||
}
|
on(event: string | symbol, listener: (...args: any[]) => void): this;
|
||||||
import internal = require('node:events');
|
once(event: string | symbol, listener: (...args: any[]) => void): this;
|
||||||
namespace EventEmitter {
|
prependListener(event: string | symbol, listener: (...args: any[]) => void): this;
|
||||||
// Should just be `export { EventEmitter }`, but that doesn't work in TypeScript 3.4
|
prependOnceListener(event: string | symbol, listener: (...args: any[]) => void): this;
|
||||||
export { internal as EventEmitter };
|
removeListener(event: string | symbol, listener: (...args: any[]) => void): this;
|
||||||
export interface Abortable {
|
off(event: string | symbol, listener: (...args: any[]) => void): this;
|
||||||
/**
|
removeAllListeners(event?: string | symbol): this;
|
||||||
* When provided the corresponding `AbortController` can be used to cancel an asynchronous action.
|
setMaxListeners(n: number): this;
|
||||||
*/
|
getMaxListeners(): number;
|
||||||
signal?: AbortSignal | undefined;
|
listeners(event: string | symbol): Function[];
|
||||||
|
rawListeners(event: string | symbol): Function[];
|
||||||
|
emit(event: string | symbol, ...args: any[]): boolean;
|
||||||
|
eventNames(): Array<string | symbol>;
|
||||||
|
listenerCount(type: string | symbol): number;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
global {
|
|
||||||
namespace NodeJS {
|
export = internal;
|
||||||
interface EventEmitter {
|
|
||||||
/**
|
|
||||||
* Alias for `emitter.on(eventName, listener)`.
|
|
||||||
* @since v0.1.26
|
|
||||||
*/
|
|
||||||
addListener(eventName: string | symbol, listener: (...args: any[]) => void): this;
|
|
||||||
/**
|
|
||||||
* Adds the `listener` function to the end of the listeners array for the
|
|
||||||
* event named `eventName`. No checks are made to see if the `listener` has
|
|
||||||
* already been added. Multiple calls passing the same combination of `eventName`and `listener` will result in the `listener` being added, and called, multiple
|
|
||||||
* times.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* server.on('connection', (stream) => {
|
|
||||||
* console.log('someone connected!');
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Returns a reference to the `EventEmitter`, so that calls can be chained.
|
|
||||||
*
|
|
||||||
* By default, event listeners are invoked in the order they are added. The`emitter.prependListener()` method can be used as an alternative to add the
|
|
||||||
* event listener to the beginning of the listeners array.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const myEE = new EventEmitter();
|
|
||||||
* myEE.on('foo', () => console.log('a'));
|
|
||||||
* myEE.prependListener('foo', () => console.log('b'));
|
|
||||||
* myEE.emit('foo');
|
|
||||||
* // Prints:
|
|
||||||
* // b
|
|
||||||
* // a
|
|
||||||
* ```
|
|
||||||
* @since v0.1.101
|
|
||||||
* @param eventName The name of the event.
|
|
||||||
* @param listener The callback function
|
|
||||||
*/
|
|
||||||
on(eventName: string | symbol, listener: (...args: any[]) => void): this;
|
|
||||||
/**
|
|
||||||
* Adds a **one-time**`listener` function for the event named `eventName`. The
|
|
||||||
* next time `eventName` is triggered, this listener is removed and then invoked.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* server.once('connection', (stream) => {
|
|
||||||
* console.log('Ah, we have our first user!');
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Returns a reference to the `EventEmitter`, so that calls can be chained.
|
|
||||||
*
|
|
||||||
* By default, event listeners are invoked in the order they are added. The`emitter.prependOnceListener()` method can be used as an alternative to add the
|
|
||||||
* event listener to the beginning of the listeners array.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const myEE = new EventEmitter();
|
|
||||||
* myEE.once('foo', () => console.log('a'));
|
|
||||||
* myEE.prependOnceListener('foo', () => console.log('b'));
|
|
||||||
* myEE.emit('foo');
|
|
||||||
* // Prints:
|
|
||||||
* // b
|
|
||||||
* // a
|
|
||||||
* ```
|
|
||||||
* @since v0.3.0
|
|
||||||
* @param eventName The name of the event.
|
|
||||||
* @param listener The callback function
|
|
||||||
*/
|
|
||||||
once(eventName: string | symbol, listener: (...args: any[]) => void): this;
|
|
||||||
/**
|
|
||||||
* Removes the specified `listener` from the listener array for the event named`eventName`.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const callback = (stream) => {
|
|
||||||
* console.log('someone connected!');
|
|
||||||
* };
|
|
||||||
* server.on('connection', callback);
|
|
||||||
* // ...
|
|
||||||
* server.removeListener('connection', callback);
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* `removeListener()` will remove, at most, one instance of a listener from the
|
|
||||||
* listener array. If any single listener has been added multiple times to the
|
|
||||||
* listener array for the specified `eventName`, then `removeListener()` must be
|
|
||||||
* called multiple times to remove each instance.
|
|
||||||
*
|
|
||||||
* Once an event is emitted, all listeners attached to it at the
|
|
||||||
* time of emitting are called in order. This implies that any`removeListener()` or `removeAllListeners()` calls _after_ emitting and_before_ the last listener finishes execution will
|
|
||||||
* not remove them from`emit()` in progress. Subsequent events behave as expected.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const myEmitter = new MyEmitter();
|
|
||||||
*
|
|
||||||
* const callbackA = () => {
|
|
||||||
* console.log('A');
|
|
||||||
* myEmitter.removeListener('event', callbackB);
|
|
||||||
* };
|
|
||||||
*
|
|
||||||
* const callbackB = () => {
|
|
||||||
* console.log('B');
|
|
||||||
* };
|
|
||||||
*
|
|
||||||
* myEmitter.on('event', callbackA);
|
|
||||||
*
|
|
||||||
* myEmitter.on('event', callbackB);
|
|
||||||
*
|
|
||||||
* // callbackA removes listener callbackB but it will still be called.
|
|
||||||
* // Internal listener array at time of emit [callbackA, callbackB]
|
|
||||||
* myEmitter.emit('event');
|
|
||||||
* // Prints:
|
|
||||||
* // A
|
|
||||||
* // B
|
|
||||||
*
|
|
||||||
* // callbackB is now removed.
|
|
||||||
* // Internal listener array [callbackA]
|
|
||||||
* myEmitter.emit('event');
|
|
||||||
* // Prints:
|
|
||||||
* // A
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Because listeners are managed using an internal array, calling this will
|
|
||||||
* change the position indices of any listener registered _after_ the listener
|
|
||||||
* being removed. This will not impact the order in which listeners are called,
|
|
||||||
* but it means that any copies of the listener array as returned by
|
|
||||||
* the `emitter.listeners()` method will need to be recreated.
|
|
||||||
*
|
|
||||||
* When a single function has been added as a handler multiple times for a single
|
|
||||||
* event (as in the example below), `removeListener()` will remove the most
|
|
||||||
* recently added instance. In the example the `once('ping')`listener is removed:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const ee = new EventEmitter();
|
|
||||||
*
|
|
||||||
* function pong() {
|
|
||||||
* console.log('pong');
|
|
||||||
* }
|
|
||||||
*
|
|
||||||
* ee.on('ping', pong);
|
|
||||||
* ee.once('ping', pong);
|
|
||||||
* ee.removeListener('ping', pong);
|
|
||||||
*
|
|
||||||
* ee.emit('ping');
|
|
||||||
* ee.emit('ping');
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Returns a reference to the `EventEmitter`, so that calls can be chained.
|
|
||||||
* @since v0.1.26
|
|
||||||
*/
|
|
||||||
removeListener(eventName: string | symbol, listener: (...args: any[]) => void): this;
|
|
||||||
/**
|
|
||||||
* Alias for `emitter.removeListener()`.
|
|
||||||
* @since v10.0.0
|
|
||||||
*/
|
|
||||||
off(eventName: string | symbol, listener: (...args: any[]) => void): this;
|
|
||||||
/**
|
|
||||||
* Removes all listeners, or those of the specified `eventName`.
|
|
||||||
*
|
|
||||||
* It is bad practice to remove listeners added elsewhere in the code,
|
|
||||||
* particularly when the `EventEmitter` instance was created by some other
|
|
||||||
* component or module (e.g. sockets or file streams).
|
|
||||||
*
|
|
||||||
* Returns a reference to the `EventEmitter`, so that calls can be chained.
|
|
||||||
* @since v0.1.26
|
|
||||||
*/
|
|
||||||
removeAllListeners(event?: string | symbol): this;
|
|
||||||
/**
|
|
||||||
* By default `EventEmitter`s will print a warning if more than `10` listeners are
|
|
||||||
* added for a particular event. This is a useful default that helps finding
|
|
||||||
* memory leaks. The `emitter.setMaxListeners()` method allows the limit to be
|
|
||||||
* modified for this specific `EventEmitter` instance. The value can be set to`Infinity` (or `0`) to indicate an unlimited number of listeners.
|
|
||||||
*
|
|
||||||
* Returns a reference to the `EventEmitter`, so that calls can be chained.
|
|
||||||
* @since v0.3.5
|
|
||||||
*/
|
|
||||||
setMaxListeners(n: number): this;
|
|
||||||
/**
|
|
||||||
* Returns the current max listener value for the `EventEmitter` which is either
|
|
||||||
* set by `emitter.setMaxListeners(n)` or defaults to {@link defaultMaxListeners}.
|
|
||||||
* @since v1.0.0
|
|
||||||
*/
|
|
||||||
getMaxListeners(): number;
|
|
||||||
/**
|
|
||||||
* Returns a copy of the array of listeners for the event named `eventName`.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* server.on('connection', (stream) => {
|
|
||||||
* console.log('someone connected!');
|
|
||||||
* });
|
|
||||||
* console.log(util.inspect(server.listeners('connection')));
|
|
||||||
* // Prints: [ [Function] ]
|
|
||||||
* ```
|
|
||||||
* @since v0.1.26
|
|
||||||
*/
|
|
||||||
listeners(eventName: string | symbol): Function[];
|
|
||||||
/**
|
|
||||||
* Returns a copy of the array of listeners for the event named `eventName`,
|
|
||||||
* including any wrappers (such as those created by `.once()`).
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const emitter = new EventEmitter();
|
|
||||||
* emitter.once('log', () => console.log('log once'));
|
|
||||||
*
|
|
||||||
* // Returns a new Array with a function `onceWrapper` which has a property
|
|
||||||
* // `listener` which contains the original listener bound above
|
|
||||||
* const listeners = emitter.rawListeners('log');
|
|
||||||
* const logFnWrapper = listeners[0];
|
|
||||||
*
|
|
||||||
* // Logs "log once" to the console and does not unbind the `once` event
|
|
||||||
* logFnWrapper.listener();
|
|
||||||
*
|
|
||||||
* // Logs "log once" to the console and removes the listener
|
|
||||||
* logFnWrapper();
|
|
||||||
*
|
|
||||||
* emitter.on('log', () => console.log('log persistently'));
|
|
||||||
* // Will return a new Array with a single function bound by `.on()` above
|
|
||||||
* const newListeners = emitter.rawListeners('log');
|
|
||||||
*
|
|
||||||
* // Logs "log persistently" twice
|
|
||||||
* newListeners[0]();
|
|
||||||
* emitter.emit('log');
|
|
||||||
* ```
|
|
||||||
* @since v9.4.0
|
|
||||||
*/
|
|
||||||
rawListeners(eventName: string | symbol): Function[];
|
|
||||||
/**
|
|
||||||
* Synchronously calls each of the listeners registered for the event named`eventName`, in the order they were registered, passing the supplied arguments
|
|
||||||
* to each.
|
|
||||||
*
|
|
||||||
* Returns `true` if the event had listeners, `false` otherwise.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const EventEmitter = require('events');
|
|
||||||
* const myEmitter = new EventEmitter();
|
|
||||||
*
|
|
||||||
* // First listener
|
|
||||||
* myEmitter.on('event', function firstListener() {
|
|
||||||
* console.log('Helloooo! first listener');
|
|
||||||
* });
|
|
||||||
* // Second listener
|
|
||||||
* myEmitter.on('event', function secondListener(arg1, arg2) {
|
|
||||||
* console.log(`event with parameters ${arg1}, ${arg2} in second listener`);
|
|
||||||
* });
|
|
||||||
* // Third listener
|
|
||||||
* myEmitter.on('event', function thirdListener(...args) {
|
|
||||||
* const parameters = args.join(', ');
|
|
||||||
* console.log(`event with parameters ${parameters} in third listener`);
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* console.log(myEmitter.listeners('event'));
|
|
||||||
*
|
|
||||||
* myEmitter.emit('event', 1, 2, 3, 4, 5);
|
|
||||||
*
|
|
||||||
* // Prints:
|
|
||||||
* // [
|
|
||||||
* // [Function: firstListener],
|
|
||||||
* // [Function: secondListener],
|
|
||||||
* // [Function: thirdListener]
|
|
||||||
* // ]
|
|
||||||
* // Helloooo! first listener
|
|
||||||
* // event with parameters 1, 2 in second listener
|
|
||||||
* // event with parameters 1, 2, 3, 4, 5 in third listener
|
|
||||||
* ```
|
|
||||||
* @since v0.1.26
|
|
||||||
*/
|
|
||||||
emit(eventName: string | symbol, ...args: any[]): boolean;
|
|
||||||
/**
|
|
||||||
* Returns the number of listeners listening to the event named `eventName`.
|
|
||||||
* @since v3.2.0
|
|
||||||
* @param eventName The name of the event being listened for
|
|
||||||
*/
|
|
||||||
listenerCount(eventName: string | symbol): number;
|
|
||||||
/**
|
|
||||||
* Adds the `listener` function to the _beginning_ of the listeners array for the
|
|
||||||
* event named `eventName`. No checks are made to see if the `listener` has
|
|
||||||
* already been added. Multiple calls passing the same combination of `eventName`and `listener` will result in the `listener` being added, and called, multiple
|
|
||||||
* times.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* server.prependListener('connection', (stream) => {
|
|
||||||
* console.log('someone connected!');
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Returns a reference to the `EventEmitter`, so that calls can be chained.
|
|
||||||
* @since v6.0.0
|
|
||||||
* @param eventName The name of the event.
|
|
||||||
* @param listener The callback function
|
|
||||||
*/
|
|
||||||
prependListener(eventName: string | symbol, listener: (...args: any[]) => void): this;
|
|
||||||
/**
|
|
||||||
* Adds a **one-time**`listener` function for the event named `eventName` to the_beginning_ of the listeners array. The next time `eventName` is triggered, this
|
|
||||||
* listener is removed, and then invoked.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* server.prependOnceListener('connection', (stream) => {
|
|
||||||
* console.log('Ah, we have our first user!');
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Returns a reference to the `EventEmitter`, so that calls can be chained.
|
|
||||||
* @since v6.0.0
|
|
||||||
* @param eventName The name of the event.
|
|
||||||
* @param listener The callback function
|
|
||||||
*/
|
|
||||||
prependOnceListener(eventName: string | symbol, listener: (...args: any[]) => void): this;
|
|
||||||
/**
|
|
||||||
* Returns an array listing the events for which the emitter has registered
|
|
||||||
* listeners. The values in the array are strings or `Symbol`s.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const EventEmitter = require('events');
|
|
||||||
* const myEE = new EventEmitter();
|
|
||||||
* myEE.on('foo', () => {});
|
|
||||||
* myEE.on('bar', () => {});
|
|
||||||
*
|
|
||||||
* const sym = Symbol('symbol');
|
|
||||||
* myEE.on(sym, () => {});
|
|
||||||
*
|
|
||||||
* console.log(myEE.eventNames());
|
|
||||||
* // Prints: [ 'foo', 'bar', Symbol(symbol) ]
|
|
||||||
* ```
|
|
||||||
* @since v6.0.0
|
|
||||||
*/
|
|
||||||
eventNames(): Array<string | symbol>;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
export = EventEmitter;
|
|
||||||
}
|
|
||||||
declare module 'node:events' {
|
|
||||||
import events = require('events');
|
|
||||||
export = events;
|
|
||||||
}
|
}
|
||||||
|
|||||||
4301
node_modules/@types/node/fs.d.ts
generated
vendored
Executable file → Normal file
4301
node_modules/@types/node/fs.d.ts
generated
vendored
Executable file → Normal file
File diff suppressed because it is too large
Load Diff
1091
node_modules/@types/node/fs/promises.d.ts
generated
vendored
1091
node_modules/@types/node/fs/promises.d.ts
generated
vendored
File diff suppressed because it is too large
Load Diff
1144
node_modules/@types/node/globals.d.ts
generated
vendored
Executable file → Normal file
1144
node_modules/@types/node/globals.d.ts
generated
vendored
Executable file → Normal file
File diff suppressed because it is too large
Load Diff
2
node_modules/@types/node/globals.global.d.ts
generated
vendored
Executable file → Normal file
2
node_modules/@types/node/globals.global.d.ts
generated
vendored
Executable file → Normal file
@@ -1 +1 @@
|
|||||||
declare var global: typeof globalThis;
|
declare var global: NodeJS.Global & typeof globalThis;
|
||||||
|
|||||||
1338
node_modules/@types/node/http.d.ts
generated
vendored
Executable file → Normal file
1338
node_modules/@types/node/http.d.ts
generated
vendored
Executable file → Normal file
File diff suppressed because it is too large
Load Diff
2219
node_modules/@types/node/http2.d.ts
generated
vendored
Executable file → Normal file
2219
node_modules/@types/node/http2.d.ts
generated
vendored
Executable file → Normal file
File diff suppressed because it is too large
Load Diff
406
node_modules/@types/node/https.d.ts
generated
vendored
Executable file → Normal file
406
node_modules/@types/node/https.d.ts
generated
vendored
Executable file → Normal file
@@ -1,391 +1,53 @@
|
|||||||
/**
|
declare module "https" {
|
||||||
* HTTPS is the HTTP protocol over TLS/SSL. In Node.js this is implemented as a
|
import * as tls from "tls";
|
||||||
* separate module.
|
import * as events from "events";
|
||||||
* @see [source](https://github.com/nodejs/node/blob/v16.9.0/lib/https.js)
|
import * as http from "http";
|
||||||
*/
|
import { URL } from "url";
|
||||||
declare module 'https' {
|
|
||||||
import { Duplex } from 'node:stream';
|
|
||||||
import * as tls from 'node:tls';
|
|
||||||
import * as http from 'node:http';
|
|
||||||
import { URL } from 'node:url';
|
|
||||||
type ServerOptions = tls.SecureContextOptions & tls.TlsOptions & http.ServerOptions;
|
type ServerOptions = tls.SecureContextOptions & tls.TlsOptions & http.ServerOptions;
|
||||||
type RequestOptions = http.RequestOptions &
|
|
||||||
tls.SecureContextOptions & {
|
type RequestOptions = http.RequestOptions & tls.SecureContextOptions & {
|
||||||
rejectUnauthorized?: boolean | undefined; // Defaults to true
|
rejectUnauthorized?: boolean; // Defaults to true
|
||||||
servername?: string | undefined; // SNI TLS Extension
|
servername?: string; // SNI TLS Extension
|
||||||
};
|
};
|
||||||
|
|
||||||
interface AgentOptions extends http.AgentOptions, tls.ConnectionOptions {
|
interface AgentOptions extends http.AgentOptions, tls.ConnectionOptions {
|
||||||
rejectUnauthorized?: boolean | undefined;
|
rejectUnauthorized?: boolean;
|
||||||
maxCachedSessions?: number | undefined;
|
maxCachedSessions?: number;
|
||||||
}
|
}
|
||||||
/**
|
|
||||||
* An `Agent` object for HTTPS similar to `http.Agent`. See {@link request} for more information.
|
|
||||||
* @since v0.4.5
|
|
||||||
*/
|
|
||||||
class Agent extends http.Agent {
|
class Agent extends http.Agent {
|
||||||
constructor(options?: AgentOptions);
|
constructor(options?: AgentOptions);
|
||||||
options: AgentOptions;
|
options: AgentOptions;
|
||||||
}
|
}
|
||||||
interface Server extends http.Server {}
|
|
||||||
/**
|
|
||||||
* See `http.Server` for more information.
|
|
||||||
* @since v0.3.4
|
|
||||||
*/
|
|
||||||
class Server extends tls.Server {
|
class Server extends tls.Server {
|
||||||
constructor(requestListener?: http.RequestListener);
|
constructor(requestListener?: http.RequestListener);
|
||||||
constructor(options: ServerOptions, requestListener?: http.RequestListener);
|
constructor(options: ServerOptions, requestListener?: http.RequestListener);
|
||||||
addListener(event: string, listener: (...args: any[]) => void): this;
|
|
||||||
addListener(event: 'keylog', listener: (line: Buffer, tlsSocket: tls.TLSSocket) => void): this;
|
setTimeout(callback: () => void): this;
|
||||||
addListener(event: 'newSession', listener: (sessionId: Buffer, sessionData: Buffer, callback: (err: Error, resp: Buffer) => void) => void): this;
|
setTimeout(msecs?: number, callback?: () => void): this;
|
||||||
addListener(event: 'OCSPRequest', listener: (certificate: Buffer, issuer: Buffer, callback: (err: Error | null, resp: Buffer) => void) => void): this;
|
/**
|
||||||
addListener(event: 'resumeSession', listener: (sessionId: Buffer, callback: (err: Error, sessionData: Buffer) => void) => void): this;
|
* Limits maximum incoming headers count. If set to 0, no limit will be applied.
|
||||||
addListener(event: 'secureConnection', listener: (tlsSocket: tls.TLSSocket) => void): this;
|
* @default 2000
|
||||||
addListener(event: 'tlsClientError', listener: (err: Error, tlsSocket: tls.TLSSocket) => void): this;
|
* {@link https://nodejs.org/api/http.html#http_server_maxheaderscount}
|
||||||
addListener(event: 'close', listener: () => void): this;
|
*/
|
||||||
addListener(event: 'connection', listener: (socket: Duplex) => void): this;
|
maxHeadersCount: number | null;
|
||||||
addListener(event: 'error', listener: (err: Error) => void): this;
|
timeout: number;
|
||||||
addListener(event: 'listening', listener: () => void): this;
|
/**
|
||||||
addListener(event: 'checkContinue', listener: http.RequestListener): this;
|
* Limit the amount of time the parser will wait to receive the complete HTTP headers.
|
||||||
addListener(event: 'checkExpectation', listener: http.RequestListener): this;
|
* @default 40000
|
||||||
addListener(event: 'clientError', listener: (err: Error, socket: Duplex) => void): this;
|
* {@link https://nodejs.org/api/http.html#http_server_headerstimeout}
|
||||||
addListener(event: 'connect', listener: (req: http.IncomingMessage, socket: Duplex, head: Buffer) => void): this;
|
*/
|
||||||
addListener(event: 'request', listener: http.RequestListener): this;
|
headersTimeout: number;
|
||||||
addListener(event: 'upgrade', listener: (req: http.IncomingMessage, socket: Duplex, head: Buffer) => void): this;
|
keepAliveTimeout: number;
|
||||||
emit(event: string, ...args: any[]): boolean;
|
|
||||||
emit(event: 'keylog', line: Buffer, tlsSocket: tls.TLSSocket): boolean;
|
|
||||||
emit(event: 'newSession', sessionId: Buffer, sessionData: Buffer, callback: (err: Error, resp: Buffer) => void): boolean;
|
|
||||||
emit(event: 'OCSPRequest', certificate: Buffer, issuer: Buffer, callback: (err: Error | null, resp: Buffer) => void): boolean;
|
|
||||||
emit(event: 'resumeSession', sessionId: Buffer, callback: (err: Error, sessionData: Buffer) => void): boolean;
|
|
||||||
emit(event: 'secureConnection', tlsSocket: tls.TLSSocket): boolean;
|
|
||||||
emit(event: 'tlsClientError', err: Error, tlsSocket: tls.TLSSocket): boolean;
|
|
||||||
emit(event: 'close'): boolean;
|
|
||||||
emit(event: 'connection', socket: Duplex): boolean;
|
|
||||||
emit(event: 'error', err: Error): boolean;
|
|
||||||
emit(event: 'listening'): boolean;
|
|
||||||
emit(event: 'checkContinue', req: http.IncomingMessage, res: http.ServerResponse): boolean;
|
|
||||||
emit(event: 'checkExpectation', req: http.IncomingMessage, res: http.ServerResponse): boolean;
|
|
||||||
emit(event: 'clientError', err: Error, socket: Duplex): boolean;
|
|
||||||
emit(event: 'connect', req: http.IncomingMessage, socket: Duplex, head: Buffer): boolean;
|
|
||||||
emit(event: 'request', req: http.IncomingMessage, res: http.ServerResponse): boolean;
|
|
||||||
emit(event: 'upgrade', req: http.IncomingMessage, socket: Duplex, head: Buffer): boolean;
|
|
||||||
on(event: string, listener: (...args: any[]) => void): this;
|
|
||||||
on(event: 'keylog', listener: (line: Buffer, tlsSocket: tls.TLSSocket) => void): this;
|
|
||||||
on(event: 'newSession', listener: (sessionId: Buffer, sessionData: Buffer, callback: (err: Error, resp: Buffer) => void) => void): this;
|
|
||||||
on(event: 'OCSPRequest', listener: (certificate: Buffer, issuer: Buffer, callback: (err: Error | null, resp: Buffer) => void) => void): this;
|
|
||||||
on(event: 'resumeSession', listener: (sessionId: Buffer, callback: (err: Error, sessionData: Buffer) => void) => void): this;
|
|
||||||
on(event: 'secureConnection', listener: (tlsSocket: tls.TLSSocket) => void): this;
|
|
||||||
on(event: 'tlsClientError', listener: (err: Error, tlsSocket: tls.TLSSocket) => void): this;
|
|
||||||
on(event: 'close', listener: () => void): this;
|
|
||||||
on(event: 'connection', listener: (socket: Duplex) => void): this;
|
|
||||||
on(event: 'error', listener: (err: Error) => void): this;
|
|
||||||
on(event: 'listening', listener: () => void): this;
|
|
||||||
on(event: 'checkContinue', listener: http.RequestListener): this;
|
|
||||||
on(event: 'checkExpectation', listener: http.RequestListener): this;
|
|
||||||
on(event: 'clientError', listener: (err: Error, socket: Duplex) => void): this;
|
|
||||||
on(event: 'connect', listener: (req: http.IncomingMessage, socket: Duplex, head: Buffer) => void): this;
|
|
||||||
on(event: 'request', listener: http.RequestListener): this;
|
|
||||||
on(event: 'upgrade', listener: (req: http.IncomingMessage, socket: Duplex, head: Buffer) => void): this;
|
|
||||||
once(event: string, listener: (...args: any[]) => void): this;
|
|
||||||
once(event: 'keylog', listener: (line: Buffer, tlsSocket: tls.TLSSocket) => void): this;
|
|
||||||
once(event: 'newSession', listener: (sessionId: Buffer, sessionData: Buffer, callback: (err: Error, resp: Buffer) => void) => void): this;
|
|
||||||
once(event: 'OCSPRequest', listener: (certificate: Buffer, issuer: Buffer, callback: (err: Error | null, resp: Buffer) => void) => void): this;
|
|
||||||
once(event: 'resumeSession', listener: (sessionId: Buffer, callback: (err: Error, sessionData: Buffer) => void) => void): this;
|
|
||||||
once(event: 'secureConnection', listener: (tlsSocket: tls.TLSSocket) => void): this;
|
|
||||||
once(event: 'tlsClientError', listener: (err: Error, tlsSocket: tls.TLSSocket) => void): this;
|
|
||||||
once(event: 'close', listener: () => void): this;
|
|
||||||
once(event: 'connection', listener: (socket: Duplex) => void): this;
|
|
||||||
once(event: 'error', listener: (err: Error) => void): this;
|
|
||||||
once(event: 'listening', listener: () => void): this;
|
|
||||||
once(event: 'checkContinue', listener: http.RequestListener): this;
|
|
||||||
once(event: 'checkExpectation', listener: http.RequestListener): this;
|
|
||||||
once(event: 'clientError', listener: (err: Error, socket: Duplex) => void): this;
|
|
||||||
once(event: 'connect', listener: (req: http.IncomingMessage, socket: Duplex, head: Buffer) => void): this;
|
|
||||||
once(event: 'request', listener: http.RequestListener): this;
|
|
||||||
once(event: 'upgrade', listener: (req: http.IncomingMessage, socket: Duplex, head: Buffer) => void): this;
|
|
||||||
prependListener(event: string, listener: (...args: any[]) => void): this;
|
|
||||||
prependListener(event: 'keylog', listener: (line: Buffer, tlsSocket: tls.TLSSocket) => void): this;
|
|
||||||
prependListener(event: 'newSession', listener: (sessionId: Buffer, sessionData: Buffer, callback: (err: Error, resp: Buffer) => void) => void): this;
|
|
||||||
prependListener(event: 'OCSPRequest', listener: (certificate: Buffer, issuer: Buffer, callback: (err: Error | null, resp: Buffer) => void) => void): this;
|
|
||||||
prependListener(event: 'resumeSession', listener: (sessionId: Buffer, callback: (err: Error, sessionData: Buffer) => void) => void): this;
|
|
||||||
prependListener(event: 'secureConnection', listener: (tlsSocket: tls.TLSSocket) => void): this;
|
|
||||||
prependListener(event: 'tlsClientError', listener: (err: Error, tlsSocket: tls.TLSSocket) => void): this;
|
|
||||||
prependListener(event: 'close', listener: () => void): this;
|
|
||||||
prependListener(event: 'connection', listener: (socket: Duplex) => void): this;
|
|
||||||
prependListener(event: 'error', listener: (err: Error) => void): this;
|
|
||||||
prependListener(event: 'listening', listener: () => void): this;
|
|
||||||
prependListener(event: 'checkContinue', listener: http.RequestListener): this;
|
|
||||||
prependListener(event: 'checkExpectation', listener: http.RequestListener): this;
|
|
||||||
prependListener(event: 'clientError', listener: (err: Error, socket: Duplex) => void): this;
|
|
||||||
prependListener(event: 'connect', listener: (req: http.IncomingMessage, socket: Duplex, head: Buffer) => void): this;
|
|
||||||
prependListener(event: 'request', listener: http.RequestListener): this;
|
|
||||||
prependListener(event: 'upgrade', listener: (req: http.IncomingMessage, socket: Duplex, head: Buffer) => void): this;
|
|
||||||
prependOnceListener(event: string, listener: (...args: any[]) => void): this;
|
|
||||||
prependOnceListener(event: 'keylog', listener: (line: Buffer, tlsSocket: tls.TLSSocket) => void): this;
|
|
||||||
prependOnceListener(event: 'newSession', listener: (sessionId: Buffer, sessionData: Buffer, callback: (err: Error, resp: Buffer) => void) => void): this;
|
|
||||||
prependOnceListener(event: 'OCSPRequest', listener: (certificate: Buffer, issuer: Buffer, callback: (err: Error | null, resp: Buffer) => void) => void): this;
|
|
||||||
prependOnceListener(event: 'resumeSession', listener: (sessionId: Buffer, callback: (err: Error, sessionData: Buffer) => void) => void): this;
|
|
||||||
prependOnceListener(event: 'secureConnection', listener: (tlsSocket: tls.TLSSocket) => void): this;
|
|
||||||
prependOnceListener(event: 'tlsClientError', listener: (err: Error, tlsSocket: tls.TLSSocket) => void): this;
|
|
||||||
prependOnceListener(event: 'close', listener: () => void): this;
|
|
||||||
prependOnceListener(event: 'connection', listener: (socket: Duplex) => void): this;
|
|
||||||
prependOnceListener(event: 'error', listener: (err: Error) => void): this;
|
|
||||||
prependOnceListener(event: 'listening', listener: () => void): this;
|
|
||||||
prependOnceListener(event: 'checkContinue', listener: http.RequestListener): this;
|
|
||||||
prependOnceListener(event: 'checkExpectation', listener: http.RequestListener): this;
|
|
||||||
prependOnceListener(event: 'clientError', listener: (err: Error, socket: Duplex) => void): this;
|
|
||||||
prependOnceListener(event: 'connect', listener: (req: http.IncomingMessage, socket: Duplex, head: Buffer) => void): this;
|
|
||||||
prependOnceListener(event: 'request', listener: http.RequestListener): this;
|
|
||||||
prependOnceListener(event: 'upgrade', listener: (req: http.IncomingMessage, socket: Duplex, head: Buffer) => void): this;
|
|
||||||
}
|
}
|
||||||
/**
|
|
||||||
* ```js
|
|
||||||
* // curl -k https://localhost:8000/
|
|
||||||
* const https = require('https');
|
|
||||||
* const fs = require('fs');
|
|
||||||
*
|
|
||||||
* const options = {
|
|
||||||
* key: fs.readFileSync('test/fixtures/keys/agent2-key.pem'),
|
|
||||||
* cert: fs.readFileSync('test/fixtures/keys/agent2-cert.pem')
|
|
||||||
* };
|
|
||||||
*
|
|
||||||
* https.createServer(options, (req, res) => {
|
|
||||||
* res.writeHead(200);
|
|
||||||
* res.end('hello world\n');
|
|
||||||
* }).listen(8000);
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Or
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const https = require('https');
|
|
||||||
* const fs = require('fs');
|
|
||||||
*
|
|
||||||
* const options = {
|
|
||||||
* pfx: fs.readFileSync('test/fixtures/test_cert.pfx'),
|
|
||||||
* passphrase: 'sample'
|
|
||||||
* };
|
|
||||||
*
|
|
||||||
* https.createServer(options, (req, res) => {
|
|
||||||
* res.writeHead(200);
|
|
||||||
* res.end('hello world\n');
|
|
||||||
* }).listen(8000);
|
|
||||||
* ```
|
|
||||||
* @since v0.3.4
|
|
||||||
* @param options Accepts `options` from `createServer`, `createSecureContext` and `createServer`.
|
|
||||||
* @param requestListener A listener to be added to the `'request'` event.
|
|
||||||
*/
|
|
||||||
function createServer(requestListener?: http.RequestListener): Server;
|
function createServer(requestListener?: http.RequestListener): Server;
|
||||||
function createServer(options: ServerOptions, requestListener?: http.RequestListener): Server;
|
function createServer(options: ServerOptions, requestListener?: http.RequestListener): Server;
|
||||||
/**
|
|
||||||
* Makes a request to a secure web server.
|
|
||||||
*
|
|
||||||
* The following additional `options` from `tls.connect()` are also accepted:`ca`, `cert`, `ciphers`, `clientCertEngine`, `crl`, `dhparam`, `ecdhCurve`,`honorCipherOrder`, `key`, `passphrase`,
|
|
||||||
* `pfx`, `rejectUnauthorized`,`secureOptions`, `secureProtocol`, `servername`, `sessionIdContext`,`highWaterMark`.
|
|
||||||
*
|
|
||||||
* `options` can be an object, a string, or a `URL` object. If `options` is a
|
|
||||||
* string, it is automatically parsed with `new URL()`. If it is a `URL` object, it will be automatically converted to an ordinary `options` object.
|
|
||||||
*
|
|
||||||
* `https.request()` returns an instance of the `http.ClientRequest` class. The `ClientRequest` instance is a writable stream. If one needs to
|
|
||||||
* upload a file with a POST request, then write to the `ClientRequest` object.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const https = require('https');
|
|
||||||
*
|
|
||||||
* const options = {
|
|
||||||
* hostname: 'encrypted.google.com',
|
|
||||||
* port: 443,
|
|
||||||
* path: '/',
|
|
||||||
* method: 'GET'
|
|
||||||
* };
|
|
||||||
*
|
|
||||||
* const req = https.request(options, (res) => {
|
|
||||||
* console.log('statusCode:', res.statusCode);
|
|
||||||
* console.log('headers:', res.headers);
|
|
||||||
*
|
|
||||||
* res.on('data', (d) => {
|
|
||||||
* process.stdout.write(d);
|
|
||||||
* });
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* req.on('error', (e) => {
|
|
||||||
* console.error(e);
|
|
||||||
* });
|
|
||||||
* req.end();
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Example using options from `tls.connect()`:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const options = {
|
|
||||||
* hostname: 'encrypted.google.com',
|
|
||||||
* port: 443,
|
|
||||||
* path: '/',
|
|
||||||
* method: 'GET',
|
|
||||||
* key: fs.readFileSync('test/fixtures/keys/agent2-key.pem'),
|
|
||||||
* cert: fs.readFileSync('test/fixtures/keys/agent2-cert.pem')
|
|
||||||
* };
|
|
||||||
* options.agent = new https.Agent(options);
|
|
||||||
*
|
|
||||||
* const req = https.request(options, (res) => {
|
|
||||||
* // ...
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Alternatively, opt out of connection pooling by not using an `Agent`.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const options = {
|
|
||||||
* hostname: 'encrypted.google.com',
|
|
||||||
* port: 443,
|
|
||||||
* path: '/',
|
|
||||||
* method: 'GET',
|
|
||||||
* key: fs.readFileSync('test/fixtures/keys/agent2-key.pem'),
|
|
||||||
* cert: fs.readFileSync('test/fixtures/keys/agent2-cert.pem'),
|
|
||||||
* agent: false
|
|
||||||
* };
|
|
||||||
*
|
|
||||||
* const req = https.request(options, (res) => {
|
|
||||||
* // ...
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Example using a `URL` as `options`:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const options = new URL('https://abc:xyz@example.com');
|
|
||||||
*
|
|
||||||
* const req = https.request(options, (res) => {
|
|
||||||
* // ...
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Example pinning on certificate fingerprint, or the public key (similar to`pin-sha256`):
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const tls = require('tls');
|
|
||||||
* const https = require('https');
|
|
||||||
* const crypto = require('crypto');
|
|
||||||
*
|
|
||||||
* function sha256(s) {
|
|
||||||
* return crypto.createHash('sha256').update(s).digest('base64');
|
|
||||||
* }
|
|
||||||
* const options = {
|
|
||||||
* hostname: 'github.com',
|
|
||||||
* port: 443,
|
|
||||||
* path: '/',
|
|
||||||
* method: 'GET',
|
|
||||||
* checkServerIdentity: function(host, cert) {
|
|
||||||
* // Make sure the certificate is issued to the host we are connected to
|
|
||||||
* const err = tls.checkServerIdentity(host, cert);
|
|
||||||
* if (err) {
|
|
||||||
* return err;
|
|
||||||
* }
|
|
||||||
*
|
|
||||||
* // Pin the public key, similar to HPKP pin-sha25 pinning
|
|
||||||
* const pubkey256 = 'pL1+qb9HTMRZJmuC/bB/ZI9d302BYrrqiVuRyW+DGrU=';
|
|
||||||
* if (sha256(cert.pubkey) !== pubkey256) {
|
|
||||||
* const msg = 'Certificate verification error: ' +
|
|
||||||
* `The public key of '${cert.subject.CN}' ` +
|
|
||||||
* 'does not match our pinned fingerprint';
|
|
||||||
* return new Error(msg);
|
|
||||||
* }
|
|
||||||
*
|
|
||||||
* // Pin the exact certificate, rather than the pub key
|
|
||||||
* const cert256 = '25:FE:39:32:D9:63:8C:8A:FC:A1:9A:29:87:' +
|
|
||||||
* 'D8:3E:4C:1D:98:DB:71:E4:1A:48:03:98:EA:22:6A:BD:8B:93:16';
|
|
||||||
* if (cert.fingerprint256 !== cert256) {
|
|
||||||
* const msg = 'Certificate verification error: ' +
|
|
||||||
* `The certificate of '${cert.subject.CN}' ` +
|
|
||||||
* 'does not match our pinned fingerprint';
|
|
||||||
* return new Error(msg);
|
|
||||||
* }
|
|
||||||
*
|
|
||||||
* // This loop is informational only.
|
|
||||||
* // Print the certificate and public key fingerprints of all certs in the
|
|
||||||
* // chain. Its common to pin the public key of the issuer on the public
|
|
||||||
* // internet, while pinning the public key of the service in sensitive
|
|
||||||
* // environments.
|
|
||||||
* do {
|
|
||||||
* console.log('Subject Common Name:', cert.subject.CN);
|
|
||||||
* console.log(' Certificate SHA256 fingerprint:', cert.fingerprint256);
|
|
||||||
*
|
|
||||||
* hash = crypto.createHash('sha256');
|
|
||||||
* console.log(' Public key ping-sha256:', sha256(cert.pubkey));
|
|
||||||
*
|
|
||||||
* lastprint256 = cert.fingerprint256;
|
|
||||||
* cert = cert.issuerCertificate;
|
|
||||||
* } while (cert.fingerprint256 !== lastprint256);
|
|
||||||
*
|
|
||||||
* },
|
|
||||||
* };
|
|
||||||
*
|
|
||||||
* options.agent = new https.Agent(options);
|
|
||||||
* const req = https.request(options, (res) => {
|
|
||||||
* console.log('All OK. Server matched our pinned cert or public key');
|
|
||||||
* console.log('statusCode:', res.statusCode);
|
|
||||||
* // Print the HPKP values
|
|
||||||
* console.log('headers:', res.headers['public-key-pins']);
|
|
||||||
*
|
|
||||||
* res.on('data', (d) => {});
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* req.on('error', (e) => {
|
|
||||||
* console.error(e.message);
|
|
||||||
* });
|
|
||||||
* req.end();
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Outputs for example:
|
|
||||||
*
|
|
||||||
* ```text
|
|
||||||
* Subject Common Name: github.com
|
|
||||||
* Certificate SHA256 fingerprint: 25:FE:39:32:D9:63:8C:8A:FC:A1:9A:29:87:D8:3E:4C:1D:98:DB:71:E4:1A:48:03:98:EA:22:6A:BD:8B:93:16
|
|
||||||
* Public key ping-sha256: pL1+qb9HTMRZJmuC/bB/ZI9d302BYrrqiVuRyW+DGrU=
|
|
||||||
* Subject Common Name: DigiCert SHA2 Extended Validation Server CA
|
|
||||||
* Certificate SHA256 fingerprint: 40:3E:06:2A:26:53:05:91:13:28:5B:AF:80:A0:D4:AE:42:2C:84:8C:9F:78:FA:D0:1F:C9:4B:C5:B8:7F:EF:1A
|
|
||||||
* Public key ping-sha256: RRM1dGqnDFsCJXBTHky16vi1obOlCgFFn/yOhI/y+ho=
|
|
||||||
* Subject Common Name: DigiCert High Assurance EV Root CA
|
|
||||||
* Certificate SHA256 fingerprint: 74:31:E5:F4:C3:C1:CE:46:90:77:4F:0B:61:E0:54:40:88:3B:A9:A0:1E:D0:0B:A6:AB:D7:80:6E:D3:B1:18:CF
|
|
||||||
* Public key ping-sha256: WoiWRyIOVNa9ihaBciRSC7XHjliYS9VwUGOIud4PB18=
|
|
||||||
* All OK. Server matched our pinned cert or public key
|
|
||||||
* statusCode: 200
|
|
||||||
* headers: max-age=0; pin-sha256="WoiWRyIOVNa9ihaBciRSC7XHjliYS9VwUGOIud4PB18="; pin-sha256="RRM1dGqnDFsCJXBTHky16vi1obOlCgFFn/yOhI/y+ho=";
|
|
||||||
* pin-sha256="k2v657xBsOVe1PQRwOsHsw3bsGT2VzIqz5K+59sNQws="; pin-sha256="K87oWBWM9UZfyddvDfoxL+8lpNyoUB2ptGtn0fv6G2Q="; pin-sha256="IQBnNBEiFuhj+8x6X8XLgh01V9Ic5/V3IRQLNFFc7v4=";
|
|
||||||
* pin-sha256="iie1VXtL7HzAMF+/PVPR9xzT80kQxdZeJ+zduCB3uj0="; pin-sha256="LvRiGEjRqfzurezaWuj8Wie2gyHMrW5Q06LspMnox7A="; includeSubDomains
|
|
||||||
* ```
|
|
||||||
* @since v0.3.6
|
|
||||||
* @param options Accepts all `options` from `request`, with some differences in default values:
|
|
||||||
*/
|
|
||||||
function request(options: RequestOptions | string | URL, callback?: (res: http.IncomingMessage) => void): http.ClientRequest;
|
function request(options: RequestOptions | string | URL, callback?: (res: http.IncomingMessage) => void): http.ClientRequest;
|
||||||
function request(url: string | URL, options: RequestOptions, callback?: (res: http.IncomingMessage) => void): http.ClientRequest;
|
function request(url: string | URL, options: RequestOptions, callback?: (res: http.IncomingMessage) => void): http.ClientRequest;
|
||||||
/**
|
|
||||||
* Like `http.get()` but for HTTPS.
|
|
||||||
*
|
|
||||||
* `options` can be an object, a string, or a `URL` object. If `options` is a
|
|
||||||
* string, it is automatically parsed with `new URL()`. If it is a `URL` object, it will be automatically converted to an ordinary `options` object.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const https = require('https');
|
|
||||||
*
|
|
||||||
* https.get('https://encrypted.google.com/', (res) => {
|
|
||||||
* console.log('statusCode:', res.statusCode);
|
|
||||||
* console.log('headers:', res.headers);
|
|
||||||
*
|
|
||||||
* res.on('data', (d) => {
|
|
||||||
* process.stdout.write(d);
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* }).on('error', (e) => {
|
|
||||||
* console.error(e);
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
* @since v0.3.6
|
|
||||||
* @param options Accepts the same `options` as {@link request}, with the `method` always set to `GET`.
|
|
||||||
*/
|
|
||||||
function get(options: RequestOptions | string | URL, callback?: (res: http.IncomingMessage) => void): http.ClientRequest;
|
function get(options: RequestOptions | string | URL, callback?: (res: http.IncomingMessage) => void): http.ClientRequest;
|
||||||
function get(url: string | URL, options: RequestOptions, callback?: (res: http.IncomingMessage) => void): http.ClientRequest;
|
function get(url: string | URL, options: RequestOptions, callback?: (res: http.IncomingMessage) => void): http.ClientRequest;
|
||||||
let globalAgent: Agent;
|
let globalAgent: Agent;
|
||||||
}
|
}
|
||||||
declare module 'node:https' {
|
|
||||||
export * from 'https';
|
|
||||||
}
|
|
||||||
|
|||||||
108
node_modules/@types/node/index.d.ts
generated
vendored
Executable file → Normal file
108
node_modules/@types/node/index.d.ts
generated
vendored
Executable file → Normal file
@@ -1,16 +1,20 @@
|
|||||||
// Type definitions for non-npm package Node.js 16.11
|
// Type definitions for non-npm package Node.js 12.12
|
||||||
// Project: https://nodejs.org/
|
// Project: http://nodejs.org/
|
||||||
// Definitions by: Microsoft TypeScript <https://github.com/Microsoft>
|
// Definitions by: Microsoft TypeScript <https://github.com/Microsoft>
|
||||||
// DefinitelyTyped <https://github.com/DefinitelyTyped>
|
// DefinitelyTyped <https://github.com/DefinitelyTyped>
|
||||||
// Alberto Schiabel <https://github.com/jkomyno>
|
// Alberto Schiabel <https://github.com/jkomyno>
|
||||||
|
// Alexander T. <https://github.com/a-tarasyuk>
|
||||||
// Alvis HT Tang <https://github.com/alvis>
|
// Alvis HT Tang <https://github.com/alvis>
|
||||||
// Andrew Makarov <https://github.com/r3nya>
|
// Andrew Makarov <https://github.com/r3nya>
|
||||||
// Benjamin Toueg <https://github.com/btoueg>
|
// Benjamin Toueg <https://github.com/btoueg>
|
||||||
|
// Bruno Scheufler <https://github.com/brunoscheufler>
|
||||||
// Chigozirim C. <https://github.com/smac89>
|
// Chigozirim C. <https://github.com/smac89>
|
||||||
// David Junger <https://github.com/touffy>
|
// David Junger <https://github.com/touffy>
|
||||||
// Deividas Bakanas <https://github.com/DeividasBakanas>
|
// Deividas Bakanas <https://github.com/DeividasBakanas>
|
||||||
// Eugene Y. Q. Shen <https://github.com/eyqs>
|
// Eugene Y. Q. Shen <https://github.com/eyqs>
|
||||||
|
// Flarna <https://github.com/Flarna>
|
||||||
// Hannes Magnusson <https://github.com/Hannes-Magnusson-CK>
|
// Hannes Magnusson <https://github.com/Hannes-Magnusson-CK>
|
||||||
|
// Hoàng Văn Khải <https://github.com/KSXGitHub>
|
||||||
// Huw <https://github.com/hoo29>
|
// Huw <https://github.com/hoo29>
|
||||||
// Kelvin Jin <https://github.com/kjin>
|
// Kelvin Jin <https://github.com/kjin>
|
||||||
// Klaus Meinhardt <https://github.com/ajafff>
|
// Klaus Meinhardt <https://github.com/ajafff>
|
||||||
@@ -21,110 +25,26 @@
|
|||||||
// Nikita Galkin <https://github.com/galkin>
|
// Nikita Galkin <https://github.com/galkin>
|
||||||
// Parambir Singh <https://github.com/parambirs>
|
// Parambir Singh <https://github.com/parambirs>
|
||||||
// Sebastian Silbermann <https://github.com/eps1lon>
|
// Sebastian Silbermann <https://github.com/eps1lon>
|
||||||
// Seth Westphal <https://github.com/westy92>
|
|
||||||
// Simon Schick <https://github.com/SimonSchick>
|
// Simon Schick <https://github.com/SimonSchick>
|
||||||
// Thomas den Hollander <https://github.com/ThomasdenH>
|
// Thomas den Hollander <https://github.com/ThomasdenH>
|
||||||
// Wilco Bakker <https://github.com/WilcoBakker>
|
// Wilco Bakker <https://github.com/WilcoBakker>
|
||||||
// wwwy3y3 <https://github.com/wwwy3y3>
|
// wwwy3y3 <https://github.com/wwwy3y3>
|
||||||
|
// Zane Hannan AU <https://github.com/ZaneHannanAU>
|
||||||
// Samuel Ainsworth <https://github.com/samuela>
|
// Samuel Ainsworth <https://github.com/samuela>
|
||||||
// Kyle Uehlein <https://github.com/kuehlein>
|
// Kyle Uehlein <https://github.com/kuehlein>
|
||||||
|
// Jordi Oliveras Rovira <https://github.com/j-oliveras>
|
||||||
// Thanik Bhongbhibhat <https://github.com/bhongy>
|
// Thanik Bhongbhibhat <https://github.com/bhongy>
|
||||||
// Marcin Kopacz <https://github.com/chyzwar>
|
// Marcin Kopacz <https://github.com/chyzwar>
|
||||||
// Trivikram Kamat <https://github.com/trivikr>
|
// Trivikram Kamat <https://github.com/trivikr>
|
||||||
|
// Minh Son Nguyen <https://github.com/nguymin4>
|
||||||
// Junxiao Shi <https://github.com/yoursunny>
|
// Junxiao Shi <https://github.com/yoursunny>
|
||||||
// Ilia Baryshnikov <https://github.com/qwelias>
|
// Ilia Baryshnikov <https://github.com/qwelias>
|
||||||
// ExE Boss <https://github.com/ExE-Boss>
|
// ExE Boss <https://github.com/ExE-Boss>
|
||||||
// Piotr Błażejewicz <https://github.com/peterblazejewicz>
|
// Jason Kwok <https://github.com/JasonHK>
|
||||||
// Anna Henningsen <https://github.com/addaleax>
|
|
||||||
// Victor Perin <https://github.com/victorperin>
|
|
||||||
// Yongsheng Zhang <https://github.com/ZYSzys>
|
|
||||||
// NodeJS Contributors <https://github.com/NodeJS>
|
|
||||||
// Linus Unnebäck <https://github.com/LinusU>
|
|
||||||
// wafuwafu13 <https://github.com/wafuwafu13>
|
|
||||||
// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped
|
// Definitions: https://github.com/DefinitelyTyped/DefinitelyTyped
|
||||||
|
|
||||||
/**
|
// NOTE: These definitions support NodeJS and TypeScript 3.7.
|
||||||
* License for programmatically and manually incorporated
|
// This isn't strictly needed since 3.7 has the assert module, but this way we're consistent.
|
||||||
* documentation aka. `JSDoc` from https://github.com/nodejs/node/tree/master/doc
|
// Typically type modificatons should be made in base.d.ts instead of here
|
||||||
*
|
|
||||||
* Copyright Node.js contributors. All rights reserved.
|
|
||||||
* 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.
|
|
||||||
*/
|
|
||||||
|
|
||||||
// NOTE: These definitions support NodeJS and TypeScript 3.7+.
|
/// <reference path="base.d.ts" />
|
||||||
|
|
||||||
// Reference required types from the default lib:
|
|
||||||
/// <reference lib="es2020" />
|
|
||||||
/// <reference lib="esnext.asynciterable" />
|
|
||||||
/// <reference lib="esnext.intl" />
|
|
||||||
/// <reference lib="esnext.bigint" />
|
|
||||||
|
|
||||||
// Base definitions for all NodeJS modules that are not specific to any version of TypeScript:
|
|
||||||
/// <reference path="assert.d.ts" />
|
|
||||||
/// <reference path="assert/strict.d.ts" />
|
|
||||||
/// <reference path="globals.d.ts" />
|
|
||||||
/// <reference path="async_hooks.d.ts" />
|
|
||||||
/// <reference path="buffer.d.ts" />
|
|
||||||
/// <reference path="child_process.d.ts" />
|
|
||||||
/// <reference path="cluster.d.ts" />
|
|
||||||
/// <reference path="console.d.ts" />
|
|
||||||
/// <reference path="constants.d.ts" />
|
|
||||||
/// <reference path="crypto.d.ts" />
|
|
||||||
/// <reference path="dgram.d.ts" />
|
|
||||||
/// <reference path="diagnostics_channel.d.ts" />
|
|
||||||
/// <reference path="dns.d.ts" />
|
|
||||||
/// <reference path="dns/promises.d.ts" />
|
|
||||||
/// <reference path="dns/promises.d.ts" />
|
|
||||||
/// <reference path="domain.d.ts" />
|
|
||||||
/// <reference path="events.d.ts" />
|
|
||||||
/// <reference path="fs.d.ts" />
|
|
||||||
/// <reference path="fs/promises.d.ts" />
|
|
||||||
/// <reference path="http.d.ts" />
|
|
||||||
/// <reference path="http2.d.ts" />
|
|
||||||
/// <reference path="https.d.ts" />
|
|
||||||
/// <reference path="inspector.d.ts" />
|
|
||||||
/// <reference path="module.d.ts" />
|
|
||||||
/// <reference path="net.d.ts" />
|
|
||||||
/// <reference path="os.d.ts" />
|
|
||||||
/// <reference path="path.d.ts" />
|
|
||||||
/// <reference path="perf_hooks.d.ts" />
|
|
||||||
/// <reference path="process.d.ts" />
|
|
||||||
/// <reference path="punycode.d.ts" />
|
|
||||||
/// <reference path="querystring.d.ts" />
|
|
||||||
/// <reference path="readline.d.ts" />
|
|
||||||
/// <reference path="repl.d.ts" />
|
|
||||||
/// <reference path="stream.d.ts" />
|
|
||||||
/// <reference path="stream/promises.d.ts" />
|
|
||||||
/// <reference path="stream/consumers.d.ts" />
|
|
||||||
/// <reference path="stream/web.d.ts" />
|
|
||||||
/// <reference path="string_decoder.d.ts" />
|
|
||||||
/// <reference path="timers.d.ts" />
|
|
||||||
/// <reference path="timers/promises.d.ts" />
|
|
||||||
/// <reference path="tls.d.ts" />
|
|
||||||
/// <reference path="trace_events.d.ts" />
|
|
||||||
/// <reference path="tty.d.ts" />
|
|
||||||
/// <reference path="url.d.ts" />
|
|
||||||
/// <reference path="util.d.ts" />
|
|
||||||
/// <reference path="v8.d.ts" />
|
|
||||||
/// <reference path="vm.d.ts" />
|
|
||||||
/// <reference path="wasi.d.ts" />
|
|
||||||
/// <reference path="worker_threads.d.ts" />
|
|
||||||
/// <reference path="zlib.d.ts" />
|
|
||||||
|
|
||||||
/// <reference path="globals.global.d.ts" />
|
|
||||||
|
|||||||
1325
node_modules/@types/node/inspector.d.ts
generated
vendored
Executable file → Normal file
1325
node_modules/@types/node/inspector.d.ts
generated
vendored
Executable file → Normal file
File diff suppressed because it is too large
Load Diff
115
node_modules/@types/node/module.d.ts
generated
vendored
Executable file → Normal file
115
node_modules/@types/node/module.d.ts
generated
vendored
Executable file → Normal file
@@ -1,114 +1,3 @@
|
|||||||
/**
|
declare module "module" {
|
||||||
* @since v0.3.7
|
export = NodeJS.Module;
|
||||||
*/
|
|
||||||
declare module 'module' {
|
|
||||||
import { URL } from 'node:url';
|
|
||||||
namespace Module {
|
|
||||||
/**
|
|
||||||
* The `module.syncBuiltinESMExports()` method updates all the live bindings for
|
|
||||||
* builtin `ES Modules` to match the properties of the `CommonJS` exports. It
|
|
||||||
* does not add or remove exported names from the `ES Modules`.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const fs = require('fs');
|
|
||||||
* const assert = require('assert');
|
|
||||||
* const { syncBuiltinESMExports } = require('module');
|
|
||||||
*
|
|
||||||
* fs.readFile = newAPI;
|
|
||||||
*
|
|
||||||
* delete fs.readFileSync;
|
|
||||||
*
|
|
||||||
* function newAPI() {
|
|
||||||
* // ...
|
|
||||||
* }
|
|
||||||
*
|
|
||||||
* fs.newAPI = newAPI;
|
|
||||||
*
|
|
||||||
* syncBuiltinESMExports();
|
|
||||||
*
|
|
||||||
* import('fs').then((esmFS) => {
|
|
||||||
* // It syncs the existing readFile property with the new value
|
|
||||||
* assert.strictEqual(esmFS.readFile, newAPI);
|
|
||||||
* // readFileSync has been deleted from the required fs
|
|
||||||
* assert.strictEqual('readFileSync' in fs, false);
|
|
||||||
* // syncBuiltinESMExports() does not remove readFileSync from esmFS
|
|
||||||
* assert.strictEqual('readFileSync' in esmFS, true);
|
|
||||||
* // syncBuiltinESMExports() does not add names
|
|
||||||
* assert.strictEqual(esmFS.newAPI, undefined);
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
* @since v12.12.0
|
|
||||||
*/
|
|
||||||
function syncBuiltinESMExports(): void;
|
|
||||||
/**
|
|
||||||
* `path` is the resolved path for the file for which a corresponding source map
|
|
||||||
* should be fetched.
|
|
||||||
* @since v13.7.0, v12.17.0
|
|
||||||
*/
|
|
||||||
function findSourceMap(path: string, error?: Error): SourceMap;
|
|
||||||
interface SourceMapPayload {
|
|
||||||
file: string;
|
|
||||||
version: number;
|
|
||||||
sources: string[];
|
|
||||||
sourcesContent: string[];
|
|
||||||
names: string[];
|
|
||||||
mappings: string;
|
|
||||||
sourceRoot: string;
|
|
||||||
}
|
|
||||||
interface SourceMapping {
|
|
||||||
generatedLine: number;
|
|
||||||
generatedColumn: number;
|
|
||||||
originalSource: string;
|
|
||||||
originalLine: number;
|
|
||||||
originalColumn: number;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* @since v13.7.0, v12.17.0
|
|
||||||
*/
|
|
||||||
class SourceMap {
|
|
||||||
/**
|
|
||||||
* Getter for the payload used to construct the `SourceMap` instance.
|
|
||||||
*/
|
|
||||||
readonly payload: SourceMapPayload;
|
|
||||||
constructor(payload: SourceMapPayload);
|
|
||||||
/**
|
|
||||||
* Given a line number and column number in the generated source file, returns
|
|
||||||
* an object representing the position in the original file. The object returned
|
|
||||||
* consists of the following keys:
|
|
||||||
*/
|
|
||||||
findEntry(line: number, column: number): SourceMapping;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
interface Module extends NodeModule {}
|
|
||||||
class Module {
|
|
||||||
static runMain(): void;
|
|
||||||
static wrap(code: string): string;
|
|
||||||
static createRequire(path: string | URL): NodeRequire;
|
|
||||||
static builtinModules: string[];
|
|
||||||
static Module: typeof Module;
|
|
||||||
constructor(id: string, parent?: Module);
|
|
||||||
}
|
|
||||||
global {
|
|
||||||
interface ImportMeta {
|
|
||||||
url: string;
|
|
||||||
/**
|
|
||||||
* @experimental
|
|
||||||
* This feature is only available with the `--experimental-import-meta-resolve`
|
|
||||||
* command flag enabled.
|
|
||||||
*
|
|
||||||
* Provides a module-relative resolution function scoped to each module, returning
|
|
||||||
* the URL string.
|
|
||||||
*
|
|
||||||
* @param specified The module specifier to resolve relative to `parent`.
|
|
||||||
* @param parent The absolute parent module URL to resolve from. If none
|
|
||||||
* is specified, the value of `import.meta.url` is used as the default.
|
|
||||||
*/
|
|
||||||
resolve?(specified: string, parent?: string | URL): Promise<string>;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
export = Module;
|
|
||||||
}
|
|
||||||
declare module 'node:module' {
|
|
||||||
import module = require('module');
|
|
||||||
export = module;
|
|
||||||
}
|
}
|
||||||
|
|||||||
816
node_modules/@types/node/net.d.ts
generated
vendored
Executable file → Normal file
816
node_modules/@types/node/net.d.ts
generated
vendored
Executable file → Normal file
@@ -1,34 +1,23 @@
|
|||||||
/**
|
declare module "net" {
|
||||||
* > Stability: 2 - Stable
|
import * as stream from "stream";
|
||||||
*
|
import * as events from "events";
|
||||||
* The `net` module provides an asynchronous network API for creating stream-based
|
import * as dns from "dns";
|
||||||
* TCP or `IPC` servers ({@link createServer}) and clients
|
|
||||||
* ({@link createConnection}).
|
|
||||||
*
|
|
||||||
* It can be accessed using:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const net = require('net');
|
|
||||||
* ```
|
|
||||||
* @see [source](https://github.com/nodejs/node/blob/v16.9.0/lib/net.js)
|
|
||||||
*/
|
|
||||||
declare module 'net' {
|
|
||||||
import * as stream from 'node:stream';
|
|
||||||
import { Abortable, EventEmitter } from 'node:events';
|
|
||||||
import * as dns from 'node:dns';
|
|
||||||
type LookupFunction = (hostname: string, options: dns.LookupOneOptions, callback: (err: NodeJS.ErrnoException | null, address: string, family: number) => void) => void;
|
type LookupFunction = (hostname: string, options: dns.LookupOneOptions, callback: (err: NodeJS.ErrnoException | null, address: string, family: number) => void) => void;
|
||||||
|
|
||||||
interface AddressInfo {
|
interface AddressInfo {
|
||||||
address: string;
|
address: string;
|
||||||
family: string;
|
family: string;
|
||||||
port: number;
|
port: number;
|
||||||
}
|
}
|
||||||
|
|
||||||
interface SocketConstructorOpts {
|
interface SocketConstructorOpts {
|
||||||
fd?: number | undefined;
|
fd?: number;
|
||||||
allowHalfOpen?: boolean | undefined;
|
allowHalfOpen?: boolean;
|
||||||
readable?: boolean | undefined;
|
readable?: boolean;
|
||||||
writable?: boolean | undefined;
|
writable?: boolean;
|
||||||
signal?: AbortSignal;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
interface OnReadOpts {
|
interface OnReadOpts {
|
||||||
buffer: Uint8Array | (() => Uint8Array);
|
buffer: Uint8Array | (() => Uint8Array);
|
||||||
/**
|
/**
|
||||||
@@ -38,259 +27,70 @@ declare module 'net' {
|
|||||||
*/
|
*/
|
||||||
callback(bytesWritten: number, buf: Uint8Array): boolean;
|
callback(bytesWritten: number, buf: Uint8Array): boolean;
|
||||||
}
|
}
|
||||||
|
|
||||||
interface ConnectOpts {
|
interface ConnectOpts {
|
||||||
/**
|
/**
|
||||||
* If specified, incoming data is stored in a single buffer and passed to the supplied callback when data arrives on the socket.
|
* If specified, incoming data is stored in a single buffer and passed to the supplied callback when data arrives on the socket.
|
||||||
* Note: this will cause the streaming functionality to not provide any data, however events like 'error', 'end', and 'close' will
|
* Note: this will cause the streaming functionality to not provide any data, however events like 'error', 'end', and 'close' will
|
||||||
* still be emitted as normal and methods like pause() and resume() will also behave as expected.
|
* still be emitted as normal and methods like pause() and resume() will also behave as expected.
|
||||||
*/
|
*/
|
||||||
onread?: OnReadOpts | undefined;
|
onread?: OnReadOpts;
|
||||||
}
|
}
|
||||||
|
|
||||||
interface TcpSocketConnectOpts extends ConnectOpts {
|
interface TcpSocketConnectOpts extends ConnectOpts {
|
||||||
port: number;
|
port: number;
|
||||||
host?: string | undefined;
|
host?: string;
|
||||||
localAddress?: string | undefined;
|
localAddress?: string;
|
||||||
localPort?: number | undefined;
|
localPort?: number;
|
||||||
hints?: number | undefined;
|
hints?: number;
|
||||||
family?: number | undefined;
|
family?: number;
|
||||||
lookup?: LookupFunction | undefined;
|
lookup?: LookupFunction;
|
||||||
}
|
}
|
||||||
|
|
||||||
interface IpcSocketConnectOpts extends ConnectOpts {
|
interface IpcSocketConnectOpts extends ConnectOpts {
|
||||||
path: string;
|
path: string;
|
||||||
}
|
}
|
||||||
|
|
||||||
type SocketConnectOpts = TcpSocketConnectOpts | IpcSocketConnectOpts;
|
type SocketConnectOpts = TcpSocketConnectOpts | IpcSocketConnectOpts;
|
||||||
/**
|
|
||||||
* This class is an abstraction of a TCP socket or a streaming `IPC` endpoint
|
|
||||||
* (uses named pipes on Windows, and Unix domain sockets otherwise). It is also
|
|
||||||
* an `EventEmitter`.
|
|
||||||
*
|
|
||||||
* A `net.Socket` can be created by the user and used directly to interact with
|
|
||||||
* a server. For example, it is returned by {@link createConnection},
|
|
||||||
* so the user can use it to talk to the server.
|
|
||||||
*
|
|
||||||
* It can also be created by Node.js and passed to the user when a connection
|
|
||||||
* is received. For example, it is passed to the listeners of a `'connection'` event emitted on a {@link Server}, so the user can use
|
|
||||||
* it to interact with the client.
|
|
||||||
* @since v0.3.4
|
|
||||||
*/
|
|
||||||
class Socket extends stream.Duplex {
|
class Socket extends stream.Duplex {
|
||||||
constructor(options?: SocketConstructorOpts);
|
constructor(options?: SocketConstructorOpts);
|
||||||
/**
|
|
||||||
* Sends data on the socket. The second parameter specifies the encoding in the
|
// Extended base methods
|
||||||
* case of a string. It defaults to UTF8 encoding.
|
|
||||||
*
|
|
||||||
* Returns `true` if the entire data was flushed successfully to the kernel
|
|
||||||
* buffer. Returns `false` if all or part of the data was queued in user memory.`'drain'` will be emitted when the buffer is again free.
|
|
||||||
*
|
|
||||||
* The optional `callback` parameter will be executed when the data is finally
|
|
||||||
* written out, which may not be immediately.
|
|
||||||
*
|
|
||||||
* See `Writable` stream `write()` method for more
|
|
||||||
* information.
|
|
||||||
* @since v0.1.90
|
|
||||||
* @param [encoding='utf8'] Only used when data is `string`.
|
|
||||||
*/
|
|
||||||
write(buffer: Uint8Array | string, cb?: (err?: Error) => void): boolean;
|
write(buffer: Uint8Array | string, cb?: (err?: Error) => void): boolean;
|
||||||
write(str: Uint8Array | string, encoding?: BufferEncoding, cb?: (err?: Error) => void): boolean;
|
write(str: Uint8Array | string, encoding?: string, cb?: (err?: Error) => void): boolean;
|
||||||
/**
|
|
||||||
* Initiate a connection on a given socket.
|
|
||||||
*
|
|
||||||
* Possible signatures:
|
|
||||||
*
|
|
||||||
* * `socket.connect(options[, connectListener])`
|
|
||||||
* * `socket.connect(path[, connectListener])` for `IPC` connections.
|
|
||||||
* * `socket.connect(port[, host][, connectListener])` for TCP connections.
|
|
||||||
* * Returns: `net.Socket` The socket itself.
|
|
||||||
*
|
|
||||||
* This function is asynchronous. When the connection is established, the `'connect'` event will be emitted. If there is a problem connecting,
|
|
||||||
* instead of a `'connect'` event, an `'error'` event will be emitted with
|
|
||||||
* the error passed to the `'error'` listener.
|
|
||||||
* The last parameter `connectListener`, if supplied, will be added as a listener
|
|
||||||
* for the `'connect'` event **once**.
|
|
||||||
*
|
|
||||||
* This function should only be used for reconnecting a socket after`'close'` has been emitted or otherwise it may lead to undefined
|
|
||||||
* behavior.
|
|
||||||
*/
|
|
||||||
connect(options: SocketConnectOpts, connectionListener?: () => void): this;
|
connect(options: SocketConnectOpts, connectionListener?: () => void): this;
|
||||||
connect(port: number, host: string, connectionListener?: () => void): this;
|
connect(port: number, host: string, connectionListener?: () => void): this;
|
||||||
connect(port: number, connectionListener?: () => void): this;
|
connect(port: number, connectionListener?: () => void): this;
|
||||||
connect(path: string, connectionListener?: () => void): this;
|
connect(path: string, connectionListener?: () => void): this;
|
||||||
/**
|
|
||||||
* Set the encoding for the socket as a `Readable Stream`. See `readable.setEncoding()` for more information.
|
setEncoding(encoding?: string): this;
|
||||||
* @since v0.1.90
|
|
||||||
* @return The socket itself.
|
|
||||||
*/
|
|
||||||
setEncoding(encoding?: BufferEncoding): this;
|
|
||||||
/**
|
|
||||||
* Pauses the reading of data. That is, `'data'` events will not be emitted.
|
|
||||||
* Useful to throttle back an upload.
|
|
||||||
* @return The socket itself.
|
|
||||||
*/
|
|
||||||
pause(): this;
|
pause(): this;
|
||||||
/**
|
|
||||||
* Resumes reading after a call to `socket.pause()`.
|
|
||||||
* @return The socket itself.
|
|
||||||
*/
|
|
||||||
resume(): this;
|
resume(): this;
|
||||||
/**
|
|
||||||
* Sets the socket to timeout after `timeout` milliseconds of inactivity on
|
|
||||||
* the socket. By default `net.Socket` do not have a timeout.
|
|
||||||
*
|
|
||||||
* When an idle timeout is triggered the socket will receive a `'timeout'` event but the connection will not be severed. The user must manually call `socket.end()` or `socket.destroy()` to
|
|
||||||
* end the connection.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* socket.setTimeout(3000);
|
|
||||||
* socket.on('timeout', () => {
|
|
||||||
* console.log('socket timeout');
|
|
||||||
* socket.end();
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* If `timeout` is 0, then the existing idle timeout is disabled.
|
|
||||||
*
|
|
||||||
* The optional `callback` parameter will be added as a one-time listener for the `'timeout'` event.
|
|
||||||
* @since v0.1.90
|
|
||||||
* @return The socket itself.
|
|
||||||
*/
|
|
||||||
setTimeout(timeout: number, callback?: () => void): this;
|
setTimeout(timeout: number, callback?: () => void): this;
|
||||||
/**
|
|
||||||
* Enable/disable the use of Nagle's algorithm.
|
|
||||||
*
|
|
||||||
* When a TCP connection is created, it will have Nagle's algorithm enabled.
|
|
||||||
*
|
|
||||||
* Nagle's algorithm delays data before it is sent via the network. It attempts
|
|
||||||
* to optimize throughput at the expense of latency.
|
|
||||||
*
|
|
||||||
* Passing `true` for `noDelay` or not passing an argument will disable Nagle's
|
|
||||||
* algorithm for the socket. Passing `false` for `noDelay` will enable Nagle's
|
|
||||||
* algorithm.
|
|
||||||
* @since v0.1.90
|
|
||||||
* @param [noDelay=true]
|
|
||||||
* @return The socket itself.
|
|
||||||
*/
|
|
||||||
setNoDelay(noDelay?: boolean): this;
|
setNoDelay(noDelay?: boolean): this;
|
||||||
/**
|
|
||||||
* Enable/disable keep-alive functionality, and optionally set the initial
|
|
||||||
* delay before the first keepalive probe is sent on an idle socket.
|
|
||||||
*
|
|
||||||
* Set `initialDelay` (in milliseconds) to set the delay between the last
|
|
||||||
* data packet received and the first keepalive probe. Setting `0` for`initialDelay` will leave the value unchanged from the default
|
|
||||||
* (or previous) setting.
|
|
||||||
*
|
|
||||||
* Enabling the keep-alive functionality will set the following socket options:
|
|
||||||
*
|
|
||||||
* * `SO_KEEPALIVE=1`
|
|
||||||
* * `TCP_KEEPIDLE=initialDelay`
|
|
||||||
* * `TCP_KEEPCNT=10`
|
|
||||||
* * `TCP_KEEPINTVL=1`
|
|
||||||
* @since v0.1.92
|
|
||||||
* @param [enable=false]
|
|
||||||
* @param [initialDelay=0]
|
|
||||||
* @return The socket itself.
|
|
||||||
*/
|
|
||||||
setKeepAlive(enable?: boolean, initialDelay?: number): this;
|
setKeepAlive(enable?: boolean, initialDelay?: number): this;
|
||||||
/**
|
address(): AddressInfo | string;
|
||||||
* Returns the bound `address`, the address `family` name and `port` of the
|
unref(): void;
|
||||||
* socket as reported by the operating system:`{ port: 12346, family: 'IPv4', address: '127.0.0.1' }`
|
ref(): void;
|
||||||
* @since v0.1.90
|
|
||||||
*/
|
|
||||||
address(): AddressInfo | {};
|
|
||||||
/**
|
|
||||||
* Calling `unref()` on a socket will allow the program to exit if this is the only
|
|
||||||
* active socket in the event system. If the socket is already `unref`ed calling`unref()` again will have no effect.
|
|
||||||
* @since v0.9.1
|
|
||||||
* @return The socket itself.
|
|
||||||
*/
|
|
||||||
unref(): this;
|
|
||||||
/**
|
|
||||||
* Opposite of `unref()`, calling `ref()` on a previously `unref`ed socket will_not_ let the program exit if it's the only socket left (the default behavior).
|
|
||||||
* If the socket is `ref`ed calling `ref` again will have no effect.
|
|
||||||
* @since v0.9.1
|
|
||||||
* @return The socket itself.
|
|
||||||
*/
|
|
||||||
ref(): this;
|
|
||||||
/**
|
|
||||||
* This property shows the number of characters buffered for writing. The buffer
|
|
||||||
* may contain strings whose length after encoding is not yet known. So this number
|
|
||||||
* is only an approximation of the number of bytes in the buffer.
|
|
||||||
*
|
|
||||||
* `net.Socket` has the property that `socket.write()` always works. This is to
|
|
||||||
* help users get up and running quickly. The computer cannot always keep up
|
|
||||||
* with the amount of data that is written to a socket. The network connection
|
|
||||||
* simply might be too slow. Node.js will internally queue up the data written to a
|
|
||||||
* socket and send it out over the wire when it is possible.
|
|
||||||
*
|
|
||||||
* The consequence of this internal buffering is that memory may grow.
|
|
||||||
* Users who experience large or growing `bufferSize` should attempt to
|
|
||||||
* "throttle" the data flows in their program with `socket.pause()` and `socket.resume()`.
|
|
||||||
* @since v0.3.8
|
|
||||||
* @deprecated Since v14.6.0 - Use `writableLength` instead.
|
|
||||||
*/
|
|
||||||
readonly bufferSize: number;
|
readonly bufferSize: number;
|
||||||
/**
|
|
||||||
* The amount of received bytes.
|
|
||||||
* @since v0.5.3
|
|
||||||
*/
|
|
||||||
readonly bytesRead: number;
|
readonly bytesRead: number;
|
||||||
/**
|
|
||||||
* The amount of bytes sent.
|
|
||||||
* @since v0.5.3
|
|
||||||
*/
|
|
||||||
readonly bytesWritten: number;
|
readonly bytesWritten: number;
|
||||||
/**
|
|
||||||
* If `true`,`socket.connect(options[, connectListener])` was
|
|
||||||
* called and has not yet finished. It will stay `true` until the socket becomes
|
|
||||||
* connected, then it is set to `false` and the `'connect'` event is emitted. Note
|
|
||||||
* that the `socket.connect(options[, connectListener])` callback is a listener for the `'connect'` event.
|
|
||||||
* @since v6.1.0
|
|
||||||
*/
|
|
||||||
readonly connecting: boolean;
|
readonly connecting: boolean;
|
||||||
/**
|
|
||||||
* See `writable.destroyed` for further details.
|
|
||||||
*/
|
|
||||||
readonly destroyed: boolean;
|
readonly destroyed: boolean;
|
||||||
/**
|
readonly localAddress: string;
|
||||||
* The string representation of the local IP address the remote client is
|
readonly localPort: number;
|
||||||
* connecting on. For example, in a server listening on `'0.0.0.0'`, if a client
|
readonly remoteAddress?: string;
|
||||||
* connects on `'192.168.1.1'`, the value of `socket.localAddress` would be`'192.168.1.1'`.
|
readonly remoteFamily?: string;
|
||||||
* @since v0.9.6
|
readonly remotePort?: number;
|
||||||
*/
|
|
||||||
readonly localAddress?: string;
|
// Extended base methods
|
||||||
/**
|
end(cb?: () => void): void;
|
||||||
* The numeric representation of the local port. For example, `80` or `21`.
|
end(buffer: Uint8Array | string, cb?: () => void): void;
|
||||||
* @since v0.9.6
|
end(str: Uint8Array | string, encoding?: string, cb?: () => void): void;
|
||||||
*/
|
|
||||||
readonly localPort?: number;
|
|
||||||
/**
|
|
||||||
* The string representation of the remote IP address. For example,`'74.125.127.100'` or `'2001:4860:a005::68'`. Value may be `undefined` if
|
|
||||||
* the socket is destroyed (for example, if the client disconnected).
|
|
||||||
* @since v0.5.10
|
|
||||||
*/
|
|
||||||
readonly remoteAddress?: string | undefined;
|
|
||||||
/**
|
|
||||||
* The string representation of the remote IP family. `'IPv4'` or `'IPv6'`.
|
|
||||||
* @since v0.11.14
|
|
||||||
*/
|
|
||||||
readonly remoteFamily?: string | undefined;
|
|
||||||
/**
|
|
||||||
* The numeric representation of the remote port. For example, `80` or `21`.
|
|
||||||
* @since v0.5.10
|
|
||||||
*/
|
|
||||||
readonly remotePort?: number | undefined;
|
|
||||||
/**
|
|
||||||
* Half-closes the socket. i.e., it sends a FIN packet. It is possible the
|
|
||||||
* server will still send some data.
|
|
||||||
*
|
|
||||||
* See `writable.end()` for further details.
|
|
||||||
* @since v0.1.90
|
|
||||||
* @param [encoding='utf8'] Only used when data is `string`.
|
|
||||||
* @param callback Optional callback for when the socket is finished.
|
|
||||||
* @return The socket itself.
|
|
||||||
*/
|
|
||||||
end(callback?: () => void): void;
|
|
||||||
end(buffer: Uint8Array | string, callback?: () => void): void;
|
|
||||||
end(str: Uint8Array | string, encoding?: BufferEncoding, callback?: () => void): void;
|
|
||||||
/**
|
/**
|
||||||
* events.EventEmitter
|
* events.EventEmitter
|
||||||
* 1. close
|
* 1. close
|
||||||
@@ -303,139 +103,85 @@ declare module 'net' {
|
|||||||
* 8. timeout
|
* 8. timeout
|
||||||
*/
|
*/
|
||||||
addListener(event: string, listener: (...args: any[]) => void): this;
|
addListener(event: string, listener: (...args: any[]) => void): this;
|
||||||
addListener(event: 'close', listener: (hadError: boolean) => void): this;
|
addListener(event: "close", listener: (had_error: boolean) => void): this;
|
||||||
addListener(event: 'connect', listener: () => void): this;
|
addListener(event: "connect", listener: () => void): this;
|
||||||
addListener(event: 'data', listener: (data: Buffer) => void): this;
|
addListener(event: "data", listener: (data: Buffer) => void): this;
|
||||||
addListener(event: 'drain', listener: () => void): this;
|
addListener(event: "drain", listener: () => void): this;
|
||||||
addListener(event: 'end', listener: () => void): this;
|
addListener(event: "end", listener: () => void): this;
|
||||||
addListener(event: 'error', listener: (err: Error) => void): this;
|
addListener(event: "error", listener: (err: Error) => void): this;
|
||||||
addListener(event: 'lookup', listener: (err: Error, address: string, family: string | number, host: string) => void): this;
|
addListener(event: "lookup", listener: (err: Error, address: string, family: string | number, host: string) => void): this;
|
||||||
addListener(event: 'ready', listener: () => void): this;
|
addListener(event: "timeout", listener: () => void): this;
|
||||||
addListener(event: 'timeout', listener: () => void): this;
|
|
||||||
emit(event: string | symbol, ...args: any[]): boolean;
|
emit(event: string | symbol, ...args: any[]): boolean;
|
||||||
emit(event: 'close', hadError: boolean): boolean;
|
emit(event: "close", had_error: boolean): boolean;
|
||||||
emit(event: 'connect'): boolean;
|
emit(event: "connect"): boolean;
|
||||||
emit(event: 'data', data: Buffer): boolean;
|
emit(event: "data", data: Buffer): boolean;
|
||||||
emit(event: 'drain'): boolean;
|
emit(event: "drain"): boolean;
|
||||||
emit(event: 'end'): boolean;
|
emit(event: "end"): boolean;
|
||||||
emit(event: 'error', err: Error): boolean;
|
emit(event: "error", err: Error): boolean;
|
||||||
emit(event: 'lookup', err: Error, address: string, family: string | number, host: string): boolean;
|
emit(event: "lookup", err: Error, address: string, family: string | number, host: string): boolean;
|
||||||
emit(event: 'ready'): boolean;
|
emit(event: "timeout"): boolean;
|
||||||
emit(event: 'timeout'): boolean;
|
|
||||||
on(event: string, listener: (...args: any[]) => void): this;
|
on(event: string, listener: (...args: any[]) => void): this;
|
||||||
on(event: 'close', listener: (hadError: boolean) => void): this;
|
on(event: "close", listener: (had_error: boolean) => void): this;
|
||||||
on(event: 'connect', listener: () => void): this;
|
on(event: "connect", listener: () => void): this;
|
||||||
on(event: 'data', listener: (data: Buffer) => void): this;
|
on(event: "data", listener: (data: Buffer) => void): this;
|
||||||
on(event: 'drain', listener: () => void): this;
|
on(event: "drain", listener: () => void): this;
|
||||||
on(event: 'end', listener: () => void): this;
|
on(event: "end", listener: () => void): this;
|
||||||
on(event: 'error', listener: (err: Error) => void): this;
|
on(event: "error", listener: (err: Error) => void): this;
|
||||||
on(event: 'lookup', listener: (err: Error, address: string, family: string | number, host: string) => void): this;
|
on(event: "lookup", listener: (err: Error, address: string, family: string | number, host: string) => void): this;
|
||||||
on(event: 'ready', listener: () => void): this;
|
on(event: "timeout", listener: () => void): this;
|
||||||
on(event: 'timeout', listener: () => void): this;
|
|
||||||
once(event: string, listener: (...args: any[]) => void): this;
|
once(event: string, listener: (...args: any[]) => void): this;
|
||||||
once(event: 'close', listener: (hadError: boolean) => void): this;
|
once(event: "close", listener: (had_error: boolean) => void): this;
|
||||||
once(event: 'connect', listener: () => void): this;
|
once(event: "connect", listener: () => void): this;
|
||||||
once(event: 'data', listener: (data: Buffer) => void): this;
|
once(event: "data", listener: (data: Buffer) => void): this;
|
||||||
once(event: 'drain', listener: () => void): this;
|
once(event: "drain", listener: () => void): this;
|
||||||
once(event: 'end', listener: () => void): this;
|
once(event: "end", listener: () => void): this;
|
||||||
once(event: 'error', listener: (err: Error) => void): this;
|
once(event: "error", listener: (err: Error) => void): this;
|
||||||
once(event: 'lookup', listener: (err: Error, address: string, family: string | number, host: string) => void): this;
|
once(event: "lookup", listener: (err: Error, address: string, family: string | number, host: string) => void): this;
|
||||||
once(event: 'ready', listener: () => void): this;
|
once(event: "timeout", listener: () => void): this;
|
||||||
once(event: 'timeout', listener: () => void): this;
|
|
||||||
prependListener(event: string, listener: (...args: any[]) => void): this;
|
prependListener(event: string, listener: (...args: any[]) => void): this;
|
||||||
prependListener(event: 'close', listener: (hadError: boolean) => void): this;
|
prependListener(event: "close", listener: (had_error: boolean) => void): this;
|
||||||
prependListener(event: 'connect', listener: () => void): this;
|
prependListener(event: "connect", listener: () => void): this;
|
||||||
prependListener(event: 'data', listener: (data: Buffer) => void): this;
|
prependListener(event: "data", listener: (data: Buffer) => void): this;
|
||||||
prependListener(event: 'drain', listener: () => void): this;
|
prependListener(event: "drain", listener: () => void): this;
|
||||||
prependListener(event: 'end', listener: () => void): this;
|
prependListener(event: "end", listener: () => void): this;
|
||||||
prependListener(event: 'error', listener: (err: Error) => void): this;
|
prependListener(event: "error", listener: (err: Error) => void): this;
|
||||||
prependListener(event: 'lookup', listener: (err: Error, address: string, family: string | number, host: string) => void): this;
|
prependListener(event: "lookup", listener: (err: Error, address: string, family: string | number, host: string) => void): this;
|
||||||
prependListener(event: 'ready', listener: () => void): this;
|
prependListener(event: "timeout", listener: () => void): this;
|
||||||
prependListener(event: 'timeout', listener: () => void): this;
|
|
||||||
prependOnceListener(event: string, listener: (...args: any[]) => void): this;
|
prependOnceListener(event: string, listener: (...args: any[]) => void): this;
|
||||||
prependOnceListener(event: 'close', listener: (hadError: boolean) => void): this;
|
prependOnceListener(event: "close", listener: (had_error: boolean) => void): this;
|
||||||
prependOnceListener(event: 'connect', listener: () => void): this;
|
prependOnceListener(event: "connect", listener: () => void): this;
|
||||||
prependOnceListener(event: 'data', listener: (data: Buffer) => void): this;
|
prependOnceListener(event: "data", listener: (data: Buffer) => void): this;
|
||||||
prependOnceListener(event: 'drain', listener: () => void): this;
|
prependOnceListener(event: "drain", listener: () => void): this;
|
||||||
prependOnceListener(event: 'end', listener: () => void): this;
|
prependOnceListener(event: "end", listener: () => void): this;
|
||||||
prependOnceListener(event: 'error', listener: (err: Error) => void): this;
|
prependOnceListener(event: "error", listener: (err: Error) => void): this;
|
||||||
prependOnceListener(event: 'lookup', listener: (err: Error, address: string, family: string | number, host: string) => void): this;
|
prependOnceListener(event: "lookup", listener: (err: Error, address: string, family: string | number, host: string) => void): this;
|
||||||
prependOnceListener(event: 'ready', listener: () => void): this;
|
prependOnceListener(event: "timeout", listener: () => void): this;
|
||||||
prependOnceListener(event: 'timeout', listener: () => void): this;
|
|
||||||
}
|
}
|
||||||
interface ListenOptions extends Abortable {
|
|
||||||
port?: number | undefined;
|
interface ListenOptions {
|
||||||
host?: string | undefined;
|
port?: number;
|
||||||
backlog?: number | undefined;
|
host?: string;
|
||||||
path?: string | undefined;
|
backlog?: number;
|
||||||
exclusive?: boolean | undefined;
|
path?: string;
|
||||||
readableAll?: boolean | undefined;
|
exclusive?: boolean;
|
||||||
writableAll?: boolean | undefined;
|
readableAll?: boolean;
|
||||||
|
writableAll?: boolean;
|
||||||
/**
|
/**
|
||||||
* @default false
|
* @default false
|
||||||
*/
|
*/
|
||||||
ipv6Only?: boolean | undefined;
|
ipv6Only?: boolean;
|
||||||
}
|
}
|
||||||
interface ServerOpts {
|
|
||||||
/**
|
// https://github.com/nodejs/node/blob/master/lib/net.js
|
||||||
* Indicates whether half-opened TCP connections are allowed.
|
class Server extends events.EventEmitter {
|
||||||
* @default false
|
|
||||||
*/
|
|
||||||
allowHalfOpen?: boolean | undefined;
|
|
||||||
/**
|
|
||||||
* Indicates whether the socket should be paused on incoming connections.
|
|
||||||
* @default false
|
|
||||||
*/
|
|
||||||
pauseOnConnect?: boolean | undefined;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* This class is used to create a TCP or `IPC` server.
|
|
||||||
* @since v0.1.90
|
|
||||||
*/
|
|
||||||
class Server extends EventEmitter {
|
|
||||||
constructor(connectionListener?: (socket: Socket) => void);
|
constructor(connectionListener?: (socket: Socket) => void);
|
||||||
constructor(options?: ServerOpts, connectionListener?: (socket: Socket) => void);
|
constructor(options?: { allowHalfOpen?: boolean, pauseOnConnect?: boolean }, connectionListener?: (socket: Socket) => void);
|
||||||
/**
|
|
||||||
* Start a server listening for connections. A `net.Server` can be a TCP or
|
|
||||||
* an `IPC` server depending on what it listens to.
|
|
||||||
*
|
|
||||||
* Possible signatures:
|
|
||||||
*
|
|
||||||
* * `server.listen(handle[, backlog][, callback])`
|
|
||||||
* * `server.listen(options[, callback])`
|
|
||||||
* * `server.listen(path[, backlog][, callback])` for `IPC` servers
|
|
||||||
* * `server.listen([port[, host[, backlog]]][, callback])` for TCP servers
|
|
||||||
*
|
|
||||||
* This function is asynchronous. When the server starts listening, the `'listening'` event will be emitted. The last parameter `callback`will be added as a listener for the `'listening'`
|
|
||||||
* event.
|
|
||||||
*
|
|
||||||
* All `listen()` methods can take a `backlog` parameter to specify the maximum
|
|
||||||
* length of the queue of pending connections. The actual length will be determined
|
|
||||||
* by the OS through sysctl settings such as `tcp_max_syn_backlog` and `somaxconn`on Linux. The default value of this parameter is 511 (not 512).
|
|
||||||
*
|
|
||||||
* All {@link Socket} are set to `SO_REUSEADDR` (see [`socket(7)`](https://man7.org/linux/man-pages/man7/socket.7.html) for
|
|
||||||
* details).
|
|
||||||
*
|
|
||||||
* The `server.listen()` method can be called again if and only if there was an
|
|
||||||
* error during the first `server.listen()` call or `server.close()` has been
|
|
||||||
* called. Otherwise, an `ERR_SERVER_ALREADY_LISTEN` error will be thrown.
|
|
||||||
*
|
|
||||||
* One of the most common errors raised when listening is `EADDRINUSE`.
|
|
||||||
* This happens when another server is already listening on the requested`port`/`path`/`handle`. One way to handle this would be to retry
|
|
||||||
* after a certain amount of time:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* server.on('error', (e) => {
|
|
||||||
* if (e.code === 'EADDRINUSE') {
|
|
||||||
* console.log('Address in use, retrying...');
|
|
||||||
* setTimeout(() => {
|
|
||||||
* server.close();
|
|
||||||
* server.listen(PORT, HOST);
|
|
||||||
* }, 1000);
|
|
||||||
* }
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*/
|
|
||||||
listen(port?: number, hostname?: string, backlog?: number, listeningListener?: () => void): this;
|
listen(port?: number, hostname?: string, backlog?: number, listeningListener?: () => void): this;
|
||||||
listen(port?: number, hostname?: string, listeningListener?: () => void): this;
|
listen(port?: number, hostname?: string, listeningListener?: () => void): this;
|
||||||
listen(port?: number, backlog?: number, listeningListener?: () => void): this;
|
listen(port?: number, backlog?: number, listeningListener?: () => void): this;
|
||||||
@@ -445,79 +191,15 @@ declare module 'net' {
|
|||||||
listen(options: ListenOptions, listeningListener?: () => void): this;
|
listen(options: ListenOptions, listeningListener?: () => void): this;
|
||||||
listen(handle: any, backlog?: number, listeningListener?: () => void): this;
|
listen(handle: any, backlog?: number, listeningListener?: () => void): this;
|
||||||
listen(handle: any, listeningListener?: () => void): this;
|
listen(handle: any, listeningListener?: () => void): this;
|
||||||
/**
|
|
||||||
* Stops the server from accepting new connections and keeps existing
|
|
||||||
* connections. This function is asynchronous, the server is finally closed
|
|
||||||
* when all connections are ended and the server emits a `'close'` event.
|
|
||||||
* The optional `callback` will be called once the `'close'` event occurs. Unlike
|
|
||||||
* that event, it will be called with an `Error` as its only argument if the server
|
|
||||||
* was not open when it was closed.
|
|
||||||
* @since v0.1.90
|
|
||||||
* @param callback Called when the server is closed.
|
|
||||||
*/
|
|
||||||
close(callback?: (err?: Error) => void): this;
|
close(callback?: (err?: Error) => void): this;
|
||||||
/**
|
|
||||||
* Returns the bound `address`, the address `family` name, and `port` of the server
|
|
||||||
* as reported by the operating system if listening on an IP socket
|
|
||||||
* (useful to find which port was assigned when getting an OS-assigned address):`{ port: 12346, family: 'IPv4', address: '127.0.0.1' }`.
|
|
||||||
*
|
|
||||||
* For a server listening on a pipe or Unix domain socket, the name is returned
|
|
||||||
* as a string.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const server = net.createServer((socket) => {
|
|
||||||
* socket.end('goodbye\n');
|
|
||||||
* }).on('error', (err) => {
|
|
||||||
* // Handle errors here.
|
|
||||||
* throw err;
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* // Grab an arbitrary unused port.
|
|
||||||
* server.listen(() => {
|
|
||||||
* console.log('opened server on', server.address());
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* `server.address()` returns `null` before the `'listening'` event has been
|
|
||||||
* emitted or after calling `server.close()`.
|
|
||||||
* @since v0.1.90
|
|
||||||
*/
|
|
||||||
address(): AddressInfo | string | null;
|
address(): AddressInfo | string | null;
|
||||||
/**
|
|
||||||
* Asynchronously get the number of concurrent connections on the server. Works
|
|
||||||
* when sockets were sent to forks.
|
|
||||||
*
|
|
||||||
* Callback should take two arguments `err` and `count`.
|
|
||||||
* @since v0.9.7
|
|
||||||
*/
|
|
||||||
getConnections(cb: (error: Error | null, count: number) => void): void;
|
getConnections(cb: (error: Error | null, count: number) => void): void;
|
||||||
/**
|
|
||||||
* Opposite of `unref()`, calling `ref()` on a previously `unref`ed server will_not_ let the program exit if it's the only server left (the default behavior).
|
|
||||||
* If the server is `ref`ed calling `ref()` again will have no effect.
|
|
||||||
* @since v0.9.1
|
|
||||||
*/
|
|
||||||
ref(): this;
|
ref(): this;
|
||||||
/**
|
|
||||||
* Calling `unref()` on a server will allow the program to exit if this is the only
|
|
||||||
* active server in the event system. If the server is already `unref`ed calling`unref()` again will have no effect.
|
|
||||||
* @since v0.9.1
|
|
||||||
*/
|
|
||||||
unref(): this;
|
unref(): this;
|
||||||
/**
|
|
||||||
* Set this property to reject connections when the server's connection count gets
|
|
||||||
* high.
|
|
||||||
*
|
|
||||||
* It is not recommended to use this option once a socket has been sent to a child
|
|
||||||
* with `child_process.fork()`.
|
|
||||||
* @since v0.2.0
|
|
||||||
*/
|
|
||||||
maxConnections: number;
|
maxConnections: number;
|
||||||
connections: number;
|
connections: number;
|
||||||
/**
|
|
||||||
* Indicates whether or not the server is listening for connections.
|
|
||||||
* @since v5.7.0
|
|
||||||
*/
|
|
||||||
listening: boolean;
|
listening: boolean;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* events.EventEmitter
|
* events.EventEmitter
|
||||||
* 1. close
|
* 1. close
|
||||||
@@ -526,259 +208,61 @@ declare module 'net' {
|
|||||||
* 4. listening
|
* 4. listening
|
||||||
*/
|
*/
|
||||||
addListener(event: string, listener: (...args: any[]) => void): this;
|
addListener(event: string, listener: (...args: any[]) => void): this;
|
||||||
addListener(event: 'close', listener: () => void): this;
|
addListener(event: "close", listener: () => void): this;
|
||||||
addListener(event: 'connection', listener: (socket: Socket) => void): this;
|
addListener(event: "connection", listener: (socket: Socket) => void): this;
|
||||||
addListener(event: 'error', listener: (err: Error) => void): this;
|
addListener(event: "error", listener: (err: Error) => void): this;
|
||||||
addListener(event: 'listening', listener: () => void): this;
|
addListener(event: "listening", listener: () => void): this;
|
||||||
|
|
||||||
emit(event: string | symbol, ...args: any[]): boolean;
|
emit(event: string | symbol, ...args: any[]): boolean;
|
||||||
emit(event: 'close'): boolean;
|
emit(event: "close"): boolean;
|
||||||
emit(event: 'connection', socket: Socket): boolean;
|
emit(event: "connection", socket: Socket): boolean;
|
||||||
emit(event: 'error', err: Error): boolean;
|
emit(event: "error", err: Error): boolean;
|
||||||
emit(event: 'listening'): boolean;
|
emit(event: "listening"): boolean;
|
||||||
|
|
||||||
on(event: string, listener: (...args: any[]) => void): this;
|
on(event: string, listener: (...args: any[]) => void): this;
|
||||||
on(event: 'close', listener: () => void): this;
|
on(event: "close", listener: () => void): this;
|
||||||
on(event: 'connection', listener: (socket: Socket) => void): this;
|
on(event: "connection", listener: (socket: Socket) => void): this;
|
||||||
on(event: 'error', listener: (err: Error) => void): this;
|
on(event: "error", listener: (err: Error) => void): this;
|
||||||
on(event: 'listening', listener: () => void): this;
|
on(event: "listening", listener: () => void): this;
|
||||||
|
|
||||||
once(event: string, listener: (...args: any[]) => void): this;
|
once(event: string, listener: (...args: any[]) => void): this;
|
||||||
once(event: 'close', listener: () => void): this;
|
once(event: "close", listener: () => void): this;
|
||||||
once(event: 'connection', listener: (socket: Socket) => void): this;
|
once(event: "connection", listener: (socket: Socket) => void): this;
|
||||||
once(event: 'error', listener: (err: Error) => void): this;
|
once(event: "error", listener: (err: Error) => void): this;
|
||||||
once(event: 'listening', listener: () => void): this;
|
once(event: "listening", listener: () => void): this;
|
||||||
|
|
||||||
prependListener(event: string, listener: (...args: any[]) => void): this;
|
prependListener(event: string, listener: (...args: any[]) => void): this;
|
||||||
prependListener(event: 'close', listener: () => void): this;
|
prependListener(event: "close", listener: () => void): this;
|
||||||
prependListener(event: 'connection', listener: (socket: Socket) => void): this;
|
prependListener(event: "connection", listener: (socket: Socket) => void): this;
|
||||||
prependListener(event: 'error', listener: (err: Error) => void): this;
|
prependListener(event: "error", listener: (err: Error) => void): this;
|
||||||
prependListener(event: 'listening', listener: () => void): this;
|
prependListener(event: "listening", listener: () => void): this;
|
||||||
|
|
||||||
prependOnceListener(event: string, listener: (...args: any[]) => void): this;
|
prependOnceListener(event: string, listener: (...args: any[]) => void): this;
|
||||||
prependOnceListener(event: 'close', listener: () => void): this;
|
prependOnceListener(event: "close", listener: () => void): this;
|
||||||
prependOnceListener(event: 'connection', listener: (socket: Socket) => void): this;
|
prependOnceListener(event: "connection", listener: (socket: Socket) => void): this;
|
||||||
prependOnceListener(event: 'error', listener: (err: Error) => void): this;
|
prependOnceListener(event: "error", listener: (err: Error) => void): this;
|
||||||
prependOnceListener(event: 'listening', listener: () => void): this;
|
prependOnceListener(event: "listening", listener: () => void): this;
|
||||||
}
|
|
||||||
type IPVersion = 'ipv4' | 'ipv6';
|
|
||||||
/**
|
|
||||||
* The `BlockList` object can be used with some network APIs to specify rules for
|
|
||||||
* disabling inbound or outbound access to specific IP addresses, IP ranges, or
|
|
||||||
* IP subnets.
|
|
||||||
* @since v15.0.0
|
|
||||||
*/
|
|
||||||
class BlockList {
|
|
||||||
/**
|
|
||||||
* Adds a rule to block the given IP address.
|
|
||||||
* @since v15.0.0
|
|
||||||
* @param address An IPv4 or IPv6 address.
|
|
||||||
* @param [type='ipv4'] Either `'ipv4'` or `'ipv6'`.
|
|
||||||
*/
|
|
||||||
addAddress(address: string, type?: IPVersion): void;
|
|
||||||
addAddress(address: SocketAddress): void;
|
|
||||||
/**
|
|
||||||
* Adds a rule to block a range of IP addresses from `start` (inclusive) to`end` (inclusive).
|
|
||||||
* @since v15.0.0
|
|
||||||
* @param start The starting IPv4 or IPv6 address in the range.
|
|
||||||
* @param end The ending IPv4 or IPv6 address in the range.
|
|
||||||
* @param [type='ipv4'] Either `'ipv4'` or `'ipv6'`.
|
|
||||||
*/
|
|
||||||
addRange(start: string, end: string, type?: IPVersion): void;
|
|
||||||
addRange(start: SocketAddress, end: SocketAddress): void;
|
|
||||||
/**
|
|
||||||
* Adds a rule to block a range of IP addresses specified as a subnet mask.
|
|
||||||
* @since v15.0.0
|
|
||||||
* @param net The network IPv4 or IPv6 address.
|
|
||||||
* @param prefix The number of CIDR prefix bits. For IPv4, this must be a value between `0` and `32`. For IPv6, this must be between `0` and `128`.
|
|
||||||
* @param [type='ipv4'] Either `'ipv4'` or `'ipv6'`.
|
|
||||||
*/
|
|
||||||
addSubnet(net: SocketAddress, prefix: number): void;
|
|
||||||
addSubnet(net: string, prefix: number, type?: IPVersion): void;
|
|
||||||
/**
|
|
||||||
* Returns `true` if the given IP address matches any of the rules added to the`BlockList`.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const blockList = new net.BlockList();
|
|
||||||
* blockList.addAddress('123.123.123.123');
|
|
||||||
* blockList.addRange('10.0.0.1', '10.0.0.10');
|
|
||||||
* blockList.addSubnet('8592:757c:efae:4e45::', 64, 'ipv6');
|
|
||||||
*
|
|
||||||
* console.log(blockList.check('123.123.123.123')); // Prints: true
|
|
||||||
* console.log(blockList.check('10.0.0.3')); // Prints: true
|
|
||||||
* console.log(blockList.check('222.111.111.222')); // Prints: false
|
|
||||||
*
|
|
||||||
* // IPv6 notation for IPv4 addresses works:
|
|
||||||
* console.log(blockList.check('::ffff:7b7b:7b7b', 'ipv6')); // Prints: true
|
|
||||||
* console.log(blockList.check('::ffff:123.123.123.123', 'ipv6')); // Prints: true
|
|
||||||
* ```
|
|
||||||
* @since v15.0.0
|
|
||||||
* @param address The IP address to check
|
|
||||||
* @param [type='ipv4'] Either `'ipv4'` or `'ipv6'`.
|
|
||||||
*/
|
|
||||||
check(address: SocketAddress): boolean;
|
|
||||||
check(address: string, type?: IPVersion): boolean;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
interface TcpNetConnectOpts extends TcpSocketConnectOpts, SocketConstructorOpts {
|
interface TcpNetConnectOpts extends TcpSocketConnectOpts, SocketConstructorOpts {
|
||||||
timeout?: number | undefined;
|
timeout?: number;
|
||||||
}
|
}
|
||||||
|
|
||||||
interface IpcNetConnectOpts extends IpcSocketConnectOpts, SocketConstructorOpts {
|
interface IpcNetConnectOpts extends IpcSocketConnectOpts, SocketConstructorOpts {
|
||||||
timeout?: number | undefined;
|
timeout?: number;
|
||||||
}
|
}
|
||||||
|
|
||||||
type NetConnectOpts = TcpNetConnectOpts | IpcNetConnectOpts;
|
type NetConnectOpts = TcpNetConnectOpts | IpcNetConnectOpts;
|
||||||
/**
|
|
||||||
* Creates a new TCP or `IPC` server.
|
|
||||||
*
|
|
||||||
* If `allowHalfOpen` is set to `true`, when the other end of the socket
|
|
||||||
* signals the end of transmission, the server will only send back the end of
|
|
||||||
* transmission when `socket.end()` is explicitly called. For example, in the
|
|
||||||
* context of TCP, when a FIN packed is received, a FIN packed is sent
|
|
||||||
* back only when `socket.end()` is explicitly called. Until then the
|
|
||||||
* connection is half-closed (non-readable but still writable). See `'end'` event and [RFC 1122](https://tools.ietf.org/html/rfc1122) (section 4.2.2.13) for more information.
|
|
||||||
*
|
|
||||||
* If `pauseOnConnect` is set to `true`, then the socket associated with each
|
|
||||||
* incoming connection will be paused, and no data will be read from its handle.
|
|
||||||
* This allows connections to be passed between processes without any data being
|
|
||||||
* read by the original process. To begin reading data from a paused socket, call `socket.resume()`.
|
|
||||||
*
|
|
||||||
* The server can be a TCP server or an `IPC` server, depending on what it `listen()` to.
|
|
||||||
*
|
|
||||||
* Here is an example of an TCP echo server which listens for connections
|
|
||||||
* on port 8124:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const net = require('net');
|
|
||||||
* const server = net.createServer((c) => {
|
|
||||||
* // 'connection' listener.
|
|
||||||
* console.log('client connected');
|
|
||||||
* c.on('end', () => {
|
|
||||||
* console.log('client disconnected');
|
|
||||||
* });
|
|
||||||
* c.write('hello\r\n');
|
|
||||||
* c.pipe(c);
|
|
||||||
* });
|
|
||||||
* server.on('error', (err) => {
|
|
||||||
* throw err;
|
|
||||||
* });
|
|
||||||
* server.listen(8124, () => {
|
|
||||||
* console.log('server bound');
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Test this by using `telnet`:
|
|
||||||
*
|
|
||||||
* ```console
|
|
||||||
* $ telnet localhost 8124
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* To listen on the socket `/tmp/echo.sock`:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* server.listen('/tmp/echo.sock', () => {
|
|
||||||
* console.log('server bound');
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Use `nc` to connect to a Unix domain socket server:
|
|
||||||
*
|
|
||||||
* ```console
|
|
||||||
* $ nc -U /tmp/echo.sock
|
|
||||||
* ```
|
|
||||||
* @since v0.5.0
|
|
||||||
* @param connectionListener Automatically set as a listener for the {@link 'connection'} event.
|
|
||||||
*/
|
|
||||||
function createServer(connectionListener?: (socket: Socket) => void): Server;
|
function createServer(connectionListener?: (socket: Socket) => void): Server;
|
||||||
function createServer(options?: ServerOpts, connectionListener?: (socket: Socket) => void): Server;
|
function createServer(options?: { allowHalfOpen?: boolean, pauseOnConnect?: boolean }, connectionListener?: (socket: Socket) => void): Server;
|
||||||
/**
|
|
||||||
* Aliases to {@link createConnection}.
|
|
||||||
*
|
|
||||||
* Possible signatures:
|
|
||||||
*
|
|
||||||
* * {@link connect}
|
|
||||||
* * {@link connect} for `IPC` connections.
|
|
||||||
* * {@link connect} for TCP connections.
|
|
||||||
*/
|
|
||||||
function connect(options: NetConnectOpts, connectionListener?: () => void): Socket;
|
function connect(options: NetConnectOpts, connectionListener?: () => void): Socket;
|
||||||
function connect(port: number, host?: string, connectionListener?: () => void): Socket;
|
function connect(port: number, host?: string, connectionListener?: () => void): Socket;
|
||||||
function connect(path: string, connectionListener?: () => void): Socket;
|
function connect(path: string, connectionListener?: () => void): Socket;
|
||||||
/**
|
|
||||||
* A factory function, which creates a new {@link Socket},
|
|
||||||
* immediately initiates connection with `socket.connect()`,
|
|
||||||
* then returns the `net.Socket` that starts the connection.
|
|
||||||
*
|
|
||||||
* When the connection is established, a `'connect'` event will be emitted
|
|
||||||
* on the returned socket. The last parameter `connectListener`, if supplied,
|
|
||||||
* will be added as a listener for the `'connect'` event **once**.
|
|
||||||
*
|
|
||||||
* Possible signatures:
|
|
||||||
*
|
|
||||||
* * {@link createConnection}
|
|
||||||
* * {@link createConnection} for `IPC` connections.
|
|
||||||
* * {@link createConnection} for TCP connections.
|
|
||||||
*
|
|
||||||
* The {@link connect} function is an alias to this function.
|
|
||||||
*/
|
|
||||||
function createConnection(options: NetConnectOpts, connectionListener?: () => void): Socket;
|
function createConnection(options: NetConnectOpts, connectionListener?: () => void): Socket;
|
||||||
function createConnection(port: number, host?: string, connectionListener?: () => void): Socket;
|
function createConnection(port: number, host?: string, connectionListener?: () => void): Socket;
|
||||||
function createConnection(path: string, connectionListener?: () => void): Socket;
|
function createConnection(path: string, connectionListener?: () => void): Socket;
|
||||||
/**
|
|
||||||
* Tests if input is an IP address. Returns `0` for invalid strings,
|
|
||||||
* returns `4` for IP version 4 addresses, and returns `6` for IP version 6
|
|
||||||
* addresses.
|
|
||||||
* @since v0.3.0
|
|
||||||
*/
|
|
||||||
function isIP(input: string): number;
|
function isIP(input: string): number;
|
||||||
/**
|
|
||||||
* Returns `true` if input is a version 4 IP address, otherwise returns `false`.
|
|
||||||
* @since v0.3.0
|
|
||||||
*/
|
|
||||||
function isIPv4(input: string): boolean;
|
function isIPv4(input: string): boolean;
|
||||||
/**
|
|
||||||
* Returns `true` if input is a version 6 IP address, otherwise returns `false`.
|
|
||||||
* @since v0.3.0
|
|
||||||
*/
|
|
||||||
function isIPv6(input: string): boolean;
|
function isIPv6(input: string): boolean;
|
||||||
interface SocketAddressInitOptions {
|
|
||||||
/**
|
|
||||||
* The network address as either an IPv4 or IPv6 string.
|
|
||||||
* @default 127.0.0.1
|
|
||||||
*/
|
|
||||||
address?: string | undefined;
|
|
||||||
/**
|
|
||||||
* @default `'ipv4'`
|
|
||||||
*/
|
|
||||||
family?: IPVersion | undefined;
|
|
||||||
/**
|
|
||||||
* An IPv6 flow-label used only if `family` is `'ipv6'`.
|
|
||||||
* @default 0
|
|
||||||
*/
|
|
||||||
flowlabel?: number | undefined;
|
|
||||||
/**
|
|
||||||
* An IP port.
|
|
||||||
* @default 0
|
|
||||||
*/
|
|
||||||
port?: number | undefined;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* @since v15.14.0
|
|
||||||
*/
|
|
||||||
class SocketAddress {
|
|
||||||
constructor(options: SocketAddressInitOptions);
|
|
||||||
/**
|
|
||||||
* Either \`'ipv4'\` or \`'ipv6'\`.
|
|
||||||
* @since v15.14.0
|
|
||||||
*/
|
|
||||||
readonly address: string;
|
|
||||||
/**
|
|
||||||
* Either \`'ipv4'\` or \`'ipv6'\`.
|
|
||||||
* @since v15.14.0
|
|
||||||
*/
|
|
||||||
readonly family: IPVersion;
|
|
||||||
/**
|
|
||||||
* @since v15.14.0
|
|
||||||
*/
|
|
||||||
readonly port: number;
|
|
||||||
/**
|
|
||||||
* @since v15.14.0
|
|
||||||
*/
|
|
||||||
readonly flowlabel: number;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
declare module 'node:net' {
|
|
||||||
export * from 'net';
|
|
||||||
}
|
}
|
||||||
|
|||||||
612
node_modules/@types/node/os.d.ts
generated
vendored
Executable file → Normal file
612
node_modules/@types/node/os.d.ts
generated
vendored
Executable file → Normal file
@@ -1,13 +1,4 @@
|
|||||||
/**
|
declare module "os" {
|
||||||
* The `os` module provides operating system-related utility methods and
|
|
||||||
* properties. It can be accessed using:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const os = require('os');
|
|
||||||
* ```
|
|
||||||
* @see [source](https://github.com/nodejs/node/blob/v16.9.0/lib/os.js)
|
|
||||||
*/
|
|
||||||
declare module 'os' {
|
|
||||||
interface CpuInfo {
|
interface CpuInfo {
|
||||||
model: string;
|
model: string;
|
||||||
speed: number;
|
speed: number;
|
||||||
@@ -19,6 +10,7 @@ declare module 'os' {
|
|||||||
irq: number;
|
irq: number;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
interface NetworkInterfaceBase {
|
interface NetworkInterfaceBase {
|
||||||
address: string;
|
address: string;
|
||||||
netmask: string;
|
netmask: string;
|
||||||
@@ -26,13 +18,16 @@ declare module 'os' {
|
|||||||
internal: boolean;
|
internal: boolean;
|
||||||
cidr: string | null;
|
cidr: string | null;
|
||||||
}
|
}
|
||||||
|
|
||||||
interface NetworkInterfaceInfoIPv4 extends NetworkInterfaceBase {
|
interface NetworkInterfaceInfoIPv4 extends NetworkInterfaceBase {
|
||||||
family: 'IPv4';
|
family: "IPv4";
|
||||||
}
|
}
|
||||||
|
|
||||||
interface NetworkInterfaceInfoIPv6 extends NetworkInterfaceBase {
|
interface NetworkInterfaceInfoIPv6 extends NetworkInterfaceBase {
|
||||||
family: 'IPv6';
|
family: "IPv6";
|
||||||
scopeid: number;
|
scopeid: number;
|
||||||
}
|
}
|
||||||
|
|
||||||
interface UserInfo<T> {
|
interface UserInfo<T> {
|
||||||
username: T;
|
username: T;
|
||||||
uid: number;
|
uid: number;
|
||||||
@@ -40,416 +35,229 @@ declare module 'os' {
|
|||||||
shell: T;
|
shell: T;
|
||||||
homedir: T;
|
homedir: T;
|
||||||
}
|
}
|
||||||
|
|
||||||
type NetworkInterfaceInfo = NetworkInterfaceInfoIPv4 | NetworkInterfaceInfoIPv6;
|
type NetworkInterfaceInfo = NetworkInterfaceInfoIPv4 | NetworkInterfaceInfoIPv6;
|
||||||
/**
|
|
||||||
* Returns the host name of the operating system as a string.
|
|
||||||
* @since v0.3.3
|
|
||||||
*/
|
|
||||||
function hostname(): string;
|
function hostname(): string;
|
||||||
/**
|
|
||||||
* Returns an array containing the 1, 5, and 15 minute load averages.
|
|
||||||
*
|
|
||||||
* The load average is a measure of system activity calculated by the operating
|
|
||||||
* system and expressed as a fractional number.
|
|
||||||
*
|
|
||||||
* The load average is a Unix-specific concept. On Windows, the return value is
|
|
||||||
* always `[0, 0, 0]`.
|
|
||||||
* @since v0.3.3
|
|
||||||
*/
|
|
||||||
function loadavg(): number[];
|
function loadavg(): number[];
|
||||||
/**
|
|
||||||
* Returns the system uptime in number of seconds.
|
|
||||||
* @since v0.3.3
|
|
||||||
*/
|
|
||||||
function uptime(): number;
|
function uptime(): number;
|
||||||
/**
|
|
||||||
* Returns the amount of free system memory in bytes as an integer.
|
|
||||||
* @since v0.3.3
|
|
||||||
*/
|
|
||||||
function freemem(): number;
|
function freemem(): number;
|
||||||
/**
|
|
||||||
* Returns the total amount of system memory in bytes as an integer.
|
|
||||||
* @since v0.3.3
|
|
||||||
*/
|
|
||||||
function totalmem(): number;
|
function totalmem(): number;
|
||||||
/**
|
|
||||||
* Returns an array of objects containing information about each logical CPU core.
|
|
||||||
*
|
|
||||||
* The properties included on each object include:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* [
|
|
||||||
* {
|
|
||||||
* model: 'Intel(R) Core(TM) i7 CPU 860 @ 2.80GHz',
|
|
||||||
* speed: 2926,
|
|
||||||
* times: {
|
|
||||||
* user: 252020,
|
|
||||||
* nice: 0,
|
|
||||||
* sys: 30340,
|
|
||||||
* idle: 1070356870,
|
|
||||||
* irq: 0
|
|
||||||
* }
|
|
||||||
* },
|
|
||||||
* {
|
|
||||||
* model: 'Intel(R) Core(TM) i7 CPU 860 @ 2.80GHz',
|
|
||||||
* speed: 2926,
|
|
||||||
* times: {
|
|
||||||
* user: 306960,
|
|
||||||
* nice: 0,
|
|
||||||
* sys: 26980,
|
|
||||||
* idle: 1071569080,
|
|
||||||
* irq: 0
|
|
||||||
* }
|
|
||||||
* },
|
|
||||||
* {
|
|
||||||
* model: 'Intel(R) Core(TM) i7 CPU 860 @ 2.80GHz',
|
|
||||||
* speed: 2926,
|
|
||||||
* times: {
|
|
||||||
* user: 248450,
|
|
||||||
* nice: 0,
|
|
||||||
* sys: 21750,
|
|
||||||
* idle: 1070919370,
|
|
||||||
* irq: 0
|
|
||||||
* }
|
|
||||||
* },
|
|
||||||
* {
|
|
||||||
* model: 'Intel(R) Core(TM) i7 CPU 860 @ 2.80GHz',
|
|
||||||
* speed: 2926,
|
|
||||||
* times: {
|
|
||||||
* user: 256880,
|
|
||||||
* nice: 0,
|
|
||||||
* sys: 19430,
|
|
||||||
* idle: 1070905480,
|
|
||||||
* irq: 20
|
|
||||||
* }
|
|
||||||
* },
|
|
||||||
* ]
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* `nice` values are POSIX-only. On Windows, the `nice` values of all processors
|
|
||||||
* are always 0.
|
|
||||||
* @since v0.3.3
|
|
||||||
*/
|
|
||||||
function cpus(): CpuInfo[];
|
function cpus(): CpuInfo[];
|
||||||
/**
|
|
||||||
* Returns the operating system name as returned by [`uname(3)`](https://linux.die.net/man/3/uname). For example, it
|
|
||||||
* returns `'Linux'` on Linux, `'Darwin'` on macOS, and `'Windows_NT'` on Windows.
|
|
||||||
*
|
|
||||||
* See [https://en.wikipedia.org/wiki/Uname#Examples](https://en.wikipedia.org/wiki/Uname#Examples) for additional information
|
|
||||||
* about the output of running [`uname(3)`](https://linux.die.net/man/3/uname) on various operating systems.
|
|
||||||
* @since v0.3.3
|
|
||||||
*/
|
|
||||||
function type(): string;
|
function type(): string;
|
||||||
/**
|
|
||||||
* Returns the operating system as a string.
|
|
||||||
*
|
|
||||||
* On POSIX systems, the operating system release is determined by calling [`uname(3)`](https://linux.die.net/man/3/uname). On Windows, `GetVersionExW()` is used. See
|
|
||||||
* [https://en.wikipedia.org/wiki/Uname#Examples](https://en.wikipedia.org/wiki/Uname#Examples) for more information.
|
|
||||||
* @since v0.3.3
|
|
||||||
*/
|
|
||||||
function release(): string;
|
function release(): string;
|
||||||
/**
|
function networkInterfaces(): { [index: string]: NetworkInterfaceInfo[] };
|
||||||
* Returns an object containing network interfaces that have been assigned a
|
|
||||||
* network address.
|
|
||||||
*
|
|
||||||
* Each key on the returned object identifies a network interface. The associated
|
|
||||||
* value is an array of objects that each describe an assigned network address.
|
|
||||||
*
|
|
||||||
* The properties available on the assigned network address object include:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* {
|
|
||||||
* lo: [
|
|
||||||
* {
|
|
||||||
* address: '127.0.0.1',
|
|
||||||
* netmask: '255.0.0.0',
|
|
||||||
* family: 'IPv4',
|
|
||||||
* mac: '00:00:00:00:00:00',
|
|
||||||
* internal: true,
|
|
||||||
* cidr: '127.0.0.1/8'
|
|
||||||
* },
|
|
||||||
* {
|
|
||||||
* address: '::1',
|
|
||||||
* netmask: 'ffff:ffff:ffff:ffff:ffff:ffff:ffff:ffff',
|
|
||||||
* family: 'IPv6',
|
|
||||||
* mac: '00:00:00:00:00:00',
|
|
||||||
* scopeid: 0,
|
|
||||||
* internal: true,
|
|
||||||
* cidr: '::1/128'
|
|
||||||
* }
|
|
||||||
* ],
|
|
||||||
* eth0: [
|
|
||||||
* {
|
|
||||||
* address: '192.168.1.108',
|
|
||||||
* netmask: '255.255.255.0',
|
|
||||||
* family: 'IPv4',
|
|
||||||
* mac: '01:02:03:0a:0b:0c',
|
|
||||||
* internal: false,
|
|
||||||
* cidr: '192.168.1.108/24'
|
|
||||||
* },
|
|
||||||
* {
|
|
||||||
* address: 'fe80::a00:27ff:fe4e:66a1',
|
|
||||||
* netmask: 'ffff:ffff:ffff:ffff::',
|
|
||||||
* family: 'IPv6',
|
|
||||||
* mac: '01:02:03:0a:0b:0c',
|
|
||||||
* scopeid: 1,
|
|
||||||
* internal: false,
|
|
||||||
* cidr: 'fe80::a00:27ff:fe4e:66a1/64'
|
|
||||||
* }
|
|
||||||
* ]
|
|
||||||
* }
|
|
||||||
* ```
|
|
||||||
* @since v0.6.0
|
|
||||||
*/
|
|
||||||
function networkInterfaces(): NodeJS.Dict<NetworkInterfaceInfo[]>;
|
|
||||||
/**
|
|
||||||
* Returns the string path of the current user's home directory.
|
|
||||||
*
|
|
||||||
* On POSIX, it uses the `$HOME` environment variable if defined. Otherwise it
|
|
||||||
* uses the [effective UID](https://en.wikipedia.org/wiki/User_identifier#Effective_user_ID) to look up the user's home directory.
|
|
||||||
*
|
|
||||||
* On Windows, it uses the `USERPROFILE` environment variable if defined.
|
|
||||||
* Otherwise it uses the path to the profile directory of the current user.
|
|
||||||
* @since v2.3.0
|
|
||||||
*/
|
|
||||||
function homedir(): string;
|
function homedir(): string;
|
||||||
/**
|
|
||||||
* Returns information about the currently effective user. On POSIX platforms,
|
|
||||||
* this is typically a subset of the password file. The returned object includes
|
|
||||||
* the `username`, `uid`, `gid`, `shell`, and `homedir`. On Windows, the `uid` and`gid` fields are `-1`, and `shell` is `null`.
|
|
||||||
*
|
|
||||||
* The value of `homedir` returned by `os.userInfo()` is provided by the operating
|
|
||||||
* system. This differs from the result of `os.homedir()`, which queries
|
|
||||||
* environment variables for the home directory before falling back to the
|
|
||||||
* operating system response.
|
|
||||||
*
|
|
||||||
* Throws a `SystemError` if a user has no `username` or `homedir`.
|
|
||||||
* @since v6.0.0
|
|
||||||
*/
|
|
||||||
function userInfo(options: { encoding: 'buffer' }): UserInfo<Buffer>;
|
function userInfo(options: { encoding: 'buffer' }): UserInfo<Buffer>;
|
||||||
function userInfo(options?: { encoding: BufferEncoding }): UserInfo<string>;
|
function userInfo(options?: { encoding: string }): UserInfo<string>;
|
||||||
type SignalConstants = {
|
const constants: {
|
||||||
[key in NodeJS.Signals]: number;
|
UV_UDP_REUSEADDR: number;
|
||||||
|
// signals: { [key in NodeJS.Signals]: number; }; @todo: change after migration to typescript 2.1
|
||||||
|
signals: {
|
||||||
|
SIGHUP: number;
|
||||||
|
SIGINT: number;
|
||||||
|
SIGQUIT: number;
|
||||||
|
SIGILL: number;
|
||||||
|
SIGTRAP: number;
|
||||||
|
SIGABRT: number;
|
||||||
|
SIGIOT: number;
|
||||||
|
SIGBUS: number;
|
||||||
|
SIGFPE: number;
|
||||||
|
SIGKILL: number;
|
||||||
|
SIGUSR1: number;
|
||||||
|
SIGSEGV: number;
|
||||||
|
SIGUSR2: number;
|
||||||
|
SIGPIPE: number;
|
||||||
|
SIGALRM: number;
|
||||||
|
SIGTERM: number;
|
||||||
|
SIGCHLD: number;
|
||||||
|
SIGSTKFLT: number;
|
||||||
|
SIGCONT: number;
|
||||||
|
SIGSTOP: number;
|
||||||
|
SIGTSTP: number;
|
||||||
|
SIGBREAK: number;
|
||||||
|
SIGTTIN: number;
|
||||||
|
SIGTTOU: number;
|
||||||
|
SIGURG: number;
|
||||||
|
SIGXCPU: number;
|
||||||
|
SIGXFSZ: number;
|
||||||
|
SIGVTALRM: number;
|
||||||
|
SIGPROF: number;
|
||||||
|
SIGWINCH: number;
|
||||||
|
SIGIO: number;
|
||||||
|
SIGPOLL: number;
|
||||||
|
SIGLOST: number;
|
||||||
|
SIGPWR: number;
|
||||||
|
SIGINFO: number;
|
||||||
|
SIGSYS: number;
|
||||||
|
SIGUNUSED: number;
|
||||||
|
};
|
||||||
|
errno: {
|
||||||
|
E2BIG: number;
|
||||||
|
EACCES: number;
|
||||||
|
EADDRINUSE: number;
|
||||||
|
EADDRNOTAVAIL: number;
|
||||||
|
EAFNOSUPPORT: number;
|
||||||
|
EAGAIN: number;
|
||||||
|
EALREADY: number;
|
||||||
|
EBADF: number;
|
||||||
|
EBADMSG: number;
|
||||||
|
EBUSY: number;
|
||||||
|
ECANCELED: number;
|
||||||
|
ECHILD: number;
|
||||||
|
ECONNABORTED: number;
|
||||||
|
ECONNREFUSED: number;
|
||||||
|
ECONNRESET: number;
|
||||||
|
EDEADLK: number;
|
||||||
|
EDESTADDRREQ: number;
|
||||||
|
EDOM: number;
|
||||||
|
EDQUOT: number;
|
||||||
|
EEXIST: number;
|
||||||
|
EFAULT: number;
|
||||||
|
EFBIG: number;
|
||||||
|
EHOSTUNREACH: number;
|
||||||
|
EIDRM: number;
|
||||||
|
EILSEQ: number;
|
||||||
|
EINPROGRESS: number;
|
||||||
|
EINTR: number;
|
||||||
|
EINVAL: number;
|
||||||
|
EIO: number;
|
||||||
|
EISCONN: number;
|
||||||
|
EISDIR: number;
|
||||||
|
ELOOP: number;
|
||||||
|
EMFILE: number;
|
||||||
|
EMLINK: number;
|
||||||
|
EMSGSIZE: number;
|
||||||
|
EMULTIHOP: number;
|
||||||
|
ENAMETOOLONG: number;
|
||||||
|
ENETDOWN: number;
|
||||||
|
ENETRESET: number;
|
||||||
|
ENETUNREACH: number;
|
||||||
|
ENFILE: number;
|
||||||
|
ENOBUFS: number;
|
||||||
|
ENODATA: number;
|
||||||
|
ENODEV: number;
|
||||||
|
ENOENT: number;
|
||||||
|
ENOEXEC: number;
|
||||||
|
ENOLCK: number;
|
||||||
|
ENOLINK: number;
|
||||||
|
ENOMEM: number;
|
||||||
|
ENOMSG: number;
|
||||||
|
ENOPROTOOPT: number;
|
||||||
|
ENOSPC: number;
|
||||||
|
ENOSR: number;
|
||||||
|
ENOSTR: number;
|
||||||
|
ENOSYS: number;
|
||||||
|
ENOTCONN: number;
|
||||||
|
ENOTDIR: number;
|
||||||
|
ENOTEMPTY: number;
|
||||||
|
ENOTSOCK: number;
|
||||||
|
ENOTSUP: number;
|
||||||
|
ENOTTY: number;
|
||||||
|
ENXIO: number;
|
||||||
|
EOPNOTSUPP: number;
|
||||||
|
EOVERFLOW: number;
|
||||||
|
EPERM: number;
|
||||||
|
EPIPE: number;
|
||||||
|
EPROTO: number;
|
||||||
|
EPROTONOSUPPORT: number;
|
||||||
|
EPROTOTYPE: number;
|
||||||
|
ERANGE: number;
|
||||||
|
EROFS: number;
|
||||||
|
ESPIPE: number;
|
||||||
|
ESRCH: number;
|
||||||
|
ESTALE: number;
|
||||||
|
ETIME: number;
|
||||||
|
ETIMEDOUT: number;
|
||||||
|
ETXTBSY: number;
|
||||||
|
EWOULDBLOCK: number;
|
||||||
|
EXDEV: number;
|
||||||
|
WSAEINTR: number;
|
||||||
|
WSAEBADF: number;
|
||||||
|
WSAEACCES: number;
|
||||||
|
WSAEFAULT: number;
|
||||||
|
WSAEINVAL: number;
|
||||||
|
WSAEMFILE: number;
|
||||||
|
WSAEWOULDBLOCK: number;
|
||||||
|
WSAEINPROGRESS: number;
|
||||||
|
WSAEALREADY: number;
|
||||||
|
WSAENOTSOCK: number;
|
||||||
|
WSAEDESTADDRREQ: number;
|
||||||
|
WSAEMSGSIZE: number;
|
||||||
|
WSAEPROTOTYPE: number;
|
||||||
|
WSAENOPROTOOPT: number;
|
||||||
|
WSAEPROTONOSUPPORT: number;
|
||||||
|
WSAESOCKTNOSUPPORT: number;
|
||||||
|
WSAEOPNOTSUPP: number;
|
||||||
|
WSAEPFNOSUPPORT: number;
|
||||||
|
WSAEAFNOSUPPORT: number;
|
||||||
|
WSAEADDRINUSE: number;
|
||||||
|
WSAEADDRNOTAVAIL: number;
|
||||||
|
WSAENETDOWN: number;
|
||||||
|
WSAENETUNREACH: number;
|
||||||
|
WSAENETRESET: number;
|
||||||
|
WSAECONNABORTED: number;
|
||||||
|
WSAECONNRESET: number;
|
||||||
|
WSAENOBUFS: number;
|
||||||
|
WSAEISCONN: number;
|
||||||
|
WSAENOTCONN: number;
|
||||||
|
WSAESHUTDOWN: number;
|
||||||
|
WSAETOOMANYREFS: number;
|
||||||
|
WSAETIMEDOUT: number;
|
||||||
|
WSAECONNREFUSED: number;
|
||||||
|
WSAELOOP: number;
|
||||||
|
WSAENAMETOOLONG: number;
|
||||||
|
WSAEHOSTDOWN: number;
|
||||||
|
WSAEHOSTUNREACH: number;
|
||||||
|
WSAENOTEMPTY: number;
|
||||||
|
WSAEPROCLIM: number;
|
||||||
|
WSAEUSERS: number;
|
||||||
|
WSAEDQUOT: number;
|
||||||
|
WSAESTALE: number;
|
||||||
|
WSAEREMOTE: number;
|
||||||
|
WSASYSNOTREADY: number;
|
||||||
|
WSAVERNOTSUPPORTED: number;
|
||||||
|
WSANOTINITIALISED: number;
|
||||||
|
WSAEDISCON: number;
|
||||||
|
WSAENOMORE: number;
|
||||||
|
WSAECANCELLED: number;
|
||||||
|
WSAEINVALIDPROCTABLE: number;
|
||||||
|
WSAEINVALIDPROVIDER: number;
|
||||||
|
WSAEPROVIDERFAILEDINIT: number;
|
||||||
|
WSASYSCALLFAILURE: number;
|
||||||
|
WSASERVICE_NOT_FOUND: number;
|
||||||
|
WSATYPE_NOT_FOUND: number;
|
||||||
|
WSA_E_NO_MORE: number;
|
||||||
|
WSA_E_CANCELLED: number;
|
||||||
|
WSAEREFUSED: number;
|
||||||
|
};
|
||||||
|
priority: {
|
||||||
|
PRIORITY_LOW: number;
|
||||||
|
PRIORITY_BELOW_NORMAL: number;
|
||||||
|
PRIORITY_NORMAL: number;
|
||||||
|
PRIORITY_ABOVE_NORMAL: number;
|
||||||
|
PRIORITY_HIGH: number;
|
||||||
|
PRIORITY_HIGHEST: number;
|
||||||
|
}
|
||||||
};
|
};
|
||||||
namespace constants {
|
|
||||||
const UV_UDP_REUSEADDR: number;
|
|
||||||
namespace signals {}
|
|
||||||
const signals: SignalConstants;
|
|
||||||
namespace errno {
|
|
||||||
const E2BIG: number;
|
|
||||||
const EACCES: number;
|
|
||||||
const EADDRINUSE: number;
|
|
||||||
const EADDRNOTAVAIL: number;
|
|
||||||
const EAFNOSUPPORT: number;
|
|
||||||
const EAGAIN: number;
|
|
||||||
const EALREADY: number;
|
|
||||||
const EBADF: number;
|
|
||||||
const EBADMSG: number;
|
|
||||||
const EBUSY: number;
|
|
||||||
const ECANCELED: number;
|
|
||||||
const ECHILD: number;
|
|
||||||
const ECONNABORTED: number;
|
|
||||||
const ECONNREFUSED: number;
|
|
||||||
const ECONNRESET: number;
|
|
||||||
const EDEADLK: number;
|
|
||||||
const EDESTADDRREQ: number;
|
|
||||||
const EDOM: number;
|
|
||||||
const EDQUOT: number;
|
|
||||||
const EEXIST: number;
|
|
||||||
const EFAULT: number;
|
|
||||||
const EFBIG: number;
|
|
||||||
const EHOSTUNREACH: number;
|
|
||||||
const EIDRM: number;
|
|
||||||
const EILSEQ: number;
|
|
||||||
const EINPROGRESS: number;
|
|
||||||
const EINTR: number;
|
|
||||||
const EINVAL: number;
|
|
||||||
const EIO: number;
|
|
||||||
const EISCONN: number;
|
|
||||||
const EISDIR: number;
|
|
||||||
const ELOOP: number;
|
|
||||||
const EMFILE: number;
|
|
||||||
const EMLINK: number;
|
|
||||||
const EMSGSIZE: number;
|
|
||||||
const EMULTIHOP: number;
|
|
||||||
const ENAMETOOLONG: number;
|
|
||||||
const ENETDOWN: number;
|
|
||||||
const ENETRESET: number;
|
|
||||||
const ENETUNREACH: number;
|
|
||||||
const ENFILE: number;
|
|
||||||
const ENOBUFS: number;
|
|
||||||
const ENODATA: number;
|
|
||||||
const ENODEV: number;
|
|
||||||
const ENOENT: number;
|
|
||||||
const ENOEXEC: number;
|
|
||||||
const ENOLCK: number;
|
|
||||||
const ENOLINK: number;
|
|
||||||
const ENOMEM: number;
|
|
||||||
const ENOMSG: number;
|
|
||||||
const ENOPROTOOPT: number;
|
|
||||||
const ENOSPC: number;
|
|
||||||
const ENOSR: number;
|
|
||||||
const ENOSTR: number;
|
|
||||||
const ENOSYS: number;
|
|
||||||
const ENOTCONN: number;
|
|
||||||
const ENOTDIR: number;
|
|
||||||
const ENOTEMPTY: number;
|
|
||||||
const ENOTSOCK: number;
|
|
||||||
const ENOTSUP: number;
|
|
||||||
const ENOTTY: number;
|
|
||||||
const ENXIO: number;
|
|
||||||
const EOPNOTSUPP: number;
|
|
||||||
const EOVERFLOW: number;
|
|
||||||
const EPERM: number;
|
|
||||||
const EPIPE: number;
|
|
||||||
const EPROTO: number;
|
|
||||||
const EPROTONOSUPPORT: number;
|
|
||||||
const EPROTOTYPE: number;
|
|
||||||
const ERANGE: number;
|
|
||||||
const EROFS: number;
|
|
||||||
const ESPIPE: number;
|
|
||||||
const ESRCH: number;
|
|
||||||
const ESTALE: number;
|
|
||||||
const ETIME: number;
|
|
||||||
const ETIMEDOUT: number;
|
|
||||||
const ETXTBSY: number;
|
|
||||||
const EWOULDBLOCK: number;
|
|
||||||
const EXDEV: number;
|
|
||||||
const WSAEINTR: number;
|
|
||||||
const WSAEBADF: number;
|
|
||||||
const WSAEACCES: number;
|
|
||||||
const WSAEFAULT: number;
|
|
||||||
const WSAEINVAL: number;
|
|
||||||
const WSAEMFILE: number;
|
|
||||||
const WSAEWOULDBLOCK: number;
|
|
||||||
const WSAEINPROGRESS: number;
|
|
||||||
const WSAEALREADY: number;
|
|
||||||
const WSAENOTSOCK: number;
|
|
||||||
const WSAEDESTADDRREQ: number;
|
|
||||||
const WSAEMSGSIZE: number;
|
|
||||||
const WSAEPROTOTYPE: number;
|
|
||||||
const WSAENOPROTOOPT: number;
|
|
||||||
const WSAEPROTONOSUPPORT: number;
|
|
||||||
const WSAESOCKTNOSUPPORT: number;
|
|
||||||
const WSAEOPNOTSUPP: number;
|
|
||||||
const WSAEPFNOSUPPORT: number;
|
|
||||||
const WSAEAFNOSUPPORT: number;
|
|
||||||
const WSAEADDRINUSE: number;
|
|
||||||
const WSAEADDRNOTAVAIL: number;
|
|
||||||
const WSAENETDOWN: number;
|
|
||||||
const WSAENETUNREACH: number;
|
|
||||||
const WSAENETRESET: number;
|
|
||||||
const WSAECONNABORTED: number;
|
|
||||||
const WSAECONNRESET: number;
|
|
||||||
const WSAENOBUFS: number;
|
|
||||||
const WSAEISCONN: number;
|
|
||||||
const WSAENOTCONN: number;
|
|
||||||
const WSAESHUTDOWN: number;
|
|
||||||
const WSAETOOMANYREFS: number;
|
|
||||||
const WSAETIMEDOUT: number;
|
|
||||||
const WSAECONNREFUSED: number;
|
|
||||||
const WSAELOOP: number;
|
|
||||||
const WSAENAMETOOLONG: number;
|
|
||||||
const WSAEHOSTDOWN: number;
|
|
||||||
const WSAEHOSTUNREACH: number;
|
|
||||||
const WSAENOTEMPTY: number;
|
|
||||||
const WSAEPROCLIM: number;
|
|
||||||
const WSAEUSERS: number;
|
|
||||||
const WSAEDQUOT: number;
|
|
||||||
const WSAESTALE: number;
|
|
||||||
const WSAEREMOTE: number;
|
|
||||||
const WSASYSNOTREADY: number;
|
|
||||||
const WSAVERNOTSUPPORTED: number;
|
|
||||||
const WSANOTINITIALISED: number;
|
|
||||||
const WSAEDISCON: number;
|
|
||||||
const WSAENOMORE: number;
|
|
||||||
const WSAECANCELLED: number;
|
|
||||||
const WSAEINVALIDPROCTABLE: number;
|
|
||||||
const WSAEINVALIDPROVIDER: number;
|
|
||||||
const WSAEPROVIDERFAILEDINIT: number;
|
|
||||||
const WSASYSCALLFAILURE: number;
|
|
||||||
const WSASERVICE_NOT_FOUND: number;
|
|
||||||
const WSATYPE_NOT_FOUND: number;
|
|
||||||
const WSA_E_NO_MORE: number;
|
|
||||||
const WSA_E_CANCELLED: number;
|
|
||||||
const WSAEREFUSED: number;
|
|
||||||
}
|
|
||||||
namespace priority {
|
|
||||||
const PRIORITY_LOW: number;
|
|
||||||
const PRIORITY_BELOW_NORMAL: number;
|
|
||||||
const PRIORITY_NORMAL: number;
|
|
||||||
const PRIORITY_ABOVE_NORMAL: number;
|
|
||||||
const PRIORITY_HIGH: number;
|
|
||||||
const PRIORITY_HIGHEST: number;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
const devNull: string;
|
|
||||||
const EOL: string;
|
|
||||||
/**
|
|
||||||
* Returns the operating system CPU architecture for which the Node.js binary was
|
|
||||||
* compiled. Possible values are `'arm'`, `'arm64'`, `'ia32'`, `'mips'`,`'mipsel'`, `'ppc'`, `'ppc64'`, `'s390'`, `'s390x'`, `'x32'`, and `'x64'`.
|
|
||||||
*
|
|
||||||
* The return value is equivalent to `process.arch`.
|
|
||||||
* @since v0.5.0
|
|
||||||
*/
|
|
||||||
function arch(): string;
|
function arch(): string;
|
||||||
/**
|
|
||||||
* Returns a string identifying the kernel version.
|
|
||||||
*
|
|
||||||
* On POSIX systems, the operating system release is determined by calling [`uname(3)`](https://linux.die.net/man/3/uname). On Windows, `RtlGetVersion()` is used, and if it is not
|
|
||||||
* available, `GetVersionExW()` will be used. See [https://en.wikipedia.org/wiki/Uname#Examples](https://en.wikipedia.org/wiki/Uname#Examples) for more information.
|
|
||||||
* @since v13.11.0, v12.17.0
|
|
||||||
*/
|
|
||||||
function version(): string;
|
|
||||||
/**
|
|
||||||
* Returns a string identifying the operating system platform. The value is set
|
|
||||||
* at compile time. Possible values are `'aix'`, `'darwin'`, `'freebsd'`,`'linux'`, `'openbsd'`, `'sunos'`, and `'win32'`.
|
|
||||||
*
|
|
||||||
* The return value is equivalent to `process.platform`.
|
|
||||||
*
|
|
||||||
* The value `'android'` may also be returned if Node.js is built on the Android
|
|
||||||
* operating system. [Android support is experimental](https://github.com/nodejs/node/blob/HEAD/BUILDING.md#androidandroid-based-devices-eg-firefox-os).
|
|
||||||
* @since v0.5.0
|
|
||||||
*/
|
|
||||||
function platform(): NodeJS.Platform;
|
function platform(): NodeJS.Platform;
|
||||||
/**
|
|
||||||
* Returns the operating system's default directory for temporary files as a
|
|
||||||
* string.
|
|
||||||
* @since v0.9.9
|
|
||||||
*/
|
|
||||||
function tmpdir(): string;
|
function tmpdir(): string;
|
||||||
|
const EOL: string;
|
||||||
|
function endianness(): "BE" | "LE";
|
||||||
/**
|
/**
|
||||||
* Returns a string identifying the endianness of the CPU for which the Node.js
|
* Gets the priority of a process.
|
||||||
* binary was compiled.
|
* Defaults to current process.
|
||||||
*
|
|
||||||
* Possible values are `'BE'` for big endian and `'LE'` for little endian.
|
|
||||||
* @since v0.9.4
|
|
||||||
*/
|
|
||||||
function endianness(): 'BE' | 'LE';
|
|
||||||
/**
|
|
||||||
* Returns the scheduling priority for the process specified by `pid`. If `pid` is
|
|
||||||
* not provided or is `0`, the priority of the current process is returned.
|
|
||||||
* @since v10.10.0
|
|
||||||
* @param [pid=0] The process ID to retrieve scheduling priority for.
|
|
||||||
*/
|
*/
|
||||||
function getPriority(pid?: number): number;
|
function getPriority(pid?: number): number;
|
||||||
/**
|
/**
|
||||||
* Attempts to set the scheduling priority for the process specified by `pid`. If`pid` is not provided or is `0`, the process ID of the current process is used.
|
* Sets the priority of the current process.
|
||||||
*
|
* @param priority Must be in range of -20 to 19
|
||||||
* The `priority` input must be an integer between `-20` (high priority) and `19`(low priority). Due to differences between Unix priority levels and Windows
|
|
||||||
* priority classes, `priority` is mapped to one of six priority constants in`os.constants.priority`. When retrieving a process priority level, this range
|
|
||||||
* mapping may cause the return value to be slightly different on Windows. To avoid
|
|
||||||
* confusion, set `priority` to one of the priority constants.
|
|
||||||
*
|
|
||||||
* On Windows, setting priority to `PRIORITY_HIGHEST` requires elevated user
|
|
||||||
* privileges. Otherwise the set priority will be silently reduced to`PRIORITY_HIGH`.
|
|
||||||
* @since v10.10.0
|
|
||||||
* @param [pid=0] The process ID to set scheduling priority for.
|
|
||||||
* @param priority The scheduling priority to assign to the process.
|
|
||||||
*/
|
*/
|
||||||
function setPriority(priority: number): void;
|
function setPriority(priority: number): void;
|
||||||
|
/**
|
||||||
|
* Sets the priority of the process specified process.
|
||||||
|
* @param priority Must be in range of -20 to 19
|
||||||
|
*/
|
||||||
function setPriority(pid: number, priority: number): void;
|
function setPriority(pid: number, priority: number): void;
|
||||||
}
|
}
|
||||||
declare module 'node:os' {
|
|
||||||
export * from 'os';
|
|
||||||
}
|
|
||||||
|
|||||||
95
node_modules/@types/node/package.json
generated
vendored
Executable file → Normal file
95
node_modules/@types/node/package.json
generated
vendored
Executable file → Normal file
@@ -1,8 +1,7 @@
|
|||||||
{
|
{
|
||||||
"name": "@types/node",
|
"name": "@types/node",
|
||||||
"version": "16.11.22",
|
"version": "12.12.70",
|
||||||
"description": "TypeScript definitions for Node.js",
|
"description": "TypeScript definitions for Node.js",
|
||||||
"homepage": "https://github.com/DefinitelyTyped/DefinitelyTyped/tree/master/types/node",
|
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"contributors": [
|
"contributors": [
|
||||||
{
|
{
|
||||||
@@ -20,6 +19,11 @@
|
|||||||
"url": "https://github.com/jkomyno",
|
"url": "https://github.com/jkomyno",
|
||||||
"githubUsername": "jkomyno"
|
"githubUsername": "jkomyno"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "Alexander T.",
|
||||||
|
"url": "https://github.com/a-tarasyuk",
|
||||||
|
"githubUsername": "a-tarasyuk"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "Alvis HT Tang",
|
"name": "Alvis HT Tang",
|
||||||
"url": "https://github.com/alvis",
|
"url": "https://github.com/alvis",
|
||||||
@@ -35,6 +39,11 @@
|
|||||||
"url": "https://github.com/btoueg",
|
"url": "https://github.com/btoueg",
|
||||||
"githubUsername": "btoueg"
|
"githubUsername": "btoueg"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "Bruno Scheufler",
|
||||||
|
"url": "https://github.com/brunoscheufler",
|
||||||
|
"githubUsername": "brunoscheufler"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "Chigozirim C.",
|
"name": "Chigozirim C.",
|
||||||
"url": "https://github.com/smac89",
|
"url": "https://github.com/smac89",
|
||||||
@@ -55,11 +64,21 @@
|
|||||||
"url": "https://github.com/eyqs",
|
"url": "https://github.com/eyqs",
|
||||||
"githubUsername": "eyqs"
|
"githubUsername": "eyqs"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "Flarna",
|
||||||
|
"url": "https://github.com/Flarna",
|
||||||
|
"githubUsername": "Flarna"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "Hannes Magnusson",
|
"name": "Hannes Magnusson",
|
||||||
"url": "https://github.com/Hannes-Magnusson-CK",
|
"url": "https://github.com/Hannes-Magnusson-CK",
|
||||||
"githubUsername": "Hannes-Magnusson-CK"
|
"githubUsername": "Hannes-Magnusson-CK"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "Hoàng Văn Khải",
|
||||||
|
"url": "https://github.com/KSXGitHub",
|
||||||
|
"githubUsername": "KSXGitHub"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "Huw",
|
"name": "Huw",
|
||||||
"url": "https://github.com/hoo29",
|
"url": "https://github.com/hoo29",
|
||||||
@@ -110,11 +129,6 @@
|
|||||||
"url": "https://github.com/eps1lon",
|
"url": "https://github.com/eps1lon",
|
||||||
"githubUsername": "eps1lon"
|
"githubUsername": "eps1lon"
|
||||||
},
|
},
|
||||||
{
|
|
||||||
"name": "Seth Westphal",
|
|
||||||
"url": "https://github.com/westy92",
|
|
||||||
"githubUsername": "westy92"
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
"name": "Simon Schick",
|
"name": "Simon Schick",
|
||||||
"url": "https://github.com/SimonSchick",
|
"url": "https://github.com/SimonSchick",
|
||||||
@@ -135,6 +149,11 @@
|
|||||||
"url": "https://github.com/wwwy3y3",
|
"url": "https://github.com/wwwy3y3",
|
||||||
"githubUsername": "wwwy3y3"
|
"githubUsername": "wwwy3y3"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "Zane Hannan AU",
|
||||||
|
"url": "https://github.com/ZaneHannanAU",
|
||||||
|
"githubUsername": "ZaneHannanAU"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "Samuel Ainsworth",
|
"name": "Samuel Ainsworth",
|
||||||
"url": "https://github.com/samuela",
|
"url": "https://github.com/samuela",
|
||||||
@@ -145,6 +164,11 @@
|
|||||||
"url": "https://github.com/kuehlein",
|
"url": "https://github.com/kuehlein",
|
||||||
"githubUsername": "kuehlein"
|
"githubUsername": "kuehlein"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "Jordi Oliveras Rovira",
|
||||||
|
"url": "https://github.com/j-oliveras",
|
||||||
|
"githubUsername": "j-oliveras"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "Thanik Bhongbhibhat",
|
"name": "Thanik Bhongbhibhat",
|
||||||
"url": "https://github.com/bhongy",
|
"url": "https://github.com/bhongy",
|
||||||
@@ -160,6 +184,11 @@
|
|||||||
"url": "https://github.com/trivikr",
|
"url": "https://github.com/trivikr",
|
||||||
"githubUsername": "trivikr"
|
"githubUsername": "trivikr"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "Minh Son Nguyen",
|
||||||
|
"url": "https://github.com/nguymin4",
|
||||||
|
"githubUsername": "nguymin4"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "Junxiao Shi",
|
"name": "Junxiao Shi",
|
||||||
"url": "https://github.com/yoursunny",
|
"url": "https://github.com/yoursunny",
|
||||||
@@ -176,43 +205,25 @@
|
|||||||
"githubUsername": "ExE-Boss"
|
"githubUsername": "ExE-Boss"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"name": "Piotr Błażejewicz",
|
"name": "Jason Kwok",
|
||||||
"url": "https://github.com/peterblazejewicz",
|
"url": "https://github.com/JasonHK",
|
||||||
"githubUsername": "peterblazejewicz"
|
"githubUsername": "JasonHK"
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "Anna Henningsen",
|
|
||||||
"url": "https://github.com/addaleax",
|
|
||||||
"githubUsername": "addaleax"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "Victor Perin",
|
|
||||||
"url": "https://github.com/victorperin",
|
|
||||||
"githubUsername": "victorperin"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "Yongsheng Zhang",
|
|
||||||
"url": "https://github.com/ZYSzys",
|
|
||||||
"githubUsername": "ZYSzys"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "NodeJS Contributors",
|
|
||||||
"url": "https://github.com/NodeJS",
|
|
||||||
"githubUsername": "NodeJS"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "Linus Unnebäck",
|
|
||||||
"url": "https://github.com/LinusU",
|
|
||||||
"githubUsername": "LinusU"
|
|
||||||
},
|
|
||||||
{
|
|
||||||
"name": "wafuwafu13",
|
|
||||||
"url": "https://github.com/wafuwafu13",
|
|
||||||
"githubUsername": "wafuwafu13"
|
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"main": "",
|
"main": "",
|
||||||
"types": "index.d.ts",
|
"types": "index.d.ts",
|
||||||
|
"typesVersions": {
|
||||||
|
"<=3.3": {
|
||||||
|
"*": [
|
||||||
|
"ts3.3/*"
|
||||||
|
]
|
||||||
|
},
|
||||||
|
"<=3.6": {
|
||||||
|
"*": [
|
||||||
|
"ts3.6/*"
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
"repository": {
|
"repository": {
|
||||||
"type": "git",
|
"type": "git",
|
||||||
"url": "https://github.com/DefinitelyTyped/DefinitelyTyped.git",
|
"url": "https://github.com/DefinitelyTyped/DefinitelyTyped.git",
|
||||||
@@ -220,6 +231,6 @@
|
|||||||
},
|
},
|
||||||
"scripts": {},
|
"scripts": {},
|
||||||
"dependencies": {},
|
"dependencies": {},
|
||||||
"typesPublisherContentHash": "57a94e60cf640ea4d81b4fa914f3fb5929a63ae0b4d5141d7daf250c569e7d10",
|
"typesPublisherContentHash": "86d21f1f394b808863aabd5045402fca03a666e6e4c13c81302c4c82c28462bd",
|
||||||
"typeScriptVersion": "3.8"
|
"typeScriptVersion": "3.2"
|
||||||
}
|
}
|
||||||
331
node_modules/@types/node/path.d.ts
generated
vendored
Executable file → Normal file
331
node_modules/@types/node/path.d.ts
generated
vendored
Executable file → Normal file
@@ -1,180 +1,159 @@
|
|||||||
declare module 'path/posix' {
|
declare module "path" {
|
||||||
import path = require('path');
|
/**
|
||||||
export = path;
|
* A parsed path object generated by path.parse() or consumed by path.format().
|
||||||
}
|
*/
|
||||||
declare module 'path/win32' {
|
interface ParsedPath {
|
||||||
import path = require('path');
|
|
||||||
export = path;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* The `path` module provides utilities for working with file and directory paths.
|
|
||||||
* It can be accessed using:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const path = require('path');
|
|
||||||
* ```
|
|
||||||
* @see [source](https://github.com/nodejs/node/blob/v16.9.0/lib/path.js)
|
|
||||||
*/
|
|
||||||
declare module 'path' {
|
|
||||||
namespace path {
|
|
||||||
/**
|
/**
|
||||||
* A parsed path object generated by path.parse() or consumed by path.format().
|
* The root of the path such as '/' or 'c:\'
|
||||||
*/
|
*/
|
||||||
interface ParsedPath {
|
root: string;
|
||||||
/**
|
/**
|
||||||
* The root of the path such as '/' or 'c:\'
|
* The full directory path such as '/home/user/dir' or 'c:\path\dir'
|
||||||
*/
|
*/
|
||||||
root: string;
|
dir: string;
|
||||||
/**
|
/**
|
||||||
* The full directory path such as '/home/user/dir' or 'c:\path\dir'
|
* The file name including extension (if any) such as 'index.html'
|
||||||
*/
|
*/
|
||||||
dir: string;
|
base: string;
|
||||||
/**
|
/**
|
||||||
* The file name including extension (if any) such as 'index.html'
|
* The file extension (if any) such as '.html'
|
||||||
*/
|
*/
|
||||||
base: string;
|
ext: string;
|
||||||
/**
|
/**
|
||||||
* The file extension (if any) such as '.html'
|
* The file name without extension (if any) such as 'index'
|
||||||
*/
|
*/
|
||||||
ext: string;
|
name: string;
|
||||||
/**
|
}
|
||||||
* The file name without extension (if any) such as 'index'
|
interface FormatInputPathObject {
|
||||||
*/
|
/**
|
||||||
name: string;
|
* The root of the path such as '/' or 'c:\'
|
||||||
}
|
*/
|
||||||
interface FormatInputPathObject {
|
root?: string;
|
||||||
/**
|
/**
|
||||||
* The root of the path such as '/' or 'c:\'
|
* The full directory path such as '/home/user/dir' or 'c:\path\dir'
|
||||||
*/
|
*/
|
||||||
root?: string | undefined;
|
dir?: string;
|
||||||
/**
|
/**
|
||||||
* The full directory path such as '/home/user/dir' or 'c:\path\dir'
|
* The file name including extension (if any) such as 'index.html'
|
||||||
*/
|
*/
|
||||||
dir?: string | undefined;
|
base?: string;
|
||||||
/**
|
/**
|
||||||
* The file name including extension (if any) such as 'index.html'
|
* The file extension (if any) such as '.html'
|
||||||
*/
|
*/
|
||||||
base?: string | undefined;
|
ext?: string;
|
||||||
/**
|
/**
|
||||||
* The file extension (if any) such as '.html'
|
* The file name without extension (if any) such as 'index'
|
||||||
*/
|
*/
|
||||||
ext?: string | undefined;
|
name?: string;
|
||||||
/**
|
}
|
||||||
* The file name without extension (if any) such as 'index'
|
|
||||||
*/
|
/**
|
||||||
name?: string | undefined;
|
* Normalize a string path, reducing '..' and '.' parts.
|
||||||
}
|
* When multiple slashes are found, they're replaced by a single one; when the path contains a trailing slash, it is preserved. On Windows backslashes are used.
|
||||||
interface PlatformPath {
|
*
|
||||||
/**
|
* @param p string path to normalize.
|
||||||
* Normalize a string path, reducing '..' and '.' parts.
|
*/
|
||||||
* When multiple slashes are found, they're replaced by a single one; when the path contains a trailing slash, it is preserved. On Windows backslashes are used.
|
function normalize(p: string): string;
|
||||||
*
|
/**
|
||||||
* @param p string path to normalize.
|
* Join all arguments together and normalize the resulting path.
|
||||||
*/
|
* Arguments must be strings. In v0.8, non-string arguments were silently ignored. In v0.10 and up, an exception is thrown.
|
||||||
normalize(p: string): string;
|
*
|
||||||
/**
|
* @param paths paths to join.
|
||||||
* Join all arguments together and normalize the resulting path.
|
*/
|
||||||
* Arguments must be strings. In v0.8, non-string arguments were silently ignored. In v0.10 and up, an exception is thrown.
|
function join(...paths: string[]): string;
|
||||||
*
|
/**
|
||||||
* @param paths paths to join.
|
* The right-most parameter is considered {to}. Other parameters are considered an array of {from}.
|
||||||
*/
|
*
|
||||||
join(...paths: string[]): string;
|
* Starting from leftmost {from} parameter, resolves {to} to an absolute path.
|
||||||
/**
|
*
|
||||||
* The right-most parameter is considered {to}. Other parameters are considered an array of {from}.
|
* If {to} isn't already absolute, {from} arguments are prepended in right to left order,
|
||||||
*
|
* until an absolute path is found. If after using all {from} paths still no absolute path is found,
|
||||||
* Starting from leftmost {from} parameter, resolves {to} to an absolute path.
|
* the current working directory is used as well. The resulting path is normalized,
|
||||||
*
|
* and trailing slashes are removed unless the path gets resolved to the root directory.
|
||||||
* If {to} isn't already absolute, {from} arguments are prepended in right to left order,
|
*
|
||||||
* until an absolute path is found. If after using all {from} paths still no absolute path is found,
|
* @param pathSegments string paths to join. Non-string arguments are ignored.
|
||||||
* the current working directory is used as well. The resulting path is normalized,
|
*/
|
||||||
* and trailing slashes are removed unless the path gets resolved to the root directory.
|
function resolve(...pathSegments: string[]): string;
|
||||||
*
|
/**
|
||||||
* @param pathSegments string paths to join. Non-string arguments are ignored.
|
* Determines whether {path} is an absolute path. An absolute path will always resolve to the same location, regardless of the working directory.
|
||||||
*/
|
*
|
||||||
resolve(...pathSegments: string[]): string;
|
* @param path path to test.
|
||||||
/**
|
*/
|
||||||
* Determines whether {path} is an absolute path. An absolute path will always resolve to the same location, regardless of the working directory.
|
function isAbsolute(path: string): boolean;
|
||||||
*
|
/**
|
||||||
* @param path path to test.
|
* Solve the relative path from {from} to {to}.
|
||||||
*/
|
* At times we have two absolute paths, and we need to derive the relative path from one to the other. This is actually the reverse transform of path.resolve.
|
||||||
isAbsolute(p: string): boolean;
|
*/
|
||||||
/**
|
function relative(from: string, to: string): string;
|
||||||
* Solve the relative path from {from} to {to}.
|
/**
|
||||||
* At times we have two absolute paths, and we need to derive the relative path from one to the other. This is actually the reverse transform of path.resolve.
|
* Return the directory name of a path. Similar to the Unix dirname command.
|
||||||
*/
|
*
|
||||||
relative(from: string, to: string): string;
|
* @param p the path to evaluate.
|
||||||
/**
|
*/
|
||||||
* Return the directory name of a path. Similar to the Unix dirname command.
|
function dirname(p: string): string;
|
||||||
*
|
/**
|
||||||
* @param p the path to evaluate.
|
* Return the last portion of a path. Similar to the Unix basename command.
|
||||||
*/
|
* Often used to extract the file name from a fully qualified path.
|
||||||
dirname(p: string): string;
|
*
|
||||||
/**
|
* @param p the path to evaluate.
|
||||||
* Return the last portion of a path. Similar to the Unix basename command.
|
* @param ext optionally, an extension to remove from the result.
|
||||||
* Often used to extract the file name from a fully qualified path.
|
*/
|
||||||
*
|
function basename(p: string, ext?: string): string;
|
||||||
* @param p the path to evaluate.
|
/**
|
||||||
* @param ext optionally, an extension to remove from the result.
|
* Return the extension of the path, from the last '.' to end of string in the last portion of the path.
|
||||||
*/
|
* If there is no '.' in the last portion of the path or the first character of it is '.', then it returns an empty string
|
||||||
basename(p: string, ext?: string): string;
|
*
|
||||||
/**
|
* @param p the path to evaluate.
|
||||||
* Return the extension of the path, from the last '.' to end of string in the last portion of the path.
|
*/
|
||||||
* If there is no '.' in the last portion of the path or the first character of it is '.', then it returns an empty string
|
function extname(p: string): string;
|
||||||
*
|
/**
|
||||||
* @param p the path to evaluate.
|
* The platform-specific file separator. '\\' or '/'.
|
||||||
*/
|
*/
|
||||||
extname(p: string): string;
|
const sep: '\\' | '/';
|
||||||
/**
|
/**
|
||||||
* The platform-specific file separator. '\\' or '/'.
|
* The platform-specific file delimiter. ';' or ':'.
|
||||||
*/
|
*/
|
||||||
readonly sep: string;
|
const delimiter: ';' | ':';
|
||||||
/**
|
/**
|
||||||
* The platform-specific file delimiter. ';' or ':'.
|
* Returns an object from a path string - the opposite of format().
|
||||||
*/
|
*
|
||||||
readonly delimiter: string;
|
* @param pathString path to evaluate.
|
||||||
/**
|
*/
|
||||||
* Returns an object from a path string - the opposite of format().
|
function parse(pathString: string): ParsedPath;
|
||||||
*
|
/**
|
||||||
* @param pathString path to evaluate.
|
* Returns a path string from an object - the opposite of parse().
|
||||||
*/
|
*
|
||||||
parse(p: string): ParsedPath;
|
* @param pathString path to evaluate.
|
||||||
/**
|
*/
|
||||||
* Returns a path string from an object - the opposite of parse().
|
function format(pathObject: FormatInputPathObject): string;
|
||||||
*
|
|
||||||
* @param pathString path to evaluate.
|
namespace posix {
|
||||||
*/
|
function normalize(p: string): string;
|
||||||
format(pP: FormatInputPathObject): string;
|
function join(...paths: string[]): string;
|
||||||
/**
|
function resolve(...pathSegments: string[]): string;
|
||||||
* On Windows systems only, returns an equivalent namespace-prefixed path for the given path.
|
function isAbsolute(p: string): boolean;
|
||||||
* If path is not a string, path will be returned without modifications.
|
function relative(from: string, to: string): string;
|
||||||
* This method is meaningful only on Windows system.
|
function dirname(p: string): string;
|
||||||
* On POSIX systems, the method is non-operational and always returns path without modifications.
|
function basename(p: string, ext?: string): string;
|
||||||
*/
|
function extname(p: string): string;
|
||||||
toNamespacedPath(path: string): string;
|
const sep: string;
|
||||||
/**
|
const delimiter: string;
|
||||||
* Posix specific pathing.
|
function parse(p: string): ParsedPath;
|
||||||
* Same as parent object on posix.
|
function format(pP: FormatInputPathObject): string;
|
||||||
*/
|
}
|
||||||
readonly posix: PlatformPath;
|
|
||||||
/**
|
namespace win32 {
|
||||||
* Windows specific pathing.
|
function normalize(p: string): string;
|
||||||
* Same as parent object on windows
|
function join(...paths: string[]): string;
|
||||||
*/
|
function resolve(...pathSegments: string[]): string;
|
||||||
readonly win32: PlatformPath;
|
function isAbsolute(p: string): boolean;
|
||||||
}
|
function relative(from: string, to: string): string;
|
||||||
|
function dirname(p: string): string;
|
||||||
|
function basename(p: string, ext?: string): string;
|
||||||
|
function extname(p: string): string;
|
||||||
|
const sep: string;
|
||||||
|
const delimiter: string;
|
||||||
|
function parse(p: string): ParsedPath;
|
||||||
|
function format(pP: FormatInputPathObject): string;
|
||||||
}
|
}
|
||||||
const path: path.PlatformPath;
|
|
||||||
export = path;
|
|
||||||
}
|
|
||||||
declare module 'node:path' {
|
|
||||||
import path = require('path');
|
|
||||||
export = path;
|
|
||||||
}
|
|
||||||
declare module 'node:path/posix' {
|
|
||||||
import path = require('path/posix');
|
|
||||||
export = path;
|
|
||||||
}
|
|
||||||
declare module 'node:path/win32' {
|
|
||||||
import path = require('path/win32');
|
|
||||||
export = path;
|
|
||||||
}
|
}
|
||||||
|
|||||||
559
node_modules/@types/node/perf_hooks.d.ts
generated
vendored
Executable file → Normal file
559
node_modules/@types/node/perf_hooks.d.ts
generated
vendored
Executable file → Normal file
@@ -1,189 +1,74 @@
|
|||||||
/**
|
declare module "perf_hooks" {
|
||||||
* This module provides an implementation of a subset of the W3C [Web Performance APIs](https://w3c.github.io/perf-timing-primer/) as well as additional APIs for
|
import { AsyncResource } from "async_hooks";
|
||||||
* Node.js-specific performance measurements.
|
|
||||||
*
|
interface PerformanceEntry {
|
||||||
* Node.js supports the following [Web Performance APIs](https://w3c.github.io/perf-timing-primer/):
|
|
||||||
*
|
|
||||||
* * [High Resolution Time](https://www.w3.org/TR/hr-time-2)
|
|
||||||
* * [Performance Timeline](https://w3c.github.io/performance-timeline/)
|
|
||||||
* * [User Timing](https://www.w3.org/TR/user-timing/)
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const { PerformanceObserver, performance } = require('perf_hooks');
|
|
||||||
*
|
|
||||||
* const obs = new PerformanceObserver((items) => {
|
|
||||||
* console.log(items.getEntries()[0].duration);
|
|
||||||
* performance.clearMarks();
|
|
||||||
* });
|
|
||||||
* obs.observe({ type: 'measure' });
|
|
||||||
* performance.measure('Start to Now');
|
|
||||||
*
|
|
||||||
* performance.mark('A');
|
|
||||||
* doSomeLongRunningProcess(() => {
|
|
||||||
* performance.measure('A to Now', 'A');
|
|
||||||
*
|
|
||||||
* performance.mark('B');
|
|
||||||
* performance.measure('A to B', 'A', 'B');
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
* @see [source](https://github.com/nodejs/node/blob/v16.9.0/lib/perf_hooks.js)
|
|
||||||
*/
|
|
||||||
declare module 'perf_hooks' {
|
|
||||||
import { AsyncResource } from 'node:async_hooks';
|
|
||||||
type EntryType = 'node' | 'mark' | 'measure' | 'gc' | 'function' | 'http2' | 'http';
|
|
||||||
interface NodeGCPerformanceDetail {
|
|
||||||
/**
|
/**
|
||||||
* When `performanceEntry.entryType` is equal to 'gc', `the performance.kind` property identifies
|
* The total number of milliseconds elapsed for this entry.
|
||||||
* the type of garbage collection operation that occurred.
|
* This value will not be meaningful for all Performance Entry types.
|
||||||
* See perf_hooks.constants for valid values.
|
|
||||||
*/
|
|
||||||
readonly kind?: number | undefined;
|
|
||||||
/**
|
|
||||||
* When `performanceEntry.entryType` is equal to 'gc', the `performance.flags`
|
|
||||||
* property contains additional information about garbage collection operation.
|
|
||||||
* See perf_hooks.constants for valid values.
|
|
||||||
*/
|
|
||||||
readonly flags?: number | undefined;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* @since v8.5.0
|
|
||||||
*/
|
|
||||||
class PerformanceEntry {
|
|
||||||
protected constructor();
|
|
||||||
/**
|
|
||||||
* The total number of milliseconds elapsed for this entry. This value will not
|
|
||||||
* be meaningful for all Performance Entry types.
|
|
||||||
* @since v8.5.0
|
|
||||||
*/
|
*/
|
||||||
readonly duration: number;
|
readonly duration: number;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The name of the performance entry.
|
* The name of the performance entry.
|
||||||
* @since v8.5.0
|
|
||||||
*/
|
*/
|
||||||
readonly name: string;
|
readonly name: string;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The high resolution millisecond timestamp marking the starting time of the
|
* The high resolution millisecond timestamp marking the starting time of the Performance Entry.
|
||||||
* Performance Entry.
|
|
||||||
* @since v8.5.0
|
|
||||||
*/
|
*/
|
||||||
readonly startTime: number;
|
readonly startTime: number;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The type of the performance entry. It may be one of:
|
* The type of the performance entry.
|
||||||
*
|
* Currently it may be one of: 'node', 'mark', 'measure', 'gc', or 'function'.
|
||||||
* * `'node'` (Node.js only)
|
|
||||||
* * `'mark'` (available on the Web)
|
|
||||||
* * `'measure'` (available on the Web)
|
|
||||||
* * `'gc'` (Node.js only)
|
|
||||||
* * `'function'` (Node.js only)
|
|
||||||
* * `'http2'` (Node.js only)
|
|
||||||
* * `'http'` (Node.js only)
|
|
||||||
* @since v8.5.0
|
|
||||||
*/
|
*/
|
||||||
readonly entryType: EntryType;
|
readonly entryType: string;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Additional detail specific to the `entryType`.
|
* When performanceEntry.entryType is equal to 'gc', the performance.kind property identifies
|
||||||
* @since v16.0.0
|
* the type of garbage collection operation that occurred.
|
||||||
|
* The value may be one of perf_hooks.constants.
|
||||||
*/
|
*/
|
||||||
readonly detail?: NodeGCPerformanceDetail | unknown | undefined; // TODO: Narrow this based on entry type.
|
readonly kind?: number;
|
||||||
}
|
}
|
||||||
/**
|
|
||||||
* _This property is an extension by Node.js. It is not available in Web browsers._
|
interface PerformanceNodeTiming extends PerformanceEntry {
|
||||||
*
|
|
||||||
* Provides timing details for Node.js itself. The constructor of this class
|
|
||||||
* is not exposed to users.
|
|
||||||
* @since v8.5.0
|
|
||||||
*/
|
|
||||||
class PerformanceNodeTiming extends PerformanceEntry {
|
|
||||||
/**
|
/**
|
||||||
* The high resolution millisecond timestamp at which the Node.js process
|
* The high resolution millisecond timestamp at which the Node.js process completed bootstrap.
|
||||||
* completed bootstrapping. If bootstrapping has not yet finished, the property
|
* If bootstrapping has not yet finished, the property has the value of -1.
|
||||||
* has the value of -1.
|
|
||||||
* @since v8.5.0
|
|
||||||
*/
|
*/
|
||||||
readonly bootstrapComplete: number;
|
readonly bootstrapComplete: number;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The high resolution millisecond timestamp at which the Node.js environment was
|
* The high resolution millisecond timestamp at which the Node.js process completed bootstrapping.
|
||||||
* initialized.
|
* If bootstrapping has not yet finished, the property has the value of -1.
|
||||||
* @since v8.5.0
|
|
||||||
*/
|
*/
|
||||||
readonly environment: number;
|
readonly environment: number;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The high resolution millisecond timestamp of the amount of time the event loop
|
* The high resolution millisecond timestamp at which the Node.js event loop exited.
|
||||||
* has been idle within the event loop's event provider (e.g. `epoll_wait`). This
|
* If the event loop has not yet exited, the property has the value of -1.
|
||||||
* does not take CPU usage into consideration. If the event loop has not yet
|
* It can only have a value of not -1 in a handler of the 'exit' event.
|
||||||
* started (e.g., in the first tick of the main script), the property has the
|
|
||||||
* value of 0.
|
|
||||||
* @since v14.10.0, v12.19.0
|
|
||||||
*/
|
|
||||||
readonly idleTime: number;
|
|
||||||
/**
|
|
||||||
* The high resolution millisecond timestamp at which the Node.js event loop
|
|
||||||
* exited. If the event loop has not yet exited, the property has the value of -1\.
|
|
||||||
* It can only have a value of not -1 in a handler of the `'exit'` event.
|
|
||||||
* @since v8.5.0
|
|
||||||
*/
|
*/
|
||||||
readonly loopExit: number;
|
readonly loopExit: number;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The high resolution millisecond timestamp at which the Node.js event loop
|
* The high resolution millisecond timestamp at which the Node.js event loop started.
|
||||||
* started. If the event loop has not yet started (e.g., in the first tick of the
|
* If the event loop has not yet started (e.g., in the first tick of the main script), the property has the value of -1.
|
||||||
* main script), the property has the value of -1.
|
|
||||||
* @since v8.5.0
|
|
||||||
*/
|
*/
|
||||||
readonly loopStart: number;
|
readonly loopStart: number;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The high resolution millisecond timestamp at which the V8 platform was
|
* The high resolution millisecond timestamp at which the Node.js process was initialized.
|
||||||
* initialized.
|
*/
|
||||||
* @since v8.5.0
|
readonly nodeStart: number;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The high resolution millisecond timestamp at which the V8 platform was initialized.
|
||||||
*/
|
*/
|
||||||
readonly v8Start: number;
|
readonly v8Start: number;
|
||||||
}
|
}
|
||||||
interface EventLoopUtilization {
|
|
||||||
idle: number;
|
|
||||||
active: number;
|
|
||||||
utilization: number;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* @param util1 The result of a previous call to eventLoopUtilization()
|
|
||||||
* @param util2 The result of a previous call to eventLoopUtilization() prior to util1
|
|
||||||
*/
|
|
||||||
type EventLoopUtilityFunction = (util1?: EventLoopUtilization, util2?: EventLoopUtilization) => EventLoopUtilization;
|
|
||||||
interface MarkOptions {
|
|
||||||
/**
|
|
||||||
* Additional optional detail to include with the mark.
|
|
||||||
*/
|
|
||||||
detail?: unknown | undefined;
|
|
||||||
/**
|
|
||||||
* An optional timestamp to be used as the mark time.
|
|
||||||
* @default `performance.now()`.
|
|
||||||
*/
|
|
||||||
startTime?: number | undefined;
|
|
||||||
}
|
|
||||||
interface MeasureOptions {
|
|
||||||
/**
|
|
||||||
* Additional optional detail to include with the mark.
|
|
||||||
*/
|
|
||||||
detail?: unknown | undefined;
|
|
||||||
/**
|
|
||||||
* Duration between start and end times.
|
|
||||||
*/
|
|
||||||
duration?: number | undefined;
|
|
||||||
/**
|
|
||||||
* Timestamp to be used as the end time, or a string identifying a previously recorded mark.
|
|
||||||
*/
|
|
||||||
end?: number | string | undefined;
|
|
||||||
/**
|
|
||||||
* Timestamp to be used as the start time, or a string identifying a previously recorded mark.
|
|
||||||
*/
|
|
||||||
start?: number | string | undefined;
|
|
||||||
}
|
|
||||||
interface TimerifyOptions {
|
|
||||||
/**
|
|
||||||
* A histogram object created using
|
|
||||||
* `perf_hooks.createHistogram()` that will record runtime durations in
|
|
||||||
* nanoseconds.
|
|
||||||
*/
|
|
||||||
histogram?: RecordableHistogram | undefined;
|
|
||||||
}
|
|
||||||
interface Performance {
|
interface Performance {
|
||||||
/**
|
/**
|
||||||
* If name is not provided, removes all PerformanceMark objects from the Performance Timeline.
|
* If name is not provided, removes all PerformanceMark objects from the Performance Timeline.
|
||||||
@@ -191,6 +76,7 @@ declare module 'perf_hooks' {
|
|||||||
* @param name
|
* @param name
|
||||||
*/
|
*/
|
||||||
clearMarks(name?: string): void;
|
clearMarks(name?: string): void;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a new PerformanceMark entry in the Performance Timeline.
|
* Creates a new PerformanceMark entry in the Performance Timeline.
|
||||||
* A PerformanceMark is a subclass of PerformanceEntry whose performanceEntry.entryType is always 'mark',
|
* A PerformanceMark is a subclass of PerformanceEntry whose performanceEntry.entryType is always 'mark',
|
||||||
@@ -198,7 +84,8 @@ declare module 'perf_hooks' {
|
|||||||
* Performance marks are used to mark specific significant moments in the Performance Timeline.
|
* Performance marks are used to mark specific significant moments in the Performance Timeline.
|
||||||
* @param name
|
* @param name
|
||||||
*/
|
*/
|
||||||
mark(name?: string, options?: MarkOptions): void;
|
mark(name?: string): void;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a new PerformanceMeasure entry in the Performance Timeline.
|
* Creates a new PerformanceMeasure entry in the Performance Timeline.
|
||||||
* A PerformanceMeasure is a subclass of PerformanceEntry whose performanceEntry.entryType is always 'measure',
|
* A PerformanceMeasure is a subclass of PerformanceEntry whose performanceEntry.entryType is always 'measure',
|
||||||
@@ -214,344 +101,138 @@ declare module 'perf_hooks' {
|
|||||||
* @param startMark
|
* @param startMark
|
||||||
* @param endMark
|
* @param endMark
|
||||||
*/
|
*/
|
||||||
measure(name: string, startMark?: string, endMark?: string): void;
|
measure(name: string, startMark: string, endMark: string): void;
|
||||||
measure(name: string, options: MeasureOptions): void;
|
|
||||||
/**
|
/**
|
||||||
* An instance of the PerformanceNodeTiming class that provides performance metrics for specific Node.js operational milestones.
|
* An instance of the PerformanceNodeTiming class that provides performance metrics for specific Node.js operational milestones.
|
||||||
*/
|
*/
|
||||||
readonly nodeTiming: PerformanceNodeTiming;
|
readonly nodeTiming: PerformanceNodeTiming;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @return the current high resolution millisecond timestamp
|
* @return the current high resolution millisecond timestamp
|
||||||
*/
|
*/
|
||||||
now(): number;
|
now(): number;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The timeOrigin specifies the high resolution millisecond timestamp from which all performance metric durations are measured.
|
* The timeOrigin specifies the high resolution millisecond timestamp from which all performance metric durations are measured.
|
||||||
*/
|
*/
|
||||||
readonly timeOrigin: number;
|
readonly timeOrigin: number;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Wraps a function within a new function that measures the running time of the wrapped function.
|
* Wraps a function within a new function that measures the running time of the wrapped function.
|
||||||
* A PerformanceObserver must be subscribed to the 'function' event type in order for the timing details to be accessed.
|
* A PerformanceObserver must be subscribed to the 'function' event type in order for the timing details to be accessed.
|
||||||
* @param fn
|
* @param fn
|
||||||
*/
|
*/
|
||||||
timerify<T extends (...params: any[]) => any>(fn: T, options?: TimerifyOptions): T;
|
timerify<T extends (...optionalParams: any[]) => any>(fn: T): T;
|
||||||
/**
|
|
||||||
* eventLoopUtilization is similar to CPU utilization except that it is calculated using high precision wall-clock time.
|
|
||||||
* It represents the percentage of time the event loop has spent outside the event loop's event provider (e.g. epoll_wait).
|
|
||||||
* No other CPU idle time is taken into consideration.
|
|
||||||
*/
|
|
||||||
eventLoopUtilization: EventLoopUtilityFunction;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
interface PerformanceObserverEntryList {
|
interface PerformanceObserverEntryList {
|
||||||
/**
|
/**
|
||||||
* Returns a list of `PerformanceEntry` objects in chronological order
|
* @return a list of PerformanceEntry objects in chronological order with respect to performanceEntry.startTime.
|
||||||
* with respect to `performanceEntry.startTime`.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const {
|
|
||||||
* performance,
|
|
||||||
* PerformanceObserver
|
|
||||||
* } = require('perf_hooks');
|
|
||||||
*
|
|
||||||
* const obs = new PerformanceObserver((perfObserverList, observer) => {
|
|
||||||
* console.log(perfObserverList.getEntries());
|
|
||||||
*
|
|
||||||
* * [
|
|
||||||
* * PerformanceEntry {
|
|
||||||
* * name: 'test',
|
|
||||||
* * entryType: 'mark',
|
|
||||||
* * startTime: 81.465639,
|
|
||||||
* * duration: 0
|
|
||||||
* * },
|
|
||||||
* * PerformanceEntry {
|
|
||||||
* * name: 'meow',
|
|
||||||
* * entryType: 'mark',
|
|
||||||
* * startTime: 81.860064,
|
|
||||||
* * duration: 0
|
|
||||||
* * }
|
|
||||||
* * ]
|
|
||||||
*
|
|
||||||
* observer.disconnect();
|
|
||||||
* });
|
|
||||||
* obs.observe({ type: 'mark' });
|
|
||||||
*
|
|
||||||
* performance.mark('test');
|
|
||||||
* performance.mark('meow');
|
|
||||||
* ```
|
|
||||||
* @since v8.5.0
|
|
||||||
*/
|
*/
|
||||||
getEntries(): PerformanceEntry[];
|
getEntries(): PerformanceEntry[];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns a list of `PerformanceEntry` objects in chronological order
|
* @return a list of PerformanceEntry objects in chronological order with respect to performanceEntry.startTime
|
||||||
* with respect to `performanceEntry.startTime` whose `performanceEntry.name` is
|
* whose performanceEntry.name is equal to name, and optionally, whose performanceEntry.entryType is equal to type.
|
||||||
* equal to `name`, and optionally, whose `performanceEntry.entryType` is equal to`type`.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const {
|
|
||||||
* performance,
|
|
||||||
* PerformanceObserver
|
|
||||||
* } = require('perf_hooks');
|
|
||||||
*
|
|
||||||
* const obs = new PerformanceObserver((perfObserverList, observer) => {
|
|
||||||
* console.log(perfObserverList.getEntriesByName('meow'));
|
|
||||||
*
|
|
||||||
* * [
|
|
||||||
* * PerformanceEntry {
|
|
||||||
* * name: 'meow',
|
|
||||||
* * entryType: 'mark',
|
|
||||||
* * startTime: 98.545991,
|
|
||||||
* * duration: 0
|
|
||||||
* * }
|
|
||||||
* * ]
|
|
||||||
*
|
|
||||||
* console.log(perfObserverList.getEntriesByName('nope')); // []
|
|
||||||
*
|
|
||||||
* console.log(perfObserverList.getEntriesByName('test', 'mark'));
|
|
||||||
*
|
|
||||||
* * [
|
|
||||||
* * PerformanceEntry {
|
|
||||||
* * name: 'test',
|
|
||||||
* * entryType: 'mark',
|
|
||||||
* * startTime: 63.518931,
|
|
||||||
* * duration: 0
|
|
||||||
* * }
|
|
||||||
* * ]
|
|
||||||
*
|
|
||||||
* console.log(perfObserverList.getEntriesByName('test', 'measure')); // []
|
|
||||||
* observer.disconnect();
|
|
||||||
* });
|
|
||||||
* obs.observe({ entryTypes: ['mark', 'measure'] });
|
|
||||||
*
|
|
||||||
* performance.mark('test');
|
|
||||||
* performance.mark('meow');
|
|
||||||
* ```
|
|
||||||
* @since v8.5.0
|
|
||||||
*/
|
*/
|
||||||
getEntriesByName(name: string, type?: EntryType): PerformanceEntry[];
|
getEntriesByName(name: string, type?: string): PerformanceEntry[];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Returns a list of `PerformanceEntry` objects in chronological order
|
* @return Returns a list of PerformanceEntry objects in chronological order with respect to performanceEntry.startTime
|
||||||
* with respect to `performanceEntry.startTime` whose `performanceEntry.entryType`is equal to `type`.
|
* whose performanceEntry.entryType is equal to type.
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const {
|
|
||||||
* performance,
|
|
||||||
* PerformanceObserver
|
|
||||||
* } = require('perf_hooks');
|
|
||||||
*
|
|
||||||
* const obs = new PerformanceObserver((perfObserverList, observer) => {
|
|
||||||
* console.log(perfObserverList.getEntriesByType('mark'));
|
|
||||||
*
|
|
||||||
* * [
|
|
||||||
* * PerformanceEntry {
|
|
||||||
* * name: 'test',
|
|
||||||
* * entryType: 'mark',
|
|
||||||
* * startTime: 55.897834,
|
|
||||||
* * duration: 0
|
|
||||||
* * },
|
|
||||||
* * PerformanceEntry {
|
|
||||||
* * name: 'meow',
|
|
||||||
* * entryType: 'mark',
|
|
||||||
* * startTime: 56.350146,
|
|
||||||
* * duration: 0
|
|
||||||
* * }
|
|
||||||
* * ]
|
|
||||||
*
|
|
||||||
* observer.disconnect();
|
|
||||||
* });
|
|
||||||
* obs.observe({ type: 'mark' });
|
|
||||||
*
|
|
||||||
* performance.mark('test');
|
|
||||||
* performance.mark('meow');
|
|
||||||
* ```
|
|
||||||
* @since v8.5.0
|
|
||||||
*/
|
*/
|
||||||
getEntriesByType(type: EntryType): PerformanceEntry[];
|
getEntriesByType(type: string): PerformanceEntry[];
|
||||||
}
|
}
|
||||||
|
|
||||||
type PerformanceObserverCallback = (list: PerformanceObserverEntryList, observer: PerformanceObserver) => void;
|
type PerformanceObserverCallback = (list: PerformanceObserverEntryList, observer: PerformanceObserver) => void;
|
||||||
|
|
||||||
class PerformanceObserver extends AsyncResource {
|
class PerformanceObserver extends AsyncResource {
|
||||||
constructor(callback: PerformanceObserverCallback);
|
constructor(callback: PerformanceObserverCallback);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Disconnects the `PerformanceObserver` instance from all notifications.
|
* Disconnects the PerformanceObserver instance from all notifications.
|
||||||
* @since v8.5.0
|
|
||||||
*/
|
*/
|
||||||
disconnect(): void;
|
disconnect(): void;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Subscribes the `PerformanceObserver` instance to notifications of new `PerformanceEntry` instances identified either by `options.entryTypes`or `options.type`:
|
* Subscribes the PerformanceObserver instance to notifications of new PerformanceEntry instances identified by options.entryTypes.
|
||||||
*
|
* When options.buffered is false, the callback will be invoked once for every PerformanceEntry instance.
|
||||||
* ```js
|
* Property buffered defaults to false.
|
||||||
* const {
|
* @param options
|
||||||
* performance,
|
|
||||||
* PerformanceObserver
|
|
||||||
* } = require('perf_hooks');
|
|
||||||
*
|
|
||||||
* const obs = new PerformanceObserver((list, observer) => {
|
|
||||||
* // Called three times synchronously. `list` contains one item.
|
|
||||||
* });
|
|
||||||
* obs.observe({ type: 'mark' });
|
|
||||||
*
|
|
||||||
* for (let n = 0; n < 3; n++)
|
|
||||||
* performance.mark(`test${n}`);
|
|
||||||
* ```
|
|
||||||
* @since v8.5.0
|
|
||||||
*/
|
*/
|
||||||
observe(
|
observe(options: { entryTypes: ReadonlyArray<string>, buffered?: boolean }): void;
|
||||||
options:
|
|
||||||
| {
|
|
||||||
entryTypes: ReadonlyArray<EntryType>;
|
|
||||||
buffered?: boolean | undefined;
|
|
||||||
}
|
|
||||||
| {
|
|
||||||
type: EntryType;
|
|
||||||
buffered?: boolean | undefined;
|
|
||||||
}
|
|
||||||
): void;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
namespace constants {
|
namespace constants {
|
||||||
const NODE_PERFORMANCE_GC_MAJOR: number;
|
const NODE_PERFORMANCE_GC_MAJOR: number;
|
||||||
const NODE_PERFORMANCE_GC_MINOR: number;
|
const NODE_PERFORMANCE_GC_MINOR: number;
|
||||||
const NODE_PERFORMANCE_GC_INCREMENTAL: number;
|
const NODE_PERFORMANCE_GC_INCREMENTAL: number;
|
||||||
const NODE_PERFORMANCE_GC_WEAKCB: number;
|
const NODE_PERFORMANCE_GC_WEAKCB: number;
|
||||||
const NODE_PERFORMANCE_GC_FLAGS_NO: number;
|
|
||||||
const NODE_PERFORMANCE_GC_FLAGS_CONSTRUCT_RETAINED: number;
|
|
||||||
const NODE_PERFORMANCE_GC_FLAGS_FORCED: number;
|
|
||||||
const NODE_PERFORMANCE_GC_FLAGS_SYNCHRONOUS_PHANTOM_PROCESSING: number;
|
|
||||||
const NODE_PERFORMANCE_GC_FLAGS_ALL_AVAILABLE_GARBAGE: number;
|
|
||||||
const NODE_PERFORMANCE_GC_FLAGS_ALL_EXTERNAL_MEMORY: number;
|
|
||||||
const NODE_PERFORMANCE_GC_FLAGS_SCHEDULE_IDLE: number;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const performance: Performance;
|
const performance: Performance;
|
||||||
|
|
||||||
interface EventLoopMonitorOptions {
|
interface EventLoopMonitorOptions {
|
||||||
/**
|
/**
|
||||||
* The sampling rate in milliseconds.
|
* The sampling rate in milliseconds.
|
||||||
* Must be greater than zero.
|
* Must be greater than zero.
|
||||||
* @default 10
|
* @default 10
|
||||||
*/
|
*/
|
||||||
resolution?: number | undefined;
|
resolution?: number;
|
||||||
}
|
}
|
||||||
interface Histogram {
|
|
||||||
|
interface EventLoopDelayMonitor {
|
||||||
/**
|
/**
|
||||||
* Returns a `Map` object detailing the accumulated percentile distribution.
|
* Enables the event loop delay sample timer. Returns `true` if the timer was started, `false` if it was already started.
|
||||||
* @since v11.10.0
|
|
||||||
*/
|
|
||||||
readonly percentiles: Map<number, number>;
|
|
||||||
/**
|
|
||||||
* The number of times the event loop delay exceeded the maximum 1 hour event
|
|
||||||
* loop delay threshold.
|
|
||||||
* @since v11.10.0
|
|
||||||
*/
|
|
||||||
readonly exceeds: number;
|
|
||||||
/**
|
|
||||||
* The minimum recorded event loop delay.
|
|
||||||
* @since v11.10.0
|
|
||||||
*/
|
|
||||||
readonly min: number;
|
|
||||||
/**
|
|
||||||
* The maximum recorded event loop delay.
|
|
||||||
* @since v11.10.0
|
|
||||||
*/
|
|
||||||
readonly max: number;
|
|
||||||
/**
|
|
||||||
* The mean of the recorded event loop delays.
|
|
||||||
* @since v11.10.0
|
|
||||||
*/
|
|
||||||
readonly mean: number;
|
|
||||||
/**
|
|
||||||
* The standard deviation of the recorded event loop delays.
|
|
||||||
* @since v11.10.0
|
|
||||||
*/
|
|
||||||
readonly stddev: number;
|
|
||||||
/**
|
|
||||||
* Resets the collected histogram data.
|
|
||||||
* @since v11.10.0
|
|
||||||
*/
|
|
||||||
reset(): void;
|
|
||||||
/**
|
|
||||||
* Returns the value at the given percentile.
|
|
||||||
* @since v11.10.0
|
|
||||||
* @param percentile A percentile value in the range (0, 100].
|
|
||||||
*/
|
|
||||||
percentile(percentile: number): number;
|
|
||||||
}
|
|
||||||
interface IntervalHistogram extends Histogram {
|
|
||||||
/**
|
|
||||||
* Enables the update interval timer. Returns `true` if the timer was
|
|
||||||
* started, `false` if it was already started.
|
|
||||||
* @since v11.10.0
|
|
||||||
*/
|
*/
|
||||||
enable(): boolean;
|
enable(): boolean;
|
||||||
/**
|
/**
|
||||||
* Disables the update interval timer. Returns `true` if the timer was
|
* Disables the event loop delay sample timer. Returns `true` if the timer was stopped, `false` if it was already stopped.
|
||||||
* stopped, `false` if it was already stopped.
|
|
||||||
* @since v11.10.0
|
|
||||||
*/
|
*/
|
||||||
disable(): boolean;
|
disable(): boolean;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Resets the collected histogram data.
|
||||||
|
*/
|
||||||
|
reset(): void;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the value at the given percentile.
|
||||||
|
* @param percentile A percentile value between 1 and 100.
|
||||||
|
*/
|
||||||
|
percentile(percentile: number): number;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A `Map` object detailing the accumulated percentile distribution.
|
||||||
|
*/
|
||||||
|
readonly percentiles: Map<number, number>;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The number of times the event loop delay exceeded the maximum 1 hour eventloop delay threshold.
|
||||||
|
*/
|
||||||
|
readonly exceeds: number;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The minimum recorded event loop delay.
|
||||||
|
*/
|
||||||
|
readonly min: number;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The maximum recorded event loop delay.
|
||||||
|
*/
|
||||||
|
readonly max: number;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The mean of the recorded event loop delays.
|
||||||
|
*/
|
||||||
|
readonly mean: number;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The standard deviation of the recorded event loop delays.
|
||||||
|
*/
|
||||||
|
readonly stddev: number;
|
||||||
}
|
}
|
||||||
interface RecordableHistogram extends Histogram {
|
|
||||||
/**
|
function monitorEventLoopDelay(options?: EventLoopMonitorOptions): EventLoopDelayMonitor;
|
||||||
* @since v15.9.0
|
|
||||||
* @param val The amount to record in the histogram.
|
|
||||||
*/
|
|
||||||
record(val: number | bigint): void;
|
|
||||||
/**
|
|
||||||
* Calculates the amount of time (in nanoseconds) that has passed since the
|
|
||||||
* previous call to `recordDelta()` and records that amount in the histogram.
|
|
||||||
*
|
|
||||||
* ## Examples
|
|
||||||
* @since v15.9.0
|
|
||||||
*/
|
|
||||||
recordDelta(): void;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* _This property is an extension by Node.js. It is not available in Web browsers._
|
|
||||||
*
|
|
||||||
* Creates an `IntervalHistogram` object that samples and reports the event loop
|
|
||||||
* delay over time. The delays will be reported in nanoseconds.
|
|
||||||
*
|
|
||||||
* Using a timer to detect approximate event loop delay works because the
|
|
||||||
* execution of timers is tied specifically to the lifecycle of the libuv
|
|
||||||
* event loop. That is, a delay in the loop will cause a delay in the execution
|
|
||||||
* of the timer, and those delays are specifically what this API is intended to
|
|
||||||
* detect.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const { monitorEventLoopDelay } = require('perf_hooks');
|
|
||||||
* const h = monitorEventLoopDelay({ resolution: 20 });
|
|
||||||
* h.enable();
|
|
||||||
* // Do something.
|
|
||||||
* h.disable();
|
|
||||||
* console.log(h.min);
|
|
||||||
* console.log(h.max);
|
|
||||||
* console.log(h.mean);
|
|
||||||
* console.log(h.stddev);
|
|
||||||
* console.log(h.percentiles);
|
|
||||||
* console.log(h.percentile(50));
|
|
||||||
* console.log(h.percentile(99));
|
|
||||||
* ```
|
|
||||||
* @since v11.10.0
|
|
||||||
*/
|
|
||||||
function monitorEventLoopDelay(options?: EventLoopMonitorOptions): IntervalHistogram;
|
|
||||||
interface CreateHistogramOptions {
|
|
||||||
/**
|
|
||||||
* The minimum recordable value. Must be an integer value greater than 0.
|
|
||||||
* @default 1
|
|
||||||
*/
|
|
||||||
min?: number | bigint | undefined;
|
|
||||||
/**
|
|
||||||
* The maximum recordable value. Must be an integer value greater than min.
|
|
||||||
* @default Number.MAX_SAFE_INTEGER
|
|
||||||
*/
|
|
||||||
max?: number | bigint | undefined;
|
|
||||||
/**
|
|
||||||
* The number of accuracy digits. Must be a number between 1 and 5.
|
|
||||||
* @default 3
|
|
||||||
*/
|
|
||||||
figures?: number | undefined;
|
|
||||||
}
|
|
||||||
/**
|
|
||||||
* Returns a `RecordableHistogram`.
|
|
||||||
* @since v15.9.0
|
|
||||||
*/
|
|
||||||
function createHistogram(options?: CreateHistogramOptions): RecordableHistogram;
|
|
||||||
}
|
|
||||||
declare module 'node:perf_hooks' {
|
|
||||||
export * from 'perf_hooks';
|
|
||||||
}
|
}
|
||||||
|
|||||||
1474
node_modules/@types/node/process.d.ts
generated
vendored
Executable file → Normal file
1474
node_modules/@types/node/process.d.ts
generated
vendored
Executable file → Normal file
File diff suppressed because it is too large
Load Diff
91
node_modules/@types/node/punycode.d.ts
generated
vendored
Executable file → Normal file
91
node_modules/@types/node/punycode.d.ts
generated
vendored
Executable file → Normal file
@@ -1,80 +1,34 @@
|
|||||||
/**
|
declare module "punycode" {
|
||||||
* **The version of the punycode module bundled in Node.js is being deprecated.**In a future major version of Node.js this module will be removed. Users
|
|
||||||
* currently depending on the `punycode` module should switch to using the
|
|
||||||
* userland-provided [Punycode.js](https://github.com/bestiejs/punycode.js) module instead. For punycode-based URL
|
|
||||||
* encoding, see `url.domainToASCII` or, more generally, the `WHATWG URL API`.
|
|
||||||
*
|
|
||||||
* The `punycode` module is a bundled version of the [Punycode.js](https://github.com/bestiejs/punycode.js) module. It
|
|
||||||
* can be accessed using:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const punycode = require('punycode');
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* [Punycode](https://tools.ietf.org/html/rfc3492) is a character encoding scheme defined by RFC 3492 that is
|
|
||||||
* primarily intended for use in Internationalized Domain Names. Because host
|
|
||||||
* names in URLs are limited to ASCII characters only, Domain Names that contain
|
|
||||||
* non-ASCII characters must be converted into ASCII using the Punycode scheme.
|
|
||||||
* For instance, the Japanese character that translates into the English word,`'example'` is `'例'`. The Internationalized Domain Name, `'例.com'` (equivalent
|
|
||||||
* to `'example.com'`) is represented by Punycode as the ASCII string`'xn--fsq.com'`.
|
|
||||||
*
|
|
||||||
* The `punycode` module provides a simple implementation of the Punycode standard.
|
|
||||||
*
|
|
||||||
* The `punycode` module is a third-party dependency used by Node.js and
|
|
||||||
* made available to developers as a convenience. Fixes or other modifications to
|
|
||||||
* the module must be directed to the [Punycode.js](https://github.com/bestiejs/punycode.js) project.
|
|
||||||
* @deprecated Since v7.0.0 - Deprecated
|
|
||||||
* @see [source](https://github.com/nodejs/node/blob/v16.9.0/lib/punycode.js)
|
|
||||||
*/
|
|
||||||
declare module 'punycode' {
|
|
||||||
/**
|
/**
|
||||||
* The `punycode.decode()` method converts a [Punycode](https://tools.ietf.org/html/rfc3492) string of ASCII-only
|
* @deprecated since v7.0.0
|
||||||
* characters to the equivalent string of Unicode codepoints.
|
* The version of the punycode module bundled in Node.js is being deprecated.
|
||||||
*
|
* In a future major version of Node.js this module will be removed.
|
||||||
* ```js
|
* Users currently depending on the punycode module should switch to using
|
||||||
* punycode.decode('maana-pta'); // 'mañana'
|
* the userland-provided Punycode.js module instead.
|
||||||
* punycode.decode('--dqo34k'); // '☃-⌘'
|
|
||||||
* ```
|
|
||||||
* @since v0.5.1
|
|
||||||
*/
|
*/
|
||||||
function decode(string: string): string;
|
function decode(string: string): string;
|
||||||
/**
|
/**
|
||||||
* The `punycode.encode()` method converts a string of Unicode codepoints to a [Punycode](https://tools.ietf.org/html/rfc3492) string of ASCII-only characters.
|
* @deprecated since v7.0.0
|
||||||
*
|
* The version of the punycode module bundled in Node.js is being deprecated.
|
||||||
* ```js
|
* In a future major version of Node.js this module will be removed.
|
||||||
* punycode.encode('mañana'); // 'maana-pta'
|
* Users currently depending on the punycode module should switch to using
|
||||||
* punycode.encode('☃-⌘'); // '--dqo34k'
|
* the userland-provided Punycode.js module instead.
|
||||||
* ```
|
|
||||||
* @since v0.5.1
|
|
||||||
*/
|
*/
|
||||||
function encode(string: string): string;
|
function encode(string: string): string;
|
||||||
/**
|
/**
|
||||||
* The `punycode.toUnicode()` method converts a string representing a domain name
|
* @deprecated since v7.0.0
|
||||||
* containing [Punycode](https://tools.ietf.org/html/rfc3492) encoded characters into Unicode. Only the [Punycode](https://tools.ietf.org/html/rfc3492) encoded parts of the domain name are be
|
* The version of the punycode module bundled in Node.js is being deprecated.
|
||||||
* converted.
|
* In a future major version of Node.js this module will be removed.
|
||||||
*
|
* Users currently depending on the punycode module should switch to using
|
||||||
* ```js
|
* the userland-provided Punycode.js module instead.
|
||||||
* // decode domain names
|
|
||||||
* punycode.toUnicode('xn--maana-pta.com'); // 'mañana.com'
|
|
||||||
* punycode.toUnicode('xn----dqo34k.com'); // '☃-⌘.com'
|
|
||||||
* punycode.toUnicode('example.com'); // 'example.com'
|
|
||||||
* ```
|
|
||||||
* @since v0.6.1
|
|
||||||
*/
|
*/
|
||||||
function toUnicode(domain: string): string;
|
function toUnicode(domain: string): string;
|
||||||
/**
|
/**
|
||||||
* The `punycode.toASCII()` method converts a Unicode string representing an
|
* @deprecated since v7.0.0
|
||||||
* Internationalized Domain Name to [Punycode](https://tools.ietf.org/html/rfc3492). Only the non-ASCII parts of the
|
* The version of the punycode module bundled in Node.js is being deprecated.
|
||||||
* domain name will be converted. Calling `punycode.toASCII()` on a string that
|
* In a future major version of Node.js this module will be removed.
|
||||||
* already only contains ASCII characters will have no effect.
|
* Users currently depending on the punycode module should switch to using
|
||||||
*
|
* the userland-provided Punycode.js module instead.
|
||||||
* ```js
|
|
||||||
* // encode domain names
|
|
||||||
* punycode.toASCII('mañana.com'); // 'xn--maana-pta.com'
|
|
||||||
* punycode.toASCII('☃-⌘.com'); // 'xn----dqo34k.com'
|
|
||||||
* punycode.toASCII('example.com'); // 'example.com'
|
|
||||||
* ```
|
|
||||||
* @since v0.6.1
|
|
||||||
*/
|
*/
|
||||||
function toASCII(domain: string): string;
|
function toASCII(domain: string): string;
|
||||||
/**
|
/**
|
||||||
@@ -112,6 +66,3 @@ declare module 'punycode' {
|
|||||||
*/
|
*/
|
||||||
const version: string;
|
const version: string;
|
||||||
}
|
}
|
||||||
declare module 'node:punycode' {
|
|
||||||
export * from 'punycode';
|
|
||||||
}
|
|
||||||
|
|||||||
126
node_modules/@types/node/querystring.d.ts
generated
vendored
Executable file → Normal file
126
node_modules/@types/node/querystring.d.ts
generated
vendored
Executable file → Normal file
@@ -1,95 +1,20 @@
|
|||||||
/**
|
declare module "querystring" {
|
||||||
* The `querystring` module provides utilities for parsing and formatting URL
|
|
||||||
* query strings. It can be accessed using:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const querystring = require('querystring');
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* The `querystring` API is considered Legacy. While it is still maintained,
|
|
||||||
* new code should use the `URLSearchParams` API instead.
|
|
||||||
* @deprecated Legacy
|
|
||||||
* @see [source](https://github.com/nodejs/node/blob/v16.9.0/lib/querystring.js)
|
|
||||||
*/
|
|
||||||
declare module 'querystring' {
|
|
||||||
interface StringifyOptions {
|
interface StringifyOptions {
|
||||||
encodeURIComponent?: ((str: string) => string) | undefined;
|
encodeURIComponent?: (str: string) => string;
|
||||||
}
|
}
|
||||||
|
|
||||||
interface ParseOptions {
|
interface ParseOptions {
|
||||||
maxKeys?: number | undefined;
|
maxKeys?: number;
|
||||||
decodeURIComponent?: ((str: string) => string) | undefined;
|
decodeURIComponent?: (str: string) => string;
|
||||||
}
|
}
|
||||||
interface ParsedUrlQuery extends NodeJS.Dict<string | string[]> {}
|
|
||||||
interface ParsedUrlQueryInput extends NodeJS.Dict<string | number | boolean | ReadonlyArray<string> | ReadonlyArray<number> | ReadonlyArray<boolean> | null> {}
|
interface ParsedUrlQuery { [key: string]: string | string[]; }
|
||||||
/**
|
|
||||||
* The `querystring.stringify()` method produces a URL query string from a
|
interface ParsedUrlQueryInput {
|
||||||
* given `obj` by iterating through the object's "own properties".
|
[key: string]: string | number | boolean | ReadonlyArray<string> | ReadonlyArray<number> | ReadonlyArray<boolean> | undefined | null;
|
||||||
*
|
}
|
||||||
* It serializes the following types of values passed in `obj`:[string](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures#String_type) |
|
|
||||||
* [number](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures#Number_type) |
|
|
||||||
* [bigint](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/BigInt) |
|
|
||||||
* [boolean](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures#Boolean_type) |
|
|
||||||
* [string\[\]](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures#String_type) |
|
|
||||||
* [number\[\]](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures#Number_type) |
|
|
||||||
* [bigint\[\]](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/BigInt) |
|
|
||||||
* [boolean\[\]](https://developer.mozilla.org/en-US/docs/Web/JavaScript/Data_structures#Boolean_type) The numeric values must be finite. Any other input values will be coerced to
|
|
||||||
* empty strings.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* querystring.stringify({ foo: 'bar', baz: ['qux', 'quux'], corge: '' });
|
|
||||||
* // Returns 'foo=bar&baz=qux&baz=quux&corge='
|
|
||||||
*
|
|
||||||
* querystring.stringify({ foo: 'bar', baz: 'qux' }, ';', ':');
|
|
||||||
* // Returns 'foo:bar;baz:qux'
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* By default, characters requiring percent-encoding within the query string will
|
|
||||||
* be encoded as UTF-8\. If an alternative encoding is required, then an alternative`encodeURIComponent` option will need to be specified:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* // Assuming gbkEncodeURIComponent function already exists,
|
|
||||||
*
|
|
||||||
* querystring.stringify({ w: '中文', foo: 'bar' }, null, null,
|
|
||||||
* { encodeURIComponent: gbkEncodeURIComponent });
|
|
||||||
* ```
|
|
||||||
* @since v0.1.25
|
|
||||||
* @param obj The object to serialize into a URL query string
|
|
||||||
* @param [sep='&'] The substring used to delimit key and value pairs in the query string.
|
|
||||||
* @param [eq='='] . The substring used to delimit keys and values in the query string.
|
|
||||||
*/
|
|
||||||
function stringify(obj?: ParsedUrlQueryInput, sep?: string, eq?: string, options?: StringifyOptions): string;
|
function stringify(obj?: ParsedUrlQueryInput, sep?: string, eq?: string, options?: StringifyOptions): string;
|
||||||
/**
|
|
||||||
* The `querystring.parse()` method parses a URL query string (`str`) into a
|
|
||||||
* collection of key and value pairs.
|
|
||||||
*
|
|
||||||
* For example, the query string `'foo=bar&abc=xyz&abc=123'` is parsed into:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* {
|
|
||||||
* foo: 'bar',
|
|
||||||
* abc: ['xyz', '123']
|
|
||||||
* }
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* The object returned by the `querystring.parse()` method _does not_prototypically inherit from the JavaScript `Object`. This means that typical`Object` methods such as `obj.toString()`,
|
|
||||||
* `obj.hasOwnProperty()`, and others
|
|
||||||
* are not defined and _will not work_.
|
|
||||||
*
|
|
||||||
* By default, percent-encoded characters within the query string will be assumed
|
|
||||||
* to use UTF-8 encoding. If an alternative character encoding is used, then an
|
|
||||||
* alternative `decodeURIComponent` option will need to be specified:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* // Assuming gbkDecodeURIComponent function already exists...
|
|
||||||
*
|
|
||||||
* querystring.parse('w=%D6%D0%CE%C4&foo=bar', null, null,
|
|
||||||
* { decodeURIComponent: gbkDecodeURIComponent });
|
|
||||||
* ```
|
|
||||||
* @since v0.1.25
|
|
||||||
* @param str The URL query string to parse
|
|
||||||
* @param [sep='&'] The substring used to delimit key and value pairs in the query string.
|
|
||||||
* @param [eq='='] . The substring used to delimit keys and values in the query string.
|
|
||||||
*/
|
|
||||||
function parse(str: string, sep?: string, eq?: string, options?: ParseOptions): ParsedUrlQuery;
|
function parse(str: string, sep?: string, eq?: string, options?: ParseOptions): ParsedUrlQuery;
|
||||||
/**
|
/**
|
||||||
* The querystring.encode() function is an alias for querystring.stringify().
|
* The querystring.encode() function is an alias for querystring.stringify().
|
||||||
@@ -99,33 +24,6 @@ declare module 'querystring' {
|
|||||||
* The querystring.decode() function is an alias for querystring.parse().
|
* The querystring.decode() function is an alias for querystring.parse().
|
||||||
*/
|
*/
|
||||||
const decode: typeof parse;
|
const decode: typeof parse;
|
||||||
/**
|
|
||||||
* The `querystring.escape()` method performs URL percent-encoding on the given`str` in a manner that is optimized for the specific requirements of URL
|
|
||||||
* query strings.
|
|
||||||
*
|
|
||||||
* The `querystring.escape()` method is used by `querystring.stringify()` and is
|
|
||||||
* generally not expected to be used directly. It is exported primarily to allow
|
|
||||||
* application code to provide a replacement percent-encoding implementation if
|
|
||||||
* necessary by assigning `querystring.escape` to an alternative function.
|
|
||||||
* @since v0.1.25
|
|
||||||
*/
|
|
||||||
function escape(str: string): string;
|
function escape(str: string): string;
|
||||||
/**
|
|
||||||
* The `querystring.unescape()` method performs decoding of URL percent-encoded
|
|
||||||
* characters on the given `str`.
|
|
||||||
*
|
|
||||||
* The `querystring.unescape()` method is used by `querystring.parse()` and is
|
|
||||||
* generally not expected to be used directly. It is exported primarily to allow
|
|
||||||
* application code to provide a replacement decoding implementation if
|
|
||||||
* necessary by assigning `querystring.unescape` to an alternative function.
|
|
||||||
*
|
|
||||||
* By default, the `querystring.unescape()` method will attempt to use the
|
|
||||||
* JavaScript built-in `decodeURIComponent()` method to decode. If that fails,
|
|
||||||
* a safer equivalent that does not throw on malformed URLs will be used.
|
|
||||||
* @since v0.1.25
|
|
||||||
*/
|
|
||||||
function unescape(str: string): string;
|
function unescape(str: string): string;
|
||||||
}
|
}
|
||||||
declare module 'node:querystring' {
|
|
||||||
export * from 'querystring';
|
|
||||||
}
|
|
||||||
|
|||||||
561
node_modules/@types/node/readline.d.ts
generated
vendored
Executable file → Normal file
561
node_modules/@types/node/readline.d.ts
generated
vendored
Executable file → Normal file
@@ -1,92 +1,25 @@
|
|||||||
/**
|
declare module "readline" {
|
||||||
* The `readline` module provides an interface for reading data from a `Readable` stream (such as `process.stdin`) one line at a time. It can be accessed
|
import * as events from "events";
|
||||||
* using:
|
import * as stream from "stream";
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const readline = require('readline');
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* The following simple example illustrates the basic use of the `readline` module.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const readline = require('readline');
|
|
||||||
*
|
|
||||||
* const rl = readline.createInterface({
|
|
||||||
* input: process.stdin,
|
|
||||||
* output: process.stdout
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* rl.question('What do you think of Node.js? ', (answer) => {
|
|
||||||
* // TODO: Log the answer in a database
|
|
||||||
* console.log(`Thank you for your valuable feedback: ${answer}`);
|
|
||||||
*
|
|
||||||
* rl.close();
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Once this code is invoked, the Node.js application will not terminate until the`readline.Interface` is closed because the interface waits for data to be
|
|
||||||
* received on the `input` stream.
|
|
||||||
* @see [source](https://github.com/nodejs/node/blob/v16.9.0/lib/readline.js)
|
|
||||||
*/
|
|
||||||
declare module 'readline' {
|
|
||||||
import { Abortable, EventEmitter } from 'node:events';
|
|
||||||
interface Key {
|
interface Key {
|
||||||
sequence?: string | undefined;
|
sequence?: string;
|
||||||
name?: string | undefined;
|
name?: string;
|
||||||
ctrl?: boolean | undefined;
|
ctrl?: boolean;
|
||||||
meta?: boolean | undefined;
|
meta?: boolean;
|
||||||
shift?: boolean | undefined;
|
shift?: boolean;
|
||||||
}
|
}
|
||||||
/**
|
|
||||||
* Instances of the `readline.Interface` class are constructed using the`readline.createInterface()` method. Every instance is associated with a
|
class Interface extends events.EventEmitter {
|
||||||
* single `input` `Readable` stream and a single `output` `Writable` stream.
|
|
||||||
* The `output` stream is used to print prompts for user input that arrives on,
|
|
||||||
* and is read from, the `input` stream.
|
|
||||||
* @since v0.1.104
|
|
||||||
*/
|
|
||||||
class Interface extends EventEmitter {
|
|
||||||
readonly terminal: boolean;
|
readonly terminal: boolean;
|
||||||
/**
|
|
||||||
* The current input data being processed by node.
|
// Need direct access to line/cursor data, for use in external processes
|
||||||
*
|
// see: https://github.com/nodejs/node/issues/30347
|
||||||
* This can be used when collecting input from a TTY stream to retrieve the
|
/** The current input data */
|
||||||
* current value that has been processed thus far, prior to the `line` event
|
|
||||||
* being emitted. Once the `line` event has been emitted, this property will
|
|
||||||
* be an empty string.
|
|
||||||
*
|
|
||||||
* Be aware that modifying the value during the instance runtime may have
|
|
||||||
* unintended consequences if `rl.cursor` is not also controlled.
|
|
||||||
*
|
|
||||||
* **If not using a TTY stream for input, use the `'line'` event.**
|
|
||||||
*
|
|
||||||
* One possible use case would be as follows:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const values = ['lorem ipsum', 'dolor sit amet'];
|
|
||||||
* const rl = readline.createInterface(process.stdin);
|
|
||||||
* const showResults = debounce(() => {
|
|
||||||
* console.log(
|
|
||||||
* '\n',
|
|
||||||
* values.filter((val) => val.startsWith(rl.line)).join(' ')
|
|
||||||
* );
|
|
||||||
* }, 300);
|
|
||||||
* process.stdin.on('keypress', (c, k) => {
|
|
||||||
* showResults();
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
* @since v0.1.98
|
|
||||||
*/
|
|
||||||
readonly line: string;
|
readonly line: string;
|
||||||
/**
|
/** The current cursor position in the input line */
|
||||||
* The cursor position relative to `rl.line`.
|
|
||||||
*
|
|
||||||
* This will track where the current cursor lands in the input string, when
|
|
||||||
* reading input from a TTY stream. The position of cursor determines the
|
|
||||||
* portion of the input string that will be modified as input is processed,
|
|
||||||
* as well as the column where the terminal caret will be rendered.
|
|
||||||
* @since v0.1.98
|
|
||||||
*/
|
|
||||||
readonly cursor: number;
|
readonly cursor: number;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* NOTE: According to the documentation:
|
* NOTE: According to the documentation:
|
||||||
*
|
*
|
||||||
@@ -105,145 +38,15 @@ declare module 'readline' {
|
|||||||
* @see https://nodejs.org/dist/latest-v10.x/docs/api/readline.html#readline_class_interface
|
* @see https://nodejs.org/dist/latest-v10.x/docs/api/readline.html#readline_class_interface
|
||||||
*/
|
*/
|
||||||
protected constructor(options: ReadLineOptions);
|
protected constructor(options: ReadLineOptions);
|
||||||
/**
|
|
||||||
* The `rl.getPrompt()` method returns the current prompt used by `rl.prompt()`.
|
|
||||||
* @since v15.3.0
|
|
||||||
* @return the current prompt string
|
|
||||||
*/
|
|
||||||
getPrompt(): string;
|
|
||||||
/**
|
|
||||||
* The `rl.setPrompt()` method sets the prompt that will be written to `output`whenever `rl.prompt()` is called.
|
|
||||||
* @since v0.1.98
|
|
||||||
*/
|
|
||||||
setPrompt(prompt: string): void;
|
setPrompt(prompt: string): void;
|
||||||
/**
|
|
||||||
* The `rl.prompt()` method writes the `readline.Interface` instances configured`prompt` to a new line in `output` in order to provide a user with a new
|
|
||||||
* location at which to provide input.
|
|
||||||
*
|
|
||||||
* When called, `rl.prompt()` will resume the `input` stream if it has been
|
|
||||||
* paused.
|
|
||||||
*
|
|
||||||
* If the `readline.Interface` was created with `output` set to `null` or`undefined` the prompt is not written.
|
|
||||||
* @since v0.1.98
|
|
||||||
* @param preserveCursor If `true`, prevents the cursor placement from being reset to `0`.
|
|
||||||
*/
|
|
||||||
prompt(preserveCursor?: boolean): void;
|
prompt(preserveCursor?: boolean): void;
|
||||||
/**
|
|
||||||
* The `rl.question()` method displays the `query` by writing it to the `output`,
|
|
||||||
* waits for user input to be provided on `input`, then invokes the `callback`function passing the provided input as the first argument.
|
|
||||||
*
|
|
||||||
* When called, `rl.question()` will resume the `input` stream if it has been
|
|
||||||
* paused.
|
|
||||||
*
|
|
||||||
* If the `readline.Interface` was created with `output` set to `null` or`undefined` the `query` is not written.
|
|
||||||
*
|
|
||||||
* The `callback` function passed to `rl.question()` does not follow the typical
|
|
||||||
* pattern of accepting an `Error` object or `null` as the first argument.
|
|
||||||
* The `callback` is called with the provided answer as the only argument.
|
|
||||||
*
|
|
||||||
* Example usage:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* rl.question('What is your favorite food? ', (answer) => {
|
|
||||||
* console.log(`Oh, so your favorite food is ${answer}`);
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Using an `AbortController` to cancel a question.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const ac = new AbortController();
|
|
||||||
* const signal = ac.signal;
|
|
||||||
*
|
|
||||||
* rl.question('What is your favorite food? ', { signal }, (answer) => {
|
|
||||||
* console.log(`Oh, so your favorite food is ${answer}`);
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* signal.addEventListener('abort', () => {
|
|
||||||
* console.log('The food question timed out');
|
|
||||||
* }, { once: true });
|
|
||||||
*
|
|
||||||
* setTimeout(() => ac.abort(), 10000);
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* If this method is invoked as it's util.promisify()ed version, it returns a
|
|
||||||
* Promise that fulfills with the answer. If the question is canceled using
|
|
||||||
* an `AbortController` it will reject with an `AbortError`.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const util = require('util');
|
|
||||||
* const question = util.promisify(rl.question).bind(rl);
|
|
||||||
*
|
|
||||||
* async function questionExample() {
|
|
||||||
* try {
|
|
||||||
* const answer = await question('What is you favorite food? ');
|
|
||||||
* console.log(`Oh, so your favorite food is ${answer}`);
|
|
||||||
* } catch (err) {
|
|
||||||
* console.error('Question rejected', err);
|
|
||||||
* }
|
|
||||||
* }
|
|
||||||
* questionExample();
|
|
||||||
* ```
|
|
||||||
* @since v0.3.3
|
|
||||||
* @param query A statement or query to write to `output`, prepended to the prompt.
|
|
||||||
* @param callback A callback function that is invoked with the user's input in response to the `query`.
|
|
||||||
*/
|
|
||||||
question(query: string, callback: (answer: string) => void): void;
|
question(query: string, callback: (answer: string) => void): void;
|
||||||
question(query: string, options: Abortable, callback: (answer: string) => void): void;
|
|
||||||
/**
|
|
||||||
* The `rl.pause()` method pauses the `input` stream, allowing it to be resumed
|
|
||||||
* later if necessary.
|
|
||||||
*
|
|
||||||
* Calling `rl.pause()` does not immediately pause other events (including`'line'`) from being emitted by the `readline.Interface` instance.
|
|
||||||
* @since v0.3.4
|
|
||||||
*/
|
|
||||||
pause(): this;
|
pause(): this;
|
||||||
/**
|
|
||||||
* The `rl.resume()` method resumes the `input` stream if it has been paused.
|
|
||||||
* @since v0.3.4
|
|
||||||
*/
|
|
||||||
resume(): this;
|
resume(): this;
|
||||||
/**
|
|
||||||
* The `rl.close()` method closes the `readline.Interface` instance and
|
|
||||||
* relinquishes control over the `input` and `output` streams. When called,
|
|
||||||
* the `'close'` event will be emitted.
|
|
||||||
*
|
|
||||||
* Calling `rl.close()` does not immediately stop other events (including `'line'`)
|
|
||||||
* from being emitted by the `readline.Interface` instance.
|
|
||||||
* @since v0.1.98
|
|
||||||
*/
|
|
||||||
close(): void;
|
close(): void;
|
||||||
/**
|
|
||||||
* The `rl.write()` method will write either `data` or a key sequence identified
|
|
||||||
* by `key` to the `output`. The `key` argument is supported only if `output` is
|
|
||||||
* a `TTY` text terminal. See `TTY keybindings` for a list of key
|
|
||||||
* combinations.
|
|
||||||
*
|
|
||||||
* If `key` is specified, `data` is ignored.
|
|
||||||
*
|
|
||||||
* When called, `rl.write()` will resume the `input` stream if it has been
|
|
||||||
* paused.
|
|
||||||
*
|
|
||||||
* If the `readline.Interface` was created with `output` set to `null` or`undefined` the `data` and `key` are not written.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* rl.write('Delete this!');
|
|
||||||
* // Simulate Ctrl+U to delete the line written previously
|
|
||||||
* rl.write(null, { ctrl: true, name: 'u' });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* The `rl.write()` method will write the data to the `readline` `Interface`'s`input`_as if it were provided by the user_.
|
|
||||||
* @since v0.1.98
|
|
||||||
*/
|
|
||||||
write(data: string | Buffer, key?: Key): void;
|
write(data: string | Buffer, key?: Key): void;
|
||||||
write(data: undefined | null | string | Buffer, key: Key): void;
|
|
||||||
/**
|
|
||||||
* Returns the real position of the cursor in relation to the input
|
|
||||||
* prompt + string. Long input (wrapping) strings, as well as multiple
|
|
||||||
* line prompts are included in the calculations.
|
|
||||||
* @since v13.5.0, v12.16.0
|
|
||||||
*/
|
|
||||||
getCursorPos(): CursorPos;
|
|
||||||
/**
|
/**
|
||||||
* events.EventEmitter
|
* events.EventEmitter
|
||||||
* 1. close
|
* 1. close
|
||||||
@@ -253,291 +56,103 @@ declare module 'readline' {
|
|||||||
* 5. SIGCONT
|
* 5. SIGCONT
|
||||||
* 6. SIGINT
|
* 6. SIGINT
|
||||||
* 7. SIGTSTP
|
* 7. SIGTSTP
|
||||||
* 8. history
|
|
||||||
*/
|
*/
|
||||||
|
|
||||||
addListener(event: string, listener: (...args: any[]) => void): this;
|
addListener(event: string, listener: (...args: any[]) => void): this;
|
||||||
addListener(event: 'close', listener: () => void): this;
|
addListener(event: "close", listener: () => void): this;
|
||||||
addListener(event: 'line', listener: (input: string) => void): this;
|
addListener(event: "line", listener: (input: string) => void): this;
|
||||||
addListener(event: 'pause', listener: () => void): this;
|
addListener(event: "pause", listener: () => void): this;
|
||||||
addListener(event: 'resume', listener: () => void): this;
|
addListener(event: "resume", listener: () => void): this;
|
||||||
addListener(event: 'SIGCONT', listener: () => void): this;
|
addListener(event: "SIGCONT", listener: () => void): this;
|
||||||
addListener(event: 'SIGINT', listener: () => void): this;
|
addListener(event: "SIGINT", listener: () => void): this;
|
||||||
addListener(event: 'SIGTSTP', listener: () => void): this;
|
addListener(event: "SIGTSTP", listener: () => void): this;
|
||||||
addListener(event: 'history', listener: (history: string[]) => void): this;
|
|
||||||
emit(event: string | symbol, ...args: any[]): boolean;
|
emit(event: string | symbol, ...args: any[]): boolean;
|
||||||
emit(event: 'close'): boolean;
|
emit(event: "close"): boolean;
|
||||||
emit(event: 'line', input: string): boolean;
|
emit(event: "line", input: string): boolean;
|
||||||
emit(event: 'pause'): boolean;
|
emit(event: "pause"): boolean;
|
||||||
emit(event: 'resume'): boolean;
|
emit(event: "resume"): boolean;
|
||||||
emit(event: 'SIGCONT'): boolean;
|
emit(event: "SIGCONT"): boolean;
|
||||||
emit(event: 'SIGINT'): boolean;
|
emit(event: "SIGINT"): boolean;
|
||||||
emit(event: 'SIGTSTP'): boolean;
|
emit(event: "SIGTSTP"): boolean;
|
||||||
emit(event: 'history', history: string[]): boolean;
|
|
||||||
on(event: string, listener: (...args: any[]) => void): this;
|
on(event: string, listener: (...args: any[]) => void): this;
|
||||||
on(event: 'close', listener: () => void): this;
|
on(event: "close", listener: () => void): this;
|
||||||
on(event: 'line', listener: (input: string) => void): this;
|
on(event: "line", listener: (input: string) => void): this;
|
||||||
on(event: 'pause', listener: () => void): this;
|
on(event: "pause", listener: () => void): this;
|
||||||
on(event: 'resume', listener: () => void): this;
|
on(event: "resume", listener: () => void): this;
|
||||||
on(event: 'SIGCONT', listener: () => void): this;
|
on(event: "SIGCONT", listener: () => void): this;
|
||||||
on(event: 'SIGINT', listener: () => void): this;
|
on(event: "SIGINT", listener: () => void): this;
|
||||||
on(event: 'SIGTSTP', listener: () => void): this;
|
on(event: "SIGTSTP", listener: () => void): this;
|
||||||
on(event: 'history', listener: (history: string[]) => void): this;
|
|
||||||
once(event: string, listener: (...args: any[]) => void): this;
|
once(event: string, listener: (...args: any[]) => void): this;
|
||||||
once(event: 'close', listener: () => void): this;
|
once(event: "close", listener: () => void): this;
|
||||||
once(event: 'line', listener: (input: string) => void): this;
|
once(event: "line", listener: (input: string) => void): this;
|
||||||
once(event: 'pause', listener: () => void): this;
|
once(event: "pause", listener: () => void): this;
|
||||||
once(event: 'resume', listener: () => void): this;
|
once(event: "resume", listener: () => void): this;
|
||||||
once(event: 'SIGCONT', listener: () => void): this;
|
once(event: "SIGCONT", listener: () => void): this;
|
||||||
once(event: 'SIGINT', listener: () => void): this;
|
once(event: "SIGINT", listener: () => void): this;
|
||||||
once(event: 'SIGTSTP', listener: () => void): this;
|
once(event: "SIGTSTP", listener: () => void): this;
|
||||||
once(event: 'history', listener: (history: string[]) => void): this;
|
|
||||||
prependListener(event: string, listener: (...args: any[]) => void): this;
|
prependListener(event: string, listener: (...args: any[]) => void): this;
|
||||||
prependListener(event: 'close', listener: () => void): this;
|
prependListener(event: "close", listener: () => void): this;
|
||||||
prependListener(event: 'line', listener: (input: string) => void): this;
|
prependListener(event: "line", listener: (input: string) => void): this;
|
||||||
prependListener(event: 'pause', listener: () => void): this;
|
prependListener(event: "pause", listener: () => void): this;
|
||||||
prependListener(event: 'resume', listener: () => void): this;
|
prependListener(event: "resume", listener: () => void): this;
|
||||||
prependListener(event: 'SIGCONT', listener: () => void): this;
|
prependListener(event: "SIGCONT", listener: () => void): this;
|
||||||
prependListener(event: 'SIGINT', listener: () => void): this;
|
prependListener(event: "SIGINT", listener: () => void): this;
|
||||||
prependListener(event: 'SIGTSTP', listener: () => void): this;
|
prependListener(event: "SIGTSTP", listener: () => void): this;
|
||||||
prependListener(event: 'history', listener: (history: string[]) => void): this;
|
|
||||||
prependOnceListener(event: string, listener: (...args: any[]) => void): this;
|
prependOnceListener(event: string, listener: (...args: any[]) => void): this;
|
||||||
prependOnceListener(event: 'close', listener: () => void): this;
|
prependOnceListener(event: "close", listener: () => void): this;
|
||||||
prependOnceListener(event: 'line', listener: (input: string) => void): this;
|
prependOnceListener(event: "line", listener: (input: string) => void): this;
|
||||||
prependOnceListener(event: 'pause', listener: () => void): this;
|
prependOnceListener(event: "pause", listener: () => void): this;
|
||||||
prependOnceListener(event: 'resume', listener: () => void): this;
|
prependOnceListener(event: "resume", listener: () => void): this;
|
||||||
prependOnceListener(event: 'SIGCONT', listener: () => void): this;
|
prependOnceListener(event: "SIGCONT", listener: () => void): this;
|
||||||
prependOnceListener(event: 'SIGINT', listener: () => void): this;
|
prependOnceListener(event: "SIGINT", listener: () => void): this;
|
||||||
prependOnceListener(event: 'SIGTSTP', listener: () => void): this;
|
prependOnceListener(event: "SIGTSTP", listener: () => void): this;
|
||||||
prependOnceListener(event: 'history', listener: (history: string[]) => void): this;
|
|
||||||
[Symbol.asyncIterator](): AsyncIterableIterator<string>;
|
[Symbol.asyncIterator](): AsyncIterableIterator<string>;
|
||||||
}
|
}
|
||||||
type ReadLine = Interface; // type forwarded for backwards compatibility
|
|
||||||
|
type ReadLine = Interface; // type forwarded for backwards compatiblity
|
||||||
|
|
||||||
type Completer = (line: string) => CompleterResult;
|
type Completer = (line: string) => CompleterResult;
|
||||||
type AsyncCompleter = (line: string, callback: (err?: null | Error, result?: CompleterResult) => void) => void;
|
type AsyncCompleter = (line: string, callback: (err?: null | Error, result?: CompleterResult) => void) => any;
|
||||||
|
|
||||||
type CompleterResult = [string[], string];
|
type CompleterResult = [string[], string];
|
||||||
|
|
||||||
interface ReadLineOptions {
|
interface ReadLineOptions {
|
||||||
input: NodeJS.ReadableStream;
|
input: NodeJS.ReadableStream;
|
||||||
output?: NodeJS.WritableStream | undefined;
|
output?: NodeJS.WritableStream;
|
||||||
completer?: Completer | AsyncCompleter | undefined;
|
completer?: Completer | AsyncCompleter;
|
||||||
terminal?: boolean | undefined;
|
terminal?: boolean;
|
||||||
/**
|
historySize?: number;
|
||||||
* Initial list of history lines. This option makes sense
|
prompt?: string;
|
||||||
* only if `terminal` is set to `true` by the user or by an internal `output`
|
crlfDelay?: number;
|
||||||
* check, otherwise the history caching mechanism is not initialized at all.
|
removeHistoryDuplicates?: boolean;
|
||||||
* @default []
|
escapeCodeTimeout?: number;
|
||||||
*/
|
|
||||||
history?: string[] | undefined;
|
|
||||||
historySize?: number | undefined;
|
|
||||||
prompt?: string | undefined;
|
|
||||||
crlfDelay?: number | undefined;
|
|
||||||
/**
|
|
||||||
* If `true`, when a new input line added
|
|
||||||
* to the history list duplicates an older one, this removes the older line
|
|
||||||
* from the list.
|
|
||||||
* @default false
|
|
||||||
*/
|
|
||||||
removeHistoryDuplicates?: boolean | undefined;
|
|
||||||
escapeCodeTimeout?: number | undefined;
|
|
||||||
tabSize?: number | undefined;
|
|
||||||
}
|
}
|
||||||
/**
|
|
||||||
* The `readline.createInterface()` method creates a new `readline.Interface`instance.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const readline = require('readline');
|
|
||||||
* const rl = readline.createInterface({
|
|
||||||
* input: process.stdin,
|
|
||||||
* output: process.stdout
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Once the `readline.Interface` instance is created, the most common case is to
|
|
||||||
* listen for the `'line'` event:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* rl.on('line', (line) => {
|
|
||||||
* console.log(`Received: ${line}`);
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* If `terminal` is `true` for this instance then the `output` stream will get
|
|
||||||
* the best compatibility if it defines an `output.columns` property and emits
|
|
||||||
* a `'resize'` event on the `output` if or when the columns ever change
|
|
||||||
* (`process.stdout` does this automatically when it is a TTY).
|
|
||||||
*
|
|
||||||
* When creating a `readline.Interface` using `stdin` as input, the program
|
|
||||||
* will not terminate until it receives `EOF` (Ctrl+D on
|
|
||||||
* Linux/macOS, Ctrl+Z followed by Return on
|
|
||||||
* Windows).
|
|
||||||
* If you want your application to exit without waiting for user input, you can `unref()` the standard input stream:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* process.stdin.unref();
|
|
||||||
* ```
|
|
||||||
* @since v0.1.98
|
|
||||||
*/
|
|
||||||
function createInterface(input: NodeJS.ReadableStream, output?: NodeJS.WritableStream, completer?: Completer | AsyncCompleter, terminal?: boolean): Interface;
|
function createInterface(input: NodeJS.ReadableStream, output?: NodeJS.WritableStream, completer?: Completer | AsyncCompleter, terminal?: boolean): Interface;
|
||||||
function createInterface(options: ReadLineOptions): Interface;
|
function createInterface(options: ReadLineOptions): Interface;
|
||||||
/**
|
|
||||||
* The `readline.emitKeypressEvents()` method causes the given `Readable` stream to begin emitting `'keypress'` events corresponding to received input.
|
|
||||||
*
|
|
||||||
* Optionally, `interface` specifies a `readline.Interface` instance for which
|
|
||||||
* autocompletion is disabled when copy-pasted input is detected.
|
|
||||||
*
|
|
||||||
* If the `stream` is a `TTY`, then it must be in raw mode.
|
|
||||||
*
|
|
||||||
* This is automatically called by any readline instance on its `input` if the`input` is a terminal. Closing the `readline` instance does not stop
|
|
||||||
* the `input` from emitting `'keypress'` events.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* readline.emitKeypressEvents(process.stdin);
|
|
||||||
* if (process.stdin.isTTY)
|
|
||||||
* process.stdin.setRawMode(true);
|
|
||||||
* ```
|
|
||||||
* @since v0.7.7
|
|
||||||
*/
|
|
||||||
function emitKeypressEvents(stream: NodeJS.ReadableStream, readlineInterface?: Interface): void;
|
function emitKeypressEvents(stream: NodeJS.ReadableStream, readlineInterface?: Interface): void;
|
||||||
|
|
||||||
type Direction = -1 | 0 | 1;
|
type Direction = -1 | 0 | 1;
|
||||||
interface CursorPos {
|
|
||||||
rows: number;
|
|
||||||
cols: number;
|
|
||||||
}
|
|
||||||
/**
|
/**
|
||||||
* The `readline.clearLine()` method clears current line of given `TTY` stream
|
* Clears the current line of this WriteStream in a direction identified by `dir`.
|
||||||
* in a specified direction identified by `dir`.
|
|
||||||
* @since v0.7.7
|
|
||||||
* @param callback Invoked once the operation completes.
|
|
||||||
* @return `false` if `stream` wishes for the calling code to wait for the `'drain'` event to be emitted before continuing to write additional data; otherwise `true`.
|
|
||||||
*/
|
*/
|
||||||
function clearLine(stream: NodeJS.WritableStream, dir: Direction, callback?: () => void): boolean;
|
function clearLine(stream: NodeJS.WritableStream, dir: Direction, callback?: () => void): boolean;
|
||||||
/**
|
/**
|
||||||
* The `readline.clearScreenDown()` method clears the given `TTY` stream from
|
* Clears this `WriteStream` from the current cursor down.
|
||||||
* the current position of the cursor down.
|
|
||||||
* @since v0.7.7
|
|
||||||
* @param callback Invoked once the operation completes.
|
|
||||||
* @return `false` if `stream` wishes for the calling code to wait for the `'drain'` event to be emitted before continuing to write additional data; otherwise `true`.
|
|
||||||
*/
|
*/
|
||||||
function clearScreenDown(stream: NodeJS.WritableStream, callback?: () => void): boolean;
|
function clearScreenDown(stream: NodeJS.WritableStream, callback?: () => void): boolean;
|
||||||
/**
|
/**
|
||||||
* The `readline.cursorTo()` method moves cursor to the specified position in a
|
* Moves this WriteStream's cursor to the specified position.
|
||||||
* given `TTY` `stream`.
|
|
||||||
* @since v0.7.7
|
|
||||||
* @param callback Invoked once the operation completes.
|
|
||||||
* @return `false` if `stream` wishes for the calling code to wait for the `'drain'` event to be emitted before continuing to write additional data; otherwise `true`.
|
|
||||||
*/
|
*/
|
||||||
function cursorTo(stream: NodeJS.WritableStream, x: number, y?: number, callback?: () => void): boolean;
|
function cursorTo(stream: NodeJS.WritableStream, x: number, y?: number, callback?: () => void): boolean;
|
||||||
/**
|
/**
|
||||||
* The `readline.moveCursor()` method moves the cursor _relative_ to its current
|
* Moves this WriteStream's cursor relative to its current position.
|
||||||
* position in a given `TTY` `stream`.
|
|
||||||
*
|
|
||||||
* ## Example: Tiny CLI
|
|
||||||
*
|
|
||||||
* The following example illustrates the use of `readline.Interface` class to
|
|
||||||
* implement a small command-line interface:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const readline = require('readline');
|
|
||||||
* const rl = readline.createInterface({
|
|
||||||
* input: process.stdin,
|
|
||||||
* output: process.stdout,
|
|
||||||
* prompt: 'OHAI> '
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* rl.prompt();
|
|
||||||
*
|
|
||||||
* rl.on('line', (line) => {
|
|
||||||
* switch (line.trim()) {
|
|
||||||
* case 'hello':
|
|
||||||
* console.log('world!');
|
|
||||||
* break;
|
|
||||||
* default:
|
|
||||||
* console.log(`Say what? I might have heard '${line.trim()}'`);
|
|
||||||
* break;
|
|
||||||
* }
|
|
||||||
* rl.prompt();
|
|
||||||
* }).on('close', () => {
|
|
||||||
* console.log('Have a great day!');
|
|
||||||
* process.exit(0);
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* ## Example: Read file stream line-by-Line
|
|
||||||
*
|
|
||||||
* A common use case for `readline` is to consume an input file one line at a
|
|
||||||
* time. The easiest way to do so is leveraging the `fs.ReadStream` API as
|
|
||||||
* well as a `for await...of` loop:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const fs = require('fs');
|
|
||||||
* const readline = require('readline');
|
|
||||||
*
|
|
||||||
* async function processLineByLine() {
|
|
||||||
* const fileStream = fs.createReadStream('input.txt');
|
|
||||||
*
|
|
||||||
* const rl = readline.createInterface({
|
|
||||||
* input: fileStream,
|
|
||||||
* crlfDelay: Infinity
|
|
||||||
* });
|
|
||||||
* // Note: we use the crlfDelay option to recognize all instances of CR LF
|
|
||||||
* // ('\r\n') in input.txt as a single line break.
|
|
||||||
*
|
|
||||||
* for await (const line of rl) {
|
|
||||||
* // Each line in input.txt will be successively available here as `line`.
|
|
||||||
* console.log(`Line from file: ${line}`);
|
|
||||||
* }
|
|
||||||
* }
|
|
||||||
*
|
|
||||||
* processLineByLine();
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Alternatively, one could use the `'line'` event:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const fs = require('fs');
|
|
||||||
* const readline = require('readline');
|
|
||||||
*
|
|
||||||
* const rl = readline.createInterface({
|
|
||||||
* input: fs.createReadStream('sample.txt'),
|
|
||||||
* crlfDelay: Infinity
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* rl.on('line', (line) => {
|
|
||||||
* console.log(`Line from file: ${line}`);
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* Currently, `for await...of` loop can be a bit slower. If `async` / `await`flow and speed are both essential, a mixed approach can be applied:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const { once } = require('events');
|
|
||||||
* const { createReadStream } = require('fs');
|
|
||||||
* const { createInterface } = require('readline');
|
|
||||||
*
|
|
||||||
* (async function processLineByLine() {
|
|
||||||
* try {
|
|
||||||
* const rl = createInterface({
|
|
||||||
* input: createReadStream('big-file.txt'),
|
|
||||||
* crlfDelay: Infinity
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* rl.on('line', (line) => {
|
|
||||||
* // Process the line.
|
|
||||||
* });
|
|
||||||
*
|
|
||||||
* await once(rl, 'close');
|
|
||||||
*
|
|
||||||
* console.log('File processed.');
|
|
||||||
* } catch (err) {
|
|
||||||
* console.error(err);
|
|
||||||
* }
|
|
||||||
* })();
|
|
||||||
* ```
|
|
||||||
* @since v0.7.7
|
|
||||||
* @param callback Invoked once the operation completes.
|
|
||||||
* @return `false` if `stream` wishes for the calling code to wait for the `'drain'` event to be emitted before continuing to write additional data; otherwise `true`.
|
|
||||||
*/
|
*/
|
||||||
function moveCursor(stream: NodeJS.WritableStream, dx: number, dy: number, callback?: () => void): boolean;
|
function moveCursor(stream: NodeJS.WritableStream, dx: number, dy: number, callback?: () => void): boolean;
|
||||||
}
|
}
|
||||||
declare module 'node:readline' {
|
|
||||||
export * from 'readline';
|
|
||||||
}
|
|
||||||
|
|||||||
310
node_modules/@types/node/repl.d.ts
generated
vendored
Executable file → Normal file
310
node_modules/@types/node/repl.d.ts
generated
vendored
Executable file → Normal file
@@ -1,40 +1,31 @@
|
|||||||
/**
|
declare module "repl" {
|
||||||
* The `repl` module provides a Read-Eval-Print-Loop (REPL) implementation that
|
import { Interface, Completer, AsyncCompleter } from "readline";
|
||||||
* is available both as a standalone program or includible in other applications.
|
import { Context } from "vm";
|
||||||
* It can be accessed using:
|
import { InspectOptions } from "util";
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const repl = require('repl');
|
|
||||||
* ```
|
|
||||||
* @see [source](https://github.com/nodejs/node/blob/v16.9.0/lib/repl.js)
|
|
||||||
*/
|
|
||||||
declare module 'repl' {
|
|
||||||
import { Interface, Completer, AsyncCompleter } from 'node:readline';
|
|
||||||
import { Context } from 'node:vm';
|
|
||||||
import { InspectOptions } from 'node:util';
|
|
||||||
interface ReplOptions {
|
interface ReplOptions {
|
||||||
/**
|
/**
|
||||||
* The input prompt to display.
|
* The input prompt to display.
|
||||||
* @default "> "
|
* Default: `"> "`
|
||||||
*/
|
*/
|
||||||
prompt?: string | undefined;
|
prompt?: string;
|
||||||
/**
|
/**
|
||||||
* The `Readable` stream from which REPL input will be read.
|
* The `Readable` stream from which REPL input will be read.
|
||||||
* @default process.stdin
|
* Default: `process.stdin`
|
||||||
*/
|
*/
|
||||||
input?: NodeJS.ReadableStream | undefined;
|
input?: NodeJS.ReadableStream;
|
||||||
/**
|
/**
|
||||||
* The `Writable` stream to which REPL output will be written.
|
* The `Writable` stream to which REPL output will be written.
|
||||||
* @default process.stdout
|
* Default: `process.stdout`
|
||||||
*/
|
*/
|
||||||
output?: NodeJS.WritableStream | undefined;
|
output?: NodeJS.WritableStream;
|
||||||
/**
|
/**
|
||||||
* If `true`, specifies that the output should be treated as a TTY terminal, and have
|
* If `true`, specifies that the output should be treated as a TTY terminal, and have
|
||||||
* ANSI/VT100 escape codes written to it.
|
* ANSI/VT100 escape codes written to it.
|
||||||
* Default: checking the value of the `isTTY` property on the output stream upon
|
* Default: checking the value of the `isTTY` property on the output stream upon
|
||||||
* instantiation.
|
* instantiation.
|
||||||
*/
|
*/
|
||||||
terminal?: boolean | undefined;
|
terminal?: boolean;
|
||||||
/**
|
/**
|
||||||
* The function to be used when evaluating each given line of input.
|
* The function to be used when evaluating each given line of input.
|
||||||
* Default: an async wrapper for the JavaScript `eval()` function. An `eval` function can
|
* Default: an async wrapper for the JavaScript `eval()` function. An `eval` function can
|
||||||
@@ -44,45 +35,40 @@ declare module 'repl' {
|
|||||||
* @see https://nodejs.org/dist/latest-v10.x/docs/api/repl.html#repl_default_evaluation
|
* @see https://nodejs.org/dist/latest-v10.x/docs/api/repl.html#repl_default_evaluation
|
||||||
* @see https://nodejs.org/dist/latest-v10.x/docs/api/repl.html#repl_custom_evaluation_functions
|
* @see https://nodejs.org/dist/latest-v10.x/docs/api/repl.html#repl_custom_evaluation_functions
|
||||||
*/
|
*/
|
||||||
eval?: REPLEval | undefined;
|
eval?: REPLEval;
|
||||||
/**
|
|
||||||
* Defines if the repl prints output previews or not.
|
|
||||||
* @default `true` Always `false` in case `terminal` is falsy.
|
|
||||||
*/
|
|
||||||
preview?: boolean | undefined;
|
|
||||||
/**
|
/**
|
||||||
* If `true`, specifies that the default `writer` function should include ANSI color
|
* If `true`, specifies that the default `writer` function should include ANSI color
|
||||||
* styling to REPL output. If a custom `writer` function is provided then this has no
|
* styling to REPL output. If a custom `writer` function is provided then this has no
|
||||||
* effect.
|
* effect.
|
||||||
* Default: the REPL instance's `terminal` value.
|
* Default: the REPL instance's `terminal` value.
|
||||||
*/
|
*/
|
||||||
useColors?: boolean | undefined;
|
useColors?: boolean;
|
||||||
/**
|
/**
|
||||||
* If `true`, specifies that the default evaluation function will use the JavaScript
|
* If `true`, specifies that the default evaluation function will use the JavaScript
|
||||||
* `global` as the context as opposed to creating a new separate context for the REPL
|
* `global` as the context as opposed to creating a new separate context for the REPL
|
||||||
* instance. The node CLI REPL sets this value to `true`.
|
* instance. The node CLI REPL sets this value to `true`.
|
||||||
* Default: `false`.
|
* Default: `false`.
|
||||||
*/
|
*/
|
||||||
useGlobal?: boolean | undefined;
|
useGlobal?: boolean;
|
||||||
/**
|
/**
|
||||||
* If `true`, specifies that the default writer will not output the return value of a
|
* If `true`, specifies that the default writer will not output the return value of a
|
||||||
* command if it evaluates to `undefined`.
|
* command if it evaluates to `undefined`.
|
||||||
* Default: `false`.
|
* Default: `false`.
|
||||||
*/
|
*/
|
||||||
ignoreUndefined?: boolean | undefined;
|
ignoreUndefined?: boolean;
|
||||||
/**
|
/**
|
||||||
* The function to invoke to format the output of each command before writing to `output`.
|
* The function to invoke to format the output of each command before writing to `output`.
|
||||||
* Default: a wrapper for `util.inspect`.
|
* Default: a wrapper for `util.inspect`.
|
||||||
*
|
*
|
||||||
* @see https://nodejs.org/dist/latest-v10.x/docs/api/repl.html#repl_customizing_repl_output
|
* @see https://nodejs.org/dist/latest-v10.x/docs/api/repl.html#repl_customizing_repl_output
|
||||||
*/
|
*/
|
||||||
writer?: REPLWriter | undefined;
|
writer?: REPLWriter;
|
||||||
/**
|
/**
|
||||||
* An optional function used for custom Tab auto completion.
|
* An optional function used for custom Tab auto completion.
|
||||||
*
|
*
|
||||||
* @see https://nodejs.org/dist/latest-v11.x/docs/api/readline.html#readline_use_of_the_completer_function
|
* @see https://nodejs.org/dist/latest-v11.x/docs/api/readline.html#readline_use_of_the_completer_function
|
||||||
*/
|
*/
|
||||||
completer?: Completer | AsyncCompleter | undefined;
|
completer?: Completer | AsyncCompleter;
|
||||||
/**
|
/**
|
||||||
* A flag that specifies whether the default evaluator executes all JavaScript commands in
|
* A flag that specifies whether the default evaluator executes all JavaScript commands in
|
||||||
* strict mode or default (sloppy) mode.
|
* strict mode or default (sloppy) mode.
|
||||||
@@ -91,47 +77,52 @@ declare module 'repl' {
|
|||||||
* - `repl.REPL_MODE_STRICT` - evaluates expressions in strict mode. This is equivalent to
|
* - `repl.REPL_MODE_STRICT` - evaluates expressions in strict mode. This is equivalent to
|
||||||
* prefacing every repl statement with `'use strict'`.
|
* prefacing every repl statement with `'use strict'`.
|
||||||
*/
|
*/
|
||||||
replMode?: typeof REPL_MODE_SLOPPY | typeof REPL_MODE_STRICT | undefined;
|
replMode?: typeof REPL_MODE_SLOPPY | typeof REPL_MODE_STRICT;
|
||||||
/**
|
/**
|
||||||
* Stop evaluating the current piece of code when `SIGINT` is received, i.e. `Ctrl+C` is
|
* Stop evaluating the current piece of code when `SIGINT` is received, i.e. `Ctrl+C` is
|
||||||
* pressed. This cannot be used together with a custom `eval` function.
|
* pressed. This cannot be used together with a custom `eval` function.
|
||||||
* Default: `false`.
|
* Default: `false`.
|
||||||
*/
|
*/
|
||||||
breakEvalOnSigint?: boolean | undefined;
|
breakEvalOnSigint?: boolean;
|
||||||
}
|
}
|
||||||
|
|
||||||
type REPLEval = (this: REPLServer, evalCmd: string, context: Context, file: string, cb: (err: Error | null, result: any) => void) => void;
|
type REPLEval = (this: REPLServer, evalCmd: string, context: Context, file: string, cb: (err: Error | null, result: any) => void) => void;
|
||||||
type REPLWriter = (this: REPLServer, obj: any) => string;
|
type REPLWriter = (this: REPLServer, obj: any) => string;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* This is the default "writer" value, if none is passed in the REPL options,
|
* This is the default "writer" value, if none is passed in the REPL options,
|
||||||
* and it can be overridden by custom print functions.
|
* and it can be overridden by custom print functions.
|
||||||
*/
|
*/
|
||||||
const writer: REPLWriter & {
|
const writer: REPLWriter & { options: InspectOptions };
|
||||||
options: InspectOptions;
|
|
||||||
};
|
|
||||||
type REPLCommandAction = (this: REPLServer, text: string) => void;
|
type REPLCommandAction = (this: REPLServer, text: string) => void;
|
||||||
|
|
||||||
interface REPLCommand {
|
interface REPLCommand {
|
||||||
/**
|
/**
|
||||||
* Help text to be displayed when `.help` is entered.
|
* Help text to be displayed when `.help` is entered.
|
||||||
*/
|
*/
|
||||||
help?: string | undefined;
|
help?: string;
|
||||||
/**
|
/**
|
||||||
* The function to execute, optionally accepting a single string argument.
|
* The function to execute, optionally accepting a single string argument.
|
||||||
*/
|
*/
|
||||||
action: REPLCommandAction;
|
action: REPLCommandAction;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Instances of `repl.REPLServer` are created using the {@link start} method
|
* Provides a customizable Read-Eval-Print-Loop (REPL).
|
||||||
* or directly using the JavaScript `new` keyword.
|
|
||||||
*
|
*
|
||||||
* ```js
|
* Instances of `repl.REPLServer` will accept individual lines of user input, evaluate those
|
||||||
* const repl = require('repl');
|
* according to a user-defined evaluation function, then output the result. Input and output
|
||||||
|
* may be from `stdin` and `stdout`, respectively, or may be connected to any Node.js `stream`.
|
||||||
*
|
*
|
||||||
* const options = { useColors: true };
|
* Instances of `repl.REPLServer` support automatic completion of inputs, simplistic Emacs-style
|
||||||
|
* line editing, multi-line inputs, ANSI-styled output, saving and restoring current REPL session
|
||||||
|
* state, error recovery, and customizable evaluation functions.
|
||||||
*
|
*
|
||||||
* const firstInstance = repl.start(options);
|
* Instances of `repl.REPLServer` are created using the `repl.start()` method and _should not_
|
||||||
* const secondInstance = new repl.REPLServer(options);
|
* be created directly using the JavaScript `new` keyword.
|
||||||
* ```
|
*
|
||||||
* @since v0.1.91
|
* @see https://nodejs.org/dist/latest-v10.x/docs/api/repl.html#repl_repl
|
||||||
*/
|
*/
|
||||||
class REPLServer extends Interface {
|
class REPLServer extends Interface {
|
||||||
/**
|
/**
|
||||||
@@ -140,25 +131,17 @@ declare module 'repl' {
|
|||||||
*/
|
*/
|
||||||
readonly context: Context;
|
readonly context: Context;
|
||||||
/**
|
/**
|
||||||
* @deprecated since v14.3.0 - Use `input` instead.
|
* The `Readable` stream from which REPL input will be read.
|
||||||
*/
|
*/
|
||||||
readonly inputStream: NodeJS.ReadableStream;
|
readonly inputStream: NodeJS.ReadableStream;
|
||||||
/**
|
/**
|
||||||
* @deprecated since v14.3.0 - Use `output` instead.
|
* The `Writable` stream to which REPL output will be written.
|
||||||
*/
|
*/
|
||||||
readonly outputStream: NodeJS.WritableStream;
|
readonly outputStream: NodeJS.WritableStream;
|
||||||
/**
|
|
||||||
* The `Readable` stream from which REPL input will be read.
|
|
||||||
*/
|
|
||||||
readonly input: NodeJS.ReadableStream;
|
|
||||||
/**
|
|
||||||
* The `Writable` stream to which REPL output will be written.
|
|
||||||
*/
|
|
||||||
readonly output: NodeJS.WritableStream;
|
|
||||||
/**
|
/**
|
||||||
* The commands registered via `replServer.defineCommand()`.
|
* The commands registered via `replServer.defineCommand()`.
|
||||||
*/
|
*/
|
||||||
readonly commands: NodeJS.ReadOnlyDict<REPLCommand>;
|
readonly commands: { readonly [name: string]: REPLCommand | undefined };
|
||||||
/**
|
/**
|
||||||
* A value indicating whether the REPL is currently in "editor mode".
|
* A value indicating whether the REPL is currently in "editor mode".
|
||||||
*
|
*
|
||||||
@@ -232,6 +215,7 @@ declare module 'repl' {
|
|||||||
* prefacing every repl statement with `'use strict'`.
|
* prefacing every repl statement with `'use strict'`.
|
||||||
*/
|
*/
|
||||||
readonly replMode: typeof REPL_MODE_SLOPPY | typeof REPL_MODE_STRICT;
|
readonly replMode: typeof REPL_MODE_SLOPPY | typeof REPL_MODE_STRICT;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* NOTE: According to the documentation:
|
* NOTE: According to the documentation:
|
||||||
*
|
*
|
||||||
@@ -243,76 +227,49 @@ declare module 'repl' {
|
|||||||
* @see https://nodejs.org/dist/latest-v10.x/docs/api/repl.html#repl_class_replserver
|
* @see https://nodejs.org/dist/latest-v10.x/docs/api/repl.html#repl_class_replserver
|
||||||
*/
|
*/
|
||||||
private constructor();
|
private constructor();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The `replServer.defineCommand()` method is used to add new `.`\-prefixed commands
|
* Used to add new `.`-prefixed commands to the REPL instance. Such commands are invoked
|
||||||
* to the REPL instance. Such commands are invoked by typing a `.` followed by the`keyword`. The `cmd` is either a `Function` or an `Object` with the following
|
* by typing a `.` followed by the `keyword`.
|
||||||
* properties:
|
|
||||||
*
|
*
|
||||||
* The following example shows two new commands added to the REPL instance:
|
* @param keyword The command keyword (_without_ a leading `.` character).
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const repl = require('repl');
|
|
||||||
*
|
|
||||||
* const replServer = repl.start({ prompt: '> ' });
|
|
||||||
* replServer.defineCommand('sayhello', {
|
|
||||||
* help: 'Say hello',
|
|
||||||
* action(name) {
|
|
||||||
* this.clearBufferedCommand();
|
|
||||||
* console.log(`Hello, ${name}!`);
|
|
||||||
* this.displayPrompt();
|
|
||||||
* }
|
|
||||||
* });
|
|
||||||
* replServer.defineCommand('saybye', function saybye() {
|
|
||||||
* console.log('Goodbye!');
|
|
||||||
* this.close();
|
|
||||||
* });
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* The new commands can then be used from within the REPL instance:
|
|
||||||
*
|
|
||||||
* ```console
|
|
||||||
* > .sayhello Node.js User
|
|
||||||
* Hello, Node.js User!
|
|
||||||
* > .saybye
|
|
||||||
* Goodbye!
|
|
||||||
* ```
|
|
||||||
* @since v0.3.0
|
|
||||||
* @param keyword The command keyword (*without* a leading `.` character).
|
|
||||||
* @param cmd The function to invoke when the command is processed.
|
* @param cmd The function to invoke when the command is processed.
|
||||||
|
*
|
||||||
|
* @see https://nodejs.org/dist/latest-v10.x/docs/api/repl.html#repl_replserver_definecommand_keyword_cmd
|
||||||
*/
|
*/
|
||||||
defineCommand(keyword: string, cmd: REPLCommandAction | REPLCommand): void;
|
defineCommand(keyword: string, cmd: REPLCommandAction | REPLCommand): void;
|
||||||
/**
|
/**
|
||||||
* The `replServer.displayPrompt()` method readies the REPL instance for input
|
* Readies the REPL instance for input from the user, printing the configured `prompt` to a
|
||||||
* from the user, printing the configured `prompt` to a new line in the `output`and resuming the `input` to accept new input.
|
* new line in the `output` and resuming the `input` to accept new input.
|
||||||
*
|
*
|
||||||
* When multi-line input is being entered, an ellipsis is printed rather than the
|
* When multi-line input is being entered, an ellipsis is printed rather than the 'prompt'.
|
||||||
* 'prompt'.
|
|
||||||
*
|
*
|
||||||
* When `preserveCursor` is `true`, the cursor placement will not be reset to `0`.
|
* This method is primarily intended to be called from within the action function for
|
||||||
|
* commands registered using the `replServer.defineCommand()` method.
|
||||||
*
|
*
|
||||||
* The `replServer.displayPrompt` method is primarily intended to be called from
|
* @param preserveCursor When `true`, the cursor placement will not be reset to `0`.
|
||||||
* within the action function for commands registered using the`replServer.defineCommand()` method.
|
|
||||||
* @since v0.1.91
|
|
||||||
*/
|
*/
|
||||||
displayPrompt(preserveCursor?: boolean): void;
|
displayPrompt(preserveCursor?: boolean): void;
|
||||||
/**
|
/**
|
||||||
* The `replServer.clearBufferedCommand()` method clears any command that has been
|
* Clears any command that has been buffered but not yet executed.
|
||||||
* buffered but not yet executed. This method is primarily intended to be
|
*
|
||||||
* called from within the action function for commands registered using the`replServer.defineCommand()` method.
|
* This method is primarily intended to be called from within the action function for
|
||||||
|
* commands registered using the `replServer.defineCommand()` method.
|
||||||
|
*
|
||||||
* @since v9.0.0
|
* @since v9.0.0
|
||||||
*/
|
*/
|
||||||
clearBufferedCommand(): void;
|
clearBufferedCommand(): void;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Initializes a history log file for the REPL instance. When executing the
|
* Initializes a history log file for the REPL instance. When executing the
|
||||||
* Node.js binary and using the command-line REPL, a history file is initialized
|
* Node.js binary and using the command line REPL, a history file is initialized
|
||||||
* by default. However, this is not the case when creating a REPL
|
* by default. However, this is not the case when creating a REPL
|
||||||
* programmatically. Use this method to initialize a history log file when working
|
* programmatically. Use this method to initialize a history log file when working
|
||||||
* with REPL instances programmatically.
|
* with REPL instances programmatically.
|
||||||
* @since v11.10.0
|
* @param path The path to the history file
|
||||||
* @param historyPath the path to the history file
|
|
||||||
* @param callback called when history writes are ready or upon error
|
|
||||||
*/
|
*/
|
||||||
setupHistory(path: string, callback: (err: Error | null, repl: this) => void): void;
|
setupHistory(path: string, cb: (err: Error | null, repl: this) => void): void;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* events.EventEmitter
|
* events.EventEmitter
|
||||||
* 1. close - inherited from `readline.Interface`
|
* 1. close - inherited from `readline.Interface`
|
||||||
@@ -325,90 +282,93 @@ declare module 'repl' {
|
|||||||
* 8. exit
|
* 8. exit
|
||||||
* 9. reset
|
* 9. reset
|
||||||
*/
|
*/
|
||||||
|
|
||||||
addListener(event: string, listener: (...args: any[]) => void): this;
|
addListener(event: string, listener: (...args: any[]) => void): this;
|
||||||
addListener(event: 'close', listener: () => void): this;
|
addListener(event: "close", listener: () => void): this;
|
||||||
addListener(event: 'line', listener: (input: string) => void): this;
|
addListener(event: "line", listener: (input: string) => void): this;
|
||||||
addListener(event: 'pause', listener: () => void): this;
|
addListener(event: "pause", listener: () => void): this;
|
||||||
addListener(event: 'resume', listener: () => void): this;
|
addListener(event: "resume", listener: () => void): this;
|
||||||
addListener(event: 'SIGCONT', listener: () => void): this;
|
addListener(event: "SIGCONT", listener: () => void): this;
|
||||||
addListener(event: 'SIGINT', listener: () => void): this;
|
addListener(event: "SIGINT", listener: () => void): this;
|
||||||
addListener(event: 'SIGTSTP', listener: () => void): this;
|
addListener(event: "SIGTSTP", listener: () => void): this;
|
||||||
addListener(event: 'exit', listener: () => void): this;
|
addListener(event: "exit", listener: () => void): this;
|
||||||
addListener(event: 'reset', listener: (context: Context) => void): this;
|
addListener(event: "reset", listener: (context: Context) => void): this;
|
||||||
|
|
||||||
emit(event: string | symbol, ...args: any[]): boolean;
|
emit(event: string | symbol, ...args: any[]): boolean;
|
||||||
emit(event: 'close'): boolean;
|
emit(event: "close"): boolean;
|
||||||
emit(event: 'line', input: string): boolean;
|
emit(event: "line", input: string): boolean;
|
||||||
emit(event: 'pause'): boolean;
|
emit(event: "pause"): boolean;
|
||||||
emit(event: 'resume'): boolean;
|
emit(event: "resume"): boolean;
|
||||||
emit(event: 'SIGCONT'): boolean;
|
emit(event: "SIGCONT"): boolean;
|
||||||
emit(event: 'SIGINT'): boolean;
|
emit(event: "SIGINT"): boolean;
|
||||||
emit(event: 'SIGTSTP'): boolean;
|
emit(event: "SIGTSTP"): boolean;
|
||||||
emit(event: 'exit'): boolean;
|
emit(event: "exit"): boolean;
|
||||||
emit(event: 'reset', context: Context): boolean;
|
emit(event: "reset", context: Context): boolean;
|
||||||
|
|
||||||
on(event: string, listener: (...args: any[]) => void): this;
|
on(event: string, listener: (...args: any[]) => void): this;
|
||||||
on(event: 'close', listener: () => void): this;
|
on(event: "close", listener: () => void): this;
|
||||||
on(event: 'line', listener: (input: string) => void): this;
|
on(event: "line", listener: (input: string) => void): this;
|
||||||
on(event: 'pause', listener: () => void): this;
|
on(event: "pause", listener: () => void): this;
|
||||||
on(event: 'resume', listener: () => void): this;
|
on(event: "resume", listener: () => void): this;
|
||||||
on(event: 'SIGCONT', listener: () => void): this;
|
on(event: "SIGCONT", listener: () => void): this;
|
||||||
on(event: 'SIGINT', listener: () => void): this;
|
on(event: "SIGINT", listener: () => void): this;
|
||||||
on(event: 'SIGTSTP', listener: () => void): this;
|
on(event: "SIGTSTP", listener: () => void): this;
|
||||||
on(event: 'exit', listener: () => void): this;
|
on(event: "exit", listener: () => void): this;
|
||||||
on(event: 'reset', listener: (context: Context) => void): this;
|
on(event: "reset", listener: (context: Context) => void): this;
|
||||||
|
|
||||||
once(event: string, listener: (...args: any[]) => void): this;
|
once(event: string, listener: (...args: any[]) => void): this;
|
||||||
once(event: 'close', listener: () => void): this;
|
once(event: "close", listener: () => void): this;
|
||||||
once(event: 'line', listener: (input: string) => void): this;
|
once(event: "line", listener: (input: string) => void): this;
|
||||||
once(event: 'pause', listener: () => void): this;
|
once(event: "pause", listener: () => void): this;
|
||||||
once(event: 'resume', listener: () => void): this;
|
once(event: "resume", listener: () => void): this;
|
||||||
once(event: 'SIGCONT', listener: () => void): this;
|
once(event: "SIGCONT", listener: () => void): this;
|
||||||
once(event: 'SIGINT', listener: () => void): this;
|
once(event: "SIGINT", listener: () => void): this;
|
||||||
once(event: 'SIGTSTP', listener: () => void): this;
|
once(event: "SIGTSTP", listener: () => void): this;
|
||||||
once(event: 'exit', listener: () => void): this;
|
once(event: "exit", listener: () => void): this;
|
||||||
once(event: 'reset', listener: (context: Context) => void): this;
|
once(event: "reset", listener: (context: Context) => void): this;
|
||||||
|
|
||||||
prependListener(event: string, listener: (...args: any[]) => void): this;
|
prependListener(event: string, listener: (...args: any[]) => void): this;
|
||||||
prependListener(event: 'close', listener: () => void): this;
|
prependListener(event: "close", listener: () => void): this;
|
||||||
prependListener(event: 'line', listener: (input: string) => void): this;
|
prependListener(event: "line", listener: (input: string) => void): this;
|
||||||
prependListener(event: 'pause', listener: () => void): this;
|
prependListener(event: "pause", listener: () => void): this;
|
||||||
prependListener(event: 'resume', listener: () => void): this;
|
prependListener(event: "resume", listener: () => void): this;
|
||||||
prependListener(event: 'SIGCONT', listener: () => void): this;
|
prependListener(event: "SIGCONT", listener: () => void): this;
|
||||||
prependListener(event: 'SIGINT', listener: () => void): this;
|
prependListener(event: "SIGINT", listener: () => void): this;
|
||||||
prependListener(event: 'SIGTSTP', listener: () => void): this;
|
prependListener(event: "SIGTSTP", listener: () => void): this;
|
||||||
prependListener(event: 'exit', listener: () => void): this;
|
prependListener(event: "exit", listener: () => void): this;
|
||||||
prependListener(event: 'reset', listener: (context: Context) => void): this;
|
prependListener(event: "reset", listener: (context: Context) => void): this;
|
||||||
|
|
||||||
prependOnceListener(event: string, listener: (...args: any[]) => void): this;
|
prependOnceListener(event: string, listener: (...args: any[]) => void): this;
|
||||||
prependOnceListener(event: 'close', listener: () => void): this;
|
prependOnceListener(event: "close", listener: () => void): this;
|
||||||
prependOnceListener(event: 'line', listener: (input: string) => void): this;
|
prependOnceListener(event: "line", listener: (input: string) => void): this;
|
||||||
prependOnceListener(event: 'pause', listener: () => void): this;
|
prependOnceListener(event: "pause", listener: () => void): this;
|
||||||
prependOnceListener(event: 'resume', listener: () => void): this;
|
prependOnceListener(event: "resume", listener: () => void): this;
|
||||||
prependOnceListener(event: 'SIGCONT', listener: () => void): this;
|
prependOnceListener(event: "SIGCONT", listener: () => void): this;
|
||||||
prependOnceListener(event: 'SIGINT', listener: () => void): this;
|
prependOnceListener(event: "SIGINT", listener: () => void): this;
|
||||||
prependOnceListener(event: 'SIGTSTP', listener: () => void): this;
|
prependOnceListener(event: "SIGTSTP", listener: () => void): this;
|
||||||
prependOnceListener(event: 'exit', listener: () => void): this;
|
prependOnceListener(event: "exit", listener: () => void): this;
|
||||||
prependOnceListener(event: 'reset', listener: (context: Context) => void): this;
|
prependOnceListener(event: "reset", listener: (context: Context) => void): this;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A flag passed in the REPL options. Evaluates expressions in sloppy mode.
|
* A flag passed in the REPL options. Evaluates expressions in sloppy mode.
|
||||||
*/
|
*/
|
||||||
const REPL_MODE_SLOPPY: unique symbol;
|
const REPL_MODE_SLOPPY: symbol; // TODO: unique symbol
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* A flag passed in the REPL options. Evaluates expressions in strict mode.
|
* A flag passed in the REPL options. Evaluates expressions in strict mode.
|
||||||
* This is equivalent to prefacing every repl statement with `'use strict'`.
|
* This is equivalent to prefacing every repl statement with `'use strict'`.
|
||||||
*/
|
*/
|
||||||
const REPL_MODE_STRICT: unique symbol;
|
const REPL_MODE_STRICT: symbol; // TODO: unique symbol
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The `repl.start()` method creates and starts a {@link REPLServer} instance.
|
* Creates and starts a `repl.REPLServer` instance.
|
||||||
*
|
*
|
||||||
* If `options` is a string, then it specifies the input prompt:
|
* @param options The options for the `REPLServer`. If `options` is a string, then it specifies
|
||||||
*
|
* the input prompt.
|
||||||
* ```js
|
|
||||||
* const repl = require('repl');
|
|
||||||
*
|
|
||||||
* // a Unix style prompt
|
|
||||||
* repl.start('$ ');
|
|
||||||
* ```
|
|
||||||
* @since v0.1.91
|
|
||||||
*/
|
*/
|
||||||
function start(options?: string | ReplOptions): REPLServer;
|
function start(options?: string | ReplOptions): REPLServer;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Indicates a recoverable error that a `REPLServer` can use to support multi-line input.
|
* Indicates a recoverable error that a `REPLServer` can use to support multi-line input.
|
||||||
*
|
*
|
||||||
@@ -416,9 +376,7 @@ declare module 'repl' {
|
|||||||
*/
|
*/
|
||||||
class Recoverable extends SyntaxError {
|
class Recoverable extends SyntaxError {
|
||||||
err: Error;
|
err: Error;
|
||||||
|
|
||||||
constructor(err: Error);
|
constructor(err: Error);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
declare module 'node:repl' {
|
|
||||||
export * from 'repl';
|
|
||||||
}
|
|
||||||
|
|||||||
1304
node_modules/@types/node/stream.d.ts
generated
vendored
Executable file → Normal file
1304
node_modules/@types/node/stream.d.ts
generated
vendored
Executable file → Normal file
File diff suppressed because it is too large
Load Diff
24
node_modules/@types/node/stream/consumers.d.ts
generated
vendored
24
node_modules/@types/node/stream/consumers.d.ts
generated
vendored
@@ -1,24 +0,0 @@
|
|||||||
// Duplicates of interface in lib.dom.ts.
|
|
||||||
// Duplicated here rather than referencing lib.dom.ts because doing so causes lib.dom.ts to be loaded for "test-all"
|
|
||||||
// Which in turn causes tests to pass that shouldn't pass.
|
|
||||||
//
|
|
||||||
// This interface is not, and should not be, exported.
|
|
||||||
interface Blob {
|
|
||||||
readonly size: number;
|
|
||||||
readonly type: string;
|
|
||||||
arrayBuffer(): Promise<ArrayBuffer>;
|
|
||||||
slice(start?: number, end?: number, contentType?: string): Blob;
|
|
||||||
stream(): NodeJS.ReadableStream;
|
|
||||||
text(): Promise<string>;
|
|
||||||
}
|
|
||||||
declare module 'stream/consumers' {
|
|
||||||
import { Readable } from 'node:stream';
|
|
||||||
function buffer(stream: NodeJS.ReadableStream | Readable | AsyncIterator<any>): Promise<Buffer>;
|
|
||||||
function text(stream: NodeJS.ReadableStream | Readable | AsyncIterator<any>): Promise<string>;
|
|
||||||
function arrayBuffer(stream: NodeJS.ReadableStream | Readable | AsyncIterator<any>): Promise<ArrayBuffer>;
|
|
||||||
function blob(stream: NodeJS.ReadableStream | Readable | AsyncIterator<any>): Promise<Blob>;
|
|
||||||
function json(stream: NodeJS.ReadableStream | Readable | AsyncIterator<any>): Promise<unknown>;
|
|
||||||
}
|
|
||||||
declare module 'node:stream/consumers' {
|
|
||||||
export * from 'stream/consumers';
|
|
||||||
}
|
|
||||||
42
node_modules/@types/node/stream/promises.d.ts
generated
vendored
42
node_modules/@types/node/stream/promises.d.ts
generated
vendored
@@ -1,42 +0,0 @@
|
|||||||
declare module 'stream/promises' {
|
|
||||||
import { FinishedOptions, PipelineSource, PipelineTransform, PipelineDestination, PipelinePromise, PipelineOptions } from 'node:stream';
|
|
||||||
function finished(stream: NodeJS.ReadableStream | NodeJS.WritableStream | NodeJS.ReadWriteStream, options?: FinishedOptions): Promise<void>;
|
|
||||||
function pipeline<A extends PipelineSource<any>, B extends PipelineDestination<A, any>>(source: A, destination: B, options?: PipelineOptions): PipelinePromise<B>;
|
|
||||||
function pipeline<A extends PipelineSource<any>, T1 extends PipelineTransform<A, any>, B extends PipelineDestination<T1, any>>(
|
|
||||||
source: A,
|
|
||||||
transform1: T1,
|
|
||||||
destination: B,
|
|
||||||
options?: PipelineOptions
|
|
||||||
): PipelinePromise<B>;
|
|
||||||
function pipeline<A extends PipelineSource<any>, T1 extends PipelineTransform<A, any>, T2 extends PipelineTransform<T1, any>, B extends PipelineDestination<T2, any>>(
|
|
||||||
source: A,
|
|
||||||
transform1: T1,
|
|
||||||
transform2: T2,
|
|
||||||
destination: B,
|
|
||||||
options?: PipelineOptions
|
|
||||||
): PipelinePromise<B>;
|
|
||||||
function pipeline<
|
|
||||||
A extends PipelineSource<any>,
|
|
||||||
T1 extends PipelineTransform<A, any>,
|
|
||||||
T2 extends PipelineTransform<T1, any>,
|
|
||||||
T3 extends PipelineTransform<T2, any>,
|
|
||||||
B extends PipelineDestination<T3, any>
|
|
||||||
>(source: A, transform1: T1, transform2: T2, transform3: T3, destination: B, options?: PipelineOptions): PipelinePromise<B>;
|
|
||||||
function pipeline<
|
|
||||||
A extends PipelineSource<any>,
|
|
||||||
T1 extends PipelineTransform<A, any>,
|
|
||||||
T2 extends PipelineTransform<T1, any>,
|
|
||||||
T3 extends PipelineTransform<T2, any>,
|
|
||||||
T4 extends PipelineTransform<T3, any>,
|
|
||||||
B extends PipelineDestination<T4, any>
|
|
||||||
>(source: A, transform1: T1, transform2: T2, transform3: T3, transform4: T4, destination: B, options?: PipelineOptions): PipelinePromise<B>;
|
|
||||||
function pipeline(streams: ReadonlyArray<NodeJS.ReadableStream | NodeJS.WritableStream | NodeJS.ReadWriteStream>, options?: PipelineOptions): Promise<void>;
|
|
||||||
function pipeline(
|
|
||||||
stream1: NodeJS.ReadableStream,
|
|
||||||
stream2: NodeJS.ReadWriteStream | NodeJS.WritableStream,
|
|
||||||
...streams: Array<NodeJS.ReadWriteStream | NodeJS.WritableStream | PipelineOptions>
|
|
||||||
): Promise<void>;
|
|
||||||
}
|
|
||||||
declare module 'node:stream/promises' {
|
|
||||||
export * from 'stream/promises';
|
|
||||||
}
|
|
||||||
391
node_modules/@types/node/stream/web.d.ts
generated
vendored
391
node_modules/@types/node/stream/web.d.ts
generated
vendored
@@ -1,391 +0,0 @@
|
|||||||
declare module 'stream/web' {
|
|
||||||
// stub module, pending copy&paste from .d.ts or manual impl
|
|
||||||
// copy from lib.dom.d.ts
|
|
||||||
|
|
||||||
interface ReadableWritablePair<R = any, W = any> {
|
|
||||||
readable: ReadableStream<R>;
|
|
||||||
/**
|
|
||||||
* Provides a convenient, chainable way of piping this readable stream
|
|
||||||
* through a transform stream (or any other { writable, readable }
|
|
||||||
* pair). It simply pipes the stream into the writable side of the
|
|
||||||
* supplied pair, and returns the readable side for further use.
|
|
||||||
*
|
|
||||||
* Piping a stream will lock it for the duration of the pipe, preventing
|
|
||||||
* any other consumer from acquiring a reader.
|
|
||||||
*/
|
|
||||||
writable: WritableStream<W>;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface StreamPipeOptions {
|
|
||||||
preventAbort?: boolean;
|
|
||||||
preventCancel?: boolean;
|
|
||||||
/**
|
|
||||||
* Pipes this readable stream to a given writable stream destination.
|
|
||||||
* The way in which the piping process behaves under various error
|
|
||||||
* conditions can be customized with a number of passed options. It
|
|
||||||
* returns a promise that fulfills when the piping process completes
|
|
||||||
* successfully, or rejects if any errors were encountered.
|
|
||||||
*
|
|
||||||
* Piping a stream will lock it for the duration of the pipe, preventing
|
|
||||||
* any other consumer from acquiring a reader.
|
|
||||||
*
|
|
||||||
* Errors and closures of the source and destination streams propagate
|
|
||||||
* as follows:
|
|
||||||
*
|
|
||||||
* An error in this source readable stream will abort destination,
|
|
||||||
* unless preventAbort is truthy. The returned promise will be rejected
|
|
||||||
* with the source's error, or with any error that occurs during
|
|
||||||
* aborting the destination.
|
|
||||||
*
|
|
||||||
* An error in destination will cancel this source readable stream,
|
|
||||||
* unless preventCancel is truthy. The returned promise will be rejected
|
|
||||||
* with the destination's error, or with any error that occurs during
|
|
||||||
* canceling the source.
|
|
||||||
*
|
|
||||||
* When this source readable stream closes, destination will be closed,
|
|
||||||
* unless preventClose is truthy. The returned promise will be fulfilled
|
|
||||||
* once this process completes, unless an error is encountered while
|
|
||||||
* closing the destination, in which case it will be rejected with that
|
|
||||||
* error.
|
|
||||||
*
|
|
||||||
* If destination starts out closed or closing, this source readable
|
|
||||||
* stream will be canceled, unless preventCancel is true. The returned
|
|
||||||
* promise will be rejected with an error indicating piping to a closed
|
|
||||||
* stream failed, or with any error that occurs during canceling the
|
|
||||||
* source.
|
|
||||||
*
|
|
||||||
* The signal option can be set to an AbortSignal to allow aborting an
|
|
||||||
* ongoing pipe operation via the corresponding AbortController. In this
|
|
||||||
* case, this source readable stream will be canceled, and destination
|
|
||||||
* aborted, unless the respective options preventCancel or preventAbort
|
|
||||||
* are set.
|
|
||||||
*/
|
|
||||||
preventClose?: boolean;
|
|
||||||
signal?: AbortSignal;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface ReadableStreamGenericReader {
|
|
||||||
readonly closed: Promise<undefined>;
|
|
||||||
cancel(reason?: any): Promise<void>;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface ReadableStreamDefaultReadValueResult<T> {
|
|
||||||
done: false;
|
|
||||||
value: T;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface ReadableStreamDefaultReadDoneResult {
|
|
||||||
done: true;
|
|
||||||
value?: undefined;
|
|
||||||
}
|
|
||||||
type ReadableStreamController<T> = ReadableStreamDefaultController<T>;
|
|
||||||
type ReadableStreamDefaultReadResult<T> =
|
|
||||||
| ReadableStreamDefaultReadValueResult<T>
|
|
||||||
| ReadableStreamDefaultReadDoneResult;
|
|
||||||
|
|
||||||
interface ReadableByteStreamControllerCallback {
|
|
||||||
(controller: ReadableByteStreamController): void | PromiseLike<void>;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface UnderlyingSinkAbortCallback {
|
|
||||||
(reason?: any): void | PromiseLike<void>;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface UnderlyingSinkCloseCallback {
|
|
||||||
(): void | PromiseLike<void>;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface UnderlyingSinkStartCallback {
|
|
||||||
(controller: WritableStreamDefaultController): any;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface UnderlyingSinkWriteCallback<W> {
|
|
||||||
(chunk: W, controller: WritableStreamDefaultController): void | PromiseLike<void>;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface UnderlyingSourceCancelCallback {
|
|
||||||
(reason?: any): void | PromiseLike<void>;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface UnderlyingSourcePullCallback<R> {
|
|
||||||
(controller: ReadableStreamController<R>): void | PromiseLike<void>;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface UnderlyingSourceStartCallback<R> {
|
|
||||||
(controller: ReadableStreamController<R>): any;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface TransformerFlushCallback<O> {
|
|
||||||
(controller: TransformStreamDefaultController<O>): void | PromiseLike<void>;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface TransformerStartCallback<O> {
|
|
||||||
(controller: TransformStreamDefaultController<O>): any;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface TransformerTransformCallback<I, O> {
|
|
||||||
(chunk: I, controller: TransformStreamDefaultController<O>): void | PromiseLike<void>;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface UnderlyingByteSource {
|
|
||||||
autoAllocateChunkSize?: number;
|
|
||||||
cancel?: ReadableStreamErrorCallback;
|
|
||||||
pull?: ReadableByteStreamControllerCallback;
|
|
||||||
start?: ReadableByteStreamControllerCallback;
|
|
||||||
type: 'bytes';
|
|
||||||
}
|
|
||||||
|
|
||||||
interface UnderlyingSource<R = any> {
|
|
||||||
cancel?: UnderlyingSourceCancelCallback;
|
|
||||||
pull?: UnderlyingSourcePullCallback<R>;
|
|
||||||
start?: UnderlyingSourceStartCallback<R>;
|
|
||||||
type?: undefined;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface UnderlyingSink<W = any> {
|
|
||||||
abort?: UnderlyingSinkAbortCallback;
|
|
||||||
close?: UnderlyingSinkCloseCallback;
|
|
||||||
start?: UnderlyingSinkStartCallback;
|
|
||||||
type?: undefined;
|
|
||||||
write?: UnderlyingSinkWriteCallback<W>;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface ReadableStreamErrorCallback {
|
|
||||||
(reason: any): void | PromiseLike<void>;
|
|
||||||
}
|
|
||||||
|
|
||||||
/** This Streams API interface represents a readable stream of byte data. */
|
|
||||||
interface ReadableStream<R = any> {
|
|
||||||
readonly locked: boolean;
|
|
||||||
cancel(reason?: any): Promise<void>;
|
|
||||||
getReader(): ReadableStreamDefaultReader<R>;
|
|
||||||
pipeThrough<T>(transform: ReadableWritablePair<T, R>, options?: StreamPipeOptions): ReadableStream<T>;
|
|
||||||
pipeTo(destination: WritableStream<R>, options?: StreamPipeOptions): Promise<void>;
|
|
||||||
tee(): [ReadableStream<R>, ReadableStream<R>];
|
|
||||||
[Symbol.asyncIterator](options?: { preventCancel?: boolean }): AsyncIterableIterator<R>;
|
|
||||||
}
|
|
||||||
|
|
||||||
const ReadableStream: {
|
|
||||||
prototype: ReadableStream;
|
|
||||||
new (
|
|
||||||
underlyingSource: UnderlyingByteSource,
|
|
||||||
strategy?: QueuingStrategy<Uint8Array>,
|
|
||||||
): ReadableStream<Uint8Array>;
|
|
||||||
new <R = any>(underlyingSource?: UnderlyingSource<R>, strategy?: QueuingStrategy<R>): ReadableStream<R>;
|
|
||||||
};
|
|
||||||
|
|
||||||
interface ReadableStreamDefaultReader<R = any> extends ReadableStreamGenericReader {
|
|
||||||
read(): Promise<ReadableStreamDefaultReadResult<R>>;
|
|
||||||
releaseLock(): void;
|
|
||||||
}
|
|
||||||
|
|
||||||
const ReadableStreamDefaultReader: {
|
|
||||||
prototype: ReadableStreamDefaultReader;
|
|
||||||
new <R = any>(stream: ReadableStream<R>): ReadableStreamDefaultReader<R>;
|
|
||||||
};
|
|
||||||
|
|
||||||
const ReadableStreamBYOBReader: any;
|
|
||||||
const ReadableStreamBYOBRequest: any;
|
|
||||||
|
|
||||||
interface ReadableByteStreamController {
|
|
||||||
readonly byobRequest: undefined;
|
|
||||||
readonly desiredSize: number | null;
|
|
||||||
close(): void;
|
|
||||||
enqueue(chunk: ArrayBufferView): void;
|
|
||||||
error(error?: any): void;
|
|
||||||
}
|
|
||||||
|
|
||||||
const ReadableByteStreamController: {
|
|
||||||
prototype: ReadableByteStreamController;
|
|
||||||
new (): ReadableByteStreamController;
|
|
||||||
};
|
|
||||||
|
|
||||||
interface ReadableStreamDefaultController<R = any> {
|
|
||||||
readonly desiredSize: number | null;
|
|
||||||
close(): void;
|
|
||||||
enqueue(chunk?: R): void;
|
|
||||||
error(e?: any): void;
|
|
||||||
}
|
|
||||||
|
|
||||||
const ReadableStreamDefaultController: {
|
|
||||||
prototype: ReadableStreamDefaultController;
|
|
||||||
new (): ReadableStreamDefaultController;
|
|
||||||
};
|
|
||||||
|
|
||||||
interface Transformer<I = any, O = any> {
|
|
||||||
flush?: TransformerFlushCallback<O>;
|
|
||||||
readableType?: undefined;
|
|
||||||
start?: TransformerStartCallback<O>;
|
|
||||||
transform?: TransformerTransformCallback<I, O>;
|
|
||||||
writableType?: undefined;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface TransformStream<I = any, O = any> {
|
|
||||||
readonly readable: ReadableStream<O>;
|
|
||||||
readonly writable: WritableStream<I>;
|
|
||||||
}
|
|
||||||
|
|
||||||
const TransformStream: {
|
|
||||||
prototype: TransformStream;
|
|
||||||
new <I = any, O = any>(
|
|
||||||
transformer?: Transformer<I, O>,
|
|
||||||
writableStrategy?: QueuingStrategy<I>,
|
|
||||||
readableStrategy?: QueuingStrategy<O>,
|
|
||||||
): TransformStream<I, O>;
|
|
||||||
};
|
|
||||||
|
|
||||||
interface TransformStreamDefaultController<O = any> {
|
|
||||||
readonly desiredSize: number | null;
|
|
||||||
enqueue(chunk?: O): void;
|
|
||||||
error(reason?: any): void;
|
|
||||||
terminate(): void;
|
|
||||||
}
|
|
||||||
|
|
||||||
const TransformStreamDefaultController: {
|
|
||||||
prototype: TransformStreamDefaultController;
|
|
||||||
new (): TransformStreamDefaultController;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This Streams API interface provides a standard abstraction for writing
|
|
||||||
* streaming data to a destination, known as a sink. This object comes with
|
|
||||||
* built-in back pressure and queuing.
|
|
||||||
*/
|
|
||||||
interface WritableStream<W = any> {
|
|
||||||
readonly locked: boolean;
|
|
||||||
abort(reason?: any): Promise<void>;
|
|
||||||
close(): Promise<void>;
|
|
||||||
getWriter(): WritableStreamDefaultWriter<W>;
|
|
||||||
}
|
|
||||||
|
|
||||||
const WritableStream: {
|
|
||||||
prototype: WritableStream;
|
|
||||||
new <W = any>(underlyingSink?: UnderlyingSink<W>, strategy?: QueuingStrategy<W>): WritableStream<W>;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This Streams API interface is the object returned by
|
|
||||||
* WritableStream.getWriter() and once created locks the < writer to the
|
|
||||||
* WritableStream ensuring that no other streams can write to the underlying
|
|
||||||
* sink.
|
|
||||||
*/
|
|
||||||
interface WritableStreamDefaultWriter<W = any> {
|
|
||||||
readonly closed: Promise<undefined>;
|
|
||||||
readonly desiredSize: number | null;
|
|
||||||
readonly ready: Promise<undefined>;
|
|
||||||
abort(reason?: any): Promise<void>;
|
|
||||||
close(): Promise<void>;
|
|
||||||
releaseLock(): void;
|
|
||||||
write(chunk?: W): Promise<void>;
|
|
||||||
}
|
|
||||||
|
|
||||||
const WritableStreamDefaultWriter: {
|
|
||||||
prototype: WritableStreamDefaultWriter;
|
|
||||||
new <W = any>(stream: WritableStream<W>): WritableStreamDefaultWriter<W>;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This Streams API interface represents a controller allowing control of a
|
|
||||||
* WritableStream's state. When constructing a WritableStream, the
|
|
||||||
* underlying sink is given a corresponding WritableStreamDefaultController
|
|
||||||
* instance to manipulate.
|
|
||||||
*/
|
|
||||||
interface WritableStreamDefaultController {
|
|
||||||
error(e?: any): void;
|
|
||||||
}
|
|
||||||
|
|
||||||
const WritableStreamDefaultController: {
|
|
||||||
prototype: WritableStreamDefaultController;
|
|
||||||
new (): WritableStreamDefaultController;
|
|
||||||
};
|
|
||||||
|
|
||||||
interface QueuingStrategy<T = any> {
|
|
||||||
highWaterMark?: number;
|
|
||||||
size?: QueuingStrategySize<T>;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface QueuingStrategySize<T = any> {
|
|
||||||
(chunk?: T): number;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface QueuingStrategyInit {
|
|
||||||
/**
|
|
||||||
* Creates a new ByteLengthQueuingStrategy with the provided high water
|
|
||||||
* mark.
|
|
||||||
*
|
|
||||||
* Note that the provided high water mark will not be validated ahead of
|
|
||||||
* time. Instead, if it is negative, NaN, or not a number, the resulting
|
|
||||||
* ByteLengthQueuingStrategy will cause the corresponding stream
|
|
||||||
* constructor to throw.
|
|
||||||
*/
|
|
||||||
highWaterMark: number;
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This Streams API interface provides a built-in byte length queuing
|
|
||||||
* strategy that can be used when constructing streams.
|
|
||||||
*/
|
|
||||||
interface ByteLengthQueuingStrategy extends QueuingStrategy<ArrayBufferView> {
|
|
||||||
readonly highWaterMark: number;
|
|
||||||
readonly size: QueuingStrategySize<ArrayBufferView>;
|
|
||||||
}
|
|
||||||
|
|
||||||
const ByteLengthQueuingStrategy: {
|
|
||||||
prototype: ByteLengthQueuingStrategy;
|
|
||||||
new (init: QueuingStrategyInit): ByteLengthQueuingStrategy;
|
|
||||||
};
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This Streams API interface provides a built-in byte length queuing
|
|
||||||
* strategy that can be used when constructing streams.
|
|
||||||
*/
|
|
||||||
interface CountQueuingStrategy extends QueuingStrategy {
|
|
||||||
readonly highWaterMark: number;
|
|
||||||
readonly size: QueuingStrategySize;
|
|
||||||
}
|
|
||||||
|
|
||||||
const CountQueuingStrategy: {
|
|
||||||
prototype: CountQueuingStrategy;
|
|
||||||
new (init: QueuingStrategyInit): CountQueuingStrategy;
|
|
||||||
};
|
|
||||||
|
|
||||||
interface TextEncoderStream {
|
|
||||||
/** Returns "utf-8". */
|
|
||||||
readonly encoding: 'utf-8';
|
|
||||||
readonly readable: ReadableStream<Uint8Array>;
|
|
||||||
readonly writable: WritableStream<string>;
|
|
||||||
readonly [Symbol.toStringTag]: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
const TextEncoderStream: {
|
|
||||||
prototype: TextEncoderStream;
|
|
||||||
new (): TextEncoderStream;
|
|
||||||
};
|
|
||||||
|
|
||||||
interface TextDecoderOptions {
|
|
||||||
fatal?: boolean;
|
|
||||||
ignoreBOM?: boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
type BufferSource = ArrayBufferView | ArrayBuffer;
|
|
||||||
|
|
||||||
interface TextDecoderStream {
|
|
||||||
/** Returns encoding's name, lower cased. */
|
|
||||||
readonly encoding: string;
|
|
||||||
/** Returns `true` if error mode is "fatal", and `false` otherwise. */
|
|
||||||
readonly fatal: boolean;
|
|
||||||
/** Returns `true` if ignore BOM flag is set, and `false` otherwise. */
|
|
||||||
readonly ignoreBOM: boolean;
|
|
||||||
readonly readable: ReadableStream<string>;
|
|
||||||
readonly writable: WritableStream<BufferSource>;
|
|
||||||
readonly [Symbol.toStringTag]: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
const TextDecoderStream: {
|
|
||||||
prototype: TextDecoderStream;
|
|
||||||
new (label?: string, options?: TextDecoderOptions): TextDecoderStream;
|
|
||||||
};
|
|
||||||
}
|
|
||||||
declare module 'node:stream/web' {
|
|
||||||
export * from 'stream/web';
|
|
||||||
}
|
|
||||||
64
node_modules/@types/node/string_decoder.d.ts
generated
vendored
Executable file → Normal file
64
node_modules/@types/node/string_decoder.d.ts
generated
vendored
Executable file → Normal file
@@ -1,67 +1,7 @@
|
|||||||
/**
|
declare module "string_decoder" {
|
||||||
* The `string_decoder` module provides an API for decoding `Buffer` objects into
|
|
||||||
* strings in a manner that preserves encoded multi-byte UTF-8 and UTF-16
|
|
||||||
* characters. It can be accessed using:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const { StringDecoder } = require('string_decoder');
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* The following example shows the basic use of the `StringDecoder` class.
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const { StringDecoder } = require('string_decoder');
|
|
||||||
* const decoder = new StringDecoder('utf8');
|
|
||||||
*
|
|
||||||
* const cent = Buffer.from([0xC2, 0xA2]);
|
|
||||||
* console.log(decoder.write(cent));
|
|
||||||
*
|
|
||||||
* const euro = Buffer.from([0xE2, 0x82, 0xAC]);
|
|
||||||
* console.log(decoder.write(euro));
|
|
||||||
* ```
|
|
||||||
*
|
|
||||||
* When a `Buffer` instance is written to the `StringDecoder` instance, an
|
|
||||||
* internal buffer is used to ensure that the decoded string does not contain
|
|
||||||
* any incomplete multibyte characters. These are held in the buffer until the
|
|
||||||
* next call to `stringDecoder.write()` or until `stringDecoder.end()` is called.
|
|
||||||
*
|
|
||||||
* In the following example, the three UTF-8 encoded bytes of the European Euro
|
|
||||||
* symbol (`€`) are written over three separate operations:
|
|
||||||
*
|
|
||||||
* ```js
|
|
||||||
* const { StringDecoder } = require('string_decoder');
|
|
||||||
* const decoder = new StringDecoder('utf8');
|
|
||||||
*
|
|
||||||
* decoder.write(Buffer.from([0xE2]));
|
|
||||||
* decoder.write(Buffer.from([0x82]));
|
|
||||||
* console.log(decoder.end(Buffer.from([0xAC])));
|
|
||||||
* ```
|
|
||||||
* @see [source](https://github.com/nodejs/node/blob/v16.9.0/lib/string_decoder.js)
|
|
||||||
*/
|
|
||||||
declare module 'string_decoder' {
|
|
||||||
class StringDecoder {
|
class StringDecoder {
|
||||||
constructor(encoding?: BufferEncoding);
|
constructor(encoding?: string);
|
||||||
/**
|
|
||||||
* Returns a decoded string, ensuring that any incomplete multibyte characters at
|
|
||||||
* the end of the `Buffer`, or `TypedArray`, or `DataView` are omitted from the
|
|
||||||
* returned string and stored in an internal buffer for the next call to`stringDecoder.write()` or `stringDecoder.end()`.
|
|
||||||
* @since v0.1.99
|
|
||||||
* @param buffer A `Buffer`, or `TypedArray`, or `DataView` containing the bytes to decode.
|
|
||||||
*/
|
|
||||||
write(buffer: Buffer): string;
|
write(buffer: Buffer): string;
|
||||||
/**
|
|
||||||
* Returns any remaining input stored in the internal buffer as a string. Bytes
|
|
||||||
* representing incomplete UTF-8 and UTF-16 characters will be replaced with
|
|
||||||
* substitution characters appropriate for the character encoding.
|
|
||||||
*
|
|
||||||
* If the `buffer` argument is provided, one final call to `stringDecoder.write()`is performed before returning the remaining input.
|
|
||||||
* After `end()` is called, the `stringDecoder` object can be reused for new input.
|
|
||||||
* @since v0.9.3
|
|
||||||
* @param buffer A `Buffer`, or `TypedArray`, or `DataView` containing the bytes to decode.
|
|
||||||
*/
|
|
||||||
end(buffer?: Buffer): string;
|
end(buffer?: Buffer): string;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
declare module 'node:string_decoder' {
|
|
||||||
export * from 'string_decoder';
|
|
||||||
}
|
|
||||||
|
|||||||
104
node_modules/@types/node/timers.d.ts
generated
vendored
Executable file → Normal file
104
node_modules/@types/node/timers.d.ts
generated
vendored
Executable file → Normal file
@@ -1,94 +1,16 @@
|
|||||||
/**
|
declare module "timers" {
|
||||||
* The `timer` module exposes a global API for scheduling functions to
|
function setTimeout(callback: (...args: any[]) => void, ms: number, ...args: any[]): NodeJS.Timeout;
|
||||||
* be called at some future period of time. Because the timer functions are
|
namespace setTimeout {
|
||||||
* globals, there is no need to call `require('timers')` to use the API.
|
function __promisify__(ms: number): Promise<void>;
|
||||||
*
|
function __promisify__<T>(ms: number, value: T): Promise<T>;
|
||||||
* The timer functions within Node.js implement a similar API as the timers API
|
|
||||||
* provided by Web Browsers but use a different internal implementation that is
|
|
||||||
* built around the Node.js [Event Loop](https://nodejs.org/en/docs/guides/event-loop-timers-and-nexttick/#setimmediate-vs-settimeout).
|
|
||||||
* @see [source](https://github.com/nodejs/node/blob/v16.9.0/lib/timers.js)
|
|
||||||
*/
|
|
||||||
declare module 'timers' {
|
|
||||||
import { Abortable } from 'node:events';
|
|
||||||
import { setTimeout as setTimeoutPromise, setImmediate as setImmediatePromise, setInterval as setIntervalPromise } from 'node:timers/promises';
|
|
||||||
interface TimerOptions extends Abortable {
|
|
||||||
/**
|
|
||||||
* Set to `false` to indicate that the scheduled `Timeout`
|
|
||||||
* should not require the Node.js event loop to remain active.
|
|
||||||
* @default true
|
|
||||||
*/
|
|
||||||
ref?: boolean | undefined;
|
|
||||||
}
|
}
|
||||||
let setTimeout: typeof global.setTimeout;
|
function clearTimeout(timeoutId: NodeJS.Timeout): void;
|
||||||
let clearTimeout: typeof global.clearTimeout;
|
function setInterval(callback: (...args: any[]) => void, ms: number, ...args: any[]): NodeJS.Timeout;
|
||||||
let setInterval: typeof global.setInterval;
|
function clearInterval(intervalId: NodeJS.Timeout): void;
|
||||||
let clearInterval: typeof global.clearInterval;
|
function setImmediate(callback: (...args: any[]) => void, ...args: any[]): NodeJS.Immediate;
|
||||||
let setImmediate: typeof global.setImmediate;
|
namespace setImmediate {
|
||||||
let clearImmediate: typeof global.clearImmediate;
|
function __promisify__(): Promise<void>;
|
||||||
global {
|
function __promisify__<T>(value: T): Promise<T>;
|
||||||
namespace NodeJS {
|
|
||||||
// compatibility with older typings
|
|
||||||
interface Timer extends RefCounted {
|
|
||||||
hasRef(): boolean;
|
|
||||||
refresh(): this;
|
|
||||||
[Symbol.toPrimitive](): number;
|
|
||||||
}
|
|
||||||
interface Immediate extends RefCounted {
|
|
||||||
/**
|
|
||||||
* If true, the `Immediate` object will keep the Node.js event loop active.
|
|
||||||
* @since v11.0.0
|
|
||||||
*/
|
|
||||||
hasRef(): boolean;
|
|
||||||
_onImmediate: Function; // to distinguish it from the Timeout class
|
|
||||||
}
|
|
||||||
interface Timeout extends Timer {
|
|
||||||
/**
|
|
||||||
* If true, the `Timeout` object will keep the Node.js event loop active.
|
|
||||||
* @since v11.0.0
|
|
||||||
*/
|
|
||||||
hasRef(): boolean;
|
|
||||||
/**
|
|
||||||
* Sets the timer's start time to the current time, and reschedules the timer to
|
|
||||||
* call its callback at the previously specified duration adjusted to the current
|
|
||||||
* time. This is useful for refreshing a timer without allocating a new
|
|
||||||
* JavaScript object.
|
|
||||||
*
|
|
||||||
* Using this on a timer that has already called its callback will reactivate the
|
|
||||||
* timer.
|
|
||||||
* @since v10.2.0
|
|
||||||
* @return a reference to `timeout`
|
|
||||||
*/
|
|
||||||
refresh(): this;
|
|
||||||
[Symbol.toPrimitive](): number;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
function setTimeout<TArgs extends any[]>(callback: (...args: TArgs) => void, ms?: number, ...args: TArgs): NodeJS.Timeout;
|
|
||||||
// util.promisify no rest args compability
|
|
||||||
// tslint:disable-next-line void-return
|
|
||||||
function setTimeout(callback: (args: void) => void, ms?: number): NodeJS.Timeout;
|
|
||||||
namespace setTimeout {
|
|
||||||
const __promisify__: typeof setTimeoutPromise;
|
|
||||||
}
|
|
||||||
function clearTimeout(timeoutId: NodeJS.Timeout): void;
|
|
||||||
function setInterval<TArgs extends any[]>(callback: (...args: TArgs) => void, ms?: number, ...args: TArgs): NodeJS.Timer;
|
|
||||||
// util.promisify no rest args compability
|
|
||||||
// tslint:disable-next-line void-return
|
|
||||||
function setInterval(callback: (args: void) => void, ms?: number): NodeJS.Timer;
|
|
||||||
namespace setInterval {
|
|
||||||
const __promisify__: typeof setIntervalPromise;
|
|
||||||
}
|
|
||||||
function clearInterval(intervalId: NodeJS.Timeout): void;
|
|
||||||
function setImmediate<TArgs extends any[]>(callback: (...args: TArgs) => void, ...args: TArgs): NodeJS.Immediate;
|
|
||||||
// util.promisify no rest args compability
|
|
||||||
// tslint:disable-next-line void-return
|
|
||||||
function setImmediate(callback: (args: void) => void): NodeJS.Immediate;
|
|
||||||
namespace setImmediate {
|
|
||||||
const __promisify__: typeof setImmediatePromise;
|
|
||||||
}
|
|
||||||
function clearImmediate(immediateId: NodeJS.Immediate): void;
|
|
||||||
function queueMicrotask(callback: () => void): void;
|
|
||||||
}
|
}
|
||||||
}
|
function clearImmediate(immediateId: NodeJS.Immediate): void;
|
||||||
declare module 'node:timers' {
|
|
||||||
export * from 'timers';
|
|
||||||
}
|
}
|
||||||
|
|||||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user