From 1b11bb00641e2a13266cc02f02d7ca45f38374dc Mon Sep 17 00:00:00 2001 From: duckception Date: Fri, 8 Sep 2023 03:29:31 +0200 Subject: [PATCH 01/35] Remove leftover TODOs --- commands/metamask.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/commands/metamask.js b/commands/metamask.js index 2c217513a..6e06bf40d 100644 --- a/commands/metamask.js +++ b/commands/metamask.js @@ -1221,11 +1221,11 @@ const metamask = { // 120 seconds while (retries < retiresLimit) { - const pendingTxs = await playwright // TODO rename + const pendingTxs = await playwright .metamaskWindow() .getByText('Pending') .count(); - const queuedTxs = await playwright // TODO rename + const queuedTxs = await playwright .metamaskWindow() .getByText('Queued') .count(); From b6637c1d6988dbf6fdffb47027b5b97da117a878 Mon Sep 17 00:00:00 2001 From: duckception Date: Sat, 9 Sep 2023 19:25:30 +0200 Subject: [PATCH 02/35] Remove text based locators --- commands/metamask.js | 17 ++++++++++++----- 1 file changed, 12 insertions(+), 5 deletions(-) diff --git a/commands/metamask.js b/commands/metamask.js index 6e06bf40d..3b796c48f 100644 --- a/commands/metamask.js +++ b/commands/metamask.js @@ -1266,13 +1266,19 @@ const metamask = { .locator( `${mainPageElements.activityTab.completedTransactionsList} > div`, ) - .filter({ hasNotText: 'History' }) - .filter({ hasNotText: 'View more' }) + .filter({ + has: playwright.metamaskWindow().locator('div.list-item__heading'), + }) .all(); while (txIndex >= visibleTxs.length) { try { - await playwright.metamaskWindow().getByText('View more').click(); + await playwright + .metamaskWindow() + .locator( + `${mainPageElements.activityTab.completedTransactionsList} > button`, + ) + .click(); } catch (error) { log('[openTransactionDetails] Clicking "View more" failed!'); throw new Error( @@ -1285,8 +1291,9 @@ const metamask = { .locator( `${mainPageElements.activityTab.completedTransactionsList} > div`, ) - .filter({ hasNotText: 'History' }) - .filter({ hasNotText: 'View more' }) + .filter({ + has: playwright.metamaskWindow().locator('div.list-item__heading'), + }) .all(); } From 0f2570687b095bc711852862044b4346d2ec4639 Mon Sep 17 00:00:00 2001 From: Daniel Izdebski Date: Thu, 14 Sep 2023 23:07:19 +0200 Subject: [PATCH 03/35] Add `Known problems with MetaMask` section --- README.md | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/README.md b/README.md index 981f5e026..e967ec303 100644 --- a/README.md +++ b/README.md @@ -441,6 +441,15 @@ Options: -h, --help display help for command ``` +## ๐Ÿ‘จโ€โš•๏ธ Known problems with MetaMask + +If your MetaMask is stuck on the loading screen, check what's happening under the hood in the console. You can find vital information about why it's stuck on this step. + +#### โญ Sentry.io HTTP error 499 (Request has been forbidden by antivirus) + +- Kaspersky antivirus sometimes blocks encrypted requests to Sentry.io. You can disable + this feature in Kaspersky advanced settings by toggling on `"Do not scan encrypted connections"`. + ## ๐Ÿ“ƒ Environmental variables | Variable | Description | From fc9b2aae09b9615286943e255d1a2c8f05daaf7d Mon Sep 17 00:00:00 2001 From: Daniel Izdebski Date: Thu, 12 Oct 2023 18:11:05 +0200 Subject: [PATCH 04/35] Remove Promise wrap from `cy.setupMetamask()` (#927) --- support/index.js | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/support/index.js b/support/index.js index db1b561b3..41b6fae42 100644 --- a/support/index.js +++ b/support/index.js @@ -24,8 +24,8 @@ Cypress.on('window:before:load', win => { }); }); -before(async () => { +before(() => { if (!Cypress.env('SKIP_METAMASK_SETUP')) { - await cy.setupMetamask(); + cy.setupMetamask(); } }); From ebeb4508ca0cc6cf54b4ba6154b2dca64f7c5835 Mon Sep 17 00:00:00 2001 From: Peter F Date: Wed, 18 Oct 2023 15:44:42 +0200 Subject: [PATCH 05/35] Fix localized Chrome's extension id (#928) * Fix localized Chrome's extension id * Improve id handling --------- Co-authored-by: Piotr Frankowski --- commands/playwright.js | 26 ++++++++++++++------------ 1 file changed, 14 insertions(+), 12 deletions(-) diff --git a/commands/playwright.js b/commands/playwright.js index a474e8b5f..fa3e350f3 100644 --- a/commands/playwright.js +++ b/commands/playwright.js @@ -57,6 +57,11 @@ module.exports = { activeTabName() { return activeTabName; }, + async metamaskExtensionId() { + const metamaskExtensionData = (await module.exports.getExtensionsData()) + .metamask; + return metamaskExtensionData.id; + }, async setExpectInstance(expect) { expectInstance = expect; }, @@ -87,8 +92,7 @@ module.exports = { return true; }, async assignWindows() { - const metamaskExtensionData = (await module.exports.getExtensionsData()) - .metamask; + const metamaskExtensionId = await module.exports.metamaskExtensionId(); let pages = await browser.contexts()[0].pages(); for (const page of pages) { @@ -97,21 +101,21 @@ module.exports = { } else if ( page .url() - .includes(`chrome-extension://${metamaskExtensionData.id}/home.html`) + .includes(`chrome-extension://${metamaskExtensionId}/home.html`) ) { metamaskWindow = page; } else if ( page .url() .includes( - `chrome-extension://${metamaskExtensionData.id}/notification.html`, + `chrome-extension://${metamaskExtensionId}/notification.html`, ) ) { metamaskNotificationWindow = page; } else if ( page .url() - .includes(`chrome-extension://${metamaskExtensionData.id}/popup.html`) + .includes(`chrome-extension://${metamaskExtensionId}/popup.html`) ) { metamaskPopupWindow = page; } @@ -161,8 +165,7 @@ module.exports = { return true; }, async switchToMetamaskNotification() { - const metamaskExtensionData = (await module.exports.getExtensionsData()) - .metamask; + const metamaskExtensionId = await module.exports.metamaskExtensionId(); let pages = await browser.contexts()[0].pages(); for (const page of pages) { @@ -170,7 +173,7 @@ module.exports = { page .url() .includes( - `chrome-extension://${metamaskExtensionData.id}/notification.html`, + `chrome-extension://${metamaskExtensionId}/notification.html`, ) ) { metamaskNotificationWindow = page; @@ -337,15 +340,14 @@ module.exports = { } }, async waitUntilStable(page) { - const metamaskExtensionData = (await module.exports.getExtensionsData()) - .metamask; + const metamaskExtensionId = await module.exports.metamaskExtensionId(); if ( page && page .url() .includes( - `chrome-extension://${metamaskExtensionData.id}/notification.html`, + `chrome-extension://${metamaskExtensionId}/notification.html`, ) ) { await page.waitForLoadState('load'); @@ -477,7 +479,7 @@ module.exports = { const extensionId = ( await extensionData.locator('#extension-id').textContent() - ).replace('ID: ', ''); + ).split(': ')[1]; extensionsData[extensionName] = { version: extensionVersion, From 5ecfd6468cc460e653b2f5a06160478485a76a7e Mon Sep 17 00:00:00 2001 From: Daniel Izdebski Date: Wed, 18 Oct 2023 15:49:26 +0200 Subject: [PATCH 06/35] Lint --- commands/playwright.js | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/commands/playwright.js b/commands/playwright.js index fa3e350f3..c71eaf205 100644 --- a/commands/playwright.js +++ b/commands/playwright.js @@ -59,7 +59,7 @@ module.exports = { }, async metamaskExtensionId() { const metamaskExtensionData = (await module.exports.getExtensionsData()) - .metamask; + .metamask; return metamaskExtensionData.id; }, async setExpectInstance(expect) { @@ -346,9 +346,7 @@ module.exports = { page && page .url() - .includes( - `chrome-extension://${metamaskExtensionId}/notification.html`, - ) + .includes(`chrome-extension://${metamaskExtensionId}/notification.html`) ) { await page.waitForLoadState('load'); await page.waitForLoadState('domcontentloaded'); From de76346e5ad8e86851531070a746a1f0108342f1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Rafa=C5=82=20Majchrzak?= Date: Wed, 18 Oct 2023 17:22:42 +0200 Subject: [PATCH 07/35] Feature/revoke permission to all (#932) * Fix typo in Permission word * Add permission revoking actions * Add tests for permission revoking actions * Regenerate synpress commands file --- commands/metamask.js | 22 ++- docs/synpress-commands.md | 227 +++++++++++++++++++++---------- plugins/index.js | 7 +- support/commands.js | 16 ++- support/index.d.ts | 34 +++-- tests/e2e/specs/metamask-spec.js | 20 ++- 6 files changed, 234 insertions(+), 92 deletions(-) diff --git a/commands/metamask.js b/commands/metamask.js index 3b796c48f..5e6e726e7 100644 --- a/commands/metamask.js +++ b/commands/metamask.js @@ -1348,7 +1348,7 @@ const metamask = { ); return true; }, - async confirmPermisionToApproveAll() { + async confirmPermissionToApproveAll() { const notificationPage = await playwright.switchToMetamaskNotification(); await playwright.waitAndClick( notificationPageElements.allowToSpendButton, @@ -1361,7 +1361,7 @@ const metamask = { ); return true; }, - async rejectPermisionToApproveAll() { + async rejectPermissionToApproveAll() { const notificationPage = await playwright.switchToMetamaskNotification(); await playwright.waitAndClick( notificationPageElements.allowToSpendButton, @@ -1374,6 +1374,24 @@ const metamask = { ); return true; }, + async confirmRevokePermissionToAll() { + const notificationPage = await playwright.switchToMetamaskNotification(); + await playwright.waitAndClick( + notificationPageElements.allowToSpendButton, + notificationPage, + { waitForEvent: 'close' }, + ); + return true; + }, + async rejectRevokePermissionToAll() { + const notificationPage = await playwright.switchToMetamaskNotification(); + await playwright.waitAndClick( + notificationPageElements.rejectToSpendButton, + notificationPage, + { waitForEvent: 'close' }, + ); + return true; + }, async allowToAddNetwork({ waitForEvent } = {}) { const notificationPage = await playwright.switchToMetamaskNotification(); if (waitForEvent) { diff --git a/docs/synpress-commands.md b/docs/synpress-commands.md index 408d800aa..8a5564c95 100644 --- a/docs/synpress-commands.md +++ b/docs/synpress-commands.md @@ -5,7 +5,7 @@ Connect playwright with Cypress instance. ```ts -initPlaywright(): Chainable; +initPlaywright(): Chainable; ``` #### `cy.assignWindows()` @@ -13,7 +13,7 @@ initPlaywright(): Chainable; Assign currently open tabs with playwright. ```ts -assignWindows(): Chainable; +assignWindows(): Chainable; ``` #### `cy.assignActiveTabName()` @@ -21,7 +21,7 @@ assignWindows(): Chainable; Assigns currently active tab. ```ts -assignActiveTabName(): Chainable; +assignActiveTabName(tabName: string): Chainable; ``` #### `cy.isMetamaskWindowActive()` @@ -29,7 +29,7 @@ assignActiveTabName(): Chainable; Checks if current active tab is metamask. ```ts -isMetamaskWindowActive(): Chainable; +isMetamaskWindowActive(): Chainable; ``` #### `cy.isCypressWindowActive()` @@ -37,7 +37,7 @@ isMetamaskWindowActive(): Chainable; Checks if current active tab is cypress. ```ts -isCypressWindowActive(): Chainable; +isCypressWindowActive(): Chainable; ``` #### `cy.switchToCypressWindow()` @@ -45,7 +45,7 @@ isCypressWindowActive(): Chainable; Switch to Cypress window. ```ts -switchToCypressWindow(): Chainable; +switchToCypressWindow(): Chainable; ``` #### `cy.switchToMetamaskWindow()` @@ -53,7 +53,7 @@ switchToCypressWindow(): Chainable; Switch to metamask window. ```ts -switchToMetamaskWindow(): Chainable; +switchToMetamaskWindow(): Chainable; ``` #### `cy.switchToMetamaskNotification()` @@ -61,7 +61,7 @@ switchToMetamaskWindow(): Chainable; Switch to metamask notification window. ```ts -switchToMetamaskNotification(): Chainable; +switchToMetamaskNotification(): Chainable; ``` #### `cy.getCurrentNetwork()` @@ -77,15 +77,26 @@ getCurrentNetwork(): Chainable; Add network in metamask (and also switch to the newly added network). ```ts -addMetamaskNetwork(network: object): Chainable; +addMetamaskNetwork( + network: + | string + | { + networkName: string; + rpcUrl: string; + chainId: number; + symbol?: string; + blockExplorer?: string; + isTestnet: boolean; + }, +): Chainable; ``` #### `cy.changeMetamaskNetwork()` -Change network in metamask. +Change network in metamask (if network is not present, it will be added). ```ts -changeMetamaskNetwork(network: string): Chainable; +changeMetamaskNetwork(network: string): Chainable; ``` #### `cy.importMetamaskAccount()` @@ -93,7 +104,7 @@ changeMetamaskNetwork(network: string): Chainable; Import new account in metamask using private key. ```ts -importMetamaskAccount(privateKey: string): Chainable; +importMetamaskAccount(privateKey: string): Chainable; ``` #### `cy.createMetamaskAccount()` @@ -101,7 +112,7 @@ importMetamaskAccount(privateKey: string): Chainable; Create new account in metamask. ```ts -createMetamaskAccount(accountName?: string): Chainable; +createMetamaskAccount(accountName?: string): Chainable; ``` #### `cy.renameMetamaskAccount()` @@ -109,7 +120,7 @@ createMetamaskAccount(accountName?: string): Chainable; Rename current account in metamask. ```ts -createMetamaskAccount(newAccountName: string): Chainable; +renameMetamaskAccount(newAccountName: string): Chainable; ``` #### `cy.switchMetamaskAccount()` @@ -119,7 +130,7 @@ Switch metamask account. ```ts switchMetamaskAccount( accountNameOrAccountNumber: string | number, -): Chainable; +): Chainable; ``` #### `cy.getMetamaskWalletAddress()` @@ -127,35 +138,38 @@ switchMetamaskAccount( Get current wallet address of metamask wallet. ```ts -getMetamaskWalletAddress(): Chainable; +getMetamaskWalletAddress(): Chainable; ``` #### `cy.activateAdvancedGasControlInMetamask()` -Activate ability (in metamask settings) to specify custom gas price and limit while doing transactions in metamask. +Activate ability (in metamask settings) to specify custom gas price and limit +while doing transactions in metamask. ```ts activateAdvancedGasControlInMetamask( skipSetup?: boolean, -): Chainable; +): Chainable; ``` #### `cy.activateShowHexDataInMetamask()` -Activate ability (in metamask settings) to show hex data while doing transaction in metamask. +Activate ability (in metamask settings) to show hex data while doing transaction +in metamask. ```ts -activateShowHexDataInMetamask(skipSetup?: boolean): Chainable; +activateShowHexDataInMetamask(skipSetup?: boolean): Chainable; ``` #### `cy.activateTestnetConversionInMetamask()` -Activate ability (in metamask settings) to show fiat conversions on testnets in metamask. +Activate ability (in metamask settings) to show fiat conversions on testnets in +metamask. ```ts activateTestnetConversionInMetamask( skipSetup?: boolean, -): Chainable; +): Chainable; ``` #### `cy.activateShowTestnetNetworksInMetamask()` @@ -165,25 +179,27 @@ Activate ability (in metamask settings) to show testnet networks in metamask. ```ts activateShowTestnetNetworksInMetamask( skipSetup?: boolean, -): Chainable; +): Chainable; ``` #### `cy.activateCustomNonceInMetamask()` -Activate ability (in metamask settings) to specify custom nonce while doing transactions in metamask. +Activate ability (in metamask settings) to specify custom nonce while doing +transactions in metamask. ```ts -activateCustomNonceInMetamask(skipSetup?: boolean): Chainable; +activateCustomNonceInMetamask(skipSetup?: boolean): Chainable; ``` #### `cy.activateDismissBackupReminderInMetamask()` -Activate ability (in metamask settings) to dismiss secret recovery phrase reminder in metamask. +Activate ability (in metamask settings) to dismiss secret recovery phrase +reminder in metamask. ```ts activateDismissBackupReminderInMetamask( skipSetup?: boolean, -): Chainable; +): Chainable; ``` #### `cy.activateEthSignRequestsInMetamask()` @@ -191,7 +207,7 @@ activateDismissBackupReminderInMetamask( Activate eth sign requests in metamask settings. ```ts -activateEthSignRequestsInMetamask(skipSetup?: boolean): Chainable; +activateEthSignRequestsInMetamask(skipSetup?: boolean): Chainable; ``` #### `cy.activateImprovedTokenAllowanceInMetamask()` @@ -201,7 +217,7 @@ Activate improved token allowance in metamask settings (experimental). ```ts activateImprovedTokenAllowanceInMetamask( skipSetup?: boolean, -): Chainable; +): Chainable; ``` #### `cy.resetMetamaskAccount()` @@ -209,7 +225,7 @@ activateImprovedTokenAllowanceInMetamask( Reset metamask account state in settings. ```ts -resetMetamaskAccount(): Chainable; +resetMetamaskAccount(): Chainable; ``` #### `cy.disconnectMetamaskWalletFromDapp()` @@ -217,7 +233,7 @@ resetMetamaskAccount(): Chainable; Disconnects metamask wallet from last connected dapp. ```ts -disconnectMetamaskWalletFromDapp(): Chainable; +disconnectMetamaskWalletFromDapp(): Chainable; ``` #### `cy.disconnectMetamaskWalletFromAllDapps()` @@ -225,7 +241,7 @@ disconnectMetamaskWalletFromDapp(): Chainable; Disconnects metamask wallet from all connected dapps. ```ts -disconnectMetamaskWalletFromAllDapps(): Chainable; +disconnectMetamaskWalletFromAllDapps(): Chainable; ``` #### `cy.confirmMetamaskSignatureRequest()` @@ -233,7 +249,7 @@ disconnectMetamaskWalletFromAllDapps(): Chainable; Confirm metamask permission to sign message. ```ts -confirmMetamaskSignatureRequest(): Chainable; +confirmMetamaskSignatureRequest(): Chainable; ``` #### `cy.confirmMetamaskDataSignatureRequest()` @@ -241,7 +257,7 @@ confirmMetamaskSignatureRequest(): Chainable; Confirm metamask permission to sign Data message. ```ts -confirmMetamaskDataSignatureRequest(): Chainable; +confirmMetamaskDataSignatureRequest(): Chainable; ``` #### `cy.rejectMetamaskSignatureRequest()` @@ -249,7 +265,7 @@ confirmMetamaskDataSignatureRequest(): Chainable; Reject metamask permission to sign message. ```ts -rejectMetamaskSignatureRequest(): Chainable; +rejectMetamaskSignatureRequest(): Chainable; ``` #### `cy.confirmMetamaskEncryptionPublicKeyRequest()` @@ -257,7 +273,7 @@ rejectMetamaskSignatureRequest(): Chainable; Confirm metamask request for public encryption key. ```ts -confirmMetamaskEncryptionPublicKeyRequest(): Chainable; +confirmMetamaskEncryptionPublicKeyRequest(): Chainable; ``` #### `cy.rejectMetamaskEncryptionPublicKeyRequest()` @@ -265,7 +281,7 @@ confirmMetamaskEncryptionPublicKeyRequest(): Chainable; Reject metamask request for public encryption key. ```ts -rejectMetamaskEncryptionPublicKeyRequest(): Chainable; +rejectMetamaskEncryptionPublicKeyRequest(): Chainable; ``` #### `cy.confirmMetamaskDecryptionRequest()` @@ -273,7 +289,7 @@ rejectMetamaskEncryptionPublicKeyRequest(): Chainable; Confirm metamask request to decrypt message with private key. ```ts -confirmMetamaskDecryptionRequest(): Chainable; +confirmMetamaskDecryptionRequest(): Chainable; ``` #### `cy.rejectMetamaskDecryptionRequest()` @@ -281,7 +297,7 @@ confirmMetamaskDecryptionRequest(): Chainable; Reject metamask request to decrypt message with private key. ```ts -rejectMetamaskDecryptionRequest(): Chainable; +rejectMetamaskDecryptionRequest(): Chainable; ``` #### `cy.rejectMetamaskDataSignatureRequest()` @@ -289,7 +305,7 @@ rejectMetamaskDecryptionRequest(): Chainable; Reject metamask permission to sign Data message. ```ts -rejectMetamaskDataSignatureRequest(): Chainable; +rejectMetamaskDataSignatureRequest(): Chainable; ``` #### `cy.importMetamaskToken()` @@ -297,7 +313,14 @@ rejectMetamaskDataSignatureRequest(): Chainable; Add custom token to metamask. ```ts -importMetamaskToken(tokenConfig?: object | string): Chainable; +importMetamaskToken( + tokenConfig?: + | { + address: string; + symbol: string; + } + | string, +): Chainable; ``` #### `cy.confirmMetamaskAddToken()` @@ -305,7 +328,7 @@ importMetamaskToken(tokenConfig?: object | string): Chainable; Confirm metamask request to add token. ```ts -confirmMetamaskAddToken(): Chainable; +confirmMetamaskAddToken(): Chainable; ``` #### `cy.rejectMetamaskAddToken()` @@ -313,7 +336,7 @@ confirmMetamaskAddToken(): Chainable; Reject metamask request to add token. ```ts -rejectMetamaskAddToken(): Chainable; +rejectMetamaskAddToken(): Chainable; ``` #### `cy.confirmMetamaskPermissionToSpend()` @@ -321,23 +344,41 @@ rejectMetamaskAddToken(): Chainable; Confirm metamask permission to spend asset. ```ts -confirmMetamaskPermissionToSpend(spendLimit?: string): Chainable; +confirmMetamaskPermissionToSpend(spendLimit?: string): Chainable; ``` -#### `cy.confirmMetamaskPermisionToApproveAll()` +#### `cy.confirmMetamaskPermissionToApproveAll()` Confirm metamask permission to access all elements (example: collectibles). ```ts -confirmMetamaskPermisionToApproveAll(): Chainable; +confirmMetamaskPermissionToApproveAll(): Chainable; ``` -#### `cy.rejectMetamaskPermisionToApproveAll()` +#### `cy.rejectMetamaskPermissionToApproveAll()` Reject metamask permission to access all elements (example: collectibles). ```ts -rejectMetamaskPermisionToApproveAll(): Chainable; +rejectMetamaskPermissionToApproveAll(): Chainable; +``` + +#### `cy.confirmMetamaskRevokePermissionToAll()` + +Confirm metamask revoking permission to access all elements (example: +collectibles). + +```ts +confirmMetamaskRevokePermissionToAll(): Chainable; +``` + +#### `cy.rejectMetamaskRevokePermissionToAll()` + +Reject metamask revoking permission to access all elements (example: +collectibles). + +```ts +rejectMetamaskRevokePermissionToAll(): Chainable; ``` #### `cy.rejectMetamaskPermissionToSpend()` @@ -345,7 +386,7 @@ rejectMetamaskPermisionToApproveAll(): Chainable; Reject metamask permission to spend asset. ```ts -rejectMetamaskPermissionToSpend(): Chainable; +rejectMetamaskPermissionToSpend(): Chainable; ``` #### `cy.acceptMetamaskAccess()` @@ -357,7 +398,15 @@ acceptMetamaskAccess(options?: { allAccounts?: boolean; confirmSignatureRequest?: boolean; confirmDataSignatureRequest?: boolean; -}): Chainable; +}): Chainable; +``` + +#### `cy.rejectMetamaskAccess()` + +Reject metamask access request. + +```ts +rejectMetamaskAccess(): Chainable; ``` #### `cy.confirmMetamaskTransaction()` @@ -365,15 +414,46 @@ acceptMetamaskAccess(options?: { Confirm metamask transaction (auto-detects eip-1559 and legacy transactions). ```ts -confirmMetamaskTransaction(gasConfig?: object | string): Chainable; +confirmMetamaskTransaction( + gasConfig?: + | { + gasLimit?: number; + baseFee?: number; + priorityFee?: number; + } + | { + gasLimit?: number; + gasPrice?: number; + } + | 'low' + | 'market' + | 'aggressive' + | 'site', +): Chainable; ``` #### `cy.confirmMetamaskTransactionAndWaitForMining()` -Confirm metamask transaction (auto-detects eip-1559 and legacy transactions) and wait for ALL pending transactions to be mined. - -```ts -confirmMetamaskTransactionAndWaitForMining(gasConfig?: object | string): Chainable; +Confirm metamask transaction (auto-detects eip-1559 and legacy transactions) and +wait for ALL pending transactions to be mined. + +```ts +confirmMetamaskTransactionAndWaitForMining( + gasConfig?: + | { + gasLimit?: number; + baseFee?: number; + priorityFee?: number; + } + | { + gasLimit?: number; + gasPrice?: number; + } + | 'low' + | 'market' + | 'aggressive' + | 'site', +): Chainable; ``` #### `cy.rejectMetamaskTransaction()` @@ -381,12 +461,13 @@ confirmMetamaskTransactionAndWaitForMining(gasConfig?: object | string): Chainab Reject metamask transaction. ```ts -rejectMetamaskTransaction(): Chainable; +rejectMetamaskTransaction(): Chainable; ``` #### `cy.openMetamaskTransactionDetails()` -Open metamask transaction details based on the index of the transaction in the list on the activity tab. +Open metamask transaction details based on the index of the transaction in the +list on the activity tab. ```ts openMetamaskTransactionDetails(txIndex: number): Chainable; @@ -394,10 +475,10 @@ openMetamaskTransactionDetails(txIndex: number): Chainable; #### `cy.closeMetamaskTransactionDetailsPopup()` -Close currently open transaction details popup. +Close metamask transaction details popup. ```ts -closeMetamaskTransactionDetailsPopup(): Chainable; +closeMetamaskTransactionDetailsPopup(): Chainable; ``` #### `cy.allowMetamaskToAddNetwork()` @@ -405,7 +486,7 @@ closeMetamaskTransactionDetailsPopup(): Chainable; Allow site to add new network in metamask. ```ts -allowMetamaskToAddNetwork(waitForEvent?: string): Chainable; +allowMetamaskToAddNetwork(waitForEvent?: string): Chainable; ``` #### `cy.rejectMetamaskToAddNetwork()` @@ -413,7 +494,7 @@ allowMetamaskToAddNetwork(waitForEvent?: string): Chainable; Reject site to add new network in metamask. ```ts -rejectMetamaskToAddNetwork(): Chainable; +rejectMetamaskToAddNetwork(): Chainable; ``` #### `cy.allowMetamaskToSwitchNetwork()` @@ -421,7 +502,7 @@ rejectMetamaskToAddNetwork(): Chainable; Allow site to switch network in metamask. ```ts -allowMetamaskToSwitchNetwork(): Chainable; +allowMetamaskToSwitchNetwork(): Chainable; ``` #### `cy.rejectMetamaskToSwitchNetwork()` @@ -429,7 +510,7 @@ allowMetamaskToSwitchNetwork(): Chainable; Reject site to switch network in metamask. ```ts -rejectMetamaskToSwitchNetwork(): Chainable; +rejectMetamaskToSwitchNetwork(): Chainable; ``` #### `cy.allowMetamaskToAddAndSwitchNetwork()` @@ -437,7 +518,7 @@ rejectMetamaskToSwitchNetwork(): Chainable; Allow site to add new network in metamask and switch to it. ```ts -allowMetamaskToAddAndSwitchNetwork(): Chainable; +allowMetamaskToAddAndSwitchNetwork(): Chainable; ``` #### `cy.unlockMetamask()` @@ -445,7 +526,7 @@ allowMetamaskToAddAndSwitchNetwork(): Chainable; Unlock metamask. ```ts -unlockMetamask(password: string): Chainable; +unlockMetamask(password: string): Chainable; ``` #### `cy.fetchMetamaskWalletAddress()` @@ -453,7 +534,7 @@ unlockMetamask(password: string): Chainable; Fetches previous metamask wallet address. ```ts -fetchMetamaskWalletAddress(): Chainable; +fetchMetamaskWalletAddress(): Chainable; ``` #### `cy.setupMetamask()` @@ -463,7 +544,16 @@ Run the flow for metamask setup. ```ts setupMetamask( secretWordsOrPrivateKey?: string, - network?: string | object, + network?: + | string + | { + networkName: string; + rpcUrl: string; + chainId: number; + symbol?: string; + blockExplorer?: string; + isTestnet: boolean; + }, password?: string, enableAdvancedSettings?: boolean, enableExperimentalSettings?: boolean, @@ -483,7 +573,7 @@ etherscanGetTransactionStatus(txid: string): Chainable; Wait until transaction is success using Etherscan API. ```ts -etherscanWaitForTxSuccess(txid: string): Chainable; +etherscanWaitForTxSuccess(txid: string): Chainable; ``` #### `cy.waitForResources()` @@ -514,4 +604,3 @@ isWithinViewport( viewportHeight: number, ): Chainable; ``` - diff --git a/plugins/index.js b/plugins/index.js index 51fe4965b..c41090ed6 100644 --- a/plugins/index.js +++ b/plugins/index.js @@ -103,8 +103,11 @@ module.exports = (on, config) => { rejectMetamaskAddToken: metamask.rejectAddToken, confirmMetamaskPermissionToSpend: metamask.confirmPermissionToSpend, rejectMetamaskPermissionToSpend: metamask.rejectPermissionToSpend, - confirmMetamaskPermisionToApproveAll: metamask.confirmPermisionToApproveAll, - rejectMetamaskPermisionToApproveAll: metamask.rejectPermisionToApproveAll, + confirmMetamaskPermissionToApproveAll: + metamask.confirmPermissionToApproveAll, + rejectMetamaskPermissionToApproveAll: metamask.rejectPermissionToApproveAll, + confirmMetamaskRevokePermissionToAll: metamask.confirmRevokePermissionToAll, + rejectMetamaskRevokePermissionToAll: metamask.rejectRevokePermissionToAll, acceptMetamaskAccess: metamask.acceptAccess, rejectMetamaskAccess: metamask.rejectAccess, confirmMetamaskTransaction: metamask.confirmTransaction, diff --git a/support/commands.js b/support/commands.js index 73869e3fc..282ab8b3e 100644 --- a/support/commands.js +++ b/support/commands.js @@ -215,12 +215,20 @@ Cypress.Commands.add('closeMetamaskTransactionDetailsPopup', () => { return cy.task('closeMetamaskTransactionDetailsPopup'); }); -Cypress.Commands.add('rejectMetamaskPermisionToApproveAll', () => { - return cy.task('rejectMetamaskPermisionToApproveAll'); +Cypress.Commands.add('rejectMetamaskPermissionToApproveAll', () => { + return cy.task('rejectMetamaskPermissionToApproveAll'); }); -Cypress.Commands.add('confirmMetamaskPermisionToApproveAll', () => { - return cy.task('confirmMetamaskPermisionToApproveAll'); +Cypress.Commands.add('confirmMetamaskPermissionToApproveAll', () => { + return cy.task('confirmMetamaskPermissionToApproveAll'); +}); + +Cypress.Commands.add('confirmMetamaskRevokePermissionToAll', () => { + return cy.task('confirmMetamaskRevokePermissionToAll'); +}); + +Cypress.Commands.add('rejectMetamaskRevokePermissionToAll', () => { + return cy.task('rejectMetamaskRevokePermissionToAll'); }); Cypress.Commands.add('allowMetamaskToAddNetwork', waitForEvent => { diff --git a/support/index.d.ts b/support/index.d.ts index 804e32d54..fb5bbb3e1 100644 --- a/support/index.d.ts +++ b/support/index.d.ts @@ -278,15 +278,27 @@ declare namespace Cypress { /** * Confirm metamask permission to access all elements (example: collectibles) * @example - * cy.confirmMetamaskPermisionToApproveAll() + * cy.confirmMetamaskPermissionToApproveAll() */ - confirmMetamaskPermisionToApproveAll(): Chainable; + confirmMetamaskPermissionToApproveAll(): Chainable; /** * Reject metamask permission to access all elements (example: collectibles) * @example - * cy.rejectMetamaskPermisionToApproveAll() + * cy.rejectMetamaskPermissionToApproveAll() */ - rejectMetamaskPermisionToApproveAll(): Chainable; + rejectMetamaskPermissionToApproveAll(): Chainable; + /** + * Confirm metamask revoking permission to access all elements (example: collectibles) + * @example + * cy.confirmMetamaskRevokePermissionToAll() + */ + confirmMetamaskRevokePermissionToAll(): Chainable; + /** + * Reject metamask revoking permission to access all elements (example: collectibles) + * @example + * cy.rejectMetamaskRevokePermissionToAll() + */ + rejectMetamaskRevokePermissionToAll(): Chainable; /** * Reject metamask permission to spend asset * @example @@ -345,14 +357,14 @@ declare namespace Cypress { confirmMetamaskTransactionAndWaitForMining( gasConfig?: | { - gasLimit?: number; - baseFee?: number; - priorityFee?: number; - } + gasLimit?: number; + baseFee?: number; + priorityFee?: number; + } | { - gasLimit?: number; - gasPrice?: number; - } + gasLimit?: number; + gasPrice?: number; + } | 'low' | 'market' | 'aggressive' diff --git a/tests/e2e/specs/metamask-spec.js b/tests/e2e/specs/metamask-spec.js index 3b00ae2a2..4cbdcf635 100644 --- a/tests/e2e/specs/metamask-spec.js +++ b/tests/e2e/specs/metamask-spec.js @@ -128,19 +128,31 @@ describe('Metamask', () => { cy.changeMetamaskNetwork('sepolia'); } }); - it(`rejectMetamaskPermisionToApproveAll should reject permission to approve all NFTs upon warning`, () => { + it(`rejectMetamaskPermissionToApproveAll should reject permission to approve all NFTs upon warning`, () => { cy.get('#deployNFTsButton').click(); cy.confirmMetamaskTransaction(); cy.get('#mintButton').click(); cy.confirmMetamaskTransaction(); cy.get('#setApprovalForAllButton').click(); - cy.rejectMetamaskPermisionToApproveAll().then(rejected => { + cy.rejectMetamaskPermissionToApproveAll().then(rejected => { expect(rejected).to.be.true; }); }); - it(`confirmMetamaskPermisionToApproveAll should confirm permission to approve all NFTs`, () => { + it(`confirmMetamaskPermissionToApproveAll should confirm permission to approve all NFTs`, () => { cy.get('#setApprovalForAllButton').click(); - cy.confirmMetamaskPermisionToApproveAll().then(confirmed => { + cy.confirmMetamaskPermissionToApproveAll().then(confirmed => { + expect(confirmed).to.be.true; + }); + }); + it(`rejectMetamaskRevokePermissionToAll should reject revoking permission to all NFTs`, () => { + cy.get('#revokeButton').click(); + cy.rejectMetamaskRevokePermissionToAll().then(confirmed => { + expect(confirmed).to.be.true; + }); + }); + it(`confirmMetamaskRevokePermissionToAll should confirm revoking permission to all NFTs`, () => { + cy.get('#revokeButton').click(); + cy.confirmMetamaskRevokePermissionToAll().then(confirmed => { expect(confirmed).to.be.true; }); }); From 26422ce0184ded9a77d974dbb0d19878f874adf7 Mon Sep 17 00:00:00 2001 From: Daniel Izdebski Date: Fri, 3 Nov 2023 18:10:37 +0100 Subject: [PATCH 08/35] Add `switchNetwork` option to `acceptAccess` function --- commands/metamask.js | 14 ++++++++++++++ docs/synpress-commands.md | 1 + support/index.d.ts | 1 + 3 files changed, 16 insertions(+) diff --git a/commands/metamask.js b/commands/metamask.js index 5e6e726e7..fdad8daad 100644 --- a/commands/metamask.js +++ b/commands/metamask.js @@ -933,6 +933,20 @@ const metamask = { return true; } + if (options && options.switchNetwork) { + await playwright.waitAndClick( + permissionsPageElements.connectButton, + notificationPage, + { waitForEvent: 'navi' }, + ); + await playwright.waitAndClick( + confirmationPageElements.footer.approveButton, + notificationPage, + { waitForEvent: 'close' }, + ); + return true; + } + await playwright.waitAndClick( permissionsPageElements.connectButton, notificationPage, diff --git a/docs/synpress-commands.md b/docs/synpress-commands.md index 8a5564c95..2ae6bee81 100644 --- a/docs/synpress-commands.md +++ b/docs/synpress-commands.md @@ -398,6 +398,7 @@ acceptMetamaskAccess(options?: { allAccounts?: boolean; confirmSignatureRequest?: boolean; confirmDataSignatureRequest?: boolean; + switchNetwork?: boolean; }): Chainable; ``` diff --git a/support/index.d.ts b/support/index.d.ts index fb5bbb3e1..68d42b311 100644 --- a/support/index.d.ts +++ b/support/index.d.ts @@ -315,6 +315,7 @@ declare namespace Cypress { allAccounts?: boolean; confirmSignatureRequest?: boolean; confirmDataSignatureRequest?: boolean; + switchNetwork?: boolean; }): Chainable; /** * Reject metamask access request From 00abaad81fce67ac31fbdd61f2408c8a7d313176 Mon Sep 17 00:00:00 2001 From: Daniel Izdebski Date: Fri, 17 Nov 2023 00:43:13 +0100 Subject: [PATCH 09/35] Add new release section to README --- README.md | 15 +++++++++++++++ 1 file changed, 15 insertions(+) diff --git a/README.md b/README.md index e967ec303..832a9bab3 100644 --- a/README.md +++ b/README.md @@ -62,6 +62,21 @@ it directly. Check [usage examples](https://github.com/Synthetixio/synpress/#usage-examples) for more details. +# โ™จ๏ธ New release + +โš ๏ธ This branch showcases the current stable release of Synpress which will receive **only** critical hotfixes. โš ๏ธ + +Active development of the upcoming version of Synpress is happening on [this branch](https://github.com/Synthetixio/synpress/tree/new-dawn). +The new release is a full rewrite of Synpress and will feature major breaking changes, and multitude of new features and improvements across the board such as: +- โญ Full TypeScript support +- โญ Multi-wallet support +- โญ Full parallelism support +- โญ Test runtime speed **faster** than any other Web3 alternative, and **equal** to native Web2 frameworks + +Curious and want to learn more? ๐Ÿค“ + +[Read this Twitter thread ๐Ÿงต](https://twitter.com/0xDuckception/status/1712961542176596054) and do not forget to check out the attached document there! + # Table of content - [](#) From 407d2409ebd76d2d61befc695484b8c0a3f2914d Mon Sep 17 00:00:00 2001 From: Daniel Izdebski Date: Thu, 25 Jan 2024 13:45:21 +0100 Subject: [PATCH 10/35] Use `goerli` for testing (#1082) * Use `goerli` for testing * Trigger tests --- tests/e2e/specs/metamask-spec.js | 46 ++++++++++++++++---------------- 1 file changed, 23 insertions(+), 23 deletions(-) diff --git a/tests/e2e/specs/metamask-spec.js b/tests/e2e/specs/metamask-spec.js index 4cbdcf635..07c3cd0b6 100644 --- a/tests/e2e/specs/metamask-spec.js +++ b/tests/e2e/specs/metamask-spec.js @@ -5,7 +5,7 @@ describe('Metamask', () => { it(`setupMetamask should finish metamask setup using secret words`, () => { cy.setupMetamask( 'test test test test test test test test test test test junk', - 'sepolia', + 'goerli', 'Tester@1234', ).then(setupFinished => { expect(setupFinished).to.be.true; @@ -33,8 +33,8 @@ describe('Metamask', () => { cy.acceptMetamaskAccess().then(connected => { expect(connected).to.be.true; }); - cy.get('#network').contains('11155111'); - cy.get('#chainId').contains('0xaa36a7'); + cy.get('#network').contains('5'); + cy.get('#chainId').contains('0x5'); cy.get('#accounts').should( 'have.text', '0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266', @@ -49,8 +49,8 @@ describe('Metamask', () => { }); it(`getCurrentNetwork should return network by default`, () => { cy.getCurrentNetwork().then(network => { - expect(network.name).to.match(/sepolia/i); - expect(network.id).to.be.equal(11155111); + expect(network.name).to.match(/goerli/i); + expect(network.id).to.be.equal(5); expect(network.testnet).to.be.true; }); }); @@ -59,12 +59,12 @@ describe('Metamask', () => { cy.addMetamaskNetwork({ networkName: 'anvil', rpcUrl: 'http://127.0.0.1:8545', - chainId: 11155111, + chainId: 5, symbol: 'aETH', isTestnet: true, }); - cy.get('#network').contains('11155111'); - cy.get('#chainId').contains('0xaa36a7'); + cy.get('#network').contains('5'); + cy.get('#chainId').contains('0x5'); } else { cy.addMetamaskNetwork({ networkName: 'Optimism Network', @@ -84,7 +84,7 @@ describe('Metamask', () => { cy.getCurrentNetwork().then(network => { if (Cypress.env('USE_ANVIL')) { expect(network.name).to.be.equal('anvil'); - expect(network.id).to.be.equal(11155111); + expect(network.id).to.be.equal(5); expect(network.testnet).to.be.true; } else { expect(network.name).to.match(/optimism network/i); @@ -117,15 +117,15 @@ describe('Metamask', () => { cy.changeMetamaskNetwork('anvil').then(networkChanged => { expect(networkChanged).to.be.true; }); - cy.get('#network').contains('0xaa36a7'); - cy.get('#chainId').contains('0xaa36a7'); + cy.get('#network').contains('0x5'); + cy.get('#chainId').contains('0x5'); } else { cy.changeMetamaskNetwork('optimism network').then(networkChanged => { expect(networkChanged).to.be.true; }); cy.get('#network').contains('0xa'); cy.get('#chainId').contains('0xa'); - cy.changeMetamaskNetwork('sepolia'); + cy.changeMetamaskNetwork('goerli'); } }); it(`rejectMetamaskPermissionToApproveAll should reject permission to approve all NFTs upon warning`, () => { @@ -488,28 +488,28 @@ describe('Metamask', () => { }); }); it(`importMetamaskToken should import token to metamask`, () => { - const USDCContractAddressOnSepolia = - '0xda9d4f9b69ac6C22e444eD9aF0CfC043b7a7f53f'; - cy.importMetamaskToken(USDCContractAddressOnSepolia).then(tokenData => { + const tetherContractAddressOnGoerli = + '0x509Ee0d083DdF8AC028f2a56731412edD63223B9'; + cy.importMetamaskToken(tetherContractAddressOnGoerli).then(tokenData => { expect(tokenData.tokenContractAddress).to.be.equal( - USDCContractAddressOnSepolia, + tetherContractAddressOnGoerli, ); - expect(tokenData.tokenSymbol).to.be.equal('USDC'); + expect(tokenData.tokenSymbol).to.be.equal('USDT'); expect(tokenData.tokenDecimals).to.be.equal('6'); expect(tokenData.imported).to.be.true; }); }); it(`importMetamaskToken should import token to metamask using advanced token settings`, () => { - const tDAIContractAddressOnSepolia = - '0x53844F9577C2334e541Aec7Df7174ECe5dF1fCf0'; + const daiContractAddressOnGoerli = + '0x5233d9FeA273A88c3c8672910042E63850ddF9aa'; cy.importMetamaskToken({ - address: tDAIContractAddressOnSepolia, - symbol: 'IADt', + address: daiContractAddressOnGoerli, + symbol: 'xDAI', }).then(tokenData => { expect(tokenData.tokenContractAddress).to.be.equal( - tDAIContractAddressOnSepolia, + daiContractAddressOnGoerli, ); - expect(tokenData.tokenSymbol).to.be.equal('IADt'); + expect(tokenData.tokenSymbol).to.be.equal('xDAI'); expect(tokenData.tokenDecimals).to.be.equal('18'); expect(tokenData.imported).to.be.true; }); From 20c8a695d3a13cfbf826bd2db9ff08c9f515ed5f Mon Sep 17 00:00:00 2001 From: Daniel Izdebski Date: Thu, 25 Jan 2024 14:24:41 +0100 Subject: [PATCH 11/35] Add `shouldWaitForPopupClosure` option to approvals and txs (#1081) --- commands/metamask.js | 14 ++++++--- docs/synpress-commands.md | 26 ++++++++------- support/commands.js | 22 ++++++++++--- support/index.d.ts | 36 ++++++++++++--------- tests/e2e/specs/metamask-spec.js | 54 ++++++++++++++++++++++++++------ 5 files changed, 108 insertions(+), 44 deletions(-) diff --git a/commands/metamask.js b/commands/metamask.js index fdad8daad..6f24d067f 100644 --- a/commands/metamask.js +++ b/commands/metamask.js @@ -852,7 +852,10 @@ const metamask = { ); return true; }, - async confirmPermissionToSpend(spendLimit) { + async confirmPermissionToSpend({ + spendLimit, + shouldWaitForPopupClosure = false, + } = {}) { const notificationPage = await playwright.switchToMetamaskNotification(); // experimental mode on if ( @@ -874,7 +877,7 @@ const metamask = { await playwright.waitAndClick( notificationPageElements.allowToSpendButton, notificationPage, - { waitForEvent: 'close' }, + shouldWaitForPopupClosure ? undefined : { waitForEvent: 'close' }, ); return true; }, @@ -963,7 +966,10 @@ const metamask = { ); return true; }, - async confirmTransaction(gasConfig) { + async confirmTransaction({ + gasConfig, + shouldWaitForPopupClosure = false, + } = {}) { let txData = {}; const notificationPage = await playwright.switchToMetamaskNotification(); if (gasConfig) { @@ -1189,7 +1195,7 @@ const metamask = { await playwright.waitAndClick( confirmPageElements.confirmButton, notificationPage, - { waitForEvent: 'close' }, + shouldWaitForPopupClosure ? undefined : { waitForEvent: 'close' }, ); txData.confirmed = true; log('[confirmTransaction] Transaction confirmed!'); diff --git a/docs/synpress-commands.md b/docs/synpress-commands.md index 2ae6bee81..4fe192a18 100644 --- a/docs/synpress-commands.md +++ b/docs/synpress-commands.md @@ -344,7 +344,10 @@ rejectMetamaskAddToken(): Chainable; Confirm metamask permission to spend asset. ```ts -confirmMetamaskPermissionToSpend(spendLimit?: string): Chainable; +confirmMetamaskPermissionToSpend(options: { + spendLimit?: string + shouldWaitForPopupClosure?: boolean +}): Chainable; ``` #### `cy.confirmMetamaskPermissionToApproveAll()` @@ -415,22 +418,23 @@ rejectMetamaskAccess(): Chainable; Confirm metamask transaction (auto-detects eip-1559 and legacy transactions). ```ts -confirmMetamaskTransaction( - gasConfig?: +confirmMetamaskTransaction(options: { + gasConfig: | { - gasLimit?: number; - baseFee?: number; - priorityFee?: number; + gasLimit?: number; + baseFee?: number; + priorityFee?: number; } | { - gasLimit?: number; - gasPrice?: number; - } + gasLimit?: number; + gasPrice?: number; + } | 'low' | 'market' | 'aggressive' - | 'site', -): Chainable; + | 'site', + shouldWaitForPopupClosure?: boolean +}): Chainable; ``` #### `cy.confirmMetamaskTransactionAndWaitForMining()` diff --git a/support/commands.js b/support/commands.js index 282ab8b3e..664571457 100644 --- a/support/commands.js +++ b/support/commands.js @@ -175,8 +175,14 @@ Cypress.Commands.add('rejectMetamaskAddToken', () => { Cypress.Commands.add( 'confirmMetamaskPermissionToSpend', - (spendLimit = '999999999999999999') => { - return cy.task('confirmMetamaskPermissionToSpend', spendLimit); + ({ + spendLimit = '999999999999999999', + shouldWaitForPopupClosure = false, + } = {}) => { + return cy.task('confirmMetamaskPermissionToSpend', { + spendLimit, + shouldWaitForPopupClosure, + }); }, ); @@ -192,9 +198,15 @@ Cypress.Commands.add('rejectMetamaskAccess', () => { return cy.task('rejectMetamaskAccess'); }); -Cypress.Commands.add('confirmMetamaskTransaction', gasConfig => { - return cy.task('confirmMetamaskTransaction', gasConfig); -}); +Cypress.Commands.add( + 'confirmMetamaskTransaction', + ({ gasConfig, shouldWaitForPopupClosure = false } = {}) => { + return cy.task('confirmMetamaskTransaction', { + gasConfig, + shouldWaitForPopupClosure, + }); + }, +); Cypress.Commands.add( 'confirmMetamaskTransactionAndWaitForMining', diff --git a/support/index.d.ts b/support/index.d.ts index 68d42b311..820a9dcae 100644 --- a/support/index.d.ts +++ b/support/index.d.ts @@ -272,9 +272,13 @@ declare namespace Cypress { * Confirm metamask permission to spend asset * @example * cy.confirmMetamaskPermissionToSpend() - * cy.confirmMetamaskPermissionToSpend('999999999') + * cy.confirmMetamaskPermissionToSpend({ spendLimit: '999999999' }) + * cy.confirmMetamaskPermissionToSpend({ spendLimit: '999999999', shouldWaitForPopupClosure: false }) */ - confirmMetamaskPermissionToSpend(spendLimit?: string): Chainable; + confirmMetamaskPermissionToSpend(options: { + spendLimit?: string + shouldWaitForPopupClosure?: boolean + }): Chainable; /** * Confirm metamask permission to access all elements (example: collectibles) * @example @@ -327,26 +331,28 @@ declare namespace Cypress { * Confirm metamask transaction (auto-detects eip-1559 and legacy transactions) * @example * cy.confirmMetamaskTransaction() - * cy.confirmMetamaskTransaction({ gasLimit: 1000000, baseFee: 20, priorityFee: 20 }) // eip-1559 - * cy.confirmMetamaskTransaction({ gasLimit: 1000000, gasPrice: 20 }) // legacy - * cy.confirmMetamaskTransaction('aggressive') // eip-1559 only! => available options: 'low', 'market', 'aggressive', 'site' (site is usually by default) + * cy.confirmMetamaskTransaction({ gasConfig: { gasLimit: 1000000, baseFee: 20, priorityFee: 20 } }) // eip-1559 + * cy.confirmMetamaskTransaction({ gasConfig: { gasLimit: 1000000, gasPrice: 20 } }) // legacy + * cy.confirmMetamaskTransaction({ gasConfig: 'aggressive' }) // eip-1559 only! => available options: 'low', 'market', 'aggressive', 'site' (site is usually by default) + * cy.confirmMetamaskTransaction({ shouldWaitForPopupClosure: false }) */ - confirmMetamaskTransaction( - gasConfig?: + confirmMetamaskTransaction(options: { + gasConfig: | { - gasLimit?: number; - baseFee?: number; - priorityFee?: number; - } + gasLimit?: number; + baseFee?: number; + priorityFee?: number; + } | { - gasLimit?: number; - gasPrice?: number; - } + gasLimit?: number; + gasPrice?: number; + } | 'low' | 'market' | 'aggressive' | 'site', - ): Chainable; + shouldWaitForPopupClosure?: boolean + }): Chainable; /** * Confirm metamask transaction (auto-detects eip-1559 and legacy transactions) and wait for ALL pending transactions to be mined * @example diff --git a/tests/e2e/specs/metamask-spec.js b/tests/e2e/specs/metamask-spec.js index 07c3cd0b6..aa45e0f3f 100644 --- a/tests/e2e/specs/metamask-spec.js +++ b/tests/e2e/specs/metamask-spec.js @@ -347,12 +347,26 @@ describe('Metamask', () => { it(`confirmMetamaskTransaction should confirm legacy transaction using advanced gas settings`, () => { cy.get('#sendButton').click(); cy.confirmMetamaskTransaction({ - gasLimit: 210000, - gasPrice: 100, + gasConfig: { + gasLimit: 210000, + gasPrice: 100, + }, }).then(txData => { expect(txData.confirmed).to.be.true; }); }); + it(`confirmMetamaskTransaction should work for serial transactions`, () => { + cy.get('#sendEIP1559Button').click(); + cy.get('#sendEIP1559Button').click(); + cy.confirmMetamaskTransaction({ + shouldWaitForPopupClosure: true, + }).then(txData => { + expect(txData.confirmed).to.be.true; + }); + cy.confirmMetamaskTransaction().then(txData => { + expect(txData.confirmed).to.be.true; + }); + }); it(`confirmMetamaskTransaction should confirm legacy ETH transfer to yourself`, () => { cy.get('#fromInput').type('0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266'); cy.get('#toInput').type('0xf39fd6e51aad88f6f4ce6ab8827279cfffb92266'); @@ -373,28 +387,38 @@ describe('Metamask', () => { }); it(`confirmMetamaskTransaction should confirm eip-1559 transaction using pre-defined (low, market, aggressive, site) gas settings`, () => { cy.get('#sendEIP1559Button').click(); - cy.confirmMetamaskTransaction('low').then(txData => { + cy.confirmMetamaskTransaction({ + gasConfig: 'low', + }).then(txData => { expect(txData.confirmed).to.be.true; }); cy.get('#sendEIP1559Button').click(); - cy.confirmMetamaskTransaction('market').then(txData => { + cy.confirmMetamaskTransaction({ + gasConfig: 'market', + }).then(txData => { expect(txData.confirmed).to.be.true; }); cy.get('#sendEIP1559Button').click(); - cy.confirmMetamaskTransaction('aggressive').then(txData => { + cy.confirmMetamaskTransaction({ + gasConfig: 'aggressive', + }).then(txData => { expect(txData.confirmed).to.be.true; }); cy.get('#sendEIP1559Button').click(); - cy.confirmMetamaskTransaction('site').then(txData => { + cy.confirmMetamaskTransaction({ + gasConfig: 'site', + }).then(txData => { expect(txData.confirmed).to.be.true; }); }); it(`confirmMetamaskTransaction should confirm eip-1559 transaction using advanced gas settings`, () => { cy.get('#sendEIP1559Button').click(); cy.confirmMetamaskTransaction({ - gasLimit: 210000, - baseFee: 100, - priorityFee: 10, + gasConfig: { + gasLimit: 210000, + baseFee: 100, + priorityFee: 10, + }, }).then(txData => { expect(txData.confirmed).to.be.true; }); @@ -526,6 +550,18 @@ describe('Metamask', () => { expect(approved).to.be.true; }); }); + it(`confirmMetamaskPermissionToSpend should work for serial transactions`, () => { + cy.get('#approveTokens').click(); + cy.get('#approveTokens').click(); + cy.confirmMetamaskPermissionToSpend({ + shouldWaitForPopupClosure: true, + }).then(approved => { + expect(approved).to.be.true; + }); + cy.confirmMetamaskPermissionToSpend().then(approved => { + expect(approved).to.be.true; + }); + }); it(`rejectMetamaskToAddNetwork should reject permission to add network`, () => { cy.get('#addEthereumChain').click(); cy.rejectMetamaskToAddNetwork().then(rejected => { From 83c76299e207cd6ec4b1b64c8194ae8d898998b2 Mon Sep 17 00:00:00 2001 From: rabi-siddique Date: Wed, 28 Feb 2024 10:12:09 +0500 Subject: [PATCH 12/35] feature: intial setup for integration of keplr --- commands/keplr.js | 146 +++++++ commands/metamask.js | 2 +- commands/playwright-keplr.js | 378 ++++++++++++++++++ .../{playwright.js => playwright-metamask.js} | 0 helpers.js | 71 +++- package.json | 8 +- pages/keplr/first-time-flow-page.js | 34 ++ pages/keplr/notification-page.js | 5 + plugins/index.js | 204 +--------- plugins/keplr-plugin.js | 86 ++++ plugins/metamask-plugin.js | 197 +++++++++ support/commands.js | 30 ++ support/index.js | 2 +- synpress.config.js | 8 +- synpress.js | 14 +- tests/e2e/specs/keplr/keplr-spec.js | 30 ++ tests/e2e/specs/keplr/playwright-spec.js | 32 ++ .../e2e/specs/{ => metamask}/metamask-spec.js | 0 .../specs/{ => metamask}/playwright-spec.js | 0 19 files changed, 1033 insertions(+), 214 deletions(-) create mode 100644 commands/keplr.js create mode 100644 commands/playwright-keplr.js rename commands/{playwright.js => playwright-metamask.js} (100%) create mode 100644 pages/keplr/first-time-flow-page.js create mode 100644 pages/keplr/notification-page.js create mode 100644 plugins/keplr-plugin.js create mode 100644 plugins/metamask-plugin.js create mode 100644 tests/e2e/specs/keplr/keplr-spec.js create mode 100644 tests/e2e/specs/keplr/playwright-spec.js rename tests/e2e/specs/{ => metamask}/metamask-spec.js (100%) rename tests/e2e/specs/{ => metamask}/playwright-spec.js (100%) diff --git a/commands/keplr.js b/commands/keplr.js new file mode 100644 index 000000000..1f7dca9a8 --- /dev/null +++ b/commands/keplr.js @@ -0,0 +1,146 @@ +const log = require('debug')('synpress:keplr'); +const playwright = require('./playwright-keplr'); +const { onboardingElements } = require('../pages/keplr/first-time-flow-page'); +const { + notificationPageElements, +} = require('../pages/keplr/notification-page'); + +let extensionId; +let extensionVersion; + +const keplr = { + async resetState() { + log('Resetting state of keplr'); + extensionId = undefined; + extensionVersion = undefined; + }, + extensionId: () => { + return extensionId; + }, + extensionUrls: () => { + return { + extensionImportAccountUrl, + }; + }, + + async getExtensionDetails() { + const keplrExtensionData = (await playwright.getExtensionsData()).keplr; + + extensionId = keplrExtensionData.id; + extensionVersion = keplrExtensionData.version; + + return { + extensionId, + extensionVersion, + }; + }, + + async importWallet(secretWords, password) { + await playwright.waitAndClickByText( + onboardingElements.createWalletButton, + await playwright.keplrWindow(), + ); + await playwright.waitAndClickByText( + onboardingElements.importRecoveryPhraseButton, + await playwright.keplrWindow(), + ); + await playwright.waitAndClickByText( + onboardingElements.useRecoveryPhraseButton, + await playwright.keplrWindow(), + ); + await playwright.waitAndClickByText( + onboardingElements.phraseCount24, + await playwright.keplrWindow(), + ); + + for (const [index, word] of secretWords.split(' ').entries()) { + await playwright.waitAndTypeByLocator( + onboardingElements.textAreaSelector, + word, + index, + ); + } + + await playwright.waitAndClick( + onboardingElements.submitPhraseButton, + await playwright.keplrWindow(), + ); + + await playwright.waitAndType( + onboardingElements.walletInput, + onboardingElements.walletName, + ); + await playwright.waitAndType(onboardingElements.passwordInput, password); + await playwright.waitAndType( + onboardingElements.confirmPasswordInput, + password, + ); + + await playwright.waitAndClick( + onboardingElements.submitWalletDataButton, + await playwright.keplrWindow(), + { number: 1 }, + ); + + await playwright.waitForByText( + onboardingElements.phraseSelectChain, + await playwright.keplrWindow(), + ); + + await playwright.waitAndClick( + onboardingElements.submitChainButton, + await playwright.keplrWindow(), + ); + + await playwright.waitForByText( + onboardingElements.phraseAccountCreated, + await playwright.keplrWindow(), + ); + + await playwright.waitAndClick( + onboardingElements.finishButton, + await playwright.keplrWindow(), + { dontWait: true }, + ); + + return true; + }, + + async acceptAccess() { + const notificationPage = await playwright.switchToKeplrNotification(); + await playwright.waitAndClick( + notificationPageElements.approveButton, + notificationPage, + { waitForEvent: 'close' }, + ); + return true; + }, + + async confirmTransaction() { + const notificationPage = await playwright.switchToKeplrNotification(); + await playwright.waitAndClick( + notificationPageElements.approveButton, + notificationPage, + { waitForEvent: 'close' }, + ); + return true; + }, + + async initialSetup( + playwrightInstance, + { secretWordsOrPrivateKey, password }, + ) { + if (playwrightInstance) { + await playwright.init(playwrightInstance); + } else { + await playwright.init(); + } + + await playwright.assignWindows(); + await playwright.assignActiveTabName('keplr'); + await module.exports.getExtensionDetails(); + await module.exports.importWallet(secretWordsOrPrivateKey, password); + }, +}; + +module.exports = keplr; \ No newline at end of file diff --git a/commands/metamask.js b/commands/metamask.js index 6f24d067f..c7b34357a 100644 --- a/commands/metamask.js +++ b/commands/metamask.js @@ -1,5 +1,5 @@ const log = require('debug')('synpress:metamask'); -const playwright = require('./playwright'); +const playwright = require('./playwright-metamask'); const sleep = require('util').promisify(setTimeout); const { diff --git a/commands/playwright-keplr.js b/commands/playwright-keplr.js new file mode 100644 index 000000000..c7fc975c6 --- /dev/null +++ b/commands/playwright-keplr.js @@ -0,0 +1,378 @@ +const log = require('debug')('synpress:playwright'); +const fetch = require('node-fetch'); +const _ = require('underscore'); +const sleep = require('util').promisify(setTimeout); + +let browser; +let mainWindow; +let keplrWindow; +let keplrNotificationWindow; +let activeTabName; +let extensionsData = {}; +let retries = 0; + +module.exports = { + async resetState() { + log('Resetting state of playwright'); + browser = undefined; + mainWindow = undefined; + keplrWindow = undefined; + activeTabName = undefined; + keplrNotificationWindow = undefined; + retries = 0; + extensionsData = {}; + }, + + async init(playwrightInstance) { + const chromium = playwrightInstance + ? playwrightInstance + : require('@playwright/test').chromium; + const debuggerDetails = await fetch('http://127.0.0.1:9222/json/version'); //DevSkim: ignore DS137138 + const debuggerDetailsConfig = await debuggerDetails.json(); + const webSocketDebuggerUrl = debuggerDetailsConfig.webSocketDebuggerUrl; + if (process.env.SLOW_MODE) { + if (!isNaN(process.env.SLOW_MODE)) { + browser = await chromium.connectOverCDP(webSocketDebuggerUrl, { + slowMo: Number(process.env.SLOW_MODE), + }); + } else { + browser = await chromium.connectOverCDP(webSocketDebuggerUrl, { + slowMo: 50, + }); + } + } else { + browser = await chromium.connectOverCDP(webSocketDebuggerUrl); + } + return browser.isConnected(); + }, + + async assignWindows() { + const keplrExtensionData = (await module.exports.getExtensionsData()).keplr; + + let pages = await browser.contexts()[0].pages(); + + for (const page of pages) { + if (page.url().includes('specs/runner')) { + mainWindow = page; + } else if ( + page + .url() + .includes(`chrome-extension://${keplrExtensionData.id}/register.html`) + ) { + keplrWindow = page; + } + } + return true; + }, + async assignActiveTabName(tabName) { + activeTabName = tabName; + return true; + }, + + async isKeplrWindowActive() { + return activeTabName === 'keplr'; + }, + + keplrNotificationWindow() { + return keplrNotificationWindow; + }, + + async waitAndClickByText(text, page = keplrWindow) { + await module.exports.waitForByText(text, page); + const element = `:is(:text-is("${text}"), :text("${text}"))`; + await page.click(element); + await module.exports.waitUntilStable(); + }, + + async waitAndSetValue(text, selector, page = keplrWindow) { + const element = await module.exports.waitFor(selector, page); + await element.fill(''); + await module.exports.waitUntilStable(page); + await element.fill(text); + await module.exports.waitUntilStable(page); + }, + + async waitAndGetValue(selector, page = keplrWindow) { + const expect = expectInstance + ? expectInstance + : require('@playwright/test').expect; + const element = await module.exports.waitFor(selector, page); + await expect(element).toHaveText(/[a-zA-Z0-9]/, { + ignoreCase: true, + useInnerText: true, + }); + const value = await element.innerText(); + return value; + }, + + async waitAndClick(selector, page = keplrWindow, args = {}) { + const element = await module.exports.waitFor( + selector, + page, + args.number || 0, + ); + if (args.numberOfClicks && !args.waitForEvent) { + await element.click({ + clickCount: args.numberOfClicks, + force: args.force, + }); + } else if (args.numberOfClicks && args.waitForEvent) { + await Promise.all([ + page.waitForEvent(args.waitForEvent), + element.click({ clickCount: args.numberOfClicks, force: args.force }), + ]); + } else if (args.waitForEvent) { + if (args.waitForEvent.includes('navi')) { + await Promise.all([ + page.waitForNavigation(), + element.click({ force: args.force }), + ]); + } else { + await Promise.all([ + page.waitForEvent(args.waitForEvent), + element.click({ force: args.force }), + ]); + } + } else { + await element.click({ force: args.force }); + } + await module.exports.waitUntilStable(); + return element; + }, + + async switchToCypressWindow() { + if (mainWindow) { + await mainWindow.bringToFront(); + await module.exports.assignActiveTabName('cypress'); + } + return true; + }, + + async clear() { + browser = null; + return true; + }, + + async clearWindows() { + mainWindow = null; + keplrWindow = null; + return true; + }, + + async isCypressWindowActive() { + return activeTabName === 'cypress'; + }, + + async switchToKeplrWindow() { + await keplrWindow.bringToFront(); + await module.exports.assignActiveTabName('keplr'); + return true; + }, + + async waitUntilStable(page) { + const keplrExtensionData = (await module.exports.getExtensionsData()) + .keplr; + + if ( + page && + page + .url() + .includes( + `chrome-extension://${keplrExtensionData.id}/register.html`, + ) + ) { + await page.waitForLoadState('load'); + await page.waitForLoadState('domcontentloaded'); + await page.waitForLoadState('networkidle'); + } + await keplrWindow.waitForLoadState('load'); + await keplrWindow.waitForLoadState('domcontentloaded'); + await keplrWindow.waitForLoadState('networkidle'); + + if (mainWindow) { + await mainWindow.waitForLoadState('load'); + await mainWindow.waitForLoadState('domcontentloaded'); + // todo: this may slow down tests and not be necessary but could improve stability + // await mainWindow.waitForLoadState('networkidle'); + } + }, + + keplrWindow() { + return keplrWindow; + }, + + async waitFor(selector, page = keplrWindow, number = 0) { + await module.exports.waitUntilStable(page); + await page.waitForSelector(selector, { strict: false }); + const element = page.locator(selector).nth(number); + await element.waitFor(); + await element.focus(); + if (process.env.STABLE_MODE) { + if (!isNaN(process.env.STABLE_MODE)) { + await page.waitForTimeout(Number(process.env.STABLE_MODE)); + } else { + await page.waitForTimeout(300); + } + } + return element; + }, + async waitForByText(text, page = keplrWindow) { + await module.exports.waitUntilStable(page); + // await page.waitForSelector(selector, { strict: false }); + const element = page.getByText(text).first(); + await element.waitFor(); + await element.focus(); + if (process.env.STABLE_MODE) { + if (!isNaN(process.env.STABLE_MODE)) { + await page.waitForTimeout(Number(process.env.STABLE_MODE)); + } else { + await page.waitForTimeout(300); + } + } + return element; + }, + + async waitAndClick(selector, page = keplrWindow, args = {}) { + const element = await module.exports.waitFor( + selector, + page, + args.number || 0, + ); + if (args.numberOfClicks && !args.waitForEvent) { + await element.click({ + clickCount: args.numberOfClicks, + force: args.force, + }); + } else if (args.numberOfClicks && args.waitForEvent) { + await Promise.all([ + page.waitForEvent(args.waitForEvent), + element.click({ clickCount: args.numberOfClicks, force: args.force }), + ]); + } else if (args.waitForEvent) { + if (args.waitForEvent.includes('navi')) { + await Promise.all([ + page.waitForNavigation(), + element.click({ force: args.force }), + ]); + } else { + await Promise.all([ + page.waitForEvent(args.waitForEvent), + element.click({ force: args.force }), + ]); + } + } else { + await element.click({ force: args.force }); + } + await module.exports.waitUntilStable(); + return element; + }, + + async waitForByRole(role, number = 0, page = keplrWindow) { + await module.exports.waitUntilStable(page); + const element = page.getByRole(role).nth(number); + await element.waitFor(); + await element.focus(); + if (process.env.STABLE_MODE) { + if (!isNaN(process.env.STABLE_MODE)) { + await page.waitForTimeout(Number(process.env.STABLE_MODE)); + } else { + await page.waitForTimeout(300); + } + } + return element; + }, + + async waitAndType(selector, value, page = keplrWindow) { + if (typeof value === 'number') { + value = value.toString(); + } + const element = await module.exports.waitFor(selector, page); + await element.type(value); + await module.exports.waitUntilStable(page); + }, + + async waitAndTypeByLocator(selector, value, number = 0, page = keplrWindow) { + if (typeof value === 'number') { + value = value.toString(); + } + const element = await module.exports.waitForByRole(selector, number, page); + await element.type(value); + await module.exports.waitUntilStable(page); + }, + + async getExtensionsData() { + if (!_.isEmpty(extensionsData)) { + return extensionsData; + } + + const context = await browser.contexts()[0]; + const page = await context.newPage(); + + await page.goto('chrome://extensions'); + await page.waitForLoadState('load'); + await page.waitForLoadState('domcontentloaded'); + + const devModeButton = page.locator('#devMode'); + await devModeButton.waitFor(); + await devModeButton.focus(); + await devModeButton.click(); + + const extensionDataItems = await page.locator('extensions-item').all(); + for (const extensionData of extensionDataItems) { + const extensionName = ( + await extensionData + .locator('#name-and-version') + .locator('#name') + .textContent() + ).toLowerCase(); + + const extensionVersion = ( + await extensionData + .locator('#name-and-version') + .locator('#version') + .textContent() + ).replace(/(\n| )/g, ''); + + const extensionId = ( + await extensionData.locator('#extension-id').textContent() + ).replace('ID: ', ''); + + extensionsData[extensionName] = { + version: extensionVersion, + id: extensionId, + }; + } + await page.close(); + + return extensionsData; + }, + + async switchToKeplrNotification() { + const keplrExtensionData = (await module.exports.getExtensionsData()).keplr; + + let pages = await browser.contexts()[0].pages(); + for (const page of pages) { + if ( + page + .url() + .includes(`chrome-extension://${keplrExtensionData.id}/popup.html`) + ) { + keplrNotificationWindow = page; + retries = 0; + await page.bringToFront(); + await module.exports.waitUntilStable(page); + return page; + } + } + await sleep(200); + if (retries < 50) { + retries++; + return await module.exports.switchToKeplrNotification(); + } else if (retries >= 50) { + retries = 0; + throw new Error( + '[switchToKeplrNotification] Max amount of retries to switch to keplr notification window has been reached. It was never found.', + ); + } + }, +}; \ No newline at end of file diff --git a/commands/playwright.js b/commands/playwright-metamask.js similarity index 100% rename from commands/playwright.js rename to commands/playwright-metamask.js diff --git a/helpers.js b/helpers.js index 80a7d96c8..0205a6aa9 100644 --- a/helpers.js +++ b/helpers.js @@ -193,6 +193,44 @@ module.exports = { ); } }, + async getKeplrReleases(version) { + log(`Trying to find keplr version ${version} in GitHub releases..`); + let filename; + let downloadUrl; + let tagName; + let response; + + try { + if (version === 'latest' || !version) { + response = await axios.get( + 'https://api.github.com/repos/chainapsis/keplr-wallet/releases', + ); + + filename = response.data[0].assets[0].name; + downloadUrl = response.data[0].assets[0].browser_download_url; + tagName = response.data[0].tag_name; + log( + `Keplr version found! Filename: ${filename}; Download url: ${downloadUrl}; Tag name: ${tagName}`, + ); + } else if (version) { + filename = `keplr-extension-manifest-v2-v${version}.zip`; + downloadUrl = `https://github.com/chainapsis/keplr-wallet/releases/download/v${version}/keplr-extension-manifest-v2-v${version}.zip`; + tagName = `keplr-extension-manifest-${version}`; + log( + `Keplr version found! Filename: ${filename}; Download url: ${downloadUrl}; Tag name: ${tagName}`, + ); + } + return { + filename, + downloadUrl, + tagName, + }; + } catch (e) { + throw new Error( + `[getKeplrReleases] Unable to fetch metamask releases from GitHub with following error:\n${e}`, + ); + } + }, async download(url, destination) { try { log( @@ -210,12 +248,19 @@ module.exports = { } } catch (e) { throw new Error( - `[download] Unable to download metamask release from: ${url} to: ${destination} with following error:\n${e}`, + `[download] Unable to download release from: ${url} to: ${destination} with following error:\n${e}`, ); } }, - async prepareMetamask(version) { - const release = await module.exports.getMetamaskReleases(version); + async prepareExtension(version, extension) { + let release; + if (extension === 'metamask') { + release = await module.exports.getMetamaskReleases(version); + } else if (extension === 'keplr') { + release = await module.exports.getKeplrReleases(version); + } else { + throw new Error('Please provide a valid extension name'); + } let downloadsDirectory; if (os.platform() === 'win32') { @@ -225,22 +270,22 @@ module.exports = { } await module.exports.createDirIfNotExist(downloadsDirectory); - const metamaskDirectory = path.join(downloadsDirectory, release.tagName); - const metamaskDirectoryExists = - await module.exports.checkDirOrFileExist(metamaskDirectory); - const metamaskManifestFilePath = path.join( + const extensionDirectory = path.join(downloadsDirectory, release.tagName); + const extensionDirectoryExists = + await module.exports.checkDirOrFileExist(extensionDirectory); + const extensionManifestFilePath = path.join( downloadsDirectory, release.tagName, 'manifest.json', ); - const metamaskManifestFileExists = await module.exports.checkDirOrFileExist( - metamaskManifestFilePath, + const extensionManifestFileExists = await module.exports.checkDirOrFileExist( + extensionManifestFilePath, ); - if (!metamaskDirectoryExists && !metamaskManifestFileExists) { - await module.exports.download(release.downloadUrl, metamaskDirectory); + if (!extensionDirectoryExists && !extensionManifestFileExists) { + await module.exports.download(release.downloadUrl, extensionDirectory); } else { - log('Metamask is already downloaded'); + log('Extension is already downloaded'); } - return metamaskDirectory; + return extensionDirectory; }, }; diff --git a/package.json b/package.json index 69ec585ac..8a1fcb023 100644 --- a/package.json +++ b/package.json @@ -41,14 +41,16 @@ "release:patch": "release-it patch --disable-metrics", "update:deps": "ncu -u -x 'node-fetch' && pnpm install", "start:server": "serve node_modules/@metamask/test-dapp/dist -p 3000", - "synpress:run": "SKIP_METAMASK_SETUP=true SYNPRESS_LOCAL_TEST=true node synpress.js run --configFile=synpress.config.js", - "test:e2e": "start-server-and-test 'turbo start:server' http-get://localhost:3000 'pnpm synpress:run'", + "synpress:run:metamask": "EXTENSION=metamask SKIP_EXTENSION_SETUP=true SYNPRESS_LOCAL_TEST=true node synpress.js run --configFile=synpress.config.js", + "test:e2e:metamask": "start-server-and-test 'turbo start:server' http-get://localhost:3000 'pnpm synpress:run:metamask'", "test:e2e:anvil": "start-server-and-test 'turbo start:server' http-get://localhost:3000 'CYPRESS_USE_ANVIL=true pnpm synpress:run'", "test:e2e:headless": "start-server-and-test 'turbo start:server' http-get://localhost:3000 'pnpm synpress:run --headless'", "test:e2e:headless:anvil": "start-server-and-test 'turbo start:server' http-get://localhost:3000 'CYPRESS_USE_ANVIL=true pnpm synpress:run --headless'", "test:e2e:ci": "start-server-and-test 'turbo start:server' http-get://localhost:3000 'pnpm synpress:run --record --group'", "test:e2e:ci:anvil": "start-server-and-test 'turbo start:server' http-get://localhost:3000 'CYPRESS_USE_ANVIL=true pnpm synpress:run --record --group'", - "test:e2e:ci:cypress-action": "CYPRESS_USE_ANVIL=true pnpm synpress:run" + "test:e2e:ci:cypress-action": "CYPRESS_USE_ANVIL=true pnpm synpress:run", + "synpress:run:keplr": "EXTENSION=keplr SKIP_EXTENSION_SETUP=true SYNPRESS_LOCAL_TEST=true node synpress.js run --configFile=synpress.config.js", + "test:e2e:keplr": "start-server-and-test 'turbo start:server' http-get://localhost:3000 'pnpm synpress:run:keplr'" }, "dependencies": { "@cypress/code-coverage": "^3.11.0", diff --git a/pages/keplr/first-time-flow-page.js b/pages/keplr/first-time-flow-page.js new file mode 100644 index 000000000..d79d6e7f9 --- /dev/null +++ b/pages/keplr/first-time-flow-page.js @@ -0,0 +1,34 @@ +const createWalletButton = 'Create a new wallet'; +const importRecoveryPhraseButton = 'Import existing recovery phrase'; +const useRecoveryPhraseButton = 'Use recovery phrase or private key'; +const phraseCount24 = '24 words'; +const walletInput = 'input[name="name"]:focus'; +const passwordInput = 'input[name="password"]'; +const confirmPasswordInput = 'input[name="confirmPassword"]'; +const walletName = 'My wallet'; +const submitWalletDataButton = 'button[type="submit"]'; +const phraseSelectChain = 'Select Chains'; +const submitChainButton = 'button[type="button"]'; +const phraseAccountCreated = 'Account Created!'; +const finishButton = 'button[type="button"]'; +const textAreaSelector = 'textbox'; +const submitPhraseButton = 'button[type="submit"]'; + +module.exports.onboardingElements = { + createWalletButton, + importRecoveryPhraseButton, + useRecoveryPhraseButton, + phraseCount24, + walletInput, + walletName, + passwordInput, + confirmPasswordInput, + submitWalletDataButton, + phraseSelectChain, + submitChainButton, + phraseAccountCreated, + finishButton, + textAreaSelector, + submitChainButton, + submitPhraseButton, +}; \ No newline at end of file diff --git a/pages/keplr/notification-page.js b/pages/keplr/notification-page.js new file mode 100644 index 000000000..639ba0ae2 --- /dev/null +++ b/pages/keplr/notification-page.js @@ -0,0 +1,5 @@ +const approveButton = `button[type="button"]`; + +module.exports.notificationPageElements = { + approveButton, +}; \ No newline at end of file diff --git a/plugins/index.js b/plugins/index.js index c41090ed6..de16662fa 100644 --- a/plugins/index.js +++ b/plugins/index.js @@ -1,197 +1,15 @@ -const helpers = require('../helpers'); -const playwright = require('../commands/playwright'); -const metamask = require('../commands/metamask'); -const etherscan = require('../commands/etherscan'); - -/** - * @type {Cypress.PluginConfig} - */ module.exports = (on, config) => { - // `on` is used to hook into various events Cypress emits - // `config` is the resolved Cypress config - - on('before:browser:launch', async (browser = {}, arguments_) => { - if (browser.name === 'chrome') { - // metamask welcome screen blocks cypress from loading - arguments_.args.push( - '--disable-background-timer-throttling', - '--disable-backgrounding-occluded-windows', - '--disable-renderer-backgrounding', - ); - if (process.env.CI) { - // Avoid: "dri3 extension not supported" error - arguments_.args.push('--disable-gpu'); - } - if (process.env.HEADLESS_MODE) { - arguments_.args.push('--headless=new'); - } - if (browser.isHeadless) { - arguments_.args.push('--window-size=1920,1080'); - } - } - - if (!process.env.SKIP_METAMASK_INSTALL) { - // NOTE: extensions cannot be loaded in headless Chrome - const metamaskPath = await helpers.prepareMetamask( - process.env.METAMASK_VERSION || '10.25.0', - ); - arguments_.extensions.push(metamaskPath); - } - - return arguments_; - }); - - on('task', { - error(message) { - console.error('\u001B[31m', 'ERROR:', message, '\u001B[0m'); - return true; - }, - warn(message) { - console.warn('\u001B[33m', 'WARNING:', message, '\u001B[0m'); - return true; - }, - // playwright commands - initPlaywright: playwright.init, - clearPlaywright: playwright.clear, - assignWindows: playwright.assignWindows, - clearWindows: playwright.clearWindows, - assignActiveTabName: playwright.assignActiveTabName, - isMetamaskWindowActive: playwright.isMetamaskWindowActive, - isCypressWindowActive: playwright.isCypressWindowActive, - switchToCypressWindow: playwright.switchToCypressWindow, - switchToMetamaskWindow: playwright.switchToMetamaskWindow, - switchToMetamaskNotification: playwright.switchToMetamaskNotification, - unlockMetamask: metamask.unlock, - importMetamaskAccount: metamask.importAccount, - createMetamaskAccount: metamask.createAccount, - renameMetamaskAccount: metamask.renameAccount, - switchMetamaskAccount: metamask.switchAccount, - addMetamaskNetwork: metamask.addNetwork, - changeMetamaskNetwork: async network => { - if (process.env.NETWORK_NAME && !network) { - network = process.env.NETWORK_NAME; - } else if (!network) { - network = 'goerli'; - } - return await metamask.changeNetwork(network); - }, - activateAdvancedGasControlInMetamask: metamask.activateAdvancedGasControl, - activateShowHexDataInMetamask: metamask.activateShowHexData, - activateTestnetConversionInMetamask: metamask.activateTestnetConversion, - activateShowTestnetNetworksInMetamask: metamask.activateShowTestnetNetworks, - activateCustomNonceInMetamask: metamask.activateCustomNonce, - activateDismissBackupReminderInMetamask: - metamask.activateDismissBackupReminder, - activateEthSignRequestsInMetamask: metamask.activateEthSignRequests, - activateImprovedTokenAllowanceInMetamask: - metamask.activateImprovedTokenAllowance, - resetMetamaskAccount: metamask.resetAccount, - disconnectMetamaskWalletFromDapp: metamask.disconnectWalletFromDapp, - disconnectMetamaskWalletFromAllDapps: metamask.disconnectWalletFromAllDapps, - confirmMetamaskSignatureRequest: metamask.confirmSignatureRequest, - confirmMetamaskDataSignatureRequest: metamask.confirmDataSignatureRequest, - rejectMetamaskSignatureRequest: metamask.rejectSignatureRequest, - rejectMetamaskDataSignatureRequest: metamask.rejectDataSignatureRequest, - confirmMetamaskEncryptionPublicKeyRequest: - metamask.confirmEncryptionPublicKeyRequest, - rejectMetamaskEncryptionPublicKeyRequest: - metamask.rejectEncryptionPublicKeyRequest, - confirmMetamaskDecryptionRequest: metamask.confirmDecryptionRequest, - rejectMetamaskDecryptionRequest: metamask.rejectDecryptionRequest, - importMetamaskToken: metamask.importToken, - confirmMetamaskAddToken: metamask.confirmAddToken, - rejectMetamaskAddToken: metamask.rejectAddToken, - confirmMetamaskPermissionToSpend: metamask.confirmPermissionToSpend, - rejectMetamaskPermissionToSpend: metamask.rejectPermissionToSpend, - confirmMetamaskPermissionToApproveAll: - metamask.confirmPermissionToApproveAll, - rejectMetamaskPermissionToApproveAll: metamask.rejectPermissionToApproveAll, - confirmMetamaskRevokePermissionToAll: metamask.confirmRevokePermissionToAll, - rejectMetamaskRevokePermissionToAll: metamask.rejectRevokePermissionToAll, - acceptMetamaskAccess: metamask.acceptAccess, - rejectMetamaskAccess: metamask.rejectAccess, - confirmMetamaskTransaction: metamask.confirmTransaction, - confirmMetamaskTransactionAndWaitForMining: - metamask.confirmTransactionAndWaitForMining, - rejectMetamaskTransaction: metamask.rejectTransaction, - openMetamaskTransactionDetails: metamask.openTransactionDetails, - closeMetamaskTransactionDetailsPopup: metamask.closeTransactionDetailsPopup, - allowMetamaskToAddNetwork: async ({ waitForEvent }) => - await metamask.allowToAddNetwork({ waitForEvent }), - rejectMetamaskToAddNetwork: metamask.rejectToAddNetwork, - allowMetamaskToSwitchNetwork: metamask.allowToSwitchNetwork, - rejectMetamaskToSwitchNetwork: metamask.rejectToSwitchNetwork, - allowMetamaskToAddAndSwitchNetwork: metamask.allowToAddAndSwitchNetwork, - getMetamaskWalletAddress: metamask.getWalletAddress, - fetchMetamaskWalletAddress: metamask.walletAddress, - setupMetamask: async ({ - secretWordsOrPrivateKey, - network, - password, - enableAdvancedSettings, - enableExperimentalSettings, - }) => { - if (process.env.NETWORK_NAME) { - network = process.env.NETWORK_NAME; - } - if ( - process.env.NETWORK_NAME && - process.env.RPC_URL && - process.env.CHAIN_ID && - process.env.SYMBOL - ) { - network = { - id: process.env.CHAIN_ID, - name: process.env.NETWORK_NAME, - nativeCurrency: { - symbol: process.env.SYMBOL, - }, - rpcUrls: { - public: { http: [process.env.RPC_URL] }, - default: { http: [process.env.RPC_URL] }, - }, - blockExplorers: { - etherscan: { url: process.env.BLOCK_EXPLORER }, - default: { url: process.env.BLOCK_EXPLORER }, - }, - testnet: process.env.IS_TESTNET, - }; - } - if (process.env.PRIVATE_KEY) { - secretWordsOrPrivateKey = process.env.PRIVATE_KEY; - } - if (process.env.SECRET_WORDS) { - secretWordsOrPrivateKey = process.env.SECRET_WORDS; - } - await metamask.initialSetup(null, { - secretWordsOrPrivateKey, - network, - password, - enableAdvancedSettings, - enableExperimentalSettings, - }); - return true; - }, - getCurrentNetwork: helpers.getCurrentNetwork, - etherscanGetTransactionStatus: async ({ txid }) => - await etherscan.getTransactionStatus(txid), - etherscanWaitForTxSuccess: async ({ txid }) => - await etherscan.waitForTxSuccess(txid), - }); - - if (process.env.BASE_URL) { - config.e2e.baseUrl = process.env.BASE_URL; - config.component.baseUrl = process.env.BASE_URL; - } - - if (process.env.CI) { - config.retries.runMode = 1; - config.retries.openMode = 1; - } - - if (process.env.SKIP_METAMASK_SETUP) { - config.env.SKIP_METAMASK_SETUP = true; + const extension = process.env.EXTENSION; + let selectedConfig; + if (extension === 'metamask') { + selectedConfig = require('./metamask-plugin'); + } else if (extension === 'keplr') { + selectedConfig = require('./keplr-plugin'); + } else { + throw new InvalidInputException( + `${extension} is not a valid extension name`, + ); } - return config; + return selectedConfig(on, config); }; diff --git a/plugins/keplr-plugin.js b/plugins/keplr-plugin.js new file mode 100644 index 000000000..99ef9be15 --- /dev/null +++ b/plugins/keplr-plugin.js @@ -0,0 +1,86 @@ +const helpers = require('../helpers'); +const playwright = require('../commands/playwright-keplr'); +const keplr = require('../commands/keplr'); + +/** + * @type {Cypress.PluginConfig} + */ +module.exports = (on, config) => { + // `on` is used to hook into various events Cypress emits + // `config` is the resolved Cypress config + + on('before:browser:launch', async (browser = {}, arguments_) => { + if (browser.name === 'chrome') { + // metamask welcome screen blocks cypress from loading + arguments_.args.push( + '--disable-background-timer-throttling', + '--disable-backgrounding-occluded-windows', + '--disable-renderer-backgrounding', + ); + if (process.env.CI) { + // Avoid: "dri3 extension not supported" error + arguments_.args.push('--disable-gpu'); + } + if (process.env.HEADLESS_MODE) { + arguments_.args.push('--headless=new'); + } + if (browser.isHeadless) { + arguments_.args.push('--window-size=1920,1080'); + } + } + + if (!process.env.SKIP_KEPLR_INSTALL) { + // NOTE: extensions cannot be loaded in headless Chrome + const keplrPath = await helpers.prepareExtension( + process.env.KEPLR_VERSION || '0.12.68', process.env.EXTENSION + ); + arguments_.extensions.push(keplrPath); + } + + return arguments_; + }); + + on('task', { + error(message) { + console.error('\u001B[31m', 'ERROR:', message, '\u001B[0m'); + return true; + }, + warn(message) { + console.warn('\u001B[33m', 'WARNING:', message, '\u001B[0m'); + return true; + }, + // playwright commands for Keplr + initPlaywright: playwright.init, + assignWindows: playwright.assignWindows, + assignActiveTabName: playwright.assignActiveTabName, + isExtensionWindowActive: playwright.isKeplrWindowActive, + switchToCypressWindow: playwright.switchToCypressWindow, + clearPlaywright: playwright.clear, + clearWindows: playwright.clearWindows, + isCypressWindowActive: playwright.isCypressWindowActive, + switchToExtensionWindow: playwright.switchToKeplrWindow, + + // keplr commands + importWallet: keplr.importWallet, + acceptAccess: keplr.acceptAccess, + confirmTransaction: keplr.confirmTransaction, + setupWallet: async ({ + secretWordsOrPrivateKey, + network, + password, + enableAdvancedSettings, + enableExperimentalSettings, + }) => { + await keplr.initialSetup(null, { + secretWordsOrPrivateKey, + network, + password, + enableAdvancedSettings, + enableExperimentalSettings, + }); + return true; + }, + }); + + return config; +}; \ No newline at end of file diff --git a/plugins/metamask-plugin.js b/plugins/metamask-plugin.js new file mode 100644 index 000000000..490f058f7 --- /dev/null +++ b/plugins/metamask-plugin.js @@ -0,0 +1,197 @@ +const helpers = require('../helpers'); +const playwright = require('../commands/playwright-metamask'); +const metamask = require('../commands/metamask'); +const etherscan = require('../commands/etherscan'); + +/** + * @type {Cypress.PluginConfig} + */ +module.exports = (on, config) => { + // `on` is used to hook into various events Cypress emits + // `config` is the resolved Cypress config + + on('before:browser:launch', async (browser = {}, arguments_) => { + if (browser.name === 'chrome') { + // metamask welcome screen blocks cypress from loading + arguments_.args.push( + '--disable-background-timer-throttling', + '--disable-backgrounding-occluded-windows', + '--disable-renderer-backgrounding', + ); + if (process.env.CI) { + // Avoid: "dri3 extension not supported" error + arguments_.args.push('--disable-gpu'); + } + if (process.env.HEADLESS_MODE) { + arguments_.args.push('--headless=new'); + } + if (browser.isHeadless) { + arguments_.args.push('--window-size=1920,1080'); + } + } + + if (!process.env.SKIP_METAMASK_INSTALL) { + // NOTE: extensions cannot be loaded in headless Chrome + const metamaskPath = await helpers.prepareExtension( + process.env.METAMASK_VERSION || '10.25.0', process.env.EXTENSION + ); + arguments_.extensions.push(metamaskPath); + } + + return arguments_; + }); + + on('task', { + error(message) { + console.error('\u001B[31m', 'ERROR:', message, '\u001B[0m'); + return true; + }, + warn(message) { + console.warn('\u001B[33m', 'WARNING:', message, '\u001B[0m'); + return true; + }, + // playwright commands + initPlaywright: playwright.init, + clearPlaywright: playwright.clear, + assignWindows: playwright.assignWindows, + clearWindows: playwright.clearWindows, + assignActiveTabName: playwright.assignActiveTabName, + isMetamaskWindowActive: playwright.isMetamaskWindowActive, + isCypressWindowActive: playwright.isCypressWindowActive, + switchToCypressWindow: playwright.switchToCypressWindow, + switchToMetamaskWindow: playwright.switchToMetamaskWindow, + switchToMetamaskNotification: playwright.switchToMetamaskNotification, + unlockMetamask: metamask.unlock, + importMetamaskAccount: metamask.importAccount, + createMetamaskAccount: metamask.createAccount, + renameMetamaskAccount: metamask.renameAccount, + switchMetamaskAccount: metamask.switchAccount, + addMetamaskNetwork: metamask.addNetwork, + changeMetamaskNetwork: async network => { + if (process.env.NETWORK_NAME && !network) { + network = process.env.NETWORK_NAME; + } else if (!network) { + network = 'goerli'; + } + return await metamask.changeNetwork(network); + }, + activateAdvancedGasControlInMetamask: metamask.activateAdvancedGasControl, + activateShowHexDataInMetamask: metamask.activateShowHexData, + activateTestnetConversionInMetamask: metamask.activateTestnetConversion, + activateShowTestnetNetworksInMetamask: metamask.activateShowTestnetNetworks, + activateCustomNonceInMetamask: metamask.activateCustomNonce, + activateDismissBackupReminderInMetamask: + metamask.activateDismissBackupReminder, + activateEthSignRequestsInMetamask: metamask.activateEthSignRequests, + activateImprovedTokenAllowanceInMetamask: + metamask.activateImprovedTokenAllowance, + resetMetamaskAccount: metamask.resetAccount, + disconnectMetamaskWalletFromDapp: metamask.disconnectWalletFromDapp, + disconnectMetamaskWalletFromAllDapps: metamask.disconnectWalletFromAllDapps, + confirmMetamaskSignatureRequest: metamask.confirmSignatureRequest, + confirmMetamaskDataSignatureRequest: metamask.confirmDataSignatureRequest, + rejectMetamaskSignatureRequest: metamask.rejectSignatureRequest, + rejectMetamaskDataSignatureRequest: metamask.rejectDataSignatureRequest, + confirmMetamaskEncryptionPublicKeyRequest: + metamask.confirmEncryptionPublicKeyRequest, + rejectMetamaskEncryptionPublicKeyRequest: + metamask.rejectEncryptionPublicKeyRequest, + confirmMetamaskDecryptionRequest: metamask.confirmDecryptionRequest, + rejectMetamaskDecryptionRequest: metamask.rejectDecryptionRequest, + importMetamaskToken: metamask.importToken, + confirmMetamaskAddToken: metamask.confirmAddToken, + rejectMetamaskAddToken: metamask.rejectAddToken, + confirmMetamaskPermissionToSpend: metamask.confirmPermissionToSpend, + rejectMetamaskPermissionToSpend: metamask.rejectPermissionToSpend, + confirmMetamaskPermissionToApproveAll: + metamask.confirmPermissionToApproveAll, + rejectMetamaskPermissionToApproveAll: metamask.rejectPermissionToApproveAll, + confirmMetamaskRevokePermissionToAll: metamask.confirmRevokePermissionToAll, + rejectMetamaskRevokePermissionToAll: metamask.rejectRevokePermissionToAll, + acceptMetamaskAccess: metamask.acceptAccess, + rejectMetamaskAccess: metamask.rejectAccess, + confirmMetamaskTransaction: metamask.confirmTransaction, + confirmMetamaskTransactionAndWaitForMining: + metamask.confirmTransactionAndWaitForMining, + rejectMetamaskTransaction: metamask.rejectTransaction, + openMetamaskTransactionDetails: metamask.openTransactionDetails, + closeMetamaskTransactionDetailsPopup: metamask.closeTransactionDetailsPopup, + allowMetamaskToAddNetwork: async ({ waitForEvent }) => + await metamask.allowToAddNetwork({ waitForEvent }), + rejectMetamaskToAddNetwork: metamask.rejectToAddNetwork, + allowMetamaskToSwitchNetwork: metamask.allowToSwitchNetwork, + rejectMetamaskToSwitchNetwork: metamask.rejectToSwitchNetwork, + allowMetamaskToAddAndSwitchNetwork: metamask.allowToAddAndSwitchNetwork, + getMetamaskWalletAddress: metamask.getWalletAddress, + fetchMetamaskWalletAddress: metamask.walletAddress, + setupMetamask: async ({ + secretWordsOrPrivateKey, + network, + password, + enableAdvancedSettings, + enableExperimentalSettings, + }) => { + if (process.env.NETWORK_NAME) { + network = process.env.NETWORK_NAME; + } + if ( + process.env.NETWORK_NAME && + process.env.RPC_URL && + process.env.CHAIN_ID && + process.env.SYMBOL + ) { + network = { + id: process.env.CHAIN_ID, + name: process.env.NETWORK_NAME, + nativeCurrency: { + symbol: process.env.SYMBOL, + }, + rpcUrls: { + public: { http: [process.env.RPC_URL] }, + default: { http: [process.env.RPC_URL] }, + }, + blockExplorers: { + etherscan: { url: process.env.BLOCK_EXPLORER }, + default: { url: process.env.BLOCK_EXPLORER }, + }, + testnet: process.env.IS_TESTNET, + }; + } + if (process.env.PRIVATE_KEY) { + secretWordsOrPrivateKey = process.env.PRIVATE_KEY; + } + if (process.env.SECRET_WORDS) { + secretWordsOrPrivateKey = process.env.SECRET_WORDS; + } + await metamask.initialSetup(null, { + secretWordsOrPrivateKey, + network, + password, + enableAdvancedSettings, + enableExperimentalSettings, + }); + return true; + }, + getCurrentNetwork: helpers.getCurrentNetwork, + etherscanGetTransactionStatus: async ({ txid }) => + await etherscan.getTransactionStatus(txid), + etherscanWaitForTxSuccess: async ({ txid }) => + await etherscan.waitForTxSuccess(txid), + }); + + if (process.env.BASE_URL) { + config.e2e.baseUrl = process.env.BASE_URL; + config.component.baseUrl = process.env.BASE_URL; + } + + if (process.env.CI) { + config.retries.runMode = 1; + config.retries.openMode = 1; + } + + if (process.env.SKIP_EXTENSION_SETUP) { + config.env.SKIP_EXTENSION_SETUP = true; + } + + return config; +}; diff --git a/support/commands.js b/support/commands.js index 664571457..1c5363a62 100644 --- a/support/commands.js +++ b/support/commands.js @@ -408,3 +408,33 @@ Cypress.Commands.add( return subject; }, ); + +// Keplr Commands +Cypress.Commands.add( + 'setupWallet', + ( + secretWordsOrPrivateKey = 'orbit bench unit task food shock brand bracket domain regular warfare company announce wheel grape trust sphere boy doctor half guard ritual three ecology', + password = 'Test1234', + ) => { + return cy.task('setupWallet', { + secretWordsOrPrivateKey, + password + }); + }, +); + +Cypress.Commands.add('acceptAccess', () => { + return cy.task('acceptAccess'); +}); + +Cypress.Commands.add('confirmTransaction', () => { + return cy.task('confirmTransaction'); +}); + +Cypress.Commands.add('isExtensionWindowActive', () => { + return cy.task('isExtensionWindowActive'); +}); + +Cypress.Commands.add('switchToExtensionWindow', () => { + return cy.task('switchToExtensionWindow'); +}); \ No newline at end of file diff --git a/support/index.js b/support/index.js index 41b6fae42..8bb05ed2c 100644 --- a/support/index.js +++ b/support/index.js @@ -25,7 +25,7 @@ Cypress.on('window:before:load', win => { }); before(() => { - if (!Cypress.env('SKIP_METAMASK_SETUP')) { + if (Cypress.env('EXTENSION') === 'metamask' && !Cypress.env('SKIP_EXTENSION_SETUP')) { cy.setupMetamask(); } }); diff --git a/synpress.config.js b/synpress.config.js index 3ef0efbc3..a28755ea3 100644 --- a/synpress.config.js +++ b/synpress.config.js @@ -11,6 +11,12 @@ const fixturesFolder = `${synpressPath}/fixtures`; log(`Detected synpress fixtures path is: ${fixturesFolder}`); const supportFile = 'tests/e2e/support.js'; + +const specPattern = { + metamask: 'tests/e2e/specs/metamask/**/*.{js,jsx,ts,tsx}', + keplr : 'tests/e2e/specs/keplr/**/*.{js,jsx,ts,tsx}' +} + module.exports = defineConfig({ userAgent: 'synpress', retries: { @@ -33,7 +39,7 @@ module.exports = defineConfig({ testIsolation: false, setupNodeEvents, baseUrl: 'http://localhost:3000', - specPattern: 'tests/e2e/specs/**/*.{js,jsx,ts,tsx}', + specPattern: specPattern[process.env.EXTENSION], supportFile, }, component: { diff --git a/synpress.js b/synpress.js index d7daab5bf..4dac7d251 100644 --- a/synpress.js +++ b/synpress.js @@ -3,6 +3,7 @@ const log = require('debug')('synpress:cli'); const program = require('commander'); const { run, open } = require('./launcher'); const { version } = require('./package.json'); +const SUPPORTED_EXTENSIONS = ['metamask', 'keplr'] if (process.env.DEBUG && process.env.DEBUG.includes('synpress')) { log('DEBUG mode is enabled'); @@ -13,6 +14,15 @@ if (process.env.DEBUG && process.env.DEBUG.includes('synpress')) { } } +if (!process.env.EXTENSION) { + throw new Error('Please provide EXTENSION environment variable'); +} +if (!SUPPORTED_EXTENSIONS.includes(process.env.EXTENSION)) { + throw new Error( + `Invalid EXTENSION value. EXTENSION can have the following values: ${SUPPORTED_EXTENSIONS.toString()}`, + ); +} + if (process.env.SYNPRESS_LOCAL_TEST) { log('Loading .env config file from root folder'); require('dotenv').config(); @@ -27,7 +37,7 @@ if (process.env.SYNPRESS_LOCAL_TEST) { } // if user skips metamask install or setup -if (!process.env.SKIP_METAMASK_INSTALL && !process.env.SKIP_METAMASK_SETUP) { +if (!process.env.SKIP_METAMASK_INSTALL && !process.env.SKIP_EXTENSION_SETUP) { // we don't want to check for presence of SECRET_WORDS or PRIVATE_KEY if (!process.env.SECRET_WORDS && !process.env.PRIVATE_KEY) { throw new Error( @@ -36,7 +46,7 @@ if (!process.env.SKIP_METAMASK_INSTALL && !process.env.SKIP_METAMASK_SETUP) { } } else { log( - 'Skipping check for SECRET_WORDS and PRIVATE_KEY as SKIP_METAMASK_INSTALL or SKIP_METAMASK_SETUP is set', + 'Skipping check for SECRET_WORDS and PRIVATE_KEY as SKIP_EXTENSION_SETUP or SKIP_METAMASK_SETUP is set', ); } diff --git a/tests/e2e/specs/keplr/keplr-spec.js b/tests/e2e/specs/keplr/keplr-spec.js new file mode 100644 index 000000000..28e5b3049 --- /dev/null +++ b/tests/e2e/specs/keplr/keplr-spec.js @@ -0,0 +1,30 @@ +/* eslint-disable ui-testing/no-disabled-tests */ +describe('Keplr', () => { + context('Test commands', () => { + it(`setupWallet should finish Keplr setup using secret words`, () => { + cy.setupWallet().then(setupFinished => { + expect(setupFinished).to.be.true; + }); + }); + + it(`acceptAccess should accept connection request to Keplr`, () => { + cy.visit('/'); + cy.contains('Connect Wallet').click(); + cy.acceptAccess().then(taskCompleted => { + expect(taskCompleted).to.be.true; + }); + cy.get('.card') + .contains('My Wallet') + .then(p => console.log(p)); + + cy.contains('agoric1p2aqakv3ulz4qfy2nut86j9gx0dx0yw09h96md'); + }); + + it(`confirmTransaction should confirm transaction for token creation (contract deployment) and check tx data`, () => { + cy.contains('Make an Offer').click(); + cy.confirmTransaction().then(taskCompleted => { + expect(taskCompleted).to.be.true; + }); + }); + }); + }); \ No newline at end of file diff --git a/tests/e2e/specs/keplr/playwright-spec.js b/tests/e2e/specs/keplr/playwright-spec.js new file mode 100644 index 000000000..46bad8fdf --- /dev/null +++ b/tests/e2e/specs/keplr/playwright-spec.js @@ -0,0 +1,32 @@ +describe('Playwright', () => { + context('Test commands', () => { + it(`initPlaywright should connect with cypress browser`, () => { + cy.initPlaywright().then(isConnected => { + expect(isConnected).to.be.true; + }); + }); + it(`assignActiveTabName should properly assign keplr tab as currently active and verify result using isKeplrWindowActive & isCypressWindowActive`, () => { + cy.assignActiveTabName('keplr'); + cy.isExtensionWindowActive().then(isActive => { + expect(isActive).to.be.true; + }); + cy.isCypressWindowActive().then(isActive => { + expect(isActive).to.be.false; + }); + }); + it(`assignWindows should properly assign cypress and keplr windows`, () => { + cy.assignWindows().then(assigned => { + expect(assigned).to.be.true; + }); + }); + it(`switchToCypressWindow should properly switch active tab to cypress window`, () => { + cy.switchToCypressWindow(); + cy.isCypressWindowActive().then(isActive => { + expect(isActive).to.be.true; + }); + cy.isExtensionWindowActive().then(isActive => { + expect(isActive).to.be.false; + }); + }); + }); + }); \ No newline at end of file diff --git a/tests/e2e/specs/metamask-spec.js b/tests/e2e/specs/metamask/metamask-spec.js similarity index 100% rename from tests/e2e/specs/metamask-spec.js rename to tests/e2e/specs/metamask/metamask-spec.js diff --git a/tests/e2e/specs/playwright-spec.js b/tests/e2e/specs/metamask/playwright-spec.js similarity index 100% rename from tests/e2e/specs/playwright-spec.js rename to tests/e2e/specs/metamask/playwright-spec.js From 61f7a964b08bb7e6ee30065c69066a97cdaa8fdd Mon Sep 17 00:00:00 2001 From: Rabi Siddique <60459172+rabi-siddique@users.noreply.github.com> Date: Wed, 28 Feb 2024 14:09:57 +0500 Subject: [PATCH 13/35] chore: use Error object for throwing an error related to invalid extension name --- plugins/index.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/index.js b/plugins/index.js index de16662fa..6507a48c0 100644 --- a/plugins/index.js +++ b/plugins/index.js @@ -6,7 +6,7 @@ module.exports = (on, config) => { } else if (extension === 'keplr') { selectedConfig = require('./keplr-plugin'); } else { - throw new InvalidInputException( + throw new Error( `${extension} is not a valid extension name`, ); } From 7fd9158f91718e1a45d74a7ba27d09f9fb943620 Mon Sep 17 00:00:00 2001 From: Rabi Siddique <60459172+rabi-siddique@users.noreply.github.com> Date: Fri, 1 Mar 2024 14:23:53 +0500 Subject: [PATCH 14/35] Adding Keplr Interaction for Importing Wallet using Private Key (#2) * feature: adding keplr interaction for creating an account using private key * feature: keplr interaction for importing an existing wallet and creating a new wallet * fix: fixed implementation of waitAndClickByText to perform exact matching --------- Co-authored-by: Fraz Arshad --- commands/keplr.js | 104 ++++++++++++++++++++-------- commands/playwright-keplr.js | 32 ++++++--- pages/keplr/first-time-flow-page.js | 6 +- plugins/keplr-plugin.js | 9 +-- support/commands.js | 8 ++- tests/e2e/specs/keplr/keplr-spec.js | 62 ++++++++++++----- 6 files changed, 158 insertions(+), 63 deletions(-) diff --git a/commands/keplr.js b/commands/keplr.js index 1f7dca9a8..891293fa5 100644 --- a/commands/keplr.js +++ b/commands/keplr.js @@ -35,47 +35,56 @@ const keplr = { }; }, - async importWallet(secretWords, password) { + async importWallet(secretWordsOrPrivateKey, password, newAccount) { await playwright.waitAndClickByText( - onboardingElements.createWalletButton, - await playwright.keplrWindow(), - ); - await playwright.waitAndClickByText( - onboardingElements.importRecoveryPhraseButton, - await playwright.keplrWindow(), - ); - await playwright.waitAndClickByText( - onboardingElements.useRecoveryPhraseButton, + newAccount + ? onboardingElements.createWalletButton + : onboardingElements.existingWalletButton, await playwright.keplrWindow(), ); + await playwright.waitAndClickByText( - onboardingElements.phraseCount24, + newAccount + ? onboardingElements.importRecoveryPhraseButton + : onboardingElements.useRecoveryPhraseButton, await playwright.keplrWindow(), ); - for (const [index, word] of secretWords.split(' ').entries()) { - await playwright.waitAndTypeByLocator( - onboardingElements.textAreaSelector, - word, - index, + newAccount && + (await playwright.waitAndClickByText( + onboardingElements.useRecoveryPhraseButton, + await playwright.keplrWindow(), + )); + + if (secretWordsOrPrivateKey.includes(' ')) { + await module.exports.importWalletWithPhrase( + secretWordsOrPrivateKey, + password, + ); + } else { + await module.exports.importWalletWithPrivateKey( + secretWordsOrPrivateKey, + password, ); } - await playwright.waitAndClick( - onboardingElements.submitPhraseButton, - await playwright.keplrWindow(), - ); - await playwright.waitAndType( onboardingElements.walletInput, onboardingElements.walletName, ); - await playwright.waitAndType(onboardingElements.passwordInput, password); - await playwright.waitAndType( - onboardingElements.confirmPasswordInput, - password, + + const passwordFieldExists = await playwright.doesElementExist( + onboardingElements.passwordInput, ); + if (passwordFieldExists) { + await playwright.waitAndType(onboardingElements.passwordInput, password); + await playwright.waitAndType( + onboardingElements.confirmPasswordInput, + password, + ); + } + await playwright.waitAndClick( onboardingElements.submitWalletDataButton, await playwright.keplrWindow(), @@ -105,7 +114,42 @@ const keplr = { return true; }, + async importWalletWithPhrase(secretWords) { + await playwright.waitAndClickByText( + onboardingElements.phraseCount24, + await playwright.keplrWindow(), + ); + + for (const [index, word] of secretWords.split(' ').entries()) { + await playwright.waitAndTypeByLocator( + onboardingElements.textAreaSelector, + word, + index, + ); + } + + await playwright.waitAndClick( + onboardingElements.submitPhraseButton, + await playwright.keplrWindow(), + ); + }, + async importWalletWithPrivateKey(privateKey) { + await playwright.waitAndClickByText( + onboardingElements.phrasePrivateKey, + await playwright.keplrWindow(), + true, + ); + + await playwright.waitAndTypeByLocator( + onboardingElements.textAreaSelector, + privateKey, + ); + await playwright.waitAndClick( + onboardingElements.submitPhraseButton, + await playwright.keplrWindow(), + ); + }, async acceptAccess() { const notificationPage = await playwright.switchToKeplrNotification(); await playwright.waitAndClick( @@ -128,7 +172,7 @@ const keplr = { async initialSetup( playwrightInstance, - { secretWordsOrPrivateKey, password }, + { secretWordsOrPrivateKey, password, newAccount }, ) { if (playwrightInstance) { await playwright.init(playwrightInstance); @@ -139,8 +183,12 @@ const keplr = { await playwright.assignWindows(); await playwright.assignActiveTabName('keplr'); await module.exports.getExtensionDetails(); - await module.exports.importWallet(secretWordsOrPrivateKey, password); + await module.exports.importWallet( + secretWordsOrPrivateKey, + password, + newAccount, + ); }, }; -module.exports = keplr; \ No newline at end of file +module.exports = keplr; diff --git a/commands/playwright-keplr.js b/commands/playwright-keplr.js index c7fc975c6..0d953b3db 100644 --- a/commands/playwright-keplr.js +++ b/commands/playwright-keplr.js @@ -7,6 +7,7 @@ let browser; let mainWindow; let keplrWindow; let keplrNotificationWindow; +let keplrRegistrationWindow; let activeTabName; let extensionsData = {}; let retries = 0; @@ -19,6 +20,7 @@ module.exports = { keplrWindow = undefined; activeTabName = undefined; keplrNotificationWindow = undefined; + keplrRegistrationWindow = undefined; retries = 0; extensionsData = {}; }, @@ -77,9 +79,9 @@ module.exports = { return keplrNotificationWindow; }, - async waitAndClickByText(text, page = keplrWindow) { + async waitAndClickByText(text, page = keplrWindow, exact = false) { await module.exports.waitForByText(text, page); - const element = `:is(:text-is("${text}"), :text("${text}"))`; + const element = `:is(:text-is("${text}")${exact ? '' : `, :text("${text}")`})`; await page.click(element); await module.exports.waitUntilStable(); }, @@ -170,16 +172,13 @@ module.exports = { }, async waitUntilStable(page) { - const keplrExtensionData = (await module.exports.getExtensionsData()) - .keplr; + const keplrExtensionData = (await module.exports.getExtensionsData()).keplr; if ( page && page .url() - .includes( - `chrome-extension://${keplrExtensionData.id}/register.html`, - ) + .includes(`chrome-extension://${keplrExtensionData.id}/register.html`) ) { await page.waitForLoadState('load'); await page.waitForLoadState('domcontentloaded'); @@ -216,6 +215,14 @@ module.exports = { } return element; }, + async doesElementExist(selector, timeout = 1000, page = keplrWindow) { + try { + await page.waitForSelector(selector, { timeout }); + return true; + } catch (error) { + return false; + } + }, async waitForByText(text, page = keplrWindow) { await module.exports.waitUntilStable(page); // await page.waitForSelector(selector, { strict: false }); @@ -347,6 +354,15 @@ module.exports = { return extensionsData; }, + async switchToKeplrRegistrationWindow() { + const keplrExtensionData = (await module.exports.getExtensionsData()).keplr; + const browserContext = await browser.contexts()[0]; + keplrRegistrationWindow = await browserContext.newPage(); + await keplrRegistrationWindow.goto( + `chrome-extension://${keplrExtensionData.id}/register.html`, + ); + return true; + }, async switchToKeplrNotification() { const keplrExtensionData = (await module.exports.getExtensionsData()).keplr; @@ -375,4 +391,4 @@ module.exports = { ); } }, -}; \ No newline at end of file +}; diff --git a/pages/keplr/first-time-flow-page.js b/pages/keplr/first-time-flow-page.js index d79d6e7f9..7bfc1bf52 100644 --- a/pages/keplr/first-time-flow-page.js +++ b/pages/keplr/first-time-flow-page.js @@ -1,7 +1,9 @@ const createWalletButton = 'Create a new wallet'; -const importRecoveryPhraseButton = 'Import existing recovery phrase'; +const existingWalletButton = 'Import an existing wallet'; +const importRecoveryPhraseButton = 'Import existing recovery phrase'; const useRecoveryPhraseButton = 'Use recovery phrase or private key'; const phraseCount24 = '24 words'; +const phrasePrivateKey = 'Private key'; const walletInput = 'input[name="name"]:focus'; const passwordInput = 'input[name="password"]'; const confirmPasswordInput = 'input[name="confirmPassword"]'; @@ -15,10 +17,12 @@ const textAreaSelector = 'textbox'; const submitPhraseButton = 'button[type="submit"]'; module.exports.onboardingElements = { + existingWalletButton, createWalletButton, importRecoveryPhraseButton, useRecoveryPhraseButton, phraseCount24, + phrasePrivateKey, walletInput, walletName, passwordInput, diff --git a/plugins/keplr-plugin.js b/plugins/keplr-plugin.js index 99ef9be15..2d018276c 100644 --- a/plugins/keplr-plugin.js +++ b/plugins/keplr-plugin.js @@ -59,6 +59,7 @@ module.exports = (on, config) => { clearWindows: playwright.clearWindows, isCypressWindowActive: playwright.isCypressWindowActive, switchToExtensionWindow: playwright.switchToKeplrWindow, + switchToExtensionRegistrationWindow: playwright.switchToKeplrRegistrationWindow, // keplr commands importWallet: keplr.importWallet, @@ -66,17 +67,13 @@ module.exports = (on, config) => { confirmTransaction: keplr.confirmTransaction, setupWallet: async ({ secretWordsOrPrivateKey, - network, password, - enableAdvancedSettings, - enableExperimentalSettings, + newAccount, }) => { await keplr.initialSetup(null, { secretWordsOrPrivateKey, - network, password, - enableAdvancedSettings, - enableExperimentalSettings, + newAccount }); return true; }, diff --git a/support/commands.js b/support/commands.js index 1c5363a62..0dac7f6a2 100644 --- a/support/commands.js +++ b/support/commands.js @@ -415,10 +415,12 @@ Cypress.Commands.add( ( secretWordsOrPrivateKey = 'orbit bench unit task food shock brand bracket domain regular warfare company announce wheel grape trust sphere boy doctor half guard ritual three ecology', password = 'Test1234', + newAccount = false ) => { return cy.task('setupWallet', { secretWordsOrPrivateKey, - password + password, + newAccount }); }, ); @@ -437,4 +439,8 @@ Cypress.Commands.add('isExtensionWindowActive', () => { Cypress.Commands.add('switchToExtensionWindow', () => { return cy.task('switchToExtensionWindow'); +}); + +Cypress.Commands.add('switchToExtensionRegistrationWindow', () => { + return cy.task('switchToExtensionRegistrationWindow'); }); \ No newline at end of file diff --git a/tests/e2e/specs/keplr/keplr-spec.js b/tests/e2e/specs/keplr/keplr-spec.js index 28e5b3049..fb7588bb6 100644 --- a/tests/e2e/specs/keplr/keplr-spec.js +++ b/tests/e2e/specs/keplr/keplr-spec.js @@ -1,30 +1,54 @@ /* eslint-disable ui-testing/no-disabled-tests */ describe('Keplr', () => { - context('Test commands', () => { - it(`setupWallet should finish Keplr setup using secret words`, () => { - cy.setupWallet().then(setupFinished => { - expect(setupFinished).to.be.true; - }); - }); - - it(`acceptAccess should accept connection request to Keplr`, () => { + context('Test commands', () => { + it(`should complete Keplr connect with wallet, and confirm transaction after importing an existing wallet using 24 word phrase`, () => { + cy.setupWallet().then(setupFinished => { + expect(setupFinished).to.be.true; + cy.visit('/'); cy.contains('Connect Wallet').click(); cy.acceptAccess().then(taskCompleted => { expect(taskCompleted).to.be.true; + + cy.contains('Make an Offer').click(); + cy.confirmTransaction().then(taskCompleted => { + expect(taskCompleted).to.be.true; + }); }); - cy.get('.card') - .contains('My Wallet') - .then(p => console.log(p)); - - cy.contains('agoric1p2aqakv3ulz4qfy2nut86j9gx0dx0yw09h96md'); }); - - it(`confirmTransaction should confirm transaction for token creation (contract deployment) and check tx data`, () => { - cy.contains('Make an Offer').click(); - cy.confirmTransaction().then(taskCompleted => { - expect(taskCompleted).to.be.true; + }); + + it(`should complete Keplr connect with wallet, and confirm transaction after creating a new wallet using 24 word phrase`, () => { + cy.switchToExtensionRegistrationWindow().then(() => { + cy.setupWallet( + 'orbit bench unit task food shock brand bracket domain regular warfare company announce wheel grape trust sphere boy doctor half guard ritual three ecology', + 'Test1234', + true, + ).then(setupFinished => { + expect(setupFinished).to.be.true; + + cy.visit('/'); + cy.contains('Connect Wallet').click(); + cy.acceptAccess().then(taskCompleted => { + expect(taskCompleted).to.be.true; + + cy.contains('Make an Offer').click(); + cy.confirmTransaction().then(taskCompleted => { + expect(taskCompleted).to.be.true; + }); + }); + }); + }); + }); + + it(`should complete Keplr setup by importing the wallet using private key`, () => { + cy.switchToExtensionRegistrationWindow().then(() => { + cy.setupWallet( + 'A9C09B6E4AF70DE1F1B621CB1AA66CFD0B4AA977E4C18497C49132DD9E579485', + ).then(setupFinished => { + expect(setupFinished).to.be.true; }); }); }); - }); \ No newline at end of file + }); +}); From afdc0a4a0e868a09dffcd9d66a78d1b9f6076af4 Mon Sep 17 00:00:00 2001 From: Rabi Siddique <60459172+rabi-siddique@users.noreply.github.com> Date: Fri, 1 Mar 2024 16:10:52 +0500 Subject: [PATCH 15/35] Disconnect Wallet Interaction (#7) * chore: removing call to acceptAccess function * feature: adding intereaction for disconnecting with wallet * remve the default arg --- commands/keplr.js | 8 +++++++- commands/playwright-keplr.js | 16 ++++++++++++++++ plugins/keplr-plugin.js | 2 ++ support/commands.js | 8 ++++++++ tests/e2e/specs/keplr/keplr-spec.js | 16 ++++++++++------ 5 files changed, 43 insertions(+), 7 deletions(-) diff --git a/commands/keplr.js b/commands/keplr.js index 891293fa5..148563db0 100644 --- a/commands/keplr.js +++ b/commands/keplr.js @@ -34,7 +34,13 @@ const keplr = { extensionVersion, }; }, - + async disconnectWalletFromDapp() { + await playwright.waitAndClickByText( + 'Disconnect All', + playwright.keplrPermissionWindow() + ); + return true; + }, async importWallet(secretWordsOrPrivateKey, password, newAccount) { await playwright.waitAndClickByText( newAccount diff --git a/commands/playwright-keplr.js b/commands/playwright-keplr.js index 0d953b3db..4f1aeea12 100644 --- a/commands/playwright-keplr.js +++ b/commands/playwright-keplr.js @@ -8,6 +8,7 @@ let mainWindow; let keplrWindow; let keplrNotificationWindow; let keplrRegistrationWindow; +let keplrPermissionWindow; let activeTabName; let extensionsData = {}; let retries = 0; @@ -21,6 +22,7 @@ module.exports = { activeTabName = undefined; keplrNotificationWindow = undefined; keplrRegistrationWindow = undefined; + keplrPermissionWindow = undefined; retries = 0; extensionsData = {}; }, @@ -79,6 +81,20 @@ module.exports = { return keplrNotificationWindow; }, + keplrPermissionWindow() { + return keplrPermissionWindow; + }, + + async switchToKeplrPermissionWindow() { + const keplrExtensionData = (await module.exports.getExtensionsData()).keplr; + const browserContext = await browser.contexts()[0]; + keplrPermissionWindow = await browserContext.newPage(); + await keplrPermissionWindow.goto( + `chrome-extension://${keplrExtensionData.id}/popup.html#/setting/security/permission`, + ); + return true; + }, + async waitAndClickByText(text, page = keplrWindow, exact = false) { await module.exports.waitForByText(text, page); const element = `:is(:text-is("${text}")${exact ? '' : `, :text("${text}")`})`; diff --git a/plugins/keplr-plugin.js b/plugins/keplr-plugin.js index 2d018276c..1b9430d4a 100644 --- a/plugins/keplr-plugin.js +++ b/plugins/keplr-plugin.js @@ -60,11 +60,13 @@ module.exports = (on, config) => { isCypressWindowActive: playwright.isCypressWindowActive, switchToExtensionWindow: playwright.switchToKeplrWindow, switchToExtensionRegistrationWindow: playwright.switchToKeplrRegistrationWindow, + switchToExtensionPermissionWindow: playwright.switchToKeplrPermissionWindow, // keplr commands importWallet: keplr.importWallet, acceptAccess: keplr.acceptAccess, confirmTransaction: keplr.confirmTransaction, + disconnectWalletFromDapp: keplr.disconnectWalletFromDapp, setupWallet: async ({ secretWordsOrPrivateKey, password, diff --git a/support/commands.js b/support/commands.js index 0dac7f6a2..1e8053867 100644 --- a/support/commands.js +++ b/support/commands.js @@ -443,4 +443,12 @@ Cypress.Commands.add('switchToExtensionWindow', () => { Cypress.Commands.add('switchToExtensionRegistrationWindow', () => { return cy.task('switchToExtensionRegistrationWindow'); +}); + +Cypress.Commands.add('switchToExtensionPermissionWindow', () => { + return cy.task('switchToExtensionPermissionWindow'); +}); + +Cypress.Commands.add('disconnectWalletFromDapp', () => { + return cy.task('disconnectWalletFromDapp'); }); \ No newline at end of file diff --git a/tests/e2e/specs/keplr/keplr-spec.js b/tests/e2e/specs/keplr/keplr-spec.js index fb7588bb6..808231d37 100644 --- a/tests/e2e/specs/keplr/keplr-spec.js +++ b/tests/e2e/specs/keplr/keplr-spec.js @@ -29,18 +29,22 @@ describe('Keplr', () => { cy.visit('/'); cy.contains('Connect Wallet').click(); - cy.acceptAccess().then(taskCompleted => { + cy.contains('Make an Offer').click(); + cy.confirmTransaction().then(taskCompleted => { expect(taskCompleted).to.be.true; - - cy.contains('Make an Offer').click(); - cy.confirmTransaction().then(taskCompleted => { - expect(taskCompleted).to.be.true; - }); }); }); }); }); + it(`should disconnect the wallet from all the connected DAPPs`, () => { + cy.switchToExtensionPermissionWindow().then(() => { + cy.disconnectWalletFromDapp().then(taskCompleted => { + expect(taskCompleted).to.be.true; + }); + }); + }); + it(`should complete Keplr setup by importing the wallet using private key`, () => { cy.switchToExtensionRegistrationWindow().then(() => { cy.setupWallet( From dbc5fe07437df5118aa7836750c4652a7b784981 Mon Sep 17 00:00:00 2001 From: frazarshad Date: Sun, 3 Mar 2024 22:50:43 -0800 Subject: [PATCH 16/35] Added Interaction to handle rejection of wallet connection (#8) * feat: added code to handle reject wallet access * feat: added test case for reject wallet access + modified test structure --- commands/keplr.js | 8 +++++- plugins/keplr-plugin.js | 17 ++++++----- support/commands.js | 10 +++++-- tests/e2e/specs/keplr/keplr-spec.js | 44 +++++++++++++++++++++-------- 4 files changed, 55 insertions(+), 24 deletions(-) diff --git a/commands/keplr.js b/commands/keplr.js index 148563db0..10c26612a 100644 --- a/commands/keplr.js +++ b/commands/keplr.js @@ -37,7 +37,7 @@ const keplr = { async disconnectWalletFromDapp() { await playwright.waitAndClickByText( 'Disconnect All', - playwright.keplrPermissionWindow() + playwright.keplrPermissionWindow(), ); return true; }, @@ -166,6 +166,12 @@ const keplr = { return true; }, + async rejectAccess() { + const notificationPage = await playwright.switchToKeplrNotification(); + await notificationPage.close(); + return true; + }, + async confirmTransaction() { const notificationPage = await playwright.switchToKeplrNotification(); await playwright.waitAndClick( diff --git a/plugins/keplr-plugin.js b/plugins/keplr-plugin.js index 1b9430d4a..f556721fd 100644 --- a/plugins/keplr-plugin.js +++ b/plugins/keplr-plugin.js @@ -32,7 +32,8 @@ module.exports = (on, config) => { if (!process.env.SKIP_KEPLR_INSTALL) { // NOTE: extensions cannot be loaded in headless Chrome const keplrPath = await helpers.prepareExtension( - process.env.KEPLR_VERSION || '0.12.68', process.env.EXTENSION + process.env.KEPLR_VERSION || '0.12.68', + process.env.EXTENSION, ); arguments_.extensions.push(keplrPath); } @@ -59,27 +60,25 @@ module.exports = (on, config) => { clearWindows: playwright.clearWindows, isCypressWindowActive: playwright.isCypressWindowActive, switchToExtensionWindow: playwright.switchToKeplrWindow, - switchToExtensionRegistrationWindow: playwright.switchToKeplrRegistrationWindow, + switchToExtensionRegistrationWindow: + playwright.switchToKeplrRegistrationWindow, switchToExtensionPermissionWindow: playwright.switchToKeplrPermissionWindow, // keplr commands importWallet: keplr.importWallet, acceptAccess: keplr.acceptAccess, + rejectAccess: keplr.rejectAccess, confirmTransaction: keplr.confirmTransaction, disconnectWalletFromDapp: keplr.disconnectWalletFromDapp, - setupWallet: async ({ - secretWordsOrPrivateKey, - password, - newAccount, - }) => { + setupWallet: async ({ secretWordsOrPrivateKey, password, newAccount }) => { await keplr.initialSetup(null, { secretWordsOrPrivateKey, password, - newAccount + newAccount, }); return true; }, }); return config; -}; \ No newline at end of file +}; diff --git a/support/commands.js b/support/commands.js index 1e8053867..8961b6d85 100644 --- a/support/commands.js +++ b/support/commands.js @@ -415,12 +415,12 @@ Cypress.Commands.add( ( secretWordsOrPrivateKey = 'orbit bench unit task food shock brand bracket domain regular warfare company announce wheel grape trust sphere boy doctor half guard ritual three ecology', password = 'Test1234', - newAccount = false + newAccount = false, ) => { return cy.task('setupWallet', { secretWordsOrPrivateKey, password, - newAccount + newAccount, }); }, ); @@ -429,6 +429,10 @@ Cypress.Commands.add('acceptAccess', () => { return cy.task('acceptAccess'); }); +Cypress.Commands.add('rejectAccess', () => { + return cy.task('rejectAccess'); +}); + Cypress.Commands.add('confirmTransaction', () => { return cy.task('confirmTransaction'); }); @@ -451,4 +455,4 @@ Cypress.Commands.add('switchToExtensionPermissionWindow', () => { Cypress.Commands.add('disconnectWalletFromDapp', () => { return cy.task('disconnectWalletFromDapp'); -}); \ No newline at end of file +}); diff --git a/tests/e2e/specs/keplr/keplr-spec.js b/tests/e2e/specs/keplr/keplr-spec.js index 808231d37..7afb6a698 100644 --- a/tests/e2e/specs/keplr/keplr-spec.js +++ b/tests/e2e/specs/keplr/keplr-spec.js @@ -1,23 +1,45 @@ /* eslint-disable ui-testing/no-disabled-tests */ describe('Keplr', () => { context('Test commands', () => { - it(`should complete Keplr connect with wallet, and confirm transaction after importing an existing wallet using 24 word phrase`, () => { + it(`should complete Keplr setup by importing an existing wallet using 24 word phrase`, () => { cy.setupWallet().then(setupFinished => { expect(setupFinished).to.be.true; + }); + cy.visit('/'); + }); + it(`should reject connect with wallet`, () => { + const alertShown = cy.stub().as('alertShown'); + cy.on('window:alert', alertShown); - cy.visit('/'); - cy.contains('Connect Wallet').click(); - cy.acceptAccess().then(taskCompleted => { - expect(taskCompleted).to.be.true; - - cy.contains('Make an Offer').click(); - cy.confirmTransaction().then(taskCompleted => { - expect(taskCompleted).to.be.true; - }); - }); + cy.contains('Connect Wallet').click(); + cy.rejectAccess().then(rejected => { + expect(rejected).to.be.true; + }); + cy.get('@alertShown').should( + 'have.been.calledOnceWith', + 'Request rejected', + ); + }); + it(`should accept connection with wallet`, () => { + cy.contains('Connect Wallet').click(); + cy.acceptAccess().then(taskCompleted => { + expect(taskCompleted).to.be.true; }); }); + it(`should confirm make an offer transaction`, () => { + const alertShown = cy.stub().as('alertShown'); + cy.on('window:alert', alertShown); + cy.contains('Make an Offer').click(); + cy.confirmTransaction().then(taskCompleted => { + expect(taskCompleted).to.be.true; + }); + + cy.get('@alertShown').should( + 'have.been.calledOnceWith', + 'Offer accepted', + ); + }); it(`should complete Keplr connect with wallet, and confirm transaction after creating a new wallet using 24 word phrase`, () => { cy.switchToExtensionRegistrationWindow().then(() => { cy.setupWallet( From f35b3fe7290e846b1e7734e6059497aebf2299e9 Mon Sep 17 00:00:00 2001 From: frazarshad Date: Mon, 4 Mar 2024 00:00:10 -0800 Subject: [PATCH 17/35] Include code for Offer up Dapp (#10) * feat(ci): Included ui/ and contract/ from offer-up-dapp (with changes) * refactor: moved ui/ and contract/ to tools/ folder --- tools/contract/.gitignore | 3 + tools/contract/Makefile | 121 +++++++++ tools/contract/jsconfig.json | 19 ++ tools/contract/package.json | 85 +++++++ .../scripts/build-contract-deployer.js | 42 ++++ tools/contract/scripts/build-proposal.sh | 11 + tools/contract/scripts/install-bundles.sh | 24 ++ tools/contract/scripts/parseProposals.mjs | 41 ++++ .../scripts/propose-start-contract.sh | 22 ++ tools/contract/scripts/run-chain.sh | 71 ++++++ .../scripts/voteLatestProposalAndWait.sh | 5 + tools/contract/src/debug.js | 41 ++++ tools/contract/src/offer-up-proposal.js | 126 ++++++++++ tools/contract/src/offer-up.contract.js | 141 +++++++++++ tools/contract/test/mintStable.js | 77 ++++++ tools/contract/test/prepare-test-env-ava.js | 13 + tools/contract/test/test-build-proposal.js | 29 +++ tools/contract/test/test-bundle-source.js | 28 +++ tools/contract/test/test-contract.js | 229 ++++++++++++++++++ tools/contract/test/utils.js | 15 ++ tools/ui/.eslintrc.cjs | 20 ++ tools/ui/index.html | 13 + tools/ui/package.json | 52 ++++ tools/ui/public/agoric.svg | 10 + tools/ui/public/vite.svg | 1 + tools/ui/src/App.css | 109 +++++++++ tools/ui/src/App.spec.tsx | 22 ++ tools/ui/src/App.tsx | 160 ++++++++++++ tools/ui/src/assets/IST.svg | 19 ++ tools/ui/src/assets/map.png | Bin 0 -> 12257 bytes tools/ui/src/assets/potionBlue.png | Bin 0 -> 10614 bytes tools/ui/src/assets/react.svg | 1 + tools/ui/src/assets/scroll.png | Bin 0 -> 10195 bytes tools/ui/src/components/Inventory.tsx | 49 ++++ tools/ui/src/components/Logos.tsx | 19 ++ tools/ui/src/components/Trade.tsx | 141 +++++++++++ tools/ui/src/index.css | 72 ++++++ tools/ui/src/index.d.ts | 16 ++ tools/ui/src/installSesLockdown.ts | 13 + tools/ui/src/main.tsx | 11 + tools/ui/src/vite-env.d.ts | 9 + tools/ui/test/App.e2e.ts | 28 +++ tools/ui/tsconfig.json | 27 +++ tools/ui/tsconfig.node.json | 10 + tools/ui/vite.config.ts | 19 ++ 45 files changed, 1964 insertions(+) create mode 100644 tools/contract/.gitignore create mode 100644 tools/contract/Makefile create mode 100644 tools/contract/jsconfig.json create mode 100644 tools/contract/package.json create mode 100644 tools/contract/scripts/build-contract-deployer.js create mode 100755 tools/contract/scripts/build-proposal.sh create mode 100755 tools/contract/scripts/install-bundles.sh create mode 100755 tools/contract/scripts/parseProposals.mjs create mode 100755 tools/contract/scripts/propose-start-contract.sh create mode 100755 tools/contract/scripts/run-chain.sh create mode 100755 tools/contract/scripts/voteLatestProposalAndWait.sh create mode 100644 tools/contract/src/debug.js create mode 100644 tools/contract/src/offer-up-proposal.js create mode 100644 tools/contract/src/offer-up.contract.js create mode 100644 tools/contract/test/mintStable.js create mode 100644 tools/contract/test/prepare-test-env-ava.js create mode 100644 tools/contract/test/test-build-proposal.js create mode 100644 tools/contract/test/test-bundle-source.js create mode 100644 tools/contract/test/test-contract.js create mode 100644 tools/contract/test/utils.js create mode 100644 tools/ui/.eslintrc.cjs create mode 100644 tools/ui/index.html create mode 100644 tools/ui/package.json create mode 100644 tools/ui/public/agoric.svg create mode 100644 tools/ui/public/vite.svg create mode 100644 tools/ui/src/App.css create mode 100644 tools/ui/src/App.spec.tsx create mode 100644 tools/ui/src/App.tsx create mode 100644 tools/ui/src/assets/IST.svg create mode 100644 tools/ui/src/assets/map.png create mode 100644 tools/ui/src/assets/potionBlue.png create mode 100644 tools/ui/src/assets/react.svg create mode 100644 tools/ui/src/assets/scroll.png create mode 100644 tools/ui/src/components/Inventory.tsx create mode 100644 tools/ui/src/components/Logos.tsx create mode 100644 tools/ui/src/components/Trade.tsx create mode 100644 tools/ui/src/index.css create mode 100644 tools/ui/src/index.d.ts create mode 100644 tools/ui/src/installSesLockdown.ts create mode 100644 tools/ui/src/main.tsx create mode 100644 tools/ui/src/vite-env.d.ts create mode 100644 tools/ui/test/App.e2e.ts create mode 100644 tools/ui/tsconfig.json create mode 100644 tools/ui/tsconfig.node.json create mode 100644 tools/ui/vite.config.ts diff --git a/tools/contract/.gitignore b/tools/contract/.gitignore new file mode 100644 index 000000000..eb994f6c6 --- /dev/null +++ b/tools/contract/.gitignore @@ -0,0 +1,3 @@ +start-offer-up-permit.json +start-offer-up.js +bundles/ diff --git a/tools/contract/Makefile b/tools/contract/Makefile new file mode 100644 index 000000000..f2b850691 --- /dev/null +++ b/tools/contract/Makefile @@ -0,0 +1,121 @@ +CHAINID=agoriclocal +USER1ADDR=$(shell agd keys show user1 -a --keyring-backend="test") +ACCT_ADDR=$(USER1ADDR) +BLD=000000ubld + +ATOM_DENOM=ibc/BA313C4A19DFBF943586C0387E6B11286F9E416B4DD27574E6909CABE0E342FA +ATOM=000000$(ATOM_DENOM) + +.PHONY: list +# https://stackoverflow.com/a/73159833/7963 +list: + @make -npq : 2> /dev/null | grep -v PHONY |\ + awk -v RS= -F: '$$1 ~ /^[^#%]+$$/ { print $$1 }' + +balance-q: + agd keys show user1 -a --keyring-backend="test" + agd query bank balances $(ACCT_ADDR) + +GAS_ADJUSTMENT=1.2 +SIGN_BROADCAST_OPTS=--keyring-backend=test --chain-id=$(CHAINID) \ + --gas=auto --gas-adjustment=$(GAS_ADJUSTMENT) \ + --yes -b block + +mint100: + make FUNDS=1000$(ATOM) fund-acct + cd /usr/src/agoric-sdk && \ + yarn --silent agops vaults open --wantMinted 100 --giveCollateral 100 >/tmp/want-ist.json && \ + yarn --silent agops perf satisfaction --executeOffer /tmp/want-ist.json --from user1 --keyring-backend=test + +# https://agoric.explorers.guru/proposal/61 +lower-bundle-cost: bundles/lower-bundle-cost.json ./scripts/voteLatestProposalAndWait.sh + agd tx gov submit-proposal param-change bundles/lower-bundle-cost.json \ + $(SIGN_BROADCAST_OPTS) \ + --from user1 + ./scripts/voteLatestProposalAndWait.sh + # agd query swingset params + + +bundles/swingset-params.json: + mkdir -p bundles/ + agd query swingset params -o json >$@ + +.ONESHELL: +bundles/lower-bundle-cost.json: bundles/swingset-params.json + @read PARAMS < bundles/swingset-params.json; export PARAMS + node - <<- EOF >$@ + const storageByte = '20000000'; + const paramChange = { + title: 'Lower Bundle Cost to 0.02 IST/Kb (a la mainnet 61)', + description: '0.02 IST/Kb', + deposit: '10000000ubld', + changes: [{ + subspace: 'swingset', + key: 'beans_per_unit', + value: '...', + }], + }; + const params = JSON.parse(process.env.PARAMS); + const ix = params.beans_per_unit.findIndex(({key}) => key === 'storageByte'); + params.beans_per_unit[ix].beans = storageByte; + paramChange.changes[0].value = params.beans_per_unit; + console.log(JSON.stringify(paramChange, null, 2)); + EOF + +# Keep mint4k around a while for compatibility +mint4k: + make FUNDS=1000$(ATOM) fund-acct + cd /usr/src/agoric-sdk && \ + yarn --silent agops vaults open --wantMinted 4000 --giveCollateral 1000 >/tmp/want4k.json && \ + yarn --silent agops perf satisfaction --executeOffer /tmp/want4k.json --from user1 --keyring-backend=test + +FUNDS=321$(BLD) +fund-acct: + agd tx bank send validator $(ACCT_ADDR) $(FUNDS) \ + $(SIGN_BROADCAST_OPTS) \ + -o json >,tx.json + jq '{code: .code, height: .height}' ,tx.json + +gov-q: + agd query gov proposals --output json | \ + jq -c '.proposals[] | [.proposal_id,.voting_end_time,.status]' + +gov-voting-q: + agd query gov proposals --status=voting_period --output json | \ + jq -c '.proposals[].proposal_id' + +PROPOSAL=1 +VOTE_OPTION=yes +vote: + agd tx gov vote $(PROPOSAL) $(VOTE_OPTION) --from=validator \ + $(SIGN_BROADCAST_OPTS) \ + -o json >,tx.json + jq '{code: .code, height: .height}' ,tx.json + +instance-q: + agd query vstorage data published.agoricNames.instance -o json + +print-key: /root/.agoric/user1.key + @echo Import the following mnemonic into Keplr: + @cat $< + @echo + @echo -n 'The resulting address should be: ' + @agd keys show user1 -a --keyring-backend="test" + @echo + +SCRIPT=start-offer-up.js +PERMIT=start-offer-up-permit.json +start-contract: $(SCRIPT) $(PERMIT) install-bundles + scripts/propose-start-contract.sh + +install-bundles: bundles/bundle-list + ./scripts/install-bundles.sh + +build-proposal: bundles/bundle-list + +bundles/bundle-list $(SCRIPT) $(PERMIT): + ./scripts/build-proposal.sh + + +clean: + @rm -rf $(SCRIPT) $(PERMIT) bundles/ diff --git a/tools/contract/jsconfig.json b/tools/contract/jsconfig.json new file mode 100644 index 000000000..e7dca0046 --- /dev/null +++ b/tools/contract/jsconfig.json @@ -0,0 +1,19 @@ +// This file can contain .js-specific Typescript compiler config. +{ + "compilerOptions": { + "target": "esnext", + "module": "ES2022", + + "noEmit": true, + /* + // The following flags are for creating .d.ts files: + "noEmit": false, + "declaration": true, + "emitDeclarationOnly": true, +*/ + "downlevelIteration": true, + "strictNullChecks": true, + "moduleResolution": "node" + }, + "include": ["src/**/*.js", "test/**/*.js", "exported.js", "globals.d.ts"] +} diff --git a/tools/contract/package.json b/tools/contract/package.json new file mode 100644 index 000000000..3a53aca50 --- /dev/null +++ b/tools/contract/package.json @@ -0,0 +1,85 @@ +{ + "name": "demo2-contract", + "version": "0.1.0", + "private": true, + "description": "Offer Up Contract", + "type": "module", + "scripts": { + "start:docker": "docker compose up -d", + "docker:logs": "docker compose logs --tail 200 -f", + "docker:bash": "docker compose exec agd bash", + "docker:make": "docker compose exec agd make -C /workspace/contract", + "make:help": "make list", + "start": "yarn docker:make clean start-contract print-key", + "build": "agoric run scripts/build-contract-deployer.js", + "test": "ava --verbose", + "lint": "eslint '**/*.js'", + "lint:fix": "eslint --fix '**/*.js'" + }, + "devDependencies": { + "@agoric/deploy-script-support": "^0.10.4-u12.0", + "@agoric/eslint-config": "dev", + "@endo/bundle-source": "^2.8.0", + "@endo/eslint-plugin": "^0.5.2", + "@endo/init": "^0.5.60", + "@endo/promise-kit": "0.2.56", + "@endo/ses-ava": "^0.2.44", + "@jessie.js/eslint-plugin": "^0.4.0", + "@typescript-eslint/eslint-plugin": "^6.7.0", + "@typescript-eslint/parser": "^6.7.0", + "agoric": "^0.21.2-u12.0", + "ava": "^5.3.0", + "eslint": "^8.47.0", + "eslint-config-airbnb-base": "^15.0.0", + "eslint-config-jessie": "^0.0.6", + "eslint-config-prettier": "^9.0.0", + "eslint-plugin-ava": "^14.0.0", + "eslint-plugin-github": "^4.10.0", + "eslint-plugin-import": "^2.25.3", + "eslint-plugin-jsdoc": "^46.4.3", + "eslint-plugin-prettier": "^5.0.0", + "import-meta-resolve": "^2.2.1", + "prettier": "^3.0.3", + "prettier-plugin-jsdoc": "^1.0.0", + "type-coverage": "^2.26.3", + "typescript": "~5.2.2" + }, + "dependencies": { + "@agoric/ertp": "^0.16.3-u12.0", + "@agoric/zoe": "^0.26.3-u12.0", + "@endo/far": "^0.2.22", + "@endo/marshal": "^0.8.9", + "@endo/patterns": "^0.2.5" + }, + "ava": { + "files": [ + "test/**/test-*.js" + ], + "timeout": "10m" + }, + "keywords": [], + "repository": { + "type": "git", + "url": "git+https://github.com/Agoric/dapp-offer-up" + }, + "author": "Agoric", + "license": "Apache-2.0", + "bugs": { + "url": "https://github.com/Agoric/dapp-offer-up/issues" + }, + "homepage": "https://github.com/Agoric/dapp-offer-up#readme", + "eslintConfig": { + "parserOptions": { + "sourceType": "module", + "ecmaVersion": 2021 + }, + "extends": [ + "@agoric" + ] + }, + "prettier": { + "trailingComma": "all", + "arrowParens": "avoid", + "singleQuote": true + } +} \ No newline at end of file diff --git a/tools/contract/scripts/build-contract-deployer.js b/tools/contract/scripts/build-contract-deployer.js new file mode 100644 index 000000000..f9732f1a3 --- /dev/null +++ b/tools/contract/scripts/build-contract-deployer.js @@ -0,0 +1,42 @@ +/** + * @file Permission Contract Deployment builder + * + * Creates files for starting an instance of the contract: + * * contract source and instantiation proposal bundles to be published via + * `agd tx swingset install-bundle` + * * start-offer-up-permit.json and start-offer-up.js to submit the + * instantiation proposal via `agd tx gov submit-proposal swingset-core-eval` + * + * Usage: + * agoric run build-contract-deployer.js + */ + +import { makeHelpers } from '@agoric/deploy-script-support'; +import { getManifestForOfferUp } from '../src/offer-up-proposal.js'; + +/** @type {import('@agoric/deploy-script-support/src/externalTypes.js').ProposalBuilder} */ +export const offerUpProposalBuilder = async ({ publishRef, install }) => { + return harden({ + sourceSpec: '../src/offer-up-proposal.js', + getManifestCall: [ + getManifestForOfferUp.name, + { + offerUpRef: publishRef( + install( + '../src/offer-up.contract.js', + '../bundles/bundle-offer-up.js', + { + persist: true, + }, + ), + ), + }, + ], + }); +}; + +/** @type {DeployScriptFunction} */ +export default async (homeP, endowments) => { + const { writeCoreProposal } = await makeHelpers(homeP, endowments); + await writeCoreProposal('start-offer-up', offerUpProposalBuilder); +}; diff --git a/tools/contract/scripts/build-proposal.sh b/tools/contract/scripts/build-proposal.sh new file mode 100755 index 000000000..68bdcadb5 --- /dev/null +++ b/tools/contract/scripts/build-proposal.sh @@ -0,0 +1,11 @@ +#!/bin/sh +# NOTE: intended to run _inside_ the agd container + +cd /workspace/contract + +mkdir -p bundles +(agoric run ./scripts/build-contract-deployer.js )>/tmp/,run.log +./scripts/parseProposals.mjs bundles/bundle-list + + diff --git a/tools/contract/scripts/install-bundles.sh b/tools/contract/scripts/install-bundles.sh new file mode 100755 index 000000000..717257bb2 --- /dev/null +++ b/tools/contract/scripts/install-bundles.sh @@ -0,0 +1,24 @@ +#!/bin/bash +# NOTE: intended to run _inside_ the agd container + +set -xueo pipefail + +cd /workspace/contract + +# TODO: try `agoric publish` to better track outcome +install_bundle() { + ls -sh "$1" + agd tx swingset install-bundle --compress "@$1" \ + --from user1 --keyring-backend=test --gas=auto --gas-adjustment=1.2 \ + --chain-id=agoriclocal -bblock --yes -o json +} + +# exit fail if bundle-list is emtpy +[ -s bundles/bundle-list ] || exit 1 + +make balance-q # do we have enough IST? + +for b in $(cat bundles/bundle-list); do + echo installing $b + install_bundle $b +done diff --git a/tools/contract/scripts/parseProposals.mjs b/tools/contract/scripts/parseProposals.mjs new file mode 100755 index 000000000..daab1be36 --- /dev/null +++ b/tools/contract/scripts/parseProposals.mjs @@ -0,0 +1,41 @@ +#!/usr/bin/env node + +import fs from 'fs'; + +const Fail = (template, ...args) => { + throw Error(String.raw(template, ...args.map(val => String(val)))); +}; + +/** + * Parse output of `agoric run proposal-builder.js` + * + * @param {string} txt + * + * adapted from packages/boot/test/bootstrapTests/supports.js + */ +const parseProposalParts = txt => { + const evals = [ + ...txt.matchAll(/swingset-core-eval (?\S+) (? + + diff --git a/tools/ui/package.json b/tools/ui/package.json new file mode 100644 index 000000000..19111626b --- /dev/null +++ b/tools/ui/package.json @@ -0,0 +1,52 @@ +{ + "name": "demo2-ui", + "private": true, + "version": "0.0.0", + "type": "module", + "scripts": { + "dev": "vite", + "build": "tsc && vite build", + "test": "vitest spec", + "test:e2e": "vitest e2e", + "lint": "eslint . --ext ts,tsx --report-unused-disable-directives --max-warnings 0", + "lint:fix": "yarn lint --fix", + "preview": "vite preview" + }, + "dependencies": { + "@endo/eventual-send": "0.17.2", + "react": "^18.2.0", + "react-dom": "^18.2.0" + }, + "devDependencies": { + "@agoric/eventual-send": "^0.14.1", + "@agoric/notifier": "^0.6.2", + "@agoric/rpc": "0.9.1-dev-f471a83.0", + "@agoric/store": "^0.9.2", + "@agoric/ui-components": "^0.9.0", + "@agoric/web-components": "^0.15.0", + "@testing-library/react": "^14.1.2", + "@types/react": "^18.2.15", + "@types/react-dom": "^18.2.7", + "@typescript-eslint/eslint-plugin": "^6.0.0", + "@typescript-eslint/parser": "^6.0.0", + "@vitejs/plugin-react": "^4.0.3", + "eslint": "^8.45.0", + "eslint-config-prettier": "^9.1.0", + "eslint-plugin-prettier": "^5.1.3", + "eslint-plugin-react-hooks": "^4.6.0", + "eslint-plugin-react-refresh": "^0.4.3", + "happy-dom": "^13.3.1", + "prettier": "^3.2.4", + "puppeteer": "^21.9.0", + "ses": "1.3.0", + "typescript": "^5.0.2", + "vite": "^4.4.5", + "vitest": "^1.2.1", + "zustand": "^4.4.1" + }, + "prettier": { + "trailingComma": "all", + "arrowParens": "avoid", + "singleQuote": true + } +} \ No newline at end of file diff --git a/tools/ui/public/agoric.svg b/tools/ui/public/agoric.svg new file mode 100644 index 000000000..28822fa58 --- /dev/null +++ b/tools/ui/public/agoric.svg @@ -0,0 +1,10 @@ + + + + + + + diff --git a/tools/ui/public/vite.svg b/tools/ui/public/vite.svg new file mode 100644 index 000000000..e7b8dfb1b --- /dev/null +++ b/tools/ui/public/vite.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/tools/ui/src/App.css b/tools/ui/src/App.css new file mode 100644 index 000000000..b4d6ec708 --- /dev/null +++ b/tools/ui/src/App.css @@ -0,0 +1,109 @@ +#root { + max-width: 1280px; + margin: 0 auto; + padding: 1rem; + text-align: center; +} + +.logo { + height: 2em; + padding: 1.5em; + will-change: filter; + transition: filter 300ms; +} +.logo:hover { + filter: drop-shadow(0 0 2em #646cffaa); +} +.logo.react:hover { + filter: drop-shadow(0 0 2em #61dafbaa); +} +.logo.agoric:hover { + filter: drop-shadow(0 0 2em #fa4a49aa); +} + +@keyframes logo-spin { + from { + transform: rotate(0deg); + } + to { + transform: rotate(360deg); + } +} + +@media (prefers-reduced-motion: no-preference) { + a:nth-of-type(2) .logo { + animation: logo-spin infinite 20s linear; + } +} + +.card { + padding: 1em; +} + +.read-the-docs { + color: #888; +} + +.piece { + width: 6em; + border-radius: 10%; +} + +.coin { + width: 2em; + margin: 10px; +} + +.trade { + display: flex; + flex-direction: column; + justify-content: center; + align-items: center; + background: #171717; + border-radius: 25px; + margin-bottom: 15px; +} + +.item-col { + display: flex; + flex-direction: column; + align-items: center; + padding: 0 15px 25px 15px; + margin: 5px; +} + +.row-center { + display: flex; + flex-direction: row; + align-items: center; +} + +input { + border: none; + background: #242424; + text-align: center; + padding: 5px 10px; + border-radius: 15px; + font-size: 1.2rem; + width: 75px; +} + +@media (prefers-color-scheme: light) { + .trade { + background: #fafafa; + border: 1px solid #e5e5e5; + } + input { + background: #e5e5e5; + } +} + +.error { + background-color: #E11D48; + color: #fff; +} + +/* increment/decrement arrows always visible */ +input[type=number]::-webkit-inner-spin-button { + opacity: 1 +} diff --git a/tools/ui/src/App.spec.tsx b/tools/ui/src/App.spec.tsx new file mode 100644 index 000000000..aa6bf43c8 --- /dev/null +++ b/tools/ui/src/App.spec.tsx @@ -0,0 +1,22 @@ +import './installSesLockdown'; +import { render, screen } from '@testing-library/react'; +import App from './App'; + +describe('App.tsx', () => { + it('renders app title', async () => { + render(); + + const titleElement = await screen.findByText('Items Listed on Offer Up', { + selector: 'h1', + }); + expect(titleElement).toBeTruthy(); + }); + + it('renders the wallet connection button', async () => { + render(); + const buttonEl = await screen.findByRole('button', { + name: 'Connect Wallet', + }); + expect(buttonEl).toBeTruthy(); + }); +}); diff --git a/tools/ui/src/App.tsx b/tools/ui/src/App.tsx new file mode 100644 index 000000000..a43c4760b --- /dev/null +++ b/tools/ui/src/App.tsx @@ -0,0 +1,160 @@ +import { useEffect } from 'react'; + +import './App.css'; +import { + makeAgoricChainStorageWatcher, + AgoricChainStoragePathKind as Kind, +} from '@agoric/rpc'; +import { create } from 'zustand'; +import { + makeAgoricWalletConnection, + suggestChain, +} from '@agoric/web-components'; +import { subscribeLatest } from '@agoric/notifier'; +import { makeCopyBag } from '@agoric/store'; +import { Logos } from './components/Logos'; +import { Inventory } from './components/Inventory'; +import { Trade } from './components/Trade'; + +const { entries, fromEntries } = Object; + +const RUN_ENV = import.meta.env.VITE_RUN_ENV || 'localhost'; +if (!['localhost', 'agoric_chain'].includes(RUN_ENV)) + throw new Error("VITE_RUN_ENV can only be 'agoric_chain' or 'localhost'"); + +type Wallet = Awaited>; + +const ENDPOINTS = { + RPC: `http://${RUN_ENV}:26657`, + API: `http://${RUN_ENV}:1317`, +}; + +const watcher = makeAgoricChainStorageWatcher(ENDPOINTS.API, 'agoriclocal'); + +interface AppState { + wallet?: Wallet; + offerUpInstance?: unknown; + brands?: Record; + purses?: Array; +} + +const useAppStore = create(() => ({})); + +const setup = async () => { + watcher.watchLatest>( + [Kind.Data, 'published.agoricNames.instance'], + instances => { + console.log('got instances', instances); + useAppStore.setState({ + offerUpInstance: instances.find(([name]) => name === 'offerUp')!.at(1), + }); + }, + ); + + watcher.watchLatest>( + [Kind.Data, 'published.agoricNames.brand'], + brands => { + console.log('Got brands', brands); + useAppStore.setState({ + brands: fromEntries(brands), + }); + }, + ); +}; + +const connectWallet = async () => { + await suggestChain(`http://localhost:3004/${RUN_ENV}`); + const wallet = await makeAgoricWalletConnection(watcher, ENDPOINTS.RPC); + useAppStore.setState({ wallet }); + const { pursesNotifier } = wallet; + for await (const purses of subscribeLatest(pursesNotifier)) { + console.log('got purses', purses); + useAppStore.setState({ purses }); + } +}; + +const makeOffer = (giveValue: bigint, wantChoices: Record) => { + const { wallet, offerUpInstance, brands } = useAppStore.getState(); + if (!offerUpInstance) throw Error('no contract instance'); + if (!(brands && brands.IST && brands.Item)) + throw Error('brands not available'); + + const value = makeCopyBag(entries(wantChoices)); + const want = { Items: { brand: brands.Item, value } }; + const give = { Price: { brand: brands.IST, value: giveValue } }; + + wallet?.makeOffer( + { + source: 'contract', + instance: offerUpInstance, + publicInvitationMaker: 'makeTradeInvitation', + }, + { give, want }, + undefined, + (update: { status: string; data?: unknown }) => { + if (update.status === 'error') { + alert(`Offer error: ${update.data}`); + } + if (update.status === 'accepted') { + alert('Offer accepted'); + } + if (update.status === 'refunded') { + alert('Offer rejected'); + } + }, + ); +}; + +function App() { + useEffect(() => { + setup(); + }, []); + + const { wallet, purses } = useAppStore(({ wallet, purses }) => ({ + wallet, + purses, + })); + const istPurse = purses?.find(p => p.brandPetname === 'IST'); + const itemsPurse = purses?.find(p => p.brandPetname === 'Item'); + + const tryConnectWallet = () => { + connectWallet().catch(err => { + switch (err.message) { + case 'KEPLR_CONNECTION_ERROR_NO_SMART_WALLET': + alert( + 'no smart wallet at that address; try: yarn docker:make print-key', + ); + break; + default: + alert(err.message); + } + }); + }; + + return ( + <> + +

Items Listed on Offer Up

+ +
+ +
+ {wallet && istPurse ? ( + + ) : ( + + )} +
+ + ); +} + +export default App; diff --git a/tools/ui/src/assets/IST.svg b/tools/ui/src/assets/IST.svg new file mode 100644 index 000000000..1fcb75c89 --- /dev/null +++ b/tools/ui/src/assets/IST.svg @@ -0,0 +1,19 @@ + + + + + + + + + + + + + + + + + + + diff --git a/tools/ui/src/assets/map.png b/tools/ui/src/assets/map.png new file mode 100644 index 0000000000000000000000000000000000000000..278c0936b1da801c6bed6a2fd8a64c000aec272d GIT binary patch literal 12257 zcmbVSRZ|>HuwC3;gCqoZf)m_j3GNFC!Cf|l;1=8#cMlMBarXd06C4&_U~v!bT)wLN z2kw2C?uV(Vn(3+OIekt?YN{*YVN+oP002A{WqIuvANb$EM1Qe;l4heX4$D>9$PEC% zA^C400Wz~G0RU_bJ2^Q`ODLa&)d=T&(RJtpEVe#T*?QU7bC0iR;x1 zS=ETZWK|b!GE6#c+2}yh1ZMWPScJfcw*?DiTEB=C6i}&$@*_|nkiZx+El%7h?0JmM zw?81kg%MFB_v=1|4s#vX+kc-LVUjzQ=Q;J`7(JM{smlCXf`PbYvagBOf(QEt);GDO zgRmK00fd`#ESB2r*ZI}6k z=t!(0x~fXZ?GCM*YX5t{JQv`dih;Eem zfAWcwr=BWM3_Z~4=?Bv>s_iG7eD~{U>pBAIMnL}FqQSZAf3Z<0h;Ln3*xKBj2lmSv zn~fOwJ=ye{_82@m-ujC_TwktrZ7>G$eGF1Uy;PU)c;=lOwl zn!aDfyw#AM6rn{7hRA2eobwgaN6IF${brhaw%mYo-lIsu1pzhol1M%YT%{i^P_9&2 z2o1mXY+M5XXYDS(W>_&%0&RoW$331;q#l*>nE-*-Dv4kK;FCNfx9&*2)F37RAfF$^ zUL!+&@r#nP2c6~@+VU@)htEPGvW)$`vV^kOmVq>1KC@MRmt_t6TSLqKnP*0tR-i}A zHY~{%pSxGD1z*CI;LZ#)_ZMqN5EiP;5GIM)+rAcY<*Ayf}pI1Y@Qh!(Mgu~0&^dRgd` zN>v+}+lX%aDb4wK!wr==8Rm%NNO%Z+BINpo8Hpq1_*h!wkyUDobf<`?6sMfE8TL5K zvILZ=7?Oq;EgkAG-Y0X?aSVlS=4|$D@^4aazCAO>&M}t;7v1P=uxgLk17B?sZV7Cm zTcz{K=oMyauap+(5(&nEWT6F3+SOX&r6dCGneYDwldGr}Lw}@9Q`u73UfWgger+RK zNqMcFHeoO|x~H_8wu^G%fr}SL7CabX!}=Y`iGydrlVgC>b?`^JxJfl zAjojhGh}aK_a#dh!A=3DFsD$n^XQh9|14iE$I(028`X^~`=sMnrKrcRgDAtANv+T; z&(S>4q1Le}6Dtibw<&eel`8T#dW=Lj>if{AAy=f8Uu%l!7@)(kcvbJo`PKoiBFsHV zu%Eg1?}G0)_V)Bg+V*IP^0I>Wa{NGkgL>`rWNRr5L^}8;`>Q(E4r@u;xqs9u=?U8g z8}(0t53RgbCJyDPX{m-4$`x7_N(Y@nRYxT`KRXrLjqZc+Wd?yPCM-%eabsvXJ30$G zD<#+^Se!TsySAgs7xdJxRSHch07-=3morQ(5z? znyq>CrK%>UCOl3-}eZAXN;VWWt!}~R5z&#V-$%LAB)PMw2UdnUH-TR- z!5`PXr!I4{>a%)}N|&mSg^ulx!CnP;pC;fbAVU+YshH? z*);Aj@L2F97(ih)&BY$&*JdXal2?*n@(_{;ap6_IRU^|s!adDH&7&H9F1e5AxGbUJp$1`65Z4Gps!857L66C0IXAfcoqVeN zYL*SJ#`|h6pdhI1hokfGjhqb} zgbzhJ&(KF#uY$4Oi_jACGHzl{(NyUV5$Ynzr!s`>rQ|V8XCxj>5Nxkr+Fl!ao=Ks} zhaM;yXUzeOSp7%_YzLM(4yQA==3soR|;~ zmMwp)megdkZ?kRvZM4!VwC?G*b96J$>lBP(hx+(RG$StTCfT36x*%269;=OVI#=UIKuSN zE5%!)n%JFYH7bq_(yIJBnZ4B9J;4|^-r?_e2r^iji*#|YkNb{CdI zElCy`RYkf)kwz9U&${fnMIG)k(w(uK+)!50-)cE-J!QSOy~>qqjGtPbww;FWjJL4Z zfCtxaIJ&%2SmH_h%evGa+$7gp*e%}DVO26b_E$_ww@CLw_fA*ncxt8540hu@c}(ro zaV2m#yJXyP{U|xywWNonr#5RnYjv-3Uw*kEv#_uAaM#)4nJ#uHuq7UNU7jxqh_ z8?6m3kG*W>S*Bu^PUgL_xpAAuAIZtN{Z;P=rKL9n*#hE5UchtRVY|h>@6$;(XX7zB zDLH=r+_%f0mwq()>{yJ!?Fn2?+6cd{PboY{?}&AXjhURad_AjM+9EM%G03bIHFetm zx-b5eG_5h%p52~V)oS9q|KK zivJgu$Fb4&1rL^EXop6J>4o%>%!1rX_^g!i)AIbua)5o0NB;TbveGqrXz=(`!etzR z99mpP+-MkH*g>v{B&X() zoqUTQ_j?XrRWA+n4!rIf_T=aNbfJHL^vh$}gZ88lPN1>rOBcZUYpY$pz z=@}Iz{rtg#pKIv_Z_-&PYpVeO-b^nzG#CK5eSYzK0D${D0AT+!03ezU08qFjn*LS< z0GM!9nbik=!%hSRS2n>1w%edhw z8^y&L(P^R>bNoL47~Q6ACKexZI%mcLo@yIW0<+|1^!uM;c=zv}9DN!Ri?5D@-006r z%#W0img)e_KP}1jQA%$ptbhJQFX0~3V%3#)ydRqH*=_sh?lKFhHx0=n}$_^T15wiXMKmq-M{IW|`3=OFCYiS#*=A-a%j>Dt+9fuK&M&Z1K`V2oX8-j+|k9}@rVu;9XxPLS_V;o~V+28<# z(@=XblC|IHM&*W9=!l=sBgF4FNA1sls-vTy89GGvQG$_3wP?&@&?7agl$tujix=3E z*VoAb&fKl4@{*`mIa?`YClCF+>NKMLxAkcY9j$RMrOQ0X(NPOn*ib%=l#}zS>vY#< z?{Lq$ujx^jpjwlgdllNafSPTOv?e+<{&a(}I&=NF&LWwK<}br`=>|63lk~fIR}$AH zYX(MY_}R&##Jy8U8(c?Kf#zhMtUVL9%l|4arI#=75utRuNAOJFS(ufc?P*7QI+jHQ za0tVG>eKMOP+zN#;eGQdH}A;*io% z^Y&kxjL!@+cwjlAeR41gq*l81Nzu;Zuext9PT8uWc>T;bE_tQE{+q1M$%|(E_dgTs zom4{;Lm4be9OF5Hb&S^o?qC{>K{sNKHKw_q7JQk35>WQeDL=*@m7!9+!vR?&e6kK8 z9JV2Nsxtug*Q-2w?{|U8f=^r2A`(Y&V+);BL{Q=Z-PV^=7>7{Kx(0`oc?NhR$QtxZ z+t2{=HTubh1)UOo2{w7waEa#W1>xR{1w>r_R`<$>qIfqP_JC&Xec{G~P8Yi?b|nJI zzE+sVnrP++$vnk#Y^dM>E4RjYy-0Hmkf_G_qg1OSdNLh(rD5_MYYvqvQ6;81+R!_x z_8wuWXSCHXaDV9)272Q_5-z|)AIB<&|D4D%&yvVtuIDWpq|-J2ORaP~7AD_o5Yvbf zTZ6W3AyyqyMx{oX;V&>Qbu+{~yQqT$H1VUBT^%YN6?7Mn-^oADfnjRt+LCjH-_2jC z`x-Ed+#^+UcFk5CpenX4Q9qqT<8@`1k=v0U^X>FIuFPDYT1t5`kSkD@zH zZ+|VnEp+eDUSs5W&(5VKh!jRWRfpc;Q0?INP)$H7ZNJeAJ;~qz0!Pv#P5Cn5V zXW_7=AI)HXLsf}y<4`v_O2^Y3TCd3PTpgtE=B}WqS%Zna$_g#Ay?Gb`Ox&^mWl5zI zGD|t=UZ&6f=Tk;uXT`lb^so0!tSNn02EetMce}YFCXGUmHwh($L?UL1gKxCdw*Hajm?Ezp0G-d zWKuI{uCRW`&1#r!+7DWKOAM#huL$@70^Gb-*lT;GF6E~r|CGXeCpVq61Cx5Ztp4)v zkCC`k&*e&g19dEKTW)o9N^+zYyB3n575JXok z|JIyn(tTeb7Kyhu7$M@`Y=%e&w#K|cJ>mK@{(uE+1f2f7s3QHnrBJ?Q)z7?7;-CdO z`S<-Wpwo4`;W_mA(Iy!ijjxq+fY*Hs_NRlFD(QOU>h-!DMXJuh#_27#9j=Tjgy*GOh@K zv;+HZD_z+Kr7{ju^<$);gG+V2V&xa6F#-CMd zs?+s>pp9ry0JWknI}wmNCJ8{VAEj-E zR{L#!eEXOnjXm$>RjC2(T@Pl35iKsT#ak`SWK}Ygai*-xn$(#cVNzoqZ#>cg%I`60 zKZ8UiR-z2zvNuN-RI`0=-NOdZ7d!^JMST|cM_f zF;%PT4dra6B_l5VIHio&1|T-6Q<`x%LAEkdOTUIGwm_<5B~_lsjPOLN@z(c z{0LMJi1nJX9)F=A6GzFTJur=@3ppvpYt}l90y^F)V=^7mYX4o_J zgUrC+auZ^&AarSPU9L2Z)rf^2cQolnkb?YBtCuf4sjKUl5ryzI5s@Pe1Nox&eZ&aU z>*o!GB_BG>{lHoJpvY^Q62nOV?3nbK6N(fv8&U0hX?F+=eZ=@y<8*B;+AgM__f^-; zk455APykc*=puM7iZzCfbfjPFL;U5bL~z7f8~zckQLnvntzm(7c}+u2{K@WN#~UL@ zq%}Nlx+u*>)sQdg`cpTq`o{VXUEjQ((e2s#Ua zEp2&9Ma#Oi#&*_Xk-L4ik@`{Fwa^lLx8pwwtLMQ4iGR@ru%GRIl`NoEmftErg5Rnj z6%G*(lGjFBNgKY`&-12 zCykP4hB$3-q3@%cDI&Ba*Wx*dS9}}|N~lUglziifu$|zRSu1GxVN&V3F@dGcqftcW zZ$O<9^Gr($)u(+{gol?)G1*y7T+)b&xkdK6GYDyx!3fa?CPg4}#kxI;lVZV+OQOXW zq13U2EnV{Qfnb{NF)R{(A5nwi8vh-cL+1u21X~~o9@;IOyjx`B=F9ba`~mRPr%uK; zVY^x-2Q?vzA~G2aG#Wpz?^|0bjHAj90FTu!45vTr6!6cF4wTAo8PxXdreP7iU|Lj} zO0{|l8LC!Jh{KTO%GahE-#?cq@I}hmI)K_8g_g|P^yH-C^Jgib49$`lQ9->;dPSPe z?TpeJD_d4oV;^*A(l1G3qh_hZq?tt&U@;&snH603Tg`Z=SBiQX;aDTn%t(EQk?C+GD-WD z@T7bDZXVwEB=$|P(r;y>La(6P-rUN*+d3NizSe}$f_>D8KMkj zWn`UHDU2v~W}8C98NP)t1S7oRQv-jj&N>5_fdo;zX+bt1?tFZJ8lh)HS~O`P)&XS?*L zB$ly%XKvNVuItN8-wu~Xf=|4RJ7-6uG@&6Ov#fTsZfbqa#ww4U^p*NX>BjW|ZHnwylJ2-4 z+U45N5Y}SW6!w+`9SoU9Z3XHV9IZnmaX}R-OGIt_B_r_7-DLPbl)TZ+hzClKsGfkfM>3{i99j^=j@Fg>;#2F$j-Dic6LT z3#_YPKpd}I@s>v_ASBYFgpeqPS9ese$qBA3l()6{Z`$|ZU+}WqGg6b|k|qH@^+&lf zD>s_d9UdEN?i>Zj7+(D1t@n|=QDBqjdxgy~q#pOb$Zc(6{gezUt-9asTkG7n_i=B9 z-V~-xDOOxGM9(d<7dsYOYcR-`%;iwerBnyDA1^BjWy!EbY^2*WRSx>=GcF+0%hDKE zk}*SaHg7npS!$7@N~wrixW%qrg02EpVaG|7PbSmNIxSq-+tEzF)~$hrk;%; z-&Q@XV2fd!*rEj~S}05;BlV^2#S z;3eAjtf8EuWMc<{I15#$TAL}A${PLj9HXLun(&YJ&HV3{<6uTn+lH)tvNmO&l$%X2t-*TD&C3m!h=4>tu$- zQ#(~{Hk>z51Q;gp5vC#<9AgGH%jmv4cUhzSyE{)P=CY*z{Q0DuZS^Nir6)}&mj0a> z|G0&zf1>+Ac*}E;*xu2JdeHQZ5znc}>DAJZ75_!-#iYc90yBk)s#CQ&p}mS_F;zK` zjkI{1v63`}!txo5KF{bJ5K-7-Bz7Kj^6_|o%wyc-VS$BWVyy?yfNdF`E!AMz_|2^Mbqu1&2_AWmiAbl6pbgezx0|NVIjYEe zm^mr=W#QC$&Y`5?x_xL_$J@_)ap6vM<4-(OlF&(a2?J%DZl1a+-JU&rWwUhMkn&I0 z|D{y91=wAowB#}Jp}V4KB|1%49{rm4DDu47 z_u7yg9g|X=)u6D%%pFJW{LaGIrb*7`m9DIUgeQ46cD4yty0me|BXf`rYo+V%sY6T* zE}y{s;Qed=z{p7cLwGmC?fa=aN$E^U^s;W??PfsTH zonsB-(~1;K-79|hbckSCLnuwAK*Ym3adf)=aJfFkS2C;Vn#pN-ho!`8BhseT+dWq< z98&9Zt$%g2@~i7nY-pQb1(b=7|06R>8u=Bxq`NumSgZ-0^o#5*0dJ#$@44xPijv(0N01uPVK z%>;Yha})!)^Ko0MMjZynPZv3=`Q3Sq?!Rr$VxfoMQ^H#yIby=#t7X!>`v+L0MYIL3 z7LD7+4VzG0T*C0zlJ4<2i*U<+!~I{I+bami#l{3+E6~g=19IHN9F4T~MHyV2*#9W{ zHiHIMD$+DBfKU+$p?^ujXE~22bVdq(E6#~u3%R2nREcgqVH1?p&CWU?9h-mUvk~UJ zY`e-_`|4yK56W`4bF8WQQ6D<|Avz`F40C*L?huitbluxmu&s{-D}ATRZ~WH;Jh7He zAK9FGDlp>C{#amSh zA&*0SMm45igaw8-JTzf+ZbqsZO=p3l^D_6YCc;k|-D6VZi+eEU3dG1?AO{ z^d!?1WWuV5JNZ@n495TU67# z=|NU#a^iJzYMKEyQ>7s%a^_45V=5h{_?gqIhC*IQ?2Yy{S6$v|Hp0p^khRGI4a0H>H-)rxarHt(C?T1^o?d>!} zLzACSuJA@#$uz6;pS(>makc(^?{atM7;ZqwEK}K&EI{AKlq6jsnLLYoNJ4BM>MNd) zR7f1Zv4vJ>HOH~Y_Rf((>mr%HlBEjB<=UVot>O^;x)aUQ-OLyy`-VffG419`WI2D!*T z2-1;8D?r{zs1(UWu6c21UB|FgAOh_viS*Oa=7!sKjVj@dr{M8VOWMoT& zDx3_Ll&MW|>sO3G^~Ec0+L@hZ^Ni9z7J;yM+4O~-KPvgyaPvN6|9IC6ik`%-Ra=p% zAdCl*=o!nD5Ke@Ka)6aiPAPvJqewPyb4oWhoUL>Zj<7-ho;0{$J}W*Cp#y)Dyxat} z&{rr9juTojC%p=VW?>wU(+Rl(No{jxWpy!$oi)8XpD88fF~U#kL0$c|#NU)?gM~H^ zHyt~p8nF2`G@dVc=24ndVSZjkCY_E0tzZhM^(nX6tk}^+%ClN_?ll1Df($U{BERi) zG#(@%fH*CQ1-NInE}(796D#mS$}bOv|5Vk@XeyFD)({gLU7t!K!k^U0|HlK(mgFYqiAS=s|Wk!68H zx>aNHa7hPy$|%4yHU#-5*ry}+xJwh~nodRLF4lyVH|`7MJb^@+D=xZ5$n#Nq-)&@6 z)1o>o_Xmz)UL&Irx7claG2|-TK6^` z|Kj@IMmy6C)1^wU{Q7vD1~%Ccd5RXPlw1&N2&!6@WNgx{(9+&$R8dV+3m0_C?24Qh zjpNzNyxy+(mUz(cz&u5#<^Ey$=n2NVMrrm);D#P!S@F*$wRQZF^`3FM$U~y?CKnSM8S=NDml*7 zAU86PUzD$0{S}hXug5ko_FowKV)rF;VYHqUN1-3YzQqnEh3()8pS)s88fWhAV`esW z{Bjnnb;-#GvDjc`#Ru}eR*RhkwL1{GXOezy7#}V4QrmeWb%UUK$V8 zN#Zp5_}SGlAAFbfC(O{5CK#;i=Q|JNqh9lICVqrbyeU&`DJU%o&M!^Xk0>YG@?3Zl zR74wn9=~jB{5SaB1cSQi_=EOud*$?PgpfaCIL^Q*kZLO{dkt9d0VK#AWzN2Z{e8{K zcfbQuf1N9V+DgYoXksD5*jkvL^o6KVY8Wg4nPxSTvuL+He~_L^W!!AL8(QXtW;zY*0GU+|4-^ciON%W^KmJkplLk zsk%H`&7qGq;N>`%`KGJ|4ugFb2{U7Ni|@Ocs)YF6U%#s+r43_9YR4L6{IYM&{OQ)1 zr6@2tOAnh+R&nQpkT6dS@B$qw19j3YIgX|8(bp)6@$B!_tJd*b5ZXA2bDI?oY4 zv2JCrDrv@0;fJY0j5zT2{Hr=Aqc2BB15HqdwDAXbyT0;)>4BRT`a0gZfqYbi$okL? zWcWp_v`}?3_)t}t^;GL5QuRDCi&Opla5z&oSnqSv#(gd;e9mP-A5RdyQM-<3-1_xN zeD>XkD2b+8s!zJajsoIEy`Mf?mrt3d_cB4CGX+w?_VXd)#X}e z;tsyLGC8S5BL=ctBGlS5_(NvThPOf&0${7N&rgutUvEy`XwShkQbK;)v+$4E8EyH~ zmkkaOZ1VeN=fInCrYA*X12_sw;em+X1}fxW&gCw@2nnF#SJzK2{E>@iuV|vt&PYd2 zYQSB4^sTKEweEM~ANC(=4b_521#pO>d#7e$fS8f1h`*b1jvj1 z%Ge6c*!p6|OZ&bXV!5n#h-@!(BZag7H2LpnzjtpsL@Q*ntyX@7SC@lVh{;+rYVybe z*O{spOv9bm{^z1~@9rKf9$uPxiruxd?ybJ)nmBiD7XskmAlrDSzM`6F_ri<3qJ{Sl z-F%Y|>FvdZSbQ*euA#O((_n)-L0=fx%ag&@F7CCHu-k|7SVXtu!T$Xq3Pa%w=nOh& z(PhY5mIj8ri%AqWA@-+B!g ze!Nq!l%rht!l!O>v~WC7=WG3jjbmW=!e;R%Iovxkr#&-B4XF#%hYLq7vwPq_;w5`q zI*#I>^zJ2vm?d*Y3dt6elKf80TtruMgogfL!YQ_6C)XQ!>(4Fc;~^$9z+yX|Kh?4ZVmGQ} zisB5F%>XhnVl&Vv)jExHcb%+;@4lks8v7)AO--Tk+Dp~U>iC!U(x-u7Iq!2*SF^)SAADq45>uo$*WWMXoSY6V)-BgG1U3b7aK2Dot&gi7 z6Ji}mM3+Pe?~@mO%9CsF$wdD!)=H2?csP!*ZC`-fez;~Te}*I)>GYRfd}m4QS*H( zj|W$mcvpO0Pkbq*+Id)&PAOQ(ajRXQ9zKMrQZPq4B_hpWt^(PLK(YG(Lh9+IrC-M= z&AcsU)Qg@PwulGPQba}R205UrUAMBad&g!;s?qQH#v3cSkrPqI7##&o(rJua9!2Wh*+(WHLEjE8FXqR>}Uhts==#AkBPa--|IWMW@gS^ zt5d~fn__j2%Wa{xf7?&%j#PnS-PN(TT=FB$BjN5G$UVq!>cAI*uu{jKy~eycuF+m(0Sf@wrR`|-fhLkZ$uHHy%l;jgo1#}& zUoX?CGQ&fuH%)~h_k*mLV0m(9w50A-Kzy=Q;eNu@*)mZwSj%3%U;wpEdXaQfq2IK{ zS5mRa;WHxl&2YnIEL-uz$0$z3 zP)Vb{vHT%NkHTD_NF`aq_We_S=C=-Eg8+@7Y;(NGMC196#?AIH8P}F4nA0Ro&>A3;`C^-KG z93VTF002N%v5}NiRke0>b9A+KbfS=#l%#NSakR9tw*UaVR`WEhG&PRFB6piNP{pXA zG(|^sJP?ICG&Tq~nU)cPgsBh(DO$l(>&KFo1`>}JM!_c}1jXU0F{8#HFC*?jiW5Rh zqGEnLZTptkEq2`5iVWLUpKM}}bAd#vKY$ka{% zOi+_K#Px*=4sahJEX+jNhu8yv^O{Ei0s21V^s$pfzG0j|vkc&Z!r=PclKB-uLAU^M zp9E+*KwJhcC@+&%15gMA7>}Eo?gCU<0LFBI2lIfSy!$L)IKam=2p(KvGJpcdB1#Hi zEd;2U){c<|=&}QFEft3Z0Lv@@c6l93IY50Ipl=Ejr4ax^1+c3{g);zvz5wG%)$vKocksRg8iKZ01C5p{G}$>^u#@tJUWP2QPgi?a@RXAyD+ zb7TCvo&W#}lkxuj_WH$Z3cYS>iZ`JZ-H7F+7vYW4)O7cCf4bU9901sM3z&UnW@{n} z5<&=acrB(m2U>qZDRjS!wQR%?Zvhk@uj*Vo{l|@TQBwQL%KqNovceGbqsb2)|5vL4 zqduJ%`-cGG=eyfqJv-FFoQA=&!24eV6E{j_B-1HKVW#T`iL%daC~wcC^OQsKrtP|n zxVviD&IwZ4ao3z>l+n->hGCkyH}jn><|la3EgnF>(hJR9?dL8*rZpqNl(^B@uzV}_a#D1F3aJt?Cx+fQ*)?mji^h*T$Z)&Z^W z=ps%Sk0zk}e)_IpB%s772*(7n8U<$>qf34`=<q#&W@##%+f7kxjGeYx&pBuP9pATH~6DRi8Bc>twXJG15DLHSCK6`S7OhmR!wY%iKG4v!VLvZ%TUO{mleYp7EM!oxhy zj>4pDBWr)uBn=0}CCf~{m}G2+CAZHCmn_J{%V5OWzzlY&cO763uo7AXS_rM;hm#NI z+3FwK%Nfdrl!TNz%iD zeGb09sm-gUS?sLstiY;hS58%~&R?_|tpC$G)>_p@SiirFuvXXV(CTku zWr}arHe5G&p4y%2-{BwsB7%q(xq@Czs!tl=+U$ZWs4cjeJ(YVd=0ALse#~a2JB>NL z%(dH!GtMw%lc$k0FKdNw)$SU49Tgj`7&6Y9AwOKpEv45i=;yWLhzfQqC_uvN<;6`L7bvQF(% zeOsC5*E^F7e9^z6E(N=yyTW{%oSS+^6MTJbqiy3VgO2$|;aie{RBz^QK5w&tiXa*| zEBNSOiQtd#p6-48AiW7Ck8&}RG;tJa(@FWsLYD4z>Ya!O7zmsYqcZZo%$x}Ay z;i>^gi!+EO2PUzD0jPB0k>NTKVhK)BxyoZpQjb#UQkywe94Z3eSQK~| zMZdDz3a|2YaCeBoSS|G?7IgD;vDGzrMw1Ed31lx(xSvr)^E28?9NS8|LW zd{TZVcky^r4|A0<@3)81RV8&Pp($Yos9k=kY1h7GLXGhEm{vxI1(oVE zos7DGZd#uYcEO+ee}we6z}cOmXd&;1`=72aof)d=vgvKLm^?=05sTtQ$JF7j;b-6l zF4M1j?Gr~j{^-qGPiwBK9%?tAww$v(KGn&d^rL_L5%V?_CxZV^fntVw$CzH=2){yytTpEhbC%pJ&gBeY^g0|6W-8*md_J zI@YtM1*i34!E(XkN&cznPOL8a>+ya1lY?QcvV-&42>cxU3nCSI>r(sA1=2YYP4&b@ zrc+t;5%QkbybDhjG+s2V_*~cym6MeB-tisM)*Ts|;HpQQZ_PI1Jh=y{6)Br7H2W%B zCPyRt>7(h#4wVVf*~ODhpJ&-Ma*SMVVLfk!Yt1p6)#H%)RI97$xV$fU{sF8H>&9!v zt-gn5Q(Lweju#!6ZrgLxZ?T6$T|!d^SKr;P8rSx5biV6ke-kuvIB`1>eodWM8R^XJ z%&u!Uuxmf}>2C40ygMe&=bPHN>Gu8uep_6~7ZBO#zV>mv8@{{U0&fJk(7jBJcdmHS zo!54$bQ#@o)f3tpQxYd}ccuFNqO??BxXI?*>aj~rZ z>o+OPaG>;S-tF#sT#2>{?brWg&&003k~@=_9-UaPv&G?=1mFsdIheZAmD915nz4&^DJ7RQBe1Bp>0a! z)OT^!x3=XDYf<0y<*x!Pg93p<8&$l9AV`-3&|nHM9R>`=z(wJ~V>108He}P*tGv|d zCdXa|>|jvUZ?Ue6q$Bt}e=SlPKO;Uy%Ey>oJ+WCW^&o7u>of*1S;LzEpyi3!Y>!Nf+$HusL!$n|U` zC2c#Ie)~=STSG;dj#ao*+V4=T$9&`~>}lO%>2;wWE71Q3m)NM4S7FO&0e{GZ9ib5@ zIBH|)=N%w{Dk*_Ye{D^=?x#%}4E?TaV)$Z0otbRh=5&hFbKT{ztMg*RZ9kmc=dJya zc_ZrFKa(dmG@-yg#pu56sq*K$p3^9uxC=V$n$BM$scb_L1#^Hs7o_ALt+7h1R>g&| zbHmdr^b6CC4xE`r^S6WQyDqEJr!vP+f3un_C;jiFRmrJIj>|hQyuUe8XX!*pFNSbn z+RUt~GUMqv{ZwyOZ&;`h1XQ`f1oIuMTcXZ;HZ-dtC~jc17Pt(RN&Mo-eH~1r{}}pmc&MzZ~Na~4@#JYcd6=mjJqD$UrJb61g3yJzT<-tyJGjE z>9kE@@%r|+Rp{cKP094Tji*6_y_?@(sSpuaY=O z8Qr}QOSO7k)9w$BeAs4r`*9`~qw7gxzkK|%naDSDz3##K5lov##qut;1st14f{I*< zsVjxrr#b6+ev3rqBIXAR5GVi_2)=15invr+sT6l7{pt;HB7XA@%*#4sc)fa;88}B1 zhUn?E=GpTja9yaM-0ud%`y%V5#_NjXqM(;Nz~j%rBHA^++a|xDpmW47b;kbn{*)%? z+DS(MZyXU$Xy}s>E^zvL!n!f@?G`OyNK+}HCO(j=*;DBWA*aqurUebXoOq5l%|I-tMyCgZ=z*9m5)5fQfw zronOF^q7F!f!!godi~`aTAzEqLAShOVz-W+&IwV*TECg!rPDo3vE-~YFKu6w+a2zS z=_4YN?e0?9YV6!h5@{XhR;j+ZvH*@x7FXDA``des2ZNA=$6=3y~oVGBsw=2fx>w>$k|f z4S2tO@^6;Yuc1nIjx=Ac8qy2oks_0eJ3BLy`z1u5i>@Co5jU&+d#~E^E7;n=IFUho zx(;Qiw-g;Ln(Iy8y_t}j?CXB6fnxQDNTZ;5p%dYzjosW9B+>i)@H9(itC4XPmyNqm zJ0om#x_7TCSKBIYD(C)}NU!Gwb^W^ZZMaG5g)NXT3Ontri~4DcAV?-pQz%q)u+~#l ze84q#OXwm_Y~1oU+z8Lxm3AHEgFHa_6G!X@VgxkD?rCN!53xA8XjazoHQAuar|4Jo zhmdWg0xoS7@U#OYkLh|o@?y`(@vMyPXwNM0R!>>@l+?g^;db3;3I2PXqO4uC=i8Lt z#6|Y-xxdKo_3jMz7$=hGmUJ1+IcuOfCqv^3?pEiugv*NNfuU8w{jgidEK^zcOD%H$ zPi6%9V5axMEhP*3q)Xeah)X#JViDsc+RX@yMMd7 zP3ZR>_THf7>%UPRYht7L9pD5GJ#G47idNED`lV^2lOW`;9#V31*&Ivcpw{`fUk?18MQ zOIv4s6;0#?r>l9y;#Mzkv>m^v!0-w2;gQG4>a9PZaRqgez-0xs#0=;6%93P55?#gz z93W&dgf~KtL3nA{-LNqW7mA!Vr^(3ky1#m%F>2Ulyswt`mZ>aDUSEGvixA}cu%DsQ zp6avH>X@qh*lg~HOh}$3hr0cp@9rk9XVQI04crf}!goaGc(_6SVwC$jb$vg(JN;*a z_}tXI2FjQPu#=}vZEpFp((cKoBGwkX@zimAer)j)OKby#o7W%D?fA!Qk6P!& zFaG2?*UqPj4*a&rv9?4DOh z>&2#GDR&t(Khf_9x|kP$&Gc_F;5iM4euMt2gEd;}ovZ?+)a=fk9QVohQP=yYnxY00 z+pf=niFmgbAhXe7JF>h2s-W*GZ`ndSMmsD5b3E2_TD`b#=)I?eDgMFGd7;C2xfggI z6S_h3S~*@yKutN7ng}Lr}}1PgPS!lR=S_MB;wM@TFwB z{Sy8<{ae=SRja>&{|o8wP2VJY+HfkGx#ZFmd6#zXv9PzMGo#cqV<^aA#KgWBI(L^T zS{o`uRj4_^RZ^12BIJQn1!AB%){LQ#aq>&VH(HOA9<_)C*WMbqiVOY?=LbGVG`kK` z?fr0wOf;_>4KYi!TFE-hYq#Qlp05@9%fGbYCKfLvCz@dc`@BV!C!eZ7=R|_YuwSj; zE7fG?)ySr*fM~~(({@psG(O8?haiE;Y374yLeSuFNM^9q?@Ee|)GJ`&CX%n$8*IRO z$d=0&Si4)vqTYBWhiI%Y^-j6-K2C_60z9ZD+@5yu=C5`f zN0`Y_3*Wj#yXF!9ZrYbO3JVLsy^S!MU*7Gtzppy7?SlSVdeKpHk!^^vai*VWtXnqB z-QaM>KfvqRSiszM-fx4uJ81Ep1Q+gozAQnQ-&@@i0dawG|N6@F(VvPWD9JfGJ4}@k zH!5x5of__+NxRR*WtzHP6F=&h4BA{co*(lm$bhe6IFcz1(W`Ut!Pc%!gUf{phfk@V zf44Cc(;@+xVST(8kCJE8}VALR!ou#PTATp(@x=mZ>Gvsw10ao57d4H3^OOJhA{mPNb2oE+}Qt1OZn|4tCC| z|85uQZrM^}e87W@!T?>LAmTX%0&%>+Y(iuScF_nb8t5fT$+JsK!$V+VN&f0-Njd?FqC=h+k7&8z&VqI<^!!>&(T=!UeD4#xukE~dM+!>3U+ZVQr8{d z5BupD@K82oS$*#C=WW*Lq}&FR)kWMYI?h;h9ctbi}%#w z()`$^eaNx1So(GbSlj#&qjG5>avz&p2`t!y@Q6qm;!aJQvu?m(GZ6y}5)v;o5HQ_T zG*X>t{xe8&_=DIzWM7@*ZqqaGFOQhoG2)9cYTvix2P3rpkQJ^vmWwmrk-prxs1DMT z1wm>{F0)z2ux1LRv+Ax3%D!3{~g->JMakutn#xQ99c@>V}=cYJj;2f45F#kP1B0i!@&>^xP zB6c0cv49s6eq%_Sot#ia8uy-|qC$un8qIW4GZrl}5)m3>e2^`!dKi9iENT8Gl+}t9yh^?!LR;fE)84fW!MnMyC|KMmiyEOB=n#esgd{325FP{~xO*Ji& z5-2cPJE*l^?Fz+{t<}|_r;f*b9O;5h0XYD@?*NhIPp)g%#4=yMtWR;=mD&poA1$8! z{w*5yBO_}qy|^q1xHPa0vt%HoMuBs%5 zov$c(oGkBEip`pU2~4(ZF3Q4`XN(4SEwTz)xiD$au|Pgc-dq?)IYZJKkO%y7HZ zn1JRj1i{Q!7wLyXt??h9%f_|qSogX&3fsB_WikJ~;GGja?%rG#y<^E?>y73n7I-Zt zz(20u7o&VxM*2}HPWC5^n7&qyj+)B_$$pS6))Qj!TNQ2y194i&e~eot2)#yB8fO7AgcvNnGgn+)$C zzCW&0>u%7EG{MS18iwf%y1)2mz{Qu9(5!9c<9_7B2s>O$Z)C&x-Qx4B5cJW~)SSqo z2yBZ$g!QrzG)q6Apa|LL6v;7G;}~vCN4-X25S$k+E0u-0j?x*%$Y-Qc$v>q)=gL}= zOqG4}_nY)}SF|i&o8P&vy13!am13hOq*424xD8NcT&b>ds-f`f;wgQXM;CsgsKXwn zVbadCSK75%`tlT>)C@y|yuCaEpp7066HhYm*JY=CnQZupV(1Tj-A4{8oUP`htgH#| zn`!#6-^WCc&Kbr!8Dx|mrYJt*&Wq}8(PSuditMK-wwDScGW59u8Kxnrmzmm14dyb* zi+(X~b0hB51Nx0fhfb>s#F8yVl}v;AuSgNHbeCt$zn@dvA9~MA))#r-ZrZ-RBvMow zP>1=`Dg$4#F}W!xkH^bj=F9yhE5w+DrdY@WL$ne_Ap`a(@q{D4q~DcFnW#lJhC>Tm zXofgVD19X7b9n{dZ8?wLqlbq{LiXoU{${2t&Kz{?p~dmwW;H_u^u8uEn^b~1R8fw< zh23aF5l$hyMNnz9(zre@&2c8o7D(OWRQ$wIE^lCe<1sm}&yM$}5%k?HK|nSmxacRTlPI~&=xD>&lM`fO5^v2v5c9b|P&++M~cs_%lOK(R@a?~<9a4JFa+ z2orJrdBXX?NgftBA$}1)~G@IGBzZM9i6+B6I1#+xN> z(sn`lX^3X_tbX6Wu}+afr~*|nm?4el7w;389ULuFkwUFMPQuSG-U4o>!J+*pQJ3U{ z=W@N3mfY8#c*)*&w{I%Szlo&7x)YaY&u=Mzd`WH$S^yha+p8Cbh2o)uLh-N_n*zn< zqB)Y>NTFs?HSgb>1rLBgwHC}#)`Zt`?dXd{L`B79GTZ}EGNl9<0|%RK`9p#f&C>dz zFw?Ss$04OCM|@8m-4&j|C% zKOds%k=a4jSk`eoK?g^Kgz2qxdaLR7Atrc5+M1zB{kEYmC0ZV+%JmM$ae1LQzsajP zRjarbLC!Q?X3mJD0vPkZ4NMy8YF9F5Kn&?Ir752ZcB7IBf|k^h=h770e+*Z+y*LZ1 zKiM^~3^U;uhf}?9j>&{ii;yOIV49YZ1lun~Ed5+#dj%{|MRCV=>bLcJN}pCR@hnB*RZGcQjg|9>h1dKw7QwHPkja)J zfP65U!{L^wL`0TFPB@;xCX}R_3z8;QtmJM{RYQ`bC4!j62mO)h^P)1R1ldSo<@k<# z-w*GmugyyTgH+oGax#$jo%R66m@6cLutcfL#ov~(X7Qe@$t2AAcaK)u3V4~W%iuJq zeRphU4{RHW$@^E47gKf3oS@R2Ak2;kb}aPlXqi4mMA<4JgzYYoYQ~rcW_ysHGQmWn zs*hC}Wz2cLG#I5n^L&?IRbVC!S+Wxb7(DUNROwW5nRfM)8`7nt3Qc_2-qEzjy z@zO5>69URv-I7u7cMiBkG1e-bQjFQZ8MURGrF989n~}G&-UkR;#@2dvP`+ z3BjtXxJkWOF)Ru5OCn?GC>LC42k00Q4lJo}ZHK86IMET0%bdUs935P_GY|0M zXGke}AuGNoB2!E+hIn7FBhYkXl^iUNz2 zbo>E)Ra%xku0z6kEsu3cgG{PBY3tdkh20%{0_OL{9W)23uS=N?K7>$EV*r#*JVjt|(PwgJ>t_ zMccS2%!mU`WreULUQm-yH>baYjh^M?Zp;S`*uB8{Ul*MgZl9^7Rl$ zEfw`utBN0Gfr`FCmi$=s4umzwj&0>#S_=kGbjVgDD!X;EW4)IIgLGXeU*vWW5Zd4v z8N|6YzH1XS_7oBUb^jFzLp_d zQ|l40?;0m(j$uio_7U^e*T`CSea%&z8(6c@X2!0q27mNC)sESi#9a2B#3}a@*v( zOap#XEEpvoKaBUTF!T2xPPx+E6!t;QHqi(nP8iauHja{A37ER0%vp4qiPOxcnBm$l zq^ezF$nk0ibX2<*nQlH8C?Mk|eH^y{^we~CJ&qh2t$JT9g~SJPmZZ&*cW;v9Z~Q(> zEe9^O$yPPvfSQuxZ!50<$pf;9NN}p=IxRAua0yj%W5a9Z_-uW@^t@4O(Av|$4r&Ai zHU;U?D?B6$(CD18Sh9W=*wqzsTQbAV?@Vmioemw9v<;m>*Y0Z6)+ISVNV6UpQeREFRzcDA5gLRt5EDw2boRsG9>ODWrzMN(W1zsTc%bab@U z`s@M#DLr?)GBfvkhHMwF+GouzwI+&8@sn$6#BG#i!<0GIahP%{DcQ3!PsQ(>JrA5o z#xheal;jlpRUL)=-#R~?bVl?%$PT5BmQw@r=Eoh6wwe}qMhEU#-BLQw4)Vu&Yemof z9JjHR?#MI)#gw}fzDe3M#PYccHkRO=SrN{e;1b$%#-UGWhTh?7?#9SK&sFD~O08{0 zxsE1_xEXqz(6;R*PL5_LX3eE&@$&z`(}!3DC5MEtopLFLBdTP6=?z$l zn9O;Kgpo{3y}a|C*&)gPr;$mV7?ACA? zZ@$efN%z?M%B5g~o`4v3GIMU0YOzhFsc}_h(y%FaWcL4J+5T_$cM+@PO$acraQH?x TIPmqKu?>)yR+g%R8i)K37K}5` literal 0 HcmV?d00001 diff --git a/tools/ui/src/assets/react.svg b/tools/ui/src/assets/react.svg new file mode 100644 index 000000000..6c87de9bb --- /dev/null +++ b/tools/ui/src/assets/react.svg @@ -0,0 +1 @@ + \ No newline at end of file diff --git a/tools/ui/src/assets/scroll.png b/tools/ui/src/assets/scroll.png new file mode 100644 index 0000000000000000000000000000000000000000..b61fe085b48a10bd8dd17fca7135e2157b086cb3 GIT binary patch literal 10195 zcmch6Wm6nX*Yx5p0fGbx1b2tvzR2Pb+!l9tcL`j$%MvWO!xEgu2_AyGI|PTo!jt<) zyl>Sx(;ug%>r_|wnK*S-c^u3Sm;e9(M^Qmm^B;!(uhCKeode?F@qd8fs-W)y0ALaR zuMq&b`J?~Hf+t&1zQqKpi+tGkP}oud^1;JZ?wWuvWiOf2@WaVrgq z4NV8RXue0M)|8G9B}!pnp~1jcilr%9ey;(0CntwYKKd;dDKRlL;k^bM_E*d$v^|>Q z#E6pEuRou+14#1XyARa4G6qD*zhW0DV*VSWN(QYyg)=Y!ov9IRIcb zN=xeth|B>H0k3sMuUPBw4_W>(mD42JPA4Q6W{A%2hNi2_LB%wsNWw}a07eAoN^u z<81yADuNp7^jb`RfoyAn_08)c-nt1-vK8>{ct!Wd^?%&R6(zSXFYoW|Eh!C38-jo8 z2EE$!oA&9#9iM_lUmotZdUoi-c#Om3ksr7ECvKI?D5g^}BF)zhlH_07u-;xM=ROT8 znz!q*5bbIZxFyQwCfx9peTtJ#Wgepc^=7%V$@YvSzR3@0uop)NNMWxqwm`ZEG2-ia z_U$|X0N0%^u-{DRNTIe7+tWU8mlAOKZ}fmrYsFMI0Ki0+jzjxrv&0BG03iD>$N16Rxy?=Kh~0%Ph5!$6iAMJEK)ti&Rif7PQ+L?_9KdZd9VAQQyXQIEwEX?y~u z@GEd@e$}S_qCj~q=8h;7V+8C-5g7&Wgug_0$#bWNHED?b#%`5quMqqY2`t8%vGnB5 zO(Oo5H{;&&K`cR_=y0am7H=gMy$>Cl8Gl+H%YIvTZCus5*ByGOo9b8U!OU@qxa`lz+Tr1{fciEJN#pKl-4Dw{{@ zOG&QgdPR};JN_gC>DnTwX1zvC1tFhTuFzxzu_CCfwm4(%gDr{egI)cRXUDts3@X*E z8Qovw$MQ#6M@Y9m*f`PeBSvCvn8@--(MWB`d`RoFmA{kC#gmO_a|v>vW*_F@<+yy& zV}Y^+zEAmynW2=ykU`GEsa;w1y=tQh>&wlTaqXl^6Rn^+;1^!4-Aat#nblva3e-=v z$hB-LMJi&dY${x|B}#+!;c=+?1IhzxGNl^d8clb*hN-bE$eMlGXdG~=qrJlT2N@bC zmjk_7Ido~js!OyyZO!CyCsE}3_j$-na{ zw{u$=IaFn4W$INcRBKerpLPq>otGDU@0RP-e-6Wy8c||2VwAT@nnEc!)LPbBFUKq= zRuL1vtK+D0C?hZGl=bO#F2Bfz^q7P~lwHa<{JIbSQUr0rwc$>G%kSi|^-!C!=}=d( zr$|MI_}yGYDLF@0uQX(g2P9?6z!~7I?Z}k&S<#Yt;D1281iN9QUAkSTVW;5|22=(b z29U~$%0;fGO8a-_?;^?~$|I8#lf{z@IsAEI+>1Pid53w6d7Eu!2EGPt&I4k}+nAHsv<=k_T%>iU1$6}d2Ny%biCM<2rZk`o_Gob@64nvk$eqf+kO&&O%{=C` z(VNDfUgF(_5{@$u+7)Q!&B@!4*tB~@+{DJmfx^c*vcx&^$cNWQyZ4kl@7#>H{eRsR z(=8`{czsvf|XB;xnt?uEPJyP|>{JRAC^6M}thqiy4A11=ELs7;v=+BeHL|F>B{ zc_=-C4N_c~RG1;+^P_(tO>d%v@T%2))AG4g!nby*_fkpWwc-1)S{mEYv*cQuhr{ft zlqoyhDD~i@g&8#P0XTjj7@ILFCQ3J2BGENg@53y27QfHznvBP$>|fbT*^N9KZZ)BL zb|rom@hT2`(G|fCz7C0D4r~31dA$NXMMn^Y5C==0fU{%I=F9m_%uc}$)@}evHs`3Z zt6$Mn|7}z`aU}-L*hIq@^_S+*FE0epFag^8dgdxPa-qcP!V#3|r5veK3ZqijWDrr!g z6Pp8T@9`R|sHWE;=lC{GstmL-hvwuO6n%C~sPy+EZ3Cu77PKZCD_!f}$+(|Fnbi>1 z$@7WkpR37&`Im)n=LG!(+o{m9Xpk;DrQShzjlEElsGHv^=I(nG)@U8n8qptLp)5}G zYSrhuS#`nP4E`z(VJ5Jj;jmT&hf}OCnEO#dr)!Jn#%g+;`kSrbztIKc;_u_W))B3e zWW5hrVp{XvCy#OY*_*SL-cngT*lsy({mc6JV1pfEh?`lJb&!SYjI+Gbg0rd9a(;I& zx5}9{$+X%T0hMVl=@tFaWmP^lH7O#YU8;Sn{a0Jy;@5gBc=6GB_JTa1>z?mye$}w+ z0WLn)v-$<$i^{z9yw$VfbMu2lU0l`iW9GAyajmM8+xZC6FC;h`EiQDi{r5cOFEMS+ zqy^SfdEAkYJ+B3qKI}LGIA8wDAKsyLmG#>@e!$p#pu!Pe@lFV+*+!fD=uK%u$!Ra0 zdz}l+)5?7|G&k%}n-HH}IN9)jkzf6Ym(M4v@27O5J!ZFZ96pz3b3L68`F*!tVYW=p`?~3?sVICqRw%&c?@A5G8aJNak9_-EtpBnF6 z_F=rJ?NaM9y_GzdT9#RlnU^qpU0b?b3$gF>`F1nACjWpM6*2vqa+icBgOZe!G#-r; zeG2(3E+n)g;SN83DVLeHoMwQKycWNX*O3r&20zZ9E>6v6&lY7}XQlNz1(v~2`cBE} zSBLwDsd~nIdAUt)b)L^*K5IUdmnEBcYI}jyAxv+!PmOn4Gv&`|WNB${$Vk~YFBZJ) ztN;8awS|JF3IO0w|Idd;002*K|L_<9@ZtghPRsxR;cNha#3j{q2nYaByei5{Y5T66 z75Jqa%Ljeyt?KN4h6aN!s|`9W$3=#hnqaJ-BiZp&-Slvg#wZTxTvL5fV+ZIQa~!$C zxW<$TbVjxSF+t(_l#UT3?3tDhS!)IzWjgisoty4$Rk;!-hM8o_q~S$!7d}&Bn zro@t@wV1SOt}bhIPeA@ndsY|w`z=N(fV6GGJ0>fxl_e#Mok1oV307yGknj$k}Ep4DDj|IN^HXg7@^H_-e-g{Jzoj z8p!Cnz#P1 zjV^e2R1mC)M}3D68FaTeII|Kwh%AaIk7KD_9>@*I&Q^~hpz)6L?^&Baml~PZOX-@N zk!lI?2_hvq-V#y>z#>1$KH6cs&6Mir$yqnKRNOxp3kiRCQ)=#cP%oBzNoVI8-m<0; zFb+o9he=fwsG>Z^i3F|S>=6e*@Yaa)g_P?rd427^43CK#uyUbFg~Nd8aZ!>*(@JK3 z!OsB+Me{YhBHZ3mHq$c&-EiJTP7XG{GAp>Jnjve)Ga9pQHNKo3?w_>cs6Nt&!==wr zb&ImijQEC)^|5!|F;nn>i5WNGtA03C4?dzckFC>cf?l|+M{D_eVzAwyeoiAAgi zcV6&$vO7zQqn1@A+48Hal~hI)etv=yWpv*lSM77k5! z>pvqL9FklaPmodw+g(Af7}I-w%y~Un^iK{CHeokBks}YG`=U8P;1+!dH=>f5hn7z79nvZ zKq9KKWdR*wC_Jf<(=mbY91|hH=gj~eqc;s;W%O`Pj>oCh5jDR||fkqCX8y0ou9 zl)x4geoD=~M4F)UyIggKyJfrk?rGU&SSm>KrSFG20D9gOw8@S8UjeLXZ!WbbkYi3& zHUuG=6$FqIKh$K|AKk|ii^`X`X;tu1i^{pO2z*8QD0^oTZd_BmTLI6PMCUT|43DEt zP)Z&KATrZyDnzEEmy7YZ!r6rF@dZg@s)MRG&h-cuZ(P^QaXHh#s~6nRbE*LkCyG`7 z6|f=kA-uMi0A=PUJ~BpT%O9ii^gH9PD1}q@VfMOFW3&NJJDb7C+_w~6<|rlRkibo; z00Kn|?MQA6P0~o)7LGW&hLsdaVUDB7;aj)s`7pecqgIAQDP}gO?7Yf%Lt}H&Z=5Ww zXZipjI_%c-zY@Y)c%8$XuJ@=ft~9!Gd%-28-(IjdA$`{gyUXyy1Ae|RvKoU2A{{0X zsU3cc4V;apuQB@IH6jPM{A@@!ejIlwUH&nRg@HmC9r>2-{*-)99Oy;U zF%Sz?B#>*(-~YmCBpBex|cL>8tOB;|g>7 zB5ZGjz-%K@&I9{0321O)5+QqAb+p-ObJyV`mZw<50@76{EQ);A*Xv{b7+Y# zg$utvNi5K5gW5nV%BZJwD>~ zo{EKp>`f)X?J4AvG5>gEgyt-x*44J(oxHZ;-tKJ%?fecG5AJ|z()Kse2M?E(B$st| zDi3qN%oV~hI-!(9-GBTe xfuVi-5dP6v6u-NUDv|8xCj2D;jdzH(L~iBx6DLj+sS1sSx!VWL z#blMF1Wq+iMl~ymnD>l(uG>N;eR^(<*RY)Fn%qTSkH8#QG6qx$mX49!t5l}2a(*ljqGnb>q$;J>0v-8Y{)DravV>MsYqY7$-U@H!fKtMGK#N`Jj%b@ z4WtHHO@2K6+cE9n;GGM%KF>6IGqthBU3L=1i)SdMKp?mmZ!haFH;fYFzPvKQ=2U4{ zdKoybyts)2rUir(_rr~22XyqGCV6TiR_sp8h zPmz-75y`3DcpD>2P_*`i$zKZA$CDYp6Tf|jgeSX4h{&t3Jgs>}`K;Wi-Su6Km4Vce zeZ0BKtd`W+dW>XbUNz4T_BY?PqB}DL=rj<)T}J7tiHN}hDS+7Y;tlj4u3qhpZeNaT zpK;ZkLSD9h$1Emlf0YT6dr64+2H#@*wWTsaNaCLEG}P1gCx4rv^MFM=a(F!b@uvHO z2J`HEPRXXvs5OP-2+&S_m}?O`Cl_Mz1DZ|Fb+U_=dbHHhiiC%Q<7rNifr}J!PtbDN z24wATWCx;wd^(^@J}akmGl0CSuocZ$4WsZ}*=A zzS=*4UwUu_YLBh%Yz5~viMedI30Q5}`0dy@G%i^Q2EUn)ud<~2h+eikm}I)Kx6J<2 zg+*I@Mq4LYUHY~X&7b0Le;S|gE=725PH;-zi%tU(*})Bl?8I>F_kv(^VVUxVr`IsX zhAKafZnNy_Hs@mXpHlf|=Kp1K7%WvVeV@1G5#f)(%}ocP2zNZ2o_K0g&9b~Wf{F6+);%!A{AoE%%7D0CIuVu<{1^4vRh>3QwY!gzGWVswL)i}MM%UHevd;AYX-RT(f8AKw9{EoRvW<~BvMFeG{& z*N)f!x=(Oh6ZMlR)>|kC9~CR2MYeNEdqpo8w^Mz1YA@D)ZbIT7fQ9B$-`I6+s@-PP z+vc(B@y4*I(KBHiHEXAFG+hQ#Uol%vm4?AP3L8xu-{LCk?P~)ZX<`$;FA&iggrzGh z&yRZPGU2+I` z|LhV&EVopGGf=ktAdcYxJxNtVCx+~B@SH8VTm@tnJAywlnbci2xku27z96PCukr5N6tM65$TZ| zHDUwNmLW7hOUP&DH8PdR-EORMZ4$L4yc}f+PVsO}yx|e^MXkMIN|v3f+xZssax)o3 zRaCxX!_5VqxU>nVhNK+uvN_9umHD>a7!XBp1^M(Z(UsVvsU0f?2w zM@ZKhEN%t5oxmbb2K0&DtY|J&85o>GI4sYFBAZW_y0 zihv${vAp3#h;ErC@%)u)#9N|2XPE&{{6`)uAZG~?>O@0KYJmM%hw zV0$5h?mNvPN12--k5HSh0Gr8lf|ZO7Cr=R*eTHZz;OB4VDE;_ss6+=Jn3!$-1qz^Y z;!57cM$cF=(sw`gt^R~!H51dzQwL?$g->5y3B8^~_}rj{JOaOx$yJ*Scz5qp&(wWd zi2LN+I*MDz*nDga4LJp0y!E4zhU{P%OrkdO{FWJ8{|F}nm%38KL+S{0O}sGbeFv&Z zm%Hxy*}Ng&eg}+vohZ`LME>y>!$SRzQ(G_b zvakw4tE-XE(+!RyX)@)C?C&6&!pAwh#@*Lv<~<`vkXb^%J({mUiaA)3`wJ*rpXYOA z&BguWbnk;OwCCCi9Qb#y6&STDx#jF<@c|*&U_cUM5J=Mc&f$}VfVHELC209e3n`PZ z>NIPB*kw^!Xq2|~7}W9TU>0uiG9Pns@DTDKkeb67ORnO$I?NPh zdQM;Acp&Byj27c_UfSD+&GeEW@1ho^#0?tu=_3uNKA4ywSbdmmcq`o+Z8->ed15?b z^54je*X`xZ5ps)f&{?2wdwooL^Bu~chzog{!J{O-tnlB!DzF*{A_zA zReH)|1Y$9<_`xV(z-yu~hZ+-!O)#R(pY<|m+kWmbocEb}<7_PUW&pRBJN@{XK0mAoF? zrnnE5oRj-T9SPgTIO~C@t9Wzkb7LTv?r@7F35Ag@Yw^3W`kPUok6YpMa-zBoR&)4u zg}Yb}R8~8;pTMPdKs9GGt3MR5C|=$M8!->5XGdxKL4L{Jvaqqn&OtuunGojM*U7EACvi zeaz>>hvd<#^kK+F*+aq^O!vd108&~uK%Df zg_uvG1w%zZye+0sIk`7%$~Za=mg{c37~*4pPhlr#_^=R>)Y`J-64~XXp_mJtxm+1U zHAf=Z>yDN_3Qryo8*YGZ3UxKi_^&_QPfQ)Sll==dUy$T<@G>8N7nqujKnVX4yBeFz zkJ&TyM>5K&ag^jz?5iq4bcYetWMv?}j%?>C%d4qw`g=9CYbmVB$(yRGv4N<;&WntB z>+w-^(z?33=l4>wDl+_S?J=`RyueNEjHTOSXLd?{H|`AWSgG5*5b(rRu zShS>9p!M@-!eg~1%{5!D#|5ptDdZJC7$4&~X8$;lSzYU`LeKVZdEXX)J|#Tttr{=Rjo&*aIcm#ns6EU=60>*<9E^D=jt{_p5A z^*MAxe~<92`g`AF1$|*_jmrxDvv`pg9~|F>&#p7*+1Nxj{iW2Aqx#Y<2hwui$x1N8 z|3kWNMoU_Z{wnkUC#h#orTbd6@yP>(u}oK-->lbKRp{8BC1cTf#Iho41LDLJ6CV!} zDQ{qpvl)<_H}@?4Ik|{^)5!UeVK%%yDwLIDLUUqy&`r6S>=VA~2LuR086=oA!qa^$ zCd=GoedGb_f=t)*ky!V^%6C>F^YGp(2aiqshewzg<>_OFp>sMM8fOH19|!Igc!}mj znQJVrYcJkYDB2pNN68YWRv@aY)t{pk|1-LAjQ26mQL}b$)RF@D7c=4B3P!r%tT(P~ zT)dkMqbiiex~Ir4YPOv-O(kkhZKt1n@J^Up%%LyzQY0FT8}?uiRNGOIDS0|1QEk7Wp& z4t^<+^AVn%O*8;S<_g~WE*L|IeiH<(MkRuVGCQT6j!+K5{H&O)>8m>iFC}gt&#H{R zKW9~EuqoM{;3}i4REde5`5iGqBNMwoC1kWwMfFUh)^u3^MFNq*rK#8p1&Z5p>Avs--@ zBAnq$zGKtD^O0SSzA@Zf<$azOG+p*kEK8RomnlmhcxaxO;z*s;)6--b3} zgG8C2w$OfEEdKov(H`^;f>Kb14X#MGWhrBW(yJ|J{!g389`CnzmdV6Hxra_{CwEB@ zjdY$=T-{H$mpIuTl(~uuw3?R2169R9+U&17aL_;tQ7R6_Y5Zowm`@^T4{Z%qsPZc7mM#IapV3$OlOd$paPg}IavP!$~7PEVE=V6n4=H` zcx*Cxh0i!EH?FNua3U+K&g)4mJv}y7?zJT*EK0OFbLlb>^Bh$ua%5Rm=FDJPEYwVC zuzY6YBlv_Yg2#5flp+iYV@SZU+H_t1OHg1{IC2l^b7Mn&9;coN%4Em;ml2XOUh{BJ z#)scW%gSUkea*lmTm1fxIbFa=58B90q0h6&gQ#mu+#jhP8^f4@5f6Qlv6whm$|g_e zHVwYU6KDbT4lM`DeB5v{c6a-#c{T(ysH(Okw(+;HMRxL<6klrwyj(xR5fx{I}Zg|8;6RK@zau3k$(vZrRRD!^)BXHY&Doi+)c(ijsq5jM(Nwqjwe=&YGc*JTE3q);`dqEW zd?7b`bs_yvv%mvH@$n#X=cxF5?)$Z0hwe^O=Bnhlw(u;}3xe_5%1pu@5AtVuwj+K( zCjHQkd3;cenwz;faAGktHUF}!2RhSr`Zy+Zx@hYDZogQ**3MRzOT2ybA}H-_BP3c& z%gcP8<4YUc*tm0dWD)E{ER+5NhYr%ohP0R|CrW(>?)gnidk?%IQuw@gN2|Z!^$=2W(GYM=BR6TH}?3^ zyQ{*eHlLU!!qfYZxoDd5^myp)X5E2n@QMDhE{fYspNmKDAeVKK_p>@YRrBPIY+Aq3 zFt&b)W9y6(>sPqMS>)RB#1O)TXF6JLg3wu(;I_S5x3ve9aQW-c4j->y} zi-B)D(DvqqFoi>Po`I-zns6D5C3u%BJyiysX#!Ecwq}{MoU}q5Oj%1uv1GNFdA;o2 zU&)~sA^tyl-KjOsvsP*>5vKC?w~6zSU*q;WH}iQd0|l&Urcxx8K)*1}gFGFT*f?c$ zTZjI3mopw-o-WD_uME|3hhq-V(e#AH3lLq(=?Z VJ`?TD{`)lrD9WkI)=8U%{~v@Jf5rd+ literal 0 HcmV?d00001 diff --git a/tools/ui/src/components/Inventory.tsx b/tools/ui/src/components/Inventory.tsx new file mode 100644 index 000000000..53dea99b3 --- /dev/null +++ b/tools/ui/src/components/Inventory.tsx @@ -0,0 +1,49 @@ +import { stringifyAmountValue } from '@agoric/ui-components'; + +type InventoryProps = { + address: string; + istPurse: Purse; + itemsPurse: Purse; +}; + +const Inventory = ({ address, istPurse, itemsPurse }: InventoryProps) => ( +
+

My Wallet

+
+
+ + {address} + +
+ +
+
+ IST: + {stringifyAmountValue( + istPurse.currentAmount, + istPurse.displayInfo.assetKind, + istPurse.displayInfo.decimalPlaces, + )} +
+
+ Items: + {itemsPurse ? ( +
    + {(itemsPurse.currentAmount.value as CopyBag).payload.map( + ([name, number]) => ( +
  • + {String(number)} {name} +
  • + ), + )} +
+ ) : ( + 'None' + )} +
+
+
+
+); + +export { Inventory }; diff --git a/tools/ui/src/components/Logos.tsx b/tools/ui/src/components/Logos.tsx new file mode 100644 index 000000000..13e9e5c85 --- /dev/null +++ b/tools/ui/src/components/Logos.tsx @@ -0,0 +1,19 @@ +import reactLogo from '../assets/react.svg'; +import viteLogo from '/vite.svg'; +import agoricLogo from '/agoric.svg'; + +const Logos = () => ( + +); + +export { Logos }; diff --git a/tools/ui/src/components/Trade.tsx b/tools/ui/src/components/Trade.tsx new file mode 100644 index 000000000..9ce8b8751 --- /dev/null +++ b/tools/ui/src/components/Trade.tsx @@ -0,0 +1,141 @@ +import { FormEvent, useState } from 'react'; +import { stringifyAmountValue } from '@agoric/ui-components'; +import scrollIcon from '../assets/scroll.png'; +import istIcon from '../assets/IST.svg'; +import mapIcon from '../assets/map.png'; +import potionIcon from '../assets/potionBlue.png'; + +const { entries, values } = Object; +const sum = (xs: bigint[]) => xs.reduce((acc, next) => acc + next, 0n); + +const terms = { + price: 250000n, + maxItems: 3n, +}; +const nameToIcon = { + scroll: scrollIcon, + map: mapIcon, + potion: potionIcon, +} as const; +type ItemName = keyof typeof nameToIcon; +type ItemChoices = Partial>; + +const parseValue = (numeral: string, purse: Purse): bigint => { + const { decimalPlaces } = purse.displayInfo; + const num = Number(numeral) * 10 ** decimalPlaces; + return BigInt(num); +}; + +const Item = ({ + icon, + coinIcon, + label, + value, + onChange, + inputClassName, + inputStep, +}: { + icon?: string; + coinIcon?: string; + label: string; + value: number | string; + onChange: React.ChangeEventHandler; + inputClassName: string; + inputStep?: string; +}) => ( +
+ + {icon && } + {coinIcon && } + +
+); + +type TradeProps = { + makeOffer: (giveValue: bigint, wantChoices: Record) => void; + istPurse: Purse; + walletConnected: boolean; +}; + +// TODO: IST displayInfo is available in vbankAsset or boardAux +const Trade = ({ makeOffer, istPurse, walletConnected }: TradeProps) => { + const [giveValue, setGiveValue] = useState(terms.price); + const [choices, setChoices] = useState({ map: 1n, scroll: 2n }); + const changeChoice = (ev: FormEvent) => { + if (!ev.target) return; + const elt = ev.target as HTMLInputElement; + const title = elt.title as ItemName; + if (!title) return; + const qty = BigInt(elt.value); + // eslint-disable-next-line @typescript-eslint/no-unused-vars + const { [title]: _old, ...rest }: ItemChoices = choices; + const newChoices = qty > 0 ? { ...rest, [title]: qty } : rest; + setChoices(newChoices); + }; + + return ( + <> +
+

Want: Choose up to 3 items

+
+ {entries(nameToIcon).map(([title, icon]) => ( + + ))} +
+
+
+

Give: Offer at least 0.25 IST

+
+ + setGiveValue(parseValue(ev?.target?.value, istPurse)) + } + inputClassName={giveValue >= terms.price ? 'ok' : 'error'} + inputStep="0.01" + /> +
+
+
+ {walletConnected && ( + + )} +
+ + ); +}; + +export { Trade }; diff --git a/tools/ui/src/index.css b/tools/ui/src/index.css new file mode 100644 index 000000000..d3f626a88 --- /dev/null +++ b/tools/ui/src/index.css @@ -0,0 +1,72 @@ +:root { + font-family: Inter, system-ui, Avenir, Helvetica, Arial, sans-serif; + line-height: 1.5; + font-weight: 400; + + color-scheme: light dark; + color: rgba(255, 255, 255, 0.87); + background-color: #242424; + + font-synthesis: none; + text-rendering: optimizeLegibility; + -webkit-font-smoothing: antialiased; + -moz-osx-font-smoothing: grayscale; + -webkit-text-size-adjust: 100%; +} + +a { + font-weight: 500; + color: #646cff; + text-decoration: inherit; +} +a:hover { + color: #535bf2; +} + +body { + margin: 0; + display: flex; + min-width: 320px; + min-height: 100vh; +} + +h1 { + line-height: 1.1; +} + +button { + border-radius: 8px; + border: 4px solid transparent; + padding: 12px 16px; + margin: 8px 2px; + font-size: 1em; + font-weight: 500; + font-family: inherit; + background-color: #1a1a1a; + cursor: pointer; + transition: border-color 0.25s; +} +button:hover { + background: #171717; +} +button:focus, +button:focus-visible { + outline: 4px auto -webkit-focus-ring-color; +} + +@media (prefers-color-scheme: light) { + :root { + color: #213547; + background-color: #ffffff; + } + a:hover { + color: #747bff; + } + button { + background-color: #04aa6d; /* Green */ + color: #fff; + } + button:hover { + background: #039962; + } +} diff --git a/tools/ui/src/index.d.ts b/tools/ui/src/index.d.ts new file mode 100644 index 000000000..d2ee4b35d --- /dev/null +++ b/tools/ui/src/index.d.ts @@ -0,0 +1,16 @@ +interface CopyBag { + payload: Array<[T, bigint]>; +} + +interface Purse { + brand: unknown; + brandPetname: string; + currentAmount: { + brand: unknown; + value: bigint | CopyBag; + }; + displayInfo: { + decimalPlaces: number; + assetKind: unknown; + }; +} diff --git a/tools/ui/src/installSesLockdown.ts b/tools/ui/src/installSesLockdown.ts new file mode 100644 index 000000000..2eb8e6e6b --- /dev/null +++ b/tools/ui/src/installSesLockdown.ts @@ -0,0 +1,13 @@ +import 'ses'; // adds lockdown, harden, and Compartment +import '@endo/eventual-send/shim.js'; // adds support needed by E + +const consoleTaming = import.meta.env.DEV ? 'unsafe' : 'safe'; + +// @ts-expect-error global +lockdown({ + errorTaming: 'unsafe', + overrideTaming: 'severe', + consoleTaming, +}); + +Error.stackTraceLimit = Infinity; diff --git a/tools/ui/src/main.tsx b/tools/ui/src/main.tsx new file mode 100644 index 000000000..bfb9f34e7 --- /dev/null +++ b/tools/ui/src/main.tsx @@ -0,0 +1,11 @@ +import './installSesLockdown.ts'; +import React from 'react'; +import ReactDOM from 'react-dom/client'; +import App from './App.tsx'; +import './index.css'; + +ReactDOM.createRoot(document.getElementById('root')!).render( + + + , +); diff --git a/tools/ui/src/vite-env.d.ts b/tools/ui/src/vite-env.d.ts new file mode 100644 index 000000000..11686fc78 --- /dev/null +++ b/tools/ui/src/vite-env.d.ts @@ -0,0 +1,9 @@ +/// + +declare module '@agoric/ui-components' { + export const stringifyAmountValue; +} + +declare module '@agoric/store' { + export const makeCopyBag; +} diff --git a/tools/ui/test/App.e2e.ts b/tools/ui/test/App.e2e.ts new file mode 100644 index 000000000..5e7ca1cd5 --- /dev/null +++ b/tools/ui/test/App.e2e.ts @@ -0,0 +1,28 @@ +import puppeteer from 'puppeteer'; +import { execSync, spawn } from 'node:child_process'; + +describe('Puppeteer E2E test', () => { + it('should load the webpage', async () => { + execSync('yarn build'); + const previewServer = spawn('yarn', ['preview'], { + detached: true, + stdio: 'ignore', + }); + // delay for preview server to start + await new Promise(resolve => setTimeout(resolve, 2000)); + + try { + const browser = await puppeteer.launch(); + const page = await browser.newPage(); + await page.goto('http://localhost:4173'); + + const buttonText = await page.$eval('button', el => el.textContent); + expect(buttonText).toBe('Connect Wallet'); + + await browser.close(); + previewServer.kill(); + } catch (_) { + previewServer.kill(); + } + }); +}); diff --git a/tools/ui/tsconfig.json b/tools/ui/tsconfig.json new file mode 100644 index 000000000..7f545954a --- /dev/null +++ b/tools/ui/tsconfig.json @@ -0,0 +1,27 @@ +{ + "compilerOptions": { + "target": "ES2020", + "useDefineForClassFields": true, + "lib": ["ES2020", "DOM", "DOM.Iterable"], + "module": "ESNext", + "skipLibCheck": true, + + /* Bundler mode */ + "moduleResolution": "bundler", + "allowImportingTsExtensions": true, + "resolveJsonModule": true, + "isolatedModules": true, + "noEmit": true, + "jsx": "react-jsx", + + /* Linting */ + "strict": true, + "noUnusedLocals": true, + "noUnusedParameters": true, + "noFallthroughCasesInSwitch": true, + + "types": ["vitest/globals"], + }, + "include": ["src", "test"], + "references": [{ "path": "./tsconfig.node.json" }], +} diff --git a/tools/ui/tsconfig.node.json b/tools/ui/tsconfig.node.json new file mode 100644 index 000000000..42872c59f --- /dev/null +++ b/tools/ui/tsconfig.node.json @@ -0,0 +1,10 @@ +{ + "compilerOptions": { + "composite": true, + "skipLibCheck": true, + "module": "ESNext", + "moduleResolution": "bundler", + "allowSyntheticDefaultImports": true + }, + "include": ["vite.config.ts"] +} diff --git a/tools/ui/vite.config.ts b/tools/ui/vite.config.ts new file mode 100644 index 000000000..7fa039ff7 --- /dev/null +++ b/tools/ui/vite.config.ts @@ -0,0 +1,19 @@ +/// + +import { defineConfig } from 'vite'; +import react from '@vitejs/plugin-react'; + +// https://vitejs.dev/config/ +export default defineConfig({ + plugins: [react()], + test: { + globals: true, + environment: 'happy-dom', + testTimeout: 20000, // 20 seconds for puppeteer CI + // modified import('vitest/dist/config.js').defaultInclude + include: '**/*.{spec,e2e}.?(c|m)[jt]s?(x)', + }, + server: { + port: 3000, + }, +}); From fcbd07f6c0331d2e63506eb1b1d7056c038e90d6 Mon Sep 17 00:00:00 2001 From: frazarshad Date: Mon, 4 Mar 2024 01:35:47 -0800 Subject: [PATCH 18/35] Updates to CI/CD to use Agoric chain and Offer up DApp (#4) * feat(ci): Included ui/ and contract/ from offer-up-dapp (with changes) * feat(ci): Updated CI to use agoric chain + offer up dapp * fix(ci): updated scripts in package.json * refactor(ci): Moved ui/ and contract/ to tools/ * refactor: moved json-server-db.json to tools folder --- .../{ => disabled}/audit_and_lint.yml | 0 .github/workflows/{ => disabled}/codeql.yml | 0 .../{ => disabled}/e2e_cypress-action.yml | 0 .../workflows/{ => disabled}/e2e_docker.yml | 0 .../workflows/{ => disabled}/e2e_headful.yml | 0 .github/workflows/{ => disabled}/release.yml | 0 .github/workflows/e2e_debug.yml | 16 +- Dockerfile | 6 +- docker-compose.yml | 38 +- package.json | 17 +- pnpm-lock.yaml | 9396 ++++++++++++----- pnpm-workspace.yaml | 2 + start-tests.sh | 2 +- tools/json-server-db.json | 13 + 14 files changed, 6989 insertions(+), 2501 deletions(-) rename .github/workflows/{ => disabled}/audit_and_lint.yml (100%) rename .github/workflows/{ => disabled}/codeql.yml (100%) rename .github/workflows/{ => disabled}/e2e_cypress-action.yml (100%) rename .github/workflows/{ => disabled}/e2e_docker.yml (100%) rename .github/workflows/{ => disabled}/e2e_headful.yml (100%) rename .github/workflows/{ => disabled}/release.yml (100%) create mode 100644 pnpm-workspace.yaml create mode 100644 tools/json-server-db.json diff --git a/.github/workflows/audit_and_lint.yml b/.github/workflows/disabled/audit_and_lint.yml similarity index 100% rename from .github/workflows/audit_and_lint.yml rename to .github/workflows/disabled/audit_and_lint.yml diff --git a/.github/workflows/codeql.yml b/.github/workflows/disabled/codeql.yml similarity index 100% rename from .github/workflows/codeql.yml rename to .github/workflows/disabled/codeql.yml diff --git a/.github/workflows/e2e_cypress-action.yml b/.github/workflows/disabled/e2e_cypress-action.yml similarity index 100% rename from .github/workflows/e2e_cypress-action.yml rename to .github/workflows/disabled/e2e_cypress-action.yml diff --git a/.github/workflows/e2e_docker.yml b/.github/workflows/disabled/e2e_docker.yml similarity index 100% rename from .github/workflows/e2e_docker.yml rename to .github/workflows/disabled/e2e_docker.yml diff --git a/.github/workflows/e2e_headful.yml b/.github/workflows/disabled/e2e_headful.yml similarity index 100% rename from .github/workflows/e2e_headful.yml rename to .github/workflows/disabled/e2e_headful.yml diff --git a/.github/workflows/release.yml b/.github/workflows/disabled/release.yml similarity index 100% rename from .github/workflows/release.yml rename to .github/workflows/disabled/release.yml diff --git a/.github/workflows/e2e_debug.yml b/.github/workflows/e2e_debug.yml index bf87fe882..5d0ac623b 100644 --- a/.github/workflows/e2e_debug.yml +++ b/.github/workflows/e2e_debug.yml @@ -1,9 +1,6 @@ name: E2E (debug) -on: - push: - pull_request: - branches: [master, dev] +on: [push, pull_request] concurrency: group: @@ -13,9 +10,6 @@ concurrency: jobs: e2e: - if: - github.ref == 'refs/heads/master' || github.ref == 'refs/heads/dev' || - github.event_name == 'pull_request' runs-on: ubuntu-latest steps: @@ -24,6 +18,8 @@ jobs: - name: Install pnpm uses: pnpm/action-setup@d882d12c64e032187b2edb46d3a0d003b7a43598 # pin@v2.4.0 + with: + version: 8.15.3 - name: Setup node uses: actions/setup-node@5e21ff4d9bc1a8cf6de233a3057d20ec6b3fb69d # pin@v3.8.1 @@ -32,9 +28,7 @@ jobs: - name: Run anvil run: | - docker-compose -f docker-compose.ci.yml --profile foundry up --build --detach - env: - ANVIL_FORK_URL: ${{ secrets.ANVIL_FORK_URL }} + docker-compose -f docker-compose.yml --profile synpress up --build --detach - name: Set pnpm cache directory run: pnpm config set store-dir .pnpm-store @@ -79,7 +73,7 @@ jobs: echo -n "======> remote noVNC URL: " sleep 5 curl -s localhost:4040/api/tunnels | jq -r .tunnels[0].public_url - pnpm test:e2e:anvil + pnpm test:e2e:keplr env: NGROK_AUTH: ${{ secrets.NGROK_AUTH }} NGROK_BASIC_AUTH: ${{ secrets.NGROK_BASIC_AUTH }} diff --git a/Dockerfile b/Dockerfile index fc501b82d..1a14eca99 100644 --- a/Dockerfile +++ b/Dockerfile @@ -8,11 +8,7 @@ RUN apt update && apt install -y nginx COPY nginx.conf /etc/nginx/sites-available/default -COPY package.json ./ -COPY pnpm-lock.yaml ./ - -FROM base as test +COPY . . RUN pnpm install --frozen-lockfile --prefer-offline -COPY . . diff --git a/docker-compose.yml b/docker-compose.yml index 82c798060..7ad20b38d 100644 --- a/docker-compose.yml +++ b/docker-compose.yml @@ -15,13 +15,14 @@ services: depends_on: - display - video + - agd entrypoint: [] working_dir: /app volumes: - ./docker/videos:/app/tests/e2e/videos - ./docker/screenshots:/app/tests/e2e/screenshots command: > - bash -c 'echo -n "======> local noVNC URL: http://localhost:8080/vnc.html?autoconnect=true " && pnpm wait-on http://display:8080 && echo -n "======> remote noVNC URL: " && curl -s ngrok:4040/api/tunnels | jq -r .tunnels[0].public_url && nginx && pnpm test:e2e:anvil' + bash -c 'echo -n "======> local noVNC URL: http://localhost:8080/vnc.html?autoconnect=true " && echo -n "======> remote noVNC URL: " && curl -s ngrok:4040/api/tunnels | jq -r .tunnels[0].public_url && VITE_RUN_ENV=agoric_chain pnpm test:e2e:keplr' networks: - x11 @@ -71,32 +72,25 @@ services: networks: - x11 - foundry: + agd: profiles: - - foundry - container_name: foundry - image: synthetixio/foundry:457bb48776c3b14de232d9dda620ba9188dc40ac-base - command: [ 'anvil --no-cors --fork-url ${ANVIL_FORK_URL}' ] - environment: - - ANVIL_IP_ADDR=0.0.0.0 + - synpress + container_name: agoric_chain + image: frazarshad/offerup-test-chain:1.0.0 + platform: linux/amd64 ports: - - '8545:8545' - networks: - - x11 - - foundry-metamask-test-dapp: - profiles: - - foundry - container_name: foundry-metamask-test-dapp - image: synthetixio/foundry:457bb48776c3b14de232d9dda620ba9188dc40ac-base - # Port and chain id as required by the MetaMask Test Dapp - command: [ 'anvil --no-cors --port 8546 --chain-id 1338' ] + - 26656:26656 + - 26657:26657 + - 1317:1317 environment: - - ANVIL_IP_ADDR=0.0.0.0 - ports: - - '8546:8546' + DEST: 1 + DEBUG: "SwingSet:ls,SwingSet:vat" + volumes: + - ./tools/contract:/workspace + entrypoint: /workspace/scripts/run-chain.sh networks: - x11 + networks: x11: diff --git a/package.json b/package.json index 8a1fcb023..4d39cd6f3 100644 --- a/package.json +++ b/package.json @@ -1,7 +1,6 @@ { "name": "@synthetixio/synpress", "version": "3.7.2-beta.9", - "packageManager": "pnpm@8.4.0", "description": "Synpress is e2e testing framework based around Cypress.io & playwright with included MetaMask support. Test your dapps with ease.", "keywords": [ "Synpress", @@ -41,16 +40,20 @@ "release:patch": "release-it patch --disable-metrics", "update:deps": "ncu -u -x 'node-fetch' && pnpm install", "start:server": "serve node_modules/@metamask/test-dapp/dist -p 3000", + "start:contract": "cd tools/contract && pnpm start", + "start:ui": "cd tools/ui && pnpm dev", + "start:json-server": "json-server tools/json-server-db.json --port 3004", "synpress:run:metamask": "EXTENSION=metamask SKIP_EXTENSION_SETUP=true SYNPRESS_LOCAL_TEST=true node synpress.js run --configFile=synpress.config.js", - "test:e2e:metamask": "start-server-and-test 'turbo start:server' http-get://localhost:3000 'pnpm synpress:run:metamask'", + "test:e2e:metamask": "start-server-and-test 'pnpm start:server' http-get://localhost:3000 'pnpm synpress:run:metamask'", "test:e2e:anvil": "start-server-and-test 'turbo start:server' http-get://localhost:3000 'CYPRESS_USE_ANVIL=true pnpm synpress:run'", "test:e2e:headless": "start-server-and-test 'turbo start:server' http-get://localhost:3000 'pnpm synpress:run --headless'", "test:e2e:headless:anvil": "start-server-and-test 'turbo start:server' http-get://localhost:3000 'CYPRESS_USE_ANVIL=true pnpm synpress:run --headless'", - "test:e2e:ci": "start-server-and-test 'turbo start:server' http-get://localhost:3000 'pnpm synpress:run --record --group'", + "test:e2e:ci": "start-server-and-test 'VITE_LOCAL_ENV=agoric_chain pnpm start:ui' http-get://localhost:3000 'pnpm start:json-server' http-get://localhost:3004 'pnpm synpress:run --record --group'", "test:e2e:ci:anvil": "start-server-and-test 'turbo start:server' http-get://localhost:3000 'CYPRESS_USE_ANVIL=true pnpm synpress:run --record --group'", "test:e2e:ci:cypress-action": "CYPRESS_USE_ANVIL=true pnpm synpress:run", "synpress:run:keplr": "EXTENSION=keplr SKIP_EXTENSION_SETUP=true SYNPRESS_LOCAL_TEST=true node synpress.js run --configFile=synpress.config.js", - "test:e2e:keplr": "start-server-and-test 'turbo start:server' http-get://localhost:3000 'pnpm synpress:run:keplr'" + "test:e2e:keplr": "start-server-and-test 'pnpm start:ui' http-get://localhost:3000 'pnpm start:json-server' http-get://localhost:3004 'pnpm synpress:run:keplr'" + }, "dependencies": { "@cypress/code-coverage": "^3.11.0", @@ -103,6 +106,7 @@ "eslint-plugin-testing-library": "^6.0.0", "eslint-plugin-ui-testing": "^2.0.1", "eslint-plugin-unicorn": "^48.0.1", + "json-server": "1.0.0-alpha.23", "npm-check-updates": "^16.12.2", "prettier": "^3.0.2", "release-it": "^16.1.5", @@ -114,7 +118,10 @@ "gh-pages": "5.0.0", "http-cache-semantics": "4.1.1", "ansi-regex": "5.0.1", - "@testing-library/dom": "8.20.0" + "@testing-library/dom": "8.20.0", + "ses": "1.3.0", + "@endo/eventual-send": "0.17.2", + "@agoric/xsnap": "0.14.3-u13.0" }, "engines": { "node": ">=14" diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index b9bfa0f14..caa748429 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -9,172 +9,268 @@ overrides: http-cache-semantics: 4.1.1 ansi-regex: 5.0.1 '@testing-library/dom': 8.20.0 - -dependencies: - '@cypress/code-coverage': - specifier: ^3.11.0 - version: 3.11.0(@babel/core@7.21.8)(@babel/preset-env@7.21.5)(babel-loader@9.1.2)(cypress@12.17.3)(webpack@5.81.0) - '@cypress/webpack-dev-server': - specifier: ^3.5.2 - version: 3.5.2(debug@4.3.4)(webpack@5.81.0) - '@drptbl/gremlins.js': - specifier: ^2.2.1 - version: 2.2.1 - '@foundry-rs/easy-foundryup': - specifier: ^0.1.3 - version: 0.1.3 - '@playwright/test': - specifier: ^1.37.0 - version: 1.37.0 - '@testing-library/cypress': - specifier: ^9.0.0 - version: 9.0.0(cypress@12.17.3) - '@testing-library/react': - specifier: ^14.0.0 - version: 14.0.0(react-dom@18.2.0)(react@18.2.0) - '@types/testing-library__cypress': - specifier: ^5.0.9 - version: 5.0.9 - '@viem/anvil': - specifier: ^0.0.6 - version: 0.0.6(debug@4.3.4) - app-root-path: - specifier: ^3.1.0 - version: 3.1.0 - axios: - specifier: ^1.4.0 - version: 1.4.0(debug@4.3.4) - babel-plugin-istanbul: - specifier: ^6.1.1 - version: 6.1.1 - babel-plugin-react-generate-property: - specifier: ^1.1.2 - version: 1.1.2 - babel-plugin-react-remove-properties: - specifier: ^0.3.0 - version: 0.3.0 - babel-plugin-transform-react-qa-classes: - specifier: ^1.6.0 - version: 1.6.0 - babel-plugin-transform-react-styled-components-qa: - specifier: ^2.1.0 - version: 2.1.0 - bytes32: - specifier: ^0.0.3 - version: 0.0.3 - commander: - specifier: ^11.0.0 - version: 11.0.0 - cypress: - specifier: 12.17.3 - version: 12.17.3 - cypress-wait-until: - specifier: ^2.0.1 - version: 2.0.1 - debug: - specifier: ^4.3.4 - version: 4.3.4(supports-color@8.1.1) - dotenv: - specifier: ^16.3.1 - version: 16.3.1 - dotenv-parse-variables: - specifier: ^2.0.0 - version: 2.0.0 - download: - specifier: ^8.0.0 - version: 8.0.0 - ethers: - specifier: ^6.7.1 - version: 6.7.1 - etherscan-api: - specifier: ^10.3.0 - version: 10.3.0(debug@4.3.4) - find-config: - specifier: ^1.0.0 - version: 1.0.0 - get-port: - specifier: ^7.0.0 - version: 7.0.0 - node-fetch: - specifier: ^2.6.1 - version: 2.6.9 - underscore: - specifier: ^1.13.6 - version: 1.13.6 - viem: - specifier: ^1.6.0 - version: 1.6.0(typescript@5.0.4) - wait-on: - specifier: ^7.0.1 - version: 7.0.1(debug@4.3.4) - -devDependencies: - '@metamask/test-dapp': - specifier: ^7.0.1 - version: 7.0.1 - '@microsoft/eslint-formatter-sarif': - specifier: ^3.0.0 - version: 3.0.0 - eslint: - specifier: ^8.47.0 - version: 8.47.0 - eslint-config-prettier: - specifier: ^9.0.0 - version: 9.0.0(eslint@8.47.0) - eslint-config-standard: - specifier: ^17.1.0 - version: 17.1.0(eslint-plugin-import@2.28.0)(eslint-plugin-n@15.7.0)(eslint-plugin-promise@6.1.1)(eslint@8.47.0) - eslint-config-turbo: - specifier: ^1.10.12 - version: 1.10.12(eslint@8.47.0) - eslint-plugin-chai-friendly: - specifier: ^0.7.2 - version: 0.7.2(eslint@8.47.0) - eslint-plugin-cypress: - specifier: ^2.14.0 - version: 2.14.0(eslint@8.47.0) - eslint-plugin-import: - specifier: ^2.28.0 - version: 2.28.0(eslint@8.47.0) - eslint-plugin-node: - specifier: ^11.1.0 - version: 11.1.0(eslint@8.47.0) - eslint-plugin-prettier: - specifier: ^5.0.0 - version: 5.0.0(eslint-config-prettier@9.0.0)(eslint@8.47.0)(prettier@3.0.2) - eslint-plugin-promise: - specifier: ^6.1.1 - version: 6.1.1(eslint@8.47.0) - eslint-plugin-standard: - specifier: ^4.1.0 - version: 4.1.0(eslint@8.47.0) - eslint-plugin-testing-library: - specifier: ^6.0.0 - version: 6.0.0(eslint@8.47.0)(typescript@5.0.4) - eslint-plugin-ui-testing: - specifier: ^2.0.1 - version: 2.0.1(eslint@8.47.0)(typescript@5.0.4) - eslint-plugin-unicorn: - specifier: ^48.0.1 - version: 48.0.1(eslint@8.47.0) - npm-check-updates: - specifier: ^16.12.2 - version: 16.12.2 - prettier: - specifier: ^3.0.2 - version: 3.0.2 - release-it: - specifier: ^16.1.5 - version: 16.1.5 - serve: - specifier: ^14.2.0 - version: 14.2.0 - start-server-and-test: - specifier: ^2.0.0 - version: 2.0.0 - turbo: - specifier: ^1.10.12 - version: 1.10.12 + ses: 1.3.0 + '@endo/eventual-send': 0.17.2 + '@agoric/xsnap': 0.14.3-u13.0 + +importers: + + .: + dependencies: + '@cypress/code-coverage': + specifier: ^3.11.0 + version: 3.12.26(@babel/core@7.23.9)(@babel/preset-env@7.23.9)(babel-loader@9.1.3)(cypress@12.17.3)(webpack@5.90.3) + '@cypress/webpack-dev-server': + specifier: ^3.5.2 + version: 3.7.4(debug@4.3.4)(webpack@5.90.3) + '@drptbl/gremlins.js': + specifier: ^2.2.1 + version: 2.2.1 + '@foundry-rs/easy-foundryup': + specifier: ^0.1.3 + version: 0.1.3 + '@playwright/test': + specifier: ^1.37.0 + version: 1.42.0 + '@testing-library/cypress': + specifier: ^9.0.0 + version: 9.0.0(cypress@12.17.3) + '@testing-library/react': + specifier: ^14.0.0 + version: 14.2.1(react-dom@18.2.0)(react@18.2.0) + '@types/testing-library__cypress': + specifier: ^5.0.9 + version: 5.0.13 + '@viem/anvil': + specifier: ^0.0.6 + version: 0.0.6(debug@4.3.4) + app-root-path: + specifier: ^3.1.0 + version: 3.1.0 + axios: + specifier: ^1.4.0 + version: 1.6.7(debug@4.3.4) + babel-plugin-istanbul: + specifier: ^6.1.1 + version: 6.1.1 + babel-plugin-react-generate-property: + specifier: ^1.1.2 + version: 1.1.2 + babel-plugin-react-remove-properties: + specifier: ^0.3.0 + version: 0.3.0 + babel-plugin-transform-react-qa-classes: + specifier: ^1.6.0 + version: 1.6.0 + babel-plugin-transform-react-styled-components-qa: + specifier: ^2.1.0 + version: 2.1.0 + bytes32: + specifier: ^0.0.3 + version: 0.0.3 + commander: + specifier: ^11.0.0 + version: 11.1.0 + cypress: + specifier: 12.17.3 + version: 12.17.3 + cypress-wait-until: + specifier: ^2.0.1 + version: 2.0.1 + debug: + specifier: ^4.3.4 + version: 4.3.4(supports-color@8.1.1) + dotenv: + specifier: ^16.3.1 + version: 16.4.5 + dotenv-parse-variables: + specifier: ^2.0.0 + version: 2.0.0 + download: + specifier: ^8.0.0 + version: 8.0.0 + ethers: + specifier: ^6.7.1 + version: 6.11.1 + etherscan-api: + specifier: ^10.3.0 + version: 10.3.0(debug@4.3.4) + find-config: + specifier: ^1.0.0 + version: 1.0.0 + get-port: + specifier: ^7.0.0 + version: 7.0.0 + node-fetch: + specifier: ^2.6.1 + version: 2.7.0 + underscore: + specifier: ^1.13.6 + version: 1.13.6 + viem: + specifier: ^1.6.0 + version: 1.21.4(typescript@5.3.3) + wait-on: + specifier: ^7.0.1 + version: 7.2.0(debug@4.3.4) + devDependencies: + '@metamask/test-dapp': + specifier: ^7.0.1 + version: 7.3.1 + '@microsoft/eslint-formatter-sarif': + specifier: ^3.0.0 + version: 3.0.0 + eslint: + specifier: ^8.47.0 + version: 8.57.0 + eslint-config-prettier: + specifier: ^9.0.0 + version: 9.1.0(eslint@8.57.0) + eslint-config-standard: + specifier: ^17.1.0 + version: 17.1.0(eslint-plugin-import@2.29.1)(eslint-plugin-n@16.6.2)(eslint-plugin-promise@6.1.1)(eslint@8.57.0) + eslint-config-turbo: + specifier: ^1.10.12 + version: 1.12.4(eslint@8.57.0) + eslint-plugin-chai-friendly: + specifier: ^0.7.2 + version: 0.7.4(eslint@8.57.0) + eslint-plugin-cypress: + specifier: ^2.14.0 + version: 2.15.1(eslint@8.57.0) + eslint-plugin-import: + specifier: ^2.28.0 + version: 2.29.1(eslint@8.57.0) + eslint-plugin-node: + specifier: ^11.1.0 + version: 11.1.0(eslint@8.57.0) + eslint-plugin-prettier: + specifier: ^5.0.0 + version: 5.1.3(eslint-config-prettier@9.1.0)(eslint@8.57.0)(prettier@3.2.5) + eslint-plugin-promise: + specifier: ^6.1.1 + version: 6.1.1(eslint@8.57.0) + eslint-plugin-standard: + specifier: ^4.1.0 + version: 4.1.0(eslint@8.57.0) + eslint-plugin-testing-library: + specifier: ^6.0.0 + version: 6.2.0(eslint@8.57.0)(typescript@5.3.3) + eslint-plugin-ui-testing: + specifier: ^2.0.1 + version: 2.0.1(eslint@8.57.0)(typescript@5.3.3) + eslint-plugin-unicorn: + specifier: ^48.0.1 + version: 48.0.1(eslint@8.57.0) + json-server: + specifier: 1.0.0-alpha.23 + version: 1.0.0-alpha.23 + npm-check-updates: + specifier: ^16.12.2 + version: 16.14.15 + prettier: + specifier: ^3.0.2 + version: 3.2.5 + release-it: + specifier: ^16.1.5 + version: 16.3.0(typescript@5.3.3) + serve: + specifier: ^14.2.0 + version: 14.2.1 + start-server-and-test: + specifier: ^2.0.0 + version: 2.0.3 + turbo: + specifier: ^1.10.12 + version: 1.12.4 + + tools/ui: + dependencies: + '@endo/eventual-send': + specifier: 0.17.2 + version: 0.17.2 + react: + specifier: ^18.2.0 + version: 18.2.0 + react-dom: + specifier: ^18.2.0 + version: 18.2.0(react@18.2.0) + devDependencies: + '@agoric/eventual-send': + specifier: ^0.14.1 + version: 0.14.1 + '@agoric/notifier': + specifier: ^0.6.2 + version: 0.6.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/rpc': + specifier: 0.9.1-dev-f471a83.0 + version: 0.9.1-dev-f471a83.0(ava@5.3.1)(debug@4.3.4)(typescript@5.3.3) + '@agoric/store': + specifier: ^0.9.2 + version: 0.9.2(ava@5.3.1) + '@agoric/ui-components': + specifier: ^0.9.0 + version: 0.9.0(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/web-components': + specifier: ^0.15.0 + version: 0.15.0(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4)(eslint@8.57.0) + '@testing-library/react': + specifier: ^14.1.2 + version: 14.2.1(react-dom@18.2.0)(react@18.2.0) + '@types/react': + specifier: ^18.2.15 + version: 18.2.60 + '@types/react-dom': + specifier: ^18.2.7 + version: 18.2.19 + '@typescript-eslint/eslint-plugin': + specifier: ^6.0.0 + version: 6.21.0(@typescript-eslint/parser@6.21.0)(eslint@8.57.0)(typescript@5.3.3) + '@typescript-eslint/parser': + specifier: ^6.0.0 + version: 6.21.0(eslint@8.57.0)(typescript@5.3.3) + '@vitejs/plugin-react': + specifier: ^4.0.3 + version: 4.2.1(vite@4.5.2) + eslint: + specifier: ^8.45.0 + version: 8.57.0 + eslint-config-prettier: + specifier: ^9.1.0 + version: 9.1.0(eslint@8.57.0) + eslint-plugin-prettier: + specifier: ^5.1.3 + version: 5.1.3(eslint-config-prettier@9.1.0)(eslint@8.57.0)(prettier@3.2.5) + eslint-plugin-react-hooks: + specifier: ^4.6.0 + version: 4.6.0(eslint@8.57.0) + eslint-plugin-react-refresh: + specifier: ^0.4.3 + version: 0.4.5(eslint@8.57.0) + happy-dom: + specifier: ^13.3.1 + version: 13.6.2 + prettier: + specifier: ^3.2.4 + version: 3.2.5 + puppeteer: + specifier: ^21.9.0 + version: 21.11.0(typescript@5.3.3) + ses: + specifier: 1.3.0 + version: 1.3.0 + typescript: + specifier: ^5.0.2 + version: 5.3.3 + vite: + specifier: ^4.4.5 + version: 4.5.2 + vitest: + specifier: ^1.2.1 + version: 1.3.1(happy-dom@13.6.2) + zustand: + specifier: ^4.4.1 + version: 4.5.1(@types/react@18.2.60)(react@18.2.0) packages: @@ -183,1138 +279,1903 @@ packages: engines: {node: '>=0.10.0'} dev: true - /@adraffy/ens-normalize@1.9.0: - resolution: {integrity: sha512-iowxq3U30sghZotgl4s/oJRci6WPBfNO5YYgk2cIOMCHr3LeGPcsZjCEr+33Q4N+oV3OABDAtA+pyvWjbvBifQ==} + /@adraffy/ens-normalize@1.10.0: + resolution: {integrity: sha512-nA9XHtlAkYfJxY7bce8DcN7eKxWWCWkU+1GR9d+U6MbNpfwQp8TI7vqOsBsMcHoT4mBu2kypKoSKnghEzOOq5Q==} dev: false - /@adraffy/ens-normalize@1.9.2: - resolution: {integrity: sha512-0h+FrQDqe2Wn+IIGFkTCd4aAwTJ+7834Ek1COohCyV26AXhwQ7WQaz+4F/nLOeVl/3BtWHOHLPsq46V8YB46Eg==} + /@adraffy/ens-normalize@1.10.1: + resolution: {integrity: sha512-96Z2IP3mYmF1Xg2cDm8f1gWGf/HUVedQ3FMifV4kG/PQ4yEP51xDtRAEfhVNt5f/uzpNkZHwWQuUcu6D6K+Ekw==} dev: false + /@agoric/access-token@0.4.21: + resolution: {integrity: sha512-wnsH3K7psw+kHCNf5vSYdBpz2uqLVnLxBsEtq5mnCrTc8pO5O/653x1mGM02k6QNi02K9QjFnWsdCgXPaRgEuQ==} + dependencies: + '@agoric/assert': 0.6.0 + n-readlines: 1.0.1 + tmp: 0.2.2 + dev: true + + /@agoric/assert@0.6.0: + resolution: {integrity: sha512-bpY9ul5egbVlmdf9RtDfxh1WQaDSOCzqcAxyqE771rbkv+QYs46oZc4oUVHi7wt3g5LVXj/JsKgLkJEKpEl1BA==} + engines: {node: '>=14.15.0'} + dev: true + + /@agoric/assert@0.6.1-u11wf.0: + resolution: {integrity: sha512-z/uq9ZkWWsBwMYLWg/X4AxEWwKv7HYU+0dCM98SZW8REK5BPhF/Vy9u0AuFLP8kwPdpp7WroYOSIVZ6xhLz0TQ==} + engines: {node: '>=14.15.0'} + dev: true + + /@agoric/babel-generator@7.17.6: + resolution: {integrity: sha512-D2wnk5fGajxMN5SCRSaA/triQGEaEX2Du0EzrRqobuD4wRXjvtF1e7jC1PPOk/RC2bZ8/0fzp0CHOiB7YLwb5w==} + engines: {node: '>=6.9.0'} + dependencies: + '@babel/types': 7.23.9 + jsesc: 2.5.2 + source-map: 0.5.7 + dev: true + + /@agoric/cache@0.3.2(@endo/ses-ava@0.2.40)(ava@5.3.1): + resolution: {integrity: sha512-cFLMiY9OI2Xp7aOAlAmZF/4H6rwaxhtzCfOJ8UiMIKE+4JXkhMLO2FtvGBUWFw40/Q9JsWRWziPs7otuFVQ6Ng==} + engines: {node: '>=14.15.0'} + dependencies: + '@agoric/internal': 0.3.2(ava@5.3.1) + '@agoric/notifier': 0.6.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/store': 0.9.2(ava@5.3.1) + '@agoric/vat-data': 0.5.2(ava@5.3.1) + '@endo/far': 0.2.18(ava@5.3.1) + '@endo/marshal': 0.8.9(ava@5.3.1) + transitivePeerDependencies: + - '@endo/ses-ava' + - ava + - supports-color + dev: true + + /@agoric/casting@0.4.2(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4): + resolution: {integrity: sha512-TiCG7hIg9Wp8Ud0PF7XSrTlqQWdczDac7QdSUWuBDodrlk3qw/5Ktcb5BoD0vFyARNZsB9PZq0cBRNYtjHj/Bg==} + engines: {node: '>=14.15.0'} + dependencies: + '@agoric/internal': 0.3.2(ava@5.3.1) + '@agoric/notifier': 0.6.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/spawner': 0.6.8(ava@5.3.1) + '@agoric/store': 0.9.2(ava@5.3.1) + '@cosmjs/encoding': 0.30.1 + '@cosmjs/proto-signing': 0.30.1 + '@cosmjs/stargate': 0.30.1(debug@4.3.4) + '@cosmjs/tendermint-rpc': 0.30.1(debug@4.3.4) + '@endo/far': 0.2.18(ava@5.3.1) + '@endo/init': 0.5.60 + '@endo/lockdown': 0.1.32 + '@endo/marshal': 0.8.9(ava@5.3.1) + '@endo/promise-kit': 0.2.60 + node-fetch: 2.7.0 + transitivePeerDependencies: + - '@endo/ses-ava' + - ava + - bufferutil + - debug + - encoding + - supports-color + - utf-8-validate + dev: true + + /@agoric/casting@0.4.3-u14.0(ava@5.3.1)(debug@4.3.4): + resolution: {integrity: sha512-LzbtDYIBowClaib/rwjoMZQXa0s2V9MSOC/fa7XDjVRva2CXcUoYGNJn5DoyfIcWq/D8KFMKRRl0r8CBO45b2g==} + engines: {node: '>=14.15.0'} + dependencies: + '@agoric/internal': 0.4.0-u14.0(ava@5.3.1) + '@agoric/notifier': 0.6.3-u14.0(ava@5.3.1) + '@agoric/spawner': 0.6.9-u14.0(ava@5.3.1) + '@agoric/store': 0.9.3-u14.0(ava@5.3.1) + '@cosmjs/encoding': 0.30.1 + '@cosmjs/proto-signing': 0.30.1 + '@cosmjs/stargate': 0.30.1(debug@4.3.4) + '@cosmjs/tendermint-rpc': 0.30.1(debug@4.3.4) + '@endo/far': 0.2.18(ava@5.3.1) + '@endo/init': 0.5.56 + '@endo/lockdown': 0.1.28 + '@endo/marshal': 0.8.5(ava@5.3.1) + '@endo/promise-kit': 0.2.56 + node-fetch: 2.7.0 + transitivePeerDependencies: + - ava + - bufferutil + - debug + - encoding + - supports-color + - utf-8-validate + dev: true + + /@agoric/cosmic-proto@0.3.0: + resolution: {integrity: sha512-cIunby6gs53sGkHx3ALraREbfVQXvsIcObMjQQ0/tZt5HVqwoS7Y1Qj1Xl0ZZvqE8B1Zyk7QMDj829mbTII+9g==} + dependencies: + protobufjs: 7.2.6 + dev: true + + /@agoric/ertp@0.16.2(@endo/ses-ava@0.2.40)(ava@5.3.1): + resolution: {integrity: sha512-4+CbrkWw2dCYlVAYH+31jFMlwWqw29bak+Rg6qkMuCAp5BpxyBc4DthdovOjwwOBqkBd3QBKrnvkoD9Ltc3YHQ==} + engines: {node: '>=14.15.0'} + dependencies: + '@agoric/assert': 0.6.0 + '@agoric/notifier': 0.6.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/store': 0.9.2(ava@5.3.1) + '@agoric/swingset-vat': 0.32.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/vat-data': 0.5.2(ava@5.3.1) + '@endo/eventual-send': 0.17.2 + '@endo/far': 0.2.18(ava@5.3.1) + '@endo/marshal': 0.8.9(ava@5.3.1) + '@endo/nat': 4.1.31 + '@endo/promise-kit': 0.2.60 + transitivePeerDependencies: + - '@endo/ses-ava' + - ava + - supports-color + dev: true + + /@agoric/eventual-send@0.14.1: + resolution: {integrity: sha512-E1gr1LhkN/imwiXIdjTQZ7pOao82avOIDsoSgjPwoFU1jrysRE8UIUGBogBn7GGFUEPogo16rrsfKzb35ZayOw==} + dev: true + + /@agoric/governance@0.10.3(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4): + resolution: {integrity: sha512-DmaZAJ7u5Tpsh3GscqLkxkZfVl5qg6fD905gdKx/b5xahzF65KIcOz48qUVFqZm/l4N4n1TzIazeAApsLpD7Pw==} + engines: {node: '>=14.15.0'} + dependencies: + '@agoric/assert': 0.6.0 + '@agoric/ertp': 0.16.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/internal': 0.3.2(ava@5.3.1) + '@agoric/notifier': 0.6.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/store': 0.9.2(ava@5.3.1) + '@agoric/swingset-vat': 0.32.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/time': 0.3.2(ava@5.3.1) + '@agoric/vat-data': 0.5.2(ava@5.3.1) + '@agoric/vats': 0.15.1(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) + '@agoric/zoe': 0.26.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@endo/captp': 3.1.1(ava@5.3.1) + '@endo/eventual-send': 0.17.2 + '@endo/far': 0.2.18(ava@5.3.1) + '@endo/marshal': 0.8.9(ava@5.3.1) + '@endo/nat': 4.1.31 + '@endo/promise-kit': 0.2.60 + transitivePeerDependencies: + - '@endo/ses-ava' + - ava + - bufferutil + - debug + - encoding + - supports-color + - utf-8-validate + dev: true + + /@agoric/inter-protocol@0.16.1(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4): + resolution: {integrity: sha512-1SJLBpeLsgXdJEK4CjzQ2QgLgCJg+OJv8M3dKy9MDMK+ajhQRCB2ySQtGbS9KXgwdpj4FFudKb0/+QaGhgfukg==} + engines: {node: '>=14.15.0'} + dependencies: + '@agoric/assert': 0.6.0 + '@agoric/ertp': 0.16.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/governance': 0.10.3(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) + '@agoric/internal': 0.3.2(ava@5.3.1) + '@agoric/notifier': 0.6.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/store': 0.9.2(ava@5.3.1) + '@agoric/time': 0.3.2(ava@5.3.1) + '@agoric/vat-data': 0.5.2(ava@5.3.1) + '@agoric/vats': 0.15.1(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) + '@agoric/zoe': 0.26.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@endo/captp': 3.1.1(ava@5.3.1) + '@endo/eventual-send': 0.17.2 + '@endo/far': 0.2.18(ava@5.3.1) + '@endo/marshal': 0.8.9(ava@5.3.1) + '@endo/nat': 4.1.31 + agoric: 0.21.1(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) + jessie.js: 0.3.3(ava@5.3.1) + transitivePeerDependencies: + - '@endo/ses-ava' + - ava + - bufferutil + - debug + - encoding + - supports-color + - utf-8-validate + dev: true + + /@agoric/internal@0.3.2(ava@5.3.1): + resolution: {integrity: sha512-iCgZE2NabhDKBJ+EfTeVqWUcoNvgxNfnw/dMF57yKnRn3E9iOqt7Iyx+DloTGBu5a1ZyywdQo4G2cFWrMX3Q7g==} + engines: {node: '>=14.15.0'} + dependencies: + '@agoric/zone': 0.2.2(ava@5.3.1) + '@endo/far': 0.2.18(ava@5.3.1) + '@endo/marshal': 0.8.9(ava@5.3.1) + '@endo/patterns': 0.2.2(ava@5.3.1) + '@endo/promise-kit': 0.2.60 + '@endo/stream': 0.3.25 + anylogger: 0.21.0 + jessie.js: 0.3.3(ava@5.3.1) + transitivePeerDependencies: + - ava + dev: true + + /@agoric/internal@0.4.0-u14.0(ava@5.3.1): + resolution: {integrity: sha512-i71iWb2n4PbzteKqZlCGrwC565HWhlRBDxkvWX3iAwDlV6SDj4r70p0BAeeE/YBe653/L0Cuhub7+nNyCZZTSg==} + engines: {node: '>=14.15.0'} + dependencies: + '@agoric/zone': 0.2.3-u14.0(ava@5.3.1) + '@endo/far': 0.2.18(ava@5.3.1) + '@endo/marshal': 0.8.5(ava@5.3.1) + '@endo/patterns': 0.2.2(ava@5.3.1) + '@endo/promise-kit': 0.2.56 + '@endo/stream': 0.3.25 + anylogger: 0.21.0 + jessie.js: 0.3.3(ava@5.3.1) + transitivePeerDependencies: + - ava + dev: true + + /@agoric/notifier@0.6.2(@endo/ses-ava@0.2.40)(ava@5.3.1): + resolution: {integrity: sha512-2Hi8u2TXtsk9Ix0L8xfRMGut1c+w7jiM8Wt4Ys2bgfI/ybdJ4FtDIBvHF1hFU0rSbhUicuKAN85Sok+MkDNcug==} + engines: {node: '>=14.15.0'} + dependencies: + '@agoric/assert': 0.6.0 + '@agoric/internal': 0.3.2(ava@5.3.1) + '@agoric/store': 0.9.2(ava@5.3.1) + '@agoric/swing-store': 0.9.1(ava@5.3.1) + '@agoric/swingset-vat': 0.32.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/vat-data': 0.5.2(ava@5.3.1) + '@endo/far': 0.2.18(ava@5.3.1) + '@endo/marshal': 0.8.9(ava@5.3.1) + '@endo/promise-kit': 0.2.60 + transitivePeerDependencies: + - '@endo/ses-ava' + - ava + - supports-color + dev: true + + /@agoric/notifier@0.6.3-u14.0(ava@5.3.1): + resolution: {integrity: sha512-lYGO/Bq6VjTBJAyPrjljC0BOmD78+v0LX+9iQbbIuy8F8LtK/YZHse9o+R0ub49QihCBOqDAPoJ+xGoLl2Ursw==} + engines: {node: '>=14.15.0'} + dependencies: + '@agoric/assert': 0.6.1-u11wf.0 + '@agoric/internal': 0.4.0-u14.0(ava@5.3.1) + '@agoric/store': 0.9.3-u14.0(ava@5.3.1) + '@agoric/swing-store': 0.9.2-u14.0(ava@5.3.1) + '@agoric/swingset-vat': 0.32.3-u14.0(ava@5.3.1) + '@agoric/vat-data': 0.5.3-u14.0(ava@5.3.1) + '@endo/far': 0.2.18(ava@5.3.1) + '@endo/marshal': 0.8.5(ava@5.3.1) + '@endo/promise-kit': 0.2.56 + transitivePeerDependencies: + - ava + - supports-color + dev: true + + /@agoric/rpc@0.9.1-dev-f471a83.0(ava@5.3.1)(debug@4.3.4)(typescript@5.3.3): + resolution: {integrity: sha512-qMWu1vhfEn2zhodGw4kuH1fr8jcP60BPDDCBEYx+y9owRCt7fVne51lFtYXfOhHEJcv5tyjITSP7msnk5dvKnA==} + dependencies: + '@endo/marshal': 0.8.9(ava@5.3.1) + axios: 1.6.7(debug@4.3.4) + axios-retry: 4.0.0(axios@1.6.7) + vite: 4.5.2 + vite-tsconfig-paths: 4.3.1(typescript@5.3.3)(vite@4.5.2) + transitivePeerDependencies: + - '@types/node' + - ava + - debug + - less + - lightningcss + - sass + - stylus + - sugarss + - supports-color + - terser + - typescript + dev: true + + /@agoric/sharing-service@0.2.11(ava@5.3.1): + resolution: {integrity: sha512-xYLxjjDcd7T0zN5Bu67JvC0WiL7CIoEKm4NAvYS5RjwCqkDjhi+QoVjnq8EskhzWU+BOnjJdtmhjNAlptSnk4Q==} + engines: {node: '>=14.15.0'} + dependencies: + '@agoric/assert': 0.6.0 + '@endo/marshal': 0.8.9(ava@5.3.1) + transitivePeerDependencies: + - ava + dev: true + + /@agoric/smart-wallet@0.5.3(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4): + resolution: {integrity: sha512-2L7sHmUL/BINuuHv+6A1kYLjidqCNJ2V3GqXm3R6oTeFtzscSzOo3LeOoQ2uPridkZ+fTXxinNfpJ/gRu2pl7g==} + dependencies: + '@agoric/assert': 0.6.0 + '@agoric/casting': 0.4.2(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) + '@agoric/ertp': 0.16.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/internal': 0.3.2(ava@5.3.1) + '@agoric/notifier': 0.6.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/store': 0.9.2(ava@5.3.1) + '@agoric/swingset-vat': 0.32.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/vat-data': 0.5.2(ava@5.3.1) + '@agoric/vats': 0.15.1(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) + '@agoric/zoe': 0.26.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@endo/eventual-send': 0.17.2 + '@endo/far': 0.2.18(ava@5.3.1) + '@endo/marshal': 0.8.9(ava@5.3.1) + '@endo/nat': 4.1.31 + '@endo/promise-kit': 0.2.60 + transitivePeerDependencies: + - '@endo/ses-ava' + - ava + - bufferutil + - debug + - encoding + - supports-color + - utf-8-validate + dev: true + + /@agoric/spawner@0.6.8(ava@5.3.1): + resolution: {integrity: sha512-n/vjSr2cU3qyla8dJlCYVqkPnVsRHZE2h6dYy8yG0UZm2AUZju5m4bwj5gm8y+g8zO8Dzmfk0GGIyy9hamS7Uw==} + engines: {node: '>=14.15.0'} + dependencies: + '@agoric/assert': 0.6.0 + '@endo/eventual-send': 0.17.2 + '@endo/import-bundle': 0.3.4 + '@endo/marshal': 0.8.9(ava@5.3.1) + transitivePeerDependencies: + - ava + - supports-color + dev: true + + /@agoric/spawner@0.6.9-u14.0(ava@5.3.1): + resolution: {integrity: sha512-U4bzpKQjSV9jeoUC6K+jDQFVXCVkp5BjhbdBab5FhW3eQz+Hq1JL+fqNKY929ckWYloQRW/mefPzUfL3INQZFA==} + engines: {node: '>=14.15.0'} + dependencies: + '@agoric/assert': 0.6.1-u11wf.0 + '@endo/eventual-send': 0.17.2 + '@endo/import-bundle': 0.3.4 + '@endo/marshal': 0.8.5(ava@5.3.1) + transitivePeerDependencies: + - ava + - supports-color + dev: true + + /@agoric/store@0.9.2(ava@5.3.1): + resolution: {integrity: sha512-9YtBlQG1cO7COfprPqBUYDW1Jg805Ick1RHm8Etj5VyfkhF8emhv/OqJKi4FMlA3XDVL3Yvbptrjvdo1WjCvjg==} + engines: {node: '>=14.15.0'} + dependencies: + '@agoric/assert': 0.6.0 + '@agoric/internal': 0.3.2(ava@5.3.1) + '@endo/eventual-send': 0.17.2 + '@endo/exo': 0.2.2(ava@5.3.1) + '@endo/far': 0.2.18(ava@5.3.1) + '@endo/marshal': 0.8.9(ava@5.3.1) + '@endo/pass-style': 0.1.7(ava@5.3.1) + '@endo/patterns': 0.2.2(ava@5.3.1) + '@endo/promise-kit': 0.2.60 + '@fast-check/ava': 1.2.1(ava@5.3.1) + transitivePeerDependencies: + - ava + dev: true + + /@agoric/store@0.9.3-u14.0(ava@5.3.1): + resolution: {integrity: sha512-wCGh1VJcCF+s7IYCWnbeINtvzyV0e/8FgDdxEyjAvLx+uXC5hrPBgWrcZ80eIT0Sl00gpJQTUE3XiXLj+27bxA==} + engines: {node: '>=14.15.0'} + dependencies: + '@agoric/assert': 0.6.1-u11wf.0 + '@endo/exo': 0.2.2(ava@5.3.1) + '@endo/marshal': 0.8.5(ava@5.3.1) + '@endo/pass-style': 0.1.3(ava@5.3.1) + '@endo/patterns': 0.2.2(ava@5.3.1) + transitivePeerDependencies: + - ava + dev: true + + /@agoric/swing-store@0.9.1(ava@5.3.1): + resolution: {integrity: sha512-GRgXOJwEnFSX3gY2sOhHs1yO503ltUVjslSeSWFHd8bmrPs11igIYRES7Vx4lOSQuNmGe5mKFhgfDnoHPmKxjQ==} + dependencies: + '@agoric/assert': 0.6.0 + '@agoric/internal': 0.3.2(ava@5.3.1) + '@endo/base64': 0.2.35 + '@endo/bundle-source': 2.8.0(ava@5.3.1) + '@endo/check-bundle': 0.2.18 + '@endo/nat': 4.1.31 + better-sqlite3: 8.7.0 + transitivePeerDependencies: + - ava + - supports-color + dev: true + + /@agoric/swing-store@0.9.2-u14.0(ava@5.3.1): + resolution: {integrity: sha512-PUtkWk5QxopX9RoJeLq53sZn9lzzeN+uCkhXrbytxmzDS/v1cGRXt0Mp2vWhs4oKJ5U7D2X1ei8P6d+SDgNBJQ==} + dependencies: + '@agoric/assert': 0.6.1-u11wf.0 + '@agoric/internal': 0.4.0-u14.0(ava@5.3.1) + '@endo/base64': 0.2.31 + '@endo/bundle-source': 2.5.2-upstream-rollup(ava@5.3.1) + '@endo/check-bundle': 0.2.18 + '@endo/nat': 4.1.27 + better-sqlite3: 8.7.0 + transitivePeerDependencies: + - ava + - supports-color + dev: true + + /@agoric/swingset-liveslots@0.10.2(@endo/far@0.2.18)(@endo/ses-ava@0.2.40)(ava@5.3.1): + resolution: {integrity: sha512-jp05WNHEUH5K8MgiIoHhNrWu7ozKqStyIe0Ex6ejSInFFo/NhJLVL7QLyUgRjD74RbUSuvbR8v8PaQ/pslVI0Q==} + engines: {node: '>=14.15.0'} + peerDependencies: + '@endo/far': ^0.2.18 + '@endo/ses-ava': ^0.2.40 + ava: ^5.2.0 + dependencies: + '@agoric/assert': 0.6.0 + '@agoric/internal': 0.3.2(ava@5.3.1) + '@agoric/store': 0.9.2(ava@5.3.1) + '@agoric/vat-data': 0.5.2(ava@5.3.1) + '@endo/eventual-send': 0.17.2 + '@endo/exo': 0.2.2(ava@5.3.1) + '@endo/far': 0.2.18(ava@5.3.1) + '@endo/init': 0.5.60 + '@endo/marshal': 0.8.9(ava@5.3.1) + '@endo/nat': 4.1.31 + '@endo/pass-style': 0.1.7(ava@5.3.1) + '@endo/patterns': 0.2.2(ava@5.3.1) + '@endo/promise-kit': 0.2.60 + '@endo/ses-ava': 0.2.40 + ava: 5.3.1 + dev: true + + /@agoric/swingset-liveslots@0.10.3-u14.0(ava@5.3.1): + resolution: {integrity: sha512-URukf41FuQD07AcvRugY9pL6pV9GtWeqoXDyeTgg7zHmmJ19E6sEFguiqxPDLsrkZ/EqF9xoAb9RHm3FkR41QA==} + engines: {node: '>=14.15.0'} + dependencies: + '@agoric/assert': 0.6.1-u11wf.0 + '@agoric/internal': 0.4.0-u14.0(ava@5.3.1) + '@agoric/store': 0.9.3-u14.0(ava@5.3.1) + '@agoric/vat-data': 0.5.3-u14.0(ava@5.3.1) + '@endo/eventual-send': 0.17.2 + '@endo/exo': 0.2.2(ava@5.3.1) + '@endo/far': 0.2.18(ava@5.3.1) + '@endo/init': 0.5.56 + '@endo/marshal': 0.8.5(ava@5.3.1) + '@endo/nat': 4.1.27 + '@endo/pass-style': 0.1.3(ava@5.3.1) + '@endo/patterns': 0.2.2(ava@5.3.1) + '@endo/promise-kit': 0.2.56 + transitivePeerDependencies: + - ava + dev: true + + /@agoric/swingset-vat@0.32.2(@endo/ses-ava@0.2.40)(ava@5.3.1): + resolution: {integrity: sha512-aYIhyYCuI7Oi47DBqn8wqMFnQOeOxSB7GU69wOQcQIoJVWRhOECDuFzoEqdV6G8xwGIsGpX/fMtXT9A1YAy6ZA==} + engines: {node: '>=14.15.0'} + hasBin: true + peerDependencies: + '@endo/ses-ava': ^0.2.40 + ava: ^5.2.0 + dependencies: + '@agoric/assert': 0.6.0 + '@agoric/internal': 0.3.2(ava@5.3.1) + '@agoric/store': 0.9.2(ava@5.3.1) + '@agoric/swing-store': 0.9.1(ava@5.3.1) + '@agoric/swingset-liveslots': 0.10.2(@endo/far@0.2.18)(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/swingset-xsnap-supervisor': 0.10.2 + '@agoric/time': 0.3.2(ava@5.3.1) + '@agoric/vat-data': 0.5.2(ava@5.3.1) + '@agoric/xsnap': 0.14.3-u13.0(ava@5.3.1) + '@agoric/xsnap-lockdown': 0.14.0 + '@endo/base64': 0.2.35 + '@endo/bundle-source': 2.8.0(ava@5.3.1) + '@endo/captp': 3.1.1(ava@5.3.1) + '@endo/check-bundle': 0.2.18 + '@endo/compartment-mapper': 0.8.4 + '@endo/eventual-send': 0.17.2 + '@endo/far': 0.2.18(ava@5.3.1) + '@endo/import-bundle': 0.3.4 + '@endo/init': 0.5.60 + '@endo/marshal': 0.8.9(ava@5.3.1) + '@endo/nat': 4.1.31 + '@endo/promise-kit': 0.2.60 + '@endo/ses-ava': 0.2.40 + '@endo/zip': 0.2.35 + ansi-styles: 6.2.1 + anylogger: 0.21.0 + ava: 5.3.1 + import-meta-resolve: 2.2.2 + microtime: 3.1.1 + semver: 6.3.1 + tmp: 0.2.2 + transitivePeerDependencies: + - supports-color + dev: true + + /@agoric/swingset-vat@0.32.3-u14.0(ava@5.3.1): + resolution: {integrity: sha512-bWouy+7vffOeBxfBdhWwbcTLdKhGS+PkmIasrPV6QsMvMY6wzk5FDz4LELX3kHN4rQu72VOy3q3xUo4YqnQ2BQ==} + engines: {node: '>=14.15.0'} + hasBin: true + peerDependencies: + ava: ^5.2.0 + dependencies: + '@agoric/assert': 0.6.1-u11wf.0 + '@agoric/internal': 0.4.0-u14.0(ava@5.3.1) + '@agoric/store': 0.9.3-u14.0(ava@5.3.1) + '@agoric/swing-store': 0.9.2-u14.0(ava@5.3.1) + '@agoric/swingset-liveslots': 0.10.3-u14.0(ava@5.3.1) + '@agoric/swingset-xsnap-supervisor': 0.10.3-u14.0 + '@agoric/time': 0.3.3-u14.0(ava@5.3.1) + '@agoric/vat-data': 0.5.3-u14.0(ava@5.3.1) + '@agoric/xsnap': 0.14.3-u13.0(ava@5.3.1) + '@agoric/xsnap-lockdown': 0.14.1-u13.0 + '@endo/base64': 0.2.31 + '@endo/bundle-source': 2.5.2-upstream-rollup(ava@5.3.1) + '@endo/captp': 3.1.1(ava@5.3.1) + '@endo/check-bundle': 0.2.18 + '@endo/compartment-mapper': 0.8.4 + '@endo/eventual-send': 0.17.2 + '@endo/far': 0.2.18(ava@5.3.1) + '@endo/import-bundle': 0.3.4 + '@endo/init': 0.5.56 + '@endo/marshal': 0.8.5(ava@5.3.1) + '@endo/nat': 4.1.27 + '@endo/promise-kit': 0.2.56 + '@endo/ses-ava': 0.2.40 + '@endo/zip': 0.2.31 + ansi-styles: 6.2.1 + anylogger: 0.21.0 + ava: 5.3.1 + import-meta-resolve: 2.2.2 + microtime: 3.1.1 + semver: 6.3.1 + tmp: 0.2.2 + transitivePeerDependencies: + - supports-color + dev: true + + /@agoric/swingset-xsnap-supervisor@0.10.2: + resolution: {integrity: sha512-3PB15aiNHfjTYmtUz9Rxmm6qSHnoO5w5dygRzjx2ytk8yoNn/ZOpxlIOLonhD8kwOaEli5D7btY9OA3jf+Sm6w==} + dev: true + + /@agoric/swingset-xsnap-supervisor@0.10.3-u14.0: + resolution: {integrity: sha512-vrZwHUphBxceQ7gTDoDIDHGcbXSm7gJpoabzmQQ++dRAktspjK7AccIZnMCBM52KZioJgRLsHwwSh/mXUdHZ7g==} + dev: true + + /@agoric/time@0.3.2(ava@5.3.1): + resolution: {integrity: sha512-qRgvfD/gQJNQaWk0uQqPhq0IGbIABz1z6oFtAhGkylU6zNO/no6VpJG4gw5YwEO8mIAJVOM5HE3qL53AaENYkw==} + engines: {node: '>=14.15.0'} + dependencies: + '@agoric/assert': 0.6.0 + '@agoric/store': 0.9.2(ava@5.3.1) + '@endo/nat': 4.1.31 + transitivePeerDependencies: + - ava + dev: true + + /@agoric/time@0.3.3-u14.0(ava@5.3.1): + resolution: {integrity: sha512-Sk0I3UPrWOdCny7KJ4/FejC9NHJkbXsyEmmD2lyGbcwNB4o9wetFkaL7g1v0yEPAjhyCxMTxkzTzcCST8XWktA==} + engines: {node: '>=14.15.0'} + dependencies: + '@agoric/assert': 0.6.1-u11wf.0 + '@agoric/store': 0.9.3-u14.0(ava@5.3.1) + '@endo/nat': 4.1.27 + transitivePeerDependencies: + - ava + dev: true + + /@agoric/ui-components@0.9.0(@endo/ses-ava@0.2.40)(ava@5.3.1): + resolution: {integrity: sha512-Ed8ZS1sprma+DLx1gBcCczIFlZ5jxLVUXqZPp32R5QnuOn9IfeDK4B+xhm7BJYr+0Lr2BNof9yqkvmWBmUEvNQ==} + dependencies: + '@agoric/assert': 0.6.0 + '@agoric/ertp': 0.16.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@endo/eventual-send': 0.17.2 + '@endo/init': 0.5.60 + '@endo/nat': 4.1.31 + clsx: 1.2.1 + transitivePeerDependencies: + - '@endo/ses-ava' + - ava + - supports-color + dev: true + + /@agoric/vat-data@0.5.2(ava@5.3.1): + resolution: {integrity: sha512-j71bSl7oPcWikR4bP15KMu67D3BLGLhEOcqgewC1cArcE99rhxDU19ALN0OITD0F0KkNCahRNifoIr73n/fBng==} + engines: {node: '>=14.15.0'} + dependencies: + '@agoric/assert': 0.6.0 + '@agoric/internal': 0.3.2(ava@5.3.1) + '@agoric/store': 0.9.2(ava@5.3.1) + transitivePeerDependencies: + - ava + dev: true + + /@agoric/vat-data@0.5.3-u14.0(ava@5.3.1): + resolution: {integrity: sha512-3uiSwLuoLgsFAZD1aaK4Gf5Z0dEf3tz9bL+CH73OEsspAoGfK0EME8XyewthudcMLv4FiwOeHEDC2Xb8GU+Ofg==} + engines: {node: '>=14.15.0'} + dependencies: + '@agoric/assert': 0.6.1-u11wf.0 + '@agoric/internal': 0.4.0-u14.0(ava@5.3.1) + '@agoric/store': 0.9.3-u14.0(ava@5.3.1) + transitivePeerDependencies: + - ava + dev: true + + /@agoric/vats@0.15.1(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4): + resolution: {integrity: sha512-uYV+f3+RJ/KM9O5+7HcsGqLfvhtj9V1e7u1y8TZeTs2zJXVRVuGi/xQaMSGwf3CBBgBtyj8hFUCCYCeHxB1qRQ==} + engines: {node: '>=14.15.0'} + dependencies: + '@agoric/assert': 0.6.0 + '@agoric/ertp': 0.16.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/governance': 0.10.3(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) + '@agoric/inter-protocol': 0.16.1(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) + '@agoric/internal': 0.3.2(ava@5.3.1) + '@agoric/notifier': 0.6.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/sharing-service': 0.2.11(ava@5.3.1) + '@agoric/store': 0.9.2(ava@5.3.1) + '@agoric/swingset-vat': 0.32.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/time': 0.3.2(ava@5.3.1) + '@agoric/vat-data': 0.5.2(ava@5.3.1) + '@agoric/zoe': 0.26.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/zone': 0.2.2(ava@5.3.1) + '@endo/far': 0.2.18(ava@5.3.1) + '@endo/import-bundle': 0.3.4 + '@endo/init': 0.5.60 + '@endo/marshal': 0.8.9(ava@5.3.1) + '@endo/nat': 4.1.31 + '@endo/promise-kit': 0.2.60 + jessie.js: 0.3.3(ava@5.3.1) + transitivePeerDependencies: + - '@endo/ses-ava' + - ava + - bufferutil + - debug + - encoding + - supports-color + - utf-8-validate + dev: true + + /@agoric/wallet-ui@0.1.3-solo.0: + resolution: {integrity: sha512-NbhCrTH9u2af+6ituM99M8Mo10VOP1nQRTZoYEXW+esBwJId/7cRniMmAC7qmkbXs8POA31S8EQ5gAhkWq08WA==} + dev: true + + /@agoric/wallet@0.18.3(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4)(eslint@8.57.0): + resolution: {integrity: sha512-Pgk5uh2ZA3sg3hP+gpQ4jpg+qhIu5diKzzVnD5g4o2JeVYjDqsR/xpcOt7r7i8zNbNutCAgGu5/qDDYEMIV6zQ==} + dependencies: + '@agoric/wallet-ui': 0.1.3-solo.0 + agoric: 0.21.1(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) + babel-eslint: 10.1.0(eslint@8.57.0) + eslint-plugin-eslint-comments: 3.2.0(eslint@8.57.0) + import-meta-resolve: 2.2.2 + transitivePeerDependencies: + - '@endo/ses-ava' + - ava + - bufferutil + - debug + - encoding + - eslint + - supports-color + - utf-8-validate + dev: true + + /@agoric/web-components@0.15.0(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4)(eslint@8.57.0): + resolution: {integrity: sha512-G1hl0NSgOuXE+9+SsyUpCHubhFJsrmFO7zo832EeJDUcO5d/V4M0YyrtIwFHKR2bH+IUl7JouasDO4fYEE8WYA==} + dependencies: + '@agoric/assert': 0.6.0 + '@agoric/cache': 0.3.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/casting': 0.4.3-u14.0(ava@5.3.1)(debug@4.3.4) + '@agoric/ertp': 0.16.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/notifier': 0.6.3-u14.0(ava@5.3.1) + '@agoric/smart-wallet': 0.5.3(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) + '@agoric/wallet': 0.18.3(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4)(eslint@8.57.0) + '@endo/captp': 3.1.1(ava@5.3.1) + '@endo/eventual-send': 0.17.2 + '@endo/marshal': 0.8.9(ava@5.3.1) + '@endo/promise-kit': 0.2.60 + '@lit-labs/react': 1.2.1 + lit: 2.0.2 + transitivePeerDependencies: + - '@endo/ses-ava' + - ava + - bufferutil + - debug + - encoding + - eslint + - supports-color + - utf-8-validate + dev: true + + /@agoric/xsnap-lockdown@0.14.0: + resolution: {integrity: sha512-T8kYrW1baTDQTkQJ9mDp1ME2Ive3RNNRFU7PXuu60Pu9A/tWliYKiJWwqcGhYAQOkHxxFz0BVwk9Jf8HErzgRA==} + dev: true + + /@agoric/xsnap-lockdown@0.14.1-u13.0: + resolution: {integrity: sha512-CUd4u1vyqSJfxj2+krNMBmDXlR7yN87RJsmB03ISPs8GuhjIrbdgkU+UfoKIJFLYco2ZSX7vR9j8l6azyVan1Q==} + dev: true + + /@agoric/xsnap@0.14.3-u13.0(ava@5.3.1): + resolution: {integrity: sha512-E9NP2Q4cPHesIeZNPnMmA+eWFZcDqNBue0VP0GiI4qUbHjz8uJS7YV/thZjDxJvnfXgT4wmIx8v11pkMp/+EKw==} + hasBin: true + requiresBuild: true + dependencies: + '@agoric/assert': 0.6.1-u11wf.0 + '@agoric/internal': 0.4.0-u14.0(ava@5.3.1) + '@agoric/xsnap-lockdown': 0.14.1-u13.0 + '@endo/bundle-source': 2.5.2-upstream-rollup(ava@5.3.1) + '@endo/eventual-send': 0.17.2 + '@endo/init': 0.5.56 + '@endo/netstring': 0.3.26 + '@endo/promise-kit': 0.2.56 + '@endo/stream': 0.3.25 + '@endo/stream-node': 0.2.26 + glob: 7.2.3 + tmp: 0.2.2 + transitivePeerDependencies: + - ava + - supports-color + dev: true + + /@agoric/zoe@0.26.2(@endo/ses-ava@0.2.40)(ava@5.3.1): + resolution: {integrity: sha512-xFZQ0Rz4UmHNWCUeLWFqtGgKNBPVvfb5IEmh+nSnbgJK45Y4Kcci77XkciO//e6xQo8dacrNhTELke3iAEISAA==} + engines: {node: '>=14.15.0'} + dependencies: + '@agoric/assert': 0.6.0 + '@agoric/ertp': 0.16.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/internal': 0.3.2(ava@5.3.1) + '@agoric/notifier': 0.6.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/store': 0.9.2(ava@5.3.1) + '@agoric/swingset-vat': 0.32.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/time': 0.3.2(ava@5.3.1) + '@agoric/vat-data': 0.5.2(ava@5.3.1) + '@endo/bundle-source': 2.8.0(ava@5.3.1) + '@endo/captp': 3.1.1(ava@5.3.1) + '@endo/eventual-send': 0.17.2 + '@endo/far': 0.2.18(ava@5.3.1) + '@endo/import-bundle': 0.3.4 + '@endo/marshal': 0.8.9(ava@5.3.1) + '@endo/nat': 4.1.31 + '@endo/patterns': 0.2.2(ava@5.3.1) + '@endo/promise-kit': 0.2.60 + transitivePeerDependencies: + - '@endo/ses-ava' + - ava + - supports-color + dev: true + + /@agoric/zone@0.2.2(ava@5.3.1): + resolution: {integrity: sha512-joVRnwH55xOeaoO2xYd1TWXXLPQ9pAeNsaiwTjO3FufYb/q55rv9mpYdUdhEy+zYQuFpPH87+6w/o3f/0AXrDQ==} + engines: {node: '>=14.15.0'} + dependencies: + '@agoric/store': 0.9.2(ava@5.3.1) + '@agoric/vat-data': 0.5.2(ava@5.3.1) + '@endo/far': 0.2.18(ava@5.3.1) + transitivePeerDependencies: + - ava + dev: true + + /@agoric/zone@0.2.3-u14.0(ava@5.3.1): + resolution: {integrity: sha512-+2c8NhNkm5XwJKyiooQ78N9qlVPMJ5K/kYOysC+BRz+vtWPInocehlFJsVuqisOmPajvnykr8QC+lPN1xHBsmg==} + engines: {node: '>=14.15.0'} + dependencies: + '@agoric/store': 0.9.3-u14.0(ava@5.3.1) + '@agoric/vat-data': 0.5.3-u14.0(ava@5.3.1) + '@endo/far': 0.2.18(ava@5.3.1) + transitivePeerDependencies: + - ava + dev: true + /@ampproject/remapping@2.2.1: resolution: {integrity: sha512-lFMjJTrFL3j7L9yBxwYfCq2k6qqwHyzuUl/XBnif78PWTJYyL/dfowQHWE3sp6U6ZzqWiiIZnpTMO96zhkjwtg==} engines: {node: '>=6.0.0'} dependencies: - '@jridgewell/gen-mapping': 0.3.3 - '@jridgewell/trace-mapping': 0.3.18 - dev: false + '@jridgewell/gen-mapping': 0.3.4 + '@jridgewell/trace-mapping': 0.3.23 - /@babel/code-frame@7.21.4: - resolution: {integrity: sha512-LYvhNKfwWSPpocw8GI7gpK2nq3HSDuEPC/uSYaALSJu9xjsalaaYFOq0Pwt5KmVqwEbZlDu81aLXwBOmD/Fv9g==} + /@babel/code-frame@7.23.5: + resolution: {integrity: sha512-CgH3s1a96LipHCmSUmYFPwY7MNx8C3avkq7i4Wl3cfa662ldtUe4VM1TPXX70pfmrlWTb6jLqTYrZyT2ZTJBgA==} engines: {node: '>=6.9.0'} dependencies: - '@babel/highlight': 7.18.6 + '@babel/highlight': 7.23.4 + chalk: 2.4.2 - /@babel/compat-data@7.21.7: - resolution: {integrity: sha512-KYMqFYTaenzMK4yUtf4EW9wc4N9ef80FsbMtkwool5zpwl4YrT1SdWYSTRcT94KO4hannogdS+LxY7L+arP3gA==} + /@babel/compat-data@7.23.5: + resolution: {integrity: sha512-uU27kfDRlhfKl+w1U6vp16IuvSLtjAxdArVXPa9BvLkrr7CYIsxH5adpHObeAGY/41+syctUWOZ140a2Rvkgjw==} engines: {node: '>=6.9.0'} - dev: false - /@babel/core@7.21.8: - resolution: {integrity: sha512-YeM22Sondbo523Sz0+CirSPnbj9bG3P0CdHcBZdqUuaeOaYEFbOLoGU7lebvGP6P5J/WE9wOn7u7C4J9HvS1xQ==} + /@babel/core@7.23.9: + resolution: {integrity: sha512-5q0175NOjddqpvvzU+kDiSOAk4PfdO6FvwCWoQ6RO7rTzEe8vlo+4HVfcnAREhD4npMs0e9uZypjTwzZPCf/cw==} engines: {node: '>=6.9.0'} dependencies: '@ampproject/remapping': 2.2.1 - '@babel/code-frame': 7.21.4 - '@babel/generator': 7.21.5 - '@babel/helper-compilation-targets': 7.21.5(@babel/core@7.21.8) - '@babel/helper-module-transforms': 7.21.5 - '@babel/helpers': 7.21.5 - '@babel/parser': 7.21.8 - '@babel/template': 7.20.7 - '@babel/traverse': 7.21.5 - '@babel/types': 7.21.5 - convert-source-map: 1.9.0 + '@babel/code-frame': 7.23.5 + '@babel/generator': 7.23.6 + '@babel/helper-compilation-targets': 7.23.6 + '@babel/helper-module-transforms': 7.23.3(@babel/core@7.23.9) + '@babel/helpers': 7.23.9 + '@babel/parser': 7.23.9 + '@babel/template': 7.23.9 + '@babel/traverse': 7.23.9 + '@babel/types': 7.23.9 + convert-source-map: 2.0.0 debug: 4.3.4(supports-color@8.1.1) gensync: 1.0.0-beta.2 json5: 2.2.3 semver: 6.3.1 transitivePeerDependencies: - supports-color - dev: false - /@babel/generator@7.21.5: - resolution: {integrity: sha512-SrKK/sRv8GesIW1bDagf9cCG38IOMYZusoe1dfg0D8aiUe3Amvoj1QtjTPAWcfrZFvIwlleLb0gxzQidL9w14w==} + /@babel/generator@7.23.6: + resolution: {integrity: sha512-qrSfCYxYQB5owCmGLbl8XRpX1ytXlpueOb0N0UmQwA073KZxejgQTzAmJezxvpwQD9uGtK2shHdi55QT+MbjIw==} engines: {node: '>=6.9.0'} dependencies: - '@babel/types': 7.21.5 - '@jridgewell/gen-mapping': 0.3.3 - '@jridgewell/trace-mapping': 0.3.18 + '@babel/types': 7.23.9 + '@jridgewell/gen-mapping': 0.3.4 + '@jridgewell/trace-mapping': 0.3.23 jsesc: 2.5.2 - dev: false - /@babel/helper-annotate-as-pure@7.18.6: - resolution: {integrity: sha512-duORpUiYrEpzKIop6iNbjnwKLAKnJ47csTyRACyEmWj0QdUrm5aqNJGHSSEQSUAvNW0ojX0dOmK9dZduvkfeXA==} + /@babel/helper-annotate-as-pure@7.22.5: + resolution: {integrity: sha512-LvBTxu8bQSQkcyKOU+a1btnNFQ1dMAd0R6PyW3arXes06F6QLWLIrd681bxRPIXlrMGR3XYnW9JyML7dP3qgxg==} engines: {node: '>=6.9.0'} dependencies: - '@babel/types': 7.21.5 + '@babel/types': 7.23.9 dev: false - /@babel/helper-builder-binary-assignment-operator-visitor@7.21.5: - resolution: {integrity: sha512-uNrjKztPLkUk7bpCNC0jEKDJzzkvel/W+HguzbN8krA+LPfC1CEobJEvAvGka2A/M+ViOqXdcRL0GqPUJSjx9g==} + /@babel/helper-builder-binary-assignment-operator-visitor@7.22.15: + resolution: {integrity: sha512-QkBXwGgaoC2GtGZRoma6kv7Szfv06khvhFav67ZExau2RaXzy8MpHSMO2PNoP2XtmQphJQRHFfg77Bq731Yizw==} engines: {node: '>=6.9.0'} dependencies: - '@babel/types': 7.21.5 + '@babel/types': 7.23.9 dev: false - /@babel/helper-compilation-targets@7.21.5(@babel/core@7.21.8): - resolution: {integrity: sha512-1RkbFGUKex4lvsB9yhIfWltJM5cZKUftB2eNajaDv3dCMEp49iBG0K14uH8NnX9IPux2+mK7JGEOB0jn48/J6w==} + /@babel/helper-compilation-targets@7.23.6: + resolution: {integrity: sha512-9JB548GZoQVmzrFgp8o7KxdgkTGm6xs9DW0o/Pim72UDjzr5ObUQ6ZzYPqA+g9OTS2bBQoctLJrky0RDCAWRgQ==} engines: {node: '>=6.9.0'} - peerDependencies: - '@babel/core': ^7.0.0 dependencies: - '@babel/compat-data': 7.21.7 - '@babel/core': 7.21.8 - '@babel/helper-validator-option': 7.21.0 - browserslist: 4.21.5 + '@babel/compat-data': 7.23.5 + '@babel/helper-validator-option': 7.23.5 + browserslist: 4.23.0 lru-cache: 5.1.1 semver: 6.3.1 - dev: false - /@babel/helper-create-class-features-plugin@7.21.8(@babel/core@7.21.8): - resolution: {integrity: sha512-+THiN8MqiH2AczyuZrnrKL6cAxFRRQDKW9h1YkBvbgKmAm6mwiacig1qT73DHIWMGo40GRnsEfN3LA+E6NtmSw==} + /@babel/helper-create-class-features-plugin@7.23.10(@babel/core@7.23.9): + resolution: {integrity: sha512-2XpP2XhkXzgxecPNEEK8Vz8Asj9aRxt08oKOqtiZoqV2UGZ5T+EkyP9sXQ9nwMxBIG34a7jmasVqoMop7VdPUw==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-annotate-as-pure': 7.18.6 - '@babel/helper-environment-visitor': 7.21.5 - '@babel/helper-function-name': 7.21.0 - '@babel/helper-member-expression-to-functions': 7.21.5 - '@babel/helper-optimise-call-expression': 7.18.6 - '@babel/helper-replace-supers': 7.21.5 - '@babel/helper-skip-transparent-expression-wrappers': 7.20.0 - '@babel/helper-split-export-declaration': 7.18.6 + '@babel/core': 7.23.9 + '@babel/helper-annotate-as-pure': 7.22.5 + '@babel/helper-environment-visitor': 7.22.20 + '@babel/helper-function-name': 7.23.0 + '@babel/helper-member-expression-to-functions': 7.23.0 + '@babel/helper-optimise-call-expression': 7.22.5 + '@babel/helper-replace-supers': 7.22.20(@babel/core@7.23.9) + '@babel/helper-skip-transparent-expression-wrappers': 7.22.5 + '@babel/helper-split-export-declaration': 7.22.6 semver: 6.3.1 - transitivePeerDependencies: - - supports-color dev: false - /@babel/helper-create-regexp-features-plugin@7.21.8(@babel/core@7.21.8): - resolution: {integrity: sha512-zGuSdedkFtsFHGbexAvNuipg1hbtitDLo2XE8/uf6Y9sOQV1xsYX/2pNbtedp/X0eU1pIt+kGvaqHCowkRbS5g==} + /@babel/helper-create-regexp-features-plugin@7.22.15(@babel/core@7.23.9): + resolution: {integrity: sha512-29FkPLFjn4TPEa3RE7GpW+qbE8tlsu3jntNYNfcGsc49LphF1PQIiD+vMZ1z1xVOKt+93khA9tc2JBs3kBjA7w==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-annotate-as-pure': 7.18.6 + '@babel/core': 7.23.9 + '@babel/helper-annotate-as-pure': 7.22.5 regexpu-core: 5.3.2 semver: 6.3.1 dev: false - /@babel/helper-define-polyfill-provider@0.3.3(@babel/core@7.21.8): - resolution: {integrity: sha512-z5aQKU4IzbqCC1XH0nAqfsFLMVSo22SBKUc0BxGrLkolTdPTructy0ToNnlO2zA4j9Q/7pjMZf0DSY+DSTYzww==} + /@babel/helper-define-polyfill-provider@0.5.0(@babel/core@7.23.9): + resolution: {integrity: sha512-NovQquuQLAQ5HuyjCz7WQP9MjRj7dx++yspwiyUiGl9ZyadHRSql1HZh5ogRd8W8w6YM6EQ/NTB8rgjLt5W65Q==} peerDependencies: - '@babel/core': ^7.4.0-0 + '@babel/core': ^7.4.0 || ^8.0.0-0 <8.0.0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-compilation-targets': 7.21.5(@babel/core@7.21.8) - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-compilation-targets': 7.23.6 + '@babel/helper-plugin-utils': 7.22.5 debug: 4.3.4(supports-color@8.1.1) lodash.debounce: 4.0.8 - resolve: 1.22.3 - semver: 6.3.1 + resolve: 1.22.8 transitivePeerDependencies: - supports-color dev: false - /@babel/helper-environment-visitor@7.21.5: - resolution: {integrity: sha512-IYl4gZ3ETsWocUWgsFZLM5i1BYx9SoemminVEXadgLBa9TdeorzgLKm8wWLA6J1N/kT3Kch8XIk1laNzYoHKvQ==} + /@babel/helper-environment-visitor@7.22.20: + resolution: {integrity: sha512-zfedSIzFhat/gFhWfHtgWvlec0nqB9YEIVrpuwjruLlXfUSnA8cJB0miHKwqDnQ7d32aKo2xt88/xZptwxbfhA==} engines: {node: '>=6.9.0'} - dev: false - /@babel/helper-function-name@7.21.0: - resolution: {integrity: sha512-HfK1aMRanKHpxemaY2gqBmL04iAPOPRj7DxtNbiDOrJK+gdwkiNRVpCpUJYbUT+aZyemKN8brqTOxzCaG6ExRg==} + /@babel/helper-function-name@7.23.0: + resolution: {integrity: sha512-OErEqsrxjZTJciZ4Oo+eoZqeW9UIiOcuYKRJA4ZAgV9myA+pOXhhmpfNCKjEH/auVfEYVFJ6y1Tc4r0eIApqiw==} engines: {node: '>=6.9.0'} dependencies: - '@babel/template': 7.20.7 - '@babel/types': 7.21.5 - dev: false + '@babel/template': 7.23.9 + '@babel/types': 7.23.9 - /@babel/helper-hoist-variables@7.18.6: - resolution: {integrity: sha512-UlJQPkFqFULIcyW5sbzgbkxn2FKRgwWiRexcuaR8RNJRy8+LLveqPjwZV/bwrLZCN0eUHD/x8D0heK1ozuoo6Q==} + /@babel/helper-hoist-variables@7.22.5: + resolution: {integrity: sha512-wGjk9QZVzvknA6yKIUURb8zY3grXCcOZt+/7Wcy8O2uctxhplmUPkOdlgoNhmdVee2c92JXbf1xpMtVNbfoxRw==} engines: {node: '>=6.9.0'} dependencies: - '@babel/types': 7.21.5 - dev: false + '@babel/types': 7.23.9 - /@babel/helper-member-expression-to-functions@7.21.5: - resolution: {integrity: sha512-nIcGfgwpH2u4n9GG1HpStW5Ogx7x7ekiFHbjjFRKXbn5zUvqO9ZgotCO4x1aNbKn/x/xOUaXEhyNHCwtFCpxWg==} + /@babel/helper-member-expression-to-functions@7.23.0: + resolution: {integrity: sha512-6gfrPwh7OuT6gZyJZvd6WbTfrqAo7vm4xCzAXOusKqq/vWdKXphTpj5klHKNmRUU6/QRGlBsyU9mAIPaWHlqJA==} engines: {node: '>=6.9.0'} dependencies: - '@babel/types': 7.21.5 + '@babel/types': 7.23.9 dev: false - /@babel/helper-module-imports@7.21.4: - resolution: {integrity: sha512-orajc5T2PsRYUN3ZryCEFeMDYwyw09c/pZeaQEZPH0MpKzSvn3e0uXsDBu3k03VI+9DBiRo+l22BfKTpKwa/Wg==} + /@babel/helper-module-imports@7.22.15: + resolution: {integrity: sha512-0pYVBnDKZO2fnSPCrgM/6WMc7eS20Fbok+0r88fp+YtWVLZrp4CkafFGIp+W0VKw4a22sgebPT99y+FDNMdP4w==} engines: {node: '>=6.9.0'} dependencies: - '@babel/types': 7.21.5 - dev: false + '@babel/types': 7.23.9 - /@babel/helper-module-transforms@7.21.5: - resolution: {integrity: sha512-bI2Z9zBGY2q5yMHoBvJ2a9iX3ZOAzJPm7Q8Yz6YeoUjU/Cvhmi2G4QyTNyPBqqXSgTjUxRg3L0xV45HvkNWWBw==} + /@babel/helper-module-transforms@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-7bBs4ED9OmswdfDzpz4MpWgSrV7FXlc3zIagvLFjS5H+Mk7Snr21vQ6QwrsoCGMfNC4e4LQPdoULEt4ykz0SRQ==} engines: {node: '>=6.9.0'} + peerDependencies: + '@babel/core': ^7.0.0 dependencies: - '@babel/helper-environment-visitor': 7.21.5 - '@babel/helper-module-imports': 7.21.4 - '@babel/helper-simple-access': 7.21.5 - '@babel/helper-split-export-declaration': 7.18.6 - '@babel/helper-validator-identifier': 7.19.1 - '@babel/template': 7.20.7 - '@babel/traverse': 7.21.5 - '@babel/types': 7.21.5 - transitivePeerDependencies: - - supports-color - dev: false + '@babel/core': 7.23.9 + '@babel/helper-environment-visitor': 7.22.20 + '@babel/helper-module-imports': 7.22.15 + '@babel/helper-simple-access': 7.22.5 + '@babel/helper-split-export-declaration': 7.22.6 + '@babel/helper-validator-identifier': 7.22.20 - /@babel/helper-optimise-call-expression@7.18.6: - resolution: {integrity: sha512-HP59oD9/fEHQkdcbgFCnbmgH5vIQTJbxh2yf+CdM89/glUNnuzr87Q8GIjGEnOktTROemO0Pe0iPAYbqZuOUiA==} + /@babel/helper-optimise-call-expression@7.22.5: + resolution: {integrity: sha512-HBwaojN0xFRx4yIvpwGqxiV2tUfl7401jlok564NgB9EHS1y6QT17FmKWm4ztqjeVdXLuC4fSvHc5ePpQjoTbw==} engines: {node: '>=6.9.0'} dependencies: - '@babel/types': 7.21.5 + '@babel/types': 7.23.9 dev: false - /@babel/helper-plugin-utils@7.21.5: - resolution: {integrity: sha512-0WDaIlXKOX/3KfBK/dwP1oQGiPh6rjMkT7HIRv7i5RR2VUMwrx5ZL0dwBkKx7+SW1zwNdgjHd34IMk5ZjTeHVg==} + /@babel/helper-plugin-utils@7.22.5: + resolution: {integrity: sha512-uLls06UVKgFG9QD4OeFYLEGteMIAa5kpTPcFL28yuCIIzsf6ZyKZMllKVOCZFhiZ5ptnwX4mtKdWCBE/uT4amg==} engines: {node: '>=6.9.0'} - dev: false - /@babel/helper-remap-async-to-generator@7.18.9(@babel/core@7.21.8): - resolution: {integrity: sha512-dI7q50YKd8BAv3VEfgg7PS7yD3Rtbi2J1XMXaalXO0W0164hYLnh8zpjRS0mte9MfVp/tltvr/cfdXPvJr1opA==} + /@babel/helper-remap-async-to-generator@7.22.20(@babel/core@7.23.9): + resolution: {integrity: sha512-pBGyV4uBqOns+0UvhsTO8qgl8hO89PmiDYv+/COyp1aeMcmfrfruz+/nCMFiYyFF/Knn0yfrC85ZzNFjembFTw==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-annotate-as-pure': 7.18.6 - '@babel/helper-environment-visitor': 7.21.5 - '@babel/helper-wrap-function': 7.20.5 - '@babel/types': 7.21.5 - transitivePeerDependencies: - - supports-color + '@babel/core': 7.23.9 + '@babel/helper-annotate-as-pure': 7.22.5 + '@babel/helper-environment-visitor': 7.22.20 + '@babel/helper-wrap-function': 7.22.20 dev: false - /@babel/helper-replace-supers@7.21.5: - resolution: {integrity: sha512-/y7vBgsr9Idu4M6MprbOVUfH3vs7tsIfnVWv/Ml2xgwvyH6LTngdfbf5AdsKwkJy4zgy1X/kuNrEKvhhK28Yrg==} + /@babel/helper-replace-supers@7.22.20(@babel/core@7.23.9): + resolution: {integrity: sha512-qsW0In3dbwQUbK8kejJ4R7IHVGwHJlV6lpG6UA7a9hSa2YEiAib+N1T2kr6PEeUT+Fl7najmSOS6SmAwCHK6Tw==} engines: {node: '>=6.9.0'} + peerDependencies: + '@babel/core': ^7.0.0 dependencies: - '@babel/helper-environment-visitor': 7.21.5 - '@babel/helper-member-expression-to-functions': 7.21.5 - '@babel/helper-optimise-call-expression': 7.18.6 - '@babel/template': 7.20.7 - '@babel/traverse': 7.21.5 - '@babel/types': 7.21.5 - transitivePeerDependencies: - - supports-color + '@babel/core': 7.23.9 + '@babel/helper-environment-visitor': 7.22.20 + '@babel/helper-member-expression-to-functions': 7.23.0 + '@babel/helper-optimise-call-expression': 7.22.5 dev: false - /@babel/helper-simple-access@7.21.5: - resolution: {integrity: sha512-ENPDAMC1wAjR0uaCUwliBdiSl1KBJAVnMTzXqi64c2MG8MPR6ii4qf7bSXDqSFbr4W6W028/rf5ivoHop5/mkg==} + /@babel/helper-simple-access@7.22.5: + resolution: {integrity: sha512-n0H99E/K+Bika3++WNL17POvo4rKWZ7lZEp1Q+fStVbUi8nxPQEBOlTmCOxW/0JsS56SKKQ+ojAe2pHKJHN35w==} engines: {node: '>=6.9.0'} dependencies: - '@babel/types': 7.21.5 - dev: false + '@babel/types': 7.23.9 - /@babel/helper-skip-transparent-expression-wrappers@7.20.0: - resolution: {integrity: sha512-5y1JYeNKfvnT8sZcK9DVRtpTbGiomYIHviSP3OQWmDPU3DeH4a1ZlT/N2lyQ5P8egjcRaT/Y9aNqUxK0WsnIIg==} + /@babel/helper-skip-transparent-expression-wrappers@7.22.5: + resolution: {integrity: sha512-tK14r66JZKiC43p8Ki33yLBVJKlQDFoA8GYN67lWCDCqoL6EMMSuM9b+Iff2jHaM/RRFYl7K+iiru7hbRqNx8Q==} engines: {node: '>=6.9.0'} dependencies: - '@babel/types': 7.21.5 + '@babel/types': 7.23.9 dev: false - /@babel/helper-split-export-declaration@7.18.6: - resolution: {integrity: sha512-bde1etTx6ZyTmobl9LLMMQsaizFVZrquTEHOqKeQESMKo4PlObf+8+JA25ZsIpZhT/WEd39+vOdLXAFG/nELpA==} + /@babel/helper-split-export-declaration@7.22.6: + resolution: {integrity: sha512-AsUnxuLhRYsisFiaJwvp1QF+I3KjD5FOxut14q/GzovUe6orHLesW2C7d754kRm53h5gqrz6sFl6sxc4BVtE/g==} engines: {node: '>=6.9.0'} dependencies: - '@babel/types': 7.21.5 - dev: false - - /@babel/helper-string-parser@7.21.5: - resolution: {integrity: sha512-5pTUx3hAJaZIdW99sJ6ZUUgWq/Y+Hja7TowEnLNMm1VivRgZQL3vpBY3qUACVsvw+yQU6+YgfBVmcbLaZtrA1w==} - engines: {node: '>=6.9.0'} - dev: false + '@babel/types': 7.23.9 - /@babel/helper-validator-identifier@7.19.1: - resolution: {integrity: sha512-awrNfaMtnHUr653GgGEs++LlAvW6w+DcPrOliSMXWCKo597CwL5Acf/wWdNkf/tfEQE3mjkeD1YOVZOUV/od1w==} + /@babel/helper-string-parser@7.23.4: + resolution: {integrity: sha512-803gmbQdqwdf4olxrX4AJyFBV/RTr3rSmOj0rKwesmzlfhYNDEs+/iOcznzpNWlJlIlTJC2QfPFcHB6DlzdVLQ==} engines: {node: '>=6.9.0'} - /@babel/helper-validator-identifier@7.22.5: - resolution: {integrity: sha512-aJXu+6lErq8ltp+JhkJUfk1MTGyuA4v7f3pA+BJ5HLfNC6nAQ0Cpi9uOquUj8Hehg0aUiHzWQbOVJGao6ztBAQ==} + /@babel/helper-validator-identifier@7.22.20: + resolution: {integrity: sha512-Y4OZ+ytlatR8AI+8KZfKuL5urKp7qey08ha31L8b3BwewJAoJamTzyvxPR/5D+KkdJCGPq/+8TukHBlY10FX9A==} engines: {node: '>=6.9.0'} - /@babel/helper-validator-option@7.21.0: - resolution: {integrity: sha512-rmL/B8/f0mKS2baE9ZpyTcTavvEuWhTTW8amjzXNvYG4AwBsqTLikfXsEofsJEfKHf+HQVQbFOHy6o+4cnC/fQ==} + /@babel/helper-validator-option@7.23.5: + resolution: {integrity: sha512-85ttAOMLsr53VgXkTbkx8oA6YTfT4q7/HzXSLEYmjcSTJPMPQtvq1BD79Byep5xMUYbGRzEpDsjUf3dyp54IKw==} engines: {node: '>=6.9.0'} - dev: false - /@babel/helper-wrap-function@7.20.5: - resolution: {integrity: sha512-bYMxIWK5mh+TgXGVqAtnu5Yn1un+v8DDZtqyzKRLUzrh70Eal2O3aZ7aPYiMADO4uKlkzOiRiZ6GX5q3qxvW9Q==} + /@babel/helper-wrap-function@7.22.20: + resolution: {integrity: sha512-pms/UwkOpnQe/PDAEdV/d7dVCoBbB+R4FvYoHGZz+4VPcg7RtYy2KP7S2lbuWM6FCSgob5wshfGESbC/hzNXZw==} engines: {node: '>=6.9.0'} dependencies: - '@babel/helper-function-name': 7.21.0 - '@babel/template': 7.20.7 - '@babel/traverse': 7.21.5 - '@babel/types': 7.21.5 - transitivePeerDependencies: - - supports-color + '@babel/helper-function-name': 7.23.0 + '@babel/template': 7.23.9 + '@babel/types': 7.23.9 dev: false - /@babel/helpers@7.21.5: - resolution: {integrity: sha512-BSY+JSlHxOmGsPTydUkPf1MdMQ3M81x5xGCOVgWM3G8XH77sJ292Y2oqcp0CbbgxhqBuI46iUz1tT7hqP7EfgA==} + /@babel/helpers@7.23.9: + resolution: {integrity: sha512-87ICKgU5t5SzOT7sBMfCOZQ2rHjRU+Pcb9BoILMYz600W6DkVRLFBPwQ18gwUVvggqXivaUakpnxWQGbpywbBQ==} engines: {node: '>=6.9.0'} dependencies: - '@babel/template': 7.20.7 - '@babel/traverse': 7.21.5 - '@babel/types': 7.21.5 + '@babel/template': 7.23.9 + '@babel/traverse': 7.23.9 + '@babel/types': 7.23.9 transitivePeerDependencies: - supports-color - dev: false - /@babel/highlight@7.18.6: - resolution: {integrity: sha512-u7stbOuYjaPezCuLj29hNW1v64M2Md2qupEKP1fHc7WdOA3DgLh37suiSrZYY7haUB7iBeQZ9P1uiRF359do3g==} + /@babel/highlight@7.23.4: + resolution: {integrity: sha512-acGdbYSfp2WheJoJm/EBBBLh/ID8KDc64ISZ9DYtBmC8/Q204PZJLHyzeB5qMzJ5trcOkybd78M4x2KWsUq++A==} engines: {node: '>=6.9.0'} dependencies: - '@babel/helper-validator-identifier': 7.19.1 + '@babel/helper-validator-identifier': 7.22.20 chalk: 2.4.2 js-tokens: 4.0.0 - /@babel/parser@7.21.8: - resolution: {integrity: sha512-6zavDGdzG3gUqAdWvlLFfk+36RilI+Pwyuuh7HItyeScCWP3k6i8vKclAQ0bM/0y/Kz/xiwvxhMv9MgTJP5gmA==} + /@babel/parser@7.23.9: + resolution: {integrity: sha512-9tcKgqKbs3xGJ+NtKF2ndOBBLVwPjl1SHxPQkd36r3Dlirw3xWUeGaTbqr7uGZcTaxkVNwc+03SVP7aCdWrTlA==} engines: {node: '>=6.0.0'} hasBin: true dependencies: - '@babel/types': 7.21.5 - dev: false + '@babel/types': 7.23.9 - /@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression@7.18.6(@babel/core@7.21.8): - resolution: {integrity: sha512-Dgxsyg54Fx1d4Nge8UnvTrED63vrwOdPmyvPzlNN/boaliRP54pm3pGzZD1SJUwrBA+Cs/xdG8kXX6Mn/RfISQ==} + /@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-iRkKcCqb7iGnq9+3G6rZ+Ciz5VywC4XNRHe57lKM+jOeYAoR0lVqdeeDRfh0tQcTfw/+vBhHn926FmQhLtlFLQ==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining@7.20.7(@babel/core@7.21.8): - resolution: {integrity: sha512-sbr9+wNE5aXMBBFBICk01tt7sBf2Oc9ikRFEcem/ZORup9IMUdNhW7/wVLEbbtlWOsEubJet46mHAL2C8+2jKQ==} + /@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-WwlxbfMNdVEpQjZmK5mhm7oSwD3dS6eU+Iwsi4Knl9wAletWem7kaRsGOG+8UEbRyqxY4SS5zvtfXwX+jMxUwQ==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.13.0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 - '@babel/helper-skip-transparent-expression-wrappers': 7.20.0 - '@babel/plugin-proposal-optional-chaining': 7.21.0(@babel/core@7.21.8) + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 + '@babel/helper-skip-transparent-expression-wrappers': 7.22.5 + '@babel/plugin-transform-optional-chaining': 7.23.4(@babel/core@7.23.9) dev: false - /@babel/plugin-proposal-async-generator-functions@7.20.7(@babel/core@7.21.8): - resolution: {integrity: sha512-xMbiLsn/8RK7Wq7VeVytytS2L6qE69bXPB10YCmMdDZbKF4okCqY74pI/jJQ/8U0b/F6NrT2+14b8/P9/3AMGA==} + /@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly@7.23.7(@babel/core@7.23.9): + resolution: {integrity: sha512-LlRT7HgaifEpQA1ZgLVOIJZZFVPWN5iReq/7/JixwBtwcoeVGDBD53ZV28rrsLYOZs1Y/EHhA8N/Z6aazHR8cw==} engines: {node: '>=6.9.0'} - deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-async-generator-functions instead. peerDependencies: - '@babel/core': ^7.0.0-0 + '@babel/core': ^7.0.0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-environment-visitor': 7.21.5 - '@babel/helper-plugin-utils': 7.21.5 - '@babel/helper-remap-async-to-generator': 7.18.9(@babel/core@7.21.8) - '@babel/plugin-syntax-async-generators': 7.8.4(@babel/core@7.21.8) - transitivePeerDependencies: - - supports-color + '@babel/core': 7.23.9 + '@babel/helper-environment-visitor': 7.22.20 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-proposal-class-properties@7.18.6(@babel/core@7.21.8): - resolution: {integrity: sha512-cumfXOF0+nzZrrN8Rf0t7M+tF6sZc7vhQwYQck9q1/5w2OExlD+b4v4RpMJFaV1Z7WcDRgO6FqvxqxGlwo+RHQ==} + /@babel/plugin-proposal-private-property-in-object@7.21.0-placeholder-for-preset-env.2(@babel/core@7.23.9): + resolution: {integrity: sha512-SOSkfJDddaM7mak6cPEpswyTRnuRltl429hMraQEglW+OkovnCzsiszTmsrlY//qLFjCpQDFRvjdm2wA5pPm9w==} engines: {node: '>=6.9.0'} - deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-class-properties instead. peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-create-class-features-plugin': 7.21.8(@babel/core@7.21.8) - '@babel/helper-plugin-utils': 7.21.5 - transitivePeerDependencies: - - supports-color + '@babel/core': 7.23.9 dev: false - /@babel/plugin-proposal-class-static-block@7.21.0(@babel/core@7.21.8): - resolution: {integrity: sha512-XP5G9MWNUskFuP30IfFSEFB0Z6HzLIUcjYM4bYOPHXl7eiJ9HFv8tWj6TXTN5QODiEhDZAeI4hLok2iHFFV4hw==} - engines: {node: '>=6.9.0'} - deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-class-static-block instead. + /@babel/plugin-syntax-async-generators@7.8.4(@babel/core@7.23.9): + resolution: {integrity: sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==} peerDependencies: - '@babel/core': ^7.12.0 + '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-create-class-features-plugin': 7.21.8(@babel/core@7.21.8) - '@babel/helper-plugin-utils': 7.21.5 - '@babel/plugin-syntax-class-static-block': 7.14.5(@babel/core@7.21.8) - transitivePeerDependencies: - - supports-color + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-proposal-dynamic-import@7.18.6(@babel/core@7.21.8): - resolution: {integrity: sha512-1auuwmK+Rz13SJj36R+jqFPMJWyKEDd7lLSdOj4oJK0UTgGueSAtkrCvz9ewmgyU/P941Rv2fQwZJN8s6QruXw==} - engines: {node: '>=6.9.0'} - deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-dynamic-import instead. + /@babel/plugin-syntax-class-properties@7.12.13(@babel/core@7.23.9): + resolution: {integrity: sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 - '@babel/plugin-syntax-dynamic-import': 7.8.3(@babel/core@7.21.8) + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-proposal-export-namespace-from@7.18.9(@babel/core@7.21.8): - resolution: {integrity: sha512-k1NtHyOMvlDDFeb9G5PhUXuGj8m/wiwojgQVEhJ/fsVsMCpLyOP4h0uGEjYJKrRI+EVPlb5Jk+Gt9P97lOGwtA==} + /@babel/plugin-syntax-class-static-block@7.14.5(@babel/core@7.23.9): + resolution: {integrity: sha512-b+YyPmr6ldyNnM6sqYeMWE+bgJcJpO6yS4QD7ymxgH34GBPNDM/THBh8iunyvKIZztiwLH4CJZ0RxTk9emgpjw==} engines: {node: '>=6.9.0'} - deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-export-namespace-from instead. peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 - '@babel/plugin-syntax-export-namespace-from': 7.8.3(@babel/core@7.21.8) + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-proposal-json-strings@7.18.6(@babel/core@7.21.8): - resolution: {integrity: sha512-lr1peyn9kOdbYc0xr0OdHTZ5FMqS6Di+H0Fz2I/JwMzGmzJETNeOFq2pBySw6X/KFL5EWDjlJuMsUGRFb8fQgQ==} - engines: {node: '>=6.9.0'} - deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-json-strings instead. + /@babel/plugin-syntax-dynamic-import@7.8.3(@babel/core@7.23.9): + resolution: {integrity: sha512-5gdGbFon+PszYzqs83S3E5mpi7/y/8M9eC90MRTZfduQOYW76ig6SOSPNe41IG5LoP3FGBn2N0RjVDSQiS94kQ==} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 - '@babel/plugin-syntax-json-strings': 7.8.3(@babel/core@7.21.8) + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-proposal-logical-assignment-operators@7.20.7(@babel/core@7.21.8): - resolution: {integrity: sha512-y7C7cZgpMIjWlKE5T7eJwp+tnRYM89HmRvWM5EQuB5BoHEONjmQ8lSNmBUwOyy/GFRsohJED51YBF79hE1djug==} - engines: {node: '>=6.9.0'} - deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-logical-assignment-operators instead. + /@babel/plugin-syntax-export-namespace-from@7.8.3(@babel/core@7.23.9): + resolution: {integrity: sha512-MXf5laXo6c1IbEbegDmzGPwGNTsHZmEy6QGznu5Sh2UCWvueywb2ee+CCE4zQiZstxU9BMoQO9i6zUFSY0Kj0Q==} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 - '@babel/plugin-syntax-logical-assignment-operators': 7.10.4(@babel/core@7.21.8) + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-proposal-nullish-coalescing-operator@7.18.6(@babel/core@7.21.8): - resolution: {integrity: sha512-wQxQzxYeJqHcfppzBDnm1yAY0jSRkUXR2z8RePZYrKwMKgMlE8+Z6LUno+bd6LvbGh8Gltvy74+9pIYkr+XkKA==} + /@babel/plugin-syntax-import-assertions@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-lPgDSU+SJLK3xmFDTV2ZRQAiM7UuUjGidwBywFavObCiZc1BeAAcMtHJKUya92hPHO+at63JJPLygilZard8jw==} engines: {node: '>=6.9.0'} - deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-nullish-coalescing-operator instead. peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 - '@babel/plugin-syntax-nullish-coalescing-operator': 7.8.3(@babel/core@7.21.8) + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-proposal-numeric-separator@7.18.6(@babel/core@7.21.8): - resolution: {integrity: sha512-ozlZFogPqoLm8WBr5Z8UckIoE4YQ5KESVcNudyXOR8uqIkliTEgJ3RoketfG6pmzLdeZF0H/wjE9/cCEitBl7Q==} + /@babel/plugin-syntax-import-attributes@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-pawnE0P9g10xgoP7yKr6CK63K2FMsTE+FZidZO/1PwRdzmAPVs+HS1mAURUsgaoxammTJvULUdIkEK0gOcU2tA==} engines: {node: '>=6.9.0'} - deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-numeric-separator instead. peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 - '@babel/plugin-syntax-numeric-separator': 7.10.4(@babel/core@7.21.8) + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-proposal-object-rest-spread@7.20.7(@babel/core@7.21.8): - resolution: {integrity: sha512-d2S98yCiLxDVmBmE8UjGcfPvNEUbA1U5q5WxaWFUGRzJSVAZqm5W6MbPct0jxnegUZ0niLeNX+IOzEs7wYg9Dg==} - engines: {node: '>=6.9.0'} - deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-object-rest-spread instead. + /@babel/plugin-syntax-import-meta@7.10.4(@babel/core@7.23.9): + resolution: {integrity: sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g==} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/compat-data': 7.21.7 - '@babel/core': 7.21.8 - '@babel/helper-compilation-targets': 7.21.5(@babel/core@7.21.8) - '@babel/helper-plugin-utils': 7.21.5 - '@babel/plugin-syntax-object-rest-spread': 7.8.3(@babel/core@7.21.8) - '@babel/plugin-transform-parameters': 7.21.3(@babel/core@7.21.8) + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-proposal-optional-catch-binding@7.18.6(@babel/core@7.21.8): - resolution: {integrity: sha512-Q40HEhs9DJQyaZfUjjn6vE8Cv4GmMHCYuMGIWUnlxH6400VGxOuwWsPt4FxXxJkC/5eOzgn0z21M9gMT4MOhbw==} - engines: {node: '>=6.9.0'} - deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-optional-catch-binding instead. + /@babel/plugin-syntax-json-strings@7.8.3(@babel/core@7.23.9): + resolution: {integrity: sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 - '@babel/plugin-syntax-optional-catch-binding': 7.8.3(@babel/core@7.21.8) + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-proposal-optional-chaining@7.21.0(@babel/core@7.21.8): - resolution: {integrity: sha512-p4zeefM72gpmEe2fkUr/OnOXpWEf8nAgk7ZYVqqfFiyIG7oFfVZcCrU64hWn5xp4tQ9LkV4bTIa5rD0KANpKNA==} - engines: {node: '>=6.9.0'} - deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-optional-chaining instead. + /@babel/plugin-syntax-logical-assignment-operators@7.10.4(@babel/core@7.23.9): + resolution: {integrity: sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 - '@babel/helper-skip-transparent-expression-wrappers': 7.20.0 - '@babel/plugin-syntax-optional-chaining': 7.8.3(@babel/core@7.21.8) + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-proposal-private-methods@7.18.6(@babel/core@7.21.8): - resolution: {integrity: sha512-nutsvktDItsNn4rpGItSNV2sz1XwS+nfU0Rg8aCx3W3NOKVzdMjJRu0O5OkgDp3ZGICSTbgRpxZoWsxoKRvbeA==} - engines: {node: '>=6.9.0'} - deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-private-methods instead. + /@babel/plugin-syntax-nullish-coalescing-operator@7.8.3(@babel/core@7.23.9): + resolution: {integrity: sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-create-class-features-plugin': 7.21.8(@babel/core@7.21.8) - '@babel/helper-plugin-utils': 7.21.5 - transitivePeerDependencies: - - supports-color + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-proposal-private-property-in-object@7.21.0(@babel/core@7.21.8): - resolution: {integrity: sha512-ha4zfehbJjc5MmXBlHec1igel5TJXXLDDRbuJ4+XT2TJcyD9/V1919BA8gMvsdHcNMBy4WBUBiRb3nw/EQUtBw==} - engines: {node: '>=6.9.0'} - deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-private-property-in-object instead. + /@babel/plugin-syntax-numeric-separator@7.10.4(@babel/core@7.23.9): + resolution: {integrity: sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-annotate-as-pure': 7.18.6 - '@babel/helper-create-class-features-plugin': 7.21.8(@babel/core@7.21.8) - '@babel/helper-plugin-utils': 7.21.5 - '@babel/plugin-syntax-private-property-in-object': 7.14.5(@babel/core@7.21.8) - transitivePeerDependencies: - - supports-color + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-proposal-unicode-property-regex@7.18.6(@babel/core@7.21.8): - resolution: {integrity: sha512-2BShG/d5yoZyXZfVePH91urL5wTG6ASZU9M4o03lKK8u8UW1y08OMttBSOADTcJrnPMpvDXRG3G8fyLh4ovs8w==} - engines: {node: '>=4'} - deprecated: This proposal has been merged to the ECMAScript standard and thus this plugin is no longer maintained. Please use @babel/plugin-transform-unicode-property-regex instead. + /@babel/plugin-syntax-object-rest-spread@7.8.3(@babel/core@7.23.9): + resolution: {integrity: sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-create-regexp-features-plugin': 7.21.8(@babel/core@7.21.8) - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-syntax-async-generators@7.8.4(@babel/core@7.21.8): - resolution: {integrity: sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==} + /@babel/plugin-syntax-optional-catch-binding@7.8.3(@babel/core@7.23.9): + resolution: {integrity: sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-syntax-class-properties@7.12.13(@babel/core@7.21.8): - resolution: {integrity: sha512-fm4idjKla0YahUNgFNLCB0qySdsoPiZP3iQE3rky0mBUtMZ23yDJ9SJdg6dXTSDnulOVqiF3Hgr9nbXvXTQZYA==} + /@babel/plugin-syntax-optional-chaining@7.8.3(@babel/core@7.23.9): + resolution: {integrity: sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-syntax-class-static-block@7.14.5(@babel/core@7.21.8): - resolution: {integrity: sha512-b+YyPmr6ldyNnM6sqYeMWE+bgJcJpO6yS4QD7ymxgH34GBPNDM/THBh8iunyvKIZztiwLH4CJZ0RxTk9emgpjw==} + /@babel/plugin-syntax-private-property-in-object@7.14.5(@babel/core@7.23.9): + resolution: {integrity: sha512-0wVnp9dxJ72ZUJDV27ZfbSj6iHLoytYZmh3rFcxNnvsJF3ktkzLDZPy/mA17HGsaQT3/DQsWYX1f1QGWkCoVUg==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-syntax-dynamic-import@7.8.3(@babel/core@7.21.8): - resolution: {integrity: sha512-5gdGbFon+PszYzqs83S3E5mpi7/y/8M9eC90MRTZfduQOYW76ig6SOSPNe41IG5LoP3FGBn2N0RjVDSQiS94kQ==} + /@babel/plugin-syntax-top-level-await@7.14.5(@babel/core@7.23.9): + resolution: {integrity: sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==} + engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-syntax-export-namespace-from@7.8.3(@babel/core@7.21.8): - resolution: {integrity: sha512-MXf5laXo6c1IbEbegDmzGPwGNTsHZmEy6QGznu5Sh2UCWvueywb2ee+CCE4zQiZstxU9BMoQO9i6zUFSY0Kj0Q==} + /@babel/plugin-syntax-unicode-sets-regex@7.18.6(@babel/core@7.23.9): + resolution: {integrity: sha512-727YkEAPwSIQTv5im8QHz3upqp92JTWhidIC81Tdx4VJYIte/VndKf1qKrfnnhPLiPghStWfvC/iFaMCQu7Nqg==} + engines: {node: '>=6.9.0'} + peerDependencies: + '@babel/core': ^7.0.0 + dependencies: + '@babel/core': 7.23.9 + '@babel/helper-create-regexp-features-plugin': 7.22.15(@babel/core@7.23.9) + '@babel/helper-plugin-utils': 7.22.5 + dev: false + + /@babel/plugin-transform-arrow-functions@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-NzQcQrzaQPkaEwoTm4Mhyl8jI1huEL/WWIEvudjTCMJ9aBZNpsJbMASx7EQECtQQPS/DcnFpo0FIh3LvEO9cxQ==} + engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-syntax-import-assertions@7.20.0(@babel/core@7.21.8): - resolution: {integrity: sha512-IUh1vakzNoWalR8ch/areW7qFopR2AEw03JlG7BbrDqmQ4X3q9uuipQwSGrUn7oGiemKjtSLDhNtQHzMHr1JdQ==} + /@babel/plugin-transform-async-generator-functions@7.23.9(@babel/core@7.23.9): + resolution: {integrity: sha512-8Q3veQEDGe14dTYuwagbRtwxQDnytyg1JFu4/HwEMETeofocrB0U0ejBJIXoeG/t2oXZ8kzCyI0ZZfbT80VFNQ==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-environment-visitor': 7.22.20 + '@babel/helper-plugin-utils': 7.22.5 + '@babel/helper-remap-async-to-generator': 7.22.20(@babel/core@7.23.9) + '@babel/plugin-syntax-async-generators': 7.8.4(@babel/core@7.23.9) dev: false - /@babel/plugin-syntax-import-meta@7.10.4(@babel/core@7.21.8): - resolution: {integrity: sha512-Yqfm+XDx0+Prh3VSeEQCPU81yC+JWZ2pDPFSS4ZdpfZhp4MkFMaDC1UqseovEKwSUpnIL7+vK+Clp7bfh0iD7g==} + /@babel/plugin-transform-async-to-generator@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-A7LFsKi4U4fomjqXJlZg/u0ft/n8/7n7lpffUP/ZULx/DtV9SGlNKZolHH6PE8Xl1ngCc0M11OaeZptXVkfKSw==} + engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-module-imports': 7.22.15 + '@babel/helper-plugin-utils': 7.22.5 + '@babel/helper-remap-async-to-generator': 7.22.20(@babel/core@7.23.9) dev: false - /@babel/plugin-syntax-json-strings@7.8.3(@babel/core@7.21.8): - resolution: {integrity: sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==} + /@babel/plugin-transform-block-scoped-functions@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-vI+0sIaPIO6CNuM9Kk5VmXcMVRiOpDh7w2zZt9GXzmE/9KD70CUEVhvPR/etAeNK/FAEkhxQtXOzVF3EuRL41A==} + engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-syntax-logical-assignment-operators@7.10.4(@babel/core@7.21.8): - resolution: {integrity: sha512-d8waShlpFDinQ5MtvGU9xDAOzKH47+FFoney2baFIoMr952hKOLp1HR7VszoZvOsV/4+RRszNY7D17ba0te0ig==} + /@babel/plugin-transform-block-scoping@7.23.4(@babel/core@7.23.9): + resolution: {integrity: sha512-0QqbP6B6HOh7/8iNR4CQU2Th/bbRtBp4KS9vcaZd1fZ0wSh5Fyssg0UCIHwxh+ka+pNDREbVLQnHCMHKZfPwfw==} + engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-syntax-nullish-coalescing-operator@7.8.3(@babel/core@7.21.8): - resolution: {integrity: sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==} + /@babel/plugin-transform-class-properties@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-uM+AN8yCIjDPccsKGlw271xjJtGii+xQIF/uMPS8H15L12jZTsLfF4o5vNO7d/oUguOyfdikHGc/yi9ge4SGIg==} + engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-create-class-features-plugin': 7.23.10(@babel/core@7.23.9) + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-syntax-numeric-separator@7.10.4(@babel/core@7.21.8): - resolution: {integrity: sha512-9H6YdfkcK/uOnY/K7/aA2xpzaAgkQn37yzWUMRK7OaPOqOpGS1+n0H5hxT9AUw9EsSjPW8SVyMJwYRtWs3X3ug==} + /@babel/plugin-transform-class-static-block@7.23.4(@babel/core@7.23.9): + resolution: {integrity: sha512-nsWu/1M+ggti1SOALj3hfx5FXzAY06fwPJsUZD4/A5e1bWi46VUIWtD+kOX6/IdhXGsXBWllLFDSnqSCdUNydQ==} + engines: {node: '>=6.9.0'} + peerDependencies: + '@babel/core': ^7.12.0 + dependencies: + '@babel/core': 7.23.9 + '@babel/helper-create-class-features-plugin': 7.23.10(@babel/core@7.23.9) + '@babel/helper-plugin-utils': 7.22.5 + '@babel/plugin-syntax-class-static-block': 7.14.5(@babel/core@7.23.9) + dev: false + + /@babel/plugin-transform-classes@7.23.8(@babel/core@7.23.9): + resolution: {integrity: sha512-yAYslGsY1bX6Knmg46RjiCiNSwJKv2IUC8qOdYKqMMr0491SXFhcHqOdRDeCRohOOIzwN/90C6mQ9qAKgrP7dg==} + engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-annotate-as-pure': 7.22.5 + '@babel/helper-compilation-targets': 7.23.6 + '@babel/helper-environment-visitor': 7.22.20 + '@babel/helper-function-name': 7.23.0 + '@babel/helper-plugin-utils': 7.22.5 + '@babel/helper-replace-supers': 7.22.20(@babel/core@7.23.9) + '@babel/helper-split-export-declaration': 7.22.6 + globals: 11.12.0 dev: false - /@babel/plugin-syntax-object-rest-spread@7.8.3(@babel/core@7.21.8): - resolution: {integrity: sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==} + /@babel/plugin-transform-computed-properties@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-dTj83UVTLw/+nbiHqQSFdwO9CbTtwq1DsDqm3CUEtDrZNET5rT5E6bIdTlOftDTDLMYxvxHNEYO4B9SLl8SLZw==} + engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 + '@babel/template': 7.23.9 dev: false - /@babel/plugin-syntax-optional-catch-binding@7.8.3(@babel/core@7.21.8): - resolution: {integrity: sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==} + /@babel/plugin-transform-destructuring@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-n225npDqjDIr967cMScVKHXJs7rout1q+tt50inyBCPkyZ8KxeI6d+GIbSBTT/w/9WdlWDOej3V9HE5Lgk57gw==} + engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-syntax-optional-chaining@7.8.3(@babel/core@7.21.8): - resolution: {integrity: sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==} + /@babel/plugin-transform-dotall-regex@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-vgnFYDHAKzFaTVp+mneDsIEbnJ2Np/9ng9iviHw3P/KVcgONxpNULEW/51Z/BaFojG2GI2GwwXck5uV1+1NOYQ==} + engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-create-regexp-features-plugin': 7.22.15(@babel/core@7.23.9) + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-syntax-private-property-in-object@7.14.5(@babel/core@7.21.8): - resolution: {integrity: sha512-0wVnp9dxJ72ZUJDV27ZfbSj6iHLoytYZmh3rFcxNnvsJF3ktkzLDZPy/mA17HGsaQT3/DQsWYX1f1QGWkCoVUg==} + /@babel/plugin-transform-duplicate-keys@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-RrqQ+BQmU3Oyav3J+7/myfvRCq7Tbz+kKLLshUmMwNlDHExbGL7ARhajvoBJEvc+fCguPPu887N+3RRXBVKZUA==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-syntax-top-level-await@7.14.5(@babel/core@7.21.8): - resolution: {integrity: sha512-hx++upLv5U1rgYfwe1xBQUhRmU41NEvpUvrp8jkrSCdvGSnM5/qdRMtylJ6PG5OFkBaHkbTAKTnd3/YyESRHFw==} + /@babel/plugin-transform-dynamic-import@7.23.4(@babel/core@7.23.9): + resolution: {integrity: sha512-V6jIbLhdJK86MaLh4Jpghi8ho5fGzt3imHOBu/x0jlBaPYqDoWz4RDXjmMOfnh+JWNaQleEAByZLV0QzBT4YQQ==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 + '@babel/plugin-syntax-dynamic-import': 7.8.3(@babel/core@7.23.9) dev: false - /@babel/plugin-transform-arrow-functions@7.21.5(@babel/core@7.21.8): - resolution: {integrity: sha512-wb1mhwGOCaXHDTcsRYMKF9e5bbMgqwxtqa2Y1ifH96dXJPwbuLX9qHy3clhrxVqgMz7nyNXs8VkxdH8UBcjKqA==} + /@babel/plugin-transform-exponentiation-operator@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-5fhCsl1odX96u7ILKHBj4/Y8vipoqwsJMh4csSA8qFfxrZDEA4Ssku2DyNvMJSmZNOEBT750LfFPbtrnTP90BQ==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-builder-binary-assignment-operator-visitor': 7.22.15 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-transform-async-to-generator@7.20.7(@babel/core@7.21.8): - resolution: {integrity: sha512-Uo5gwHPT9vgnSXQxqGtpdufUiWp96gk7yiP4Mp5bm1QMkEmLXBO7PAGYbKoJ6DhAwiNkcHFBol/x5zZZkL/t0Q==} + /@babel/plugin-transform-export-namespace-from@7.23.4(@babel/core@7.23.9): + resolution: {integrity: sha512-GzuSBcKkx62dGzZI1WVgTWvkkz84FZO5TC5T8dl/Tht/rAla6Dg/Mz9Yhypg+ezVACf/rgDuQt3kbWEv7LdUDQ==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-module-imports': 7.21.4 - '@babel/helper-plugin-utils': 7.21.5 - '@babel/helper-remap-async-to-generator': 7.18.9(@babel/core@7.21.8) - transitivePeerDependencies: - - supports-color + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 + '@babel/plugin-syntax-export-namespace-from': 7.8.3(@babel/core@7.23.9) dev: false - /@babel/plugin-transform-block-scoped-functions@7.18.6(@babel/core@7.21.8): - resolution: {integrity: sha512-ExUcOqpPWnliRcPqves5HJcJOvHvIIWfuS4sroBUenPuMdmW+SMHDakmtS7qOo13sVppmUijqeTv7qqGsvURpQ==} + /@babel/plugin-transform-for-of@7.23.6(@babel/core@7.23.9): + resolution: {integrity: sha512-aYH4ytZ0qSuBbpfhuofbg/e96oQ7U2w1Aw/UQmKT+1l39uEhUPoFS3fHevDc1G0OvewyDudfMKY1OulczHzWIw==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 + '@babel/helper-skip-transparent-expression-wrappers': 7.22.5 dev: false - /@babel/plugin-transform-block-scoping@7.21.0(@babel/core@7.21.8): - resolution: {integrity: sha512-Mdrbunoh9SxwFZapeHVrwFmri16+oYotcZysSzhNIVDwIAb1UV+kvnxULSYq9J3/q5MDG+4X6w8QVgD1zhBXNQ==} + /@babel/plugin-transform-function-name@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-I1QXp1LxIvt8yLaib49dRW5Okt7Q4oaxao6tFVKS/anCdEOMtYwWVKoiOA1p34GOWIZjUK0E+zCp7+l1pfQyiw==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-compilation-targets': 7.23.6 + '@babel/helper-function-name': 7.23.0 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-transform-classes@7.21.0(@babel/core@7.21.8): - resolution: {integrity: sha512-RZhbYTCEUAe6ntPehC4hlslPWosNHDox+vAs4On/mCLRLfoDVHf6hVEd7kuxr1RnHwJmxFfUM3cZiZRmPxJPXQ==} + /@babel/plugin-transform-json-strings@7.23.4(@babel/core@7.23.9): + resolution: {integrity: sha512-81nTOqM1dMwZ/aRXQ59zVubN9wHGqk6UtqRK+/q+ciXmRy8fSolhGVvG09HHRGo4l6fr/c4ZhXUQH0uFW7PZbg==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-annotate-as-pure': 7.18.6 - '@babel/helper-compilation-targets': 7.21.5(@babel/core@7.21.8) - '@babel/helper-environment-visitor': 7.21.5 - '@babel/helper-function-name': 7.21.0 - '@babel/helper-optimise-call-expression': 7.18.6 - '@babel/helper-plugin-utils': 7.21.5 - '@babel/helper-replace-supers': 7.21.5 - '@babel/helper-split-export-declaration': 7.18.6 - globals: 11.12.0 - transitivePeerDependencies: - - supports-color + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 + '@babel/plugin-syntax-json-strings': 7.8.3(@babel/core@7.23.9) dev: false - /@babel/plugin-transform-computed-properties@7.21.5(@babel/core@7.21.8): - resolution: {integrity: sha512-TR653Ki3pAwxBxUe8srfF3e4Pe3FTA46uaNHYyQwIoM4oWKSoOZiDNyHJ0oIoDIUPSRQbQG7jzgVBX3FPVne1Q==} + /@babel/plugin-transform-literals@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-wZ0PIXRxnwZvl9AYpqNUxpZ5BiTGrYt7kueGQ+N5FiQ7RCOD4cm8iShd6S6ggfVIWaJf2EMk8eRzAh52RfP4rQ==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 - '@babel/template': 7.20.7 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-transform-destructuring@7.21.3(@babel/core@7.21.8): - resolution: {integrity: sha512-bp6hwMFzuiE4HqYEyoGJ/V2LeIWn+hLVKc4pnj++E5XQptwhtcGmSayM029d/j2X1bPKGTlsyPwAubuU22KhMA==} + /@babel/plugin-transform-logical-assignment-operators@7.23.4(@babel/core@7.23.9): + resolution: {integrity: sha512-Mc/ALf1rmZTP4JKKEhUwiORU+vcfarFVLfcFiolKUo6sewoxSEgl36ak5t+4WamRsNr6nzjZXQjM35WsU+9vbg==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 + '@babel/plugin-syntax-logical-assignment-operators': 7.10.4(@babel/core@7.23.9) dev: false - /@babel/plugin-transform-dotall-regex@7.18.6(@babel/core@7.21.8): - resolution: {integrity: sha512-6S3jpun1eEbAxq7TdjLotAsl4WpQI9DxfkycRcKrjhQYzU87qpXdknpBg/e+TdcMehqGnLFi7tnFUBR02Vq6wg==} + /@babel/plugin-transform-member-expression-literals@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-sC3LdDBDi5x96LA+Ytekz2ZPk8i/Ck+DEuDbRAll5rknJ5XRTSaPKEYwomLcs1AA8wg9b3KjIQRsnApj+q51Ag==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-create-regexp-features-plugin': 7.21.8(@babel/core@7.21.8) - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-transform-duplicate-keys@7.18.9(@babel/core@7.21.8): - resolution: {integrity: sha512-d2bmXCtZXYc59/0SanQKbiWINadaJXqtvIQIzd4+hNwkWBgyCd5F/2t1kXoUdvPMrxzPvhK6EMQRROxsue+mfw==} + /@babel/plugin-transform-modules-amd@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-vJYQGxeKM4t8hYCKVBlZX/gtIY2I7mRGFNcm85sgXGMTBcoV3QdVtdpbcWEbzbfUIUZKwvgFT82mRvaQIebZzw==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-module-transforms': 7.23.3(@babel/core@7.23.9) + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-transform-exponentiation-operator@7.18.6(@babel/core@7.21.8): - resolution: {integrity: sha512-wzEtc0+2c88FVR34aQmiz56dxEkxr2g8DQb/KfaFa1JYXOFVsbhvAonFN6PwVWj++fKmku8NP80plJ5Et4wqHw==} + /@babel/plugin-transform-modules-commonjs@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-aVS0F65LKsdNOtcz6FRCpE4OgsP2OFnW46qNxNIX9h3wuzaNcSQsJysuMwqSibC98HPrf2vCgtxKNwS0DAlgcA==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-builder-binary-assignment-operator-visitor': 7.21.5 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-module-transforms': 7.23.3(@babel/core@7.23.9) + '@babel/helper-plugin-utils': 7.22.5 + '@babel/helper-simple-access': 7.22.5 dev: false - /@babel/plugin-transform-for-of@7.21.5(@babel/core@7.21.8): - resolution: {integrity: sha512-nYWpjKW/7j/I/mZkGVgHJXh4bA1sfdFnJoOXwJuj4m3Q2EraO/8ZyrkCau9P5tbHQk01RMSt6KYLCsW7730SXQ==} + /@babel/plugin-transform-modules-systemjs@7.23.9(@babel/core@7.23.9): + resolution: {integrity: sha512-KDlPRM6sLo4o1FkiSlXoAa8edLXFsKKIda779fbLrvmeuc3itnjCtaO6RrtoaANsIJANj+Vk1zqbZIMhkCAHVw==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-hoist-variables': 7.22.5 + '@babel/helper-module-transforms': 7.23.3(@babel/core@7.23.9) + '@babel/helper-plugin-utils': 7.22.5 + '@babel/helper-validator-identifier': 7.22.20 dev: false - /@babel/plugin-transform-function-name@7.18.9(@babel/core@7.21.8): - resolution: {integrity: sha512-WvIBoRPaJQ5yVHzcnJFor7oS5Ls0PYixlTYE63lCj2RtdQEl15M68FXQlxnG6wdraJIXRdR7KI+hQ7q/9QjrCQ==} + /@babel/plugin-transform-modules-umd@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-zHsy9iXX2nIsCBFPud3jKn1IRPWg3Ing1qOZgeKV39m1ZgIdpJqvlWVeiHBZC6ITRG0MfskhYe9cLgntfSFPIg==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-compilation-targets': 7.21.5(@babel/core@7.21.8) - '@babel/helper-function-name': 7.21.0 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-module-transforms': 7.23.3(@babel/core@7.23.9) + '@babel/helper-plugin-utils': 7.22.5 + dev: false + + /@babel/plugin-transform-named-capturing-groups-regex@7.22.5(@babel/core@7.23.9): + resolution: {integrity: sha512-YgLLKmS3aUBhHaxp5hi1WJTgOUb/NCuDHzGT9z9WTt3YG+CPRhJs6nprbStx6DnWM4dh6gt7SU3sZodbZ08adQ==} + engines: {node: '>=6.9.0'} + peerDependencies: + '@babel/core': ^7.0.0 + dependencies: + '@babel/core': 7.23.9 + '@babel/helper-create-regexp-features-plugin': 7.22.15(@babel/core@7.23.9) + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-transform-literals@7.18.9(@babel/core@7.21.8): - resolution: {integrity: sha512-IFQDSRoTPnrAIrI5zoZv73IFeZu2dhu6irxQjY9rNjTT53VmKg9fenjvoiOWOkJ6mm4jKVPtdMzBY98Fp4Z4cg==} + /@babel/plugin-transform-new-target@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-YJ3xKqtJMAT5/TIZnpAR3I+K+WaDowYbN3xyxI8zxx/Gsypwf9B9h0VB+1Nh6ACAAPRS5NSRje0uVv5i79HYGQ==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-transform-member-expression-literals@7.18.6(@babel/core@7.21.8): - resolution: {integrity: sha512-qSF1ihLGO3q+/g48k85tUjD033C29TNTVB2paCwZPVmOsjn9pClvYYrM2VeJpBY2bcNkuny0YUyTNRyRxJ54KA==} + /@babel/plugin-transform-nullish-coalescing-operator@7.23.4(@babel/core@7.23.9): + resolution: {integrity: sha512-jHE9EVVqHKAQx+VePv5LLGHjmHSJR76vawFPTdlxR/LVJPfOEGxREQwQfjuZEOPTwG92X3LINSh3M40Rv4zpVA==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 + '@babel/plugin-syntax-nullish-coalescing-operator': 7.8.3(@babel/core@7.23.9) dev: false - /@babel/plugin-transform-modules-amd@7.20.11(@babel/core@7.21.8): - resolution: {integrity: sha512-NuzCt5IIYOW0O30UvqktzHYR2ud5bOWbY0yaxWZ6G+aFzOMJvrs5YHNikrbdaT15+KNO31nPOy5Fim3ku6Zb5g==} + /@babel/plugin-transform-numeric-separator@7.23.4(@babel/core@7.23.9): + resolution: {integrity: sha512-mps6auzgwjRrwKEZA05cOwuDc9FAzoyFS4ZsG/8F43bTLf/TgkJg7QXOrPO1JO599iA3qgK9MXdMGOEC8O1h6Q==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-module-transforms': 7.21.5 - '@babel/helper-plugin-utils': 7.21.5 - transitivePeerDependencies: - - supports-color + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 + '@babel/plugin-syntax-numeric-separator': 7.10.4(@babel/core@7.23.9) dev: false - /@babel/plugin-transform-modules-commonjs@7.21.5(@babel/core@7.21.8): - resolution: {integrity: sha512-OVryBEgKUbtqMoB7eG2rs6UFexJi6Zj6FDXx+esBLPTCxCNxAY9o+8Di7IsUGJ+AVhp5ncK0fxWUBd0/1gPhrQ==} + /@babel/plugin-transform-object-rest-spread@7.23.4(@babel/core@7.23.9): + resolution: {integrity: sha512-9x9K1YyeQVw0iOXJlIzwm8ltobIIv7j2iLyP2jIhEbqPRQ7ScNgwQufU2I0Gq11VjyG4gI4yMXt2VFags+1N3g==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-module-transforms': 7.21.5 - '@babel/helper-plugin-utils': 7.21.5 - '@babel/helper-simple-access': 7.21.5 - transitivePeerDependencies: - - supports-color + '@babel/compat-data': 7.23.5 + '@babel/core': 7.23.9 + '@babel/helper-compilation-targets': 7.23.6 + '@babel/helper-plugin-utils': 7.22.5 + '@babel/plugin-syntax-object-rest-spread': 7.8.3(@babel/core@7.23.9) + '@babel/plugin-transform-parameters': 7.23.3(@babel/core@7.23.9) dev: false - /@babel/plugin-transform-modules-systemjs@7.20.11(@babel/core@7.21.8): - resolution: {integrity: sha512-vVu5g9BPQKSFEmvt2TA4Da5N+QVS66EX21d8uoOihC+OCpUoGvzVsXeqFdtAEfVa5BILAeFt+U7yVmLbQnAJmw==} + /@babel/plugin-transform-object-super@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-BwQ8q0x2JG+3lxCVFohg+KbQM7plfpBwThdW9A6TMtWwLsbDA01Ek2Zb/AgDN39BiZsExm4qrXxjk+P1/fzGrA==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-hoist-variables': 7.18.6 - '@babel/helper-module-transforms': 7.21.5 - '@babel/helper-plugin-utils': 7.21.5 - '@babel/helper-validator-identifier': 7.22.5 - transitivePeerDependencies: - - supports-color + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 + '@babel/helper-replace-supers': 7.22.20(@babel/core@7.23.9) dev: false - /@babel/plugin-transform-modules-umd@7.18.6(@babel/core@7.21.8): - resolution: {integrity: sha512-dcegErExVeXcRqNtkRU/z8WlBLnvD4MRnHgNs3MytRO1Mn1sHRyhbcpYbVMGclAqOjdW+9cfkdZno9dFdfKLfQ==} + /@babel/plugin-transform-optional-catch-binding@7.23.4(@babel/core@7.23.9): + resolution: {integrity: sha512-XIq8t0rJPHf6Wvmbn9nFxU6ao4c7WhghTR5WyV8SrJfUFzyxhCm4nhC+iAp3HFhbAKLfYpgzhJ6t4XCtVwqO5A==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-module-transforms': 7.21.5 - '@babel/helper-plugin-utils': 7.21.5 - transitivePeerDependencies: - - supports-color + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 + '@babel/plugin-syntax-optional-catch-binding': 7.8.3(@babel/core@7.23.9) dev: false - /@babel/plugin-transform-named-capturing-groups-regex@7.20.5(@babel/core@7.21.8): - resolution: {integrity: sha512-mOW4tTzi5iTLnw+78iEq3gr8Aoq4WNRGpmSlrogqaiCBoR1HFhpU4JkpQFOHfeYx3ReVIFWOQJS4aZBRvuZ6mA==} + /@babel/plugin-transform-optional-chaining@7.23.4(@babel/core@7.23.9): + resolution: {integrity: sha512-ZU8y5zWOfjM5vZ+asjgAPwDaBjJzgufjES89Rs4Lpq63O300R/kOz30WCLo6BxxX6QVEilwSlpClnG5cZaikTA==} engines: {node: '>=6.9.0'} peerDependencies: - '@babel/core': ^7.0.0 + '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-create-regexp-features-plugin': 7.21.8(@babel/core@7.21.8) - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 + '@babel/helper-skip-transparent-expression-wrappers': 7.22.5 + '@babel/plugin-syntax-optional-chaining': 7.8.3(@babel/core@7.23.9) dev: false - /@babel/plugin-transform-new-target@7.18.6(@babel/core@7.21.8): - resolution: {integrity: sha512-DjwFA/9Iu3Z+vrAn+8pBUGcjhxKguSMlsFqeCKbhb9BAV756v0krzVK04CRDi/4aqmk8BsHb4a/gFcaA5joXRw==} + /@babel/plugin-transform-parameters@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-09lMt6UsUb3/34BbECKVbVwrT9bO6lILWln237z7sLaWnMsTi7Yc9fhX5DLpkJzAGfaReXI22wP41SZmnAA3Vw==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-transform-object-super@7.18.6(@babel/core@7.21.8): - resolution: {integrity: sha512-uvGz6zk+pZoS1aTZrOvrbj6Pp/kK2mp45t2B+bTDre2UgsZZ8EZLSJtUg7m/no0zOJUWgFONpB7Zv9W2tSaFlA==} + /@babel/plugin-transform-private-methods@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-UzqRcRtWsDMTLrRWFvUBDwmw06tCQH9Rl1uAjfh6ijMSmGYQ+fpdB+cnqRC8EMh5tuuxSv0/TejGL+7vyj+50g==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 - '@babel/helper-replace-supers': 7.21.5 - transitivePeerDependencies: - - supports-color + '@babel/core': 7.23.9 + '@babel/helper-create-class-features-plugin': 7.23.10(@babel/core@7.23.9) + '@babel/helper-plugin-utils': 7.22.5 + dev: false + + /@babel/plugin-transform-private-property-in-object@7.23.4(@babel/core@7.23.9): + resolution: {integrity: sha512-9G3K1YqTq3F4Vt88Djx1UZ79PDyj+yKRnUy7cZGSMe+a7jkwD259uKKuUzQlPkGam7R+8RJwh5z4xO27fA1o2A==} + engines: {node: '>=6.9.0'} + peerDependencies: + '@babel/core': ^7.0.0-0 + dependencies: + '@babel/core': 7.23.9 + '@babel/helper-annotate-as-pure': 7.22.5 + '@babel/helper-create-class-features-plugin': 7.23.10(@babel/core@7.23.9) + '@babel/helper-plugin-utils': 7.22.5 + '@babel/plugin-syntax-private-property-in-object': 7.14.5(@babel/core@7.23.9) dev: false - /@babel/plugin-transform-parameters@7.21.3(@babel/core@7.21.8): - resolution: {integrity: sha512-Wxc+TvppQG9xWFYatvCGPvZ6+SIUxQ2ZdiBP+PHYMIjnPXD+uThCshaz4NZOnODAtBjjcVQQ/3OKs9LW28purQ==} + /@babel/plugin-transform-property-literals@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-jR3Jn3y7cZp4oEWPFAlRsSWjxKe4PZILGBSd4nis1TsC5qeSpb+nrtihJuDhNI7QHiVbUaiXa0X2RZY3/TI6Nw==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-transform-property-literals@7.18.6(@babel/core@7.21.8): - resolution: {integrity: sha512-cYcs6qlgafTud3PAzrrRNbQtfpQ8+y/+M5tKmksS9+M1ckbH6kzY8MrexEM9mcA6JDsukE19iIRvAyYl463sMg==} + /@babel/plugin-transform-react-jsx-self@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-qXRvbeKDSfwnlJnanVRp0SfuWE5DQhwQr5xtLBzp56Wabyo+4CMosF6Kfp+eOD/4FYpql64XVJ2W0pVLlJZxOQ==} + engines: {node: '>=6.9.0'} + peerDependencies: + '@babel/core': ^7.0.0-0 + dependencies: + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 + dev: true + + /@babel/plugin-transform-react-jsx-source@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-91RS0MDnAWDNvGC6Wio5XYkyWI39FMFO+JK9+4AlgaTH+yWwVTsw7/sn6LK0lH7c5F+TFkpv/3LfCJ1Ydwof/g==} + engines: {node: '>=6.9.0'} + peerDependencies: + '@babel/core': ^7.0.0-0 + dependencies: + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 + dev: true + + /@babel/plugin-transform-regenerator@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-KP+75h0KghBMcVpuKisx3XTu9Ncut8Q8TuvGO4IhY+9D5DFEckQefOuIsB/gQ2tG71lCke4NMrtIPS8pOj18BQ==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 + regenerator-transform: 0.15.2 dev: false - /@babel/plugin-transform-regenerator@7.21.5(@babel/core@7.21.8): - resolution: {integrity: sha512-ZoYBKDb6LyMi5yCsByQ5jmXsHAQDDYeexT1Szvlmui+lADvfSecr5Dxd/PkrTC3pAD182Fcju1VQkB4oCp9M+w==} + /@babel/plugin-transform-reserved-words@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-QnNTazY54YqgGxwIexMZva9gqbPa15t/x9VS+0fsEFWplwVpXYZivtgl43Z1vMpc1bdPP2PP8siFeVcnFvA3Cg==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 - regenerator-transform: 0.15.1 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-transform-reserved-words@7.18.6(@babel/core@7.21.8): - resolution: {integrity: sha512-oX/4MyMoypzHjFrT1CdivfKZ+XvIPMFXwwxHp/r0Ddy2Vuomt4HDFGmft1TAY2yiTKiNSsh3kjBAzcM8kSdsjA==} + /@babel/plugin-transform-shorthand-properties@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-ED2fgqZLmexWiN+YNFX26fx4gh5qHDhn1O2gvEhreLW2iI63Sqm4llRLCXALKrCnbN4Jy0VcMQZl/SAzqug/jg==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-transform-shorthand-properties@7.18.6(@babel/core@7.21.8): - resolution: {integrity: sha512-eCLXXJqv8okzg86ywZJbRn19YJHU4XUa55oz2wbHhaQVn/MM+XhukiT7SYqp/7o00dg52Rj51Ny+Ecw4oyoygw==} + /@babel/plugin-transform-spread@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-VvfVYlrlBVu+77xVTOAoxQ6mZbnIq5FM0aGBSFEcIh03qHf+zNqA4DC/3XMUozTg7bZV3e3mZQ0i13VB6v5yUg==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 + '@babel/helper-skip-transparent-expression-wrappers': 7.22.5 dev: false - /@babel/plugin-transform-spread@7.20.7(@babel/core@7.21.8): - resolution: {integrity: sha512-ewBbHQ+1U/VnH1fxltbJqDeWBU1oNLG8Dj11uIv3xVf7nrQu0bPGe5Rf716r7K5Qz+SqtAOVswoVunoiBtGhxw==} + /@babel/plugin-transform-sticky-regex@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-HZOyN9g+rtvnOU3Yh7kSxXrKbzgrm5X4GncPY1QOquu7epga5MxKHVpYu2hvQnry/H+JjckSYRb93iNfsioAGg==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 - '@babel/helper-skip-transparent-expression-wrappers': 7.20.0 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-transform-sticky-regex@7.18.6(@babel/core@7.21.8): - resolution: {integrity: sha512-kfiDrDQ+PBsQDO85yj1icueWMfGfJFKN1KCkndygtu/C9+XUfydLC8Iv5UYJqRwy4zk8EcplRxEOeLyjq1gm6Q==} + /@babel/plugin-transform-template-literals@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-Flok06AYNp7GV2oJPZZcP9vZdszev6vPBkHLwxwSpaIqx75wn6mUd3UFWsSsA0l8nXAKkyCmL/sR02m8RYGeHg==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-transform-template-literals@7.18.9(@babel/core@7.21.8): - resolution: {integrity: sha512-S8cOWfT82gTezpYOiVaGHrCbhlHgKhQt8XH5ES46P2XWmX92yisoZywf5km75wv5sYcXDUCLMmMxOLCtthDgMA==} + /@babel/plugin-transform-typeof-symbol@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-4t15ViVnaFdrPC74be1gXBSMzXk3B4Us9lP7uLRQHTFpV5Dvt33pn+2MyyNxmN3VTTm3oTrZVMUmuw3oBnQ2oQ==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-transform-typeof-symbol@7.18.9(@babel/core@7.21.8): - resolution: {integrity: sha512-SRfwTtF11G2aemAZWivL7PD+C9z52v9EvMqH9BuYbabyPuKUvSWks3oCg6041pT925L4zVFqaVBeECwsmlguEw==} + /@babel/plugin-transform-unicode-escapes@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-OMCUx/bU6ChE3r4+ZdylEqAjaQgHAgipgW8nsCfu5pGqDcFytVd91AwRvUJSBZDz0exPGgnjoqhgRYLRjFZc9Q==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-transform-unicode-escapes@7.21.5(@babel/core@7.21.8): - resolution: {integrity: sha512-LYm/gTOwZqsYohlvFUe/8Tujz75LqqVC2w+2qPHLR+WyWHGCZPN1KBpJCJn+4Bk4gOkQy/IXKIge6az5MqwlOg==} + /@babel/plugin-transform-unicode-property-regex@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-KcLIm+pDZkWZQAFJ9pdfmh89EwVfmNovFBcXko8szpBeF8z68kWIPeKlmSOkT9BXJxs2C0uk+5LxoxIv62MROA==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-create-regexp-features-plugin': 7.22.15(@babel/core@7.23.9) + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/plugin-transform-unicode-regex@7.18.6(@babel/core@7.21.8): - resolution: {integrity: sha512-gE7A6Lt7YLnNOL3Pb9BNeZvi+d8l7tcRrG4+pwJjK9hD2xX4mEvjlQW60G9EEmfXVYRPv9VRQcyegIVHCql/AA==} + /@babel/plugin-transform-unicode-regex@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-wMHpNA4x2cIA32b/ci3AfwNgheiva2W0WUKWTK7vBHBhDKfPsc5cFGNWm69WBqpwd86u1qwZ9PWevKqm1A3yAw==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-create-regexp-features-plugin': 7.21.8(@babel/core@7.21.8) - '@babel/helper-plugin-utils': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-create-regexp-features-plugin': 7.22.15(@babel/core@7.23.9) + '@babel/helper-plugin-utils': 7.22.5 + dev: false + + /@babel/plugin-transform-unicode-sets-regex@7.23.3(@babel/core@7.23.9): + resolution: {integrity: sha512-W7lliA/v9bNR83Qc3q1ip9CQMZ09CcHDbHfbLRDNuAhn1Mvkr1ZNF7hPmztMQvtTGVLJ9m8IZqWsTkXOml8dbw==} + engines: {node: '>=6.9.0'} + peerDependencies: + '@babel/core': ^7.0.0 + dependencies: + '@babel/core': 7.23.9 + '@babel/helper-create-regexp-features-plugin': 7.22.15(@babel/core@7.23.9) + '@babel/helper-plugin-utils': 7.22.5 dev: false - /@babel/preset-env@7.21.5(@babel/core@7.21.8): - resolution: {integrity: sha512-wH00QnTTldTbf/IefEVyChtRdw5RJvODT/Vb4Vcxq1AZvtXj6T0YeX0cAcXhI6/BdGuiP3GcNIL4OQbI2DVNxg==} + /@babel/preset-env@7.23.9(@babel/core@7.23.9): + resolution: {integrity: sha512-3kBGTNBBk9DQiPoXYS0g0BYlwTQYUTifqgKTjxUwEUkduRT2QOa0FPGBJ+NROQhGyYO5BuTJwGvBnqKDykac6A==} engines: {node: '>=6.9.0'} peerDependencies: '@babel/core': ^7.0.0-0 dependencies: - '@babel/compat-data': 7.21.7 - '@babel/core': 7.21.8 - '@babel/helper-compilation-targets': 7.21.5(@babel/core@7.21.8) - '@babel/helper-plugin-utils': 7.21.5 - '@babel/helper-validator-option': 7.21.0 - '@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression': 7.18.6(@babel/core@7.21.8) - '@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining': 7.20.7(@babel/core@7.21.8) - '@babel/plugin-proposal-async-generator-functions': 7.20.7(@babel/core@7.21.8) - '@babel/plugin-proposal-class-properties': 7.18.6(@babel/core@7.21.8) - '@babel/plugin-proposal-class-static-block': 7.21.0(@babel/core@7.21.8) - '@babel/plugin-proposal-dynamic-import': 7.18.6(@babel/core@7.21.8) - '@babel/plugin-proposal-export-namespace-from': 7.18.9(@babel/core@7.21.8) - '@babel/plugin-proposal-json-strings': 7.18.6(@babel/core@7.21.8) - '@babel/plugin-proposal-logical-assignment-operators': 7.20.7(@babel/core@7.21.8) - '@babel/plugin-proposal-nullish-coalescing-operator': 7.18.6(@babel/core@7.21.8) - '@babel/plugin-proposal-numeric-separator': 7.18.6(@babel/core@7.21.8) - '@babel/plugin-proposal-object-rest-spread': 7.20.7(@babel/core@7.21.8) - '@babel/plugin-proposal-optional-catch-binding': 7.18.6(@babel/core@7.21.8) - '@babel/plugin-proposal-optional-chaining': 7.21.0(@babel/core@7.21.8) - '@babel/plugin-proposal-private-methods': 7.18.6(@babel/core@7.21.8) - '@babel/plugin-proposal-private-property-in-object': 7.21.0(@babel/core@7.21.8) - '@babel/plugin-proposal-unicode-property-regex': 7.18.6(@babel/core@7.21.8) - '@babel/plugin-syntax-async-generators': 7.8.4(@babel/core@7.21.8) - '@babel/plugin-syntax-class-properties': 7.12.13(@babel/core@7.21.8) - '@babel/plugin-syntax-class-static-block': 7.14.5(@babel/core@7.21.8) - '@babel/plugin-syntax-dynamic-import': 7.8.3(@babel/core@7.21.8) - '@babel/plugin-syntax-export-namespace-from': 7.8.3(@babel/core@7.21.8) - '@babel/plugin-syntax-import-assertions': 7.20.0(@babel/core@7.21.8) - '@babel/plugin-syntax-import-meta': 7.10.4(@babel/core@7.21.8) - '@babel/plugin-syntax-json-strings': 7.8.3(@babel/core@7.21.8) - '@babel/plugin-syntax-logical-assignment-operators': 7.10.4(@babel/core@7.21.8) - '@babel/plugin-syntax-nullish-coalescing-operator': 7.8.3(@babel/core@7.21.8) - '@babel/plugin-syntax-numeric-separator': 7.10.4(@babel/core@7.21.8) - '@babel/plugin-syntax-object-rest-spread': 7.8.3(@babel/core@7.21.8) - '@babel/plugin-syntax-optional-catch-binding': 7.8.3(@babel/core@7.21.8) - '@babel/plugin-syntax-optional-chaining': 7.8.3(@babel/core@7.21.8) - '@babel/plugin-syntax-private-property-in-object': 7.14.5(@babel/core@7.21.8) - '@babel/plugin-syntax-top-level-await': 7.14.5(@babel/core@7.21.8) - '@babel/plugin-transform-arrow-functions': 7.21.5(@babel/core@7.21.8) - '@babel/plugin-transform-async-to-generator': 7.20.7(@babel/core@7.21.8) - '@babel/plugin-transform-block-scoped-functions': 7.18.6(@babel/core@7.21.8) - '@babel/plugin-transform-block-scoping': 7.21.0(@babel/core@7.21.8) - '@babel/plugin-transform-classes': 7.21.0(@babel/core@7.21.8) - '@babel/plugin-transform-computed-properties': 7.21.5(@babel/core@7.21.8) - '@babel/plugin-transform-destructuring': 7.21.3(@babel/core@7.21.8) - '@babel/plugin-transform-dotall-regex': 7.18.6(@babel/core@7.21.8) - '@babel/plugin-transform-duplicate-keys': 7.18.9(@babel/core@7.21.8) - '@babel/plugin-transform-exponentiation-operator': 7.18.6(@babel/core@7.21.8) - '@babel/plugin-transform-for-of': 7.21.5(@babel/core@7.21.8) - '@babel/plugin-transform-function-name': 7.18.9(@babel/core@7.21.8) - '@babel/plugin-transform-literals': 7.18.9(@babel/core@7.21.8) - '@babel/plugin-transform-member-expression-literals': 7.18.6(@babel/core@7.21.8) - '@babel/plugin-transform-modules-amd': 7.20.11(@babel/core@7.21.8) - '@babel/plugin-transform-modules-commonjs': 7.21.5(@babel/core@7.21.8) - '@babel/plugin-transform-modules-systemjs': 7.20.11(@babel/core@7.21.8) - '@babel/plugin-transform-modules-umd': 7.18.6(@babel/core@7.21.8) - '@babel/plugin-transform-named-capturing-groups-regex': 7.20.5(@babel/core@7.21.8) - '@babel/plugin-transform-new-target': 7.18.6(@babel/core@7.21.8) - '@babel/plugin-transform-object-super': 7.18.6(@babel/core@7.21.8) - '@babel/plugin-transform-parameters': 7.21.3(@babel/core@7.21.8) - '@babel/plugin-transform-property-literals': 7.18.6(@babel/core@7.21.8) - '@babel/plugin-transform-regenerator': 7.21.5(@babel/core@7.21.8) - '@babel/plugin-transform-reserved-words': 7.18.6(@babel/core@7.21.8) - '@babel/plugin-transform-shorthand-properties': 7.18.6(@babel/core@7.21.8) - '@babel/plugin-transform-spread': 7.20.7(@babel/core@7.21.8) - '@babel/plugin-transform-sticky-regex': 7.18.6(@babel/core@7.21.8) - '@babel/plugin-transform-template-literals': 7.18.9(@babel/core@7.21.8) - '@babel/plugin-transform-typeof-symbol': 7.18.9(@babel/core@7.21.8) - '@babel/plugin-transform-unicode-escapes': 7.21.5(@babel/core@7.21.8) - '@babel/plugin-transform-unicode-regex': 7.18.6(@babel/core@7.21.8) - '@babel/preset-modules': 0.1.5(@babel/core@7.21.8) - '@babel/types': 7.21.5 - babel-plugin-polyfill-corejs2: 0.3.3(@babel/core@7.21.8) - babel-plugin-polyfill-corejs3: 0.6.0(@babel/core@7.21.8) - babel-plugin-polyfill-regenerator: 0.4.1(@babel/core@7.21.8) - core-js-compat: 3.30.1 + '@babel/compat-data': 7.23.5 + '@babel/core': 7.23.9 + '@babel/helper-compilation-targets': 7.23.6 + '@babel/helper-plugin-utils': 7.22.5 + '@babel/helper-validator-option': 7.23.5 + '@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly': 7.23.7(@babel/core@7.23.9) + '@babel/plugin-proposal-private-property-in-object': 7.21.0-placeholder-for-preset-env.2(@babel/core@7.23.9) + '@babel/plugin-syntax-async-generators': 7.8.4(@babel/core@7.23.9) + '@babel/plugin-syntax-class-properties': 7.12.13(@babel/core@7.23.9) + '@babel/plugin-syntax-class-static-block': 7.14.5(@babel/core@7.23.9) + '@babel/plugin-syntax-dynamic-import': 7.8.3(@babel/core@7.23.9) + '@babel/plugin-syntax-export-namespace-from': 7.8.3(@babel/core@7.23.9) + '@babel/plugin-syntax-import-assertions': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-syntax-import-attributes': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-syntax-import-meta': 7.10.4(@babel/core@7.23.9) + '@babel/plugin-syntax-json-strings': 7.8.3(@babel/core@7.23.9) + '@babel/plugin-syntax-logical-assignment-operators': 7.10.4(@babel/core@7.23.9) + '@babel/plugin-syntax-nullish-coalescing-operator': 7.8.3(@babel/core@7.23.9) + '@babel/plugin-syntax-numeric-separator': 7.10.4(@babel/core@7.23.9) + '@babel/plugin-syntax-object-rest-spread': 7.8.3(@babel/core@7.23.9) + '@babel/plugin-syntax-optional-catch-binding': 7.8.3(@babel/core@7.23.9) + '@babel/plugin-syntax-optional-chaining': 7.8.3(@babel/core@7.23.9) + '@babel/plugin-syntax-private-property-in-object': 7.14.5(@babel/core@7.23.9) + '@babel/plugin-syntax-top-level-await': 7.14.5(@babel/core@7.23.9) + '@babel/plugin-syntax-unicode-sets-regex': 7.18.6(@babel/core@7.23.9) + '@babel/plugin-transform-arrow-functions': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-async-generator-functions': 7.23.9(@babel/core@7.23.9) + '@babel/plugin-transform-async-to-generator': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-block-scoped-functions': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-block-scoping': 7.23.4(@babel/core@7.23.9) + '@babel/plugin-transform-class-properties': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-class-static-block': 7.23.4(@babel/core@7.23.9) + '@babel/plugin-transform-classes': 7.23.8(@babel/core@7.23.9) + '@babel/plugin-transform-computed-properties': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-destructuring': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-dotall-regex': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-duplicate-keys': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-dynamic-import': 7.23.4(@babel/core@7.23.9) + '@babel/plugin-transform-exponentiation-operator': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-export-namespace-from': 7.23.4(@babel/core@7.23.9) + '@babel/plugin-transform-for-of': 7.23.6(@babel/core@7.23.9) + '@babel/plugin-transform-function-name': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-json-strings': 7.23.4(@babel/core@7.23.9) + '@babel/plugin-transform-literals': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-logical-assignment-operators': 7.23.4(@babel/core@7.23.9) + '@babel/plugin-transform-member-expression-literals': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-modules-amd': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-modules-commonjs': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-modules-systemjs': 7.23.9(@babel/core@7.23.9) + '@babel/plugin-transform-modules-umd': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-named-capturing-groups-regex': 7.22.5(@babel/core@7.23.9) + '@babel/plugin-transform-new-target': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-nullish-coalescing-operator': 7.23.4(@babel/core@7.23.9) + '@babel/plugin-transform-numeric-separator': 7.23.4(@babel/core@7.23.9) + '@babel/plugin-transform-object-rest-spread': 7.23.4(@babel/core@7.23.9) + '@babel/plugin-transform-object-super': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-optional-catch-binding': 7.23.4(@babel/core@7.23.9) + '@babel/plugin-transform-optional-chaining': 7.23.4(@babel/core@7.23.9) + '@babel/plugin-transform-parameters': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-private-methods': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-private-property-in-object': 7.23.4(@babel/core@7.23.9) + '@babel/plugin-transform-property-literals': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-regenerator': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-reserved-words': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-shorthand-properties': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-spread': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-sticky-regex': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-template-literals': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-typeof-symbol': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-unicode-escapes': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-unicode-property-regex': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-unicode-regex': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-unicode-sets-regex': 7.23.3(@babel/core@7.23.9) + '@babel/preset-modules': 0.1.6-no-external-plugins(@babel/core@7.23.9) + babel-plugin-polyfill-corejs2: 0.4.8(@babel/core@7.23.9) + babel-plugin-polyfill-corejs3: 0.9.0(@babel/core@7.23.9) + babel-plugin-polyfill-regenerator: 0.5.5(@babel/core@7.23.9) + core-js-compat: 3.36.0 semver: 6.3.1 transitivePeerDependencies: - supports-color dev: false - /@babel/preset-modules@0.1.5(@babel/core@7.21.8): - resolution: {integrity: sha512-A57th6YRG7oR3cq/yt/Y84MvGgE0eJG2F1JLhKuyG+jFxEgrd/HAMJatiFtmOiZurz+0DkrvbheCLaV5f2JfjA==} + /@babel/preset-modules@0.1.6-no-external-plugins(@babel/core@7.23.9): + resolution: {integrity: sha512-HrcgcIESLm9aIR842yhJ5RWan/gebQUJ6E/E5+rf0y9o6oj7w0Br+sWuL6kEQ/o/AdfvR1Je9jG18/gnpwjEyA==} peerDependencies: - '@babel/core': ^7.0.0-0 + '@babel/core': ^7.0.0-0 || ^8.0.0-0 <8.0.0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-plugin-utils': 7.21.5 - '@babel/plugin-proposal-unicode-property-regex': 7.18.6(@babel/core@7.21.8) - '@babel/plugin-transform-dotall-regex': 7.18.6(@babel/core@7.21.8) - '@babel/types': 7.21.5 + '@babel/core': 7.23.9 + '@babel/helper-plugin-utils': 7.22.5 + '@babel/types': 7.23.9 esutils: 2.0.3 dev: false @@ -1322,48 +2183,44 @@ packages: resolution: {integrity: sha512-x/rqGMdzj+fWZvCOYForTghzbtqPDZ5gPwaoNGHdgDfF2QA/XZbCBp4Moo5scrkAMPhB7z26XM/AaHuIJdgauA==} dev: false - /@babel/runtime@7.21.5: - resolution: {integrity: sha512-8jI69toZqqcsnqGGqwGS4Qb1VwLOEp4hz+CXPywcvjs60u3B4Pom/U/7rm4W8tMOYEB+E9wgD0mW1l3r8qlI9Q==} + /@babel/runtime@7.23.9: + resolution: {integrity: sha512-0CX6F+BI2s9dkUqr08KFrAIZgNFj75rdBU/DjCyYLIaV/quFjkk6T+EJ2LkZHyZTbEV4L5p97mNkUsHl2wLFAw==} engines: {node: '>=6.9.0'} dependencies: - regenerator-runtime: 0.13.11 - dev: false + regenerator-runtime: 0.14.1 - /@babel/template@7.20.7: - resolution: {integrity: sha512-8SegXApWe6VoNw0r9JHpSteLKTpTiLZ4rMlGIm9JQ18KiCtyQiAMEazujAHrUS5flrcqYZa75ukev3P6QmUwUw==} + /@babel/template@7.23.9: + resolution: {integrity: sha512-+xrD2BWLpvHKNmX2QbpdpsBaWnRxahMwJjO+KZk2JOElj5nSmKezyS1B4u+QbHMTX69t4ukm6hh9lsYQ7GHCKA==} engines: {node: '>=6.9.0'} dependencies: - '@babel/code-frame': 7.21.4 - '@babel/parser': 7.21.8 - '@babel/types': 7.21.5 - dev: false + '@babel/code-frame': 7.23.5 + '@babel/parser': 7.23.9 + '@babel/types': 7.23.9 - /@babel/traverse@7.21.5: - resolution: {integrity: sha512-AhQoI3YjWi6u/y/ntv7k48mcrCXmus0t79J9qPNlk/lAsFlCiJ047RmbfMOawySTHtywXhbXgpx/8nXMYd+oFw==} + /@babel/traverse@7.23.9: + resolution: {integrity: sha512-I/4UJ9vs90OkBtY6iiiTORVMyIhJ4kAVmsKo9KFc8UOxMeUfi2hvtIBsET5u9GizXE6/GFSuKCTNfgCswuEjRg==} engines: {node: '>=6.9.0'} dependencies: - '@babel/code-frame': 7.21.4 - '@babel/generator': 7.21.5 - '@babel/helper-environment-visitor': 7.21.5 - '@babel/helper-function-name': 7.21.0 - '@babel/helper-hoist-variables': 7.18.6 - '@babel/helper-split-export-declaration': 7.18.6 - '@babel/parser': 7.21.8 - '@babel/types': 7.21.5 + '@babel/code-frame': 7.23.5 + '@babel/generator': 7.23.6 + '@babel/helper-environment-visitor': 7.22.20 + '@babel/helper-function-name': 7.23.0 + '@babel/helper-hoist-variables': 7.22.5 + '@babel/helper-split-export-declaration': 7.22.6 + '@babel/parser': 7.23.9 + '@babel/types': 7.23.9 debug: 4.3.4(supports-color@8.1.1) globals: 11.12.0 transitivePeerDependencies: - supports-color - dev: false - /@babel/types@7.21.5: - resolution: {integrity: sha512-m4AfNvVF2mVC/F7fDEdH2El3HzUg9It/XsCxZiOTTA3m3qYfcSVSbTfM6Q9xG+hYDniZssYhlXKKUMD5m8tF4Q==} + /@babel/types@7.23.9: + resolution: {integrity: sha512-dQjSq/7HaSjRM43FFGnv5keM2HsxpmyV1PfaSVm0nzzjwwTmjOe6J4bC8e3+pTEIgHaHj+1ZlLThRJ2auc/w1Q==} engines: {node: '>=6.9.0'} dependencies: - '@babel/helper-string-parser': 7.21.5 - '@babel/helper-validator-identifier': 7.19.1 + '@babel/helper-string-parser': 7.23.4 + '@babel/helper-validator-identifier': 7.22.20 to-fast-properties: 2.0.0 - dev: false /@colors/colors@1.5.0: resolution: {integrity: sha512-ooWCrlZP11i8GImSjTHYHLkvFDP48nS4+204nGb1RiX/WXYHmJA2III9/e2DWVabCESdW7hBAEzHRqUn9OUVvQ==} @@ -1371,27 +2228,220 @@ packages: requiresBuild: true optional: true - /@cypress/code-coverage@3.11.0(@babel/core@7.21.8)(@babel/preset-env@7.21.5)(babel-loader@9.1.2)(cypress@12.17.3)(webpack@5.81.0): - resolution: {integrity: sha512-ihSO1s03gmLRE224oIjrbdG1ey63vw/UY+VSqQ5m/TKkAvyz6GIiniq6juk3AV/+0vQC1Eb4UWFu8ndtji4M1g==} + /@colors/colors@1.6.0: + resolution: {integrity: sha512-Ir+AOibqzrIsL6ajt3Rz3LskB7OiMVHqltZmspbW/TJuTVuyOMirVqAkjfY6JISiLHgyNqicAC8AyHHGzNd/dA==} + engines: {node: '>=0.1.90'} + dev: true + + /@confio/ics23@0.6.8: + resolution: {integrity: sha512-wB6uo+3A50m0sW/EWcU64xpV/8wShZ6bMTa7pF8eYsTrSkQA7oLUIJcs/wb8g4y2Oyq701BaGiO6n/ak5WXO1w==} + dependencies: + '@noble/hashes': 1.3.2 + protobufjs: 6.11.4 + dev: true + + /@confio/relayer@0.9.0(debug@4.3.4): + resolution: {integrity: sha512-YfoPMCH72BM/bYQ58+F75zYsZ2vEPocY0CaQLE6PPDtBOKrdXM3LTj5zUdZSbHDQSrDDmRrKcuZVufpdrRimQw==} + engines: {node: '>=12'} + hasBin: true + dependencies: + '@cosmjs/cosmwasm-stargate': 0.30.1(debug@4.3.4) + '@cosmjs/crypto': 0.30.1 + '@cosmjs/encoding': 0.30.1 + '@cosmjs/faucet-client': 0.30.1(debug@4.3.4) + '@cosmjs/math': 0.30.1 + '@cosmjs/proto-signing': 0.30.1 + '@cosmjs/stargate': 0.30.1(debug@4.3.4) + '@cosmjs/stream': 0.30.1 + '@cosmjs/tendermint-rpc': 0.30.1(debug@4.3.4) + '@cosmjs/utils': 0.30.1 + ajv: 7.1.1 + axios: 0.21.4(debug@4.3.4) + commander: 7.1.0 + cosmjs-types: 0.7.2 + fast-safe-stringify: 2.0.4 + js-yaml: 4.0.0 + lodash: 4.17.21 + prom-client: 13.1.0 + protobufjs: 6.11.4 + table: 6.8.1 + triple-beam: 1.3.0 + winston: 3.3.3 + transitivePeerDependencies: + - bufferutil + - debug + - utf-8-validate + dev: true + + /@cosmjs/amino@0.30.1: + resolution: {integrity: sha512-yNHnzmvAlkETDYIpeCTdVqgvrdt1qgkOXwuRVi8s27UKI5hfqyE9fJ/fuunXE6ZZPnKkjIecDznmuUOMrMvw4w==} + dependencies: + '@cosmjs/crypto': 0.30.1 + '@cosmjs/encoding': 0.30.1 + '@cosmjs/math': 0.30.1 + '@cosmjs/utils': 0.30.1 + dev: true + + /@cosmjs/cosmwasm-stargate@0.30.1(debug@4.3.4): + resolution: {integrity: sha512-W/6SLUCJAJGBN+sJLXouLZikVgmqDd9LCdlMzQaxczcCHTWeJAmRvOiZGSZaSy3shw/JN1qc6g6PKpvTVgj10A==} + dependencies: + '@cosmjs/amino': 0.30.1 + '@cosmjs/crypto': 0.30.1 + '@cosmjs/encoding': 0.30.1 + '@cosmjs/math': 0.30.1 + '@cosmjs/proto-signing': 0.30.1 + '@cosmjs/stargate': 0.30.1(debug@4.3.4) + '@cosmjs/tendermint-rpc': 0.30.1(debug@4.3.4) + '@cosmjs/utils': 0.30.1 + cosmjs-types: 0.7.2 + long: 4.0.0 + pako: 2.1.0 + transitivePeerDependencies: + - bufferutil + - debug + - utf-8-validate + dev: true + + /@cosmjs/crypto@0.30.1: + resolution: {integrity: sha512-rAljUlake3MSXs9xAm87mu34GfBLN0h/1uPPV6jEwClWjNkAMotzjC0ab9MARy5FFAvYHL3lWb57bhkbt2GtzQ==} + dependencies: + '@cosmjs/encoding': 0.30.1 + '@cosmjs/math': 0.30.1 + '@cosmjs/utils': 0.30.1 + '@noble/hashes': 1.3.2 + bn.js: 5.2.1 + elliptic: 6.5.4 + libsodium-wrappers: 0.7.13 + dev: true + + /@cosmjs/encoding@0.30.1: + resolution: {integrity: sha512-rXmrTbgqwihORwJ3xYhIgQFfMSrwLu1s43RIK9I8EBudPx3KmnmyAKzMOVsRDo9edLFNuZ9GIvysUCwQfq3WlQ==} + dependencies: + base64-js: 1.5.1 + bech32: 1.1.4 + readonly-date: 1.0.0 + dev: true + + /@cosmjs/faucet-client@0.30.1(debug@4.3.4): + resolution: {integrity: sha512-uOYIjouOCjncfthDzeygcWtEpShiNN0u9tORSingufOAO/kmlHwM53M5I1a8ak1EktkEEa+Mxdj3kRfV87DOcw==} + dependencies: + axios: 0.21.4(debug@4.3.4) + transitivePeerDependencies: + - debug + dev: true + + /@cosmjs/json-rpc@0.30.1: + resolution: {integrity: sha512-pitfC/2YN9t+kXZCbNuyrZ6M8abnCC2n62m+JtU9vQUfaEtVsgy+1Fk4TRQ175+pIWSdBMFi2wT8FWVEE4RhxQ==} + dependencies: + '@cosmjs/stream': 0.30.1 + xstream: 11.14.0 + dev: true + + /@cosmjs/math@0.30.1: + resolution: {integrity: sha512-yaoeI23pin9ZiPHIisa6qqLngfnBR/25tSaWpkTm8Cy10MX70UF5oN4+/t1heLaM6SSmRrhk3psRkV4+7mH51Q==} + dependencies: + bn.js: 5.2.1 + dev: true + + /@cosmjs/proto-signing@0.30.1: + resolution: {integrity: sha512-tXh8pPYXV4aiJVhTKHGyeZekjj+K9s2KKojMB93Gcob2DxUjfKapFYBMJSgfKPuWUPEmyr8Q9km2hplI38ILgQ==} + dependencies: + '@cosmjs/amino': 0.30.1 + '@cosmjs/crypto': 0.30.1 + '@cosmjs/encoding': 0.30.1 + '@cosmjs/math': 0.30.1 + '@cosmjs/utils': 0.30.1 + cosmjs-types: 0.7.2 + long: 4.0.0 + dev: true + + /@cosmjs/socket@0.30.1: + resolution: {integrity: sha512-r6MpDL+9N+qOS/D5VaxnPaMJ3flwQ36G+vPvYJsXArj93BjgyFB7BwWwXCQDzZ+23cfChPUfhbINOenr8N2Kow==} + dependencies: + '@cosmjs/stream': 0.30.1 + isomorphic-ws: 4.0.1(ws@7.5.9) + ws: 7.5.9 + xstream: 11.14.0 + transitivePeerDependencies: + - bufferutil + - utf-8-validate + dev: true + + /@cosmjs/stargate@0.30.1(debug@4.3.4): + resolution: {integrity: sha512-RdbYKZCGOH8gWebO7r6WvNnQMxHrNXInY/gPHPzMjbQF6UatA6fNM2G2tdgS5j5u7FTqlCI10stNXrknaNdzog==} + dependencies: + '@confio/ics23': 0.6.8 + '@cosmjs/amino': 0.30.1 + '@cosmjs/encoding': 0.30.1 + '@cosmjs/math': 0.30.1 + '@cosmjs/proto-signing': 0.30.1 + '@cosmjs/stream': 0.30.1 + '@cosmjs/tendermint-rpc': 0.30.1(debug@4.3.4) + '@cosmjs/utils': 0.30.1 + cosmjs-types: 0.7.2 + long: 4.0.0 + protobufjs: 6.11.4 + xstream: 11.14.0 + transitivePeerDependencies: + - bufferutil + - debug + - utf-8-validate + dev: true + + /@cosmjs/stream@0.30.1: + resolution: {integrity: sha512-Fg0pWz1zXQdoxQZpdHRMGvUH5RqS6tPv+j9Eh7Q953UjMlrwZVo0YFLC8OTf/HKVf10E4i0u6aM8D69Q6cNkgQ==} + dependencies: + xstream: 11.14.0 + dev: true + + /@cosmjs/tendermint-rpc@0.30.1(debug@4.3.4): + resolution: {integrity: sha512-Z3nCwhXSbPZJ++v85zHObeUggrEHVfm1u18ZRwXxFE9ZMl5mXTybnwYhczuYOl7KRskgwlB+rID0WYACxj4wdQ==} + dependencies: + '@cosmjs/crypto': 0.30.1 + '@cosmjs/encoding': 0.30.1 + '@cosmjs/json-rpc': 0.30.1 + '@cosmjs/math': 0.30.1 + '@cosmjs/socket': 0.30.1 + '@cosmjs/stream': 0.30.1 + '@cosmjs/utils': 0.30.1 + axios: 0.21.4(debug@4.3.4) + readonly-date: 1.0.0 + xstream: 11.14.0 + transitivePeerDependencies: + - bufferutil + - debug + - utf-8-validate + dev: true + + /@cosmjs/utils@0.30.1: + resolution: {integrity: sha512-KvvX58MGMWh7xA+N+deCfunkA/ZNDvFLw4YbOmX3f/XBIkqrVY7qlotfy2aNb1kgp6h4B6Yc8YawJPDTfvWX7g==} + dev: true + + /@cypress/code-coverage@3.12.26(@babel/core@7.23.9)(@babel/preset-env@7.23.9)(babel-loader@9.1.3)(cypress@12.17.3)(webpack@5.90.3): + resolution: {integrity: sha512-fJDELN3BNOPKm8JRZxHN/FrNebXpjX/PAsJYUbqp7SIn7Rk7MlDhKR5T0gFOzhrfvOpKmJ7t0dQf7kqRjb/LOQ==} peerDependencies: + '@babel/core': ^7.0.1 + '@babel/preset-env': ^7.0.0 + babel-loader: ^8.3 || ^9 cypress: '*' + webpack: ^4 || ^5 dependencies: - '@cypress/webpack-preprocessor': 5.17.1(@babel/core@7.21.8)(@babel/preset-env@7.21.5)(babel-loader@9.1.2)(webpack@5.81.0) + '@babel/core': 7.23.9 + '@babel/preset-env': 7.23.9(@babel/core@7.23.9) + '@cypress/webpack-preprocessor': 6.0.1(@babel/core@7.23.9)(@babel/preset-env@7.23.9)(babel-loader@9.1.3)(webpack@5.90.3) + babel-loader: 9.1.3(@babel/core@7.23.9)(webpack@5.90.3) chalk: 4.1.2 cypress: 12.17.3 - dayjs: 1.11.9 + dayjs: 1.11.10 debug: 4.3.4(supports-color@8.1.1) execa: 4.1.0 - globby: 11.0.4 - istanbul-lib-coverage: 3.0.0 + globby: 11.1.0 + istanbul-lib-coverage: 3.2.2 js-yaml: 4.1.0 nyc: 15.1.0 + webpack: 5.90.3 transitivePeerDependencies: - - '@babel/core' - - '@babel/preset-env' - - babel-loader - supports-color - - webpack dev: false /@cypress/request@2.88.12: @@ -1418,20 +2468,21 @@ packages: uuid: 8.3.2 dev: false - /@cypress/webpack-dev-server@3.5.2(debug@4.3.4)(webpack@5.81.0): - resolution: {integrity: sha512-g2nkWgTWFWqYCfG/3K1C2W8p1WyvcdYNG9eqsmRhkifroJDsm5q5aBI9lA9dHhL8qoRARaPzEaeef3PqBTjNUg==} + /@cypress/webpack-dev-server@3.7.4(debug@4.3.4)(webpack@5.90.3): + resolution: {integrity: sha512-/j6Hgq7eDKuoqa6hsnf4y01PFXMQJEjvj8cXSQB597Ufpm3kApwsRlHj4cN1kyaRckujbfPaXX/5gMHDbOTM1g==} dependencies: find-up: 6.3.0 fs-extra: 9.1.0 - html-webpack-plugin-4: /html-webpack-plugin@4.5.2(webpack@5.81.0) - html-webpack-plugin-5: /html-webpack-plugin@5.5.1(webpack@5.81.0) + html-webpack-plugin-4: /html-webpack-plugin@4.5.2(webpack@5.90.3) + html-webpack-plugin-5: /html-webpack-plugin@5.6.0(webpack@5.90.3) local-pkg: 0.4.1 - semver: 7.5.4 - speed-measure-webpack-plugin: 1.4.2(webpack@5.81.0) - tslib: 2.6.1 - webpack-dev-server: 4.13.3(debug@4.3.4)(webpack@5.81.0) - webpack-merge: 5.8.0 + semver: 7.6.0 + speed-measure-webpack-plugin: 1.4.2(webpack@5.90.3) + tslib: 2.6.2 + webpack-dev-server: 4.15.1(debug@4.3.4)(webpack@5.90.3) + webpack-merge: 5.10.0 transitivePeerDependencies: + - '@rspack/core' - bufferutil - debug - supports-color @@ -1440,21 +2491,21 @@ packages: - webpack-cli dev: false - /@cypress/webpack-preprocessor@5.17.1(@babel/core@7.21.8)(@babel/preset-env@7.21.5)(babel-loader@9.1.2)(webpack@5.81.0): - resolution: {integrity: sha512-FE/e8ikPc8z4EVopJCaior3RGy0jd2q9Xcp5NtiwNG4XnLfEnUFTZlAGwXe75sEh4fNMPrBJW1KIz77PX5vGAw==} + /@cypress/webpack-preprocessor@6.0.1(@babel/core@7.23.9)(@babel/preset-env@7.23.9)(babel-loader@9.1.3)(webpack@5.90.3): + resolution: {integrity: sha512-WVNeFVSnFKxE3WZNRIriduTgqJRpevaiJIPlfqYTTzfXRD7X1Pv4woDE+G4caPV9bJqVKmVFiwzrXMRNeJxpxA==} peerDependencies: '@babel/core': ^7.0.1 '@babel/preset-env': ^7.0.0 - babel-loader: ^8.0.2 || ^9 + babel-loader: ^8.3 || ^9 webpack: ^4 || ^5 dependencies: - '@babel/core': 7.21.8 - '@babel/preset-env': 7.21.5(@babel/core@7.21.8) - babel-loader: 9.1.2(@babel/core@7.21.8)(webpack@5.81.0) + '@babel/core': 7.23.9 + '@babel/preset-env': 7.23.9(@babel/core@7.23.9) + babel-loader: 9.1.3(@babel/core@7.23.9)(webpack@5.90.3) bluebird: 3.7.1 debug: 4.3.4(supports-color@8.1.1) lodash: 4.17.21 - webpack: 5.81.0 + webpack: 5.90.3 transitivePeerDependencies: - supports-color dev: false @@ -1468,74 +2519,846 @@ packages: - supports-color dev: false - /@drptbl/gremlins.js@2.2.1: - resolution: {integrity: sha512-VWsdOZTsu8ABNVplFQUniHSLsCAQIJh+HDTUP6CllxXBe2pgFQKQ6RGxAS/QRTUcPprQCGpB3zH+gqNnvRRTmQ==} + /@dabh/diagnostics@2.0.3: + resolution: {integrity: sha512-hrlQOIi7hAfzsMqlGSFyVucrx38O+j6wiGOf//H2ecvIEqYN4ADBSS2iLMh5UFyDunCNniUIPk/q3riFv45xRA==} dependencies: - chance: 1.1.11 - core-js: 3.30.1 - dev: false + colorspace: 1.1.4 + enabled: 2.0.0 + kuler: 2.0.0 + dev: true - /@eslint-community/eslint-utils@4.4.0(eslint@8.47.0): - resolution: {integrity: sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==} - engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} - peerDependencies: - eslint: ^6.0.0 || ^7.0.0 || >=8.0.0 + /@datadog/native-appsec@7.0.0: + resolution: {integrity: sha512-bywstWFW2hWxzPuS0+mFMVHHL0geulx5yQFtsjfszaH2LTAgk2D+Rt40MKbAoZ8q3tRw2dy6aYQ7svO3ca8jpA==} + engines: {node: '>=14'} + requiresBuild: true dependencies: - eslint: 8.47.0 - eslint-visitor-keys: 3.4.3 + node-gyp-build: 3.9.0 dev: true - /@eslint-community/regexpp@4.6.2: - resolution: {integrity: sha512-pPTNuaAG3QMH+buKyBIGJs3g/S5y0caxw0ygM3YyE6yJFySwiGGSzA+mM3KJ8QQvzeLh3blwgSonkFjgQdxzMw==} - engines: {node: ^12.0.0 || ^14.0.0 || >=16.0.0} + /@datadog/native-iast-rewriter@2.2.3: + resolution: {integrity: sha512-RCbflf8BJ++h99I7iA4NxTA1lx7YqB+sPQkJNSZKxXyEXtWl9J4XsDV9C/sB9iGbf1PVY77tFvoGm5/WpUV4IA==} + engines: {node: '>= 10'} + dependencies: + lru-cache: 7.18.3 + node-gyp-build: 4.8.0 dev: true - /@eslint/eslintrc@2.1.2: - resolution: {integrity: sha512-+wvgpDsrB1YqAMdEUCcnTlpfVBH7Vqn6A/NT3D8WVXFIaKMlErPIZT3oCIAVCOtarRpMtelZLqJeU3t7WY6X6g==} - engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} + /@datadog/native-iast-taint-tracking@1.7.0: + resolution: {integrity: sha512-p3qnYJrUr9TQ38tuOFoutDAQWOobLdaaWpTl0SHu126JH3ANBxWL/QirtJy6czfzLpm5eXwYHwHidD1Y0mNPdg==} + requiresBuild: true dependencies: - ajv: 6.12.6 - debug: 4.3.4(supports-color@8.1.1) - espree: 9.6.1 - globals: 13.20.0 - ignore: 5.2.4 - import-fresh: 3.3.0 - js-yaml: 4.1.0 - minimatch: 3.1.2 - strip-json-comments: 3.1.1 - transitivePeerDependencies: - - supports-color + node-gyp-build: 3.9.0 dev: true - /@eslint/js@8.47.0: - resolution: {integrity: sha512-P6omY1zv5MItm93kLM8s2vr1HICJH8v0dvddDhysbIuZ+vcjOHg5Zbkf1mTkcmi2JA9oBG2anOkRnW8WJTS8Og==} - engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} + /@datadog/native-metrics@2.0.0: + resolution: {integrity: sha512-YklGVwUtmKGYqFf1MNZuOHvTYdKuR4+Af1XkWcMD8BwOAjxmd9Z+97328rCOY8TFUJzlGUPaXzB8j2qgG/BMwA==} + engines: {node: '>=12'} + requiresBuild: true + dependencies: + node-addon-api: 6.1.0 + node-gyp-build: 3.9.0 dev: true - /@foundry-rs/easy-foundryup@0.1.3: - resolution: {integrity: sha512-Funb4hrSBeikKCmccFT/d3Ud5o92tlIZHTJeMCVk5b54/+CHZHr4g7MmtvO5xrGhxrOebQ0L+ojIj+VixgW7ug==} + /@datadog/pprof@5.0.0: + resolution: {integrity: sha512-vhNan4SBuNWLpexunDJQ+hNbRAgWdk2qy5Iyh7Nn94uSSHXigAJMAvu4jwMKKQKFfchtobOkWT8GQUWW3tgpFg==} + engines: {node: '>=14'} + requiresBuild: true dependencies: - command-exists: 1.2.9 - ts-interface-checker: 0.1.13 - dev: false - - /@gar/promisify@1.1.3: - resolution: {integrity: sha512-k2Ty1JcVojjJFwrg/ThKi2ujJ7XNLYaFGNB/bWT9wGR+oSMJHMa5w+CUq6p/pVrKeNNgA7pCqEcjSnHVoqJQFw==} + delay: 5.0.0 + node-gyp-build: 3.9.0 + p-limit: 3.1.0 + pprof-format: 2.0.7 + source-map: 0.7.4 dev: true - /@hapi/hoek@9.3.0: - resolution: {integrity: sha512-/c6rf4UJlmHlC9b5BaNvzAcFv7HZ2QHaV0D4/HNlBdvFnvQq8RI4kYdhyPCl7Xj+oWvTWQ8ujhqS53LIgAe6KQ==} + /@datadog/sketches-js@2.1.0: + resolution: {integrity: sha512-smLocSfrt3s53H/XSVP3/1kP42oqvrkjUPtyaFd1F79ux24oE31BKt+q0c6lsa6hOYrFzsIwyc5GXAI5JmfOew==} + dev: true - /@hapi/topo@5.1.0: - resolution: {integrity: sha512-foQZKJig7Ob0BMAYBfcJk8d77QtOe7Wo4ox7ff1lQYoNNAb6jwcY1ncdoy2e9wQZzvNy7ODZCYJkK8kzmcAnAg==} + /@drptbl/gremlins.js@2.2.1: + resolution: {integrity: sha512-VWsdOZTsu8ABNVplFQUniHSLsCAQIJh+HDTUP6CllxXBe2pgFQKQ6RGxAS/QRTUcPprQCGpB3zH+gqNnvRRTmQ==} dependencies: - '@hapi/hoek': 9.3.0 + chance: 1.1.11 + core-js: 3.36.0 + dev: false + + /@endo/base64@0.2.31: + resolution: {integrity: sha512-7IndkaZ7buIuFw8oBovNZV7epuyFWs0gdusSJ/zrx6fMXRqX0ycSTtxr6M5xADQGss1I9fqP3vteVLiNFlyIbw==} + dev: true + + /@endo/base64@0.2.35: + resolution: {integrity: sha512-rsAicKvgNq/ar+9b3ElXRXglMiJcg1IErz3lx1HFYZUzfWp8r/Dibi3TEjYpSBmtOeYN9CeWH8CBluN0uFqdag==} + dev: true + + /@endo/bundle-source@2.5.2-upstream-rollup(ava@5.3.1): + resolution: {integrity: sha512-UoQlCMZ8jnQA6ulKYII+plWdyK0/XAj1clHPnAW1ILEthQWN1h9WeQT26mIWowGp+sX8CIyiRSVRQN/0pC35Fw==} + hasBin: true + dependencies: + '@agoric/babel-generator': 7.17.6 + '@babel/parser': 7.23.9 + '@babel/traverse': 7.23.9 + '@endo/base64': 0.2.35 + '@endo/compartment-mapper': 0.8.4 + '@endo/init': 0.5.60 + '@endo/promise-kit': 0.2.60 + '@rollup/plugin-commonjs': 19.0.2(rollup@2.79.1) + '@rollup/plugin-node-resolve': 13.3.0(rollup@2.79.1) + acorn: 8.11.3 + jessie.js: 0.3.3(ava@5.3.1) + rollup: 2.79.1 + source-map: 0.7.4 + transitivePeerDependencies: + - ava + - supports-color + dev: true + + /@endo/bundle-source@2.8.0(ava@5.3.1): + resolution: {integrity: sha512-nDiM3u/LKWq5xAnJ+zm35HC6kMKF3IG6Y5V0385slFHZVT8mXzRJ5ztEqRsVzvVeITfz3ZRFOaFer6v4V8Lkjg==} + hasBin: true + dependencies: + '@agoric/babel-generator': 7.17.6 + '@babel/parser': 7.23.9 + '@babel/traverse': 7.23.9 + '@endo/base64': 0.2.35 + '@endo/compartment-mapper': 0.9.2 + '@endo/init': 0.5.60 + '@endo/promise-kit': 0.2.60 + '@endo/where': 0.3.5 + '@rollup/plugin-commonjs': 19.0.2(rollup@2.79.1) + '@rollup/plugin-node-resolve': 13.3.0(rollup@2.79.1) + acorn: 8.11.3 + jessie.js: 0.3.3(ava@5.3.1) + rollup: 2.79.1 + source-map: 0.7.4 + transitivePeerDependencies: + - ava + - supports-color + dev: true + + /@endo/captp@3.1.1(ava@5.3.1): + resolution: {integrity: sha512-M+EiRxtm5xzKmZtOQmTtk5IfscPUKGSDGhmcxGTm4g4WvukFKSAB8hLHAbeurLaWVQG/ZcqZBffAZL/SGUZbmw==} + dependencies: + '@endo/eventual-send': 0.17.2 + '@endo/marshal': 0.8.9(ava@5.3.1) + '@endo/nat': 4.1.31 + '@endo/promise-kit': 0.2.60 + transitivePeerDependencies: + - ava + dev: true + + /@endo/check-bundle@0.2.18: + resolution: {integrity: sha512-PQB8ACM6ukv8dihzvqyfnHaKNr/+pKdJKmtZSxBvPmyBR4VnmLRSeTWMgMKnnmd27AyYN7vxdvKrL+qZDMA4RQ==} + dependencies: + '@endo/base64': 0.2.35 + '@endo/compartment-mapper': 0.8.4 + transitivePeerDependencies: + - supports-color + dev: true + + /@endo/cjs-module-analyzer@0.2.35: + resolution: {integrity: sha512-Ldr1auybH9AzrR/WV6bzP4aLRpv8CCl98mv0IAui4uQmmFOPOGchshyBfpiDF5XMKM6wh7z0VgmvmydQ5/7AHQ==} + dev: true + + /@endo/compartment-mapper@0.8.4: + resolution: {integrity: sha512-OXK3pfsFWa+k6I1sA4UH+XBsXyCd1G8YEJo0PYsHyzErDSnVYQZ8Ka+M+8Jq8jJtE4SFqZqp1KwihCvMJSA6oA==} + dependencies: + '@endo/cjs-module-analyzer': 0.2.35 + '@endo/static-module-record': 0.7.20 + '@endo/zip': 0.2.35 + ses: 1.3.0 + transitivePeerDependencies: + - supports-color + dev: true + + /@endo/compartment-mapper@0.9.2: + resolution: {integrity: sha512-zsAyTf87zBsE1yZ2CBzEGhcGZGGv5m93/CXZHQhut53o4DWwhuS/WTQ4cBoVFSGKWz63JbbA/7qa4fcOnv5dDw==} + dependencies: + '@endo/cjs-module-analyzer': 0.2.35 + '@endo/static-module-record': 0.8.2 + '@endo/zip': 0.2.35 + ses: 1.3.0 + transitivePeerDependencies: + - supports-color + dev: true + + /@endo/env-options@1.1.1: + resolution: {integrity: sha512-uCwlJ8Vkndx/VBBo36BdYHdxSoQPy7ZZpwyJNfv86Rh4B1IZfqzCRPf0u0mPgJdzOr7lShQey60SuYwoMSZ9Xg==} + dev: true + + /@endo/eventual-send@0.17.2: + resolution: {integrity: sha512-nux02l2yYXXUeUA2PigOO1K0gbVVMYx3prfYrW/G7Ny6PiDLtOyaeMWwKQwFTgJV2yAkOfvycr4LC1+tm7hu/Q==} + + /@endo/exo@0.2.2(ava@5.3.1): + resolution: {integrity: sha512-4787jRJe7nQLV02mCCd1fQ8Ai25ParaIzLBUrxl7UKtsP98LcTlQKAON+OQmnSbV6jjXINa/wHdUeoi8/0xZDA==} + dependencies: + '@endo/far': 0.2.18(ava@5.3.1) + '@endo/patterns': 0.2.2(ava@5.3.1) + transitivePeerDependencies: + - ava + dev: true + + /@endo/far@0.2.18(ava@5.3.1): + resolution: {integrity: sha512-NJPz5x11AOsFgxZNSIW4+llQtSUNQtcYCrvxpMwhofti3hncMjhIiUUrMVggw99pdHNmXEBr0gl16H3n/1X0sw==} + dependencies: + '@endo/eventual-send': 0.17.2 + '@endo/pass-style': 0.1.7(ava@5.3.1) + transitivePeerDependencies: + - ava + dev: true + + /@endo/import-bundle@0.3.4: + resolution: {integrity: sha512-MjB7VBJYFgcUhelMddJQf9uMwxqXV1McjVGqoJ3ZJ/OIQZ5BTYqR+uyZOI8CaUqpVmhNbsg3qMw8/wXW304YlA==} + engines: {node: '>=12'} + dependencies: + '@endo/base64': 0.2.35 + '@endo/compartment-mapper': 0.8.4 + transitivePeerDependencies: + - supports-color + dev: true + + /@endo/init@0.5.56: + resolution: {integrity: sha512-BKA7O2uy9uaGw9dB9X515SIaTumaO58HD30AXkJllW6bmLM/BxxFM3GCgS127x0Wot1ni32Y0DxkwxdEXFXJEQ==} + dependencies: + '@endo/base64': 0.2.35 + '@endo/eventual-send': 0.17.2 + '@endo/lockdown': 0.1.32 + '@endo/promise-kit': 0.2.60 + dev: true + + /@endo/init@0.5.60: + resolution: {integrity: sha512-AbAvs6Nk01fyJ+PaW0RzwemIWyomjzDf8ZEhVa3jCOhr8kBBsTnJdX0v7XkbZ/Y8NQxlrFaW0fPqlJK6aMWTlQ==} + dependencies: + '@endo/base64': 0.2.35 + '@endo/eventual-send': 0.17.2 + '@endo/lockdown': 0.1.32 + '@endo/promise-kit': 0.2.60 + dev: true + + /@endo/lockdown@0.1.28: + resolution: {integrity: sha512-YqurtDU23+0kuWq4J2c94HyRB1aqSB8xEwrx5xTZA9IY/anrtppEiTFGU8tQXqZFhE6bfRzSGWDIVKaXCcm4Lw==} + dependencies: + ses: 1.3.0 + dev: true + + /@endo/lockdown@0.1.32: + resolution: {integrity: sha512-AN696XS3robsopxVg7gc/6c9TXPGosGmKfcM0g9SNnD1rqgo1EakS4wf7f3AbICU9iJdo0e4V5JjzWPnjqoR0g==} + dependencies: + ses: 1.3.0 + dev: true + + /@endo/marshal@0.8.5(ava@5.3.1): + resolution: {integrity: sha512-oj2Ag/TlkoMPv8m00fjoa1uWPgDwm5w8nYUU0DPqaCLfTNGRe8a8s7kYDPbv+sQdiQbkZ1RgUQjdyr/O2Mvs+A==} + dependencies: + '@endo/eventual-send': 0.17.2 + '@endo/nat': 4.1.31 + '@endo/pass-style': 0.1.7(ava@5.3.1) + '@endo/promise-kit': 0.2.60 + transitivePeerDependencies: + - ava + dev: true + + /@endo/marshal@0.8.9(ava@5.3.1): + resolution: {integrity: sha512-wzYlY5/JFzY/wAVxZ6h0BxlRaAS/9KKnhircKO/tGw5bZYHFvLeSeMCBZ4VCSZg5aNgDlhuvB0S6iCwS5MYqcg==} + dependencies: + '@endo/eventual-send': 0.17.2 + '@endo/nat': 4.1.31 + '@endo/pass-style': 0.1.7(ava@5.3.1) + '@endo/promise-kit': 0.2.60 + transitivePeerDependencies: + - ava + dev: true + + /@endo/nat@4.1.27: + resolution: {integrity: sha512-mKRdIc4NvrxZ1qPBcYZH6zaj0RsRwADaCcfPNRnGWcHC9dY8DmZDDcgqNdSBFLiEto1RnXeoKAEGxk6hn253Ow==} + dev: true + + /@endo/nat@4.1.31: + resolution: {integrity: sha512-tz0PnEmzX9BAtKEawYndsx+XC6f+2CKErtrpbpOuX3uct5VNLdw6q6cArSYtnHbxRHR0YaHUdeG0W6okmup4bg==} + dev: true + + /@endo/netstring@0.3.26: + resolution: {integrity: sha512-IT3epH32/jLiNBwKhM+7BRjm0OwFjRooeQyymfGZUKGN95fm+hKHEbm8pDmWT8bnwSzHB++wsaQJTpi39U+obg==} + dependencies: + '@endo/init': 0.5.60 + '@endo/stream': 0.3.25 + ses: 1.3.0 + dev: true + + /@endo/pass-style@0.1.3(ava@5.3.1): + resolution: {integrity: sha512-V2FLPBUJXsJYWjMSoZW2IopOuggEX14pm8AHfOVXUceF3uvHbdJj7qwKAuIIOhPApZ/TV+6nWYi86eb393Ic2w==} + dependencies: + '@endo/promise-kit': 0.2.60 + '@fast-check/ava': 1.2.1(ava@5.3.1) + transitivePeerDependencies: + - ava + dev: true + + /@endo/pass-style@0.1.7(ava@5.3.1): + resolution: {integrity: sha512-dlB62Ptjcy/+iachy7qzAdgIwaU60rE+XLummLRpE2tDSJF2jSFJlVwa/QuGw1KKO7Rt4vog/51sKev3EbJZQg==} + dependencies: + '@endo/promise-kit': 0.2.60 + '@fast-check/ava': 1.2.1(ava@5.3.1) + transitivePeerDependencies: + - ava + dev: true + + /@endo/patterns@0.2.2(ava@5.3.1): + resolution: {integrity: sha512-rbS4BLRohZQhB+0aEPBoxmzOfOie9nAu8Qx55Fxe8xFQKS4k9acafeIYmKh9nvslEJISYQmogy5Lewm5mgdSjg==} + dependencies: + '@endo/eventual-send': 0.17.2 + '@endo/marshal': 0.8.9(ava@5.3.1) + '@endo/promise-kit': 0.2.60 + transitivePeerDependencies: + - ava + dev: true + + /@endo/promise-kit@0.2.56: + resolution: {integrity: sha512-eKlOg353jJCHwDAwXCajtcAiTTjGkd7oWBXniEEc97gZHK83MeB3pnGT2lhoeq3xzdNw3Xv2DDsowBI194AXeA==} + engines: {node: '>=11.0'} + dependencies: + ses: 1.3.0 + dev: true + + /@endo/promise-kit@0.2.60: + resolution: {integrity: sha512-6Zp9BqBbc3ywaG+iLRrQRmO/VLKrMnvsbgOKKPMpjEC3sUlksYA09uaH3GrKZgoGChF8m9bXK8eFW39z7wJNUw==} + engines: {node: '>=11.0'} + dependencies: + ses: 1.3.0 + dev: true + + /@endo/ses-ava@0.2.40: + resolution: {integrity: sha512-YIiAPuUfjS5dzyqeiV36FASv4YiSdkRzdxXbntNTBdOvdDymbT37SMkG0mUxD5YZRQuKMTu9xQyaGYSRqf8zaw==} + dependencies: + ses: 1.3.0 + dev: true + + /@endo/static-module-record@0.7.20: + resolution: {integrity: sha512-qpow712L7Bh7F3olFW9e15PcDWnC2eSY4xPdhpZoYTzedsyjCETRgxFWY6+DdT193lNlyKIn0On1O1Go+5WmBA==} + dependencies: + '@agoric/babel-generator': 7.17.6 + '@babel/parser': 7.23.9 + '@babel/traverse': 7.23.9 + '@babel/types': 7.23.9 + ses: 1.3.0 + transitivePeerDependencies: + - supports-color + dev: true + + /@endo/static-module-record@0.8.2: + resolution: {integrity: sha512-wHJLX/hU/MoSFvnFN9sZ/49DYPlbASHlVQrJszeKH3xIpBtl3SG4JdRswO6RQgLREQJD/HV/ZN5V8x2bCpMu4Q==} + dependencies: + '@agoric/babel-generator': 7.17.6 + '@babel/parser': 7.23.9 + '@babel/traverse': 7.23.9 + '@babel/types': 7.23.9 + ses: 1.3.0 + transitivePeerDependencies: + - supports-color + dev: true + + /@endo/stream-node@0.2.26: + resolution: {integrity: sha512-+UUr1/wZZIWz3KhuAwQr9HPsZv5P8zykw+z1aVFDckTMcdKRyK8yxSg35iEcntvyZoP40LEdnArCXuuEWjm0qw==} + dependencies: + '@endo/init': 0.5.60 + '@endo/stream': 0.3.25 + ses: 1.3.0 + dev: true + + /@endo/stream@0.3.25: + resolution: {integrity: sha512-qSl9Q9o20/4nKdXlXYCs6KJfeANMKBLrsi7JIxWV1jP9YzIDdq/PkEJsMNq89Z/HWXtPRfEQ4JEMd3O1WBYU5Q==} + dependencies: + '@endo/eventual-send': 0.17.2 + '@endo/promise-kit': 0.2.60 + ses: 1.3.0 + dev: true + + /@endo/where@0.3.5: + resolution: {integrity: sha512-y9agS7UWpSY9YSAAYwtn6sAE7zfU2BmYGOUJpw859WcmRt5ufCRi2XAXDcvIugAUPTsSVPqJj6FO3uZNVRmXPw==} + dev: true + + /@endo/zip@0.2.31: + resolution: {integrity: sha512-rNCZtQzPm6Q8kW69gyeU0hUwKZtwuR8cX1+URgpDuUuaMUbKWBaqURKOmrqKVtE5fkqCE7pSrHvGH02DMDbDHQ==} + dev: true + + /@endo/zip@0.2.35: + resolution: {integrity: sha512-UM+mMZjBtJf33lXj38xXIEIe1B5wrgg/nT9CHrC8s+Pj/h63eMpQmcJzjL2vMKrvq3Tsj+TDzmQhtYcbrFACqQ==} + dev: true + + /@esbuild/aix-ppc64@0.19.12: + resolution: {integrity: sha512-bmoCYyWdEL3wDQIVbcyzRyeKLgk2WtWLTWz1ZIAZF/EGbNOwSA6ew3PftJ1PqMiOOGu0OyFMzG53L0zqIpPeNA==} + engines: {node: '>=12'} + cpu: [ppc64] + os: [aix] + requiresBuild: true + dev: true + optional: true + + /@esbuild/android-arm64@0.18.20: + resolution: {integrity: sha512-Nz4rJcchGDtENV0eMKUNa6L12zz2zBDXuhj/Vjh18zGqB44Bi7MBMSXjgunJgjRhCmKOjnPuZp4Mb6OKqtMHLQ==} + engines: {node: '>=12'} + cpu: [arm64] + os: [android] + requiresBuild: true + dev: true + optional: true + + /@esbuild/android-arm64@0.19.12: + resolution: {integrity: sha512-P0UVNGIienjZv3f5zq0DP3Nt2IE/3plFzuaS96vihvD0Hd6H/q4WXUGpCxD/E8YrSXfNyRPbpTq+T8ZQioSuPA==} + engines: {node: '>=12'} + cpu: [arm64] + os: [android] + requiresBuild: true + dev: true + optional: true + + /@esbuild/android-arm@0.18.20: + resolution: {integrity: sha512-fyi7TDI/ijKKNZTUJAQqiG5T7YjJXgnzkURqmGj13C6dCqckZBLdl4h7bkhHt/t0WP+zO9/zwroDvANaOqO5Sw==} + engines: {node: '>=12'} + cpu: [arm] + os: [android] + requiresBuild: true + dev: true + optional: true + + /@esbuild/android-arm@0.19.12: + resolution: {integrity: sha512-qg/Lj1mu3CdQlDEEiWrlC4eaPZ1KztwGJ9B6J+/6G+/4ewxJg7gqj8eVYWvao1bXrqGiW2rsBZFSX3q2lcW05w==} + engines: {node: '>=12'} + cpu: [arm] + os: [android] + requiresBuild: true + dev: true + optional: true + + /@esbuild/android-x64@0.18.20: + resolution: {integrity: sha512-8GDdlePJA8D6zlZYJV/jnrRAi6rOiNaCC/JclcXpB+KIuvfBN4owLtgzY2bsxnx666XjJx2kDPUmnTtR8qKQUg==} + engines: {node: '>=12'} + cpu: [x64] + os: [android] + requiresBuild: true + dev: true + optional: true + + /@esbuild/android-x64@0.19.12: + resolution: {integrity: sha512-3k7ZoUW6Q6YqhdhIaq/WZ7HwBpnFBlW905Fa4s4qWJyiNOgT1dOqDiVAQFwBH7gBRZr17gLrlFCRzF6jFh7Kew==} + engines: {node: '>=12'} + cpu: [x64] + os: [android] + requiresBuild: true + dev: true + optional: true + + /@esbuild/darwin-arm64@0.18.20: + resolution: {integrity: sha512-bxRHW5kHU38zS2lPTPOyuyTm+S+eobPUnTNkdJEfAddYgEcll4xkT8DB9d2008DtTbl7uJag2HuE5NZAZgnNEA==} + engines: {node: '>=12'} + cpu: [arm64] + os: [darwin] + requiresBuild: true + dev: true + optional: true + + /@esbuild/darwin-arm64@0.19.12: + resolution: {integrity: sha512-B6IeSgZgtEzGC42jsI+YYu9Z3HKRxp8ZT3cqhvliEHovq8HSX2YX8lNocDn79gCKJXOSaEot9MVYky7AKjCs8g==} + engines: {node: '>=12'} + cpu: [arm64] + os: [darwin] + requiresBuild: true + dev: true + optional: true + + /@esbuild/darwin-x64@0.18.20: + resolution: {integrity: sha512-pc5gxlMDxzm513qPGbCbDukOdsGtKhfxD1zJKXjCCcU7ju50O7MeAZ8c4krSJcOIJGFR+qx21yMMVYwiQvyTyQ==} + engines: {node: '>=12'} + cpu: [x64] + os: [darwin] + requiresBuild: true + dev: true + optional: true + + /@esbuild/darwin-x64@0.19.12: + resolution: {integrity: sha512-hKoVkKzFiToTgn+41qGhsUJXFlIjxI/jSYeZf3ugemDYZldIXIxhvwN6erJGlX4t5h417iFuheZ7l+YVn05N3A==} + engines: {node: '>=12'} + cpu: [x64] + os: [darwin] + requiresBuild: true + dev: true + optional: true + + /@esbuild/freebsd-arm64@0.18.20: + resolution: {integrity: sha512-yqDQHy4QHevpMAaxhhIwYPMv1NECwOvIpGCZkECn8w2WFHXjEwrBn3CeNIYsibZ/iZEUemj++M26W3cNR5h+Tw==} + engines: {node: '>=12'} + cpu: [arm64] + os: [freebsd] + requiresBuild: true + dev: true + optional: true + + /@esbuild/freebsd-arm64@0.19.12: + resolution: {integrity: sha512-4aRvFIXmwAcDBw9AueDQ2YnGmz5L6obe5kmPT8Vd+/+x/JMVKCgdcRwH6APrbpNXsPz+K653Qg8HB/oXvXVukA==} + engines: {node: '>=12'} + cpu: [arm64] + os: [freebsd] + requiresBuild: true + dev: true + optional: true + + /@esbuild/freebsd-x64@0.18.20: + resolution: {integrity: sha512-tgWRPPuQsd3RmBZwarGVHZQvtzfEBOreNuxEMKFcd5DaDn2PbBxfwLcj4+aenoh7ctXcbXmOQIn8HI6mCSw5MQ==} + engines: {node: '>=12'} + cpu: [x64] + os: [freebsd] + requiresBuild: true + dev: true + optional: true + + /@esbuild/freebsd-x64@0.19.12: + resolution: {integrity: sha512-EYoXZ4d8xtBoVN7CEwWY2IN4ho76xjYXqSXMNccFSx2lgqOG/1TBPW0yPx1bJZk94qu3tX0fycJeeQsKovA8gg==} + engines: {node: '>=12'} + cpu: [x64] + os: [freebsd] + requiresBuild: true + dev: true + optional: true + + /@esbuild/linux-arm64@0.18.20: + resolution: {integrity: sha512-2YbscF+UL7SQAVIpnWvYwM+3LskyDmPhe31pE7/aoTMFKKzIc9lLbyGUpmmb8a8AixOL61sQ/mFh3jEjHYFvdA==} + engines: {node: '>=12'} + cpu: [arm64] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@esbuild/linux-arm64@0.19.12: + resolution: {integrity: sha512-EoTjyYyLuVPfdPLsGVVVC8a0p1BFFvtpQDB/YLEhaXyf/5bczaGeN15QkR+O4S5LeJ92Tqotve7i1jn35qwvdA==} + engines: {node: '>=12'} + cpu: [arm64] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@esbuild/linux-arm@0.18.20: + resolution: {integrity: sha512-/5bHkMWnq1EgKr1V+Ybz3s1hWXok7mDFUMQ4cG10AfW3wL02PSZi5kFpYKrptDsgb2WAJIvRcDm+qIvXf/apvg==} + engines: {node: '>=12'} + cpu: [arm] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@esbuild/linux-arm@0.19.12: + resolution: {integrity: sha512-J5jPms//KhSNv+LO1S1TX1UWp1ucM6N6XuL6ITdKWElCu8wXP72l9MM0zDTzzeikVyqFE6U8YAV9/tFyj0ti+w==} + engines: {node: '>=12'} + cpu: [arm] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@esbuild/linux-ia32@0.18.20: + resolution: {integrity: sha512-P4etWwq6IsReT0E1KHU40bOnzMHoH73aXp96Fs8TIT6z9Hu8G6+0SHSw9i2isWrD2nbx2qo5yUqACgdfVGx7TA==} + engines: {node: '>=12'} + cpu: [ia32] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@esbuild/linux-ia32@0.19.12: + resolution: {integrity: sha512-Thsa42rrP1+UIGaWz47uydHSBOgTUnwBwNq59khgIwktK6x60Hivfbux9iNR0eHCHzOLjLMLfUMLCypBkZXMHA==} + engines: {node: '>=12'} + cpu: [ia32] + os: [linux] + requiresBuild: true + dev: true + optional: true - /@humanwhocodes/config-array@0.11.10: - resolution: {integrity: sha512-KVVjQmNUepDVGXNuoRRdmmEjruj0KfiGSbS8LVc12LMsWDQzRXJ0qdhN8L8uUigKpfEHRhlaQFY0ib1tnUbNeQ==} + /@esbuild/linux-loong64@0.18.20: + resolution: {integrity: sha512-nXW8nqBTrOpDLPgPY9uV+/1DjxoQ7DoB2N8eocyq8I9XuqJ7BiAMDMf9n1xZM9TgW0J8zrquIb/A7s3BJv7rjg==} + engines: {node: '>=12'} + cpu: [loong64] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@esbuild/linux-loong64@0.19.12: + resolution: {integrity: sha512-LiXdXA0s3IqRRjm6rV6XaWATScKAXjI4R4LoDlvO7+yQqFdlr1Bax62sRwkVvRIrwXxvtYEHHI4dm50jAXkuAA==} + engines: {node: '>=12'} + cpu: [loong64] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@esbuild/linux-mips64el@0.18.20: + resolution: {integrity: sha512-d5NeaXZcHp8PzYy5VnXV3VSd2D328Zb+9dEq5HE6bw6+N86JVPExrA6O68OPwobntbNJ0pzCpUFZTo3w0GyetQ==} + engines: {node: '>=12'} + cpu: [mips64el] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@esbuild/linux-mips64el@0.19.12: + resolution: {integrity: sha512-fEnAuj5VGTanfJ07ff0gOA6IPsvrVHLVb6Lyd1g2/ed67oU1eFzL0r9WL7ZzscD+/N6i3dWumGE1Un4f7Amf+w==} + engines: {node: '>=12'} + cpu: [mips64el] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@esbuild/linux-ppc64@0.18.20: + resolution: {integrity: sha512-WHPyeScRNcmANnLQkq6AfyXRFr5D6N2sKgkFo2FqguP44Nw2eyDlbTdZwd9GYk98DZG9QItIiTlFLHJHjxP3FA==} + engines: {node: '>=12'} + cpu: [ppc64] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@esbuild/linux-ppc64@0.19.12: + resolution: {integrity: sha512-nYJA2/QPimDQOh1rKWedNOe3Gfc8PabU7HT3iXWtNUbRzXS9+vgB0Fjaqr//XNbd82mCxHzik2qotuI89cfixg==} + engines: {node: '>=12'} + cpu: [ppc64] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@esbuild/linux-riscv64@0.18.20: + resolution: {integrity: sha512-WSxo6h5ecI5XH34KC7w5veNnKkju3zBRLEQNY7mv5mtBmrP/MjNBCAlsM2u5hDBlS3NGcTQpoBvRzqBcRtpq1A==} + engines: {node: '>=12'} + cpu: [riscv64] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@esbuild/linux-riscv64@0.19.12: + resolution: {integrity: sha512-2MueBrlPQCw5dVJJpQdUYgeqIzDQgw3QtiAHUC4RBz9FXPrskyyU3VI1hw7C0BSKB9OduwSJ79FTCqtGMWqJHg==} + engines: {node: '>=12'} + cpu: [riscv64] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@esbuild/linux-s390x@0.18.20: + resolution: {integrity: sha512-+8231GMs3mAEth6Ja1iK0a1sQ3ohfcpzpRLH8uuc5/KVDFneH6jtAJLFGafpzpMRO6DzJ6AvXKze9LfFMrIHVQ==} + engines: {node: '>=12'} + cpu: [s390x] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@esbuild/linux-s390x@0.19.12: + resolution: {integrity: sha512-+Pil1Nv3Umes4m3AZKqA2anfhJiVmNCYkPchwFJNEJN5QxmTs1uzyy4TvmDrCRNT2ApwSari7ZIgrPeUx4UZDg==} + engines: {node: '>=12'} + cpu: [s390x] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@esbuild/linux-x64@0.18.20: + resolution: {integrity: sha512-UYqiqemphJcNsFEskc73jQ7B9jgwjWrSayxawS6UVFZGWrAAtkzjxSqnoclCXxWtfwLdzU+vTpcNYhpn43uP1w==} + engines: {node: '>=12'} + cpu: [x64] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@esbuild/linux-x64@0.19.12: + resolution: {integrity: sha512-B71g1QpxfwBvNrfyJdVDexenDIt1CiDN1TIXLbhOw0KhJzE78KIFGX6OJ9MrtC0oOqMWf+0xop4qEU8JrJTwCg==} + engines: {node: '>=12'} + cpu: [x64] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@esbuild/netbsd-x64@0.18.20: + resolution: {integrity: sha512-iO1c++VP6xUBUmltHZoMtCUdPlnPGdBom6IrO4gyKPFFVBKioIImVooR5I83nTew5UOYrk3gIJhbZh8X44y06A==} + engines: {node: '>=12'} + cpu: [x64] + os: [netbsd] + requiresBuild: true + dev: true + optional: true + + /@esbuild/netbsd-x64@0.19.12: + resolution: {integrity: sha512-3ltjQ7n1owJgFbuC61Oj++XhtzmymoCihNFgT84UAmJnxJfm4sYCiSLTXZtE00VWYpPMYc+ZQmB6xbSdVh0JWA==} + engines: {node: '>=12'} + cpu: [x64] + os: [netbsd] + requiresBuild: true + dev: true + optional: true + + /@esbuild/openbsd-x64@0.18.20: + resolution: {integrity: sha512-e5e4YSsuQfX4cxcygw/UCPIEP6wbIL+se3sxPdCiMbFLBWu0eiZOJ7WoD+ptCLrmjZBK1Wk7I6D/I3NglUGOxg==} + engines: {node: '>=12'} + cpu: [x64] + os: [openbsd] + requiresBuild: true + dev: true + optional: true + + /@esbuild/openbsd-x64@0.19.12: + resolution: {integrity: sha512-RbrfTB9SWsr0kWmb9srfF+L933uMDdu9BIzdA7os2t0TXhCRjrQyCeOt6wVxr79CKD4c+p+YhCj31HBkYcXebw==} + engines: {node: '>=12'} + cpu: [x64] + os: [openbsd] + requiresBuild: true + dev: true + optional: true + + /@esbuild/sunos-x64@0.18.20: + resolution: {integrity: sha512-kDbFRFp0YpTQVVrqUd5FTYmWo45zGaXe0X8E1G/LKFC0v8x0vWrhOWSLITcCn63lmZIxfOMXtCfti/RxN/0wnQ==} + engines: {node: '>=12'} + cpu: [x64] + os: [sunos] + requiresBuild: true + dev: true + optional: true + + /@esbuild/sunos-x64@0.19.12: + resolution: {integrity: sha512-HKjJwRrW8uWtCQnQOz9qcU3mUZhTUQvi56Q8DPTLLB+DawoiQdjsYq+j+D3s9I8VFtDr+F9CjgXKKC4ss89IeA==} + engines: {node: '>=12'} + cpu: [x64] + os: [sunos] + requiresBuild: true + dev: true + optional: true + + /@esbuild/win32-arm64@0.18.20: + resolution: {integrity: sha512-ddYFR6ItYgoaq4v4JmQQaAI5s7npztfV4Ag6NrhiaW0RrnOXqBkgwZLofVTlq1daVTQNhtI5oieTvkRPfZrePg==} + engines: {node: '>=12'} + cpu: [arm64] + os: [win32] + requiresBuild: true + dev: true + optional: true + + /@esbuild/win32-arm64@0.19.12: + resolution: {integrity: sha512-URgtR1dJnmGvX864pn1B2YUYNzjmXkuJOIqG2HdU62MVS4EHpU2946OZoTMnRUHklGtJdJZ33QfzdjGACXhn1A==} + engines: {node: '>=12'} + cpu: [arm64] + os: [win32] + requiresBuild: true + dev: true + optional: true + + /@esbuild/win32-ia32@0.18.20: + resolution: {integrity: sha512-Wv7QBi3ID/rROT08SABTS7eV4hX26sVduqDOTe1MvGMjNd3EjOz4b7zeexIR62GTIEKrfJXKL9LFxTYgkyeu7g==} + engines: {node: '>=12'} + cpu: [ia32] + os: [win32] + requiresBuild: true + dev: true + optional: true + + /@esbuild/win32-ia32@0.19.12: + resolution: {integrity: sha512-+ZOE6pUkMOJfmxmBZElNOx72NKpIa/HFOMGzu8fqzQJ5kgf6aTGrcJaFsNiVMH4JKpMipyK+7k0n2UXN7a8YKQ==} + engines: {node: '>=12'} + cpu: [ia32] + os: [win32] + requiresBuild: true + dev: true + optional: true + + /@esbuild/win32-x64@0.18.20: + resolution: {integrity: sha512-kTdfRcSiDfQca/y9QIkng02avJ+NCaQvrMejlsB3RRv5sE9rRoeBPISaZpKxHELzRxZyLvNts1P27W3wV+8geQ==} + engines: {node: '>=12'} + cpu: [x64] + os: [win32] + requiresBuild: true + dev: true + optional: true + + /@esbuild/win32-x64@0.19.12: + resolution: {integrity: sha512-T1QyPSDCyMXaO3pzBkF96E8xMkiRYbUEZADd29SyPGabqxMViNoii+NcK7eWJAEoU6RZyEm5lVSIjTmcdoB9HA==} + engines: {node: '>=12'} + cpu: [x64] + os: [win32] + requiresBuild: true + dev: true + optional: true + + /@eslint-community/eslint-utils@4.4.0(eslint@8.57.0): + resolution: {integrity: sha512-1/sA4dwrzBAyeUoQ6oxahHKmrZvsnLCg4RfxW3ZFGGmQkSNQPFNLV9CUEFQP1x9EYXHTo5p6xdhZM1Ne9p/AfA==} + engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} + peerDependencies: + eslint: ^6.0.0 || ^7.0.0 || >=8.0.0 + dependencies: + eslint: 8.57.0 + eslint-visitor-keys: 3.4.3 + dev: true + + /@eslint-community/regexpp@4.10.0: + resolution: {integrity: sha512-Cu96Sd2By9mCNTx2iyKOmq10v22jUVQv0lQnlGNy16oE9589yE+QADPbrMGCkA51cKZSg3Pu/aTJVTGfL/qjUA==} + engines: {node: ^12.0.0 || ^14.0.0 || >=16.0.0} + dev: true + + /@eslint/eslintrc@2.1.4: + resolution: {integrity: sha512-269Z39MS6wVJtsoUl10L60WdkhJVdPG24Q4eZTH3nnF6lpvSShEK3wQjDX9JRWAUPvPh7COouPpU9IrqaZFvtQ==} + engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} + dependencies: + ajv: 6.12.6 + debug: 4.3.4(supports-color@8.1.1) + espree: 9.6.1 + globals: 13.24.0 + ignore: 5.3.1 + import-fresh: 3.3.0 + js-yaml: 4.1.0 + minimatch: 3.1.2 + strip-json-comments: 3.1.1 + transitivePeerDependencies: + - supports-color + dev: true + + /@eslint/js@8.57.0: + resolution: {integrity: sha512-Ys+3g2TaW7gADOJzPt83SJtCDhMjndcDMFVQ/Tj9iA1BfJzFKD9mAUXT3OenpuPHbI6P/myECxRJrofUsDx/5g==} + engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} + dev: true + + /@fast-check/ava@1.2.1(ava@5.3.1): + resolution: {integrity: sha512-d7O8CjYV2e+JFnN67Yofw+tt16fJI7kuX1K7OZCNxqQL5XNrkipWBmAmW9sPxYVjaItPBPvTPp7nORsO9KuBgg==} + peerDependencies: + ava: ^4 || ^5 || ^6 + dependencies: + ava: 5.3.1 + fast-check: 3.15.1 + dev: true + + /@foundry-rs/easy-foundryup@0.1.3: + resolution: {integrity: sha512-Funb4hrSBeikKCmccFT/d3Ud5o92tlIZHTJeMCVk5b54/+CHZHr4g7MmtvO5xrGhxrOebQ0L+ojIj+VixgW7ug==} + dependencies: + command-exists: 1.2.9 + ts-interface-checker: 0.1.13 + dev: false + + /@gar/promisify@1.1.3: + resolution: {integrity: sha512-k2Ty1JcVojjJFwrg/ThKi2ujJ7XNLYaFGNB/bWT9wGR+oSMJHMa5w+CUq6p/pVrKeNNgA7pCqEcjSnHVoqJQFw==} + dev: true + + /@hapi/hoek@9.3.0: + resolution: {integrity: sha512-/c6rf4UJlmHlC9b5BaNvzAcFv7HZ2QHaV0D4/HNlBdvFnvQq8RI4kYdhyPCl7Xj+oWvTWQ8ujhqS53LIgAe6KQ==} + + /@hapi/topo@5.1.0: + resolution: {integrity: sha512-foQZKJig7Ob0BMAYBfcJk8d77QtOe7Wo4ox7ff1lQYoNNAb6jwcY1ncdoy2e9wQZzvNy7ODZCYJkK8kzmcAnAg==} + dependencies: + '@hapi/hoek': 9.3.0 + + /@humanwhocodes/config-array@0.11.14: + resolution: {integrity: sha512-3T8LkOmg45BV5FICb15QQMsyUSWrQ8AygVfC7ZG32zOalnqrilm018ZVCw0eapXux8FtA33q8PSRSstjee3jSg==} engines: {node: '>=10.10.0'} dependencies: - '@humanwhocodes/object-schema': 1.2.1 + '@humanwhocodes/object-schema': 2.0.2 debug: 4.3.4(supports-color@8.1.1) minimatch: 3.1.2 transitivePeerDependencies: @@ -1547,8 +3370,8 @@ packages: engines: {node: '>=12.22'} dev: true - /@humanwhocodes/object-schema@1.2.1: - resolution: {integrity: sha512-ZnQMnLV4e7hDlUvw8H+U8ASL02SS2Gn6+9Ac3wGGLIe7+je2AeAOxPY+izIPJDfFDb7eDjev0Us8MO1iFRN8hA==} + /@humanwhocodes/object-schema@2.0.2: + resolution: {integrity: sha512-6EwiSjwWYP7pTckG6I5eyFANjPhmPjUX9JRLUSfNPC7FX7zK9gyZAfUEaECL6ALTpGX5AjnBq3C9XmVWPitNpw==} dev: true /@iarna/toml@2.2.5: @@ -1565,7 +3388,6 @@ packages: strip-ansi-cjs: /strip-ansi@6.0.1 wrap-ansi: 8.1.0 wrap-ansi-cjs: /wrap-ansi@7.0.0 - dev: true /@istanbuljs/load-nyc-config@1.1.0: resolution: {integrity: sha512-VjeHSlIzpv/NyD3N0YuHfXOPDIixcA1q2ZV98wsMqcYlPmv2n3Yb2lYP9XMElnaFVXg5A7YLTeLu6V84uQDjmQ==} @@ -1583,58 +3405,72 @@ packages: engines: {node: '>=8'} dev: false - /@jridgewell/gen-mapping@0.3.3: - resolution: {integrity: sha512-HLhSWOLRi875zjjMG/r+Nv0oCW8umGb0BgEhyX3dDX3egwZtB8PqLnjz3yedt8R5StBrzcg4aBpnh8UA9D1BoQ==} + /@jest/schemas@29.6.3: + resolution: {integrity: sha512-mo5j5X+jIZmJQveBKeS/clAueipV7KgiX1vMgCxam1RNYiqE1w62n0/tJJnHtjW8ZHcQco5gY85jA3mi0L+nSA==} + engines: {node: ^14.15.0 || ^16.10.0 || >=18.0.0} + dependencies: + '@sinclair/typebox': 0.27.8 + dev: true + + /@jridgewell/gen-mapping@0.3.4: + resolution: {integrity: sha512-Oud2QPM5dHviZNn4y/WhhYKSXksv+1xLEIsNrAbGcFzUN3ubqWRFT5gwPchNc5NuzILOU4tPBDTZ4VwhL8Y7cw==} engines: {node: '>=6.0.0'} dependencies: '@jridgewell/set-array': 1.1.2 '@jridgewell/sourcemap-codec': 1.4.15 - '@jridgewell/trace-mapping': 0.3.18 - dev: false + '@jridgewell/trace-mapping': 0.3.23 - /@jridgewell/resolve-uri@3.1.0: - resolution: {integrity: sha512-F2msla3tad+Mfht5cJq7LSXcdudKTWCVYUgw6pLFOOHSTtZlj6SWNYAp+AhuqLmWdBO2X5hPrLcu8cVP8fy28w==} + /@jridgewell/resolve-uri@3.1.2: + resolution: {integrity: sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==} engines: {node: '>=6.0.0'} - dev: false /@jridgewell/set-array@1.1.2: resolution: {integrity: sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==} engines: {node: '>=6.0.0'} - dev: false - /@jridgewell/source-map@0.3.3: - resolution: {integrity: sha512-b+fsZXeLYi9fEULmfBrhxn4IrPlINf8fiNarzTof004v3lFdntdwa9PF7vFJqm3mg7s+ScJMxXaE3Acp1irZcg==} + /@jridgewell/source-map@0.3.5: + resolution: {integrity: sha512-UTYAUj/wviwdsMfzoSJspJxbkH5o1snzwX0//0ENX1u/55kkZZkcTZP6u9bwKGkv+dkk9at4m1Cpt0uY80kcpQ==} dependencies: - '@jridgewell/gen-mapping': 0.3.3 - '@jridgewell/trace-mapping': 0.3.18 - dev: false - - /@jridgewell/sourcemap-codec@1.4.14: - resolution: {integrity: sha512-XPSJHWmi394fuUuzDnGz1wiKqWfo1yXecHQMRf2l6hztTO+nPru658AyDngaBe7isIxEkRsPR3FZh+s7iVa4Uw==} + '@jridgewell/gen-mapping': 0.3.4 + '@jridgewell/trace-mapping': 0.3.23 dev: false /@jridgewell/sourcemap-codec@1.4.15: resolution: {integrity: sha512-eF2rxCRulEKXHTRiDrDy6erMYWqNw4LPdQ8UQA4huuxaQsVeRPFl2oM8oDGxMFhJUWZf9McpLtJasDDZb/Bpeg==} - dev: false - /@jridgewell/trace-mapping@0.3.18: - resolution: {integrity: sha512-w+niJYzMHdd7USdiH2U6869nqhD2nbfZXND5Yp93qIbEmnDNk7PD48o+YchRVpzMU7M6jVCbenTR7PA1FLQ9pA==} + /@jridgewell/trace-mapping@0.3.23: + resolution: {integrity: sha512-9/4foRoUKp8s96tSkh8DlAAc5A0Ty8vLXld+l9gjKKY6ckwI8G15f0hskGmuLZu78ZlGa1vtsfOa+lnB4vG6Jg==} dependencies: - '@jridgewell/resolve-uri': 3.1.0 - '@jridgewell/sourcemap-codec': 1.4.14 - dev: false + '@jridgewell/resolve-uri': 3.1.2 + '@jridgewell/sourcemap-codec': 1.4.15 /@leichtgewicht/ip-codec@2.0.4: resolution: {integrity: sha512-Hcv+nVC0kZnQ3tD9GVu5xSMR4VVYOteQIr/hwFPVEvPdlXqgGEuRjiheChHgdM+JyqdgNcmzZOX/tnl0JOiI7A==} dev: false - /@ljharb/through@2.3.9: - resolution: {integrity: sha512-yN599ZBuMPPK4tdoToLlvgJB4CLK8fGl7ntfy0Wn7U6ttNvHYurd81bfUiK/6sMkiIwm65R6ck4L6+Y3DfVbNQ==} + /@lit-labs/react@1.2.1: + resolution: {integrity: sha512-DiZdJYFU0tBbdQkfwwRSwYyI/mcWkg3sWesKRsHUd4G+NekTmmeq9fzsurvcKTNVa0comNljwtg4Hvi1ds3V+A==} + dev: true + + /@lit-labs/ssr-dom-shim@1.2.0: + resolution: {integrity: sha512-yWJKmpGE6lUURKAaIltoPIE/wrbY3TEkqQt+X0m+7fQNnAv0keydnYvbiJFP1PnMhizmIWRWOG5KLhYyc/xl+g==} + dev: true + + /@lit/reactive-element@1.6.3: + resolution: {integrity: sha512-QuTgnG52Poic7uM1AN5yJ09QMe0O28e10XzSvWDz02TJiiKee4stsiownEIadWm8nYzyDAyT+gKzUoZmiWQtsQ==} + dependencies: + '@lit-labs/ssr-dom-shim': 1.2.0 + dev: true + + /@ljharb/through@2.3.12: + resolution: {integrity: sha512-ajo/heTlG3QgC8EGP6APIejksVAYt4ayz4tqoP3MolFELzcH1x1fzwEYRJTPO0IELutZ5HQ0c26/GqAYy79u3g==} engines: {node: '>= 0.4'} + dependencies: + call-bind: 1.0.7 dev: true - /@metamask/test-dapp@7.0.1: - resolution: {integrity: sha512-HB7wbzU9mizzuv1Tcjh/PAXwayw/nyHnDv1V0ySyoqGM+o/MswdLpPApwT+HIZJuL/bHpu8PHPYfouujy9EfoQ==} + /@metamask/test-dapp@7.3.1: + resolution: {integrity: sha512-uQ+GoiARmol07d0QWDdgfLBaG9Wv3l612ZSjHqBNooPOIf44S9ksqU214KWXtZvq1u902QjKdBH2ujDTI1iOCA==} engines: {node: '>= 16.0.0'} dev: true @@ -1642,42 +3478,23 @@ packages: resolution: {integrity: sha512-KIKkT44hEqCzqxODYwFMUvYEK0CrdHx/Ll9xiOWgFbBSRuzbxmVy4d/tzfgoucGz72HJZNOMjuyzFTBKntRK5Q==} engines: {node: '>= 14'} dependencies: - eslint: 8.47.0 + eslint: 8.57.0 jschardet: 3.0.0 lodash: 4.17.21 utf8: 3.0.0 transitivePeerDependencies: - - supports-color - dev: true - - /@noble/curves@1.0.0: - resolution: {integrity: sha512-2upgEu0iLiDVDZkNLeFV2+ht0BAVgQnEmCk6JsOch9Rp8xfkMCbvbAZlA2pBHQc73dbl+vFOXfqkf4uemdn0bw==} - dependencies: - '@noble/hashes': 1.3.0 - dev: false + - supports-color + dev: true - /@noble/curves@1.1.0: - resolution: {integrity: sha512-091oBExgENk/kGj3AZmtBDMpxQPDtxQABR2B9lb1JbVTs6ytdzZNwvhxQ4MWasRNEzlbEH8jCWFCwhF/Obj5AA==} + /@noble/curves@1.2.0: + resolution: {integrity: sha512-oYclrNgRaM9SsBUBVbb8M6DTV7ZHRTKugureoYEncY5c65HOmRzvSiTE3y5CYaPYJA/GVkrhXEoF0M3Ya9PMnw==} dependencies: - '@noble/hashes': 1.3.1 - dev: false - - /@noble/hashes@1.1.2: - resolution: {integrity: sha512-KYRCASVTv6aeUi1tsF8/vpyR7zpfs3FUzy2Jqm+MU+LmUKhQ0y2FpfwqkCcxSg2ua4GALJd8k2R76WxwZGbQpA==} + '@noble/hashes': 1.3.2 dev: false - /@noble/hashes@1.3.0: - resolution: {integrity: sha512-ilHEACi9DwqJB0pw7kv+Apvh50jiiSyR/cQ3y4W7lOR5mhvn/50FLUfsnfJz0BDZtl/RR16kXvptiv6q1msYZg==} - dev: false - - /@noble/hashes@1.3.1: - resolution: {integrity: sha512-EbqwksQwz9xDRGfDST86whPBgM65E0OH/pCgqW0GBVzO22bNE+NuIbeTb714+IfSjU3aRk47EUvXIb5bTsenKA==} + /@noble/hashes@1.3.2: + resolution: {integrity: sha512-MVC8EAQp7MvEcm30KWENFjgR+Mkmf+D189XJTkFIlwohU5hcBbn1ZkKq7KVTi2Hme3PMGF390DaL52beVrIihQ==} engines: {node: '>= 16'} - dev: false - - /@noble/secp256k1@1.7.1: - resolution: {integrity: sha512-hOUk6AyBFmqVrv7k5WAw/LpszxVbj9gGN4JRkIX52fdFAj1UA61KXmZDvqVEm+pOyec3+fIeZB02LYa/pWOArw==} - dev: false /@nodelib/fs.scandir@2.1.5: resolution: {integrity: sha512-vq24Bq3ym5HEQm2NKCr3yXDwjc7vTsEThRDnkp2DK9p1uqLR+DHurm/NOTo0KG7HYHU7eppKZj3MyqYuMBf62g==} @@ -1695,34 +3512,34 @@ packages: engines: {node: '>= 8'} dependencies: '@nodelib/fs.scandir': 2.1.5 - fastq: 1.15.0 + fastq: 1.17.1 /@npmcli/fs@2.1.2: resolution: {integrity: sha512-yOJKRvohFOaLqipNtwYB9WugyZKhC/DZC4VYPmpaCzDBrA8YpK3qHZ8/HGscMnE4GqbkLNuVcCnxkeQEdGt6LQ==} engines: {node: ^12.13.0 || ^14.15.0 || >=16.0.0} dependencies: '@gar/promisify': 1.1.3 - semver: 7.5.4 + semver: 7.6.0 dev: true /@npmcli/fs@3.1.0: resolution: {integrity: sha512-7kZUAaLscfgbwBQRbvdMYaZOWyMEcPTH/tJjnyAWJ/dvvs9Ef+CERx/qJb9GExJpl1qipaDGn7KqHnFGGixd0w==} engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} dependencies: - semver: 7.5.4 + semver: 7.6.0 dev: true - /@npmcli/git@4.0.4: - resolution: {integrity: sha512-5yZghx+u5M47LghaybLCkdSyFzV/w4OuH12d96HO389Ik9CDsLaDZJVynSGGVJOLn6gy/k7Dz5XYcplM3uxXRg==} + /@npmcli/git@4.1.0: + resolution: {integrity: sha512-9hwoB3gStVfa0N31ymBmrX+GuDGdVA/QWShZVqE0HK2Af+7QGGrCTbZia/SW0ImUTjTne7SP91qxDmtXvDHRPQ==} engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} dependencies: '@npmcli/promise-spawn': 6.0.2 lru-cache: 7.18.3 - npm-pick-manifest: 8.0.1 + npm-pick-manifest: 8.0.2 proc-log: 3.0.0 promise-inflight: 1.0.1 promise-retry: 2.0.1 - semver: 7.5.4 + semver: 7.6.0 which: 3.0.1 transitivePeerDependencies: - bluebird @@ -1734,7 +3551,7 @@ packages: hasBin: true dependencies: npm-bundled: 3.0.0 - npm-normalize-package-bin: 3.0.0 + npm-normalize-package-bin: 3.0.1 dev: true /@npmcli/move-file@2.0.1: @@ -1758,13 +3575,13 @@ packages: which: 3.0.1 dev: true - /@npmcli/run-script@6.0.1: - resolution: {integrity: sha512-Yi04ZSold8jcbBJD/ahKMJSQCQifH8DAbMwkBvoLaTpGFxzHC3B/5ZyoVR69q/4xedz84tvi9DJOJjNe17h+LA==} + /@npmcli/run-script@6.0.2: + resolution: {integrity: sha512-NCcr1uQo1k5U+SYlnIrbAh3cxy+OQT1VtqiAbxdymSlptbzBb62AjH2xXgjNCoP073hoa1CfCAcwoZ8k96C4nA==} engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} dependencies: '@npmcli/node-gyp': 3.0.0 '@npmcli/promise-spawn': 6.0.2 - node-gyp: 9.3.1 + node-gyp: 9.4.1 read-package-json-fast: 3.0.2 which: 3.0.1 transitivePeerDependencies: @@ -1772,50 +3589,48 @@ packages: - supports-color dev: true - /@octokit/auth-token@3.0.3: - resolution: {integrity: sha512-/aFM2M4HVDBT/jjDBa84sJniv1t9Gm/rLkalaz9htOm+L+8JMj1k9w0CkUdcxNyNxZPlTxKPVko+m1VlM58ZVA==} + /@octokit/auth-token@3.0.4: + resolution: {integrity: sha512-TWFX7cZF2LXoCvdmJWY7XVPi74aSY0+FfBZNSXEXFkMpjcqsQwDSYVv5FhRFaI0V1ECnwbz4j59T/G+rXNWaIQ==} engines: {node: '>= 14'} - dependencies: - '@octokit/types': 9.3.2 dev: true /@octokit/core@4.2.4: resolution: {integrity: sha512-rYKilwgzQ7/imScn3M9/pFfUf4I1AZEH3KhyJmtPdE2zfaXAn2mFfUy4FbKewzc2We5y/LlKLj36fWJLKC2SIQ==} engines: {node: '>= 14'} dependencies: - '@octokit/auth-token': 3.0.3 - '@octokit/graphql': 5.0.5 - '@octokit/request': 6.2.3 + '@octokit/auth-token': 3.0.4 + '@octokit/graphql': 5.0.6 + '@octokit/request': 6.2.8 '@octokit/request-error': 3.0.3 '@octokit/types': 9.3.2 before-after-hook: 2.2.3 - universal-user-agent: 6.0.0 + universal-user-agent: 6.0.1 transitivePeerDependencies: - encoding dev: true - /@octokit/endpoint@7.0.5: - resolution: {integrity: sha512-LG4o4HMY1Xoaec87IqQ41TQ+glvIeTKqfjkCEmt5AIwDZJwQeVZFIEYXrYY6yLwK+pAScb9Gj4q+Nz2qSw1roA==} + /@octokit/endpoint@7.0.6: + resolution: {integrity: sha512-5L4fseVRUsDFGR00tMWD/Trdeeihn999rTMGRMC1G/Ldi1uWlWJzI98H4Iak5DB/RVvQuyMYKqSK/R6mbSOQyg==} engines: {node: '>= 14'} dependencies: '@octokit/types': 9.3.2 is-plain-object: 5.0.0 - universal-user-agent: 6.0.0 + universal-user-agent: 6.0.1 dev: true - /@octokit/graphql@5.0.5: - resolution: {integrity: sha512-Qwfvh3xdqKtIznjX9lz2D458r7dJPP8l6r4GQkIdWQouZwHQK0mVT88uwiU2bdTU2OtT1uOlKpRciUWldpG0yQ==} + /@octokit/graphql@5.0.6: + resolution: {integrity: sha512-Fxyxdy/JH0MnIB5h+UQ3yCoh1FG4kWXfFKkpWqjZHw/p+Kc8Y44Hu/kCgNBT6nU1shNumEchmW/sUO1JuQnPcw==} engines: {node: '>= 14'} dependencies: - '@octokit/request': 6.2.3 + '@octokit/request': 6.2.8 '@octokit/types': 9.3.2 - universal-user-agent: 6.0.0 + universal-user-agent: 6.0.1 transitivePeerDependencies: - encoding dev: true - /@octokit/openapi-types@18.0.0: - resolution: {integrity: sha512-V8GImKs3TeQRxRtXFpG2wl19V7444NIOTDF24AWuIbmNaNYOQMWRbjcGDXV5B+0n887fgDcuMNOmlul+k+oJtw==} + /@octokit/openapi-types@18.1.1: + resolution: {integrity: sha512-VRaeH8nCDtF5aXWnjPuEMIYf1itK/s3JYyJcWFJT8X9pSNnBtriDf7wlEWsGuhPLl4QIH4xM8fqTXDwJ3Mu6sw==} dev: true /@octokit/plugin-paginate-rest@6.1.2(@octokit/core@4.2.4): @@ -1856,16 +3671,16 @@ packages: once: 1.4.0 dev: true - /@octokit/request@6.2.3: - resolution: {integrity: sha512-TNAodj5yNzrrZ/VxP+H5HiYaZep0H3GU0O7PaF+fhDrt8FPrnkei9Aal/txsN/1P7V3CPiThG0tIvpPDYUsyAA==} + /@octokit/request@6.2.8: + resolution: {integrity: sha512-ow4+pkVQ+6XVVsekSYBzJC0VTVvh/FCTUUgTsboGq+DTeWdyIFV8WSCdo0RIxk6wSkBTHqIK1mYuY7nOBXOchw==} engines: {node: '>= 14'} dependencies: - '@octokit/endpoint': 7.0.5 + '@octokit/endpoint': 7.0.6 '@octokit/request-error': 3.0.3 '@octokit/types': 9.3.2 is-plain-object: 5.0.0 - node-fetch: 2.6.9 - universal-user-agent: 6.0.0 + node-fetch: 2.7.0 + universal-user-agent: 6.0.1 transitivePeerDependencies: - encoding dev: true @@ -1889,43 +3704,52 @@ packages: /@octokit/types@10.0.0: resolution: {integrity: sha512-Vm8IddVmhCgU1fxC1eyinpwqzXPEYu0NrYzD3YZjlGjyftdLBTeqNblRC0jmJmgxbJIsQlyogVeGnrNaaMVzIg==} dependencies: - '@octokit/openapi-types': 18.0.0 + '@octokit/openapi-types': 18.1.1 dev: true /@octokit/types@9.3.2: resolution: {integrity: sha512-D4iHGTdAnEEVsB8fl95m1hiz7D5YiRdQ9b/OEb3BYRVwbLsGHcRVPz+u+BgRLNk0Q0/4iZCBqDN96j2XNxfXrA==} dependencies: - '@octokit/openapi-types': 18.0.0 + '@octokit/openapi-types': 18.1.1 + dev: true + + /@opentelemetry/api@1.7.0: + resolution: {integrity: sha512-AdY5wvN0P2vXBi3b29hxZgSFvdhdxPB9+f0B6s//P9Q8nibRWeA3cHm8UmLpio9ABigkVHJ5NMPk+Mz8VCCyrw==} + engines: {node: '>=8.0.0'} + dev: true + + /@opentelemetry/core@1.21.0(@opentelemetry/api@1.7.0): + resolution: {integrity: sha512-KP+OIweb3wYoP7qTYL/j5IpOlu52uxBv5M4+QhSmmUfLyTgu1OIS71msK3chFo1D6Y61BIH3wMiMYRCxJCQctA==} + engines: {node: '>=14'} + peerDependencies: + '@opentelemetry/api': '>=1.0.0 <1.8.0' + dependencies: + '@opentelemetry/api': 1.7.0 + '@opentelemetry/semantic-conventions': 1.21.0 + dev: true + + /@opentelemetry/semantic-conventions@1.21.0: + resolution: {integrity: sha512-lkC8kZYntxVKr7b8xmjCVUgE0a8xgDakPyDo9uSWavXPyYqLgYYGdEd2j8NxihRyb6UwpX3G/hFUF4/9q2V+/g==} + engines: {node: '>=14'} dev: true /@pkgjs/parseargs@0.11.0: resolution: {integrity: sha512-+1VkjdD0QBLPodGrJUeqarH8VAIvQODIbwh9XpP5Syisf7YoQgsJKPNFoqqLQlu+VQ/tVSshMR6loPMn8U+dPg==} engines: {node: '>=14'} requiresBuild: true - dev: true optional: true - /@pkgr/utils@2.4.2: - resolution: {integrity: sha512-POgTXhjrTfbTV63DiFXav4lBHiICLKKwDeaKn9Nphwj7WH6m0hMMCaJkMyRWjgtPFyRKRVoMXXjczsTQRDEhYw==} + /@pkgr/core@0.1.1: + resolution: {integrity: sha512-cq8o4cWH0ibXh9VGi5P20Tu9XF/0fFXl9EUinr9QfTM7a7p0oTA4iJRCQWppXR1Pg8dSM0UCItCkPwsk9qWWYA==} engines: {node: ^12.20.0 || ^14.18.0 || >=16.0.0} - dependencies: - cross-spawn: 7.0.3 - fast-glob: 3.3.1 - is-glob: 4.0.3 - open: 9.1.0 - picocolors: 1.0.0 - tslib: 2.6.1 dev: true - /@playwright/test@1.37.0: - resolution: {integrity: sha512-181WBLk4SRUyH1Q96VZl7BP6HcK0b7lbdeKisn3N/vnjitk+9HbdlFz/L5fey05vxaAhldIDnzo8KUoy8S3mmQ==} + /@playwright/test@1.42.0: + resolution: {integrity: sha512-2k1HzC28Fs+HiwbJOQDUwrWMttqSLUVdjCqitBOjdCD0svWOMQUVqrXX6iFD7POps6xXAojsX/dGBpKnjZctLA==} engines: {node: '>=16'} hasBin: true dependencies: - '@types/node': 18.16.3 - playwright-core: 1.37.0 - optionalDependencies: - fsevents: 2.3.2 + playwright: 1.42.0 dev: false /@pnpm/config.env-replace@1.1.0: @@ -1940,8 +3764,8 @@ packages: graceful-fs: 4.2.10 dev: true - /@pnpm/npm-conf@2.2.0: - resolution: {integrity: sha512-roLI1ul/GwzwcfcVpZYPdrgW2W/drLriObl1h+yLF5syc8/5ULWw2ALbCHUWF+4YltIqA3xFSbG4IwyJz37e9g==} + /@pnpm/npm-conf@2.2.2: + resolution: {integrity: sha512-UA91GwWPhFExt3IizW6bOeY/pQ0BkuNwKjk9iQW9KqxluGCrg4VenZ0/L+2Y0+ZOtme72EVvg6v0zo3AMQRCeA==} engines: {node: '>=12'} dependencies: '@pnpm/config.env-replace': 1.1.0 @@ -1949,27 +3773,237 @@ packages: config-chain: 1.1.13 dev: true - /@scure/base@1.1.1: - resolution: {integrity: sha512-ZxOhsSyxYwLJj3pLZCefNitxsj093tb2vq90mp2txoYeBqbcjDjqFhyM8eUjq/uFm6zJ+mUuqxlS2FkuSY1MTA==} + /@polka/url@1.0.0-next.24: + resolution: {integrity: sha512-2LuNTFBIO0m7kKIQvvPHN6UE63VjpmL9rnEEaOOaiSPbZK+zUOYIzBAWcED+3XYzhYsd/0mD57VdxAEqqV52CQ==} + dev: true + + /@protobufjs/aspromise@1.1.2: + resolution: {integrity: sha512-j+gKExEuLmKwvz3OgROXtrJ2UG2x8Ch2YZUxahh+s1F2HZ+wAceUNLkvy6zKCPVRkU++ZWQrdxsUeQXmcg4uoQ==} + dev: true + + /@protobufjs/base64@1.1.2: + resolution: {integrity: sha512-AZkcAA5vnN/v4PDqKyMR5lx7hZttPDgClv83E//FMNhR2TMcLUhfRUBHCmSl0oi9zMgDDqRUJkSxO3wm85+XLg==} + dev: true + + /@protobufjs/codegen@2.0.4: + resolution: {integrity: sha512-YyFaikqM5sH0ziFZCN3xDC7zeGaB/d0IUb9CATugHWbd1FRFwWwt4ld4OYMPWu5a3Xe01mGAULCdqhMlPl29Jg==} + dev: true + + /@protobufjs/eventemitter@1.1.0: + resolution: {integrity: sha512-j9ednRT81vYJ9OfVuXG6ERSTdEL1xVsNgqpkxMsbIabzSo3goCjDIveeGv5d03om39ML71RdmrGNjG5SReBP/Q==} + dev: true + + /@protobufjs/fetch@1.1.0: + resolution: {integrity: sha512-lljVXpqXebpsijW71PZaCYeIcE5on1w5DlQy5WH6GLbFryLUrBD4932W/E2BSpfRJWseIL4v/KPgBFxDOIdKpQ==} + dependencies: + '@protobufjs/aspromise': 1.1.2 + '@protobufjs/inquire': 1.1.0 + dev: true + + /@protobufjs/float@1.0.2: + resolution: {integrity: sha512-Ddb+kVXlXst9d+R9PfTIxh1EdNkgoRe5tOX6t01f1lYWOvJnSPDBlG241QLzcyPdoNTsblLUdujGSE4RzrTZGQ==} + dev: true + + /@protobufjs/inquire@1.1.0: + resolution: {integrity: sha512-kdSefcPdruJiFMVSbn801t4vFK7KB/5gd2fYvrxhuJYg8ILrmn9SKSX2tZdV6V+ksulWqS7aXjBcRXl3wHoD9Q==} + dev: true + + /@protobufjs/path@1.1.2: + resolution: {integrity: sha512-6JOcJ5Tm08dOHAbdR3GrvP+yUUfkjG5ePsHYczMFLq3ZmMkAD98cDgcT2iA1lJ9NVwFd4tH/iSSoe44YWkltEA==} + dev: true + + /@protobufjs/pool@1.1.0: + resolution: {integrity: sha512-0kELaGSIDBKvcgS4zkjz1PeddatrjYcmMWOlAuAPwAeccUrPHdUqo/J6LiymHHEiJT5NrF1UVwxY14f+fy4WQw==} + dev: true + + /@protobufjs/utf8@1.1.0: + resolution: {integrity: sha512-Vvn3zZrhQZkkBE8LSuW3em98c0FwgO4nxzv6OdSxPKJIEKY2bGbHn+mhGIPerzI4twdxaP8/0+06HBpwf345Lw==} + dev: true + + /@puppeteer/browsers@1.9.1: + resolution: {integrity: sha512-PuvK6xZzGhKPvlx3fpfdM2kYY3P/hB1URtK8wA7XUJ6prn6pp22zvJHu48th0SGcHL9SutbPHrFuQgfXTFobWA==} + engines: {node: '>=16.3.0'} + hasBin: true + dependencies: + debug: 4.3.4(supports-color@8.1.1) + extract-zip: 2.0.1(supports-color@8.1.1) + progress: 2.0.3 + proxy-agent: 6.3.1 + tar-fs: 3.0.4 + unbzip2-stream: 1.4.3 + yargs: 17.7.2 + transitivePeerDependencies: + - supports-color + dev: true + + /@rollup/plugin-commonjs@19.0.2(rollup@2.79.1): + resolution: {integrity: sha512-gBjarfqlC7qs0AutpRW/hrFNm+cd2/QKxhwyFa+srbg1oX7rDsEU3l+W7LAUhsAp9mPJMAkXDhLbQaVwEaE8bA==} + engines: {node: '>= 8.0.0'} + peerDependencies: + rollup: ^2.38.3 + dependencies: + '@rollup/pluginutils': 3.1.0(rollup@2.79.1) + commondir: 1.0.1 + estree-walker: 2.0.2 + glob: 7.2.3 + is-reference: 1.2.1 + magic-string: 0.25.9 + resolve: 1.22.8 + rollup: 2.79.1 + dev: true + + /@rollup/plugin-node-resolve@13.3.0(rollup@2.79.1): + resolution: {integrity: sha512-Lus8rbUo1eEcnS4yTFKLZrVumLPY+YayBdWXgFSHYhTT2iJbMhoaaBL3xl5NCdeRytErGr8tZ0L71BMRmnlwSw==} + engines: {node: '>= 10.0.0'} + peerDependencies: + rollup: ^2.42.0 + dependencies: + '@rollup/pluginutils': 3.1.0(rollup@2.79.1) + '@types/resolve': 1.17.1 + deepmerge: 4.3.1 + is-builtin-module: 3.2.1 + is-module: 1.0.0 + resolve: 1.22.8 + rollup: 2.79.1 + dev: true + + /@rollup/pluginutils@3.1.0(rollup@2.79.1): + resolution: {integrity: sha512-GksZ6pr6TpIjHm8h9lSQ8pi8BE9VeubNT0OMJ3B5uZJ8pz73NPiqOtCog/x2/QzM1ENChPKxMDhiQuRHsqc+lg==} + engines: {node: '>= 8.0.0'} + peerDependencies: + rollup: ^1.20.0||^2.0.0 + dependencies: + '@types/estree': 0.0.39 + estree-walker: 1.0.1 + picomatch: 2.3.1 + rollup: 2.79.1 + dev: true + + /@rollup/rollup-android-arm-eabi@4.12.0: + resolution: {integrity: sha512-+ac02NL/2TCKRrJu2wffk1kZ+RyqxVUlbjSagNgPm94frxtr+XDL12E5Ll1enWskLrtrZ2r8L3wED1orIibV/w==} + cpu: [arm] + os: [android] + requiresBuild: true + dev: true + optional: true + + /@rollup/rollup-android-arm64@4.12.0: + resolution: {integrity: sha512-OBqcX2BMe6nvjQ0Nyp7cC90cnumt8PXmO7Dp3gfAju/6YwG0Tj74z1vKrfRz7qAv23nBcYM8BCbhrsWqO7PzQQ==} + cpu: [arm64] + os: [android] + requiresBuild: true + dev: true + optional: true + + /@rollup/rollup-darwin-arm64@4.12.0: + resolution: {integrity: sha512-X64tZd8dRE/QTrBIEs63kaOBG0b5GVEd3ccoLtyf6IdXtHdh8h+I56C2yC3PtC9Ucnv0CpNFJLqKFVgCYe0lOQ==} + cpu: [arm64] + os: [darwin] + requiresBuild: true + dev: true + optional: true + + /@rollup/rollup-darwin-x64@4.12.0: + resolution: {integrity: sha512-cc71KUZoVbUJmGP2cOuiZ9HSOP14AzBAThn3OU+9LcA1+IUqswJyR1cAJj3Mg55HbjZP6OLAIscbQsQLrpgTOg==} + cpu: [x64] + os: [darwin] + requiresBuild: true + dev: true + optional: true + + /@rollup/rollup-linux-arm-gnueabihf@4.12.0: + resolution: {integrity: sha512-a6w/Y3hyyO6GlpKL2xJ4IOh/7d+APaqLYdMf86xnczU3nurFTaVN9s9jOXQg97BE4nYm/7Ga51rjec5nfRdrvA==} + cpu: [arm] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@rollup/rollup-linux-arm64-gnu@4.12.0: + resolution: {integrity: sha512-0fZBq27b+D7Ar5CQMofVN8sggOVhEtzFUwOwPppQt0k+VR+7UHMZZY4y+64WJ06XOhBTKXtQB/Sv0NwQMXyNAA==} + cpu: [arm64] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@rollup/rollup-linux-arm64-musl@4.12.0: + resolution: {integrity: sha512-eTvzUS3hhhlgeAv6bfigekzWZjaEX9xP9HhxB0Dvrdbkk5w/b+1Sxct2ZuDxNJKzsRStSq1EaEkVSEe7A7ipgQ==} + cpu: [arm64] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@rollup/rollup-linux-riscv64-gnu@4.12.0: + resolution: {integrity: sha512-ix+qAB9qmrCRiaO71VFfY8rkiAZJL8zQRXveS27HS+pKdjwUfEhqo2+YF2oI+H/22Xsiski+qqwIBxVewLK7sw==} + cpu: [riscv64] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@rollup/rollup-linux-x64-gnu@4.12.0: + resolution: {integrity: sha512-TenQhZVOtw/3qKOPa7d+QgkeM6xY0LtwzR8OplmyL5LrgTWIXpTQg2Q2ycBf8jm+SFW2Wt/DTn1gf7nFp3ssVA==} + cpu: [x64] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@rollup/rollup-linux-x64-musl@4.12.0: + resolution: {integrity: sha512-LfFdRhNnW0zdMvdCb5FNuWlls2WbbSridJvxOvYWgSBOYZtgBfW9UGNJG//rwMqTX1xQE9BAodvMH9tAusKDUw==} + cpu: [x64] + os: [linux] + requiresBuild: true + dev: true + optional: true + + /@rollup/rollup-win32-arm64-msvc@4.12.0: + resolution: {integrity: sha512-JPDxovheWNp6d7AHCgsUlkuCKvtu3RB55iNEkaQcf0ttsDU/JZF+iQnYcQJSk/7PtT4mjjVG8N1kpwnI9SLYaw==} + cpu: [arm64] + os: [win32] + requiresBuild: true + dev: true + optional: true + + /@rollup/rollup-win32-ia32-msvc@4.12.0: + resolution: {integrity: sha512-fjtuvMWRGJn1oZacG8IPnzIV6GF2/XG+h71FKn76OYFqySXInJtseAqdprVTDTyqPxQOG9Exak5/E9Z3+EJ8ZA==} + cpu: [ia32] + os: [win32] + requiresBuild: true + dev: true + optional: true + + /@rollup/rollup-win32-x64-msvc@4.12.0: + resolution: {integrity: sha512-ZYmr5mS2wd4Dew/JjT0Fqi2NPB/ZhZ2VvPp7SmvPZb4Y1CG/LRcS6tcRo2cYU7zLK5A7cdbhWnnWmUjoI4qapg==} + cpu: [x64] + os: [win32] + requiresBuild: true + dev: true + optional: true + + /@scure/base@1.1.5: + resolution: {integrity: sha512-Brj9FiG2W1MRQSTB212YVPRrcbjkv48FoZi/u4l/zds/ieRrqsh7aUf6CLwkAq61oKXr/ZlTzlY66gLIj3TFTQ==} dev: false - /@scure/bip32@1.3.0: - resolution: {integrity: sha512-bcKpo1oj54hGholplGLpqPHRbIsnbixFtc06nwuNM5/dwSXOq/AAYoIBRsBmnZJSdfeNW5rnff7NTAz3ZCqR9Q==} + /@scure/bip32@1.3.2: + resolution: {integrity: sha512-N1ZhksgwD3OBlwTv3R6KFEcPojl/W4ElJOeCZdi+vuI5QmTFwLq3OFf2zd2ROpKvxFdgZ6hUpb0dx9bVNEwYCA==} dependencies: - '@noble/curves': 1.0.0 - '@noble/hashes': 1.3.0 - '@scure/base': 1.1.1 + '@noble/curves': 1.2.0 + '@noble/hashes': 1.3.2 + '@scure/base': 1.1.5 dev: false - /@scure/bip39@1.2.0: - resolution: {integrity: sha512-SX/uKq52cuxm4YFXWFaVByaSHJh2w3BnokVSeUJVCv6K7WulT9u2BuNRBhuFl8vAuYnzx9bEu9WgpcNYTrYieg==} + /@scure/bip39@1.2.1: + resolution: {integrity: sha512-Z3/Fsz1yr904dduJD0NpiyRHhRYHdcnyh73FZWiV+/qhWi83wNJ3NWolYqCEN+ZWsUz2TWwajJggcRE9r1zUYg==} dependencies: - '@noble/hashes': 1.3.0 - '@scure/base': 1.1.1 + '@noble/hashes': 1.3.2 + '@scure/base': 1.1.5 dev: false - /@sideway/address@4.1.4: - resolution: {integrity: sha512-7vwq+rOHVWjyXxVlR76Agnvhy8I9rpzjosTESvmhNeXOXdZZB15Fl+TI9x1SiHZH5Jv2wTGduSxFDIaq0m3DUw==} + /@sideway/address@4.1.5: + resolution: {integrity: sha512-IqO/DUQHUkPeixNQ8n0JA6102hT9CmaljNTPmQ1u8MEhBo/R4Q8eKLN/vGZxuebwOroDB4cbpjheD4+/sKFK4Q==} dependencies: '@hapi/hoek': 9.3.0 @@ -1979,9 +4013,41 @@ packages: /@sideway/pinpoint@2.0.0: resolution: {integrity: sha512-RNiOoTPkptFtSVzQevY/yWtZwf/RxyVnPy/OcA9HBM3MlGDnBEYL5B41H0MTn0Uec8Hi+2qUtTfG2WWZBmMejQ==} - /@sigstore/protobuf-specs@0.1.0: - resolution: {integrity: sha512-a31EnjuIDSX8IXBUib3cYLDRlPMU36AWX4xS8ysLaNu4ZzUesDiPt83pgrW2X1YLMe5L2HbDyaKK5BrL4cNKaQ==} + /@sigstore/bundle@1.1.0: + resolution: {integrity: sha512-PFutXEy0SmQxYI4texPw3dd2KewuNqv7OuK1ZFtY2fM754yhvG2KdgwIhRnoEE2uHdtdGNQ8s0lb94dW9sELog==} + engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} + dependencies: + '@sigstore/protobuf-specs': 0.2.1 + dev: true + + /@sigstore/protobuf-specs@0.2.1: + resolution: {integrity: sha512-XTWVxnWJu+c1oCshMLwnKvz8ZQJJDVOlciMfgpJBQbThVjKTCG8dwyhgLngBD2KN0ap9F/gOV8rFDEx8uh7R2A==} + engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} + dev: true + + /@sigstore/sign@1.0.0: + resolution: {integrity: sha512-INxFVNQteLtcfGmcoldzV6Je0sbbfh9I16DM4yJPw3j5+TFP8X6uIiA18mvpEa9yyeycAKgPmOA3X9hVdVTPUA==} + engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} + dependencies: + '@sigstore/bundle': 1.1.0 + '@sigstore/protobuf-specs': 0.2.1 + make-fetch-happen: 11.1.1 + transitivePeerDependencies: + - supports-color + dev: true + + /@sigstore/tuf@1.0.3: + resolution: {integrity: sha512-2bRovzs0nJZFlCN3rXirE4gwxCn97JNjMmwpecqlbgV9WcxX7WRuIrgzx/X7Ib7MYRbyUTpBYE0s2x6AmZXnlg==} engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} + dependencies: + '@sigstore/protobuf-specs': 0.2.1 + tuf-js: 1.1.7 + transitivePeerDependencies: + - supports-color + dev: true + + /@sinclair/typebox@0.27.8: + resolution: {integrity: sha512-+Fj43pSMwJs4KRrH/938Uf+uAELIgVBmQzg/q1YG10djyfA3TnrU8N8XzqCh/okZdszqBQTZf96idMfE5lnwTA==} dev: true /@sindresorhus/is@0.7.0: @@ -1989,56 +4055,182 @@ packages: engines: {node: '>=4'} dev: false - /@sindresorhus/is@5.3.0: - resolution: {integrity: sha512-CX6t4SYQ37lzxicAqsBtxA3OseeoVrh9cSJ5PFYam0GksYlupRfy1A+Q4aYD3zvcfECLc0zO2u+ZnR2UYKvCrw==} + /@sindresorhus/is@5.6.0: + resolution: {integrity: sha512-TV7t8GKYaJWsn00tFDqBw8+Uqmr8A0fRU1tvTQhyZzGv0sJCGRQL3JGMI3ucuKo3XIZdUP+Lx7/gh2t3lewy7g==} engines: {node: '>=14.16'} dev: true - /@szmarczak/http-timer@5.0.1: - resolution: {integrity: sha512-+PmQX0PiAYPMeVYe237LJAYvOMYW1j2rH5YROyS3b4CTVJum34HfRvKvAzozHAQG0TnHNdUfY9nCeUyRAs//cw==} - engines: {node: '>=14.16'} + /@szmarczak/http-timer@5.0.1: + resolution: {integrity: sha512-+PmQX0PiAYPMeVYe237LJAYvOMYW1j2rH5YROyS3b4CTVJum34HfRvKvAzozHAQG0TnHNdUfY9nCeUyRAs//cw==} + engines: {node: '>=14.16'} + dependencies: + defer-to-connect: 2.0.1 + dev: true + + /@testing-library/cypress@9.0.0(cypress@12.17.3): + resolution: {integrity: sha512-c1XiCGeHGGTWn0LAU12sFUfoX3qfId5gcSE2yHode+vsyHDWraxDPALjVnHd4/Fa3j4KBcc5k++Ccy6A9qnkMA==} + engines: {node: '>=12', npm: '>=6'} + peerDependencies: + cypress: ^12.0.0 + dependencies: + '@babel/runtime': 7.23.9 + '@testing-library/dom': 8.20.0 + cypress: 12.17.3 + dev: false + + /@testing-library/dom@8.20.0: + resolution: {integrity: sha512-d9ULIT+a4EXLX3UU8FBjauG9NnsZHkHztXoIcTsOKoOw030fyjheN9svkTULjJxtYag9DZz5Jz5qkWZDPxTFwA==} + engines: {node: '>=12'} + dependencies: + '@babel/code-frame': 7.23.5 + '@babel/runtime': 7.23.9 + '@types/aria-query': 5.0.4 + aria-query: 5.3.0 + chalk: 4.1.2 + dom-accessibility-api: 0.5.16 + lz-string: 1.5.0 + pretty-format: 27.5.1 + + /@testing-library/react@14.2.1(react-dom@18.2.0)(react@18.2.0): + resolution: {integrity: sha512-sGdjws32ai5TLerhvzThYFbpnF9XtL65Cjf+gB0Dhr29BGqK+mAeN7SURSdu+eqgET4ANcWoC7FQpkaiGvBr+A==} + engines: {node: '>=14'} + peerDependencies: + react: ^18.0.0 + react-dom: ^18.0.0 + dependencies: + '@babel/runtime': 7.23.9 + '@testing-library/dom': 8.20.0 + '@types/react-dom': 18.2.19 + react: 18.2.0 + react-dom: 18.2.0(react@18.2.0) + + /@tinyhttp/accepts@2.2.1: + resolution: {integrity: sha512-2DHJLSJX1gqR5F6nKuu7+hyCNoPRNOxvnQ11m0X8klkSVoBFBO2HMf3bJ8P+fmNv1e6RjHzHF+G+hJ3dxXIQXQ==} + engines: {node: '>=12.20.0'} + dependencies: + mime: 4.0.1 + negotiator: 0.6.3 + dev: true + + /@tinyhttp/app@2.2.3: + resolution: {integrity: sha512-njr499Tx9BwlnIGfJjTuqfPwaUSTsjhUeRq/jVtHJpS95UgWECH7kiq8+bEx6TFRXiNKpARZ6KJUemlMyV+iCg==} + engines: {node: '>=14.21.3'} + dependencies: + '@tinyhttp/cookie': 2.1.0 + '@tinyhttp/proxy-addr': 2.1.3 + '@tinyhttp/req': 2.2.2 + '@tinyhttp/res': 2.2.2 + '@tinyhttp/router': 2.2.2 + header-range-parser: 1.1.3 + regexparam: 2.0.2 + dev: true + + /@tinyhttp/content-disposition@2.2.0: + resolution: {integrity: sha512-w1dJaSAtcCinOlT/YQg35RnFCOBbCHBGDVhH4yLoiJVtecRAJ2cYMf5HP+UhfbXURa38GC8fkRXO0vODDTjmeg==} + engines: {node: '>=12.20.0'} + dev: true + + /@tinyhttp/content-type@0.1.4: + resolution: {integrity: sha512-dl6f3SHIJPYbhsW1oXdrqOmLSQF/Ctlv3JnNfXAE22kIP7FosqJHxkz/qj2gv465prG8ODKH5KEyhBkvwrueKQ==} + engines: {node: '>=12.4'} + dev: true + + /@tinyhttp/cookie-signature@2.1.0: + resolution: {integrity: sha512-bpOXBGf9rKoajtEG75O7xjwW+u2I/NNPkJWJTDdr6j7Vx0lG5R9Hnl3ty80Af4jwyo90ywXVpZIxKLubPK6RzA==} + engines: {node: '>=12.20.0'} + dev: true + + /@tinyhttp/cookie@2.1.0: + resolution: {integrity: sha512-o56utxXvIuLTCtPm66r8lcyUufpw0RkO+u4wQrTbc6snyyGZZ9hHzGRxPyko0ks90ctOkLh0mNKn7YZaTWlvfw==} + engines: {node: '>=12.20.0'} + dev: true + + /@tinyhttp/cors@2.0.0: + resolution: {integrity: sha512-IwQsPBnK+gRrhTsPA4FPOfbNzZZt8cVsOIMNFb6HzoScaiWcoLEogL0Bz/aBSm8KM13uieVXoVT6udMqhqUS2A==} + engines: {node: '>=12.4 || 14.x || >=16'} + dependencies: + es-vary: 0.1.2 + dev: true + + /@tinyhttp/encode-url@2.1.1: + resolution: {integrity: sha512-AhY+JqdZ56qV77tzrBm0qThXORbsVjs/IOPgGCS7x/wWnsa/Bx30zDUU/jPAUcSzNOzt860x9fhdGpzdqbUeUw==} + engines: {node: '>=12.20.0'} + dev: true + + /@tinyhttp/etag@2.1.1: + resolution: {integrity: sha512-AcHGK1nMlKIHmlbg8bb8UY/KhiaAX17SAn3/6wlgwwdX4UizA8HETDfCH3KLdu2ZASokynuwVFNDJCo1DAawGw==} + engines: {node: '>=12.20.0'} + dev: true + + /@tinyhttp/forwarded@2.1.2: + resolution: {integrity: sha512-9H/eulJ68ElY/+zYpTpNhZ7vxGV+cnwaR6+oQSm7bVgZMyuQfgROW/qvZuhmgDTIxnGMXst+Ba4ij6w6Krcs3w==} + engines: {node: '>=12.20.0'} + dev: true + + /@tinyhttp/proxy-addr@2.1.3: + resolution: {integrity: sha512-Z0Q/0wEJpvall7LlBezXDy96CXLzPZb6xJawwEgsMXXQhmjb+r3EkpCBwMrWm2GlbJFL/UxKxpdumiNW3Ne06g==} + engines: {node: '>=12.20.0'} + dependencies: + '@tinyhttp/forwarded': 2.1.2 + ipaddr.js: 2.1.0 + dev: true + + /@tinyhttp/req@2.2.2: + resolution: {integrity: sha512-LaL/RFRro0qjOQ0g3vxE6i9bWl9hhv9en7opykzLU4NimFPg2C8wl7Qkoyc0mDuoRMQmWpq730PDWXSUmLiT2A==} + engines: {node: '>=12.20.0'} + dependencies: + '@tinyhttp/accepts': 2.2.1 + '@tinyhttp/type-is': 2.2.2 + '@tinyhttp/url': 2.1.1 + header-range-parser: 1.1.3 + dev: true + + /@tinyhttp/res@2.2.2: + resolution: {integrity: sha512-YeEYFwozag2qO5xoTj1Df+d5l6MXUefxz3xbcJD6ASVqUQytTEYtOC0FjhQKLpTLjMJKlS4mkKmeIdDLFO9btg==} + engines: {node: '>=12.20.0'} + dependencies: + '@tinyhttp/content-disposition': 2.2.0 + '@tinyhttp/cookie': 2.1.0 + '@tinyhttp/cookie-signature': 2.1.0 + '@tinyhttp/encode-url': 2.1.1 + '@tinyhttp/req': 2.2.2 + '@tinyhttp/send': 2.2.1 + '@tinyhttp/vary': 0.1.3 + es-escape-html: 0.1.1 + mime: 4.0.1 + dev: true + + /@tinyhttp/router@2.2.2: + resolution: {integrity: sha512-i+1ouhPyTqcuJuOsKqmo7i+YD++0RF2lQLhBpcTnsaegD2gTEa3xW2Pcz7spYQGo7K8PQYtOrL7m9b14+BEXqg==} + engines: {node: '>=12.20.0'} + dev: true + + /@tinyhttp/send@2.2.1: + resolution: {integrity: sha512-uFW0fxmYIPpB5RKP2vpL8QuafjUrCBmBWxZMIhFb7uBQky87t7x1QdpRB0vc+w11a2kok+Nc8ClD5kc6CRJCFg==} + engines: {node: '>=12.20.0'} dependencies: - defer-to-connect: 2.0.1 + '@tinyhttp/content-type': 0.1.4 + '@tinyhttp/etag': 2.1.1 + mime: 4.0.1 dev: true - /@testing-library/cypress@9.0.0(cypress@12.17.3): - resolution: {integrity: sha512-c1XiCGeHGGTWn0LAU12sFUfoX3qfId5gcSE2yHode+vsyHDWraxDPALjVnHd4/Fa3j4KBcc5k++Ccy6A9qnkMA==} - engines: {node: '>=12', npm: '>=6'} - peerDependencies: - cypress: ^12.0.0 + /@tinyhttp/type-is@2.2.2: + resolution: {integrity: sha512-DmTm0MkdrUxEPI2WBBoYJT0bitWx6+xeUd3lya1NGbKmYArzyUE+KVro/9y/h6Bxh+RaAKNeTCF4H/ksbe/ULQ==} + engines: {node: '>=12.20.0'} dependencies: - '@babel/runtime': 7.21.5 - '@testing-library/dom': 8.20.0 - cypress: 12.17.3 - dev: false + '@tinyhttp/content-type': 0.1.4 + mime: 4.0.1 + dev: true - /@testing-library/dom@8.20.0: - resolution: {integrity: sha512-d9ULIT+a4EXLX3UU8FBjauG9NnsZHkHztXoIcTsOKoOw030fyjheN9svkTULjJxtYag9DZz5Jz5qkWZDPxTFwA==} - engines: {node: '>=12'} - dependencies: - '@babel/code-frame': 7.21.4 - '@babel/runtime': 7.21.5 - '@types/aria-query': 5.0.1 - aria-query: 5.1.3 - chalk: 4.1.2 - dom-accessibility-api: 0.5.16 - lz-string: 1.5.0 - pretty-format: 27.5.1 - dev: false + /@tinyhttp/url@2.1.1: + resolution: {integrity: sha512-POJeq2GQ5jI7Zrdmj22JqOijB5/GeX+LEX7DUdml1hUnGbJOTWDx7zf2b5cCERj7RoXL67zTgyzVblBJC+NJWg==} + engines: {node: '>=12.20.0'} + dev: true - /@testing-library/react@14.0.0(react-dom@18.2.0)(react@18.2.0): - resolution: {integrity: sha512-S04gSNJbYE30TlIMLTzv6QCTzt9AqIF5y6s6SzVFILNcNvbV/jU96GeiTPillGQo+Ny64M/5PV7klNYYgv5Dfg==} - engines: {node: '>=14'} - peerDependencies: - react: ^18.0.0 - react-dom: ^18.0.0 - dependencies: - '@babel/runtime': 7.21.5 - '@testing-library/dom': 8.20.0 - '@types/react-dom': 18.2.1 - react: 18.2.0 - react-dom: 18.2.0(react@18.2.0) - dev: false + /@tinyhttp/vary@0.1.3: + resolution: {integrity: sha512-SoL83sQXAGiHN1jm2VwLUWQSQeDAAl1ywOm6T0b0Cg1CZhVsjoiZadmjhxF6FHCCY7OHHVaLnTgSMxTPIDLxMg==} + engines: {node: '>=12.20'} + dev: true /@tootallnate/once@2.0.0: resolution: {integrity: sha512-XCuKFP5PS55gnMVu3dty8KPatLqUoy/ZYzDzAGCQ8JNFCkLXzmI7vNHCR+XpbZaMWQK/vQubr7PkYq8g470J/A==} @@ -2054,78 +4246,109 @@ packages: engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} dev: true - /@tufjs/models@1.0.3: - resolution: {integrity: sha512-mkFEqqRisi13DmR5pX4x+Zk97EiU8djTtpNW1GeuX410y/raAsq/T3ZCjwoRIZ8/cIBfW0olK/sywlAiWevDVw==} + /@tufjs/models@1.0.4: + resolution: {integrity: sha512-qaGV9ltJP0EO25YfFUPhxRVK0evXFIAGicsVXuRim4Ed9cjPxYhNnNJ49SFmbeLgtxpslIkX317IgpfcHPVj/A==} engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} dependencies: '@tufjs/canonical-json': 1.0.0 - minimatch: 7.4.6 + minimatch: 9.0.3 dev: true - /@types/aria-query@5.0.1: - resolution: {integrity: sha512-XTIieEY+gvJ39ChLcB4If5zHtPxt3Syj5rgZR+e1ctpmK8NjPf0zFqsz4JpLJT0xla9GFDKjy8Cpu331nrmE1Q==} - dev: false + /@types/aria-query@5.0.4: + resolution: {integrity: sha512-rfT93uj5s0PRL7EzccGMs3brplhcrghnDoV26NqKhCAS1hVo+WdNsPvE/yb6ilfr5hi2MEk6d5EWJTKdxg8jVw==} - /@types/body-parser@1.19.2: - resolution: {integrity: sha512-ALYone6pm6QmwZoAgeyNksccT9Q4AWZQ6PvfwR37GT6r6FWUPguq6sUmNGSMV2Wr761oQoBxwGGa6DR5o1DC9g==} + /@types/babel__core@7.20.5: + resolution: {integrity: sha512-qoQprZvz5wQFJwMDqeseRXWv3rqMvhgpbXFfVyWhbx9X47POIA6i/+dXefEmZKoAgOaTdaIgNSMqMIU61yRyzA==} dependencies: - '@types/connect': 3.4.35 - '@types/node': 18.16.3 - dev: false + '@babel/parser': 7.23.9 + '@babel/types': 7.23.9 + '@types/babel__generator': 7.6.8 + '@types/babel__template': 7.4.4 + '@types/babel__traverse': 7.20.5 + dev: true + + /@types/babel__generator@7.6.8: + resolution: {integrity: sha512-ASsj+tpEDsEiFr1arWrlN6V3mdfjRMZt6LtK/Vp/kreFLnr5QH5+DhvD5nINYZXzwJvXeGq+05iUXcAzVrqWtw==} + dependencies: + '@babel/types': 7.23.9 + dev: true + + /@types/babel__template@7.4.4: + resolution: {integrity: sha512-h/NUaSyG5EyxBIp8YRxo4RMe2/qQgvyowRwVMzhYhBCONbW8PUsg4lkFMrhgZhUe5z3L3MiLDuvyJ/CaPa2A8A==} + dependencies: + '@babel/parser': 7.23.9 + '@babel/types': 7.23.9 + dev: true - /@types/bonjour@3.5.10: - resolution: {integrity: sha512-p7ienRMiS41Nu2/igbJxxLDWrSZ0WxM8UQgCeO9KhoVF7cOVFkrKsiDr1EsJIla8vV3oEEjGcz11jc5yimhzZw==} + /@types/babel__traverse@7.20.5: + resolution: {integrity: sha512-WXCyOcRtH37HAUkpXhUduaxdm82b4GSlyTqajXviN4EfiuPgNYR109xMCKvpl6zPIpua0DGlMEDCq+g8EdoheQ==} dependencies: - '@types/node': 18.16.3 + '@babel/types': 7.23.9 + dev: true + + /@types/body-parser@1.19.5: + resolution: {integrity: sha512-fB3Zu92ucau0iQ0JMCFQE7b/dv8Ot07NI3KaZIkIUNXq82k4eBAqUaneXfleGY9JWskeS9y+u0nXMyspcuQrCg==} + dependencies: + '@types/connect': 3.4.38 + '@types/node': 20.11.21 dev: false - /@types/connect-history-api-fallback@1.5.0: - resolution: {integrity: sha512-4x5FkPpLipqwthjPsF7ZRbOv3uoLUFkTA9G9v583qi4pACvq0uTELrB8OLUzPWUI4IJIyvM85vzkV1nyiI2Lig==} + /@types/bonjour@3.5.13: + resolution: {integrity: sha512-z9fJ5Im06zvUL548KvYNecEVlA7cVDkGUi6kZusb04mpyEFKCIZJvloCcmpmLaIahDpOQGHaHmG6imtPMmPXGQ==} dependencies: - '@types/express-serve-static-core': 4.17.34 - '@types/node': 18.16.3 + '@types/node': 20.11.21 dev: false - /@types/connect@3.4.35: - resolution: {integrity: sha512-cdeYyv4KWoEgpBISTxWvqYsVy444DOqehiF3fM3ne10AmJ62RSyNkUnxMJXHQWRQQX2eR94m5y1IZyDwBjV9FQ==} + /@types/connect-history-api-fallback@1.5.4: + resolution: {integrity: sha512-n6Cr2xS1h4uAulPRdlw6Jl6s1oG8KrVilPN2yUITEs+K48EzMJJ3W1xy8K5eWuFvjp3R74AOIGSmp2UfBJ8HFw==} dependencies: - '@types/node': 18.16.3 + '@types/express-serve-static-core': 4.17.43 + '@types/node': 20.11.21 dev: false - /@types/eslint-scope@3.7.4: - resolution: {integrity: sha512-9K4zoImiZc3HlIp6AVUDE4CWYx22a+lhSZMYNpbjW04+YF0KWj4pJXnEMjdnFTiQibFFmElcsasJXDbdI/EPhA==} + /@types/connect@3.4.38: + resolution: {integrity: sha512-K6uROf1LD88uDQqJCktA4yzL1YYAK6NgfsI0v/mTgyPKWsX1CnJ0XPSDhViejru1GcRkLWb8RlzFYJRqGUbaug==} dependencies: - '@types/eslint': 8.37.0 - '@types/estree': 1.0.1 + '@types/node': 20.11.21 dev: false - /@types/eslint@8.37.0: - resolution: {integrity: sha512-Piet7dG2JBuDIfohBngQ3rCt7MgO9xCO4xIMKxBThCq5PNRB91IjlJ10eJVwfoNtvTErmxLzwBZ7rHZtbOMmFQ==} + /@types/eslint-scope@3.7.7: + resolution: {integrity: sha512-MzMFlSLBqNF2gcHWO0G1vP/YQyfvrxZ0bF+u7mzUdZ1/xK4A4sru+nraZz5i3iEIk1l1uyicaDVTB4QbbEkAYg==} dependencies: - '@types/estree': 1.0.1 - '@types/json-schema': 7.0.11 + '@types/eslint': 8.56.4 + '@types/estree': 1.0.5 dev: false - /@types/estree@1.0.1: - resolution: {integrity: sha512-LG4opVs2ANWZ1TJoKc937iMmNstM/d0ae1vNbnBvBhqCSezgVUOzcLCqbI5elV8Vy6WKwKjaqR+zO9VKirBBCA==} + /@types/eslint@8.56.4: + resolution: {integrity: sha512-lG1GLUnL5vuRBGb3MgWUWLdGMH2Hps+pERuyQXCfWozuGKdnhf9Pbg4pkcrVUHjKrU7Rl+GCZ/299ObBXZFAxg==} + dependencies: + '@types/estree': 1.0.5 + '@types/json-schema': 7.0.15 dev: false - /@types/express-serve-static-core@4.17.34: - resolution: {integrity: sha512-fvr49XlCGoUj2Pp730AItckfjat4WNb0lb3kfrLWffd+RLeoGAMsq7UOy04PAPtoL01uKwcp6u8nhzpgpDYr3w==} + /@types/estree@0.0.39: + resolution: {integrity: sha512-EYNwp3bU+98cpU4lAWYYL7Zz+2gryWH1qbdDTidVd6hkiR6weksdbMadyXKXNPEkQFhXM+hVO9ZygomHXp+AIw==} + dev: true + + /@types/estree@1.0.5: + resolution: {integrity: sha512-/kYRxGDLWzHOB7q+wtSUQlFrtcdUccpfy+X+9iMBpHK8QLLhx2wIPYuS5DYtR9Wa/YlZAbIovy7qVdB1Aq6Lyw==} + + /@types/express-serve-static-core@4.17.43: + resolution: {integrity: sha512-oaYtiBirUOPQGSWNGPWnzyAFJ0BP3cwvN4oWZQY+zUBwpVIGsKUkpBpSztp74drYcjavs7SKFZ4DX1V2QeN8rg==} dependencies: - '@types/node': 18.16.3 - '@types/qs': 6.9.7 - '@types/range-parser': 1.2.4 - '@types/send': 0.17.1 + '@types/node': 20.11.21 + '@types/qs': 6.9.12 + '@types/range-parser': 1.2.7 + '@types/send': 0.17.4 dev: false - /@types/express@4.17.17: - resolution: {integrity: sha512-Q4FmmuLGBG58btUnfS1c1r/NQdlp3DMfGDGig8WhfpA2YRUtEkxAjkZb0yvplJGYdF1fsQ81iMDcH24sSCNC/Q==} + /@types/express@4.17.21: + resolution: {integrity: sha512-ejlPM315qwLpaQlQDTjPdsUFSc6ZsP4AN6AlWnogPjQ7CVi7PYF3YVz+CY3jE2pwYf7E/7HlDAN0rV2GxTG0HQ==} dependencies: - '@types/body-parser': 1.19.2 - '@types/express-serve-static-core': 4.17.34 - '@types/qs': 6.9.7 - '@types/serve-static': 1.15.1 + '@types/body-parser': 1.19.5 + '@types/express-serve-static-core': 4.17.43 + '@types/qs': 6.9.12 + '@types/serve-static': 1.15.5 dev: false /@types/html-minifier-terser@5.1.2: @@ -2136,18 +4359,22 @@ packages: resolution: {integrity: sha512-oh/6byDPnL1zeNXFrDXFLyZjkr1MsBG667IM792caf1L2UPOOMf65NFzjUH/ltyfwjAGfs1rsX1eftK0jC/KIg==} dev: false - /@types/http-cache-semantics@4.0.1: - resolution: {integrity: sha512-SZs7ekbP8CN0txVG2xVRH6EgKmEm31BOxA07vkFaETzZz1xh+cbt8BcI0slpymvwhx5dlFnQG2rTlPVQn+iRPQ==} + /@types/http-cache-semantics@4.0.4: + resolution: {integrity: sha512-1m0bIFVc7eJWyve9S0RnuRgcQqF/Xd5QsUZAZeQFr1Q3/p9JWoQQEqmVy+DPTNpGXwhgIetAoYF8JSc33q29QA==} dev: true - /@types/http-proxy@1.17.11: - resolution: {integrity: sha512-HC8G7c1WmaF2ekqpnFq626xd3Zz0uvaqFmBJNRZCGEZCXkvSdJoNFn/8Ygbd9fKNQj8UzLdCETaI0UWPAjK7IA==} + /@types/http-errors@2.0.4: + resolution: {integrity: sha512-D0CFMMtydbJAegzOyHjtiKPLlvnm3iTZyZRSZoLq2mRhDdmLfIWOCYPfQJ4cu2erKghU++QvjcUjp/5h7hESpA==} + dev: false + + /@types/http-proxy@1.17.14: + resolution: {integrity: sha512-SSrD0c1OQzlFX7pGu1eXxSEjemej64aaNPRhhVYUGqXh0BtldAAx37MG8btcumvpgKyZp1F5Gn3JkktdxiFv6w==} dependencies: - '@types/node': 18.16.3 + '@types/node': 20.11.21 dev: false - /@types/json-schema@7.0.11: - resolution: {integrity: sha512-wOuvG1SN4Us4rez+tylwwwCV1psiNVOkJeM3AUWUNWg/jDQY2+HE/444y5gc+jBmRqASOm2Oeh5c1axHobwRKQ==} + /@types/json-schema@7.0.15: + resolution: {integrity: sha512-5+fP8P8MFNC+AyZCDxrB2pkZFPGzqQWUzpSeuuVLvm8VMcorNYavBqoFcxK8bQz4Qsbn4oUEEem4wDLfcysGHA==} /@types/json5@0.0.29: resolution: {integrity: sha512-dRLjCWHYg4oaA77cxO64oO+7JwCwnIzkZPdrrC71jQmQtlhM556pwKo5bUzqvZndkVbeFLIIi+9TC40JNF5hNQ==} @@ -2156,193 +4383,296 @@ packages: /@types/keyv@3.1.4: resolution: {integrity: sha512-BQ5aZNSCpj7D6K2ksrRCTmKRLEpnPvWDiLPfoGyhZ++8YtiK9d/3DBKPJgry359X/P1PfruyYwvnvwFjuEiEIg==} dependencies: - '@types/node': 18.16.3 + '@types/node': 20.11.21 dev: false - /@types/mime@1.3.2: - resolution: {integrity: sha512-YATxVxgRqNH6nHEIsvg6k2Boc1JHI9ZbH5iWFFv/MTkchz3b1ieGDa5T0a9RznNdI0KhVbdbWSN+KWWrQZRxTw==} + /@types/long@4.0.2: + resolution: {integrity: sha512-MqTGEo5bj5t157U6fA/BiDynNkn0YknVdh48CMPkTSpFTVmvao5UQmm7uEF6xBEo7qIMAlY/JSleYaE6VOdpaA==} + dev: true + + /@types/mime@1.3.5: + resolution: {integrity: sha512-/pyBZWSLD2n0dcHE3hq8s8ZvcETHtEuF+3E7XVt0Ig2nvsVQXdghHVcEkIWjy9A0wKfTn97a/PSDYohKIlnP/w==} dev: false - /@types/mime@3.0.1: - resolution: {integrity: sha512-Y4XFY5VJAuw0FgAqPNd6NNoV44jbq9Bz2L7Rh/J6jLTiHBSBJa9fxqQIvkIld4GsoDOcCbvzOUAbLPsSKKg+uA==} + /@types/mime@3.0.4: + resolution: {integrity: sha512-iJt33IQnVRkqeqC7PzBHPTC6fDlRNRW8vjrgqtScAhrmMwe8c4Eo7+fUGTa+XdWrpEgpyKWMYmi2dIwMAYRzPw==} dev: false - /@types/node@16.18.39: - resolution: {integrity: sha512-8q9ZexmdYYyc5/cfujaXb4YOucpQxAV4RMG0himLyDUOEr8Mr79VrqsFI+cQ2M2h89YIuy95lbxuYjxT4Hk4kQ==} + /@types/node-forge@1.3.11: + resolution: {integrity: sha512-FQx220y22OKNTqaByeBGqHWYz4cl94tpcxeFdvBo3wjG6XPBuZ0BNgNZRV5J5TFmmcsJ4IzsLkmGRiQbnYsBEQ==} + dependencies: + '@types/node': 20.11.21 dev: false + /@types/node@16.18.84: + resolution: {integrity: sha512-mtn6ixzrUK5IMf6gyyMVUsm0TIeF3IYpUr3i0HHTuPJVbdZ6kc93poZ+wCkFNtxXoP/tyGrdVPOL6/WqGXjfXw==} + /@types/node@18.15.13: resolution: {integrity: sha512-N+0kuo9KgrUQ1Sn/ifDXsvg0TTleP7rIy4zOBGECxAljqvqfqpTfzx0Q1NUedOixRMBfe2Whhb056a42cWs26Q==} dev: false - /@types/node@18.16.3: - resolution: {integrity: sha512-OPs5WnnT1xkCBiuQrZA4+YAV4HEJejmHneyraIaxsbev5yCEr6KMwINNFP9wQeFIw8FWcoTqF3vQsa5CDaI+8Q==} - dev: false + /@types/node@20.11.21: + resolution: {integrity: sha512-/ySDLGscFPNasfqStUuWWPfL78jompfIoVzLJPVVAHBh6rpG68+pI2Gk+fNLeI8/f1yPYL4s46EleVIc20F1Ow==} + dependencies: + undici-types: 5.26.5 - /@types/normalize-package-data@2.4.1: - resolution: {integrity: sha512-Gj7cI7z+98M282Tqmp2K5EIsoouUEzbBJhQQzDE3jSIRk6r9gsz0oUokqIUR4u1R3dMHo0pDHM7sNOHyhulypw==} + /@types/normalize-package-data@2.4.4: + resolution: {integrity: sha512-37i+OaWTh9qeK4LSHPsyRC7NahnGotNuZvjLSgcPzblpHB3rrCJxAOgI5gCdKm7coonsaX1Of0ILiTcnZjbfxA==} dev: true - /@types/prop-types@15.7.5: - resolution: {integrity: sha512-JCB8C6SnDoQf0cNycqd/35A7MjcnK+ZTqE7judS6o7utxUCg6imJg3QK2qzHKszlTjcj2cn+NwMB2i96ubpj7w==} - dev: false + /@types/prop-types@15.7.11: + resolution: {integrity: sha512-ga8y9v9uyeiLdpKddhxYQkxNDrfvuPrlFb0N1qnZZByvcElJaXthF1UhvCh9TLWJBEHeNtdnbysW7Y6Uq8CVng==} - /@types/qs@6.9.7: - resolution: {integrity: sha512-FGa1F62FT09qcrueBA6qYTrJPVDzah9a+493+o2PCXsesWHIn27G98TsSMs3WPNbZIEj4+VJf6saSFpvD+3Zsw==} + /@types/qs@6.9.12: + resolution: {integrity: sha512-bZcOkJ6uWrL0Qb2NAWKa7TBU+mJHPzhx9jjLL1KHF+XpzEcR7EXHvjbHlGtR/IsP1vyPrehuS6XqkmaePy//mg==} dev: false - /@types/range-parser@1.2.4: - resolution: {integrity: sha512-EEhsLsD6UsDM1yFhAvy0Cjr6VwmpMWqFBCb9w07wVugF7w9nfajxLuVmngTIpgS6svCnm6Vaw+MZhoDCKnOfsw==} + /@types/range-parser@1.2.7: + resolution: {integrity: sha512-hKormJbkJqzQGhziax5PItDUTMAM9uE2XXQmM37dyd4hVM+5aVl7oVxMVUiVQn2oCQFN/LKCZdvSM0pFRqbSmQ==} dev: false - /@types/react-dom@18.2.1: - resolution: {integrity: sha512-8QZEV9+Kwy7tXFmjJrp3XUKQSs9LTnE0KnoUb0YCguWBiNW0Yfb2iBMYZ08WPg35IR6P3Z0s00B15SwZnO26+w==} + /@types/react-dom@18.2.19: + resolution: {integrity: sha512-aZvQL6uUbIJpjZk4U8JZGbau9KDeAwMfmhyWorxgBkqDIEf6ROjRozcmPIicqsUwPUjbkDfHKgGee1Lq65APcA==} dependencies: - '@types/react': 18.2.0 - dev: false + '@types/react': 18.2.60 - /@types/react@18.2.0: - resolution: {integrity: sha512-0FLj93y5USLHdnhIhABk83rm8XEGA7kH3cr+YUlvxoUGp1xNt/DINUMvqPxLyOQMzLmZe8i4RTHbvb8MC7NmrA==} + /@types/react@18.2.60: + resolution: {integrity: sha512-dfiPj9+k20jJrLGOu9Nf6eqxm2EyJRrq2NvwOFsfbb7sFExZ9WELPs67UImHj3Ayxg8ruTtKtNnbjaF8olPq0A==} dependencies: - '@types/prop-types': 15.7.5 - '@types/scheduler': 0.16.3 - csstype: 3.1.2 - dev: false + '@types/prop-types': 15.7.11 + '@types/scheduler': 0.16.8 + csstype: 3.1.3 + + /@types/resolve@1.17.1: + resolution: {integrity: sha512-yy7HuzQhj0dhGpD8RLXSZWEkLsV9ibvxvi6EiJ3bkqLAO1RGo0WbkWQiwpRlSFymTJRz0d3k5LM3kkx8ArDbLw==} + dependencies: + '@types/node': 20.11.21 + dev: true - /@types/responselike@1.0.0: - resolution: {integrity: sha512-85Y2BjiufFzaMIlvJDvTTB8Fxl2xfLo4HgmHzVBz08w4wDePCTjYw66PdrolO0kzli3yam/YCgRufyo1DdQVTA==} + /@types/responselike@1.0.3: + resolution: {integrity: sha512-H/+L+UkTV33uf49PH5pCAUBVPNj2nDBXTN+qS1dOwyyg24l3CcicicCA7ca+HMvJBZcFgl5r8e+RR6elsb4Lyw==} dependencies: - '@types/node': 18.16.3 + '@types/node': 20.11.21 dev: false /@types/retry@0.12.0: resolution: {integrity: sha512-wWKOClTTiizcZhXnPY4wikVAwmdYHp8q6DmC+EJUzAMsycb7HB32Kh9RN4+0gExjmPmZSAQjgURXIGATPegAvA==} dev: false - /@types/scheduler@0.16.3: - resolution: {integrity: sha512-5cJ8CB4yAx7BH1oMvdU0Jh9lrEXyPkar6F9G/ERswkCuvP4KQZfZkSjcMbAICCpQTN4OuZn8tz0HiKv9TGZgrQ==} - dev: false + /@types/scheduler@0.16.8: + resolution: {integrity: sha512-WZLiwShhwLRmeV6zH+GkbOFT6Z6VklCItrDioxUnv+u4Ll+8vKeFySoFyK/0ctcRpOmwAicELfmys1sDc/Rw+A==} - /@types/semver@7.3.13: - resolution: {integrity: sha512-21cFJr9z3g5dW8B0CVI9g2O9beqaThGQ6ZFBqHfwhzLDKUxaqTIy3vnfah/UPkfOiF2pLq+tGz+W8RyCskuslw==} + /@types/semver@7.5.8: + resolution: {integrity: sha512-I8EUhyrgfLrcTkzV3TSsGyl1tSuPrEDzr0yd5m90UgNxQkyDXULk3b6MlQqTCpZpNtWe1K0hzclnZkTcLBe2UQ==} dev: true - /@types/send@0.17.1: - resolution: {integrity: sha512-Cwo8LE/0rnvX7kIIa3QHCkcuF21c05Ayb0ZfxPiv0W8VRiZiNW/WuRupHKpqqGVGf7SUA44QSOUKaEd9lIrd/Q==} + /@types/send@0.17.4: + resolution: {integrity: sha512-x2EM6TJOybec7c52BX0ZspPodMsQUd5L6PRwOunVyVUhXiBSKf3AezDL8Dgvgt5o0UfKNfuA0eMLr2wLT4AiBA==} dependencies: - '@types/mime': 1.3.2 - '@types/node': 18.16.3 + '@types/mime': 1.3.5 + '@types/node': 20.11.21 dev: false - /@types/serve-index@1.9.1: - resolution: {integrity: sha512-d/Hs3nWDxNL2xAczmOVZNj92YZCS6RGxfBPjKzuu/XirCgXdpKEb88dYNbrYGint6IVWLNP+yonwVAuRC0T2Dg==} + /@types/serve-index@1.9.4: + resolution: {integrity: sha512-qLpGZ/c2fhSs5gnYsQxtDEq3Oy8SXPClIXkW5ghvAvsNuVSA8k+gCONcUCS/UjLEYvYps+e8uBtfgXgvhwfNug==} dependencies: - '@types/express': 4.17.17 + '@types/express': 4.17.21 dev: false - /@types/serve-static@1.15.1: - resolution: {integrity: sha512-NUo5XNiAdULrJENtJXZZ3fHtfMolzZwczzBbnAeBbqBwG+LaG6YaJtuwzwGSQZ2wsCrxjEhNNjAkKigy3n8teQ==} + /@types/serve-static@1.15.5: + resolution: {integrity: sha512-PDRk21MnK70hja/YF8AHfC7yIsiQHn1rcXx7ijCFBX/k+XQJhQT/gw3xekXKJvx+5SXaMMS8oqQy09Mzvz2TuQ==} dependencies: - '@types/mime': 3.0.1 - '@types/node': 18.16.3 + '@types/http-errors': 2.0.4 + '@types/mime': 3.0.4 + '@types/node': 20.11.21 dev: false /@types/sinonjs__fake-timers@8.1.1: resolution: {integrity: sha512-0kSuKjAS0TrGLJ0M/+8MaFkGsQhZpB6pxOmvS3K8FYI72K//YmdfoW9X2qPsAKh1mkwxGD5zib9s1FIFed6E8g==} dev: false - /@types/sizzle@2.3.3: - resolution: {integrity: sha512-JYM8x9EGF163bEyhdJBpR2QX1R5naCJHC8ucJylJ3w9/CVBaskdQ8WqBf8MmQrd1kRvp/a4TS8HJ+bxzR7ZJYQ==} + /@types/sizzle@2.3.8: + resolution: {integrity: sha512-0vWLNK2D5MT9dg0iOo8GlKguPAU02QjmZitPEsXRuJXU/OGIOt9vT9Fc26wtYuavLxtO45v9PGleoL9Z0k1LHg==} dev: false - /@types/sockjs@0.3.33: - resolution: {integrity: sha512-f0KEEe05NvUnat+boPTZ0dgaLZ4SfSouXUgv5noUiefG2ajgKjmETo9ZJyuqsl7dfl2aHlLJUiki6B4ZYldiiw==} + /@types/sockjs@0.3.36: + resolution: {integrity: sha512-MK9V6NzAS1+Ud7JV9lJLFqW85VbC9dq3LmwZCuBe4wBDgKC0Kj/jd8Xl+nSviU+Qc3+m7umHHyHg//2KSa0a0Q==} dependencies: - '@types/node': 18.16.3 + '@types/node': 20.11.21 dev: false - /@types/source-list-map@0.1.2: - resolution: {integrity: sha512-K5K+yml8LTo9bWJI/rECfIPrGgxdpeNbj+d53lwN4QjW1MCwlkhUms+gtdzigTeUyBr09+u8BwOIY3MXvHdcsA==} + /@types/source-list-map@0.1.6: + resolution: {integrity: sha512-5JcVt1u5HDmlXkwOD2nslZVllBBc7HDuOICfiZah2Z0is8M8g+ddAEawbmd3VjedfDHBzxCaXLs07QEmb7y54g==} dev: false - /@types/tapable@1.0.8: - resolution: {integrity: sha512-ipixuVrh2OdNmauvtT51o3d8z12p6LtFW9in7U79der/kwejjdNchQC5UMn5u/KxNoM7VHHOs/l8KS8uHxhODQ==} + /@types/tapable@1.0.12: + resolution: {integrity: sha512-bTHG8fcxEqv1M9+TD14P8ok8hjxoOCkfKc8XXLaaD05kI7ohpeI956jtDOD3XHKBQrlyPughUtzm1jtVhHpA5Q==} dev: false - /@types/testing-library__cypress@5.0.9: - resolution: {integrity: sha512-WTiIZhZKWDnV+Tgo42pxff8YfHdmaNFQz/bFoTlmfw2vbXcstCcb39VRaRi5yFHj/lb7t3K47btKYEbR1fci+Q==} + /@types/testing-library__cypress@5.0.13: + resolution: {integrity: sha512-lkxNGVFBEX825Z/FrHA8FLuKv1q5L6Bccqm08Zds2MUG4gd5al32hCpplzVumke3br+hkhtVmuPTfwQadIkc5w==} dependencies: '@testing-library/dom': 8.20.0 cypress: 12.17.3 dev: false - /@types/uglify-js@3.17.1: - resolution: {integrity: sha512-GkewRA4i5oXacU/n4MA9+bLgt5/L3F1mKrYvFGm7r2ouLXhRKjuWwo9XHNnbx6WF3vlGW21S3fCvgqxvxXXc5g==} + /@types/triple-beam@1.3.5: + resolution: {integrity: sha512-6WaYesThRMCl19iryMYP7/x2OVgCtbIVflDGFpWnb9irXI3UjYE4AzmYuiUKY1AJstGijoY+MgUszMgRxIYTYw==} + dev: true + + /@types/trusted-types@2.0.7: + resolution: {integrity: sha512-ScaPdn1dQczgbl0QFTeTOmVHFULt394XJgOQNoyVhZ6r2vLnMLJfBPd53SB52T/3G36VI1/g2MZaX0cwDuXsfw==} + dev: true + + /@types/uglify-js@3.17.4: + resolution: {integrity: sha512-Hm/T0kV3ywpJyMGNbsItdivRhYNCQQf1IIsYsXnoVPES4t+FMLyDe0/K+Ea7ahWtMtSNb22ZdY7MIyoD9rqARg==} dependencies: source-map: 0.6.1 dev: false - /@types/webpack-sources@3.2.0: - resolution: {integrity: sha512-Ft7YH3lEVRQ6ls8k4Ff1oB4jN6oy/XmU6tQISKdhfh+1mR+viZFphS6WL0IrtDOzvefmJg5a0s7ZQoRXwqTEFg==} + /@types/webpack-sources@3.2.3: + resolution: {integrity: sha512-4nZOdMwSPHZ4pTEZzSp0AsTM4K7Qmu40UKW4tJDiOVs20UzYF9l+qUe4s0ftfN0pin06n+5cWWDJXH+sbhAiDw==} dependencies: - '@types/node': 18.16.3 - '@types/source-list-map': 0.1.2 + '@types/node': 20.11.21 + '@types/source-list-map': 0.1.6 source-map: 0.7.4 dev: false - /@types/webpack@4.41.33: - resolution: {integrity: sha512-PPajH64Ft2vWevkerISMtnZ8rTs4YmRbs+23c402J0INmxDKCrhZNvwZYtzx96gY2wAtXdrK1BS2fiC8MlLr3g==} + /@types/webpack@4.41.38: + resolution: {integrity: sha512-oOW7E931XJU1mVfCnxCVgv8GLFL768pDO5u2Gzk82i8yTIgX6i7cntyZOkZYb/JtYM8252SN9bQp9tgkVDSsRw==} dependencies: - '@types/node': 18.16.3 - '@types/tapable': 1.0.8 - '@types/uglify-js': 3.17.1 - '@types/webpack-sources': 3.2.0 + '@types/node': 20.11.21 + '@types/tapable': 1.0.12 + '@types/uglify-js': 3.17.4 + '@types/webpack-sources': 3.2.3 anymatch: 3.1.3 source-map: 0.6.1 dev: false - /@types/ws@8.5.4: - resolution: {integrity: sha512-zdQDHKUgcX/zBc4GrwsE/7dVdAD8JR4EuiAXiiUhhfyIJXXb2+PrGshFyeXWQPMmmZ2XxgaqclgpIC7eTXc1mg==} + /@types/ws@8.5.10: + resolution: {integrity: sha512-vmQSUcfalpIq0R9q7uTo2lXs6eGIpt9wtnLdMv9LVpIjCA/+ufZRozlVoVelIYixx1ugCBKDhn89vnsEGOCx9A==} dependencies: - '@types/node': 18.16.3 + '@types/node': 20.11.21 dev: false - /@types/yauzl@2.10.0: - resolution: {integrity: sha512-Cn6WYCm0tXv8p6k+A8PvbDG763EDpBoTzHdA+Q/MF6H3sapGjCm9NzoaJncJS9tUKSuCoDs9XHxYYsQDgxR6kw==} + /@types/yauzl@2.10.3: + resolution: {integrity: sha512-oJoftv0LSuaDZE3Le4DbKX+KS9G36NzOeSap90UIK0yMA/NhKJhqlSGtNDORNRaIbQfzjXDrQa0ytJ6mNRGz/Q==} requiresBuild: true dependencies: - '@types/node': 18.16.3 - dev: false + '@types/node': 16.18.84 optional: true - /@typescript-eslint/experimental-utils@5.59.2(eslint@8.47.0)(typescript@5.0.4): - resolution: {integrity: sha512-JLw2UImsjHDuVukpA8Nt+UK7JKE/LQAeV3tU5f7wJo2/NNYVwcakzkWjoYzu/2qzWY/Z9c7zojngNDfecNt92g==} + /@typescript-eslint/eslint-plugin@6.21.0(@typescript-eslint/parser@6.21.0)(eslint@8.57.0)(typescript@5.3.3): + resolution: {integrity: sha512-oy9+hTPCUFpngkEZUSzbf9MxI65wbKFoQYsgPdILTfbUldp5ovUuphZVe4i30emU9M/kP+T64Di0mxl7dSw3MA==} + engines: {node: ^16.0.0 || >=18.0.0} + peerDependencies: + '@typescript-eslint/parser': ^6.0.0 || ^6.0.0-alpha + eslint: ^7.0.0 || ^8.0.0 + typescript: '*' + peerDependenciesMeta: + typescript: + optional: true + dependencies: + '@eslint-community/regexpp': 4.10.0 + '@typescript-eslint/parser': 6.21.0(eslint@8.57.0)(typescript@5.3.3) + '@typescript-eslint/scope-manager': 6.21.0 + '@typescript-eslint/type-utils': 6.21.0(eslint@8.57.0)(typescript@5.3.3) + '@typescript-eslint/utils': 6.21.0(eslint@8.57.0)(typescript@5.3.3) + '@typescript-eslint/visitor-keys': 6.21.0 + debug: 4.3.4(supports-color@8.1.1) + eslint: 8.57.0 + graphemer: 1.4.0 + ignore: 5.3.1 + natural-compare: 1.4.0 + semver: 7.6.0 + ts-api-utils: 1.2.1(typescript@5.3.3) + typescript: 5.3.3 + transitivePeerDependencies: + - supports-color + dev: true + + /@typescript-eslint/experimental-utils@5.62.0(eslint@8.57.0)(typescript@5.3.3): + resolution: {integrity: sha512-RTXpeB3eMkpoclG3ZHft6vG/Z30azNHuqY6wKPBHlVMZFuEvrtlEDe8gMqDb+SO+9hjC/pLekeSCryf9vMZlCw==} engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} peerDependencies: eslint: ^6.0.0 || ^7.0.0 || ^8.0.0 dependencies: - '@typescript-eslint/utils': 5.59.2(eslint@8.47.0)(typescript@5.0.4) - eslint: 8.47.0 + '@typescript-eslint/utils': 5.62.0(eslint@8.57.0)(typescript@5.3.3) + eslint: 8.57.0 transitivePeerDependencies: - supports-color - typescript dev: true - /@typescript-eslint/scope-manager@5.59.2: - resolution: {integrity: sha512-dB1v7ROySwQWKqQ8rEWcdbTsFjh2G0vn8KUyvTXdPoyzSL6lLGkiXEV5CvpJsEe9xIdKV+8Zqb7wif2issoOFA==} + /@typescript-eslint/parser@6.21.0(eslint@8.57.0)(typescript@5.3.3): + resolution: {integrity: sha512-tbsV1jPne5CkFQCgPBcDOt30ItF7aJoZL997JSF7MhGQqOeT3svWRYxiqlfA5RUdlHN6Fi+EI9bxqbdyAUZjYQ==} + engines: {node: ^16.0.0 || >=18.0.0} + peerDependencies: + eslint: ^7.0.0 || ^8.0.0 + typescript: '*' + peerDependenciesMeta: + typescript: + optional: true + dependencies: + '@typescript-eslint/scope-manager': 6.21.0 + '@typescript-eslint/types': 6.21.0 + '@typescript-eslint/typescript-estree': 6.21.0(typescript@5.3.3) + '@typescript-eslint/visitor-keys': 6.21.0 + debug: 4.3.4(supports-color@8.1.1) + eslint: 8.57.0 + typescript: 5.3.3 + transitivePeerDependencies: + - supports-color + dev: true + + /@typescript-eslint/scope-manager@5.62.0: + resolution: {integrity: sha512-VXuvVvZeQCQb5Zgf4HAxc04q5j+WrNAtNh9OwCsCgpKqESMTu3tF/jhZ3xG6T4NZwWl65Bg8KuS2uEvhSfLl0w==} engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} dependencies: - '@typescript-eslint/types': 5.59.2 - '@typescript-eslint/visitor-keys': 5.59.2 + '@typescript-eslint/types': 5.62.0 + '@typescript-eslint/visitor-keys': 5.62.0 + dev: true + + /@typescript-eslint/scope-manager@6.21.0: + resolution: {integrity: sha512-OwLUIWZJry80O99zvqXVEioyniJMa+d2GrqpUTqi5/v5D5rOrppJVBPa0yKCblcigC0/aYAzxxqQ1B+DS2RYsg==} + engines: {node: ^16.0.0 || >=18.0.0} + dependencies: + '@typescript-eslint/types': 6.21.0 + '@typescript-eslint/visitor-keys': 6.21.0 + dev: true + + /@typescript-eslint/type-utils@6.21.0(eslint@8.57.0)(typescript@5.3.3): + resolution: {integrity: sha512-rZQI7wHfao8qMX3Rd3xqeYSMCL3SoiSQLBATSiVKARdFGCYSRvmViieZjqc58jKgs8Y8i9YvVVhRbHSTA4VBag==} + engines: {node: ^16.0.0 || >=18.0.0} + peerDependencies: + eslint: ^7.0.0 || ^8.0.0 + typescript: '*' + peerDependenciesMeta: + typescript: + optional: true + dependencies: + '@typescript-eslint/typescript-estree': 6.21.0(typescript@5.3.3) + '@typescript-eslint/utils': 6.21.0(eslint@8.57.0)(typescript@5.3.3) + debug: 4.3.4(supports-color@8.1.1) + eslint: 8.57.0 + ts-api-utils: 1.2.1(typescript@5.3.3) + typescript: 5.3.3 + transitivePeerDependencies: + - supports-color dev: true - /@typescript-eslint/types@5.59.2: - resolution: {integrity: sha512-LbJ/HqoVs2XTGq5shkiKaNTuVv5tTejdHgfdjqRUGdYhjW1crm/M7og2jhVskMt8/4wS3T1+PfFvL1K3wqYj4w==} + /@typescript-eslint/types@5.62.0: + resolution: {integrity: sha512-87NVngcbVXUahrRTqIK27gD2t5Cu1yuCXxbLcFtCzZGlfyVWWh8mLHkoxzjsB6DDNnvdL+fW8MiwPEJyGJQDgQ==} engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} dev: true - /@typescript-eslint/typescript-estree@5.59.2(typescript@5.0.4): - resolution: {integrity: sha512-+j4SmbwVmZsQ9jEyBMgpuBD0rKwi9RxRpjX71Brr73RsYnEr3Lt5QZ624Bxphp8HUkSKfqGnPJp1kA5nl0Sh7Q==} + /@typescript-eslint/types@6.21.0: + resolution: {integrity: sha512-1kFmZ1rOm5epu9NZEZm1kckCDGj5UJEf7P1kliH4LKu/RkwpsfqqGmY2OOcUs18lSlQBKLDYBOGxRVtrMN5lpg==} + engines: {node: ^16.0.0 || >=18.0.0} + dev: true + + /@typescript-eslint/typescript-estree@5.62.0(typescript@5.3.3): + resolution: {integrity: sha512-CmcQ6uY7b9y694lKdRB8FEel7JbU/40iSAPomu++SjLMntB+2Leay2LO6i8VnJk58MtE9/nQSFIH6jpyRWyYzA==} engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} peerDependencies: typescript: '*' @@ -2350,173 +4680,270 @@ packages: typescript: optional: true dependencies: - '@typescript-eslint/types': 5.59.2 - '@typescript-eslint/visitor-keys': 5.59.2 + '@typescript-eslint/types': 5.62.0 + '@typescript-eslint/visitor-keys': 5.62.0 debug: 4.3.4(supports-color@8.1.1) globby: 11.1.0 is-glob: 4.0.3 - semver: 7.5.4 - tsutils: 3.21.0(typescript@5.0.4) - typescript: 5.0.4 + semver: 7.6.0 + tsutils: 3.21.0(typescript@5.3.3) + typescript: 5.3.3 + transitivePeerDependencies: + - supports-color + dev: true + + /@typescript-eslint/typescript-estree@6.21.0(typescript@5.3.3): + resolution: {integrity: sha512-6npJTkZcO+y2/kr+z0hc4HwNfrrP4kNYh57ek7yCNlrBjWQ1Y0OS7jiZTkgumrvkX5HkEKXFZkkdFNkaW2wmUQ==} + engines: {node: ^16.0.0 || >=18.0.0} + peerDependencies: + typescript: '*' + peerDependenciesMeta: + typescript: + optional: true + dependencies: + '@typescript-eslint/types': 6.21.0 + '@typescript-eslint/visitor-keys': 6.21.0 + debug: 4.3.4(supports-color@8.1.1) + globby: 11.1.0 + is-glob: 4.0.3 + minimatch: 9.0.3 + semver: 7.6.0 + ts-api-utils: 1.2.1(typescript@5.3.3) + typescript: 5.3.3 transitivePeerDependencies: - supports-color dev: true - /@typescript-eslint/utils@5.59.2(eslint@8.47.0)(typescript@5.0.4): - resolution: {integrity: sha512-kSuF6/77TZzyGPhGO4uVp+f0SBoYxCDf+lW3GKhtKru/L8k/Hd7NFQxyWUeY7Z/KGB2C6Fe3yf2vVi4V9TsCSQ==} + /@typescript-eslint/utils@5.62.0(eslint@8.57.0)(typescript@5.3.3): + resolution: {integrity: sha512-n8oxjeb5aIbPFEtmQxQYOLI0i9n5ySBEY/ZEHHZqKQSFnxio1rv6dthascc9dLuwrL0RC5mPCxB7vnAVGAYWAQ==} engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} peerDependencies: eslint: ^6.0.0 || ^7.0.0 || ^8.0.0 dependencies: - '@eslint-community/eslint-utils': 4.4.0(eslint@8.47.0) - '@types/json-schema': 7.0.11 - '@types/semver': 7.3.13 - '@typescript-eslint/scope-manager': 5.59.2 - '@typescript-eslint/types': 5.59.2 - '@typescript-eslint/typescript-estree': 5.59.2(typescript@5.0.4) - eslint: 8.47.0 + '@eslint-community/eslint-utils': 4.4.0(eslint@8.57.0) + '@types/json-schema': 7.0.15 + '@types/semver': 7.5.8 + '@typescript-eslint/scope-manager': 5.62.0 + '@typescript-eslint/types': 5.62.0 + '@typescript-eslint/typescript-estree': 5.62.0(typescript@5.3.3) + eslint: 8.57.0 eslint-scope: 5.1.1 - semver: 7.5.4 + semver: 7.6.0 + transitivePeerDependencies: + - supports-color + - typescript + dev: true + + /@typescript-eslint/utils@6.21.0(eslint@8.57.0)(typescript@5.3.3): + resolution: {integrity: sha512-NfWVaC8HP9T8cbKQxHcsJBY5YE1O33+jpMwN45qzWWaPDZgLIbo12toGMWnmhvCpd3sIxkpDw3Wv1B3dYrbDQQ==} + engines: {node: ^16.0.0 || >=18.0.0} + peerDependencies: + eslint: ^7.0.0 || ^8.0.0 + dependencies: + '@eslint-community/eslint-utils': 4.4.0(eslint@8.57.0) + '@types/json-schema': 7.0.15 + '@types/semver': 7.5.8 + '@typescript-eslint/scope-manager': 6.21.0 + '@typescript-eslint/types': 6.21.0 + '@typescript-eslint/typescript-estree': 6.21.0(typescript@5.3.3) + eslint: 8.57.0 + semver: 7.6.0 transitivePeerDependencies: - supports-color - typescript dev: true - /@typescript-eslint/visitor-keys@5.59.2: - resolution: {integrity: sha512-EEpsO8m3RASrKAHI9jpavNv9NlEUebV4qmF1OWxSTtKSFBpC1NCmWazDQHFivRf0O1DV11BA645yrLEVQ0/Lig==} + /@typescript-eslint/visitor-keys@5.62.0: + resolution: {integrity: sha512-07ny+LHRzQXepkGg6w0mFY41fVUNBrL2Roj/++7V1txKugfjm/Ci/qSND03r2RhlJhJYMcTn9AhhSSqQp0Ysyw==} engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} dependencies: - '@typescript-eslint/types': 5.59.2 - eslint-visitor-keys: 3.4.2 + '@typescript-eslint/types': 5.62.0 + eslint-visitor-keys: 3.4.3 + dev: true + + /@typescript-eslint/visitor-keys@6.21.0: + resolution: {integrity: sha512-JJtkDduxLi9bivAB+cYOVMtbkqdPOhZ+ZI5LC47MIRrDV4Yn2o+ZnW10Nkmr28xRpSpdJ6Sm42Hjf2+REYXm0A==} + engines: {node: ^16.0.0 || >=18.0.0} + dependencies: + '@typescript-eslint/types': 6.21.0 + eslint-visitor-keys: 3.4.3 + dev: true + + /@ungap/structured-clone@1.2.0: + resolution: {integrity: sha512-zuVdFrMJiuCDQUMCzQaD6KL28MjnqqN8XnAqiEq9PNm/hCPTSGfrXCOfwj1ow4LFb/tNymJPwsNbVePc1xFqrQ==} dev: true /@viem/anvil@0.0.6(debug@4.3.4): resolution: {integrity: sha512-OjKR/+FVwzuygXYFqP8MBal1SXG8bT2gbZwqqB0XuLw81LNBBvmE/Repm6+5kkBh4IUj0PhYdrqOsnayS14Gtg==} dependencies: - execa: 7.1.1 + execa: 7.2.0 get-port: 6.1.2 http-proxy: 1.18.1(debug@4.3.4) - ws: 8.13.0 + ws: 8.16.0 transitivePeerDependencies: - bufferutil - debug - utf-8-validate dev: false - /@wagmi/chains@1.6.0(typescript@5.0.4): - resolution: {integrity: sha512-5FRlVxse5P4ZaHG3GTvxwVANSmYJas1eQrTBHhjxVtqXoorm0aLmCHbhmN8Xo1yu09PaWKlleEvfE98yH4AgIw==} + /@vitejs/plugin-react@4.2.1(vite@4.5.2): + resolution: {integrity: sha512-oojO9IDc4nCUUi8qIR11KoQm0XFFLIwsRBwHRR4d/88IWghn1y6ckz/bJ8GHDCsYEJee8mDzqtJxh15/cisJNQ==} + engines: {node: ^14.18.0 || >=16.0.0} peerDependencies: - typescript: '>=5.0.4' - peerDependenciesMeta: - typescript: - optional: true + vite: ^4.2.0 || ^5.0.0 dependencies: - typescript: 5.0.4 - dev: false + '@babel/core': 7.23.9 + '@babel/plugin-transform-react-jsx-self': 7.23.3(@babel/core@7.23.9) + '@babel/plugin-transform-react-jsx-source': 7.23.3(@babel/core@7.23.9) + '@types/babel__core': 7.20.5 + react-refresh: 0.14.0 + vite: 4.5.2 + transitivePeerDependencies: + - supports-color + dev: true - /@webassemblyjs/ast@1.11.5: - resolution: {integrity: sha512-LHY/GSAZZRpsNQH+/oHqhRQ5FT7eoULcBqgfyTB5nQHogFnK3/7QoN7dLnwSE/JkUAF0SrRuclT7ODqMFtWxxQ==} + /@vitest/expect@1.3.1: + resolution: {integrity: sha512-xofQFwIzfdmLLlHa6ag0dPV8YsnKOCP1KdAeVVh34vSjN2dcUiXYCD9htu/9eM7t8Xln4v03U9HLxLpPlsXdZw==} dependencies: - '@webassemblyjs/helper-numbers': 1.11.5 - '@webassemblyjs/helper-wasm-bytecode': 1.11.5 + '@vitest/spy': 1.3.1 + '@vitest/utils': 1.3.1 + chai: 4.4.1 + dev: true + + /@vitest/runner@1.3.1: + resolution: {integrity: sha512-5FzF9c3jG/z5bgCnjr8j9LNq/9OxV2uEBAITOXfoe3rdZJTdO7jzThth7FXv/6b+kdY65tpRQB7WaKhNZwX+Kg==} + dependencies: + '@vitest/utils': 1.3.1 + p-limit: 5.0.0 + pathe: 1.1.2 + dev: true + + /@vitest/snapshot@1.3.1: + resolution: {integrity: sha512-EF++BZbt6RZmOlE3SuTPu/NfwBF6q4ABS37HHXzs2LUVPBLx2QoY/K0fKpRChSo8eLiuxcbCVfqKgx/dplCDuQ==} + dependencies: + magic-string: 0.30.7 + pathe: 1.1.2 + pretty-format: 29.7.0 + dev: true + + /@vitest/spy@1.3.1: + resolution: {integrity: sha512-xAcW+S099ylC9VLU7eZfdT9myV67Nor9w9zhf0mGCYJSO+zM2839tOeROTdikOi/8Qeusffvxb/MyBSOja1Uig==} + dependencies: + tinyspy: 2.2.1 + dev: true + + /@vitest/utils@1.3.1: + resolution: {integrity: sha512-d3Waie/299qqRyHTm2DjADeTaNdNSVsnwHPWrs20JMpjh6eiVq7ggggweO8rc4arhf6rRkWuHKwvxGvejUXZZQ==} + dependencies: + diff-sequences: 29.6.3 + estree-walker: 3.0.3 + loupe: 2.3.7 + pretty-format: 29.7.0 + dev: true + + /@webassemblyjs/ast@1.11.6: + resolution: {integrity: sha512-IN1xI7PwOvLPgjcf180gC1bqn3q/QaOCwYUahIOhbYUu8KA/3tw2RT/T0Gidi1l7Hhj5D/INhJxiICObqpMu4Q==} + dependencies: + '@webassemblyjs/helper-numbers': 1.11.6 + '@webassemblyjs/helper-wasm-bytecode': 1.11.6 dev: false - /@webassemblyjs/floating-point-hex-parser@1.11.5: - resolution: {integrity: sha512-1j1zTIC5EZOtCplMBG/IEwLtUojtwFVwdyVMbL/hwWqbzlQoJsWCOavrdnLkemwNoC/EOwtUFch3fuo+cbcXYQ==} + /@webassemblyjs/floating-point-hex-parser@1.11.6: + resolution: {integrity: sha512-ejAj9hfRJ2XMsNHk/v6Fu2dGS+i4UaXBXGemOfQ/JfQ6mdQg/WXtwleQRLLS4OvfDhv8rYnVwH27YJLMyYsxhw==} dev: false - /@webassemblyjs/helper-api-error@1.11.5: - resolution: {integrity: sha512-L65bDPmfpY0+yFrsgz8b6LhXmbbs38OnwDCf6NpnMUYqa+ENfE5Dq9E42ny0qz/PdR0LJyq/T5YijPnU8AXEpA==} + /@webassemblyjs/helper-api-error@1.11.6: + resolution: {integrity: sha512-o0YkoP4pVu4rN8aTJgAyj9hC2Sv5UlkzCHhxqWj8butaLvnpdc2jOwh4ewE6CX0txSfLn/UYaV/pheS2Txg//Q==} dev: false - /@webassemblyjs/helper-buffer@1.11.5: - resolution: {integrity: sha512-fDKo1gstwFFSfacIeH5KfwzjykIE6ldh1iH9Y/8YkAZrhmu4TctqYjSh7t0K2VyDSXOZJ1MLhht/k9IvYGcIxg==} + /@webassemblyjs/helper-buffer@1.11.6: + resolution: {integrity: sha512-z3nFzdcp1mb8nEOFFk8DrYLpHvhKC3grJD2ardfKOzmbmJvEf/tPIqCY+sNcwZIY8ZD7IkB2l7/pqhUhqm7hLA==} dev: false - /@webassemblyjs/helper-numbers@1.11.5: - resolution: {integrity: sha512-DhykHXM0ZABqfIGYNv93A5KKDw/+ywBFnuWybZZWcuzWHfbp21wUfRkbtz7dMGwGgT4iXjWuhRMA2Mzod6W4WA==} + /@webassemblyjs/helper-numbers@1.11.6: + resolution: {integrity: sha512-vUIhZ8LZoIWHBohiEObxVm6hwP034jwmc9kuq5GdHZH0wiLVLIPcMCdpJzG4C11cHoQ25TFIQj9kaVADVX7N3g==} dependencies: - '@webassemblyjs/floating-point-hex-parser': 1.11.5 - '@webassemblyjs/helper-api-error': 1.11.5 + '@webassemblyjs/floating-point-hex-parser': 1.11.6 + '@webassemblyjs/helper-api-error': 1.11.6 '@xtuc/long': 4.2.2 dev: false - /@webassemblyjs/helper-wasm-bytecode@1.11.5: - resolution: {integrity: sha512-oC4Qa0bNcqnjAowFn7MPCETQgDYytpsfvz4ujZz63Zu/a/v71HeCAAmZsgZ3YVKec3zSPYytG3/PrRCqbtcAvA==} + /@webassemblyjs/helper-wasm-bytecode@1.11.6: + resolution: {integrity: sha512-sFFHKwcmBprO9e7Icf0+gddyWYDViL8bpPjJJl0WHxCdETktXdmtWLGVzoHbqUcY4Be1LkNfwTmXOJUFZYSJdA==} dev: false - /@webassemblyjs/helper-wasm-section@1.11.5: - resolution: {integrity: sha512-uEoThA1LN2NA+K3B9wDo3yKlBfVtC6rh0i4/6hvbz071E8gTNZD/pT0MsBf7MeD6KbApMSkaAK0XeKyOZC7CIA==} + /@webassemblyjs/helper-wasm-section@1.11.6: + resolution: {integrity: sha512-LPpZbSOwTpEC2cgn4hTydySy1Ke+XEu+ETXuoyvuyezHO3Kjdu90KK95Sh9xTbmjrCsUwvWwCOQQNta37VrS9g==} dependencies: - '@webassemblyjs/ast': 1.11.5 - '@webassemblyjs/helper-buffer': 1.11.5 - '@webassemblyjs/helper-wasm-bytecode': 1.11.5 - '@webassemblyjs/wasm-gen': 1.11.5 + '@webassemblyjs/ast': 1.11.6 + '@webassemblyjs/helper-buffer': 1.11.6 + '@webassemblyjs/helper-wasm-bytecode': 1.11.6 + '@webassemblyjs/wasm-gen': 1.11.6 dev: false - /@webassemblyjs/ieee754@1.11.5: - resolution: {integrity: sha512-37aGq6qVL8A8oPbPrSGMBcp38YZFXcHfiROflJn9jxSdSMMM5dS5P/9e2/TpaJuhE+wFrbukN2WI6Hw9MH5acg==} + /@webassemblyjs/ieee754@1.11.6: + resolution: {integrity: sha512-LM4p2csPNvbij6U1f19v6WR56QZ8JcHg3QIJTlSwzFcmx6WSORicYj6I63f9yU1kEUtrpG+kjkiIAkevHpDXrg==} dependencies: '@xtuc/ieee754': 1.2.0 dev: false - /@webassemblyjs/leb128@1.11.5: - resolution: {integrity: sha512-ajqrRSXaTJoPW+xmkfYN6l8VIeNnR4vBOTQO9HzR7IygoCcKWkICbKFbVTNMjMgMREqXEr0+2M6zukzM47ZUfQ==} + /@webassemblyjs/leb128@1.11.6: + resolution: {integrity: sha512-m7a0FhE67DQXgouf1tbN5XQcdWoNgaAuoULHIfGFIEVKA6tu/edls6XnIlkmS6FrXAquJRPni3ZZKjw6FSPjPQ==} dependencies: '@xtuc/long': 4.2.2 dev: false - /@webassemblyjs/utf8@1.11.5: - resolution: {integrity: sha512-WiOhulHKTZU5UPlRl53gHR8OxdGsSOxqfpqWeA2FmcwBMaoEdz6b2x2si3IwC9/fSPLfe8pBMRTHVMk5nlwnFQ==} + /@webassemblyjs/utf8@1.11.6: + resolution: {integrity: sha512-vtXf2wTQ3+up9Zsg8sa2yWiQpzSsMyXj0qViVP6xKGCUT8p8YJ6HqI7l5eCnWx1T/FYdsv07HQs2wTFbbof/RA==} dev: false - /@webassemblyjs/wasm-edit@1.11.5: - resolution: {integrity: sha512-C0p9D2fAu3Twwqvygvf42iGCQ4av8MFBLiTb+08SZ4cEdwzWx9QeAHDo1E2k+9s/0w1DM40oflJOpkZ8jW4HCQ==} + /@webassemblyjs/wasm-edit@1.11.6: + resolution: {integrity: sha512-Ybn2I6fnfIGuCR+Faaz7YcvtBKxvoLV3Lebn1tM4o/IAJzmi9AWYIPWpyBfU8cC+JxAO57bk4+zdsTjJR+VTOw==} dependencies: - '@webassemblyjs/ast': 1.11.5 - '@webassemblyjs/helper-buffer': 1.11.5 - '@webassemblyjs/helper-wasm-bytecode': 1.11.5 - '@webassemblyjs/helper-wasm-section': 1.11.5 - '@webassemblyjs/wasm-gen': 1.11.5 - '@webassemblyjs/wasm-opt': 1.11.5 - '@webassemblyjs/wasm-parser': 1.11.5 - '@webassemblyjs/wast-printer': 1.11.5 + '@webassemblyjs/ast': 1.11.6 + '@webassemblyjs/helper-buffer': 1.11.6 + '@webassemblyjs/helper-wasm-bytecode': 1.11.6 + '@webassemblyjs/helper-wasm-section': 1.11.6 + '@webassemblyjs/wasm-gen': 1.11.6 + '@webassemblyjs/wasm-opt': 1.11.6 + '@webassemblyjs/wasm-parser': 1.11.6 + '@webassemblyjs/wast-printer': 1.11.6 dev: false - /@webassemblyjs/wasm-gen@1.11.5: - resolution: {integrity: sha512-14vteRlRjxLK9eSyYFvw1K8Vv+iPdZU0Aebk3j6oB8TQiQYuO6hj9s4d7qf6f2HJr2khzvNldAFG13CgdkAIfA==} + /@webassemblyjs/wasm-gen@1.11.6: + resolution: {integrity: sha512-3XOqkZP/y6B4F0PBAXvI1/bky7GryoogUtfwExeP/v7Nzwo1QLcq5oQmpKlftZLbT+ERUOAZVQjuNVak6UXjPA==} dependencies: - '@webassemblyjs/ast': 1.11.5 - '@webassemblyjs/helper-wasm-bytecode': 1.11.5 - '@webassemblyjs/ieee754': 1.11.5 - '@webassemblyjs/leb128': 1.11.5 - '@webassemblyjs/utf8': 1.11.5 + '@webassemblyjs/ast': 1.11.6 + '@webassemblyjs/helper-wasm-bytecode': 1.11.6 + '@webassemblyjs/ieee754': 1.11.6 + '@webassemblyjs/leb128': 1.11.6 + '@webassemblyjs/utf8': 1.11.6 dev: false - /@webassemblyjs/wasm-opt@1.11.5: - resolution: {integrity: sha512-tcKwlIXstBQgbKy1MlbDMlXaxpucn42eb17H29rawYLxm5+MsEmgPzeCP8B1Cl69hCice8LeKgZpRUAPtqYPgw==} + /@webassemblyjs/wasm-opt@1.11.6: + resolution: {integrity: sha512-cOrKuLRE7PCe6AsOVl7WasYf3wbSo4CeOk6PkrjS7g57MFfVUF9u6ysQBBODX0LdgSvQqRiGz3CXvIDKcPNy4g==} dependencies: - '@webassemblyjs/ast': 1.11.5 - '@webassemblyjs/helper-buffer': 1.11.5 - '@webassemblyjs/wasm-gen': 1.11.5 - '@webassemblyjs/wasm-parser': 1.11.5 + '@webassemblyjs/ast': 1.11.6 + '@webassemblyjs/helper-buffer': 1.11.6 + '@webassemblyjs/wasm-gen': 1.11.6 + '@webassemblyjs/wasm-parser': 1.11.6 dev: false - /@webassemblyjs/wasm-parser@1.11.5: - resolution: {integrity: sha512-SVXUIwsLQlc8srSD7jejsfTU83g7pIGr2YYNb9oHdtldSxaOhvA5xwvIiWIfcX8PlSakgqMXsLpLfbbJ4cBYew==} + /@webassemblyjs/wasm-parser@1.11.6: + resolution: {integrity: sha512-6ZwPeGzMJM3Dqp3hCsLgESxBGtT/OeCvCZ4TA1JUPYgmhAx38tTPR9JaKy0S5H3evQpO/h2uWs2j6Yc/fjkpTQ==} dependencies: - '@webassemblyjs/ast': 1.11.5 - '@webassemblyjs/helper-api-error': 1.11.5 - '@webassemblyjs/helper-wasm-bytecode': 1.11.5 - '@webassemblyjs/ieee754': 1.11.5 - '@webassemblyjs/leb128': 1.11.5 - '@webassemblyjs/utf8': 1.11.5 + '@webassemblyjs/ast': 1.11.6 + '@webassemblyjs/helper-api-error': 1.11.6 + '@webassemblyjs/helper-wasm-bytecode': 1.11.6 + '@webassemblyjs/ieee754': 1.11.6 + '@webassemblyjs/leb128': 1.11.6 + '@webassemblyjs/utf8': 1.11.6 dev: false - /@webassemblyjs/wast-printer@1.11.5: - resolution: {integrity: sha512-f7Pq3wvg3GSPUPzR0F6bmI89Hdb+u9WXrSKc4v+N0aV0q6r42WoF92Jp2jEorBEBRoRNXgjp53nBniDXcqZYPA==} + /@webassemblyjs/wast-printer@1.11.6: + resolution: {integrity: sha512-JM7AhRcE+yW2GWYaKeHL5vt4xqee5N2WcezptmgyhNS+ScggqcT1OtXykhAb13Sn5Yas0j2uv9tHgrjwvzAP4A==} dependencies: - '@webassemblyjs/ast': 1.11.5 + '@webassemblyjs/ast': 1.11.6 '@xtuc/long': 4.2.2 dev: false @@ -2536,8 +4963,8 @@ packages: resolution: {integrity: sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==} dev: true - /abitype@0.9.3(typescript@5.0.4): - resolution: {integrity: sha512-dz4qCQLurx97FQhnb/EIYTk/ldQ+oafEDUqC0VVIeQS1Q48/YWt/9YNfMmp9SLFqN41ktxny3c8aYxHjmFIB/w==} + /abitype@0.9.8(typescript@5.3.3): + resolution: {integrity: sha512-puLifILdm+8sjyss4S+fsUN09obiT1g2YW6CtcQF+QDzxR0euzgEB29MZujC6zMk2a6SVmtttq1fc6+YFA7WYQ==} peerDependencies: typescript: '>=5.0.4' zod: ^3 >=3.19.1 @@ -2547,7 +4974,7 @@ packages: zod: optional: true dependencies: - typescript: 5.0.4 + typescript: 5.3.3 dev: false /accepts@1.3.8: @@ -2557,24 +4984,28 @@ packages: mime-types: 2.1.35 negotiator: 0.6.3 - /acorn-import-assertions@1.8.0(acorn@8.10.0): - resolution: {integrity: sha512-m7VZ3jwz4eK6A4Vtt8Ew1/mNbP24u0FhdyfA7fSvnJR6LMdfOYnmuIrrJAgrYfYJ10F/otaHTtrtrtmHdMNzEw==} + /acorn-import-assertions@1.9.0(acorn@8.11.3): + resolution: {integrity: sha512-cmMwop9x+8KFhxvKrKfPYmN6/pKTYYHBqLa0DfvVZcKMJWNyWLnaqND7dx/qn66R7ewM1UX5XMaDVP5wlVTaVA==} peerDependencies: acorn: ^8 dependencies: - acorn: 8.10.0 - dev: false + acorn: 8.11.3 - /acorn-jsx@5.3.2(acorn@8.10.0): + /acorn-jsx@5.3.2(acorn@8.11.3): resolution: {integrity: sha512-rq9s+JNhf0IChjtDXxllJ7g41oZk5SlXtp0LHwyA5cejwn7vKmKp4pPri6YEePv2PU65sAsegbXtIinmDFDXgQ==} peerDependencies: acorn: ^6.0.0 || ^7.0.0 || ^8.0.0 dependencies: - acorn: 8.10.0 + acorn: 8.11.3 dev: true - /acorn@8.10.0: - resolution: {integrity: sha512-F0SAmZ8iUtS//m8DmCTA0jlh6TDKkHQyK6xc6V4KDTyZKA9dnvX9/3sRTVQrWm79glUAZbnmmNcdYwUIHWVybw==} + /acorn-walk@8.3.2: + resolution: {integrity: sha512-cjkyv4OtNCIeqhHrfS81QWXoCBPExR/J62oyEqepVw8WaQeSqpW2uhuLPh1m9eWhDuOo/jUXVTlifvesOWp/4A==} + engines: {node: '>=0.4.0'} + dev: true + + /acorn@8.11.3: + resolution: {integrity: sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg==} engines: {node: '>=0.4.0'} hasBin: true @@ -2600,15 +5031,11 @@ packages: - supports-color dev: true - /agentkeepalive@4.3.0: - resolution: {integrity: sha512-7Epl1Blf4Sy37j4v9f9FjICCh4+KAQOyXgHEwlyBiAQLbhKdq/i2QQU3amQalS/wPhdPzDXPL5DMR5bkn+YeWg==} + /agentkeepalive@4.5.0: + resolution: {integrity: sha512-5GG/5IbQQpC9FpkRGsSvZI5QYeSCzlJHdpBQntCsuTOxhKD8lqKhrleg2Yi7yvMIf82Ycmmqln9U8V9qwEiJew==} engines: {node: '>= 8.0.0'} dependencies: - debug: 4.3.4(supports-color@8.1.1) - depd: 2.0.0 humanize-ms: 1.2.1 - transitivePeerDependencies: - - supports-color dev: true /aggregate-error@3.1.0: @@ -2618,6 +5045,68 @@ packages: clean-stack: 2.2.0 indent-string: 4.0.0 + /aggregate-error@4.0.1: + resolution: {integrity: sha512-0poP0T7el6Vq3rstR8Mn4V/IQrpBLO6POkUSrN7RhyY+GF/InCFShQzsQ39T25gkHhLgSLByyAz+Kjb+c2L98w==} + engines: {node: '>=12'} + dependencies: + clean-stack: 4.2.0 + indent-string: 5.0.0 + dev: true + + /agoric@0.21.1(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4): + resolution: {integrity: sha512-couQBRaYLY9S5cXm0uUmf/022+Zy6EHH9tbZLOFYGzdFQeTMZCvYbxdklKGVzLWcoe8CHc/YMemnpaBghkPG4A==} + hasBin: true + dependencies: + '@agoric/access-token': 0.4.21 + '@agoric/assert': 0.6.0 + '@agoric/cache': 0.3.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/casting': 0.4.2(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) + '@agoric/cosmic-proto': 0.3.0 + '@agoric/ertp': 0.16.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/inter-protocol': 0.16.1(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) + '@agoric/internal': 0.3.2(ava@5.3.1) + '@agoric/smart-wallet': 0.5.3(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) + '@agoric/store': 0.9.2(ava@5.3.1) + '@agoric/swingset-vat': 0.32.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/vats': 0.15.1(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) + '@agoric/zoe': 0.26.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/zone': 0.2.2(ava@5.3.1) + '@confio/relayer': 0.9.0(debug@4.3.4) + '@cosmjs/crypto': 0.30.1 + '@cosmjs/encoding': 0.30.1 + '@cosmjs/math': 0.30.1 + '@cosmjs/proto-signing': 0.30.1 + '@cosmjs/stargate': 0.30.1(debug@4.3.4) + '@cosmjs/tendermint-rpc': 0.30.1(debug@4.3.4) + '@endo/bundle-source': 2.8.0(ava@5.3.1) + '@endo/captp': 3.1.1(ava@5.3.1) + '@endo/compartment-mapper': 0.8.4 + '@endo/far': 0.2.18(ava@5.3.1) + '@endo/init': 0.5.60 + '@endo/marshal': 0.8.9(ava@5.3.1) + '@endo/nat': 4.1.31 + '@endo/promise-kit': 0.2.60 + '@iarna/toml': 2.2.5 + anylogger: 0.21.0 + chalk: 5.3.0 + commander: 10.0.1 + dd-trace: 3.50.0 + deterministic-json: 1.0.5 + esm: github.com/agoric-labs/esm/3603726ad4636b2f865f463188fcaade6375638e + inquirer: 8.2.6 + opener: 1.5.2 + tmp: 0.2.2 + ws: 7.5.9 + transitivePeerDependencies: + - '@endo/ses-ava' + - ava + - bufferutil + - debug + - encoding + - supports-color + - utf-8-validate + dev: true + /ajv-formats@2.1.1(ajv@8.12.0): resolution: {integrity: sha512-Wx0Kx52hxE7C18hkMEggYlEifqWZtYaRgouJor+WMdPnQyEK13vgEWyVNup7SoeeoLMsr4kf5h6dOW11I15MUA==} peerDependencies: @@ -2654,6 +5143,15 @@ packages: json-schema-traverse: 0.4.1 uri-js: 4.4.1 + /ajv@7.1.1: + resolution: {integrity: sha512-ga/aqDYnUy/o7vbsRTFhhTsNeXiYb5JWDIcRIeZfwRNCefwjNTVYCGdGSUrEmiu3yDK3vFvNbgJxvrQW4JXrYQ==} + dependencies: + fast-deep-equal: 3.1.3 + json-schema-traverse: 1.0.0 + require-from-string: 2.0.2 + uri-js: 4.4.1 + dev: true + /ajv@8.11.0: resolution: {integrity: sha512-wGgprdCvMalC0BztXvitD2hC04YffAvtsUn93JbGXYLAtCUO4xd17mCCZQxUOItiBwZvJScWo8NIvQMQ71rdpg==} dependencies: @@ -2670,7 +5168,6 @@ packages: json-schema-traverse: 1.0.0 require-from-string: 2.0.2 uri-js: 4.4.1 - dev: false /ansi-align@3.0.1: resolution: {integrity: sha512-IOfwwBF5iczOjp/WeY4YxyjqAFMQoZufdQWDd19SEExbVLNXqvpzSJ/M7Za4/sCPmQ0+GRquoA7bGcINcxew6w==} @@ -2714,11 +5211,13 @@ packages: /ansi-styles@5.2.0: resolution: {integrity: sha512-Cxwpt2SfTzTtXcfOlzGEee8O+c+MmUgGrNiBcXnuWxuFJHe6a5Hz7qwhwe5OgaSYI0IJvkLqWX1ASG+cJOkEiA==} engines: {node: '>=10'} - dev: false /ansi-styles@6.2.1: resolution: {integrity: sha512-bN798gFfQX+viw3R7yrGWRqnrN2oRkEkUjjl4JNn4E8GxxbjtG3FbrEIIY3l8/hrwUwIeCZvi4QuOTP4MErVug==} engines: {node: '>=12'} + + /anylogger@0.21.0: + resolution: {integrity: sha512-XJVplwflEff43l7aE48lW9gNoS0fpb1Ha4WttzjfTFlN3uJUIKALZ5oNWtwgRXPm/Q2dbp1EIddMbQ/AGHVX1A==} dev: true /anymatch@3.1.3: @@ -2727,7 +5226,6 @@ packages: dependencies: normalize-path: 3.0.0 picomatch: 2.3.1 - dev: false /app-root-path@3.1.0: resolution: {integrity: sha512-biN3PwB2gUtjaYy/isrU3aNWI5w+fAfvHkSvCKeQGxhmYpwKFUxudR3Yya+KqVRHBmEDYh+/lTozYCFbmzX4nA==} @@ -2775,39 +5273,39 @@ packages: resolution: {integrity: sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==} dependencies: sprintf-js: 1.0.3 - dev: false /argparse@2.0.1: resolution: {integrity: sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==} - /aria-query@5.1.3: - resolution: {integrity: sha512-R5iJ5lkuHybztUfuOAznmboyjWq8O6sqNqtK7CLOqdydi54VNbORp49mb14KbWgG1QD3JFO9hJdZ+y4KutfdOQ==} + /aria-query@5.3.0: + resolution: {integrity: sha512-b0P0sZPKtyu8HkeRAfCq0IfURZK+SuwMjY1UXGBU27wpAiTwQAIlq56IbIO+ytk/JjS1fMR14ee5WBBfKi5J6A==} dependencies: - deep-equal: 2.2.1 - dev: false + dequal: 2.0.3 - /array-buffer-byte-length@1.0.0: - resolution: {integrity: sha512-LPuwb2P+NrQw3XhxGc36+XSvuBPopovXYTR9Ew++Du9Yb/bx5AzBfrIsBoj0EZUifjQU+sHL21sseZ3jerWO/A==} + /array-buffer-byte-length@1.0.1: + resolution: {integrity: sha512-ahC5W1xgou+KTXix4sAO8Ki12Q+jf4i0+tmk3sC+zgcynshkHxzpXdImBehiUYKKKDwvfFiJl1tZt6ewscS1Mg==} + engines: {node: '>= 0.4'} dependencies: - call-bind: 1.0.2 - is-array-buffer: 3.0.2 + call-bind: 1.0.7 + is-array-buffer: 3.0.4 + + /array-find-index@1.0.2: + resolution: {integrity: sha512-M1HQyIXcBGtVywBt8WVdim+lrNaK7VHp99Qt5pSNziXznKHViIBbXWtfRTpEFpF/c4FdfxNAsCCwPp5phBYJtw==} + engines: {node: '>=0.10.0'} + dev: true /array-flatten@1.1.1: resolution: {integrity: sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==} dev: false - /array-flatten@2.1.2: - resolution: {integrity: sha512-hNfzcOV8W4NdualtqBFPyVO+54DSJuZGY9qT4pRroB6S9e3iiido2ISIC5h9R2sPJ8H3FHCIiEnsv1lPXO3KtQ==} - dev: false - - /array-includes@3.1.6: - resolution: {integrity: sha512-sgTbLvL6cNnw24FnbaDyjmvddQ2ML8arZsgaJhoABMoplz/4QRhtrYS+alr1BUM1Bwp6dhx8vVCBSLG+StwOFw==} + /array-includes@3.1.7: + resolution: {integrity: sha512-dlcsNBIiWhPkHdOEEKnehA+RNUWDc4UqFtnIXU4uuYDPtA4LDkr7qip2p0VvFAEXNDr0yWZ9PJyIRiGjRLQzwQ==} engines: {node: '>= 0.4'} dependencies: - call-bind: 1.0.2 - define-properties: 1.2.0 - es-abstract: 1.21.2 - get-intrinsic: 1.2.0 + call-bind: 1.0.7 + define-properties: 1.2.1 + es-abstract: 1.22.4 + get-intrinsic: 1.2.4 is-string: 1.0.7 dev: true @@ -2827,59 +5325,93 @@ packages: engines: {node: '>=0.10.0'} dev: false - /array.prototype.findlastindex@1.2.2: - resolution: {integrity: sha512-tb5thFFlUcp7NdNF6/MpDk/1r/4awWG1FIz3YqDf+/zJSTezBb+/5WViH41obXULHVpDzoiCLpJ/ZO9YbJMsdw==} + /array.prototype.filter@1.0.3: + resolution: {integrity: sha512-VizNcj/RGJiUyQBgzwxzE5oHdeuXY5hSbbmKMlphj1cy1Vl7Pn2asCGbSrru6hSQjmCzqTBPVWAF/whmEOVHbw==} + engines: {node: '>= 0.4'} + dependencies: + call-bind: 1.0.7 + define-properties: 1.2.1 + es-abstract: 1.22.4 + es-array-method-boxes-properly: 1.0.0 + is-string: 1.0.7 + dev: true + + /array.prototype.findlastindex@1.2.4: + resolution: {integrity: sha512-hzvSHUshSpCflDR1QMUBLHGHP1VIEBegT4pix9H/Z92Xw3ySoy6c2qh7lJWTJnRJ8JCZ9bJNCgTyYaJGcJu6xQ==} engines: {node: '>= 0.4'} dependencies: - call-bind: 1.0.2 - define-properties: 1.2.0 - es-abstract: 1.21.2 - es-shim-unscopables: 1.0.0 - get-intrinsic: 1.2.0 + call-bind: 1.0.7 + define-properties: 1.2.1 + es-abstract: 1.22.4 + es-errors: 1.3.0 + es-shim-unscopables: 1.0.2 dev: true - /array.prototype.flat@1.3.1: - resolution: {integrity: sha512-roTU0KWIOmJ4DRLmwKd19Otg0/mT3qPNt0Qb3GWW8iObuZXxrjB/pzn0R3hqpRSWg4HCwqx+0vwOnWnvlOyeIA==} + /array.prototype.flat@1.3.2: + resolution: {integrity: sha512-djYB+Zx2vLewY8RWlNCUdHjDXs2XOgm602S9E7P/UpHgfeHL00cRiIF+IN/G/aUJ7kGPb6yO/ErDI5V2s8iycA==} engines: {node: '>= 0.4'} dependencies: - call-bind: 1.0.2 - define-properties: 1.2.0 - es-abstract: 1.21.2 - es-shim-unscopables: 1.0.0 + call-bind: 1.0.7 + define-properties: 1.2.1 + es-abstract: 1.22.4 + es-shim-unscopables: 1.0.2 dev: true - /array.prototype.flatmap@1.3.1: - resolution: {integrity: sha512-8UGn9O1FDVvMNB0UlLv4voxRMze7+FpHyF5mSMRjWHUMlpoDViniy05870VlxhfgTnLbpuwTzvD76MTtWxB/mQ==} + /array.prototype.flatmap@1.3.2: + resolution: {integrity: sha512-Ewyx0c9PmpcsByhSW4r+9zDU7sGjFc86qf/kKtuSCRdhfbk0SNLLkaT5qvcHnRGgc5NP/ly/y+qkXkqONX54CQ==} engines: {node: '>= 0.4'} dependencies: - call-bind: 1.0.2 - define-properties: 1.2.0 - es-abstract: 1.21.2 - es-shim-unscopables: 1.0.0 + call-bind: 1.0.7 + define-properties: 1.2.1 + es-abstract: 1.22.4 + es-shim-unscopables: 1.0.2 dev: true - /array.prototype.map@1.0.5: - resolution: {integrity: sha512-gfaKntvwqYIuC7mLLyv2wzZIJqrRhn5PZ9EfFejSx6a78sV7iDsGpG9P+3oUPtm1Rerqm6nrKS4FYuTIvWfo3g==} + /array.prototype.map@1.0.6: + resolution: {integrity: sha512-nK1psgF2cXqP3wSyCSq0Hc7zwNq3sfljQqaG27r/7a7ooNUnn5nGq6yYWyks9jMO5EoFQ0ax80hSg6oXSRNXaw==} engines: {node: '>= 0.4'} dependencies: - call-bind: 1.0.2 - define-properties: 1.2.0 - es-abstract: 1.21.2 + call-bind: 1.0.7 + define-properties: 1.2.1 + es-abstract: 1.22.4 es-array-method-boxes-properly: 1.0.0 is-string: 1.0.7 dev: true - /array.prototype.reduce@1.0.5: - resolution: {integrity: sha512-kDdugMl7id9COE8R7MHF5jWk7Dqt/fs4Pv+JXoICnYwqpjjjbUurz6w5fT5IG6brLdJhv6/VoHB0H7oyIBXd+Q==} + /array.prototype.reduce@1.0.6: + resolution: {integrity: sha512-UW+Mz8LG/sPSU8jRDCjVr6J/ZKAGpHfwrZ6kWTG5qCxIEiXdVshqGnu5vEZA8S1y6X4aCSbQZ0/EEsfvEvBiSg==} engines: {node: '>= 0.4'} dependencies: - call-bind: 1.0.2 - define-properties: 1.2.0 - es-abstract: 1.21.2 + call-bind: 1.0.7 + define-properties: 1.2.1 + es-abstract: 1.22.4 es-array-method-boxes-properly: 1.0.0 is-string: 1.0.7 dev: false + /arraybuffer.prototype.slice@1.0.3: + resolution: {integrity: sha512-bMxMKAjg13EBSVscxTaYA4mRc5t1UAXa2kXiGTNfZ079HIWXEkKmkgFrh/nJqamaLSrXO5H4WFFkPEaLJWbs3A==} + engines: {node: '>= 0.4'} + dependencies: + array-buffer-byte-length: 1.0.1 + call-bind: 1.0.7 + define-properties: 1.2.1 + es-abstract: 1.22.4 + es-errors: 1.3.0 + get-intrinsic: 1.2.4 + is-array-buffer: 3.0.4 + is-shared-array-buffer: 1.0.3 + + /arrgv@1.0.2: + resolution: {integrity: sha512-a4eg4yhp7mmruZDQFqVMlxNRFGi/i1r87pt8SDHy0/I8PqSXoUTlWZRdAZo0VXgvEARcujbtTk8kiZRi1uDGRw==} + engines: {node: '>=8.0.0'} + dev: true + + /arrify@3.0.0: + resolution: {integrity: sha512-tLkvA81vQG/XqE2mjDkGQHoOINtMHtysSnemrmoGe6PydDPMRbVugqyk4A6V/WDWEfm3l+0d8anA9r8cv/5Jaw==} + engines: {node: '>=12'} + dev: true + /asn1@0.2.6: resolution: {integrity: sha512-ix/FxPn0MDjeyJ7i/yoHGFt/EX6LyNbxSEhPPXODPL+KB0VPk86UYfL0lMdy+KCnv+fmvIzySwaK5COwqVbWTQ==} dependencies: @@ -2891,17 +5423,20 @@ packages: engines: {node: '>=0.8'} dev: false + /assertion-error@1.1.0: + resolution: {integrity: sha512-jgsaNduz+ndvGyFt3uSuWqvy4lCnIJiovtouQN5JZHOKCS2QuhEdbcQHFhVksz2N2U9hXJo8odG7ETyWlEeuDw==} + dev: true + /ast-types@0.13.4: resolution: {integrity: sha512-x1FCFnFifvYDDzTaLII71vG5uvDwgtmDTEVWAxrgeiR8VjMONcCXJx7E+USjDtHlwFmt9MysbqgF9b9Vjr6w+w==} engines: {node: '>=4'} dependencies: - tslib: 2.6.1 + tslib: 2.6.2 dev: true /astral-regex@2.0.0: resolution: {integrity: sha512-Z7tMw1ytTXt5jqMcOP+OQteU1VuNK9Y02uuJtKQ1Sv69jXQKKg5cibLwGJow8yzZP+eAc18EmLGPal0bp36rvQ==} engines: {node: '>=8'} - dev: false /async-retry@1.3.3: resolution: {integrity: sha512-wfr/jstw9xNi/0teMHrRW7dsz3Lt5ARhYNZ2ewpadnhaIp5mbALhOAP+EAdsC7t4Z6wqsDVv9+W6gm1Dk9mEyw==} @@ -2909,9 +5444,8 @@ packages: retry: 0.13.1 dev: true - /async@3.2.4: - resolution: {integrity: sha512-iAB+JbDEGXhyIUavoDl9WP/Jj106Kz9DEn1DPgYw5ruDn0e3Wgi3sKFm55sASdGBNOQB8F59d9qQ7deqrHA8wQ==} - dev: false + /async@3.2.5: + resolution: {integrity: sha512-baNZyqaaLhyLVKm/DlvdW051MSgO6b8eVfIezl9E5PqWxFgzLm/wQntEW4zOytVburDEr0JlALEpdOFwvErLsg==} /asynckit@0.4.0: resolution: {integrity: sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==} @@ -2921,9 +5455,68 @@ packages: engines: {node: '>= 4.0.0'} dev: false - /available-typed-arrays@1.0.5: - resolution: {integrity: sha512-DMD0KiN46eipeziST1LPP/STfDU0sufISXmjSgvVsoU2tqxctQeASejWcfNtxYKqETM1UxQ8sp2OrSBWpHY6sw==} + /ava@5.3.1: + resolution: {integrity: sha512-Scv9a4gMOXB6+ni4toLuhAm9KYWEjsgBglJl+kMGI5+IVDt120CCDZyB5HNU9DjmLI2t4I0GbnxGLmmRfGTJGg==} + engines: {node: '>=14.19 <15 || >=16.15 <17 || >=18'} + hasBin: true + peerDependencies: + '@ava/typescript': '*' + peerDependenciesMeta: + '@ava/typescript': + optional: true + dependencies: + acorn: 8.11.3 + acorn-walk: 8.3.2 + ansi-styles: 6.2.1 + arrgv: 1.0.2 + arrify: 3.0.0 + callsites: 4.1.0 + cbor: 8.1.0 + chalk: 5.3.0 + chokidar: 3.6.0 + chunkd: 2.0.1 + ci-info: 3.9.0 + ci-parallel-vars: 1.0.1 + clean-yaml-object: 0.1.0 + cli-truncate: 3.1.0 + code-excerpt: 4.0.0 + common-path-prefix: 3.0.0 + concordance: 5.0.4 + currently-unhandled: 0.4.1 + debug: 4.3.4(supports-color@8.1.1) + emittery: 1.0.3 + figures: 5.0.0 + globby: 13.2.2 + ignore-by-default: 2.1.0 + indent-string: 5.0.0 + is-error: 2.2.2 + is-plain-object: 5.0.0 + is-promise: 4.0.0 + matcher: 5.0.0 + mem: 9.0.2 + ms: 2.1.3 + p-event: 5.0.1 + p-map: 5.5.0 + picomatch: 2.3.1 + pkg-conf: 4.0.0 + plur: 5.1.0 + pretty-ms: 8.0.0 + resolve-cwd: 3.0.0 + stack-utils: 2.0.6 + strip-ansi: 7.1.0 + supertap: 3.0.1 + temp-dir: 3.0.0 + write-file-atomic: 5.0.1 + yargs: 17.7.2 + transitivePeerDependencies: + - supports-color + dev: true + + /available-typed-arrays@1.0.7: + resolution: {integrity: sha512-wvUjBtSGN7+7SjNpq/9M2Tg350UZD3q62IFZLbRAR1bSMlCo1ZaeW+BJ+D090e4hIIZLBcTDWe4Mh4jvUDajzQ==} engines: {node: '>= 0.4'} + dependencies: + possible-typed-array-names: 1.0.0 /aws-sign2@0.7.0: resolution: {integrity: sha512-08kcGqnYf/YmjoRhfxyu+CLxBjUtHLXLXX/vUfx9l2LYzG3c1m61nrpyFUZI6zeS+Li/wWMMidD9KgrqtGq3mA==} @@ -2933,52 +5526,82 @@ packages: resolution: {integrity: sha512-NmWvPnx0F1SfrQbYwOi7OeaNGokp9XhzNioJ/CSBs8Qa4vxug81mhJEAVZwxXuBmYB5KDRfMq/F3RR0BIU7sWg==} dev: false - /axios@0.27.2(debug@4.3.4): - resolution: {integrity: sha512-t+yRIyySRTp/wua5xEr+z1q60QmLq8ABsS5O9Me1AsE5dfKqgnCFzwiCZZ/cGNd1lq4/7akDWMxdhVlucjmnOQ==} + /axios-retry@4.0.0(axios@1.6.7): + resolution: {integrity: sha512-F6P4HVGITD/v4z9Lw2mIA24IabTajvpDZmKa6zq/gGwn57wN5j1P3uWrAV0+diqnW6kTM2fTqmWNfgYWGmMuiA==} + peerDependencies: + axios: 0.x || 1.x dependencies: - follow-redirects: 1.15.2(debug@4.3.4) - form-data: 4.0.0 + axios: 1.6.7(debug@4.3.4) + is-retry-allowed: 2.2.0 + dev: true + + /axios@0.21.4(debug@4.3.4): + resolution: {integrity: sha512-ut5vewkiu8jjGBdqpM44XxjuCjq9LAKeHVmoVfHVzy8eHgxxq8SbAVQNovDA8mVi05kP0Ea/n/UzcSHcTJQfNg==} + dependencies: + follow-redirects: 1.15.5(debug@4.3.4) transitivePeerDependencies: - debug + dev: true /axios@1.2.2(debug@4.3.4): resolution: {integrity: sha512-bz/J4gS2S3I7mpN/YZfGFTqhXTYzRho8Ay38w2otuuDR322KzFIWm/4W2K6gIwvWaws5n+mnb7D1lN9uD+QH6Q==} dependencies: - follow-redirects: 1.15.2(debug@4.3.4) + follow-redirects: 1.15.5(debug@4.3.4) form-data: 4.0.0 proxy-from-env: 1.1.0 transitivePeerDependencies: - debug dev: false - /axios@1.4.0(debug@4.3.4): - resolution: {integrity: sha512-S4XCWMEmzvo64T9GfvQDOXgYRDJ/wsSZc7Jvdgx5u1sd0JwsuPLqb3SYmusag+edF6ziyMensPVqLTSc1PiSEA==} + /axios@1.6.7(debug@4.3.4): + resolution: {integrity: sha512-/hDJGff6/c7u0hDkvkGxR/oy6CbCs8ziCsC7SqmhjfozqiJGc8Z11wrv9z9lYfY4K8l+H9TpjcMDX0xOZmx+RA==} dependencies: - follow-redirects: 1.15.2(debug@4.3.4) + follow-redirects: 1.15.5(debug@4.3.4) form-data: 4.0.0 proxy-from-env: 1.1.0 transitivePeerDependencies: - debug - dev: false - /babel-loader@9.1.2(@babel/core@7.21.8)(webpack@5.81.0): - resolution: {integrity: sha512-mN14niXW43tddohGl8HPu5yfQq70iUThvFL/4QzESA7GcZoC0eVOhvWdQ8+3UlSjaDE9MVtsW9mxDY07W7VpVA==} + /b4a@1.6.6: + resolution: {integrity: sha512-5Tk1HLk6b6ctmjIkAcU/Ujv/1WqiDl0F0JdRCR80VsOcUlHcu7pWeWRlOqQLHfDEsVx9YH/aif5AG4ehoCtTmg==} + dev: true + + /babel-eslint@10.1.0(eslint@8.57.0): + resolution: {integrity: sha512-ifWaTHQ0ce+448CYop8AdrQiBsGrnC+bMgfyKFdi6EsPLTAWG+QfyDeM6OH+FmWnKvEq5NnBMLvlBUPKQZoDSg==} + engines: {node: '>=6'} + deprecated: babel-eslint is now @babel/eslint-parser. This package will no longer receive updates. + peerDependencies: + eslint: '>= 4.12.1' + dependencies: + '@babel/code-frame': 7.23.5 + '@babel/parser': 7.23.9 + '@babel/traverse': 7.23.9 + '@babel/types': 7.23.9 + eslint: 8.57.0 + eslint-visitor-keys: 1.3.0 + resolve: 1.22.8 + transitivePeerDependencies: + - supports-color + dev: true + + /babel-loader@9.1.3(@babel/core@7.23.9)(webpack@5.90.3): + resolution: {integrity: sha512-xG3ST4DglodGf8qSwv0MdeWLhrDsw/32QMdTO5T1ZIp9gQur0HkCyFs7Awskr10JKXFXwpAhiCuYX5oGXnRGbw==} engines: {node: '>= 14.15.0'} peerDependencies: '@babel/core': ^7.12.0 webpack: '>=5' dependencies: - '@babel/core': 7.21.8 - find-cache-dir: 3.3.2 - schema-utils: 4.0.1 - webpack: 5.81.0 + '@babel/core': 7.23.9 + find-cache-dir: 4.0.0 + schema-utils: 4.2.0 + webpack: 5.90.3 dev: false /babel-plugin-istanbul@6.1.1: resolution: {integrity: sha512-Y1IQok9821cC9onCx5otgFfRm7Lm+I+wwxOx738M/WLPZ9Q42m4IG5W0FNX8WLL2gYMZo3JkuXIH2DOpWM+qwA==} engines: {node: '>=8'} dependencies: - '@babel/helper-plugin-utils': 7.21.5 + '@babel/helper-plugin-utils': 7.22.5 '@istanbuljs/load-nyc-config': 1.1.0 '@istanbuljs/schema': 0.1.3 istanbul-lib-instrument: 5.2.1 @@ -2987,38 +5610,38 @@ packages: - supports-color dev: false - /babel-plugin-polyfill-corejs2@0.3.3(@babel/core@7.21.8): - resolution: {integrity: sha512-8hOdmFYFSZhqg2C/JgLUQ+t52o5nirNwaWM2B9LWteozwIvM14VSwdsCAUET10qT+kmySAlseadmfeeSWFCy+Q==} + /babel-plugin-polyfill-corejs2@0.4.8(@babel/core@7.23.9): + resolution: {integrity: sha512-OtIuQfafSzpo/LhnJaykc0R/MMnuLSSVjVYy9mHArIZ9qTCSZ6TpWCuEKZYVoN//t8HqBNScHrOtCrIK5IaGLg==} peerDependencies: - '@babel/core': ^7.0.0-0 + '@babel/core': ^7.4.0 || ^8.0.0-0 <8.0.0 dependencies: - '@babel/compat-data': 7.21.7 - '@babel/core': 7.21.8 - '@babel/helper-define-polyfill-provider': 0.3.3(@babel/core@7.21.8) + '@babel/compat-data': 7.23.5 + '@babel/core': 7.23.9 + '@babel/helper-define-polyfill-provider': 0.5.0(@babel/core@7.23.9) semver: 6.3.1 transitivePeerDependencies: - supports-color dev: false - /babel-plugin-polyfill-corejs3@0.6.0(@babel/core@7.21.8): - resolution: {integrity: sha512-+eHqR6OPcBhJOGgsIar7xoAB1GcSwVUA3XjAd7HJNzOXT4wv6/H7KIdA/Nc60cvUlDbKApmqNvD1B1bzOt4nyA==} + /babel-plugin-polyfill-corejs3@0.9.0(@babel/core@7.23.9): + resolution: {integrity: sha512-7nZPG1uzK2Ymhy/NbaOWTg3uibM2BmGASS4vHS4szRZAIR8R6GwA/xAujpdrXU5iyklrimWnLWU+BLF9suPTqg==} peerDependencies: - '@babel/core': ^7.0.0-0 + '@babel/core': ^7.4.0 || ^8.0.0-0 <8.0.0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-define-polyfill-provider': 0.3.3(@babel/core@7.21.8) - core-js-compat: 3.30.1 + '@babel/core': 7.23.9 + '@babel/helper-define-polyfill-provider': 0.5.0(@babel/core@7.23.9) + core-js-compat: 3.36.0 transitivePeerDependencies: - supports-color dev: false - /babel-plugin-polyfill-regenerator@0.4.1(@babel/core@7.21.8): - resolution: {integrity: sha512-NtQGmyQDXjQqQ+IzRkBVwEOz9lQ4zxAQZgoAYEtU9dJjnl1Oc98qnN7jcp+bE7O7aYzVpavXE3/VKXNzUbh7aw==} + /babel-plugin-polyfill-regenerator@0.5.5(@babel/core@7.23.9): + resolution: {integrity: sha512-OJGYZlhLqBh2DDHeqAxWB1XIvr49CxiJ2gIt61/PU55CQK4Z58OzMqjDe1zwQdQk+rBYsRc+1rJmdajM3gimHg==} peerDependencies: - '@babel/core': ^7.0.0-0 + '@babel/core': ^7.4.0 || ^8.0.0-0 <8.0.0 dependencies: - '@babel/core': 7.21.8 - '@babel/helper-define-polyfill-provider': 0.3.3(@babel/core@7.21.8) + '@babel/core': 7.23.9 + '@babel/helper-define-polyfill-provider': 0.5.0(@babel/core@7.23.9) transitivePeerDependencies: - supports-color dev: false @@ -3071,11 +5694,17 @@ packages: /balanced-match@1.0.2: resolution: {integrity: sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==} + /bare-events@2.2.0: + resolution: {integrity: sha512-Yyyqff4PIFfSuthCZqLlPISTWHmnQxoPuAvkmgzsJEmG3CesdIv6Xweayl0JkCZJSB2yYIdJyEz97tpxNhgjbg==} + requiresBuild: true + dev: true + optional: true + /base64-js@1.5.1: resolution: {integrity: sha512-AKpaYlHn8t4SVbOHCy+b5+KKgvR4vrsD8vbvrbiQJps7fKDTkjkDry6ji0rUJjC0kzbNePLwzxq8iypo41qeWA==} - /basic-ftp@5.0.3: - resolution: {integrity: sha512-QHX8HLlncOLpy54mh+k/sWIFd0ThmRqwe9ZjELybGZK+tZ8rUb9VO0saKJUROTbE+KhzDUT7xziGpGrW8Kmd+g==} + /basic-ftp@5.0.5: + resolution: {integrity: sha512-4Bcg1P8xhUuqcii/S0Z9wiHIrQVPMermM1any+MX5GeGD7faD3/msQUDGLol9wOcz4/jbg/WJnGqoJF6LiBdtg==} engines: {node: '>=10.0.0'} dev: true @@ -3089,12 +5718,24 @@ packages: tweetnacl: 0.14.5 dev: false + /bech32@1.1.4: + resolution: {integrity: sha512-s0IrSOzLlbvX7yp4WBfPITzpAU8sqQcpsmwXDiKwrG4r491vwCO/XpejasRNl0piBMe/DvP4Tz0mIS/X1DPJBQ==} + dev: true + /before-after-hook@2.2.3: resolution: {integrity: sha512-NzUnlZexiaH/46WDhANlyR2bXRopNg4F/zuSA3OpZnllCUgRaOF2znDioDWrmbNVsuZk6l9pMquQB38cfBZwkQ==} dev: true - /big-integer@1.6.51: - resolution: {integrity: sha512-GPEid2Y9QU1Exl1rpO9B2IPJGHPSupF5GnVIP0blYvNOMer2bTvSWs1jGOUg04hTmu67nmLsQ9TBo1puaotBHg==} + /better-sqlite3@8.7.0: + resolution: {integrity: sha512-99jZU4le+f3G6aIl6PmmV0cxUIWqKieHxsiF7G34CVFiE+/UabpYqkU0NJIkY/96mQKikHeBjtR27vFfs5JpEw==} + requiresBuild: true + dependencies: + bindings: 1.5.0 + prebuild-install: 7.1.1 + dev: true + + /big-integer@1.6.52: + resolution: {integrity: sha512-QxD8cf2eVqJOOz63z6JIN9BzvVs/dlySa5HGSBH5xtR8dPteIRQnBxxKqkNTiT6jbDTF6jAfrd4oMcND9RGbQg==} engines: {node: '>=0.6'} dev: true @@ -3105,7 +5746,16 @@ packages: /binary-extensions@2.2.0: resolution: {integrity: sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==} engines: {node: '>=8'} - dev: false + + /bindings@1.5.0: + resolution: {integrity: sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ==} + dependencies: + file-uri-to-path: 1.0.0 + dev: true + + /bintrees@1.0.2: + resolution: {integrity: sha512-VOMgTMwjAaUG580SXn3LacVgjurrbMme7ZZNYGSSV7mmtY6QQRh0Eg3pwIcntQ77DErK1L0NxkbetjcoXzVwKw==} + dev: true /bl@1.2.3: resolution: {integrity: sha512-pvcNpa0UU69UT341rO6AYy4FVAIkUHuZXRIWbq+zHnsVcRzDDjIAhGuuYoi0d//cwIwtt4pkpKycWEfjdV+vww==} @@ -3141,6 +5791,18 @@ packages: /bluebird@3.7.2: resolution: {integrity: sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg==} + /blueimp-md5@2.19.0: + resolution: {integrity: sha512-DRQrD6gJyy8FbiE4s+bDoXS9hiW3Vbx5uCdwvcCf3zLHL+Iv7LtGHLpr+GZV8rHG8tK766FGYBwRbu8pELTt+w==} + dev: true + + /bn.js@4.12.0: + resolution: {integrity: sha512-c98Bf3tPniI+scsdk237ku1Dc3ujXQTSgyiPUDEOe7tRkhrqridvh8klBv0HCEso1OLOYcHuCv/cS6DNxKH+ZA==} + dev: true + + /bn.js@5.2.1: + resolution: {integrity: sha512-eXRvHzWyYPBuB4NBy0cmYQjGitUrtqwbvlzP3G6VFnNRbsZQIxQ10PbKKHt8gZ/HW/D/747aDl+QkDqg3KQLMQ==} + dev: true + /body-parser@1.20.1: resolution: {integrity: sha512-jWi7abTbYwajOytWCQc37VulmWiRae5RyTpaCyDcS5/lMdtwSz5lOpDE67srw/HYe35f1z3fDQw+3txg7gNtWw==} engines: {node: '>= 0.8', npm: 1.2.8000 || >= 1.4.16} @@ -3161,11 +5823,9 @@ packages: - supports-color dev: false - /bonjour-service@1.1.1: - resolution: {integrity: sha512-Z/5lQRMOG9k7W+FkeGTNjh7htqn/2LMnfOvBZ8pynNZCM9MwkQkI3zeI4oz09uWdcgmgHugVvBqxGg4VQJ5PCg==} + /bonjour-service@1.2.1: + resolution: {integrity: sha512-oSzCS2zV14bh2kji6vNe7vrpJYCHGvcZnlffFQ1MEoX/WOeQ/teD8SYWKR942OI3INjq8OMNJlbPK5LLLUxFDw==} dependencies: - array-flatten: 2.1.2 - dns-equal: 1.0.0 fast-deep-equal: 3.1.3 multicast-dns: 7.2.5 dev: false @@ -3180,7 +5840,7 @@ packages: dependencies: ansi-align: 3.0.1 camelcase: 7.0.1 - chalk: 5.3.0 + chalk: 5.0.1 cli-boxes: 3.0.0 string-width: 5.1.2 type-fest: 2.19.0 @@ -3188,8 +5848,8 @@ packages: wrap-ansi: 8.1.0 dev: true - /boxen@7.0.2: - resolution: {integrity: sha512-1Z4UJabXUP1/R9rLpoU3O2lEMnG3pPLAs/ZD2lF3t2q7qD5lM8rqbtnvtvm4N0wEyNlE+9yZVTVAGmd1V5jabg==} + /boxen@7.1.1: + resolution: {integrity: sha512-2hCgjEmP8YLWQ130n2FerGv7rYpfBmnmp9Uy2Le1vge6X3gZIfSmEzP5QTDElFxcvVcXlEn8Aq6MU/PZygIOog==} engines: {node: '>=14.16'} dependencies: ansi-align: 3.0.1 @@ -3206,7 +5866,7 @@ packages: resolution: {integrity: sha512-z0M+byMThzQmD9NILRniCUXYsYpjwnlO8N5uCFaCqIOpqRsJCrQL9NK3JsD67CN5a08nF5oIL2bD6loTdHOuKw==} engines: {node: '>= 5.10.0'} dependencies: - big-integer: 1.6.51 + big-integer: 1.6.52 dev: true /brace-expansion@1.1.11: @@ -3219,7 +5879,6 @@ packages: resolution: {integrity: sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==} dependencies: balanced-match: 1.0.2 - dev: true /braces@3.0.2: resolution: {integrity: sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==} @@ -3227,16 +5886,19 @@ packages: dependencies: fill-range: 7.0.1 - /browserslist@4.21.5: - resolution: {integrity: sha512-tUkiguQGW7S3IhB7N+c2MV/HZPSCPAAiYBZXLsBhFB/PCy6ZKKsZrmBayHV9fdGV/ARIfJ14NkxKzRDjvp7L6w==} + /brorand@1.1.0: + resolution: {integrity: sha512-cKV8tMCEpQs4hK/ik71d6LrPOnpkpGBR0wzxqr68g2m/LB2GxVYQroAjMJZRVM1Y4BCjCKc3vAamxSzOY2RP+w==} + dev: true + + /browserslist@4.23.0: + resolution: {integrity: sha512-QW8HiM1shhT2GuzkvklfjcKDiWFXHOeFCIA/huJPwHsslwcydgk7X+z2zXpEijP98UCY7HbubZt5J2Zgvf0CaQ==} engines: {node: ^6 || ^7 || ^8 || ^9 || ^10 || ^11 || ^12 || >=13.7} hasBin: true dependencies: - caniuse-lite: 1.0.30001482 - electron-to-chromium: 1.4.380 - node-releases: 2.0.10 - update-browserslist-db: 1.0.11(browserslist@4.21.5) - dev: false + caniuse-lite: 1.0.30001591 + electron-to-chromium: 1.4.685 + node-releases: 2.0.14 + update-browserslist-db: 1.0.13(browserslist@4.23.0) /buffer-alloc-unsafe@1.1.0: resolution: {integrity: sha512-TEM2iMIEQdJ2yjPJoSIsldnleVaAk1oW3DBVUykyOLsEsFmEc9kn+SFFPz+gl54KQNxlDnAwCXosOS9Okx2xAg==} @@ -3251,7 +5913,6 @@ packages: /buffer-crc32@0.2.13: resolution: {integrity: sha512-VO9Ht/+p3SN7SKWqcrgEzjGbRSJYTx+Q1pTQC0wrWqHx0vpJraQ6GtHx8tvcg1rlK1byhU5gccxgOgj7B0TDkQ==} - dev: false /buffer-fill@1.0.0: resolution: {integrity: sha512-T7zexNBwiiaCOGDg9xNX9PBmjrubblRkENuptryuI64URkXDFum9il/JGL8Lm8wYfAXpredVXXZz7eMHilimiQ==} @@ -3281,7 +5942,7 @@ packages: /builtins@5.0.1: resolution: {integrity: sha512-qwVpFEHNfhYJIzNRBvd2C1kyo6jz3ZSMPyyuR47OPdiKWlbYnZNyDWuyR175qDnAJLiCo5fBBqPb3RiXgWlkOQ==} dependencies: - semver: 7.5.4 + semver: 7.6.0 dev: true /bundle-name@3.0.0: @@ -3305,6 +5966,11 @@ packages: engines: {node: '>= 0.8'} dev: false + /cac@6.7.14: + resolution: {integrity: sha512-b6Ilus+c3RrdDk+JhLKUAQfzzgLEPy6wcXqS7f/xe1EETvsDP6GORG7SFuOs6cID5YkqchW/LXZbX5bc8j7ZcQ==} + engines: {node: '>=8'} + dev: true + /cacache@16.1.3: resolution: {integrity: sha512-/+Emcj9DAXxX4cwlLmRI9c166RuL3w30zp4R7Joiv2cQTtTtA+jeuCAjH3ZlGnYS3tKENSrKhAzVVP9GVyzeYQ==} engines: {node: ^12.13.0 || ^14.15.0 || >=16.0.0} @@ -3325,27 +5991,27 @@ packages: promise-inflight: 1.0.1 rimraf: 3.0.2 ssri: 9.0.1 - tar: 6.1.13 + tar: 6.2.0 unique-filename: 2.0.1 transitivePeerDependencies: - bluebird dev: true - /cacache@17.0.7: - resolution: {integrity: sha512-2GdqQs7hl20V50cB+JEuGeR6YtcNsf1Y9+SP8YXjmGlZz4hM5Ds9s6mKo7e27r6sfF/6MhN4DKRrGldidJJWow==} + /cacache@17.1.4: + resolution: {integrity: sha512-/aJwG2l3ZMJ1xNAnqbMpA40of9dj/pIH3QfiuQSqjfPJF747VR0J/bHn+/KdNnHKc6XQcWt/AfRSBft82W1d2A==} engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} dependencies: '@npmcli/fs': 3.1.0 - fs-minipass: 3.0.2 - glob: 10.3.3 + fs-minipass: 3.0.3 + glob: 10.3.10 lru-cache: 7.18.3 - minipass: 5.0.0 + minipass: 7.0.4 minipass-collect: 1.0.2 minipass-flush: 1.0.5 minipass-pipeline: 1.2.4 p-map: 4.0.0 - ssri: 10.0.4 - tar: 6.1.13 + ssri: 10.0.5 + tar: 6.2.0 unique-filename: 3.0.0 dev: true @@ -3354,14 +6020,14 @@ packages: engines: {node: '>=14.16'} dev: true - /cacheable-request@10.2.10: - resolution: {integrity: sha512-v6WB+Epm/qO4Hdlio/sfUn69r5Shgh39SsE9DSd4bIezP0mblOlObI+I0kUEM7J0JFc+I7pSeMeYaOYtX1N/VQ==} + /cacheable-request@10.2.14: + resolution: {integrity: sha512-zkDT5WAF4hSSoUgyfg5tFIxz8XQK+25W/TLVojJTMKBaxevLBBtLxgqguAuVQB8PVW79FVjHcU+GJ9tVbDZ9mQ==} engines: {node: '>=14.16'} dependencies: - '@types/http-cache-semantics': 4.0.1 + '@types/http-cache-semantics': 4.0.4 get-stream: 6.0.1 http-cache-semantics: 4.1.1 - keyv: 4.5.2 + keyv: 4.5.4 mimic-response: 4.0.0 normalize-url: 8.0.0 responselike: 3.0.0 @@ -3379,8 +6045,8 @@ packages: responselike: 1.0.2 dev: false - /cachedir@2.3.0: - resolution: {integrity: sha512-A+Fezp4zxnit6FanDmv9EqXNAi3vt9DWp51/71UEhXukb7QUuvtv9344h91dyAxuTLoSYJFU299qzR3tzwPAhw==} + /cachedir@2.4.0: + resolution: {integrity: sha512-9EtFOZR8g22CL7BWjJ9BUx1+A/djkofnyW3aOXZORNW2kxoUpx2h+uN2cOqwPmFhnpVmxg+KW2OjOSgChTEvsQ==} engines: {node: '>=6'} dev: false @@ -3394,22 +6060,31 @@ packages: write-file-atomic: 3.0.3 dev: false - /call-bind@1.0.2: - resolution: {integrity: sha512-7O+FbCihrB5WGbFYesctwmTKae6rOiIzmz1icreWJ+0aA7LJfuqhEso2T9ncpcFtzMQtzXf2QGGueWJGTYsqrA==} + /call-bind@1.0.7: + resolution: {integrity: sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w==} + engines: {node: '>= 0.4'} dependencies: - function-bind: 1.1.1 - get-intrinsic: 1.2.0 + es-define-property: 1.0.0 + es-errors: 1.3.0 + function-bind: 1.1.2 + get-intrinsic: 1.2.4 + set-function-length: 1.2.1 /callsites@3.1.0: resolution: {integrity: sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==} engines: {node: '>=6'} dev: true + /callsites@4.1.0: + resolution: {integrity: sha512-aBMbD1Xxay75ViYezwT40aQONfr+pSXTHwNKvIXhXD6+LY3F1dLIcceoC5OZKBVHbXcysz1hL9D2w0JJIMXpUw==} + engines: {node: '>=12.20'} + dev: true + /camel-case@4.1.2: resolution: {integrity: sha512-gxGWBrTT1JuMx6R+o5PTXMmUnhnVzLQ9SNutD4YqKtI6ap897t3tKECYla6gCWEkplXnlNybEkZg9GEGxKFCgw==} dependencies: pascal-case: 3.1.2 - tslib: 2.6.1 + tslib: 2.6.2 dev: false /camelcase@5.3.1: @@ -3422,14 +6097,33 @@ packages: engines: {node: '>=14.16'} dev: true - /caniuse-lite@1.0.30001482: - resolution: {integrity: sha512-F1ZInsg53cegyjroxLNW9DmrEQ1SuGRTO1QlpA0o2/6OpQ0gFeDRoq1yFmnr8Sakn9qwwt9DmbxHB6w167OSuQ==} - dev: false + /caniuse-lite@1.0.30001591: + resolution: {integrity: sha512-PCzRMei/vXjJyL5mJtzNiUCKP59dm8Apqc3PH8gJkMnMXZGox93RbE76jHsmLwmIo6/3nsYIpJtx0O7u5PqFuQ==} /caseless@0.12.0: resolution: {integrity: sha512-4tYFyifaFfGacoiObjJegolkwSU4xQNGbVgUiNYVUxbQ2x2lUsFvY4hVgVzGiIe6WLOPqycWXA40l+PWsxthUw==} dev: false + /cbor@8.1.0: + resolution: {integrity: sha512-DwGjNW9omn6EwP70aXsn7FQJx5kO12tX0bZkaTjzdVFM6/7nhA4t0EENocKGx6D2Bch9PE2KzCUf5SceBdeijg==} + engines: {node: '>=12.19'} + dependencies: + nofilter: 3.1.0 + dev: true + + /chai@4.4.1: + resolution: {integrity: sha512-13sOfMv2+DWduEU+/xbun3LScLoqN17nBeTLUsmDfKdoiC1fr0n9PU4guu4AhRcOVFk/sW8LyZWHuhWtQZiF+g==} + engines: {node: '>=4'} + dependencies: + assertion-error: 1.1.0 + check-error: 1.0.3 + deep-eql: 4.1.3 + get-func-name: 2.0.2 + loupe: 2.3.7 + pathval: 1.1.1 + type-detect: 4.0.8 + dev: true + /chalk-template@0.4.0: resolution: {integrity: sha512-/ghrgmhfY8RaSdeo43hNXxpoHAtxdbskUHjPpfqUWGttFgycUhYPGx3YZBCnUCvOa7Doivn1IZec3DEGFoMgLg==} engines: {node: '>=12'} @@ -3470,12 +6164,18 @@ packages: resolution: {integrity: sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==} dev: true + /check-error@1.0.3: + resolution: {integrity: sha512-iKEoDYaRmd1mxM90a2OEfWhjsjPpYPuQ+lMYsoxB126+t8fw7ySEO48nmDg5COTjxDI65/Y2OWpeEHk3ZOe8zg==} + dependencies: + get-func-name: 2.0.2 + dev: true + /check-more-types@2.24.0: resolution: {integrity: sha512-Pj779qHxV2tuapviy1bSZNEL1maXr13bPYpsvSDB68HlYcYuhlDrmGd63i0JHMCLKzc7rUSNIrpdJlhVlNwrxA==} engines: {node: '>= 0.8.0'} - /chokidar@3.5.3: - resolution: {integrity: sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==} + /chokidar@3.6.0: + resolution: {integrity: sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==} engines: {node: '>= 8.10.0'} dependencies: anymatch: 3.1.3 @@ -3486,8 +6186,11 @@ packages: normalize-path: 3.0.0 readdirp: 3.6.0 optionalDependencies: - fsevents: 2.3.2 - dev: false + fsevents: 2.3.3 + + /chownr@1.1.4: + resolution: {integrity: sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg==} + dev: true /chownr@2.0.0: resolution: {integrity: sha512-bIomtDF5KGpdogkLd9VspvFzk9KfpyyGlS8YFVZl7TGPBHL5snIOnxeshwVgPteQ9b4Eydl+pVbIyE1DcvCWgQ==} @@ -3499,10 +6202,32 @@ packages: engines: {node: '>=6.0'} dev: false - /ci-info@3.8.0: - resolution: {integrity: sha512-eXTggHWSooYhq49F2opQhuHWgzucfF2YgODK4e1566GQs5BIfP30B0oenwBJHfWxAs2fyPB1s7Mg949zLf61Yw==} + /chromium-bidi@0.5.8(devtools-protocol@0.0.1232444): + resolution: {integrity: sha512-blqh+1cEQbHBKmok3rVJkBlBxt9beKBgOsxbFgs7UJcoVbbeZ+K7+6liAsjgpc8l1Xd55cQUy14fXZdGSb4zIw==} + peerDependencies: + devtools-protocol: '*' + dependencies: + devtools-protocol: 0.0.1232444 + mitt: 3.0.1 + urlpattern-polyfill: 10.0.0 + dev: true + + /chunkd@2.0.1: + resolution: {integrity: sha512-7d58XsFmOq0j6el67Ug9mHf9ELUXsQXYJBkyxhH/k+6Ke0qXRnv0kbemx+Twc6fRJ07C49lcbdgm9FL1Ei/6SQ==} + dev: true + + /ci-info@3.9.0: + resolution: {integrity: sha512-NIxF55hv4nSqQswkAeiOi1r83xy8JldOFDTWiug55KBu9Jnblncd2U6ViHmYgHf01TPZS77NJBhBMKdWj9HQMQ==} engines: {node: '>=8'} + /ci-parallel-vars@1.0.1: + resolution: {integrity: sha512-uvzpYrpmidaoxvIQHM+rKSrigjOe9feHYbw4uOI2gdfe1C3xIlxO+kVXq83WQWNniTf8bAxVpy+cQeFQsMERKg==} + dev: true + + /cjs-module-lexer@1.2.3: + resolution: {integrity: sha512-0TNiGstbQmCFwt4akjjBg5pLRTSyj/PkWQ1ZoO2zntmg9yLqSRxwEa4iCfQLGjqhiqBfOJa7W/E8wfGrTDmlZQ==} + dev: true + /clean-css@4.2.4: resolution: {integrity: sha512-EJUDT7nDVFDvaQgAo2G/PJvxmp1o/c6iXLbswsBbUFXi1Nr+AjA2cKmfbKDMjMvzEe75g3P6JkaDDAKk96A85A==} engines: {node: '>= 4.0'} @@ -3510,8 +6235,8 @@ packages: source-map: 0.6.1 dev: false - /clean-css@5.3.2: - resolution: {integrity: sha512-JVJbM+f3d3Q704rF4bqQ5UUyTtuJ0JRKNbTKVEeujCCBoMdkEi+V+e8oktO9qGQNSvHrFTM6JZRXrUvGR1czww==} + /clean-css@5.3.3: + resolution: {integrity: sha512-D5J+kHaVb/wKSFcyyV75uCn8fiY4sV38XJoe4CUyGQ+mOU/fMVYUdH1hJC+CJQ5uY3EnW27SbJYS4X8BiLrAFg==} engines: {node: '>= 10.0'} dependencies: source-map: 0.6.1 @@ -3528,6 +6253,18 @@ packages: resolution: {integrity: sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==} engines: {node: '>=6'} + /clean-stack@4.2.0: + resolution: {integrity: sha512-LYv6XPxoyODi36Dp976riBtSY27VmFo+MKqEU9QCCWyTrdEPDog+RWA7xQWHi6Vbp61j5c4cdzzX1NidnwtUWg==} + engines: {node: '>=12'} + dependencies: + escape-string-regexp: 5.0.0 + dev: true + + /clean-yaml-object@0.1.0: + resolution: {integrity: sha512-3yONmlN9CSAkzNwnRCiJQ7Q2xK5mWuEfL3PuTZcAUzhObbXsfsnMptJzXwz93nc5zn9V9TwCVMmV7w4xsm43dw==} + engines: {node: '>=0.10.0'} + dev: true + /cli-boxes@3.0.0: resolution: {integrity: sha512-/lzGpEWL/8PfI0BmBOPRwp0c/wFNX1RdUML3jK/RcSBA9T8mZDdQpqYBKtCFTOfQbwPqWEOpjqW+Fnayc0969g==} engines: {node: '>=10'} @@ -3546,8 +6283,8 @@ packages: restore-cursor: 4.0.0 dev: true - /cli-spinners@2.9.0: - resolution: {integrity: sha512-4/aL9X3Wh0yiMQlE+eeRhWP6vclO3QRtw1JHKIT0FFUs5FjpFmESqtMvYZ0+lbzBw900b95mS0hohy+qn2VK/g==} + /cli-spinners@2.9.2: + resolution: {integrity: sha512-ywqV+5MmyL4E7ybXgKys4DugZbX0FC6LnwrhjuykIjnK9k8OQacQ7axGKnjDXWNhns0xot3bZI5h55H8yo9cJg==} engines: {node: '>=6'} dev: true @@ -3567,6 +6304,19 @@ packages: string-width: 4.2.3 dev: false + /cli-truncate@3.1.0: + resolution: {integrity: sha512-wfOBkjXteqSnI59oPcJkcPl/ZmwvMMOj340qUIY1SKZCv0B9Cf4D4fAucRkIKQmsIuYK3x1rrgU7MeGRruiuiA==} + engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} + dependencies: + slice-ansi: 5.0.0 + string-width: 5.1.2 + dev: true + + /cli-width@3.0.0: + resolution: {integrity: sha512-FxqpkPPwu1HjuN93Omfm4h8uIanXofW0RxVEW3k5RKx+mJJYSthzNhp32Kzxxy3YAEZ/Dc/EWN1vZRY0+kOhbw==} + engines: {node: '>= 10'} + dev: true + /cli-width@4.1.0: resolution: {integrity: sha512-ouuZd4/dm2Sw5Gmqy6bGyNNNe1qt9RpmxveLSO7KcgsTnU7RXfsw+/bukWGo1abgBiMAic068rclZsO4IWmmxQ==} engines: {node: '>= 12'} @@ -3589,6 +6339,15 @@ packages: wrap-ansi: 6.2.0 dev: false + /cliui@8.0.1: + resolution: {integrity: sha512-BSeNnyus75C4//NQ9gQt1/csTXyo/8Sb+afLAkzAptFuMsod9HFokGNudZpi/oQV73hnVK+sR+5PVRMd+Dr7YQ==} + engines: {node: '>=12'} + dependencies: + string-width: 4.2.3 + strip-ansi: 6.0.1 + wrap-ansi: 7.0.0 + dev: true + /clone-deep@4.0.1: resolution: {integrity: sha512-neHB9xuzh/wk0dIHweyAXv2aPGZIVk3pLMe+/RNzINf17fe0OG96QroktYAUm7SM1PBnzTabaLboqqxDyMU+SQ==} engines: {node: '>=6'} @@ -3609,6 +6368,18 @@ packages: engines: {node: '>=0.8'} dev: true + /clsx@1.2.1: + resolution: {integrity: sha512-EcR6r5a8bj6pu3ycsa/E/cKVGuTgZJZdsyUYHOksG/UHIiKfjxzRxYJpyVBwYaQeOvghal9fcc4PidlgzugAQg==} + engines: {node: '>=6'} + dev: true + + /code-excerpt@4.0.0: + resolution: {integrity: sha512-xxodCmBen3iy2i0WtAK8FlFNrRzjUqjRsMfho58xT/wvZU1YTM3fCnRjcy1gJPMepaRlgm/0e6w8SpWHpn3/cA==} + engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} + dependencies: + convert-to-spaces: 2.0.1 + dev: true + /color-convert@1.9.3: resolution: {integrity: sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==} dependencies: @@ -3626,15 +6397,36 @@ packages: /color-name@1.1.4: resolution: {integrity: sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==} + /color-string@1.9.1: + resolution: {integrity: sha512-shrVawQFojnZv6xM40anx4CkoDP+fZsw/ZerEMsW/pyzsRbElpsL/DBVW7q3ExxwusdNXI3lXpuhEZkzs8p5Eg==} + dependencies: + color-name: 1.1.4 + simple-swizzle: 0.2.2 + dev: true + /color-support@1.1.3: resolution: {integrity: sha512-qiBjkpbMLO/HL68y+lh4q0/O1MZFj2RX6X/KmMa3+gJD3z+WwI1ZzDHysvqHGS3mP6mznPckpXmw1nI9cJjyRg==} hasBin: true dev: true + /color@3.2.1: + resolution: {integrity: sha512-aBl7dZI9ENN6fUGC7mWpMTPNHmWUSNan9tuWN6ahh5ZLNk9baLJOnSMlrQkHcrfFgz2/RigjUVAjdx36VcemKA==} + dependencies: + color-convert: 1.9.3 + color-string: 1.9.1 + dev: true + /colorette@2.0.20: resolution: {integrity: sha512-IfEDxwoWIjkeXL1eXcDiow4UbKjhLdq6/EuSVR9GMN7KVH3r9gQ83e73hsz1Nd1T3ijd5xv1wcWRYO+D6kCI2w==} dev: false + /colorspace@1.1.4: + resolution: {integrity: sha512-BgvKJiuVu1igBUF2kEjRCZXol6wiiGbY5ipL/oVPwm0BL9sIpMIzM8IK7vwuxIIzOXMV3Ey5w+vxhm0rR/TN8w==} + dependencies: + color: 3.2.1 + text-hex: 1.0.0 + dev: true + /combined-stream@1.0.8: resolution: {integrity: sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==} engines: {node: '>= 0.8'} @@ -3650,8 +6442,8 @@ packages: engines: {node: '>=14'} dev: true - /commander@11.0.0: - resolution: {integrity: sha512-9HMlXtt/BNoYr8ooyjjNRdIilOTkVJXB+GhxMTtOKwk0R4j4lS4NpjuqmRxroBfnfTSHQIHQB7wryHhXarNjmQ==} + /commander@11.1.0: + resolution: {integrity: sha512-yPVavfyCcRhmorC7rWlkHn15b4wDVgVmBA7kV4QVBsF7kv/9TKJAbAXVTxvTnwP8HHKjRCJDClKbciiYS7p0DQ==} engines: {node: '>=16'} dev: false @@ -3669,11 +6461,19 @@ packages: engines: {node: '>= 6'} dev: false + /commander@7.1.0: + resolution: {integrity: sha512-pRxBna3MJe6HKnBGsDyMv8ETbptw3axEdYHoqNh7gu5oDcew8fs0xnivZGm06Ogk8zGAJ9VX+OPEr2GXEQK4dg==} + engines: {node: '>= 10'} + dev: true + /commander@8.3.0: resolution: {integrity: sha512-OkTL9umf+He2DZkUq8f8J9of7yL6RJKI24dVITBmNfZBmri9zYZQrKkuXiKhyfPSu8tUhnVBB1iKXevvnlR4Ww==} engines: {node: '>= 12'} dev: false + /common-path-prefix@3.0.0: + resolution: {integrity: sha512-QE33hToZseCH3jS0qN96O/bSh3kaw/h+Tq7ngyY9eWDUnTlTNUyqfqvCXioLe5Na5jFsL78ra/wuBU4iuEgd4w==} + /common-tags@1.8.2: resolution: {integrity: sha512-gk/Z852D2Wtb//0I+kRFNKKE9dIIVirjoqPoA1wJU+XePVXZfGeBpk45+A1rKO4Q43prqWBNY/MiIeRLbPWUaA==} engines: {node: '>=4.0.0'} @@ -3681,7 +6481,6 @@ packages: /commondir@1.0.1: resolution: {integrity: sha512-W9pAhw0ja1Edb5GVdIF1mjZw/ASI0AlShXM83UUGe2DVr5TdAPEA1OA8m/g8zWp9x6On7gqufY+FatDbC3MDQg==} - dev: false /compressible@2.0.18: resolution: {integrity: sha512-AF3r7P5dWxL8MxyITRMlORQNaOA2IkAFaTr4k7BUumjPtRpGDTZpl0Pb1XCO6JeDCBdp126Cgs9sMxqSjgYyRg==} @@ -3706,6 +6505,20 @@ packages: /concat-map@0.0.1: resolution: {integrity: sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==} + /concordance@5.0.4: + resolution: {integrity: sha512-OAcsnTEYu1ARJqWVGwf4zh4JDfHZEaSNlNccFmt8YjB2l/n19/PF2viLINHc57vO4FKIAFl2FWASIGZZWZ2Kxw==} + engines: {node: '>=10.18.0 <11 || >=12.14.0 <13 || >=14'} + dependencies: + date-time: 3.1.0 + esutils: 2.0.3 + fast-diff: 1.3.0 + js-string-escape: 1.0.1 + lodash: 4.17.21 + md5-hex: 3.0.1 + semver: 7.6.0 + well-known-symbols: 2.0.0 + dev: true + /config-chain@1.1.13: resolution: {integrity: sha512-qj+f8APARXHrM0hraqXYb2/bOVSV4PvJQlNZ/DVj0QrmNM2q2euizkeuVckQ57J+W0mRH6Hvi+k50M4Jul2VRQ==} dependencies: @@ -3754,6 +6567,14 @@ packages: resolution: {integrity: sha512-ASFBup0Mz1uyiIjANan1jzLQami9z1PoYSZCiiYW2FczPbenXc45FZdBZLzOT+r6+iciuEModtmCti+hjaAk0A==} dev: false + /convert-source-map@2.0.0: + resolution: {integrity: sha512-Kvp459HrV2FEJ1CAsi1Ku+MY3kasH19TFykTz2xWmMeq6bk2NU3XXvfJ+Q61m0xktWwt+1HSYf3JZsTms3aRJg==} + + /convert-to-spaces@2.0.1: + resolution: {integrity: sha512-rcQ1bsQO9799wq24uE5AM2tAILy4gXGIK/njFWcVQkGNZ96edlpY+A7bjwvzjYvLDyzmG1MmMLZhpcsb+klNMQ==} + engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} + dev: true + /cookie-signature@1.0.6: resolution: {integrity: sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==} dev: false @@ -3763,10 +6584,10 @@ packages: engines: {node: '>= 0.6'} dev: false - /core-js-compat@3.30.1: - resolution: {integrity: sha512-d690npR7MC6P0gq4npTl5n2VQeNAmUrJ90n+MHiKS7W2+xno4o3F5GDEuylSdi6EJ3VssibSGXOa1r3YXD3Mhw==} + /core-js-compat@3.36.0: + resolution: {integrity: sha512-iV9Pd/PsgjNWBXeq8XRtWVSgz2tKAfhfvBs7qxYty+RlRd+OCksaWmOnc4JKrTc1cToXL1N0s3l/vwlxPtdElw==} dependencies: - browserslist: 4.21.5 + browserslist: 4.23.0 dev: false /core-js@2.6.12: @@ -3775,8 +6596,8 @@ packages: requiresBuild: true dev: false - /core-js@3.30.1: - resolution: {integrity: sha512-ZNS5nbiSwDTq4hFosEDqm65izl2CWmLz0hARJMyNQBgkUZMIF51cQiMvIQKA6hvuaeWxQDP3hEedM1JZIgTldQ==} + /core-js@3.36.0: + resolution: {integrity: sha512-mt7+TUBbTFg5+GngsAxeKBTl5/VS0guFeJacYge9OmHb+m058UwwIm41SE9T4Den7ClatV57B6TYTuJ0CX1MAw==} requiresBuild: true dev: false @@ -3788,14 +6609,51 @@ packages: resolution: {integrity: sha512-ZQBvi1DcpJ4GDqanjucZ2Hj3wEO5pZDS89BWbkcrvdxksJorwUDDZamX9ldFkp9aw2lmBDLgkObEA4DWNJ9FYQ==} dev: false - /cosmiconfig@8.2.0: - resolution: {integrity: sha512-3rTMnFJA1tCOPwRxtgF4wd7Ab2qvDbL8jX+3smjIbS4HlZBagTlpERbdN7iAbWlrfxE3M8c27kTwTawQ7st+OQ==} + /cosmiconfig@8.3.6(typescript@5.3.3): + resolution: {integrity: sha512-kcZ6+W5QzcJ3P1Mt+83OUv/oHFqZHIx8DuxG6eZ5RGMERoLqp4BuGjhHLYGK+Kf5XVkQvqBSmAy/nGWN3qDgEA==} engines: {node: '>=14'} + peerDependencies: + typescript: '>=4.9.5' + peerDependenciesMeta: + typescript: + optional: true dependencies: import-fresh: 3.3.0 js-yaml: 4.1.0 parse-json: 5.2.0 path-type: 4.0.0 + typescript: 5.3.3 + dev: true + + /cosmiconfig@9.0.0(typescript@5.3.3): + resolution: {integrity: sha512-itvL5h8RETACmOTFc4UfIyB2RfEHi71Ax6E/PivVxq9NseKbOWpeyHEOIbmAw1rs8Ak0VursQNww7lf7YtUwzg==} + engines: {node: '>=14'} + peerDependencies: + typescript: '>=4.9.5' + peerDependenciesMeta: + typescript: + optional: true + dependencies: + env-paths: 2.2.1 + import-fresh: 3.3.0 + js-yaml: 4.1.0 + parse-json: 5.2.0 + typescript: 5.3.3 + dev: true + + /cosmjs-types@0.7.2: + resolution: {integrity: sha512-vf2uLyktjr/XVAgEq0DjMxeAWh1yYREe7AMHDKd7EiHVqxBPCaBS+qEEQUkXbR9ndnckqr1sUG8BQhazh4X5lA==} + dependencies: + long: 4.0.0 + protobufjs: 6.11.4 + dev: true + + /cross-fetch@4.0.0: + resolution: {integrity: sha512-e4a5N8lVvuLgAWgnCrLr2PP0YyDOTHa9H/Rj54dirp61qXnNq46m82bRhNqIA5VccJtWBvPTFRV3TtvHUKPB1g==} + dependencies: + node-fetch: 2.7.0 + transitivePeerDependencies: + - encoding dev: true /cross-spawn@7.0.3: @@ -3813,6 +6671,10 @@ packages: type-fest: 1.4.0 dev: true + /crypto-randomuuid@1.0.0: + resolution: {integrity: sha512-/RC5F4l1SCqD/jazwUF6+t34Cd8zTSAGZ7rvvZu1whZUhD2a5MOGKjSGowoGcpj/cbVZk1ZODIooJEQQq3nNAA==} + dev: true + /css-select@4.3.0: resolution: {integrity: sha512-wPpOYtnsVontu2mODhA19JrqWxNsfdatRKd64kmpRbQgh1KtItko5sTnEpPdpSaJszTOhEMlF/RPz28qj4HqhQ==} dependencies: @@ -3828,9 +6690,15 @@ packages: engines: {node: '>= 6'} dev: false - /csstype@3.1.2: - resolution: {integrity: sha512-I7K1Uu0MBPzaFKg4nI5Q7Vs2t+3gWWW648spaF+Rg7pI9ds18Ugn+lvg4SHczUdKlHI5LWBXyqfS8+DufyBsgQ==} - dev: false + /csstype@3.1.3: + resolution: {integrity: sha512-M1uQkMl8rQK/szD0LNhtqxIPLpimGm8sOBwU7lLnCpSbTyY3yeU1Vc7l4KT5zT4s/yOxHH5O7tIuuLOCnLADRw==} + + /currently-unhandled@0.4.1: + resolution: {integrity: sha512-/fITjgjGU50vjQ4FH6eUoYu+iUoUKIXws2hL15JJpIR+BbTxaXQsMuuyjtNh2WqsSBS5nsaZHFsFecyw5CCAng==} + engines: {node: '>=0.10.0'} + dependencies: + array-find-index: 1.0.2 + dev: true /cypress-wait-until@2.0.1: resolution: {integrity: sha512-+IyVnYNiaX1+C+V/LazrJWAi/CqiwfNoRSrFviECQEyolW1gDRy765PZosL2alSSGK8V10Y7BGfOQyZUDgmnjQ==} @@ -3844,23 +6712,23 @@ packages: dependencies: '@cypress/request': 2.88.12 '@cypress/xvfb': 1.2.4(supports-color@8.1.1) - '@types/node': 16.18.39 + '@types/node': 16.18.84 '@types/sinonjs__fake-timers': 8.1.1 - '@types/sizzle': 2.3.3 + '@types/sizzle': 2.3.8 arch: 2.2.0 blob-util: 2.0.2 bluebird: 3.7.2 buffer: 5.7.1 - cachedir: 2.3.0 + cachedir: 2.4.0 chalk: 4.1.2 check-more-types: 2.24.0 cli-cursor: 3.1.0 cli-table3: 0.6.3 commander: 6.2.1 common-tags: 1.8.2 - dayjs: 1.11.9 + dayjs: 1.11.10 debug: 4.3.4(supports-color@8.1.1) - enquirer: 2.3.6 + enquirer: 2.4.1 eventemitter2: 6.4.7 execa: 4.1.0 executable: 4.1.1 @@ -3871,7 +6739,7 @@ packages: is-ci: 3.0.1 is-installed-globally: 0.4.0 lazy-ass: 1.6.0 - listr2: 3.14.0(enquirer@2.3.6) + listr2: 3.14.0(enquirer@2.4.1) lodash: 4.17.21 log-symbols: 4.1.0 minimist: 1.2.8 @@ -3879,9 +6747,9 @@ packages: pretty-bytes: 5.6.0 proxy-from-env: 1.0.0 request-progress: 3.0.0 - semver: 7.5.4 + semver: 7.6.0 supports-color: 8.1.1 - tmp: 0.2.1 + tmp: 0.2.2 untildify: 4.0.0 yauzl: 2.10.0 dev: false @@ -3898,15 +6766,66 @@ packages: engines: {node: '>= 12'} dev: true - /data-uri-to-buffer@5.0.1: - resolution: {integrity: sha512-a9l6T1qqDogvvnw0nKlfZzqsyikEBZBClF39V3TFoKhDtGBqHu2HkuomJc02j5zft8zrUaXEuoicLeW54RkzPg==} + /data-uri-to-buffer@6.0.2: + resolution: {integrity: sha512-7hvf7/GW8e86rW0ptuwS3OcBGDjIi6SZva7hCyWC0yYry2cOPmLIjXAUHI6DK2HsnwJd9ifmt57i8eV2n4YNpw==} engines: {node: '>= 14'} dev: true - /dayjs@1.11.9: - resolution: {integrity: sha512-QvzAURSbQ0pKdIye2txOzNaHmxtUBXerpY0FJsFXUMKbIZeFm5ht1LS/jFsrncjnmtv8HsG0W2g6c0zUjZWmpA==} + /date-time@3.1.0: + resolution: {integrity: sha512-uqCUKXE5q1PNBXjPqvwhwJf9SwMoAHBgWJ6DcrnS5o+W2JOiIILl0JEdVD8SGujrNS02GGxgwAg2PN2zONgtjg==} + engines: {node: '>=6'} + dependencies: + time-zone: 1.0.0 + dev: true + + /dayjs@1.11.10: + resolution: {integrity: sha512-vjAczensTgRcqDERK0SR2XMwsF/tSvnvlv6VcF2GIhg6Sx4yOIt/irsr1RDJsKiIyBzJDpCoXiWWq28MqH2cnQ==} dev: false + /dc-polyfill@0.1.4: + resolution: {integrity: sha512-8iwEduR2jR9wWYggeaYtYZWRiUe3XZPyAQtMTL1otv8X3kfR8xUIVb4l5awHEeyDrH6Je7N324lKzMKlMMN6Yw==} + engines: {node: '>=12.17'} + dev: true + + /dd-trace@3.50.0: + resolution: {integrity: sha512-e4nw89MvqjPDUmUgYwffvVHY2upRHG2YNMUXY1iNcwQo8q64JuHTTazOessHO5yqYcXZ+OWdH0xXDO6Dqzj05A==} + engines: {node: '>=14'} + requiresBuild: true + dependencies: + '@datadog/native-appsec': 7.0.0 + '@datadog/native-iast-rewriter': 2.2.3 + '@datadog/native-iast-taint-tracking': 1.7.0 + '@datadog/native-metrics': 2.0.0 + '@datadog/pprof': 5.0.0 + '@datadog/sketches-js': 2.1.0 + '@opentelemetry/api': 1.7.0 + '@opentelemetry/core': 1.21.0(@opentelemetry/api@1.7.0) + crypto-randomuuid: 1.0.0 + dc-polyfill: 0.1.4 + ignore: 5.3.1 + import-in-the-middle: 1.7.3 + int64-buffer: 0.1.10 + ipaddr.js: 2.1.0 + istanbul-lib-coverage: 3.2.0 + jest-docblock: 29.7.0 + koalas: 1.0.2 + limiter: 1.1.5 + lodash.sortby: 4.7.0 + lru-cache: 7.18.3 + methods: 1.1.2 + module-details-from-path: 1.0.3 + msgpack-lite: 0.1.26 + node-abort-controller: 3.1.1 + opentracing: 0.14.7 + path-to-regexp: 0.1.7 + pprof-format: 2.0.7 + protobufjs: 7.2.6 + retry: 0.13.1 + semver: 7.6.0 + shell-quote: 1.8.1 + tlhunter-sorted-set: 0.1.0 + dev: true + /debug@2.6.9: resolution: {integrity: sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==} peerDependencies: @@ -4017,28 +6936,12 @@ packages: strip-dirs: 2.1.0 dev: false - /deep-equal@2.2.1: - resolution: {integrity: sha512-lKdkdV6EOGoVn65XaOsPdH4rMxTZOnmFyuIkMjM1i5HHCbfjC97dawgTAy0deYNfuqUqW+Q5VrVaQYtUpSd6yQ==} + /deep-eql@4.1.3: + resolution: {integrity: sha512-WaEtAOpRA1MQ0eohqZjpGD8zdI0Ovsm8mmFhaDN8dvDZzyoUMcYDnf5Y6iu7HTXxf8JDS23qWa4a+hKCDyOPzw==} + engines: {node: '>=6'} dependencies: - array-buffer-byte-length: 1.0.0 - call-bind: 1.0.2 - es-get-iterator: 1.1.3 - get-intrinsic: 1.2.1 - is-arguments: 1.1.1 - is-array-buffer: 3.0.2 - is-date-object: 1.0.5 - is-regex: 1.1.4 - is-shared-array-buffer: 1.0.2 - isarray: 2.0.5 - object-is: 1.1.5 - object-keys: 1.1.1 - object.assign: 4.1.4 - regexp.prototype.flags: 1.5.0 - side-channel: 1.0.4 - which-boxed-primitive: 1.0.2 - which-collection: 1.0.1 - which-typed-array: 1.1.9 - dev: false + type-detect: 4.0.8 + dev: true /deep-extend@0.6.0: resolution: {integrity: sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==} @@ -4049,6 +6952,11 @@ packages: resolution: {integrity: sha512-oIPzksmTg4/MriiaYGO+okXDT7ztn/w3Eptv/+gSIdMdKsJo0u4CfYNFJPy+4SKMuCqGw2wxnA+URMg3t8a/bQ==} dev: true + /deepmerge@4.3.1: + resolution: {integrity: sha512-3sUqbMEc77XqpdNO7FRyRog+eW3ph+GYCbj+rK+uYyRMuwsVy0rMiVtPn+QJlKFvWP/1PYpapqYn0Me2knFn+A==} + engines: {node: '>=0.10.0'} + dev: true + /default-browser-id@3.0.0: resolution: {integrity: sha512-OZ1y3y0SqSICtE8DE4S8YOE9UZOJ8wO16fKWVP5J1Qz42kV9jcnMVFrEE/noXb/ss3Q4pZIH79kxofzyNNtUNA==} engines: {node: '>=12'} @@ -4092,6 +7000,14 @@ packages: engines: {node: '>=10'} dev: true + /define-data-property@1.1.4: + resolution: {integrity: sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A==} + engines: {node: '>= 0.4'} + dependencies: + es-define-property: 1.0.0 + es-errors: 1.3.0 + gopd: 1.0.1 + /define-lazy-prop@2.0.0: resolution: {integrity: sha512-Ds09qNh8yw3khSjiJjiUInaGX9xlqZDY7JVryGxdxV7NPeuqQfplOpQ66yJFZut3jLa5zOwkXw1g9EI2uKh4Og==} engines: {node: '>=8'} @@ -4102,11 +7018,12 @@ packages: engines: {node: '>=12'} dev: true - /define-properties@1.2.0: - resolution: {integrity: sha512-xvqAVKGfT1+UAvPwKTVw/njhdQ8ZhXK4lI0bCIuCMrp2up9nPnaDftrLtmpTazqd1o+UY4zgzU+avtMbDP+ldA==} + /define-properties@1.2.1: + resolution: {integrity: sha512-8QmQKqEASLd5nx0U1B1okLElbUuuttJ/AnYmRXbbbGDWh6uS208EjD4Xqq/I9wK7u0v6O08XhTWnt5XtEbR6Dg==} engines: {node: '>= 0.4'} dependencies: - has-property-descriptors: 1.0.0 + define-data-property: 1.1.4 + has-property-descriptors: 1.0.2 object-keys: 1.1.1 /degenerator@5.0.1: @@ -4118,6 +7035,11 @@ packages: esprima: 4.0.1 dev: true + /delay@5.0.0: + resolution: {integrity: sha512-ReEBKkIfe4ya47wlPYf/gu5ib6yUG0/Aez0JQZQz94kiWtRQvZIQbTiehsnwHvLSWJnQdhVeqYue7Id1dKr0qw==} + engines: {node: '>=10'} + dev: true + /delayed-stream@1.0.0: resolution: {integrity: sha512-ZySD7Nf91aLB0RxL4KGrKHBXl7Eds1DAmEdcoVawXnLD7SDhpNgtuII2aAkg7a7QS41jxPSZ17p4VdGnMHk3MQ==} engines: {node: '>=0.4.0'} @@ -4134,32 +7056,58 @@ packages: /depd@2.0.0: resolution: {integrity: sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==} engines: {node: '>= 0.8'} + dev: false /deprecation@2.3.1: resolution: {integrity: sha512-xmHIy4F3scKVwMsQ4WnVaS8bHOx0DmVwRywosKhaILI0ywMDWPtBSku2HNxRvF7jtwDRsoEwYQSfbxj8b7RlJQ==} dev: true + /dequal@2.0.3: + resolution: {integrity: sha512-0je+qPKHEMohvfRTCEo3CrPG6cAzAYgmzKyxRiYSSDkS6eGJdyVJm7WaYA5ECaAD9wLB2T4EEeymA5aFVcYXCA==} + engines: {node: '>=6'} + /destroy@1.2.0: resolution: {integrity: sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==} engines: {node: '>= 0.8', npm: 1.2.8000 || >= 1.4.16} dev: false + /detect-libc@2.0.2: + resolution: {integrity: sha512-UX6sGumvvqSaXgdKGUsgZWqcUyIXZ/vZTrlRT/iobiKhGL0zL4d3osHj3uqllWJK+i+sixDS/3COVEOFbupFyw==} + engines: {node: '>=8'} + dev: true + + /detect-newline@3.1.0: + resolution: {integrity: sha512-TLz+x/vEXm/Y7P7wn1EJFNLxYpUD4TgMosxY6fAVJUnJMbupHBOncxyWUG9OpTaH9EBD7uFI5LfEgmMOc54DsA==} + engines: {node: '>=8'} + dev: true + /detect-node@2.1.0: resolution: {integrity: sha512-T0NIuQpnTvFDATNuHN5roPwSBG83rFsuO+MXXH9/3N1eFbn4wcPjttvjMLEPWJ0RGUYgQE7cGgS3tNxbqCGM7g==} dev: false + /deterministic-json@1.0.5: + resolution: {integrity: sha512-JSD3TNaM+xEgvV9JK+7hnQvEIAHD9ZvhTl4h2EmH5rDxmyN1o4/RSC0lH82anzt5b6IUW4Tb4d5uzE00vH/tMw==} + dependencies: + json-stable-stringify: 1.1.1 + dev: true + + /devtools-protocol@0.0.1232444: + resolution: {integrity: sha512-pM27vqEfxSxRkTMnF+XCmxSEb6duO5R+t8A9DEEJgy4Wz2RVanje2mmj99B6A3zv2r/qGfYlOvYznUhuokizmg==} + dev: true + + /diff-sequences@29.6.3: + resolution: {integrity: sha512-EjePK1srD3P08o2j4f0ExnylqRs5B9tJjcp9t1krH2qRi8CCdsYfwe9JgSLurFBWwq4uOlipzfk5fHNvwFKr8Q==} + engines: {node: ^14.15.0 || ^16.10.0 || >=18.0.0} + dev: true + /dir-glob@3.0.1: resolution: {integrity: sha512-WkrWp9GR4KXfKGYzOLmTuGVi1UWFfws377n9cc55/tb6DuqyF6pcQ5AbiHEshaDpY9v6oaSr2XCDidGmMwdzIA==} engines: {node: '>=8'} dependencies: path-type: 4.0.0 - /dns-equal@1.0.0: - resolution: {integrity: sha512-z+paD6YUQsk+AbGCEM4PrOXSss5gd66QfcVBFTKR/HpFL9jCqikS94HYwKww6fQyO7IxrIIyUu+g0Ka9tUS2Cg==} - dev: false - - /dns-packet@5.6.0: - resolution: {integrity: sha512-rza3UH1LwdHh9qyPXp8lkwpjSNk/AMD3dPytUoRoqnypDUhY0xvbdmVhWOfxO68frEfV9BU8V12Ez7ZsHGZpCQ==} + /dns-packet@5.6.1: + resolution: {integrity: sha512-l4gcSouhcgIKRvyy99RNVOgxXiicE+2jZoNmaNmZ6JXiGajBOJAesk1OBlJuM5k2c+eudGdLxDqXuPCKIj6kpw==} engines: {node: '>=6'} dependencies: '@leichtgewicht/ip-codec': 2.0.4 @@ -4181,7 +7129,6 @@ packages: /dom-accessibility-api@0.5.16: resolution: {integrity: sha512-X7BJ2yElsnOJ30pZF4uIIDfBEVgF4XEBxL9Bxhy6dnrm5hkzqmsWHGTiHqRiITNhMyFLyAiWndIJP7Z1NTteDg==} - dev: false /dom-converter@0.2.0: resolution: {integrity: sha512-gd3ypIPfOMr9h5jIKq8E3sHOTCjeirnl0WK5ZdS1AW0Odt0b1PaWaHdJ4Qk4klv+YB9aJBS7mESXjFoDQPu6DA==} @@ -4220,7 +7167,7 @@ packages: resolution: {integrity: sha512-Kv5nKlh6yRrdrGvxeJ2e5y2eRUpkUosIW4A2AS38zwSz27zu7ufDwQPi5Jhs3XAlGNetl3bmnGhQsMtkKJnj3w==} dependencies: no-case: 3.0.4 - tslib: 2.6.1 + tslib: 2.6.2 dev: false /dot-prop@6.0.1: @@ -4230,6 +7177,13 @@ packages: is-obj: 2.0.0 dev: true + /dot-prop@8.0.2: + resolution: {integrity: sha512-xaBe6ZT4DHPkg0k4Ytbvn5xoxgpG0jOS1dYxSOwAHPuNLjP3/OzN0gH55SrLqpx8cBfSaVt91lXYkApjb+nYdQ==} + engines: {node: '>=16'} + dependencies: + type-fest: 3.13.1 + dev: true + /dotenv-parse-variables@2.0.0: resolution: {integrity: sha512-/Tezlx6xpDqR6zKg1V4vLCeQtHWiELhWoBz5A/E0+A1lXN9iIkNbbfc4THSymS0LQUo8F1PMiIwVG8ai/HrnSA==} engines: {node: '>= 8.3.0'} @@ -4245,8 +7199,8 @@ packages: engines: {node: '>=12'} dev: true - /dotenv@16.3.1: - resolution: {integrity: sha512-IPzF4w4/Rd94bA9imS68tZBaYyBWSCE47V1RGuMrB94iyTOIEwRmVL2x/4An+6mETpLrKJ5hQkB8W4kFAadeIQ==} + /dotenv@16.4.5: + resolution: {integrity: sha512-ZmdL2rui+eB2YwhsWzjInR8LldtZHGDoQ1ugH85ppHKwpUHL7j7rN0Ti9NCnGiQbhaZ11FpR+7ao1dNsmduNUg==} engines: {node: '>=12'} dev: false @@ -4277,7 +7231,6 @@ packages: /eastasianwidth@0.2.0: resolution: {integrity: sha512-I88TYZWc9XiYHRQ4/3c5rjjfgkjhLyW2luGIheGERbNQ6OY7yTybanSpDXZa8y7VUP9YmDcYa+eyq4ca7iLqWA==} - dev: true /ecc-jsbn@0.1.2: resolution: {integrity: sha512-eh9O+hwRHNbG4BLTjEl3nw044CkGm5X6LoaCf7LPp7UU8Qrt47JYNi6nPX8xjW97TKGKm1ouctg0QSpZe9qrnw==} @@ -4290,16 +7243,32 @@ packages: resolution: {integrity: sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==} dev: false - /electron-to-chromium@1.4.380: - resolution: {integrity: sha512-XKGdI4pWM78eLH2cbXJHiBnWUwFSzZM7XujsB6stDiGu9AeSqziedP6amNLpJzE3i0rLTcfAwdCTs5ecP5yeSg==} - dev: false + /electron-to-chromium@1.4.685: + resolution: {integrity: sha512-yDYeobbTEe4TNooEzOQO6xFqg9XnAkVy2Lod1C1B2it8u47JNLYvl9nLDWBamqUakWB8Jc1hhS1uHUNYTNQdfw==} + + /elliptic@6.5.4: + resolution: {integrity: sha512-iLhC6ULemrljPZb+QutR5TQGB+pdW6KGD5RSegS+8sorOZT+rdQFbsQFJgvN3eRqNALqJer4oQ16YvJHlU8hzQ==} + dependencies: + bn.js: 4.12.0 + brorand: 1.1.0 + hash.js: 1.1.7 + hmac-drbg: 1.0.1 + inherits: 2.0.4 + minimalistic-assert: 1.0.1 + minimalistic-crypto-utils: 1.0.1 + dev: true /email-addresses@5.0.0: resolution: {integrity: sha512-4OIPYlA6JXqtVn8zpHpGiI7vE6EQOAg16aGnDMIAlZVinnoZ8208tW1hAbjWydgN/4PLTT9q+O1K6AH/vALJGw==} dev: false - /emoji-regex@10.2.1: - resolution: {integrity: sha512-97g6QgOk8zlDRdgq1WxwgTMgEWGVAQvB5Fdpgc1MkNy56la5SKP9GsMXKDOdqwn90/41a8yPwIGk1Y6WVbeMQA==} + /emittery@1.0.3: + resolution: {integrity: sha512-tJdCJitoy2lrC2ldJcqN4vkqJ00lT+tOWNT1hBJjO/3FDMJa5TTIiYGCKGkn/WfCyOzUMObeohbVTj00fhiLiA==} + engines: {node: '>=14.16'} + dev: true + + /emoji-regex@10.3.0: + resolution: {integrity: sha512-QpLs9D9v9kArv4lfDEgg1X/gN5XLnf/A6l9cs8SPZLRZR3ZkY9+kwIQTxm+fsSej5UMYGE8fdoaZVIBlqG0XTw==} dev: true /emoji-regex@8.0.0: @@ -4307,13 +7276,16 @@ packages: /emoji-regex@9.2.2: resolution: {integrity: sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==} - dev: true /emojis-list@3.0.0: resolution: {integrity: sha512-/kyM18EfinwXZbno9FyUGeFh87KC8HRQBQGildHZbEuRyWFOmv1U10o9BBp8XVZDVNNuQKyIGIu5ZYAAXJ0V2Q==} engines: {node: '>= 4'} dev: false + /enabled@2.0.0: + resolution: {integrity: sha512-AKrN98kuwOzMIdAizXGI86UFBoo26CL21UM763y1h/GMSJ4/OHU9k2YlsmBpyScFo/wbLzWQJBMCW4+IO3/+OQ==} + dev: true + /encodeurl@1.0.2: resolution: {integrity: sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==} engines: {node: '>= 0.8'} @@ -4331,27 +7303,32 @@ packages: resolution: {integrity: sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==} dependencies: once: 1.4.0 - dev: false - /enhanced-resolve@5.13.0: - resolution: {integrity: sha512-eyV8f0y1+bzyfh8xAwW/WTSZpLbjhqc4ne9eGSH4Zo2ejdyiNG9pU6mf9DG8a7+Auk6MFTlNOT4Y2y/9k8GKVg==} + /enhanced-resolve@5.15.1: + resolution: {integrity: sha512-3d3JRbwsCLJsYgvb6NuWEG44jjPSOMuS73L/6+7BZuoKm3W+qXnSoIYVHi8dG7Qcg4inAY4jbzkZ7MnskePeDg==} engines: {node: '>=10.13.0'} dependencies: graceful-fs: 4.2.11 tapable: 2.2.1 dev: false - /enquirer@2.3.6: - resolution: {integrity: sha512-yjNnPr315/FjS4zIsUxYguYUPP2e1NK4d7E7ZOLiyYCcbFBiTMyID+2wvm2w6+pZ/odMA7cRkjhsPbltwBOrLg==} + /enquirer@2.4.1: + resolution: {integrity: sha512-rRqJg/6gd538VHvR3PSrdRBb/1Vy2YfzHqzvbhGIQpDRKIa4FgV/54b5Q1xYSxOOwKvjXweS26E0Q+nAMwp2pQ==} engines: {node: '>=8.6'} dependencies: ansi-colors: 4.1.3 + strip-ansi: 6.0.1 dev: false /entities@2.2.0: resolution: {integrity: sha512-p92if5Nz619I0w+akJrLZH0MX0Pb5DX39XOwQTtXSdQQOaYH03S1uIQp4mhOZtAXrxq4ViO67YTiLBo2638o9A==} dev: false + /entities@4.5.0: + resolution: {integrity: sha512-V0hjH4dGPh9Ao5p0MoRY6BVqtwCjhz6vI5LT8AJ55H+4g9/4vbHx1I54fS0XuclLhDHArPQCiMjDxjaL8fPxhw==} + engines: {node: '>=0.12'} + dev: true + /env-paths@2.2.1: resolution: {integrity: sha512-+h1lkLKhZMTYjog1VEpJNG7NZJWcuc2DDk/qsqSTRRCOXiLjeQ1d1/udrUGhqMxUgAlwKNZ0cf2uqan5GLuS2A==} engines: {node: '>=6'} @@ -4367,53 +7344,75 @@ packages: is-arrayish: 0.2.1 dev: true - /es-abstract@1.21.2: - resolution: {integrity: sha512-y/B5POM2iBnIxCiernH1G7rC9qQoM77lLIMQLuob0zhp8C56Po81+2Nj0WFKnd0pNReDTnkYryc+zhOzpEIROg==} + /es-abstract@1.22.4: + resolution: {integrity: sha512-vZYJlk2u6qHYxBOTjAeg7qUxHdNfih64Uu2J8QqWgXZ2cri0ZpJAkzDUK/q593+mvKwlxyaxr6F1Q+3LKoQRgg==} engines: {node: '>= 0.4'} dependencies: - array-buffer-byte-length: 1.0.0 - available-typed-arrays: 1.0.5 - call-bind: 1.0.2 - es-set-tostringtag: 2.0.1 + array-buffer-byte-length: 1.0.1 + arraybuffer.prototype.slice: 1.0.3 + available-typed-arrays: 1.0.7 + call-bind: 1.0.7 + es-define-property: 1.0.0 + es-errors: 1.3.0 + es-set-tostringtag: 2.0.3 es-to-primitive: 1.2.1 - function.prototype.name: 1.1.5 - get-intrinsic: 1.2.0 - get-symbol-description: 1.0.0 + function.prototype.name: 1.1.6 + get-intrinsic: 1.2.4 + get-symbol-description: 1.0.2 globalthis: 1.0.3 gopd: 1.0.1 - has: 1.0.3 - has-property-descriptors: 1.0.0 - has-proto: 1.0.1 + has-property-descriptors: 1.0.2 + has-proto: 1.0.3 has-symbols: 1.0.3 - internal-slot: 1.0.5 - is-array-buffer: 3.0.2 + hasown: 2.0.1 + internal-slot: 1.0.7 + is-array-buffer: 3.0.4 is-callable: 1.2.7 - is-negative-zero: 2.0.2 + is-negative-zero: 2.0.3 is-regex: 1.1.4 - is-shared-array-buffer: 1.0.2 + is-shared-array-buffer: 1.0.3 is-string: 1.0.7 - is-typed-array: 1.1.10 + is-typed-array: 1.1.13 is-weakref: 1.0.2 - object-inspect: 1.12.3 + object-inspect: 1.13.1 object-keys: 1.1.1 - object.assign: 4.1.4 - regexp.prototype.flags: 1.5.0 - safe-regex-test: 1.0.0 - string.prototype.trim: 1.2.7 - string.prototype.trimend: 1.0.6 - string.prototype.trimstart: 1.0.6 - typed-array-length: 1.0.4 + object.assign: 4.1.5 + regexp.prototype.flags: 1.5.2 + safe-array-concat: 1.1.0 + safe-regex-test: 1.0.3 + string.prototype.trim: 1.2.8 + string.prototype.trimend: 1.0.7 + string.prototype.trimstart: 1.0.7 + typed-array-buffer: 1.0.2 + typed-array-byte-length: 1.0.1 + typed-array-byte-offset: 1.0.2 + typed-array-length: 1.0.5 unbox-primitive: 1.0.2 - which-typed-array: 1.1.9 + which-typed-array: 1.1.14 + + /es-array-method-boxes-properly@1.0.0: + resolution: {integrity: sha512-wd6JXUmyHmt8T5a2xreUwKcGPq6f1f+WwIJkijUqiGcJz1qqnZgP6XIK+QyIWU5lT7imeNxUll48bziG+TSYcA==} + + /es-define-property@1.0.0: + resolution: {integrity: sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ==} + engines: {node: '>= 0.4'} + dependencies: + get-intrinsic: 1.2.4 + + /es-errors@1.3.0: + resolution: {integrity: sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==} + engines: {node: '>= 0.4'} - /es-array-method-boxes-properly@1.0.0: - resolution: {integrity: sha512-wd6JXUmyHmt8T5a2xreUwKcGPq6f1f+WwIJkijUqiGcJz1qqnZgP6XIK+QyIWU5lT7imeNxUll48bziG+TSYcA==} + /es-escape-html@0.1.1: + resolution: {integrity: sha512-yUx1o+8RsG7UlszmYPtks+dm6Lho2m8lgHMOsLJQsFI0R8XwUJwiMhM1M4E/S8QLeGyf6MkDV/pWgjQ0tdTSyQ==} + engines: {node: '>=12.x'} + dev: true /es-get-iterator@1.1.3: resolution: {integrity: sha512-sPZmqHBe6JIiTfN5q2pEi//TwxmAFHwj/XEuYjTuse78i8KxaqMTTzxPoFKuzRpDpTJ+0NAbpfenkmH2rePtuw==} dependencies: - call-bind: 1.0.2 - get-intrinsic: 1.2.1 + call-bind: 1.0.7 + get-intrinsic: 1.2.4 has-symbols: 1.0.3 is-arguments: 1.1.1 is-map: 2.0.2 @@ -4421,23 +7420,24 @@ packages: is-string: 1.0.7 isarray: 2.0.5 stop-iteration-iterator: 1.0.0 + dev: true - /es-module-lexer@1.2.1: - resolution: {integrity: sha512-9978wrXM50Y4rTMmW5kXIC09ZdXQZqkE4mxhwkd8VbzsGkXGPgV4zWuqQJgCEzYngdo2dYDa0l8xhX4fkSwJSg==} + /es-module-lexer@1.4.1: + resolution: {integrity: sha512-cXLGjP0c4T3flZJKQSuziYoq7MlT+rnvfZjfp7h+I7K9BNX54kP9nyWvdbwjQ4u1iWbOL4u96fgeZLToQlZC7w==} dev: false - /es-set-tostringtag@2.0.1: - resolution: {integrity: sha512-g3OMbtlwY3QewlqAiMLI47KywjWZoEytKr8pf6iTC8uJq5bIAH52Z9pnQ8pVL6whrCto53JZDuUIsifGeLorTg==} + /es-set-tostringtag@2.0.3: + resolution: {integrity: sha512-3T8uNMC3OQTHkFUsFq8r/BwAXLHvU/9O9mE0fBc/MY5iq/8H7ncvO947LmYA6ldWw9Uh8Yhf25zu6n7nML5QWQ==} engines: {node: '>= 0.4'} dependencies: - get-intrinsic: 1.2.0 - has: 1.0.3 - has-tostringtag: 1.0.0 + get-intrinsic: 1.2.4 + has-tostringtag: 1.0.2 + hasown: 2.0.1 - /es-shim-unscopables@1.0.0: - resolution: {integrity: sha512-Jm6GPcCdC30eMLbZ2x8z2WuRwAws3zTBBKuusffYVUrNj/GVSUAZ+xKMaUpfNDR5IbyNA5LJbaecoUVbmUcB1w==} + /es-shim-unscopables@1.0.2: + resolution: {integrity: sha512-J3yBRXCzDu4ULnQwxyToo/OjdMx6akgVC7K6few0a7F/0wLtmKKN7I73AH5T2836UuXRqN7Qg+IIUw/+YJksRw==} dependencies: - has: 1.0.3 + hasown: 2.0.1 dev: true /es-to-primitive@1.2.1: @@ -4448,14 +7448,79 @@ packages: is-date-object: 1.0.5 is-symbol: 1.0.4 + /es-vary@0.1.2: + resolution: {integrity: sha512-pLqqZoOutAXQXyBJrUYVNM5fZngiOJYi1Xl4svQMrluTsqDUOQlBMw9EYgLrsWL6niDYn/Yd1y2Pj6GC+j/yjA==} + engines: {node: '>=12.x'} + dev: true + /es6-error@4.1.1: resolution: {integrity: sha512-Um/+FxMr9CISWh0bi5Zv0iOD+4cFh5qLeks1qhAopKVAJw3drgKbKySikp7wGhDL0HPeaja0P5ULZrxLkniUVg==} dev: false - /escalade@3.1.1: - resolution: {integrity: sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==} + /esbuild@0.18.20: + resolution: {integrity: sha512-ceqxoedUrcayh7Y7ZX6NdbbDzGROiyVBgC4PriJThBKSVPWnnFHZAkfI1lJT8QFkOwH4qOS2SJkS4wvpGl8BpA==} + engines: {node: '>=12'} + hasBin: true + requiresBuild: true + optionalDependencies: + '@esbuild/android-arm': 0.18.20 + '@esbuild/android-arm64': 0.18.20 + '@esbuild/android-x64': 0.18.20 + '@esbuild/darwin-arm64': 0.18.20 + '@esbuild/darwin-x64': 0.18.20 + '@esbuild/freebsd-arm64': 0.18.20 + '@esbuild/freebsd-x64': 0.18.20 + '@esbuild/linux-arm': 0.18.20 + '@esbuild/linux-arm64': 0.18.20 + '@esbuild/linux-ia32': 0.18.20 + '@esbuild/linux-loong64': 0.18.20 + '@esbuild/linux-mips64el': 0.18.20 + '@esbuild/linux-ppc64': 0.18.20 + '@esbuild/linux-riscv64': 0.18.20 + '@esbuild/linux-s390x': 0.18.20 + '@esbuild/linux-x64': 0.18.20 + '@esbuild/netbsd-x64': 0.18.20 + '@esbuild/openbsd-x64': 0.18.20 + '@esbuild/sunos-x64': 0.18.20 + '@esbuild/win32-arm64': 0.18.20 + '@esbuild/win32-ia32': 0.18.20 + '@esbuild/win32-x64': 0.18.20 + dev: true + + /esbuild@0.19.12: + resolution: {integrity: sha512-aARqgq8roFBj054KvQr5f1sFu0D65G+miZRCuJyJ0G13Zwx7vRar5Zhn2tkQNzIXcBrNVsv/8stehpj+GAjgbg==} + engines: {node: '>=12'} + hasBin: true + requiresBuild: true + optionalDependencies: + '@esbuild/aix-ppc64': 0.19.12 + '@esbuild/android-arm': 0.19.12 + '@esbuild/android-arm64': 0.19.12 + '@esbuild/android-x64': 0.19.12 + '@esbuild/darwin-arm64': 0.19.12 + '@esbuild/darwin-x64': 0.19.12 + '@esbuild/freebsd-arm64': 0.19.12 + '@esbuild/freebsd-x64': 0.19.12 + '@esbuild/linux-arm': 0.19.12 + '@esbuild/linux-arm64': 0.19.12 + '@esbuild/linux-ia32': 0.19.12 + '@esbuild/linux-loong64': 0.19.12 + '@esbuild/linux-mips64el': 0.19.12 + '@esbuild/linux-ppc64': 0.19.12 + '@esbuild/linux-riscv64': 0.19.12 + '@esbuild/linux-s390x': 0.19.12 + '@esbuild/linux-x64': 0.19.12 + '@esbuild/netbsd-x64': 0.19.12 + '@esbuild/openbsd-x64': 0.19.12 + '@esbuild/sunos-x64': 0.19.12 + '@esbuild/win32-arm64': 0.19.12 + '@esbuild/win32-ia32': 0.19.12 + '@esbuild/win32-x64': 0.19.12 + dev: true + + /escalade@3.1.2: + resolution: {integrity: sha512-ErCHMCae19vR8vQGe50xIsVomy19rg6gFu3+r3jkEO46suLMWBksvVyoGgQV+jOfl84ZSOSlmv6Gxa89PmTGmA==} engines: {node: '>=6'} - dev: false /escape-goat@4.0.0: resolution: {integrity: sha512-2Sd4ShcWxbx6OY1IHyla/CVNwvg7XwZVoXZHcSu9w9SReNP1EzzD5T8NWKIR38fIqEns9kDWKUQTXXAmlDrdPg==} @@ -4470,6 +7535,11 @@ packages: resolution: {integrity: sha512-vbRorB5FUQWvla16U8R/qgaFIya2qGzwDrNmCZuYKrbdSUMG6I1ZCGQRefkRVhuOkIGVne7BQ35DSfo1qvJqFg==} engines: {node: '>=0.8.0'} + /escape-string-regexp@2.0.0: + resolution: {integrity: sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==} + engines: {node: '>=8'} + dev: true + /escape-string-regexp@4.0.0: resolution: {integrity: sha512-TtpcNJ3XAzx3Gq8sWRzJaVajRs0uVxA2YAkdb1jm2YkPz4G6egUFAyA3n5vtEIZefPk5Wa4UXbKuS5fKkJWdgA==} engines: {node: '>=10'} @@ -4492,16 +7562,25 @@ packages: source-map: 0.6.1 dev: true - /eslint-config-prettier@9.0.0(eslint@8.47.0): - resolution: {integrity: sha512-IcJsTkJae2S35pRsRAwoCE+925rJJStOdkKnLVgtE+tEpqU0EVVM7OqrwxqgptKdX29NUwC82I5pXsGFIgSevw==} + /eslint-compat-utils@0.1.2(eslint@8.57.0): + resolution: {integrity: sha512-Jia4JDldWnFNIru1Ehx1H5s9/yxiRHY/TimCuUc0jNexew3cF1gI6CYZil1ociakfWO3rRqFjl1mskBblB3RYg==} + engines: {node: '>=12'} + peerDependencies: + eslint: '>=6.0.0' + dependencies: + eslint: 8.57.0 + dev: true + + /eslint-config-prettier@9.1.0(eslint@8.57.0): + resolution: {integrity: sha512-NSWl5BFQWEPi1j4TjVNItzYV7dZXZ+wP6I6ZhrBGpChQhZRUaElihE9uRRkcbRnNb76UMKDF3r+WTmNcGPKsqw==} hasBin: true peerDependencies: eslint: '>=7.0.0' dependencies: - eslint: 8.47.0 + eslint: 8.57.0 dev: true - /eslint-config-standard@17.1.0(eslint-plugin-import@2.28.0)(eslint-plugin-n@15.7.0)(eslint-plugin-promise@6.1.1)(eslint@8.47.0): + /eslint-config-standard@17.1.0(eslint-plugin-import@2.29.1)(eslint-plugin-n@16.6.2)(eslint-plugin-promise@6.1.1)(eslint@8.57.0): resolution: {integrity: sha512-IwHwmaBNtDK4zDHQukFDW5u/aTb8+meQWZvNFWkiGmbWjD6bqyuSSBxxXKkCftCUzc1zwCH2m/baCNDLGmuO5Q==} engines: {node: '>=12.0.0'} peerDependencies: @@ -4510,33 +7589,33 @@ packages: eslint-plugin-n: '^15.0.0 || ^16.0.0 ' eslint-plugin-promise: ^6.0.0 dependencies: - eslint: 8.47.0 - eslint-plugin-import: 2.28.0(eslint@8.47.0) - eslint-plugin-n: 15.7.0(eslint@8.47.0) - eslint-plugin-promise: 6.1.1(eslint@8.47.0) + eslint: 8.57.0 + eslint-plugin-import: 2.29.1(eslint@8.57.0) + eslint-plugin-n: 16.6.2(eslint@8.57.0) + eslint-plugin-promise: 6.1.1(eslint@8.57.0) dev: true - /eslint-config-turbo@1.10.12(eslint@8.47.0): - resolution: {integrity: sha512-z3jfh+D7UGYlzMWGh+Kqz++hf8LOE96q3o5R8X4HTjmxaBWlLAWG+0Ounr38h+JLR2TJno0hU9zfzoPNkR9BdA==} + /eslint-config-turbo@1.12.4(eslint@8.57.0): + resolution: {integrity: sha512-5hqEaV6PNmAYLL4RTmq74OcCt8pgzOLnfDVPG/7PUXpQ0Mpz0gr926oCSFukywKKXjdum3VHD84S7Z9A/DqTAw==} peerDependencies: eslint: '>6.6.0' dependencies: - eslint: 8.47.0 - eslint-plugin-turbo: 1.10.12(eslint@8.47.0) + eslint: 8.57.0 + eslint-plugin-turbo: 1.12.4(eslint@8.57.0) dev: true - /eslint-import-resolver-node@0.3.7: - resolution: {integrity: sha512-gozW2blMLJCeFpBwugLTGyvVjNoeo1knonXAcatC6bjPBZitotxdWf7Gimr25N4c0AAOo4eOUfaG82IJPDpqCA==} + /eslint-import-resolver-node@0.3.9: + resolution: {integrity: sha512-WFj2isz22JahUv+B788TlO3N6zL3nNJGU8CcZbPZvVEkBPaJdCV4vy5wyghty5ROFbCRnm132v8BScu5/1BQ8g==} dependencies: debug: 3.2.7(supports-color@8.1.1) - is-core-module: 2.12.1 - resolve: 1.22.2 + is-core-module: 2.13.1 + resolve: 1.22.8 transitivePeerDependencies: - supports-color dev: true - /eslint-module-utils@2.8.0(eslint-import-resolver-node@0.3.7)(eslint@8.47.0): - resolution: {integrity: sha512-aWajIYfsqCKRDgUfjEXNN/JlrzauMuSEy5sbd7WXbtW3EH6A6MpwEh42c7qD+MqQo9QMJ6fWLAeIJynx0g6OAw==} + /eslint-module-utils@2.8.1(eslint-import-resolver-node@0.3.9)(eslint@8.57.0): + resolution: {integrity: sha512-rXDXR3h7cs7dy9RNpUlQf80nX31XWJEyGq1tRMo+6GsO5VmTe4UTwtmonAD4ZkAsrfMVDA2wlGJ3790Ys+D49Q==} engines: {node: '>=4'} peerDependencies: '@typescript-eslint/parser': '*' @@ -4557,54 +7636,66 @@ packages: optional: true dependencies: debug: 3.2.7(supports-color@8.1.1) - eslint: 8.47.0 - eslint-import-resolver-node: 0.3.7 + eslint: 8.57.0 + eslint-import-resolver-node: 0.3.9 transitivePeerDependencies: - supports-color dev: true - /eslint-plugin-chai-friendly@0.7.2(eslint@8.47.0): - resolution: {integrity: sha512-LOIfGx5sZZ5FwM1shr2GlYAWV9Omdi+1/3byuVagvQNoGUuU0iHhp7AfjA1uR+4dJ4Isfb4+FwBJgQajIw9iAg==} + /eslint-plugin-chai-friendly@0.7.4(eslint@8.57.0): + resolution: {integrity: sha512-PGPjJ8diYgX1mjLxGJqRop2rrGwZRKImoEOwUOgoIhg0p80MkTaqvmFLe5TF7/iagZHggasvIfQlUyHIhK/PYg==} engines: {node: '>=0.10.0'} peerDependencies: eslint: '>=3.0.0' dependencies: - eslint: 8.47.0 + eslint: 8.57.0 dev: true - /eslint-plugin-cypress@2.14.0(eslint@8.47.0): - resolution: {integrity: sha512-eW6tv7iIg7xujleAJX4Ujm649Bf5jweqa4ObPEIuueYRyLZt7qXGWhCY/n4bfeFW/j6nQZwbIBHKZt6EKcL/cg==} + /eslint-plugin-cypress@2.15.1(eslint@8.57.0): + resolution: {integrity: sha512-eLHLWP5Q+I4j2AWepYq0PgFEei9/s5LvjuSqWrxurkg1YZ8ltxdvMNmdSf0drnsNo57CTgYY/NIHHLRSWejR7w==} peerDependencies: eslint: '>= 3.2.1' dependencies: - eslint: 8.47.0 - globals: 13.20.0 + eslint: 8.57.0 + globals: 13.24.0 + dev: true + + /eslint-plugin-es-x@7.5.0(eslint@8.57.0): + resolution: {integrity: sha512-ODswlDSO0HJDzXU0XvgZ3lF3lS3XAZEossh15Q2UHjwrJggWeBoKqqEsLTZLXl+dh5eOAozG0zRcYtuE35oTuQ==} + engines: {node: ^14.18.0 || >=16.0.0} + peerDependencies: + eslint: '>=8' + dependencies: + '@eslint-community/eslint-utils': 4.4.0(eslint@8.57.0) + '@eslint-community/regexpp': 4.10.0 + eslint: 8.57.0 + eslint-compat-utils: 0.1.2(eslint@8.57.0) dev: true - /eslint-plugin-es@3.0.1(eslint@8.47.0): + /eslint-plugin-es@3.0.1(eslint@8.57.0): resolution: {integrity: sha512-GUmAsJaN4Fc7Gbtl8uOBlayo2DqhwWvEzykMHSCZHU3XdJ+NSzzZcVhXh3VxX5icqQ+oQdIEawXX8xkR3mIFmQ==} engines: {node: '>=8.10.0'} peerDependencies: eslint: '>=4.19.1' dependencies: - eslint: 8.47.0 + eslint: 8.57.0 eslint-utils: 2.1.0 regexpp: 3.2.0 dev: true - /eslint-plugin-es@4.1.0(eslint@8.47.0): - resolution: {integrity: sha512-GILhQTnjYE2WorX5Jyi5i4dz5ALWxBIdQECVQavL6s7cI76IZTDWleTHkxz/QT3kvcs2QlGHvKLYsSlPOlPXnQ==} - engines: {node: '>=8.10.0'} + /eslint-plugin-eslint-comments@3.2.0(eslint@8.57.0): + resolution: {integrity: sha512-0jkOl0hfojIHHmEHgmNdqv4fmh7300NdpA9FFpF7zaoLvB/QeXOGNLIo86oAveJFrfB1p05kC8hpEMHM8DwWVQ==} + engines: {node: '>=6.5.0'} peerDependencies: eslint: '>=4.19.1' dependencies: - eslint: 8.47.0 - eslint-utils: 2.1.0 - regexpp: 3.2.0 + escape-string-regexp: 1.0.5 + eslint: 8.57.0 + ignore: 5.3.1 dev: true - /eslint-plugin-import@2.28.0(eslint@8.47.0): - resolution: {integrity: sha512-B8s/n+ZluN7sxj9eUf7/pRFERX0r5bnFA2dCaLHy2ZeaQEAz0k+ZZkFWRFHJAqxfxQDx6KLv9LeIki7cFdwW+Q==} + /eslint-plugin-import@2.29.1(eslint@8.57.0): + resolution: {integrity: sha512-BbPC0cuExzhiMo4Ff1BTVwHpjjv28C5R+btTOGaCRC7UEz801up0JadwkeSk5Ued6TG34uaczuVuH6qyy5YUxw==} engines: {node: '>=4'} peerDependencies: '@typescript-eslint/parser': '*' @@ -4613,65 +7704,67 @@ packages: '@typescript-eslint/parser': optional: true dependencies: - array-includes: 3.1.6 - array.prototype.findlastindex: 1.2.2 - array.prototype.flat: 1.3.1 - array.prototype.flatmap: 1.3.1 + array-includes: 3.1.7 + array.prototype.findlastindex: 1.2.4 + array.prototype.flat: 1.3.2 + array.prototype.flatmap: 1.3.2 debug: 3.2.7(supports-color@8.1.1) doctrine: 2.1.0 - eslint: 8.47.0 - eslint-import-resolver-node: 0.3.7 - eslint-module-utils: 2.8.0(eslint-import-resolver-node@0.3.7)(eslint@8.47.0) - has: 1.0.3 - is-core-module: 2.12.1 + eslint: 8.57.0 + eslint-import-resolver-node: 0.3.9 + eslint-module-utils: 2.8.1(eslint-import-resolver-node@0.3.9)(eslint@8.57.0) + hasown: 2.0.1 + is-core-module: 2.13.1 is-glob: 4.0.3 minimatch: 3.1.2 - object.fromentries: 2.0.6 - object.groupby: 1.0.0 - object.values: 1.1.6 - resolve: 1.22.3 + object.fromentries: 2.0.7 + object.groupby: 1.0.2 + object.values: 1.1.7 semver: 6.3.1 - tsconfig-paths: 3.14.2 + tsconfig-paths: 3.15.0 transitivePeerDependencies: - eslint-import-resolver-typescript - eslint-import-resolver-webpack - supports-color dev: true - /eslint-plugin-n@15.7.0(eslint@8.47.0): - resolution: {integrity: sha512-jDex9s7D/Qial8AGVIHq4W7NswpUD5DPDL2RH8Lzd9EloWUuvUkHfv4FRLMipH5q2UtyurorBkPeNi1wVWNh3Q==} - engines: {node: '>=12.22.0'} + /eslint-plugin-n@16.6.2(eslint@8.57.0): + resolution: {integrity: sha512-6TyDmZ1HXoFQXnhCTUjVFULReoBPOAjpuiKELMkeP40yffI/1ZRO+d9ug/VC6fqISo2WkuIBk3cvuRPALaWlOQ==} + engines: {node: '>=16.0.0'} peerDependencies: eslint: '>=7.0.0' dependencies: + '@eslint-community/eslint-utils': 4.4.0(eslint@8.57.0) builtins: 5.0.1 - eslint: 8.47.0 - eslint-plugin-es: 4.1.0(eslint@8.47.0) - eslint-utils: 3.0.0(eslint@8.47.0) - ignore: 5.2.4 - is-core-module: 2.12.1 + eslint: 8.57.0 + eslint-plugin-es-x: 7.5.0(eslint@8.57.0) + get-tsconfig: 4.7.2 + globals: 13.24.0 + ignore: 5.3.1 + is-builtin-module: 3.2.1 + is-core-module: 2.13.1 minimatch: 3.1.2 - resolve: 1.22.3 - semver: 7.5.4 + resolve: 1.22.8 + semver: 7.6.0 dev: true - /eslint-plugin-node@11.1.0(eslint@8.47.0): + /eslint-plugin-node@11.1.0(eslint@8.57.0): resolution: {integrity: sha512-oUwtPJ1W0SKD0Tr+wqu92c5xuCeQqB3hSCHasn/ZgjFdA9iDGNkNf2Zi9ztY7X+hNuMib23LNGRm6+uN+KLE3g==} engines: {node: '>=8.10.0'} peerDependencies: eslint: '>=5.16.0' dependencies: - eslint: 8.47.0 - eslint-plugin-es: 3.0.1(eslint@8.47.0) + eslint: 8.57.0 + eslint-plugin-es: 3.0.1(eslint@8.57.0) eslint-utils: 2.1.0 - ignore: 5.2.4 + ignore: 5.3.1 minimatch: 3.1.2 - resolve: 1.22.2 - semver: 6.3.0 + resolve: 1.22.8 + semver: 6.3.1 dev: true - /eslint-plugin-prettier@5.0.0(eslint-config-prettier@9.0.0)(eslint@8.47.0)(prettier@3.0.2): - resolution: {integrity: sha512-AgaZCVuYDXHUGxj/ZGu1u8H8CYgDY3iG6w5kUFw4AzMVXzB7VvbKgYR4nATIN+OvUrghMbiDLeimVjVY5ilq3w==} + /eslint-plugin-prettier@5.1.3(eslint-config-prettier@9.1.0)(eslint@8.57.0)(prettier@3.2.5): + resolution: {integrity: sha512-C9GCVAs4Eq7ZC/XFQHITLiHJxQngdtraXaM+LoUFoFp/lHNl2Zn8f3WQbe9HvTBBQ9YnKFB0/2Ajdqwo5D1EAw==} engines: {node: ^14.18.0 || >=16.0.0} peerDependencies: '@types/eslint': '>=8.0.0' @@ -4684,76 +7777,93 @@ packages: eslint-config-prettier: optional: true dependencies: - eslint: 8.47.0 - eslint-config-prettier: 9.0.0(eslint@8.47.0) - prettier: 3.0.2 + eslint: 8.57.0 + eslint-config-prettier: 9.1.0(eslint@8.57.0) + prettier: 3.2.5 prettier-linter-helpers: 1.0.0 - synckit: 0.8.5 + synckit: 0.8.8 dev: true - /eslint-plugin-promise@6.1.1(eslint@8.47.0): + /eslint-plugin-promise@6.1.1(eslint@8.57.0): resolution: {integrity: sha512-tjqWDwVZQo7UIPMeDReOpUgHCmCiH+ePnVT+5zVapL0uuHnegBUs2smM13CzOs2Xb5+MHMRFTs9v24yjba4Oig==} engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} peerDependencies: eslint: ^7.0.0 || ^8.0.0 dependencies: - eslint: 8.47.0 + eslint: 8.57.0 + dev: true + + /eslint-plugin-react-hooks@4.6.0(eslint@8.57.0): + resolution: {integrity: sha512-oFc7Itz9Qxh2x4gNHStv3BqJq54ExXmfC+a1NjAta66IAN87Wu0R/QArgIS9qKzX3dXKPI9H5crl9QchNMY9+g==} + engines: {node: '>=10'} + peerDependencies: + eslint: ^3.0.0 || ^4.0.0 || ^5.0.0 || ^6.0.0 || ^7.0.0 || ^8.0.0-0 + dependencies: + eslint: 8.57.0 + dev: true + + /eslint-plugin-react-refresh@0.4.5(eslint@8.57.0): + resolution: {integrity: sha512-D53FYKJa+fDmZMtriODxvhwrO+IOqrxoEo21gMA0sjHdU6dPVH4OhyFip9ypl8HOF5RV5KdTo+rBQLvnY2cO8w==} + peerDependencies: + eslint: '>=7' + dependencies: + eslint: 8.57.0 dev: true - /eslint-plugin-standard@4.1.0(eslint@8.47.0): + /eslint-plugin-standard@4.1.0(eslint@8.57.0): resolution: {integrity: sha512-ZL7+QRixjTR6/528YNGyDotyffm5OQst/sGxKDwGb9Uqs4In5Egi4+jbobhqJoyoCM6/7v/1A5fhQ7ScMtDjaQ==} peerDependencies: eslint: '>=5.0.0' dependencies: - eslint: 8.47.0 + eslint: 8.57.0 dev: true - /eslint-plugin-testing-library@6.0.0(eslint@8.47.0)(typescript@5.0.4): - resolution: {integrity: sha512-SHeisSxG1f6UV2wKdMuQBiTTmGEQ858H7LMyz1LG+30TxPQEcXXQauC4E6sfEdcrJ/nIOUxNmlFZdlL6PNK4mg==} + /eslint-plugin-testing-library@6.2.0(eslint@8.57.0)(typescript@5.3.3): + resolution: {integrity: sha512-+LCYJU81WF2yQ+Xu4A135CgK8IszcFcyMF4sWkbiu6Oj+Nel0TrkZq/HvDw0/1WuO3dhDQsZA/OpEMGd0NfcUw==} engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0, npm: '>=6'} peerDependencies: eslint: ^7.5.0 || ^8.0.0 dependencies: - '@typescript-eslint/utils': 5.59.2(eslint@8.47.0)(typescript@5.0.4) - eslint: 8.47.0 + '@typescript-eslint/utils': 5.62.0(eslint@8.57.0)(typescript@5.3.3) + eslint: 8.57.0 transitivePeerDependencies: - supports-color - typescript dev: true - /eslint-plugin-turbo@1.10.12(eslint@8.47.0): - resolution: {integrity: sha512-uNbdj+ohZaYo4tFJ6dStRXu2FZigwulR1b3URPXe0Q8YaE7thuekKNP+54CHtZPH9Zey9dmDx5btAQl9mfzGOw==} + /eslint-plugin-turbo@1.12.4(eslint@8.57.0): + resolution: {integrity: sha512-3AGmXvH7E4i/XTWqBrcgu+G7YKZJV/8FrEn79kTd50ilNsv+U3nS2IlcCrQB6Xm2m9avGD9cadLzKDR1/UF2+g==} peerDependencies: eslint: '>6.6.0' dependencies: dotenv: 16.0.3 - eslint: 8.47.0 + eslint: 8.57.0 dev: true - /eslint-plugin-ui-testing@2.0.1(eslint@8.47.0)(typescript@5.0.4): + /eslint-plugin-ui-testing@2.0.1(eslint@8.57.0)(typescript@5.3.3): resolution: {integrity: sha512-GpvE0u03GSytsJ/K49C2dJlvDKQSfh+PX4lAEjBIc5RxUWEpGf9/jY3JTFd7F0gQ9ElGfYskJceVKyz7knbFFw==} engines: {node: ^10.12.0 || >=12.0.0, npm: '>=6'} peerDependencies: eslint: '>= 7' dependencies: - '@typescript-eslint/experimental-utils': 5.59.2(eslint@8.47.0)(typescript@5.0.4) - eslint: 8.47.0 + '@typescript-eslint/experimental-utils': 5.62.0(eslint@8.57.0)(typescript@5.3.3) + eslint: 8.57.0 transitivePeerDependencies: - supports-color - typescript dev: true - /eslint-plugin-unicorn@48.0.1(eslint@8.47.0): + /eslint-plugin-unicorn@48.0.1(eslint@8.57.0): resolution: {integrity: sha512-FW+4r20myG/DqFcCSzoumaddKBicIPeFnTrifon2mWIzlfyvzwyqZjqVP7m4Cqr/ZYisS2aiLghkUWaPg6vtCw==} engines: {node: '>=16'} peerDependencies: eslint: '>=8.44.0' dependencies: - '@babel/helper-validator-identifier': 7.22.5 - '@eslint-community/eslint-utils': 4.4.0(eslint@8.47.0) - ci-info: 3.8.0 + '@babel/helper-validator-identifier': 7.22.20 + '@eslint-community/eslint-utils': 4.4.0(eslint@8.57.0) + ci-info: 3.9.0 clean-regexp: 1.0.0 - eslint: 8.47.0 + eslint: 8.57.0 esquery: 1.5.0 indent-string: 4.0.0 is-builtin-module: 3.2.1 @@ -4763,7 +7873,7 @@ packages: read-pkg-up: 7.0.1 regexp-tree: 0.1.27 regjsparser: 0.10.0 - semver: 7.5.4 + semver: 7.6.0 strip-indent: 3.0.0 dev: true @@ -4789,48 +7899,29 @@ packages: eslint-visitor-keys: 1.3.0 dev: true - /eslint-utils@3.0.0(eslint@8.47.0): - resolution: {integrity: sha512-uuQC43IGctw68pJA1RgbQS8/NP7rch6Cwd4j3ZBtgo4/8Flj4eGE7ZYSZRN3iq5pVUv6GPdW5Z1RFleo84uLDA==} - engines: {node: ^10.0.0 || ^12.0.0 || >= 14.0.0} - peerDependencies: - eslint: '>=5' - dependencies: - eslint: 8.47.0 - eslint-visitor-keys: 2.1.0 - dev: true - /eslint-visitor-keys@1.3.0: resolution: {integrity: sha512-6J72N8UNa462wa/KFODt/PJ3IU60SDpC3QXC1Hjc1BXXpfL2C9R5+AU7jhe0F6GREqVMh4Juu+NY7xn+6dipUQ==} engines: {node: '>=4'} dev: true - /eslint-visitor-keys@2.1.0: - resolution: {integrity: sha512-0rSmRBzXgDzIsD6mGdJgevzgezI534Cer5L/vyMX0kHzT/jiB43jRhd9YUlMGYLQy2zprNmoT8qasCGtY+QaKw==} - engines: {node: '>=10'} - dev: true - - /eslint-visitor-keys@3.4.2: - resolution: {integrity: sha512-8drBzUEyZ2llkpCA67iYrgEssKDUu68V8ChqqOfFupIaG/LCVPUT+CoGJpT77zJprs4T/W7p07LP7zAIMuweVw==} - engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} - dev: true - /eslint-visitor-keys@3.4.3: resolution: {integrity: sha512-wpc+LXeiyiisxPlEkUzU6svyS1frIO3Mgxj1fdy7Pm8Ygzguax2N3Fa/D/ag1WqbOprdI+uY6wMUl8/a2G+iag==} engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} dev: true - /eslint@8.47.0: - resolution: {integrity: sha512-spUQWrdPt+pRVP1TTJLmfRNJJHHZryFmptzcafwSvHsceV81djHOdnEeDmkdotZyLNjDhrOasNK8nikkoG1O8Q==} + /eslint@8.57.0: + resolution: {integrity: sha512-dZ6+mexnaTIbSBZWgou51U6OmzIhYM2VcNdtiTtI7qPNZm35Akpr0f6vtw3w1Kmn5PYo+tZVfh13WrhpS6oLqQ==} engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} hasBin: true dependencies: - '@eslint-community/eslint-utils': 4.4.0(eslint@8.47.0) - '@eslint-community/regexpp': 4.6.2 - '@eslint/eslintrc': 2.1.2 - '@eslint/js': 8.47.0 - '@humanwhocodes/config-array': 0.11.10 + '@eslint-community/eslint-utils': 4.4.0(eslint@8.57.0) + '@eslint-community/regexpp': 4.10.0 + '@eslint/eslintrc': 2.1.4 + '@eslint/js': 8.57.0 + '@humanwhocodes/config-array': 0.11.14 '@humanwhocodes/module-importer': 1.0.1 '@nodelib/fs.walk': 1.2.8 + '@ungap/structured-clone': 1.2.0 ajv: 6.12.6 chalk: 4.1.2 cross-spawn: 7.0.3 @@ -4846,9 +7937,9 @@ packages: file-entry-cache: 6.0.1 find-up: 5.0.0 glob-parent: 6.0.2 - globals: 13.20.0 + globals: 13.24.0 graphemer: 1.4.0 - ignore: 5.2.4 + ignore: 5.3.1 imurmurhash: 0.1.4 is-glob: 4.0.3 is-path-inside: 3.0.3 @@ -4869,8 +7960,8 @@ packages: resolution: {integrity: sha512-oruZaFkjorTpF32kDSI5/75ViwGeZginGGy2NoOSg3Q9bnwlnmDm4HLnkl0RE3n+njDXR037aY1+x58Z/zFdwQ==} engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} dependencies: - acorn: 8.10.0 - acorn-jsx: 5.3.2(acorn@8.10.0) + acorn: 8.11.3 + acorn-jsx: 5.3.2(acorn@8.11.3) eslint-visitor-keys: 3.4.3 dev: true @@ -4900,22 +7991,41 @@ packages: resolution: {integrity: sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==} engines: {node: '>=4.0'} + /estree-walker@1.0.1: + resolution: {integrity: sha512-1fMXF3YP4pZZVozF8j/ZLfvnR8NSIljt56UhbZ5PeeDmmGHpgpdwQt7ITlGvYaQukCvuBRMLEiKiYC+oeIg4cg==} + dev: true + + /estree-walker@2.0.2: + resolution: {integrity: sha512-Rfkk/Mp/DL7JVje3u18FxFujQlTNR2q6QfMSMB7AvCBx91NGj/ba3kCfza0f6dVDbw7YlRf/nDrn7pQrCCyQ/w==} + dev: true + + /estree-walker@3.0.3: + resolution: {integrity: sha512-7RUKfXgSMMkzt6ZuXmqapOurLGPPfgj6l9uRZ7lRGolvk0y2yocc35LdcxKC5PQZdn2DMqioAQ2NoWcrTKmm6g==} + dependencies: + '@types/estree': 1.0.5 + dev: true + /esutils@2.0.3: resolution: {integrity: sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==} engines: {node: '>=0.10.0'} + /eta@3.2.0: + resolution: {integrity: sha512-Qzc3it7nLn49dbOb9+oHV9rwtt9qN8oShRztqkZ3gXPqQflF0VLin5qhWk0g/2ioibBwT4DU6OIMVft7tg/rVg==} + engines: {node: '>=6.0.0'} + dev: true + /etag@1.8.1: resolution: {integrity: sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==} engines: {node: '>= 0.6'} dev: false - /ethers@6.7.1: - resolution: {integrity: sha512-qX5kxIFMfg1i+epfgb0xF4WM7IqapIIu50pOJ17aebkxxa4BacW5jFrQRmCJpDEg2ZK2oNtR5QjrQ1WDBF29dA==} + /ethers@6.11.1: + resolution: {integrity: sha512-mxTAE6wqJQAbp5QAe/+o+rXOID7Nw91OZXvgpjDa1r4fAbq2Nu314oEZSbjoRLacuCzs7kUC3clEvkCQowffGg==} engines: {node: '>=14.0.0'} dependencies: - '@adraffy/ens-normalize': 1.9.2 - '@noble/hashes': 1.1.2 - '@noble/secp256k1': 1.7.1 + '@adraffy/ens-normalize': 1.10.1 + '@noble/curves': 1.2.0 + '@noble/hashes': 1.3.2 '@types/node': 18.15.13 aes-js: 4.0.0-beta.5 tslib: 2.4.0 @@ -4935,6 +8045,10 @@ packages: - debug dev: false + /event-lite@0.1.3: + resolution: {integrity: sha512-8qz9nOz5VeD2z96elrEKD2U433+L3DWdUdDkOINLGOJvx1GsMBbMn0aCeu28y8/e85A6mCigBiFlYMnTBEGlSw==} + dev: true + /event-stream@3.3.4: resolution: {integrity: sha512-QHpkERcGsR0T7Qm3HNJSyXKEEj8AHNxkY3PK8TS2KJvQ7NiSHe3DDpwVKKtoYprL/AreyzFBeIkBIWChAqn60g==} dependencies: @@ -4989,8 +8103,8 @@ packages: signal-exit: 3.0.7 strip-final-newline: 2.0.0 - /execa@7.1.1: - resolution: {integrity: sha512-wH0eMf/UXckdUYnO21+HDztteVv05rq2GXksxT4fCGeHkBhw1DROXh40wcjMcRqDOWE7iPJ4n3M7e2+YFP+76Q==} + /execa@7.2.0: + resolution: {integrity: sha512-UduyVP7TLB5IcAQl+OzLyLcS/l32W/GLg+AhHJ+ow40FOk2U3SAllPwR44v4vmdFwIWqpdwxxpQbF1n5ta9seA==} engines: {node: ^14.18.0 || ^16.14.0 || >=18.0.0} dependencies: cross-spawn: 7.0.3 @@ -4998,24 +8112,23 @@ packages: human-signals: 4.3.1 is-stream: 3.0.0 merge-stream: 2.0.0 - npm-run-path: 5.1.0 + npm-run-path: 5.3.0 onetime: 6.0.0 signal-exit: 3.0.7 strip-final-newline: 3.0.0 - dev: false - /execa@7.2.0: - resolution: {integrity: sha512-UduyVP7TLB5IcAQl+OzLyLcS/l32W/GLg+AhHJ+ow40FOk2U3SAllPwR44v4vmdFwIWqpdwxxpQbF1n5ta9seA==} - engines: {node: ^14.18.0 || ^16.14.0 || >=18.0.0} + /execa@8.0.1: + resolution: {integrity: sha512-VyhnebXciFV2DESc+p6B+y0LjSm0krU4OgJN44qFAhBY0TJ+1V61tYD2+wHusZ6F9n5K+vl8k0sTy7PEfV4qpg==} + engines: {node: '>=16.17'} dependencies: cross-spawn: 7.0.3 - get-stream: 6.0.1 - human-signals: 4.3.1 + get-stream: 8.0.1 + human-signals: 5.0.0 is-stream: 3.0.0 merge-stream: 2.0.0 - npm-run-path: 5.1.0 + npm-run-path: 5.3.0 onetime: 6.0.0 - signal-exit: 3.0.7 + signal-exit: 4.1.0 strip-final-newline: 3.0.0 dev: true @@ -5026,6 +8139,15 @@ packages: pify: 2.3.0 dev: false + /expand-template@2.0.3: + resolution: {integrity: sha512-XYfuKMvj4O35f/pOXLObndIRvyQ+/+6AhODh+OKWj9S9498pHHn/IMszH+gt0fBCRWMNfk1ZSp5x3AifmnI2vg==} + engines: {node: '>=6'} + dev: true + + /exponential-backoff@3.1.1: + resolution: {integrity: sha512-dX7e/LHVJ6W3DE1MHWi9S1EYzDESENfLrYohG2G++ovZrYOkm4Knwa0mc1cn84xJOR4KEU0WSchhLbd0UklbHw==} + dev: true + /express@4.18.2: resolution: {integrity: sha512-5/PsL6iGPdfQ/lKM1UuielYgv3BUoJfz1aUwU9vHZ+J7gyvwdQXFEBIEIaxeGf0GIcreATNyBExtalisDbuMqQ==} engines: {node: '>= 0.10.0'} @@ -5102,36 +8224,35 @@ packages: get-stream: 5.2.0 yauzl: 2.10.0 optionalDependencies: - '@types/yauzl': 2.10.0 + '@types/yauzl': 2.10.3 transitivePeerDependencies: - supports-color - dev: false /extsprintf@1.3.0: resolution: {integrity: sha512-11Ndz7Nv+mvAC1j0ktTa7fAb0vLyGGX+rMHNBYQviQDGU0Hw7lhctJANqbPhu9nV9/izT/IntTgZ7Im/9LJs9g==} engines: {'0': node >=0.6.0} dev: false + /fast-check@3.15.1: + resolution: {integrity: sha512-GutOXZ+SCxGaFWfHe0Pbeq8PrkpGtPxA9/hdkI3s9YzqeMlrq5RdJ+QfYZ/S93jMX+tAyqgW0z5c9ppD+vkGUw==} + engines: {node: '>=8.0.0'} + dependencies: + pure-rand: 6.0.4 + dev: true + /fast-deep-equal@3.1.3: resolution: {integrity: sha512-f3qQ9oQy9j2AhBe/H9VC91wLmKBCCU/gDOnKNAYG5hswO7BLKj09Hc5HYNz9cGI++xlpDCIgDaitVs03ATR84Q==} - /fast-diff@1.2.0: - resolution: {integrity: sha512-xJuoT5+L99XlZ8twedaRf6Ax2TgQVxvgZOYoPKqZufmJib0tL2tegPBOZb1pVNgIhlqDlA0eO0c3wBvQcmzx4w==} + /fast-diff@1.3.0: + resolution: {integrity: sha512-VxPP4NqbUjj6MaAOafWeUn2cXWLcCtljklUtZf0Ind4XQ+QPtmA0b18zZy0jIQx+ExRVCR/ZQpBmik5lXshNsw==} dev: true - /fast-glob@3.2.12: - resolution: {integrity: sha512-DVj4CQIYYow0BlaelwK1pHl5n5cRSJfM60UA0zK891sVInoPri2Ekj7+e1CT3/3qxXenpI+nBBmQAcJPJgaj4w==} - engines: {node: '>=8.6.0'} - dependencies: - '@nodelib/fs.stat': 2.0.5 - '@nodelib/fs.walk': 1.2.8 - glob-parent: 5.1.2 - merge2: 1.4.1 - micromatch: 4.0.5 - dev: false + /fast-fifo@1.3.2: + resolution: {integrity: sha512-/d9sfos4yxzpwkDkuN7k2SqFKtYNmCTzgfEpz82x34IM9/zc8KGxQoXg1liNC/izpRM/MBdt44Nmx41ZWqk+FQ==} + dev: true - /fast-glob@3.3.1: - resolution: {integrity: sha512-kNFPyjhh5cKjrUltxs+wFx+ZkbRaxxmZ+X0ZU31SOsxCEtP9VPgtq2teZw1DebupL5GmDaNQ6yKMMVcM41iqDg==} + /fast-glob@3.3.2: + resolution: {integrity: sha512-oX2ruAFQwf/Orj8m737Y5adxDQO0LAB7/S5MnxCdTNDd4p6BsyIVsv9JQsATbTSq8KHRpLwIHbVlUNatxd+1Ow==} engines: {node: '>=8.6.0'} dependencies: '@nodelib/fs.stat': 2.0.5 @@ -5139,7 +8260,6 @@ packages: glob-parent: 5.1.2 merge2: 1.4.1 micromatch: 4.0.5 - dev: true /fast-json-stable-stringify@2.1.0: resolution: {integrity: sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==} @@ -5152,14 +8272,18 @@ packages: resolution: {integrity: sha512-Ue0LwpDYErFbmNnZSF0UH6eImUwDmogUO1jyE+JbN2gsQz/jICm1Ve7t9QT0rNSsfJt+Hs4/S3GnsDVjL4HVrw==} dev: true + /fast-safe-stringify@2.0.4: + resolution: {integrity: sha512-mNlGUdKOeGNleyrmgbKYtbnCr9KZkZXU7eM89JRo8vY10f7Ul1Fbj07hUBW3N4fC0xM+fmfFfa2zM7mIizhpNQ==} + dev: true + /fast-url-parser@1.1.3: resolution: {integrity: sha512-5jOCVXADYNuRkKFzNJ0dCCewsZiYo0dz8QNYljkOpFC6r2U4OBmKtvm/Tsuh4w1YYdDqDb31a8TVhBJ2OJKdqQ==} dependencies: punycode: 1.4.1 dev: true - /fastq@1.15.0: - resolution: {integrity: sha512-wBrocU2LCXXa+lWBt8RoIRD89Fi8OdABODa/kEnyeyjS5aZO5/GNvI5sEINADqP/h8M29UHTHUb53sUu5Ihqdw==} + /fastq@1.17.1: + resolution: {integrity: sha512-sRVD3lWVIXWg6By68ZN7vho9a1pQcN/WBFaAAsDDFzlJjvoGx0P8z7V1t72grFJfJhu3YPZBuu25f7Kaw2jN1w==} dependencies: reusify: 1.0.4 @@ -5174,14 +8298,17 @@ packages: resolution: {integrity: sha512-cE1qsB/VwyQozZ+q1dGxR8LBYNZeofhEdUNGSMbQD3Gw2lAzX9Zb3uIU6Ebc/Fmyjo9AWWfnn0AUCHqtevs/8g==} dependencies: pend: 1.2.0 - dev: false + + /fecha@4.2.3: + resolution: {integrity: sha512-OP2IUU6HeYKJi3i0z4A19kHMQoLVs4Hc+DPqqxI2h/DPZHTm/vjsfC6P0b4jCMy14XizLBqvndQ+UilD7707Jw==} + dev: true /fetch-blob@3.2.0: resolution: {integrity: sha512-7yAQpD2UMJzLi1Dqv7qFYnPbaPx7ZfFK6PiIxQ4PfkGPyNyl2Ugx+a/umUonmKqjhM4DnfbMvdX6otXq83soQQ==} engines: {node: ^12.20 || >= 14.13} dependencies: node-domexception: 1.0.0 - web-streams-polyfill: 3.2.1 + web-streams-polyfill: 3.3.3 dev: true /figures@3.2.0: @@ -5189,7 +8316,6 @@ packages: engines: {node: '>=8'} dependencies: escape-string-regexp: 1.0.5 - dev: false /figures@5.0.0: resolution: {integrity: sha512-ej8ksPF4x6e5wvK9yevct0UCXh8TTFlWGVLlgjZuoBH1HwjIfKE/IdL5mq89sFA7zELi1VhKpmtDnrs7zWyeyg==} @@ -5203,7 +8329,7 @@ packages: resolution: {integrity: sha512-7Gps/XWymbLk2QLYK4NzpMOrYjMhdIxXuIvy2QBsLE6ljuodKvdkWs/cpyJJ3CVIVpH0Oi1Hvg1ovbMzLdFBBg==} engines: {node: ^10.12.0 || >=12.0.0} dependencies: - flat-cache: 3.0.4 + flat-cache: 3.2.0 dev: true /file-type@11.1.0: @@ -5231,6 +8357,10 @@ packages: engines: {node: '>=4'} dev: false + /file-uri-to-path@1.0.0: + resolution: {integrity: sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw==} + dev: true + /filename-reserved-regex@2.0.0: resolution: {integrity: sha512-lc1bnsSr4L4Bdif8Xb/qrtokGbq5zlsms/CYH8PP+WtCkGNF65DPiQY8vG3SakEdRn8Dlnm+gW/qWKKjS5sZzQ==} engines: {node: '>=4'} @@ -5284,6 +8414,14 @@ packages: pkg-dir: 4.2.0 dev: false + /find-cache-dir@4.0.0: + resolution: {integrity: sha512-9ZonPT4ZAK4a+1pUPVPZJapbi7O5qbbJPdYw/NOQWZZbVLdDTYM3A4R9z/DpAM08IDaFGsvPgiGZ82WEwUDWjg==} + engines: {node: '>=14.16'} + dependencies: + common-path-prefix: 3.0.0 + pkg-dir: 7.0.0 + dev: false + /find-config@1.0.0: resolution: {integrity: sha512-Z+suHH+7LSE40WfUeZPIxSxypCWvrzdVc60xAjUShZeT5eMWM0/FQUduq3HjluyfAHWvC/aOBkT1pTZktyF/jg==} engines: {node: '>= 0.12'} @@ -5312,22 +8450,31 @@ packages: dependencies: locate-path: 7.2.0 path-exists: 5.0.0 - dev: false - /flat-cache@3.0.4: - resolution: {integrity: sha512-dm9s5Pw7Jc0GvMYbshN6zchCA9RgQlzzEZX3vylR9IqFfS8XciblUXOKfW6SiuJ0e13eDYZoZV5wdrev7P3Nwg==} + /flat-cache@3.2.0: + resolution: {integrity: sha512-CYcENa+FtcUKLmhhqyctpclsq7QF38pKjZHsGNiSQF5r4FtoKDWabFDl3hzaEQMvT1LHEysw5twgLvpYYb4vbw==} engines: {node: ^10.12.0 || >=12.0.0} dependencies: - flatted: 3.2.7 + flatted: 3.3.1 + keyv: 4.5.4 rimraf: 3.0.2 dev: true - /flatted@3.2.7: - resolution: {integrity: sha512-5nqDSxl8nn5BSNxyR3n4I6eDmbolI6WT+QqR547RwxQapgjQBmtktdP+HTBb/a/zLsbzERTONyUB5pefh5TtjQ==} + /flat@5.0.2: + resolution: {integrity: sha512-b6suED+5/3rTpUBdG1gupIl8MPFCAMA0QXwmljLhvCUKcUvdE4gWky9zpuGCcXHOsz4J9wPGNWq6OKpmIzz3hQ==} + hasBin: true + dev: false + + /flatted@3.3.1: + resolution: {integrity: sha512-X8cqMLLie7KsNUDSdzeN8FYK9rEt4Dt67OsG/DNGnYTSDBG4uFAJFBnUeiV+zCVAvwFy56IjM9sH51jVaEhNxw==} + dev: true + + /fn.name@1.1.0: + resolution: {integrity: sha512-GRnmB5gPyJpAhTQdSZTSp9uaPSvl09KoYcMQtsB9rQoOmzs9dH6ffeccH+Z+cv6P68Hu5bC6JjRh4Ah/mHSNRw==} dev: true - /follow-redirects@1.15.2(debug@4.3.4): - resolution: {integrity: sha512-VQLG33o04KaQ8uYi2tVNbdrWp1QWxNNea+nmIB4EVM28v0hmP17z7aG1+wAkNzVq4KeXTq3221ye5qTJP91JwA==} + /follow-redirects@1.15.5(debug@4.3.4): + resolution: {integrity: sha512-vSFWUON1B+yAw1VN4xMfxgn5fTUiaOzAJCKBwIIgT/+7CuGy9+r+5gITvP62j3RmaD5Ph65UaERdOSRGUzZtgw==} engines: {node: '>=4.0'} peerDependencies: debug: '*' @@ -5355,8 +8502,7 @@ packages: engines: {node: '>=14'} dependencies: cross-spawn: 7.0.3 - signal-exit: 4.0.1 - dev: true + signal-exit: 4.1.0 /forever-agent@0.6.1: resolution: {integrity: sha512-j0KLYPhm6zeac4lz3oJ3o65qvgQCcPubiyotZrXqEaG4hNagNYO8qdlUrX5vwqv9ohqeT/Z3j6+yW067yWWdUw==} @@ -5396,8 +8542,8 @@ packages: engines: {node: '>= 0.6'} dev: false - /fp-and-or@0.1.3: - resolution: {integrity: sha512-wJaE62fLaB3jCYvY2ZHjZvmKK2iiLiiehX38rz5QZxtdN8fVPJDeZUiVvJrHStdTc+23LHlyZuSEKgFc0pxi2g==} + /fp-and-or@0.1.4: + resolution: {integrity: sha512-+yRYRhpnFPWXSly/6V4Lw9IfOV26uu30kynGJ03PW+MnjOEQe45RZ141QcS0aJehYBYA50GfCDnsRbFJdhssRw==} engines: {node: '>=10'} dev: true @@ -5423,7 +8569,15 @@ packages: /fs-constants@1.0.0: resolution: {integrity: sha512-y6OAwoSIf7FyjMIv94u+b5rdheZEjzR63GTyZJm5qh4Bi+2YgwLCcI/fPFZkL5PSixOt6ZNKm+w+Hfp/Bciwow==} - dev: false + + /fs-extra@11.2.0: + resolution: {integrity: sha512-PmDi3uwK5nFuXh7XDTlVnS17xJS7vW36is2+w3xcv8SVxiB4NyATf4ctkVY5bkSjX0Y4nbvZCq1/EjtEyr9ktw==} + engines: {node: '>=14.14'} + dependencies: + graceful-fs: 4.2.11 + jsonfile: 6.1.0 + universalify: 2.0.1 + dev: true /fs-extra@8.1.0: resolution: {integrity: sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g==} @@ -5432,6 +8586,7 @@ packages: graceful-fs: 4.2.11 jsonfile: 4.0.0 universalify: 0.1.2 + dev: false /fs-extra@9.1.0: resolution: {integrity: sha512-hcg3ZmepS30/7BSFqRvoo3DOMQu7IjqxO5nCDt+zM9XWjb33Wg7ziNT+Qvqbuc3+gWpzO02JubVyk2G4Zvo1OQ==} @@ -5440,7 +8595,7 @@ packages: at-least-node: 1.0.0 graceful-fs: 4.2.11 jsonfile: 6.1.0 - universalify: 2.0.0 + universalify: 2.0.1 dev: false /fs-minipass@2.1.0: @@ -5450,15 +8605,15 @@ packages: minipass: 3.3.6 dev: true - /fs-minipass@3.0.2: - resolution: {integrity: sha512-2GAfyfoaCDRrM6jaOS3UsBts8yJ55VioXdWcOL7dK9zdAuKT71+WBA4ifnNYqVjYv+4SsPxjK0JT4yIIn4cA/g==} + /fs-minipass@3.0.3: + resolution: {integrity: sha512-XUBA9XClHbnJWSfBzjkm6RvPsyg3sryZt06BEQoXcF7EK/xpGaQYJgQKDJSUH5SGZ76Y7pFx1QBnXz09rU5Fbw==} engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} dependencies: - minipass: 5.0.0 + minipass: 7.0.4 dev: true - /fs-monkey@1.0.3: - resolution: {integrity: sha512-cybjIfiiE+pTWicSCLFHSrXZ6EilF30oh91FDP9S2B051prEa7QWfrVTQm10/dDpswBDXZugPa1Ogu8Yh+HV0Q==} + /fs-monkey@1.0.5: + resolution: {integrity: sha512-8uMbBjrhzW76TYgEV27Y5E//W2f/lTFmx78P2w19FZSxarhI/798APGQyuGCwmkNxgwGRhrLfvWyLBvNtuOmew==} dev: false /fs.realpath@1.0.0: @@ -5472,16 +8627,23 @@ packages: dev: false optional: true - /function-bind@1.1.1: - resolution: {integrity: sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==} + /fsevents@2.3.3: + resolution: {integrity: sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==} + engines: {node: ^8.16.0 || ^10.6.0 || >=11.0.0} + os: [darwin] + requiresBuild: true + optional: true + + /function-bind@1.1.2: + resolution: {integrity: sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==} - /function.prototype.name@1.1.5: - resolution: {integrity: sha512-uN7m/BzVKQnCUF/iW8jYea67v++2u7m5UgENbHRtdDVclOUP+FMPlCNdmk0h/ysGyo2tavMJEDqJAkJdRa1vMA==} + /function.prototype.name@1.1.6: + resolution: {integrity: sha512-Z5kx79swU5P27WEayXM1tBi5Ze/lbIyiNgU3qyXUOf9b2rgXYyF9Dy9Cx+IQv/Lc8WCG6L82zwUPpSS9hGehIg==} engines: {node: '>= 0.4'} dependencies: - call-bind: 1.0.2 - define-properties: 1.2.0 - es-abstract: 1.21.2 + call-bind: 1.0.7 + define-properties: 1.2.1 + es-abstract: 1.22.4 functions-have-names: 1.2.3 /functions-have-names@1.2.3: @@ -5504,27 +8666,24 @@ packages: /gensync@1.0.0-beta.2: resolution: {integrity: sha512-3hN7NaskYvMDLQY55gnW3NQ+mesEAepTqlg+VEbj7zzqEMBVNhzcGYYeqFo/TlYz6eQiFcp1HcsCZO+nGgS8zg==} engines: {node: '>=6.9.0'} - dev: false /get-caller-file@2.0.5: resolution: {integrity: sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==} engines: {node: 6.* || 8.* || >= 10.*} - dev: false - /get-intrinsic@1.2.0: - resolution: {integrity: sha512-L049y6nFOuom5wGyRc3/gdTLO94dySVKRACj1RmJZBQXlbTMhtNIgkWkUHq+jYmZvKf14EW1EoJnnjbmoHij0Q==} - dependencies: - function-bind: 1.1.1 - has: 1.0.3 - has-symbols: 1.0.3 + /get-func-name@2.0.2: + resolution: {integrity: sha512-8vXOvuE167CtIc3OyItco7N/dpRtBbYOsPsXCz7X/PMnlGjYjSGuZJgM1Y7mmew7BKf9BqvLX2tnOVy1BBUsxQ==} + dev: true - /get-intrinsic@1.2.1: - resolution: {integrity: sha512-2DcsyfABl+gVHEfCOaTrWgyt+tb6MSEGmKq+kI5HwLbIYgjgmMcV8KQ41uaKz1xxUcn9tJtgFbQUEVcEbd0FYw==} + /get-intrinsic@1.2.4: + resolution: {integrity: sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==} + engines: {node: '>= 0.4'} dependencies: - function-bind: 1.1.1 - has: 1.0.3 - has-proto: 1.0.1 + es-errors: 1.3.0 + function-bind: 1.1.2 + has-proto: 1.0.3 has-symbols: 1.0.3 + hasown: 2.0.1 /get-package-type@0.1.0: resolution: {integrity: sha512-pjzuKtY64GYfWizNAJ0fr9VqttZkNiK2iS430LtIHzjBEr6bX8Am2zm4sW4Ro5wjWW5cAlRL1qAMTcXbjNAO2Q==} @@ -5571,27 +8730,38 @@ packages: engines: {node: '>=8'} dependencies: pump: 3.0.0 - dev: false /get-stream@6.0.1: resolution: {integrity: sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==} engines: {node: '>=10'} - /get-symbol-description@1.0.0: - resolution: {integrity: sha512-2EmdH1YvIQiZpltCNgkuiUnyukzxM/R6NDJX31Ke3BG1Nq5b0S2PhX59UKi9vZpPDQVdqn+1IcaAwnzTT5vCjw==} + /get-stream@8.0.1: + resolution: {integrity: sha512-VaUJspBffn/LMCJVoMvSAdmscJyS1auj5Zulnn5UoYcY531UWmdwhRWkcGKnGU93m5HSXP9LP2usOryrBtQowA==} + engines: {node: '>=16'} + dev: true + + /get-symbol-description@1.0.2: + resolution: {integrity: sha512-g0QYk1dZBxGwk+Ngc+ltRH2IBp2f7zBkBMBJZCDerh6EhlhSR6+9irMCuT/09zD6qkarHUSn529sK/yL4S27mg==} engines: {node: '>= 0.4'} dependencies: - call-bind: 1.0.2 - get-intrinsic: 1.2.0 + call-bind: 1.0.7 + es-errors: 1.3.0 + get-intrinsic: 1.2.4 - /get-uri@6.0.1: - resolution: {integrity: sha512-7ZqONUVqaabogsYNWlYj0t3YZaL6dhuEueZXGF+/YVmf6dHmaFg8/6psJKqhx9QykIDKzpGcy2cn4oV4YC7V/Q==} + /get-tsconfig@4.7.2: + resolution: {integrity: sha512-wuMsz4leaj5hbGgg4IvDU0bqJagpftG5l5cXIAvo8uZrqn0NJqwtfupTN00VnkQJPcIRrxYrm1Ue24btpCha2A==} + dependencies: + resolve-pkg-maps: 1.0.0 + dev: true + + /get-uri@6.0.3: + resolution: {integrity: sha512-BzUrJBS9EcUb4cFol8r4W3v1cPsSyajLSthNkz5BxbpDcHN5tIrM10E2eNvfnvBn3DaT3DUgx0OpsBKkaOpanw==} engines: {node: '>= 14'} dependencies: - basic-ftp: 5.0.3 - data-uri-to-buffer: 5.0.1 + basic-ftp: 5.0.5 + data-uri-to-buffer: 6.0.2 debug: 4.3.4(supports-color@8.1.1) - fs-extra: 8.1.0 + fs-extra: 11.2.0 transitivePeerDependencies: - supports-color dev: true @@ -5599,7 +8769,7 @@ packages: /getos@3.2.1: resolution: {integrity: sha512-U56CfOK17OKgTVqozZjUKNdkfEv6jk5WISBJ8SHoagjE6L69zOwl3Z+O8myjY9MEW3i2HPWQBt/LTbCgcC973Q==} dependencies: - async: 3.2.4 + async: 3.2.5 dev: false /getpass@0.1.7: @@ -5613,7 +8783,7 @@ packages: engines: {node: '>=10'} hasBin: true dependencies: - async: 3.2.4 + async: 3.2.5 commander: 2.20.3 email-addresses: 5.0.0 filenamify: 4.3.0 @@ -5635,6 +8805,10 @@ packages: git-up: 7.0.0 dev: true + /github-from-package@0.0.0: + resolution: {integrity: sha512-SyHy3T1v2NUXn29OsWdxmK6RwHD+vkj3v8en8AOBZ1wBQ/hCAQ5bAQTD02kW4W9tUp/3Qh6J8r9EvntiyCmOOw==} + dev: true + /glob-parent@5.1.2: resolution: {integrity: sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==} engines: {node: '>= 6'} @@ -5652,17 +8826,16 @@ packages: resolution: {integrity: sha512-lkX1HJXwyMcprw/5YUZc2s7DrpAiHB21/V+E1rHUrVNokkvB6bqMzT0VfV6/86ZNabt1k14YOIaT7nDvOX3Iiw==} dev: false - /glob@10.3.3: - resolution: {integrity: sha512-92vPiMb/iqpmEgsOoIDvTjc50wf9CCCvMzsi6W0JLPeUKE8TWP1a73PgqSrqy7iAZxaSD1YdzU7QZR5LF51MJw==} + /glob@10.3.10: + resolution: {integrity: sha512-fa46+tv1Ak0UPK1TOy/pZrIybNNt4HCv7SDzwyfiOZkvZLEbjsZkJBPtDHVshZjbecAoAGSC20MjLDG/qr679g==} engines: {node: '>=16 || 14 >=14.17'} hasBin: true dependencies: foreground-child: 3.1.1 - jackspeak: 2.2.0 + jackspeak: 2.3.6 minimatch: 9.0.3 - minipass: 5.0.0 + minipass: 7.0.4 path-scurry: 1.10.1 - dev: true /glob@7.2.3: resolution: {integrity: sha512-nFR0zLpU2YCaRxwoCJvL6UvCH2JFyFVIvwTLsIf21AuHlMskA1hhTdk+LlYJtOlYt9v6dvszD2BGRqBL+iQK9Q==} @@ -5694,10 +8867,9 @@ packages: /globals@11.12.0: resolution: {integrity: sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==} engines: {node: '>=4'} - dev: false - /globals@13.20.0: - resolution: {integrity: sha512-Qg5QtVkCy/kv3FUSlu4ukeZDVf9ee0iXLAUYX13gbR17bnejFTzr4iS9bY7kwCf1NztRNm1t91fjOiyx4CSwPQ==} + /globals@13.24.0: + resolution: {integrity: sha512-AhO5QUcj8llrbG09iWhPU2B204J1xnPeL8kQmVorSsy+Sjj1sk8gIyh6cUocGmH4L0UuhAJy+hJMRA4mgA4mFQ==} engines: {node: '>=8'} dependencies: type-fest: 0.20.2 @@ -5707,19 +8879,7 @@ packages: resolution: {integrity: sha512-sFdI5LyBiNTHjRd7cGPWapiHWMOXKyuBNX/cWJ3NfzrZQVa8GI/8cofCl74AOVqq9W5kNmguTIzJ/1s2gyI9wA==} engines: {node: '>= 0.4'} dependencies: - define-properties: 1.2.0 - - /globby@11.0.4: - resolution: {integrity: sha512-9O4MVG9ioZJ08ffbcyVYyLOJLk5JQ688pJ4eMGLpdWLHq/Wr1D9BlriLQyL0E+jbkuePVZXYFj47QM/v093wHg==} - engines: {node: '>=10'} - dependencies: - array-union: 2.1.0 - dir-glob: 3.0.1 - fast-glob: 3.2.12 - ignore: 5.2.4 - merge2: 1.4.1 - slash: 3.0.0 - dev: false + define-properties: 1.2.1 /globby@11.1.0: resolution: {integrity: sha512-jhIXaOzy1sb8IyocaruWSn1TjmnBVs8Ayhcy83rmxNJ8q2uWKCAj3CnJY+KpGSXCueAPc0i05kVvVKtP1t9S3g==} @@ -5727,19 +8887,18 @@ packages: dependencies: array-union: 2.1.0 dir-glob: 3.0.1 - fast-glob: 3.3.1 - ignore: 5.2.4 + fast-glob: 3.3.2 + ignore: 5.3.1 merge2: 1.4.1 slash: 3.0.0 - dev: true /globby@13.2.2: resolution: {integrity: sha512-Y1zNGV+pzQdh7H39l9zgB4PJqjRNqydvdYCDG4HFXM4XuvSaQQlEc91IU1yALL8gUTDomgBAfz3XJdmUS+oo0w==} engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} dependencies: dir-glob: 3.0.1 - fast-glob: 3.3.1 - ignore: 5.2.4 + fast-glob: 3.3.2 + ignore: 5.3.1 merge2: 1.4.1 slash: 4.0.0 dev: true @@ -5755,23 +8914,27 @@ packages: pinkie-promise: 2.0.1 dev: false + /globrex@0.1.2: + resolution: {integrity: sha512-uHJgbwAMwNFf5mLst7IWLNg14x1CkeqglJb/K3doi4dw6q2IvAAmM/Y81kevy83wP+Sst+nutFTYOGg3d1lsxg==} + dev: true + /gopd@1.0.1: resolution: {integrity: sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==} dependencies: - get-intrinsic: 1.2.0 + get-intrinsic: 1.2.4 - /got@12.6.0: - resolution: {integrity: sha512-WTcaQ963xV97MN3x0/CbAriXFZcXCfgxVp91I+Ze6pawQOa7SgzwSx2zIJJsX+kTajMnVs0xcFD1TxZKFqhdnQ==} + /got@12.6.1: + resolution: {integrity: sha512-mThBblvlAF1d4O5oqyvN+ZxLAYwIJK7bpMxgYqPD9okW0C3qm5FFn7k811QrcuEBwaogR3ngOFoCfs6mRv7teQ==} engines: {node: '>=14.16'} dependencies: - '@sindresorhus/is': 5.3.0 + '@sindresorhus/is': 5.6.0 '@szmarczak/http-timer': 5.0.1 cacheable-lookup: 7.0.0 - cacheable-request: 10.2.10 + cacheable-request: 10.2.14 decompress-response: 6.0.0 form-data-encoder: 2.1.4 get-stream: 6.0.1 - http2-wrapper: 2.2.0 + http2-wrapper: 2.2.1 lowercase-keys: 3.0.0 p-cancelable: 3.0.0 responselike: 3.0.0 @@ -5781,14 +8944,14 @@ packages: resolution: {integrity: sha512-XfBk1CxOOScDcMr9O1yKkNaQyy865NbYs+F7dr4H0LZMVgCj2Le59k6PqbNHoL5ToeaEQUYh6c6yMfVcc6SJxA==} engines: {node: '>=16'} dependencies: - '@sindresorhus/is': 5.3.0 + '@sindresorhus/is': 5.6.0 '@szmarczak/http-timer': 5.0.1 cacheable-lookup: 7.0.0 - cacheable-request: 10.2.10 + cacheable-request: 10.2.14 decompress-response: 6.0.0 form-data-encoder: 2.1.4 get-stream: 6.0.1 - http2-wrapper: 2.2.0 + http2-wrapper: 2.2.1 lowercase-keys: 3.0.0 p-cancelable: 3.0.0 responselike: 3.0.0 @@ -5800,7 +8963,7 @@ packages: dependencies: '@sindresorhus/is': 0.7.0 '@types/keyv': 3.1.4 - '@types/responselike': 1.0.0 + '@types/responselike': 1.0.3 cacheable-request: 2.1.4 decompress-response: 3.3.0 duplexer3: 0.1.5 @@ -5834,6 +8997,15 @@ packages: resolution: {integrity: sha512-9Qn4yBxelxoh2Ow62nP+Ka/kMnOXRi8BXnRaUwezLNhqelnN49xKz4F/dPP8OYLxLxq6JDtZb2i9XznUQbNPTg==} dev: false + /happy-dom@13.6.2: + resolution: {integrity: sha512-Ku+wDqcF/KwFA0dI+xIMZd9Jn020RXjuSil/Vz7gu2yhDC3FsDYZ55qqV9k+SGC4opwb4acisXqVSRxUJMlPbQ==} + engines: {node: '>=16.0.0'} + dependencies: + entities: 4.5.0 + webidl-conversions: 7.0.0 + whatwg-mimetype: 3.0.0 + dev: true + /has-bigints@1.0.2: resolution: {integrity: sha512-tSvCKtBr9lkF0Ex0aQiP9N+OpV4zi2r/Nee5VkRDbaqv35RLYMzbwQfFSZZH0kR+Rd6302UJZ2p/bJCEoR3VoQ==} @@ -5845,13 +9017,13 @@ packages: resolution: {integrity: sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==} engines: {node: '>=8'} - /has-property-descriptors@1.0.0: - resolution: {integrity: sha512-62DVLZGoiEBDHQyqG4w9xCuZ7eJEwNmJRWw2VY84Oedb7WFcA27fiEVe8oUQx9hAUJ4ekurquucTGwsyO1XGdQ==} + /has-property-descriptors@1.0.2: + resolution: {integrity: sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==} dependencies: - get-intrinsic: 1.2.0 + es-define-property: 1.0.0 - /has-proto@1.0.1: - resolution: {integrity: sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg==} + /has-proto@1.0.3: + resolution: {integrity: sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q==} engines: {node: '>= 0.4'} /has-symbol-support-x@1.4.2: @@ -5868,8 +9040,8 @@ packages: has-symbol-support-x: 1.4.2 dev: false - /has-tostringtag@1.0.0: - resolution: {integrity: sha512-kFjcSNhnlGV1kyoGk7OXKSawH5JOb/LzUc5w9B02hOTO0dfFRjbHQKvg1d6cf3HbeUmtU9VbbV3qzZ2Teh97WQ==} + /has-tostringtag@1.0.2: + resolution: {integrity: sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw==} engines: {node: '>= 0.4'} dependencies: has-symbols: 1.0.3 @@ -5883,11 +9055,12 @@ packages: engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} dev: true - /has@1.0.3: - resolution: {integrity: sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==} - engines: {node: '>= 0.4.0'} + /hash.js@1.1.7: + resolution: {integrity: sha512-taOaskGt4z4SOANNseOviYDvjEJinIkRgmp7LbKP2YTTmVxWBl87s/uzK9r+44BclBSp2X7K1hqeNfz9JbBeXA==} dependencies: - function-bind: 1.1.1 + inherits: 2.0.4 + minimalistic-assert: 1.0.1 + dev: true /hasha@5.2.2: resolution: {integrity: sha512-Hrp5vIK/xr5SkeN2onO32H0MgNZ0f17HRNH39WfL0SYUNOTZ5Lz1TJ8Pajo/87dYGEFlLMm7mIc/k/s6Bvz9HQ==} @@ -5897,11 +9070,30 @@ packages: type-fest: 0.8.1 dev: false + /hasown@2.0.1: + resolution: {integrity: sha512-1/th4MHjnwncwXsIW6QMzlvYL9kG5e/CpVvLRZe4XPa8TOUNbCELqmvhDmnkNsAjwaG4+I8gJJL0JBvTTLO9qA==} + engines: {node: '>= 0.4'} + dependencies: + function-bind: 1.1.2 + /he@1.2.0: resolution: {integrity: sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==} hasBin: true dev: false + /header-range-parser@1.1.3: + resolution: {integrity: sha512-B9zCFt3jH8g09LR1vHL4pcAn8yMEtlSlOUdQemzHMRKMImNIhhszdeosYFfNW0WXKQtXIlWB+O4owHJKvEJYaA==} + engines: {node: '>=12.22.0'} + dev: true + + /hmac-drbg@1.0.1: + resolution: {integrity: sha512-Tti3gMqLdZfhOQY1Mzf/AanLiqh1WTiJgEj26ZuYQ9fbkLomzGchCws4FyrSd4VkpBfiNhaE1On+lOz894jvXg==} + dependencies: + hash.js: 1.1.7 + minimalistic-assert: 1.0.1 + minimalistic-crypto-utils: 1.0.1 + dev: true + /hosted-git-info@2.8.9: resolution: {integrity: sha512-mxIDAb9Lsm6DoOJ7xH+5+X4y1LU/4Hi50L9C5sIswK3JzULS4bwk1FvjdBgvYR4bzT4tuUQiC15FE2f5HbLvYw==} dev: true @@ -5929,8 +9121,8 @@ packages: wbuf: 1.7.3 dev: false - /html-entities@2.3.3: - resolution: {integrity: sha512-DV5Ln36z34NNTDgnz0EWGBLZENelNAtkiFA4kyNOG2tDI6Mz1uSWiq1wAKdyjnJwyDiDO7Fa2SO1CTxPXL8VxA==} + /html-entities@2.4.0: + resolution: {integrity: sha512-igBTJcNNNhvZFRtm8uA6xMY6xYleeDwn3PeBCkDz7tHttv4F2hsDI2aPgNERWzvRcNYHNT3ymRaQzllmXj4YsQ==} dev: false /html-escaper@2.0.2: @@ -5957,44 +9149,50 @@ packages: hasBin: true dependencies: camel-case: 4.1.2 - clean-css: 5.3.2 + clean-css: 5.3.3 commander: 8.3.0 he: 1.2.0 param-case: 3.0.4 relateurl: 0.2.7 - terser: 5.17.1 + terser: 5.28.1 dev: false - /html-webpack-plugin@4.5.2(webpack@5.81.0): + /html-webpack-plugin@4.5.2(webpack@5.90.3): resolution: {integrity: sha512-q5oYdzjKUIPQVjOosjgvCHQOv9Ett9CYYHlgvJeXG0qQvdSojnBq4vAdQBwn1+yGveAwHCoe/rMR86ozX3+c2A==} engines: {node: '>=6.9'} peerDependencies: webpack: ^4.0.0 || ^5.0.0 dependencies: '@types/html-minifier-terser': 5.1.2 - '@types/tapable': 1.0.8 - '@types/webpack': 4.41.33 + '@types/tapable': 1.0.12 + '@types/webpack': 4.41.38 html-minifier-terser: 5.1.1 loader-utils: 1.4.2 lodash: 4.17.21 pretty-error: 2.1.2 tapable: 1.1.3 util.promisify: 1.0.0 - webpack: 5.81.0 + webpack: 5.90.3 dev: false - /html-webpack-plugin@5.5.1(webpack@5.81.0): - resolution: {integrity: sha512-cTUzZ1+NqjGEKjmVgZKLMdiFg3m9MdRXkZW2OEe69WYVi5ONLMmlnSZdXzGGMOq0C8jGDrL6EWyEDDUioHO/pA==} + /html-webpack-plugin@5.6.0(webpack@5.90.3): + resolution: {integrity: sha512-iwaY4wzbe48AfKLZ/Cc8k0L+FKG6oSNRaZ8x5A/T/IVDGyXcbHncM9TdDa93wn0FsSm82FhTKW7f3vS61thXAw==} engines: {node: '>=10.13.0'} peerDependencies: + '@rspack/core': 0.x || 1.x webpack: ^5.20.0 + peerDependenciesMeta: + '@rspack/core': + optional: true + webpack: + optional: true dependencies: '@types/html-minifier-terser': 6.1.0 html-minifier-terser: 6.1.0 lodash: 4.17.21 pretty-error: 4.0.0 tapable: 2.2.1 - webpack: 5.81.0 + webpack: 5.90.3 dev: false /htmlparser2@6.1.0: @@ -6049,8 +9247,8 @@ packages: - supports-color dev: true - /http-proxy-agent@7.0.0: - resolution: {integrity: sha512-+ZT+iBxVUQ1asugqnD6oWoRiS25AkjNfG085dKJGtGxkdwLQrMKU5wJr2bOOFAXzKcTuqq+7fZlTMgG3SRfIYQ==} + /http-proxy-agent@7.0.2: + resolution: {integrity: sha512-T1gkAiYYDWYx3V5Bmyu7HcfcvL7mUrTWiM6yOfa3PIphViJ/gFPbvidQ+veqSOHci/PxBcDabeUNCzpOODJZig==} engines: {node: '>= 14'} dependencies: agent-base: 7.1.0 @@ -6059,7 +9257,7 @@ packages: - supports-color dev: true - /http-proxy-middleware@2.0.6(@types/express@4.17.17)(debug@4.3.4): + /http-proxy-middleware@2.0.6(@types/express@4.17.21)(debug@4.3.4): resolution: {integrity: sha512-ya/UeJ6HVBYxrgYotAZo1KvPWlgB48kUJLDePFeneHsVujFaW5WNj2NgWCAE//B1Dl02BIfYlpNgBy8Kf8Rjmw==} engines: {node: '>=12.0.0'} peerDependencies: @@ -6068,8 +9266,8 @@ packages: '@types/express': optional: true dependencies: - '@types/express': 4.17.17 - '@types/http-proxy': 1.17.11 + '@types/express': 4.17.21 + '@types/http-proxy': 1.17.14 http-proxy: 1.18.1(debug@4.3.4) is-glob: 4.0.3 is-plain-obj: 3.0.0 @@ -6083,7 +9281,7 @@ packages: engines: {node: '>=8.0.0'} dependencies: eventemitter3: 4.0.7 - follow-redirects: 1.15.2(debug@4.3.4) + follow-redirects: 1.15.5(debug@4.3.4) requires-port: 1.0.0 transitivePeerDependencies: - debug @@ -6095,11 +9293,11 @@ packages: dependencies: assert-plus: 1.0.0 jsprim: 2.0.2 - sshpk: 1.17.0 + sshpk: 1.18.0 dev: false - /http2-wrapper@2.2.0: - resolution: {integrity: sha512-kZB0wxMo0sh1PehyjJUWRFEd99KC5TLjZ2cULC4f9iqJBAmKQQXEICjxl5iPJRwP40dpeHFqqhm7tYCvODpqpQ==} + /http2-wrapper@2.2.1: + resolution: {integrity: sha512-V5nVw1PAOgfI3Lmeaj2Exmeg7fenjhRUgz1lPSezy1CuhPYbgQtbQj4jZfEAEMlaL+vupsvhjqCyjzob0yxsmQ==} engines: {node: '>=10.19.0'} dependencies: quick-lru: 5.1.1 @@ -6116,8 +9314,8 @@ packages: - supports-color dev: true - /https-proxy-agent@7.0.1: - resolution: {integrity: sha512-Eun8zV0kcYS1g19r78osiQLEFIRspRUDd9tIfBCTBPBeMieF/EsJNL8VI3xOIdYRDEkjQnqOYPsZ2DsWsVsFwQ==} + /https-proxy-agent@7.0.4: + resolution: {integrity: sha512-wlwpilI7YdjSkWaQ/7omYBMTliDcmCN8OLihO6I9B86g06lMyAoqgoDpV0XqoaPOKj+0DIdAvnsWfyAAhmimcg==} engines: {node: '>= 14'} dependencies: agent-base: 7.1.0 @@ -6139,6 +9337,11 @@ packages: resolution: {integrity: sha512-nZXjEF2nbo7lIw3mgYjItAfgQXog3OjJogSbKa2CQIIvSGWcKgeJnQlNXip6NglNzYH45nSRiEVimMvYL8DDqQ==} engines: {node: '>=14.18.0'} + /human-signals@5.0.0: + resolution: {integrity: sha512-AXcZb6vzzrFAUE61HnN4mpLqd/cSIwNQjtNWR0euPm6y0iqx3G4gOXaIDdtdDwZmhwe82LA6+zinmW4UBWVePQ==} + engines: {node: '>=16.17.0'} + dev: true + /humanize-ms@1.2.1: resolution: {integrity: sha512-Fl70vYtsAFb/C06PTS9dZBo7ihau+Tu/DNCk/OyHhea07S+aeMWpFFkUaXRa8fI+ScZbEI8dfSxwY7gxZ9SAVQ==} dependencies: @@ -6163,15 +9366,20 @@ packages: /ieee754@1.2.1: resolution: {integrity: sha512-dcyqhDvX1C46lXZcVqCpK+FtMRQVdIMN6/Df5js2zouUsqG7I6sFxitIC+7KYK29KdXOLHdu9zL4sFnoVQnqaA==} - /ignore-walk@6.0.3: - resolution: {integrity: sha512-C7FfFoTA+bI10qfeydT8aZbvr91vAEU+2W5BZUlzPec47oNb07SsOfwYrtxuvOYdUApPP/Qlh4DtAO51Ekk2QA==} + /ignore-by-default@2.1.0: + resolution: {integrity: sha512-yiWd4GVmJp0Q6ghmM2B/V3oZGRmjrKLXvHR3TE1nfoXsmoggllfZUQe74EN0fJdPFZu2NIvNdrMMLm3OsV7Ohw==} + engines: {node: '>=10 <11 || >=12 <13 || >=14'} + dev: true + + /ignore-walk@6.0.4: + resolution: {integrity: sha512-t7sv42WkwFkyKbivUCglsQW5YWMskWtbEf4MNKX5u/CCWHKSPzN4FtBQGsQZgCLbxOzpVlcbWVK5KB3auIOjSw==} engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} dependencies: minimatch: 9.0.3 dev: true - /ignore@5.2.4: - resolution: {integrity: sha512-MAb38BcSbH0eHNBxn7ql2NH/kX33OkB3lZ1BNdh7ENeRChHTYsTvWrMubiIAMNS2llXEEgZ1MUOBtXChP3kaFQ==} + /ignore@5.3.1: + resolution: {integrity: sha512-5Fytz/IraMjqpwfd34ke28PTVMjZjJG2MPn5t7OE4eUCUNf8BAa7b5WUS9/Qvr6mwOQS7Mk6vdsMno5he+T8Xw==} engines: {node: '>= 4'} /import-fresh@3.3.0: @@ -6182,11 +9390,24 @@ packages: resolve-from: 4.0.0 dev: true + /import-in-the-middle@1.7.3: + resolution: {integrity: sha512-R2I11NRi0lI3jD2+qjqyVlVEahsejw7LDnYEbGb47QEFjczE3bZYsmWheCTQA+LFs2DzOQxR7Pms7naHW1V4bQ==} + dependencies: + acorn: 8.11.3 + acorn-import-assertions: 1.9.0(acorn@8.11.3) + cjs-module-lexer: 1.2.3 + module-details-from-path: 1.0.3 + dev: true + /import-lazy@4.0.0: resolution: {integrity: sha512-rKtvo6a868b5Hu3heneU+L4yEQ4jYKLtjpnPeUdK7h0yzXGmyBTypknlkCvHFBqfX9YlorEiMM6Dnq/5atfHkw==} engines: {node: '>=8'} dev: true + /import-meta-resolve@2.2.2: + resolution: {integrity: sha512-f8KcQ1D80V7RnqVm+/lirO9zkOxjGxhaTC1IPrBGd3MEfNgmNG67tSUO9gTi2F3Blr2Az6g1vocaxzkVnWl9MA==} + dev: true + /imurmurhash@0.1.4: resolution: {integrity: sha512-JmXMZ6wuvDmLiHEml9ykzqO6lwFbof0GG4IkcGaENdCRDDmMVnny7s5HsIgHCbaq0w2MyPhDqkhTUgS2LU2PHA==} engines: {node: '>=0.8.19'} @@ -6195,10 +9416,20 @@ packages: resolution: {integrity: sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==} engines: {node: '>=8'} + /indent-string@5.0.0: + resolution: {integrity: sha512-m6FAo/spmsW2Ab2fU35JTYwtOKa2yAwXSwgjSv1TJzh4Mh7mC3lzAOVLBprb72XsTrgkEIsl7YrFNAiDiRhIGg==} + engines: {node: '>=12'} + dev: true + /infer-owner@1.0.4: resolution: {integrity: sha512-IClj+Xz94+d7irH5qRyfJonOdfTzuDaifE6ZPWfx0N0+/ATZCbuTPq2prFl526urkQd90WyUKIh1DfBQ2hMz9A==} dev: true + /inflection@3.0.0: + resolution: {integrity: sha512-1zEJU1l19SgJlmwqsEyFTbScw/tkMHFenUo//Y0i+XEP83gDFdMvPizAD/WGcE+l1ku12PcTVHQhO6g5E0UCMw==} + engines: {node: '>=18.0.0'} + dev: true + /inflight@1.0.6: resolution: {integrity: sha512-k92I/b08q4wvFscXCLvqfsHCrjrF7yiXsQuIVvVE7N82W3+aqpzuUdBbfhWcy/FZR3/4IgflMgKLOsvPDrGCJA==} dependencies: @@ -6225,11 +9456,32 @@ packages: engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} dev: true - /inquirer@9.2.10: - resolution: {integrity: sha512-tVVNFIXU8qNHoULiazz612GFl+yqNfjMTbLuViNJE/d860Qxrd3NMrse8dm40VUQLOQeULvaQF8lpAhvysjeyA==} + /inquirer@8.2.6: + resolution: {integrity: sha512-M1WuAmb7pn9zdFRtQYk26ZBoY043Sse0wVDdk4Bppr+JOXyQYybdtvK+l9wUibhtjdjvtoiNy8tk+EgsYIUqKg==} + engines: {node: '>=12.0.0'} + dependencies: + ansi-escapes: 4.3.2 + chalk: 4.1.2 + cli-cursor: 3.1.0 + cli-width: 3.0.0 + external-editor: 3.1.0 + figures: 3.2.0 + lodash: 4.17.21 + mute-stream: 0.0.8 + ora: 5.4.1 + run-async: 2.4.1 + rxjs: 7.8.1 + string-width: 4.2.3 + strip-ansi: 6.0.1 + through: 2.3.8 + wrap-ansi: 6.2.0 + dev: true + + /inquirer@9.2.11: + resolution: {integrity: sha512-B2LafrnnhbRzCWfAdOXisUzL89Kg8cVJlYmhqoi3flSiV/TveO+nsXwgKr9h9PIo+J1hz7nBSk6gegRIMBBf7g==} engines: {node: '>=14.18.0'} dependencies: - '@ljharb/through': 2.3.9 + '@ljharb/through': 2.3.12 ansi-escapes: 4.3.2 chalk: 5.3.0 cli-cursor: 3.1.0 @@ -6246,13 +9498,17 @@ packages: wrap-ansi: 6.2.0 dev: true - /internal-slot@1.0.5: - resolution: {integrity: sha512-Y+R5hJrzs52QCG2laLn4udYVnxsfny9CpOhNhUvk/SSSVyF6T27FzRbF0sroPidSu3X8oEAkOn2K804mjpt6UQ==} + /int64-buffer@0.1.10: + resolution: {integrity: sha512-v7cSY1J8ydZ0GyjUHqF+1bshJ6cnEVLo9EnjB8p+4HDRPZc9N5jjmvUV7NvEsqQOKyH0pmIBFWXVQbiS0+OBbA==} + dev: true + + /internal-slot@1.0.7: + resolution: {integrity: sha512-NGnrKwXzSms2qUUih/ILZ5JBqNTSa1+ZmP6flaIp6KmSElgE9qdndzS3cqjrDovwFdmwsGsLdeFgB6suw+1e9g==} engines: {node: '>= 0.4'} dependencies: - get-intrinsic: 1.2.0 - has: 1.0.3 - side-channel: 1.0.4 + es-errors: 1.3.0 + hasown: 2.0.1 + side-channel: 1.0.5 /interpret@1.4.0: resolution: {integrity: sha512-agE4QfB2Lkp9uICn7BAqoscw4SZP9kTE2hxiFI3jBPmXJfdqiahTbUuKGsMoN2GtqL9AxhYioAcVvgsb1HvRbA==} @@ -6267,12 +9523,12 @@ packages: p-is-promise: 1.1.0 dev: false - /ip@1.1.8: - resolution: {integrity: sha512-PuExPYUiu6qMBQb4l06ecm6T6ujzhmh+MeJcW9wa89PoAz5pvd4zPgN5WJV104mb6S2T1AwNIAaB70JNrLQWhg==} - dev: true - - /ip@2.0.0: - resolution: {integrity: sha512-WKa+XuLG1A1R0UWhl2+1XQSi+fZWMsYKffMZTTYsiZaUD8k2yDAj5atimTUD2TZkyCkNEeYE5NhFZmupOGtjYQ==} + /ip-address@9.0.5: + resolution: {integrity: sha512-zHtQzGojZXTwZTHQqra+ETKd4Sn3vgi7uBmlPoXVWZqYvuKmtI0l/VZTjqGmJY9x88GGOaZ9+G9ES8hC4T4X8g==} + engines: {node: '>= 12'} + dependencies: + jsbn: 1.1.0 + sprintf-js: 1.1.3 dev: true /ipaddr.js@1.9.1: @@ -6280,29 +9536,38 @@ packages: engines: {node: '>= 0.10'} dev: false - /ipaddr.js@2.0.1: - resolution: {integrity: sha512-1qTgH9NG+IIJ4yfKs2e6Pp1bZg8wbDbKHT21HrLIeYBTRLgMYKnMTPAuI3Lcs61nfx5h1xlXnbJtH1kX5/d/ng==} + /ipaddr.js@2.1.0: + resolution: {integrity: sha512-LlbxQ7xKzfBusov6UMi4MFpEg0m+mAm9xyNGEduwXMEDuf4WfzB/RZwMVYEd7IKGvh4IUkEXYxtAVu9T3OelJQ==} engines: {node: '>= 10'} - dev: false + + /irregular-plurals@3.5.0: + resolution: {integrity: sha512-1ANGLZ+Nkv1ptFb2pa8oG8Lem4krflKuX/gINiHJHjJUKaJHk/SXk5x6K3J+39/p0h1RQ2saROclJJ+QLvETCQ==} + engines: {node: '>=8'} + dev: true /is-arguments@1.1.1: resolution: {integrity: sha512-8Q7EARjzEnKpt/PCD7e1cgUS0a6X8u5tdSiMqXhojOdoV9TsMsiO+9VLC5vAmO8N7/GmXn7yjR8qnA6bVAEzfA==} engines: {node: '>= 0.4'} dependencies: - call-bind: 1.0.2 - has-tostringtag: 1.0.0 + call-bind: 1.0.7 + has-tostringtag: 1.0.2 + dev: true - /is-array-buffer@3.0.2: - resolution: {integrity: sha512-y+FyyR/w8vfIRq4eQcM1EYgSTnmHXPqaF+IgzgraytCFq5Xh8lllDVmAZolPJiZttZLeFSINPYMaEJ7/vWUa1w==} + /is-array-buffer@3.0.4: + resolution: {integrity: sha512-wcjaerHw0ydZwfhiKbXJWLDY8A7yV7KhjQOpb83hGgGfId/aQa4TOvwyzn2PuswW2gPCYEL/nEAiSVpdOj1lXw==} + engines: {node: '>= 0.4'} dependencies: - call-bind: 1.0.2 - get-intrinsic: 1.2.0 - is-typed-array: 1.1.10 + call-bind: 1.0.7 + get-intrinsic: 1.2.4 /is-arrayish@0.2.1: resolution: {integrity: sha512-zz06S8t0ozoDXMG+ube26zeCTNXcKIPJZJi8hBrF4idCLms4CG9QtK7qBl1boi5ODzFpjswb5JPmHCbMpjaYzg==} dev: true + /is-arrayish@0.3.2: + resolution: {integrity: sha512-eVRqCvVlZbuw3GrM63ovNSNAeA1K16kaR/LRY/92w0zxQ5/1YzwblUX652i4Xs9RwAGjW9d9y6X88t8OaAJfWQ==} + dev: true + /is-bigint@1.0.4: resolution: {integrity: sha512-zB9CruMamjym81i2JZ3UMn54PKGsQzsJeo6xvN3HJJ4CAsQNB6iRutp2To77OfCNuoxspsIhzaPoO1zyCEhFOg==} dependencies: @@ -6313,14 +9578,13 @@ packages: engines: {node: '>=8'} dependencies: binary-extensions: 2.2.0 - dev: false /is-boolean-object@1.1.2: resolution: {integrity: sha512-gDYaKHJmnj4aWxyj6YHyXVpdQawtVLHU5cb+eztPGczf6cjuTdwve5ZIEfgXqH4e57An1D1AKf8CZ3kYrQRqYA==} engines: {node: '>= 0.4'} dependencies: - call-bind: 1.0.2 - has-tostringtag: 1.0.0 + call-bind: 1.0.7 + has-tostringtag: 1.0.2 /is-builtin-module@3.2.1: resolution: {integrity: sha512-BSLE3HnV2syZ0FK0iMA/yUGplUeMmNz4AW5fnTunbCIqZi4vG3WjJT9FHMy5D69xmAYBHXQhJdALdpwVxV501A==} @@ -6337,24 +9601,18 @@ packages: resolution: {integrity: sha512-ZYvCgrefwqoQ6yTyYUbQu64HsITZ3NfKX1lzaEYdkTDcfKzzCI/wthRRYKkdjHKFVgNiXKAKm65Zo1pk2as/QQ==} hasBin: true dependencies: - ci-info: 3.8.0 - - /is-core-module@2.12.0: - resolution: {integrity: sha512-RECHCBCd/viahWmwj6enj19sKbHfJrddi/6cBDsNTKbNq0f7VeaUkBo60BqzvPqo/W54ChS62Z5qyun7cfOMqQ==} - dependencies: - has: 1.0.3 - dev: true + ci-info: 3.9.0 - /is-core-module@2.12.1: - resolution: {integrity: sha512-Q4ZuBAe2FUsKtyQJoQHlvP8OvBERxO3jEmy1I7hcRXcJBGGHFh/aJBswbXuS9sgrDH2QUO8ilkwNPHvHMd8clg==} + /is-core-module@2.13.1: + resolution: {integrity: sha512-hHrIjvZsftOsvKSn2TRYl63zvxsgE0K+0mYMoH6gD4omR5IWB2KynivBQczo3+wF1cCkjzvptnI9Q0sPU66ilw==} dependencies: - has: 1.0.3 + hasown: 2.0.1 /is-date-object@1.0.5: resolution: {integrity: sha512-9YQaSxsAiSwcvS33MBk3wTCVnWK+HhF8VZR2jRxehM16QcVOdHqPn4VPHmRK4lSr38n9JriurInLcP90xsYNfQ==} engines: {node: '>= 0.4'} dependencies: - has-tostringtag: 1.0.0 + has-tostringtag: 1.0.2 /is-docker@2.2.1: resolution: {integrity: sha512-F+i2BKsFrH66iaUFc0woD8sLy8getkwTwtOBjvs56Cx4CgJDeKQeqfz8wAYiSb8JOprWhHH5p77PbmYCvvUuXQ==} @@ -6367,6 +9625,10 @@ packages: hasBin: true dev: true + /is-error@2.2.2: + resolution: {integrity: sha512-IOQqts/aHWbiisY5DuPJQ0gcbvaLFCa7fBa9xoLfxBZvQ+ZI/Zh9xoI7Gk+G64N0FdK4AbibytHht2tWgpJWLg==} + dev: true + /is-extglob@2.1.1: resolution: {integrity: sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==} engines: {node: '>=0.10.0'} @@ -6375,6 +9637,11 @@ packages: resolution: {integrity: sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==} engines: {node: '>=8'} + /is-fullwidth-code-point@4.0.0: + resolution: {integrity: sha512-O4L094N2/dZ7xqVdrXhh9r1KODPJpFms8B5sGdJLPy664AgvXsreZUyCQQNItZRDlYug4xStLjNp/sz3HvBowQ==} + engines: {node: '>=12'} + dev: true + /is-glob@4.0.3: resolution: {integrity: sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==} engines: {node: '>=0.10.0'} @@ -6412,13 +9679,18 @@ packages: /is-map@2.0.2: resolution: {integrity: sha512-cOZFQQozTha1f4MxLFzlgKYPTyj26picdZTx82hbc/Xf4K/tZOOXSCkMvU4pKioRXGDLJRn0GM7Upe7kR721yg==} + dev: true + + /is-module@1.0.0: + resolution: {integrity: sha512-51ypPSPCoTEIN9dy5Oy+h4pShgJmPCygKfyRCISBI+JoWT/2oJvK8QPxmwv7b/p239jXrm9M1mlQbyKJ5A152g==} + dev: true /is-natural-number@4.0.1: resolution: {integrity: sha512-Y4LTamMe0DDQIIAlaer9eKebAlDSV6huy+TWhJVPlzZh2o4tRP5SQWFlLn5N0To4mDD22/qdOq+veo1cSISLgQ==} dev: false - /is-negative-zero@2.0.2: - resolution: {integrity: sha512-dqJvarLawXsFbNDeJW7zAz8ItJ9cd28YufuuFzh0G8pNHjJMnY08Dv7sYX2uF5UpQOwieAeOExEYAWWfu7ZZUA==} + /is-negative-zero@2.0.3: + resolution: {integrity: sha512-5KoIu2Ngpyek75jXodFvnafB6DJgr3u8uuK0LEZJjrU19DrMD3EVERaR8sjz8CCGgpZvxPl9SuE1GMVPFHx1mw==} engines: {node: '>= 0.4'} /is-npm@6.0.0: @@ -6430,7 +9702,7 @@ packages: resolution: {integrity: sha512-k1U0IRzLMo7ZlYIfzRu23Oh6MiIFasgpb9X76eqfFZAqwH44UI4KTBvBYIZ1dSL9ZzChTB9ShHfLkR4pdW5krQ==} engines: {node: '>= 0.4'} dependencies: - has-tostringtag: 1.0.0 + has-tostringtag: 1.0.2 /is-number@7.0.0: resolution: {integrity: sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==} @@ -6476,25 +9748,42 @@ packages: engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} dev: true + /is-promise@4.0.0: + resolution: {integrity: sha512-hvpoI6korhJMnej285dSg6nu1+e6uxs7zG3BYAm5byqDsgJNWwxzM6z6iZiAgQR4TJ30JmBTOwqZUw3WlyH3AQ==} + dev: true + + /is-reference@1.2.1: + resolution: {integrity: sha512-U82MsXXiFIrjCK4otLT+o2NA2Cd2g5MLoOVXUZjIOhLurrRxpEXzI8O0KZHr3IjLvlAH1kTPYSuqer5T9ZVBKQ==} + dependencies: + '@types/estree': 1.0.5 + dev: true + /is-regex@1.1.4: resolution: {integrity: sha512-kvRdxDsxZjhzUX07ZnLydzS1TU/TJlTUHHY4YLL87e37oUA49DfkLqgy+VjFocowy29cKvcSiu+kIv728jTTVg==} engines: {node: '>= 0.4'} dependencies: - call-bind: 1.0.2 - has-tostringtag: 1.0.0 + call-bind: 1.0.7 + has-tostringtag: 1.0.2 /is-retry-allowed@1.2.0: resolution: {integrity: sha512-RUbUeKwvm3XG2VYamhJL1xFktgjvPzL0Hq8C+6yrWIswDy3BIXGqCxhxkc30N9jqK311gVU137K8Ei55/zVJRg==} engines: {node: '>=0.10.0'} dev: false + /is-retry-allowed@2.2.0: + resolution: {integrity: sha512-XVm7LOeLpTW4jV19QSH38vkswxoLud8sQ57YwJVTPWdiaI9I8keEhGFpBlslyVsgdQy4Opg8QOLb8YRgsyZiQg==} + engines: {node: '>=10'} + dev: true + /is-set@2.0.2: resolution: {integrity: sha512-+2cnTEZeY5z/iXGbLhPrOAaK/Mau5k5eXq9j14CpRTftq0pAJu2MwVRSZhyZWBzx3o6X795Lz6Bpb6R0GKf37g==} + dev: true - /is-shared-array-buffer@1.0.2: - resolution: {integrity: sha512-sqN2UDu1/0y6uvXyStCOzyhAjCSlHceFoMKJW8W9EU9cvic/QdsZ0kEU93HEy3IUEFZIiH/3w+AH/UQbPHNdhA==} + /is-shared-array-buffer@1.0.3: + resolution: {integrity: sha512-nA2hv5XIhLR3uVzDDfCIknerhx8XUKnstuOERPNNIinXG7v9u+ohXF67vxm4TPTEPU6lm61ZkwP3c9PCB97rhg==} + engines: {node: '>= 0.4'} dependencies: - call-bind: 1.0.2 + call-bind: 1.0.7 /is-ssh@1.4.0: resolution: {integrity: sha512-x7+VxdxOdlV3CYpjvRLBv5Lo9OJerlYanjwFrPR9fuGPjCiNiCzFgAWpiLAohSbsnH4ZAys3SBh+hq5rJosxUQ==} @@ -6530,7 +9819,7 @@ packages: resolution: {integrity: sha512-tE2UXzivje6ofPW7l23cjDOMa09gb7xlAqG6jG5ej6uPV32TlWP3NKPigtaGeHNu9fohccRYvIiZMfOOnOYUtg==} engines: {node: '>= 0.4'} dependencies: - has-tostringtag: 1.0.0 + has-tostringtag: 1.0.2 /is-symbol@1.0.4: resolution: {integrity: sha512-C/CPBqKWnvdcxqIARxyOh4v1UUEOCHpgDa0WYgpKDFMszcrPcffg5uhwSgPCLD2WWxmq6isisz87tzT01tuGhg==} @@ -6538,15 +9827,11 @@ packages: dependencies: has-symbols: 1.0.3 - /is-typed-array@1.1.10: - resolution: {integrity: sha512-PJqgEHiWZvMpaFZ3uTc8kHPM4+4ADTlDniuQL7cU/UDA0Ql7F70yGfHph3cLNe+c9toaigv+DFzTJKhc2CtO6A==} + /is-typed-array@1.1.13: + resolution: {integrity: sha512-uZ25/bUAlUY5fR4OKT4rZQEBrzQWYV9ZJYGGsUmEJ6thodVJ1HX64ePQ6Z0qPWP+m+Uq6e9UugrE38jeYsDSMw==} engines: {node: '>= 0.4'} dependencies: - available-typed-arrays: 1.0.5 - call-bind: 1.0.2 - for-each: 0.3.3 - gopd: 1.0.1 - has-tostringtag: 1.0.0 + which-typed-array: 1.1.14 /is-typedarray@1.0.0: resolution: {integrity: sha512-cyA56iCMHAh5CdzjJIa4aohJyeO1YbwLi3Jc35MmRU6poroFjIGZzUzupGiRPOjgHg9TLu43xbpwXk523fMxKA==} @@ -6560,21 +9845,10 @@ packages: engines: {node: '>=12'} dev: true - /is-weakmap@2.0.1: - resolution: {integrity: sha512-NSBR4kH5oVj1Uwvv970ruUkCV7O1mzgVFO4/rev2cLRda9Tm9HrL70ZPut4rOHgY0FNrUu9BCbXA2sdQ+x0chA==} - dev: false - /is-weakref@1.0.2: resolution: {integrity: sha512-qctsuLZmIQ0+vSSMfoVvyFe2+GSEvnmZ2ezTup1SBse9+twCCeial6EEi3Nc2KFcf6+qz2FBPnjXsk8xhKSaPQ==} dependencies: - call-bind: 1.0.2 - - /is-weakset@2.0.2: - resolution: {integrity: sha512-t2yVvttHkQktwnNNmBQ98AhENLdPUTDTE21uPqAQ0ARwQfGeQKRVS0NNurH7bTf7RrvcVn1OOge45CnBeHCSmg==} - dependencies: - call-bind: 1.0.2 - get-intrinsic: 1.2.1 - dev: false + call-bind: 1.0.7 /is-windows@1.0.2: resolution: {integrity: sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==} @@ -6594,7 +9868,6 @@ packages: /isarray@1.0.0: resolution: {integrity: sha512-VLghIWNM6ELQzo7zwmcg0NmTVyWKYjvIeM83yjp0wRDTmUnrM678fQbcKBo6n2CJEF0szoG//ytg+TKla89ALQ==} - dev: false /isarray@2.0.5: resolution: {integrity: sha512-xHjhDr3cNBK0BzdUJSPXZntQUx/mwMS5Rw4A7lPJ90XGAO6ISP/ePDNuo0vhqOZU+UD5JoodwCAAoZQd3FeAKw==} @@ -6607,12 +9880,20 @@ packages: engines: {node: '>=0.10.0'} dev: false - /isomorphic-ws@5.0.0(ws@8.12.0): - resolution: {integrity: sha512-muId7Zzn9ywDsyXgTIafTry2sV3nySZeUDe6YedVd1Hvuuep5AsIlqK+XefWpYTyJG5e503F2xIuT2lcU6rCSw==} + /isomorphic-ws@4.0.1(ws@7.5.9): + resolution: {integrity: sha512-BhBvN2MBpWTaSHdWRb/bwdZJ1WaehQ2L1KngkCkfLUGF0mAWAT1sQUQacEmQ0jXkFw/czDXPNQSL5u2/Krsz1w==} + peerDependencies: + ws: '*' + dependencies: + ws: 7.5.9 + dev: true + + /isows@1.0.3(ws@8.13.0): + resolution: {integrity: sha512-2cKei4vlmg2cxEjm3wVSqn8pcoRF/LX/wpifuuNquFO4SQmPwarClT+SUCA2lt+l581tTeZIPIZuIDo2jWN1fg==} peerDependencies: ws: '*' dependencies: - ws: 8.12.0 + ws: 8.13.0 dev: false /isstream@0.1.2: @@ -6630,14 +9911,14 @@ packages: lodash.uniqby: 4.7.0 dev: true - /istanbul-lib-coverage@3.0.0: - resolution: {integrity: sha512-UiUIqxMgRDET6eR+o5HbfRYP1l0hqkWOs7vNxC/mggutCMUIhWMm8gAHb8tHlyfD3/l6rlgNA5cKdDzEAf6hEg==} - engines: {node: '>=8'} - dev: false - /istanbul-lib-coverage@3.2.0: resolution: {integrity: sha512-eOeJ5BHCmHYvQK7xt9GkdHuzuCGS1Y6g9Gvnx3Ym33fz/HpLRYxiS0wHNr+m/MBC8B647Xt608vCDEvhl9c6Mw==} engines: {node: '>=8'} + dev: true + + /istanbul-lib-coverage@3.2.2: + resolution: {integrity: sha512-O8dpsF+r0WV/8MNRKfnmrtCWhuKjxrq2w+jpzBL5UZKTi2LeVWnWOmWRxFlesJONmc+wLAGvKQZEOanko0LFTg==} + engines: {node: '>=8'} dev: false /istanbul-lib-hook@3.0.0: @@ -6651,9 +9932,9 @@ packages: resolution: {integrity: sha512-BXgQl9kf4WTCPCCpmFGoJkz/+uhvm7h7PFKUYxh7qarQd3ER33vHG//qaE8eN25l07YqZPpHXU9I09l/RD5aGQ==} engines: {node: '>=8'} dependencies: - '@babel/core': 7.21.8 + '@babel/core': 7.23.9 '@istanbuljs/schema': 0.1.3 - istanbul-lib-coverage: 3.2.0 + istanbul-lib-coverage: 3.2.2 semver: 6.3.1 transitivePeerDependencies: - supports-color @@ -6663,10 +9944,10 @@ packages: resolution: {integrity: sha512-pzqtp31nLv/XFOzXGuvhCb8qhjmTVo5vjVk19XE4CRlSWz0KoeJ3bw9XsA7nOp9YBf4qHjwBxkDzKcME/J29Yg==} engines: {node: '>=8'} dependencies: - '@babel/core': 7.21.8 - '@babel/parser': 7.21.8 + '@babel/core': 7.23.9 + '@babel/parser': 7.23.9 '@istanbuljs/schema': 0.1.3 - istanbul-lib-coverage: 3.2.0 + istanbul-lib-coverage: 3.2.2 semver: 6.3.1 transitivePeerDependencies: - supports-color @@ -6678,18 +9959,18 @@ packages: dependencies: archy: 1.0.0 cross-spawn: 7.0.3 - istanbul-lib-coverage: 3.2.0 + istanbul-lib-coverage: 3.2.2 p-map: 3.0.0 rimraf: 3.0.2 uuid: 8.3.2 dev: false - /istanbul-lib-report@3.0.0: - resolution: {integrity: sha512-wcdi+uAKzfiGT2abPpKZ0hSU1rGQjUQnLvtY5MpQ7QCTahD3VODhcu4wcfY1YtkGaDD5yuydOLINXsfbus9ROw==} - engines: {node: '>=8'} + /istanbul-lib-report@3.0.1: + resolution: {integrity: sha512-GCfE1mtsHGOELCU8e/Z7YWzpmybrx/+dSTfLrvY8qRmaY6zXTKWn6WQIjaAFw069icm6GVMNkgu0NzI4iPZUNw==} + engines: {node: '>=10'} dependencies: - istanbul-lib-coverage: 3.2.0 - make-dir: 3.1.0 + istanbul-lib-coverage: 3.2.2 + make-dir: 4.0.0 supports-color: 7.2.0 dev: false @@ -6698,18 +9979,18 @@ packages: engines: {node: '>=10'} dependencies: debug: 4.3.4(supports-color@8.1.1) - istanbul-lib-coverage: 3.2.0 + istanbul-lib-coverage: 3.2.2 source-map: 0.6.1 transitivePeerDependencies: - supports-color dev: false - /istanbul-reports@3.1.5: - resolution: {integrity: sha512-nUsEMa9pBt/NOHqbcbeJEgqIlY/K7rVWUX6Lql2orY5e9roQOthbR3vtY4zzf2orPELg80fnxxk9zUyPlgwD1w==} + /istanbul-reports@3.1.7: + resolution: {integrity: sha512-BewmUXImeuRk2YY0PVbxgKAysvhRPUQE0h5QRM++nVWyubKGV0l8qQ5op8+B2DOmwSe63Jivj0BjkPQVf8fP5g==} engines: {node: '>=8'} dependencies: html-escaper: 2.0.2 - istanbul-lib-report: 3.0.0 + istanbul-lib-report: 3.0.1 dev: false /isurl@1.0.0: @@ -6731,20 +10012,34 @@ packages: iterate-iterator: 1.0.2 dev: true - /jackspeak@2.2.0: - resolution: {integrity: sha512-r5XBrqIJfwRIjRt/Xr5fv9Wh09qyhHfKnYddDlpM+ibRR20qrYActpCAgU6U+d53EOEjzkvxPMVHSlgR7leXrQ==} + /jackspeak@2.3.6: + resolution: {integrity: sha512-N3yCS/NegsOBokc8GAdM8UcmfsKiSS8cipheD/nivzr700H+nsMOxJjQnvwOcRYVuFkdH0wGUvW2WbXGmrZGbQ==} engines: {node: '>=14'} dependencies: '@isaacs/cliui': 8.0.2 optionalDependencies: '@pkgjs/parseargs': 0.11.0 + + /jessie.js@0.3.3(ava@5.3.1): + resolution: {integrity: sha512-qtm2JSB/ZeH9xNNPjVkeTFH+Hoq9BxAzakgf6WK1PLarIoXJ9roSi+Z5UF65K47rT7QteWrP8b6RPBVquvIwsg==} + dependencies: + '@endo/far': 0.2.18(ava@5.3.1) + transitivePeerDependencies: + - ava + dev: true + + /jest-docblock@29.7.0: + resolution: {integrity: sha512-q617Auw3A612guyaFgsbFeYpNP5t2aoUNLwBUbc/0kD1R4t9ixDbyFTHd1nok4epoVFpr7PmeWHrhvuV3XaJ4g==} + engines: {node: ^14.15.0 || ^16.10.0 || >=18.0.0} + dependencies: + detect-newline: 3.1.0 dev: true /jest-worker@27.5.1: resolution: {integrity: sha512-7vuh85V5cdDofPyxn58nrPjBktZo0u9x1g8WtjQol+jZDaE+fhN+cIvTj11GndBnMnyfrUOG1sZQxCdjKh+DKg==} engines: {node: '>= 10.13.0'} dependencies: - '@types/node': 18.16.3 + '@types/node': 20.11.21 merge-stream: 2.0.0 supports-color: 8.1.1 dev: false @@ -6753,25 +10048,40 @@ packages: resolution: {integrity: sha512-8wb9Yw966OSxApiCt0K3yNJL8pnNeIv+OEq2YMidz4FKP6nonSRoOXc80iXY4JaN2FC11B9qsNmDsm+ZOfMROA==} dev: true - /joi@17.9.2: - resolution: {integrity: sha512-Itk/r+V4Dx0V3c7RLFdRh12IOjySm2/WGPMubBT92cQvRfYZhPM2W0hZlctjj72iES8jsRCwp7S/cRmWBnJ4nw==} + /joi@17.12.2: + resolution: {integrity: sha512-RonXAIzCiHLc8ss3Ibuz45u28GOsWE1UpfDXLbN/9NKbL4tCJf8TWYVKsoYuuh+sAUt7fsSNpA+r2+TBA6Wjmw==} dependencies: '@hapi/hoek': 9.3.0 '@hapi/topo': 5.1.0 - '@sideway/address': 4.1.4 + '@sideway/address': 4.1.5 '@sideway/formula': 3.0.1 '@sideway/pinpoint': 2.0.0 + /js-string-escape@1.0.1: + resolution: {integrity: sha512-Smw4xcfIQ5LVjAOuJCvN/zIodzA/BBSsluuoSykP+lUvScIi4U6RJLfwHet5cxFnCswUjISV8oAXaqaJDY3chg==} + engines: {node: '>= 0.8'} + dev: true + /js-tokens@4.0.0: resolution: {integrity: sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==} + /js-tokens@8.0.3: + resolution: {integrity: sha512-UfJMcSJc+SEXEl9lH/VLHSZbThQyLpw1vLO1Lb+j4RWDvG3N2f7yj3PVQA3cmkTBNldJ9eFnM+xEXxHIXrYiJw==} + dev: true + /js-yaml@3.14.1: resolution: {integrity: sha512-okMH7OXXJ7YrN9Ok3/SXrnu4iX9yOk+25nqX4imS2npuvTYDmo/QEZoqwZkYaIDk3jVvBOTOIEgEhaLOynBS9g==} hasBin: true dependencies: argparse: 1.0.10 esprima: 4.0.1 - dev: false + + /js-yaml@4.0.0: + resolution: {integrity: sha512-pqon0s+4ScYUvX30wxQi3PogGFAlUyH0awepWvwkj4jD4v+ova3RiYw8bmA6x2rDrEaj8i/oWKoRxpVNW+Re8Q==} + hasBin: true + dependencies: + argparse: 2.0.1 + dev: true /js-yaml@4.1.0: resolution: {integrity: sha512-wpxZs9NoxZaJESJGIZTyDEaYpl0FKSA+FB9aJiyemKhMwkxQg63h4T1KJgUGHpTqPDNRcmmYLugrRjJlBtWvRA==} @@ -6783,6 +10093,10 @@ packages: resolution: {integrity: sha512-UVU9dibq2JcFWxQPA6KCqj5O42VOmAY3zQUfEKxU0KpTGXwNoCjkX1e13eHNvw/xPynt6pU0rZ1htjWTNTSXsg==} dev: false + /jsbn@1.1.0: + resolution: {integrity: sha512-4bYVV3aAMtDTTu4+xsDYa6sy9GyJ69/amsu9sYF2zqjiEoZA5xJi3BrfX3uY+/IekIu7MwdObdbDWpoZdBv3/A==} + dev: true + /jschardet@3.0.0: resolution: {integrity: sha512-lJH6tJ77V8Nzd5QWRkFYCLc13a3vADkh3r/Fi8HupZGWk2OVVDfnZP8V/VgQgZ+lzW0kG2UGb5hFgt3V3ndotQ==} engines: {node: '>=0.1.90'} @@ -6796,7 +10110,6 @@ packages: resolution: {integrity: sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==} engines: {node: '>=4'} hasBin: true - dev: false /jsesc@3.0.2: resolution: {integrity: sha512-xKqzzWXDttJuOcawBt4KnKHHIf5oQ/Cxax+0PWFG+DFDgHNAdi+TXECADI+RYiFUMmx8792xsMbbgXj4CwnP4g==} @@ -6815,8 +10128,8 @@ packages: /json-parse-even-better-errors@2.3.1: resolution: {integrity: sha512-xyFwyhro/JEof6Ghe2iz2NcXoj2sloNsWr/XsERDK/oiPCfaNhl5ONfp+jQdAZRQQ0IJWNzH9zIZF7li91kh2w==} - /json-parse-even-better-errors@3.0.0: - resolution: {integrity: sha512-iZbGHafX/59r39gPwVPRBGw0QQKnA7tte5pSMrhWOW7swGsVvVTjmfyAV9pNqk8YGT7tRCdxRu8uzcgZwoDooA==} + /json-parse-even-better-errors@3.0.1: + resolution: {integrity: sha512-aatBvbL26wVUCLmbWdCpeu9iF5wOyWpagiKkInA+kfws3sWdBrTnsvN2CKcyCYyUrc7rebNBlK6+kteg7ksecg==} engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} dev: true @@ -6836,10 +10149,39 @@ packages: resolution: {integrity: sha512-es94M3nTIfsEPisRafak+HDLfHXnKBhV3vU5eqPcS3flIWqcxJWgXHXiey3YrpaNsanY5ei1VoYEbOzijuq9BA==} dev: false + /json-server@1.0.0-alpha.23: + resolution: {integrity: sha512-FPL1veNELhkr3tttwbIutKPkc/AUfLWSmslTwLYYPzl9RbCJQrwSPJceYWg2LnK1cv20tcEMLI2Kxl1lHz155Q==} + engines: {node: '>=18.3'} + hasBin: true + dependencies: + '@tinyhttp/app': 2.2.3 + '@tinyhttp/cors': 2.0.0 + chalk: 5.3.0 + chokidar: 3.6.0 + dot-prop: 8.0.2 + eta: 3.2.0 + inflection: 3.0.0 + json5: 2.2.3 + lowdb: 7.0.1 + milliparsec: 2.3.0 + sirv: 2.0.4 + sort-on: 6.0.0 + dev: true + /json-stable-stringify-without-jsonify@1.0.1: resolution: {integrity: sha512-Bdboy+l7tA3OGW6FjyFHWkP5LuByj1Tk33Ljyq0axyzdk9//JSi2u3fP1QSmd1KNwq6VOKYGlAu87CisVir6Pw==} dev: true + /json-stable-stringify@1.1.1: + resolution: {integrity: sha512-SU/971Kt5qVQfJpyDveVhQ/vya+5hvrjClFOcr8c0Fq5aODJjMwutrOfCU+eCnVD5gpx1Q3fEqkyom77zH1iIg==} + engines: {node: '>= 0.4'} + dependencies: + call-bind: 1.0.7 + isarray: 2.0.5 + jsonify: 0.0.1 + object-keys: 1.1.1 + dev: true + /json-stringify-safe@5.0.1: resolution: {integrity: sha512-ZClg6AaYvamvYEE82d3Iyd3vSSIjQ+odgjaTzRuO3s7toCdFKczob2i0zCh7JE8kWn17yvAWhUVxvqGwUalsRA==} dev: false @@ -6855,18 +10197,26 @@ packages: engines: {node: '>=6'} hasBin: true + /jsonc-parser@3.2.1: + resolution: {integrity: sha512-AilxAyFOAcK5wA1+LeaySVBrHsGQvUFCDWXKpZjzaL0PqW+xfBOttn8GNtWKFWqneyMZj41MWF9Kl6iPWLwgOA==} + dev: true + /jsonfile@4.0.0: resolution: {integrity: sha512-m6F1R3z8jjlf2imQHS2Qez5sjKWQzbuuhuJ/FKYFRZvPE3PuHcSMVZzfsLhGVOkfd20obL5SWEBew5ShlquNxg==} optionalDependencies: graceful-fs: 4.2.11 + dev: false /jsonfile@6.1.0: resolution: {integrity: sha512-5dgndWOriYSm5cnYaJNhalLNDKOqFwyDB/rr1E9ZsGciGvKPs8R2xYGCacuf3z6K1YKDz182fd+fY3cn3pMqXQ==} dependencies: - universalify: 2.0.0 + universalify: 2.0.1 optionalDependencies: graceful-fs: 4.2.11 - dev: false + + /jsonify@0.0.1: + resolution: {integrity: sha512-2/Ki0GcmuqSrgFyelQq9M05y7PS0mEwuIzrf3f1fPqkVDVRvZrPZtVSMHxdgo8Aq0sxAOb/cr2aqqA3LeWHVPg==} + dev: true /jsonlines@0.1.1: resolution: {integrity: sha512-ekDrAGso79Cvf+dtm+mL8OBI2bmAOt3gssYs833De/C9NmIpWDWyUO4zPgB5x2/OhY366dkhgfPMYfwZF7yOZA==} @@ -6893,8 +10243,8 @@ packages: json-buffer: 3.0.0 dev: false - /keyv@4.5.2: - resolution: {integrity: sha512-5MHbFaKn8cNSmVW7BYnijeAVlE4cYA/SVkifVgrh7yotnfhKmjuXpDKjrABLnT0SfHWV21P8ow07OGfRrNDg8g==} + /keyv@4.5.4: + resolution: {integrity: sha512-oxVHkHR/EJf2CNXnWxRLW6mg7JyCCUcG0DtEGmL2ctUo1PNTin1PUil+r/+4r5MpVgC/fn1kjsx7mjSujKqIpw==} dependencies: json-buffer: 3.0.1 dev: true @@ -6909,15 +10259,24 @@ packages: engines: {node: '>=6'} dev: true + /koalas@1.0.2: + resolution: {integrity: sha512-RYhBbYaTTTHId3l6fnMZc3eGQNW6FVCqMG6AMwA5I1Mafr6AflaXeoi6x3xQuATRotGYRLk6+1ELZH4dstFNOA==} + engines: {node: '>=0.10.0'} + dev: true + + /kuler@2.0.0: + resolution: {integrity: sha512-Xq9nH7KlWZmXAtodXDDRE7vs6DU1gTU8zYDHDiWLSip45Egwq3plLHzPn27NgvzL2r1LMPC1vdqh98sQxtqj4A==} + dev: true + /latest-version@7.0.0: resolution: {integrity: sha512-KvNT4XqAMzdcL6ka6Tl3i2lYeFDgXNCuIX+xNx6ZMVR1dFq+idXd9FLKNMOIx0t9mJ9/HudyX4oZWXZQ0UJHeg==} engines: {node: '>=14.16'} dependencies: - package-json: 8.1.0 + package-json: 8.1.1 dev: true - /launch-editor@2.6.0: - resolution: {integrity: sha512-JpDCcQnyAAzZZaZ7vEiSqL690w7dAEyLao+KC96zBplnYbJS7TYNjvM3M7y3dGz+v7aIsJk3hllWuc0kWAjyRQ==} + /launch-editor@2.6.1: + resolution: {integrity: sha512-eB/uXmFVpY4zezmGp5XtU21kwo7GBbKB+EQ+UZeWtGb9yAM5xt/Evk+lYH3eRNAtId+ej4u7TYPFZ07w4s7rRw==} dependencies: picocolors: 1.0.0 shell-quote: 1.8.1 @@ -6935,11 +10294,25 @@ packages: type-check: 0.4.0 dev: true + /libsodium-wrappers@0.7.13: + resolution: {integrity: sha512-kasvDsEi/r1fMzKouIDv7B8I6vNmknXwGiYodErGuESoFTohGSKZplFtVxZqHaoQ217AynyIFgnOVRitpHs0Qw==} + dependencies: + libsodium: 0.7.13 + dev: true + + /libsodium@0.7.13: + resolution: {integrity: sha512-mK8ju0fnrKXXfleL53vtp9xiPq5hKM0zbDQtcxQIsSmxNgSxqCj6R7Hl9PkrNe2j29T4yoDaF7DJLK9/i5iWUw==} + dev: true + + /limiter@1.1.5: + resolution: {integrity: sha512-FWWMIEOxz3GwUI4Ts/IvgVy6LPvoMPgjMdQ185nN6psJyBJ4yOpzqm695/h5umdLJg2vW3GR5iG11MAkR2AzJA==} + dev: true + /lines-and-columns@1.2.4: resolution: {integrity: sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==} dev: true - /listr2@3.14.0(enquirer@2.3.6): + /listr2@3.14.0(enquirer@2.4.1): resolution: {integrity: sha512-TyWI8G99GX9GjE54cJ+RrNMcIFBfwMPxc3XTFiAYGN4s10hWROGtOg7+O6u6LE3mNkyld7RSLE6nrKBvTfcs3g==} engines: {node: '>=10.0.0'} peerDependencies: @@ -6950,15 +10323,42 @@ packages: dependencies: cli-truncate: 2.1.0 colorette: 2.0.20 - enquirer: 2.3.6 + enquirer: 2.4.1 log-update: 4.0.0 p-map: 4.0.0 - rfdc: 1.3.0 + rfdc: 1.3.1 rxjs: 7.8.1 through: 2.3.8 wrap-ansi: 7.0.0 dev: false + /lit-element@3.3.3: + resolution: {integrity: sha512-XbeRxmTHubXENkV4h8RIPyr8lXc+Ff28rkcQzw3G6up2xg5E8Zu1IgOWIwBLEQsu3cOVFqdYwiVi0hv0SlpqUA==} + dependencies: + '@lit-labs/ssr-dom-shim': 1.2.0 + '@lit/reactive-element': 1.6.3 + lit-html: 2.8.0 + dev: true + + /lit-html@2.8.0: + resolution: {integrity: sha512-o9t+MQM3P4y7M7yNzqAyjp7z+mQGa4NS4CxiyLqFPyFWyc4O+nodLrkrxSaCTrla6M5YOLaT3RpbbqjszB5g3Q==} + dependencies: + '@types/trusted-types': 2.0.7 + dev: true + + /lit@2.0.2: + resolution: {integrity: sha512-hKA/1YaSB+P+DvKWuR2q1Xzy/iayhNrJ3aveD0OQ9CKn6wUjsdnF/7LavDOJsKP/K5jzW/kXsuduPgRvTFrFJw==} + dependencies: + '@lit/reactive-element': 1.6.3 + lit-element: 3.3.3 + lit-html: 2.8.0 + dev: true + + /load-json-file@7.0.1: + resolution: {integrity: sha512-Gnxj3ev3mB5TkVBGad0JM6dmLiQL+o0t23JPBZ9sd+yvSLk05mFoqKBw5N8gbbkU4TNXyqCgIrl/VM17OgUIgQ==} + engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} + dev: true + /loader-runner@4.3.0: resolution: {integrity: sha512-3R/1M+yS3j5ou80Me59j7F9IMs4PXs3VqRrm0TU3AbKPxlmpoY1TNscJV/oGJXo8qCatFGTfDbY6W6ipGOYXfg==} engines: {node: '>=6.11.5'} @@ -6978,6 +10378,14 @@ packages: engines: {node: '>=14'} dev: false + /local-pkg@0.5.0: + resolution: {integrity: sha512-ok6z3qlYyCDS4ZEU27HaU6x/xZa9Whf8jD4ptH5UZTQYZVYeb9bnZ3ojVhiJNLiXK1Hfc0GNbLXcmZ5plLDDBg==} + engines: {node: '>=14'} + dependencies: + mlly: 1.6.1 + pkg-types: 1.0.3 + dev: true + /locate-path@5.0.0: resolution: {integrity: sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==} engines: {node: '>=8'} @@ -6996,7 +10404,6 @@ packages: engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} dependencies: p-locate: 6.0.0 - dev: false /lodash.camelcase@4.3.0: resolution: {integrity: sha512-TwuEnCnxbc3rAvhf/LbG7tJUDzhqXyFnv3dtzLOPgCG/hODL7WFnsbwktkD7yUV0RrreP/l1PALq/YSg6VvjlA==} @@ -7041,6 +10448,14 @@ packages: resolution: {integrity: sha512-QZ1d4xoBHYUeuouhEq3lk3Uq7ldgyFXGBhg04+oRLnIz8o9T65Eh+8YdroUwn846zchkA9yDsDl5CVVaV2nqYw==} dev: false + /lodash.sortby@4.7.0: + resolution: {integrity: sha512-HDWXG8isMntAyRF5vZ7xKuEvOhT4AhlRt/3czTSjvGUxjYCBVRQY48ViDHyfYz9VIoBkW4TMGQNapx+l3RUwdA==} + dev: true + + /lodash.truncate@4.4.2: + resolution: {integrity: sha512-jttmRe7bRse52OsWIMDLaXxWqRAmtIUccAQ3garviCqJjafXOfNMO0yMfNpdD6zbGaTU0P5Nz7e7gAT6cKmJRw==} + dev: true + /lodash.uniqby@4.7.0: resolution: {integrity: sha512-e/zcLx6CSbmaEgFHCA7BnoQKyCtKMxnuWrJygbwPs/AIn+IMKl66L8/s+wBUn5LRw2pZx3bUHibiV1b6aTWIww==} dev: true @@ -7077,17 +10492,49 @@ packages: wrap-ansi: 6.2.0 dev: false + /logform@2.6.0: + resolution: {integrity: sha512-1ulHeNPp6k/LD8H91o7VYFBng5i1BDE7HoKxVbZiGFidS1Rj65qcywLxX+pVfAPoQJEjRdvKcusKwOupHCVOVQ==} + engines: {node: '>= 12.0.0'} + dependencies: + '@colors/colors': 1.6.0 + '@types/triple-beam': 1.3.5 + fecha: 4.2.3 + ms: 2.1.3 + safe-stable-stringify: 2.4.3 + triple-beam: 1.3.0 + dev: true + + /long@4.0.0: + resolution: {integrity: sha512-XsP+KhQif4bjX1kbuSiySJFNAehNxgLb6hPRGJ9QsUr8ajHkuXGdrHmFUTUUXhDwVX2R5bY4JNZEwbUiMhV+MA==} + dev: true + + /long@5.2.3: + resolution: {integrity: sha512-lcHwpNoggQTObv5apGNCTdJrO69eHOZMi4BNC+rTLER8iHAqGrUVeLh/irVIM7zTw2bOXA8T6uNPeujwOLg/2Q==} + dev: true + /loose-envify@1.4.0: resolution: {integrity: sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==} hasBin: true dependencies: js-tokens: 4.0.0 - dev: false + + /loupe@2.3.7: + resolution: {integrity: sha512-zSMINGVYkdpYSOBmLi0D1Uo7JU9nVdQKrHxC8eYlV+9YKK9WePqAlL7lSlorG/U2Fw1w0hTBmaa/jrQ3UbPHtA==} + dependencies: + get-func-name: 2.0.2 + dev: true + + /lowdb@7.0.1: + resolution: {integrity: sha512-neJAj8GwF0e8EpycYIDFqEPcx9Qz4GUho20jWFR7YiFeXzF1YMLdxB36PypcTSPMA+4+LvgyMacYhlr18Zlymw==} + engines: {node: '>=18'} + dependencies: + steno: 4.0.2 + dev: true /lower-case@2.0.2: resolution: {integrity: sha512-7fm3l3NAF9WfN6W3JOmf5drwpVqX78JtoGJ3A6W0a6ZnldM41w2fV5D490psKFTpMds8TJse/eHLFFsNHHjHgg==} dependencies: - tslib: 2.6.1 + tslib: 2.6.2 dev: false /lowercase-keys@1.0.0: @@ -7105,11 +10552,14 @@ packages: engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} dev: true + /lru-cache@10.2.0: + resolution: {integrity: sha512-2bIM8x+VAf6JT4bKAljS1qUWgMsqZRPGJS6FSahIMPVvctcNhyVp7AJu7quxOW9jwkryBReKZY5tY5JYv2n/7Q==} + engines: {node: 14 || >=16.14} + /lru-cache@5.1.1: resolution: {integrity: sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==} dependencies: yallist: 3.1.1 - dev: false /lru-cache@6.0.0: resolution: {integrity: sha512-Jo6dJ04CmSjuznwJSS3pUeWmd/H0ffTlkXXgwZi+eq1UCmqQwCh+eLsYOYCwY991i2Fah4h1BEMCx4qThGbsiA==} @@ -7122,21 +10572,28 @@ packages: engines: {node: '>=12'} dev: true - /lru-cache@9.1.1: - resolution: {integrity: sha512-65/Jky17UwSb0BuB9V+MyDpsOtXKmYwzhyl+cOa9XUiI4uV2Ouy/2voFP3+al0BjZbJgMBD8FojMpAf+Z+qn4A==} - engines: {node: 14 || >=16.14} - dev: true - /lz-string@1.5.0: resolution: {integrity: sha512-h5bgJWpxJNswbU7qCrV0tIKQCaS3blPDrqKWx+QxzuzL1zGUzij9XCWLrSLsJPu5t+eWA/ycetzYAO5IOMcWAQ==} hasBin: true - dev: false - /macos-release@3.1.0: - resolution: {integrity: sha512-/M/R0gCDgM+Cv1IuBG1XGdfTFnMEG6PZeT+KGWHO/OG+imqmaD9CH5vHBTycEM3+Kc4uG2Il+tFAuUWLqQOeUA==} + /macos-release@3.2.0: + resolution: {integrity: sha512-fSErXALFNsnowREYZ49XCdOHF8wOPWuFOGQrAhP7x5J/BqQv+B02cNsTykGpDgRVx43EKg++6ANmTaGTtW+hUA==} engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} dev: true + /magic-string@0.25.9: + resolution: {integrity: sha512-RmF0AsMzgt25qzqqLc1+MbHmhdx0ojF2Fvs4XnOqz2ZOBXzzkEwc/dJQZCYHAn7v1jbVOjAZfK8msRn4BxO4VQ==} + dependencies: + sourcemap-codec: 1.4.8 + dev: true + + /magic-string@0.30.7: + resolution: {integrity: sha512-8vBuFF/I/+OSLRmdf2wwFCJCz+nSn0m6DPvGH1fS/KiQoSaR+sETbov0eIk9KhEKy8CYqIkIAnbohxT/4H0kuA==} + engines: {node: '>=12'} + dependencies: + '@jridgewell/sourcemap-codec': 1.4.15 + dev: true + /make-dir@1.3.0: resolution: {integrity: sha512-2w31R7SJtieJJnQtGc7RVL2StM2vGYVfqUOvUDxH6bC6aJTxPxTF0GnIgCyu7tjockiUWAYQRbxa7vKn34s5sQ==} engines: {node: '>=4'} @@ -7149,7 +10606,7 @@ packages: engines: {node: '>=6'} dependencies: pify: 4.0.1 - semver: 5.7.1 + semver: 5.7.2 dev: false /make-dir@3.1.0: @@ -7159,11 +10616,18 @@ packages: semver: 6.3.1 dev: false + /make-dir@4.0.0: + resolution: {integrity: sha512-hXdUTZYIVOt1Ex//jAQi+wTZZpUpwBj/0QsOzqegb3rGMMeJiSEu5xLHnYfBrRV4RH2+OCSOO95Is/7x1WJ4bw==} + engines: {node: '>=10'} + dependencies: + semver: 7.6.0 + dev: false + /make-fetch-happen@10.2.1: resolution: {integrity: sha512-NgOPbRiaQM10DYXvN3/hhGVI2M5MtITFryzBGxHM5p4wnFxsVCbxkrBrDsk+EZ5OB4jEOT7AjDxtdF+KVEFT7w==} engines: {node: ^12.13.0 || ^14.15.0 || >=16.0.0} dependencies: - agentkeepalive: 4.3.0 + agentkeepalive: 4.5.0 cacache: 16.1.3 http-cache-semantics: 4.1.1 http-proxy-agent: 5.0.0 @@ -7188,39 +10652,68 @@ packages: resolution: {integrity: sha512-rLWS7GCSTcEujjVBs2YqG7Y4643u8ucvCJeSRqiLYhesrDuzeuFIk37xREzAsfQaqzl8b9rNCE4m6J8tvX4Q8w==} engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} dependencies: - agentkeepalive: 4.3.0 - cacache: 17.0.7 + agentkeepalive: 4.5.0 + cacache: 17.1.4 http-cache-semantics: 4.1.1 http-proxy-agent: 5.0.0 https-proxy-agent: 5.0.1 is-lambda: 1.0.1 lru-cache: 7.18.3 minipass: 5.0.0 - minipass-fetch: 3.0.3 + minipass-fetch: 3.0.4 minipass-flush: 1.0.5 minipass-pipeline: 1.2.4 negotiator: 0.6.3 promise-retry: 2.0.1 socks-proxy-agent: 7.0.0 - ssri: 10.0.4 + ssri: 10.0.5 transitivePeerDependencies: - supports-color dev: true + /map-age-cleaner@0.1.3: + resolution: {integrity: sha512-bJzx6nMoP6PDLPBFmg7+xRKeFZvFboMrGlxmNj9ClvX53KrmvM5bXFXEWjbz4cz1AFn+jWJ9z/DJSz7hrs0w3w==} + engines: {node: '>=6'} + dependencies: + p-defer: 1.0.0 + dev: true + /map-stream@0.1.0: resolution: {integrity: sha512-CkYQrPYZfWnu/DAmVCpTSX/xHpKZ80eKh2lAkyA6AJTef6bW+6JpbQZN5rofum7da+SyN1bi5ctTm+lTfcCW3g==} dev: true + /matcher@5.0.0: + resolution: {integrity: sha512-s2EMBOWtXFc8dgqvoAzKJXxNHibcdJMV0gwqKUaw9E2JBJuGUK7DrNKrA6g/i+v72TT16+6sVm5mS3thaMLQUw==} + engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} + dependencies: + escape-string-regexp: 5.0.0 + dev: true + + /md5-hex@3.0.1: + resolution: {integrity: sha512-BUiRtTtV39LIJwinWBjqVsU9xhdnz7/i889V859IBFpuqGAj6LuOvHv5XLbgZ2R7ptJoJaEcxkv88/h25T7Ciw==} + engines: {node: '>=8'} + dependencies: + blueimp-md5: 2.19.0 + dev: true + /media-typer@0.3.0: resolution: {integrity: sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==} engines: {node: '>= 0.6'} dev: false - /memfs@3.5.1: - resolution: {integrity: sha512-UWbFJKvj5k+nETdteFndTpYxdeTMox/ULeqX5k/dpaQJCCFmj5EeKv3dBcyO2xmkRAx2vppRu5dVG7SOtsGOzA==} + /mem@9.0.2: + resolution: {integrity: sha512-F2t4YIv9XQUBHt6AOJ0y7lSmP1+cY7Fm1DRh9GClTGzKST7UWLMx6ly9WZdLH/G/ppM5RL4MlQfRT71ri9t19A==} + engines: {node: '>=12.20'} + dependencies: + map-age-cleaner: 0.1.3 + mimic-fn: 4.0.0 + dev: true + + /memfs@3.5.3: + resolution: {integrity: sha512-UERzLsxzllchadvbPs5aolHh65ISpKpM+ccLbOJ8/vvpBKmAWf+la7dXFy7Mr0ySHbdHrFv5kGFCUHHe6GFEmw==} engines: {node: '>= 4.0.0'} dependencies: - fs-monkey: 1.0.3 + fs-monkey: 1.0.5 dev: false /merge-descriptors@1.0.1: @@ -7237,7 +10730,6 @@ packages: /methods@1.1.2: resolution: {integrity: sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==} engines: {node: '>= 0.6'} - dev: false /micromatch@4.0.5: resolution: {integrity: sha512-DMy+ERcEW2q8Z2Po+WNXuw3c5YaUSFjAO5GsJqfEl7UjvtIuFKO6ZrKvcItdy98dwFI2N1tg3zNIdKaQT+aNdA==} @@ -7246,6 +10738,20 @@ packages: braces: 3.0.2 picomatch: 2.3.1 + /microtime@3.1.1: + resolution: {integrity: sha512-to1r7o24cDsud9IhN6/8wGmMx5R2kT0w2Xwm5okbYI3d1dk6Xv0m+Z+jg2vS9pt+ocgQHTCtgs/YuyJhySzxNg==} + engines: {node: '>= 14.13.0'} + requiresBuild: true + dependencies: + node-addon-api: 5.1.0 + node-gyp-build: 4.8.0 + dev: true + + /milliparsec@2.3.0: + resolution: {integrity: sha512-b+6KYJw+DwQjk24qCUuq+lZvRXDpXJ02qsllKgKaDurHpQ0v7D5op9VAkdYM/pXRhFeh7uLYHmnwFnYvdXGa3A==} + engines: {node: '>=12.4'} + dev: true + /mime-db@1.33.0: resolution: {integrity: sha512-BHJ/EKruNIqJf/QahvxwQZXKygOQ256myeN/Ew+THcAa5q+PjyTTMMeNQC4DZw5AwfvelsUrA6B67NKMqXDbzQ==} engines: {node: '>= 0.6'} @@ -7274,6 +10780,12 @@ packages: hasBin: true dev: false + /mime@4.0.1: + resolution: {integrity: sha512-5lZ5tyrIfliMXzFtkYyekWbtRXObT9OWa8IwQ5uxTBDHucNNwniRqo0yInflj+iYi5CBa6qxadGzGarDfuEOxA==} + engines: {node: '>=16'} + hasBin: true + dev: true + /mimic-fn@2.1.0: resolution: {integrity: sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==} engines: {node: '>=6'} @@ -7304,7 +10816,10 @@ packages: /minimalistic-assert@1.0.1: resolution: {integrity: sha512-UtJcAD4yEaGtjPezWuO9wC4nwUnVH/8/Im3yEHQP4b67cXlD/Qr9hdITCU1xDbSEXg2XKNaP8jsReV7vQd00/A==} - dev: false + + /minimalistic-crypto-utils@1.0.1: + resolution: {integrity: sha512-JIYlbt6g8i5jKfJ3xz7rF0LXmv2TkDxBLUkiBeZ7bAx4GnnNMr8xFpGnOxn6GhTEHx3SjRrZEoU+j04prX1ktg==} + dev: true /minimatch@3.1.2: resolution: {integrity: sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==} @@ -7318,19 +10833,11 @@ packages: brace-expansion: 2.0.1 dev: true - /minimatch@7.4.6: - resolution: {integrity: sha512-sBz8G/YjVniEz6lKPNpKxXwazJe4c19fEfV2GDMX6AjFz+MX9uDWIZW8XreVhkFW3fkIdTv/gxWr/Kks5FFAVw==} - engines: {node: '>=10'} - dependencies: - brace-expansion: 2.0.1 - dev: true - /minimatch@9.0.3: resolution: {integrity: sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==} engines: {node: '>=16 || 14 >=14.17'} dependencies: brace-expansion: 2.0.1 - dev: true /minimist@1.2.8: resolution: {integrity: sha512-2yyAR8qBkN3YuheJanUpWC5U3bb5osDywNB8RzDVlDwDHbocAJveqqj1u8+SVD7jkWT4yvsHCpWqqWqAxb0zCA==} @@ -7353,11 +10860,11 @@ packages: encoding: 0.1.13 dev: true - /minipass-fetch@3.0.3: - resolution: {integrity: sha512-n5ITsTkDqYkYJZjcRWzZt9qnZKCT7nKCosJhHoj7S7zD+BP4jVbWs+odsniw5TA3E0sLomhTKOKjF86wf11PuQ==} + /minipass-fetch@3.0.4: + resolution: {integrity: sha512-jHAqnA728uUpIaFm7NWsCnqKT6UqZz7GcI/bDpPATuwYyKwJwW0remxSCxUlKiEty+eopHGa3oc8WxgQ1FFJqg==} engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} dependencies: - minipass: 5.0.0 + minipass: 7.0.4 minipass-sized: 1.0.3 minizlib: 2.1.2 optionalDependencies: @@ -7399,16 +10906,15 @@ packages: yallist: 4.0.0 dev: true - /minipass@4.2.8: - resolution: {integrity: sha512-fNzuVyifolSLFL4NzpF+wEF4qrgqaaKX0haXPQEdQ7NKAN+WecoKMHV09YcuL/DHxrUsYQOK3MiuDf7Ip2OXfQ==} - engines: {node: '>=8'} - dev: true - /minipass@5.0.0: resolution: {integrity: sha512-3FnjYuehv9k6ovOEbyOswadCDPX1piCfhV8ncmYtHOjuPwylVWsghTLo7rabjC3Rx5xD4HDx8Wm1xnMF7S5qFQ==} engines: {node: '>=8'} dev: true + /minipass@7.0.4: + resolution: {integrity: sha512-jYofLM5Dam9279rdkWzqHozUo4ybjdZmCsDHePy5V/PbBcVMiSZR97gmAy45aqi8CK1lG2ECd356FU86avfwUQ==} + engines: {node: '>=16 || 14 >=14.17'} + /minizlib@2.1.2: resolution: {integrity: sha512-bAxsR8BVfj60DWXHE3u30oHzfl4G7khkSuPW+qvpd7jFRHm7dLxOjUk1EHACJ/hxLY8phGJ0YhYHZo7jil7Qdg==} engines: {node: '>= 8'} @@ -7417,12 +10923,38 @@ packages: yallist: 4.0.0 dev: true + /mitt@3.0.1: + resolution: {integrity: sha512-vKivATfr97l2/QBCYAkXYDbrIWPM2IIKEl7YPhjCvKlG3kE2gm+uBo6nEXK3M5/Ffh/FLpKExzOQ3JJoJGFKBw==} + dev: true + + /mkdirp-classic@0.5.3: + resolution: {integrity: sha512-gKLcREMhtuZRwRAfqP3RFW+TK4JqApVBtOIftVgjuABpAtpxhPGaDcfvbhNvD0B8iD1oUr/txX35NjcaY6Ns/A==} + dev: true + /mkdirp@1.0.4: resolution: {integrity: sha512-vVqVZQyf3WLx2Shd0qJ9xuvqgAyKPLAiqITEtqW0oIUjzo3PePDd6fW9iFz30ef7Ysp/oiWqbhszeGWW2T6Gzw==} engines: {node: '>=10'} hasBin: true dev: true + /mlly@1.6.1: + resolution: {integrity: sha512-vLgaHvaeunuOXHSmEbZ9izxPx3USsk8KCQ8iC+aTlp5sKRSoZvwhHh5L9VbKSaVC6sJDqbyohIS76E2VmHIPAA==} + dependencies: + acorn: 8.11.3 + pathe: 1.1.2 + pkg-types: 1.0.3 + ufo: 1.4.0 + dev: true + + /module-details-from-path@1.0.3: + resolution: {integrity: sha512-ySViT69/76t8VhE1xXHK6Ch4NcDd26gx0MzKXLO+F7NOtnqH68d9zF94nT8ZWSxXh8ELOERsnJO/sWt1xZYw5A==} + dev: true + + /mrmime@2.0.0: + resolution: {integrity: sha512-eu38+hdgojoyq63s+yTpN4XMBdt5l8HhMhc4VKLO9KM5caLIBvUm4thi7fFaxyTmCKeNnXZ5pAlBwCUnhA09uw==} + engines: {node: '>=10'} + dev: true + /ms@2.0.0: resolution: {integrity: sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==} @@ -7432,19 +10964,48 @@ packages: /ms@2.1.3: resolution: {integrity: sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==} + /msgpack-lite@0.1.26: + resolution: {integrity: sha512-SZ2IxeqZ1oRFGo0xFGbvBJWMp3yLIY9rlIJyxy8CGrwZn1f0ZK4r6jV/AM1r0FZMDUkWkglOk/eeKIL9g77Nxw==} + hasBin: true + dependencies: + event-lite: 0.1.3 + ieee754: 1.2.1 + int64-buffer: 0.1.10 + isarray: 1.0.0 + dev: true + /multicast-dns@7.2.5: resolution: {integrity: sha512-2eznPJP8z2BFLX50tf0LuODrpINqP1RVIm/CObbTcBRITQgmC/TjcREF1NeTBzIcR5XO/ukWo+YHOjBbFwIupg==} hasBin: true dependencies: - dns-packet: 5.6.0 + dns-packet: 5.6.1 thunky: 1.1.0 dev: false + /mute-stream@0.0.8: + resolution: {integrity: sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==} + dev: true + /mute-stream@1.0.0: resolution: {integrity: sha512-avsJQhyd+680gKXyG/sQc0nXaC6rBkPOfyHYcFb9+hdkqQkR9bdnkJ0AMZhke0oesPqIO+mFFJ+IdBc7mst4IA==} engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} dev: true + /n-readlines@1.0.1: + resolution: {integrity: sha512-z4SyAIVgMy7CkgsoNw7YVz40v0g4+WWvvqy8+ZdHrCtgevcEO758WQyrYcw3XPxcLxF+//RszTz/rO48nzD0wQ==} + engines: {node: '>=6.x.x'} + dev: true + + /nanoid@3.3.7: + resolution: {integrity: sha512-eSRppjcPIatRIMC1U6UngP8XFcz8MQWGQdt1MTBQ7NaAmvXDfvNxbvWV3x2y6CdEUciCSsDHDQZbhYaB8QEo2g==} + engines: {node: ^10 || ^12 || ^13.7 || ^14 || >=15.0.1} + hasBin: true + dev: true + + /napi-build-utils@1.0.2: + resolution: {integrity: sha512-ONmRUqK7zj7DWX0D9ADe03wbwOBZxNAfF20PlGfCWQcD3+/MakShIHrMqx9YwPTfxDdF1zLeL+RGZiR9kGMLdg==} + dev: true + /natural-compare@1.4.0: resolution: {integrity: sha512-OWND8ei3VtNC9h7V60qff3SVobHr996CTwgxubgyQYEpg290h9J0buyECNNJexkFm5sOajh5G116RYA1c8ZMSw==} dev: true @@ -7473,16 +11034,35 @@ packages: resolution: {integrity: sha512-fgAN3jGAh+RoxUGZHTSOLJIqUc2wmoBwGR4tbpNAKmmovFoWq0OdRkb0VkldReO2a2iBT/OEulG9XSUc10r3zg==} dependencies: lower-case: 2.0.2 - tslib: 2.6.1 + tslib: 2.6.2 dev: false + /node-abi@3.56.0: + resolution: {integrity: sha512-fZjdhDOeRcaS+rcpve7XuwHBmktS1nS1gzgghwKUQQ8nTy2FdSDr6ZT8k6YhvlJeHmmQMYiT/IH9hfco5zeW2Q==} + engines: {node: '>=10'} + dependencies: + semver: 7.6.0 + dev: true + + /node-abort-controller@3.1.1: + resolution: {integrity: sha512-AGK2yQKIjRuqnc6VkX2Xj5d+QW8xZ87pa1UK6yA6ouUyuxfHuMP6umE5QK7UmTeOAymo+Zx1Fxiuw9rVx8taHQ==} + dev: true + + /node-addon-api@5.1.0: + resolution: {integrity: sha512-eh0GgfEkpnoWDq+VY8OyvYhFEzBk6jIYbRKdIlyTiAXIVJ8PyBaKb0rp7oDtoddbdoHWhq8wwr+XZ81F1rpNdA==} + dev: true + + /node-addon-api@6.1.0: + resolution: {integrity: sha512-+eawOlIgy680F0kBzPUNFhMZGtJ1YmqM6l4+Crf4IkImjYrO/mqPwRMh352g23uIaQKFItcQ64I7KMaJxHgAVA==} + dev: true + /node-domexception@1.0.0: resolution: {integrity: sha512-/jKZoMpw0F8GRwl4/eLROPA3cfcXtLApP0QzLmUT/HuPCZWyB7IY9ZrMeKw2O/nFIqPQB3PVM9aYm0F312AXDQ==} engines: {node: '>=10.5.0'} dev: true - /node-fetch@2.6.9: - resolution: {integrity: sha512-DJm/CJkZkRjKKj4Zi4BsKVZh3ValV5IR5s7LVZnW+6YMh0W1BfNA8XSs6DLMGYlId5F3KnA70uu2qepcR08Qqg==} + /node-fetch@2.7.0: + resolution: {integrity: sha512-c4FRfUm/dbcWZ7U+1Wq0AwCyFL+3nt2bEw05wfxSz+DWpWsitgmSgYmy2dQdWyKC1694ELPqMs/YzUSNozLt8A==} engines: {node: 4.x || >=6.0.0} peerDependencies: encoding: ^0.1.0 @@ -7506,20 +11086,31 @@ packages: engines: {node: '>= 6.13.0'} dev: false - /node-gyp@9.3.1: - resolution: {integrity: sha512-4Q16ZCqq3g8awk6UplT7AuxQ35XN4R/yf/+wSAwcBUAjg7l58RTactWaP8fIDTi0FzI7YcVLujwExakZlfWkXg==} + /node-gyp-build@3.9.0: + resolution: {integrity: sha512-zLcTg6P4AbcHPq465ZMFNXx7XpKKJh+7kkN699NiQWisR2uWYOWNWqRHAmbnmKiL4e9aLSlmy5U7rEMUXV59+A==} + hasBin: true + dev: true + + /node-gyp-build@4.8.0: + resolution: {integrity: sha512-u6fs2AEUljNho3EYTJNBfImO5QTo/J/1Etd+NVdCj7qWKUSN/bSLkZwhDv7I+w/MSC6qJ4cknepkAYykDdK8og==} + hasBin: true + dev: true + + /node-gyp@9.4.1: + resolution: {integrity: sha512-OQkWKbjQKbGkMf/xqI1jjy3oCTgMKJac58G2+bjZb3fza6gW2YrCSdMQYaoTb70crvE//Gngr4f0AgVHmqHvBQ==} engines: {node: ^12.13 || ^14.13 || >=16} hasBin: true dependencies: env-paths: 2.2.1 + exponential-backoff: 3.1.1 glob: 7.2.3 graceful-fs: 4.2.11 make-fetch-happen: 10.2.1 nopt: 6.0.0 npmlog: 6.0.2 rimraf: 3.0.2 - semver: 7.5.4 - tar: 6.1.13 + semver: 7.6.0 + tar: 6.2.0 which: 2.0.2 transitivePeerDependencies: - bluebird @@ -7533,9 +11124,13 @@ packages: process-on-spawn: 1.0.0 dev: false - /node-releases@2.0.10: - resolution: {integrity: sha512-5GFldHPXVG/YZmFzJvKK2zDSzPKhEp0+ZR5SVaoSag9fsL5YgHbUHDfnG5494ISANDcK4KwPXAx2xqVEydmd7w==} - dev: false + /node-releases@2.0.14: + resolution: {integrity: sha512-y10wOWt8yZpqXmOgRo77WaHEmhYQYGNA6y421PKsKYWEK8aW+cqAphborZDhqfyKrbZEN92CN1X2KbafY2s7Yw==} + + /nofilter@3.1.0: + resolution: {integrity: sha512-l2NNj07e9afPnhAhvgVrCD/oy2Ai1yfLpuo3EpiO1jFTsB4sFz6oIfAfSZyQzVpkZQ9xS8ZS5g1jCBgq4Hwo0g==} + engines: {node: '>=12.19'} + dev: true /nopt@6.0.0: resolution: {integrity: sha512-ZwLpbTgdhuZUnZzjd7nb1ZV+4DoiC6/sfiVKok72ym/4Tlf+DFdlHYmT2JPmcNNWV6Pi3SDf1kT+A4r9RTuT9g==} @@ -7549,8 +11144,8 @@ packages: resolution: {integrity: sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==} dependencies: hosted-git-info: 2.8.9 - resolve: 1.22.2 - semver: 5.7.1 + resolve: 1.22.8 + semver: 5.7.2 validate-npm-package-license: 3.0.4 dev: true @@ -7559,15 +11154,14 @@ packages: engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} dependencies: hosted-git-info: 6.1.1 - is-core-module: 2.12.1 - semver: 7.5.4 + is-core-module: 2.13.1 + semver: 7.6.0 validate-npm-package-license: 3.0.4 dev: true /normalize-path@3.0.0: resolution: {integrity: sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==} engines: {node: '>=0.10.0'} - dev: false /normalize-url@2.0.1: resolution: {integrity: sha512-D6MUW4K/VzoJ4rJ01JFKxDrtY1v9wrgzCX5f2qj/lzH1m/lW6MhUZFKerVsnyjOhOsYzI9Kqqak+10l4LvLpMw==} @@ -7587,11 +11181,11 @@ packages: resolution: {integrity: sha512-Vq0eyEQy+elFpzsKjMss9kxqb9tG3YHg4dsyWuUENuzvSUWe1TCnW/vV9FkhvBk/brEDoDiVd+M1Btosa6ImdQ==} engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} dependencies: - npm-normalize-package-bin: 3.0.0 + npm-normalize-package-bin: 3.0.1 dev: true - /npm-check-updates@16.12.2: - resolution: {integrity: sha512-N0jeEcak3/+PS1O5JzwJ2+fvmQVv+084O4iRnDtcMBLcr9S7vPOBxwWgsEuNfj3shKFZRYOuh4NHB9nMenCHXA==} + /npm-check-updates@16.14.15: + resolution: {integrity: sha512-WH0wJ9j6CP7Azl+LLCxWAYqroT2IX02kRIzgK/fg0rPpMbETgHITWBdOPtrv521xmA3JMgeNsQ62zvVtS/nCmQ==} engines: {node: '>=14.14'} hasBin: true dependencies: @@ -7600,7 +11194,7 @@ packages: commander: 10.0.1 fast-memoize: 2.5.2 find-up: 5.0.0 - fp-and-or: 0.1.3 + fp-and-or: 0.1.4 get-stdin: 8.0.0 globby: 11.1.0 hosted-git-info: 5.2.1 @@ -7618,11 +11212,12 @@ packages: prompts-ncu: 3.0.0 rc-config-loader: 4.1.3 remote-git-tags: 3.0.0 - rimraf: 5.0.1 - semver: 7.5.4 + rimraf: 5.0.5 + semver: 7.6.0 semver-utils: 1.1.4 source-map-support: 0.5.21 - spawn-please: 2.0.1 + spawn-please: 2.0.2 + strip-ansi: 7.1.0 strip-json-comments: 5.0.1 untildify: 4.0.0 update-notifier: 6.0.2 @@ -7631,15 +11226,15 @@ packages: - supports-color dev: true - /npm-install-checks@6.1.1: - resolution: {integrity: sha512-dH3GmQL4vsPtld59cOn8uY0iOqRmqKvV+DLGwNXV/Q7MDgD2QfOADWd/mFXcIE5LVhYYGjA3baz6W9JneqnuCw==} + /npm-install-checks@6.3.0: + resolution: {integrity: sha512-W29RiK/xtpCGqn6f3ixfRYGk+zRyr+Ew9F2E20BfXxT5/euLdA/Nm7fO7OeTGuAmTs30cpgInyJ0cYe708YTZw==} engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} dependencies: - semver: 7.5.4 + semver: 7.6.0 dev: true - /npm-normalize-package-bin@3.0.0: - resolution: {integrity: sha512-g+DPQSkusnk7HYXr75NtzkIP4+N81i3RPsGFidF3DzHd9MT9wWngmqoeg/fnHFz5MNdtG4w03s+QnhewSLTT2Q==} + /npm-normalize-package-bin@3.0.1: + resolution: {integrity: sha512-dMxCf+zZ+3zeQZXKxmyuCKlIDPGuv8EF940xbkC4kQVDTtqoh6rJFO+JTKSA6/Rwi0getWmtuy4Itup0AMcaDQ==} engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} dev: true @@ -7649,7 +11244,7 @@ packages: dependencies: hosted-git-info: 6.1.1 proc-log: 3.0.0 - semver: 7.5.4 + semver: 7.6.0 validate-npm-package-name: 5.0.0 dev: true @@ -7657,17 +11252,17 @@ packages: resolution: {integrity: sha512-d6RGEuRrNS5/N84iglPivjaJPxhDbZmlbTwTDX2IbcRHG5bZCdtysYMhwiPvcF4GisXHGn7xsxv+GQ7T/02M5Q==} engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} dependencies: - ignore-walk: 6.0.3 + ignore-walk: 6.0.4 dev: true - /npm-pick-manifest@8.0.1: - resolution: {integrity: sha512-mRtvlBjTsJvfCCdmPtiu2bdlx8d/KXtF7yNXNWe7G0Z36qWA9Ny5zXsI2PfBZEv7SXgoxTmNaTzGSbbzDZChoA==} + /npm-pick-manifest@8.0.2: + resolution: {integrity: sha512-1dKY+86/AIiq1tkKVD3l0WI+Gd3vkknVGAggsFeBkTvbhMQ1OND/LKkYv4JtXPKUJ8bOTCyLiqEg2P6QNdK+Gg==} engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} dependencies: - npm-install-checks: 6.1.1 - npm-normalize-package-bin: 3.0.0 + npm-install-checks: 6.3.0 + npm-normalize-package-bin: 3.0.1 npm-package-arg: 10.1.0 - semver: 7.5.4 + semver: 7.6.0 dev: true /npm-registry-fetch@14.0.5: @@ -7676,7 +11271,7 @@ packages: dependencies: make-fetch-happen: 11.1.1 minipass: 5.0.0 - minipass-fetch: 3.0.3 + minipass-fetch: 3.0.4 minipass-json-stream: 1.0.1 minizlib: 2.1.2 npm-package-arg: 10.1.0 @@ -7691,8 +11286,8 @@ packages: dependencies: path-key: 3.1.1 - /npm-run-path@5.1.0: - resolution: {integrity: sha512-sJOdmRGrY2sjNTRMbSvluQqg+8X7ZK61yvzBEIDhz4f8z1TZFYABsqjjCBd/0PUNE9M6QDgHJXQkGUEm7Q+l9Q==} + /npm-run-path@5.3.0: + resolution: {integrity: sha512-ppwTtiJZq0O/ai0z7yfudtBpWIoxM8yE6nHi1X47eFR2EWORqfbu6CnPlNsjeN683eT0qG6H/Pyf9fCcvjnnnQ==} engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} dependencies: path-key: 4.0.0 @@ -7728,13 +11323,13 @@ packages: foreground-child: 2.0.0 get-package-type: 0.1.0 glob: 7.2.3 - istanbul-lib-coverage: 3.2.0 + istanbul-lib-coverage: 3.2.2 istanbul-lib-hook: 3.0.0 istanbul-lib-instrument: 4.0.3 istanbul-lib-processinfo: 2.0.3 - istanbul-lib-report: 3.0.0 + istanbul-lib-report: 3.0.1 istanbul-lib-source-maps: 4.0.1 - istanbul-reports: 3.1.5 + istanbul-reports: 3.1.7 make-dir: 3.1.0 node-preload: 0.2.1 p-map: 3.0.0 @@ -7754,66 +11349,59 @@ packages: engines: {node: '>=0.10.0'} dev: false - /object-inspect@1.12.3: - resolution: {integrity: sha512-geUvdk7c+eizMNUDkRpW1wJwgfOiOeHbxBR/hLXK1aT6zmVSO0jsQcs7fj6MGw89jC/cjGfLcNOrtMYtGqm81g==} - - /object-is@1.1.5: - resolution: {integrity: sha512-3cyDsyHgtmi7I7DfSSI2LDp6SK2lwvtbg0p0R1e0RvTqF5ceGx+K2dfSjm1bKDMVCFEDAQvy+o8c6a7VujOddw==} - engines: {node: '>= 0.4'} - dependencies: - call-bind: 1.0.2 - define-properties: 1.2.0 - dev: false + /object-inspect@1.13.1: + resolution: {integrity: sha512-5qoj1RUiKOMsCCNLV1CBiPYE10sziTsnmNxkAI/rZhiD63CF7IqdFGC/XzjWjpSgLf0LxXX3bDFIh0E18f6UhQ==} /object-keys@1.1.1: resolution: {integrity: sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==} engines: {node: '>= 0.4'} - /object.assign@4.1.4: - resolution: {integrity: sha512-1mxKf0e58bvyjSCtKYY4sRe9itRk3PJpquJOjeIkz885CczcI4IvJJDLPS72oowuSh+pBxUFROpX+TU++hxhZQ==} + /object.assign@4.1.5: + resolution: {integrity: sha512-byy+U7gp+FVwmyzKPYhW2h5l3crpmGsxl7X2s8y43IgxvG4g3QZ6CffDtsNQy1WsmZpQbO+ybo0AlW7TY6DcBQ==} engines: {node: '>= 0.4'} dependencies: - call-bind: 1.0.2 - define-properties: 1.2.0 + call-bind: 1.0.7 + define-properties: 1.2.1 has-symbols: 1.0.3 object-keys: 1.1.1 - /object.fromentries@2.0.6: - resolution: {integrity: sha512-VciD13dswC4j1Xt5394WR4MzmAQmlgN72phd/riNp9vtD7tp4QQWJ0R4wvclXcafgcYK8veHRed2W6XeGBvcfg==} + /object.fromentries@2.0.7: + resolution: {integrity: sha512-UPbPHML6sL8PI/mOqPwsH4G6iyXcCGzLin8KvEPenOZN5lpCNBZZQ+V62vdjB1mQHrmqGQt5/OJzemUA+KJmEA==} engines: {node: '>= 0.4'} dependencies: - call-bind: 1.0.2 - define-properties: 1.2.0 - es-abstract: 1.21.2 + call-bind: 1.0.7 + define-properties: 1.2.1 + es-abstract: 1.22.4 dev: true - /object.getownpropertydescriptors@2.1.6: - resolution: {integrity: sha512-lq+61g26E/BgHv0ZTFgRvi7NMEPuAxLkFU7rukXjc/AlwH4Am5xXVnIXy3un1bg/JPbXHrixRkK1itUzzPiIjQ==} + /object.getownpropertydescriptors@2.1.7: + resolution: {integrity: sha512-PrJz0C2xJ58FNn11XV2lr4Jt5Gzl94qpy9Lu0JlfEj14z88sqbSBJCBEzdlNUCzY2gburhbrwOZ5BHCmuNUy0g==} engines: {node: '>= 0.8'} dependencies: - array.prototype.reduce: 1.0.5 - call-bind: 1.0.2 - define-properties: 1.2.0 - es-abstract: 1.21.2 - safe-array-concat: 1.0.0 + array.prototype.reduce: 1.0.6 + call-bind: 1.0.7 + define-properties: 1.2.1 + es-abstract: 1.22.4 + safe-array-concat: 1.1.0 dev: false - /object.groupby@1.0.0: - resolution: {integrity: sha512-70MWG6NfRH9GnbZOikuhPPYzpUpof9iW2J9E4dW7FXTqPNb6rllE6u39SKwwiNh8lCwX3DDb5OgcKGiEBrTTyw==} + /object.groupby@1.0.2: + resolution: {integrity: sha512-bzBq58S+x+uo0VjurFT0UktpKHOZmv4/xePiOA1nbB9pMqpGK7rUPNgf+1YC+7mE+0HzhTMqNUuCqvKhj6FnBw==} dependencies: - call-bind: 1.0.2 - define-properties: 1.2.0 - es-abstract: 1.21.2 - get-intrinsic: 1.2.1 + array.prototype.filter: 1.0.3 + call-bind: 1.0.7 + define-properties: 1.2.1 + es-abstract: 1.22.4 + es-errors: 1.3.0 dev: true - /object.values@1.1.6: - resolution: {integrity: sha512-FVVTkD1vENCsAcwNs9k6jea2uHC/X0+JcjG8YA60FN5CMaJmG95wT9jek/xX9nornqGRrBkKtzuAu2wuHpKqvw==} + /object.values@1.1.7: + resolution: {integrity: sha512-aU6xnDFYT3x17e/f0IiiwlGPTy2jzMySGfUB4fq6z7CV8l85CWHDk5ErhyhpfDHhrOMwGFhSQkhMGHaIotA6Ng==} engines: {node: '>= 0.4'} dependencies: - call-bind: 1.0.2 - define-properties: 1.2.0 - es-abstract: 1.21.2 + call-bind: 1.0.7 + define-properties: 1.2.1 + es-abstract: 1.22.4 dev: true /obuf@1.1.2: @@ -7836,6 +11424,12 @@ packages: dependencies: wrappy: 1.0.2 + /one-time@1.0.0: + resolution: {integrity: sha512-5DXOiRKwuSEcQ/l0kGCF6Q3jcADFv5tSmRaJck/OqkVFcOzutB134KRSfF0xDrL39MNnqxbHBbUUcjZIhTgb2g==} + dependencies: + fn.name: 1.1.0 + dev: true + /onetime@5.1.2: resolution: {integrity: sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==} engines: {node: '>=6'} @@ -7867,6 +11461,16 @@ packages: is-wsl: 2.2.0 dev: true + /opener@1.5.2: + resolution: {integrity: sha512-ur5UIdyw5Y7yEj9wLzhqXiy6GZ3Mwx0yGI+5sMn2r0N0v3cKJvUmFH5yPP+WXh9e0xfyzyJX95D8l088DNFj7A==} + hasBin: true + dev: true + + /opentracing@0.14.7: + resolution: {integrity: sha512-vz9iS7MJ5+Bp1URw8Khvdyw1H/hGvzHWlKQ7eRrQojSCDL1/SrWfrY9QebLw97n2deyRtzHRC3MkQfVNUCo91Q==} + engines: {node: '>=0.10'} + dev: true + /optionator@0.9.3: resolution: {integrity: sha512-JjCoypp+jKn1ttEFExxhetCKeJt9zhAgAve5FXHixTvFDW/5aEktX9bufBKLRRMdU7bNtpLfcGu94B3cdEJgjg==} engines: {node: '>= 0.8.0'} @@ -7886,7 +11490,7 @@ packages: bl: 4.1.0 chalk: 4.1.2 cli-cursor: 3.1.0 - cli-spinners: 2.9.0 + cli-spinners: 2.9.2 is-interactive: 1.0.0 is-unicode-supported: 0.1.0 log-symbols: 4.1.0 @@ -7900,7 +11504,7 @@ packages: dependencies: chalk: 5.3.0 cli-cursor: 4.0.0 - cli-spinners: 2.9.0 + cli-spinners: 2.9.2 is-interactive: 2.0.0 is-unicode-supported: 1.3.0 log-symbols: 5.1.0 @@ -7918,8 +11522,8 @@ packages: resolution: {integrity: sha512-YEIoAnM6zFmzw3PQ201gCVCIWbXNyKObGlVvpAVvraAeOHnlYVKFssbA/riRX5R40WA6kKrZ7Dr7dWzO3nKSeQ==} engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} dependencies: - macos-release: 3.1.0 - windows-release: 5.1.0 + macos-release: 3.2.0 + windows-release: 5.1.1 dev: true /os-tmpdir@1.0.2: @@ -7941,6 +11545,11 @@ packages: engines: {node: '>=12.20'} dev: true + /p-defer@1.0.0: + resolution: {integrity: sha512-wB3wfAxZpk2AzOfUMJNL+d36xothRSyj8EXOa4f6GMqYDN9BJaaSISbsk+wS9abmnebVw95C2Kb5t85UmpCxuw==} + engines: {node: '>=4'} + dev: true + /p-event@2.3.1: resolution: {integrity: sha512-NQCqOFhbpVTMX4qMe8PF8lbGtzZ+LCiN7pcNrb/413Na7+TRoe1xkKUzuWa/YEJdGQ0FvKtj35EEbDoVPO2kbA==} engines: {node: '>=6'} @@ -7948,6 +11557,13 @@ packages: p-timeout: 2.0.1 dev: false + /p-event@5.0.1: + resolution: {integrity: sha512-dd589iCQ7m1L0bmC5NLlVYfy3TbBEsMUfWx9PyAgPeIcFZ/E2yaTZ4Rz4MiBmmJShviiftHVXOqfnfzJ6kyMrQ==} + engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} + dependencies: + p-timeout: 5.1.0 + dev: true + /p-finally@1.0.0: resolution: {integrity: sha512-LICb2p9CB7FS+0eR1oqWnHhp0FljGLZCWBE9aix0Uye9W8LTQPwMTYVGWQWIw9RdQiDg4+epXQODwIYJtSJaow==} engines: {node: '>=4'} @@ -7976,7 +11592,13 @@ packages: engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} dependencies: yocto-queue: 1.0.0 - dev: false + + /p-limit@5.0.0: + resolution: {integrity: sha512-/Eaoq+QyLSiXQ4lyYV23f14mZRQcXnxfHrN0vCai+ak9G0pp9iEQukIIZq5NccEvwRB8PUnZT0KsOoDCINS1qQ==} + engines: {node: '>=18'} + dependencies: + yocto-queue: 1.0.0 + dev: true /p-locate@4.1.0: resolution: {integrity: sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==} @@ -7996,7 +11618,6 @@ packages: engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} dependencies: p-limit: 4.0.0 - dev: false /p-map@3.0.0: resolution: {integrity: sha512-d3qXVTF/s+W+CdJ5A29wywV2n8CQQYahlgz2bFiA+4eVNJbHJodPZ+/gXwPGh0bOqA+j8S+6+ckmvLGPk1QpxQ==} @@ -8011,6 +11632,13 @@ packages: dependencies: aggregate-error: 3.1.0 + /p-map@5.5.0: + resolution: {integrity: sha512-VFqfGDHlx87K66yZrNdI4YGtD70IRyd+zSvgks6mzHPRNkoKy+9EKP4SFC77/vTTQYmRmti7dvqC+m5jBrBAcg==} + engines: {node: '>=12'} + dependencies: + aggregate-error: 4.0.1 + dev: true + /p-retry@4.6.2: resolution: {integrity: sha512-312Id396EbJdvRONlngUx0NydfrIQ5lsYu0znKVUzVvArzEIt08V1qhtyESbGVd1FGX7UKtiFp5uwKZdM8wIuQ==} engines: {node: '>=8'} @@ -8026,32 +11654,36 @@ packages: p-finally: 1.0.0 dev: false + /p-timeout@5.1.0: + resolution: {integrity: sha512-auFDyzzzGZZZdHz3BtET9VEz0SE/uMEAx7uWfGPucfzEwwe/xH0iVeZibQmANYE/hp9T2+UUZT5m+BKyrDp3Ew==} + engines: {node: '>=12'} + dev: true + /p-try@2.2.0: resolution: {integrity: sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==} engines: {node: '>=6'} - /pac-proxy-agent@7.0.0: - resolution: {integrity: sha512-t4tRAMx0uphnZrio0S0Jw9zg3oDbz1zVhQ/Vy18FjLfP1XOLNUEjaVxYCYRI6NS+BsMBXKIzV6cTLOkO9AtywA==} + /pac-proxy-agent@7.0.1: + resolution: {integrity: sha512-ASV8yU4LLKBAjqIPMbrgtaKIvxQri/yh2OpI+S6hVa9JRkUI3Y3NPFbfngDtY7oFtSMD3w31Xns89mDa3Feo5A==} engines: {node: '>= 14'} dependencies: '@tootallnate/quickjs-emscripten': 0.23.0 agent-base: 7.1.0 debug: 4.3.4(supports-color@8.1.1) - get-uri: 6.0.1 - http-proxy-agent: 7.0.0 - https-proxy-agent: 7.0.1 - pac-resolver: 7.0.0 - socks-proxy-agent: 8.0.1 + get-uri: 6.0.3 + http-proxy-agent: 7.0.2 + https-proxy-agent: 7.0.4 + pac-resolver: 7.0.1 + socks-proxy-agent: 8.0.2 transitivePeerDependencies: - supports-color dev: true - /pac-resolver@7.0.0: - resolution: {integrity: sha512-Fd9lT9vJbHYRACT8OhCbZBbxr6KRSawSovFpy8nDGshaK99S/EBhVIHp9+crhxrsZOuvLpgL1n23iyPg6Rl2hg==} + /pac-resolver@7.0.1: + resolution: {integrity: sha512-5NPgf87AT2STgwa2ntRMr45jTKrYBGkVU36yT0ig/n/GMAa3oPqhZfIQ2kMEimReg0+t9kZViDVZ83qfVUlckg==} engines: {node: '>= 14'} dependencies: degenerator: 5.0.1 - ip: 1.1.8 netmask: 2.0.2 dev: true @@ -8065,14 +11697,14 @@ packages: release-zalgo: 1.0.0 dev: false - /package-json@8.1.0: - resolution: {integrity: sha512-hySwcV8RAWeAfPsXb9/HGSPn8lwDnv6fabH+obUZKX169QknRkRhPxd1yMubpKDskLFATkl3jHpNtVtDPFA0Wg==} + /package-json@8.1.1: + resolution: {integrity: sha512-cbH9IAIJHNj9uXi196JVsRlt7cHKak6u/e6AkL/bkRelZ7rlL3X1YKxsZwa36xipOEKAsdtmaG6aAJoM1fx2zA==} engines: {node: '>=14.16'} dependencies: - got: 12.6.0 + got: 12.6.1 registry-auth-token: 5.0.2 registry-url: 6.0.1 - semver: 7.5.4 + semver: 7.6.0 dev: true /pacote@15.2.0: @@ -8080,34 +11712,38 @@ packages: engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} hasBin: true dependencies: - '@npmcli/git': 4.0.4 + '@npmcli/git': 4.1.0 '@npmcli/installed-package-contents': 2.0.2 '@npmcli/promise-spawn': 6.0.2 - '@npmcli/run-script': 6.0.1 - cacache: 17.0.7 - fs-minipass: 3.0.2 + '@npmcli/run-script': 6.0.2 + cacache: 17.1.4 + fs-minipass: 3.0.3 minipass: 5.0.0 npm-package-arg: 10.1.0 npm-packlist: 7.0.4 - npm-pick-manifest: 8.0.1 + npm-pick-manifest: 8.0.2 npm-registry-fetch: 14.0.5 proc-log: 3.0.0 promise-retry: 2.0.1 - read-package-json: 6.0.2 + read-package-json: 6.0.4 read-package-json-fast: 3.0.2 - sigstore: 1.4.0 - ssri: 10.0.4 - tar: 6.1.13 + sigstore: 1.9.0 + ssri: 10.0.5 + tar: 6.2.0 transitivePeerDependencies: - bluebird - supports-color dev: true + /pako@2.1.0: + resolution: {integrity: sha512-w+eufiZ1WuJYgPXbV/PO3NCMEc3xqylkKHzp8bxp1uW4qaSNQUkwmLLEc3kKsfz8lpV1F8Ht3U1Cm+9Srog2ug==} + dev: true + /param-case@3.0.4: resolution: {integrity: sha512-RXlj7zCYokReqWpOPH9oYivUzLYZ5vAPIfEmCTNViosC78F8F0H9y7T7gG2M39ymgutxF5gcFEsyZQSph9Bp3A==} dependencies: dot-case: 3.0.4 - tslib: 2.6.1 + tslib: 2.6.2 dev: false /parent-module@1.0.1: @@ -8127,12 +11763,17 @@ packages: resolution: {integrity: sha512-ayCKvm/phCGxOkYRSCM82iDwct8/EonSEgCSxWxD7ve6jHggsFl4fZVQBPRNgQoKiuV/odhFrGzQXZwbifC8Rg==} engines: {node: '>=8'} dependencies: - '@babel/code-frame': 7.21.4 + '@babel/code-frame': 7.23.5 error-ex: 1.3.2 json-parse-even-better-errors: 2.3.1 lines-and-columns: 1.2.4 dev: true + /parse-ms@3.0.0: + resolution: {integrity: sha512-Tpb8Z7r7XbbtBTrM9UhpkzzaMrqA2VXMT3YChzYltwV3P3pM6t8wl7TvpMnSTosz1aQAdVib7kdoys7vYOPerw==} + engines: {node: '>=12'} + dev: true + /parse-path@7.0.0: resolution: {integrity: sha512-Euf9GG8WT9CdqwuWJGdf3RkUcTBArppHABkO7Lm8IzRQp0e2r/kkFnmhu4TSK30Wcu5rVAZLmfPKSBBi9tWFog==} dependencies: @@ -8154,7 +11795,7 @@ packages: resolution: {integrity: sha512-uWlGT3YSnK9x3BQJaOdcZwrnV6hPpd8jFH1/ucpiLRPh/2zCVJKS19E4GvYHvaCcACn3foXZ0cLB9Wrx1KGe5g==} dependencies: no-case: 3.0.4 - tslib: 2.6.1 + tslib: 2.6.2 dev: false /pascalcase@1.0.0: @@ -8169,7 +11810,6 @@ packages: /path-exists@5.0.0: resolution: {integrity: sha512-RjhtfwJOxzcFmNOi6ltcbcu4Iu+FL3zEj83dk4kAS+fVpTxXLO1b38RvJgT/0QwvV/L3aY9TAnyv0EOqW4GoMQ==} engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} - dev: false /path-is-absolute@1.0.1: resolution: {integrity: sha512-AVbw3UJ2e9bq64vSaS9Am0fje1Pa8pbGqTTsmXfaIiMpnr5DlDhfJOuLj9Sf95ZPVDAUerDfEk88MPmPe7UCQg==} @@ -8194,13 +11834,11 @@ packages: resolution: {integrity: sha512-MkhCqzzBEpPvxxQ71Md0b1Kk51W01lrYvlMzSUaIzNsODdd7mqhiimSZlr+VegAz5Z6Vzt9Xg2ttE//XBhH3EQ==} engines: {node: '>=16 || 14 >=14.17'} dependencies: - lru-cache: 9.1.1 - minipass: 5.0.0 - dev: true + lru-cache: 10.2.0 + minipass: 7.0.4 /path-to-regexp@0.1.7: resolution: {integrity: sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ==} - dev: false /path-to-regexp@2.2.1: resolution: {integrity: sha512-gu9bD6Ta5bwGrrU8muHzVOBFFREpp2iRkVfhBJahwJ6p6Xw20SjT0MxLnwkjOibQmGSYhiUnf2FLe7k+jcFmGQ==} @@ -8210,6 +11848,14 @@ packages: resolution: {integrity: sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==} engines: {node: '>=8'} + /pathe@1.1.2: + resolution: {integrity: sha512-whLdWMYL2TwI08hn8/ZqAbrVemu0LNaNNJZX73O6qaIdCTfXutsLhMkjdENX0qhsQ9uIimo4/aQOmXkoon2nDQ==} + dev: true + + /pathval@1.1.1: + resolution: {integrity: sha512-Dp6zGqpTdETdR63lehJYPeIOqpiNBNtc7BpWSLrOje7UaIsE5aY92r/AunQA7rsXvet3lrJ3JnZX29UPTKXyKQ==} + dev: true + /pause-stream@0.0.11: resolution: {integrity: sha512-e3FBlXLmN/D1S+zHzanP4E/4Z60oFAa3O051qt1pxa7DEJWKAyil6upYVXCWadEnuoqa4Pkc9oUx9zsxYeRv8A==} dependencies: @@ -8218,7 +11864,6 @@ packages: /pend@1.2.0: resolution: {integrity: sha512-F3asv42UuXchdzt+xXqfW1OGlVBe+mxa2mqI0pg5yAHZPvFmY3Y6drSf/GQ1A86WgWEN9Kzh/WrgKa6iGcHXLg==} - dev: false /performance-now@2.1.0: resolution: {integrity: sha512-7EAHlyLHI56VEIdK57uwHdHKIaAGbnXPiw0yWbarQZOKaKpvUIgW0jWRVLiatnM+XXlSwsanIBH/hzGMJulMow==} @@ -8258,6 +11903,14 @@ packages: engines: {node: '>=0.10.0'} dev: false + /pkg-conf@4.0.0: + resolution: {integrity: sha512-7dmgi4UY4qk+4mj5Cd8v/GExPo0K+SlY+hulOSdfZ/T6jVH6//y7NtzZo5WrfhDBxuQ0jCa7fLZmNaNh7EWL/w==} + engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} + dependencies: + find-up: 6.3.0 + load-json-file: 7.0.1 + dev: true + /pkg-dir@4.2.0: resolution: {integrity: sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==} engines: {node: '>=8'} @@ -8265,17 +11918,85 @@ packages: find-up: 4.1.0 dev: false - /playwright-core@1.37.0: - resolution: {integrity: sha512-1c46jhTH/myQw6sesrcuHVtLoSNfJv8Pfy9t3rs6subY7kARv0HRw5PpyfPYPpPtQvBOmgbE6K+qgYUpj81LAA==} + /pkg-dir@7.0.0: + resolution: {integrity: sha512-Ie9z/WINcxxLp27BKOCHGde4ITq9UklYKDzVo1nhk5sqGEXU3FpkwP5GM2voTGJkGd9B3Otl+Q4uwSOeSUtOBA==} + engines: {node: '>=14.16'} + dependencies: + find-up: 6.3.0 + dev: false + + /pkg-types@1.0.3: + resolution: {integrity: sha512-nN7pYi0AQqJnoLPC9eHFQ8AcyaixBUOwvqc5TDnIKCMEE6I0y8P7OKA7fPexsXGCGxQDl/cmrLAp26LhcwxZ4A==} + dependencies: + jsonc-parser: 3.2.1 + mlly: 1.6.1 + pathe: 1.1.2 + dev: true + + /playwright-core@1.42.0: + resolution: {integrity: sha512-0HD9y8qEVlcbsAjdpBaFjmaTHf+1FeIddy8VJLeiqwhcNqGCBe4Wp2e8knpqiYbzxtxarxiXyNDw2cG8sCaNMQ==} + engines: {node: '>=16'} + hasBin: true + dev: false + + /playwright@1.42.0: + resolution: {integrity: sha512-Ko7YRUgj5xBHbntrgt4EIw/nE//XBHOKVKnBjO1KuZkmkhlbgyggTe5s9hjqQ1LpN+Xg+kHsQyt5Pa0Bw5XpvQ==} engines: {node: '>=16'} hasBin: true + dependencies: + playwright-core: 1.42.0 + optionalDependencies: + fsevents: 2.3.2 dev: false + /plur@5.1.0: + resolution: {integrity: sha512-VP/72JeXqak2KiOzjgKtQen5y3IZHn+9GOuLDafPv0eXa47xq0At93XahYBs26MsifCQ4enGKwbjBTKgb9QJXg==} + engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} + dependencies: + irregular-plurals: 3.5.0 + dev: true + /pluralize@8.0.0: resolution: {integrity: sha512-Nc3IT5yHzflTfbjgqWcCPpo7DaKy4FnpB0l/zCAW0Tc7jxAiuqSxHasntB3D7887LSrA93kDJ9IXovxJYxyLCA==} engines: {node: '>=4'} dev: true + /possible-typed-array-names@1.0.0: + resolution: {integrity: sha512-d7Uw+eZoloe0EHDIYoe+bQ5WXnGMOpmiZFTuMWCwpjzzkL2nTjcKiAk4hh8TjnGye2TwWOk3UXucZ+3rbmBa8Q==} + engines: {node: '>= 0.4'} + + /postcss@8.4.35: + resolution: {integrity: sha512-u5U8qYpBCpN13BsiEB0CbR1Hhh4Gc0zLFuedrHJKMctHCHAGrMdG0PRM/KErzAL3CU6/eckEtmHNB3x6e3c0vA==} + engines: {node: ^10 || ^12 || >=14} + dependencies: + nanoid: 3.3.7 + picocolors: 1.0.0 + source-map-js: 1.0.2 + dev: true + + /pprof-format@2.0.7: + resolution: {integrity: sha512-1qWaGAzwMpaXJP9opRa23nPnt2Egi7RMNoNBptEE/XwHbcn4fC2b/4U4bKc5arkGkIh2ZabpF2bEb+c5GNHEKA==} + dev: true + + /prebuild-install@7.1.1: + resolution: {integrity: sha512-jAXscXWMcCK8GgCoHOfIr0ODh5ai8mj63L2nWrjuAgXE6tDyYGnx4/8o/rCgU+B4JSyZBKbeZqzhtwtC3ovxjw==} + engines: {node: '>=10'} + hasBin: true + dependencies: + detect-libc: 2.0.2 + expand-template: 2.0.3 + github-from-package: 0.0.0 + minimist: 1.2.8 + mkdirp-classic: 0.5.3 + napi-build-utils: 1.0.2 + node-abi: 3.56.0 + pump: 3.0.0 + rc: 1.2.8 + simple-get: 4.0.1 + tar-fs: 2.1.1 + tunnel-agent: 0.6.0 + dev: true + /prelude-ls@1.2.1: resolution: {integrity: sha512-vkcDPrRZo1QZLbn5RLGPpg/WmIQ65qoWWhcGKf/b5eplkkarX0m9z8ppCat4mlOqUsWpyNuYgO3VRyrYHSzX5g==} engines: {node: '>= 0.8.0'} @@ -8290,11 +12011,11 @@ packages: resolution: {integrity: sha512-GbK2cP9nraSSUF9N2XwUwqfzlAFlMNYYl+ShE/V+H8a9uNl/oUqB1w2EL54Jh0OlyRSd8RfWYJ3coVS4TROP2w==} engines: {node: '>=6.0.0'} dependencies: - fast-diff: 1.2.0 + fast-diff: 1.3.0 dev: true - /prettier@3.0.2: - resolution: {integrity: sha512-o2YR9qtniXvwEZlOKbveKfDQVyqxbEIWn48Z8m3ZJjBjcCmUy3xZGIv+7AkaeuaTr6yPXJjwv07ZWlsWbEy1rQ==} + /prettier@3.2.5: + resolution: {integrity: sha512-3/GWa9aOC0YeD7LUfvOG2NiDyhOWRvt1k+rcKhOuYnMY24iiCphgneUfJDyFXd6rZCAnuLBv6UeAULtrhT/F4A==} engines: {node: '>=14'} hasBin: true dev: true @@ -8325,7 +12046,22 @@ packages: ansi-regex: 5.0.1 ansi-styles: 5.2.0 react-is: 17.0.2 - dev: false + + /pretty-format@29.7.0: + resolution: {integrity: sha512-Pdlw/oPxN+aXdmM9R00JVC9WVFoCLTKJvDVLgmJ+qAffBMxsV85l/Lu7sNx4zSzPyoL2euImuEwHhOXdEgNFZQ==} + engines: {node: ^14.15.0 || ^16.10.0 || >=18.0.0} + dependencies: + '@jest/schemas': 29.6.3 + ansi-styles: 5.2.0 + react-is: 18.2.0 + dev: true + + /pretty-ms@8.0.0: + resolution: {integrity: sha512-ASJqOugUF1bbzI35STMBUpZqdfYKlJugy6JBziGi2EE+AL5JPJGSzvpeVXojxrr0ViUYoToUjb5kjSEGf7Y83Q==} + engines: {node: '>=14.16'} + dependencies: + parse-ms: 3.0.0 + dev: true /proc-log@3.0.0: resolution: {integrity: sha512-++Vn7NS4Xf9NacaU9Xq3URUuqZETPsf8L4j5/ckhaRYsfPeRyzGw+iDjFhV/Jr3uNmTvvddEJFWh5R1gRgUH8A==} @@ -8348,6 +12084,13 @@ packages: engines: {node: '>=0.4.0'} dev: true + /prom-client@13.1.0: + resolution: {integrity: sha512-jT9VccZCWrJWXdyEtQddCDszYsiuWj5T0ekrPszi/WEegj3IZy6Mm09iOOVM86A4IKMWq8hZkT2dD9MaSe+sng==} + engines: {node: '>=10'} + dependencies: + tdigest: 0.1.2 + dev: true + /promise-inflight@1.0.1: resolution: {integrity: sha512-6zWPyEOFaQBJYcGMHBKTKJ3u6TBsnMFOIZSa6ce1e/ZrrsOlnHRHbabMjLiBYKp+n44X9eUI6VUPaukCXHuG4g==} peerDependencies: @@ -8365,15 +12108,15 @@ packages: retry: 0.12.0 dev: true - /promise.allsettled@1.0.6: - resolution: {integrity: sha512-22wJUOD3zswWFqgwjNHa1965LvqTX87WPu/lreY2KSd7SVcERfuZ4GfUaOnJNnvtoIv2yXT/W00YIGMetXtFXg==} + /promise.allsettled@1.0.7: + resolution: {integrity: sha512-hezvKvQQmsFkOdrZfYxUxkyxl8mgFQeT259Ajj9PXdbg9VzBCWrItOev72JyWxkCD5VSSqAeHmlN3tWx4DlmsA==} engines: {node: '>= 0.4'} dependencies: - array.prototype.map: 1.0.5 - call-bind: 1.0.2 - define-properties: 1.2.0 - es-abstract: 1.21.2 - get-intrinsic: 1.2.1 + array.prototype.map: 1.0.6 + call-bind: 1.0.7 + define-properties: 1.2.1 + es-abstract: 1.22.4 + get-intrinsic: 1.2.4 iterate-value: 1.0.2 dev: true @@ -8389,6 +12132,45 @@ packages: resolution: {integrity: sha512-vtK/94akxsTMhe0/cbfpR+syPuszcuwhqVjJq26CuNDgFGj682oRBXOP5MJpv2r7JtE8MsiepGIqvvOTBwn2vA==} dev: true + /protobufjs@6.11.4: + resolution: {integrity: sha512-5kQWPaJHi1WoCpjTGszzQ32PG2F4+wRY6BmAT4Vfw56Q2FZ4YZzK20xUYQH4YkfehY1e6QSICrJquM6xXZNcrw==} + hasBin: true + requiresBuild: true + dependencies: + '@protobufjs/aspromise': 1.1.2 + '@protobufjs/base64': 1.1.2 + '@protobufjs/codegen': 2.0.4 + '@protobufjs/eventemitter': 1.1.0 + '@protobufjs/fetch': 1.1.0 + '@protobufjs/float': 1.0.2 + '@protobufjs/inquire': 1.1.0 + '@protobufjs/path': 1.1.2 + '@protobufjs/pool': 1.1.0 + '@protobufjs/utf8': 1.1.0 + '@types/long': 4.0.2 + '@types/node': 20.11.21 + long: 4.0.0 + dev: true + + /protobufjs@7.2.6: + resolution: {integrity: sha512-dgJaEDDL6x8ASUZ1YqWciTRrdOuYNzoOf27oHNfdyvKqHr5i0FV7FSLU+aIeFjyFgVxrpTOtQUi0BLLBymZaBw==} + engines: {node: '>=12.0.0'} + requiresBuild: true + dependencies: + '@protobufjs/aspromise': 1.1.2 + '@protobufjs/base64': 1.1.2 + '@protobufjs/codegen': 2.0.4 + '@protobufjs/eventemitter': 1.1.0 + '@protobufjs/fetch': 1.1.0 + '@protobufjs/float': 1.0.2 + '@protobufjs/inquire': 1.1.0 + '@protobufjs/path': 1.1.2 + '@protobufjs/pool': 1.1.0 + '@protobufjs/utf8': 1.1.0 + '@types/node': 20.11.21 + long: 5.2.3 + dev: true + /protocols@2.0.1: resolution: {integrity: sha512-/XJ368cyBJ7fzLMwLKv1e4vLxOju2MNAIokcr7meSaNcVbWz/CPcW22cP04mwxOErdA5mwjA8Q6w/cdAQxVn7Q==} dev: true @@ -8401,18 +12183,18 @@ packages: ipaddr.js: 1.9.1 dev: false - /proxy-agent@6.3.0: - resolution: {integrity: sha512-0LdR757eTj/JfuU7TL2YCuAZnxWXu3tkJbg4Oq3geW/qFNT/32T0sp2HnZ9O0lMR4q3vwAt0+xCA8SR0WAD0og==} + /proxy-agent@6.3.1: + resolution: {integrity: sha512-Rb5RVBy1iyqOtNl15Cw/llpeLH8bsb37gM1FUfKQ+Wck6xHlbAhWGUFiTRHtkjqGTA5pSHz6+0hrPW/oECihPQ==} engines: {node: '>= 14'} dependencies: agent-base: 7.1.0 debug: 4.3.4(supports-color@8.1.1) - http-proxy-agent: 7.0.0 - https-proxy-agent: 7.0.1 + http-proxy-agent: 7.0.2 + https-proxy-agent: 7.0.4 lru-cache: 7.18.3 - pac-proxy-agent: 7.0.0 + pac-proxy-agent: 7.0.1 proxy-from-env: 1.1.0 - socks-proxy-agent: 8.0.1 + socks-proxy-agent: 8.0.2 transitivePeerDependencies: - supports-color dev: true @@ -8441,14 +12223,13 @@ packages: dependencies: end-of-stream: 1.4.4 once: 1.4.0 - dev: false /punycode@1.4.1: resolution: {integrity: sha512-jmYNElW7yvO7TV33CjSmvSiE2yco3bV2czu/OzDKdMNVZQWfxCblURLhf+47syQRBntjfLdd/H0egrzIG+oaFQ==} dev: true - /punycode@2.3.0: - resolution: {integrity: sha512-rRV+zQD8tVFys26lAGR9WUuS4iUAngJScM+ZRSKtvl5tKeZ2t5bvdNFdNHBW9FWR4guGHlgmsZ1G7BSm2wTbuA==} + /punycode@2.3.1: + resolution: {integrity: sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==} engines: {node: '>=6'} /pupa@3.1.0: @@ -8458,18 +12239,56 @@ packages: escape-goat: 4.0.0 dev: true + /puppeteer-core@21.11.0: + resolution: {integrity: sha512-ArbnyA3U5SGHokEvkfWjW+O8hOxV1RSJxOgriX/3A4xZRqixt9ZFHD0yPgZQF05Qj0oAqi8H/7stDorjoHY90Q==} + engines: {node: '>=16.13.2'} + dependencies: + '@puppeteer/browsers': 1.9.1 + chromium-bidi: 0.5.8(devtools-protocol@0.0.1232444) + cross-fetch: 4.0.0 + debug: 4.3.4(supports-color@8.1.1) + devtools-protocol: 0.0.1232444 + ws: 8.16.0 + transitivePeerDependencies: + - bufferutil + - encoding + - supports-color + - utf-8-validate + dev: true + + /puppeteer@21.11.0(typescript@5.3.3): + resolution: {integrity: sha512-9jTHuYe22TD3sNxy0nEIzC7ZrlRnDgeX3xPkbS7PnbdwYjl2o/z/YuCrRBwezdKpbTDTJ4VqIggzNyeRcKq3cg==} + engines: {node: '>=16.13.2'} + hasBin: true + requiresBuild: true + dependencies: + '@puppeteer/browsers': 1.9.1 + cosmiconfig: 9.0.0(typescript@5.3.3) + puppeteer-core: 21.11.0 + transitivePeerDependencies: + - bufferutil + - encoding + - supports-color + - typescript + - utf-8-validate + dev: true + + /pure-rand@6.0.4: + resolution: {integrity: sha512-LA0Y9kxMYv47GIPJy6MI84fqTd2HmYZI83W/kM/SkKfDlajnZYfmXFTxkbY+xSBPkLJxltMa9hIkmdc29eguMA==} + dev: true + /qs@6.10.4: resolution: {integrity: sha512-OQiU+C+Ds5qiH91qh/mg0w+8nwQuLjM4F4M/PbmhDOoYehPh+Fb0bDjtR1sOvy7YKxvj28Y/M0PhP5uVX0kB+g==} engines: {node: '>=0.6'} dependencies: - side-channel: 1.0.4 + side-channel: 1.0.5 dev: false /qs@6.11.0: resolution: {integrity: sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==} engines: {node: '>=0.6'} dependencies: - side-channel: 1.0.4 + side-channel: 1.0.5 dev: false /query-string@5.1.1: @@ -8494,6 +12313,10 @@ packages: /queue-microtask@1.2.3: resolution: {integrity: sha512-NuaNSa6flKT5JaSYQzJok04JzTL1CA6aGhv5rfLW3PgqA+M2ChpZQnAC8h8i4ZFkBS8X5RqkDBHA7r4hej3K9A==} + /queue-tick@1.0.1: + resolution: {integrity: sha512-kJt5qhMxoszgU/62PLP1CJytzd2NKetjSRnyuj31fDd3Rlcz3fzlFdFLD1SItunPwyqEOkca6GbV612BWfaBag==} + dev: true + /quick-lru@5.1.1: resolution: {integrity: sha512-WuyALRjWPDGtt/wzJiadO5AXY+8hZ80hVpe6MyivgraREW751X3SbhRvG3eLKOYN+8VEvqLcf3wdnt44Z4S4SA==} engines: {node: '>=10'} @@ -8554,35 +12377,41 @@ packages: loose-envify: 1.4.0 react: 18.2.0 scheduler: 0.23.0 - dev: false /react-is@17.0.2: resolution: {integrity: sha512-w2GsyukL62IJnlaff/nRegPQR94C/XXamvMWmSHRJ4y7Ts/4ocGRmTHvOs8PSE6pB3dWOrD/nueuU5sduBsQ4w==} - dev: false + + /react-is@18.2.0: + resolution: {integrity: sha512-xWGDIW6x921xtzPkhiULtthJHoJvBbF3q26fzloPCK0hsvxtPVelvftw3zjbHWSkR2km9Z+4uxbDDK/6Zw9B8w==} + dev: true + + /react-refresh@0.14.0: + resolution: {integrity: sha512-wViHqhAd8OHeLS/IRMJjTSDHF3U9eWi62F/MledQGPdJGDhodXJ9PBLNGr6WWL7qlH12Mt3TyTpbS+hGXMjCzQ==} + engines: {node: '>=0.10.0'} + dev: true /react@18.2.0: resolution: {integrity: sha512-/3IjMdb2L9QbBdWiW5e3P2/npwMBaU9mHCSCUzNln0ZCYbcfTsGbTJrU/kGemdH2IWmB2ioZ+zkxtmq6g09fGQ==} engines: {node: '>=0.10.0'} dependencies: loose-envify: 1.4.0 - dev: false /read-package-json-fast@3.0.2: resolution: {integrity: sha512-0J+Msgym3vrLOUB3hzQCuZHII0xkNGCtz/HJH9xZshwv9DbDwkw1KaE3gx/e2J5rpEY5rtOy6cyhKOPrkP7FZw==} engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} dependencies: - json-parse-even-better-errors: 3.0.0 - npm-normalize-package-bin: 3.0.0 + json-parse-even-better-errors: 3.0.1 + npm-normalize-package-bin: 3.0.1 dev: true - /read-package-json@6.0.2: - resolution: {integrity: sha512-Ismd3km1d/FGzcjm8fBf/4ktkyd0t6pbkjYqu1gvRzOzN+aTxi1eigdZp7441TlszQ+GsdYezgS+g9cgy8QK9w==} + /read-package-json@6.0.4: + resolution: {integrity: sha512-AEtWXYfopBj2z5N5PbkAOeNHRPUg5q+Nen7QLxV8M2zJq1ym6/lCz3fYNTCXe19puu2d06jfHhrP7v/S2PtMMw==} engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} dependencies: - glob: 10.3.3 - json-parse-even-better-errors: 3.0.0 + glob: 10.3.10 + json-parse-even-better-errors: 3.0.1 normalize-package-data: 5.0.0 - npm-normalize-package-bin: 3.0.0 + npm-normalize-package-bin: 3.0.1 dev: true /read-pkg-up@7.0.1: @@ -8598,7 +12427,7 @@ packages: resolution: {integrity: sha512-Ug69mNOpfvKDAc2Q8DRpMjjzdtrnv9HcSMX+4VsZxD1aZ6ZzrIE7rlzXBtWTyhULSMKg076AW6WR5iZpD0JiOg==} engines: {node: '>=8'} dependencies: - '@types/normalize-package-data': 2.4.1 + '@types/normalize-package-data': 2.4.4 normalize-package-data: 2.5.0 parse-json: 5.2.0 type-fest: 0.6.0 @@ -8629,17 +12458,20 @@ packages: engines: {node: '>=8.10.0'} dependencies: picomatch: 2.3.1 - dev: false + + /readonly-date@1.0.0: + resolution: {integrity: sha512-tMKIV7hlk0h4mO3JTmmVuIlJVXjKk3Sep9Bf5OH0O+758ruuVkUy2J9SttDLm91IEX/WHlXPSpxMGjPj4beMIQ==} + dev: true /rechoir@0.6.2: resolution: {integrity: sha512-HFM8rkZ+i3zrV+4LQjwQ0W+ez98pApMGM3HUrN04j3CqzPOzl9nmP15Y8YXNm8QHGv/eacOVEjqhmWpkRV0NAw==} engines: {node: '>= 0.10'} dependencies: - resolve: 1.22.3 + resolve: 1.22.8 dev: true - /regenerate-unicode-properties@10.1.0: - resolution: {integrity: sha512-d1VudCLoIGitcU/hEg2QqvyGZQmdC0Lf8BqdOMXGFSvJP4bNV1+XqbPQeHHLD51Jh4QJJ225dlIFvY4Ly6MXmQ==} + /regenerate-unicode-properties@10.1.1: + resolution: {integrity: sha512-X007RyZLsCJVVrjgEFVpLUTZwyOZk3oiL75ZcuYjlIWd6rNJtOjkBwQc5AsRrpbKVkxN6sklw/k/9m2jJYOf8Q==} engines: {node: '>=4'} dependencies: regenerate: 1.4.2 @@ -8653,14 +12485,13 @@ packages: resolution: {integrity: sha512-MguG95oij0fC3QV3URf4V2SDYGJhJnJGqvIIgdECeODCT98wSWDAJ94SSuVpYQUoTcGUIL6L4yNB7j1DFFHSBg==} dev: false - /regenerator-runtime@0.13.11: - resolution: {integrity: sha512-kY1AZVr2Ra+t+piVaJ4gxaFaReZVH40AKNo7UCX6W+dEwBo/2oZJzqfuN1qLq1oL45o56cPaTXELwrTh8Fpggg==} - dev: false + /regenerator-runtime@0.14.1: + resolution: {integrity: sha512-dYnhHh0nJoMfnkZs6GmmhFknAGRrLznOu5nc9ML+EJxGvrx6H7teuevqVqCuPcPK//3eDrrjQhehXVx9cnkGdw==} - /regenerator-transform@0.15.1: - resolution: {integrity: sha512-knzmNAcuyxV+gQCufkYcvOqX/qIIfHLv0u5x79kRxuGojfYVky1f15TzZEu2Avte8QGepvUNTnLskf8E6X6Vyg==} + /regenerator-transform@0.15.2: + resolution: {integrity: sha512-hfMp2BoF0qOk3uc5V20ALGDS2ddjQaLrdl7xrGXvAIow7qeWRM2VA2HuCHkUKk9slq3VwEwLNK3DFBqDfPGYtg==} dependencies: - '@babel/runtime': 7.21.5 + '@babel/runtime': 7.23.9 dev: false /regexp-tree@0.1.27: @@ -8668,13 +12499,19 @@ packages: hasBin: true dev: true - /regexp.prototype.flags@1.5.0: - resolution: {integrity: sha512-0SutC3pNudRKgquxGoRGIz946MZVHqbNfPjBdxeOhBrdgDKlRoXmYLQN9xRbrR09ZXWeGAdPuif7egofn6v5LA==} + /regexp.prototype.flags@1.5.2: + resolution: {integrity: sha512-NcDiDkTLuPR+++OCKB0nWafEmhg/Da8aUPLPMQbK+bxKKCm1/S5he+AqYa4PlMCVBalb4/yxIRub6qkEx5yJbw==} engines: {node: '>= 0.4'} dependencies: - call-bind: 1.0.2 - define-properties: 1.2.0 - functions-have-names: 1.2.3 + call-bind: 1.0.7 + define-properties: 1.2.1 + es-errors: 1.3.0 + set-function-name: 2.0.2 + + /regexparam@2.0.2: + resolution: {integrity: sha512-A1PeDEYMrkLrfyOwv2jwihXbo9qxdGD3atBYQA9JJgreAx8/7rC6IUkWOw2NQlOxLp2wL0ifQbh1HuidDfYA6w==} + engines: {node: '>=8'} + dev: true /regexpp@3.2.0: resolution: {integrity: sha512-pq2bWo9mVD43nbts2wGv17XLiNLya+GklZ8kaDLV2Z08gDCsGpnKn9BFMepvWuHCbyVvY7J5o5+BVvoQbmlJLg==} @@ -8687,7 +12524,7 @@ packages: dependencies: '@babel/regjsgen': 0.8.0 regenerate: 1.4.2 - regenerate-unicode-properties: 10.1.0 + regenerate-unicode-properties: 10.1.1 regjsparser: 0.9.1 unicode-match-property-ecmascript: 2.0.0 unicode-match-property-value-ecmascript: 2.1.0 @@ -8704,7 +12541,7 @@ packages: resolution: {integrity: sha512-o/3ikDxtXaA59BmZuZrJZDJv8NMDGSj+6j6XaeBmHw8eY1i1qd9+6H+LjVvQXx3HN6aRCGa1cUdJ9RaJZUugnQ==} engines: {node: '>=14'} dependencies: - '@pnpm/npm-conf': 2.2.0 + '@pnpm/npm-conf': 2.2.2 dev: true /registry-url@3.1.0: @@ -8740,8 +12577,8 @@ packages: engines: {node: '>= 0.10'} dev: false - /release-it@16.1.5: - resolution: {integrity: sha512-w/zCljPZBSYcCwR9fjDB1zaYwie1CAQganUrwNqjtXacXhrrsS5E6dDUNLcxm2ypu8GWAgZNMJfuBJqIO2E7fA==} + /release-it@16.3.0(typescript@5.3.3): + resolution: {integrity: sha512-CP+WwKbgEvXreq6Iz9po3BtcyELtTxrt5RXRGnazQ0eCphPxFZR29+8sEZRCsJq2IKvlwb5mFUbf92u426oQog==} engines: {node: '>=16'} hasBin: true dependencies: @@ -8749,12 +12586,12 @@ packages: '@octokit/rest': 19.0.13 async-retry: 1.3.3 chalk: 5.3.0 - cosmiconfig: 8.2.0 + cosmiconfig: 8.3.6(typescript@5.3.3) execa: 7.2.0 git-url-parse: 13.1.0 globby: 13.2.2 got: 13.0.0 - inquirer: 9.2.10 + inquirer: 9.2.11 is-ci: 3.0.1 issue-parser: 6.0.0 lodash: 4.17.21 @@ -8764,8 +12601,8 @@ packages: open: 9.1.0 ora: 7.0.1 os-name: 5.1.0 - promise.allsettled: 1.0.6 - proxy-agent: 6.3.0 + promise.allsettled: 1.0.7 + proxy-agent: 6.3.1 semver: 7.5.4 shelljs: 0.8.5 update-notifier: 6.0.2 @@ -8775,6 +12612,7 @@ packages: transitivePeerDependencies: - encoding - supports-color + - typescript dev: true /release-zalgo@1.0.0: @@ -8812,13 +12650,12 @@ packages: /request-progress@3.0.0: resolution: {integrity: sha512-MnWzEHHaxHO2iWiQuHrUPBi/1WeBf5PkxQqNyNvLl9VAYSdXkP8tQ3pBSeCPD+yw0v0Aq1zosWLz0BdeXpWwZg==} dependencies: - throttleit: 1.0.0 + throttleit: 1.0.1 dev: false /require-directory@2.1.1: resolution: {integrity: sha512-fGxEI7+wsG9xrvdjsrlmL22OMTTiHRwAMroiEeMgq8gzoLC/PQr7RsRDSTLUg/bZAZtF+TVIkHc6/4RIKrui+Q==} engines: {node: '>=0.10.0'} - dev: false /require-from-string@2.0.2: resolution: {integrity: sha512-Xf0nWe6RseziFMu+Ap9biiUbmplq6S9/p+7w7YXP/JBHhrUDDUhwa+vANyubuqfZWTveU//DYVGsDG7RKL/vEw==} @@ -8836,6 +12673,13 @@ packages: resolution: {integrity: sha512-0a1F4l73/ZFZOakJnQ3FvkJ2+gSTQWz/r2KE5OdDY0TxPm5h4GkqkWWfM47T7HsbnOtcJVEF4epCVy6u7Q3K+g==} dev: true + /resolve-cwd@3.0.0: + resolution: {integrity: sha512-OrZaX2Mb+rJCpH/6CpSqt9xFVpN++x01XnN2ie9g6P5/3xelLAkXWVADpdz1IHD/KFfEXyE6V0U01OQ3UO2rEg==} + engines: {node: '>=8'} + dependencies: + resolve-from: 5.0.0 + dev: true + /resolve-from@4.0.0: resolution: {integrity: sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==} engines: {node: '>=4'} @@ -8844,22 +12688,16 @@ packages: /resolve-from@5.0.0: resolution: {integrity: sha512-qYg9KP24dD5qka9J47d0aVky0N+b4fTU89LN9iDnjB5waksiC49rvMB0PrUJQGoTmH50XPiqOvAjDfaijGxYZw==} engines: {node: '>=8'} - dev: false - /resolve@1.22.2: - resolution: {integrity: sha512-Sb+mjNHOULsBv818T40qSPeRiuWLyaGMa5ewydRLFimneixmVy2zdivRl+AF6jaYPC8ERxGDmFSiqui6SfPd+g==} - hasBin: true - dependencies: - is-core-module: 2.12.0 - path-parse: 1.0.7 - supports-preserve-symlinks-flag: 1.0.0 + /resolve-pkg-maps@1.0.0: + resolution: {integrity: sha512-seS2Tj26TBVOC2NIc2rOe2y2ZO7efxITtLZcGSOnHHNOQ7CkiUBfw0Iw2ck6xkIhPwLhKNLS8BO+hEpngQlqzw==} dev: true - /resolve@1.22.3: - resolution: {integrity: sha512-P8ur/gp/AmbEzjr729bZnLjXK5Z+4P0zhIJgBgzqRih7hL7BOukHGtSTA3ACMY467GRFz3duQsi0bDZdR7DKdw==} + /resolve@1.22.8: + resolution: {integrity: sha512-oKWePCxqpd6FlLvGV1VU0x7bkPmmCNolxzjMf4NczoDnQcIWrAF+cPtZn5i6n+RfD2d9i0tzpKnG6Yk168yIyw==} hasBin: true dependencies: - is-core-module: 2.12.1 + is-core-module: 2.13.1 path-parse: 1.0.7 supports-preserve-symlinks-flag: 1.0.0 @@ -8904,8 +12742,8 @@ packages: resolution: {integrity: sha512-U9nH88a3fc/ekCF1l0/UP1IosiuIjyTh7hBvXVMHYgVcfGvt897Xguj2UOLDeI5BG2m7/uwyaLVT6fbtCwTyzw==} engines: {iojs: '>=1.0.0', node: '>=0.10.0'} - /rfdc@1.3.0: - resolution: {integrity: sha512-V2hovdzFbOi77/WajaSMXk2OLm+xNIeQdMMuB7icj7bk6zi2F8GGAxigcnDFpJHbNyNcgyJDiP+8nOrY5cZGrA==} + /rfdc@1.3.1: + resolution: {integrity: sha512-r5a3l5HzYlIC68TpmYKlxWjmOP6wiPJ1vWv2HeLhNsRZMrCkxeqxiHlQ21oXmQ4F3SiryXBHhAD7JZqvOJjFmg==} dev: false /rimraf@3.0.2: @@ -8914,12 +12752,50 @@ packages: dependencies: glob: 7.2.3 - /rimraf@5.0.1: - resolution: {integrity: sha512-OfFZdwtd3lZ+XZzYP/6gTACubwFcHdLRqS9UX3UwpU2dnGQYkPFISRwvM3w9IiB2w7bW5qGo/uAwE4SmXXSKvg==} + /rimraf@5.0.5: + resolution: {integrity: sha512-CqDakW+hMe/Bz202FPEymy68P+G50RfMQK+Qo5YUqc9SPipvbGjCGKd0RSKEelbsfQuw3g5NZDSrlZZAJurH1A==} engines: {node: '>=14'} hasBin: true dependencies: - glob: 10.3.3 + glob: 10.3.10 + + /rollup@2.79.1: + resolution: {integrity: sha512-uKxbd0IhMZOhjAiD5oAFp7BqvkA4Dv47qpOCtaNvng4HBwdbWtdOh8f5nZNuk2rp51PMGk3bzfWu5oayNEuYnw==} + engines: {node: '>=10.0.0'} + hasBin: true + optionalDependencies: + fsevents: 2.3.3 + dev: true + + /rollup@3.29.4: + resolution: {integrity: sha512-oWzmBZwvYrU0iJHtDmhsm662rC15FRXmcjCk1xD771dFDx5jJ02ufAQQTn0etB2emNk4J9EZg/yWKpsn9BWGRw==} + engines: {node: '>=14.18.0', npm: '>=8.0.0'} + hasBin: true + optionalDependencies: + fsevents: 2.3.3 + dev: true + + /rollup@4.12.0: + resolution: {integrity: sha512-wz66wn4t1OHIJw3+XU7mJJQV/2NAfw5OAk6G6Hoo3zcvz/XOfQ52Vgi+AN4Uxoxi0KBBwk2g8zPrTDA4btSB/Q==} + engines: {node: '>=18.0.0', npm: '>=8.0.0'} + hasBin: true + dependencies: + '@types/estree': 1.0.5 + optionalDependencies: + '@rollup/rollup-android-arm-eabi': 4.12.0 + '@rollup/rollup-android-arm64': 4.12.0 + '@rollup/rollup-darwin-arm64': 4.12.0 + '@rollup/rollup-darwin-x64': 4.12.0 + '@rollup/rollup-linux-arm-gnueabihf': 4.12.0 + '@rollup/rollup-linux-arm64-gnu': 4.12.0 + '@rollup/rollup-linux-arm64-musl': 4.12.0 + '@rollup/rollup-linux-riscv64-gnu': 4.12.0 + '@rollup/rollup-linux-x64-gnu': 4.12.0 + '@rollup/rollup-linux-x64-musl': 4.12.0 + '@rollup/rollup-win32-arm64-msvc': 4.12.0 + '@rollup/rollup-win32-ia32-msvc': 4.12.0 + '@rollup/rollup-win32-x64-msvc': 4.12.0 + fsevents: 2.3.3 dev: true /run-applescript@5.0.0: @@ -8929,6 +12805,11 @@ packages: execa: 5.1.1 dev: true + /run-async@2.4.1: + resolution: {integrity: sha512-tvVnVv01b8c1RrA6Ep7JkStj85Guv/YrMcwqYQnwjsAS2cTmmPGBBjAjpCW7RrSodNSoE2/qg9O4bceNvUuDgQ==} + engines: {node: '>=0.12.0'} + dev: true + /run-async@3.0.0: resolution: {integrity: sha512-540WwVDOMxA6dN6We19EcT9sc3hkXPw5mzRNGM3FkdN/vtE9NFvj5lFAPNwUDmJjXidm3v7TC1cTE7t17Ulm1Q==} engines: {node: '>=0.12.0'} @@ -8942,17 +12823,16 @@ packages: /rxjs@7.8.1: resolution: {integrity: sha512-AA3TVj+0A2iuIoQkWEK/tqFjBq2j+6PO6Y0zJcvzLAFhEFIO3HL0vls9hWLncZbAAbK0mar7oZ4V079I/qPMxg==} dependencies: - tslib: 2.6.1 + tslib: 2.6.2 - /safe-array-concat@1.0.0: - resolution: {integrity: sha512-9dVEFruWIsnie89yym+xWTAYASdpw3CJV7Li/6zBewGf9z2i1j31rP6jnY0pHEO4QZh6N0K11bFjWmdR8UGdPQ==} + /safe-array-concat@1.1.0: + resolution: {integrity: sha512-ZdQ0Jeb9Ofti4hbt5lX3T2JcAamT9hfzYU1MNB+z/jaEbB6wfFfPIR/zEORmZqobkCCJhSjodobH6WHNmJ97dg==} engines: {node: '>=0.4'} dependencies: - call-bind: 1.0.2 - get-intrinsic: 1.2.1 + call-bind: 1.0.7 + get-intrinsic: 1.2.4 has-symbols: 1.0.3 isarray: 2.0.5 - dev: false /safe-buffer@5.1.2: resolution: {integrity: sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==} @@ -8960,13 +12840,19 @@ packages: /safe-buffer@5.2.1: resolution: {integrity: sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==} - /safe-regex-test@1.0.0: - resolution: {integrity: sha512-JBUUzyOgEwXQY1NuPtvcj/qcBDbDmEvWufhlnXZIm75DEHp+afM1r1ujJpJsV/gSM4t59tpDyPi1sd6ZaPFfsA==} + /safe-regex-test@1.0.3: + resolution: {integrity: sha512-CdASjNJPvRa7roO6Ra/gLYBTzYzzPyyBXxIMdGW3USQLyjWEls2RgW5UBTXaQVp+OrpeCK3bLem8smtmheoRuw==} + engines: {node: '>= 0.4'} dependencies: - call-bind: 1.0.2 - get-intrinsic: 1.2.0 + call-bind: 1.0.7 + es-errors: 1.3.0 is-regex: 1.1.4 + /safe-stable-stringify@2.4.3: + resolution: {integrity: sha512-e2bDA2WJT0wxseVd4lsDP4+3ONX6HpMXQa1ZhFQ7SU+GjvORCmShbCMltrtIDfkYhVHrOcPtj+KhmDBdPdZD1g==} + engines: {node: '>=10'} + dev: true + /safer-buffer@2.1.2: resolution: {integrity: sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==} @@ -8974,22 +12860,21 @@ packages: resolution: {integrity: sha512-CtuThmgHNg7zIZWAXi3AsyIzA3n4xx7aNyjwC2VJldO2LMVDhFK+63xGqq6CsJH4rTAt6/M+N4GhZiDYPx9eUw==} dependencies: loose-envify: 1.4.0 - dev: false - /schema-utils@3.1.2: - resolution: {integrity: sha512-pvjEHOgWc9OWA/f/DE3ohBWTD6EleVLf7iFUkoSwAxttdBhB9QUebQgxER2kWueOvRJXPHNnyrvvh9eZINB8Eg==} + /schema-utils@3.3.0: + resolution: {integrity: sha512-pN/yOAvcC+5rQ5nERGuwrjLlYvLTbCibnZ1I7B1LaiAz9BRBlE9GMgE/eqV30P7aJQUf7Ddimy/RsbYO/GrVGg==} engines: {node: '>= 10.13.0'} dependencies: - '@types/json-schema': 7.0.11 + '@types/json-schema': 7.0.15 ajv: 6.12.6 ajv-keywords: 3.5.2(ajv@6.12.6) dev: false - /schema-utils@4.0.1: - resolution: {integrity: sha512-lELhBAAly9NowEsX0yZBlw9ahZG+sK/1RJ21EpzdYHKEs13Vku3LJ+MIPhh4sMs0oCCeufZQEQbMekiA4vuVIQ==} + /schema-utils@4.2.0: + resolution: {integrity: sha512-L0jRsrPpjdckP3oPug3/VxNKt2trR8TcabrM6FOAAlvC/9Phcmm+cuAgTlxBqdBR1WJx7Naj9WHw+aOmheSVbw==} engines: {node: '>= 12.13.0'} dependencies: - '@types/json-schema': 7.0.11 + '@types/json-schema': 7.0.15 ajv: 8.12.0 ajv-formats: 2.1.1(ajv@8.12.0) ajv-keywords: 5.1.0(ajv@8.12.0) @@ -9006,10 +12891,11 @@ packages: resolution: {integrity: sha512-mEugaLK+YfkijB4fx0e6kImuJdCIt2LxCRcbEYPqRGCs4F2ogyfZU5IAZRdjCP8JPq2AtdNoC/Dux63d9Kiryg==} dev: false - /selfsigned@2.1.1: - resolution: {integrity: sha512-GSL3aowiF7wa/WtSFwnUrludWFoNhftq8bUkH9pkzjpN2XSPOAYEgg6e0sS9s0rZwgJzJiQRPU18A6clnoW5wQ==} + /selfsigned@2.4.1: + resolution: {integrity: sha512-th5B4L2U+eGLq1TVh7zNRGBapioSORUeymIydxgFpwww9d2qyKvtuPU2jJuHvYAwwqi2Y596QBL3eEqcPEYL8Q==} engines: {node: '>=10'} dependencies: + '@types/node-forge': 1.3.11 node-forge: 1.3.1 dev: false @@ -9017,21 +12903,16 @@ packages: resolution: {integrity: sha512-0Ju4+6A8iOnpL/Thra7dZsSlOHYAHIeMxfhWQRI1/VLcT3WDBZKKtQt/QkBOsiIN9ZpuvHE6cGZ0x4glCMmfiA==} engines: {node: '>=12'} dependencies: - semver: 7.5.4 + semver: 7.6.0 dev: true /semver-utils@1.1.4: resolution: {integrity: sha512-EjnoLE5OGmDAVV/8YDoN5KiajNadjzIp9BAHOhYeQHt7j0UWxjmgsx4YD48wp4Ue1Qogq38F1GNUJNqF1kKKxA==} dev: true - /semver@5.7.1: - resolution: {integrity: sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==} - hasBin: true - - /semver@6.3.0: - resolution: {integrity: sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==} + /semver@5.7.2: + resolution: {integrity: sha512-cBznnQ9KjJqU67B52RMC65CMarK2600WFnbkcaiwWq3xy/5haFJlshgnpjovMVJ+Hff49d8GEn0b87C5pDQ10g==} hasBin: true - dev: true /semver@6.3.1: resolution: {integrity: sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==} @@ -9043,6 +12924,14 @@ packages: hasBin: true dependencies: lru-cache: 6.0.0 + dev: true + + /semver@7.6.0: + resolution: {integrity: sha512-EnwXhrlwXMk9gKu5/flx5sv/an57AkRplG3hTK68W7FRDN+k+OWBj65M7719OkA82XLBxrcX0KSHj+X5COhOVg==} + engines: {node: '>=10'} + hasBin: true + dependencies: + lru-cache: 6.0.0 /send@0.18.0: resolution: {integrity: sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==} @@ -9065,8 +12954,15 @@ packages: - supports-color dev: false - /serialize-javascript@6.0.1: - resolution: {integrity: sha512-owoXEFjWRllis8/M1Q+Cw5k8ZH40e3zhp/ovX+Xr/vi1qj6QesbyXXViFbpNvWvPNAD62SutwEXavefrLJWj7w==} + /serialize-error@7.0.1: + resolution: {integrity: sha512-8I8TjW5KMOKsZQTvoxjuSIa7foAwPWGOts+6o7sgjz41/qMD9VQHEDxi6PBvK2l0MXUmqZyNpUK+T2tQaaElvw==} + engines: {node: '>=10'} + dependencies: + type-fest: 0.13.1 + dev: true + + /serialize-javascript@6.0.2: + resolution: {integrity: sha512-Saa1xPByTTq2gdeFZYLLo+RFE35NHZkAbqZeWNd3BpzppeVisAqpDjcp8dyf6uIvEqJRd46jemmyA4iFIeVk8g==} dependencies: randombytes: 2.1.0 dev: false @@ -9111,8 +13007,8 @@ packages: - supports-color dev: false - /serve@14.2.0: - resolution: {integrity: sha512-+HOw/XK1bW8tw5iBilBz/mJLWRzM8XM6MPxL4J/dKzdxq1vfdEWSwhaR7/yS8EJp5wzvP92p1qirysJvnEtjXg==} + /serve@14.2.1: + resolution: {integrity: sha512-48er5fzHh7GCShLnNyPBRPEjs2I6QBozeGr02gaacROiyS/8ARADlj595j39iZXAqBbJHH/ivJJyPRWY9sQWZA==} engines: {node: '>= 14'} hasBin: true dependencies: @@ -9131,9 +13027,35 @@ packages: - supports-color dev: true + /ses@1.3.0: + resolution: {integrity: sha512-TURVgXm/fs38N4iJfhU9NjUiNvnU7Z/G7gVjM17jD+nrChRzMmR57fbvAzbQeGCS8Cm0m1fBs0jYCqmU6GZ7Tg==} + dependencies: + '@endo/env-options': 1.1.1 + dev: true + /set-blocking@2.0.0: resolution: {integrity: sha512-KiKBS8AnWGEyLzofFfmvKwpdPzqiy16LvQfK3yv/fVH7Bj13/wl3JSR1J+rfgRE9q7xUJK4qvgS8raSOeLUehw==} + /set-function-length@1.2.1: + resolution: {integrity: sha512-j4t6ccc+VsKwYHso+kElc5neZpjtq9EnRICFZtWyBsLojhmeF/ZBd/elqm22WJh/BziDe/SBiOeAt0m2mfLD0g==} + engines: {node: '>= 0.4'} + dependencies: + define-data-property: 1.1.4 + es-errors: 1.3.0 + function-bind: 1.1.2 + get-intrinsic: 1.2.4 + gopd: 1.0.1 + has-property-descriptors: 1.0.2 + + /set-function-name@2.0.2: + resolution: {integrity: sha512-7PGFlmtwsEADb0WYyvCMa1t+yke6daIG4Wirafur5kcf+MhUnPms1UeR0CKQdTZD81yESwMHbtn+TR+dMviakQ==} + engines: {node: '>= 0.4'} + dependencies: + define-data-property: 1.1.4 + es-errors: 1.3.0 + functions-have-names: 1.2.3 + has-property-descriptors: 1.0.2 + /setprototypeof@1.1.0: resolution: {integrity: sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ==} dev: false @@ -9161,7 +13083,6 @@ packages: /shell-quote@1.8.1: resolution: {integrity: sha512-6j1W9l1iAs/4xYBI1SYOVZyFcCis9b4KCLQ8fgAGG07QvzaRLVVRQvAy85yNmmZSjYjg4MWh4gNvlPujU/5LpA==} - dev: false /shelljs@0.8.5: resolution: {integrity: sha512-TiwcRcrkhHvbrZbnRcFYMLl30Dfov3HKqzp5tO5b4pt6G/SezKcYhmDg15zXVBswHmctSAQKznqNW2LO5tTDow==} @@ -9173,33 +13094,67 @@ packages: rechoir: 0.6.2 dev: true - /side-channel@1.0.4: - resolution: {integrity: sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==} + /side-channel@1.0.5: + resolution: {integrity: sha512-QcgiIWV4WV7qWExbN5llt6frQB/lBven9pqliLXfGPB+K9ZYXxDozp0wLkHS24kWCm+6YXH/f0HhnObZnZOBnQ==} + engines: {node: '>= 0.4'} dependencies: - call-bind: 1.0.2 - get-intrinsic: 1.2.1 - object-inspect: 1.12.3 + call-bind: 1.0.7 + es-errors: 1.3.0 + get-intrinsic: 1.2.4 + object-inspect: 1.13.1 + + /siginfo@2.0.0: + resolution: {integrity: sha512-ybx0WO1/8bSBLEWXZvEd7gMW3Sn3JFlW3TvX1nREbDLRNQNaeNN8WK0meBwPdAaOI7TtRRRJn/Es1zhrrCHu7g==} + dev: true /signal-exit@3.0.7: resolution: {integrity: sha512-wnD2ZE+l+SPC/uoS0vXeE9L1+0wuaMqKlfz9AMUo38JsyLSBWSFcHR1Rri62LZc12vLr1gb3jl7iwQhgwpAbGQ==} - /signal-exit@4.0.1: - resolution: {integrity: sha512-uUWsN4aOxJAS8KOuf3QMyFtgm1pkb6I+KRZbRF/ghdf5T7sM+B1lLLzPDxswUjkmHyxQAVzEgG35E3NzDM9GVw==} + /signal-exit@4.1.0: + resolution: {integrity: sha512-bzyZ1e88w9O1iNJbKnOlvYTrWPDl46O1bG0D3XInv+9tkPrxrN8jUUTiFlDkkmKWgn1M6CfIA13SuGqOa9Korw==} engines: {node: '>=14'} - dev: true - /sigstore@1.4.0: - resolution: {integrity: sha512-N7TRpSbFjY/TrFDg6yGAQSYBrQ5s6qmPiq4pD6fkv1LoyfMsLG0NwZWG2s5q+uttLHgyVyTa0Rogx2P78rN8kQ==} + /sigstore@1.9.0: + resolution: {integrity: sha512-0Zjz0oe37d08VeOtBIuB6cRriqXse2e8w+7yIy2XSXjshRKxbc2KkhXjL229jXSxEm7UbcjS76wcJDGQddVI9A==} engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} hasBin: true dependencies: - '@sigstore/protobuf-specs': 0.1.0 + '@sigstore/bundle': 1.1.0 + '@sigstore/protobuf-specs': 0.2.1 + '@sigstore/sign': 1.0.0 + '@sigstore/tuf': 1.0.3 make-fetch-happen: 11.1.1 - tuf-js: 1.1.4 transitivePeerDependencies: - supports-color dev: true + /simple-concat@1.0.1: + resolution: {integrity: sha512-cSFtAPtRhljv69IK0hTVZQ+OfE9nePi/rtJmw5UjHeVyVroEqJXP1sFztKUy1qU+xvz3u/sfYJLa947b7nAN2Q==} + dev: true + + /simple-get@4.0.1: + resolution: {integrity: sha512-brv7p5WgH0jmQJr1ZDDfKDOSeWWg+OVypG99A/5vYGPqJ6pxiaHLy8nxtFjBA7oMa01ebA9gfh1uMCFqOuXxvA==} + dependencies: + decompress-response: 6.0.0 + once: 1.4.0 + simple-concat: 1.0.1 + dev: true + + /simple-swizzle@0.2.2: + resolution: {integrity: sha512-JA//kQgZtbuY83m+xT+tXJkmJncGMTFT+C+g2h2R9uxkYIrE2yy9sgmcLhCnw57/WSD+Eh3J97FPEDFnbXnDUg==} + dependencies: + is-arrayish: 0.3.2 + dev: true + + /sirv@2.0.4: + resolution: {integrity: sha512-94Bdh3cC2PKrbgSOUqTiGPWVZeSiXfKOVZNJniWoqrWrRkB1CJzBU3NEbiTsPcYy1lDsANA/THzS+9WBiy5nfQ==} + engines: {node: '>= 10'} + dependencies: + '@polka/url': 1.0.0-next.24 + mrmime: 2.0.0 + totalist: 3.0.1 + dev: true + /sisteransi@1.0.5: resolution: {integrity: sha512-bLGGlR1QxBcynn2d5YmDX4MGjlZvy2MRBDRNHLJ8VI6l6+9FUiyTFNJ0IveOSP0bcXgVDPRcfGqA0pjaqUpfVg==} dev: true @@ -9229,7 +13184,14 @@ packages: ansi-styles: 4.3.0 astral-regex: 2.0.0 is-fullwidth-code-point: 3.0.0 - dev: false + + /slice-ansi@5.0.0: + resolution: {integrity: sha512-FC+lgizVPfie0kkhqUScwRu1O/lF6NOgJmlCgK+/LYxDCTk8sGelYaHDhFcDN+Sn3Cv+3VSa4Byeo+IMCzpMgQ==} + engines: {node: '>=12'} + dependencies: + ansi-styles: 6.2.1 + is-fullwidth-code-point: 4.0.0 + dev: true /smart-buffer@4.2.0: resolution: {integrity: sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg==} @@ -9250,27 +13212,27 @@ packages: dependencies: agent-base: 6.0.2 debug: 4.3.4(supports-color@8.1.1) - socks: 2.7.1 + socks: 2.8.1 transitivePeerDependencies: - supports-color dev: true - /socks-proxy-agent@8.0.1: - resolution: {integrity: sha512-59EjPbbgg8U3x62hhKOFVAmySQUcfRQ4C7Q/D5sEHnZTQRrQlNKINks44DMR1gwXp0p4LaVIeccX2KHTTcHVqQ==} + /socks-proxy-agent@8.0.2: + resolution: {integrity: sha512-8zuqoLv1aP/66PHF5TqwJ7Czm3Yv32urJQHrVyhD7mmA6d61Zv8cIXQYPTWwmg6qlupnPvs/QKDmfa4P/qct2g==} engines: {node: '>= 14'} dependencies: agent-base: 7.1.0 debug: 4.3.4(supports-color@8.1.1) - socks: 2.7.1 + socks: 2.8.1 transitivePeerDependencies: - supports-color dev: true - /socks@2.7.1: - resolution: {integrity: sha512-7maUZy1N7uo6+WVEX6psASxtNlKaNVMlGQKkG/63nEDdLOWNbiUMoLK7X4uYoLhQstau72mLgfEWcXcwsaHbYQ==} - engines: {node: '>= 10.13.0', npm: '>= 3.0.0'} + /socks@2.8.1: + resolution: {integrity: sha512-B6w7tkwNid7ToxjZ08rQMT8M9BJAf8DKx8Ft4NivzH0zBUfd6jldGcisJn/RLgxcX3FPNDdNQCUEMMT79b+oCQ==} + engines: {node: '>= 10.0.0', npm: '>= 3.0.0'} dependencies: - ip: 2.0.0 + ip-address: 9.0.5 smart-buffer: 4.2.0 dev: true @@ -9295,12 +13257,29 @@ packages: is-plain-obj: 1.1.0 dev: false + /sort-on@6.0.0: + resolution: {integrity: sha512-d51VlJWoFQjp+cIZRyNusCyJdP5pLAw+H+sC4C2q6RhPBv+RAb/QXXck5q3Kdm7h/ot/kD2AlpGPDee8v+0qiA==} + engines: {node: '>=18'} + dependencies: + dot-prop: 8.0.2 + dev: true + + /source-map-js@1.0.2: + resolution: {integrity: sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==} + engines: {node: '>=0.10.0'} + dev: true + /source-map-support@0.5.21: resolution: {integrity: sha512-uBHU3L3czsIyYXKX88fdrGovxdSCoTGDRZ6SYXtSRxLZUzHg5P/66Ht6uoUlHu9EZod+inXhKo3qQgwXUT/y1w==} dependencies: buffer-from: 1.1.2 source-map: 0.6.1 + /source-map@0.5.7: + resolution: {integrity: sha512-LbrmJOMUSdEVxIKvdcJzQC+nQhe8FUZQTXQy6+I75skNgn3OoQ0DZA8YnFa7gp8tqtL3KPf1kmo0R5DoApeSGQ==} + engines: {node: '>=0.10.0'} + dev: true + /source-map@0.6.1: resolution: {integrity: sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==} engines: {node: '>=0.10.0'} @@ -9308,10 +13287,14 @@ packages: /source-map@0.7.4: resolution: {integrity: sha512-l3BikUxvPOcn5E74dZiq5BGsTb5yEwhaTSzccU6t4sDOH8NWJCstKO5QT2CvtFoK6F0saL7p9xHAqHOlCPJygA==} engines: {node: '>= 8'} - dev: false - /spawn-please@2.0.1: - resolution: {integrity: sha512-W+cFbZR2q2mMTfjz5ZGvhBAiX+e/zczFCNlbS9mxiSdYswBXwUuBUT+a0urH+xZZa8f/bs0mXHyZsZHR9hKogA==} + /sourcemap-codec@1.4.8: + resolution: {integrity: sha512-9NykojV5Uih4lgo5So5dtw+f0JgJX30KCNI8gwhz2J9A15wD0Ml6tjHKwf6fTSa6fAdVBdZeNOs9eJ71qCk8vA==} + deprecated: Please use @jridgewell/sourcemap-codec instead + dev: true + + /spawn-please@2.0.2: + resolution: {integrity: sha512-KM8coezO6ISQ89c1BzyWNtcn2V2kAVtwIXd3cN/V5a0xPYc1F/vydrRc01wsKFEQ/p+V1a4sw4z2yMITIXrgGw==} engines: {node: '>=14'} dependencies: cross-spawn: 7.0.3 @@ -9333,22 +13316,22 @@ packages: resolution: {integrity: sha512-kN9dJbvnySHULIluDHy32WHRUu3Og7B9sbY7tsFLctQkIqnMh3hErYgdMjTYuqmcXX+lK5T1lnUt3G7zNswmZA==} dependencies: spdx-expression-parse: 3.0.1 - spdx-license-ids: 3.0.13 + spdx-license-ids: 3.0.17 dev: true - /spdx-exceptions@2.3.0: - resolution: {integrity: sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==} + /spdx-exceptions@2.5.0: + resolution: {integrity: sha512-PiU42r+xO4UbUS1buo3LPJkjlO7430Xn5SVAhdpzzsPHsjbYVflnnFdATgabnLude+Cqu25p6N+g2lw/PFsa4w==} dev: true /spdx-expression-parse@3.0.1: resolution: {integrity: sha512-cbqHunsQWnJNE6KhVSMsMeH5H/L9EpymbzqTQ3uLwNCLZ1Q481oWaofqH7nO6V07xlXwY6PhQdQ2IedWx/ZK4Q==} dependencies: - spdx-exceptions: 2.3.0 - spdx-license-ids: 3.0.13 + spdx-exceptions: 2.5.0 + spdx-license-ids: 3.0.17 dev: true - /spdx-license-ids@3.0.13: - resolution: {integrity: sha512-XkD+zwiqXHikFZm4AX/7JSCXA98U5Db4AFd5XUg/+9UNtnH75+Z9KxtpYiJZx36mUDVOwH83pl7yvCer6ewM3w==} + /spdx-license-ids@3.0.17: + resolution: {integrity: sha512-sh8PWc/ftMqAAdFiBu6Fy6JUOYjqDJBJvIhpfDMyHrr0Rbp5liZqd4TjtQ/RgfLjKFZb+LMx5hpml5qOWy0qvg==} dev: true /spdy-transport@3.0.0: @@ -9377,14 +13360,14 @@ packages: - supports-color dev: false - /speed-measure-webpack-plugin@1.4.2(webpack@5.81.0): + /speed-measure-webpack-plugin@1.4.2(webpack@5.90.3): resolution: {integrity: sha512-AtVzD0bnIy2/B0fWqJpJgmhcrfWFhBlduzSo0uwplr/QvB33ZNZj2NEth3NONgdnZJqicK0W0mSxnLSbsVCDbw==} engines: {node: '>=6.0.0'} peerDependencies: webpack: ^1 || ^2 || ^3 || ^4 || ^5 dependencies: chalk: 4.1.2 - webpack: 5.81.0 + webpack: 5.90.3 dev: false /split@0.3.3: @@ -9395,10 +13378,13 @@ packages: /sprintf-js@1.0.3: resolution: {integrity: sha512-D9cPgkvLlV3t3IzL0D0YLvGA9Ahk4PcvVwUbN0dSGr1aP0Nrt4AEnTUbuGvquEC0mA64Gqt1fzirlRs5ibXx8g==} - dev: false - /sshpk@1.17.0: - resolution: {integrity: sha512-/9HIEs1ZXGhSPE8X6Ccm7Nam1z8KcoCqPdI7ecm1N33EzAetWahvQWVqLZtaZQ+IDKX4IyA2o0gBzqIMkAagHQ==} + /sprintf-js@1.1.3: + resolution: {integrity: sha512-Oo+0REFV59/rz3gfJNKQiBlwfHaSESl1pcGyABQsnnIfWOFt6JNj5gCog2U6MLZ//IGYD+nA8nI+mTShREReaA==} + dev: true + + /sshpk@1.18.0: + resolution: {integrity: sha512-2p2KJZTSqQ/I3+HX42EpYOa2l3f8Erv8MWKsy2I9uf4wA7yFIkXRffYdsx86y6z4vHtV8u7g+pPlr8/4ouAxsQ==} engines: {node: '>=0.10.0'} hasBin: true dependencies: @@ -9413,11 +13399,11 @@ packages: tweetnacl: 0.14.5 dev: false - /ssri@10.0.4: - resolution: {integrity: sha512-12+IR2CB2C28MMAw0Ncqwj5QbTcs0nGIhgJzYWzDkb21vWmfNI83KS4f3Ci6GI98WreIfG7o9UXp3C0qbpA8nQ==} + /ssri@10.0.5: + resolution: {integrity: sha512-bSf16tAFkGeRlUNDjXu8FzaMQt6g2HZJrun7mtMbIPOddxt3GLMSz5VWUWcqTJUPfLEaDIepGxv+bYQW49596A==} engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} dependencies: - minipass: 5.0.0 + minipass: 7.0.4 dev: true /ssri@9.0.1: @@ -9427,9 +13413,24 @@ packages: minipass: 3.3.6 dev: true - /start-server-and-test@2.0.0: - resolution: {integrity: sha512-UqKLw0mJbfrsG1jcRLTUlvuRi9sjNuUiDOLI42r7R5fA9dsFoywAy9DoLXNYys9B886E4RCKb+qM1Gzu96h7DQ==} - engines: {node: '>=6'} + /stack-trace@0.0.10: + resolution: {integrity: sha512-KGzahc7puUKkzyMt+IqAep+TVNbKP+k2Lmwhub39m1AsTSkaDutx56aDCo+HLDzf/D26BIHTJWNiTG1KAJiQCg==} + dev: true + + /stack-utils@2.0.6: + resolution: {integrity: sha512-XlkWvfIm6RmsWtNJx+uqtKLS8eqFbxUg0ZzLXqY0caEy9l7hruX8IpiDnjsLavoBgqCCR71TqWO8MaXYheJ3RQ==} + engines: {node: '>=10'} + dependencies: + escape-string-regexp: 2.0.0 + dev: true + + /stackback@0.0.2: + resolution: {integrity: sha512-1XMJE5fQo1jGH6Y/7ebnwPOBEkIEnT4QF32d5R1+VXdXveM0IBMJt8zfaxX1P3QhVwrYe+576+jkANtSS2mBbw==} + dev: true + + /start-server-and-test@2.0.3: + resolution: {integrity: sha512-QsVObjfjFZKJE6CS6bSKNwWZCKBG6975/jKRPPGFfFh+yOQglSeGXiNWjzgQNXdphcBI9nXbyso9tPfX4YAUhg==} + engines: {node: '>=16'} hasBin: true dependencies: arg: 5.0.2 @@ -9439,7 +13440,7 @@ packages: execa: 5.1.1 lazy-ass: 1.6.0 ps-tree: 1.2.0 - wait-on: 7.0.1(debug@4.3.4) + wait-on: 7.2.0(debug@4.3.4) transitivePeerDependencies: - supports-color dev: true @@ -9454,6 +13455,10 @@ packages: engines: {node: '>= 0.8'} dev: false + /std-env@3.7.0: + resolution: {integrity: sha512-JPbdCEQLj1w5GilpiHAx3qJvFndqybBysA3qUOnznweH4QbNYUsW/ea8QzSrnh0vNsezMMw5bcVool8lM0gwzg==} + dev: true + /stdin-discarder@0.1.0: resolution: {integrity: sha512-xhV7w8S+bUwlPTb4bAOUQhv8/cSS5offJuX8GQGq32ONF0ZtDWKfkdomM3HMRA+LhX6um/FZ0COqlwsjD53LeQ==} engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} @@ -9461,11 +13466,17 @@ packages: bl: 5.1.0 dev: true + /steno@4.0.2: + resolution: {integrity: sha512-yhPIQXjrlt1xv7dyPQg2P17URmXbuM5pdGkpiMB3RenprfiBlvK415Lctfe0eshk90oA7/tNq7WEiMK8RSP39A==} + engines: {node: '>=18'} + dev: true + /stop-iteration-iterator@1.0.0: resolution: {integrity: sha512-iCGQj+0l0HOdZ2AEeBADlsRC+vsnDsZsbdSiH1yNSjcfKM7fdpCMfqAL/dwF5BLiw/XhRft/Wax6zQbhq2BcjQ==} engines: {node: '>= 0.4'} dependencies: - internal-slot: 1.0.5 + internal-slot: 1.0.7 + dev: true /stream-combiner@0.0.4: resolution: {integrity: sha512-rT00SPnTVyRsaSz5zgSPma/aHSOic5U1prhYdRy5HS2kTZviFpmDgzilbtsJsxiroqACmayynDN/9VzIbX5DOw==} @@ -9473,6 +13484,15 @@ packages: duplexer: 0.1.2 dev: true + /streamx@2.16.1: + resolution: {integrity: sha512-m9QYj6WygWyWa3H1YY69amr4nVgy61xfjys7xO7kviL5rfIEc2naf+ewFiOA+aEJD7y0JO3h2GoiUv4TDwEGzQ==} + dependencies: + fast-fifo: 1.3.2 + queue-tick: 1.0.1 + optionalDependencies: + bare-events: 2.2.0 + dev: true + /strict-uri-encode@1.1.0: resolution: {integrity: sha512-R3f198pcvnB+5IpnBlRkphuE9n46WyVl8I39W/ZUTZLz4nqSP/oLYUrcnJrw462Ds8he4YKMov2efsTIw1BDGQ==} engines: {node: '>=0.10.0'} @@ -9493,38 +13513,37 @@ packages: eastasianwidth: 0.2.0 emoji-regex: 9.2.2 strip-ansi: 7.1.0 - dev: true /string-width@6.1.0: resolution: {integrity: sha512-k01swCJAgQmuADB0YIc+7TuatfNvTBVOoaUWJjTB9R4VJzR5vNWzf5t42ESVZFPS8xTySF7CAdV4t/aaIm3UnQ==} engines: {node: '>=16'} dependencies: eastasianwidth: 0.2.0 - emoji-regex: 10.2.1 + emoji-regex: 10.3.0 strip-ansi: 7.1.0 dev: true - /string.prototype.trim@1.2.7: - resolution: {integrity: sha512-p6TmeT1T3411M8Cgg9wBTMRtY2q9+PNy9EV1i2lIXUN/btt763oIfxwN3RR8VU6wHX8j/1CFy0L+YuThm6bgOg==} + /string.prototype.trim@1.2.8: + resolution: {integrity: sha512-lfjY4HcixfQXOfaqCvcBuOIapyaroTXhbkfJN3gcB1OtyupngWK4sEET9Knd0cXd28kTUqu/kHoV4HKSJdnjiQ==} engines: {node: '>= 0.4'} dependencies: - call-bind: 1.0.2 - define-properties: 1.2.0 - es-abstract: 1.21.2 + call-bind: 1.0.7 + define-properties: 1.2.1 + es-abstract: 1.22.4 - /string.prototype.trimend@1.0.6: - resolution: {integrity: sha512-JySq+4mrPf9EsDBEDYMOb/lM7XQLulwg5R/m1r0PXEFqrV0qHvl58sdTilSXtKOflCsK2E8jxf+GKC0T07RWwQ==} + /string.prototype.trimend@1.0.7: + resolution: {integrity: sha512-Ni79DqeB72ZFq1uH/L6zJ+DKZTkOtPIHovb3YZHQViE+HDouuU4mBrLOLDn5Dde3RF8qw5qVETEjhu9locMLvA==} dependencies: - call-bind: 1.0.2 - define-properties: 1.2.0 - es-abstract: 1.21.2 + call-bind: 1.0.7 + define-properties: 1.2.1 + es-abstract: 1.22.4 - /string.prototype.trimstart@1.0.6: - resolution: {integrity: sha512-omqjMDaY92pbn5HOX7f9IccLA+U1tA9GvtU4JrodiXFfYB7jPzzHpRzpglLAjtUV6bB557zwClJezTqnAiYnQA==} + /string.prototype.trimstart@1.0.7: + resolution: {integrity: sha512-NGhtDFu3jCEm7B4Fy0DpLewdJQOZcQ0rGbwQ/+stjnrp2i+rlKeCvos9hOIeCmqwratM47OBxY7uFZzjxHXmrg==} dependencies: - call-bind: 1.0.2 - define-properties: 1.2.0 - es-abstract: 1.21.2 + call-bind: 1.0.7 + define-properties: 1.2.1 + es-abstract: 1.22.4 /string_decoder@1.1.1: resolution: {integrity: sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==} @@ -9555,7 +13574,6 @@ packages: engines: {node: '>=12'} dependencies: ansi-regex: 5.0.1 - dev: true /strip-bom@3.0.0: resolution: {integrity: sha512-vavAMRXOgBVNF6nyEEmL3DBK19iRpDcoIwW+swQ+CbGiu7lju6t+JklA1MHweoWtadgt4ISVUsXLyDq34ddcwA==} @@ -9603,6 +13621,12 @@ packages: engines: {node: '>=14.16'} dev: true + /strip-literal@2.0.0: + resolution: {integrity: sha512-f9vHgsCWBq2ugHAkGMiiYY+AYG0D/cbloKKg0nhaaaSNsujdGIpVXCNsrJpCKr5M0f4aI31mr13UjY6GAuXCKA==} + dependencies: + js-tokens: 8.0.3 + dev: true + /strip-outer@1.0.1: resolution: {integrity: sha512-k55yxKHwaXnpYGsOzg4Vl8+tDrWylxDEpknGjhTiZB8dFRU5rTo9CAzeycivxV3s+zlTKwrs6WxMxR95n26kwg==} engines: {node: '>=0.10.0'} @@ -9610,6 +13634,16 @@ packages: escape-string-regexp: 1.0.5 dev: false + /supertap@3.0.1: + resolution: {integrity: sha512-u1ZpIBCawJnO+0QePsEiOknOfCRq0yERxiAchT0i4li0WHNUJbf0evXXSXOcCAR4M8iMDoajXYmstm/qO81Isw==} + engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} + dependencies: + indent-string: 5.0.0 + js-yaml: 3.14.1 + serialize-error: 7.0.1 + strip-ansi: 7.1.0 + dev: true + /supports-color@5.5.0: resolution: {integrity: sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==} engines: {node: '>=4'} @@ -9632,12 +13666,28 @@ packages: resolution: {integrity: sha512-ot0WnXS9fgdkgIcePe6RHNk1WA8+muPa6cSjeR3V8K27q9BB1rTE3R1p7Hv0z1ZyAc8s6Vvv8DIyWf681MAt0w==} engines: {node: '>= 0.4'} - /synckit@0.8.5: - resolution: {integrity: sha512-L1dapNV6vu2s/4Sputv8xGsCdAVlb5nRDMFU/E27D44l5U6cw1g0dGd45uLc+OXjNMmF4ntiMdCimzcjFKQI8Q==} + /symbol-observable@2.0.3: + resolution: {integrity: sha512-sQV7phh2WCYAn81oAkakC5qjq2Ml0g8ozqz03wOGnx9dDlG1de6yrF+0RAzSJD8fPUow3PTSMf2SAbOGxb93BA==} + engines: {node: '>=0.10'} + dev: true + + /synckit@0.8.8: + resolution: {integrity: sha512-HwOKAP7Wc5aRGYdKH+dw0PRRpbO841v2DENBtjnR5HFWoiNByAl7vrx3p0G/rCyYXQsrxqtX48TImFtPcIHSpQ==} engines: {node: ^14.18.0 || >=16.0.0} dependencies: - '@pkgr/utils': 2.4.2 - tslib: 2.5.0 + '@pkgr/core': 0.1.1 + tslib: 2.6.2 + dev: true + + /table@6.8.1: + resolution: {integrity: sha512-Y4X9zqrCftUhMeH2EptSSERdVKt/nEdijTOacGD/97EKjhQ/Qs8RTlEGABSJNNN8lac9kheH+af7yAkEWlgneA==} + engines: {node: '>=10.0.0'} + dependencies: + ajv: 8.12.0 + lodash.truncate: 4.4.2 + slice-ansi: 4.0.0 + string-width: 4.2.3 + strip-ansi: 6.0.1 dev: true /tapable@1.1.3: @@ -9650,6 +13700,23 @@ packages: engines: {node: '>=6'} dev: false + /tar-fs@2.1.1: + resolution: {integrity: sha512-V0r2Y9scmbDRLCNex/+hYzvp/zyYjvFbHPNgVTKfQvVrb6guiE/fxP+XblDNR011utopbkex2nM4dHNV6GDsng==} + dependencies: + chownr: 1.1.4 + mkdirp-classic: 0.5.3 + pump: 3.0.0 + tar-stream: 2.2.0 + dev: true + + /tar-fs@3.0.4: + resolution: {integrity: sha512-5AFQU8b9qLfZCX9zp2duONhPmZv0hGYiBPJsyUdqMjzq/mqVpy/rEUSeHk1+YitmxugaptgBh5oDGU3VsAJq4w==} + dependencies: + mkdirp-classic: 0.5.3 + pump: 3.0.0 + tar-stream: 3.1.7 + dev: true + /tar-stream@1.6.2: resolution: {integrity: sha512-rzS0heiNf8Xn7/mpdSVVSMAWAoy9bfb1WOTYC78Z0UQKeKa/CWS8FOq0lKGNa8DWKAn9gxjCvMLYc5PGXYlK2A==} engines: {node: '>= 0.8.0'} @@ -9663,20 +13730,50 @@ packages: xtend: 4.0.2 dev: false - /tar@6.1.13: - resolution: {integrity: sha512-jdIBIN6LTIe2jqzay/2vtYLlBHa3JF42ot3h1dW8Q0PaAG4v8rm0cvpVePtau5C6OKXGGcgO9q2AMNSWxiLqKw==} + /tar-stream@2.2.0: + resolution: {integrity: sha512-ujeqbceABgwMZxEJnk2HDY2DlnUZ+9oEcb1KzTVfYHio0UE6dG71n60d8D2I4qNvleWrrXpmjpt7vZeF1LnMZQ==} + engines: {node: '>=6'} + dependencies: + bl: 4.1.0 + end-of-stream: 1.4.4 + fs-constants: 1.0.0 + inherits: 2.0.4 + readable-stream: 3.6.2 + dev: true + + /tar-stream@3.1.7: + resolution: {integrity: sha512-qJj60CXt7IU1Ffyc3NJMjh6EkuCFej46zUqJ4J7pqYlThyd9bO0XBTmcOIhSzZJVWfsLks0+nle/j538YAW9RQ==} + dependencies: + b4a: 1.6.6 + fast-fifo: 1.3.2 + streamx: 2.16.1 + dev: true + + /tar@6.2.0: + resolution: {integrity: sha512-/Wo7DcT0u5HUV486xg675HtjNd3BXZ6xDbzsCUZPt5iw8bTQ63bP0Raut3mvro9u+CUyq7YQd8Cx55fsZXxqLQ==} engines: {node: '>=10'} dependencies: chownr: 2.0.0 fs-minipass: 2.1.0 - minipass: 4.2.8 + minipass: 5.0.0 minizlib: 2.1.2 mkdirp: 1.0.4 yallist: 4.0.0 dev: true - /terser-webpack-plugin@5.3.7(webpack@5.81.0): - resolution: {integrity: sha512-AfKwIktyP7Cu50xNjXF/6Qb5lBNzYaWpU6YfoX3uZicTx0zTy0stDDCsvjDapKsSDvOeWo5MEq4TmdBy2cNoHw==} + /tdigest@0.1.2: + resolution: {integrity: sha512-+G0LLgjjo9BZX2MfdvPfH+MKLCrxlXSYec5DaPYP1fe6Iyhf0/fSmJ0bFiZ1F8BT6cGXl2LpltQptzjXKWEkKA==} + dependencies: + bintrees: 1.0.2 + dev: true + + /temp-dir@3.0.0: + resolution: {integrity: sha512-nHc6S/bwIilKHNRgK/3jlhDoIHcp45YgyiwcAk46Tr0LfEqGBVpmiAyuiuxeVE44m3mXnEeVhaipLOEWmH+Njw==} + engines: {node: '>=14.16'} + dev: true + + /terser-webpack-plugin@5.3.10(webpack@5.90.3): + resolution: {integrity: sha512-BKFPWlPDndPs+NGGCr1U59t0XScL5317Y0UReNrHaw9/FwhPENlq6bfgs+4yPfyP51vqC1bQ4rp1EfXW5ZSH9w==} engines: {node: '>= 10.13.0'} peerDependencies: '@swc/core': '*' @@ -9691,12 +13788,12 @@ packages: uglify-js: optional: true dependencies: - '@jridgewell/trace-mapping': 0.3.18 + '@jridgewell/trace-mapping': 0.3.23 jest-worker: 27.5.1 - schema-utils: 3.1.2 - serialize-javascript: 6.0.1 - terser: 5.17.1 - webpack: 5.81.0 + schema-utils: 3.3.0 + serialize-javascript: 6.0.2 + terser: 5.28.1 + webpack: 5.90.3 dev: false /terser@4.8.1: @@ -9704,19 +13801,19 @@ packages: engines: {node: '>=6.0.0'} hasBin: true dependencies: - acorn: 8.10.0 + acorn: 8.11.3 commander: 2.20.3 source-map: 0.6.1 source-map-support: 0.5.21 dev: false - /terser@5.17.1: - resolution: {integrity: sha512-hVl35zClmpisy6oaoKALOpS0rDYLxRFLHhRuDlEGTKey9qHjS1w9GMORjuwIMt70Wan4lwsLYyWDVnWgF+KUEw==} + /terser@5.28.1: + resolution: {integrity: sha512-wM+bZp54v/E9eRRGXb5ZFDvinrJIOaTapx3WUokyVGZu5ucVCK55zEgGd5Dl2fSr3jUo5sDiERErUWLY6QPFyA==} engines: {node: '>=10'} hasBin: true dependencies: - '@jridgewell/source-map': 0.3.3 - acorn: 8.10.0 + '@jridgewell/source-map': 0.3.5 + acorn: 8.11.3 commander: 2.20.3 source-map-support: 0.5.21 dev: false @@ -9730,12 +13827,16 @@ packages: minimatch: 3.1.2 dev: false + /text-hex@1.0.0: + resolution: {integrity: sha512-uuVGNWzgJ4yhRaNSiubPY7OjISw4sw4E5Uv0wbjp+OzcbmVU/rsT8ujgcXJhn9ypzsgr5vlzpPqP+MBBKcGvbg==} + dev: true + /text-table@0.2.0: resolution: {integrity: sha512-N+8UisAXDGk8PFXP4HAzVR9nbfmVJ3zYLAWiTIoqC5v5isinhr+r5uaO8+7r3BMfuNIufIsA7RdpVgacC2cSpw==} dev: true - /throttleit@1.0.0: - resolution: {integrity: sha512-rkTVqu6IjfQ/6+uNuuc3sZek4CEYxTJom3IktzgdSxcZqdARuebbA/f4QmAxMQIxqq9ZLEUkSYqvuk1I6VKq4g==} + /throttleit@1.0.1: + resolution: {integrity: sha512-vDZpf9Chs9mAdfY046mcPt8fg5QSZr37hEH4TXYBnDF+izxgrbRGUAAaBvIk/fJm9aOFCGFd1EsNg5AZCbnQCQ==} dev: false /through@2.3.8: @@ -9745,16 +13846,39 @@ packages: resolution: {integrity: sha512-eHY7nBftgThBqOyHGVN+l8gF0BucP09fMo0oO/Lb0w1OF80dJv+lDVpXG60WMQvkcxAkNybKsrEIE3ZtKGmPrA==} dev: false + /time-zone@1.0.0: + resolution: {integrity: sha512-TIsDdtKo6+XrPtiTm1ssmMngN1sAhyKnTO2kunQWqNPWIVvCm15Wmw4SWInwTVgJ5u/Tr04+8Ei9TNcw4x4ONA==} + engines: {node: '>=4'} + dev: true + /timed-out@4.0.1: resolution: {integrity: sha512-G7r3AhovYtr5YKOWQkta8RKAPb+J9IsO4uVmzjl8AZwfhs8UcUwTiD6gcJYSgOtzyjvQKrKYn41syHbUWMkafA==} engines: {node: '>=0.10.0'} dev: false + /tinybench@2.6.0: + resolution: {integrity: sha512-N8hW3PG/3aOoZAN5V/NSAEDz0ZixDSSt5b/a05iqtpgfLWMSVuCo7w0k2vVvEjdrIoeGqZzweX2WlyioNIHchA==} + dev: true + + /tinypool@0.8.2: + resolution: {integrity: sha512-SUszKYe5wgsxnNOVlBYO6IC+8VGWdVGZWAqUxp3UErNBtptZvWbwyUOyzNL59zigz2rCA92QiL3wvG+JDSdJdQ==} + engines: {node: '>=14.0.0'} + dev: true + + /tinyspy@2.2.1: + resolution: {integrity: sha512-KYad6Vy5VDWV4GH3fjpseMQ/XU2BhIYP7Vzd0LG44qRWm/Yt2WCOTicFdvmgo6gWaqooMQCawTtILVQJupKu7A==} + engines: {node: '>=14.0.0'} + dev: true + /titleize@3.0.0: resolution: {integrity: sha512-KxVu8EYHDPBdUYdKZdKtU2aj2XfEx9AfjXxE/Aj0vT06w2icA09Vus1rh6eSu1y01akYg6BjIK/hxyLJINoMLQ==} engines: {node: '>=12'} dev: true + /tlhunter-sorted-set@0.1.0: + resolution: {integrity: sha512-eGYW4bjf1DtrHzUYxYfAcSytpOkA44zsr7G2n3PV7yOUR23vmkGe3LL4R+1jL9OsXtbsFOwe8XtbCrabeaEFnw==} + dev: true + /tmp@0.0.33: resolution: {integrity: sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==} engines: {node: '>=0.6.0'} @@ -9762,12 +13886,11 @@ packages: os-tmpdir: 1.0.2 dev: true - /tmp@0.2.1: - resolution: {integrity: sha512-76SUhtfqR2Ijn+xllcI5P1oyannHNHByD80W1q447gU3mp9G9PSpGdWmjUOHRDPiHYacIk66W7ubDTuPF3BEtQ==} - engines: {node: '>=8.17.0'} + /tmp@0.2.2: + resolution: {integrity: sha512-ETcvHhaIc9J2MDEAH6N67j9bvBvu/3Gb764qaGhwtFvjtvhegqoqSpofgeyq1Sc24mW5pdyUDs9HP5j3ehkxRw==} + engines: {node: '>=14'} dependencies: - rimraf: 3.0.2 - dev: false + rimraf: 5.0.5 /to-buffer@1.1.1: resolution: {integrity: sha512-lx9B5iv7msuFYE3dytT+KE5tap+rNYw+K4jVkb9R/asAb+pbBSM17jtunHplhBe6RRJdZx3Pn2Jph24O32mOVg==} @@ -9781,7 +13904,6 @@ packages: /to-fast-properties@2.0.0: resolution: {integrity: sha512-/OaKK0xYrs3DmxRYqL/yDc+FxFUVYhDlXMhRmv3z915w2HF1tnN1omB354j8VUGO/hbRzyD6Y3sA7v7GS/ceog==} engines: {node: '>=4'} - dev: false /to-regex-range@5.0.1: resolution: {integrity: sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==} @@ -9794,12 +13916,17 @@ packages: engines: {node: '>=0.6'} dev: false + /totalist@3.0.1: + resolution: {integrity: sha512-sf4i37nQ2LBx4m3wB74y+ubopq6W/dIzXg0FDGjsYnZHVa1Da8FH853wlL2gtUhg+xJXjfk3kUZS3BRoQeoQBQ==} + engines: {node: '>=6'} + dev: true + /tough-cookie@4.1.3: resolution: {integrity: sha512-aX/y5pVRkfRnfmuX+OdbSdXvPe6ieKX/G2s7e98f4poJHnqH3281gDPm/metm6E/WRamfx7WC4HUqkWHfQHprw==} engines: {node: '>=6'} dependencies: psl: 1.9.0 - punycode: 2.3.0 + punycode: 2.3.1 universalify: 0.2.0 url-parse: 1.5.10 dev: false @@ -9814,12 +13941,38 @@ packages: escape-string-regexp: 1.0.5 dev: false + /triple-beam@1.3.0: + resolution: {integrity: sha512-XrHUvV5HpdLmIj4uVMxHggLbFSZYIn7HEWsqePZcI50pco+MPqJ50wMGY794X7AOOhxOBAjbkqfAbEe/QMp2Lw==} + dev: true + + /ts-api-utils@1.2.1(typescript@5.3.3): + resolution: {integrity: sha512-RIYA36cJn2WiH9Hy77hdF9r7oEwxAtB/TS9/S4Qd90Ap4z5FSiin5zEiTL44OII1Y3IIlEvxwxFUVgrHSZ/UpA==} + engines: {node: '>=16'} + peerDependencies: + typescript: '>=4.2.0' + dependencies: + typescript: 5.3.3 + dev: true + /ts-interface-checker@0.1.13: resolution: {integrity: sha512-Y/arvbn+rrz3JCKl9C4kVNfTfSm2/mEp5FSz5EsZSANGPSlQrpRI5M4PKF+mJnE52jOO90PnPSc3Ur3bTQw0gA==} dev: false - /tsconfig-paths@3.14.2: - resolution: {integrity: sha512-o/9iXgCYc5L/JxCHPe3Hvh8Q/2xm5Z+p18PESBU6Ff33695QnCHBEjcytY2q19ua7Mbl/DavtBOLq+oG0RCL+g==} + /tsconfck@3.0.2(typescript@5.3.3): + resolution: {integrity: sha512-6lWtFjwuhS3XI4HsX4Zg0izOI3FU/AI9EGVlPEUMDIhvLPMD4wkiof0WCoDgW7qY+Dy198g4d9miAqUHWHFH6Q==} + engines: {node: ^18 || >=20} + hasBin: true + peerDependencies: + typescript: ^5.0.0 + peerDependenciesMeta: + typescript: + optional: true + dependencies: + typescript: 5.3.3 + dev: true + + /tsconfig-paths@3.15.0: + resolution: {integrity: sha512-2Ac2RgzDe/cn48GvOe3M+o82pEFewD3UPbyoUHHdKasHwJKjds4fLXWf/Ux5kATBKN20oaFGu+jbElp1pos0mg==} dependencies: '@types/json5': 0.0.29 json5: 1.0.2 @@ -9835,28 +13988,25 @@ packages: resolution: {integrity: sha512-d6xOpEDfsi2CZVlPQzGeux8XMwLT9hssAsaPYExaQMuYskwb+x1x7J371tWlbBdWHroy99KnVB6qIkUbs5X3UQ==} dev: false - /tslib@2.5.0: - resolution: {integrity: sha512-336iVw3rtn2BUK7ORdIAHTyxHGRIHVReokCR3XjbckJMK7ms8FysBfhLR8IXnAgy7T0PTPNBWKiH514FOW/WSg==} - dev: true - - /tslib@2.6.1: - resolution: {integrity: sha512-t0hLfiEKfMUoqhG+U1oid7Pva4bbDPHYfJNiB7BiIjRkj1pyC++4N3huJfqY6aRH6VTB0rvtzQwjM4K6qpfOig==} + /tslib@2.6.2: + resolution: {integrity: sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==} - /tsutils@3.21.0(typescript@5.0.4): + /tsutils@3.21.0(typescript@5.3.3): resolution: {integrity: sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA==} engines: {node: '>= 6'} peerDependencies: typescript: '>=2.8.0 || >= 3.2.0-dev || >= 3.3.0-dev || >= 3.4.0-dev || >= 3.5.0-dev || >= 3.6.0-dev || >= 3.6.0-beta || >= 3.7.0-dev || >= 3.7.0-beta' dependencies: tslib: 1.14.1 - typescript: 5.0.4 + typescript: 5.3.3 dev: true - /tuf-js@1.1.4: - resolution: {integrity: sha512-Lw2JRM3HTYhEtQJM2Th3aNCPbnXirtWMl065BawwmM2pX6XStH/ZO9e8T2hh0zk/HUa+1i6j+Lv6eDitKTau6A==} + /tuf-js@1.1.7: + resolution: {integrity: sha512-i3P9Kgw3ytjELUfpuKVDNBJvk4u5bXL6gskv572mcevPbSKCV3zt3djhmlEQ65yERjIbOSncy7U4cQJaB1CBCg==} engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} dependencies: - '@tufjs/models': 1.0.3 + '@tufjs/models': 1.0.4 + debug: 4.3.4(supports-color@8.1.1) make-fetch-happen: 11.1.1 transitivePeerDependencies: - supports-color @@ -9866,67 +14016,65 @@ packages: resolution: {integrity: sha512-McnNiV1l8RYeY8tBgEpuodCC1mLUdbSN+CYBL7kJsJNInOP8UjDDEwdk6Mw60vdLLrr5NHKZhMAOSrR2NZuQ+w==} dependencies: safe-buffer: 5.2.1 - dev: false - /turbo-darwin-64@1.10.12: - resolution: {integrity: sha512-vmDfGVPl5/aFenAbOj3eOx3ePNcWVUyZwYr7taRl0ZBbmv2TzjRiFotO4vrKCiTVnbqjQqAFQWY2ugbqCI1kOQ==} + /turbo-darwin-64@1.12.4: + resolution: {integrity: sha512-dBwFxhp9isTa9RS/fz2gDVk5wWhKQsPQMozYhjM7TT4jTrnYn0ZJMzr7V3B/M/T8QF65TbniW7w1gtgxQgX5Zg==} cpu: [x64] os: [darwin] requiresBuild: true dev: true optional: true - /turbo-darwin-arm64@1.10.12: - resolution: {integrity: sha512-3JliEESLNX2s7g54SOBqqkqJ7UhcOGkS0ywMr5SNuvF6kWVTbuUq7uBU/sVbGq8RwvK1ONlhPvJne5MUqBCTCQ==} + /turbo-darwin-arm64@1.12.4: + resolution: {integrity: sha512-1Uo5iI6xsJ1j9ObsqxYRsa3W26mEbUe6fnj4rQYV6kDaqYD54oAMJ6hM53q9rB8JvFxwdrUXGp3PwTw9A0qqkA==} cpu: [arm64] os: [darwin] requiresBuild: true dev: true optional: true - /turbo-linux-64@1.10.12: - resolution: {integrity: sha512-siYhgeX0DidIfHSgCR95b8xPee9enKSOjCzx7EjTLmPqPaCiVebRYvbOIYdQWRqiaKh9yfhUtFmtMOMScUf1gg==} + /turbo-linux-64@1.12.4: + resolution: {integrity: sha512-ONg2aSqKP7LAQOg7ysmU5WpEQp4DGNxSlAiR7um+LKtbmC/UxogbR5+T+Uuq6zGuQ5kJyKjWJ4NhtvUswOqBsA==} cpu: [x64] os: [linux] requiresBuild: true dev: true optional: true - /turbo-linux-arm64@1.10.12: - resolution: {integrity: sha512-K/ZhvD9l4SslclaMkTiIrnfcACgos79YcAo4kwc8bnMQaKuUeRpM15sxLpZp3xDjDg8EY93vsKyjaOhdFG2UbA==} + /turbo-linux-arm64@1.12.4: + resolution: {integrity: sha512-9FPufkwdgfIKg/9jj87Cdtftw8o36y27/S2vLN7FTR2pp9c0MQiTBOLVYadUr1FlShupddmaMbTkXEhyt9SdrA==} cpu: [arm64] os: [linux] requiresBuild: true dev: true optional: true - /turbo-windows-64@1.10.12: - resolution: {integrity: sha512-7FSgSwvktWDNOqV65l9AbZwcoueAILeE4L7JvjauNASAjjbuzXGCEq5uN8AQU3U5BOFj4TdXrVmO2dX+lLu8Zg==} + /turbo-windows-64@1.12.4: + resolution: {integrity: sha512-2mOtxHW5Vjh/5rDVu/aFwsMzI+chs8XcEuJHlY1sYOpEymYTz+u6AXbnzRvwZFMrLKr7J7fQOGl+v96sLKbNdA==} cpu: [x64] os: [win32] requiresBuild: true dev: true optional: true - /turbo-windows-arm64@1.10.12: - resolution: {integrity: sha512-gCNXF52dwom1HLY9ry/cneBPOKTBHhzpqhMylcyvJP0vp9zeMQQkt6yjYv+6QdnmELC92CtKNp2FsNZo+z0pyw==} + /turbo-windows-arm64@1.12.4: + resolution: {integrity: sha512-nOY5wae9qnxPOpT1fRuYO0ks6dTwpKMPV6++VkDkamFDLFHUDVM/9kmD2UTeh1yyrKnrZksbb9zmShhmfj1wog==} cpu: [arm64] os: [win32] requiresBuild: true dev: true optional: true - /turbo@1.10.12: - resolution: {integrity: sha512-WM3+jTfQWnB9W208pmP4oeehZcC6JQNlydb/ZHMRrhmQa+htGhWLCzd6Q9rLe0MwZLPpSPFV2/bN5egCLyoKjQ==} + /turbo@1.12.4: + resolution: {integrity: sha512-yUJ7elEUSToiGwFZogXpYKJpQ0BvaMbkEuQECIWtkBLcmWzlMOt6bActsIm29oN83mRU0WbzGt4e8H1KHWedhg==} hasBin: true - requiresBuild: true optionalDependencies: - turbo-darwin-64: 1.10.12 - turbo-darwin-arm64: 1.10.12 - turbo-linux-64: 1.10.12 - turbo-linux-arm64: 1.10.12 - turbo-windows-64: 1.10.12 - turbo-windows-arm64: 1.10.12 + turbo-darwin-64: 1.12.4 + turbo-darwin-arm64: 1.12.4 + turbo-linux-64: 1.12.4 + turbo-linux-arm64: 1.12.4 + turbo-windows-64: 1.12.4 + turbo-windows-arm64: 1.12.4 dev: true /tweetnacl@0.14.5: @@ -9940,6 +14088,16 @@ packages: prelude-ls: 1.2.1 dev: true + /type-detect@4.0.8: + resolution: {integrity: sha512-0fr/mIH1dlO+x7TlcMy+bIDqKPsw/70tVyeHW787goQjhmqaZe10uwLujubK9q9Lg6Fiho1KUKDYz0Z7k7g5/g==} + engines: {node: '>=4'} + dev: true + + /type-fest@0.13.1: + resolution: {integrity: sha512-34R7HTnG0XIJcBSn5XhDd7nNFPRcXYRZrBB2O2jdKqYODldSzBAqzsWoZYYvduky73toYS/ESqxPvkDf/F0XMg==} + engines: {node: '>=10'} + dev: true + /type-fest@0.20.2: resolution: {integrity: sha512-Ne+eE4r0/iWnpAxD852z3A+N0Bt5RN//NjJwRd2VFHEmrywxf5vsZlh4R6lixl6B+wz/8d+maTSAkN1FIkI3LQ==} engines: {node: '>=10'} @@ -9968,6 +14126,11 @@ packages: engines: {node: '>=12.20'} dev: true + /type-fest@3.13.1: + resolution: {integrity: sha512-tLq3bSNx+xSpwvAJnzrK0Ep5CLNWjvFTOp71URMaAEWBfRb9nnJiBoUe0tF8bI4ZFO3omgBR6NvnbzVUT3Ly4g==} + engines: {node: '>=14.16'} + dev: true + /type-is@1.6.18: resolution: {integrity: sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==} engines: {node: '>= 0.6'} @@ -9976,27 +14139,64 @@ packages: mime-types: 2.1.35 dev: false - /typed-array-length@1.0.4: - resolution: {integrity: sha512-KjZypGq+I/H7HI5HlOoGHkWUUGq+Q0TPhQurLbyrVrvnKTBgzLhIJ7j6J/XTQOi0d1RjyZ0wdas8bKs2p0x3Ng==} + /typed-array-buffer@1.0.2: + resolution: {integrity: sha512-gEymJYKZtKXzzBzM4jqa9w6Q1Jjm7x2d+sh19AdsD4wqnMPDYyvwpsIc2Q/835kHuo3BEQ7CjelGhfTsoBb2MQ==} + engines: {node: '>= 0.4'} + dependencies: + call-bind: 1.0.7 + es-errors: 1.3.0 + is-typed-array: 1.1.13 + + /typed-array-byte-length@1.0.1: + resolution: {integrity: sha512-3iMJ9q0ao7WE9tWcaYKIptkNBuOIcZCCT0d4MRvuuH88fEoEH62IuQe0OtraD3ebQEoTRk8XCBoknUNc1Y67pw==} + engines: {node: '>= 0.4'} + dependencies: + call-bind: 1.0.7 + for-each: 0.3.3 + gopd: 1.0.1 + has-proto: 1.0.3 + is-typed-array: 1.1.13 + + /typed-array-byte-offset@1.0.2: + resolution: {integrity: sha512-Ous0vodHa56FviZucS2E63zkgtgrACj7omjwd/8lTEMEPFFyjfixMZ1ZXenpgCFBBt4EC1J2XsyVS2gkG0eTFA==} + engines: {node: '>= 0.4'} + dependencies: + available-typed-arrays: 1.0.7 + call-bind: 1.0.7 + for-each: 0.3.3 + gopd: 1.0.1 + has-proto: 1.0.3 + is-typed-array: 1.1.13 + + /typed-array-length@1.0.5: + resolution: {integrity: sha512-yMi0PlwuznKHxKmcpoOdeLwxBoVPkqZxd7q2FgMkmD3bNwvF5VW0+UlUQ1k1vmktTu4Yu13Q0RIxEP8+B+wloA==} + engines: {node: '>= 0.4'} dependencies: - call-bind: 1.0.2 + call-bind: 1.0.7 for-each: 0.3.3 - is-typed-array: 1.1.10 + gopd: 1.0.1 + has-proto: 1.0.3 + is-typed-array: 1.1.13 + possible-typed-array-names: 1.0.0 /typedarray-to-buffer@3.1.5: resolution: {integrity: sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q==} dependencies: is-typedarray: 1.0.0 - /typescript@5.0.4: - resolution: {integrity: sha512-cW9T5W9xY37cc+jfEnaUvX91foxtHkza3Nw3wkoF4sSlKn0MONdkdEndig/qPBWXNkmplh3NzayQzCiHM4/hqw==} - engines: {node: '>=12.20'} + /typescript@5.3.3: + resolution: {integrity: sha512-pXWcraxM0uxAS+tN0AG/BF2TyqmHO014Z070UsJ+pFvYuRSq8KH8DmWpnbXe0pEPDHXZV3FcAbJkijJ5oNEnWw==} + engines: {node: '>=14.17'} hasBin: true + /ufo@1.4.0: + resolution: {integrity: sha512-Hhy+BhRBleFjpJ2vchUNN40qgkh0366FWJGqVLYBHev0vpHTrXSA0ryT+74UiW6KWsldNurQMKGqCm1M2zBciQ==} + dev: true + /unbox-primitive@1.0.2: resolution: {integrity: sha512-61pPlCD9h51VoreyJ0BReideM3MDKMKnh6+V9L08331ipq6Q8OFXZYiqP6n/tbHx4s5I9uRhcye6BrbkizkBDw==} dependencies: - call-bind: 1.0.2 + call-bind: 1.0.7 has-bigints: 1.0.2 has-symbols: 1.0.3 which-boxed-primitive: 1.0.2 @@ -10006,12 +14206,14 @@ packages: dependencies: buffer: 5.7.1 through: 2.3.8 - dev: false /underscore@1.13.6: resolution: {integrity: sha512-+A5Sja4HP1M08MaXya7p5LvjuM7K6q/2EaC0+iovj/wOcMsTzMvDFbasi/oSapiwOlt252IqsKqPjCl7huKS0A==} dev: false + /undici-types@5.26.5: + resolution: {integrity: sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==} + /unicode-canonical-property-names-ecmascript@2.0.0: resolution: {integrity: sha512-yY5PpDlfVIU5+y/BSCxAJRBIS1Zc2dDG3Ujq+sR0U+JjUevW2JhocOF+soROYDSaAezOzOKuyyixhD6mBknSmQ==} engines: {node: '>=4'} @@ -10070,23 +14272,23 @@ packages: crypto-random-string: 4.0.0 dev: true - /universal-user-agent@6.0.0: - resolution: {integrity: sha512-isyNax3wXoKaulPDZWHQqbmIx1k2tb9fb3GGDBRxCscfYV2Ch7WxPArBsFEG8s/safwXTT7H4QGhaIkTp9447w==} + /universal-user-agent@6.0.1: + resolution: {integrity: sha512-yCzhz6FN2wU1NiiQRogkTQszlQSlpWaw8SvVegAc+bDxbzHgh1vX8uIe8OYyMH6DwH+sdTJsgMl36+mSMdRJIQ==} dev: true /universalify@0.1.2: resolution: {integrity: sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==} engines: {node: '>= 4.0.0'} + dev: false /universalify@0.2.0: resolution: {integrity: sha512-CJ1QgKmNg3CwvAv/kOFmtnEN05f0D/cn9QntgNOQlQF9dgvVTHj3t+8JPdjqawCHk7V/KA+fbUqzZ9XWhcqPUg==} engines: {node: '>= 4.0.0'} dev: false - /universalify@2.0.0: - resolution: {integrity: sha512-hAZsKq7Yy11Zu1DE0OzWjw7nnLZmJZYTDZZyEFHZdUhV8FkH5MCfoU1XMaxXovpyW5nq5scPqq0ZDP9Zyl04oQ==} + /universalify@2.0.1: + resolution: {integrity: sha512-gptHNQghINnc/vTGIk0SOFGFNXw7JVrlRUtConJRlvaw6DuX0wO5Jeko9sWrMBhh+PsYAZ7oXAiOnf/UKogyiw==} engines: {node: '>= 10.0.0'} - dev: false /unpipe@1.0.0: resolution: {integrity: sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==} @@ -10097,16 +14299,15 @@ packages: resolution: {integrity: sha512-KK8xQ1mkzZeg9inewmFVDNkg3l5LUhoq9kN6iWYB/CC9YMG8HA+c1Q8HwDe6dEX7kErrEVNVBO3fWsVq5iDgtw==} engines: {node: '>=8'} - /update-browserslist-db@1.0.11(browserslist@4.21.5): - resolution: {integrity: sha512-dCwEFf0/oT85M1fHBg4F0jtLwJrutGoHSQXCh7u4o2t1drG+c0a9Flnqww6XUKSfQMPpJBRjU8d4RXB09qtvaA==} + /update-browserslist-db@1.0.13(browserslist@4.23.0): + resolution: {integrity: sha512-xebP81SNcPuNpPP3uzeW1NYXxI3rxyJzF3pD6sH4jE7o/IX+WtSpwnVU+qIsDPyk0d3hmFQ7mjqc6AtV604hbg==} hasBin: true peerDependencies: browserslist: '>= 4.21.0' dependencies: - browserslist: 4.21.5 - escalade: 3.1.1 + browserslist: 4.23.0 + escalade: 3.1.2 picocolors: 1.0.0 - dev: false /update-check@1.5.4: resolution: {integrity: sha512-5YHsflzHP4t1G+8WGPlvKbJEbAJGCgw+Em+dGR1KmBUbr1J36SJBqlHLjR7oob7sco5hWHGQVcr9B2poIVDDTQ==} @@ -10119,7 +14320,7 @@ packages: resolution: {integrity: sha512-EDxhTEVPZZRLWYcJ4ZXjGFN0oP7qYvbXWzEgRm/Yql4dHX5wDbvh89YHP6PK1lzZJYrMtXUuZZz8XGK+U6U1og==} engines: {node: '>=14.16'} dependencies: - boxen: 7.0.2 + boxen: 7.1.1 chalk: 5.3.0 configstore: 6.0.0 has-yarn: 3.0.0 @@ -10130,7 +14331,7 @@ packages: is-yarn-global: 0.4.1 latest-version: 7.0.0 pupa: 3.1.0 - semver: 7.5.4 + semver: 7.6.0 semver-diff: 4.0.0 xdg-basedir: 5.1.0 dev: true @@ -10138,7 +14339,7 @@ packages: /uri-js@4.4.1: resolution: {integrity: sha512-7rKUyy33Q1yc98pQ1DAmLtwX109F7TIfWlW1Ydo8Wl1ii1SeHieeh0HHfPeL2fMXK6z0s8ecKs9frCuLJvndBg==} dependencies: - punycode: 2.3.0 + punycode: 2.3.1 /url-join@5.0.0: resolution: {integrity: sha512-n2huDr9h9yzd6exQVnH/jU5mr+Pfx08LRXXZhkLLetAMESRj+anQsTAh940iMrIetKAmry9coFuZQ2jY8/p3WA==} @@ -10164,6 +14365,18 @@ packages: engines: {node: '>= 4'} dev: false + /urlpattern-polyfill@10.0.0: + resolution: {integrity: sha512-H/A06tKD7sS1O1X2SshBVeA5FLycRpjqiBeqGKmBwBDBy28EnRjORxTNe269KSSr5un5qyWi1iL61wLxpd+ZOg==} + dev: true + + /use-sync-external-store@1.2.0(react@18.2.0): + resolution: {integrity: sha512-eEgnFxGQ1Ife9bzYs6VLi8/4X6CObHMw9Qr9tPY43iKwsPw8xE8+EFsf/2cFZ5S3esXgpWgtSCtLNS41F+sKPA==} + peerDependencies: + react: ^16.8.0 || ^17.0.0 || ^18.0.0 + dependencies: + react: 18.2.0 + dev: true + /user-home@2.0.0: resolution: {integrity: sha512-KMWqdlOcjCYdtIJpicDSFBQ8nFwS2i9sslAd6f4+CBGcU4gist2REnr2fxj2YocvJFxSF3ZOHLYLVZnUxv4BZQ==} engines: {node: '>=0.10.0'} @@ -10181,8 +14394,8 @@ packages: /util.promisify@1.0.0: resolution: {integrity: sha512-i+6qA2MPhvoKLuxnJNpXAGhg7HphQOSUq2LKMZD0m15EiskXUkMvKdF4Uui0WYeCUGea+o2cw/ZuwehtfsrNkA==} dependencies: - define-properties: 1.2.0 - object.getownpropertydescriptors: 2.1.6 + define-properties: 1.2.1 + object.getownpropertydescriptors: 2.1.7 dev: false /utila@0.4.0: @@ -10226,38 +14439,200 @@ packages: extsprintf: 1.3.0 dev: false - /viem@1.6.0(typescript@5.0.4): - resolution: {integrity: sha512-ae9Twkd0q2Qlj4yYpWjb4DzYAhKY0ibEpRH8FJaTywZXNpTjFidSdBaT0CVn1BaH7O7cnX4/O47zvDUMGJD1AA==} + /viem@1.21.4(typescript@5.3.3): + resolution: {integrity: sha512-BNVYdSaUjeS2zKQgPs+49e5JKocfo60Ib2yiXOWBT6LuVxY1I/6fFX3waEtpXvL1Xn4qu+BVitVtMh9lyThyhQ==} peerDependencies: typescript: '>=5.0.4' peerDependenciesMeta: typescript: optional: true dependencies: - '@adraffy/ens-normalize': 1.9.0 - '@noble/curves': 1.1.0 - '@noble/hashes': 1.3.0 - '@scure/bip32': 1.3.0 - '@scure/bip39': 1.2.0 - '@types/ws': 8.5.4 - '@wagmi/chains': 1.6.0(typescript@5.0.4) - abitype: 0.9.3(typescript@5.0.4) - isomorphic-ws: 5.0.0(ws@8.12.0) - typescript: 5.0.4 - ws: 8.12.0 + '@adraffy/ens-normalize': 1.10.0 + '@noble/curves': 1.2.0 + '@noble/hashes': 1.3.2 + '@scure/bip32': 1.3.2 + '@scure/bip39': 1.2.1 + abitype: 0.9.8(typescript@5.3.3) + isows: 1.0.3(ws@8.13.0) + typescript: 5.3.3 + ws: 8.13.0 transitivePeerDependencies: - bufferutil - utf-8-validate - zod dev: false - /wait-on@7.0.1(debug@4.3.4): - resolution: {integrity: sha512-9AnJE9qTjRQOlTZIldAaf/da2eW0eSRSgcqq85mXQja/DW3MriHxkpODDSUEg+Gri/rKEcXUZHe+cevvYItaog==} + /vite-node@1.3.1: + resolution: {integrity: sha512-azbRrqRxlWTJEVbzInZCTchx0X69M/XPTCz4H+TLvlTcR/xH/3hkRqhOakT41fMJCMzXTu4UvegkZiEoJAWvng==} + engines: {node: ^18.0.0 || >=20.0.0} + hasBin: true + dependencies: + cac: 6.7.14 + debug: 4.3.4(supports-color@8.1.1) + pathe: 1.1.2 + picocolors: 1.0.0 + vite: 5.1.4 + transitivePeerDependencies: + - '@types/node' + - less + - lightningcss + - sass + - stylus + - sugarss + - supports-color + - terser + dev: true + + /vite-tsconfig-paths@4.3.1(typescript@5.3.3)(vite@4.5.2): + resolution: {integrity: sha512-cfgJwcGOsIxXOLU/nELPny2/LUD/lcf1IbfyeKTv2bsupVbTH/xpFtdQlBmIP1GEK2CjjLxYhFfB+QODFAx5aw==} + peerDependencies: + vite: '*' + peerDependenciesMeta: + vite: + optional: true + dependencies: + debug: 4.3.4(supports-color@8.1.1) + globrex: 0.1.2 + tsconfck: 3.0.2(typescript@5.3.3) + vite: 4.5.2 + transitivePeerDependencies: + - supports-color + - typescript + dev: true + + /vite@4.5.2: + resolution: {integrity: sha512-tBCZBNSBbHQkaGyhGCDUGqeo2ph8Fstyp6FMSvTtsXeZSPpSMGlviAOav2hxVTqFcx8Hj/twtWKsMJXNY0xI8w==} + engines: {node: ^14.18.0 || >=16.0.0} + hasBin: true + peerDependencies: + '@types/node': '>= 14' + less: '*' + lightningcss: ^1.21.0 + sass: '*' + stylus: '*' + sugarss: '*' + terser: ^5.4.0 + peerDependenciesMeta: + '@types/node': + optional: true + less: + optional: true + lightningcss: + optional: true + sass: + optional: true + stylus: + optional: true + sugarss: + optional: true + terser: + optional: true + dependencies: + esbuild: 0.18.20 + postcss: 8.4.35 + rollup: 3.29.4 + optionalDependencies: + fsevents: 2.3.3 + dev: true + + /vite@5.1.4: + resolution: {integrity: sha512-n+MPqzq+d9nMVTKyewqw6kSt+R3CkvF9QAKY8obiQn8g1fwTscKxyfaYnC632HtBXAQGc1Yjomphwn1dtwGAHg==} + engines: {node: ^18.0.0 || >=20.0.0} + hasBin: true + peerDependencies: + '@types/node': ^18.0.0 || >=20.0.0 + less: '*' + lightningcss: ^1.21.0 + sass: '*' + stylus: '*' + sugarss: '*' + terser: ^5.4.0 + peerDependenciesMeta: + '@types/node': + optional: true + less: + optional: true + lightningcss: + optional: true + sass: + optional: true + stylus: + optional: true + sugarss: + optional: true + terser: + optional: true + dependencies: + esbuild: 0.19.12 + postcss: 8.4.35 + rollup: 4.12.0 + optionalDependencies: + fsevents: 2.3.3 + dev: true + + /vitest@1.3.1(happy-dom@13.6.2): + resolution: {integrity: sha512-/1QJqXs8YbCrfv/GPQ05wAZf2eakUPLPa18vkJAKE7RXOKfVHqMZZ1WlTjiwl6Gcn65M5vpNUB6EFLnEdRdEXQ==} + engines: {node: ^18.0.0 || >=20.0.0} + hasBin: true + peerDependencies: + '@edge-runtime/vm': '*' + '@types/node': ^18.0.0 || >=20.0.0 + '@vitest/browser': 1.3.1 + '@vitest/ui': 1.3.1 + happy-dom: '*' + jsdom: '*' + peerDependenciesMeta: + '@edge-runtime/vm': + optional: true + '@types/node': + optional: true + '@vitest/browser': + optional: true + '@vitest/ui': + optional: true + happy-dom: + optional: true + jsdom: + optional: true + dependencies: + '@vitest/expect': 1.3.1 + '@vitest/runner': 1.3.1 + '@vitest/snapshot': 1.3.1 + '@vitest/spy': 1.3.1 + '@vitest/utils': 1.3.1 + acorn-walk: 8.3.2 + chai: 4.4.1 + debug: 4.3.4(supports-color@8.1.1) + execa: 8.0.1 + happy-dom: 13.6.2 + local-pkg: 0.5.0 + magic-string: 0.30.7 + pathe: 1.1.2 + picocolors: 1.0.0 + std-env: 3.7.0 + strip-literal: 2.0.0 + tinybench: 2.6.0 + tinypool: 0.8.2 + vite: 5.1.4 + vite-node: 1.3.1 + why-is-node-running: 2.2.2 + transitivePeerDependencies: + - less + - lightningcss + - sass + - stylus + - sugarss + - supports-color + - terser + dev: true + + /wait-on@7.2.0(debug@4.3.4): + resolution: {integrity: sha512-wCQcHkRazgjG5XoAq9jbTMLpNIjoSlZslrJ2+N9MxDsGEv1HnFoVjOCexL0ESva7Y9cu350j+DWADdk54s4AFQ==} engines: {node: '>=12.0.0'} hasBin: true dependencies: - axios: 0.27.2(debug@4.3.4) - joi: 17.9.2 + axios: 1.6.7(debug@4.3.4) + joi: 17.12.2 lodash: 4.17.21 minimist: 1.2.8 rxjs: 7.8.1 @@ -10284,30 +14659,35 @@ packages: defaults: 1.0.4 dev: true - /web-streams-polyfill@3.2.1: - resolution: {integrity: sha512-e0MO3wdXWKrLbL0DgGnUV7WHVuw9OUvL4hjgnPkIeEvESk74gAITi5G606JtZPp39cd8HA9VQzCIvA49LpPN5Q==} + /web-streams-polyfill@3.3.3: + resolution: {integrity: sha512-d2JWLCivmZYTSIoge9MsgFCZrt571BikcWGYkjC1khllbTeDlGqZ2D8vD8E/lJa8WGWbb7Plm8/XJYV7IJHZZw==} engines: {node: '>= 8'} dev: true /webidl-conversions@3.0.1: resolution: {integrity: sha512-2JAn3z8AR6rjK8Sm8orRC0h/bcl/DqL7tRPdGZ4I1CjdF+EaMLmYxBHyXuKL849eucPFhvBoxMsflfOb8kxaeQ==} - /webpack-dev-middleware@5.3.3(webpack@5.81.0): + /webidl-conversions@7.0.0: + resolution: {integrity: sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g==} + engines: {node: '>=12'} + dev: true + + /webpack-dev-middleware@5.3.3(webpack@5.90.3): resolution: {integrity: sha512-hj5CYrY0bZLB+eTO+x/j67Pkrquiy7kWepMHmUMoPsmcUaeEnQJqFzHJOyxgWlq746/wUuA64p9ta34Kyb01pA==} engines: {node: '>= 12.13.0'} peerDependencies: webpack: ^4.0.0 || ^5.0.0 dependencies: colorette: 2.0.20 - memfs: 3.5.1 + memfs: 3.5.3 mime-types: 2.1.35 range-parser: 1.2.1 - schema-utils: 4.0.1 - webpack: 5.81.0 + schema-utils: 4.2.0 + webpack: 5.90.3 dev: false - /webpack-dev-server@4.13.3(debug@4.3.4)(webpack@5.81.0): - resolution: {integrity: sha512-KqqzrzMRSRy5ePz10VhjyL27K2dxqwXQLP5rAKwRJBPUahe7Z2bBWzHw37jeb8GCPKxZRO79ZdQUAPesMh/Nug==} + /webpack-dev-server@4.15.1(debug@4.3.4)(webpack@5.90.3): + resolution: {integrity: sha512-5hbAst3h3C3L8w6W4P96L5vaV0PxSmJhxZvWKYIdgxOQm8pNZ5dEOmmSLBVpP85ReeyRt6AS1QJNyo/oFFPeVA==} engines: {node: '>= 12.13.0'} hasBin: true peerDependencies: @@ -10319,37 +14699,37 @@ packages: webpack-cli: optional: true dependencies: - '@types/bonjour': 3.5.10 - '@types/connect-history-api-fallback': 1.5.0 - '@types/express': 4.17.17 - '@types/serve-index': 1.9.1 - '@types/serve-static': 1.15.1 - '@types/sockjs': 0.3.33 - '@types/ws': 8.5.4 + '@types/bonjour': 3.5.13 + '@types/connect-history-api-fallback': 1.5.4 + '@types/express': 4.17.21 + '@types/serve-index': 1.9.4 + '@types/serve-static': 1.15.5 + '@types/sockjs': 0.3.36 + '@types/ws': 8.5.10 ansi-html-community: 0.0.8 - bonjour-service: 1.1.1 - chokidar: 3.5.3 + bonjour-service: 1.2.1 + chokidar: 3.6.0 colorette: 2.0.20 compression: 1.7.4 connect-history-api-fallback: 2.0.0 default-gateway: 6.0.3 express: 4.18.2 graceful-fs: 4.2.11 - html-entities: 2.3.3 - http-proxy-middleware: 2.0.6(@types/express@4.17.17)(debug@4.3.4) - ipaddr.js: 2.0.1 - launch-editor: 2.6.0 + html-entities: 2.4.0 + http-proxy-middleware: 2.0.6(@types/express@4.17.21)(debug@4.3.4) + ipaddr.js: 2.1.0 + launch-editor: 2.6.1 open: 8.4.2 p-retry: 4.6.2 rimraf: 3.0.2 - schema-utils: 4.0.1 - selfsigned: 2.1.1 + schema-utils: 4.2.0 + selfsigned: 2.4.1 serve-index: 1.9.1 sockjs: 0.3.24 spdy: 4.0.2 - webpack: 5.81.0 - webpack-dev-middleware: 5.3.3(webpack@5.81.0) - ws: 8.13.0 + webpack: 5.90.3 + webpack-dev-middleware: 5.3.3(webpack@5.90.3) + ws: 8.16.0 transitivePeerDependencies: - bufferutil - debug @@ -10357,11 +14737,12 @@ packages: - utf-8-validate dev: false - /webpack-merge@5.8.0: - resolution: {integrity: sha512-/SaI7xY0831XwP6kzuwhKWVKDP9t1QY1h65lAFLbZqMPIuYcD9QAW4u9STIbU9kaJbPBB/geU/gLr1wDjOhQ+Q==} + /webpack-merge@5.10.0: + resolution: {integrity: sha512-+4zXKdx7UnO+1jaN4l2lHVD+mFvnlZQP/6ljaJVb4SZiwIKeUnrT5l0gkT8z+n4hKpC+jpOv6O9R+gLtag7pSA==} engines: {node: '>=10.0.0'} dependencies: clone-deep: 4.0.1 + flat: 5.0.2 wildcard: 2.0.1 dev: false @@ -10370,8 +14751,8 @@ packages: engines: {node: '>=10.13.0'} dev: false - /webpack@5.81.0: - resolution: {integrity: sha512-AAjaJ9S4hYCVODKLQTgG5p5e11hiMawBwV2v8MYLE0C/6UAGLuAF4n1qa9GOwdxnicaP+5k6M5HrLmD4+gIB8Q==} + /webpack@5.90.3: + resolution: {integrity: sha512-h6uDYlWCctQRuXBs1oYpVe6sFcWedl0dpcVaTf/YF67J9bKvwJajFulMVSYKHrksMB3I/pIagRzDxwxkebuzKA==} engines: {node: '>=10.13.0'} hasBin: true peerDependencies: @@ -10380,17 +14761,17 @@ packages: webpack-cli: optional: true dependencies: - '@types/eslint-scope': 3.7.4 - '@types/estree': 1.0.1 - '@webassemblyjs/ast': 1.11.5 - '@webassemblyjs/wasm-edit': 1.11.5 - '@webassemblyjs/wasm-parser': 1.11.5 - acorn: 8.10.0 - acorn-import-assertions: 1.8.0(acorn@8.10.0) - browserslist: 4.21.5 + '@types/eslint-scope': 3.7.7 + '@types/estree': 1.0.5 + '@webassemblyjs/ast': 1.11.6 + '@webassemblyjs/wasm-edit': 1.11.6 + '@webassemblyjs/wasm-parser': 1.11.6 + acorn: 8.11.3 + acorn-import-assertions: 1.9.0(acorn@8.11.3) + browserslist: 4.23.0 chrome-trace-event: 1.0.3 - enhanced-resolve: 5.13.0 - es-module-lexer: 1.2.1 + enhanced-resolve: 5.15.1 + es-module-lexer: 1.4.1 eslint-scope: 5.1.1 events: 3.3.0 glob-to-regexp: 0.4.1 @@ -10399,9 +14780,9 @@ packages: loader-runner: 4.3.0 mime-types: 2.1.35 neo-async: 2.6.2 - schema-utils: 3.1.2 + schema-utils: 3.3.0 tapable: 2.2.1 - terser-webpack-plugin: 5.3.7(webpack@5.81.0) + terser-webpack-plugin: 5.3.10(webpack@5.90.3) watchpack: 2.4.0 webpack-sources: 3.2.3 transitivePeerDependencies: @@ -10424,6 +14805,16 @@ packages: engines: {node: '>=0.8.0'} dev: false + /well-known-symbols@2.0.0: + resolution: {integrity: sha512-ZMjC3ho+KXo0BfJb7JgtQ5IBuvnShdlACNkKkdsqBmYw3bPAaJfPeYUo6tLUaT5tG/Gkh7xkpBhKRQ9e7pyg9Q==} + engines: {node: '>=6'} + dev: true + + /whatwg-mimetype@3.0.0: + resolution: {integrity: sha512-nt+N2dzIutVRxARx1nghPKGv1xHikU7HKdfafKkLNLindmPU/ch3U31NOCGGA/dmPcmb1VlofO0vnKAcsm0o/Q==} + engines: {node: '>=12'} + dev: true + /whatwg-url@5.0.0: resolution: {integrity: sha512-saE57nupxk6v3HY35+jzBwYa0rKSy0XR8JSxZPwgLr7ys0IBzhGviA1/TUGJLmSVqs8pb9AnvICXEuOHLprYTw==} dependencies: @@ -10439,29 +14830,19 @@ packages: is-string: 1.0.7 is-symbol: 1.0.4 - /which-collection@1.0.1: - resolution: {integrity: sha512-W8xeTUwaln8i3K/cY1nGXzdnVZlidBcagyNFtBdD5kxnb4TvGKR7FfSIS3mYpwWS1QUCutfKz8IY8RjftB0+1A==} - dependencies: - is-map: 2.0.2 - is-set: 2.0.2 - is-weakmap: 2.0.1 - is-weakset: 2.0.2 - dev: false - /which-module@2.0.1: resolution: {integrity: sha512-iBdZ57RDvnOR9AGBhML2vFZf7h8vmBjhoaZqODJBFWHVtKkDmKuHai3cx5PgVMrX5YDNp27AofYbAwctSS+vhQ==} dev: false - /which-typed-array@1.1.9: - resolution: {integrity: sha512-w9c4xkx6mPidwp7180ckYWfMmvxpjlZuIudNtDf4N/tTAUB8VJbX25qZoAsrtGuYNnGw3pa0AXgbGKRB8/EceA==} + /which-typed-array@1.1.14: + resolution: {integrity: sha512-VnXFiIW8yNn9kIHN88xvZ4yOWchftKDsRJ8fEPacX/wl1lOvBrhsJ/OeJCXq7B0AaijRuqgzSKalJoPk+D8MPg==} engines: {node: '>= 0.4'} dependencies: - available-typed-arrays: 1.0.5 - call-bind: 1.0.2 + available-typed-arrays: 1.0.7 + call-bind: 1.0.7 for-each: 0.3.3 gopd: 1.0.1 - has-tostringtag: 1.0.0 - is-typed-array: 1.1.10 + has-tostringtag: 1.0.2 /which@2.0.2: resolution: {integrity: sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==} @@ -10478,6 +14859,15 @@ packages: isexe: 2.0.0 dev: true + /why-is-node-running@2.2.2: + resolution: {integrity: sha512-6tSwToZxTOcotxHeA+qGCq1mVzKR3CwcJGmVcY+QE8SHy6TnpFnh8PAvPNHYr7EcuVeG0QSMxtYCuO1ta/G/oA==} + engines: {node: '>=8'} + hasBin: true + dependencies: + siginfo: 2.0.0 + stackback: 0.0.2 + dev: true + /wide-align@1.1.5: resolution: {integrity: sha512-eDMORYaPNZ4sQIuuYPDHdQvf4gyCF9rEEV/yPxGfwPkRodwEgiMUUXTx/dex+Me0wxx53S+NgUHaP7y3MGlDmg==} dependencies: @@ -10499,13 +14889,37 @@ packages: resolution: {integrity: sha512-CC1bOL87PIWSBhDcTrdeLo6eGT7mCFtrg0uIJtqJUFyK+eJnzl8A1niH56uu7KMa5XFrtiV+AQuHO3n7DsHnLQ==} dev: false - /windows-release@5.1.0: - resolution: {integrity: sha512-CddHecz5dt0ngTjGPP1uYr9Tjl4qq5rEKNk8UGb8XCdngNXI+GRYvqelD055FdiUgqODZz3R/5oZWYldPtXQpA==} + /windows-release@5.1.1: + resolution: {integrity: sha512-NMD00arvqcq2nwqc5Q6KtrSRHK+fVD31erE5FEMahAw5PmVCgD7MUXodq3pdZSUkqA9Cda2iWx6s1XYwiJWRmw==} engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} dependencies: execa: 5.1.1 dev: true + /winston-transport@4.7.0: + resolution: {integrity: sha512-ajBj65K5I7denzer2IYW6+2bNIVqLGDHqDw3Ow8Ohh+vdW+rv4MZ6eiDvHoKhfJFZ2auyN8byXieDDJ96ViONg==} + engines: {node: '>= 12.0.0'} + dependencies: + logform: 2.6.0 + readable-stream: 3.6.2 + triple-beam: 1.3.0 + dev: true + + /winston@3.3.3: + resolution: {integrity: sha512-oEXTISQnC8VlSAKf1KYSSd7J6IWuRPQqDdo8eoRNaYKLvwSb5+79Z3Yi1lrl6KDpU6/VWaxpakDAtb1oQ4n9aw==} + engines: {node: '>= 6.4.0'} + dependencies: + '@dabh/diagnostics': 2.0.3 + async: 3.2.5 + is-stream: 2.0.1 + logform: 2.6.0 + one-time: 1.0.0 + readable-stream: 3.6.2 + stack-trace: 0.0.10 + triple-beam: 1.3.0 + winston-transport: 4.7.0 + dev: true + /wrap-ansi@6.2.0: resolution: {integrity: sha512-r6lPcBGxZXlIcymEu7InxDMhdW0KDxpLgoFLcguasxCaJ/SOIZwINatK9KY/tf+ZrlywOKU0UDj3ATXUBfxJXA==} engines: {node: '>=8'} @@ -10529,7 +14943,6 @@ packages: ansi-styles: 6.2.1 string-width: 5.1.2 strip-ansi: 7.1.0 - dev: true /wrappy@1.0.2: resolution: {integrity: sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==} @@ -10542,18 +14955,26 @@ packages: signal-exit: 3.0.7 typedarray-to-buffer: 3.1.5 - /ws@8.12.0: - resolution: {integrity: sha512-kU62emKIdKVeEIOIKVegvqpXMSTAMLJozpHZaJNDYqBjzlSYXQGviYwN1osDLJ9av68qHd4a2oSjd7yD4pacig==} - engines: {node: '>=10.0.0'} + /write-file-atomic@5.0.1: + resolution: {integrity: sha512-+QU2zd6OTD8XWIJCbffaiQeH9U73qIqafo1x6V1snCWYGJf6cVE0cDR4D8xRzcEnfI21IFrUPzPGtcPf8AC+Rw==} + engines: {node: ^14.17.0 || ^16.13.0 || >=18.0.0} + dependencies: + imurmurhash: 0.1.4 + signal-exit: 4.1.0 + dev: true + + /ws@7.5.9: + resolution: {integrity: sha512-F+P9Jil7UiSKSkppIiD94dN07AwvFixvLIj1Og1Rl9GGMuNipJnV9JzjD6XuqmAeiswGvUmNLjr5cFuXwNS77Q==} + engines: {node: '>=8.3.0'} peerDependencies: bufferutil: ^4.0.1 - utf-8-validate: '>=5.0.2' + utf-8-validate: ^5.0.2 peerDependenciesMeta: bufferutil: optional: true utf-8-validate: optional: true - dev: false + dev: true /ws@8.13.0: resolution: {integrity: sha512-x9vcZYTrFPC7aSIbj7sRCYo7L/Xb8Iy+pW0ng0wt2vCJv7M9HOMy0UoN3rr+IFC7hb7vXoqS+P9ktyLLLhO+LA==} @@ -10568,6 +14989,18 @@ packages: optional: true dev: false + /ws@8.16.0: + resolution: {integrity: sha512-HS0c//TP7Ina87TfiPUz1rQzMhHrl/SG2guqRcTOIUYD2q8uhUdNHZYJUaQ8aTGPzCh+c6oawMKW35nFl1dxyQ==} + engines: {node: '>=10.0.0'} + peerDependencies: + bufferutil: ^4.0.1 + utf-8-validate: '>=5.0.2' + peerDependenciesMeta: + bufferutil: + optional: true + utf-8-validate: + optional: true + /ws@8.5.0: resolution: {integrity: sha512-BWX0SWVgLPzYwF8lTzEy1egjhS4S4OEAHfsO8o65WOVsrnSRGaSiUaa9e0ggGlkMTtBlmOpEXiie9RUcBO86qg==} engines: {node: '>=10.0.0'} @@ -10586,6 +15019,13 @@ packages: engines: {node: '>=12'} dev: true + /xstream@11.14.0: + resolution: {integrity: sha512-1bLb+kKKtKPbgTK6i/BaoAn03g47PpFstlbe1BA+y3pNS/LfvcaghS5BFf9+EE1J+KwSQsEpfJvFN5GqFtiNmw==} + dependencies: + globalthis: 1.0.3 + symbol-observable: 2.0.3 + dev: true + /xtend@4.0.2: resolution: {integrity: sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==} engines: {node: '>=0.4'} @@ -10595,9 +15035,13 @@ packages: resolution: {integrity: sha512-JKhqTOwSrqNA1NY5lSztJ1GrBiUodLMmIZuLiDaMRJ+itFd+ABVE8XBjOvIWL+rSqNDC74LCSFmlb/U4UZ4hJQ==} dev: false + /y18n@5.0.8: + resolution: {integrity: sha512-0pfFzegeDWJHJIAmTLRP2DwHjdF5s7jo9tuztdQxAhINCdvS+3nGINqPd00AphqJR/0LhANUS6/+7SCb98YOfA==} + engines: {node: '>=10'} + dev: true + /yallist@3.1.1: resolution: {integrity: sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==} - dev: false /yallist@4.0.0: resolution: {integrity: sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==} @@ -10632,12 +15076,24 @@ packages: yargs-parser: 18.1.3 dev: false + /yargs@17.7.2: + resolution: {integrity: sha512-7dSzzRQ++CKnNI/krKnYRV7JKKPUXMEh61soaHKg9mrWEhzFWhFnxPxGl+69cD1Ou63C13NUPCnmIcrvqCuM6w==} + engines: {node: '>=12'} + dependencies: + cliui: 8.0.1 + escalade: 3.1.2 + get-caller-file: 2.0.5 + require-directory: 2.1.1 + string-width: 4.2.3 + y18n: 5.0.8 + yargs-parser: 21.1.1 + dev: true + /yauzl@2.10.0: resolution: {integrity: sha512-p4a9I6X6nu6IhoGmBqAcbJy1mlC4j27vEPZX9F4L4/vZT3Lyq1VkFHw/V/PUcB9Buo+DG3iHkT0x3Qya58zc3g==} dependencies: buffer-crc32: 0.2.13 fd-slicer: 1.1.0 - dev: false /yocto-queue@0.1.0: resolution: {integrity: sha512-rVksvsnNCdJ/ohGc6xgPwyN8eheCxsiLM8mxuE/t/mOVqJewPuO1miLpTHQiRgTKCLexL4MeAFVagts7HmNZ2Q==} @@ -10647,4 +15103,30 @@ packages: /yocto-queue@1.0.0: resolution: {integrity: sha512-9bnSc/HEW2uRy67wc+T8UwauLuPJVn28jb+GtJY16iiKWyvmYJRXVT4UamsAEGQfPohgr2q4Tq0sQbQlxTfi1g==} engines: {node: '>=12.20'} - dev: false + + /zustand@4.5.1(@types/react@18.2.60)(react@18.2.0): + resolution: {integrity: sha512-XlauQmH64xXSC1qGYNv00ODaQ3B+tNPoy22jv2diYiP4eoDKr9LA+Bh5Bc3gplTrFdb6JVI+N4kc1DZ/tbtfPg==} + engines: {node: '>=12.7.0'} + peerDependencies: + '@types/react': '>=16.8' + immer: '>=9.0.6' + react: '>=16.8' + peerDependenciesMeta: + '@types/react': + optional: true + immer: + optional: true + react: + optional: true + dependencies: + '@types/react': 18.2.60 + react: 18.2.0 + use-sync-external-store: 1.2.0(react@18.2.0) + dev: true + + github.com/agoric-labs/esm/3603726ad4636b2f865f463188fcaade6375638e: + resolution: {tarball: https://codeload.github.com/agoric-labs/esm/tar.gz/3603726ad4636b2f865f463188fcaade6375638e} + name: esm + version: 3.2.25 + engines: {node: '>=6'} + dev: true diff --git a/pnpm-workspace.yaml b/pnpm-workspace.yaml new file mode 100644 index 000000000..39a985dda --- /dev/null +++ b/pnpm-workspace.yaml @@ -0,0 +1,2 @@ +packages: + - 'tools/ui/' diff --git a/start-tests.sh b/start-tests.sh index 6a17c4a3e..15312ad18 100755 --- a/start-tests.sh +++ b/start-tests.sh @@ -1,2 +1,2 @@ #!/bin/bash -docker-compose --profile synpress --profile foundry up --build --exit-code-from synpress +docker-compose --profile synpress up --build --exit-code-from synpress diff --git a/tools/json-server-db.json b/tools/json-server-db.json new file mode 100644 index 000000000..061186462 --- /dev/null +++ b/tools/json-server-db.json @@ -0,0 +1,13 @@ +{ + "agoric_chain":{ + "chainName": "agoriclocal", + "rpcAddrs": ["http://agoric_chain:26657"], + "dappInterJumperBanner": "A Chrome update is affecting some users' dapp-wallet connection. If you're affected by this issue, please use Brave with shields down until the fix completes." + }, + "localhost":{ + "chainName": "agoriclocal", + "rpcAddrs": ["http://localhost:26657"], + "dappInterJumperBanner": "A Chrome update is affecting some users' dapp-wallet connection. If you're affected by this issue, please use Brave with shields down until the fix completes." + } + +} \ No newline at end of file From f026bce42d19bc7e79e4341ae2d716ed92f4bace Mon Sep 17 00:00:00 2001 From: Rabi Siddique <60459172+rabi-siddique@users.noreply.github.com> Date: Mon, 4 Mar 2024 17:31:01 +0500 Subject: [PATCH 19/35] Single Screen Interaction, Approve Button Fix and Code Cleanup (#9) * chore: organize code in playwright.keplr.js and remove not used states * chore: resolve merge conflicts with dev branch * chore: using a consistent and more intention revealing name for a helper function * chore: adding a test case for validating the switchToExtensionWindow function * chore: change selector for Approve button on connecting with wallet UI * chore: addressing PR comments --- commands/keplr.js | 46 +++- commands/metamask.js | 1 + commands/playwright-keplr.js | 320 ++++++++++------------- pages/keplr/notification-page.js | 2 +- support/commands.js | 8 - tests/e2e/specs/keplr/keplr-spec.js | 29 +- tests/e2e/specs/keplr/playwright-spec.js | 9 + 7 files changed, 194 insertions(+), 221 deletions(-) diff --git a/commands/keplr.js b/commands/keplr.js index 10c26612a..000d970c6 100644 --- a/commands/keplr.js +++ b/commands/keplr.js @@ -7,41 +7,72 @@ const { let extensionId; let extensionVersion; +let registrationUrl; +let permissionsUrl; +let switchBackToCypressWindow; const keplr = { async resetState() { log('Resetting state of keplr'); extensionId = undefined; extensionVersion = undefined; + registrationUrl = undefined; + permissionsUrl = undefined; }, extensionId: () => { return extensionId; }, extensionUrls: () => { return { - extensionImportAccountUrl, + registrationUrl, + permissionsUrl, }; }, - + async goTo(url) { + await Promise.all([ + playwright.keplrWindow().waitForNavigation(), + playwright.keplrWindow().goto(url), + ]); + await playwright.waitUntilStable(); + }, + async goToRegistration() { + await module.exports.goTo(registrationUrl); + }, + async goToPermissions() { + await module.exports.goTo(permissionsUrl); + }, + async switchToKeplrIfNotActive() { + if (await playwright.isCypressWindowActive()) { + await playwright.switchToKeplrWindow(); + switchBackToCypressWindow = true; + } + return switchBackToCypressWindow; + }, async getExtensionDetails() { const keplrExtensionData = (await playwright.getExtensionsData()).keplr; extensionId = keplrExtensionData.id; extensionVersion = keplrExtensionData.version; + registrationUrl = `chrome-extension://${extensionId}/register.html`; + permissionsUrl = `chrome-extension://${extensionId}/popup.html#/setting/security/permission`; return { extensionId, extensionVersion, + registrationUrl, + permissionsUrl, }; }, async disconnectWalletFromDapp() { + await module.exports.goToPermissions(); await playwright.waitAndClickByText( 'Disconnect All', - playwright.keplrPermissionWindow(), + playwright.keplrWindow(), ); return true; }, async importWallet(secretWordsOrPrivateKey, password, newAccount) { + await module.exports.goToRegistration(); await playwright.waitAndClickByText( newAccount ? onboardingElements.createWalletButton @@ -79,7 +110,7 @@ const keplr = { onboardingElements.walletName, ); - const passwordFieldExists = await playwright.doesElementExist( + const passwordFieldExists = await playwright.waitForAndCheckElementExistence( onboardingElements.passwordInput, ); @@ -112,12 +143,7 @@ const keplr = { await playwright.keplrWindow(), ); - await playwright.waitAndClick( - onboardingElements.finishButton, - await playwright.keplrWindow(), - { dontWait: true }, - ); - + await playwright.switchToCypressWindow(); return true; }, async importWalletWithPhrase(secretWords) { diff --git a/commands/metamask.js b/commands/metamask.js index c7b34357a..f1721f861 100644 --- a/commands/metamask.js +++ b/commands/metamask.js @@ -582,6 +582,7 @@ const metamask = { return true; }, async disconnectWalletFromDapp() { + await playwright.switchToKeplrWindow(); await switchToMetamaskIfNotActive(); await playwright.waitAndClick(mainPageElements.optionsMenu.button); await playwright.waitAndClick( diff --git a/commands/playwright-keplr.js b/commands/playwright-keplr.js index 4f1aeea12..9ebafc484 100644 --- a/commands/playwright-keplr.js +++ b/commands/playwright-keplr.js @@ -7,8 +7,6 @@ let browser; let mainWindow; let keplrWindow; let keplrNotificationWindow; -let keplrRegistrationWindow; -let keplrPermissionWindow; let activeTabName; let extensionsData = {}; let retries = 0; @@ -21,12 +19,53 @@ module.exports = { keplrWindow = undefined; activeTabName = undefined; keplrNotificationWindow = undefined; - keplrRegistrationWindow = undefined; - keplrPermissionWindow = undefined; retries = 0; extensionsData = {}; }, - + browser() { + return browser; + }, + mainWindow() { + return mainWindow; + }, + keplrWindow() { + return keplrWindow; + }, + keplrNotificationWindow() { + return keplrNotificationWindow; + }, + async assignActiveTabName(tabName) { + activeTabName = tabName; + return true; + }, + async isKeplrWindowActive() { + return activeTabName === 'keplr'; + }, + async isCypressWindowActive() { + return activeTabName === 'cypress'; + }, + async switchToKeplrWindow() { + await keplrWindow.bringToFront(); + await module.exports.assignActiveTabName('keplr'); + return true; + }, + async switchToCypressWindow() { + if (mainWindow) { + await mainWindow.bringToFront(); + await module.exports.assignActiveTabName('cypress'); + } + return true; + }, + async clear() { + browser = null; + return true; + }, + async clearWindows() { + mainWindow = null; + keplrWindow = null; + keplrNotificationWindow = null; + return true; + }, async init(playwrightInstance) { const chromium = playwrightInstance ? playwrightInstance @@ -49,7 +88,52 @@ module.exports = { } return browser.isConnected(); }, + async getExtensionsData() { + if (!_.isEmpty(extensionsData)) { + return extensionsData; + } + + const context = await browser.contexts()[0]; + const page = await context.newPage(); + + await page.goto('chrome://extensions'); + await page.waitForLoadState('load'); + await page.waitForLoadState('domcontentloaded'); + + const devModeButton = page.locator('#devMode'); + await devModeButton.waitFor(); + await devModeButton.focus(); + await devModeButton.click(); + + const extensionDataItems = await page.locator('extensions-item').all(); + for (const extensionData of extensionDataItems) { + const extensionName = ( + await extensionData + .locator('#name-and-version') + .locator('#name') + .textContent() + ).toLowerCase(); + + const extensionVersion = ( + await extensionData + .locator('#name-and-version') + .locator('#version') + .textContent() + ).replace(/(\n| )/g, ''); + + const extensionId = ( + await extensionData.locator('#extension-id').textContent() + ).replace('ID: ', ''); + + extensionsData[extensionName] = { + version: extensionVersion, + id: extensionId, + }; + } + await page.close(); + return extensionsData; + }, async assignWindows() { const keplrExtensionData = (await module.exports.getExtensionsData()).keplr; @@ -68,40 +152,64 @@ module.exports = { } return true; }, - async assignActiveTabName(tabName) { - activeTabName = tabName; - return true; - }, - - async isKeplrWindowActive() { - return activeTabName === 'keplr'; - }, + async waitUntilStable(page) { + const keplrExtensionData = (await module.exports.getExtensionsData()).keplr; + if ( + page && + page + .url() + .includes(`chrome-extension://${keplrExtensionData.id}/register.html`) + ) { + await page.waitForLoadState('load'); + await page.waitForLoadState('domcontentloaded'); + await page.waitForLoadState('networkidle'); + } + await keplrWindow.waitForLoadState('load'); + await keplrWindow.waitForLoadState('domcontentloaded'); + await keplrWindow.waitForLoadState('networkidle'); - keplrNotificationWindow() { - return keplrNotificationWindow; + if (mainWindow) { + await mainWindow.waitForLoadState('load'); + await mainWindow.waitForLoadState('domcontentloaded'); + // todo: this may slow down tests and not be necessary but could improve stability + // await mainWindow.waitForLoadState('networkidle'); + } }, - - keplrPermissionWindow() { - return keplrPermissionWindow; + async waitFor(selector, page = keplrWindow, number = 0) { + await module.exports.waitUntilStable(page); + await page.waitForSelector(selector, { strict: false }); + const element = page.locator(selector).nth(number); + await element.waitFor(); + await element.focus(); + if (process.env.STABLE_MODE) { + if (!isNaN(process.env.STABLE_MODE)) { + await page.waitForTimeout(Number(process.env.STABLE_MODE)); + } else { + await page.waitForTimeout(300); + } + } + return element; }, - - async switchToKeplrPermissionWindow() { - const keplrExtensionData = (await module.exports.getExtensionsData()).keplr; - const browserContext = await browser.contexts()[0]; - keplrPermissionWindow = await browserContext.newPage(); - await keplrPermissionWindow.goto( - `chrome-extension://${keplrExtensionData.id}/popup.html#/setting/security/permission`, - ); - return true; + async waitForByText(text, page = keplrWindow) { + await module.exports.waitUntilStable(page); + const element = page.getByText(text).first(); + await element.waitFor(); + await element.focus(); + if (process.env.STABLE_MODE) { + if (!isNaN(process.env.STABLE_MODE)) { + await page.waitForTimeout(Number(process.env.STABLE_MODE)); + } else { + await page.waitForTimeout(300); + } + } + return element; }, - async waitAndClickByText(text, page = keplrWindow, exact = false) { await module.exports.waitForByText(text, page); const element = `:is(:text-is("${text}")${exact ? '' : `, :text("${text}")`})`; await page.click(element); await module.exports.waitUntilStable(); }, - async waitAndSetValue(text, selector, page = keplrWindow) { const element = await module.exports.waitFor(selector, page); await element.fill(''); @@ -109,7 +217,6 @@ module.exports = { await element.fill(text); await module.exports.waitUntilStable(page); }, - async waitAndGetValue(selector, page = keplrWindow) { const expect = expectInstance ? expectInstance @@ -122,7 +229,6 @@ module.exports = { const value = await element.innerText(); return value; }, - async waitAndClick(selector, page = keplrWindow, args = {}) { const element = await module.exports.waitFor( selector, @@ -157,81 +263,7 @@ module.exports = { await module.exports.waitUntilStable(); return element; }, - - async switchToCypressWindow() { - if (mainWindow) { - await mainWindow.bringToFront(); - await module.exports.assignActiveTabName('cypress'); - } - return true; - }, - - async clear() { - browser = null; - return true; - }, - - async clearWindows() { - mainWindow = null; - keplrWindow = null; - return true; - }, - - async isCypressWindowActive() { - return activeTabName === 'cypress'; - }, - - async switchToKeplrWindow() { - await keplrWindow.bringToFront(); - await module.exports.assignActiveTabName('keplr'); - return true; - }, - - async waitUntilStable(page) { - const keplrExtensionData = (await module.exports.getExtensionsData()).keplr; - - if ( - page && - page - .url() - .includes(`chrome-extension://${keplrExtensionData.id}/register.html`) - ) { - await page.waitForLoadState('load'); - await page.waitForLoadState('domcontentloaded'); - await page.waitForLoadState('networkidle'); - } - await keplrWindow.waitForLoadState('load'); - await keplrWindow.waitForLoadState('domcontentloaded'); - await keplrWindow.waitForLoadState('networkidle'); - - if (mainWindow) { - await mainWindow.waitForLoadState('load'); - await mainWindow.waitForLoadState('domcontentloaded'); - // todo: this may slow down tests and not be necessary but could improve stability - // await mainWindow.waitForLoadState('networkidle'); - } - }, - - keplrWindow() { - return keplrWindow; - }, - - async waitFor(selector, page = keplrWindow, number = 0) { - await module.exports.waitUntilStable(page); - await page.waitForSelector(selector, { strict: false }); - const element = page.locator(selector).nth(number); - await element.waitFor(); - await element.focus(); - if (process.env.STABLE_MODE) { - if (!isNaN(process.env.STABLE_MODE)) { - await page.waitForTimeout(Number(process.env.STABLE_MODE)); - } else { - await page.waitForTimeout(300); - } - } - return element; - }, - async doesElementExist(selector, timeout = 1000, page = keplrWindow) { + async waitForAndCheckElementExistence(selector, timeout = 1000, page = keplrWindow) { try { await page.waitForSelector(selector, { timeout }); return true; @@ -239,22 +271,6 @@ module.exports = { return false; } }, - async waitForByText(text, page = keplrWindow) { - await module.exports.waitUntilStable(page); - // await page.waitForSelector(selector, { strict: false }); - const element = page.getByText(text).first(); - await element.waitFor(); - await element.focus(); - if (process.env.STABLE_MODE) { - if (!isNaN(process.env.STABLE_MODE)) { - await page.waitForTimeout(Number(process.env.STABLE_MODE)); - } else { - await page.waitForTimeout(300); - } - } - return element; - }, - async waitAndClick(selector, page = keplrWindow, args = {}) { const element = await module.exports.waitFor( selector, @@ -289,7 +305,6 @@ module.exports = { await module.exports.waitUntilStable(); return element; }, - async waitForByRole(role, number = 0, page = keplrWindow) { await module.exports.waitUntilStable(page); const element = page.getByRole(role).nth(number); @@ -304,7 +319,6 @@ module.exports = { } return element; }, - async waitAndType(selector, value, page = keplrWindow) { if (typeof value === 'number') { value = value.toString(); @@ -313,7 +327,6 @@ module.exports = { await element.type(value); await module.exports.waitUntilStable(page); }, - async waitAndTypeByLocator(selector, value, number = 0, page = keplrWindow) { if (typeof value === 'number') { value = value.toString(); @@ -322,63 +335,6 @@ module.exports = { await element.type(value); await module.exports.waitUntilStable(page); }, - - async getExtensionsData() { - if (!_.isEmpty(extensionsData)) { - return extensionsData; - } - - const context = await browser.contexts()[0]; - const page = await context.newPage(); - - await page.goto('chrome://extensions'); - await page.waitForLoadState('load'); - await page.waitForLoadState('domcontentloaded'); - - const devModeButton = page.locator('#devMode'); - await devModeButton.waitFor(); - await devModeButton.focus(); - await devModeButton.click(); - - const extensionDataItems = await page.locator('extensions-item').all(); - for (const extensionData of extensionDataItems) { - const extensionName = ( - await extensionData - .locator('#name-and-version') - .locator('#name') - .textContent() - ).toLowerCase(); - - const extensionVersion = ( - await extensionData - .locator('#name-and-version') - .locator('#version') - .textContent() - ).replace(/(\n| )/g, ''); - - const extensionId = ( - await extensionData.locator('#extension-id').textContent() - ).replace('ID: ', ''); - - extensionsData[extensionName] = { - version: extensionVersion, - id: extensionId, - }; - } - await page.close(); - - return extensionsData; - }, - - async switchToKeplrRegistrationWindow() { - const keplrExtensionData = (await module.exports.getExtensionsData()).keplr; - const browserContext = await browser.contexts()[0]; - keplrRegistrationWindow = await browserContext.newPage(); - await keplrRegistrationWindow.goto( - `chrome-extension://${keplrExtensionData.id}/register.html`, - ); - return true; - }, async switchToKeplrNotification() { const keplrExtensionData = (await module.exports.getExtensionsData()).keplr; diff --git a/pages/keplr/notification-page.js b/pages/keplr/notification-page.js index 639ba0ae2..e5e59a883 100644 --- a/pages/keplr/notification-page.js +++ b/pages/keplr/notification-page.js @@ -1,4 +1,4 @@ -const approveButton = `button[type="button"]`; +const approveButton = `button`; module.exports.notificationPageElements = { approveButton, diff --git a/support/commands.js b/support/commands.js index 8961b6d85..7cf288e4f 100644 --- a/support/commands.js +++ b/support/commands.js @@ -445,14 +445,6 @@ Cypress.Commands.add('switchToExtensionWindow', () => { return cy.task('switchToExtensionWindow'); }); -Cypress.Commands.add('switchToExtensionRegistrationWindow', () => { - return cy.task('switchToExtensionRegistrationWindow'); -}); - -Cypress.Commands.add('switchToExtensionPermissionWindow', () => { - return cy.task('switchToExtensionPermissionWindow'); -}); - Cypress.Commands.add('disconnectWalletFromDapp', () => { return cy.task('disconnectWalletFromDapp'); }); diff --git a/tests/e2e/specs/keplr/keplr-spec.js b/tests/e2e/specs/keplr/keplr-spec.js index 7afb6a698..9756036dd 100644 --- a/tests/e2e/specs/keplr/keplr-spec.js +++ b/tests/e2e/specs/keplr/keplr-spec.js @@ -7,7 +7,7 @@ describe('Keplr', () => { }); cy.visit('/'); }); - it(`should reject connect with wallet`, () => { + it(`should reject connection with wallet`, () => { const alertShown = cy.stub().as('alertShown'); cy.on('window:alert', alertShown); @@ -40,35 +40,19 @@ describe('Keplr', () => { 'Offer accepted', ); }); - it(`should complete Keplr connect with wallet, and confirm transaction after creating a new wallet using 24 word phrase`, () => { - cy.switchToExtensionRegistrationWindow().then(() => { + it(`should create a new wallet using 24 word phrase`, () => { + cy.switchToExtensionWindow().then(() => { cy.setupWallet( 'orbit bench unit task food shock brand bracket domain regular warfare company announce wheel grape trust sphere boy doctor half guard ritual three ecology', 'Test1234', true, ).then(setupFinished => { expect(setupFinished).to.be.true; - - cy.visit('/'); - cy.contains('Connect Wallet').click(); - cy.contains('Make an Offer').click(); - cy.confirmTransaction().then(taskCompleted => { - expect(taskCompleted).to.be.true; - }); - }); - }); - }); - - it(`should disconnect the wallet from all the connected DAPPs`, () => { - cy.switchToExtensionPermissionWindow().then(() => { - cy.disconnectWalletFromDapp().then(taskCompleted => { - expect(taskCompleted).to.be.true; }); }); }); - it(`should complete Keplr setup by importing the wallet using private key`, () => { - cy.switchToExtensionRegistrationWindow().then(() => { + cy.switchToExtensionWindow().then(() => { cy.setupWallet( 'A9C09B6E4AF70DE1F1B621CB1AA66CFD0B4AA977E4C18497C49132DD9E579485', ).then(setupFinished => { @@ -76,5 +60,10 @@ describe('Keplr', () => { }); }); }); + it(`should disconnect the wallet from all the connected DAPPs`, () => { + cy.disconnectWalletFromDapp().then(taskCompleted => { + expect(taskCompleted).to.be.true; + }); + }); }); }); diff --git a/tests/e2e/specs/keplr/playwright-spec.js b/tests/e2e/specs/keplr/playwright-spec.js index 46bad8fdf..6d0bc67b4 100644 --- a/tests/e2e/specs/keplr/playwright-spec.js +++ b/tests/e2e/specs/keplr/playwright-spec.js @@ -28,5 +28,14 @@ describe('Playwright', () => { expect(isActive).to.be.false; }); }); + it(`switchToExtensionWindow should properly switch active tab to keplr window`, () => { + cy.switchToExtensionWindow(); + cy.isExtensionWindowActive().then(isActive => { + expect(isActive).to.be.true; + }); + cy.isCypressWindowActive().then(isActive => { + expect(isActive).to.be.false; + }); + }); }); }); \ No newline at end of file From 1081dc079bc5fa1886f95ac567c68d3b5737db14 Mon Sep 17 00:00:00 2001 From: frazarshad Date: Mon, 4 Mar 2024 05:58:47 -0800 Subject: [PATCH 20/35] Interaction for transaction rejection (#12) * feat: added logic for transaction rejection * feat: added test for transaction rejection * fix: typo in test name --- commands/keplr.js | 6 ++++++ plugins/keplr-plugin.js | 1 + support/commands.js | 4 ++++ tests/e2e/specs/keplr/keplr-spec.js | 14 ++++++++++++++ 4 files changed, 25 insertions(+) diff --git a/commands/keplr.js b/commands/keplr.js index 000d970c6..8df501adf 100644 --- a/commands/keplr.js +++ b/commands/keplr.js @@ -208,6 +208,12 @@ const keplr = { return true; }, + async rejectTransaction() { + const notificationPage = await playwright.switchToKeplrNotification(); + await notificationPage.close(); + return true; + }, + async initialSetup( playwrightInstance, { secretWordsOrPrivateKey, password, newAccount }, diff --git a/plugins/keplr-plugin.js b/plugins/keplr-plugin.js index f556721fd..f010067a8 100644 --- a/plugins/keplr-plugin.js +++ b/plugins/keplr-plugin.js @@ -69,6 +69,7 @@ module.exports = (on, config) => { acceptAccess: keplr.acceptAccess, rejectAccess: keplr.rejectAccess, confirmTransaction: keplr.confirmTransaction, + rejectTransaction: keplr.rejectTransaction, disconnectWalletFromDapp: keplr.disconnectWalletFromDapp, setupWallet: async ({ secretWordsOrPrivateKey, password, newAccount }) => { await keplr.initialSetup(null, { diff --git a/support/commands.js b/support/commands.js index 7cf288e4f..1d76b206b 100644 --- a/support/commands.js +++ b/support/commands.js @@ -437,6 +437,10 @@ Cypress.Commands.add('confirmTransaction', () => { return cy.task('confirmTransaction'); }); +Cypress.Commands.add('rejectTransaction', () => { + return cy.task('rejectTransaction'); +}); + Cypress.Commands.add('isExtensionWindowActive', () => { return cy.task('isExtensionWindowActive'); }); diff --git a/tests/e2e/specs/keplr/keplr-spec.js b/tests/e2e/specs/keplr/keplr-spec.js index 9756036dd..92511f502 100644 --- a/tests/e2e/specs/keplr/keplr-spec.js +++ b/tests/e2e/specs/keplr/keplr-spec.js @@ -26,6 +26,20 @@ describe('Keplr', () => { expect(taskCompleted).to.be.true; }); }); + it(`should reject make an offer transaction`, () => { + const alertShown = cy.stub().as('alertShown'); + cy.on('window:alert', alertShown); + + cy.contains('Make an Offer').click(); + cy.rejectTransaction().then(taskCompleted => { + expect(taskCompleted).to.be.true; + }); + + cy.get('@alertShown').should( + 'have.been.calledOnceWith', + 'Offer error: Error: Request rejected', + ); + }); it(`should confirm make an offer transaction`, () => { const alertShown = cy.stub().as('alertShown'); cy.on('window:alert', alertShown); From bbff0a4b69920553997207c5c1e46476897776ac Mon Sep 17 00:00:00 2001 From: Rabi Siddique <60459172+rabi-siddique@users.noreply.github.com> Date: Tue, 5 Mar 2024 08:51:33 +0500 Subject: [PATCH 21/35] chore:remove call to switchToKeplrWindow in metamask.js (#16) --- commands/metamask.js | 1 - 1 file changed, 1 deletion(-) diff --git a/commands/metamask.js b/commands/metamask.js index f1721f861..c7b34357a 100644 --- a/commands/metamask.js +++ b/commands/metamask.js @@ -582,7 +582,6 @@ const metamask = { return true; }, async disconnectWalletFromDapp() { - await playwright.switchToKeplrWindow(); await switchToMetamaskIfNotActive(); await playwright.waitAndClick(mainPageElements.optionsMenu.button); await playwright.waitAndClick( From e6c340ec92ef9d29a56e3da83ba4bdcd7fe79790 Mon Sep 17 00:00:00 2001 From: Rabi Siddique <60459172+rabi-siddique@users.noreply.github.com> Date: Tue, 5 Mar 2024 11:02:18 +0500 Subject: [PATCH 22/35] Abstracting Calls to Switching Extension in Keplr Helper Methods (#13) * chore: abstracting calls to switching to keplr window in keplr helper functions * chore: removing unnecessary awaits with sync function --- commands/keplr.js | 7 +++++-- commands/playwright-keplr.js | 10 +++++----- tests/e2e/specs/keplr/keplr-spec.js | 24 ++++++++++-------------- 3 files changed, 20 insertions(+), 21 deletions(-) diff --git a/commands/keplr.js b/commands/keplr.js index 8df501adf..03c141a73 100644 --- a/commands/keplr.js +++ b/commands/keplr.js @@ -42,7 +42,7 @@ const keplr = { await module.exports.goTo(permissionsUrl); }, async switchToKeplrIfNotActive() { - if (await playwright.isCypressWindowActive()) { + if (playwright.isCypressWindowActive()) { await playwright.switchToKeplrWindow(); switchBackToCypressWindow = true; } @@ -225,7 +225,10 @@ const keplr = { } await playwright.assignWindows(); - await playwright.assignActiveTabName('keplr'); + if (!playwright.isKeplrWindowActive()) { + await playwright.switchToKeplrWindow(); + } + playwright.assignActiveTabName('keplr'); await module.exports.getExtensionDetails(); await module.exports.importWallet( secretWordsOrPrivateKey, diff --git a/commands/playwright-keplr.js b/commands/playwright-keplr.js index 9ebafc484..d5ff94d84 100644 --- a/commands/playwright-keplr.js +++ b/commands/playwright-keplr.js @@ -34,25 +34,25 @@ module.exports = { keplrNotificationWindow() { return keplrNotificationWindow; }, - async assignActiveTabName(tabName) { + assignActiveTabName(tabName) { activeTabName = tabName; return true; }, - async isKeplrWindowActive() { + isKeplrWindowActive() { return activeTabName === 'keplr'; }, - async isCypressWindowActive() { + isCypressWindowActive() { return activeTabName === 'cypress'; }, async switchToKeplrWindow() { await keplrWindow.bringToFront(); - await module.exports.assignActiveTabName('keplr'); + module.exports.assignActiveTabName('keplr'); return true; }, async switchToCypressWindow() { if (mainWindow) { await mainWindow.bringToFront(); - await module.exports.assignActiveTabName('cypress'); + module.exports.assignActiveTabName('cypress'); } return true; }, diff --git a/tests/e2e/specs/keplr/keplr-spec.js b/tests/e2e/specs/keplr/keplr-spec.js index 92511f502..09ae290e9 100644 --- a/tests/e2e/specs/keplr/keplr-spec.js +++ b/tests/e2e/specs/keplr/keplr-spec.js @@ -55,23 +55,19 @@ describe('Keplr', () => { ); }); it(`should create a new wallet using 24 word phrase`, () => { - cy.switchToExtensionWindow().then(() => { - cy.setupWallet( - 'orbit bench unit task food shock brand bracket domain regular warfare company announce wheel grape trust sphere boy doctor half guard ritual three ecology', - 'Test1234', - true, - ).then(setupFinished => { - expect(setupFinished).to.be.true; - }); + cy.setupWallet( + 'orbit bench unit task food shock brand bracket domain regular warfare company announce wheel grape trust sphere boy doctor half guard ritual three ecology', + 'Test1234', + true, + ).then(setupFinished => { + expect(setupFinished).to.be.true; }); }); it(`should complete Keplr setup by importing the wallet using private key`, () => { - cy.switchToExtensionWindow().then(() => { - cy.setupWallet( - 'A9C09B6E4AF70DE1F1B621CB1AA66CFD0B4AA977E4C18497C49132DD9E579485', - ).then(setupFinished => { - expect(setupFinished).to.be.true; - }); + cy.setupWallet( + 'A9C09B6E4AF70DE1F1B621CB1AA66CFD0B4AA977E4C18497C49132DD9E579485', + ).then(setupFinished => { + expect(setupFinished).to.be.true; }); }); it(`should disconnect the wallet from all the connected DAPPs`, () => { From 6e2b5c4b872670c6d690a5dc9526cbc57afdfce0 Mon Sep 17 00:00:00 2001 From: frazarshad Date: Mon, 4 Mar 2024 23:21:31 -0800 Subject: [PATCH 23/35] Enable setup of the keplr extension in the beforeAll hook for cypress (#14) * fix: added code to handle setup of keplr wallet beforehand * chore: lint fixes --- plugins/index.js | 12 ++++++++++-- support/index.js | 11 +++++++++-- 2 files changed, 19 insertions(+), 4 deletions(-) diff --git a/plugins/index.js b/plugins/index.js index 6507a48c0..29f89de05 100644 --- a/plugins/index.js +++ b/plugins/index.js @@ -6,10 +6,18 @@ module.exports = (on, config) => { } else if (extension === 'keplr') { selectedConfig = require('./keplr-plugin'); } else { - throw new Error( - `${extension} is not a valid extension name`, + throw new Error(`${extension} is not a valid extension name`); + } + + if (process.env.SKIP_EXTENSION_SETUP) { + config.env.SKIP_EXTENSION_SETUP = JSON.parse( + process.env.SKIP_EXTENSION_SETUP, ); } + if (process.env.EXTENSION) { + config.env.EXTENSION = process.env.EXTENSION; + } + return selectedConfig(on, config); }; diff --git a/support/index.js b/support/index.js index 8bb05ed2c..92911f960 100644 --- a/support/index.js +++ b/support/index.js @@ -25,7 +25,14 @@ Cypress.on('window:before:load', win => { }); before(() => { - if (Cypress.env('EXTENSION') === 'metamask' && !Cypress.env('SKIP_EXTENSION_SETUP')) { - cy.setupMetamask(); + if (!Cypress.env('SKIP_EXTENSION_SETUP')) { + switch (Cypress.env('EXTENSION')) { + case 'metamask': + cy.setupMetamask(); + break; + case 'keplr': + cy.setupWallet(); + break; + } } }); From d333345514df153bb01479bc826c586b627ec6b0 Mon Sep 17 00:00:00 2001 From: frazarshad Date: Tue, 5 Mar 2024 06:50:28 -0800 Subject: [PATCH 24/35] Add command to switch to another wallet (#18) * feat: interaction to switch wallet * chore: fixes for await async --- commands/keplr.js | 43 +++++++++++++++++++++++------ pages/keplr/first-time-flow-page.js | 7 ++--- plugins/keplr-plugin.js | 9 +++++- support/commands.js | 6 ++++ tests/e2e/specs/keplr/keplr-spec.js | 10 +++++++ 5 files changed, 60 insertions(+), 15 deletions(-) diff --git a/commands/keplr.js b/commands/keplr.js index 03c141a73..7ebbd9474 100644 --- a/commands/keplr.js +++ b/commands/keplr.js @@ -9,6 +9,7 @@ let extensionId; let extensionVersion; let registrationUrl; let permissionsUrl; +let walletsPageUrl; let switchBackToCypressWindow; const keplr = { @@ -18,6 +19,7 @@ const keplr = { extensionVersion = undefined; registrationUrl = undefined; permissionsUrl = undefined; + walletsPageUrl = undefined; }, extensionId: () => { return extensionId; @@ -41,6 +43,9 @@ const keplr = { async goToPermissions() { await module.exports.goTo(permissionsUrl); }, + async goToWalletsPage() { + await module.exports.goTo(walletsPageUrl); + }, async switchToKeplrIfNotActive() { if (playwright.isCypressWindowActive()) { await playwright.switchToKeplrWindow(); @@ -55,12 +60,14 @@ const keplr = { extensionVersion = keplrExtensionData.version; registrationUrl = `chrome-extension://${extensionId}/register.html`; permissionsUrl = `chrome-extension://${extensionId}/popup.html#/setting/security/permission`; + walletsPageUrl = `chrome-extension://${extensionId}/popup.html#/wallet/select`; return { extensionId, extensionVersion, registrationUrl, permissionsUrl, + walletsPageUrl, }; }, async disconnectWalletFromDapp() { @@ -71,7 +78,12 @@ const keplr = { ); return true; }, - async importWallet(secretWordsOrPrivateKey, password, newAccount) { + async importWallet( + secretWordsOrPrivateKey, + password, + newAccount, + walletName, + ) { await module.exports.goToRegistration(); await playwright.waitAndClickByText( newAccount @@ -105,14 +117,12 @@ const keplr = { ); } - await playwright.waitAndType( - onboardingElements.walletInput, - onboardingElements.walletName, - ); + await playwright.waitAndType(onboardingElements.walletInput, walletName); - const passwordFieldExists = await playwright.waitForAndCheckElementExistence( - onboardingElements.passwordInput, - ); + const passwordFieldExists = + await playwright.waitForAndCheckElementExistence( + onboardingElements.passwordInput, + ); if (passwordFieldExists) { await playwright.waitAndType(onboardingElements.passwordInput, password); @@ -216,7 +226,7 @@ const keplr = { async initialSetup( playwrightInstance, - { secretWordsOrPrivateKey, password, newAccount }, + { secretWordsOrPrivateKey, password, newAccount, walletName }, ) { if (playwrightInstance) { await playwright.init(playwrightInstance); @@ -234,8 +244,23 @@ const keplr = { secretWordsOrPrivateKey, password, newAccount, + walletName, ); }, + + async switchWallet({ walletName }) { + await module.exports.switchToKeplrIfNotActive(); + await module.exports.goToWalletsPage(); + + await playwright.waitAndClickByText( + walletName, + playwright.keplrWindow(), + true, + ); + await playwright.switchToCypressWindow(); + + return true; + }, }; module.exports = keplr; diff --git a/pages/keplr/first-time-flow-page.js b/pages/keplr/first-time-flow-page.js index 7bfc1bf52..3d6e6337b 100644 --- a/pages/keplr/first-time-flow-page.js +++ b/pages/keplr/first-time-flow-page.js @@ -1,13 +1,12 @@ const createWalletButton = 'Create a new wallet'; const existingWalletButton = 'Import an existing wallet'; -const importRecoveryPhraseButton = 'Import existing recovery phrase'; +const importRecoveryPhraseButton = 'Import existing recovery phrase'; const useRecoveryPhraseButton = 'Use recovery phrase or private key'; const phraseCount24 = '24 words'; const phrasePrivateKey = 'Private key'; const walletInput = 'input[name="name"]:focus'; const passwordInput = 'input[name="password"]'; const confirmPasswordInput = 'input[name="confirmPassword"]'; -const walletName = 'My wallet'; const submitWalletDataButton = 'button[type="submit"]'; const phraseSelectChain = 'Select Chains'; const submitChainButton = 'button[type="button"]'; @@ -24,7 +23,6 @@ module.exports.onboardingElements = { phraseCount24, phrasePrivateKey, walletInput, - walletName, passwordInput, confirmPasswordInput, submitWalletDataButton, @@ -33,6 +31,5 @@ module.exports.onboardingElements = { phraseAccountCreated, finishButton, textAreaSelector, - submitChainButton, submitPhraseButton, -}; \ No newline at end of file +}; diff --git a/plugins/keplr-plugin.js b/plugins/keplr-plugin.js index f010067a8..ae647e325 100644 --- a/plugins/keplr-plugin.js +++ b/plugins/keplr-plugin.js @@ -71,14 +71,21 @@ module.exports = (on, config) => { confirmTransaction: keplr.confirmTransaction, rejectTransaction: keplr.rejectTransaction, disconnectWalletFromDapp: keplr.disconnectWalletFromDapp, - setupWallet: async ({ secretWordsOrPrivateKey, password, newAccount }) => { + setupWallet: async ({ + secretWordsOrPrivateKey, + password, + newAccount, + walletName, + }) => { await keplr.initialSetup(null, { secretWordsOrPrivateKey, password, newAccount, + walletName, }); return true; }, + switchWallet: keplr.switchWallet, }); return config; diff --git a/support/commands.js b/support/commands.js index 1d76b206b..af6c9494d 100644 --- a/support/commands.js +++ b/support/commands.js @@ -416,11 +416,13 @@ Cypress.Commands.add( secretWordsOrPrivateKey = 'orbit bench unit task food shock brand bracket domain regular warfare company announce wheel grape trust sphere boy doctor half guard ritual three ecology', password = 'Test1234', newAccount = false, + walletName = 'My Wallet', ) => { return cy.task('setupWallet', { secretWordsOrPrivateKey, password, newAccount, + walletName, }); }, ); @@ -452,3 +454,7 @@ Cypress.Commands.add('switchToExtensionWindow', () => { Cypress.Commands.add('disconnectWalletFromDapp', () => { return cy.task('disconnectWalletFromDapp'); }); + +Cypress.Commands.add('switchWallet', walletName => { + return cy.task('switchWallet', { walletName }); +}); diff --git a/tests/e2e/specs/keplr/keplr-spec.js b/tests/e2e/specs/keplr/keplr-spec.js index 09ae290e9..ddab9eeb2 100644 --- a/tests/e2e/specs/keplr/keplr-spec.js +++ b/tests/e2e/specs/keplr/keplr-spec.js @@ -59,6 +59,7 @@ describe('Keplr', () => { 'orbit bench unit task food shock brand bracket domain regular warfare company announce wheel grape trust sphere boy doctor half guard ritual three ecology', 'Test1234', true, + 'My Wallet 2', ).then(setupFinished => { expect(setupFinished).to.be.true; }); @@ -66,10 +67,19 @@ describe('Keplr', () => { it(`should complete Keplr setup by importing the wallet using private key`, () => { cy.setupWallet( 'A9C09B6E4AF70DE1F1B621CB1AA66CFD0B4AA977E4C18497C49132DD9E579485', + null, + false, + 'My wallet 3', ).then(setupFinished => { expect(setupFinished).to.be.true; }); }); + it(`should switch to new wallet by name`, () => { + cy.switchWallet('My Wallet 2').then(taskCompleted => { + expect(taskCompleted).to.be.true; + }); + // TODO: Add some more robust check later + }); it(`should disconnect the wallet from all the connected DAPPs`, () => { cy.disconnectWalletFromDapp().then(taskCompleted => { expect(taskCompleted).to.be.true; From fa21859426a3759d2cadee5d04d8c1ebf0f797cb Mon Sep 17 00:00:00 2001 From: Rabi Siddique <60459172+rabi-siddique@users.noreply.github.com> Date: Tue, 5 Mar 2024 22:16:56 +0500 Subject: [PATCH 25/35] Getting Wallet Address (#17) * feat: initial working setup for retrieving wallet address * chore:code cleanup * feat: interaction to switch wallet * chore: simplifying switching screens in import wallet flow * chore format code with prettier * chore: moving get wallet address test case in the main context * chore: fixes for await async * chore: address PR comments --------- Co-authored-by: Fraz Arshad --- commands/keplr.js | 34 +++++++++++-- commands/playwright-keplr.js | 3 ++ package.json | 2 +- pages/keplr/notification-page.js | 4 ++ plugins/keplr-plugin.js | 1 + pnpm-lock.yaml | 76 +++++++++++++++++++++++++++++ support/commands.js | 5 ++ tests/e2e/specs/keplr/keplr-spec.js | 7 +++ 8 files changed, 126 insertions(+), 6 deletions(-) diff --git a/commands/keplr.js b/commands/keplr.js index 7ebbd9474..612024e07 100644 --- a/commands/keplr.js +++ b/commands/keplr.js @@ -4,13 +4,17 @@ const { onboardingElements } = require('../pages/keplr/first-time-flow-page'); const { notificationPageElements, } = require('../pages/keplr/notification-page'); +const clipboardy = require('clipboardy'); + let extensionId; let extensionVersion; let registrationUrl; let permissionsUrl; +let popupUrl; let walletsPageUrl; let switchBackToCypressWindow; +let walletAddress; const keplr = { async resetState() { @@ -19,8 +23,14 @@ const keplr = { extensionVersion = undefined; registrationUrl = undefined; permissionsUrl = undefined; + popupUrl = undefined; + walletAddress = undefined; walletsPageUrl = undefined; }, + walletAddress: () => { + return walletAddress; + + }, extensionId: () => { return extensionId; }, @@ -28,6 +38,7 @@ const keplr = { return { registrationUrl, permissionsUrl, + popupUrl, }; }, async goTo(url) { @@ -43,6 +54,9 @@ const keplr = { async goToPermissions() { await module.exports.goTo(permissionsUrl); }, + async goToHome() { + await module.exports.goTo(popupUrl); + }, async goToWalletsPage() { await module.exports.goTo(walletsPageUrl); }, @@ -60,6 +74,7 @@ const keplr = { extensionVersion = keplrExtensionData.version; registrationUrl = `chrome-extension://${extensionId}/register.html`; permissionsUrl = `chrome-extension://${extensionId}/popup.html#/setting/security/permission`; + popupUrl = `chrome-extension://${extensionId}/popup.html`; walletsPageUrl = `chrome-extension://${extensionId}/popup.html#/wallet/select`; return { @@ -67,6 +82,7 @@ const keplr = { extensionVersion, registrationUrl, permissionsUrl, + popupUrl, walletsPageUrl, }; }, @@ -153,7 +169,6 @@ const keplr = { await playwright.keplrWindow(), ); - await playwright.switchToCypressWindow(); return true; }, async importWalletWithPhrase(secretWords) { @@ -224,6 +239,17 @@ const keplr = { return true; }, + async getWalletAddress() { + await playwright.switchToKeplrWindow(); + await module.exports.goToHome(); + const page = playwright.keplrWindow(); + await playwright.waitAndClickByText(notificationPageElements.copyAddress); + await page.click(notificationPageElements.copyWalletAddressSelector); + walletAddress = clipboardy.readSync(); + await playwright.switchToCypressWindow(); + return walletAddress; + }, + async initialSetup( playwrightInstance, { secretWordsOrPrivateKey, password, newAccount, walletName }, @@ -235,10 +261,7 @@ const keplr = { } await playwright.assignWindows(); - if (!playwright.isKeplrWindowActive()) { - await playwright.switchToKeplrWindow(); - } - playwright.assignActiveTabName('keplr'); + await playwright.switchToKeplrWindow(); await module.exports.getExtensionDetails(); await module.exports.importWallet( secretWordsOrPrivateKey, @@ -246,6 +269,7 @@ const keplr = { newAccount, walletName, ); + await playwright.switchToCypressWindow(); }, async switchWallet({ walletName }) { diff --git a/commands/playwright-keplr.js b/commands/playwright-keplr.js index d5ff94d84..385ab7f55 100644 --- a/commands/playwright-keplr.js +++ b/commands/playwright-keplr.js @@ -44,6 +44,9 @@ module.exports = { isCypressWindowActive() { return activeTabName === 'cypress'; }, + activeTabName() { + return activeTabName; + }, async switchToKeplrWindow() { await keplrWindow.bringToFront(); module.exports.assignActiveTabName('keplr'); diff --git a/package.json b/package.json index 4d39cd6f3..886a46ea2 100644 --- a/package.json +++ b/package.json @@ -53,7 +53,6 @@ "test:e2e:ci:cypress-action": "CYPRESS_USE_ANVIL=true pnpm synpress:run", "synpress:run:keplr": "EXTENSION=keplr SKIP_EXTENSION_SETUP=true SYNPRESS_LOCAL_TEST=true node synpress.js run --configFile=synpress.config.js", "test:e2e:keplr": "start-server-and-test 'pnpm start:ui' http-get://localhost:3000 'pnpm start:json-server' http-get://localhost:3004 'pnpm synpress:run:keplr'" - }, "dependencies": { "@cypress/code-coverage": "^3.11.0", @@ -73,6 +72,7 @@ "babel-plugin-transform-react-qa-classes": "^1.6.0", "babel-plugin-transform-react-styled-components-qa": "^2.1.0", "bytes32": "^0.0.3", + "clipboardy": "^2.3.0", "commander": "^11.0.0", "cypress": "12.17.3", "cypress-wait-until": "^2.0.1", diff --git a/pages/keplr/notification-page.js b/pages/keplr/notification-page.js index e5e59a883..e04726c24 100644 --- a/pages/keplr/notification-page.js +++ b/pages/keplr/notification-page.js @@ -1,5 +1,9 @@ const approveButton = `button`; +const copyAddress = 'Copy Address'; +const copyWalletAddressSelector = 'div.sc-dkzDqf div.sc-hKMtZM.sc-kDDrLX.cyoEAq.dkJSBQ' module.exports.notificationPageElements = { approveButton, + copyAddress, + copyWalletAddressSelector }; \ No newline at end of file diff --git a/plugins/keplr-plugin.js b/plugins/keplr-plugin.js index ae647e325..7da74b18b 100644 --- a/plugins/keplr-plugin.js +++ b/plugins/keplr-plugin.js @@ -68,6 +68,7 @@ module.exports = (on, config) => { importWallet: keplr.importWallet, acceptAccess: keplr.acceptAccess, rejectAccess: keplr.rejectAccess, + getWalletAddress: keplr.getWalletAddress, confirmTransaction: keplr.confirmTransaction, rejectTransaction: keplr.rejectTransaction, disconnectWalletFromDapp: keplr.disconnectWalletFromDapp, diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index caa748429..e6c097911 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -68,6 +68,9 @@ importers: bytes32: specifier: ^0.0.3 version: 0.0.3 + clipboardy: + specifier: ^2.3.0 + version: 2.3.0 commander: specifier: ^11.0.0 version: 11.1.0 @@ -6322,6 +6325,15 @@ packages: engines: {node: '>= 12'} dev: true + /clipboardy@2.3.0: + resolution: {integrity: sha512-mKhiIL2DrQIsuXMgBgnfEHOZOryC7kY7YO//TN6c63wlEm3NG5tz+YgY5rVi29KCmq/QQjKYvM7a19+MDOTHOQ==} + engines: {node: '>=8'} + dependencies: + arch: 2.2.0 + execa: 1.0.0 + is-wsl: 2.2.0 + dev: false + /clipboardy@3.0.0: resolution: {integrity: sha512-Su+uU5sr1jkUy1sGRpLKjKrvEOVXgSgiSInwa/qeID6aJ07yh+5NWc3h2QfjHjBnfX4LhtFcuAWKUsJ3r+fjbg==} engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} @@ -6656,6 +6668,17 @@ packages: - encoding dev: true + /cross-spawn@6.0.5: + resolution: {integrity: sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==} + engines: {node: '>=4.8'} + dependencies: + nice-try: 1.0.5 + path-key: 2.0.1 + semver: 5.7.2 + shebang-command: 1.2.0 + which: 1.3.1 + dev: false + /cross-spawn@7.0.3: resolution: {integrity: sha512-iRDPJKUPVEND7dHPO8rkbOnPpyDygcDFtWjpeWNCgy8WP2rXcxXL8TskReQl6OrB2G7+UJrags1q15Fudc7G6w==} engines: {node: '>= 8'} @@ -8074,6 +8097,19 @@ packages: engines: {node: '>=0.8.x'} dev: false + /execa@1.0.0: + resolution: {integrity: sha512-adbxcyWV46qiHyvSp50TKt05tB4tK3HcmF7/nxfAdhnox83seTDbwnaqKO4sXRy7roHAIFqJP/Rw/AuEbX61LA==} + engines: {node: '>=6'} + dependencies: + cross-spawn: 6.0.5 + get-stream: 4.1.0 + is-stream: 1.1.0 + npm-run-path: 2.0.2 + p-finally: 1.0.0 + signal-exit: 3.0.7 + strip-eof: 1.0.0 + dev: false + /execa@4.1.0: resolution: {integrity: sha512-j5W0//W7f8UxAn8hXVnwG8tLwdiUy4FJLcSupCg6maBYZDpyBvTApK7KyuI4bKj8KOh1r2YH+6ucuYtJv1bTZA==} engines: {node: '>=10'} @@ -11030,6 +11066,10 @@ packages: type-fest: 2.19.0 dev: true + /nice-try@1.0.5: + resolution: {integrity: sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==} + dev: false + /no-case@3.0.4: resolution: {integrity: sha512-fgAN3jGAh+RoxUGZHTSOLJIqUc2wmoBwGR4tbpNAKmmovFoWq0OdRkb0VkldReO2a2iBT/OEulG9XSUc10r3zg==} dependencies: @@ -11280,6 +11320,13 @@ packages: - supports-color dev: true + /npm-run-path@2.0.2: + resolution: {integrity: sha512-lJxZYlT4DW/bRUtFh1MQIWqmLwQfAxnqWG4HhEdjMlkrJYnJn0Jrr2u3mgxqaWsdiBc76TYkTG/mhrnYTuzfHw==} + engines: {node: '>=4'} + dependencies: + path-key: 2.0.1 + dev: false + /npm-run-path@4.0.1: resolution: {integrity: sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==} engines: {node: '>=8'} @@ -11819,6 +11866,11 @@ packages: resolution: {integrity: sha512-DUWJr3+ULp4zXmol/SZkFf3JGsS9/SIv+Y3Rt93/UjPpDpklB5f1er4O3POIbUuUJ3FXgqte2Q7SrU6zAqwk8w==} dev: true + /path-key@2.0.1: + resolution: {integrity: sha512-fEHGKCSmUSDPv4uoj8AlD+joPlq3peND+HRYyxFz4KPw4z926S/b8rIuFs2FYJg3BwsxJf6A9/3eIdLaYC+9Dw==} + engines: {node: '>=4'} + dev: false + /path-key@3.1.1: resolution: {integrity: sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==} engines: {node: '>=8'} @@ -13071,12 +13123,24 @@ packages: kind-of: 6.0.3 dev: false + /shebang-command@1.2.0: + resolution: {integrity: sha512-EV3L1+UQWGor21OmnvojK36mhg+TyIKDh3iFBKBohr5xeXIhNBcx8oWdgkTEEQ+BEFFYdLRuqMfd5L84N1V5Vg==} + engines: {node: '>=0.10.0'} + dependencies: + shebang-regex: 1.0.0 + dev: false + /shebang-command@2.0.0: resolution: {integrity: sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==} engines: {node: '>=8'} dependencies: shebang-regex: 3.0.0 + /shebang-regex@1.0.0: + resolution: {integrity: sha512-wpoSFAxys6b2a2wHZ1XpDSgD7N9iVjg29Ph9uV/uaP9Ex/KXlkTZTeddxDPSYQpgvzKLGJke2UU0AzoGCjNIvQ==} + engines: {node: '>=0.10.0'} + dev: false + /shebang-regex@3.0.0: resolution: {integrity: sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==} engines: {node: '>=8'} @@ -13591,6 +13655,11 @@ packages: is-natural-number: 4.0.1 dev: false + /strip-eof@1.0.0: + resolution: {integrity: sha512-7FCwGGmx8mD5xQd3RPUvnSpUXHM3BWuzjtpD4TXsfcZ9EL4azvVVUscFYwD9nx8Kh+uCBC00XBtAykoMHwTh8Q==} + engines: {node: '>=0.10.0'} + dev: false + /strip-final-newline@2.0.0: resolution: {integrity: sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==} engines: {node: '>=6'} @@ -14844,6 +14913,13 @@ packages: gopd: 1.0.1 has-tostringtag: 1.0.2 + /which@1.3.1: + resolution: {integrity: sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==} + hasBin: true + dependencies: + isexe: 2.0.0 + dev: false + /which@2.0.2: resolution: {integrity: sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==} engines: {node: '>= 8'} diff --git a/support/commands.js b/support/commands.js index af6c9494d..19c296bdd 100644 --- a/support/commands.js +++ b/support/commands.js @@ -455,6 +455,11 @@ Cypress.Commands.add('disconnectWalletFromDapp', () => { return cy.task('disconnectWalletFromDapp'); }); +Cypress.Commands.add('getWalletAddress', () => { + cy.task('getWalletAddress').then(address => { + return address; + }); +}); Cypress.Commands.add('switchWallet', walletName => { return cy.task('switchWallet', { walletName }); }); diff --git a/tests/e2e/specs/keplr/keplr-spec.js b/tests/e2e/specs/keplr/keplr-spec.js index ddab9eeb2..81a6af071 100644 --- a/tests/e2e/specs/keplr/keplr-spec.js +++ b/tests/e2e/specs/keplr/keplr-spec.js @@ -1,4 +1,5 @@ /* eslint-disable ui-testing/no-disabled-tests */ + describe('Keplr', () => { context('Test commands', () => { it(`should complete Keplr setup by importing an existing wallet using 24 word phrase`, () => { @@ -85,5 +86,11 @@ describe('Keplr', () => { expect(taskCompleted).to.be.true; }); }); + + it(`should get wallet address`, () => { + cy.getWalletAddress().then(walletAddress => { + expect(walletAddress.length).to.be.equal(45); + }); + }); }); }); From d49d84e236c0ec774ffe96863d8b818c421793d0 Mon Sep 17 00:00:00 2001 From: frazarshad Date: Tue, 5 Mar 2024 22:29:04 -0800 Subject: [PATCH 26/35] Added Interaction to get the value of a certain token (#19) * feat: added command to get tokens * chore: await/async fixes --- commands/keplr.js | 44 +++++++++++++++++++++- commands/playwright-keplr.js | 57 ++++++++--------------------- pages/keplr/home-page.js | 13 +++++++ plugins/keplr-plugin.js | 2 + support/commands.js | 8 ++++ tests/e2e/specs/keplr/keplr-spec.js | 12 ++++++ 6 files changed, 92 insertions(+), 44 deletions(-) create mode 100644 pages/keplr/home-page.js diff --git a/commands/keplr.js b/commands/keplr.js index 612024e07..7463c199e 100644 --- a/commands/keplr.js +++ b/commands/keplr.js @@ -4,9 +4,9 @@ const { onboardingElements } = require('../pages/keplr/first-time-flow-page'); const { notificationPageElements, } = require('../pages/keplr/notification-page'); +const { homePageElements } = require('../pages/keplr/home-page'); const clipboardy = require('clipboardy'); - let extensionId; let extensionVersion; let registrationUrl; @@ -29,7 +29,6 @@ const keplr = { }, walletAddress: () => { return walletAddress; - }, extensionId: () => { return extensionId; @@ -273,6 +272,7 @@ const keplr = { }, async switchWallet({ walletName }) { + const originalURL = playwright.keplrWindow().url(); await module.exports.switchToKeplrIfNotActive(); await module.exports.goToWalletsPage(); @@ -281,10 +281,50 @@ const keplr = { playwright.keplrWindow(), true, ); + + await playwright.waitForURLLoad(originalURL); await playwright.switchToCypressWindow(); return true; }, + + async addNewTokensFound() { + module.exports.switchToKeplrIfNotActive(); + await module.exports.goToHome(); + await playwright.waitAndClickByText(homePageElements.newTokensFound); + await playwright.waitAndClick( + homePageElements.selectAllTokensCheck, + playwright.keplrWindow(), + { number: -1, force: true }, + ); + await playwright.waitAndClickByText( + homePageElements.addChainsButton, + playwright.keplrWindow(), + true, + ); + await playwright.switchToCypressWindow(); + + return true; + }, + + async getTokenAmount({ tokenName }) { + await module.exports.switchToKeplrIfNotActive(); + await module.exports.goToHome(); + + const tokenLabel = await playwright.waitFor( + homePageElements.tokenNameLabel(tokenName), + ); + const parentElement = tokenLabel.locator( + homePageElements.tokenParentSelector, + ); + const innerTexts = await parentElement.allInnerTexts(); + const textArray = innerTexts[0].split('\n'); + const tokenValue = Number(textArray[3]); + + await playwright.switchToCypressWindow(); + + return tokenValue; + }, }; module.exports = keplr; diff --git a/commands/playwright-keplr.js b/commands/playwright-keplr.js index 385ab7f55..ba2ec17eb 100644 --- a/commands/playwright-keplr.js +++ b/commands/playwright-keplr.js @@ -52,7 +52,8 @@ module.exports = { module.exports.assignActiveTabName('keplr'); return true; }, - async switchToCypressWindow() { + async switchToCypressWindow(page = keplrWindow) { + await module.exports.waitUntilStable(page); if (mainWindow) { await mainWindow.bringToFront(); module.exports.assignActiveTabName('cypress'); @@ -193,9 +194,9 @@ module.exports = { } return element; }, - async waitForByText(text, page = keplrWindow) { + async waitForByText(text, page = keplrWindow, exact = false) { await module.exports.waitUntilStable(page); - const element = page.getByText(text).first(); + const element = page.getByText(text, { exact: exact }).first(); await element.waitFor(); await element.focus(); if (process.env.STABLE_MODE) { @@ -208,7 +209,7 @@ module.exports = { return element; }, async waitAndClickByText(text, page = keplrWindow, exact = false) { - await module.exports.waitForByText(text, page); + await module.exports.waitForByText(text, page, exact); const element = `:is(:text-is("${text}")${exact ? '' : `, :text("${text}")`})`; await page.click(element); await module.exports.waitUntilStable(); @@ -221,9 +222,7 @@ module.exports = { await module.exports.waitUntilStable(page); }, async waitAndGetValue(selector, page = keplrWindow) { - const expect = expectInstance - ? expectInstance - : require('@playwright/test').expect; + const expect = require('@playwright/test').expect; const element = await module.exports.waitFor(selector, page); await expect(element).toHaveText(/[a-zA-Z0-9]/, { ignoreCase: true, @@ -266,7 +265,11 @@ module.exports = { await module.exports.waitUntilStable(); return element; }, - async waitForAndCheckElementExistence(selector, timeout = 1000, page = keplrWindow) { + async waitForAndCheckElementExistence( + selector, + timeout = 1000, + page = keplrWindow, + ) { try { await page.waitForSelector(selector, { timeout }); return true; @@ -274,40 +277,6 @@ module.exports = { return false; } }, - async waitAndClick(selector, page = keplrWindow, args = {}) { - const element = await module.exports.waitFor( - selector, - page, - args.number || 0, - ); - if (args.numberOfClicks && !args.waitForEvent) { - await element.click({ - clickCount: args.numberOfClicks, - force: args.force, - }); - } else if (args.numberOfClicks && args.waitForEvent) { - await Promise.all([ - page.waitForEvent(args.waitForEvent), - element.click({ clickCount: args.numberOfClicks, force: args.force }), - ]); - } else if (args.waitForEvent) { - if (args.waitForEvent.includes('navi')) { - await Promise.all([ - page.waitForNavigation(), - element.click({ force: args.force }), - ]); - } else { - await Promise.all([ - page.waitForEvent(args.waitForEvent), - element.click({ force: args.force }), - ]); - } - } else { - await element.click({ force: args.force }); - } - await module.exports.waitUntilStable(); - return element; - }, async waitForByRole(role, number = 0, page = keplrWindow) { await module.exports.waitUntilStable(page); const element = page.getByRole(role).nth(number); @@ -366,4 +335,8 @@ module.exports = { ); } }, + async waitForURLLoad(url, page = keplrWindow) { + await page.waitForURL(url); + await module.exports.waitUntilStable(page); + }, }; diff --git a/pages/keplr/home-page.js b/pages/keplr/home-page.js new file mode 100644 index 000000000..a0c339ca3 --- /dev/null +++ b/pages/keplr/home-page.js @@ -0,0 +1,13 @@ +const tokenNameLabel = tokenName => `:text-is("${tokenName}")`; +const tokenParentSelector = '../../../..'; +const selectAllTokensCheck = 'input[type="checkbox"]:enabled'; +const newTokensFound = 'new token(s) found'; +const addChainsButton = 'Add Chains'; + +module.exports.homePageElements = { + tokenNameLabel, + tokenParentSelector, + selectAllTokensCheck, + newTokensFound, + addChainsButton, +}; diff --git a/plugins/keplr-plugin.js b/plugins/keplr-plugin.js index 7da74b18b..f20f35c1f 100644 --- a/plugins/keplr-plugin.js +++ b/plugins/keplr-plugin.js @@ -87,6 +87,8 @@ module.exports = (on, config) => { return true; }, switchWallet: keplr.switchWallet, + addNewTokensFound: keplr.addNewTokensFound, + getTokenAmount: keplr.getTokenAmount, }); return config; diff --git a/support/commands.js b/support/commands.js index 19c296bdd..a0ca6ecdc 100644 --- a/support/commands.js +++ b/support/commands.js @@ -463,3 +463,11 @@ Cypress.Commands.add('getWalletAddress', () => { Cypress.Commands.add('switchWallet', walletName => { return cy.task('switchWallet', { walletName }); }); + +Cypress.Commands.add('addNewTokensFound', () => { + return cy.task('addNewTokensFound'); +}); + +Cypress.Commands.add('getTokenAmount', tokenName => { + return cy.task('getTokenAmount', { tokenName }); +}); diff --git a/tests/e2e/specs/keplr/keplr-spec.js b/tests/e2e/specs/keplr/keplr-spec.js index 81a6af071..a03522c30 100644 --- a/tests/e2e/specs/keplr/keplr-spec.js +++ b/tests/e2e/specs/keplr/keplr-spec.js @@ -81,6 +81,18 @@ describe('Keplr', () => { }); // TODO: Add some more robust check later }); + it(`should get the accurate values for the tokens in the wallet`, () => { + cy.switchWallet('My Wallet').then(taskCompleted => { + expect(taskCompleted).to.be.true; + }); + cy.addNewTokensFound(); + cy.getTokenAmount('ATOM').then(tokenValue => { + expect(tokenValue).to.equal(0); + }); + cy.getTokenAmount('BLD').then(tokenValue => { + expect(tokenValue).to.equal(331); + }); + }); it(`should disconnect the wallet from all the connected DAPPs`, () => { cy.disconnectWalletFromDapp().then(taskCompleted => { expect(taskCompleted).to.be.true; From 7d92996f5d25673100ad2bedc95c4ea8e5443fb8 Mon Sep 17 00:00:00 2001 From: frazarshad Date: Wed, 6 Mar 2024 03:58:36 -0800 Subject: [PATCH 27/35] Updates to CI/CD flow (#20) * ci: new docker ci file for keplr * ci: using docker workflow instead of debug workflow temporarily * ci: updated config to have not retires in ci --- .../workflows/{ => disabled}/e2e_debug.yml | 5 +- .../workflows/{disabled => }/e2e_docker.yml | 4 +- docker-compose.ci.keplr.yml | 126 ++++++++++++++++++ package.json | 3 +- synpress.config.js | 7 +- 5 files changed, 137 insertions(+), 8 deletions(-) rename .github/workflows/{ => disabled}/e2e_debug.yml (98%) rename .github/workflows/{disabled => }/e2e_docker.yml (91%) create mode 100644 docker-compose.ci.keplr.yml diff --git a/.github/workflows/e2e_debug.yml b/.github/workflows/disabled/e2e_debug.yml similarity index 98% rename from .github/workflows/e2e_debug.yml rename to .github/workflows/disabled/e2e_debug.yml index 5d0ac623b..f74ad984b 100644 --- a/.github/workflows/e2e_debug.yml +++ b/.github/workflows/disabled/e2e_debug.yml @@ -1,6 +1,9 @@ name: E2E (debug) -on: [push, pull_request] +on: + push: + pull_request: + branches: [master, dev] concurrency: group: diff --git a/.github/workflows/disabled/e2e_docker.yml b/.github/workflows/e2e_docker.yml similarity index 91% rename from .github/workflows/disabled/e2e_docker.yml rename to .github/workflows/e2e_docker.yml index b40b583d0..38fd44336 100644 --- a/.github/workflows/disabled/e2e_docker.yml +++ b/.github/workflows/e2e_docker.yml @@ -19,7 +19,7 @@ jobs: runs-on: ubuntu-latest strategy: matrix: - resolution: ['low', 'medium', 'high'] + resolution: ['high'] steps: - name: Checkout @@ -41,7 +41,7 @@ jobs: - name: Run e2e tests (${{ matrix.resolution }} res) run: | - docker-compose -f docker-compose.ci.yml --env-file ${{ matrix.resolution }}-res.env --profile synpress --profile foundry up --build --exit-code-from synpress + docker-compose -f docker-compose.ci.keplr.yml --env-file ${{ matrix.resolution }}-res.env --profile synpress up --build --exit-code-from synpress env: COMPOSE_DOCKER_CLI_BUILD: 1 DOCKER_BUILDKIT: 1 diff --git a/docker-compose.ci.keplr.yml b/docker-compose.ci.keplr.yml new file mode 100644 index 000000000..7e2dfa29a --- /dev/null +++ b/docker-compose.ci.keplr.yml @@ -0,0 +1,126 @@ +version: '3.9' + +services: + synpress: + profiles: + - synpress + container_name: synpress + build: . + environment: + - DISPLAY=display:0.0 + - CYPRESS_PRIVATE_KEY_WITH_FUNDS=${CYPRESS_PRIVATE_KEY_WITH_FUNDS} + - DEBUG=${DEBUG} + - CYPRESS_DOCKER_RUN=true + - GH_PAT=${GH_PAT} + - GH_USERNAME=${GH_USERNAME} + - CI=${CI} + # cypress dashboard + - CYPRESS_GROUP=${CYPRESS_GROUP} + - GITHUB_TOKEN=${GITHUB_TOKEN} + - CYPRESS_PROJECT_ID=${CYPRESS_PROJECT_ID} + - CYPRESS_RECORD_KEY=${CYPRESS_RECORD_KEY} + - COMMIT_INFO_MESSAGE=${COMMIT_INFO_MESSAGE} + - COMMIT_INFO_SHA=${COMMIT_INFO_SHA} + # passing required CI variables + - GITHUB_ACTIONS=${GITHUB_ACTIONS} + - GITHUB_WORKFLOW=${GITHUB_WORKFLOW} + - GITHUB_ACTION=${GITHUB_ACTION} + - GITHUB_EVENT_NAME=${GITHUB_EVENT_NAME} + - GITHUB_RUN_ID=${GITHUB_RUN_ID} + - GITHUB_RUN_ATTEMPT=${GITHUB_RUN_ATTEMPT} + - GITHUB_REPOSITORY=${GITHUB_REPOSITORY} + - GH_BRANCH=${GH_BRANCH} + - GITHUB_SHA=${GITHUB_SHA} + - GITHUB_REF=${GITHUB_REF} + - GITHUB_BASE_REF=${GITHUB_BASE_REF} + - GITHUB_HEAD_REF=${GITHUB_HEAD_REF} + depends_on: + - display + - video + - agd + entrypoint: [] + working_dir: /app + volumes: + - ./docker/videos:/app/tests/e2e/videos + - ./docker/screenshots:/app/tests/e2e/screenshots + command: > + bash -c 'echo -n "======> local noVNC URL: http://localhost:8080/vnc.html?autoconnect=true " && pnpm wait-on http://display:8080 && echo -n "======> remote noVNC URL: " && curl -s ngrok:4040/api/tunnels | jq -r .tunnels[0].public_url && pnpm test:e2e:ci:keplr' + networks: + - x11 + + display: + profiles: + - synpress + container_name: display + image: synthetixio/display:016121eafdfff448414894d0ca5a50b1d72b62eb-base + environment: + - RUN_XTERM=no + - DISPLAY_WIDTH=${DISPLAY_WIDTH} + - DISPLAY_HEIGHT=${DISPLAY_HEIGHT} + ports: + - '8080:8080' + networks: + - x11 + + ngrok: + profiles: + - ngrok + container_name: ngrok + image: synthetixio/ngrok:016121eafdfff448414894d0ca5a50b1d72b62eb-base + ports: + - '4040:4040' + command: + [ + 'ngrok', + 'http', + 'display:8080', + '--authtoken', + '${NGROK_AUTH}' + ] + environment: + - NGROK_AUTH=${NGROK_AUTH} + - NGROK_BASIC_AUTH=${NGROK_BASIC_AUTH} + depends_on: + - display + networks: + - x11 + + video: + profiles: + - synpress + container_name: video + image: synthetixio/video:457bb48776c3b14de232d9dda620ba9188dc40ac-base + volumes: + - ./docker/videos-ci:/videos + environment: + - FILE_NAME=CI-full-video.mp4 + - SE_SCREEN_WIDTH=${SE_SCREEN_WIDTH} + - SE_SCREEN_HEIGHT=${SE_SCREEN_HEIGHT} + depends_on: + - display + networks: + - x11 + + agd: + profiles: + - synpress + container_name: agoric_chain + image: frazarshad/offerup-test-chain:1.0.0 + logging: + driver: none + platform: linux/amd64 + ports: + - 26656:26656 + - 26657:26657 + - 1317:1317 + environment: + DEST: 1 + DEBUG: "SwingSet:ls,SwingSet:vat" + volumes: + - ./tools/contract:/workspace + entrypoint: /workspace/scripts/run-chain.sh + networks: + - x11 + +networks: + x11: diff --git a/package.json b/package.json index 886a46ea2..c47e1fca1 100644 --- a/package.json +++ b/package.json @@ -48,7 +48,8 @@ "test:e2e:anvil": "start-server-and-test 'turbo start:server' http-get://localhost:3000 'CYPRESS_USE_ANVIL=true pnpm synpress:run'", "test:e2e:headless": "start-server-and-test 'turbo start:server' http-get://localhost:3000 'pnpm synpress:run --headless'", "test:e2e:headless:anvil": "start-server-and-test 'turbo start:server' http-get://localhost:3000 'CYPRESS_USE_ANVIL=true pnpm synpress:run --headless'", - "test:e2e:ci": "start-server-and-test 'VITE_LOCAL_ENV=agoric_chain pnpm start:ui' http-get://localhost:3000 'pnpm start:json-server' http-get://localhost:3004 'pnpm synpress:run --record --group'", + "test:e2e:ci": "start-server-and-test 'VITE_RUN_ENV=agoric_chain pnpm start:ui' http-get://localhost:3000 'pnpm start:json-server' http-get://localhost:3004 'pnpm synpress:run --record --group'", + "test:e2e:ci:keplr": "start-server-and-test 'VITE_RUN_ENV=agoric_chain pnpm start:ui' http-get://localhost:3000 'pnpm start:json-server' http-get://localhost:3004 'pnpm synpress:run:keplr'", "test:e2e:ci:anvil": "start-server-and-test 'turbo start:server' http-get://localhost:3000 'CYPRESS_USE_ANVIL=true pnpm synpress:run --record --group'", "test:e2e:ci:cypress-action": "CYPRESS_USE_ANVIL=true pnpm synpress:run", "synpress:run:keplr": "EXTENSION=keplr SKIP_EXTENSION_SETUP=true SYNPRESS_LOCAL_TEST=true node synpress.js run --configFile=synpress.config.js", diff --git a/synpress.config.js b/synpress.config.js index a28755ea3..361b563ec 100644 --- a/synpress.config.js +++ b/synpress.config.js @@ -11,16 +11,15 @@ const fixturesFolder = `${synpressPath}/fixtures`; log(`Detected synpress fixtures path is: ${fixturesFolder}`); const supportFile = 'tests/e2e/support.js'; - const specPattern = { metamask: 'tests/e2e/specs/metamask/**/*.{js,jsx,ts,tsx}', - keplr : 'tests/e2e/specs/keplr/**/*.{js,jsx,ts,tsx}' -} + keplr: 'tests/e2e/specs/keplr/**/*.{js,jsx,ts,tsx}', +}; module.exports = defineConfig({ userAgent: 'synpress', retries: { - runMode: process.env.CI ? 1 : 0, + runMode: 0, openMode: 0, }, fixturesFolder, From bd127a35f43350aed932b46322d9f893db1e5f71 Mon Sep 17 00:00:00 2001 From: Rabi Siddique <60459172+rabi-siddique@users.noreply.github.com> Date: Thu, 7 Mar 2024 22:27:32 +0500 Subject: [PATCH 28/35] Adding Selecting Chain Interaction And Flow Improvements (#21) * chore: changing the flow of test cases; starting by creating a new wallet rather than importing * feature: adding behavior in import wallet flow to select a chain when importing/creating wallet * feature: adding helper methods to click elements in a reliable way * chore: using helper methods inside keplr.js * chore: handling edge case for grabbing token values when values are large numbers containing commas * chore: updating selector for getting wallet address and adding test cases to validate the behavior * chore: addressing PR comments * chore: addressing PR comments * chore: replacing Agoric local with Agoric localhost --- commands/keplr.js | 76 ++++++++++++++++++++++------- commands/playwright-keplr.js | 25 ++++++++++ pages/keplr/first-time-flow-page.js | 6 +++ pages/keplr/home-page.js | 2 + pages/keplr/notification-page.js | 6 +-- support/commands.js | 5 +- tests/e2e/specs/keplr/keplr-spec.js | 20 ++++++-- 7 files changed, 114 insertions(+), 26 deletions(-) diff --git a/commands/keplr.js b/commands/keplr.js index 7463c199e..0121b0c6f 100644 --- a/commands/keplr.js +++ b/commands/keplr.js @@ -158,10 +158,7 @@ const keplr = { await playwright.keplrWindow(), ); - await playwright.waitAndClick( - onboardingElements.submitChainButton, - await playwright.keplrWindow(), - ); + await module.exports.handleSelectChain(); await playwright.waitForByText( onboardingElements.phraseAccountCreated, @@ -170,6 +167,38 @@ const keplr = { return true; }, + async handleSelectChain() { + const chainNameExists = await playwright.waitForAndCheckElementExistence( + onboardingElements.chainNameSelector, + ); + + if (chainNameExists) { + await playwright.waitAndClickByText( + onboardingElements.chainName, + playwright.keplrWindow(), + ); + await playwright.waitAndClick( + onboardingElements.submitChainButton, + playwright.keplrWindow(), + ); + const importButtonExists = + await playwright.waitForAndCheckElementExistence( + onboardingElements.importButtonSelector, + ); + + if (importButtonExists) { + await playwright.waitAndClick( + onboardingElements.importButtonSelector, + playwright.keplrWindow(), + ); + } + } else { + await playwright.waitAndClick( + onboardingElements.submitChainButton, + playwright.keplrWindow(), + ); + } + }, async importWalletWithPhrase(secretWords) { await playwright.waitAndClickByText( onboardingElements.phraseCount24, @@ -238,12 +267,20 @@ const keplr = { return true; }, - async getWalletAddress() { - await playwright.switchToKeplrWindow(); + async getWalletAddress(chainName) { + playwright.switchToKeplrWindow(); await module.exports.goToHome(); - const page = playwright.keplrWindow(); + const newTokensSelctorExists = await playwright.waitForAndCheckElementExistence( + homePageElements.newTokensFoundSelector, + ); + + if (newTokensSelctorExists) { + await module.exports.addNewTokensFound(false); + } + await playwright.waitAndClickByText(notificationPageElements.copyAddress); - await page.click(notificationPageElements.copyWalletAddressSelector); + await playwright.waitAndClick(notificationPageElements.walletSelectors(chainName)) + walletAddress = clipboardy.readSync(); await playwright.switchToCypressWindow(); return walletAddress; @@ -287,14 +324,14 @@ const keplr = { return true; }, - - async addNewTokensFound() { - module.exports.switchToKeplrIfNotActive(); - await module.exports.goToHome(); + async addNewTokensFound(switchScreens = true) { + if (switchScreens) { + module.exports.switchToKeplrIfNotActive(); + await module.exports.goToHome(); + } await playwright.waitAndClickByText(homePageElements.newTokensFound); - await playwright.waitAndClick( + await playwright.waitAndClickWithRetry( homePageElements.selectAllTokensCheck, - playwright.keplrWindow(), { number: -1, force: true }, ); await playwright.waitAndClickByText( @@ -302,7 +339,10 @@ const keplr = { playwright.keplrWindow(), true, ); - await playwright.switchToCypressWindow(); + + if (switchScreens) { + await playwright.switchToCypressWindow(); + } return true; }, @@ -319,11 +359,11 @@ const keplr = { ); const innerTexts = await parentElement.allInnerTexts(); const textArray = innerTexts[0].split('\n'); - const tokenValue = Number(textArray[3]); + const tokenValue = textArray[3]; + const parsedTokenValue = Number(tokenValue.replace(/,/g, '')); await playwright.switchToCypressWindow(); - - return tokenValue; + return parsedTokenValue; }, }; diff --git a/commands/playwright-keplr.js b/commands/playwright-keplr.js index ba2ec17eb..0f1da1962 100644 --- a/commands/playwright-keplr.js +++ b/commands/playwright-keplr.js @@ -271,6 +271,7 @@ module.exports = { page = keplrWindow, ) { try { + await module.exports.waitUntilStable(page); await page.waitForSelector(selector, { timeout }); return true; } catch (error) { @@ -307,6 +308,30 @@ module.exports = { await element.type(value); await module.exports.waitUntilStable(page); }, + async waitAndClickWithRetry(selector, options) { + const maxRetries = 5; + let retries = 0; + + while (retries < maxRetries) { + try { + await module.exports.waitAndClick( + selector, + module.exports.keplrWindow(), + options, + ); + return; + } catch (error) { + retries++; + } + } + + throw new Error(`Failed to click element after ${maxRetries} attempts`); + }, + async waitAndClickWithDelay(selector, options, delay) { + const page = module.exports.keplrWindow() + await page.waitForTimeout(delay) + await module.exports.waitAndClick(selector, page, options); + }, async switchToKeplrNotification() { const keplrExtensionData = (await module.exports.getExtensionsData()).keplr; diff --git a/pages/keplr/first-time-flow-page.js b/pages/keplr/first-time-flow-page.js index 3d6e6337b..4b81860a0 100644 --- a/pages/keplr/first-time-flow-page.js +++ b/pages/keplr/first-time-flow-page.js @@ -14,12 +14,17 @@ const phraseAccountCreated = 'Account Created!'; const finishButton = 'button[type="button"]'; const textAreaSelector = 'textbox'; const submitPhraseButton = 'button[type="submit"]'; +const chainName = 'Agoric local' +const chainNameSelector = 'text=Agoric local' +const importButtonSelector = 'button:has-text("Import")' module.exports.onboardingElements = { existingWalletButton, createWalletButton, importRecoveryPhraseButton, useRecoveryPhraseButton, + chainNameSelector, + importButtonSelector, phraseCount24, phrasePrivateKey, walletInput, @@ -32,4 +37,5 @@ module.exports.onboardingElements = { finishButton, textAreaSelector, submitPhraseButton, + chainName }; diff --git a/pages/keplr/home-page.js b/pages/keplr/home-page.js index a0c339ca3..02baeed9c 100644 --- a/pages/keplr/home-page.js +++ b/pages/keplr/home-page.js @@ -3,6 +3,7 @@ const tokenParentSelector = '../../../..'; const selectAllTokensCheck = 'input[type="checkbox"]:enabled'; const newTokensFound = 'new token(s) found'; const addChainsButton = 'Add Chains'; +const newTokensFoundSelector = 'text=new token(s) found' module.exports.homePageElements = { tokenNameLabel, @@ -10,4 +11,5 @@ module.exports.homePageElements = { selectAllTokensCheck, newTokensFound, addChainsButton, + newTokensFoundSelector }; diff --git a/pages/keplr/notification-page.js b/pages/keplr/notification-page.js index e04726c24..bb5e8b1c5 100644 --- a/pages/keplr/notification-page.js +++ b/pages/keplr/notification-page.js @@ -1,9 +1,9 @@ const approveButton = `button`; const copyAddress = 'Copy Address'; -const copyWalletAddressSelector = 'div.sc-dkzDqf div.sc-hKMtZM.sc-kDDrLX.cyoEAq.dkJSBQ' +const walletSelectors = chainName => `img[alt="${chainName}"]`; module.exports.notificationPageElements = { approveButton, copyAddress, - copyWalletAddressSelector -}; \ No newline at end of file + walletSelectors +}; diff --git a/support/commands.js b/support/commands.js index a0ca6ecdc..d8399b5b4 100644 --- a/support/commands.js +++ b/support/commands.js @@ -455,11 +455,12 @@ Cypress.Commands.add('disconnectWalletFromDapp', () => { return cy.task('disconnectWalletFromDapp'); }); -Cypress.Commands.add('getWalletAddress', () => { - cy.task('getWalletAddress').then(address => { +Cypress.Commands.add('getWalletAddress', chainName => { + cy.task('getWalletAddress', chainName).then(address => { return address; }); }); + Cypress.Commands.add('switchWallet', walletName => { return cy.task('switchWallet', { walletName }); }); diff --git a/tests/e2e/specs/keplr/keplr-spec.js b/tests/e2e/specs/keplr/keplr-spec.js index a03522c30..8015d853e 100644 --- a/tests/e2e/specs/keplr/keplr-spec.js +++ b/tests/e2e/specs/keplr/keplr-spec.js @@ -75,6 +75,16 @@ describe('Keplr', () => { expect(setupFinished).to.be.true; }); }); + + it(`should get wallet address while running addNewTokensFound flow`, () => { + cy.getWalletAddress('Agoric localhost').then(walletAddress => { + expect(walletAddress.length).to.be.equal(45); + }); + + cy.getWalletAddress('Cosmos Hub').then(walletAddress => { + expect(walletAddress.length).to.be.equal(45); + }); + }); it(`should switch to new wallet by name`, () => { cy.switchWallet('My Wallet 2').then(taskCompleted => { expect(taskCompleted).to.be.true; @@ -99,10 +109,14 @@ describe('Keplr', () => { }); }); - it(`should get wallet address`, () => { - cy.getWalletAddress().then(walletAddress => { + it(`should get wallet address without running addNewTokensFound flow`, () => { + cy.getWalletAddress('Agoric localhost').then(walletAddress => { + expect(walletAddress.length).to.be.equal(45); + }); + + cy.getWalletAddress('Cosmos Hub').then(walletAddress => { expect(walletAddress.length).to.be.equal(45); }); }); }); -}); +}); \ No newline at end of file From 7d679043f4b8ca75d9f4105600dfe2c2e1b4b682 Mon Sep 17 00:00:00 2001 From: frazarshad Date: Thu, 7 Mar 2024 09:30:29 -0800 Subject: [PATCH 29/35] feat: included settings to setup npm (#22) --- .npmignore | 9 +++++++++ package.json | 16 ++++++++-------- synpress.config.js | 7 +------ 3 files changed, 18 insertions(+), 14 deletions(-) create mode 100644 .npmignore diff --git a/.npmignore b/.npmignore new file mode 100644 index 000000000..c4acaa9fd --- /dev/null +++ b/.npmignore @@ -0,0 +1,9 @@ +.github +.env +.dockerignore +docker +docs +downloads +images +tests +tools diff --git a/package.json b/package.json index c47e1fca1..e9ca616e9 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { - "name": "@synthetixio/synpress", - "version": "3.7.2-beta.9", + "name": "@agoric/synpress", + "version": "3.7.2-dev", "description": "Synpress is e2e testing framework based around Cypress.io & playwright with included MetaMask support. Test your dapps with ease.", "keywords": [ "Synpress", @@ -9,17 +9,17 @@ "testing", "e2e" ], - "homepage": "https://github.com/synthetixio/synpress#readme", + "homepage": "https://github.com/agoric-labs/synpress#readme", "bugs": { - "url": "https://github.com/synthetixio/synpress/issues" + "url": "https://github.com/agoric-labs/synpress/issues" }, "repository": { "type": "git", - "url": "git+https://github.com/synthetixio/synpress.git" + "url": "git+https://github.com/agoric-labs/synpress.git" }, "license": "MIT", "author": { - "name": "Synthetix" + "name": "agoric-labs" }, "type": "commonjs", "main": "launcher.js", @@ -43,7 +43,7 @@ "start:contract": "cd tools/contract && pnpm start", "start:ui": "cd tools/ui && pnpm dev", "start:json-server": "json-server tools/json-server-db.json --port 3004", - "synpress:run:metamask": "EXTENSION=metamask SKIP_EXTENSION_SETUP=true SYNPRESS_LOCAL_TEST=true node synpress.js run --configFile=synpress.config.js", + "synpress:run:metamask": "CYPRESS_SPEC_PATTERN=tests/e2e/specs/metamask/** EXTENSION=metamask SKIP_EXTENSION_SETUP=true SYNPRESS_LOCAL_TEST=true node synpress.js run --configFile=synpress.config.js", "test:e2e:metamask": "start-server-and-test 'pnpm start:server' http-get://localhost:3000 'pnpm synpress:run:metamask'", "test:e2e:anvil": "start-server-and-test 'turbo start:server' http-get://localhost:3000 'CYPRESS_USE_ANVIL=true pnpm synpress:run'", "test:e2e:headless": "start-server-and-test 'turbo start:server' http-get://localhost:3000 'pnpm synpress:run --headless'", @@ -52,7 +52,7 @@ "test:e2e:ci:keplr": "start-server-and-test 'VITE_RUN_ENV=agoric_chain pnpm start:ui' http-get://localhost:3000 'pnpm start:json-server' http-get://localhost:3004 'pnpm synpress:run:keplr'", "test:e2e:ci:anvil": "start-server-and-test 'turbo start:server' http-get://localhost:3000 'CYPRESS_USE_ANVIL=true pnpm synpress:run --record --group'", "test:e2e:ci:cypress-action": "CYPRESS_USE_ANVIL=true pnpm synpress:run", - "synpress:run:keplr": "EXTENSION=keplr SKIP_EXTENSION_SETUP=true SYNPRESS_LOCAL_TEST=true node synpress.js run --configFile=synpress.config.js", + "synpress:run:keplr": "CYPRESS_SPEC_PATTERN=tests/e2e/specs/keplr/** EXTENSION=keplr SKIP_EXTENSION_SETUP=true SYNPRESS_LOCAL_TEST=true node synpress.js run --configFile=synpress.config.js", "test:e2e:keplr": "start-server-and-test 'pnpm start:ui' http-get://localhost:3000 'pnpm start:json-server' http-get://localhost:3004 'pnpm synpress:run:keplr'" }, "dependencies": { diff --git a/synpress.config.js b/synpress.config.js index 361b563ec..f68a6327e 100644 --- a/synpress.config.js +++ b/synpress.config.js @@ -11,11 +11,6 @@ const fixturesFolder = `${synpressPath}/fixtures`; log(`Detected synpress fixtures path is: ${fixturesFolder}`); const supportFile = 'tests/e2e/support.js'; -const specPattern = { - metamask: 'tests/e2e/specs/metamask/**/*.{js,jsx,ts,tsx}', - keplr: 'tests/e2e/specs/keplr/**/*.{js,jsx,ts,tsx}', -}; - module.exports = defineConfig({ userAgent: 'synpress', retries: { @@ -38,7 +33,7 @@ module.exports = defineConfig({ testIsolation: false, setupNodeEvents, baseUrl: 'http://localhost:3000', - specPattern: specPattern[process.env.EXTENSION], + specPattern: 'tests/e2e/specs/**/*spec.{js,jsx,ts,tsx}', supportFile, }, component: { From 0287cc31c22bc24d94bac7b3565bcd3f478973b9 Mon Sep 17 00:00:00 2001 From: frazarshad Date: Thu, 7 Mar 2024 23:22:50 -0800 Subject: [PATCH 30/35] refactor: changed args for setupWallet (#24) --- support/commands.js | 28 +++++++++++++++------------- support/index.d.ts | 18 ++++++++++++++++++ tests/e2e/specs/keplr/keplr-spec.js | 26 +++++++++++++------------- 3 files changed, 46 insertions(+), 26 deletions(-) diff --git a/support/commands.js b/support/commands.js index d8399b5b4..3179a0ea8 100644 --- a/support/commands.js +++ b/support/commands.js @@ -410,22 +410,24 @@ Cypress.Commands.add( ); // Keplr Commands -Cypress.Commands.add( - 'setupWallet', - ( - secretWordsOrPrivateKey = 'orbit bench unit task food shock brand bracket domain regular warfare company announce wheel grape trust sphere boy doctor half guard ritual three ecology', +Cypress.Commands.add('setupWallet', (args = {}) => { + const { + secretWords, + privateKey, password = 'Test1234', newAccount = false, walletName = 'My Wallet', - ) => { - return cy.task('setupWallet', { - secretWordsOrPrivateKey, - password, - newAccount, - walletName, - }); - }, -); + } = args; + return cy.task('setupWallet', { + secretWordsOrPrivateKey: + secretWords || + privateKey || + 'orbit bench unit task food shock brand bracket domain regular warfare company announce wheel grape trust sphere boy doctor half guard ritual three ecology', + password, + newAccount, + walletName, + }); +}); Cypress.Commands.add('acceptAccess', () => { return cy.task('acceptAccess'); diff --git a/support/index.d.ts b/support/index.d.ts index 820a9dcae..4cf9717ae 100644 --- a/support/index.d.ts +++ b/support/index.d.ts @@ -505,5 +505,23 @@ declare namespace Cypress { viewportWidth: number, viewportHeight: number, ): Chainable; + /** + * Generic method to setup wallet (works for keplr only) + * @example + * cy.setupWallet(); + * cy.setupWallet({ + * secretWords: 'test test test test test test test test test test test junk', + * password: 'Password123', + * }); + */ + setupWallet( + args: { + secretWords?: String; + privateKey?: String; + password?: String; + newAccount?: Boolean; + walletName?: String; + } + ): Chainable; } } diff --git a/tests/e2e/specs/keplr/keplr-spec.js b/tests/e2e/specs/keplr/keplr-spec.js index 8015d853e..a2f9b1791 100644 --- a/tests/e2e/specs/keplr/keplr-spec.js +++ b/tests/e2e/specs/keplr/keplr-spec.js @@ -56,22 +56,22 @@ describe('Keplr', () => { ); }); it(`should create a new wallet using 24 word phrase`, () => { - cy.setupWallet( - 'orbit bench unit task food shock brand bracket domain regular warfare company announce wheel grape trust sphere boy doctor half guard ritual three ecology', - 'Test1234', - true, - 'My Wallet 2', - ).then(setupFinished => { + cy.setupWallet({ + secretWords: + 'orbit bench unit task food shock brand bracket domain regular warfare company announce wheel grape trust sphere boy doctor half guard ritual three ecology', + password: 'Test1234', + newAccount: true, + walletName: 'My Wallet 2', + }).then(setupFinished => { expect(setupFinished).to.be.true; }); }); it(`should complete Keplr setup by importing the wallet using private key`, () => { - cy.setupWallet( - 'A9C09B6E4AF70DE1F1B621CB1AA66CFD0B4AA977E4C18497C49132DD9E579485', - null, - false, - 'My wallet 3', - ).then(setupFinished => { + cy.setupWallet({ + privateKey: + 'A9C09B6E4AF70DE1F1B621CB1AA66CFD0B4AA977E4C18497C49132DD9E579485', + walletName: 'My wallet 3', + }).then(setupFinished => { expect(setupFinished).to.be.true; }); }); @@ -119,4 +119,4 @@ describe('Keplr', () => { }); }); }); -}); \ No newline at end of file +}); From 26edc77b42c9bed879ca126d2829a3f45916b27c Mon Sep 17 00:00:00 2001 From: frazarshad Date: Fri, 8 Mar 2024 01:27:53 -0800 Subject: [PATCH 31/35] Added automatic linting to the repository (#23) * style:changing settings for linting * style: fixes to lint + styling throughout repo --- .eslintignore | 2 + .eslintrc.js | 22 ++ .husky/pre-commit | 1 + .prettierignore | 1 + commands/keplr.js | 13 +- commands/playwright-keplr.js | 4 +- helpers.js | 5 +- package.json | 27 +- pages/keplr/first-time-flow-page.js | 8 +- pages/keplr/home-page.js | 4 +- pages/keplr/notification-page.js | 2 +- plugins/metamask-plugin.js | 3 +- pnpm-lock.yaml | 396 ++++++++++++++++------- support/index.d.ts | 22 +- synpress.js | 2 +- tests/e2e/specs/keplr/playwright-spec.js | 76 ++--- tools/contract/package.json | 7 +- tools/json-server-db.json | 23 +- tools/ui/package.json | 2 +- tools/ui/tsconfig.json | 4 +- 20 files changed, 412 insertions(+), 212 deletions(-) create mode 100644 .husky/pre-commit create mode 100644 .prettierignore diff --git a/.eslintignore b/.eslintignore index 98f1881ee..b925b823a 100644 --- a/.eslintignore +++ b/.eslintignore @@ -8,3 +8,5 @@ coverage downloads # dont lint examples examples +# don't lint the contract folder since we dont want to mess with it +/tools/contract/ \ No newline at end of file diff --git a/.eslintrc.js b/.eslintrc.js index ab53eb647..e6f7dd674 100644 --- a/.eslintrc.js +++ b/.eslintrc.js @@ -37,4 +37,26 @@ module.exports = { 'testing-library/prefer-screen-queries': 0, 'turbo/no-undeclared-env-vars': 0, }, + + overrides: [ + { + files: ['*.ts', '*.tsx'], + parser: '@typescript-eslint/parser', + plugins: ['@typescript-eslint'], + extends: [ + 'eslint:recommended', + 'prettier', + 'plugin:prettier/recommended', + 'plugin:import/errors', + 'plugin:import/warnings', + 'plugin:import/typescript', + 'plugin:cypress/recommended', + 'plugin:ui-testing/cypress', + 'plugin:testing-library/react', + 'turbo', + 'plugin:@typescript-eslint/eslint-recommended', + 'plugin:@typescript-eslint/recommended', + ], + }, + ], }; diff --git a/.husky/pre-commit b/.husky/pre-commit new file mode 100644 index 000000000..e02c24e2b --- /dev/null +++ b/.husky/pre-commit @@ -0,0 +1 @@ +pnpm lint-staged \ No newline at end of file diff --git a/.prettierignore b/.prettierignore new file mode 100644 index 000000000..abf82aa9e --- /dev/null +++ b/.prettierignore @@ -0,0 +1 @@ +/tools/contract/ \ No newline at end of file diff --git a/commands/keplr.js b/commands/keplr.js index 0121b0c6f..3fbaf11f3 100644 --- a/commands/keplr.js +++ b/commands/keplr.js @@ -270,17 +270,20 @@ const keplr = { async getWalletAddress(chainName) { playwright.switchToKeplrWindow(); await module.exports.goToHome(); - const newTokensSelctorExists = await playwright.waitForAndCheckElementExistence( - homePageElements.newTokensFoundSelector, - ); + const newTokensSelctorExists = + await playwright.waitForAndCheckElementExistence( + homePageElements.newTokensFoundSelector, + ); if (newTokensSelctorExists) { await module.exports.addNewTokensFound(false); } await playwright.waitAndClickByText(notificationPageElements.copyAddress); - await playwright.waitAndClick(notificationPageElements.walletSelectors(chainName)) - + await playwright.waitAndClick( + notificationPageElements.walletSelectors(chainName), + ); + walletAddress = clipboardy.readSync(); await playwright.switchToCypressWindow(); return walletAddress; diff --git a/commands/playwright-keplr.js b/commands/playwright-keplr.js index 0f1da1962..2c2f42fcb 100644 --- a/commands/playwright-keplr.js +++ b/commands/playwright-keplr.js @@ -328,8 +328,8 @@ module.exports = { throw new Error(`Failed to click element after ${maxRetries} attempts`); }, async waitAndClickWithDelay(selector, options, delay) { - const page = module.exports.keplrWindow() - await page.waitForTimeout(delay) + const page = module.exports.keplrWindow(); + await page.waitForTimeout(delay); await module.exports.waitAndClick(selector, page, options); }, async switchToKeplrNotification() { diff --git a/helpers.js b/helpers.js index 0205a6aa9..5b56e16c7 100644 --- a/helpers.js +++ b/helpers.js @@ -278,9 +278,8 @@ module.exports = { release.tagName, 'manifest.json', ); - const extensionManifestFileExists = await module.exports.checkDirOrFileExist( - extensionManifestFilePath, - ); + const extensionManifestFileExists = + await module.exports.checkDirOrFileExist(extensionManifestFilePath); if (!extensionDirectoryExists && !extensionManifestFileExists) { await module.exports.download(release.downloadUrl, extensionDirectory); } else { diff --git a/package.json b/package.json index e9ca616e9..acb086984 100644 --- a/package.json +++ b/package.json @@ -26,13 +26,21 @@ "bin": { "synpress": "synpress.js" }, + "lint-staged": { + "*.{js,jsx,ts,tsx}": [ + "eslint --quiet --fix" + ], + "*.{json,js,ts,jsx,tsx,html}": [ + "prettier --write --ignore-unknown" + ] + }, "scripts": { "fix": "turbo fix:eslint fix:prettier --concurrency 1", - "fix:eslint": "eslint --fix **/*.js", - "fix:prettier": "prettier --write **/*.js", + "fix:eslint": "eslint . --ext .js,.ts,.jsx,.tsx --fix", + "fix:prettier": "prettier --write **/*.{js,json,ts,tsx,html}", "lint": "turbo lint:eslint lint:prettier", - "lint:eslint": "eslint . --ext js", - "lint:prettier": "prettier --check **/*.js", + "lint:eslint": "eslint . --ext .js,.ts,.jsx,.tsx", + "lint:prettier": "prettier --check **/*.{js,json,ts,tsx,html}", "lint:sarif": "node lint.js . --ext js", "release": "release-it --disable-metrics", "release:major": "release-it major --disable-metrics", @@ -53,7 +61,8 @@ "test:e2e:ci:anvil": "start-server-and-test 'turbo start:server' http-get://localhost:3000 'CYPRESS_USE_ANVIL=true pnpm synpress:run --record --group'", "test:e2e:ci:cypress-action": "CYPRESS_USE_ANVIL=true pnpm synpress:run", "synpress:run:keplr": "CYPRESS_SPEC_PATTERN=tests/e2e/specs/keplr/** EXTENSION=keplr SKIP_EXTENSION_SETUP=true SYNPRESS_LOCAL_TEST=true node synpress.js run --configFile=synpress.config.js", - "test:e2e:keplr": "start-server-and-test 'pnpm start:ui' http-get://localhost:3000 'pnpm start:json-server' http-get://localhost:3004 'pnpm synpress:run:keplr'" + "test:e2e:keplr": "start-server-and-test 'pnpm start:ui' http-get://localhost:3000 'pnpm start:json-server' http-get://localhost:3004 'pnpm synpress:run:keplr'", + "prepare": "husky" }, "dependencies": { "@cypress/code-coverage": "^3.11.0", @@ -93,8 +102,10 @@ "devDependencies": { "@metamask/test-dapp": "^7.0.1", "@microsoft/eslint-formatter-sarif": "^3.0.0", + "@typescript-eslint/eslint-plugin": "^6.0.0", + "@typescript-eslint/parser": "^6.0.0", "eslint": "^8.47.0", - "eslint-config-prettier": "^9.0.0", + "eslint-config-prettier": "^9.1.0", "eslint-config-standard": "^17.1.0", "eslint-config-turbo": "^1.10.12", "eslint-plugin-chai-friendly": "^0.7.2", @@ -107,9 +118,11 @@ "eslint-plugin-testing-library": "^6.0.0", "eslint-plugin-ui-testing": "^2.0.1", "eslint-plugin-unicorn": "^48.0.1", + "husky": "^9.0.11", "json-server": "1.0.0-alpha.23", + "lint-staged": "^15.2.2", "npm-check-updates": "^16.12.2", - "prettier": "^3.0.2", + "prettier": "^3.2.5", "release-it": "^16.1.5", "serve": "^14.2.0", "start-server-and-test": "^2.0.0", diff --git a/pages/keplr/first-time-flow-page.js b/pages/keplr/first-time-flow-page.js index 4b81860a0..a02bbacb4 100644 --- a/pages/keplr/first-time-flow-page.js +++ b/pages/keplr/first-time-flow-page.js @@ -14,9 +14,9 @@ const phraseAccountCreated = 'Account Created!'; const finishButton = 'button[type="button"]'; const textAreaSelector = 'textbox'; const submitPhraseButton = 'button[type="submit"]'; -const chainName = 'Agoric local' -const chainNameSelector = 'text=Agoric local' -const importButtonSelector = 'button:has-text("Import")' +const chainName = 'Agoric local'; +const chainNameSelector = 'text=Agoric local'; +const importButtonSelector = 'button:has-text("Import")'; module.exports.onboardingElements = { existingWalletButton, @@ -37,5 +37,5 @@ module.exports.onboardingElements = { finishButton, textAreaSelector, submitPhraseButton, - chainName + chainName, }; diff --git a/pages/keplr/home-page.js b/pages/keplr/home-page.js index 02baeed9c..02b2d7126 100644 --- a/pages/keplr/home-page.js +++ b/pages/keplr/home-page.js @@ -3,7 +3,7 @@ const tokenParentSelector = '../../../..'; const selectAllTokensCheck = 'input[type="checkbox"]:enabled'; const newTokensFound = 'new token(s) found'; const addChainsButton = 'Add Chains'; -const newTokensFoundSelector = 'text=new token(s) found' +const newTokensFoundSelector = 'text=new token(s) found'; module.exports.homePageElements = { tokenNameLabel, @@ -11,5 +11,5 @@ module.exports.homePageElements = { selectAllTokensCheck, newTokensFound, addChainsButton, - newTokensFoundSelector + newTokensFoundSelector, }; diff --git a/pages/keplr/notification-page.js b/pages/keplr/notification-page.js index bb5e8b1c5..c77f70649 100644 --- a/pages/keplr/notification-page.js +++ b/pages/keplr/notification-page.js @@ -5,5 +5,5 @@ const walletSelectors = chainName => `img[alt="${chainName}"]`; module.exports.notificationPageElements = { approveButton, copyAddress, - walletSelectors + walletSelectors, }; diff --git a/plugins/metamask-plugin.js b/plugins/metamask-plugin.js index 490f058f7..11e92f9f9 100644 --- a/plugins/metamask-plugin.js +++ b/plugins/metamask-plugin.js @@ -33,7 +33,8 @@ module.exports = (on, config) => { if (!process.env.SKIP_METAMASK_INSTALL) { // NOTE: extensions cannot be loaded in headless Chrome const metamaskPath = await helpers.prepareExtension( - process.env.METAMASK_VERSION || '10.25.0', process.env.EXTENSION + process.env.METAMASK_VERSION || '10.25.0', + process.env.EXTENSION, ); arguments_.extensions.push(metamaskPath); } diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index e6c097911..c6697a13b 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -123,11 +123,17 @@ importers: '@microsoft/eslint-formatter-sarif': specifier: ^3.0.0 version: 3.0.0 + '@typescript-eslint/eslint-plugin': + specifier: ^6.0.0 + version: 6.21.0(@typescript-eslint/parser@6.21.0)(eslint@8.57.0)(typescript@5.3.3) + '@typescript-eslint/parser': + specifier: ^6.0.0 + version: 6.21.0(eslint@8.57.0)(typescript@5.3.3) eslint: specifier: ^8.47.0 version: 8.57.0 eslint-config-prettier: - specifier: ^9.0.0 + specifier: ^9.1.0 version: 9.1.0(eslint@8.57.0) eslint-config-standard: specifier: ^17.1.0 @@ -143,7 +149,7 @@ importers: version: 2.15.1(eslint@8.57.0) eslint-plugin-import: specifier: ^2.28.0 - version: 2.29.1(eslint@8.57.0) + version: 2.29.1(@typescript-eslint/parser@6.21.0)(eslint@8.57.0) eslint-plugin-node: specifier: ^11.1.0 version: 11.1.0(eslint@8.57.0) @@ -165,14 +171,20 @@ importers: eslint-plugin-unicorn: specifier: ^48.0.1 version: 48.0.1(eslint@8.57.0) + husky: + specifier: ^9.0.11 + version: 9.0.11 json-server: specifier: 1.0.0-alpha.23 version: 1.0.0-alpha.23 + lint-staged: + specifier: ^15.2.2 + version: 15.2.2 npm-check-updates: specifier: ^16.12.2 version: 16.14.15 prettier: - specifier: ^3.0.2 + specifier: ^3.2.5 version: 3.2.5 release-it: specifier: ^16.1.5 @@ -204,7 +216,7 @@ importers: version: 0.14.1 '@agoric/notifier': specifier: ^0.6.2 - version: 0.6.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + version: 0.6.2(@endo/ses-ava@0.2.44)(ava@5.3.1) '@agoric/rpc': specifier: 0.9.1-dev-f471a83.0 version: 0.9.1-dev-f471a83.0(ava@5.3.1)(debug@4.3.4)(typescript@5.3.3) @@ -213,10 +225,10 @@ importers: version: 0.9.2(ava@5.3.1) '@agoric/ui-components': specifier: ^0.9.0 - version: 0.9.0(@endo/ses-ava@0.2.40)(ava@5.3.1) + version: 0.9.0(@endo/ses-ava@0.2.44)(ava@5.3.1) '@agoric/web-components': specifier: ^0.15.0 - version: 0.15.0(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4)(eslint@8.57.0) + version: 0.15.0(@endo/ses-ava@0.2.44)(ava@5.3.1)(debug@4.3.4)(eslint@8.57.0) '@testing-library/react': specifier: ^14.1.2 version: 14.2.1(react-dom@18.2.0)(react@18.2.0) @@ -317,15 +329,15 @@ packages: source-map: 0.5.7 dev: true - /@agoric/cache@0.3.2(@endo/ses-ava@0.2.40)(ava@5.3.1): + /@agoric/cache@0.3.2(@endo/ses-ava@0.2.44)(ava@5.3.1): resolution: {integrity: sha512-cFLMiY9OI2Xp7aOAlAmZF/4H6rwaxhtzCfOJ8UiMIKE+4JXkhMLO2FtvGBUWFw40/Q9JsWRWziPs7otuFVQ6Ng==} engines: {node: '>=14.15.0'} dependencies: '@agoric/internal': 0.3.2(ava@5.3.1) - '@agoric/notifier': 0.6.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/notifier': 0.6.2(@endo/ses-ava@0.2.44)(ava@5.3.1) '@agoric/store': 0.9.2(ava@5.3.1) '@agoric/vat-data': 0.5.2(ava@5.3.1) - '@endo/far': 0.2.18(ava@5.3.1) + '@endo/far': 0.2.22(ava@5.3.1) '@endo/marshal': 0.8.9(ava@5.3.1) transitivePeerDependencies: - '@endo/ses-ava' @@ -333,23 +345,23 @@ packages: - supports-color dev: true - /@agoric/casting@0.4.2(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4): + /@agoric/casting@0.4.2(@endo/ses-ava@0.2.44)(ava@5.3.1)(debug@4.3.4): resolution: {integrity: sha512-TiCG7hIg9Wp8Ud0PF7XSrTlqQWdczDac7QdSUWuBDodrlk3qw/5Ktcb5BoD0vFyARNZsB9PZq0cBRNYtjHj/Bg==} engines: {node: '>=14.15.0'} dependencies: '@agoric/internal': 0.3.2(ava@5.3.1) - '@agoric/notifier': 0.6.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/notifier': 0.6.2(@endo/ses-ava@0.2.44)(ava@5.3.1) '@agoric/spawner': 0.6.8(ava@5.3.1) '@agoric/store': 0.9.2(ava@5.3.1) '@cosmjs/encoding': 0.30.1 '@cosmjs/proto-signing': 0.30.1 '@cosmjs/stargate': 0.30.1(debug@4.3.4) '@cosmjs/tendermint-rpc': 0.30.1(debug@4.3.4) - '@endo/far': 0.2.18(ava@5.3.1) + '@endo/far': 0.2.22(ava@5.3.1) '@endo/init': 0.5.60 '@endo/lockdown': 0.1.32 '@endo/marshal': 0.8.9(ava@5.3.1) - '@endo/promise-kit': 0.2.60 + '@endo/promise-kit': 0.2.56 node-fetch: 2.7.0 transitivePeerDependencies: - '@endo/ses-ava' @@ -394,20 +406,20 @@ packages: protobufjs: 7.2.6 dev: true - /@agoric/ertp@0.16.2(@endo/ses-ava@0.2.40)(ava@5.3.1): + /@agoric/ertp@0.16.2(@endo/ses-ava@0.2.44)(ava@5.3.1): resolution: {integrity: sha512-4+CbrkWw2dCYlVAYH+31jFMlwWqw29bak+Rg6qkMuCAp5BpxyBc4DthdovOjwwOBqkBd3QBKrnvkoD9Ltc3YHQ==} engines: {node: '>=14.15.0'} dependencies: '@agoric/assert': 0.6.0 - '@agoric/notifier': 0.6.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/notifier': 0.6.2(@endo/ses-ava@0.2.44)(ava@5.3.1) '@agoric/store': 0.9.2(ava@5.3.1) - '@agoric/swingset-vat': 0.32.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/swingset-vat': 0.32.2(@endo/ses-ava@0.2.44)(ava@5.3.1) '@agoric/vat-data': 0.5.2(ava@5.3.1) '@endo/eventual-send': 0.17.2 - '@endo/far': 0.2.18(ava@5.3.1) + '@endo/far': 0.2.22(ava@5.3.1) '@endo/marshal': 0.8.9(ava@5.3.1) '@endo/nat': 4.1.31 - '@endo/promise-kit': 0.2.60 + '@endo/promise-kit': 0.2.56 transitivePeerDependencies: - '@endo/ses-ava' - ava @@ -418,26 +430,26 @@ packages: resolution: {integrity: sha512-E1gr1LhkN/imwiXIdjTQZ7pOao82avOIDsoSgjPwoFU1jrysRE8UIUGBogBn7GGFUEPogo16rrsfKzb35ZayOw==} dev: true - /@agoric/governance@0.10.3(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4): + /@agoric/governance@0.10.3(@endo/ses-ava@0.2.44)(ava@5.3.1)(debug@4.3.4): resolution: {integrity: sha512-DmaZAJ7u5Tpsh3GscqLkxkZfVl5qg6fD905gdKx/b5xahzF65KIcOz48qUVFqZm/l4N4n1TzIazeAApsLpD7Pw==} engines: {node: '>=14.15.0'} dependencies: '@agoric/assert': 0.6.0 - '@agoric/ertp': 0.16.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/ertp': 0.16.2(@endo/ses-ava@0.2.44)(ava@5.3.1) '@agoric/internal': 0.3.2(ava@5.3.1) - '@agoric/notifier': 0.6.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/notifier': 0.6.2(@endo/ses-ava@0.2.44)(ava@5.3.1) '@agoric/store': 0.9.2(ava@5.3.1) - '@agoric/swingset-vat': 0.32.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/swingset-vat': 0.32.2(@endo/ses-ava@0.2.44)(ava@5.3.1) '@agoric/time': 0.3.2(ava@5.3.1) '@agoric/vat-data': 0.5.2(ava@5.3.1) - '@agoric/vats': 0.15.1(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) - '@agoric/zoe': 0.26.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/vats': 0.15.1(@endo/ses-ava@0.2.44)(ava@5.3.1)(debug@4.3.4) + '@agoric/zoe': 0.26.2(@endo/ses-ava@0.2.44)(ava@5.3.1) '@endo/captp': 3.1.1(ava@5.3.1) '@endo/eventual-send': 0.17.2 - '@endo/far': 0.2.18(ava@5.3.1) + '@endo/far': 0.2.22(ava@5.3.1) '@endo/marshal': 0.8.9(ava@5.3.1) '@endo/nat': 4.1.31 - '@endo/promise-kit': 0.2.60 + '@endo/promise-kit': 0.2.56 transitivePeerDependencies: - '@endo/ses-ava' - ava @@ -448,26 +460,26 @@ packages: - utf-8-validate dev: true - /@agoric/inter-protocol@0.16.1(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4): + /@agoric/inter-protocol@0.16.1(@endo/ses-ava@0.2.44)(ava@5.3.1)(debug@4.3.4): resolution: {integrity: sha512-1SJLBpeLsgXdJEK4CjzQ2QgLgCJg+OJv8M3dKy9MDMK+ajhQRCB2ySQtGbS9KXgwdpj4FFudKb0/+QaGhgfukg==} engines: {node: '>=14.15.0'} dependencies: '@agoric/assert': 0.6.0 - '@agoric/ertp': 0.16.2(@endo/ses-ava@0.2.40)(ava@5.3.1) - '@agoric/governance': 0.10.3(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) + '@agoric/ertp': 0.16.2(@endo/ses-ava@0.2.44)(ava@5.3.1) + '@agoric/governance': 0.10.3(@endo/ses-ava@0.2.44)(ava@5.3.1)(debug@4.3.4) '@agoric/internal': 0.3.2(ava@5.3.1) - '@agoric/notifier': 0.6.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/notifier': 0.6.2(@endo/ses-ava@0.2.44)(ava@5.3.1) '@agoric/store': 0.9.2(ava@5.3.1) '@agoric/time': 0.3.2(ava@5.3.1) '@agoric/vat-data': 0.5.2(ava@5.3.1) - '@agoric/vats': 0.15.1(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) - '@agoric/zoe': 0.26.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/vats': 0.15.1(@endo/ses-ava@0.2.44)(ava@5.3.1)(debug@4.3.4) + '@agoric/zoe': 0.26.2(@endo/ses-ava@0.2.44)(ava@5.3.1) '@endo/captp': 3.1.1(ava@5.3.1) '@endo/eventual-send': 0.17.2 - '@endo/far': 0.2.18(ava@5.3.1) + '@endo/far': 0.2.22(ava@5.3.1) '@endo/marshal': 0.8.9(ava@5.3.1) '@endo/nat': 4.1.31 - agoric: 0.21.1(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) + agoric: 0.21.1(@endo/ses-ava@0.2.44)(ava@5.3.1)(debug@4.3.4) jessie.js: 0.3.3(ava@5.3.1) transitivePeerDependencies: - '@endo/ses-ava' @@ -484,10 +496,10 @@ packages: engines: {node: '>=14.15.0'} dependencies: '@agoric/zone': 0.2.2(ava@5.3.1) - '@endo/far': 0.2.18(ava@5.3.1) + '@endo/far': 0.2.22(ava@5.3.1) '@endo/marshal': 0.8.9(ava@5.3.1) - '@endo/patterns': 0.2.2(ava@5.3.1) - '@endo/promise-kit': 0.2.60 + '@endo/patterns': 0.2.6(ava@5.3.1) + '@endo/promise-kit': 0.2.56 '@endo/stream': 0.3.25 anylogger: 0.21.0 jessie.js: 0.3.3(ava@5.3.1) @@ -511,7 +523,7 @@ packages: - ava dev: true - /@agoric/notifier@0.6.2(@endo/ses-ava@0.2.40)(ava@5.3.1): + /@agoric/notifier@0.6.2(@endo/ses-ava@0.2.44)(ava@5.3.1): resolution: {integrity: sha512-2Hi8u2TXtsk9Ix0L8xfRMGut1c+w7jiM8Wt4Ys2bgfI/ybdJ4FtDIBvHF1hFU0rSbhUicuKAN85Sok+MkDNcug==} engines: {node: '>=14.15.0'} dependencies: @@ -519,11 +531,11 @@ packages: '@agoric/internal': 0.3.2(ava@5.3.1) '@agoric/store': 0.9.2(ava@5.3.1) '@agoric/swing-store': 0.9.1(ava@5.3.1) - '@agoric/swingset-vat': 0.32.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/swingset-vat': 0.32.2(@endo/ses-ava@0.2.44)(ava@5.3.1) '@agoric/vat-data': 0.5.2(ava@5.3.1) - '@endo/far': 0.2.18(ava@5.3.1) + '@endo/far': 0.2.22(ava@5.3.1) '@endo/marshal': 0.8.9(ava@5.3.1) - '@endo/promise-kit': 0.2.60 + '@endo/promise-kit': 0.2.56 transitivePeerDependencies: - '@endo/ses-ava' - ava @@ -580,24 +592,24 @@ packages: - ava dev: true - /@agoric/smart-wallet@0.5.3(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4): + /@agoric/smart-wallet@0.5.3(@endo/ses-ava@0.2.44)(ava@5.3.1)(debug@4.3.4): resolution: {integrity: sha512-2L7sHmUL/BINuuHv+6A1kYLjidqCNJ2V3GqXm3R6oTeFtzscSzOo3LeOoQ2uPridkZ+fTXxinNfpJ/gRu2pl7g==} dependencies: '@agoric/assert': 0.6.0 - '@agoric/casting': 0.4.2(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) - '@agoric/ertp': 0.16.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/casting': 0.4.2(@endo/ses-ava@0.2.44)(ava@5.3.1)(debug@4.3.4) + '@agoric/ertp': 0.16.2(@endo/ses-ava@0.2.44)(ava@5.3.1) '@agoric/internal': 0.3.2(ava@5.3.1) - '@agoric/notifier': 0.6.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/notifier': 0.6.2(@endo/ses-ava@0.2.44)(ava@5.3.1) '@agoric/store': 0.9.2(ava@5.3.1) - '@agoric/swingset-vat': 0.32.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/swingset-vat': 0.32.2(@endo/ses-ava@0.2.44)(ava@5.3.1) '@agoric/vat-data': 0.5.2(ava@5.3.1) - '@agoric/vats': 0.15.1(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) - '@agoric/zoe': 0.26.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/vats': 0.15.1(@endo/ses-ava@0.2.44)(ava@5.3.1)(debug@4.3.4) + '@agoric/zoe': 0.26.2(@endo/ses-ava@0.2.44)(ava@5.3.1) '@endo/eventual-send': 0.17.2 - '@endo/far': 0.2.18(ava@5.3.1) + '@endo/far': 0.2.22(ava@5.3.1) '@endo/marshal': 0.8.9(ava@5.3.1) '@endo/nat': 4.1.31 - '@endo/promise-kit': 0.2.60 + '@endo/promise-kit': 0.2.56 transitivePeerDependencies: - '@endo/ses-ava' - ava @@ -642,11 +654,11 @@ packages: '@agoric/internal': 0.3.2(ava@5.3.1) '@endo/eventual-send': 0.17.2 '@endo/exo': 0.2.2(ava@5.3.1) - '@endo/far': 0.2.18(ava@5.3.1) + '@endo/far': 0.2.22(ava@5.3.1) '@endo/marshal': 0.8.9(ava@5.3.1) '@endo/pass-style': 0.1.7(ava@5.3.1) - '@endo/patterns': 0.2.2(ava@5.3.1) - '@endo/promise-kit': 0.2.60 + '@endo/patterns': 0.2.6(ava@5.3.1) + '@endo/promise-kit': 0.2.56 '@fast-check/ava': 1.2.1(ava@5.3.1) transitivePeerDependencies: - ava @@ -695,7 +707,7 @@ packages: - supports-color dev: true - /@agoric/swingset-liveslots@0.10.2(@endo/far@0.2.18)(@endo/ses-ava@0.2.40)(ava@5.3.1): + /@agoric/swingset-liveslots@0.10.2(@endo/far@0.2.22)(@endo/ses-ava@0.2.44)(ava@5.3.1): resolution: {integrity: sha512-jp05WNHEUH5K8MgiIoHhNrWu7ozKqStyIe0Ex6ejSInFFo/NhJLVL7QLyUgRjD74RbUSuvbR8v8PaQ/pslVI0Q==} engines: {node: '>=14.15.0'} peerDependencies: @@ -709,14 +721,14 @@ packages: '@agoric/vat-data': 0.5.2(ava@5.3.1) '@endo/eventual-send': 0.17.2 '@endo/exo': 0.2.2(ava@5.3.1) - '@endo/far': 0.2.18(ava@5.3.1) + '@endo/far': 0.2.22(ava@5.3.1) '@endo/init': 0.5.60 '@endo/marshal': 0.8.9(ava@5.3.1) '@endo/nat': 4.1.31 '@endo/pass-style': 0.1.7(ava@5.3.1) - '@endo/patterns': 0.2.2(ava@5.3.1) - '@endo/promise-kit': 0.2.60 - '@endo/ses-ava': 0.2.40 + '@endo/patterns': 0.2.6(ava@5.3.1) + '@endo/promise-kit': 0.2.56 + '@endo/ses-ava': 0.2.44 ava: 5.3.1 dev: true @@ -741,7 +753,7 @@ packages: - ava dev: true - /@agoric/swingset-vat@0.32.2(@endo/ses-ava@0.2.40)(ava@5.3.1): + /@agoric/swingset-vat@0.32.2(@endo/ses-ava@0.2.44)(ava@5.3.1): resolution: {integrity: sha512-aYIhyYCuI7Oi47DBqn8wqMFnQOeOxSB7GU69wOQcQIoJVWRhOECDuFzoEqdV6G8xwGIsGpX/fMtXT9A1YAy6ZA==} engines: {node: '>=14.15.0'} hasBin: true @@ -753,7 +765,7 @@ packages: '@agoric/internal': 0.3.2(ava@5.3.1) '@agoric/store': 0.9.2(ava@5.3.1) '@agoric/swing-store': 0.9.1(ava@5.3.1) - '@agoric/swingset-liveslots': 0.10.2(@endo/far@0.2.18)(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/swingset-liveslots': 0.10.2(@endo/far@0.2.22)(@endo/ses-ava@0.2.44)(ava@5.3.1) '@agoric/swingset-xsnap-supervisor': 0.10.2 '@agoric/time': 0.3.2(ava@5.3.1) '@agoric/vat-data': 0.5.2(ava@5.3.1) @@ -765,13 +777,13 @@ packages: '@endo/check-bundle': 0.2.18 '@endo/compartment-mapper': 0.8.4 '@endo/eventual-send': 0.17.2 - '@endo/far': 0.2.18(ava@5.3.1) + '@endo/far': 0.2.22(ava@5.3.1) '@endo/import-bundle': 0.3.4 '@endo/init': 0.5.60 '@endo/marshal': 0.8.9(ava@5.3.1) '@endo/nat': 4.1.31 - '@endo/promise-kit': 0.2.60 - '@endo/ses-ava': 0.2.40 + '@endo/promise-kit': 0.2.56 + '@endo/ses-ava': 0.2.44 '@endo/zip': 0.2.35 ansi-styles: 6.2.1 anylogger: 0.21.0 @@ -856,11 +868,11 @@ packages: - ava dev: true - /@agoric/ui-components@0.9.0(@endo/ses-ava@0.2.40)(ava@5.3.1): + /@agoric/ui-components@0.9.0(@endo/ses-ava@0.2.44)(ava@5.3.1): resolution: {integrity: sha512-Ed8ZS1sprma+DLx1gBcCczIFlZ5jxLVUXqZPp32R5QnuOn9IfeDK4B+xhm7BJYr+0Lr2BNof9yqkvmWBmUEvNQ==} dependencies: '@agoric/assert': 0.6.0 - '@agoric/ertp': 0.16.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/ertp': 0.16.2(@endo/ses-ava@0.2.44)(ava@5.3.1) '@endo/eventual-send': 0.17.2 '@endo/init': 0.5.60 '@endo/nat': 4.1.31 @@ -893,29 +905,29 @@ packages: - ava dev: true - /@agoric/vats@0.15.1(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4): + /@agoric/vats@0.15.1(@endo/ses-ava@0.2.44)(ava@5.3.1)(debug@4.3.4): resolution: {integrity: sha512-uYV+f3+RJ/KM9O5+7HcsGqLfvhtj9V1e7u1y8TZeTs2zJXVRVuGi/xQaMSGwf3CBBgBtyj8hFUCCYCeHxB1qRQ==} engines: {node: '>=14.15.0'} dependencies: '@agoric/assert': 0.6.0 - '@agoric/ertp': 0.16.2(@endo/ses-ava@0.2.40)(ava@5.3.1) - '@agoric/governance': 0.10.3(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) - '@agoric/inter-protocol': 0.16.1(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) + '@agoric/ertp': 0.16.2(@endo/ses-ava@0.2.44)(ava@5.3.1) + '@agoric/governance': 0.10.3(@endo/ses-ava@0.2.44)(ava@5.3.1)(debug@4.3.4) + '@agoric/inter-protocol': 0.16.1(@endo/ses-ava@0.2.44)(ava@5.3.1)(debug@4.3.4) '@agoric/internal': 0.3.2(ava@5.3.1) - '@agoric/notifier': 0.6.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/notifier': 0.6.2(@endo/ses-ava@0.2.44)(ava@5.3.1) '@agoric/sharing-service': 0.2.11(ava@5.3.1) '@agoric/store': 0.9.2(ava@5.3.1) - '@agoric/swingset-vat': 0.32.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/swingset-vat': 0.32.2(@endo/ses-ava@0.2.44)(ava@5.3.1) '@agoric/time': 0.3.2(ava@5.3.1) '@agoric/vat-data': 0.5.2(ava@5.3.1) - '@agoric/zoe': 0.26.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/zoe': 0.26.2(@endo/ses-ava@0.2.44)(ava@5.3.1) '@agoric/zone': 0.2.2(ava@5.3.1) - '@endo/far': 0.2.18(ava@5.3.1) + '@endo/far': 0.2.22(ava@5.3.1) '@endo/import-bundle': 0.3.4 '@endo/init': 0.5.60 '@endo/marshal': 0.8.9(ava@5.3.1) '@endo/nat': 4.1.31 - '@endo/promise-kit': 0.2.60 + '@endo/promise-kit': 0.2.56 jessie.js: 0.3.3(ava@5.3.1) transitivePeerDependencies: - '@endo/ses-ava' @@ -931,11 +943,11 @@ packages: resolution: {integrity: sha512-NbhCrTH9u2af+6ituM99M8Mo10VOP1nQRTZoYEXW+esBwJId/7cRniMmAC7qmkbXs8POA31S8EQ5gAhkWq08WA==} dev: true - /@agoric/wallet@0.18.3(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4)(eslint@8.57.0): + /@agoric/wallet@0.18.3(@endo/ses-ava@0.2.44)(ava@5.3.1)(debug@4.3.4)(eslint@8.57.0): resolution: {integrity: sha512-Pgk5uh2ZA3sg3hP+gpQ4jpg+qhIu5diKzzVnD5g4o2JeVYjDqsR/xpcOt7r7i8zNbNutCAgGu5/qDDYEMIV6zQ==} dependencies: '@agoric/wallet-ui': 0.1.3-solo.0 - agoric: 0.21.1(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) + agoric: 0.21.1(@endo/ses-ava@0.2.44)(ava@5.3.1)(debug@4.3.4) babel-eslint: 10.1.0(eslint@8.57.0) eslint-plugin-eslint-comments: 3.2.0(eslint@8.57.0) import-meta-resolve: 2.2.2 @@ -950,20 +962,20 @@ packages: - utf-8-validate dev: true - /@agoric/web-components@0.15.0(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4)(eslint@8.57.0): + /@agoric/web-components@0.15.0(@endo/ses-ava@0.2.44)(ava@5.3.1)(debug@4.3.4)(eslint@8.57.0): resolution: {integrity: sha512-G1hl0NSgOuXE+9+SsyUpCHubhFJsrmFO7zo832EeJDUcO5d/V4M0YyrtIwFHKR2bH+IUl7JouasDO4fYEE8WYA==} dependencies: '@agoric/assert': 0.6.0 - '@agoric/cache': 0.3.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/cache': 0.3.2(@endo/ses-ava@0.2.44)(ava@5.3.1) '@agoric/casting': 0.4.3-u14.0(ava@5.3.1)(debug@4.3.4) - '@agoric/ertp': 0.16.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/ertp': 0.16.2(@endo/ses-ava@0.2.44)(ava@5.3.1) '@agoric/notifier': 0.6.3-u14.0(ava@5.3.1) - '@agoric/smart-wallet': 0.5.3(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) - '@agoric/wallet': 0.18.3(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4)(eslint@8.57.0) + '@agoric/smart-wallet': 0.5.3(@endo/ses-ava@0.2.44)(ava@5.3.1)(debug@4.3.4) + '@agoric/wallet': 0.18.3(@endo/ses-ava@0.2.44)(ava@5.3.1)(debug@4.3.4)(eslint@8.57.0) '@endo/captp': 3.1.1(ava@5.3.1) '@endo/eventual-send': 0.17.2 '@endo/marshal': 0.8.9(ava@5.3.1) - '@endo/promise-kit': 0.2.60 + '@endo/promise-kit': 0.2.56 '@lit-labs/react': 1.2.1 lit: 2.0.2 transitivePeerDependencies: @@ -1007,27 +1019,27 @@ packages: - supports-color dev: true - /@agoric/zoe@0.26.2(@endo/ses-ava@0.2.40)(ava@5.3.1): + /@agoric/zoe@0.26.2(@endo/ses-ava@0.2.44)(ava@5.3.1): resolution: {integrity: sha512-xFZQ0Rz4UmHNWCUeLWFqtGgKNBPVvfb5IEmh+nSnbgJK45Y4Kcci77XkciO//e6xQo8dacrNhTELke3iAEISAA==} engines: {node: '>=14.15.0'} dependencies: '@agoric/assert': 0.6.0 - '@agoric/ertp': 0.16.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/ertp': 0.16.2(@endo/ses-ava@0.2.44)(ava@5.3.1) '@agoric/internal': 0.3.2(ava@5.3.1) - '@agoric/notifier': 0.6.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/notifier': 0.6.2(@endo/ses-ava@0.2.44)(ava@5.3.1) '@agoric/store': 0.9.2(ava@5.3.1) - '@agoric/swingset-vat': 0.32.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/swingset-vat': 0.32.2(@endo/ses-ava@0.2.44)(ava@5.3.1) '@agoric/time': 0.3.2(ava@5.3.1) '@agoric/vat-data': 0.5.2(ava@5.3.1) '@endo/bundle-source': 2.8.0(ava@5.3.1) '@endo/captp': 3.1.1(ava@5.3.1) '@endo/eventual-send': 0.17.2 - '@endo/far': 0.2.18(ava@5.3.1) + '@endo/far': 0.2.22(ava@5.3.1) '@endo/import-bundle': 0.3.4 '@endo/marshal': 0.8.9(ava@5.3.1) '@endo/nat': 4.1.31 - '@endo/patterns': 0.2.2(ava@5.3.1) - '@endo/promise-kit': 0.2.60 + '@endo/patterns': 0.2.6(ava@5.3.1) + '@endo/promise-kit': 0.2.56 transitivePeerDependencies: - '@endo/ses-ava' - ava @@ -1040,7 +1052,7 @@ packages: dependencies: '@agoric/store': 0.9.2(ava@5.3.1) '@agoric/vat-data': 0.5.2(ava@5.3.1) - '@endo/far': 0.2.18(ava@5.3.1) + '@endo/far': 0.2.22(ava@5.3.1) transitivePeerDependencies: - ava dev: true @@ -2603,7 +2615,7 @@ packages: '@endo/base64': 0.2.35 '@endo/compartment-mapper': 0.8.4 '@endo/init': 0.5.60 - '@endo/promise-kit': 0.2.60 + '@endo/promise-kit': 0.2.56 '@rollup/plugin-commonjs': 19.0.2(rollup@2.79.1) '@rollup/plugin-node-resolve': 13.3.0(rollup@2.79.1) acorn: 8.11.3 @@ -2644,7 +2656,7 @@ packages: '@endo/eventual-send': 0.17.2 '@endo/marshal': 0.8.9(ava@5.3.1) '@endo/nat': 4.1.31 - '@endo/promise-kit': 0.2.60 + '@endo/promise-kit': 0.2.56 transitivePeerDependencies: - ava dev: true @@ -2694,8 +2706,8 @@ packages: /@endo/exo@0.2.2(ava@5.3.1): resolution: {integrity: sha512-4787jRJe7nQLV02mCCd1fQ8Ai25ParaIzLBUrxl7UKtsP98LcTlQKAON+OQmnSbV6jjXINa/wHdUeoi8/0xZDA==} dependencies: - '@endo/far': 0.2.18(ava@5.3.1) - '@endo/patterns': 0.2.2(ava@5.3.1) + '@endo/far': 0.2.22(ava@5.3.1) + '@endo/patterns': 0.2.6(ava@5.3.1) transitivePeerDependencies: - ava dev: true @@ -2709,6 +2721,15 @@ packages: - ava dev: true + /@endo/far@0.2.22(ava@5.3.1): + resolution: {integrity: sha512-LFOicqyHslKOSk/H5EfGOcw347ftDSwYHARPasnrG4UJOEkcU1ZG5bN/BmfONtcidB776gWZKrV/tNl4WLIlyw==} + dependencies: + '@endo/eventual-send': 0.17.2 + '@endo/pass-style': 0.1.7(ava@5.3.1) + transitivePeerDependencies: + - ava + dev: true + /@endo/import-bundle@0.3.4: resolution: {integrity: sha512-MjB7VBJYFgcUhelMddJQf9uMwxqXV1McjVGqoJ3ZJ/OIQZ5BTYqR+uyZOI8CaUqpVmhNbsg3qMw8/wXW304YlA==} engines: {node: '>=12'} @@ -2725,7 +2746,7 @@ packages: '@endo/base64': 0.2.35 '@endo/eventual-send': 0.17.2 '@endo/lockdown': 0.1.32 - '@endo/promise-kit': 0.2.60 + '@endo/promise-kit': 0.2.56 dev: true /@endo/init@0.5.60: @@ -2755,7 +2776,7 @@ packages: '@endo/eventual-send': 0.17.2 '@endo/nat': 4.1.31 '@endo/pass-style': 0.1.7(ava@5.3.1) - '@endo/promise-kit': 0.2.60 + '@endo/promise-kit': 0.2.56 transitivePeerDependencies: - ava dev: true @@ -2790,7 +2811,7 @@ packages: /@endo/pass-style@0.1.3(ava@5.3.1): resolution: {integrity: sha512-V2FLPBUJXsJYWjMSoZW2IopOuggEX14pm8AHfOVXUceF3uvHbdJj7qwKAuIIOhPApZ/TV+6nWYi86eb393Ic2w==} dependencies: - '@endo/promise-kit': 0.2.60 + '@endo/promise-kit': 0.2.56 '@fast-check/ava': 1.2.1(ava@5.3.1) transitivePeerDependencies: - ava @@ -2807,6 +2828,16 @@ packages: /@endo/patterns@0.2.2(ava@5.3.1): resolution: {integrity: sha512-rbS4BLRohZQhB+0aEPBoxmzOfOie9nAu8Qx55Fxe8xFQKS4k9acafeIYmKh9nvslEJISYQmogy5Lewm5mgdSjg==} + dependencies: + '@endo/eventual-send': 0.17.2 + '@endo/marshal': 0.8.9(ava@5.3.1) + '@endo/promise-kit': 0.2.56 + transitivePeerDependencies: + - ava + dev: true + + /@endo/patterns@0.2.6(ava@5.3.1): + resolution: {integrity: sha512-FbayXMv9sY4qP5vSaPhq9RSJmsTykImbCy0FN1YmZzaChGwOfSPOJw4898xVLDK5Xi6f+6zV02uXjuMTuZt6UA==} dependencies: '@endo/eventual-send': 0.17.2 '@endo/marshal': 0.8.9(ava@5.3.1) @@ -2835,6 +2866,12 @@ packages: ses: 1.3.0 dev: true + /@endo/ses-ava@0.2.44: + resolution: {integrity: sha512-Pp0os/ZN7r0L94eCxWFYhSWt+DIdIASIVlY4oYCwMLxLa28cuswCjRQvPKLINBpZezogCKKptEWJTyHhGWpVQw==} + dependencies: + ses: 1.3.0 + dev: true + /@endo/static-module-record@0.7.20: resolution: {integrity: sha512-qpow712L7Bh7F3olFW9e15PcDWnC2eSY4xPdhpZoYTzedsyjCETRgxFWY6+DdT193lNlyKIn0On1O1Go+5WmBA==} dependencies: @@ -2871,7 +2908,7 @@ packages: resolution: {integrity: sha512-qSl9Q9o20/4nKdXlXYCs6KJfeANMKBLrsi7JIxWV1jP9YzIDdq/PkEJsMNq89Z/HWXtPRfEQ4JEMd3O1WBYU5Q==} dependencies: '@endo/eventual-send': 0.17.2 - '@endo/promise-kit': 0.2.60 + '@endo/promise-kit': 0.2.56 ses: 1.3.0 dev: true @@ -5056,23 +5093,23 @@ packages: indent-string: 5.0.0 dev: true - /agoric@0.21.1(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4): + /agoric@0.21.1(@endo/ses-ava@0.2.44)(ava@5.3.1)(debug@4.3.4): resolution: {integrity: sha512-couQBRaYLY9S5cXm0uUmf/022+Zy6EHH9tbZLOFYGzdFQeTMZCvYbxdklKGVzLWcoe8CHc/YMemnpaBghkPG4A==} hasBin: true dependencies: '@agoric/access-token': 0.4.21 '@agoric/assert': 0.6.0 - '@agoric/cache': 0.3.2(@endo/ses-ava@0.2.40)(ava@5.3.1) - '@agoric/casting': 0.4.2(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) + '@agoric/cache': 0.3.2(@endo/ses-ava@0.2.44)(ava@5.3.1) + '@agoric/casting': 0.4.2(@endo/ses-ava@0.2.44)(ava@5.3.1)(debug@4.3.4) '@agoric/cosmic-proto': 0.3.0 - '@agoric/ertp': 0.16.2(@endo/ses-ava@0.2.40)(ava@5.3.1) - '@agoric/inter-protocol': 0.16.1(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) + '@agoric/ertp': 0.16.2(@endo/ses-ava@0.2.44)(ava@5.3.1) + '@agoric/inter-protocol': 0.16.1(@endo/ses-ava@0.2.44)(ava@5.3.1)(debug@4.3.4) '@agoric/internal': 0.3.2(ava@5.3.1) - '@agoric/smart-wallet': 0.5.3(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) + '@agoric/smart-wallet': 0.5.3(@endo/ses-ava@0.2.44)(ava@5.3.1)(debug@4.3.4) '@agoric/store': 0.9.2(ava@5.3.1) - '@agoric/swingset-vat': 0.32.2(@endo/ses-ava@0.2.40)(ava@5.3.1) - '@agoric/vats': 0.15.1(@endo/ses-ava@0.2.40)(ava@5.3.1)(debug@4.3.4) - '@agoric/zoe': 0.26.2(@endo/ses-ava@0.2.40)(ava@5.3.1) + '@agoric/swingset-vat': 0.32.2(@endo/ses-ava@0.2.44)(ava@5.3.1) + '@agoric/vats': 0.15.1(@endo/ses-ava@0.2.44)(ava@5.3.1)(debug@4.3.4) + '@agoric/zoe': 0.26.2(@endo/ses-ava@0.2.44)(ava@5.3.1) '@agoric/zone': 0.2.2(ava@5.3.1) '@confio/relayer': 0.9.0(debug@4.3.4) '@cosmjs/crypto': 0.30.1 @@ -5084,11 +5121,11 @@ packages: '@endo/bundle-source': 2.8.0(ava@5.3.1) '@endo/captp': 3.1.1(ava@5.3.1) '@endo/compartment-mapper': 0.8.4 - '@endo/far': 0.2.18(ava@5.3.1) + '@endo/far': 0.2.22(ava@5.3.1) '@endo/init': 0.5.60 '@endo/marshal': 0.8.9(ava@5.3.1) '@endo/nat': 4.1.31 - '@endo/promise-kit': 0.2.60 + '@endo/promise-kit': 0.2.56 '@iarna/toml': 2.2.5 anylogger: 0.21.0 chalk: 5.3.0 @@ -5189,6 +5226,13 @@ packages: dependencies: type-fest: 0.21.3 + /ansi-escapes@6.2.0: + resolution: {integrity: sha512-kzRaCqXnpzWs+3z5ABPQiVke+iq0KXkHo8xiWV4RPTi5Yli0l97BEQuhXV1s7+aSU/fu1kUuxgS4MsQ0fRuygw==} + engines: {node: '>=14.16'} + dependencies: + type-fest: 3.13.1 + dev: true + /ansi-html-community@0.0.8: resolution: {integrity: sha512-1APHAyr3+PCamwNw3bXCPp4HFLONZt/yIH0sZp0/469KWNTEy+qN5jQ3GVX6DMZ1UXAi34yVwtTeaG/HpBuuzw==} engines: {'0': node >= 0.8.0} @@ -6315,6 +6359,14 @@ packages: string-width: 5.1.2 dev: true + /cli-truncate@4.0.0: + resolution: {integrity: sha512-nPdaFdQ0h/GEigbPClz11D0v/ZJEwxmeVZGeMo3Z5StPtUTkA9o1lD6QwoirYiSDzbcwn2XcjwmCp68W1IS4TA==} + engines: {node: '>=18'} + dependencies: + slice-ansi: 5.0.0 + string-width: 7.1.0 + dev: true + /cli-width@3.0.0: resolution: {integrity: sha512-FxqpkPPwu1HjuN93Omfm4h8uIanXofW0RxVEW3k5RKx+mJJYSthzNhp32Kzxxy3YAEZ/Dc/EWN1vZRY0+kOhbw==} engines: {node: '>= 10'} @@ -6430,7 +6482,6 @@ packages: /colorette@2.0.20: resolution: {integrity: sha512-IfEDxwoWIjkeXL1eXcDiow4UbKjhLdq6/EuSVR9GMN7KVH3r9gQ83e73hsz1Nd1T3ijd5xv1wcWRYO+D6kCI2w==} - dev: false /colorspace@1.1.4: resolution: {integrity: sha512-BgvKJiuVu1igBUF2kEjRCZXol6wiiGbY5ipL/oVPwm0BL9sIpMIzM8IK7vwuxIIzOXMV3Ey5w+vxhm0rR/TN8w==} @@ -6457,7 +6508,6 @@ packages: /commander@11.1.0: resolution: {integrity: sha512-yPVavfyCcRhmorC7rWlkHn15b4wDVgVmBA7kV4QVBsF7kv/9TKJAbAXVTxvTnwP8HHKjRCJDClKbciiYS7p0DQ==} engines: {node: '>=16'} - dev: false /commander@2.20.3: resolution: {integrity: sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==} @@ -7613,7 +7663,7 @@ packages: eslint-plugin-promise: ^6.0.0 dependencies: eslint: 8.57.0 - eslint-plugin-import: 2.29.1(eslint@8.57.0) + eslint-plugin-import: 2.29.1(@typescript-eslint/parser@6.21.0)(eslint@8.57.0) eslint-plugin-n: 16.6.2(eslint@8.57.0) eslint-plugin-promise: 6.1.1(eslint@8.57.0) dev: true @@ -7637,7 +7687,7 @@ packages: - supports-color dev: true - /eslint-module-utils@2.8.1(eslint-import-resolver-node@0.3.9)(eslint@8.57.0): + /eslint-module-utils@2.8.1(@typescript-eslint/parser@6.21.0)(eslint-import-resolver-node@0.3.9)(eslint@8.57.0): resolution: {integrity: sha512-rXDXR3h7cs7dy9RNpUlQf80nX31XWJEyGq1tRMo+6GsO5VmTe4UTwtmonAD4ZkAsrfMVDA2wlGJ3790Ys+D49Q==} engines: {node: '>=4'} peerDependencies: @@ -7658,6 +7708,7 @@ packages: eslint-import-resolver-webpack: optional: true dependencies: + '@typescript-eslint/parser': 6.21.0(eslint@8.57.0)(typescript@5.3.3) debug: 3.2.7(supports-color@8.1.1) eslint: 8.57.0 eslint-import-resolver-node: 0.3.9 @@ -7717,7 +7768,7 @@ packages: ignore: 5.3.1 dev: true - /eslint-plugin-import@2.29.1(eslint@8.57.0): + /eslint-plugin-import@2.29.1(@typescript-eslint/parser@6.21.0)(eslint@8.57.0): resolution: {integrity: sha512-BbPC0cuExzhiMo4Ff1BTVwHpjjv28C5R+btTOGaCRC7UEz801up0JadwkeSk5Ued6TG34uaczuVuH6qyy5YUxw==} engines: {node: '>=4'} peerDependencies: @@ -7727,6 +7778,7 @@ packages: '@typescript-eslint/parser': optional: true dependencies: + '@typescript-eslint/parser': 6.21.0(eslint@8.57.0)(typescript@5.3.3) array-includes: 3.1.7 array.prototype.findlastindex: 1.2.4 array.prototype.flat: 1.3.2 @@ -7735,7 +7787,7 @@ packages: doctrine: 2.1.0 eslint: 8.57.0 eslint-import-resolver-node: 0.3.9 - eslint-module-utils: 2.8.1(eslint-import-resolver-node@0.3.9)(eslint@8.57.0) + eslint-module-utils: 2.8.1(@typescript-eslint/parser@6.21.0)(eslint-import-resolver-node@0.3.9)(eslint@8.57.0) hasown: 2.0.1 is-core-module: 2.13.1 is-glob: 4.0.3 @@ -8092,6 +8144,10 @@ packages: resolution: {integrity: sha512-8guHBZCwKnFhYdHr2ysuRWErTwhoN2X8XELRlrRwpmfeY2jjuUN4taQMsULKUVo1K4DvZl+0pgfyoysHxvmvEw==} dev: false + /eventemitter3@5.0.1: + resolution: {integrity: sha512-GWkBvjiSZK87ELrYOSESUYeVIc9mvLLf/nXalMOS5dYrgZq9o5OVkbZAVM06CVxYsCwH9BDZFPlQTlPA1j4ahA==} + dev: true + /events@3.3.0: resolution: {integrity: sha512-mQw+2fkQbALzQ7V0MY0IqdnXNOeTtP4r0lN9z7AAawCXgqea7bDii20AYrIBrFd/Hx0M2Ocz6S111CaFkUcb0Q==} engines: {node: '>=0.8.x'} @@ -8707,6 +8763,11 @@ packages: resolution: {integrity: sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==} engines: {node: 6.* || 8.* || >= 10.*} + /get-east-asian-width@1.2.0: + resolution: {integrity: sha512-2nk+7SIVb14QrgXFHcm84tD4bKQz0RxPuMT8Ag5KPOq7J5fEmAg0UbXdTOSHqNuHSU28k55qnceesxXRZGzKWA==} + engines: {node: '>=18'} + dev: true + /get-func-name@2.0.2: resolution: {integrity: sha512-8vXOvuE167CtIc3OyItco7N/dpRtBbYOsPsXCz7X/PMnlGjYjSGuZJgM1Y7mmew7BKf9BqvLX2tnOVy1BBUsxQ==} dev: true @@ -9384,6 +9445,12 @@ packages: ms: 2.1.3 dev: true + /husky@9.0.11: + resolution: {integrity: sha512-AB6lFlbwwyIqMdHYhwPe+kjOC3Oc5P3nThEoW/AaO2BX3vJDjWPFxYLxokUZOo6RNX20He3AaT8sESs9NJcmEw==} + engines: {node: '>=18'} + hasBin: true + dev: true + /iconv-lite@0.4.24: resolution: {integrity: sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==} engines: {node: '>=0.10.0'} @@ -9678,6 +9745,13 @@ packages: engines: {node: '>=12'} dev: true + /is-fullwidth-code-point@5.0.0: + resolution: {integrity: sha512-OVa3u9kkBbw7b8Xw5F9P+D/T9X+Z4+JruYVNapTjPYZYUznQ5YfWeFkOj606XYYW8yugTfC8Pj0hYqvi4ryAhA==} + engines: {node: '>=18'} + dependencies: + get-east-asian-width: 1.2.0 + dev: true + /is-glob@4.0.3: resolution: {integrity: sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==} engines: {node: '>=0.10.0'} @@ -10059,7 +10133,7 @@ packages: /jessie.js@0.3.3(ava@5.3.1): resolution: {integrity: sha512-qtm2JSB/ZeH9xNNPjVkeTFH+Hoq9BxAzakgf6WK1PLarIoXJ9roSi+Z5UF65K47rT7QteWrP8b6RPBVquvIwsg==} dependencies: - '@endo/far': 0.2.18(ava@5.3.1) + '@endo/far': 0.2.22(ava@5.3.1) transitivePeerDependencies: - ava dev: true @@ -10340,6 +10414,11 @@ packages: resolution: {integrity: sha512-mK8ju0fnrKXXfleL53vtp9xiPq5hKM0zbDQtcxQIsSmxNgSxqCj6R7Hl9PkrNe2j29T4yoDaF7DJLK9/i5iWUw==} dev: true + /lilconfig@3.0.0: + resolution: {integrity: sha512-K2U4W2Ff5ibV7j7ydLr+zLAkIg5JJ4lPn1Ltsdt+Tz/IjQ8buJ55pZAxoP34lqIiwtF9iAvtLv3JGv7CAyAg+g==} + engines: {node: '>=14'} + dev: true + /limiter@1.1.5: resolution: {integrity: sha512-FWWMIEOxz3GwUI4Ts/IvgVy6LPvoMPgjMdQ185nN6psJyBJ4yOpzqm695/h5umdLJg2vW3GR5iG11MAkR2AzJA==} dev: true @@ -10348,6 +10427,25 @@ packages: resolution: {integrity: sha512-7ylylesZQ/PV29jhEDl3Ufjo6ZX7gCqJr5F7PKrqc93v7fzSymt1BpwEU8nAUXs8qzzvqhbjhK5QZg6Mt/HkBg==} dev: true + /lint-staged@15.2.2: + resolution: {integrity: sha512-TiTt93OPh1OZOsb5B7k96A/ATl2AjIZo+vnzFZ6oHK5FuTk63ByDtxGQpHm+kFETjEWqgkF95M8FRXKR/LEBcw==} + engines: {node: '>=18.12.0'} + hasBin: true + dependencies: + chalk: 5.3.0 + commander: 11.1.0 + debug: 4.3.4(supports-color@8.1.1) + execa: 8.0.1 + lilconfig: 3.0.0 + listr2: 8.0.1 + micromatch: 4.0.5 + pidtree: 0.6.0 + string-argv: 0.3.2 + yaml: 2.3.4 + transitivePeerDependencies: + - supports-color + dev: true + /listr2@3.14.0(enquirer@2.4.1): resolution: {integrity: sha512-TyWI8G99GX9GjE54cJ+RrNMcIFBfwMPxc3XTFiAYGN4s10hWROGtOg7+O6u6LE3mNkyld7RSLE6nrKBvTfcs3g==} engines: {node: '>=10.0.0'} @@ -10368,6 +10466,18 @@ packages: wrap-ansi: 7.0.0 dev: false + /listr2@8.0.1: + resolution: {integrity: sha512-ovJXBXkKGfq+CwmKTjluEqFi3p4h8xvkxGQQAQan22YCgef4KZ1mKGjzfGh6PL6AW5Csw0QiQPNuQyH+6Xk3hA==} + engines: {node: '>=18.0.0'} + dependencies: + cli-truncate: 4.0.0 + colorette: 2.0.20 + eventemitter3: 5.0.1 + log-update: 6.0.0 + rfdc: 1.3.1 + wrap-ansi: 9.0.0 + dev: true + /lit-element@3.3.3: resolution: {integrity: sha512-XbeRxmTHubXENkV4h8RIPyr8lXc+Ff28rkcQzw3G6up2xg5E8Zu1IgOWIwBLEQsu3cOVFqdYwiVi0hv0SlpqUA==} dependencies: @@ -10528,6 +10638,17 @@ packages: wrap-ansi: 6.2.0 dev: false + /log-update@6.0.0: + resolution: {integrity: sha512-niTvB4gqvtof056rRIrTZvjNYE4rCUzO6X/X+kYjd7WFxXeJ0NwEFnRxX6ehkvv3jTwrXnNdtAak5XYZuIyPFw==} + engines: {node: '>=18'} + dependencies: + ansi-escapes: 6.2.0 + cli-cursor: 4.0.0 + slice-ansi: 7.1.0 + strip-ansi: 7.1.0 + wrap-ansi: 9.0.0 + dev: true + /logform@2.6.0: resolution: {integrity: sha512-1ulHeNPp6k/LD8H91o7VYFBng5i1BDE7HoKxVbZiGFidS1Rj65qcywLxX+pVfAPoQJEjRdvKcusKwOupHCVOVQ==} engines: {node: '>= 12.0.0'} @@ -11928,6 +12049,12 @@ packages: resolution: {integrity: sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==} engines: {node: '>=8.6'} + /pidtree@0.6.0: + resolution: {integrity: sha512-eG2dWTVw5bzqGRztnHExczNxt5VGsE6OwTeCG3fdUf9KBsZzO3R5OIIIzWR+iZA0NtZ+RDVdaoE2dK1cn6jH4g==} + engines: {node: '>=0.10'} + hasBin: true + dev: true + /pify@2.3.0: resolution: {integrity: sha512-udgsAY+fTnvv7kI7aaxbqwWNb0AHiB0qBO89PZKPkoTmGOgdbrHDKD+0B2X4uTfJ/FT1R09r9gTsjUjNJotuog==} engines: {node: '>=0.10.0'} @@ -12796,7 +12923,6 @@ packages: /rfdc@1.3.1: resolution: {integrity: sha512-r5a3l5HzYlIC68TpmYKlxWjmOP6wiPJ1vWv2HeLhNsRZMrCkxeqxiHlQ21oXmQ4F3SiryXBHhAD7JZqvOJjFmg==} - dev: false /rimraf@3.0.2: resolution: {integrity: sha512-JZkJMZkAGFFPP2YqXZXPbMlMBgsxzE8ILs4lMIX/2o0L9UBw9O/Y3o6wFw/i9YLapcUJWwqbi3kdxIPdC62TIA==} @@ -13257,6 +13383,14 @@ packages: is-fullwidth-code-point: 4.0.0 dev: true + /slice-ansi@7.1.0: + resolution: {integrity: sha512-bSiSngZ/jWeX93BqeIAbImyTbEihizcwNjFoRUIY/T1wWQsfsm2Vw1agPKylXvQTU7iASGdHhyqRlqQzfz+Htg==} + engines: {node: '>=18'} + dependencies: + ansi-styles: 6.2.1 + is-fullwidth-code-point: 5.0.0 + dev: true + /smart-buffer@4.2.0: resolution: {integrity: sha512-94hK0Hh8rPqQl2xXc3HsaBoOXKV20MToPkcXvwbISWLEs+64sBq5kFgn2kJDHb1Pry9yrP0dxrCI9RRci7RXKg==} engines: {node: '>= 6.0.0', npm: '>= 3.0.0'} @@ -13562,6 +13696,11 @@ packages: engines: {node: '>=0.10.0'} dev: false + /string-argv@0.3.2: + resolution: {integrity: sha512-aqD2Q0144Z+/RqG52NeHEkZauTAUWJO8c6yTftGJKO3Tja5tUgIfmIl6kExvhtxSDP7fXB6DvzkfMpCd/F3G+Q==} + engines: {node: '>=0.6.19'} + dev: true + /string-width@4.2.3: resolution: {integrity: sha512-wKyQRQpjJ0sIp62ErSZdGsjMJWsap5oRNihHhu6G7JVO/9jIB6UyevL+tXuOqrng8j/cxKTWyWUwvSTriiZz/g==} engines: {node: '>=8'} @@ -13587,6 +13726,15 @@ packages: strip-ansi: 7.1.0 dev: true + /string-width@7.1.0: + resolution: {integrity: sha512-SEIJCWiX7Kg4c129n48aDRwLbFb2LJmXXFrWBG4NGaRtMQ3myKPKbwrD1BKqQn74oCoNMBVrfDEr5M9YxCsrkw==} + engines: {node: '>=18'} + dependencies: + emoji-regex: 10.3.0 + get-east-asian-width: 1.2.0 + strip-ansi: 7.1.0 + dev: true + /string.prototype.trim@1.2.8: resolution: {integrity: sha512-lfjY4HcixfQXOfaqCvcBuOIapyaroTXhbkfJN3gcB1OtyupngWK4sEET9Knd0cXd28kTUqu/kHoV4HKSJdnjiQ==} engines: {node: '>= 0.4'} @@ -15020,6 +15168,15 @@ packages: string-width: 5.1.2 strip-ansi: 7.1.0 + /wrap-ansi@9.0.0: + resolution: {integrity: sha512-G8ura3S+3Z2G+mkgNRq8dqaFZAuxfsxpBB8OCTGRTCtp+l/v9nbFNmCUP1BZMts3G1142MsZfn6eeUKrr4PD1Q==} + engines: {node: '>=18'} + dependencies: + ansi-styles: 6.2.1 + string-width: 7.1.0 + strip-ansi: 7.1.0 + dev: true + /wrappy@1.0.2: resolution: {integrity: sha512-l4Sp/DRseor9wL6EvV2+TuQn63dMkPjZ/sp9XkghTEbV9KlPS1xUsZ3u7/IQO4wxtcFB4bgpQPRcR3QCvezPcQ==} @@ -15122,6 +15279,11 @@ packages: /yallist@4.0.0: resolution: {integrity: sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==} + /yaml@2.3.4: + resolution: {integrity: sha512-8aAvwVUSHpfEqTQ4w/KMlf3HcRdt50E5ODIQJBw1fQ5RL34xabzxtUlzTXVqc4rkZsPbvrXKWnABCD7kWSmocA==} + engines: {node: '>= 14'} + dev: true + /yargs-parser@18.1.3: resolution: {integrity: sha512-o50j0JeToy/4K6OZcaQmW6lyXXKhq7csREXcDwk2omFPJEwUNOVtJKvmDr9EI1fAJZUyZcRF7kxGBWmRXudrCQ==} engines: {node: '>=6'} diff --git a/support/index.d.ts b/support/index.d.ts index 4cf9717ae..3503a9208 100644 --- a/support/index.d.ts +++ b/support/index.d.ts @@ -276,8 +276,8 @@ declare namespace Cypress { * cy.confirmMetamaskPermissionToSpend({ spendLimit: '999999999', shouldWaitForPopupClosure: false }) */ confirmMetamaskPermissionToSpend(options: { - spendLimit?: string - shouldWaitForPopupClosure?: boolean + spendLimit?: string; + shouldWaitForPopupClosure?: boolean; }): Chainable; /** * Confirm metamask permission to access all elements (example: collectibles) @@ -339,19 +339,19 @@ declare namespace Cypress { confirmMetamaskTransaction(options: { gasConfig: | { - gasLimit?: number; - baseFee?: number; - priorityFee?: number; - } + gasLimit?: number; + baseFee?: number; + priorityFee?: number; + } | { - gasLimit?: number; - gasPrice?: number; - } + gasLimit?: number; + gasPrice?: number; + } | 'low' | 'market' | 'aggressive' - | 'site', - shouldWaitForPopupClosure?: boolean + | 'site'; + shouldWaitForPopupClosure?: boolean; }): Chainable; /** * Confirm metamask transaction (auto-detects eip-1559 and legacy transactions) and wait for ALL pending transactions to be mined diff --git a/synpress.js b/synpress.js index 4dac7d251..fdd515df9 100644 --- a/synpress.js +++ b/synpress.js @@ -3,7 +3,7 @@ const log = require('debug')('synpress:cli'); const program = require('commander'); const { run, open } = require('./launcher'); const { version } = require('./package.json'); -const SUPPORTED_EXTENSIONS = ['metamask', 'keplr'] +const SUPPORTED_EXTENSIONS = ['metamask', 'keplr']; if (process.env.DEBUG && process.env.DEBUG.includes('synpress')) { log('DEBUG mode is enabled'); diff --git a/tests/e2e/specs/keplr/playwright-spec.js b/tests/e2e/specs/keplr/playwright-spec.js index 6d0bc67b4..399c4b52f 100644 --- a/tests/e2e/specs/keplr/playwright-spec.js +++ b/tests/e2e/specs/keplr/playwright-spec.js @@ -1,41 +1,41 @@ describe('Playwright', () => { - context('Test commands', () => { - it(`initPlaywright should connect with cypress browser`, () => { - cy.initPlaywright().then(isConnected => { - expect(isConnected).to.be.true; - }); - }); - it(`assignActiveTabName should properly assign keplr tab as currently active and verify result using isKeplrWindowActive & isCypressWindowActive`, () => { - cy.assignActiveTabName('keplr'); - cy.isExtensionWindowActive().then(isActive => { - expect(isActive).to.be.true; - }); - cy.isCypressWindowActive().then(isActive => { - expect(isActive).to.be.false; - }); - }); - it(`assignWindows should properly assign cypress and keplr windows`, () => { - cy.assignWindows().then(assigned => { - expect(assigned).to.be.true; - }); - }); - it(`switchToCypressWindow should properly switch active tab to cypress window`, () => { - cy.switchToCypressWindow(); - cy.isCypressWindowActive().then(isActive => { - expect(isActive).to.be.true; - }); - cy.isExtensionWindowActive().then(isActive => { - expect(isActive).to.be.false; - }); - }); - it(`switchToExtensionWindow should properly switch active tab to keplr window`, () => { - cy.switchToExtensionWindow(); - cy.isExtensionWindowActive().then(isActive => { - expect(isActive).to.be.true; - }); - cy.isCypressWindowActive().then(isActive => { - expect(isActive).to.be.false; - }); + context('Test commands', () => { + it(`initPlaywright should connect with cypress browser`, () => { + cy.initPlaywright().then(isConnected => { + expect(isConnected).to.be.true; }); }); - }); \ No newline at end of file + it(`assignActiveTabName should properly assign keplr tab as currently active and verify result using isKeplrWindowActive & isCypressWindowActive`, () => { + cy.assignActiveTabName('keplr'); + cy.isExtensionWindowActive().then(isActive => { + expect(isActive).to.be.true; + }); + cy.isCypressWindowActive().then(isActive => { + expect(isActive).to.be.false; + }); + }); + it(`assignWindows should properly assign cypress and keplr windows`, () => { + cy.assignWindows().then(assigned => { + expect(assigned).to.be.true; + }); + }); + it(`switchToCypressWindow should properly switch active tab to cypress window`, () => { + cy.switchToCypressWindow(); + cy.isCypressWindowActive().then(isActive => { + expect(isActive).to.be.true; + }); + cy.isExtensionWindowActive().then(isActive => { + expect(isActive).to.be.false; + }); + }); + it(`switchToExtensionWindow should properly switch active tab to keplr window`, () => { + cy.switchToExtensionWindow(); + cy.isExtensionWindowActive().then(isActive => { + expect(isActive).to.be.true; + }); + cy.isCypressWindowActive().then(isActive => { + expect(isActive).to.be.false; + }); + }); + }); +}); diff --git a/tools/contract/package.json b/tools/contract/package.json index 3a53aca50..c3f1f0c37 100644 --- a/tools/contract/package.json +++ b/tools/contract/package.json @@ -72,14 +72,11 @@ "parserOptions": { "sourceType": "module", "ecmaVersion": 2021 - }, - "extends": [ - "@agoric" - ] + } }, "prettier": { "trailingComma": "all", "arrowParens": "avoid", "singleQuote": true } -} \ No newline at end of file +} diff --git a/tools/json-server-db.json b/tools/json-server-db.json index 061186462..8679d1b08 100644 --- a/tools/json-server-db.json +++ b/tools/json-server-db.json @@ -1,13 +1,12 @@ { - "agoric_chain":{ - "chainName": "agoriclocal", - "rpcAddrs": ["http://agoric_chain:26657"], - "dappInterJumperBanner": "A Chrome update is affecting some users' dapp-wallet connection. If you're affected by this issue, please use Brave with shields down until the fix completes." - }, - "localhost":{ - "chainName": "agoriclocal", - "rpcAddrs": ["http://localhost:26657"], - "dappInterJumperBanner": "A Chrome update is affecting some users' dapp-wallet connection. If you're affected by this issue, please use Brave with shields down until the fix completes." - } - -} \ No newline at end of file + "agoric_chain": { + "chainName": "agoriclocal", + "rpcAddrs": ["http://agoric_chain:26657"], + "dappInterJumperBanner": "A Chrome update is affecting some users' dapp-wallet connection. If you're affected by this issue, please use Brave with shields down until the fix completes." + }, + "localhost": { + "chainName": "agoriclocal", + "rpcAddrs": ["http://localhost:26657"], + "dappInterJumperBanner": "A Chrome update is affecting some users' dapp-wallet connection. If you're affected by this issue, please use Brave with shields down until the fix completes." + } +} diff --git a/tools/ui/package.json b/tools/ui/package.json index 19111626b..a34ad1bf6 100644 --- a/tools/ui/package.json +++ b/tools/ui/package.json @@ -49,4 +49,4 @@ "arrowParens": "avoid", "singleQuote": true } -} \ No newline at end of file +} diff --git a/tools/ui/tsconfig.json b/tools/ui/tsconfig.json index 7f545954a..3579097c7 100644 --- a/tools/ui/tsconfig.json +++ b/tools/ui/tsconfig.json @@ -20,8 +20,8 @@ "noUnusedParameters": true, "noFallthroughCasesInSwitch": true, - "types": ["vitest/globals"], + "types": ["vitest/globals"] }, "include": ["src", "test"], - "references": [{ "path": "./tsconfig.node.json" }], + "references": [{ "path": "./tsconfig.node.json" }] } From c64a952ffea8864217078ac344c09347a7ebe67d Mon Sep 17 00:00:00 2001 From: frazarshad Date: Mon, 11 Mar 2024 16:24:43 +0500 Subject: [PATCH 32/35] Enabled CI Pipeline for NPM deployment (#25) * feat: release workflow enabled * feat: added CI cache folders to .npmignore * chore: revert back to master after testing --- .github/workflows/{disabled => }/release.yml | 0 .npmignore | 3 +++ 2 files changed, 3 insertions(+) rename .github/workflows/{disabled => }/release.yml (100%) diff --git a/.github/workflows/disabled/release.yml b/.github/workflows/release.yml similarity index 100% rename from .github/workflows/disabled/release.yml rename to .github/workflows/release.yml diff --git a/.npmignore b/.npmignore index c4acaa9fd..c3078e393 100644 --- a/.npmignore +++ b/.npmignore @@ -1,6 +1,9 @@ +.git +.husky .github .env .dockerignore +.pnpm-store docker docs downloads From 96b238b48d35fd07347b672a11ba50f27b2040af Mon Sep 17 00:00:00 2001 From: frazarshad Date: Wed, 13 Mar 2024 17:52:47 +0500 Subject: [PATCH 33/35] Fix for switching between keplr windows with same url (#27) * fix: checking added for window instance * test: test added for edge case --- commands/playwright-keplr.js | 3 ++- tests/e2e/specs/keplr/keplr-spec.js | 10 ++++++++++ 2 files changed, 12 insertions(+), 1 deletion(-) diff --git a/commands/playwright-keplr.js b/commands/playwright-keplr.js index 2c2f42fcb..45b8e5e5f 100644 --- a/commands/playwright-keplr.js +++ b/commands/playwright-keplr.js @@ -340,7 +340,8 @@ module.exports = { if ( page .url() - .includes(`chrome-extension://${keplrExtensionData.id}/popup.html`) + .includes(`chrome-extension://${keplrExtensionData.id}/popup.html`) && + page !== keplrWindow ) { keplrNotificationWindow = page; retries = 0; diff --git a/tests/e2e/specs/keplr/keplr-spec.js b/tests/e2e/specs/keplr/keplr-spec.js index a2f9b1791..927c2d128 100644 --- a/tests/e2e/specs/keplr/keplr-spec.js +++ b/tests/e2e/specs/keplr/keplr-spec.js @@ -103,6 +103,16 @@ describe('Keplr', () => { expect(tokenValue).to.equal(331); }); }); + it(`should differntiate between keplrWindow and keplrNotificationWindow when they have the same URL`, () => { + cy.getTokenAmount('ATOM').then(tokenValue => { + expect(tokenValue).to.equal(0); + }); + + cy.contains('Make an Offer').click(); + cy.confirmTransaction().then(taskCompleted => { + expect(taskCompleted).to.be.true; + }); + }); it(`should disconnect the wallet from all the connected DAPPs`, () => { cy.disconnectWalletFromDapp().then(taskCompleted => { expect(taskCompleted).to.be.true; From f8bba0e489b782c53b3dffeedd5e05931383b022 Mon Sep 17 00:00:00 2001 From: frazarshad Date: Thu, 14 Mar 2024 11:17:04 +0500 Subject: [PATCH 34/35] fix: added click after timeout to resolve flakiness (#28) --- commands/keplr.js | 3 ++- commands/playwright-keplr.js | 2 +- 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/commands/keplr.js b/commands/keplr.js index 3fbaf11f3..47174ba01 100644 --- a/commands/keplr.js +++ b/commands/keplr.js @@ -333,8 +333,9 @@ const keplr = { await module.exports.goToHome(); } await playwright.waitAndClickByText(homePageElements.newTokensFound); - await playwright.waitAndClickWithRetry( + await playwright.waitAndClickWithDelay( homePageElements.selectAllTokensCheck, + 2000, { number: -1, force: true }, ); await playwright.waitAndClickByText( diff --git a/commands/playwright-keplr.js b/commands/playwright-keplr.js index 45b8e5e5f..1cfb79bbd 100644 --- a/commands/playwright-keplr.js +++ b/commands/playwright-keplr.js @@ -327,7 +327,7 @@ module.exports = { throw new Error(`Failed to click element after ${maxRetries} attempts`); }, - async waitAndClickWithDelay(selector, options, delay) { + async waitAndClickWithDelay(selector, delay, options) { const page = module.exports.keplrWindow(); await page.waitForTimeout(delay); await module.exports.waitAndClick(selector, page, options); From 0f62f8595947a6a9651132806578464bfffdff20 Mon Sep 17 00:00:00 2001 From: frazarshad Date: Thu, 14 Mar 2024 13:50:25 +0500 Subject: [PATCH 35/35] Updated README.md (#29) * docs: updated README.md * docs: added env section to readme * docs: 24 words memonics --- README.md | 496 ++++++------------------------------------------------ 1 file changed, 52 insertions(+), 444 deletions(-) diff --git a/README.md b/README.md index 832a9bab3..be37fe60b 100644 --- a/README.md +++ b/README.md @@ -1,191 +1,31 @@ -[![npm version](https://badge.fury.io/js/%40synthetixio%2Fsynpress.svg)](https://badge.fury.io/js/%40synthetixio%2Fsynpress) -![Synpress CI](https://github.com/Synthetixio/synpress/workflows/Synpress%20CI/badge.svg?branch=master) -[![CodeQL](https://github.com/Synthetixio/synpress/actions/workflows/codeql.yml/badge.svg?branch=master)](https://github.com/Synthetixio/synpress/actions/workflows/codeql.yml) -[![Release CI](https://github.com/Synthetixio/synpress/actions/workflows/release.yml/badge.svg?branch=master)](https://github.com/Synthetixio/synpress/actions/workflows/release.yml) -[![synpress](https://img.shields.io/endpoint?url=https://dashboard.cypress.io/badge/count/ohpeaz/master&style=flat&logo=cypress)](https://dashboard.cypress.io/projects/ohpeaz/runs) -[![Discord](https://img.shields.io/discord/1103781993394733136.svg?color=768AD4&label=discord&logo=https%3A%2F%2Fdiscordapp.com%2Fassets%2F8c9701b98ad4372b58f13fd9f65f966e.svg)](https://discord.gg/XhZKSRGtWc) -[![Twitter Follow](https://img.shields.io/twitter/follow/synpress_.svg?label=synpress&style=social)](https://twitter.com/synpress_) - -> **We're Hiring ๐ŸŽ‰** โ€” Think you have what it takes? We're looking for Software -> Engineer, -> [find out more](https://mirror.xyz/synpress.eth/FXhd5-7e7wBmYYtfmqkF0h7FhDBRUGuGF6j-D7jPpvM). - -# - -

- -

- Synpress - is E2E testing framework
based on Cypress - and Playwright - with support for MetaMask. -

-

- -

- Sponsored & used by:

- Synthetix - Optimism -

- -

- Power users:

- Phantom - Ethereum Name Service (ENS) - Kwenta -
- Panther Protocol - Guild - Aragon - Delvtech -
- Offchain Labs - Snapshot Labs - Hedera -

-

+[![npm version](https://badge.fury.io/js/@agoric%2Fsynpress.svg)](https://badge.fury.io/js/@agoric%2Fsynpress) +[![E2E (docker)](https://github.com/agoric-labs/synpress/actions/workflows/e2e_docker.yml/badge.svg?branch=master)](https://github.com/agoric-labs/synpress/actions/workflows/e2e_docker.yml) +[![Release CI](https://github.com/agoric-labs/synpress/actions/workflows/release.yml/badge.svg?branch=master)](https://github.com/agoric-labs/synpress/actions/workflows/release.yml) # -

- Synpress Demo -

- -Synpress makes sure to always use latest version of metamask and puts a lot of -effort to make sure that dapp tests are stable and trustful. - -It also provides an easy way to use and access metamask straight from your e2e -tests with all features of cypress and playwright. - -๐Ÿ”ฅ Synpress works out-of-the-box with other frameworks! There is no need to use -it directly. Check -[usage examples](https://github.com/Synthetixio/synpress/#usage-examples) for -more details. - -# โ™จ๏ธ New release - -โš ๏ธ This branch showcases the current stable release of Synpress which will receive **only** critical hotfixes. โš ๏ธ +`@agoric/synpress` is a testing framework designed to test DApps that use the Keplr Wallet. -Active development of the upcoming version of Synpress is happening on [this branch](https://github.com/Synthetixio/synpress/tree/new-dawn). -The new release is a full rewrite of Synpress and will feature major breaking changes, and multitude of new features and improvements across the board such as: -- โญ Full TypeScript support -- โญ Multi-wallet support -- โญ Full parallelism support -- โญ Test runtime speed **faster** than any other Web3 alternative, and **equal** to native Web2 frameworks - -Curious and want to learn more? ๐Ÿค“ - -[Read this Twitter thread ๐Ÿงต](https://twitter.com/0xDuckception/status/1712961542176596054) and do not forget to check out the attached document there! - -# Table of content - -- [](#) -- [](#-1) -- [Table of content](#table-of-content) - - [๐Ÿง‘โ€๐Ÿคโ€๐Ÿง‘ Community](#-community) - - [๐Ÿ–ฅ๏ธ Install](#๏ธ-install) - - [โš™๏ธ Supported frameworks](#๏ธ-supported-frameworks) - - [๐Ÿ‘ Supported wallets](#-supported-wallets) - - [โœ๏ธ Usage examples:](#๏ธ-usage-examples) - - [๐ŸŒŸ Features](#-features) - - [๐Ÿ‘ท Example setup for eslint and tsconfig](#-example-setup-for-eslint-and-tsconfig) - - [โšก Important notes](#-important-notes) - - [๐Ÿณ Using with Docker](#-using-with-docker) - - [Requirements](#requirements) - - [Some neat features](#some-neat-features) - - [How to run e2e tests for Synpress using Docker](#how-to-run-e2e-tests-for-synpress-using-docker) - - [๐Ÿ’โ€โ™‚๏ธ CI tips \& tricks](#๏ธ-ci-tips--tricks) - - [๐Ÿงช Usage \& commands](#-usage--commands) - - [๐Ÿ“ƒ Environmental variables](#-environmental-variables) - - [๐Ÿšข Release process](#-release-process) - - [๐Ÿ“ More resources](#-more-resources) - -## ๐Ÿง‘โ€๐Ÿคโ€๐Ÿง‘ Community - -- [Discord](https://discord.gg/XhZKSRGtWc) => for **live support** and direct - chat with devs. -- [Twitter](https://twitter.com/synpress_) => for updates and announcements. +For full commands and their examples, +[check here](https://github.com/agoric-labs/synpress/blob/master/support/index.d.ts). ## ๐Ÿ–ฅ๏ธ Install ```bash # with pnpm -pnpm add --save-dev @synthetixio/synpress +pnpm add --save-dev @agoric/synpress # with npm -npm install --save-dev @synthetixio/synpress +npm install --save-dev @agoric/synpress # with yarn -yarn add -D @synthetixio/synpress +yarn add -D @agoric/synpress ``` -## โš™๏ธ Supported frameworks - -- [Synpress](https://github.com/Synthetixio/synpress) -- [Playwright](https://playwright.dev/) (as a plugin) -- [Cypress](https://github.com/cypress-io/cypress) (as a plugin) - ## ๐Ÿ‘ Supported wallets -- [MetaMask](https://metamask.io/) - -## โœ๏ธ Usage examples: - -- [โญ Synpress examples](https://github.com/drptbl/synpress-examples/) -- [Synpress e2e tests](https://github.com/Synthetixio/synpress/tree/dev/tests/e2e) - ---- +- [Keplr](https://www.keplr.app) +- [MetaMask](https://metamask.io/) (Currently in alpha) -For full Synpress commands and their examples, -[check here](https://github.com/Synthetixio/synpress/blob/dev/docs/synpress-commands.md). - -To see in which direction Synpress is headed to, take a look at -[planning board](https://github.com/orgs/Synthetixio/projects/14). - -## ๐ŸŒŸ Features - -- Added support for metamask ๐ŸฆŠ -- Supports headless mode ๐Ÿค– (`synpress run --headless`) - - Recommended for local development (but - [not for CI yet](https://developer.chrome.com/articles/new-headless/) as - it's new and experimental) -- Integrated with - [Docker ๐Ÿณ](https://github.com/Synthetixio/synpress#-using-with-docker) - - Recommended for - [CI](https://github.com/Synthetixio/synpress#ci-tips--tricks) - - Includes VNC and [noVNC](https://novnc.com/info.html) - - Integrated video recording ๐ŸŽฅ (full screen) - - Exposes noVNC with [ngrok](https://ngrok.com/) (optional) -- Easy to debug ๐Ÿ› - - Improved error handling - - Supports [cypress](https://docs.cypress.io/guides/guides/debugging) and - [playwright](https://playwright.dev/docs/debug) debuggers - - noVNC allows for interactions through browser ๐ŸŒ - - Debug remote machines on CI with ngrok -- Blazingly-fast โšก -- Extensible โš™๏ธ (add own custom commands and plugins) -- Can be used in existing - [Cypress setup](https://github.com/Synthetixio/synpress/issues/346#issuecomment-1060506096) -- Supports dotenv - - Loads all env vars from your `.env` file automatically (from project root - folder) -- Ability to use latest metamask or lock it's version to avoid unexpected - failures related to metamask updates -- Supports multi-lang of metamask, it doesn't depend on any labels -- Synpress is - [fully tested](https://github.com/Synthetixio/synpress/tree/dev/tests/e2e/specs) -- Waits for XHR requests, navigations and animations automatically -- Ability to fail test run if there are any browser console errors found -- Types support for all additional custom commands -- The best possible options set up in place to avoid flakiness -- Etherscan API helpers in place which for ex. allows to compare your - transaction results with etherscan and check tx status -- Synthetix helpers in place which allows to interact with synthetix protocol - programmatically -- Supports codespaces - - Run your tests in docker - - Get your feedback remotely thanks to ngrok - - Use mpeg-4 preview plugin to watch videos from inside codespaces :) ... - -## ๐Ÿ‘ท Example setup for eslint and tsconfig +## ๐Ÿ‘ท Example setup Project structure: @@ -196,11 +36,8 @@ project_dir โ””โ”€โ”€ e2e โ””โ”€โ”€ .eslintrc.js โ””โ”€โ”€ support.js - โ””โ”€โ”€ tsconfig.json โ””โ”€โ”€ specs โ””โ”€โ”€ example-spec.js - โ””โ”€โ”€ pages - โ””โ”€โ”€ example-page.js ``` 1. Create `.eslintrc.js` inside your tests folder (`/project_dir/tests/e2e`): @@ -209,7 +46,7 @@ project_dir const path = require('path'); const synpressPath = path.join( process.cwd(), - '/node_modules/@synthetixio/synpress', + '/node_modules/@agoric/synpress', ); module.exports = { @@ -220,301 +57,72 @@ module.exports = { 2. Create `support.js` inside your tests folder (`/project_dir/tests/e2e`): ```js -import '@synthetixio/synpress/support/index'; +import '@agoric/synpress/support/index'; ``` _^ hint: you can also use this file to extend synpress - add custom commands, and more.._ -3. Create `tsconfig.json` inside your tests folder (`/project_dir/tests/e2e`): - +3. Add a command to your package.json file ```json { - "compilerOptions": { - "allowJs": true, - "baseUrl": "../../node_modules", - "types": [ - "cypress", - "@synthetixio/synpress/support", - "cypress-wait-until", - "@testing-library/cypress" - ], - "outDir": "./output" - }, - "include": ["**/*.*"] + ... + "scripts": { + ... + "test:e2e": "EXTENSION=keplr synpress run" + } } ``` -4. You're done! ๐ŸŽ‰ - -To change specific values in default config, you can use `--config` flag. For -example, to change path for `support.js` file, you can use -`synpress run --config "supportFile=__tests__/e2e/supportFile.js"` - -If you would like to use custom paths for your tests and configs, you should -[mirror (full) default synpress config](https://github.com/Synthetixio/synpress/blob/dev/synpress.config.js) -and then modify it for your needs. Then you can direct synpress to use it with -`--configFile` flag. - -For example: `synpress run --configFile __tests__/e2e/customConfig.config.js` - -## โšก Important notes - -Synpress doesn't seem to communicate with metamask properly if -`"chromeWebSecurity": false` flag is set. More about it -[here](https://github.com/Synthetixio/synpress/issues/17). - -Thanks to -[new headless mode in Chrome](https://developer.chrome.com/articles/new-headless/), -tests are now working in headless mode ๐Ÿค– (`synpress run --headless`). However, -I recommend to use it only for local development as this feature is new and -experimental and may cause issues on CI (UNIX). So please, stick to non-headless -mode on CI. - -In the past, tests worked only in non-headless mode because extensions were not -supported in headless mode by -[playwright](https://playwright.dev/docs/chrome-extensions) and -[Cypress](https://docs.cypress.io/api/plugins/browser-launch-api.html#Add-browser-extensions). -As a workaround, we've provided Docker ๐Ÿณ containers. They solved this issue and -it's an alternative. - -You have to setup `xvfb` and window manager (like `fluxbox` or `xfce4`) to run -tests without issues on CI (together with `DISPLAY` env var). Take a look at -[CI tips & tricks](https://github.com/Synthetixio/synpress/tree/dev/.github/workflows) -for working examples. - -There is a global -[`before()`](https://github.com/synthetixio/synpress/blob/dev/support/index.js#L27) -which runs metamask setup before all tests: - -- passes welcome page -- imports wallet -- changes network (defaults to `goerli`) or creates custom network and changes - to it (depending on your setup) -- switches back to Cypress window and starts testing - -It requires environmental variable called `SECRET_WORDS` to be present in -following format => `'word1 word2 word3 ..'` (delimited with spaces) or private -key in an environmental variable called `PRIVATE_KEY`. - -To change default network (`goerli`), you can use `NETWORK_NAME` environmental -variable, for example: `NETWORK_NAME=sepolia`. - -Available choices are: `mainnet`, `goerli`, `sepolia` and `localhost`. - -To create and switch to custom network at metamask setup phase, use these: - -1. `NETWORK_NAME` => ex: `synthetix` -2. `RPC_URL` => ex: `https://synthetix-node.io` -3. `CHAIN_ID` => ex: `123` -4. `SYMBOL` => ex: `SNX` -5. `BLOCK_EXPLORER` (optional) => ex: `https://synthetix-explorer.io` -6. `IS_TESTNET` (optional) => ex: `false` - -Metamask version is hardcoded and frequently updated under supervision to avoid -a case when e2e tests break because of CSS classes changes in new version, so -all you need is to keep synpress updated in your project. However, you can still -override metamask with `METAMASK_VERSION` environmental variable, for example: -`METAMASK_VERSION=10.21.0` or `METAMASK_VERSION=latest`. - -If you don't want to use environmental variables, you can modify -[`setupMetamask()`](https://github.com/synthetixio/synpress/blob/dev/support/index.js#L29) -to following: - -`setupMetamask(secretWordsOrPrivateKey, network, password)`, for example: -`setupMetamask('word1 word2 word3 ..', 'mainnet', 'password')` (delimited with -spaces). - -You can also add and switch to custom network by passing an `object` instead of -`string` inside `setupMetamask(secretWordsOrPrivateKey, network, password)` -function for `network` parameter. - -If you want to use Etherscan API helpers, you will have to provide Etherscan API -key using `ETHERSCAN_KEY` environmental variable. - -To fail a test if there are any browser console errors, set `FAIL_ON_ERROR` to -`1` or `true`. - -Automatic waiting for XHR requests to finish before tests start can be turned on -with `CYPRESS_RESOURCES_WAIT` environmental variable, set it to `1` or `true`. - -If you want to skip metamask extension installation or metamask setup, you can -use `SKIP_METAMASK_INSTALL` and `SKIP_METAMASK_SETUP` separately. Both variables -accept `1` or `true`. - -Synpress is blazingly-fast โšก by default! If you want to change that, you can -use `STABLE_MODE=true` (which will introduce delays only between main actions, -300ms by default) / `STABLE_MODE=` or `SLOW_MODE=true` (which will -introduce delay between every action, 50ms by default) / `SLOW_MODE=`. - -`DEBUG=synpress:*` is very useful while debugging your tests. It enables -following features: - -- improved logging -- [Cypress debugger](https://docs.cypress.io/guides/guides/debugging) -- [Playwright debugger](https://playwright.dev/docs/debug) -- slow down tests - -You may encounter 403 errors (on shared IPs & CI) related to rate limiting while -fetching metamask releases from GitHub REST API. This should never happen at -all, but it's good to mention. To prevent it from happening, you can create new -private access token on GitHub (without any additional access) and specify -`GH_USERNAME` & `GH_PAT` environmental variables. - -## ๐Ÿณ Using with Docker - -Docker is awesome for CI. Give it a try. - -### Requirements - -- [docker](https://www.docker.com/) -- [docker-compose](https://docs.docker.com/compose/install/) - -### Some neat features - -- based on [docker-e2e](https://github.com/Synthetixio/docker-e2e) โค -- full screen video recording ๐ŸŽฅ (together with metamask extension) -- VNC & noVNC support ๐Ÿ–ฅ๏ธ (very easy to debug with browser) - - local: http://localhost:8080/vnc.html?autoconnect=true -- ngrok ๐Ÿ”Œ integration (exposes noVNC for everyone) - - remote: https://.ngrok.io/vnc.html?autoconnect=true (check logs for - url) - -### How to run e2e tests for Synpress using Docker - -1. `git clone git@github.com:Synthetixio/synpress.git` -2. `cd synpress` -3. (optional) Fill env vars inside `.env` file -4. (with foundry; preferred) - `docker-compose --profile synpress --profile foundry up --build --exit-code-from synpress` - or `./start-tests.sh` - - (without foundry) - `docker-compose up --profile synpress --build --exit-code-from synpress` -5. (with foundry and ngrok) - `docker-compose --profile synpress --profile foundry --profile ngrok up --build --exit-code-from synpress` - -All examples of setup are present in this repository. Just take a look around. - -## ๐Ÿ’โ€โ™‚๏ธ CI tips & tricks - -- Check out many different examples for GitHub Actions - [in this repository](https://github.com/Synthetixio/synpress/tree/dev/.github/workflows): - - [e2e_headful.yml](https://github.com/Synthetixio/synpress/blob/dev/.github/workflows/e2e_headful.yml) - => runs on `ubuntu-latest`. - - [e2e_debug.yml](https://github.com/Synthetixio/synpress/blob/dev/.github/workflows/e2e_debug.yml) - => runs on `ubuntu-latest`, has configured VNC, noVNC and ngrok for easy - debugging. - - [e2e_docker.yml](https://github.com/Synthetixio/synpress/blob/dev/.github/workflows/e2e_docker.yml) - => runs on `ubuntu-latest` with `docker compose` stack. - - [e2e_cypress-action.yml](https://github.com/Synthetixio/synpress/blob/dev/.github/workflows/e2e_cypress-action.yml) - => runs on `ubuntu-latest`, using official - [cypress-io/github-action](https://github.com/cypress-io/github-action). -- You can find examples for GitLab CI => - [here](https://gitlab.com/synpress/synpress-demo#synpress-gitlab-demo). -- Use [docker-e2e](https://github.com/Synthetixio/docker-e2e) -- Synpress is tested and should work on all resolutions, starting from 800x600 - -## ๐Ÿงช Usage & commands - -- `synpress run` to run tests -- `synpress open` to open Cypress UI (may be bugged in some cases because it - doesn't clear metamask state before each e2e test, please use `synpress run`) - -Command line interface (`synpress help`): - -```text -Usage: synpress run [options] - -launch tests - -Options: - -b, --browser run on specified browser (default: "chrome") - -c, --config set configuration values, separate multiple values with a comma - -cf, --configFile specify a path to *.js file where configuration values are set - -e, --env set environment variables, separate multiple values with comma - -s, --spec run only provided spec files - -ne, --noExit keep runner open after tests finish - -pr, --project run with specific project path - -q, --quiet only test runner output in console - -r, --reporter specify mocha reporter - -ro, --reporterOptions specify mocha reporter options, separate multiple values with comma - -r, --record [dashboard] record video of tests running after setting up your project to record - -k, --key [dashboard] set record key - -p, --parallel [dashboard] run recorded specs in parallel across multiple machines - -g, --group [name] [dashboard] group recorded tests together under a single run - -t, --tag [dashboard] add tags to dashboard for test run - -h, --help display help for command +4. **(Optional)** Create a custom config file. @agoric/synpress aleardy has some configurations set up in this [file](https://github.com/agoric-labs/synpress/blob/master/synpress.config.js). To override this and add your custom config, you can create your own config file `synpress.config.js` in `/project_dir/tests/e2e` +```js +const baseConfig = require('@agoric/synpress/synpress.config'); +const { defineConfig } = require('cypress'); + +module.exports = defineConfig({ + ...baseConfig, + e2e: { + ...baseConfig.e2e, + baseUrl: 'http://localhost:5173', + }, +}); ``` +        +use this config by passing the `--configFile` flag to synpress +```json +{ + ... + "scripts": { + ... + "test:e2e": "EXTENSION=keplr synpress run --configFile=test/e2e/synpress.config.js" + } +} -```text -Usage: synpress open [options] - -launch test runner UI - -Options: - -cf, --configFile specify a path to *.js file where configuration values are set - -h, --help display help for command ``` -## ๐Ÿ‘จโ€โš•๏ธ Known problems with MetaMask -If your MetaMask is stuck on the loading screen, check what's happening under the hood in the console. You can find vital information about why it's stuck on this step. +5. You're done! ๐ŸŽ‰ -#### โญ Sentry.io HTTP error 499 (Request has been forbidden by antivirus) +
-- Kaspersky antivirus sometimes blocks encrypted requests to Sentry.io. You can disable - this feature in Kaspersky advanced settings by toggling on `"Do not scan encrypted connections"`. +For an example project, you can take a look at how we've set up tests in this [repository](https://github.com/agoric-labs/synpress/tree/dev/tests/e2e) ## ๐Ÿ“ƒ Environmental variables | Variable | Description | | ----------------------- | ----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | -| `SECRET_WORDS` | Space separated words for the test wallet recovery phrase (mnemonic; 12 words) | +| `EXTENSION` (Required) | Picks which extension to use during tests. `keplr` and `metamask` are the only possible values | +| `SECRET_WORDS` | Space separated words for the test wallet recovery phrase (mnemonic; 24 words) | | `PRIVATE_KEY` | Test wallet private key | -| `NETWORK_NAME` | Network name (eg `NETWORK_NAME=Optimism`) | -| `RPC_URL` | Network RPC (eg`RPC_URL=https://mainnet.optimism.io`) | -| `CHAIN_ID` | Network ID (eg`CHAIN_ID=10`) | -| `SYMBOL` | Native chain token ticker (eg `SYMBOL=OP`) | -| `IS_TESTNET` | `boolean` indicates that the added network is testnet | -| `BLOCK_EXPLORER` | Blockchain explorer (eg `BLOCK_EXPLORER=https://optimistic.etherscan.io/`) | | `SYNDEBUG` | Set debugging mode to be on | | `STABLE_MODE` | Introduce delay between main actions, 300ms by default (eg `STABLE_MODE=300ms`, `STABLE_MODE=true`) | | `SLOW_MODE` | Introduce delay between every action, 50ms by default (eg `SLOW_MODE=true`, `SLOW_MODE=200ms`) | -| `METAMASK_VERSION` | Metamask version to be installed | -| `SKIP_METAMASK_INSTALL` | Will skip MetaMask installation | -| `SKIP_METAMASK_SETUP` | Will skip MetaMask initial setup | -| `GH_USERNAME` | GitHub username (used to avoid rate-limit issues while downloading Metamask) | -| `GH_PAT` | GitHub [personal access token](https://docs.github.com/en/authentication/keeping-your-account-and-data-secure/creating-a-personal-access-token) (used to avoid rate-limit issue while downloading metamask) | -| `ETHERSCAN_KEY` | [Etherscan key](https://info.etherscan.com/etherscan-developer-api-key/) (used only for etherscan-related commands) | -| `FAIL_ON_ERROR` | Fail a test if there are any browser console errors | -| `CYPRESS_GROUP` | [Group tests](https://docs.cypress.io/guides/guides/command-line#cypress-run-group-lt-name-gt) | -| `CI` | Boolean value indicates that tests are running from CI/CD pipeline | - -## ๐Ÿšข Release process - -1. Create PR from `dev` branch to `master` branch -2. Merge it (new `-beta` version is automatically released) -3. Run GitHub Action workflow named - [Release CI](https://github.com/Synthetixio/synpress/actions/workflows/release.yml) - with `patch|minor|major` depending on your needs to promote your build. - -Alternatively, instead of running GitHub Action for release, you can move on -with manual release process: - -1. Switch to `master` branch and pull latest changes -2. Run `pnpm release:patch/minor/major` command -3. Keep `dev` branch up to date with `master` - -Above actions will lead to: +| `KEPLR_VERSION` | Keplr version to be installed | +| `SKIP_KEPLR_INSTALL` | Will skip installation of keplr wallet | +| `SKIP_EXTENSION_SETUP` | Will skip initial setup of wallet | -- New npm node module release -- New GitHub packages node module release -- New GitHub release (tagged) created with changelog from commit messages +These is a basic list of environment variables to be used. A more in depth list can be found [here](https://github.com/Synthetixio/synpress#-environmental-variables) ## ๐Ÿ“ More resources -- [End-to-end testing using Synpress](https://klaytn.foundation/synpress-setup-tutorial/) -- [Synpress - web3-enabled e2e testing tool](https://gitcoin.co/grants/5699/synpress-web3-enabled-e2e-testing-tool) -- [How to set up Synpress for Web3 dApp Frontend Test Automation with MetaMask](https://medium.com/andamp/how-to-setup-synpress-for-wen3-dapp-frontend-test-automation-with-metamask-73396896684a) -- [Extending Synpress with additional MetaMask commands](https://medium.com/andamp/extending-synpress-with-additional-metamask-commands-fdc6b35a2ffc) -- [Test e2e login to dApp with Metamask with Synpress](https://medium.com/coinmonks/test-e2e-login-to-dapp-with-metamask-with-synpress-5248dd1f17c1) +`@agoric/synpress` uses Synpress as its base and therefore supports most of its functionality. To learn more about command line options, usage examples, and CI/CD setup, you can use the original [README file](https://github.com/Synthetixio/synpress/blob/dev/README.md) \ No newline at end of file