@metamask/connect-evm 0.11.2 → 1.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -7,6 +7,19 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
7
7
 
8
8
  ## [Unreleased]
9
9
 
10
+ ## [1.1.0]
11
+
12
+ ### Changed
13
+
14
+ - Cleanup initialization promise logic ([#281](https://github.com/MetaMask/connect-monorepo/pull/281))
15
+
16
+ ## [1.0.0]
17
+
18
+ ### Changed
19
+
20
+ - **BREAKING** `connectAndSign` now returns `{ accounts: Address[]; chainId: Hex; signature: string }` instead of a bare `string`. Code that previously destructured or assigned the return value as a string must be updated to read `.signature`. ([#266](https://github.com/MetaMask/connect-monorepo/pull/266))
21
+ - **BREAKING** `connectWith` now returns `{ accounts: Address[]; chainId: Hex; result: unknown }` instead of `unknown`. Code that previously used the return value as the raw RPC result must be updated to read `.result`. ([#266](https://github.com/MetaMask/connect-monorepo/pull/266))
22
+
10
23
  ## [0.11.2]
11
24
 
12
25
  ### Changed
@@ -198,7 +211,9 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
198
211
 
199
212
  - Initial release ([#58](https://github.com/MetaMask/connect-monorepo/pull/58))
200
213
 
201
- [Unreleased]: https://github.com/MetaMask/connect-monorepo/compare/@metamask/connect-evm@0.11.2...HEAD
214
+ [Unreleased]: https://github.com/MetaMask/connect-monorepo/compare/@metamask/connect-evm@1.1.0...HEAD
215
+ [1.1.0]: https://github.com/MetaMask/connect-monorepo/compare/@metamask/connect-evm@1.0.0...@metamask/connect-evm@1.1.0
216
+ [1.0.0]: https://github.com/MetaMask/connect-monorepo/compare/@metamask/connect-evm@0.11.2...@metamask/connect-evm@1.0.0
202
217
  [0.11.2]: https://github.com/MetaMask/connect-monorepo/compare/@metamask/connect-evm@0.11.1...@metamask/connect-evm@0.11.2
203
218
  [0.11.1]: https://github.com/MetaMask/connect-monorepo/compare/@metamask/connect-evm@0.11.0...@metamask/connect-evm@0.11.1
204
219
  [0.11.0]: https://github.com/MetaMask/connect-monorepo/compare/@metamask/connect-evm@0.10.0...@metamask/connect-evm@0.11.0
package/README.md CHANGED
@@ -247,10 +247,10 @@ Connects and immediately signs a message using `personal_sign`.
247
247
 
248
248
  **Returns**
249
249
 
250
- `Promise<string>` - The signature as a hex string.
250
+ `Promise<{ accounts: Address[]; chainId: Hex; signature: string }>` - The connected accounts, the active chain ID used for signing, and the resulting signature as a hex string.
251
251
 
252
252
  ```typescript
253
- const signature = await client.connectAndSign({
253
+ const { accounts, chainId, signature } = await client.connectAndSign({
254
254
  message: 'Sign this message',
255
255
  chainIds: ['0x1'],
256
256
  });
@@ -272,10 +272,10 @@ Connects and immediately invokes a method with specified parameters.
272
272
 
273
273
  **Returns**
274
274
 
275
- `Promise<unknown>` - The result of the method invocation.
275
+ `Promise<{ accounts: Address[]; chainId: Hex; result: unknown }>` - The connected accounts, the active chain ID used for the method call, and the result of the method invocation.
276
276
 
277
277
  ```typescript
278
- const result = await client.connectWith({
278
+ const { accounts, chainId, result } = await client.connectWith({
279
279
  method: 'eth_sendTransaction',
280
280
  params: (account) => [
281
281
  {
@@ -546,12 +546,12 @@ type EventHandlers = {
546
546
  connectAndSign: (result: {
547
547
  accounts: Address[];
548
548
  chainId: Hex;
549
- signResponse: string;
549
+ signature: string;
550
550
  }) => void;
551
551
  connectWith: (result: {
552
552
  accounts: Address[];
553
553
  chainId: Hex;
554
- connectWithResponse: unknown;
554
+ result: unknown;
555
555
  }) => void;
556
556
  };
557
557
  ```
@@ -88,7 +88,7 @@ import {
88
88
  isRejectionError,
89
89
  TransportType
90
90
  } from "@metamask/connect-multichain";
91
- import { createDeferredPromise, hexToNumber as hexToNumber3 } from "@metamask/utils";
91
+ import { hexToNumber as hexToNumber3 } from "@metamask/utils";
92
92
 
93
93
  // src/constants.ts
94
94
  var IGNORED_METHODS = [
@@ -354,7 +354,7 @@ ${invalidUrls.join("\n")}`
354
354
  // src/connect.ts
355
355
  var DEFAULT_CHAIN_ID = "0x1";
356
356
  var CHAIN_STORE_KEY = "cache_eth_chainId";
357
- var _core2, _provider, _sessionScopes, _eventHandlers, _sessionChangedHandler, _displayUriHandler, _removeNotificationHandler, _status, _pendingPreferredChainId, _initPromise, _MetamaskConnectEVM_instances, getCoreOptions_fn, createInvokeOptions_fn, trackWalletActionRequested_fn, trackWalletActionSucceeded_fn, trackWalletActionFailed_fn, getSelectedChainId_fn, requestInterceptor_fn, clearConnectionState_fn, addEthereumChain_fn, request_fn, cacheChainId_fn, onSessionChanged_fn, onChainChanged_fn, onAccountsChanged_fn, onConnect_fn, onDisconnect_fn, onDisplayUri_fn;
357
+ var _core2, _provider, _sessionScopes, _eventHandlers, _sessionChangedHandler, _displayUriHandler, _removeNotificationHandler, _status, _pendingPreferredChainId, _MetamaskConnectEVM_instances, getCoreOptions_fn, createInvokeOptions_fn, trackWalletActionRequested_fn, trackWalletActionSucceeded_fn, trackWalletActionFailed_fn, getSelectedChainId_fn, requestInterceptor_fn, clearConnectionState_fn, addEthereumChain_fn, request_fn, cacheChainId_fn, onSessionChanged_fn, onChainChanged_fn, onAccountsChanged_fn, onConnect_fn, onDisconnect_fn, onDisplayUri_fn;
358
358
  var _MetamaskConnectEVM = class _MetamaskConnectEVM {
359
359
  /**
360
360
  * Creates a new MetamaskConnectEVM instance.
@@ -389,8 +389,6 @@ var _MetamaskConnectEVM = class _MetamaskConnectEVM {
389
389
  * so that an explicit chainIds request always wins over a prior cached value.
390
390
  */
391
391
  __privateAdd(this, _pendingPreferredChainId);
392
- /** Deferred that resolves once #onSessionChanged has completed for the first time. */
393
- __privateAdd(this, _initPromise);
394
392
  __privateSet(this, _core2, core);
395
393
  __privateSet(this, _provider, new EIP1193Provider(
396
394
  core,
@@ -401,7 +399,6 @@ var _MetamaskConnectEVM = class _MetamaskConnectEVM {
401
399
  __privateGet(this, _core2).on("wallet_sessionChanged", __privateGet(this, _sessionChangedHandler));
402
400
  __privateSet(this, _displayUriHandler, __privateMethod(this, _MetamaskConnectEVM_instances, onDisplayUri_fn).bind(this));
403
401
  __privateGet(this, _core2).on("display_uri", __privateGet(this, _displayUriHandler));
404
- __privateSet(this, _initPromise, createDeferredPromise());
405
402
  logger("Connect/EVM constructor completed");
406
403
  }
407
404
  /**
@@ -417,9 +414,15 @@ var _MetamaskConnectEVM = class _MetamaskConnectEVM {
417
414
  */
418
415
  static create(options) {
419
416
  return __async(this, null, function* () {
417
+ var _a;
420
418
  const instance = new _MetamaskConnectEVM(options);
421
- yield __privateGet(instance, _core2).emitSessionChanged();
422
- yield __privateGet(instance, _initPromise).promise;
419
+ let session;
420
+ try {
421
+ session = yield __privateGet(instance, _core2).provider.getSession();
422
+ } catch (e) {
423
+ session = { sessionScopes: {} };
424
+ }
425
+ yield __privateMethod(_a = instance, _MetamaskConnectEVM_instances, onSessionChanged_fn).call(_a, session);
423
426
  return instance;
424
427
  });
425
428
  }
@@ -486,7 +489,7 @@ var _MetamaskConnectEVM = class _MetamaskConnectEVM {
486
489
  * @param options - The connection options
487
490
  * @param options.message - The message to sign after connecting
488
491
  * @param [options.chainIds] - Optional hex chain IDs to connect to (defaults to ethereum mainnet if not provided)
489
- * @returns A promise that resolves with the signature
492
+ * @returns A promise that resolves with the connected accounts, chainId, and signature
490
493
  * @throws Error if the selected account is not available after timeout
491
494
  */
492
495
  connectAndSign(_0) {
@@ -498,16 +501,16 @@ var _MetamaskConnectEVM = class _MetamaskConnectEVM {
498
501
  const { accounts, chainId } = yield this.connect({
499
502
  chainIds: chainIds != null ? chainIds : [DEFAULT_CHAIN_ID]
500
503
  });
501
- const result = yield __privateGet(this, _provider).request({
504
+ const signature = yield __privateGet(this, _provider).request({
502
505
  method: "personal_sign",
503
506
  params: [accounts[0], message]
504
507
  });
505
508
  (_b = (_a = __privateGet(this, _eventHandlers)) == null ? void 0 : _a.connectAndSign) == null ? void 0 : _b.call(_a, {
506
509
  accounts,
507
510
  chainId,
508
- signResponse: result
511
+ signature
509
512
  });
510
- return result;
513
+ return { accounts, chainId, signature };
511
514
  });
512
515
  }
513
516
  /**
@@ -519,7 +522,7 @@ var _MetamaskConnectEVM = class _MetamaskConnectEVM {
519
522
  * @param [options.chainIds] - Optional hex chain IDs to connect to (defaults to ethereum mainnet if not provided)
520
523
  * @param [options.account] - Optional specific account to connect to
521
524
  * @param [options.forceRequest] - Whether to force a request regardless of an existing session
522
- * @returns A promise that resolves with the result of the method invocation
525
+ * @returns A promise that resolves with the connected accounts, chainId, and the result of the method invocation
523
526
  * @throws Error if the selected account is not available after timeout (for methods that require an account)
524
527
  */
525
528
  connectWith(_0) {
@@ -544,9 +547,9 @@ var _MetamaskConnectEVM = class _MetamaskConnectEVM {
544
547
  (_b = (_a = __privateGet(this, _eventHandlers)) == null ? void 0 : _a.connectWith) == null ? void 0 : _b.call(_a, {
545
548
  accounts: connectedAccounts,
546
549
  chainId: connectedChainId,
547
- connectWithResponse: result
550
+ result
548
551
  });
549
- return result;
552
+ return { accounts: connectedAccounts, chainId: connectedChainId, result };
550
553
  });
551
554
  }
552
555
  /**
@@ -688,7 +691,6 @@ _displayUriHandler = new WeakMap();
688
691
  _removeNotificationHandler = new WeakMap();
689
692
  _status = new WeakMap();
690
693
  _pendingPreferredChainId = new WeakMap();
691
- _initPromise = new WeakMap();
692
694
  _MetamaskConnectEVM_instances = new WeakSet();
693
695
  /**
694
696
  * Gets the core options for analytics checks.
@@ -927,7 +929,6 @@ onSessionChanged_fn = function(session) {
927
929
  accounts: initialAccounts
928
930
  });
929
931
  }
930
- __privateGet(this, _initPromise).resolve();
931
932
  });
932
933
  };
933
934
  /**
@@ -1075,7 +1076,7 @@ function createEVMClient(options) {
1075
1076
  versions: {
1076
1077
  // typeof guard needed: Metro (React Native) bundles TS source directly,
1077
1078
  // bypassing the tsup build that substitutes __PACKAGE_VERSION__.
1078
- "connect-evm": false ? "unknown" : "0.11.2"
1079
+ "connect-evm": false ? "unknown" : "1.1.0"
1079
1080
  }
1080
1081
  }));
1081
1082
  return MetamaskConnectEVM.create({
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/utils/infura.ts","../../../src/connect.ts","../../../src/constants.ts","../../../src/logger.ts","../../../src/provider.ts","../../../src/utils/caip.ts","../../../src/utils/type-guards.ts"],"sourcesContent":["import { getInfuraRpcUrls as getInfuraRpcUrlsMultichain } from '@metamask/connect-multichain';\nimport type { CaipChainId, Hex } from '@metamask/utils';\nimport {\n hexToNumber,\n KnownCaipNamespace,\n numberToHex,\n parseCaipChainId,\n} from '@metamask/utils';\n\n/**\n * Generates Infura RPC URLs for common EVM networks keyed by hex chain ID.\n *\n * @param options - The options for generating Infura RPC URLs\n * @param options.infuraApiKey - The Infura API key\n * @param options.chainIds - Optional hex chain IDs to filter the output\n * @returns A map of hex chain IDs to Infura RPC URLs\n */\nexport const getInfuraRpcUrls = ({\n infuraApiKey,\n chainIds,\n}: {\n infuraApiKey: string;\n chainIds?: Hex[];\n}): Record<Hex, string> => {\n const caipChainIds = chainIds?.map(\n (chainId) => `eip155:${hexToNumber(chainId)}` as CaipChainId,\n );\n\n const caipMap = getInfuraRpcUrlsMultichain({\n infuraApiKey,\n caipChainIds,\n });\n\n return Object.entries(caipMap).reduce<Record<Hex, string>>(\n (acc, [key, url]) => {\n const { namespace, reference } = parseCaipChainId(key as CaipChainId);\n if (namespace !== KnownCaipNamespace.Eip155) {\n return acc;\n }\n const chainId = numberToHex(parseInt(reference, 10));\n acc[chainId] = url as string;\n return acc;\n },\n {},\n );\n};\n","/* eslint-disable no-restricted-syntax -- Private class properties use established patterns */\n/* eslint-disable @typescript-eslint/naming-convention -- __PACKAGE_VERSION__ is an esbuild define convention */\nimport { analytics } from '@metamask/analytics';\nimport { parseScopeString } from '@metamask/chain-agnostic-permission';\nimport type {\n MultichainCore,\n MultichainOptions,\n Scope,\n SessionData,\n} from '@metamask/connect-multichain';\nimport {\n createMultichainClient,\n getWalletActionAnalyticsProperties,\n isRejectionError,\n TransportType,\n} from '@metamask/connect-multichain';\nimport { createDeferredPromise, hexToNumber } from '@metamask/utils';\nimport type { DeferredPromise } from '@metamask/utils';\n\nimport { IGNORED_METHODS } from './constants';\nimport { enableDebug, logger } from './logger';\nimport { EIP1193Provider } from './provider';\nimport type {\n AddEthereumChainParameter,\n Address,\n CaipAccountId,\n EventHandlers,\n Hex,\n MetamaskConnectEVMOptions,\n ProviderRequest,\n ProviderRequestInterceptor,\n} from './types';\nimport { getEthAccounts, getPermittedEthChainIds } from './utils/caip';\nimport {\n isAccountsRequest,\n isAddChainRequest,\n isChainIdRequest,\n isConnectRequest,\n isSwitchChainRequest,\n validSupportedChainsUrls,\n} from './utils/type-guards';\n\n// Value substitued by tsup at build time\ndeclare const __PACKAGE_VERSION__: string | undefined;\n\nconst DEFAULT_CHAIN_ID = '0x1';\nconst CHAIN_STORE_KEY = 'cache_eth_chainId';\n\n/** The options for the connect method */\ntype ConnectOptions = {\n /** The account to connect to */\n account?: string | undefined;\n /** Whether to force a request regardless of an existing session */\n forceRequest?: boolean;\n /** All available chain IDs in the dapp in hex format */\n chainIds?: Hex[];\n};\n\nexport type ConnectEvmStatus = 'disconnected' | 'connected' | 'connecting';\n\n/**\n * The MetamaskConnectEVM class provides an EIP-1193 compatible interface for connecting\n * to MetaMask and interacting with Ethereum Virtual Machine (EVM) networks.\n *\n * This class serves as a modern replacement for MetaMask SDK V1, offering enhanced\n * functionality and cross-platform compatibility. It wraps the Multichain SDK to provide\n * a simplified, EIP-1193 compliant API for dapp developers.\n *\n * Key features:\n * - EIP-1193 provider interface for seamless integration with existing dapp code\n * - Automatic session recovery when reloading or opening in new tabs\n * - Chain switching with automatic chain addition if not configured\n * - Event-driven architecture with support for connect, disconnect, accountsChanged, and chainChanged events\n * - Cross-platform support for browser extensions and mobile applications\n * - Built-in handling of common Ethereum methods (eth_accounts, wallet_switchEthereumChain, etc.)\n *\n * @example\n * ```typescript\n * const client = await createEVMClient({\n * dapp: { name: 'My DApp', url: 'https://mydapp.com' }\n * });\n *\n * const { accounts, chainId } = await client.connect({ chainIds: [1, 137] }); // Connect to Ethereum Mainnet, and Polygon\n *\n * const provider = client.getProvider();\n * const signedMessage = await provider.request({ method: 'personal_sign', params: ['0x0', accounts[0]] });\n * ```\n */\nexport class MetamaskConnectEVM {\n /** The core instance of the Multichain SDK */\n readonly #core: MultichainCore;\n\n /** An instance of the EIP-1193 provider interface */\n readonly #provider: EIP1193Provider;\n\n /** The session scopes currently permitted */\n #sessionScopes: SessionData['sessionScopes'] = {};\n\n /** Optional event handlers for the EIP-1193 provider events. */\n readonly #eventHandlers?: Partial<EventHandlers> | undefined;\n\n /** The handler for the wallet_sessionChanged event */\n readonly #sessionChangedHandler: (session?: SessionData) => void;\n\n /** The handler for the display_uri event */\n readonly #displayUriHandler: (uri: string) => void;\n\n /** The clean-up function for the notification handler */\n #removeNotificationHandler?: () => void;\n\n /** The current connection status */\n #status: ConnectEvmStatus = 'disconnected';\n\n /**\n * The preferred chain ID to use for the active connect() call.\n * Set to the first explicit chainId passed by the caller, cleared once the\n * connect event resolves. Takes priority over the cache in #getSelectedChainId\n * so that an explicit chainIds request always wins over a prior cached value.\n */\n #pendingPreferredChainId: Hex | undefined;\n\n /** Deferred that resolves once #onSessionChanged has completed for the first time. */\n readonly #initPromise: DeferredPromise;\n\n /**\n * Creates a new MetamaskConnectEVM instance.\n * Use the static `create()` method instead to ensure proper async initialization.\n *\n * @param options - The options for the MetamaskConnectEVM instance\n * @param options.core - The core instance of the Multichain SDK\n * @param options.eventHandlers - Optional event handlers for EIP-1193 provider events\n */\n private constructor({ core, eventHandlers }: MetamaskConnectEVMOptions) {\n this.#core = core;\n\n this.#provider = new EIP1193Provider(\n core,\n this.#requestInterceptor.bind(this),\n );\n\n this.#eventHandlers = eventHandlers;\n\n /**\n * Handles the wallet_sessionChanged event.\n * Updates the internal connection state with the new session data.\n *\n * @param session - The session data\n */\n // eslint-disable-next-line @typescript-eslint/no-misused-promises\n this.#sessionChangedHandler = this.#onSessionChanged.bind(this);\n this.#core.on('wallet_sessionChanged', this.#sessionChangedHandler);\n\n /**\n * Handles the display_uri event.\n * Forwards the QR code URI to the provider for custom UI implementations.\n */\n this.#displayUriHandler = this.#onDisplayUri.bind(this);\n this.#core.on('display_uri', this.#displayUriHandler);\n\n this.#initPromise = createDeferredPromise();\n\n logger('Connect/EVM constructor completed');\n }\n\n /**\n * Creates a fully initialized MetamaskConnectEVM instance.\n * This is the recommended way to instantiate the class, as it ensures\n * all async initialization (like session recovery) completes before\n * the instance is returned.\n *\n * @param options - The options for the MetamaskConnectEVM instance\n * @param options.core - The core instance of the Multichain SDK\n * @param options.eventHandlers - Optional event handlers for EIP-1193 provider events\n * @returns A promise that resolves with a fully initialized MetamaskConnectEVM instance\n */\n static async create(\n options: MetamaskConnectEVMOptions,\n ): Promise<MetamaskConnectEVM> {\n const instance = new MetamaskConnectEVM(options);\n await instance.#core.emitSessionChanged();\n await instance.#initPromise.promise;\n return instance;\n }\n\n /**\n * Gets the core options for analytics checks.\n *\n * @returns The multichain options from the core instance\n */\n #getCoreOptions(): MultichainOptions {\n return (this.#core as any).options as MultichainOptions;\n }\n\n /**\n * Creates invoke options for analytics tracking.\n *\n * @param method - The RPC method name\n * @param scope - The CAIP chain ID scope\n * @param params - The method parameters\n * @returns Invoke options object for analytics\n */\n #createInvokeOptions(\n method: string,\n scope: Scope,\n params: unknown[],\n ): {\n scope: Scope;\n request: { method: string; params: unknown[] };\n } {\n return {\n scope,\n request: { method, params },\n };\n }\n\n /**\n * Tracks a wallet action requested event.\n *\n * @param method - The RPC method name\n * @param scope - The CAIP chain ID scope\n * @param params - The method parameters\n */\n async #trackWalletActionRequested(\n method: string,\n scope: Scope,\n params: unknown[],\n ): Promise<void> {\n const coreOptions = this.#getCoreOptions();\n try {\n const invokeOptions = this.#createInvokeOptions(method, scope, params);\n const props = await getWalletActionAnalyticsProperties(\n coreOptions,\n this.#core.storage,\n invokeOptions,\n this.#core.transportType,\n );\n analytics.track('mmconnect_wallet_action_requested', props);\n } catch (error) {\n logger('Error tracking mmconnect_wallet_action_requested event', error);\n }\n }\n\n /**\n * Tracks a wallet action succeeded event.\n *\n * @param method - The RPC method name\n * @param scope - The CAIP chain ID scope\n * @param params - The method parameters\n */\n async #trackWalletActionSucceeded(\n method: string,\n scope: Scope,\n params: unknown[],\n ): Promise<void> {\n const coreOptions = this.#getCoreOptions();\n try {\n const invokeOptions = this.#createInvokeOptions(method, scope, params);\n const props = await getWalletActionAnalyticsProperties(\n coreOptions,\n this.#core.storage,\n invokeOptions,\n this.#core.transportType,\n );\n analytics.track('mmconnect_wallet_action_succeeded', props);\n } catch (error) {\n logger('Error tracking mmconnect_wallet_action_succeeded event', error);\n }\n }\n\n /**\n * Tracks a wallet action failed or rejected event based on the error.\n *\n * @param method - The RPC method name\n * @param scope - The CAIP chain ID scope\n * @param params - The method parameters\n * @param error - The error that occurred\n */\n async #trackWalletActionFailed(\n method: string,\n scope: Scope,\n params: unknown[],\n error: unknown,\n ): Promise<void> {\n const coreOptions = this.#getCoreOptions();\n try {\n const invokeOptions = this.#createInvokeOptions(method, scope, params);\n const props = await getWalletActionAnalyticsProperties(\n coreOptions,\n this.#core.storage,\n invokeOptions,\n this.#core.transportType,\n );\n const isRejection = isRejectionError(error);\n if (isRejection) {\n analytics.track('mmconnect_wallet_action_rejected', props);\n } else {\n analytics.track('mmconnect_wallet_action_failed', props);\n }\n } catch {\n logger('Error tracking wallet action rejected or failed event', error);\n }\n }\n\n /**\n * Gets the currently selected chainId. Priority order:\n * - Explicit caller preference from an active connect() call, if permitted.\n * - Cached chainId from storage, if permitted.\n * - First permitted chain as a fallback.\n *\n * @param permittedChainIds - Array of permitted chain IDs in hex format\n * @returns The selected chainId (hex string)\n */\n async #getSelectedChainId(permittedChainIds: Hex[]): Promise<Hex> {\n // Honour an explicit caller preference set during an active connect() call\n if (\n this.#pendingPreferredChainId &&\n permittedChainIds.includes(this.#pendingPreferredChainId)\n ) {\n return this.#pendingPreferredChainId;\n }\n\n try {\n const cachedChainId =\n await this.#core.storage.adapter.get(CHAIN_STORE_KEY);\n if (cachedChainId) {\n const chainId: Hex = JSON.parse(cachedChainId);\n\n // Validate that the cached chainId is in the permitted chains list\n if (permittedChainIds.includes(chainId)) {\n return chainId;\n }\n }\n } catch (error) {\n logger('Error retrieving cached chainId', error);\n }\n\n // Fallback to the first permitted chain if cache retrieval failed or returned an invalid chain\n return permittedChainIds[0];\n }\n\n /**\n * Connects to the wallet with the specified chain ID and optional account.\n *\n * @param options - The connection options\n * @param [options.account] - Optional param to specify an account to connect to\n * @param [options.forceRequest] - Optional param to force a connection request regardless of whether there is a pre-existing session\n * @param [options.chainIds] - Array of chain IDs to request permission for (defaults to ethereum mainnet). The first entry is used as the active chain returned by the call. Ethereum mainnet is always included in the permission request as a bootstrap fallback.\n * @returns A promise that resolves with the connected accounts and chain ID\n */\n async connect({\n account,\n forceRequest,\n chainIds = [DEFAULT_CHAIN_ID],\n }: ConnectOptions = {}): Promise<{ accounts: Address[]; chainId: Hex }> {\n logger('request: connect', { account });\n\n if (!chainIds || chainIds.length === 0) {\n throw new Error('chainIds must be an array of at least one chain ID');\n }\n\n // The first explicitly-requested chain is preferred for chain selection.\n // DEFAULT_CHAIN_ID is still included in the permission request as a bootstrap\n // fallback, but it must not win over an explicit caller request.\n this.#pendingPreferredChainId = chainIds[0];\n\n const caipChainIds = Array.from(\n new Set(chainIds.concat(DEFAULT_CHAIN_ID) ?? [DEFAULT_CHAIN_ID]),\n ).map((id) => `eip155:${hexToNumber(id)}`);\n\n const caipAccountIds = account\n ? caipChainIds.map((caipChainId) => `${caipChainId}:${account}`)\n : [];\n\n this.#status = 'connecting';\n\n try {\n // Wait for the wallet_sessionChanged event to fire and set the provider properties\n const result = new Promise<{ accounts: Address[]; chainId: Hex }>(\n (resolve) => {\n this.#provider.once('connect', ({ chainId, accounts }) => {\n logger('fulfilled-request: connect', {\n chainId,\n accounts,\n });\n resolve({\n accounts,\n chainId,\n });\n });\n },\n );\n\n await this.#core.connect(\n caipChainIds as Scope[],\n caipAccountIds as CaipAccountId[],\n undefined,\n forceRequest,\n );\n\n // Await here so the finally block always runs after #onSessionChanged\n // has consumed #pendingPreferredChainId, not before.\n return await result;\n } catch (error) {\n this.#status = 'disconnected';\n logger('Error connecting to wallet', error);\n throw error;\n } finally {\n this.#pendingPreferredChainId = undefined;\n }\n }\n\n /**\n * Connects to the wallet and signs a message using personal_sign.\n *\n * @param options - The connection options\n * @param options.message - The message to sign after connecting\n * @param [options.chainIds] - Optional hex chain IDs to connect to (defaults to ethereum mainnet if not provided)\n * @returns A promise that resolves with the signature\n * @throws Error if the selected account is not available after timeout\n */\n async connectAndSign({\n message,\n chainIds,\n }: {\n message: string;\n chainIds?: Hex[];\n }): Promise<string> {\n const { accounts, chainId } = await this.connect({\n chainIds: chainIds ?? [DEFAULT_CHAIN_ID],\n });\n\n const result = (await this.#provider.request({\n method: 'personal_sign',\n params: [accounts[0], message],\n })) as string;\n\n this.#eventHandlers?.connectAndSign?.({\n accounts,\n chainId,\n signResponse: result,\n });\n\n return result;\n }\n\n /**\n * Connects to the wallet and invokes a method with specified parameters.\n *\n * @param options - The options for connecting and invoking the method\n * @param options.method - The method name to invoke\n * @param options.params - The parameters to pass to the method, or a function that receives the account and returns params\n * @param [options.chainIds] - Optional hex chain IDs to connect to (defaults to ethereum mainnet if not provided)\n * @param [options.account] - Optional specific account to connect to\n * @param [options.forceRequest] - Whether to force a request regardless of an existing session\n * @returns A promise that resolves with the result of the method invocation\n * @throws Error if the selected account is not available after timeout (for methods that require an account)\n */\n async connectWith({\n method,\n params,\n chainIds,\n account,\n forceRequest,\n }: {\n method: string;\n params: unknown[] | ((account: Address) => unknown[]);\n chainIds?: Hex[];\n account?: string | undefined;\n forceRequest?: boolean;\n }): Promise<unknown> {\n const { accounts: connectedAccounts, chainId: connectedChainId } =\n await this.connect({\n chainIds: chainIds ?? [DEFAULT_CHAIN_ID],\n account,\n forceRequest,\n });\n\n const resolvedParams =\n typeof params === 'function' ? params(connectedAccounts[0]) : params;\n\n const result = await this.#provider.request({\n method,\n params: resolvedParams,\n });\n\n this.#eventHandlers?.connectWith?.({\n accounts: connectedAccounts,\n chainId: connectedChainId,\n connectWithResponse: result,\n });\n\n return result;\n }\n\n /**\n * Disconnects from the wallet by revoking the session and cleaning up event listeners.\n *\n * @returns A promise that resolves when disconnection is complete\n */\n async disconnect(): Promise<void> {\n logger('request: disconnect');\n\n const sessionScopes = this.#sessionScopes;\n const eip155Scopes = Object.keys(sessionScopes).filter((scope) => {\n const { namespace } = parseScopeString(scope as Scope);\n return namespace === 'eip155';\n });\n\n await this.#core.disconnect(eip155Scopes as Scope[]);\n this.#onDisconnect();\n this.#clearConnectionState();\n\n // Note: We intentionally do NOT remove the display_uri and wallet_sessionChanged\n // listeners here. These are instance-scoped listeners that should remain active\n // for the lifetime of the SDK instance, allowing reconnection to work properly.\n // Session-scoped listeners (like the notification handler below) are removed.\n\n this.#removeNotificationHandler?.();\n this.#removeNotificationHandler = undefined;\n\n logger('fulfilled-request: disconnect');\n }\n\n /**\n * Switches the Ethereum chain. Will track state internally whenever possible.\n *\n * @param options - The options for the switch chain request\n * @param options.chainId - The chain ID to switch to\n * @param [options.chainConfiguration] - The chain configuration to use in case the chain is not present by the wallet\n * @returns A promise that resolves when the chain has been switched\n */\n async switchChain({\n chainId,\n chainConfiguration,\n }: {\n chainId: Hex;\n chainConfiguration?: AddEthereumChainParameter;\n }): Promise<void> {\n const method = 'wallet_switchEthereumChain';\n const scope: Scope = `eip155:${hexToNumber(chainId)}`;\n const params = [{ chainId }];\n\n // TODO (wenfix): better way to return here other than resolving.\n if (this.selectedChainId === chainId) {\n return Promise.resolve();\n }\n\n const permittedChainIds = getPermittedEthChainIds(this.#sessionScopes);\n\n if (\n permittedChainIds.includes(chainId) &&\n this.#core.transportType === TransportType.MWP\n ) {\n await this.#cacheChainId(chainId);\n this.#onChainChanged(chainId);\n return Promise.resolve();\n }\n\n await this.#trackWalletActionRequested(method, scope, params);\n\n try {\n const result = await this.#request({\n method: 'wallet_switchEthereumChain',\n params,\n });\n\n // When using the MWP transport, the error is returned instead of thrown,\n // so we force it into the catch block here.\n const resultWithError = result as { error?: { message: string } };\n if (resultWithError?.error) {\n throw new Error(resultWithError.error.message);\n }\n\n await this.#trackWalletActionSucceeded(method, scope, params);\n if ((result as { result: unknown }).result === null) {\n // result is successful we eagerly call onChainChanged to update the provider's selected chain ID.\n await this.#cacheChainId(chainId);\n this.#onChainChanged(chainId);\n }\n return Promise.resolve();\n } catch (error) {\n await this.#trackWalletActionFailed(method, scope, params, error);\n // Fallback to add the chain if its not configured in the wallet.\n if ((error as Error).message.includes('Unrecognized chain ID')) {\n return this.#addEthereumChain(chainConfiguration);\n }\n throw error;\n }\n }\n\n /**\n * Handles several EIP-1193 requests that require special handling\n * due the nature of the Multichain SDK.\n *\n * @param request - The request object containing the method and params\n * @returns The result of the request or undefined if the request is ignored\n */\n async #requestInterceptor(\n request: ProviderRequest,\n ): ReturnType<ProviderRequestInterceptor> {\n logger(`Intercepting request for method: ${request.method}`);\n\n if (IGNORED_METHODS.includes(request.method)) {\n // TODO: replace with correct method unsupported provider error\n return Promise.reject(\n new Error(\n `Method: ${request.method} is not supported by Metamask Connect/EVM`,\n ),\n );\n }\n\n if (request.method === 'wallet_revokePermissions') {\n return this.disconnect();\n }\n\n if (isConnectRequest(request)) {\n // When calling wallet_requestPermissions, we need to force a new session request to prompt\n // the user for accounts, because internally the Multichain SDK will check if\n // the user is already connected and skip the request if so, unless we\n // explicitly request a specific account. This is needed to workaround\n // wallet_requestPermissions not requesting specific accounts.\n const shouldForceConnectionRequest =\n request.method === 'wallet_requestPermissions';\n\n const { method, params } = request;\n const permitted = getPermittedEthChainIds(this.#sessionScopes);\n if (permitted.length === 0) {\n permitted.push(DEFAULT_CHAIN_ID);\n }\n\n const selected = this.#provider.selectedChainId;\n const preferred =\n selected && permitted.includes(selected) ? selected : permitted[0];\n\n const chainIds = [\n preferred,\n ...permitted.filter((id) => id !== preferred),\n ];\n\n const scope: Scope = `eip155:${hexToNumber(preferred)}`;\n\n await this.#trackWalletActionRequested(method, scope, params);\n\n try {\n const result = await this.connect({\n chainIds,\n forceRequest: shouldForceConnectionRequest,\n });\n await this.#trackWalletActionSucceeded(method, scope, params);\n return result;\n } catch (error) {\n await this.#trackWalletActionFailed(method, scope, params, error);\n throw error;\n }\n }\n\n if (isSwitchChainRequest(request)) {\n return this.switchChain({\n chainId: request.params[0].chainId as Hex,\n });\n }\n\n if (isAddChainRequest(request)) {\n return this.#addEthereumChain(request.params[0]);\n }\n\n if (isAccountsRequest(request)) {\n return this.#provider.accounts;\n }\n\n if (isChainIdRequest(request)) {\n return this.#provider.selectedChainId;\n }\n\n logger('Request not intercepted, forwarding to default handler', request);\n return Promise.resolve();\n }\n\n /**\n * Clears the internal connection state: accounts and chainId\n */\n #clearConnectionState(): void {\n this.#provider.accounts = [];\n this.#provider.selectedChainId = undefined;\n }\n\n /**\n * Adds an Ethereum chain using the latest chain configuration received from\n * a switchEthereumChain request\n *\n * @param chainConfiguration - The chain configuration to use in case the chain is not present by the wallet\n * @returns Nothing\n */\n async #addEthereumChain(\n chainConfiguration?: AddEthereumChainParameter,\n ): Promise<void> {\n logger('addEthereumChain called', { chainConfiguration });\n const method = 'wallet_addEthereumChain';\n\n if (!chainConfiguration) {\n throw new Error('No chain configuration found.');\n }\n\n // Get chain ID from config or use current chain\n const chainId =\n (chainConfiguration.chainId as Hex) ||\n this.#provider.selectedChainId ||\n '0x1';\n const decimalChainId = hexToNumber(chainId);\n const scope: Scope = `eip155:${decimalChainId}`;\n const params = [chainConfiguration];\n\n await this.#trackWalletActionRequested(method, scope, params);\n\n try {\n const result = await this.#request({\n method: 'wallet_addEthereumChain',\n params,\n });\n\n if ((result as { result: unknown }).result === null) {\n // if result is successful we eagerly call onChainChanged to update the provider's selected chain ID.\n await this.#cacheChainId(chainId);\n this.#onChainChanged(chainId);\n }\n await this.#trackWalletActionSucceeded(method, scope, params);\n } catch (error) {\n await this.#trackWalletActionFailed(method, scope, params, error);\n throw error;\n }\n }\n\n /**\n * Submits a request to the EIP-1193 provider\n *\n * @param request - The request object containing the method and params\n * @param request.method - The method to request\n * @param request.params - The parameters to pass to the method\n * @returns The result of the request\n */\n async #request(request: {\n method: string;\n params: unknown[];\n }): Promise<unknown> {\n logger('direct request to metamask-provider called', request);\n const result = this.#core.transport.sendEip1193Message(request);\n if (\n request.method === 'wallet_addEthereumChain' ||\n request.method === 'wallet_switchEthereumChain'\n ) {\n this.#core.openSimpleDeeplinkIfNeeded();\n }\n return result;\n }\n\n /**\n * Caches the chainId to storage for persistence across page refreshes.\n *\n * @param chainId - The hex chain ID\n */\n async #cacheChainId(chainId: Hex): Promise<void> {\n try {\n await this.#core.storage.adapter.set(\n CHAIN_STORE_KEY,\n JSON.stringify(chainId),\n );\n } catch (error) {\n logger('Error caching chainId', error);\n }\n }\n\n async #onSessionChanged(session?: SessionData): Promise<void> {\n logger('event: wallet_sessionChanged', session);\n this.#sessionScopes = session?.sessionScopes ?? {};\n const hexPermittedChainIds = getPermittedEthChainIds(this.#sessionScopes);\n if (hexPermittedChainIds.length === 0) {\n this.#onDisconnect();\n } else {\n let initialAccounts: Address[] = [];\n if (this.#core.status === 'connected') {\n const ethAccountsResponse =\n await this.#core.transport.sendEip1193Message({\n method: 'eth_accounts',\n params: [],\n });\n initialAccounts = ethAccountsResponse.result as Address[];\n } else {\n initialAccounts = getEthAccounts(this.#sessionScopes);\n }\n\n const chainId = await this.#getSelectedChainId(hexPermittedChainIds);\n\n this.#onConnect({\n chainId,\n accounts: initialAccounts,\n });\n }\n\n this.#initPromise.resolve();\n }\n\n /**\n * Handles chain change events and updates the provider's selected chain ID.\n *\n * @param chainId - The new hex chain ID\n */\n #onChainChanged(chainId: Hex): void {\n if (chainId === this.#provider.selectedChainId) {\n return;\n }\n logger('handler: chainChanged', { chainId });\n this.#provider.selectedChainId = chainId;\n this.#provider.emit('chainChanged', chainId);\n this.#eventHandlers?.chainChanged?.(chainId);\n }\n\n /**\n * Handles accounts change events and updates the provider's accounts list.\n *\n * @param accounts - The new list of permitted accounts\n */\n #onAccountsChanged(accounts: Address[]): void {\n const accountsUnchanged =\n accounts.length === this.#provider.accounts.length &&\n accounts.every((acct, idx) => acct === this.#provider.accounts[idx]);\n if (accountsUnchanged) {\n return;\n }\n logger('handler: accountsChanged', accounts);\n this.#provider.accounts = accounts;\n this.#provider.emit('accountsChanged', accounts);\n this.#eventHandlers?.accountsChanged?.(accounts);\n }\n\n /**\n * Handles connection events and emits the connect event to listeners.\n *\n * @param options - The connection options\n * @param options.chainId - The hex chain ID of the connection\n * @param options.accounts - The accounts of the connection\n */\n #onConnect({\n chainId,\n accounts,\n }: {\n chainId: Hex;\n accounts: Address[];\n }): void {\n logger('handler: connect', { chainId, accounts });\n const data = {\n chainId,\n accounts,\n };\n\n if (this.#status === 'connected') {\n this.#onChainChanged(chainId);\n this.#onAccountsChanged(accounts);\n return;\n }\n\n this.#provider.selectedChainId = chainId;\n this.#provider.accounts = accounts;\n\n this.#status = 'connected';\n this.#provider.emit('connect', data);\n this.#eventHandlers?.connect?.(data);\n\n this.#provider.emit('chainChanged', chainId);\n this.#eventHandlers?.chainChanged?.(chainId);\n\n this.#provider.emit('accountsChanged', accounts);\n this.#eventHandlers?.accountsChanged?.(accounts);\n\n this.#removeNotificationHandler?.();\n\n const onAccountsChanged = (accs: string[]): void => {\n logger('core-event: accountsChanged', accs);\n this.#onAccountsChanged(accs as Address[]);\n };\n\n const onChainChanged = (chainChanged: { chainId: string }): void => {\n logger('core-event: chainChanged', chainChanged.chainId);\n this.#cacheChainId(chainChanged.chainId as Hex).catch((error) => {\n logger('Error caching chainId in notification handler', error);\n });\n this.#onChainChanged(chainChanged.chainId as Hex);\n };\n\n this.#core.on('metamask_accountsChanged', onAccountsChanged);\n this.#core.on('metamask_chainChanged', onChainChanged);\n\n this.#removeNotificationHandler = (): void => {\n this.#core.off('metamask_accountsChanged', onAccountsChanged);\n this.#core.off('metamask_chainChanged', onChainChanged);\n };\n }\n\n /**\n * Handles disconnection events and emits the disconnect event to listeners.\n * Also clears accounts by triggering an accountsChanged event with an empty array.\n */\n #onDisconnect(): void {\n if (this.#status === 'disconnected') {\n return;\n }\n this.#status = 'disconnected';\n\n logger('handler: disconnect');\n this.#provider.emit('disconnect');\n this.#eventHandlers?.disconnect?.();\n\n this.#onAccountsChanged([]);\n }\n\n /**\n * Handles display_uri events and emits them to the provider.\n * This allows consumers to display their own custom QR code UI.\n *\n * @param uri - The deeplink URI to be displayed as a QR code\n */\n #onDisplayUri(uri: string): void {\n if (this.#status !== 'connecting') {\n return;\n }\n\n logger('handler: display_uri', uri);\n this.#provider.emit('display_uri', uri);\n this.#eventHandlers?.displayUri?.(uri);\n }\n\n /**\n * Gets the EIP-1193 provider instance\n *\n * @returns The EIP-1193 provider instance\n */\n getProvider(): EIP1193Provider {\n return this.#provider;\n }\n\n /**\n * Gets the currently selected chain ID on the wallet\n *\n * @returns The currently selected chain ID or undefined if no chain is selected\n */\n getChainId(): Hex | undefined {\n return this.selectedChainId;\n }\n\n /**\n * Gets the currently selected account on the wallet\n *\n * @returns The currently selected account or undefined if no account is selected\n */\n getAccount(): Address | undefined {\n return this.#provider.selectedAccount;\n }\n\n // Convenience getters for the EIP-1193 provider\n /**\n * Gets the currently permitted accounts\n *\n * @returns The currently permitted accounts\n */\n get accounts(): Address[] {\n return this.#provider.accounts;\n }\n\n /**\n * Gets the currently selected account on the wallet\n *\n * @returns The currently selected account or undefined if no account is selected\n */\n get selectedAccount(): Address | undefined {\n return this.#provider.selectedAccount;\n }\n\n /**\n * Gets the currently selected chain ID on the wallet\n *\n * @returns The currently selected chain ID or undefined if no chain is selected\n */\n get selectedChainId(): Hex | undefined {\n return this.#provider.selectedChainId;\n }\n\n /**\n * Gets the current connection status\n *\n * @returns The current connection status\n */\n get status(): ConnectEvmStatus {\n return this.#status;\n }\n}\n\n/**\n * Creates a new Metamask Connect/EVM instance\n *\n * @param options - The options for the Metamask Connect/EVM layer\n * @param options.dapp - Dapp identification and branding settings\n * @param options.api - API configuration including read-only RPC map\n * @param options.api.supportedNetworks - A map of hex chain IDs to RPC URLs for read-only requests\n * @param [options.analytics.integrationType] - Integration type for analytics\n * @param [options.ui] - UI configuration options\n * @param [options.ui.headless] - Whether to run without UI\n * @param [options.ui.preferExtension] - Whether to prefer browser extension\n * @param [options.ui.showInstallModal] - Whether to render installation modal for desktop extension\n * @param [options.mobile] - Mobile configuration options\n * @param [options.mobile.preferredOpenLink] - Custom handler for opening deeplinks (useful for React Native, etc.)\n * @param [options.mobile.useDeeplink] - Whether to use native deeplinks instead of universal links\n * @param [options.transport] - Transport configuration (e.g., extensionId, notification handler)\n * @param [options.transport.extensionId] - Extension ID for browser extension transport\n * @param [options.transport.onNotification] - Callback for receiving transport notifications\n * @param [options.eventHandlers] - Event handlers for the Metamask Connect/EVM layer\n * @param [options.debug] - Enable debug logging\n * @returns The Metamask-Connect EVM client instance\n */\nexport async function createEVMClient(\n options: Pick<\n MultichainOptions,\n 'dapp' | 'mobile' | 'transport' | 'analytics'\n > & {\n ui?: Omit<MultichainOptions['ui'], 'factory'>;\n } & {\n eventHandlers?: Partial<EventHandlers>;\n debug?: boolean;\n api: {\n supportedNetworks: Record<Hex, string>;\n };\n },\n): Promise<MetamaskConnectEVM> {\n if (options.debug) {\n enableDebug();\n }\n\n logger('Creating Metamask Connect/EVM with options:', options);\n\n // Validate that supportedNetworks is provided and not empty\n if (\n !options.api?.supportedNetworks ||\n Object.keys(options.api.supportedNetworks).length === 0\n ) {\n throw new Error(\n 'supportedNetworks is required and must contain at least one chain configuration',\n );\n }\n\n validSupportedChainsUrls(options.api.supportedNetworks, 'supportedNetworks');\n\n const supportedNetworksCaipChainId = Object.entries(\n options.api.supportedNetworks,\n ).reduce<Record<string, string>>((acc, [hexChainId, url]) => {\n const decimalChainId = parseInt(hexChainId, 16);\n const caip2ChainId = `eip155:${decimalChainId}`;\n acc[caip2ChainId] = url;\n return acc;\n }, {});\n\n try {\n const core = await createMultichainClient({\n ...options,\n api: {\n supportedNetworks: supportedNetworksCaipChainId,\n },\n analytics: {\n // eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing\n integrationType: options.analytics?.integrationType || 'direct',\n },\n versions: {\n // typeof guard needed: Metro (React Native) bundles TS source directly,\n // bypassing the tsup build that substitutes __PACKAGE_VERSION__.\n 'connect-evm':\n typeof __PACKAGE_VERSION__ === 'undefined'\n ? 'unknown'\n : __PACKAGE_VERSION__,\n },\n });\n\n return MetamaskConnectEVM.create({\n core,\n eventHandlers: options.eventHandlers,\n supportedNetworks: options.api.supportedNetworks,\n });\n } catch (error) {\n console.error('Error creating Metamask Connect/EVM', error);\n throw error;\n }\n}\n","export const IGNORED_METHODS = [\n 'metamask_getProviderState',\n 'metamask_sendDomainMetadata',\n 'metamask_logWeb3ShimUsage',\n 'wallet_registerOnboarding',\n 'net_version',\n 'wallet_getPermissions',\n];\n\nexport const CONNECT_METHODS = [\n 'wallet_requestPermissions',\n 'eth_requestAccounts',\n];\n\nexport const ACCOUNTS_METHODS = ['eth_accounts', 'eth_coinbase'];\n\nexport const CHAIN_METHODS = ['eth_chainId'];\n\nexport const INTERCEPTABLE_METHODS = [\n ...ACCOUNTS_METHODS,\n ...IGNORED_METHODS,\n ...CONNECT_METHODS,\n ...CHAIN_METHODS,\n // These have bespoke handlers\n 'wallet_revokePermissions',\n 'wallet_switchEthereumChain',\n 'wallet_addEthereumChain',\n];\n","import {\n createLogger,\n enableDebug as debug,\n} from '@metamask/connect-multichain';\n\nconst namespace = 'metamask-connect:evm';\n\n// @ts-expect-error logger needs to be typed properly\nexport const logger = createLogger(namespace, '63');\n\nexport const enableDebug = (): void => {\n // @ts-expect-error logger needs to be typed properly\n debug(namespace);\n};\n","/* eslint-disable promise/always-return -- Legacy callback patterns */\n/* eslint-disable promise/no-callback-in-promise -- Legacy sendAsync/send API */\n/* eslint-disable consistent-return -- Legacy method returns void or Promise */\n/* eslint-disable @typescript-eslint/no-floating-promises -- Legacy fire-and-forget pattern */\n/* eslint-disable jsdoc/require-returns -- Inherited from abstract class */\nimport type { MultichainCore, Scope } from '@metamask/connect-multichain';\nimport { EventEmitter, RPCInvokeMethodErr } from '@metamask/connect-multichain';\nimport { hexToNumber } from '@metamask/utils';\n\nimport { INTERCEPTABLE_METHODS } from './constants';\nimport { logger } from './logger';\nimport type {\n Address,\n EIP1193ProviderEvents,\n Hex,\n JsonRpcCallback,\n JsonRpcRequest,\n JsonRpcResponse,\n ProviderRequest,\n ProviderRequestInterceptor,\n} from './types';\n\n/**\n * EIP-1193 Provider wrapper around the Multichain SDK.\n */\nexport class EIP1193Provider extends EventEmitter<EIP1193ProviderEvents> {\n /** The core instance of the Multichain SDK */\n readonly #core: MultichainCore;\n\n /** Interceptor function to handle specific methods */\n readonly #requestInterceptor: ProviderRequestInterceptor;\n\n /** The currently permitted accounts */\n #accounts: Address[] = [];\n\n /** The currently selected chain ID on the wallet */\n #selectedChainId?: Hex | undefined;\n\n constructor(core: MultichainCore, interceptor: ProviderRequestInterceptor) {\n super();\n this.#core = core;\n this.#requestInterceptor = interceptor;\n\n // Bind all public methods to ensure `this` context is preserved\n // when methods are extracted or passed as callbacks.\n // This eliminates the need for Proxy wrappers in consumers.\n this.request = this.request.bind(this);\n this.sendAsync = this.sendAsync.bind(this);\n this.send = this.send.bind(this);\n\n // Bind inherited EventEmitter methods\n this.on = this.on.bind(this);\n this.off = this.off.bind(this);\n this.emit = this.emit.bind(this);\n this.once = this.once.bind(this);\n this.removeListener = this.removeListener.bind(this);\n this.listenerCount = this.listenerCount.bind(this);\n }\n\n /**\n * Performs a EIP-1193 request.\n *\n * @param request - The request object containing the method and params\n * @returns The result of the request\n */\n async request(request: ProviderRequest): Promise<unknown> {\n logger(\n `request: ${request.method} - chainId: ${this.selectedChainId}`,\n request.params,\n );\n /* Some methods require special handling, so we intercept them here\n * and handle them in MetamaskConnectEVM.requestInterceptor method. */\n if (INTERCEPTABLE_METHODS.includes(request.method)) {\n return this.#requestInterceptor?.(request);\n }\n\n if (!this.#selectedChainId) {\n // TODO: replace with a better error\n throw new Error('No chain ID selected');\n }\n\n const decimalChainId = hexToNumber(this.#selectedChainId);\n const scope: Scope = `eip155:${decimalChainId}`;\n\n // Validate that the chain is configured in supportedNetworks\n // This check is performed here to provide better error messages\n // The RpcClient will also validate, but this gives us a chance to provide\n // a clearer error message before the request is routed\n const coreOptions = (this.#core as any).options; // TODO: options is `protected readonly` property, this needs to be refactored so `any` type assertion is not necessary\n const supportedNetworks = coreOptions?.api?.supportedNetworks ?? {};\n if (!supportedNetworks[scope]) {\n throw new Error(\n `Chain ${scope} is not configured in supportedNetworks. Requests cannot be made to chains not explicitly configured in supportedNetworks.`,\n );\n }\n\n try {\n return await this.#core.invokeMethod({\n scope,\n request: {\n method: request.method,\n params: request.params,\n },\n });\n } catch (error) {\n if (error instanceof RPCInvokeMethodErr && error.rpcCode !== undefined) {\n const rpcError = new Error(\n error.rpcMessage ?? error.reason,\n ) as Error & { code: number };\n rpcError.code = error.rpcCode;\n throw rpcError;\n }\n throw error;\n }\n }\n\n // Getters and setters\n public get selectedAccount(): Address | undefined {\n return this.accounts[0];\n }\n\n public set accounts(accounts: Address[]) {\n this.#accounts = accounts;\n }\n\n public get accounts(): Address[] {\n return this.#accounts;\n }\n\n public get selectedChainId(): Hex | undefined {\n return this.#selectedChainId;\n }\n\n public set selectedChainId(chainId: Hex | undefined) {\n this.#selectedChainId = chainId;\n }\n\n // ==========================================\n // Legacy compatibility methods\n // ==========================================\n\n /**\n * Alias for selectedChainId for legacy compatibility.\n * Many dApps expect a `chainId` property on the provider.\n */\n public get chainId(): Hex | undefined {\n return this.selectedChainId;\n }\n\n /**\n * Legacy method for sending JSON-RPC requests.\n *\n * @deprecated Use `request` instead. This method is provided for backwards compatibility.\n * @param request - The JSON-RPC request object\n * @param callback - Optional callback function. If provided, the method returns void.\n * @returns A promise resolving to the JSON-RPC response, or void if a callback is provided.\n */\n async sendAsync<TParams = unknown, TResult = unknown>(\n request: JsonRpcRequest<TParams>,\n callback?: JsonRpcCallback<TResult>,\n ): Promise<JsonRpcResponse<TResult> | void> {\n const id = request.id ?? 1;\n\n const promise = this.request({\n method: request.method,\n params: request.params as unknown,\n })\n .then(\n (result): JsonRpcResponse<TResult> => ({\n id,\n jsonrpc: '2.0',\n result: result as TResult,\n }),\n )\n .catch(\n (error): JsonRpcResponse<TResult> => ({\n id,\n jsonrpc: '2.0',\n error: {\n code: error.code ?? -32603,\n message: error.message ?? 'Internal error',\n data: error.data,\n },\n }),\n );\n\n if (callback) {\n promise\n .then((response) => {\n if (response.error) {\n callback(new Error(response.error.message), response);\n } else {\n callback(null, response);\n }\n })\n .catch((error) => {\n callback(error, null);\n });\n return;\n }\n\n return promise;\n }\n\n /**\n * Legacy method for sending JSON-RPC requests synchronously (callback-based).\n *\n * @deprecated Use `request` instead. This method is provided for backwards compatibility.\n * @param request - The JSON-RPC request object\n * @param callback - The callback function to receive the response\n */\n send<TParams = unknown, TResult = unknown>(\n request: JsonRpcRequest<TParams>,\n callback: JsonRpcCallback<TResult>,\n ): void {\n this.sendAsync(request, callback);\n }\n}\n","import type { InternalScopesObject } from '@metamask/chain-agnostic-permission';\nimport {\n getPermittedEthChainIds as _getPermittedEthChainIds,\n getEthAccounts as _getEthAccounts,\n} from '@metamask/chain-agnostic-permission';\nimport type { SessionData } from '@metamask/connect-multichain';\n\nimport type { Address, Hex } from '../types';\n\n/**\n * Get the Ethereum accounts from the session data\n *\n * @param sessionScopes - The session scopes\n * @returns The Ethereum accounts\n */\nexport const getEthAccounts = (\n sessionScopes: SessionData['sessionScopes'] | undefined,\n): Address[] => {\n if (!sessionScopes) {\n return [];\n }\n\n return _getEthAccounts({\n requiredScopes: sessionScopes as InternalScopesObject,\n optionalScopes: sessionScopes as InternalScopesObject,\n });\n};\n\n/**\n * Get the permitted Ethereum chain IDs from the session scopes.\n * Wrapper around getPermittedEthChainIds from @metamask/chain-agnostic-permission\n *\n * @param sessionScopes - The session scopes\n * @returns The permitted Ethereum chain IDs\n */\nexport const getPermittedEthChainIds = (\n sessionScopes: SessionData['sessionScopes'] | undefined,\n): Hex[] => {\n if (!sessionScopes) {\n return [];\n }\n\n return _getPermittedEthChainIds({\n requiredScopes: sessionScopes as InternalScopesObject,\n optionalScopes: sessionScopes as InternalScopesObject,\n });\n};\n","import type { ProviderRequest } from '../types';\n\n/**\n * Type guard for connect-like requests:\n * - wallet_requestPermissions\n * - eth_requestAccounts\n *\n * @param req - The request object to check\n * @returns True if the request is a connect-like request, false otherwise\n */\nexport function isConnectRequest(req: ProviderRequest): req is Extract<\n ProviderRequest,\n {\n method: 'wallet_requestPermissions' | 'eth_requestAccounts';\n }\n> {\n return (\n req.method === 'wallet_requestPermissions' ||\n req.method === 'eth_requestAccounts'\n );\n}\n\n/**\n * Type guard for wallet_switchEthereumChain request.\n *\n * @param req - The request object to check\n * @returns True if the request is a wallet_switchEthereumChain request, false otherwise\n */\nexport function isSwitchChainRequest(\n req: ProviderRequest,\n): req is Extract<ProviderRequest, { method: 'wallet_switchEthereumChain' }> {\n return req.method === 'wallet_switchEthereumChain';\n}\n\n/**\n * Type guard for wallet_addEthereumChain request.\n *\n * @param req - The request object to check\n * @returns True if the request is a wallet_addEthereumChain request, false otherwise\n */\nexport function isAddChainRequest(\n req: ProviderRequest,\n): req is Extract<ProviderRequest, { method: 'wallet_addEthereumChain' }> {\n return req.method === 'wallet_addEthereumChain';\n}\n\n/**\n * Type guard for generic accounts request:\n * - eth_accounts\n * - eth_coinbase\n *\n * @param req - The request object to check\n * @returns True if the request is a generic accounts request, false otherwise\n */\nexport function isAccountsRequest(\n req: ProviderRequest,\n): req is Extract<\n ProviderRequest,\n { method: 'eth_accounts' | 'eth_coinbase' }\n> {\n return req.method === 'eth_accounts' || req.method === 'eth_coinbase';\n}\n\n/**\n * Type guard for generic eth_chainId request.\n *\n * @param req - The request object to check\n * @returns True if the request is a eth_chainId request, false otherwise\n */\nexport function isChainIdRequest(\n req: ProviderRequest,\n): req is Extract<ProviderRequest, { method: 'eth_chainId' }> {\n return req.method === 'eth_chainId';\n}\n\n/**\n * Validates that all values in a Record are valid URLs.\n *\n * @param record - The record to validate (e.g., supportedNetworks)\n * @param recordName - The name of the record for error messages\n * @throws Error if any values are invalid URLs\n */\nexport function validSupportedChainsUrls(\n record: Record<string, string>,\n recordName: string,\n): void {\n const invalidUrls: string[] = [];\n for (const [key, url] of Object.entries(record)) {\n try {\n // eslint-disable-next-line no-new\n new URL(url);\n } catch {\n invalidUrls.push(`${key}: ${url}`);\n }\n }\n\n if (invalidUrls.length > 0) {\n throw new Error(\n `${recordName} contains invalid URLs:\\n${invalidUrls.join('\\n')}`,\n );\n }\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,SAAS,oBAAoB,kCAAkC;AAE/D;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AAUA,IAAM,mBAAmB,CAAC;AAAA,EAC/B;AAAA,EACA;AACF,MAG2B;AACzB,QAAM,eAAe,qCAAU;AAAA,IAC7B,CAAC,YAAY,UAAU,YAAY,OAAO,CAAC;AAAA;AAG7C,QAAM,UAAU,2BAA2B;AAAA,IACzC;AAAA,IACA;AAAA,EACF,CAAC;AAED,SAAO,OAAO,QAAQ,OAAO,EAAE;AAAA,IAC7B,CAAC,KAAK,CAAC,KAAK,GAAG,MAAM;AACnB,YAAM,EAAE,WAAAA,YAAW,UAAU,IAAI,iBAAiB,GAAkB;AACpE,UAAIA,eAAc,mBAAmB,QAAQ;AAC3C,eAAO;AAAA,MACT;AACA,YAAM,UAAU,YAAY,SAAS,WAAW,EAAE,CAAC;AACnD,UAAI,OAAO,IAAI;AACf,aAAO;AAAA,IACT;AAAA,IACA,CAAC;AAAA,EACH;AACF;;;AC3CA,SAAS,iBAAiB;AAC1B,SAAS,wBAAwB;AAOjC;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AACP,SAAS,uBAAuB,eAAAC,oBAAmB;;;AChB5C,IAAM,kBAAkB;AAAA,EAC7B;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AACF;AAEO,IAAM,kBAAkB;AAAA,EAC7B;AAAA,EACA;AACF;AAEO,IAAM,mBAAmB,CAAC,gBAAgB,cAAc;AAExD,IAAM,gBAAgB,CAAC,aAAa;AAEpC,IAAM,wBAAwB;AAAA,EACnC,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AAAA,EACH,GAAG;AAAA;AAAA,EAEH;AAAA,EACA;AAAA,EACA;AACF;;;AC3BA;AAAA,EACE;AAAA,EACA,eAAe;AAAA,OACV;AAEP,IAAM,YAAY;AAGX,IAAM,SAAS,aAAa,WAAW,IAAI;AAE3C,IAAM,cAAc,MAAY;AAErC,QAAM,SAAS;AACjB;;;ACPA,SAAS,cAAc,0BAA0B;AACjD,SAAS,eAAAC,oBAAmB;AAP5B;AAyBO,IAAM,kBAAN,cAA8B,aAAoC;AAAA,EAavE,YAAY,MAAsB,aAAyC;AACzE,UAAM;AAZR;AAAA,uBAAS;AAGT;AAAA,uBAAS;AAGT;AAAA,kCAAuB,CAAC;AAGxB;AAAA;AAIE,uBAAK,OAAQ;AACb,uBAAK,qBAAsB;AAK3B,SAAK,UAAU,KAAK,QAAQ,KAAK,IAAI;AACrC,SAAK,YAAY,KAAK,UAAU,KAAK,IAAI;AACzC,SAAK,OAAO,KAAK,KAAK,KAAK,IAAI;AAG/B,SAAK,KAAK,KAAK,GAAG,KAAK,IAAI;AAC3B,SAAK,MAAM,KAAK,IAAI,KAAK,IAAI;AAC7B,SAAK,OAAO,KAAK,KAAK,KAAK,IAAI;AAC/B,SAAK,OAAO,KAAK,KAAK,KAAK,IAAI;AAC/B,SAAK,iBAAiB,KAAK,eAAe,KAAK,IAAI;AACnD,SAAK,gBAAgB,KAAK,cAAc,KAAK,IAAI;AAAA,EACnD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQM,QAAQ,SAA4C;AAAA;AAjE5D;AAkEI;AAAA,QACE,YAAY,QAAQ,MAAM,eAAe,KAAK,eAAe;AAAA,QAC7D,QAAQ;AAAA,MACV;AAGA,UAAI,sBAAsB,SAAS,QAAQ,MAAM,GAAG;AAClD,gBAAO,wBAAK,yBAAL,8BAA2B;AAAA,MACpC;AAEA,UAAI,CAAC,mBAAK,mBAAkB;AAE1B,cAAM,IAAI,MAAM,sBAAsB;AAAA,MACxC;AAEA,YAAM,iBAAiBC,aAAY,mBAAK,iBAAgB;AACxD,YAAM,QAAe,UAAU,cAAc;AAM7C,YAAM,cAAe,mBAAK,OAAc;AACxC,YAAM,qBAAoB,sDAAa,QAAb,mBAAkB,sBAAlB,YAAuC,CAAC;AAClE,UAAI,CAAC,kBAAkB,KAAK,GAAG;AAC7B,cAAM,IAAI;AAAA,UACR,SAAS,KAAK;AAAA,QAChB;AAAA,MACF;AAEA,UAAI;AACF,eAAO,MAAM,mBAAK,OAAM,aAAa;AAAA,UACnC;AAAA,UACA,SAAS;AAAA,YACP,QAAQ,QAAQ;AAAA,YAChB,QAAQ,QAAQ;AAAA,UAClB;AAAA,QACF,CAAC;AAAA,MACH,SAAS,OAAO;AACd,YAAI,iBAAiB,sBAAsB,MAAM,YAAY,QAAW;AACtE,gBAAM,WAAW,IAAI;AAAA,aACnB,WAAM,eAAN,YAAoB,MAAM;AAAA,UAC5B;AACA,mBAAS,OAAO,MAAM;AACtB,gBAAM;AAAA,QACR;AACA,cAAM;AAAA,MACR;AAAA,IACF;AAAA;AAAA;AAAA,EAGA,IAAW,kBAAuC;AAChD,WAAO,KAAK,SAAS,CAAC;AAAA,EACxB;AAAA,EAEA,IAAW,SAAS,UAAqB;AACvC,uBAAK,WAAY;AAAA,EACnB;AAAA,EAEA,IAAW,WAAsB;AAC/B,WAAO,mBAAK;AAAA,EACd;AAAA,EAEA,IAAW,kBAAmC;AAC5C,WAAO,mBAAK;AAAA,EACd;AAAA,EAEA,IAAW,gBAAgB,SAA0B;AACnD,uBAAK,kBAAmB;AAAA,EAC1B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUA,IAAW,UAA2B;AACpC,WAAO,KAAK;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUM,UACJ,SACA,UAC0C;AAAA;AAhK9C;AAiKI,YAAM,MAAK,aAAQ,OAAR,YAAc;AAEzB,YAAM,UAAU,KAAK,QAAQ;AAAA,QAC3B,QAAQ,QAAQ;AAAA,QAChB,QAAQ,QAAQ;AAAA,MAClB,CAAC,EACE;AAAA,QACC,CAAC,YAAsC;AAAA,UACrC;AAAA,UACA,SAAS;AAAA,UACT;AAAA,QACF;AAAA,MACF,EACC;AAAA,QACC,CAAC,UAAiC;AA/K1C,cAAAC,KAAA;AA+K8C;AAAA,YACpC;AAAA,YACA,SAAS;AAAA,YACT,OAAO;AAAA,cACL,OAAMA,MAAA,MAAM,SAAN,OAAAA,MAAc;AAAA,cACpB,UAAS,WAAM,YAAN,YAAiB;AAAA,cAC1B,MAAM,MAAM;AAAA,YACd;AAAA,UACF;AAAA;AAAA,MACF;AAEF,UAAI,UAAU;AACZ,gBACG,KAAK,CAAC,aAAa;AAClB,cAAI,SAAS,OAAO;AAClB,qBAAS,IAAI,MAAM,SAAS,MAAM,OAAO,GAAG,QAAQ;AAAA,UACtD,OAAO;AACL,qBAAS,MAAM,QAAQ;AAAA,UACzB;AAAA,QACF,CAAC,EACA,MAAM,CAAC,UAAU;AAChB,mBAAS,OAAO,IAAI;AAAA,QACtB,CAAC;AACH;AAAA,MACF;AAEA,aAAO;AAAA,IACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EASA,KACE,SACA,UACM;AACN,SAAK,UAAU,SAAS,QAAQ;AAAA,EAClC;AACF;AA9LW;AAGA;AAGT;AAGA;;;ACnCF;AAAA,EACE,2BAA2B;AAAA,EAC3B,kBAAkB;AAAA,OACb;AAWA,IAAM,iBAAiB,CAC5B,kBACc;AACd,MAAI,CAAC,eAAe;AAClB,WAAO,CAAC;AAAA,EACV;AAEA,SAAO,gBAAgB;AAAA,IACrB,gBAAgB;AAAA,IAChB,gBAAgB;AAAA,EAClB,CAAC;AACH;AASO,IAAM,0BAA0B,CACrC,kBACU;AACV,MAAI,CAAC,eAAe;AAClB,WAAO,CAAC;AAAA,EACV;AAEA,SAAO,yBAAyB;AAAA,IAC9B,gBAAgB;AAAA,IAChB,gBAAgB;AAAA,EAClB,CAAC;AACH;;;ACpCO,SAAS,iBAAiB,KAK/B;AACA,SACE,IAAI,WAAW,+BACf,IAAI,WAAW;AAEnB;AAQO,SAAS,qBACd,KAC2E;AAC3E,SAAO,IAAI,WAAW;AACxB;AAQO,SAAS,kBACd,KACwE;AACxE,SAAO,IAAI,WAAW;AACxB;AAUO,SAAS,kBACd,KAIA;AACA,SAAO,IAAI,WAAW,kBAAkB,IAAI,WAAW;AACzD;AAQO,SAAS,iBACd,KAC4D;AAC5D,SAAO,IAAI,WAAW;AACxB;AASO,SAAS,yBACd,QACA,YACM;AACN,QAAM,cAAwB,CAAC;AAC/B,aAAW,CAAC,KAAK,GAAG,KAAK,OAAO,QAAQ,MAAM,GAAG;AAC/C,QAAI;AAEF,UAAI,IAAI,GAAG;AAAA,IACb,SAAQ;AACN,kBAAY,KAAK,GAAG,GAAG,KAAK,GAAG,EAAE;AAAA,IACnC;AAAA,EACF;AAEA,MAAI,YAAY,SAAS,GAAG;AAC1B,UAAM,IAAI;AAAA,MACR,GAAG,UAAU;AAAA,EAA4B,YAAY,KAAK,IAAI,CAAC;AAAA,IACjE;AAAA,EACF;AACF;;;ALxDA,IAAM,mBAAmB;AACzB,IAAM,kBAAkB;AA9CxB,IAAAC,QAAA;AAwFO,IAAM,sBAAN,MAAM,oBAAmB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EA4CtB,YAAY,EAAE,MAAM,cAAc,GAA8B;AA5CnE;AAEL;AAAA,uBAASA;AAGT;AAAA,uBAAS;AAGT;AAAA,uCAA+C,CAAC;AAGhD;AAAA,uBAAS;AAGT;AAAA,uBAAS;AAGT;AAAA,uBAAS;AAGT;AAAA;AAGA;AAAA,gCAA4B;AAQ5B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAGA;AAAA,uBAAS;AAWP,uBAAKA,QAAQ;AAEb,uBAAK,WAAY,IAAI;AAAA,MACnB;AAAA,MACA,sBAAK,sDAAoB,KAAK,IAAI;AAAA,IACpC;AAEA,uBAAK,gBAAiB;AAStB,uBAAK,wBAAyB,sBAAK,oDAAkB,KAAK,IAAI;AAC9D,uBAAKA,QAAM,GAAG,yBAAyB,mBAAK,uBAAsB;AAMlE,uBAAK,oBAAqB,sBAAK,gDAAc,KAAK,IAAI;AACtD,uBAAKA,QAAM,GAAG,eAAe,mBAAK,mBAAkB;AAEpD,uBAAK,cAAe,sBAAsB;AAE1C,WAAO,mCAAmC;AAAA,EAC5C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAaA,OAAa,OACX,SAC6B;AAAA;AAC7B,YAAM,WAAW,IAAI,oBAAmB,OAAO;AAC/C,YAAM,uBAASA,QAAM,mBAAmB;AACxC,YAAM,uBAAS,cAAa;AAC5B,aAAO;AAAA,IACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAuKM,UAIkE;AAAA,+CAJ1D;AAAA,MACZ;AAAA,MACA;AAAA,MACA,WAAW,CAAC,gBAAgB;AAAA,IAC9B,IAAoB,CAAC,GAAmD;AAjW1E;AAkWI,aAAO,oBAAoB,EAAE,QAAQ,CAAC;AAEtC,UAAI,CAAC,YAAY,SAAS,WAAW,GAAG;AACtC,cAAM,IAAI,MAAM,oDAAoD;AAAA,MACtE;AAKA,yBAAK,0BAA2B,SAAS,CAAC;AAE1C,YAAM,eAAe,MAAM;AAAA,QACzB,IAAI,KAAI,cAAS,OAAO,gBAAgB,MAAhC,YAAqC,CAAC,gBAAgB,CAAC;AAAA,MACjE,EAAE,IAAI,CAAC,OAAO,UAAUC,aAAY,EAAE,CAAC,EAAE;AAEzC,YAAM,iBAAiB,UACnB,aAAa,IAAI,CAAC,gBAAgB,GAAG,WAAW,IAAI,OAAO,EAAE,IAC7D,CAAC;AAEL,yBAAK,SAAU;AAEf,UAAI;AAEF,cAAM,SAAS,IAAI;AAAA,UACjB,CAAC,YAAY;AACX,+BAAK,WAAU,KAAK,WAAW,CAAC,EAAE,SAAS,SAAS,MAAM;AACxD,qBAAO,8BAA8B;AAAA,gBACnC;AAAA,gBACA;AAAA,cACF,CAAC;AACD,sBAAQ;AAAA,gBACN;AAAA,gBACA;AAAA,cACF,CAAC;AAAA,YACH,CAAC;AAAA,UACH;AAAA,QACF;AAEA,cAAM,mBAAKD,QAAM;AAAA,UACf;AAAA,UACA;AAAA,UACA;AAAA,UACA;AAAA,QACF;AAIA,eAAO,MAAM;AAAA,MACf,SAAS,OAAO;AACd,2BAAK,SAAU;AACf,eAAO,8BAA8B,KAAK;AAC1C,cAAM;AAAA,MACR,UAAE;AACA,2BAAK,0BAA2B;AAAA,MAClC;AAAA,IACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAWM,eAAe,IAMD;AAAA,+CANC;AAAA,MACnB;AAAA,MACA;AAAA,IACF,GAGoB;AA1atB;AA2aI,YAAM,EAAE,UAAU,QAAQ,IAAI,MAAM,KAAK,QAAQ;AAAA,QAC/C,UAAU,8BAAY,CAAC,gBAAgB;AAAA,MACzC,CAAC;AAED,YAAM,SAAU,MAAM,mBAAK,WAAU,QAAQ;AAAA,QAC3C,QAAQ;AAAA,QACR,QAAQ,CAAC,SAAS,CAAC,GAAG,OAAO;AAAA,MAC/B,CAAC;AAED,qCAAK,oBAAL,mBAAqB,mBAArB,4BAAsC;AAAA,QACpC;AAAA,QACA;AAAA,QACA,cAAc;AAAA,MAChB;AAEA,aAAO;AAAA,IACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAcM,YAAY,IAYG;AAAA,+CAZH;AAAA,MAChB;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,MACA;AAAA,IACF,GAMqB;AArdvB;AAsdI,YAAM,EAAE,UAAU,mBAAmB,SAAS,iBAAiB,IAC7D,MAAM,KAAK,QAAQ;AAAA,QACjB,UAAU,8BAAY,CAAC,gBAAgB;AAAA,QACvC;AAAA,QACA;AAAA,MACF,CAAC;AAEH,YAAM,iBACJ,OAAO,WAAW,aAAa,OAAO,kBAAkB,CAAC,CAAC,IAAI;AAEhE,YAAM,SAAS,MAAM,mBAAK,WAAU,QAAQ;AAAA,QAC1C;AAAA,QACA,QAAQ;AAAA,MACV,CAAC;AAED,qCAAK,oBAAL,mBAAqB,gBAArB,4BAAmC;AAAA,QACjC,UAAU;AAAA,QACV,SAAS;AAAA,QACT,qBAAqB;AAAA,MACvB;AAEA,aAAO;AAAA,IACT;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOM,aAA4B;AAAA;AAnfpC;AAofI,aAAO,qBAAqB;AAE5B,YAAM,gBAAgB,mBAAK;AAC3B,YAAM,eAAe,OAAO,KAAK,aAAa,EAAE,OAAO,CAAC,UAAU;AAChE,cAAM,EAAE,WAAAE,WAAU,IAAI,iBAAiB,KAAc;AACrD,eAAOA,eAAc;AAAA,MACvB,CAAC;AAED,YAAM,mBAAKF,QAAM,WAAW,YAAuB;AACnD,4BAAK,gDAAL;AACA,4BAAK,wDAAL;AAOA,+BAAK,gCAAL;AACA,yBAAK,4BAA6B;AAElC,aAAO,+BAA+B;AAAA,IACxC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAUM,YAAY,IAMA;AAAA,+CANA;AAAA,MAChB;AAAA,MACA;AAAA,IACF,GAGkB;AAChB,YAAM,SAAS;AACf,YAAM,QAAe,UAAUC,aAAY,OAAO,CAAC;AACnD,YAAM,SAAS,CAAC,EAAE,QAAQ,CAAC;AAG3B,UAAI,KAAK,oBAAoB,SAAS;AACpC,eAAO,QAAQ,QAAQ;AAAA,MACzB;AAEA,YAAM,oBAAoB,wBAAwB,mBAAK,eAAc;AAErE,UACE,kBAAkB,SAAS,OAAO,KAClC,mBAAKD,QAAM,kBAAkB,cAAc,KAC3C;AACA,cAAM,sBAAK,gDAAL,WAAmB;AACzB,8BAAK,kDAAL,WAAqB;AACrB,eAAO,QAAQ,QAAQ;AAAA,MACzB;AAEA,YAAM,sBAAK,8DAAL,WAAiC,QAAQ,OAAO;AAEtD,UAAI;AACF,cAAM,SAAS,MAAM,sBAAK,2CAAL,WAAc;AAAA,UACjC,QAAQ;AAAA,UACR;AAAA,QACF;AAIA,cAAM,kBAAkB;AACxB,YAAI,mDAAiB,OAAO;AAC1B,gBAAM,IAAI,MAAM,gBAAgB,MAAM,OAAO;AAAA,QAC/C;AAEA,cAAM,sBAAK,8DAAL,WAAiC,QAAQ,OAAO;AACtD,YAAK,OAA+B,WAAW,MAAM;AAEnD,gBAAM,sBAAK,gDAAL,WAAmB;AACzB,gCAAK,kDAAL,WAAqB;AAAA,QACvB;AACA,eAAO,QAAQ,QAAQ;AAAA,MACzB,SAAS,OAAO;AACd,cAAM,sBAAK,2DAAL,WAA8B,QAAQ,OAAO,QAAQ;AAE3D,YAAK,MAAgB,QAAQ,SAAS,uBAAuB,GAAG;AAC9D,iBAAO,sBAAK,oDAAL,WAAuB;AAAA,QAChC;AACA,cAAM;AAAA,MACR;AAAA,IACF;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EA2VA,cAA+B;AAC7B,WAAO,mBAAK;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,aAA8B;AAC5B,WAAO,KAAK;AAAA,EACd;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,aAAkC;AAChC,WAAO,mBAAK,WAAU;AAAA,EACxB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAQA,IAAI,WAAsB;AACxB,WAAO,mBAAK,WAAU;AAAA,EACxB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,IAAI,kBAAuC;AACzC,WAAO,mBAAK,WAAU;AAAA,EACxB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,IAAI,kBAAmC;AACrC,WAAO,mBAAK,WAAU;AAAA,EACxB;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAOA,IAAI,SAA2B;AAC7B,WAAO,mBAAK;AAAA,EACd;AACF;AAv4BWA,SAAA;AAGA;AAGT;AAGS;AAGA;AAGA;AAGT;AAGA;AAQA;AAGS;AAlCJ;AAAA;AAAA;AAAA;AAAA;AAAA;AAqGL,oBAAe,WAAsB;AACnC,SAAQ,mBAAKA,QAAc;AAC7B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAUA,yBAAoB,SAClB,QACA,OACA,QAIA;AACA,SAAO;AAAA,IACL;AAAA,IACA,SAAS,EAAE,QAAQ,OAAO;AAAA,EAC5B;AACF;AASM,gCAA2B,SAC/B,QACA,OACA,QACe;AAAA;AACf,UAAM,cAAc,sBAAK,kDAAL;AACpB,QAAI;AACF,YAAM,gBAAgB,sBAAK,uDAAL,WAA0B,QAAQ,OAAO;AAC/D,YAAM,QAAQ,MAAM;AAAA,QAClB;AAAA,QACA,mBAAKA,QAAM;AAAA,QACX;AAAA,QACA,mBAAKA,QAAM;AAAA,MACb;AACA,gBAAU,MAAM,qCAAqC,KAAK;AAAA,IAC5D,SAAS,OAAO;AACd,aAAO,0DAA0D,KAAK;AAAA,IACxE;AAAA,EACF;AAAA;AASM,gCAA2B,SAC/B,QACA,OACA,QACe;AAAA;AACf,UAAM,cAAc,sBAAK,kDAAL;AACpB,QAAI;AACF,YAAM,gBAAgB,sBAAK,uDAAL,WAA0B,QAAQ,OAAO;AAC/D,YAAM,QAAQ,MAAM;AAAA,QAClB;AAAA,QACA,mBAAKA,QAAM;AAAA,QACX;AAAA,QACA,mBAAKA,QAAM;AAAA,MACb;AACA,gBAAU,MAAM,qCAAqC,KAAK;AAAA,IAC5D,SAAS,OAAO;AACd,aAAO,0DAA0D,KAAK;AAAA,IACxE;AAAA,EACF;AAAA;AAUM,6BAAwB,SAC5B,QACA,OACA,QACA,OACe;AAAA;AACf,UAAM,cAAc,sBAAK,kDAAL;AACpB,QAAI;AACF,YAAM,gBAAgB,sBAAK,uDAAL,WAA0B,QAAQ,OAAO;AAC/D,YAAM,QAAQ,MAAM;AAAA,QAClB;AAAA,QACA,mBAAKA,QAAM;AAAA,QACX;AAAA,QACA,mBAAKA,QAAM;AAAA,MACb;AACA,YAAM,cAAc,iBAAiB,KAAK;AAC1C,UAAI,aAAa;AACf,kBAAU,MAAM,oCAAoC,KAAK;AAAA,MAC3D,OAAO;AACL,kBAAU,MAAM,kCAAkC,KAAK;AAAA,MACzD;AAAA,IACF,SAAQ;AACN,aAAO,yDAAyD,KAAK;AAAA,IACvE;AAAA,EACF;AAAA;AAWM,wBAAmB,SAAC,mBAAwC;AAAA;AAEhE,QACE,mBAAK,6BACL,kBAAkB,SAAS,mBAAK,yBAAwB,GACxD;AACA,aAAO,mBAAK;AAAA,IACd;AAEA,QAAI;AACF,YAAM,gBACJ,MAAM,mBAAKA,QAAM,QAAQ,QAAQ,IAAI,eAAe;AACtD,UAAI,eAAe;AACjB,cAAM,UAAe,KAAK,MAAM,aAAa;AAG7C,YAAI,kBAAkB,SAAS,OAAO,GAAG;AACvC,iBAAO;AAAA,QACT;AAAA,MACF;AAAA,IACF,SAAS,OAAO;AACd,aAAO,mCAAmC,KAAK;AAAA,IACjD;AAGA,WAAO,kBAAkB,CAAC;AAAA,EAC5B;AAAA;AAmQM,wBAAmB,SACvB,SACwC;AAAA;AACxC,WAAO,oCAAoC,QAAQ,MAAM,EAAE;AAE3D,QAAI,gBAAgB,SAAS,QAAQ,MAAM,GAAG;AAE5C,aAAO,QAAQ;AAAA,QACb,IAAI;AAAA,UACF,WAAW,QAAQ,MAAM;AAAA,QAC3B;AAAA,MACF;AAAA,IACF;AAEA,QAAI,QAAQ,WAAW,4BAA4B;AACjD,aAAO,KAAK,WAAW;AAAA,IACzB;AAEA,QAAI,iBAAiB,OAAO,GAAG;AAM7B,YAAM,+BACJ,QAAQ,WAAW;AAErB,YAAM,EAAE,QAAQ,OAAO,IAAI;AAC3B,YAAM,YAAY,wBAAwB,mBAAK,eAAc;AAC7D,UAAI,UAAU,WAAW,GAAG;AAC1B,kBAAU,KAAK,gBAAgB;AAAA,MACjC;AAEA,YAAM,WAAW,mBAAK,WAAU;AAChC,YAAM,YACJ,YAAY,UAAU,SAAS,QAAQ,IAAI,WAAW,UAAU,CAAC;AAEnE,YAAM,WAAW;AAAA,QACf;AAAA,QACA,GAAG,UAAU,OAAO,CAAC,OAAO,OAAO,SAAS;AAAA,MAC9C;AAEA,YAAM,QAAe,UAAUC,aAAY,SAAS,CAAC;AAErD,YAAM,sBAAK,8DAAL,WAAiC,QAAQ,OAAO;AAEtD,UAAI;AACF,cAAM,SAAS,MAAM,KAAK,QAAQ;AAAA,UAChC;AAAA,UACA,cAAc;AAAA,QAChB,CAAC;AACD,cAAM,sBAAK,8DAAL,WAAiC,QAAQ,OAAO;AACtD,eAAO;AAAA,MACT,SAAS,OAAO;AACd,cAAM,sBAAK,2DAAL,WAA8B,QAAQ,OAAO,QAAQ;AAC3D,cAAM;AAAA,MACR;AAAA,IACF;AAEA,QAAI,qBAAqB,OAAO,GAAG;AACjC,aAAO,KAAK,YAAY;AAAA,QACtB,SAAS,QAAQ,OAAO,CAAC,EAAE;AAAA,MAC7B,CAAC;AAAA,IACH;AAEA,QAAI,kBAAkB,OAAO,GAAG;AAC9B,aAAO,sBAAK,oDAAL,WAAuB,QAAQ,OAAO,CAAC;AAAA,IAChD;AAEA,QAAI,kBAAkB,OAAO,GAAG;AAC9B,aAAO,mBAAK,WAAU;AAAA,IACxB;AAEA,QAAI,iBAAiB,OAAO,GAAG;AAC7B,aAAO,mBAAK,WAAU;AAAA,IACxB;AAEA,WAAO,0DAA0D,OAAO;AACxE,WAAO,QAAQ,QAAQ;AAAA,EACzB;AAAA;AAAA;AAAA;AAAA;AAKA,0BAAqB,WAAS;AAC5B,qBAAK,WAAU,WAAW,CAAC;AAC3B,qBAAK,WAAU,kBAAkB;AACnC;AASM,sBAAiB,SACrB,oBACe;AAAA;AACf,WAAO,2BAA2B,EAAE,mBAAmB,CAAC;AACxD,UAAM,SAAS;AAEf,QAAI,CAAC,oBAAoB;AACvB,YAAM,IAAI,MAAM,+BAA+B;AAAA,IACjD;AAGA,UAAM,UACH,mBAAmB,WACpB,mBAAK,WAAU,mBACf;AACF,UAAM,iBAAiBA,aAAY,OAAO;AAC1C,UAAM,QAAe,UAAU,cAAc;AAC7C,UAAM,SAAS,CAAC,kBAAkB;AAElC,UAAM,sBAAK,8DAAL,WAAiC,QAAQ,OAAO;AAEtD,QAAI;AACF,YAAM,SAAS,MAAM,sBAAK,2CAAL,WAAc;AAAA,QACjC,QAAQ;AAAA,QACR;AAAA,MACF;AAEA,UAAK,OAA+B,WAAW,MAAM;AAEnD,cAAM,sBAAK,gDAAL,WAAmB;AACzB,8BAAK,kDAAL,WAAqB;AAAA,MACvB;AACA,YAAM,sBAAK,8DAAL,WAAiC,QAAQ,OAAO;AAAA,IACxD,SAAS,OAAO;AACd,YAAM,sBAAK,2DAAL,WAA8B,QAAQ,OAAO,QAAQ;AAC3D,YAAM;AAAA,IACR;AAAA,EACF;AAAA;AAUM,aAAQ,SAAC,SAGM;AAAA;AACnB,WAAO,8CAA8C,OAAO;AAC5D,UAAM,SAAS,mBAAKD,QAAM,UAAU,mBAAmB,OAAO;AAC9D,QACE,QAAQ,WAAW,6BACnB,QAAQ,WAAW,8BACnB;AACA,yBAAKA,QAAM,2BAA2B;AAAA,IACxC;AACA,WAAO;AAAA,EACT;AAAA;AAOM,kBAAa,SAAC,SAA6B;AAAA;AAC/C,QAAI;AACF,YAAM,mBAAKA,QAAM,QAAQ,QAAQ;AAAA,QAC/B;AAAA,QACA,KAAK,UAAU,OAAO;AAAA,MACxB;AAAA,IACF,SAAS,OAAO;AACd,aAAO,yBAAyB,KAAK;AAAA,IACvC;AAAA,EACF;AAAA;AAEM,sBAAiB,SAAC,SAAsC;AAAA;AAnwBhE;AAowBI,WAAO,gCAAgC,OAAO;AAC9C,uBAAK,iBAAiB,wCAAS,kBAAT,YAA0B,CAAC;AACjD,UAAM,uBAAuB,wBAAwB,mBAAK,eAAc;AACxE,QAAI,qBAAqB,WAAW,GAAG;AACrC,4BAAK,gDAAL;AAAA,IACF,OAAO;AACL,UAAI,kBAA6B,CAAC;AAClC,UAAI,mBAAKA,QAAM,WAAW,aAAa;AACrC,cAAM,sBACJ,MAAM,mBAAKA,QAAM,UAAU,mBAAmB;AAAA,UAC5C,QAAQ;AAAA,UACR,QAAQ,CAAC;AAAA,QACX,CAAC;AACH,0BAAkB,oBAAoB;AAAA,MACxC,OAAO;AACL,0BAAkB,eAAe,mBAAK,eAAc;AAAA,MACtD;AAEA,YAAM,UAAU,MAAM,sBAAK,sDAAL,WAAyB;AAE/C,4BAAK,6CAAL,WAAgB;AAAA,QACd;AAAA,QACA,UAAU;AAAA,MACZ;AAAA,IACF;AAEA,uBAAK,cAAa,QAAQ;AAAA,EAC5B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAOA,oBAAe,SAAC,SAAoB;AAtyBtC;AAuyBI,MAAI,YAAY,mBAAK,WAAU,iBAAiB;AAC9C;AAAA,EACF;AACA,SAAO,yBAAyB,EAAE,QAAQ,CAAC;AAC3C,qBAAK,WAAU,kBAAkB;AACjC,qBAAK,WAAU,KAAK,gBAAgB,OAAO;AAC3C,iCAAK,oBAAL,mBAAqB,iBAArB,4BAAoC;AACtC;AAAA;AAAA;AAAA;AAAA;AAAA;AAOA,uBAAkB,SAAC,UAA2B;AArzBhD;AAszBI,QAAM,oBACJ,SAAS,WAAW,mBAAK,WAAU,SAAS,UAC5C,SAAS,MAAM,CAAC,MAAM,QAAQ,SAAS,mBAAK,WAAU,SAAS,GAAG,CAAC;AACrE,MAAI,mBAAmB;AACrB;AAAA,EACF;AACA,SAAO,4BAA4B,QAAQ;AAC3C,qBAAK,WAAU,WAAW;AAC1B,qBAAK,WAAU,KAAK,mBAAmB,QAAQ;AAC/C,iCAAK,oBAAL,mBAAqB,oBAArB,4BAAuC;AACzC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AASA,eAAU,SAAC;AAAA,EACT;AAAA,EACA;AACF,GAGS;AA/0BX;AAg1BI,SAAO,oBAAoB,EAAE,SAAS,SAAS,CAAC;AAChD,QAAM,OAAO;AAAA,IACX;AAAA,IACA;AAAA,EACF;AAEA,MAAI,mBAAK,aAAY,aAAa;AAChC,0BAAK,kDAAL,WAAqB;AACrB,0BAAK,qDAAL,WAAwB;AACxB;AAAA,EACF;AAEA,qBAAK,WAAU,kBAAkB;AACjC,qBAAK,WAAU,WAAW;AAE1B,qBAAK,SAAU;AACf,qBAAK,WAAU,KAAK,WAAW,IAAI;AACnC,iCAAK,oBAAL,mBAAqB,YAArB,4BAA+B;AAE/B,qBAAK,WAAU,KAAK,gBAAgB,OAAO;AAC3C,iCAAK,oBAAL,mBAAqB,iBAArB,4BAAoC;AAEpC,qBAAK,WAAU,KAAK,mBAAmB,QAAQ;AAC/C,iCAAK,oBAAL,mBAAqB,oBAArB,4BAAuC;AAEvC,2BAAK,gCAAL;AAEA,QAAM,oBAAoB,CAAC,SAAyB;AAClD,WAAO,+BAA+B,IAAI;AAC1C,0BAAK,qDAAL,WAAwB;AAAA,EAC1B;AAEA,QAAM,iBAAiB,CAAC,iBAA4C;AAClE,WAAO,4BAA4B,aAAa,OAAO;AACvD,0BAAK,gDAAL,WAAmB,aAAa,SAAgB,MAAM,CAAC,UAAU;AAC/D,aAAO,iDAAiD,KAAK;AAAA,IAC/D,CAAC;AACD,0BAAK,kDAAL,WAAqB,aAAa;AAAA,EACpC;AAEA,qBAAKA,QAAM,GAAG,4BAA4B,iBAAiB;AAC3D,qBAAKA,QAAM,GAAG,yBAAyB,cAAc;AAErD,qBAAK,4BAA6B,MAAY;AAC5C,uBAAKA,QAAM,IAAI,4BAA4B,iBAAiB;AAC5D,uBAAKA,QAAM,IAAI,yBAAyB,cAAc;AAAA,EACxD;AACF;AAAA;AAAA;AAAA;AAAA;AAMA,kBAAa,WAAS;AAr4BxB;AAs4BI,MAAI,mBAAK,aAAY,gBAAgB;AACnC;AAAA,EACF;AACA,qBAAK,SAAU;AAEf,SAAO,qBAAqB;AAC5B,qBAAK,WAAU,KAAK,YAAY;AAChC,iCAAK,oBAAL,mBAAqB,eAArB;AAEA,wBAAK,qDAAL,WAAwB,CAAC;AAC3B;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAQA,kBAAa,SAAC,KAAmB;AAx5BnC;AAy5BI,MAAI,mBAAK,aAAY,cAAc;AACjC;AAAA,EACF;AAEA,SAAO,wBAAwB,GAAG;AAClC,qBAAK,WAAU,KAAK,eAAe,GAAG;AACtC,iCAAK,oBAAL,mBAAqB,eAArB,4BAAkC;AACpC;AAx0BK,IAAM,qBAAN;AAi6BP,SAAsB,gBACpB,SAY6B;AAAA;AAtgC/B;AAugCE,QAAI,QAAQ,OAAO;AACjB,kBAAY;AAAA,IACd;AAEA,WAAO,+CAA+C,OAAO;AAG7D,QACE,GAAC,aAAQ,QAAR,mBAAa,sBACd,OAAO,KAAK,QAAQ,IAAI,iBAAiB,EAAE,WAAW,GACtD;AACA,YAAM,IAAI;AAAA,QACR;AAAA,MACF;AAAA,IACF;AAEA,6BAAyB,QAAQ,IAAI,mBAAmB,mBAAmB;AAE3E,UAAM,+BAA+B,OAAO;AAAA,MAC1C,QAAQ,IAAI;AAAA,IACd,EAAE,OAA+B,CAAC,KAAK,CAAC,YAAY,GAAG,MAAM;AAC3D,YAAM,iBAAiB,SAAS,YAAY,EAAE;AAC9C,YAAM,eAAe,UAAU,cAAc;AAC7C,UAAI,YAAY,IAAI;AACpB,aAAO;AAAA,IACT,GAAG,CAAC,CAAC;AAEL,QAAI;AACF,YAAM,OAAO,MAAM,uBAAuB,iCACrC,UADqC;AAAA,QAExC,KAAK;AAAA,UACH,mBAAmB;AAAA,QACrB;AAAA,QACA,WAAW;AAAA;AAAA,UAET,mBAAiB,aAAQ,cAAR,mBAAmB,oBAAmB;AAAA,QACzD;AAAA,QACA,UAAU;AAAA;AAAA;AAAA,UAGR,eACE,QACI,YACA;AAAA,QACR;AAAA,MACF,EAAC;AAED,aAAO,mBAAmB,OAAO;AAAA,QAC/B;AAAA,QACA,eAAe,QAAQ;AAAA,QACvB,mBAAmB,QAAQ,IAAI;AAAA,MACjC,CAAC;AAAA,IACH,SAAS,OAAO;AACd,cAAQ,MAAM,uCAAuC,KAAK;AAC1D,YAAM;AAAA,IACR;AAAA,EACF;AAAA;","names":["namespace","hexToNumber","hexToNumber","hexToNumber","_a","_core","hexToNumber","namespace"]}
1
+ {"version":3,"sources":["../../../src/utils/infura.ts","../../../src/connect.ts","../../../src/constants.ts","../../../src/logger.ts","../../../src/provider.ts","../../../src/utils/caip.ts","../../../src/utils/type-guards.ts"],"sourcesContent":["import { getInfuraRpcUrls as getInfuraRpcUrlsMultichain } from '@metamask/connect-multichain';\nimport type { CaipChainId, Hex } from '@metamask/utils';\nimport {\n hexToNumber,\n KnownCaipNamespace,\n numberToHex,\n parseCaipChainId,\n} from '@metamask/utils';\n\n/**\n * Generates Infura RPC URLs for common EVM networks keyed by hex chain ID.\n *\n * @param options - The options for generating Infura RPC URLs\n * @param options.infuraApiKey - The Infura API key\n * @param options.chainIds - Optional hex chain IDs to filter the output\n * @returns A map of hex chain IDs to Infura RPC URLs\n */\nexport const getInfuraRpcUrls = ({\n infuraApiKey,\n chainIds,\n}: {\n infuraApiKey: string;\n chainIds?: Hex[];\n}): Record<Hex, string> => {\n const caipChainIds = chainIds?.map(\n (chainId) => `eip155:${hexToNumber(chainId)}` as CaipChainId,\n );\n\n const caipMap = getInfuraRpcUrlsMultichain({\n infuraApiKey,\n caipChainIds,\n });\n\n return Object.entries(caipMap).reduce<Record<Hex, string>>(\n (acc, [key, url]) => {\n const { namespace, reference } = parseCaipChainId(key as CaipChainId);\n if (namespace !== KnownCaipNamespace.Eip155) {\n return acc;\n }\n const chainId = numberToHex(parseInt(reference, 10));\n acc[chainId] = url as string;\n return acc;\n },\n {},\n );\n};\n","/* eslint-disable no-restricted-syntax -- Private class properties use established patterns */\n/* eslint-disable @typescript-eslint/naming-convention -- __PACKAGE_VERSION__ is an esbuild define convention */\nimport { analytics } from '@metamask/analytics';\nimport { parseScopeString } from '@metamask/chain-agnostic-permission';\nimport type {\n MultichainCore,\n MultichainOptions,\n Scope,\n SessionData,\n} from '@metamask/connect-multichain';\nimport {\n createMultichainClient,\n getWalletActionAnalyticsProperties,\n isRejectionError,\n TransportType,\n} from '@metamask/connect-multichain';\nimport { hexToNumber } from '@metamask/utils';\n\nimport { IGNORED_METHODS } from './constants';\nimport { enableDebug, logger } from './logger';\nimport { EIP1193Provider } from './provider';\nimport type {\n AddEthereumChainParameter,\n Address,\n CaipAccountId,\n EventHandlers,\n Hex,\n MetamaskConnectEVMOptions,\n ProviderRequest,\n ProviderRequestInterceptor,\n} from './types';\nimport { getEthAccounts, getPermittedEthChainIds } from './utils/caip';\nimport {\n isAccountsRequest,\n isAddChainRequest,\n isChainIdRequest,\n isConnectRequest,\n isSwitchChainRequest,\n validSupportedChainsUrls,\n} from './utils/type-guards';\n\n// Value substitued by tsup at build time\ndeclare const __PACKAGE_VERSION__: string | undefined;\n\nconst DEFAULT_CHAIN_ID = '0x1';\nconst CHAIN_STORE_KEY = 'cache_eth_chainId';\n\n/** The options for the connect method */\ntype ConnectOptions = {\n /** The account to connect to */\n account?: string | undefined;\n /** Whether to force a request regardless of an existing session */\n forceRequest?: boolean;\n /** All available chain IDs in the dapp in hex format */\n chainIds?: Hex[];\n};\n\nexport type ConnectEvmStatus = 'disconnected' | 'connected' | 'connecting';\n\n/**\n * The MetamaskConnectEVM class provides an EIP-1193 compatible interface for connecting\n * to MetaMask and interacting with Ethereum Virtual Machine (EVM) networks.\n *\n * This class serves as a modern replacement for MetaMask SDK V1, offering enhanced\n * functionality and cross-platform compatibility. It wraps the Multichain SDK to provide\n * a simplified, EIP-1193 compliant API for dapp developers.\n *\n * Key features:\n * - EIP-1193 provider interface for seamless integration with existing dapp code\n * - Automatic session recovery when reloading or opening in new tabs\n * - Chain switching with automatic chain addition if not configured\n * - Event-driven architecture with support for connect, disconnect, accountsChanged, and chainChanged events\n * - Cross-platform support for browser extensions and mobile applications\n * - Built-in handling of common Ethereum methods (eth_accounts, wallet_switchEthereumChain, etc.)\n *\n * @example\n * ```typescript\n * const client = await createEVMClient({\n * dapp: { name: 'My DApp', url: 'https://mydapp.com' }\n * });\n *\n * const { accounts, chainId } = await client.connect({ chainIds: [1, 137] }); // Connect to Ethereum Mainnet, and Polygon\n *\n * const provider = client.getProvider();\n * const signedMessage = await provider.request({ method: 'personal_sign', params: ['0x0', accounts[0]] });\n * ```\n */\nexport class MetamaskConnectEVM {\n /** The core instance of the Multichain SDK */\n readonly #core: MultichainCore;\n\n /** An instance of the EIP-1193 provider interface */\n readonly #provider: EIP1193Provider;\n\n /** The session scopes currently permitted */\n #sessionScopes: SessionData['sessionScopes'] = {};\n\n /** Optional event handlers for the EIP-1193 provider events. */\n readonly #eventHandlers?: Partial<EventHandlers> | undefined;\n\n /** The handler for the wallet_sessionChanged event */\n readonly #sessionChangedHandler: (session?: SessionData) => void;\n\n /** The handler for the display_uri event */\n readonly #displayUriHandler: (uri: string) => void;\n\n /** The clean-up function for the notification handler */\n #removeNotificationHandler?: () => void;\n\n /** The current connection status */\n #status: ConnectEvmStatus = 'disconnected';\n\n /**\n * The preferred chain ID to use for the active connect() call.\n * Set to the first explicit chainId passed by the caller, cleared once the\n * connect event resolves. Takes priority over the cache in #getSelectedChainId\n * so that an explicit chainIds request always wins over a prior cached value.\n */\n #pendingPreferredChainId: Hex | undefined;\n\n /**\n * Creates a new MetamaskConnectEVM instance.\n * Use the static `create()` method instead to ensure proper async initialization.\n *\n * @param options - The options for the MetamaskConnectEVM instance\n * @param options.core - The core instance of the Multichain SDK\n * @param options.eventHandlers - Optional event handlers for EIP-1193 provider events\n */\n private constructor({ core, eventHandlers }: MetamaskConnectEVMOptions) {\n this.#core = core;\n\n this.#provider = new EIP1193Provider(\n core,\n this.#requestInterceptor.bind(this),\n );\n\n this.#eventHandlers = eventHandlers;\n\n /**\n * Handles the wallet_sessionChanged event.\n * Updates the internal connection state with the new session data.\n *\n * @param session - The session data\n */\n // eslint-disable-next-line @typescript-eslint/no-misused-promises\n this.#sessionChangedHandler = this.#onSessionChanged.bind(this);\n this.#core.on('wallet_sessionChanged', this.#sessionChangedHandler);\n\n /**\n * Handles the display_uri event.\n * Forwards the QR code URI to the provider for custom UI implementations.\n */\n this.#displayUriHandler = this.#onDisplayUri.bind(this);\n this.#core.on('display_uri', this.#displayUriHandler);\n\n logger('Connect/EVM constructor completed');\n }\n\n /**\n * Creates a fully initialized MetamaskConnectEVM instance.\n * This is the recommended way to instantiate the class, as it ensures\n * all async initialization (like session recovery) completes before\n * the instance is returned.\n *\n * @param options - The options for the MetamaskConnectEVM instance\n * @param options.core - The core instance of the Multichain SDK\n * @param options.eventHandlers - Optional event handlers for EIP-1193 provider events\n * @returns A promise that resolves with a fully initialized MetamaskConnectEVM instance\n */\n static async create(\n options: MetamaskConnectEVMOptions,\n ): Promise<MetamaskConnectEVM> {\n const instance = new MetamaskConnectEVM(options);\n let session;\n try {\n session = await instance.#core.provider.getSession();\n } catch {\n session = { sessionScopes: {} };\n }\n await instance.#onSessionChanged(session);\n return instance;\n }\n\n /**\n * Gets the core options for analytics checks.\n *\n * @returns The multichain options from the core instance\n */\n #getCoreOptions(): MultichainOptions {\n return (this.#core as any).options as MultichainOptions;\n }\n\n /**\n * Creates invoke options for analytics tracking.\n *\n * @param method - The RPC method name\n * @param scope - The CAIP chain ID scope\n * @param params - The method parameters\n * @returns Invoke options object for analytics\n */\n #createInvokeOptions(\n method: string,\n scope: Scope,\n params: unknown[],\n ): {\n scope: Scope;\n request: { method: string; params: unknown[] };\n } {\n return {\n scope,\n request: { method, params },\n };\n }\n\n /**\n * Tracks a wallet action requested event.\n *\n * @param method - The RPC method name\n * @param scope - The CAIP chain ID scope\n * @param params - The method parameters\n */\n async #trackWalletActionRequested(\n method: string,\n scope: Scope,\n params: unknown[],\n ): Promise<void> {\n const coreOptions = this.#getCoreOptions();\n try {\n const invokeOptions = this.#createInvokeOptions(method, scope, params);\n const props = await getWalletActionAnalyticsProperties(\n coreOptions,\n this.#core.storage,\n invokeOptions,\n this.#core.transportType,\n );\n analytics.track('mmconnect_wallet_action_requested', props);\n } catch (error) {\n logger('Error tracking mmconnect_wallet_action_requested event', error);\n }\n }\n\n /**\n * Tracks a wallet action succeeded event.\n *\n * @param method - The RPC method name\n * @param scope - The CAIP chain ID scope\n * @param params - The method parameters\n */\n async #trackWalletActionSucceeded(\n method: string,\n scope: Scope,\n params: unknown[],\n ): Promise<void> {\n const coreOptions = this.#getCoreOptions();\n try {\n const invokeOptions = this.#createInvokeOptions(method, scope, params);\n const props = await getWalletActionAnalyticsProperties(\n coreOptions,\n this.#core.storage,\n invokeOptions,\n this.#core.transportType,\n );\n analytics.track('mmconnect_wallet_action_succeeded', props);\n } catch (error) {\n logger('Error tracking mmconnect_wallet_action_succeeded event', error);\n }\n }\n\n /**\n * Tracks a wallet action failed or rejected event based on the error.\n *\n * @param method - The RPC method name\n * @param scope - The CAIP chain ID scope\n * @param params - The method parameters\n * @param error - The error that occurred\n */\n async #trackWalletActionFailed(\n method: string,\n scope: Scope,\n params: unknown[],\n error: unknown,\n ): Promise<void> {\n const coreOptions = this.#getCoreOptions();\n try {\n const invokeOptions = this.#createInvokeOptions(method, scope, params);\n const props = await getWalletActionAnalyticsProperties(\n coreOptions,\n this.#core.storage,\n invokeOptions,\n this.#core.transportType,\n );\n const isRejection = isRejectionError(error);\n if (isRejection) {\n analytics.track('mmconnect_wallet_action_rejected', props);\n } else {\n analytics.track('mmconnect_wallet_action_failed', props);\n }\n } catch {\n logger('Error tracking wallet action rejected or failed event', error);\n }\n }\n\n /**\n * Gets the currently selected chainId. Priority order:\n * - Explicit caller preference from an active connect() call, if permitted.\n * - Cached chainId from storage, if permitted.\n * - First permitted chain as a fallback.\n *\n * @param permittedChainIds - Array of permitted chain IDs in hex format\n * @returns The selected chainId (hex string)\n */\n async #getSelectedChainId(permittedChainIds: Hex[]): Promise<Hex> {\n // Honour an explicit caller preference set during an active connect() call\n if (\n this.#pendingPreferredChainId &&\n permittedChainIds.includes(this.#pendingPreferredChainId)\n ) {\n return this.#pendingPreferredChainId;\n }\n\n try {\n const cachedChainId =\n await this.#core.storage.adapter.get(CHAIN_STORE_KEY);\n if (cachedChainId) {\n const chainId: Hex = JSON.parse(cachedChainId);\n\n // Validate that the cached chainId is in the permitted chains list\n if (permittedChainIds.includes(chainId)) {\n return chainId;\n }\n }\n } catch (error) {\n logger('Error retrieving cached chainId', error);\n }\n\n // Fallback to the first permitted chain if cache retrieval failed or returned an invalid chain\n return permittedChainIds[0];\n }\n\n /**\n * Connects to the wallet with the specified chain ID and optional account.\n *\n * @param options - The connection options\n * @param [options.account] - Optional param to specify an account to connect to\n * @param [options.forceRequest] - Optional param to force a connection request regardless of whether there is a pre-existing session\n * @param [options.chainIds] - Array of chain IDs to request permission for (defaults to ethereum mainnet). The first entry is used as the active chain returned by the call. Ethereum mainnet is always included in the permission request as a bootstrap fallback.\n * @returns A promise that resolves with the connected accounts and chain ID\n */\n async connect({\n account,\n forceRequest,\n chainIds = [DEFAULT_CHAIN_ID],\n }: ConnectOptions = {}): Promise<{ accounts: Address[]; chainId: Hex }> {\n logger('request: connect', { account });\n\n if (!chainIds || chainIds.length === 0) {\n throw new Error('chainIds must be an array of at least one chain ID');\n }\n\n // The first explicitly-requested chain is preferred for chain selection.\n // DEFAULT_CHAIN_ID is still included in the permission request as a bootstrap\n // fallback, but it must not win over an explicit caller request.\n this.#pendingPreferredChainId = chainIds[0];\n\n const caipChainIds = Array.from(\n new Set(chainIds.concat(DEFAULT_CHAIN_ID) ?? [DEFAULT_CHAIN_ID]),\n ).map((id) => `eip155:${hexToNumber(id)}`);\n\n const caipAccountIds = account\n ? caipChainIds.map((caipChainId) => `${caipChainId}:${account}`)\n : [];\n\n this.#status = 'connecting';\n\n try {\n // Wait for the wallet_sessionChanged event to fire and set the provider properties\n const result = new Promise<{ accounts: Address[]; chainId: Hex }>(\n (resolve) => {\n this.#provider.once('connect', ({ chainId, accounts }) => {\n logger('fulfilled-request: connect', {\n chainId,\n accounts,\n });\n resolve({\n accounts,\n chainId,\n });\n });\n },\n );\n\n await this.#core.connect(\n caipChainIds as Scope[],\n caipAccountIds as CaipAccountId[],\n undefined,\n forceRequest,\n );\n\n // Await here so the finally block always runs after #onSessionChanged\n // has consumed #pendingPreferredChainId, not before.\n return await result;\n } catch (error) {\n this.#status = 'disconnected';\n logger('Error connecting to wallet', error);\n throw error;\n } finally {\n this.#pendingPreferredChainId = undefined;\n }\n }\n\n /**\n * Connects to the wallet and signs a message using personal_sign.\n *\n * @param options - The connection options\n * @param options.message - The message to sign after connecting\n * @param [options.chainIds] - Optional hex chain IDs to connect to (defaults to ethereum mainnet if not provided)\n * @returns A promise that resolves with the connected accounts, chainId, and signature\n * @throws Error if the selected account is not available after timeout\n */\n async connectAndSign({\n message,\n chainIds,\n }: {\n message: string;\n chainIds?: Hex[];\n }): Promise<{ accounts: Address[]; chainId: Hex; signature: string }> {\n const { accounts, chainId } = await this.connect({\n chainIds: chainIds ?? [DEFAULT_CHAIN_ID],\n });\n\n const signature = (await this.#provider.request({\n method: 'personal_sign',\n params: [accounts[0], message],\n })) as string;\n\n this.#eventHandlers?.connectAndSign?.({\n accounts,\n chainId,\n signature,\n });\n\n return { accounts, chainId, signature };\n }\n\n /**\n * Connects to the wallet and invokes a method with specified parameters.\n *\n * @param options - The options for connecting and invoking the method\n * @param options.method - The method name to invoke\n * @param options.params - The parameters to pass to the method, or a function that receives the account and returns params\n * @param [options.chainIds] - Optional hex chain IDs to connect to (defaults to ethereum mainnet if not provided)\n * @param [options.account] - Optional specific account to connect to\n * @param [options.forceRequest] - Whether to force a request regardless of an existing session\n * @returns A promise that resolves with the connected accounts, chainId, and the result of the method invocation\n * @throws Error if the selected account is not available after timeout (for methods that require an account)\n */\n async connectWith({\n method,\n params,\n chainIds,\n account,\n forceRequest,\n }: {\n method: string;\n params: unknown[] | ((account: Address) => unknown[]);\n chainIds?: Hex[];\n account?: string | undefined;\n forceRequest?: boolean;\n }): Promise<{ accounts: Address[]; chainId: Hex; result: unknown }> {\n const { accounts: connectedAccounts, chainId: connectedChainId } =\n await this.connect({\n chainIds: chainIds ?? [DEFAULT_CHAIN_ID],\n account,\n forceRequest,\n });\n\n const resolvedParams =\n typeof params === 'function' ? params(connectedAccounts[0]) : params;\n\n const result = await this.#provider.request({\n method,\n params: resolvedParams,\n });\n\n this.#eventHandlers?.connectWith?.({\n accounts: connectedAccounts,\n chainId: connectedChainId,\n result,\n });\n\n return { accounts: connectedAccounts, chainId: connectedChainId, result };\n }\n\n /**\n * Disconnects from the wallet by revoking the session and cleaning up event listeners.\n *\n * @returns A promise that resolves when disconnection is complete\n */\n async disconnect(): Promise<void> {\n logger('request: disconnect');\n\n const sessionScopes = this.#sessionScopes;\n const eip155Scopes = Object.keys(sessionScopes).filter((scope) => {\n const { namespace } = parseScopeString(scope as Scope);\n return namespace === 'eip155';\n });\n\n await this.#core.disconnect(eip155Scopes as Scope[]);\n this.#onDisconnect();\n this.#clearConnectionState();\n\n // Note: We intentionally do NOT remove the display_uri and wallet_sessionChanged\n // listeners here. These are instance-scoped listeners that should remain active\n // for the lifetime of the SDK instance, allowing reconnection to work properly.\n // Session-scoped listeners (like the notification handler below) are removed.\n\n this.#removeNotificationHandler?.();\n this.#removeNotificationHandler = undefined;\n\n logger('fulfilled-request: disconnect');\n }\n\n /**\n * Switches the Ethereum chain. Will track state internally whenever possible.\n *\n * @param options - The options for the switch chain request\n * @param options.chainId - The chain ID to switch to\n * @param [options.chainConfiguration] - The chain configuration to use in case the chain is not present by the wallet\n * @returns A promise that resolves when the chain has been switched\n */\n async switchChain({\n chainId,\n chainConfiguration,\n }: {\n chainId: Hex;\n chainConfiguration?: AddEthereumChainParameter;\n }): Promise<void> {\n const method = 'wallet_switchEthereumChain';\n const scope: Scope = `eip155:${hexToNumber(chainId)}`;\n const params = [{ chainId }];\n\n // TODO (wenfix): better way to return here other than resolving.\n if (this.selectedChainId === chainId) {\n return Promise.resolve();\n }\n\n const permittedChainIds = getPermittedEthChainIds(this.#sessionScopes);\n\n if (\n permittedChainIds.includes(chainId) &&\n this.#core.transportType === TransportType.MWP\n ) {\n await this.#cacheChainId(chainId);\n this.#onChainChanged(chainId);\n return Promise.resolve();\n }\n\n await this.#trackWalletActionRequested(method, scope, params);\n\n try {\n const result = await this.#request({\n method: 'wallet_switchEthereumChain',\n params,\n });\n\n // When using the MWP transport, the error is returned instead of thrown,\n // so we force it into the catch block here.\n const resultWithError = result as { error?: { message: string } };\n if (resultWithError?.error) {\n throw new Error(resultWithError.error.message);\n }\n\n await this.#trackWalletActionSucceeded(method, scope, params);\n if ((result as { result: unknown }).result === null) {\n // result is successful we eagerly call onChainChanged to update the provider's selected chain ID.\n await this.#cacheChainId(chainId);\n this.#onChainChanged(chainId);\n }\n return Promise.resolve();\n } catch (error) {\n await this.#trackWalletActionFailed(method, scope, params, error);\n // Fallback to add the chain if its not configured in the wallet.\n if ((error as Error).message.includes('Unrecognized chain ID')) {\n return this.#addEthereumChain(chainConfiguration);\n }\n throw error;\n }\n }\n\n /**\n * Handles several EIP-1193 requests that require special handling\n * due the nature of the Multichain SDK.\n *\n * @param request - The request object containing the method and params\n * @returns The result of the request or undefined if the request is ignored\n */\n async #requestInterceptor(\n request: ProviderRequest,\n ): ReturnType<ProviderRequestInterceptor> {\n logger(`Intercepting request for method: ${request.method}`);\n\n if (IGNORED_METHODS.includes(request.method)) {\n // TODO: replace with correct method unsupported provider error\n return Promise.reject(\n new Error(\n `Method: ${request.method} is not supported by Metamask Connect/EVM`,\n ),\n );\n }\n\n if (request.method === 'wallet_revokePermissions') {\n return this.disconnect();\n }\n\n if (isConnectRequest(request)) {\n // When calling wallet_requestPermissions, we need to force a new session request to prompt\n // the user for accounts, because internally the Multichain SDK will check if\n // the user is already connected and skip the request if so, unless we\n // explicitly request a specific account. This is needed to workaround\n // wallet_requestPermissions not requesting specific accounts.\n const shouldForceConnectionRequest =\n request.method === 'wallet_requestPermissions';\n\n const { method, params } = request;\n const permitted = getPermittedEthChainIds(this.#sessionScopes);\n if (permitted.length === 0) {\n permitted.push(DEFAULT_CHAIN_ID);\n }\n\n const selected = this.#provider.selectedChainId;\n const preferred =\n selected && permitted.includes(selected) ? selected : permitted[0];\n\n const chainIds = [\n preferred,\n ...permitted.filter((id) => id !== preferred),\n ];\n\n const scope: Scope = `eip155:${hexToNumber(preferred)}`;\n\n await this.#trackWalletActionRequested(method, scope, params);\n\n try {\n const result = await this.connect({\n chainIds,\n forceRequest: shouldForceConnectionRequest,\n });\n await this.#trackWalletActionSucceeded(method, scope, params);\n return result;\n } catch (error) {\n await this.#trackWalletActionFailed(method, scope, params, error);\n throw error;\n }\n }\n\n if (isSwitchChainRequest(request)) {\n return this.switchChain({\n chainId: request.params[0].chainId as Hex,\n });\n }\n\n if (isAddChainRequest(request)) {\n return this.#addEthereumChain(request.params[0]);\n }\n\n if (isAccountsRequest(request)) {\n return this.#provider.accounts;\n }\n\n if (isChainIdRequest(request)) {\n return this.#provider.selectedChainId;\n }\n\n logger('Request not intercepted, forwarding to default handler', request);\n return Promise.resolve();\n }\n\n /**\n * Clears the internal connection state: accounts and chainId\n */\n #clearConnectionState(): void {\n this.#provider.accounts = [];\n this.#provider.selectedChainId = undefined;\n }\n\n /**\n * Adds an Ethereum chain using the latest chain configuration received from\n * a switchEthereumChain request\n *\n * @param chainConfiguration - The chain configuration to use in case the chain is not present by the wallet\n * @returns Nothing\n */\n async #addEthereumChain(\n chainConfiguration?: AddEthereumChainParameter,\n ): Promise<void> {\n logger('addEthereumChain called', { chainConfiguration });\n const method = 'wallet_addEthereumChain';\n\n if (!chainConfiguration) {\n throw new Error('No chain configuration found.');\n }\n\n // Get chain ID from config or use current chain\n const chainId =\n (chainConfiguration.chainId as Hex) ||\n this.#provider.selectedChainId ||\n '0x1';\n const decimalChainId = hexToNumber(chainId);\n const scope: Scope = `eip155:${decimalChainId}`;\n const params = [chainConfiguration];\n\n await this.#trackWalletActionRequested(method, scope, params);\n\n try {\n const result = await this.#request({\n method: 'wallet_addEthereumChain',\n params,\n });\n\n if ((result as { result: unknown }).result === null) {\n // if result is successful we eagerly call onChainChanged to update the provider's selected chain ID.\n await this.#cacheChainId(chainId);\n this.#onChainChanged(chainId);\n }\n await this.#trackWalletActionSucceeded(method, scope, params);\n } catch (error) {\n await this.#trackWalletActionFailed(method, scope, params, error);\n throw error;\n }\n }\n\n /**\n * Submits a request to the EIP-1193 provider\n *\n * @param request - The request object containing the method and params\n * @param request.method - The method to request\n * @param request.params - The parameters to pass to the method\n * @returns The result of the request\n */\n async #request(request: {\n method: string;\n params: unknown[];\n }): Promise<unknown> {\n logger('direct request to metamask-provider called', request);\n const result = this.#core.transport.sendEip1193Message(request);\n if (\n request.method === 'wallet_addEthereumChain' ||\n request.method === 'wallet_switchEthereumChain'\n ) {\n this.#core.openSimpleDeeplinkIfNeeded();\n }\n return result;\n }\n\n /**\n * Caches the chainId to storage for persistence across page refreshes.\n *\n * @param chainId - The hex chain ID\n */\n async #cacheChainId(chainId: Hex): Promise<void> {\n try {\n await this.#core.storage.adapter.set(\n CHAIN_STORE_KEY,\n JSON.stringify(chainId),\n );\n } catch (error) {\n logger('Error caching chainId', error);\n }\n }\n\n async #onSessionChanged(session?: SessionData): Promise<void> {\n logger('event: wallet_sessionChanged', session);\n this.#sessionScopes = session?.sessionScopes ?? {};\n const hexPermittedChainIds = getPermittedEthChainIds(this.#sessionScopes);\n if (hexPermittedChainIds.length === 0) {\n this.#onDisconnect();\n } else {\n let initialAccounts: Address[] = [];\n if (this.#core.status === 'connected') {\n const ethAccountsResponse =\n await this.#core.transport.sendEip1193Message({\n method: 'eth_accounts',\n params: [],\n });\n initialAccounts = ethAccountsResponse.result as Address[];\n } else {\n initialAccounts = getEthAccounts(this.#sessionScopes);\n }\n\n const chainId = await this.#getSelectedChainId(hexPermittedChainIds);\n\n this.#onConnect({\n chainId,\n accounts: initialAccounts,\n });\n }\n }\n\n /**\n * Handles chain change events and updates the provider's selected chain ID.\n *\n * @param chainId - The new hex chain ID\n */\n #onChainChanged(chainId: Hex): void {\n if (chainId === this.#provider.selectedChainId) {\n return;\n }\n logger('handler: chainChanged', { chainId });\n this.#provider.selectedChainId = chainId;\n this.#provider.emit('chainChanged', chainId);\n this.#eventHandlers?.chainChanged?.(chainId);\n }\n\n /**\n * Handles accounts change events and updates the provider's accounts list.\n *\n * @param accounts - The new list of permitted accounts\n */\n #onAccountsChanged(accounts: Address[]): void {\n const accountsUnchanged =\n accounts.length === this.#provider.accounts.length &&\n accounts.every((acct, idx) => acct === this.#provider.accounts[idx]);\n if (accountsUnchanged) {\n return;\n }\n logger('handler: accountsChanged', accounts);\n this.#provider.accounts = accounts;\n this.#provider.emit('accountsChanged', accounts);\n this.#eventHandlers?.accountsChanged?.(accounts);\n }\n\n /**\n * Handles connection events and emits the connect event to listeners.\n *\n * @param options - The connection options\n * @param options.chainId - The hex chain ID of the connection\n * @param options.accounts - The accounts of the connection\n */\n #onConnect({\n chainId,\n accounts,\n }: {\n chainId: Hex;\n accounts: Address[];\n }): void {\n logger('handler: connect', { chainId, accounts });\n const data = {\n chainId,\n accounts,\n };\n\n if (this.#status === 'connected') {\n this.#onChainChanged(chainId);\n this.#onAccountsChanged(accounts);\n return;\n }\n\n this.#provider.selectedChainId = chainId;\n this.#provider.accounts = accounts;\n\n this.#status = 'connected';\n this.#provider.emit('connect', data);\n this.#eventHandlers?.connect?.(data);\n\n this.#provider.emit('chainChanged', chainId);\n this.#eventHandlers?.chainChanged?.(chainId);\n\n this.#provider.emit('accountsChanged', accounts);\n this.#eventHandlers?.accountsChanged?.(accounts);\n\n this.#removeNotificationHandler?.();\n\n const onAccountsChanged = (accs: string[]): void => {\n logger('core-event: accountsChanged', accs);\n this.#onAccountsChanged(accs as Address[]);\n };\n\n const onChainChanged = (chainChanged: { chainId: string }): void => {\n logger('core-event: chainChanged', chainChanged.chainId);\n this.#cacheChainId(chainChanged.chainId as Hex).catch((error) => {\n logger('Error caching chainId in notification handler', error);\n });\n this.#onChainChanged(chainChanged.chainId as Hex);\n };\n\n this.#core.on('metamask_accountsChanged', onAccountsChanged);\n this.#core.on('metamask_chainChanged', onChainChanged);\n\n this.#removeNotificationHandler = (): void => {\n this.#core.off('metamask_accountsChanged', onAccountsChanged);\n this.#core.off('metamask_chainChanged', onChainChanged);\n };\n }\n\n /**\n * Handles disconnection events and emits the disconnect event to listeners.\n * Also clears accounts by triggering an accountsChanged event with an empty array.\n */\n #onDisconnect(): void {\n if (this.#status === 'disconnected') {\n return;\n }\n this.#status = 'disconnected';\n\n logger('handler: disconnect');\n this.#provider.emit('disconnect');\n this.#eventHandlers?.disconnect?.();\n\n this.#onAccountsChanged([]);\n }\n\n /**\n * Handles display_uri events and emits them to the provider.\n * This allows consumers to display their own custom QR code UI.\n *\n * @param uri - The deeplink URI to be displayed as a QR code\n */\n #onDisplayUri(uri: string): void {\n if (this.#status !== 'connecting') {\n return;\n }\n\n logger('handler: display_uri', uri);\n this.#provider.emit('display_uri', uri);\n this.#eventHandlers?.displayUri?.(uri);\n }\n\n /**\n * Gets the EIP-1193 provider instance\n *\n * @returns The EIP-1193 provider instance\n */\n getProvider(): EIP1193Provider {\n return this.#provider;\n }\n\n /**\n * Gets the currently selected chain ID on the wallet\n *\n * @returns The currently selected chain ID or undefined if no chain is selected\n */\n getChainId(): Hex | undefined {\n return this.selectedChainId;\n }\n\n /**\n * Gets the currently selected account on the wallet\n *\n * @returns The currently selected account or undefined if no account is selected\n */\n getAccount(): Address | undefined {\n return this.#provider.selectedAccount;\n }\n\n // Convenience getters for the EIP-1193 provider\n /**\n * Gets the currently permitted accounts\n *\n * @returns The currently permitted accounts\n */\n get accounts(): Address[] {\n return this.#provider.accounts;\n }\n\n /**\n * Gets the currently selected account on the wallet\n *\n * @returns The currently selected account or undefined if no account is selected\n */\n get selectedAccount(): Address | undefined {\n return this.#provider.selectedAccount;\n }\n\n /**\n * Gets the currently selected chain ID on the wallet\n *\n * @returns The currently selected chain ID or undefined if no chain is selected\n */\n get selectedChainId(): Hex | undefined {\n return this.#provider.selectedChainId;\n }\n\n /**\n * Gets the current connection status\n *\n * @returns The current connection status\n */\n get status(): ConnectEvmStatus {\n return this.#status;\n }\n}\n\n/**\n * Creates a new Metamask Connect/EVM instance\n *\n * @param options - The options for the Metamask Connect/EVM layer\n * @param options.dapp - Dapp identification and branding settings\n * @param options.api - API configuration including read-only RPC map\n * @param options.api.supportedNetworks - A map of hex chain IDs to RPC URLs for read-only requests\n * @param [options.analytics.integrationType] - Integration type for analytics\n * @param [options.ui] - UI configuration options\n * @param [options.ui.headless] - Whether to run without UI\n * @param [options.ui.preferExtension] - Whether to prefer browser extension\n * @param [options.ui.showInstallModal] - Whether to render installation modal for desktop extension\n * @param [options.mobile] - Mobile configuration options\n * @param [options.mobile.preferredOpenLink] - Custom handler for opening deeplinks (useful for React Native, etc.)\n * @param [options.mobile.useDeeplink] - Whether to use native deeplinks instead of universal links\n * @param [options.transport] - Transport configuration (e.g., extensionId, notification handler)\n * @param [options.transport.extensionId] - Extension ID for browser extension transport\n * @param [options.transport.onNotification] - Callback for receiving transport notifications\n * @param [options.eventHandlers] - Event handlers for the Metamask Connect/EVM layer\n * @param [options.debug] - Enable debug logging\n * @returns The Metamask-Connect EVM client instance\n */\nexport async function createEVMClient(\n options: Pick<\n MultichainOptions,\n 'dapp' | 'mobile' | 'transport' | 'analytics'\n > & {\n ui?: Omit<MultichainOptions['ui'], 'factory'>;\n } & {\n eventHandlers?: Partial<EventHandlers>;\n debug?: boolean;\n api: {\n supportedNetworks: Record<Hex, string>;\n };\n },\n): Promise<MetamaskConnectEVM> {\n if (options.debug) {\n enableDebug();\n }\n\n logger('Creating Metamask Connect/EVM with options:', options);\n\n // Validate that supportedNetworks is provided and not empty\n if (\n !options.api?.supportedNetworks ||\n Object.keys(options.api.supportedNetworks).length === 0\n ) {\n throw new Error(\n 'supportedNetworks is required and must contain at least one chain configuration',\n );\n }\n\n validSupportedChainsUrls(options.api.supportedNetworks, 'supportedNetworks');\n\n const supportedNetworksCaipChainId = Object.entries(\n options.api.supportedNetworks,\n ).reduce<Record<string, string>>((acc, [hexChainId, url]) => {\n const decimalChainId = parseInt(hexChainId, 16);\n const caip2ChainId = `eip155:${decimalChainId}`;\n acc[caip2ChainId] = url;\n return acc;\n }, {});\n\n try {\n const core = await createMultichainClient({\n ...options,\n api: {\n supportedNetworks: supportedNetworksCaipChainId,\n },\n analytics: {\n // eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing\n integrationType: options.analytics?.integrationType || 'direct',\n },\n versions: {\n // typeof guard needed: Metro (React Native) bundles TS source directly,\n // bypassing the tsup build that substitutes __PACKAGE_VERSION__.\n 'connect-evm':\n typeof __PACKAGE_VERSION__ === 'undefined'\n ? 'unknown'\n : __PACKAGE_VERSION__,\n },\n });\n\n return MetamaskConnectEVM.create({\n core,\n eventHandlers: options.eventHandlers,\n supportedNetworks: options.api.supportedNetworks,\n });\n } catch (error) {\n console.error('Error creating Metamask Connect/EVM', error);\n throw error;\n }\n}\n","export const IGNORED_METHODS = [\n 'metamask_getProviderState',\n 'metamask_sendDomainMetadata',\n 'metamask_logWeb3ShimUsage',\n 'wallet_registerOnboarding',\n 'net_version',\n 'wallet_getPermissions',\n];\n\nexport const CONNECT_METHODS = [\n 'wallet_requestPermissions',\n 'eth_requestAccounts',\n];\n\nexport const ACCOUNTS_METHODS = ['eth_accounts', 'eth_coinbase'];\n\nexport const CHAIN_METHODS = ['eth_chainId'];\n\nexport const INTERCEPTABLE_METHODS = [\n ...ACCOUNTS_METHODS,\n ...IGNORED_METHODS,\n ...CONNECT_METHODS,\n ...CHAIN_METHODS,\n // These have bespoke handlers\n 'wallet_revokePermissions',\n 'wallet_switchEthereumChain',\n 'wallet_addEthereumChain',\n];\n","import {\n createLogger,\n enableDebug as debug,\n} from '@metamask/connect-multichain';\n\nconst namespace = 'metamask-connect:evm';\n\n// @ts-expect-error logger needs to be typed properly\nexport const logger = createLogger(namespace, '63');\n\nexport const enableDebug = (): void => {\n // @ts-expect-error logger needs to be typed properly\n debug(namespace);\n};\n","/* eslint-disable promise/always-return -- Legacy callback patterns */\n/* eslint-disable promise/no-callback-in-promise -- Legacy sendAsync/send API */\n/* eslint-disable consistent-return -- Legacy method returns void or Promise */\n/* eslint-disable @typescript-eslint/no-floating-promises -- Legacy fire-and-forget pattern */\n/* eslint-disable jsdoc/require-returns -- Inherited from abstract class */\nimport type { MultichainCore, Scope } from '@metamask/connect-multichain';\nimport { EventEmitter, RPCInvokeMethodErr } from '@metamask/connect-multichain';\nimport { hexToNumber } from '@metamask/utils';\n\nimport { INTERCEPTABLE_METHODS } from './constants';\nimport { logger } from './logger';\nimport type {\n Address,\n EIP1193ProviderEvents,\n Hex,\n JsonRpcCallback,\n JsonRpcRequest,\n JsonRpcResponse,\n ProviderRequest,\n ProviderRequestInterceptor,\n} from './types';\n\n/**\n * EIP-1193 Provider wrapper around the Multichain SDK.\n */\nexport class EIP1193Provider extends EventEmitter<EIP1193ProviderEvents> {\n /** The core instance of the Multichain SDK */\n readonly #core: MultichainCore;\n\n /** Interceptor function to handle specific methods */\n readonly #requestInterceptor: ProviderRequestInterceptor;\n\n /** The currently permitted accounts */\n #accounts: Address[] = [];\n\n /** The currently selected chain ID on the wallet */\n #selectedChainId?: Hex | undefined;\n\n constructor(core: MultichainCore, interceptor: ProviderRequestInterceptor) {\n super();\n this.#core = core;\n this.#requestInterceptor = interceptor;\n\n // Bind all public methods to ensure `this` context is preserved\n // when methods are extracted or passed as callbacks.\n // This eliminates the need for Proxy wrappers in consumers.\n this.request = this.request.bind(this);\n this.sendAsync = this.sendAsync.bind(this);\n this.send = this.send.bind(this);\n\n // Bind inherited EventEmitter methods\n this.on = this.on.bind(this);\n this.off = this.off.bind(this);\n this.emit = this.emit.bind(this);\n this.once = this.once.bind(this);\n this.removeListener = this.removeListener.bind(this);\n this.listenerCount = this.listenerCount.bind(this);\n }\n\n /**\n * Performs a EIP-1193 request.\n *\n * @param request - The request object containing the method and params\n * @returns The result of the request\n */\n async request(request: ProviderRequest): Promise<unknown> {\n logger(\n `request: ${request.method} - chainId: ${this.selectedChainId}`,\n request.params,\n );\n /* Some methods require special handling, so we intercept them here\n * and handle them in MetamaskConnectEVM.requestInterceptor method. */\n if (INTERCEPTABLE_METHODS.includes(request.method)) {\n return this.#requestInterceptor?.(request);\n }\n\n if (!this.#selectedChainId) {\n // TODO: replace with a better error\n throw new Error('No chain ID selected');\n }\n\n const decimalChainId = hexToNumber(this.#selectedChainId);\n const scope: Scope = `eip155:${decimalChainId}`;\n\n // Validate that the chain is configured in supportedNetworks\n // This check is performed here to provide better error messages\n // The RpcClient will also validate, but this gives us a chance to provide\n // a clearer error message before the request is routed\n const coreOptions = (this.#core as any).options; // TODO: options is `protected readonly` property, this needs to be refactored so `any` type assertion is not necessary\n const supportedNetworks = coreOptions?.api?.supportedNetworks ?? {};\n if (!supportedNetworks[scope]) {\n throw new Error(\n `Chain ${scope} is not configured in supportedNetworks. Requests cannot be made to chains not explicitly configured in supportedNetworks.`,\n );\n }\n\n try {\n return await this.#core.invokeMethod({\n scope,\n request: {\n method: request.method,\n params: request.params,\n },\n });\n } catch (error) {\n if (error instanceof RPCInvokeMethodErr && error.rpcCode !== undefined) {\n const rpcError = new Error(\n error.rpcMessage ?? error.reason,\n ) as Error & { code: number };\n rpcError.code = error.rpcCode;\n throw rpcError;\n }\n throw error;\n }\n }\n\n // Getters and setters\n public get selectedAccount(): Address | undefined {\n return this.accounts[0];\n }\n\n public set accounts(accounts: Address[]) {\n this.#accounts = accounts;\n }\n\n public get accounts(): Address[] {\n return this.#accounts;\n }\n\n public get selectedChainId(): Hex | undefined {\n return this.#selectedChainId;\n }\n\n public set selectedChainId(chainId: Hex | undefined) {\n this.#selectedChainId = chainId;\n }\n\n // ==========================================\n // Legacy compatibility methods\n // ==========================================\n\n /**\n * Alias for selectedChainId for legacy compatibility.\n * Many dApps expect a `chainId` property on the provider.\n */\n public get chainId(): Hex | undefined {\n return this.selectedChainId;\n }\n\n /**\n * Legacy method for sending JSON-RPC requests.\n *\n * @deprecated Use `request` instead. This method is provided for backwards compatibility.\n * @param request - The JSON-RPC request object\n * @param callback - Optional callback function. If provided, the method returns void.\n * @returns A promise resolving to the JSON-RPC response, or void if a callback is provided.\n */\n async sendAsync<TParams = unknown, TResult = unknown>(\n request: JsonRpcRequest<TParams>,\n callback?: JsonRpcCallback<TResult>,\n ): Promise<JsonRpcResponse<TResult> | void> {\n const id = request.id ?? 1;\n\n const promise = this.request({\n method: request.method,\n params: request.params as unknown,\n })\n .then(\n (result): JsonRpcResponse<TResult> => ({\n id,\n jsonrpc: '2.0',\n result: result as TResult,\n }),\n )\n .catch(\n (error): JsonRpcResponse<TResult> => ({\n id,\n jsonrpc: '2.0',\n error: {\n code: error.code ?? -32603,\n message: error.message ?? 'Internal error',\n data: error.data,\n },\n }),\n );\n\n if (callback) {\n promise\n .then((response) => {\n if (response.error) {\n callback(new Error(response.error.message), response);\n } else {\n callback(null, response);\n }\n })\n .catch((error) => {\n callback(error, null);\n });\n return;\n }\n\n return promise;\n }\n\n /**\n * Legacy method for sending JSON-RPC requests synchronously (callback-based).\n *\n * @deprecated Use `request` instead. This method is provided for backwards compatibility.\n * @param request - The JSON-RPC request object\n * @param callback - The callback function to receive the response\n */\n send<TParams = unknown, TResult = unknown>(\n request: JsonRpcRequest<TParams>,\n callback: JsonRpcCallback<TResult>,\n ): void {\n this.sendAsync(request, callback);\n }\n}\n","import type { InternalScopesObject } from '@metamask/chain-agnostic-permission';\nimport {\n getPermittedEthChainIds as _getPermittedEthChainIds,\n getEthAccounts as _getEthAccounts,\n} from '@metamask/chain-agnostic-permission';\nimport type { SessionData } from '@metamask/connect-multichain';\n\nimport type { Address, Hex } from '../types';\n\n/**\n * Get the Ethereum accounts from the session data\n *\n * @param sessionScopes - The session scopes\n * @returns The Ethereum accounts\n */\nexport const getEthAccounts = (\n sessionScopes: SessionData['sessionScopes'] | undefined,\n): Address[] => {\n if (!sessionScopes) {\n return [];\n }\n\n return _getEthAccounts({\n requiredScopes: sessionScopes as InternalScopesObject,\n optionalScopes: sessionScopes as InternalScopesObject,\n });\n};\n\n/**\n * Get the permitted Ethereum chain IDs from the session scopes.\n * Wrapper around getPermittedEthChainIds from @metamask/chain-agnostic-permission\n *\n * @param sessionScopes - The session scopes\n * @returns The permitted Ethereum chain IDs\n */\nexport const getPermittedEthChainIds = (\n sessionScopes: SessionData['sessionScopes'] | undefined,\n): Hex[] => {\n if (!sessionScopes) {\n return [];\n }\n\n return _getPermittedEthChainIds({\n requiredScopes: sessionScopes as InternalScopesObject,\n optionalScopes: sessionScopes as InternalScopesObject,\n });\n};\n","import type { ProviderRequest } from '../types';\n\n/**\n * Type guard for connect-like requests:\n * - wallet_requestPermissions\n * - eth_requestAccounts\n *\n * @param req - The request object to check\n * @returns True if the request is a connect-like request, false otherwise\n */\nexport function isConnectRequest(req: ProviderRequest): req is Extract<\n ProviderRequest,\n {\n method: 'wallet_requestPermissions' | 'eth_requestAccounts';\n }\n> {\n return (\n req.method === 'wallet_requestPermissions' ||\n req.method === 'eth_requestAccounts'\n );\n}\n\n/**\n * Type guard for wallet_switchEthereumChain request.\n *\n * @param req - The request object to check\n * @returns True if the request is a wallet_switchEthereumChain request, false otherwise\n */\nexport function isSwitchChainRequest(\n req: ProviderRequest,\n): req is Extract<ProviderRequest, { method: 'wallet_switchEthereumChain' }> {\n return req.method === 'wallet_switchEthereumChain';\n}\n\n/**\n * Type guard for wallet_addEthereumChain request.\n *\n * @param req - The request object to check\n * @returns True if the request is a wallet_addEthereumChain request, false otherwise\n */\nexport function isAddChainRequest(\n req: ProviderRequest,\n): req is Extract<ProviderRequest, { method: 'wallet_addEthereumChain' }> {\n return req.method === 'wallet_addEthereumChain';\n}\n\n/**\n * Type guard for generic accounts request:\n * - eth_accounts\n * - eth_coinbase\n *\n * @param req - The request object to check\n * @returns True if the request is a generic accounts request, false otherwise\n */\nexport function isAccountsRequest(\n req: ProviderRequest,\n): req is Extract<\n ProviderRequest,\n { method: 'eth_accounts' | 'eth_coinbase' }\n> {\n return req.method === 'eth_accounts' || req.method === 'eth_coinbase';\n}\n\n/**\n * Type guard for generic eth_chainId request.\n *\n * @param req - The request object to check\n * @returns True if the request is a eth_chainId request, false otherwise\n */\nexport function isChainIdRequest(\n req: ProviderRequest,\n): req is Extract<ProviderRequest, { method: 'eth_chainId' }> {\n return req.method === 'eth_chainId';\n}\n\n/**\n * Validates that all values in a Record are valid URLs.\n *\n * @param record - The record to validate (e.g., supportedNetworks)\n * @param recordName - The name of the record for error messages\n * @throws Error if any values are invalid URLs\n */\nexport function validSupportedChainsUrls(\n record: Record<string, string>,\n recordName: string,\n): void {\n const invalidUrls: string[] = [];\n for (const [key, url] of Object.entries(record)) {\n try {\n // eslint-disable-next-line no-new\n new URL(url);\n } catch {\n invalidUrls.push(`${key}: ${url}`);\n }\n }\n\n if (invalidUrls.length > 0) {\n throw new Error(\n `${recordName} contains invalid URLs:\\n${invalidUrls.join('\\n')}`,\n );\n }\n}\n"],"mappings":"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","names":["namespace","hexToNumber","hexToNumber","hexToNumber","_a","_core","hexToNumber","namespace"]}
@@ -81,13 +81,17 @@ export declare class MetamaskConnectEVM {
81
81
  * @param options - The connection options
82
82
  * @param options.message - The message to sign after connecting
83
83
  * @param [options.chainIds] - Optional hex chain IDs to connect to (defaults to ethereum mainnet if not provided)
84
- * @returns A promise that resolves with the signature
84
+ * @returns A promise that resolves with the connected accounts, chainId, and signature
85
85
  * @throws Error if the selected account is not available after timeout
86
86
  */
87
87
  connectAndSign({ message, chainIds, }: {
88
88
  message: string;
89
89
  chainIds?: Hex[];
90
- }): Promise<string>;
90
+ }): Promise<{
91
+ accounts: Address[];
92
+ chainId: Hex;
93
+ signature: string;
94
+ }>;
91
95
  /**
92
96
  * Connects to the wallet and invokes a method with specified parameters.
93
97
  *
@@ -97,7 +101,7 @@ export declare class MetamaskConnectEVM {
97
101
  * @param [options.chainIds] - Optional hex chain IDs to connect to (defaults to ethereum mainnet if not provided)
98
102
  * @param [options.account] - Optional specific account to connect to
99
103
  * @param [options.forceRequest] - Whether to force a request regardless of an existing session
100
- * @returns A promise that resolves with the result of the method invocation
104
+ * @returns A promise that resolves with the connected accounts, chainId, and the result of the method invocation
101
105
  * @throws Error if the selected account is not available after timeout (for methods that require an account)
102
106
  */
103
107
  connectWith({ method, params, chainIds, account, forceRequest, }: {
@@ -106,7 +110,11 @@ export declare class MetamaskConnectEVM {
106
110
  chainIds?: Hex[];
107
111
  account?: string | undefined;
108
112
  forceRequest?: boolean;
109
- }): Promise<unknown>;
113
+ }): Promise<{
114
+ accounts: Address[];
115
+ chainId: Hex;
116
+ result: unknown;
117
+ }>;
110
118
  /**
111
119
  * Disconnects from the wallet by revoking the session and cleaning up event listeners.
112
120
  *
@@ -1 +1 @@
1
- {"version":3,"file":"connect.d.ts","sourceRoot":"","sources":["../../src/connect.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"connect.d.ts","sourceRoot":"","sources":["../../src/connect.ts"],"names":[],"mappings":"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"}
@@ -18,13 +18,13 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (
18
18
  if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
19
19
  return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
20
20
  };
21
- var _MetamaskConnectEVM_instances, _MetamaskConnectEVM_core, _MetamaskConnectEVM_provider, _MetamaskConnectEVM_sessionScopes, _MetamaskConnectEVM_eventHandlers, _MetamaskConnectEVM_sessionChangedHandler, _MetamaskConnectEVM_displayUriHandler, _MetamaskConnectEVM_removeNotificationHandler, _MetamaskConnectEVM_status, _MetamaskConnectEVM_pendingPreferredChainId, _MetamaskConnectEVM_initPromise, _MetamaskConnectEVM_getCoreOptions, _MetamaskConnectEVM_createInvokeOptions, _MetamaskConnectEVM_trackWalletActionRequested, _MetamaskConnectEVM_trackWalletActionSucceeded, _MetamaskConnectEVM_trackWalletActionFailed, _MetamaskConnectEVM_getSelectedChainId, _MetamaskConnectEVM_requestInterceptor, _MetamaskConnectEVM_clearConnectionState, _MetamaskConnectEVM_addEthereumChain, _MetamaskConnectEVM_request, _MetamaskConnectEVM_cacheChainId, _MetamaskConnectEVM_onSessionChanged, _MetamaskConnectEVM_onChainChanged, _MetamaskConnectEVM_onAccountsChanged, _MetamaskConnectEVM_onConnect, _MetamaskConnectEVM_onDisconnect, _MetamaskConnectEVM_onDisplayUri;
21
+ var _MetamaskConnectEVM_instances, _MetamaskConnectEVM_core, _MetamaskConnectEVM_provider, _MetamaskConnectEVM_sessionScopes, _MetamaskConnectEVM_eventHandlers, _MetamaskConnectEVM_sessionChangedHandler, _MetamaskConnectEVM_displayUriHandler, _MetamaskConnectEVM_removeNotificationHandler, _MetamaskConnectEVM_status, _MetamaskConnectEVM_pendingPreferredChainId, _MetamaskConnectEVM_getCoreOptions, _MetamaskConnectEVM_createInvokeOptions, _MetamaskConnectEVM_trackWalletActionRequested, _MetamaskConnectEVM_trackWalletActionSucceeded, _MetamaskConnectEVM_trackWalletActionFailed, _MetamaskConnectEVM_getSelectedChainId, _MetamaskConnectEVM_requestInterceptor, _MetamaskConnectEVM_clearConnectionState, _MetamaskConnectEVM_addEthereumChain, _MetamaskConnectEVM_request, _MetamaskConnectEVM_cacheChainId, _MetamaskConnectEVM_onSessionChanged, _MetamaskConnectEVM_onChainChanged, _MetamaskConnectEVM_onAccountsChanged, _MetamaskConnectEVM_onConnect, _MetamaskConnectEVM_onDisconnect, _MetamaskConnectEVM_onDisplayUri;
22
22
  /* eslint-disable no-restricted-syntax -- Private class properties use established patterns */
23
23
  /* eslint-disable @typescript-eslint/naming-convention -- __PACKAGE_VERSION__ is an esbuild define convention */
24
24
  import { analytics } from '@metamask/analytics';
25
25
  import { parseScopeString } from '@metamask/chain-agnostic-permission';
26
26
  import { createMultichainClient, getWalletActionAnalyticsProperties, isRejectionError, TransportType, } from '@metamask/connect-multichain';
27
- import { createDeferredPromise, hexToNumber } from '@metamask/utils';
27
+ import { hexToNumber } from '@metamask/utils';
28
28
  import { IGNORED_METHODS } from './constants';
29
29
  import { enableDebug, logger } from './logger';
30
30
  import { EIP1193Provider } from './provider';
@@ -94,8 +94,6 @@ export class MetamaskConnectEVM {
94
94
  * so that an explicit chainIds request always wins over a prior cached value.
95
95
  */
96
96
  _MetamaskConnectEVM_pendingPreferredChainId.set(this, void 0);
97
- /** Deferred that resolves once #onSessionChanged has completed for the first time. */
98
- _MetamaskConnectEVM_initPromise.set(this, void 0);
99
97
  __classPrivateFieldSet(this, _MetamaskConnectEVM_core, core, "f");
100
98
  __classPrivateFieldSet(this, _MetamaskConnectEVM_provider, new EIP1193Provider(core, __classPrivateFieldGet(this, _MetamaskConnectEVM_instances, "m", _MetamaskConnectEVM_requestInterceptor).bind(this)), "f");
101
99
  __classPrivateFieldSet(this, _MetamaskConnectEVM_eventHandlers, eventHandlers, "f");
@@ -114,7 +112,6 @@ export class MetamaskConnectEVM {
114
112
  */
115
113
  __classPrivateFieldSet(this, _MetamaskConnectEVM_displayUriHandler, __classPrivateFieldGet(this, _MetamaskConnectEVM_instances, "m", _MetamaskConnectEVM_onDisplayUri).bind(this), "f");
116
114
  __classPrivateFieldGet(this, _MetamaskConnectEVM_core, "f").on('display_uri', __classPrivateFieldGet(this, _MetamaskConnectEVM_displayUriHandler, "f"));
117
- __classPrivateFieldSet(this, _MetamaskConnectEVM_initPromise, createDeferredPromise(), "f");
118
115
  logger('Connect/EVM constructor completed');
119
116
  }
120
117
  /**
@@ -131,8 +128,14 @@ export class MetamaskConnectEVM {
131
128
  static create(options) {
132
129
  return __awaiter(this, void 0, void 0, function* () {
133
130
  const instance = new MetamaskConnectEVM(options);
134
- yield __classPrivateFieldGet(instance, _MetamaskConnectEVM_core, "f").emitSessionChanged();
135
- yield __classPrivateFieldGet(instance, _MetamaskConnectEVM_initPromise, "f").promise;
131
+ let session;
132
+ try {
133
+ session = yield __classPrivateFieldGet(instance, _MetamaskConnectEVM_core, "f").provider.getSession();
134
+ }
135
+ catch (_a) {
136
+ session = { sessionScopes: {} };
137
+ }
138
+ yield __classPrivateFieldGet(instance, _MetamaskConnectEVM_instances, "m", _MetamaskConnectEVM_onSessionChanged).call(instance, session);
136
139
  return instance;
137
140
  });
138
141
  }
@@ -196,7 +199,7 @@ export class MetamaskConnectEVM {
196
199
  * @param options - The connection options
197
200
  * @param options.message - The message to sign after connecting
198
201
  * @param [options.chainIds] - Optional hex chain IDs to connect to (defaults to ethereum mainnet if not provided)
199
- * @returns A promise that resolves with the signature
202
+ * @returns A promise that resolves with the connected accounts, chainId, and signature
200
203
  * @throws Error if the selected account is not available after timeout
201
204
  */
202
205
  connectAndSign(_a) {
@@ -205,16 +208,16 @@ export class MetamaskConnectEVM {
205
208
  const { accounts, chainId } = yield this.connect({
206
209
  chainIds: chainIds !== null && chainIds !== void 0 ? chainIds : [DEFAULT_CHAIN_ID],
207
210
  });
208
- const result = (yield __classPrivateFieldGet(this, _MetamaskConnectEVM_provider, "f").request({
211
+ const signature = (yield __classPrivateFieldGet(this, _MetamaskConnectEVM_provider, "f").request({
209
212
  method: 'personal_sign',
210
213
  params: [accounts[0], message],
211
214
  }));
212
215
  (_c = (_b = __classPrivateFieldGet(this, _MetamaskConnectEVM_eventHandlers, "f")) === null || _b === void 0 ? void 0 : _b.connectAndSign) === null || _c === void 0 ? void 0 : _c.call(_b, {
213
216
  accounts,
214
217
  chainId,
215
- signResponse: result,
218
+ signature,
216
219
  });
217
- return result;
220
+ return { accounts, chainId, signature };
218
221
  });
219
222
  }
220
223
  /**
@@ -226,7 +229,7 @@ export class MetamaskConnectEVM {
226
229
  * @param [options.chainIds] - Optional hex chain IDs to connect to (defaults to ethereum mainnet if not provided)
227
230
  * @param [options.account] - Optional specific account to connect to
228
231
  * @param [options.forceRequest] - Whether to force a request regardless of an existing session
229
- * @returns A promise that resolves with the result of the method invocation
232
+ * @returns A promise that resolves with the connected accounts, chainId, and the result of the method invocation
230
233
  * @throws Error if the selected account is not available after timeout (for methods that require an account)
231
234
  */
232
235
  connectWith(_a) {
@@ -245,9 +248,9 @@ export class MetamaskConnectEVM {
245
248
  (_c = (_b = __classPrivateFieldGet(this, _MetamaskConnectEVM_eventHandlers, "f")) === null || _b === void 0 ? void 0 : _b.connectWith) === null || _c === void 0 ? void 0 : _c.call(_b, {
246
249
  accounts: connectedAccounts,
247
250
  chainId: connectedChainId,
248
- connectWithResponse: result,
251
+ result,
249
252
  });
250
- return result;
253
+ return { accounts: connectedAccounts, chainId: connectedChainId, result };
251
254
  });
252
255
  }
253
256
  /**
@@ -388,7 +391,7 @@ export class MetamaskConnectEVM {
388
391
  return __classPrivateFieldGet(this, _MetamaskConnectEVM_status, "f");
389
392
  }
390
393
  }
391
- _MetamaskConnectEVM_core = new WeakMap(), _MetamaskConnectEVM_provider = new WeakMap(), _MetamaskConnectEVM_sessionScopes = new WeakMap(), _MetamaskConnectEVM_eventHandlers = new WeakMap(), _MetamaskConnectEVM_sessionChangedHandler = new WeakMap(), _MetamaskConnectEVM_displayUriHandler = new WeakMap(), _MetamaskConnectEVM_removeNotificationHandler = new WeakMap(), _MetamaskConnectEVM_status = new WeakMap(), _MetamaskConnectEVM_pendingPreferredChainId = new WeakMap(), _MetamaskConnectEVM_initPromise = new WeakMap(), _MetamaskConnectEVM_instances = new WeakSet(), _MetamaskConnectEVM_getCoreOptions = function _MetamaskConnectEVM_getCoreOptions() {
394
+ _MetamaskConnectEVM_core = new WeakMap(), _MetamaskConnectEVM_provider = new WeakMap(), _MetamaskConnectEVM_sessionScopes = new WeakMap(), _MetamaskConnectEVM_eventHandlers = new WeakMap(), _MetamaskConnectEVM_sessionChangedHandler = new WeakMap(), _MetamaskConnectEVM_displayUriHandler = new WeakMap(), _MetamaskConnectEVM_removeNotificationHandler = new WeakMap(), _MetamaskConnectEVM_status = new WeakMap(), _MetamaskConnectEVM_pendingPreferredChainId = new WeakMap(), _MetamaskConnectEVM_instances = new WeakSet(), _MetamaskConnectEVM_getCoreOptions = function _MetamaskConnectEVM_getCoreOptions() {
392
395
  return __classPrivateFieldGet(this, _MetamaskConnectEVM_core, "f").options;
393
396
  }, _MetamaskConnectEVM_createInvokeOptions = function _MetamaskConnectEVM_createInvokeOptions(method, scope, params) {
394
397
  return {
@@ -601,7 +604,6 @@ _MetamaskConnectEVM_core = new WeakMap(), _MetamaskConnectEVM_provider = new Wea
601
604
  accounts: initialAccounts,
602
605
  });
603
606
  }
604
- __classPrivateFieldGet(this, _MetamaskConnectEVM_initPromise, "f").resolve();
605
607
  });
606
608
  }, _MetamaskConnectEVM_onChainChanged = function _MetamaskConnectEVM_onChainChanged(chainId) {
607
609
  var _a, _b;
@@ -1 +1 @@
1
- {"version":3,"file":"connect.js","sourceRoot":"","sources":["../../src/connect.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"connect.js","sourceRoot":"","sources":["../../src/connect.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;AAAA,8FAA8F;AAC9F,gHAAgH;AAChH,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAChD,OAAO,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAC;AAOvE,OAAO,EACL,sBAAsB,EACtB,kCAAkC,EAClC,gBAAgB,EAChB,aAAa,GACd,MAAM,8BAA8B,CAAC;AACtC,OAAO,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC;AAE9C,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAC/C,OAAO,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAW7C,OAAO,EAAE,cAAc,EAAE,uBAAuB,EAAE,MAAM,cAAc,CAAC;AACvE,OAAO,EACL,iBAAiB,EACjB,iBAAiB,EACjB,gBAAgB,EAChB,gBAAgB,EAChB,oBAAoB,EACpB,wBAAwB,GACzB,MAAM,qBAAqB,CAAC;AAK7B,MAAM,gBAAgB,GAAG,KAAK,CAAC;AAC/B,MAAM,eAAe,GAAG,mBAAmB,CAAC;AAc5C;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AACH,MAAM,OAAO,kBAAkB;IAiC7B;;;;;;;OAOG;IACH,YAAoB,EAAE,IAAI,EAAE,aAAa,EAA6B;;QAxCtE,8CAA8C;QACrC,2CAAsB;QAE/B,qDAAqD;QAC5C,+CAA2B;QAEpC,6CAA6C;QAC7C,4CAA+C,EAAE,EAAC;QAElD,gEAAgE;QACvD,oDAAoD;QAE7D,sDAAsD;QAC7C,4DAAwD;QAEjE,4CAA4C;QACnC,wDAA0C;QAEnD,yDAAyD;QACzD,gEAAwC;QAExC,oCAAoC;QACpC,qCAA4B,cAAc,EAAC;QAE3C;;;;;WAKG;QACH,8DAA0C;QAWxC,uBAAA,IAAI,4BAAS,IAAI,MAAA,CAAC;QAElB,uBAAA,IAAI,gCAAa,IAAI,eAAe,CAClC,IAAI,EACJ,uBAAA,IAAI,6EAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,CACpC,MAAA,CAAC;QAEF,uBAAA,IAAI,qCAAkB,aAAa,MAAA,CAAC;QAEpC;;;;;WAKG;QACH,kEAAkE;QAClE,uBAAA,IAAI,6CAA0B,uBAAA,IAAI,2EAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,MAAA,CAAC;QAChE,uBAAA,IAAI,gCAAM,CAAC,EAAE,CAAC,uBAAuB,EAAE,uBAAA,IAAI,iDAAuB,CAAC,CAAC;QAEpE;;;WAGG;QACH,uBAAA,IAAI,yCAAsB,uBAAA,IAAI,uEAAc,CAAC,IAAI,CAAC,IAAI,CAAC,MAAA,CAAC;QACxD,uBAAA,IAAI,gCAAM,CAAC,EAAE,CAAC,aAAa,EAAE,uBAAA,IAAI,6CAAmB,CAAC,CAAC;QAEtD,MAAM,CAAC,mCAAmC,CAAC,CAAC;IAC9C,CAAC;IAED;;;;;;;;;;OAUG;IACH,MAAM,CAAO,MAAM,CACjB,OAAkC;;YAElC,MAAM,QAAQ,GAAG,IAAI,kBAAkB,CAAC,OAAO,CAAC,CAAC;YACjD,IAAI,OAAO,CAAC;YACZ,IAAI,CAAC;gBACH,OAAO,GAAG,MAAM,uBAAA,QAAQ,gCAAM,CAAC,QAAQ,CAAC,UAAU,EAAE,CAAC;YACvD,CAAC;YAAC,WAAM,CAAC;gBACP,OAAO,GAAG,EAAE,aAAa,EAAE,EAAE,EAAE,CAAC;YAClC,CAAC;YACD,MAAM,uBAAA,QAAQ,2EAAkB,MAA1B,QAAQ,EAAmB,OAAO,CAAC,CAAC;YAC1C,OAAO,QAAQ,CAAC;QAClB,CAAC;KAAA;IA8JD;;;;;;;;OAQG;IACG,OAAO;6DAAC,EACZ,OAAO,EACP,YAAY,EACZ,QAAQ,GAAG,CAAC,gBAAgB,CAAC,MACX,EAAE;;YACpB,MAAM,CAAC,kBAAkB,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC;YAExC,IAAI,CAAC,QAAQ,IAAI,QAAQ,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBACvC,MAAM,IAAI,KAAK,CAAC,oDAAoD,CAAC,CAAC;YACxE,CAAC;YAED,yEAAyE;YACzE,8EAA8E;YAC9E,iEAAiE;YACjE,uBAAA,IAAI,+CAA4B,QAAQ,CAAC,CAAC,CAAC,MAAA,CAAC;YAE5C,MAAM,YAAY,GAAG,KAAK,CAAC,IAAI,CAC7B,IAAI,GAAG,CAAC,MAAA,QAAQ,CAAC,MAAM,CAAC,gBAAgB,CAAC,mCAAI,CAAC,gBAAgB,CAAC,CAAC,CACjE,CAAC,GAAG,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,UAAU,WAAW,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;YAE3C,MAAM,cAAc,GAAG,OAAO;gBAC5B,CAAC,CAAC,YAAY,CAAC,GAAG,CAAC,CAAC,WAAW,EAAE,EAAE,CAAC,GAAG,WAAW,IAAI,OAAO,EAAE,CAAC;gBAChE,CAAC,CAAC,EAAE,CAAC;YAEP,uBAAA,IAAI,8BAAW,YAAY,MAAA,CAAC;YAE5B,IAAI,CAAC;gBACH,mFAAmF;gBACnF,MAAM,MAAM,GAAG,IAAI,OAAO,CACxB,CAAC,OAAO,EAAE,EAAE;oBACV,uBAAA,IAAI,oCAAU,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC,EAAE,OAAO,EAAE,QAAQ,EAAE,EAAE,EAAE;wBACvD,MAAM,CAAC,4BAA4B,EAAE;4BACnC,OAAO;4BACP,QAAQ;yBACT,CAAC,CAAC;wBACH,OAAO,CAAC;4BACN,QAAQ;4BACR,OAAO;yBACR,CAAC,CAAC;oBACL,CAAC,CAAC,CAAC;gBACL,CAAC,CACF,CAAC;gBAEF,MAAM,uBAAA,IAAI,gCAAM,CAAC,OAAO,CACtB,YAAuB,EACvB,cAAiC,EACjC,SAAS,EACT,YAAY,CACb,CAAC;gBAEF,sEAAsE;gBACtE,qDAAqD;gBACrD,OAAO,MAAM,MAAM,CAAC;YACtB,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,uBAAA,IAAI,8BAAW,cAAc,MAAA,CAAC;gBAC9B,MAAM,CAAC,4BAA4B,EAAE,KAAK,CAAC,CAAC;gBAC5C,MAAM,KAAK,CAAC;YACd,CAAC;oBAAS,CAAC;gBACT,uBAAA,IAAI,+CAA4B,SAAS,MAAA,CAAC;YAC5C,CAAC;QACH,CAAC;KAAA;IAED;;;;;;;;OAQG;IACG,cAAc;6DAAC,EACnB,OAAO,EACP,QAAQ,GAIT;;YACC,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC;gBAC/C,QAAQ,EAAE,QAAQ,aAAR,QAAQ,cAAR,QAAQ,GAAI,CAAC,gBAAgB,CAAC;aACzC,CAAC,CAAC;YAEH,MAAM,SAAS,GAAG,CAAC,MAAM,uBAAA,IAAI,oCAAU,CAAC,OAAO,CAAC;gBAC9C,MAAM,EAAE,eAAe;gBACvB,MAAM,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,OAAO,CAAC;aAC/B,CAAC,CAAW,CAAC;YAEd,MAAA,MAAA,uBAAA,IAAI,yCAAe,0CAAE,cAAc,mDAAG;gBACpC,QAAQ;gBACR,OAAO;gBACP,SAAS;aACV,CAAC,CAAC;YAEH,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,SAAS,EAAE,CAAC;QAC1C,CAAC;KAAA;IAED;;;;;;;;;;;OAWG;IACG,WAAW;6DAAC,EAChB,MAAM,EACN,MAAM,EACN,QAAQ,EACR,OAAO,EACP,YAAY,GAOb;;YACC,MAAM,EAAE,QAAQ,EAAE,iBAAiB,EAAE,OAAO,EAAE,gBAAgB,EAAE,GAC9D,MAAM,IAAI,CAAC,OAAO,CAAC;gBACjB,QAAQ,EAAE,QAAQ,aAAR,QAAQ,cAAR,QAAQ,GAAI,CAAC,gBAAgB,CAAC;gBACxC,OAAO;gBACP,YAAY;aACb,CAAC,CAAC;YAEL,MAAM,cAAc,GAClB,OAAO,MAAM,KAAK,UAAU,CAAC,CAAC,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC;YAEvE,MAAM,MAAM,GAAG,MAAM,uBAAA,IAAI,oCAAU,CAAC,OAAO,CAAC;gBAC1C,MAAM;gBACN,MAAM,EAAE,cAAc;aACvB,CAAC,CAAC;YAEH,MAAA,MAAA,uBAAA,IAAI,yCAAe,0CAAE,WAAW,mDAAG;gBACjC,QAAQ,EAAE,iBAAiB;gBAC3B,OAAO,EAAE,gBAAgB;gBACzB,MAAM;aACP,CAAC,CAAC;YAEH,OAAO,EAAE,QAAQ,EAAE,iBAAiB,EAAE,OAAO,EAAE,gBAAgB,EAAE,MAAM,EAAE,CAAC;QAC5E,CAAC;KAAA;IAED;;;;OAIG;IACG,UAAU;;;YACd,MAAM,CAAC,qBAAqB,CAAC,CAAC;YAE9B,MAAM,aAAa,GAAG,uBAAA,IAAI,yCAAe,CAAC;YAC1C,MAAM,YAAY,GAAG,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE;gBAC/D,MAAM,EAAE,SAAS,EAAE,GAAG,gBAAgB,CAAC,KAAc,CAAC,CAAC;gBACvD,OAAO,SAAS,KAAK,QAAQ,CAAC;YAChC,CAAC,CAAC,CAAC;YAEH,MAAM,uBAAA,IAAI,gCAAM,CAAC,UAAU,CAAC,YAAuB,CAAC,CAAC;YACrD,uBAAA,IAAI,uEAAc,MAAlB,IAAI,CAAgB,CAAC;YACrB,uBAAA,IAAI,+EAAsB,MAA1B,IAAI,CAAwB,CAAC;YAE7B,iFAAiF;YACjF,gFAAgF;YAChF,gFAAgF;YAChF,8EAA8E;YAE9E,MAAA,uBAAA,IAAI,qDAA2B,+CAA/B,IAAI,CAA+B,CAAC;YACpC,uBAAA,IAAI,iDAA8B,SAAS,MAAA,CAAC;YAE5C,MAAM,CAAC,+BAA+B,CAAC,CAAC;QAC1C,CAAC;KAAA;IAED;;;;;;;OAOG;IACG,WAAW;6DAAC,EAChB,OAAO,EACP,kBAAkB,GAInB;YACC,MAAM,MAAM,GAAG,4BAA4B,CAAC;YAC5C,MAAM,KAAK,GAAU,UAAU,WAAW,CAAC,OAAO,CAAC,EAAE,CAAC;YACtD,MAAM,MAAM,GAAG,CAAC,EAAE,OAAO,EAAE,CAAC,CAAC;YAE7B,iEAAiE;YACjE,IAAI,IAAI,CAAC,eAAe,KAAK,OAAO,EAAE,CAAC;gBACrC,OAAO,OAAO,CAAC,OAAO,EAAE,CAAC;YAC3B,CAAC;YAED,MAAM,iBAAiB,GAAG,uBAAuB,CAAC,uBAAA,IAAI,yCAAe,CAAC,CAAC;YAEvE,IACE,iBAAiB,CAAC,QAAQ,CAAC,OAAO,CAAC;gBACnC,uBAAA,IAAI,gCAAM,CAAC,aAAa,KAAK,aAAa,CAAC,GAAG,EAC9C,CAAC;gBACD,MAAM,uBAAA,IAAI,uEAAc,MAAlB,IAAI,EAAe,OAAO,CAAC,CAAC;gBAClC,uBAAA,IAAI,yEAAgB,MAApB,IAAI,EAAiB,OAAO,CAAC,CAAC;gBAC9B,OAAO,OAAO,CAAC,OAAO,EAAE,CAAC;YAC3B,CAAC;YAED,MAAM,uBAAA,IAAI,qFAA4B,MAAhC,IAAI,EAA6B,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;YAE9D,IAAI,CAAC;gBACH,MAAM,MAAM,GAAG,MAAM,uBAAA,IAAI,kEAAS,MAAb,IAAI,EAAU;oBACjC,MAAM,EAAE,4BAA4B;oBACpC,MAAM;iBACP,CAAC,CAAC;gBAEH,yEAAyE;gBACzE,4CAA4C;gBAC5C,MAAM,eAAe,GAAG,MAAyC,CAAC;gBAClE,IAAI,eAAe,aAAf,eAAe,uBAAf,eAAe,CAAE,KAAK,EAAE,CAAC;oBAC3B,MAAM,IAAI,KAAK,CAAC,eAAe,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;gBACjD,CAAC;gBAED,MAAM,uBAAA,IAAI,qFAA4B,MAAhC,IAAI,EAA6B,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;gBAC9D,IAAK,MAA8B,CAAC,MAAM,KAAK,IAAI,EAAE,CAAC;oBACpD,kGAAkG;oBAClG,MAAM,uBAAA,IAAI,uEAAc,MAAlB,IAAI,EAAe,OAAO,CAAC,CAAC;oBAClC,uBAAA,IAAI,yEAAgB,MAApB,IAAI,EAAiB,OAAO,CAAC,CAAC;gBAChC,CAAC;gBACD,OAAO,OAAO,CAAC,OAAO,EAAE,CAAC;YAC3B,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,MAAM,uBAAA,IAAI,kFAAyB,MAA7B,IAAI,EAA0B,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;gBAClE,iEAAiE;gBACjE,IAAK,KAAe,CAAC,OAAO,CAAC,QAAQ,CAAC,uBAAuB,CAAC,EAAE,CAAC;oBAC/D,OAAO,uBAAA,IAAI,2EAAkB,MAAtB,IAAI,EAAmB,kBAAkB,CAAC,CAAC;gBACpD,CAAC;gBACD,MAAM,KAAK,CAAC;YACd,CAAC;QACH,CAAC;KAAA;IAoVD;;;;OAIG;IACH,WAAW;QACT,OAAO,uBAAA,IAAI,oCAAU,CAAC;IACxB,CAAC;IAED;;;;OAIG;IACH,UAAU;QACR,OAAO,IAAI,CAAC,eAAe,CAAC;IAC9B,CAAC;IAED;;;;OAIG;IACH,UAAU;QACR,OAAO,uBAAA,IAAI,oCAAU,CAAC,eAAe,CAAC;IACxC,CAAC;IAED,gDAAgD;IAChD;;;;OAIG;IACH,IAAI,QAAQ;QACV,OAAO,uBAAA,IAAI,oCAAU,CAAC,QAAQ,CAAC;IACjC,CAAC;IAED;;;;OAIG;IACH,IAAI,eAAe;QACjB,OAAO,uBAAA,IAAI,oCAAU,CAAC,eAAe,CAAC;IACxC,CAAC;IAED;;;;OAIG;IACH,IAAI,eAAe;QACjB,OAAO,uBAAA,IAAI,oCAAU,CAAC,eAAe,CAAC;IACxC,CAAC;IAED;;;;OAIG;IACH,IAAI,MAAM;QACR,OAAO,uBAAA,IAAI,kCAAQ,CAAC;IACtB,CAAC;CACF;;IAjyBG,OAAQ,uBAAA,IAAI,gCAAc,CAAC,OAA4B,CAAC;AAC1D,CAAC,6FAWC,MAAc,EACd,KAAY,EACZ,MAAiB;IAKjB,OAAO;QACL,KAAK;QACL,OAAO,EAAE,EAAE,MAAM,EAAE,MAAM,EAAE;KAC5B,CAAC;AACJ,CAAC,2GAUC,MAAc,EACd,KAAY,EACZ,MAAiB;;QAEjB,MAAM,WAAW,GAAG,uBAAA,IAAI,yEAAgB,MAApB,IAAI,CAAkB,CAAC;QAC3C,IAAI,CAAC;YACH,MAAM,aAAa,GAAG,uBAAA,IAAI,8EAAqB,MAAzB,IAAI,EAAsB,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;YACvE,MAAM,KAAK,GAAG,MAAM,kCAAkC,CACpD,WAAW,EACX,uBAAA,IAAI,gCAAM,CAAC,OAAO,EAClB,aAAa,EACb,uBAAA,IAAI,gCAAM,CAAC,aAAa,CACzB,CAAC;YACF,SAAS,CAAC,KAAK,CAAC,mCAAmC,EAAE,KAAK,CAAC,CAAC;QAC9D,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,wDAAwD,EAAE,KAAK,CAAC,CAAC;QAC1E,CAAC;IACH,CAAC;4GAUC,MAAc,EACd,KAAY,EACZ,MAAiB;;QAEjB,MAAM,WAAW,GAAG,uBAAA,IAAI,yEAAgB,MAApB,IAAI,CAAkB,CAAC;QAC3C,IAAI,CAAC;YACH,MAAM,aAAa,GAAG,uBAAA,IAAI,8EAAqB,MAAzB,IAAI,EAAsB,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;YACvE,MAAM,KAAK,GAAG,MAAM,kCAAkC,CACpD,WAAW,EACX,uBAAA,IAAI,gCAAM,CAAC,OAAO,EAClB,aAAa,EACb,uBAAA,IAAI,gCAAM,CAAC,aAAa,CACzB,CAAC;YACF,SAAS,CAAC,KAAK,CAAC,mCAAmC,EAAE,KAAK,CAAC,CAAC;QAC9D,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,wDAAwD,EAAE,KAAK,CAAC,CAAC;QAC1E,CAAC;IACH,CAAC;sGAWC,MAAc,EACd,KAAY,EACZ,MAAiB,EACjB,KAAc;;QAEd,MAAM,WAAW,GAAG,uBAAA,IAAI,yEAAgB,MAApB,IAAI,CAAkB,CAAC;QAC3C,IAAI,CAAC;YACH,MAAM,aAAa,GAAG,uBAAA,IAAI,8EAAqB,MAAzB,IAAI,EAAsB,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;YACvE,MAAM,KAAK,GAAG,MAAM,kCAAkC,CACpD,WAAW,EACX,uBAAA,IAAI,gCAAM,CAAC,OAAO,EAClB,aAAa,EACb,uBAAA,IAAI,gCAAM,CAAC,aAAa,CACzB,CAAC;YACF,MAAM,WAAW,GAAG,gBAAgB,CAAC,KAAK,CAAC,CAAC;YAC5C,IAAI,WAAW,EAAE,CAAC;gBAChB,SAAS,CAAC,KAAK,CAAC,kCAAkC,EAAE,KAAK,CAAC,CAAC;YAC7D,CAAC;iBAAM,CAAC;gBACN,SAAS,CAAC,KAAK,CAAC,gCAAgC,EAAE,KAAK,CAAC,CAAC;YAC3D,CAAC;QACH,CAAC;QAAC,WAAM,CAAC;YACP,MAAM,CAAC,uDAAuD,EAAE,KAAK,CAAC,CAAC;QACzE,CAAC;IACH,CAAC;4FAWyB,iBAAwB;;QAChD,2EAA2E;QAC3E,IACE,uBAAA,IAAI,mDAAyB;YAC7B,iBAAiB,CAAC,QAAQ,CAAC,uBAAA,IAAI,mDAAyB,CAAC,EACzD,CAAC;YACD,OAAO,uBAAA,IAAI,mDAAyB,CAAC;QACvC,CAAC;QAED,IAAI,CAAC;YACH,MAAM,aAAa,GACjB,MAAM,uBAAA,IAAI,gCAAM,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;YACxD,IAAI,aAAa,EAAE,CAAC;gBAClB,MAAM,OAAO,GAAQ,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,CAAC;gBAE/C,mEAAmE;gBACnE,IAAI,iBAAiB,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,CAAC;oBACxC,OAAO,OAAO,CAAC;gBACjB,CAAC;YACH,CAAC;QACH,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,iCAAiC,EAAE,KAAK,CAAC,CAAC;QACnD,CAAC;QAED,+FAA+F;QAC/F,OAAO,iBAAiB,CAAC,CAAC,CAAC,CAAC;IAC9B,CAAC;4FAoQC,OAAwB;;QAExB,MAAM,CAAC,oCAAoC,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;QAE7D,IAAI,eAAe,CAAC,QAAQ,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE,CAAC;YAC7C,+DAA+D;YAC/D,OAAO,OAAO,CAAC,MAAM,CACnB,IAAI,KAAK,CACP,WAAW,OAAO,CAAC,MAAM,2CAA2C,CACrE,CACF,CAAC;QACJ,CAAC;QAED,IAAI,OAAO,CAAC,MAAM,KAAK,0BAA0B,EAAE,CAAC;YAClD,OAAO,IAAI,CAAC,UAAU,EAAE,CAAC;QAC3B,CAAC;QAED,IAAI,gBAAgB,CAAC,OAAO,CAAC,EAAE,CAAC;YAC9B,2FAA2F;YAC3F,6EAA6E;YAC7E,sEAAsE;YACtE,sEAAsE;YACtE,8DAA8D;YAC9D,MAAM,4BAA4B,GAChC,OAAO,CAAC,MAAM,KAAK,2BAA2B,CAAC;YAEjD,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC;YACnC,MAAM,SAAS,GAAG,uBAAuB,CAAC,uBAAA,IAAI,yCAAe,CAAC,CAAC;YAC/D,IAAI,SAAS,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;gBAC3B,SAAS,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;YACnC,CAAC;YAED,MAAM,QAAQ,GAAG,uBAAA,IAAI,oCAAU,CAAC,eAAe,CAAC;YAChD,MAAM,SAAS,GACb,QAAQ,IAAI,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;YAErE,MAAM,QAAQ,GAAG;gBACf,SAAS;gBACT,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,EAAE,KAAK,SAAS,CAAC;aAC9C,CAAC;YAEF,MAAM,KAAK,GAAU,UAAU,WAAW,CAAC,SAAS,CAAC,EAAE,CAAC;YAExD,MAAM,uBAAA,IAAI,qFAA4B,MAAhC,IAAI,EAA6B,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;YAE9D,IAAI,CAAC;gBACH,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC;oBAChC,QAAQ;oBACR,YAAY,EAAE,4BAA4B;iBAC3C,CAAC,CAAC;gBACH,MAAM,uBAAA,IAAI,qFAA4B,MAAhC,IAAI,EAA6B,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;gBAC9D,OAAO,MAAM,CAAC;YAChB,CAAC;YAAC,OAAO,KAAK,EAAE,CAAC;gBACf,MAAM,uBAAA,IAAI,kFAAyB,MAA7B,IAAI,EAA0B,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;gBAClE,MAAM,KAAK,CAAC;YACd,CAAC;QACH,CAAC;QAED,IAAI,oBAAoB,CAAC,OAAO,CAAC,EAAE,CAAC;YAClC,OAAO,IAAI,CAAC,WAAW,CAAC;gBACtB,OAAO,EAAE,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,OAAc;aAC1C,CAAC,CAAC;QACL,CAAC;QAED,IAAI,iBAAiB,CAAC,OAAO,CAAC,EAAE,CAAC;YAC/B,OAAO,uBAAA,IAAI,2EAAkB,MAAtB,IAAI,EAAmB,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;QACnD,CAAC;QAED,IAAI,iBAAiB,CAAC,OAAO,CAAC,EAAE,CAAC;YAC/B,OAAO,uBAAA,IAAI,oCAAU,CAAC,QAAQ,CAAC;QACjC,CAAC;QAED,IAAI,gBAAgB,CAAC,OAAO,CAAC,EAAE,CAAC;YAC9B,OAAO,uBAAA,IAAI,oCAAU,CAAC,eAAe,CAAC;QACxC,CAAC;QAED,MAAM,CAAC,wDAAwD,EAAE,OAAO,CAAC,CAAC;QAC1E,OAAO,OAAO,CAAC,OAAO,EAAE,CAAC;IAC3B,CAAC;;IAMC,uBAAA,IAAI,oCAAU,CAAC,QAAQ,GAAG,EAAE,CAAC;IAC7B,uBAAA,IAAI,oCAAU,CAAC,eAAe,GAAG,SAAS,CAAC;AAC7C,CAAC,uFAUC,kBAA8C;;QAE9C,MAAM,CAAC,yBAAyB,EAAE,EAAE,kBAAkB,EAAE,CAAC,CAAC;QAC1D,MAAM,MAAM,GAAG,yBAAyB,CAAC;QAEzC,IAAI,CAAC,kBAAkB,EAAE,CAAC;YACxB,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;QACnD,CAAC;QAED,gDAAgD;QAChD,MAAM,OAAO,GACV,kBAAkB,CAAC,OAAe;YACnC,uBAAA,IAAI,oCAAU,CAAC,eAAe;YAC9B,KAAK,CAAC;QACR,MAAM,cAAc,GAAG,WAAW,CAAC,OAAO,CAAC,CAAC;QAC5C,MAAM,KAAK,GAAU,UAAU,cAAc,EAAE,CAAC;QAChD,MAAM,MAAM,GAAG,CAAC,kBAAkB,CAAC,CAAC;QAEpC,MAAM,uBAAA,IAAI,qFAA4B,MAAhC,IAAI,EAA6B,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;QAE9D,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,MAAM,uBAAA,IAAI,kEAAS,MAAb,IAAI,EAAU;gBACjC,MAAM,EAAE,yBAAyB;gBACjC,MAAM;aACP,CAAC,CAAC;YAEH,IAAK,MAA8B,CAAC,MAAM,KAAK,IAAI,EAAE,CAAC;gBACpD,qGAAqG;gBACrG,MAAM,uBAAA,IAAI,uEAAc,MAAlB,IAAI,EAAe,OAAO,CAAC,CAAC;gBAClC,uBAAA,IAAI,yEAAgB,MAApB,IAAI,EAAiB,OAAO,CAAC,CAAC;YAChC,CAAC;YACD,MAAM,uBAAA,IAAI,qFAA4B,MAAhC,IAAI,EAA6B,MAAM,EAAE,KAAK,EAAE,MAAM,CAAC,CAAC;QAChE,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,uBAAA,IAAI,kFAAyB,MAA7B,IAAI,EAA0B,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;YAClE,MAAM,KAAK,CAAC;QACd,CAAC;IACH,CAAC;sEAUc,OAGd;;QACC,MAAM,CAAC,4CAA4C,EAAE,OAAO,CAAC,CAAC;QAC9D,MAAM,MAAM,GAAG,uBAAA,IAAI,gCAAM,CAAC,SAAS,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC;QAChE,IACE,OAAO,CAAC,MAAM,KAAK,yBAAyB;YAC5C,OAAO,CAAC,MAAM,KAAK,4BAA4B,EAC/C,CAAC;YACD,uBAAA,IAAI,gCAAM,CAAC,0BAA0B,EAAE,CAAC;QAC1C,CAAC;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;gFAOmB,OAAY;;QAC9B,IAAI,CAAC;YACH,MAAM,uBAAA,IAAI,gCAAM,CAAC,OAAO,CAAC,OAAO,CAAC,GAAG,CAClC,eAAe,EACf,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CACxB,CAAC;QACJ,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,MAAM,CAAC,uBAAuB,EAAE,KAAK,CAAC,CAAC;QACzC,CAAC;IACH,CAAC;wFAEuB,OAAqB;;;QAC3C,MAAM,CAAC,8BAA8B,EAAE,OAAO,CAAC,CAAC;QAChD,uBAAA,IAAI,qCAAkB,MAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,aAAa,mCAAI,EAAE,MAAA,CAAC;QACnD,MAAM,oBAAoB,GAAG,uBAAuB,CAAC,uBAAA,IAAI,yCAAe,CAAC,CAAC;QAC1E,IAAI,oBAAoB,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACtC,uBAAA,IAAI,uEAAc,MAAlB,IAAI,CAAgB,CAAC;QACvB,CAAC;aAAM,CAAC;YACN,IAAI,eAAe,GAAc,EAAE,CAAC;YACpC,IAAI,uBAAA,IAAI,gCAAM,CAAC,MAAM,KAAK,WAAW,EAAE,CAAC;gBACtC,MAAM,mBAAmB,GACvB,MAAM,uBAAA,IAAI,gCAAM,CAAC,SAAS,CAAC,kBAAkB,CAAC;oBAC5C,MAAM,EAAE,cAAc;oBACtB,MAAM,EAAE,EAAE;iBACX,CAAC,CAAC;gBACL,eAAe,GAAG,mBAAmB,CAAC,MAAmB,CAAC;YAC5D,CAAC;iBAAM,CAAC;gBACN,eAAe,GAAG,cAAc,CAAC,uBAAA,IAAI,yCAAe,CAAC,CAAC;YACxD,CAAC;YAED,MAAM,OAAO,GAAG,MAAM,uBAAA,IAAI,6EAAoB,MAAxB,IAAI,EAAqB,oBAAoB,CAAC,CAAC;YAErE,uBAAA,IAAI,oEAAW,MAAf,IAAI,EAAY;gBACd,OAAO;gBACP,QAAQ,EAAE,eAAe;aAC1B,CAAC,CAAC;QACL,CAAC;IACH,CAAC;oFAOe,OAAY;;IAC1B,IAAI,OAAO,KAAK,uBAAA,IAAI,oCAAU,CAAC,eAAe,EAAE,CAAC;QAC/C,OAAO;IACT,CAAC;IACD,MAAM,CAAC,uBAAuB,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC;IAC7C,uBAAA,IAAI,oCAAU,CAAC,eAAe,GAAG,OAAO,CAAC;IACzC,uBAAA,IAAI,oCAAU,CAAC,IAAI,CAAC,cAAc,EAAE,OAAO,CAAC,CAAC;IAC7C,MAAA,MAAA,uBAAA,IAAI,yCAAe,0CAAE,YAAY,mDAAG,OAAO,CAAC,CAAC;AAC/C,CAAC,yFAOkB,QAAmB;;IACpC,MAAM,iBAAiB,GACrB,QAAQ,CAAC,MAAM,KAAK,uBAAA,IAAI,oCAAU,CAAC,QAAQ,CAAC,MAAM;QAClD,QAAQ,CAAC,KAAK,CAAC,CAAC,IAAI,EAAE,GAAG,EAAE,EAAE,CAAC,IAAI,KAAK,uBAAA,IAAI,oCAAU,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC;IACvE,IAAI,iBAAiB,EAAE,CAAC;QACtB,OAAO;IACT,CAAC;IACD,MAAM,CAAC,0BAA0B,EAAE,QAAQ,CAAC,CAAC;IAC7C,uBAAA,IAAI,oCAAU,CAAC,QAAQ,GAAG,QAAQ,CAAC;IACnC,uBAAA,IAAI,oCAAU,CAAC,IAAI,CAAC,iBAAiB,EAAE,QAAQ,CAAC,CAAC;IACjD,MAAA,MAAA,uBAAA,IAAI,yCAAe,0CAAE,eAAe,mDAAG,QAAQ,CAAC,CAAC;AACnD,CAAC,yEASU,EACT,OAAO,EACP,QAAQ,GAIT;;IACC,MAAM,CAAC,kBAAkB,EAAE,EAAE,OAAO,EAAE,QAAQ,EAAE,CAAC,CAAC;IAClD,MAAM,IAAI,GAAG;QACX,OAAO;QACP,QAAQ;KACT,CAAC;IAEF,IAAI,uBAAA,IAAI,kCAAQ,KAAK,WAAW,EAAE,CAAC;QACjC,uBAAA,IAAI,yEAAgB,MAApB,IAAI,EAAiB,OAAO,CAAC,CAAC;QAC9B,uBAAA,IAAI,4EAAmB,MAAvB,IAAI,EAAoB,QAAQ,CAAC,CAAC;QAClC,OAAO;IACT,CAAC;IAED,uBAAA,IAAI,oCAAU,CAAC,eAAe,GAAG,OAAO,CAAC;IACzC,uBAAA,IAAI,oCAAU,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAEnC,uBAAA,IAAI,8BAAW,WAAW,MAAA,CAAC;IAC3B,uBAAA,IAAI,oCAAU,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;IACrC,MAAA,MAAA,uBAAA,IAAI,yCAAe,0CAAE,OAAO,mDAAG,IAAI,CAAC,CAAC;IAErC,uBAAA,IAAI,oCAAU,CAAC,IAAI,CAAC,cAAc,EAAE,OAAO,CAAC,CAAC;IAC7C,MAAA,MAAA,uBAAA,IAAI,yCAAe,0CAAE,YAAY,mDAAG,OAAO,CAAC,CAAC;IAE7C,uBAAA,IAAI,oCAAU,CAAC,IAAI,CAAC,iBAAiB,EAAE,QAAQ,CAAC,CAAC;IACjD,MAAA,MAAA,uBAAA,IAAI,yCAAe,0CAAE,eAAe,mDAAG,QAAQ,CAAC,CAAC;IAEjD,MAAA,uBAAA,IAAI,qDAA2B,+CAA/B,IAAI,CAA+B,CAAC;IAEpC,MAAM,iBAAiB,GAAG,CAAC,IAAc,EAAQ,EAAE;QACjD,MAAM,CAAC,6BAA6B,EAAE,IAAI,CAAC,CAAC;QAC5C,uBAAA,IAAI,4EAAmB,MAAvB,IAAI,EAAoB,IAAiB,CAAC,CAAC;IAC7C,CAAC,CAAC;IAEF,MAAM,cAAc,GAAG,CAAC,YAAiC,EAAQ,EAAE;QACjE,MAAM,CAAC,0BAA0B,EAAE,YAAY,CAAC,OAAO,CAAC,CAAC;QACzD,uBAAA,IAAI,uEAAc,MAAlB,IAAI,EAAe,YAAY,CAAC,OAAc,CAAC,CAAC,KAAK,CAAC,CAAC,KAAK,EAAE,EAAE;YAC9D,MAAM,CAAC,+CAA+C,EAAE,KAAK,CAAC,CAAC;QACjE,CAAC,CAAC,CAAC;QACH,uBAAA,IAAI,yEAAgB,MAApB,IAAI,EAAiB,YAAY,CAAC,OAAc,CAAC,CAAC;IACpD,CAAC,CAAC;IAEF,uBAAA,IAAI,gCAAM,CAAC,EAAE,CAAC,0BAA0B,EAAE,iBAAiB,CAAC,CAAC;IAC7D,uBAAA,IAAI,gCAAM,CAAC,EAAE,CAAC,uBAAuB,EAAE,cAAc,CAAC,CAAC;IAEvD,uBAAA,IAAI,iDAA8B,GAAS,EAAE;QAC3C,uBAAA,IAAI,gCAAM,CAAC,GAAG,CAAC,0BAA0B,EAAE,iBAAiB,CAAC,CAAC;QAC9D,uBAAA,IAAI,gCAAM,CAAC,GAAG,CAAC,uBAAuB,EAAE,cAAc,CAAC,CAAC;IAC1D,CAAC,MAAA,CAAC;AACJ,CAAC;;IAOC,IAAI,uBAAA,IAAI,kCAAQ,KAAK,cAAc,EAAE,CAAC;QACpC,OAAO;IACT,CAAC;IACD,uBAAA,IAAI,8BAAW,cAAc,MAAA,CAAC;IAE9B,MAAM,CAAC,qBAAqB,CAAC,CAAC;IAC9B,uBAAA,IAAI,oCAAU,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAClC,MAAA,MAAA,uBAAA,IAAI,yCAAe,0CAAE,UAAU,kDAAI,CAAC;IAEpC,uBAAA,IAAI,4EAAmB,MAAvB,IAAI,EAAoB,EAAE,CAAC,CAAC;AAC9B,CAAC,+EAQa,GAAW;;IACvB,IAAI,uBAAA,IAAI,kCAAQ,KAAK,YAAY,EAAE,CAAC;QAClC,OAAO;IACT,CAAC;IAED,MAAM,CAAC,sBAAsB,EAAE,GAAG,CAAC,CAAC;IACpC,uBAAA,IAAI,oCAAU,CAAC,IAAI,CAAC,aAAa,EAAE,GAAG,CAAC,CAAC;IACxC,MAAA,MAAA,uBAAA,IAAI,yCAAe,0CAAE,UAAU,mDAAG,GAAG,CAAC,CAAC;AACzC,CAAC;AAmEH;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,MAAM,UAAgB,eAAe,CACnC,OAWC;;;QAED,IAAI,OAAO,CAAC,KAAK,EAAE,CAAC;YAClB,WAAW,EAAE,CAAC;QAChB,CAAC;QAED,MAAM,CAAC,6CAA6C,EAAE,OAAO,CAAC,CAAC;QAE/D,4DAA4D;QAC5D,IACE,CAAC,CAAA,MAAA,OAAO,CAAC,GAAG,0CAAE,iBAAiB,CAAA;YAC/B,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC,MAAM,KAAK,CAAC,EACvD,CAAC;YACD,MAAM,IAAI,KAAK,CACb,iFAAiF,CAClF,CAAC;QACJ,CAAC;QAED,wBAAwB,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAiB,EAAE,mBAAmB,CAAC,CAAC;QAE7E,MAAM,4BAA4B,GAAG,MAAM,CAAC,OAAO,CACjD,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAC9B,CAAC,MAAM,CAAyB,CAAC,GAAG,EAAE,CAAC,UAAU,EAAE,GAAG,CAAC,EAAE,EAAE;YAC1D,MAAM,cAAc,GAAG,QAAQ,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;YAChD,MAAM,YAAY,GAAG,UAAU,cAAc,EAAE,CAAC;YAChD,GAAG,CAAC,YAAY,CAAC,GAAG,GAAG,CAAC;YACxB,OAAO,GAAG,CAAC;QACb,CAAC,EAAE,EAAE,CAAC,CAAC;QAEP,IAAI,CAAC;YACH,MAAM,IAAI,GAAG,MAAM,sBAAsB,iCACpC,OAAO,KACV,GAAG,EAAE;oBACH,iBAAiB,EAAE,4BAA4B;iBAChD,EACD,SAAS,EAAE;oBACT,wEAAwE;oBACxE,eAAe,EAAE,CAAA,MAAA,OAAO,CAAC,SAAS,0CAAE,eAAe,KAAI,QAAQ;iBAChE,EACD,QAAQ,EAAE;oBACR,wEAAwE;oBACxE,iEAAiE;oBACjE,aAAa,EACX,OAAO,mBAAmB,KAAK,WAAW;wBACxC,CAAC,CAAC,SAAS;wBACX,CAAC,CAAC,mBAAmB;iBAC1B,IACD,CAAC;YAEH,OAAO,kBAAkB,CAAC,MAAM,CAAC;gBAC/B,IAAI;gBACJ,aAAa,EAAE,OAAO,CAAC,aAAa;gBACpC,iBAAiB,EAAE,OAAO,CAAC,GAAG,CAAC,iBAAiB;aACjD,CAAC,CAAC;QACL,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,KAAK,CAAC,qCAAqC,EAAE,KAAK,CAAC,CAAC;YAC5D,MAAM,KAAK,CAAC;QACd,CAAC;IACH,CAAC;CAAA"}
@@ -24,14 +24,14 @@ export type EIP1193ProviderEvents = {
24
24
  {
25
25
  accounts: readonly Address[];
26
26
  chainId: Hex;
27
- signResponse: string;
27
+ signature: string;
28
28
  }
29
29
  ];
30
30
  connectWith: [
31
31
  {
32
32
  accounts: readonly Address[];
33
33
  chainId: Hex;
34
- connectWithResponse: unknown;
34
+ result: unknown;
35
35
  }
36
36
  ];
37
37
  };
@@ -47,12 +47,12 @@ export type EventHandlers = {
47
47
  connectAndSign: (result: {
48
48
  accounts: readonly Address[];
49
49
  chainId: Hex;
50
- signResponse: string;
50
+ signature: string;
51
51
  }) => void;
52
52
  connectWith: (result: {
53
53
  accounts: readonly Address[];
54
54
  chainId: Hex;
55
- connectWithResponse: unknown;
55
+ result: unknown;
56
56
  }) => void;
57
57
  };
58
58
  export type MetamaskConnectEVMOptions = {
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/types.ts"],"names":[],"mappings":"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"}
@@ -39,14 +39,14 @@ type EIP1193ProviderEvents = {
39
39
  {
40
40
  accounts: readonly Address[];
41
41
  chainId: Hex;
42
- signResponse: string;
42
+ signature: string;
43
43
  }
44
44
  ];
45
45
  connectWith: [
46
46
  {
47
47
  accounts: readonly Address[];
48
48
  chainId: Hex;
49
- connectWithResponse: unknown;
49
+ result: unknown;
50
50
  }
51
51
  ];
52
52
  };
@@ -62,12 +62,12 @@ type EventHandlers = {
62
62
  connectAndSign: (result: {
63
63
  accounts: readonly Address[];
64
64
  chainId: Hex;
65
- signResponse: string;
65
+ signature: string;
66
66
  }) => void;
67
67
  connectWith: (result: {
68
68
  accounts: readonly Address[];
69
69
  chainId: Hex;
70
- connectWithResponse: unknown;
70
+ result: unknown;
71
71
  }) => void;
72
72
  };
73
73
  type MetamaskConnectEVMOptions = {
@@ -256,13 +256,17 @@ declare class MetamaskConnectEVM {
256
256
  * @param options - The connection options
257
257
  * @param options.message - The message to sign after connecting
258
258
  * @param [options.chainIds] - Optional hex chain IDs to connect to (defaults to ethereum mainnet if not provided)
259
- * @returns A promise that resolves with the signature
259
+ * @returns A promise that resolves with the connected accounts, chainId, and signature
260
260
  * @throws Error if the selected account is not available after timeout
261
261
  */
262
262
  connectAndSign({ message, chainIds, }: {
263
263
  message: string;
264
264
  chainIds?: Hex[];
265
- }): Promise<string>;
265
+ }): Promise<{
266
+ accounts: Address[];
267
+ chainId: Hex;
268
+ signature: string;
269
+ }>;
266
270
  /**
267
271
  * Connects to the wallet and invokes a method with specified parameters.
268
272
  *
@@ -272,7 +276,7 @@ declare class MetamaskConnectEVM {
272
276
  * @param [options.chainIds] - Optional hex chain IDs to connect to (defaults to ethereum mainnet if not provided)
273
277
  * @param [options.account] - Optional specific account to connect to
274
278
  * @param [options.forceRequest] - Whether to force a request regardless of an existing session
275
- * @returns A promise that resolves with the result of the method invocation
279
+ * @returns A promise that resolves with the connected accounts, chainId, and the result of the method invocation
276
280
  * @throws Error if the selected account is not available after timeout (for methods that require an account)
277
281
  */
278
282
  connectWith({ method, params, chainIds, account, forceRequest, }: {
@@ -281,7 +285,11 @@ declare class MetamaskConnectEVM {
281
285
  chainIds?: Hex[];
282
286
  account?: string | undefined;
283
287
  forceRequest?: boolean;
284
- }): Promise<unknown>;
288
+ }): Promise<{
289
+ accounts: Address[];
290
+ chainId: Hex;
291
+ result: unknown;
292
+ }>;
285
293
  /**
286
294
  * Disconnects from the wallet by revoking the session and cleaning up event listeners.
287
295
  *
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@metamask/connect-evm",
3
- "version": "0.11.2",
3
+ "version": "1.1.0",
4
4
  "description": "EVM Layer for MetaMask Connect",
5
5
  "keywords": [
6
6
  "MetaMask",
@@ -56,7 +56,7 @@
56
56
  "dependencies": {
57
57
  "@metamask/analytics": "^0.4.0",
58
58
  "@metamask/chain-agnostic-permission": "^1.2.2",
59
- "@metamask/connect-multichain": "^0.12.1",
59
+ "@metamask/connect-multichain": "^0.13.0",
60
60
  "@metamask/utils": "^11.8.1"
61
61
  },
62
62
  "devDependencies": {