@metamask-previews/assets-controller 4.0.0-preview-b6a517f5e → 4.0.0-preview-119723bcd
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 +13 -0
- package/dist/AssetsController.cjs +59 -26
- package/dist/AssetsController.cjs.map +1 -1
- package/dist/AssetsController.d.cts +3 -3
- package/dist/AssetsController.d.cts.map +1 -1
- package/dist/AssetsController.d.mts +3 -3
- package/dist/AssetsController.d.mts.map +1 -1
- package/dist/AssetsController.mjs +59 -26
- package/dist/AssetsController.mjs.map +1 -1
- package/dist/data-sources/PriceDataSource.cjs +63 -38
- package/dist/data-sources/PriceDataSource.cjs.map +1 -1
- package/dist/data-sources/PriceDataSource.d.cts.map +1 -1
- package/dist/data-sources/PriceDataSource.d.mts.map +1 -1
- package/dist/data-sources/PriceDataSource.mjs +63 -38
- package/dist/data-sources/PriceDataSource.mjs.map +1 -1
- package/dist/data-sources/RpcDataSource.cjs +8 -57
- package/dist/data-sources/RpcDataSource.cjs.map +1 -1
- package/dist/data-sources/RpcDataSource.d.cts +1 -2
- package/dist/data-sources/RpcDataSource.d.cts.map +1 -1
- package/dist/data-sources/RpcDataSource.d.mts +1 -2
- package/dist/data-sources/RpcDataSource.d.mts.map +1 -1
- package/dist/data-sources/RpcDataSource.mjs +10 -59
- package/dist/data-sources/RpcDataSource.mjs.map +1 -1
- package/dist/data-sources/TokenDataSource.cjs +61 -30
- package/dist/data-sources/TokenDataSource.cjs.map +1 -1
- package/dist/data-sources/TokenDataSource.d.cts.map +1 -1
- package/dist/data-sources/TokenDataSource.d.mts.map +1 -1
- package/dist/data-sources/TokenDataSource.mjs +63 -32
- package/dist/data-sources/TokenDataSource.mjs.map +1 -1
- package/dist/data-sources/evm-rpc-services/clients/TokensApiClient.cjs +67 -0
- package/dist/data-sources/evm-rpc-services/clients/TokensApiClient.cjs.map +1 -0
- package/dist/data-sources/evm-rpc-services/clients/TokensApiClient.d.cts +23 -0
- package/dist/data-sources/evm-rpc-services/clients/TokensApiClient.d.cts.map +1 -0
- package/dist/data-sources/evm-rpc-services/clients/TokensApiClient.d.mts +23 -0
- package/dist/data-sources/evm-rpc-services/clients/TokensApiClient.d.mts.map +1 -0
- package/dist/data-sources/evm-rpc-services/clients/TokensApiClient.mjs +63 -0
- package/dist/data-sources/evm-rpc-services/clients/TokensApiClient.mjs.map +1 -0
- package/dist/data-sources/evm-rpc-services/clients/index.cjs +3 -1
- package/dist/data-sources/evm-rpc-services/clients/index.cjs.map +1 -1
- package/dist/data-sources/evm-rpc-services/clients/index.d.cts +1 -0
- package/dist/data-sources/evm-rpc-services/clients/index.d.cts.map +1 -1
- package/dist/data-sources/evm-rpc-services/clients/index.d.mts +1 -0
- package/dist/data-sources/evm-rpc-services/clients/index.d.mts.map +1 -1
- package/dist/data-sources/evm-rpc-services/clients/index.mjs +1 -0
- package/dist/data-sources/evm-rpc-services/clients/index.mjs.map +1 -1
- package/dist/data-sources/evm-rpc-services/index.cjs +2 -1
- package/dist/data-sources/evm-rpc-services/index.cjs.map +1 -1
- package/dist/data-sources/evm-rpc-services/index.d.cts +1 -1
- package/dist/data-sources/evm-rpc-services/index.d.cts.map +1 -1
- package/dist/data-sources/evm-rpc-services/index.d.mts +1 -1
- package/dist/data-sources/evm-rpc-services/index.d.mts.map +1 -1
- package/dist/data-sources/evm-rpc-services/index.mjs +1 -1
- package/dist/data-sources/evm-rpc-services/index.mjs.map +1 -1
- package/dist/data-sources/evm-rpc-services/services/TokenDetector.cjs +47 -50
- package/dist/data-sources/evm-rpc-services/services/TokenDetector.cjs.map +1 -1
- package/dist/data-sources/evm-rpc-services/services/TokenDetector.d.cts +12 -9
- package/dist/data-sources/evm-rpc-services/services/TokenDetector.d.cts.map +1 -1
- package/dist/data-sources/evm-rpc-services/services/TokenDetector.d.mts +12 -9
- package/dist/data-sources/evm-rpc-services/services/TokenDetector.d.mts.map +1 -1
- package/dist/data-sources/evm-rpc-services/services/TokenDetector.mjs +47 -50
- package/dist/data-sources/evm-rpc-services/services/TokenDetector.mjs.map +1 -1
- package/dist/data-sources/evm-rpc-services/services/index.cjs.map +1 -1
- package/dist/data-sources/evm-rpc-services/services/index.d.cts +1 -1
- package/dist/data-sources/evm-rpc-services/services/index.d.cts.map +1 -1
- package/dist/data-sources/evm-rpc-services/services/index.d.mts +1 -1
- package/dist/data-sources/evm-rpc-services/services/index.d.mts.map +1 -1
- package/dist/data-sources/evm-rpc-services/services/index.mjs.map +1 -1
- package/package.json +1 -1
package/CHANGELOG.md
CHANGED
|
@@ -9,6 +9,19 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
|
|
9
9
|
|
|
10
10
|
### Changed
|
|
11
11
|
|
|
12
|
+
- `TokenDetector` now fetches the token list directly from the Tokens API (`/v3/chains/{chain}/assets`) via a new `TokensApiClient` instead of reading from `TokenListController:getState` ([#8385](https://github.com/MetaMask/core/pull/8385))
|
|
13
|
+
- `TokenDetectorMessenger` type has been removed; `TokenDetector` constructor now takes a `TokensApiClient` instance as its second argument
|
|
14
|
+
- `RpcDataSource` no longer requires `TokenListController:getState` — `GetTokenListState` has been removed from `RpcDataSourceAllowedActions` and `AssetsControllerAllowedActions`
|
|
15
|
+
- Unknown ERC-20 metadata is no longer looked up from the token list as a fallback in `RpcDataSource`; `TokenDataSource` handles enrichment downstream
|
|
16
|
+
- Split `getAssets` fetch pipeline into a fast awaited path and a parallel fire-and-forget background path to reduce perceived latency on unlock and onboarding ([#8383](https://github.com/MetaMask/core/pull/8383))
|
|
17
|
+
- Fast pipeline: AccountsApi + StakedBalance → Detection → Token + Price (awaited, committed to state immediately)
|
|
18
|
+
- Background pipeline: Snap + RPC run in parallel → Detection → Token + Price when basic functionality is enabled; when disabled (RPC-only mode), Token + Price are omitted (fire-and-forget merge)
|
|
19
|
+
- `handleAssetsUpdate` skips token/price enrichment and strips `metadata` / `price` from the effective request when basic functionality is disabled (RPC-only mode)
|
|
20
|
+
- `setSelectedCurrency` no longer triggers a price refresh via `getAssets` when basic functionality is disabled
|
|
21
|
+
- `PriceDataSource` now batches spot-price API requests in chunks of 50 using `reduceInBatchesSerially` to avoid DynamoDB batch-limit errors ([#8383](https://github.com/MetaMask/core/pull/8383))
|
|
22
|
+
- `TokenDataSource` now batches token metadata API requests in chunks of 50 using `reduceInBatchesSerially` to avoid DynamoDB batch-limit errors ([#8383](https://github.com/MetaMask/core/pull/8383))
|
|
23
|
+
- `PriceDataSource` filters out all synthetic `slip44:NUMBER-*` staking-position asset IDs before calling the Price API ([#8383](https://github.com/MetaMask/core/pull/8383))
|
|
24
|
+
- `TokenDataSource` filters EVM ERC-20 tokens by `occurrences >= 3` and treats missing occurrences as 0 ([#8383](https://github.com/MetaMask/core/pull/8383))
|
|
12
25
|
- Bump `@metamask/keyring-controller` from `^25.1.1` to `^25.2.0` ([#8363](https://github.com/MetaMask/core/pull/8363))
|
|
13
26
|
- Bump `@metamask/messenger` from `^1.0.0` to `^1.1.1` ([#8364](https://github.com/MetaMask/core/pull/8364), [#8373](https://github.com/MetaMask/core/pull/8373))
|
|
14
27
|
|
|
@@ -356,12 +356,18 @@ class AssetsController extends base_controller_1.BaseController {
|
|
|
356
356
|
forceUpdate: true,
|
|
357
357
|
assetsForPriceUpdate: options?.assetsForPriceUpdate,
|
|
358
358
|
});
|
|
359
|
-
|
|
359
|
+
// Fast pipeline: accountsApi + stakedBalance → detection → token + price.
|
|
360
|
+
// Snap and RPC are excluded here due to their latency (snap triggers account
|
|
361
|
+
// creation, RPC is slow on many chains). Results are committed to state
|
|
362
|
+
// immediately so the UI can display balances without waiting for them.
|
|
363
|
+
//
|
|
364
|
+
// Both the fast and background pipelines use 'merge' mode because neither
|
|
365
|
+
// alone represents the full set of data sources. Using 'full' in either
|
|
366
|
+
// would wipe balances from the sources handled by the other pipeline.
|
|
367
|
+
const fastSources = __classPrivateFieldGet(this, _AssetsController_isBasicFunctionality, "f").call(this)
|
|
360
368
|
? [
|
|
361
369
|
(0, ParallelMiddleware_1.createParallelBalanceMiddleware)([
|
|
362
370
|
__classPrivateFieldGet(this, _AssetsController_accountsApiDataSource, "f"),
|
|
363
|
-
__classPrivateFieldGet(this, _AssetsController_snapDataSource, "f"),
|
|
364
|
-
__classPrivateFieldGet(this, _AssetsController_rpcDataSource, "f"),
|
|
365
371
|
__classPrivateFieldGet(this, _AssetsController_stakedBalanceDataSource, "f"),
|
|
366
372
|
]),
|
|
367
373
|
__classPrivateFieldGet(this, _AssetsController_detectionMiddleware, "f"),
|
|
@@ -370,18 +376,33 @@ class AssetsController extends base_controller_1.BaseController {
|
|
|
370
376
|
__classPrivateFieldGet(this, _AssetsController_priceDataSource, "f"),
|
|
371
377
|
]),
|
|
372
378
|
]
|
|
373
|
-
: [
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
//
|
|
380
|
-
//
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
const
|
|
384
|
-
|
|
379
|
+
: [__classPrivateFieldGet(this, _AssetsController_stakedBalanceDataSource, "f"), __classPrivateFieldGet(this, _AssetsController_detectionMiddleware, "f")];
|
|
380
|
+
const { response, durationByDataSource } = await __classPrivateFieldGet(this, _AssetsController_instances, "m", _AssetsController_executeMiddlewares).call(this, fastSources, request);
|
|
381
|
+
// The fast pipeline only contains a subset of data sources (AccountsApi +
|
|
382
|
+
// StakedBalance), so it must always merge to avoid wiping Snap/RPC
|
|
383
|
+
// balances that the background pipeline hasn't yet replaced.
|
|
384
|
+
await __classPrivateFieldGet(this, _AssetsController_instances, "m", _AssetsController_updateState).call(this, { ...response, updateMode: 'merge' });
|
|
385
|
+
// Background pipeline: snap and RPC run in parallel after the fast path
|
|
386
|
+
// commits to state. Their balances are merged together before detection.
|
|
387
|
+
// Token + price enrichment matches the pre-split behavior: only when basic
|
|
388
|
+
// functionality is on (RPC-only mode must not call token/price APIs).
|
|
389
|
+
const slowSources = __classPrivateFieldGet(this, _AssetsController_isBasicFunctionality, "f").call(this)
|
|
390
|
+
? [__classPrivateFieldGet(this, _AssetsController_snapDataSource, "f"), __classPrivateFieldGet(this, _AssetsController_rpcDataSource, "f")]
|
|
391
|
+
: [__classPrivateFieldGet(this, _AssetsController_rpcDataSource, "f")];
|
|
392
|
+
__classPrivateFieldGet(this, _AssetsController_instances, "m", _AssetsController_executeMiddlewares).call(this, [
|
|
393
|
+
(0, ParallelMiddleware_1.createParallelBalanceMiddleware)(slowSources),
|
|
394
|
+
__classPrivateFieldGet(this, _AssetsController_detectionMiddleware, "f"),
|
|
395
|
+
...(__classPrivateFieldGet(this, _AssetsController_isBasicFunctionality, "f").call(this)
|
|
396
|
+
? [
|
|
397
|
+
(0, ParallelMiddleware_1.createParallelMiddleware)([
|
|
398
|
+
__classPrivateFieldGet(this, _AssetsController_tokenDataSource, "f"),
|
|
399
|
+
__classPrivateFieldGet(this, _AssetsController_priceDataSource, "f"),
|
|
400
|
+
]),
|
|
401
|
+
]
|
|
402
|
+
: []),
|
|
403
|
+
], request)
|
|
404
|
+
.then(({ response: slowResponse }) => __classPrivateFieldGet(this, _AssetsController_instances, "m", _AssetsController_updateState).call(this, { ...slowResponse, updateMode: 'merge' }))
|
|
405
|
+
.catch((error) => log('Background pipeline failed', { error }));
|
|
385
406
|
const durationMs = performance.now() - startTime;
|
|
386
407
|
// Emit trace for every full fetch (Assets Health dashboard)
|
|
387
408
|
__classPrivateFieldGet(this, _AssetsController_instances, "m", _AssetsController_emitTrace).call(this, TRACE_FULL_FETCH, {
|
|
@@ -648,6 +669,9 @@ class AssetsController extends base_controller_1.BaseController {
|
|
|
648
669
|
previousCurrency,
|
|
649
670
|
selectedCurrency,
|
|
650
671
|
});
|
|
672
|
+
if (!__classPrivateFieldGet(this, _AssetsController_isBasicFunctionality, "f").call(this)) {
|
|
673
|
+
return;
|
|
674
|
+
}
|
|
651
675
|
this.getAssets(__classPrivateFieldGet(this, _AssetsController_instances, "a", _AssetsController_selectedAccounts_get), {
|
|
652
676
|
forceUpdate: true,
|
|
653
677
|
dataTypes: ['price'],
|
|
@@ -722,7 +746,8 @@ class AssetsController extends base_controller_1.BaseController {
|
|
|
722
746
|
/**
|
|
723
747
|
* Handle assets updated from a data source.
|
|
724
748
|
* Called via the onAssetsUpdate callback passed in SubscriptionRequest when the controller subscribes to a data source.
|
|
725
|
-
*
|
|
749
|
+
* Runs detection, then (when basic functionality is enabled) token metadata and price enrichment before updating state.
|
|
750
|
+
* When basic functionality is disabled (RPC-only mode), only detection runs; token and price APIs are not used.
|
|
726
751
|
*
|
|
727
752
|
* @param response - The data response with updated assets
|
|
728
753
|
* @param sourceId - The data source ID reporting the update
|
|
@@ -735,19 +760,27 @@ class AssetsController extends base_controller_1.BaseController {
|
|
|
735
760
|
hasBalance: Boolean(response.assetsBalance),
|
|
736
761
|
hasPrice: Boolean(response.assetsPrice),
|
|
737
762
|
});
|
|
738
|
-
|
|
739
|
-
// Include 'metadata' in dataTypes so TokenDataSource runs to enrich detected assets
|
|
740
|
-
const { response: enrichedResponse } = await __classPrivateFieldGet(this, _AssetsController_instances, "m", _AssetsController_executeMiddlewares).call(this, [
|
|
741
|
-
__classPrivateFieldGet(this, _AssetsController_detectionMiddleware, "f"),
|
|
742
|
-
(0, ParallelMiddleware_1.createParallelMiddleware)([
|
|
743
|
-
__classPrivateFieldGet(this, _AssetsController_tokenDataSource, "f"),
|
|
744
|
-
__classPrivateFieldGet(this, _AssetsController_priceDataSource, "f"),
|
|
745
|
-
]),
|
|
746
|
-
], request ?? {
|
|
763
|
+
const resolvedRequest = request ?? {
|
|
747
764
|
accountsWithSupportedChains: [],
|
|
748
765
|
chainIds: [],
|
|
749
766
|
dataTypes: ['balance', 'metadata', 'price'],
|
|
750
|
-
}
|
|
767
|
+
};
|
|
768
|
+
// RPC-only mode (basic functionality off): never run token/price APIs. Strip
|
|
769
|
+
// those data types so downstream middleware cannot treat them as requested.
|
|
770
|
+
const pipelineRequest = __classPrivateFieldGet(this, _AssetsController_isBasicFunctionality, "f").call(this)
|
|
771
|
+
? resolvedRequest
|
|
772
|
+
: {
|
|
773
|
+
...resolvedRequest,
|
|
774
|
+
dataTypes: resolvedRequest.dataTypes.filter((dt) => dt !== 'metadata' && dt !== 'price'),
|
|
775
|
+
};
|
|
776
|
+
const enrichmentSources = [__classPrivateFieldGet(this, _AssetsController_detectionMiddleware, "f")];
|
|
777
|
+
if (__classPrivateFieldGet(this, _AssetsController_isBasicFunctionality, "f").call(this)) {
|
|
778
|
+
enrichmentSources.push((0, ParallelMiddleware_1.createParallelMiddleware)([
|
|
779
|
+
__classPrivateFieldGet(this, _AssetsController_tokenDataSource, "f"),
|
|
780
|
+
__classPrivateFieldGet(this, _AssetsController_priceDataSource, "f"),
|
|
781
|
+
]));
|
|
782
|
+
}
|
|
783
|
+
const { response: enrichedResponse } = await __classPrivateFieldGet(this, _AssetsController_instances, "m", _AssetsController_executeMiddlewares).call(this, enrichmentSources, pipelineRequest, response);
|
|
751
784
|
await __classPrivateFieldGet(this, _AssetsController_instances, "m", _AssetsController_updateState).call(this, enrichedResponse);
|
|
752
785
|
__classPrivateFieldGet(this, _AssetsController_instances, "m", _AssetsController_emitTrace).call(this, TRACE_UPDATE_PIPELINE, {
|
|
753
786
|
source: sourceId,
|