mirror of
https://github.com/docker/login-action.git
synced 2026-03-11 23:02:07 +00:00
Compare commits
142 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
6af3c118c8 | ||
|
|
caca3368ce | ||
|
|
17f28ab24d | ||
|
|
a875dd0e21 | ||
|
|
7948fffc49 | ||
|
|
5fcefb941d | ||
|
|
3bb2d084df | ||
|
|
242fb9a356 | ||
|
|
fa72313bc3 | ||
|
|
088f62a4f2 | ||
|
|
7929ac7647 | ||
|
|
42d299face | ||
|
|
4858b0b5ea | ||
|
|
1d7d8649e7 | ||
|
|
58855695bb | ||
|
|
d9927c4142 | ||
|
|
b9a4d91ee5 | ||
|
|
b20b9f5e31 | ||
|
|
cb21399f71 | ||
|
|
faae4d6665 | ||
|
|
4d84a3c20f | ||
|
|
6f7ca8828b | ||
|
|
b776a64ec0 | ||
|
|
f6476db6e9 | ||
|
|
46ab6d5c3c | ||
|
|
1cce1654e0 | ||
|
|
9537342dee | ||
|
|
7f47463f56 | ||
|
|
8807319764 | ||
|
|
ebac4bd30d | ||
|
|
499663a42c | ||
|
|
70b0f7898e | ||
|
|
885923496b | ||
|
|
ab92432d0b | ||
|
|
1828bf2d51 | ||
|
|
25c0ca8bab | ||
|
|
f11d2ba650 | ||
|
|
3f83d7b89c | ||
|
|
c9c0083563 | ||
|
|
f694e84504 | ||
|
|
b30d77254f | ||
|
|
95778bc566 | ||
|
|
2c6df6a22f | ||
|
|
c41c9a5c65 | ||
|
|
fc6fe565d2 | ||
|
|
10428f39dc | ||
|
|
1b4cf55146 | ||
|
|
5bcefc987c | ||
|
|
169057673d | ||
|
|
5d62c58fc3 | ||
|
|
73cda5dad9 | ||
|
|
5ffec3343b | ||
|
|
305d960cac | ||
|
|
9a9ae26c89 | ||
|
|
48af9f2a97 | ||
|
|
c08e3a84a9 | ||
|
|
f12fe5c78d | ||
|
|
b566635cc9 | ||
|
|
b8e54a5ea5 | ||
|
|
d64238b93b | ||
|
|
763661a124 | ||
|
|
41fba5a8c6 | ||
|
|
f054a8b539 | ||
|
|
0644d98afe | ||
|
|
9e433e18cf | ||
|
|
39efbd2c12 | ||
|
|
4608add020 | ||
|
|
4fd5d8ead6 | ||
|
|
e2346b6971 | ||
|
|
2051808c83 | ||
|
|
7c220e1b8d | ||
|
|
f4cae19820 | ||
|
|
e5ad366574 | ||
|
|
45bc0ebd6b | ||
|
|
79068f5240 | ||
|
|
8e670da7a1 | ||
|
|
76901a9025 | ||
|
|
31f1bb4610 | ||
|
|
28eb30dcb6 | ||
|
|
03b00fbeba | ||
|
|
5934fe3407 | ||
|
|
3cba154eb7 | ||
|
|
986a54f35b | ||
|
|
fdb725ed4b | ||
|
|
bab7dcbf29 | ||
|
|
c0d23108f7 | ||
|
|
c902ecc709 | ||
|
|
b612a76a31 | ||
|
|
28218f9b04 | ||
|
|
7439f8b467 | ||
|
|
4b206288bd | ||
|
|
4abf7e9de3 | ||
|
|
175e20ba61 | ||
|
|
92a2593650 | ||
|
|
957a8f0d4a | ||
|
|
971b76aea9 | ||
|
|
5b092cf2f7 | ||
|
|
ab81ae06bb | ||
|
|
f4a3bbc2c6 | ||
|
|
e2302b10cc | ||
|
|
c2c723b5d1 | ||
|
|
ab80d026d4 | ||
|
|
9376d24995 | ||
|
|
13fa0663e1 | ||
|
|
75e7be0db4 | ||
|
|
d6f5c68835 | ||
|
|
f3364599c6 | ||
|
|
24646ef465 | ||
|
|
9f189206e8 | ||
|
|
aed1d0c0c1 | ||
|
|
31722002f5 | ||
|
|
2a481b4109 | ||
|
|
9bed62818a | ||
|
|
c718c795e7 | ||
|
|
7b79d7e834 | ||
|
|
f53ca527f7 | ||
|
|
d3160f671f | ||
|
|
3b14bab101 | ||
|
|
1e75de0e0e | ||
|
|
7c9afe235c | ||
|
|
7dc3c3a70e | ||
|
|
b17cf6ab8f | ||
|
|
27c3146301 | ||
|
|
12fd63324c | ||
|
|
a3de3de177 | ||
|
|
9cbd4f95c4 | ||
|
|
ad9eb3b250 | ||
|
|
71b3c789fa | ||
|
|
5e0bc83b38 | ||
|
|
1f68ce02d7 | ||
|
|
767b2f4b7b | ||
|
|
ddf06e1fed | ||
|
|
a5aa81adc8 | ||
|
|
3b9e1f51cd | ||
|
|
adb73476b6 | ||
|
|
5df5104555 | ||
|
|
39ef12fb7a | ||
|
|
1c402b7c97 | ||
|
|
1c2cf9942d | ||
|
|
4b15841c41 | ||
|
|
34d5f75b0d | ||
|
|
a579245f45 |
2
.dockerignore
Normal file
2
.dockerignore
Normal file
@@ -0,0 +1,2 @@
|
|||||||
|
/coverage
|
||||||
|
/node_modules
|
||||||
20
.github/CONTRIBUTING.md
vendored
20
.github/CONTRIBUTING.md
vendored
@@ -2,20 +2,24 @@
|
|||||||
|
|
||||||
Hi there! We're thrilled that you'd like to contribute to this project. Your help is essential for keeping it great.
|
Hi there! We're thrilled that you'd like to contribute to this project. Your help is essential for keeping it great.
|
||||||
|
|
||||||
Contributions to this project are [released](https://help.github.com/articles/github-terms-of-service/#6-contributions-under-repository-license) to the public under the [project's open source license](LICENSE).
|
Contributions to this project are [released](https://docs.github.com/en/github/site-policy/github-terms-of-service#6-contributions-under-repository-license)
|
||||||
|
to the public under the [project's open source license](LICENSE).
|
||||||
|
|
||||||
## Submitting a pull request
|
## Submitting a pull request
|
||||||
|
|
||||||
1. [Fork](https://github.com/docker/login-action/fork) and clone the repository
|
1. [Fork](https://github.com/docker/login-action/fork) and clone the repository
|
||||||
2. Configure and install the dependencies: `yarn install`
|
2. Configure and install the dependencies: `yarn install`
|
||||||
4. Create a new branch: `git checkout -b my-branch-name`
|
3. Create a new branch: `git checkout -b my-branch-name`
|
||||||
5. Make your change
|
4. Make your changes
|
||||||
6. Run pre-checkin: `yarn run pre-checkin`
|
5. Make sure the tests pass: `docker buildx bake test`
|
||||||
7. Push to your fork and [submit a pull request](https://github.com/docker/login-action/compare)
|
6. Format code and build javascript artifacts: `docker buildx bake pre-checkin`
|
||||||
8. Pat your self on the back and wait for your pull request to be reviewed and merged.
|
7. Validate all code has correctly formatted and built: `docker buildx bake validate`
|
||||||
|
8. Push to your fork and [submit a pull request](https://github.com/docker/login-action/compare)
|
||||||
|
9. Pat your self on the back and wait for your pull request to be reviewed and merged.
|
||||||
|
|
||||||
Here are a few things you can do that will increase the likelihood of your pull request being accepted:
|
Here are a few things you can do that will increase the likelihood of your pull request being accepted:
|
||||||
|
|
||||||
|
- Write tests.
|
||||||
- Make sure the `README.md` and any other relevant **documentation are kept up-to-date**.
|
- Make sure the `README.md` and any other relevant **documentation are kept up-to-date**.
|
||||||
- We try to follow [SemVer v2.0.0](https://semver.org/). Randomly breaking public APIs is not an option.
|
- We try to follow [SemVer v2.0.0](https://semver.org/). Randomly breaking public APIs is not an option.
|
||||||
- Keep your change as focused as possible. If there are multiple changes you would like to make that are not dependent upon each other, consider submitting them as **separate pull requests**.
|
- Keep your change as focused as possible. If there are multiple changes you would like to make that are not dependent upon each other, consider submitting them as **separate pull requests**.
|
||||||
@@ -24,5 +28,5 @@ Here are a few things you can do that will increase the likelihood of your pull
|
|||||||
## Resources
|
## Resources
|
||||||
|
|
||||||
- [How to Contribute to Open Source](https://opensource.guide/how-to-contribute/)
|
- [How to Contribute to Open Source](https://opensource.guide/how-to-contribute/)
|
||||||
- [Using Pull Requests](https://help.github.com/articles/about-pull-requests/)
|
- [Using Pull Requests](https://docs.github.com/en/github/collaborating-with-issues-and-pull-requests/about-pull-requests)
|
||||||
- [GitHub Help](https://help.github.com)
|
- [GitHub Help](https://docs.github.com/en)
|
||||||
|
|||||||
3
.github/ISSUE_TEMPLATE/bug_report.md
vendored
3
.github/ISSUE_TEMPLATE/bug_report.md
vendored
@@ -30,4 +30,5 @@ about: Create a report to help us improve
|
|||||||
|
|
||||||
### Logs
|
### Logs
|
||||||
|
|
||||||
> Download the [log file of your build](https://help.github.com/en/actions/configuring-and-managing-workflows/managing-a-workflow-run#downloading-logs) and [attach it](https://help.github.com/en/github/managing-your-work-on-github/file-attachments-on-issues-and-pull-requests) to this issue.
|
> Download the [log file of your build](https://docs.github.com/en/actions/managing-workflow-runs/using-workflow-run-logs#downloading-logs)
|
||||||
|
> and [attach it](https://docs.github.com/en/github/managing-your-work-on-github/file-attachments-on-issues-and-pull-requests) to this issue.
|
||||||
|
|||||||
12
.github/dependabot.yml
vendored
12
.github/dependabot.yml
vendored
@@ -4,19 +4,15 @@ updates:
|
|||||||
directory: "/"
|
directory: "/"
|
||||||
schedule:
|
schedule:
|
||||||
interval: "daily"
|
interval: "daily"
|
||||||
time: "06:00"
|
|
||||||
timezone: "Europe/Paris"
|
|
||||||
labels:
|
labels:
|
||||||
- ":game_die: dependencies"
|
- "dependencies"
|
||||||
- ":robot: bot"
|
- "bot"
|
||||||
- package-ecosystem: "npm"
|
- package-ecosystem: "npm"
|
||||||
directory: "/"
|
directory: "/"
|
||||||
schedule:
|
schedule:
|
||||||
interval: "daily"
|
interval: "daily"
|
||||||
time: "06:00"
|
|
||||||
timezone: "Europe/Paris"
|
|
||||||
allow:
|
allow:
|
||||||
- dependency-type: "production"
|
- dependency-type: "production"
|
||||||
labels:
|
labels:
|
||||||
- ":game_die: dependencies"
|
- "dependencies"
|
||||||
- ":robot: bot"
|
- "bot"
|
||||||
|
|||||||
BIN
.github/docker-login.png
vendored
BIN
.github/docker-login.png
vendored
Binary file not shown.
|
Before Width: | Height: | Size: 5.0 KiB After Width: | Height: | Size: 4.3 KiB |
77
.github/labels.yml
vendored
77
.github/labels.yml
vendored
@@ -1,77 +0,0 @@
|
|||||||
## more info https://github.com/crazy-max/ghaction-github-labeler
|
|
||||||
- # automerge
|
|
||||||
name: ":bell: automerge"
|
|
||||||
color: "8f4fbc"
|
|
||||||
description: ""
|
|
||||||
- # bot
|
|
||||||
name: ":robot: bot"
|
|
||||||
color: "69cde9"
|
|
||||||
description: ""
|
|
||||||
- # bug
|
|
||||||
name: ":bug: bug"
|
|
||||||
color: "b60205"
|
|
||||||
description: ""
|
|
||||||
- # dependencies
|
|
||||||
name: ":game_die: dependencies"
|
|
||||||
color: "0366d6"
|
|
||||||
description: ""
|
|
||||||
- # documentation
|
|
||||||
name: ":memo: documentation"
|
|
||||||
color: "c5def5"
|
|
||||||
description: ""
|
|
||||||
- # duplicate
|
|
||||||
name: ":busts_in_silhouette: duplicate"
|
|
||||||
color: "cccccc"
|
|
||||||
description: ""
|
|
||||||
- # enhancement
|
|
||||||
name: ":sparkles: enhancement"
|
|
||||||
color: "0054ca"
|
|
||||||
description: ""
|
|
||||||
- # feature request
|
|
||||||
name: ":bulb: feature request"
|
|
||||||
color: "0e8a16"
|
|
||||||
description: ""
|
|
||||||
- # feedback
|
|
||||||
name: ":mega: feedback"
|
|
||||||
color: "03a9f4"
|
|
||||||
description: ""
|
|
||||||
- # future maybe
|
|
||||||
name: ":rocket: future maybe"
|
|
||||||
color: "fef2c0"
|
|
||||||
description: ""
|
|
||||||
- # good first issue
|
|
||||||
name: ":hatching_chick: good first issue"
|
|
||||||
color: "7057ff"
|
|
||||||
description: ""
|
|
||||||
- # help wanted
|
|
||||||
name: ":pray: help wanted"
|
|
||||||
color: "4caf50"
|
|
||||||
description: ""
|
|
||||||
- # hold
|
|
||||||
name: ":hand: hold"
|
|
||||||
color: "24292f"
|
|
||||||
description: ""
|
|
||||||
- # invalid
|
|
||||||
name: ":no_entry_sign: invalid"
|
|
||||||
color: "e6e6e6"
|
|
||||||
description: ""
|
|
||||||
- # maybe bug
|
|
||||||
name: ":interrobang: maybe bug"
|
|
||||||
color: "ff5722"
|
|
||||||
description: ""
|
|
||||||
- # needs more info
|
|
||||||
name: ":thinking: needs more info"
|
|
||||||
color: "795548"
|
|
||||||
description: ""
|
|
||||||
- # question
|
|
||||||
name: ":question: question"
|
|
||||||
color: "3f51b5"
|
|
||||||
description: ""
|
|
||||||
- # upstream
|
|
||||||
name: ":eyes: upstream"
|
|
||||||
color: "fbca04"
|
|
||||||
description: ""
|
|
||||||
- # wontfix
|
|
||||||
name: ":coffin: wontfix"
|
|
||||||
color: "ffffff"
|
|
||||||
description: ""
|
|
||||||
355
.github/workflows/ci.yml
vendored
355
.github/workflows/ci.yml
vendored
@@ -1,119 +1,282 @@
|
|||||||
name: ci
|
name: ci
|
||||||
|
|
||||||
on:
|
on:
|
||||||
|
workflow_dispatch:
|
||||||
|
schedule:
|
||||||
|
- cron: '0 10 * * *'
|
||||||
push:
|
push:
|
||||||
branches:
|
branches:
|
||||||
- master
|
- 'master'
|
||||||
- releases/v*
|
- 'releases/v*'
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
# dockerhub:
|
stop-docker:
|
||||||
# runs-on: ${{ matrix.os }}
|
runs-on: ubuntu-latest
|
||||||
# strategy:
|
steps:
|
||||||
# fail-fast: false
|
-
|
||||||
# matrix:
|
name: Checkout
|
||||||
# os:
|
uses: actions/checkout@v2
|
||||||
# - ubuntu-20.04
|
-
|
||||||
# - ubuntu-18.04
|
name: Stop docker
|
||||||
# - ubuntu-16.04
|
run: |
|
||||||
# logout:
|
sudo systemctl stop docker
|
||||||
# - true
|
-
|
||||||
# - false
|
name: Login to GitHub Container Registry
|
||||||
# steps:
|
uses: ./
|
||||||
# -
|
with:
|
||||||
# name: Checkout
|
registry: ghcr.io
|
||||||
# uses: actions/checkout@v2.3.2
|
username: ${{ github.actor }}
|
||||||
# -
|
password: ${{ secrets.GITHUB_TOKEN }}
|
||||||
# name: Login to DockerHub
|
|
||||||
# uses: ./
|
|
||||||
# with:
|
|
||||||
# username: ${{ secrets.DOCKERHUB_USERNAME_TEST }}
|
|
||||||
# password: ${{ secrets.DOCKERHUB_PASSWORD_TEST }}
|
|
||||||
# logout: ${{ matrix.logout }}
|
|
||||||
# -
|
|
||||||
# name: Clear
|
|
||||||
# if: always()
|
|
||||||
# run: |
|
|
||||||
# rm -f ${HOME}/.docker/config.json
|
|
||||||
|
|
||||||
gpr:
|
logout:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
strategy:
|
strategy:
|
||||||
fail-fast: false
|
fail-fast: false
|
||||||
matrix:
|
matrix:
|
||||||
logout:
|
logout:
|
||||||
- true
|
|
||||||
- false
|
- false
|
||||||
|
- true
|
||||||
steps:
|
steps:
|
||||||
-
|
-
|
||||||
name: Checkout
|
name: Checkout
|
||||||
uses: actions/checkout@v2.3.2
|
uses: actions/checkout@v2
|
||||||
-
|
-
|
||||||
name: Login to GitHub Package Registry
|
name: Login to GitHub Container Registry
|
||||||
uses: ./
|
uses: ./
|
||||||
with:
|
with:
|
||||||
registry: docker.pkg.github.com
|
registry: ghcr.io
|
||||||
username: ${{ github.repository_owner }}
|
username: ${{ github.actor }}
|
||||||
password: ${{ secrets.GITHUB_TOKEN }}
|
password: ${{ secrets.GITHUB_TOKEN }}
|
||||||
logout: ${{ matrix.logout }}
|
logout: ${{ matrix.logout }}
|
||||||
-
|
|
||||||
name: Clear
|
|
||||||
if: always()
|
|
||||||
run: |
|
|
||||||
rm -f ${HOME}/.docker/config.json
|
|
||||||
|
|
||||||
# gitlab:
|
dind:
|
||||||
# runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
# strategy:
|
env:
|
||||||
# fail-fast: false
|
DOCKER_CONFIG: $HOME/.docker
|
||||||
# matrix:
|
steps:
|
||||||
# logout:
|
-
|
||||||
# - true
|
name: Checkout
|
||||||
# - false
|
uses: actions/checkout@v2
|
||||||
# steps:
|
-
|
||||||
# -
|
name: Login to GitHub Container Registry
|
||||||
# name: Checkout
|
uses: ./
|
||||||
# uses: actions/checkout@v2.3.2
|
with:
|
||||||
# -
|
registry: ghcr.io
|
||||||
# name: Login to GitLab
|
username: ${{ secrets.GHCR_USERNAME }}
|
||||||
# uses: ./
|
password: ${{ secrets.GHCR_PAT }}
|
||||||
# with:
|
-
|
||||||
# registry: registry.gitlab.com
|
name: DinD
|
||||||
# username: ${{ secrets.GITLAB_USERNAME_TEST }}
|
uses: docker://docker
|
||||||
# password: ${{ secrets.GITLAB_PASSWORD_TEST }}
|
with:
|
||||||
# logout: ${{ matrix.logout }}
|
entrypoint: docker
|
||||||
# -
|
args: pull ghcr.io/docker-ghactiontest/test
|
||||||
# name: Clear
|
-
|
||||||
# if: always()
|
name: Pull private image
|
||||||
# run: |
|
run: |
|
||||||
# rm -f ${HOME}/.docker/config.json
|
docker image prune -a -f >/dev/null 2>&1
|
||||||
#
|
docker pull ghcr.io/docker-ghactiontest/test
|
||||||
# ecr:
|
|
||||||
# runs-on: ${{ matrix.os }}
|
acr:
|
||||||
# strategy:
|
runs-on: ubuntu-latest
|
||||||
# fail-fast: false
|
steps:
|
||||||
# matrix:
|
-
|
||||||
# os:
|
name: Checkout
|
||||||
# - ubuntu-20.04
|
uses: actions/checkout@v2
|
||||||
# - ubuntu-18.04
|
-
|
||||||
# - ubuntu-16.04
|
name: Login to ACR
|
||||||
# logout:
|
uses: ./
|
||||||
# - true
|
with:
|
||||||
# - false
|
registry: ${{ secrets.AZURE_REGISTRY_NAME }}.azurecr.io
|
||||||
# steps:
|
username: ${{ secrets.AZURE_CLIENT_ID }}
|
||||||
# -
|
password: ${{ secrets.AZURE_CLIENT_SECRET }}
|
||||||
# name: Checkout
|
|
||||||
# uses: actions/checkout@v2.3.1
|
dockerhub:
|
||||||
# -
|
runs-on: ${{ matrix.os }}
|
||||||
# name: Login to ECR
|
strategy:
|
||||||
# uses: ./
|
fail-fast: false
|
||||||
# with:
|
matrix:
|
||||||
# registry: ${{ secrets.AWS_ACCOUNT_NUMBER }}.dkr.ecr.${{ secrets.AWS_REGION }}.amazonaws.com
|
os:
|
||||||
# username: ${{ secrets.AWS_ACCESS_KEY_ID }}
|
- ubuntu-latest
|
||||||
# password: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
|
- windows-latest
|
||||||
# logout: ${{ matrix.logout }}
|
steps:
|
||||||
# -
|
-
|
||||||
# name: Clear
|
name: Checkout
|
||||||
# if: always()
|
uses: actions/checkout@v2
|
||||||
# run: |
|
-
|
||||||
# rm -f ${HOME}/.docker/config.json
|
name: Login to Docker Hub
|
||||||
|
uses: ./
|
||||||
|
with:
|
||||||
|
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
||||||
|
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
||||||
|
|
||||||
|
ecr:
|
||||||
|
runs-on: ${{ matrix.os }}
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
os:
|
||||||
|
- ubuntu-latest
|
||||||
|
- windows-latest
|
||||||
|
steps:
|
||||||
|
-
|
||||||
|
name: Checkout
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
-
|
||||||
|
name: Login to ECR
|
||||||
|
uses: ./
|
||||||
|
with:
|
||||||
|
registry: ${{ secrets.AWS_ACCOUNT_NUMBER }}.dkr.ecr.us-east-1.amazonaws.com
|
||||||
|
username: ${{ secrets.AWS_ACCESS_KEY_ID }}
|
||||||
|
password: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
|
||||||
|
|
||||||
|
ecr-aws-creds:
|
||||||
|
runs-on: ${{ matrix.os }}
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
os:
|
||||||
|
- ubuntu-latest
|
||||||
|
- windows-latest
|
||||||
|
steps:
|
||||||
|
-
|
||||||
|
name: Checkout
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
-
|
||||||
|
name: Configure AWS Credentials
|
||||||
|
uses: aws-actions/configure-aws-credentials@v1
|
||||||
|
with:
|
||||||
|
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }}
|
||||||
|
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
|
||||||
|
aws-region: us-east-1
|
||||||
|
-
|
||||||
|
name: Login to ECR
|
||||||
|
uses: ./
|
||||||
|
with:
|
||||||
|
registry: ${{ secrets.AWS_ACCOUNT_NUMBER }}.dkr.ecr.us-east-1.amazonaws.com
|
||||||
|
|
||||||
|
ecr-public:
|
||||||
|
runs-on: ${{ matrix.os }}
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
os:
|
||||||
|
- ubuntu-latest
|
||||||
|
- windows-latest
|
||||||
|
steps:
|
||||||
|
-
|
||||||
|
name: Checkout
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
-
|
||||||
|
name: Login to Public ECR
|
||||||
|
uses: ./
|
||||||
|
with:
|
||||||
|
registry: public.ecr.aws
|
||||||
|
username: ${{ secrets.AWS_ACCESS_KEY_ID }}
|
||||||
|
password: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
|
||||||
|
env:
|
||||||
|
AWS_REGION: us-east-1
|
||||||
|
|
||||||
|
ecr-public-aws-creds:
|
||||||
|
runs-on: ${{ matrix.os }}
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
os:
|
||||||
|
- ubuntu-latest
|
||||||
|
- windows-latest
|
||||||
|
steps:
|
||||||
|
-
|
||||||
|
name: Checkout
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
-
|
||||||
|
name: Configure AWS Credentials
|
||||||
|
uses: aws-actions/configure-aws-credentials@v1
|
||||||
|
with:
|
||||||
|
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }}
|
||||||
|
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
|
||||||
|
aws-region: us-east-1
|
||||||
|
-
|
||||||
|
name: Login to ECR
|
||||||
|
uses: ./
|
||||||
|
with:
|
||||||
|
registry: public.ecr.aws
|
||||||
|
|
||||||
|
github-container:
|
||||||
|
runs-on: ${{ matrix.os }}
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
os:
|
||||||
|
- ubuntu-latest
|
||||||
|
- windows-latest
|
||||||
|
steps:
|
||||||
|
-
|
||||||
|
name: Checkout
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
-
|
||||||
|
name: Login to GitHub Container Registry
|
||||||
|
uses: ./
|
||||||
|
with:
|
||||||
|
registry: ghcr.io
|
||||||
|
username: ${{ github.actor }}
|
||||||
|
password: ${{ secrets.GITHUB_TOKEN }}
|
||||||
|
|
||||||
|
gitlab:
|
||||||
|
runs-on: ${{ matrix.os }}
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
os:
|
||||||
|
- ubuntu-latest
|
||||||
|
- windows-latest
|
||||||
|
steps:
|
||||||
|
-
|
||||||
|
name: Checkout
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
-
|
||||||
|
name: Login to GitLab
|
||||||
|
uses: ./
|
||||||
|
with:
|
||||||
|
registry: registry.gitlab.com
|
||||||
|
username: ${{ secrets.GITLAB_USERNAME }}
|
||||||
|
password: ${{ secrets.GITLAB_TOKEN }}
|
||||||
|
|
||||||
|
google-artifact:
|
||||||
|
runs-on: ${{ matrix.os }}
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
os:
|
||||||
|
- ubuntu-latest
|
||||||
|
- windows-latest
|
||||||
|
steps:
|
||||||
|
-
|
||||||
|
name: Checkout
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
-
|
||||||
|
name: Login to Google Artifact Registry
|
||||||
|
uses: ./
|
||||||
|
with:
|
||||||
|
registry: ${{ secrets.GAR_LOCATION }}-docker.pkg.dev
|
||||||
|
username: _json_key
|
||||||
|
password: ${{ secrets.GAR_JSON_KEY }}
|
||||||
|
|
||||||
|
google-container:
|
||||||
|
runs-on: ${{ matrix.os }}
|
||||||
|
strategy:
|
||||||
|
fail-fast: false
|
||||||
|
matrix:
|
||||||
|
os:
|
||||||
|
- ubuntu-latest
|
||||||
|
- windows-latest
|
||||||
|
steps:
|
||||||
|
-
|
||||||
|
name: Checkout
|
||||||
|
uses: actions/checkout@v2
|
||||||
|
-
|
||||||
|
name: Login to Google Container Registry
|
||||||
|
uses: ./
|
||||||
|
with:
|
||||||
|
registry: gcr.io
|
||||||
|
username: _json_key
|
||||||
|
password: ${{ secrets.GCR_JSON_KEY }}
|
||||||
|
|||||||
20
.github/workflows/labels.yml
vendored
20
.github/workflows/labels.yml
vendored
@@ -1,20 +0,0 @@
|
|||||||
name: labels
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
branches:
|
|
||||||
- 'master'
|
|
||||||
paths:
|
|
||||||
- '.github/labels.yml'
|
|
||||||
- '.github/workflows/labels.yml'
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
labeler:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
-
|
|
||||||
name: Checkout
|
|
||||||
uses: actions/checkout@v2.3.2
|
|
||||||
-
|
|
||||||
name: Run Labeler
|
|
||||||
uses: crazy-max/ghaction-github-labeler@v3.0.0
|
|
||||||
36
.github/workflows/test.yml
vendored
36
.github/workflows/test.yml
vendored
@@ -3,38 +3,32 @@ name: test
|
|||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches:
|
branches:
|
||||||
- master
|
- 'master'
|
||||||
- releases/v*
|
- 'releases/v*'
|
||||||
paths-ignore:
|
|
||||||
- '**.md'
|
|
||||||
pull_request:
|
pull_request:
|
||||||
paths-ignore:
|
branches:
|
||||||
- '**.md'
|
- 'master'
|
||||||
|
- 'releases/v*'
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
test:
|
test:
|
||||||
runs-on: ${{ matrix.os }}
|
runs-on: ubuntu-latest
|
||||||
strategy:
|
|
||||||
fail-fast: false
|
|
||||||
matrix:
|
|
||||||
os:
|
|
||||||
- ubuntu-20.04
|
|
||||||
- ubuntu-18.04
|
|
||||||
- ubuntu-16.04
|
|
||||||
steps:
|
steps:
|
||||||
-
|
-
|
||||||
name: Checkout
|
name: Checkout
|
||||||
uses: actions/checkout@v2.3.2
|
uses: actions/checkout@v2
|
||||||
-
|
-
|
||||||
name: Install
|
name: Validate
|
||||||
run: yarn install
|
uses: docker/bake-action@v1
|
||||||
|
with:
|
||||||
|
targets: validate
|
||||||
-
|
-
|
||||||
name: Test
|
name: Test
|
||||||
run: yarn run test
|
uses: docker/bake-action@v1
|
||||||
|
with:
|
||||||
|
targets: test
|
||||||
-
|
-
|
||||||
name: Upload coverage
|
name: Upload coverage
|
||||||
uses: codecov/codecov-action@v1.0.13
|
uses: codecov/codecov-action@v2
|
||||||
if: success()
|
|
||||||
with:
|
with:
|
||||||
token: ${{ secrets.CODECOV_TOKEN }}
|
|
||||||
file: ./coverage/clover.xml
|
file: ./coverage/clover.xml
|
||||||
|
|||||||
@@ -1,5 +1,5 @@
|
|||||||
{
|
{
|
||||||
"printWidth": 120,
|
"printWidth": 240,
|
||||||
"tabWidth": 2,
|
"tabWidth": 2,
|
||||||
"useTabs": false,
|
"useTabs": false,
|
||||||
"semi": true,
|
"semi": true,
|
||||||
|
|||||||
350
README.md
350
README.md
@@ -1,6 +1,6 @@
|
|||||||
[](https://github.com/docker/login-action/releases/latest)
|
[](https://github.com/docker/login-action/releases/latest)
|
||||||
[](https://github.com/marketplace/actions/docker-login)
|
[](https://github.com/marketplace/actions/docker-login)
|
||||||
[](https://github.com/docker/login-action/actions?workflow=ci)
|
[](https://github.com/docker/login-action/actions?workflow=ci)
|
||||||
[](https://github.com/docker/login-action/actions?workflow=test)
|
[](https://github.com/docker/login-action/actions?workflow=test)
|
||||||
[](https://codecov.io/gh/docker/login-action)
|
[](https://codecov.io/gh/docker/login-action)
|
||||||
|
|
||||||
@@ -8,33 +8,30 @@
|
|||||||
|
|
||||||
GitHub Action to login against a Docker registry.
|
GitHub Action to login against a Docker registry.
|
||||||
|
|
||||||
> :bulb: See also:
|
|
||||||
> * [setup-buildx](https://github.com/docker/setup-buildx-action) action
|
|
||||||
> * [setup-qemu](https://github.com/docker/setup-qemu-action) action
|
|
||||||
> * [build-push](https://github.com/docker/build-push-action) action
|
|
||||||
|
|
||||||

|

|
||||||
|
|
||||||
___
|
___
|
||||||
|
|
||||||
* [Usage](#usage)
|
* [Usage](#usage)
|
||||||
* [DockerHub](#dockerhub)
|
* [Docker Hub](#docker-hub)
|
||||||
* [GitHub Packages Docker Registry](#github-packages-docker-registry)
|
|
||||||
* [GitHub Container Registry](#github-container-registry)
|
* [GitHub Container Registry](#github-container-registry)
|
||||||
* [GitLab](#gitlab)
|
* [GitLab](#gitlab)
|
||||||
* [Azure Container Registry (ACR)](#azure-container-registry-acr)
|
* [Azure Container Registry (ACR)](#azure-container-registry-acr)
|
||||||
* [Google Container Registry (GCR)](#google-container-registry-gcr)
|
* [Google Container Registry (GCR)](#google-container-registry-gcr)
|
||||||
|
* [Google Artifact Registry (GAR)](#google-artifact-registry-gar)
|
||||||
* [AWS Elastic Container Registry (ECR)](#aws-elastic-container-registry-ecr)
|
* [AWS Elastic Container Registry (ECR)](#aws-elastic-container-registry-ecr)
|
||||||
|
* [AWS Public Elastic Container Registry (ECR)](#aws-public-elastic-container-registry-ecr)
|
||||||
|
* [OCI Oracle Cloud Infrastructure Registry (OCIR)](#oci-oracle-cloud-infrastructure-registry-ocir)
|
||||||
|
* [Quay.io](#quayio)
|
||||||
* [Customizing](#customizing)
|
* [Customizing](#customizing)
|
||||||
* [inputs](#inputs)
|
* [inputs](#inputs)
|
||||||
* [Keep up-to-date with GitHub Dependabot](#keep-up-to-date-with-github-dependabot)
|
* [Keep up-to-date with GitHub Dependabot](#keep-up-to-date-with-github-dependabot)
|
||||||
* [Limitation](#limitation)
|
|
||||||
|
|
||||||
## Usage
|
## Usage
|
||||||
|
|
||||||
### DockerHub
|
### Docker Hub
|
||||||
|
|
||||||
To authenticate against [DockerHub](https://hub.docker.com) it's strongly recommended to create a
|
To authenticate against [Docker Hub](https://hub.docker.com) it's strongly recommended to create a
|
||||||
[personal access token](https://docs.docker.com/docker-hub/access-tokens/) as an alternative to your password.
|
[personal access token](https://docs.docker.com/docker-hub/access-tokens/) as an alternative to your password.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
@@ -42,60 +39,32 @@ name: ci
|
|||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches: master
|
branches: main
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
login:
|
login:
|
||||||
runs-on: ubuntu-latest
|
runs-on: ubuntu-latest
|
||||||
steps:
|
steps:
|
||||||
-
|
-
|
||||||
name: Login to DockerHub
|
name: Login to Docker Hub
|
||||||
uses: docker/login-action@v1
|
uses: docker/login-action@v1
|
||||||
with:
|
with:
|
||||||
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
username: ${{ secrets.DOCKERHUB_USERNAME }}
|
||||||
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
password: ${{ secrets.DOCKERHUB_TOKEN }}
|
||||||
```
|
```
|
||||||
|
|
||||||
### GitHub Packages Docker Registry
|
|
||||||
|
|
||||||
> :warning: GitHub Packages Docker Registry (aka `docker.pkg.github.com`) **is deprecated** and will sunset early next
|
|
||||||
> year. It's strongly advised to [migrate to GitHub Container Registry](https://docs.github.com/en/packages/getting-started-with-github-container-registry/migrating-to-github-container-registry-for-docker-images)
|
|
||||||
> instead.
|
|
||||||
|
|
||||||
You can configure the Docker client to use [GitHub Packages to publish and retrieve docker images](https://docs.github.com/en/packages/using-github-packages-with-your-projects-ecosystem/configuring-docker-for-use-with-github-packages).
|
|
||||||
|
|
||||||
```yaml
|
|
||||||
name: ci
|
|
||||||
|
|
||||||
on:
|
|
||||||
push:
|
|
||||||
branches: master
|
|
||||||
|
|
||||||
jobs:
|
|
||||||
login:
|
|
||||||
runs-on: ubuntu-latest
|
|
||||||
steps:
|
|
||||||
-
|
|
||||||
name: Login to GitHub Packages Docker Registry
|
|
||||||
uses: docker/login-action@v1
|
|
||||||
with:
|
|
||||||
registry: docker.pkg.github.com
|
|
||||||
username: ${{ github.repository_owner }}
|
|
||||||
password: ${{ secrets.GITHUB_TOKEN }}
|
|
||||||
```
|
|
||||||
|
|
||||||
### GitHub Container Registry
|
### GitHub Container Registry
|
||||||
|
|
||||||
To authenticate against the [GitHub Container Registry](https://docs.github.com/en/packages/getting-started-with-github-container-registry),
|
To authenticate against the [GitHub Container Registry](https://docs.github.com/en/packages/working-with-a-github-packages-registry/working-with-the-container-registry),
|
||||||
you will need to create a new [personal access token (PAT)](https://docs.github.com/en/github/authenticating-to-github/creating-a-personal-access-token)
|
use the [`GITHUB_TOKEN`](https://docs.github.com/en/actions/reference/authentication-in-a-workflow) for the best
|
||||||
with the [appropriate scopes](https://docs.github.com/en/packages/getting-started-with-github-container-registry/migrating-to-github-container-registry-for-docker-images#authenticating-with-the-container-registry).
|
security and experience.
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
name: ci
|
name: ci
|
||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches: master
|
branches: main
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
login:
|
login:
|
||||||
@@ -106,10 +75,16 @@ jobs:
|
|||||||
uses: docker/login-action@v1
|
uses: docker/login-action@v1
|
||||||
with:
|
with:
|
||||||
registry: ghcr.io
|
registry: ghcr.io
|
||||||
username: ${{ github.repository_owner }}
|
username: ${{ github.actor }}
|
||||||
password: ${{ secrets.CR_PAT }}
|
password: ${{ secrets.GITHUB_TOKEN }}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
You may need to [manage write and read access of GitHub Actions](https://docs.github.com/en/packages/managing-github-packages-using-github-actions-workflows/publishing-and-installing-a-package-with-github-actions#upgrading-a-workflow-that-accesses-ghcrio)
|
||||||
|
for repositories in the container settings.
|
||||||
|
|
||||||
|
You can also use a [personal access token (PAT)](https://docs.github.com/en/github/authenticating-to-github/creating-a-personal-access-token)
|
||||||
|
with the [appropriate scopes](https://docs.github.com/en/packages/getting-started-with-github-container-registry/migrating-to-github-container-registry-for-docker-images#authenticating-with-the-container-registry).
|
||||||
|
|
||||||
### GitLab
|
### GitLab
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
@@ -117,7 +92,7 @@ name: ci
|
|||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches: master
|
branches: main
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
login:
|
login:
|
||||||
@@ -143,7 +118,7 @@ name: ci
|
|||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches: master
|
branches: main
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
login:
|
login:
|
||||||
@@ -162,17 +137,62 @@ jobs:
|
|||||||
|
|
||||||
### Google Container Registry (GCR)
|
### Google Container Registry (GCR)
|
||||||
|
|
||||||
Use a service account with the ability to push to GCR and [configure access control](https://cloud.google.com/container-registry/docs/access-control).
|
> [Google Artifact Registry](#google-artifact-registry-gar) is the evolution of Google Container Registry. As a
|
||||||
Then create and download the JSON key for this service account and save content of `.json` file
|
> fully-managed service with support for both container images and non-container artifacts. If you currently use
|
||||||
[as a secret](https://docs.github.com/en/actions/configuring-and-managing-workflows/creating-and-storing-encrypted-secrets#creating-encrypted-secrets-for-a-repository)
|
> Google Container Registry, use the information [on this page](https://cloud.google.com/artifact-registry/docs/transition/transition-from-gcr)
|
||||||
called `GCR_JSON_KEY` in your GitHub repo. Ensure you set the username to `_json_key`.
|
> to learn about transitioning to Google Artifact Registry.
|
||||||
|
|
||||||
|
You can use either workload identity federation based keyless authentication or service account based authentication.
|
||||||
|
|
||||||
|
#### Workload identity federation based authentication
|
||||||
|
|
||||||
|
Configure the workload identity federation for github actions in gcloud (for steps, [refer here](https://github.com/google-github-actions/auth#setting-up-workload-identity-federation)). In the steps, your service account should the ability to push to GCR. Then use google-github-actions/auth action for authentication using workload identity like below:
|
||||||
|
|
||||||
```yaml
|
```yaml
|
||||||
name: ci
|
name: ci
|
||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches: master
|
branches: main
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
login:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- id: 'auth'
|
||||||
|
name: 'Authenticate to Google Cloud'
|
||||||
|
uses: 'google-github-actions/auth@v0'
|
||||||
|
with:
|
||||||
|
token_format: 'access_token'
|
||||||
|
workload_identity_provider: '<workload_identity_provider>'
|
||||||
|
service_account: '<service_account>'
|
||||||
|
|
||||||
|
- name: Login to GCR
|
||||||
|
uses: docker/login-action@v1
|
||||||
|
with:
|
||||||
|
registry: gcr.io
|
||||||
|
username: oauth2accesstoken
|
||||||
|
password: ${{ steps.auth.outputs.access_token }}
|
||||||
|
```
|
||||||
|
|
||||||
|
> Replace `<workload_identity_provider>` with configured workload identity provider. For steps to configure, [refer here](https://github.com/google-github-actions/auth#setting-up-workload-identity-federation).
|
||||||
|
|
||||||
|
> Replace `<service_account>` with configured service account in workload identity provider which has access to push to GCR
|
||||||
|
|
||||||
|
#### Service account based authentication
|
||||||
|
|
||||||
|
Use a service account with the ability to push to GCR and [configure access control](https://cloud.google.com/container-registry/docs/access-control).
|
||||||
|
Then create and download the JSON key for this service account and save content of `.json` file
|
||||||
|
[as a secret](https://docs.github.com/en/actions/configuring-and-managing-workflows/creating-and-storing-encrypted-secrets#creating-encrypted-secrets-for-a-repository)
|
||||||
|
called `GCR_JSON_KEY` in your GitHub repo. Ensure you set the username to `_json_key`,
|
||||||
|
or `_json_key_base64` if you use a base64-encoded key.
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
name: ci
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: main
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
login:
|
login:
|
||||||
@@ -187,9 +207,81 @@ jobs:
|
|||||||
password: ${{ secrets.GCR_JSON_KEY }}
|
password: ${{ secrets.GCR_JSON_KEY }}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
### Google Artifact Registry (GAR)
|
||||||
|
|
||||||
|
You can use either workload identity federation based keyless authentication or service account based authentication.
|
||||||
|
|
||||||
|
#### Workload identity federation based authentication
|
||||||
|
|
||||||
|
Configure the workload identity federation for github actions in gcloud (for steps, [refer here](https://github.com/google-github-actions/auth#setting-up-workload-identity-federation)). In the steps, your service account should the ability to push to GAR. Then use google-github-actions/auth action for authentication using workload identity like below:
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
name: ci
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: main
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
login:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
- id: 'auth'
|
||||||
|
name: 'Authenticate to Google Cloud'
|
||||||
|
uses: 'google-github-actions/auth@v0'
|
||||||
|
with:
|
||||||
|
token_format: 'access_token'
|
||||||
|
workload_identity_provider: '<workload_identity_provider>'
|
||||||
|
service_account: '<service_account>'
|
||||||
|
|
||||||
|
- name: Login to GAR
|
||||||
|
uses: docker/login-action@v1
|
||||||
|
with:
|
||||||
|
registry: <location>-docker.pkg.dev
|
||||||
|
username: oauth2accesstoken
|
||||||
|
password: ${{ steps.auth.outputs.access_token }}
|
||||||
|
```
|
||||||
|
> Replace `<workload_identity_provider>` with configured workload identity provider
|
||||||
|
|
||||||
|
> Replace `<service_account>` with configured service account in workload identity provider which has access to push to GCR
|
||||||
|
|
||||||
|
> Replace `<location>` with the regional or multi-regional [location](https://cloud.google.com/artifact-registry/docs/repo-organize#locations)
|
||||||
|
> of the repository where the image is stored.
|
||||||
|
|
||||||
|
#### Service account based authentication
|
||||||
|
|
||||||
|
Use a service account with the ability to push to GAR and [configure access control](https://cloud.google.com/artifact-registry/docs/access-control).
|
||||||
|
Then create and download the JSON key for this service account and save content of `.json` file
|
||||||
|
[as a secret](https://docs.github.com/en/actions/configuring-and-managing-workflows/creating-and-storing-encrypted-secrets#creating-encrypted-secrets-for-a-repository)
|
||||||
|
called `GAR_JSON_KEY` in your GitHub repo. Ensure you set the username to `_json_key`,
|
||||||
|
or `_json_key_base64` if you use a base64-encoded key.
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
name: ci
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: main
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
login:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
-
|
||||||
|
name: Login to GAR
|
||||||
|
uses: docker/login-action@v1
|
||||||
|
with:
|
||||||
|
registry: <location>-docker.pkg.dev
|
||||||
|
username: _json_key
|
||||||
|
password: ${{ secrets.GAR_JSON_KEY }}
|
||||||
|
```
|
||||||
|
|
||||||
|
> Replace `<location>` with the regional or multi-regional [location](https://cloud.google.com/artifact-registry/docs/repo-organize#locations)
|
||||||
|
> of the repository where the image is stored.
|
||||||
|
|
||||||
### AWS Elastic Container Registry (ECR)
|
### AWS Elastic Container Registry (ECR)
|
||||||
|
|
||||||
Use an IAM user with the [ability to push to ECR](https://docs.aws.amazon.com/AmazonECR/latest/userguide/ecr_managed_policies.html).
|
Use an IAM user with the ability to [push to ECR with `AmazonEC2ContainerRegistryPowerUser` managed policy for example](https://docs.aws.amazon.com/AmazonECR/latest/userguide/ecr_managed_policies.html#AmazonEC2ContainerRegistryPowerUser).
|
||||||
Then create and download access keys and save `AWS_ACCESS_KEY_ID` and `AWS_SECRET_ACCESS_KEY` [as secrets](https://docs.github.com/en/actions/configuring-and-managing-workflows/creating-and-storing-encrypted-secrets#creating-encrypted-secrets-for-a-repository)
|
Then create and download access keys and save `AWS_ACCESS_KEY_ID` and `AWS_SECRET_ACCESS_KEY` [as secrets](https://docs.github.com/en/actions/configuring-and-managing-workflows/creating-and-storing-encrypted-secrets#creating-encrypted-secrets-for-a-repository)
|
||||||
in your GitHub repo.
|
in your GitHub repo.
|
||||||
|
|
||||||
@@ -198,7 +290,7 @@ name: ci
|
|||||||
|
|
||||||
on:
|
on:
|
||||||
push:
|
push:
|
||||||
branches: master
|
branches: main
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
login:
|
login:
|
||||||
@@ -213,8 +305,149 @@ jobs:
|
|||||||
password: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
|
password: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
|
||||||
```
|
```
|
||||||
|
|
||||||
|
If you need to log in to Amazon ECR registries associated with other accounts, you can use the `AWS_ACCOUNT_IDS`
|
||||||
|
environment variable:
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
name: ci
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: main
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
login:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
-
|
||||||
|
name: Login to ECR
|
||||||
|
uses: docker/login-action@v1
|
||||||
|
with:
|
||||||
|
registry: <aws-account-number>.dkr.ecr.<region>.amazonaws.com
|
||||||
|
username: ${{ secrets.AWS_ACCESS_KEY_ID }}
|
||||||
|
password: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
|
||||||
|
env:
|
||||||
|
AWS_ACCOUNT_IDS: 012345678910,023456789012
|
||||||
|
```
|
||||||
|
|
||||||
|
> Only available with [AWS CLI version 1](https://docs.aws.amazon.com/cli/latest/reference/ecr/get-login.html)
|
||||||
|
|
||||||
|
You can also use the [Configure AWS Credentials](https://github.com/aws-actions/configure-aws-credentials) action in
|
||||||
|
combination with this action:
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
name: ci
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: main
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
login:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
-
|
||||||
|
name: Configure AWS Credentials
|
||||||
|
uses: aws-actions/configure-aws-credentials@v1
|
||||||
|
with:
|
||||||
|
aws-access-key-id: ${{ secrets.AWS_ACCESS_KEY_ID }}
|
||||||
|
aws-secret-access-key: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
|
||||||
|
aws-region: <region>
|
||||||
|
-
|
||||||
|
name: Login to ECR
|
||||||
|
uses: docker/login-action@v1
|
||||||
|
with:
|
||||||
|
registry: <aws-account-number>.dkr.ecr.<region>.amazonaws.com
|
||||||
|
```
|
||||||
|
|
||||||
> Replace `<aws-account-number>` and `<region>` with their respective values.
|
> Replace `<aws-account-number>` and `<region>` with their respective values.
|
||||||
|
|
||||||
|
### AWS Public Elastic Container Registry (ECR)
|
||||||
|
|
||||||
|
Use an IAM user with the ability to [push to ECR Public with `AmazonElasticContainerRegistryPublicPowerUser` managed policy for example](https://docs.aws.amazon.com/AmazonECR/latest/public/public-ecr-managed-policies.html#AmazonElasticContainerRegistryPublicPowerUser).
|
||||||
|
Then create and download access keys and save `AWS_ACCESS_KEY_ID` and `AWS_SECRET_ACCESS_KEY` [as secrets](https://docs.github.com/en/actions/configuring-and-managing-workflows/creating-and-storing-encrypted-secrets#creating-encrypted-secrets-for-a-repository)
|
||||||
|
in your GitHub repo.
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
name: ci
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: main
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
login:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
-
|
||||||
|
name: Login to Public ECR
|
||||||
|
uses: docker/login-action@v1
|
||||||
|
with:
|
||||||
|
registry: public.ecr.aws
|
||||||
|
username: ${{ secrets.AWS_ACCESS_KEY_ID }}
|
||||||
|
password: ${{ secrets.AWS_SECRET_ACCESS_KEY }}
|
||||||
|
env:
|
||||||
|
AWS_REGION: <region>
|
||||||
|
```
|
||||||
|
|
||||||
|
> Replace `<region>` with its respective value (default `us-east-1`).
|
||||||
|
|
||||||
|
### OCI Oracle Cloud Infrastructure Registry (OCIR)
|
||||||
|
|
||||||
|
To push into OCIR in specific tenancy the [username](https://www.oracle.com/webfolder/technetwork/tutorials/obe/oci/registry/index.html#LogintoOracleCloudInfrastructureRegistryfromtheDockerCLI)
|
||||||
|
must be placed in format `<tenancy>/<username>` (in case of federated tenancy use the format
|
||||||
|
`<tenancy-namespace>/oracleidentitycloudservice/<username>`).
|
||||||
|
|
||||||
|
For password [create an auth token](https://www.oracle.com/webfolder/technetwork/tutorials/obe/oci/registry/index.html#GetanAuthToken).
|
||||||
|
Save username and token [as a secrets](https://docs.github.com/en/actions/configuring-and-managing-workflows/creating-and-storing-encrypted-secrets#creating-encrypted-secrets-for-a-repository)
|
||||||
|
in your GitHub repo.
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
name: ci
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: main
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
login:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
-
|
||||||
|
name: Login to OCIR
|
||||||
|
uses: docker/login-action@v1
|
||||||
|
with:
|
||||||
|
registry: <region>.ocir.io
|
||||||
|
username: ${{ secrets.OCI_USERNAME }}
|
||||||
|
password: ${{ secrets.OCI_TOKEN }}
|
||||||
|
```
|
||||||
|
|
||||||
|
> Replace `<region>` with their respective values from [availability regions](https://docs.cloud.oracle.com/iaas/Content/Registry/Concepts/registryprerequisites.htm#Availab)
|
||||||
|
|
||||||
|
### Quay.io
|
||||||
|
|
||||||
|
Use a [Robot account](https://docs.quay.io/glossary/robot-accounts.html) with the ability to push to a public/private Quay.io repository.
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
name: ci
|
||||||
|
|
||||||
|
on:
|
||||||
|
push:
|
||||||
|
branches: main
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
login:
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
steps:
|
||||||
|
-
|
||||||
|
name: Login to Quay.io
|
||||||
|
uses: docker/login-action@v1
|
||||||
|
with:
|
||||||
|
registry: quay.io
|
||||||
|
username: ${{ secrets.QUAY_USERNAME }}
|
||||||
|
password: ${{ secrets.QUAY_ROBOT_TOKEN }}
|
||||||
|
```
|
||||||
|
|
||||||
## Customizing
|
## Customizing
|
||||||
|
|
||||||
### inputs
|
### inputs
|
||||||
@@ -226,6 +459,7 @@ Following inputs can be used as `step.with` keys
|
|||||||
| `registry` | String | | Server address of Docker registry. If not set then will default to Docker Hub |
|
| `registry` | String | | Server address of Docker registry. If not set then will default to Docker Hub |
|
||||||
| `username` | String | | Username used to log against the Docker registry |
|
| `username` | String | | Username used to log against the Docker registry |
|
||||||
| `password` | String | | Password or personal access token used to log against the Docker registry |
|
| `password` | String | | Password or personal access token used to log against the Docker registry |
|
||||||
|
| `ecr` | String | `auto` | Specifies whether the given registry is ECR (`auto`, `true` or `false`) |
|
||||||
| `logout` | Bool | `true` | Log out from the Docker registry at the end of a job |
|
| `logout` | Bool | `true` | Log out from the Docker registry at the end of a job |
|
||||||
|
|
||||||
## Keep up-to-date with GitHub Dependabot
|
## Keep up-to-date with GitHub Dependabot
|
||||||
@@ -243,7 +477,3 @@ updates:
|
|||||||
schedule:
|
schedule:
|
||||||
interval: "daily"
|
interval: "daily"
|
||||||
```
|
```
|
||||||
|
|
||||||
## Limitation
|
|
||||||
|
|
||||||
This action is only available for Linux [virtual environments](https://help.github.com/en/articles/virtual-environments-for-github-actions#supported-virtual-environments-and-hardware-resources).
|
|
||||||
|
|||||||
@@ -1,54 +1,155 @@
|
|||||||
import * as semver from 'semver';
|
import {AuthorizationData} from '@aws-sdk/client-ecr';
|
||||||
import * as aws from '../src/aws';
|
import * as aws from '../src/aws';
|
||||||
|
|
||||||
describe('isECR', () => {
|
describe('isECR', () => {
|
||||||
test.each([
|
test.each([
|
||||||
['registry.gitlab.com', false],
|
['registry.gitlab.com', false],
|
||||||
['gcr.io', false],
|
['gcr.io', false],
|
||||||
['012345678901.dkr.ecr.eu-west-3.amazonaws.com', true]
|
['012345678901.dkr.ecr.eu-west-3.amazonaws.com', true],
|
||||||
|
['876820548815.dkr.ecr.cn-north-1.amazonaws.com.cn', true],
|
||||||
|
['390948362332.dkr.ecr.cn-northwest-1.amazonaws.com.cn', true],
|
||||||
|
['public.ecr.aws', true]
|
||||||
])('given registry %p', async (registry, expected) => {
|
])('given registry %p', async (registry, expected) => {
|
||||||
expect(await aws.isECR(registry)).toEqual(expected);
|
expect(aws.isECR(registry)).toEqual(expected);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('getCLI', () => {
|
describe('isPubECR', () => {
|
||||||
it('exists', async () => {
|
|
||||||
const awsPath = await aws.getCLI();
|
|
||||||
console.log(`awsPath: ${awsPath}`);
|
|
||||||
expect(awsPath).not.toEqual('');
|
|
||||||
});
|
|
||||||
});
|
|
||||||
|
|
||||||
describe('execCLI', () => {
|
|
||||||
it('--version not empty', async () => {
|
|
||||||
const cliCmdOutput = await aws.execCLI(['--version']);
|
|
||||||
console.log(`cliCmdOutput: ${cliCmdOutput}`);
|
|
||||||
expect(cliCmdOutput).not.toEqual('');
|
|
||||||
}, 100000);
|
|
||||||
});
|
|
||||||
|
|
||||||
describe('getCLIVersion', () => {
|
|
||||||
it('valid', async () => {
|
|
||||||
const cliVersion = await aws.getCLIVersion();
|
|
||||||
console.log(`cliVersion: ${cliVersion}`);
|
|
||||||
expect(semver.valid(cliVersion)).not.toBeNull();
|
|
||||||
}, 100000);
|
|
||||||
});
|
|
||||||
|
|
||||||
describe('parseCLIVersion', () => {
|
|
||||||
test.each([
|
test.each([
|
||||||
['v1', 'aws-cli/1.18.120 Python/2.7.17 Linux/5.3.0-1034-azure botocore/1.17.43', '1.18.120'],
|
['registry.gitlab.com', false],
|
||||||
['v2', 'aws-cli/2.0.41 Python/3.7.3 Linux/4.19.104-microsoft-standard exe/x86_64.ubuntu.18', '2.0.41']
|
['gcr.io', false],
|
||||||
])('given aws %p', async (version, stdout, expected) => {
|
['012345678901.dkr.ecr.eu-west-3.amazonaws.com', false],
|
||||||
expect(await aws.parseCLIVersion(stdout)).toEqual(expected);
|
['876820548815.dkr.ecr.cn-north-1.amazonaws.com.cn', false],
|
||||||
|
['390948362332.dkr.ecr.cn-northwest-1.amazonaws.com.cn', false],
|
||||||
|
['public.ecr.aws', true]
|
||||||
|
])('given registry %p', async (registry, expected) => {
|
||||||
|
expect(aws.isPubECR(registry)).toEqual(expected);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('getRegion', () => {
|
describe('getRegion', () => {
|
||||||
test.each([['012345678901.dkr.ecr.eu-west-3.amazonaws.com', 'eu-west-3']])(
|
test.each([
|
||||||
'given registry %p',
|
['012345678901.dkr.ecr.eu-west-3.amazonaws.com', 'eu-west-3'],
|
||||||
async (registry, expected) => {
|
['876820548815.dkr.ecr.cn-north-1.amazonaws.com.cn', 'cn-north-1'],
|
||||||
expect(await aws.getRegion(registry)).toEqual(expected);
|
['390948362332.dkr.ecr.cn-northwest-1.amazonaws.com.cn', 'cn-northwest-1'],
|
||||||
}
|
['public.ecr.aws', 'us-east-1']
|
||||||
);
|
])('given registry %p', async (registry, expected) => {
|
||||||
|
expect(aws.getRegion(registry)).toEqual(expected);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('getAccountIDs', () => {
|
||||||
|
test.each([
|
||||||
|
['012345678901.dkr.ecr.eu-west-3.amazonaws.com', undefined, ['012345678901']],
|
||||||
|
['012345678901.dkr.ecr.eu-west-3.amazonaws.com', '012345678910,023456789012', ['012345678901', '012345678910', '023456789012']],
|
||||||
|
['012345678901.dkr.ecr.eu-west-3.amazonaws.com', '012345678901,012345678910,023456789012', ['012345678901', '012345678910', '023456789012']],
|
||||||
|
['390948362332.dkr.ecr.cn-northwest-1.amazonaws.com.cn', '012345678910,023456789012', ['390948362332', '012345678910', '023456789012']],
|
||||||
|
['public.ecr.aws', undefined, []]
|
||||||
|
])('given registry %p', async (registry, accountIDsEnv, expected) => {
|
||||||
|
if (accountIDsEnv) {
|
||||||
|
process.env.AWS_ACCOUNT_IDS = accountIDsEnv;
|
||||||
|
}
|
||||||
|
expect(aws.getAccountIDs(registry)).toEqual(expected);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
const mockEcrGetAuthToken = jest.fn();
|
||||||
|
const mockEcrPublicGetAuthToken = jest.fn();
|
||||||
|
jest.mock('@aws-sdk/client-ecr', () => {
|
||||||
|
return {
|
||||||
|
ECR: jest.fn(() => ({
|
||||||
|
getAuthorizationToken: mockEcrGetAuthToken
|
||||||
|
}))
|
||||||
|
};
|
||||||
|
});
|
||||||
|
jest.mock('@aws-sdk/client-ecr-public', () => {
|
||||||
|
return {
|
||||||
|
ECRPUBLIC: jest.fn(() => ({
|
||||||
|
getAuthorizationToken: mockEcrPublicGetAuthToken
|
||||||
|
}))
|
||||||
|
};
|
||||||
|
});
|
||||||
|
|
||||||
|
describe('getRegistriesData', () => {
|
||||||
|
beforeEach(() => {
|
||||||
|
jest.clearAllMocks();
|
||||||
|
delete process.env.AWS_ACCOUNT_IDS;
|
||||||
|
});
|
||||||
|
// prettier-ignore
|
||||||
|
test.each([
|
||||||
|
[
|
||||||
|
'012345678901.dkr.ecr.aws-region-1.amazonaws.com',
|
||||||
|
'dkr.ecr.aws-region-1.amazonaws.com', undefined,
|
||||||
|
[
|
||||||
|
{
|
||||||
|
registry: '012345678901.dkr.ecr.aws-region-1.amazonaws.com',
|
||||||
|
username: '012345678901',
|
||||||
|
password: 'world'
|
||||||
|
}
|
||||||
|
]
|
||||||
|
],
|
||||||
|
[
|
||||||
|
'012345678901.dkr.ecr.eu-west-3.amazonaws.com',
|
||||||
|
'dkr.ecr.eu-west-3.amazonaws.com',
|
||||||
|
'012345678910,023456789012',
|
||||||
|
[
|
||||||
|
{
|
||||||
|
registry: '012345678901.dkr.ecr.eu-west-3.amazonaws.com',
|
||||||
|
username: '012345678901',
|
||||||
|
password: 'world'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
registry: '012345678910.dkr.ecr.eu-west-3.amazonaws.com',
|
||||||
|
username: '012345678910',
|
||||||
|
password: 'world'
|
||||||
|
},
|
||||||
|
{
|
||||||
|
registry: '023456789012.dkr.ecr.eu-west-3.amazonaws.com',
|
||||||
|
username: '023456789012',
|
||||||
|
password: 'world'
|
||||||
|
}
|
||||||
|
]
|
||||||
|
],
|
||||||
|
[
|
||||||
|
'public.ecr.aws',
|
||||||
|
undefined,
|
||||||
|
undefined,
|
||||||
|
[
|
||||||
|
{
|
||||||
|
registry: 'public.ecr.aws',
|
||||||
|
username: 'AWS',
|
||||||
|
password: 'world'
|
||||||
|
}
|
||||||
|
]
|
||||||
|
]
|
||||||
|
])('given registry %p', async (registry, fqdn, accountIDsEnv, expected: aws.RegistryData[]) => {
|
||||||
|
if (accountIDsEnv) {
|
||||||
|
process.env.AWS_ACCOUNT_IDS = accountIDsEnv;
|
||||||
|
}
|
||||||
|
const accountIDs = aws.getAccountIDs(registry);
|
||||||
|
const authData: AuthorizationData[] = [];
|
||||||
|
if (accountIDs.length == 0) {
|
||||||
|
mockEcrPublicGetAuthToken.mockImplementation(() => {
|
||||||
|
return Promise.resolve({
|
||||||
|
authorizationData: {
|
||||||
|
authorizationToken: Buffer.from(`AWS:world`).toString('base64'),
|
||||||
|
}
|
||||||
|
});
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
aws.getAccountIDs(registry).forEach(accountID => {
|
||||||
|
authData.push({
|
||||||
|
authorizationToken: Buffer.from(`${accountID}:world`).toString('base64'),
|
||||||
|
proxyEndpoint: `${accountID}.${fqdn}`
|
||||||
|
});
|
||||||
|
});
|
||||||
|
mockEcrGetAuthToken.mockImplementation(() => {
|
||||||
|
return Promise.resolve({
|
||||||
|
authorizationData: authData
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
const regData = await aws.getRegistriesData(registry);
|
||||||
|
expect(regData).toEqual(expected);
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|||||||
10
__tests__/context.test.ts
Normal file
10
__tests__/context.test.ts
Normal file
@@ -0,0 +1,10 @@
|
|||||||
|
import {getInputs} from '../src/context';
|
||||||
|
|
||||||
|
test('with password and username getInputs does not throw error', async () => {
|
||||||
|
process.env['INPUT_USERNAME'] = 'dbowie';
|
||||||
|
process.env['INPUT_PASSWORD'] = 'groundcontrol';
|
||||||
|
process.env['INPUT_LOGOUT'] = 'true';
|
||||||
|
expect(() => {
|
||||||
|
getInputs();
|
||||||
|
}).not.toThrowError();
|
||||||
|
});
|
||||||
49
__tests__/docker.test.ts
Normal file
49
__tests__/docker.test.ts
Normal file
@@ -0,0 +1,49 @@
|
|||||||
|
import {loginStandard, logout} from '../src/docker';
|
||||||
|
|
||||||
|
import * as path from 'path';
|
||||||
|
|
||||||
|
import * as exec from '@actions/exec';
|
||||||
|
|
||||||
|
process.env['RUNNER_TEMP'] = path.join(__dirname, 'runner');
|
||||||
|
|
||||||
|
test('loginStandard calls exec', async () => {
|
||||||
|
const execSpy: jest.SpyInstance = jest.spyOn(exec, 'getExecOutput');
|
||||||
|
execSpy.mockImplementation(() =>
|
||||||
|
Promise.resolve({
|
||||||
|
exitCode: expect.any(Number),
|
||||||
|
stdout: expect.any(Function),
|
||||||
|
stderr: expect.any(Function)
|
||||||
|
})
|
||||||
|
);
|
||||||
|
|
||||||
|
const username: string = 'dbowie';
|
||||||
|
const password: string = 'groundcontrol';
|
||||||
|
const registry: string = 'https://ghcr.io';
|
||||||
|
|
||||||
|
await loginStandard(registry, username, password);
|
||||||
|
|
||||||
|
expect(execSpy).toHaveBeenCalledWith(`docker`, ['login', '--password-stdin', '--username', username, registry], {
|
||||||
|
input: Buffer.from(password),
|
||||||
|
silent: true,
|
||||||
|
ignoreReturnCode: true
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
test('logout calls exec', async () => {
|
||||||
|
const execSpy: jest.SpyInstance = jest.spyOn(exec, 'getExecOutput');
|
||||||
|
execSpy.mockImplementation(() =>
|
||||||
|
Promise.resolve({
|
||||||
|
exitCode: expect.any(Number),
|
||||||
|
stdout: expect.any(Function),
|
||||||
|
stderr: expect.any(Function)
|
||||||
|
})
|
||||||
|
);
|
||||||
|
|
||||||
|
const registry: string = 'https://ghcr.io';
|
||||||
|
|
||||||
|
await logout(registry);
|
||||||
|
|
||||||
|
expect(execSpy).toHaveBeenCalledWith(`docker`, ['logout', registry], {
|
||||||
|
ignoreReturnCode: true
|
||||||
|
});
|
||||||
|
});
|
||||||
79
__tests__/main.test.ts
Normal file
79
__tests__/main.test.ts
Normal file
@@ -0,0 +1,79 @@
|
|||||||
|
import osm = require('os');
|
||||||
|
|
||||||
|
import {run} from '../src/main';
|
||||||
|
import * as docker from '../src/docker';
|
||||||
|
import * as stateHelper from '../src/state-helper';
|
||||||
|
|
||||||
|
import * as core from '@actions/core';
|
||||||
|
|
||||||
|
test('errors without username and password', async () => {
|
||||||
|
const platSpy = jest.spyOn(osm, 'platform');
|
||||||
|
platSpy.mockImplementation(() => 'linux');
|
||||||
|
|
||||||
|
process.env['INPUT_LOGOUT'] = 'true'; // default value
|
||||||
|
|
||||||
|
const coreSpy: jest.SpyInstance = jest.spyOn(core, 'setFailed');
|
||||||
|
|
||||||
|
await run();
|
||||||
|
|
||||||
|
expect(coreSpy).toHaveBeenCalledWith('Username and password required');
|
||||||
|
});
|
||||||
|
|
||||||
|
test('successful with username and password', async () => {
|
||||||
|
const platSpy = jest.spyOn(osm, 'platform');
|
||||||
|
platSpy.mockImplementation(() => 'linux');
|
||||||
|
|
||||||
|
const setRegistrySpy: jest.SpyInstance = jest.spyOn(stateHelper, 'setRegistry');
|
||||||
|
const setLogoutSpy: jest.SpyInstance = jest.spyOn(stateHelper, 'setLogout');
|
||||||
|
const dockerSpy: jest.SpyInstance = jest.spyOn(docker, 'login');
|
||||||
|
dockerSpy.mockImplementation(() => {});
|
||||||
|
|
||||||
|
const username: string = 'dbowie';
|
||||||
|
process.env[`INPUT_USERNAME`] = username;
|
||||||
|
|
||||||
|
const password: string = 'groundcontrol';
|
||||||
|
process.env[`INPUT_PASSWORD`] = password;
|
||||||
|
|
||||||
|
const ecr: string = 'auto';
|
||||||
|
process.env['INPUT_ECR'] = ecr;
|
||||||
|
|
||||||
|
const logout: boolean = false;
|
||||||
|
process.env['INPUT_LOGOUT'] = String(logout);
|
||||||
|
|
||||||
|
await run();
|
||||||
|
|
||||||
|
expect(setRegistrySpy).toHaveBeenCalledWith('');
|
||||||
|
expect(setLogoutSpy).toHaveBeenCalledWith(logout);
|
||||||
|
expect(dockerSpy).toHaveBeenCalledWith('', username, password, ecr);
|
||||||
|
});
|
||||||
|
|
||||||
|
test('calls docker login', async () => {
|
||||||
|
const platSpy = jest.spyOn(osm, 'platform');
|
||||||
|
platSpy.mockImplementation(() => 'linux');
|
||||||
|
|
||||||
|
const setRegistrySpy: jest.SpyInstance = jest.spyOn(stateHelper, 'setRegistry');
|
||||||
|
const setLogoutSpy: jest.SpyInstance = jest.spyOn(stateHelper, 'setLogout');
|
||||||
|
const dockerSpy: jest.SpyInstance = jest.spyOn(docker, 'login');
|
||||||
|
dockerSpy.mockImplementation(() => {});
|
||||||
|
|
||||||
|
const username: string = 'dbowie';
|
||||||
|
process.env[`INPUT_USERNAME`] = username;
|
||||||
|
|
||||||
|
const password: string = 'groundcontrol';
|
||||||
|
process.env[`INPUT_PASSWORD`] = password;
|
||||||
|
|
||||||
|
const registry: string = 'ghcr.io';
|
||||||
|
process.env[`INPUT_REGISTRY`] = registry;
|
||||||
|
|
||||||
|
const ecr: string = 'auto';
|
||||||
|
process.env['INPUT_ECR'] = ecr;
|
||||||
|
|
||||||
|
const logout: boolean = true;
|
||||||
|
process.env['INPUT_LOGOUT'] = String(logout);
|
||||||
|
|
||||||
|
await run();
|
||||||
|
|
||||||
|
expect(setRegistrySpy).toHaveBeenCalledWith(registry);
|
||||||
|
expect(setLogoutSpy).toHaveBeenCalledWith(logout);
|
||||||
|
expect(dockerSpy).toHaveBeenCalledWith(registry, username, password, ecr);
|
||||||
|
});
|
||||||
@@ -15,7 +15,11 @@ inputs:
|
|||||||
required: false
|
required: false
|
||||||
password:
|
password:
|
||||||
description: 'Password or personal access token used to log against the Docker registry'
|
description: 'Password or personal access token used to log against the Docker registry'
|
||||||
required: true
|
required: false
|
||||||
|
ecr:
|
||||||
|
description: 'Specifies whether the given registry is ECR (auto, true or false)'
|
||||||
|
default: 'auto'
|
||||||
|
required: false
|
||||||
logout:
|
logout:
|
||||||
description: 'Log out from the Docker registry at the end of a job'
|
description: 'Log out from the Docker registry at the end of a job'
|
||||||
default: 'true'
|
default: 'true'
|
||||||
|
|||||||
3
codecov.yml
Normal file
3
codecov.yml
Normal file
@@ -0,0 +1,3 @@
|
|||||||
|
comment: false
|
||||||
|
github_checks:
|
||||||
|
annotations: false
|
||||||
984
dist/bridge.js
generated
vendored
Normal file
984
dist/bridge.js
generated
vendored
Normal file
@@ -0,0 +1,984 @@
|
|||||||
|
/******/ (() => { // webpackBootstrap
|
||||||
|
/******/ "use strict";
|
||||||
|
/******/ var __webpack_modules__ = ({
|
||||||
|
|
||||||
|
/***/ 989:
|
||||||
|
/***/ ((__unused_webpack_module, exports) => {
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* __ ___ ____ _ _ ___ _ _ ____
|
||||||
|
* \ \ / / \ | _ \| \ | |_ _| \ | |/ ___|
|
||||||
|
* \ \ /\ / / _ \ | |_) | \| || || \| | | _
|
||||||
|
* \ V V / ___ \| _ <| |\ || || |\ | |_| |
|
||||||
|
* \_/\_/_/ \_\_| \_\_| \_|___|_| \_|\____|
|
||||||
|
*
|
||||||
|
* This file is critical for vm2. It implements the bridge between the host and the sandbox.
|
||||||
|
* If you do not know exactly what you are doing, you should NOT edit this file.
|
||||||
|
*
|
||||||
|
* The file is loaded in the host and sandbox to handle objects in both directions.
|
||||||
|
* This is done to ensure that RangeErrors are from the correct context.
|
||||||
|
* The boundary between the sandbox and host might throw RangeErrors from both contexts.
|
||||||
|
* Therefore, thisFromOther and friends can handle objects from both domains.
|
||||||
|
*
|
||||||
|
* Method parameters have comments to tell from which context they came.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
const globalsList = [
|
||||||
|
'Number',
|
||||||
|
'String',
|
||||||
|
'Boolean',
|
||||||
|
'Date',
|
||||||
|
'RegExp',
|
||||||
|
'Map',
|
||||||
|
'WeakMap',
|
||||||
|
'Set',
|
||||||
|
'WeakSet',
|
||||||
|
'Promise',
|
||||||
|
'Function'
|
||||||
|
];
|
||||||
|
|
||||||
|
const errorsList = [
|
||||||
|
'RangeError',
|
||||||
|
'ReferenceError',
|
||||||
|
'SyntaxError',
|
||||||
|
'TypeError',
|
||||||
|
'EvalError',
|
||||||
|
'URIError',
|
||||||
|
'Error'
|
||||||
|
];
|
||||||
|
|
||||||
|
const OPNA = 'Operation not allowed on contextified object.';
|
||||||
|
|
||||||
|
const thisGlobalPrototypes = {
|
||||||
|
__proto__: null,
|
||||||
|
Object: Object.prototype,
|
||||||
|
Array: Array.prototype
|
||||||
|
};
|
||||||
|
|
||||||
|
for (let i = 0; i < globalsList.length; i++) {
|
||||||
|
const key = globalsList[i];
|
||||||
|
const g = global[key];
|
||||||
|
if (g) thisGlobalPrototypes[key] = g.prototype;
|
||||||
|
}
|
||||||
|
|
||||||
|
for (let i = 0; i < errorsList.length; i++) {
|
||||||
|
const key = errorsList[i];
|
||||||
|
const g = global[key];
|
||||||
|
if (g) thisGlobalPrototypes[key] = g.prototype;
|
||||||
|
}
|
||||||
|
|
||||||
|
const {
|
||||||
|
getPrototypeOf: thisReflectGetPrototypeOf,
|
||||||
|
setPrototypeOf: thisReflectSetPrototypeOf,
|
||||||
|
defineProperty: thisReflectDefineProperty,
|
||||||
|
deleteProperty: thisReflectDeleteProperty,
|
||||||
|
getOwnPropertyDescriptor: thisReflectGetOwnPropertyDescriptor,
|
||||||
|
isExtensible: thisReflectIsExtensible,
|
||||||
|
preventExtensions: thisReflectPreventExtensions,
|
||||||
|
apply: thisReflectApply,
|
||||||
|
construct: thisReflectConstruct,
|
||||||
|
set: thisReflectSet,
|
||||||
|
get: thisReflectGet,
|
||||||
|
has: thisReflectHas,
|
||||||
|
ownKeys: thisReflectOwnKeys,
|
||||||
|
enumerate: thisReflectEnumerate,
|
||||||
|
} = Reflect;
|
||||||
|
|
||||||
|
const thisObject = Object;
|
||||||
|
const {
|
||||||
|
freeze: thisObjectFreeze,
|
||||||
|
prototype: thisObjectPrototype
|
||||||
|
} = thisObject;
|
||||||
|
const thisObjectHasOwnProperty = thisObjectPrototype.hasOwnProperty;
|
||||||
|
const ThisProxy = Proxy;
|
||||||
|
const ThisWeakMap = WeakMap;
|
||||||
|
const {
|
||||||
|
get: thisWeakMapGet,
|
||||||
|
set: thisWeakMapSet
|
||||||
|
} = ThisWeakMap.prototype;
|
||||||
|
const ThisMap = Map;
|
||||||
|
const thisMapGet = ThisMap.prototype.get;
|
||||||
|
const thisMapSet = ThisMap.prototype.set;
|
||||||
|
const thisFunction = Function;
|
||||||
|
const thisFunctionBind = thisFunction.prototype.bind;
|
||||||
|
const thisArrayIsArray = Array.isArray;
|
||||||
|
const thisErrorCaptureStackTrace = Error.captureStackTrace;
|
||||||
|
|
||||||
|
const thisSymbolToString = Symbol.prototype.toString;
|
||||||
|
const thisSymbolToStringTag = Symbol.toStringTag;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* VMError.
|
||||||
|
*
|
||||||
|
* @public
|
||||||
|
* @extends {Error}
|
||||||
|
*/
|
||||||
|
class VMError extends Error {
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Create VMError instance.
|
||||||
|
*
|
||||||
|
* @public
|
||||||
|
* @param {string} message - Error message.
|
||||||
|
* @param {string} code - Error code.
|
||||||
|
*/
|
||||||
|
constructor(message, code) {
|
||||||
|
super(message);
|
||||||
|
|
||||||
|
this.name = 'VMError';
|
||||||
|
this.code = code;
|
||||||
|
|
||||||
|
thisErrorCaptureStackTrace(this, this.constructor);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
thisGlobalPrototypes['VMError'] = VMError.prototype;
|
||||||
|
|
||||||
|
function thisUnexpected() {
|
||||||
|
return new VMError('Unexpected');
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!thisReflectSetPrototypeOf(exports, null)) throw thisUnexpected();
|
||||||
|
|
||||||
|
function thisSafeGetOwnPropertyDescriptor(obj, key) {
|
||||||
|
const desc = thisReflectGetOwnPropertyDescriptor(obj, key);
|
||||||
|
if (!desc) return desc;
|
||||||
|
if (!thisReflectSetPrototypeOf(desc, null)) throw thisUnexpected();
|
||||||
|
return desc;
|
||||||
|
}
|
||||||
|
|
||||||
|
function thisThrowCallerCalleeArgumentsAccess(key) {
|
||||||
|
'use strict';
|
||||||
|
thisThrowCallerCalleeArgumentsAccess[key];
|
||||||
|
return thisUnexpected();
|
||||||
|
}
|
||||||
|
|
||||||
|
function thisIdMapping(factory, other) {
|
||||||
|
return other;
|
||||||
|
}
|
||||||
|
|
||||||
|
const thisThrowOnKeyAccessHandler = thisObjectFreeze({
|
||||||
|
__proto__: null,
|
||||||
|
get(target, key, receiver) {
|
||||||
|
if (typeof key === 'symbol') {
|
||||||
|
key = thisReflectApply(thisSymbolToString, key, []);
|
||||||
|
}
|
||||||
|
throw new VMError(`Unexpected access to key '${key}'`);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
const emptyForzenObject = thisObjectFreeze({
|
||||||
|
__proto__: null
|
||||||
|
});
|
||||||
|
|
||||||
|
const thisThrowOnKeyAccess = new ThisProxy(emptyForzenObject, thisThrowOnKeyAccessHandler);
|
||||||
|
|
||||||
|
function SafeBase() {}
|
||||||
|
|
||||||
|
if (!thisReflectDefineProperty(SafeBase, 'prototype', {
|
||||||
|
__proto__: null,
|
||||||
|
value: thisThrowOnKeyAccess
|
||||||
|
})) throw thisUnexpected();
|
||||||
|
|
||||||
|
function SHARED_FUNCTION() {}
|
||||||
|
|
||||||
|
const TEST_PROXY_HANDLER = thisObjectFreeze({
|
||||||
|
__proto__: thisThrowOnKeyAccess,
|
||||||
|
construct() {
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
function thisIsConstructor(obj) {
|
||||||
|
// Note: obj@any(unsafe)
|
||||||
|
const Func = new ThisProxy(obj, TEST_PROXY_HANDLER);
|
||||||
|
try {
|
||||||
|
// eslint-disable-next-line no-new
|
||||||
|
new Func();
|
||||||
|
return true;
|
||||||
|
} catch (e) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function thisCreateTargetObject(obj, proto) {
|
||||||
|
// Note: obj@any(unsafe) proto@any(unsafe) returns@this(unsafe) throws@this(unsafe)
|
||||||
|
let base;
|
||||||
|
if (typeof obj === 'function') {
|
||||||
|
if (thisIsConstructor(obj)) {
|
||||||
|
// Bind the function since bound functions do not have a prototype property.
|
||||||
|
base = thisReflectApply(thisFunctionBind, SHARED_FUNCTION, [null]);
|
||||||
|
} else {
|
||||||
|
base = () => {};
|
||||||
|
}
|
||||||
|
} else if (thisArrayIsArray(obj)) {
|
||||||
|
base = [];
|
||||||
|
} else {
|
||||||
|
return {__proto__: proto};
|
||||||
|
}
|
||||||
|
if (!thisReflectSetPrototypeOf(base, proto)) throw thisUnexpected();
|
||||||
|
return base;
|
||||||
|
}
|
||||||
|
|
||||||
|
function createBridge(otherInit, registerProxy) {
|
||||||
|
|
||||||
|
const mappingOtherToThis = new ThisWeakMap();
|
||||||
|
const protoMappings = new ThisMap();
|
||||||
|
const protoName = new ThisMap();
|
||||||
|
|
||||||
|
function thisAddProtoMapping(proto, other, name) {
|
||||||
|
// Note: proto@this(unsafe) other@other(unsafe) name@this(unsafe) throws@this(unsafe)
|
||||||
|
thisReflectApply(thisMapSet, protoMappings, [proto, thisIdMapping]);
|
||||||
|
thisReflectApply(thisMapSet, protoMappings, [other,
|
||||||
|
(factory, object) => thisProxyOther(factory, object, proto)]);
|
||||||
|
if (name) thisReflectApply(thisMapSet, protoName, [proto, name]);
|
||||||
|
}
|
||||||
|
|
||||||
|
function thisAddProtoMappingFactory(protoFactory, other, name) {
|
||||||
|
// Note: protoFactory@this(unsafe) other@other(unsafe) name@this(unsafe) throws@this(unsafe)
|
||||||
|
let proto;
|
||||||
|
thisReflectApply(thisMapSet, protoMappings, [other,
|
||||||
|
(factory, object) => {
|
||||||
|
if (!proto) {
|
||||||
|
proto = protoFactory();
|
||||||
|
thisReflectApply(thisMapSet, protoMappings, [proto, thisIdMapping]);
|
||||||
|
if (name) thisReflectApply(thisMapSet, protoName, [proto, name]);
|
||||||
|
}
|
||||||
|
return thisProxyOther(factory, object, proto);
|
||||||
|
}]);
|
||||||
|
}
|
||||||
|
|
||||||
|
const result = {
|
||||||
|
__proto__: null,
|
||||||
|
globalPrototypes: thisGlobalPrototypes,
|
||||||
|
safeGetOwnPropertyDescriptor: thisSafeGetOwnPropertyDescriptor,
|
||||||
|
fromArguments: thisFromOtherArguments,
|
||||||
|
from: thisFromOther,
|
||||||
|
fromWithFactory: thisFromOtherWithFactory,
|
||||||
|
ensureThis: thisEnsureThis,
|
||||||
|
mapping: mappingOtherToThis,
|
||||||
|
connect: thisConnect,
|
||||||
|
reflectSet: thisReflectSet,
|
||||||
|
reflectGet: thisReflectGet,
|
||||||
|
reflectDefineProperty: thisReflectDefineProperty,
|
||||||
|
reflectDeleteProperty: thisReflectDeleteProperty,
|
||||||
|
reflectApply: thisReflectApply,
|
||||||
|
reflectConstruct: thisReflectConstruct,
|
||||||
|
reflectHas: thisReflectHas,
|
||||||
|
reflectOwnKeys: thisReflectOwnKeys,
|
||||||
|
reflectEnumerate: thisReflectEnumerate,
|
||||||
|
reflectGetPrototypeOf: thisReflectGetPrototypeOf,
|
||||||
|
reflectIsExtensible: thisReflectIsExtensible,
|
||||||
|
reflectPreventExtensions: thisReflectPreventExtensions,
|
||||||
|
objectHasOwnProperty: thisObjectHasOwnProperty,
|
||||||
|
weakMapSet: thisWeakMapSet,
|
||||||
|
addProtoMapping: thisAddProtoMapping,
|
||||||
|
addProtoMappingFactory: thisAddProtoMappingFactory,
|
||||||
|
defaultFactory,
|
||||||
|
protectedFactory,
|
||||||
|
readonlyFactory,
|
||||||
|
VMError
|
||||||
|
};
|
||||||
|
|
||||||
|
const isHost = typeof otherInit !== 'object';
|
||||||
|
|
||||||
|
if (isHost) {
|
||||||
|
otherInit = otherInit(result, registerProxy);
|
||||||
|
}
|
||||||
|
|
||||||
|
result.other = otherInit;
|
||||||
|
|
||||||
|
const {
|
||||||
|
globalPrototypes: otherGlobalPrototypes,
|
||||||
|
safeGetOwnPropertyDescriptor: otherSafeGetOwnPropertyDescriptor,
|
||||||
|
fromArguments: otherFromThisArguments,
|
||||||
|
from: otherFromThis,
|
||||||
|
mapping: mappingThisToOther,
|
||||||
|
reflectSet: otherReflectSet,
|
||||||
|
reflectGet: otherReflectGet,
|
||||||
|
reflectDefineProperty: otherReflectDefineProperty,
|
||||||
|
reflectDeleteProperty: otherReflectDeleteProperty,
|
||||||
|
reflectApply: otherReflectApply,
|
||||||
|
reflectConstruct: otherReflectConstruct,
|
||||||
|
reflectHas: otherReflectHas,
|
||||||
|
reflectOwnKeys: otherReflectOwnKeys,
|
||||||
|
reflectEnumerate: otherReflectEnumerate,
|
||||||
|
reflectGetPrototypeOf: otherReflectGetPrototypeOf,
|
||||||
|
reflectIsExtensible: otherReflectIsExtensible,
|
||||||
|
reflectPreventExtensions: otherReflectPreventExtensions,
|
||||||
|
objectHasOwnProperty: otherObjectHasOwnProperty,
|
||||||
|
weakMapSet: otherWeakMapSet
|
||||||
|
} = otherInit;
|
||||||
|
|
||||||
|
function thisOtherHasOwnProperty(object, key) {
|
||||||
|
// Note: object@other(safe) key@prim throws@this(unsafe)
|
||||||
|
try {
|
||||||
|
return otherReflectApply(otherObjectHasOwnProperty, object, [key]) === true;
|
||||||
|
} catch (e) { // @other(unsafe)
|
||||||
|
throw thisFromOther(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function thisDefaultGet(handler, object, key, desc) {
|
||||||
|
// Note: object@other(unsafe) key@prim desc@other(safe)
|
||||||
|
let ret; // @other(unsafe)
|
||||||
|
if (desc.get || desc.set) {
|
||||||
|
const getter = desc.get;
|
||||||
|
if (!getter) return undefined;
|
||||||
|
try {
|
||||||
|
ret = otherReflectApply(getter, object, [key]);
|
||||||
|
} catch (e) {
|
||||||
|
throw thisFromOther(e);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
ret = desc.value;
|
||||||
|
}
|
||||||
|
return handler.fromOtherWithContext(ret);
|
||||||
|
}
|
||||||
|
|
||||||
|
function otherFromThisIfAvailable(to, from, key) {
|
||||||
|
// Note: to@other(safe) from@this(safe) key@prim throws@this(unsafe)
|
||||||
|
if (!thisReflectApply(thisObjectHasOwnProperty, from, [key])) return false;
|
||||||
|
try {
|
||||||
|
to[key] = otherFromThis(from[key]);
|
||||||
|
} catch (e) { // @other(unsafe)
|
||||||
|
throw thisFromOther(e);
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
class BaseHandler extends SafeBase {
|
||||||
|
|
||||||
|
constructor(object) {
|
||||||
|
// Note: object@other(unsafe) throws@this(unsafe)
|
||||||
|
super();
|
||||||
|
this.object = object;
|
||||||
|
}
|
||||||
|
|
||||||
|
getFactory() {
|
||||||
|
return defaultFactory;
|
||||||
|
}
|
||||||
|
|
||||||
|
fromOtherWithContext(other) {
|
||||||
|
// Note: other@other(unsafe) throws@this(unsafe)
|
||||||
|
return thisFromOtherWithFactory(this.getFactory(), other);
|
||||||
|
}
|
||||||
|
|
||||||
|
doPreventExtensions(target, object, factory) {
|
||||||
|
// Note: target@this(unsafe) object@other(unsafe) throws@this(unsafe)
|
||||||
|
let keys; // @other(safe-array-of-prim)
|
||||||
|
try {
|
||||||
|
keys = otherReflectOwnKeys(object);
|
||||||
|
} catch (e) { // @other(unsafe)
|
||||||
|
throw thisFromOther(e);
|
||||||
|
}
|
||||||
|
for (let i = 0; i < keys.length; i++) {
|
||||||
|
const key = keys[i]; // @prim
|
||||||
|
let desc;
|
||||||
|
try {
|
||||||
|
desc = otherSafeGetOwnPropertyDescriptor(object, key);
|
||||||
|
} catch (e) { // @other(unsafe)
|
||||||
|
throw thisFromOther(e);
|
||||||
|
}
|
||||||
|
if (!desc) continue;
|
||||||
|
if (!desc.configurable) {
|
||||||
|
const current = thisSafeGetOwnPropertyDescriptor(target, key);
|
||||||
|
if (current && !current.configurable) continue;
|
||||||
|
if (desc.get || desc.set) {
|
||||||
|
desc.get = this.fromOtherWithContext(desc.get);
|
||||||
|
desc.set = this.fromOtherWithContext(desc.set);
|
||||||
|
} else if (typeof object === 'function' && (key === 'caller' || key === 'callee' || key === 'arguments')) {
|
||||||
|
desc.value = null;
|
||||||
|
} else {
|
||||||
|
desc.value = this.fromOtherWithContext(desc.value);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (desc.get || desc.set) {
|
||||||
|
desc = {
|
||||||
|
__proto__: null,
|
||||||
|
configurable: true,
|
||||||
|
enumerable: desc.enumerable,
|
||||||
|
writable: true,
|
||||||
|
value: null
|
||||||
|
};
|
||||||
|
} else {
|
||||||
|
desc.value = null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (!thisReflectDefineProperty(target, key, desc)) throw thisUnexpected();
|
||||||
|
}
|
||||||
|
if (!thisReflectPreventExtensions(target)) throw thisUnexpected();
|
||||||
|
}
|
||||||
|
|
||||||
|
get(target, key, receiver) {
|
||||||
|
// Note: target@this(unsafe) key@prim receiver@this(unsafe) throws@this(unsafe)
|
||||||
|
const object = this.object; // @other(unsafe)
|
||||||
|
switch (key) {
|
||||||
|
case 'constructor': {
|
||||||
|
const desc = otherSafeGetOwnPropertyDescriptor(object, key);
|
||||||
|
if (desc) return thisDefaultGet(this, object, key, desc);
|
||||||
|
const proto = thisReflectGetPrototypeOf(target);
|
||||||
|
return proto === null ? undefined : proto.constructor;
|
||||||
|
}
|
||||||
|
case '__proto__': {
|
||||||
|
const desc = otherSafeGetOwnPropertyDescriptor(object, key);
|
||||||
|
if (desc) return thisDefaultGet(this, object, key, desc);
|
||||||
|
return thisReflectGetPrototypeOf(target);
|
||||||
|
}
|
||||||
|
case thisSymbolToStringTag:
|
||||||
|
if (!thisOtherHasOwnProperty(object, thisSymbolToStringTag)) {
|
||||||
|
const proto = thisReflectGetPrototypeOf(target);
|
||||||
|
const name = thisReflectApply(thisMapGet, protoName, [proto]);
|
||||||
|
if (name) return name;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case 'arguments':
|
||||||
|
case 'caller':
|
||||||
|
case 'callee':
|
||||||
|
if (thisOtherHasOwnProperty(object, key)) throw thisThrowCallerCalleeArgumentsAccess(key);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
let ret; // @other(unsafe)
|
||||||
|
try {
|
||||||
|
ret = otherReflectGet(object, key);
|
||||||
|
} catch (e) { // @other(unsafe)
|
||||||
|
throw thisFromOther(e);
|
||||||
|
}
|
||||||
|
return this.fromOtherWithContext(ret);
|
||||||
|
}
|
||||||
|
|
||||||
|
set(target, key, value, receiver) {
|
||||||
|
// Note: target@this(unsafe) key@prim value@this(unsafe) receiver@this(unsafe) throws@this(unsafe)
|
||||||
|
const object = this.object; // @other(unsafe)
|
||||||
|
if (key === '__proto__' && !thisOtherHasOwnProperty(object, key)) {
|
||||||
|
return this.setPrototypeOf(target, value);
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
value = otherFromThis(value);
|
||||||
|
return otherReflectSet(object, key, value) === true;
|
||||||
|
} catch (e) { // @other(unsafe)
|
||||||
|
throw thisFromOther(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
getPrototypeOf(target) {
|
||||||
|
// Note: target@this(unsafe)
|
||||||
|
return thisReflectGetPrototypeOf(target);
|
||||||
|
}
|
||||||
|
|
||||||
|
setPrototypeOf(target, value) {
|
||||||
|
// Note: target@this(unsafe) throws@this(unsafe)
|
||||||
|
throw new VMError(OPNA);
|
||||||
|
}
|
||||||
|
|
||||||
|
apply(target, context, args) {
|
||||||
|
// Note: target@this(unsafe) context@this(unsafe) args@this(safe-array) throws@this(unsafe)
|
||||||
|
const object = this.object; // @other(unsafe)
|
||||||
|
let ret; // @other(unsafe)
|
||||||
|
try {
|
||||||
|
context = otherFromThis(context);
|
||||||
|
args = otherFromThisArguments(args);
|
||||||
|
ret = otherReflectApply(object, context, args);
|
||||||
|
} catch (e) { // @other(unsafe)
|
||||||
|
throw thisFromOther(e);
|
||||||
|
}
|
||||||
|
return thisFromOther(ret);
|
||||||
|
}
|
||||||
|
|
||||||
|
construct(target, args, newTarget) {
|
||||||
|
// Note: target@this(unsafe) args@this(safe-array) newTarget@this(unsafe) throws@this(unsafe)
|
||||||
|
const object = this.object; // @other(unsafe)
|
||||||
|
let ret; // @other(unsafe)
|
||||||
|
try {
|
||||||
|
args = otherFromThisArguments(args);
|
||||||
|
ret = otherReflectConstruct(object, args);
|
||||||
|
} catch (e) { // @other(unsafe)
|
||||||
|
throw thisFromOther(e);
|
||||||
|
}
|
||||||
|
return thisFromOtherWithFactory(this.getFactory(), ret, thisFromOther(object));
|
||||||
|
}
|
||||||
|
|
||||||
|
getOwnPropertyDescriptorDesc(target, prop, desc) {
|
||||||
|
// Note: target@this(unsafe) prop@prim desc@other{safe} throws@this(unsafe)
|
||||||
|
const object = this.object; // @other(unsafe)
|
||||||
|
if (desc && typeof object === 'function' && (prop === 'arguments' || prop === 'caller' || prop === 'callee')) desc.value = null;
|
||||||
|
return desc;
|
||||||
|
}
|
||||||
|
|
||||||
|
getOwnPropertyDescriptor(target, prop) {
|
||||||
|
// Note: target@this(unsafe) prop@prim throws@this(unsafe)
|
||||||
|
const object = this.object; // @other(unsafe)
|
||||||
|
let desc; // @other(safe)
|
||||||
|
try {
|
||||||
|
desc = otherSafeGetOwnPropertyDescriptor(object, prop);
|
||||||
|
} catch (e) { // @other(unsafe)
|
||||||
|
throw thisFromOther(e);
|
||||||
|
}
|
||||||
|
|
||||||
|
desc = this.getOwnPropertyDescriptorDesc(target, prop, desc);
|
||||||
|
|
||||||
|
if (!desc) return undefined;
|
||||||
|
|
||||||
|
let thisDesc;
|
||||||
|
if (desc.get || desc.set) {
|
||||||
|
thisDesc = {
|
||||||
|
__proto__: null,
|
||||||
|
get: this.fromOtherWithContext(desc.get),
|
||||||
|
set: this.fromOtherWithContext(desc.set),
|
||||||
|
enumerable: desc.enumerable === true,
|
||||||
|
configurable: desc.configurable === true
|
||||||
|
};
|
||||||
|
} else {
|
||||||
|
thisDesc = {
|
||||||
|
__proto__: null,
|
||||||
|
value: this.fromOtherWithContext(desc.value),
|
||||||
|
writable: desc.writable === true,
|
||||||
|
enumerable: desc.enumerable === true,
|
||||||
|
configurable: desc.configurable === true
|
||||||
|
};
|
||||||
|
}
|
||||||
|
if (!thisDesc.configurable) {
|
||||||
|
const oldDesc = thisSafeGetOwnPropertyDescriptor(target, prop);
|
||||||
|
if (!oldDesc || oldDesc.configurable || oldDesc.writable !== thisDesc.writable) {
|
||||||
|
if (!thisReflectDefineProperty(target, prop, thisDesc)) throw thisUnexpected();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return thisDesc;
|
||||||
|
}
|
||||||
|
|
||||||
|
definePropertyDesc(target, prop, desc) {
|
||||||
|
// Note: target@this(unsafe) prop@prim desc@this(safe) throws@this(unsafe)
|
||||||
|
return desc;
|
||||||
|
}
|
||||||
|
|
||||||
|
defineProperty(target, prop, desc) {
|
||||||
|
// Note: target@this(unsafe) prop@prim desc@this(unsafe) throws@this(unsafe)
|
||||||
|
const object = this.object; // @other(unsafe)
|
||||||
|
if (!thisReflectSetPrototypeOf(desc, null)) throw thisUnexpected();
|
||||||
|
|
||||||
|
desc = this.definePropertyDesc(target, prop, desc);
|
||||||
|
|
||||||
|
if (!desc) return false;
|
||||||
|
|
||||||
|
let otherDesc = {__proto__: null};
|
||||||
|
let hasFunc = true;
|
||||||
|
let hasValue = true;
|
||||||
|
let hasBasic = true;
|
||||||
|
hasFunc &= otherFromThisIfAvailable(otherDesc, desc, 'get');
|
||||||
|
hasFunc &= otherFromThisIfAvailable(otherDesc, desc, 'set');
|
||||||
|
hasValue &= otherFromThisIfAvailable(otherDesc, desc, 'value');
|
||||||
|
hasValue &= otherFromThisIfAvailable(otherDesc, desc, 'writable');
|
||||||
|
hasBasic &= otherFromThisIfAvailable(otherDesc, desc, 'enumerable');
|
||||||
|
hasBasic &= otherFromThisIfAvailable(otherDesc, desc, 'configurable');
|
||||||
|
|
||||||
|
try {
|
||||||
|
if (!otherReflectDefineProperty(object, prop, otherDesc)) return false;
|
||||||
|
if (otherDesc.configurable !== true && (!hasBasic || !(hasFunc || hasValue))) {
|
||||||
|
otherDesc = otherSafeGetOwnPropertyDescriptor(object, prop);
|
||||||
|
}
|
||||||
|
} catch (e) { // @other(unsafe)
|
||||||
|
throw thisFromOther(e);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!otherDesc.configurable) {
|
||||||
|
let thisDesc;
|
||||||
|
if (otherDesc.get || otherDesc.set) {
|
||||||
|
thisDesc = {
|
||||||
|
__proto__: null,
|
||||||
|
get: this.fromOtherWithContext(otherDesc.get),
|
||||||
|
set: this.fromOtherWithContext(otherDesc.set),
|
||||||
|
enumerable: otherDesc.enumerable,
|
||||||
|
configurable: otherDesc.configurable
|
||||||
|
};
|
||||||
|
} else {
|
||||||
|
thisDesc = {
|
||||||
|
__proto__: null,
|
||||||
|
value: this.fromOtherWithContext(otherDesc.value),
|
||||||
|
writable: otherDesc.writable,
|
||||||
|
enumerable: otherDesc.enumerable,
|
||||||
|
configurable: otherDesc.configurable
|
||||||
|
};
|
||||||
|
}
|
||||||
|
if (!thisReflectDefineProperty(target, prop, thisDesc)) throw thisUnexpected();
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
deleteProperty(target, prop) {
|
||||||
|
// Note: target@this(unsafe) prop@prim throws@this(unsafe)
|
||||||
|
const object = this.object; // @other(unsafe)
|
||||||
|
try {
|
||||||
|
return otherReflectDeleteProperty(object, prop) === true;
|
||||||
|
} catch (e) { // @other(unsafe)
|
||||||
|
throw thisFromOther(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
has(target, key) {
|
||||||
|
// Note: target@this(unsafe) key@prim throws@this(unsafe)
|
||||||
|
const object = this.object; // @other(unsafe)
|
||||||
|
try {
|
||||||
|
return otherReflectHas(object, key) === true;
|
||||||
|
} catch (e) { // @other(unsafe)
|
||||||
|
throw thisFromOther(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
isExtensible(target) {
|
||||||
|
// Note: target@this(unsafe) throws@this(unsafe)
|
||||||
|
const object = this.object; // @other(unsafe)
|
||||||
|
try {
|
||||||
|
if (otherReflectIsExtensible(object)) return true;
|
||||||
|
} catch (e) { // @other(unsafe)
|
||||||
|
throw thisFromOther(e);
|
||||||
|
}
|
||||||
|
if (thisReflectIsExtensible(target)) {
|
||||||
|
this.doPreventExtensions(target, object, this);
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
ownKeys(target) {
|
||||||
|
// Note: target@this(unsafe) throws@this(unsafe)
|
||||||
|
const object = this.object; // @other(unsafe)
|
||||||
|
let res; // @other(unsafe)
|
||||||
|
try {
|
||||||
|
res = otherReflectOwnKeys(object);
|
||||||
|
} catch (e) { // @other(unsafe)
|
||||||
|
throw thisFromOther(e);
|
||||||
|
}
|
||||||
|
return thisFromOther(res);
|
||||||
|
}
|
||||||
|
|
||||||
|
preventExtensions(target) {
|
||||||
|
// Note: target@this(unsafe) throws@this(unsafe)
|
||||||
|
const object = this.object; // @other(unsafe)
|
||||||
|
try {
|
||||||
|
if (!otherReflectPreventExtensions(object)) return false;
|
||||||
|
} catch (e) { // @other(unsafe)
|
||||||
|
throw thisFromOther(e);
|
||||||
|
}
|
||||||
|
if (thisReflectIsExtensible(target)) {
|
||||||
|
this.doPreventExtensions(target, object, this);
|
||||||
|
}
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
enumerate(target) {
|
||||||
|
// Note: target@this(unsafe) throws@this(unsafe)
|
||||||
|
const object = this.object; // @other(unsafe)
|
||||||
|
let res; // @other(unsafe)
|
||||||
|
try {
|
||||||
|
res = otherReflectEnumerate(object);
|
||||||
|
} catch (e) { // @other(unsafe)
|
||||||
|
throw thisFromOther(e);
|
||||||
|
}
|
||||||
|
return this.fromOtherWithContext(res);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function defaultFactory(object) {
|
||||||
|
// Note: other@other(unsafe) returns@this(unsafe) throws@this(unsafe)
|
||||||
|
return new BaseHandler(object);
|
||||||
|
}
|
||||||
|
|
||||||
|
class ProtectedHandler extends BaseHandler {
|
||||||
|
|
||||||
|
getFactory() {
|
||||||
|
return protectedFactory;
|
||||||
|
}
|
||||||
|
|
||||||
|
set(target, key, value, receiver) {
|
||||||
|
// Note: target@this(unsafe) key@prim value@this(unsafe) receiver@this(unsafe) throws@this(unsafe)
|
||||||
|
if (typeof value === 'function') {
|
||||||
|
return thisReflectDefineProperty(receiver, key, {
|
||||||
|
__proto__: null,
|
||||||
|
value: value,
|
||||||
|
writable: true,
|
||||||
|
enumerable: true,
|
||||||
|
configurable: true
|
||||||
|
}) === true;
|
||||||
|
}
|
||||||
|
return super.set(target, key, value, receiver);
|
||||||
|
}
|
||||||
|
|
||||||
|
definePropertyDesc(target, prop, desc) {
|
||||||
|
// Note: target@this(unsafe) prop@prim desc@this(safe) throws@this(unsafe)
|
||||||
|
if (desc && (desc.set || desc.get || typeof desc.value === 'function')) return undefined;
|
||||||
|
return desc;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function protectedFactory(object) {
|
||||||
|
// Note: other@other(unsafe) returns@this(unsafe) throws@this(unsafe)
|
||||||
|
return new ProtectedHandler(object);
|
||||||
|
}
|
||||||
|
|
||||||
|
class ReadOnlyHandler extends BaseHandler {
|
||||||
|
|
||||||
|
getFactory() {
|
||||||
|
return readonlyFactory;
|
||||||
|
}
|
||||||
|
|
||||||
|
set(target, key, value, receiver) {
|
||||||
|
// Note: target@this(unsafe) key@prim value@this(unsafe) receiver@this(unsafe) throws@this(unsafe)
|
||||||
|
return thisReflectDefineProperty(receiver, key, {
|
||||||
|
__proto__: null,
|
||||||
|
value: value,
|
||||||
|
writable: true,
|
||||||
|
enumerable: true,
|
||||||
|
configurable: true
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
setPrototypeOf(target, value) {
|
||||||
|
// Note: target@this(unsafe) throws@this(unsafe)
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
defineProperty(target, prop, desc) {
|
||||||
|
// Note: target@this(unsafe) prop@prim desc@this(unsafe) throws@this(unsafe)
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
deleteProperty(target, prop) {
|
||||||
|
// Note: target@this(unsafe) prop@prim throws@this(unsafe)
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
isExtensible(target) {
|
||||||
|
// Note: target@this(unsafe) throws@this(unsafe)
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
preventExtensions(target) {
|
||||||
|
// Note: target@this(unsafe) throws@this(unsafe)
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function readonlyFactory(object) {
|
||||||
|
// Note: other@other(unsafe) returns@this(unsafe) throws@this(unsafe)
|
||||||
|
return new ReadOnlyHandler(object);
|
||||||
|
}
|
||||||
|
|
||||||
|
class ReadOnlyMockHandler extends ReadOnlyHandler {
|
||||||
|
|
||||||
|
constructor(object, mock) {
|
||||||
|
// Note: object@other(unsafe) mock:this(unsafe) throws@this(unsafe)
|
||||||
|
super(object);
|
||||||
|
this.mock = mock;
|
||||||
|
}
|
||||||
|
|
||||||
|
get(target, key, receiver) {
|
||||||
|
// Note: target@this(unsafe) key@prim receiver@this(unsafe) throws@this(unsafe)
|
||||||
|
const object = this.object; // @other(unsafe)
|
||||||
|
const mock = this.mock;
|
||||||
|
if (thisReflectApply(thisObjectHasOwnProperty, mock, key) && !thisOtherHasOwnProperty(object, key)) {
|
||||||
|
return mock[key];
|
||||||
|
}
|
||||||
|
return super.get(target, key, receiver);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function thisFromOther(other) {
|
||||||
|
// Note: other@other(unsafe) returns@this(unsafe) throws@this(unsafe)
|
||||||
|
return thisFromOtherWithFactory(defaultFactory, other);
|
||||||
|
}
|
||||||
|
|
||||||
|
function thisProxyOther(factory, other, proto) {
|
||||||
|
const target = thisCreateTargetObject(other, proto);
|
||||||
|
const handler = factory(other);
|
||||||
|
const proxy = new ThisProxy(target, handler);
|
||||||
|
try {
|
||||||
|
otherReflectApply(otherWeakMapSet, mappingThisToOther, [proxy, other]);
|
||||||
|
registerProxy(proxy, handler);
|
||||||
|
} catch (e) {
|
||||||
|
throw new VMError('Unexpected error');
|
||||||
|
}
|
||||||
|
if (!isHost) {
|
||||||
|
thisReflectApply(thisWeakMapSet, mappingOtherToThis, [other, proxy]);
|
||||||
|
return proxy;
|
||||||
|
}
|
||||||
|
const proxy2 = new ThisProxy(proxy, emptyForzenObject);
|
||||||
|
try {
|
||||||
|
otherReflectApply(otherWeakMapSet, mappingThisToOther, [proxy2, other]);
|
||||||
|
registerProxy(proxy2, handler);
|
||||||
|
} catch (e) {
|
||||||
|
throw new VMError('Unexpected error');
|
||||||
|
}
|
||||||
|
thisReflectApply(thisWeakMapSet, mappingOtherToThis, [other, proxy2]);
|
||||||
|
return proxy2;
|
||||||
|
}
|
||||||
|
|
||||||
|
function thisEnsureThis(other) {
|
||||||
|
const type = typeof other;
|
||||||
|
switch (type) {
|
||||||
|
case 'object':
|
||||||
|
case 'function':
|
||||||
|
if (other === null) {
|
||||||
|
return null;
|
||||||
|
} else {
|
||||||
|
let proto = thisReflectGetPrototypeOf(other);
|
||||||
|
if (!proto) {
|
||||||
|
return other;
|
||||||
|
}
|
||||||
|
while (proto) {
|
||||||
|
const mapping = thisReflectApply(thisMapGet, protoMappings, [proto]);
|
||||||
|
if (mapping) {
|
||||||
|
const mapped = thisReflectApply(thisWeakMapGet, mappingOtherToThis, [other]);
|
||||||
|
if (mapped) return mapped;
|
||||||
|
return mapping(defaultFactory, other);
|
||||||
|
}
|
||||||
|
proto = thisReflectGetPrototypeOf(proto);
|
||||||
|
}
|
||||||
|
return other;
|
||||||
|
}
|
||||||
|
|
||||||
|
case 'undefined':
|
||||||
|
case 'string':
|
||||||
|
case 'number':
|
||||||
|
case 'boolean':
|
||||||
|
case 'symbol':
|
||||||
|
case 'bigint':
|
||||||
|
return other;
|
||||||
|
|
||||||
|
default: // new, unknown types can be dangerous
|
||||||
|
throw new VMError(`Unknown type '${type}'`);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function thisFromOtherWithFactory(factory, other, proto) {
|
||||||
|
for (let loop = 0; loop < 10; loop++) {
|
||||||
|
const type = typeof other;
|
||||||
|
switch (type) {
|
||||||
|
case 'object':
|
||||||
|
case 'function':
|
||||||
|
if (other === null) {
|
||||||
|
return null;
|
||||||
|
} else {
|
||||||
|
const mapped = thisReflectApply(thisWeakMapGet, mappingOtherToThis, [other]);
|
||||||
|
if (mapped) return mapped;
|
||||||
|
if (proto) {
|
||||||
|
return thisProxyOther(factory, other, proto);
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
proto = otherReflectGetPrototypeOf(other);
|
||||||
|
} catch (e) { // @other(unsafe)
|
||||||
|
other = e;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
if (!proto) {
|
||||||
|
return thisProxyOther(factory, other, null);
|
||||||
|
}
|
||||||
|
while (proto) {
|
||||||
|
const mapping = thisReflectApply(thisMapGet, protoMappings, [proto]);
|
||||||
|
if (mapping) return mapping(factory, other);
|
||||||
|
try {
|
||||||
|
proto = otherReflectGetPrototypeOf(proto);
|
||||||
|
} catch (e) { // @other(unsafe)
|
||||||
|
other = e;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return thisProxyOther(factory, other, thisObjectPrototype);
|
||||||
|
}
|
||||||
|
|
||||||
|
case 'undefined':
|
||||||
|
case 'string':
|
||||||
|
case 'number':
|
||||||
|
case 'boolean':
|
||||||
|
case 'symbol':
|
||||||
|
case 'bigint':
|
||||||
|
return other;
|
||||||
|
|
||||||
|
default: // new, unknown types can be dangerous
|
||||||
|
throw new VMError(`Unknown type '${type}'`);
|
||||||
|
}
|
||||||
|
factory = defaultFactory;
|
||||||
|
proto = undefined;
|
||||||
|
}
|
||||||
|
throw new VMError('Exception recursion depth');
|
||||||
|
}
|
||||||
|
|
||||||
|
function thisFromOtherArguments(args) {
|
||||||
|
// Note: args@other(safe-array) returns@this(safe-array) throws@this(unsafe)
|
||||||
|
const arr = [];
|
||||||
|
for (let i = 0; i < args.length; i++) {
|
||||||
|
const value = thisFromOther(args[i]);
|
||||||
|
thisReflectDefineProperty(arr, i, {
|
||||||
|
__proto__: null,
|
||||||
|
value: value,
|
||||||
|
writable: true,
|
||||||
|
enumerable: true,
|
||||||
|
configurable: true
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return arr;
|
||||||
|
}
|
||||||
|
|
||||||
|
function thisConnect(obj, other) {
|
||||||
|
// Note: obj@this(unsafe) other@other(unsafe) throws@this(unsafe)
|
||||||
|
try {
|
||||||
|
otherReflectApply(otherWeakMapSet, mappingThisToOther, [obj, other]);
|
||||||
|
} catch (e) {
|
||||||
|
throw new VMError('Unexpected error');
|
||||||
|
}
|
||||||
|
thisReflectApply(thisWeakMapSet, mappingOtherToThis, [other, obj]);
|
||||||
|
}
|
||||||
|
|
||||||
|
thisAddProtoMapping(thisGlobalPrototypes.Object, otherGlobalPrototypes.Object);
|
||||||
|
thisAddProtoMapping(thisGlobalPrototypes.Array, otherGlobalPrototypes.Array);
|
||||||
|
|
||||||
|
for (let i = 0; i < globalsList.length; i++) {
|
||||||
|
const key = globalsList[i];
|
||||||
|
const tp = thisGlobalPrototypes[key];
|
||||||
|
const op = otherGlobalPrototypes[key];
|
||||||
|
if (tp && op) thisAddProtoMapping(tp, op, key);
|
||||||
|
}
|
||||||
|
|
||||||
|
for (let i = 0; i < errorsList.length; i++) {
|
||||||
|
const key = errorsList[i];
|
||||||
|
const tp = thisGlobalPrototypes[key];
|
||||||
|
const op = otherGlobalPrototypes[key];
|
||||||
|
if (tp && op) thisAddProtoMapping(tp, op, 'Error');
|
||||||
|
}
|
||||||
|
|
||||||
|
thisAddProtoMapping(thisGlobalPrototypes.VMError, otherGlobalPrototypes.VMError, 'Error');
|
||||||
|
|
||||||
|
result.BaseHandler = BaseHandler;
|
||||||
|
result.ProtectedHandler = ProtectedHandler;
|
||||||
|
result.ReadOnlyHandler = ReadOnlyHandler;
|
||||||
|
result.ReadOnlyMockHandler = ReadOnlyMockHandler;
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
exports.createBridge = createBridge;
|
||||||
|
exports.VMError = VMError;
|
||||||
|
|
||||||
|
|
||||||
|
/***/ })
|
||||||
|
|
||||||
|
/******/ });
|
||||||
|
/************************************************************************/
|
||||||
|
/******/ /* webpack/runtime/compat */
|
||||||
|
/******/
|
||||||
|
/******/ if (typeof __nccwpck_require__ !== 'undefined') __nccwpck_require__.ab = __dirname + "/";/************************************************************************/
|
||||||
|
/******/
|
||||||
|
/******/ // startup
|
||||||
|
/******/ // Load entry module and return exports
|
||||||
|
/******/ // This entry module is referenced by other modules so it can't be inlined
|
||||||
|
/******/ var __webpack_exports__ = {};
|
||||||
|
/******/ __webpack_modules__[989](0, __webpack_exports__);
|
||||||
|
/******/ module.exports = __webpack_exports__;
|
||||||
|
/******/
|
||||||
|
/******/ })()
|
||||||
|
;
|
||||||
1033
dist/events.js
generated
vendored
Normal file
1033
dist/events.js
generated
vendored
Normal file
@@ -0,0 +1,1033 @@
|
|||||||
|
/******/ (() => { // webpackBootstrap
|
||||||
|
/******/ "use strict";
|
||||||
|
/******/ var __webpack_modules__ = ({
|
||||||
|
|
||||||
|
/***/ 906:
|
||||||
|
/***/ ((module) => {
|
||||||
|
|
||||||
|
// Copyright Joyent, Inc. and other Node contributors.
|
||||||
|
//
|
||||||
|
// 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.
|
||||||
|
|
||||||
|
// Modified by the vm2 team to make this a standalone module to be loaded into the sandbox.
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
const host = fromhost;
|
||||||
|
|
||||||
|
const {
|
||||||
|
Boolean,
|
||||||
|
Error,
|
||||||
|
String,
|
||||||
|
Symbol
|
||||||
|
} = globalThis;
|
||||||
|
|
||||||
|
const ReflectApply = Reflect.apply;
|
||||||
|
const ReflectOwnKeys = Reflect.ownKeys;
|
||||||
|
|
||||||
|
const ErrorCaptureStackTrace = Error.captureStackTrace;
|
||||||
|
|
||||||
|
const NumberIsNaN = Number.isNaN;
|
||||||
|
|
||||||
|
const ObjectCreate = Object.create;
|
||||||
|
const ObjectDefineProperty = Object.defineProperty;
|
||||||
|
const ObjectDefineProperties = Object.defineProperties;
|
||||||
|
const ObjectGetPrototypeOf = Object.getPrototypeOf;
|
||||||
|
|
||||||
|
const SymbolFor = Symbol.for;
|
||||||
|
|
||||||
|
function uncurryThis(func) {
|
||||||
|
return (thiz, ...args) => ReflectApply(func, thiz, args);
|
||||||
|
}
|
||||||
|
|
||||||
|
const ArrayPrototypeIndexOf = uncurryThis(Array.prototype.indexOf);
|
||||||
|
const ArrayPrototypeJoin = uncurryThis(Array.prototype.join);
|
||||||
|
const ArrayPrototypeSlice = uncurryThis(Array.prototype.slice);
|
||||||
|
const ArrayPrototypeSplice = uncurryThis(Array.prototype.splice);
|
||||||
|
const ArrayPrototypeUnshift = uncurryThis(Array.prototype.unshift);
|
||||||
|
|
||||||
|
const kRejection = SymbolFor('nodejs.rejection');
|
||||||
|
|
||||||
|
function inspect(obj) {
|
||||||
|
return typeof obj === 'symbol' ? obj.toString() : `${obj}`;
|
||||||
|
}
|
||||||
|
|
||||||
|
function spliceOne(list, index) {
|
||||||
|
for (; index + 1 < list.length; index++)
|
||||||
|
list[index] = list[index + 1];
|
||||||
|
list.pop();
|
||||||
|
}
|
||||||
|
|
||||||
|
function assert(what, message) {
|
||||||
|
if (!what) throw new Error(message);
|
||||||
|
}
|
||||||
|
|
||||||
|
function E(key, msg, Base) {
|
||||||
|
return function NodeError(...args) {
|
||||||
|
const error = new Base();
|
||||||
|
const message = ReflectApply(msg, error, args);
|
||||||
|
ObjectDefineProperties(error, {
|
||||||
|
message: {
|
||||||
|
value: message,
|
||||||
|
enumerable: false,
|
||||||
|
writable: true,
|
||||||
|
configurable: true,
|
||||||
|
},
|
||||||
|
toString: {
|
||||||
|
value() {
|
||||||
|
return `${this.name} [${key}]: ${this.message}`;
|
||||||
|
},
|
||||||
|
enumerable: false,
|
||||||
|
writable: true,
|
||||||
|
configurable: true,
|
||||||
|
},
|
||||||
|
});
|
||||||
|
error.code = key;
|
||||||
|
return error;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
const ERR_INVALID_ARG_TYPE = E('ERR_INVALID_ARG_TYPE',
|
||||||
|
(name, expected, actual) => {
|
||||||
|
assert(typeof name === 'string', "'name' must be a string");
|
||||||
|
if (!ArrayIsArray(expected)) {
|
||||||
|
expected = [expected];
|
||||||
|
}
|
||||||
|
|
||||||
|
let msg = 'The ';
|
||||||
|
if (StringPrototypeEndsWith(name, ' argument')) {
|
||||||
|
// For cases like 'first argument'
|
||||||
|
msg += `${name} `;
|
||||||
|
} else {
|
||||||
|
const type = StringPrototypeIncludes(name, '.') ? 'property' : 'argument';
|
||||||
|
msg += `"${name}" ${type} `;
|
||||||
|
}
|
||||||
|
msg += 'must be ';
|
||||||
|
|
||||||
|
const types = [];
|
||||||
|
const instances = [];
|
||||||
|
const other = [];
|
||||||
|
|
||||||
|
for (const value of expected) {
|
||||||
|
assert(typeof value === 'string',
|
||||||
|
'All expected entries have to be of type string');
|
||||||
|
if (ArrayPrototypeIncludes(kTypes, value)) {
|
||||||
|
ArrayPrototypePush(types, StringPrototypeToLowerCase(value));
|
||||||
|
} else if (RegExpPrototypeTest(classRegExp, value)) {
|
||||||
|
ArrayPrototypePush(instances, value);
|
||||||
|
} else {
|
||||||
|
assert(value !== 'object',
|
||||||
|
'The value "object" should be written as "Object"');
|
||||||
|
ArrayPrototypePush(other, value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Special handle `object` in case other instances are allowed to outline
|
||||||
|
// the differences between each other.
|
||||||
|
if (instances.length > 0) {
|
||||||
|
const pos = ArrayPrototypeIndexOf(types, 'object');
|
||||||
|
if (pos !== -1) {
|
||||||
|
ArrayPrototypeSplice(types, pos, 1);
|
||||||
|
ArrayPrototypePush(instances, 'Object');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (types.length > 0) {
|
||||||
|
if (types.length > 2) {
|
||||||
|
const last = ArrayPrototypePop(types);
|
||||||
|
msg += `one of type ${ArrayPrototypeJoin(types, ', ')}, or ${last}`;
|
||||||
|
} else if (types.length === 2) {
|
||||||
|
msg += `one of type ${types[0]} or ${types[1]}`;
|
||||||
|
} else {
|
||||||
|
msg += `of type ${types[0]}`;
|
||||||
|
}
|
||||||
|
if (instances.length > 0 || other.length > 0)
|
||||||
|
msg += ' or ';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (instances.length > 0) {
|
||||||
|
if (instances.length > 2) {
|
||||||
|
const last = ArrayPrototypePop(instances);
|
||||||
|
msg +=
|
||||||
|
`an instance of ${ArrayPrototypeJoin(instances, ', ')}, or ${last}`;
|
||||||
|
} else {
|
||||||
|
msg += `an instance of ${instances[0]}`;
|
||||||
|
if (instances.length === 2) {
|
||||||
|
msg += ` or ${instances[1]}`;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (other.length > 0)
|
||||||
|
msg += ' or ';
|
||||||
|
}
|
||||||
|
|
||||||
|
if (other.length > 0) {
|
||||||
|
if (other.length > 2) {
|
||||||
|
const last = ArrayPrototypePop(other);
|
||||||
|
msg += `one of ${ArrayPrototypeJoin(other, ', ')}, or ${last}`;
|
||||||
|
} else if (other.length === 2) {
|
||||||
|
msg += `one of ${other[0]} or ${other[1]}`;
|
||||||
|
} else {
|
||||||
|
if (StringPrototypeToLowerCase(other[0]) !== other[0])
|
||||||
|
msg += 'an ';
|
||||||
|
msg += `${other[0]}`;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (actual == null) {
|
||||||
|
msg += `. Received ${actual}`;
|
||||||
|
} else if (typeof actual === 'function' && actual.name) {
|
||||||
|
msg += `. Received function ${actual.name}`;
|
||||||
|
} else if (typeof actual === 'object') {
|
||||||
|
if (actual.constructor && actual.constructor.name) {
|
||||||
|
msg += `. Received an instance of ${actual.constructor.name}`;
|
||||||
|
} else {
|
||||||
|
const inspected = inspect(actual, { depth: -1 });
|
||||||
|
msg += `. Received ${inspected}`;
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
let inspected = inspect(actual, { colors: false });
|
||||||
|
if (inspected.length > 25)
|
||||||
|
inspected = `${StringPrototypeSlice(inspected, 0, 25)}...`;
|
||||||
|
msg += `. Received type ${typeof actual} (${inspected})`;
|
||||||
|
}
|
||||||
|
return msg;
|
||||||
|
}, TypeError);
|
||||||
|
|
||||||
|
const ERR_INVALID_THIS = E('ERR_INVALID_THIS', s => `Value of "this" must be of type ${s}`, TypeError);
|
||||||
|
|
||||||
|
const ERR_OUT_OF_RANGE = E('ERR_OUT_OF_RANGE',
|
||||||
|
(str, range, input, replaceDefaultBoolean = false) => {
|
||||||
|
assert(range, 'Missing "range" argument');
|
||||||
|
let msg = replaceDefaultBoolean ? str :
|
||||||
|
`The value of "${str}" is out of range.`;
|
||||||
|
const received = inspect(input);
|
||||||
|
msg += ` It must be ${range}. Received ${received}`;
|
||||||
|
return msg;
|
||||||
|
}, RangeError);
|
||||||
|
|
||||||
|
const ERR_UNHANDLED_ERROR = E('ERR_UNHANDLED_ERROR',
|
||||||
|
err => {
|
||||||
|
const msg = 'Unhandled error.';
|
||||||
|
if (err === undefined) return msg;
|
||||||
|
return `${msg} (${err})`;
|
||||||
|
}, Error);
|
||||||
|
|
||||||
|
function validateBoolean(value, name) {
|
||||||
|
if (typeof value !== 'boolean')
|
||||||
|
throw new ERR_INVALID_ARG_TYPE(name, 'boolean', value);
|
||||||
|
}
|
||||||
|
|
||||||
|
function validateFunction(value, name) {
|
||||||
|
if (typeof value !== 'function')
|
||||||
|
throw new ERR_INVALID_ARG_TYPE(name, 'Function', value);
|
||||||
|
}
|
||||||
|
|
||||||
|
function validateString(value, name) {
|
||||||
|
if (typeof value !== 'string')
|
||||||
|
throw new ERR_INVALID_ARG_TYPE(name, 'string', value);
|
||||||
|
}
|
||||||
|
|
||||||
|
function nc(cond, e) {
|
||||||
|
return cond === undefined || cond === null ? e : cond;
|
||||||
|
}
|
||||||
|
|
||||||
|
function oc(base, key) {
|
||||||
|
return base === undefined || base === null ? undefined : base[key];
|
||||||
|
}
|
||||||
|
|
||||||
|
const kCapture = Symbol('kCapture');
|
||||||
|
const kErrorMonitor = host.kErrorMonitor || Symbol('events.errorMonitor');
|
||||||
|
const kMaxEventTargetListeners = Symbol('events.maxEventTargetListeners');
|
||||||
|
const kMaxEventTargetListenersWarned =
|
||||||
|
Symbol('events.maxEventTargetListenersWarned');
|
||||||
|
|
||||||
|
const kIsEventTarget = SymbolFor('nodejs.event_target');
|
||||||
|
|
||||||
|
function isEventTarget(obj) {
|
||||||
|
return oc(oc(obj, 'constructor'), kIsEventTarget);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Creates a new `EventEmitter` instance.
|
||||||
|
* @param {{ captureRejections?: boolean; }} [opts]
|
||||||
|
* @constructs {EventEmitter}
|
||||||
|
*/
|
||||||
|
function EventEmitter(opts) {
|
||||||
|
EventEmitter.init.call(this, opts);
|
||||||
|
}
|
||||||
|
module.exports = EventEmitter;
|
||||||
|
if (host.once) module.exports.once = host.once;
|
||||||
|
if (host.on) module.exports.on = host.on;
|
||||||
|
if (host.getEventListeners) module.exports.getEventListeners = host.getEventListeners;
|
||||||
|
// Backwards-compat with node 0.10.x
|
||||||
|
EventEmitter.EventEmitter = EventEmitter;
|
||||||
|
|
||||||
|
EventEmitter.usingDomains = false;
|
||||||
|
|
||||||
|
EventEmitter.captureRejectionSymbol = kRejection;
|
||||||
|
ObjectDefineProperty(EventEmitter, 'captureRejections', {
|
||||||
|
get() {
|
||||||
|
return EventEmitter.prototype[kCapture];
|
||||||
|
},
|
||||||
|
set(value) {
|
||||||
|
validateBoolean(value, 'EventEmitter.captureRejections');
|
||||||
|
|
||||||
|
EventEmitter.prototype[kCapture] = value;
|
||||||
|
},
|
||||||
|
enumerable: true
|
||||||
|
});
|
||||||
|
|
||||||
|
if (host.EventEmitterReferencingAsyncResource) {
|
||||||
|
const kAsyncResource = Symbol('kAsyncResource');
|
||||||
|
const EventEmitterReferencingAsyncResource = host.EventEmitterReferencingAsyncResource;
|
||||||
|
|
||||||
|
class EventEmitterAsyncResource extends EventEmitter {
|
||||||
|
/**
|
||||||
|
* @param {{
|
||||||
|
* name?: string,
|
||||||
|
* triggerAsyncId?: number,
|
||||||
|
* requireManualDestroy?: boolean,
|
||||||
|
* }} [options]
|
||||||
|
*/
|
||||||
|
constructor(options = undefined) {
|
||||||
|
let name;
|
||||||
|
if (typeof options === 'string') {
|
||||||
|
name = options;
|
||||||
|
options = undefined;
|
||||||
|
} else {
|
||||||
|
if (new.target === EventEmitterAsyncResource) {
|
||||||
|
validateString(oc(options, 'name'), 'options.name');
|
||||||
|
}
|
||||||
|
name = oc(options, 'name') || new.target.name;
|
||||||
|
}
|
||||||
|
super(options);
|
||||||
|
|
||||||
|
this[kAsyncResource] =
|
||||||
|
new EventEmitterReferencingAsyncResource(this, name, options);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @param {symbol,string} event
|
||||||
|
* @param {...any} args
|
||||||
|
* @returns {boolean}
|
||||||
|
*/
|
||||||
|
emit(event, ...args) {
|
||||||
|
if (this[kAsyncResource] === undefined)
|
||||||
|
throw new ERR_INVALID_THIS('EventEmitterAsyncResource');
|
||||||
|
const { asyncResource } = this;
|
||||||
|
ArrayPrototypeUnshift(args, super.emit, this, event);
|
||||||
|
return ReflectApply(asyncResource.runInAsyncScope, asyncResource,
|
||||||
|
args);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @returns {void}
|
||||||
|
*/
|
||||||
|
emitDestroy() {
|
||||||
|
if (this[kAsyncResource] === undefined)
|
||||||
|
throw new ERR_INVALID_THIS('EventEmitterAsyncResource');
|
||||||
|
this.asyncResource.emitDestroy();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @type {number}
|
||||||
|
*/
|
||||||
|
get asyncId() {
|
||||||
|
if (this[kAsyncResource] === undefined)
|
||||||
|
throw new ERR_INVALID_THIS('EventEmitterAsyncResource');
|
||||||
|
return this.asyncResource.asyncId();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @type {number}
|
||||||
|
*/
|
||||||
|
get triggerAsyncId() {
|
||||||
|
if (this[kAsyncResource] === undefined)
|
||||||
|
throw new ERR_INVALID_THIS('EventEmitterAsyncResource');
|
||||||
|
return this.asyncResource.triggerAsyncId();
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @type {EventEmitterReferencingAsyncResource}
|
||||||
|
*/
|
||||||
|
get asyncResource() {
|
||||||
|
if (this[kAsyncResource] === undefined)
|
||||||
|
throw new ERR_INVALID_THIS('EventEmitterAsyncResource');
|
||||||
|
return this[kAsyncResource];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
EventEmitter.EventEmitterAsyncResource = EventEmitterAsyncResource;
|
||||||
|
}
|
||||||
|
|
||||||
|
EventEmitter.errorMonitor = kErrorMonitor;
|
||||||
|
|
||||||
|
// The default for captureRejections is false
|
||||||
|
ObjectDefineProperty(EventEmitter.prototype, kCapture, {
|
||||||
|
value: false,
|
||||||
|
writable: true,
|
||||||
|
enumerable: false
|
||||||
|
});
|
||||||
|
|
||||||
|
EventEmitter.prototype._events = undefined;
|
||||||
|
EventEmitter.prototype._eventsCount = 0;
|
||||||
|
EventEmitter.prototype._maxListeners = undefined;
|
||||||
|
|
||||||
|
// By default EventEmitters will print a warning if more than 10 listeners are
|
||||||
|
// added to it. This is a useful default which helps finding memory leaks.
|
||||||
|
let defaultMaxListeners = 10;
|
||||||
|
|
||||||
|
function checkListener(listener) {
|
||||||
|
validateFunction(listener, 'listener');
|
||||||
|
}
|
||||||
|
|
||||||
|
ObjectDefineProperty(EventEmitter, 'defaultMaxListeners', {
|
||||||
|
enumerable: true,
|
||||||
|
get: function() {
|
||||||
|
return defaultMaxListeners;
|
||||||
|
},
|
||||||
|
set: function(arg) {
|
||||||
|
if (typeof arg !== 'number' || arg < 0 || NumberIsNaN(arg)) {
|
||||||
|
throw new ERR_OUT_OF_RANGE('defaultMaxListeners',
|
||||||
|
'a non-negative number',
|
||||||
|
arg);
|
||||||
|
}
|
||||||
|
defaultMaxListeners = arg;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
ObjectDefineProperties(EventEmitter, {
|
||||||
|
kMaxEventTargetListeners: {
|
||||||
|
value: kMaxEventTargetListeners,
|
||||||
|
enumerable: false,
|
||||||
|
configurable: false,
|
||||||
|
writable: false,
|
||||||
|
},
|
||||||
|
kMaxEventTargetListenersWarned: {
|
||||||
|
value: kMaxEventTargetListenersWarned,
|
||||||
|
enumerable: false,
|
||||||
|
configurable: false,
|
||||||
|
writable: false,
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Sets the max listeners.
|
||||||
|
* @param {number} n
|
||||||
|
* @param {EventTarget[] | EventEmitter[]} [eventTargets]
|
||||||
|
* @returns {void}
|
||||||
|
*/
|
||||||
|
EventEmitter.setMaxListeners =
|
||||||
|
function(n = defaultMaxListeners, ...eventTargets) {
|
||||||
|
if (typeof n !== 'number' || n < 0 || NumberIsNaN(n))
|
||||||
|
throw new ERR_OUT_OF_RANGE('n', 'a non-negative number', n);
|
||||||
|
if (eventTargets.length === 0) {
|
||||||
|
defaultMaxListeners = n;
|
||||||
|
} else {
|
||||||
|
for (let i = 0; i < eventTargets.length; i++) {
|
||||||
|
const target = eventTargets[i];
|
||||||
|
if (isEventTarget(target)) {
|
||||||
|
target[kMaxEventTargetListeners] = n;
|
||||||
|
target[kMaxEventTargetListenersWarned] = false;
|
||||||
|
} else if (typeof target.setMaxListeners === 'function') {
|
||||||
|
target.setMaxListeners(n);
|
||||||
|
} else {
|
||||||
|
throw new ERR_INVALID_ARG_TYPE(
|
||||||
|
'eventTargets',
|
||||||
|
['EventEmitter', 'EventTarget'],
|
||||||
|
target);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
// If you're updating this function definition, please also update any
|
||||||
|
// re-definitions, such as the one in the Domain module (lib/domain.js).
|
||||||
|
EventEmitter.init = function(opts) {
|
||||||
|
|
||||||
|
if (this._events === undefined ||
|
||||||
|
this._events === ObjectGetPrototypeOf(this)._events) {
|
||||||
|
this._events = ObjectCreate(null);
|
||||||
|
this._eventsCount = 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
this._maxListeners = this._maxListeners || undefined;
|
||||||
|
|
||||||
|
|
||||||
|
if (oc(opts, 'captureRejections')) {
|
||||||
|
validateBoolean(opts.captureRejections, 'options.captureRejections');
|
||||||
|
this[kCapture] = Boolean(opts.captureRejections);
|
||||||
|
} else {
|
||||||
|
// Assigning the kCapture property directly saves an expensive
|
||||||
|
// prototype lookup in a very sensitive hot path.
|
||||||
|
this[kCapture] = EventEmitter.prototype[kCapture];
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
function addCatch(that, promise, type, args) {
|
||||||
|
if (!that[kCapture]) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Handle Promises/A+ spec, then could be a getter
|
||||||
|
// that throws on second use.
|
||||||
|
try {
|
||||||
|
const then = promise.then;
|
||||||
|
|
||||||
|
if (typeof then === 'function') {
|
||||||
|
then.call(promise, undefined, function(err) {
|
||||||
|
// The callback is called with nextTick to avoid a follow-up
|
||||||
|
// rejection from this promise.
|
||||||
|
process.nextTick(emitUnhandledRejectionOrErr, that, err, type, args);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
} catch (err) {
|
||||||
|
that.emit('error', err);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function emitUnhandledRejectionOrErr(ee, err, type, args) {
|
||||||
|
if (typeof ee[kRejection] === 'function') {
|
||||||
|
ee[kRejection](err, type, ...args);
|
||||||
|
} else {
|
||||||
|
// We have to disable the capture rejections mechanism, otherwise
|
||||||
|
// we might end up in an infinite loop.
|
||||||
|
const prev = ee[kCapture];
|
||||||
|
|
||||||
|
// If the error handler throws, it is not catchable and it
|
||||||
|
// will end up in 'uncaughtException'. We restore the previous
|
||||||
|
// value of kCapture in case the uncaughtException is present
|
||||||
|
// and the exception is handled.
|
||||||
|
try {
|
||||||
|
ee[kCapture] = false;
|
||||||
|
ee.emit('error', err);
|
||||||
|
} finally {
|
||||||
|
ee[kCapture] = prev;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Increases the max listeners of the event emitter.
|
||||||
|
* @param {number} n
|
||||||
|
* @returns {EventEmitter}
|
||||||
|
*/
|
||||||
|
EventEmitter.prototype.setMaxListeners = function setMaxListeners(n) {
|
||||||
|
if (typeof n !== 'number' || n < 0 || NumberIsNaN(n)) {
|
||||||
|
throw new ERR_OUT_OF_RANGE('n', 'a non-negative number', n);
|
||||||
|
}
|
||||||
|
this._maxListeners = n;
|
||||||
|
return this;
|
||||||
|
};
|
||||||
|
|
||||||
|
function _getMaxListeners(that) {
|
||||||
|
if (that._maxListeners === undefined)
|
||||||
|
return EventEmitter.defaultMaxListeners;
|
||||||
|
return that._maxListeners;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the current max listener value for the event emitter.
|
||||||
|
* @returns {number}
|
||||||
|
*/
|
||||||
|
EventEmitter.prototype.getMaxListeners = function getMaxListeners() {
|
||||||
|
return _getMaxListeners(this);
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Synchronously calls each of the listeners registered
|
||||||
|
* for the event.
|
||||||
|
* @param {string | symbol} type
|
||||||
|
* @param {...any} [args]
|
||||||
|
* @returns {boolean}
|
||||||
|
*/
|
||||||
|
EventEmitter.prototype.emit = function emit(type, ...args) {
|
||||||
|
let doError = (type === 'error');
|
||||||
|
|
||||||
|
const events = this._events;
|
||||||
|
if (events !== undefined) {
|
||||||
|
if (doError && events[kErrorMonitor] !== undefined)
|
||||||
|
this.emit(kErrorMonitor, ...args);
|
||||||
|
doError = (doError && events.error === undefined);
|
||||||
|
} else if (!doError)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
// If there is no 'error' event listener then throw.
|
||||||
|
if (doError) {
|
||||||
|
let er;
|
||||||
|
if (args.length > 0)
|
||||||
|
er = args[0];
|
||||||
|
if (er instanceof Error) {
|
||||||
|
try {
|
||||||
|
const capture = {};
|
||||||
|
ErrorCaptureStackTrace(capture, EventEmitter.prototype.emit);
|
||||||
|
} catch (e) {}
|
||||||
|
|
||||||
|
// Note: The comments on the `throw` lines are intentional, they show
|
||||||
|
// up in Node's output if this results in an unhandled exception.
|
||||||
|
throw er; // Unhandled 'error' event
|
||||||
|
}
|
||||||
|
|
||||||
|
let stringifiedEr;
|
||||||
|
try {
|
||||||
|
stringifiedEr = inspect(er);
|
||||||
|
} catch (e) {
|
||||||
|
stringifiedEr = er;
|
||||||
|
}
|
||||||
|
|
||||||
|
// At least give some kind of context to the user
|
||||||
|
const err = new ERR_UNHANDLED_ERROR(stringifiedEr);
|
||||||
|
err.context = er;
|
||||||
|
throw err; // Unhandled 'error' event
|
||||||
|
}
|
||||||
|
|
||||||
|
const handler = events[type];
|
||||||
|
|
||||||
|
if (handler === undefined)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
if (typeof handler === 'function') {
|
||||||
|
const result = handler.apply(this, args);
|
||||||
|
|
||||||
|
// We check if result is undefined first because that
|
||||||
|
// is the most common case so we do not pay any perf
|
||||||
|
// penalty
|
||||||
|
if (result !== undefined && result !== null) {
|
||||||
|
addCatch(this, result, type, args);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
const len = handler.length;
|
||||||
|
const listeners = arrayClone(handler);
|
||||||
|
for (let i = 0; i < len; ++i) {
|
||||||
|
const result = listeners[i].apply(this, args);
|
||||||
|
|
||||||
|
// We check if result is undefined first because that
|
||||||
|
// is the most common case so we do not pay any perf
|
||||||
|
// penalty.
|
||||||
|
// This code is duplicated because extracting it away
|
||||||
|
// would make it non-inlineable.
|
||||||
|
if (result !== undefined && result !== null) {
|
||||||
|
addCatch(this, result, type, args);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
};
|
||||||
|
|
||||||
|
function _addListener(target, type, listener, prepend) {
|
||||||
|
let m;
|
||||||
|
let events;
|
||||||
|
let existing;
|
||||||
|
|
||||||
|
checkListener(listener);
|
||||||
|
|
||||||
|
events = target._events;
|
||||||
|
if (events === undefined) {
|
||||||
|
events = target._events = ObjectCreate(null);
|
||||||
|
target._eventsCount = 0;
|
||||||
|
} else {
|
||||||
|
// To avoid recursion in the case that type === "newListener"! Before
|
||||||
|
// adding it to the listeners, first emit "newListener".
|
||||||
|
if (events.newListener !== undefined) {
|
||||||
|
target.emit('newListener', type,
|
||||||
|
nc(listener.listener, listener));
|
||||||
|
|
||||||
|
// Re-assign `events` because a newListener handler could have caused the
|
||||||
|
// this._events to be assigned to a new object
|
||||||
|
events = target._events;
|
||||||
|
}
|
||||||
|
existing = events[type];
|
||||||
|
}
|
||||||
|
|
||||||
|
if (existing === undefined) {
|
||||||
|
// Optimize the case of one listener. Don't need the extra array object.
|
||||||
|
events[type] = listener;
|
||||||
|
++target._eventsCount;
|
||||||
|
} else {
|
||||||
|
if (typeof existing === 'function') {
|
||||||
|
// Adding the second element, need to change to array.
|
||||||
|
existing = events[type] =
|
||||||
|
prepend ? [listener, existing] : [existing, listener];
|
||||||
|
// If we've already got an array, just append.
|
||||||
|
} else if (prepend) {
|
||||||
|
existing.unshift(listener);
|
||||||
|
} else {
|
||||||
|
existing.push(listener);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Check for listener leak
|
||||||
|
m = _getMaxListeners(target);
|
||||||
|
if (m > 0 && existing.length > m && !existing.warned) {
|
||||||
|
existing.warned = true;
|
||||||
|
// No error code for this since it is a Warning
|
||||||
|
// eslint-disable-next-line no-restricted-syntax
|
||||||
|
const w = new Error('Possible EventEmitter memory leak detected. ' +
|
||||||
|
`${existing.length} ${String(type)} listeners ` +
|
||||||
|
`added to ${inspect(target, { depth: -1 })}. Use ` +
|
||||||
|
'emitter.setMaxListeners() to increase limit');
|
||||||
|
w.name = 'MaxListenersExceededWarning';
|
||||||
|
w.emitter = target;
|
||||||
|
w.type = type;
|
||||||
|
w.count = existing.length;
|
||||||
|
process.emitWarning(w);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return target;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds a listener to the event emitter.
|
||||||
|
* @param {string | symbol} type
|
||||||
|
* @param {Function} listener
|
||||||
|
* @returns {EventEmitter}
|
||||||
|
*/
|
||||||
|
EventEmitter.prototype.addListener = function addListener(type, listener) {
|
||||||
|
return _addListener(this, type, listener, false);
|
||||||
|
};
|
||||||
|
|
||||||
|
EventEmitter.prototype.on = EventEmitter.prototype.addListener;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds the `listener` function to the beginning of
|
||||||
|
* the listeners array.
|
||||||
|
* @param {string | symbol} type
|
||||||
|
* @param {Function} listener
|
||||||
|
* @returns {EventEmitter}
|
||||||
|
*/
|
||||||
|
EventEmitter.prototype.prependListener =
|
||||||
|
function prependListener(type, listener) {
|
||||||
|
return _addListener(this, type, listener, true);
|
||||||
|
};
|
||||||
|
|
||||||
|
function onceWrapper() {
|
||||||
|
if (!this.fired) {
|
||||||
|
this.target.removeListener(this.type, this.wrapFn);
|
||||||
|
this.fired = true;
|
||||||
|
if (arguments.length === 0)
|
||||||
|
return this.listener.call(this.target);
|
||||||
|
return this.listener.apply(this.target, arguments);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function _onceWrap(target, type, listener) {
|
||||||
|
const state = { fired: false, wrapFn: undefined, target, type, listener };
|
||||||
|
const wrapped = onceWrapper.bind(state);
|
||||||
|
wrapped.listener = listener;
|
||||||
|
state.wrapFn = wrapped;
|
||||||
|
return wrapped;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds a one-time `listener` function to the event emitter.
|
||||||
|
* @param {string | symbol} type
|
||||||
|
* @param {Function} listener
|
||||||
|
* @returns {EventEmitter}
|
||||||
|
*/
|
||||||
|
EventEmitter.prototype.once = function once(type, listener) {
|
||||||
|
checkListener(listener);
|
||||||
|
|
||||||
|
this.on(type, _onceWrap(this, type, listener));
|
||||||
|
return this;
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Adds a one-time `listener` function to the beginning of
|
||||||
|
* the listeners array.
|
||||||
|
* @param {string | symbol} type
|
||||||
|
* @param {Function} listener
|
||||||
|
* @returns {EventEmitter}
|
||||||
|
*/
|
||||||
|
EventEmitter.prototype.prependOnceListener =
|
||||||
|
function prependOnceListener(type, listener) {
|
||||||
|
checkListener(listener);
|
||||||
|
|
||||||
|
this.prependListener(type, _onceWrap(this, type, listener));
|
||||||
|
return this;
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Removes the specified `listener` from the listeners array.
|
||||||
|
* @param {string | symbol} type
|
||||||
|
* @param {Function} listener
|
||||||
|
* @returns {EventEmitter}
|
||||||
|
*/
|
||||||
|
EventEmitter.prototype.removeListener =
|
||||||
|
function removeListener(type, listener) {
|
||||||
|
checkListener(listener);
|
||||||
|
|
||||||
|
const events = this._events;
|
||||||
|
if (events === undefined)
|
||||||
|
return this;
|
||||||
|
|
||||||
|
const list = events[type];
|
||||||
|
if (list === undefined)
|
||||||
|
return this;
|
||||||
|
|
||||||
|
if (list === listener || list.listener === listener) {
|
||||||
|
if (--this._eventsCount === 0)
|
||||||
|
this._events = ObjectCreate(null);
|
||||||
|
else {
|
||||||
|
delete events[type];
|
||||||
|
if (events.removeListener)
|
||||||
|
this.emit('removeListener', type, list.listener || listener);
|
||||||
|
}
|
||||||
|
} else if (typeof list !== 'function') {
|
||||||
|
let position = -1;
|
||||||
|
|
||||||
|
for (let i = list.length - 1; i >= 0; i--) {
|
||||||
|
if (list[i] === listener || list[i].listener === listener) {
|
||||||
|
position = i;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (position < 0)
|
||||||
|
return this;
|
||||||
|
|
||||||
|
if (position === 0)
|
||||||
|
list.shift();
|
||||||
|
else {
|
||||||
|
spliceOne(list, position);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (list.length === 1)
|
||||||
|
events[type] = list[0];
|
||||||
|
|
||||||
|
if (events.removeListener !== undefined)
|
||||||
|
this.emit('removeListener', type, listener);
|
||||||
|
}
|
||||||
|
|
||||||
|
return this;
|
||||||
|
};
|
||||||
|
|
||||||
|
EventEmitter.prototype.off = EventEmitter.prototype.removeListener;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Removes all listeners from the event emitter. (Only
|
||||||
|
* removes listeners for a specific event name if specified
|
||||||
|
* as `type`).
|
||||||
|
* @param {string | symbol} [type]
|
||||||
|
* @returns {EventEmitter}
|
||||||
|
*/
|
||||||
|
EventEmitter.prototype.removeAllListeners =
|
||||||
|
function removeAllListeners(type) {
|
||||||
|
const events = this._events;
|
||||||
|
if (events === undefined)
|
||||||
|
return this;
|
||||||
|
|
||||||
|
// Not listening for removeListener, no need to emit
|
||||||
|
if (events.removeListener === undefined) {
|
||||||
|
if (arguments.length === 0) {
|
||||||
|
this._events = ObjectCreate(null);
|
||||||
|
this._eventsCount = 0;
|
||||||
|
} else if (events[type] !== undefined) {
|
||||||
|
if (--this._eventsCount === 0)
|
||||||
|
this._events = ObjectCreate(null);
|
||||||
|
else
|
||||||
|
delete events[type];
|
||||||
|
}
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
// Emit removeListener for all listeners on all events
|
||||||
|
if (arguments.length === 0) {
|
||||||
|
for (const key of ReflectOwnKeys(events)) {
|
||||||
|
if (key === 'removeListener') continue;
|
||||||
|
this.removeAllListeners(key);
|
||||||
|
}
|
||||||
|
this.removeAllListeners('removeListener');
|
||||||
|
this._events = ObjectCreate(null);
|
||||||
|
this._eventsCount = 0;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
const listeners = events[type];
|
||||||
|
|
||||||
|
if (typeof listeners === 'function') {
|
||||||
|
this.removeListener(type, listeners);
|
||||||
|
} else if (listeners !== undefined) {
|
||||||
|
// LIFO order
|
||||||
|
for (let i = listeners.length - 1; i >= 0; i--) {
|
||||||
|
this.removeListener(type, listeners[i]);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return this;
|
||||||
|
};
|
||||||
|
|
||||||
|
function _listeners(target, type, unwrap) {
|
||||||
|
const events = target._events;
|
||||||
|
|
||||||
|
if (events === undefined)
|
||||||
|
return [];
|
||||||
|
|
||||||
|
const evlistener = events[type];
|
||||||
|
if (evlistener === undefined)
|
||||||
|
return [];
|
||||||
|
|
||||||
|
if (typeof evlistener === 'function')
|
||||||
|
return unwrap ? [evlistener.listener || evlistener] : [evlistener];
|
||||||
|
|
||||||
|
return unwrap ?
|
||||||
|
unwrapListeners(evlistener) : arrayClone(evlistener);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a copy of the array of listeners for the event name
|
||||||
|
* specified as `type`.
|
||||||
|
* @param {string | symbol} type
|
||||||
|
* @returns {Function[]}
|
||||||
|
*/
|
||||||
|
EventEmitter.prototype.listeners = function listeners(type) {
|
||||||
|
return _listeners(this, type, true);
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns a copy of the array of listeners and wrappers for
|
||||||
|
* the event name specified as `type`.
|
||||||
|
* @param {string | symbol} type
|
||||||
|
* @returns {Function[]}
|
||||||
|
*/
|
||||||
|
EventEmitter.prototype.rawListeners = function rawListeners(type) {
|
||||||
|
return _listeners(this, type, false);
|
||||||
|
};
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the number of listeners listening to the event name
|
||||||
|
* specified as `type`.
|
||||||
|
* @deprecated since v3.2.0
|
||||||
|
* @param {EventEmitter} emitter
|
||||||
|
* @param {string | symbol} type
|
||||||
|
* @returns {number}
|
||||||
|
*/
|
||||||
|
EventEmitter.listenerCount = function(emitter, type) {
|
||||||
|
if (typeof emitter.listenerCount === 'function') {
|
||||||
|
return emitter.listenerCount(type);
|
||||||
|
}
|
||||||
|
return emitter.listenerCount(type);
|
||||||
|
};
|
||||||
|
|
||||||
|
EventEmitter.prototype.listenerCount = listenerCount;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns the number of listeners listening to event name
|
||||||
|
* specified as `type`.
|
||||||
|
* @param {string | symbol} type
|
||||||
|
* @returns {number}
|
||||||
|
*/
|
||||||
|
function listenerCount(type) {
|
||||||
|
const events = this._events;
|
||||||
|
|
||||||
|
if (events !== undefined) {
|
||||||
|
const evlistener = events[type];
|
||||||
|
|
||||||
|
if (typeof evlistener === 'function') {
|
||||||
|
return 1;
|
||||||
|
} else if (evlistener !== undefined) {
|
||||||
|
return evlistener.length;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Returns an array listing the events for which
|
||||||
|
* the emitter has registered listeners.
|
||||||
|
* @returns {any[]}
|
||||||
|
*/
|
||||||
|
EventEmitter.prototype.eventNames = function eventNames() {
|
||||||
|
return this._eventsCount > 0 ? ReflectOwnKeys(this._events) : [];
|
||||||
|
};
|
||||||
|
|
||||||
|
function arrayClone(arr) {
|
||||||
|
// At least since V8 8.3, this implementation is faster than the previous
|
||||||
|
// which always used a simple for-loop
|
||||||
|
switch (arr.length) {
|
||||||
|
case 2: return [arr[0], arr[1]];
|
||||||
|
case 3: return [arr[0], arr[1], arr[2]];
|
||||||
|
case 4: return [arr[0], arr[1], arr[2], arr[3]];
|
||||||
|
case 5: return [arr[0], arr[1], arr[2], arr[3], arr[4]];
|
||||||
|
case 6: return [arr[0], arr[1], arr[2], arr[3], arr[4], arr[5]];
|
||||||
|
}
|
||||||
|
return ArrayPrototypeSlice(arr);
|
||||||
|
}
|
||||||
|
|
||||||
|
function unwrapListeners(arr) {
|
||||||
|
const ret = arrayClone(arr);
|
||||||
|
for (let i = 0; i < ret.length; ++i) {
|
||||||
|
const orig = ret[i].listener;
|
||||||
|
if (typeof orig === 'function')
|
||||||
|
ret[i] = orig;
|
||||||
|
}
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/***/ })
|
||||||
|
|
||||||
|
/******/ });
|
||||||
|
/************************************************************************/
|
||||||
|
/******/ // The module cache
|
||||||
|
/******/ var __webpack_module_cache__ = {};
|
||||||
|
/******/
|
||||||
|
/******/ // The require function
|
||||||
|
/******/ function __nccwpck_require__(moduleId) {
|
||||||
|
/******/ // Check if module is in cache
|
||||||
|
/******/ var cachedModule = __webpack_module_cache__[moduleId];
|
||||||
|
/******/ if (cachedModule !== undefined) {
|
||||||
|
/******/ return cachedModule.exports;
|
||||||
|
/******/ }
|
||||||
|
/******/ // Create a new module (and put it into the cache)
|
||||||
|
/******/ var module = __webpack_module_cache__[moduleId] = {
|
||||||
|
/******/ // no module.id needed
|
||||||
|
/******/ // no module.loaded needed
|
||||||
|
/******/ exports: {}
|
||||||
|
/******/ };
|
||||||
|
/******/
|
||||||
|
/******/ // Execute the module function
|
||||||
|
/******/ var threw = true;
|
||||||
|
/******/ try {
|
||||||
|
/******/ __webpack_modules__[moduleId](module, module.exports, __nccwpck_require__);
|
||||||
|
/******/ threw = false;
|
||||||
|
/******/ } finally {
|
||||||
|
/******/ if(threw) delete __webpack_module_cache__[moduleId];
|
||||||
|
/******/ }
|
||||||
|
/******/
|
||||||
|
/******/ // Return the exports of the module
|
||||||
|
/******/ return module.exports;
|
||||||
|
/******/ }
|
||||||
|
/******/
|
||||||
|
/************************************************************************/
|
||||||
|
/******/ /* webpack/runtime/compat */
|
||||||
|
/******/
|
||||||
|
/******/ if (typeof __nccwpck_require__ !== 'undefined') __nccwpck_require__.ab = __dirname + "/";/************************************************************************/
|
||||||
|
/******/
|
||||||
|
/******/ // startup
|
||||||
|
/******/ // Load entry module and return exports
|
||||||
|
/******/ // This entry module is referenced by other modules so it can't be inlined
|
||||||
|
/******/ var __webpack_exports__ = __nccwpck_require__(906);
|
||||||
|
/******/ module.exports = __webpack_exports__;
|
||||||
|
/******/
|
||||||
|
/******/ })()
|
||||||
|
;
|
||||||
85251
dist/index.js
generated
vendored
85251
dist/index.js
generated
vendored
File diff suppressed because one or more lines are too long
473
dist/setup-node-sandbox.js
generated
vendored
Normal file
473
dist/setup-node-sandbox.js
generated
vendored
Normal file
@@ -0,0 +1,473 @@
|
|||||||
|
/******/ (() => { // webpackBootstrap
|
||||||
|
/******/ "use strict";
|
||||||
|
/******/ /* webpack/runtime/compat */
|
||||||
|
/******/
|
||||||
|
/******/ if (typeof __nccwpck_require__ !== 'undefined') __nccwpck_require__.ab = __dirname + "/";/************************************************************************/
|
||||||
|
var __webpack_exports__ = {};
|
||||||
|
/* global host, data, VMError */
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
const LocalError = Error;
|
||||||
|
const LocalTypeError = TypeError;
|
||||||
|
const LocalWeakMap = WeakMap;
|
||||||
|
|
||||||
|
const {
|
||||||
|
apply: localReflectApply,
|
||||||
|
defineProperty: localReflectDefineProperty
|
||||||
|
} = Reflect;
|
||||||
|
|
||||||
|
const {
|
||||||
|
set: localWeakMapSet,
|
||||||
|
get: localWeakMapGet
|
||||||
|
} = LocalWeakMap.prototype;
|
||||||
|
|
||||||
|
const {
|
||||||
|
isArray: localArrayIsArray
|
||||||
|
} = Array;
|
||||||
|
|
||||||
|
function uncurryThis(func) {
|
||||||
|
return (thiz, ...args) => localReflectApply(func, thiz, args);
|
||||||
|
}
|
||||||
|
|
||||||
|
const localArrayPrototypeSlice = uncurryThis(Array.prototype.slice);
|
||||||
|
const localArrayPrototypeIncludes = uncurryThis(Array.prototype.includes);
|
||||||
|
const localArrayPrototypePush = uncurryThis(Array.prototype.push);
|
||||||
|
const localArrayPrototypeIndexOf = uncurryThis(Array.prototype.indexOf);
|
||||||
|
const localArrayPrototypeSplice = uncurryThis(Array.prototype.splice);
|
||||||
|
const localStringPrototypeStartsWith = uncurryThis(String.prototype.startsWith);
|
||||||
|
const localStringPrototypeSlice = uncurryThis(String.prototype.slice);
|
||||||
|
const localStringPrototypeIndexOf = uncurryThis(String.prototype.indexOf);
|
||||||
|
|
||||||
|
const {
|
||||||
|
argv: optionArgv,
|
||||||
|
env: optionEnv,
|
||||||
|
console: optionConsole,
|
||||||
|
vm,
|
||||||
|
resolver,
|
||||||
|
extensions
|
||||||
|
} = data;
|
||||||
|
|
||||||
|
function ensureSandboxArray(a) {
|
||||||
|
return localArrayPrototypeSlice(a);
|
||||||
|
}
|
||||||
|
|
||||||
|
const globalPaths = ensureSandboxArray(resolver.globalPaths);
|
||||||
|
|
||||||
|
class Module {
|
||||||
|
|
||||||
|
constructor(id, path, parent) {
|
||||||
|
this.id = id;
|
||||||
|
this.filename = id;
|
||||||
|
this.path = path;
|
||||||
|
this.parent = parent;
|
||||||
|
this.loaded = false;
|
||||||
|
this.paths = path ? ensureSandboxArray(resolver.genLookupPaths(path)) : [];
|
||||||
|
this.children = [];
|
||||||
|
this.exports = {};
|
||||||
|
}
|
||||||
|
|
||||||
|
_updateChildren(child, isNew) {
|
||||||
|
const children = this.children;
|
||||||
|
if (children && (isNew || !localArrayPrototypeIncludes(children, child))) {
|
||||||
|
localArrayPrototypePush(children, child);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
require(id) {
|
||||||
|
return requireImpl(this, id, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
const originalRequire = Module.prototype.require;
|
||||||
|
const cacheBuiltins = {__proto__: null};
|
||||||
|
|
||||||
|
function requireImpl(mod, id, direct) {
|
||||||
|
if (direct && mod.require !== originalRequire) {
|
||||||
|
return mod.require(id);
|
||||||
|
}
|
||||||
|
const filename = resolver.resolve(mod, id, undefined, Module._extensions, direct);
|
||||||
|
if (localStringPrototypeStartsWith(filename, 'node:')) {
|
||||||
|
id = localStringPrototypeSlice(filename, 5);
|
||||||
|
let nmod = cacheBuiltins[id];
|
||||||
|
if (!nmod) {
|
||||||
|
nmod = resolver.loadBuiltinModule(vm, id);
|
||||||
|
if (!nmod) throw new VMError(`Cannot find module '${filename}'`, 'ENOTFOUND');
|
||||||
|
cacheBuiltins[id] = nmod;
|
||||||
|
}
|
||||||
|
return nmod;
|
||||||
|
}
|
||||||
|
|
||||||
|
const cachedModule = Module._cache[filename];
|
||||||
|
if (cachedModule !== undefined) {
|
||||||
|
mod._updateChildren(cachedModule, false);
|
||||||
|
return cachedModule.exports;
|
||||||
|
}
|
||||||
|
|
||||||
|
let nmod = cacheBuiltins[id];
|
||||||
|
if (nmod) return nmod;
|
||||||
|
nmod = resolver.loadBuiltinModule(vm, id);
|
||||||
|
if (nmod) {
|
||||||
|
cacheBuiltins[id] = nmod;
|
||||||
|
return nmod;
|
||||||
|
}
|
||||||
|
|
||||||
|
const path = resolver.pathDirname(filename);
|
||||||
|
const module = new Module(filename, path, mod);
|
||||||
|
resolver.registerModule(module, filename, path, mod, direct);
|
||||||
|
mod._updateChildren(module, true);
|
||||||
|
try {
|
||||||
|
Module._cache[filename] = module;
|
||||||
|
const handler = findBestExtensionHandler(filename);
|
||||||
|
handler(module, filename);
|
||||||
|
module.loaded = true;
|
||||||
|
} catch (e) {
|
||||||
|
delete Module._cache[filename];
|
||||||
|
const children = mod.children;
|
||||||
|
if (localArrayIsArray(children)) {
|
||||||
|
const index = localArrayPrototypeIndexOf(children, module);
|
||||||
|
if (index !== -1) {
|
||||||
|
localArrayPrototypeSplice(children, index, 1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
throw e;
|
||||||
|
}
|
||||||
|
|
||||||
|
return module.exports;
|
||||||
|
}
|
||||||
|
|
||||||
|
Module.builtinModules = ensureSandboxArray(resolver.getBuiltinModulesList());
|
||||||
|
Module.globalPaths = globalPaths;
|
||||||
|
Module._extensions = {__proto__: null};
|
||||||
|
Module._cache = {__proto__: null};
|
||||||
|
|
||||||
|
{
|
||||||
|
const keys = Object.getOwnPropertyNames(extensions);
|
||||||
|
for (let i = 0; i < keys.length; i++) {
|
||||||
|
const key = keys[i];
|
||||||
|
const handler = extensions[key];
|
||||||
|
Module._extensions[key] = (mod, filename) => handler(mod, filename);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function findBestExtensionHandler(filename) {
|
||||||
|
const name = resolver.pathBasename(filename);
|
||||||
|
for (let i = 0; (i = localStringPrototypeIndexOf(name, '.', i + 1)) !== -1;) {
|
||||||
|
const ext = localStringPrototypeSlice(name, i + 1);
|
||||||
|
const handler = Module._extensions[ext];
|
||||||
|
if (handler) return handler;
|
||||||
|
}
|
||||||
|
const js = Module._extensions['.js'];
|
||||||
|
if (js) return js;
|
||||||
|
const keys = Object.getOwnPropertyNames(Module._extensions);
|
||||||
|
if (keys.length === 0) throw new VMError(`Failed to load '${filename}': Unknown type.`, 'ELOADFAIL');
|
||||||
|
return Module._extensions[keys[0]];
|
||||||
|
}
|
||||||
|
|
||||||
|
function createRequireForModule(mod) {
|
||||||
|
// eslint-disable-next-line no-shadow
|
||||||
|
function require(id) {
|
||||||
|
return requireImpl(mod, id, true);
|
||||||
|
}
|
||||||
|
function resolve(id, options) {
|
||||||
|
return resolver.resolve(mod, id, options, Module._extensions, true);
|
||||||
|
}
|
||||||
|
require.resolve = resolve;
|
||||||
|
function paths(id) {
|
||||||
|
return ensureSandboxArray(resolver.lookupPaths(mod, id));
|
||||||
|
}
|
||||||
|
resolve.paths = paths;
|
||||||
|
|
||||||
|
require.extensions = Module._extensions;
|
||||||
|
|
||||||
|
require.cache = Module._cache;
|
||||||
|
|
||||||
|
return require;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Prepare sandbox.
|
||||||
|
*/
|
||||||
|
|
||||||
|
const TIMERS = new LocalWeakMap();
|
||||||
|
|
||||||
|
class Timeout {
|
||||||
|
}
|
||||||
|
|
||||||
|
class Interval {
|
||||||
|
}
|
||||||
|
|
||||||
|
class Immediate {
|
||||||
|
}
|
||||||
|
|
||||||
|
function clearTimer(timer) {
|
||||||
|
const obj = localReflectApply(localWeakMapGet, TIMERS, [timer]);
|
||||||
|
if (obj) {
|
||||||
|
obj.clear(obj.value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// This is a function and not an arrow function, since the original is also a function
|
||||||
|
// eslint-disable-next-line no-shadow
|
||||||
|
global.setTimeout = function setTimeout(callback, delay, ...args) {
|
||||||
|
if (typeof callback !== 'function') throw new LocalTypeError('"callback" argument must be a function');
|
||||||
|
const obj = new Timeout(callback, args);
|
||||||
|
const cb = () => {
|
||||||
|
localReflectApply(callback, null, args);
|
||||||
|
};
|
||||||
|
const tmr = host.setTimeout(cb, delay);
|
||||||
|
|
||||||
|
const ref = {
|
||||||
|
__proto__: null,
|
||||||
|
clear: host.clearTimeout,
|
||||||
|
value: tmr
|
||||||
|
};
|
||||||
|
|
||||||
|
localReflectApply(localWeakMapSet, TIMERS, [obj, ref]);
|
||||||
|
return obj;
|
||||||
|
};
|
||||||
|
|
||||||
|
// eslint-disable-next-line no-shadow
|
||||||
|
global.setInterval = function setInterval(callback, interval, ...args) {
|
||||||
|
if (typeof callback !== 'function') throw new LocalTypeError('"callback" argument must be a function');
|
||||||
|
const obj = new Interval();
|
||||||
|
const cb = () => {
|
||||||
|
localReflectApply(callback, null, args);
|
||||||
|
};
|
||||||
|
const tmr = host.setInterval(cb, interval);
|
||||||
|
|
||||||
|
const ref = {
|
||||||
|
__proto__: null,
|
||||||
|
clear: host.clearInterval,
|
||||||
|
value: tmr
|
||||||
|
};
|
||||||
|
|
||||||
|
localReflectApply(localWeakMapSet, TIMERS, [obj, ref]);
|
||||||
|
return obj;
|
||||||
|
};
|
||||||
|
|
||||||
|
// eslint-disable-next-line no-shadow
|
||||||
|
global.setImmediate = function setImmediate(callback, ...args) {
|
||||||
|
if (typeof callback !== 'function') throw new LocalTypeError('"callback" argument must be a function');
|
||||||
|
const obj = new Immediate();
|
||||||
|
const cb = () => {
|
||||||
|
localReflectApply(callback, null, args);
|
||||||
|
};
|
||||||
|
const tmr = host.setImmediate(cb);
|
||||||
|
|
||||||
|
const ref = {
|
||||||
|
__proto__: null,
|
||||||
|
clear: host.clearImmediate,
|
||||||
|
value: tmr
|
||||||
|
};
|
||||||
|
|
||||||
|
localReflectApply(localWeakMapSet, TIMERS, [obj, ref]);
|
||||||
|
return obj;
|
||||||
|
};
|
||||||
|
|
||||||
|
// eslint-disable-next-line no-shadow
|
||||||
|
global.clearTimeout = function clearTimeout(timeout) {
|
||||||
|
clearTimer(timeout);
|
||||||
|
};
|
||||||
|
|
||||||
|
// eslint-disable-next-line no-shadow
|
||||||
|
global.clearInterval = function clearInterval(interval) {
|
||||||
|
clearTimer(interval);
|
||||||
|
};
|
||||||
|
|
||||||
|
// eslint-disable-next-line no-shadow
|
||||||
|
global.clearImmediate = function clearImmediate(immediate) {
|
||||||
|
clearTimer(immediate);
|
||||||
|
};
|
||||||
|
|
||||||
|
const localProcess = host.process;
|
||||||
|
|
||||||
|
function vmEmitArgs(event, args) {
|
||||||
|
const allargs = [event];
|
||||||
|
for (let i = 0; i < args.length; i++) {
|
||||||
|
if (!localReflectDefineProperty(allargs, i + 1, {
|
||||||
|
__proto__: null,
|
||||||
|
value: args[i],
|
||||||
|
writable: true,
|
||||||
|
enumerable: true,
|
||||||
|
configurable: true
|
||||||
|
})) throw new LocalError('Unexpected');
|
||||||
|
}
|
||||||
|
return localReflectApply(vm.emit, vm, allargs);
|
||||||
|
}
|
||||||
|
|
||||||
|
const LISTENERS = new LocalWeakMap();
|
||||||
|
const LISTENER_HANDLER = new LocalWeakMap();
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param {*} name
|
||||||
|
* @param {*} handler
|
||||||
|
* @this process
|
||||||
|
* @return {this}
|
||||||
|
*/
|
||||||
|
function addListener(name, handler) {
|
||||||
|
if (name !== 'beforeExit' && name !== 'exit') {
|
||||||
|
throw new LocalError(`Access denied to listen for '${name}' event.`);
|
||||||
|
}
|
||||||
|
|
||||||
|
let cb = localReflectApply(localWeakMapGet, LISTENERS, [handler]);
|
||||||
|
if (!cb) {
|
||||||
|
cb = () => {
|
||||||
|
handler();
|
||||||
|
};
|
||||||
|
localReflectApply(localWeakMapSet, LISTENER_HANDLER, [cb, handler]);
|
||||||
|
localReflectApply(localWeakMapSet, LISTENERS, [handler, cb]);
|
||||||
|
}
|
||||||
|
|
||||||
|
localProcess.on(name, cb);
|
||||||
|
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @this process
|
||||||
|
* @return {this}
|
||||||
|
*/
|
||||||
|
// eslint-disable-next-line no-shadow
|
||||||
|
function process() {
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
// FIXME wrong class structure
|
||||||
|
global.process = {
|
||||||
|
__proto__: process.prototype,
|
||||||
|
argv: optionArgv !== undefined ? optionArgv : [],
|
||||||
|
title: localProcess.title,
|
||||||
|
version: localProcess.version,
|
||||||
|
versions: localProcess.versions,
|
||||||
|
arch: localProcess.arch,
|
||||||
|
platform: localProcess.platform,
|
||||||
|
env: optionEnv !== undefined ? optionEnv : {},
|
||||||
|
pid: localProcess.pid,
|
||||||
|
features: localProcess.features,
|
||||||
|
nextTick: function nextTick(callback, ...args) {
|
||||||
|
if (typeof callback !== 'function') {
|
||||||
|
throw new LocalError('Callback must be a function.');
|
||||||
|
}
|
||||||
|
|
||||||
|
localProcess.nextTick(()=>{
|
||||||
|
localReflectApply(callback, null, args);
|
||||||
|
});
|
||||||
|
},
|
||||||
|
hrtime: function hrtime(time) {
|
||||||
|
return localProcess.hrtime(time);
|
||||||
|
},
|
||||||
|
cwd: function cwd() {
|
||||||
|
return localProcess.cwd();
|
||||||
|
},
|
||||||
|
addListener,
|
||||||
|
on: addListener,
|
||||||
|
|
||||||
|
once: function once(name, handler) {
|
||||||
|
if (name !== 'beforeExit' && name !== 'exit') {
|
||||||
|
throw new LocalError(`Access denied to listen for '${name}' event.`);
|
||||||
|
}
|
||||||
|
|
||||||
|
let triggered = false;
|
||||||
|
const cb = () => {
|
||||||
|
if (triggered) return;
|
||||||
|
triggered = true;
|
||||||
|
localProcess.removeListener(name, cb);
|
||||||
|
handler();
|
||||||
|
};
|
||||||
|
localReflectApply(localWeakMapSet, LISTENER_HANDLER, [cb, handler]);
|
||||||
|
|
||||||
|
localProcess.on(name, cb);
|
||||||
|
|
||||||
|
return this;
|
||||||
|
},
|
||||||
|
|
||||||
|
listeners: function listeners(name) {
|
||||||
|
if (name !== 'beforeExit' && name !== 'exit') {
|
||||||
|
// Maybe add ({__proto__:null})[name] to throw when name fails in https://tc39.es/ecma262/#sec-topropertykey.
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
|
||||||
|
// Filter out listeners, which were not created in this sandbox
|
||||||
|
const all = localProcess.listeners(name);
|
||||||
|
const filtered = [];
|
||||||
|
let j = 0;
|
||||||
|
for (let i = 0; i < all.length; i++) {
|
||||||
|
const h = localReflectApply(localWeakMapGet, LISTENER_HANDLER, [all[i]]);
|
||||||
|
if (h) {
|
||||||
|
if (!localReflectDefineProperty(filtered, j, {
|
||||||
|
__proto__: null,
|
||||||
|
value: h,
|
||||||
|
writable: true,
|
||||||
|
enumerable: true,
|
||||||
|
configurable: true
|
||||||
|
})) throw new LocalError('Unexpected');
|
||||||
|
j++;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return filtered;
|
||||||
|
},
|
||||||
|
|
||||||
|
removeListener: function removeListener(name, handler) {
|
||||||
|
if (name !== 'beforeExit' && name !== 'exit') {
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
const cb = localReflectApply(localWeakMapGet, LISTENERS, [handler]);
|
||||||
|
if (cb) localProcess.removeListener(name, cb);
|
||||||
|
|
||||||
|
return this;
|
||||||
|
},
|
||||||
|
|
||||||
|
umask: function umask() {
|
||||||
|
if (arguments.length) {
|
||||||
|
throw new LocalError('Access denied to set umask.');
|
||||||
|
}
|
||||||
|
|
||||||
|
return localProcess.umask();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
if (optionConsole === 'inherit') {
|
||||||
|
global.console = host.console;
|
||||||
|
} else if (optionConsole === 'redirect') {
|
||||||
|
global.console = {
|
||||||
|
debug(...args) {
|
||||||
|
vmEmitArgs('console.debug', args);
|
||||||
|
},
|
||||||
|
log(...args) {
|
||||||
|
vmEmitArgs('console.log', args);
|
||||||
|
},
|
||||||
|
info(...args) {
|
||||||
|
vmEmitArgs('console.info', args);
|
||||||
|
},
|
||||||
|
warn(...args) {
|
||||||
|
vmEmitArgs('console.warn', args);
|
||||||
|
},
|
||||||
|
error(...args) {
|
||||||
|
vmEmitArgs('console.error', args);
|
||||||
|
},
|
||||||
|
dir(...args) {
|
||||||
|
vmEmitArgs('console.dir', args);
|
||||||
|
},
|
||||||
|
time() {},
|
||||||
|
timeEnd() {},
|
||||||
|
trace(...args) {
|
||||||
|
vmEmitArgs('console.trace', args);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
return {
|
||||||
|
__proto__: null,
|
||||||
|
Module,
|
||||||
|
jsonParse: JSON.parse,
|
||||||
|
createRequireForModule
|
||||||
|
};
|
||||||
|
|
||||||
|
module.exports = __webpack_exports__;
|
||||||
|
/******/ })()
|
||||||
|
;
|
||||||
462
dist/setup-sandbox.js
generated
vendored
Normal file
462
dist/setup-sandbox.js
generated
vendored
Normal file
@@ -0,0 +1,462 @@
|
|||||||
|
/******/ (() => { // webpackBootstrap
|
||||||
|
/******/ "use strict";
|
||||||
|
/******/ /* webpack/runtime/compat */
|
||||||
|
/******/
|
||||||
|
/******/ if (typeof __nccwpck_require__ !== 'undefined') __nccwpck_require__.ab = __dirname + "/";/************************************************************************/
|
||||||
|
var __webpack_exports__ = {};
|
||||||
|
/* global host, bridge, data, context */
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
const {
|
||||||
|
Object: localObject,
|
||||||
|
Array: localArray,
|
||||||
|
Error: LocalError,
|
||||||
|
Reflect: localReflect,
|
||||||
|
Proxy: LocalProxy,
|
||||||
|
WeakMap: LocalWeakMap,
|
||||||
|
Function: localFunction,
|
||||||
|
Promise: localPromise,
|
||||||
|
eval: localEval
|
||||||
|
} = global;
|
||||||
|
|
||||||
|
const {
|
||||||
|
freeze: localObjectFreeze
|
||||||
|
} = localObject;
|
||||||
|
|
||||||
|
const {
|
||||||
|
getPrototypeOf: localReflectGetPrototypeOf,
|
||||||
|
apply: localReflectApply,
|
||||||
|
deleteProperty: localReflectDeleteProperty,
|
||||||
|
has: localReflectHas,
|
||||||
|
defineProperty: localReflectDefineProperty,
|
||||||
|
setPrototypeOf: localReflectSetPrototypeOf,
|
||||||
|
getOwnPropertyDescriptor: localReflectGetOwnPropertyDescriptor
|
||||||
|
} = localReflect;
|
||||||
|
|
||||||
|
const {
|
||||||
|
isArray: localArrayIsArray
|
||||||
|
} = localArray;
|
||||||
|
|
||||||
|
const {
|
||||||
|
ensureThis,
|
||||||
|
ReadOnlyHandler,
|
||||||
|
from,
|
||||||
|
fromWithFactory,
|
||||||
|
readonlyFactory,
|
||||||
|
connect,
|
||||||
|
addProtoMapping,
|
||||||
|
VMError,
|
||||||
|
ReadOnlyMockHandler
|
||||||
|
} = bridge;
|
||||||
|
|
||||||
|
const {
|
||||||
|
allowAsync,
|
||||||
|
GeneratorFunction,
|
||||||
|
AsyncFunction,
|
||||||
|
AsyncGeneratorFunction
|
||||||
|
} = data;
|
||||||
|
|
||||||
|
const localWeakMapGet = LocalWeakMap.prototype.get;
|
||||||
|
|
||||||
|
function localUnexpected() {
|
||||||
|
return new VMError('Should not happen');
|
||||||
|
}
|
||||||
|
|
||||||
|
// global is originally prototype of host.Object so it can be used to climb up from the sandbox.
|
||||||
|
if (!localReflectSetPrototypeOf(context, localObject.prototype)) throw localUnexpected();
|
||||||
|
|
||||||
|
Object.defineProperties(global, {
|
||||||
|
global: {value: global, writable: true, configurable: true, enumerable: true},
|
||||||
|
globalThis: {value: global, writable: true, configurable: true},
|
||||||
|
GLOBAL: {value: global, writable: true, configurable: true},
|
||||||
|
root: {value: global, writable: true, configurable: true}
|
||||||
|
});
|
||||||
|
|
||||||
|
if (!localReflectDefineProperty(global, 'VMError', {
|
||||||
|
__proto__: null,
|
||||||
|
value: VMError,
|
||||||
|
writable: true,
|
||||||
|
enumerable: false,
|
||||||
|
configurable: true
|
||||||
|
})) throw localUnexpected();
|
||||||
|
|
||||||
|
// Fixes buffer unsafe allocation
|
||||||
|
/* eslint-disable no-use-before-define */
|
||||||
|
class BufferHandler extends ReadOnlyHandler {
|
||||||
|
|
||||||
|
apply(target, thiz, args) {
|
||||||
|
if (args.length > 0 && typeof args[0] === 'number') {
|
||||||
|
return LocalBuffer.alloc(args[0]);
|
||||||
|
}
|
||||||
|
return localReflectApply(LocalBuffer.from, LocalBuffer, args);
|
||||||
|
}
|
||||||
|
|
||||||
|
construct(target, args, newTarget) {
|
||||||
|
if (args.length > 0 && typeof args[0] === 'number') {
|
||||||
|
return LocalBuffer.alloc(args[0]);
|
||||||
|
}
|
||||||
|
return localReflectApply(LocalBuffer.from, LocalBuffer, args);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
/* eslint-enable no-use-before-define */
|
||||||
|
|
||||||
|
const LocalBuffer = fromWithFactory(obj => new BufferHandler(obj), host.Buffer);
|
||||||
|
|
||||||
|
|
||||||
|
if (!localReflectDefineProperty(global, 'Buffer', {
|
||||||
|
__proto__: null,
|
||||||
|
value: LocalBuffer,
|
||||||
|
writable: true,
|
||||||
|
enumerable: false,
|
||||||
|
configurable: true
|
||||||
|
})) throw localUnexpected();
|
||||||
|
|
||||||
|
addProtoMapping(LocalBuffer.prototype, host.Buffer.prototype, 'Uint8Array');
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param {*} size Size of new buffer
|
||||||
|
* @this LocalBuffer
|
||||||
|
* @return {LocalBuffer}
|
||||||
|
*/
|
||||||
|
function allocUnsafe(size) {
|
||||||
|
return LocalBuffer.alloc(size);
|
||||||
|
}
|
||||||
|
|
||||||
|
connect(allocUnsafe, host.Buffer.allocUnsafe);
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param {*} size Size of new buffer
|
||||||
|
* @this LocalBuffer
|
||||||
|
* @return {LocalBuffer}
|
||||||
|
*/
|
||||||
|
function allocUnsafeSlow(size) {
|
||||||
|
return LocalBuffer.alloc(size);
|
||||||
|
}
|
||||||
|
|
||||||
|
connect(allocUnsafeSlow, host.Buffer.allocUnsafeSlow);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Replacement for Buffer inspect
|
||||||
|
*
|
||||||
|
* @param {*} recurseTimes
|
||||||
|
* @param {*} ctx
|
||||||
|
* @this LocalBuffer
|
||||||
|
* @return {string}
|
||||||
|
*/
|
||||||
|
function inspect(recurseTimes, ctx) {
|
||||||
|
// Mimic old behavior, could throw but didn't pass a test.
|
||||||
|
const max = host.INSPECT_MAX_BYTES;
|
||||||
|
const actualMax = Math.min(max, this.length);
|
||||||
|
const remaining = this.length - max;
|
||||||
|
let str = this.hexSlice(0, actualMax).replace(/(.{2})/g, '$1 ').trim();
|
||||||
|
if (remaining > 0) str += ` ... ${remaining} more byte${remaining > 1 ? 's' : ''}`;
|
||||||
|
return `<${this.constructor.name} ${str}>`;
|
||||||
|
}
|
||||||
|
|
||||||
|
connect(inspect, host.Buffer.prototype.inspect);
|
||||||
|
|
||||||
|
connect(localFunction.prototype.bind, host.Function.prototype.bind);
|
||||||
|
|
||||||
|
connect(localObject.prototype.__defineGetter__, host.Object.prototype.__defineGetter__);
|
||||||
|
connect(localObject.prototype.__defineSetter__, host.Object.prototype.__defineSetter__);
|
||||||
|
connect(localObject.prototype.__lookupGetter__, host.Object.prototype.__lookupGetter__);
|
||||||
|
connect(localObject.prototype.__lookupSetter__, host.Object.prototype.__lookupSetter__);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* PrepareStackTrace sanitization
|
||||||
|
*/
|
||||||
|
|
||||||
|
const oldPrepareStackTraceDesc = localReflectGetOwnPropertyDescriptor(LocalError, 'prepareStackTrace');
|
||||||
|
|
||||||
|
let currentPrepareStackTrace = LocalError.prepareStackTrace;
|
||||||
|
const wrappedPrepareStackTrace = new LocalWeakMap();
|
||||||
|
if (typeof currentPrepareStackTrace === 'function') {
|
||||||
|
wrappedPrepareStackTrace.set(currentPrepareStackTrace, currentPrepareStackTrace);
|
||||||
|
}
|
||||||
|
|
||||||
|
let OriginalCallSite;
|
||||||
|
LocalError.prepareStackTrace = (e, sst) => {
|
||||||
|
OriginalCallSite = sst[0].constructor;
|
||||||
|
};
|
||||||
|
new LocalError().stack;
|
||||||
|
if (typeof OriginalCallSite === 'function') {
|
||||||
|
LocalError.prepareStackTrace = undefined;
|
||||||
|
|
||||||
|
function makeCallSiteGetters(list) {
|
||||||
|
const callSiteGetters = [];
|
||||||
|
for (let i=0; i<list.length; i++) {
|
||||||
|
const name = list[i];
|
||||||
|
const func = OriginalCallSite.prototype[name];
|
||||||
|
callSiteGetters[i] = {__proto__: null,
|
||||||
|
name,
|
||||||
|
propName: '_' + name,
|
||||||
|
func: (thiz) => {
|
||||||
|
return localReflectApply(func, thiz, []);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}
|
||||||
|
return callSiteGetters;
|
||||||
|
}
|
||||||
|
|
||||||
|
function applyCallSiteGetters(thiz, callSite, getters) {
|
||||||
|
for (let i=0; i<getters.length; i++) {
|
||||||
|
const getter = getters[i];
|
||||||
|
localReflectDefineProperty(thiz, getter.propName, {
|
||||||
|
__proto__: null,
|
||||||
|
value: getter.func(callSite)
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
const callSiteGetters = makeCallSiteGetters([
|
||||||
|
'getTypeName',
|
||||||
|
'getFunctionName',
|
||||||
|
'getMethodName',
|
||||||
|
'getFileName',
|
||||||
|
'getLineNumber',
|
||||||
|
'getColumnNumber',
|
||||||
|
'getEvalOrigin',
|
||||||
|
'isToplevel',
|
||||||
|
'isEval',
|
||||||
|
'isNative',
|
||||||
|
'isConstructor',
|
||||||
|
'isAsync',
|
||||||
|
'isPromiseAll',
|
||||||
|
'getPromiseIndex'
|
||||||
|
]);
|
||||||
|
|
||||||
|
class CallSite {
|
||||||
|
constructor(callSite) {
|
||||||
|
applyCallSiteGetters(this, callSite, callSiteGetters);
|
||||||
|
}
|
||||||
|
getThis() {
|
||||||
|
return undefined;
|
||||||
|
}
|
||||||
|
getFunction() {
|
||||||
|
return undefined;
|
||||||
|
}
|
||||||
|
toString() {
|
||||||
|
return 'CallSite {}';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
for (let i=0; i<callSiteGetters.length; i++) {
|
||||||
|
const name = callSiteGetters[i].name;
|
||||||
|
const funcProp = localReflectGetOwnPropertyDescriptor(OriginalCallSite.prototype, name);
|
||||||
|
if (!funcProp) continue;
|
||||||
|
const propertyName = callSiteGetters[i].propName;
|
||||||
|
const func = {func() {
|
||||||
|
return this[propertyName];
|
||||||
|
}}.func;
|
||||||
|
const nameProp = localReflectGetOwnPropertyDescriptor(func, 'name');
|
||||||
|
if (!nameProp) throw localUnexpected();
|
||||||
|
nameProp.value = name;
|
||||||
|
if (!localReflectDefineProperty(func, 'name', nameProp)) throw localUnexpected();
|
||||||
|
funcProp.value = func;
|
||||||
|
if (!localReflectDefineProperty(CallSite.prototype, name, funcProp)) throw localUnexpected();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!localReflectDefineProperty(LocalError, 'prepareStackTrace', {
|
||||||
|
configurable: false,
|
||||||
|
enumerable: false,
|
||||||
|
get() {
|
||||||
|
return currentPrepareStackTrace;
|
||||||
|
},
|
||||||
|
set(value) {
|
||||||
|
if (typeof(value) !== 'function') {
|
||||||
|
currentPrepareStackTrace = value;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const wrapped = localReflectApply(localWeakMapGet, wrappedPrepareStackTrace, [value]);
|
||||||
|
if (wrapped) {
|
||||||
|
currentPrepareStackTrace = wrapped;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
const newWrapped = (error, sst) => {
|
||||||
|
if (localArrayIsArray(sst)) {
|
||||||
|
for (let i=0; i < sst.length; i++) {
|
||||||
|
const cs = sst[i];
|
||||||
|
if (typeof cs === 'object' && localReflectGetPrototypeOf(cs) === OriginalCallSite.prototype) {
|
||||||
|
sst[i] = new CallSite(cs);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return value(error, sst);
|
||||||
|
};
|
||||||
|
wrappedPrepareStackTrace.set(value, newWrapped);
|
||||||
|
wrappedPrepareStackTrace.set(newWrapped, newWrapped);
|
||||||
|
currentPrepareStackTrace = newWrapped;
|
||||||
|
}
|
||||||
|
})) throw localUnexpected();
|
||||||
|
} else if (oldPrepareStackTraceDesc) {
|
||||||
|
localReflectDefineProperty(LocalError, 'prepareStackTrace', oldPrepareStackTraceDesc);
|
||||||
|
} else {
|
||||||
|
localReflectDeleteProperty(LocalError, 'prepareStackTrace');
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Exception sanitization
|
||||||
|
*/
|
||||||
|
|
||||||
|
const withProxy = localObjectFreeze({
|
||||||
|
__proto__: null,
|
||||||
|
has(target, key) {
|
||||||
|
if (key === host.INTERNAL_STATE_NAME) return false;
|
||||||
|
return localReflectHas(target, key);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
const interanState = localObjectFreeze({
|
||||||
|
__proto__: null,
|
||||||
|
wrapWith(x) {
|
||||||
|
return new LocalProxy(x, withProxy);
|
||||||
|
},
|
||||||
|
handleException: ensureThis,
|
||||||
|
import(what) {
|
||||||
|
throw new VMError('Dynamic Import not supported');
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
if (!localReflectDefineProperty(global, host.INTERNAL_STATE_NAME, {
|
||||||
|
__proto__: null,
|
||||||
|
configurable: false,
|
||||||
|
enumerable: false,
|
||||||
|
writable: false,
|
||||||
|
value: interanState
|
||||||
|
})) throw localUnexpected();
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Eval sanitization
|
||||||
|
*/
|
||||||
|
|
||||||
|
function throwAsync() {
|
||||||
|
return new VMError('Async not available');
|
||||||
|
}
|
||||||
|
|
||||||
|
function makeFunction(inputArgs, isAsync, isGenerator) {
|
||||||
|
const lastArgs = inputArgs.length - 1;
|
||||||
|
let code = lastArgs >= 0 ? `${inputArgs[lastArgs]}` : '';
|
||||||
|
let args = lastArgs > 0 ? `${inputArgs[0]}` : '';
|
||||||
|
for (let i = 1; i < lastArgs; i++) {
|
||||||
|
args += `,${inputArgs[i]}`;
|
||||||
|
}
|
||||||
|
try {
|
||||||
|
code = host.transformAndCheck(args, code, isAsync, isGenerator, allowAsync);
|
||||||
|
} catch (e) {
|
||||||
|
throw bridge.from(e);
|
||||||
|
}
|
||||||
|
return localEval(code);
|
||||||
|
}
|
||||||
|
|
||||||
|
const FunctionHandler = {
|
||||||
|
__proto__: null,
|
||||||
|
apply(target, thiz, args) {
|
||||||
|
return makeFunction(args, this.isAsync, this.isGenerator);
|
||||||
|
},
|
||||||
|
construct(target, args, newTarget) {
|
||||||
|
return makeFunction(args, this.isAsync, this.isGenerator);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
const EvalHandler = {
|
||||||
|
__proto__: null,
|
||||||
|
apply(target, thiz, args) {
|
||||||
|
if (args.length === 0) return undefined;
|
||||||
|
let code = `${args[0]}`;
|
||||||
|
try {
|
||||||
|
code = host.transformAndCheck(null, code, false, false, allowAsync);
|
||||||
|
} catch (e) {
|
||||||
|
throw bridge.from(e);
|
||||||
|
}
|
||||||
|
return localEval(code);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
const AsyncErrorHandler = {
|
||||||
|
__proto__: null,
|
||||||
|
apply(target, thiz, args) {
|
||||||
|
throw throwAsync();
|
||||||
|
},
|
||||||
|
construct(target, args, newTarget) {
|
||||||
|
throw throwAsync();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
function makeCheckFunction(isAsync, isGenerator) {
|
||||||
|
if (isAsync && !allowAsync) return AsyncErrorHandler;
|
||||||
|
return {
|
||||||
|
__proto__: FunctionHandler,
|
||||||
|
isAsync,
|
||||||
|
isGenerator
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
function overrideWithProxy(obj, prop, value, handler) {
|
||||||
|
const proxy = new LocalProxy(value, handler);
|
||||||
|
if (!localReflectDefineProperty(obj, prop, {__proto__: null, value: proxy})) throw localUnexpected();
|
||||||
|
return proxy;
|
||||||
|
}
|
||||||
|
|
||||||
|
const proxiedFunction = overrideWithProxy(localFunction.prototype, 'constructor', localFunction, makeCheckFunction(false, false));
|
||||||
|
if (GeneratorFunction) {
|
||||||
|
if (!localReflectSetPrototypeOf(GeneratorFunction, proxiedFunction)) throw localUnexpected();
|
||||||
|
overrideWithProxy(GeneratorFunction.prototype, 'constructor', GeneratorFunction, makeCheckFunction(false, true));
|
||||||
|
}
|
||||||
|
if (AsyncFunction) {
|
||||||
|
if (!localReflectSetPrototypeOf(AsyncFunction, proxiedFunction)) throw localUnexpected();
|
||||||
|
overrideWithProxy(AsyncFunction.prototype, 'constructor', AsyncFunction, makeCheckFunction(true, false));
|
||||||
|
}
|
||||||
|
if (AsyncGeneratorFunction) {
|
||||||
|
if (!localReflectSetPrototypeOf(AsyncGeneratorFunction, proxiedFunction)) throw localUnexpected();
|
||||||
|
overrideWithProxy(AsyncGeneratorFunction.prototype, 'constructor', AsyncGeneratorFunction, makeCheckFunction(true, true));
|
||||||
|
}
|
||||||
|
|
||||||
|
global.Function = proxiedFunction;
|
||||||
|
global.eval = new LocalProxy(localEval, EvalHandler);
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Promise sanitization
|
||||||
|
*/
|
||||||
|
|
||||||
|
if (localPromise && !allowAsync) {
|
||||||
|
|
||||||
|
const PromisePrototype = localPromise.prototype;
|
||||||
|
|
||||||
|
overrideWithProxy(PromisePrototype, 'then', PromisePrototype.then, AsyncErrorHandler);
|
||||||
|
// This seems not to work, and will produce
|
||||||
|
// UnhandledPromiseRejectionWarning: TypeError: Method Promise.prototype.then called on incompatible receiver [object Object].
|
||||||
|
// This is likely caused since the host.Promise.prototype.then cannot use the VM Proxy object.
|
||||||
|
// Contextify.connect(host.Promise.prototype.then, Promise.prototype.then);
|
||||||
|
|
||||||
|
if (PromisePrototype.finally) {
|
||||||
|
overrideWithProxy(PromisePrototype, 'finally', PromisePrototype.finally, AsyncErrorHandler);
|
||||||
|
// Contextify.connect(host.Promise.prototype.finally, Promise.prototype.finally);
|
||||||
|
}
|
||||||
|
if (Promise.prototype.catch) {
|
||||||
|
overrideWithProxy(PromisePrototype, 'catch', PromisePrototype.catch, AsyncErrorHandler);
|
||||||
|
// Contextify.connect(host.Promise.prototype.catch, Promise.prototype.catch);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function readonly(other, mock) {
|
||||||
|
// Note: other@other(unsafe) mock@other(unsafe) returns@this(unsafe) throws@this(unsafe)
|
||||||
|
if (!mock) return fromWithFactory(readonlyFactory, other);
|
||||||
|
const tmock = from(mock);
|
||||||
|
return fromWithFactory(obj=>new ReadOnlyMockHandler(obj, tmock), other);
|
||||||
|
}
|
||||||
|
|
||||||
|
return {
|
||||||
|
__proto__: null,
|
||||||
|
readonly,
|
||||||
|
global
|
||||||
|
};
|
||||||
|
|
||||||
|
module.exports = __webpack_exports__;
|
||||||
|
/******/ })()
|
||||||
|
;
|
||||||
70
docker-bake.hcl
Normal file
70
docker-bake.hcl
Normal file
@@ -0,0 +1,70 @@
|
|||||||
|
variable "NODE_VERSION" {
|
||||||
|
default = "12"
|
||||||
|
}
|
||||||
|
|
||||||
|
target "node-version" {
|
||||||
|
args = {
|
||||||
|
NODE_VERSION = NODE_VERSION
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
group "default" {
|
||||||
|
targets = ["build"]
|
||||||
|
}
|
||||||
|
|
||||||
|
group "pre-checkin" {
|
||||||
|
targets = ["vendor-update", "format", "build"]
|
||||||
|
}
|
||||||
|
|
||||||
|
group "validate" {
|
||||||
|
targets = ["format-validate", "build-validate", "vendor-validate"]
|
||||||
|
}
|
||||||
|
|
||||||
|
target "build" {
|
||||||
|
inherits = ["node-version"]
|
||||||
|
dockerfile = "./hack/build.Dockerfile"
|
||||||
|
target = "build-update"
|
||||||
|
output = ["."]
|
||||||
|
}
|
||||||
|
|
||||||
|
target "build-validate" {
|
||||||
|
inherits = ["node-version"]
|
||||||
|
dockerfile = "./hack/build.Dockerfile"
|
||||||
|
target = "build-validate"
|
||||||
|
output = ["type=cacheonly"]
|
||||||
|
}
|
||||||
|
|
||||||
|
target "format" {
|
||||||
|
inherits = ["node-version"]
|
||||||
|
dockerfile = "./hack/build.Dockerfile"
|
||||||
|
target = "format-update"
|
||||||
|
output = ["."]
|
||||||
|
}
|
||||||
|
|
||||||
|
target "format-validate" {
|
||||||
|
inherits = ["node-version"]
|
||||||
|
dockerfile = "./hack/build.Dockerfile"
|
||||||
|
target = "format-validate"
|
||||||
|
output = ["type=cacheonly"]
|
||||||
|
}
|
||||||
|
|
||||||
|
target "vendor-update" {
|
||||||
|
inherits = ["node-version"]
|
||||||
|
dockerfile = "./hack/build.Dockerfile"
|
||||||
|
target = "vendor-update"
|
||||||
|
output = ["."]
|
||||||
|
}
|
||||||
|
|
||||||
|
target "vendor-validate" {
|
||||||
|
inherits = ["node-version"]
|
||||||
|
dockerfile = "./hack/build.Dockerfile"
|
||||||
|
target = "vendor-validate"
|
||||||
|
output = ["type=cacheonly"]
|
||||||
|
}
|
||||||
|
|
||||||
|
target "test" {
|
||||||
|
inherits = ["node-version"]
|
||||||
|
dockerfile = "./hack/build.Dockerfile"
|
||||||
|
target = "test-coverage"
|
||||||
|
output = ["./coverage"]
|
||||||
|
}
|
||||||
78
hack/build.Dockerfile
Normal file
78
hack/build.Dockerfile
Normal file
@@ -0,0 +1,78 @@
|
|||||||
|
# syntax=docker/dockerfile:1.3-labs
|
||||||
|
|
||||||
|
ARG NODE_VERSION
|
||||||
|
ARG DOCKER_VERSION=20.10.10
|
||||||
|
ARG BUILDX_VERSION=0.7.0
|
||||||
|
|
||||||
|
FROM node:${NODE_VERSION}-alpine AS base
|
||||||
|
RUN apk add --no-cache cpio findutils git
|
||||||
|
WORKDIR /src
|
||||||
|
|
||||||
|
FROM base AS deps
|
||||||
|
RUN --mount=type=bind,target=.,rw \
|
||||||
|
--mount=type=cache,target=/src/node_modules \
|
||||||
|
yarn install && mkdir /vendor && cp yarn.lock /vendor
|
||||||
|
|
||||||
|
FROM scratch AS vendor-update
|
||||||
|
COPY --from=deps /vendor /
|
||||||
|
|
||||||
|
FROM deps AS vendor-validate
|
||||||
|
RUN --mount=type=bind,target=.,rw <<EOT
|
||||||
|
set -e
|
||||||
|
git add -A
|
||||||
|
cp -rf /vendor/* .
|
||||||
|
if [ -n "$(git status --porcelain -- yarn.lock)" ]; then
|
||||||
|
echo >&2 'ERROR: Vendor result differs. Please vendor your package with "docker buildx bake vendor-update"'
|
||||||
|
git status --porcelain -- yarn.lock
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
EOT
|
||||||
|
|
||||||
|
FROM deps AS build
|
||||||
|
RUN --mount=type=bind,target=.,rw \
|
||||||
|
--mount=type=cache,target=/src/node_modules \
|
||||||
|
yarn run build && mkdir /out && cp -Rf dist /out/
|
||||||
|
|
||||||
|
FROM scratch AS build-update
|
||||||
|
COPY --from=build /out /
|
||||||
|
|
||||||
|
FROM build AS build-validate
|
||||||
|
RUN --mount=type=bind,target=.,rw <<EOT
|
||||||
|
set -e
|
||||||
|
git add -A
|
||||||
|
cp -rf /out/* .
|
||||||
|
if [ -n "$(git status --porcelain -- dist)" ]; then
|
||||||
|
echo >&2 'ERROR: Build result differs. Please build first with "docker buildx bake build"'
|
||||||
|
git status --porcelain -- dist
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
EOT
|
||||||
|
|
||||||
|
FROM deps AS format
|
||||||
|
RUN --mount=type=bind,target=.,rw \
|
||||||
|
--mount=type=cache,target=/src/node_modules \
|
||||||
|
yarn run format \
|
||||||
|
&& mkdir /out && find . -name '*.ts' -not -path './node_modules/*' | cpio -pdm /out
|
||||||
|
|
||||||
|
FROM scratch AS format-update
|
||||||
|
COPY --from=format /out /
|
||||||
|
|
||||||
|
FROM deps AS format-validate
|
||||||
|
RUN --mount=type=bind,target=.,rw \
|
||||||
|
--mount=type=cache,target=/src/node_modules \
|
||||||
|
yarn run format-check
|
||||||
|
|
||||||
|
FROM docker:${DOCKER_VERSION} as docker
|
||||||
|
FROM docker/buildx-bin:${BUILDX_VERSION} as buildx
|
||||||
|
|
||||||
|
FROM deps AS test
|
||||||
|
ENV RUNNER_TEMP=/tmp/github_runner
|
||||||
|
ENV RUNNER_TOOL_CACHE=/tmp/github_tool_cache
|
||||||
|
RUN --mount=type=bind,target=.,rw \
|
||||||
|
--mount=type=cache,target=/src/node_modules \
|
||||||
|
--mount=type=bind,from=docker,source=/usr/local/bin/docker,target=/usr/bin/docker \
|
||||||
|
--mount=type=bind,from=buildx,source=/buildx,target=/usr/libexec/docker/cli-plugins/docker-buildx \
|
||||||
|
yarn run test --coverageDirectory=/tmp/coverage
|
||||||
|
|
||||||
|
FROM scratch AS test-coverage
|
||||||
|
COPY --from=test /tmp/coverage /
|
||||||
30
package.json
30
package.json
@@ -27,22 +27,24 @@
|
|||||||
],
|
],
|
||||||
"license": "MIT",
|
"license": "MIT",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@actions/core": "^1.2.5",
|
"@actions/core": "^1.6.0",
|
||||||
"@actions/exec": "^1.0.4",
|
"@actions/exec": "^1.1.0",
|
||||||
"@actions/io": "^1.0.2",
|
"@actions/io": "^1.1.1",
|
||||||
"semver": "^7.3.2"
|
"@aws-sdk/client-ecr": "^3.45.0",
|
||||||
|
"@aws-sdk/client-ecr-public": "^3.45.0",
|
||||||
|
"proxy-agent": "^5.0.0"
|
||||||
},
|
},
|
||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@types/jest": "^26.0.3",
|
"@types/jest": "^26.0.23",
|
||||||
"@types/node": "^14.0.14",
|
"@types/node": "^14.17.4",
|
||||||
"@vercel/ncc": "^0.23.0",
|
"@vercel/ncc": "^0.28.6",
|
||||||
"dotenv": "^8.2.0",
|
"dotenv": "^8.6.0",
|
||||||
"jest": "^26.1.0",
|
"jest": "^26.6.3",
|
||||||
"jest-circus": "^26.1.0",
|
"jest-circus": "^26.6.3",
|
||||||
"jest-runtime": "^26.1.0",
|
"jest-runtime": "^26.6.3",
|
||||||
"prettier": "^2.0.5",
|
"prettier": "^2.3.2",
|
||||||
"ts-jest": "^26.1.1",
|
"ts-jest": "^26.5.6",
|
||||||
"typescript": "^3.9.5",
|
"typescript": "^3.9.10",
|
||||||
"typescript-formatter": "^7.2.2"
|
"typescript-formatter": "^7.2.2"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
155
src/aws.ts
155
src/aws.ts
@@ -1,51 +1,132 @@
|
|||||||
import * as semver from 'semver';
|
import * as core from '@actions/core';
|
||||||
import * as io from '@actions/io';
|
import {ECR} from '@aws-sdk/client-ecr';
|
||||||
import * as execm from './exec';
|
import {ECRPUBLIC} from '@aws-sdk/client-ecr-public';
|
||||||
|
import {NodeHttpHandler} from '@aws-sdk/node-http-handler';
|
||||||
|
import ProxyAgent from 'proxy-agent';
|
||||||
|
|
||||||
export const isECR = async (registry: string): Promise<boolean> => {
|
const ecrRegistryRegex = /^(([0-9]{12})\.dkr\.ecr\.(.+)\.amazonaws\.com(.cn)?)(\/([^:]+)(:.+)?)?$/;
|
||||||
return registry.includes('amazonaws');
|
|
||||||
|
export const isECR = (registry: string): boolean => {
|
||||||
|
return ecrRegistryRegex.test(registry) || isPubECR(registry);
|
||||||
};
|
};
|
||||||
|
|
||||||
export const getRegion = async (registry: string): Promise<string> => {
|
export const isPubECR = (registry: string): boolean => {
|
||||||
return registry.substring(registry.indexOf('ecr.') + 4, registry.indexOf('.amazonaws'));
|
return registry === 'public.ecr.aws';
|
||||||
};
|
};
|
||||||
|
|
||||||
export const getCLI = async (): Promise<string> => {
|
export const getRegion = (registry: string): string => {
|
||||||
return io.which('aws', true);
|
if (isPubECR(registry)) {
|
||||||
};
|
return process.env.AWS_REGION || process.env.AWS_DEFAULT_REGION || 'us-east-1';
|
||||||
|
}
|
||||||
export const execCLI = async (args: string[]): Promise<string> => {
|
const matches = registry.match(ecrRegistryRegex);
|
||||||
return execm.exec(await getCLI(), args, true).then(res => {
|
|
||||||
if (res.stderr != '' && !res.success) {
|
|
||||||
throw new Error(res.stderr);
|
|
||||||
} else if (res.stderr != '') {
|
|
||||||
return res.stderr.trim();
|
|
||||||
} else {
|
|
||||||
return res.stdout.trim();
|
|
||||||
}
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
export const getCLIVersion = async (): Promise<string> => {
|
|
||||||
return parseCLIVersion(await execCLI(['--version']));
|
|
||||||
};
|
|
||||||
|
|
||||||
export const parseCLIVersion = async (stdout: string): Promise<string> => {
|
|
||||||
const matches = /aws-cli\/([0-9.]+)/.exec(stdout);
|
|
||||||
if (!matches) {
|
if (!matches) {
|
||||||
throw new Error(`Cannot parse AWS CLI version`);
|
return '';
|
||||||
}
|
}
|
||||||
return semver.clean(matches[1]);
|
return matches[3];
|
||||||
};
|
};
|
||||||
|
|
||||||
export const getDockerLoginCmd = async (cliVersion: string, registry: string, region: string): Promise<string> => {
|
export const getAccountIDs = (registry: string): string[] => {
|
||||||
if (semver.satisfies(cliVersion, '>=2.0.0')) {
|
if (isPubECR(registry)) {
|
||||||
return execCLI(['ecr', 'get-login-password', '--region', region]).then(pwd => {
|
return [];
|
||||||
return `docker login --username AWS --password ${pwd} ${registry}`;
|
}
|
||||||
|
const matches = registry.match(ecrRegistryRegex);
|
||||||
|
if (!matches) {
|
||||||
|
return [];
|
||||||
|
}
|
||||||
|
let accountIDs: Array<string> = [matches[2]];
|
||||||
|
if (process.env.AWS_ACCOUNT_IDS) {
|
||||||
|
accountIDs.push(...process.env.AWS_ACCOUNT_IDS.split(','));
|
||||||
|
}
|
||||||
|
return accountIDs.filter((item, index) => accountIDs.indexOf(item) === index);
|
||||||
|
};
|
||||||
|
|
||||||
|
export interface RegistryData {
|
||||||
|
registry: string;
|
||||||
|
username: string;
|
||||||
|
password: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
export const getRegistriesData = async (registry: string, username?: string, password?: string): Promise<RegistryData[]> => {
|
||||||
|
const region = getRegion(registry);
|
||||||
|
const accountIDs = getAccountIDs(registry);
|
||||||
|
|
||||||
|
const authTokenRequest = {};
|
||||||
|
if (accountIDs.length > 0) {
|
||||||
|
core.debug(`Requesting AWS ECR auth token for ${accountIDs.join(', ')}`);
|
||||||
|
authTokenRequest['registryIds'] = accountIDs;
|
||||||
|
}
|
||||||
|
|
||||||
|
let httpProxyAgent: any = null;
|
||||||
|
const httpProxy = process.env.http_proxy || process.env.HTTP_PROXY || '';
|
||||||
|
if (httpProxy) {
|
||||||
|
core.debug(`Using http proxy ${httpProxy}`);
|
||||||
|
httpProxyAgent = new ProxyAgent(httpProxy);
|
||||||
|
}
|
||||||
|
|
||||||
|
let httpsProxyAgent: any = null;
|
||||||
|
const httpsProxy = process.env.https_proxy || process.env.HTTPS_PROXY || '';
|
||||||
|
if (httpsProxy) {
|
||||||
|
core.debug(`Using https proxy ${httpsProxy}`);
|
||||||
|
httpsProxyAgent = new ProxyAgent(httpsProxy);
|
||||||
|
}
|
||||||
|
|
||||||
|
const credentials =
|
||||||
|
username && password
|
||||||
|
? {
|
||||||
|
accessKeyId: username,
|
||||||
|
secretAccessKey: password
|
||||||
|
}
|
||||||
|
: undefined;
|
||||||
|
|
||||||
|
if (isPubECR(registry)) {
|
||||||
|
core.info(`AWS Public ECR detected with ${region} region`);
|
||||||
|
const ecrPublic = new ECRPUBLIC({
|
||||||
|
customUserAgent: 'docker-login-action',
|
||||||
|
credentials,
|
||||||
|
region: region,
|
||||||
|
requestHandler: new NodeHttpHandler({
|
||||||
|
httpAgent: httpProxyAgent,
|
||||||
|
httpsAgent: httpsProxyAgent
|
||||||
|
})
|
||||||
});
|
});
|
||||||
|
const authTokenResponse = await ecrPublic.getAuthorizationToken(authTokenRequest);
|
||||||
|
if (!authTokenResponse.authorizationData || !authTokenResponse.authorizationData.authorizationToken) {
|
||||||
|
throw new Error('Could not retrieve an authorization token from AWS Public ECR');
|
||||||
|
}
|
||||||
|
const authToken = Buffer.from(authTokenResponse.authorizationData.authorizationToken, 'base64').toString('utf-8');
|
||||||
|
const creds = authToken.split(':', 2);
|
||||||
|
return [
|
||||||
|
{
|
||||||
|
registry: 'public.ecr.aws',
|
||||||
|
username: creds[0],
|
||||||
|
password: creds[1]
|
||||||
|
}
|
||||||
|
];
|
||||||
} else {
|
} else {
|
||||||
return execCLI(['ecr', 'get-login', '--region', region, '--no-include-email']).then(dockerLoginCmd => {
|
core.info(`AWS ECR detected with ${region} region`);
|
||||||
return dockerLoginCmd;
|
const ecr = new ECR({
|
||||||
|
customUserAgent: 'docker-login-action',
|
||||||
|
credentials,
|
||||||
|
region: region,
|
||||||
|
requestHandler: new NodeHttpHandler({
|
||||||
|
httpAgent: httpProxyAgent,
|
||||||
|
httpsAgent: httpsProxyAgent
|
||||||
|
})
|
||||||
});
|
});
|
||||||
|
const authTokenResponse = await ecr.getAuthorizationToken(authTokenRequest);
|
||||||
|
if (!Array.isArray(authTokenResponse.authorizationData) || !authTokenResponse.authorizationData.length) {
|
||||||
|
throw new Error('Could not retrieve an authorization token from AWS ECR');
|
||||||
|
}
|
||||||
|
const regDatas: RegistryData[] = [];
|
||||||
|
for (const authData of authTokenResponse.authorizationData) {
|
||||||
|
const authToken = Buffer.from(authData.authorizationToken || '', 'base64').toString('utf-8');
|
||||||
|
const creds = authToken.split(':', 2);
|
||||||
|
regDatas.push({
|
||||||
|
registry: authData.proxyEndpoint || '',
|
||||||
|
username: creds[0],
|
||||||
|
password: creds[1]
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return regDatas;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -4,14 +4,16 @@ export interface Inputs {
|
|||||||
registry: string;
|
registry: string;
|
||||||
username: string;
|
username: string;
|
||||||
password: string;
|
password: string;
|
||||||
logout: string;
|
ecr: string;
|
||||||
|
logout: boolean;
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function getInputs(): Promise<Inputs> {
|
export function getInputs(): Inputs {
|
||||||
return {
|
return {
|
||||||
registry: core.getInput('registry'),
|
registry: core.getInput('registry'),
|
||||||
username: core.getInput('username'),
|
username: core.getInput('username'),
|
||||||
password: core.getInput('password', {required: true}),
|
password: core.getInput('password'),
|
||||||
logout: core.getInput('logout')
|
ecr: core.getInput('ecr'),
|
||||||
|
logout: core.getBooleanInput('logout')
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
import * as core from '@actions/core';
|
|
||||||
import * as aws from './aws';
|
import * as aws from './aws';
|
||||||
import * as execm from './exec';
|
import * as core from '@actions/core';
|
||||||
|
import * as exec from '@actions/exec';
|
||||||
|
|
||||||
export async function login(registry: string, username: string, password: string): Promise<void> {
|
export async function login(registry: string, username: string, password: string, ecr: string): Promise<void> {
|
||||||
if (await aws.isECR(registry)) {
|
if (/true/i.test(ecr) || (ecr == 'auto' && aws.isECR(registry))) {
|
||||||
await loginECR(registry, username, password);
|
await loginECR(registry, username, password);
|
||||||
} else {
|
} else {
|
||||||
await loginStandard(registry, username, password);
|
await loginStandard(registry, username, password);
|
||||||
@@ -11,50 +11,61 @@ export async function login(registry: string, username: string, password: string
|
|||||||
}
|
}
|
||||||
|
|
||||||
export async function logout(registry: string): Promise<void> {
|
export async function logout(registry: string): Promise<void> {
|
||||||
await execm.exec('docker', ['logout', registry], false).then(res => {
|
await exec
|
||||||
if (res.stderr != '' && !res.success) {
|
.getExecOutput('docker', ['logout', registry], {
|
||||||
core.warning(res.stderr);
|
ignoreReturnCode: true
|
||||||
}
|
})
|
||||||
});
|
.then(res => {
|
||||||
|
if (res.stderr.length > 0 && res.exitCode != 0) {
|
||||||
|
core.warning(res.stderr.trim());
|
||||||
|
}
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function loginStandard(registry: string, username: string, password: string): Promise<void> {
|
export async function loginStandard(registry: string, username: string, password: string): Promise<void> {
|
||||||
let loginArgs: Array<string> = ['login', '--password-stdin'];
|
if (!username || !password) {
|
||||||
if (username) {
|
throw new Error('Username and password required');
|
||||||
loginArgs.push('--username', username);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
let loginArgs: Array<string> = ['login', '--password-stdin'];
|
||||||
|
loginArgs.push('--username', username);
|
||||||
loginArgs.push(registry);
|
loginArgs.push(registry);
|
||||||
|
|
||||||
if (registry) {
|
if (registry) {
|
||||||
core.info(`🔑 Logging into ${registry}...`);
|
core.info(`Logging into ${registry}...`);
|
||||||
} else {
|
} else {
|
||||||
core.info(`🔑 Logging into DockerHub...`);
|
core.info(`Logging into Docker Hub...`);
|
||||||
}
|
}
|
||||||
await execm.exec('docker', loginArgs, true, password).then(res => {
|
await exec
|
||||||
if (res.stderr != '' && !res.success) {
|
.getExecOutput('docker', loginArgs, {
|
||||||
throw new Error(res.stderr);
|
ignoreReturnCode: true,
|
||||||
}
|
silent: true,
|
||||||
core.info('🎉 Login Succeeded!');
|
input: Buffer.from(password)
|
||||||
});
|
})
|
||||||
|
.then(res => {
|
||||||
|
if (res.stderr.length > 0 && res.exitCode != 0) {
|
||||||
|
throw new Error(res.stderr.trim());
|
||||||
|
}
|
||||||
|
core.info(`Login Succeeded!`);
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
export async function loginECR(registry: string, username: string, password: string): Promise<void> {
|
export async function loginECR(registry: string, username: string, password: string): Promise<void> {
|
||||||
const cliPath = await aws.getCLI();
|
core.info(`Retrieving registries data through AWS SDK...`);
|
||||||
const cliVersion = await aws.getCLIVersion();
|
const regDatas = await aws.getRegistriesData(registry, username, password);
|
||||||
const region = await aws.getRegion(registry);
|
for (const regData of regDatas) {
|
||||||
core.info(`💡 AWS ECR detected with ${region} region`);
|
core.info(`Logging into ${regData.registry}...`);
|
||||||
|
await exec
|
||||||
process.env.AWS_ACCESS_KEY_ID = username;
|
.getExecOutput('docker', ['login', '--password-stdin', '--username', regData.username, regData.registry], {
|
||||||
process.env.AWS_SECRET_ACCESS_KEY = password;
|
ignoreReturnCode: true,
|
||||||
|
silent: true,
|
||||||
core.info(`⬇️ Retrieving docker login command through AWS CLI ${cliVersion} (${cliPath})...`);
|
input: Buffer.from(regData.password)
|
||||||
const loginCmd = await aws.getDockerLoginCmd(cliVersion, registry, region);
|
})
|
||||||
|
.then(res => {
|
||||||
core.info(`🔑 Logging into ${registry}...`);
|
if (res.stderr.length > 0 && res.exitCode != 0) {
|
||||||
execm.exec(loginCmd, [], true).then(res => {
|
throw new Error(res.stderr.trim());
|
||||||
if (res.stderr != '' && !res.success) {
|
}
|
||||||
throw new Error(res.stderr);
|
core.info('Login Succeeded!');
|
||||||
}
|
});
|
||||||
core.info('🎉 Login Succeeded!');
|
}
|
||||||
});
|
|
||||||
}
|
}
|
||||||
|
|||||||
40
src/exec.ts
40
src/exec.ts
@@ -1,40 +0,0 @@
|
|||||||
import * as actionsExec from '@actions/exec';
|
|
||||||
import {ExecOptions} from '@actions/exec';
|
|
||||||
|
|
||||||
export interface ExecResult {
|
|
||||||
success: boolean;
|
|
||||||
stdout: string;
|
|
||||||
stderr: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
export const exec = async (
|
|
||||||
command: string,
|
|
||||||
args: string[] = [],
|
|
||||||
silent: boolean,
|
|
||||||
stdin?: string
|
|
||||||
): Promise<ExecResult> => {
|
|
||||||
let stdout: string = '';
|
|
||||||
let stderr: string = '';
|
|
||||||
|
|
||||||
const options: ExecOptions = {
|
|
||||||
silent: silent,
|
|
||||||
ignoreReturnCode: true,
|
|
||||||
input: Buffer.from(stdin || '')
|
|
||||||
};
|
|
||||||
options.listeners = {
|
|
||||||
stdout: (data: Buffer) => {
|
|
||||||
stdout += data.toString();
|
|
||||||
},
|
|
||||||
stderr: (data: Buffer) => {
|
|
||||||
stderr += data.toString();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
const returnCode: number = await actionsExec.exec(command, args, options);
|
|
||||||
|
|
||||||
return {
|
|
||||||
success: returnCode === 0,
|
|
||||||
stdout: stdout.trim(),
|
|
||||||
stderr: stderr.trim()
|
|
||||||
};
|
|
||||||
};
|
|
||||||
18
src/main.ts
18
src/main.ts
@@ -1,20 +1,14 @@
|
|||||||
import * as os from 'os';
|
|
||||||
import * as core from '@actions/core';
|
import * as core from '@actions/core';
|
||||||
import {getInputs, Inputs} from './context';
|
import * as context from './context';
|
||||||
import * as docker from './docker';
|
import * as docker from './docker';
|
||||||
import * as stateHelper from './state-helper';
|
import * as stateHelper from './state-helper';
|
||||||
|
|
||||||
async function run(): Promise<void> {
|
export async function run(): Promise<void> {
|
||||||
try {
|
try {
|
||||||
if (os.platform() !== 'linux') {
|
const input: context.Inputs = context.getInputs();
|
||||||
core.setFailed('Only supported on linux platform');
|
stateHelper.setRegistry(input.registry);
|
||||||
return;
|
stateHelper.setLogout(input.logout);
|
||||||
}
|
await docker.login(input.registry, input.username, input.password, input.ecr);
|
||||||
|
|
||||||
let inputs: Inputs = await getInputs();
|
|
||||||
stateHelper.setRegistry(inputs.registry);
|
|
||||||
stateHelper.setLogout(inputs.logout);
|
|
||||||
await docker.login(inputs.registry, inputs.username, inputs.password);
|
|
||||||
} catch (error) {
|
} catch (error) {
|
||||||
core.setFailed(error.message);
|
core.setFailed(error.message);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -8,7 +8,7 @@ export function setRegistry(registry: string) {
|
|||||||
core.saveState('registry', registry);
|
core.saveState('registry', registry);
|
||||||
}
|
}
|
||||||
|
|
||||||
export function setLogout(logout: string) {
|
export function setLogout(logout: boolean) {
|
||||||
core.saveState('logout', logout);
|
core.saveState('logout', logout);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
3046
yarn.lock
3046
yarn.lock
@@ -2,168 +2,842 @@
|
|||||||
# yarn lockfile v1
|
# yarn lockfile v1
|
||||||
|
|
||||||
|
|
||||||
"@actions/core@^1.2.5":
|
"@actions/core@^1.6.0":
|
||||||
version "1.2.5"
|
version "1.6.0"
|
||||||
resolved "https://registry.yarnpkg.com/@actions/core/-/core-1.2.5.tgz#fa57bf8c07a38191e243beb9ea9d8368c1cb02c8"
|
resolved "https://registry.yarnpkg.com/@actions/core/-/core-1.6.0.tgz#0568e47039bfb6a9170393a73f3b7eb3b22462cb"
|
||||||
integrity sha512-mwpoNjHSWWh0IiALdDEQi3tru124JKn0yVNziIBzTME8QRv7thwoghVuT1jBRjFvdtoHsqD58IRHy1nf86paRg==
|
integrity sha512-NB1UAZomZlCV/LmJqkLhNTqtKfFXJZAUPcfl/zqG7EfsQdeUJtaWO98SGbuQ3pydJ3fHl2CvI/51OKYlCYYcaw==
|
||||||
|
dependencies:
|
||||||
|
"@actions/http-client" "^1.0.11"
|
||||||
|
|
||||||
"@actions/exec@^1.0.4":
|
"@actions/exec@^1.1.0":
|
||||||
version "1.0.4"
|
version "1.1.0"
|
||||||
resolved "https://registry.yarnpkg.com/@actions/exec/-/exec-1.0.4.tgz#99d75310e62e59fc37d2ee6dcff6d4bffadd3a5d"
|
resolved "https://registry.yarnpkg.com/@actions/exec/-/exec-1.1.0.tgz#53441d968e56d2fec69ad3f15773d4d94e01162c"
|
||||||
integrity sha512-4DPChWow9yc9W3WqEbUj8Nr86xkpyE29ZzWjXucHItclLbEW6jr80Zx4nqv18QL6KK65+cifiQZXvnqgTV6oHw==
|
integrity sha512-LImpN9AY0J1R1mEYJjVJfSZWU4zYOlEcwSTgPve1rFQqK5AwrEs6uWW5Rv70gbDIQIAUwI86z6B+9mPK4w9Sbg==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@actions/io" "^1.0.1"
|
"@actions/io" "^1.0.1"
|
||||||
|
|
||||||
"@actions/io@^1.0.1", "@actions/io@^1.0.2":
|
"@actions/http-client@^1.0.11":
|
||||||
version "1.0.2"
|
version "1.0.11"
|
||||||
resolved "https://registry.yarnpkg.com/@actions/io/-/io-1.0.2.tgz#2f614b6e69ce14d191180451eb38e6576a6e6b27"
|
resolved "https://registry.yarnpkg.com/@actions/http-client/-/http-client-1.0.11.tgz#c58b12e9aa8b159ee39e7dd6cbd0e91d905633c0"
|
||||||
integrity sha512-J8KuFqVPr3p6U8W93DOXlXW6zFvrQAJANdS+vw0YhusLIq+bszW8zmK2Fh1C2kDPX8FMvwIl1OUcFgvJoXLbAg==
|
integrity sha512-VRYHGQV1rqnROJqdMvGUbY/Kn8vriQe/F9HR2AlYHzmKuM/p3kjNuXhmdBfcVgsvRWTz5C5XW5xvndZrVBuAYg==
|
||||||
|
|
||||||
"@babel/code-frame@^7.0.0", "@babel/code-frame@^7.10.4":
|
|
||||||
version "7.10.4"
|
|
||||||
resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.10.4.tgz#168da1a36e90da68ae8d49c0f1b48c7c6249213a"
|
|
||||||
integrity sha512-vG6SvB6oYEhvgisZNFRmRCUkLz11c7rp+tbNTynGqc6mS1d5ATd/sGyV6W0KZZnXRKMTzZDRgQT3Ou9jhpAfUg==
|
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/highlight" "^7.10.4"
|
tunnel "0.0.6"
|
||||||
|
|
||||||
|
"@actions/io@^1.0.1", "@actions/io@^1.1.1":
|
||||||
|
version "1.1.1"
|
||||||
|
resolved "https://registry.yarnpkg.com/@actions/io/-/io-1.1.1.tgz#4a157406309e212ab27ed3ae30e8c1d641686a66"
|
||||||
|
integrity sha512-Qi4JoKXjmE0O67wAOH6y0n26QXhMKMFo7GD/4IXNVcrtLjUlGjGuVys6pQgwF3ArfGTQu0XpqaNr0YhED2RaRA==
|
||||||
|
|
||||||
|
"@aws-crypto/ie11-detection@^2.0.0":
|
||||||
|
version "2.0.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-crypto/ie11-detection/-/ie11-detection-2.0.0.tgz#bb6c2facf8f03457e949dcf0921477397ffa4c6e"
|
||||||
|
integrity sha512-pkVXf/dq6PITJ0jzYZ69VhL8VFOFoPZLZqtU/12SGnzYuJOOGNfF41q9GxdI1yqC8R13Rq3jOLKDFpUJFT5eTA==
|
||||||
|
dependencies:
|
||||||
|
tslib "^1.11.1"
|
||||||
|
|
||||||
|
"@aws-crypto/sha256-browser@2.0.0":
|
||||||
|
version "2.0.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-crypto/sha256-browser/-/sha256-browser-2.0.0.tgz#741c9024df55ec59b51e5b1f5d806a4852699fb5"
|
||||||
|
integrity sha512-rYXOQ8BFOaqMEHJrLHul/25ckWH6GTJtdLSajhlqGMx0PmSueAuvboCuZCTqEKlxR8CQOwRarxYMZZSYlhRA1A==
|
||||||
|
dependencies:
|
||||||
|
"@aws-crypto/ie11-detection" "^2.0.0"
|
||||||
|
"@aws-crypto/sha256-js" "^2.0.0"
|
||||||
|
"@aws-crypto/supports-web-crypto" "^2.0.0"
|
||||||
|
"@aws-crypto/util" "^2.0.0"
|
||||||
|
"@aws-sdk/types" "^3.1.0"
|
||||||
|
"@aws-sdk/util-locate-window" "^3.0.0"
|
||||||
|
"@aws-sdk/util-utf8-browser" "^3.0.0"
|
||||||
|
tslib "^1.11.1"
|
||||||
|
|
||||||
|
"@aws-crypto/sha256-js@2.0.0":
|
||||||
|
version "2.0.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-crypto/sha256-js/-/sha256-js-2.0.0.tgz#f1f936039bdebd0b9e2dd834d65afdc2aac4efcb"
|
||||||
|
integrity sha512-VZY+mCY4Nmrs5WGfitmNqXzaE873fcIZDu54cbaDaaamsaTOP1DBImV9F4pICc3EHjQXujyE8jig+PFCaew9ig==
|
||||||
|
dependencies:
|
||||||
|
"@aws-crypto/util" "^2.0.0"
|
||||||
|
"@aws-sdk/types" "^3.1.0"
|
||||||
|
tslib "^1.11.1"
|
||||||
|
|
||||||
|
"@aws-crypto/sha256-js@^2.0.0":
|
||||||
|
version "2.0.1"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-crypto/sha256-js/-/sha256-js-2.0.1.tgz#79e1e6cf61f652ef2089c08d471c722ecf1626a9"
|
||||||
|
integrity sha512-mbHTBSPBvg6o/mN/c18Z/zifM05eJrapj5ggoOIeHIWckvkv5VgGi7r/wYpt+QAO2ySKXLNvH2d8L7bne4xrMQ==
|
||||||
|
dependencies:
|
||||||
|
"@aws-crypto/util" "^2.0.1"
|
||||||
|
"@aws-sdk/types" "^3.1.0"
|
||||||
|
tslib "^1.11.1"
|
||||||
|
|
||||||
|
"@aws-crypto/supports-web-crypto@^2.0.0":
|
||||||
|
version "2.0.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-crypto/supports-web-crypto/-/supports-web-crypto-2.0.0.tgz#fd6cde30b88f77d5a4f57b2c37c560d918014f9e"
|
||||||
|
integrity sha512-Ge7WQ3E0OC7FHYprsZV3h0QIcpdyJLvIeg+uTuHqRYm8D6qCFJoiC+edSzSyFiHtZf+NOQDJ1q46qxjtzIY2nA==
|
||||||
|
dependencies:
|
||||||
|
tslib "^1.11.1"
|
||||||
|
|
||||||
|
"@aws-crypto/util@^2.0.0", "@aws-crypto/util@^2.0.1":
|
||||||
|
version "2.0.1"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-crypto/util/-/util-2.0.1.tgz#976cf619cf85084ca85ec5eb947a6ac6b8b5c98c"
|
||||||
|
integrity sha512-JJmFFwvbm08lULw4Nm5QOLg8+lAQeC8aCXK5xrtxntYzYXCGfHwUJ4Is3770Q7HmICsXthGQ+ZsDL7C2uH3yBQ==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/types" "^3.1.0"
|
||||||
|
"@aws-sdk/util-utf8-browser" "^3.0.0"
|
||||||
|
tslib "^1.11.1"
|
||||||
|
|
||||||
|
"@aws-sdk/abort-controller@3.40.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/abort-controller/-/abort-controller-3.40.0.tgz#e17299776782483835439d9b1b5300add24adc3f"
|
||||||
|
integrity sha512-S7LzLvNuwuf0q7r4q7zqGzxd/W2xYsn8cpZ90MMb3ObolhbkLySrikUJujmXae8k+2/KFCOr+FVC0YLrATSUgQ==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/client-ecr-public@^3.45.0":
|
||||||
|
version "3.45.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/client-ecr-public/-/client-ecr-public-3.45.0.tgz#767a17470f502e3d4861b5bb5658f418267482d1"
|
||||||
|
integrity sha512-fT6JBDbDTFl9OGv1b3uu1XlYDlduW7bV7pWVrUx28eJJaEMvGLxMJkcUOvjDCyTcvQYvHdpGgEQHwFNKictvuA==
|
||||||
|
dependencies:
|
||||||
|
"@aws-crypto/sha256-browser" "2.0.0"
|
||||||
|
"@aws-crypto/sha256-js" "2.0.0"
|
||||||
|
"@aws-sdk/client-sts" "3.45.0"
|
||||||
|
"@aws-sdk/config-resolver" "3.45.0"
|
||||||
|
"@aws-sdk/credential-provider-node" "3.45.0"
|
||||||
|
"@aws-sdk/fetch-http-handler" "3.40.0"
|
||||||
|
"@aws-sdk/hash-node" "3.40.0"
|
||||||
|
"@aws-sdk/invalid-dependency" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-content-length" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-host-header" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-logger" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-retry" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-serde" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-signing" "3.45.0"
|
||||||
|
"@aws-sdk/middleware-stack" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-user-agent" "3.40.0"
|
||||||
|
"@aws-sdk/node-config-provider" "3.40.0"
|
||||||
|
"@aws-sdk/node-http-handler" "3.40.0"
|
||||||
|
"@aws-sdk/protocol-http" "3.40.0"
|
||||||
|
"@aws-sdk/smithy-client" "3.41.0"
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
"@aws-sdk/url-parser" "3.40.0"
|
||||||
|
"@aws-sdk/util-base64-browser" "3.37.0"
|
||||||
|
"@aws-sdk/util-base64-node" "3.37.0"
|
||||||
|
"@aws-sdk/util-body-length-browser" "3.37.0"
|
||||||
|
"@aws-sdk/util-body-length-node" "3.37.0"
|
||||||
|
"@aws-sdk/util-user-agent-browser" "3.40.0"
|
||||||
|
"@aws-sdk/util-user-agent-node" "3.40.0"
|
||||||
|
"@aws-sdk/util-utf8-browser" "3.37.0"
|
||||||
|
"@aws-sdk/util-utf8-node" "3.37.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/client-ecr@^3.45.0":
|
||||||
|
version "3.45.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/client-ecr/-/client-ecr-3.45.0.tgz#17bc428a26db52075cf8a1de8834fe489a540cec"
|
||||||
|
integrity sha512-hQNapi+DkcabzXoVA7NEeO2hdFOug7K8lR/2iMgoTJnPOa4SMVfHhZan/CJqa2Wb00xQGrv1YXVrQIwhK/gzDA==
|
||||||
|
dependencies:
|
||||||
|
"@aws-crypto/sha256-browser" "2.0.0"
|
||||||
|
"@aws-crypto/sha256-js" "2.0.0"
|
||||||
|
"@aws-sdk/client-sts" "3.45.0"
|
||||||
|
"@aws-sdk/config-resolver" "3.45.0"
|
||||||
|
"@aws-sdk/credential-provider-node" "3.45.0"
|
||||||
|
"@aws-sdk/fetch-http-handler" "3.40.0"
|
||||||
|
"@aws-sdk/hash-node" "3.40.0"
|
||||||
|
"@aws-sdk/invalid-dependency" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-content-length" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-host-header" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-logger" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-retry" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-serde" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-signing" "3.45.0"
|
||||||
|
"@aws-sdk/middleware-stack" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-user-agent" "3.40.0"
|
||||||
|
"@aws-sdk/node-config-provider" "3.40.0"
|
||||||
|
"@aws-sdk/node-http-handler" "3.40.0"
|
||||||
|
"@aws-sdk/protocol-http" "3.40.0"
|
||||||
|
"@aws-sdk/smithy-client" "3.41.0"
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
"@aws-sdk/url-parser" "3.40.0"
|
||||||
|
"@aws-sdk/util-base64-browser" "3.37.0"
|
||||||
|
"@aws-sdk/util-base64-node" "3.37.0"
|
||||||
|
"@aws-sdk/util-body-length-browser" "3.37.0"
|
||||||
|
"@aws-sdk/util-body-length-node" "3.37.0"
|
||||||
|
"@aws-sdk/util-user-agent-browser" "3.40.0"
|
||||||
|
"@aws-sdk/util-user-agent-node" "3.40.0"
|
||||||
|
"@aws-sdk/util-utf8-browser" "3.37.0"
|
||||||
|
"@aws-sdk/util-utf8-node" "3.37.0"
|
||||||
|
"@aws-sdk/util-waiter" "3.40.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/client-sso@3.45.0":
|
||||||
|
version "3.45.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/client-sso/-/client-sso-3.45.0.tgz#4e6f16096758c4681bd2464507e6a3ec5623ec3c"
|
||||||
|
integrity sha512-MfsKg4Wq5KvuGEg+M7kYfl6B3TRhxKeL01+5wtxhYbiLqxzr18mfO8PnBAasXMmYCmEQsSGmFepD7GLOld9uHA==
|
||||||
|
dependencies:
|
||||||
|
"@aws-crypto/sha256-browser" "2.0.0"
|
||||||
|
"@aws-crypto/sha256-js" "2.0.0"
|
||||||
|
"@aws-sdk/config-resolver" "3.45.0"
|
||||||
|
"@aws-sdk/fetch-http-handler" "3.40.0"
|
||||||
|
"@aws-sdk/hash-node" "3.40.0"
|
||||||
|
"@aws-sdk/invalid-dependency" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-content-length" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-host-header" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-logger" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-retry" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-serde" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-stack" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-user-agent" "3.40.0"
|
||||||
|
"@aws-sdk/node-config-provider" "3.40.0"
|
||||||
|
"@aws-sdk/node-http-handler" "3.40.0"
|
||||||
|
"@aws-sdk/protocol-http" "3.40.0"
|
||||||
|
"@aws-sdk/smithy-client" "3.41.0"
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
"@aws-sdk/url-parser" "3.40.0"
|
||||||
|
"@aws-sdk/util-base64-browser" "3.37.0"
|
||||||
|
"@aws-sdk/util-base64-node" "3.37.0"
|
||||||
|
"@aws-sdk/util-body-length-browser" "3.37.0"
|
||||||
|
"@aws-sdk/util-body-length-node" "3.37.0"
|
||||||
|
"@aws-sdk/util-user-agent-browser" "3.40.0"
|
||||||
|
"@aws-sdk/util-user-agent-node" "3.40.0"
|
||||||
|
"@aws-sdk/util-utf8-browser" "3.37.0"
|
||||||
|
"@aws-sdk/util-utf8-node" "3.37.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/client-sts@3.45.0":
|
||||||
|
version "3.45.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/client-sts/-/client-sts-3.45.0.tgz#753c850e5e3e427ce30bde851eb607a766316d59"
|
||||||
|
integrity sha512-D+VGhAg+1i7/WQhfkLn7nWHR+Uyp7FPVAQ/N2MBQvZxGbSSb2agU9DN2FnxeFljOEcGJ7NdJ9YSZCFlJo0bLWA==
|
||||||
|
dependencies:
|
||||||
|
"@aws-crypto/sha256-browser" "2.0.0"
|
||||||
|
"@aws-crypto/sha256-js" "2.0.0"
|
||||||
|
"@aws-sdk/config-resolver" "3.45.0"
|
||||||
|
"@aws-sdk/credential-provider-node" "3.45.0"
|
||||||
|
"@aws-sdk/fetch-http-handler" "3.40.0"
|
||||||
|
"@aws-sdk/hash-node" "3.40.0"
|
||||||
|
"@aws-sdk/invalid-dependency" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-content-length" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-host-header" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-logger" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-retry" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-sdk-sts" "3.45.0"
|
||||||
|
"@aws-sdk/middleware-serde" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-signing" "3.45.0"
|
||||||
|
"@aws-sdk/middleware-stack" "3.40.0"
|
||||||
|
"@aws-sdk/middleware-user-agent" "3.40.0"
|
||||||
|
"@aws-sdk/node-config-provider" "3.40.0"
|
||||||
|
"@aws-sdk/node-http-handler" "3.40.0"
|
||||||
|
"@aws-sdk/protocol-http" "3.40.0"
|
||||||
|
"@aws-sdk/smithy-client" "3.41.0"
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
"@aws-sdk/url-parser" "3.40.0"
|
||||||
|
"@aws-sdk/util-base64-browser" "3.37.0"
|
||||||
|
"@aws-sdk/util-base64-node" "3.37.0"
|
||||||
|
"@aws-sdk/util-body-length-browser" "3.37.0"
|
||||||
|
"@aws-sdk/util-body-length-node" "3.37.0"
|
||||||
|
"@aws-sdk/util-user-agent-browser" "3.40.0"
|
||||||
|
"@aws-sdk/util-user-agent-node" "3.40.0"
|
||||||
|
"@aws-sdk/util-utf8-browser" "3.37.0"
|
||||||
|
"@aws-sdk/util-utf8-node" "3.37.0"
|
||||||
|
entities "2.2.0"
|
||||||
|
fast-xml-parser "3.19.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/config-resolver@3.45.0":
|
||||||
|
version "3.45.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/config-resolver/-/config-resolver-3.45.0.tgz#6c58c789a2e104d1ed8824f0ef541414295fd5c0"
|
||||||
|
integrity sha512-pk+9jWQGvga2jr4aiB/KR1vAI0vPngvo9HqBbKebbJzaBhpA/RwGVWB1ZJch93oG8DBeyKZ0md9eOJRU1BkTIQ==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/signature-v4" "3.45.0"
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
"@aws-sdk/util-config-provider" "3.40.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/credential-provider-env@3.40.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/credential-provider-env/-/credential-provider-env-3.40.0.tgz#0ca7611f13520dd6654e8eac7fa3e767d027ede6"
|
||||||
|
integrity sha512-qHZdf2vxhzZkSygjw2I4SEYFL2dMZxxYvO4QlkqQouKY81OVxs/j69oiNCjPasQzGz5jaZZKI8xEAIfkSyr1lg==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/property-provider" "3.40.0"
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/credential-provider-imds@3.40.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/credential-provider-imds/-/credential-provider-imds-3.40.0.tgz#7c324eff731f85d4d40763c484e78673aa5dedfb"
|
||||||
|
integrity sha512-Ty/wVa+BQrCFrP06AGl5S1CeLifDt68YrlYXUnkRn603SX4DvxBgVO7XFeDH58G8ziDCiqxfmVl4yjbncPPeSw==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/node-config-provider" "3.40.0"
|
||||||
|
"@aws-sdk/property-provider" "3.40.0"
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
"@aws-sdk/url-parser" "3.40.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/credential-provider-ini@3.45.0":
|
||||||
|
version "3.45.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/credential-provider-ini/-/credential-provider-ini-3.45.0.tgz#fa62ff47a00a0e590d4db3d3a1f49b250021ebbc"
|
||||||
|
integrity sha512-lfYh8LVW33de01zzfqs6H+4xr20l+++QtvWG8PwKzEAY/71s344ybrOw7KiVUkCDLLbj3SWEmsMJFvBcrvifbA==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/credential-provider-env" "3.40.0"
|
||||||
|
"@aws-sdk/credential-provider-imds" "3.40.0"
|
||||||
|
"@aws-sdk/credential-provider-sso" "3.45.0"
|
||||||
|
"@aws-sdk/credential-provider-web-identity" "3.41.0"
|
||||||
|
"@aws-sdk/property-provider" "3.40.0"
|
||||||
|
"@aws-sdk/shared-ini-file-loader" "3.37.0"
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
"@aws-sdk/util-credentials" "3.37.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/credential-provider-node@3.45.0":
|
||||||
|
version "3.45.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/credential-provider-node/-/credential-provider-node-3.45.0.tgz#a33e6f08f6127165f2e01b9c31490a25aeb31b44"
|
||||||
|
integrity sha512-ZNqo0JlA7S4k1bAB+Xb8A3KsmNPWVFMmoY3NC25dgXU4xQLVxy0MucQggnfCqRjvshwI4OEdDQsRgl69n/XErQ==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/credential-provider-env" "3.40.0"
|
||||||
|
"@aws-sdk/credential-provider-imds" "3.40.0"
|
||||||
|
"@aws-sdk/credential-provider-ini" "3.45.0"
|
||||||
|
"@aws-sdk/credential-provider-process" "3.40.0"
|
||||||
|
"@aws-sdk/credential-provider-sso" "3.45.0"
|
||||||
|
"@aws-sdk/credential-provider-web-identity" "3.41.0"
|
||||||
|
"@aws-sdk/property-provider" "3.40.0"
|
||||||
|
"@aws-sdk/shared-ini-file-loader" "3.37.0"
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
"@aws-sdk/util-credentials" "3.37.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/credential-provider-process@3.40.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/credential-provider-process/-/credential-provider-process-3.40.0.tgz#b4f16e43ca9c855002e833ac9dc8e409b3c7ca23"
|
||||||
|
integrity sha512-qsaNCDesW2GasDbzpeOA371gxugi05JWxt3EKonLbUfkGKBK7kmmL6EgLIxZuNm2/Ve4RS07PKp8yBGm4xIx9w==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/property-provider" "3.40.0"
|
||||||
|
"@aws-sdk/shared-ini-file-loader" "3.37.0"
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
"@aws-sdk/util-credentials" "3.37.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/credential-provider-sso@3.45.0":
|
||||||
|
version "3.45.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/credential-provider-sso/-/credential-provider-sso-3.45.0.tgz#c3b1b16c1928310dd06b5193421935cd3598a4f6"
|
||||||
|
integrity sha512-FBMn+QA6rI74A90ieQtCJckbKPBxNn4mgR9rzWyi/R6o5gVuu99yJGL03NXtWtm5N4x/1SygBtezY/XL5UU0Mg==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/client-sso" "3.45.0"
|
||||||
|
"@aws-sdk/property-provider" "3.40.0"
|
||||||
|
"@aws-sdk/shared-ini-file-loader" "3.37.0"
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
"@aws-sdk/util-credentials" "3.37.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/credential-provider-web-identity@3.41.0":
|
||||||
|
version "3.41.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/credential-provider-web-identity/-/credential-provider-web-identity-3.41.0.tgz#7f0e9cc5650eaf6ac32ef359fb0e0dea2ca0ce78"
|
||||||
|
integrity sha512-VqvVoEh9C8xTXl4stKyJC5IKQhS8g1Gi5k6B9HPHLIxFRRfKxkE73DT4pMN6npnus7o0yi0MTFGQFQGYSrFO2g==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/property-provider" "3.40.0"
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/fetch-http-handler@3.40.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/fetch-http-handler/-/fetch-http-handler-3.40.0.tgz#5e6ecfb7fe1f32a5709e4e9c13b0536073477737"
|
||||||
|
integrity sha512-w1HiZromoU+/bbEo89uO81l6UO/M+c2uOMnXntZqe6t3ZHUUUo3AbvhKh0QGVFqRQa+Oi0+95KqWmTHa72/9Iw==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/protocol-http" "3.40.0"
|
||||||
|
"@aws-sdk/querystring-builder" "3.40.0"
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
"@aws-sdk/util-base64-browser" "3.37.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/hash-node@3.40.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/hash-node/-/hash-node-3.40.0.tgz#bf4d31a41652cbc3c937055087c80096cfab67ae"
|
||||||
|
integrity sha512-yOXXK85DdGDktdnQtXgMdaVKii4wtMjEhJ1mrvx2A9nMFNaPhxvERkVVIUKSWlJRa9ZujOw5jWOx8d2R51/Kjg==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
"@aws-sdk/util-buffer-from" "3.37.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/invalid-dependency@3.40.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/invalid-dependency/-/invalid-dependency-3.40.0.tgz#023e37abfb2882676c3cef02da630342634aa429"
|
||||||
|
integrity sha512-axIWtDwCBDDqEgAJipX1FB1ZNpWYXquVwKDMo+7G+ftPBZ4FEq4M1ELhXJL3hhNJ9ZmCQzv+4F6Wnt8dwuzUaQ==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/is-array-buffer@3.37.0":
|
||||||
|
version "3.37.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/is-array-buffer/-/is-array-buffer-3.37.0.tgz#aa87619f8172b1a2a7ac8d573032025d98ae6c50"
|
||||||
|
integrity sha512-XLjA/a6AuGnCvcJZLsMTy2jxF2upgGhqCCkoIJgLlzzXHSihur13KcmPvW/zcaGnCRj0SvKWXiJHl4vDlW75VQ==
|
||||||
|
dependencies:
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/middleware-content-length@3.40.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/middleware-content-length/-/middleware-content-length-3.40.0.tgz#affe235fc0eb43c7b8e21189f85a238fdd0b4c3f"
|
||||||
|
integrity sha512-sybAJb8v7I/vvL08R3+TI/XDAg9gybQTZ2treC24Ap4+jAOz4QBTHJPMKaUlEeFlMUcq4rj6/u2897ebYH6opw==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/protocol-http" "3.40.0"
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/middleware-host-header@3.40.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/middleware-host-header/-/middleware-host-header-3.40.0.tgz#a6a1d52ab0da7f8e65a199c27d71750f8329eccc"
|
||||||
|
integrity sha512-/wocR7JFOLM7/+BQM1DgAd6KCFYcdxYu1P7AhI451GlVNuYa5f89zh7p0gt3SRC6monI5lXgpL7RudhDm8fTrA==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/protocol-http" "3.40.0"
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/middleware-logger@3.40.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/middleware-logger/-/middleware-logger-3.40.0.tgz#29d9616bd39dafa1493cef333a32363e4df2c607"
|
||||||
|
integrity sha512-19kx0Xg5ymVRKoupmhdmfTBkROcv3DZj508agpyG2YAo0abOObMlIP4Jltg0VD4PhNjGzNh0jFGJnvhjdwv4/A==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/middleware-retry@3.40.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/middleware-retry/-/middleware-retry-3.40.0.tgz#5cffe046b1fd208a62a09495de6659be48ef86f3"
|
||||||
|
integrity sha512-SMUJrukugLL7YJE5X8B2ToukxMWMPwnf7jAFr84ptycCe8bdWv8x8klQ3EtVWpyqochtNlbTi6J/tTQBniUX7A==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/protocol-http" "3.40.0"
|
||||||
|
"@aws-sdk/service-error-classification" "3.40.0"
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
uuid "^8.3.2"
|
||||||
|
|
||||||
|
"@aws-sdk/middleware-sdk-sts@3.45.0":
|
||||||
|
version "3.45.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/middleware-sdk-sts/-/middleware-sdk-sts-3.45.0.tgz#67a39b91913a2a30d56dd95bf8469bb7335d0024"
|
||||||
|
integrity sha512-nvvzoKItzyZF44+0/VdygbUDgBG8wxYqDK0i+aPYLmmTu2NTBcREeMDiYO/aHZIzMNemyJqSdB3p8sdf2BYTAA==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/middleware-signing" "3.45.0"
|
||||||
|
"@aws-sdk/property-provider" "3.40.0"
|
||||||
|
"@aws-sdk/protocol-http" "3.40.0"
|
||||||
|
"@aws-sdk/signature-v4" "3.45.0"
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/middleware-serde@3.40.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/middleware-serde/-/middleware-serde-3.40.0.tgz#90124ff60a7f23963bbcd00a5cc95862b29dddd9"
|
||||||
|
integrity sha512-uOWfZjlAoBy6xPqp0d4ka83WNNbEVCWn9WwfqBUXThyoTdTooYSpXe5y2YzN0BJa8b+tEZTyWpgamnBpFLp47g==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/middleware-signing@3.45.0":
|
||||||
|
version "3.45.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/middleware-signing/-/middleware-signing-3.45.0.tgz#614935fc1f1ae79c09a17ea59d0650392f5b5d5b"
|
||||||
|
integrity sha512-MUtKe0mRWgWimGlbDX9KWHnxcQz8g1N+gEjfkcxzw+HMIxxQIKYFgUyllhFZ3HvYIje/wLlFYuDKXRBrJjUxYQ==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/property-provider" "3.40.0"
|
||||||
|
"@aws-sdk/protocol-http" "3.40.0"
|
||||||
|
"@aws-sdk/signature-v4" "3.45.0"
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/middleware-stack@3.40.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/middleware-stack/-/middleware-stack-3.40.0.tgz#5aa614e49a4fc76cc63986fb45302f7afab6db87"
|
||||||
|
integrity sha512-hby9HvESUYJxpdALX+6Dn2LPmS5jtMVurGB/+j3MWOvIcDYB4bcSXgVRvXzYnTKwbSupIdbX9zOE2ZAx2SJpUQ==
|
||||||
|
dependencies:
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/middleware-user-agent@3.40.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/middleware-user-agent/-/middleware-user-agent-3.40.0.tgz#bf03d2deddc00689c85e7eadd9b4e02f24b61c08"
|
||||||
|
integrity sha512-dzC2fxWnanetFJ1oYgil8df3N36bR1yc/OCOpbdfQNiUk1FrXiCXqH5rHNO8zCvnwJAj8GHFwpFGd9a2Qube2w==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/protocol-http" "3.40.0"
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/node-config-provider@3.40.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/node-config-provider/-/node-config-provider-3.40.0.tgz#54a8abc4f6d78503093b270e6dff3d6174c59f95"
|
||||||
|
integrity sha512-AmokjgUDECG8osoMfdRsPNweqI+L1pn4bYGk5iTLmzbBi0o4ot0U1FdX8Rf0qJZZwS4t1TXc3s8/PDVknmPxKg==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/property-provider" "3.40.0"
|
||||||
|
"@aws-sdk/shared-ini-file-loader" "3.37.0"
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/node-http-handler@3.40.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/node-http-handler/-/node-http-handler-3.40.0.tgz#26491f11dabbd673c6318376d06af154adc123df"
|
||||||
|
integrity sha512-qjda6IbxDhbYr8NHmrMurKkbjgLUkfTMVgagDErDK24Nm3Dn5VaO6J4n6c0Q4OLHlmFaRcUfZSTrOo5DAubqCw==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/abort-controller" "3.40.0"
|
||||||
|
"@aws-sdk/protocol-http" "3.40.0"
|
||||||
|
"@aws-sdk/querystring-builder" "3.40.0"
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/property-provider@3.40.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/property-provider/-/property-provider-3.40.0.tgz#243cb1e87e36b1123ddc66d40d344e7580f80470"
|
||||||
|
integrity sha512-Mx4lkShjsYRwW9ujHA1pcnuubrWQ4kF5/DXWNfUiXuSIO/0Lojp1qTLheyBm4vzkJIlx5umyP6NvRAUkEHSN4Q==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/protocol-http@3.40.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/protocol-http/-/protocol-http-3.40.0.tgz#ce6c7170a59e0a0eb63df5cd7cec87fe05bae680"
|
||||||
|
integrity sha512-f4ea7/HZkjpvGBrnRIuzc/bhrExWrgDv7eulj4htPukZGHdTqSJD3Jk8lEXWvFuX2vUKQDGhEhCDsqup7YWJQQ==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/querystring-builder@3.40.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/querystring-builder/-/querystring-builder-3.40.0.tgz#f57212e60519d2d79ce6173cbe00fbe17a69bc0d"
|
||||||
|
integrity sha512-gO24oipnNaxJRBXB7lhLfa96vIMOd8gtMBqJTjelTjS2e1ZP1YY12CNKKTWwafSk8Ge021erZAG/YTOaXGpv+g==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
"@aws-sdk/util-uri-escape" "3.37.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/querystring-parser@3.40.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/querystring-parser/-/querystring-parser-3.40.0.tgz#5a5ba9c095ad3125a0daf37c33ed1cc8a600d53e"
|
||||||
|
integrity sha512-XZIyaKQIiZAM6zelCBcsLHhVDOLafi7XIOd3jy6SymGN8ajj3HqUJ/vdQ5G6ISTk18OrqgqcCOI9oNzv+nrBcA==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/service-error-classification@3.40.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/service-error-classification/-/service-error-classification-3.40.0.tgz#c98cbb781bd50e5d90649742ff954d754201c44d"
|
||||||
|
integrity sha512-c8btKmkvjXczWudXubGdbO3JgmjySBUVC/gCrZDNfwNGsG8RYJJQYYcnmt1gWjelUZsgMDl/2PIzxTlxVF91rA==
|
||||||
|
|
||||||
|
"@aws-sdk/shared-ini-file-loader@3.37.0":
|
||||||
|
version "3.37.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/shared-ini-file-loader/-/shared-ini-file-loader-3.37.0.tgz#ca595d9745150f46805f68be6a6c1607d618ad94"
|
||||||
|
integrity sha512-+vRBSlfa48R9KL7DpQt3dsu5/+5atjRgoCISblWo3SLpjrx41pKcjKneo7a1u0aP1Xc2oG2TfIyqTWZuOXsmEQ==
|
||||||
|
dependencies:
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/signature-v4@3.45.0":
|
||||||
|
version "3.45.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/signature-v4/-/signature-v4-3.45.0.tgz#1852f3ad0447c9788f2454a7cfec2182b30eadac"
|
||||||
|
integrity sha512-73dwNe4R4Ytgn82gV8B99tE6UqrWjHE1JIAXpEZeXsBPJtg+8wpgd9sujs6JH9JW2cvnSnIsCXs1gQGD9+bZ0A==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/is-array-buffer" "3.37.0"
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
"@aws-sdk/util-hex-encoding" "3.37.0"
|
||||||
|
"@aws-sdk/util-uri-escape" "3.37.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/smithy-client@3.41.0":
|
||||||
|
version "3.41.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/smithy-client/-/smithy-client-3.41.0.tgz#61154b4813a01dc079e7083805a20e1bc05d3199"
|
||||||
|
integrity sha512-ldhS0Pf3v6yHCd//kk5DvKcdyeUkKEwxNDRanAp+ekTW68J3XcYgKaPC9sNDhVTDH1zrywTvtEz5zWHEvXjQow==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/middleware-stack" "3.40.0"
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/types@3.40.0", "@aws-sdk/types@^3.1.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/types/-/types-3.40.0.tgz#a9d7926fcb9b699bc46be975033559d2293e60d1"
|
||||||
|
integrity sha512-KpILcfvRaL88TLvo3SY4OuCCg90SvcNLPyjDwUuBqiOyWODjrKShHtAPJzej4CLp92lofh+ul0UnBfV9Jb/5PA==
|
||||||
|
|
||||||
|
"@aws-sdk/url-parser@3.40.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/url-parser/-/url-parser-3.40.0.tgz#9ccd00a2026605d5eaef630e94b6632cc9598ec3"
|
||||||
|
integrity sha512-HwNV+HX7bHgLk5FzTOgdXANsC0SeVz5PMC4Nh+TLz2IoeQnrw4H8dsA4YNonncjern5oC5veKRjQeOoCL5SlSQ==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/querystring-parser" "3.40.0"
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/util-base64-browser@3.37.0":
|
||||||
|
version "3.37.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/util-base64-browser/-/util-base64-browser-3.37.0.tgz#4bf105de91e5e17ded644557dac6851c30e992d2"
|
||||||
|
integrity sha512-o4s/rHVm5k8eC/T7grJQINyYA/mKfDmEWKMA9wk5iBroXlI2rUm7x649TBk5hzoddufk/mffEeNz/1wM7yTmlg==
|
||||||
|
dependencies:
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/util-base64-node@3.37.0":
|
||||||
|
version "3.37.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/util-base64-node/-/util-base64-node-3.37.0.tgz#81ff164d227db8faeb910af33ff5f861269d6d67"
|
||||||
|
integrity sha512-1UPxly1GPrGZtlIWvbNCDIAund4Oyp8cFi9neA43TeNACvrmEQu/nG01pDbOoo0ENoVSVJrNAVBeqKEpqjH2GA==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/util-buffer-from" "3.37.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/util-body-length-browser@3.37.0":
|
||||||
|
version "3.37.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/util-body-length-browser/-/util-body-length-browser-3.37.0.tgz#2e3a375ac191a9bacd40a6b3479ee402dcb5769d"
|
||||||
|
integrity sha512-tClmH1uYelqWT43xxmnOsVFbCQJiIwizp6y4E109G2LIof07inxrO0L8nbwBpjhugVplx6NZr9IaqTFqbdM1gA==
|
||||||
|
dependencies:
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/util-body-length-node@3.37.0":
|
||||||
|
version "3.37.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/util-body-length-node/-/util-body-length-node-3.37.0.tgz#d6170dafd351799687d583f818a4a3924b61cbec"
|
||||||
|
integrity sha512-aY3mXdbEajruRi9CHgq/heM89R+Gectj/Xrs1naewmamaN8NJrvjDm3s+cw//lqqSOW903LYHXDgm7wvCzUnFA==
|
||||||
|
dependencies:
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/util-buffer-from@3.37.0":
|
||||||
|
version "3.37.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/util-buffer-from/-/util-buffer-from-3.37.0.tgz#298d4a925b9f0ca23f99617648cd9fb3896b573c"
|
||||||
|
integrity sha512-aa3SBwjLwImuJoE4+hxDIWQ9REz3UFb3p7KFPe9qopdXb/yB12RTcbrXVb4whUux4i4mO6KRij0ZNjFZrjrKPg==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/is-array-buffer" "3.37.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/util-config-provider@3.40.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/util-config-provider/-/util-config-provider-3.40.0.tgz#acefff264d6650450a1f8b056a63830a454b756d"
|
||||||
|
integrity sha512-NjZGrA4mqhpr6gkVCAUweurP0Z9d3vFyXJCtulC0BFbpKAnKCf/crSK56NwUaNhAEMCkSuBvjRFzkbfT+HO8bA==
|
||||||
|
dependencies:
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/util-credentials@3.37.0":
|
||||||
|
version "3.37.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/util-credentials/-/util-credentials-3.37.0.tgz#76261c3d7c20bee5d28e5c17741adf19558b3b67"
|
||||||
|
integrity sha512-zcLhSZDKgBLhUjSU5HoQpuQiP3v8oE86NmV/tiZVPEaO6YVULEAB2Cfj1hpM/b/JXWzjSHfT06KXT7QUODKS+A==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/shared-ini-file-loader" "3.37.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/util-hex-encoding@3.37.0":
|
||||||
|
version "3.37.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/util-hex-encoding/-/util-hex-encoding-3.37.0.tgz#40ce21b5ff682e811e98ac7476692ee55ae61493"
|
||||||
|
integrity sha512-tn5UpfaeM+rZWqynoNqB8lwtcAXil5YYO3HLGH9himpWAdft/2Z7LK6bsYDpctaAI1WHgMDcL0bw3Id04ZUbhA==
|
||||||
|
dependencies:
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/util-locate-window@^3.0.0":
|
||||||
|
version "3.37.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/util-locate-window/-/util-locate-window-3.37.0.tgz#e041f411e5e6a235e5bcffacc4b7fa90f25d8d01"
|
||||||
|
integrity sha512-NvDCfOhLLVHp27oGUUs8EVirhz91aX5gdxGS7J/sh5PF0cNN8rwaR1vSLR7BxPmJHMO7NH7i9EwiELfLfYcq6g==
|
||||||
|
dependencies:
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/util-uri-escape@3.37.0":
|
||||||
|
version "3.37.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/util-uri-escape/-/util-uri-escape-3.37.0.tgz#42b8393a51dcc04f228e70d1c94c2fe38a738994"
|
||||||
|
integrity sha512-8pKf4YJTELP5lm/CEgYw2atyJBB1RWWqFa0sZx6YJmTlOtLF5G6raUdAi4iDa2hldGt2B6IAdIIyuusT8zeU8Q==
|
||||||
|
dependencies:
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/util-user-agent-browser@3.40.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/util-user-agent-browser/-/util-user-agent-browser-3.40.0.tgz#d9f4f49af35895df260598a333a8b792b56e9f76"
|
||||||
|
integrity sha512-C69sTI26bV2EprTv3DTXu9XP7kD9Wu4YVPBzqztOYArd2GDYw3w+jS8SEg3XRbjAKY/mOPZ2Thw4StjpZlWZiA==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
bowser "^2.11.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/util-user-agent-node@3.40.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/util-user-agent-node/-/util-user-agent-node-3.40.0.tgz#76240a4ee05e409ad1267854761c53e746e9bcdf"
|
||||||
|
integrity sha512-cjIzd0hRZFTTh7iLJD6Bciu++Em1iaM1clyG02xRl0JD5DEtDSR1zO02uu+AeM7GSLGOxIvwOkK2j8ySPAOmBA==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/node-config-provider" "3.40.0"
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/util-utf8-browser@3.37.0", "@aws-sdk/util-utf8-browser@^3.0.0":
|
||||||
|
version "3.37.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/util-utf8-browser/-/util-utf8-browser-3.37.0.tgz#d896899f4c475ceeaf8b77c5d7cdc453e5fe6b83"
|
||||||
|
integrity sha512-tuiOxzfqet1kKGYzlgpMGfhr64AHJnYsFx2jZiH/O6Yq8XQg43ryjQlbJlim/K/XHGNzY0R+nabeJg34q3Ua1g==
|
||||||
|
dependencies:
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/util-utf8-node@3.37.0":
|
||||||
|
version "3.37.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/util-utf8-node/-/util-utf8-node-3.37.0.tgz#300912cce55d72c18213190237d6ab943e17b5bf"
|
||||||
|
integrity sha512-fUAgd7UTCULL36j9/vnXHxVhxvswnq23mYgTCIT8NQ7wHN30q2a89ym1e9DwGeQkJEBOkOcKLn6nsMsN7YQMDQ==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/util-buffer-from" "3.37.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@aws-sdk/util-waiter@3.40.0":
|
||||||
|
version "3.40.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/@aws-sdk/util-waiter/-/util-waiter-3.40.0.tgz#91c537efc9d0129fb24d9bdab86acbfd797ddf1f"
|
||||||
|
integrity sha512-jdxwNEZdID49ZvyAnxaeNm5w2moIfMLOwj/q6TxKlxYoXMs16FQWkhyfGue0vEASzchS49ewbyt+KBqpT31Ebg==
|
||||||
|
dependencies:
|
||||||
|
"@aws-sdk/abort-controller" "3.40.0"
|
||||||
|
"@aws-sdk/types" "3.40.0"
|
||||||
|
tslib "^2.3.0"
|
||||||
|
|
||||||
|
"@babel/code-frame@^7.0.0", "@babel/code-frame@^7.14.5":
|
||||||
|
version "7.14.5"
|
||||||
|
resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.14.5.tgz#23b08d740e83f49c5e59945fbf1b43e80bbf4edb"
|
||||||
|
integrity sha512-9pzDqyc6OLDaqe+zbACgFkb6fKMNG6CObKpnYXChRsvYGyEdc7CA2BaqeOM+vOtCS5ndmJicPJhKAwYRI6UfFw==
|
||||||
|
dependencies:
|
||||||
|
"@babel/highlight" "^7.14.5"
|
||||||
|
|
||||||
|
"@babel/compat-data@^7.14.5":
|
||||||
|
version "7.14.7"
|
||||||
|
resolved "https://registry.yarnpkg.com/@babel/compat-data/-/compat-data-7.14.7.tgz#7b047d7a3a89a67d2258dc61f604f098f1bc7e08"
|
||||||
|
integrity sha512-nS6dZaISCXJ3+518CWiBfEr//gHyMO02uDxBkXTKZDN5POruCnOZ1N4YBRZDCabwF8nZMWBpRxIicmXtBs+fvw==
|
||||||
|
|
||||||
"@babel/core@^7.1.0", "@babel/core@^7.7.5":
|
"@babel/core@^7.1.0", "@babel/core@^7.7.5":
|
||||||
version "7.11.4"
|
version "7.14.6"
|
||||||
resolved "https://registry.yarnpkg.com/@babel/core/-/core-7.11.4.tgz#4301dfdfafa01eeb97f1896c5501a3f0655d4229"
|
resolved "https://registry.yarnpkg.com/@babel/core/-/core-7.14.6.tgz#e0814ec1a950032ff16c13a2721de39a8416fcab"
|
||||||
integrity sha512-5deljj5HlqRXN+5oJTY7Zs37iH3z3b++KjiKtIsJy1NrjOOVSEaJHEetLBhyu0aQOSNNZ/0IuEAan9GzRuDXHg==
|
integrity sha512-gJnOEWSqTk96qG5BoIrl5bVtc23DCycmIePPYnamY9RboYdI4nFy5vAQMSl81O5K/W0sLDWfGysnOECC+KUUCA==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/code-frame" "^7.10.4"
|
"@babel/code-frame" "^7.14.5"
|
||||||
"@babel/generator" "^7.11.4"
|
"@babel/generator" "^7.14.5"
|
||||||
"@babel/helper-module-transforms" "^7.11.0"
|
"@babel/helper-compilation-targets" "^7.14.5"
|
||||||
"@babel/helpers" "^7.10.4"
|
"@babel/helper-module-transforms" "^7.14.5"
|
||||||
"@babel/parser" "^7.11.4"
|
"@babel/helpers" "^7.14.6"
|
||||||
"@babel/template" "^7.10.4"
|
"@babel/parser" "^7.14.6"
|
||||||
"@babel/traverse" "^7.11.0"
|
"@babel/template" "^7.14.5"
|
||||||
"@babel/types" "^7.11.0"
|
"@babel/traverse" "^7.14.5"
|
||||||
|
"@babel/types" "^7.14.5"
|
||||||
convert-source-map "^1.7.0"
|
convert-source-map "^1.7.0"
|
||||||
debug "^4.1.0"
|
debug "^4.1.0"
|
||||||
gensync "^1.0.0-beta.1"
|
gensync "^1.0.0-beta.2"
|
||||||
json5 "^2.1.2"
|
json5 "^2.1.2"
|
||||||
lodash "^4.17.19"
|
semver "^6.3.0"
|
||||||
resolve "^1.3.2"
|
|
||||||
semver "^5.4.1"
|
|
||||||
source-map "^0.5.0"
|
source-map "^0.5.0"
|
||||||
|
|
||||||
"@babel/generator@^7.11.0", "@babel/generator@^7.11.4":
|
"@babel/generator@^7.14.5":
|
||||||
version "7.11.4"
|
version "7.14.5"
|
||||||
resolved "https://registry.yarnpkg.com/@babel/generator/-/generator-7.11.4.tgz#1ec7eec00defba5d6f83e50e3ee72ae2fee482be"
|
resolved "https://registry.yarnpkg.com/@babel/generator/-/generator-7.14.5.tgz#848d7b9f031caca9d0cd0af01b063f226f52d785"
|
||||||
integrity sha512-Rn26vueFx0eOoz7iifCN2UHT6rGtnkSGWSoDRIy8jZN3B91PzeSULbswfLoOWuTuAcNwpG/mxy+uCTDnZ9Mp1g==
|
integrity sha512-y3rlP+/G25OIX3mYKKIOlQRcqj7YgrvHxOLbVmyLJ9bPmi5ttvUmpydVjcFjZphOktWuA7ovbx91ECloWTfjIA==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/types" "^7.11.0"
|
"@babel/types" "^7.14.5"
|
||||||
jsesc "^2.5.1"
|
jsesc "^2.5.1"
|
||||||
source-map "^0.5.0"
|
source-map "^0.5.0"
|
||||||
|
|
||||||
"@babel/helper-function-name@^7.10.4":
|
"@babel/helper-compilation-targets@^7.14.5":
|
||||||
version "7.10.4"
|
version "7.14.5"
|
||||||
resolved "https://registry.yarnpkg.com/@babel/helper-function-name/-/helper-function-name-7.10.4.tgz#d2d3b20c59ad8c47112fa7d2a94bc09d5ef82f1a"
|
resolved "https://registry.yarnpkg.com/@babel/helper-compilation-targets/-/helper-compilation-targets-7.14.5.tgz#7a99c5d0967911e972fe2c3411f7d5b498498ecf"
|
||||||
integrity sha512-YdaSyz1n8gY44EmN7x44zBn9zQ1Ry2Y+3GTA+3vH6Mizke1Vw0aWDM66FOYEPw8//qKkmqOckrGgTYa+6sceqQ==
|
integrity sha512-v+QtZqXEiOnpO6EYvlImB6zCD2Lel06RzOPzmkz/D/XgQiUu3C/Jb1LOqSt/AIA34TYi/Q+KlT8vTQrgdxkbLw==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/helper-get-function-arity" "^7.10.4"
|
"@babel/compat-data" "^7.14.5"
|
||||||
"@babel/template" "^7.10.4"
|
"@babel/helper-validator-option" "^7.14.5"
|
||||||
"@babel/types" "^7.10.4"
|
browserslist "^4.16.6"
|
||||||
|
semver "^6.3.0"
|
||||||
|
|
||||||
"@babel/helper-get-function-arity@^7.10.4":
|
"@babel/helper-function-name@^7.14.5":
|
||||||
version "7.10.4"
|
version "7.14.5"
|
||||||
resolved "https://registry.yarnpkg.com/@babel/helper-get-function-arity/-/helper-get-function-arity-7.10.4.tgz#98c1cbea0e2332f33f9a4661b8ce1505b2c19ba2"
|
resolved "https://registry.yarnpkg.com/@babel/helper-function-name/-/helper-function-name-7.14.5.tgz#89e2c474972f15d8e233b52ee8c480e2cfcd50c4"
|
||||||
integrity sha512-EkN3YDB+SRDgiIUnNgcmiD361ti+AVbL3f3Henf6dqqUyr5dMsorno0lJWJuLhDhkI5sYEpgj6y9kB8AOU1I2A==
|
integrity sha512-Gjna0AsXWfFvrAuX+VKcN/aNNWonizBj39yGwUzVDVTlMYJMK2Wp6xdpy72mfArFq5uK+NOuexfzZlzI1z9+AQ==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/types" "^7.10.4"
|
"@babel/helper-get-function-arity" "^7.14.5"
|
||||||
|
"@babel/template" "^7.14.5"
|
||||||
|
"@babel/types" "^7.14.5"
|
||||||
|
|
||||||
"@babel/helper-member-expression-to-functions@^7.10.4":
|
"@babel/helper-get-function-arity@^7.14.5":
|
||||||
version "7.11.0"
|
version "7.14.5"
|
||||||
resolved "https://registry.yarnpkg.com/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.11.0.tgz#ae69c83d84ee82f4b42f96e2a09410935a8f26df"
|
resolved "https://registry.yarnpkg.com/@babel/helper-get-function-arity/-/helper-get-function-arity-7.14.5.tgz#25fbfa579b0937eee1f3b805ece4ce398c431815"
|
||||||
integrity sha512-JbFlKHFntRV5qKw3YC0CvQnDZ4XMwgzzBbld7Ly4Mj4cbFy3KywcR8NtNctRToMWJOVvLINJv525Gd6wwVEx/Q==
|
integrity sha512-I1Db4Shst5lewOM4V+ZKJzQ0JGGaZ6VY1jYvMghRjqs6DWgxLCIyFt30GlnKkfUeFLpJt2vzbMVEXVSXlIFYUg==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/types" "^7.11.0"
|
"@babel/types" "^7.14.5"
|
||||||
|
|
||||||
"@babel/helper-module-imports@^7.10.4":
|
"@babel/helper-hoist-variables@^7.14.5":
|
||||||
version "7.10.4"
|
version "7.14.5"
|
||||||
resolved "https://registry.yarnpkg.com/@babel/helper-module-imports/-/helper-module-imports-7.10.4.tgz#4c5c54be04bd31670a7382797d75b9fa2e5b5620"
|
resolved "https://registry.yarnpkg.com/@babel/helper-hoist-variables/-/helper-hoist-variables-7.14.5.tgz#e0dd27c33a78e577d7c8884916a3e7ef1f7c7f8d"
|
||||||
integrity sha512-nEQJHqYavI217oD9+s5MUBzk6x1IlvoS9WTPfgG43CbMEeStE0v+r+TucWdx8KFGowPGvyOkDT9+7DHedIDnVw==
|
integrity sha512-R1PXiz31Uc0Vxy4OEOm07x0oSjKAdPPCh3tPivn/Eo8cvz6gveAeuyUUPB21Hoiif0uoPQSSdhIPS3352nvdyQ==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/types" "^7.10.4"
|
"@babel/types" "^7.14.5"
|
||||||
|
|
||||||
"@babel/helper-module-transforms@^7.11.0":
|
"@babel/helper-member-expression-to-functions@^7.14.5":
|
||||||
version "7.11.0"
|
version "7.14.7"
|
||||||
resolved "https://registry.yarnpkg.com/@babel/helper-module-transforms/-/helper-module-transforms-7.11.0.tgz#b16f250229e47211abdd84b34b64737c2ab2d359"
|
resolved "https://registry.yarnpkg.com/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.14.7.tgz#97e56244beb94211fe277bd818e3a329c66f7970"
|
||||||
integrity sha512-02EVu8COMuTRO1TAzdMtpBPbe6aQ1w/8fePD2YgQmxZU4gpNWaL9gK3Jp7dxlkUlUCJOTaSeA+Hrm1BRQwqIhg==
|
integrity sha512-TMUt4xKxJn6ccjcOW7c4hlwyJArizskAhoSTOCkA0uZ+KghIaci0Qg9R043kUMWI9mtQfgny+NQ5QATnZ+paaA==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/helper-module-imports" "^7.10.4"
|
"@babel/types" "^7.14.5"
|
||||||
"@babel/helper-replace-supers" "^7.10.4"
|
|
||||||
"@babel/helper-simple-access" "^7.10.4"
|
|
||||||
"@babel/helper-split-export-declaration" "^7.11.0"
|
|
||||||
"@babel/template" "^7.10.4"
|
|
||||||
"@babel/types" "^7.11.0"
|
|
||||||
lodash "^4.17.19"
|
|
||||||
|
|
||||||
"@babel/helper-optimise-call-expression@^7.10.4":
|
"@babel/helper-module-imports@^7.14.5":
|
||||||
version "7.10.4"
|
version "7.14.5"
|
||||||
resolved "https://registry.yarnpkg.com/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.10.4.tgz#50dc96413d594f995a77905905b05893cd779673"
|
resolved "https://registry.yarnpkg.com/@babel/helper-module-imports/-/helper-module-imports-7.14.5.tgz#6d1a44df6a38c957aa7c312da076429f11b422f3"
|
||||||
integrity sha512-n3UGKY4VXwXThEiKrgRAoVPBMqeoPgHVqiHZOanAJCG9nQUL2pLRQirUzl0ioKclHGpGqRgIOkgcIJaIWLpygg==
|
integrity sha512-SwrNHu5QWS84XlHwGYPDtCxcA0hrSlL2yhWYLgeOc0w7ccOl2qv4s/nARI0aYZW+bSwAL5CukeXA47B/1NKcnQ==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/types" "^7.10.4"
|
"@babel/types" "^7.14.5"
|
||||||
|
|
||||||
"@babel/helper-plugin-utils@^7.0.0", "@babel/helper-plugin-utils@^7.10.4", "@babel/helper-plugin-utils@^7.8.0":
|
"@babel/helper-module-transforms@^7.14.5":
|
||||||
version "7.10.4"
|
version "7.14.5"
|
||||||
resolved "https://registry.yarnpkg.com/@babel/helper-plugin-utils/-/helper-plugin-utils-7.10.4.tgz#2f75a831269d4f677de49986dff59927533cf375"
|
resolved "https://registry.yarnpkg.com/@babel/helper-module-transforms/-/helper-module-transforms-7.14.5.tgz#7de42f10d789b423eb902ebd24031ca77cb1e10e"
|
||||||
integrity sha512-O4KCvQA6lLiMU9l2eawBPMf1xPP8xPfB3iEQw150hOVTqj/rfXz0ThTb4HEzqQfs2Bmo5Ay8BzxfzVtBrr9dVg==
|
integrity sha512-iXpX4KW8LVODuAieD7MzhNjmM6dzYY5tfRqT+R9HDXWl0jPn/djKmA+G9s/2C2T9zggw5tK1QNqZ70USfedOwA==
|
||||||
|
|
||||||
"@babel/helper-replace-supers@^7.10.4":
|
|
||||||
version "7.10.4"
|
|
||||||
resolved "https://registry.yarnpkg.com/@babel/helper-replace-supers/-/helper-replace-supers-7.10.4.tgz#d585cd9388ea06e6031e4cd44b6713cbead9e6cf"
|
|
||||||
integrity sha512-sPxZfFXocEymYTdVK1UNmFPBN+Hv5mJkLPsYWwGBxZAxaWfFu+xqp7b6qWD0yjNuNL2VKc6L5M18tOXUP7NU0A==
|
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/helper-member-expression-to-functions" "^7.10.4"
|
"@babel/helper-module-imports" "^7.14.5"
|
||||||
"@babel/helper-optimise-call-expression" "^7.10.4"
|
"@babel/helper-replace-supers" "^7.14.5"
|
||||||
"@babel/traverse" "^7.10.4"
|
"@babel/helper-simple-access" "^7.14.5"
|
||||||
"@babel/types" "^7.10.4"
|
"@babel/helper-split-export-declaration" "^7.14.5"
|
||||||
|
"@babel/helper-validator-identifier" "^7.14.5"
|
||||||
|
"@babel/template" "^7.14.5"
|
||||||
|
"@babel/traverse" "^7.14.5"
|
||||||
|
"@babel/types" "^7.14.5"
|
||||||
|
|
||||||
"@babel/helper-simple-access@^7.10.4":
|
"@babel/helper-optimise-call-expression@^7.14.5":
|
||||||
version "7.10.4"
|
version "7.14.5"
|
||||||
resolved "https://registry.yarnpkg.com/@babel/helper-simple-access/-/helper-simple-access-7.10.4.tgz#0f5ccda2945277a2a7a2d3a821e15395edcf3461"
|
resolved "https://registry.yarnpkg.com/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.14.5.tgz#f27395a8619e0665b3f0364cddb41c25d71b499c"
|
||||||
integrity sha512-0fMy72ej/VEvF8ULmX6yb5MtHG4uH4Dbd6I/aHDb/JVg0bbivwt9Wg+h3uMvX+QSFtwr5MeItvazbrc4jtRAXw==
|
integrity sha512-IqiLIrODUOdnPU9/F8ib1Fx2ohlgDhxnIDU7OEVi+kAbEZcyiF7BLU8W6PfvPi9LzztjS7kcbzbmL7oG8kD6VA==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/template" "^7.10.4"
|
"@babel/types" "^7.14.5"
|
||||||
"@babel/types" "^7.10.4"
|
|
||||||
|
|
||||||
"@babel/helper-split-export-declaration@^7.11.0":
|
"@babel/helper-plugin-utils@^7.0.0", "@babel/helper-plugin-utils@^7.10.4", "@babel/helper-plugin-utils@^7.12.13", "@babel/helper-plugin-utils@^7.14.5", "@babel/helper-plugin-utils@^7.8.0":
|
||||||
version "7.11.0"
|
version "7.14.5"
|
||||||
resolved "https://registry.yarnpkg.com/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.11.0.tgz#f8a491244acf6a676158ac42072911ba83ad099f"
|
resolved "https://registry.yarnpkg.com/@babel/helper-plugin-utils/-/helper-plugin-utils-7.14.5.tgz#5ac822ce97eec46741ab70a517971e443a70c5a9"
|
||||||
integrity sha512-74Vejvp6mHkGE+m+k5vHY93FX2cAtrw1zXrZXRlG4l410Nm9PxfEiVTn1PjDPV5SnmieiueY4AFg2xqhNFuuZg==
|
integrity sha512-/37qQCE3K0vvZKwoK4XU/irIJQdIfCJuhU5eKnNxpFDsOkgFaUAwbv+RYw6eYgsC0E4hS7r5KqGULUogqui0fQ==
|
||||||
|
|
||||||
|
"@babel/helper-replace-supers@^7.14.5":
|
||||||
|
version "7.14.5"
|
||||||
|
resolved "https://registry.yarnpkg.com/@babel/helper-replace-supers/-/helper-replace-supers-7.14.5.tgz#0ecc0b03c41cd567b4024ea016134c28414abb94"
|
||||||
|
integrity sha512-3i1Qe9/8x/hCHINujn+iuHy+mMRLoc77b2nI9TB0zjH1hvn9qGlXjWlggdwUcju36PkPCy/lpM7LLUdcTyH4Ow==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/types" "^7.11.0"
|
"@babel/helper-member-expression-to-functions" "^7.14.5"
|
||||||
|
"@babel/helper-optimise-call-expression" "^7.14.5"
|
||||||
|
"@babel/traverse" "^7.14.5"
|
||||||
|
"@babel/types" "^7.14.5"
|
||||||
|
|
||||||
"@babel/helper-validator-identifier@^7.10.4":
|
"@babel/helper-simple-access@^7.14.5":
|
||||||
version "7.10.4"
|
version "7.14.5"
|
||||||
resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.10.4.tgz#a78c7a7251e01f616512d31b10adcf52ada5e0d2"
|
resolved "https://registry.yarnpkg.com/@babel/helper-simple-access/-/helper-simple-access-7.14.5.tgz#66ea85cf53ba0b4e588ba77fc813f53abcaa41c4"
|
||||||
integrity sha512-3U9y+43hz7ZM+rzG24Qe2mufW5KhvFg/NhnNph+i9mgCtdTCtMJuI1TMkrIUiK7Ix4PYlRF9I5dhqaLYA/ADXw==
|
integrity sha512-nfBN9xvmCt6nrMZjfhkl7i0oTV3yxR4/FztsbOASyTvVcoYd0TRHh7eMLdlEcCqobydC0LAF3LtC92Iwxo0wyw==
|
||||||
|
|
||||||
"@babel/helpers@^7.10.4":
|
|
||||||
version "7.10.4"
|
|
||||||
resolved "https://registry.yarnpkg.com/@babel/helpers/-/helpers-7.10.4.tgz#2abeb0d721aff7c0a97376b9e1f6f65d7a475044"
|
|
||||||
integrity sha512-L2gX/XeUONeEbI78dXSrJzGdz4GQ+ZTA/aazfUsFaWjSe95kiCuOZ5HsXvkiw3iwF+mFHSRUfJU8t6YavocdXA==
|
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/template" "^7.10.4"
|
"@babel/types" "^7.14.5"
|
||||||
"@babel/traverse" "^7.10.4"
|
|
||||||
"@babel/types" "^7.10.4"
|
|
||||||
|
|
||||||
"@babel/highlight@^7.10.4":
|
"@babel/helper-split-export-declaration@^7.14.5":
|
||||||
version "7.10.4"
|
version "7.14.5"
|
||||||
resolved "https://registry.yarnpkg.com/@babel/highlight/-/highlight-7.10.4.tgz#7d1bdfd65753538fabe6c38596cdb76d9ac60143"
|
resolved "https://registry.yarnpkg.com/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.14.5.tgz#22b23a54ef51c2b7605d851930c1976dd0bc693a"
|
||||||
integrity sha512-i6rgnR/YgPEQzZZnbTHHuZdlE8qyoBNalD6F+q4vAFlcMEcqmkoG+mPqJYJCo63qPf74+Y1UZsl3l6f7/RIkmA==
|
integrity sha512-hprxVPu6e5Kdp2puZUmvOGjaLv9TCe58E/Fl6hRq4YiVQxIcNvuq6uTM2r1mT/oPskuS9CgR+I94sqAYv0NGKA==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/helper-validator-identifier" "^7.10.4"
|
"@babel/types" "^7.14.5"
|
||||||
|
|
||||||
|
"@babel/helper-validator-identifier@^7.14.5":
|
||||||
|
version "7.14.5"
|
||||||
|
resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.14.5.tgz#d0f0e277c512e0c938277faa85a3968c9a44c0e8"
|
||||||
|
integrity sha512-5lsetuxCLilmVGyiLEfoHBRX8UCFD+1m2x3Rj97WrW3V7H3u4RWRXA4evMjImCsin2J2YT0QaVDGf+z8ondbAg==
|
||||||
|
|
||||||
|
"@babel/helper-validator-option@^7.14.5":
|
||||||
|
version "7.14.5"
|
||||||
|
resolved "https://registry.yarnpkg.com/@babel/helper-validator-option/-/helper-validator-option-7.14.5.tgz#6e72a1fff18d5dfcb878e1e62f1a021c4b72d5a3"
|
||||||
|
integrity sha512-OX8D5eeX4XwcroVW45NMvoYaIuFI+GQpA2a8Gi+X/U/cDUIRsV37qQfF905F0htTRCREQIB4KqPeaveRJUl3Ow==
|
||||||
|
|
||||||
|
"@babel/helpers@^7.14.6":
|
||||||
|
version "7.14.6"
|
||||||
|
resolved "https://registry.yarnpkg.com/@babel/helpers/-/helpers-7.14.6.tgz#5b58306b95f1b47e2a0199434fa8658fa6c21635"
|
||||||
|
integrity sha512-yesp1ENQBiLI+iYHSJdoZKUtRpfTlL1grDIX9NRlAVppljLw/4tTyYupIB7uIYmC3stW/imAv8EqaKaS/ibmeA==
|
||||||
|
dependencies:
|
||||||
|
"@babel/template" "^7.14.5"
|
||||||
|
"@babel/traverse" "^7.14.5"
|
||||||
|
"@babel/types" "^7.14.5"
|
||||||
|
|
||||||
|
"@babel/highlight@^7.14.5":
|
||||||
|
version "7.14.5"
|
||||||
|
resolved "https://registry.yarnpkg.com/@babel/highlight/-/highlight-7.14.5.tgz#6861a52f03966405001f6aa534a01a24d99e8cd9"
|
||||||
|
integrity sha512-qf9u2WFWVV0MppaL877j2dBtQIDgmidgjGk5VIMw3OadXvYaXn66U1BFlH2t4+t3i+8PhedppRv+i40ABzd+gg==
|
||||||
|
dependencies:
|
||||||
|
"@babel/helper-validator-identifier" "^7.14.5"
|
||||||
chalk "^2.0.0"
|
chalk "^2.0.0"
|
||||||
js-tokens "^4.0.0"
|
js-tokens "^4.0.0"
|
||||||
|
|
||||||
"@babel/parser@^7.1.0", "@babel/parser@^7.10.4", "@babel/parser@^7.11.0", "@babel/parser@^7.11.4":
|
"@babel/parser@^7.1.0", "@babel/parser@^7.14.5", "@babel/parser@^7.14.6", "@babel/parser@^7.14.7":
|
||||||
version "7.11.4"
|
version "7.14.7"
|
||||||
resolved "https://registry.yarnpkg.com/@babel/parser/-/parser-7.11.4.tgz#6fa1a118b8b0d80d0267b719213dc947e88cc0ca"
|
resolved "https://registry.yarnpkg.com/@babel/parser/-/parser-7.14.7.tgz#6099720c8839ca865a2637e6c85852ead0bdb595"
|
||||||
integrity sha512-MggwidiH+E9j5Sh8pbrX5sJvMcsqS5o+7iB42M9/k0CD63MjYbdP4nhSh7uB5wnv2/RVzTZFTxzF/kIa5mrCqA==
|
integrity sha512-X67Z5y+VBJuHB/RjwECp8kSl5uYi0BvRbNeWqkaJCVh+LiTPl19WBUfG627psSgp9rSf6ojuXghQM3ha6qHHdA==
|
||||||
|
|
||||||
"@babel/plugin-syntax-async-generators@^7.8.4":
|
"@babel/plugin-syntax-async-generators@^7.8.4":
|
||||||
version "7.8.4"
|
version "7.8.4"
|
||||||
@@ -180,11 +854,11 @@
|
|||||||
"@babel/helper-plugin-utils" "^7.8.0"
|
"@babel/helper-plugin-utils" "^7.8.0"
|
||||||
|
|
||||||
"@babel/plugin-syntax-class-properties@^7.8.3":
|
"@babel/plugin-syntax-class-properties@^7.8.3":
|
||||||
version "7.10.4"
|
version "7.12.13"
|
||||||
resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.10.4.tgz#6644e6a0baa55a61f9e3231f6c9eeb6ee46c124c"
|
resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz#b5c987274c4a3a82b89714796931a6b53544ae10"
|
||||||
integrity sha512-GCSBF7iUle6rNugfURwNmCGG3Z/2+opxAMLs1nND4bhEG5PuxTIggDBoeYYSujAlLtsupzOHYJQgPS3pivwXIA==
|
integrity sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/helper-plugin-utils" "^7.10.4"
|
"@babel/helper-plugin-utils" "^7.12.13"
|
||||||
|
|
||||||
"@babel/plugin-syntax-import-meta@^7.8.3":
|
"@babel/plugin-syntax-import-meta@^7.8.3":
|
||||||
version "7.10.4"
|
version "7.10.4"
|
||||||
@@ -242,37 +916,43 @@
|
|||||||
dependencies:
|
dependencies:
|
||||||
"@babel/helper-plugin-utils" "^7.8.0"
|
"@babel/helper-plugin-utils" "^7.8.0"
|
||||||
|
|
||||||
"@babel/template@^7.10.4", "@babel/template@^7.3.3":
|
"@babel/plugin-syntax-top-level-await@^7.8.3":
|
||||||
version "7.10.4"
|
version "7.14.5"
|
||||||
resolved "https://registry.yarnpkg.com/@babel/template/-/template-7.10.4.tgz#3251996c4200ebc71d1a8fc405fba940f36ba278"
|
resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz#c1cfdadc35a646240001f06138247b741c34d94c"
|
||||||
integrity sha512-ZCjD27cGJFUB6nmCB1Enki3r+L5kJveX9pq1SvAUKoICy6CZ9yD8xO086YXdYhvNjBdnekm4ZnaP5yC8Cs/1tA==
|
integrity sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/code-frame" "^7.10.4"
|
"@babel/helper-plugin-utils" "^7.14.5"
|
||||||
"@babel/parser" "^7.10.4"
|
|
||||||
"@babel/types" "^7.10.4"
|
|
||||||
|
|
||||||
"@babel/traverse@^7.1.0", "@babel/traverse@^7.10.4", "@babel/traverse@^7.11.0":
|
"@babel/template@^7.14.5", "@babel/template@^7.3.3":
|
||||||
version "7.11.0"
|
version "7.14.5"
|
||||||
resolved "https://registry.yarnpkg.com/@babel/traverse/-/traverse-7.11.0.tgz#9b996ce1b98f53f7c3e4175115605d56ed07dd24"
|
resolved "https://registry.yarnpkg.com/@babel/template/-/template-7.14.5.tgz#a9bc9d8b33354ff6e55a9c60d1109200a68974f4"
|
||||||
integrity sha512-ZB2V+LskoWKNpMq6E5UUCrjtDUh5IOTAyIl0dTjIEoXum/iKWkoIEKIRDnUucO6f+2FzNkE0oD4RLKoPIufDtg==
|
integrity sha512-6Z3Po85sfxRGachLULUhOmvAaOo7xCvqGQtxINai2mEGPFm6pQ4z5QInFnUrRpfoSV60BnjyF5F3c+15fxFV1g==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/code-frame" "^7.10.4"
|
"@babel/code-frame" "^7.14.5"
|
||||||
"@babel/generator" "^7.11.0"
|
"@babel/parser" "^7.14.5"
|
||||||
"@babel/helper-function-name" "^7.10.4"
|
"@babel/types" "^7.14.5"
|
||||||
"@babel/helper-split-export-declaration" "^7.11.0"
|
|
||||||
"@babel/parser" "^7.11.0"
|
"@babel/traverse@^7.1.0", "@babel/traverse@^7.14.5":
|
||||||
"@babel/types" "^7.11.0"
|
version "7.14.7"
|
||||||
|
resolved "https://registry.yarnpkg.com/@babel/traverse/-/traverse-7.14.7.tgz#64007c9774cfdc3abd23b0780bc18a3ce3631753"
|
||||||
|
integrity sha512-9vDr5NzHu27wgwejuKL7kIOm4bwEtaPQ4Z6cpCmjSuaRqpH/7xc4qcGEscwMqlkwgcXl6MvqoAjZkQ24uSdIZQ==
|
||||||
|
dependencies:
|
||||||
|
"@babel/code-frame" "^7.14.5"
|
||||||
|
"@babel/generator" "^7.14.5"
|
||||||
|
"@babel/helper-function-name" "^7.14.5"
|
||||||
|
"@babel/helper-hoist-variables" "^7.14.5"
|
||||||
|
"@babel/helper-split-export-declaration" "^7.14.5"
|
||||||
|
"@babel/parser" "^7.14.7"
|
||||||
|
"@babel/types" "^7.14.5"
|
||||||
debug "^4.1.0"
|
debug "^4.1.0"
|
||||||
globals "^11.1.0"
|
globals "^11.1.0"
|
||||||
lodash "^4.17.19"
|
|
||||||
|
|
||||||
"@babel/types@^7.0.0", "@babel/types@^7.10.4", "@babel/types@^7.11.0", "@babel/types@^7.3.0", "@babel/types@^7.3.3":
|
"@babel/types@^7.0.0", "@babel/types@^7.14.5", "@babel/types@^7.3.0", "@babel/types@^7.3.3":
|
||||||
version "7.11.0"
|
version "7.14.5"
|
||||||
resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.11.0.tgz#2ae6bf1ba9ae8c3c43824e5861269871b206e90d"
|
resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.14.5.tgz#3bb997ba829a2104cedb20689c4a5b8121d383ff"
|
||||||
integrity sha512-O53yME4ZZI0jO1EVGtF1ePGl0LHirG4P1ibcD80XyzZcKhcMFeCXmh4Xb1ifGBIV233Qg12x4rBfQgA+tmOukA==
|
integrity sha512-M/NzBpEL95I5Hh4dwhin5JlE7EzO5PHMAuzjxss3tiOBD46KfQvVedN/3jEPZvdRvtsK2222XfdHogNIttFgcg==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/helper-validator-identifier" "^7.10.4"
|
"@babel/helper-validator-identifier" "^7.14.5"
|
||||||
lodash "^4.17.19"
|
|
||||||
to-fast-properties "^2.0.0"
|
to-fast-properties "^2.0.0"
|
||||||
|
|
||||||
"@bcoe/v8-coverage@^0.2.3":
|
"@bcoe/v8-coverage@^0.2.3":
|
||||||
@@ -300,97 +980,97 @@
|
|||||||
resolve-from "^5.0.0"
|
resolve-from "^5.0.0"
|
||||||
|
|
||||||
"@istanbuljs/schema@^0.1.2":
|
"@istanbuljs/schema@^0.1.2":
|
||||||
version "0.1.2"
|
version "0.1.3"
|
||||||
resolved "https://registry.yarnpkg.com/@istanbuljs/schema/-/schema-0.1.2.tgz#26520bf09abe4a5644cd5414e37125a8954241dd"
|
resolved "https://registry.yarnpkg.com/@istanbuljs/schema/-/schema-0.1.3.tgz#e45e384e4b8ec16bce2fd903af78450f6bf7ec98"
|
||||||
integrity sha512-tsAQNx32a8CoFhjhijUIhI4kccIAgmGhy8LZMZgGfmXcpMbPRUqn5LWmgRttILi6yeGmBJd2xsPkFMs0PzgPCw==
|
integrity sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA==
|
||||||
|
|
||||||
"@jest/console@^26.3.0":
|
"@jest/console@^26.6.2":
|
||||||
version "26.3.0"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/@jest/console/-/console-26.3.0.tgz#ed04063efb280c88ba87388b6f16427c0a85c856"
|
resolved "https://registry.yarnpkg.com/@jest/console/-/console-26.6.2.tgz#4e04bc464014358b03ab4937805ee36a0aeb98f2"
|
||||||
integrity sha512-/5Pn6sJev0nPUcAdpJHMVIsA8sKizL2ZkcKPE5+dJrCccks7tcM7c9wbgHudBJbxXLoTbqsHkG1Dofoem4F09w==
|
integrity sha512-IY1R2i2aLsLr7Id3S6p2BA82GNWryt4oSvEXLAKc+L2zdi89dSkE8xC1C+0kpATG4JhBJREnQOH7/zmccM2B0g==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
"@types/node" "*"
|
"@types/node" "*"
|
||||||
chalk "^4.0.0"
|
chalk "^4.0.0"
|
||||||
jest-message-util "^26.3.0"
|
jest-message-util "^26.6.2"
|
||||||
jest-util "^26.3.0"
|
jest-util "^26.6.2"
|
||||||
slash "^3.0.0"
|
slash "^3.0.0"
|
||||||
|
|
||||||
"@jest/core@^26.4.1":
|
"@jest/core@^26.6.3":
|
||||||
version "26.4.1"
|
version "26.6.3"
|
||||||
resolved "https://registry.yarnpkg.com/@jest/core/-/core-26.4.1.tgz#04af2e4d985e035e13ef94d61d302a8458f587e9"
|
resolved "https://registry.yarnpkg.com/@jest/core/-/core-26.6.3.tgz#7639fcb3833d748a4656ada54bde193051e45fad"
|
||||||
integrity sha512-EFziH1tJC5N8xb8OjUcQgyWdezJh6+zBX5p+9S7HR1jzBVeG8jCE/Edp7yqxW/cToLG/QKj8qrpox+HV9Qw1rw==
|
integrity sha512-xvV1kKbhfUqFVuZ8Cyo+JPpipAHHAV3kcDBftiduK8EICXmTFddryy3P7NfZt8Pv37rA9nEJBKCCkglCPt/Xjw==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@jest/console" "^26.3.0"
|
"@jest/console" "^26.6.2"
|
||||||
"@jest/reporters" "^26.4.1"
|
"@jest/reporters" "^26.6.2"
|
||||||
"@jest/test-result" "^26.3.0"
|
"@jest/test-result" "^26.6.2"
|
||||||
"@jest/transform" "^26.3.0"
|
"@jest/transform" "^26.6.2"
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
"@types/node" "*"
|
"@types/node" "*"
|
||||||
ansi-escapes "^4.2.1"
|
ansi-escapes "^4.2.1"
|
||||||
chalk "^4.0.0"
|
chalk "^4.0.0"
|
||||||
exit "^0.1.2"
|
exit "^0.1.2"
|
||||||
graceful-fs "^4.2.4"
|
graceful-fs "^4.2.4"
|
||||||
jest-changed-files "^26.3.0"
|
jest-changed-files "^26.6.2"
|
||||||
jest-config "^26.4.1"
|
jest-config "^26.6.3"
|
||||||
jest-haste-map "^26.3.0"
|
jest-haste-map "^26.6.2"
|
||||||
jest-message-util "^26.3.0"
|
jest-message-util "^26.6.2"
|
||||||
jest-regex-util "^26.0.0"
|
jest-regex-util "^26.0.0"
|
||||||
jest-resolve "^26.4.0"
|
jest-resolve "^26.6.2"
|
||||||
jest-resolve-dependencies "^26.4.1"
|
jest-resolve-dependencies "^26.6.3"
|
||||||
jest-runner "^26.4.1"
|
jest-runner "^26.6.3"
|
||||||
jest-runtime "^26.4.1"
|
jest-runtime "^26.6.3"
|
||||||
jest-snapshot "^26.4.1"
|
jest-snapshot "^26.6.2"
|
||||||
jest-util "^26.3.0"
|
jest-util "^26.6.2"
|
||||||
jest-validate "^26.4.0"
|
jest-validate "^26.6.2"
|
||||||
jest-watcher "^26.3.0"
|
jest-watcher "^26.6.2"
|
||||||
micromatch "^4.0.2"
|
micromatch "^4.0.2"
|
||||||
p-each-series "^2.1.0"
|
p-each-series "^2.1.0"
|
||||||
rimraf "^3.0.0"
|
rimraf "^3.0.0"
|
||||||
slash "^3.0.0"
|
slash "^3.0.0"
|
||||||
strip-ansi "^6.0.0"
|
strip-ansi "^6.0.0"
|
||||||
|
|
||||||
"@jest/environment@^26.3.0":
|
"@jest/environment@^26.6.2":
|
||||||
version "26.3.0"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/@jest/environment/-/environment-26.3.0.tgz#e6953ab711ae3e44754a025f838bde1a7fd236a0"
|
resolved "https://registry.yarnpkg.com/@jest/environment/-/environment-26.6.2.tgz#ba364cc72e221e79cc8f0a99555bf5d7577cf92c"
|
||||||
integrity sha512-EW+MFEo0DGHahf83RAaiqQx688qpXgl99wdb8Fy67ybyzHwR1a58LHcO376xQJHfmoXTu89M09dH3J509cx2AA==
|
integrity sha512-nFy+fHl28zUrRsCeMB61VDThV1pVTtlEokBRgqPrcT1JNq4yRNIyTHfyht6PqtUvY9IsuLGTrbG8kPXjSZIZwA==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@jest/fake-timers" "^26.3.0"
|
"@jest/fake-timers" "^26.6.2"
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
"@types/node" "*"
|
"@types/node" "*"
|
||||||
jest-mock "^26.3.0"
|
jest-mock "^26.6.2"
|
||||||
|
|
||||||
"@jest/fake-timers@^26.3.0":
|
"@jest/fake-timers@^26.6.2":
|
||||||
version "26.3.0"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/@jest/fake-timers/-/fake-timers-26.3.0.tgz#f515d4667a6770f60ae06ae050f4e001126c666a"
|
resolved "https://registry.yarnpkg.com/@jest/fake-timers/-/fake-timers-26.6.2.tgz#459c329bcf70cee4af4d7e3f3e67848123535aad"
|
||||||
integrity sha512-ZL9ytUiRwVP8ujfRepffokBvD2KbxbqMhrXSBhSdAhISCw3gOkuntisiSFv+A6HN0n0fF4cxzICEKZENLmW+1A==
|
integrity sha512-14Uleatt7jdzefLPYM3KLcnUl1ZNikaKq34enpb5XG9i81JpppDb5muZvonvKyrl7ftEHkKS5L5/eB/kxJ+bvA==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
"@sinonjs/fake-timers" "^6.0.1"
|
"@sinonjs/fake-timers" "^6.0.1"
|
||||||
"@types/node" "*"
|
"@types/node" "*"
|
||||||
jest-message-util "^26.3.0"
|
jest-message-util "^26.6.2"
|
||||||
jest-mock "^26.3.0"
|
jest-mock "^26.6.2"
|
||||||
jest-util "^26.3.0"
|
jest-util "^26.6.2"
|
||||||
|
|
||||||
"@jest/globals@^26.4.1":
|
"@jest/globals@^26.6.2":
|
||||||
version "26.4.1"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/@jest/globals/-/globals-26.4.1.tgz#4e8f6721f081444eda86a7c3e4ceefcf2baa5de1"
|
resolved "https://registry.yarnpkg.com/@jest/globals/-/globals-26.6.2.tgz#5b613b78a1aa2655ae908eba638cc96a20df720a"
|
||||||
integrity sha512-gdsHefnwjck+AwDUwW+6rmctmKEcZEEZ4F3PB5kKnub7r0dUoN1KVSyNRXtB5qpZgRYESnxgDXhpw/XYKIsAeg==
|
integrity sha512-85Ltnm7HlB/KesBUuALwQ68YTU72w9H2xW9FjZ1eL1U3lhtefjjl5c2MiUbpXt/i6LaPRvoOFJ22yCBSfQ0JIA==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@jest/environment" "^26.3.0"
|
"@jest/environment" "^26.6.2"
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
expect "^26.4.1"
|
expect "^26.6.2"
|
||||||
|
|
||||||
"@jest/reporters@^26.4.1":
|
"@jest/reporters@^26.6.2":
|
||||||
version "26.4.1"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/@jest/reporters/-/reporters-26.4.1.tgz#3b4d6faf28650f3965f8b97bc3d114077fb71795"
|
resolved "https://registry.yarnpkg.com/@jest/reporters/-/reporters-26.6.2.tgz#1f518b99637a5f18307bd3ecf9275f6882a667f6"
|
||||||
integrity sha512-aROTkCLU8++yiRGVxLsuDmZsQEKO6LprlrxtAuzvtpbIFl3eIjgIf3EUxDKgomkS25R9ZzwGEdB5weCcBZlrpQ==
|
integrity sha512-h2bW53APG4HvkOnVMo8q3QXa6pcaNt1HkwVsOPMBV6LD/q9oSpxNSYZQYkAnjdMjrJ86UuYeLo+aEZClV6opnw==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@bcoe/v8-coverage" "^0.2.3"
|
"@bcoe/v8-coverage" "^0.2.3"
|
||||||
"@jest/console" "^26.3.0"
|
"@jest/console" "^26.6.2"
|
||||||
"@jest/test-result" "^26.3.0"
|
"@jest/test-result" "^26.6.2"
|
||||||
"@jest/transform" "^26.3.0"
|
"@jest/transform" "^26.6.2"
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
chalk "^4.0.0"
|
chalk "^4.0.0"
|
||||||
collect-v8-coverage "^1.0.0"
|
collect-v8-coverage "^1.0.0"
|
||||||
exit "^0.1.2"
|
exit "^0.1.2"
|
||||||
@@ -401,83 +1081,73 @@
|
|||||||
istanbul-lib-report "^3.0.0"
|
istanbul-lib-report "^3.0.0"
|
||||||
istanbul-lib-source-maps "^4.0.0"
|
istanbul-lib-source-maps "^4.0.0"
|
||||||
istanbul-reports "^3.0.2"
|
istanbul-reports "^3.0.2"
|
||||||
jest-haste-map "^26.3.0"
|
jest-haste-map "^26.6.2"
|
||||||
jest-resolve "^26.4.0"
|
jest-resolve "^26.6.2"
|
||||||
jest-util "^26.3.0"
|
jest-util "^26.6.2"
|
||||||
jest-worker "^26.3.0"
|
jest-worker "^26.6.2"
|
||||||
slash "^3.0.0"
|
slash "^3.0.0"
|
||||||
source-map "^0.6.0"
|
source-map "^0.6.0"
|
||||||
string-length "^4.0.1"
|
string-length "^4.0.1"
|
||||||
terminal-link "^2.0.0"
|
terminal-link "^2.0.0"
|
||||||
v8-to-istanbul "^5.0.1"
|
v8-to-istanbul "^7.0.0"
|
||||||
optionalDependencies:
|
optionalDependencies:
|
||||||
node-notifier "^8.0.0"
|
node-notifier "^8.0.0"
|
||||||
|
|
||||||
"@jest/source-map@^26.3.0":
|
"@jest/source-map@^26.6.2":
|
||||||
version "26.3.0"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/@jest/source-map/-/source-map-26.3.0.tgz#0e646e519883c14c551f7b5ae4ff5f1bfe4fc3d9"
|
resolved "https://registry.yarnpkg.com/@jest/source-map/-/source-map-26.6.2.tgz#29af5e1e2e324cafccc936f218309f54ab69d535"
|
||||||
integrity sha512-hWX5IHmMDWe1kyrKl7IhFwqOuAreIwHhbe44+XH2ZRHjrKIh0LO5eLQ/vxHFeAfRwJapmxuqlGAEYLadDq6ZGQ==
|
integrity sha512-YwYcCwAnNmOVsZ8mr3GfnzdXDAl4LaenZP5z+G0c8bzC9/dugL8zRmxZzdoTl4IaS3CryS1uWnROLPFmb6lVvA==
|
||||||
dependencies:
|
dependencies:
|
||||||
callsites "^3.0.0"
|
callsites "^3.0.0"
|
||||||
graceful-fs "^4.2.4"
|
graceful-fs "^4.2.4"
|
||||||
source-map "^0.6.0"
|
source-map "^0.6.0"
|
||||||
|
|
||||||
"@jest/test-result@^26.3.0":
|
"@jest/test-result@^26.6.2":
|
||||||
version "26.3.0"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/@jest/test-result/-/test-result-26.3.0.tgz#46cde01fa10c0aaeb7431bf71e4a20d885bc7fdb"
|
resolved "https://registry.yarnpkg.com/@jest/test-result/-/test-result-26.6.2.tgz#55da58b62df134576cc95476efa5f7949e3f5f18"
|
||||||
integrity sha512-a8rbLqzW/q7HWheFVMtghXV79Xk+GWwOK1FrtimpI5n1la2SY0qHri3/b0/1F0Ve0/yJmV8pEhxDfVwiUBGtgg==
|
integrity sha512-5O7H5c/7YlojphYNrK02LlDIV2GNPYisKwHm2QTKjNZeEzezCbwYs9swJySv2UfPMyZ0VdsmMv7jIlD/IKYQpQ==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@jest/console" "^26.3.0"
|
"@jest/console" "^26.6.2"
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
"@types/istanbul-lib-coverage" "^2.0.0"
|
"@types/istanbul-lib-coverage" "^2.0.0"
|
||||||
collect-v8-coverage "^1.0.0"
|
collect-v8-coverage "^1.0.0"
|
||||||
|
|
||||||
"@jest/test-sequencer@^26.4.1":
|
"@jest/test-sequencer@^26.6.3":
|
||||||
version "26.4.1"
|
version "26.6.3"
|
||||||
resolved "https://registry.yarnpkg.com/@jest/test-sequencer/-/test-sequencer-26.4.1.tgz#b7cd13fedf4c1c20364bd40c134876b003f742e1"
|
resolved "https://registry.yarnpkg.com/@jest/test-sequencer/-/test-sequencer-26.6.3.tgz#98e8a45100863886d074205e8ffdc5a7eb582b17"
|
||||||
integrity sha512-YR4PNPu1RVHxyv/HSQMjc+pBEWa6wuM7xbEX/u5M5FFg6ZM6m00m7Jf0fjRxGN6hZlY5vECmNhJu/kvJLrxR8w==
|
integrity sha512-YHlVIjP5nfEyjlrSr8t/YdNfU/1XEt7c5b4OxcXCjyRhjzLYu/rO69/WHPuYcbCWkz8kAeZVZp2N2+IOLLEPGw==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@jest/test-result" "^26.3.0"
|
"@jest/test-result" "^26.6.2"
|
||||||
graceful-fs "^4.2.4"
|
graceful-fs "^4.2.4"
|
||||||
jest-haste-map "^26.3.0"
|
jest-haste-map "^26.6.2"
|
||||||
jest-runner "^26.4.1"
|
jest-runner "^26.6.3"
|
||||||
jest-runtime "^26.4.1"
|
jest-runtime "^26.6.3"
|
||||||
|
|
||||||
"@jest/transform@^26.3.0":
|
"@jest/transform@^26.6.2":
|
||||||
version "26.3.0"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/@jest/transform/-/transform-26.3.0.tgz#c393e0e01459da8a8bfc6d2a7c2ece1a13e8ba55"
|
resolved "https://registry.yarnpkg.com/@jest/transform/-/transform-26.6.2.tgz#5ac57c5fa1ad17b2aae83e73e45813894dcf2e4b"
|
||||||
integrity sha512-Isj6NB68QorGoFWvcOjlUhpkT56PqNIsXKR7XfvoDlCANn/IANlh8DrKAA2l2JKC3yWSMH5wS0GwuQM20w3b2A==
|
integrity sha512-E9JjhUgNzvuQ+vVAL21vlyfy12gP0GhazGgJC4h6qUt1jSdUXGWJ1wfu/X7Sd8etSgxV4ovT1pb9v5D6QW4XgA==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/core" "^7.1.0"
|
"@babel/core" "^7.1.0"
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
babel-plugin-istanbul "^6.0.0"
|
babel-plugin-istanbul "^6.0.0"
|
||||||
chalk "^4.0.0"
|
chalk "^4.0.0"
|
||||||
convert-source-map "^1.4.0"
|
convert-source-map "^1.4.0"
|
||||||
fast-json-stable-stringify "^2.0.0"
|
fast-json-stable-stringify "^2.0.0"
|
||||||
graceful-fs "^4.2.4"
|
graceful-fs "^4.2.4"
|
||||||
jest-haste-map "^26.3.0"
|
jest-haste-map "^26.6.2"
|
||||||
jest-regex-util "^26.0.0"
|
jest-regex-util "^26.0.0"
|
||||||
jest-util "^26.3.0"
|
jest-util "^26.6.2"
|
||||||
micromatch "^4.0.2"
|
micromatch "^4.0.2"
|
||||||
pirates "^4.0.1"
|
pirates "^4.0.1"
|
||||||
slash "^3.0.0"
|
slash "^3.0.0"
|
||||||
source-map "^0.6.1"
|
source-map "^0.6.1"
|
||||||
write-file-atomic "^3.0.0"
|
write-file-atomic "^3.0.0"
|
||||||
|
|
||||||
"@jest/types@^25.5.0":
|
"@jest/types@^26.6.2":
|
||||||
version "25.5.0"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/@jest/types/-/types-25.5.0.tgz#4d6a4793f7b9599fc3680877b856a97dbccf2a9d"
|
resolved "https://registry.yarnpkg.com/@jest/types/-/types-26.6.2.tgz#bef5a532030e1d88a2f5a6d933f84e97226ed48e"
|
||||||
integrity sha512-OXD0RgQ86Tu3MazKo8bnrkDRaDXXMGUqd+kTtLtK1Zb7CRzQcaSRPPPV37SvYTdevXEBVxe0HXylEjs8ibkmCw==
|
integrity sha512-fC6QCp7Sc5sX6g8Tvbmj4XUTbyrik0akgRy03yjXbQaBWWNWGE7SGtJk98m0N8nzegD/7SggrUlivxo5ax4KWQ==
|
||||||
dependencies:
|
|
||||||
"@types/istanbul-lib-coverage" "^2.0.0"
|
|
||||||
"@types/istanbul-reports" "^1.1.1"
|
|
||||||
"@types/yargs" "^15.0.0"
|
|
||||||
chalk "^3.0.0"
|
|
||||||
|
|
||||||
"@jest/types@^26.3.0":
|
|
||||||
version "26.3.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/@jest/types/-/types-26.3.0.tgz#97627bf4bdb72c55346eef98e3b3f7ddc4941f71"
|
|
||||||
integrity sha512-BDPG23U0qDeAvU4f99haztXwdAg3hz4El95LkAM+tHAqqhiVzRpEGHHU8EDxT/AnxOrA65YjLBwDahdJ9pTLJQ==
|
|
||||||
dependencies:
|
dependencies:
|
||||||
"@types/istanbul-lib-coverage" "^2.0.0"
|
"@types/istanbul-lib-coverage" "^2.0.0"
|
||||||
"@types/istanbul-reports" "^3.0.0"
|
"@types/istanbul-reports" "^3.0.0"
|
||||||
@@ -486,9 +1156,9 @@
|
|||||||
chalk "^4.0.0"
|
chalk "^4.0.0"
|
||||||
|
|
||||||
"@sinonjs/commons@^1.7.0":
|
"@sinonjs/commons@^1.7.0":
|
||||||
version "1.8.1"
|
version "1.8.3"
|
||||||
resolved "https://registry.yarnpkg.com/@sinonjs/commons/-/commons-1.8.1.tgz#e7df00f98a203324f6dc7cc606cad9d4a8ab2217"
|
resolved "https://registry.yarnpkg.com/@sinonjs/commons/-/commons-1.8.3.tgz#3802ddd21a50a949b6721ddd72da36e67e7f1b2d"
|
||||||
integrity sha512-892K+kWUUi3cl+LlqEWIDrhvLgdL79tECi8JZUyq6IviKy/DNhuzCRlbHUjxK89f4ypPMMaFnFuR9Ie6DoIMsw==
|
integrity sha512-xkNcLAn/wZaX14RPlwizcKicDk9G3F8m2nU3L7Ukm5zBgTwiT0wsoFAHx9Jq56fJA1z/7uKGtCRu16sOUCLIHQ==
|
||||||
dependencies:
|
dependencies:
|
||||||
type-detect "4.0.8"
|
type-detect "4.0.8"
|
||||||
|
|
||||||
@@ -499,10 +1169,15 @@
|
|||||||
dependencies:
|
dependencies:
|
||||||
"@sinonjs/commons" "^1.7.0"
|
"@sinonjs/commons" "^1.7.0"
|
||||||
|
|
||||||
|
"@tootallnate/once@1":
|
||||||
|
version "1.1.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/@tootallnate/once/-/once-1.1.2.tgz#ccb91445360179a04e7fe6aff78c00ffc1eeaf82"
|
||||||
|
integrity sha512-RbzJvlNzmRq5c3O09UipeuXno4tA1FE6ikOjxZK0tuxVv3412l64l5t1W5pj4+rJq9vpkm/kwiR07aZXnsKPxw==
|
||||||
|
|
||||||
"@types/babel__core@^7.0.0", "@types/babel__core@^7.1.7":
|
"@types/babel__core@^7.0.0", "@types/babel__core@^7.1.7":
|
||||||
version "7.1.9"
|
version "7.1.14"
|
||||||
resolved "https://registry.yarnpkg.com/@types/babel__core/-/babel__core-7.1.9.tgz#77e59d438522a6fb898fa43dc3455c6e72f3963d"
|
resolved "https://registry.yarnpkg.com/@types/babel__core/-/babel__core-7.1.14.tgz#faaeefc4185ec71c389f4501ee5ec84b170cc402"
|
||||||
integrity sha512-sY2RsIJ5rpER1u3/aQ8OFSI7qGIy8o1NEEbgb2UaJcvOtXOMpd39ko723NBpjQFg9SIX7TXtjejZVGeIMLhoOw==
|
integrity sha512-zGZJzzBUVDo/eV6KgbE0f0ZI7dInEYvo12Rb70uNQDshC3SkRMb67ja0GgRHZgAX3Za6rhaWlvbDO8rrGyAb1g==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/parser" "^7.1.0"
|
"@babel/parser" "^7.1.0"
|
||||||
"@babel/types" "^7.0.0"
|
"@babel/types" "^7.0.0"
|
||||||
@@ -511,36 +1186,31 @@
|
|||||||
"@types/babel__traverse" "*"
|
"@types/babel__traverse" "*"
|
||||||
|
|
||||||
"@types/babel__generator@*":
|
"@types/babel__generator@*":
|
||||||
version "7.6.1"
|
version "7.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/@types/babel__generator/-/babel__generator-7.6.1.tgz#4901767b397e8711aeb99df8d396d7ba7b7f0e04"
|
resolved "https://registry.yarnpkg.com/@types/babel__generator/-/babel__generator-7.6.2.tgz#f3d71178e187858f7c45e30380f8f1b7415a12d8"
|
||||||
integrity sha512-bBKm+2VPJcMRVwNhxKu8W+5/zT7pwNEqeokFOmbvVSqGzFneNxYcEBro9Ac7/N9tlsaPYnZLK8J1LWKkMsLAew==
|
integrity sha512-MdSJnBjl+bdwkLskZ3NGFp9YcXGx5ggLpQQPqtgakVhsWK0hTtNYhjpZLlWQTviGTvF8at+Bvli3jV7faPdgeQ==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/types" "^7.0.0"
|
"@babel/types" "^7.0.0"
|
||||||
|
|
||||||
"@types/babel__template@*":
|
"@types/babel__template@*":
|
||||||
version "7.0.2"
|
version "7.4.0"
|
||||||
resolved "https://registry.yarnpkg.com/@types/babel__template/-/babel__template-7.0.2.tgz#4ff63d6b52eddac1de7b975a5223ed32ecea9307"
|
resolved "https://registry.yarnpkg.com/@types/babel__template/-/babel__template-7.4.0.tgz#0c888dd70b3ee9eebb6e4f200e809da0076262be"
|
||||||
integrity sha512-/K6zCpeW7Imzgab2bLkLEbz0+1JlFSrUMdw7KoIIu+IUdu51GWaBZpd3y1VXGVXzynvGa4DaIaxNZHiON3GXUg==
|
integrity sha512-NTPErx4/FiPCGScH7foPyr+/1Dkzkni+rHiYHHoTjvwou7AQzJkNeD60A9CXRy+ZEN2B1bggmkTMCDb+Mv5k+A==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/parser" "^7.1.0"
|
"@babel/parser" "^7.1.0"
|
||||||
"@babel/types" "^7.0.0"
|
"@babel/types" "^7.0.0"
|
||||||
|
|
||||||
"@types/babel__traverse@*", "@types/babel__traverse@^7.0.6":
|
"@types/babel__traverse@*", "@types/babel__traverse@^7.0.4", "@types/babel__traverse@^7.0.6":
|
||||||
version "7.0.13"
|
version "7.14.0"
|
||||||
resolved "https://registry.yarnpkg.com/@types/babel__traverse/-/babel__traverse-7.0.13.tgz#1874914be974a492e1b4cb00585cabb274e8ba18"
|
resolved "https://registry.yarnpkg.com/@types/babel__traverse/-/babel__traverse-7.14.0.tgz#a34277cf8acbd3185ea74129e1f100491eb1da7f"
|
||||||
integrity sha512-i+zS7t6/s9cdQvbqKDARrcbrPvtJGlbYsMkazo03nTAK3RX9FNrLllXys22uiTGJapPOTZTQ35nHh4ISph4SLQ==
|
integrity sha512-IilJZ1hJBUZwMOVDNTdflOOLzJB/ZtljYVa7k3gEZN/jqIJIPkWHC6dvbX+DD2CwZDHB9wAKzZPzzqMIkW37/w==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/types" "^7.3.0"
|
"@babel/types" "^7.3.0"
|
||||||
|
|
||||||
"@types/color-name@^1.1.1":
|
|
||||||
version "1.1.1"
|
|
||||||
resolved "https://registry.yarnpkg.com/@types/color-name/-/color-name-1.1.1.tgz#1c1261bbeaa10a8055bbc5d8ab84b7b2afc846a0"
|
|
||||||
integrity sha512-rr+OQyAjxze7GgWrSaJwydHStIhHq2lvY3BOC2Mj7KnzI7XK0Uw1TOOdI9lDoajEbSWLiYgoo4f1R51erQfhPQ==
|
|
||||||
|
|
||||||
"@types/graceful-fs@^4.1.2":
|
"@types/graceful-fs@^4.1.2":
|
||||||
version "4.1.3"
|
version "4.1.5"
|
||||||
resolved "https://registry.yarnpkg.com/@types/graceful-fs/-/graceful-fs-4.1.3.tgz#039af35fe26bec35003e8d86d2ee9c586354348f"
|
resolved "https://registry.yarnpkg.com/@types/graceful-fs/-/graceful-fs-4.1.5.tgz#21ffba0d98da4350db64891f92a9e5db3cdb4e15"
|
||||||
integrity sha512-AiHRaEB50LQg0pZmm659vNBb9f4SJ0qrAnteuzhSeAUcJKxoYgEnprg/83kppCnc2zvtCKbdZry1a5pVY3lOTQ==
|
integrity sha512-anKkLmZZ+xm4p8JWBf4hElkM4XR+EZeA2M9BAkkTldmcyDY4mbdIJnRghDJH3Ov5ooY7/UAoENtmdMSkaAd7Cw==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@types/node" "*"
|
"@types/node" "*"
|
||||||
|
|
||||||
@@ -556,38 +1226,30 @@
|
|||||||
dependencies:
|
dependencies:
|
||||||
"@types/istanbul-lib-coverage" "*"
|
"@types/istanbul-lib-coverage" "*"
|
||||||
|
|
||||||
"@types/istanbul-reports@^1.1.1":
|
|
||||||
version "1.1.2"
|
|
||||||
resolved "https://registry.yarnpkg.com/@types/istanbul-reports/-/istanbul-reports-1.1.2.tgz#e875cc689e47bce549ec81f3df5e6f6f11cfaeb2"
|
|
||||||
integrity sha512-P/W9yOX/3oPZSpaYOCQzGqgCQRXn0FFO/V8bWrCQs+wLmvVVxk6CRBXALEvNs9OHIatlnlFokfhuDo2ug01ciw==
|
|
||||||
dependencies:
|
|
||||||
"@types/istanbul-lib-coverage" "*"
|
|
||||||
"@types/istanbul-lib-report" "*"
|
|
||||||
|
|
||||||
"@types/istanbul-reports@^3.0.0":
|
"@types/istanbul-reports@^3.0.0":
|
||||||
version "3.0.0"
|
version "3.0.1"
|
||||||
resolved "https://registry.yarnpkg.com/@types/istanbul-reports/-/istanbul-reports-3.0.0.tgz#508b13aa344fa4976234e75dddcc34925737d821"
|
resolved "https://registry.yarnpkg.com/@types/istanbul-reports/-/istanbul-reports-3.0.1.tgz#9153fe98bba2bd565a63add9436d6f0d7f8468ff"
|
||||||
integrity sha512-nwKNbvnwJ2/mndE9ItP/zc2TCzw6uuodnF4EHYWD+gCQDVBuRQL5UzbZD0/ezy1iKsFU2ZQiDqg4M9dN4+wZgA==
|
integrity sha512-c3mAZEuK0lvBp8tmuL74XRKn1+y2dcwOUpH7x4WrF6gk1GIgiluDRgMYQtw2OFcBvAJWlt6ASU3tSqxp0Uu0Aw==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@types/istanbul-lib-report" "*"
|
"@types/istanbul-lib-report" "*"
|
||||||
|
|
||||||
"@types/jest@26.x", "@types/jest@^26.0.3":
|
"@types/jest@^26.0.23":
|
||||||
version "26.0.10"
|
version "26.0.23"
|
||||||
resolved "https://registry.yarnpkg.com/@types/jest/-/jest-26.0.10.tgz#8faf7e9756c033c39014ae76a7329efea00ea607"
|
resolved "https://registry.yarnpkg.com/@types/jest/-/jest-26.0.23.tgz#a1b7eab3c503b80451d019efb588ec63522ee4e7"
|
||||||
integrity sha512-i2m0oyh8w/Lum7wWK/YOZJakYF8Mx08UaKA1CtbmFeDquVhAEdA7znacsVSf2hJ1OQ/OfVMGN90pw/AtzF8s/Q==
|
integrity sha512-ZHLmWMJ9jJ9PTiT58juykZpL7KjwJywFN3Rr2pTSkyQfydf/rk22yS7W8p5DaVUMQ2BQC7oYiU3FjbTM/mYrOA==
|
||||||
dependencies:
|
dependencies:
|
||||||
jest-diff "^25.2.1"
|
jest-diff "^26.0.0"
|
||||||
pretty-format "^25.2.1"
|
pretty-format "^26.0.0"
|
||||||
|
|
||||||
"@types/node@*":
|
"@types/node@*":
|
||||||
version "14.6.0"
|
version "16.0.0"
|
||||||
resolved "https://registry.yarnpkg.com/@types/node/-/node-14.6.0.tgz#7d4411bf5157339337d7cff864d9ff45f177b499"
|
resolved "https://registry.yarnpkg.com/@types/node/-/node-16.0.0.tgz#067a6c49dc7a5c2412a505628e26902ae967bf6f"
|
||||||
integrity sha512-mikldZQitV94akrc4sCcSjtJfsTKt4p+e/s0AGscVA6XArQ9kFclP+ZiYUMnq987rc6QlYxXv/EivqlfSLxpKA==
|
integrity sha512-TmCW5HoZ2o2/z2EYi109jLqIaPIi9y/lc2LmDCWzuCi35bcaQ+OtUh6nwBiFK7SOu25FAU5+YKdqFZUwtqGSdg==
|
||||||
|
|
||||||
"@types/node@^14.0.14":
|
"@types/node@^14.17.4":
|
||||||
version "14.0.27"
|
version "14.17.4"
|
||||||
resolved "https://registry.yarnpkg.com/@types/node/-/node-14.0.27.tgz#a151873af5a5e851b51b3b065c9e63390a9e0eb1"
|
resolved "https://registry.yarnpkg.com/@types/node/-/node-14.17.4.tgz#218712242446fc868d0e007af29a4408c7765bc0"
|
||||||
integrity sha512-kVrqXhbclHNHGu9ztnAwSncIgJv/FaxmzXJvGXNdcCpV1b8u1/Mi6z6m0vwy0LzKeXFTPLH0NzwmoJ3fNCIq0g==
|
integrity sha512-8kQ3+wKGRNN0ghtEn7EGps/B8CzuBz1nXZEIGGLP2GnwbqYn4dbTs7k+VKLTq1HvZLRCIDtN3Snx1Ege8B7L5A==
|
||||||
|
|
||||||
"@types/normalize-package-data@^2.4.0":
|
"@types/normalize-package-data@^2.4.0":
|
||||||
version "2.4.0"
|
version "2.4.0"
|
||||||
@@ -595,36 +1257,36 @@
|
|||||||
integrity sha512-f5j5b/Gf71L+dbqxIpQ4Z2WlmI/mPJ0fOkGGmFgtb6sAu97EPczzbS3/tJKxmcYDj55OX6ssqwDAWOHIYDRDGA==
|
integrity sha512-f5j5b/Gf71L+dbqxIpQ4Z2WlmI/mPJ0fOkGGmFgtb6sAu97EPczzbS3/tJKxmcYDj55OX6ssqwDAWOHIYDRDGA==
|
||||||
|
|
||||||
"@types/prettier@^2.0.0":
|
"@types/prettier@^2.0.0":
|
||||||
version "2.0.2"
|
version "2.3.1"
|
||||||
resolved "https://registry.yarnpkg.com/@types/prettier/-/prettier-2.0.2.tgz#5bb52ee68d0f8efa9cc0099920e56be6cc4e37f3"
|
resolved "https://registry.yarnpkg.com/@types/prettier/-/prettier-2.3.1.tgz#54dd88bdc7f49958329666af3779561e47d5dab3"
|
||||||
integrity sha512-IkVfat549ggtkZUthUzEX49562eGikhSYeVGX97SkMFn+sTZrgRewXjQ4tPKFPCykZHkX1Zfd9OoELGqKU2jJA==
|
integrity sha512-NVkb4p4YjI8E3O6+1m8I+8JlMpFZwfSbPGdaw0wXuyPRTEz0SLKwBUWNSO7Maoi8tQMPC8JLZNWkrcKPI7/sLA==
|
||||||
|
|
||||||
"@types/stack-utils@^1.0.1":
|
"@types/stack-utils@^2.0.0":
|
||||||
version "1.0.1"
|
version "2.0.1"
|
||||||
resolved "https://registry.yarnpkg.com/@types/stack-utils/-/stack-utils-1.0.1.tgz#0a851d3bd96498fa25c33ab7278ed3bd65f06c3e"
|
resolved "https://registry.yarnpkg.com/@types/stack-utils/-/stack-utils-2.0.1.tgz#20f18294f797f2209b5f65c8e3b5c8e8261d127c"
|
||||||
integrity sha512-l42BggppR6zLmpfU6fq9HEa2oGPEI8yrSPL3GITjfRInppYFahObbIQOQK3UGxEnyQpltZLaPe75046NOZQikw==
|
integrity sha512-Hl219/BT5fLAaz6NDkSuhzasy49dwQS/DSdu4MdggFB8zcXv7vflBI3xp7FEmkmdDkBUI2bPUNeMttp2knYdxw==
|
||||||
|
|
||||||
"@types/yargs-parser@*":
|
"@types/yargs-parser@*":
|
||||||
version "15.0.0"
|
version "20.2.1"
|
||||||
resolved "https://registry.yarnpkg.com/@types/yargs-parser/-/yargs-parser-15.0.0.tgz#cb3f9f741869e20cce330ffbeb9271590483882d"
|
resolved "https://registry.yarnpkg.com/@types/yargs-parser/-/yargs-parser-20.2.1.tgz#3b9ce2489919d9e4fea439b76916abc34b2df129"
|
||||||
integrity sha512-FA/BWv8t8ZWJ+gEOnLLd8ygxH/2UFbAvgEonyfN6yWGLKc7zVjbpl2Y4CTjid9h2RfgPP6SEt6uHwEOply00yw==
|
integrity sha512-7tFImggNeNBVMsn0vLrpn1H1uPrUBdnARPTpZoitY37ZrdJREzf7I16tMrlK3hen349gr1NYh8CmZQa7CTG6Aw==
|
||||||
|
|
||||||
"@types/yargs@^15.0.0":
|
"@types/yargs@^15.0.0":
|
||||||
version "15.0.5"
|
version "15.0.14"
|
||||||
resolved "https://registry.yarnpkg.com/@types/yargs/-/yargs-15.0.5.tgz#947e9a6561483bdee9adffc983e91a6902af8b79"
|
resolved "https://registry.yarnpkg.com/@types/yargs/-/yargs-15.0.14.tgz#26d821ddb89e70492160b66d10a0eb6df8f6fb06"
|
||||||
integrity sha512-Dk/IDOPtOgubt/IaevIUbTgV7doaKkoorvOyYM2CMwuDyP89bekI7H4xLIwunNYiK9jhCkmc6pUrJk3cj2AB9w==
|
integrity sha512-yEJzHoxf6SyQGhBhIYGXQDSCkJjB6HohDShto7m8vaKg9Yp0Yn8+71J9eakh2bnPg6BfsH9PRMhiRTZnd4eXGQ==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@types/yargs-parser" "*"
|
"@types/yargs-parser" "*"
|
||||||
|
|
||||||
"@vercel/ncc@^0.23.0":
|
"@vercel/ncc@^0.28.6":
|
||||||
version "0.23.0"
|
version "0.28.6"
|
||||||
resolved "https://registry.yarnpkg.com/@vercel/ncc/-/ncc-0.23.0.tgz#628f293f8ae2038d004378f864396ad8fc14380c"
|
resolved "https://registry.yarnpkg.com/@vercel/ncc/-/ncc-0.28.6.tgz#073c0ce8e0269210c0a9f180fb0bf949eecc20e0"
|
||||||
integrity sha512-Fcr1qlG9t54X4X9qbo/+jr1+t5Qc6H3TgIRBXmKkF/WDs6YFulAN6ilq2Ehx38RbgIOFxaZnjlAQ50GyexnMpQ==
|
integrity sha512-t4BoSSuyK8BZaUE0gV18V6bkFs4st7baumtFGa50dv1tMu2GDBEBF8sUZaKBdKiL6DzJ2D2+XVCwYWWDcQOYdQ==
|
||||||
|
|
||||||
abab@^2.0.3:
|
abab@^2.0.3, abab@^2.0.5:
|
||||||
version "2.0.4"
|
version "2.0.5"
|
||||||
resolved "https://registry.yarnpkg.com/abab/-/abab-2.0.4.tgz#6dfa57b417ca06d21b2478f0e638302f99c2405c"
|
resolved "https://registry.yarnpkg.com/abab/-/abab-2.0.5.tgz#c0b678fb32d60fc1219c784d6a826fe385aeb79a"
|
||||||
integrity sha512-Eu9ELJWCz/c1e9gTiCY+FceWxcqzjYEbqMgtndnuSqZSUCOL73TWNK2mHfIj4Cw2E/ongOp+JISVNCmovt2KYQ==
|
integrity sha512-9IK9EadsbHo6jLWIpxpR6pL0sazTXV6+SQv25ZB+F7Bj9mJNaOc4nCRabwd5M/JwmUa8idz6Eci6eKfJryPs6Q==
|
||||||
|
|
||||||
acorn-globals@^6.0.0:
|
acorn-globals@^6.0.0:
|
||||||
version "6.0.0"
|
version "6.0.0"
|
||||||
@@ -639,32 +1301,44 @@ acorn-walk@^7.1.1:
|
|||||||
resolved "https://registry.yarnpkg.com/acorn-walk/-/acorn-walk-7.2.0.tgz#0de889a601203909b0fbe07b8938dc21d2e967bc"
|
resolved "https://registry.yarnpkg.com/acorn-walk/-/acorn-walk-7.2.0.tgz#0de889a601203909b0fbe07b8938dc21d2e967bc"
|
||||||
integrity sha512-OPdCF6GsMIP+Az+aWfAAOEt2/+iVDKE7oy6lJ098aoe59oAmK76qV6Gw60SbZ8jHuG2wH058GF4pLFbYamYrVA==
|
integrity sha512-OPdCF6GsMIP+Az+aWfAAOEt2/+iVDKE7oy6lJ098aoe59oAmK76qV6Gw60SbZ8jHuG2wH058GF4pLFbYamYrVA==
|
||||||
|
|
||||||
acorn@^7.1.1:
|
acorn-walk@^8.2.0:
|
||||||
version "7.4.0"
|
version "8.2.0"
|
||||||
resolved "https://registry.yarnpkg.com/acorn/-/acorn-7.4.0.tgz#e1ad486e6c54501634c6c397c5c121daa383607c"
|
resolved "https://registry.yarnpkg.com/acorn-walk/-/acorn-walk-8.2.0.tgz#741210f2e2426454508853a2f44d0ab83b7f69c1"
|
||||||
integrity sha512-+G7P8jJmCHr+S+cLfQxygbWhXy+8YTVGzAkpEbcLo2mLoL7tij/VG41QSHACSf5QgYRhMZYHuNc6drJaO0Da+w==
|
integrity sha512-k+iyHEuPgSw6SbuDpGQM+06HQUa04DZ3o+F6CSzXMvvI5KMvnaEqXe+YVe555R9nn6GPt404fos4wcgpw12SDA==
|
||||||
|
|
||||||
ajv@^6.12.3:
|
acorn@^7.1.1:
|
||||||
version "6.12.4"
|
version "7.4.1"
|
||||||
resolved "https://registry.yarnpkg.com/ajv/-/ajv-6.12.4.tgz#0614facc4522127fa713445c6bfd3ebd376e2234"
|
resolved "https://registry.yarnpkg.com/acorn/-/acorn-7.4.1.tgz#feaed255973d2e77555b83dbc08851a6c63520fa"
|
||||||
integrity sha512-eienB2c9qVQs2KWexhkrdMLVDoIQCz5KSeLxwg9Lzk4DOfBtIK9PQwwufcsn1jjGuf9WZmqPMbGxOzfcuphJCQ==
|
integrity sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A==
|
||||||
|
|
||||||
|
acorn@^8.2.4:
|
||||||
|
version "8.4.1"
|
||||||
|
resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.4.1.tgz#56c36251fc7cabc7096adc18f05afe814321a28c"
|
||||||
|
integrity sha512-asabaBSkEKosYKMITunzX177CXxQ4Q8BSSzMTKD+FefUhipQC70gfW5SiUDhYQ3vk8G+81HqQk7Fv9OXwwn9KA==
|
||||||
|
|
||||||
|
acorn@^8.7.0:
|
||||||
|
version "8.7.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/acorn/-/acorn-8.7.0.tgz#90951fde0f8f09df93549481e5fc141445b791cf"
|
||||||
|
integrity sha512-V/LGr1APy+PXIwKebEWrkZPwoeoF+w1jiOBUmuxuiUIaOHtob8Qc9BTrYo7VuI5fR8tqsy+buA2WFooR5olqvQ==
|
||||||
|
|
||||||
|
agent-base@6, agent-base@^6.0.0, agent-base@^6.0.2:
|
||||||
|
version "6.0.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/agent-base/-/agent-base-6.0.2.tgz#49fff58577cfee3f37176feab4c22e00f86d7f77"
|
||||||
|
integrity sha512-RZNwNclF7+MS/8bDg70amg32dyeZGZxiDuQmZxKLAlQjr3jGyLx+4Kkk58UO7D2QdgFIQCovuSuZESne6RG6XQ==
|
||||||
dependencies:
|
dependencies:
|
||||||
fast-deep-equal "^3.1.1"
|
debug "4"
|
||||||
fast-json-stable-stringify "^2.0.0"
|
|
||||||
json-schema-traverse "^0.4.1"
|
|
||||||
uri-js "^4.2.2"
|
|
||||||
|
|
||||||
ansi-escapes@^4.2.1:
|
ansi-escapes@^4.2.1:
|
||||||
version "4.3.1"
|
version "4.3.2"
|
||||||
resolved "https://registry.yarnpkg.com/ansi-escapes/-/ansi-escapes-4.3.1.tgz#a5c47cc43181f1f38ffd7076837700d395522a61"
|
resolved "https://registry.yarnpkg.com/ansi-escapes/-/ansi-escapes-4.3.2.tgz#6b2291d1db7d98b6521d5f1efa42d0f3a9feb65e"
|
||||||
integrity sha512-JWF7ocqNrp8u9oqpgV+wH5ftbt+cfvv+PTjOvKLT3AdYly/LmORARfEVT1iyjwN+4MqE5UmVKoAdIBqeoCHgLA==
|
integrity sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ==
|
||||||
dependencies:
|
dependencies:
|
||||||
type-fest "^0.11.0"
|
type-fest "^0.21.3"
|
||||||
|
|
||||||
ansi-regex@^5.0.0:
|
ansi-regex@^5.0.0:
|
||||||
version "5.0.0"
|
version "5.0.1"
|
||||||
resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-5.0.0.tgz#388539f55179bf39339c81af30a654d69f87cb75"
|
resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-5.0.1.tgz#082cb2c89c9fe8659a311a53bd6a4dc5301db304"
|
||||||
integrity sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==
|
integrity sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ==
|
||||||
|
|
||||||
ansi-styles@^3.2.1:
|
ansi-styles@^3.2.1:
|
||||||
version "3.2.1"
|
version "3.2.1"
|
||||||
@@ -674,11 +1348,10 @@ ansi-styles@^3.2.1:
|
|||||||
color-convert "^1.9.0"
|
color-convert "^1.9.0"
|
||||||
|
|
||||||
ansi-styles@^4.0.0, ansi-styles@^4.1.0:
|
ansi-styles@^4.0.0, ansi-styles@^4.1.0:
|
||||||
version "4.2.1"
|
version "4.3.0"
|
||||||
resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-4.2.1.tgz#90ae75c424d008d2624c5bf29ead3177ebfcf359"
|
resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-4.3.0.tgz#edd803628ae71c04c85ae7a0906edad34b648937"
|
||||||
integrity sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA==
|
integrity sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@types/color-name" "^1.1.1"
|
|
||||||
color-convert "^2.0.1"
|
color-convert "^2.0.1"
|
||||||
|
|
||||||
anymatch@^2.0.0:
|
anymatch@^2.0.0:
|
||||||
@@ -690,9 +1363,9 @@ anymatch@^2.0.0:
|
|||||||
normalize-path "^2.1.1"
|
normalize-path "^2.1.1"
|
||||||
|
|
||||||
anymatch@^3.0.3:
|
anymatch@^3.0.3:
|
||||||
version "3.1.1"
|
version "3.1.2"
|
||||||
resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-3.1.1.tgz#c55ecf02185e2469259399310c173ce31233b142"
|
resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-3.1.2.tgz#c0557c096af32f106198f4f4e2a383537e378716"
|
||||||
integrity sha512-mM8522psRCqzV+6LhomX5wgp25YVibjh8Wj23I5RPkPppSVSjyKD2A2mBJmWGa+KN7f2D6LNh9jkBCeyLktzjg==
|
integrity sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg==
|
||||||
dependencies:
|
dependencies:
|
||||||
normalize-path "^3.0.0"
|
normalize-path "^3.0.0"
|
||||||
picomatch "^2.0.4"
|
picomatch "^2.0.4"
|
||||||
@@ -724,23 +1397,18 @@ array-unique@^0.3.2:
|
|||||||
resolved "https://registry.yarnpkg.com/array-unique/-/array-unique-0.3.2.tgz#a894b75d4bc4f6cd679ef3244a9fd8f46ae2d428"
|
resolved "https://registry.yarnpkg.com/array-unique/-/array-unique-0.3.2.tgz#a894b75d4bc4f6cd679ef3244a9fd8f46ae2d428"
|
||||||
integrity sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=
|
integrity sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=
|
||||||
|
|
||||||
asn1@~0.2.3:
|
|
||||||
version "0.2.4"
|
|
||||||
resolved "https://registry.yarnpkg.com/asn1/-/asn1-0.2.4.tgz#8d2475dfab553bb33e77b54e59e880bb8ce23136"
|
|
||||||
integrity sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg==
|
|
||||||
dependencies:
|
|
||||||
safer-buffer "~2.1.0"
|
|
||||||
|
|
||||||
assert-plus@1.0.0, assert-plus@^1.0.0:
|
|
||||||
version "1.0.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/assert-plus/-/assert-plus-1.0.0.tgz#f12e0f3c5d77b0b1cdd9146942e4e96c1e4dd525"
|
|
||||||
integrity sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=
|
|
||||||
|
|
||||||
assign-symbols@^1.0.0:
|
assign-symbols@^1.0.0:
|
||||||
version "1.0.0"
|
version "1.0.0"
|
||||||
resolved "https://registry.yarnpkg.com/assign-symbols/-/assign-symbols-1.0.0.tgz#59667f41fadd4f20ccbc2bb96b8d4f7f78ec0367"
|
resolved "https://registry.yarnpkg.com/assign-symbols/-/assign-symbols-1.0.0.tgz#59667f41fadd4f20ccbc2bb96b8d4f7f78ec0367"
|
||||||
integrity sha1-WWZ/QfrdTyDMvCu5a41Pf3jsA2c=
|
integrity sha1-WWZ/QfrdTyDMvCu5a41Pf3jsA2c=
|
||||||
|
|
||||||
|
ast-types@^0.13.2:
|
||||||
|
version "0.13.4"
|
||||||
|
resolved "https://registry.yarnpkg.com/ast-types/-/ast-types-0.13.4.tgz#ee0d77b343263965ecc3fb62da16e7222b2b6782"
|
||||||
|
integrity sha512-x1FCFnFifvYDDzTaLII71vG5uvDwgtmDTEVWAxrgeiR8VjMONcCXJx7E+USjDtHlwFmt9MysbqgF9b9Vjr6w+w==
|
||||||
|
dependencies:
|
||||||
|
tslib "^2.0.1"
|
||||||
|
|
||||||
asynckit@^0.4.0:
|
asynckit@^0.4.0:
|
||||||
version "0.4.0"
|
version "0.4.0"
|
||||||
resolved "https://registry.yarnpkg.com/asynckit/-/asynckit-0.4.0.tgz#c79ed97f7f34cb8f2ba1bc9790bcc366474b4b79"
|
resolved "https://registry.yarnpkg.com/asynckit/-/asynckit-0.4.0.tgz#c79ed97f7f34cb8f2ba1bc9790bcc366474b4b79"
|
||||||
@@ -751,26 +1419,16 @@ atob@^2.1.2:
|
|||||||
resolved "https://registry.yarnpkg.com/atob/-/atob-2.1.2.tgz#6d9517eb9e030d2436666651e86bd9f6f13533c9"
|
resolved "https://registry.yarnpkg.com/atob/-/atob-2.1.2.tgz#6d9517eb9e030d2436666651e86bd9f6f13533c9"
|
||||||
integrity sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg==
|
integrity sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg==
|
||||||
|
|
||||||
aws-sign2@~0.7.0:
|
babel-jest@^26.6.3:
|
||||||
version "0.7.0"
|
version "26.6.3"
|
||||||
resolved "https://registry.yarnpkg.com/aws-sign2/-/aws-sign2-0.7.0.tgz#b46e890934a9591f2d2f6f86d7e6a9f1b3fe76a8"
|
resolved "https://registry.yarnpkg.com/babel-jest/-/babel-jest-26.6.3.tgz#d87d25cb0037577a0c89f82e5755c5d293c01056"
|
||||||
integrity sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=
|
integrity sha512-pl4Q+GAVOHwvjrck6jKjvmGhnO3jHX/xuB9d27f+EJZ/6k+6nMuPjorrYp7s++bKKdANwzElBWnLWaObvTnaZA==
|
||||||
|
|
||||||
aws4@^1.8.0:
|
|
||||||
version "1.10.1"
|
|
||||||
resolved "https://registry.yarnpkg.com/aws4/-/aws4-1.10.1.tgz#e1e82e4f3e999e2cfd61b161280d16a111f86428"
|
|
||||||
integrity sha512-zg7Hz2k5lI8kb7U32998pRRFin7zJlkfezGJjUc2heaD4Pw2wObakCDVzkKztTm/Ln7eiVvYsjqak0Ed4LkMDA==
|
|
||||||
|
|
||||||
babel-jest@^26.3.0:
|
|
||||||
version "26.3.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/babel-jest/-/babel-jest-26.3.0.tgz#10d0ca4b529ca3e7d1417855ef7d7bd6fc0c3463"
|
|
||||||
integrity sha512-sxPnQGEyHAOPF8NcUsD0g7hDCnvLL2XyblRBcgrzTWBB/mAIpWow3n1bEL+VghnnZfreLhFSBsFluRoK2tRK4g==
|
|
||||||
dependencies:
|
dependencies:
|
||||||
"@jest/transform" "^26.3.0"
|
"@jest/transform" "^26.6.2"
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
"@types/babel__core" "^7.1.7"
|
"@types/babel__core" "^7.1.7"
|
||||||
babel-plugin-istanbul "^6.0.0"
|
babel-plugin-istanbul "^6.0.0"
|
||||||
babel-preset-jest "^26.3.0"
|
babel-preset-jest "^26.6.2"
|
||||||
chalk "^4.0.0"
|
chalk "^4.0.0"
|
||||||
graceful-fs "^4.2.4"
|
graceful-fs "^4.2.4"
|
||||||
slash "^3.0.0"
|
slash "^3.0.0"
|
||||||
@@ -786,20 +1444,20 @@ babel-plugin-istanbul@^6.0.0:
|
|||||||
istanbul-lib-instrument "^4.0.0"
|
istanbul-lib-instrument "^4.0.0"
|
||||||
test-exclude "^6.0.0"
|
test-exclude "^6.0.0"
|
||||||
|
|
||||||
babel-plugin-jest-hoist@^26.2.0:
|
babel-plugin-jest-hoist@^26.6.2:
|
||||||
version "26.2.0"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-26.2.0.tgz#bdd0011df0d3d513e5e95f76bd53b51147aca2dd"
|
resolved "https://registry.yarnpkg.com/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-26.6.2.tgz#8185bd030348d254c6d7dd974355e6a28b21e62d"
|
||||||
integrity sha512-B/hVMRv8Nh1sQ1a3EY8I0n4Y1Wty3NrR5ebOyVT302op+DOAau+xNEImGMsUWOC3++ZlMooCytKz+NgN8aKGbA==
|
integrity sha512-PO9t0697lNTmcEHH69mdtYiOIkkOlj9fySqfO3K1eCcdISevLAE0xY59VLLUj0SoiPiTX/JU2CYFpILydUa5Lw==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/template" "^7.3.3"
|
"@babel/template" "^7.3.3"
|
||||||
"@babel/types" "^7.3.3"
|
"@babel/types" "^7.3.3"
|
||||||
"@types/babel__core" "^7.0.0"
|
"@types/babel__core" "^7.0.0"
|
||||||
"@types/babel__traverse" "^7.0.6"
|
"@types/babel__traverse" "^7.0.6"
|
||||||
|
|
||||||
babel-preset-current-node-syntax@^0.1.3:
|
babel-preset-current-node-syntax@^1.0.0:
|
||||||
version "0.1.3"
|
version "1.0.1"
|
||||||
resolved "https://registry.yarnpkg.com/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-0.1.3.tgz#b4b547acddbf963cba555ba9f9cbbb70bfd044da"
|
resolved "https://registry.yarnpkg.com/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.0.1.tgz#b4399239b89b2a011f9ddbe3e4f401fc40cff73b"
|
||||||
integrity sha512-uyexu1sVwcdFnyq9o8UQYsXwXflIh8LvrF5+cKrYam93ned1CStffB3+BEcsxGSgagoA3GEyjDqO4a/58hyPYQ==
|
integrity sha512-M7LQ0bxarkxQoN+vz5aJPsLBn77n8QgTFmo8WK0/44auK2xlCXrYcUxHFxgU7qW5Yzw/CjmLRK2uJzaCd7LvqQ==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/plugin-syntax-async-generators" "^7.8.4"
|
"@babel/plugin-syntax-async-generators" "^7.8.4"
|
||||||
"@babel/plugin-syntax-bigint" "^7.8.3"
|
"@babel/plugin-syntax-bigint" "^7.8.3"
|
||||||
@@ -812,19 +1470,20 @@ babel-preset-current-node-syntax@^0.1.3:
|
|||||||
"@babel/plugin-syntax-object-rest-spread" "^7.8.3"
|
"@babel/plugin-syntax-object-rest-spread" "^7.8.3"
|
||||||
"@babel/plugin-syntax-optional-catch-binding" "^7.8.3"
|
"@babel/plugin-syntax-optional-catch-binding" "^7.8.3"
|
||||||
"@babel/plugin-syntax-optional-chaining" "^7.8.3"
|
"@babel/plugin-syntax-optional-chaining" "^7.8.3"
|
||||||
|
"@babel/plugin-syntax-top-level-await" "^7.8.3"
|
||||||
|
|
||||||
babel-preset-jest@^26.3.0:
|
babel-preset-jest@^26.6.2:
|
||||||
version "26.3.0"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/babel-preset-jest/-/babel-preset-jest-26.3.0.tgz#ed6344506225c065fd8a0b53e191986f74890776"
|
resolved "https://registry.yarnpkg.com/babel-preset-jest/-/babel-preset-jest-26.6.2.tgz#747872b1171df032252426586881d62d31798fee"
|
||||||
integrity sha512-5WPdf7nyYi2/eRxCbVrE1kKCWxgWY4RsPEbdJWFm7QsesFGqjdkyLeu1zRkwM1cxK6EPIlNd6d2AxLk7J+t4pw==
|
integrity sha512-YvdtlVm9t3k777c5NPQIv6cxFFFapys25HiUmuSgHwIZhfifweR5c5Sf5nwE3MAbfu327CYSvps8Yx6ANLyleQ==
|
||||||
dependencies:
|
dependencies:
|
||||||
babel-plugin-jest-hoist "^26.2.0"
|
babel-plugin-jest-hoist "^26.6.2"
|
||||||
babel-preset-current-node-syntax "^0.1.3"
|
babel-preset-current-node-syntax "^1.0.0"
|
||||||
|
|
||||||
balanced-match@^1.0.0:
|
balanced-match@^1.0.0:
|
||||||
version "1.0.0"
|
version "1.0.2"
|
||||||
resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.0.tgz#89b4d199ab2bee49de164ea02b89ce462d71b767"
|
resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.2.tgz#e83e3a7e3f300b34cb9d87f615fa0cbf357690ee"
|
||||||
integrity sha1-ibTRmasr7kneFk6gK4nORi1xt2c=
|
integrity sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==
|
||||||
|
|
||||||
base@^0.11.1:
|
base@^0.11.1:
|
||||||
version "0.11.2"
|
version "0.11.2"
|
||||||
@@ -839,12 +1498,10 @@ base@^0.11.1:
|
|||||||
mixin-deep "^1.2.0"
|
mixin-deep "^1.2.0"
|
||||||
pascalcase "^0.1.1"
|
pascalcase "^0.1.1"
|
||||||
|
|
||||||
bcrypt-pbkdf@^1.0.0:
|
bowser@^2.11.0:
|
||||||
version "1.0.2"
|
version "2.11.0"
|
||||||
resolved "https://registry.yarnpkg.com/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz#a4301d389b6a43f9b67ff3ca11a3f6637e360e9e"
|
resolved "https://registry.yarnpkg.com/bowser/-/bowser-2.11.0.tgz#5ca3c35757a7aa5771500c70a73a9f91ef420a8f"
|
||||||
integrity sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=
|
integrity sha512-AlcaJBi/pqqJBIQ8U9Mcpc9i8Aqxn88Skv5d+xBX006BY5u8N3mGLHa5Lgppa7L/HfwgwLgZ6NYs+Ag6uUmJRA==
|
||||||
dependencies:
|
|
||||||
tweetnacl "^0.14.3"
|
|
||||||
|
|
||||||
brace-expansion@^1.1.7:
|
brace-expansion@^1.1.7:
|
||||||
version "1.1.11"
|
version "1.1.11"
|
||||||
@@ -882,6 +1539,17 @@ browser-process-hrtime@^1.0.0:
|
|||||||
resolved "https://registry.yarnpkg.com/browser-process-hrtime/-/browser-process-hrtime-1.0.0.tgz#3c9b4b7d782c8121e56f10106d84c0d0ffc94626"
|
resolved "https://registry.yarnpkg.com/browser-process-hrtime/-/browser-process-hrtime-1.0.0.tgz#3c9b4b7d782c8121e56f10106d84c0d0ffc94626"
|
||||||
integrity sha512-9o5UecI3GhkpM6DrXr69PblIuWxPKk9Y0jHBRhdocZ2y7YECBFCsHm79Pr3OyR2AvjhDkabFJaDJMYRazHgsow==
|
integrity sha512-9o5UecI3GhkpM6DrXr69PblIuWxPKk9Y0jHBRhdocZ2y7YECBFCsHm79Pr3OyR2AvjhDkabFJaDJMYRazHgsow==
|
||||||
|
|
||||||
|
browserslist@^4.16.6:
|
||||||
|
version "4.16.6"
|
||||||
|
resolved "https://registry.yarnpkg.com/browserslist/-/browserslist-4.16.6.tgz#d7901277a5a88e554ed305b183ec9b0c08f66fa2"
|
||||||
|
integrity sha512-Wspk/PqO+4W9qp5iUTJsa1B/QrYn1keNCcEP5OvP7WBwT4KaDly0uONYmC6Xa3Z5IqnUgS0KcgLYu1l74x0ZXQ==
|
||||||
|
dependencies:
|
||||||
|
caniuse-lite "^1.0.30001219"
|
||||||
|
colorette "^1.2.2"
|
||||||
|
electron-to-chromium "^1.3.723"
|
||||||
|
escalade "^3.1.1"
|
||||||
|
node-releases "^1.1.71"
|
||||||
|
|
||||||
bs-logger@0.x:
|
bs-logger@0.x:
|
||||||
version "0.2.6"
|
version "0.2.6"
|
||||||
resolved "https://registry.yarnpkg.com/bs-logger/-/bs-logger-0.2.6.tgz#eb7d365307a72cf974cc6cda76b68354ad336bd8"
|
resolved "https://registry.yarnpkg.com/bs-logger/-/bs-logger-0.2.6.tgz#eb7d365307a72cf974cc6cda76b68354ad336bd8"
|
||||||
@@ -901,6 +1569,11 @@ buffer-from@1.x, buffer-from@^1.0.0:
|
|||||||
resolved "https://registry.yarnpkg.com/buffer-from/-/buffer-from-1.1.1.tgz#32713bc028f75c02fdb710d7c7bcec1f2c6070ef"
|
resolved "https://registry.yarnpkg.com/buffer-from/-/buffer-from-1.1.1.tgz#32713bc028f75c02fdb710d7c7bcec1f2c6070ef"
|
||||||
integrity sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==
|
integrity sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==
|
||||||
|
|
||||||
|
bytes@3.1.2:
|
||||||
|
version "3.1.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/bytes/-/bytes-3.1.2.tgz#8b0beeb98605adf1b128fa4386403c009e0221a5"
|
||||||
|
integrity sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==
|
||||||
|
|
||||||
cache-base@^1.0.1:
|
cache-base@^1.0.1:
|
||||||
version "1.0.1"
|
version "1.0.1"
|
||||||
resolved "https://registry.yarnpkg.com/cache-base/-/cache-base-1.0.1.tgz#0a7f46416831c8b662ee36fe4e7c59d76f666ab2"
|
resolved "https://registry.yarnpkg.com/cache-base/-/cache-base-1.0.1.tgz#0a7f46416831c8b662ee36fe4e7c59d76f666ab2"
|
||||||
@@ -927,9 +1600,14 @@ camelcase@^5.0.0, camelcase@^5.3.1:
|
|||||||
integrity sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==
|
integrity sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==
|
||||||
|
|
||||||
camelcase@^6.0.0:
|
camelcase@^6.0.0:
|
||||||
version "6.0.0"
|
version "6.2.0"
|
||||||
resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-6.0.0.tgz#5259f7c30e35e278f1bdc2a4d91230b37cad981e"
|
resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-6.2.0.tgz#924af881c9d525ac9d87f40d964e5cea982a1809"
|
||||||
integrity sha512-8KMDF1Vz2gzOq54ONPJS65IvTUaB1cHJ2DMM7MbPmLZljDH1qpzzLsWdiN9pHh6qvkRVDTi/07+eNGch/oLU4w==
|
integrity sha512-c7wVvbw3f37nuobQNtgsgG9POC9qMbNuMQmTCqZv23b6MIz0fcYpBiOlv9gEN/hdLdnZTDQhg6e9Dq5M1vKvfg==
|
||||||
|
|
||||||
|
caniuse-lite@^1.0.30001219:
|
||||||
|
version "1.0.30001242"
|
||||||
|
resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001242.tgz#04201627abcd60dc89211f22cbe2347306cda46b"
|
||||||
|
integrity sha512-KvNuZ/duufelMB3w2xtf9gEWCSxJwUgoxOx5b6ScLXC4kPc9xsczUVCPrQU26j5kOsHM4pSUL54tAZt5THQKug==
|
||||||
|
|
||||||
capture-exit@^2.0.0:
|
capture-exit@^2.0.0:
|
||||||
version "2.0.0"
|
version "2.0.0"
|
||||||
@@ -938,11 +1616,6 @@ capture-exit@^2.0.0:
|
|||||||
dependencies:
|
dependencies:
|
||||||
rsvp "^4.8.4"
|
rsvp "^4.8.4"
|
||||||
|
|
||||||
caseless@~0.12.0:
|
|
||||||
version "0.12.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/caseless/-/caseless-0.12.0.tgz#1b681c21ff84033c826543090689420d187151dc"
|
|
||||||
integrity sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=
|
|
||||||
|
|
||||||
chalk@^2.0.0:
|
chalk@^2.0.0:
|
||||||
version "2.4.2"
|
version "2.4.2"
|
||||||
resolved "https://registry.yarnpkg.com/chalk/-/chalk-2.4.2.tgz#cd42541677a54333cf541a49108c1432b44c9424"
|
resolved "https://registry.yarnpkg.com/chalk/-/chalk-2.4.2.tgz#cd42541677a54333cf541a49108c1432b44c9424"
|
||||||
@@ -952,18 +1625,10 @@ chalk@^2.0.0:
|
|||||||
escape-string-regexp "^1.0.5"
|
escape-string-regexp "^1.0.5"
|
||||||
supports-color "^5.3.0"
|
supports-color "^5.3.0"
|
||||||
|
|
||||||
chalk@^3.0.0:
|
|
||||||
version "3.0.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/chalk/-/chalk-3.0.0.tgz#3f73c2bf526591f574cc492c51e2456349f844e4"
|
|
||||||
integrity sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg==
|
|
||||||
dependencies:
|
|
||||||
ansi-styles "^4.1.0"
|
|
||||||
supports-color "^7.1.0"
|
|
||||||
|
|
||||||
chalk@^4.0.0:
|
chalk@^4.0.0:
|
||||||
version "4.1.0"
|
version "4.1.1"
|
||||||
resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.1.0.tgz#4e14870a618d9e2edd97dd8345fd9d9dc315646a"
|
resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.1.1.tgz#c80b3fab28bf6371e6863325eee67e618b77e6ad"
|
||||||
integrity sha512-qwx12AxXe2Q5xQ43Ac//I6v5aXTipYrSESdOgzrN+9XjgEpyjpKuvSGaN4qE93f7TQTlerQQ8S+EQ0EyDoVL1A==
|
integrity sha512-diHzdDKxcU+bAsUboHLPEDQiw0qEe0qd7SYUn3HgcFlWgbDcfLGswOHYeGrHKzG9z6UYf01d9VFMfZxPM1xZSg==
|
||||||
dependencies:
|
dependencies:
|
||||||
ansi-styles "^4.1.0"
|
ansi-styles "^4.1.0"
|
||||||
supports-color "^7.1.0"
|
supports-color "^7.1.0"
|
||||||
@@ -978,6 +1643,11 @@ ci-info@^2.0.0:
|
|||||||
resolved "https://registry.yarnpkg.com/ci-info/-/ci-info-2.0.0.tgz#67a9e964be31a51e15e5010d58e6f12834002f46"
|
resolved "https://registry.yarnpkg.com/ci-info/-/ci-info-2.0.0.tgz#67a9e964be31a51e15e5010d58e6f12834002f46"
|
||||||
integrity sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==
|
integrity sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==
|
||||||
|
|
||||||
|
cjs-module-lexer@^0.6.0:
|
||||||
|
version "0.6.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/cjs-module-lexer/-/cjs-module-lexer-0.6.0.tgz#4186fcca0eae175970aee870b9fe2d6cf8d5655f"
|
||||||
|
integrity sha512-uc2Vix1frTfnuzxxu1Hp4ktSvM3QaI4oXl4ZUqL1wjTu/BGki9TrCWoqLTg/drR1KwAEarXuRFCG2Svr1GxPFw==
|
||||||
|
|
||||||
class-utils@^0.3.5:
|
class-utils@^0.3.5:
|
||||||
version "0.3.6"
|
version "0.3.6"
|
||||||
resolved "https://registry.yarnpkg.com/class-utils/-/class-utils-0.3.6.tgz#f93369ae8b9a7ce02fd41faad0ca83033190c463"
|
resolved "https://registry.yarnpkg.com/class-utils/-/class-utils-0.3.6.tgz#f93369ae8b9a7ce02fd41faad0ca83033190c463"
|
||||||
@@ -1039,7 +1709,12 @@ color-name@~1.1.4:
|
|||||||
resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2"
|
resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2"
|
||||||
integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==
|
integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==
|
||||||
|
|
||||||
combined-stream@^1.0.6, combined-stream@~1.0.6:
|
colorette@^1.2.2:
|
||||||
|
version "1.2.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/colorette/-/colorette-1.2.2.tgz#cbcc79d5e99caea2dbf10eb3a26fd8b3e6acfa94"
|
||||||
|
integrity sha512-MKGMzyfeuutC/ZJ1cba9NqcNpfeqMUcYmyF1ZFY6/Cn7CNSAKx6a+s48sqLqyAiZuaP2TcqMhoo+dlwFnVxT9w==
|
||||||
|
|
||||||
|
combined-stream@^1.0.8:
|
||||||
version "1.0.8"
|
version "1.0.8"
|
||||||
resolved "https://registry.yarnpkg.com/combined-stream/-/combined-stream-1.0.8.tgz#c3d45a8b34fd730631a110a8a2520682b31d5a7f"
|
resolved "https://registry.yarnpkg.com/combined-stream/-/combined-stream-1.0.8.tgz#c3d45a8b34fd730631a110a8a2520682b31d5a7f"
|
||||||
integrity sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==
|
integrity sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==
|
||||||
@@ -1067,9 +1742,9 @@ concat-map@0.0.1:
|
|||||||
integrity sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=
|
integrity sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=
|
||||||
|
|
||||||
convert-source-map@^1.4.0, convert-source-map@^1.6.0, convert-source-map@^1.7.0:
|
convert-source-map@^1.4.0, convert-source-map@^1.6.0, convert-source-map@^1.7.0:
|
||||||
version "1.7.0"
|
version "1.8.0"
|
||||||
resolved "https://registry.yarnpkg.com/convert-source-map/-/convert-source-map-1.7.0.tgz#17a2cb882d7f77d3490585e2ce6c524424a3a442"
|
resolved "https://registry.yarnpkg.com/convert-source-map/-/convert-source-map-1.8.0.tgz#f3373c32d21b4d780dd8004514684fb791ca4369"
|
||||||
integrity sha512-4FJkXzKXEDB1snCFZlLP4gpC3JILicCpGbzG9f9G7tGqGCzETQ2hWPrcinA9oU4wtf2biUaEH5065UnMeR33oA==
|
integrity sha512-+OQdjP49zViI/6i7nIJpA8rAl4sV/JdPfU9nZs3VqOwGIgizICvuN2ru6fMd+4llL0tar18UYJXfZ/TWtmhUjA==
|
||||||
dependencies:
|
dependencies:
|
||||||
safe-buffer "~5.1.1"
|
safe-buffer "~5.1.1"
|
||||||
|
|
||||||
@@ -1078,10 +1753,10 @@ copy-descriptor@^0.1.0:
|
|||||||
resolved "https://registry.yarnpkg.com/copy-descriptor/-/copy-descriptor-0.1.1.tgz#676f6eb3c39997c2ee1ac3a924fd6124748f578d"
|
resolved "https://registry.yarnpkg.com/copy-descriptor/-/copy-descriptor-0.1.1.tgz#676f6eb3c39997c2ee1ac3a924fd6124748f578d"
|
||||||
integrity sha1-Z29us8OZl8LuGsOpJP1hJHSPV40=
|
integrity sha1-Z29us8OZl8LuGsOpJP1hJHSPV40=
|
||||||
|
|
||||||
core-util-is@1.0.2:
|
core-util-is@~1.0.0:
|
||||||
version "1.0.2"
|
version "1.0.3"
|
||||||
resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.2.tgz#b5fd54220aa2bc5ab57aab7140c940754503c1a7"
|
resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.3.tgz#a6042d3634c2b27e9328f837b965fac83808db85"
|
||||||
integrity sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=
|
integrity sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==
|
||||||
|
|
||||||
cross-spawn@^6.0.0:
|
cross-spawn@^6.0.0:
|
||||||
version "6.0.5"
|
version "6.0.5"
|
||||||
@@ -1113,19 +1788,17 @@ cssom@~0.3.6:
|
|||||||
resolved "https://registry.yarnpkg.com/cssom/-/cssom-0.3.8.tgz#9f1276f5b2b463f2114d3f2c75250af8c1a36f4a"
|
resolved "https://registry.yarnpkg.com/cssom/-/cssom-0.3.8.tgz#9f1276f5b2b463f2114d3f2c75250af8c1a36f4a"
|
||||||
integrity sha512-b0tGHbfegbhPJpxpiBPU2sCkigAqtM9O121le6bbOlgyV+NyGyCmVfJ6QW9eRjz8CpNfWEOYBIMIGRYkLwsIYg==
|
integrity sha512-b0tGHbfegbhPJpxpiBPU2sCkigAqtM9O121le6bbOlgyV+NyGyCmVfJ6QW9eRjz8CpNfWEOYBIMIGRYkLwsIYg==
|
||||||
|
|
||||||
cssstyle@^2.2.0:
|
cssstyle@^2.3.0:
|
||||||
version "2.3.0"
|
version "2.3.0"
|
||||||
resolved "https://registry.yarnpkg.com/cssstyle/-/cssstyle-2.3.0.tgz#ff665a0ddbdc31864b09647f34163443d90b0852"
|
resolved "https://registry.yarnpkg.com/cssstyle/-/cssstyle-2.3.0.tgz#ff665a0ddbdc31864b09647f34163443d90b0852"
|
||||||
integrity sha512-AZL67abkUzIuvcHqk7c09cezpGNcxUxU4Ioi/05xHk4DQeTkWmGYftIE6ctU6AEt+Gn4n1lDStOtj7FKycP71A==
|
integrity sha512-AZL67abkUzIuvcHqk7c09cezpGNcxUxU4Ioi/05xHk4DQeTkWmGYftIE6ctU6AEt+Gn4n1lDStOtj7FKycP71A==
|
||||||
dependencies:
|
dependencies:
|
||||||
cssom "~0.3.6"
|
cssom "~0.3.6"
|
||||||
|
|
||||||
dashdash@^1.12.0:
|
data-uri-to-buffer@3:
|
||||||
version "1.14.1"
|
version "3.0.1"
|
||||||
resolved "https://registry.yarnpkg.com/dashdash/-/dashdash-1.14.1.tgz#853cfa0f7cbe2fed5de20326b8dd581035f6e2f0"
|
resolved "https://registry.yarnpkg.com/data-uri-to-buffer/-/data-uri-to-buffer-3.0.1.tgz#594b8973938c5bc2c33046535785341abc4f3636"
|
||||||
integrity sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=
|
integrity sha512-WboRycPNsVw3B3TL559F7kuBUM4d8CgMEvk6xEJlOp7OBPjt6G7z8WMWlD2rOFZLk6OYfFIUGsCOWzcQH9K2og==
|
||||||
dependencies:
|
|
||||||
assert-plus "^1.0.0"
|
|
||||||
|
|
||||||
data-urls@^2.0.0:
|
data-urls@^2.0.0:
|
||||||
version "2.0.0"
|
version "2.0.0"
|
||||||
@@ -1136,6 +1809,13 @@ data-urls@^2.0.0:
|
|||||||
whatwg-mimetype "^2.3.0"
|
whatwg-mimetype "^2.3.0"
|
||||||
whatwg-url "^8.0.0"
|
whatwg-url "^8.0.0"
|
||||||
|
|
||||||
|
debug@4, debug@^4.1.0, debug@^4.1.1:
|
||||||
|
version "4.3.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.2.tgz#f0a49c18ac8779e31d4a0c6029dfb76873c7428b"
|
||||||
|
integrity sha512-mOp8wKcvj7XxC78zLgw/ZA+6TSgkoE2C/ienthhRD298T7UNwAg9diBpLRxC0mOezLl4B0xV7M0cCO6P/O0Xhw==
|
||||||
|
dependencies:
|
||||||
|
ms "2.1.2"
|
||||||
|
|
||||||
debug@^2.2.0, debug@^2.3.3:
|
debug@^2.2.0, debug@^2.3.3:
|
||||||
version "2.6.9"
|
version "2.6.9"
|
||||||
resolved "https://registry.yarnpkg.com/debug/-/debug-2.6.9.tgz#5d128515df134ff327e90a4c93f4e077a536341f"
|
resolved "https://registry.yarnpkg.com/debug/-/debug-2.6.9.tgz#5d128515df134ff327e90a4c93f4e077a536341f"
|
||||||
@@ -1143,22 +1823,15 @@ debug@^2.2.0, debug@^2.3.3:
|
|||||||
dependencies:
|
dependencies:
|
||||||
ms "2.0.0"
|
ms "2.0.0"
|
||||||
|
|
||||||
debug@^4.1.0, debug@^4.1.1:
|
|
||||||
version "4.1.1"
|
|
||||||
resolved "https://registry.yarnpkg.com/debug/-/debug-4.1.1.tgz#3b72260255109c6b589cee050f1d516139664791"
|
|
||||||
integrity sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==
|
|
||||||
dependencies:
|
|
||||||
ms "^2.1.1"
|
|
||||||
|
|
||||||
decamelize@^1.2.0:
|
decamelize@^1.2.0:
|
||||||
version "1.2.0"
|
version "1.2.0"
|
||||||
resolved "https://registry.yarnpkg.com/decamelize/-/decamelize-1.2.0.tgz#f6534d15148269b20352e7bee26f501f9a191290"
|
resolved "https://registry.yarnpkg.com/decamelize/-/decamelize-1.2.0.tgz#f6534d15148269b20352e7bee26f501f9a191290"
|
||||||
integrity sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=
|
integrity sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=
|
||||||
|
|
||||||
decimal.js@^10.2.0:
|
decimal.js@^10.2.1:
|
||||||
version "10.2.0"
|
version "10.3.1"
|
||||||
resolved "https://registry.yarnpkg.com/decimal.js/-/decimal.js-10.2.0.tgz#39466113a9e036111d02f82489b5fd6b0b5ed231"
|
resolved "https://registry.yarnpkg.com/decimal.js/-/decimal.js-10.3.1.tgz#d8c3a444a9c6774ba60ca6ad7261c3a94fd5e783"
|
||||||
integrity sha512-vDPw+rDgn3bZe1+F/pyEwb1oMG2XTlRVgAa6B4KccTEpYgF8w6eQllVbQcfIJnZyvzFtFpxnpGtx8dd7DJp/Rw==
|
integrity sha512-V0pfhfr8suzyPGOx3nmq4aHqabehUZn6Ch9kyFpV79TGDTWFmHqUqXdabR7QHqxzrYolF4+tVmJhUG4OURg5dQ==
|
||||||
|
|
||||||
decode-uri-component@^0.2.0:
|
decode-uri-component@^0.2.0:
|
||||||
version "0.2.0"
|
version "0.2.0"
|
||||||
@@ -1202,25 +1875,35 @@ define-property@^2.0.2:
|
|||||||
is-descriptor "^1.0.2"
|
is-descriptor "^1.0.2"
|
||||||
isobject "^3.0.1"
|
isobject "^3.0.1"
|
||||||
|
|
||||||
|
degenerator@^3.0.1:
|
||||||
|
version "3.0.1"
|
||||||
|
resolved "https://registry.yarnpkg.com/degenerator/-/degenerator-3.0.1.tgz#7ef78ec0c8577a544477308ddf1d2d6e88d51f5b"
|
||||||
|
integrity sha512-LFsIFEeLPlKvAKXu7j3ssIG6RT0TbI7/GhsqrI0DnHASEQjXQ0LUSYcjJteGgRGmZbl1TnMSxpNQIAiJ7Du5TQ==
|
||||||
|
dependencies:
|
||||||
|
ast-types "^0.13.2"
|
||||||
|
escodegen "^1.8.1"
|
||||||
|
esprima "^4.0.0"
|
||||||
|
vm2 "^3.9.3"
|
||||||
|
|
||||||
delayed-stream@~1.0.0:
|
delayed-stream@~1.0.0:
|
||||||
version "1.0.0"
|
version "1.0.0"
|
||||||
resolved "https://registry.yarnpkg.com/delayed-stream/-/delayed-stream-1.0.0.tgz#df3ae199acadfb7d440aaae0b29e2272b24ec619"
|
resolved "https://registry.yarnpkg.com/delayed-stream/-/delayed-stream-1.0.0.tgz#df3ae199acadfb7d440aaae0b29e2272b24ec619"
|
||||||
integrity sha1-3zrhmayt+31ECqrgsp4icrJOxhk=
|
integrity sha1-3zrhmayt+31ECqrgsp4icrJOxhk=
|
||||||
|
|
||||||
|
depd@~1.1.2:
|
||||||
|
version "1.1.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/depd/-/depd-1.1.2.tgz#9bcd52e14c097763e749b274c4346ed2e560b5a9"
|
||||||
|
integrity sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=
|
||||||
|
|
||||||
detect-newline@^3.0.0:
|
detect-newline@^3.0.0:
|
||||||
version "3.1.0"
|
version "3.1.0"
|
||||||
resolved "https://registry.yarnpkg.com/detect-newline/-/detect-newline-3.1.0.tgz#576f5dfc63ae1a192ff192d8ad3af6308991b651"
|
resolved "https://registry.yarnpkg.com/detect-newline/-/detect-newline-3.1.0.tgz#576f5dfc63ae1a192ff192d8ad3af6308991b651"
|
||||||
integrity sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA==
|
integrity sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA==
|
||||||
|
|
||||||
diff-sequences@^25.2.6:
|
diff-sequences@^26.6.2:
|
||||||
version "25.2.6"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/diff-sequences/-/diff-sequences-25.2.6.tgz#5f467c00edd35352b7bca46d7927d60e687a76dd"
|
resolved "https://registry.yarnpkg.com/diff-sequences/-/diff-sequences-26.6.2.tgz#48ba99157de1923412eed41db6b6d4aa9ca7c0b1"
|
||||||
integrity sha512-Hq8o7+6GaZeoFjtpgvRBUknSXNeJiCx7V9Fr94ZMljNiCr9n9L8H8aJqgWOQiDDGdyn29fRNcDdRVJ5fdyihfg==
|
integrity sha512-Mv/TDa3nZ9sbc5soK+OoA74BsS3mL37yixCvUAQkiuA4Wz6YtwP/K47n2rv2ovzHZvoiQeA5FTQOschKkEwB0Q==
|
||||||
|
|
||||||
diff-sequences@^26.3.0:
|
|
||||||
version "26.3.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/diff-sequences/-/diff-sequences-26.3.0.tgz#62a59b1b29ab7fd27cef2a33ae52abe73042d0a2"
|
|
||||||
integrity sha512-5j5vdRcw3CNctePNYN0Wy2e/JbWT6cAYnXv5OuqPhDpyCGc0uLu2TK0zOCJWNB9kOIfYMSpIulRaDgIi4HJ6Ig==
|
|
||||||
|
|
||||||
domexception@^2.0.1:
|
domexception@^2.0.1:
|
||||||
version "2.0.1"
|
version "2.0.1"
|
||||||
@@ -1229,18 +1912,10 @@ domexception@^2.0.1:
|
|||||||
dependencies:
|
dependencies:
|
||||||
webidl-conversions "^5.0.0"
|
webidl-conversions "^5.0.0"
|
||||||
|
|
||||||
dotenv@^8.2.0:
|
dotenv@^8.6.0:
|
||||||
version "8.2.0"
|
version "8.6.0"
|
||||||
resolved "https://registry.yarnpkg.com/dotenv/-/dotenv-8.2.0.tgz#97e619259ada750eea3e4ea3e26bceea5424b16a"
|
resolved "https://registry.yarnpkg.com/dotenv/-/dotenv-8.6.0.tgz#061af664d19f7f4d8fc6e4ff9b584ce237adcb8b"
|
||||||
integrity sha512-8sJ78ElpbDJBHNeBzUbUVLsqKdccaa/BXF1uPTw3GrvQTBgrQrtObr2mUrE38vzYd8cEv+m/JBfDLioYcfXoaw==
|
integrity sha512-IrPdXQsk2BbzvCBGBOTmmSH5SodmqZNt4ERAZDmW4CT+tL8VtvinqywuANaFu4bOMWki16nqf0e4oC0QIaDr/g==
|
||||||
|
|
||||||
ecc-jsbn@~0.1.1:
|
|
||||||
version "0.1.2"
|
|
||||||
resolved "https://registry.yarnpkg.com/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz#3a83a904e54353287874c564b7549386849a98c9"
|
|
||||||
integrity sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=
|
|
||||||
dependencies:
|
|
||||||
jsbn "~0.1.0"
|
|
||||||
safer-buffer "^2.1.0"
|
|
||||||
|
|
||||||
editorconfig@^0.15.0:
|
editorconfig@^0.15.0:
|
||||||
version "0.15.3"
|
version "0.15.3"
|
||||||
@@ -1252,10 +1927,15 @@ editorconfig@^0.15.0:
|
|||||||
semver "^5.6.0"
|
semver "^5.6.0"
|
||||||
sigmund "^1.0.1"
|
sigmund "^1.0.1"
|
||||||
|
|
||||||
|
electron-to-chromium@^1.3.723:
|
||||||
|
version "1.3.768"
|
||||||
|
resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.3.768.tgz#bbe47394f0073c947168589b7d19388518a7a9a9"
|
||||||
|
integrity sha512-I4UMZHhVSK2pwt8jOIxTi3GIuc41NkddtKT/hpuxp9GO5UWJgDKTBa4TACppbVAuKtKbMK6BhQZvT5tFF1bcNA==
|
||||||
|
|
||||||
emittery@^0.7.1:
|
emittery@^0.7.1:
|
||||||
version "0.7.1"
|
version "0.7.2"
|
||||||
resolved "https://registry.yarnpkg.com/emittery/-/emittery-0.7.1.tgz#c02375a927a40948c0345cc903072597f5270451"
|
resolved "https://registry.yarnpkg.com/emittery/-/emittery-0.7.2.tgz#25595908e13af0f5674ab419396e2fb394cdfa82"
|
||||||
integrity sha512-d34LN4L6h18Bzz9xpoku2nPwKxCPlPMr3EEKTkoEBi+1/+b0lcRkRJ1UVyyZaKNeqGR3swcGl6s390DNO4YVgQ==
|
integrity sha512-A8OG5SR/ij3SsJdWDJdkkSYUjQdCUx6APQXem0SaEePBSRg4eymGYwBkKo1Y6DU+af/Jn2dBQqDBvjnr9Vi8nQ==
|
||||||
|
|
||||||
emoji-regex@^8.0.0:
|
emoji-regex@^8.0.0:
|
||||||
version "8.0.0"
|
version "8.0.0"
|
||||||
@@ -1269,6 +1949,11 @@ end-of-stream@^1.1.0:
|
|||||||
dependencies:
|
dependencies:
|
||||||
once "^1.4.0"
|
once "^1.4.0"
|
||||||
|
|
||||||
|
entities@2.2.0:
|
||||||
|
version "2.2.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/entities/-/entities-2.2.0.tgz#098dc90ebb83d8dffa089d55256b351d34c4da55"
|
||||||
|
integrity sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A==
|
||||||
|
|
||||||
error-ex@^1.3.1:
|
error-ex@^1.3.1:
|
||||||
version "1.3.2"
|
version "1.3.2"
|
||||||
resolved "https://registry.yarnpkg.com/error-ex/-/error-ex-1.3.2.tgz#b4ac40648107fdcdcfae242f428bea8a14d4f1bf"
|
resolved "https://registry.yarnpkg.com/error-ex/-/error-ex-1.3.2.tgz#b4ac40648107fdcdcfae242f428bea8a14d4f1bf"
|
||||||
@@ -1276,6 +1961,11 @@ error-ex@^1.3.1:
|
|||||||
dependencies:
|
dependencies:
|
||||||
is-arrayish "^0.2.1"
|
is-arrayish "^0.2.1"
|
||||||
|
|
||||||
|
escalade@^3.1.1:
|
||||||
|
version "3.1.1"
|
||||||
|
resolved "https://registry.yarnpkg.com/escalade/-/escalade-3.1.1.tgz#d8cfdc7000965c5a0174b4a82eaa5c0552742e40"
|
||||||
|
integrity sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==
|
||||||
|
|
||||||
escape-string-regexp@^1.0.5:
|
escape-string-regexp@^1.0.5:
|
||||||
version "1.0.5"
|
version "1.0.5"
|
||||||
resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz#1b61c0562190a8dff6ae3bb2cf0200ca130b86d4"
|
resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz#1b61c0562190a8dff6ae3bb2cf0200ca130b86d4"
|
||||||
@@ -1286,7 +1976,7 @@ escape-string-regexp@^2.0.0:
|
|||||||
resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz#a30304e99daa32e23b2fd20f51babd07cffca344"
|
resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz#a30304e99daa32e23b2fd20f51babd07cffca344"
|
||||||
integrity sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==
|
integrity sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==
|
||||||
|
|
||||||
escodegen@^1.14.1:
|
escodegen@^1.8.1:
|
||||||
version "1.14.3"
|
version "1.14.3"
|
||||||
resolved "https://registry.yarnpkg.com/escodegen/-/escodegen-1.14.3.tgz#4e7b81fba61581dc97582ed78cab7f0e8d63f503"
|
resolved "https://registry.yarnpkg.com/escodegen/-/escodegen-1.14.3.tgz#4e7b81fba61581dc97582ed78cab7f0e8d63f503"
|
||||||
integrity sha512-qFcX0XJkdg+PB3xjZZG/wKSuT1PnQWx57+TVSjIMmILd2yC/6ByYElPwJnslDsuWuSAp4AwJGumarAAmJch5Kw==
|
integrity sha512-qFcX0XJkdg+PB3xjZZG/wKSuT1PnQWx57+TVSjIMmILd2yC/6ByYElPwJnslDsuWuSAp4AwJGumarAAmJch5Kw==
|
||||||
@@ -1298,6 +1988,18 @@ escodegen@^1.14.1:
|
|||||||
optionalDependencies:
|
optionalDependencies:
|
||||||
source-map "~0.6.1"
|
source-map "~0.6.1"
|
||||||
|
|
||||||
|
escodegen@^2.0.0:
|
||||||
|
version "2.0.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/escodegen/-/escodegen-2.0.0.tgz#5e32b12833e8aa8fa35e1bf0befa89380484c7dd"
|
||||||
|
integrity sha512-mmHKys/C8BFUGI+MAWNcSYoORYLMdPzjrknd2Vc+bUsjN5bXcr8EhrNB+UTqfL1y3I9c4fw2ihgtMPQLBRiQxw==
|
||||||
|
dependencies:
|
||||||
|
esprima "^4.0.1"
|
||||||
|
estraverse "^5.2.0"
|
||||||
|
esutils "^2.0.2"
|
||||||
|
optionator "^0.8.1"
|
||||||
|
optionalDependencies:
|
||||||
|
source-map "~0.6.1"
|
||||||
|
|
||||||
esprima@^4.0.0, esprima@^4.0.1:
|
esprima@^4.0.0, esprima@^4.0.1:
|
||||||
version "4.0.1"
|
version "4.0.1"
|
||||||
resolved "https://registry.yarnpkg.com/esprima/-/esprima-4.0.1.tgz#13b04cdb3e6c5d19df91ab6987a8695619b0aa71"
|
resolved "https://registry.yarnpkg.com/esprima/-/esprima-4.0.1.tgz#13b04cdb3e6c5d19df91ab6987a8695619b0aa71"
|
||||||
@@ -1308,15 +2010,20 @@ estraverse@^4.2.0:
|
|||||||
resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-4.3.0.tgz#398ad3f3c5a24948be7725e83d11a7de28cdbd1d"
|
resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-4.3.0.tgz#398ad3f3c5a24948be7725e83d11a7de28cdbd1d"
|
||||||
integrity sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==
|
integrity sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==
|
||||||
|
|
||||||
|
estraverse@^5.2.0:
|
||||||
|
version "5.2.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-5.2.0.tgz#307df42547e6cc7324d3cf03c155d5cdb8c53880"
|
||||||
|
integrity sha512-BxbNGGNm0RyRYvUdHpIwv9IWzeM9XClbOxwoATuFdOE7ZE6wHL+HQ5T8hoPM+zHvmKzzsEqhgy0GrQ5X13afiQ==
|
||||||
|
|
||||||
esutils@^2.0.2:
|
esutils@^2.0.2:
|
||||||
version "2.0.3"
|
version "2.0.3"
|
||||||
resolved "https://registry.yarnpkg.com/esutils/-/esutils-2.0.3.tgz#74d2eb4de0b8da1293711910d50775b9b710ef64"
|
resolved "https://registry.yarnpkg.com/esutils/-/esutils-2.0.3.tgz#74d2eb4de0b8da1293711910d50775b9b710ef64"
|
||||||
integrity sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==
|
integrity sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==
|
||||||
|
|
||||||
exec-sh@^0.3.2:
|
exec-sh@^0.3.2:
|
||||||
version "0.3.4"
|
version "0.3.6"
|
||||||
resolved "https://registry.yarnpkg.com/exec-sh/-/exec-sh-0.3.4.tgz#3a018ceb526cc6f6df2bb504b2bfe8e3a4934ec5"
|
resolved "https://registry.yarnpkg.com/exec-sh/-/exec-sh-0.3.6.tgz#ff264f9e325519a60cb5e273692943483cca63bc"
|
||||||
integrity sha512-sEFIkc61v75sWeOe72qyrqg2Qg0OuLESziUDk/O/z2qgS15y2gWVFrI6f2Qn/qw/0/NCfCEsmNA4zOjkwEZT1A==
|
integrity sha512-nQn+hI3yp+oD0huYhKwvYI32+JFeq+XkNcD1GAo3Y/MjxsfVGmrrzrnzjWiNY6f+pUCP440fThsFh5gZrRAU/w==
|
||||||
|
|
||||||
execa@^1.0.0:
|
execa@^1.0.0:
|
||||||
version "1.0.0"
|
version "1.0.0"
|
||||||
@@ -1332,9 +2039,9 @@ execa@^1.0.0:
|
|||||||
strip-eof "^1.0.0"
|
strip-eof "^1.0.0"
|
||||||
|
|
||||||
execa@^4.0.0:
|
execa@^4.0.0:
|
||||||
version "4.0.3"
|
version "4.1.0"
|
||||||
resolved "https://registry.yarnpkg.com/execa/-/execa-4.0.3.tgz#0a34dabbad6d66100bd6f2c576c8669403f317f2"
|
resolved "https://registry.yarnpkg.com/execa/-/execa-4.1.0.tgz#4e5491ad1572f2f17a77d388c6c857135b22847a"
|
||||||
integrity sha512-WFDXGHckXPWZX19t1kCsXzOpqX9LWYNqn4C+HqZlk/V0imTkzJZqf87ZBhvpHaftERYknpk0fjSylnXVlVgI0A==
|
integrity sha512-j5W0//W7f8UxAn8hXVnwG8tLwdiUy4FJLcSupCg6maBYZDpyBvTApK7KyuI4bKj8KOh1r2YH+6ucuYtJv1bTZA==
|
||||||
dependencies:
|
dependencies:
|
||||||
cross-spawn "^7.0.0"
|
cross-spawn "^7.0.0"
|
||||||
get-stream "^5.0.0"
|
get-stream "^5.0.0"
|
||||||
@@ -1364,16 +2071,16 @@ expand-brackets@^2.1.4:
|
|||||||
snapdragon "^0.8.1"
|
snapdragon "^0.8.1"
|
||||||
to-regex "^3.0.1"
|
to-regex "^3.0.1"
|
||||||
|
|
||||||
expect@^26.4.1:
|
expect@^26.6.2:
|
||||||
version "26.4.1"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/expect/-/expect-26.4.1.tgz#6ed3dc218e6a9ffce16c15edc518f44bad9a6731"
|
resolved "https://registry.yarnpkg.com/expect/-/expect-26.6.2.tgz#c6b996bf26bf3fe18b67b2d0f51fc981ba934417"
|
||||||
integrity sha512-PnsyF/VmPRH/HAWELjrIAgQ5h+4JLTiomA1A2djx+jXrCQzQ/4egZYBOEx9hShoX+mQLS4enYk6Ouxk8b4kcEw==
|
integrity sha512-9/hlOBkQl2l/PLHJx6JjoDF6xPKcJEsUlWKb23rKE7KzeDqUZKXKNMW27KIue5JMdBV9HgmoJPcc8HtO85t9IA==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
ansi-styles "^4.0.0"
|
ansi-styles "^4.0.0"
|
||||||
jest-get-type "^26.3.0"
|
jest-get-type "^26.3.0"
|
||||||
jest-matcher-utils "^26.4.1"
|
jest-matcher-utils "^26.6.2"
|
||||||
jest-message-util "^26.3.0"
|
jest-message-util "^26.6.2"
|
||||||
jest-regex-util "^26.0.0"
|
jest-regex-util "^26.0.0"
|
||||||
|
|
||||||
extend-shallow@^2.0.1:
|
extend-shallow@^2.0.1:
|
||||||
@@ -1391,11 +2098,6 @@ extend-shallow@^3.0.0, extend-shallow@^3.0.2:
|
|||||||
assign-symbols "^1.0.0"
|
assign-symbols "^1.0.0"
|
||||||
is-extendable "^1.0.1"
|
is-extendable "^1.0.1"
|
||||||
|
|
||||||
extend@~3.0.2:
|
|
||||||
version "3.0.2"
|
|
||||||
resolved "https://registry.yarnpkg.com/extend/-/extend-3.0.2.tgz#f8b1136b4071fbd8eb140aff858b1019ec2915fa"
|
|
||||||
integrity sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==
|
|
||||||
|
|
||||||
extglob@^2.0.4:
|
extglob@^2.0.4:
|
||||||
version "2.0.4"
|
version "2.0.4"
|
||||||
resolved "https://registry.yarnpkg.com/extglob/-/extglob-2.0.4.tgz#ad00fe4dc612a9232e8718711dc5cb5ab0285543"
|
resolved "https://registry.yarnpkg.com/extglob/-/extglob-2.0.4.tgz#ad00fe4dc612a9232e8718711dc5cb5ab0285543"
|
||||||
@@ -1410,21 +2112,6 @@ extglob@^2.0.4:
|
|||||||
snapdragon "^0.8.1"
|
snapdragon "^0.8.1"
|
||||||
to-regex "^3.0.1"
|
to-regex "^3.0.1"
|
||||||
|
|
||||||
extsprintf@1.3.0:
|
|
||||||
version "1.3.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/extsprintf/-/extsprintf-1.3.0.tgz#96918440e3041a7a414f8c52e3c574eb3c3e1e05"
|
|
||||||
integrity sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=
|
|
||||||
|
|
||||||
extsprintf@^1.2.0:
|
|
||||||
version "1.4.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/extsprintf/-/extsprintf-1.4.0.tgz#e2689f8f356fad62cca65a3a91c5df5f9551692f"
|
|
||||||
integrity sha1-4mifjzVvrWLMplo6kcXfX5VRaS8=
|
|
||||||
|
|
||||||
fast-deep-equal@^3.1.1:
|
|
||||||
version "3.1.3"
|
|
||||||
resolved "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-3.1.3.tgz#3a7d56b559d6cbc3eb512325244e619a65c6c525"
|
|
||||||
integrity sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==
|
|
||||||
|
|
||||||
fast-json-stable-stringify@2.x, fast-json-stable-stringify@^2.0.0:
|
fast-json-stable-stringify@2.x, fast-json-stable-stringify@^2.0.0:
|
||||||
version "2.1.0"
|
version "2.1.0"
|
||||||
resolved "https://registry.yarnpkg.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz#874bf69c6f404c2b5d99c481341399fd55892633"
|
resolved "https://registry.yarnpkg.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz#874bf69c6f404c2b5d99c481341399fd55892633"
|
||||||
@@ -1435,6 +2122,11 @@ fast-levenshtein@~2.0.6:
|
|||||||
resolved "https://registry.yarnpkg.com/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz#3d8a5c66883a16a30ca8643e851f19baa7797917"
|
resolved "https://registry.yarnpkg.com/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz#3d8a5c66883a16a30ca8643e851f19baa7797917"
|
||||||
integrity sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=
|
integrity sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=
|
||||||
|
|
||||||
|
fast-xml-parser@3.19.0:
|
||||||
|
version "3.19.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/fast-xml-parser/-/fast-xml-parser-3.19.0.tgz#cb637ec3f3999f51406dd8ff0e6fc4d83e520d01"
|
||||||
|
integrity sha512-4pXwmBplsCPv8FOY1WRakF970TjNGnGnfbOnLqjlYvMiF1SR3yOHyxMR/YCXpPTOspNF5gwudqktIP4VsWkvBg==
|
||||||
|
|
||||||
fb-watchman@^2.0.0:
|
fb-watchman@^2.0.0:
|
||||||
version "2.0.1"
|
version "2.0.1"
|
||||||
resolved "https://registry.yarnpkg.com/fb-watchman/-/fb-watchman-2.0.1.tgz#fc84fb39d2709cf3ff6d743706157bb5708a8a85"
|
resolved "https://registry.yarnpkg.com/fb-watchman/-/fb-watchman-2.0.1.tgz#fc84fb39d2709cf3ff6d743706157bb5708a8a85"
|
||||||
@@ -1442,6 +2134,11 @@ fb-watchman@^2.0.0:
|
|||||||
dependencies:
|
dependencies:
|
||||||
bser "2.1.1"
|
bser "2.1.1"
|
||||||
|
|
||||||
|
file-uri-to-path@2:
|
||||||
|
version "2.0.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/file-uri-to-path/-/file-uri-to-path-2.0.0.tgz#7b415aeba227d575851e0a5b0c640d7656403fba"
|
||||||
|
integrity sha512-hjPFI8oE/2iQPVe4gbrJ73Pp+Xfub2+WI2LlXDbsaJBwT5wuMh35WNWVYYTpnz895shtwfyutMFLFywpQAFdLg==
|
||||||
|
|
||||||
fill-range@^4.0.0:
|
fill-range@^4.0.0:
|
||||||
version "4.0.0"
|
version "4.0.0"
|
||||||
resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-4.0.0.tgz#d544811d428f98eb06a63dc402d2403c328c38f7"
|
resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-4.0.0.tgz#d544811d428f98eb06a63dc402d2403c328c38f7"
|
||||||
@@ -1472,18 +2169,13 @@ for-in@^1.0.2:
|
|||||||
resolved "https://registry.yarnpkg.com/for-in/-/for-in-1.0.2.tgz#81068d295a8142ec0ac726c6e2200c30fb6d5e80"
|
resolved "https://registry.yarnpkg.com/for-in/-/for-in-1.0.2.tgz#81068d295a8142ec0ac726c6e2200c30fb6d5e80"
|
||||||
integrity sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=
|
integrity sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=
|
||||||
|
|
||||||
forever-agent@~0.6.1:
|
form-data@^3.0.0:
|
||||||
version "0.6.1"
|
version "3.0.1"
|
||||||
resolved "https://registry.yarnpkg.com/forever-agent/-/forever-agent-0.6.1.tgz#fbc71f0c41adeb37f96c577ad1ed42d8fdacca91"
|
resolved "https://registry.yarnpkg.com/form-data/-/form-data-3.0.1.tgz#ebd53791b78356a99af9a300d4282c4d5eb9755f"
|
||||||
integrity sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=
|
integrity sha512-RHkBKtLWUVwd7SqRIvCZMEvAMoGUp0XU+seQiZejj0COz3RI3hWP4sCv3gZWWLjJTd7rGwcsF5eKZGii0r/hbg==
|
||||||
|
|
||||||
form-data@~2.3.2:
|
|
||||||
version "2.3.3"
|
|
||||||
resolved "https://registry.yarnpkg.com/form-data/-/form-data-2.3.3.tgz#dcce52c05f644f298c6a7ab936bd724ceffbf3a6"
|
|
||||||
integrity sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==
|
|
||||||
dependencies:
|
dependencies:
|
||||||
asynckit "^0.4.0"
|
asynckit "^0.4.0"
|
||||||
combined-stream "^1.0.6"
|
combined-stream "^1.0.8"
|
||||||
mime-types "^2.1.12"
|
mime-types "^2.1.12"
|
||||||
|
|
||||||
fragment-cache@^0.2.1:
|
fragment-cache@^0.2.1:
|
||||||
@@ -1493,20 +2185,42 @@ fragment-cache@^0.2.1:
|
|||||||
dependencies:
|
dependencies:
|
||||||
map-cache "^0.2.2"
|
map-cache "^0.2.2"
|
||||||
|
|
||||||
|
fs-extra@^8.1.0:
|
||||||
|
version "8.1.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/fs-extra/-/fs-extra-8.1.0.tgz#49d43c45a88cd9677668cb7be1b46efdb8d2e1c0"
|
||||||
|
integrity sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g==
|
||||||
|
dependencies:
|
||||||
|
graceful-fs "^4.2.0"
|
||||||
|
jsonfile "^4.0.0"
|
||||||
|
universalify "^0.1.0"
|
||||||
|
|
||||||
fs.realpath@^1.0.0:
|
fs.realpath@^1.0.0:
|
||||||
version "1.0.0"
|
version "1.0.0"
|
||||||
resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f"
|
resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f"
|
||||||
integrity sha1-FQStJSMVjKpA20onh8sBQRmU6k8=
|
integrity sha1-FQStJSMVjKpA20onh8sBQRmU6k8=
|
||||||
|
|
||||||
fsevents@^2.1.2:
|
fsevents@^2.1.2:
|
||||||
version "2.1.3"
|
version "2.3.2"
|
||||||
resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.1.3.tgz#fb738703ae8d2f9fe900c33836ddebee8b97f23e"
|
resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.3.2.tgz#8a526f78b8fdf4623b709e0b975c52c24c02fd1a"
|
||||||
integrity sha512-Auw9a4AxqWpa9GUfj370BMPzzyncfBABW8Mab7BGWBYDj4Isgq+cDKtx0i6u9jcX9pQDnswsaaOTgTmA5pEjuQ==
|
integrity sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA==
|
||||||
|
|
||||||
gensync@^1.0.0-beta.1:
|
ftp@^0.3.10:
|
||||||
version "1.0.0-beta.1"
|
version "0.3.10"
|
||||||
resolved "https://registry.yarnpkg.com/gensync/-/gensync-1.0.0-beta.1.tgz#58f4361ff987e5ff6e1e7a210827aa371eaac269"
|
resolved "https://registry.yarnpkg.com/ftp/-/ftp-0.3.10.tgz#9197d861ad8142f3e63d5a83bfe4c59f7330885d"
|
||||||
integrity sha512-r8EC6NO1sngH/zdD9fiRDLdcgnbayXah+mLgManTaIZJqEC1MZstmnox8KpnI2/fxQwrp5OpCOYWLp4rBl4Jcg==
|
integrity sha1-kZfYYa2BQvPmPVqDv+TFn3MwiF0=
|
||||||
|
dependencies:
|
||||||
|
readable-stream "1.1.x"
|
||||||
|
xregexp "2.0.0"
|
||||||
|
|
||||||
|
function-bind@^1.1.1:
|
||||||
|
version "1.1.1"
|
||||||
|
resolved "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.1.tgz#a56899d3ea3c9bab874bb9773b7c5ede92f4895d"
|
||||||
|
integrity sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==
|
||||||
|
|
||||||
|
gensync@^1.0.0-beta.2:
|
||||||
|
version "1.0.0-beta.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/gensync/-/gensync-1.0.0-beta.2.tgz#32a6ee76c3d7f52d46b2b1ae5d93fea8580a25e0"
|
||||||
|
integrity sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==
|
||||||
|
|
||||||
get-caller-file@^2.0.1:
|
get-caller-file@^2.0.1:
|
||||||
version "2.0.5"
|
version "2.0.5"
|
||||||
@@ -1532,22 +2246,27 @@ get-stream@^5.0.0:
|
|||||||
dependencies:
|
dependencies:
|
||||||
pump "^3.0.0"
|
pump "^3.0.0"
|
||||||
|
|
||||||
|
get-uri@3:
|
||||||
|
version "3.0.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/get-uri/-/get-uri-3.0.2.tgz#f0ef1356faabc70e1f9404fa3b66b2ba9bfc725c"
|
||||||
|
integrity sha512-+5s0SJbGoyiJTZZ2JTpFPLMPSch72KEqGOTvQsBqg0RBWvwhWUSYZFAtz3TPW0GXJuLBJPts1E241iHg+VRfhg==
|
||||||
|
dependencies:
|
||||||
|
"@tootallnate/once" "1"
|
||||||
|
data-uri-to-buffer "3"
|
||||||
|
debug "4"
|
||||||
|
file-uri-to-path "2"
|
||||||
|
fs-extra "^8.1.0"
|
||||||
|
ftp "^0.3.10"
|
||||||
|
|
||||||
get-value@^2.0.3, get-value@^2.0.6:
|
get-value@^2.0.3, get-value@^2.0.6:
|
||||||
version "2.0.6"
|
version "2.0.6"
|
||||||
resolved "https://registry.yarnpkg.com/get-value/-/get-value-2.0.6.tgz#dc15ca1c672387ca76bd37ac0a395ba2042a2c28"
|
resolved "https://registry.yarnpkg.com/get-value/-/get-value-2.0.6.tgz#dc15ca1c672387ca76bd37ac0a395ba2042a2c28"
|
||||||
integrity sha1-3BXKHGcjh8p2vTesCjlbogQqLCg=
|
integrity sha1-3BXKHGcjh8p2vTesCjlbogQqLCg=
|
||||||
|
|
||||||
getpass@^0.1.1:
|
|
||||||
version "0.1.7"
|
|
||||||
resolved "https://registry.yarnpkg.com/getpass/-/getpass-0.1.7.tgz#5eff8e3e684d569ae4cb2b1282604e8ba62149fa"
|
|
||||||
integrity sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=
|
|
||||||
dependencies:
|
|
||||||
assert-plus "^1.0.0"
|
|
||||||
|
|
||||||
glob@^7.1.1, glob@^7.1.2, glob@^7.1.3, glob@^7.1.4:
|
glob@^7.1.1, glob@^7.1.2, glob@^7.1.3, glob@^7.1.4:
|
||||||
version "7.1.6"
|
version "7.1.7"
|
||||||
resolved "https://registry.yarnpkg.com/glob/-/glob-7.1.6.tgz#141f33b81a7c2492e125594307480c46679278a6"
|
resolved "https://registry.yarnpkg.com/glob/-/glob-7.1.7.tgz#3b193e9233f01d42d0b3f78294bbeeb418f94a90"
|
||||||
integrity sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==
|
integrity sha512-OvD9ENzPLbegENnYP5UUfJIirTg4+XwMWGaQfQTY0JenxNvvIKP3U3/tAQSPIu/lHxXYSZmpXlUHeqAIdKzBLQ==
|
||||||
dependencies:
|
dependencies:
|
||||||
fs.realpath "^1.0.0"
|
fs.realpath "^1.0.0"
|
||||||
inflight "^1.0.4"
|
inflight "^1.0.4"
|
||||||
@@ -1561,29 +2280,21 @@ globals@^11.1.0:
|
|||||||
resolved "https://registry.yarnpkg.com/globals/-/globals-11.12.0.tgz#ab8795338868a0babd8525758018c2a7eb95c42e"
|
resolved "https://registry.yarnpkg.com/globals/-/globals-11.12.0.tgz#ab8795338868a0babd8525758018c2a7eb95c42e"
|
||||||
integrity sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==
|
integrity sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==
|
||||||
|
|
||||||
|
graceful-fs@^4.1.6, graceful-fs@^4.2.0:
|
||||||
|
version "4.2.9"
|
||||||
|
resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.9.tgz#041b05df45755e587a24942279b9d113146e1c96"
|
||||||
|
integrity sha512-NtNxqUcXgpW2iMrfqSfR73Glt39K+BLwWsPs94yR63v45T0Wbej7eRmL5cWfwEgqXnmjQp3zaJTshdRW/qC2ZQ==
|
||||||
|
|
||||||
graceful-fs@^4.2.4:
|
graceful-fs@^4.2.4:
|
||||||
version "4.2.4"
|
version "4.2.6"
|
||||||
resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.4.tgz#2256bde14d3632958c465ebc96dc467ca07a29fb"
|
resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.6.tgz#ff040b2b0853b23c3d31027523706f1885d76bee"
|
||||||
integrity sha512-WjKPNJF79dtJAVniUlGGWHYGz2jWxT6VhN/4m1NdkbZ2nOsEF+cI1Edgql5zCRhs/VsQYRvrXctxktVXZUkixw==
|
integrity sha512-nTnJ528pbqxYanhpDYsi4Rd8MAeaBA67+RZ10CM1m3bTAVFEDcd5AuA4a6W5YkGZ1iNXHzZz8T6TBKLeBuNriQ==
|
||||||
|
|
||||||
growly@^1.3.0:
|
growly@^1.3.0:
|
||||||
version "1.3.0"
|
version "1.3.0"
|
||||||
resolved "https://registry.yarnpkg.com/growly/-/growly-1.3.0.tgz#f10748cbe76af964b7c96c93c6bcc28af120c081"
|
resolved "https://registry.yarnpkg.com/growly/-/growly-1.3.0.tgz#f10748cbe76af964b7c96c93c6bcc28af120c081"
|
||||||
integrity sha1-8QdIy+dq+WS3yWyTxrzCivEgwIE=
|
integrity sha1-8QdIy+dq+WS3yWyTxrzCivEgwIE=
|
||||||
|
|
||||||
har-schema@^2.0.0:
|
|
||||||
version "2.0.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/har-schema/-/har-schema-2.0.0.tgz#a94c2224ebcac04782a0d9035521f24735b7ec92"
|
|
||||||
integrity sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=
|
|
||||||
|
|
||||||
har-validator@~5.1.3:
|
|
||||||
version "5.1.5"
|
|
||||||
resolved "https://registry.yarnpkg.com/har-validator/-/har-validator-5.1.5.tgz#1f0803b9f8cb20c0fa13822df1ecddb36bde1efd"
|
|
||||||
integrity sha512-nmT2T0lljbxdQZfspsno9hgrG3Uir6Ks5afism62poxqBM6sDnMEuPmzTq8XN0OEwqKLLdh1jQI3qyE66Nzb3w==
|
|
||||||
dependencies:
|
|
||||||
ajv "^6.12.3"
|
|
||||||
har-schema "^2.0.0"
|
|
||||||
|
|
||||||
has-flag@^3.0.0:
|
has-flag@^3.0.0:
|
||||||
version "3.0.0"
|
version "3.0.0"
|
||||||
resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-3.0.0.tgz#b5d454dc2199ae225699f3467e5a07f3b955bafd"
|
resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-3.0.0.tgz#b5d454dc2199ae225699f3467e5a07f3b955bafd"
|
||||||
@@ -1625,10 +2336,17 @@ has-values@^1.0.0:
|
|||||||
is-number "^3.0.0"
|
is-number "^3.0.0"
|
||||||
kind-of "^4.0.0"
|
kind-of "^4.0.0"
|
||||||
|
|
||||||
|
has@^1.0.3:
|
||||||
|
version "1.0.3"
|
||||||
|
resolved "https://registry.yarnpkg.com/has/-/has-1.0.3.tgz#722d7cbfc1f6aa8241f16dd814e011e1f41e8796"
|
||||||
|
integrity sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==
|
||||||
|
dependencies:
|
||||||
|
function-bind "^1.1.1"
|
||||||
|
|
||||||
hosted-git-info@^2.1.4:
|
hosted-git-info@^2.1.4:
|
||||||
version "2.8.8"
|
version "2.8.9"
|
||||||
resolved "https://registry.yarnpkg.com/hosted-git-info/-/hosted-git-info-2.8.8.tgz#7539bd4bc1e0e0a895815a2e0262420b12858488"
|
resolved "https://registry.yarnpkg.com/hosted-git-info/-/hosted-git-info-2.8.9.tgz#dffc0bf9a21c02209090f2aa69429e1414daf3f9"
|
||||||
integrity sha512-f/wzC2QaWBs7t9IYqB4T3sR1xviIViXJRJTWBlx2Gf3g0Xi5vI7Yy4koXQ1c9OYDGHN9sBy1DQ2AB8fqZBWhUg==
|
integrity sha512-mxIDAb9Lsm6DoOJ7xH+5+X4y1LU/4Hi50L9C5sIswK3JzULS4bwk1FvjdBgvYR4bzT4tuUQiC15FE2f5HbLvYw==
|
||||||
|
|
||||||
html-encoding-sniffer@^2.0.1:
|
html-encoding-sniffer@^2.0.1:
|
||||||
version "2.0.1"
|
version "2.0.1"
|
||||||
@@ -1642,14 +2360,33 @@ html-escaper@^2.0.0:
|
|||||||
resolved "https://registry.yarnpkg.com/html-escaper/-/html-escaper-2.0.2.tgz#dfd60027da36a36dfcbe236262c00a5822681453"
|
resolved "https://registry.yarnpkg.com/html-escaper/-/html-escaper-2.0.2.tgz#dfd60027da36a36dfcbe236262c00a5822681453"
|
||||||
integrity sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==
|
integrity sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg==
|
||||||
|
|
||||||
http-signature@~1.2.0:
|
http-errors@1.8.1:
|
||||||
version "1.2.0"
|
version "1.8.1"
|
||||||
resolved "https://registry.yarnpkg.com/http-signature/-/http-signature-1.2.0.tgz#9aecd925114772f3d95b65a60abb8f7c18fbace1"
|
resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-1.8.1.tgz#7c3f28577cbc8a207388455dbd62295ed07bd68c"
|
||||||
integrity sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=
|
integrity sha512-Kpk9Sm7NmI+RHhnj6OIWDI1d6fIoFAtFt9RLaTMRlg/8w49juAStsrBgp0Dp4OdxdVbRIeKhtCUvoi/RuAhO4g==
|
||||||
dependencies:
|
dependencies:
|
||||||
assert-plus "^1.0.0"
|
depd "~1.1.2"
|
||||||
jsprim "^1.2.2"
|
inherits "2.0.4"
|
||||||
sshpk "^1.7.0"
|
setprototypeof "1.2.0"
|
||||||
|
statuses ">= 1.5.0 < 2"
|
||||||
|
toidentifier "1.0.1"
|
||||||
|
|
||||||
|
http-proxy-agent@^4.0.0, http-proxy-agent@^4.0.1:
|
||||||
|
version "4.0.1"
|
||||||
|
resolved "https://registry.yarnpkg.com/http-proxy-agent/-/http-proxy-agent-4.0.1.tgz#8a8c8ef7f5932ccf953c296ca8291b95aa74aa3a"
|
||||||
|
integrity sha512-k0zdNgqWTGA6aeIRVpvfVob4fL52dTfaehylg0Y4UvSySvOq/Y+BOyPrgpUrA7HylqvU8vIZGsRuXmspskV0Tg==
|
||||||
|
dependencies:
|
||||||
|
"@tootallnate/once" "1"
|
||||||
|
agent-base "6"
|
||||||
|
debug "4"
|
||||||
|
|
||||||
|
https-proxy-agent@5, https-proxy-agent@^5.0.0:
|
||||||
|
version "5.0.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/https-proxy-agent/-/https-proxy-agent-5.0.0.tgz#e2a90542abb68a762e0a0850f6c9edadfd8506b2"
|
||||||
|
integrity sha512-EkYm5BcKUGiduxzSt3Eppko+PiNWNEpa4ySk9vTC6wDsQJW9rHSa+UhGNJoRYp7bz6Ht1eaRIa6QaJqO5rCFbA==
|
||||||
|
dependencies:
|
||||||
|
agent-base "6"
|
||||||
|
debug "4"
|
||||||
|
|
||||||
human-signals@^1.1.1:
|
human-signals@^1.1.1:
|
||||||
version "1.1.1"
|
version "1.1.1"
|
||||||
@@ -1684,15 +2421,15 @@ inflight@^1.0.4:
|
|||||||
once "^1.3.0"
|
once "^1.3.0"
|
||||||
wrappy "1"
|
wrappy "1"
|
||||||
|
|
||||||
inherits@2:
|
inherits@2, inherits@2.0.4, inherits@~2.0.1:
|
||||||
version "2.0.4"
|
version "2.0.4"
|
||||||
resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c"
|
resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c"
|
||||||
integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==
|
integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==
|
||||||
|
|
||||||
ip-regex@^2.1.0:
|
ip@^1.1.5:
|
||||||
version "2.1.0"
|
version "1.1.5"
|
||||||
resolved "https://registry.yarnpkg.com/ip-regex/-/ip-regex-2.1.0.tgz#fa78bf5d2e6913c911ce9f819ee5146bb6d844e9"
|
resolved "https://registry.yarnpkg.com/ip/-/ip-1.1.5.tgz#bdded70114290828c0a039e72ef25f5aaec4354a"
|
||||||
integrity sha1-+ni/XS5pE8kRzp+BnuUUa7bYROk=
|
integrity sha1-vd7XARQpCCjAoDnnLvJfWq7ENUo=
|
||||||
|
|
||||||
is-accessor-descriptor@^0.1.6:
|
is-accessor-descriptor@^0.1.6:
|
||||||
version "0.1.6"
|
version "0.1.6"
|
||||||
@@ -1725,6 +2462,13 @@ is-ci@^2.0.0:
|
|||||||
dependencies:
|
dependencies:
|
||||||
ci-info "^2.0.0"
|
ci-info "^2.0.0"
|
||||||
|
|
||||||
|
is-core-module@^2.2.0:
|
||||||
|
version "2.4.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.4.0.tgz#8e9fc8e15027b011418026e98f0e6f4d86305cc1"
|
||||||
|
integrity sha512-6A2fkfq1rfeQZjxrZJGerpLCTHRNEBiSgnu0+obeJpEPZRUooHgsizvzv0ZjJwOz3iWIHdJtVWJ/tmPr3D21/A==
|
||||||
|
dependencies:
|
||||||
|
has "^1.0.3"
|
||||||
|
|
||||||
is-data-descriptor@^0.1.4:
|
is-data-descriptor@^0.1.4:
|
||||||
version "0.1.4"
|
version "0.1.4"
|
||||||
resolved "https://registry.yarnpkg.com/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz#0b5ee648388e2c860282e793f1856fec3f301b56"
|
resolved "https://registry.yarnpkg.com/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz#0b5ee648388e2c860282e793f1856fec3f301b56"
|
||||||
@@ -1758,9 +2502,9 @@ is-descriptor@^1.0.0, is-descriptor@^1.0.2:
|
|||||||
kind-of "^6.0.2"
|
kind-of "^6.0.2"
|
||||||
|
|
||||||
is-docker@^2.0.0:
|
is-docker@^2.0.0:
|
||||||
version "2.1.1"
|
version "2.2.1"
|
||||||
resolved "https://registry.yarnpkg.com/is-docker/-/is-docker-2.1.1.tgz#4125a88e44e450d384e09047ede71adc2d144156"
|
resolved "https://registry.yarnpkg.com/is-docker/-/is-docker-2.2.1.tgz#33eeabe23cfe86f14bde4408a02c0cfb853acdaa"
|
||||||
integrity sha512-ZOoqiXfEwtGknTiuDEy8pN2CfE3TxMHprvNer1mXiqwkOT77Rw3YVrUQ52EqAOU3QAWDQ+bQdx7HJzrv7LS2Hw==
|
integrity sha512-F+i2BKsFrH66iaUFc0woD8sLy8getkwTwtOBjvs56Cx4CgJDeKQeqfz8wAYiSb8JOprWhHH5p77PbmYCvvUuXQ==
|
||||||
|
|
||||||
is-extendable@^0.1.0, is-extendable@^0.1.1:
|
is-extendable@^0.1.0, is-extendable@^0.1.1:
|
||||||
version "0.1.1"
|
version "0.1.1"
|
||||||
@@ -1803,10 +2547,10 @@ is-plain-object@^2.0.3, is-plain-object@^2.0.4:
|
|||||||
dependencies:
|
dependencies:
|
||||||
isobject "^3.0.1"
|
isobject "^3.0.1"
|
||||||
|
|
||||||
is-potential-custom-element-name@^1.0.0:
|
is-potential-custom-element-name@^1.0.1:
|
||||||
version "1.0.0"
|
version "1.0.1"
|
||||||
resolved "https://registry.yarnpkg.com/is-potential-custom-element-name/-/is-potential-custom-element-name-1.0.0.tgz#0c52e54bcca391bb2c494b21e8626d7336c6e397"
|
resolved "https://registry.yarnpkg.com/is-potential-custom-element-name/-/is-potential-custom-element-name-1.0.1.tgz#171ed6f19e3ac554394edf78caa05784a45bebb5"
|
||||||
integrity sha1-DFLlS8yjkbssSUsh6GJtczbG45c=
|
integrity sha512-bCYeRA2rVibKZd+s2625gGnGF/t7DSqDs4dP7CrLA1m7jKWz6pps0LpYLJN8Q64HtmPKJ1hrN3nzPNKFEKOUiQ==
|
||||||
|
|
||||||
is-stream@^1.1.0:
|
is-stream@^1.1.0:
|
||||||
version "1.1.0"
|
version "1.1.0"
|
||||||
@@ -1818,7 +2562,7 @@ is-stream@^2.0.0:
|
|||||||
resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-2.0.0.tgz#bde9c32680d6fae04129d6ac9d921ce7815f78e3"
|
resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-2.0.0.tgz#bde9c32680d6fae04129d6ac9d921ce7815f78e3"
|
||||||
integrity sha512-XCoy+WlUr7d1+Z8GgSuXmpuUFC9fOhRXglJMx+dwLKTkL44Cjd4W1Z5P+BQZpr+cR93aGP4S/s7Ftw6Nd/kiEw==
|
integrity sha512-XCoy+WlUr7d1+Z8GgSuXmpuUFC9fOhRXglJMx+dwLKTkL44Cjd4W1Z5P+BQZpr+cR93aGP4S/s7Ftw6Nd/kiEw==
|
||||||
|
|
||||||
is-typedarray@^1.0.0, is-typedarray@~1.0.0:
|
is-typedarray@^1.0.0:
|
||||||
version "1.0.0"
|
version "1.0.0"
|
||||||
resolved "https://registry.yarnpkg.com/is-typedarray/-/is-typedarray-1.0.0.tgz#e479c80858df0c1b11ddda6940f96011fcda4a9a"
|
resolved "https://registry.yarnpkg.com/is-typedarray/-/is-typedarray-1.0.0.tgz#e479c80858df0c1b11ddda6940f96011fcda4a9a"
|
||||||
integrity sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=
|
integrity sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=
|
||||||
@@ -1835,6 +2579,11 @@ is-wsl@^2.2.0:
|
|||||||
dependencies:
|
dependencies:
|
||||||
is-docker "^2.0.0"
|
is-docker "^2.0.0"
|
||||||
|
|
||||||
|
isarray@0.0.1:
|
||||||
|
version "0.0.1"
|
||||||
|
resolved "https://registry.yarnpkg.com/isarray/-/isarray-0.0.1.tgz#8a18acfca9a8f4177e09abfc6038939b05d1eedf"
|
||||||
|
integrity sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8=
|
||||||
|
|
||||||
isarray@1.0.0:
|
isarray@1.0.0:
|
||||||
version "1.0.0"
|
version "1.0.0"
|
||||||
resolved "https://registry.yarnpkg.com/isarray/-/isarray-1.0.0.tgz#bb935d48582cba168c06834957a54a3e07124f11"
|
resolved "https://registry.yarnpkg.com/isarray/-/isarray-1.0.0.tgz#bb935d48582cba168c06834957a54a3e07124f11"
|
||||||
@@ -1857,11 +2606,6 @@ isobject@^3.0.0, isobject@^3.0.1:
|
|||||||
resolved "https://registry.yarnpkg.com/isobject/-/isobject-3.0.1.tgz#4e431e92b11a9731636aa1f9c8d1ccbcfdab78df"
|
resolved "https://registry.yarnpkg.com/isobject/-/isobject-3.0.1.tgz#4e431e92b11a9731636aa1f9c8d1ccbcfdab78df"
|
||||||
integrity sha1-TkMekrEalzFjaqH5yNHMvP2reN8=
|
integrity sha1-TkMekrEalzFjaqH5yNHMvP2reN8=
|
||||||
|
|
||||||
isstream@~0.1.2:
|
|
||||||
version "0.1.2"
|
|
||||||
resolved "https://registry.yarnpkg.com/isstream/-/isstream-0.1.2.tgz#47e63f7af55afa6f92e1500e690eb8b8529c099a"
|
|
||||||
integrity sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=
|
|
||||||
|
|
||||||
istanbul-lib-coverage@^3.0.0:
|
istanbul-lib-coverage@^3.0.0:
|
||||||
version "3.0.0"
|
version "3.0.0"
|
||||||
resolved "https://registry.yarnpkg.com/istanbul-lib-coverage/-/istanbul-lib-coverage-3.0.0.tgz#f5944a37c70b550b02a78a5c3b2055b280cec8ec"
|
resolved "https://registry.yarnpkg.com/istanbul-lib-coverage/-/istanbul-lib-coverage-3.0.0.tgz#f5944a37c70b550b02a78a5c3b2055b280cec8ec"
|
||||||
@@ -1903,103 +2647,94 @@ istanbul-reports@^3.0.2:
|
|||||||
html-escaper "^2.0.0"
|
html-escaper "^2.0.0"
|
||||||
istanbul-lib-report "^3.0.0"
|
istanbul-lib-report "^3.0.0"
|
||||||
|
|
||||||
jest-changed-files@^26.3.0:
|
jest-changed-files@^26.6.2:
|
||||||
version "26.3.0"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/jest-changed-files/-/jest-changed-files-26.3.0.tgz#68fb2a7eb125f50839dab1f5a17db3607fe195b1"
|
resolved "https://registry.yarnpkg.com/jest-changed-files/-/jest-changed-files-26.6.2.tgz#f6198479e1cc66f22f9ae1e22acaa0b429c042d0"
|
||||||
integrity sha512-1C4R4nijgPltX6fugKxM4oQ18zimS7LqQ+zTTY8lMCMFPrxqBFb7KJH0Z2fRQJvw2Slbaipsqq7s1mgX5Iot+g==
|
integrity sha512-fDS7szLcY9sCtIip8Fjry9oGf3I2ht/QT21bAHm5Dmf0mD4X3ReNUf17y+bO6fR8WgbIZTlbyG1ak/53cbRzKQ==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
execa "^4.0.0"
|
execa "^4.0.0"
|
||||||
throat "^5.0.0"
|
throat "^5.0.0"
|
||||||
|
|
||||||
jest-circus@^26.1.0:
|
jest-circus@^26.6.3:
|
||||||
version "26.4.1"
|
version "26.6.3"
|
||||||
resolved "https://registry.yarnpkg.com/jest-circus/-/jest-circus-26.4.1.tgz#06d23d313bb891db0bdac7477bd50ff2c69cb630"
|
resolved "https://registry.yarnpkg.com/jest-circus/-/jest-circus-26.6.3.tgz#3cc7ef2a6a3787e5d7bfbe2c72d83262154053e7"
|
||||||
integrity sha512-rc3cj7aPMx5ZrrI7PC4n44oYbfVtAJ+QTQIWpNESzgFDe9+bpcUOUtgo9pfH7WeB8Q6EWEL1SetFQgvEl6eVrA==
|
integrity sha512-ACrpWZGcQMpbv13XbzRzpytEJlilP/Su0JtNCi5r/xLpOUhnaIJr8leYYpLEMgPFURZISEHrnnpmB54Q/UziPw==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/traverse" "^7.1.0"
|
"@babel/traverse" "^7.1.0"
|
||||||
"@jest/environment" "^26.3.0"
|
"@jest/environment" "^26.6.2"
|
||||||
"@jest/test-result" "^26.3.0"
|
"@jest/test-result" "^26.6.2"
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
|
"@types/babel__traverse" "^7.0.4"
|
||||||
"@types/node" "*"
|
"@types/node" "*"
|
||||||
chalk "^4.0.0"
|
chalk "^4.0.0"
|
||||||
co "^4.6.0"
|
co "^4.6.0"
|
||||||
dedent "^0.7.0"
|
dedent "^0.7.0"
|
||||||
expect "^26.4.1"
|
expect "^26.6.2"
|
||||||
is-generator-fn "^2.0.0"
|
is-generator-fn "^2.0.0"
|
||||||
jest-each "^26.4.0"
|
jest-each "^26.6.2"
|
||||||
jest-matcher-utils "^26.4.1"
|
jest-matcher-utils "^26.6.2"
|
||||||
jest-message-util "^26.3.0"
|
jest-message-util "^26.6.2"
|
||||||
jest-runner "^26.4.1"
|
jest-runner "^26.6.3"
|
||||||
jest-runtime "^26.4.1"
|
jest-runtime "^26.6.3"
|
||||||
jest-snapshot "^26.4.1"
|
jest-snapshot "^26.6.2"
|
||||||
jest-util "^26.3.0"
|
jest-util "^26.6.2"
|
||||||
pretty-format "^26.4.0"
|
pretty-format "^26.6.2"
|
||||||
stack-utils "^2.0.2"
|
stack-utils "^2.0.2"
|
||||||
throat "^5.0.0"
|
throat "^5.0.0"
|
||||||
|
|
||||||
jest-cli@^26.4.1:
|
jest-cli@^26.6.3:
|
||||||
version "26.4.1"
|
version "26.6.3"
|
||||||
resolved "https://registry.yarnpkg.com/jest-cli/-/jest-cli-26.4.1.tgz#877fff1c17661c7bbd8e7df56711ee489091236f"
|
resolved "https://registry.yarnpkg.com/jest-cli/-/jest-cli-26.6.3.tgz#43117cfef24bc4cd691a174a8796a532e135e92a"
|
||||||
integrity sha512-c6px+IOO0OsZ7X/uSr65wcjZnd7NYNUDWFT5OETyCnJRkkwoTER7gneRDrwgr3Ex5+gCGO7D/IMWxUHB/L624A==
|
integrity sha512-GF9noBSa9t08pSyl3CY4frMrqp+aQXFGFkf5hEPbh/pIUFYWMK6ZLTfbmadxJVcJrdRoChlWQsA2VkJcDFK8hg==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@jest/core" "^26.4.1"
|
"@jest/core" "^26.6.3"
|
||||||
"@jest/test-result" "^26.3.0"
|
"@jest/test-result" "^26.6.2"
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
chalk "^4.0.0"
|
chalk "^4.0.0"
|
||||||
exit "^0.1.2"
|
exit "^0.1.2"
|
||||||
graceful-fs "^4.2.4"
|
graceful-fs "^4.2.4"
|
||||||
import-local "^3.0.2"
|
import-local "^3.0.2"
|
||||||
is-ci "^2.0.0"
|
is-ci "^2.0.0"
|
||||||
jest-config "^26.4.1"
|
jest-config "^26.6.3"
|
||||||
jest-util "^26.3.0"
|
jest-util "^26.6.2"
|
||||||
jest-validate "^26.4.0"
|
jest-validate "^26.6.2"
|
||||||
prompts "^2.0.1"
|
prompts "^2.0.1"
|
||||||
yargs "^15.3.1"
|
yargs "^15.4.1"
|
||||||
|
|
||||||
jest-config@^26.4.1:
|
jest-config@^26.6.3:
|
||||||
version "26.4.1"
|
version "26.6.3"
|
||||||
resolved "https://registry.yarnpkg.com/jest-config/-/jest-config-26.4.1.tgz#16b5a8e25c43279025718b1678115e39607f914f"
|
resolved "https://registry.yarnpkg.com/jest-config/-/jest-config-26.6.3.tgz#64f41444eef9eb03dc51d5c53b75c8c71f645349"
|
||||||
integrity sha512-0kUnVceEax0sYN+wdkNYF7fxjYKbsvmKmjVWwJvsSYA2p94bIL6wSy3oehewev7L9Dp/FDZFhmc9dyOoavdT6A==
|
integrity sha512-t5qdIj/bCj2j7NFVHb2nFB4aUdfucDn3JRKgrZnplb8nieAirAzRSHP8uDEd+qV6ygzg9Pz4YG7UTJf94LPSyg==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/core" "^7.1.0"
|
"@babel/core" "^7.1.0"
|
||||||
"@jest/test-sequencer" "^26.4.1"
|
"@jest/test-sequencer" "^26.6.3"
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
babel-jest "^26.3.0"
|
babel-jest "^26.6.3"
|
||||||
chalk "^4.0.0"
|
chalk "^4.0.0"
|
||||||
deepmerge "^4.2.2"
|
deepmerge "^4.2.2"
|
||||||
glob "^7.1.1"
|
glob "^7.1.1"
|
||||||
graceful-fs "^4.2.4"
|
graceful-fs "^4.2.4"
|
||||||
jest-environment-jsdom "^26.3.0"
|
jest-environment-jsdom "^26.6.2"
|
||||||
jest-environment-node "^26.3.0"
|
jest-environment-node "^26.6.2"
|
||||||
jest-get-type "^26.3.0"
|
jest-get-type "^26.3.0"
|
||||||
jest-jasmine2 "^26.4.1"
|
jest-jasmine2 "^26.6.3"
|
||||||
jest-regex-util "^26.0.0"
|
jest-regex-util "^26.0.0"
|
||||||
jest-resolve "^26.4.0"
|
jest-resolve "^26.6.2"
|
||||||
jest-util "^26.3.0"
|
jest-util "^26.6.2"
|
||||||
jest-validate "^26.4.0"
|
jest-validate "^26.6.2"
|
||||||
micromatch "^4.0.2"
|
micromatch "^4.0.2"
|
||||||
pretty-format "^26.4.0"
|
pretty-format "^26.6.2"
|
||||||
|
|
||||||
jest-diff@^25.2.1:
|
jest-diff@^26.0.0, jest-diff@^26.6.2:
|
||||||
version "25.5.0"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/jest-diff/-/jest-diff-25.5.0.tgz#1dd26ed64f96667c068cef026b677dfa01afcfa9"
|
resolved "https://registry.yarnpkg.com/jest-diff/-/jest-diff-26.6.2.tgz#1aa7468b52c3a68d7d5c5fdcdfcd5e49bd164394"
|
||||||
integrity sha512-z1kygetuPiREYdNIumRpAHY6RXiGmp70YHptjdaxTWGmA085W3iCnXNx0DhflK3vwrKmrRWyY1wUpkPMVxMK7A==
|
integrity sha512-6m+9Z3Gv9wN0WFVasqjCL/06+EFCMTqDEUl/b87HYK2rAPTyfz4ZIuSlPhY51PIQRWx5TaxeF1qmXKe9gfN3sA==
|
||||||
dependencies:
|
|
||||||
chalk "^3.0.0"
|
|
||||||
diff-sequences "^25.2.6"
|
|
||||||
jest-get-type "^25.2.6"
|
|
||||||
pretty-format "^25.5.0"
|
|
||||||
|
|
||||||
jest-diff@^26.4.0:
|
|
||||||
version "26.4.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/jest-diff/-/jest-diff-26.4.0.tgz#d073a0a11952b5bd9f1ff39bb9ad24304a0c55f7"
|
|
||||||
integrity sha512-wwC38HlOW+iTq6j5tkj/ZamHn6/nrdcEOc/fKaVILNtN2NLWGdkfRaHWwfNYr5ehaLvuoG2LfCZIcWByVj0gjg==
|
|
||||||
dependencies:
|
dependencies:
|
||||||
chalk "^4.0.0"
|
chalk "^4.0.0"
|
||||||
diff-sequences "^26.3.0"
|
diff-sequences "^26.6.2"
|
||||||
jest-get-type "^26.3.0"
|
jest-get-type "^26.3.0"
|
||||||
pretty-format "^26.4.0"
|
pretty-format "^26.6.2"
|
||||||
|
|
||||||
jest-docblock@^26.0.0:
|
jest-docblock@^26.0.0:
|
||||||
version "26.0.0"
|
version "26.0.0"
|
||||||
@@ -2008,135 +2743,131 @@ jest-docblock@^26.0.0:
|
|||||||
dependencies:
|
dependencies:
|
||||||
detect-newline "^3.0.0"
|
detect-newline "^3.0.0"
|
||||||
|
|
||||||
jest-each@^26.4.0:
|
jest-each@^26.6.2:
|
||||||
version "26.4.0"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/jest-each/-/jest-each-26.4.0.tgz#c53605b20e7a0a58d6dcf4d8b2f309e607d35d5a"
|
resolved "https://registry.yarnpkg.com/jest-each/-/jest-each-26.6.2.tgz#02526438a77a67401c8a6382dfe5999952c167cb"
|
||||||
integrity sha512-+cyBh1ehs6thVT/bsZVG+WwmRn2ix4Q4noS9yLZgM10yGWPW12/TDvwuOV2VZXn1gi09/ZwJKJWql6YW1C9zNw==
|
integrity sha512-Mer/f0KaATbjl8MCJ+0GEpNdqmnVmDYqCTJYTvoo7rqmRiDllmp2AYN+06F93nXcY3ur9ShIjS+CO/uD+BbH4A==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
chalk "^4.0.0"
|
chalk "^4.0.0"
|
||||||
jest-get-type "^26.3.0"
|
jest-get-type "^26.3.0"
|
||||||
jest-util "^26.3.0"
|
jest-util "^26.6.2"
|
||||||
pretty-format "^26.4.0"
|
pretty-format "^26.6.2"
|
||||||
|
|
||||||
jest-environment-jsdom@^26.3.0:
|
jest-environment-jsdom@^26.6.2:
|
||||||
version "26.3.0"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/jest-environment-jsdom/-/jest-environment-jsdom-26.3.0.tgz#3b749ba0f3a78e92ba2c9ce519e16e5dd515220c"
|
resolved "https://registry.yarnpkg.com/jest-environment-jsdom/-/jest-environment-jsdom-26.6.2.tgz#78d09fe9cf019a357009b9b7e1f101d23bd1da3e"
|
||||||
integrity sha512-zra8He2btIMJkAzvLaiZ9QwEPGEetbxqmjEBQwhH3CA+Hhhu0jSiEJxnJMbX28TGUvPLxBt/zyaTLrOPF4yMJA==
|
integrity sha512-jgPqCruTlt3Kwqg5/WVFyHIOJHsiAvhcp2qiR2QQstuG9yWox5+iHpU3ZrcBxW14T4fe5Z68jAfLRh7joCSP2Q==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@jest/environment" "^26.3.0"
|
"@jest/environment" "^26.6.2"
|
||||||
"@jest/fake-timers" "^26.3.0"
|
"@jest/fake-timers" "^26.6.2"
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
"@types/node" "*"
|
"@types/node" "*"
|
||||||
jest-mock "^26.3.0"
|
jest-mock "^26.6.2"
|
||||||
jest-util "^26.3.0"
|
jest-util "^26.6.2"
|
||||||
jsdom "^16.2.2"
|
jsdom "^16.4.0"
|
||||||
|
|
||||||
jest-environment-node@^26.3.0:
|
jest-environment-node@^26.6.2:
|
||||||
version "26.3.0"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/jest-environment-node/-/jest-environment-node-26.3.0.tgz#56c6cfb506d1597f94ee8d717072bda7228df849"
|
resolved "https://registry.yarnpkg.com/jest-environment-node/-/jest-environment-node-26.6.2.tgz#824e4c7fb4944646356f11ac75b229b0035f2b0c"
|
||||||
integrity sha512-c9BvYoo+FGcMj5FunbBgtBnbR5qk3uky8PKyRVpSfe2/8+LrNQMiXX53z6q2kY+j15SkjQCOSL/6LHnCPLVHNw==
|
integrity sha512-zhtMio3Exty18dy8ee8eJ9kjnRyZC1N4C1Nt/VShN1apyXc8rWGtJ9lI7vqiWcyyXS4BVSEn9lxAM2D+07/Tag==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@jest/environment" "^26.3.0"
|
"@jest/environment" "^26.6.2"
|
||||||
"@jest/fake-timers" "^26.3.0"
|
"@jest/fake-timers" "^26.6.2"
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
"@types/node" "*"
|
"@types/node" "*"
|
||||||
jest-mock "^26.3.0"
|
jest-mock "^26.6.2"
|
||||||
jest-util "^26.3.0"
|
jest-util "^26.6.2"
|
||||||
|
|
||||||
jest-get-type@^25.2.6:
|
|
||||||
version "25.2.6"
|
|
||||||
resolved "https://registry.yarnpkg.com/jest-get-type/-/jest-get-type-25.2.6.tgz#0b0a32fab8908b44d508be81681487dbabb8d877"
|
|
||||||
integrity sha512-DxjtyzOHjObRM+sM1knti6or+eOgcGU4xVSb2HNP1TqO4ahsT+rqZg+nyqHWJSvWgKC5cG3QjGFBqxLghiF/Ig==
|
|
||||||
|
|
||||||
jest-get-type@^26.3.0:
|
jest-get-type@^26.3.0:
|
||||||
version "26.3.0"
|
version "26.3.0"
|
||||||
resolved "https://registry.yarnpkg.com/jest-get-type/-/jest-get-type-26.3.0.tgz#e97dc3c3f53c2b406ca7afaed4493b1d099199e0"
|
resolved "https://registry.yarnpkg.com/jest-get-type/-/jest-get-type-26.3.0.tgz#e97dc3c3f53c2b406ca7afaed4493b1d099199e0"
|
||||||
integrity sha512-TpfaviN1R2pQWkIihlfEanwOXK0zcxrKEE4MlU6Tn7keoXdN6/3gK/xl0yEh8DOunn5pOVGKf8hB4R9gVh04ig==
|
integrity sha512-TpfaviN1R2pQWkIihlfEanwOXK0zcxrKEE4MlU6Tn7keoXdN6/3gK/xl0yEh8DOunn5pOVGKf8hB4R9gVh04ig==
|
||||||
|
|
||||||
jest-haste-map@^26.3.0:
|
jest-haste-map@^26.6.2:
|
||||||
version "26.3.0"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/jest-haste-map/-/jest-haste-map-26.3.0.tgz#c51a3b40100d53ab777bfdad382d2e7a00e5c726"
|
resolved "https://registry.yarnpkg.com/jest-haste-map/-/jest-haste-map-26.6.2.tgz#dd7e60fe7dc0e9f911a23d79c5ff7fb5c2cafeaa"
|
||||||
integrity sha512-DHWBpTJgJhLLGwE5Z1ZaqLTYqeODQIZpby0zMBsCU9iRFHYyhklYqP4EiG73j5dkbaAdSZhgB938mL51Q5LeZA==
|
integrity sha512-easWIJXIw71B2RdR8kgqpjQrbMRWQBgiBwXYEhtGUTaX+doCjBheluShdDMeR8IMfJiTqH4+zfhtg29apJf/8w==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
"@types/graceful-fs" "^4.1.2"
|
"@types/graceful-fs" "^4.1.2"
|
||||||
"@types/node" "*"
|
"@types/node" "*"
|
||||||
anymatch "^3.0.3"
|
anymatch "^3.0.3"
|
||||||
fb-watchman "^2.0.0"
|
fb-watchman "^2.0.0"
|
||||||
graceful-fs "^4.2.4"
|
graceful-fs "^4.2.4"
|
||||||
jest-regex-util "^26.0.0"
|
jest-regex-util "^26.0.0"
|
||||||
jest-serializer "^26.3.0"
|
jest-serializer "^26.6.2"
|
||||||
jest-util "^26.3.0"
|
jest-util "^26.6.2"
|
||||||
jest-worker "^26.3.0"
|
jest-worker "^26.6.2"
|
||||||
micromatch "^4.0.2"
|
micromatch "^4.0.2"
|
||||||
sane "^4.0.3"
|
sane "^4.0.3"
|
||||||
walker "^1.0.7"
|
walker "^1.0.7"
|
||||||
optionalDependencies:
|
optionalDependencies:
|
||||||
fsevents "^2.1.2"
|
fsevents "^2.1.2"
|
||||||
|
|
||||||
jest-jasmine2@^26.4.1:
|
jest-jasmine2@^26.6.3:
|
||||||
version "26.4.1"
|
version "26.6.3"
|
||||||
resolved "https://registry.yarnpkg.com/jest-jasmine2/-/jest-jasmine2-26.4.1.tgz#85f5997720332bedaa64b65b1e7b01074d8485c1"
|
resolved "https://registry.yarnpkg.com/jest-jasmine2/-/jest-jasmine2-26.6.3.tgz#adc3cf915deacb5212c93b9f3547cd12958f2edd"
|
||||||
integrity sha512-GMPqJXyAWpohCg4wfA82lwac65lmgANH4/rOhNNaAN9yjInMAeMExQcWE1xb3fcCgLwibqeAuqVrV83oQl+szg==
|
integrity sha512-kPKUrQtc8aYwBV7CqBg5pu+tmYXlvFlSFYn18ev4gPFtrRzB15N2gW/Roew3187q2w2eHuu0MU9TJz6w0/nPEg==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/traverse" "^7.1.0"
|
"@babel/traverse" "^7.1.0"
|
||||||
"@jest/environment" "^26.3.0"
|
"@jest/environment" "^26.6.2"
|
||||||
"@jest/source-map" "^26.3.0"
|
"@jest/source-map" "^26.6.2"
|
||||||
"@jest/test-result" "^26.3.0"
|
"@jest/test-result" "^26.6.2"
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
"@types/node" "*"
|
"@types/node" "*"
|
||||||
chalk "^4.0.0"
|
chalk "^4.0.0"
|
||||||
co "^4.6.0"
|
co "^4.6.0"
|
||||||
expect "^26.4.1"
|
expect "^26.6.2"
|
||||||
is-generator-fn "^2.0.0"
|
is-generator-fn "^2.0.0"
|
||||||
jest-each "^26.4.0"
|
jest-each "^26.6.2"
|
||||||
jest-matcher-utils "^26.4.1"
|
jest-matcher-utils "^26.6.2"
|
||||||
jest-message-util "^26.3.0"
|
jest-message-util "^26.6.2"
|
||||||
jest-runtime "^26.4.1"
|
jest-runtime "^26.6.3"
|
||||||
jest-snapshot "^26.4.1"
|
jest-snapshot "^26.6.2"
|
||||||
jest-util "^26.3.0"
|
jest-util "^26.6.2"
|
||||||
pretty-format "^26.4.0"
|
pretty-format "^26.6.2"
|
||||||
throat "^5.0.0"
|
throat "^5.0.0"
|
||||||
|
|
||||||
jest-leak-detector@^26.4.0:
|
jest-leak-detector@^26.6.2:
|
||||||
version "26.4.0"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/jest-leak-detector/-/jest-leak-detector-26.4.0.tgz#1efeeef693af3c9332062876add5ac5f25cb0a70"
|
resolved "https://registry.yarnpkg.com/jest-leak-detector/-/jest-leak-detector-26.6.2.tgz#7717cf118b92238f2eba65054c8a0c9c653a91af"
|
||||||
integrity sha512-7EXKKEKnAWUPyiVtGZzJflbPOtYUdlNoevNVOkAcPpdR8xWiYKPGNGA6sz25S+8YhZq3rmkQJYAh3/P0VnoRwA==
|
integrity sha512-i4xlXpsVSMeKvg2cEKdfhh0H39qlJlP5Ex1yQxwF9ubahboQYMgTtz5oML35AVA3B4Eu+YsmwaiKVev9KCvLxg==
|
||||||
dependencies:
|
dependencies:
|
||||||
jest-get-type "^26.3.0"
|
jest-get-type "^26.3.0"
|
||||||
pretty-format "^26.4.0"
|
pretty-format "^26.6.2"
|
||||||
|
|
||||||
jest-matcher-utils@^26.4.1:
|
jest-matcher-utils@^26.6.2:
|
||||||
version "26.4.1"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/jest-matcher-utils/-/jest-matcher-utils-26.4.1.tgz#f9f2d1d37d301e328eb22e9df09e7343d6cc1b25"
|
resolved "https://registry.yarnpkg.com/jest-matcher-utils/-/jest-matcher-utils-26.6.2.tgz#8e6fd6e863c8b2d31ac6472eeb237bc595e53e7a"
|
||||||
integrity sha512-nmHWaOz54R/w6zJju5tuW0bw6+m38Rb1jnDKehKM/bOngDDL0UwtN634cRxpFoUNVRUrX8Wa0Z34xq/f8iuP5A==
|
integrity sha512-llnc8vQgYcNqDrqRDXWwMr9i7rS5XFiCwvh6DTP7Jqa2mqpcCBBlpCbn+trkG0KNhPu/h8rzyBkriOtBstvWhw==
|
||||||
dependencies:
|
dependencies:
|
||||||
chalk "^4.0.0"
|
chalk "^4.0.0"
|
||||||
jest-diff "^26.4.0"
|
jest-diff "^26.6.2"
|
||||||
jest-get-type "^26.3.0"
|
jest-get-type "^26.3.0"
|
||||||
pretty-format "^26.4.0"
|
pretty-format "^26.6.2"
|
||||||
|
|
||||||
jest-message-util@^26.3.0:
|
jest-message-util@^26.6.2:
|
||||||
version "26.3.0"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/jest-message-util/-/jest-message-util-26.3.0.tgz#3bdb538af27bb417f2d4d16557606fd082d5841a"
|
resolved "https://registry.yarnpkg.com/jest-message-util/-/jest-message-util-26.6.2.tgz#58173744ad6fc0506b5d21150b9be56ef001ca07"
|
||||||
integrity sha512-xIavRYqr4/otGOiLxLZGj3ieMmjcNE73Ui+LdSW/Y790j5acqCsAdDiLIbzHCZMpN07JOENRWX5DcU+OQ+TjTA==
|
integrity sha512-rGiLePzQ3AzwUshu2+Rn+UMFk0pHN58sOG+IaJbk5Jxuqo3NYO1U2/MIR4S1sKgsoYSXSzdtSa0TgrmtUwEbmA==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/code-frame" "^7.0.0"
|
"@babel/code-frame" "^7.0.0"
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
"@types/stack-utils" "^1.0.1"
|
"@types/stack-utils" "^2.0.0"
|
||||||
chalk "^4.0.0"
|
chalk "^4.0.0"
|
||||||
graceful-fs "^4.2.4"
|
graceful-fs "^4.2.4"
|
||||||
micromatch "^4.0.2"
|
micromatch "^4.0.2"
|
||||||
|
pretty-format "^26.6.2"
|
||||||
slash "^3.0.0"
|
slash "^3.0.0"
|
||||||
stack-utils "^2.0.2"
|
stack-utils "^2.0.2"
|
||||||
|
|
||||||
jest-mock@^26.3.0:
|
jest-mock@^26.6.2:
|
||||||
version "26.3.0"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/jest-mock/-/jest-mock-26.3.0.tgz#ee62207c3c5ebe5f35b760e1267fee19a1cfdeba"
|
resolved "https://registry.yarnpkg.com/jest-mock/-/jest-mock-26.6.2.tgz#d6cb712b041ed47fe0d9b6fc3474bc6543feb302"
|
||||||
integrity sha512-PeaRrg8Dc6mnS35gOo/CbZovoDPKAeB1FICZiuagAgGvbWdNNyjQjkOaGUa/3N3JtpQ/Mh9P4A2D4Fv51NnP8Q==
|
integrity sha512-YyFjePHHp1LzpzYcmgqkJ0nm0gg/lJx2aZFzFy1S6eUqNjXsOqTK10zNRff2dNfssgokjkG65OlWNcIlgd3zew==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
"@types/node" "*"
|
"@types/node" "*"
|
||||||
|
|
||||||
jest-pnp-resolver@^1.2.2:
|
jest-pnp-resolver@^1.2.2:
|
||||||
@@ -2149,170 +2880,172 @@ jest-regex-util@^26.0.0:
|
|||||||
resolved "https://registry.yarnpkg.com/jest-regex-util/-/jest-regex-util-26.0.0.tgz#d25e7184b36e39fd466c3bc41be0971e821fee28"
|
resolved "https://registry.yarnpkg.com/jest-regex-util/-/jest-regex-util-26.0.0.tgz#d25e7184b36e39fd466c3bc41be0971e821fee28"
|
||||||
integrity sha512-Gv3ZIs/nA48/Zvjrl34bf+oD76JHiGDUxNOVgUjh3j890sblXryjY4rss71fPtD/njchl6PSE2hIhvyWa1eT0A==
|
integrity sha512-Gv3ZIs/nA48/Zvjrl34bf+oD76JHiGDUxNOVgUjh3j890sblXryjY4rss71fPtD/njchl6PSE2hIhvyWa1eT0A==
|
||||||
|
|
||||||
jest-resolve-dependencies@^26.4.1:
|
jest-resolve-dependencies@^26.6.3:
|
||||||
version "26.4.1"
|
version "26.6.3"
|
||||||
resolved "https://registry.yarnpkg.com/jest-resolve-dependencies/-/jest-resolve-dependencies-26.4.1.tgz#8e7cd28a1774cfdd64bb79b77ef8cd07e0f35598"
|
resolved "https://registry.yarnpkg.com/jest-resolve-dependencies/-/jest-resolve-dependencies-26.6.3.tgz#6680859ee5d22ee5dcd961fe4871f59f4c784fb6"
|
||||||
integrity sha512-Gx4JfQ1k/hGb4lqVOOx8TPOkNtyJIQSHcJU68pB+sdyDJi9rbMxD1XXiYyaEq9WXufiZo90k9GTK6z6a5m0SQw==
|
integrity sha512-pVwUjJkxbhe4RY8QEWzN3vns2kqyuldKpxlxJlzEYfKSvY6/bMvxoFrYYzUO1Gx28yKWN37qyV7rIoIp2h8fTg==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
jest-regex-util "^26.0.0"
|
jest-regex-util "^26.0.0"
|
||||||
jest-snapshot "^26.4.1"
|
jest-snapshot "^26.6.2"
|
||||||
|
|
||||||
jest-resolve@^26.4.0:
|
jest-resolve@^26.6.2:
|
||||||
version "26.4.0"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/jest-resolve/-/jest-resolve-26.4.0.tgz#6dc0af7fb93e65b73fec0368ca2b76f3eb59a6d7"
|
resolved "https://registry.yarnpkg.com/jest-resolve/-/jest-resolve-26.6.2.tgz#a3ab1517217f469b504f1b56603c5bb541fbb507"
|
||||||
integrity sha512-bn/JoZTEXRSlEx3+SfgZcJAVuTMOksYq9xe9O6s4Ekg84aKBObEaVXKOEilULRqviSLAYJldnoWV9c07kwtiCg==
|
integrity sha512-sOxsZOq25mT1wRsfHcbtkInS+Ek7Q8jCHUB0ZUTP0tc/c41QHriU/NunqMfCUWsL4H3MHpvQD4QR9kSYhS7UvQ==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
chalk "^4.0.0"
|
chalk "^4.0.0"
|
||||||
graceful-fs "^4.2.4"
|
graceful-fs "^4.2.4"
|
||||||
jest-pnp-resolver "^1.2.2"
|
jest-pnp-resolver "^1.2.2"
|
||||||
jest-util "^26.3.0"
|
jest-util "^26.6.2"
|
||||||
read-pkg-up "^7.0.1"
|
read-pkg-up "^7.0.1"
|
||||||
resolve "^1.17.0"
|
resolve "^1.18.1"
|
||||||
slash "^3.0.0"
|
slash "^3.0.0"
|
||||||
|
|
||||||
jest-runner@^26.4.1:
|
jest-runner@^26.6.3:
|
||||||
version "26.4.1"
|
version "26.6.3"
|
||||||
resolved "https://registry.yarnpkg.com/jest-runner/-/jest-runner-26.4.1.tgz#5a98c87b558aacf88e761d5ee83e98bfb0a59839"
|
resolved "https://registry.yarnpkg.com/jest-runner/-/jest-runner-26.6.3.tgz#2d1fed3d46e10f233fd1dbd3bfaa3fe8924be159"
|
||||||
integrity sha512-QcKwn1YNlzFumTtFsocETgIm13KNt2X8sae4wcqsF3JnxGUcYYUGBstCQhtAG4fKD/TKThHkgE/ZgQVKipj7oA==
|
integrity sha512-atgKpRHnaA2OvByG/HpGA4g6CSPS/1LK0jK3gATJAoptC1ojltpmVlYC3TYgdmGp+GLuhzpH30Gvs36szSL2JQ==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@jest/console" "^26.3.0"
|
"@jest/console" "^26.6.2"
|
||||||
"@jest/environment" "^26.3.0"
|
"@jest/environment" "^26.6.2"
|
||||||
"@jest/test-result" "^26.3.0"
|
"@jest/test-result" "^26.6.2"
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
"@types/node" "*"
|
"@types/node" "*"
|
||||||
chalk "^4.0.0"
|
chalk "^4.0.0"
|
||||||
emittery "^0.7.1"
|
emittery "^0.7.1"
|
||||||
exit "^0.1.2"
|
exit "^0.1.2"
|
||||||
graceful-fs "^4.2.4"
|
graceful-fs "^4.2.4"
|
||||||
jest-config "^26.4.1"
|
jest-config "^26.6.3"
|
||||||
jest-docblock "^26.0.0"
|
jest-docblock "^26.0.0"
|
||||||
jest-haste-map "^26.3.0"
|
jest-haste-map "^26.6.2"
|
||||||
jest-leak-detector "^26.4.0"
|
jest-leak-detector "^26.6.2"
|
||||||
jest-message-util "^26.3.0"
|
jest-message-util "^26.6.2"
|
||||||
jest-resolve "^26.4.0"
|
jest-resolve "^26.6.2"
|
||||||
jest-runtime "^26.4.1"
|
jest-runtime "^26.6.3"
|
||||||
jest-util "^26.3.0"
|
jest-util "^26.6.2"
|
||||||
jest-worker "^26.3.0"
|
jest-worker "^26.6.2"
|
||||||
source-map-support "^0.5.6"
|
source-map-support "^0.5.6"
|
||||||
throat "^5.0.0"
|
throat "^5.0.0"
|
||||||
|
|
||||||
jest-runtime@^26.1.0, jest-runtime@^26.4.1:
|
jest-runtime@^26.6.3:
|
||||||
version "26.4.1"
|
version "26.6.3"
|
||||||
resolved "https://registry.yarnpkg.com/jest-runtime/-/jest-runtime-26.4.1.tgz#9a6ffefc7167b0f244e0907f4820ab38d825cdd2"
|
resolved "https://registry.yarnpkg.com/jest-runtime/-/jest-runtime-26.6.3.tgz#4f64efbcfac398331b74b4b3c82d27d401b8fa2b"
|
||||||
integrity sha512-zXPQBS4iL/CEZtDfX+rDz+oZ/inQK/EYOeVt3uDWu8kwSdP/Cw4yOZtCTPApeNsGtZy6X5WQ1U+fyagN1B/Qkw==
|
integrity sha512-lrzyR3N8sacTAMeonbqpnSka1dHNux2uk0qqDXVkMv2c/A3wYnvQ4EXuI013Y6+gSKSCxdaczvf4HF0mVXHRdw==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@jest/console" "^26.3.0"
|
"@jest/console" "^26.6.2"
|
||||||
"@jest/environment" "^26.3.0"
|
"@jest/environment" "^26.6.2"
|
||||||
"@jest/fake-timers" "^26.3.0"
|
"@jest/fake-timers" "^26.6.2"
|
||||||
"@jest/globals" "^26.4.1"
|
"@jest/globals" "^26.6.2"
|
||||||
"@jest/source-map" "^26.3.0"
|
"@jest/source-map" "^26.6.2"
|
||||||
"@jest/test-result" "^26.3.0"
|
"@jest/test-result" "^26.6.2"
|
||||||
"@jest/transform" "^26.3.0"
|
"@jest/transform" "^26.6.2"
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
"@types/yargs" "^15.0.0"
|
"@types/yargs" "^15.0.0"
|
||||||
chalk "^4.0.0"
|
chalk "^4.0.0"
|
||||||
|
cjs-module-lexer "^0.6.0"
|
||||||
collect-v8-coverage "^1.0.0"
|
collect-v8-coverage "^1.0.0"
|
||||||
exit "^0.1.2"
|
exit "^0.1.2"
|
||||||
glob "^7.1.3"
|
glob "^7.1.3"
|
||||||
graceful-fs "^4.2.4"
|
graceful-fs "^4.2.4"
|
||||||
jest-config "^26.4.1"
|
jest-config "^26.6.3"
|
||||||
jest-haste-map "^26.3.0"
|
jest-haste-map "^26.6.2"
|
||||||
jest-message-util "^26.3.0"
|
jest-message-util "^26.6.2"
|
||||||
jest-mock "^26.3.0"
|
jest-mock "^26.6.2"
|
||||||
jest-regex-util "^26.0.0"
|
jest-regex-util "^26.0.0"
|
||||||
jest-resolve "^26.4.0"
|
jest-resolve "^26.6.2"
|
||||||
jest-snapshot "^26.4.1"
|
jest-snapshot "^26.6.2"
|
||||||
jest-util "^26.3.0"
|
jest-util "^26.6.2"
|
||||||
jest-validate "^26.4.0"
|
jest-validate "^26.6.2"
|
||||||
slash "^3.0.0"
|
slash "^3.0.0"
|
||||||
strip-bom "^4.0.0"
|
strip-bom "^4.0.0"
|
||||||
yargs "^15.3.1"
|
yargs "^15.4.1"
|
||||||
|
|
||||||
jest-serializer@^26.3.0:
|
jest-serializer@^26.6.2:
|
||||||
version "26.3.0"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/jest-serializer/-/jest-serializer-26.3.0.tgz#1c9d5e1b74d6e5f7e7f9627080fa205d976c33ef"
|
resolved "https://registry.yarnpkg.com/jest-serializer/-/jest-serializer-26.6.2.tgz#d139aafd46957d3a448f3a6cdabe2919ba0742d1"
|
||||||
integrity sha512-IDRBQBLPlKa4flg77fqg0n/pH87tcRKwe8zxOVTWISxGpPHYkRZ1dXKyh04JOja7gppc60+soKVZ791mruVdow==
|
integrity sha512-S5wqyz0DXnNJPd/xfIzZ5Xnp1HrJWBczg8mMfMpN78OJ5eDxXyf+Ygld9wX1DnUWbIbhM1YDY95NjR4CBXkb2g==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@types/node" "*"
|
"@types/node" "*"
|
||||||
graceful-fs "^4.2.4"
|
graceful-fs "^4.2.4"
|
||||||
|
|
||||||
jest-snapshot@^26.4.1:
|
jest-snapshot@^26.6.2:
|
||||||
version "26.4.1"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/jest-snapshot/-/jest-snapshot-26.4.1.tgz#41dd85c41dbb76ac874e36c18dcfe722c88d22c4"
|
resolved "https://registry.yarnpkg.com/jest-snapshot/-/jest-snapshot-26.6.2.tgz#f3b0af1acb223316850bd14e1beea9837fb39c84"
|
||||||
integrity sha512-5DsxbSSuYA8rZ/ynO+l5J65wSIyzDB2AXjuIvep90YmtslrROqDtba2hBgq1Cj6L6A0j/jv6h8JydEe2WYPM/g==
|
integrity sha512-OLhxz05EzUtsAmOMzuupt1lHYXCNib0ECyuZ/PZOx9TrZcC8vL0x+DUG3TL+GLX3yHG45e6YGjIm0XwDc3q3og==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/types" "^7.0.0"
|
"@babel/types" "^7.0.0"
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
|
"@types/babel__traverse" "^7.0.4"
|
||||||
"@types/prettier" "^2.0.0"
|
"@types/prettier" "^2.0.0"
|
||||||
chalk "^4.0.0"
|
chalk "^4.0.0"
|
||||||
expect "^26.4.1"
|
expect "^26.6.2"
|
||||||
graceful-fs "^4.2.4"
|
graceful-fs "^4.2.4"
|
||||||
jest-diff "^26.4.0"
|
jest-diff "^26.6.2"
|
||||||
jest-get-type "^26.3.0"
|
jest-get-type "^26.3.0"
|
||||||
jest-haste-map "^26.3.0"
|
jest-haste-map "^26.6.2"
|
||||||
jest-matcher-utils "^26.4.1"
|
jest-matcher-utils "^26.6.2"
|
||||||
jest-message-util "^26.3.0"
|
jest-message-util "^26.6.2"
|
||||||
jest-resolve "^26.4.0"
|
jest-resolve "^26.6.2"
|
||||||
natural-compare "^1.4.0"
|
natural-compare "^1.4.0"
|
||||||
pretty-format "^26.4.0"
|
pretty-format "^26.6.2"
|
||||||
semver "^7.3.2"
|
semver "^7.3.2"
|
||||||
|
|
||||||
jest-util@26.x, jest-util@^26.3.0:
|
jest-util@^26.1.0, jest-util@^26.6.2:
|
||||||
version "26.3.0"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/jest-util/-/jest-util-26.3.0.tgz#a8974b191df30e2bf523ebbfdbaeb8efca535b3e"
|
resolved "https://registry.yarnpkg.com/jest-util/-/jest-util-26.6.2.tgz#907535dbe4d5a6cb4c47ac9b926f6af29576cbc1"
|
||||||
integrity sha512-4zpn6bwV0+AMFN0IYhH/wnzIQzRaYVrz1A8sYnRnj4UXDXbOVtWmlaZkO9mipFqZ13okIfN87aDoJWB7VH6hcw==
|
integrity sha512-MDW0fKfsn0OI7MS7Euz6h8HNDXVQ0gaM9uW6RjfDmd1DAFcaxX9OqIakHIqhbnmF08Cf2DLDG+ulq8YQQ0Lp0Q==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
"@types/node" "*"
|
"@types/node" "*"
|
||||||
chalk "^4.0.0"
|
chalk "^4.0.0"
|
||||||
graceful-fs "^4.2.4"
|
graceful-fs "^4.2.4"
|
||||||
is-ci "^2.0.0"
|
is-ci "^2.0.0"
|
||||||
micromatch "^4.0.2"
|
micromatch "^4.0.2"
|
||||||
|
|
||||||
jest-validate@^26.4.0:
|
jest-validate@^26.6.2:
|
||||||
version "26.4.0"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/jest-validate/-/jest-validate-26.4.0.tgz#3874a7cc9e27328afac88899ee9e2fae5e3a4293"
|
resolved "https://registry.yarnpkg.com/jest-validate/-/jest-validate-26.6.2.tgz#23d380971587150467342911c3d7b4ac57ab20ec"
|
||||||
integrity sha512-t56Z/FRMrLP6mpmje7/YgHy0wOzcuc6i3LBXz6kjmsUWYN62OuMdC86Vg9/dX59SvyitSqqegOrx+h7BkNXeaQ==
|
integrity sha512-NEYZ9Aeyj0i5rQqbq+tpIOom0YS1u2MVu6+euBsvpgIme+FOfRmoC4R5p0JiAUpaFvFy24xgrpMknarR/93XjQ==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
camelcase "^6.0.0"
|
camelcase "^6.0.0"
|
||||||
chalk "^4.0.0"
|
chalk "^4.0.0"
|
||||||
jest-get-type "^26.3.0"
|
jest-get-type "^26.3.0"
|
||||||
leven "^3.1.0"
|
leven "^3.1.0"
|
||||||
pretty-format "^26.4.0"
|
pretty-format "^26.6.2"
|
||||||
|
|
||||||
jest-watcher@^26.3.0:
|
jest-watcher@^26.6.2:
|
||||||
version "26.3.0"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/jest-watcher/-/jest-watcher-26.3.0.tgz#f8ef3068ddb8af160ef868400318dc4a898eed08"
|
resolved "https://registry.yarnpkg.com/jest-watcher/-/jest-watcher-26.6.2.tgz#a5b683b8f9d68dbcb1d7dae32172d2cca0592975"
|
||||||
integrity sha512-XnLdKmyCGJ3VoF6G/p5ohbJ04q/vv5aH9ENI+i6BL0uu9WWB6Z7Z2lhQQk0d2AVZcRGp1yW+/TsoToMhBFPRdQ==
|
integrity sha512-WKJob0P/Em2csiVthsI68p6aGKTIcsfjH9Gsx1f0A3Italz43e3ho0geSAVsmj09RWOELP1AZ/DXyJgOgDKxXQ==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@jest/test-result" "^26.3.0"
|
"@jest/test-result" "^26.6.2"
|
||||||
"@jest/types" "^26.3.0"
|
"@jest/types" "^26.6.2"
|
||||||
"@types/node" "*"
|
"@types/node" "*"
|
||||||
ansi-escapes "^4.2.1"
|
ansi-escapes "^4.2.1"
|
||||||
chalk "^4.0.0"
|
chalk "^4.0.0"
|
||||||
jest-util "^26.3.0"
|
jest-util "^26.6.2"
|
||||||
string-length "^4.0.1"
|
string-length "^4.0.1"
|
||||||
|
|
||||||
jest-worker@^26.3.0:
|
jest-worker@^26.6.2:
|
||||||
version "26.3.0"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/jest-worker/-/jest-worker-26.3.0.tgz#7c8a97e4f4364b4f05ed8bca8ca0c24de091871f"
|
resolved "https://registry.yarnpkg.com/jest-worker/-/jest-worker-26.6.2.tgz#7f72cbc4d643c365e27b9fd775f9d0eaa9c7a8ed"
|
||||||
integrity sha512-Vmpn2F6IASefL+DVBhPzI2J9/GJUsqzomdeN+P+dK8/jKxbh8R3BtFnx3FIta7wYlPU62cpJMJQo4kuOowcMnw==
|
integrity sha512-KWYVV1c4i+jbMpaBC+U++4Va0cp8OisU185o73T1vo99hqi7w8tSJfUXYswwqqrjzwxa6KpRK54WhPvwf5w6PQ==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@types/node" "*"
|
"@types/node" "*"
|
||||||
merge-stream "^2.0.0"
|
merge-stream "^2.0.0"
|
||||||
supports-color "^7.0.0"
|
supports-color "^7.0.0"
|
||||||
|
|
||||||
jest@^26.1.0:
|
jest@^26.6.3:
|
||||||
version "26.4.1"
|
version "26.6.3"
|
||||||
resolved "https://registry.yarnpkg.com/jest/-/jest-26.4.1.tgz#4c187999c9af761eba862d720f66f43e80b8d12f"
|
resolved "https://registry.yarnpkg.com/jest/-/jest-26.6.3.tgz#40e8fdbe48f00dfa1f0ce8121ca74b88ac9148ef"
|
||||||
integrity sha512-q+az+ZXFOTxTlD6BRIMcZC+a33O9lsryV4Wo9gU4D/AI+Y6KKgVRCmyzpc4H2gWv0rn45lACukmMS2uSB7e1LA==
|
integrity sha512-lGS5PXGAzR4RF7V5+XObhqz2KZIDUA1yD0DG6pBVmy10eh0ZIXQImRuzocsI/N2XZ1GrLFwTS27In2i2jlpq1Q==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@jest/core" "^26.4.1"
|
"@jest/core" "^26.6.3"
|
||||||
import-local "^3.0.2"
|
import-local "^3.0.2"
|
||||||
jest-cli "^26.4.1"
|
jest-cli "^26.6.3"
|
||||||
|
|
||||||
js-tokens@^4.0.0:
|
js-tokens@^4.0.0:
|
||||||
version "4.0.0"
|
version "4.0.0"
|
||||||
@@ -2320,48 +3053,44 @@ js-tokens@^4.0.0:
|
|||||||
integrity sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==
|
integrity sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==
|
||||||
|
|
||||||
js-yaml@^3.13.1:
|
js-yaml@^3.13.1:
|
||||||
version "3.14.0"
|
version "3.14.1"
|
||||||
resolved "https://registry.yarnpkg.com/js-yaml/-/js-yaml-3.14.0.tgz#a7a34170f26a21bb162424d8adacb4113a69e482"
|
resolved "https://registry.yarnpkg.com/js-yaml/-/js-yaml-3.14.1.tgz#dae812fdb3825fa306609a8717383c50c36a0537"
|
||||||
integrity sha512-/4IbIeHcD9VMHFqDR/gQ7EdZdLimOvW2DdcxFjdyyZ9NsbS+ccrXqVWDtab/lRl5AlUqmpBx8EhPaWR+OtY17A==
|
integrity sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==
|
||||||
dependencies:
|
dependencies:
|
||||||
argparse "^1.0.7"
|
argparse "^1.0.7"
|
||||||
esprima "^4.0.0"
|
esprima "^4.0.0"
|
||||||
|
|
||||||
jsbn@~0.1.0:
|
jsdom@^16.4.0:
|
||||||
version "0.1.1"
|
version "16.6.0"
|
||||||
resolved "https://registry.yarnpkg.com/jsbn/-/jsbn-0.1.1.tgz#a5e654c2e5a2deb5f201d96cefbca80c0ef2f513"
|
resolved "https://registry.yarnpkg.com/jsdom/-/jsdom-16.6.0.tgz#f79b3786682065492a3da6a60a4695da983805ac"
|
||||||
integrity sha1-peZUwuWi3rXyAdls77yoDA7y9RM=
|
integrity sha512-Ty1vmF4NHJkolaEmdjtxTfSfkdb8Ywarwf63f+F8/mDD1uLSSWDxDuMiZxiPhwunLrn9LOSVItWj4bLYsLN3Dg==
|
||||||
|
|
||||||
jsdom@^16.2.2:
|
|
||||||
version "16.4.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/jsdom/-/jsdom-16.4.0.tgz#36005bde2d136f73eee1a830c6d45e55408edddb"
|
|
||||||
integrity sha512-lYMm3wYdgPhrl7pDcRmvzPhhrGVBeVhPIqeHjzeiHN3DFmD1RBpbExbi8vU7BJdH8VAZYovR8DMt0PNNDM7k8w==
|
|
||||||
dependencies:
|
dependencies:
|
||||||
abab "^2.0.3"
|
abab "^2.0.5"
|
||||||
acorn "^7.1.1"
|
acorn "^8.2.4"
|
||||||
acorn-globals "^6.0.0"
|
acorn-globals "^6.0.0"
|
||||||
cssom "^0.4.4"
|
cssom "^0.4.4"
|
||||||
cssstyle "^2.2.0"
|
cssstyle "^2.3.0"
|
||||||
data-urls "^2.0.0"
|
data-urls "^2.0.0"
|
||||||
decimal.js "^10.2.0"
|
decimal.js "^10.2.1"
|
||||||
domexception "^2.0.1"
|
domexception "^2.0.1"
|
||||||
escodegen "^1.14.1"
|
escodegen "^2.0.0"
|
||||||
|
form-data "^3.0.0"
|
||||||
html-encoding-sniffer "^2.0.1"
|
html-encoding-sniffer "^2.0.1"
|
||||||
is-potential-custom-element-name "^1.0.0"
|
http-proxy-agent "^4.0.1"
|
||||||
|
https-proxy-agent "^5.0.0"
|
||||||
|
is-potential-custom-element-name "^1.0.1"
|
||||||
nwsapi "^2.2.0"
|
nwsapi "^2.2.0"
|
||||||
parse5 "5.1.1"
|
parse5 "6.0.1"
|
||||||
request "^2.88.2"
|
saxes "^5.0.1"
|
||||||
request-promise-native "^1.0.8"
|
|
||||||
saxes "^5.0.0"
|
|
||||||
symbol-tree "^3.2.4"
|
symbol-tree "^3.2.4"
|
||||||
tough-cookie "^3.0.1"
|
tough-cookie "^4.0.0"
|
||||||
w3c-hr-time "^1.0.2"
|
w3c-hr-time "^1.0.2"
|
||||||
w3c-xmlserializer "^2.0.0"
|
w3c-xmlserializer "^2.0.0"
|
||||||
webidl-conversions "^6.1.0"
|
webidl-conversions "^6.1.0"
|
||||||
whatwg-encoding "^1.0.5"
|
whatwg-encoding "^1.0.5"
|
||||||
whatwg-mimetype "^2.3.0"
|
whatwg-mimetype "^2.3.0"
|
||||||
whatwg-url "^8.0.0"
|
whatwg-url "^8.5.0"
|
||||||
ws "^7.2.3"
|
ws "^7.4.5"
|
||||||
xml-name-validator "^3.0.0"
|
xml-name-validator "^3.0.0"
|
||||||
|
|
||||||
jsesc@^2.5.1:
|
jsesc@^2.5.1:
|
||||||
@@ -2369,42 +3098,24 @@ jsesc@^2.5.1:
|
|||||||
resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-2.5.2.tgz#80564d2e483dacf6e8ef209650a67df3f0c283a4"
|
resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-2.5.2.tgz#80564d2e483dacf6e8ef209650a67df3f0c283a4"
|
||||||
integrity sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==
|
integrity sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==
|
||||||
|
|
||||||
json-parse-better-errors@^1.0.1:
|
json-parse-even-better-errors@^2.3.0:
|
||||||
version "1.0.2"
|
version "2.3.1"
|
||||||
resolved "https://registry.yarnpkg.com/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz#bb867cfb3450e69107c131d1c514bab3dc8bcaa9"
|
resolved "https://registry.yarnpkg.com/json-parse-even-better-errors/-/json-parse-even-better-errors-2.3.1.tgz#7c47805a94319928e05777405dc12e1f7a4ee02d"
|
||||||
integrity sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==
|
integrity sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==
|
||||||
|
|
||||||
json-schema-traverse@^0.4.1:
|
|
||||||
version "0.4.1"
|
|
||||||
resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz#69f6a87d9513ab8bb8fe63bdb0979c448e684660"
|
|
||||||
integrity sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==
|
|
||||||
|
|
||||||
json-schema@0.2.3:
|
|
||||||
version "0.2.3"
|
|
||||||
resolved "https://registry.yarnpkg.com/json-schema/-/json-schema-0.2.3.tgz#b480c892e59a2f05954ce727bd3f2a4e882f9e13"
|
|
||||||
integrity sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=
|
|
||||||
|
|
||||||
json-stringify-safe@~5.0.1:
|
|
||||||
version "5.0.1"
|
|
||||||
resolved "https://registry.yarnpkg.com/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz#1296a2d58fd45f19a0f6ce01d65701e2c735b6eb"
|
|
||||||
integrity sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=
|
|
||||||
|
|
||||||
json5@2.x, json5@^2.1.2:
|
json5@2.x, json5@^2.1.2:
|
||||||
version "2.1.3"
|
version "2.2.0"
|
||||||
resolved "https://registry.yarnpkg.com/json5/-/json5-2.1.3.tgz#c9b0f7fa9233bfe5807fe66fcf3a5617ed597d43"
|
resolved "https://registry.yarnpkg.com/json5/-/json5-2.2.0.tgz#2dfefe720c6ba525d9ebd909950f0515316c89a3"
|
||||||
integrity sha512-KXPvOm8K9IJKFM0bmdn8QXh7udDh1g/giieX0NLCaMnb4hEiVFqnop2ImTXCc5e0/oHz3LTqmHGtExn5hfMkOA==
|
integrity sha512-f+8cldu7X/y7RAJurMEJmdoKXGB/X550w2Nr3tTbezL6RwEE/iMcm+tZnXeoZtKuOq6ft8+CqzEkrIgx1fPoQA==
|
||||||
dependencies:
|
dependencies:
|
||||||
minimist "^1.2.5"
|
minimist "^1.2.5"
|
||||||
|
|
||||||
jsprim@^1.2.2:
|
jsonfile@^4.0.0:
|
||||||
version "1.4.1"
|
version "4.0.0"
|
||||||
resolved "https://registry.yarnpkg.com/jsprim/-/jsprim-1.4.1.tgz#313e66bc1e5cc06e438bc1b7499c2e5c56acb6a2"
|
resolved "https://registry.yarnpkg.com/jsonfile/-/jsonfile-4.0.0.tgz#8771aae0799b64076b76640fca058f9c10e33ecb"
|
||||||
integrity sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=
|
integrity sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss=
|
||||||
dependencies:
|
optionalDependencies:
|
||||||
assert-plus "1.0.0"
|
graceful-fs "^4.1.6"
|
||||||
extsprintf "1.3.0"
|
|
||||||
json-schema "0.2.3"
|
|
||||||
verror "1.10.0"
|
|
||||||
|
|
||||||
kind-of@^3.0.2, kind-of@^3.0.3, kind-of@^3.2.0:
|
kind-of@^3.0.2, kind-of@^3.0.3, kind-of@^3.2.0:
|
||||||
version "3.2.2"
|
version "3.2.2"
|
||||||
@@ -2460,20 +3171,10 @@ locate-path@^5.0.0:
|
|||||||
dependencies:
|
dependencies:
|
||||||
p-locate "^4.1.0"
|
p-locate "^4.1.0"
|
||||||
|
|
||||||
lodash.memoize@4.x:
|
lodash@4.x, lodash@^4.7.0:
|
||||||
version "4.1.2"
|
version "4.17.21"
|
||||||
resolved "https://registry.yarnpkg.com/lodash.memoize/-/lodash.memoize-4.1.2.tgz#bcc6c49a42a2840ed997f323eada5ecd182e0bfe"
|
resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.21.tgz#679591c564c3bffaae8454cf0b3df370c3d6911c"
|
||||||
integrity sha1-vMbEmkKihA7Zl/Mj6tpezRguC/4=
|
integrity sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg==
|
||||||
|
|
||||||
lodash.sortby@^4.7.0:
|
|
||||||
version "4.7.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/lodash.sortby/-/lodash.sortby-4.7.0.tgz#edd14c824e2cc9c1e0b0a1b42bb5210516a42438"
|
|
||||||
integrity sha1-7dFMgk4sycHgsKG0K7UhBRakJDg=
|
|
||||||
|
|
||||||
lodash@^4.17.19:
|
|
||||||
version "4.17.20"
|
|
||||||
resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.20.tgz#b44a9b6297bcb698f1c51a3545a2b3b368d59c52"
|
|
||||||
integrity sha512-PlhdFcillOINfeV7Ni6oF1TAEayyZBoZ8bcshTHqOYJYlrqzRK5hagpagky5o4HfCzzd1TRkXPMFq6cKk9rGmA==
|
|
||||||
|
|
||||||
lru-cache@^4.1.5:
|
lru-cache@^4.1.5:
|
||||||
version "4.1.5"
|
version "4.1.5"
|
||||||
@@ -2483,6 +3184,20 @@ lru-cache@^4.1.5:
|
|||||||
pseudomap "^1.0.2"
|
pseudomap "^1.0.2"
|
||||||
yallist "^2.1.2"
|
yallist "^2.1.2"
|
||||||
|
|
||||||
|
lru-cache@^5.1.1:
|
||||||
|
version "5.1.1"
|
||||||
|
resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-5.1.1.tgz#1da27e6710271947695daf6848e847f01d84b920"
|
||||||
|
integrity sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==
|
||||||
|
dependencies:
|
||||||
|
yallist "^3.0.2"
|
||||||
|
|
||||||
|
lru-cache@^6.0.0:
|
||||||
|
version "6.0.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-6.0.0.tgz#6d6fe6570ebd96aaf90fcad1dafa3b2566db3a94"
|
||||||
|
integrity sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==
|
||||||
|
dependencies:
|
||||||
|
yallist "^4.0.0"
|
||||||
|
|
||||||
make-dir@^3.0.0:
|
make-dir@^3.0.0:
|
||||||
version "3.1.0"
|
version "3.1.0"
|
||||||
resolved "https://registry.yarnpkg.com/make-dir/-/make-dir-3.1.0.tgz#415e967046b3a7f1d185277d84aa58203726a13f"
|
resolved "https://registry.yarnpkg.com/make-dir/-/make-dir-3.1.0.tgz#415e967046b3a7f1d185277d84aa58203726a13f"
|
||||||
@@ -2539,24 +3254,24 @@ micromatch@^3.1.4:
|
|||||||
to-regex "^3.0.2"
|
to-regex "^3.0.2"
|
||||||
|
|
||||||
micromatch@^4.0.2:
|
micromatch@^4.0.2:
|
||||||
version "4.0.2"
|
version "4.0.4"
|
||||||
resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.2.tgz#4fcb0999bf9fbc2fcbdd212f6d629b9a56c39259"
|
resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.4.tgz#896d519dfe9db25fce94ceb7a500919bf881ebf9"
|
||||||
integrity sha512-y7FpHSbMUMoyPbYUSzO6PaZ6FyRnQOpHuKwbo1G+Knck95XVU4QAiKdGEnj5wwoS7PlOgthX/09u5iFJ+aYf5Q==
|
integrity sha512-pRmzw/XUcwXGpD9aI9q/0XOwLNygjETJ8y0ao0wdqprrzDa4YnxLcz7fQRZr8voh8V10kGhABbNcHVk5wHgWwg==
|
||||||
dependencies:
|
dependencies:
|
||||||
braces "^3.0.1"
|
braces "^3.0.1"
|
||||||
picomatch "^2.0.5"
|
picomatch "^2.2.3"
|
||||||
|
|
||||||
mime-db@1.44.0:
|
mime-db@1.48.0:
|
||||||
version "1.44.0"
|
version "1.48.0"
|
||||||
resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.44.0.tgz#fa11c5eb0aca1334b4233cb4d52f10c5a6272f92"
|
resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.48.0.tgz#e35b31045dd7eada3aaad537ed88a33afbef2d1d"
|
||||||
integrity sha512-/NOTfLrsPBVeH7YtFPgsVWveuL+4SjjYxaQ1xtM1KMFj7HdxlBlxeyNLzhyJVx7r4rZGJAZ/6lkKCitSc/Nmpg==
|
integrity sha512-FM3QwxV+TnZYQ2aRqhlKBMHxk10lTbMt3bBkMAp54ddrNeVSfcQYOOKuGuy3Ddrm38I04If834fOUSq1yzslJQ==
|
||||||
|
|
||||||
mime-types@^2.1.12, mime-types@~2.1.19:
|
mime-types@^2.1.12:
|
||||||
version "2.1.27"
|
version "2.1.31"
|
||||||
resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.27.tgz#47949f98e279ea53119f5722e0f34e529bec009f"
|
resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.31.tgz#a00d76b74317c61f9c2db2218b8e9f8e9c5c9e6b"
|
||||||
integrity sha512-JIhqnCasI9yD+SsmkquHBxTSEuZdQX5BuQnS2Vc7puQQQ+8yiP5AY5uWhpdv4YL4VM5c6iliiYWPgJ/nJQLp7w==
|
integrity sha512-XGZnNzm3QvgKxa8dpzyhFTHmpP3l5YNusmne07VUOXxou9CqUqYa/HBy124RqtVh/O2pECas/MOcsDgpilPOPg==
|
||||||
dependencies:
|
dependencies:
|
||||||
mime-db "1.44.0"
|
mime-db "1.48.0"
|
||||||
|
|
||||||
mimic-fn@^2.1.0:
|
mimic-fn@^2.1.0:
|
||||||
version "2.1.0"
|
version "2.1.0"
|
||||||
@@ -2593,7 +3308,7 @@ ms@2.0.0:
|
|||||||
resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8"
|
resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8"
|
||||||
integrity sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=
|
integrity sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=
|
||||||
|
|
||||||
ms@^2.1.1:
|
ms@2.1.2:
|
||||||
version "2.1.2"
|
version "2.1.2"
|
||||||
resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009"
|
resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009"
|
||||||
integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==
|
integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==
|
||||||
@@ -2620,6 +3335,11 @@ natural-compare@^1.4.0:
|
|||||||
resolved "https://registry.yarnpkg.com/natural-compare/-/natural-compare-1.4.0.tgz#4abebfeed7541f2c27acfb29bdbbd15c8d5ba4f7"
|
resolved "https://registry.yarnpkg.com/natural-compare/-/natural-compare-1.4.0.tgz#4abebfeed7541f2c27acfb29bdbbd15c8d5ba4f7"
|
||||||
integrity sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=
|
integrity sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=
|
||||||
|
|
||||||
|
netmask@^2.0.1:
|
||||||
|
version "2.0.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/netmask/-/netmask-2.0.2.tgz#8b01a07644065d536383835823bc52004ebac5e7"
|
||||||
|
integrity sha512-dBpDMdxv9Irdq66304OLfEmQ9tbNRFnFTuZiLo+bD+r332bBmMJ8GBLXklIXXgxd3+v9+KUnZaUR5PJMa75Gsg==
|
||||||
|
|
||||||
nice-try@^1.0.4:
|
nice-try@^1.0.4:
|
||||||
version "1.0.5"
|
version "1.0.5"
|
||||||
resolved "https://registry.yarnpkg.com/nice-try/-/nice-try-1.0.5.tgz#a3378a7696ce7d223e88fc9b764bd7ef1089e366"
|
resolved "https://registry.yarnpkg.com/nice-try/-/nice-try-1.0.5.tgz#a3378a7696ce7d223e88fc9b764bd7ef1089e366"
|
||||||
@@ -2636,9 +3356,9 @@ node-modules-regexp@^1.0.0:
|
|||||||
integrity sha1-jZ2+KJZKSsVxLpExZCEHxx6Q7EA=
|
integrity sha1-jZ2+KJZKSsVxLpExZCEHxx6Q7EA=
|
||||||
|
|
||||||
node-notifier@^8.0.0:
|
node-notifier@^8.0.0:
|
||||||
version "8.0.0"
|
version "8.0.2"
|
||||||
resolved "https://registry.yarnpkg.com/node-notifier/-/node-notifier-8.0.0.tgz#a7eee2d51da6d0f7ff5094bc7108c911240c1620"
|
resolved "https://registry.yarnpkg.com/node-notifier/-/node-notifier-8.0.2.tgz#f3167a38ef0d2c8a866a83e318c1ba0efeb702c5"
|
||||||
integrity sha512-46z7DUmcjoYdaWyXouuFNNfUo6eFa94t23c53c+lG/9Cvauk4a98rAUp9672X5dxGdQmLpPzTxzu8f/OeEPaFA==
|
integrity sha512-oJP/9NAdd9+x2Q+rfphB2RJCHjod70RcRLjosiPMMu5gjIfwVnOUGq2nbTjTUbmy0DJ/tFIVT30+Qe3nzl4TJg==
|
||||||
dependencies:
|
dependencies:
|
||||||
growly "^1.3.0"
|
growly "^1.3.0"
|
||||||
is-wsl "^2.2.0"
|
is-wsl "^2.2.0"
|
||||||
@@ -2647,6 +3367,11 @@ node-notifier@^8.0.0:
|
|||||||
uuid "^8.3.0"
|
uuid "^8.3.0"
|
||||||
which "^2.0.2"
|
which "^2.0.2"
|
||||||
|
|
||||||
|
node-releases@^1.1.71:
|
||||||
|
version "1.1.73"
|
||||||
|
resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-1.1.73.tgz#dd4e81ddd5277ff846b80b52bb40c49edf7a7b20"
|
||||||
|
integrity sha512-uW7fodD6pyW2FZNZnp/Z3hvWKeEW1Y8R1+1CnErE8cXFXzl5blBOoVB41CvMer6P6Q0S5FXDwcHgFd1Wj0U9zg==
|
||||||
|
|
||||||
normalize-package-data@^2.5.0:
|
normalize-package-data@^2.5.0:
|
||||||
version "2.5.0"
|
version "2.5.0"
|
||||||
resolved "https://registry.yarnpkg.com/normalize-package-data/-/normalize-package-data-2.5.0.tgz#e66db1838b200c1dfc233225d12cb36520e234a8"
|
resolved "https://registry.yarnpkg.com/normalize-package-data/-/normalize-package-data-2.5.0.tgz#e66db1838b200c1dfc233225d12cb36520e234a8"
|
||||||
@@ -2688,11 +3413,6 @@ nwsapi@^2.2.0:
|
|||||||
resolved "https://registry.yarnpkg.com/nwsapi/-/nwsapi-2.2.0.tgz#204879a9e3d068ff2a55139c2c772780681a38b7"
|
resolved "https://registry.yarnpkg.com/nwsapi/-/nwsapi-2.2.0.tgz#204879a9e3d068ff2a55139c2c772780681a38b7"
|
||||||
integrity sha512-h2AatdwYH+JHiZpv7pt/gSX1XoRGb7L/qSIeuqA6GwYoF9w1vP1cw42TO0aI2pNyshRK5893hNSl+1//vHK7hQ==
|
integrity sha512-h2AatdwYH+JHiZpv7pt/gSX1XoRGb7L/qSIeuqA6GwYoF9w1vP1cw42TO0aI2pNyshRK5893hNSl+1//vHK7hQ==
|
||||||
|
|
||||||
oauth-sign@~0.9.0:
|
|
||||||
version "0.9.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/oauth-sign/-/oauth-sign-0.9.0.tgz#47a7b016baa68b5fa0ecf3dee08a85c679ac6455"
|
|
||||||
integrity sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==
|
|
||||||
|
|
||||||
object-copy@^0.1.0:
|
object-copy@^0.1.0:
|
||||||
version "0.1.0"
|
version "0.1.0"
|
||||||
resolved "https://registry.yarnpkg.com/object-copy/-/object-copy-0.1.0.tgz#7e7d858b781bd7c991a41ba975ed3812754e998c"
|
resolved "https://registry.yarnpkg.com/object-copy/-/object-copy-0.1.0.tgz#7e7d858b781bd7c991a41ba975ed3812754e998c"
|
||||||
@@ -2743,9 +3463,9 @@ optionator@^0.8.1:
|
|||||||
word-wrap "~1.2.3"
|
word-wrap "~1.2.3"
|
||||||
|
|
||||||
p-each-series@^2.1.0:
|
p-each-series@^2.1.0:
|
||||||
version "2.1.0"
|
version "2.2.0"
|
||||||
resolved "https://registry.yarnpkg.com/p-each-series/-/p-each-series-2.1.0.tgz#961c8dd3f195ea96c747e636b262b800a6b1af48"
|
resolved "https://registry.yarnpkg.com/p-each-series/-/p-each-series-2.2.0.tgz#105ab0357ce72b202a8a8b94933672657b5e2a9a"
|
||||||
integrity sha512-ZuRs1miPT4HrjFa+9fRfOFXxGJfORgelKV9f9nNOWw2gl6gVsRaVDOQP0+MI0G0wGKns1Yacsu0GjOFbTK0JFQ==
|
integrity sha512-ycIL2+1V32th+8scbpTvyHNaHe02z0sjgh91XXjAk+ZeXoPN4Z46DVUnzdso0aX4KckKw0FNNFHdjZ2UsZvxiA==
|
||||||
|
|
||||||
p-finally@^1.0.0:
|
p-finally@^1.0.0:
|
||||||
version "1.0.0"
|
version "1.0.0"
|
||||||
@@ -2771,20 +3491,44 @@ p-try@^2.0.0:
|
|||||||
resolved "https://registry.yarnpkg.com/p-try/-/p-try-2.2.0.tgz#cb2868540e313d61de58fafbe35ce9004d5540e6"
|
resolved "https://registry.yarnpkg.com/p-try/-/p-try-2.2.0.tgz#cb2868540e313d61de58fafbe35ce9004d5540e6"
|
||||||
integrity sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==
|
integrity sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==
|
||||||
|
|
||||||
|
pac-proxy-agent@^5.0.0:
|
||||||
|
version "5.0.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/pac-proxy-agent/-/pac-proxy-agent-5.0.0.tgz#b718f76475a6a5415c2efbe256c1c971c84f635e"
|
||||||
|
integrity sha512-CcFG3ZtnxO8McDigozwE3AqAw15zDvGH+OjXO4kzf7IkEKkQ4gxQ+3sdF50WmhQ4P/bVusXcqNE2S3XrNURwzQ==
|
||||||
|
dependencies:
|
||||||
|
"@tootallnate/once" "1"
|
||||||
|
agent-base "6"
|
||||||
|
debug "4"
|
||||||
|
get-uri "3"
|
||||||
|
http-proxy-agent "^4.0.1"
|
||||||
|
https-proxy-agent "5"
|
||||||
|
pac-resolver "^5.0.0"
|
||||||
|
raw-body "^2.2.0"
|
||||||
|
socks-proxy-agent "5"
|
||||||
|
|
||||||
|
pac-resolver@^5.0.0:
|
||||||
|
version "5.0.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/pac-resolver/-/pac-resolver-5.0.0.tgz#1d717a127b3d7a9407a16d6e1b012b13b9ba8dc0"
|
||||||
|
integrity sha512-H+/A6KitiHNNW+bxBKREk2MCGSxljfqRX76NjummWEYIat7ldVXRU3dhRIE3iXZ0nvGBk6smv3nntxKkzRL8NA==
|
||||||
|
dependencies:
|
||||||
|
degenerator "^3.0.1"
|
||||||
|
ip "^1.1.5"
|
||||||
|
netmask "^2.0.1"
|
||||||
|
|
||||||
parse-json@^5.0.0:
|
parse-json@^5.0.0:
|
||||||
version "5.0.1"
|
version "5.2.0"
|
||||||
resolved "https://registry.yarnpkg.com/parse-json/-/parse-json-5.0.1.tgz#7cfe35c1ccd641bce3981467e6c2ece61b3b3878"
|
resolved "https://registry.yarnpkg.com/parse-json/-/parse-json-5.2.0.tgz#c76fc66dee54231c962b22bcc8a72cf2f99753cd"
|
||||||
integrity sha512-ztoZ4/DYeXQq4E21v169sC8qWINGpcosGv9XhTDvg9/hWvx/zrFkc9BiWxR58OJLHGk28j5BL0SDLeV2WmFZlQ==
|
integrity sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@babel/code-frame" "^7.0.0"
|
"@babel/code-frame" "^7.0.0"
|
||||||
error-ex "^1.3.1"
|
error-ex "^1.3.1"
|
||||||
json-parse-better-errors "^1.0.1"
|
json-parse-even-better-errors "^2.3.0"
|
||||||
lines-and-columns "^1.1.6"
|
lines-and-columns "^1.1.6"
|
||||||
|
|
||||||
parse5@5.1.1:
|
parse5@6.0.1:
|
||||||
version "5.1.1"
|
version "6.0.1"
|
||||||
resolved "https://registry.yarnpkg.com/parse5/-/parse5-5.1.1.tgz#f68e4e5ba1852ac2cadc00f4555fff6c2abb6178"
|
resolved "https://registry.yarnpkg.com/parse5/-/parse5-6.0.1.tgz#e1a1c085c569b3dc08321184f19a39cc27f7c30b"
|
||||||
integrity sha512-ugq4DFI0Ptb+WWjAdOK16+u/nHfiIrcE+sh8kZMaM0WllQKLI9rOUq6c2b7cwPkXdzfQESqvoqK6ug7U/Yyzug==
|
integrity sha512-Ofn/CTFzRGTTxwpNEs9PP93gXShHcTq255nzRYSKe8AkVpZY7e1fpmTfOyoIvjP5HG7Z2ZM7VS9PPhQGW2pOpw==
|
||||||
|
|
||||||
pascalcase@^0.1.1:
|
pascalcase@^0.1.1:
|
||||||
version "0.1.1"
|
version "0.1.1"
|
||||||
@@ -2812,19 +3556,14 @@ path-key@^3.0.0, path-key@^3.1.0:
|
|||||||
integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==
|
integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==
|
||||||
|
|
||||||
path-parse@^1.0.6:
|
path-parse@^1.0.6:
|
||||||
version "1.0.6"
|
version "1.0.7"
|
||||||
resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.6.tgz#d62dbb5679405d72c4737ec58600e9ddcf06d24c"
|
resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.7.tgz#fbc114b60ca42b30d9daf5858e4bd68bbedb6735"
|
||||||
integrity sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==
|
integrity sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw==
|
||||||
|
|
||||||
performance-now@^2.1.0:
|
picomatch@^2.0.4, picomatch@^2.2.3:
|
||||||
version "2.1.0"
|
version "2.3.0"
|
||||||
resolved "https://registry.yarnpkg.com/performance-now/-/performance-now-2.1.0.tgz#6309f4e0e5fa913ec1c69307ae364b4b377c9e7b"
|
resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.0.tgz#f1f061de8f6a4bf022892e2d128234fb98302972"
|
||||||
integrity sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=
|
integrity sha512-lY1Q/PiJGC2zOv/z391WOTD+Z02bCgsFfvxoXXf6h7kv9o+WmsmzYqrAwY63sNgOxE4xEdq0WyUnXfKeBrSvYw==
|
||||||
|
|
||||||
picomatch@^2.0.4, picomatch@^2.0.5:
|
|
||||||
version "2.2.2"
|
|
||||||
resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.2.2.tgz#21f333e9b6b8eaff02468f5146ea406d345f4dad"
|
|
||||||
integrity sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg==
|
|
||||||
|
|
||||||
pirates@^4.0.1:
|
pirates@^4.0.1:
|
||||||
version "4.0.1"
|
version "4.0.1"
|
||||||
@@ -2850,45 +3589,54 @@ prelude-ls@~1.1.2:
|
|||||||
resolved "https://registry.yarnpkg.com/prelude-ls/-/prelude-ls-1.1.2.tgz#21932a549f5e52ffd9a827f570e04be62a97da54"
|
resolved "https://registry.yarnpkg.com/prelude-ls/-/prelude-ls-1.1.2.tgz#21932a549f5e52ffd9a827f570e04be62a97da54"
|
||||||
integrity sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=
|
integrity sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=
|
||||||
|
|
||||||
prettier@^2.0.5:
|
prettier@^2.3.2:
|
||||||
version "2.0.5"
|
version "2.3.2"
|
||||||
resolved "https://registry.yarnpkg.com/prettier/-/prettier-2.0.5.tgz#d6d56282455243f2f92cc1716692c08aa31522d4"
|
resolved "https://registry.yarnpkg.com/prettier/-/prettier-2.3.2.tgz#ef280a05ec253712e486233db5c6f23441e7342d"
|
||||||
integrity sha512-7PtVymN48hGcO4fGjybyBSIWDsLU4H4XlvOHfq91pz9kkGlonzwTfYkaIEwiRg/dAJF9YlbsduBAgtYLi+8cFg==
|
integrity sha512-lnJzDfJ66zkMy58OL5/NY5zp70S7Nz6KqcKkXYzn2tMVrNxvbqaBpg7H3qHaLxCJ5lNMsGuM8+ohS7cZrthdLQ==
|
||||||
|
|
||||||
pretty-format@^25.2.1, pretty-format@^25.5.0:
|
pretty-format@^26.0.0, pretty-format@^26.6.2:
|
||||||
version "25.5.0"
|
version "26.6.2"
|
||||||
resolved "https://registry.yarnpkg.com/pretty-format/-/pretty-format-25.5.0.tgz#7873c1d774f682c34b8d48b6743a2bf2ac55791a"
|
resolved "https://registry.yarnpkg.com/pretty-format/-/pretty-format-26.6.2.tgz#e35c2705f14cb7fe2fe94fa078345b444120fc93"
|
||||||
integrity sha512-kbo/kq2LQ/A/is0PQwsEHM7Ca6//bGPPvU6UnsdDRSKTWxT/ru/xb88v4BJf6a69H+uTytOEsTusT9ksd/1iWQ==
|
integrity sha512-7AeGuCYNGmycyQbCqd/3PWH4eOoX/OiCa0uphp57NVTeAGdJGaAliecxwBDHYQCIvrW7aDBZCYeNTP/WX69mkg==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@jest/types" "^25.5.0"
|
"@jest/types" "^26.6.2"
|
||||||
ansi-regex "^5.0.0"
|
ansi-regex "^5.0.0"
|
||||||
ansi-styles "^4.0.0"
|
ansi-styles "^4.0.0"
|
||||||
react-is "^16.12.0"
|
react-is "^17.0.1"
|
||||||
|
|
||||||
pretty-format@^26.4.0:
|
|
||||||
version "26.4.0"
|
|
||||||
resolved "https://registry.yarnpkg.com/pretty-format/-/pretty-format-26.4.0.tgz#c08073f531429e9e5024049446f42ecc9f933a3b"
|
|
||||||
integrity sha512-mEEwwpCseqrUtuMbrJG4b824877pM5xald3AkilJ47Po2YLr97/siejYQHqj2oDQBeJNbu+Q0qUuekJ8F0NAPg==
|
|
||||||
dependencies:
|
|
||||||
"@jest/types" "^26.3.0"
|
|
||||||
ansi-regex "^5.0.0"
|
|
||||||
ansi-styles "^4.0.0"
|
|
||||||
react-is "^16.12.0"
|
|
||||||
|
|
||||||
prompts@^2.0.1:
|
prompts@^2.0.1:
|
||||||
version "2.3.2"
|
version "2.4.1"
|
||||||
resolved "https://registry.yarnpkg.com/prompts/-/prompts-2.3.2.tgz#480572d89ecf39566d2bd3fe2c9fccb7c4c0b068"
|
resolved "https://registry.yarnpkg.com/prompts/-/prompts-2.4.1.tgz#befd3b1195ba052f9fd2fde8a486c4e82ee77f61"
|
||||||
integrity sha512-Q06uKs2CkNYVID0VqwfAl9mipo99zkBv/n2JtWY89Yxa3ZabWSrs0e2KTudKVa3peLUvYXMefDqIleLPVUBZMA==
|
integrity sha512-EQyfIuO2hPDsX1L/blblV+H7I0knhgAd82cVneCwcdND9B8AuCDuRcBH6yIcG4dFzlOUqbazQqwGjx5xmsNLuQ==
|
||||||
dependencies:
|
dependencies:
|
||||||
kleur "^3.0.3"
|
kleur "^3.0.3"
|
||||||
sisteransi "^1.0.4"
|
sisteransi "^1.0.5"
|
||||||
|
|
||||||
|
proxy-agent@^5.0.0:
|
||||||
|
version "5.0.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/proxy-agent/-/proxy-agent-5.0.0.tgz#d31405c10d6e8431fde96cba7a0c027ce01d633b"
|
||||||
|
integrity sha512-gkH7BkvLVkSfX9Dk27W6TyNOWWZWRilRfk1XxGNWOYJ2TuedAv1yFpCaU9QSBmBe716XOTNpYNOzhysyw8xn7g==
|
||||||
|
dependencies:
|
||||||
|
agent-base "^6.0.0"
|
||||||
|
debug "4"
|
||||||
|
http-proxy-agent "^4.0.0"
|
||||||
|
https-proxy-agent "^5.0.0"
|
||||||
|
lru-cache "^5.1.1"
|
||||||
|
pac-proxy-agent "^5.0.0"
|
||||||
|
proxy-from-env "^1.0.0"
|
||||||
|
socks-proxy-agent "^5.0.0"
|
||||||
|
|
||||||
|
proxy-from-env@^1.0.0:
|
||||||
|
version "1.1.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/proxy-from-env/-/proxy-from-env-1.1.0.tgz#e102f16ca355424865755d2c9e8ea4f24d58c3e2"
|
||||||
|
integrity sha512-D+zkORCbA9f1tdWRK0RaCR3GPv50cMxcrz4X8k5LTSUD1Dkw47mKJEZQNunItRTkWwgtaUSo1RVFRIG9ZXiFYg==
|
||||||
|
|
||||||
pseudomap@^1.0.2:
|
pseudomap@^1.0.2:
|
||||||
version "1.0.2"
|
version "1.0.2"
|
||||||
resolved "https://registry.yarnpkg.com/pseudomap/-/pseudomap-1.0.2.tgz#f052a28da70e618917ef0a8ac34c1ae5a68286b3"
|
resolved "https://registry.yarnpkg.com/pseudomap/-/pseudomap-1.0.2.tgz#f052a28da70e618917ef0a8ac34c1ae5a68286b3"
|
||||||
integrity sha1-8FKijacOYYkX7wqKw0wa5aaChrM=
|
integrity sha1-8FKijacOYYkX7wqKw0wa5aaChrM=
|
||||||
|
|
||||||
psl@^1.1.28:
|
psl@^1.1.33:
|
||||||
version "1.8.0"
|
version "1.8.0"
|
||||||
resolved "https://registry.yarnpkg.com/psl/-/psl-1.8.0.tgz#9326f8bcfb013adcc005fdff056acce020e51c24"
|
resolved "https://registry.yarnpkg.com/psl/-/psl-1.8.0.tgz#9326f8bcfb013adcc005fdff056acce020e51c24"
|
||||||
integrity sha512-RIdOzyoavK+hA18OGGWDqUTsCLhtA7IcZ/6NCs4fFJaHBDab+pDDmDIByWFRQJq2Cd7r1OoQxBGKOaztq+hjIQ==
|
integrity sha512-RIdOzyoavK+hA18OGGWDqUTsCLhtA7IcZ/6NCs4fFJaHBDab+pDDmDIByWFRQJq2Cd7r1OoQxBGKOaztq+hjIQ==
|
||||||
@@ -2901,20 +3649,25 @@ pump@^3.0.0:
|
|||||||
end-of-stream "^1.1.0"
|
end-of-stream "^1.1.0"
|
||||||
once "^1.3.1"
|
once "^1.3.1"
|
||||||
|
|
||||||
punycode@^2.1.0, punycode@^2.1.1:
|
punycode@^2.1.1:
|
||||||
version "2.1.1"
|
version "2.1.1"
|
||||||
resolved "https://registry.yarnpkg.com/punycode/-/punycode-2.1.1.tgz#b58b010ac40c22c5657616c8d2c2c02c7bf479ec"
|
resolved "https://registry.yarnpkg.com/punycode/-/punycode-2.1.1.tgz#b58b010ac40c22c5657616c8d2c2c02c7bf479ec"
|
||||||
integrity sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==
|
integrity sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==
|
||||||
|
|
||||||
qs@~6.5.2:
|
raw-body@^2.2.0:
|
||||||
version "6.5.2"
|
version "2.4.3"
|
||||||
resolved "https://registry.yarnpkg.com/qs/-/qs-6.5.2.tgz#cb3ae806e8740444584ef154ce8ee98d403f3e36"
|
resolved "https://registry.yarnpkg.com/raw-body/-/raw-body-2.4.3.tgz#8f80305d11c2a0a545c2d9d89d7a0286fcead43c"
|
||||||
integrity sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==
|
integrity sha512-UlTNLIcu0uzb4D2f4WltY6cVjLi+/jEN4lgEUj3E04tpMDpUlkBo/eSn6zou9hum2VMNpCCUone0O0WeJim07g==
|
||||||
|
dependencies:
|
||||||
|
bytes "3.1.2"
|
||||||
|
http-errors "1.8.1"
|
||||||
|
iconv-lite "0.4.24"
|
||||||
|
unpipe "1.0.0"
|
||||||
|
|
||||||
react-is@^16.12.0:
|
react-is@^17.0.1:
|
||||||
version "16.13.1"
|
version "17.0.2"
|
||||||
resolved "https://registry.yarnpkg.com/react-is/-/react-is-16.13.1.tgz#789729a4dc36de2999dc156dd6c1d9c18cea56a4"
|
resolved "https://registry.yarnpkg.com/react-is/-/react-is-17.0.2.tgz#e691d4a8e9c789365655539ab372762b0efb54f0"
|
||||||
integrity sha512-24e6ynE2H+OKt4kqsOvNd8kBpV65zoxbA4BVsEOB3ARVWQki/DHzaUoC5KuON/BiccDaCCTZBuOcfZs70kR8bQ==
|
integrity sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w==
|
||||||
|
|
||||||
read-pkg-up@^7.0.1:
|
read-pkg-up@^7.0.1:
|
||||||
version "7.0.1"
|
version "7.0.1"
|
||||||
@@ -2935,6 +3688,16 @@ read-pkg@^5.2.0:
|
|||||||
parse-json "^5.0.0"
|
parse-json "^5.0.0"
|
||||||
type-fest "^0.6.0"
|
type-fest "^0.6.0"
|
||||||
|
|
||||||
|
readable-stream@1.1.x:
|
||||||
|
version "1.1.14"
|
||||||
|
resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-1.1.14.tgz#7cf4c54ef648e3813084c636dd2079e166c081d9"
|
||||||
|
integrity sha1-fPTFTvZI44EwhMY23SB54WbAgdk=
|
||||||
|
dependencies:
|
||||||
|
core-util-is "~1.0.0"
|
||||||
|
inherits "~2.0.1"
|
||||||
|
isarray "0.0.1"
|
||||||
|
string_decoder "~0.10.x"
|
||||||
|
|
||||||
regex-not@^1.0.0, regex-not@^1.0.2:
|
regex-not@^1.0.0, regex-not@^1.0.2:
|
||||||
version "1.0.2"
|
version "1.0.2"
|
||||||
resolved "https://registry.yarnpkg.com/regex-not/-/regex-not-1.0.2.tgz#1f4ece27e00b0b65e0247a6810e6a85d83a5752c"
|
resolved "https://registry.yarnpkg.com/regex-not/-/regex-not-1.0.2.tgz#1f4ece27e00b0b65e0247a6810e6a85d83a5752c"
|
||||||
@@ -2949,57 +3712,15 @@ remove-trailing-separator@^1.0.1:
|
|||||||
integrity sha1-wkvOKig62tW8P1jg1IJJuSN52O8=
|
integrity sha1-wkvOKig62tW8P1jg1IJJuSN52O8=
|
||||||
|
|
||||||
repeat-element@^1.1.2:
|
repeat-element@^1.1.2:
|
||||||
version "1.1.3"
|
version "1.1.4"
|
||||||
resolved "https://registry.yarnpkg.com/repeat-element/-/repeat-element-1.1.3.tgz#782e0d825c0c5a3bb39731f84efee6b742e6b1ce"
|
resolved "https://registry.yarnpkg.com/repeat-element/-/repeat-element-1.1.4.tgz#be681520847ab58c7568ac75fbfad28ed42d39e9"
|
||||||
integrity sha512-ahGq0ZnV5m5XtZLMb+vP76kcAM5nkLqk0lpqAuojSKGgQtn4eRi4ZZGm2olo2zKFH+sMsWaqOCW1dqAnOru72g==
|
integrity sha512-LFiNfRcSu7KK3evMyYOuCzv3L10TW7yC1G2/+StMjK8Y6Vqd2MG7r/Qjw4ghtuCOjFvlnms/iMmLqpvW/ES/WQ==
|
||||||
|
|
||||||
repeat-string@^1.6.1:
|
repeat-string@^1.6.1:
|
||||||
version "1.6.1"
|
version "1.6.1"
|
||||||
resolved "https://registry.yarnpkg.com/repeat-string/-/repeat-string-1.6.1.tgz#8dcae470e1c88abc2d600fff4a776286da75e637"
|
resolved "https://registry.yarnpkg.com/repeat-string/-/repeat-string-1.6.1.tgz#8dcae470e1c88abc2d600fff4a776286da75e637"
|
||||||
integrity sha1-jcrkcOHIirwtYA//Sndihtp15jc=
|
integrity sha1-jcrkcOHIirwtYA//Sndihtp15jc=
|
||||||
|
|
||||||
request-promise-core@1.1.4:
|
|
||||||
version "1.1.4"
|
|
||||||
resolved "https://registry.yarnpkg.com/request-promise-core/-/request-promise-core-1.1.4.tgz#3eedd4223208d419867b78ce815167d10593a22f"
|
|
||||||
integrity sha512-TTbAfBBRdWD7aNNOoVOBH4pN/KigV6LyapYNNlAPA8JwbovRti1E88m3sYAwsLi5ryhPKsE9APwnjFTgdUjTpw==
|
|
||||||
dependencies:
|
|
||||||
lodash "^4.17.19"
|
|
||||||
|
|
||||||
request-promise-native@^1.0.8:
|
|
||||||
version "1.0.9"
|
|
||||||
resolved "https://registry.yarnpkg.com/request-promise-native/-/request-promise-native-1.0.9.tgz#e407120526a5efdc9a39b28a5679bf47b9d9dc28"
|
|
||||||
integrity sha512-wcW+sIUiWnKgNY0dqCpOZkUbF/I+YPi+f09JZIDa39Ec+q82CpSYniDp+ISgTTbKmnpJWASeJBPZmoxH84wt3g==
|
|
||||||
dependencies:
|
|
||||||
request-promise-core "1.1.4"
|
|
||||||
stealthy-require "^1.1.1"
|
|
||||||
tough-cookie "^2.3.3"
|
|
||||||
|
|
||||||
request@^2.88.2:
|
|
||||||
version "2.88.2"
|
|
||||||
resolved "https://registry.yarnpkg.com/request/-/request-2.88.2.tgz#d73c918731cb5a87da047e207234146f664d12b3"
|
|
||||||
integrity sha512-MsvtOrfG9ZcrOwAW+Qi+F6HbD0CWXEh9ou77uOb7FM2WPhwT7smM833PzanhJLsgXjN89Ir6V2PczXNnMpwKhw==
|
|
||||||
dependencies:
|
|
||||||
aws-sign2 "~0.7.0"
|
|
||||||
aws4 "^1.8.0"
|
|
||||||
caseless "~0.12.0"
|
|
||||||
combined-stream "~1.0.6"
|
|
||||||
extend "~3.0.2"
|
|
||||||
forever-agent "~0.6.1"
|
|
||||||
form-data "~2.3.2"
|
|
||||||
har-validator "~5.1.3"
|
|
||||||
http-signature "~1.2.0"
|
|
||||||
is-typedarray "~1.0.0"
|
|
||||||
isstream "~0.1.2"
|
|
||||||
json-stringify-safe "~5.0.1"
|
|
||||||
mime-types "~2.1.19"
|
|
||||||
oauth-sign "~0.9.0"
|
|
||||||
performance-now "^2.1.0"
|
|
||||||
qs "~6.5.2"
|
|
||||||
safe-buffer "^5.1.2"
|
|
||||||
tough-cookie "~2.5.0"
|
|
||||||
tunnel-agent "^0.6.0"
|
|
||||||
uuid "^3.3.2"
|
|
||||||
|
|
||||||
require-directory@^2.1.1:
|
require-directory@^2.1.1:
|
||||||
version "2.1.1"
|
version "2.1.1"
|
||||||
resolved "https://registry.yarnpkg.com/require-directory/-/require-directory-2.1.1.tgz#8c64ad5fd30dab1c976e2344ffe7f792a6a6df42"
|
resolved "https://registry.yarnpkg.com/require-directory/-/require-directory-2.1.1.tgz#8c64ad5fd30dab1c976e2344ffe7f792a6a6df42"
|
||||||
@@ -3027,11 +3748,12 @@ resolve-url@^0.2.1:
|
|||||||
resolved "https://registry.yarnpkg.com/resolve-url/-/resolve-url-0.2.1.tgz#2c637fe77c893afd2a663fe21aa9080068e2052a"
|
resolved "https://registry.yarnpkg.com/resolve-url/-/resolve-url-0.2.1.tgz#2c637fe77c893afd2a663fe21aa9080068e2052a"
|
||||||
integrity sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo=
|
integrity sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo=
|
||||||
|
|
||||||
resolve@^1.10.0, resolve@^1.17.0, resolve@^1.3.2:
|
resolve@^1.10.0, resolve@^1.18.1:
|
||||||
version "1.17.0"
|
version "1.20.0"
|
||||||
resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.17.0.tgz#b25941b54968231cc2d1bb76a79cb7f2c0bf8444"
|
resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.20.0.tgz#629a013fb3f70755d6f0b7935cc1c2c5378b1975"
|
||||||
integrity sha512-ic+7JYiV8Vi2yzQGFWOkiZD5Z9z7O2Zhm9XMaTxdJExKasieFCr+yXZ/WmXsckHiKl12ar0y6XiXDx3m4RHn1w==
|
integrity sha512-wENBPt4ySzg4ybFQW2TT1zMQucPK95HSh/nq2CFTZVOGut2+pQvSsgtda4d26YrYcr067wjbmzOG8byDPBX63A==
|
||||||
dependencies:
|
dependencies:
|
||||||
|
is-core-module "^2.2.0"
|
||||||
path-parse "^1.0.6"
|
path-parse "^1.0.6"
|
||||||
|
|
||||||
ret@~0.1.10:
|
ret@~0.1.10:
|
||||||
@@ -3051,11 +3773,6 @@ rsvp@^4.8.4:
|
|||||||
resolved "https://registry.yarnpkg.com/rsvp/-/rsvp-4.8.5.tgz#c8f155311d167f68f21e168df71ec5b083113734"
|
resolved "https://registry.yarnpkg.com/rsvp/-/rsvp-4.8.5.tgz#c8f155311d167f68f21e168df71ec5b083113734"
|
||||||
integrity sha512-nfMOlASu9OnRJo1mbEk2cz0D56a1MBNrJ7orjRZQG10XDyuvwksKbuXNp6qa+kbn839HwjwhBzhFmdsaEAfauA==
|
integrity sha512-nfMOlASu9OnRJo1mbEk2cz0D56a1MBNrJ7orjRZQG10XDyuvwksKbuXNp6qa+kbn839HwjwhBzhFmdsaEAfauA==
|
||||||
|
|
||||||
safe-buffer@^5.0.1, safe-buffer@^5.1.2:
|
|
||||||
version "5.2.1"
|
|
||||||
resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.2.1.tgz#1eaf9fa9bdb1fdd4ec75f58f9cdb4e6b7827eec6"
|
|
||||||
integrity sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==
|
|
||||||
|
|
||||||
safe-buffer@~5.1.1:
|
safe-buffer@~5.1.1:
|
||||||
version "5.1.2"
|
version "5.1.2"
|
||||||
resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.2.tgz#991ec69d296e0313747d59bdfd2b745c35f8828d"
|
resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.2.tgz#991ec69d296e0313747d59bdfd2b745c35f8828d"
|
||||||
@@ -3068,7 +3785,7 @@ safe-regex@^1.1.0:
|
|||||||
dependencies:
|
dependencies:
|
||||||
ret "~0.1.10"
|
ret "~0.1.10"
|
||||||
|
|
||||||
"safer-buffer@>= 2.1.2 < 3", safer-buffer@^2.0.2, safer-buffer@^2.1.0, safer-buffer@~2.1.0:
|
"safer-buffer@>= 2.1.2 < 3":
|
||||||
version "2.1.2"
|
version "2.1.2"
|
||||||
resolved "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a"
|
resolved "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a"
|
||||||
integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==
|
integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==
|
||||||
@@ -3088,22 +3805,24 @@ sane@^4.0.3:
|
|||||||
minimist "^1.1.1"
|
minimist "^1.1.1"
|
||||||
walker "~1.0.5"
|
walker "~1.0.5"
|
||||||
|
|
||||||
saxes@^5.0.0:
|
saxes@^5.0.1:
|
||||||
version "5.0.1"
|
version "5.0.1"
|
||||||
resolved "https://registry.yarnpkg.com/saxes/-/saxes-5.0.1.tgz#eebab953fa3b7608dbe94e5dadb15c888fa6696d"
|
resolved "https://registry.yarnpkg.com/saxes/-/saxes-5.0.1.tgz#eebab953fa3b7608dbe94e5dadb15c888fa6696d"
|
||||||
integrity sha512-5LBh1Tls8c9xgGjw3QrMwETmTMVk0oFgvrFSvWx62llR2hcEInrKNZ2GZCCuuy2lvWrdl5jhbpeqc5hRYKFOcw==
|
integrity sha512-5LBh1Tls8c9xgGjw3QrMwETmTMVk0oFgvrFSvWx62llR2hcEInrKNZ2GZCCuuy2lvWrdl5jhbpeqc5hRYKFOcw==
|
||||||
dependencies:
|
dependencies:
|
||||||
xmlchars "^2.2.0"
|
xmlchars "^2.2.0"
|
||||||
|
|
||||||
"semver@2 || 3 || 4 || 5", semver@^5.4.1, semver@^5.5.0, semver@^5.6.0:
|
"semver@2 || 3 || 4 || 5", semver@^5.5.0, semver@^5.6.0:
|
||||||
version "5.7.1"
|
version "5.7.1"
|
||||||
resolved "https://registry.yarnpkg.com/semver/-/semver-5.7.1.tgz#a954f931aeba508d307bbf069eff0c01c96116f7"
|
resolved "https://registry.yarnpkg.com/semver/-/semver-5.7.1.tgz#a954f931aeba508d307bbf069eff0c01c96116f7"
|
||||||
integrity sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==
|
integrity sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==
|
||||||
|
|
||||||
semver@7.x, semver@^7.3.2:
|
semver@7.x, semver@^7.3.2:
|
||||||
version "7.3.2"
|
version "7.3.5"
|
||||||
resolved "https://registry.yarnpkg.com/semver/-/semver-7.3.2.tgz#604962b052b81ed0786aae84389ffba70ffd3938"
|
resolved "https://registry.yarnpkg.com/semver/-/semver-7.3.5.tgz#0b621c879348d8998e4b0e4be94b3f12e6018ef7"
|
||||||
integrity sha512-OrOb32TeeambH6UrhtShmF7CRDqhL6/5XpPNp2DuRH6+9QLw/orhp72j87v8Qa1ScDkvrrBNpZcDejAirJmfXQ==
|
integrity sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ==
|
||||||
|
dependencies:
|
||||||
|
lru-cache "^6.0.0"
|
||||||
|
|
||||||
semver@^6.0.0, semver@^6.3.0:
|
semver@^6.0.0, semver@^6.3.0:
|
||||||
version "6.3.0"
|
version "6.3.0"
|
||||||
@@ -3125,6 +3844,11 @@ set-value@^2.0.0, set-value@^2.0.1:
|
|||||||
is-plain-object "^2.0.3"
|
is-plain-object "^2.0.3"
|
||||||
split-string "^3.0.1"
|
split-string "^3.0.1"
|
||||||
|
|
||||||
|
setprototypeof@1.2.0:
|
||||||
|
version "1.2.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/setprototypeof/-/setprototypeof-1.2.0.tgz#66c9a24a73f9fc28cbe66b09fed3d33dcaf1b424"
|
||||||
|
integrity sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==
|
||||||
|
|
||||||
shebang-command@^1.2.0:
|
shebang-command@^1.2.0:
|
||||||
version "1.2.0"
|
version "1.2.0"
|
||||||
resolved "https://registry.yarnpkg.com/shebang-command/-/shebang-command-1.2.0.tgz#44aac65b695b03398968c39f363fee5deafdf1ea"
|
resolved "https://registry.yarnpkg.com/shebang-command/-/shebang-command-1.2.0.tgz#44aac65b695b03398968c39f363fee5deafdf1ea"
|
||||||
@@ -3164,7 +3888,7 @@ signal-exit@^3.0.0, signal-exit@^3.0.2:
|
|||||||
resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.3.tgz#a1410c2edd8f077b08b4e253c8eacfcaf057461c"
|
resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.3.tgz#a1410c2edd8f077b08b4e253c8eacfcaf057461c"
|
||||||
integrity sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==
|
integrity sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA==
|
||||||
|
|
||||||
sisteransi@^1.0.4:
|
sisteransi@^1.0.5:
|
||||||
version "1.0.5"
|
version "1.0.5"
|
||||||
resolved "https://registry.yarnpkg.com/sisteransi/-/sisteransi-1.0.5.tgz#134d681297756437cc05ca01370d3a7a571075ed"
|
resolved "https://registry.yarnpkg.com/sisteransi/-/sisteransi-1.0.5.tgz#134d681297756437cc05ca01370d3a7a571075ed"
|
||||||
integrity sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==
|
integrity sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==
|
||||||
@@ -3174,6 +3898,11 @@ slash@^3.0.0:
|
|||||||
resolved "https://registry.yarnpkg.com/slash/-/slash-3.0.0.tgz#6539be870c165adbd5240220dbe361f1bc4d4634"
|
resolved "https://registry.yarnpkg.com/slash/-/slash-3.0.0.tgz#6539be870c165adbd5240220dbe361f1bc4d4634"
|
||||||
integrity sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==
|
integrity sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==
|
||||||
|
|
||||||
|
smart-buffer@^4.2.0:
|
||||||
|
version "4.2.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/smart-buffer/-/smart-buffer-4.2.0.tgz#6e1d71fa4f18c05f7d0ff216dd16a481d0e8d9ae"
|
||||||
|
integrity sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg==
|
||||||
|
|
||||||
snapdragon-node@^2.0.1:
|
snapdragon-node@^2.0.1:
|
||||||
version "2.1.1"
|
version "2.1.1"
|
||||||
resolved "https://registry.yarnpkg.com/snapdragon-node/-/snapdragon-node-2.1.1.tgz#6c175f86ff14bdb0724563e8f3c1b021a286853b"
|
resolved "https://registry.yarnpkg.com/snapdragon-node/-/snapdragon-node-2.1.1.tgz#6c175f86ff14bdb0724563e8f3c1b021a286853b"
|
||||||
@@ -3204,6 +3933,23 @@ snapdragon@^0.8.1:
|
|||||||
source-map-resolve "^0.5.0"
|
source-map-resolve "^0.5.0"
|
||||||
use "^3.1.0"
|
use "^3.1.0"
|
||||||
|
|
||||||
|
socks-proxy-agent@5, socks-proxy-agent@^5.0.0:
|
||||||
|
version "5.0.1"
|
||||||
|
resolved "https://registry.yarnpkg.com/socks-proxy-agent/-/socks-proxy-agent-5.0.1.tgz#032fb583048a29ebffec2e6a73fca0761f48177e"
|
||||||
|
integrity sha512-vZdmnjb9a2Tz6WEQVIurybSwElwPxMZaIc7PzqbJTrezcKNznv6giT7J7tZDZ1BojVaa1jvO/UiUdhDVB0ACoQ==
|
||||||
|
dependencies:
|
||||||
|
agent-base "^6.0.2"
|
||||||
|
debug "4"
|
||||||
|
socks "^2.3.3"
|
||||||
|
|
||||||
|
socks@^2.3.3:
|
||||||
|
version "2.6.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/socks/-/socks-2.6.2.tgz#ec042d7960073d40d94268ff3bb727dc685f111a"
|
||||||
|
integrity sha512-zDZhHhZRY9PxRruRMR7kMhnf3I8hDs4S3f9RecfnGxvcBHQcKcIH/oUcEWffsfl1XxdYlA7nnlGbbTvPz9D8gA==
|
||||||
|
dependencies:
|
||||||
|
ip "^1.1.5"
|
||||||
|
smart-buffer "^4.2.0"
|
||||||
|
|
||||||
source-map-resolve@^0.5.0:
|
source-map-resolve@^0.5.0:
|
||||||
version "0.5.3"
|
version "0.5.3"
|
||||||
resolved "https://registry.yarnpkg.com/source-map-resolve/-/source-map-resolve-0.5.3.tgz#190866bece7553e1f8f267a2ee82c606b5509a1a"
|
resolved "https://registry.yarnpkg.com/source-map-resolve/-/source-map-resolve-0.5.3.tgz#190866bece7553e1f8f267a2ee82c606b5509a1a"
|
||||||
@@ -3224,9 +3970,9 @@ source-map-support@^0.5.6:
|
|||||||
source-map "^0.6.0"
|
source-map "^0.6.0"
|
||||||
|
|
||||||
source-map-url@^0.4.0:
|
source-map-url@^0.4.0:
|
||||||
version "0.4.0"
|
version "0.4.1"
|
||||||
resolved "https://registry.yarnpkg.com/source-map-url/-/source-map-url-0.4.0.tgz#3e935d7ddd73631b97659956d55128e87b5084a3"
|
resolved "https://registry.yarnpkg.com/source-map-url/-/source-map-url-0.4.1.tgz#0af66605a745a5a2f91cf1bbf8a7afbc283dec56"
|
||||||
integrity sha1-PpNdfd1zYxuXZZlW1VEo6HtQhKM=
|
integrity sha512-cPiFOTLUKvJFIg4SKVScy4ilPPW6rFgMgfuZJPNoDuMs3nC1HbMUycBoJw77xFIp6z1UJQJOfx6C9GMH80DiTw==
|
||||||
|
|
||||||
source-map@^0.5.0, source-map@^0.5.6:
|
source-map@^0.5.0, source-map@^0.5.6:
|
||||||
version "0.5.7"
|
version "0.5.7"
|
||||||
@@ -3265,9 +4011,9 @@ spdx-expression-parse@^3.0.0:
|
|||||||
spdx-license-ids "^3.0.0"
|
spdx-license-ids "^3.0.0"
|
||||||
|
|
||||||
spdx-license-ids@^3.0.0:
|
spdx-license-ids@^3.0.0:
|
||||||
version "3.0.5"
|
version "3.0.9"
|
||||||
resolved "https://registry.yarnpkg.com/spdx-license-ids/-/spdx-license-ids-3.0.5.tgz#3694b5804567a458d3c8045842a6358632f62654"
|
resolved "https://registry.yarnpkg.com/spdx-license-ids/-/spdx-license-ids-3.0.9.tgz#8a595135def9592bda69709474f1cbeea7c2467f"
|
||||||
integrity sha512-J+FWzZoynJEXGphVIS+XEh3kFSjZX/1i9gFBaWQcB+/tmpe2qUsSBABpcxqxnAxFdiUFEgAX1bjYGQvIZmoz9Q==
|
integrity sha512-Ki212dKK4ogX+xDo4CtOZBVIwhsKBEfsEEcwmJfLQzirgc2jIWdzg40Unxz/HzEUqM1WFzVlQSMF9kZZ2HboLQ==
|
||||||
|
|
||||||
split-string@^3.0.1, split-string@^3.0.2:
|
split-string@^3.0.1, split-string@^3.0.2:
|
||||||
version "3.1.0"
|
version "3.1.0"
|
||||||
@@ -3281,25 +4027,10 @@ sprintf-js@~1.0.2:
|
|||||||
resolved "https://registry.yarnpkg.com/sprintf-js/-/sprintf-js-1.0.3.tgz#04e6926f662895354f3dd015203633b857297e2c"
|
resolved "https://registry.yarnpkg.com/sprintf-js/-/sprintf-js-1.0.3.tgz#04e6926f662895354f3dd015203633b857297e2c"
|
||||||
integrity sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=
|
integrity sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=
|
||||||
|
|
||||||
sshpk@^1.7.0:
|
|
||||||
version "1.16.1"
|
|
||||||
resolved "https://registry.yarnpkg.com/sshpk/-/sshpk-1.16.1.tgz#fb661c0bef29b39db40769ee39fa70093d6f6877"
|
|
||||||
integrity sha512-HXXqVUq7+pcKeLqqZj6mHFUMvXtOJt1uoUx09pFW6011inTMxqI8BA8PM95myrIyyKwdnzjdFjLiE6KBPVtJIg==
|
|
||||||
dependencies:
|
|
||||||
asn1 "~0.2.3"
|
|
||||||
assert-plus "^1.0.0"
|
|
||||||
bcrypt-pbkdf "^1.0.0"
|
|
||||||
dashdash "^1.12.0"
|
|
||||||
ecc-jsbn "~0.1.1"
|
|
||||||
getpass "^0.1.1"
|
|
||||||
jsbn "~0.1.0"
|
|
||||||
safer-buffer "^2.0.2"
|
|
||||||
tweetnacl "~0.14.0"
|
|
||||||
|
|
||||||
stack-utils@^2.0.2:
|
stack-utils@^2.0.2:
|
||||||
version "2.0.2"
|
version "2.0.3"
|
||||||
resolved "https://registry.yarnpkg.com/stack-utils/-/stack-utils-2.0.2.tgz#5cf48b4557becb4638d0bc4f21d23f5d19586593"
|
resolved "https://registry.yarnpkg.com/stack-utils/-/stack-utils-2.0.3.tgz#cd5f030126ff116b78ccb3c027fe302713b61277"
|
||||||
integrity sha512-0H7QK2ECz3fyZMzQ8rH0j2ykpfbnd20BFtfg/SqVC2+sCTtcw0aDTGB7dk+de4U4uUeuz6nOtJcrkFFLG1B0Rg==
|
integrity sha512-gL//fkxfWUsIlFL2Tl42Cl6+HFALEaB1FU76I/Fy+oZjRreP7OPMXFlGbxM7NQsI0ZpUfw76sHnv0WNYuTb7Iw==
|
||||||
dependencies:
|
dependencies:
|
||||||
escape-string-regexp "^2.0.0"
|
escape-string-regexp "^2.0.0"
|
||||||
|
|
||||||
@@ -3311,28 +4042,33 @@ static-extend@^0.1.1:
|
|||||||
define-property "^0.2.5"
|
define-property "^0.2.5"
|
||||||
object-copy "^0.1.0"
|
object-copy "^0.1.0"
|
||||||
|
|
||||||
stealthy-require@^1.1.1:
|
"statuses@>= 1.5.0 < 2":
|
||||||
version "1.1.1"
|
version "1.5.0"
|
||||||
resolved "https://registry.yarnpkg.com/stealthy-require/-/stealthy-require-1.1.1.tgz#35b09875b4ff49f26a777e509b3090a3226bf24b"
|
resolved "https://registry.yarnpkg.com/statuses/-/statuses-1.5.0.tgz#161c7dac177659fd9811f43771fa99381478628c"
|
||||||
integrity sha1-NbCYdbT/SfJqd35QmzCQoyJr8ks=
|
integrity sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=
|
||||||
|
|
||||||
string-length@^4.0.1:
|
string-length@^4.0.1:
|
||||||
version "4.0.1"
|
version "4.0.2"
|
||||||
resolved "https://registry.yarnpkg.com/string-length/-/string-length-4.0.1.tgz#4a973bf31ef77c4edbceadd6af2611996985f8a1"
|
resolved "https://registry.yarnpkg.com/string-length/-/string-length-4.0.2.tgz#a8a8dc7bd5c1a82b9b3c8b87e125f66871b6e57a"
|
||||||
integrity sha512-PKyXUd0LK0ePjSOnWn34V2uD6acUWev9uy0Ft05k0E8xRW+SKcA0F7eMr7h5xlzfn+4O3N+55rduYyet3Jk+jw==
|
integrity sha512-+l6rNN5fYHNhZZy41RXsYptCjA2Igmq4EG7kZAYFQI1E1VTXarr6ZPXBg6eq7Y6eK4FEhY6AJlyuFIb/v/S0VQ==
|
||||||
dependencies:
|
dependencies:
|
||||||
char-regex "^1.0.2"
|
char-regex "^1.0.2"
|
||||||
strip-ansi "^6.0.0"
|
strip-ansi "^6.0.0"
|
||||||
|
|
||||||
string-width@^4.1.0, string-width@^4.2.0:
|
string-width@^4.1.0, string-width@^4.2.0:
|
||||||
version "4.2.0"
|
version "4.2.2"
|
||||||
resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.0.tgz#952182c46cc7b2c313d1596e623992bd163b72b5"
|
resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.2.tgz#dafd4f9559a7585cfba529c6a0a4f73488ebd4c5"
|
||||||
integrity sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==
|
integrity sha512-XBJbT3N4JhVumXE0eoLU9DCjcaF92KLNqTmFCnG1pf8duUxFGwtP6AD6nkjw9a3IdiRtL3E2w3JDiE/xi3vOeA==
|
||||||
dependencies:
|
dependencies:
|
||||||
emoji-regex "^8.0.0"
|
emoji-regex "^8.0.0"
|
||||||
is-fullwidth-code-point "^3.0.0"
|
is-fullwidth-code-point "^3.0.0"
|
||||||
strip-ansi "^6.0.0"
|
strip-ansi "^6.0.0"
|
||||||
|
|
||||||
|
string_decoder@~0.10.x:
|
||||||
|
version "0.10.31"
|
||||||
|
resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-0.10.31.tgz#62e203bc41766c6c28c9fc84301dab1c5310fa94"
|
||||||
|
integrity sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ=
|
||||||
|
|
||||||
strip-ansi@^6.0.0:
|
strip-ansi@^6.0.0:
|
||||||
version "6.0.0"
|
version "6.0.0"
|
||||||
resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.0.tgz#0b1571dd7669ccd4f3e06e14ef1eed26225ae532"
|
resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.0.tgz#0b1571dd7669ccd4f3e06e14ef1eed26225ae532"
|
||||||
@@ -3363,16 +4099,16 @@ supports-color@^5.3.0:
|
|||||||
has-flag "^3.0.0"
|
has-flag "^3.0.0"
|
||||||
|
|
||||||
supports-color@^7.0.0, supports-color@^7.1.0:
|
supports-color@^7.0.0, supports-color@^7.1.0:
|
||||||
version "7.1.0"
|
version "7.2.0"
|
||||||
resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-7.1.0.tgz#68e32591df73e25ad1c4b49108a2ec507962bfd1"
|
resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-7.2.0.tgz#1b7dcdcb32b8138801b3e478ba6a51caa89648da"
|
||||||
integrity sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==
|
integrity sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==
|
||||||
dependencies:
|
dependencies:
|
||||||
has-flag "^4.0.0"
|
has-flag "^4.0.0"
|
||||||
|
|
||||||
supports-hyperlinks@^2.0.0:
|
supports-hyperlinks@^2.0.0:
|
||||||
version "2.1.0"
|
version "2.2.0"
|
||||||
resolved "https://registry.yarnpkg.com/supports-hyperlinks/-/supports-hyperlinks-2.1.0.tgz#f663df252af5f37c5d49bbd7eeefa9e0b9e59e47"
|
resolved "https://registry.yarnpkg.com/supports-hyperlinks/-/supports-hyperlinks-2.2.0.tgz#4f77b42488765891774b70c79babd87f9bd594bb"
|
||||||
integrity sha512-zoE5/e+dnEijk6ASB6/qrK+oYdm2do1hjoLWrqUC/8WEIW1gbxFcKuBof7sW8ArN6e+AYvsE8HBGiVRWL/F5CA==
|
integrity sha512-6sXEzV5+I5j8Bmq9/vUphGRM/RJNT9SCURJLjwfOg51heRtguGWDzcaBlgAzKhQa0EVNpPEKzQuBwZ8S8WaCeQ==
|
||||||
dependencies:
|
dependencies:
|
||||||
has-flag "^4.0.0"
|
has-flag "^4.0.0"
|
||||||
supports-color "^7.0.0"
|
supports-color "^7.0.0"
|
||||||
@@ -3405,9 +4141,9 @@ throat@^5.0.0:
|
|||||||
integrity sha512-fcwX4mndzpLQKBS1DVYhGAcYaYt7vsHNIvQV+WXMvnow5cgjPphq5CaayLaGsjRdSCKZFNGt7/GYAuXaNOiYCA==
|
integrity sha512-fcwX4mndzpLQKBS1DVYhGAcYaYt7vsHNIvQV+WXMvnow5cgjPphq5CaayLaGsjRdSCKZFNGt7/GYAuXaNOiYCA==
|
||||||
|
|
||||||
tmpl@1.0.x:
|
tmpl@1.0.x:
|
||||||
version "1.0.4"
|
version "1.0.5"
|
||||||
resolved "https://registry.yarnpkg.com/tmpl/-/tmpl-1.0.4.tgz#23640dd7b42d00433911140820e5cf440e521dd1"
|
resolved "https://registry.yarnpkg.com/tmpl/-/tmpl-1.0.5.tgz#8683e0b902bb9c20c4f726e3c0b69f36518c07cc"
|
||||||
integrity sha1-I2QN17QtAEM5ERQIIOXPRA5SHdE=
|
integrity sha512-3f0uOEAQwIqGuWW2MVzYg8fV/QNnc/IpuJNG837rLuczAaLVHslWHZQj4IGiEl5Hs3kkbhwL9Ab7Hrsmuj+Smw==
|
||||||
|
|
||||||
to-fast-properties@^2.0.0:
|
to-fast-properties@^2.0.0:
|
||||||
version "2.0.0"
|
version "2.0.0"
|
||||||
@@ -3446,58 +4182,57 @@ to-regex@^3.0.1, to-regex@^3.0.2:
|
|||||||
regex-not "^1.0.2"
|
regex-not "^1.0.2"
|
||||||
safe-regex "^1.1.0"
|
safe-regex "^1.1.0"
|
||||||
|
|
||||||
tough-cookie@^2.3.3, tough-cookie@~2.5.0:
|
toidentifier@1.0.1:
|
||||||
version "2.5.0"
|
version "1.0.1"
|
||||||
resolved "https://registry.yarnpkg.com/tough-cookie/-/tough-cookie-2.5.0.tgz#cd9fb2a0aa1d5a12b473bd9fb96fa3dcff65ade2"
|
resolved "https://registry.yarnpkg.com/toidentifier/-/toidentifier-1.0.1.tgz#3be34321a88a820ed1bd80dfaa33e479fbb8dd35"
|
||||||
integrity sha512-nlLsUzgm1kfLXSXfRZMc1KLAugd4hqJHDTvc2hDIwS3mZAfMEuMbc03SujMF+GEcpaX/qboeycw6iO8JwVv2+g==
|
integrity sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==
|
||||||
dependencies:
|
|
||||||
psl "^1.1.28"
|
|
||||||
punycode "^2.1.1"
|
|
||||||
|
|
||||||
tough-cookie@^3.0.1:
|
tough-cookie@^4.0.0:
|
||||||
version "3.0.1"
|
version "4.0.0"
|
||||||
resolved "https://registry.yarnpkg.com/tough-cookie/-/tough-cookie-3.0.1.tgz#9df4f57e739c26930a018184887f4adb7dca73b2"
|
resolved "https://registry.yarnpkg.com/tough-cookie/-/tough-cookie-4.0.0.tgz#d822234eeca882f991f0f908824ad2622ddbece4"
|
||||||
integrity sha512-yQyJ0u4pZsv9D4clxO69OEjLWYw+jbgspjTue4lTQZLfV0c5l1VmK2y1JK8E9ahdpltPOaAThPcp5nKPUgSnsg==
|
integrity sha512-tHdtEpQCMrc1YLrMaqXXcj6AxhYi/xgit6mZu1+EDWUn+qhUf8wMQoFIy9NXuq23zAwtcB0t/MjACGR18pcRbg==
|
||||||
dependencies:
|
dependencies:
|
||||||
ip-regex "^2.1.0"
|
psl "^1.1.33"
|
||||||
psl "^1.1.28"
|
|
||||||
punycode "^2.1.1"
|
punycode "^2.1.1"
|
||||||
|
universalify "^0.1.2"
|
||||||
|
|
||||||
tr46@^2.0.2:
|
tr46@^2.1.0:
|
||||||
version "2.0.2"
|
version "2.1.0"
|
||||||
resolved "https://registry.yarnpkg.com/tr46/-/tr46-2.0.2.tgz#03273586def1595ae08fedb38d7733cee91d2479"
|
resolved "https://registry.yarnpkg.com/tr46/-/tr46-2.1.0.tgz#fa87aa81ca5d5941da8cbf1f9b749dc969a4e240"
|
||||||
integrity sha512-3n1qG+/5kg+jrbTzwAykB5yRYtQCTqOGKq5U5PE3b0a1/mzo6snDhjGS0zJVJunO0NrT3Dg1MLy5TjWP/UJppg==
|
integrity sha512-15Ih7phfcdP5YxqiB+iDtLoaTz4Nd35+IiAv0kQ5FNKHzXgdWqPoTIqEDDJmXceQt4JZk6lVPT8lnDlPpGDppw==
|
||||||
dependencies:
|
dependencies:
|
||||||
punycode "^2.1.1"
|
punycode "^2.1.1"
|
||||||
|
|
||||||
ts-jest@^26.1.1:
|
ts-jest@^26.5.6:
|
||||||
version "26.2.0"
|
version "26.5.6"
|
||||||
resolved "https://registry.yarnpkg.com/ts-jest/-/ts-jest-26.2.0.tgz#7ec22faceb05ee1467fdb5265d1b33c27441f163"
|
resolved "https://registry.yarnpkg.com/ts-jest/-/ts-jest-26.5.6.tgz#c32e0746425274e1dfe333f43cd3c800e014ec35"
|
||||||
integrity sha512-9+y2qwzXdAImgLSYLXAb/Rhq9+K4rbt0417b8ai987V60g2uoNWBBmMkYgutI7D8Zhu+IbCSHbBtrHxB9d7xyA==
|
integrity sha512-rua+rCP8DxpA8b4DQD/6X2HQS8Zy/xzViVYfEs2OQu68tkCuKLV0Md8pmX55+W24uRIyAsf/BajRfxOs+R2MKA==
|
||||||
dependencies:
|
dependencies:
|
||||||
"@types/jest" "26.x"
|
|
||||||
bs-logger "0.x"
|
bs-logger "0.x"
|
||||||
buffer-from "1.x"
|
buffer-from "1.x"
|
||||||
fast-json-stable-stringify "2.x"
|
fast-json-stable-stringify "2.x"
|
||||||
jest-util "26.x"
|
jest-util "^26.1.0"
|
||||||
json5 "2.x"
|
json5 "2.x"
|
||||||
lodash.memoize "4.x"
|
lodash "4.x"
|
||||||
make-error "1.x"
|
make-error "1.x"
|
||||||
mkdirp "1.x"
|
mkdirp "1.x"
|
||||||
semver "7.x"
|
semver "7.x"
|
||||||
yargs-parser "18.x"
|
yargs-parser "20.x"
|
||||||
|
|
||||||
tunnel-agent@^0.6.0:
|
tslib@^1.11.1:
|
||||||
version "0.6.0"
|
version "1.14.1"
|
||||||
resolved "https://registry.yarnpkg.com/tunnel-agent/-/tunnel-agent-0.6.0.tgz#27a5dea06b36b04a0a9966774b290868f0fc40fd"
|
resolved "https://registry.yarnpkg.com/tslib/-/tslib-1.14.1.tgz#cf2d38bdc34a134bcaf1091c41f6619e2f672d00"
|
||||||
integrity sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=
|
integrity sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==
|
||||||
dependencies:
|
|
||||||
safe-buffer "^5.0.1"
|
|
||||||
|
|
||||||
tweetnacl@^0.14.3, tweetnacl@~0.14.0:
|
tslib@^2.0.1, tslib@^2.3.0:
|
||||||
version "0.14.5"
|
version "2.3.1"
|
||||||
resolved "https://registry.yarnpkg.com/tweetnacl/-/tweetnacl-0.14.5.tgz#5ae68177f192d4456269d108afa93ff8743f4f64"
|
resolved "https://registry.yarnpkg.com/tslib/-/tslib-2.3.1.tgz#e8a335add5ceae51aa261d32a490158ef042ef01"
|
||||||
integrity sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=
|
integrity sha512-77EbyPPpMz+FRFRuAFlWMtmgUWGe9UOG2Z25NqCwiIjRhOf5iKGuzSe5P2w1laq+FkRy4p+PCuVkJSGkzTEKVw==
|
||||||
|
|
||||||
|
tunnel@0.0.6:
|
||||||
|
version "0.0.6"
|
||||||
|
resolved "https://registry.yarnpkg.com/tunnel/-/tunnel-0.0.6.tgz#72f1314b34a5b192db012324df2cc587ca47f92c"
|
||||||
|
integrity sha512-1h/Lnq9yajKY2PEbBadPXj3VxsDDu844OnaAo52UVmIzIvwwtBPIuNvkjuzBlTWpfJyUbG3ez0KSBibQkj4ojg==
|
||||||
|
|
||||||
type-check@~0.3.2:
|
type-check@~0.3.2:
|
||||||
version "0.3.2"
|
version "0.3.2"
|
||||||
@@ -3511,10 +4246,10 @@ type-detect@4.0.8:
|
|||||||
resolved "https://registry.yarnpkg.com/type-detect/-/type-detect-4.0.8.tgz#7646fb5f18871cfbb7749e69bd39a6388eb7450c"
|
resolved "https://registry.yarnpkg.com/type-detect/-/type-detect-4.0.8.tgz#7646fb5f18871cfbb7749e69bd39a6388eb7450c"
|
||||||
integrity sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==
|
integrity sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==
|
||||||
|
|
||||||
type-fest@^0.11.0:
|
type-fest@^0.21.3:
|
||||||
version "0.11.0"
|
version "0.21.3"
|
||||||
resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.11.0.tgz#97abf0872310fed88a5c466b25681576145e33f1"
|
resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.21.3.tgz#d260a24b0198436e133fa26a524a6d65fa3b2e37"
|
||||||
integrity sha512-OdjXJxnCN1AvyLSzeKIgXTXxV+99ZuXl3Hpo9XpJAv9MBcHrrJOQ5kV7ypXOuQie+AmWG25hLbiKdwYTifzcfQ==
|
integrity sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w==
|
||||||
|
|
||||||
type-fest@^0.6.0:
|
type-fest@^0.6.0:
|
||||||
version "0.6.0"
|
version "0.6.0"
|
||||||
@@ -3541,10 +4276,10 @@ typescript-formatter@^7.2.2:
|
|||||||
commandpost "^1.0.0"
|
commandpost "^1.0.0"
|
||||||
editorconfig "^0.15.0"
|
editorconfig "^0.15.0"
|
||||||
|
|
||||||
typescript@^3.9.5:
|
typescript@^3.9.10:
|
||||||
version "3.9.7"
|
version "3.9.10"
|
||||||
resolved "https://registry.yarnpkg.com/typescript/-/typescript-3.9.7.tgz#98d600a5ebdc38f40cb277522f12dc800e9e25fa"
|
resolved "https://registry.yarnpkg.com/typescript/-/typescript-3.9.10.tgz#70f3910ac7a51ed6bef79da7800690b19bf778b8"
|
||||||
integrity sha512-BLbiRkiBzAwsjut4x/dsibSTB6yWpwT5qWmC2OfuCg3GgVQCSgMs4vEctYPhsaGtd0AeuuHMkjZ2h2WG8MSzRw==
|
integrity sha512-w6fIxVE/H1PkLKcCPsFqKE7Kv7QUwhU8qQY2MueZXWx5cPZdwFupLgKK3vntcK98BtNHZtAF4LA/yl2a7k8R6Q==
|
||||||
|
|
||||||
union-value@^1.0.0:
|
union-value@^1.0.0:
|
||||||
version "1.0.1"
|
version "1.0.1"
|
||||||
@@ -3556,6 +4291,16 @@ union-value@^1.0.0:
|
|||||||
is-extendable "^0.1.1"
|
is-extendable "^0.1.1"
|
||||||
set-value "^2.0.1"
|
set-value "^2.0.1"
|
||||||
|
|
||||||
|
universalify@^0.1.0, universalify@^0.1.2:
|
||||||
|
version "0.1.2"
|
||||||
|
resolved "https://registry.yarnpkg.com/universalify/-/universalify-0.1.2.tgz#b646f69be3942dabcecc9d6639c80dc105efaa66"
|
||||||
|
integrity sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==
|
||||||
|
|
||||||
|
unpipe@1.0.0:
|
||||||
|
version "1.0.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/unpipe/-/unpipe-1.0.0.tgz#b2bf4ee8514aae6165b4817829d21b2ef49904ec"
|
||||||
|
integrity sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=
|
||||||
|
|
||||||
unset-value@^1.0.0:
|
unset-value@^1.0.0:
|
||||||
version "1.0.0"
|
version "1.0.0"
|
||||||
resolved "https://registry.yarnpkg.com/unset-value/-/unset-value-1.0.0.tgz#8376873f7d2335179ffb1e6fc3a8ed0dfc8ab559"
|
resolved "https://registry.yarnpkg.com/unset-value/-/unset-value-1.0.0.tgz#8376873f7d2335179ffb1e6fc3a8ed0dfc8ab559"
|
||||||
@@ -3564,13 +4309,6 @@ unset-value@^1.0.0:
|
|||||||
has-value "^0.3.1"
|
has-value "^0.3.1"
|
||||||
isobject "^3.0.0"
|
isobject "^3.0.0"
|
||||||
|
|
||||||
uri-js@^4.2.2:
|
|
||||||
version "4.2.2"
|
|
||||||
resolved "https://registry.yarnpkg.com/uri-js/-/uri-js-4.2.2.tgz#94c540e1ff772956e2299507c010aea6c8838eb0"
|
|
||||||
integrity sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==
|
|
||||||
dependencies:
|
|
||||||
punycode "^2.1.0"
|
|
||||||
|
|
||||||
urix@^0.1.0:
|
urix@^0.1.0:
|
||||||
version "0.1.0"
|
version "0.1.0"
|
||||||
resolved "https://registry.yarnpkg.com/urix/-/urix-0.1.0.tgz#da937f7a62e21fec1fd18d49b35c2935067a6c72"
|
resolved "https://registry.yarnpkg.com/urix/-/urix-0.1.0.tgz#da937f7a62e21fec1fd18d49b35c2935067a6c72"
|
||||||
@@ -3581,20 +4319,15 @@ use@^3.1.0:
|
|||||||
resolved "https://registry.yarnpkg.com/use/-/use-3.1.1.tgz#d50c8cac79a19fbc20f2911f56eb973f4e10070f"
|
resolved "https://registry.yarnpkg.com/use/-/use-3.1.1.tgz#d50c8cac79a19fbc20f2911f56eb973f4e10070f"
|
||||||
integrity sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ==
|
integrity sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ==
|
||||||
|
|
||||||
uuid@^3.3.2:
|
uuid@^8.3.0, uuid@^8.3.2:
|
||||||
version "3.4.0"
|
version "8.3.2"
|
||||||
resolved "https://registry.yarnpkg.com/uuid/-/uuid-3.4.0.tgz#b23e4358afa8a202fe7a100af1f5f883f02007ee"
|
resolved "https://registry.yarnpkg.com/uuid/-/uuid-8.3.2.tgz#80d5b5ced271bb9af6c445f21a1a04c606cefbe2"
|
||||||
integrity sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==
|
integrity sha512-+NYs2QeMWy+GWFOEm9xnn6HCDp0l7QBD7ml8zLUmJ+93Q5NF0NocErnwkTkXVFNiX3/fpC6afS8Dhb/gz7R7eg==
|
||||||
|
|
||||||
uuid@^8.3.0:
|
v8-to-istanbul@^7.0.0:
|
||||||
version "8.3.0"
|
version "7.1.2"
|
||||||
resolved "https://registry.yarnpkg.com/uuid/-/uuid-8.3.0.tgz#ab738085ca22dc9a8c92725e459b1d507df5d6ea"
|
resolved "https://registry.yarnpkg.com/v8-to-istanbul/-/v8-to-istanbul-7.1.2.tgz#30898d1a7fa0c84d225a2c1434fb958f290883c1"
|
||||||
integrity sha512-fX6Z5o4m6XsXBdli9g7DtWgAx+osMsRRZFKma1mIUsLCz6vRvv+pz5VNbyu9UEDzpMWulZfvpgb/cmDXVulYFQ==
|
integrity sha512-TxNb7YEUwkLXCQYeudi6lgQ/SZrzNO4kMdlqVxaZPUIUjCv6iSSypUQX70kNBSERpQ8fk48+d61FXk+tgqcWow==
|
||||||
|
|
||||||
v8-to-istanbul@^5.0.1:
|
|
||||||
version "5.0.1"
|
|
||||||
resolved "https://registry.yarnpkg.com/v8-to-istanbul/-/v8-to-istanbul-5.0.1.tgz#0608f5b49a481458625edb058488607f25498ba5"
|
|
||||||
integrity sha512-mbDNjuDajqYe3TXFk5qxcQy8L1msXNE37WTlLoqqpBfRsimbNcrlhQlDPntmECEcUvdC+AQ8CyMMf6EUx1r74Q==
|
|
||||||
dependencies:
|
dependencies:
|
||||||
"@types/istanbul-lib-coverage" "^2.0.1"
|
"@types/istanbul-lib-coverage" "^2.0.1"
|
||||||
convert-source-map "^1.6.0"
|
convert-source-map "^1.6.0"
|
||||||
@@ -3608,14 +4341,13 @@ validate-npm-package-license@^3.0.1:
|
|||||||
spdx-correct "^3.0.0"
|
spdx-correct "^3.0.0"
|
||||||
spdx-expression-parse "^3.0.0"
|
spdx-expression-parse "^3.0.0"
|
||||||
|
|
||||||
verror@1.10.0:
|
vm2@^3.9.3:
|
||||||
version "1.10.0"
|
version "3.9.7"
|
||||||
resolved "https://registry.yarnpkg.com/verror/-/verror-1.10.0.tgz#3a105ca17053af55d6e270c1f8288682e18da400"
|
resolved "https://registry.yarnpkg.com/vm2/-/vm2-3.9.7.tgz#bb87aa677c97c61e23a6cb6547e44e990517a6f6"
|
||||||
integrity sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=
|
integrity sha512-g/GZ7V0Mlmch3eDVOATvAXr1GsJNg6kQ5PjvYy3HbJMCRn5slNbo/u73Uy7r5yUej1cRa3ZjtoVwcWSQuQ/fow==
|
||||||
dependencies:
|
dependencies:
|
||||||
assert-plus "^1.0.0"
|
acorn "^8.7.0"
|
||||||
core-util-is "1.0.2"
|
acorn-walk "^8.2.0"
|
||||||
extsprintf "^1.2.0"
|
|
||||||
|
|
||||||
w3c-hr-time@^1.0.2:
|
w3c-hr-time@^1.0.2:
|
||||||
version "1.0.2"
|
version "1.0.2"
|
||||||
@@ -3660,14 +4392,14 @@ whatwg-mimetype@^2.3.0:
|
|||||||
resolved "https://registry.yarnpkg.com/whatwg-mimetype/-/whatwg-mimetype-2.3.0.tgz#3d4b1e0312d2079879f826aff18dbeeca5960fbf"
|
resolved "https://registry.yarnpkg.com/whatwg-mimetype/-/whatwg-mimetype-2.3.0.tgz#3d4b1e0312d2079879f826aff18dbeeca5960fbf"
|
||||||
integrity sha512-M4yMwr6mAnQz76TbJm914+gPpB/nCwvZbJU28cUD6dR004SAxDLOOSUaB1JDRqLtaOV/vi0IC5lEAGFgrjGv/g==
|
integrity sha512-M4yMwr6mAnQz76TbJm914+gPpB/nCwvZbJU28cUD6dR004SAxDLOOSUaB1JDRqLtaOV/vi0IC5lEAGFgrjGv/g==
|
||||||
|
|
||||||
whatwg-url@^8.0.0:
|
whatwg-url@^8.0.0, whatwg-url@^8.5.0:
|
||||||
version "8.1.0"
|
version "8.7.0"
|
||||||
resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-8.1.0.tgz#c628acdcf45b82274ce7281ee31dd3c839791771"
|
resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-8.7.0.tgz#656a78e510ff8f3937bc0bcbe9f5c0ac35941b77"
|
||||||
integrity sha512-vEIkwNi9Hqt4TV9RdnaBPNt+E2Sgmo3gePebCRgZ1R7g6d23+53zCTnuB0amKI4AXq6VM8jj2DUAa0S1vjJxkw==
|
integrity sha512-gAojqb/m9Q8a5IV96E3fHJM70AzCkgt4uXYX2O7EmuyOnLrViCQlsEBmF9UQIu3/aeAIp2U17rtbpZWNntQqdg==
|
||||||
dependencies:
|
dependencies:
|
||||||
lodash.sortby "^4.7.0"
|
lodash "^4.7.0"
|
||||||
tr46 "^2.0.2"
|
tr46 "^2.1.0"
|
||||||
webidl-conversions "^5.0.0"
|
webidl-conversions "^6.1.0"
|
||||||
|
|
||||||
which-module@^2.0.0:
|
which-module@^2.0.0:
|
||||||
version "2.0.0"
|
version "2.0.0"
|
||||||
@@ -3717,10 +4449,10 @@ write-file-atomic@^3.0.0:
|
|||||||
signal-exit "^3.0.2"
|
signal-exit "^3.0.2"
|
||||||
typedarray-to-buffer "^3.1.5"
|
typedarray-to-buffer "^3.1.5"
|
||||||
|
|
||||||
ws@^7.2.3:
|
ws@^7.4.5:
|
||||||
version "7.3.1"
|
version "7.5.2"
|
||||||
resolved "https://registry.yarnpkg.com/ws/-/ws-7.3.1.tgz#d0547bf67f7ce4f12a72dfe31262c68d7dc551c8"
|
resolved "https://registry.yarnpkg.com/ws/-/ws-7.5.2.tgz#09cc8fea3bec1bc5ed44ef51b42f945be36900f6"
|
||||||
integrity sha512-D3RuNkynyHmEJIpD2qrgVkc9DQ23OrN/moAwZX4L8DfvszsJxpjQuUq3LMx6HoYji9fbIOBY18XWBsAux1ZZUA==
|
integrity sha512-lkF7AWRicoB9mAgjeKbGqVUekLnSNO4VjKVnuPHpQeOxZOErX6BPXwJk70nFslRCEEA8EVW7ZjKwXaP9N+1sKQ==
|
||||||
|
|
||||||
xml-name-validator@^3.0.0:
|
xml-name-validator@^3.0.0:
|
||||||
version "3.0.0"
|
version "3.0.0"
|
||||||
@@ -3732,17 +4464,37 @@ xmlchars@^2.2.0:
|
|||||||
resolved "https://registry.yarnpkg.com/xmlchars/-/xmlchars-2.2.0.tgz#060fe1bcb7f9c76fe2a17db86a9bc3ab894210cb"
|
resolved "https://registry.yarnpkg.com/xmlchars/-/xmlchars-2.2.0.tgz#060fe1bcb7f9c76fe2a17db86a9bc3ab894210cb"
|
||||||
integrity sha512-JZnDKK8B0RCDw84FNdDAIpZK+JuJw+s7Lz8nksI7SIuU3UXJJslUthsi+uWBUYOwPFwW7W7PRLRfUKpxjtjFCw==
|
integrity sha512-JZnDKK8B0RCDw84FNdDAIpZK+JuJw+s7Lz8nksI7SIuU3UXJJslUthsi+uWBUYOwPFwW7W7PRLRfUKpxjtjFCw==
|
||||||
|
|
||||||
|
xregexp@2.0.0:
|
||||||
|
version "2.0.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/xregexp/-/xregexp-2.0.0.tgz#52a63e56ca0b84a7f3a5f3d61872f126ad7a5943"
|
||||||
|
integrity sha1-UqY+VsoLhKfzpfPWGHLxJq16WUM=
|
||||||
|
|
||||||
y18n@^4.0.0:
|
y18n@^4.0.0:
|
||||||
version "4.0.0"
|
version "4.0.3"
|
||||||
resolved "https://registry.yarnpkg.com/y18n/-/y18n-4.0.0.tgz#95ef94f85ecc81d007c264e190a120f0a3c8566b"
|
resolved "https://registry.yarnpkg.com/y18n/-/y18n-4.0.3.tgz#b5f259c82cd6e336921efd7bfd8bf560de9eeedf"
|
||||||
integrity sha512-r9S/ZyXu/Xu9q1tYlpsLIsa3EeLXXk0VwlxqTcFRfg9EhMW+17kbt9G0NrgCmhGb5vT2hyhJZLfDGx+7+5Uj/w==
|
integrity sha512-JKhqTOwSrqNA1NY5lSztJ1GrBiUodLMmIZuLiDaMRJ+itFd+ABVE8XBjOvIWL+rSqNDC74LCSFmlb/U4UZ4hJQ==
|
||||||
|
|
||||||
yallist@^2.1.2:
|
yallist@^2.1.2:
|
||||||
version "2.1.2"
|
version "2.1.2"
|
||||||
resolved "https://registry.yarnpkg.com/yallist/-/yallist-2.1.2.tgz#1c11f9218f076089a47dd512f93c6699a6a81d52"
|
resolved "https://registry.yarnpkg.com/yallist/-/yallist-2.1.2.tgz#1c11f9218f076089a47dd512f93c6699a6a81d52"
|
||||||
integrity sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=
|
integrity sha1-HBH5IY8HYImkfdUS+TxmmaaoHVI=
|
||||||
|
|
||||||
yargs-parser@18.x, yargs-parser@^18.1.2:
|
yallist@^3.0.2:
|
||||||
|
version "3.1.1"
|
||||||
|
resolved "https://registry.yarnpkg.com/yallist/-/yallist-3.1.1.tgz#dbb7daf9bfd8bac9ab45ebf602b8cbad0d5d08fd"
|
||||||
|
integrity sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==
|
||||||
|
|
||||||
|
yallist@^4.0.0:
|
||||||
|
version "4.0.0"
|
||||||
|
resolved "https://registry.yarnpkg.com/yallist/-/yallist-4.0.0.tgz#9bb92790d9c0effec63be73519e11a35019a3a72"
|
||||||
|
integrity sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==
|
||||||
|
|
||||||
|
yargs-parser@20.x:
|
||||||
|
version "20.2.9"
|
||||||
|
resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-20.2.9.tgz#2eb7dc3b0289718fc295f362753845c41a0c94ee"
|
||||||
|
integrity sha512-y11nGElTIV+CT3Zv9t7VKl+Q3hTQoT9a1Qzezhhl6Rp21gJ/IVTW7Z3y9EWXhuUBC2Shnf+DX0antecpAwSP8w==
|
||||||
|
|
||||||
|
yargs-parser@^18.1.2:
|
||||||
version "18.1.3"
|
version "18.1.3"
|
||||||
resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-18.1.3.tgz#be68c4975c6b2abf469236b0c870362fab09a7b0"
|
resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-18.1.3.tgz#be68c4975c6b2abf469236b0c870362fab09a7b0"
|
||||||
integrity sha512-o50j0JeToy/4K6OZcaQmW6lyXXKhq7csREXcDwk2omFPJEwUNOVtJKvmDr9EI1fAJZUyZcRF7kxGBWmRXudrCQ==
|
integrity sha512-o50j0JeToy/4K6OZcaQmW6lyXXKhq7csREXcDwk2omFPJEwUNOVtJKvmDr9EI1fAJZUyZcRF7kxGBWmRXudrCQ==
|
||||||
@@ -3750,7 +4502,7 @@ yargs-parser@18.x, yargs-parser@^18.1.2:
|
|||||||
camelcase "^5.0.0"
|
camelcase "^5.0.0"
|
||||||
decamelize "^1.2.0"
|
decamelize "^1.2.0"
|
||||||
|
|
||||||
yargs@^15.3.1:
|
yargs@^15.4.1:
|
||||||
version "15.4.1"
|
version "15.4.1"
|
||||||
resolved "https://registry.yarnpkg.com/yargs/-/yargs-15.4.1.tgz#0d87a16de01aee9d8bec2bfbf74f67851730f4f8"
|
resolved "https://registry.yarnpkg.com/yargs/-/yargs-15.4.1.tgz#0d87a16de01aee9d8bec2bfbf74f67851730f4f8"
|
||||||
integrity sha512-aePbxDmcYW++PaqBsJ+HYUFwCdv4LVvdnhBy78E57PIor8/OVvhMrADFFEDh8DHDFRv/O9i3lPhsENjO7QX0+A==
|
integrity sha512-aePbxDmcYW++PaqBsJ+HYUFwCdv4LVvdnhBy78E57PIor8/OVvhMrADFFEDh8DHDFRv/O9i3lPhsENjO7QX0+A==
|
||||||
|
|||||||
Reference in New Issue
Block a user