From 99fb567ccc00aa150bbcb2f5966f71085be892a1 Mon Sep 17 00:00:00 2001 From: argaen Date: Tue, 27 Jun 2023 17:22:11 +0800 Subject: [PATCH] app.maffin.io initial commit --- .github/dependabot.yml | 12 + .github/workflows/backend-ci.yml | 29 + .github/workflows/frontend-ci.yml | 29 + .gitignore | 49 + .nvmrc | 1 + README.md | 50 + amplify.yml | 23 + amplify/.config/project-config.json | 17 + amplify/backend/api/stocker/cli-inputs.json | 19 + amplify/backend/backend-config.json | 44 + .../function/stockerlambda/amplify.state | 6 + .../stockerlambda/custom-policies.json | 6 + .../stockerlambda/function-parameters.json | 3 + .../backend/function/stockerlambda/src/app.js | 67 + .../function/stockerlambda/src/errors.js | 12 + .../function/stockerlambda/src/event.json | 7 + .../function/stockerlambda/src/helpers.js | 12 + .../stockerlambda/src/helpers.test.js | 22 + .../function/stockerlambda/src/index.js | 9 + .../function/stockerlambda/src/local.js | 5 + .../function/stockerlambda/src/package.json | 26 + .../function/stockerlambda/src/yahoo.js | 73 + .../function/stockerlambda/src/yahoo.test.js | 179 + .../function/stockerlambda/src/yarn.lock | 3179 ++++++ ...stockerlambda-cloudformation-template.json | 202 + .../function/stockerlambda/tsconfig.json | 17 + amplify/backend/tags.json | 10 + .../amplify-dependent-resources-ref.d.ts | 18 + amplify/cli.json | 56 + amplify/hooks/README.md | 7 + amplify/team-provider-info.json | 23 + jest.config.mjs | 34 + next-env.d.ts | 5 + next.config.js | 57 + package.json | 145 + postcss.config.js | 6 + public/favicon/apple-touch-icon.png | Bin 0 -> 26919 bytes public/favicon/favicon-16x16.png | Bin 0 -> 835 bytes public/favicon/favicon-32x32.png | Bin 0 -> 2369 bytes src/__tests__/apis/BookStorage.test.ts | 304 + .../__snapshots__/layout.test.tsx.snap | 44 + .../[guid]/__snapshots__/page.test.tsx.snap | 295 + .../dashboard/accounts/[guid]/page.test.tsx | 103 + .../accounts/__snapshots__/page.test.tsx.snap | 45 + .../app/dashboard/accounts/page.test.tsx | 24 + .../__snapshots__/page.test.tsx.snap | 346 + .../app/dashboard/investments/page.test.tsx | 144 + src/__tests__/app/dashboard/layout.test.tsx | 99 + .../user/__snapshots__/layout.test.tsx.snap | 41 + src/__tests__/app/user/layout.test.tsx | 17 + .../login/__snapshots__/layout.test.tsx.snap | 19 + .../login/__snapshots__/page.test.tsx.snap | 12 + src/__tests__/app/user/login/layout.test.tsx | 40 + src/__tests__/app/user/login/page.test.tsx | 70 + .../logout/__snapshots__/page.test.tsx.snap | 20 + src/__tests__/app/user/logout/page.test.tsx | 18 + .../components/AccountSelector.test.tsx | 203 + .../components/AccountsTable.test.tsx | 195 + .../components/AddTransactionButton.test.tsx | 93 + src/__tests__/components/SaveButton.test.tsx | 77 + src/__tests__/components/Table.test.tsx | 135 + .../components/TransactionsTable.test.tsx | 137 + .../AccountSelector.test.tsx.snap | 101 + .../__snapshots__/AccountsTable.test.tsx.snap | 51 + .../AddTransactionButton.test.tsx.snap | 28 + .../__snapshots__/SaveButton.test.tsx.snap | 51 + .../__snapshots__/Table.test.tsx.snap | 205 + .../TransactionsTable.test.tsx.snap | 254 + .../equities/StatisticsWidget.test.tsx | 43 + .../StatisticsWidget.test.tsx.snap | 45 + .../forms/transaction/AmountField.test.tsx | 185 + .../forms/transaction/SplitField.test.tsx | 410 + .../transaction/TransactionForm.test.tsx | 430 + .../__snapshots__/AmountField.test.tsx.snap | 67 + .../__snapshots__/SplitField.test.tsx.snap | 317 + .../TransactionForm.test.tsx.snap | 216 + src/__tests__/helpers/currency.test.ts | 35 + src/__tests__/helpers/number.test.ts | 45 + src/__tests__/hooks/useBookStorage.test.ts | 40 + src/__tests__/hooks/useDataSource.test.ts | 69 + src/__tests__/hooks/useGapiClient.test.ts | 96 + src/__tests__/hooks/useUser.test.tsx | 125 + src/__tests__/layout/Footer.test.tsx | 12 + src/__tests__/layout/LeftSideBar.test.tsx | 19 + src/__tests__/layout/Topbar.test.tsx | 54 + .../layout/__snapshots__/Footer.test.tsx.snap | 14 + .../__snapshots__/LeftSideBar.test.tsx.snap | 145 + .../layout/__snapshots__/Topbar.test.tsx.snap | 45 + src/apis/BookStorage.ts | 148 + src/apis/Stocker.ts | 31 + src/app/dashboard/accounts/[guid]/page.tsx | 79 + src/app/dashboard/accounts/page.tsx | 31 + src/app/dashboard/investments/page.tsx | 147 + src/app/dashboard/layout.tsx | 29 + src/app/layout.tsx | 40 + src/app/page.tsx | 5 + src/app/user/layout.tsx | 33 + src/app/user/login/layout.tsx | 44 + src/app/user/login/page.tsx | 42 + src/app/user/logout/page.tsx | 22 + src/assets/fonts/Nunito-Bold.eot | Bin 0 -> 116020 bytes src/assets/fonts/Nunito-Bold.svg | 5009 +++++++++ src/assets/fonts/Nunito-Bold.ttf | Bin 0 -> 115852 bytes src/assets/fonts/Nunito-Bold.woff | Bin 0 -> 51940 bytes src/assets/fonts/Nunito-Light.eot | Bin 0 -> 127225 bytes src/assets/fonts/Nunito-Light.svg | 5431 ++++++++++ src/assets/fonts/Nunito-Light.ttf | Bin 0 -> 134148 bytes src/assets/fonts/Nunito-Light.woff | Bin 0 -> 59220 bytes src/assets/fonts/Nunito-Light.woff2 | Bin 0 -> 42320 bytes src/assets/fonts/Nunito-Regular.eot | Bin 0 -> 114012 bytes src/assets/fonts/Nunito-Regular.svg | 4996 +++++++++ src/assets/fonts/Nunito-Regular.ttf | Bin 0 -> 113832 bytes src/assets/fonts/Nunito-Regular.woff | Bin 0 -> 50968 bytes src/assets/fonts/Nunito-SemiBold.eot | Bin 0 -> 116168 bytes src/assets/fonts/Nunito-SemiBold.svg | 5001 +++++++++ src/assets/fonts/Nunito-SemiBold.ttf | Bin 0 -> 115968 bytes src/assets/fonts/Nunito-SemiBold.woff | Bin 0 -> 51528 bytes src/assets/fonts/dripicons-v2.eot | Bin 0 -> 40522 bytes src/assets/fonts/dripicons-v2.svg | 210 + src/assets/fonts/dripicons-v2.ttf | Bin 0 -> 40348 bytes src/assets/fonts/dripicons-v2.woff | Bin 0 -> 26004 bytes .../fonts/materialdesignicons-webfont.eot | Bin 0 -> 1005160 bytes .../fonts/materialdesignicons-webfont.ttf | Bin 0 -> 1004940 bytes .../fonts/materialdesignicons-webfont.woff | Bin 0 -> 456532 bytes .../fonts/materialdesignicons-webfont.woff2 | Bin 0 -> 319984 bytes src/assets/fonts/unicons.eot | Bin 0 -> 403744 bytes src/assets/fonts/unicons.svg | 2148 ++++ src/assets/fonts/unicons.ttf | Bin 0 -> 403580 bytes src/assets/fonts/unicons.woff | Bin 0 -> 203748 bytes src/assets/fonts/unicons.woff2 | Bin 0 -> 147808 bytes src/assets/images/maffin_logo_sm.png | Bin 0 -> 34557 bytes src/aws-exports.ts | 16 + src/book/Money.ts | 173 + src/book/__tests__/Money.test.ts | 170 + src/book/__tests__/datasource.test.ts | 82 + src/book/__tests__/entities/Account.test.ts | 239 + src/book/__tests__/entities/Book.test.ts | 54 + src/book/__tests__/entities/Commodity.test.ts | 68 + src/book/__tests__/entities/Price.test.ts | 97 + src/book/__tests__/entities/Split.test.ts | 90 + .../__tests__/entities/Transaction.test.ts | 84 + .../__tests__/entities/transformers.test.ts | 33 + .../models/InvestmentAccount.test.ts | 1094 ++ src/book/__tests__/prices/PriceDB.test.ts | 426 + src/book/__tests__/prices/PriceDBMap.test.ts | 162 + .../queries/getAccountsWithPath.test.ts | 94 + .../__tests__/queries/getInvestments.test.ts | 115 + .../__tests__/queries/getMainCurrency.test.ts | 108 + src/book/datasource.ts | 59 + src/book/entities/Account.ts | 113 + src/book/entities/Book.ts | 35 + src/book/entities/Commodity.ts | 62 + src/book/entities/Price.ts | 96 + src/book/entities/Split.ts | 125 + src/book/entities/Transaction.ts | 67 + src/book/entities/index.ts | 6 + src/book/entities/transformers.ts | 26 + src/book/helpers/currencyToSymbol.ts | 12 + src/book/helpers/index.ts | 1 + src/book/models/InvestmentAccount.ts | 303 + src/book/models/index.ts | 1 + src/book/prices/PriceDB.ts | 192 + src/book/prices/PriceDBMap.ts | 75 + src/book/prices/index.ts | 2 + src/book/queries/getAccountsWithPath.ts | 45 + src/book/queries/getInvestments.ts | 47 + src/book/queries/getMainCurrency.ts | 32 + src/book/queries/index.ts | 3 + src/book/types/index.d.ts | 6 + src/components/AccountSelector.tsx | 108 + src/components/AccountsTable.tsx | 162 + src/components/AddTransactionButton.tsx | 49 + src/components/Modal.tsx | 42 + src/components/Pagination.tsx | 107 + src/components/ProfileDropdown.tsx | 98 + src/components/SaveButton.tsx | 34 + src/components/Table.tsx | 133 + src/components/Tooltip.tsx | 26 + src/components/TransactionsTable.tsx | 184 + src/components/equities/DividendChart.tsx | 310 + src/components/equities/InvestmentsTable.tsx | 182 + src/components/equities/StatisticsWidget.tsx | 28 + src/components/equities/WeightsChart.tsx | 161 + .../forms/transaction/AmountField.tsx | 50 + .../forms/transaction/SplitField.tsx | 136 + .../forms/transaction/TransactionForm.tsx | 228 + src/components/forms/transaction/types.d.ts | 15 + src/css/globals.css | 42 + src/helpers/currency.ts | 23 + src/helpers/number.ts | 37 + src/hooks/index.ts | 4 + src/hooks/useBookStorage.ts | 8 + src/hooks/useDataSource.ts | 47 + src/hooks/useGapiClient.ts | 56 + src/hooks/useUser.ts | 52 + src/layout/Footer.tsx | 14 + src/layout/LeftSidebar.tsx | 23 + src/layout/Menu.tsx | 66 + src/layout/Topbar.tsx | 40 + src/setupTests.ts | 5 + src/types/images.d.ts | 2 + src/types/react-table.config.d.ts | 120 + src/types/user.d.ts | 5 + tailwind.config.js | 37 + tsconfig.json | 49 + yarn.lock | 9374 +++++++++++++++++ 206 files changed, 49958 insertions(+) create mode 100644 .github/dependabot.yml create mode 100644 .github/workflows/backend-ci.yml create mode 100644 .github/workflows/frontend-ci.yml create mode 100644 .gitignore create mode 100644 .nvmrc create mode 100644 README.md create mode 100644 amplify.yml create mode 100644 amplify/.config/project-config.json create mode 100644 amplify/backend/api/stocker/cli-inputs.json create mode 100644 amplify/backend/backend-config.json create mode 100644 amplify/backend/function/stockerlambda/amplify.state create mode 100644 amplify/backend/function/stockerlambda/custom-policies.json create mode 100644 amplify/backend/function/stockerlambda/function-parameters.json create mode 100644 amplify/backend/function/stockerlambda/src/app.js create mode 100644 amplify/backend/function/stockerlambda/src/errors.js create mode 100644 amplify/backend/function/stockerlambda/src/event.json create mode 100644 amplify/backend/function/stockerlambda/src/helpers.js create mode 100644 amplify/backend/function/stockerlambda/src/helpers.test.js create mode 100644 amplify/backend/function/stockerlambda/src/index.js create mode 100644 amplify/backend/function/stockerlambda/src/local.js create mode 100644 amplify/backend/function/stockerlambda/src/package.json create mode 100644 amplify/backend/function/stockerlambda/src/yahoo.js create mode 100644 amplify/backend/function/stockerlambda/src/yahoo.test.js create mode 100644 amplify/backend/function/stockerlambda/src/yarn.lock create mode 100644 amplify/backend/function/stockerlambda/stockerlambda-cloudformation-template.json create mode 100644 amplify/backend/function/stockerlambda/tsconfig.json create mode 100644 amplify/backend/tags.json create mode 100644 amplify/backend/types/amplify-dependent-resources-ref.d.ts create mode 100644 amplify/cli.json create mode 100644 amplify/hooks/README.md create mode 100644 amplify/team-provider-info.json create mode 100644 jest.config.mjs create mode 100644 next-env.d.ts create mode 100644 next.config.js create mode 100644 package.json create mode 100644 postcss.config.js create mode 100644 public/favicon/apple-touch-icon.png create mode 100644 public/favicon/favicon-16x16.png create mode 100644 public/favicon/favicon-32x32.png create mode 100644 src/__tests__/apis/BookStorage.test.ts create mode 100644 src/__tests__/app/dashboard/__snapshots__/layout.test.tsx.snap create mode 100644 src/__tests__/app/dashboard/accounts/[guid]/__snapshots__/page.test.tsx.snap create mode 100644 src/__tests__/app/dashboard/accounts/[guid]/page.test.tsx create mode 100644 src/__tests__/app/dashboard/accounts/__snapshots__/page.test.tsx.snap create mode 100644 src/__tests__/app/dashboard/accounts/page.test.tsx create mode 100644 src/__tests__/app/dashboard/investments/__snapshots__/page.test.tsx.snap create mode 100644 src/__tests__/app/dashboard/investments/page.test.tsx create mode 100644 src/__tests__/app/dashboard/layout.test.tsx create mode 100644 src/__tests__/app/user/__snapshots__/layout.test.tsx.snap create mode 100644 src/__tests__/app/user/layout.test.tsx create mode 100644 src/__tests__/app/user/login/__snapshots__/layout.test.tsx.snap create mode 100644 src/__tests__/app/user/login/__snapshots__/page.test.tsx.snap create mode 100644 src/__tests__/app/user/login/layout.test.tsx create mode 100644 src/__tests__/app/user/login/page.test.tsx create mode 100644 src/__tests__/app/user/logout/__snapshots__/page.test.tsx.snap create mode 100644 src/__tests__/app/user/logout/page.test.tsx create mode 100644 src/__tests__/components/AccountSelector.test.tsx create mode 100644 src/__tests__/components/AccountsTable.test.tsx create mode 100644 src/__tests__/components/AddTransactionButton.test.tsx create mode 100644 src/__tests__/components/SaveButton.test.tsx create mode 100644 src/__tests__/components/Table.test.tsx create mode 100644 src/__tests__/components/TransactionsTable.test.tsx create mode 100644 src/__tests__/components/__snapshots__/AccountSelector.test.tsx.snap create mode 100644 src/__tests__/components/__snapshots__/AccountsTable.test.tsx.snap create mode 100644 src/__tests__/components/__snapshots__/AddTransactionButton.test.tsx.snap create mode 100644 src/__tests__/components/__snapshots__/SaveButton.test.tsx.snap create mode 100644 src/__tests__/components/__snapshots__/Table.test.tsx.snap create mode 100644 src/__tests__/components/__snapshots__/TransactionsTable.test.tsx.snap create mode 100644 src/__tests__/components/equities/StatisticsWidget.test.tsx create mode 100644 src/__tests__/components/equities/__snapshots__/StatisticsWidget.test.tsx.snap create mode 100644 src/__tests__/components/forms/transaction/AmountField.test.tsx create mode 100644 src/__tests__/components/forms/transaction/SplitField.test.tsx create mode 100644 src/__tests__/components/forms/transaction/TransactionForm.test.tsx create mode 100644 src/__tests__/components/forms/transaction/__snapshots__/AmountField.test.tsx.snap create mode 100644 src/__tests__/components/forms/transaction/__snapshots__/SplitField.test.tsx.snap create mode 100644 src/__tests__/components/forms/transaction/__snapshots__/TransactionForm.test.tsx.snap create mode 100644 src/__tests__/helpers/currency.test.ts create mode 100644 src/__tests__/helpers/number.test.ts create mode 100644 src/__tests__/hooks/useBookStorage.test.ts create mode 100644 src/__tests__/hooks/useDataSource.test.ts create mode 100644 src/__tests__/hooks/useGapiClient.test.ts create mode 100644 src/__tests__/hooks/useUser.test.tsx create mode 100644 src/__tests__/layout/Footer.test.tsx create mode 100644 src/__tests__/layout/LeftSideBar.test.tsx create mode 100644 src/__tests__/layout/Topbar.test.tsx create mode 100644 src/__tests__/layout/__snapshots__/Footer.test.tsx.snap create mode 100644 src/__tests__/layout/__snapshots__/LeftSideBar.test.tsx.snap create mode 100644 src/__tests__/layout/__snapshots__/Topbar.test.tsx.snap create mode 100644 src/apis/BookStorage.ts create mode 100644 src/apis/Stocker.ts create mode 100644 src/app/dashboard/accounts/[guid]/page.tsx create mode 100644 src/app/dashboard/accounts/page.tsx create mode 100644 src/app/dashboard/investments/page.tsx create mode 100644 src/app/dashboard/layout.tsx create mode 100644 src/app/layout.tsx create mode 100644 src/app/page.tsx create mode 100644 src/app/user/layout.tsx create mode 100644 src/app/user/login/layout.tsx create mode 100644 src/app/user/login/page.tsx create mode 100644 src/app/user/logout/page.tsx create mode 100644 src/assets/fonts/Nunito-Bold.eot create mode 100644 src/assets/fonts/Nunito-Bold.svg create mode 100644 src/assets/fonts/Nunito-Bold.ttf create mode 100644 src/assets/fonts/Nunito-Bold.woff create mode 100644 src/assets/fonts/Nunito-Light.eot create mode 100644 src/assets/fonts/Nunito-Light.svg create mode 100644 src/assets/fonts/Nunito-Light.ttf create mode 100644 src/assets/fonts/Nunito-Light.woff create mode 100644 src/assets/fonts/Nunito-Light.woff2 create mode 100644 src/assets/fonts/Nunito-Regular.eot create mode 100644 src/assets/fonts/Nunito-Regular.svg create mode 100644 src/assets/fonts/Nunito-Regular.ttf create mode 100644 src/assets/fonts/Nunito-Regular.woff create mode 100644 src/assets/fonts/Nunito-SemiBold.eot create mode 100644 src/assets/fonts/Nunito-SemiBold.svg create mode 100644 src/assets/fonts/Nunito-SemiBold.ttf create mode 100644 src/assets/fonts/Nunito-SemiBold.woff create mode 100644 src/assets/fonts/dripicons-v2.eot create mode 100644 src/assets/fonts/dripicons-v2.svg create mode 100644 src/assets/fonts/dripicons-v2.ttf create mode 100644 src/assets/fonts/dripicons-v2.woff create mode 100644 src/assets/fonts/materialdesignicons-webfont.eot create mode 100644 src/assets/fonts/materialdesignicons-webfont.ttf create mode 100644 src/assets/fonts/materialdesignicons-webfont.woff create mode 100644 src/assets/fonts/materialdesignicons-webfont.woff2 create mode 100644 src/assets/fonts/unicons.eot create mode 100644 src/assets/fonts/unicons.svg create mode 100644 src/assets/fonts/unicons.ttf create mode 100644 src/assets/fonts/unicons.woff create mode 100644 src/assets/fonts/unicons.woff2 create mode 100644 src/assets/images/maffin_logo_sm.png create mode 100644 src/aws-exports.ts create mode 100644 src/book/Money.ts create mode 100644 src/book/__tests__/Money.test.ts create mode 100644 src/book/__tests__/datasource.test.ts create mode 100644 src/book/__tests__/entities/Account.test.ts create mode 100644 src/book/__tests__/entities/Book.test.ts create mode 100644 src/book/__tests__/entities/Commodity.test.ts create mode 100644 src/book/__tests__/entities/Price.test.ts create mode 100644 src/book/__tests__/entities/Split.test.ts create mode 100644 src/book/__tests__/entities/Transaction.test.ts create mode 100644 src/book/__tests__/entities/transformers.test.ts create mode 100644 src/book/__tests__/models/InvestmentAccount.test.ts create mode 100644 src/book/__tests__/prices/PriceDB.test.ts create mode 100644 src/book/__tests__/prices/PriceDBMap.test.ts create mode 100644 src/book/__tests__/queries/getAccountsWithPath.test.ts create mode 100644 src/book/__tests__/queries/getInvestments.test.ts create mode 100644 src/book/__tests__/queries/getMainCurrency.test.ts create mode 100644 src/book/datasource.ts create mode 100644 src/book/entities/Account.ts create mode 100644 src/book/entities/Book.ts create mode 100644 src/book/entities/Commodity.ts create mode 100644 src/book/entities/Price.ts create mode 100644 src/book/entities/Split.ts create mode 100644 src/book/entities/Transaction.ts create mode 100644 src/book/entities/index.ts create mode 100644 src/book/entities/transformers.ts create mode 100644 src/book/helpers/currencyToSymbol.ts create mode 100644 src/book/helpers/index.ts create mode 100644 src/book/models/InvestmentAccount.ts create mode 100644 src/book/models/index.ts create mode 100644 src/book/prices/PriceDB.ts create mode 100644 src/book/prices/PriceDBMap.ts create mode 100644 src/book/prices/index.ts create mode 100644 src/book/queries/getAccountsWithPath.ts create mode 100644 src/book/queries/getInvestments.ts create mode 100644 src/book/queries/getMainCurrency.ts create mode 100644 src/book/queries/index.ts create mode 100644 src/book/types/index.d.ts create mode 100644 src/components/AccountSelector.tsx create mode 100644 src/components/AccountsTable.tsx create mode 100644 src/components/AddTransactionButton.tsx create mode 100644 src/components/Modal.tsx create mode 100644 src/components/Pagination.tsx create mode 100644 src/components/ProfileDropdown.tsx create mode 100644 src/components/SaveButton.tsx create mode 100644 src/components/Table.tsx create mode 100644 src/components/Tooltip.tsx create mode 100644 src/components/TransactionsTable.tsx create mode 100644 src/components/equities/DividendChart.tsx create mode 100644 src/components/equities/InvestmentsTable.tsx create mode 100644 src/components/equities/StatisticsWidget.tsx create mode 100644 src/components/equities/WeightsChart.tsx create mode 100644 src/components/forms/transaction/AmountField.tsx create mode 100644 src/components/forms/transaction/SplitField.tsx create mode 100644 src/components/forms/transaction/TransactionForm.tsx create mode 100644 src/components/forms/transaction/types.d.ts create mode 100644 src/css/globals.css create mode 100644 src/helpers/currency.ts create mode 100644 src/helpers/number.ts create mode 100644 src/hooks/index.ts create mode 100644 src/hooks/useBookStorage.ts create mode 100644 src/hooks/useDataSource.ts create mode 100644 src/hooks/useGapiClient.ts create mode 100644 src/hooks/useUser.ts create mode 100644 src/layout/Footer.tsx create mode 100644 src/layout/LeftSidebar.tsx create mode 100644 src/layout/Menu.tsx create mode 100644 src/layout/Topbar.tsx create mode 100644 src/setupTests.ts create mode 100644 src/types/images.d.ts create mode 100644 src/types/react-table.config.d.ts create mode 100644 src/types/user.d.ts create mode 100644 tailwind.config.js create mode 100644 tsconfig.json create mode 100644 yarn.lock diff --git a/.github/dependabot.yml b/.github/dependabot.yml new file mode 100644 index 00000000..01a043d0 --- /dev/null +++ b/.github/dependabot.yml @@ -0,0 +1,12 @@ +# To get started with Dependabot version updates, you'll need to specify which +# package ecosystems to update and where the package manifests are located. +# Please see the documentation for all configuration options: +# https://docs.github.com/github/administering-a-repository/configuration-options-for-dependency-updates + +version: 2 +updates: + - package-ecosystem: "npm" # See documentation for possible values + directory: "/" # Location of package manifests + schedule: + interval: "daily" + open-pull-requests-limit: 20 diff --git a/.github/workflows/backend-ci.yml b/.github/workflows/backend-ci.yml new file mode 100644 index 00000000..8d70ad41 --- /dev/null +++ b/.github/workflows/backend-ci.yml @@ -0,0 +1,29 @@ +name: Backend CI + +on: [push] + +jobs: + build: + + runs-on: ubuntu-latest + + strategy: + matrix: + node-version: [16.17.0] + + steps: + - uses: actions/checkout@v3 + - name: Use Node.js ${{ matrix.node-version }} + uses: actions/setup-node@v3 + with: + node-version: ${{ matrix.node-version }} + cache: 'yarn' + + - name: Install dependencies + run: yarn stocker:install + + - name: Lint + run: yarn stocker:lint + + - name: Test + run: yarn stocker:test diff --git a/.github/workflows/frontend-ci.yml b/.github/workflows/frontend-ci.yml new file mode 100644 index 00000000..c6d7516e --- /dev/null +++ b/.github/workflows/frontend-ci.yml @@ -0,0 +1,29 @@ +name: Frontend CI + +on: [push] + +jobs: + build: + + runs-on: ubuntu-latest + + strategy: + matrix: + node-version: [16.17.0] + + steps: + - uses: actions/checkout@v3 + - name: Use Node.js ${{ matrix.node-version }} + uses: actions/setup-node@v3 + with: + node-version: ${{ matrix.node-version }} + cache: 'yarn' + + - name: Install dependencies + run: yarn + + - name: Build # includes lint + run: yarn maffin:build + + - name: Test + run: yarn maffin:test --coverage diff --git a/.gitignore b/.gitignore new file mode 100644 index 00000000..b7ba459e --- /dev/null +++ b/.gitignore @@ -0,0 +1,49 @@ +# See https://help.github.com/articles/ignoring-files/ for more about ignoring files. + +# dependencies +/node_modules +/.pnp +.pnp.js + +# testing +**/coverage + +# next +.next +.vscode + +# production +/build + +account.gz* + +# misc +.DS_Store +.env.local +.env.development.local +.env.test.local +.env.production.local + +npm-debug.log* +yarn-debug.log* +yarn-error.log* + +#amplify-do-not-edit-begin +amplify/\#current-cloud-backend +amplify/.config/local-* +amplify/logs +amplify/mock-data +amplify/backend/amplify-meta.json +amplify/backend/.temp +build/ +dist/ +node_modules/ +awsconfiguration.json +amplifyconfiguration.json +amplifyconfiguration.dart +amplify-build-config.json +amplify-gradle-config.json +amplifytools.xcconfig +.secret-* +**.sample +#amplify-do-not-edit-end diff --git a/.nvmrc b/.nvmrc new file mode 100644 index 00000000..37e391fe --- /dev/null +++ b/.nvmrc @@ -0,0 +1 @@ +v16.17.0 diff --git a/README.md b/README.md new file mode 100644 index 00000000..77440853 --- /dev/null +++ b/README.md @@ -0,0 +1,50 @@ +# maffin.io + +# Developing + +If you want to add a new user, before starting with the installation you will need few steps: + +1. [new maintainers only] Ask a maintainer for the AWS keys and credentials so you can interact with local amplify cli and access AWS console respectively +2. Add the user gmail account to the google console as a test user (for now) + + +## Installation + +Run `nvm use` to set the correct node version. + +``` +yarn # Install frontend dependencies +yarn stocker:install # Install backend dependencies +``` + +If not installed yet, install amplify cli with `npm install -g @aws-amplify/cli`. Then if it's your first time, you'll have to pull the amplify project: + +> Make sure to select your AWS profile credentials with `export AWS_PROFILE=maffin` + +``` +10:56 $ amplify pull +? Select the authentication method you want to use: AWS access keys +? accessKeyId: ******************** # credentials from maffin account +? secretAccessKey: **************************************** +? region: eu-central-1 +? Which app are you working on? dkycpktllbi8x +Backend environment 'master' found. Initializing... +? Choose your default editor: Vim (via Terminal, macOS only) +? Choose the type of app that you're building javascript +Please tell us about your project +? What javascript framework are you using react +? Source Directory Path: src +? Distribution Directory Path: build +? Build Command: yarn build +? Start Command: yarn start +✖ Failed to sync UI components +? Do you plan on modifying this backend? Yes +``` + +## Running + +Run stocker with `yarn stocker:start` and then the frontend with `yarn maffin:start:`. + +## Deploying + +The project is deployed automatically everytime there is a merge to master using Amplify pipeline. diff --git a/amplify.yml b/amplify.yml new file mode 100644 index 00000000..b705943d --- /dev/null +++ b/amplify.yml @@ -0,0 +1,23 @@ +version: 1 +backend: + phases: + build: + commands: + - '# Execute Amplify CLI with the helper script' + - amplifyPush --simple +frontend: + phases: + preBuild: + commands: + - yarn install + build: + commands: + - rm -rf .next/ + - yarn maffin:build + artifacts: + baseDirectory: .next + files: + - '**/*' + cache: + paths: + - node_modules/**/* diff --git a/amplify/.config/project-config.json b/amplify/.config/project-config.json new file mode 100644 index 00000000..350e5841 --- /dev/null +++ b/amplify/.config/project-config.json @@ -0,0 +1,17 @@ +{ + "providers": [ + "awscloudformation" + ], + "projectName": "maffinapp", + "version": "3.1", + "frontend": "javascript", + "javascript": { + "framework": "react", + "config": { + "SourceDir": "src", + "DistributionDir": "build", + "BuildCommand": "yarn build", + "StartCommand": "yarn maffin:start" + } + } +} \ No newline at end of file diff --git a/amplify/backend/api/stocker/cli-inputs.json b/amplify/backend/api/stocker/cli-inputs.json new file mode 100644 index 00000000..9ed8d3bc --- /dev/null +++ b/amplify/backend/api/stocker/cli-inputs.json @@ -0,0 +1,19 @@ +{ + "version": 1, + "paths": { + "/api/prices/live": { + "name": "/api/prices/live", + "lambdaFunction": "stockerlambda", + "permissions": { + "setting": "open" + } + }, + "/api/funds/{isin}": { + "name": "/api/funds/{isin}", + "lambdaFunction": "stockerlambda", + "permissions": { + "setting": "open" + } + } + } +} \ No newline at end of file diff --git a/amplify/backend/backend-config.json b/amplify/backend/backend-config.json new file mode 100644 index 00000000..85a51950 --- /dev/null +++ b/amplify/backend/backend-config.json @@ -0,0 +1,44 @@ +{ + "api": { + "stocker": { + "dependsOn": [ + { + "attributes": [ + "Name", + "Arn" + ], + "category": "function", + "resourceName": "stockerlambda" + } + ], + "providerPlugin": "awscloudformation", + "service": "API Gateway" + } + }, + "auth": {}, + "function": { + "stockerlambda": { + "build": true, + "providerPlugin": "awscloudformation", + "service": "Lambda" + } + }, + "parameters": { + "AMPLIFY_function_stockerlambda_deploymentBucketName": { + "usedBy": [ + { + "category": "function", + "resourceName": "stockerlambda" + } + ] + }, + "AMPLIFY_function_stockerlambda_s3Key": { + "usedBy": [ + { + "category": "function", + "resourceName": "stockerlambda" + } + ] + } + } +} \ No newline at end of file diff --git a/amplify/backend/function/stockerlambda/amplify.state b/amplify/backend/function/stockerlambda/amplify.state new file mode 100644 index 00000000..2a685b3b --- /dev/null +++ b/amplify/backend/function/stockerlambda/amplify.state @@ -0,0 +1,6 @@ +{ + "pluginId": "amplify-nodejs-function-runtime-provider", + "functionRuntime": "nodejs", + "useLegacyBuild": true, + "defaultEditorFile": "src/app.js" +} \ No newline at end of file diff --git a/amplify/backend/function/stockerlambda/custom-policies.json b/amplify/backend/function/stockerlambda/custom-policies.json new file mode 100644 index 00000000..528c94f2 --- /dev/null +++ b/amplify/backend/function/stockerlambda/custom-policies.json @@ -0,0 +1,6 @@ +[ + { + "Action": [], + "Resource": [] + } +] \ No newline at end of file diff --git a/amplify/backend/function/stockerlambda/function-parameters.json b/amplify/backend/function/stockerlambda/function-parameters.json new file mode 100644 index 00000000..d5078776 --- /dev/null +++ b/amplify/backend/function/stockerlambda/function-parameters.json @@ -0,0 +1,3 @@ +{ + "lambdaLayers": [] +} \ No newline at end of file diff --git a/amplify/backend/function/stockerlambda/src/app.js b/amplify/backend/function/stockerlambda/src/app.js new file mode 100644 index 00000000..2bd25f70 --- /dev/null +++ b/amplify/backend/function/stockerlambda/src/app.js @@ -0,0 +1,67 @@ +const cors = require('cors'); +const express = require('express'); +const bodyParser = require('body-parser'); +const awsServerlessExpressMiddleware = require('aws-serverless-express/middleware'); + +const yahoo = require('./yahoo'); +const helpers = require('./helpers'); + +const app = express() +app.use(bodyParser.json()) +app.use(awsServerlessExpressMiddleware.eventContext()) + + +const ALLOWED_ORIGINS = [ + 'http://localhost:3000', + 'https://app.maffin.io', +]; + +app.use(cors({ + origin: (origin, callback) => { + if ( + ALLOWED_ORIGINS.indexOf(origin) !== -1 + || origin.match(/https:\/\/.*d199ayutgsrlxn\.amplifyapp\.com/g) + ) { + callback(null, true); + } else { + callback(new Error('Not allowed by CORS')); + } + } +})); + +app.get('/api/prices/live', async (req, res) => { + let tickers = req.query.ids; + if (!tickers) { + res.status(400).json({ + error: 'IDS_REQUIRED', + description: 'You need to pass \'ids\' queryparam to select specific quotes', + }); + return; + } + + tickers = tickers.split(','); + + const result = {}; + const promises = []; + + async function callAndSave(ticker) { + price = await yahoo.getLiveSummary(ticker); + result[ticker] = price; + } + + try { + tickers.forEach(ticker => promises.push(callAndSave(ticker))); + await Promise.all(promises); + } catch (error) { + console.log(error); + res.status(500).json({ + error: 'UNKNOWN_ERROR', + description: 'Failed to retrieve prices', + }); + return; + } + + res.json(result); +}); + +module.exports = app; diff --git a/amplify/backend/function/stockerlambda/src/errors.js b/amplify/backend/function/stockerlambda/src/errors.js new file mode 100644 index 00000000..5716320f --- /dev/null +++ b/amplify/backend/function/stockerlambda/src/errors.js @@ -0,0 +1,12 @@ +class HTTPError extends Error { + constructor(message, status, code) { + super(message); + this.message = message; + this.status = status; + this.code = code; + } +} + +module.exports = { + HTTPError, +}; diff --git a/amplify/backend/function/stockerlambda/src/event.json b/amplify/backend/function/stockerlambda/src/event.json new file mode 100644 index 00000000..0f1078aa --- /dev/null +++ b/amplify/backend/function/stockerlambda/src/event.json @@ -0,0 +1,7 @@ +{ + "httpMethod": "GET", + "path": "/api/prices/live", + "queryStringParameters": { + "ids": "IAG.MC,AIR.PA" + } +} diff --git a/amplify/backend/function/stockerlambda/src/helpers.js b/amplify/backend/function/stockerlambda/src/helpers.js new file mode 100644 index 00000000..696249a7 --- /dev/null +++ b/amplify/backend/function/stockerlambda/src/helpers.js @@ -0,0 +1,12 @@ +function getNext12AM() { + now = new Date(); + currentDay = now.getUTCDate(); + now.setUTCDate(currentDay + 1); + now.setUTCHours(0); + now.setUTCMinutes(30); + return now; +} + +module.exports = { + getNext12AM, +}; diff --git a/amplify/backend/function/stockerlambda/src/helpers.test.js b/amplify/backend/function/stockerlambda/src/helpers.test.js new file mode 100644 index 00000000..17bafd9e --- /dev/null +++ b/amplify/backend/function/stockerlambda/src/helpers.test.js @@ -0,0 +1,22 @@ +const { getNext12AM } = require('./helpers'); + +describe('getNext12AM', () => { + afterEach(() => { + jest.restoreAllMocks(); + }); + + it.each([ + [new Date(Date.UTC(2022, 0, 31, 23, 59)), new Date(Date.UTC(2022, 1, 1, 0, 30))], + [new Date(Date.UTC(2022, 1, 1, 0, 0)), new Date(Date.UTC(2022, 1, 2, 0, 30))], + [new Date(Date.UTC(2022, 0, 20, 23, 59)), new Date(Date.UTC(2022, 0, 21, 0, 30))], + [new Date(Date.UTC(2022, 0, 20, 0, 0)), new Date(Date.UTC(2022, 0, 21, 0, 30))], + [new Date(Date.UTC(2022, 0, 20, 0, 1)), new Date(Date.UTC(2022, 0, 21, 0, 30))], + [new Date(Date.UTC(2022, 0, 20, 8, 0)), new Date(Date.UTC(2022, 0, 21, 0, 30))], + ])('returns 12AM of next day', (date, expected) => { + const spy = jest + .spyOn(global, 'Date') + .mockImplementation(() => date); + + expect(getNext12AM()).toEqual(expected); + }); +}); diff --git a/amplify/backend/function/stockerlambda/src/index.js b/amplify/backend/function/stockerlambda/src/index.js new file mode 100644 index 00000000..c0827eb1 --- /dev/null +++ b/amplify/backend/function/stockerlambda/src/index.js @@ -0,0 +1,9 @@ +const awsServerlessExpress = require('aws-serverless-express'); +const app = require('./app'); + +const server = awsServerlessExpress.createServer(app); + +exports.handler = (event, context) => { + console.log(`EVENT: ${JSON.stringify(event)}`); + return awsServerlessExpress.proxy(server, event, context, 'PROMISE').promise; +}; diff --git a/amplify/backend/function/stockerlambda/src/local.js b/amplify/backend/function/stockerlambda/src/local.js new file mode 100644 index 00000000..f7de79fc --- /dev/null +++ b/amplify/backend/function/stockerlambda/src/local.js @@ -0,0 +1,5 @@ +const app = require('./app') +const port = 3001 + +app.listen(port) +console.log(`listening on http://localhost:${port}`) diff --git a/amplify/backend/function/stockerlambda/src/package.json b/amplify/backend/function/stockerlambda/src/package.json new file mode 100644 index 00000000..c8244315 --- /dev/null +++ b/amplify/backend/function/stockerlambda/src/package.json @@ -0,0 +1,26 @@ +{ + "name": "stockerlambda", + "version": "1.0.0", + "description": "", + "main": "index.js", + "dependencies": { + "aws-serverless-express": "^3.3.5", + "axios": "^0.24.0", + "body-parser": "^1.17.1", + "cors": "^2.8.5", + "express": "^4.17.3" + }, + "jest": { + "coverageThreshold": { + "global": { + "branches": 99 + } + } + }, + "author": "", + "license": "ISC", + "devDependencies": { + "eslint": "^8.6.0", + "jest": "^27.4.6" + } +} diff --git a/amplify/backend/function/stockerlambda/src/yahoo.js b/amplify/backend/function/stockerlambda/src/yahoo.js new file mode 100644 index 00000000..93a520d1 --- /dev/null +++ b/amplify/backend/function/stockerlambda/src/yahoo.js @@ -0,0 +1,73 @@ +const axios= require('axios'); + +const { HTTPError } = require('./errors'); + +class YahooError extends HTTPError {} + +const HOST = 'https://query2.finance.yahoo.com'; + +async function getLiveSummary(ticker) { + let resp; + if (ticker === 'SGDCAD=X') { + ticker = 'SGDCAX=X'; + } + try { + resp = await axios.get( + `${HOST}/v10/finance/quoteSummary/${ticker}?modules=price`, + ); + } catch (error) { + throw new YahooError( + `${ticker} failed: error.message`, + error.response.status, + 'UNKNOWN', + ); + } + + const { quoteSummary } = resp.data; + if (quoteSummary.error !== null) { + if (quoteSummary.error.code === 'Not Found') { + throw new YahooError( + `ticker '${ticker}' not found`, + 404, + 'NOT_FOUND', + ); + } + + throw new YahooError( + `unknown error '${quoteSummary.error.description}'`, + resp.status, + 'UNKNOWN', + ); + } + + const priceObj = quoteSummary.result[0].price; + const { currency } = priceObj; + + return { + price: priceObj.regularMarketPrice.raw * toStandardUnit(currency), + currency: toCurrency(currency), + changePct: priceObj.regularMarketChangePercent.raw * 100, + changeAbs: priceObj.regularMarketChange.raw * toStandardUnit(currency), + }; +} + +function toStandardUnit(currency) { + if (currency === 'GBp') { + return 0.01; + } + + return 1; +} + +function toCurrency(currency) { + if (currency === 'GBp') { + return 'GBP'; + } + + return currency; +} + +module.exports = { + getLiveSummary, + YahooError, +}; diff --git a/amplify/backend/function/stockerlambda/src/yahoo.test.js b/amplify/backend/function/stockerlambda/src/yahoo.test.js new file mode 100644 index 00000000..1a72b220 --- /dev/null +++ b/amplify/backend/function/stockerlambda/src/yahoo.test.js @@ -0,0 +1,179 @@ +const axios= require('axios'); + +const yh = require('./yahoo'); + +jest.mock('axios'); + +describe('getLiveSummary', () => { + let mockAxiosGet; + + beforeEach(() => { + mockAxiosGet = jest.spyOn(axios, 'get'); + mockAxiosGet.mockImplementation(() => Promise.resolve({ + data: { + quoteSummary: { + result: [ + { + price: { + regularMarketPrice: { + raw: 10, + }, + regularMarketChangePercent: { + raw: -0.1, + }, + regularMarketChange: { + raw: -1, + }, + currency: 'USD', + }, + }, + ], + error: null, + }, + }, + status: 200, + statusText: 'OK', + })); + }); + + afterEach(() => { + jest.clearAllMocks(); + }); + + it('calls api with ticker', async () => { + await yh.getLiveSummary('ticker'); + + expect(mockAxiosGet).toHaveBeenNthCalledWith( + 1, + 'https://query2.finance.yahoo.com/v10/finance/quoteSummary/ticker?modules=price', + ); + }); + + it('throws error when axios call fails', async () => { + mockAxiosGet.mockRejectedValue({ + message: 'message', + url: 'url', + response: { + status: 500, + }, + }); + + try { + await yh.getLiveSummary('ticker'); + } catch (error) { + expect(error instanceof yh.YahooError).toBe(true); + expect(error.message).toEqual('ticker failed: error.message'); + expect(error.status).toEqual(500); + expect(error.code).toEqual('UNKNOWN'); + } + expect.assertions(4); + }); + + it('fails when no data for stock', async () => { + mockAxiosGet.mockImplementation(() => Promise.resolve({ + data: { + quoteSummary: { + error: { + code: 'Not Found', + }, + }, + }, + status: 404, + })); + + try { + await yh.getLiveSummary('ticker'); + } catch (error) { + expect(error instanceof yh.YahooError).toBe(true); + expect(error.message).toEqual('ticker \'ticker\' not found'); + expect(error.status).toEqual(404); + expect(error.code).toEqual('NOT_FOUND'); + } + expect.assertions(4); + }); + + it('fails when unknown error', async () => { + mockAxiosGet.mockImplementation(() => Promise.resolve({ + data: { + quoteSummary: { + error: { + code: 'Unknown', + description: 'random error', + }, + }, + }, + status: 200, + })); + try { + await yh.getLiveSummary('ticker'); + } catch (error) { + expect(error instanceof yh.YahooError).toBe(true); + expect(error.message).toEqual('unknown error \'random error\''); + expect(error.status).toEqual(200); + expect(error.code).toEqual('UNKNOWN'); + } + expect.assertions(4); + }); + + it('returns price from http request call with correct params', async () => { + const resp = await yh.getLiveSummary('ticker'); + + expect(resp).toEqual({ + price: 10, + currency: 'USD', + changePct: -10, + changeAbs: -1, + }); + }); + + it('returns price *100 from http request call when GBP', async () => { + mockAxiosGet.mockImplementation(() => Promise.resolve({ + data: { + quoteSummary: { + result: [ + { + price: { + regularMarketPrice: { + raw: 10, + }, + regularMarketChangePercent: { + raw: -0.1, + }, + regularMarketChange: { + raw: -1, + }, + currency: 'GBp', + }, + }, + ], + error: null, + }, + }, + status: 200, + })); + const resp = await yh.getLiveSummary('ticker'); + + expect(resp).toEqual({ + price: 0.1, + changePct: -10, + changeAbs: -0.01, + currency: 'GBP', + }); + }); + + it('customises ticker for SGDCAD=X', async () => { + const resp = await yh.getLiveSummary('SGDCAD=X'); + + expect(mockAxiosGet).toHaveBeenNthCalledWith( + 1, + 'https://query2.finance.yahoo.com/v10/finance/quoteSummary/SGDCAX=X?modules=price', + ); + + expect(resp).toEqual({ + price: 10, + currency: 'USD', + changePct: -10, + changeAbs: -1, + }); + }); +}); diff --git a/amplify/backend/function/stockerlambda/src/yarn.lock b/amplify/backend/function/stockerlambda/src/yarn.lock new file mode 100644 index 00000000..4b37bf34 --- /dev/null +++ b/amplify/backend/function/stockerlambda/src/yarn.lock @@ -0,0 +1,3179 @@ +# THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. +# yarn lockfile v1 + + +"@babel/code-frame@^7.12.13", "@babel/code-frame@^7.16.7": + version "7.16.7" + resolved "https://registry.yarnpkg.com/@babel/code-frame/-/code-frame-7.16.7.tgz#44416b6bd7624b998f5b1af5d470856c40138789" + integrity sha512-iAXqUn8IIeBTNd72xsFlgaXHkMBMt6y4HJp1tIaK465CWLT/fG1aqB7ykr95gHHmlBdGbFeWWfyB4NJJ0nmeIg== + dependencies: + "@babel/highlight" "^7.16.7" + +"@babel/compat-data@^7.16.4": + version "7.16.4" + resolved "https://registry.yarnpkg.com/@babel/compat-data/-/compat-data-7.16.4.tgz#081d6bbc336ec5c2435c6346b2ae1fb98b5ac68e" + integrity sha512-1o/jo7D+kC9ZjHX5v+EHrdjl3PhxMrLSOTGsOdHJ+KL8HCaEK6ehrVL2RS6oHDZp+L7xLirLrPmQtEng769J/Q== + +"@babel/core@^7.1.0", "@babel/core@^7.12.3", "@babel/core@^7.7.2", "@babel/core@^7.8.0": + version "7.16.7" + resolved "https://registry.yarnpkg.com/@babel/core/-/core-7.16.7.tgz#db990f931f6d40cb9b87a0dc7d2adc749f1dcbcf" + integrity sha512-aeLaqcqThRNZYmbMqtulsetOQZ/5gbR/dWruUCJcpas4Qoyy+QeagfDsPdMrqwsPRDNxJvBlRiZxxX7THO7qtA== + dependencies: + "@babel/code-frame" "^7.16.7" + "@babel/generator" "^7.16.7" + "@babel/helper-compilation-targets" "^7.16.7" + "@babel/helper-module-transforms" "^7.16.7" + "@babel/helpers" "^7.16.7" + "@babel/parser" "^7.16.7" + "@babel/template" "^7.16.7" + "@babel/traverse" "^7.16.7" + "@babel/types" "^7.16.7" + convert-source-map "^1.7.0" + debug "^4.1.0" + gensync "^1.0.0-beta.2" + json5 "^2.1.2" + semver "^6.3.0" + source-map "^0.5.0" + +"@babel/generator@^7.16.7", "@babel/generator@^7.7.2": + version "7.16.7" + resolved "https://registry.yarnpkg.com/@babel/generator/-/generator-7.16.7.tgz#b42bf46a3079fa65e1544135f32e7958f048adbb" + integrity sha512-/ST3Sg8MLGY5HVYmrjOgL60ENux/HfO/CsUh7y4MalThufhE/Ff/6EibFDHi4jiDCaWfJKoqbE6oTh21c5hrRg== + dependencies: + "@babel/types" "^7.16.7" + jsesc "^2.5.1" + source-map "^0.5.0" + +"@babel/helper-compilation-targets@^7.16.7": + version "7.16.7" + resolved "https://registry.yarnpkg.com/@babel/helper-compilation-targets/-/helper-compilation-targets-7.16.7.tgz#06e66c5f299601e6c7da350049315e83209d551b" + integrity sha512-mGojBwIWcwGD6rfqgRXVlVYmPAv7eOpIemUG3dGnDdCY4Pae70ROij3XmfrH6Fa1h1aiDylpglbZyktfzyo/hA== + dependencies: + "@babel/compat-data" "^7.16.4" + "@babel/helper-validator-option" "^7.16.7" + browserslist "^4.17.5" + semver "^6.3.0" + +"@babel/helper-environment-visitor@^7.16.7": + version "7.16.7" + resolved "https://registry.yarnpkg.com/@babel/helper-environment-visitor/-/helper-environment-visitor-7.16.7.tgz#ff484094a839bde9d89cd63cba017d7aae80ecd7" + integrity sha512-SLLb0AAn6PkUeAfKJCCOl9e1R53pQlGAfc4y4XuMRZfqeMYLE0dM1LMhqbGAlGQY0lfw5/ohoYWAe9V1yibRag== + dependencies: + "@babel/types" "^7.16.7" + +"@babel/helper-function-name@^7.16.7": + version "7.16.7" + resolved "https://registry.yarnpkg.com/@babel/helper-function-name/-/helper-function-name-7.16.7.tgz#f1ec51551fb1c8956bc8dd95f38523b6cf375f8f" + integrity sha512-QfDfEnIUyyBSR3HtrtGECuZ6DAyCkYFp7GHl75vFtTnn6pjKeK0T1DB5lLkFvBea8MdaiUABx3osbgLyInoejA== + dependencies: + "@babel/helper-get-function-arity" "^7.16.7" + "@babel/template" "^7.16.7" + "@babel/types" "^7.16.7" + +"@babel/helper-get-function-arity@^7.16.7": + version "7.16.7" + resolved "https://registry.yarnpkg.com/@babel/helper-get-function-arity/-/helper-get-function-arity-7.16.7.tgz#ea08ac753117a669f1508ba06ebcc49156387419" + integrity sha512-flc+RLSOBXzNzVhcLu6ujeHUrD6tANAOU5ojrRx/as+tbzf8+stUCj7+IfRRoAbEZqj/ahXEMsjhOhgeZsrnTw== + dependencies: + "@babel/types" "^7.16.7" + +"@babel/helper-hoist-variables@^7.16.7": + version "7.16.7" + resolved "https://registry.yarnpkg.com/@babel/helper-hoist-variables/-/helper-hoist-variables-7.16.7.tgz#86bcb19a77a509c7b77d0e22323ef588fa58c246" + integrity sha512-m04d/0Op34H5v7pbZw6pSKP7weA6lsMvfiIAMeIvkY/R4xQtBSMFEigu9QTZ2qB/9l22vsxtM8a+Q8CzD255fg== + dependencies: + "@babel/types" "^7.16.7" + +"@babel/helper-module-imports@^7.16.7": + version "7.16.7" + resolved "https://registry.yarnpkg.com/@babel/helper-module-imports/-/helper-module-imports-7.16.7.tgz#25612a8091a999704461c8a222d0efec5d091437" + integrity sha512-LVtS6TqjJHFc+nYeITRo6VLXve70xmq7wPhWTqDJusJEgGmkAACWwMiTNrvfoQo6hEhFwAIixNkvB0jPXDL8Wg== + dependencies: + "@babel/types" "^7.16.7" + +"@babel/helper-module-transforms@^7.16.7": + version "7.16.7" + resolved "https://registry.yarnpkg.com/@babel/helper-module-transforms/-/helper-module-transforms-7.16.7.tgz#7665faeb721a01ca5327ddc6bba15a5cb34b6a41" + integrity sha512-gaqtLDxJEFCeQbYp9aLAefjhkKdjKcdh6DB7jniIGU3Pz52WAmP268zK0VgPz9hUNkMSYeH976K2/Y6yPadpng== + dependencies: + "@babel/helper-environment-visitor" "^7.16.7" + "@babel/helper-module-imports" "^7.16.7" + "@babel/helper-simple-access" "^7.16.7" + "@babel/helper-split-export-declaration" "^7.16.7" + "@babel/helper-validator-identifier" "^7.16.7" + "@babel/template" "^7.16.7" + "@babel/traverse" "^7.16.7" + "@babel/types" "^7.16.7" + +"@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.16.7", "@babel/helper-plugin-utils@^7.8.0": + version "7.16.7" + resolved "https://registry.yarnpkg.com/@babel/helper-plugin-utils/-/helper-plugin-utils-7.16.7.tgz#aa3a8ab4c3cceff8e65eb9e73d87dc4ff320b2f5" + integrity sha512-Qg3Nk7ZxpgMrsox6HreY1ZNKdBq7K72tDSliA6dCl5f007jR4ne8iD5UzuNnCJH2xBf2BEEVGr+/OL6Gdp7RxA== + +"@babel/helper-simple-access@^7.16.7": + version "7.16.7" + resolved "https://registry.yarnpkg.com/@babel/helper-simple-access/-/helper-simple-access-7.16.7.tgz#d656654b9ea08dbb9659b69d61063ccd343ff0f7" + integrity sha512-ZIzHVyoeLMvXMN/vok/a4LWRy8G2v205mNP0XOuf9XRLyX5/u9CnVulUtDgUTama3lT+bf/UqucuZjqiGuTS1g== + dependencies: + "@babel/types" "^7.16.7" + +"@babel/helper-split-export-declaration@^7.16.7": + version "7.16.7" + resolved "https://registry.yarnpkg.com/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.16.7.tgz#0b648c0c42da9d3920d85ad585f2778620b8726b" + integrity sha512-xbWoy/PFoxSWazIToT9Sif+jJTlrMcndIsaOKvTA6u7QEo7ilkRZpjew18/W3c7nm8fXdUDXh02VXTbZ0pGDNw== + dependencies: + "@babel/types" "^7.16.7" + +"@babel/helper-validator-identifier@^7.16.7": + version "7.16.7" + resolved "https://registry.yarnpkg.com/@babel/helper-validator-identifier/-/helper-validator-identifier-7.16.7.tgz#e8c602438c4a8195751243da9031d1607d247cad" + integrity sha512-hsEnFemeiW4D08A5gUAZxLBTXpZ39P+a+DGDsHw1yxqyQ/jzFEnxf5uTEGp+3bzAbNOxU1paTgYS4ECU/IgfDw== + +"@babel/helper-validator-option@^7.16.7": + version "7.16.7" + resolved "https://registry.yarnpkg.com/@babel/helper-validator-option/-/helper-validator-option-7.16.7.tgz#b203ce62ce5fe153899b617c08957de860de4d23" + integrity sha512-TRtenOuRUVo9oIQGPC5G9DgK4743cdxvtOw0weQNpZXaS16SCBi5MNjZF8vba3ETURjZpTbVn7Vvcf2eAwFozQ== + +"@babel/helpers@^7.16.7": + version "7.16.7" + resolved "https://registry.yarnpkg.com/@babel/helpers/-/helpers-7.16.7.tgz#7e3504d708d50344112767c3542fc5e357fffefc" + integrity sha512-9ZDoqtfY7AuEOt3cxchfii6C7GDyyMBffktR5B2jvWv8u2+efwvpnVKXMWzNehqy68tKgAfSwfdw/lWpthS2bw== + dependencies: + "@babel/template" "^7.16.7" + "@babel/traverse" "^7.16.7" + "@babel/types" "^7.16.7" + +"@babel/highlight@^7.16.7": + version "7.16.7" + resolved "https://registry.yarnpkg.com/@babel/highlight/-/highlight-7.16.7.tgz#81a01d7d675046f0d96f82450d9d9578bdfd6b0b" + integrity sha512-aKpPMfLvGO3Q97V0qhw/V2SWNWlwfJknuwAunU7wZLSfrM4xTBvg7E5opUVi1kJTBKihE38CPg4nBiqX83PWYw== + dependencies: + "@babel/helper-validator-identifier" "^7.16.7" + chalk "^2.0.0" + js-tokens "^4.0.0" + +"@babel/parser@^7.1.0", "@babel/parser@^7.14.7", "@babel/parser@^7.16.7": + version "7.16.7" + resolved "https://registry.yarnpkg.com/@babel/parser/-/parser-7.16.7.tgz#d372dda9c89fcec340a82630a9f533f2fe15877e" + integrity sha512-sR4eaSrnM7BV7QPzGfEX5paG/6wrZM3I0HDzfIAK06ESvo9oy3xBuVBxE3MbQaKNhvg8g/ixjMWo2CGpzpHsDA== + +"@babel/plugin-syntax-async-generators@^7.8.4": + version "7.8.4" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz#a983fb1aeb2ec3f6ed042a210f640e90e786fe0d" + integrity sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-bigint@^7.8.3": + version "7.8.3" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-bigint/-/plugin-syntax-bigint-7.8.3.tgz#4c9a6f669f5d0cdf1b90a1671e9a146be5300cea" + integrity sha512-wnTnFlG+YxQm3vDxpGE57Pj0srRU4sHE/mDkt1qv2YJJSeUAec2ma4WLUnUPeKjyrfntVwe/N6dCXpU+zL3Npg== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-class-properties@^7.8.3": + version "7.12.13" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-class-properties/-/plugin-syntax-class-properties-7.12.13.tgz#b5c987274c4a3a82b89714796931a6b53544ae10" + integrity sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA== + dependencies: + "@babel/helper-plugin-utils" "^7.12.13" + +"@babel/plugin-syntax-import-meta@^7.8.3": + version "7.10.4" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-import-meta/-/plugin-syntax-import-meta-7.10.4.tgz#ee601348c370fa334d2207be158777496521fd51" + integrity sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g== + dependencies: + "@babel/helper-plugin-utils" "^7.10.4" + +"@babel/plugin-syntax-json-strings@^7.8.3": + version "7.8.3" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz#01ca21b668cd8218c9e640cb6dd88c5412b2c96a" + integrity sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-logical-assignment-operators@^7.8.3": + version "7.10.4" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-logical-assignment-operators/-/plugin-syntax-logical-assignment-operators-7.10.4.tgz#ca91ef46303530448b906652bac2e9fe9941f699" + integrity sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig== + dependencies: + "@babel/helper-plugin-utils" "^7.10.4" + +"@babel/plugin-syntax-nullish-coalescing-operator@^7.8.3": + version "7.8.3" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz#167ed70368886081f74b5c36c65a88c03b66d1a9" + integrity sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-numeric-separator@^7.8.3": + version "7.10.4" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.10.4.tgz#b9b070b3e33570cd9fd07ba7fa91c0dd37b9af97" + integrity sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug== + dependencies: + "@babel/helper-plugin-utils" "^7.10.4" + +"@babel/plugin-syntax-object-rest-spread@^7.8.3": + version "7.8.3" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz#60e225edcbd98a640332a2e72dd3e66f1af55871" + integrity sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-optional-catch-binding@^7.8.3": + version "7.8.3" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz#6111a265bcfb020eb9efd0fdfd7d26402b9ed6c1" + integrity sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-optional-chaining@^7.8.3": + version "7.8.3" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz#4f69c2ab95167e0180cd5336613f8c5788f7d48a" + integrity sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg== + dependencies: + "@babel/helper-plugin-utils" "^7.8.0" + +"@babel/plugin-syntax-top-level-await@^7.8.3": + version "7.14.5" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.14.5.tgz#c1cfdadc35a646240001f06138247b741c34d94c" + integrity sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw== + dependencies: + "@babel/helper-plugin-utils" "^7.14.5" + +"@babel/plugin-syntax-typescript@^7.7.2": + version "7.16.7" + resolved "https://registry.yarnpkg.com/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.16.7.tgz#39c9b55ee153151990fb038651d58d3fd03f98f8" + integrity sha512-YhUIJHHGkqPgEcMYkPCKTyGUdoGKWtopIycQyjJH8OjvRgOYsXsaKehLVPScKJWAULPxMa4N1vCe6szREFlZ7A== + dependencies: + "@babel/helper-plugin-utils" "^7.16.7" + +"@babel/template@^7.16.7", "@babel/template@^7.3.3": + version "7.16.7" + resolved "https://registry.yarnpkg.com/@babel/template/-/template-7.16.7.tgz#8d126c8701fde4d66b264b3eba3d96f07666d155" + integrity sha512-I8j/x8kHUrbYRTUxXrrMbfCa7jxkE7tZre39x3kjr9hvI82cK1FfqLygotcWN5kdPGWcLdWMHpSBavse5tWw3w== + dependencies: + "@babel/code-frame" "^7.16.7" + "@babel/parser" "^7.16.7" + "@babel/types" "^7.16.7" + +"@babel/traverse@^7.16.7", "@babel/traverse@^7.7.2": + version "7.16.7" + resolved "https://registry.yarnpkg.com/@babel/traverse/-/traverse-7.16.7.tgz#dac01236a72c2560073658dd1a285fe4e0865d76" + integrity sha512-8KWJPIb8c2VvY8AJrydh6+fVRo2ODx1wYBU2398xJVq0JomuLBZmVQzLPBblJgHIGYG4znCpUZUZ0Pt2vdmVYQ== + dependencies: + "@babel/code-frame" "^7.16.7" + "@babel/generator" "^7.16.7" + "@babel/helper-environment-visitor" "^7.16.7" + "@babel/helper-function-name" "^7.16.7" + "@babel/helper-hoist-variables" "^7.16.7" + "@babel/helper-split-export-declaration" "^7.16.7" + "@babel/parser" "^7.16.7" + "@babel/types" "^7.16.7" + debug "^4.1.0" + globals "^11.1.0" + +"@babel/types@^7.0.0", "@babel/types@^7.16.7", "@babel/types@^7.3.0", "@babel/types@^7.3.3": + version "7.16.7" + resolved "https://registry.yarnpkg.com/@babel/types/-/types-7.16.7.tgz#4ed19d51f840ed4bd5645be6ce40775fecf03159" + integrity sha512-E8HuV7FO9qLpx6OtoGfUQ2cjIYnbFwvZWYBS+87EwtdMvmUPJSwykpovFB+8insbpF0uJcpr8KMUi64XZntZcg== + dependencies: + "@babel/helper-validator-identifier" "^7.16.7" + to-fast-properties "^2.0.0" + +"@bcoe/v8-coverage@^0.2.3": + version "0.2.3" + resolved "https://registry.yarnpkg.com/@bcoe/v8-coverage/-/v8-coverage-0.2.3.tgz#75a2e8b51cb758a7553d6804a5932d7aace75c39" + integrity sha512-0hYQ8SB4Db5zvZB4axdMHGwEaQjkZzFjQiN9LVYvIFB2nSUHW9tYpxWriPrWDASIxiaXax83REcLxuSdnGPZtw== + +"@eslint/eslintrc@^1.0.5": + version "1.0.5" + resolved "https://registry.yarnpkg.com/@eslint/eslintrc/-/eslintrc-1.0.5.tgz#33f1b838dbf1f923bfa517e008362b78ddbbf318" + integrity sha512-BLxsnmK3KyPunz5wmCCpqy0YelEoxxGmH73Is+Z74oOTMtExcjkr3dDR6quwrjh1YspA8DH9gnX1o069KiS9AQ== + dependencies: + ajv "^6.12.4" + debug "^4.3.2" + espree "^9.2.0" + globals "^13.9.0" + ignore "^4.0.6" + import-fresh "^3.2.1" + js-yaml "^4.1.0" + minimatch "^3.0.4" + strip-json-comments "^3.1.1" + +"@humanwhocodes/config-array@^0.9.2": + version "0.9.2" + resolved "https://registry.yarnpkg.com/@humanwhocodes/config-array/-/config-array-0.9.2.tgz#68be55c737023009dfc5fe245d51181bb6476914" + integrity sha512-UXOuFCGcwciWckOpmfKDq/GyhlTf9pN/BzG//x8p8zTOFEcGuA68ANXheFS0AGvy3qgZqLBUkMs7hqzqCKOVwA== + dependencies: + "@humanwhocodes/object-schema" "^1.2.1" + debug "^4.1.1" + minimatch "^3.0.4" + +"@humanwhocodes/object-schema@^1.2.1": + version "1.2.1" + resolved "https://registry.yarnpkg.com/@humanwhocodes/object-schema/-/object-schema-1.2.1.tgz#b520529ec21d8e5945a1851dfd1c32e94e39ff45" + integrity sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA== + +"@istanbuljs/load-nyc-config@^1.0.0": + version "1.1.0" + resolved "https://registry.yarnpkg.com/@istanbuljs/load-nyc-config/-/load-nyc-config-1.1.0.tgz#fd3db1d59ecf7cf121e80650bb86712f9b55eced" + integrity sha512-VjeHSlIzpv/NyD3N0YuHfXOPDIixcA1q2ZV98wsMqcYlPmv2n3Yb2lYP9XMElnaFVXg5A7YLTeLu6V84uQDjmQ== + dependencies: + camelcase "^5.3.1" + find-up "^4.1.0" + get-package-type "^0.1.0" + js-yaml "^3.13.1" + resolve-from "^5.0.0" + +"@istanbuljs/schema@^0.1.2": + version "0.1.3" + resolved "https://registry.yarnpkg.com/@istanbuljs/schema/-/schema-0.1.3.tgz#e45e384e4b8ec16bce2fd903af78450f6bf7ec98" + integrity sha512-ZXRY4jNvVgSVQ8DL3LTcakaAtXwTVUxE81hslsyD2AtoXW/wVob10HkOJ1X/pAlcI7D+2YoZKg5do8G/w6RYgA== + +"@jest/console@^27.4.6": + version "27.4.6" + resolved "https://registry.yarnpkg.com/@jest/console/-/console-27.4.6.tgz#0742e6787f682b22bdad56f9db2a8a77f6a86107" + integrity sha512-jauXyacQD33n47A44KrlOVeiXHEXDqapSdfb9kTekOchH/Pd18kBIO1+xxJQRLuG+LUuljFCwTG92ra4NW7SpA== + dependencies: + "@jest/types" "^27.4.2" + "@types/node" "*" + chalk "^4.0.0" + jest-message-util "^27.4.6" + jest-util "^27.4.2" + slash "^3.0.0" + +"@jest/core@^27.4.7": + version "27.4.7" + resolved "https://registry.yarnpkg.com/@jest/core/-/core-27.4.7.tgz#84eabdf42a25f1fa138272ed229bcf0a1b5e6913" + integrity sha512-n181PurSJkVMS+kClIFSX/LLvw9ExSb+4IMtD6YnfxZVerw9ANYtW0bPrm0MJu2pfe9SY9FJ9FtQ+MdZkrZwjg== + dependencies: + "@jest/console" "^27.4.6" + "@jest/reporters" "^27.4.6" + "@jest/test-result" "^27.4.6" + "@jest/transform" "^27.4.6" + "@jest/types" "^27.4.2" + "@types/node" "*" + ansi-escapes "^4.2.1" + chalk "^4.0.0" + emittery "^0.8.1" + exit "^0.1.2" + graceful-fs "^4.2.4" + jest-changed-files "^27.4.2" + jest-config "^27.4.7" + jest-haste-map "^27.4.6" + jest-message-util "^27.4.6" + jest-regex-util "^27.4.0" + jest-resolve "^27.4.6" + jest-resolve-dependencies "^27.4.6" + jest-runner "^27.4.6" + jest-runtime "^27.4.6" + jest-snapshot "^27.4.6" + jest-util "^27.4.2" + jest-validate "^27.4.6" + jest-watcher "^27.4.6" + micromatch "^4.0.4" + rimraf "^3.0.0" + slash "^3.0.0" + strip-ansi "^6.0.0" + +"@jest/environment@^27.4.6": + version "27.4.6" + resolved "https://registry.yarnpkg.com/@jest/environment/-/environment-27.4.6.tgz#1e92885d64f48c8454df35ed9779fbcf31c56d8b" + integrity sha512-E6t+RXPfATEEGVidr84WngLNWZ8ffCPky8RqqRK6u1Bn0LK92INe0MDttyPl/JOzaq92BmDzOeuqk09TvM22Sg== + dependencies: + "@jest/fake-timers" "^27.4.6" + "@jest/types" "^27.4.2" + "@types/node" "*" + jest-mock "^27.4.6" + +"@jest/fake-timers@^27.4.6": + version "27.4.6" + resolved "https://registry.yarnpkg.com/@jest/fake-timers/-/fake-timers-27.4.6.tgz#e026ae1671316dbd04a56945be2fa251204324e8" + integrity sha512-mfaethuYF8scV8ntPpiVGIHQgS0XIALbpY2jt2l7wb/bvq4Q5pDLk4EP4D7SAvYT1QrPOPVZAtbdGAOOyIgs7A== + dependencies: + "@jest/types" "^27.4.2" + "@sinonjs/fake-timers" "^8.0.1" + "@types/node" "*" + jest-message-util "^27.4.6" + jest-mock "^27.4.6" + jest-util "^27.4.2" + +"@jest/globals@^27.4.6": + version "27.4.6" + resolved "https://registry.yarnpkg.com/@jest/globals/-/globals-27.4.6.tgz#3f09bed64b0fd7f5f996920258bd4be8f52f060a" + integrity sha512-kAiwMGZ7UxrgPzu8Yv9uvWmXXxsy0GciNejlHvfPIfWkSxChzv6bgTS3YqBkGuHcis+ouMFI2696n2t+XYIeFw== + dependencies: + "@jest/environment" "^27.4.6" + "@jest/types" "^27.4.2" + expect "^27.4.6" + +"@jest/reporters@^27.4.6": + version "27.4.6" + resolved "https://registry.yarnpkg.com/@jest/reporters/-/reporters-27.4.6.tgz#b53dec3a93baf9b00826abf95b932de919d6d8dd" + integrity sha512-+Zo9gV81R14+PSq4wzee4GC2mhAN9i9a7qgJWL90Gpx7fHYkWpTBvwWNZUXvJByYR9tAVBdc8VxDWqfJyIUrIQ== + dependencies: + "@bcoe/v8-coverage" "^0.2.3" + "@jest/console" "^27.4.6" + "@jest/test-result" "^27.4.6" + "@jest/transform" "^27.4.6" + "@jest/types" "^27.4.2" + "@types/node" "*" + chalk "^4.0.0" + collect-v8-coverage "^1.0.0" + exit "^0.1.2" + glob "^7.1.2" + graceful-fs "^4.2.4" + istanbul-lib-coverage "^3.0.0" + istanbul-lib-instrument "^5.1.0" + istanbul-lib-report "^3.0.0" + istanbul-lib-source-maps "^4.0.0" + istanbul-reports "^3.1.3" + jest-haste-map "^27.4.6" + jest-resolve "^27.4.6" + jest-util "^27.4.2" + jest-worker "^27.4.6" + slash "^3.0.0" + source-map "^0.6.0" + string-length "^4.0.1" + terminal-link "^2.0.0" + v8-to-istanbul "^8.1.0" + +"@jest/source-map@^27.4.0": + version "27.4.0" + resolved "https://registry.yarnpkg.com/@jest/source-map/-/source-map-27.4.0.tgz#2f0385d0d884fb3e2554e8f71f8fa957af9a74b6" + integrity sha512-Ntjx9jzP26Bvhbm93z/AKcPRj/9wrkI88/gK60glXDx1q+IeI0rf7Lw2c89Ch6ofonB0On/iRDreQuQ6te9pgQ== + dependencies: + callsites "^3.0.0" + graceful-fs "^4.2.4" + source-map "^0.6.0" + +"@jest/test-result@^27.4.6": + version "27.4.6" + resolved "https://registry.yarnpkg.com/@jest/test-result/-/test-result-27.4.6.tgz#b3df94c3d899c040f602cea296979844f61bdf69" + integrity sha512-fi9IGj3fkOrlMmhQqa/t9xum8jaJOOAi/lZlm6JXSc55rJMXKHxNDN1oCP39B0/DhNOa2OMupF9BcKZnNtXMOQ== + dependencies: + "@jest/console" "^27.4.6" + "@jest/types" "^27.4.2" + "@types/istanbul-lib-coverage" "^2.0.0" + collect-v8-coverage "^1.0.0" + +"@jest/test-sequencer@^27.4.6": + version "27.4.6" + resolved "https://registry.yarnpkg.com/@jest/test-sequencer/-/test-sequencer-27.4.6.tgz#447339b8a3d7b5436f50934df30854e442a9d904" + integrity sha512-3GL+nsf6E1PsyNsJuvPyIz+DwFuCtBdtvPpm/LMXVkBJbdFvQYCDpccYT56qq5BGniXWlE81n2qk1sdXfZebnw== + dependencies: + "@jest/test-result" "^27.4.6" + graceful-fs "^4.2.4" + jest-haste-map "^27.4.6" + jest-runtime "^27.4.6" + +"@jest/transform@^27.4.6": + version "27.4.6" + resolved "https://registry.yarnpkg.com/@jest/transform/-/transform-27.4.6.tgz#153621940b1ed500305eacdb31105d415dc30231" + integrity sha512-9MsufmJC8t5JTpWEQJ0OcOOAXaH5ioaIX6uHVBLBMoCZPfKKQF+EqP8kACAvCZ0Y1h2Zr3uOccg8re+Dr5jxyw== + dependencies: + "@babel/core" "^7.1.0" + "@jest/types" "^27.4.2" + babel-plugin-istanbul "^6.1.1" + chalk "^4.0.0" + convert-source-map "^1.4.0" + fast-json-stable-stringify "^2.0.0" + graceful-fs "^4.2.4" + jest-haste-map "^27.4.6" + jest-regex-util "^27.4.0" + jest-util "^27.4.2" + micromatch "^4.0.4" + pirates "^4.0.4" + slash "^3.0.0" + source-map "^0.6.1" + write-file-atomic "^3.0.0" + +"@jest/types@^27.4.2": + version "27.4.2" + resolved "https://registry.yarnpkg.com/@jest/types/-/types-27.4.2.tgz#96536ebd34da6392c2b7c7737d693885b5dd44a5" + integrity sha512-j35yw0PMTPpZsUoOBiuHzr1zTYoad1cVIE0ajEjcrJONxxrko/IRGKkXx3os0Nsi4Hu3+5VmDbVfq5WhG/pWAg== + dependencies: + "@types/istanbul-lib-coverage" "^2.0.0" + "@types/istanbul-reports" "^3.0.0" + "@types/node" "*" + "@types/yargs" "^16.0.0" + chalk "^4.0.0" + +"@sinonjs/commons@^1.7.0": + version "1.8.3" + resolved "https://registry.yarnpkg.com/@sinonjs/commons/-/commons-1.8.3.tgz#3802ddd21a50a949b6721ddd72da36e67e7f1b2d" + integrity sha512-xkNcLAn/wZaX14RPlwizcKicDk9G3F8m2nU3L7Ukm5zBgTwiT0wsoFAHx9Jq56fJA1z/7uKGtCRu16sOUCLIHQ== + dependencies: + type-detect "4.0.8" + +"@sinonjs/fake-timers@^8.0.1": + version "8.1.0" + resolved "https://registry.yarnpkg.com/@sinonjs/fake-timers/-/fake-timers-8.1.0.tgz#3fdc2b6cb58935b21bfb8d1625eb1300484316e7" + integrity sha512-OAPJUAtgeINhh/TAlUID4QTs53Njm7xzddaVlEs/SXwgtiD1tW22zAB/W1wdqfrpmikgaWQ9Fw6Ws+hsiRm5Vg== + dependencies: + "@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.14": + version "7.1.18" + resolved "https://registry.yarnpkg.com/@types/babel__core/-/babel__core-7.1.18.tgz#1a29abcc411a9c05e2094c98f9a1b7da6cdf49f8" + integrity sha512-S7unDjm/C7z2A2R9NzfKCK1I+BAALDtxEmsJBwlB3EzNfb929ykjL++1CK9LO++EIp2fQrC8O+BwjKvz6UeDyQ== + dependencies: + "@babel/parser" "^7.1.0" + "@babel/types" "^7.0.0" + "@types/babel__generator" "*" + "@types/babel__template" "*" + "@types/babel__traverse" "*" + +"@types/babel__generator@*": + version "7.6.4" + resolved "https://registry.yarnpkg.com/@types/babel__generator/-/babel__generator-7.6.4.tgz#1f20ce4c5b1990b37900b63f050182d28c2439b7" + integrity sha512-tFkciB9j2K755yrTALxD44McOrk+gfpIpvC3sxHjRawj6PfnQxrse4Clq5y/Rq+G3mrBurMax/lG8Qn2t9mSsg== + dependencies: + "@babel/types" "^7.0.0" + +"@types/babel__template@*": + version "7.4.1" + resolved "https://registry.yarnpkg.com/@types/babel__template/-/babel__template-7.4.1.tgz#3d1a48fd9d6c0edfd56f2ff578daed48f36c8969" + integrity sha512-azBFKemX6kMg5Io+/rdGT0dkGreboUVR0Cdm3fz9QJWpaQGJRQXl7C+6hOTCZcMll7KFyEQpgbYI2lHdsS4U7g== + dependencies: + "@babel/parser" "^7.1.0" + "@babel/types" "^7.0.0" + +"@types/babel__traverse@*", "@types/babel__traverse@^7.0.4", "@types/babel__traverse@^7.0.6": + version "7.14.2" + resolved "https://registry.yarnpkg.com/@types/babel__traverse/-/babel__traverse-7.14.2.tgz#ffcd470bbb3f8bf30481678fb5502278ca833a43" + integrity sha512-K2waXdXBi2302XUdcHcR1jCeU0LL4TD9HRs/gk0N2Xvrht+G/BfJa4QObBQZfhMdxiCpV3COl5Nfq4uKTeTnJA== + dependencies: + "@babel/types" "^7.3.0" + +"@types/graceful-fs@^4.1.2": + version "4.1.5" + resolved "https://registry.yarnpkg.com/@types/graceful-fs/-/graceful-fs-4.1.5.tgz#21ffba0d98da4350db64891f92a9e5db3cdb4e15" + integrity sha512-anKkLmZZ+xm4p8JWBf4hElkM4XR+EZeA2M9BAkkTldmcyDY4mbdIJnRghDJH3Ov5ooY7/UAoENtmdMSkaAd7Cw== + dependencies: + "@types/node" "*" + +"@types/istanbul-lib-coverage@*", "@types/istanbul-lib-coverage@^2.0.0", "@types/istanbul-lib-coverage@^2.0.1": + version "2.0.4" + resolved "https://registry.yarnpkg.com/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.4.tgz#8467d4b3c087805d63580480890791277ce35c44" + integrity sha512-z/QT1XN4K4KYuslS23k62yDIDLwLFkzxOuMplDtObz0+y7VqJCaO2o+SPwHCvLFZh7xazvvoor2tA/hPz9ee7g== + +"@types/istanbul-lib-report@*": + version "3.0.0" + resolved "https://registry.yarnpkg.com/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz#c14c24f18ea8190c118ee7562b7ff99a36552686" + integrity sha512-plGgXAPfVKFoYfa9NpYDAkseG+g6Jr294RqeqcqDixSbU34MZVJRi/P+7Y8GDpzkEwLaGZZOpKIEmeVZNtKsrg== + dependencies: + "@types/istanbul-lib-coverage" "*" + +"@types/istanbul-reports@^3.0.0": + version "3.0.1" + resolved "https://registry.yarnpkg.com/@types/istanbul-reports/-/istanbul-reports-3.0.1.tgz#9153fe98bba2bd565a63add9436d6f0d7f8468ff" + integrity sha512-c3mAZEuK0lvBp8tmuL74XRKn1+y2dcwOUpH7x4WrF6gk1GIgiluDRgMYQtw2OFcBvAJWlt6ASU3tSqxp0Uu0Aw== + dependencies: + "@types/istanbul-lib-report" "*" + +"@types/node@*": + version "17.0.8" + resolved "https://registry.yarnpkg.com/@types/node/-/node-17.0.8.tgz#50d680c8a8a78fe30abe6906453b21ad8ab0ad7b" + integrity sha512-YofkM6fGv4gDJq78g4j0mMuGMkZVxZDgtU0JRdx6FgiJDG+0fY0GKVolOV8WqVmEhLCXkQRjwDdKyPxJp/uucg== + +"@types/prettier@^2.1.5": + version "2.4.2" + resolved "https://registry.yarnpkg.com/@types/prettier/-/prettier-2.4.2.tgz#4c62fae93eb479660c3bd93f9d24d561597a8281" + integrity sha512-ekoj4qOQYp7CvjX8ZDBgN86w3MqQhLE1hczEJbEIjgFEumDy+na/4AJAbLXfgEWFNB2pKadM5rPFtuSGMWK7xA== + +"@types/stack-utils@^2.0.0": + version "2.0.1" + resolved "https://registry.yarnpkg.com/@types/stack-utils/-/stack-utils-2.0.1.tgz#20f18294f797f2209b5f65c8e3b5c8e8261d127c" + integrity sha512-Hl219/BT5fLAaz6NDkSuhzasy49dwQS/DSdu4MdggFB8zcXv7vflBI3xp7FEmkmdDkBUI2bPUNeMttp2knYdxw== + +"@types/yargs-parser@*": + version "20.2.1" + resolved "https://registry.yarnpkg.com/@types/yargs-parser/-/yargs-parser-20.2.1.tgz#3b9ce2489919d9e4fea439b76916abc34b2df129" + integrity sha512-7tFImggNeNBVMsn0vLrpn1H1uPrUBdnARPTpZoitY37ZrdJREzf7I16tMrlK3hen349gr1NYh8CmZQa7CTG6Aw== + +"@types/yargs@^16.0.0": + version "16.0.4" + resolved "https://registry.yarnpkg.com/@types/yargs/-/yargs-16.0.4.tgz#26aad98dd2c2a38e421086ea9ad42b9e51642977" + integrity sha512-T8Yc9wt/5LbJyCaLiHPReJa0kApcIgJ7Bn735GjItUfh08Z1pJvu8QZqb9s+mMvKV6WUQRV7K2R46YbjMXTTJw== + dependencies: + "@types/yargs-parser" "*" + +"@vendia/serverless-express@^3.4.0": + version "3.4.0" + resolved "https://registry.yarnpkg.com/@vendia/serverless-express/-/serverless-express-3.4.0.tgz#156f47d364b067ae6fa678a914c51887f494321a" + integrity sha512-/UAAbi9qRjUtjRISt5MJ1sfhtrHb26hqQ0nvE5qhMLsAdR5H7ErBwPD8Q/v2OENKm0iWsGwErIZEg7ebUeFDjQ== + dependencies: + binary-case "^1.0.0" + type-is "^1.6.16" + +abab@^2.0.3, abab@^2.0.5: + version "2.0.5" + resolved "https://registry.yarnpkg.com/abab/-/abab-2.0.5.tgz#c0b678fb32d60fc1219c784d6a826fe385aeb79a" + integrity sha512-9IK9EadsbHo6jLWIpxpR6pL0sazTXV6+SQv25ZB+F7Bj9mJNaOc4nCRabwd5M/JwmUa8idz6Eci6eKfJryPs6Q== + +accepts@~1.3.8: + version "1.3.8" + resolved "https://registry.yarnpkg.com/accepts/-/accepts-1.3.8.tgz#0bf0be125b67014adcb0b0921e62db7bffe16b2e" + integrity sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw== + dependencies: + mime-types "~2.1.34" + negotiator "0.6.3" + +acorn-globals@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/acorn-globals/-/acorn-globals-6.0.0.tgz#46cdd39f0f8ff08a876619b55f5ac8a6dc770b45" + integrity sha512-ZQl7LOWaF5ePqqcX4hLuv/bLXYQNfNWw2c0/yX/TsPRKamzHcTGQnlCjHT3TsmkOUVEPS3crCxiPfdzE/Trlhg== + dependencies: + acorn "^7.1.1" + acorn-walk "^7.1.1" + +acorn-jsx@^5.3.1: + version "5.3.2" + resolved "https://registry.yarnpkg.com/acorn-jsx/-/acorn-jsx-5.3.2.tgz#7ed5bb55908b3b2f1bc55c6af1653bada7f07937" + integrity sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ== + +acorn-walk@^7.1.1: + version "7.2.0" + resolved "https://registry.yarnpkg.com/acorn-walk/-/acorn-walk-7.2.0.tgz#0de889a601203909b0fbe07b8938dc21d2e967bc" + integrity sha512-OPdCF6GsMIP+Az+aWfAAOEt2/+iVDKE7oy6lJ098aoe59oAmK76qV6Gw60SbZ8jHuG2wH058GF4pLFbYamYrVA== + +acorn@^7.1.1: + version "7.4.1" + resolved "https://registry.yarnpkg.com/acorn/-/acorn-7.4.1.tgz#feaed255973d2e77555b83dbc08851a6c63520fa" + integrity sha512-nQyp0o1/mNdbTO1PO6kHkwSrmgZ0MT/jCCpNiwbUjGoRN4dlBhqJtoQuCnEOKzgTVwg0ZWiCoQy6SxMebQVh8A== + +acorn@^8.2.4, 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: + 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: + debug "4" + +ajv@^6.10.0, ajv@^6.12.4: + version "6.12.6" + resolved "https://registry.yarnpkg.com/ajv/-/ajv-6.12.6.tgz#baf5a62e802b07d977034586f8c3baf5adf26df4" + integrity sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g== + dependencies: + fast-deep-equal "^3.1.1" + fast-json-stable-stringify "^2.0.0" + json-schema-traverse "^0.4.1" + uri-js "^4.2.2" + +ansi-colors@^4.1.1: + version "4.1.1" + resolved "https://registry.yarnpkg.com/ansi-colors/-/ansi-colors-4.1.1.tgz#cbb9ae256bf750af1eab344f229aa27fe94ba348" + integrity sha512-JoX0apGbHaUJBNl6yF+p6JAFYZ666/hhCGKN5t9QFjbJQKUU/g8MNbFDbvfrgKXvI1QpZplPOnwIo99lX/AAmA== + +ansi-escapes@^4.2.1: + version "4.3.2" + resolved "https://registry.yarnpkg.com/ansi-escapes/-/ansi-escapes-4.3.2.tgz#6b2291d1db7d98b6521d5f1efa42d0f3a9feb65e" + integrity sha512-gKXj5ALrKWQLsYG9jlTRmR/xKluxHV+Z9QEwNIgCfM1/uwPMCuzVVnh5mwTd+OuBZcwSIMbqssNWRm1lE51QaQ== + dependencies: + type-fest "^0.21.3" + +ansi-regex@^5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-5.0.1.tgz#082cb2c89c9fe8659a311a53bd6a4dc5301db304" + integrity sha512-quJQXlTSUGL2LH9SUXo8VwsY4soanhgo6LNSm84E1LBcE8s3O0wpdiRzyR9z/ZZJMlMWv37qOOb9pdJlMUEKFQ== + +ansi-styles@^3.2.1: + version "3.2.1" + resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-3.2.1.tgz#41fbb20243e50b12be0f04b8dedbf07520ce841d" + integrity sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA== + dependencies: + color-convert "^1.9.0" + +ansi-styles@^4.0.0, ansi-styles@^4.1.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-4.3.0.tgz#edd803628ae71c04c85ae7a0906edad34b648937" + integrity sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg== + dependencies: + color-convert "^2.0.1" + +ansi-styles@^5.0.0: + version "5.2.0" + resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-5.2.0.tgz#07449690ad45777d1924ac2abb2fc8895dba836b" + integrity sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA== + +anymatch@^3.0.3: + version "3.1.2" + resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-3.1.2.tgz#c0557c096af32f106198f4f4e2a383537e378716" + integrity sha512-P43ePfOAIupkguHUycrc4qJ9kz8ZiuOUijaETwX7THt0Y/GNK7v0aa8rY816xWjZ7rJdA5XdMcpVFTKMq+RvWg== + dependencies: + normalize-path "^3.0.0" + picomatch "^2.0.4" + +argparse@^1.0.7: + version "1.0.10" + resolved "https://registry.yarnpkg.com/argparse/-/argparse-1.0.10.tgz#bcd6791ea5ae09725e17e5ad988134cd40b3d911" + integrity sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg== + dependencies: + sprintf-js "~1.0.2" + +argparse@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/argparse/-/argparse-2.0.1.tgz#246f50f3ca78a3240f6c997e8a9bd1eac49e4b38" + integrity sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q== + +array-flatten@1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/array-flatten/-/array-flatten-1.1.1.tgz#9a5f699051b1e7073328f2a008968b64ea2955d2" + integrity sha1-ml9pkFGx5wczKPKgCJaLZOopVdI= + +asynckit@^0.4.0: + version "0.4.0" + resolved "https://registry.yarnpkg.com/asynckit/-/asynckit-0.4.0.tgz#c79ed97f7f34cb8f2ba1bc9790bcc366474b4b79" + integrity sha1-x57Zf380y48robyXkLzDZkdLS3k= + +aws-serverless-express@^3.3.5: + version "3.4.0" + resolved "https://registry.yarnpkg.com/aws-serverless-express/-/aws-serverless-express-3.4.0.tgz#74153b8cc80dbd2c6a32a51e6d353a325c2710d7" + integrity sha512-YG9ZjAOI9OpwqDDWzkRc3kKJYJuR7gTMjLa3kAWopO17myoprxskCUyCEee+RKe34tcR4UNrVtgAwW5yDe74bw== + dependencies: + "@vendia/serverless-express" "^3.4.0" + binary-case "^1.0.0" + type-is "^1.6.16" + +axios@^0.24.0: + version "0.24.0" + resolved "https://registry.yarnpkg.com/axios/-/axios-0.24.0.tgz#804e6fa1e4b9c5288501dd9dff56a7a0940d20d6" + integrity sha512-Q6cWsys88HoPgAaFAVUb0WpPk0O8iTeisR9IMqy9G8AbO4NlpVknrnQS03zzF9PGAWgO3cgletO3VjV/P7VztA== + dependencies: + follow-redirects "^1.14.4" + +babel-jest@^27.4.6: + version "27.4.6" + resolved "https://registry.yarnpkg.com/babel-jest/-/babel-jest-27.4.6.tgz#4d024e69e241cdf4f396e453a07100f44f7ce314" + integrity sha512-qZL0JT0HS1L+lOuH+xC2DVASR3nunZi/ozGhpgauJHgmI7f8rudxf6hUjEHympdQ/J64CdKmPkgfJ+A3U6QCrg== + dependencies: + "@jest/transform" "^27.4.6" + "@jest/types" "^27.4.2" + "@types/babel__core" "^7.1.14" + babel-plugin-istanbul "^6.1.1" + babel-preset-jest "^27.4.0" + chalk "^4.0.0" + graceful-fs "^4.2.4" + slash "^3.0.0" + +babel-plugin-istanbul@^6.1.1: + version "6.1.1" + resolved "https://registry.yarnpkg.com/babel-plugin-istanbul/-/babel-plugin-istanbul-6.1.1.tgz#fa88ec59232fd9b4e36dbbc540a8ec9a9b47da73" + integrity sha512-Y1IQok9821cC9onCx5otgFfRm7Lm+I+wwxOx738M/WLPZ9Q42m4IG5W0FNX8WLL2gYMZo3JkuXIH2DOpWM+qwA== + dependencies: + "@babel/helper-plugin-utils" "^7.0.0" + "@istanbuljs/load-nyc-config" "^1.0.0" + "@istanbuljs/schema" "^0.1.2" + istanbul-lib-instrument "^5.0.4" + test-exclude "^6.0.0" + +babel-plugin-jest-hoist@^27.4.0: + version "27.4.0" + resolved "https://registry.yarnpkg.com/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-27.4.0.tgz#d7831fc0f93573788d80dee7e682482da4c730d6" + integrity sha512-Jcu7qS4OX5kTWBc45Hz7BMmgXuJqRnhatqpUhnzGC3OBYpOmf2tv6jFNwZpwM7wU7MUuv2r9IPS/ZlYOuburVw== + dependencies: + "@babel/template" "^7.3.3" + "@babel/types" "^7.3.3" + "@types/babel__core" "^7.0.0" + "@types/babel__traverse" "^7.0.6" + +babel-preset-current-node-syntax@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/babel-preset-current-node-syntax/-/babel-preset-current-node-syntax-1.0.1.tgz#b4399239b89b2a011f9ddbe3e4f401fc40cff73b" + integrity sha512-M7LQ0bxarkxQoN+vz5aJPsLBn77n8QgTFmo8WK0/44auK2xlCXrYcUxHFxgU7qW5Yzw/CjmLRK2uJzaCd7LvqQ== + dependencies: + "@babel/plugin-syntax-async-generators" "^7.8.4" + "@babel/plugin-syntax-bigint" "^7.8.3" + "@babel/plugin-syntax-class-properties" "^7.8.3" + "@babel/plugin-syntax-import-meta" "^7.8.3" + "@babel/plugin-syntax-json-strings" "^7.8.3" + "@babel/plugin-syntax-logical-assignment-operators" "^7.8.3" + "@babel/plugin-syntax-nullish-coalescing-operator" "^7.8.3" + "@babel/plugin-syntax-numeric-separator" "^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-chaining" "^7.8.3" + "@babel/plugin-syntax-top-level-await" "^7.8.3" + +babel-preset-jest@^27.4.0: + version "27.4.0" + resolved "https://registry.yarnpkg.com/babel-preset-jest/-/babel-preset-jest-27.4.0.tgz#70d0e676a282ccb200fbabd7f415db5fdf393bca" + integrity sha512-NK4jGYpnBvNxcGo7/ZpZJr51jCGT+3bwwpVIDY2oNfTxJJldRtB4VAcYdgp1loDE50ODuTu+yBjpMAswv5tlpg== + dependencies: + babel-plugin-jest-hoist "^27.4.0" + babel-preset-current-node-syntax "^1.0.0" + +balanced-match@^1.0.0: + version "1.0.2" + resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.2.tgz#e83e3a7e3f300b34cb9d87f615fa0cbf357690ee" + integrity sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw== + +binary-case@^1.0.0: + version "1.1.4" + resolved "https://registry.yarnpkg.com/binary-case/-/binary-case-1.1.4.tgz#d687104d59e38f2b9e658d3a58936963c59ab931" + integrity sha512-9Kq8m6NZTAgy05Ryuh7U3Qc4/ujLQU1AZ5vMw4cr3igTdi5itZC6kCNrRr2X8NzPiDn2oUIFTfa71DKMnue/Zg== + +body-parser@1.19.2, body-parser@^1.17.1: + version "1.19.2" + resolved "https://registry.yarnpkg.com/body-parser/-/body-parser-1.19.2.tgz#4714ccd9c157d44797b8b5607d72c0b89952f26e" + integrity sha512-SAAwOxgoCKMGs9uUAUFHygfLAyaniaoun6I8mFY9pRAJL9+Kec34aU+oIjDhTycub1jozEfEwx1W1IuOYxVSFw== + dependencies: + bytes "3.1.2" + content-type "~1.0.4" + debug "2.6.9" + depd "~1.1.2" + http-errors "1.8.1" + iconv-lite "0.4.24" + on-finished "~2.3.0" + qs "6.9.7" + raw-body "2.4.3" + type-is "~1.6.18" + +brace-expansion@^1.1.7: + version "1.1.11" + resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz#3c7fcbf529d87226f3d2f52b966ff5271eb441dd" + integrity sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA== + dependencies: + balanced-match "^1.0.0" + concat-map "0.0.1" + +braces@^3.0.1: + version "3.0.2" + resolved "https://registry.yarnpkg.com/braces/-/braces-3.0.2.tgz#3454e1a462ee8d599e236df336cd9ea4f8afe107" + integrity sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A== + dependencies: + fill-range "^7.0.1" + +browser-process-hrtime@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/browser-process-hrtime/-/browser-process-hrtime-1.0.0.tgz#3c9b4b7d782c8121e56f10106d84c0d0ffc94626" + integrity sha512-9o5UecI3GhkpM6DrXr69PblIuWxPKk9Y0jHBRhdocZ2y7YECBFCsHm79Pr3OyR2AvjhDkabFJaDJMYRazHgsow== + +browserslist@^4.17.5: + version "4.19.1" + resolved "https://registry.yarnpkg.com/browserslist/-/browserslist-4.19.1.tgz#4ac0435b35ab655896c31d53018b6dd5e9e4c9a3" + integrity sha512-u2tbbG5PdKRTUoctO3NBD8FQ5HdPh1ZXPHzp1rwaa5jTc+RV9/+RlWiAIKmjRPQF+xbGM9Kklj5bZQFa2s/38A== + dependencies: + caniuse-lite "^1.0.30001286" + electron-to-chromium "^1.4.17" + escalade "^3.1.1" + node-releases "^2.0.1" + picocolors "^1.0.0" + +bser@2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/bser/-/bser-2.1.1.tgz#e6787da20ece9d07998533cfd9de6f5c38f4bc05" + integrity sha512-gQxTNE/GAfIIrmHLUE3oJyp5FO6HRBfhjnw4/wMmA63ZGDJnWBmgY/lyQBpnDUkGmAhbSe39tx2d/iTOAfglwQ== + dependencies: + node-int64 "^0.4.0" + +buffer-from@^1.0.0: + version "1.1.2" + resolved "https://registry.yarnpkg.com/buffer-from/-/buffer-from-1.1.2.tgz#2b146a6fd72e80b4f55d255f35ed59a3a9a41bd5" + integrity sha512-E+XQCRwSbaaiChtv6k6Dwgc+bx+Bs6vuKJHHl5kox/BaKbhiXzqQOwK4cO22yElGp2OCmjwVhT3HmxgyPGnJfQ== + +bytes@3.1.2: + version "3.1.2" + resolved "https://registry.yarnpkg.com/bytes/-/bytes-3.1.2.tgz#8b0beeb98605adf1b128fa4386403c009e0221a5" + integrity sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg== + +callsites@^3.0.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/callsites/-/callsites-3.1.0.tgz#b3630abd8943432f54b3f0519238e33cd7df2f73" + integrity sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ== + +camelcase@^5.3.1: + version "5.3.1" + resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-5.3.1.tgz#e3c9b31569e106811df242f715725a1f4c494320" + integrity sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg== + +camelcase@^6.2.0: + version "6.3.0" + resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-6.3.0.tgz#5685b95eb209ac9c0c177467778c9c84df58ba9a" + integrity sha512-Gmy6FhYlCY7uOElZUSbxo2UCDH8owEk996gkbrpsgGtrJLM3J7jGxl9Ic7Qwwj4ivOE5AWZWRMecDdF7hqGjFA== + +caniuse-lite@^1.0.30001286: + version "1.0.30001296" + resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30001296.tgz#d99f0f3bee66544800b93d261c4be55a35f1cec8" + integrity sha512-WfrtPEoNSoeATDlf4y3QvkwiELl9GyPLISV5GejTbbQRtQx4LhsXmc9IQ6XCL2d7UxCyEzToEZNMeqR79OUw8Q== + +chalk@^2.0.0: + version "2.4.2" + resolved "https://registry.yarnpkg.com/chalk/-/chalk-2.4.2.tgz#cd42541677a54333cf541a49108c1432b44c9424" + integrity sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ== + dependencies: + ansi-styles "^3.2.1" + escape-string-regexp "^1.0.5" + supports-color "^5.3.0" + +chalk@^4.0.0: + version "4.1.2" + resolved "https://registry.yarnpkg.com/chalk/-/chalk-4.1.2.tgz#aac4e2b7734a740867aeb16bf02aad556a1e7a01" + integrity sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA== + dependencies: + ansi-styles "^4.1.0" + supports-color "^7.1.0" + +char-regex@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/char-regex/-/char-regex-1.0.2.tgz#d744358226217f981ed58f479b1d6bcc29545dcf" + integrity sha512-kWWXztvZ5SBQV+eRgKFeh8q5sLuZY2+8WUIzlxWVTg+oGwY14qylx1KbKzHd8P6ZYkAg0xyIDU9JMHhyJMZ1jw== + +ci-info@^3.2.0: + version "3.3.0" + resolved "https://registry.yarnpkg.com/ci-info/-/ci-info-3.3.0.tgz#b4ed1fb6818dea4803a55c623041f9165d2066b2" + integrity sha512-riT/3vI5YpVH6/qomlDnJow6TBee2PBKSEpx3O32EGPYbWGIRsIlGRms3Sm74wYE1JMo8RnO04Hb12+v1J5ICw== + +cjs-module-lexer@^1.0.0: + version "1.2.2" + resolved "https://registry.yarnpkg.com/cjs-module-lexer/-/cjs-module-lexer-1.2.2.tgz#9f84ba3244a512f3a54e5277e8eef4c489864e40" + integrity sha512-cOU9usZw8/dXIXKtwa8pM0OTJQuJkxMN6w30csNRUerHfeQ5R6U3kkU/FtJeIf3M202OHfY2U8ccInBG7/xogA== + +cliui@^7.0.2: + version "7.0.4" + resolved "https://registry.yarnpkg.com/cliui/-/cliui-7.0.4.tgz#a0265ee655476fc807aea9df3df8df7783808b4f" + integrity sha512-OcRE68cOsVMXp1Yvonl/fzkQOyjLSu/8bhPDfQt0e0/Eb283TKP20Fs2MqoPsr9SwA595rRCA+QMzYc9nBP+JQ== + dependencies: + string-width "^4.2.0" + strip-ansi "^6.0.0" + wrap-ansi "^7.0.0" + +co@^4.6.0: + version "4.6.0" + resolved "https://registry.yarnpkg.com/co/-/co-4.6.0.tgz#6ea6bdf3d853ae54ccb8e47bfa0bf3f9031fb184" + integrity sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ= + +collect-v8-coverage@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/collect-v8-coverage/-/collect-v8-coverage-1.0.1.tgz#cc2c8e94fc18bbdffe64d6534570c8a673b27f59" + integrity sha512-iBPtljfCNcTKNAto0KEtDfZ3qzjJvqE3aTGZsbhjSBlorqpXJlaWWtPO35D+ZImoC3KWejX64o+yPGxhWSTzfg== + +color-convert@^1.9.0: + version "1.9.3" + resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-1.9.3.tgz#bb71850690e1f136567de629d2d5471deda4c1e8" + integrity sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg== + dependencies: + color-name "1.1.3" + +color-convert@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-2.0.1.tgz#72d3a68d598c9bdb3af2ad1e84f21d896abd4de3" + integrity sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ== + dependencies: + color-name "~1.1.4" + +color-name@1.1.3: + version "1.1.3" + resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.3.tgz#a7d0558bd89c42f795dd42328f740831ca53bc25" + integrity sha1-p9BVi9icQveV3UIyj3QIMcpTvCU= + +color-name@~1.1.4: + version "1.1.4" + resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2" + integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA== + +combined-stream@^1.0.8: + version "1.0.8" + resolved "https://registry.yarnpkg.com/combined-stream/-/combined-stream-1.0.8.tgz#c3d45a8b34fd730631a110a8a2520682b31d5a7f" + integrity sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg== + dependencies: + delayed-stream "~1.0.0" + +concat-map@0.0.1: + version "0.0.1" + resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" + integrity sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg== + +content-disposition@0.5.4: + version "0.5.4" + resolved "https://registry.yarnpkg.com/content-disposition/-/content-disposition-0.5.4.tgz#8b82b4efac82512a02bb0b1dcec9d2c5e8eb5bfe" + integrity sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ== + dependencies: + safe-buffer "5.2.1" + +content-type@~1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/content-type/-/content-type-1.0.4.tgz#e138cc75e040c727b1966fe5e5f8c9aee256fe3b" + integrity sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA== + +convert-source-map@^1.4.0, convert-source-map@^1.6.0, convert-source-map@^1.7.0: + version "1.8.0" + resolved "https://registry.yarnpkg.com/convert-source-map/-/convert-source-map-1.8.0.tgz#f3373c32d21b4d780dd8004514684fb791ca4369" + integrity sha512-+OQdjP49zViI/6i7nIJpA8rAl4sV/JdPfU9nZs3VqOwGIgizICvuN2ru6fMd+4llL0tar18UYJXfZ/TWtmhUjA== + dependencies: + safe-buffer "~5.1.1" + +cookie-signature@1.0.6: + version "1.0.6" + resolved "https://registry.yarnpkg.com/cookie-signature/-/cookie-signature-1.0.6.tgz#e303a882b342cc3ee8ca513a79999734dab3ae2c" + integrity sha1-4wOogrNCzD7oylE6eZmXNNqzriw= + +cookie@0.4.2: + version "0.4.2" + resolved "https://registry.yarnpkg.com/cookie/-/cookie-0.4.2.tgz#0e41f24de5ecf317947c82fc789e06a884824432" + integrity sha512-aSWTXFzaKWkvHO1Ny/s+ePFpvKsPnjc551iI41v3ny/ow6tBG5Vd+FuqGNhh1LxOmVzOlGUriIlOaokOvhaStA== + +cors@^2.8.5: + version "2.8.5" + resolved "https://registry.yarnpkg.com/cors/-/cors-2.8.5.tgz#eac11da51592dd86b9f06f6e7ac293b3df875d29" + integrity sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g== + dependencies: + object-assign "^4" + vary "^1" + +cross-spawn@^7.0.2, cross-spawn@^7.0.3: + version "7.0.3" + resolved "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-7.0.3.tgz#f73a85b9d5d41d045551c177e2882d4ac85728a6" + integrity sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w== + dependencies: + path-key "^3.1.0" + shebang-command "^2.0.0" + which "^2.0.1" + +cssom@^0.4.4: + version "0.4.4" + resolved "https://registry.yarnpkg.com/cssom/-/cssom-0.4.4.tgz#5a66cf93d2d0b661d80bf6a44fb65f5c2e4e0a10" + integrity sha512-p3pvU7r1MyyqbTk+WbNJIgJjG2VmTIaB10rI93LzVPrmDJKkzKYMtxxyAvQXR/NS6otuzveI7+7BBq3SjBS2mw== + +cssom@~0.3.6: + version "0.3.8" + resolved "https://registry.yarnpkg.com/cssom/-/cssom-0.3.8.tgz#9f1276f5b2b463f2114d3f2c75250af8c1a36f4a" + integrity sha512-b0tGHbfegbhPJpxpiBPU2sCkigAqtM9O121le6bbOlgyV+NyGyCmVfJ6QW9eRjz8CpNfWEOYBIMIGRYkLwsIYg== + +cssstyle@^2.3.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/cssstyle/-/cssstyle-2.3.0.tgz#ff665a0ddbdc31864b09647f34163443d90b0852" + integrity sha512-AZL67abkUzIuvcHqk7c09cezpGNcxUxU4Ioi/05xHk4DQeTkWmGYftIE6ctU6AEt+Gn4n1lDStOtj7FKycP71A== + dependencies: + cssom "~0.3.6" + +data-urls@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/data-urls/-/data-urls-2.0.0.tgz#156485a72963a970f5d5821aaf642bef2bf2db9b" + integrity sha512-X5eWTSXO/BJmpdIKCRuKUgSCgAN0OwliVK3yPKbwIWU1Tdw5BRajxlzMidvh+gwko9AfQ9zIj52pzF91Q3YAvQ== + dependencies: + abab "^2.0.3" + whatwg-mimetype "^2.3.0" + whatwg-url "^8.0.0" + +debug@2.6.9: + version "2.6.9" + resolved "https://registry.yarnpkg.com/debug/-/debug-2.6.9.tgz#5d128515df134ff327e90a4c93f4e077a536341f" + integrity sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA== + dependencies: + ms "2.0.0" + +debug@4, debug@^4.1.0, debug@^4.1.1, debug@^4.3.2: + version "4.3.3" + resolved "https://registry.yarnpkg.com/debug/-/debug-4.3.3.tgz#04266e0b70a98d4462e6e288e38259213332b664" + integrity sha512-/zxw5+vh1Tfv+4Qn7a5nsbcJKPaSvCDhojn6FEl9vupwK2VCSDtEiEtqr8DFtzYFOdz63LBkxec7DYuc2jon6Q== + dependencies: + ms "2.1.2" + +decimal.js@^10.2.1: + version "10.3.1" + resolved "https://registry.yarnpkg.com/decimal.js/-/decimal.js-10.3.1.tgz#d8c3a444a9c6774ba60ca6ad7261c3a94fd5e783" + integrity sha512-V0pfhfr8suzyPGOx3nmq4aHqabehUZn6Ch9kyFpV79TGDTWFmHqUqXdabR7QHqxzrYolF4+tVmJhUG4OURg5dQ== + +dedent@^0.7.0: + version "0.7.0" + resolved "https://registry.yarnpkg.com/dedent/-/dedent-0.7.0.tgz#2495ddbaf6eb874abb0e1be9df22d2e5a544326c" + integrity sha1-JJXduvbrh0q7Dhvp3yLS5aVEMmw= + +deep-is@^0.1.3, deep-is@~0.1.3: + version "0.1.4" + resolved "https://registry.yarnpkg.com/deep-is/-/deep-is-0.1.4.tgz#a6f2dce612fadd2ef1f519b73551f17e85199831" + integrity sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ== + +deepmerge@^4.2.2: + version "4.2.2" + resolved "https://registry.yarnpkg.com/deepmerge/-/deepmerge-4.2.2.tgz#44d2ea3679b8f4d4ffba33f03d865fc1e7bf4955" + integrity sha512-FJ3UgI4gIl+PHZm53knsuSFpE+nESMr7M4v9QcgB7S63Kj/6WqMiFQJpBBYz1Pt+66bZpP3Q7Lye0Oo9MPKEdg== + +delayed-stream@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/delayed-stream/-/delayed-stream-1.0.0.tgz#df3ae199acadfb7d440aaae0b29e2272b24ec619" + 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= + +destroy@~1.0.4: + version "1.0.4" + resolved "https://registry.yarnpkg.com/destroy/-/destroy-1.0.4.tgz#978857442c44749e4206613e37946205826abd80" + integrity sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA= + +detect-newline@^3.0.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/detect-newline/-/detect-newline-3.1.0.tgz#576f5dfc63ae1a192ff192d8ad3af6308991b651" + integrity sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA== + +diff-sequences@^27.4.0: + version "27.4.0" + resolved "https://registry.yarnpkg.com/diff-sequences/-/diff-sequences-27.4.0.tgz#d783920ad8d06ec718a060d00196dfef25b132a5" + integrity sha512-YqiQzkrsmHMH5uuh8OdQFU9/ZpADnwzml8z0O5HvRNda+5UZsaX/xN+AAxfR2hWq1Y7HZnAzO9J5lJXOuDz2Ww== + +doctrine@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/doctrine/-/doctrine-3.0.0.tgz#addebead72a6574db783639dc87a121773973961" + integrity sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w== + dependencies: + esutils "^2.0.2" + +domexception@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/domexception/-/domexception-2.0.1.tgz#fb44aefba793e1574b0af6aed2801d057529f304" + integrity sha512-yxJ2mFy/sibVQlu5qHjOkf9J3K6zgmCxgJ94u2EdvDOV09H+32LtRswEcUsmUWN72pVLOEnTSRaIVVzVQgS0dg== + dependencies: + webidl-conversions "^5.0.0" + +ee-first@1.1.1: + version "1.1.1" + resolved "https://registry.yarnpkg.com/ee-first/-/ee-first-1.1.1.tgz#590c61156b0ae2f4f0255732a158b266bc56b21d" + integrity sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0= + +electron-to-chromium@^1.4.17: + version "1.4.36" + resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.4.36.tgz#446c6184dbe5baeb5eae9a875490831e4bc5319a" + integrity sha512-MbLlbF39vKrXWlFEFpCgDHwdlz4O3LmHM5W4tiLRHjSmEUXjJjz8sZkMgWgvYxlZw3N1iDTmCEtOkkESb5TMCg== + +emittery@^0.8.1: + version "0.8.1" + resolved "https://registry.yarnpkg.com/emittery/-/emittery-0.8.1.tgz#bb23cc86d03b30aa75a7f734819dee2e1ba70860" + integrity sha512-uDfvUjVrfGJJhymx/kz6prltenw1u7WrCg1oa94zYY8xxVpLLUu045LAT0dhDZdXG58/EpPL/5kA180fQ/qudg== + +emoji-regex@^8.0.0: + version "8.0.0" + resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-8.0.0.tgz#e818fd69ce5ccfcb404594f842963bf53164cc37" + integrity sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A== + +encodeurl@~1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/encodeurl/-/encodeurl-1.0.2.tgz#ad3ff4c86ec2d029322f5a02c3a9a606c95b3f59" + integrity sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k= + +enquirer@^2.3.5: + version "2.3.6" + resolved "https://registry.yarnpkg.com/enquirer/-/enquirer-2.3.6.tgz#2a7fe5dd634a1e4125a975ec994ff5456dc3734d" + integrity sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg== + dependencies: + ansi-colors "^4.1.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-html@~1.0.3: + version "1.0.3" + resolved "https://registry.yarnpkg.com/escape-html/-/escape-html-1.0.3.tgz#0258eae4d3d0c0974de1c169188ef0051d1d1988" + integrity sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg= + +escape-string-regexp@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz#1b61c0562190a8dff6ae3bb2cf0200ca130b86d4" + integrity sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ= + +escape-string-regexp@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz#a30304e99daa32e23b2fd20f51babd07cffca344" + integrity sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w== + +escape-string-regexp@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-4.0.0.tgz#14ba83a5d373e3d311e5afca29cf5bfad965bf34" + integrity sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA== + +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" + +eslint-scope@^7.1.0: + version "7.1.0" + resolved "https://registry.yarnpkg.com/eslint-scope/-/eslint-scope-7.1.0.tgz#c1f6ea30ac583031f203d65c73e723b01298f153" + integrity sha512-aWwkhnS0qAXqNOgKOK0dJ2nvzEbhEvpy8OlJ9kZ0FeZnA6zpjv1/Vei+puGFFX7zkPCkHHXb7IDX3A+7yPrRWg== + dependencies: + esrecurse "^4.3.0" + estraverse "^5.2.0" + +eslint-utils@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/eslint-utils/-/eslint-utils-3.0.0.tgz#8aebaface7345bb33559db0a1f13a1d2d48c3672" + integrity sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA== + dependencies: + eslint-visitor-keys "^2.0.0" + +eslint-visitor-keys@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-2.1.0.tgz#f65328259305927392c938ed44eb0a5c9b2bd303" + integrity sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw== + +eslint-visitor-keys@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/eslint-visitor-keys/-/eslint-visitor-keys-3.1.0.tgz#eee4acea891814cda67a7d8812d9647dd0179af2" + integrity sha512-yWJFpu4DtjsWKkt5GeNBBuZMlNcYVs6vRCLoCVEJrTjaSB6LC98gFipNK/erM2Heg/E8mIK+hXG/pJMLK+eRZA== + +eslint@^8.6.0: + version "8.6.0" + resolved "https://registry.yarnpkg.com/eslint/-/eslint-8.6.0.tgz#4318c6a31c5584838c1a2e940c478190f58d558e" + integrity sha512-UvxdOJ7mXFlw7iuHZA4jmzPaUqIw54mZrv+XPYKNbKdLR0et4rf60lIZUU9kiNtnzzMzGWxMV+tQ7uG7JG8DPw== + dependencies: + "@eslint/eslintrc" "^1.0.5" + "@humanwhocodes/config-array" "^0.9.2" + ajv "^6.10.0" + chalk "^4.0.0" + cross-spawn "^7.0.2" + debug "^4.3.2" + doctrine "^3.0.0" + enquirer "^2.3.5" + escape-string-regexp "^4.0.0" + eslint-scope "^7.1.0" + eslint-utils "^3.0.0" + eslint-visitor-keys "^3.1.0" + espree "^9.3.0" + esquery "^1.4.0" + esutils "^2.0.2" + fast-deep-equal "^3.1.3" + file-entry-cache "^6.0.1" + functional-red-black-tree "^1.0.1" + glob-parent "^6.0.1" + globals "^13.6.0" + ignore "^4.0.6" + import-fresh "^3.0.0" + imurmurhash "^0.1.4" + is-glob "^4.0.0" + js-yaml "^4.1.0" + json-stable-stringify-without-jsonify "^1.0.1" + levn "^0.4.1" + lodash.merge "^4.6.2" + minimatch "^3.0.4" + natural-compare "^1.4.0" + optionator "^0.9.1" + progress "^2.0.0" + regexpp "^3.2.0" + semver "^7.2.1" + strip-ansi "^6.0.1" + strip-json-comments "^3.1.0" + text-table "^0.2.0" + v8-compile-cache "^2.0.3" + +espree@^9.2.0, espree@^9.3.0: + version "9.3.0" + resolved "https://registry.yarnpkg.com/espree/-/espree-9.3.0.tgz#c1240d79183b72aaee6ccfa5a90bc9111df085a8" + integrity sha512-d/5nCsb0JcqsSEeQzFZ8DH1RmxPcglRWh24EFTlUEmCKoehXGdpsx0RkHDubqUI8LSAIKMQp4r9SzQ3n+sm4HQ== + dependencies: + acorn "^8.7.0" + acorn-jsx "^5.3.1" + eslint-visitor-keys "^3.1.0" + +esprima@^4.0.0, esprima@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/esprima/-/esprima-4.0.1.tgz#13b04cdb3e6c5d19df91ab6987a8695619b0aa71" + integrity sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A== + +esquery@^1.4.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/esquery/-/esquery-1.4.0.tgz#2148ffc38b82e8c7057dfed48425b3e61f0f24a5" + integrity sha512-cCDispWt5vHHtwMY2YrAQ4ibFkAL8RbH5YGBnZBc90MolvvfkkQcJro/aZiAQUlQ3qgrYS6D6v8Gc5G5CQsc9w== + dependencies: + estraverse "^5.1.0" + +esrecurse@^4.3.0: + version "4.3.0" + resolved "https://registry.yarnpkg.com/esrecurse/-/esrecurse-4.3.0.tgz#7ad7964d679abb28bee72cec63758b1c5d2c9921" + integrity sha512-KmfKL3b6G+RXvP8N1vr3Tq1kL/oCFgn2NYXEtqP8/L3pKapUA4G8cFVaoF3SU323CD4XypR/ffioHmkti6/Tag== + dependencies: + estraverse "^5.2.0" + +estraverse@^5.1.0, estraverse@^5.2.0: + version "5.3.0" + resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-5.3.0.tgz#2eea5290702f26ab8fe5370370ff86c965d21123" + integrity sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA== + +esutils@^2.0.2: + version "2.0.3" + resolved "https://registry.yarnpkg.com/esutils/-/esutils-2.0.3.tgz#74d2eb4de0b8da1293711910d50775b9b710ef64" + integrity sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g== + +etag@~1.8.1: + version "1.8.1" + resolved "https://registry.yarnpkg.com/etag/-/etag-1.8.1.tgz#41ae2eeb65efa62268aebfea83ac7d79299b0887" + integrity sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc= + +execa@^5.0.0: + version "5.1.1" + resolved "https://registry.yarnpkg.com/execa/-/execa-5.1.1.tgz#f80ad9cbf4298f7bd1d4c9555c21e93741c411dd" + integrity sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg== + dependencies: + cross-spawn "^7.0.3" + get-stream "^6.0.0" + human-signals "^2.1.0" + is-stream "^2.0.0" + merge-stream "^2.0.0" + npm-run-path "^4.0.1" + onetime "^5.1.2" + signal-exit "^3.0.3" + strip-final-newline "^2.0.0" + +exit@^0.1.2: + version "0.1.2" + resolved "https://registry.yarnpkg.com/exit/-/exit-0.1.2.tgz#0632638f8d877cc82107d30a0fff1a17cba1cd0c" + integrity sha1-BjJjj42HfMghB9MKD/8aF8uhzQw= + +expect@^27.4.6: + version "27.4.6" + resolved "https://registry.yarnpkg.com/expect/-/expect-27.4.6.tgz#f335e128b0335b6ceb4fcab67ece7cbd14c942e6" + integrity sha512-1M/0kAALIaj5LaG66sFJTbRsWTADnylly82cu4bspI0nl+pgP4E6Bh/aqdHlTUjul06K7xQnnrAoqfxVU0+/ag== + dependencies: + "@jest/types" "^27.4.2" + jest-get-type "^27.4.0" + jest-matcher-utils "^27.4.6" + jest-message-util "^27.4.6" + +express@^4.17.3: + version "4.17.3" + resolved "https://registry.yarnpkg.com/express/-/express-4.17.3.tgz#f6c7302194a4fb54271b73a1fe7a06478c8f85a1" + integrity sha512-yuSQpz5I+Ch7gFrPCk4/c+dIBKlQUxtgwqzph132bsT6qhuzss6I8cLJQz7B3rFblzd6wtcI0ZbGltH/C4LjUg== + dependencies: + accepts "~1.3.8" + array-flatten "1.1.1" + body-parser "1.19.2" + content-disposition "0.5.4" + content-type "~1.0.4" + cookie "0.4.2" + cookie-signature "1.0.6" + debug "2.6.9" + depd "~1.1.2" + encodeurl "~1.0.2" + escape-html "~1.0.3" + etag "~1.8.1" + finalhandler "~1.1.2" + fresh "0.5.2" + merge-descriptors "1.0.1" + methods "~1.1.2" + on-finished "~2.3.0" + parseurl "~1.3.3" + path-to-regexp "0.1.7" + proxy-addr "~2.0.7" + qs "6.9.7" + range-parser "~1.2.1" + safe-buffer "5.2.1" + send "0.17.2" + serve-static "1.14.2" + setprototypeof "1.2.0" + statuses "~1.5.0" + type-is "~1.6.18" + utils-merge "1.0.1" + vary "~1.1.2" + +fast-deep-equal@^3.1.1, fast-deep-equal@^3.1.3: + 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.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz#874bf69c6f404c2b5d99c481341399fd55892633" + integrity sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw== + +fast-levenshtein@^2.0.6, fast-levenshtein@~2.0.6: + version "2.0.6" + resolved "https://registry.yarnpkg.com/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz#3d8a5c66883a16a30ca8643e851f19baa7797917" + integrity sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc= + +fb-watchman@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/fb-watchman/-/fb-watchman-2.0.1.tgz#fc84fb39d2709cf3ff6d743706157bb5708a8a85" + integrity sha512-DkPJKQeY6kKwmuMretBhr7G6Vodr7bFwDYTXIkfG1gjvNpaxBTQV3PbXg6bR1c1UP4jPOX0jHUbbHANL9vRjVg== + dependencies: + bser "2.1.1" + +file-entry-cache@^6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/file-entry-cache/-/file-entry-cache-6.0.1.tgz#211b2dd9659cb0394b073e7323ac3c933d522027" + integrity sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg== + dependencies: + flat-cache "^3.0.4" + +fill-range@^7.0.1: + version "7.0.1" + resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-7.0.1.tgz#1919a6a7c75fe38b2c7c77e5198535da9acdda40" + integrity sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ== + dependencies: + to-regex-range "^5.0.1" + +finalhandler@~1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/finalhandler/-/finalhandler-1.1.2.tgz#b7e7d000ffd11938d0fdb053506f6ebabe9f587d" + integrity sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA== + dependencies: + debug "2.6.9" + encodeurl "~1.0.2" + escape-html "~1.0.3" + on-finished "~2.3.0" + parseurl "~1.3.3" + statuses "~1.5.0" + unpipe "~1.0.0" + +find-up@^4.0.0, find-up@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/find-up/-/find-up-4.1.0.tgz#97afe7d6cdc0bc5928584b7c8d7b16e8a9aa5d19" + integrity sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw== + dependencies: + locate-path "^5.0.0" + path-exists "^4.0.0" + +flat-cache@^3.0.4: + version "3.0.4" + resolved "https://registry.yarnpkg.com/flat-cache/-/flat-cache-3.0.4.tgz#61b0338302b2fe9f957dcc32fc2a87f1c3048b11" + integrity sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg== + dependencies: + flatted "^3.1.0" + rimraf "^3.0.2" + +flatted@^3.1.0: + version "3.2.4" + resolved "https://registry.yarnpkg.com/flatted/-/flatted-3.2.4.tgz#28d9969ea90661b5134259f312ab6aa7929ac5e2" + integrity sha512-8/sOawo8tJ4QOBX8YlQBMxL8+RLZfxMQOif9o0KUKTNTjMYElWPE0r/m5VNFxTRd0NSw8qSy8dajrwX4RYI1Hw== + +follow-redirects@^1.14.4: + version "1.14.8" + resolved "https://registry.yarnpkg.com/follow-redirects/-/follow-redirects-1.14.8.tgz#016996fb9a11a100566398b1c6839337d7bfa8fc" + integrity sha512-1x0S9UVJHsQprFcEC/qnNzBLcIxsjAV905f/UkQxbclCsoTWlacCNOpQa/anodLl2uaEKFhfWOvM2Qg77+15zA== + +form-data@^3.0.0: + version "3.0.1" + resolved "https://registry.yarnpkg.com/form-data/-/form-data-3.0.1.tgz#ebd53791b78356a99af9a300d4282c4d5eb9755f" + integrity sha512-RHkBKtLWUVwd7SqRIvCZMEvAMoGUp0XU+seQiZejj0COz3RI3hWP4sCv3gZWWLjJTd7rGwcsF5eKZGii0r/hbg== + dependencies: + asynckit "^0.4.0" + combined-stream "^1.0.8" + mime-types "^2.1.12" + +forwarded@0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/forwarded/-/forwarded-0.2.0.tgz#2269936428aad4c15c7ebe9779a84bf0b2a81811" + integrity sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow== + +fresh@0.5.2: + version "0.5.2" + resolved "https://registry.yarnpkg.com/fresh/-/fresh-0.5.2.tgz#3d8cadd90d976569fa835ab1f8e4b23a105605a7" + integrity sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac= + +fs.realpath@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f" + integrity sha1-FQStJSMVjKpA20onh8sBQRmU6k8= + +fsevents@^2.3.2: + version "2.3.2" + resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.3.2.tgz#8a526f78b8fdf4623b709e0b975c52c24c02fd1a" + integrity sha512-xiqMQR4xAeHTuB9uWm+fFRcIOgKBMiOBP+eXiyT7jsgVCq1bkVygt00oASowB7EdtpOHaaPgKt812P9ab+DDKA== + +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== + +functional-red-black-tree@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz#1b0ab3bd553b2a0d6399d29c0e3ea0b252078327" + integrity sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc= + +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.5: + version "2.0.5" + resolved "https://registry.yarnpkg.com/get-caller-file/-/get-caller-file-2.0.5.tgz#4f94412a82db32f36e3b0b9741f8a97feb031f7e" + integrity sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg== + +get-package-type@^0.1.0: + version "0.1.0" + resolved "https://registry.yarnpkg.com/get-package-type/-/get-package-type-0.1.0.tgz#8de2d803cff44df3bc6c456e6668b36c3926e11a" + integrity sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q== + +get-stream@^6.0.0: + version "6.0.1" + resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-6.0.1.tgz#a262d8eef67aced57c2852ad6167526a43cbf7b7" + integrity sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg== + +glob-parent@^6.0.1: + version "6.0.2" + resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-6.0.2.tgz#6d237d99083950c79290f24c7642a3de9a28f9e3" + integrity sha512-XxwI8EOhVQgWp6iDL+3b0r86f4d6AX6zSU55HfB4ydCEuXLXc5FcYeOu+nnGftS4TEju/11rt4KJPTMgbfmv4A== + dependencies: + is-glob "^4.0.3" + +glob@^7.1.1, glob@^7.1.2, glob@^7.1.3, glob@^7.1.4: + version "7.2.0" + resolved "https://registry.yarnpkg.com/glob/-/glob-7.2.0.tgz#d15535af7732e02e948f4c41628bd910293f6023" + integrity sha512-lmLf6gtyrPq8tTjSmrO94wBeQbFR3HbLHbuyD69wuyQkImp2hWqMGB47OX65FBkPffO641IP9jWa1z4ivqG26Q== + dependencies: + fs.realpath "^1.0.0" + inflight "^1.0.4" + inherits "2" + minimatch "^3.0.4" + once "^1.3.0" + path-is-absolute "^1.0.0" + +globals@^11.1.0: + version "11.12.0" + resolved "https://registry.yarnpkg.com/globals/-/globals-11.12.0.tgz#ab8795338868a0babd8525758018c2a7eb95c42e" + integrity sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA== + +globals@^13.6.0, globals@^13.9.0: + version "13.12.0" + resolved "https://registry.yarnpkg.com/globals/-/globals-13.12.0.tgz#4d733760304230a0082ed96e21e5c565f898089e" + integrity sha512-uS8X6lSKN2JumVoXrbUz+uG4BYG+eiawqm3qFcT7ammfbUHeCBoJMlHcec/S3krSk73/AE/f0szYFmgAA3kYZg== + dependencies: + type-fest "^0.20.2" + +graceful-fs@^4.2.4: + version "4.2.9" + resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.9.tgz#041b05df45755e587a24942279b9d113146e1c96" + integrity sha512-NtNxqUcXgpW2iMrfqSfR73Glt39K+BLwWsPs94yR63v45T0Wbej7eRmL5cWfwEgqXnmjQp3zaJTshdRW/qC2ZQ== + +has-flag@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-3.0.0.tgz#b5d454dc2199ae225699f3467e5a07f3b955bafd" + integrity sha1-tdRU3CGZriJWmfNGfloH87lVuv0= + +has-flag@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-4.0.0.tgz#944771fd9c81c81265c4d6941860da06bb59479b" + integrity sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ== + +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" + +html-encoding-sniffer@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/html-encoding-sniffer/-/html-encoding-sniffer-2.0.1.tgz#42a6dc4fd33f00281176e8b23759ca4e4fa185f3" + integrity sha512-D5JbOMBIR/TVZkubHT+OyT2705QvogUW4IBn6nHd756OwieSF9aDYFj4dv6HHEVGYbHaLETa3WggZYWWMyy3ZQ== + dependencies: + whatwg-encoding "^1.0.5" + +html-escaper@^2.0.0: + version "2.0.2" + resolved "https://registry.yarnpkg.com/html-escaper/-/html-escaper-2.0.2.tgz#dfd60027da36a36dfcbe236262c00a5822681453" + integrity sha512-H2iMtd0I4Mt5eYiapRdIDjp+XzelXQ0tFE4JS7YFwFevXXMmOp9myNrUvCg0D6ws8iqkRPBfKHgbwig1SmlLfg== + +http-errors@1.8.1: + version "1.8.1" + resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-1.8.1.tgz#7c3f28577cbc8a207388455dbd62295ed07bd68c" + integrity sha512-Kpk9Sm7NmI+RHhnj6OIWDI1d6fIoFAtFt9RLaTMRlg/8w49juAStsrBgp0Dp4OdxdVbRIeKhtCUvoi/RuAhO4g== + dependencies: + depd "~1.1.2" + inherits "2.0.4" + setprototypeof "1.2.0" + statuses ">= 1.5.0 < 2" + toidentifier "1.0.1" + +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.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@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/human-signals/-/human-signals-2.1.0.tgz#dc91fcba42e4d06e4abaed33b3e7a3c02f514ea0" + integrity sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw== + +iconv-lite@0.4.24: + version "0.4.24" + resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.4.24.tgz#2022b4b25fbddc21d2f524974a474aafe733908b" + integrity sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA== + dependencies: + safer-buffer ">= 2.1.2 < 3" + +ignore@^4.0.6: + version "4.0.6" + resolved "https://registry.yarnpkg.com/ignore/-/ignore-4.0.6.tgz#750e3db5862087b4737ebac8207ffd1ef27b25fc" + integrity sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg== + +import-fresh@^3.0.0, import-fresh@^3.2.1: + version "3.3.0" + resolved "https://registry.yarnpkg.com/import-fresh/-/import-fresh-3.3.0.tgz#37162c25fcb9ebaa2e6e53d5b4d88ce17d9e0c2b" + integrity sha512-veYYhQa+D1QBKznvhUHxb8faxlrwUnxseDAbAp457E0wLNio2bOSKnjYDhMj+YiAq61xrMGhQk9iXVk5FzgQMw== + dependencies: + parent-module "^1.0.0" + resolve-from "^4.0.0" + +import-local@^3.0.2: + version "3.0.3" + resolved "https://registry.yarnpkg.com/import-local/-/import-local-3.0.3.tgz#4d51c2c495ca9393da259ec66b62e022920211e0" + integrity sha512-bE9iaUY3CXH8Cwfan/abDKAxe1KGT9kyGsBPqf6DMK/z0a2OzAsrukeYNgIH6cH5Xr452jb1TUL8rSfCLjZ9uA== + dependencies: + pkg-dir "^4.2.0" + resolve-cwd "^3.0.0" + +imurmurhash@^0.1.4: + version "0.1.4" + resolved "https://registry.yarnpkg.com/imurmurhash/-/imurmurhash-0.1.4.tgz#9218b9b2b928a238b13dc4fb6b6d576f231453ea" + integrity sha1-khi5srkoojixPcT7a21XbyMUU+o= + +inflight@^1.0.4: + version "1.0.6" + resolved "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9" + integrity sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk= + dependencies: + once "^1.3.0" + wrappy "1" + +inherits@2, inherits@2.0.4: + version "2.0.4" + resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c" + integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== + +ipaddr.js@1.9.1: + version "1.9.1" + resolved "https://registry.yarnpkg.com/ipaddr.js/-/ipaddr.js-1.9.1.tgz#bff38543eeb8984825079ff3a2a8e6cbd46781b3" + integrity sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g== + +is-core-module@^2.8.0: + version "2.8.1" + resolved "https://registry.yarnpkg.com/is-core-module/-/is-core-module-2.8.1.tgz#f59fdfca701d5879d0a6b100a40aa1560ce27211" + integrity sha512-SdNCUs284hr40hFTFP6l0IfZ/RSrMXF3qgoRHd3/79unUTvrFO/JoXwkGm+5J/Oe3E/b5GsnG330uUNgRpu1PA== + dependencies: + has "^1.0.3" + +is-extglob@^2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/is-extglob/-/is-extglob-2.1.1.tgz#a88c02535791f02ed37c76a1b9ea9773c833f8c2" + integrity sha1-qIwCU1eR8C7TfHahueqXc8gz+MI= + +is-fullwidth-code-point@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz#f116f8064fe90b3f7844a38997c0b75051269f1d" + integrity sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg== + +is-generator-fn@^2.0.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/is-generator-fn/-/is-generator-fn-2.1.0.tgz#7d140adc389aaf3011a8f2a2a4cfa6faadffb118" + integrity sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ== + +is-glob@^4.0.0, is-glob@^4.0.3: + version "4.0.3" + resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.3.tgz#64f61e42cbbb2eec2071a9dac0b28ba1e65d5084" + integrity sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg== + dependencies: + is-extglob "^2.1.1" + +is-number@^7.0.0: + version "7.0.0" + resolved "https://registry.yarnpkg.com/is-number/-/is-number-7.0.0.tgz#7535345b896734d5f80c4d06c50955527a14f12b" + integrity sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng== + +is-potential-custom-element-name@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/is-potential-custom-element-name/-/is-potential-custom-element-name-1.0.1.tgz#171ed6f19e3ac554394edf78caa05784a45bebb5" + integrity sha512-bCYeRA2rVibKZd+s2625gGnGF/t7DSqDs4dP7CrLA1m7jKWz6pps0LpYLJN8Q64HtmPKJ1hrN3nzPNKFEKOUiQ== + +is-stream@^2.0.0: + version "2.0.1" + resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-2.0.1.tgz#fac1e3d53b97ad5a9d0ae9cef2389f5810a5c077" + integrity sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg== + +is-typedarray@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/is-typedarray/-/is-typedarray-1.0.0.tgz#e479c80858df0c1b11ddda6940f96011fcda4a9a" + integrity sha1-5HnICFjfDBsR3dppQPlgEfzaSpo= + +isexe@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/isexe/-/isexe-2.0.0.tgz#e8fbf374dc556ff8947a10dcb0572d633f2cfa10" + integrity sha1-6PvzdNxVb/iUehDcsFctYz8s+hA= + +istanbul-lib-coverage@^3.0.0, istanbul-lib-coverage@^3.2.0: + version "3.2.0" + resolved "https://registry.yarnpkg.com/istanbul-lib-coverage/-/istanbul-lib-coverage-3.2.0.tgz#189e7909d0a39fa5a3dfad5b03f71947770191d3" + integrity sha512-eOeJ5BHCmHYvQK7xt9GkdHuzuCGS1Y6g9Gvnx3Ym33fz/HpLRYxiS0wHNr+m/MBC8B647Xt608vCDEvhl9c6Mw== + +istanbul-lib-instrument@^5.0.4, istanbul-lib-instrument@^5.1.0: + version "5.1.0" + resolved "https://registry.yarnpkg.com/istanbul-lib-instrument/-/istanbul-lib-instrument-5.1.0.tgz#7b49198b657b27a730b8e9cb601f1e1bff24c59a" + integrity sha512-czwUz525rkOFDJxfKK6mYfIs9zBKILyrZQxjz3ABhjQXhbhFsSbo1HW/BFcsDnfJYJWA6thRR5/TUY2qs5W99Q== + dependencies: + "@babel/core" "^7.12.3" + "@babel/parser" "^7.14.7" + "@istanbuljs/schema" "^0.1.2" + istanbul-lib-coverage "^3.2.0" + semver "^6.3.0" + +istanbul-lib-report@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz#7518fe52ea44de372f460a76b5ecda9ffb73d8a6" + integrity sha512-wcdi+uAKzfiGT2abPpKZ0hSU1rGQjUQnLvtY5MpQ7QCTahD3VODhcu4wcfY1YtkGaDD5yuydOLINXsfbus9ROw== + dependencies: + istanbul-lib-coverage "^3.0.0" + make-dir "^3.0.0" + supports-color "^7.1.0" + +istanbul-lib-source-maps@^4.0.0: + version "4.0.1" + resolved "https://registry.yarnpkg.com/istanbul-lib-source-maps/-/istanbul-lib-source-maps-4.0.1.tgz#895f3a709fcfba34c6de5a42939022f3e4358551" + integrity sha512-n3s8EwkdFIJCG3BPKBYvskgXGoy88ARzvegkitk60NxRdwltLOTaH7CUiMRXvwYorl0Q712iEjcWB+fK/MrWVw== + dependencies: + debug "^4.1.1" + istanbul-lib-coverage "^3.0.0" + source-map "^0.6.1" + +istanbul-reports@^3.1.3: + version "3.1.3" + resolved "https://registry.yarnpkg.com/istanbul-reports/-/istanbul-reports-3.1.3.tgz#4bcae3103b94518117930d51283690960b50d3c2" + integrity sha512-x9LtDVtfm/t1GFiLl3NffC7hz+I1ragvgX1P/Lg1NlIagifZDKUkuuaAxH/qpwj2IuEfD8G2Bs/UKp+sZ/pKkg== + dependencies: + html-escaper "^2.0.0" + istanbul-lib-report "^3.0.0" + +jest-changed-files@^27.4.2: + version "27.4.2" + resolved "https://registry.yarnpkg.com/jest-changed-files/-/jest-changed-files-27.4.2.tgz#da2547ea47c6e6a5f6ed336151bd2075736eb4a5" + integrity sha512-/9x8MjekuzUQoPjDHbBiXbNEBauhrPU2ct7m8TfCg69ywt1y/N+yYwGh3gCpnqUS3klYWDU/lSNgv+JhoD2k1A== + dependencies: + "@jest/types" "^27.4.2" + execa "^5.0.0" + throat "^6.0.1" + +jest-circus@^27.4.6: + version "27.4.6" + resolved "https://registry.yarnpkg.com/jest-circus/-/jest-circus-27.4.6.tgz#d3af34c0eb742a967b1919fbb351430727bcea6c" + integrity sha512-UA7AI5HZrW4wRM72Ro80uRR2Fg+7nR0GESbSI/2M+ambbzVuA63mn5T1p3Z/wlhntzGpIG1xx78GP2YIkf6PhQ== + dependencies: + "@jest/environment" "^27.4.6" + "@jest/test-result" "^27.4.6" + "@jest/types" "^27.4.2" + "@types/node" "*" + chalk "^4.0.0" + co "^4.6.0" + dedent "^0.7.0" + expect "^27.4.6" + is-generator-fn "^2.0.0" + jest-each "^27.4.6" + jest-matcher-utils "^27.4.6" + jest-message-util "^27.4.6" + jest-runtime "^27.4.6" + jest-snapshot "^27.4.6" + jest-util "^27.4.2" + pretty-format "^27.4.6" + slash "^3.0.0" + stack-utils "^2.0.3" + throat "^6.0.1" + +jest-cli@^27.4.7: + version "27.4.7" + resolved "https://registry.yarnpkg.com/jest-cli/-/jest-cli-27.4.7.tgz#d00e759e55d77b3bcfea0715f527c394ca314e5a" + integrity sha512-zREYhvjjqe1KsGV15mdnxjThKNDgza1fhDT+iUsXWLCq3sxe9w5xnvyctcYVT5PcdLSjv7Y5dCwTS3FCF1tiuw== + dependencies: + "@jest/core" "^27.4.7" + "@jest/test-result" "^27.4.6" + "@jest/types" "^27.4.2" + chalk "^4.0.0" + exit "^0.1.2" + graceful-fs "^4.2.4" + import-local "^3.0.2" + jest-config "^27.4.7" + jest-util "^27.4.2" + jest-validate "^27.4.6" + prompts "^2.0.1" + yargs "^16.2.0" + +jest-config@^27.4.7: + version "27.4.7" + resolved "https://registry.yarnpkg.com/jest-config/-/jest-config-27.4.7.tgz#4f084b2acbd172c8b43aa4cdffe75d89378d3972" + integrity sha512-xz/o/KJJEedHMrIY9v2ParIoYSrSVY6IVeE4z5Z3i101GoA5XgfbJz+1C8EYPsv7u7f39dS8F9v46BHDhn0vlw== + dependencies: + "@babel/core" "^7.8.0" + "@jest/test-sequencer" "^27.4.6" + "@jest/types" "^27.4.2" + babel-jest "^27.4.6" + chalk "^4.0.0" + ci-info "^3.2.0" + deepmerge "^4.2.2" + glob "^7.1.1" + graceful-fs "^4.2.4" + jest-circus "^27.4.6" + jest-environment-jsdom "^27.4.6" + jest-environment-node "^27.4.6" + jest-get-type "^27.4.0" + jest-jasmine2 "^27.4.6" + jest-regex-util "^27.4.0" + jest-resolve "^27.4.6" + jest-runner "^27.4.6" + jest-util "^27.4.2" + jest-validate "^27.4.6" + micromatch "^4.0.4" + pretty-format "^27.4.6" + slash "^3.0.0" + +jest-diff@^27.4.6: + version "27.4.6" + resolved "https://registry.yarnpkg.com/jest-diff/-/jest-diff-27.4.6.tgz#93815774d2012a2cbb6cf23f84d48c7a2618f98d" + integrity sha512-zjaB0sh0Lb13VyPsd92V7HkqF6yKRH9vm33rwBt7rPYrpQvS1nCvlIy2pICbKta+ZjWngYLNn4cCK4nyZkjS/w== + dependencies: + chalk "^4.0.0" + diff-sequences "^27.4.0" + jest-get-type "^27.4.0" + pretty-format "^27.4.6" + +jest-docblock@^27.4.0: + version "27.4.0" + resolved "https://registry.yarnpkg.com/jest-docblock/-/jest-docblock-27.4.0.tgz#06c78035ca93cbbb84faf8fce64deae79a59f69f" + integrity sha512-7TBazUdCKGV7svZ+gh7C8esAnweJoG+SvcF6Cjqj4l17zA2q1cMwx2JObSioubk317H+cjcHgP+7fTs60paulg== + dependencies: + detect-newline "^3.0.0" + +jest-each@^27.4.6: + version "27.4.6" + resolved "https://registry.yarnpkg.com/jest-each/-/jest-each-27.4.6.tgz#e7e8561be61d8cc6dbf04296688747ab186c40ff" + integrity sha512-n6QDq8y2Hsmn22tRkgAk+z6MCX7MeVlAzxmZDshfS2jLcaBlyhpF3tZSJLR+kXmh23GEvS0ojMR8i6ZeRvpQcA== + dependencies: + "@jest/types" "^27.4.2" + chalk "^4.0.0" + jest-get-type "^27.4.0" + jest-util "^27.4.2" + pretty-format "^27.4.6" + +jest-environment-jsdom@^27.4.6: + version "27.4.6" + resolved "https://registry.yarnpkg.com/jest-environment-jsdom/-/jest-environment-jsdom-27.4.6.tgz#c23a394eb445b33621dfae9c09e4c8021dea7b36" + integrity sha512-o3dx5p/kHPbUlRvSNjypEcEtgs6LmvESMzgRFQE6c+Prwl2JLA4RZ7qAnxc5VM8kutsGRTB15jXeeSbJsKN9iA== + dependencies: + "@jest/environment" "^27.4.6" + "@jest/fake-timers" "^27.4.6" + "@jest/types" "^27.4.2" + "@types/node" "*" + jest-mock "^27.4.6" + jest-util "^27.4.2" + jsdom "^16.6.0" + +jest-environment-node@^27.4.6: + version "27.4.6" + resolved "https://registry.yarnpkg.com/jest-environment-node/-/jest-environment-node-27.4.6.tgz#ee8cd4ef458a0ef09d087c8cd52ca5856df90242" + integrity sha512-yfHlZ9m+kzTKZV0hVfhVu6GuDxKAYeFHrfulmy7Jxwsq4V7+ZK7f+c0XP/tbVDMQW7E4neG2u147hFkuVz0MlQ== + dependencies: + "@jest/environment" "^27.4.6" + "@jest/fake-timers" "^27.4.6" + "@jest/types" "^27.4.2" + "@types/node" "*" + jest-mock "^27.4.6" + jest-util "^27.4.2" + +jest-get-type@^27.4.0: + version "27.4.0" + resolved "https://registry.yarnpkg.com/jest-get-type/-/jest-get-type-27.4.0.tgz#7503d2663fffa431638337b3998d39c5e928e9b5" + integrity sha512-tk9o+ld5TWq41DkK14L4wox4s2D9MtTpKaAVzXfr5CUKm5ZK2ExcaFE0qls2W71zE/6R2TxxrK9w2r6svAFDBQ== + +jest-haste-map@^27.4.6: + version "27.4.6" + resolved "https://registry.yarnpkg.com/jest-haste-map/-/jest-haste-map-27.4.6.tgz#c60b5233a34ca0520f325b7e2cc0a0140ad0862a" + integrity sha512-0tNpgxg7BKurZeFkIOvGCkbmOHbLFf4LUQOxrQSMjvrQaQe3l6E8x6jYC1NuWkGo5WDdbr8FEzUxV2+LWNawKQ== + dependencies: + "@jest/types" "^27.4.2" + "@types/graceful-fs" "^4.1.2" + "@types/node" "*" + anymatch "^3.0.3" + fb-watchman "^2.0.0" + graceful-fs "^4.2.4" + jest-regex-util "^27.4.0" + jest-serializer "^27.4.0" + jest-util "^27.4.2" + jest-worker "^27.4.6" + micromatch "^4.0.4" + walker "^1.0.7" + optionalDependencies: + fsevents "^2.3.2" + +jest-jasmine2@^27.4.6: + version "27.4.6" + resolved "https://registry.yarnpkg.com/jest-jasmine2/-/jest-jasmine2-27.4.6.tgz#109e8bc036cb455950ae28a018f983f2abe50127" + integrity sha512-uAGNXF644I/whzhsf7/qf74gqy9OuhvJ0XYp8SDecX2ooGeaPnmJMjXjKt0mqh1Rl5dtRGxJgNrHlBQIBfS5Nw== + dependencies: + "@jest/environment" "^27.4.6" + "@jest/source-map" "^27.4.0" + "@jest/test-result" "^27.4.6" + "@jest/types" "^27.4.2" + "@types/node" "*" + chalk "^4.0.0" + co "^4.6.0" + expect "^27.4.6" + is-generator-fn "^2.0.0" + jest-each "^27.4.6" + jest-matcher-utils "^27.4.6" + jest-message-util "^27.4.6" + jest-runtime "^27.4.6" + jest-snapshot "^27.4.6" + jest-util "^27.4.2" + pretty-format "^27.4.6" + throat "^6.0.1" + +jest-leak-detector@^27.4.6: + version "27.4.6" + resolved "https://registry.yarnpkg.com/jest-leak-detector/-/jest-leak-detector-27.4.6.tgz#ed9bc3ce514b4c582637088d9faf58a33bd59bf4" + integrity sha512-kkaGixDf9R7CjHm2pOzfTxZTQQQ2gHTIWKY/JZSiYTc90bZp8kSZnUMS3uLAfwTZwc0tcMRoEX74e14LG1WapA== + dependencies: + jest-get-type "^27.4.0" + pretty-format "^27.4.6" + +jest-matcher-utils@^27.4.6: + version "27.4.6" + resolved "https://registry.yarnpkg.com/jest-matcher-utils/-/jest-matcher-utils-27.4.6.tgz#53ca7f7b58170638590e946f5363b988775509b8" + integrity sha512-XD4PKT3Wn1LQnRAq7ZsTI0VRuEc9OrCPFiO1XL7bftTGmfNF0DcEwMHRgqiu7NGf8ZoZDREpGrCniDkjt79WbA== + dependencies: + chalk "^4.0.0" + jest-diff "^27.4.6" + jest-get-type "^27.4.0" + pretty-format "^27.4.6" + +jest-message-util@^27.4.6: + version "27.4.6" + resolved "https://registry.yarnpkg.com/jest-message-util/-/jest-message-util-27.4.6.tgz#9fdde41a33820ded3127465e1a5896061524da31" + integrity sha512-0p5szriFU0U74czRSFjH6RyS7UYIAkn/ntwMuOwTGWrQIOh5NzXXrq72LOqIkJKKvFbPq+byZKuBz78fjBERBA== + dependencies: + "@babel/code-frame" "^7.12.13" + "@jest/types" "^27.4.2" + "@types/stack-utils" "^2.0.0" + chalk "^4.0.0" + graceful-fs "^4.2.4" + micromatch "^4.0.4" + pretty-format "^27.4.6" + slash "^3.0.0" + stack-utils "^2.0.3" + +jest-mock@^27.4.6: + version "27.4.6" + resolved "https://registry.yarnpkg.com/jest-mock/-/jest-mock-27.4.6.tgz#77d1ba87fbd33ccb8ef1f061697e7341b7635195" + integrity sha512-kvojdYRkst8iVSZ1EJ+vc1RRD9llueBjKzXzeCytH3dMM7zvPV/ULcfI2nr0v0VUgm3Bjt3hBCQvOeaBz+ZTHw== + dependencies: + "@jest/types" "^27.4.2" + "@types/node" "*" + +jest-pnp-resolver@^1.2.2: + version "1.2.2" + resolved "https://registry.yarnpkg.com/jest-pnp-resolver/-/jest-pnp-resolver-1.2.2.tgz#b704ac0ae028a89108a4d040b3f919dfddc8e33c" + integrity sha512-olV41bKSMm8BdnuMsewT4jqlZ8+3TCARAXjZGT9jcoSnrfUnRCqnMoF9XEeoWjbzObpqF9dRhHQj0Xb9QdF6/w== + +jest-regex-util@^27.4.0: + version "27.4.0" + resolved "https://registry.yarnpkg.com/jest-regex-util/-/jest-regex-util-27.4.0.tgz#e4c45b52653128843d07ad94aec34393ea14fbca" + integrity sha512-WeCpMpNnqJYMQoOjm1nTtsgbR4XHAk1u00qDoNBQoykM280+/TmgA5Qh5giC1ecy6a5d4hbSsHzpBtu5yvlbEg== + +jest-resolve-dependencies@^27.4.6: + version "27.4.6" + resolved "https://registry.yarnpkg.com/jest-resolve-dependencies/-/jest-resolve-dependencies-27.4.6.tgz#fc50ee56a67d2c2183063f6a500cc4042b5e2327" + integrity sha512-W85uJZcFXEVZ7+MZqIPCscdjuctruNGXUZ3OHSXOfXR9ITgbUKeHj+uGcies+0SsvI5GtUfTw4dY7u9qjTvQOw== + dependencies: + "@jest/types" "^27.4.2" + jest-regex-util "^27.4.0" + jest-snapshot "^27.4.6" + +jest-resolve@^27.4.6: + version "27.4.6" + resolved "https://registry.yarnpkg.com/jest-resolve/-/jest-resolve-27.4.6.tgz#2ec3110655e86d5bfcfa992e404e22f96b0b5977" + integrity sha512-SFfITVApqtirbITKFAO7jOVN45UgFzcRdQanOFzjnbd+CACDoyeX7206JyU92l4cRr73+Qy/TlW51+4vHGt+zw== + dependencies: + "@jest/types" "^27.4.2" + chalk "^4.0.0" + graceful-fs "^4.2.4" + jest-haste-map "^27.4.6" + jest-pnp-resolver "^1.2.2" + jest-util "^27.4.2" + jest-validate "^27.4.6" + resolve "^1.20.0" + resolve.exports "^1.1.0" + slash "^3.0.0" + +jest-runner@^27.4.6: + version "27.4.6" + resolved "https://registry.yarnpkg.com/jest-runner/-/jest-runner-27.4.6.tgz#1d390d276ec417e9b4d0d081783584cbc3e24773" + integrity sha512-IDeFt2SG4DzqalYBZRgbbPmpwV3X0DcntjezPBERvnhwKGWTW7C5pbbA5lVkmvgteeNfdd/23gwqv3aiilpYPg== + dependencies: + "@jest/console" "^27.4.6" + "@jest/environment" "^27.4.6" + "@jest/test-result" "^27.4.6" + "@jest/transform" "^27.4.6" + "@jest/types" "^27.4.2" + "@types/node" "*" + chalk "^4.0.0" + emittery "^0.8.1" + exit "^0.1.2" + graceful-fs "^4.2.4" + jest-docblock "^27.4.0" + jest-environment-jsdom "^27.4.6" + jest-environment-node "^27.4.6" + jest-haste-map "^27.4.6" + jest-leak-detector "^27.4.6" + jest-message-util "^27.4.6" + jest-resolve "^27.4.6" + jest-runtime "^27.4.6" + jest-util "^27.4.2" + jest-worker "^27.4.6" + source-map-support "^0.5.6" + throat "^6.0.1" + +jest-runtime@^27.4.6: + version "27.4.6" + resolved "https://registry.yarnpkg.com/jest-runtime/-/jest-runtime-27.4.6.tgz#83ae923818e3ea04463b22f3597f017bb5a1cffa" + integrity sha512-eXYeoR/MbIpVDrjqy5d6cGCFOYBFFDeKaNWqTp0h6E74dK0zLHzASQXJpl5a2/40euBmKnprNLJ0Kh0LCndnWQ== + dependencies: + "@jest/environment" "^27.4.6" + "@jest/fake-timers" "^27.4.6" + "@jest/globals" "^27.4.6" + "@jest/source-map" "^27.4.0" + "@jest/test-result" "^27.4.6" + "@jest/transform" "^27.4.6" + "@jest/types" "^27.4.2" + chalk "^4.0.0" + cjs-module-lexer "^1.0.0" + collect-v8-coverage "^1.0.0" + execa "^5.0.0" + glob "^7.1.3" + graceful-fs "^4.2.4" + jest-haste-map "^27.4.6" + jest-message-util "^27.4.6" + jest-mock "^27.4.6" + jest-regex-util "^27.4.0" + jest-resolve "^27.4.6" + jest-snapshot "^27.4.6" + jest-util "^27.4.2" + slash "^3.0.0" + strip-bom "^4.0.0" + +jest-serializer@^27.4.0: + version "27.4.0" + resolved "https://registry.yarnpkg.com/jest-serializer/-/jest-serializer-27.4.0.tgz#34866586e1cae2388b7d12ffa2c7819edef5958a" + integrity sha512-RDhpcn5f1JYTX2pvJAGDcnsNTnsV9bjYPU8xcV+xPwOXnUPOQwf4ZEuiU6G9H1UztH+OapMgu/ckEVwO87PwnQ== + dependencies: + "@types/node" "*" + graceful-fs "^4.2.4" + +jest-snapshot@^27.4.6: + version "27.4.6" + resolved "https://registry.yarnpkg.com/jest-snapshot/-/jest-snapshot-27.4.6.tgz#e2a3b4fff8bdce3033f2373b2e525d8b6871f616" + integrity sha512-fafUCDLQfzuNP9IRcEqaFAMzEe7u5BF7mude51wyWv7VRex60WznZIC7DfKTgSIlJa8aFzYmXclmN328aqSDmQ== + dependencies: + "@babel/core" "^7.7.2" + "@babel/generator" "^7.7.2" + "@babel/plugin-syntax-typescript" "^7.7.2" + "@babel/traverse" "^7.7.2" + "@babel/types" "^7.0.0" + "@jest/transform" "^27.4.6" + "@jest/types" "^27.4.2" + "@types/babel__traverse" "^7.0.4" + "@types/prettier" "^2.1.5" + babel-preset-current-node-syntax "^1.0.0" + chalk "^4.0.0" + expect "^27.4.6" + graceful-fs "^4.2.4" + jest-diff "^27.4.6" + jest-get-type "^27.4.0" + jest-haste-map "^27.4.6" + jest-matcher-utils "^27.4.6" + jest-message-util "^27.4.6" + jest-util "^27.4.2" + natural-compare "^1.4.0" + pretty-format "^27.4.6" + semver "^7.3.2" + +jest-util@^27.4.2: + version "27.4.2" + resolved "https://registry.yarnpkg.com/jest-util/-/jest-util-27.4.2.tgz#ed95b05b1adfd761e2cda47e0144c6a58e05a621" + integrity sha512-YuxxpXU6nlMan9qyLuxHaMMOzXAl5aGZWCSzben5DhLHemYQxCc4YK+4L3ZrCutT8GPQ+ui9k5D8rUJoDioMnA== + dependencies: + "@jest/types" "^27.4.2" + "@types/node" "*" + chalk "^4.0.0" + ci-info "^3.2.0" + graceful-fs "^4.2.4" + picomatch "^2.2.3" + +jest-validate@^27.4.6: + version "27.4.6" + resolved "https://registry.yarnpkg.com/jest-validate/-/jest-validate-27.4.6.tgz#efc000acc4697b6cf4fa68c7f3f324c92d0c4f1f" + integrity sha512-872mEmCPVlBqbA5dToC57vA3yJaMRfIdpCoD3cyHWJOMx+SJwLNw0I71EkWs41oza/Er9Zno9XuTkRYCPDUJXQ== + dependencies: + "@jest/types" "^27.4.2" + camelcase "^6.2.0" + chalk "^4.0.0" + jest-get-type "^27.4.0" + leven "^3.1.0" + pretty-format "^27.4.6" + +jest-watcher@^27.4.6: + version "27.4.6" + resolved "https://registry.yarnpkg.com/jest-watcher/-/jest-watcher-27.4.6.tgz#673679ebeffdd3f94338c24f399b85efc932272d" + integrity sha512-yKQ20OMBiCDigbD0quhQKLkBO+ObGN79MO4nT7YaCuQ5SM+dkBNWE8cZX0FjU6czwMvWw6StWbe+Wv4jJPJ+fw== + dependencies: + "@jest/test-result" "^27.4.6" + "@jest/types" "^27.4.2" + "@types/node" "*" + ansi-escapes "^4.2.1" + chalk "^4.0.0" + jest-util "^27.4.2" + string-length "^4.0.1" + +jest-worker@^27.4.6: + version "27.4.6" + resolved "https://registry.yarnpkg.com/jest-worker/-/jest-worker-27.4.6.tgz#5d2d93db419566cb680752ca0792780e71b3273e" + integrity sha512-gHWJF/6Xi5CTG5QCvROr6GcmpIqNYpDJyc8A1h/DyXqH1tD6SnRCM0d3U5msV31D2LB/U+E0M+W4oyvKV44oNw== + dependencies: + "@types/node" "*" + merge-stream "^2.0.0" + supports-color "^8.0.0" + +jest@^27.4.6: + version "27.4.7" + resolved "https://registry.yarnpkg.com/jest/-/jest-27.4.7.tgz#87f74b9026a1592f2da05b4d258e57505f28eca4" + integrity sha512-8heYvsx7nV/m8m24Vk26Y87g73Ba6ueUd0MWed/NXMhSZIm62U/llVbS0PJe1SHunbyXjJ/BqG1z9bFjGUIvTg== + dependencies: + "@jest/core" "^27.4.7" + import-local "^3.0.2" + jest-cli "^27.4.7" + +js-tokens@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/js-tokens/-/js-tokens-4.0.0.tgz#19203fb59991df98e3a287050d4647cdeaf32499" + integrity sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ== + +js-yaml@^3.13.1: + version "3.14.1" + resolved "https://registry.yarnpkg.com/js-yaml/-/js-yaml-3.14.1.tgz#dae812fdb3825fa306609a8717383c50c36a0537" + integrity sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g== + dependencies: + argparse "^1.0.7" + esprima "^4.0.0" + +js-yaml@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/js-yaml/-/js-yaml-4.1.0.tgz#c1fb65f8f5017901cdd2c951864ba18458a10602" + integrity sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA== + dependencies: + argparse "^2.0.1" + +jsdom@^16.6.0: + version "16.7.0" + resolved "https://registry.yarnpkg.com/jsdom/-/jsdom-16.7.0.tgz#918ae71965424b197c819f8183a754e18977b710" + integrity sha512-u9Smc2G1USStM+s/x1ru5Sxrl6mPYCbByG1U/hUmqaVsm4tbNyS7CicOSRyuGQYZhTu0h84qkZZQ/I+dzizSVw== + dependencies: + abab "^2.0.5" + acorn "^8.2.4" + acorn-globals "^6.0.0" + cssom "^0.4.4" + cssstyle "^2.3.0" + data-urls "^2.0.0" + decimal.js "^10.2.1" + domexception "^2.0.1" + escodegen "^2.0.0" + form-data "^3.0.0" + html-encoding-sniffer "^2.0.1" + http-proxy-agent "^4.0.1" + https-proxy-agent "^5.0.0" + is-potential-custom-element-name "^1.0.1" + nwsapi "^2.2.0" + parse5 "6.0.1" + saxes "^5.0.1" + symbol-tree "^3.2.4" + tough-cookie "^4.0.0" + w3c-hr-time "^1.0.2" + w3c-xmlserializer "^2.0.0" + webidl-conversions "^6.1.0" + whatwg-encoding "^1.0.5" + whatwg-mimetype "^2.3.0" + whatwg-url "^8.5.0" + ws "^7.4.6" + xml-name-validator "^3.0.0" + +jsesc@^2.5.1: + version "2.5.2" + resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-2.5.2.tgz#80564d2e483dacf6e8ef209650a67df3f0c283a4" + integrity sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA== + +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-stable-stringify-without-jsonify@^1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz#9db7b59496ad3f3cfef30a75142d2d930ad72651" + integrity sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE= + +json5@^2.1.2: + version "2.2.3" + resolved "https://registry.yarnpkg.com/json5/-/json5-2.2.3.tgz#78cd6f1a19bdc12b73db5ad0c61efd66c1e29283" + integrity sha512-XmOWe7eyHYH14cLdVPoyg+GOH3rYX++KpzrylJwSW98t3Nk+U8XOl8FWKOgwtzdb8lXGf6zYwDUzeHMWfxasyg== + +kleur@^3.0.3: + version "3.0.3" + resolved "https://registry.yarnpkg.com/kleur/-/kleur-3.0.3.tgz#a79c9ecc86ee1ce3fa6206d1216c501f147fc07e" + integrity sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w== + +leven@^3.1.0: + version "3.1.0" + resolved "https://registry.yarnpkg.com/leven/-/leven-3.1.0.tgz#77891de834064cccba82ae7842bb6b14a13ed7f2" + integrity sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A== + +levn@^0.4.1: + version "0.4.1" + resolved "https://registry.yarnpkg.com/levn/-/levn-0.4.1.tgz#ae4562c007473b932a6200d403268dd2fffc6ade" + integrity sha512-+bT2uH4E5LGE7h/n3evcS/sQlJXCpIp6ym8OWJ5eV6+67Dsql/LaaT7qJBAt2rzfoa/5QBGBhxDix1dMt2kQKQ== + dependencies: + prelude-ls "^1.2.1" + type-check "~0.4.0" + +levn@~0.3.0: + version "0.3.0" + resolved "https://registry.yarnpkg.com/levn/-/levn-0.3.0.tgz#3b09924edf9f083c0490fdd4c0bc4421e04764ee" + integrity sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4= + dependencies: + prelude-ls "~1.1.2" + type-check "~0.3.2" + +locate-path@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-5.0.0.tgz#1afba396afd676a6d42504d0a67a3a7eb9f62aa0" + integrity sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g== + dependencies: + p-locate "^4.1.0" + +lodash.merge@^4.6.2: + version "4.6.2" + resolved "https://registry.yarnpkg.com/lodash.merge/-/lodash.merge-4.6.2.tgz#558aa53b43b661e1925a0afdfa36a9a1085fe57a" + integrity sha512-0KpjqXRVvrYyCsX1swR/XTK0va6VQkQM6MNo7PqW77ByjAhoARA8EfrP1N4+KlKj8YS0ZUCtRT/YUuhyYDujIQ== + +lodash@^4.7.0: + version "4.17.21" + resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.21.tgz#679591c564c3bffaae8454cf0b3df370c3d6911c" + integrity sha512-v2kDEe57lecTulaDIuNTPy3Ry4gLGJ6Z1O3vE1krgXZNrsQ+LFTGHVxVjcXPs17LhbZVGedAJv8XZ1tvj5FvSg== + +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: + version "3.1.0" + resolved "https://registry.yarnpkg.com/make-dir/-/make-dir-3.1.0.tgz#415e967046b3a7f1d185277d84aa58203726a13f" + integrity sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw== + dependencies: + semver "^6.0.0" + +makeerror@1.0.12: + version "1.0.12" + resolved "https://registry.yarnpkg.com/makeerror/-/makeerror-1.0.12.tgz#3e5dd2079a82e812e983cc6610c4a2cb0eaa801a" + integrity sha512-JmqCvUhmt43madlpFzG4BQzG2Z3m6tvQDNKdClZnO3VbIudJYmxsT0FNJMeiB2+JTSlTQTSbU8QdesVmwJcmLg== + dependencies: + tmpl "1.0.5" + +media-typer@0.3.0: + version "0.3.0" + resolved "https://registry.yarnpkg.com/media-typer/-/media-typer-0.3.0.tgz#8710d7af0aa626f8fffa1ce00168545263255748" + integrity sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g= + +merge-descriptors@1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/merge-descriptors/-/merge-descriptors-1.0.1.tgz#b00aaa556dd8b44568150ec9d1b953f3f90cbb61" + integrity sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E= + +merge-stream@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/merge-stream/-/merge-stream-2.0.0.tgz#52823629a14dd00c9770fb6ad47dc6310f2c1f60" + integrity sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w== + +methods@~1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/methods/-/methods-1.1.2.tgz#5529a4d67654134edcc5266656835b0f851afcee" + integrity sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4= + +micromatch@^4.0.4: + version "4.0.4" + resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-4.0.4.tgz#896d519dfe9db25fce94ceb7a500919bf881ebf9" + integrity sha512-pRmzw/XUcwXGpD9aI9q/0XOwLNygjETJ8y0ao0wdqprrzDa4YnxLcz7fQRZr8voh8V10kGhABbNcHVk5wHgWwg== + dependencies: + braces "^3.0.1" + picomatch "^2.2.3" + +mime-db@1.51.0: + version "1.51.0" + resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.51.0.tgz#d9ff62451859b18342d960850dc3cfb77e63fb0c" + integrity sha512-5y8A56jg7XVQx2mbv1lu49NR4dokRnhZYTtL+KGfaa27uq4pSTXkwQkFJl4pkRMyNFz/EtYDSkiiEHx3F7UN6g== + +mime-db@1.52.0: + version "1.52.0" + resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.52.0.tgz#bbabcdc02859f4987301c856e3387ce5ec43bf70" + integrity sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg== + +mime-types@^2.1.12, mime-types@~2.1.24: + version "2.1.34" + resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.34.tgz#5a712f9ec1503511a945803640fafe09d3793c24" + integrity sha512-6cP692WwGIs9XXdOO4++N+7qjqv0rqxxVvJ3VHPh/Sc9mVZcQP+ZGhkKiTvWMQRr2tbHkJP/Yn7Y0npb3ZBs4A== + dependencies: + mime-db "1.51.0" + +mime-types@~2.1.34: + version "2.1.35" + resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.35.tgz#381a871b62a734450660ae3deee44813f70d959a" + integrity sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw== + dependencies: + mime-db "1.52.0" + +mime@1.6.0: + version "1.6.0" + resolved "https://registry.yarnpkg.com/mime/-/mime-1.6.0.tgz#32cd9e5c64553bd58d19a568af452acff04981b1" + integrity sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg== + +mimic-fn@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-2.1.0.tgz#7ed2c2ccccaf84d3ffcb7a69b57711fc2083401b" + integrity sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg== + +minimatch@^3.0.4: + version "3.1.2" + resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.1.2.tgz#19cd194bfd3e428f049a70817c038d89ab4be35b" + integrity sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw== + dependencies: + brace-expansion "^1.1.7" + +ms@2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8" + integrity sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g= + +ms@2.1.2: + version "2.1.2" + resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009" + integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w== + +ms@2.1.3: + version "2.1.3" + resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.3.tgz#574c8138ce1d2b5861f0b44579dbadd60c6615b2" + integrity sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA== + +natural-compare@^1.4.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/natural-compare/-/natural-compare-1.4.0.tgz#4abebfeed7541f2c27acfb29bdbbd15c8d5ba4f7" + integrity sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc= + +negotiator@0.6.3: + version "0.6.3" + resolved "https://registry.yarnpkg.com/negotiator/-/negotiator-0.6.3.tgz#58e323a72fedc0d6f9cd4d31fe49f51479590ccd" + integrity sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg== + +node-int64@^0.4.0: + version "0.4.0" + resolved "https://registry.yarnpkg.com/node-int64/-/node-int64-0.4.0.tgz#87a9065cdb355d3182d8f94ce11188b825c68a3b" + integrity sha1-h6kGXNs1XTGC2PlM4RGIuCXGijs= + +node-releases@^2.0.1: + version "2.0.1" + resolved "https://registry.yarnpkg.com/node-releases/-/node-releases-2.0.1.tgz#3d1d395f204f1f2f29a54358b9fb678765ad2fc5" + integrity sha512-CqyzN6z7Q6aMeF/ktcMVTzhAHCEpf8SOarwpzpf8pNBY2k5/oM34UHldUwp8VKI7uxct2HxSRdJjBaZeESzcxA== + +normalize-path@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/normalize-path/-/normalize-path-3.0.0.tgz#0dcd69ff23a1c9b11fd0978316644a0388216a65" + integrity sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA== + +npm-run-path@^4.0.1: + version "4.0.1" + resolved "https://registry.yarnpkg.com/npm-run-path/-/npm-run-path-4.0.1.tgz#b7ecd1e5ed53da8e37a55e1c2269e0b97ed748ea" + integrity sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw== + dependencies: + path-key "^3.0.0" + +nwsapi@^2.2.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/nwsapi/-/nwsapi-2.2.0.tgz#204879a9e3d068ff2a55139c2c772780681a38b7" + integrity sha512-h2AatdwYH+JHiZpv7pt/gSX1XoRGb7L/qSIeuqA6GwYoF9w1vP1cw42TO0aI2pNyshRK5893hNSl+1//vHK7hQ== + +object-assign@^4: + version "4.1.1" + resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" + integrity sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM= + +on-finished@~2.3.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/on-finished/-/on-finished-2.3.0.tgz#20f1336481b083cd75337992a16971aa2d906947" + integrity sha1-IPEzZIGwg811M3mSoWlxqi2QaUc= + dependencies: + ee-first "1.1.1" + +once@^1.3.0: + version "1.4.0" + resolved "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1" + integrity sha1-WDsap3WWHUsROsF9nFC6753Xa9E= + dependencies: + wrappy "1" + +onetime@^5.1.2: + version "5.1.2" + resolved "https://registry.yarnpkg.com/onetime/-/onetime-5.1.2.tgz#d0e96ebb56b07476df1dd9c4806e5237985ca45e" + integrity sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg== + dependencies: + mimic-fn "^2.1.0" + +optionator@^0.8.1: + version "0.8.3" + resolved "https://registry.yarnpkg.com/optionator/-/optionator-0.8.3.tgz#84fa1d036fe9d3c7e21d99884b601167ec8fb495" + integrity sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA== + dependencies: + deep-is "~0.1.3" + fast-levenshtein "~2.0.6" + levn "~0.3.0" + prelude-ls "~1.1.2" + type-check "~0.3.2" + word-wrap "~1.2.3" + +optionator@^0.9.1: + version "0.9.1" + resolved "https://registry.yarnpkg.com/optionator/-/optionator-0.9.1.tgz#4f236a6373dae0566a6d43e1326674f50c291499" + integrity sha512-74RlY5FCnhq4jRxVUPKDaRwrVNXMqsGsiW6AJw4XK8hmtm10wC0ypZBLw5IIp85NZMr91+qd1RvvENwg7jjRFw== + dependencies: + deep-is "^0.1.3" + fast-levenshtein "^2.0.6" + levn "^0.4.1" + prelude-ls "^1.2.1" + type-check "^0.4.0" + word-wrap "^1.2.3" + +p-limit@^2.2.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-2.3.0.tgz#3dd33c647a214fdfffd835933eb086da0dc21db1" + integrity sha512-//88mFWSJx8lxCzwdAABTJL2MyWB12+eIY7MDL2SqLmAkeKU9qxRvWuSyTjm3FUmpBEMuFfckAIqEaVGUDxb6w== + dependencies: + p-try "^2.0.0" + +p-locate@^4.1.0: + version "4.1.0" + resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-4.1.0.tgz#a3428bb7088b3a60292f66919278b7c297ad4f07" + integrity sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A== + dependencies: + p-limit "^2.2.0" + +p-try@^2.0.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/p-try/-/p-try-2.2.0.tgz#cb2868540e313d61de58fafbe35ce9004d5540e6" + integrity sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ== + +parent-module@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/parent-module/-/parent-module-1.0.1.tgz#691d2709e78c79fae3a156622452d00762caaaa2" + integrity sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g== + dependencies: + callsites "^3.0.0" + +parse5@6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/parse5/-/parse5-6.0.1.tgz#e1a1c085c569b3dc08321184f19a39cc27f7c30b" + integrity sha512-Ofn/CTFzRGTTxwpNEs9PP93gXShHcTq255nzRYSKe8AkVpZY7e1fpmTfOyoIvjP5HG7Z2ZM7VS9PPhQGW2pOpw== + +parseurl@~1.3.3: + version "1.3.3" + resolved "https://registry.yarnpkg.com/parseurl/-/parseurl-1.3.3.tgz#9da19e7bee8d12dff0513ed5b76957793bc2e8d4" + integrity sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ== + +path-exists@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-4.0.0.tgz#513bdbe2d3b95d7762e8c1137efa195c6c61b5b3" + integrity sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w== + +path-is-absolute@^1.0.0: + version "1.0.1" + resolved "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f" + integrity sha1-F0uSaHNVNP+8es5r9TpanhtcX18= + +path-key@^3.0.0, path-key@^3.1.0: + version "3.1.1" + resolved "https://registry.yarnpkg.com/path-key/-/path-key-3.1.1.tgz#581f6ade658cbba65a0d3380de7753295054f375" + integrity sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q== + +path-parse@^1.0.7: + version "1.0.7" + resolved "https://registry.yarnpkg.com/path-parse/-/path-parse-1.0.7.tgz#fbc114b60ca42b30d9daf5858e4bd68bbedb6735" + integrity sha512-LDJzPVEEEPR+y48z93A0Ed0yXb8pAByGWo/k5YYdYgpY2/2EsOsksJrq7lOHxryrVOn1ejG6oAp8ahvOIQD8sw== + +path-to-regexp@0.1.7: + version "0.1.7" + resolved "https://registry.yarnpkg.com/path-to-regexp/-/path-to-regexp-0.1.7.tgz#df604178005f522f15eb4490e7247a1bfaa67f8c" + integrity sha1-32BBeABfUi8V60SQ5yR6G/qmf4w= + +picocolors@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/picocolors/-/picocolors-1.0.0.tgz#cb5bdc74ff3f51892236eaf79d68bc44564ab81c" + integrity sha512-1fygroTLlHu66zi26VoTDv8yRgm0Fccecssto+MhsZ0D/DGW2sm8E8AjW7NU5VVTRt5GxbeZ5qBuJr+HyLYkjQ== + +picomatch@^2.0.4, picomatch@^2.2.3: + version "2.3.1" + resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.3.1.tgz#3ba3833733646d9d3e4995946c1365a67fb07a42" + integrity sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA== + +pirates@^4.0.4: + version "4.0.4" + resolved "https://registry.yarnpkg.com/pirates/-/pirates-4.0.4.tgz#07df81e61028e402735cdd49db701e4885b4e6e6" + integrity sha512-ZIrVPH+A52Dw84R0L3/VS9Op04PuQ2SEoJL6bkshmiTic/HldyW9Tf7oH5mhJZBK7NmDx27vSMrYEXPXclpDKw== + +pkg-dir@^4.2.0: + version "4.2.0" + resolved "https://registry.yarnpkg.com/pkg-dir/-/pkg-dir-4.2.0.tgz#f099133df7ede422e81d1d8448270eeb3e4261f3" + integrity sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ== + dependencies: + find-up "^4.0.0" + +prelude-ls@^1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/prelude-ls/-/prelude-ls-1.2.1.tgz#debc6489d7a6e6b0e7611888cec880337d316396" + integrity sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g== + +prelude-ls@~1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/prelude-ls/-/prelude-ls-1.1.2.tgz#21932a549f5e52ffd9a827f570e04be62a97da54" + integrity sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ= + +pretty-format@^27.4.6: + version "27.4.6" + resolved "https://registry.yarnpkg.com/pretty-format/-/pretty-format-27.4.6.tgz#1b784d2f53c68db31797b2348fa39b49e31846b7" + integrity sha512-NblstegA1y/RJW2VyML+3LlpFjzx62cUrtBIKIWDXEDkjNeleA7Od7nrzcs/VLQvAeV4CgSYhrN39DRN88Qi/g== + dependencies: + ansi-regex "^5.0.1" + ansi-styles "^5.0.0" + react-is "^17.0.1" + +progress@^2.0.0: + version "2.0.3" + resolved "https://registry.yarnpkg.com/progress/-/progress-2.0.3.tgz#7e8cf8d8f5b8f239c1bc68beb4eb78567d572ef8" + integrity sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA== + +prompts@^2.0.1: + version "2.4.2" + resolved "https://registry.yarnpkg.com/prompts/-/prompts-2.4.2.tgz#7b57e73b3a48029ad10ebd44f74b01722a4cb069" + integrity sha512-NxNv/kLguCA7p3jE8oL2aEBsrJWgAakBpgmgK6lpPWV+WuOmY6r2/zbAVnP+T8bQlA0nzHXSJSJW0Hq7ylaD2Q== + dependencies: + kleur "^3.0.3" + sisteransi "^1.0.5" + +proxy-addr@~2.0.7: + version "2.0.7" + resolved "https://registry.yarnpkg.com/proxy-addr/-/proxy-addr-2.0.7.tgz#f19fe69ceab311eeb94b42e70e8c2070f9ba1025" + integrity sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg== + dependencies: + forwarded "0.2.0" + ipaddr.js "1.9.1" + +psl@^1.1.33: + version "1.8.0" + resolved "https://registry.yarnpkg.com/psl/-/psl-1.8.0.tgz#9326f8bcfb013adcc005fdff056acce020e51c24" + integrity sha512-RIdOzyoavK+hA18OGGWDqUTsCLhtA7IcZ/6NCs4fFJaHBDab+pDDmDIByWFRQJq2Cd7r1OoQxBGKOaztq+hjIQ== + +punycode@^2.1.0, punycode@^2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/punycode/-/punycode-2.1.1.tgz#b58b010ac40c22c5657616c8d2c2c02c7bf479ec" + integrity sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A== + +qs@6.9.7: + version "6.9.7" + resolved "https://registry.yarnpkg.com/qs/-/qs-6.9.7.tgz#4610846871485e1e048f44ae3b94033f0e675afe" + integrity sha512-IhMFgUmuNpyRfxA90umL7ByLlgRXu6tIfKPpF5TmcfRLlLCckfP/g3IQmju6jjpu+Hh8rA+2p6A27ZSPOOHdKw== + +range-parser@~1.2.1: + version "1.2.1" + resolved "https://registry.yarnpkg.com/range-parser/-/range-parser-1.2.1.tgz#3cf37023d199e1c24d1a55b84800c2f3e6468031" + integrity sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg== + +raw-body@2.4.3: + version "2.4.3" + resolved "https://registry.yarnpkg.com/raw-body/-/raw-body-2.4.3.tgz#8f80305d11c2a0a545c2d9d89d7a0286fcead43c" + 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@^17.0.1: + version "17.0.2" + resolved "https://registry.yarnpkg.com/react-is/-/react-is-17.0.2.tgz#e691d4a8e9c789365655539ab372762b0efb54f0" + integrity sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w== + +regexpp@^3.2.0: + version "3.2.0" + resolved "https://registry.yarnpkg.com/regexpp/-/regexpp-3.2.0.tgz#0425a2768d8f23bad70ca4b90461fa2f1213e1b2" + integrity sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg== + +require-directory@^2.1.1: + version "2.1.1" + resolved "https://registry.yarnpkg.com/require-directory/-/require-directory-2.1.1.tgz#8c64ad5fd30dab1c976e2344ffe7f792a6a6df42" + integrity sha1-jGStX9MNqxyXbiNE/+f3kqam30I= + +resolve-cwd@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/resolve-cwd/-/resolve-cwd-3.0.0.tgz#0f0075f1bb2544766cf73ba6a6e2adfebcb13f2d" + integrity sha512-OrZaX2Mb+rJCpH/6CpSqt9xFVpN++x01XnN2ie9g6P5/3xelLAkXWVADpdz1IHD/KFfEXyE6V0U01OQ3UO2rEg== + dependencies: + resolve-from "^5.0.0" + +resolve-from@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-4.0.0.tgz#4abcd852ad32dd7baabfe9b40e00a36db5f392e6" + integrity sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g== + +resolve-from@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-5.0.0.tgz#c35225843df8f776df21c57557bc087e9dfdfc69" + integrity sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw== + +resolve.exports@^1.1.0: + version "1.1.0" + resolved "https://registry.yarnpkg.com/resolve.exports/-/resolve.exports-1.1.0.tgz#5ce842b94b05146c0e03076985d1d0e7e48c90c9" + integrity sha512-J1l+Zxxp4XK3LUDZ9m60LRJF/mAe4z6a4xyabPHk7pvK5t35dACV32iIjJDFeWZFfZlO29w6SZ67knR0tHzJtQ== + +resolve@^1.20.0: + version "1.21.0" + resolved "https://registry.yarnpkg.com/resolve/-/resolve-1.21.0.tgz#b51adc97f3472e6a5cf4444d34bc9d6b9037591f" + integrity sha512-3wCbTpk5WJlyE4mSOtDLhqQmGFi0/TD9VPwmiolnk8U0wRgMEktqCXd3vy5buTO3tljvalNvKrjHEfrd2WpEKA== + dependencies: + is-core-module "^2.8.0" + path-parse "^1.0.7" + supports-preserve-symlinks-flag "^1.0.0" + +rimraf@^3.0.0, rimraf@^3.0.2: + version "3.0.2" + resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-3.0.2.tgz#f1a5402ba6220ad52cc1282bac1ae3aa49fd061a" + integrity sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA== + dependencies: + glob "^7.1.3" + +safe-buffer@5.2.1: + 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: + version "5.1.2" + resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.2.tgz#991ec69d296e0313747d59bdfd2b745c35f8828d" + integrity sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g== + +"safer-buffer@>= 2.1.2 < 3": + version "2.1.2" + resolved "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a" + integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg== + +saxes@^5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/saxes/-/saxes-5.0.1.tgz#eebab953fa3b7608dbe94e5dadb15c888fa6696d" + integrity sha512-5LBh1Tls8c9xgGjw3QrMwETmTMVk0oFgvrFSvWx62llR2hcEInrKNZ2GZCCuuy2lvWrdl5jhbpeqc5hRYKFOcw== + dependencies: + xmlchars "^2.2.0" + +semver@^6.0.0, semver@^6.3.0: + version "6.3.0" + resolved "https://registry.yarnpkg.com/semver/-/semver-6.3.0.tgz#ee0a64c8af5e8ceea67687b133761e1becbd1d3d" + integrity sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw== + +semver@^7.2.1, semver@^7.3.2: + version "7.3.5" + resolved "https://registry.yarnpkg.com/semver/-/semver-7.3.5.tgz#0b621c879348d8998e4b0e4be94b3f12e6018ef7" + integrity sha512-PoeGJYh8HK4BTO/a9Tf6ZG3veo/A7ZVsYrSA6J8ny9nb3B1VrpkuN+z9OE5wfE5p6H4LchYZsegiQgbJD94ZFQ== + dependencies: + lru-cache "^6.0.0" + +send@0.17.2: + version "0.17.2" + resolved "https://registry.yarnpkg.com/send/-/send-0.17.2.tgz#926622f76601c41808012c8bf1688fe3906f7820" + integrity sha512-UJYB6wFSJE3G00nEivR5rgWp8c2xXvJ3OPWPhmuteU0IKj8nKbG3DrjiOmLwpnHGYWAVwA69zmTm++YG0Hmwww== + dependencies: + debug "2.6.9" + depd "~1.1.2" + destroy "~1.0.4" + encodeurl "~1.0.2" + escape-html "~1.0.3" + etag "~1.8.1" + fresh "0.5.2" + http-errors "1.8.1" + mime "1.6.0" + ms "2.1.3" + on-finished "~2.3.0" + range-parser "~1.2.1" + statuses "~1.5.0" + +serve-static@1.14.2: + version "1.14.2" + resolved "https://registry.yarnpkg.com/serve-static/-/serve-static-1.14.2.tgz#722d6294b1d62626d41b43a013ece4598d292bfa" + integrity sha512-+TMNA9AFxUEGuC0z2mevogSnn9MXKb4fa7ngeRMJaaGv8vTwnIEkKi+QGvPt33HSnf8pRS+WGM0EbMtCJLKMBQ== + dependencies: + encodeurl "~1.0.2" + escape-html "~1.0.3" + parseurl "~1.3.3" + send "0.17.2" + +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@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/shebang-command/-/shebang-command-2.0.0.tgz#ccd0af4f8835fbdc265b82461aaf0c36663f34ea" + integrity sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA== + dependencies: + shebang-regex "^3.0.0" + +shebang-regex@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-3.0.0.tgz#ae16f1644d873ecad843b0307b143362d4c42172" + integrity sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A== + +signal-exit@^3.0.2, signal-exit@^3.0.3: + version "3.0.6" + resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.6.tgz#24e630c4b0f03fea446a2bd299e62b4a6ca8d0af" + integrity sha512-sDl4qMFpijcGw22U5w63KmD3cZJfBuFlVNbVMKje2keoKML7X2UzWbc4XrmEbDwg0NXJc3yv4/ox7b+JWb57kQ== + +sisteransi@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/sisteransi/-/sisteransi-1.0.5.tgz#134d681297756437cc05ca01370d3a7a571075ed" + integrity sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg== + +slash@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/slash/-/slash-3.0.0.tgz#6539be870c165adbd5240220dbe361f1bc4d4634" + integrity sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q== + +source-map-support@^0.5.6: + version "0.5.21" + resolved "https://registry.yarnpkg.com/source-map-support/-/source-map-support-0.5.21.tgz#04fe7c7f9e1ed2d662233c28cb2b35b9f63f6e4f" + integrity sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w== + dependencies: + buffer-from "^1.0.0" + source-map "^0.6.0" + +source-map@^0.5.0: + version "0.5.7" + resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.5.7.tgz#8a039d2d1021d22d1ea14c80d8ea468ba2ef3fcc" + integrity sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w= + +source-map@^0.6.0, source-map@^0.6.1, source-map@~0.6.1: + version "0.6.1" + resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.6.1.tgz#74722af32e9614e9c287a8d0bbde48b5e2f1a263" + integrity sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g== + +source-map@^0.7.3: + version "0.7.3" + resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.7.3.tgz#5302f8169031735226544092e64981f751750383" + integrity sha512-CkCj6giN3S+n9qrYiBTX5gystlENnRW5jZeNLHpe6aue+SrHcG5VYwujhW9s4dY31mEGsxBDrHR6oI69fTXsaQ== + +sprintf-js@~1.0.2: + version "1.0.3" + resolved "https://registry.yarnpkg.com/sprintf-js/-/sprintf-js-1.0.3.tgz#04e6926f662895354f3dd015203633b857297e2c" + integrity sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw= + +stack-utils@^2.0.3: + version "2.0.5" + resolved "https://registry.yarnpkg.com/stack-utils/-/stack-utils-2.0.5.tgz#d25265fca995154659dbbfba3b49254778d2fdd5" + integrity sha512-xrQcmYhOsn/1kX+Vraq+7j4oE2j/6BFscZ0etmYg81xuM8Gq0022Pxb8+IqgOFUIaxHs0KaSb7T1+OegiNrNFA== + dependencies: + escape-string-regexp "^2.0.0" + +"statuses@>= 1.5.0 < 2", statuses@~1.5.0: + version "1.5.0" + resolved "https://registry.yarnpkg.com/statuses/-/statuses-1.5.0.tgz#161c7dac177659fd9811f43771fa99381478628c" + integrity sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow= + +string-length@^4.0.1: + version "4.0.2" + resolved "https://registry.yarnpkg.com/string-length/-/string-length-4.0.2.tgz#a8a8dc7bd5c1a82b9b3c8b87e125f66871b6e57a" + integrity sha512-+l6rNN5fYHNhZZy41RXsYptCjA2Igmq4EG7kZAYFQI1E1VTXarr6ZPXBg6eq7Y6eK4FEhY6AJlyuFIb/v/S0VQ== + dependencies: + char-regex "^1.0.2" + strip-ansi "^6.0.0" + +string-width@^4.1.0, string-width@^4.2.0: + version "4.2.3" + resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.3.tgz#269c7117d27b05ad2e536830a8ec895ef9c6d010" + integrity sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g== + dependencies: + emoji-regex "^8.0.0" + is-fullwidth-code-point "^3.0.0" + strip-ansi "^6.0.1" + +strip-ansi@^6.0.0, strip-ansi@^6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.1.tgz#9e26c63d30f53443e9489495b2105d37b67a85d9" + integrity sha512-Y38VPSHcqkFrCpFnQ9vuSXmquuv5oXOKpGeT6aGrr3o3Gc9AlVa6JBfUSOCnbxGGZF+/0ooI7KrPuUSztUdU5A== + dependencies: + ansi-regex "^5.0.1" + +strip-bom@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/strip-bom/-/strip-bom-4.0.0.tgz#9c3505c1db45bcedca3d9cf7a16f5c5aa3901878" + integrity sha512-3xurFv5tEgii33Zi8Jtp55wEIILR9eh34FAW00PZf+JnSsTmV/ioewSgQl97JHvgjoRGwPShsWm+IdrxB35d0w== + +strip-final-newline@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/strip-final-newline/-/strip-final-newline-2.0.0.tgz#89b852fb2fcbe936f6f4b3187afb0a12c1ab58ad" + integrity sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA== + +strip-json-comments@^3.1.0, strip-json-comments@^3.1.1: + version "3.1.1" + resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-3.1.1.tgz#31f1281b3832630434831c310c01cccda8cbe006" + integrity sha512-6fPc+R4ihwqP6N/aIv2f1gMH8lOVtWQHoqC4yK6oSDVVocumAsfCqjkXnqiYMhmMwS/mEHLp7Vehlt3ql6lEig== + +supports-color@^5.3.0: + version "5.5.0" + resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-5.5.0.tgz#e2e69a44ac8772f78a1ec0b35b689df6530efc8f" + integrity sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow== + dependencies: + has-flag "^3.0.0" + +supports-color@^7.0.0, supports-color@^7.1.0: + version "7.2.0" + resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-7.2.0.tgz#1b7dcdcb32b8138801b3e478ba6a51caa89648da" + integrity sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw== + dependencies: + has-flag "^4.0.0" + +supports-color@^8.0.0: + version "8.1.1" + resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-8.1.1.tgz#cd6fc17e28500cff56c1b86c0a7fd4a54a73005c" + integrity sha512-MpUEN2OodtUzxvKQl72cUF7RQ5EiHsGvSsVG0ia9c5RbWGL2CI4C7EpPS8UTBIplnlzZiNuV56w+FuNxy3ty2Q== + dependencies: + has-flag "^4.0.0" + +supports-hyperlinks@^2.0.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/supports-hyperlinks/-/supports-hyperlinks-2.2.0.tgz#4f77b42488765891774b70c79babd87f9bd594bb" + integrity sha512-6sXEzV5+I5j8Bmq9/vUphGRM/RJNT9SCURJLjwfOg51heRtguGWDzcaBlgAzKhQa0EVNpPEKzQuBwZ8S8WaCeQ== + dependencies: + has-flag "^4.0.0" + supports-color "^7.0.0" + +supports-preserve-symlinks-flag@^1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/supports-preserve-symlinks-flag/-/supports-preserve-symlinks-flag-1.0.0.tgz#6eda4bd344a3c94aea376d4cc31bc77311039e09" + integrity sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w== + +symbol-tree@^3.2.4: + version "3.2.4" + resolved "https://registry.yarnpkg.com/symbol-tree/-/symbol-tree-3.2.4.tgz#430637d248ba77e078883951fb9aa0eed7c63fa2" + integrity sha512-9QNk5KwDF+Bvz+PyObkmSYjI5ksVUYtjW7AU22r2NKcfLJcXp96hkDWU3+XndOsUb+AQ9QhfzfCT2O+CNWT5Tw== + +terminal-link@^2.0.0: + version "2.1.1" + resolved "https://registry.yarnpkg.com/terminal-link/-/terminal-link-2.1.1.tgz#14a64a27ab3c0df933ea546fba55f2d078edc994" + integrity sha512-un0FmiRUQNr5PJqy9kP7c40F5BOfpGlYTrxonDChEZB7pzZxRNp/bt+ymiy9/npwXya9KH99nJ/GXFIiUkYGFQ== + dependencies: + ansi-escapes "^4.2.1" + supports-hyperlinks "^2.0.0" + +test-exclude@^6.0.0: + version "6.0.0" + resolved "https://registry.yarnpkg.com/test-exclude/-/test-exclude-6.0.0.tgz#04a8698661d805ea6fa293b6cb9e63ac044ef15e" + integrity sha512-cAGWPIyOHU6zlmg88jwm7VRyXnMN7iV68OGAbYDk/Mh/xC/pzVPlQtY6ngoIH/5/tciuhGfvESU8GrHrcxD56w== + dependencies: + "@istanbuljs/schema" "^0.1.2" + glob "^7.1.4" + minimatch "^3.0.4" + +text-table@^0.2.0: + version "0.2.0" + resolved "https://registry.yarnpkg.com/text-table/-/text-table-0.2.0.tgz#7f5ee823ae805207c00af2df4a84ec3fcfa570b4" + integrity sha1-f17oI66AUgfACvLfSoTsP8+lcLQ= + +throat@^6.0.1: + version "6.0.1" + resolved "https://registry.yarnpkg.com/throat/-/throat-6.0.1.tgz#d514fedad95740c12c2d7fc70ea863eb51ade375" + integrity sha512-8hmiGIJMDlwjg7dlJ4yKGLK8EsYqKgPWbG3b4wjJddKNwc7N7Dpn08Df4szr/sZdMVeOstrdYSsqzX6BYbcB+w== + +tmpl@1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/tmpl/-/tmpl-1.0.5.tgz#8683e0b902bb9c20c4f726e3c0b69f36518c07cc" + integrity sha512-3f0uOEAQwIqGuWW2MVzYg8fV/QNnc/IpuJNG837rLuczAaLVHslWHZQj4IGiEl5Hs3kkbhwL9Ab7Hrsmuj+Smw== + +to-fast-properties@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/to-fast-properties/-/to-fast-properties-2.0.0.tgz#dc5e698cbd079265bc73e0377681a4e4e83f616e" + integrity sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4= + +to-regex-range@^5.0.1: + version "5.0.1" + resolved "https://registry.yarnpkg.com/to-regex-range/-/to-regex-range-5.0.1.tgz#1648c44aae7c8d988a326018ed72f5b4dd0392e4" + integrity sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ== + dependencies: + is-number "^7.0.0" + +toidentifier@1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/toidentifier/-/toidentifier-1.0.1.tgz#3be34321a88a820ed1bd80dfaa33e479fbb8dd35" + integrity sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA== + +tough-cookie@^4.0.0: + version "4.0.0" + resolved "https://registry.yarnpkg.com/tough-cookie/-/tough-cookie-4.0.0.tgz#d822234eeca882f991f0f908824ad2622ddbece4" + integrity sha512-tHdtEpQCMrc1YLrMaqXXcj6AxhYi/xgit6mZu1+EDWUn+qhUf8wMQoFIy9NXuq23zAwtcB0t/MjACGR18pcRbg== + dependencies: + psl "^1.1.33" + punycode "^2.1.1" + universalify "^0.1.2" + +tr46@^2.1.0: + version "2.1.0" + resolved "https://registry.yarnpkg.com/tr46/-/tr46-2.1.0.tgz#fa87aa81ca5d5941da8cbf1f9b749dc969a4e240" + integrity sha512-15Ih7phfcdP5YxqiB+iDtLoaTz4Nd35+IiAv0kQ5FNKHzXgdWqPoTIqEDDJmXceQt4JZk6lVPT8lnDlPpGDppw== + dependencies: + punycode "^2.1.1" + +type-check@^0.4.0, type-check@~0.4.0: + version "0.4.0" + resolved "https://registry.yarnpkg.com/type-check/-/type-check-0.4.0.tgz#07b8203bfa7056c0657050e3ccd2c37730bab8f1" + integrity sha512-XleUoc9uwGXqjWwXaUTZAmzMcFZ5858QA2vvx1Ur5xIcixXIP+8LnFDgRplU30us6teqdlskFfu+ae4K79Ooew== + dependencies: + prelude-ls "^1.2.1" + +type-check@~0.3.2: + version "0.3.2" + resolved "https://registry.yarnpkg.com/type-check/-/type-check-0.3.2.tgz#5884cab512cf1d355e3fb784f30804b2b520db72" + integrity sha1-WITKtRLPHTVeP7eE8wgEsrUg23I= + dependencies: + prelude-ls "~1.1.2" + +type-detect@4.0.8: + version "4.0.8" + resolved "https://registry.yarnpkg.com/type-detect/-/type-detect-4.0.8.tgz#7646fb5f18871cfbb7749e69bd39a6388eb7450c" + integrity sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g== + +type-fest@^0.20.2: + version "0.20.2" + resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.20.2.tgz#1bf207f4b28f91583666cb5fbd327887301cd5f4" + integrity sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ== + +type-fest@^0.21.3: + version "0.21.3" + resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.21.3.tgz#d260a24b0198436e133fa26a524a6d65fa3b2e37" + integrity sha512-t0rzBq87m3fVcduHDUFhKmyyX+9eo6WQjZvf51Ea/M0Q7+T374Jp1aUiyUl0GKxp8M/OETVHSDvmkyPgvX+X2w== + +type-is@^1.6.16, type-is@~1.6.18: + version "1.6.18" + resolved "https://registry.yarnpkg.com/type-is/-/type-is-1.6.18.tgz#4e552cd05df09467dcbc4ef739de89f2cf37c131" + integrity sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g== + dependencies: + media-typer "0.3.0" + mime-types "~2.1.24" + +typedarray-to-buffer@^3.1.5: + version "3.1.5" + resolved "https://registry.yarnpkg.com/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz#a97ee7a9ff42691b9f783ff1bc5112fe3fca9080" + integrity sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q== + dependencies: + is-typedarray "^1.0.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, unpipe@~1.0.0: + version "1.0.0" + resolved "https://registry.yarnpkg.com/unpipe/-/unpipe-1.0.0.tgz#b2bf4ee8514aae6165b4817829d21b2ef49904ec" + integrity sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw= + +uri-js@^4.2.2: + version "4.4.1" + resolved "https://registry.yarnpkg.com/uri-js/-/uri-js-4.4.1.tgz#9b1a52595225859e55f669d928f88c6c57f2a77e" + integrity sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg== + dependencies: + punycode "^2.1.0" + +utils-merge@1.0.1: + version "1.0.1" + resolved "https://registry.yarnpkg.com/utils-merge/-/utils-merge-1.0.1.tgz#9f95710f50a267947b2ccc124741c1028427e713" + integrity sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM= + +v8-compile-cache@^2.0.3: + version "2.3.0" + resolved "https://registry.yarnpkg.com/v8-compile-cache/-/v8-compile-cache-2.3.0.tgz#2de19618c66dc247dcfb6f99338035d8245a2cee" + integrity sha512-l8lCEmLcLYZh4nbunNZvQCJc5pv7+RCwa8q/LdUx8u7lsWvPDKmpodJAJNwkAhJC//dFY48KuIEmjtd4RViDrA== + +v8-to-istanbul@^8.1.0: + version "8.1.0" + resolved "https://registry.yarnpkg.com/v8-to-istanbul/-/v8-to-istanbul-8.1.0.tgz#0aeb763894f1a0a1676adf8a8b7612a38902446c" + integrity sha512-/PRhfd8aTNp9Ggr62HPzXg2XasNFGy5PBt0Rp04du7/8GNNSgxFL6WBTkgMKSL9bFjH+8kKEG3f37FmxiTqUUA== + dependencies: + "@types/istanbul-lib-coverage" "^2.0.1" + convert-source-map "^1.6.0" + source-map "^0.7.3" + +vary@^1, vary@~1.1.2: + version "1.1.2" + resolved "https://registry.yarnpkg.com/vary/-/vary-1.1.2.tgz#2299f02c6ded30d4a5961b0b9f74524a18f634fc" + integrity sha1-IpnwLG3tMNSllhsLn3RSShj2NPw= + +w3c-hr-time@^1.0.2: + version "1.0.2" + resolved "https://registry.yarnpkg.com/w3c-hr-time/-/w3c-hr-time-1.0.2.tgz#0a89cdf5cc15822df9c360543676963e0cc308cd" + integrity sha512-z8P5DvDNjKDoFIHK7q8r8lackT6l+jo/Ye3HOle7l9nICP9lf1Ci25fy9vHd0JOWewkIFzXIEig3TdKT7JQ5fQ== + dependencies: + browser-process-hrtime "^1.0.0" + +w3c-xmlserializer@^2.0.0: + version "2.0.0" + resolved "https://registry.yarnpkg.com/w3c-xmlserializer/-/w3c-xmlserializer-2.0.0.tgz#3e7104a05b75146cc60f564380b7f683acf1020a" + integrity sha512-4tzD0mF8iSiMiNs30BiLO3EpfGLZUT2MSX/G+o7ZywDzliWQ3OPtTZ0PTC3B3ca1UAf4cJMHB+2Bf56EriJuRA== + dependencies: + xml-name-validator "^3.0.0" + +walker@^1.0.7: + version "1.0.8" + resolved "https://registry.yarnpkg.com/walker/-/walker-1.0.8.tgz#bd498db477afe573dc04185f011d3ab8a8d7653f" + integrity sha512-ts/8E8l5b7kY0vlWLewOkDXMmPdLcVV4GmOQLyxuSswIJsweeFZtAsMF7k1Nszz+TYBQrlYRmzOnr398y1JemQ== + dependencies: + makeerror "1.0.12" + +webidl-conversions@^5.0.0: + version "5.0.0" + resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-5.0.0.tgz#ae59c8a00b121543a2acc65c0434f57b0fc11aff" + integrity sha512-VlZwKPCkYKxQgeSbH5EyngOmRp7Ww7I9rQLERETtf5ofd9pGeswWiOtogpEO850jziPRarreGxn5QIiTqpb2wA== + +webidl-conversions@^6.1.0: + version "6.1.0" + resolved "https://registry.yarnpkg.com/webidl-conversions/-/webidl-conversions-6.1.0.tgz#9111b4d7ea80acd40f5270d666621afa78b69514" + integrity sha512-qBIvFLGiBpLjfwmYAaHPXsn+ho5xZnGvyGvsarywGNc8VyQJUMHJ8OBKGGrPER0okBeMDaan4mNBlgBROxuI8w== + +whatwg-encoding@^1.0.5: + version "1.0.5" + resolved "https://registry.yarnpkg.com/whatwg-encoding/-/whatwg-encoding-1.0.5.tgz#5abacf777c32166a51d085d6b4f3e7d27113ddb0" + integrity sha512-b5lim54JOPN9HtzvK9HFXvBma/rnfFeqsic0hSpjtDbVxR3dJKLc+KB4V6GgiGOvl7CY/KNh8rxSo9DKQrnUEw== + dependencies: + iconv-lite "0.4.24" + +whatwg-mimetype@^2.3.0: + version "2.3.0" + resolved "https://registry.yarnpkg.com/whatwg-mimetype/-/whatwg-mimetype-2.3.0.tgz#3d4b1e0312d2079879f826aff18dbeeca5960fbf" + integrity sha512-M4yMwr6mAnQz76TbJm914+gPpB/nCwvZbJU28cUD6dR004SAxDLOOSUaB1JDRqLtaOV/vi0IC5lEAGFgrjGv/g== + +whatwg-url@^8.0.0, whatwg-url@^8.5.0: + version "8.7.0" + resolved "https://registry.yarnpkg.com/whatwg-url/-/whatwg-url-8.7.0.tgz#656a78e510ff8f3937bc0bcbe9f5c0ac35941b77" + integrity sha512-gAojqb/m9Q8a5IV96E3fHJM70AzCkgt4uXYX2O7EmuyOnLrViCQlsEBmF9UQIu3/aeAIp2U17rtbpZWNntQqdg== + dependencies: + lodash "^4.7.0" + tr46 "^2.1.0" + webidl-conversions "^6.1.0" + +which@^2.0.1: + version "2.0.2" + resolved "https://registry.yarnpkg.com/which/-/which-2.0.2.tgz#7c6a8dd0a636a0327e10b59c9286eee93f3f51b1" + integrity sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA== + dependencies: + isexe "^2.0.0" + +word-wrap@^1.2.3, word-wrap@~1.2.3: + version "1.2.3" + resolved "https://registry.yarnpkg.com/word-wrap/-/word-wrap-1.2.3.tgz#610636f6b1f703891bd34771ccb17fb93b47079c" + integrity sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ== + +wrap-ansi@^7.0.0: + version "7.0.0" + resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-7.0.0.tgz#67e145cff510a6a6984bdf1152911d69d2eb9e43" + integrity sha512-YVGIj2kamLSTxw6NsZjoBxfSwsn0ycdesmc4p+Q21c5zPuZ1pl+NfxVdxPtdHvmNVOQ6XSYG4AUtyt/Fi7D16Q== + dependencies: + ansi-styles "^4.0.0" + string-width "^4.1.0" + strip-ansi "^6.0.0" + +wrappy@1: + version "1.0.2" + resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" + integrity sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8= + +write-file-atomic@^3.0.0: + version "3.0.3" + resolved "https://registry.yarnpkg.com/write-file-atomic/-/write-file-atomic-3.0.3.tgz#56bd5c5a5c70481cd19c571bd39ab965a5de56e8" + integrity sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q== + dependencies: + imurmurhash "^0.1.4" + is-typedarray "^1.0.0" + signal-exit "^3.0.2" + typedarray-to-buffer "^3.1.5" + +ws@^7.4.6: + version "7.5.6" + resolved "https://registry.yarnpkg.com/ws/-/ws-7.5.6.tgz#e59fc509fb15ddfb65487ee9765c5a51dec5fe7b" + integrity sha512-6GLgCqo2cy2A2rjCNFlxQS6ZljG/coZfZXclldI8FB/1G3CCI36Zd8xy2HrFVACi8tfk5XrgLQEk+P0Tnz9UcA== + +xml-name-validator@^3.0.0: + version "3.0.0" + resolved "https://registry.yarnpkg.com/xml-name-validator/-/xml-name-validator-3.0.0.tgz#6ae73e06de4d8c6e47f9fb181f78d648ad457c6a" + integrity sha512-A5CUptxDsvxKJEU3yO6DuWBSJz/qizqzJKOMIfUJHETbBw/sFaDxgd6fxm1ewUaM0jZ444Fc5vC5ROYurg/4Pw== + +xmlchars@^2.2.0: + version "2.2.0" + resolved "https://registry.yarnpkg.com/xmlchars/-/xmlchars-2.2.0.tgz#060fe1bcb7f9c76fe2a17db86a9bc3ab894210cb" + integrity sha512-JZnDKK8B0RCDw84FNdDAIpZK+JuJw+s7Lz8nksI7SIuU3UXJJslUthsi+uWBUYOwPFwW7W7PRLRfUKpxjtjFCw== + +y18n@^5.0.5: + version "5.0.8" + resolved "https://registry.yarnpkg.com/y18n/-/y18n-5.0.8.tgz#7f4934d0f7ca8c56f95314939ddcd2dd91ce1d55" + integrity sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA== + +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.2.2: + 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@^16.2.0: + version "16.2.0" + resolved "https://registry.yarnpkg.com/yargs/-/yargs-16.2.0.tgz#1c82bf0f6b6a66eafce7ef30e376f49a12477f66" + integrity sha512-D1mvvtDG0L5ft/jGWkLpG1+m0eQxOfaBvTNELraWj22wSVUMWxZUvYgJYcKh6jGGIkJFhH4IZPQhR4TKpc8mBw== + dependencies: + cliui "^7.0.2" + escalade "^3.1.1" + get-caller-file "^2.0.5" + require-directory "^2.1.1" + string-width "^4.2.0" + y18n "^5.0.5" + yargs-parser "^20.2.2" diff --git a/amplify/backend/function/stockerlambda/stockerlambda-cloudformation-template.json b/amplify/backend/function/stockerlambda/stockerlambda-cloudformation-template.json new file mode 100644 index 00000000..47e4d386 --- /dev/null +++ b/amplify/backend/function/stockerlambda/stockerlambda-cloudformation-template.json @@ -0,0 +1,202 @@ +{ + "AWSTemplateFormatVersion": "2010-09-09", + "Description": "Lambda Function resource stack creation using Amplify CLI", + "Parameters": { + "CloudWatchRule": { + "Type": "String", + "Default": "NONE", + "Description": " Schedule Expression" + }, + "deploymentBucketName": { + "Type": "String" + }, + "env": { + "Type": "String" + }, + "s3Key": { + "Type": "String" + } + }, + "Conditions": { + "ShouldNotCreateEnvResources": { + "Fn::Equals": [ + { + "Ref": "env" + }, + "NONE" + ] + } + }, + "Resources": { + "LambdaFunction": { + "Type": "AWS::Lambda::Function", + "Metadata": { + "aws:asset:path": "./src", + "aws:asset:property": "Code" + }, + "Properties": { + "Code": { + "S3Bucket": { + "Ref": "deploymentBucketName" + }, + "S3Key": { + "Ref": "s3Key" + } + }, + "Handler": "index.handler", + "FunctionName": { + "Fn::If": [ + "ShouldNotCreateEnvResources", + "stockerlambda", + { + "Fn::Join": [ + "", + [ + "stockerlambda", + "-", + { + "Ref": "env" + } + ] + ] + } + ] + }, + "Environment": { + "Variables": { + "ENV": { + "Ref": "env" + }, + "REGION": { + "Ref": "AWS::Region" + } + } + }, + "Role": { + "Fn::GetAtt": [ + "LambdaExecutionRole", + "Arn" + ] + }, + "Runtime": "nodejs14.x", + "Layers": [], + "Timeout": 25 + } + }, + "LambdaExecutionRole": { + "Type": "AWS::IAM::Role", + "Properties": { + "RoleName": { + "Fn::If": [ + "ShouldNotCreateEnvResources", + "mywalletLambdaRoleceec97aa", + { + "Fn::Join": [ + "", + [ + "mywalletLambdaRoleceec97aa", + "-", + { + "Ref": "env" + } + ] + ] + } + ] + }, + "AssumeRolePolicyDocument": { + "Version": "2012-10-17", + "Statement": [ + { + "Effect": "Allow", + "Principal": { + "Service": [ + "lambda.amazonaws.com" + ] + }, + "Action": [ + "sts:AssumeRole" + ] + } + ] + } + } + }, + "lambdaexecutionpolicy": { + "DependsOn": [ + "LambdaExecutionRole" + ], + "Type": "AWS::IAM::Policy", + "Properties": { + "PolicyName": "lambda-execution-policy", + "Roles": [ + { + "Ref": "LambdaExecutionRole" + } + ], + "PolicyDocument": { + "Version": "2012-10-17", + "Statement": [ + { + "Effect": "Allow", + "Action": [ + "logs:CreateLogGroup", + "logs:CreateLogStream", + "logs:PutLogEvents" + ], + "Resource": { + "Fn::Sub": [ + "arn:aws:logs:${region}:${account}:log-group:/aws/lambda/${lambda}:log-stream:*", + { + "region": { + "Ref": "AWS::Region" + }, + "account": { + "Ref": "AWS::AccountId" + }, + "lambda": { + "Ref": "LambdaFunction" + } + } + ] + } + } + ] + } + } + } + }, + "Outputs": { + "Name": { + "Value": { + "Ref": "LambdaFunction" + } + }, + "Arn": { + "Value": { + "Fn::GetAtt": [ + "LambdaFunction", + "Arn" + ] + } + }, + "Region": { + "Value": { + "Ref": "AWS::Region" + } + }, + "LambdaExecutionRole": { + "Value": { + "Ref": "LambdaExecutionRole" + } + }, + "LambdaExecutionRoleArn": { + "Value": { + "Fn::GetAtt": [ + "LambdaExecutionRole", + "Arn" + ] + } + } + } +} \ No newline at end of file diff --git a/amplify/backend/function/stockerlambda/tsconfig.json b/amplify/backend/function/stockerlambda/tsconfig.json new file mode 100644 index 00000000..60103b68 --- /dev/null +++ b/amplify/backend/function/stockerlambda/tsconfig.json @@ -0,0 +1,17 @@ +{ + "compilerOptions": { + "allowSyntheticDefaultImports": true, + "lib": ["dom", "esnext"], + "module": "commonjs", + "moduleResolution": "node", + "esModuleInterop": true, + "skipLibCheck": true, + "resolveJsonModule": true, + "outDir": "./src", + "baseUrl": "./", + "rootDir": "./lib", + "paths": { + "src": ["./lib"] + } + } +} diff --git a/amplify/backend/tags.json b/amplify/backend/tags.json new file mode 100644 index 00000000..b9321d71 --- /dev/null +++ b/amplify/backend/tags.json @@ -0,0 +1,10 @@ +[ + { + "Key": "user:Stack", + "Value": "{project-env}" + }, + { + "Key": "user:Application", + "Value": "{project-name}" + } +] \ No newline at end of file diff --git a/amplify/backend/types/amplify-dependent-resources-ref.d.ts b/amplify/backend/types/amplify-dependent-resources-ref.d.ts new file mode 100644 index 00000000..85486f15 --- /dev/null +++ b/amplify/backend/types/amplify-dependent-resources-ref.d.ts @@ -0,0 +1,18 @@ +export type AmplifyDependentResourcesAttributes = { + "api": { + "stocker": { + "RootUrl": "string", + "ApiName": "string", + "ApiId": "string" + } + }, + "function": { + "stockerlambda": { + "Name": "string", + "Arn": "string", + "Region": "string", + "LambdaExecutionRole": "string", + "LambdaExecutionRoleArn": "string" + } + } +} \ No newline at end of file diff --git a/amplify/cli.json b/amplify/cli.json new file mode 100644 index 00000000..19815681 --- /dev/null +++ b/amplify/cli.json @@ -0,0 +1,56 @@ +{ + "features": { + "graphqltransformer": { + "addmissingownerfields": true, + "improvepluralization": false, + "validatetypenamereservedwords": true, + "useexperimentalpipelinedtransformer": true, + "enableiterativegsiupdates": true, + "secondarykeyasgsi": true, + "skipoverridemutationinputtypes": true, + "transformerversion": 2, + "suppressschemamigrationprompt": true, + "securityEnhancementNotification": false, + "showfieldauthnotification": false + }, + "frontend-ios": { + "enablexcodeintegration": true + }, + "auth": { + "enablecaseinsensitivity": true, + "useinclusiveterminology": true, + "breakcirculardependency": true, + "forcealiasattributes": false, + "useenabledmfas": true + }, + "codegen": { + "useappsyncmodelgenplugin": true, + "usedocsgeneratorplugin": true, + "usetypesgeneratorplugin": true, + "cleangeneratedmodelsdirectory": true, + "retaincasestyle": true, + "addtimestampfields": true, + "handlelistnullabilitytransparently": true, + "emitauthprovider": true, + "generateindexrules": true, + "enabledartnullsafety": true + }, + "appsync": { + "generategraphqlpermissions": true + }, + "latestregionsupport": { + "pinpoint": 1, + "translate": 1, + "transcribe": 1, + "rekognition": 1, + "textract": 1, + "comprehend": 1 + }, + "project": { + "overrides": true + } + }, + "debug": { + "shareProjectConfig": true + } +} \ No newline at end of file diff --git a/amplify/hooks/README.md b/amplify/hooks/README.md new file mode 100644 index 00000000..8fb601ea --- /dev/null +++ b/amplify/hooks/README.md @@ -0,0 +1,7 @@ +# Command Hooks + +Command hooks can be used to run custom scripts upon Amplify CLI lifecycle events like pre-push, post-add-function, etc. + +To get started, add your script files based on the expected naming convention in this directory. + +Learn more about the script file naming convention, hook parameters, third party dependencies, and advanced configurations at https://docs.amplify.aws/cli/usage/command-hooks diff --git a/amplify/team-provider-info.json b/amplify/team-provider-info.json new file mode 100644 index 00000000..86d84a1a --- /dev/null +++ b/amplify/team-provider-info.json @@ -0,0 +1,23 @@ +{ + "master": { + "awscloudformation": { + "AuthRoleName": "amplify-maffinapp-master-161929-authRole", + "UnauthRoleArn": "arn:aws:iam::650534923181:role/amplify-maffinapp-master-161929-unauthRole", + "AuthRoleArn": "arn:aws:iam::650534923181:role/amplify-maffinapp-master-161929-authRole", + "Region": "eu-central-1", + "DeploymentBucketName": "amplify-maffinapp-master-161929-deployment", + "UnauthRoleName": "amplify-maffinapp-master-161929-unauthRole", + "StackName": "amplify-maffinapp-master-161929", + "StackId": "arn:aws:cloudformation:eu-central-1:650534923181:stack/amplify-maffinapp-master-161929/ca165f80-bcc0-11ed-bb03-022def382602", + "AmplifyAppId": "d199ayutgsrlxn" + }, + "categories": { + "function": { + "stockerlambda": { + "deploymentBucketName": "amplify-maffinapp-master-161929-deployment", + "s3Key": "amplify-builds/stockerlambda-625267674d6b78532b31-build.zip" + } + } + } + } +} \ No newline at end of file diff --git a/jest.config.mjs b/jest.config.mjs new file mode 100644 index 00000000..90d4b9d1 --- /dev/null +++ b/jest.config.mjs @@ -0,0 +1,34 @@ +// jest.config.mjs +import nextJest from 'next/jest.js' + +const createJestConfig = nextJest({ + // Provide the path to your Next.js app to load next.config.js and .env files in your test environment + dir: './', +}) + +// Add any custom config to be passed to Jest +/** @type {import('jest').Config} */ +const config = { + // Add more setup options before each test is run + setupFilesAfterEnv: ['/src/setupTests.ts'], + + collectCoverageFrom: ['src/**/*.{ts,tsx}'], + coverageThreshold: { + global: { + lines: 83, + branches: 78, + }, + }, + testEnvironment: 'jest-environment-jsdom', + testPathIgnorePatterns: [ + '/node_modules', + '/amplify', + ], + moduleNameMapper: { + '^@/(.*)$': '/src/$1', + '^uuid$': 'uuid', + }, +} + +// createJestConfig is exported this way to ensure that next/jest can load the Next.js config which is async +export default createJestConfig(config) diff --git a/next-env.d.ts b/next-env.d.ts new file mode 100644 index 00000000..4f11a03d --- /dev/null +++ b/next-env.d.ts @@ -0,0 +1,5 @@ +/// +/// + +// NOTE: This file should not be edited +// see https://nextjs.org/docs/basic-features/typescript for more information. diff --git a/next.config.js b/next.config.js new file mode 100644 index 00000000..e187bc8f --- /dev/null +++ b/next.config.js @@ -0,0 +1,57 @@ +const FilterWarningsPlugin = require('webpack-filter-warnings-plugin'); + +/** @type {import('next').NextConfig} */ +const nextConfig = { + reactStrictMode: true, + experimental: { + appDir: true, + }, + images: { + remotePatterns: [ + { + protocol: 'https', + hostname: 'lh3.googleusercontent.com', + pathname: '/a/*', + }, + ], + }, + webpack: (config, { isServer, webpack }) => { + if (!isServer) { + config.resolve.fallback = { + ...config.resolve.fallback, + fs: false, + 'react-native-sqlite-storage': false, + }; + + config.plugins = [ + ...config.plugins, + // This helps typeorm find sql.js driver. If we remove this then we + // need to pass the driver in datasource initialization. + new webpack.ProvidePlugin({ + 'window.SQL': 'sql.js/dist/sql-wasm.js' + }), + new FilterWarningsPlugin({ + exclude: [ + /mongodb/, + /mssql/, + /mysql/, + /mysql2/, + /oracledb/, + /pg/, + /pg-native/, + /pg-query-stream/, + /react-native-sqlite-storage/, + /redis/, + /sqlite3/, + /sql.js/, + /typeorm-aurora-data-api-driver/ + ], + }), + ]; + } + + return config; + }, +} + +module.exports = nextConfig diff --git a/package.json b/package.json new file mode 100644 index 00000000..33c96691 --- /dev/null +++ b/package.json @@ -0,0 +1,145 @@ +{ + "name": "maffin", + "version": "0.1.0", + "private": true, + "dependencies": { + "@dinero.js/currencies": "^2.0.0-alpha.14", + "@fontsource/inter": "^5.0.3", + "@tanstack/react-table": "^8.9.3", + "@testing-library/jest-dom": "^5.16.5", + "apexcharts": "^3.41.0", + "aws-amplify": "^5.3.1", + "class-validator": "^0.14.0", + "classnames": "^2.3.1", + "dinero.js": "^2.0.0-alpha.14", + "luxon": "^3.3.0", + "next": "^13.4.7", + "pako": "^2.1.0", + "react": "^18.2.0", + "react-apexcharts": "^1.3.9", + "react-dom": "^18.2.0", + "react-hook-form": "^7.45.0", + "react-hotkeys-hook": "^4.4.0", + "react-icons": "^4.10.1", + "react-select": "^5.7.3", + "reflect-metadata": "^0.1.13", + "sharp": "^0.32.1", + "simplebar-react": "^3.2.4", + "sql.js": "^1.8.0", + "swr": "^2.2.0", + "typeorm": "^0.3.17", + "winston-react": "^1.0.0-RC.0" + }, + "scripts": { + "maffin:dev": "next dev", + "maffin:run": "next start", + "maffin:build": "next build", + "maffin:test": "jest --watchAll=false", + "maffin:lint": "yarn eslint . --ext .js,.jsx,.ts,.tsx", + "stocker:start": "node amplify/backend/function/stockerlambda/src/local.js", + "stocker:install": "cd amplify/backend/function/stockerlambda/src/ && yarn && cd -", + "stocker:lint": "cd amplify/backend/function/stockerlambda/src/ && yarn eslint --ext .js && cd -", + "stocker:test": "cd amplify/backend/function/stockerlambda/src/ && yarn jest --coverage && cd -", + "stocker:test:events": "amplify mock function stockerlambda --event src/event.json" + }, + "eslintConfig": { + "plugins": [ + "prettier" + ], + "extends": [ + "next", + "prettier", + "airbnb", + "airbnb-typescript", + "react-app", + "react-app/jest", + "eslint:recommended", + "plugin:@typescript-eslint/recommended" + ], + "rules": { + "semi": "error", + "no-unexpected-multiline": "error", + "arrow-parens": "off", + "react/require-default-props": "off", + "max-classes-per-file": "off", + "@typescript-eslint/lines-between-class-members": "off", + "react/no-array-index-key": "off", + "jsx-a11y/no-static-element-interactions": "off", + "jsx-a11y/click-events-have-key-events": "off", + "import/prefer-default-export": "off", + "@typescript-eslint/ban-ts-comment": "off", + "@typescript-eslint/ban-types": "off", + "new-cap": "off", + "jsx-a11y/label-has-associated-control": "off", + "react/jsx-props-no-spreading": "off", + "no-underscore-dangle": "off", + "react/destructuring-assignment": "off", + "import/extensions": "off", + "no-param-reassign": "warn" + }, + "parserOptions": { + "project": "./tsconfig.json" + }, + "ignorePatterns": [ + "*.js", + "*.d.ts" + ], + "overrides": [ + { + "files": [ + "src/**/*.ts?(x)", + "src/**/*.test.ts?(x)" + ] + } + ] + }, + "browserslist": { + "production": [ + ">0.2%", + "not dead", + "not op_mini all" + ], + "development": [ + "last 1 chrome version", + "last 1 firefox version", + "last 1 safari version" + ] + }, + "devDependencies": { + "@testing-library/react": "^14.0.0", + "@testing-library/user-event": "^14.4.3", + "@types/gapi": "^0.0.44", + "@types/gapi.auth2": "^0.0.57", + "@types/gapi.client.drive": "^3.0.15", + "@types/gapi.client.people": "^1.0.5", + "@types/google.accounts": "^0.0.7", + "@types/jest": "^29.5.2", + "@types/luxon": "^3.3.0", + "@types/node": "^20.3.2", + "@types/pako": "^2.0.0", + "@types/react": "^18.2.14", + "@types/react-dom": "^18.2.6", + "@types/react-router-dom": "^5.3.3", + "@types/react-table": "^7.7.14", + "@types/react-test-renderer": "^18.0.0", + "@types/sql.js": "^1.4.4", + "autoprefixer": "^10.4.14", + "babel-preset-react-app": "^10.0.1", + "eslint": "^8.43.0", + "eslint-config-airbnb": "^19.0.4", + "eslint-config-airbnb-typescript": "^17.0.0", + "eslint-config-next": "^13.4.7", + "eslint-config-prettier": "^8.8.0", + "eslint-config-react-app": "^7.0.1", + "eslint-plugin-prettier": "^4.2.1", + "jest": "^29.5.0", + "jest-environment-jsdom": "^29.5.0", + "postcss": "^8.4.24", + "prettier": "^2.8.8", + "prettier-plugin-tailwindcss": "^0.3.0", + "snapshot-diff": "^0.10.0", + "tailwindcss": "^3.3.2", + "typescript": "^5.1.3", + "webpack-filter-warnings-plugin": "^1.2.1" + } +} diff --git a/postcss.config.js b/postcss.config.js new file mode 100644 index 00000000..33ad091d --- /dev/null +++ b/postcss.config.js @@ -0,0 +1,6 @@ +module.exports = { + plugins: { + tailwindcss: {}, + autoprefixer: {}, + }, +} diff --git a/public/favicon/apple-touch-icon.png b/public/favicon/apple-touch-icon.png new file mode 100644 index 0000000000000000000000000000000000000000..079feca2f4fe2e88c48fbc02dcdfdaeab414119a GIT binary patch literal 26919 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 literal 0 HcmV?d00001 diff --git a/src/__tests__/apis/BookStorage.test.ts b/src/__tests__/apis/BookStorage.test.ts new file mode 100644 index 00000000..2fe55ebb --- /dev/null +++ b/src/__tests__/apis/BookStorage.test.ts @@ -0,0 +1,304 @@ +import BookStorage from '@/apis/BookStorage'; + +describe('GoogleDrive', () => { + let rawBook: Uint8Array; + let client: BookStorage; + let mockDriveClient: typeof gapi.client.drive; + let mockGapiClient: typeof gapi.client; + let mockFetch: jest.SpyInstance; + + beforeEach(() => { + rawBook = new Uint8Array([22, 33]); + mockDriveClient = { + files: { + // @ts-ignore + list: jest.fn(async () => ( + { + result: { + files: [], + }, + } + )), + // @ts-ignore + create: jest.fn(async () => ( + { + result: { + id: 'createdResourceId', + }, + } + )), + }, + }; + mockGapiClient = { + // @ts-ignore + request: jest.fn(async () => {}), + drive: mockDriveClient, + getToken: () => ({ + access_token: 'ACCESS_TOKEN', + error: '', + expires_in: 'never', + state: 'state', + }), + }; + client = new BookStorage(mockGapiClient); + + global.fetch = jest.fn(); + mockFetch = jest.spyOn(global, 'fetch'); + }); + + afterEach(() => { + jest.restoreAllMocks(); + }); + + describe('findParentFolderId', () => { + it('calls list with expected params', async () => { + await client.findParentFolderId(); + expect(mockDriveClient.files.list).toHaveBeenNthCalledWith( + 1, + { + q: 'mimeType = \'application/vnd.google-apps.folder\' and name=\'maffin.io\' and trashed = false', + }, + ); + }); + + it('returns parentFolderId when found', async () => { + // @ts-ignore + mockDriveClient.files.list = jest.fn(async () => ( + { + result: { + files: [ + { + id: 'parentFolderId', + }, + ], + }, + } + )); + const parentFolderId = await client.findParentFolderId(); + expect(parentFolderId).toEqual('parentFolderId'); + }); + + it('returns empty string when not found', async () => { + const parentFolderId = await client.findParentFolderId(); + expect(parentFolderId).toEqual(''); + }); + }); + + describe('findBookFileId', () => { + beforeEach(() => { + client.parentFolderId = 'parentFolderId'; + }); + + it('calls list with expected params', async () => { + await client.findBookFileId('book1'); + expect(mockDriveClient.files.list).toHaveBeenNthCalledWith( + 1, + { + q: 'name=\'book1.sqlite\' and trashed = false and \'parentFolderId\' in parents', + }, + ); + }); + + it('returns bookFileId when found', async () => { + // @ts-ignore + mockDriveClient.files.list = jest.fn(async () => ( + { + result: { + files: [ + { + id: 'bookFileId', + }, + ], + }, + } + )); + const bookFileId = await client.findBookFileId('book1'); + expect(bookFileId).toEqual('bookFileId'); + }); + + it('returns empty string when not found', async () => { + const bookFileId = await client.findBookFileId('book1'); + expect(bookFileId).toEqual(''); + }); + + it('fails when parentFolderId is not set', async () => { + client.parentFolderId = ''; + await expect(client.findBookFileId('book1')).rejects.toThrow('Parent folder id is not set'); + }); + }); + + describe('initStorage', () => { + beforeEach(() => { + jest.spyOn(client, 'findParentFolderId').mockReturnValue(Promise.resolve('parentFolderId')); + jest.spyOn(client, 'findBookFileId').mockReturnValue(Promise.resolve('bookFileId')); + }); + + it('calls findParentFolderId', async () => { + await client.initStorage(); + expect(client.findParentFolderId).toHaveBeenCalledTimes(1); + }); + + it('creates parent folder and book file when not initialised', async () => { + jest.spyOn(client, 'findParentFolderId').mockReturnValue(Promise.resolve('')); + jest.spyOn(client, 'findBookFileId').mockReturnValue(Promise.resolve('')); + mockFetch = jest.spyOn(global, 'fetch').mockImplementation( + jest.fn(() => Promise.resolve({ + json: () => Promise.resolve({ id: 'createdResourceId' }), + })) as jest.Mock, + ); + await client.initStorage(); + expect(client.parentFolderId).toEqual('createdResourceId'); + expect(client.bookFileId).toEqual('createdResourceId'); + expect(mockDriveClient.files.create).toHaveBeenNthCalledWith( + 1, + { + fields: 'id', + resource: { + name: 'maffin.io', + mimeType: 'application/vnd.google-apps.folder', + }, + }, + ); + expect(mockDriveClient.files.create).toHaveBeenNthCalledWith( + 2, + { + fields: 'id', + resource: { + name: 'book1.sqlite', + mimeType: 'application/vnd.sqlite3', + parents: ['createdResourceId'], + }, + }, + ); + }); + + it('doesnt recreate when initialised', async () => { + // @ts-ignore + mockDriveClient.files.list = jest.fn(async () => ( + { + result: { + files: [ + { + id: 'parentFolderId', + }, + ], + }, + } + )); + await client.initStorage(); + expect(client.parentFolderId).toEqual('parentFolderId'); + expect(mockDriveClient.files.create).not.toHaveBeenCalled(); + }); + + it('raises an error when cant find parent id after creating', async () => { + jest.spyOn(client, 'findParentFolderId').mockReturnValue(Promise.resolve('')); + // @ts-ignore + mockDriveClient.files.create = jest.fn(async () => ( + { + result: { + id: undefined, + }, + } + )); + + await expect(client.initStorage()).rejects.toThrow('Couldnt get parent folder id'); + }); + + it('calls findBookFileId', async () => { + await client.initStorage(); + expect(client.findBookFileId).toHaveBeenCalledTimes(1); + }); + + it('raises an error when cant find book id after creating', async () => { + jest.spyOn(client, 'findParentFolderId').mockReturnValue(Promise.resolve('parentFolderId')); + jest.spyOn(client, 'findBookFileId').mockReturnValue(Promise.resolve('')); + // @ts-ignore + mockDriveClient.files.create = jest.fn(async () => ( + { + result: { + id: undefined, + }, + } + )); + + await expect(client.initStorage()).rejects.toThrow('Couldnt get bookFile id'); + }); + }); + + describe('get', () => { + beforeEach(() => { + mockFetch = jest.spyOn(global, 'fetch').mockImplementation( + jest.fn(() => Promise.resolve({ + arrayBuffer: () => Promise.resolve(rawBook), + })) as jest.Mock, + ); + jest.spyOn(client, 'initStorage'); + }); + + it('inits storage when no parentFolderId', async () => { + await client.get(); + expect(client.initStorage).toHaveBeenCalledTimes(1); + }); + + it('returns rawBook from downloaded file', async () => { + client.parentFolderId = 'parentFolderId'; + client.bookFileId = 'bookFileId'; + const content = await client.get(); + + expect(mockFetch).toHaveBeenNthCalledWith( + 1, + 'https://www.googleapis.com/drive/v3/files/bookFileId?alt=media', + { + headers: new Headers({ + authorization: 'Bearer ACCESS_TOKEN', + 'content-type': 'application/vnd.sqlite3', + }), + method: 'GET', + }, + ); + expect(content).toEqual(rawBook); + }); + }); + + describe('save', () => { + beforeEach(() => { + jest.spyOn(client, 'initStorage'); + }); + + it('inits storage when no parentFolderId', async () => { + await client.save(rawBook); + expect(client.initStorage).toHaveBeenCalledTimes(1); + }); + + it('saves book as expected', async () => { + client.parentFolderId = 'parentFolderId'; + client.bookFileId = 'bookFileId'; + await client.save(rawBook); + + expect(mockFetch).toHaveBeenNthCalledWith( + 1, + 'https://www.googleapis.com/upload/drive/v3/files/bookFileId', + { + method: 'PATCH', + headers: new Headers({ + authorization: 'Bearer ACCESS_TOKEN', + 'content-type': 'application/vnd.sqlite3', + }), + body: expect.any(Blob), + }, + ); + + const blob = mockFetch.mock.calls[0][1]!.body as Blob; + const blobData = await fileToArrayBuffer(blob); + expect(new Uint8Array(blobData as ArrayBuffer)).toEqual(rawBook); + }); + }); +}); + +function fileToArrayBuffer(f: Blob): Promise { + return new Promise((resolve) => { + const reader = new FileReader(); + reader.onloadend = () => resolve(reader.result); + reader.readAsArrayBuffer(f); + }); +} diff --git a/src/__tests__/app/dashboard/__snapshots__/layout.test.tsx.snap b/src/__tests__/app/dashboard/__snapshots__/layout.test.tsx.snap new file mode 100644 index 00000000..a8d9f405 --- /dev/null +++ b/src/__tests__/app/dashboard/__snapshots__/layout.test.tsx.snap @@ -0,0 +1,44 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`DashboardLayout renders as expected when user available 1`] = ` +
+
+