From b80c4251715f8f4e4258f4b7d07b00479d10c1b8 Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Wed, 13 Mar 2024 10:18:37 +0100 Subject: [PATCH 01/44] update readme --- packages/sdk/README.md | 26 ++++++++++++++++++++++++++ 1 file changed, 26 insertions(+) diff --git a/packages/sdk/README.md b/packages/sdk/README.md index 83224cc7..71fd7f49 100644 --- a/packages/sdk/README.md +++ b/packages/sdk/README.md @@ -118,3 +118,29 @@ To create a release version run: ```bash npm run changeset ``` + +# Testing the change in the SDK locally + +Build the project: + +```bash +npm run build +``` + +```bash +npm link +``` + +In your project where you would like to test the changes: + +```bash +npm link @moonbeam-network/xcm-sdk +``` + +If you need you can link other packages too. + +After testing is done, unlink the SDK: + +```bash +npm unlink @moonbeam-network/xcm-sdk +``` From 4b1e0278a1f4c4d567fdd34aae95ccee11056f84 Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Wed, 13 Mar 2024 17:07:13 +0100 Subject: [PATCH 02/44] add function to get chain balances by address --- .../sdk/src/getTransferData/getSourceData.ts | 60 ++++++++++++++++++- .../getTransferData/getTransferData.utils.ts | 26 +++++--- packages/sdk/src/sdk.ts | 40 ++++++++++++- 3 files changed, 116 insertions(+), 10 deletions(-) diff --git a/packages/sdk/src/getTransferData/getSourceData.ts b/packages/sdk/src/getTransferData/getSourceData.ts index 8f26d8c9..bdea97f0 100644 --- a/packages/sdk/src/getTransferData/getSourceData.ts +++ b/packages/sdk/src/getTransferData/getSourceData.ts @@ -4,7 +4,11 @@ import { ExtrinsicConfig, SubstrateQueryConfig, } from '@moonbeam-network/xcm-builder'; -import { FeeAssetConfig, TransferConfig } from '@moonbeam-network/xcm-config'; +import { + AssetConfig, + FeeAssetConfig, + TransferConfig, +} from '@moonbeam-network/xcm-config'; import { AnyChain, AssetAmount } from '@moonbeam-network/xcm-types'; import { convertDecimals, toBigInt } from '@moonbeam-network/xcm-utils'; import Big from 'big.js'; @@ -323,3 +327,57 @@ export function getMax({ amount: result.lt(0) ? 0n : BigInt(result.toFixed()), }); } + +export interface GetAssetsBalancesParams { + address: string; + chain: AnyChain; + assets: AssetConfig[]; + evmSigner?: EvmSigner; + polkadot: PolkadotService; +} + +export async function getAssetsBalances({ + address, + chain, + assets, + evmSigner, + polkadot, +}: GetAssetsBalancesParams) { + const assetToTest = assets[0]; + + console.log( + '\x1b[34m████████████████████▓▓▒▒░ getSourceData.ts:344 ░▒▒▓▓████████████████████\x1b[0m', + ); + console.log('* assetToTest = '); + console.log(assetToTest); + console.log( + '\x1b[34m▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄\x1b[0m', + ); + + const decimals = await getDecimals({ + address, + asset: assetToTest.asset, + chain, + config: assetToTest, + evmSigner, + polkadot, + }); + + const balance = await getBalance({ + address, + chain, + config: assets[0], + decimals, + evmSigner, + polkadot, + }); + + console.log( + '\x1b[34m████████████████████▓▓▒▒░ getSourceData.ts:375 ░▒▒▓▓████████████████████\x1b[0m', + ); + console.log('* balance = '); + console.log(balance); + console.log( + '\x1b[34m▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄\x1b[0m', + ); +} diff --git a/packages/sdk/src/getTransferData/getTransferData.utils.ts b/packages/sdk/src/getTransferData/getTransferData.utils.ts index d6fac4f8..e3e55537 100644 --- a/packages/sdk/src/getTransferData/getTransferData.utils.ts +++ b/packages/sdk/src/getTransferData/getTransferData.utils.ts @@ -18,14 +18,24 @@ export interface GetBalancesParams { export type GetDecimalsParams = Omit; -export async function getBalance({ - address, - chain, - config, - decimals, - evmSigner, - polkadot, -}: GetBalancesParams) { +export async function getBalance(params: GetBalancesParams) { + const { address, chain, config, decimals, evmSigner, polkadot } = params; + + // address: "5CezZTdwzytCEAxMvXbXkxf9cxErweUWfGUH9aTHnZsmSyrG" my wallet + // chain is the chain object Polkadot or HydraDX from sdk + // polkadot is ApiPROvider polkadot + + // pirnt config object class name + + // console.log( + // '\x1b[34m████████████████████▓▓▒▒░ getTransferData.utils.ts:24 ░▒▒▓▓████████████████████\x1b[0m', + // ); + // console.log('* params = '); + // console.log(params); + // console.log( + // '\x1b[34m▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄\x1b[0m', + // ); + const cfg = config.balance.build({ address, asset: polkadot.chain.getBalanceAssetId(config.asset), diff --git a/packages/sdk/src/sdk.ts b/packages/sdk/src/sdk.ts index 76701b88..2ebb500b 100644 --- a/packages/sdk/src/sdk.ts +++ b/packages/sdk/src/sdk.ts @@ -5,8 +5,10 @@ import { IConfigService, } from '@moonbeam-network/xcm-config'; import { AnyChain, Asset, Ecosystem } from '@moonbeam-network/xcm-types'; +import { getAssetsBalances } from './getTransferData/getSourceData'; import { getTransferData as gtd } from './getTransferData/getTransferData'; -import { Signers, TransferData } from './sdk.interfaces'; +import { PolkadotService } from './polkadot'; +import { EvmSigner, Signers, TransferData } from './sdk.interfaces'; export interface SdkOptions extends Partial { configService?: IConfigService; @@ -83,6 +85,42 @@ export function Sdk(options?: SdkOptions) { }; } +export async function getParachainBalances( + chain: AnyChain, + address: string, + evmSigner?: EvmSigner, +): Promise { + const configService = new ConfigService(); + const chainsConfig = configService.getChainConfig(chain); + const assets = chainsConfig.getAssetsConfigs(); + + const polkadot = await PolkadotService.create(chain, configService); + + // address, + // chain, + // assets, + // evmSigner, + // polkadot, + const balances = await getAssetsBalances({ + chain, + assets, + address, + evmSigner, + polkadot, + }); + + console.log( + '\x1b[34m████████████████████▓▓▒▒░ sdk.ts:112 ░▒▒▓▓████████████████████\x1b[0m', + ); + console.log('* balances = '); + console.log(balances); + console.log( + '\x1b[34m▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄\x1b[0m', + ); + + return []; +} + export interface SdkTransferParams extends Partial { destinationAddress: string; destinationKeyOrChain: string | AnyChain; From 3ace99b31a8b5f1148b0b079ed110061b56553f3 Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Thu, 14 Mar 2024 09:48:05 +0100 Subject: [PATCH 03/44] --wip-- [skip ci] --- .../sdk/src/getTransferData/getSourceData.ts | 78 +++++++++++-------- .../getTransferData/getTransferData.utils.ts | 34 ++++---- packages/sdk/src/sdk.ts | 16 +--- 3 files changed, 61 insertions(+), 67 deletions(-) diff --git a/packages/sdk/src/getTransferData/getSourceData.ts b/packages/sdk/src/getTransferData/getSourceData.ts index bdea97f0..3b36e552 100644 --- a/packages/sdk/src/getTransferData/getSourceData.ts +++ b/packages/sdk/src/getTransferData/getSourceData.ts @@ -343,41 +343,55 @@ export async function getAssetsBalances({ evmSigner, polkadot, }: GetAssetsBalancesParams) { - const assetToTest = assets[0]; + const result = []; - console.log( - '\x1b[34m████████████████████▓▓▒▒░ getSourceData.ts:344 ░▒▒▓▓████████████████████\x1b[0m', - ); - console.log('* assetToTest = '); - console.log(assetToTest); - console.log( - '\x1b[34m▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄\x1b[0m', + const uniqueAssets = assets.reduce( + (acc: AssetConfig[], asset: AssetConfig) => { + if (!acc.some((a: AssetConfig) => a.asset.isEqual(asset.asset))) { + return [asset, ...acc]; + } + + return acc; + }, + [], ); - const decimals = await getDecimals({ - address, - asset: assetToTest.asset, - chain, - config: assetToTest, - evmSigner, - polkadot, - }); + // eslint-disable-next-line no-restricted-syntax + for (const asset of uniqueAssets) { + try { + console.log(asset); - const balance = await getBalance({ - address, - chain, - config: assets[0], - decimals, - evmSigner, - polkadot, - }); + // eslint-disable-next-line no-await-in-loop + const decimals = await getDecimals({ + address, + asset: asset.asset, + chain, + config: asset, + evmSigner, + polkadot, + }); - console.log( - '\x1b[34m████████████████████▓▓▒▒░ getSourceData.ts:375 ░▒▒▓▓████████████████████\x1b[0m', - ); - console.log('* balance = '); - console.log(balance); - console.log( - '\x1b[34m▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄\x1b[0m', - ); + // eslint-disable-next-line no-await-in-loop + const balance = await getBalance({ + address, + chain, + config: asset, + decimals, + evmSigner, + polkadot, + }); + + result.push({ balance, asset: asset.asset }); + } catch (error) { + console.log( + '\x1b[34m████████████████████▓▓▒▒░ getSourceData.ts:406 ░▒▒▓▓████████████████████\x1b[0m', + ); + console.log('* error = '); + console.log(error); + console.log( + '\x1b[34m▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄\x1b[0m', + ); + } + } + return result; } diff --git a/packages/sdk/src/getTransferData/getTransferData.utils.ts b/packages/sdk/src/getTransferData/getTransferData.utils.ts index e3e55537..cd9c1fb8 100644 --- a/packages/sdk/src/getTransferData/getTransferData.utils.ts +++ b/packages/sdk/src/getTransferData/getTransferData.utils.ts @@ -18,24 +18,14 @@ export interface GetBalancesParams { export type GetDecimalsParams = Omit; -export async function getBalance(params: GetBalancesParams) { - const { address, chain, config, decimals, evmSigner, polkadot } = params; - - // address: "5CezZTdwzytCEAxMvXbXkxf9cxErweUWfGUH9aTHnZsmSyrG" my wallet - // chain is the chain object Polkadot or HydraDX from sdk - // polkadot is ApiPROvider polkadot - - // pirnt config object class name - - // console.log( - // '\x1b[34m████████████████████▓▓▒▒░ getTransferData.utils.ts:24 ░▒▒▓▓████████████████████\x1b[0m', - // ); - // console.log('* params = '); - // console.log(params); - // console.log( - // '\x1b[34m▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄\x1b[0m', - // ); - +export async function getBalance({ + address, + chain, + config, + decimals, + evmSigner, + polkadot, +}: GetBalancesParams) { const cfg = config.balance.build({ address, asset: polkadot.chain.getBalanceAssetId(config.asset), @@ -49,7 +39,9 @@ export async function getBalance(params: GetBalancesParams) { } if (!evmSigner) { - throw new Error('Evm signer must be provided'); + throw new Error( + `getBalance: Evm signer must be provided. Asset: ${config.asset.key}`, + ); } const contract = createContract(cfg, evmSigner) as BalanceContractInterface; @@ -74,7 +66,9 @@ export async function getDecimals({ } if (!evmSigner) { - throw new Error('Evm signer must be provided'); + throw new Error( + `getDecimals: Evm signer must be provided. Asset: ${asset?.key}`, + ); } const contract = createContract(cfg, evmSigner) as BalanceContractInterface; diff --git a/packages/sdk/src/sdk.ts b/packages/sdk/src/sdk.ts index 2ebb500b..ba57ea63 100644 --- a/packages/sdk/src/sdk.ts +++ b/packages/sdk/src/sdk.ts @@ -96,11 +96,6 @@ export async function getParachainBalances( const polkadot = await PolkadotService.create(chain, configService); - // address, - // chain, - // assets, - // evmSigner, - // polkadot, const balances = await getAssetsBalances({ chain, assets, @@ -109,16 +104,7 @@ export async function getParachainBalances( polkadot, }); - console.log( - '\x1b[34m████████████████████▓▓▒▒░ sdk.ts:112 ░▒▒▓▓████████████████████\x1b[0m', - ); - console.log('* balances = '); - console.log(balances); - console.log( - '\x1b[34m▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄\x1b[0m', - ); - - return []; + return balances; } export interface SdkTransferParams extends Partial { From b62f4914617fe14495d2a9d701e7238b170c8af8 Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Thu, 14 Mar 2024 15:37:38 +0100 Subject: [PATCH 04/44] add logic to get tokens balances for chain and address, change getBalance and getDecimals to work without signer --- package-lock.json | 12 +++-- .../builder/fixtures/builderParamsMock.ts | 5 ++ packages/config/package.json | 3 +- .../src/ConfigService/ConfigService.test.ts | 5 ++ packages/config/src/chains.ts | 36 +++++++++++++ packages/sdk/src/contract/contract.factory.ts | 13 +++++ .../contract/contracts/Erc20/Erc20Public.ts | 46 +++++++++++++++++ .../sdk/src/getTransferData/getSourceData.ts | 50 +++++++------------ .../getTransferData/getTransferData.utils.ts | 32 ++++++------ packages/sdk/src/sdk.ts | 4 +- packages/types/package.json | 3 +- .../types/src/chain/parachain/EvmParachain.ts | 33 +++++++++++- 12 files changed, 180 insertions(+), 62 deletions(-) create mode 100644 packages/sdk/src/contract/contracts/Erc20/Erc20Public.ts diff --git a/package-lock.json b/package-lock.json index 3dde639b..f8540fe1 100644 --- a/package-lock.json +++ b/package-lock.json @@ -16732,9 +16732,9 @@ } }, "node_modules/viem": { - "version": "2.7.8", - "resolved": "https://registry.npmjs.org/viem/-/viem-2.7.8.tgz", - "integrity": "sha512-5r5pkBDBmihCvMx4b3MqtP0FoZCRWE2ML1DssU80+vhJQur0PKd4yHdLbbvoiGGVD6bYiA394juhfdSvXIGgFA==", + "version": "2.8.6", + "resolved": "https://registry.npmjs.org/viem/-/viem-2.8.6.tgz", + "integrity": "sha512-LqxLOSFtXfbC3tsiZ8Km8jKR4ktTOLfigL2dR9IN28He2+QrNhYvvwGPz3P4hbfU12Wvuxo6mWGZ2L1lpNtvrA==", "funding": [ { "type": "github", @@ -17290,7 +17290,8 @@ "license": "MIT", "dependencies": { "@moonbeam-network/xcm-builder": "2.0.1", - "@moonbeam-network/xcm-types": "2.0.1" + "@moonbeam-network/xcm-types": "2.0.1", + "viem": "^2.8.6" }, "peerDependencies": { "@polkadot/types": "^10.10.1", @@ -17325,7 +17326,8 @@ "dependencies": { "@moonbeam-network/xcm-utils": "2.0.1", "big.js": "^6.2.1", - "type-fest": "^3.8.0" + "type-fest": "^3.8.0", + "viem": "^2.8.6" } }, "packages/types/node_modules/type-fest": { diff --git a/packages/builder/fixtures/builderParamsMock.ts b/packages/builder/fixtures/builderParamsMock.ts index 8c408b18..573c4ec3 100644 --- a/packages/builder/fixtures/builderParamsMock.ts +++ b/packages/builder/fixtures/builderParamsMock.ts @@ -37,6 +37,11 @@ export const moonbaseAlphaMock = new EvmParachain({ isTestChain: true, key: 'moonbase-alpha', name: 'Moonbase Alpha', + nativeCurrency: { + decimals: 18, + name: 'MOCK', + symbol: 'MOCK', + }, parachainId: 1000, rpc: 'https://rpc.api.moonbase.moonbeam.network', ss58Format: 1287, diff --git a/packages/config/package.json b/packages/config/package.json index 6cca0ce9..9f311efc 100644 --- a/packages/config/package.json +++ b/packages/config/package.json @@ -51,7 +51,8 @@ "main": "./build/index.cjs", "dependencies": { "@moonbeam-network/xcm-builder": "2.0.1", - "@moonbeam-network/xcm-types": "2.0.1" + "@moonbeam-network/xcm-types": "2.0.1", + "viem": "^2.8.6" }, "peerDependencies": { "@polkadot/types": "^10.10.1", diff --git a/packages/config/src/ConfigService/ConfigService.test.ts b/packages/config/src/ConfigService/ConfigService.test.ts index 55ca9ecc..ff7793df 100644 --- a/packages/config/src/ConfigService/ConfigService.test.ts +++ b/packages/config/src/ConfigService/ConfigService.test.ts @@ -100,6 +100,11 @@ describe('config service', () => { isTestChain: true, key: 'test', name: 'test', + nativeCurrency: { + decimals: 18, + name: 'TEST', + symbol: 'TEST', + }, parachainId: 1000, rpc: '', ss58Format: 1287, diff --git a/packages/config/src/chains.ts b/packages/config/src/chains.ts index fa22819e..88611816 100644 --- a/packages/config/src/chains.ts +++ b/packages/config/src/chains.ts @@ -329,6 +329,11 @@ export const darwinia = new EvmParachain({ id: 46, key: 'darwinia', name: 'Darwinia', + nativeCurrency: { + decimals: 18, + name: 'RING', + symbol: 'RING', + }, parachainId: 2046, rpc: 'https://rpc.darwinia.network', ss58Format: 18, @@ -355,12 +360,18 @@ export const darwiniaCrab = new EvmParachain({ id: 44, key: 'darwinia-crab', name: 'Darwinia Crab', + nativeCurrency: { + decimals: 18, + name: 'CRAB', + symbol: 'CRAB', + }, parachainId: 2105, rpc: 'https://crab-rpc.darwinia.network', ss58Format: 18, ws: 'wss://crab-parachain-rpc.darwinia.network', }); +// FIXME: do we need this chain? it looks dead to me - https://pangoro.subscan.io/ export const darwiniaPangoro = new EvmParachain({ assetsData: [ { @@ -382,6 +393,11 @@ export const darwiniaPangoro = new EvmParachain({ isTestChain: true, key: 'darwinia-pangoro', name: 'Pangoro', + nativeCurrency: { + decimals: 18, + name: '???', + symbol: '???', + }, parachainId: 2105, rpc: 'https://pangoro-rpc.darwinia.network', ss58Format: 18, @@ -729,6 +745,11 @@ export const moonbaseAlpha = new EvmParachain({ isTestChain: true, key: 'moonbase-alpha', name: 'Moonbase Alpha', + nativeCurrency: { + decimals: 18, + name: 'DEV', + symbol: 'DEV', + }, parachainId: 1000, rpc: 'https://rpc.api.moonbase.moonbeam.network', ss58Format: 1287, @@ -759,6 +780,11 @@ export const moonbaseBeta = new EvmParachain({ isTestChain: true, key: 'moonbase-beta', name: 'Moonbase Beta', + nativeCurrency: { + decimals: 18, + name: 'DEV', + symbol: 'DEV', + }, parachainId: 888, rpc: 'https://frag-moonbase-beta-rpc.g.moonbase.moonbeam.network', ss58Format: 1287, @@ -931,6 +957,11 @@ export const moonbeam = new EvmParachain({ id: 1284, key: 'moonbeam', name: 'Moonbeam', + nativeCurrency: { + decimals: 18, + name: 'Glimmer', + symbol: 'GLMR', + }, parachainId: 2004, rpc: 'https://rpc.api.moonbeam.network', ss58Format: 1284, @@ -1046,6 +1077,11 @@ export const moonriver = new EvmParachain({ id: 1285, key: 'moonriver', name: 'Moonriver', + nativeCurrency: { + decimals: 18, + name: 'MOVR', + symbol: 'MOVR', + }, parachainId: 2023, rpc: 'https://rpc.api.moonriver.moonbeam.network', ss58Format: 1285, diff --git a/packages/sdk/src/contract/contract.factory.ts b/packages/sdk/src/contract/contract.factory.ts index a90a76d7..0ef0be76 100644 --- a/packages/sdk/src/contract/contract.factory.ts +++ b/packages/sdk/src/contract/contract.factory.ts @@ -1,10 +1,12 @@ import { ContractConfig } from '@moonbeam-network/xcm-builder'; +import { EvmParachain } from '@moonbeam-network/xcm-types'; import { EvmSigner } from '../sdk.interfaces'; import { BalanceContractInterface, TransferContractInterface, } from './contract.interfaces'; import { Erc20, Xtokens } from './contracts'; +import { Erc20Public } from './contracts/Erc20/Erc20Public'; export function createContract( config: ContractConfig, @@ -20,3 +22,14 @@ export function createContract( throw new Error(`Contract ${config.module} not found`); } + +export function createContractWithoutSigner( + config: ContractConfig, + chain: EvmParachain, +): TransferContractInterface | BalanceContractInterface { + if (config.module === 'Erc20') { + return new Erc20Public(config, chain.getViemChain()); + } + + throw new Error(`Public Contract ${config.module} not found`); +} diff --git a/packages/sdk/src/contract/contracts/Erc20/Erc20Public.ts b/packages/sdk/src/contract/contracts/Erc20/Erc20Public.ts new file mode 100644 index 00000000..df91ca78 --- /dev/null +++ b/packages/sdk/src/contract/contracts/Erc20/Erc20Public.ts @@ -0,0 +1,46 @@ +import { ContractConfig } from '@moonbeam-network/xcm-builder'; +import { Chain, PublicClient, createPublicClient, http } from 'viem'; +import { BalanceContractInterface } from '../../contract.interfaces'; +import abi from './Erc20ABI.json'; + +export class Erc20Public implements BalanceContractInterface { + readonly address: string; + + readonly #config: ContractConfig; + + readonly #publicClient: PublicClient; + + constructor(config: ContractConfig, chain: Chain) { + if (!config.address) { + throw new Error('Contract address is required'); + } + this.address = config.address; + + this.#config = config; + + this.#publicClient = createPublicClient({ + chain, + transport: http(), + }); + } + + async getBalance(): Promise { + const data = await this.#publicClient.readContract({ + abi, + address: this.#config.address as `0x${string}`, + functionName: 'balanceOf', + }); + + return data as unknown as bigint; + } + + async getDecimals(): Promise { + const data = await this.#publicClient.readContract({ + abi, + address: this.#config.address as `0x${string}`, + functionName: 'decimals', + }); + + return data as unknown as number; + } +} diff --git a/packages/sdk/src/getTransferData/getSourceData.ts b/packages/sdk/src/getTransferData/getSourceData.ts index 3b36e552..0a85e869 100644 --- a/packages/sdk/src/getTransferData/getSourceData.ts +++ b/packages/sdk/src/getTransferData/getSourceData.ts @@ -340,7 +340,6 @@ export async function getAssetsBalances({ address, chain, assets, - evmSigner, polkadot, }: GetAssetsBalancesParams) { const result = []; @@ -358,40 +357,25 @@ export async function getAssetsBalances({ // eslint-disable-next-line no-restricted-syntax for (const asset of uniqueAssets) { - try { - console.log(asset); - - // eslint-disable-next-line no-await-in-loop - const decimals = await getDecimals({ - address, - asset: asset.asset, - chain, - config: asset, - evmSigner, - polkadot, - }); + // eslint-disable-next-line no-await-in-loop + const decimals = await getDecimals({ + address, + asset: asset.asset, + chain, + config: asset, + polkadot, + }); - // eslint-disable-next-line no-await-in-loop - const balance = await getBalance({ - address, - chain, - config: asset, - decimals, - evmSigner, - polkadot, - }); + // eslint-disable-next-line no-await-in-loop + const balance = await getBalance({ + address, + chain, + config: asset, + decimals, + polkadot, + }); - result.push({ balance, asset: asset.asset }); - } catch (error) { - console.log( - '\x1b[34m████████████████████▓▓▒▒░ getSourceData.ts:406 ░▒▒▓▓████████████████████\x1b[0m', - ); - console.log('* error = '); - console.log(error); - console.log( - '\x1b[34m▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄▄\x1b[0m', - ); - } + result.push({ asset: asset.asset, balance, decimals }); } return result; } diff --git a/packages/sdk/src/getTransferData/getTransferData.utils.ts b/packages/sdk/src/getTransferData/getTransferData.utils.ts index cd9c1fb8..ec989cd3 100644 --- a/packages/sdk/src/getTransferData/getTransferData.utils.ts +++ b/packages/sdk/src/getTransferData/getTransferData.utils.ts @@ -1,8 +1,11 @@ import { CallType, SubstrateQueryConfig } from '@moonbeam-network/xcm-builder'; import { AssetConfig } from '@moonbeam-network/xcm-config'; -import { AnyChain, Asset } from '@moonbeam-network/xcm-types'; +import { AnyChain, Asset, EvmParachain } from '@moonbeam-network/xcm-types'; import { convertDecimals, toBigInt } from '@moonbeam-network/xcm-utils'; -import { BalanceContractInterface, createContract } from '../contract'; +import { + BalanceContractInterface, + createContractWithoutSigner, +} from '../contract'; import { PolkadotService } from '../polkadot'; import { EvmSigner } from '../sdk.interfaces'; @@ -23,7 +26,6 @@ export async function getBalance({ chain, config, decimals, - evmSigner, polkadot, }: GetBalancesParams) { const cfg = config.balance.build({ @@ -38,13 +40,10 @@ export async function getBalance({ : balance; } - if (!evmSigner) { - throw new Error( - `getBalance: Evm signer must be provided. Asset: ${config.asset.key}`, - ); - } - - const contract = createContract(cfg, evmSigner) as BalanceContractInterface; + const contract = createContractWithoutSigner( + cfg, + chain as EvmParachain, + ) as BalanceContractInterface; return contract.getBalance(); } @@ -53,8 +52,8 @@ export async function getDecimals({ address, asset, config, - evmSigner, polkadot, + chain, }: GetDecimalsParams) { const cfg = config.balance.build({ address, @@ -65,13 +64,10 @@ export async function getDecimals({ return polkadot.getAssetDecimals(asset || config.asset); } - if (!evmSigner) { - throw new Error( - `getDecimals: Evm signer must be provided. Asset: ${asset?.key}`, - ); - } - - const contract = createContract(cfg, evmSigner) as BalanceContractInterface; + const contract = createContractWithoutSigner( + cfg, + chain as EvmParachain, + ) as BalanceContractInterface; return contract.getDecimals(); } diff --git a/packages/sdk/src/sdk.ts b/packages/sdk/src/sdk.ts index ba57ea63..d2c7988d 100644 --- a/packages/sdk/src/sdk.ts +++ b/packages/sdk/src/sdk.ts @@ -8,7 +8,7 @@ import { AnyChain, Asset, Ecosystem } from '@moonbeam-network/xcm-types'; import { getAssetsBalances } from './getTransferData/getSourceData'; import { getTransferData as gtd } from './getTransferData/getTransferData'; import { PolkadotService } from './polkadot'; -import { EvmSigner, Signers, TransferData } from './sdk.interfaces'; +import { Signers, TransferData } from './sdk.interfaces'; export interface SdkOptions extends Partial { configService?: IConfigService; @@ -88,7 +88,6 @@ export function Sdk(options?: SdkOptions) { export async function getParachainBalances( chain: AnyChain, address: string, - evmSigner?: EvmSigner, ): Promise { const configService = new ConfigService(); const chainsConfig = configService.getChainConfig(chain); @@ -100,7 +99,6 @@ export async function getParachainBalances( chain, assets, address, - evmSigner, polkadot, }); diff --git a/packages/types/package.json b/packages/types/package.json index 54876f2a..b7ea62bf 100644 --- a/packages/types/package.json +++ b/packages/types/package.json @@ -51,6 +51,7 @@ "dependencies": { "@moonbeam-network/xcm-utils": "2.0.1", "big.js": "^6.2.1", - "type-fest": "^3.8.0" + "type-fest": "^3.8.0", + "viem": "^2.8.6" } } diff --git a/packages/types/src/chain/parachain/EvmParachain.ts b/packages/types/src/chain/parachain/EvmParachain.ts index bf2aae97..e2fbc836 100644 --- a/packages/types/src/chain/parachain/EvmParachain.ts +++ b/packages/types/src/chain/parachain/EvmParachain.ts @@ -1,3 +1,5 @@ +import { defineChain } from 'viem'; +import { Chain } from 'viem/chains'; import { ChainType } from '../Chain.interfaces'; import { Parachain, ParachainConstructorParams } from './Parachain'; @@ -5,17 +7,46 @@ export interface EvmParachainConstructorParams extends Omit { id: number; rpc: string; + nativeCurrency: NativeCurrency; } +type NativeCurrency = { + decimals: number; + name: string; + symbol: string; +}; + export class EvmParachain extends Parachain { readonly id: number; readonly rpc: string; - constructor({ id, rpc, ...others }: EvmParachainConstructorParams) { + readonly nativeCurrency: NativeCurrency; + + constructor({ + id, + rpc, + nativeCurrency, + ...others + }: EvmParachainConstructorParams) { super({ type: ChainType.EvmParachain, ...others }); this.id = id; this.rpc = rpc; + this.nativeCurrency = nativeCurrency; + } + + getViemChain(): Chain { + return defineChain({ + id: this.id, + name: this.name, + nativeCurrency: this.nativeCurrency, + rpcUrls: { + default: { + http: [this.rpc], + webSocket: [this.ws], + }, + }, + }); } } From f9623ae00c488d8610c64150de4d8cd88d840c28 Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Thu, 14 Mar 2024 15:41:39 +0100 Subject: [PATCH 05/44] fix unit tests --- packages/types/src/chain/parachain/EvmParachain.test.ts | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/packages/types/src/chain/parachain/EvmParachain.test.ts b/packages/types/src/chain/parachain/EvmParachain.test.ts index c7c877d0..a41a475d 100644 --- a/packages/types/src/chain/parachain/EvmParachain.test.ts +++ b/packages/types/src/chain/parachain/EvmParachain.test.ts @@ -9,6 +9,11 @@ describe('evmParachain', () => { id: 1284, key: 'moonbeam', name: 'Moonbeam', + nativeCurrency: { + decimals: 18, + name: 'Glimmer', + symbol: 'GLMR', + }, parachainId: 2004, rpc: 'https://rpc.api.moonbeam.network', ss58Format: 1284, From c0e911c11ee0bb3f8bb9160f44d58363ec279e94 Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Thu, 14 Mar 2024 16:42:31 +0100 Subject: [PATCH 06/44] change sdk to return AssetAmount --- packages/sdk/src/getTransferData/getSourceData.ts | 12 +++++++++--- packages/sdk/src/sdk.ts | 9 +++++++-- 2 files changed, 16 insertions(+), 5 deletions(-) diff --git a/packages/sdk/src/getTransferData/getSourceData.ts b/packages/sdk/src/getTransferData/getSourceData.ts index 0a85e869..5d1bab68 100644 --- a/packages/sdk/src/getTransferData/getSourceData.ts +++ b/packages/sdk/src/getTransferData/getSourceData.ts @@ -341,8 +341,8 @@ export async function getAssetsBalances({ chain, assets, polkadot, -}: GetAssetsBalancesParams) { - const result = []; +}: GetAssetsBalancesParams): Promise { + const result: AssetAmount[] = []; const uniqueAssets = assets.reduce( (acc: AssetConfig[], asset: AssetConfig) => { @@ -375,7 +375,13 @@ export async function getAssetsBalances({ polkadot, }); - result.push({ asset: asset.asset, balance, decimals }); + const assetAmount = AssetAmount.fromAsset(asset.asset, { + amount: balance, + decimals, + }); + + result.push(assetAmount); } + return result; } diff --git a/packages/sdk/src/sdk.ts b/packages/sdk/src/sdk.ts index d2c7988d..6660ac29 100644 --- a/packages/sdk/src/sdk.ts +++ b/packages/sdk/src/sdk.ts @@ -4,7 +4,12 @@ import { ConfigService, IConfigService, } from '@moonbeam-network/xcm-config'; -import { AnyChain, Asset, Ecosystem } from '@moonbeam-network/xcm-types'; +import { + AnyChain, + Asset, + AssetAmount, + Ecosystem, +} from '@moonbeam-network/xcm-types'; import { getAssetsBalances } from './getTransferData/getSourceData'; import { getTransferData as gtd } from './getTransferData/getTransferData'; import { PolkadotService } from './polkadot'; @@ -88,7 +93,7 @@ export function Sdk(options?: SdkOptions) { export async function getParachainBalances( chain: AnyChain, address: string, -): Promise { +): Promise { const configService = new ConfigService(); const chainsConfig = configService.getChainConfig(chain); const assets = chainsConfig.getAssetsConfigs(); From 22aea6f1434bb47d200bb8950a428b20268445b4 Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Fri, 15 Mar 2024 14:06:16 +0100 Subject: [PATCH 07/44] add e2e tests for getBalances, remove darwiniaPangoro, fix erc20public to use contract address --- packages/config/src/chains.ts | 34 -- .../config/src/configs/darwiniaPangoro.ts | 29 -- packages/config/src/configs/index.ts | 2 - packages/config/src/configs/moonbaseAlpha.ts | 29 +- .../contract/contracts/Erc20/Erc20Public.ts | 1 + packages/sdk/src/polkadot/PolkadotService.ts | 13 +- .../acceptance/__snapshots__/sdk.test.ts.snap | 324 ++++++++++++++++++ packages/sdk/tests/acceptance/sdk.test.ts | 29 ++ 8 files changed, 356 insertions(+), 105 deletions(-) delete mode 100644 packages/config/src/configs/darwiniaPangoro.ts create mode 100644 packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap diff --git a/packages/config/src/chains.ts b/packages/config/src/chains.ts index 88611816..e89aa247 100644 --- a/packages/config/src/chains.ts +++ b/packages/config/src/chains.ts @@ -371,39 +371,6 @@ export const darwiniaCrab = new EvmParachain({ ws: 'wss://crab-parachain-rpc.darwinia.network', }); -// FIXME: do we need this chain? it looks dead to me - https://pangoro.subscan.io/ -export const darwiniaPangoro = new EvmParachain({ - assetsData: [ - { - // NOTE: no meta for native token - asset: paring, - metadataId: 0, - palletInstance: 5, - }, - { - // NOTE: no meta for movr - asset: dev, - metadataId: 0, - }, - ], - ecosystem: Ecosystem.AlphanetRelay, - genesisHash: - '0xaaa8b33b723b30b44e45e4e6c01936cc92e7559b4184fb0cee2853d55610fcbf', - id: 45, - isTestChain: true, - key: 'darwinia-pangoro', - name: 'Pangoro', - nativeCurrency: { - decimals: 18, - name: '???', - symbol: '???', - }, - parachainId: 2105, - rpc: 'https://pangoro-rpc.darwinia.network', - ss58Format: 18, - ws: 'wss://pangoro-rpc.darwinia.network', -}); - export const equilibrium = new Parachain({ assetsData: [ { @@ -1495,7 +1462,6 @@ export const chainsList: AnyChain[] = [ crustShadow, darwinia, darwiniaCrab, - darwiniaPangoro, equilibrium, hydraDX, integritee, diff --git a/packages/config/src/configs/darwiniaPangoro.ts b/packages/config/src/configs/darwiniaPangoro.ts deleted file mode 100644 index 3b488844..00000000 --- a/packages/config/src/configs/darwiniaPangoro.ts +++ /dev/null @@ -1,29 +0,0 @@ -import { - BalanceBuilder, - ExtrinsicBuilder, - FeeBuilder, -} from '@moonbeam-network/xcm-builder'; -import { paring } from '../assets'; -import { darwiniaPangoro, moonbaseAlpha } from '../chains'; -import { AssetConfig } from '../types/AssetConfig'; -import { ChainConfig } from '../types/ChainConfig'; - -export const darwiniaPangoroConfig = new ChainConfig({ - assets: [ - new AssetConfig({ - asset: paring, - balance: BalanceBuilder().substrate().system().account(), - destination: moonbaseAlpha, - destinationFee: { - amount: FeeBuilder().assetManager().assetTypeUnitsPerSecond(), - asset: paring, - balance: BalanceBuilder().substrate().system().account(), - }, - extrinsic: ExtrinsicBuilder() - .polkadotXcm() - .limitedReserveTransferAssets() - .X1(), - }), - ], - chain: darwiniaPangoro, -}); diff --git a/packages/config/src/configs/index.ts b/packages/config/src/configs/index.ts index 0ece8b1b..44dde5fe 100644 --- a/packages/config/src/configs/index.ts +++ b/packages/config/src/configs/index.ts @@ -11,7 +11,6 @@ import { centrifugeConfig } from './centrifuge'; import { crustShadowConfig } from './crustShadow'; import { darwiniaConfig } from './darwinia'; import { darwiniaCrabConfig } from './darwiniaCrab'; -import { darwiniaPangoroConfig } from './darwiniaPangoro'; import { equilibriumConfig } from './equilibrium'; import { hydraDxConfig } from './hydraDX'; import { integriteeConfig } from './integritee'; @@ -59,7 +58,6 @@ export const chainsConfigList: ChainConfig[] = [ crustShadowConfig, darwiniaConfig, darwiniaCrabConfig, - darwiniaPangoroConfig, equilibriumConfig, hydraDxConfig, integriteeConfig, diff --git a/packages/config/src/configs/moonbaseAlpha.ts b/packages/config/src/configs/moonbaseAlpha.ts index b362fd1c..357c5a50 100644 --- a/packages/config/src/configs/moonbaseAlpha.ts +++ b/packages/config/src/configs/moonbaseAlpha.ts @@ -1,20 +1,8 @@ import { BalanceBuilder, ContractBuilder } from '@moonbeam-network/xcm-builder'; -import { - alan, - ampe, - atom, - dev, - otp, - paring, - pica, - tt1, - tur, - unit, -} from '../assets'; +import { alan, ampe, atom, dev, otp, pica, tt1, tur, unit } from '../assets'; import { alphanetAssetHub, alphanetRelay, - darwiniaPangoro, moonbaseAlpha, moonbaseBeta, originTrailAlphanet, @@ -131,21 +119,6 @@ export const moonbaseAlphaConfig = new ChainConfig({ balance: BalanceBuilder().substrate().system().account(), }, }), - new AssetConfig({ - asset: paring, - balance: BalanceBuilder().substrate().assets().account(), - contract: ContractBuilder().Xtokens().transfer(), - destination: darwiniaPangoro, - destinationFee: { - amount: 4, - asset: paring, - balance: BalanceBuilder().substrate().assets().account(), - }, - fee: { - asset: dev, - balance: BalanceBuilder().substrate().system().account(), - }, - }), new AssetConfig({ asset: atom, balance: BalanceBuilder().substrate().assets().account(), diff --git a/packages/sdk/src/contract/contracts/Erc20/Erc20Public.ts b/packages/sdk/src/contract/contracts/Erc20/Erc20Public.ts index df91ca78..adf6adec 100644 --- a/packages/sdk/src/contract/contracts/Erc20/Erc20Public.ts +++ b/packages/sdk/src/contract/contracts/Erc20/Erc20Public.ts @@ -28,6 +28,7 @@ export class Erc20Public implements BalanceContractInterface { const data = await this.#publicClient.readContract({ abi, address: this.#config.address as `0x${string}`, + args: [this.address], functionName: 'balanceOf', }); diff --git a/packages/sdk/src/polkadot/PolkadotService.ts b/packages/sdk/src/polkadot/PolkadotService.ts index f45c1420..a50ad49b 100644 --- a/packages/sdk/src/polkadot/PolkadotService.ts +++ b/packages/sdk/src/polkadot/PolkadotService.ts @@ -4,13 +4,7 @@ import { ExtrinsicConfig, SubstrateQueryConfig, } from '@moonbeam-network/xcm-builder'; -import { - IConfigService, - darwiniaPangoro, - eq, - equilibrium, - paring, -} from '@moonbeam-network/xcm-config'; +import { IConfigService, eq, equilibrium } from '@moonbeam-network/xcm-config'; import { AnyParachain, Asset, @@ -77,11 +71,6 @@ export class PolkadotService { return eq; } - // TODO: Remove this once Darwinia Pangoro is updated - if (key === 'oring' && this.chain.key === darwiniaPangoro.key) { - return paring; - } - if (!key) { throw new Error('No native symbol key found'); } diff --git a/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap b/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap new file mode 100644 index 00000000..658f284f --- /dev/null +++ b/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap @@ -0,0 +1,324 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`sdk getParachainBalances should get expected balances for Centrifuge 1`] = ` +[ + r { + "amount": 570000000000000000n, + "decimals": 18, + "key": "cfg", + "originSymbol": "CFG", + "symbol": "CFG", + }, +] +`; + +exports[`sdk getParachainBalances should get expected balances for HydraDX 1`] = ` +[ + r { + "amount": 37000000000000n, + "decimals": 12, + "key": "weth", + "originSymbol": "WETH", + "symbol": "WETH", + }, + r { + "amount": 120n, + "decimals": 12, + "key": "wbtc", + "originSymbol": "WBTC", + "symbol": "WBTC", + }, + r { + "amount": 0n, + "decimals": 12, + "key": "usdtwh", + "originSymbol": "USDT.Wh", + "symbol": "USDT.Wh", + }, + r { + "amount": 0n, + "decimals": 12, + "key": "usdcwh", + "originSymbol": "USDC.Wh", + "symbol": "USDC.Wh", + }, + r { + "amount": 0n, + "decimals": 12, + "key": "dai", + "originSymbol": "DAI", + "symbol": "DAI", + }, + r { + "amount": 0n, + "decimals": 12, + "key": "glmr", + "originSymbol": "GLMR", + "symbol": "GLMR", + }, + r { + "amount": 1000000000000n, + "decimals": 12, + "key": "hdx", + "originSymbol": "HDX", + "symbol": "HDX", + }, +] +`; + +exports[`sdk getParachainBalances should get expected balances for Moonbeam 1`] = ` +[ + r { + "amount": 0n, + "decimals": 10, + "key": "sub", + "originSymbol": "SUB", + "symbol": "SUB", + }, + r { + "amount": 0n, + "decimals": 10, + "key": "ztg", + "originSymbol": "ZTG", + "symbol": "ZTG", + }, + r { + "amount": 0n, + "decimals": 18, + "key": "fil", + "originSymbol": "FIL", + "symbol": "FIL", + }, + r { + "amount": 0n, + "decimals": 18, + "key": "weth", + "originSymbol": "WETH", + "symbol": "WETH", + }, + r { + "amount": 0n, + "decimals": 8, + "key": "wbtc", + "originSymbol": "WBTC", + "symbol": "WBTC", + }, + r { + "amount": 0n, + "decimals": 18, + "key": "vmanta", + "originSymbol": "vMANTA", + "symbol": "vMANTA", + }, + r { + "amount": 0n, + "decimals": 18, + "key": "vglmr", + "originSymbol": "vGLMR", + "symbol": "vGLMR", + }, + r { + "amount": 0n, + "decimals": 18, + "key": "vfil", + "originSymbol": "vFIL", + "symbol": "vFIL", + }, + r { + "amount": 0n, + "decimals": 10, + "key": "vdot", + "originSymbol": "vDOT", + "symbol": "vDOT", + }, + r { + "amount": 0n, + "decimals": 18, + "key": "vastr", + "originSymbol": "vASTR", + "symbol": "vASTR", + }, + r { + "amount": 0n, + "decimals": 6, + "key": "usdtwh", + "originSymbol": "USDT.Wh", + "symbol": "USDT.Wh", + }, + r { + "amount": 374573n, + "decimals": 6, + "key": "usdcwh", + "originSymbol": "USDC.Wh", + "symbol": "USDC.Wh", + }, + r { + "amount": 0n, + "decimals": 18, + "key": "dai", + "originSymbol": "DAI", + "symbol": "DAI", + }, + r { + "amount": 0n, + "decimals": 12, + "key": "hdx", + "originSymbol": "HDX", + "symbol": "HDX", + }, + r { + "amount": 0n, + "decimals": 10, + "key": "pink", + "originSymbol": "PINK", + "symbol": "PINK", + }, + r { + "amount": 0n, + "decimals": 6, + "key": "usdc", + "originSymbol": "USDC", + "symbol": "USDC", + }, + r { + "amount": 0n, + "decimals": 6, + "key": "usdt", + "originSymbol": "USDT", + "symbol": "USDT", + }, + r { + "amount": 0n, + "decimals": 18, + "key": "ring", + "originSymbol": "RING", + "symbol": "RING", + }, + r { + "amount": 0n, + "decimals": 12, + "key": "pha", + "originSymbol": "PHA", + "symbol": "PHA", + }, + r { + "amount": 0n, + "decimals": 12, + "key": "pen", + "originSymbol": "PEN", + "symbol": "PEN", + }, + r { + "amount": 0n, + "decimals": 12, + "key": "para", + "originSymbol": "PARA", + "symbol": "PARA", + }, + r { + "amount": 0n, + "decimals": 12, + "key": "otp", + "originSymbol": "OTP", + "symbol": "OTP", + }, + r { + "amount": 0n, + "decimals": 11, + "key": "nodl", + "originSymbol": "NODL", + "symbol": "NODL", + }, + r { + "amount": 0n, + "decimals": 18, + "key": "manta", + "originSymbol": "MANTA", + "symbol": "MANTA", + }, + r { + "amount": 0n, + "decimals": 10, + "key": "ldot", + "originSymbol": "LDOT", + "symbol": "LDOT", + }, + r { + "amount": 0n, + "decimals": 10, + "key": "intr", + "originSymbol": "INTR", + "symbol": "INTR", + }, + r { + "amount": 0n, + "decimals": 8, + "key": "ibtc", + "originSymbol": "IBTC", + "symbol": "IBTC", + }, + r { + "amount": 0n, + "decimals": 9, + "key": "eqd", + "originSymbol": "EQD", + "symbol": "EQD", + }, + r { + "amount": 0n, + "decimals": 9, + "key": "eq", + "originSymbol": "EQ", + "symbol": "EQ", + }, + r { + "amount": 330000000n, + "decimals": 10, + "key": "dot", + "originSymbol": "DOT", + "symbol": "DOT", + }, + r { + "amount": 0n, + "decimals": 18, + "key": "cfg", + "originSymbol": "CFG", + "symbol": "CFG", + }, + r { + "amount": 0n, + "decimals": 12, + "key": "bnc", + "originSymbol": "BNC", + "symbol": "BNC", + }, + r { + "amount": 0n, + "decimals": 12, + "key": "aseed", + "originSymbol": "aSEED", + "symbol": "aSEED", + }, + r { + "amount": 0n, + "decimals": 18, + "key": "astr", + "originSymbol": "ASTR", + "symbol": "ASTR", + }, + r { + "amount": 0n, + "decimals": 12, + "key": "aca", + "originSymbol": "ACA", + "symbol": "ACA", + }, + r { + "amount": 1330000000000000000n, + "decimals": 18, + "key": "glmr", + "originSymbol": "GLMR", + "symbol": "GLMR", + }, +] +`; diff --git a/packages/sdk/tests/acceptance/sdk.test.ts b/packages/sdk/tests/acceptance/sdk.test.ts index 1cb89ba5..80e28c5d 100644 --- a/packages/sdk/tests/acceptance/sdk.test.ts +++ b/packages/sdk/tests/acceptance/sdk.test.ts @@ -1,3 +1,32 @@ +/* eslint-disable jest/no-commented-out-tests */ +import { centrifuge, hydraDX, moonbeam } from '@moonbeam-network/xcm-config'; +import { getParachainBalances } from '../../src/sdk'; + +// E2E balance test wallet +const hydraDXAddress = '7MR8Qxy9sJmN6bfHMggAtFY5DwLxfrssLuTnP5rmkpD92oPH'; +const centrifugeAddress = '4fAKSBMGVT9jt1jkuJvXgvMbmqV2BuspFWWEmdVeFj9yRudb'; +const moonbeamAddress = '0x4E82143Af671Cc8201Bc7efCBbCED3A69e84405e'; + +describe('sdk', () => { + describe(`${getParachainBalances.name}`, () => { + it(`should get expected balances for ${moonbeam.name}`, async () => { + const result = await getParachainBalances(moonbeam, moonbeamAddress); + + expect(result).toMatchSnapshot(); + }); + it(`should get expected balances for ${hydraDX.name}`, async () => { + const result = await getParachainBalances(hydraDX, hydraDXAddress); + + expect(result).toMatchSnapshot(); + }); + it(`should get expected balances for ${centrifuge.name}`, async () => { + const result = await getParachainBalances(centrifuge, centrifugeAddress); + + expect(result).toMatchSnapshot(); + }); + }); +}); + /* eslint-disable jest/max-expects */ /* eslint-disable @typescript-eslint/no-unused-expressions */ /* eslint-disable jest/no-standalone-expect */ From f0f74b2172e160bc68453ea6f015d5f7bdc54cd5 Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Fri, 15 Mar 2024 14:30:13 +0100 Subject: [PATCH 08/44] change to map and get balances in parallel --- .../sdk/src/getTransferData/getSourceData.ts | 52 +++++++++---------- 1 file changed, 25 insertions(+), 27 deletions(-) diff --git a/packages/sdk/src/getTransferData/getSourceData.ts b/packages/sdk/src/getTransferData/getSourceData.ts index 5d1bab68..1b96be61 100644 --- a/packages/sdk/src/getTransferData/getSourceData.ts +++ b/packages/sdk/src/getTransferData/getSourceData.ts @@ -342,8 +342,6 @@ export async function getAssetsBalances({ assets, polkadot, }: GetAssetsBalancesParams): Promise { - const result: AssetAmount[] = []; - const uniqueAssets = assets.reduce( (acc: AssetConfig[], asset: AssetConfig) => { if (!acc.some((a: AssetConfig) => a.asset.isEqual(asset.asset))) { @@ -355,33 +353,33 @@ export async function getAssetsBalances({ [], ); - // eslint-disable-next-line no-restricted-syntax - for (const asset of uniqueAssets) { - // eslint-disable-next-line no-await-in-loop - const decimals = await getDecimals({ - address, - asset: asset.asset, - chain, - config: asset, - polkadot, - }); + const balances = await Promise.all( + uniqueAssets.map(async (asset: AssetConfig) => { + const decimals = await getDecimals({ + address, + asset: asset.asset, + chain, + config: asset, + polkadot, + }); - // eslint-disable-next-line no-await-in-loop - const balance = await getBalance({ - address, - chain, - config: asset, - decimals, - polkadot, - }); + // eslint-disable-next-line no-await-in-loop + const balance = await getBalance({ + address, + chain, + config: asset, + decimals, + polkadot, + }); - const assetAmount = AssetAmount.fromAsset(asset.asset, { - amount: balance, - decimals, - }); + const assetAmount = AssetAmount.fromAsset(asset.asset, { + amount: balance, + decimals, + }); - result.push(assetAmount); - } + return assetAmount; + }), + ); - return result; + return balances; } From ffd4fdb49198eadd01df1b4a93f7397cfda7b772 Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Mon, 18 Mar 2024 12:45:02 +0100 Subject: [PATCH 09/44] add HydraDX Alphanet --- packages/config/src/assets.ts | 10 ++- packages/config/src/chains.ts | 35 ++++++++++ .../config/src/configs/hydraDXAlphanet.ts | 68 +++++++++++++++++++ 3 files changed, 111 insertions(+), 2 deletions(-) create mode 100644 packages/config/src/configs/hydraDXAlphanet.ts diff --git a/packages/config/src/assets.ts b/packages/config/src/assets.ts index 63c77261..1f53799a 100644 --- a/packages/config/src/assets.ts +++ b/packages/config/src/assets.ts @@ -335,14 +335,19 @@ export const ztg = new Asset({ originSymbol: 'ZTG', }); +export const ftmwh = new Asset({ + key: 'ftmwh', + originSymbol: 'FTM.wh', +}); + export const assetsList: Asset[] = [ aca, alan, ampe, + aseed, astr, atom, auq, - aseed, bnc, cfg, crab, @@ -353,6 +358,7 @@ export const assetsList: Asset[] = [ eq, eqd, fil, + ftmwh, glmr, hdx, hko, @@ -397,10 +403,10 @@ export const assetsList: Asset[] = [ vksm, vmanta, vmovr, - xrt, wbtc, weth, wftm, + xrt, ztg, ]; diff --git a/packages/config/src/chains.ts b/packages/config/src/chains.ts index e89aa247..5ee20ec2 100644 --- a/packages/config/src/chains.ts +++ b/packages/config/src/chains.ts @@ -23,6 +23,7 @@ import { eq, eqd, fil, + ftmwh, glmr, hdx, hko, @@ -438,6 +439,40 @@ export const hydraDX = new Parachain({ ws: 'wss://hydradx-rpc.dwellir.com', }); +export const hydraDxAlphanet = new Parachain({ + assetsData: [ + { + asset: hdx, + id: 0, + }, + { + asset: usdcwh, + id: 1000001, + }, + { + asset: ftmwh, + id: 1000002, + }, + { + asset: usdtwh, + id: 2, + }, + { + asset: dev, + id: 1, + }, + ], + ecosystem: Ecosystem.Polkadot, + genesisHash: + '0x025980095be141a99f983631c49271af15cab61c4ce0d73db73192443932669a', + isTestChain: true, + key: 'hydra-dx-Alphanet', + name: 'HydraDX Alphanet', + parachainId: 2034, + ss58Format: 63, + ws: 'wss://hydradx-moonbase-rpc.play.hydration.cloud', +}); + export const interlay = new Parachain({ assetsData: [ { diff --git a/packages/config/src/configs/hydraDXAlphanet.ts b/packages/config/src/configs/hydraDXAlphanet.ts new file mode 100644 index 00000000..11332831 --- /dev/null +++ b/packages/config/src/configs/hydraDXAlphanet.ts @@ -0,0 +1,68 @@ +import { + BalanceBuilder, + ExtrinsicBuilder, + FeeBuilder, +} from '@moonbeam-network/xcm-builder'; +import { dev, ftmwh, hdx, usdcwh } from '../assets'; +import { hydraDxAlphanet, moonbaseAlpha } from '../chains'; +import { AssetConfig } from '../types/AssetConfig'; +import { ChainConfig } from '../types/ChainConfig'; + +// FIXME: has to be verified +export const hydraDxConfig = new ChainConfig({ + assets: [ + new AssetConfig({ + asset: hdx, + balance: BalanceBuilder().substrate().system().account(), + destination: moonbaseAlpha, + destinationFee: { + amount: FeeBuilder().assetManager().assetTypeUnitsPerSecond(), + asset: hdx, + balance: BalanceBuilder().substrate().system().account(), + }, + extrinsic: ExtrinsicBuilder().xTokens().transfer(), + }), + new AssetConfig({ + asset: dev, + balance: BalanceBuilder().substrate().tokens().accounts(), + destination: moonbaseAlpha, + destinationFee: { + amount: 0.01, + asset: dev, + balance: BalanceBuilder().substrate().tokens().accounts(), + }, + extrinsic: ExtrinsicBuilder().xTokens().transfer(), + }), + new AssetConfig({ + asset: usdcwh, + balance: BalanceBuilder().substrate().tokens().accounts(), + destination: moonbaseAlpha, + destinationFee: { + amount: 0.04, + asset: dev, + balance: BalanceBuilder().substrate().tokens().accounts(), + }, + extrinsic: ExtrinsicBuilder().xTokens().transferMultiCurrencies(), + fee: { + asset: hdx, + balance: BalanceBuilder().substrate().system().account(), + }, + }), + new AssetConfig({ + asset: ftmwh, + balance: BalanceBuilder().substrate().tokens().accounts(), + destination: moonbaseAlpha, + destinationFee: { + amount: 0.04, + asset: dev, + balance: BalanceBuilder().substrate().tokens().accounts(), + }, + extrinsic: ExtrinsicBuilder().xTokens().transferMultiCurrencies(), + fee: { + asset: hdx, + balance: BalanceBuilder().substrate().system().account(), + }, + }), + ], + chain: hydraDxAlphanet, +}); From 72112381b2b3892517b1175312b6715a942c08f6 Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Mon, 18 Mar 2024 13:51:20 +0100 Subject: [PATCH 10/44] add to chains config --- packages/config/src/configs/hydraDXAlphanet.ts | 2 +- packages/config/src/configs/index.ts | 2 ++ 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/packages/config/src/configs/hydraDXAlphanet.ts b/packages/config/src/configs/hydraDXAlphanet.ts index 11332831..df4ec90e 100644 --- a/packages/config/src/configs/hydraDXAlphanet.ts +++ b/packages/config/src/configs/hydraDXAlphanet.ts @@ -9,7 +9,7 @@ import { AssetConfig } from '../types/AssetConfig'; import { ChainConfig } from '../types/ChainConfig'; // FIXME: has to be verified -export const hydraDxConfig = new ChainConfig({ +export const hydraDxAlphanetConfig = new ChainConfig({ assets: [ new AssetConfig({ asset: hdx, diff --git a/packages/config/src/configs/index.ts b/packages/config/src/configs/index.ts index 44dde5fe..5d9ca31d 100644 --- a/packages/config/src/configs/index.ts +++ b/packages/config/src/configs/index.ts @@ -13,6 +13,7 @@ import { darwiniaConfig } from './darwinia'; import { darwiniaCrabConfig } from './darwiniaCrab'; import { equilibriumConfig } from './equilibrium'; import { hydraDxConfig } from './hydraDX'; +import { hydraDxAlphanetConfig } from './hydraDXAlphanet'; import { integriteeConfig } from './integritee'; import { interlayConfig } from './interlay'; import { karuraConfig } from './karura'; @@ -60,6 +61,7 @@ export const chainsConfigList: ChainConfig[] = [ darwiniaCrabConfig, equilibriumConfig, hydraDxConfig, + hydraDxAlphanetConfig, integriteeConfig, interlayConfig, karuraConfig, From dd750a0160a04fb3c879a5481ad45ecceee9b826 Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Mon, 18 Mar 2024 14:49:16 +0100 Subject: [PATCH 11/44] add HydraDX alphanet e2e test --- .../acceptance/__snapshots__/sdk.test.ts.snap | 33 +++++++++++++++++++ packages/sdk/tests/acceptance/sdk.test.ts | 16 ++++++++- 2 files changed, 48 insertions(+), 1 deletion(-) diff --git a/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap b/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap index 658f284f..9d3c4f91 100644 --- a/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap +++ b/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap @@ -66,6 +66,39 @@ exports[`sdk getParachainBalances should get expected balances for HydraDX 1`] = ] `; +exports[`sdk getParachainBalances should get expected balances for HydraDX Alphanet 1`] = ` +[ + r { + "amount": 0n, + "decimals": 18, + "key": "ftmwh", + "originSymbol": "FTM.wh", + "symbol": "FTM.wh", + }, + r { + "amount": 0n, + "decimals": 6, + "key": "usdcwh", + "originSymbol": "USDC.Wh", + "symbol": "USDC.Wh", + }, + r { + "amount": 0n, + "decimals": 18, + "key": "dev", + "originSymbol": "DEV", + "symbol": "DEV", + }, + r { + "amount": 0n, + "decimals": 12, + "key": "hdx", + "originSymbol": "HDX", + "symbol": "HDX", + }, +] +`; + exports[`sdk getParachainBalances should get expected balances for Moonbeam 1`] = ` [ r { diff --git a/packages/sdk/tests/acceptance/sdk.test.ts b/packages/sdk/tests/acceptance/sdk.test.ts index 80e28c5d..aff6f659 100644 --- a/packages/sdk/tests/acceptance/sdk.test.ts +++ b/packages/sdk/tests/acceptance/sdk.test.ts @@ -1,5 +1,10 @@ /* eslint-disable jest/no-commented-out-tests */ -import { centrifuge, hydraDX, moonbeam } from '@moonbeam-network/xcm-config'; +import { + centrifuge, + hydraDX, + hydraDxAlphanet, + moonbeam, +} from '@moonbeam-network/xcm-config'; import { getParachainBalances } from '../../src/sdk'; // E2E balance test wallet @@ -24,6 +29,15 @@ describe('sdk', () => { expect(result).toMatchSnapshot(); }); + + it(`should get expected balances for ${hydraDxAlphanet.name}`, async () => { + const result = await getParachainBalances( + hydraDxAlphanet, + hydraDXAddress, + ); + + expect(result).toMatchSnapshot(); + }); }); }); From 0f31eaf32992fef2d05c63283023ea087a7b68fe Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Mon, 18 Mar 2024 15:27:21 +0100 Subject: [PATCH 12/44] add HydraDX e2e test with FTM and HDX balances --- packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap b/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap index 9d3c4f91..8e8a43e3 100644 --- a/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap +++ b/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap @@ -69,7 +69,7 @@ exports[`sdk getParachainBalances should get expected balances for HydraDX 1`] = exports[`sdk getParachainBalances should get expected balances for HydraDX Alphanet 1`] = ` [ r { - "amount": 0n, + "amount": 178046239082538836n, "decimals": 18, "key": "ftmwh", "originSymbol": "FTM.wh", @@ -90,7 +90,7 @@ exports[`sdk getParachainBalances should get expected balances for HydraDX Alpha "symbol": "DEV", }, r { - "amount": 0n, + "amount": 3000000000000n, "decimals": 12, "key": "hdx", "originSymbol": "HDX", From 97b9bca034bbc2301ba747aad7437d041a3960b1 Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Mon, 18 Mar 2024 16:49:55 +0100 Subject: [PATCH 13/44] add hydraDxAlphanet to chainsMap --- packages/config/src/chains.ts | 1 + 1 file changed, 1 insertion(+) diff --git a/packages/config/src/chains.ts b/packages/config/src/chains.ts index 5ee20ec2..196cf6eb 100644 --- a/packages/config/src/chains.ts +++ b/packages/config/src/chains.ts @@ -1499,6 +1499,7 @@ export const chainsList: AnyChain[] = [ darwiniaCrab, equilibrium, hydraDX, + hydraDxAlphanet, integritee, interlay, karura, From 9a2efe977a9209dfd844ae74bff9f147297d4b42 Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Tue, 19 Mar 2024 08:44:43 +0100 Subject: [PATCH 14/44] add changeset --- .changeset/twelve-bats-bathe.md | 8 ++++++++ 1 file changed, 8 insertions(+) create mode 100644 .changeset/twelve-bats-bathe.md diff --git a/.changeset/twelve-bats-bathe.md b/.changeset/twelve-bats-bathe.md new file mode 100644 index 00000000..96d9e7c5 --- /dev/null +++ b/.changeset/twelve-bats-bathe.md @@ -0,0 +1,8 @@ +--- +'@moonbeam-network/xcm-builder': major +'@moonbeam-network/xcm-config': major +'@moonbeam-network/xcm-types': major +'@moonbeam-network/xcm-sdk': major +--- + +Add function to get balances, get balances and decimals without signer, add HydraDX Alphanet From efe437389f6b6988914b5cc4a6746d70e6d4f932 Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Tue, 19 Mar 2024 09:42:55 +0100 Subject: [PATCH 15/44] change version to minor --- .changeset/twelve-bats-bathe.md | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/.changeset/twelve-bats-bathe.md b/.changeset/twelve-bats-bathe.md index 96d9e7c5..aeb4f8d6 100644 --- a/.changeset/twelve-bats-bathe.md +++ b/.changeset/twelve-bats-bathe.md @@ -1,8 +1,8 @@ --- -'@moonbeam-network/xcm-builder': major -'@moonbeam-network/xcm-config': major -'@moonbeam-network/xcm-types': major -'@moonbeam-network/xcm-sdk': major +'@moonbeam-network/xcm-builder': minor +'@moonbeam-network/xcm-config': minor +'@moonbeam-network/xcm-types': minor +'@moonbeam-network/xcm-sdk': minor --- Add function to get balances, get balances and decimals without signer, add HydraDX Alphanet From b54768767605346a1d27dd689f817ac365a0a538 Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Tue, 19 Mar 2024 09:49:37 +0100 Subject: [PATCH 16/44] remove viem from config --- package-lock.json | 3 +-- packages/config/package.json | 3 +-- 2 files changed, 2 insertions(+), 4 deletions(-) diff --git a/package-lock.json b/package-lock.json index 84574784..4f1be7e5 100644 --- a/package-lock.json +++ b/package-lock.json @@ -17290,8 +17290,7 @@ "license": "MIT", "dependencies": { "@moonbeam-network/xcm-builder": "2.0.1", - "@moonbeam-network/xcm-types": "2.0.1", - "viem": "^2.8.6" + "@moonbeam-network/xcm-types": "2.0.1" }, "peerDependencies": { "@polkadot/types": "^10.10.1", diff --git a/packages/config/package.json b/packages/config/package.json index 9f311efc..6cca0ce9 100644 --- a/packages/config/package.json +++ b/packages/config/package.json @@ -51,8 +51,7 @@ "main": "./build/index.cjs", "dependencies": { "@moonbeam-network/xcm-builder": "2.0.1", - "@moonbeam-network/xcm-types": "2.0.1", - "viem": "^2.8.6" + "@moonbeam-network/xcm-types": "2.0.1" }, "peerDependencies": { "@polkadot/types": "^10.10.1", From fd8332344b4e1f15566d7099fcb1c63bf623b2aa Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Wed, 20 Mar 2024 09:19:29 +0100 Subject: [PATCH 17/44] fix HydraDX Alphanet decimals, add more e2e tests --- packages/config/src/chains.ts | 5 + .../acceptance/__snapshots__/sdk.test.ts.snap | 111 +++++++++++++++++- packages/sdk/tests/acceptance/sdk.test.ts | 18 +++ 3 files changed, 128 insertions(+), 6 deletions(-) diff --git a/packages/config/src/chains.ts b/packages/config/src/chains.ts index 54882dbf..c1df6a09 100644 --- a/packages/config/src/chains.ts +++ b/packages/config/src/chains.ts @@ -443,22 +443,27 @@ export const hydraDxAlphanet = new Parachain({ assetsData: [ { asset: hdx, + decimals: 12, id: 0, }, { asset: usdcwh, + decimals: 6, id: 1000001, }, { asset: ftmwh, + decimals: 18, id: 1000002, }, { asset: usdtwh, + decimals: 6, id: 2, }, { asset: dev, + decimals: 18, id: 1, }, ], diff --git a/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap b/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap index 8e8a43e3..691b6efd 100644 --- a/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap +++ b/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap @@ -1,5 +1,17 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP +exports[`sdk getParachainBalances should get expected balances for Centrifuge for substrate address 1`] = ` +[ + r { + "amount": 570000000000000000n, + "decimals": 18, + "key": "cfg", + "originSymbol": "CFG", + "symbol": "CFG", + }, +] +`; + exports[`sdk getParachainBalances should get expected balances for Centrifuge 1`] = ` [ r { @@ -16,42 +28,42 @@ exports[`sdk getParachainBalances should get expected balances for HydraDX 1`] = [ r { "amount": 37000000000000n, - "decimals": 12, + "decimals": 18, "key": "weth", "originSymbol": "WETH", "symbol": "WETH", }, r { "amount": 120n, - "decimals": 12, + "decimals": 8, "key": "wbtc", "originSymbol": "WBTC", "symbol": "WBTC", }, r { "amount": 0n, - "decimals": 12, + "decimals": 6, "key": "usdtwh", "originSymbol": "USDT.Wh", "symbol": "USDT.Wh", }, r { "amount": 0n, - "decimals": 12, + "decimals": 6, "key": "usdcwh", "originSymbol": "USDC.Wh", "symbol": "USDC.Wh", }, r { "amount": 0n, - "decimals": 12, + "decimals": 18, "key": "dai", "originSymbol": "DAI", "symbol": "DAI", }, r { "amount": 0n, - "decimals": 12, + "decimals": 18, "key": "glmr", "originSymbol": "GLMR", "symbol": "GLMR", @@ -99,6 +111,93 @@ exports[`sdk getParachainBalances should get expected balances for HydraDX Alpha ] `; +exports[`sdk getParachainBalances should get expected balances for HydraDX Alphanet for substrate address 1`] = ` +[ + r { + "amount": 178046239082538836n, + "decimals": 18, + "key": "ftmwh", + "originSymbol": "FTM.wh", + "symbol": "FTM.wh", + }, + r { + "amount": 0n, + "decimals": 6, + "key": "usdcwh", + "originSymbol": "USDC.Wh", + "symbol": "USDC.Wh", + }, + r { + "amount": 0n, + "decimals": 18, + "key": "dev", + "originSymbol": "DEV", + "symbol": "DEV", + }, + r { + "amount": 3000000000000n, + "decimals": 12, + "key": "hdx", + "originSymbol": "HDX", + "symbol": "HDX", + }, +] +`; + +exports[`sdk getParachainBalances should get expected balances for HydraDX for substrate address 1`] = ` +[ + r { + "amount": 37000000000000n, + "decimals": 18, + "key": "weth", + "originSymbol": "WETH", + "symbol": "WETH", + }, + r { + "amount": 120n, + "decimals": 8, + "key": "wbtc", + "originSymbol": "WBTC", + "symbol": "WBTC", + }, + r { + "amount": 0n, + "decimals": 6, + "key": "usdtwh", + "originSymbol": "USDT.Wh", + "symbol": "USDT.Wh", + }, + r { + "amount": 0n, + "decimals": 6, + "key": "usdcwh", + "originSymbol": "USDC.Wh", + "symbol": "USDC.Wh", + }, + r { + "amount": 0n, + "decimals": 18, + "key": "dai", + "originSymbol": "DAI", + "symbol": "DAI", + }, + r { + "amount": 0n, + "decimals": 18, + "key": "glmr", + "originSymbol": "GLMR", + "symbol": "GLMR", + }, + r { + "amount": 1000000000000n, + "decimals": 12, + "key": "hdx", + "originSymbol": "HDX", + "symbol": "HDX", + }, +] +`; + exports[`sdk getParachainBalances should get expected balances for Moonbeam 1`] = ` [ r { diff --git a/packages/sdk/tests/acceptance/sdk.test.ts b/packages/sdk/tests/acceptance/sdk.test.ts index aff6f659..58b12387 100644 --- a/packages/sdk/tests/acceptance/sdk.test.ts +++ b/packages/sdk/tests/acceptance/sdk.test.ts @@ -11,6 +11,7 @@ import { getParachainBalances } from '../../src/sdk'; const hydraDXAddress = '7MR8Qxy9sJmN6bfHMggAtFY5DwLxfrssLuTnP5rmkpD92oPH'; const centrifugeAddress = '4fAKSBMGVT9jt1jkuJvXgvMbmqV2BuspFWWEmdVeFj9yRudb'; const moonbeamAddress = '0x4E82143Af671Cc8201Bc7efCBbCED3A69e84405e'; +const substrateAddress = '5FtGz8bgoCQ6pNAYLWCfxKx9ekLnX1ewP9q2TjMT2riu7sf9'; describe('sdk', () => { describe(`${getParachainBalances.name}`, () => { @@ -24,18 +25,35 @@ describe('sdk', () => { expect(result).toMatchSnapshot(); }); + it(`should get expected balances for ${hydraDX.name} for substrate address`, async () => { + const result = await getParachainBalances(hydraDX, substrateAddress); + + expect(result).toMatchSnapshot(); + }); it(`should get expected balances for ${centrifuge.name}`, async () => { const result = await getParachainBalances(centrifuge, centrifugeAddress); expect(result).toMatchSnapshot(); }); + it(`should get expected balances for ${centrifuge.name} for substrate address`, async () => { + const result = await getParachainBalances(centrifuge, substrateAddress); + expect(result).toMatchSnapshot(); + }); it(`should get expected balances for ${hydraDxAlphanet.name}`, async () => { const result = await getParachainBalances( hydraDxAlphanet, hydraDXAddress, ); + expect(result).toMatchSnapshot(); + }); + it(`should get expected balances for ${hydraDxAlphanet.name} for substrate address`, async () => { + const result = await getParachainBalances( + hydraDxAlphanet, + substrateAddress, + ); + expect(result).toMatchSnapshot(); }); }); From b7c5b857d3385c7cc0e7dafb51862415ab5e8b65 Mon Sep 17 00:00:00 2001 From: Richard Kenigs <18597956+Rihyx@users.noreply.github.com> Date: Wed, 20 Mar 2024 12:53:00 +0100 Subject: [PATCH 18/44] Update packages/sdk/README.md Co-authored-by: mmaurello <93129175+mmaurello@users.noreply.github.com> --- packages/sdk/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/sdk/README.md b/packages/sdk/README.md index 71fd7f49..b20b1bc2 100644 --- a/packages/sdk/README.md +++ b/packages/sdk/README.md @@ -128,7 +128,7 @@ npm run build ``` ```bash -npm link +npm run link ``` In your project where you would like to test the changes: From e31eff4a6a8734f5474e12137cb1bde8dd6d4970 Mon Sep 17 00:00:00 2001 From: Richard Kenigs <18597956+Rihyx@users.noreply.github.com> Date: Wed, 20 Mar 2024 12:53:16 +0100 Subject: [PATCH 19/44] Update packages/sdk/README.md Co-authored-by: mmaurello <93129175+mmaurello@users.noreply.github.com> --- packages/sdk/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/sdk/README.md b/packages/sdk/README.md index b20b1bc2..37ea97e4 100644 --- a/packages/sdk/README.md +++ b/packages/sdk/README.md @@ -134,7 +134,7 @@ npm run link In your project where you would like to test the changes: ```bash -npm link @moonbeam-network/xcm-sdk +npm link @moonbeam-network/xcm-types @moonbeam-network/xcm-utils @moonbeam-network/xcm-builder @moonbeam-network/xcm-config @moonbeam-network/xcm-sdk ``` If you need you can link other packages too. From 8105e8058a410fa9d89463485b93490c1ac988a1 Mon Sep 17 00:00:00 2001 From: Richard Kenigs <18597956+Rihyx@users.noreply.github.com> Date: Wed, 20 Mar 2024 12:53:31 +0100 Subject: [PATCH 20/44] Update packages/sdk/README.md Co-authored-by: mmaurello <93129175+mmaurello@users.noreply.github.com> --- packages/sdk/README.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/sdk/README.md b/packages/sdk/README.md index 37ea97e4..a4b153f8 100644 --- a/packages/sdk/README.md +++ b/packages/sdk/README.md @@ -142,5 +142,5 @@ If you need you can link other packages too. After testing is done, unlink the SDK: ```bash -npm unlink @moonbeam-network/xcm-sdk +npm unlink @moonbeam-network/xcm-types @moonbeam-network/xcm-utils @moonbeam-network/xcm-builder @moonbeam-network/xcm-config @moonbeam-network/xcm-sdk ``` From 5c3f0ee860c8689f4ba6c3f69c26531ffdd803ec Mon Sep 17 00:00:00 2001 From: Richard Kenigs <18597956+Rihyx@users.noreply.github.com> Date: Wed, 20 Mar 2024 12:55:08 +0100 Subject: [PATCH 21/44] Update packages/config/src/chains.ts Co-authored-by: mmaurello <93129175+mmaurello@users.noreply.github.com> --- packages/config/src/chains.ts | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/packages/config/src/chains.ts b/packages/config/src/chains.ts index c1df6a09..9c1908e5 100644 --- a/packages/config/src/chains.ts +++ b/packages/config/src/chains.ts @@ -467,7 +467,7 @@ export const hydraDxAlphanet = new Parachain({ id: 1, }, ], - ecosystem: Ecosystem.Polkadot, + ecosystem: Ecosystem.AlphanetRelay, genesisHash: '0x025980095be141a99f983631c49271af15cab61c4ce0d73db73192443932669a', isTestChain: true, From 2723eba9d348f3678b7c37567bd13193e63bc9eb Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Wed, 20 Mar 2024 13:05:36 +0100 Subject: [PATCH 22/44] fix nativeCurrency --- packages/config/src/chains.ts | 24 ++++++++++++------------ 1 file changed, 12 insertions(+), 12 deletions(-) diff --git a/packages/config/src/chains.ts b/packages/config/src/chains.ts index 9c1908e5..17231904 100644 --- a/packages/config/src/chains.ts +++ b/packages/config/src/chains.ts @@ -332,8 +332,8 @@ export const darwinia = new EvmParachain({ name: 'Darwinia', nativeCurrency: { decimals: 18, - name: 'RING', - symbol: 'RING', + name: ring.originSymbol, + symbol: ring.originSymbol, }, parachainId: 2046, rpc: 'https://rpc.darwinia.network', @@ -363,8 +363,8 @@ export const darwiniaCrab = new EvmParachain({ name: 'Darwinia Crab', nativeCurrency: { decimals: 18, - name: 'CRAB', - symbol: 'CRAB', + name: crab.originSymbol, + symbol: crab.originSymbol, }, parachainId: 2105, rpc: 'https://crab-rpc.darwinia.network', @@ -754,8 +754,8 @@ export const moonbaseAlpha = new EvmParachain({ name: 'Moonbase Alpha', nativeCurrency: { decimals: 18, - name: 'DEV', - symbol: 'DEV', + name: dev.originSymbol, + symbol: dev.originSymbol, }, parachainId: 1000, rpc: 'https://rpc.api.moonbase.moonbeam.network', @@ -789,8 +789,8 @@ export const moonbaseBeta = new EvmParachain({ name: 'Moonbase Beta', nativeCurrency: { decimals: 18, - name: 'DEV', - symbol: 'DEV', + name: dev.originSymbol, + symbol: dev.originSymbol, }, parachainId: 888, rpc: 'https://frag-moonbase-beta-rpc.g.moonbase.moonbeam.network', @@ -966,8 +966,8 @@ export const moonbeam = new EvmParachain({ name: 'Moonbeam', nativeCurrency: { decimals: 18, - name: 'Glimmer', - symbol: 'GLMR', + name: glmr.originSymbol, + symbol: glmr.originSymbol, }, parachainId: 2004, rpc: 'https://rpc.api.moonbeam.network', @@ -1086,8 +1086,8 @@ export const moonriver = new EvmParachain({ name: 'Moonriver', nativeCurrency: { decimals: 18, - name: 'MOVR', - symbol: 'MOVR', + name: movr.originSymbol, + symbol: movr.originSymbol, }, parachainId: 2023, rpc: 'https://rpc.api.moonriver.moonbeam.network', From c6f30e145c388e90199840b0d2abc103951a651d Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Wed, 20 Mar 2024 13:26:50 +0100 Subject: [PATCH 23/44] add usdc wh and ftm wh to moonbase beta --- packages/config/src/chains.ts | 10 ++++++++++ 1 file changed, 10 insertions(+) diff --git a/packages/config/src/chains.ts b/packages/config/src/chains.ts index 17231904..bfe59fbc 100644 --- a/packages/config/src/chains.ts +++ b/packages/config/src/chains.ts @@ -779,6 +779,16 @@ export const moonbaseBeta = new EvmParachain({ balanceId: '85534404031760856987006367174489651085', id: { ForeignAsset: '85534404031760856987006367174489651085' }, }, + { + asset: usdcwh, + balanceId: '319794858556516669238969276945382613133', + id: { ForeignAsset: '319794858556516669238969276945382613133' }, + }, + { + asset: ftmwh, + balanceId: '198801030527939140930753142903035039136', + id: { ForeignAsset: '198801030527939140930753142903035039136' }, + }, ], ecosystem: Ecosystem.AlphanetRelay, genesisHash: From 736d6ed3348edb85732e4aa3634b66d1894a22f5 Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Wed, 20 Mar 2024 13:37:18 +0100 Subject: [PATCH 24/44] add tokens to config --- packages/config/src/configs/moonbaseBeta.ts | 32 ++++++++++++++++++++- 1 file changed, 31 insertions(+), 1 deletion(-) diff --git a/packages/config/src/configs/moonbaseBeta.ts b/packages/config/src/configs/moonbaseBeta.ts index ef9cbadd..006dea49 100644 --- a/packages/config/src/configs/moonbaseBeta.ts +++ b/packages/config/src/configs/moonbaseBeta.ts @@ -2,7 +2,7 @@ import { BalanceBuilder, ExtrinsicBuilder, } from '@moonbeam-network/xcm-builder'; -import { alan, betaDEV, dev } from '../assets'; +import { alan, betaDEV, dev, ftmwh, usdcwh } from '../assets'; import { moonbaseAlpha, moonbaseBeta } from '../chains'; import { AssetConfig } from '../types/AssetConfig'; import { ChainConfig } from '../types/ChainConfig'; @@ -39,6 +39,36 @@ export const moonbaseBetaConfig = new ChainConfig({ balance: BalanceBuilder().substrate().system().account(), }, }), + new AssetConfig({ + asset: usdcwh, + balance: BalanceBuilder().substrate().assets().account(), + destination: moonbaseAlpha, + destinationFee: { + amount: 0.002, + asset: dev, + balance: BalanceBuilder().substrate().system().account(), + }, + extrinsic: ExtrinsicBuilder().xTokens().transferMultiCurrencies(), + fee: { + asset: betaDEV, + balance: BalanceBuilder().substrate().system().account(), + }, + }), + new AssetConfig({ + asset: ftmwh, + balance: BalanceBuilder().substrate().assets().account(), + destination: moonbaseAlpha, + destinationFee: { + amount: 0.002, + asset: dev, + balance: BalanceBuilder().substrate().system().account(), + }, + extrinsic: ExtrinsicBuilder().xTokens().transferMultiCurrencies(), + fee: { + asset: betaDEV, + balance: BalanceBuilder().substrate().system().account(), + }, + }), ], chain: moonbaseBeta, }); From c2be268faf2dcf3dec2c2734838845333d6901d2 Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Wed, 20 Mar 2024 13:49:47 +0100 Subject: [PATCH 25/44] add e2e test for moonbase beta --- .../acceptance/__snapshots__/sdk.test.ts.snap | 33 +++++++++++++++++++ packages/sdk/tests/acceptance/sdk.test.ts | 10 ++++++ 2 files changed, 43 insertions(+) diff --git a/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap b/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap index 691b6efd..69529728 100644 --- a/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap +++ b/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap @@ -198,6 +198,39 @@ exports[`sdk getParachainBalances should get expected balances for HydraDX for s ] `; +exports[`sdk getParachainBalances should get expected balances for Moonbase Beta 1`] = ` +[ + r { + "amount": 0n, + "decimals": 18, + "key": "ftmwh", + "originSymbol": "FTM.wh", + "symbol": "FTM.wh", + }, + r { + "amount": 0n, + "decimals": 6, + "key": "usdcwh", + "originSymbol": "USDC.Wh", + "symbol": "USDC.Wh", + }, + r { + "amount": 12080000000000000000n, + "decimals": 18, + "key": "alan", + "originSymbol": "ALAN", + "symbol": "ALAN", + }, + r { + "amount": 9972701135728000000n, + "decimals": 18, + "key": "dev", + "originSymbol": "DEV", + "symbol": "DEV", + }, +] +`; + exports[`sdk getParachainBalances should get expected balances for Moonbeam 1`] = ` [ r { diff --git a/packages/sdk/tests/acceptance/sdk.test.ts b/packages/sdk/tests/acceptance/sdk.test.ts index 58b12387..c9d46de0 100644 --- a/packages/sdk/tests/acceptance/sdk.test.ts +++ b/packages/sdk/tests/acceptance/sdk.test.ts @@ -3,6 +3,7 @@ import { centrifuge, hydraDX, hydraDxAlphanet, + moonbaseBeta, moonbeam, } from '@moonbeam-network/xcm-config'; import { getParachainBalances } from '../../src/sdk'; @@ -12,6 +13,7 @@ const hydraDXAddress = '7MR8Qxy9sJmN6bfHMggAtFY5DwLxfrssLuTnP5rmkpD92oPH'; const centrifugeAddress = '4fAKSBMGVT9jt1jkuJvXgvMbmqV2BuspFWWEmdVeFj9yRudb'; const moonbeamAddress = '0x4E82143Af671Cc8201Bc7efCBbCED3A69e84405e'; const substrateAddress = '5FtGz8bgoCQ6pNAYLWCfxKx9ekLnX1ewP9q2TjMT2riu7sf9'; +const moonbaseBetaAddress = '0x08480769599E23F626efff39B89F3137e9917a40'; describe('sdk', () => { describe(`${getParachainBalances.name}`, () => { @@ -54,6 +56,14 @@ describe('sdk', () => { substrateAddress, ); + expect(result).toMatchSnapshot(); + }); + it(`should get expected balances for ${moonbaseBeta.name}`, async () => { + const result = await getParachainBalances( + moonbaseBeta, + moonbaseBetaAddress, + ); + expect(result).toMatchSnapshot(); }); }); From c3712a83a2cb75203456b23a782a8e689ae143e3 Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Thu, 21 Mar 2024 09:55:48 +0100 Subject: [PATCH 26/44] add wFTM.wh to moonbase-alpha --- packages/config/src/chains.ts | 4 + packages/config/src/configs/moonbaseAlpha.ts | 30 +++++++- .../acceptance/__snapshots__/sdk.test.ts.snap | 75 +++++++++++++++++++ packages/sdk/tests/acceptance/sdk.test.ts | 6 ++ 4 files changed, 114 insertions(+), 1 deletion(-) diff --git a/packages/config/src/chains.ts b/packages/config/src/chains.ts index bfe59fbc..7d6604d0 100644 --- a/packages/config/src/chains.ts +++ b/packages/config/src/chains.ts @@ -744,6 +744,10 @@ export const moonbaseAlpha = new EvmParachain({ asset: unit, id: '42259045809535163221576417993425387648', }, + { + asset: ftmwh, + id: '0x566c1cebc6A4AFa1C122E039C4BEBe77043148Ee', + }, ], ecosystem: Ecosystem.AlphanetRelay, genesisHash: diff --git a/packages/config/src/configs/moonbaseAlpha.ts b/packages/config/src/configs/moonbaseAlpha.ts index 357c5a50..1169d1c2 100644 --- a/packages/config/src/configs/moonbaseAlpha.ts +++ b/packages/config/src/configs/moonbaseAlpha.ts @@ -1,8 +1,21 @@ import { BalanceBuilder, ContractBuilder } from '@moonbeam-network/xcm-builder'; -import { alan, ampe, atom, dev, otp, pica, tt1, tur, unit } from '../assets'; +import { + alan, + ampe, + atom, + dev, + ftmwh, + hdx, + otp, + pica, + tt1, + tur, + unit, +} from '../assets'; import { alphanetAssetHub, alphanetRelay, + hydraDxAlphanet, moonbaseAlpha, moonbaseBeta, originTrailAlphanet, @@ -194,6 +207,21 @@ export const moonbaseAlphaConfig = new ChainConfig({ balance: BalanceBuilder().substrate().system().account(), }, }), + new AssetConfig({ + asset: ftmwh, + balance: BalanceBuilder().evm().erc20(), + contract: ContractBuilder().Xtokens().transfer(), + destination: hydraDxAlphanet, + destinationFee: { + amount: 0.1, // not sure + asset: hdx, + balance: BalanceBuilder().substrate().system().account(), + }, + fee: { + asset: dev, + balance: BalanceBuilder().substrate().system().account(), + }, + }), ], chain: moonbaseAlpha, }); diff --git a/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap b/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap index 69529728..6e17ff28 100644 --- a/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap +++ b/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap @@ -198,6 +198,81 @@ exports[`sdk getParachainBalances should get expected balances for HydraDX for s ] `; +exports[`sdk getParachainBalances should get expected balances for Moonbase Alpha 1`] = ` +[ + r { + "amount": 0n, + "decimals": 18, + "key": "ftmwh", + "originSymbol": "FTM.wh", + "symbol": "FTM.wh", + }, + r { + "amount": 0n, + "decimals": 12, + "key": "unit", + "originSymbol": "Unit", + "symbol": "Unit", + }, + r { + "amount": 0n, + "decimals": 10, + "key": "tur", + "originSymbol": "TUR", + "symbol": "TUR", + }, + r { + "amount": 0n, + "decimals": 18, + "key": "tt1", + "originSymbol": "TT1", + "symbol": "TT1", + }, + r { + "amount": 0n, + "decimals": 12, + "key": "pica", + "originSymbol": "PICA", + "symbol": "PICA", + }, + r { + "amount": 0n, + "decimals": 6, + "key": "atom", + "originSymbol": "ATOM", + "symbol": "ATOM", + }, + r { + "amount": 0n, + "decimals": 12, + "key": "otp", + "originSymbol": "OTP", + "symbol": "OTP", + }, + r { + "amount": 0n, + "decimals": 12, + "key": "ampe", + "originSymbol": "AMPE", + "symbol": "AMPE", + }, + r { + "amount": 0n, + "decimals": 18, + "key": "alan", + "originSymbol": "ALAN", + "symbol": "ALAN", + }, + r { + "amount": 0n, + "decimals": 18, + "key": "dev", + "originSymbol": "DEV", + "symbol": "DEV", + }, +] +`; + exports[`sdk getParachainBalances should get expected balances for Moonbase Beta 1`] = ` [ r { diff --git a/packages/sdk/tests/acceptance/sdk.test.ts b/packages/sdk/tests/acceptance/sdk.test.ts index c9d46de0..8828d423 100644 --- a/packages/sdk/tests/acceptance/sdk.test.ts +++ b/packages/sdk/tests/acceptance/sdk.test.ts @@ -3,6 +3,7 @@ import { centrifuge, hydraDX, hydraDxAlphanet, + moonbaseAlpha, moonbaseBeta, moonbeam, } from '@moonbeam-network/xcm-config'; @@ -64,6 +65,11 @@ describe('sdk', () => { moonbaseBetaAddress, ); + expect(result).toMatchSnapshot(); + }); + it(`should get expected balances for ${moonbaseAlpha.name}`, async () => { + const result = await getParachainBalances(moonbaseAlpha, moonbeamAddress); + expect(result).toMatchSnapshot(); }); }); From 7aafa02e5cbf893f9c48acb8f1b4e3b37eeecd90 Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Thu, 21 Mar 2024 11:01:10 +0100 Subject: [PATCH 27/44] fix erc20 contract call --- packages/sdk/src/contract/contracts/Erc20/Erc20Public.ts | 2 +- packages/sdk/src/getTransferData/getTransferData.utils.ts | 4 +++- .../sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap | 6 +++--- 3 files changed, 7 insertions(+), 5 deletions(-) diff --git a/packages/sdk/src/contract/contracts/Erc20/Erc20Public.ts b/packages/sdk/src/contract/contracts/Erc20/Erc20Public.ts index adf6adec..bb40a652 100644 --- a/packages/sdk/src/contract/contracts/Erc20/Erc20Public.ts +++ b/packages/sdk/src/contract/contracts/Erc20/Erc20Public.ts @@ -28,7 +28,7 @@ export class Erc20Public implements BalanceContractInterface { const data = await this.#publicClient.readContract({ abi, address: this.#config.address as `0x${string}`, - args: [this.address], + args: this.#config.args, functionName: 'balanceOf', }); diff --git a/packages/sdk/src/getTransferData/getTransferData.utils.ts b/packages/sdk/src/getTransferData/getTransferData.utils.ts index ec989cd3..d2a68635 100644 --- a/packages/sdk/src/getTransferData/getTransferData.utils.ts +++ b/packages/sdk/src/getTransferData/getTransferData.utils.ts @@ -45,7 +45,9 @@ export async function getBalance({ chain as EvmParachain, ) as BalanceContractInterface; - return contract.getBalance(); + const balance = await contract.getBalance(); + + return balance; } export async function getDecimals({ diff --git a/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap b/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap index 6e17ff28..b9316698 100644 --- a/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap +++ b/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap @@ -201,7 +201,7 @@ exports[`sdk getParachainBalances should get expected balances for HydraDX for s exports[`sdk getParachainBalances should get expected balances for Moonbase Alpha 1`] = ` [ r { - "amount": 0n, + "amount": 1234567890000000000n, "decimals": 18, "key": "ftmwh", "originSymbol": "FTM.wh", @@ -264,7 +264,7 @@ exports[`sdk getParachainBalances should get expected balances for Moonbase Alph "symbol": "ALAN", }, r { - "amount": 0n, + "amount": 6543210000000000000n, "decimals": 18, "key": "dev", "originSymbol": "DEV", @@ -386,7 +386,7 @@ exports[`sdk getParachainBalances should get expected balances for Moonbeam 1`] "symbol": "USDT.Wh", }, r { - "amount": 374573n, + "amount": 0n, "decimals": 6, "key": "usdcwh", "originSymbol": "USDC.Wh", From 04f22adbd2e763279b3759b58d28ccd16438fd1a Mon Sep 17 00:00:00 2001 From: Mario J Maurello Date: Thu, 21 Mar 2024 22:13:16 +1300 Subject: [PATCH 28/44] add missing configurations for moonbase-alpha --- packages/config/src/chains.ts | 8 ++++++++ packages/config/src/configs/moonbaseAlpha.ts | 18 +++++++++++++++++- 2 files changed, 25 insertions(+), 1 deletion(-) diff --git a/packages/config/src/chains.ts b/packages/config/src/chains.ts index 7d6604d0..11f0657e 100644 --- a/packages/config/src/chains.ts +++ b/packages/config/src/chains.ts @@ -748,6 +748,14 @@ export const moonbaseAlpha = new EvmParachain({ asset: ftmwh, id: '0x566c1cebc6A4AFa1C122E039C4BEBe77043148Ee', }, + { + asset: hdx, + id: '69606720909260275826784788104880799692', + }, + { + asset: usdcwh, + id: '0xD909178CC99d318e4D46e7E66a972955859670E1', + }, ], ecosystem: Ecosystem.AlphanetRelay, genesisHash: diff --git a/packages/config/src/configs/moonbaseAlpha.ts b/packages/config/src/configs/moonbaseAlpha.ts index 1169d1c2..0742e00c 100644 --- a/packages/config/src/configs/moonbaseAlpha.ts +++ b/packages/config/src/configs/moonbaseAlpha.ts @@ -11,6 +11,7 @@ import { tt1, tur, unit, + usdcwh, } from '../assets'; import { alphanetAssetHub, @@ -207,13 +208,28 @@ export const moonbaseAlphaConfig = new ChainConfig({ balance: BalanceBuilder().substrate().system().account(), }, }), + new AssetConfig({ + asset: usdcwh, + balance: BalanceBuilder().evm().erc20(), + contract: ContractBuilder().Xtokens().transfer(), + destination: hydraDxAlphanet, + destinationFee: { + amount: 0.1, + asset: hdx, + balance: BalanceBuilder().substrate().system().account(), + }, + fee: { + asset: dev, + balance: BalanceBuilder().substrate().system().account(), + }, + }), new AssetConfig({ asset: ftmwh, balance: BalanceBuilder().evm().erc20(), contract: ContractBuilder().Xtokens().transfer(), destination: hydraDxAlphanet, destinationFee: { - amount: 0.1, // not sure + amount: 0.1, asset: hdx, balance: BalanceBuilder().substrate().system().account(), }, From 719c6dc994fe2ba59a10727c2086fe4a3e090651 Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Thu, 21 Mar 2024 12:03:45 +0100 Subject: [PATCH 29/44] add usdc.wh contract address --- packages/config/src/chains.ts | 2 +- .../sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap | 7 +++++++ 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/packages/config/src/chains.ts b/packages/config/src/chains.ts index 11f0657e..af4dfd30 100644 --- a/packages/config/src/chains.ts +++ b/packages/config/src/chains.ts @@ -754,7 +754,7 @@ export const moonbaseAlpha = new EvmParachain({ }, { asset: usdcwh, - id: '0xD909178CC99d318e4D46e7E66a972955859670E1', + id: '0xE5dE10C4b744bac6b783fAF8d9B9fDFF14Acc3c9', }, ], ecosystem: Ecosystem.AlphanetRelay, diff --git a/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap b/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap index b9316698..e26b0921 100644 --- a/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap +++ b/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap @@ -207,6 +207,13 @@ exports[`sdk getParachainBalances should get expected balances for Moonbase Alph "originSymbol": "FTM.wh", "symbol": "FTM.wh", }, + r { + "amount": 10000n, + "decimals": 6, + "key": "usdcwh", + "originSymbol": "USDC.Wh", + "symbol": "USDC.Wh", + }, r { "amount": 0n, "decimals": 12, From 82ce0a98774b5a44bc0128c4779b55a165a12875 Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Thu, 21 Mar 2024 12:12:42 +0100 Subject: [PATCH 30/44] update snapshots --- .../sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap | 2 +- packages/sdk/tests/acceptance/sdk.test.ts | 6 +++--- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap b/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap index e26b0921..9fb89f8a 100644 --- a/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap +++ b/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap @@ -264,7 +264,7 @@ exports[`sdk getParachainBalances should get expected balances for Moonbase Alph "symbol": "AMPE", }, r { - "amount": 0n, + "amount": 10000000000000000n, "decimals": 18, "key": "alan", "originSymbol": "ALAN", diff --git a/packages/sdk/tests/acceptance/sdk.test.ts b/packages/sdk/tests/acceptance/sdk.test.ts index 8828d423..f18a6576 100644 --- a/packages/sdk/tests/acceptance/sdk.test.ts +++ b/packages/sdk/tests/acceptance/sdk.test.ts @@ -12,14 +12,14 @@ import { getParachainBalances } from '../../src/sdk'; // E2E balance test wallet const hydraDXAddress = '7MR8Qxy9sJmN6bfHMggAtFY5DwLxfrssLuTnP5rmkpD92oPH'; const centrifugeAddress = '4fAKSBMGVT9jt1jkuJvXgvMbmqV2BuspFWWEmdVeFj9yRudb'; -const moonbeamAddress = '0x4E82143Af671Cc8201Bc7efCBbCED3A69e84405e'; +const moonEvmAddress = '0x4E82143Af671Cc8201Bc7efCBbCED3A69e84405e'; const substrateAddress = '5FtGz8bgoCQ6pNAYLWCfxKx9ekLnX1ewP9q2TjMT2riu7sf9'; const moonbaseBetaAddress = '0x08480769599E23F626efff39B89F3137e9917a40'; describe('sdk', () => { describe(`${getParachainBalances.name}`, () => { it(`should get expected balances for ${moonbeam.name}`, async () => { - const result = await getParachainBalances(moonbeam, moonbeamAddress); + const result = await getParachainBalances(moonbeam, moonEvmAddress); expect(result).toMatchSnapshot(); }); @@ -68,7 +68,7 @@ describe('sdk', () => { expect(result).toMatchSnapshot(); }); it(`should get expected balances for ${moonbaseAlpha.name}`, async () => { - const result = await getParachainBalances(moonbaseAlpha, moonbeamAddress); + const result = await getParachainBalances(moonbaseAlpha, moonEvmAddress); expect(result).toMatchSnapshot(); }); From 38580844cfec8df8c88a412372cd753a42b50bf9 Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Tue, 2 Apr 2024 11:15:40 +0200 Subject: [PATCH 31/44] add DEV -> HydraDX Alpha to config --- packages/config/src/configs/moonbaseAlpha.ts | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/packages/config/src/configs/moonbaseAlpha.ts b/packages/config/src/configs/moonbaseAlpha.ts index 0742e00c..2beca035 100644 --- a/packages/config/src/configs/moonbaseAlpha.ts +++ b/packages/config/src/configs/moonbaseAlpha.ts @@ -238,6 +238,17 @@ export const moonbaseAlphaConfig = new ChainConfig({ balance: BalanceBuilder().substrate().system().account(), }, }), + new AssetConfig({ + asset: dev, + balance: BalanceBuilder().substrate().system().account(), + contract: ContractBuilder().Xtokens().transfer(), + destination: hydraDxAlphanet, + destinationFee: { + amount: 0.0002, + asset: dev, + balance: BalanceBuilder().substrate().system().account(), + }, + }), ], chain: moonbaseAlpha, }); From c7de67fd347aca17968f03f54220da3672e77160 Mon Sep 17 00:00:00 2001 From: Mario J Maurello Date: Mon, 8 Apr 2024 21:42:32 +1200 Subject: [PATCH 32/44] fix integrations --- packages/config/src/chains.ts | 2 ++ packages/config/src/configs/moonbaseAlpha.ts | 25 +++++++++++++++---- packages/sdk/src/contract/contract.factory.ts | 14 +++++++++-- .../getTransferData/getTransferData.utils.ts | 21 ++++++++-------- 4 files changed, 44 insertions(+), 18 deletions(-) diff --git a/packages/config/src/chains.ts b/packages/config/src/chains.ts index 3a629f2d..a69116bc 100644 --- a/packages/config/src/chains.ts +++ b/packages/config/src/chains.ts @@ -747,6 +747,7 @@ export const moonbaseAlpha = new EvmParachain({ { asset: ftmwh, id: '0x566c1cebc6A4AFa1C122E039C4BEBe77043148Ee', + metadataId: 0, // no metadata for ERC20 tokens }, { asset: hdx, @@ -755,6 +756,7 @@ export const moonbaseAlpha = new EvmParachain({ { asset: usdcwh, id: '0xE5dE10C4b744bac6b783fAF8d9B9fDFF14Acc3c9', + metadataId: 0, // no metadata for ERC20 tokens }, ], ecosystem: Ecosystem.AlphanetRelay, diff --git a/packages/config/src/configs/moonbaseAlpha.ts b/packages/config/src/configs/moonbaseAlpha.ts index 2beca035..92277e33 100644 --- a/packages/config/src/configs/moonbaseAlpha.ts +++ b/packages/config/src/configs/moonbaseAlpha.ts @@ -215,8 +215,8 @@ export const moonbaseAlphaConfig = new ChainConfig({ destination: hydraDxAlphanet, destinationFee: { amount: 0.1, - asset: hdx, - balance: BalanceBuilder().substrate().system().account(), + asset: usdcwh, + balance: BalanceBuilder().evm().erc20(), }, fee: { asset: dev, @@ -229,9 +229,9 @@ export const moonbaseAlphaConfig = new ChainConfig({ contract: ContractBuilder().Xtokens().transfer(), destination: hydraDxAlphanet, destinationFee: { - amount: 0.1, - asset: hdx, - balance: BalanceBuilder().substrate().system().account(), + amount: 0.01, + asset: ftmwh, + balance: BalanceBuilder().evm().erc20(), }, fee: { asset: dev, @@ -249,6 +249,21 @@ export const moonbaseAlphaConfig = new ChainConfig({ balance: BalanceBuilder().substrate().system().account(), }, }), + new AssetConfig({ + asset: hdx, + balance: BalanceBuilder().substrate().assets().account(), + contract: ContractBuilder().Xtokens().transfer(), + destination: hydraDxAlphanet, + destinationFee: { + amount: 0.5, + asset: hdx, + balance: BalanceBuilder().substrate().system().account(), + }, + fee: { + asset: dev, + balance: BalanceBuilder().substrate().system().account(), + }, + }), ], chain: moonbaseAlpha, }); diff --git a/packages/sdk/src/contract/contract.factory.ts b/packages/sdk/src/contract/contract.factory.ts index 0ef0be76..2fae09ff 100644 --- a/packages/sdk/src/contract/contract.factory.ts +++ b/packages/sdk/src/contract/contract.factory.ts @@ -1,5 +1,5 @@ import { ContractConfig } from '@moonbeam-network/xcm-builder'; -import { EvmParachain } from '@moonbeam-network/xcm-types'; +import { AnyChain, EvmParachain } from '@moonbeam-network/xcm-types'; import { EvmSigner } from '../sdk.interfaces'; import { BalanceContractInterface, @@ -8,7 +8,7 @@ import { import { Erc20, Xtokens } from './contracts'; import { Erc20Public } from './contracts/Erc20/Erc20Public'; -export function createContract( +export function createContractWithSigner( config: ContractConfig, signer: EvmSigner, ): TransferContractInterface | BalanceContractInterface { @@ -33,3 +33,13 @@ export function createContractWithoutSigner( throw new Error(`Public Contract ${config.module} not found`); } + +export function createContract( + config: ContractConfig, + signer: EvmSigner | undefined, + chain?: AnyChain, +): TransferContractInterface | BalanceContractInterface { + return signer + ? createContractWithSigner(config, signer) + : createContractWithoutSigner(config, chain as EvmParachain); +} diff --git a/packages/sdk/src/getTransferData/getTransferData.utils.ts b/packages/sdk/src/getTransferData/getTransferData.utils.ts index d2a68635..71301846 100644 --- a/packages/sdk/src/getTransferData/getTransferData.utils.ts +++ b/packages/sdk/src/getTransferData/getTransferData.utils.ts @@ -1,11 +1,8 @@ import { CallType, SubstrateQueryConfig } from '@moonbeam-network/xcm-builder'; import { AssetConfig } from '@moonbeam-network/xcm-config'; -import { AnyChain, Asset, EvmParachain } from '@moonbeam-network/xcm-types'; +import { AnyChain, Asset } from '@moonbeam-network/xcm-types'; import { convertDecimals, toBigInt } from '@moonbeam-network/xcm-utils'; -import { - BalanceContractInterface, - createContractWithoutSigner, -} from '../contract'; +import { BalanceContractInterface, createContract } from '../contract'; import { PolkadotService } from '../polkadot'; import { EvmSigner } from '../sdk.interfaces'; @@ -26,13 +23,13 @@ export async function getBalance({ chain, config, decimals, + evmSigner, polkadot, }: GetBalancesParams) { const cfg = config.balance.build({ address, asset: polkadot.chain.getBalanceAssetId(config.asset), }); - if (cfg.type === CallType.Substrate) { const balance = await polkadot.query(cfg as SubstrateQueryConfig); return chain.usesChainDecimals @@ -40,9 +37,10 @@ export async function getBalance({ : balance; } - const contract = createContractWithoutSigner( + const contract = createContract( cfg, - chain as EvmParachain, + evmSigner, + chain, ) as BalanceContractInterface; const balance = await contract.getBalance(); @@ -55,20 +53,21 @@ export async function getDecimals({ asset, config, polkadot, + evmSigner, chain, }: GetDecimalsParams) { const cfg = config.balance.build({ address, asset: polkadot.chain.getBalanceAssetId(asset || config.asset), }); - if (cfg.type === CallType.Substrate) { return polkadot.getAssetDecimals(asset || config.asset); } - const contract = createContractWithoutSigner( + const contract = createContract( cfg, - chain as EvmParachain, + evmSigner, + chain, ) as BalanceContractInterface; return contract.getDecimals(); From e2cfa1ec918454454d7ac18b5146ed3e18030044 Mon Sep 17 00:00:00 2001 From: Elmar Kenigs Date: Fri, 12 Apr 2024 11:32:11 +0300 Subject: [PATCH 33/44] Updated deps and ESLint, TypeScript fixes --- .eslintrc.json | 19 +- package-lock.json | 3109 +++++++++-------- package.json | 23 +- packages/builder/package.json | 3 +- .../src/asset-min/AssetMinBuilder.test.ts | 1 + .../builder/src/asset-min/AssetMinBuilder.ts | 2 + .../src/balance/BalanceBuilder.test.ts | 1 + .../builder/src/balance/BalanceBuilder.ts | 2 + .../builder/src/contract/ContractConfig.ts | 2 + .../builder/src/extrinsic/ExtrinsicConfig.ts | 2 + .../pallets/eqBalances/eqBalances.test.ts | 2 + .../pallets/polkadotXcm/polkadotXcm.test.ts | 1 + .../pallets/polkadotXcm/polkadotXcm.util.ts | 2 + .../extrinsic/pallets/xTokens/xTokens.test.ts | 1 + .../pallets/xTransfer/xTransfer.test.ts | 1 + .../pallets/xcmPallet/xcmPallet.test.ts | 1 + packages/builder/src/fee/FeeBuilder.ts | 1 + .../types/substrate/SubstrateCallConfig.ts | 1 + .../types/substrate/SubstrateQueryConfig.ts | 6 +- .../src/ConfigBuilder/ConfigBuilder.test.ts | 1 + .../src/ConfigService/ConfigService.test.ts | 1 + packages/sdk/package.json | 2 +- .../src/contract/contracts/Xtokens/Xtokens.ts | 1 + packages/types/package.json | 3 +- .../src/chain/parachain/EvmParachain.test.ts | 1 + .../src/chain/parachain/Parachain.test.ts | 1 + .../types/src/chain/parachain/Parachain.ts | 2 +- packages/types/src/common.interfaces.ts | 2 + packages/types/src/index.ts | 1 + packages/utils/src/numbers/decimals.test.ts | 1 + .../src/polkadot/polkadot.address.test.ts | 1 + 31 files changed, 1712 insertions(+), 1485 deletions(-) create mode 100644 packages/types/src/common.interfaces.ts diff --git a/.eslintrc.json b/.eslintrc.json index a267bd88..33797d96 100644 --- a/.eslintrc.json +++ b/.eslintrc.json @@ -1,9 +1,14 @@ { - "extends": ["airbnb-base", "airbnb-typescript/base", "prettier"], - "plugins": [ - // this should be last + "extends": [ + "airbnb-base", + "airbnb-typescript/base", + "plugin:@typescript-eslint/recommended", + "plugin:import/errors", + "plugin:import/warnings", + "plugin:import/typescript", "prettier" ], + "plugins": ["@typescript-eslint", "import", "prettier"], "parserOptions": { "project": "./tsconfig.json" }, @@ -25,6 +30,12 @@ "sort-keys": ["error"], "import/prefer-default-export": "off", "import/no-default-export": "error", - "import/no-cycle": "off" + "import/no-unresolved": "error", + "import/no-cycle": [ + 2, + { + "maxDepth": "∞" + } + ] } } diff --git a/package-lock.json b/package-lock.json index e6b7243a..93e59c42 100644 --- a/package-lock.json +++ b/package-lock.json @@ -18,23 +18,24 @@ "@polkadot/util-crypto": "^12.5.1" }, "devDependencies": { - "@changesets/changelog-github": "^0.4.8", + "@changesets/changelog-github": "^0.5.0", "@changesets/cli": "^2.27.1", "@slack/webhook": "^7.0.2", - "@types/jest": "^29.5.11", - "@typescript-eslint/eslint-plugin": "^7.2.0", - "@typescript-eslint/parser": "^7.2.0", - "bun": "^1.0.21", + "@types/jest": "^29.5.12", + "@typescript-eslint/eslint-plugin": "^7.6.0", + "@typescript-eslint/parser": "^7.6.0", + "bun": "^1.1.3", "dotenv": "^16.4.5", "eslint": "^8.57.0", "eslint-config-airbnb-base": "^15.0.0", "eslint-config-airbnb-typescript": "^18.0.0", "eslint-config-prettier": "^9.1.0", + "eslint-import-resolver-typescript": "^3.6.1", "eslint-plugin-import": "^2.29.1", - "eslint-plugin-jest": "^27.9.0", + "eslint-plugin-jest": "^28.2.0", "eslint-plugin-prettier": "^5.1.3", - "ethers": "^6.11.0", - "glob": "^10.3.10", + "ethers": "^6.11.1", + "glob": "^10.3.12", "husky": "^9.0.11", "jest": "^29.7.0", "lint-staged": "^15.2.2", @@ -42,9 +43,9 @@ "ts-jest": "^29.1.2", "ts-node": "^10.9.2", "tsup": "^8.0.2", - "turbo": "^1.12.5", - "typescript": "^5.4.2", - "viem": "^2.7.8" + "turbo": "^1.13.2", + "typescript": "^5.4.5", + "viem": "^2.9.16" } }, "examples/sdk-simple": { @@ -78,61 +79,61 @@ } }, "node_modules/@adraffy/ens-normalize": { - "version": "1.10.0", - "resolved": "https://registry.npmjs.org/@adraffy/ens-normalize/-/ens-normalize-1.10.0.tgz", - "integrity": "sha512-nA9XHtlAkYfJxY7bce8DcN7eKxWWCWkU+1GR9d+U6MbNpfwQp8TI7vqOsBsMcHoT4mBu2kypKoSKnghEzOOq5Q==" + "version": "1.10.1", + "resolved": "https://registry.npmjs.org/@adraffy/ens-normalize/-/ens-normalize-1.10.1.tgz", + "integrity": "sha512-96Z2IP3mYmF1Xg2cDm8f1gWGf/HUVedQ3FMifV4kG/PQ4yEP51xDtRAEfhVNt5f/uzpNkZHwWQuUcu6D6K+Ekw==" }, "node_modules/@ampproject/remapping": { - "version": "2.2.1", - "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.2.1.tgz", - "integrity": "sha512-lFMjJTrFL3j7L9yBxwYfCq2k6qqwHyzuUl/XBnif78PWTJYyL/dfowQHWE3sp6U6ZzqWiiIZnpTMO96zhkjwtg==", + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/@ampproject/remapping/-/remapping-2.3.0.tgz", + "integrity": "sha512-30iZtAPgz+LTIYoeivqYo853f02jBYSd5uGnGpkFV0M3xOt9aN73erkgYAmZU43x4VfqcnLxW9Kpg3R5LC4YYw==", "dev": true, "dependencies": { - "@jridgewell/gen-mapping": "^0.3.0", - "@jridgewell/trace-mapping": "^0.3.9" + "@jridgewell/gen-mapping": "^0.3.5", + "@jridgewell/trace-mapping": "^0.3.24" }, "engines": { "node": ">=6.0.0" } }, "node_modules/@babel/code-frame": { - "version": "7.23.5", - "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.23.5.tgz", - "integrity": "sha512-CgH3s1a96LipHCmSUmYFPwY7MNx8C3avkq7i4Wl3cfa662ldtUe4VM1TPXX70pfmrlWTb6jLqTYrZyT2ZTJBgA==", + "version": "7.24.2", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.24.2.tgz", + "integrity": "sha512-y5+tLQyV8pg3fsiln67BVLD1P13Eg4lh5RW9mF0zUuvLrv9uIQ4MCL+CRT+FTsBlBjcIan6PGsLcBN0m3ClUyQ==", "dev": true, "dependencies": { - "@babel/highlight": "^7.23.4", - "chalk": "^2.4.2" + "@babel/highlight": "^7.24.2", + "picocolors": "^1.0.0" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/compat-data": { - "version": "7.23.5", - "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.23.5.tgz", - "integrity": "sha512-uU27kfDRlhfKl+w1U6vp16IuvSLtjAxdArVXPa9BvLkrr7CYIsxH5adpHObeAGY/41+syctUWOZ140a2Rvkgjw==", + "version": "7.24.4", + "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.24.4.tgz", + "integrity": "sha512-vg8Gih2MLK+kOkHJp4gBEIkyaIi00jgWot2D9QOmmfLC8jINSOzmCLta6Bvz/JSBCqnegV0L80jhxkol5GWNfQ==", "dev": true, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/core": { - "version": "7.23.7", - "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.23.7.tgz", - "integrity": "sha512-+UpDgowcmqe36d4NwqvKsyPMlOLNGMsfMmQ5WGCu+siCe3t3dfe9njrzGfdN4qq+bcNUt0+Vw6haRxBOycs4dw==", + "version": "7.24.4", + "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.24.4.tgz", + "integrity": "sha512-MBVlMXP+kkl5394RBLSxxk/iLTeVGuXTV3cIDXavPpMMqnSnt6apKgan/U8O3USWZCWZT/TbgfEpKa4uMgN4Dg==", "dev": true, "dependencies": { "@ampproject/remapping": "^2.2.0", - "@babel/code-frame": "^7.23.5", - "@babel/generator": "^7.23.6", + "@babel/code-frame": "^7.24.2", + "@babel/generator": "^7.24.4", "@babel/helper-compilation-targets": "^7.23.6", "@babel/helper-module-transforms": "^7.23.3", - "@babel/helpers": "^7.23.7", - "@babel/parser": "^7.23.6", - "@babel/template": "^7.22.15", - "@babel/traverse": "^7.23.7", - "@babel/types": "^7.23.6", + "@babel/helpers": "^7.24.4", + "@babel/parser": "^7.24.4", + "@babel/template": "^7.24.0", + "@babel/traverse": "^7.24.1", + "@babel/types": "^7.24.0", "convert-source-map": "^2.0.0", "debug": "^4.1.0", "gensync": "^1.0.0-beta.2", @@ -157,14 +158,14 @@ } }, "node_modules/@babel/generator": { - "version": "7.23.6", - "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.23.6.tgz", - "integrity": "sha512-qrSfCYxYQB5owCmGLbl8XRpX1ytXlpueOb0N0UmQwA073KZxejgQTzAmJezxvpwQD9uGtK2shHdi55QT+MbjIw==", + "version": "7.24.4", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.24.4.tgz", + "integrity": "sha512-Xd6+v6SnjWVx/nus+y0l1sxMOTOMBkyL4+BIdbALyatQnAe/SRVjANeDPSCYaX+i1iJmuGSKf3Z+E+V/va1Hvw==", "dev": true, "dependencies": { - "@babel/types": "^7.23.6", - "@jridgewell/gen-mapping": "^0.3.2", - "@jridgewell/trace-mapping": "^0.3.17", + "@babel/types": "^7.24.0", + "@jridgewell/gen-mapping": "^0.3.5", + "@jridgewell/trace-mapping": "^0.3.25", "jsesc": "^2.5.1" }, "engines": { @@ -231,12 +232,12 @@ } }, "node_modules/@babel/helper-module-imports": { - "version": "7.22.15", - "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.22.15.tgz", - "integrity": "sha512-0pYVBnDKZO2fnSPCrgM/6WMc7eS20Fbok+0r88fp+YtWVLZrp4CkafFGIp+W0VKw4a22sgebPT99y+FDNMdP4w==", + "version": "7.24.3", + "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.24.3.tgz", + "integrity": "sha512-viKb0F9f2s0BCS22QSF308z/+1YWKV/76mwt61NBzS5izMzDPwdq1pTrzf+Li3npBWX9KdQbkeCt1jSAM7lZqg==", "dev": true, "dependencies": { - "@babel/types": "^7.22.15" + "@babel/types": "^7.24.0" }, "engines": { "node": ">=6.9.0" @@ -262,9 +263,9 @@ } }, "node_modules/@babel/helper-plugin-utils": { - "version": "7.22.5", - "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.22.5.tgz", - "integrity": "sha512-uLls06UVKgFG9QD4OeFYLEGteMIAa5kpTPcFL28yuCIIzsf6ZyKZMllKVOCZFhiZ5ptnwX4mtKdWCBE/uT4amg==", + "version": "7.24.0", + "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.24.0.tgz", + "integrity": "sha512-9cUznXMG0+FxRuJfvL82QlTqIzhVW9sL0KjMPHhAOOvpQGL8QtdxnBKILjBqxlHyliz0yCa1G903ZXI/FuHy2w==", "dev": true, "engines": { "node": ">=6.9.0" @@ -295,9 +296,9 @@ } }, "node_modules/@babel/helper-string-parser": { - "version": "7.23.4", - "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.23.4.tgz", - "integrity": "sha512-803gmbQdqwdf4olxrX4AJyFBV/RTr3rSmOj0rKwesmzlfhYNDEs+/iOcznzpNWlJlIlTJC2QfPFcHB6DlzdVLQ==", + "version": "7.24.1", + "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.24.1.tgz", + "integrity": "sha512-2ofRCjnnA9y+wk8b9IAREroeUP02KHp431N2mhKniy2yKIDKpbrHv9eXwm8cBeWQYcJmzv5qKCu65P47eCF7CQ==", "dev": true, "engines": { "node": ">=6.9.0" @@ -322,37 +323,38 @@ } }, "node_modules/@babel/helpers": { - "version": "7.23.7", - "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.23.7.tgz", - "integrity": "sha512-6AMnjCoC8wjqBzDHkuqpa7jAKwvMo4dC+lr/TFBz+ucfulO1XMpDnwWPGBNwClOKZ8h6xn5N81W/R5OrcKtCbQ==", + "version": "7.24.4", + "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.24.4.tgz", + "integrity": "sha512-FewdlZbSiwaVGlgT1DPANDuCHaDMiOo+D/IDYRFYjHOuv66xMSJ7fQwwODwRNAPkADIO/z1EoF/l2BCWlWABDw==", "dev": true, "dependencies": { - "@babel/template": "^7.22.15", - "@babel/traverse": "^7.23.7", - "@babel/types": "^7.23.6" + "@babel/template": "^7.24.0", + "@babel/traverse": "^7.24.1", + "@babel/types": "^7.24.0" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/highlight": { - "version": "7.23.4", - "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.23.4.tgz", - "integrity": "sha512-acGdbYSfp2WheJoJm/EBBBLh/ID8KDc64ISZ9DYtBmC8/Q204PZJLHyzeB5qMzJ5trcOkybd78M4x2KWsUq++A==", + "version": "7.24.2", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.24.2.tgz", + "integrity": "sha512-Yac1ao4flkTxTteCDZLEvdxg2fZfz1v8M4QpaGypq/WPDqg3ijHYbDfs+LG5hvzSoqaSZ9/Z9lKSP3CjZjv+pA==", "dev": true, "dependencies": { "@babel/helper-validator-identifier": "^7.22.20", "chalk": "^2.4.2", - "js-tokens": "^4.0.0" + "js-tokens": "^4.0.0", + "picocolors": "^1.0.0" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/parser": { - "version": "7.23.6", - "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.23.6.tgz", - "integrity": "sha512-Z2uID7YJ7oNvAI20O9X0bblw7Qqs8Q2hFy0R9tAfnfLkp5MW0UH9eUvnDSnFwKZ0AvgS1ucqR4KzvVHgnke1VQ==", + "version": "7.24.4", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.24.4.tgz", + "integrity": "sha512-zTvEBcghmeBma9QIGunWevvBAp4/Qu9Bdq+2k0Ot4fVMD6v3dsC9WOcRSKk7tRRyBM/53yKMJko9xOatGQAwSg==", "dev": true, "bin": { "parser": "bin/babel-parser.js" @@ -422,12 +424,12 @@ } }, "node_modules/@babel/plugin-syntax-jsx": { - "version": "7.23.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.23.3.tgz", - "integrity": "sha512-EB2MELswq55OHUoRZLGg/zC7QWUKfNLpE57m/S2yr1uEneIgsTgrSzXP3NXEsMkVn76OlaVVnzN+ugObuYGwhg==", + "version": "7.24.1", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.24.1.tgz", + "integrity": "sha512-2eCtxZXf+kbkMIsXS4poTvT4Yu5rXiRa+9xGVT56raghjmBTKMpFNc9R4IDiB4emao9eO22Ox7CxuJG7BgExqA==", "dev": true, "dependencies": { - "@babel/helper-plugin-utils": "^7.22.5" + "@babel/helper-plugin-utils": "^7.24.0" }, "engines": { "node": ">=6.9.0" @@ -524,12 +526,12 @@ } }, "node_modules/@babel/plugin-syntax-typescript": { - "version": "7.23.3", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.23.3.tgz", - "integrity": "sha512-9EiNjVJOMwCO+43TqoTrgQ8jMwcAd0sWyXi9RPfIsLTj4R2MADDDQXELhffaUx/uJv2AYcxBgPwH6j4TIA4ytQ==", + "version": "7.24.1", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.24.1.tgz", + "integrity": "sha512-Yhnmvy5HZEnHUty6i++gcfH1/l68AHnItFHnaCv6hn9dNh0hQvvQJsxpi4BMBFN5DLeHBuucT/0DgzXif/OyRw==", "dev": true, "dependencies": { - "@babel/helper-plugin-utils": "^7.22.5" + "@babel/helper-plugin-utils": "^7.24.0" }, "engines": { "node": ">=6.9.0" @@ -539,9 +541,9 @@ } }, "node_modules/@babel/runtime": { - "version": "7.23.7", - "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.23.7.tgz", - "integrity": "sha512-w06OXVOFso7LcbzMiDGt+3X7Rh7Ho8MmgPoWU3rarH+8upf+wSU/grlGbWzQyr3DkdN6ZeuMFjpdwW0Q+HxobA==", + "version": "7.24.4", + "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.24.4.tgz", + "integrity": "sha512-dkxf7+hn8mFBwKjs9bvBlArzLVxVbS8usaPUDd5p2a9JCL9tB8OaOVN1isD4+Xyk4ns89/xeOmbQvgdK7IIVdA==", "dependencies": { "regenerator-runtime": "^0.14.0" }, @@ -550,33 +552,33 @@ } }, "node_modules/@babel/template": { - "version": "7.22.15", - "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.22.15.tgz", - "integrity": "sha512-QPErUVm4uyJa60rkI73qneDacvdvzxshT3kksGqlGWYdOTIUOwJ7RDUL8sGqslY1uXWSL6xMFKEXDS3ox2uF0w==", + "version": "7.24.0", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.24.0.tgz", + "integrity": "sha512-Bkf2q8lMB0AFpX0NFEqSbx1OkTHf0f+0j82mkw+ZpzBnkk7e9Ql0891vlfgi+kHwOk8tQjiQHpqh4LaSa0fKEA==", "dev": true, "dependencies": { - "@babel/code-frame": "^7.22.13", - "@babel/parser": "^7.22.15", - "@babel/types": "^7.22.15" + "@babel/code-frame": "^7.23.5", + "@babel/parser": "^7.24.0", + "@babel/types": "^7.24.0" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/traverse": { - "version": "7.23.7", - "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.23.7.tgz", - "integrity": "sha512-tY3mM8rH9jM0YHFGyfC0/xf+SB5eKUu7HPj7/k3fpi9dAlsMc5YbQvDi0Sh2QTPXqMhyaAtzAr807TIyfQrmyg==", + "version": "7.24.1", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.24.1.tgz", + "integrity": "sha512-xuU6o9m68KeqZbQuDt2TcKSxUw/mrsvavlEqQ1leZ/B+C9tk6E4sRWy97WaXgvq5E+nU3cXMxv3WKOCanVMCmQ==", "dev": true, "dependencies": { - "@babel/code-frame": "^7.23.5", - "@babel/generator": "^7.23.6", + "@babel/code-frame": "^7.24.1", + "@babel/generator": "^7.24.1", "@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.6", - "@babel/types": "^7.23.6", + "@babel/parser": "^7.24.1", + "@babel/types": "^7.24.0", "debug": "^4.3.1", "globals": "^11.1.0" }, @@ -594,9 +596,9 @@ } }, "node_modules/@babel/types": { - "version": "7.23.6", - "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.23.6.tgz", - "integrity": "sha512-+uarb83brBzPKN38NX1MkB6vb6+mwvR6amUulqAE7ccQw1pEl+bCia9TbdG1lsnFP7lZySvUn37CHyXQdfTwzg==", + "version": "7.24.0", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.24.0.tgz", + "integrity": "sha512-+j7a5c253RfKh8iABBhywc8NSfP5LURe7Uh4qpsh6jc+aLJguvmIUBdjSdEMQv2bENrCR5MfRdjGo7vzS/ob7w==", "dev": true, "dependencies": { "@babel/helper-string-parser": "^7.23.4", @@ -643,12 +645,6 @@ "semver": "^7.5.3" } }, - "node_modules/@changesets/apply-release-plan/node_modules/@changesets/types": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/@changesets/types/-/types-6.0.0.tgz", - "integrity": "sha512-b1UkfNulgKoWfqyHtzKS5fOZYSJO+77adgL7DLRDr+/7jhChN+QcHnbjiQVOz/U+Ts3PGNySq7diAItzDgugfQ==", - "dev": true - }, "node_modules/@changesets/apply-release-plan/node_modules/prettier": { "version": "2.8.8", "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.8.8.tgz", @@ -678,12 +674,6 @@ "semver": "^7.5.3" } }, - "node_modules/@changesets/assemble-release-plan/node_modules/@changesets/types": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/@changesets/types/-/types-6.0.0.tgz", - "integrity": "sha512-b1UkfNulgKoWfqyHtzKS5fOZYSJO+77adgL7DLRDr+/7jhChN+QcHnbjiQVOz/U+Ts3PGNySq7diAItzDgugfQ==", - "dev": true - }, "node_modules/@changesets/changelog-git": { "version": "0.2.0", "resolved": "https://registry.npmjs.org/@changesets/changelog-git/-/changelog-git-0.2.0.tgz", @@ -693,20 +683,14 @@ "@changesets/types": "^6.0.0" } }, - "node_modules/@changesets/changelog-git/node_modules/@changesets/types": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/@changesets/types/-/types-6.0.0.tgz", - "integrity": "sha512-b1UkfNulgKoWfqyHtzKS5fOZYSJO+77adgL7DLRDr+/7jhChN+QcHnbjiQVOz/U+Ts3PGNySq7diAItzDgugfQ==", - "dev": true - }, "node_modules/@changesets/changelog-github": { - "version": "0.4.8", - "resolved": "https://registry.npmjs.org/@changesets/changelog-github/-/changelog-github-0.4.8.tgz", - "integrity": "sha512-jR1DHibkMAb5v/8ym77E4AMNWZKB5NPzw5a5Wtqm1JepAuIF+hrKp2u04NKM14oBZhHglkCfrla9uq8ORnK/dw==", + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/@changesets/changelog-github/-/changelog-github-0.5.0.tgz", + "integrity": "sha512-zoeq2LJJVcPJcIotHRJEEA2qCqX0AQIeFE+L21L8sRLPVqDhSXY8ZWAt2sohtBpFZkBwu+LUwMSKRr2lMy3LJA==", "dev": true, "dependencies": { - "@changesets/get-github-info": "^0.5.2", - "@changesets/types": "^5.2.1", + "@changesets/get-github-info": "^0.6.0", + "@changesets/types": "^6.0.0", "dotenv": "^8.1.0" } }, @@ -762,12 +746,6 @@ "changeset": "bin.js" } }, - "node_modules/@changesets/cli/node_modules/@changesets/types": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/@changesets/types/-/types-6.0.0.tgz", - "integrity": "sha512-b1UkfNulgKoWfqyHtzKS5fOZYSJO+77adgL7DLRDr+/7jhChN+QcHnbjiQVOz/U+Ts3PGNySq7diAItzDgugfQ==", - "dev": true - }, "node_modules/@changesets/config": { "version": "3.0.0", "resolved": "https://registry.npmjs.org/@changesets/config/-/config-3.0.0.tgz", @@ -783,12 +761,6 @@ "micromatch": "^4.0.2" } }, - "node_modules/@changesets/config/node_modules/@changesets/types": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/@changesets/types/-/types-6.0.0.tgz", - "integrity": "sha512-b1UkfNulgKoWfqyHtzKS5fOZYSJO+77adgL7DLRDr+/7jhChN+QcHnbjiQVOz/U+Ts3PGNySq7diAItzDgugfQ==", - "dev": true - }, "node_modules/@changesets/errors": { "version": "0.2.0", "resolved": "https://registry.npmjs.org/@changesets/errors/-/errors-0.2.0.tgz", @@ -811,16 +783,10 @@ "semver": "^7.5.3" } }, - "node_modules/@changesets/get-dependents-graph/node_modules/@changesets/types": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/@changesets/types/-/types-6.0.0.tgz", - "integrity": "sha512-b1UkfNulgKoWfqyHtzKS5fOZYSJO+77adgL7DLRDr+/7jhChN+QcHnbjiQVOz/U+Ts3PGNySq7diAItzDgugfQ==", - "dev": true - }, "node_modules/@changesets/get-github-info": { - "version": "0.5.2", - "resolved": "https://registry.npmjs.org/@changesets/get-github-info/-/get-github-info-0.5.2.tgz", - "integrity": "sha512-JppheLu7S114aEs157fOZDjFqUDpm7eHdq5E8SSR0gUBTEK0cNSHsrSR5a66xs0z3RWuo46QvA3vawp8BxDHvg==", + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/@changesets/get-github-info/-/get-github-info-0.6.0.tgz", + "integrity": "sha512-v/TSnFVXI8vzX9/w3DU2Ol+UlTZcu3m0kXTjTT4KlAdwSvwutcByYwyYn9hwerPWfPkT2JfpoX0KgvCEi8Q/SA==", "dev": true, "dependencies": { "dataloader": "^1.4.0", @@ -842,12 +808,6 @@ "@manypkg/get-packages": "^1.1.3" } }, - "node_modules/@changesets/get-release-plan/node_modules/@changesets/types": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/@changesets/types/-/types-6.0.0.tgz", - "integrity": "sha512-b1UkfNulgKoWfqyHtzKS5fOZYSJO+77adgL7DLRDr+/7jhChN+QcHnbjiQVOz/U+Ts3PGNySq7diAItzDgugfQ==", - "dev": true - }, "node_modules/@changesets/get-version-range-type": { "version": "0.4.0", "resolved": "https://registry.npmjs.org/@changesets/get-version-range-type/-/get-version-range-type-0.4.0.tgz", @@ -869,12 +829,6 @@ "spawndamnit": "^2.0.0" } }, - "node_modules/@changesets/git/node_modules/@changesets/types": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/@changesets/types/-/types-6.0.0.tgz", - "integrity": "sha512-b1UkfNulgKoWfqyHtzKS5fOZYSJO+77adgL7DLRDr+/7jhChN+QcHnbjiQVOz/U+Ts3PGNySq7diAItzDgugfQ==", - "dev": true - }, "node_modules/@changesets/logger": { "version": "0.1.0", "resolved": "https://registry.npmjs.org/@changesets/logger/-/logger-0.1.0.tgz", @@ -894,12 +848,6 @@ "js-yaml": "^3.13.1" } }, - "node_modules/@changesets/parse/node_modules/@changesets/types": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/@changesets/types/-/types-6.0.0.tgz", - "integrity": "sha512-b1UkfNulgKoWfqyHtzKS5fOZYSJO+77adgL7DLRDr+/7jhChN+QcHnbjiQVOz/U+Ts3PGNySq7diAItzDgugfQ==", - "dev": true - }, "node_modules/@changesets/pre": { "version": "2.0.0", "resolved": "https://registry.npmjs.org/@changesets/pre/-/pre-2.0.0.tgz", @@ -913,12 +861,6 @@ "fs-extra": "^7.0.1" } }, - "node_modules/@changesets/pre/node_modules/@changesets/types": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/@changesets/types/-/types-6.0.0.tgz", - "integrity": "sha512-b1UkfNulgKoWfqyHtzKS5fOZYSJO+77adgL7DLRDr+/7jhChN+QcHnbjiQVOz/U+Ts3PGNySq7diAItzDgugfQ==", - "dev": true - }, "node_modules/@changesets/read": { "version": "0.6.0", "resolved": "https://registry.npmjs.org/@changesets/read/-/read-0.6.0.tgz", @@ -935,18 +877,12 @@ "p-filter": "^2.1.0" } }, - "node_modules/@changesets/read/node_modules/@changesets/types": { + "node_modules/@changesets/types": { "version": "6.0.0", "resolved": "https://registry.npmjs.org/@changesets/types/-/types-6.0.0.tgz", "integrity": "sha512-b1UkfNulgKoWfqyHtzKS5fOZYSJO+77adgL7DLRDr+/7jhChN+QcHnbjiQVOz/U+Ts3PGNySq7diAItzDgugfQ==", "dev": true }, - "node_modules/@changesets/types": { - "version": "5.2.1", - "resolved": "https://registry.npmjs.org/@changesets/types/-/types-5.2.1.tgz", - "integrity": "sha512-myLfHbVOqaq9UtUKqR/nZA/OY7xFjQMdfgfqeZIBK4d0hA6pgxArvdv8M+6NUzzBsjWLOtvApv8YHr4qM+Kpfg==", - "dev": true - }, "node_modules/@changesets/write": { "version": "0.3.0", "resolved": "https://registry.npmjs.org/@changesets/write/-/write-0.3.0.tgz", @@ -960,12 +896,6 @@ "prettier": "^2.7.1" } }, - "node_modules/@changesets/write/node_modules/@changesets/types": { - "version": "6.0.0", - "resolved": "https://registry.npmjs.org/@changesets/types/-/types-6.0.0.tgz", - "integrity": "sha512-b1UkfNulgKoWfqyHtzKS5fOZYSJO+77adgL7DLRDr+/7jhChN+QcHnbjiQVOz/U+Ts3PGNySq7diAItzDgugfQ==", - "dev": true - }, "node_modules/@changesets/write/node_modules/prettier": { "version": "2.8.8", "resolved": "https://registry.npmjs.org/prettier/-/prettier-2.8.8.tgz", @@ -1708,6 +1638,16 @@ "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", "dev": true }, + "node_modules/@eslint/eslintrc/node_modules/brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "dependencies": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, "node_modules/@eslint/eslintrc/node_modules/js-yaml": { "version": "4.1.0", "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-4.1.0.tgz", @@ -1720,6 +1660,18 @@ "js-yaml": "bin/js-yaml.js" } }, + "node_modules/@eslint/eslintrc/node_modules/minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dev": true, + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, "node_modules/@eslint/js": { "version": "8.57.0", "resolved": "https://registry.npmjs.org/@eslint/js/-/js-8.57.0.tgz", @@ -2281,6 +2233,13 @@ "eventemitter3": "^4.0.7" } }, + "node_modules/@fragnova/api-augment/node_modules/@substrate/connect-extension-protocol": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/@substrate/connect-extension-protocol/-/connect-extension-protocol-1.0.1.tgz", + "integrity": "sha512-161JhCC1csjH3GE5mPLEd7HbWtwNSPJBg3p1Ksz9SFlTzj/bgEwudiRN2y5i0MoLGCIJRYKyKGMxVnd29PzNjg==", + "optional": true, + "peer": true + }, "node_modules/@fragnova/api-augment/node_modules/@substrate/connect/node_modules/eventemitter3": { "version": "4.0.7", "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-4.0.7.tgz", @@ -2331,6 +2290,28 @@ "node": ">=10.10.0" } }, + "node_modules/@humanwhocodes/config-array/node_modules/brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "dependencies": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "node_modules/@humanwhocodes/config-array/node_modules/minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dev": true, + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, "node_modules/@humanwhocodes/module-importer": { "version": "1.0.1", "resolved": "https://registry.npmjs.org/@humanwhocodes/module-importer/-/module-importer-1.0.1.tgz", @@ -2345,9 +2326,9 @@ } }, "node_modules/@humanwhocodes/object-schema": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.2.tgz", - "integrity": "sha512-6EwiSjwWYP7pTckG6I5eyFANjPhmPjUX9JRLUSfNPC7FX7zK9gyZAfUEaECL6ALTpGX5AjnBq3C9XmVWPitNpw==", + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/@humanwhocodes/object-schema/-/object-schema-2.0.3.tgz", + "integrity": "sha512-93zYdMES/c1D69yZiKDBj0V24vqNzB/koF26KPaagAfd3P/4gUlh3Dys5ogAK+Exi9QyzlD8x/08Zt7wIKcDcA==", "dev": true }, "node_modules/@interlay/interbtc-types": { @@ -2759,6 +2740,16 @@ "url": "https://github.com/chalk/ansi-styles?sponsor=1" } }, + "node_modules/@jest/reporters/node_modules/brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "dependencies": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, "node_modules/@jest/reporters/node_modules/chalk": { "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", @@ -2822,6 +2813,18 @@ "node": ">=8" } }, + "node_modules/@jest/reporters/node_modules/minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dev": true, + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, "node_modules/@jest/reporters/node_modules/supports-color": { "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", @@ -3074,32 +3077,32 @@ } }, "node_modules/@jridgewell/gen-mapping": { - "version": "0.3.3", - "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.3.tgz", - "integrity": "sha512-HLhSWOLRi875zjjMG/r+Nv0oCW8umGb0BgEhyX3dDX3egwZtB8PqLnjz3yedt8R5StBrzcg4aBpnh8UA9D1BoQ==", + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/@jridgewell/gen-mapping/-/gen-mapping-0.3.5.tgz", + "integrity": "sha512-IzL8ZoEDIBRWEzlCcRhOaCupYyN5gdIK+Q6fbFdPDg6HqX6jpkItn7DFIpW9LQzXG6Df9sA7+OKnq0qlz/GaQg==", "dev": true, "dependencies": { - "@jridgewell/set-array": "^1.0.1", + "@jridgewell/set-array": "^1.2.1", "@jridgewell/sourcemap-codec": "^1.4.10", - "@jridgewell/trace-mapping": "^0.3.9" + "@jridgewell/trace-mapping": "^0.3.24" }, "engines": { "node": ">=6.0.0" } }, "node_modules/@jridgewell/resolve-uri": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.1.tgz", - "integrity": "sha512-dSYZh7HhCDtCKm4QakX0xFpsRDqjjtZf/kjI/v3T3Nwt5r8/qz/M19F9ySyOqU94SXBmeG9ttTul+YnR4LOxFA==", + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/@jridgewell/resolve-uri/-/resolve-uri-3.1.2.tgz", + "integrity": "sha512-bRISgCIjP20/tbWSPWMEi54QVPRZExkuD9lJL+UIxUKtwVJA8wW1Trb1jMs1RFXo1CBTNZ/5hpC9QvmKWdopKw==", "dev": true, "engines": { "node": ">=6.0.0" } }, "node_modules/@jridgewell/set-array": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.1.2.tgz", - "integrity": "sha512-xnkseuNADM0gt2bs+BvhO0p78Mk762YnZdsuzFV018NoG1Sj1SCQvpSqa7XUaTam5vAGasABV9qXASMKnFMwMw==", + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/@jridgewell/set-array/-/set-array-1.2.1.tgz", + "integrity": "sha512-R8gLRTZeyp03ymzP/6Lil/28tGeGEzhx1q2k703KGWRAI1VdvPIXdG70VJc2pAMw3NA6JKL5hhFu1sJX0Mnn/A==", "dev": true, "engines": { "node": ">=6.0.0" @@ -3112,9 +3115,9 @@ "dev": true }, "node_modules/@jridgewell/trace-mapping": { - "version": "0.3.20", - "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.20.tgz", - "integrity": "sha512-R8LcPeWZol2zR8mmH3JeKQ6QRCFb7XgUhV9ZlGhHLGyg4wpPiPZNQOOWhFZhxKw8u//yTbNGI42Bx/3paXEQ+Q==", + "version": "0.3.25", + "resolved": "https://registry.npmjs.org/@jridgewell/trace-mapping/-/trace-mapping-0.3.25.tgz", + "integrity": "sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==", "dev": true, "dependencies": { "@jridgewell/resolve-uri": "^3.1.0", @@ -3258,20 +3261,20 @@ "link": true }, "node_modules/@noble/curves": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/@noble/curves/-/curves-1.3.0.tgz", - "integrity": "sha512-t01iSXPuN+Eqzb4eBX0S5oubSqXbK/xXa1Ne18Hj8f9pStxztHCE2gfboSp/dZRLSqfuLpRK2nDXDK+W9puocA==", + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/@noble/curves/-/curves-1.4.0.tgz", + "integrity": "sha512-p+4cb332SFCrReJkCYe8Xzm0OWi4Jji5jVdIZRL/PmacmDkFNw6MrrV+gGpiPxLHbV+zKFRywUWbaseT+tZRXg==", "dependencies": { - "@noble/hashes": "1.3.3" + "@noble/hashes": "1.4.0" }, "funding": { "url": "https://paulmillr.com/funding/" } }, "node_modules/@noble/hashes": { - "version": "1.3.3", - "resolved": "https://registry.npmjs.org/@noble/hashes/-/hashes-1.3.3.tgz", - "integrity": "sha512-V7/fPHgl+jsVPXqqeOzT8egNj2iBIVt+ECeMMG8TdcnTikP3oaBtUVqpT/gYCR68aEBJSF+XbYUxStjbFMqIIA==", + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/@noble/hashes/-/hashes-1.4.0.tgz", + "integrity": "sha512-V1JJ1WTRUqHHrOSh597hURcMqVKVGL/ea3kv0gSnEdsEZ0/+VyPghM1lMNGc00z7CIQorSvbKpuJkxvuHbvdbg==", "engines": { "node": ">= 16" }, @@ -3336,9 +3339,9 @@ } }, "node_modules/@oven/bun-darwin-aarch64": { - "version": "1.0.21", - "resolved": "https://registry.npmjs.org/@oven/bun-darwin-aarch64/-/bun-darwin-aarch64-1.0.21.tgz", - "integrity": "sha512-OdYWsGdKHkZHomO+NgASW+WfUeGBWiaiOFPBP+q/bZVuik6LmGsk0KbnTZB02wxe3lvDxJHdxaYzQe+x5WbW6g==", + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/@oven/bun-darwin-aarch64/-/bun-darwin-aarch64-1.1.3.tgz", + "integrity": "sha512-EgcHnvwC/A6WoF2F6gV1cc09i5CsYbPM6FX0xyEViUuyvC00z9SmhgqvocGFa1eFmKQODQBIZsovxEZxhLqfQw==", "cpu": [ "arm64" ], @@ -3349,9 +3352,9 @@ ] }, "node_modules/@oven/bun-darwin-x64": { - "version": "1.0.21", - "resolved": "https://registry.npmjs.org/@oven/bun-darwin-x64/-/bun-darwin-x64-1.0.21.tgz", - "integrity": "sha512-PAiLNFMMFX9bBNnVfbM1msYlhU48r7ef9QpNbyf/hauJKFOhL48JTLFpRkq775E63BxAMO1lIKH8J1/8Nuzj3A==", + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/@oven/bun-darwin-x64/-/bun-darwin-x64-1.1.3.tgz", + "integrity": "sha512-WNzpUzUampox5SKLx93JPcm8cRkjLyYKRqYhG7I21+psYtSicbcINoYjpW20NRdlk123u2rmb0a98dEPIj1Xaw==", "cpu": [ "x64" ], @@ -3362,9 +3365,9 @@ ] }, "node_modules/@oven/bun-darwin-x64-baseline": { - "version": "1.0.21", - "resolved": "https://registry.npmjs.org/@oven/bun-darwin-x64-baseline/-/bun-darwin-x64-baseline-1.0.21.tgz", - "integrity": "sha512-NYuDJ523Ax27xwH+GJpxfD1rXhdCkO4PL5U9wxyi/Ky5YnQWfNgnr4dyLaWs58bq6pjwaB0PhqW+HsKztX5csg==", + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/@oven/bun-darwin-x64-baseline/-/bun-darwin-x64-baseline-1.1.3.tgz", + "integrity": "sha512-vaxqGRsIJ+lSmFBEACapgQS+mHBSS8XxCaQn7lbjUsr/LnFyNBzgSlDrU7cCVbxXMa7vVqDa/dRJ9rEpi0fqLA==", "cpu": [ "x64" ], @@ -3375,9 +3378,9 @@ ] }, "node_modules/@oven/bun-linux-aarch64": { - "version": "1.0.21", - "resolved": "https://registry.npmjs.org/@oven/bun-linux-aarch64/-/bun-linux-aarch64-1.0.21.tgz", - "integrity": "sha512-m9AfJSg+I2na6MUoT5+gjCjARK7tQNDDVNIKbUuEE++6Y1j8MB8SgIYFurS8BLsQ//dxf1KfC1jkdcW+q62NRg==", + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/@oven/bun-linux-aarch64/-/bun-linux-aarch64-1.1.3.tgz", + "integrity": "sha512-s6rsbpsHzu19wl25WyAbi9yQRCOtigQN3IfbuiL+c71zctI5MGWdMz1yhBcjkFW64t656kGsvhHieS8n3rLjSw==", "cpu": [ "arm64" ], @@ -3388,9 +3391,9 @@ ] }, "node_modules/@oven/bun-linux-x64": { - "version": "1.0.21", - "resolved": "https://registry.npmjs.org/@oven/bun-linux-x64/-/bun-linux-x64-1.0.21.tgz", - "integrity": "sha512-OBRi+goiCYlhFLOjw/FBREG7ku20rV7DFACAsx6QWepV4QXM6mXBzwXwjUSneI2VLILUNO5ohyqFG6RmS8hG5w==", + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/@oven/bun-linux-x64/-/bun-linux-x64-1.1.3.tgz", + "integrity": "sha512-hCAuEKLSjd0XxhgU/K+aZIvmDVnkHK1mSbD7pGWvTN+z2g6Ac64tQSBin+TyhiS4DzOxr2nNelMllFjFMwOd+Q==", "cpu": [ "x64" ], @@ -3401,9 +3404,9 @@ ] }, "node_modules/@oven/bun-linux-x64-baseline": { - "version": "1.0.21", - "resolved": "https://registry.npmjs.org/@oven/bun-linux-x64-baseline/-/bun-linux-x64-baseline-1.0.21.tgz", - "integrity": "sha512-F9R8qoxOij7PLi05tWJX6j/i5mJHiHe/cIEawHJy/S+YqU3mtVo0vqJa9bErVJz14CKQStTgIuREDFH+39qdXA==", + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/@oven/bun-linux-x64-baseline/-/bun-linux-x64-baseline-1.1.3.tgz", + "integrity": "sha512-mxw4Lo4c6epzkM/WTYbd8K2EeNoaMxzyYIB69mw26fSZmI/Sr4hmn14/SDZF6qwvnurignlqdYwWRasmhnC2hw==", "cpu": [ "x64" ], @@ -3413,6 +3416,32 @@ "linux" ] }, + "node_modules/@oven/bun-windows-x64": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/@oven/bun-windows-x64/-/bun-windows-x64-1.1.3.tgz", + "integrity": "sha512-IBV+DCOAyaQGhtqQ0gliBprMRBoRGwDBSOQJrQ6Df/0t0R7eyJzl8SyR2C89jZ/vK4VsNMgEv5Mxa6zP7SSQOw==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ] + }, + "node_modules/@oven/bun-windows-x64-baseline": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/@oven/bun-windows-x64-baseline/-/bun-windows-x64-baseline-1.1.3.tgz", + "integrity": "sha512-LgGYYWA6f5FKp3QeT8PCQ6JpQkz2kLu21i6um4BYyh1U7hZb75LoLzetfhdOJa00hy9Zrt+8Z8QnQ7ffmGevyQ==", + "cpu": [ + "x64" + ], + "dev": true, + "optional": true, + "os": [ + "win32" + ] + }, "node_modules/@parallel-finance/type-definitions": { "version": "1.7.17", "resolved": "https://registry.npmjs.org/@parallel-finance/type-definitions/-/type-definitions-1.7.17.tgz", @@ -3468,24 +3497,85 @@ "url": "https://opencollective.com/unts" } }, + "node_modules/@polkadot-api/client": { + "version": "0.0.1-492c132563ea6b40ae1fc5470dec4cd18768d182.1.0", + "resolved": "https://registry.npmjs.org/@polkadot-api/client/-/client-0.0.1-492c132563ea6b40ae1fc5470dec4cd18768d182.1.0.tgz", + "integrity": "sha512-0fqK6pUKcGHSG2pBvY+gfSS+1mMdjd/qRygAcKI5d05tKsnZLRnmhb9laDguKmGEIB0Bz9vQqNK3gIN/cfvVwg==", + "optional": true, + "dependencies": { + "@polkadot-api/metadata-builders": "0.0.1-492c132563ea6b40ae1fc5470dec4cd18768d182.1.0", + "@polkadot-api/substrate-bindings": "0.0.1-492c132563ea6b40ae1fc5470dec4cd18768d182.1.0", + "@polkadot-api/substrate-client": "0.0.1-492c132563ea6b40ae1fc5470dec4cd18768d182.1.0", + "@polkadot-api/utils": "0.0.1-492c132563ea6b40ae1fc5470dec4cd18768d182.1.0" + }, + "peerDependencies": { + "rxjs": ">=7.8.0" + } + }, + "node_modules/@polkadot-api/json-rpc-provider": { + "version": "0.0.1-492c132563ea6b40ae1fc5470dec4cd18768d182.1.0", + "resolved": "https://registry.npmjs.org/@polkadot-api/json-rpc-provider/-/json-rpc-provider-0.0.1-492c132563ea6b40ae1fc5470dec4cd18768d182.1.0.tgz", + "integrity": "sha512-EaUS9Fc3wsiUr6ZS43PQqaRScW7kM6DYbuM/ou0aYjm8N9MBqgDbGm2oL6RE1vAVmOfEuHcXZuZkhzWtyvQUtA==", + "optional": true + }, + "node_modules/@polkadot-api/json-rpc-provider-proxy": { + "version": "0.0.1-492c132563ea6b40ae1fc5470dec4cd18768d182.1.0", + "resolved": "https://registry.npmjs.org/@polkadot-api/json-rpc-provider-proxy/-/json-rpc-provider-proxy-0.0.1-492c132563ea6b40ae1fc5470dec4cd18768d182.1.0.tgz", + "integrity": "sha512-0hZ8vtjcsyCX8AyqP2sqUHa1TFFfxGWmlXJkit0Nqp9b32MwZqn5eaUAiV2rNuEpoglKOdKnkGtUF8t5MoodKw==", + "optional": true + }, + "node_modules/@polkadot-api/metadata-builders": { + "version": "0.0.1-492c132563ea6b40ae1fc5470dec4cd18768d182.1.0", + "resolved": "https://registry.npmjs.org/@polkadot-api/metadata-builders/-/metadata-builders-0.0.1-492c132563ea6b40ae1fc5470dec4cd18768d182.1.0.tgz", + "integrity": "sha512-BD7rruxChL1VXt0icC2gD45OtT9ofJlql0qIllHSRYgama1CR2Owt+ApInQxB+lWqM+xNOznZRpj8CXNDvKIMg==", + "optional": true, + "dependencies": { + "@polkadot-api/substrate-bindings": "0.0.1-492c132563ea6b40ae1fc5470dec4cd18768d182.1.0", + "@polkadot-api/utils": "0.0.1-492c132563ea6b40ae1fc5470dec4cd18768d182.1.0" + } + }, + "node_modules/@polkadot-api/substrate-bindings": { + "version": "0.0.1-492c132563ea6b40ae1fc5470dec4cd18768d182.1.0", + "resolved": "https://registry.npmjs.org/@polkadot-api/substrate-bindings/-/substrate-bindings-0.0.1-492c132563ea6b40ae1fc5470dec4cd18768d182.1.0.tgz", + "integrity": "sha512-N4vdrZopbsw8k57uG58ofO7nLXM4Ai7835XqakN27MkjXMp5H830A1KJE0L9sGQR7ukOCDEIHHcwXVrzmJ/PBg==", + "optional": true, + "dependencies": { + "@noble/hashes": "^1.3.1", + "@polkadot-api/utils": "0.0.1-492c132563ea6b40ae1fc5470dec4cd18768d182.1.0", + "@scure/base": "^1.1.1", + "scale-ts": "^1.6.0" + } + }, + "node_modules/@polkadot-api/substrate-client": { + "version": "0.0.1-492c132563ea6b40ae1fc5470dec4cd18768d182.1.0", + "resolved": "https://registry.npmjs.org/@polkadot-api/substrate-client/-/substrate-client-0.0.1-492c132563ea6b40ae1fc5470dec4cd18768d182.1.0.tgz", + "integrity": "sha512-lcdvd2ssUmB1CPzF8s2dnNOqbrDa+nxaaGbuts+Vo8yjgSKwds2Lo7Oq+imZN4VKW7t9+uaVcKFLMF7PdH0RWw==", + "optional": true + }, + "node_modules/@polkadot-api/utils": { + "version": "0.0.1-492c132563ea6b40ae1fc5470dec4cd18768d182.1.0", + "resolved": "https://registry.npmjs.org/@polkadot-api/utils/-/utils-0.0.1-492c132563ea6b40ae1fc5470dec4cd18768d182.1.0.tgz", + "integrity": "sha512-0CYaCjfLQJTCRCiYvZ81OncHXEKPzAexCMoVloR+v2nl/O2JRya/361MtPkeNLC6XBoaEgLAG9pWQpH3WePzsw==", + "optional": true + }, "node_modules/@polkadot/api": { - "version": "10.11.2", - "resolved": "https://registry.npmjs.org/@polkadot/api/-/api-10.11.2.tgz", - "integrity": "sha512-AorCZxCWCoTtdbl4DPUZh+ACe/pbLIS1BkdQY0AFJuZllm0x/yWzjgampcPd5jQAA/O3iKShRBkZqj6Mk9yG/A==", + "version": "10.12.6", + "resolved": "https://registry.npmjs.org/@polkadot/api/-/api-10.12.6.tgz", + "integrity": "sha512-qWF7qFLZtpSILuPeZcvz0oCBXe89XndDjzgCnflvEVIUkQvxtFM8mDXpzI4bz8klrLYHlyFbP7HJl/xLi+XTew==", "dependencies": { - "@polkadot/api-augment": "10.11.2", - "@polkadot/api-base": "10.11.2", - "@polkadot/api-derive": "10.11.2", + "@polkadot/api-augment": "10.12.6", + "@polkadot/api-base": "10.12.6", + "@polkadot/api-derive": "10.12.6", "@polkadot/keyring": "^12.6.2", - "@polkadot/rpc-augment": "10.11.2", - "@polkadot/rpc-core": "10.11.2", - "@polkadot/rpc-provider": "10.11.2", - "@polkadot/types": "10.11.2", - "@polkadot/types-augment": "10.11.2", - "@polkadot/types-codec": "10.11.2", - "@polkadot/types-create": "10.11.2", - "@polkadot/types-known": "10.11.2", - "@polkadot/util": "^12.5.1", + "@polkadot/rpc-augment": "10.12.6", + "@polkadot/rpc-core": "10.12.6", + "@polkadot/rpc-provider": "10.12.6", + "@polkadot/types": "10.12.6", + "@polkadot/types-augment": "10.12.6", + "@polkadot/types-codec": "10.12.6", + "@polkadot/types-create": "10.12.6", + "@polkadot/types-known": "10.12.6", + "@polkadot/util": "^12.6.2", "@polkadot/util-crypto": "^12.6.2", "eventemitter3": "^5.0.1", "rxjs": "^7.8.1", @@ -3496,16 +3586,16 @@ } }, "node_modules/@polkadot/api-augment": { - "version": "10.11.2", - "resolved": "https://registry.npmjs.org/@polkadot/api-augment/-/api-augment-10.11.2.tgz", - "integrity": "sha512-PTpnqpezc75qBqUtgrc0GYB8h9UHjfbHSRZamAbecIVAJ2/zc6CqtnldeaBlIu1IKTgBzi3FFtTyYu+ZGbNT2Q==", - "dependencies": { - "@polkadot/api-base": "10.11.2", - "@polkadot/rpc-augment": "10.11.2", - "@polkadot/types": "10.11.2", - "@polkadot/types-augment": "10.11.2", - "@polkadot/types-codec": "10.11.2", - "@polkadot/util": "^12.5.1", + "version": "10.12.6", + "resolved": "https://registry.npmjs.org/@polkadot/api-augment/-/api-augment-10.12.6.tgz", + "integrity": "sha512-CZHaFAd6zexk3JCm1mY5doE1E634xNpKaTGpbs61Ch285d5EqBY25GdzGNiMprNl4VyRFT4N7dXKfwEdsM6Z9w==", + "dependencies": { + "@polkadot/api-base": "10.12.6", + "@polkadot/rpc-augment": "10.12.6", + "@polkadot/types": "10.12.6", + "@polkadot/types-augment": "10.12.6", + "@polkadot/types-codec": "10.12.6", + "@polkadot/util": "^12.6.2", "tslib": "^2.6.2" }, "engines": { @@ -3513,13 +3603,13 @@ } }, "node_modules/@polkadot/api-base": { - "version": "10.11.2", - "resolved": "https://registry.npmjs.org/@polkadot/api-base/-/api-base-10.11.2.tgz", - "integrity": "sha512-4LIjaUfO9nOzilxo7XqzYKCNMtmUypdk8oHPdrRnSjKEsnK7vDsNi+979z2KXNXd2KFSCFHENmI523fYnMnReg==", + "version": "10.12.6", + "resolved": "https://registry.npmjs.org/@polkadot/api-base/-/api-base-10.12.6.tgz", + "integrity": "sha512-6EzMettffiadB5j0X2nValtrEZJ2dKZMArfWHbSCV1QRSPOaMO3Phf/idqtF8HgBHD3FCHJ+JsZEns6xpkpteg==", "dependencies": { - "@polkadot/rpc-core": "10.11.2", - "@polkadot/types": "10.11.2", - "@polkadot/util": "^12.5.1", + "@polkadot/rpc-core": "10.12.6", + "@polkadot/types": "10.12.6", + "@polkadot/util": "^12.6.2", "rxjs": "^7.8.1", "tslib": "^2.6.2" }, @@ -3528,17 +3618,17 @@ } }, "node_modules/@polkadot/api-derive": { - "version": "10.11.2", - "resolved": "https://registry.npmjs.org/@polkadot/api-derive/-/api-derive-10.11.2.tgz", - "integrity": "sha512-m3BQbPionkd1iSlknddxnL2hDtolPIsT+aRyrtn4zgMRPoLjHFmTmovvg8RaUyYofJtZeYrnjMw0mdxiSXx7eA==", - "dependencies": { - "@polkadot/api": "10.11.2", - "@polkadot/api-augment": "10.11.2", - "@polkadot/api-base": "10.11.2", - "@polkadot/rpc-core": "10.11.2", - "@polkadot/types": "10.11.2", - "@polkadot/types-codec": "10.11.2", - "@polkadot/util": "^12.5.1", + "version": "10.12.6", + "resolved": "https://registry.npmjs.org/@polkadot/api-derive/-/api-derive-10.12.6.tgz", + "integrity": "sha512-stjciYU9caSvPrcPo40zwPu15O7Q9OK9ldMFyyQkDdUT4cCE0LHuCmTNwcm4XhQq3XXJn+e7WNdhBfquwvkuhw==", + "dependencies": { + "@polkadot/api": "10.12.6", + "@polkadot/api-augment": "10.12.6", + "@polkadot/api-base": "10.12.6", + "@polkadot/rpc-core": "10.12.6", + "@polkadot/types": "10.12.6", + "@polkadot/types-codec": "10.12.6", + "@polkadot/util": "^12.6.2", "@polkadot/util-crypto": "^12.6.2", "rxjs": "^7.8.1", "tslib": "^2.6.2" @@ -3853,16 +3943,16 @@ } }, "node_modules/@polkadot/react-identicon": { - "version": "3.6.4", - "resolved": "https://registry.npmjs.org/@polkadot/react-identicon/-/react-identicon-3.6.4.tgz", - "integrity": "sha512-y8DFLXEVVZ1dKAQDdvtASxPyR4JqnqokRzbuZF1eDUleNxOJruNDGLGrfuM6rqVNHdHRy35Rku546aFqVE5Ldg==", + "version": "3.6.5", + "resolved": "https://registry.npmjs.org/@polkadot/react-identicon/-/react-identicon-3.6.5.tgz", + "integrity": "sha512-a2kV2GRgJaxQIuay6CDpIsYB+L8/erth+v9t48H+TX5y87FadBIqj6F7LsaOD5HJ8dsXrDaPOx5f7SsoKAGm6A==", "peer": true, "dependencies": { - "@polkadot/keyring": "^12.6.1", - "@polkadot/ui-settings": "3.6.4", - "@polkadot/ui-shared": "3.6.4", - "@polkadot/util": "^12.6.1", - "@polkadot/util-crypto": "^12.6.1", + "@polkadot/keyring": "^12.6.2", + "@polkadot/ui-settings": "3.6.5", + "@polkadot/ui-shared": "3.6.5", + "@polkadot/util": "^12.6.2", + "@polkadot/util-crypto": "^12.6.2", "ethereum-blockies-base64": "^1.0.2", "jdenticon": "3.2.0", "react-copy-to-clipboard": "^5.1.0", @@ -3882,14 +3972,14 @@ } }, "node_modules/@polkadot/rpc-augment": { - "version": "10.11.2", - "resolved": "https://registry.npmjs.org/@polkadot/rpc-augment/-/rpc-augment-10.11.2.tgz", - "integrity": "sha512-9AhT0WW81/8jYbRcAC6PRmuxXqNhJje8OYiulBQHbG1DTCcjAfz+6VQBke9BwTStzPq7d526+yyBKD17O3zlAA==", - "dependencies": { - "@polkadot/rpc-core": "10.11.2", - "@polkadot/types": "10.11.2", - "@polkadot/types-codec": "10.11.2", - "@polkadot/util": "^12.5.1", + "version": "10.12.6", + "resolved": "https://registry.npmjs.org/@polkadot/rpc-augment/-/rpc-augment-10.12.6.tgz", + "integrity": "sha512-MMZgdZtVygHqgsmCdKhfaN9ywf6im72xJzc9H8fkqyoJ+cGVy36uI3e8YwEM9vV6g/nallFmz4mU46u8/TjGlw==", + "dependencies": { + "@polkadot/rpc-core": "10.12.6", + "@polkadot/types": "10.12.6", + "@polkadot/types-codec": "10.12.6", + "@polkadot/util": "^12.6.2", "tslib": "^2.6.2" }, "engines": { @@ -3897,14 +3987,14 @@ } }, "node_modules/@polkadot/rpc-core": { - "version": "10.11.2", - "resolved": "https://registry.npmjs.org/@polkadot/rpc-core/-/rpc-core-10.11.2.tgz", - "integrity": "sha512-Ot0CFLWx8sZhLZog20WDuniPA01Bk2StNDsdAQgcFKPwZw6ShPaZQCHuKLQK6I6DodOrem9FXX7c1hvoKJP5Ww==", - "dependencies": { - "@polkadot/rpc-augment": "10.11.2", - "@polkadot/rpc-provider": "10.11.2", - "@polkadot/types": "10.11.2", - "@polkadot/util": "^12.5.1", + "version": "10.12.6", + "resolved": "https://registry.npmjs.org/@polkadot/rpc-core/-/rpc-core-10.12.6.tgz", + "integrity": "sha512-aBXhkryv2NMNg+cWajn/G0DF13inXIW+6iZV9cGc6lfsYT9Di/sasO0EIx7UUZW3ILYQ6Gh9jRgNLkwSNlAV9Q==", + "dependencies": { + "@polkadot/rpc-augment": "10.12.6", + "@polkadot/rpc-provider": "10.12.6", + "@polkadot/types": "10.12.6", + "@polkadot/util": "^12.6.2", "rxjs": "^7.8.1", "tslib": "^2.6.2" }, @@ -3913,40 +4003,40 @@ } }, "node_modules/@polkadot/rpc-provider": { - "version": "10.11.2", - "resolved": "https://registry.npmjs.org/@polkadot/rpc-provider/-/rpc-provider-10.11.2.tgz", - "integrity": "sha512-he5jWMpDJp7e+vUzTZDzpkB7ps3H8psRally+/ZvZZScPvFEjfczT7I1WWY9h58s8+ImeVP/lkXjL9h/gUOt3Q==", + "version": "10.12.6", + "resolved": "https://registry.npmjs.org/@polkadot/rpc-provider/-/rpc-provider-10.12.6.tgz", + "integrity": "sha512-xLmzb2rMQXEWQlrIDY3E3IXo1jcV9+Vy3A8zMw/s/UIrwXZ3I0TefP8+mXcqEjLkkz7zwldDQvHfdmtnxdE14g==", "dependencies": { "@polkadot/keyring": "^12.6.2", - "@polkadot/types": "10.11.2", - "@polkadot/types-support": "10.11.2", - "@polkadot/util": "^12.5.1", + "@polkadot/types": "10.12.6", + "@polkadot/types-support": "10.12.6", + "@polkadot/util": "^12.6.2", "@polkadot/util-crypto": "^12.6.2", "@polkadot/x-fetch": "^12.6.2", "@polkadot/x-global": "^12.6.2", "@polkadot/x-ws": "^12.6.2", "eventemitter3": "^5.0.1", "mock-socket": "^9.3.1", - "nock": "^13.4.0", + "nock": "^13.5.0", "tslib": "^2.6.2" }, "engines": { "node": ">=18" }, "optionalDependencies": { - "@substrate/connect": "0.7.35" + "@substrate/connect": "0.8.8" } }, "node_modules/@polkadot/types": { - "version": "10.11.2", - "resolved": "https://registry.npmjs.org/@polkadot/types/-/types-10.11.2.tgz", - "integrity": "sha512-d52j3xXni+C8GdYZVTSfu8ROAnzXFMlyRvXtor0PudUc8UQHOaC4+mYAkTBGA2gKdmL8MHSfRSbhcxHhsikY6Q==", + "version": "10.12.6", + "resolved": "https://registry.npmjs.org/@polkadot/types/-/types-10.12.6.tgz", + "integrity": "sha512-ByjvZkKJclHSWEETk1m9HPYn/IdIyjWONOdy7Ih+/Nd0wVIahvXDYbV4CXe25xO0RhfFJzkGIZP+LFHL5F63Uw==", "dependencies": { "@polkadot/keyring": "^12.6.2", - "@polkadot/types-augment": "10.11.2", - "@polkadot/types-codec": "10.11.2", - "@polkadot/types-create": "10.11.2", - "@polkadot/util": "^12.5.1", + "@polkadot/types-augment": "10.12.6", + "@polkadot/types-codec": "10.12.6", + "@polkadot/types-create": "10.12.6", + "@polkadot/util": "^12.6.2", "@polkadot/util-crypto": "^12.6.2", "rxjs": "^7.8.1", "tslib": "^2.6.2" @@ -3956,13 +4046,13 @@ } }, "node_modules/@polkadot/types-augment": { - "version": "10.11.2", - "resolved": "https://registry.npmjs.org/@polkadot/types-augment/-/types-augment-10.11.2.tgz", - "integrity": "sha512-8eB8ew04wZiE5GnmFvEFW1euJWmF62SGxb1O+8wL3zoUtB9Xgo1vB6w6xbTrd+HLV6jNSeXXnbbF1BEUvi9cNg==", + "version": "10.12.6", + "resolved": "https://registry.npmjs.org/@polkadot/types-augment/-/types-augment-10.12.6.tgz", + "integrity": "sha512-eUNanLs0w7SQLlsjFs7kTPfOTclfjllJxghwRqWZFHWjUbVcGcPwr8ITv/mfx1WTCqUqLMe6K8CPJ7BSggAWBA==", "dependencies": { - "@polkadot/types": "10.11.2", - "@polkadot/types-codec": "10.11.2", - "@polkadot/util": "^12.5.1", + "@polkadot/types": "10.12.6", + "@polkadot/types-codec": "10.12.6", + "@polkadot/util": "^12.6.2", "tslib": "^2.6.2" }, "engines": { @@ -3970,11 +4060,11 @@ } }, "node_modules/@polkadot/types-codec": { - "version": "10.11.2", - "resolved": "https://registry.npmjs.org/@polkadot/types-codec/-/types-codec-10.11.2.tgz", - "integrity": "sha512-3xjOQL+LOOMzYqlgP9ROL0FQnzU8lGflgYewzau7AsDlFziSEtb49a9BpYo6zil4koC+QB8zQ9OHGFumG08T8w==", + "version": "10.12.6", + "resolved": "https://registry.npmjs.org/@polkadot/types-codec/-/types-codec-10.12.6.tgz", + "integrity": "sha512-yCzKdj/mLhjSG3mR1XhQdzzpAy0Exv9UuEhGQHPpdjkF0CCfVgsFoOAF3ScsSzwacJxGgxPWvlk849DfTrBYGA==", "dependencies": { - "@polkadot/util": "^12.5.1", + "@polkadot/util": "^12.6.2", "@polkadot/x-bigint": "^12.6.2", "tslib": "^2.6.2" }, @@ -3983,12 +4073,12 @@ } }, "node_modules/@polkadot/types-create": { - "version": "10.11.2", - "resolved": "https://registry.npmjs.org/@polkadot/types-create/-/types-create-10.11.2.tgz", - "integrity": "sha512-SJt23NxYvefRxVZZm6mT9ed1pR6FDoIGQ3xUpbjhTLfU2wuhpKjekMVorYQ6z/gK2JLMu2kV92Ardsz+6GX5XQ==", + "version": "10.12.6", + "resolved": "https://registry.npmjs.org/@polkadot/types-create/-/types-create-10.12.6.tgz", + "integrity": "sha512-byuPy7IUFjzoxG3qrP4kEScfR92KFOAkaJksNT4kDZILPCeZSPPN7cLqdejypwDBqJthTJM0LqKK4g+eHGKdvw==", "dependencies": { - "@polkadot/types-codec": "10.11.2", - "@polkadot/util": "^12.5.1", + "@polkadot/types-codec": "10.12.6", + "@polkadot/util": "^12.6.2", "tslib": "^2.6.2" }, "engines": { @@ -3996,15 +4086,15 @@ } }, "node_modules/@polkadot/types-known": { - "version": "10.11.2", - "resolved": "https://registry.npmjs.org/@polkadot/types-known/-/types-known-10.11.2.tgz", - "integrity": "sha512-kbEIX7NUQFxpDB0FFGNyXX/odY7jbp56RGD+Z4A731fW2xh/DgAQrI994xTzuh0c0EqPE26oQm3kATSpseqo9w==", + "version": "10.12.6", + "resolved": "https://registry.npmjs.org/@polkadot/types-known/-/types-known-10.12.6.tgz", + "integrity": "sha512-E/LWfOAPUW7YKAiioY7Ax/s+G4cuNQop3U/TPPM7sxXOv9hSia2hgFjtiU4NyTRVwf1O07YASXtYSecdSgcCuQ==", "dependencies": { "@polkadot/networks": "^12.6.2", - "@polkadot/types": "10.11.2", - "@polkadot/types-codec": "10.11.2", - "@polkadot/types-create": "10.11.2", - "@polkadot/util": "^12.5.1", + "@polkadot/types": "10.12.6", + "@polkadot/types-codec": "10.12.6", + "@polkadot/types-create": "10.12.6", + "@polkadot/util": "^12.6.2", "tslib": "^2.6.2" }, "engines": { @@ -4012,11 +4102,11 @@ } }, "node_modules/@polkadot/types-support": { - "version": "10.11.2", - "resolved": "https://registry.npmjs.org/@polkadot/types-support/-/types-support-10.11.2.tgz", - "integrity": "sha512-X11hoykFYv/3efg4coZy2hUOUc97JhjQMJLzDhHniFwGLlYU8MeLnPdCVGkXx0xDDjTo4/ptS1XpZ5HYcg+gRw==", + "version": "10.12.6", + "resolved": "https://registry.npmjs.org/@polkadot/types-support/-/types-support-10.12.6.tgz", + "integrity": "sha512-SMq/hUZJLCZXq26pNDaxgXNJqAJD8YhVXWXulCg0YvbIoVwEkFE66TEkUbtoRLKcsZXbPdxJ3JfSoa9r6Ewhnw==", "dependencies": { - "@polkadot/util": "^12.5.1", + "@polkadot/util": "^12.6.2", "tslib": "^2.6.2" }, "engines": { @@ -4024,13 +4114,13 @@ } }, "node_modules/@polkadot/ui-settings": { - "version": "3.6.4", - "resolved": "https://registry.npmjs.org/@polkadot/ui-settings/-/ui-settings-3.6.4.tgz", - "integrity": "sha512-0vZPiMqGP9wv1SNBt0Snt6ScmrNHI2aqd9mixKs0pneDI0EO6ZndGanF3xgC51SCpS/N9qNh+VXckghmQMgaNQ==", + "version": "3.6.5", + "resolved": "https://registry.npmjs.org/@polkadot/ui-settings/-/ui-settings-3.6.5.tgz", + "integrity": "sha512-pRDwnXAsIrkARanL9BLDvg5u9PG7nnSDQkKmqYJiWbTW6G+ohOgBitlctjBnWASqjYMZLSRBY0MKwYrRrxJgVw==", "peer": true, "dependencies": { - "@polkadot/networks": "^12.6.1", - "@polkadot/util": "^12.6.1", + "@polkadot/networks": "^12.6.2", + "@polkadot/util": "^12.6.2", "eventemitter3": "^5.0.1", "store": "^2.0.12", "tslib": "^2.6.2" @@ -4044,9 +4134,9 @@ } }, "node_modules/@polkadot/ui-shared": { - "version": "3.6.4", - "resolved": "https://registry.npmjs.org/@polkadot/ui-shared/-/ui-shared-3.6.4.tgz", - "integrity": "sha512-nDlfKRPLxjSFm0769Nmkm+8vamH4HwZtKYZ5X+e2yDF1QkgaRUIc9+xJ/eeXp5lkfH985s0IAEmeNw8dQ0SbYg==", + "version": "3.6.5", + "resolved": "https://registry.npmjs.org/@polkadot/ui-shared/-/ui-shared-3.6.5.tgz", + "integrity": "sha512-ZBkOcKxun+lwCkokDDX71Ajir9yNYc0VuyUik+76xFvoHYkKdQ+qInv2GS6caWAtTSfIxb4EKNN2Euc9m8un1A==", "peer": true, "dependencies": { "colord": "^2.9.3", @@ -4342,9 +4432,9 @@ "peer": true }, "node_modules/@rollup/rollup-android-arm-eabi": { - "version": "4.9.6", - "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.9.6.tgz", - "integrity": "sha512-MVNXSSYN6QXOulbHpLMKYi60ppyO13W9my1qogeiAqtjb2yR4LSmfU2+POvDkLzhjYLXz9Rf9+9a3zFHW1Lecg==", + "version": "4.14.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm-eabi/-/rollup-android-arm-eabi-4.14.2.tgz", + "integrity": "sha512-ahxSgCkAEk+P/AVO0vYr7DxOD3CwAQrT0Go9BJyGQ9Ef0QxVOfjDZMiF4Y2s3mLyPrjonchIMH/tbWHucJMykQ==", "cpu": [ "arm" ], @@ -4355,9 +4445,9 @@ ] }, "node_modules/@rollup/rollup-android-arm64": { - "version": "4.9.6", - "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.9.6.tgz", - "integrity": "sha512-T14aNLpqJ5wzKNf5jEDpv5zgyIqcpn1MlwCrUXLrwoADr2RkWA0vOWP4XxbO9aiO3dvMCQICZdKeDrFl7UMClw==", + "version": "4.14.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-android-arm64/-/rollup-android-arm64-4.14.2.tgz", + "integrity": "sha512-lAarIdxZWbFSHFSDao9+I/F5jDaKyCqAPMq5HqnfpBw8dKDiCaaqM0lq5h1pQTLeIqueeay4PieGR5jGZMWprw==", "cpu": [ "arm64" ], @@ -4368,9 +4458,9 @@ ] }, "node_modules/@rollup/rollup-darwin-arm64": { - "version": "4.9.6", - "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.9.6.tgz", - "integrity": "sha512-CqNNAyhRkTbo8VVZ5R85X73H3R5NX9ONnKbXuHisGWC0qRbTTxnF1U4V9NafzJbgGM0sHZpdO83pLPzq8uOZFw==", + "version": "4.14.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-arm64/-/rollup-darwin-arm64-4.14.2.tgz", + "integrity": "sha512-SWsr8zEUk82KSqquIMgZEg2GE5mCSfr9sE/thDROkX6pb3QQWPp8Vw8zOq2GyxZ2t0XoSIUlvHDkrf5Gmf7x3Q==", "cpu": [ "arm64" ], @@ -4381,9 +4471,9 @@ ] }, "node_modules/@rollup/rollup-darwin-x64": { - "version": "4.9.6", - "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.9.6.tgz", - "integrity": "sha512-zRDtdJuRvA1dc9Mp6BWYqAsU5oeLixdfUvkTHuiYOHwqYuQ4YgSmi6+/lPvSsqc/I0Omw3DdICx4Tfacdzmhog==", + "version": "4.14.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-darwin-x64/-/rollup-darwin-x64-4.14.2.tgz", + "integrity": "sha512-o/HAIrQq0jIxJAhgtIvV5FWviYK4WB0WwV91SLUnsliw1lSAoLsmgEEgRWzDguAFeUEUUoIWXiJrPqU7vGiVkA==", "cpu": [ "x64" ], @@ -4394,9 +4484,9 @@ ] }, "node_modules/@rollup/rollup-linux-arm-gnueabihf": { - "version": "4.9.6", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.9.6.tgz", - "integrity": "sha512-oNk8YXDDnNyG4qlNb6is1ojTOGL/tRhbbKeE/YuccItzerEZT68Z9gHrY3ROh7axDc974+zYAPxK5SH0j/G+QQ==", + "version": "4.14.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm-gnueabihf/-/rollup-linux-arm-gnueabihf-4.14.2.tgz", + "integrity": "sha512-nwlJ65UY9eGq91cBi6VyDfArUJSKOYt5dJQBq8xyLhvS23qO+4Nr/RreibFHjP6t+5ap2ohZrUJcHv5zk5ju/g==", "cpu": [ "arm" ], @@ -4407,9 +4497,9 @@ ] }, "node_modules/@rollup/rollup-linux-arm64-gnu": { - "version": "4.9.6", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.9.6.tgz", - "integrity": "sha512-Z3O60yxPtuCYobrtzjo0wlmvDdx2qZfeAWTyfOjEDqd08kthDKexLpV97KfAeUXPosENKd8uyJMRDfFMxcYkDQ==", + "version": "4.14.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-gnu/-/rollup-linux-arm64-gnu-4.14.2.tgz", + "integrity": "sha512-Pg5TxxO2IVlMj79+c/9G0LREC9SY3HM+pfAwX7zj5/cAuwrbfj2Wv9JbMHIdPCfQpYsI4g9mE+2Bw/3aeSs2rQ==", "cpu": [ "arm64" ], @@ -4420,9 +4510,9 @@ ] }, "node_modules/@rollup/rollup-linux-arm64-musl": { - "version": "4.9.6", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.9.6.tgz", - "integrity": "sha512-gpiG0qQJNdYEVad+1iAsGAbgAnZ8j07FapmnIAQgODKcOTjLEWM9sRb+MbQyVsYCnA0Im6M6QIq6ax7liws6eQ==", + "version": "4.14.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-arm64-musl/-/rollup-linux-arm64-musl-4.14.2.tgz", + "integrity": "sha512-cAOTjGNm84gc6tS02D1EXtG7tDRsVSDTBVXOLbj31DkwfZwgTPYZ6aafSU7rD/4R2a34JOwlF9fQayuTSkoclA==", "cpu": [ "arm64" ], @@ -4432,10 +4522,23 @@ "linux" ] }, + "node_modules/@rollup/rollup-linux-powerpc64le-gnu": { + "version": "4.14.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-powerpc64le-gnu/-/rollup-linux-powerpc64le-gnu-4.14.2.tgz", + "integrity": "sha512-4RyT6v1kXb7C0fn6zV33rvaX05P0zHoNzaXI/5oFHklfKm602j+N4mn2YvoezQViRLPnxP8M1NaY4s/5kXO5cw==", + "cpu": [ + "ppc64" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, "node_modules/@rollup/rollup-linux-riscv64-gnu": { - "version": "4.9.6", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.9.6.tgz", - "integrity": "sha512-+uCOcvVmFUYvVDr27aiyun9WgZk0tXe7ThuzoUTAukZJOwS5MrGbmSlNOhx1j80GdpqbOty05XqSl5w4dQvcOA==", + "version": "4.14.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-riscv64-gnu/-/rollup-linux-riscv64-gnu-4.14.2.tgz", + "integrity": "sha512-KNUH6jC/vRGAKSorySTyc/yRYlCwN/5pnMjXylfBniwtJx5O7X17KG/0efj8XM3TZU7raYRXJFFReOzNmL1n1w==", "cpu": [ "riscv64" ], @@ -4445,10 +4548,23 @@ "linux" ] }, + "node_modules/@rollup/rollup-linux-s390x-gnu": { + "version": "4.14.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-s390x-gnu/-/rollup-linux-s390x-gnu-4.14.2.tgz", + "integrity": "sha512-xPV4y73IBEXToNPa3h5lbgXOi/v0NcvKxU0xejiFw6DtIYQqOTMhZ2DN18/HrrP0PmiL3rGtRG9gz1QE8vFKXQ==", + "cpu": [ + "s390x" + ], + "dev": true, + "optional": true, + "os": [ + "linux" + ] + }, "node_modules/@rollup/rollup-linux-x64-gnu": { - "version": "4.9.6", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.9.6.tgz", - "integrity": "sha512-HUNqM32dGzfBKuaDUBqFB7tP6VMN74eLZ33Q9Y1TBqRDn+qDonkAUyKWwF9BR9unV7QUzffLnz9GrnKvMqC/fw==", + "version": "4.14.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-gnu/-/rollup-linux-x64-gnu-4.14.2.tgz", + "integrity": "sha512-QBhtr07iFGmF9egrPOWyO5wciwgtzKkYPNLVCFZTmr4TWmY0oY2Dm/bmhHjKRwZoGiaKdNcKhFtUMBKvlchH+Q==", "cpu": [ "x64" ], @@ -4459,9 +4575,9 @@ ] }, "node_modules/@rollup/rollup-linux-x64-musl": { - "version": "4.9.6", - "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.9.6.tgz", - "integrity": "sha512-ch7M+9Tr5R4FK40FHQk8VnML0Szi2KRujUgHXd/HjuH9ifH72GUmw6lStZBo3c3GB82vHa0ZoUfjfcM7JiiMrQ==", + "version": "4.14.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-linux-x64-musl/-/rollup-linux-x64-musl-4.14.2.tgz", + "integrity": "sha512-8zfsQRQGH23O6qazZSFY5jP5gt4cFvRuKTpuBsC1ZnSWxV8ZKQpPqOZIUtdfMOugCcBvFGRa1pDC/tkf19EgBw==", "cpu": [ "x64" ], @@ -4472,9 +4588,9 @@ ] }, "node_modules/@rollup/rollup-win32-arm64-msvc": { - "version": "4.9.6", - "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.9.6.tgz", - "integrity": "sha512-VD6qnR99dhmTQ1mJhIzXsRcTBvTjbfbGGwKAHcu+52cVl15AC/kplkhxzW/uT0Xl62Y/meBKDZvoJSJN+vTeGA==", + "version": "4.14.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-arm64-msvc/-/rollup-win32-arm64-msvc-4.14.2.tgz", + "integrity": "sha512-H4s8UjgkPnlChl6JF5empNvFHp77Jx+Wfy2EtmYPe9G22XV+PMuCinZVHurNe8ggtwoaohxARJZbaH/3xjB/FA==", "cpu": [ "arm64" ], @@ -4485,9 +4601,9 @@ ] }, "node_modules/@rollup/rollup-win32-ia32-msvc": { - "version": "4.9.6", - "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.9.6.tgz", - "integrity": "sha512-J9AFDq/xiRI58eR2NIDfyVmTYGyIZmRcvcAoJ48oDld/NTR8wyiPUu2X/v1navJ+N/FGg68LEbX3Ejd6l8B7MQ==", + "version": "4.14.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-ia32-msvc/-/rollup-win32-ia32-msvc-4.14.2.tgz", + "integrity": "sha512-djqpAjm/i8erWYF0K6UY4kRO3X5+T4TypIqw60Q8MTqSBaQNpNXDhxdjpZ3ikgb+wn99svA7jxcXpiyg9MUsdw==", "cpu": [ "ia32" ], @@ -4498,9 +4614,9 @@ ] }, "node_modules/@rollup/rollup-win32-x64-msvc": { - "version": "4.9.6", - "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.9.6.tgz", - "integrity": "sha512-jqzNLhNDvIZOrt69Ce4UjGRpXJBzhUBzawMwnaDAwyHriki3XollsewxWzOzz+4yOFDkuJHtTsZFwMxhYJWmLQ==", + "version": "4.14.2", + "resolved": "https://registry.npmjs.org/@rollup/rollup-win32-x64-msvc/-/rollup-win32-x64-msvc-4.14.2.tgz", + "integrity": "sha512-teAqzLT0yTYZa8ZP7zhFKEx4cotS8Tkk5XiqNMJhD4CpaWB1BHARE4Qy+RzwnXvSAYv+Q3jAqCVBS+PS+Yee8Q==", "cpu": [ "x64" ], @@ -4511,9 +4627,9 @@ ] }, "node_modules/@scure/base": { - "version": "1.1.5", - "resolved": "https://registry.npmjs.org/@scure/base/-/base-1.1.5.tgz", - "integrity": "sha512-Brj9FiG2W1MRQSTB212YVPRrcbjkv48FoZi/u4l/zds/ieRrqsh7aUf6CLwkAq61oKXr/ZlTzlY66gLIj3TFTQ==", + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/@scure/base/-/base-1.1.6.tgz", + "integrity": "sha512-ok9AWwhcgYuGG3Zfhyqg+zwl+Wn5uE+dwC0NV/2qQkx4dABbb/bx96vWu8NSj+BNjjSjno+JRYRjle1jV08k3g==", "funding": { "url": "https://paulmillr.com/funding/" } @@ -4542,7 +4658,7 @@ "url": "https://paulmillr.com/funding/" } }, - "node_modules/@scure/bip32/node_modules/@noble/hashes": { + "node_modules/@scure/bip32/node_modules/@noble/curves/node_modules/@noble/hashes": { "version": "1.3.2", "resolved": "https://registry.npmjs.org/@noble/hashes/-/hashes-1.3.2.tgz", "integrity": "sha512-MVC8EAQp7MvEcm30KWENFjgR+Mkmf+D189XJTkFIlwohU5hcBbn1ZkKq7KVTi2Hme3PMGF390DaL52beVrIihQ==", @@ -4553,18 +4669,40 @@ "url": "https://paulmillr.com/funding/" } }, - "node_modules/@scure/bip39": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/@scure/bip39/-/bip39-1.2.1.tgz", - "integrity": "sha512-Z3/Fsz1yr904dduJD0NpiyRHhRYHdcnyh73FZWiV+/qhWi83wNJ3NWolYqCEN+ZWsUz2TWwajJggcRE9r1zUYg==", - "dependencies": { - "@noble/hashes": "~1.3.0", + "node_modules/@scure/bip32/node_modules/@noble/hashes": { + "version": "1.3.3", + "resolved": "https://registry.npmjs.org/@noble/hashes/-/hashes-1.3.3.tgz", + "integrity": "sha512-V7/fPHgl+jsVPXqqeOzT8egNj2iBIVt+ECeMMG8TdcnTikP3oaBtUVqpT/gYCR68aEBJSF+XbYUxStjbFMqIIA==", + "engines": { + "node": ">= 16" + }, + "funding": { + "url": "https://paulmillr.com/funding/" + } + }, + "node_modules/@scure/bip39": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/@scure/bip39/-/bip39-1.2.1.tgz", + "integrity": "sha512-Z3/Fsz1yr904dduJD0NpiyRHhRYHdcnyh73FZWiV+/qhWi83wNJ3NWolYqCEN+ZWsUz2TWwajJggcRE9r1zUYg==", + "dependencies": { + "@noble/hashes": "~1.3.0", "@scure/base": "~1.1.0" }, "funding": { "url": "https://paulmillr.com/funding/" } }, + "node_modules/@scure/bip39/node_modules/@noble/hashes": { + "version": "1.3.3", + "resolved": "https://registry.npmjs.org/@noble/hashes/-/hashes-1.3.3.tgz", + "integrity": "sha512-V7/fPHgl+jsVPXqqeOzT8egNj2iBIVt+ECeMMG8TdcnTikP3oaBtUVqpT/gYCR68aEBJSF+XbYUxStjbFMqIIA==", + "engines": { + "node": ">= 16" + }, + "funding": { + "url": "https://paulmillr.com/funding/" + } + }, "node_modules/@sinclair/typebox": { "version": "0.27.8", "resolved": "https://registry.npmjs.org/@sinclair/typebox/-/typebox-0.27.8.tgz", @@ -4572,9 +4710,9 @@ "dev": true }, "node_modules/@sinonjs/commons": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-3.0.0.tgz", - "integrity": "sha512-jXBtWAF4vmdNmZgD5FoKsVLv3rPgDnLgPbU84LIJ3otV44vJlDRokVng5v8NFJdCf/da9legHcKaRuZs4L7faA==", + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/@sinonjs/commons/-/commons-3.0.1.tgz", + "integrity": "sha512-K3mCHKQ9sVh8o1C9cxkwxaOmXoAMlDxC1mYyHrjqOWEcBjYr76t96zL2zlj5dUGZ3HSw240X1qgH3Mjf1yJWpQ==", "dev": true, "dependencies": { "type-detect": "4.0.8" @@ -5115,6 +5253,12 @@ "eventemitter3": "^4.0.7" } }, + "node_modules/@snowfork/snowbridge-types/node_modules/@substrate/connect-extension-protocol": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/@substrate/connect-extension-protocol/-/connect-extension-protocol-1.0.1.tgz", + "integrity": "sha512-161JhCC1csjH3GE5mPLEd7HbWtwNSPJBg3p1Ksz9SFlTzj/bgEwudiRN2y5i0MoLGCIJRYKyKGMxVnd29PzNjg==", + "peer": true + }, "node_modules/@snowfork/snowbridge-types/node_modules/@substrate/smoldot-light": { "version": "0.6.8", "resolved": "https://registry.npmjs.org/@substrate/smoldot-light/-/smoldot-light-0.6.8.tgz", @@ -5161,20 +5305,46 @@ } }, "node_modules/@substrate/connect": { - "version": "0.7.35", - "resolved": "https://registry.npmjs.org/@substrate/connect/-/connect-0.7.35.tgz", - "integrity": "sha512-Io8vkalbwaye+7yXfG1Nj52tOOoJln2bMlc7Q9Yy3vEWqZEVkgKmcPVzbwV0CWL3QD+KMPDA2Dnw/X7EdwgoLw==", - "hasInstallScript": true, + "version": "0.8.8", + "resolved": "https://registry.npmjs.org/@substrate/connect/-/connect-0.8.8.tgz", + "integrity": "sha512-zwaxuNEVI9bGt0rT8PEJiXOyebLIo6QN1SyiAHRPBOl6g3Sy0KKdSN8Jmyn++oXhVRD8aIe75/V8ZkS81T+BPQ==", "optional": true, "dependencies": { - "@substrate/connect-extension-protocol": "^1.0.1", - "smoldot": "2.0.7" + "@substrate/connect-extension-protocol": "^2.0.0", + "@substrate/connect-known-chains": "^1.1.1", + "@substrate/light-client-extension-helpers": "^0.0.4", + "smoldot": "2.0.22" } }, "node_modules/@substrate/connect-extension-protocol": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/@substrate/connect-extension-protocol/-/connect-extension-protocol-1.0.1.tgz", - "integrity": "sha512-161JhCC1csjH3GE5mPLEd7HbWtwNSPJBg3p1Ksz9SFlTzj/bgEwudiRN2y5i0MoLGCIJRYKyKGMxVnd29PzNjg==" + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/@substrate/connect-extension-protocol/-/connect-extension-protocol-2.0.0.tgz", + "integrity": "sha512-nKu8pDrE3LNCEgJjZe1iGXzaD6OSIDD4Xzz/yo4KO9mQ6LBvf49BVrt4qxBFGL6++NneLiWUZGoh+VSd4PyVIg==", + "optional": true + }, + "node_modules/@substrate/connect-known-chains": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/@substrate/connect-known-chains/-/connect-known-chains-1.1.3.tgz", + "integrity": "sha512-anL/gwl/kkfMvr+XFDpNOhcQDXBPF0KkaTKveIExs0bJ8AEjUrpsnaUgyQTjeMNTRcMR87fu+CVslc5ga6su2Q==", + "optional": true + }, + "node_modules/@substrate/light-client-extension-helpers": { + "version": "0.0.4", + "resolved": "https://registry.npmjs.org/@substrate/light-client-extension-helpers/-/light-client-extension-helpers-0.0.4.tgz", + "integrity": "sha512-vfKcigzL0SpiK+u9sX6dq2lQSDtuFLOxIJx2CKPouPEHIs8C+fpsufn52r19GQn+qDhU8POMPHOVoqLktj8UEA==", + "optional": true, + "dependencies": { + "@polkadot-api/client": "0.0.1-492c132563ea6b40ae1fc5470dec4cd18768d182.1.0", + "@polkadot-api/json-rpc-provider": "0.0.1-492c132563ea6b40ae1fc5470dec4cd18768d182.1.0", + "@polkadot-api/json-rpc-provider-proxy": "0.0.1-492c132563ea6b40ae1fc5470dec4cd18768d182.1.0", + "@polkadot-api/substrate-client": "0.0.1-492c132563ea6b40ae1fc5470dec4cd18768d182.1.0", + "@substrate/connect-extension-protocol": "^2.0.0", + "@substrate/connect-known-chains": "^1.1.1", + "rxjs": "^7.8.1" + }, + "peerDependencies": { + "smoldot": "2.x" + } }, "node_modules/@substrate/smoldot-light": { "version": "0.7.9", @@ -5188,14 +5358,14 @@ } }, "node_modules/@substrate/ss58-registry": { - "version": "1.44.0", - "resolved": "https://registry.npmjs.org/@substrate/ss58-registry/-/ss58-registry-1.44.0.tgz", - "integrity": "sha512-7lQ/7mMCzVNSEfDS4BCqnRnKCFKpcOaPrxMeGTXHX1YQzM/m2BBHjbK2C3dJvjv7GYxMiaTq/HdWQj1xS6ss+A==" + "version": "1.47.0", + "resolved": "https://registry.npmjs.org/@substrate/ss58-registry/-/ss58-registry-1.47.0.tgz", + "integrity": "sha512-6kuIJedRcisUJS2pgksEH2jZf3hfSIVzqtFzs/AyjTW3ETbMg5q1Bb7VWa0WYaT6dTrEXp/6UoXM5B9pSIUmcw==" }, "node_modules/@tsconfig/node10": { - "version": "1.0.9", - "resolved": "https://registry.npmjs.org/@tsconfig/node10/-/node10-1.0.9.tgz", - "integrity": "sha512-jNsYVVxU8v5g43Erja32laIDHXeoNvFEpX33OK4d6hljo3jDhCBDhx5dhCCTMWUojscpAagGiRkBKxpdl9fxqA==", + "version": "1.0.11", + "resolved": "https://registry.npmjs.org/@tsconfig/node10/-/node10-1.0.11.tgz", + "integrity": "sha512-DcRjDCujK/kCk/cUe8Xz8ZSpm8mS3mNNpta+jGCA6USEDfktlNvm1+IuZ9eTcDbNk41BHwpHHeW+N1lKCz4zOw==", "dev": true }, "node_modules/@tsconfig/node12": { @@ -5311,9 +5481,9 @@ } }, "node_modules/@types/jest": { - "version": "29.5.11", - "resolved": "https://registry.npmjs.org/@types/jest/-/jest-29.5.11.tgz", - "integrity": "sha512-S2mHmYIVe13vrm6q4kN6fLYYAka15ALQki/vgDC3mIukEOx8WJlv0kQPM+d4w8Gp6u0uSdKND04IlTXBv0rwnQ==", + "version": "29.5.12", + "resolved": "https://registry.npmjs.org/@types/jest/-/jest-29.5.12.tgz", + "integrity": "sha512-eDC8bTvT/QhYdxJAulQikueigY5AsdBRH2yDKW3yveW7svY3+DzN84/2NUgkw10RTiJbWqZrTtoGVdYlvFJdLw==", "dev": true, "dependencies": { "expect": "^29.0.0", @@ -5339,17 +5509,17 @@ "dev": true }, "node_modules/@types/node": { - "version": "20.10.6", - "resolved": "https://registry.npmjs.org/@types/node/-/node-20.10.6.tgz", - "integrity": "sha512-Vac8H+NlRNNlAmDfGUP7b5h/KA+AtWIzuXy0E6OyP8f1tCLYAtPvKRRDJjAPqhpCb0t6U2j7/xqAuLEebW2kiw==", + "version": "20.12.7", + "resolved": "https://registry.npmjs.org/@types/node/-/node-20.12.7.tgz", + "integrity": "sha512-wq0cICSkRLVaf3UGLMGItu/PtdY7oaXaI/RVU+xliKVOtRna3PRY57ZDfztpDL0n11vfymMUnXv8QwYCO7L1wg==", "dependencies": { "undici-types": "~5.26.4" } }, "node_modules/@types/node-fetch": { - "version": "2.6.10", - "resolved": "https://registry.npmjs.org/@types/node-fetch/-/node-fetch-2.6.10.tgz", - "integrity": "sha512-PPpPK6F9ALFTn59Ka3BaL+qGuipRfxNE8qVgkp0bVixeiR2c2/L+IVOiBdu9JhhT22sWnQEp6YyHGI2b2+CMcA==", + "version": "2.6.11", + "resolved": "https://registry.npmjs.org/@types/node-fetch/-/node-fetch-2.6.11.tgz", + "integrity": "sha512-24xFj9R5+rfQJLRyM56qh+wnVSYhyXC2tkoBndtY0U+vubqNsYXGjufB2nn8Q6gt0LrARwL6UBtMCSVCwl4B1g==", "peer": true, "dependencies": { "@types/node": "*", @@ -5363,9 +5533,9 @@ "dev": true }, "node_modules/@types/semver": { - "version": "7.5.6", - "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.5.6.tgz", - "integrity": "sha512-dn1l8LaMea/IjDoHNd9J52uBbInB796CDffS6VdIxvqYCPSG0V0DzHp76GpaWnlhg88uYyPbXCDIowa86ybd5A==", + "version": "7.5.8", + "resolved": "https://registry.npmjs.org/@types/semver/-/semver-7.5.8.tgz", + "integrity": "sha512-I8EUhyrgfLrcTkzV3TSsGyl1tSuPrEDzr0yd5m90UgNxQkyDXULk3b6MlQqTCpZpNtWe1K0hzclnZkTcLBe2UQ==", "dev": true }, "node_modules/@types/stack-utils": { @@ -5381,9 +5551,9 @@ "peer": true }, "node_modules/@types/uuid": { - "version": "9.0.7", - "resolved": "https://registry.npmjs.org/@types/uuid/-/uuid-9.0.7.tgz", - "integrity": "sha512-WUtIVRUZ9i5dYXefDEAI7sh9/O7jGvHg7Df/5O/gtH3Yabe5odI3UWopVR1qbPXQtvOxWu3mM4XxlYeZtMWF4g==", + "version": "9.0.8", + "resolved": "https://registry.npmjs.org/@types/uuid/-/uuid-9.0.8.tgz", + "integrity": "sha512-jg+97EGIcY9AGHJJRaaPVgetKDsrTgbRjQ5Msgjh/DQKEFl0DtyRr/VCOyD1T2R1MNeWPK/u7JoGhlDZnKBAfA==", "peer": true }, "node_modules/@types/websocket": { @@ -5411,25 +5581,25 @@ "dev": true }, "node_modules/@typescript-eslint/eslint-plugin": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-7.2.0.tgz", - "integrity": "sha512-mdekAHOqS9UjlmyF/LSs6AIEvfceV749GFxoBAjwAv0nkevfKHWQFDMcBZWUiIC5ft6ePWivXoS36aKQ0Cy3sw==", + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-7.6.0.tgz", + "integrity": "sha512-gKmTNwZnblUdnTIJu3e9kmeRRzV2j1a/LUO27KNNAnIC5zjy1aSvXSRp4rVNlmAoHlQ7HzX42NbKpcSr4jF80A==", "dev": true, "dependencies": { - "@eslint-community/regexpp": "^4.5.1", - "@typescript-eslint/scope-manager": "7.2.0", - "@typescript-eslint/type-utils": "7.2.0", - "@typescript-eslint/utils": "7.2.0", - "@typescript-eslint/visitor-keys": "7.2.0", + "@eslint-community/regexpp": "^4.10.0", + "@typescript-eslint/scope-manager": "7.6.0", + "@typescript-eslint/type-utils": "7.6.0", + "@typescript-eslint/utils": "7.6.0", + "@typescript-eslint/visitor-keys": "7.6.0", "debug": "^4.3.4", "graphemer": "^1.4.0", - "ignore": "^5.2.4", + "ignore": "^5.3.1", "natural-compare": "^1.4.0", - "semver": "^7.5.4", - "ts-api-utils": "^1.0.1" + "semver": "^7.6.0", + "ts-api-utils": "^1.3.0" }, "engines": { - "node": "^16.0.0 || >=18.0.0" + "node": "^18.18.0 || >=20.0.0" }, "funding": { "type": "opencollective", @@ -5445,144 +5615,20 @@ } } }, - "node_modules/@typescript-eslint/eslint-plugin/node_modules/@typescript-eslint/scope-manager": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-7.2.0.tgz", - "integrity": "sha512-Qh976RbQM/fYtjx9hs4XkayYujB/aPwglw2choHmf3zBjB4qOywWSdt9+KLRdHubGcoSwBnXUH2sR3hkyaERRg==", - "dev": true, - "dependencies": { - "@typescript-eslint/types": "7.2.0", - "@typescript-eslint/visitor-keys": "7.2.0" - }, - "engines": { - "node": "^16.0.0 || >=18.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/typescript-eslint" - } - }, - "node_modules/@typescript-eslint/eslint-plugin/node_modules/@typescript-eslint/types": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-7.2.0.tgz", - "integrity": "sha512-XFtUHPI/abFhm4cbCDc5Ykc8npOKBSJePY3a3s+lwumt7XWJuzP5cZcfZ610MIPHjQjNsOLlYK8ASPaNG8UiyA==", - "dev": true, - "engines": { - "node": "^16.0.0 || >=18.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/typescript-eslint" - } - }, - "node_modules/@typescript-eslint/eslint-plugin/node_modules/@typescript-eslint/typescript-estree": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-7.2.0.tgz", - "integrity": "sha512-cyxS5WQQCoBwSakpMrvMXuMDEbhOo9bNHHrNcEWis6XHx6KF518tkF1wBvKIn/tpq5ZpUYK7Bdklu8qY0MsFIA==", - "dev": true, - "dependencies": { - "@typescript-eslint/types": "7.2.0", - "@typescript-eslint/visitor-keys": "7.2.0", - "debug": "^4.3.4", - "globby": "^11.1.0", - "is-glob": "^4.0.3", - "minimatch": "9.0.3", - "semver": "^7.5.4", - "ts-api-utils": "^1.0.1" - }, - "engines": { - "node": "^16.0.0 || >=18.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/typescript-eslint" - }, - "peerDependenciesMeta": { - "typescript": { - "optional": true - } - } - }, - "node_modules/@typescript-eslint/eslint-plugin/node_modules/@typescript-eslint/utils": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-7.2.0.tgz", - "integrity": "sha512-YfHpnMAGb1Eekpm3XRK8hcMwGLGsnT6L+7b2XyRv6ouDuJU1tZir1GS2i0+VXRatMwSI1/UfcyPe53ADkU+IuA==", - "dev": true, - "dependencies": { - "@eslint-community/eslint-utils": "^4.4.0", - "@types/json-schema": "^7.0.12", - "@types/semver": "^7.5.0", - "@typescript-eslint/scope-manager": "7.2.0", - "@typescript-eslint/types": "7.2.0", - "@typescript-eslint/typescript-estree": "7.2.0", - "semver": "^7.5.4" - }, - "engines": { - "node": "^16.0.0 || >=18.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/typescript-eslint" - }, - "peerDependencies": { - "eslint": "^8.56.0" - } - }, - "node_modules/@typescript-eslint/eslint-plugin/node_modules/@typescript-eslint/visitor-keys": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-7.2.0.tgz", - "integrity": "sha512-c6EIQRHhcpl6+tO8EMR+kjkkV+ugUNXOmeASA1rlzkd8EPIriavpWoiEz1HR/VLhbVIdhqnV6E7JZm00cBDx2A==", - "dev": true, - "dependencies": { - "@typescript-eslint/types": "7.2.0", - "eslint-visitor-keys": "^3.4.1" - }, - "engines": { - "node": "^16.0.0 || >=18.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/typescript-eslint" - } - }, - "node_modules/@typescript-eslint/eslint-plugin/node_modules/brace-expansion": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", - "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", - "dev": true, - "dependencies": { - "balanced-match": "^1.0.0" - } - }, - "node_modules/@typescript-eslint/eslint-plugin/node_modules/minimatch": { - "version": "9.0.3", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz", - "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==", - "dev": true, - "dependencies": { - "brace-expansion": "^2.0.1" - }, - "engines": { - "node": ">=16 || 14 >=14.17" - }, - "funding": { - "url": "https://github.com/sponsors/isaacs" - } - }, "node_modules/@typescript-eslint/parser": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-7.2.0.tgz", - "integrity": "sha512-5FKsVcHTk6TafQKQbuIVkXq58Fnbkd2wDL4LB7AURN7RUOu1utVP+G8+6u3ZhEroW3DF6hyo3ZEXxgKgp4KeCg==", + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-7.6.0.tgz", + "integrity": "sha512-usPMPHcwX3ZoPWnBnhhorc14NJw9J4HpSXQX4urF2TPKG0au0XhJoZyX62fmvdHONUkmyUe74Hzm1//XA+BoYg==", "dev": true, "dependencies": { - "@typescript-eslint/scope-manager": "7.2.0", - "@typescript-eslint/types": "7.2.0", - "@typescript-eslint/typescript-estree": "7.2.0", - "@typescript-eslint/visitor-keys": "7.2.0", + "@typescript-eslint/scope-manager": "7.6.0", + "@typescript-eslint/types": "7.6.0", + "@typescript-eslint/typescript-estree": "7.6.0", + "@typescript-eslint/visitor-keys": "7.6.0", "debug": "^4.3.4" }, "engines": { - "node": "^16.0.0 || >=18.0.0" + "node": "^18.18.0 || >=20.0.0" }, "funding": { "type": "opencollective", @@ -5597,116 +5643,17 @@ } } }, - "node_modules/@typescript-eslint/parser/node_modules/@typescript-eslint/scope-manager": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-7.2.0.tgz", - "integrity": "sha512-Qh976RbQM/fYtjx9hs4XkayYujB/aPwglw2choHmf3zBjB4qOywWSdt9+KLRdHubGcoSwBnXUH2sR3hkyaERRg==", - "dev": true, - "dependencies": { - "@typescript-eslint/types": "7.2.0", - "@typescript-eslint/visitor-keys": "7.2.0" - }, - "engines": { - "node": "^16.0.0 || >=18.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/typescript-eslint" - } - }, - "node_modules/@typescript-eslint/parser/node_modules/@typescript-eslint/types": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-7.2.0.tgz", - "integrity": "sha512-XFtUHPI/abFhm4cbCDc5Ykc8npOKBSJePY3a3s+lwumt7XWJuzP5cZcfZ610MIPHjQjNsOLlYK8ASPaNG8UiyA==", - "dev": true, - "engines": { - "node": "^16.0.0 || >=18.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/typescript-eslint" - } - }, - "node_modules/@typescript-eslint/parser/node_modules/@typescript-eslint/typescript-estree": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-7.2.0.tgz", - "integrity": "sha512-cyxS5WQQCoBwSakpMrvMXuMDEbhOo9bNHHrNcEWis6XHx6KF518tkF1wBvKIn/tpq5ZpUYK7Bdklu8qY0MsFIA==", - "dev": true, - "dependencies": { - "@typescript-eslint/types": "7.2.0", - "@typescript-eslint/visitor-keys": "7.2.0", - "debug": "^4.3.4", - "globby": "^11.1.0", - "is-glob": "^4.0.3", - "minimatch": "9.0.3", - "semver": "^7.5.4", - "ts-api-utils": "^1.0.1" - }, - "engines": { - "node": "^16.0.0 || >=18.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/typescript-eslint" - }, - "peerDependenciesMeta": { - "typescript": { - "optional": true - } - } - }, - "node_modules/@typescript-eslint/parser/node_modules/@typescript-eslint/visitor-keys": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-7.2.0.tgz", - "integrity": "sha512-c6EIQRHhcpl6+tO8EMR+kjkkV+ugUNXOmeASA1rlzkd8EPIriavpWoiEz1HR/VLhbVIdhqnV6E7JZm00cBDx2A==", - "dev": true, - "dependencies": { - "@typescript-eslint/types": "7.2.0", - "eslint-visitor-keys": "^3.4.1" - }, - "engines": { - "node": "^16.0.0 || >=18.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/typescript-eslint" - } - }, - "node_modules/@typescript-eslint/parser/node_modules/brace-expansion": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", - "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", - "dev": true, - "dependencies": { - "balanced-match": "^1.0.0" - } - }, - "node_modules/@typescript-eslint/parser/node_modules/minimatch": { - "version": "9.0.3", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz", - "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==", - "dev": true, - "dependencies": { - "brace-expansion": "^2.0.1" - }, - "engines": { - "node": ">=16 || 14 >=14.17" - }, - "funding": { - "url": "https://github.com/sponsors/isaacs" - } - }, "node_modules/@typescript-eslint/scope-manager": { - "version": "5.62.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-5.62.0.tgz", - "integrity": "sha512-VXuvVvZeQCQb5Zgf4HAxc04q5j+WrNAtNh9OwCsCgpKqESMTu3tF/jhZ3xG6T4NZwWl65Bg8KuS2uEvhSfLl0w==", + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-7.6.0.tgz", + "integrity": "sha512-ngttyfExA5PsHSx0rdFgnADMYQi+Zkeiv4/ZxGYUWd0nLs63Ha0ksmp8VMxAIC0wtCFxMos7Lt3PszJssG/E6w==", "dev": true, "dependencies": { - "@typescript-eslint/types": "5.62.0", - "@typescript-eslint/visitor-keys": "5.62.0" + "@typescript-eslint/types": "7.6.0", + "@typescript-eslint/visitor-keys": "7.6.0" }, "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + "node": "^18.18.0 || >=20.0.0" }, "funding": { "type": "opencollective", @@ -5714,18 +5661,18 @@ } }, "node_modules/@typescript-eslint/type-utils": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-7.2.0.tgz", - "integrity": "sha512-xHi51adBHo9O9330J8GQYQwrKBqbIPJGZZVQTHHmy200hvkLZFWJIFtAG/7IYTWUyun6DE6w5InDReePJYJlJA==", + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/type-utils/-/type-utils-7.6.0.tgz", + "integrity": "sha512-NxAfqAPNLG6LTmy7uZgpK8KcuiS2NZD/HlThPXQRGwz6u7MDBWRVliEEl1Gj6U7++kVJTpehkhZzCJLMK66Scw==", "dev": true, "dependencies": { - "@typescript-eslint/typescript-estree": "7.2.0", - "@typescript-eslint/utils": "7.2.0", + "@typescript-eslint/typescript-estree": "7.6.0", + "@typescript-eslint/utils": "7.6.0", "debug": "^4.3.4", - "ts-api-utils": "^1.0.1" + "ts-api-utils": "^1.3.0" }, "engines": { - "node": "^16.0.0 || >=18.0.0" + "node": "^18.18.0 || >=20.0.0" }, "funding": { "type": "opencollective", @@ -5740,137 +5687,13 @@ } } }, - "node_modules/@typescript-eslint/type-utils/node_modules/@typescript-eslint/scope-manager": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-7.2.0.tgz", - "integrity": "sha512-Qh976RbQM/fYtjx9hs4XkayYujB/aPwglw2choHmf3zBjB4qOywWSdt9+KLRdHubGcoSwBnXUH2sR3hkyaERRg==", - "dev": true, - "dependencies": { - "@typescript-eslint/types": "7.2.0", - "@typescript-eslint/visitor-keys": "7.2.0" - }, - "engines": { - "node": "^16.0.0 || >=18.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/typescript-eslint" - } - }, - "node_modules/@typescript-eslint/type-utils/node_modules/@typescript-eslint/types": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-7.2.0.tgz", - "integrity": "sha512-XFtUHPI/abFhm4cbCDc5Ykc8npOKBSJePY3a3s+lwumt7XWJuzP5cZcfZ610MIPHjQjNsOLlYK8ASPaNG8UiyA==", - "dev": true, - "engines": { - "node": "^16.0.0 || >=18.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/typescript-eslint" - } - }, - "node_modules/@typescript-eslint/type-utils/node_modules/@typescript-eslint/typescript-estree": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-7.2.0.tgz", - "integrity": "sha512-cyxS5WQQCoBwSakpMrvMXuMDEbhOo9bNHHrNcEWis6XHx6KF518tkF1wBvKIn/tpq5ZpUYK7Bdklu8qY0MsFIA==", - "dev": true, - "dependencies": { - "@typescript-eslint/types": "7.2.0", - "@typescript-eslint/visitor-keys": "7.2.0", - "debug": "^4.3.4", - "globby": "^11.1.0", - "is-glob": "^4.0.3", - "minimatch": "9.0.3", - "semver": "^7.5.4", - "ts-api-utils": "^1.0.1" - }, - "engines": { - "node": "^16.0.0 || >=18.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/typescript-eslint" - }, - "peerDependenciesMeta": { - "typescript": { - "optional": true - } - } - }, - "node_modules/@typescript-eslint/type-utils/node_modules/@typescript-eslint/utils": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-7.2.0.tgz", - "integrity": "sha512-YfHpnMAGb1Eekpm3XRK8hcMwGLGsnT6L+7b2XyRv6ouDuJU1tZir1GS2i0+VXRatMwSI1/UfcyPe53ADkU+IuA==", - "dev": true, - "dependencies": { - "@eslint-community/eslint-utils": "^4.4.0", - "@types/json-schema": "^7.0.12", - "@types/semver": "^7.5.0", - "@typescript-eslint/scope-manager": "7.2.0", - "@typescript-eslint/types": "7.2.0", - "@typescript-eslint/typescript-estree": "7.2.0", - "semver": "^7.5.4" - }, - "engines": { - "node": "^16.0.0 || >=18.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/typescript-eslint" - }, - "peerDependencies": { - "eslint": "^8.56.0" - } - }, - "node_modules/@typescript-eslint/type-utils/node_modules/@typescript-eslint/visitor-keys": { - "version": "7.2.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-7.2.0.tgz", - "integrity": "sha512-c6EIQRHhcpl6+tO8EMR+kjkkV+ugUNXOmeASA1rlzkd8EPIriavpWoiEz1HR/VLhbVIdhqnV6E7JZm00cBDx2A==", - "dev": true, - "dependencies": { - "@typescript-eslint/types": "7.2.0", - "eslint-visitor-keys": "^3.4.1" - }, - "engines": { - "node": "^16.0.0 || >=18.0.0" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/typescript-eslint" - } - }, - "node_modules/@typescript-eslint/type-utils/node_modules/brace-expansion": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", - "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", - "dev": true, - "dependencies": { - "balanced-match": "^1.0.0" - } - }, - "node_modules/@typescript-eslint/type-utils/node_modules/minimatch": { - "version": "9.0.3", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz", - "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==", - "dev": true, - "dependencies": { - "brace-expansion": "^2.0.1" - }, - "engines": { - "node": ">=16 || 14 >=14.17" - }, - "funding": { - "url": "https://github.com/sponsors/isaacs" - } - }, "node_modules/@typescript-eslint/types": { - "version": "5.62.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-5.62.0.tgz", - "integrity": "sha512-87NVngcbVXUahrRTqIK27gD2t5Cu1yuCXxbLcFtCzZGlfyVWWh8mLHkoxzjsB6DDNnvdL+fW8MiwPEJyGJQDgQ==", + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-7.6.0.tgz", + "integrity": "sha512-h02rYQn8J+MureCvHVVzhl69/GAfQGPQZmOMjG1KfCl7o3HtMSlPaPUAPu6lLctXI5ySRGIYk94clD/AUMCUgQ==", "dev": true, "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + "node": "^18.18.0 || >=20.0.0" }, "funding": { "type": "opencollective", @@ -5878,21 +5701,22 @@ } }, "node_modules/@typescript-eslint/typescript-estree": { - "version": "5.62.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-5.62.0.tgz", - "integrity": "sha512-CmcQ6uY7b9y694lKdRB8FEel7JbU/40iSAPomu++SjLMntB+2Leay2LO6i8VnJk58MtE9/nQSFIH6jpyRWyYzA==", + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-7.6.0.tgz", + "integrity": "sha512-+7Y/GP9VuYibecrCQWSKgl3GvUM5cILRttpWtnAu8GNL9j11e4tbuGZmZjJ8ejnKYyBRb2ddGQ3rEFCq3QjMJw==", "dev": true, "dependencies": { - "@typescript-eslint/types": "5.62.0", - "@typescript-eslint/visitor-keys": "5.62.0", + "@typescript-eslint/types": "7.6.0", + "@typescript-eslint/visitor-keys": "7.6.0", "debug": "^4.3.4", "globby": "^11.1.0", "is-glob": "^4.0.3", - "semver": "^7.3.7", - "tsutils": "^3.21.0" + "minimatch": "^9.0.4", + "semver": "^7.6.0", + "ts-api-utils": "^1.3.0" }, "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + "node": "^18.18.0 || >=20.0.0" }, "funding": { "type": "opencollective", @@ -5905,42 +5729,41 @@ } }, "node_modules/@typescript-eslint/utils": { - "version": "5.62.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-5.62.0.tgz", - "integrity": "sha512-n8oxjeb5aIbPFEtmQxQYOLI0i9n5ySBEY/ZEHHZqKQSFnxio1rv6dthascc9dLuwrL0RC5mPCxB7vnAVGAYWAQ==", + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-7.6.0.tgz", + "integrity": "sha512-x54gaSsRRI+Nwz59TXpCsr6harB98qjXYzsRxGqvA5Ue3kQH+FxS7FYU81g/omn22ML2pZJkisy6Q+ElK8pBCA==", "dev": true, "dependencies": { - "@eslint-community/eslint-utils": "^4.2.0", - "@types/json-schema": "^7.0.9", - "@types/semver": "^7.3.12", - "@typescript-eslint/scope-manager": "5.62.0", - "@typescript-eslint/types": "5.62.0", - "@typescript-eslint/typescript-estree": "5.62.0", - "eslint-scope": "^5.1.1", - "semver": "^7.3.7" + "@eslint-community/eslint-utils": "^4.4.0", + "@types/json-schema": "^7.0.15", + "@types/semver": "^7.5.8", + "@typescript-eslint/scope-manager": "7.6.0", + "@typescript-eslint/types": "7.6.0", + "@typescript-eslint/typescript-estree": "7.6.0", + "semver": "^7.6.0" }, "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + "node": "^18.18.0 || >=20.0.0" }, "funding": { "type": "opencollective", "url": "https://opencollective.com/typescript-eslint" }, "peerDependencies": { - "eslint": "^6.0.0 || ^7.0.0 || ^8.0.0" + "eslint": "^8.56.0" } }, "node_modules/@typescript-eslint/visitor-keys": { - "version": "5.62.0", - "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-5.62.0.tgz", - "integrity": "sha512-07ny+LHRzQXepkGg6w0mFY41fVUNBrL2Roj/++7V1txKugfjm/Ci/qSND03r2RhlJhJYMcTn9AhhSSqQp0Ysyw==", + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-7.6.0.tgz", + "integrity": "sha512-4eLB7t+LlNUmXzfOu1VAIAdkjbu5xNSerURS9X/S5TUKWFRpXRQZbmtPqgKmYx8bj3J0irtQXSiWAOY82v+cgw==", "dev": true, "dependencies": { - "@typescript-eslint/types": "5.62.0", - "eslint-visitor-keys": "^3.3.0" + "@typescript-eslint/types": "7.6.0", + "eslint-visitor-keys": "^3.4.3" }, "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + "node": "^18.18.0 || >=20.0.0" }, "funding": { "type": "opencollective", @@ -6047,9 +5870,9 @@ } }, "node_modules/acorn-walk": { - "version": "8.3.1", - "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.3.1.tgz", - "integrity": "sha512-TgUZgYvqZprrl7YldZNoa9OciCAyZR+Ejm9eXzKCmjsF5IKp/wgQ7Z/ZpjpGTIUPwrHQIcYeI8qDh4PsEwxMbw==", + "version": "8.3.2", + "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.3.2.tgz", + "integrity": "sha512-cjkyv4OtNCIeqhHrfS81QWXoCBPExR/J62oyEqepVw8WaQeSqpW2uhuLPh1m9eWhDuOo/jUXVTlifvesOWp/4A==", "dev": true, "engines": { "node": ">=0.4.0" @@ -6168,28 +5991,32 @@ } }, "node_modules/array-buffer-byte-length": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/array-buffer-byte-length/-/array-buffer-byte-length-1.0.0.tgz", - "integrity": "sha512-LPuwb2P+NrQw3XhxGc36+XSvuBPopovXYTR9Ew++Du9Yb/bx5AzBfrIsBoj0EZUifjQU+sHL21sseZ3jerWO/A==", + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/array-buffer-byte-length/-/array-buffer-byte-length-1.0.1.tgz", + "integrity": "sha512-ahC5W1xgou+KTXix4sAO8Ki12Q+jf4i0+tmk3sC+zgcynshkHxzpXdImBehiUYKKKDwvfFiJl1tZt6ewscS1Mg==", "dev": true, "dependencies": { - "call-bind": "^1.0.2", - "is-array-buffer": "^3.0.1" + "call-bind": "^1.0.5", + "is-array-buffer": "^3.0.4" + }, + "engines": { + "node": ">= 0.4" }, "funding": { "url": "https://github.com/sponsors/ljharb" } }, "node_modules/array-includes": { - "version": "3.1.7", - "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.7.tgz", - "integrity": "sha512-dlcsNBIiWhPkHdOEEKnehA+RNUWDc4UqFtnIXU4uuYDPtA4LDkr7qip2p0VvFAEXNDr0yWZ9PJyIRiGjRLQzwQ==", - "dev": true, - "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.2.0", - "es-abstract": "^1.22.1", - "get-intrinsic": "^1.2.1", + "version": "3.1.8", + "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.8.tgz", + "integrity": "sha512-itaWrbYbqpGXkGhZPGUulwnhVf5Hpy1xiCFsGqyIGglbBxmG5vSjxQen3/WGOjPpNEv1RtBLKxbmVXm8HpJStQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.2", + "es-object-atoms": "^1.0.0", + "get-intrinsic": "^1.2.4", "is-string": "^1.0.7" }, "engines": { @@ -6209,16 +6036,17 @@ } }, "node_modules/array.prototype.findlastindex": { - "version": "1.2.3", - "resolved": "https://registry.npmjs.org/array.prototype.findlastindex/-/array.prototype.findlastindex-1.2.3.tgz", - "integrity": "sha512-LzLoiOMAxvy+Gd3BAq3B7VeIgPdo+Q8hthvKtXybMvRV0jrXfJM/t8mw7nNlpEcVlVUnCnM2KSX4XU5HmpodOA==", + "version": "1.2.5", + "resolved": "https://registry.npmjs.org/array.prototype.findlastindex/-/array.prototype.findlastindex-1.2.5.tgz", + "integrity": "sha512-zfETvRFA8o7EiNn++N5f/kaCw221hrpGsDmcpndVupkPzEc1Wuf3VgC0qby1BbHs7f5DVYjgtEU2LLh5bqeGfQ==", "dev": true, "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.2.0", - "es-abstract": "^1.22.1", - "es-shim-unscopables": "^1.0.0", - "get-intrinsic": "^1.2.1" + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.2", + "es-errors": "^1.3.0", + "es-object-atoms": "^1.0.0", + "es-shim-unscopables": "^1.0.2" }, "engines": { "node": ">= 0.4" @@ -6264,17 +6092,18 @@ } }, "node_modules/arraybuffer.prototype.slice": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.2.tgz", - "integrity": "sha512-yMBKppFur/fbHu9/6USUe03bZ4knMYiwFBcyiaXB8Go0qNehwX6inYPzK9U0NeQvGxKthcmHcaR8P5MStSRBAw==", + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/arraybuffer.prototype.slice/-/arraybuffer.prototype.slice-1.0.3.tgz", + "integrity": "sha512-bMxMKAjg13EBSVscxTaYA4mRc5t1UAXa2kXiGTNfZ079HIWXEkKmkgFrh/nJqamaLSrXO5H4WFFkPEaLJWbs3A==", "dev": true, "dependencies": { - "array-buffer-byte-length": "^1.0.0", - "call-bind": "^1.0.2", - "define-properties": "^1.2.0", - "es-abstract": "^1.22.1", - "get-intrinsic": "^1.2.1", - "is-array-buffer": "^3.0.2", + "array-buffer-byte-length": "^1.0.1", + "call-bind": "^1.0.5", + "define-properties": "^1.2.1", + "es-abstract": "^1.22.3", + "es-errors": "^1.2.1", + "get-intrinsic": "^1.2.3", + "is-array-buffer": "^3.0.4", "is-shared-array-buffer": "^1.0.2" }, "engines": { @@ -6299,10 +6128,13 @@ "integrity": "sha512-Oei9OH4tRh0YqU3GxhX79dM/mwVgvbZJaSNaRk+bshkj0S5cfHcgYakreBjrHwatXKbz+IoIdYLxrKim2MjW0Q==" }, "node_modules/available-typed-arrays": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.5.tgz", - "integrity": "sha512-DMD0KiN46eipeziST1LPP/STfDU0sufISXmjSgvVsoU2tqxctQeASejWcfNtxYKqETM1UxQ8sp2OrSBWpHY6sw==", + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/available-typed-arrays/-/available-typed-arrays-1.0.7.tgz", + "integrity": "sha512-wvUjBtSGN7+7SjNpq/9M2Tg350UZD3q62IFZLbRAR1bSMlCo1ZaeW+BJ+D090e4hIIZLBcTDWe4Mh4jvUDajzQ==", "dev": true, + "dependencies": { + "possible-typed-array-names": "^1.0.0" + }, "engines": { "node": ">= 0.4" }, @@ -6311,30 +6143,16 @@ } }, "node_modules/axios": { - "version": "1.6.5", - "resolved": "https://registry.npmjs.org/axios/-/axios-1.6.5.tgz", - "integrity": "sha512-Ii012v05KEVuUoFWmMW/UQv9aRIc3ZwkWDcM+h5Il8izZCtRVpDUfwpoFf7eOtajT3QiGR4yDUx7lPqHJULgbg==", + "version": "1.6.8", + "resolved": "https://registry.npmjs.org/axios/-/axios-1.6.8.tgz", + "integrity": "sha512-v/ZHtJDU39mDpyBoFVkETcd/uNdxrWRrg3bKpOKzXFA6Bvqopts6ALSMU3y6ijYxbw2B+wPrIv46egTzJXCLGQ==", "dev": true, "dependencies": { - "follow-redirects": "^1.15.4", + "follow-redirects": "^1.15.6", "form-data": "^4.0.0", "proxy-from-env": "^1.1.0" } }, - "node_modules/axios/node_modules/form-data": { - "version": "4.0.0", - "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.0.tgz", - "integrity": "sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww==", - "dev": true, - "dependencies": { - "asynckit": "^0.4.0", - "combined-stream": "^1.0.8", - "mime-types": "^2.1.12" - }, - "engines": { - "node": ">= 6" - } - }, "node_modules/babel-jest": { "version": "29.7.0", "resolved": "https://registry.npmjs.org/babel-jest/-/babel-jest-29.7.0.tgz", @@ -6581,12 +6399,15 @@ } }, "node_modules/binary-extensions": { - "version": "2.2.0", - "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.2.0.tgz", - "integrity": "sha512-jDctJ/IVQbZoJykoeHbhXpOlNBqGNcwXJKJog42E5HDPUwQTSdjCHdihjj0DlnheQ7blbT6dHOafNAiS8ooQKA==", + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.3.0.tgz", + "integrity": "sha512-Ceh+7ox5qe7LJuLHoY0feh3pHuUDHAcRUeyL2VYghZwfpkNIy/+8Ocg0a3UuSoYzavmylwuLWQOf3hl0jjMMIw==", "dev": true, "engines": { "node": ">=8" + }, + "funding": { + "url": "https://github.com/sponsors/sindresorhus" } }, "node_modules/blakejs": { @@ -6601,13 +6422,12 @@ "integrity": "sha512-eXRvHzWyYPBuB4NBy0cmYQjGitUrtqwbvlzP3G6VFnNRbsZQIxQ10PbKKHt8gZ/HW/D/747aDl+QkDqg3KQLMQ==" }, "node_modules/brace-expansion": { - "version": "1.1.11", - "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", - "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", + "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", "dev": true, "dependencies": { - "balanced-match": "^1.0.0", - "concat-map": "0.0.1" + "balanced-match": "^1.0.0" } }, "node_modules/braces": { @@ -6638,9 +6458,9 @@ "peer": true }, "node_modules/browserslist": { - "version": "4.22.2", - "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.22.2.tgz", - "integrity": "sha512-0UgcrvQmBDvZHFGdYUehrCNIazki7/lUP3kkoi/r3YB2amZbFM9J43ZRkJTXBUZK4gmx56+Sqk9+Vs9mwZx9+A==", + "version": "4.23.0", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.23.0.tgz", + "integrity": "sha512-QW8HiM1shhT2GuzkvklfjcKDiWFXHOeFCIA/huJPwHsslwcydgk7X+z2zXpEijP98UCY7HbubZt5J2Zgvf0CaQ==", "dev": true, "funding": [ { @@ -6657,8 +6477,8 @@ } ], "dependencies": { - "caniuse-lite": "^1.0.30001565", - "electron-to-chromium": "^1.4.601", + "caniuse-lite": "^1.0.30001587", + "electron-to-chromium": "^1.4.668", "node-releases": "^2.0.14", "update-browserslist-db": "^1.0.13" }, @@ -6734,9 +6554,9 @@ } }, "node_modules/bun": { - "version": "1.0.21", - "resolved": "https://registry.npmjs.org/bun/-/bun-1.0.21.tgz", - "integrity": "sha512-KqiXg0N6+SWgyh4QpCKIYlsli6wB7P/jX7tSUpE8jOdp5dPztQpId/Hx6wJ3ZAXGOr0gd56eMQf7TY9EnAyuzQ==", + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/bun/-/bun-1.1.3.tgz", + "integrity": "sha512-1jPSmSJcRlBmgBUFbaaw6DKy7HvyotWRNjafZKkhvVHoDhEXK1YRkHo99IG/0vvwj8BmkMnFpQu9R0T7JArllw==", "cpu": [ "arm64", "x64" @@ -6745,19 +6565,22 @@ "hasInstallScript": true, "os": [ "darwin", - "linux" + "linux", + "win32" ], "bin": { - "bun": "bin/bun", - "bunx": "bin/bun" + "bun": "bin/bun.exe", + "bunx": "bin/bun.exe" }, "optionalDependencies": { - "@oven/bun-darwin-aarch64": "1.0.21", - "@oven/bun-darwin-x64": "1.0.21", - "@oven/bun-darwin-x64-baseline": "1.0.21", - "@oven/bun-linux-aarch64": "1.0.21", - "@oven/bun-linux-x64": "1.0.21", - "@oven/bun-linux-x64-baseline": "1.0.21" + "@oven/bun-darwin-aarch64": "1.1.3", + "@oven/bun-darwin-x64": "1.1.3", + "@oven/bun-darwin-x64-baseline": "1.1.3", + "@oven/bun-linux-aarch64": "1.1.3", + "@oven/bun-linux-x64": "1.1.3", + "@oven/bun-linux-x64-baseline": "1.1.3", + "@oven/bun-windows-x64": "1.1.3", + "@oven/bun-windows-x64-baseline": "1.1.3" } }, "node_modules/bundle-require": { @@ -6785,14 +6608,19 @@ } }, "node_modules/call-bind": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.5.tgz", - "integrity": "sha512-C3nQxfFZxFRVoJoGKKI8y3MOEo129NQ+FgQ08iye+Mk4zNZZGdjfs06bVTr+DBSlA66Q2VEcMki/cUCP4SercQ==", + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.7.tgz", + "integrity": "sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w==", "dev": true, "dependencies": { + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", "function-bind": "^1.1.2", - "get-intrinsic": "^1.2.1", - "set-function-length": "^1.1.1" + "get-intrinsic": "^1.2.4", + "set-function-length": "^1.2.1" + }, + "engines": { + "node": ">= 0.4" }, "funding": { "url": "https://github.com/sponsors/ljharb" @@ -6842,9 +6670,9 @@ } }, "node_modules/caniuse-lite": { - "version": "1.0.30001574", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001574.tgz", - "integrity": "sha512-BtYEK4r/iHt/txm81KBudCUcTy7t+s9emrIaHqjYurQ10x71zJ5VQ9x1dYPcz/b+pKSp4y/v1xSI67A+LzpNyg==", + "version": "1.0.30001609", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001609.tgz", + "integrity": "sha512-JFPQs34lHKx1B5t1EpQpWH4c+29zIyn/haGsbpfq3suuV9v56enjFt23zqijxGTMwy1p/4H2tjnQMY+p1WoAyA==", "dev": true, "funding": [ { @@ -6900,16 +6728,10 @@ "dev": true }, "node_modules/chokidar": { - "version": "3.5.3", - "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.5.3.tgz", - "integrity": "sha512-Dr3sfKRP6oTcjf2JmUmFJfeVMvXBdegxB0iVQ5eb2V10uFJUCAS8OByZdVAyVb8xXNz3GjjTgj9kLWsZTqE6kw==", + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.6.0.tgz", + "integrity": "sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==", "dev": true, - "funding": [ - { - "type": "individual", - "url": "https://paulmillr.com/funding/" - } - ], "dependencies": { "anymatch": "~3.1.2", "braces": "~3.0.2", @@ -6922,6 +6744,9 @@ "engines": { "node": ">= 8.10.0" }, + "funding": { + "url": "https://paulmillr.com/funding/" + }, "optionalDependencies": { "fsevents": "~2.3.2" } @@ -7432,13 +7257,16 @@ "peer": true }, "node_modules/d": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/d/-/d-1.0.1.tgz", - "integrity": "sha512-m62ShEObQ39CfralilEQRjH6oAMtNCV1xJyEx5LpRYUVN+EviphDgUc/F3hnYbADmkiNs67Y+3ylmlG7Lnu+FA==", + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/d/-/d-1.0.2.tgz", + "integrity": "sha512-MOqHvMWF9/9MX6nza0KgvFH4HpMU0EF5uUDXqX/BtxtU8NfB0QzRtJ8Oe/6SuS4kbhyzVJwjd97EA4PKrzJ8bw==", "peer": true, "dependencies": { - "es5-ext": "^0.10.50", - "type": "^1.0.1" + "es5-ext": "^0.10.64", + "type": "^2.7.2" + }, + "engines": { + "node": ">=0.12" } }, "node_modules/data-uri-to-buffer": { @@ -7449,6 +7277,57 @@ "node": ">= 12" } }, + "node_modules/data-view-buffer": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/data-view-buffer/-/data-view-buffer-1.0.1.tgz", + "integrity": "sha512-0lht7OugA5x3iJLOWFhWK/5ehONdprk0ISXqVFn/NFrDu+cuc8iADFrGQz5BnRK7LLU3JmkbXSxaqX+/mXYtUA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.6", + "es-errors": "^1.3.0", + "is-data-view": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/data-view-byte-length": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/data-view-byte-length/-/data-view-byte-length-1.0.1.tgz", + "integrity": "sha512-4J7wRJD3ABAzr8wP+OcIcqq2dlUKp4DVflx++hs5h5ZKydWMI6/D/fAot+yh6g2tHh8fLFTvNOaVN357NvSrOQ==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "is-data-view": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, + "node_modules/data-view-byte-offset": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/data-view-byte-offset/-/data-view-byte-offset-1.0.0.tgz", + "integrity": "sha512-t/Ygsytq+R995EJ5PZlD4Cu56sWa8InXySaViRzw9apusqsOO2bQP+SbYzAhR0pFKoB+43lYy8rWban9JSuXnA==", + "dev": true, + "dependencies": { + "call-bind": "^1.0.6", + "es-errors": "^1.3.0", + "is-data-view": "^1.0.1" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, "node_modules/dataloader": { "version": "1.4.0", "resolved": "https://registry.npmjs.org/dataloader/-/dataloader-1.4.0.tgz", @@ -7506,9 +7385,9 @@ } }, "node_modules/dedent": { - "version": "1.5.1", - "resolved": "https://registry.npmjs.org/dedent/-/dedent-1.5.1.tgz", - "integrity": "sha512-+LxW+KLWxu3HW3M2w2ympwtqPrqYRzU8fqi6Fhd18fBALe15blJPI/I4+UHveMVG6lJqB4JNd4UG0S5cnVHwIg==", + "version": "1.5.3", + "resolved": "https://registry.npmjs.org/dedent/-/dedent-1.5.3.tgz", + "integrity": "sha512-NHQtfOOW68WD8lgypbLA5oT+Bt0xXJhiYvoR6SmmNXZfpzOGXwdKWmcwG8N7PwVVWV3eF/68nmD9BaJSsTBhyQ==", "dev": true, "peerDependencies": { "babel-plugin-macros": "^3.1.0" @@ -7547,17 +7426,20 @@ } }, "node_modules/define-data-property": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.1.tgz", - "integrity": "sha512-E7uGkTzkk1d0ByLeSc6ZsFS79Axg+m1P/VsgYsxHgiuc3tFSj+MjMIwe90FC4lOAZzNBdY7kkO2P2wKdsQ1vgQ==", + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.4.tgz", + "integrity": "sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A==", "dev": true, "dependencies": { - "get-intrinsic": "^1.2.1", - "gopd": "^1.0.1", - "has-property-descriptors": "^1.0.0" + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "gopd": "^1.0.1" }, "engines": { "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" } }, "node_modules/define-properties": { @@ -7673,15 +7555,15 @@ } }, "node_modules/electron-to-chromium": { - "version": "1.4.620", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.620.tgz", - "integrity": "sha512-a2fcSHOHrqBJsPNXtf6ZCEZpXrFCcbK1FBxfX3txoqWzNgtEDG1f3M59M98iwxhRW4iMKESnSjbJ310/rkrp0g==", + "version": "1.4.735", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.735.tgz", + "integrity": "sha512-pkYpvwg8VyOTQAeBqZ7jsmpCjko1Qc6We1ZtZCjRyYbT5v4AIUKDy5cQTRotQlSSZmMr8jqpEt6JtOj5k7lR7A==", "dev": true }, "node_modules/elliptic": { - "version": "6.5.4", - "resolved": "https://registry.npmjs.org/elliptic/-/elliptic-6.5.4.tgz", - "integrity": "sha512-iLhC6ULemrljPZb+QutR5TQGB+pdW6KGD5RSegS+8sorOZT+rdQFbsQFJgvN3eRqNALqJer4oQ16YvJHlU8hzQ==", + "version": "6.5.5", + "resolved": "https://registry.npmjs.org/elliptic/-/elliptic-6.5.5.tgz", + "integrity": "sha512-7EjbcmUm17NQFu4Pmgmq2olYMj8nwMnpcddByChSUjArp8F5DQWcIcpriwO4ZToLNAJig0yiyjswfyGNje/ixw==", "peer": true, "dependencies": { "bn.js": "^4.11.9", @@ -7717,6 +7599,19 @@ "integrity": "sha512-L18DaJsXSUk2+42pv8mLs5jJT2hqFkFE4j21wOmgbUqsZ2hL72NsUU785g9RXgo3s0ZNgVl42TiHp3ZtOv/Vyg==", "dev": true }, + "node_modules/enhanced-resolve": { + "version": "5.16.0", + "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.16.0.tgz", + "integrity": "sha512-O+QWCviPNSSLAD9Ucn8Awv+poAkqn3T1XY5/N7kR7rQO9yfSGWkYZDwpJ+iKF7B8rxaQKWngSqACpgzeapSyoA==", + "dev": true, + "dependencies": { + "graceful-fs": "^4.2.4", + "tapable": "^2.2.0" + }, + "engines": { + "node": ">=10.13.0" + } + }, "node_modules/enquirer": { "version": "2.4.1", "resolved": "https://registry.npmjs.org/enquirer/-/enquirer-2.4.1.tgz", @@ -7740,50 +7635,57 @@ } }, "node_modules/es-abstract": { - "version": "1.22.3", - "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.22.3.tgz", - "integrity": "sha512-eiiY8HQeYfYH2Con2berK+To6GrK2RxbPawDkGq4UiCQQfZHb6wX9qQqkbpPqaxQFcl8d9QzZqo0tGE0VcrdwA==", - "dev": true, - "dependencies": { - "array-buffer-byte-length": "^1.0.0", - "arraybuffer.prototype.slice": "^1.0.2", - "available-typed-arrays": "^1.0.5", - "call-bind": "^1.0.5", - "es-set-tostringtag": "^2.0.1", + "version": "1.23.3", + "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.23.3.tgz", + "integrity": "sha512-e+HfNH61Bj1X9/jLc5v1owaLYuHdeHHSQlkhCBiTK8rBvKaULl/beGMxwrMXjpYrv4pz22BlY570vVePA2ho4A==", + "dev": true, + "dependencies": { + "array-buffer-byte-length": "^1.0.1", + "arraybuffer.prototype.slice": "^1.0.3", + "available-typed-arrays": "^1.0.7", + "call-bind": "^1.0.7", + "data-view-buffer": "^1.0.1", + "data-view-byte-length": "^1.0.1", + "data-view-byte-offset": "^1.0.0", + "es-define-property": "^1.0.0", + "es-errors": "^1.3.0", + "es-object-atoms": "^1.0.0", + "es-set-tostringtag": "^2.0.3", "es-to-primitive": "^1.2.1", "function.prototype.name": "^1.1.6", - "get-intrinsic": "^1.2.2", - "get-symbol-description": "^1.0.0", + "get-intrinsic": "^1.2.4", + "get-symbol-description": "^1.0.2", "globalthis": "^1.0.3", "gopd": "^1.0.1", - "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", - "hasown": "^2.0.0", - "internal-slot": "^1.0.5", - "is-array-buffer": "^3.0.2", + "hasown": "^2.0.2", + "internal-slot": "^1.0.7", + "is-array-buffer": "^3.0.4", "is-callable": "^1.2.7", - "is-negative-zero": "^2.0.2", + "is-data-view": "^1.0.1", + "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.12", + "is-typed-array": "^1.1.13", "is-weakref": "^1.0.2", "object-inspect": "^1.13.1", "object-keys": "^1.1.1", - "object.assign": "^4.1.4", - "regexp.prototype.flags": "^1.5.1", - "safe-array-concat": "^1.0.1", - "safe-regex-test": "^1.0.0", - "string.prototype.trim": "^1.2.8", - "string.prototype.trimend": "^1.0.7", - "string.prototype.trimstart": "^1.0.7", - "typed-array-buffer": "^1.0.0", - "typed-array-byte-length": "^1.0.0", - "typed-array-byte-offset": "^1.0.0", - "typed-array-length": "^1.0.4", + "object.assign": "^4.1.5", + "regexp.prototype.flags": "^1.5.2", + "safe-array-concat": "^1.1.2", + "safe-regex-test": "^1.0.3", + "string.prototype.trim": "^1.2.9", + "string.prototype.trimend": "^1.0.8", + "string.prototype.trimstart": "^1.0.8", + "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.6", "unbox-primitive": "^1.0.2", - "which-typed-array": "^1.1.13" + "which-typed-array": "^1.1.15" }, "engines": { "node": ">= 0.4" @@ -7792,15 +7694,48 @@ "url": "https://github.com/sponsors/ljharb" } }, + "node_modules/es-define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.0.tgz", + "integrity": "sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ==", + "dev": true, + "dependencies": { + "get-intrinsic": "^1.2.4" + }, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-errors": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz", + "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==", + "dev": true, + "engines": { + "node": ">= 0.4" + } + }, + "node_modules/es-object-atoms": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/es-object-atoms/-/es-object-atoms-1.0.0.tgz", + "integrity": "sha512-MZ4iQ6JwHOBQjahnjwaC1ZtIBH+2ohjamzAO3oaHcXYup7qxjF2fixyH+Q71voWHeOkI2q/TnJao/KfXYIZWbw==", + "dev": true, + "dependencies": { + "es-errors": "^1.3.0" + }, + "engines": { + "node": ">= 0.4" + } + }, "node_modules/es-set-tostringtag": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.0.2.tgz", - "integrity": "sha512-BuDyupZt65P9D2D2vA/zqcI3G5xRsklm5N3xCwuiy+/vKy8i0ifdsQP1sLgO4tZDSCaQUSnmC48khknGMV3D2Q==", + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/es-set-tostringtag/-/es-set-tostringtag-2.0.3.tgz", + "integrity": "sha512-3T8uNMC3OQTHkFUsFq8r/BwAXLHvU/9O9mE0fBc/MY5iq/8H7ncvO947LmYA6ldWw9Uh8Yhf25zu6n7nML5QWQ==", "dev": true, "dependencies": { - "get-intrinsic": "^1.2.2", - "has-tostringtag": "^1.0.0", - "hasown": "^2.0.0" + "get-intrinsic": "^1.2.4", + "has-tostringtag": "^1.0.2", + "hasown": "^2.0.1" }, "engines": { "node": ">= 0.4" @@ -7860,13 +7795,16 @@ } }, "node_modules/es6-symbol": { - "version": "3.1.3", - "resolved": "https://registry.npmjs.org/es6-symbol/-/es6-symbol-3.1.3.tgz", - "integrity": "sha512-NJ6Yn3FuDinBaBRWl/q5X/s4koRHBrgKAu+yGI6JCBeiu3qrcbJhwT2GeR/EXVfylRk8dpQVJoLEFhK+Mu31NA==", + "version": "3.1.4", + "resolved": "https://registry.npmjs.org/es6-symbol/-/es6-symbol-3.1.4.tgz", + "integrity": "sha512-U9bFFjX8tFiATgtkJ1zg25+KviIXpgRvRHS8sau3GfhVzThRQrOeksPeT0BWW2MNZs1OEWJ1DPXOQMn0KKRkvg==", "peer": true, "dependencies": { - "d": "^1.0.1", - "ext": "^1.1.2" + "d": "^1.0.2", + "ext": "^1.7.0" + }, + "engines": { + "node": ">=0.12" } }, "node_modules/esbuild": { @@ -7908,9 +7846,9 @@ } }, "node_modules/escalade": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.1.tgz", - "integrity": "sha512-k0er2gUkLf8O0zKJiAhmkTnJlTvINGv7ygDNPbeIsX/TJjGJZHuh9B2UxbsaEkmlEo9MfhrSzmhIlhRlI2GXnw==", + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/escalade/-/escalade-3.1.2.tgz", + "integrity": "sha512-ErCHMCae19vR8vQGe50xIsVomy19rg6gFu3+r3jkEO46suLMWBksvVyoGgQV+jOfl84ZSOSlmv6Gxa89PmTGmA==", "dev": true, "engines": { "node": ">=6" @@ -8054,10 +7992,35 @@ "ms": "^2.1.1" } }, + "node_modules/eslint-import-resolver-typescript": { + "version": "3.6.1", + "resolved": "https://registry.npmjs.org/eslint-import-resolver-typescript/-/eslint-import-resolver-typescript-3.6.1.tgz", + "integrity": "sha512-xgdptdoi5W3niYeuQxKmzVDTATvLYqhpwmykwsh7f6HIOStGWEIL9iqZgQDF9u9OEzrRwR8no5q2VT+bjAujTg==", + "dev": true, + "dependencies": { + "debug": "^4.3.4", + "enhanced-resolve": "^5.12.0", + "eslint-module-utils": "^2.7.4", + "fast-glob": "^3.3.1", + "get-tsconfig": "^4.5.0", + "is-core-module": "^2.11.0", + "is-glob": "^4.0.3" + }, + "engines": { + "node": "^14.18.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/unts/projects/eslint-import-resolver-ts" + }, + "peerDependencies": { + "eslint": "*", + "eslint-plugin-import": "*" + } + }, "node_modules/eslint-module-utils": { - "version": "2.8.0", - "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.8.0.tgz", - "integrity": "sha512-aWajIYfsqCKRDgUfjEXNN/JlrzauMuSEy5sbd7WXbtW3EH6A6MpwEh42c7qD+MqQo9QMJ6fWLAeIJynx0g6OAw==", + "version": "2.8.1", + "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.8.1.tgz", + "integrity": "sha512-rXDXR3h7cs7dy9RNpUlQf80nX31XWJEyGq1tRMo+6GsO5VmTe4UTwtmonAD4ZkAsrfMVDA2wlGJ3790Ys+D49Q==", "dev": true, "dependencies": { "debug": "^3.2.7" @@ -8107,63 +8070,200 @@ "engines": { "node": ">=4" }, - "peerDependencies": { - "eslint": "^2 || ^3 || ^4 || ^5 || ^6 || ^7.2.0 || ^8" + "peerDependencies": { + "eslint": "^2 || ^3 || ^4 || ^5 || ^6 || ^7.2.0 || ^8" + } + }, + "node_modules/eslint-plugin-import/node_modules/brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "dependencies": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "node_modules/eslint-plugin-import/node_modules/debug": { + "version": "3.2.7", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", + "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", + "dev": true, + "dependencies": { + "ms": "^2.1.1" + } + }, + "node_modules/eslint-plugin-import/node_modules/doctrine": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", + "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", + "dev": true, + "dependencies": { + "esutils": "^2.0.2" + }, + "engines": { + "node": ">=0.10.0" + } + }, + "node_modules/eslint-plugin-import/node_modules/minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dev": true, + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, + "node_modules/eslint-plugin-import/node_modules/semver": { + "version": "6.3.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", + "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", + "dev": true, + "bin": { + "semver": "bin/semver.js" + } + }, + "node_modules/eslint-plugin-jest": { + "version": "28.2.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-jest/-/eslint-plugin-jest-28.2.0.tgz", + "integrity": "sha512-yRDti/a+f+SMSmNTiT9/M/MzXGkitl8CfzUxnpoQcTyfq8gUrXMriVcWU36W1X6BZSUoyUCJrDAWWUA2N4hE5g==", + "dev": true, + "dependencies": { + "@typescript-eslint/utils": "^6.0.0" + }, + "engines": { + "node": "^16.10.0 || ^18.12.0 || >=20.0.0" + }, + "peerDependencies": { + "@typescript-eslint/eslint-plugin": "^6.0.0 || ^7.0.0", + "eslint": "^7.0.0 || ^8.0.0 || ^9.0.0", + "jest": "*" + }, + "peerDependenciesMeta": { + "@typescript-eslint/eslint-plugin": { + "optional": true + }, + "jest": { + "optional": true + } + } + }, + "node_modules/eslint-plugin-jest/node_modules/@typescript-eslint/scope-manager": { + "version": "6.21.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/scope-manager/-/scope-manager-6.21.0.tgz", + "integrity": "sha512-OwLUIWZJry80O99zvqXVEioyniJMa+d2GrqpUTqi5/v5D5rOrppJVBPa0yKCblcigC0/aYAzxxqQ1B+DS2RYsg==", + "dev": true, + "dependencies": { + "@typescript-eslint/types": "6.21.0", + "@typescript-eslint/visitor-keys": "6.21.0" + }, + "engines": { + "node": "^16.0.0 || >=18.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + } + }, + "node_modules/eslint-plugin-jest/node_modules/@typescript-eslint/types": { + "version": "6.21.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/types/-/types-6.21.0.tgz", + "integrity": "sha512-1kFmZ1rOm5epu9NZEZm1kckCDGj5UJEf7P1kliH4LKu/RkwpsfqqGmY2OOcUs18lSlQBKLDYBOGxRVtrMN5lpg==", + "dev": true, + "engines": { + "node": "^16.0.0 || >=18.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" } }, - "node_modules/eslint-plugin-import/node_modules/debug": { - "version": "3.2.7", - "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.7.tgz", - "integrity": "sha512-CFjzYYAi4ThfiQvizrFQevTTXHtnCqWfe7x1AhgEscTz6ZbLbfoLRLPugTQyBth6f8ZERVUSyWHFD/7Wu4t1XQ==", + "node_modules/eslint-plugin-jest/node_modules/@typescript-eslint/typescript-estree": { + "version": "6.21.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-6.21.0.tgz", + "integrity": "sha512-6npJTkZcO+y2/kr+z0hc4HwNfrrP4kNYh57ek7yCNlrBjWQ1Y0OS7jiZTkgumrvkX5HkEKXFZkkdFNkaW2wmUQ==", "dev": true, "dependencies": { - "ms": "^2.1.1" + "@typescript-eslint/types": "6.21.0", + "@typescript-eslint/visitor-keys": "6.21.0", + "debug": "^4.3.4", + "globby": "^11.1.0", + "is-glob": "^4.0.3", + "minimatch": "9.0.3", + "semver": "^7.5.4", + "ts-api-utils": "^1.0.1" + }, + "engines": { + "node": "^16.0.0 || >=18.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + }, + "peerDependenciesMeta": { + "typescript": { + "optional": true + } } }, - "node_modules/eslint-plugin-import/node_modules/doctrine": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", - "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", + "node_modules/eslint-plugin-jest/node_modules/@typescript-eslint/utils": { + "version": "6.21.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/utils/-/utils-6.21.0.tgz", + "integrity": "sha512-NfWVaC8HP9T8cbKQxHcsJBY5YE1O33+jpMwN45qzWWaPDZgLIbo12toGMWnmhvCpd3sIxkpDw3Wv1B3dYrbDQQ==", "dev": true, "dependencies": { - "esutils": "^2.0.2" + "@eslint-community/eslint-utils": "^4.4.0", + "@types/json-schema": "^7.0.12", + "@types/semver": "^7.5.0", + "@typescript-eslint/scope-manager": "6.21.0", + "@typescript-eslint/types": "6.21.0", + "@typescript-eslint/typescript-estree": "6.21.0", + "semver": "^7.5.4" }, "engines": { - "node": ">=0.10.0" + "node": "^16.0.0 || >=18.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" + }, + "peerDependencies": { + "eslint": "^7.0.0 || ^8.0.0" } }, - "node_modules/eslint-plugin-import/node_modules/semver": { - "version": "6.3.1", - "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.1.tgz", - "integrity": "sha512-BR7VvDCVHO+q2xBEWskxS6DJE1qRnb7DxzUrogb71CWoSficBxYsiAGd+Kl0mmq/MprG9yArRkyrQxTO6XjMzA==", + "node_modules/eslint-plugin-jest/node_modules/@typescript-eslint/visitor-keys": { + "version": "6.21.0", + "resolved": "https://registry.npmjs.org/@typescript-eslint/visitor-keys/-/visitor-keys-6.21.0.tgz", + "integrity": "sha512-JJtkDduxLi9bivAB+cYOVMtbkqdPOhZ+ZI5LC47MIRrDV4Yn2o+ZnW10Nkmr28xRpSpdJ6Sm42Hjf2+REYXm0A==", "dev": true, - "bin": { - "semver": "bin/semver.js" + "dependencies": { + "@typescript-eslint/types": "6.21.0", + "eslint-visitor-keys": "^3.4.1" + }, + "engines": { + "node": "^16.0.0 || >=18.0.0" + }, + "funding": { + "type": "opencollective", + "url": "https://opencollective.com/typescript-eslint" } }, - "node_modules/eslint-plugin-jest": { - "version": "27.9.0", - "resolved": "https://registry.npmjs.org/eslint-plugin-jest/-/eslint-plugin-jest-27.9.0.tgz", - "integrity": "sha512-QIT7FH7fNmd9n4se7FFKHbsLKGQiw885Ds6Y/sxKgCZ6natwCsXdgPOADnYVxN2QrRweF0FZWbJ6S7Rsn7llug==", + "node_modules/eslint-plugin-jest/node_modules/minimatch": { + "version": "9.0.3", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz", + "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==", "dev": true, "dependencies": { - "@typescript-eslint/utils": "^5.10.0" + "brace-expansion": "^2.0.1" }, "engines": { - "node": "^14.15.0 || ^16.10.0 || >=18.0.0" - }, - "peerDependencies": { - "@typescript-eslint/eslint-plugin": "^5.0.0 || ^6.0.0 || ^7.0.0", - "eslint": "^7.0.0 || ^8.0.0", - "jest": "*" + "node": ">=16 || 14 >=14.17" }, - "peerDependenciesMeta": { - "@typescript-eslint/eslint-plugin": { - "optional": true - }, - "jest": { - "optional": true - } + "funding": { + "url": "https://github.com/sponsors/isaacs" } }, "node_modules/eslint-plugin-prettier": { @@ -8197,16 +8297,19 @@ } }, "node_modules/eslint-scope": { - "version": "5.1.1", - "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.1.1.tgz", - "integrity": "sha512-2NxwbF/hZ0KpepYN0cNbo+FN6XoK7GaHlQhgx/hIZl6Va0bF45RQOOwhLIy8lQDbuCiadSLCBnH2CFYquit5bw==", + "version": "7.2.2", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz", + "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==", "dev": true, "dependencies": { "esrecurse": "^4.3.0", - "estraverse": "^4.1.1" + "estraverse": "^5.2.0" }, "engines": { - "node": ">=8.0.0" + "node": "^12.22.0 || ^14.17.0 || >=16.0.0" + }, + "funding": { + "url": "https://opencollective.com/eslint" } }, "node_modules/eslint-visitor-keys": { @@ -8242,6 +8345,16 @@ "integrity": "sha512-8+9WqebbFzpX9OR+Wa6O29asIogeRMzcGtAINdpMHHyAg10f05aSFVBbcEqGf/PXw1EjAZ+q2/bEBg3DvurK3Q==", "dev": true }, + "node_modules/eslint/node_modules/brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "dependencies": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, "node_modules/eslint/node_modules/chalk": { "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", @@ -8288,31 +8401,6 @@ "url": "https://github.com/sponsors/sindresorhus" } }, - "node_modules/eslint/node_modules/eslint-scope": { - "version": "7.2.2", - "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-7.2.2.tgz", - "integrity": "sha512-dOt21O7lTMhDM+X9mB4GX+DZrZtCUJPL/wlcTqxyrx5IvO0IYtILdtrQGQp+8n5S0gwSVmOf9NQrjMOgfQZlIg==", - "dev": true, - "dependencies": { - "esrecurse": "^4.3.0", - "estraverse": "^5.2.0" - }, - "engines": { - "node": "^12.22.0 || ^14.17.0 || >=16.0.0" - }, - "funding": { - "url": "https://opencollective.com/eslint" - } - }, - "node_modules/eslint/node_modules/estraverse": { - "version": "5.3.0", - "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", - "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", - "dev": true, - "engines": { - "node": ">=4.0" - } - }, "node_modules/eslint/node_modules/find-up": { "version": "5.0.0", "resolved": "https://registry.npmjs.org/find-up/-/find-up-5.0.0.tgz", @@ -8365,6 +8453,18 @@ "url": "https://github.com/sponsors/sindresorhus" } }, + "node_modules/eslint/node_modules/minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dev": true, + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, "node_modules/eslint/node_modules/p-limit": { "version": "3.1.0", "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-3.1.0.tgz", @@ -8422,12 +8522,6 @@ "node": ">=0.10" } }, - "node_modules/esniff/node_modules/type": { - "version": "2.7.2", - "resolved": "https://registry.npmjs.org/type/-/type-2.7.2.tgz", - "integrity": "sha512-dzlvlNlt6AXU7EBSfpAscydQ7gXB+pPGsPnfJnZpiNJBDj7IaJzQlBZYGdEi4R9HmPdBv2XmWJ6YUtoTa7lmCw==", - "peer": true - }, "node_modules/espree": { "version": "9.6.1", "resolved": "https://registry.npmjs.org/espree/-/espree-9.6.1.tgz", @@ -8470,15 +8564,6 @@ "node": ">=0.10" } }, - "node_modules/esquery/node_modules/estraverse": { - "version": "5.3.0", - "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", - "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", - "dev": true, - "engines": { - "node": ">=4.0" - } - }, "node_modules/esrecurse": { "version": "4.3.0", "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.3.0.tgz", @@ -8491,7 +8576,7 @@ "node": ">=4.0" } }, - "node_modules/esrecurse/node_modules/estraverse": { + "node_modules/estraverse": { "version": "5.3.0", "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-5.3.0.tgz", "integrity": "sha512-MMdARuVEQziNTeJD8DgMqmhwR11BRQ/cBP+pLtYdSTnf3MIO8fFeiINEbX36ZdNlfU/7A9f3gUw49B3oQsvwBA==", @@ -8500,15 +8585,6 @@ "node": ">=4.0" } }, - "node_modules/estraverse": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", - "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==", - "dev": true, - "engines": { - "node": ">=4.0" - } - }, "node_modules/esutils": { "version": "2.0.3", "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", @@ -8528,9 +8604,9 @@ } }, "node_modules/ethers": { - "version": "6.11.0", - "resolved": "https://registry.npmjs.org/ethers/-/ethers-6.11.0.tgz", - "integrity": "sha512-kPHNTnhVWiWU6AVo6CAeTjXEK24SpCXyZvwG9ROFjT0Vlux0EOhWKBAeC+45iDj80QNJTYaT1SDEmeunT0vDNw==", + "version": "6.11.1", + "resolved": "https://registry.npmjs.org/ethers/-/ethers-6.11.1.tgz", + "integrity": "sha512-mxTAE6wqJQAbp5QAe/+o+rXOID7Nw91OZXvgpjDa1r4fAbq2Nu314oEZSbjoRLacuCzs7kUC3clEvkCQowffGg==", "funding": [ { "type": "individual", @@ -8554,11 +8630,6 @@ "node": ">=14.0.0" } }, - "node_modules/ethers/node_modules/@adraffy/ens-normalize": { - "version": "1.10.1", - "resolved": "https://registry.npmjs.org/@adraffy/ens-normalize/-/ens-normalize-1.10.1.tgz", - "integrity": "sha512-96Z2IP3mYmF1Xg2cDm8f1gWGf/HUVedQ3FMifV4kG/PQ4yEP51xDtRAEfhVNt5f/uzpNkZHwWQuUcu6D6K+Ekw==" - }, "node_modules/ethers/node_modules/@noble/curves": { "version": "1.2.0", "resolved": "https://registry.npmjs.org/@noble/curves/-/curves-1.2.0.tgz", @@ -8689,12 +8760,6 @@ "type": "^2.7.2" } }, - "node_modules/ext/node_modules/type": { - "version": "2.7.2", - "resolved": "https://registry.npmjs.org/type/-/type-2.7.2.tgz", - "integrity": "sha512-dzlvlNlt6AXU7EBSfpAscydQ7gXB+pPGsPnfJnZpiNJBDj7IaJzQlBZYGdEi4R9HmPdBv2XmWJ6YUtoTa7lmCw==", - "peer": true - }, "node_modules/extendable-error": { "version": "0.1.7", "resolved": "https://registry.npmjs.org/extendable-error/-/extendable-error-0.1.7.tgz", @@ -8774,9 +8839,9 @@ "peer": true }, "node_modules/fastq": { - "version": "1.16.0", - "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.16.0.tgz", - "integrity": "sha512-ifCoaXsDrsdkWTtiNJX5uzHDsrck5TzfKKDcuFFTIrrc/BS076qgEIfoIy1VeZqViznfKiysPYTh/QeHtnIsYA==", + "version": "1.17.1", + "resolved": "https://registry.npmjs.org/fastq/-/fastq-1.17.1.tgz", + "integrity": "sha512-sRVD3lWVIXWg6By68ZN7vho9a1pQcN/WBFaAAsDDFzlJjvoGx0P8z7V1t72grFJfJhu3YPZBuu25f7Kaw2jN1w==", "dev": true, "dependencies": { "reusify": "^1.0.4" @@ -8875,15 +8940,15 @@ } }, "node_modules/flatted": { - "version": "3.2.9", - "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.2.9.tgz", - "integrity": "sha512-36yxDn5H7OFZQla0/jFJmbIKTdZAQHngCedGxiMmpNfEZM0sdEeT+WczLQrjK6D7o2aiyLYDnkw0R3JK0Qv1RQ==", + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/flatted/-/flatted-3.3.1.tgz", + "integrity": "sha512-X8cqMLLie7KsNUDSdzeN8FYK9rEt4Dt67OsG/DNGnYTSDBG4uFAJFBnUeiV+zCVAvwFy56IjM9sH51jVaEhNxw==", "dev": true }, "node_modules/follow-redirects": { - "version": "1.15.5", - "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.5.tgz", - "integrity": "sha512-vSFWUON1B+yAw1VN4xMfxgn5fTUiaOzAJCKBwIIgT/+7CuGy9+r+5gITvP62j3RmaD5Ph65UaERdOSRGUzZtgw==", + "version": "1.15.6", + "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.15.6.tgz", + "integrity": "sha512-wWN62YITEaOpSK584EZXJafH1AGpO8RVgElfkuXbTOrPX4fIfOyEpW/CsiNd8JdYrAoOvafRTOEnvsO++qCqFA==", "dev": true, "funding": [ { @@ -8929,7 +8994,6 @@ "version": "4.0.0", "resolved": "https://registry.npmjs.org/form-data/-/form-data-4.0.0.tgz", "integrity": "sha512-ETEklSGi5t0QMZuiXoA/Q6vcnxcLQP5vdugSpuAyi6SVGi2clPPp+xgEhuMaHC+zGgn31Kd235W35f7Hykkaww==", - "peer": true, "dependencies": { "asynckit": "^0.4.0", "combined-stream": "^1.0.8", @@ -9051,16 +9115,20 @@ } }, "node_modules/get-intrinsic": { - "version": "1.2.2", - "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.2.tgz", - "integrity": "sha512-0gSo4ml/0j98Y3lngkFEot/zhiCeWsbYIlZ+uZOVgzLyLaUw7wxUL+nCTP0XJvJg1AXulJRI3UJi8GsbDuxdGA==", + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.4.tgz", + "integrity": "sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==", "dev": true, "dependencies": { + "es-errors": "^1.3.0", "function-bind": "^1.1.2", "has-proto": "^1.0.1", "has-symbols": "^1.0.3", "hasown": "^2.0.0" }, + "engines": { + "node": ">= 0.4" + }, "funding": { "url": "https://github.com/sponsors/ljharb" } @@ -9087,13 +9155,14 @@ } }, "node_modules/get-symbol-description": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.0.tgz", - "integrity": "sha512-2EmdH1YvIQiZpltCNgkuiUnyukzxM/R6NDJX31Ke3BG1Nq5b0S2PhX59UKi9vZpPDQVdqn+1IcaAwnzTT5vCjw==", + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/get-symbol-description/-/get-symbol-description-1.0.2.tgz", + "integrity": "sha512-g0QYk1dZBxGwk+Ngc+ltRH2IBp2f7zBkBMBJZCDerh6EhlhSR6+9irMCuT/09zD6qkarHUSn529sK/yL4S27mg==", "dev": true, "dependencies": { - "call-bind": "^1.0.2", - "get-intrinsic": "^1.1.1" + "call-bind": "^1.0.5", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.4" }, "engines": { "node": ">= 0.4" @@ -9102,17 +9171,29 @@ "url": "https://github.com/sponsors/ljharb" } }, + "node_modules/get-tsconfig": { + "version": "4.7.3", + "resolved": "https://registry.npmjs.org/get-tsconfig/-/get-tsconfig-4.7.3.tgz", + "integrity": "sha512-ZvkrzoUA0PQZM6fy6+/Hce561s+faD1rsNwhnO5FelNjyy7EMGJ3Rz1AQ8GYDWjhRs/7dBLOEJvhK8MiEJOAFg==", + "dev": true, + "dependencies": { + "resolve-pkg-maps": "^1.0.0" + }, + "funding": { + "url": "https://github.com/privatenumber/get-tsconfig?sponsor=1" + } + }, "node_modules/glob": { - "version": "10.3.10", - "resolved": "https://registry.npmjs.org/glob/-/glob-10.3.10.tgz", - "integrity": "sha512-fa46+tv1Ak0UPK1TOy/pZrIybNNt4HCv7SDzwyfiOZkvZLEbjsZkJBPtDHVshZjbecAoAGSC20MjLDG/qr679g==", + "version": "10.3.12", + "resolved": "https://registry.npmjs.org/glob/-/glob-10.3.12.tgz", + "integrity": "sha512-TCNv8vJ+xz4QiqTpfOJA7HvYv+tNIRHKfUWw/q+v2jdgN4ebz+KY9tGx5J4rHP0o84mNP+ApH66HRX8us3Khqg==", "dev": true, "dependencies": { "foreground-child": "^3.1.0", - "jackspeak": "^2.3.5", + "jackspeak": "^2.3.6", "minimatch": "^9.0.1", - "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0", - "path-scurry": "^1.10.1" + "minipass": "^7.0.4", + "path-scurry": "^1.10.2" }, "bin": { "glob": "dist/esm/bin.mjs" @@ -9136,30 +9217,6 @@ "node": ">=10.13.0" } }, - "node_modules/glob/node_modules/brace-expansion": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-2.0.1.tgz", - "integrity": "sha512-XnAIvQ8eM+kC6aULx6wuQiwVsnzsi9d3WxzV3FpWTGA19F621kwdbsAcFKXgKUHZWsy+mY6iL1sHTxWEFCytDA==", - "dev": true, - "dependencies": { - "balanced-match": "^1.0.0" - } - }, - "node_modules/glob/node_modules/minimatch": { - "version": "9.0.3", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.3.tgz", - "integrity": "sha512-RHiac9mvaRw0x3AYRgDC1CxAP7HTcNrrECeA8YYJeWnpo+2Q5CegtZjaotWTWxDG3UeGA1coE05iH1mPjT/2mg==", - "dev": true, - "dependencies": { - "brace-expansion": "^2.0.1" - }, - "engines": { - "node": ">=16 || 14 >=14.17" - }, - "funding": { - "url": "https://github.com/sponsors/isaacs" - } - }, "node_modules/globals": { "version": "13.24.0", "resolved": "https://registry.npmjs.org/globals/-/globals-13.24.0.tgz", @@ -9268,21 +9325,21 @@ } }, "node_modules/has-property-descriptors": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.1.tgz", - "integrity": "sha512-VsX8eaIewvas0xnvinAe9bw4WfIeODpGYikiWYLH+dma0Jw6KHYqWiWfhQlgOVK8D6PvjubK5Uc4P0iIhIcNVg==", + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.2.tgz", + "integrity": "sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==", "dev": true, "dependencies": { - "get-intrinsic": "^1.2.2" + "es-define-property": "^1.0.0" }, "funding": { "url": "https://github.com/sponsors/ljharb" } }, "node_modules/has-proto": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.1.tgz", - "integrity": "sha512-7qE+iP+O+bgF9clE5+UoBFzE65mlBiVj3tKCrlNQ0Ogwm0BjpT/gK4SlLYDMybDh5I3TCTKnPPa0oMG7JDYrhg==", + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.3.tgz", + "integrity": "sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q==", "dev": true, "engines": { "node": ">= 0.4" @@ -9304,12 +9361,12 @@ } }, "node_modules/has-tostringtag": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.0.tgz", - "integrity": "sha512-kFjcSNhnlGV1kyoGk7OXKSawH5JOb/LzUc5w9B02hOTO0dfFRjbHQKvg1d6cf3HbeUmtU9VbbV3qzZ2Teh97WQ==", + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/has-tostringtag/-/has-tostringtag-1.0.2.tgz", + "integrity": "sha512-NqADB8VjPFLM2V0VvHUewwwsw0ZWBaIdgo+ieHtK3hasLz4qeCRjYcqfB6AQrBggRKppKF8L52/VqdVsO47Dlw==", "dev": true, "dependencies": { - "has-symbols": "^1.0.2" + "has-symbols": "^1.0.3" }, "engines": { "node": ">= 0.4" @@ -9343,9 +9400,9 @@ } }, "node_modules/hasown": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.0.tgz", - "integrity": "sha512-vUptKVTpIJhcczKBbgnS+RtcuYMB8+oNzPK2/Hp3hanz8JmpATdmmgLgSaadVREkDm+e2giHwY3ZRkyjSIDDFA==", + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", + "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", "dev": true, "dependencies": { "function-bind": "^1.1.2" @@ -9440,9 +9497,9 @@ "peer": true }, "node_modules/ignore": { - "version": "5.3.0", - "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.0.tgz", - "integrity": "sha512-g7dmpshy+gD7mh88OC9NwSGTKoc3kyLAZQRU1mt53Aw/vnvfXnbC+F/7F7QoYVKbV+KNvJx8wArewKy1vXMtlg==", + "version": "5.3.1", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-5.3.1.tgz", + "integrity": "sha512-5Fytz/IraMjqpwfd34ke28PTVMjZjJG2MPn5t7OE4eUCUNf8BAa7b5WUS9/Qvr6mwOQS7Mk6vdsMno5he+T8Xw==", "dev": true, "engines": { "node": ">= 4" @@ -9526,12 +9583,12 @@ "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" }, "node_modules/internal-slot": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.6.tgz", - "integrity": "sha512-Xj6dv+PsbtwyPpEflsejS+oIZxmMlV44zAhG479uYu89MsjcYOhCFnNyKrkJrihbsiasQyY0afoCl/9BLR65bg==", + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/internal-slot/-/internal-slot-1.0.7.tgz", + "integrity": "sha512-NGnrKwXzSms2qUUih/ILZ5JBqNTSa1+ZmP6flaIp6KmSElgE9qdndzS3cqjrDovwFdmwsGsLdeFgB6suw+1e9g==", "dev": true, "dependencies": { - "get-intrinsic": "^1.2.2", + "es-errors": "^1.3.0", "hasown": "^2.0.0", "side-channel": "^1.0.4" }, @@ -9549,14 +9606,16 @@ } }, "node_modules/is-array-buffer": { - "version": "3.0.2", - "resolved": "https://registry.npmjs.org/is-array-buffer/-/is-array-buffer-3.0.2.tgz", - "integrity": "sha512-y+FyyR/w8vfIRq4eQcM1EYgSTnmHXPqaF+IgzgraytCFq5Xh8lllDVmAZolPJiZttZLeFSINPYMaEJ7/vWUa1w==", + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/is-array-buffer/-/is-array-buffer-3.0.4.tgz", + "integrity": "sha512-wcjaerHw0ydZwfhiKbXJWLDY8A7yV7KhjQOpb83hGgGfId/aQa4TOvwyzn2PuswW2gPCYEL/nEAiSVpdOj1lXw==", "dev": true, "dependencies": { "call-bind": "^1.0.2", - "get-intrinsic": "^1.2.0", - "is-typed-array": "^1.1.10" + "get-intrinsic": "^1.2.1" + }, + "engines": { + "node": ">= 0.4" }, "funding": { "url": "https://github.com/sponsors/ljharb" @@ -9632,6 +9691,21 @@ "url": "https://github.com/sponsors/ljharb" } }, + "node_modules/is-data-view": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-data-view/-/is-data-view-1.0.1.tgz", + "integrity": "sha512-AHkaJrsUVW6wq6JS8y3JnM/GJF/9cf+k20+iDzlSaJrinEo5+7vRiteOSwBhHRiAyQATN1AmY4hwzxJKPmYf+w==", + "dev": true, + "dependencies": { + "is-typed-array": "^1.1.13" + }, + "engines": { + "node": ">= 0.4" + }, + "funding": { + "url": "https://github.com/sponsors/ljharb" + } + }, "node_modules/is-date-object": { "version": "1.0.5", "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.5.tgz", @@ -9690,9 +9764,9 @@ } }, "node_modules/is-negative-zero": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.2.tgz", - "integrity": "sha512-dqJvarLawXsFbNDeJW7zAz8ItJ9cd28YufuuFzh0G8pNHjJMnY08Dv7sYX2uF5UpQOwieAeOExEYAWWfu7ZZUA==", + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/is-negative-zero/-/is-negative-zero-2.0.3.tgz", + "integrity": "sha512-5KoIu2Ngpyek75jXodFvnafB6DJgr3u8uuK0LEZJjrU19DrMD3EVERaR8sjz8CCGgpZvxPl9SuE1GMVPFHx1mw==", "dev": true, "engines": { "node": ">= 0.4" @@ -9760,12 +9834,15 @@ } }, "node_modules/is-shared-array-buffer": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.2.tgz", - "integrity": "sha512-sqN2UDu1/0y6uvXyStCOzyhAjCSlHceFoMKJW8W9EU9cvic/QdsZ0kEU93HEy3IUEFZIiH/3w+AH/UQbPHNdhA==", + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/is-shared-array-buffer/-/is-shared-array-buffer-1.0.3.tgz", + "integrity": "sha512-nA2hv5XIhLR3uVzDDfCIknerhx8XUKnstuOERPNNIinXG7v9u+ohXF67vxm4TPTEPU6lm61ZkwP3c9PCB97rhg==", "dev": true, "dependencies": { - "call-bind": "^1.0.2" + "call-bind": "^1.0.7" + }, + "engines": { + "node": ">= 0.4" }, "funding": { "url": "https://github.com/sponsors/ljharb" @@ -9826,12 +9903,12 @@ } }, "node_modules/is-typed-array": { - "version": "1.1.12", - "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.12.tgz", - "integrity": "sha512-Z14TF2JNG8Lss5/HMqt0//T9JeHXttXy5pH/DBU4vi98ozO2btxzq9MwYDZYnKwU8nRsz/+GVFVRDq3DkVuSPg==", + "version": "1.1.13", + "resolved": "https://registry.npmjs.org/is-typed-array/-/is-typed-array-1.1.13.tgz", + "integrity": "sha512-uZ25/bUAlUY5fR4OKT4rZQEBrzQWYV9ZJYGGsUmEJ6thodVJ1HX64ePQ6Z0qPWP+m+Uq6e9UugrE38jeYsDSMw==", "dev": true, "dependencies": { - "which-typed-array": "^1.1.11" + "which-typed-array": "^1.1.14" }, "engines": { "node": ">= 0.4" @@ -9903,14 +9980,14 @@ } }, "node_modules/istanbul-lib-instrument": { - "version": "6.0.1", - "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-6.0.1.tgz", - "integrity": "sha512-EAMEJBsYuyyztxMxW3g7ugGPkrZsV57v0Hmv3mm1uQsmB+QnZuepg731CRaIgeUVSdmsTngOkSnauNF8p7FIhA==", + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-6.0.2.tgz", + "integrity": "sha512-1WUsZ9R1lA0HtBSohTkm39WTPlNKSJ5iFk7UwqXkBLoHQT+hfqPsfsTDVuZdKGaBwn7din9bS7SsnoAr943hvw==", "dev": true, "dependencies": { - "@babel/core": "^7.12.3", - "@babel/parser": "^7.14.7", - "@istanbuljs/schema": "^0.1.2", + "@babel/core": "^7.23.9", + "@babel/parser": "^7.23.9", + "@istanbuljs/schema": "^0.1.3", "istanbul-lib-coverage": "^3.2.0", "semver": "^7.5.4" }, @@ -9968,9 +10045,9 @@ } }, "node_modules/istanbul-reports": { - "version": "3.1.6", - "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.6.tgz", - "integrity": "sha512-TLgnMkKg3iTDsQ9PbPTdpfAK2DzjF9mqUG7RMgcQl8oFjad8ob4laGxv5XV5U9MAfx8D6tSJiUyuAwzLicaxlg==", + "version": "3.1.7", + "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-3.1.7.tgz", + "integrity": "sha512-BewmUXImeuRk2YY0PVbxgKAysvhRPUQE0h5QRM++nVWyubKGV0l8qQ5op8+B2DOmwSe63Jivj0BjkPQVf8fP5g==", "dev": true, "dependencies": { "html-escaper": "^2.0.0", @@ -10347,6 +10424,16 @@ "url": "https://github.com/chalk/ansi-styles?sponsor=1" } }, + "node_modules/jest-config/node_modules/brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "dependencies": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, "node_modules/jest-config/node_modules/chalk": { "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", @@ -10410,6 +10497,18 @@ "node": ">=8" } }, + "node_modules/jest-config/node_modules/minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dev": true, + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, "node_modules/jest-config/node_modules/supports-color": { "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", @@ -11152,6 +11251,16 @@ "url": "https://github.com/chalk/ansi-styles?sponsor=1" } }, + "node_modules/jest-runtime/node_modules/brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "dependencies": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, "node_modules/jest-runtime/node_modules/chalk": { "version": "4.1.2", "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz", @@ -11215,6 +11324,18 @@ "node": ">=8" } }, + "node_modules/jest-runtime/node_modules/minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dev": true, + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, "node_modules/jest-runtime/node_modules/supports-color": { "version": "7.2.0", "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz", @@ -11909,9 +12030,9 @@ } }, "node_modules/lint-staged/node_modules/npm-run-path": { - "version": "5.2.0", - "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-5.2.0.tgz", - "integrity": "sha512-W4/tgAXFqFA0iL7fk0+uQ3g7wkL8xJmx3XdK0VGb4cHW//eZTtKGvFBBoRKVTpY7n6ze4NL9ly7rgXcHufqXKg==", + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-5.3.0.tgz", + "integrity": "sha512-ppwTtiJZq0O/ai0z7yfudtBpWIoxM8yE6nHi1X47eFR2EWORqfbu6CnPlNsjeN683eT0qG6H/Pyf9fCcvjnnnQ==", "dev": true, "dependencies": { "path-key": "^4.0.0" @@ -12152,13 +12273,10 @@ } }, "node_modules/log-update/node_modules/ansi-escapes": { - "version": "6.2.0", - "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-6.2.0.tgz", - "integrity": "sha512-kzRaCqXnpzWs+3z5ABPQiVke+iq0KXkHo8xiWV4RPTi5Yli0l97BEQuhXV1s7+aSU/fu1kUuxgS4MsQ0fRuygw==", + "version": "6.2.1", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-6.2.1.tgz", + "integrity": "sha512-4nJ3yixlEthEJ9Rk4vPcdBRkZvQZlYyu8j4/Mqz5sgIkddmEnH2Yj2ZrnP9S3tQOvSNRUIgVNF/1yPpRAGNRig==", "dev": true, - "dependencies": { - "type-fest": "^3.0.0" - }, "engines": { "node": ">=14.16" }, @@ -12259,18 +12377,6 @@ "url": "https://github.com/chalk/strip-ansi?sponsor=1" } }, - "node_modules/log-update/node_modules/type-fest": { - "version": "3.13.1", - "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-3.13.1.tgz", - "integrity": "sha512-tLq3bSNx+xSpwvAJnzrK0Ep5CLNWjvFTOp71URMaAEWBfRb9nnJiBoUe0tF8bI4ZFO3omgBR6NvnbzVUT3Ly4g==", - "dev": true, - "engines": { - "node": ">=14.16" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, "node_modules/log-update/node_modules/wrap-ansi": { "version": "9.0.0", "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-9.0.0.tgz", @@ -12484,15 +12590,18 @@ "peer": true }, "node_modules/minimatch": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", - "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "version": "9.0.4", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-9.0.4.tgz", + "integrity": "sha512-KqWh+VchfxcMNRAJjj2tnsSJdNbHsVgnkBhTNrW7AjVo6OvLtxw8zfT9oLw1JSohlFzJ8jCoTgaoXvJ+kHt6fw==", "dev": true, "dependencies": { - "brace-expansion": "^1.1.7" + "brace-expansion": "^2.0.1" }, "engines": { - "node": "*" + "node": ">=16 || 14 >=14.17" + }, + "funding": { + "url": "https://github.com/sponsors/isaacs" } }, "node_modules/minimist": { @@ -13095,6 +13204,13 @@ "eventemitter3": "^4.0.7" } }, + "node_modules/moonbeam-types-bundle/node_modules/@substrate/connect-extension-protocol": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/@substrate/connect-extension-protocol/-/connect-extension-protocol-1.0.1.tgz", + "integrity": "sha512-161JhCC1csjH3GE5mPLEd7HbWtwNSPJBg3p1Ksz9SFlTzj/bgEwudiRN2y5i0MoLGCIJRYKyKGMxVnd29PzNjg==", + "optional": true, + "peer": true + }, "node_modules/moonbeam-types-bundle/node_modules/@substrate/connect/node_modules/eventemitter3": { "version": "4.0.7", "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-4.0.7.tgz", @@ -13180,9 +13296,9 @@ "peer": true }, "node_modules/nock": { - "version": "13.4.0", - "resolved": "https://registry.npmjs.org/nock/-/nock-13.4.0.tgz", - "integrity": "sha512-W8NVHjO/LCTNA64yxAPHV/K47LpGYcVzgKd3Q0n6owhwvD0Dgoterc25R4rnZbckJEb6Loxz1f5QMuJpJnbSyQ==", + "version": "13.5.4", + "resolved": "https://registry.npmjs.org/nock/-/nock-13.5.4.tgz", + "integrity": "sha512-yAyTfdeNJGGBFxWdzSKCBYxs5FxLbCg5X5Q4ets974hcQzG1+qCxvIyOo4j2Ry6MUlhWVMX4OoYDefAIIwupjw==", "dependencies": { "debug": "^4.1.0", "json-stringify-safe": "^5.0.1", @@ -13230,9 +13346,9 @@ } }, "node_modules/node-gyp-build": { - "version": "4.7.1", - "resolved": "https://registry.npmjs.org/node-gyp-build/-/node-gyp-build-4.7.1.tgz", - "integrity": "sha512-wTSrZ+8lsRRa3I3H8Xr65dLWSgCvY2l4AOnaeKdPA9TB/WYMPaTcrzf3rXvFoVvjKNVnu0CcWSx54qq9GKRUYg==", + "version": "4.8.0", + "resolved": "https://registry.npmjs.org/node-gyp-build/-/node-gyp-build-4.8.0.tgz", + "integrity": "sha512-u6fs2AEUljNho3EYTJNBfImO5QTo/J/1Etd+NVdCj7qWKUSN/bSLkZwhDv7I+w/MSC6qJ4cknepkAYykDdK8og==", "peer": true, "bin": { "node-gyp-build": "bin.js", @@ -13339,28 +13455,29 @@ } }, "node_modules/object.entries": { - "version": "1.1.7", - "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.7.tgz", - "integrity": "sha512-jCBs/0plmPsOnrKAfFQXRG2NFjlhZgjjcBLSmTnEhU8U6vVTsVe8ANeQJCHTl3gSsI4J+0emOoCgoKlmQPMgmA==", + "version": "1.1.8", + "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.8.tgz", + "integrity": "sha512-cmopxi8VwRIAw/fkijJohSfpef5PdN0pMQJN6VC/ZKvn0LIknWD8KtgY6KlQdEc4tIjcQ3HxSMmnvtzIscdaYQ==", "dev": true, "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.2.0", - "es-abstract": "^1.22.1" + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-object-atoms": "^1.0.0" }, "engines": { "node": ">= 0.4" } }, "node_modules/object.fromentries": { - "version": "2.0.7", - "resolved": "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.7.tgz", - "integrity": "sha512-UPbPHML6sL8PI/mOqPwsH4G6iyXcCGzLin8KvEPenOZN5lpCNBZZQ+V62vdjB1mQHrmqGQt5/OJzemUA+KJmEA==", + "version": "2.0.8", + "resolved": "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.8.tgz", + "integrity": "sha512-k6E21FzySsSK5a21KRADBd/NGneRegFO5pLHfdQLpRDETUNJueLXs3WCzyQ3tFRDYgbq3KHGXfTbi2bs8WQ6rQ==", "dev": true, "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.2.0", - "es-abstract": "^1.22.1" + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.2", + "es-object-atoms": "^1.0.0" }, "engines": { "node": ">= 0.4" @@ -13370,26 +13487,28 @@ } }, "node_modules/object.groupby": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/object.groupby/-/object.groupby-1.0.1.tgz", - "integrity": "sha512-HqaQtqLnp/8Bn4GL16cj+CUYbnpe1bh0TtEaWvybszDG4tgxCJuRpV8VGuvNaI1fAnI4lUJzDG55MXcOH4JZcQ==", + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/object.groupby/-/object.groupby-1.0.3.tgz", + "integrity": "sha512-+Lhy3TQTuzXI5hevh8sBGqbmurHbbIjAi0Z4S63nthVLmLxfbj4T54a4CfZrXIrt9iP4mVAPYMo/v99taj3wjQ==", "dev": true, "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.2.0", - "es-abstract": "^1.22.1", - "get-intrinsic": "^1.2.1" + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.2" + }, + "engines": { + "node": ">= 0.4" } }, "node_modules/object.values": { - "version": "1.1.7", - "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.7.tgz", - "integrity": "sha512-aU6xnDFYT3x17e/f0IiiwlGPTy2jzMySGfUB4fq6z7CV8l85CWHDk5ErhyhpfDHhrOMwGFhSQkhMGHaIotA6Ng==", + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.2.0.tgz", + "integrity": "sha512-yBYjY9QX2hnRmZHAjG/f13MzmBzxzYgQhFrke06TTyKY5zSTEqkOeukBzIdVA3j3ulu8Qa3MbVFShV7T2RmGtQ==", "dev": true, "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.2.0", - "es-abstract": "^1.22.1" + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-object-atoms": "^1.0.0" }, "engines": { "node": ">= 0.4" @@ -13581,12 +13700,12 @@ "dev": true }, "node_modules/path-scurry": { - "version": "1.10.1", - "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-1.10.1.tgz", - "integrity": "sha512-MkhCqzzBEpPvxxQ71Md0b1Kk51W01lrYvlMzSUaIzNsODdd7mqhiimSZlr+VegAz5Z6Vzt9Xg2ttE//XBhH3EQ==", + "version": "1.10.2", + "resolved": "https://registry.npmjs.org/path-scurry/-/path-scurry-1.10.2.tgz", + "integrity": "sha512-7xTavNy5RQXnsjANvVvMkEjvloOinkAjv/Z6Ildz9v2RinZ4SBKTWFOVRbaF8p0vpHnyjV/UwNDdKuUv6M5qcA==", "dev": true, "dependencies": { - "lru-cache": "^9.1.1 || ^10.0.0", + "lru-cache": "^10.2.0", "minipass": "^5.0.0 || ^6.0.2 || ^7.0.0" }, "engines": { @@ -13597,9 +13716,9 @@ } }, "node_modules/path-scurry/node_modules/lru-cache": { - "version": "10.1.0", - "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-10.1.0.tgz", - "integrity": "sha512-/1clY/ui8CzjKFyjdvwPWJUYKiFVXG2I2cY0ssG7h4+hwk+XOIX7ZSG9Q7TW8TW3Kp3BUSqgFWBLgL4PJ+Blag==", + "version": "10.2.0", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-10.2.0.tgz", + "integrity": "sha512-2bIM8x+VAf6JT4bKAljS1qUWgMsqZRPGJS6FSahIMPVvctcNhyVp7AJu7quxOW9jwkryBReKZY5tY5JYv2n/7Q==", "dev": true, "engines": { "node": "14 || >=16.14" @@ -14270,6 +14389,15 @@ "node": ">=4.2.0" } }, + "node_modules/possible-typed-array-names": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/possible-typed-array-names/-/possible-typed-array-names-1.0.0.tgz", + "integrity": "sha512-d7Uw+eZoloe0EHDIYoe+bQ5WXnGMOpmiZFTuMWCwpjzzkL2nTjcKiAk4hh8TjnGye2TwWOk3UXucZ+3rbmBa8Q==", + "dev": true, + "engines": { + "node": ">= 0.4" + } + }, "node_modules/postcss": { "version": "8.4.31", "resolved": "https://registry.npmjs.org/postcss/-/postcss-8.4.31.tgz", @@ -14340,9 +14468,9 @@ "peer": true }, "node_modules/preferred-pm": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/preferred-pm/-/preferred-pm-3.1.2.tgz", - "integrity": "sha512-nk7dKrcW8hfCZ4H6klWcdRknBOXWzNQByJ0oJyX97BOupsYD+FzLS4hflgEu/uPUEHZCuRfMxzCBsuWd7OzT8Q==", + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/preferred-pm/-/preferred-pm-3.1.3.tgz", + "integrity": "sha512-MkXsENfftWSRpzCzImcp4FRsCc3y1opwB73CfCNWyzMqArju2CrlMHlqB7VexKiPEOjGMbttv1r9fSCn5S610w==", "dev": true, "dependencies": { "find-up": "^5.0.0", @@ -14537,9 +14665,9 @@ } }, "node_modules/pure-rand": { - "version": "6.0.4", - "resolved": "https://registry.npmjs.org/pure-rand/-/pure-rand-6.0.4.tgz", - "integrity": "sha512-LA0Y9kxMYv47GIPJy6MI84fqTd2HmYZI83W/kM/SkKfDlajnZYfmXFTxkbY+xSBPkLJxltMa9hIkmdc29eguMA==", + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/pure-rand/-/pure-rand-6.1.0.tgz", + "integrity": "sha512-bVWawvoZoBYpp6yIoQtQXHZjmz35RSVHnUOTefl8Vcjr8snTPY1wnpSPMWekcFwbxI6gtmT7rSYPFvz71ldiOA==", "dev": true, "funding": [ { @@ -14743,14 +14871,15 @@ "integrity": "sha512-dYnhHh0nJoMfnkZs6GmmhFknAGRrLznOu5nc9ML+EJxGvrx6H7teuevqVqCuPcPK//3eDrrjQhehXVx9cnkGdw==" }, "node_modules/regexp.prototype.flags": { - "version": "1.5.1", - "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.1.tgz", - "integrity": "sha512-sy6TXMN+hnP/wMy+ISxg3krXx7BAtWVO4UouuCN/ziM9UEne0euamVNafDfvC83bRNr95y0V5iijeDQFUNpvrg==", + "version": "1.5.2", + "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.5.2.tgz", + "integrity": "sha512-NcDiDkTLuPR+++OCKB0nWafEmhg/Da8aUPLPMQbK+bxKKCm1/S5he+AqYa4PlMCVBalb4/yxIRub6qkEx5yJbw==", "dev": true, "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.2.0", - "set-function-name": "^2.0.0" + "call-bind": "^1.0.6", + "define-properties": "^1.2.1", + "es-errors": "^1.3.0", + "set-function-name": "^2.0.1" }, "engines": { "node": ">= 0.4" @@ -14812,6 +14941,15 @@ "node": ">=8" } }, + "node_modules/resolve-pkg-maps": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/resolve-pkg-maps/-/resolve-pkg-maps-1.0.0.tgz", + "integrity": "sha512-seS2Tj26TBVOC2NIc2rOe2y2ZO7efxITtLZcGSOnHHNOQ7CkiUBfw0Iw2ck6xkIhPwLhKNLS8BO+hEpngQlqzw==", + "dev": true, + "funding": { + "url": "https://github.com/privatenumber/resolve-pkg-maps?sponsor=1" + } + }, "node_modules/resolve.exports": { "version": "2.0.2", "resolved": "https://registry.npmjs.org/resolve.exports/-/resolve.exports-2.0.2.tgz", @@ -14874,6 +15012,16 @@ "url": "https://github.com/sponsors/isaacs" } }, + "node_modules/rimraf/node_modules/brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "dependencies": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, "node_modules/rimraf/node_modules/glob": { "version": "7.2.3", "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", @@ -14894,6 +15042,18 @@ "url": "https://github.com/sponsors/isaacs" } }, + "node_modules/rimraf/node_modules/minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dev": true, + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, "node_modules/ripemd160": { "version": "2.0.2", "resolved": "https://registry.npmjs.org/ripemd160/-/ripemd160-2.0.2.tgz", @@ -14905,9 +15065,9 @@ } }, "node_modules/rollup": { - "version": "4.9.6", - "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.9.6.tgz", - "integrity": "sha512-05lzkCS2uASX0CiLFybYfVkwNbKZG5NFQ6Go0VWyogFTXXbR039UVsegViTntkk4OglHBdF54ccApXRRuXRbsg==", + "version": "4.14.2", + "resolved": "https://registry.npmjs.org/rollup/-/rollup-4.14.2.tgz", + "integrity": "sha512-WkeoTWvuBoFjFAhsEOHKRoZ3r9GfTyhh7Vff1zwebEFLEFjT1lG3784xEgKiTa7E+e70vsC81roVL2MP4tgEEQ==", "dev": true, "dependencies": { "@types/estree": "1.0.5" @@ -14920,19 +15080,21 @@ "npm": ">=8.0.0" }, "optionalDependencies": { - "@rollup/rollup-android-arm-eabi": "4.9.6", - "@rollup/rollup-android-arm64": "4.9.6", - "@rollup/rollup-darwin-arm64": "4.9.6", - "@rollup/rollup-darwin-x64": "4.9.6", - "@rollup/rollup-linux-arm-gnueabihf": "4.9.6", - "@rollup/rollup-linux-arm64-gnu": "4.9.6", - "@rollup/rollup-linux-arm64-musl": "4.9.6", - "@rollup/rollup-linux-riscv64-gnu": "4.9.6", - "@rollup/rollup-linux-x64-gnu": "4.9.6", - "@rollup/rollup-linux-x64-musl": "4.9.6", - "@rollup/rollup-win32-arm64-msvc": "4.9.6", - "@rollup/rollup-win32-ia32-msvc": "4.9.6", - "@rollup/rollup-win32-x64-msvc": "4.9.6", + "@rollup/rollup-android-arm-eabi": "4.14.2", + "@rollup/rollup-android-arm64": "4.14.2", + "@rollup/rollup-darwin-arm64": "4.14.2", + "@rollup/rollup-darwin-x64": "4.14.2", + "@rollup/rollup-linux-arm-gnueabihf": "4.14.2", + "@rollup/rollup-linux-arm64-gnu": "4.14.2", + "@rollup/rollup-linux-arm64-musl": "4.14.2", + "@rollup/rollup-linux-powerpc64le-gnu": "4.14.2", + "@rollup/rollup-linux-riscv64-gnu": "4.14.2", + "@rollup/rollup-linux-s390x-gnu": "4.14.2", + "@rollup/rollup-linux-x64-gnu": "4.14.2", + "@rollup/rollup-linux-x64-musl": "4.14.2", + "@rollup/rollup-win32-arm64-msvc": "4.14.2", + "@rollup/rollup-win32-ia32-msvc": "4.14.2", + "@rollup/rollup-win32-x64-msvc": "4.14.2", "fsevents": "~2.3.2" } }, @@ -14968,13 +15130,13 @@ } }, "node_modules/safe-array-concat": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/safe-array-concat/-/safe-array-concat-1.0.1.tgz", - "integrity": "sha512-6XbUAseYE2KtOuGueyeobCySj9L4+66Tn6KQMOPQJrAJEowYKW/YR/MGJZl7FdydUdaFu4LYyDZjxf4/Nmo23Q==", + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/safe-array-concat/-/safe-array-concat-1.1.2.tgz", + "integrity": "sha512-vj6RsCsWBCf19jIeHEfkRMw8DPiBb+DMXklQ/1SGDHOMlHdPUkZXFQ2YdplS23zESTijAcurb1aSgJA3AgMu1Q==", "dev": true, "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" }, @@ -15006,15 +15168,18 @@ "peer": true }, "node_modules/safe-regex-test": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/safe-regex-test/-/safe-regex-test-1.0.0.tgz", - "integrity": "sha512-JBUUzyOgEwXQY1NuPtvcj/qcBDbDmEvWufhlnXZIm75DEHp+afM1r1ujJpJsV/gSM4t59tpDyPi1sd6ZaPFfsA==", + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/safe-regex-test/-/safe-regex-test-1.0.3.tgz", + "integrity": "sha512-CdASjNJPvRa7roO6Ra/gLYBTzYzzPyyBXxIMdGW3USQLyjWEls2RgW5UBTXaQVp+OrpeCK3bLem8smtmheoRuw==", "dev": true, "dependencies": { - "call-bind": "^1.0.2", - "get-intrinsic": "^1.1.3", + "call-bind": "^1.0.6", + "es-errors": "^1.3.0", "is-regex": "^1.1.4" }, + "engines": { + "node": ">= 0.4" + }, "funding": { "url": "https://github.com/sponsors/ljharb" } @@ -15025,6 +15190,12 @@ "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==", "dev": true }, + "node_modules/scale-ts": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/scale-ts/-/scale-ts-1.6.0.tgz", + "integrity": "sha512-Ja5VCjNZR8TGKhUumy9clVVxcDpM+YFjAnkMuwQy68Hixio3VRRvWdE3g8T/yC+HXA0ZDQl2TGyUmtmbcVl40Q==", + "optional": true + }, "node_modules/scheduler": { "version": "0.23.0", "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.23.0.tgz", @@ -15045,9 +15216,9 @@ "link": true }, "node_modules/semver": { - "version": "7.5.4", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.5.4.tgz", - "integrity": "sha512-1bCSESV6Pv+i21Hvpxp3Dx+pSD8lIPt8uVjRrxAUt/nbswYc+tK6Y2btiULjd4+fnq15PX+nqQDC7Oft7WkwcA==", + "version": "7.6.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.0.tgz", + "integrity": "sha512-EnwXhrlwXMk9gKu5/flx5sv/an57AkRplG3hTK68W7FRDN+k+OWBj65M7719OkA82XLBxrcX0KSHj+X5COhOVg==", "dev": true, "dependencies": { "lru-cache": "^6.0.0" @@ -15084,29 +15255,32 @@ "dev": true }, "node_modules/set-function-length": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.1.1.tgz", - "integrity": "sha512-VoaqjbBJKiWtg4yRcKBQ7g7wnGnLV3M8oLvVWwOk2PdYY6PEFegR1vezXR0tw6fZGF9csVakIRjrJiy2veSBFQ==", + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.2.tgz", + "integrity": "sha512-pgRc4hJ4/sNjWCSS9AmnS40x3bNMDTknHgL5UaMBTMyJnU90EgWh1Rz+MC9eFu4BuN/UwZjKQuY/1v3rM7HMfg==", "dev": true, "dependencies": { - "define-data-property": "^1.1.1", - "get-intrinsic": "^1.2.1", + "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.0" + "has-property-descriptors": "^1.0.2" }, "engines": { "node": ">= 0.4" } }, "node_modules/set-function-name": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/set-function-name/-/set-function-name-2.0.1.tgz", - "integrity": "sha512-tMNCiqYVkXIZgc2Hnoy2IvC/f8ezc5koaRFkCjrpWzGpCd3qbZXPzVy9MAZzK1ch/X0jvSkojys3oqJN0qCmdA==", + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/set-function-name/-/set-function-name-2.0.2.tgz", + "integrity": "sha512-7PGFlmtwsEADb0WYyvCMa1t+yke6daIG4Wirafur5kcf+MhUnPms1UeR0CKQdTZD81yESwMHbtn+TR+dMviakQ==", "dev": true, "dependencies": { - "define-data-property": "^1.0.1", + "define-data-property": "^1.1.4", + "es-errors": "^1.3.0", "functions-have-names": "^1.2.3", - "has-property-descriptors": "^1.0.0" + "has-property-descriptors": "^1.0.2" }, "engines": { "node": ">= 0.4" @@ -15153,14 +15327,18 @@ } }, "node_modules/side-channel": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.4.tgz", - "integrity": "sha512-q5XPytqFEIKHkGdiMIrY10mvLRvnQh42/+GoBlFW3b2LXLE2xxJpZFdm94we0BaoV3RwJyGqg5wS7epxTv0Zvw==", + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.6.tgz", + "integrity": "sha512-fDW/EZ6Q9RiO8eFG8Hj+7u/oW+XrPTIChwCOM2+th2A6OblDtYYIpve9m+KvI9Z4C9qSEXlaGR6bTEYHReuglA==", "dev": true, "dependencies": { - "call-bind": "^1.0.0", - "get-intrinsic": "^1.0.2", - "object-inspect": "^1.9.0" + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "get-intrinsic": "^1.2.4", + "object-inspect": "^1.13.1" + }, + "engines": { + "node": ">= 0.4" }, "funding": { "url": "https://github.com/sponsors/ljharb" @@ -15357,9 +15535,9 @@ } }, "node_modules/smoldot": { - "version": "2.0.7", - "resolved": "https://registry.npmjs.org/smoldot/-/smoldot-2.0.7.tgz", - "integrity": "sha512-VAOBqEen6vises36/zgrmAT1GWk2qE3X8AGnO7lmQFdskbKx8EovnwS22rtPAG+Y1Rk23/S22kDJUdPANyPkBA==", + "version": "2.0.22", + "resolved": "https://registry.npmjs.org/smoldot/-/smoldot-2.0.22.tgz", + "integrity": "sha512-B50vRgTY6v3baYH6uCgL15tfaag5tcS2o/P5q1OiXcKGv1axZDfz2dzzMuIkVpyMR2ug11F6EAtQlmYBQd292g==", "optional": true, "dependencies": { "ws": "^8.8.1" @@ -15375,9 +15553,9 @@ } }, "node_modules/source-map-js": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.0.2.tgz", - "integrity": "sha512-R0XvVJ9WusLiqTCEiGCmICCMplcCkIwwR11mOSD9CR5u+IXYdiseeEuXCVAjS54zqwkLcPNnmU4OeJ6tUrWhDw==", + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/source-map-js/-/source-map-js-1.2.0.tgz", + "integrity": "sha512-itJW8lvSA0TXEphiRoawsCksnlf8SyvmFzIhltqAHluXd88pkCd+cXJVHTDwdCr0IzwptSm035IHQktUu1QUMg==", "peer": true, "engines": { "node": ">=0.10.0" @@ -15480,9 +15658,9 @@ } }, "node_modules/spdx-exceptions": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.3.0.tgz", - "integrity": "sha512-/tTrYOC7PPI1nUAgx34hUpqXuyJG+DTHJTnIULG4rDygi4xu/tfgmq1e1cIRwRzwZgo4NLySi+ricLkZkw4i5A==", + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.5.0.tgz", + "integrity": "sha512-PiU42r+xO4UbUS1buo3LPJkjlO7430Xn5SVAhdpzzsPHsjbYVflnnFdATgabnLude+Cqu25p6N+g2lw/PFsa4w==", "dev": true }, "node_modules/spdx-expression-parse": { @@ -15496,9 +15674,9 @@ } }, "node_modules/spdx-license-ids": { - "version": "3.0.16", - "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.16.tgz", - "integrity": "sha512-eWN+LnM3GR6gPu35WxNgbGl8rmY1AEmoMDvL/QD6zYmPWgywxWqJWNdLGT+ke8dKNWrcYgYjPpG5gbTfghP8rw==", + "version": "3.0.17", + "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.17.tgz", + "integrity": "sha512-sh8PWc/ftMqAAdFiBu6Fy6JUOYjqDJBJvIhpfDMyHrr0Rbp5liZqd4TjtQ/RgfLjKFZb+LMx5hpml5qOWy0qvg==", "dev": true }, "node_modules/sprintf-js": { @@ -15652,14 +15830,15 @@ } }, "node_modules/string.prototype.trim": { - "version": "1.2.8", - "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.2.8.tgz", - "integrity": "sha512-lfjY4HcixfQXOfaqCvcBuOIapyaroTXhbkfJN3gcB1OtyupngWK4sEET9Knd0cXd28kTUqu/kHoV4HKSJdnjiQ==", + "version": "1.2.9", + "resolved": "https://registry.npmjs.org/string.prototype.trim/-/string.prototype.trim-1.2.9.tgz", + "integrity": "sha512-klHuCNxiMZ8MlsOihJhJEBJAiMVqU3Z2nEXWfWnIqjN0gEFS9J9+IxKozWWtQGcgoa1WUZzLjKPTr4ZHNFTFxw==", "dev": true, "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.2.0", - "es-abstract": "^1.22.1" + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-abstract": "^1.23.0", + "es-object-atoms": "^1.0.0" }, "engines": { "node": ">= 0.4" @@ -15669,28 +15848,31 @@ } }, "node_modules/string.prototype.trimend": { - "version": "1.0.7", - "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.7.tgz", - "integrity": "sha512-Ni79DqeB72ZFq1uH/L6zJ+DKZTkOtPIHovb3YZHQViE+HDouuU4mBrLOLDn5Dde3RF8qw5qVETEjhu9locMLvA==", + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/string.prototype.trimend/-/string.prototype.trimend-1.0.8.tgz", + "integrity": "sha512-p73uL5VCHCO2BZZ6krwwQE3kCzM7NKmis8S//xEC6fQonchbum4eP6kR4DLEjQFO3Wnj3Fuo8NM0kOSjVdHjZQ==", "dev": true, "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.2.0", - "es-abstract": "^1.22.1" + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-object-atoms": "^1.0.0" }, "funding": { "url": "https://github.com/sponsors/ljharb" } }, "node_modules/string.prototype.trimstart": { - "version": "1.0.7", - "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.7.tgz", - "integrity": "sha512-NGhtDFu3jCEm7B4Fy0DpLewdJQOZcQ0rGbwQ/+stjnrp2i+rlKeCvos9hOIeCmqwratM47OBxY7uFZzjxHXmrg==", + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/string.prototype.trimstart/-/string.prototype.trimstart-1.0.8.tgz", + "integrity": "sha512-UXSH262CSZY1tfu3G3Secr6uGLCFVPMhIqHjlgCUtCCcgihYc/xKs9djMTMUOb2j1mVSeU8EU6NWc/iQKU6Gfg==", "dev": true, "dependencies": { - "call-bind": "^1.0.2", - "define-properties": "^1.2.0", - "es-abstract": "^1.22.1" + "call-bind": "^1.0.7", + "define-properties": "^1.2.1", + "es-object-atoms": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" }, "funding": { "url": "https://github.com/sponsors/ljharb" @@ -15764,9 +15946,9 @@ } }, "node_modules/styled-components": { - "version": "6.1.6", - "resolved": "https://registry.npmjs.org/styled-components/-/styled-components-6.1.6.tgz", - "integrity": "sha512-DgTLULSC29xpabJ24bbn1+hulU6vvGFQf4RPwBOJrm8WJFnN42yXpo5voBt3jDSJBa5tBd1L6PqswJjQ0wRKdg==", + "version": "6.1.8", + "resolved": "https://registry.npmjs.org/styled-components/-/styled-components-6.1.8.tgz", + "integrity": "sha512-PQ6Dn+QxlWyEGCKDS71NGsXoVLKfE1c3vApkvDYS5KAK+V8fNWGhbSUEo9Gg2iaID2tjLXegEW3bZDUGpofRWw==", "peer": true, "dependencies": { "@emotion/is-prop-valid": "1.2.1", @@ -15874,6 +16056,15 @@ "url": "https://opencollective.com/unts" } }, + "node_modules/tapable": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/tapable/-/tapable-2.2.1.tgz", + "integrity": "sha512-GNzQvQTOIP6RyTfE2Qxb8ZVlNmw0n88vp1szwWRimP02mnTsx3Wtn5qRdqY9w2XduFNUgvOwhNnQsjwCp+kqaQ==", + "dev": true, + "engines": { + "node": ">=6" + } + }, "node_modules/term-size": { "version": "2.2.1", "resolved": "https://registry.npmjs.org/term-size/-/term-size-2.2.1.tgz", @@ -15900,6 +16091,16 @@ "node": ">=8" } }, + "node_modules/test-exclude/node_modules/brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "dev": true, + "dependencies": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, "node_modules/test-exclude/node_modules/glob": { "version": "7.2.3", "resolved": "https://registry.npmjs.org/glob/-/glob-7.2.3.tgz", @@ -15920,6 +16121,18 @@ "url": "https://github.com/sponsors/isaacs" } }, + "node_modules/test-exclude/node_modules/minimatch": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", + "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", + "dev": true, + "dependencies": { + "brace-expansion": "^1.1.7" + }, + "engines": { + "node": "*" + } + }, "node_modules/text-table": { "version": "0.2.0", "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", @@ -16016,9 +16229,9 @@ } }, "node_modules/ts-api-utils": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/ts-api-utils/-/ts-api-utils-1.2.1.tgz", - "integrity": "sha512-RIYA36cJn2WiH9Hy77hdF9r7oEwxAtB/TS9/S4Qd90Ap4z5FSiin5zEiTL44OII1Y3IIlEvxwxFUVgrHSZ/UpA==", + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/ts-api-utils/-/ts-api-utils-1.3.0.tgz", + "integrity": "sha512-UQMIo7pb8WRomKR1/+MFVLTroIvDVtMX3K6OUir8ynLyzB8Jeriont2bTAtmNPa1ekAgN7YPDyf6V+ygrdU+eQ==", "dev": true, "engines": { "node": ">=16" @@ -16253,27 +16466,6 @@ "webidl-conversions": "^4.0.2" } }, - "node_modules/tsutils": { - "version": "3.21.0", - "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.21.0.tgz", - "integrity": "sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA==", - "dev": true, - "dependencies": { - "tslib": "^1.8.1" - }, - "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" - } - }, - "node_modules/tsutils/node_modules/tslib": { - "version": "1.14.1", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.14.1.tgz", - "integrity": "sha512-Xni35NKzjgMrwevysHTCArtLDpPvye8zV/0E4EyYn43P7/7qvQwPh9BGkHewbMulVntbigmcT7rdX3BNo9wRJg==", - "dev": true - }, "node_modules/tty-table": { "version": "4.2.3", "resolved": "https://registry.npmjs.org/tty-table/-/tty-table-4.2.3.tgz", @@ -16375,26 +16567,26 @@ } }, "node_modules/turbo": { - "version": "1.12.5", - "resolved": "https://registry.npmjs.org/turbo/-/turbo-1.12.5.tgz", - "integrity": "sha512-FATU5EnhrYG8RvQJYFJnDd18DpccDjyvd53hggw9T9JEg9BhWtIEoeaKtBjYbpXwOVrJQMDdXcIB4f2nD3QPPg==", + "version": "1.13.2", + "resolved": "https://registry.npmjs.org/turbo/-/turbo-1.13.2.tgz", + "integrity": "sha512-rX/d9f4MgRT3yK6cERPAkfavIxbpBZowDQpgvkYwGMGDQ0Nvw1nc0NVjruE76GrzXQqoxR1UpnmEP54vBARFHQ==", "dev": true, "bin": { "turbo": "bin/turbo" }, "optionalDependencies": { - "turbo-darwin-64": "1.12.5", - "turbo-darwin-arm64": "1.12.5", - "turbo-linux-64": "1.12.5", - "turbo-linux-arm64": "1.12.5", - "turbo-windows-64": "1.12.5", - "turbo-windows-arm64": "1.12.5" + "turbo-darwin-64": "1.13.2", + "turbo-darwin-arm64": "1.13.2", + "turbo-linux-64": "1.13.2", + "turbo-linux-arm64": "1.13.2", + "turbo-windows-64": "1.13.2", + "turbo-windows-arm64": "1.13.2" } }, "node_modules/turbo-darwin-64": { - "version": "1.12.5", - "resolved": "https://registry.npmjs.org/turbo-darwin-64/-/turbo-darwin-64-1.12.5.tgz", - "integrity": "sha512-0GZ8reftwNQgIQLHkHjHEXTc/Z1NJm+YjsrBP+qhM/7yIZ3TEy9gJhuogDt2U0xIWwFgisTyzbtU7xNaQydtoA==", + "version": "1.13.2", + "resolved": "https://registry.npmjs.org/turbo-darwin-64/-/turbo-darwin-64-1.13.2.tgz", + "integrity": "sha512-CCSuD8CfmtncpohCuIgq7eAzUas0IwSbHfI8/Q3vKObTdXyN8vAo01gwqXjDGpzG9bTEVedD0GmLbD23dR0MLA==", "cpu": [ "x64" ], @@ -16405,9 +16597,9 @@ ] }, "node_modules/turbo-darwin-arm64": { - "version": "1.12.5", - "resolved": "https://registry.npmjs.org/turbo-darwin-arm64/-/turbo-darwin-arm64-1.12.5.tgz", - "integrity": "sha512-8WpOLNNzvH6kohQOjihD+gaWL+ZFNfjvBwhOF0rjEzvW+YR3Pa7KjhulrjWyeN2yMFqAPubTbZIGOz1EVXLuQA==", + "version": "1.13.2", + "resolved": "https://registry.npmjs.org/turbo-darwin-arm64/-/turbo-darwin-arm64-1.13.2.tgz", + "integrity": "sha512-0HySm06/D2N91rJJ89FbiI/AodmY8B3WDSFTVEpu2+8spUw7hOJ8okWOT0e5iGlyayUP9gr31eOeL3VFZkpfCw==", "cpu": [ "arm64" ], @@ -16418,9 +16610,9 @@ ] }, "node_modules/turbo-linux-64": { - "version": "1.12.5", - "resolved": "https://registry.npmjs.org/turbo-linux-64/-/turbo-linux-64-1.12.5.tgz", - "integrity": "sha512-INit73+bNUpwqGZCxgXCR3I+cQsdkQ3/LkfkgSOibkpg+oGqxJRzeXw3sp990d7SCoE8QOcs3iw+PtiFX/LDAA==", + "version": "1.13.2", + "resolved": "https://registry.npmjs.org/turbo-linux-64/-/turbo-linux-64-1.13.2.tgz", + "integrity": "sha512-7HnibgbqZrjn4lcfIouzlPu8ZHSBtURG4c7Bedu7WJUDeZo+RE1crlrQm8wuwO54S0siYqUqo7GNHxu4IXbioQ==", "cpu": [ "x64" ], @@ -16431,9 +16623,9 @@ ] }, "node_modules/turbo-linux-arm64": { - "version": "1.12.5", - "resolved": "https://registry.npmjs.org/turbo-linux-arm64/-/turbo-linux-arm64-1.12.5.tgz", - "integrity": "sha512-6lkRBvxtI/GQdGtaAec9LvVQUoRw6nXFp0kM+Eu+5PbZqq7yn6cMkgDJLI08zdeui36yXhone8XGI8pHg8bpUQ==", + "version": "1.13.2", + "resolved": "https://registry.npmjs.org/turbo-linux-arm64/-/turbo-linux-arm64-1.13.2.tgz", + "integrity": "sha512-sUq4dbpk6SNKg/Hkwn256Vj2AEYSQdG96repio894h5/LEfauIK2QYiC/xxAeW3WBMc6BngmvNyURIg7ltrePg==", "cpu": [ "arm64" ], @@ -16444,9 +16636,9 @@ ] }, "node_modules/turbo-windows-64": { - "version": "1.12.5", - "resolved": "https://registry.npmjs.org/turbo-windows-64/-/turbo-windows-64-1.12.5.tgz", - "integrity": "sha512-gQYbOhZg5Ww0bQ/bC0w/4W6yQRwBumUUnkB+QPo15VznwxZe2a7bo6JM+9Xy9dKLa/kn+p7zTqme4OEp6M3/Yg==", + "version": "1.13.2", + "resolved": "https://registry.npmjs.org/turbo-windows-64/-/turbo-windows-64-1.13.2.tgz", + "integrity": "sha512-DqzhcrciWq3dpzllJR2VVIyOhSlXYCo4mNEWl98DJ3FZ08PEzcI3ceudlH6F0t/nIcfSItK1bDP39cs7YoZHEA==", "cpu": [ "x64" ], @@ -16457,9 +16649,9 @@ ] }, "node_modules/turbo-windows-arm64": { - "version": "1.12.5", - "resolved": "https://registry.npmjs.org/turbo-windows-arm64/-/turbo-windows-arm64-1.12.5.tgz", - "integrity": "sha512-auvhZ9FrhnvQ4mgBlY9O68MT4dIfprYGvd2uPICba/mHUZZvVy5SGgbHJ0KbMwaJfnnFoPgLJO6M+3N2gDprKw==", + "version": "1.13.2", + "resolved": "https://registry.npmjs.org/turbo-windows-arm64/-/turbo-windows-arm64-1.13.2.tgz", + "integrity": "sha512-WnPMrwfCXxK69CdDfS1/j2DlzcKxSmycgDAqV0XCYpK/812KB0KlvsVAt5PjEbZGXkY88pCJ1BLZHAjF5FcbqA==", "cpu": [ "arm64" ], @@ -16476,9 +16668,9 @@ "peer": true }, "node_modules/type": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/type/-/type-1.2.0.tgz", - "integrity": "sha512-+5nt5AAniqsCnu2cEQQdpzCAh33kVx8n0VoFidKpB1dVVLAN/F+bgVOqOJqOnEnrhp222clB5p3vUlD+1QAnfg==", + "version": "2.7.2", + "resolved": "https://registry.npmjs.org/type/-/type-2.7.2.tgz", + "integrity": "sha512-dzlvlNlt6AXU7EBSfpAscydQ7gXB+pPGsPnfJnZpiNJBDj7IaJzQlBZYGdEi4R9HmPdBv2XmWJ6YUtoTa7lmCw==", "peer": true }, "node_modules/type-check": { @@ -16515,29 +16707,30 @@ } }, "node_modules/typed-array-buffer": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/typed-array-buffer/-/typed-array-buffer-1.0.0.tgz", - "integrity": "sha512-Y8KTSIglk9OZEr8zywiIHG/kmQ7KWyjseXs1CbSo8vC42w7hg2HgYTxSWwP0+is7bWDc1H+Fo026CpHFwm8tkw==", + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/typed-array-buffer/-/typed-array-buffer-1.0.2.tgz", + "integrity": "sha512-gEymJYKZtKXzzBzM4jqa9w6Q1Jjm7x2d+sh19AdsD4wqnMPDYyvwpsIc2Q/835kHuo3BEQ7CjelGhfTsoBb2MQ==", "dev": true, "dependencies": { - "call-bind": "^1.0.2", - "get-intrinsic": "^1.2.1", - "is-typed-array": "^1.1.10" + "call-bind": "^1.0.7", + "es-errors": "^1.3.0", + "is-typed-array": "^1.1.13" }, "engines": { "node": ">= 0.4" } }, "node_modules/typed-array-byte-length": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/typed-array-byte-length/-/typed-array-byte-length-1.0.0.tgz", - "integrity": "sha512-Or/+kvLxNpeQ9DtSydonMxCx+9ZXOswtwJn17SNLvhptaXYDJvkFFP5zbfU/uLmvnBJlI4yrnXRxpdWH/M5tNA==", + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/typed-array-byte-length/-/typed-array-byte-length-1.0.1.tgz", + "integrity": "sha512-3iMJ9q0ao7WE9tWcaYKIptkNBuOIcZCCT0d4MRvuuH88fEoEH62IuQe0OtraD3ebQEoTRk8XCBoknUNc1Y67pw==", "dev": true, "dependencies": { - "call-bind": "^1.0.2", + "call-bind": "^1.0.7", "for-each": "^0.3.3", - "has-proto": "^1.0.1", - "is-typed-array": "^1.1.10" + "gopd": "^1.0.1", + "has-proto": "^1.0.3", + "is-typed-array": "^1.1.13" }, "engines": { "node": ">= 0.4" @@ -16547,16 +16740,17 @@ } }, "node_modules/typed-array-byte-offset": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/typed-array-byte-offset/-/typed-array-byte-offset-1.0.0.tgz", - "integrity": "sha512-RD97prjEt9EL8YgAgpOkf3O4IF9lhJFr9g0htQkm0rchFp/Vx7LW5Q8fSXXub7BXAODyUQohRMyOc3faCPd0hg==", + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/typed-array-byte-offset/-/typed-array-byte-offset-1.0.2.tgz", + "integrity": "sha512-Ous0vodHa56FviZucS2E63zkgtgrACj7omjwd/8lTEMEPFFyjfixMZ1ZXenpgCFBBt4EC1J2XsyVS2gkG0eTFA==", "dev": true, "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", - "has-proto": "^1.0.1", - "is-typed-array": "^1.1.10" + "gopd": "^1.0.1", + "has-proto": "^1.0.3", + "is-typed-array": "^1.1.13" }, "engines": { "node": ">= 0.4" @@ -16566,14 +16760,20 @@ } }, "node_modules/typed-array-length": { - "version": "1.0.4", - "resolved": "https://registry.npmjs.org/typed-array-length/-/typed-array-length-1.0.4.tgz", - "integrity": "sha512-KjZypGq+I/H7HI5HlOoGHkWUUGq+Q0TPhQurLbyrVrvnKTBgzLhIJ7j6J/XTQOi0d1RjyZ0wdas8bKs2p0x3Ng==", + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/typed-array-length/-/typed-array-length-1.0.6.tgz", + "integrity": "sha512-/OxDN6OtAk5KBpGb28T+HZc2M+ADtvRxXrKKbUwtsLgdoxgX13hyy7ek6bFRl5+aBs2yZzB0c4CnQfAtVypW/g==", "dev": true, "dependencies": { - "call-bind": "^1.0.2", + "call-bind": "^1.0.7", "for-each": "^0.3.3", - "is-typed-array": "^1.1.9" + "gopd": "^1.0.1", + "has-proto": "^1.0.3", + "is-typed-array": "^1.1.13", + "possible-typed-array-names": "^1.0.0" + }, + "engines": { + "node": ">= 0.4" }, "funding": { "url": "https://github.com/sponsors/ljharb" @@ -16589,9 +16789,9 @@ } }, "node_modules/typescript": { - "version": "5.4.2", - "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.4.2.tgz", - "integrity": "sha512-+2/g0Fds1ERlP6JsakQQDXjZdZMM+rqpamFZJEKh4kwTIn3iDkgKtby0CeNd5ATNZ4Ry1ax15TMx0W2V+miizQ==", + "version": "5.4.5", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.4.5.tgz", + "integrity": "sha512-vcI4UpRgg81oIRUFwR0WSIHKt11nJ7SAVlYNIu+QpqeyXP+gpQJy/Z4+F0aGxSE4MqwjyXvW/TzgkLAx2AGHwQ==", "devOptional": true, "bin": { "tsc": "bin/tsc", @@ -16732,9 +16932,9 @@ } }, "node_modules/viem": { - "version": "2.8.6", - "resolved": "https://registry.npmjs.org/viem/-/viem-2.8.6.tgz", - "integrity": "sha512-LqxLOSFtXfbC3tsiZ8Km8jKR4ktTOLfigL2dR9IN28He2+QrNhYvvwGPz3P4hbfU12Wvuxo6mWGZ2L1lpNtvrA==", + "version": "2.9.16", + "resolved": "https://registry.npmjs.org/viem/-/viem-2.9.16.tgz", + "integrity": "sha512-FQRfN4G7uKEUs5DYvVrH/kZmTkwcSDpTBxnadpwG1EEP8nHm57WDpSaGN7PwSPVgJ6rMo5MENT5hgnqaNTlb2w==", "funding": [ { "type": "github", @@ -16760,6 +16960,11 @@ } } }, + "node_modules/viem/node_modules/@adraffy/ens-normalize": { + "version": "1.10.0", + "resolved": "https://registry.npmjs.org/@adraffy/ens-normalize/-/ens-normalize-1.10.0.tgz", + "integrity": "sha512-nA9XHtlAkYfJxY7bce8DcN7eKxWWCWkU+1GR9d+U6MbNpfwQp8TI7vqOsBsMcHoT4mBu2kypKoSKnghEzOOq5Q==" + }, "node_modules/viem/node_modules/@noble/curves": { "version": "1.2.0", "resolved": "https://registry.npmjs.org/@noble/curves/-/curves-1.2.0.tgz", @@ -16821,9 +17026,9 @@ } }, "node_modules/web-streams-polyfill": { - "version": "3.2.1", - "resolved": "https://registry.npmjs.org/web-streams-polyfill/-/web-streams-polyfill-3.2.1.tgz", - "integrity": "sha512-e0MO3wdXWKrLbL0DgGnUV7WHVuw9OUvL4hjgnPkIeEvESk74gAITi5G606JtZPp39cd8HA9VQzCIvA49LpPN5Q==", + "version": "3.3.3", + "resolved": "https://registry.npmjs.org/web-streams-polyfill/-/web-streams-polyfill-3.3.3.tgz", + "integrity": "sha512-d2JWLCivmZYTSIoge9MsgFCZrt571BikcWGYkjC1khllbTeDlGqZ2D8vD8E/lJa8WGWbb7Plm8/XJYV7IJHZZw==", "engines": { "node": ">= 8" } @@ -16925,16 +17130,16 @@ } }, "node_modules/which-typed-array": { - "version": "1.1.13", - "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.13.tgz", - "integrity": "sha512-P5Nra0qjSncduVPEAr7xhoF5guty49ArDTwzJ/yNuPIbZppyRxFQsRCWrocxIY+CnMVG+qfbU2FmDKyvSGClow==", + "version": "1.1.15", + "resolved": "https://registry.npmjs.org/which-typed-array/-/which-typed-array-1.1.15.tgz", + "integrity": "sha512-oV0jmFtUky6CXfkqehVvBP/LSWJ2sy4vWMioiENyJLePrBO/yKyV9OyJySfAKosh+RYkIl5zJCNZ8/4JncrpdA==", "dev": true, "dependencies": { - "available-typed-arrays": "^1.0.5", - "call-bind": "^1.0.4", + "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" + "has-tostringtag": "^1.0.2" }, "engines": { "node": ">= 0.4" @@ -17263,8 +17468,7 @@ "dependencies": { "@moonbeam-network/xcm-types": "2.0.3", "@moonbeam-network/xcm-utils": "2.0.3", - "big.js": "^6.2.1", - "type-fest": "^3.8.0" + "big.js": "^6.2.1" }, "peerDependencies": { "@polkadot/api": "^10.10.1", @@ -17274,16 +17478,6 @@ "@polkadot/util-crypto": "^12.5.1" } }, - "packages/builder/node_modules/type-fest": { - "version": "3.13.1", - "license": "(MIT OR CC0-1.0)", - "engines": { - "node": ">=14.16" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, "packages/config": { "name": "@moonbeam-network/xcm-config", "version": "2.0.7", @@ -17315,7 +17509,7 @@ "@polkadot/types": "^10.10.1", "@polkadot/util": "^12.5.1", "ethers": "^6.11.0", - "viem": "^2.7.8" + "viem": "^2.9.16" } }, "packages/types": { @@ -17325,18 +17519,7 @@ "dependencies": { "@moonbeam-network/xcm-utils": "2.0.3", "big.js": "^6.2.1", - "type-fest": "^3.8.0", - "viem": "^2.8.6" - } - }, - "packages/types/node_modules/type-fest": { - "version": "3.13.1", - "license": "(MIT OR CC0-1.0)", - "engines": { - "node": ">=14.16" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" + "viem": "^2.9.16" } }, "packages/utils": { diff --git a/package.json b/package.json index 826a0a26..c2d1739f 100644 --- a/package.json +++ b/package.json @@ -41,23 +41,24 @@ "@polkadot/util-crypto": "^12.5.1" }, "devDependencies": { - "@changesets/changelog-github": "^0.4.8", + "@changesets/changelog-github": "^0.5.0", "@changesets/cli": "^2.27.1", "@slack/webhook": "^7.0.2", - "@types/jest": "^29.5.11", - "@typescript-eslint/eslint-plugin": "^7.2.0", - "@typescript-eslint/parser": "^7.2.0", - "bun": "^1.0.21", + "@types/jest": "^29.5.12", + "@typescript-eslint/eslint-plugin": "^7.6.0", + "@typescript-eslint/parser": "^7.6.0", + "bun": "^1.1.3", "dotenv": "^16.4.5", "eslint": "^8.57.0", "eslint-config-airbnb-base": "^15.0.0", "eslint-config-airbnb-typescript": "^18.0.0", "eslint-config-prettier": "^9.1.0", + "eslint-import-resolver-typescript": "^3.6.1", "eslint-plugin-import": "^2.29.1", - "eslint-plugin-jest": "^27.9.0", + "eslint-plugin-jest": "^28.2.0", "eslint-plugin-prettier": "^5.1.3", - "ethers": "^6.11.0", - "glob": "^10.3.10", + "ethers": "^6.11.1", + "glob": "^10.3.12", "husky": "^9.0.11", "jest": "^29.7.0", "lint-staged": "^15.2.2", @@ -65,9 +66,9 @@ "ts-jest": "^29.1.2", "ts-node": "^10.9.2", "tsup": "^8.0.2", - "turbo": "^1.12.5", - "typescript": "^5.4.2", - "viem": "^2.7.8" + "turbo": "^1.13.2", + "typescript": "^5.4.5", + "viem": "^2.9.16" }, "lint-staged": { "*.{js,ts}": "eslint --cache --fix --max-warnings=0", diff --git a/packages/builder/package.json b/packages/builder/package.json index 3198e621..0c65a0bc 100644 --- a/packages/builder/package.json +++ b/packages/builder/package.json @@ -52,8 +52,7 @@ "dependencies": { "@moonbeam-network/xcm-types": "2.0.3", "@moonbeam-network/xcm-utils": "2.0.3", - "big.js": "^6.2.1", - "type-fest": "^3.8.0" + "big.js": "^6.2.1" }, "peerDependencies": { "@polkadot/api": "^10.10.1", diff --git a/packages/builder/src/asset-min/AssetMinBuilder.test.ts b/packages/builder/src/asset-min/AssetMinBuilder.test.ts index 4953db0c..55a6d982 100644 --- a/packages/builder/src/asset-min/AssetMinBuilder.test.ts +++ b/packages/builder/src/asset-min/AssetMinBuilder.test.ts @@ -1,4 +1,5 @@ import { TypeRegistry, U128 } from '@polkadot/types'; +import { describe, expect, it } from '@jest/globals'; import { AssetMinBuilder } from './AssetMinBuilder'; function balanceOf(number: number | string): U128 { diff --git a/packages/builder/src/asset-min/AssetMinBuilder.ts b/packages/builder/src/asset-min/AssetMinBuilder.ts index cd6246be..fa2c814a 100644 --- a/packages/builder/src/asset-min/AssetMinBuilder.ts +++ b/packages/builder/src/asset-min/AssetMinBuilder.ts @@ -22,6 +22,7 @@ function assetRegistry() { module: pallet, func: 'assetMetadatas', args: [asset], + // eslint-disable-next-line @typescript-eslint/no-explicit-any transform: async (response: Option): Promise => response.unwrapOrDefault().minimalBalance.toBigInt(), }), @@ -32,6 +33,7 @@ function assetRegistry() { module: pallet, func: 'currencyMetadatas', args: [asset], + // eslint-disable-next-line @typescript-eslint/no-explicit-any transform: async (response: Option): Promise => response.unwrapOrDefault().minimalBalance.toBigInt(), }), diff --git a/packages/builder/src/balance/BalanceBuilder.test.ts b/packages/builder/src/balance/BalanceBuilder.test.ts index f430f302..dac11544 100644 --- a/packages/builder/src/balance/BalanceBuilder.test.ts +++ b/packages/builder/src/balance/BalanceBuilder.test.ts @@ -1,4 +1,5 @@ import { TypeRegistry, U128 } from '@polkadot/types'; +import { describe, expect, it } from '@jest/globals'; import { SubstrateQueryConfig } from '../types/substrate/SubstrateQueryConfig'; import { BalanceBuilder } from './BalanceBuilder'; diff --git a/packages/builder/src/balance/BalanceBuilder.ts b/packages/builder/src/balance/BalanceBuilder.ts index d9ed43e3..f5e6afee 100644 --- a/packages/builder/src/balance/BalanceBuilder.ts +++ b/packages/builder/src/balance/BalanceBuilder.ts @@ -108,7 +108,9 @@ function system() { balances = res; } + // eslint-disable-next-line @typescript-eslint/no-explicit-any if (Array.isArray((res as any)?.v0?.balance)) { + // eslint-disable-next-line @typescript-eslint/no-explicit-any balances = (res as any).v0.balance; } diff --git a/packages/builder/src/contract/ContractConfig.ts b/packages/builder/src/contract/ContractConfig.ts index 8e136121..73160df8 100644 --- a/packages/builder/src/contract/ContractConfig.ts +++ b/packages/builder/src/contract/ContractConfig.ts @@ -3,11 +3,13 @@ import { BaseConfig, BaseConfigConstructorParams } from '../types/BaseConfig'; export interface ContractConfigConstructorParams extends Omit { + // eslint-disable-next-line @typescript-eslint/no-explicit-any args: any[]; address?: string; } export class ContractConfig extends BaseConfig { + // eslint-disable-next-line @typescript-eslint/no-explicit-any readonly args: any[]; readonly address?: string; diff --git a/packages/builder/src/extrinsic/ExtrinsicConfig.ts b/packages/builder/src/extrinsic/ExtrinsicConfig.ts index fd7e2b30..2e935357 100644 --- a/packages/builder/src/extrinsic/ExtrinsicConfig.ts +++ b/packages/builder/src/extrinsic/ExtrinsicConfig.ts @@ -4,10 +4,12 @@ import { BaseConfig, BaseConfigConstructorParams } from '../types/BaseConfig'; export interface ExtrinsicConfigConstructorParams extends Omit { + // eslint-disable-next-line @typescript-eslint/no-explicit-any getArgs: (func?: SubmittableExtrinsicFunction<'promise'>) => any[]; } export class ExtrinsicConfig extends BaseConfig { + // eslint-disable-next-line @typescript-eslint/no-explicit-any getArgs: (func?: SubmittableExtrinsicFunction<'promise'>) => any[]; constructor({ getArgs, ...other }: ExtrinsicConfigConstructorParams) { diff --git a/packages/builder/src/extrinsic/pallets/eqBalances/eqBalances.test.ts b/packages/builder/src/extrinsic/pallets/eqBalances/eqBalances.test.ts index 44728928..1c740e41 100644 --- a/packages/builder/src/extrinsic/pallets/eqBalances/eqBalances.test.ts +++ b/packages/builder/src/extrinsic/pallets/eqBalances/eqBalances.test.ts @@ -1,3 +1,5 @@ +/* eslint-disable @typescript-eslint/no-explicit-any */ +import { describe, expect, it } from '@jest/globals'; import { buildParachainParamsMock, buildParamsMock, diff --git a/packages/builder/src/extrinsic/pallets/polkadotXcm/polkadotXcm.test.ts b/packages/builder/src/extrinsic/pallets/polkadotXcm/polkadotXcm.test.ts index 4ad917b3..ae304284 100644 --- a/packages/builder/src/extrinsic/pallets/polkadotXcm/polkadotXcm.test.ts +++ b/packages/builder/src/extrinsic/pallets/polkadotXcm/polkadotXcm.test.ts @@ -1,3 +1,4 @@ +import { describe, expect, it } from '@jest/globals'; import { buildParachainParamsMock, buildParamsMock, diff --git a/packages/builder/src/extrinsic/pallets/polkadotXcm/polkadotXcm.util.ts b/packages/builder/src/extrinsic/pallets/polkadotXcm/polkadotXcm.util.ts index 2cf597ef..e5ebea18 100644 --- a/packages/builder/src/extrinsic/pallets/polkadotXcm/polkadotXcm.util.ts +++ b/packages/builder/src/extrinsic/pallets/polkadotXcm/polkadotXcm.util.ts @@ -10,6 +10,7 @@ import { } from '../../ExtrinsicBuilder.utils'; export interface GetExtrinsicParams extends ExtrinsicConfigBuilderPrams { + // eslint-disable-next-line @typescript-eslint/no-explicit-any asset: any; func?: SubmittableExtrinsicFunction<'promise'>; parents?: Parents; @@ -23,6 +24,7 @@ export function getPolkadotXcmExtrinsicArgs({ func, parents = 1, feeIndex = 0, + // eslint-disable-next-line @typescript-eslint/no-explicit-any }: GetExtrinsicParams): any[] { // eslint-disable-next-line @typescript-eslint/no-use-before-define const version = getExtrinsicArgumentVersion(func); diff --git a/packages/builder/src/extrinsic/pallets/xTokens/xTokens.test.ts b/packages/builder/src/extrinsic/pallets/xTokens/xTokens.test.ts index 0b468147..7ec9bd50 100644 --- a/packages/builder/src/extrinsic/pallets/xTokens/xTokens.test.ts +++ b/packages/builder/src/extrinsic/pallets/xTokens/xTokens.test.ts @@ -1,3 +1,4 @@ +import { describe, expect, it } from '@jest/globals'; import { buildParachainParamsMock, buildParamsMock, diff --git a/packages/builder/src/extrinsic/pallets/xTransfer/xTransfer.test.ts b/packages/builder/src/extrinsic/pallets/xTransfer/xTransfer.test.ts index 9222cbfa..95685d86 100644 --- a/packages/builder/src/extrinsic/pallets/xTransfer/xTransfer.test.ts +++ b/packages/builder/src/extrinsic/pallets/xTransfer/xTransfer.test.ts @@ -1,3 +1,4 @@ +import { describe, expect, it } from '@jest/globals'; import { buildParachainParamsMock, buildParamsMock, diff --git a/packages/builder/src/extrinsic/pallets/xcmPallet/xcmPallet.test.ts b/packages/builder/src/extrinsic/pallets/xcmPallet/xcmPallet.test.ts index 7ae3b8ec..623cb804 100644 --- a/packages/builder/src/extrinsic/pallets/xcmPallet/xcmPallet.test.ts +++ b/packages/builder/src/extrinsic/pallets/xcmPallet/xcmPallet.test.ts @@ -1,3 +1,4 @@ +import { describe, expect, it } from '@jest/globals'; import { buildParamsMock } from '../../../../fixtures'; import { xcmPallet } from './xcmPallet'; diff --git a/packages/builder/src/fee/FeeBuilder.ts b/packages/builder/src/fee/FeeBuilder.ts index b0e6bf15..055f5e0c 100644 --- a/packages/builder/src/fee/FeeBuilder.ts +++ b/packages/builder/src/fee/FeeBuilder.ts @@ -20,6 +20,7 @@ function assetManager() { call: async (): Promise => { const type = (await api.query.assetManager.assetIdType( asset, + // eslint-disable-next-line @typescript-eslint/no-explicit-any )) as unknown as Option; if (type.isNone) { diff --git a/packages/builder/src/types/substrate/SubstrateCallConfig.ts b/packages/builder/src/types/substrate/SubstrateCallConfig.ts index a203e534..eb2bb555 100644 --- a/packages/builder/src/types/substrate/SubstrateCallConfig.ts +++ b/packages/builder/src/types/substrate/SubstrateCallConfig.ts @@ -9,6 +9,7 @@ export interface SubstrateCallConfigConstructorParams { export class SubstrateCallConfig { readonly api: ApiPromise; + // eslint-disable-next-line @typescript-eslint/no-explicit-any readonly call: () => Promise; readonly type = CallType.Substrate; diff --git a/packages/builder/src/types/substrate/SubstrateQueryConfig.ts b/packages/builder/src/types/substrate/SubstrateQueryConfig.ts index 66d28cc5..82add59c 100644 --- a/packages/builder/src/types/substrate/SubstrateQueryConfig.ts +++ b/packages/builder/src/types/substrate/SubstrateQueryConfig.ts @@ -1,16 +1,20 @@ -import { SetOptional } from 'type-fest'; +import { SetOptional } from '@moonbeam-network/xcm-types'; import { CallType } from '../../builder.interfaces'; import { BaseConfig, BaseConfigConstructorParams } from '../BaseConfig'; export interface QueryConfigConstructorParams extends SetOptional { + // eslint-disable-next-line @typescript-eslint/no-explicit-any args?: any[]; + // eslint-disable-next-line @typescript-eslint/no-explicit-any transform: (data: any) => Promise; } export class SubstrateQueryConfig extends BaseConfig { + // eslint-disable-next-line @typescript-eslint/no-explicit-any readonly args: any[]; + // eslint-disable-next-line @typescript-eslint/no-explicit-any readonly transform: (data: any) => Promise; constructor({ diff --git a/packages/config/src/ConfigBuilder/ConfigBuilder.test.ts b/packages/config/src/ConfigBuilder/ConfigBuilder.test.ts index c182b682..533532cf 100644 --- a/packages/config/src/ConfigBuilder/ConfigBuilder.test.ts +++ b/packages/config/src/ConfigBuilder/ConfigBuilder.test.ts @@ -1,5 +1,6 @@ /* eslint-disable sort-keys */ import { Ecosystem } from '@moonbeam-network/xcm-types'; +import { describe, expect, it } from '@jest/globals'; import { ConfigService } from '../ConfigService'; import { dev } from '../assets'; import { moonbaseAlpha, pendulumAlphanet } from '../chains'; diff --git a/packages/config/src/ConfigService/ConfigService.test.ts b/packages/config/src/ConfigService/ConfigService.test.ts index ff7793df..7ab14eb9 100644 --- a/packages/config/src/ConfigService/ConfigService.test.ts +++ b/packages/config/src/ConfigService/ConfigService.test.ts @@ -8,6 +8,7 @@ import { EvmParachain, Parachain, } from '@moonbeam-network/xcm-types'; +import { describe, expect, it } from '@jest/globals'; import { assetsList, dev, glmr, tt1, unit } from '../assets'; import { hydraDX, moonbaseAlpha, moonbeam, pendulumAlphanet } from '../chains'; import { ConfigService } from './ConfigService'; diff --git a/packages/sdk/package.json b/packages/sdk/package.json index 606f9547..6f5897ef 100644 --- a/packages/sdk/package.json +++ b/packages/sdk/package.json @@ -63,6 +63,6 @@ "@polkadot/types": "^10.10.1", "@polkadot/util": "^12.5.1", "ethers": "^6.11.0", - "viem": "^2.7.8" + "viem": "^2.9.16" } } diff --git a/packages/sdk/src/contract/contracts/Xtokens/Xtokens.ts b/packages/sdk/src/contract/contracts/Xtokens/Xtokens.ts index f2490cde..d7041359 100644 --- a/packages/sdk/src/contract/contracts/Xtokens/Xtokens.ts +++ b/packages/sdk/src/contract/contracts/Xtokens/Xtokens.ts @@ -63,6 +63,7 @@ export class Xtokens implements TransferContractInterface { return 0n; } + // eslint-disable-next-line @typescript-eslint/no-explicit-any return contract.estimateGas[this.#config.func](this.#config.args as any); } diff --git a/packages/types/package.json b/packages/types/package.json index d0ac20ae..425eb031 100644 --- a/packages/types/package.json +++ b/packages/types/package.json @@ -51,7 +51,6 @@ "dependencies": { "@moonbeam-network/xcm-utils": "2.0.3", "big.js": "^6.2.1", - "type-fest": "^3.8.0", - "viem": "^2.8.6" + "viem": "^2.9.16" } } diff --git a/packages/types/src/chain/parachain/EvmParachain.test.ts b/packages/types/src/chain/parachain/EvmParachain.test.ts index a41a475d..8e92c90b 100644 --- a/packages/types/src/chain/parachain/EvmParachain.test.ts +++ b/packages/types/src/chain/parachain/EvmParachain.test.ts @@ -1,3 +1,4 @@ +import { describe, expect, it } from '@jest/globals'; import { Ecosystem } from '../Chain.interfaces'; import { EvmParachain } from './EvmParachain'; diff --git a/packages/types/src/chain/parachain/Parachain.test.ts b/packages/types/src/chain/parachain/Parachain.test.ts index 74c1c01a..c042a9dc 100644 --- a/packages/types/src/chain/parachain/Parachain.test.ts +++ b/packages/types/src/chain/parachain/Parachain.test.ts @@ -1,3 +1,4 @@ +import { describe, expect, it } from '@jest/globals'; import { Ecosystem } from '../Chain.interfaces'; import { Parachain } from './Parachain'; diff --git a/packages/types/src/chain/parachain/Parachain.ts b/packages/types/src/chain/parachain/Parachain.ts index 98e7d7e2..7e575a5f 100644 --- a/packages/types/src/chain/parachain/Parachain.ts +++ b/packages/types/src/chain/parachain/Parachain.ts @@ -1,5 +1,5 @@ -import { SetOptional } from 'type-fest'; import { Asset } from '../../asset'; +import { SetOptional } from '../../common.interfaces'; import { Chain, ChainConstructorParams } from '../Chain'; import { ChainType } from '../Chain.interfaces'; import { ChainAssetId, ChainAssetsData } from './Parachain.interfaces'; diff --git a/packages/types/src/common.interfaces.ts b/packages/types/src/common.interfaces.ts new file mode 100644 index 00000000..6cc92abc --- /dev/null +++ b/packages/types/src/common.interfaces.ts @@ -0,0 +1,2 @@ +export type SetOptional = Omit & + Partial>; diff --git a/packages/types/src/index.ts b/packages/types/src/index.ts index 18b7df07..5cf8c931 100644 --- a/packages/types/src/index.ts +++ b/packages/types/src/index.ts @@ -1,2 +1,3 @@ export * from './asset'; export * from './chain'; +export * from './common.interfaces'; diff --git a/packages/utils/src/numbers/decimals.test.ts b/packages/utils/src/numbers/decimals.test.ts index 6da57ec9..bcf9b5bd 100644 --- a/packages/utils/src/numbers/decimals.test.ts +++ b/packages/utils/src/numbers/decimals.test.ts @@ -1,5 +1,6 @@ /* eslint-disable jest/no-focused-tests */ /* eslint-disable jest/max-expects */ +import { describe, expect, it } from '@jest/globals'; import Big from 'big.js'; import { convertDecimals, diff --git a/packages/utils/src/polkadot/polkadot.address.test.ts b/packages/utils/src/polkadot/polkadot.address.test.ts index 167895e4..f4f8321a 100644 --- a/packages/utils/src/polkadot/polkadot.address.test.ts +++ b/packages/utils/src/polkadot/polkadot.address.test.ts @@ -1,3 +1,4 @@ +import { describe, expect, it } from '@jest/globals'; import { getSovereignAccountAddresses } from './polkadot.address'; describe('utils - polkadot address', () => { From f9fa3cfc6e556ad329ad4c51ade2baf19352ddf1 Mon Sep 17 00:00:00 2001 From: Elmar Kenigs Date: Fri, 12 Apr 2024 11:42:19 +0300 Subject: [PATCH 34/44] Updated actions --- .github/workflows/acceptance.yml | 6 +++--- .github/workflows/build.yml | 7 +++---- .github/workflows/lint.yml | 8 ++++---- .github/workflows/publish-dev.yml | 6 +++--- .github/workflows/release.yml | 6 +++--- .github/workflows/unit.yml | 6 +++--- 6 files changed, 19 insertions(+), 20 deletions(-) diff --git a/.github/workflows/acceptance.yml b/.github/workflows/acceptance.yml index 633033a5..5ee43cef 100644 --- a/.github/workflows/acceptance.yml +++ b/.github/workflows/acceptance.yml @@ -13,12 +13,12 @@ jobs: runs-on: ubuntu-latest steps: - name: 🤘 checkout - uses: actions/checkout@v3 + uses: actions/checkout@v4 - name: ⚙️ Setup Node.js environment - uses: actions/setup-node@v3.0.0 + uses: actions/setup-node@v4 with: - node-version: 18.x + node-version: 20.x cache: 'npm' - run: npm ci --ignore-scripts diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index c9943916..7639f98c 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -9,12 +9,12 @@ jobs: runs-on: ubuntu-latest steps: - name: 🤘 checkout - uses: actions/checkout@v3 + uses: actions/checkout@v4 - name: ⚙️ Setup Node.js environment - uses: actions/setup-node@v3.0.0 + uses: actions/setup-node@v4 with: - node-version: 18.x + node-version: 20.x cache: 'npm' - run: npm ci --ignore-scripts @@ -24,4 +24,3 @@ jobs: - name: 🧪 Run TypeCheck run: npm run typecheck - diff --git a/.github/workflows/lint.yml b/.github/workflows/lint.yml index 8b5126be..2adb3572 100644 --- a/.github/workflows/lint.yml +++ b/.github/workflows/lint.yml @@ -5,16 +5,16 @@ on: push concurrency: ${{ github.workflow }}-${{ github.ref }} jobs: - unit: + lint: runs-on: ubuntu-latest steps: - name: 🤘 checkout - uses: actions/checkout@v3 + uses: actions/checkout@v4 - name: ⚙️ Setup Node.js environment - uses: actions/setup-node@v3.0.0 + uses: actions/setup-node@v4 with: - node-version: 18.x + node-version: 20.x cache: 'npm' - run: npm ci --ignore-scripts diff --git a/.github/workflows/publish-dev.yml b/.github/workflows/publish-dev.yml index 4e9b1d4f..b9f86eb8 100644 --- a/.github/workflows/publish-dev.yml +++ b/.github/workflows/publish-dev.yml @@ -8,12 +8,12 @@ jobs: runs-on: ubuntu-latest steps: - name: 🤘 checkout - uses: actions/checkout@v3 + uses: actions/checkout@v4 - name: ⚙️ Setup Node.js environment - uses: actions/setup-node@v3.0.0 + uses: actions/setup-node@v4 with: - node-version: 18.x + node-version: 20.x cache: 'npm' - name: 🔐 Authenticate with NPM diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 41f8f963..06ab0956 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -12,12 +12,12 @@ jobs: runs-on: ubuntu-latest steps: - name: 🤘 checkout - uses: actions/checkout@v3 + uses: actions/checkout@v4 - name: ⚙️ Setup Node.js environment - uses: actions/setup-node@v3.0.0 + uses: actions/setup-node@v4 with: - node-version: 18.x + node-version: 20.x cache: 'npm' - run: npm ci --ignore-scripts diff --git a/.github/workflows/unit.yml b/.github/workflows/unit.yml index c443aff8..fc808006 100644 --- a/.github/workflows/unit.yml +++ b/.github/workflows/unit.yml @@ -9,12 +9,12 @@ jobs: runs-on: ubuntu-latest steps: - name: 🤘 checkout - uses: actions/checkout@v3 + uses: actions/checkout@v4 - name: ⚙️ Setup Node.js environment - uses: actions/setup-node@v3.0.0 + uses: actions/setup-node@v4 with: - node-version: 18.x + node-version: 20.x cache: 'npm' - run: npm ci --ignore-scripts From 496d6683f2dc0790e9cf3ab28f54ea7375517185 Mon Sep 17 00:00:00 2001 From: Elmar Kenigs Date: Fri, 12 Apr 2024 11:46:18 +0300 Subject: [PATCH 35/44] Fixed lint action --- .github/workflows/build.yml | 7 +++++-- .github/workflows/lint.yml | 23 ----------------------- 2 files changed, 5 insertions(+), 25 deletions(-) delete mode 100644 .github/workflows/lint.yml diff --git a/.github/workflows/build.yml b/.github/workflows/build.yml index 7639f98c..21e22fee 100644 --- a/.github/workflows/build.yml +++ b/.github/workflows/build.yml @@ -1,11 +1,11 @@ -name: build +name: lint on: push concurrency: ${{ github.workflow }}-${{ github.ref }} jobs: - unit: + lint: runs-on: ubuntu-latest steps: - name: 🤘 checkout @@ -24,3 +24,6 @@ jobs: - name: 🧪 Run TypeCheck run: npm run typecheck + + - name: 🧪 Run ESLint + run: npm run lint diff --git a/.github/workflows/lint.yml b/.github/workflows/lint.yml deleted file mode 100644 index 2adb3572..00000000 --- a/.github/workflows/lint.yml +++ /dev/null @@ -1,23 +0,0 @@ -name: lint - -on: push - -concurrency: ${{ github.workflow }}-${{ github.ref }} - -jobs: - lint: - runs-on: ubuntu-latest - steps: - - name: 🤘 checkout - uses: actions/checkout@v4 - - - name: ⚙️ Setup Node.js environment - uses: actions/setup-node@v4 - with: - node-version: 20.x - cache: 'npm' - - - run: npm ci --ignore-scripts - - - name: 🧪 Run linter - run: npm run lint From d84ca20f79e222053ace5a962c0d04adb0c9fe83 Mon Sep 17 00:00:00 2001 From: Elmar Kenigs Date: Fri, 12 Apr 2024 11:47:49 +0300 Subject: [PATCH 36/44] Updated endpoints monitoring action --- .github/workflows/xcm-wss-endpoints-monitor.yml | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/.github/workflows/xcm-wss-endpoints-monitor.yml b/.github/workflows/xcm-wss-endpoints-monitor.yml index 7ce1b628..6bc8189a 100644 --- a/.github/workflows/xcm-wss-endpoints-monitor.yml +++ b/.github/workflows/xcm-wss-endpoints-monitor.yml @@ -12,12 +12,12 @@ jobs: steps: - name: 🤘 checkout - uses: actions/checkout@v3 + uses: actions/checkout@v4 - name: ⚙️ Setup Node.js environment - uses: actions/setup-node@v3.0.0 + uses: actions/setup-node@v4 with: - node-version: 18.x + node-version: 20.x cache: 'npm' - name: Update npm From a13fa8124d7ce1f612ff7723bdb214547639f7b6 Mon Sep 17 00:00:00 2001 From: Elmar Kenigs Date: Fri, 12 Apr 2024 12:00:28 +0300 Subject: [PATCH 37/44] Moved viem to peerDeps in types package --- package-lock.json | 4 +++- packages/types/package.json | 4 +++- 2 files changed, 6 insertions(+), 2 deletions(-) diff --git a/package-lock.json b/package-lock.json index 93e59c42..627ffb74 100644 --- a/package-lock.json +++ b/package-lock.json @@ -17518,7 +17518,9 @@ "license": "MIT", "dependencies": { "@moonbeam-network/xcm-utils": "2.0.3", - "big.js": "^6.2.1", + "big.js": "^6.2.1" + }, + "peerDependencies": { "viem": "^2.9.16" } }, diff --git a/packages/types/package.json b/packages/types/package.json index 425eb031..82e23b81 100644 --- a/packages/types/package.json +++ b/packages/types/package.json @@ -50,7 +50,9 @@ "main": "./build/index.cjs", "dependencies": { "@moonbeam-network/xcm-utils": "2.0.3", - "big.js": "^6.2.1", + "big.js": "^6.2.1" + }, + "peerDependencies": { "viem": "^2.9.16" } } From c1167fe1813f169c359ca0b05b7a46fe068f1789 Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Mon, 15 Apr 2024 11:12:42 +0200 Subject: [PATCH 38/44] Improve Dev version script, fix acc tets, add more info to the pipeline --- .github/workflows/publish-dev.yml | 9 ++++++ .../acceptance/__snapshots__/sdk.test.ts.snap | 11 ++++++-- scripts/update-dev-versions.ts | 28 +++++++++++++++++-- 3 files changed, 43 insertions(+), 5 deletions(-) diff --git a/.github/workflows/publish-dev.yml b/.github/workflows/publish-dev.yml index b9f86eb8..66570ebe 100644 --- a/.github/workflows/publish-dev.yml +++ b/.github/workflows/publish-dev.yml @@ -19,11 +19,20 @@ jobs: - name: 🔐 Authenticate with NPM run: echo "//registry.npmjs.org/:_authToken=${{ secrets.NPM_TOKEN }}" > ~/.npmrc + - name: Update npm + run: npm i -g npm@latest + + - name: node/npm version + run: node --version && npm --version + - run: npm ci --ignore-scripts - name: ✌️ Update versions run: npx bun ./scripts/update-dev-versions.ts + - name: ✌️ Print versions + run: find ./packages -name 'package.json' -not -path '*/node_modules/*' -exec grep -H 'version' {} + + - name: 🛠️ Build run: npm run build diff --git a/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap b/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap index 9fb89f8a..a42cebf3 100644 --- a/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap +++ b/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap @@ -200,6 +200,13 @@ exports[`sdk getParachainBalances should get expected balances for HydraDX for s exports[`sdk getParachainBalances should get expected balances for Moonbase Alpha 1`] = ` [ + r { + "amount": 0n, + "decimals": 12, + "key": "hdx", + "originSymbol": "HDX", + "symbol": "HDX", + }, r { "amount": 1234567890000000000n, "decimals": 18, @@ -297,14 +304,14 @@ exports[`sdk getParachainBalances should get expected balances for Moonbase Beta "symbol": "USDC.Wh", }, r { - "amount": 12080000000000000000n, + "amount": 12180000000000000000n, "decimals": 18, "key": "alan", "originSymbol": "ALAN", "symbol": "ALAN", }, r { - "amount": 9972701135728000000n, + "amount": 7972889614166000000n, "decimals": 18, "key": "dev", "originSymbol": "DEV", diff --git a/scripts/update-dev-versions.ts b/scripts/update-dev-versions.ts index 9ebaa0ee..5fa58b6f 100644 --- a/scripts/update-dev-versions.ts +++ b/scripts/update-dev-versions.ts @@ -10,6 +10,23 @@ import { promisify } from 'node:util'; const execPromise = promisify(exec); +// eslint-disable-next-line @typescript-eslint/no-explicit-any +async function getHighestDevTag(pkgs: any[]) { + const promises = pkgs.map(async (pkg) => { + const { name } = pkg; + const { stdout } = await execPromise(`npm view ${name} dist-tags.dev`); + const current = stdout.replace(/\n$/, ''); + + const number = current.split('.').at(-1) || '0'; + + return Number(number); + }); + + const allVersions = await Promise.all(promises); + + return Math.max(...allVersions); +} + async function main() { const files = await glob(`${process.env.PWD}/packages/**/package.json`, { ignore: '**/node_modules/**', @@ -21,13 +38,18 @@ async function main() { }), ); + const highestCurrent = await getHighestDevTag(pkgs); + const nextVersionNumber = highestCurrent + 1; + + console.log(`highestCurrent = ${highestCurrent}`); + console.log(`newVersion = ${nextVersionNumber}`); + for (const pkg of pkgs) { const { name } = pkg; const { stdout } = await execPromise(`npm view ${name} dist-tags.dev`); + const current = stdout.replace(/\n$/, ''); - const number = current.split('.').at(-1) || '0'; - const next = Number(number) + 1; - const newVersion = current.replace(/\.\d+$/, `.${next}`); + const newVersion = current.replace(/\.\d+$/, `.${nextVersionNumber}`); pkg.version = newVersion; From ed3e6616efa64abbf347a7979758aa65d291820d Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Mon, 15 Apr 2024 11:24:46 +0200 Subject: [PATCH 39/44] try to fix pipeline --- .github/workflows/publish-dev.yml | 30 +++++++++++++++--------------- scripts/update-dev-versions.ts | 6 ++++++ 2 files changed, 21 insertions(+), 15 deletions(-) diff --git a/.github/workflows/publish-dev.yml b/.github/workflows/publish-dev.yml index 66570ebe..35a00950 100644 --- a/.github/workflows/publish-dev.yml +++ b/.github/workflows/publish-dev.yml @@ -36,22 +36,22 @@ jobs: - name: 🛠️ Build run: npm run build - - name: 🚀 Publish types - working-directory: ./packages/types - run: npm publish --tag dev + # - name: 🚀 Publish types + # working-directory: ./packages/types + # run: npm publish --tag dev - - name: 🚀 Publish utils - working-directory: ./packages/utils - run: npm publish --tag dev + # - name: 🚀 Publish utils + # working-directory: ./packages/utils + # run: npm publish --tag dev - - name: 🚀 Publish builder - working-directory: ./packages/builder - run: npm publish --tag dev + # - name: 🚀 Publish builder + # working-directory: ./packages/builder + # run: npm publish --tag dev - - name: 🚀 Publish config - working-directory: ./packages/config - run: npm publish --tag dev + # - name: 🚀 Publish config + # working-directory: ./packages/config + # run: npm publish --tag dev - - name: 🚀 Publish sdk - working-directory: ./packages/sdk - run: npm publish --tag dev + # - name: 🚀 Publish sdk + # working-directory: ./packages/sdk + # run: npm publish --tag dev diff --git a/scripts/update-dev-versions.ts b/scripts/update-dev-versions.ts index 5fa58b6f..096090de 100644 --- a/scripts/update-dev-versions.ts +++ b/scripts/update-dev-versions.ts @@ -44,6 +44,9 @@ async function main() { console.log(`highestCurrent = ${highestCurrent}`); console.log(`newVersion = ${nextVersionNumber}`); + await execPromise(`echo highestCurrent = ${highestCurrent}`); + await execPromise(`echo nextVersionNumber = ${nextVersionNumber}`); + for (const pkg of pkgs) { const { name } = pkg; const { stdout } = await execPromise(`npm view ${name} dist-tags.dev`); @@ -51,6 +54,9 @@ async function main() { const current = stdout.replace(/\n$/, ''); const newVersion = current.replace(/\.\d+$/, `.${nextVersionNumber}`); + await execPromise(`echo name = ${name}`); + await execPromise(`echo newVersion = ${newVersion}`); + pkg.version = newVersion; pkgs.forEach((p) => { From 33052f2815b3fa7dfc097350951d3f701f413ebc Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Mon, 15 Apr 2024 11:50:44 +0200 Subject: [PATCH 40/44] add console.logs to pipeline --- scripts/update-dev-versions.ts | 9 +++------ 1 file changed, 3 insertions(+), 6 deletions(-) diff --git a/scripts/update-dev-versions.ts b/scripts/update-dev-versions.ts index 096090de..1db1c47a 100644 --- a/scripts/update-dev-versions.ts +++ b/scripts/update-dev-versions.ts @@ -28,6 +28,9 @@ async function getHighestDevTag(pkgs: any[]) { } async function main() { + console.log( + `************************************ update-dev-versions script start! ************************************`, + ); const files = await glob(`${process.env.PWD}/packages/**/package.json`, { ignore: '**/node_modules/**', }); @@ -44,9 +47,6 @@ async function main() { console.log(`highestCurrent = ${highestCurrent}`); console.log(`newVersion = ${nextVersionNumber}`); - await execPromise(`echo highestCurrent = ${highestCurrent}`); - await execPromise(`echo nextVersionNumber = ${nextVersionNumber}`); - for (const pkg of pkgs) { const { name } = pkg; const { stdout } = await execPromise(`npm view ${name} dist-tags.dev`); @@ -54,9 +54,6 @@ async function main() { const current = stdout.replace(/\n$/, ''); const newVersion = current.replace(/\.\d+$/, `.${nextVersionNumber}`); - await execPromise(`echo name = ${name}`); - await execPromise(`echo newVersion = ${newVersion}`); - pkg.version = newVersion; pkgs.forEach((p) => { From 60dfdafb027a2ffddce75b7e4d24d8e63b1fe760 Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Mon, 15 Apr 2024 11:56:37 +0200 Subject: [PATCH 41/44] install but to actions --- .github/workflows/publish-dev.yml | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/.github/workflows/publish-dev.yml b/.github/workflows/publish-dev.yml index 35a00950..351e265b 100644 --- a/.github/workflows/publish-dev.yml +++ b/.github/workflows/publish-dev.yml @@ -16,6 +16,8 @@ jobs: node-version: 20.x cache: 'npm' + - uses: oven-sh/setup-bun@v1 + - name: 🔐 Authenticate with NPM run: echo "//registry.npmjs.org/:_authToken=${{ secrets.NPM_TOKEN }}" > ~/.npmrc @@ -27,8 +29,8 @@ jobs: - run: npm ci --ignore-scripts - - name: ✌️ Update versions - run: npx bun ./scripts/update-dev-versions.ts + - name: ✌️ Update versions (BUN) + run: bun ./scripts/update-dev-versions.ts - name: ✌️ Print versions run: find ./packages -name 'package.json' -not -path '*/node_modules/*' -exec grep -H 'version' {} + From c3bf55815e4c250393ebf1601f9c0253d51059d9 Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Mon, 15 Apr 2024 11:59:52 +0200 Subject: [PATCH 42/44] fix the script with dev versions --- .github/workflows/publish-dev.yml | 30 +++++++++++++++--------------- 1 file changed, 15 insertions(+), 15 deletions(-) diff --git a/.github/workflows/publish-dev.yml b/.github/workflows/publish-dev.yml index 351e265b..bbfa5419 100644 --- a/.github/workflows/publish-dev.yml +++ b/.github/workflows/publish-dev.yml @@ -38,22 +38,22 @@ jobs: - name: 🛠️ Build run: npm run build - # - name: 🚀 Publish types - # working-directory: ./packages/types - # run: npm publish --tag dev + - name: 🚀 Publish types + working-directory: ./packages/types + run: npm publish --tag dev - # - name: 🚀 Publish utils - # working-directory: ./packages/utils - # run: npm publish --tag dev + - name: 🚀 Publish utils + working-directory: ./packages/utils + run: npm publish --tag dev - # - name: 🚀 Publish builder - # working-directory: ./packages/builder - # run: npm publish --tag dev + - name: 🚀 Publish builder + working-directory: ./packages/builder + run: npm publish --tag dev - # - name: 🚀 Publish config - # working-directory: ./packages/config - # run: npm publish --tag dev + - name: 🚀 Publish config + working-directory: ./packages/config + run: npm publish --tag dev - # - name: 🚀 Publish sdk - # working-directory: ./packages/sdk - # run: npm publish --tag dev + - name: 🚀 Publish sdk + working-directory: ./packages/sdk + run: npm publish --tag dev From 4e4d482cdc42d99ffb48ffc6b8e77a57b0fbb5a0 Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Mon, 15 Apr 2024 12:05:48 +0200 Subject: [PATCH 43/44] fix check websockets script --- .github/workflows/xcm-wss-endpoints-monitor.yml | 3 ++- scripts/check-websockets.ts | 4 +++- 2 files changed, 5 insertions(+), 2 deletions(-) diff --git a/.github/workflows/xcm-wss-endpoints-monitor.yml b/.github/workflows/xcm-wss-endpoints-monitor.yml index 6bc8189a..c0eb27d9 100644 --- a/.github/workflows/xcm-wss-endpoints-monitor.yml +++ b/.github/workflows/xcm-wss-endpoints-monitor.yml @@ -19,6 +19,7 @@ jobs: with: node-version: 20.x cache: 'npm' + - uses: oven-sh/setup-bun@v1 - name: Update npm run: npm i -g npm@9 @@ -30,4 +31,4 @@ jobs: run: npm run build - name: 💻 Run script - run: npx bun ./scripts/check-websockets.ts --slack-wh=${{ secrets.SLACK_WEBHOOK_URL }} + run: bun ./scripts/check-websockets.ts --slack-wh=${{ secrets.SLACK_WEBHOOK_URL }} diff --git a/scripts/check-websockets.ts b/scripts/check-websockets.ts index 9023cbe2..1974d006 100644 --- a/scripts/check-websockets.ts +++ b/scripts/check-websockets.ts @@ -15,6 +15,7 @@ function procesArgs() { async function checkWebSocketEndpoints( endpoints: ChainEndpoint[], ): Promise<{ endpoint: ChainEndpoint; isAlive: boolean }[]> { + console.log('Checking WebSocket endpoints...'); async function checkIsWebSocketAlive({ chainKey, ws: endpoint, @@ -24,7 +25,8 @@ async function checkWebSocketEndpoints( let isAlive = false; - ws.on('error', (error) => { + // eslint-disable-next-line @typescript-eslint/no-explicit-any + ws.on('error', (error: any) => { console.error( `WebSocket ${chainKey} connection to ${endpoint} failed. Error: ${error.message}`, ); From 4084c9589f32ff08c0ae6f1bd0571a252949212f Mon Sep 17 00:00:00 2001 From: Richard Kenigs Date: Tue, 16 Apr 2024 08:45:09 +0200 Subject: [PATCH 44/44] fix snapshots for acc tests --- package.json | 1 + .../acceptance/__snapshots__/sdk.test.ts.snap | 14 ++++++++++++++ 2 files changed, 15 insertions(+) diff --git a/package.json b/package.json index c2d1739f..feb0ec12 100644 --- a/package.json +++ b/package.json @@ -28,6 +28,7 @@ "test:update": "turbo run test:update", "test:ci": "turbo run test:ci", "test:acc": "turbo run test:acc", + "test:acc:u": "turbo run test:acc -- -u", "prepare": "husky install", "changeset": "changeset", "changeset:version": "changeset version && npm i --package-lock-only", diff --git a/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap b/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap index a42cebf3..1ed6c31d 100644 --- a/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap +++ b/packages/sdk/tests/acceptance/__snapshots__/sdk.test.ts.snap @@ -322,6 +322,13 @@ exports[`sdk getParachainBalances should get expected balances for Moonbase Beta exports[`sdk getParachainBalances should get expected balances for Moonbeam 1`] = ` [ + r { + "amount": 0n, + "decimals": 12, + "key": "bncs", + "originSymbol": "BNCS", + "symbol": "BNCS", + }, r { "amount": 0n, "decimals": 10, @@ -420,6 +427,13 @@ exports[`sdk getParachainBalances should get expected balances for Moonbeam 1`] "originSymbol": "HDX", "symbol": "HDX", }, + r { + "amount": 0n, + "decimals": 10, + "key": "ded", + "originSymbol": "DED", + "symbol": "DED", + }, r { "amount": 0n, "decimals": 10,