@metamask-previews/assets-controller 0.0.0-preview-40468f94 → 0.0.0-preview-fb7aa07ff
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 +1 -0
- package/dist/data-sources/SnapDataSource.cjs +193 -464
- package/dist/data-sources/SnapDataSource.cjs.map +1 -1
- package/dist/data-sources/SnapDataSource.d.cts +24 -86
- package/dist/data-sources/SnapDataSource.d.cts.map +1 -1
- package/dist/data-sources/SnapDataSource.d.mts +24 -86
- package/dist/data-sources/SnapDataSource.d.mts.map +1 -1
- package/dist/data-sources/SnapDataSource.mjs +191 -458
- package/dist/data-sources/SnapDataSource.mjs.map +1 -1
- package/dist/data-sources/index.cjs +7 -36
- package/dist/data-sources/index.cjs.map +1 -1
- package/dist/data-sources/index.d.cts +1 -1
- package/dist/data-sources/index.d.cts.map +1 -1
- package/dist/data-sources/index.d.mts +1 -1
- package/dist/data-sources/index.d.mts.map +1 -1
- package/dist/data-sources/index.mjs +5 -13
- package/dist/data-sources/index.mjs.map +1 -1
- package/dist/data-sources/initDataSources.cjs +9 -3
- package/dist/data-sources/initDataSources.cjs.map +1 -1
- package/dist/data-sources/initDataSources.d.cts +2 -4
- package/dist/data-sources/initDataSources.d.cts.map +1 -1
- package/dist/data-sources/initDataSources.d.mts +2 -4
- package/dist/data-sources/initDataSources.d.mts.map +1 -1
- package/dist/data-sources/initDataSources.mjs +9 -3
- package/dist/data-sources/initDataSources.mjs.map +1 -1
- package/dist/index.cjs +7 -36
- package/dist/index.cjs.map +1 -1
- package/dist/index.d.cts +2 -2
- package/dist/index.d.cts.map +1 -1
- package/dist/index.d.mts +2 -2
- package/dist/index.d.mts.map +1 -1
- package/dist/index.mjs +5 -13
- package/dist/index.mjs.map +1 -1
- package/package.json +7 -2
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SnapDataSource.cjs","sourceRoot":"","sources":["../../src/data-sources/SnapDataSource.ts"],"names":[],"mappings":"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","sourcesContent":["import type { InternalAccount } from '@metamask/keyring-internal-api';\nimport type { Messenger } from '@metamask/messenger';\n\nimport { AbstractDataSource } from './AbstractDataSource';\nimport type {\n DataSourceState,\n SubscriptionRequest,\n} from './AbstractDataSource';\nimport { projectLogger, createModuleLogger } from '../logger';\nimport type {\n ChainId,\n Caip19AssetId,\n DataRequest,\n DataResponse,\n Middleware,\n} from '../types';\n\n// ============================================================================\n// SNAP KEYRING EVENT TYPES\n// ============================================================================\n\n/**\n * Payload for AccountsController:accountBalancesUpdated event.\n * Re-published from SnapKeyring:accountBalancesUpdated.\n */\nexport type AccountBalancesUpdatedEventPayload = {\n balances: {\n [accountId: string]: {\n [assetId: string]: {\n amount: string;\n unit: string;\n };\n };\n };\n};\n\n/**\n * Event from AccountsController when snap balances are updated.\n */\nexport type AccountsControllerAccountBalancesUpdatedEvent = {\n type: 'AccountsController:accountBalancesUpdated';\n payload: [AccountBalancesUpdatedEventPayload];\n};\n\nconst log = createModuleLogger(projectLogger, 'SnapDataSource');\n\n// ============================================================================\n// CONSTANTS\n// ============================================================================\n\nexport const SNAP_DATA_SOURCE_NAME = 'SnapDataSource';\n\n// Snap IDs\nexport const SOLANA_SNAP_ID = 'npm:@metamask/solana-wallet-snap';\nexport const BITCOIN_SNAP_ID = 'npm:@metamask/bitcoin-wallet-snap';\nexport const TRON_SNAP_ID = 'npm:@metamask/tron-wallet-snap';\n\n// Chain prefixes for detection\nexport const SOLANA_CHAIN_PREFIX = 'solana:';\nexport const BITCOIN_CHAIN_PREFIX = 'bip122:';\nexport const TRON_CHAIN_PREFIX = 'tron:';\n\n// Default networks\nexport const SOLANA_MAINNET =\n 'solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp' as ChainId;\nexport const SOLANA_DEVNET =\n 'solana:EtWTRABZaYq6iMfeYKouRu166VU2xqa1' as ChainId;\nexport const SOLANA_TESTNET =\n 'solana:4uhcVJyU9pJkvQyS88uRDiswHXSCkY3z' as ChainId;\n\nexport const BITCOIN_MAINNET =\n 'bip122:000000000019d6689c085ae165831e93' as ChainId;\nexport const BITCOIN_TESTNET =\n 'bip122:000000000933ea01ad0ee984209779ba' as ChainId;\n\nexport const TRON_MAINNET = 'tron:728126428' as ChainId;\nexport const TRON_SHASTA = 'tron:2494104990' as ChainId;\nexport const TRON_NILE = 'tron:3448148188' as ChainId;\n// Hex format alternatives for Tron\nexport const TRON_MAINNET_HEX = 'tron:0x2b6653dc' as ChainId;\nexport const TRON_SHASTA_HEX = 'tron:0x94a9059e' as ChainId;\nexport const TRON_NILE_HEX = 'tron:0xcd8690dc' as ChainId;\n\n// Default poll intervals\nexport const DEFAULT_SOLANA_POLL_INTERVAL = 30_000; // 30 seconds\nexport const DEFAULT_BITCOIN_POLL_INTERVAL = 60_000; // 1 minute\nexport const DEFAULT_TRON_POLL_INTERVAL = 30_000; // 30 seconds\nexport const DEFAULT_SNAP_POLL_INTERVAL = 30_000; // Default for unknown snaps\n\n// All default networks\nexport const ALL_DEFAULT_NETWORKS: ChainId[] = [\n SOLANA_MAINNET,\n SOLANA_DEVNET,\n SOLANA_TESTNET,\n BITCOIN_MAINNET,\n BITCOIN_TESTNET,\n TRON_MAINNET,\n TRON_SHASTA,\n TRON_NILE,\n TRON_MAINNET_HEX,\n TRON_SHASTA_HEX,\n TRON_NILE_HEX,\n];\n\n// ============================================================================\n// SNAP ROUTING\n// ============================================================================\n\nexport type SnapType = 'solana' | 'bitcoin' | 'tron';\n\nexport type SnapInfo = {\n snapId: string;\n chainPrefix: string;\n pollInterval: number;\n version: string | null;\n available: boolean;\n};\n\nexport const SNAP_REGISTRY: Record<\n SnapType,\n Omit<SnapInfo, 'version' | 'available'>\n> = {\n solana: {\n snapId: SOLANA_SNAP_ID,\n chainPrefix: SOLANA_CHAIN_PREFIX,\n pollInterval: DEFAULT_SOLANA_POLL_INTERVAL,\n },\n bitcoin: {\n snapId: BITCOIN_SNAP_ID,\n chainPrefix: BITCOIN_CHAIN_PREFIX,\n pollInterval: DEFAULT_BITCOIN_POLL_INTERVAL,\n },\n tron: {\n snapId: TRON_SNAP_ID,\n chainPrefix: TRON_CHAIN_PREFIX,\n pollInterval: DEFAULT_TRON_POLL_INTERVAL,\n },\n};\n\n/**\n * Get the snap type for a chain ID based on its prefix.\n *\n * @param chainId - The CAIP-2 chain ID to check.\n * @returns The snap type for the chain, or null if not supported.\n */\nexport function getSnapTypeForChain(chainId: ChainId): SnapType | null {\n if (chainId.startsWith(SOLANA_CHAIN_PREFIX)) {\n return 'solana';\n }\n if (chainId.startsWith(BITCOIN_CHAIN_PREFIX)) {\n return 'bitcoin';\n }\n if (chainId.startsWith(TRON_CHAIN_PREFIX)) {\n return 'tron';\n }\n return null;\n}\n\n/**\n * Check if a chain ID is supported by a snap.\n *\n * @param chainId - The CAIP-2 chain ID to check.\n * @returns True if the chain is supported by a snap.\n */\nexport function isSnapSupportedChain(chainId: ChainId): boolean {\n return getSnapTypeForChain(chainId) !== null;\n}\n\n/**\n * Extract chain ID from a CAIP-19 asset ID.\n * e.g., \"solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp/slip44:501\" -> \"solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp\"\n *\n * @param assetId - The CAIP-19 asset ID to extract chain from.\n * @returns The CAIP-2 chain ID portion of the asset ID.\n */\nexport function extractChainFromAssetId(assetId: string): ChainId {\n const parts = assetId.split('/');\n return parts[0] as ChainId;\n}\n\n// Helper functions for specific chain types\nexport function isSolanaChain(chainId: ChainId): boolean {\n return chainId.startsWith(SOLANA_CHAIN_PREFIX);\n}\n\nexport function isBitcoinChain(chainId: ChainId): boolean {\n return chainId.startsWith(BITCOIN_CHAIN_PREFIX);\n}\n\nexport function isTronChain(chainId: ChainId): boolean {\n return chainId.startsWith(TRON_CHAIN_PREFIX);\n}\n\n// ============================================================================\n// STATE\n// ============================================================================\n\nexport type SnapDataSourceState = {\n /** Snap availability and versions */\n snaps: Record<SnapType, { version: string | null; available: boolean }>;\n} & DataSourceState;\n\nconst defaultSnapState: SnapDataSourceState = {\n activeChains: ALL_DEFAULT_NETWORKS,\n snaps: {\n solana: { version: null, available: false },\n bitcoin: { version: null, available: false },\n tron: { version: null, available: false },\n },\n};\n\n// ============================================================================\n// MESSENGER TYPES\n// ============================================================================\n\nexport type SnapDataSourceGetAssetsMiddlewareAction = {\n type: 'SnapDataSource:getAssetsMiddleware';\n handler: () => Middleware;\n};\n\nexport type SnapDataSourceGetActiveChainsAction = {\n type: 'SnapDataSource:getActiveChains';\n handler: () => Promise<ChainId[]>;\n};\n\nexport type SnapDataSourceFetchAction = {\n type: 'SnapDataSource:fetch';\n handler: (request: DataRequest) => Promise<DataResponse>;\n};\n\nexport type SnapDataSourceSubscribeAction = {\n type: 'SnapDataSource:subscribe';\n handler: (request: SubscriptionRequest) => Promise<void>;\n};\n\nexport type SnapDataSourceUnsubscribeAction = {\n type: 'SnapDataSource:unsubscribe';\n handler: (subscriptionId: string) => Promise<void>;\n};\n\nexport type SnapDataSourceActions =\n | SnapDataSourceGetAssetsMiddlewareAction\n | SnapDataSourceGetActiveChainsAction\n | SnapDataSourceFetchAction\n | SnapDataSourceSubscribeAction\n | SnapDataSourceUnsubscribeAction;\n\nexport type SnapDataSourceActiveChainsChangedEvent = {\n type: 'SnapDataSource:activeChainsUpdated';\n payload: [ChainId[]];\n};\n\nexport type SnapDataSourceAssetsUpdatedEvent = {\n type: 'SnapDataSource:assetsUpdated';\n payload: [DataResponse, string | undefined];\n};\n\nexport type SnapDataSourceEvents =\n | SnapDataSourceActiveChainsChangedEvent\n | SnapDataSourceAssetsUpdatedEvent;\n\n/**\n * Allowed events that SnapDataSource can subscribe to.\n */\nexport type SnapDataSourceAllowedEvents =\n AccountsControllerAccountBalancesUpdatedEvent;\n\n// Actions to report to AssetsController\ntype AssetsControllerActiveChainsUpdateAction = {\n type: 'AssetsController:activeChainsUpdate';\n handler: (dataSourceId: string, activeChains: ChainId[]) => void;\n};\n\ntype AssetsControllerAssetsUpdateAction = {\n type: 'AssetsController:assetsUpdate';\n handler: (response: DataResponse, sourceId: string) => Promise<void>;\n};\n\nexport type SnapDataSourceAllowedActions =\n | AssetsControllerActiveChainsUpdateAction\n | AssetsControllerAssetsUpdateAction;\n\nexport type SnapDataSourceMessenger = Messenger<\n typeof SNAP_DATA_SOURCE_NAME,\n SnapDataSourceActions | SnapDataSourceAllowedActions,\n SnapDataSourceEvents | SnapDataSourceAllowedEvents\n>;\n\n// ============================================================================\n// SNAP PROVIDER INTERFACE\n// ============================================================================\n\nexport type SnapProvider = {\n request<ResponseType>(args: {\n method: string;\n params?: unknown;\n }): Promise<ResponseType>;\n};\n\n// ============================================================================\n// OPTIONS\n// ============================================================================\n\nexport type SnapDataSourceOptions = {\n /** Messenger for this data source */\n messenger: SnapDataSourceMessenger;\n /**\n * Snap provider for communicating with snaps.\n */\n snapProvider: SnapProvider;\n /** Configured networks to support (defaults to all snap networks) */\n configuredNetworks?: ChainId[];\n /** Default polling interval in ms for subscriptions */\n pollInterval?: number;\n /** Initial state */\n state?: Partial<SnapDataSourceState>;\n};\n\n// ============================================================================\n// SNAP DATA SOURCE\n// ============================================================================\n\n/**\n * Unified Snap data source that routes requests to the appropriate wallet snap\n * based on the chain ID prefix.\n *\n * Supports:\n * - Solana chains (solana:*) → @metamask/solana-wallet-snap\n * - Bitcoin chains (bip122:*) → @metamask/bitcoin-wallet-snap\n * - Tron chains (tron:*) → @metamask/tron-wallet-snap\n *\n * @example\n * ```typescript\n * const snapDataSource = new SnapDataSource({\n * messenger,\n * snapProvider: metamaskProvider,\n * });\n *\n * // Fetch will automatically route to the correct snap\n * await snapDataSource.fetch({\n * chainIds: ['solana:mainnet', 'bip122:000000000019d6689c085ae165831e93'],\n * accountIds: ['account1'],\n * });\n * ```\n */\nexport class SnapDataSource extends AbstractDataSource<\n typeof SNAP_DATA_SOURCE_NAME,\n SnapDataSourceState\n> {\n readonly #messenger: SnapDataSourceMessenger;\n\n readonly #snapProvider: SnapProvider;\n\n constructor(options: SnapDataSourceOptions) {\n const configuredNetworks =\n options.configuredNetworks ?? ALL_DEFAULT_NETWORKS;\n\n super(SNAP_DATA_SOURCE_NAME, {\n ...defaultSnapState,\n ...options.state,\n activeChains: configuredNetworks,\n });\n\n this.#messenger = options.messenger;\n this.#snapProvider = options.snapProvider;\n\n this.#registerActionHandlers();\n this.#subscribeToSnapKeyringEvents();\n\n // Check availability for all snaps on initialization\n this.#checkAllSnapsAvailability().catch(() => {\n // Silently ignore availability check failures on init\n });\n }\n\n /**\n * Subscribe to snap keyring events for real-time balance updates.\n * The snaps emit AccountBalancesUpdated events when balances change,\n * which are re-published by AccountsController.\n */\n #subscribeToSnapKeyringEvents(): void {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const messenger = this.#messenger as any;\n\n try {\n messenger.subscribe(\n 'AccountsController:accountBalancesUpdated',\n (payload: AccountBalancesUpdatedEventPayload) => {\n this.#handleSnapBalancesUpdated(payload);\n },\n );\n } catch (error) {\n log('Failed to subscribe to snap keyring events', { error });\n }\n }\n\n /**\n * Handle snap balance updates from the keyring.\n * Transforms the payload and publishes to AssetsController.\n *\n * @param payload - The balance update payload from AccountsController.\n */\n #handleSnapBalancesUpdated(\n payload: AccountBalancesUpdatedEventPayload,\n ): void {\n // Transform the snap keyring payload to DataResponse format\n const response: DataResponse = {\n assetsBalance: {},\n };\n\n for (const [accountId, assets] of Object.entries(payload.balances)) {\n if (response.assetsBalance) {\n response.assetsBalance[accountId] = {};\n\n for (const [assetId, balance] of Object.entries(assets)) {\n // Only include snap-supported assets (solana, bitcoin, tron)\n if (isSnapSupportedChain(extractChainFromAssetId(assetId))) {\n response.assetsBalance[accountId][assetId as Caip19AssetId] = {\n amount: balance.amount,\n };\n }\n }\n\n // Remove account if no snap assets\n if (Object.keys(response.assetsBalance[accountId]).length === 0) {\n delete response.assetsBalance[accountId];\n }\n }\n }\n\n // Only report if we have snap-related updates\n if (Object.keys(response.assetsBalance ?? {}).length > 0) {\n this.#messenger\n .call('AssetsController:assetsUpdate', response, SNAP_DATA_SOURCE_NAME)\n .catch(console.error);\n }\n }\n\n #registerActionHandlers(): void {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const messenger = this.#messenger as any;\n\n messenger.registerActionHandler(\n 'SnapDataSource:getAssetsMiddleware',\n () => this.assetsMiddleware,\n );\n\n messenger.registerActionHandler(\n 'SnapDataSource:getActiveChains',\n async () => this.getActiveChains(),\n );\n\n messenger.registerActionHandler(\n 'SnapDataSource:fetch',\n async (request: DataRequest) => this.fetch(request),\n );\n\n messenger.registerActionHandler(\n 'SnapDataSource:subscribe',\n async (request: SubscriptionRequest) => this.subscribe(request),\n );\n\n messenger.registerActionHandler(\n 'SnapDataSource:unsubscribe',\n async (subscriptionId: string) => this.unsubscribe(subscriptionId),\n );\n }\n\n // ============================================================================\n // SNAP AVAILABILITY\n // ============================================================================\n\n /**\n * Get all installed snaps from the snap provider.\n *\n * @returns A map of snap IDs to their versions.\n */\n async #getInstalledSnaps(): Promise<Record<string, { version: string }>> {\n try {\n const snaps = await this.#snapProvider.request<\n Record<string, { version: string }>\n >({\n method: 'wallet_getSnaps',\n params: {},\n });\n\n return snaps;\n } catch (error) {\n log('Failed to get installed snaps', error);\n return {};\n }\n }\n\n /**\n * Check availability for a single snap type on-demand.\n * This is called before each fetch to ensure we have the latest availability status.\n *\n * @param snapType - The snap type to check (solana, bitcoin, tron)\n * @returns True if the snap is available, false otherwise\n */\n async #checkSnapAvailabilityOnDemand(snapType: SnapType): Promise<boolean> {\n const config = SNAP_REGISTRY[snapType];\n const currentState = this.state.snaps[snapType];\n\n // If already marked as available, return true (snap was found previously)\n if (currentState.available) {\n return true;\n }\n\n // Check if snap is now available (handles timing issues where snap wasn't ready at init)\n try {\n const snaps = await this.#getInstalledSnaps();\n const snap = snaps[config.snapId];\n\n if (snap) {\n // Snap is now available - update state\n this.state.snaps[snapType] = {\n version: snap.version,\n available: true,\n };\n return true;\n }\n\n return false;\n } catch {\n return false;\n }\n }\n\n async #checkAllSnapsAvailability(): Promise<void> {\n try {\n const snaps = await this.#getInstalledSnaps();\n\n for (const [snapType, config] of Object.entries(SNAP_REGISTRY)) {\n const snap = snaps[config.snapId];\n\n if (snap) {\n this.state.snaps[snapType as SnapType] = {\n version: snap.version,\n available: true,\n };\n } else {\n this.state.snaps[snapType as SnapType] = {\n version: null,\n available: false,\n };\n }\n }\n } catch {\n // Mark all snaps as unavailable on error\n for (const snapType of Object.keys(SNAP_REGISTRY)) {\n this.state.snaps[snapType as SnapType] = {\n version: null,\n available: false,\n };\n }\n }\n }\n\n /**\n * Get info about all snaps.\n *\n * @returns Record of snap info keyed by snap type.\n */\n getSnapsInfo(): Record<SnapType, SnapInfo> {\n const result: Record<SnapType, SnapInfo> = {} as Record<SnapType, SnapInfo>;\n\n for (const [snapType, config] of Object.entries(SNAP_REGISTRY)) {\n const state = this.state.snaps[snapType as SnapType];\n result[snapType as SnapType] = {\n ...config,\n version: state.version,\n available: state.available,\n };\n }\n\n return result;\n }\n\n /**\n * Check if a specific snap is available.\n *\n * @param snapType - The snap type to check (solana, bitcoin, tron).\n * @returns True if the snap is available.\n */\n isSnapAvailable(snapType: SnapType): boolean {\n return this.state.snaps[snapType]?.available ?? false;\n }\n\n /**\n * Force refresh snap availability check.\n */\n async refreshSnapsStatus(): Promise<void> {\n await this.#checkAllSnapsAvailability();\n }\n\n // ============================================================================\n // CHAIN MANAGEMENT\n // ============================================================================\n\n addNetworks(chainIds: ChainId[]): void {\n const snapChains = chainIds.filter(isSnapSupportedChain);\n const newChains = snapChains.filter(\n (chain) => !this.state.activeChains.includes(chain),\n );\n\n if (newChains.length > 0) {\n const updated = [...this.state.activeChains, ...newChains];\n this.updateActiveChains(updated, (updatedChains) =>\n this.#messenger.call(\n 'AssetsController:activeChainsUpdate',\n SNAP_DATA_SOURCE_NAME,\n updatedChains,\n ),\n );\n }\n }\n\n removeNetworks(chainIds: ChainId[]): void {\n const chainSet = new Set(chainIds);\n const updated = this.state.activeChains.filter(\n (chain) => !chainSet.has(chain),\n );\n if (updated.length !== this.state.activeChains.length) {\n this.updateActiveChains(updated, (updatedChains) =>\n this.#messenger.call(\n 'AssetsController:activeChainsUpdate',\n SNAP_DATA_SOURCE_NAME,\n updatedChains,\n ),\n );\n }\n }\n\n // ============================================================================\n // ACCOUNT SCOPE HELPERS\n // ============================================================================\n\n /**\n * Check if an account supports a specific chain based on its scopes.\n * For snap chains (Solana, Bitcoin, Tron), we check for the appropriate namespace.\n *\n * @param account - The account to check\n * @param chainId - The chain ID to check (e.g., \"solana:...\", \"bip122:...\", \"tron:...\")\n * @returns True if the account supports the chain\n */\n #accountSupportsChain(account: InternalAccount, chainId: ChainId): boolean {\n const scopes = account.scopes ?? [];\n\n // If no scopes defined, assume it supports the chain (backward compatibility)\n if (scopes.length === 0) {\n return true;\n }\n\n // Extract namespace and reference from chainId\n const [chainNamespace, chainReference] = chainId.split(':');\n\n for (const scope of scopes) {\n const [scopeNamespace, scopeReference] = (scope as string).split(':');\n\n // Check if namespaces match\n if (scopeNamespace !== chainNamespace) {\n continue;\n }\n\n // Wildcard scope (e.g., \"solana:0\" means all chains in that namespace)\n if (scopeReference === '0') {\n return true;\n }\n\n // Exact match check\n if (scopeReference === chainReference) {\n return true;\n }\n }\n\n return false;\n }\n\n // ============================================================================\n // FETCH - Routes to appropriate snap(s)\n // ============================================================================\n\n async fetch(request: DataRequest): Promise<DataResponse> {\n // Guard against undefined request or chainIds\n if (!request?.chainIds) {\n return {};\n }\n\n // Filter to only snap-supported chains\n const snapChains = request.chainIds.filter(isSnapSupportedChain);\n\n if (snapChains.length === 0) {\n return {};\n }\n\n // Group chains by snap type\n const chainsBySnap = this.#groupChainsBySnap(snapChains);\n\n // Fetch from each snap in parallel\n const results = await Promise.all(\n Object.entries(chainsBySnap).map(async ([snapType, chains]) => {\n return this.#fetchFromSnap(snapType as SnapType, {\n ...request,\n chainIds: chains,\n });\n }),\n );\n\n // Merge all results\n const mergedResponse: DataResponse = {};\n\n for (const result of results) {\n if (result.assetsBalance) {\n mergedResponse.assetsBalance = {\n ...mergedResponse.assetsBalance,\n ...result.assetsBalance,\n };\n }\n if (result.assetsMetadata) {\n mergedResponse.assetsMetadata = {\n ...mergedResponse.assetsMetadata,\n ...result.assetsMetadata,\n };\n }\n if (result.assetsPrice) {\n mergedResponse.assetsPrice = {\n ...mergedResponse.assetsPrice,\n ...result.assetsPrice,\n };\n }\n if (result.errors) {\n mergedResponse.errors = { ...mergedResponse.errors, ...result.errors };\n }\n }\n\n return mergedResponse;\n }\n\n #groupChainsBySnap(\n chainIds: ChainId[],\n ): Partial<Record<SnapType, ChainId[]>> {\n const groups: Partial<Record<SnapType, ChainId[]>> = {};\n\n for (const chainId of chainIds) {\n const snapType = getSnapTypeForChain(chainId);\n if (snapType) {\n groups[snapType] ??= [];\n const snapChains = groups[snapType];\n if (snapChains) {\n snapChains.push(chainId);\n }\n }\n }\n\n return groups;\n }\n\n async #fetchFromSnap(\n snapType: SnapType,\n request: DataRequest,\n ): Promise<DataResponse> {\n const config = SNAP_REGISTRY[snapType];\n\n // Check snap availability on-demand - handles timing issues where snap\n // wasn't ready during initialization but is now available\n const isAvailable = await this.#checkSnapAvailabilityOnDemand(snapType);\n if (!isAvailable) {\n log(`${snapType} snap not available, skipping fetch`);\n // Return errors for these chains so they can fallback to other data sources\n const errors: Record<ChainId, string> = {};\n for (const chainId of request.chainIds) {\n errors[chainId] = `${snapType} snap not available`;\n }\n return { errors };\n }\n\n const results: DataResponse = {\n assetsBalance: {},\n assetsMetadata: {},\n };\n\n // Fetch balances for each account using Keyring API\n // Important: Must first get account assets, then request balances for those specific assets\n for (const account of request.accounts) {\n // Filter to only process accounts that support the chains being fetched\n const accountSupportedChains = request.chainIds.filter((chainId) =>\n this.#accountSupportsChain(account, chainId),\n );\n\n // Skip accounts that don't support any of the requested chains\n if (accountSupportedChains.length === 0) {\n continue;\n }\n\n const accountId = account.id;\n try {\n // Step 1: Get the list of assets for this account\n log(`${snapType} snap calling keyring_listAccountAssets`, {\n snapId: config.snapId,\n accountId,\n });\n\n const accountAssets = await this.#snapProvider.request<string[]>({\n method: 'wallet_invokeSnap',\n params: {\n snapId: config.snapId,\n request: {\n method: 'keyring_listAccountAssets',\n params: {\n id: accountId, // Account UUID\n },\n },\n },\n });\n\n log(`${snapType} snap keyring_listAccountAssets response`, {\n accountId,\n assetCount: accountAssets?.length ?? 0,\n assets: accountAssets,\n });\n\n // If no assets, skip to next account\n if (!accountAssets || accountAssets.length === 0) {\n log(\n `${snapType} snap: account has no assets, skipping balance fetch`,\n {\n accountId,\n },\n );\n continue;\n }\n\n // Step 2: Get balances for those specific assets\n log(`${snapType} snap calling keyring_getAccountBalances`, {\n snapId: config.snapId,\n accountId,\n requestedAssets: accountAssets.length,\n });\n\n const balances = await this.#snapProvider.request<\n Record<string, { amount: string; unit: string; rawAmount?: string }>\n >({\n method: 'wallet_invokeSnap',\n params: {\n snapId: config.snapId,\n request: {\n method: 'keyring_getAccountBalances',\n params: {\n id: accountId, // Account UUID (the keyring API uses 'id' not 'accountId')\n assets: accountAssets, // Must pass specific asset types from listAccountAssets\n },\n },\n },\n });\n\n log(`${snapType} snap keyring_getAccountBalances response`, {\n accountId,\n balances,\n balancesType: typeof balances,\n isNull: balances === null,\n isUndefined: balances === undefined,\n assetCount: balances ? Object.keys(balances).length : 0,\n });\n\n // Transform keyring response to DataResponse format\n // Note: snap may return null/undefined if account doesn't belong to this snap\n if (balances && typeof balances === 'object' && results.assetsBalance) {\n const balanceEntries = Object.entries(balances);\n log(\n `${snapType} snap processing ${balanceEntries.length} balances for account ${accountId}`,\n );\n\n for (const [assetId, balance] of balanceEntries) {\n // Initialize account balances if not exists\n results.assetsBalance[accountId] ??= {};\n // Store raw balance for this asset\n // Use rawAmount if available (preferred - smallest unit), fall back to amount\n // Note: Snaps should return rawAmount in smallest unit (satoshis, lamports, etc.)\n const accountBalances = results.assetsBalance[accountId];\n if (accountBalances) {\n (accountBalances as Record<string, unknown>)[assetId] = {\n amount: balance.rawAmount ?? balance.amount,\n };\n }\n }\n } else if (!balances) {\n log(\n `${snapType} snap returned empty/null for account (account may not belong to this snap)`,\n {\n accountId,\n balances,\n },\n );\n }\n } catch (error) {\n // This is expected when querying a snap with an account it doesn't manage\n log(`${snapType} snap fetch FAILED for account`, {\n accountId,\n error: error instanceof Error ? error.message : String(error),\n errorStack: error instanceof Error ? error.stack : undefined,\n });\n }\n }\n\n log(`${snapType} snap fetch completed`, {\n chains: request.chainIds.length,\n accountsWithBalances: Object.keys(results.assetsBalance ?? {}).length,\n });\n\n return results;\n }\n\n // ============================================================================\n // MIDDLEWARE\n // ============================================================================\n\n /**\n * Get the middleware for fetching balances via Snaps.\n * This middleware:\n * - Supports multiple accounts in a single request\n * - Filters request to only chains this data source supports\n * - Fetches balances for those chains for all accounts\n * - Merges response into context\n * - Removes handled chains from request for next middleware\n *\n * @returns The middleware function for the assets pipeline.\n */\n get assetsMiddleware(): Middleware {\n return async (context, next) => {\n const { request } = context;\n\n // Filter to chains this data source supports\n const supportedChains = request.chainIds.filter((chainId) =>\n this.state.activeChains.includes(chainId),\n );\n\n // If no supported chains, skip and pass to next middleware\n if (supportedChains.length === 0) {\n return next(context);\n }\n\n let successfullyHandledChains: ChainId[] = [];\n\n try {\n // Fetch for supported chains\n const response = await this.fetch({\n ...request,\n chainIds: supportedChains,\n });\n\n // Merge response into context\n if (response.assetsBalance) {\n context.response.assetsBalance ??= {};\n for (const [accountId, accountBalances] of Object.entries(\n response.assetsBalance,\n )) {\n context.response.assetsBalance[accountId] = {\n ...context.response.assetsBalance[accountId],\n ...accountBalances,\n };\n }\n }\n if (response.assetsMetadata) {\n context.response.assetsMetadata = {\n ...context.response.assetsMetadata,\n ...response.assetsMetadata,\n };\n }\n if (response.assetsPrice) {\n context.response.assetsPrice = {\n ...context.response.assetsPrice,\n ...response.assetsPrice,\n };\n }\n\n // Determine successfully handled chains (exclude errors)\n const failedChains = new Set(Object.keys(response.errors ?? {}));\n successfullyHandledChains = supportedChains.filter(\n (chainId) => !failedChains.has(chainId),\n );\n } catch (error) {\n log('Middleware fetch failed', { error });\n successfullyHandledChains = [];\n }\n\n // Prepare context for next middleware\n let nextContext = context;\n if (successfullyHandledChains.length > 0) {\n const remainingChains = request.chainIds.filter(\n (chainId) => !successfullyHandledChains.includes(chainId),\n );\n nextContext = {\n ...context,\n request: {\n ...request,\n chainIds: remainingChains,\n },\n };\n }\n\n // Call next middleware\n return next(nextContext);\n };\n }\n\n // ============================================================================\n // SUBSCRIBE - Routes to appropriate snap(s)\n // ============================================================================\n\n async subscribe(subscriptionRequest: SubscriptionRequest): Promise<void> {\n const { request, subscriptionId, isUpdate } = subscriptionRequest;\n\n // Guard against undefined request or chainIds\n if (!request?.chainIds) {\n return;\n }\n\n // Filter to only snap-supported chains\n const snapChains = request.chainIds.filter(isSnapSupportedChain);\n\n if (snapChains.length === 0) {\n return;\n }\n\n if (isUpdate) {\n const existing = this.activeSubscriptions.get(subscriptionId);\n if (existing) {\n existing.chains = snapChains;\n // Do a fetch to get latest data on subscription update\n this.fetch({\n ...request,\n chainIds: snapChains,\n })\n .then(async (fetchResponse) => {\n if (Object.keys(fetchResponse.assetsBalance ?? {}).length > 0) {\n await this.#messenger.call(\n 'AssetsController:assetsUpdate',\n fetchResponse,\n SNAP_DATA_SOURCE_NAME,\n );\n }\n return fetchResponse;\n })\n .catch((error) => {\n log('Subscription update fetch failed', { subscriptionId, error });\n });\n return;\n }\n }\n\n await this.unsubscribe(subscriptionId);\n\n // Snaps provide real-time updates via AccountsController:accountBalancesUpdated\n // We only need to track the subscription and do an initial fetch\n // No polling needed - updates come through #handleSnapBalancesUpdated\n\n this.activeSubscriptions.set(subscriptionId, {\n cleanup: () => {\n // No timer to clear - we use event-based updates\n },\n chains: snapChains,\n });\n\n // Initial fetch to get current balances\n try {\n const fetchResponse = await this.fetch({\n ...request,\n chainIds: snapChains,\n });\n\n if (Object.keys(fetchResponse.assetsBalance ?? {}).length > 0) {\n await this.#messenger.call(\n 'AssetsController:assetsUpdate',\n fetchResponse,\n SNAP_DATA_SOURCE_NAME,\n );\n }\n } catch (error) {\n log('Initial fetch failed', { subscriptionId, error });\n }\n }\n\n // ============================================================================\n // CLEANUP\n // ============================================================================\n\n destroy(): void {\n for (const [subscriptionId] of this.activeSubscriptions) {\n this.unsubscribe(subscriptionId).catch(() => {\n // Ignore cleanup errors\n });\n }\n }\n}\n\n// ============================================================================\n// FACTORY\n// ============================================================================\n\nexport function createSnapDataSource(\n options: SnapDataSourceOptions,\n): SnapDataSource {\n return new SnapDataSource(options);\n}\n"]}
|
|
1
|
+
{"version":3,"file":"SnapDataSource.cjs","sourceRoot":"","sources":["../../src/data-sources/SnapDataSource.ts"],"names":[],"mappings":"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","sourcesContent":["import type { Balance, CaipAssetType } from '@metamask/keyring-api';\nimport { KeyringClient } from '@metamask/keyring-snap-client';\nimport type { Messenger } from '@metamask/messenger';\nimport type {\n Caveat,\n GetPermissions,\n PermissionConstraint,\n PermissionControllerStateChange,\n SubjectPermissions,\n} from '@metamask/permission-controller';\nimport type {\n GetRunnableSnaps,\n HandleSnapRequest,\n} from '@metamask/snaps-controllers';\nimport type { Snap, SnapId } from '@metamask/snaps-sdk';\nimport { HandlerType, SnapCaveatType } from '@metamask/snaps-utils';\nimport type { Json, JsonRpcRequest } from '@metamask/utils';\n\nimport { AbstractDataSource } from './AbstractDataSource';\nimport type {\n DataSourceState,\n SubscriptionRequest,\n} from './AbstractDataSource';\nimport { projectLogger, createModuleLogger } from '../logger';\nimport type {\n AssetBalance,\n ChainId,\n Caip19AssetId,\n DataRequest,\n DataResponse,\n Middleware,\n} from '../types';\n\n// ============================================================================\n// SNAP KEYRING EVENT TYPES\n// ============================================================================\n\n/**\n * Payload for AccountsController:accountBalancesUpdated event.\n * Re-published from SnapKeyring:accountBalancesUpdated.\n */\nexport type AccountBalancesUpdatedEventPayload = {\n balances: {\n [accountId: string]: {\n [assetId: string]: {\n amount: string;\n unit: string;\n };\n };\n };\n};\n\n/**\n * Event from AccountsController when snap balances are updated.\n */\nexport type AccountsControllerAccountBalancesUpdatedEvent = {\n type: 'AccountsController:accountBalancesUpdated';\n payload: [AccountBalancesUpdatedEventPayload];\n};\n\nconst log = createModuleLogger(projectLogger, 'SnapDataSource');\n\n// ============================================================================\n// CONSTANTS\n// ============================================================================\n\nexport const SNAP_DATA_SOURCE_NAME = 'SnapDataSource';\n\n/** The permission name for snap keyring endowment */\nexport const KEYRING_PERMISSION = 'endowment:keyring';\n\n/** The permission name for snap assets endowment (contains chainIds) */\nexport const ASSETS_PERMISSION = 'endowment:assets';\n\n// ============================================================================\n// PERMISSION UTILITIES\n// ============================================================================\n\n/**\n * Getter function to get the chainIds caveat from a permission.\n *\n * This does basic validation of the caveat, but does not validate the type or\n * value of the namespaces object itself, as this is handled by the\n * `PermissionsController` when the permission is requested.\n *\n * @param permission - The permission to get the `chainIds` caveat from.\n * @returns An array of `chainIds` that the snap supports, or null if none.\n */\nexport function getChainIdsCaveat(\n permission?: PermissionConstraint,\n): ChainId[] | null {\n if (!permission?.caveats) {\n return null;\n }\n\n const caveat = permission.caveats.find(\n (permCaveat) => permCaveat.type === SnapCaveatType.ChainIds,\n ) as Caveat<string, string[]> | undefined;\n\n return caveat ? (caveat.value as ChainId[]) : null;\n}\n\n/**\n * Extract chain ID from a CAIP-19 asset ID.\n * e.g., \"solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp/slip44:501\" -> \"solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp\"\n *\n * @param assetId - The CAIP-19 asset ID to extract chain from.\n * @returns The CAIP-2 chain ID portion of the asset ID.\n */\nexport function extractChainFromAssetId(assetId: string): ChainId {\n const parts = assetId.split('/');\n return parts[0] as ChainId;\n}\n\n// ============================================================================\n// STATE\n// ============================================================================\n\n/**\n * State for the SnapDataSource.\n * Uses dynamic snap discovery - chains are populated from PermissionController.\n */\nexport type SnapDataSourceState = {\n /**\n * Mapping of chain IDs to snap IDs that support them.\n * Used to filter which accounts to process for a given chain request.\n */\n chainToSnap: Record<ChainId, string>;\n} & DataSourceState;\n\nconst defaultSnapState: SnapDataSourceState = {\n activeChains: [],\n chainToSnap: {},\n};\n\n// ============================================================================\n// MESSENGER TYPES\n// ============================================================================\n\nexport type SnapDataSourceGetAssetsMiddlewareAction = {\n type: 'SnapDataSource:getAssetsMiddleware';\n handler: () => Middleware;\n};\n\nexport type SnapDataSourceGetActiveChainsAction = {\n type: 'SnapDataSource:getActiveChains';\n handler: () => Promise<ChainId[]>;\n};\n\nexport type SnapDataSourceFetchAction = {\n type: 'SnapDataSource:fetch';\n handler: (request: DataRequest) => Promise<DataResponse>;\n};\n\nexport type SnapDataSourceSubscribeAction = {\n type: 'SnapDataSource:subscribe';\n handler: (request: SubscriptionRequest) => Promise<void>;\n};\n\nexport type SnapDataSourceUnsubscribeAction = {\n type: 'SnapDataSource:unsubscribe';\n handler: (subscriptionId: string) => Promise<void>;\n};\n\nexport type SnapDataSourceActions =\n | SnapDataSourceGetAssetsMiddlewareAction\n | SnapDataSourceGetActiveChainsAction\n | SnapDataSourceFetchAction\n | SnapDataSourceSubscribeAction\n | SnapDataSourceUnsubscribeAction;\n\nexport type SnapDataSourceActiveChainsChangedEvent = {\n type: 'SnapDataSource:activeChainsUpdated';\n payload: [ChainId[]];\n};\n\nexport type SnapDataSourceAssetsUpdatedEvent = {\n type: 'SnapDataSource:assetsUpdated';\n payload: [DataResponse, string | undefined];\n};\n\nexport type SnapDataSourceEvents =\n | SnapDataSourceActiveChainsChangedEvent\n | SnapDataSourceAssetsUpdatedEvent;\n\n/**\n * Allowed events that SnapDataSource can subscribe to.\n */\nexport type SnapDataSourceAllowedEvents =\n | AccountsControllerAccountBalancesUpdatedEvent\n | PermissionControllerStateChange;\n\n// Actions to report to AssetsController\ntype AssetsControllerActiveChainsUpdateAction = {\n type: 'AssetsController:activeChainsUpdate';\n handler: (dataSourceId: string, activeChains: ChainId[]) => void;\n};\n\ntype AssetsControllerAssetsUpdateAction = {\n type: 'AssetsController:assetsUpdate';\n handler: (response: DataResponse, sourceId: string) => Promise<void>;\n};\n\nexport type SnapDataSourceAllowedActions =\n | AssetsControllerActiveChainsUpdateAction\n | AssetsControllerAssetsUpdateAction\n | GetRunnableSnaps\n | HandleSnapRequest\n | GetPermissions;\n\nexport type SnapDataSourceMessenger = Messenger<\n typeof SNAP_DATA_SOURCE_NAME,\n SnapDataSourceActions | SnapDataSourceAllowedActions,\n SnapDataSourceEvents | SnapDataSourceAllowedEvents\n>;\n\n// ============================================================================\n// OPTIONS\n// ============================================================================\n\nexport type SnapDataSourceOptions = {\n /** Messenger for this data source */\n messenger: SnapDataSourceMessenger;\n /** Configured networks to support (defaults to all snap networks) */\n configuredNetworks?: ChainId[];\n /** Default polling interval in ms for subscriptions */\n pollInterval?: number;\n /** Initial state */\n state?: Partial<SnapDataSourceState>;\n};\n\n// ============================================================================\n// SNAP DATA SOURCE\n// ============================================================================\n\n/**\n * Unified Snap data source that routes requests to the appropriate wallet snap\n * based on the chain ID prefix.\n *\n * @example\n * ```typescript\n * const snapDataSource = new SnapDataSource({\n * messenger,\n * });\n *\n * // Fetch will automatically route to the correct snap\n * await snapDataSource.fetch({\n * chainIds: ['solana:mainnet', 'bip122:000000000019d6689c085ae165831e93'],\n * accountIds: ['account1'],\n * });\n * ```\n */\nexport class SnapDataSource extends AbstractDataSource<\n typeof SNAP_DATA_SOURCE_NAME,\n SnapDataSourceState\n> {\n readonly #messenger: SnapDataSourceMessenger;\n\n /** Bound handler for snap keyring balance updates, stored for cleanup */\n readonly #handleSnapBalancesUpdatedBound: (\n payload: AccountBalancesUpdatedEventPayload,\n ) => void;\n\n readonly #handlePermissionStateChangeBound: () => void;\n\n /** Cache of KeyringClient instances per snap ID to avoid re-instantiation */\n readonly #keyringClientCache: Map<string, KeyringClient> = new Map();\n\n constructor(options: SnapDataSourceOptions) {\n super(SNAP_DATA_SOURCE_NAME, {\n ...defaultSnapState,\n ...options.state,\n });\n\n this.#messenger = options.messenger;\n\n // Bind handlers for cleanup in destroy()\n this.#handleSnapBalancesUpdatedBound = this.#handleSnapBalancesUpdated.bind(\n this,\n ) as (payload: AccountBalancesUpdatedEventPayload) => void;\n this.#handlePermissionStateChangeBound =\n this.#discoverKeyringSnaps.bind(this);\n\n this.#registerActionHandlers();\n this.#subscribeToEvents();\n\n // Discover keyring-capable snaps and populate activeChains dynamically\n this.#discoverKeyringSnaps();\n }\n\n /**\n * Subscribe to all events needed by SnapDataSource.\n * Groups snap keyring events and permission change events.\n */\n #subscribeToEvents(): void {\n // Subscribe to snap keyring events for real-time balance updates.\n // The snaps emit AccountBalancesUpdated events when balances change,\n // which are re-published by AccountsController.\n this.#messenger.subscribe(\n 'AccountsController:accountBalancesUpdated',\n this.#handleSnapBalancesUpdatedBound,\n );\n\n // Subscribe to permission changes to detect new keyring snaps at runtime.\n // Re-runs snap discovery when permissions change.\n this.#messenger.subscribe(\n 'PermissionController:stateChange',\n this.#handlePermissionStateChangeBound,\n );\n }\n\n /**\n * Handle snap balance updates from the keyring.\n * Transforms the payload and publishes to AssetsController.\n *\n * @param payload - The balance update payload from AccountsController.\n */\n #handleSnapBalancesUpdated(\n payload: AccountBalancesUpdatedEventPayload,\n ): void {\n // Transform the snap keyring payload to DataResponse format\n let assetsBalance: NonNullable<DataResponse['assetsBalance']> | undefined;\n\n for (const [accountId, assets] of Object.entries(payload.balances)) {\n let accountAssets: Record<Caip19AssetId, AssetBalance> | undefined;\n\n for (const [assetId, balance] of Object.entries(assets)) {\n const chainId = extractChainFromAssetId(assetId);\n if (this.#isChainSupportedBySnap(chainId)) {\n accountAssets ??= {};\n accountAssets[assetId as Caip19AssetId] = {\n amount: balance.amount,\n };\n }\n }\n\n if (accountAssets) {\n assetsBalance ??= {};\n assetsBalance[accountId] = accountAssets;\n }\n }\n\n // Only report if we have snap-related updates\n if (assetsBalance) {\n const response: DataResponse = { assetsBalance };\n this.#messenger\n .call('AssetsController:assetsUpdate', response, SNAP_DATA_SOURCE_NAME)\n .catch(console.error);\n }\n }\n\n /**\n * Check if a chain ID is supported by any discovered snap.\n *\n * @param chainId - The CAIP-2 chain ID to check.\n * @returns True if we have a snap that supports this chain.\n */\n #isChainSupportedBySnap(chainId: ChainId): boolean {\n return this.state.activeChains.includes(chainId);\n }\n\n #registerActionHandlers(): void {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const messenger = this.#messenger as any;\n\n messenger.registerActionHandler(\n 'SnapDataSource:getAssetsMiddleware',\n () => this.assetsMiddleware,\n );\n\n messenger.registerActionHandler(\n 'SnapDataSource:getActiveChains',\n async () => this.getActiveChains(),\n );\n\n messenger.registerActionHandler(\n 'SnapDataSource:fetch',\n async (request: DataRequest) => this.fetch(request),\n );\n\n messenger.registerActionHandler(\n 'SnapDataSource:subscribe',\n async (request: SubscriptionRequest) => this.subscribe(request),\n );\n\n messenger.registerActionHandler(\n 'SnapDataSource:unsubscribe',\n async (subscriptionId: string) => this.unsubscribe(subscriptionId),\n );\n }\n\n // ============================================================================\n // SNAP DISCOVERY (Dynamic via PermissionController)\n // ============================================================================\n\n /**\n * Get all runnable snaps from SnapController.\n * Runnable snaps are enabled and not blocked.\n *\n * @returns Array of runnable snaps.\n */\n #getRunnableSnaps(): Snap[] {\n try {\n return this.#messenger.call('SnapController:getRunnableSnaps');\n } catch (error) {\n log('Failed to get runnable snaps', error);\n return [];\n }\n }\n\n /**\n * Get permissions for a snap from PermissionController.\n *\n * @param snapId - The snap ID to get permissions for.\n * @returns The snap's permissions, or undefined if none.\n */\n #getSnapPermissions(\n snapId: string,\n ): SubjectPermissions<PermissionConstraint> | undefined {\n try {\n return this.#messenger.call(\n 'PermissionController:getPermissions',\n snapId,\n ) as SubjectPermissions<PermissionConstraint>;\n } catch (error) {\n log('Failed to get permissions for snap', { snapId, error });\n return undefined;\n }\n }\n\n /**\n * Discover all snaps with keyring capabilities and their supported chains.\n * Uses PermissionController to find snaps with endowment:keyring permission.\n * Updates chainToSnap mapping and activeChains.\n *\n * Called on initialization and whenever PermissionController state changes\n * (e.g., new snaps installed, permissions granted/revoked).\n *\n * @remarks\n * **Known limitation:** If discovery fails (e.g., SnapController not ready),\n * the data source continues with empty chainToSnap. This means no snap\n * chains will be supported until a re-discovery is triggered by a permission\n * change. Callers should be aware that initialization may complete with no\n * active chains.\n */\n #discoverKeyringSnaps(): void {\n try {\n const runnableSnaps = this.#getRunnableSnaps();\n const chainToSnap: Record<ChainId, string> = {};\n const supportedChains: ChainId[] = [];\n\n for (const snap of runnableSnaps) {\n const permissions = this.#getSnapPermissions(snap.id);\n // Must have endowment:keyring permission to be a keyring snap\n if (!permissions?.[KEYRING_PERMISSION]) {\n continue;\n }\n\n // Get chainIds caveat from the assets permission (not keyring permission)\n // The chainIds are stored in endowment:assets\n const assetsPermission = permissions[ASSETS_PERMISSION];\n const chainIds = getChainIdsCaveat(assetsPermission);\n\n // Map each chain to this snap (first snap wins if multiple support same chain)\n if (chainIds) {\n for (const chainId of chainIds) {\n if (!(chainId in chainToSnap)) {\n chainToSnap[chainId] = snap.id;\n supportedChains.push(chainId);\n }\n }\n }\n }\n\n // Update chainToSnap mapping\n this.state.chainToSnap = chainToSnap;\n\n // Notify if chains changed\n try {\n this.updateActiveChains(supportedChains, (updatedChains) => {\n this.#messenger.call(\n 'AssetsController:activeChainsUpdate',\n SNAP_DATA_SOURCE_NAME,\n updatedChains,\n );\n });\n } catch {\n // AssetsController not ready yet - expected during initialization\n }\n } catch (error) {\n log('Keyring snap discovery failed', { error });\n this.state.chainToSnap = {};\n try {\n this.updateActiveChains([], (updatedChains) => {\n this.#messenger.call(\n 'AssetsController:activeChainsUpdate',\n SNAP_DATA_SOURCE_NAME,\n updatedChains,\n );\n });\n } catch {\n // AssetsController not ready yet - expected during initialization\n }\n }\n }\n\n // ============================================================================\n // FETCH\n // ============================================================================\n\n async fetch(request: DataRequest): Promise<DataResponse> {\n // Guard against undefined request\n // Note: chainIds filtering is done by middleware/subscribe before calling fetch\n if (!request?.accounts || !request?.chainIds?.length) {\n return {};\n }\n\n const results: DataResponse = {\n assetsBalance: {},\n assetsMetadata: {},\n };\n\n // Fetch balances for each account using its snap ID from metadata\n for (const account of request.accounts) {\n // Skip accounts without snap metadata (non-snap accounts)\n const snapId = account.metadata.snap?.id;\n if (!snapId) {\n continue;\n }\n\n // Skip accounts whose snap doesn't support any of the requested chains\n const snapSupportsRequestedChains = request.chainIds.some(\n (chainId) => this.state.chainToSnap[chainId] === snapId,\n );\n if (!snapSupportsRequestedChains) {\n continue;\n }\n\n const accountId = account.id;\n try {\n const client = this.#getKeyringClient(snapId);\n\n // Step 1: Get the list of assets for this account\n const accountAssets = await client.listAccountAssets(accountId);\n\n // If no assets, skip to next account\n if (!accountAssets || accountAssets.length === 0) {\n continue;\n }\n\n // Step 2: Get balances for those specific assets\n const balances: Record<CaipAssetType, Balance> =\n await client.getAccountBalances(\n accountId,\n accountAssets as CaipAssetType[],\n );\n\n // Transform keyring response to DataResponse format\n if (balances && typeof balances === 'object' && results.assetsBalance) {\n for (const [assetId, balance] of Object.entries(balances)) {\n results.assetsBalance[accountId] ??= {};\n const accountBalances = results.assetsBalance[accountId];\n if (accountBalances) {\n (accountBalances as Record<string, unknown>)[assetId] = {\n amount: balance.amount,\n };\n }\n }\n }\n } catch {\n // Expected when account doesn't belong to this snap\n }\n }\n\n return results;\n }\n\n // ============================================================================\n // MIDDLEWARE\n // ============================================================================\n\n /**\n * Get the middleware for fetching balances via Snaps.\n * This middleware:\n * - Supports multiple accounts in a single request\n * - Filters request to only chains this data source supports\n * - Fetches balances for those chains for all accounts\n * - Merges response into context\n * - Removes handled chains from request for next middleware\n *\n * @returns The middleware function for the assets pipeline.\n */\n get assetsMiddleware(): Middleware {\n return async (context, next) => {\n const { request } = context;\n\n // Filter to chains this data source supports\n const supportedChains = request.chainIds.filter((chainId) =>\n this.state.activeChains.includes(chainId),\n );\n\n // If no supported chains, skip and pass to next middleware\n if (supportedChains.length === 0) {\n return next(context);\n }\n\n let successfullyHandledChains: ChainId[] = [];\n\n try {\n // Fetch for supported chains\n const response = await this.fetch({\n ...request,\n chainIds: supportedChains,\n });\n\n // Merge response into context\n if (response.assetsBalance) {\n context.response.assetsBalance ??= {};\n for (const [accountId, accountBalances] of Object.entries(\n response.assetsBalance,\n )) {\n context.response.assetsBalance[accountId] = {\n ...context.response.assetsBalance[accountId],\n ...accountBalances,\n };\n }\n }\n if (response.assetsMetadata) {\n context.response.assetsMetadata = {\n ...context.response.assetsMetadata,\n ...response.assetsMetadata,\n };\n }\n if (response.assetsPrice) {\n context.response.assetsPrice = {\n ...context.response.assetsPrice,\n ...response.assetsPrice,\n };\n }\n\n // Determine successfully handled chains (exclude errors)\n const failedChains = new Set(Object.keys(response.errors ?? {}));\n successfullyHandledChains = supportedChains.filter(\n (chainId) => !failedChains.has(chainId),\n );\n } catch (error) {\n log('Middleware fetch failed', { error });\n successfullyHandledChains = [];\n }\n\n // Prepare context for next middleware\n let nextContext = context;\n if (successfullyHandledChains.length > 0) {\n const remainingChains = request.chainIds.filter(\n (chainId) => !successfullyHandledChains.includes(chainId),\n );\n nextContext = {\n ...context,\n request: {\n ...request,\n chainIds: remainingChains,\n },\n };\n }\n\n // Call next middleware\n return next(nextContext);\n };\n }\n\n // ============================================================================\n // SUBSCRIBE - Routes to appropriate snap(s)\n // ============================================================================\n\n async subscribe(subscriptionRequest: SubscriptionRequest): Promise<void> {\n const { request, subscriptionId, isUpdate } = subscriptionRequest;\n\n // Guard against undefined request or chainIds\n if (!request?.chainIds) {\n return;\n }\n\n // Filter to chains we have a snap for\n const supportedChains = request.chainIds.filter((chainId) =>\n this.#isChainSupportedBySnap(chainId),\n );\n\n if (supportedChains.length === 0) {\n return;\n }\n\n if (isUpdate) {\n const existing = this.activeSubscriptions.get(subscriptionId);\n if (existing) {\n existing.chains = supportedChains;\n // Do a fetch to get latest data on subscription update\n this.fetch({\n ...request,\n chainIds: supportedChains,\n })\n .then(async (fetchResponse) => {\n if (Object.keys(fetchResponse.assetsBalance ?? {}).length > 0) {\n await this.#messenger.call(\n 'AssetsController:assetsUpdate',\n fetchResponse,\n SNAP_DATA_SOURCE_NAME,\n );\n }\n return fetchResponse;\n })\n .catch((error) => {\n log('Subscription update fetch failed', { subscriptionId, error });\n });\n return;\n }\n }\n\n await this.unsubscribe(subscriptionId);\n\n // Snaps provide real-time updates via AccountsController:accountBalancesUpdated\n // We only need to track the subscription and do an initial fetch\n // No polling needed - updates come through #handleSnapBalancesUpdated\n\n this.activeSubscriptions.set(subscriptionId, {\n cleanup: () => {\n // No timer to clear - we use event-based updates\n },\n chains: supportedChains,\n });\n\n // Initial fetch to get current balances\n try {\n const fetchResponse = await this.fetch({\n ...request,\n chainIds: supportedChains,\n });\n\n if (Object.keys(fetchResponse.assetsBalance ?? {}).length > 0) {\n await this.#messenger.call(\n 'AssetsController:assetsUpdate',\n fetchResponse,\n SNAP_DATA_SOURCE_NAME,\n );\n }\n } catch (error) {\n log('Initial fetch failed', { subscriptionId, error });\n }\n }\n\n // ============================================================================\n // KEYRING CLIENT\n // ============================================================================\n\n /**\n * Gets a `KeyringClient` for a Snap.\n * Caches clients per snap ID to avoid re-instantiation across multiple calls.\n *\n * @param snapId - ID of the Snap to get the client for.\n * @returns A `KeyringClient` for the Snap.\n */\n #getKeyringClient(snapId: string): KeyringClient {\n const cachedClient = this.#keyringClientCache.get(snapId);\n if (cachedClient) {\n return cachedClient;\n }\n\n const client = new KeyringClient({\n send: async (request: JsonRpcRequest): Promise<Json> =>\n (await this.#messenger.call('SnapController:handleRequest', {\n snapId: snapId as SnapId,\n origin: 'metamask',\n handler: HandlerType.OnKeyringRequest,\n request,\n })) as Json,\n });\n\n this.#keyringClientCache.set(snapId, client);\n return client;\n }\n\n // ============================================================================\n // CLEANUP\n // ============================================================================\n\n destroy(): void {\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n const messenger = this.#messenger as any;\n\n // Unsubscribe from snap keyring events\n try {\n messenger.unsubscribe(\n 'AccountsController:accountBalancesUpdated',\n this.#handleSnapBalancesUpdatedBound,\n );\n } catch (error) {\n log('Failed to unsubscribe from snap keyring events', { error });\n }\n\n // Unsubscribe from permission changes\n try {\n messenger.unsubscribe(\n 'PermissionController:stateChange',\n this.#handlePermissionStateChangeBound,\n );\n } catch (error) {\n log('Failed to unsubscribe from permission changes', { error });\n }\n\n // Clean up active subscriptions\n for (const [subscriptionId] of this.activeSubscriptions) {\n this.unsubscribe(subscriptionId).catch(() => {\n // Ignore cleanup errors\n });\n }\n\n // Clear keyring client cache\n this.#keyringClientCache.clear();\n }\n}\n\n// ============================================================================\n// FACTORY\n// ============================================================================\n\nexport function createSnapDataSource(\n options: SnapDataSourceOptions,\n): SnapDataSource {\n return new SnapDataSource(options);\n}\n"]}
|
|
@@ -1,4 +1,6 @@
|
|
|
1
1
|
import type { Messenger } from "@metamask/messenger";
|
|
2
|
+
import type { GetPermissions, PermissionConstraint, PermissionControllerStateChange } from "@metamask/permission-controller";
|
|
3
|
+
import type { GetRunnableSnaps, HandleSnapRequest } from "@metamask/snaps-controllers";
|
|
2
4
|
import { AbstractDataSource } from "./AbstractDataSource.cjs";
|
|
3
5
|
import type { DataSourceState, SubscriptionRequest } from "./AbstractDataSource.cjs";
|
|
4
6
|
import type { ChainId, DataRequest, DataResponse, Middleware } from "../types.cjs";
|
|
@@ -24,51 +26,21 @@ export type AccountsControllerAccountBalancesUpdatedEvent = {
|
|
|
24
26
|
payload: [AccountBalancesUpdatedEventPayload];
|
|
25
27
|
};
|
|
26
28
|
export declare const SNAP_DATA_SOURCE_NAME = "SnapDataSource";
|
|
27
|
-
|
|
28
|
-
export declare const
|
|
29
|
-
|
|
30
|
-
export declare const
|
|
31
|
-
export declare const BITCOIN_CHAIN_PREFIX = "bip122:";
|
|
32
|
-
export declare const TRON_CHAIN_PREFIX = "tron:";
|
|
33
|
-
export declare const SOLANA_MAINNET: `${string}:${string}`;
|
|
34
|
-
export declare const SOLANA_DEVNET: `${string}:${string}`;
|
|
35
|
-
export declare const SOLANA_TESTNET: `${string}:${string}`;
|
|
36
|
-
export declare const BITCOIN_MAINNET: `${string}:${string}`;
|
|
37
|
-
export declare const BITCOIN_TESTNET: `${string}:${string}`;
|
|
38
|
-
export declare const TRON_MAINNET: `${string}:${string}`;
|
|
39
|
-
export declare const TRON_SHASTA: `${string}:${string}`;
|
|
40
|
-
export declare const TRON_NILE: `${string}:${string}`;
|
|
41
|
-
export declare const TRON_MAINNET_HEX: `${string}:${string}`;
|
|
42
|
-
export declare const TRON_SHASTA_HEX: `${string}:${string}`;
|
|
43
|
-
export declare const TRON_NILE_HEX: `${string}:${string}`;
|
|
44
|
-
export declare const DEFAULT_SOLANA_POLL_INTERVAL = 30000;
|
|
45
|
-
export declare const DEFAULT_BITCOIN_POLL_INTERVAL = 60000;
|
|
46
|
-
export declare const DEFAULT_TRON_POLL_INTERVAL = 30000;
|
|
47
|
-
export declare const DEFAULT_SNAP_POLL_INTERVAL = 30000;
|
|
48
|
-
export declare const ALL_DEFAULT_NETWORKS: ChainId[];
|
|
49
|
-
export type SnapType = 'solana' | 'bitcoin' | 'tron';
|
|
50
|
-
export type SnapInfo = {
|
|
51
|
-
snapId: string;
|
|
52
|
-
chainPrefix: string;
|
|
53
|
-
pollInterval: number;
|
|
54
|
-
version: string | null;
|
|
55
|
-
available: boolean;
|
|
56
|
-
};
|
|
57
|
-
export declare const SNAP_REGISTRY: Record<SnapType, Omit<SnapInfo, 'version' | 'available'>>;
|
|
29
|
+
/** The permission name for snap keyring endowment */
|
|
30
|
+
export declare const KEYRING_PERMISSION = "endowment:keyring";
|
|
31
|
+
/** The permission name for snap assets endowment (contains chainIds) */
|
|
32
|
+
export declare const ASSETS_PERMISSION = "endowment:assets";
|
|
58
33
|
/**
|
|
59
|
-
*
|
|
34
|
+
* Getter function to get the chainIds caveat from a permission.
|
|
60
35
|
*
|
|
61
|
-
*
|
|
62
|
-
*
|
|
63
|
-
|
|
64
|
-
export declare function getSnapTypeForChain(chainId: ChainId): SnapType | null;
|
|
65
|
-
/**
|
|
66
|
-
* Check if a chain ID is supported by a snap.
|
|
36
|
+
* This does basic validation of the caveat, but does not validate the type or
|
|
37
|
+
* value of the namespaces object itself, as this is handled by the
|
|
38
|
+
* `PermissionsController` when the permission is requested.
|
|
67
39
|
*
|
|
68
|
-
* @param
|
|
69
|
-
* @returns
|
|
40
|
+
* @param permission - The permission to get the `chainIds` caveat from.
|
|
41
|
+
* @returns An array of `chainIds` that the snap supports, or null if none.
|
|
70
42
|
*/
|
|
71
|
-
export declare function
|
|
43
|
+
export declare function getChainIdsCaveat(permission?: PermissionConstraint): ChainId[] | null;
|
|
72
44
|
/**
|
|
73
45
|
* Extract chain ID from a CAIP-19 asset ID.
|
|
74
46
|
* e.g., "solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp/slip44:501" -> "solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp"
|
|
@@ -77,15 +49,16 @@ export declare function isSnapSupportedChain(chainId: ChainId): boolean;
|
|
|
77
49
|
* @returns The CAIP-2 chain ID portion of the asset ID.
|
|
78
50
|
*/
|
|
79
51
|
export declare function extractChainFromAssetId(assetId: string): ChainId;
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
52
|
+
/**
|
|
53
|
+
* State for the SnapDataSource.
|
|
54
|
+
* Uses dynamic snap discovery - chains are populated from PermissionController.
|
|
55
|
+
*/
|
|
83
56
|
export type SnapDataSourceState = {
|
|
84
|
-
/**
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
57
|
+
/**
|
|
58
|
+
* Mapping of chain IDs to snap IDs that support them.
|
|
59
|
+
* Used to filter which accounts to process for a given chain request.
|
|
60
|
+
*/
|
|
61
|
+
chainToSnap: Record<ChainId, string>;
|
|
89
62
|
} & DataSourceState;
|
|
90
63
|
export type SnapDataSourceGetAssetsMiddlewareAction = {
|
|
91
64
|
type: 'SnapDataSource:getAssetsMiddleware';
|
|
@@ -120,7 +93,7 @@ export type SnapDataSourceEvents = SnapDataSourceActiveChainsChangedEvent | Snap
|
|
|
120
93
|
/**
|
|
121
94
|
* Allowed events that SnapDataSource can subscribe to.
|
|
122
95
|
*/
|
|
123
|
-
export type SnapDataSourceAllowedEvents = AccountsControllerAccountBalancesUpdatedEvent;
|
|
96
|
+
export type SnapDataSourceAllowedEvents = AccountsControllerAccountBalancesUpdatedEvent | PermissionControllerStateChange;
|
|
124
97
|
type AssetsControllerActiveChainsUpdateAction = {
|
|
125
98
|
type: 'AssetsController:activeChainsUpdate';
|
|
126
99
|
handler: (dataSourceId: string, activeChains: ChainId[]) => void;
|
|
@@ -129,21 +102,11 @@ type AssetsControllerAssetsUpdateAction = {
|
|
|
129
102
|
type: 'AssetsController:assetsUpdate';
|
|
130
103
|
handler: (response: DataResponse, sourceId: string) => Promise<void>;
|
|
131
104
|
};
|
|
132
|
-
export type SnapDataSourceAllowedActions = AssetsControllerActiveChainsUpdateAction | AssetsControllerAssetsUpdateAction;
|
|
105
|
+
export type SnapDataSourceAllowedActions = AssetsControllerActiveChainsUpdateAction | AssetsControllerAssetsUpdateAction | GetRunnableSnaps | HandleSnapRequest | GetPermissions;
|
|
133
106
|
export type SnapDataSourceMessenger = Messenger<typeof SNAP_DATA_SOURCE_NAME, SnapDataSourceActions | SnapDataSourceAllowedActions, SnapDataSourceEvents | SnapDataSourceAllowedEvents>;
|
|
134
|
-
export type SnapProvider = {
|
|
135
|
-
request<ResponseType>(args: {
|
|
136
|
-
method: string;
|
|
137
|
-
params?: unknown;
|
|
138
|
-
}): Promise<ResponseType>;
|
|
139
|
-
};
|
|
140
107
|
export type SnapDataSourceOptions = {
|
|
141
108
|
/** Messenger for this data source */
|
|
142
109
|
messenger: SnapDataSourceMessenger;
|
|
143
|
-
/**
|
|
144
|
-
* Snap provider for communicating with snaps.
|
|
145
|
-
*/
|
|
146
|
-
snapProvider: SnapProvider;
|
|
147
110
|
/** Configured networks to support (defaults to all snap networks) */
|
|
148
111
|
configuredNetworks?: ChainId[];
|
|
149
112
|
/** Default polling interval in ms for subscriptions */
|
|
@@ -155,16 +118,10 @@ export type SnapDataSourceOptions = {
|
|
|
155
118
|
* Unified Snap data source that routes requests to the appropriate wallet snap
|
|
156
119
|
* based on the chain ID prefix.
|
|
157
120
|
*
|
|
158
|
-
* Supports:
|
|
159
|
-
* - Solana chains (solana:*) → @metamask/solana-wallet-snap
|
|
160
|
-
* - Bitcoin chains (bip122:*) → @metamask/bitcoin-wallet-snap
|
|
161
|
-
* - Tron chains (tron:*) → @metamask/tron-wallet-snap
|
|
162
|
-
*
|
|
163
121
|
* @example
|
|
164
122
|
* ```typescript
|
|
165
123
|
* const snapDataSource = new SnapDataSource({
|
|
166
124
|
* messenger,
|
|
167
|
-
* snapProvider: metamaskProvider,
|
|
168
125
|
* });
|
|
169
126
|
*
|
|
170
127
|
* // Fetch will automatically route to the correct snap
|
|
@@ -177,25 +134,6 @@ export type SnapDataSourceOptions = {
|
|
|
177
134
|
export declare class SnapDataSource extends AbstractDataSource<typeof SNAP_DATA_SOURCE_NAME, SnapDataSourceState> {
|
|
178
135
|
#private;
|
|
179
136
|
constructor(options: SnapDataSourceOptions);
|
|
180
|
-
/**
|
|
181
|
-
* Get info about all snaps.
|
|
182
|
-
*
|
|
183
|
-
* @returns Record of snap info keyed by snap type.
|
|
184
|
-
*/
|
|
185
|
-
getSnapsInfo(): Record<SnapType, SnapInfo>;
|
|
186
|
-
/**
|
|
187
|
-
* Check if a specific snap is available.
|
|
188
|
-
*
|
|
189
|
-
* @param snapType - The snap type to check (solana, bitcoin, tron).
|
|
190
|
-
* @returns True if the snap is available.
|
|
191
|
-
*/
|
|
192
|
-
isSnapAvailable(snapType: SnapType): boolean;
|
|
193
|
-
/**
|
|
194
|
-
* Force refresh snap availability check.
|
|
195
|
-
*/
|
|
196
|
-
refreshSnapsStatus(): Promise<void>;
|
|
197
|
-
addNetworks(chainIds: ChainId[]): void;
|
|
198
|
-
removeNetworks(chainIds: ChainId[]): void;
|
|
199
137
|
fetch(request: DataRequest): Promise<DataResponse>;
|
|
200
138
|
/**
|
|
201
139
|
* Get the middleware for fetching balances via Snaps.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SnapDataSource.d.cts","sourceRoot":"","sources":["../../src/data-sources/SnapDataSource.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"SnapDataSource.d.cts","sourceRoot":"","sources":["../../src/data-sources/SnapDataSource.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,6 @@
|
|
|
1
1
|
import type { Messenger } from "@metamask/messenger";
|
|
2
|
+
import type { GetPermissions, PermissionConstraint, PermissionControllerStateChange } from "@metamask/permission-controller";
|
|
3
|
+
import type { GetRunnableSnaps, HandleSnapRequest } from "@metamask/snaps-controllers";
|
|
2
4
|
import { AbstractDataSource } from "./AbstractDataSource.mjs";
|
|
3
5
|
import type { DataSourceState, SubscriptionRequest } from "./AbstractDataSource.mjs";
|
|
4
6
|
import type { ChainId, DataRequest, DataResponse, Middleware } from "../types.mjs";
|
|
@@ -24,51 +26,21 @@ export type AccountsControllerAccountBalancesUpdatedEvent = {
|
|
|
24
26
|
payload: [AccountBalancesUpdatedEventPayload];
|
|
25
27
|
};
|
|
26
28
|
export declare const SNAP_DATA_SOURCE_NAME = "SnapDataSource";
|
|
27
|
-
|
|
28
|
-
export declare const
|
|
29
|
-
|
|
30
|
-
export declare const
|
|
31
|
-
export declare const BITCOIN_CHAIN_PREFIX = "bip122:";
|
|
32
|
-
export declare const TRON_CHAIN_PREFIX = "tron:";
|
|
33
|
-
export declare const SOLANA_MAINNET: `${string}:${string}`;
|
|
34
|
-
export declare const SOLANA_DEVNET: `${string}:${string}`;
|
|
35
|
-
export declare const SOLANA_TESTNET: `${string}:${string}`;
|
|
36
|
-
export declare const BITCOIN_MAINNET: `${string}:${string}`;
|
|
37
|
-
export declare const BITCOIN_TESTNET: `${string}:${string}`;
|
|
38
|
-
export declare const TRON_MAINNET: `${string}:${string}`;
|
|
39
|
-
export declare const TRON_SHASTA: `${string}:${string}`;
|
|
40
|
-
export declare const TRON_NILE: `${string}:${string}`;
|
|
41
|
-
export declare const TRON_MAINNET_HEX: `${string}:${string}`;
|
|
42
|
-
export declare const TRON_SHASTA_HEX: `${string}:${string}`;
|
|
43
|
-
export declare const TRON_NILE_HEX: `${string}:${string}`;
|
|
44
|
-
export declare const DEFAULT_SOLANA_POLL_INTERVAL = 30000;
|
|
45
|
-
export declare const DEFAULT_BITCOIN_POLL_INTERVAL = 60000;
|
|
46
|
-
export declare const DEFAULT_TRON_POLL_INTERVAL = 30000;
|
|
47
|
-
export declare const DEFAULT_SNAP_POLL_INTERVAL = 30000;
|
|
48
|
-
export declare const ALL_DEFAULT_NETWORKS: ChainId[];
|
|
49
|
-
export type SnapType = 'solana' | 'bitcoin' | 'tron';
|
|
50
|
-
export type SnapInfo = {
|
|
51
|
-
snapId: string;
|
|
52
|
-
chainPrefix: string;
|
|
53
|
-
pollInterval: number;
|
|
54
|
-
version: string | null;
|
|
55
|
-
available: boolean;
|
|
56
|
-
};
|
|
57
|
-
export declare const SNAP_REGISTRY: Record<SnapType, Omit<SnapInfo, 'version' | 'available'>>;
|
|
29
|
+
/** The permission name for snap keyring endowment */
|
|
30
|
+
export declare const KEYRING_PERMISSION = "endowment:keyring";
|
|
31
|
+
/** The permission name for snap assets endowment (contains chainIds) */
|
|
32
|
+
export declare const ASSETS_PERMISSION = "endowment:assets";
|
|
58
33
|
/**
|
|
59
|
-
*
|
|
34
|
+
* Getter function to get the chainIds caveat from a permission.
|
|
60
35
|
*
|
|
61
|
-
*
|
|
62
|
-
*
|
|
63
|
-
|
|
64
|
-
export declare function getSnapTypeForChain(chainId: ChainId): SnapType | null;
|
|
65
|
-
/**
|
|
66
|
-
* Check if a chain ID is supported by a snap.
|
|
36
|
+
* This does basic validation of the caveat, but does not validate the type or
|
|
37
|
+
* value of the namespaces object itself, as this is handled by the
|
|
38
|
+
* `PermissionsController` when the permission is requested.
|
|
67
39
|
*
|
|
68
|
-
* @param
|
|
69
|
-
* @returns
|
|
40
|
+
* @param permission - The permission to get the `chainIds` caveat from.
|
|
41
|
+
* @returns An array of `chainIds` that the snap supports, or null if none.
|
|
70
42
|
*/
|
|
71
|
-
export declare function
|
|
43
|
+
export declare function getChainIdsCaveat(permission?: PermissionConstraint): ChainId[] | null;
|
|
72
44
|
/**
|
|
73
45
|
* Extract chain ID from a CAIP-19 asset ID.
|
|
74
46
|
* e.g., "solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp/slip44:501" -> "solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp"
|
|
@@ -77,15 +49,16 @@ export declare function isSnapSupportedChain(chainId: ChainId): boolean;
|
|
|
77
49
|
* @returns The CAIP-2 chain ID portion of the asset ID.
|
|
78
50
|
*/
|
|
79
51
|
export declare function extractChainFromAssetId(assetId: string): ChainId;
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
52
|
+
/**
|
|
53
|
+
* State for the SnapDataSource.
|
|
54
|
+
* Uses dynamic snap discovery - chains are populated from PermissionController.
|
|
55
|
+
*/
|
|
83
56
|
export type SnapDataSourceState = {
|
|
84
|
-
/**
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
57
|
+
/**
|
|
58
|
+
* Mapping of chain IDs to snap IDs that support them.
|
|
59
|
+
* Used to filter which accounts to process for a given chain request.
|
|
60
|
+
*/
|
|
61
|
+
chainToSnap: Record<ChainId, string>;
|
|
89
62
|
} & DataSourceState;
|
|
90
63
|
export type SnapDataSourceGetAssetsMiddlewareAction = {
|
|
91
64
|
type: 'SnapDataSource:getAssetsMiddleware';
|
|
@@ -120,7 +93,7 @@ export type SnapDataSourceEvents = SnapDataSourceActiveChainsChangedEvent | Snap
|
|
|
120
93
|
/**
|
|
121
94
|
* Allowed events that SnapDataSource can subscribe to.
|
|
122
95
|
*/
|
|
123
|
-
export type SnapDataSourceAllowedEvents = AccountsControllerAccountBalancesUpdatedEvent;
|
|
96
|
+
export type SnapDataSourceAllowedEvents = AccountsControllerAccountBalancesUpdatedEvent | PermissionControllerStateChange;
|
|
124
97
|
type AssetsControllerActiveChainsUpdateAction = {
|
|
125
98
|
type: 'AssetsController:activeChainsUpdate';
|
|
126
99
|
handler: (dataSourceId: string, activeChains: ChainId[]) => void;
|
|
@@ -129,21 +102,11 @@ type AssetsControllerAssetsUpdateAction = {
|
|
|
129
102
|
type: 'AssetsController:assetsUpdate';
|
|
130
103
|
handler: (response: DataResponse, sourceId: string) => Promise<void>;
|
|
131
104
|
};
|
|
132
|
-
export type SnapDataSourceAllowedActions = AssetsControllerActiveChainsUpdateAction | AssetsControllerAssetsUpdateAction;
|
|
105
|
+
export type SnapDataSourceAllowedActions = AssetsControllerActiveChainsUpdateAction | AssetsControllerAssetsUpdateAction | GetRunnableSnaps | HandleSnapRequest | GetPermissions;
|
|
133
106
|
export type SnapDataSourceMessenger = Messenger<typeof SNAP_DATA_SOURCE_NAME, SnapDataSourceActions | SnapDataSourceAllowedActions, SnapDataSourceEvents | SnapDataSourceAllowedEvents>;
|
|
134
|
-
export type SnapProvider = {
|
|
135
|
-
request<ResponseType>(args: {
|
|
136
|
-
method: string;
|
|
137
|
-
params?: unknown;
|
|
138
|
-
}): Promise<ResponseType>;
|
|
139
|
-
};
|
|
140
107
|
export type SnapDataSourceOptions = {
|
|
141
108
|
/** Messenger for this data source */
|
|
142
109
|
messenger: SnapDataSourceMessenger;
|
|
143
|
-
/**
|
|
144
|
-
* Snap provider for communicating with snaps.
|
|
145
|
-
*/
|
|
146
|
-
snapProvider: SnapProvider;
|
|
147
110
|
/** Configured networks to support (defaults to all snap networks) */
|
|
148
111
|
configuredNetworks?: ChainId[];
|
|
149
112
|
/** Default polling interval in ms for subscriptions */
|
|
@@ -155,16 +118,10 @@ export type SnapDataSourceOptions = {
|
|
|
155
118
|
* Unified Snap data source that routes requests to the appropriate wallet snap
|
|
156
119
|
* based on the chain ID prefix.
|
|
157
120
|
*
|
|
158
|
-
* Supports:
|
|
159
|
-
* - Solana chains (solana:*) → @metamask/solana-wallet-snap
|
|
160
|
-
* - Bitcoin chains (bip122:*) → @metamask/bitcoin-wallet-snap
|
|
161
|
-
* - Tron chains (tron:*) → @metamask/tron-wallet-snap
|
|
162
|
-
*
|
|
163
121
|
* @example
|
|
164
122
|
* ```typescript
|
|
165
123
|
* const snapDataSource = new SnapDataSource({
|
|
166
124
|
* messenger,
|
|
167
|
-
* snapProvider: metamaskProvider,
|
|
168
125
|
* });
|
|
169
126
|
*
|
|
170
127
|
* // Fetch will automatically route to the correct snap
|
|
@@ -177,25 +134,6 @@ export type SnapDataSourceOptions = {
|
|
|
177
134
|
export declare class SnapDataSource extends AbstractDataSource<typeof SNAP_DATA_SOURCE_NAME, SnapDataSourceState> {
|
|
178
135
|
#private;
|
|
179
136
|
constructor(options: SnapDataSourceOptions);
|
|
180
|
-
/**
|
|
181
|
-
* Get info about all snaps.
|
|
182
|
-
*
|
|
183
|
-
* @returns Record of snap info keyed by snap type.
|
|
184
|
-
*/
|
|
185
|
-
getSnapsInfo(): Record<SnapType, SnapInfo>;
|
|
186
|
-
/**
|
|
187
|
-
* Check if a specific snap is available.
|
|
188
|
-
*
|
|
189
|
-
* @param snapType - The snap type to check (solana, bitcoin, tron).
|
|
190
|
-
* @returns True if the snap is available.
|
|
191
|
-
*/
|
|
192
|
-
isSnapAvailable(snapType: SnapType): boolean;
|
|
193
|
-
/**
|
|
194
|
-
* Force refresh snap availability check.
|
|
195
|
-
*/
|
|
196
|
-
refreshSnapsStatus(): Promise<void>;
|
|
197
|
-
addNetworks(chainIds: ChainId[]): void;
|
|
198
|
-
removeNetworks(chainIds: ChainId[]): void;
|
|
199
137
|
fetch(request: DataRequest): Promise<DataResponse>;
|
|
200
138
|
/**
|
|
201
139
|
* Get the middleware for fetching balances via Snaps.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SnapDataSource.d.mts","sourceRoot":"","sources":["../../src/data-sources/SnapDataSource.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"SnapDataSource.d.mts","sourceRoot":"","sources":["../../src/data-sources/SnapDataSource.ts"],"names":[],"mappings":"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"}
|