@metamask-previews/assets-controller 1.0.0-preview-ee8f1b28b → 2.0.0-preview-33dbba4f3
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 +6 -1
- package/dist/AssetsController.cjs +61 -18
- package/dist/AssetsController.cjs.map +1 -1
- package/dist/AssetsController.d.cts +13 -8
- package/dist/AssetsController.d.cts.map +1 -1
- package/dist/AssetsController.d.mts +13 -8
- package/dist/AssetsController.d.mts.map +1 -1
- package/dist/AssetsController.mjs +62 -19
- package/dist/AssetsController.mjs.map +1 -1
- package/dist/data-sources/AccountsApiDataSource.cjs +9 -11
- package/dist/data-sources/AccountsApiDataSource.cjs.map +1 -1
- package/dist/data-sources/AccountsApiDataSource.d.cts.map +1 -1
- package/dist/data-sources/AccountsApiDataSource.d.mts.map +1 -1
- package/dist/data-sources/AccountsApiDataSource.mjs +7 -9
- package/dist/data-sources/AccountsApiDataSource.mjs.map +1 -1
- package/dist/data-sources/BackendWebsocketDataSource.cjs +6 -4
- package/dist/data-sources/BackendWebsocketDataSource.cjs.map +1 -1
- package/dist/data-sources/BackendWebsocketDataSource.d.cts.map +1 -1
- package/dist/data-sources/BackendWebsocketDataSource.d.mts.map +1 -1
- package/dist/data-sources/BackendWebsocketDataSource.mjs +6 -4
- package/dist/data-sources/BackendWebsocketDataSource.mjs.map +1 -1
- package/dist/data-sources/PriceDataSource.cjs +13 -3
- 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 +13 -3
- package/dist/data-sources/PriceDataSource.mjs.map +1 -1
- package/dist/data-sources/RpcDataSource.cjs +80 -10
- package/dist/data-sources/RpcDataSource.cjs.map +1 -1
- package/dist/data-sources/RpcDataSource.d.cts +8 -59
- package/dist/data-sources/RpcDataSource.d.cts.map +1 -1
- package/dist/data-sources/RpcDataSource.d.mts +8 -59
- package/dist/data-sources/RpcDataSource.d.mts.map +1 -1
- package/dist/data-sources/RpcDataSource.mjs +81 -11
- package/dist/data-sources/RpcDataSource.mjs.map +1 -1
- package/dist/data-sources/SnapDataSource.cjs +16 -4
- package/dist/data-sources/SnapDataSource.cjs.map +1 -1
- package/dist/data-sources/SnapDataSource.d.cts +2 -1
- package/dist/data-sources/SnapDataSource.d.cts.map +1 -1
- package/dist/data-sources/SnapDataSource.d.mts +2 -1
- package/dist/data-sources/SnapDataSource.d.mts.map +1 -1
- package/dist/data-sources/SnapDataSource.mjs +16 -4
- package/dist/data-sources/SnapDataSource.mjs.map +1 -1
- package/dist/data-sources/StakedBalanceDataSource.cjs +609 -0
- package/dist/data-sources/StakedBalanceDataSource.cjs.map +1 -0
- package/dist/data-sources/StakedBalanceDataSource.d.cts +72 -0
- package/dist/data-sources/StakedBalanceDataSource.d.cts.map +1 -0
- package/dist/data-sources/StakedBalanceDataSource.d.mts +72 -0
- package/dist/data-sources/StakedBalanceDataSource.d.mts.map +1 -0
- package/dist/data-sources/StakedBalanceDataSource.mjs +605 -0
- package/dist/data-sources/StakedBalanceDataSource.mjs.map +1 -0
- package/dist/data-sources/TokenDataSource.cjs +5 -0
- 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 +5 -0
- package/dist/data-sources/TokenDataSource.mjs.map +1 -1
- package/dist/data-sources/evm-rpc-services/index.cjs +5 -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/StakedBalanceFetcher.cjs +132 -0
- package/dist/data-sources/evm-rpc-services/services/StakedBalanceFetcher.cjs.map +1 -0
- package/dist/data-sources/evm-rpc-services/services/StakedBalanceFetcher.d.cts +78 -0
- package/dist/data-sources/evm-rpc-services/services/StakedBalanceFetcher.d.cts.map +1 -0
- package/dist/data-sources/evm-rpc-services/services/StakedBalanceFetcher.d.mts +78 -0
- package/dist/data-sources/evm-rpc-services/services/StakedBalanceFetcher.d.mts.map +1 -0
- package/dist/data-sources/evm-rpc-services/services/StakedBalanceFetcher.mjs +126 -0
- package/dist/data-sources/evm-rpc-services/services/StakedBalanceFetcher.mjs.map +1 -0
- package/dist/data-sources/evm-rpc-services/services/index.cjs +6 -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 -0
- 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 -0
- package/dist/data-sources/evm-rpc-services/services/index.d.mts.map +1 -1
- package/dist/data-sources/evm-rpc-services/services/index.mjs +1 -0
- package/dist/data-sources/evm-rpc-services/services/index.mjs.map +1 -1
- package/dist/data-sources/evm-rpc-services/types/state.cjs.map +1 -1
- package/dist/data-sources/evm-rpc-services/types/state.d.cts +3 -3
- package/dist/data-sources/evm-rpc-services/types/state.d.cts.map +1 -1
- package/dist/data-sources/evm-rpc-services/types/state.d.mts +3 -3
- package/dist/data-sources/evm-rpc-services/types/state.d.mts.map +1 -1
- package/dist/data-sources/evm-rpc-services/types/state.mjs.map +1 -1
- package/dist/data-sources/evm-rpc-services/utils/index.cjs +9 -1
- package/dist/data-sources/evm-rpc-services/utils/index.cjs.map +1 -1
- package/dist/data-sources/evm-rpc-services/utils/index.d.cts +2 -0
- package/dist/data-sources/evm-rpc-services/utils/index.d.cts.map +1 -1
- package/dist/data-sources/evm-rpc-services/utils/index.d.mts +2 -0
- package/dist/data-sources/evm-rpc-services/utils/index.d.mts.map +1 -1
- package/dist/data-sources/evm-rpc-services/utils/index.mjs +2 -0
- package/dist/data-sources/evm-rpc-services/utils/index.mjs.map +1 -1
- package/dist/data-sources/evm-rpc-services/utils/parsing.cjs +47 -0
- package/dist/data-sources/evm-rpc-services/utils/parsing.cjs.map +1 -0
- package/dist/data-sources/evm-rpc-services/utils/parsing.d.cts +25 -0
- package/dist/data-sources/evm-rpc-services/utils/parsing.d.cts.map +1 -0
- package/dist/data-sources/evm-rpc-services/utils/parsing.d.mts +25 -0
- package/dist/data-sources/evm-rpc-services/utils/parsing.d.mts.map +1 -0
- package/dist/data-sources/evm-rpc-services/utils/parsing.mjs +39 -0
- package/dist/data-sources/evm-rpc-services/utils/parsing.mjs.map +1 -0
- package/dist/data-sources/evm-rpc-services/utils/staking-contracts.cjs +68 -0
- package/dist/data-sources/evm-rpc-services/utils/staking-contracts.cjs.map +1 -0
- package/dist/data-sources/evm-rpc-services/utils/staking-contracts.d.cts +25 -0
- package/dist/data-sources/evm-rpc-services/utils/staking-contracts.d.cts.map +1 -0
- package/dist/data-sources/evm-rpc-services/utils/staking-contracts.d.mts +25 -0
- package/dist/data-sources/evm-rpc-services/utils/staking-contracts.d.mts.map +1 -0
- package/dist/data-sources/evm-rpc-services/utils/staking-contracts.mjs +62 -0
- package/dist/data-sources/evm-rpc-services/utils/staking-contracts.mjs.map +1 -0
- package/dist/data-sources/index.cjs +3 -1
- package/dist/data-sources/index.cjs.map +1 -1
- package/dist/data-sources/index.d.cts +1 -0
- package/dist/data-sources/index.d.cts.map +1 -1
- package/dist/data-sources/index.d.mts +1 -0
- package/dist/data-sources/index.d.mts.map +1 -1
- package/dist/data-sources/index.mjs +1 -0
- package/dist/data-sources/index.mjs.map +1 -1
- package/package.json +3 -1
|
@@ -0,0 +1,609 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
|
|
3
|
+
if (kind === "m") throw new TypeError("Private method is not writable");
|
|
4
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
|
|
5
|
+
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
|
|
6
|
+
return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
|
|
7
|
+
};
|
|
8
|
+
var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
|
|
9
|
+
if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
|
|
10
|
+
if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
|
|
11
|
+
return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
|
|
12
|
+
};
|
|
13
|
+
var _StakedBalanceDataSource_instances, _StakedBalanceDataSource_messenger, _StakedBalanceDataSource_onActiveChainsUpdated, _StakedBalanceDataSource_pollInterval, _StakedBalanceDataSource_enabled, _StakedBalanceDataSource_stakedBalanceFetcher, _StakedBalanceDataSource_activeSubscriptions, _StakedBalanceDataSource_providerCache, _StakedBalanceDataSource_supportedChainIds, _StakedBalanceDataSource_unsubscribeTransactionConfirmed, _StakedBalanceDataSource_unsubscribeIncomingTransactions, _StakedBalanceDataSource_unsubscribeNetworkStateChange, _StakedBalanceDataSource_unsubscribeNetworkEnablementControllerStateChange, _StakedBalanceDataSource_onNetworkStateChange, _StakedBalanceDataSource_onNetworkEnablementControllerStateChange, _StakedBalanceDataSource_isTransactionInvolvingStakingContract, _StakedBalanceDataSource_onTransactionConfirmed, _StakedBalanceDataSource_onIncomingTransactions, _StakedBalanceDataSource_getToRefreshForChains, _StakedBalanceDataSource_getToRefreshAll, _StakedBalanceDataSource_refreshStakedBalanceAfterTransaction, _StakedBalanceDataSource_initializeActiveChains, _StakedBalanceDataSource_initializeActiveChainsFromEnabledMap, _StakedBalanceDataSource_getProvider, _StakedBalanceDataSource_handleStakedBalanceUpdate;
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.StakedBalanceDataSource = void 0;
|
|
16
|
+
const util_1 = require("@ethereumjs/util");
|
|
17
|
+
const providers_1 = require("@ethersproject/providers");
|
|
18
|
+
const utils_1 = require("@metamask/utils");
|
|
19
|
+
const AbstractDataSource_1 = require("./AbstractDataSource.cjs");
|
|
20
|
+
const evm_rpc_services_1 = require("./evm-rpc-services/index.cjs");
|
|
21
|
+
const logger_1 = require("../logger.cjs");
|
|
22
|
+
const CONTROLLER_NAME = 'StakedBalanceDataSource';
|
|
23
|
+
const DEFAULT_POLL_INTERVAL = 180000; // 3 minutes
|
|
24
|
+
/** Metadata for staked ETH (same symbol and decimals as native ETH). */
|
|
25
|
+
const STAKED_ETH_METADATA = {
|
|
26
|
+
type: 'erc20',
|
|
27
|
+
name: 'staked ethereum',
|
|
28
|
+
symbol: 'ETH',
|
|
29
|
+
decimals: 18,
|
|
30
|
+
};
|
|
31
|
+
const log = (0, logger_1.createModuleLogger)(logger_1.projectLogger, CONTROLLER_NAME);
|
|
32
|
+
/**
|
|
33
|
+
* Convert CAIP chain ID or hex chain ID to hex chain ID.
|
|
34
|
+
*
|
|
35
|
+
* @param chainId - CAIP chain ID or hex chain ID.
|
|
36
|
+
* @returns Hex chain ID.
|
|
37
|
+
*/
|
|
38
|
+
function caipChainIdToHex(chainId) {
|
|
39
|
+
if ((0, utils_1.isStrictHexString)(chainId)) {
|
|
40
|
+
return chainId;
|
|
41
|
+
}
|
|
42
|
+
if ((0, utils_1.isCaipChainId)(chainId)) {
|
|
43
|
+
const ref = (0, utils_1.parseCaipChainId)(chainId).reference;
|
|
44
|
+
return (0, utils_1.numberToHex)(parseInt(ref, 10));
|
|
45
|
+
}
|
|
46
|
+
throw new Error('caipChainIdToHex - Failed to provide CAIP-2 or Hex chainId');
|
|
47
|
+
}
|
|
48
|
+
/**
|
|
49
|
+
* Build the CAIP-19 asset ID for staked balance (same format as ERC20).
|
|
50
|
+
* Uses the staking contract address (checksummed) so it is consistent with
|
|
51
|
+
* other token assets.
|
|
52
|
+
* Example: "eip155:1/erc20:0x4fef9d741011476750a243ac70b9789a63dd47df"
|
|
53
|
+
*
|
|
54
|
+
* @param chainId - CAIP-2 chain ID (e.g. "eip155:1").
|
|
55
|
+
* @param contractAddress - Staking contract address (hex).
|
|
56
|
+
* @returns The staked asset CAIP-19 ID with checksummed address.
|
|
57
|
+
*/
|
|
58
|
+
function stakedAssetId(chainId, contractAddress) {
|
|
59
|
+
const checksummed = (0, util_1.toChecksumAddress)(contractAddress);
|
|
60
|
+
return `${chainId}/erc20:${checksummed}`;
|
|
61
|
+
}
|
|
62
|
+
/**
|
|
63
|
+
* Data source for fetching staked ETH balances via on-chain staking contracts.
|
|
64
|
+
*
|
|
65
|
+
* Delegates to {@link StakedBalanceFetcher} for the actual RPC calls
|
|
66
|
+
* (getShares + convertToAssets on ERC-4626-style staking contracts).
|
|
67
|
+
* Reports balances as CAIP-19 asset IDs using the ERC20 format with the
|
|
68
|
+
* staking contract address (e.g. "eip155:1/erc20:0x4fef9d741011476750a243ac70b9789a63dd47df").
|
|
69
|
+
*
|
|
70
|
+
* Only supports chains with known staking contracts (mainnet, Hoodi).
|
|
71
|
+
* Polling is managed by StakedBalanceFetcher via startPolling/stopPollingByPollingToken.
|
|
72
|
+
*/
|
|
73
|
+
class StakedBalanceDataSource extends AbstractDataSource_1.AbstractDataSource {
|
|
74
|
+
constructor(options) {
|
|
75
|
+
super(CONTROLLER_NAME, { activeChains: [] });
|
|
76
|
+
_StakedBalanceDataSource_instances.add(this);
|
|
77
|
+
_StakedBalanceDataSource_messenger.set(this, void 0);
|
|
78
|
+
_StakedBalanceDataSource_onActiveChainsUpdated.set(this, void 0);
|
|
79
|
+
_StakedBalanceDataSource_pollInterval.set(this, void 0);
|
|
80
|
+
_StakedBalanceDataSource_enabled.set(this, void 0);
|
|
81
|
+
/** The StakedBalanceFetcher that handles polling and RPC calls. */
|
|
82
|
+
_StakedBalanceDataSource_stakedBalanceFetcher.set(this, void 0);
|
|
83
|
+
/** Active subscriptions by ID. */
|
|
84
|
+
_StakedBalanceDataSource_activeSubscriptions.set(this, new Map());
|
|
85
|
+
/** Cache of Web3Provider instances by hex chain ID. */
|
|
86
|
+
_StakedBalanceDataSource_providerCache.set(this, new Map());
|
|
87
|
+
/** CAIP-2 chain IDs that have known staking contracts. */
|
|
88
|
+
_StakedBalanceDataSource_supportedChainIds.set(this, void 0);
|
|
89
|
+
_StakedBalanceDataSource_unsubscribeTransactionConfirmed.set(this, undefined);
|
|
90
|
+
_StakedBalanceDataSource_unsubscribeIncomingTransactions.set(this, undefined);
|
|
91
|
+
_StakedBalanceDataSource_unsubscribeNetworkStateChange.set(this, undefined);
|
|
92
|
+
_StakedBalanceDataSource_unsubscribeNetworkEnablementControllerStateChange.set(this, undefined);
|
|
93
|
+
__classPrivateFieldSet(this, _StakedBalanceDataSource_messenger, options.messenger, "f");
|
|
94
|
+
__classPrivateFieldSet(this, _StakedBalanceDataSource_onActiveChainsUpdated, options.onActiveChainsUpdated, "f");
|
|
95
|
+
__classPrivateFieldSet(this, _StakedBalanceDataSource_pollInterval, options.pollInterval ?? DEFAULT_POLL_INTERVAL, "f");
|
|
96
|
+
__classPrivateFieldSet(this, _StakedBalanceDataSource_enabled, options.enabled !== false, "f");
|
|
97
|
+
__classPrivateFieldSet(this, _StakedBalanceDataSource_supportedChainIds, (0, evm_rpc_services_1.getSupportedStakingChainIds)(), "f");
|
|
98
|
+
log('Initializing StakedBalanceDataSource', {
|
|
99
|
+
enabled: __classPrivateFieldGet(this, _StakedBalanceDataSource_enabled, "f"),
|
|
100
|
+
pollInterval: __classPrivateFieldGet(this, _StakedBalanceDataSource_pollInterval, "f"),
|
|
101
|
+
});
|
|
102
|
+
// Create StakedBalanceFetcher with provider getter
|
|
103
|
+
__classPrivateFieldSet(this, _StakedBalanceDataSource_stakedBalanceFetcher, new evm_rpc_services_1.StakedBalanceFetcher({
|
|
104
|
+
pollingInterval: __classPrivateFieldGet(this, _StakedBalanceDataSource_pollInterval, "f"),
|
|
105
|
+
getNetworkProvider: (hexChainId) => __classPrivateFieldGet(this, _StakedBalanceDataSource_instances, "m", _StakedBalanceDataSource_getProvider).call(this, hexChainId),
|
|
106
|
+
}), "f");
|
|
107
|
+
// Wire the callback so polling results flow back to subscriptions
|
|
108
|
+
__classPrivateFieldGet(this, _StakedBalanceDataSource_stakedBalanceFetcher, "f").setOnStakedBalanceUpdate(__classPrivateFieldGet(this, _StakedBalanceDataSource_instances, "m", _StakedBalanceDataSource_handleStakedBalanceUpdate).bind(this));
|
|
109
|
+
const unsubConfirmed = __classPrivateFieldGet(this, _StakedBalanceDataSource_messenger, "f").subscribe('TransactionController:transactionConfirmed', __classPrivateFieldGet(this, _StakedBalanceDataSource_instances, "m", _StakedBalanceDataSource_onTransactionConfirmed).bind(this));
|
|
110
|
+
__classPrivateFieldSet(this, _StakedBalanceDataSource_unsubscribeTransactionConfirmed, typeof unsubConfirmed === 'function' ? unsubConfirmed : undefined, "f");
|
|
111
|
+
const unsubIncoming = __classPrivateFieldGet(this, _StakedBalanceDataSource_messenger, "f").subscribe('TransactionController:incomingTransactionsReceived', __classPrivateFieldGet(this, _StakedBalanceDataSource_instances, "m", _StakedBalanceDataSource_onIncomingTransactions).bind(this));
|
|
112
|
+
__classPrivateFieldSet(this, _StakedBalanceDataSource_unsubscribeIncomingTransactions, typeof unsubIncoming === 'function' ? unsubIncoming : undefined, "f");
|
|
113
|
+
const unsubNetwork = __classPrivateFieldGet(this, _StakedBalanceDataSource_messenger, "f").subscribe('NetworkController:stateChange', __classPrivateFieldGet(this, _StakedBalanceDataSource_instances, "m", _StakedBalanceDataSource_onNetworkStateChange).bind(this));
|
|
114
|
+
__classPrivateFieldSet(this, _StakedBalanceDataSource_unsubscribeNetworkStateChange, typeof unsubNetwork === 'function' ? unsubNetwork : undefined, "f");
|
|
115
|
+
const unsubEnablement = __classPrivateFieldGet(this, _StakedBalanceDataSource_messenger, "f").subscribe('NetworkEnablementController:stateChange', __classPrivateFieldGet(this, _StakedBalanceDataSource_instances, "m", _StakedBalanceDataSource_onNetworkEnablementControllerStateChange).bind(this));
|
|
116
|
+
__classPrivateFieldSet(this, _StakedBalanceDataSource_unsubscribeNetworkEnablementControllerStateChange, typeof unsubEnablement === 'function' ? unsubEnablement : undefined, "f");
|
|
117
|
+
__classPrivateFieldGet(this, _StakedBalanceDataSource_instances, "m", _StakedBalanceDataSource_initializeActiveChains).call(this);
|
|
118
|
+
}
|
|
119
|
+
/**
|
|
120
|
+
* Refresh staked balance for all currently subscribed accounts and chains, then
|
|
121
|
+
* push updates to the controller. Can be called from UI or after transaction events.
|
|
122
|
+
*/
|
|
123
|
+
async refreshStakedBalance() {
|
|
124
|
+
if (!__classPrivateFieldGet(this, _StakedBalanceDataSource_enabled, "f")) {
|
|
125
|
+
return;
|
|
126
|
+
}
|
|
127
|
+
const toRefresh = __classPrivateFieldGet(this, _StakedBalanceDataSource_instances, "m", _StakedBalanceDataSource_getToRefreshAll).call(this);
|
|
128
|
+
if (toRefresh.length > 0) {
|
|
129
|
+
await __classPrivateFieldGet(this, _StakedBalanceDataSource_instances, "m", _StakedBalanceDataSource_refreshStakedBalanceAfterTransaction).call(this, toRefresh);
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
/**
|
|
133
|
+
* Fetch staked balances for all accounts on supported chains.
|
|
134
|
+
*
|
|
135
|
+
* @param request - The data request with accounts and chains.
|
|
136
|
+
* @returns DataResponse with staked balance data.
|
|
137
|
+
*/
|
|
138
|
+
async fetch(request) {
|
|
139
|
+
var _a;
|
|
140
|
+
if (!__classPrivateFieldGet(this, _StakedBalanceDataSource_enabled, "f")) {
|
|
141
|
+
return {};
|
|
142
|
+
}
|
|
143
|
+
const response = {};
|
|
144
|
+
const activeChainsSet = new Set(this.state.activeChains);
|
|
145
|
+
const chainsToFetch = request.chainIds.filter((chainId) => activeChainsSet.has(chainId));
|
|
146
|
+
if (chainsToFetch.length === 0) {
|
|
147
|
+
return response;
|
|
148
|
+
}
|
|
149
|
+
const balances = {};
|
|
150
|
+
for (const { account, supportedChains: accountChains, } of request.accountsWithSupportedChains) {
|
|
151
|
+
const chains = chainsToFetch.filter((chain) => accountChains.includes(chain));
|
|
152
|
+
for (const chainId of chains) {
|
|
153
|
+
try {
|
|
154
|
+
const hexChainId = caipChainIdToHex(chainId);
|
|
155
|
+
const contractAddress = (0, evm_rpc_services_1.getStakingContractAddress)(hexChainId);
|
|
156
|
+
if (!contractAddress) {
|
|
157
|
+
continue;
|
|
158
|
+
}
|
|
159
|
+
const input = {
|
|
160
|
+
chainId: hexChainId,
|
|
161
|
+
accountId: account.id,
|
|
162
|
+
accountAddress: account.address,
|
|
163
|
+
};
|
|
164
|
+
const result = await __classPrivateFieldGet(this, _StakedBalanceDataSource_stakedBalanceFetcher, "f").fetchStakedBalance(input);
|
|
165
|
+
// Include zero amounts so merged updates clear prior non-zero state.
|
|
166
|
+
balances[_a = account.id] ?? (balances[_a] = {});
|
|
167
|
+
const assetId = stakedAssetId(chainId, contractAddress);
|
|
168
|
+
balances[account.id][assetId] = { amount: result.amount };
|
|
169
|
+
}
|
|
170
|
+
catch (error) {
|
|
171
|
+
log('Failed to fetch staked balance', {
|
|
172
|
+
chainId,
|
|
173
|
+
accountId: account.id,
|
|
174
|
+
error,
|
|
175
|
+
});
|
|
176
|
+
}
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
if (Object.keys(balances).length > 0) {
|
|
180
|
+
response.assetsBalance = balances;
|
|
181
|
+
// Add metadata for each staked asset ID present in balances
|
|
182
|
+
const assetIds = new Set();
|
|
183
|
+
for (const accountBalances of Object.values(balances)) {
|
|
184
|
+
for (const assetId of Object.keys(accountBalances)) {
|
|
185
|
+
assetIds.add(assetId);
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
response.assetsInfo = {};
|
|
189
|
+
for (const assetId of assetIds) {
|
|
190
|
+
response.assetsInfo[assetId] = STAKED_ETH_METADATA;
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
return response;
|
|
194
|
+
}
|
|
195
|
+
/**
|
|
196
|
+
* Assets middleware for the fetch pipeline.
|
|
197
|
+
* Fetches staked balances and merges them into the response, then passes
|
|
198
|
+
* all chains to the next middleware (staked balance doesn't claim chains).
|
|
199
|
+
*
|
|
200
|
+
* @returns The middleware function for the assets pipeline.
|
|
201
|
+
*/
|
|
202
|
+
get assetsMiddleware() {
|
|
203
|
+
return async (context, next) => {
|
|
204
|
+
var _a, _b;
|
|
205
|
+
if (!__classPrivateFieldGet(this, _StakedBalanceDataSource_enabled, "f")) {
|
|
206
|
+
return next(context);
|
|
207
|
+
}
|
|
208
|
+
const { request } = context;
|
|
209
|
+
if (!request.dataTypes.includes('balance')) {
|
|
210
|
+
return next(context);
|
|
211
|
+
}
|
|
212
|
+
if (request.chainIds.length === 0) {
|
|
213
|
+
return next(context);
|
|
214
|
+
}
|
|
215
|
+
try {
|
|
216
|
+
const fetchResponse = await this.fetch(request);
|
|
217
|
+
if (fetchResponse.assetsInfo) {
|
|
218
|
+
(_a = context.response).assetsInfo ?? (_a.assetsInfo = {});
|
|
219
|
+
Object.assign(context.response.assetsInfo, fetchResponse.assetsInfo);
|
|
220
|
+
}
|
|
221
|
+
if (fetchResponse.assetsBalance) {
|
|
222
|
+
(_b = context.response).assetsBalance ?? (_b.assetsBalance = {});
|
|
223
|
+
for (const [accountId, accountBalances] of Object.entries(fetchResponse.assetsBalance)) {
|
|
224
|
+
context.response.assetsBalance[accountId] = {
|
|
225
|
+
...context.response.assetsBalance[accountId],
|
|
226
|
+
...accountBalances,
|
|
227
|
+
};
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
catch (error) {
|
|
232
|
+
log('Middleware fetch failed', { error });
|
|
233
|
+
}
|
|
234
|
+
// Pass all chains through (staked balance doesn't claim chains)
|
|
235
|
+
return next(context);
|
|
236
|
+
};
|
|
237
|
+
}
|
|
238
|
+
/**
|
|
239
|
+
* Subscribe to staked balance updates with polling.
|
|
240
|
+
* Starts polling via StakedBalanceFetcher for each account/chain combination.
|
|
241
|
+
*
|
|
242
|
+
* @param subscriptionRequest - The subscription request details.
|
|
243
|
+
*/
|
|
244
|
+
async subscribe(subscriptionRequest) {
|
|
245
|
+
const { request, subscriptionId, isUpdate } = subscriptionRequest;
|
|
246
|
+
const activeChainsSet = new Set(this.state.activeChains);
|
|
247
|
+
const chainsToSubscribe = request.chainIds.filter((chainId) => activeChainsSet.has(chainId));
|
|
248
|
+
log('Subscribe requested', {
|
|
249
|
+
subscriptionId,
|
|
250
|
+
isUpdate,
|
|
251
|
+
chainsToSubscribe,
|
|
252
|
+
});
|
|
253
|
+
if (chainsToSubscribe.length === 0) {
|
|
254
|
+
log('No staking chains to subscribe');
|
|
255
|
+
return;
|
|
256
|
+
}
|
|
257
|
+
// Handle subscription update - restart polling for new chains
|
|
258
|
+
if (isUpdate) {
|
|
259
|
+
const existing = __classPrivateFieldGet(this, _StakedBalanceDataSource_activeSubscriptions, "f").get(subscriptionId);
|
|
260
|
+
if (existing) {
|
|
261
|
+
log('Updating existing subscription - restarting polling', {
|
|
262
|
+
subscriptionId,
|
|
263
|
+
});
|
|
264
|
+
}
|
|
265
|
+
}
|
|
266
|
+
// Clean up existing subscription (stops old polling)
|
|
267
|
+
await this.unsubscribe(subscriptionId);
|
|
268
|
+
// Build subscription data first so it is available when the first poll runs
|
|
269
|
+
const accountsWithSupportedChains = request.accountsWithSupportedChains
|
|
270
|
+
.map(({ account, supportedChains }) => ({
|
|
271
|
+
account,
|
|
272
|
+
supportedChains: chainsToSubscribe.filter((chain) => supportedChains.includes(chain)),
|
|
273
|
+
}))
|
|
274
|
+
.filter(({ supportedChains }) => supportedChains.length > 0);
|
|
275
|
+
const accounts = accountsWithSupportedChains.map((entry) => entry.account);
|
|
276
|
+
const pollingTokens = [];
|
|
277
|
+
// Store subscription before startPolling so first poll (setTimeout 0) has the callback
|
|
278
|
+
__classPrivateFieldGet(this, _StakedBalanceDataSource_activeSubscriptions, "f").set(subscriptionId, {
|
|
279
|
+
pollingTokens,
|
|
280
|
+
chains: chainsToSubscribe,
|
|
281
|
+
accounts,
|
|
282
|
+
accountsWithSupportedChains,
|
|
283
|
+
onAssetsUpdate: subscriptionRequest.onAssetsUpdate,
|
|
284
|
+
});
|
|
285
|
+
this.activeSubscriptions.set(subscriptionId, {
|
|
286
|
+
cleanup: () => {
|
|
287
|
+
for (const token of pollingTokens) {
|
|
288
|
+
__classPrivateFieldGet(this, _StakedBalanceDataSource_stakedBalanceFetcher, "f").stopPollingByPollingToken(token);
|
|
289
|
+
}
|
|
290
|
+
__classPrivateFieldGet(this, _StakedBalanceDataSource_activeSubscriptions, "f").delete(subscriptionId);
|
|
291
|
+
},
|
|
292
|
+
chains: chainsToSubscribe,
|
|
293
|
+
request,
|
|
294
|
+
onAssetsUpdate: subscriptionRequest.onAssetsUpdate,
|
|
295
|
+
});
|
|
296
|
+
// Start polling for each account/chain (first poll runs on next tick)
|
|
297
|
+
for (const { account, supportedChains: accountChains, } of request.accountsWithSupportedChains) {
|
|
298
|
+
const chainsForAccount = chainsToSubscribe.filter((chain) => accountChains.includes(chain));
|
|
299
|
+
for (const chainId of chainsForAccount) {
|
|
300
|
+
const hexChainId = caipChainIdToHex(chainId);
|
|
301
|
+
const input = {
|
|
302
|
+
chainId: hexChainId,
|
|
303
|
+
accountId: account.id,
|
|
304
|
+
accountAddress: account.address,
|
|
305
|
+
};
|
|
306
|
+
const pollingToken = __classPrivateFieldGet(this, _StakedBalanceDataSource_stakedBalanceFetcher, "f").startPolling(input);
|
|
307
|
+
pollingTokens.push(pollingToken);
|
|
308
|
+
}
|
|
309
|
+
}
|
|
310
|
+
// Immediate initial fetch so state is updated without waiting for first poll
|
|
311
|
+
try {
|
|
312
|
+
const initialRequest = {
|
|
313
|
+
accountsWithSupportedChains,
|
|
314
|
+
chainIds: chainsToSubscribe,
|
|
315
|
+
dataTypes: ['balance'],
|
|
316
|
+
};
|
|
317
|
+
const initialResponse = await this.fetch(initialRequest);
|
|
318
|
+
if (initialResponse.assetsBalance &&
|
|
319
|
+
Object.keys(initialResponse.assetsBalance).length > 0) {
|
|
320
|
+
subscriptionRequest
|
|
321
|
+
.onAssetsUpdate?.(initialResponse)
|
|
322
|
+
?.catch((error) => {
|
|
323
|
+
log('Initial staked balance update failed', { error });
|
|
324
|
+
});
|
|
325
|
+
}
|
|
326
|
+
}
|
|
327
|
+
catch (error) {
|
|
328
|
+
log('Initial staked balance fetch failed', { error });
|
|
329
|
+
}
|
|
330
|
+
log('Subscription SUCCESS', {
|
|
331
|
+
subscriptionId,
|
|
332
|
+
chains: chainsToSubscribe,
|
|
333
|
+
pollingCount: pollingTokens.length,
|
|
334
|
+
});
|
|
335
|
+
}
|
|
336
|
+
/**
|
|
337
|
+
* Unsubscribe from staked balance updates and stop polling.
|
|
338
|
+
*
|
|
339
|
+
* @param subscriptionId - The subscription ID to unsubscribe.
|
|
340
|
+
*/
|
|
341
|
+
async unsubscribe(subscriptionId) {
|
|
342
|
+
const subscription = __classPrivateFieldGet(this, _StakedBalanceDataSource_activeSubscriptions, "f").get(subscriptionId);
|
|
343
|
+
if (subscription) {
|
|
344
|
+
for (const token of subscription.pollingTokens) {
|
|
345
|
+
__classPrivateFieldGet(this, _StakedBalanceDataSource_stakedBalanceFetcher, "f").stopPollingByPollingToken(token);
|
|
346
|
+
}
|
|
347
|
+
__classPrivateFieldGet(this, _StakedBalanceDataSource_activeSubscriptions, "f").delete(subscriptionId);
|
|
348
|
+
}
|
|
349
|
+
await super.unsubscribe(subscriptionId);
|
|
350
|
+
}
|
|
351
|
+
/**
|
|
352
|
+
* Destroy the data source and clean up all resources.
|
|
353
|
+
*/
|
|
354
|
+
destroy() {
|
|
355
|
+
__classPrivateFieldGet(this, _StakedBalanceDataSource_unsubscribeTransactionConfirmed, "f")?.call(this);
|
|
356
|
+
__classPrivateFieldGet(this, _StakedBalanceDataSource_unsubscribeIncomingTransactions, "f")?.call(this);
|
|
357
|
+
__classPrivateFieldGet(this, _StakedBalanceDataSource_unsubscribeNetworkStateChange, "f")?.call(this);
|
|
358
|
+
__classPrivateFieldGet(this, _StakedBalanceDataSource_unsubscribeNetworkEnablementControllerStateChange, "f")?.call(this);
|
|
359
|
+
for (const subscription of __classPrivateFieldGet(this, _StakedBalanceDataSource_activeSubscriptions, "f").values()) {
|
|
360
|
+
for (const token of subscription.pollingTokens) {
|
|
361
|
+
__classPrivateFieldGet(this, _StakedBalanceDataSource_stakedBalanceFetcher, "f").stopPollingByPollingToken(token);
|
|
362
|
+
}
|
|
363
|
+
}
|
|
364
|
+
__classPrivateFieldGet(this, _StakedBalanceDataSource_activeSubscriptions, "f").clear();
|
|
365
|
+
__classPrivateFieldGet(this, _StakedBalanceDataSource_providerCache, "f").clear();
|
|
366
|
+
super.destroy();
|
|
367
|
+
}
|
|
368
|
+
}
|
|
369
|
+
exports.StakedBalanceDataSource = StakedBalanceDataSource;
|
|
370
|
+
_StakedBalanceDataSource_messenger = new WeakMap(), _StakedBalanceDataSource_onActiveChainsUpdated = new WeakMap(), _StakedBalanceDataSource_pollInterval = new WeakMap(), _StakedBalanceDataSource_enabled = new WeakMap(), _StakedBalanceDataSource_stakedBalanceFetcher = new WeakMap(), _StakedBalanceDataSource_activeSubscriptions = new WeakMap(), _StakedBalanceDataSource_providerCache = new WeakMap(), _StakedBalanceDataSource_supportedChainIds = new WeakMap(), _StakedBalanceDataSource_unsubscribeTransactionConfirmed = new WeakMap(), _StakedBalanceDataSource_unsubscribeIncomingTransactions = new WeakMap(), _StakedBalanceDataSource_unsubscribeNetworkStateChange = new WeakMap(), _StakedBalanceDataSource_unsubscribeNetworkEnablementControllerStateChange = new WeakMap(), _StakedBalanceDataSource_instances = new WeakSet(), _StakedBalanceDataSource_onNetworkStateChange = function _StakedBalanceDataSource_onNetworkStateChange() {
|
|
371
|
+
__classPrivateFieldGet(this, _StakedBalanceDataSource_providerCache, "f").clear();
|
|
372
|
+
log('Provider cache cleared after network state change');
|
|
373
|
+
}, _StakedBalanceDataSource_onNetworkEnablementControllerStateChange = function _StakedBalanceDataSource_onNetworkEnablementControllerStateChange(state) {
|
|
374
|
+
const { enabledNetworkMap } = state ?? {};
|
|
375
|
+
if (!enabledNetworkMap) {
|
|
376
|
+
return;
|
|
377
|
+
}
|
|
378
|
+
__classPrivateFieldGet(this, _StakedBalanceDataSource_instances, "m", _StakedBalanceDataSource_initializeActiveChainsFromEnabledMap).call(this, enabledNetworkMap);
|
|
379
|
+
}, _StakedBalanceDataSource_isTransactionInvolvingStakingContract = function _StakedBalanceDataSource_isTransactionInvolvingStakingContract(payload) {
|
|
380
|
+
const hexChainId = payload?.chainId;
|
|
381
|
+
if (!hexChainId) {
|
|
382
|
+
return false;
|
|
383
|
+
}
|
|
384
|
+
const contractAddress = (0, evm_rpc_services_1.getStakingContractAddress)(hexChainId);
|
|
385
|
+
if (!contractAddress) {
|
|
386
|
+
return false;
|
|
387
|
+
}
|
|
388
|
+
const contractLower = contractAddress.toLowerCase();
|
|
389
|
+
const from = payload.txParams?.from?.toLowerCase();
|
|
390
|
+
const to = payload.txParams?.to?.toLowerCase();
|
|
391
|
+
return from === contractLower || to === contractLower;
|
|
392
|
+
}, _StakedBalanceDataSource_onTransactionConfirmed = function _StakedBalanceDataSource_onTransactionConfirmed(payload) {
|
|
393
|
+
if (!__classPrivateFieldGet(this, _StakedBalanceDataSource_enabled, "f")) {
|
|
394
|
+
return;
|
|
395
|
+
}
|
|
396
|
+
if (!__classPrivateFieldGet(this, _StakedBalanceDataSource_instances, "m", _StakedBalanceDataSource_isTransactionInvolvingStakingContract).call(this, payload)) {
|
|
397
|
+
return;
|
|
398
|
+
}
|
|
399
|
+
const hexChainId = payload?.chainId;
|
|
400
|
+
if (!hexChainId) {
|
|
401
|
+
return;
|
|
402
|
+
}
|
|
403
|
+
const caipChainId = `eip155:${parseInt(hexChainId, 16)}`;
|
|
404
|
+
const toRefresh = __classPrivateFieldGet(this, _StakedBalanceDataSource_instances, "m", _StakedBalanceDataSource_getToRefreshForChains).call(this, [caipChainId]);
|
|
405
|
+
if (toRefresh.length > 0) {
|
|
406
|
+
__classPrivateFieldGet(this, _StakedBalanceDataSource_instances, "m", _StakedBalanceDataSource_refreshStakedBalanceAfterTransaction).call(this, toRefresh).catch((error) => {
|
|
407
|
+
log('Failed to refresh staked balance after transaction', { error });
|
|
408
|
+
});
|
|
409
|
+
}
|
|
410
|
+
}, _StakedBalanceDataSource_onIncomingTransactions = function _StakedBalanceDataSource_onIncomingTransactions(payload) {
|
|
411
|
+
if (!__classPrivateFieldGet(this, _StakedBalanceDataSource_enabled, "f")) {
|
|
412
|
+
return;
|
|
413
|
+
}
|
|
414
|
+
const chainIdsToRefresh = new Set();
|
|
415
|
+
for (const item of payload ?? []) {
|
|
416
|
+
if (!item?.chainId) {
|
|
417
|
+
continue;
|
|
418
|
+
}
|
|
419
|
+
if (__classPrivateFieldGet(this, _StakedBalanceDataSource_instances, "m", _StakedBalanceDataSource_isTransactionInvolvingStakingContract).call(this, item)) {
|
|
420
|
+
chainIdsToRefresh.add(item.chainId);
|
|
421
|
+
}
|
|
422
|
+
}
|
|
423
|
+
const caipChainIds = [...chainIdsToRefresh].map((hexChainId) => `eip155:${parseInt(hexChainId, 16)}`);
|
|
424
|
+
if (caipChainIds.length === 0) {
|
|
425
|
+
return;
|
|
426
|
+
}
|
|
427
|
+
const toRefresh = __classPrivateFieldGet(this, _StakedBalanceDataSource_instances, "m", _StakedBalanceDataSource_getToRefreshForChains).call(this, caipChainIds);
|
|
428
|
+
if (toRefresh.length > 0) {
|
|
429
|
+
__classPrivateFieldGet(this, _StakedBalanceDataSource_instances, "m", _StakedBalanceDataSource_refreshStakedBalanceAfterTransaction).call(this, toRefresh).catch((error) => {
|
|
430
|
+
log('Failed to refresh staked balance after incoming transactions', {
|
|
431
|
+
error,
|
|
432
|
+
});
|
|
433
|
+
});
|
|
434
|
+
}
|
|
435
|
+
}, _StakedBalanceDataSource_getToRefreshForChains = function _StakedBalanceDataSource_getToRefreshForChains(chainIds) {
|
|
436
|
+
const toRefresh = [];
|
|
437
|
+
const chainSet = new Set(chainIds);
|
|
438
|
+
for (const subscription of __classPrivateFieldGet(this, _StakedBalanceDataSource_activeSubscriptions, "f").values()) {
|
|
439
|
+
for (const { account, supportedChains, } of subscription.accountsWithSupportedChains) {
|
|
440
|
+
for (const chainId of supportedChains) {
|
|
441
|
+
if (chainSet.has(chainId)) {
|
|
442
|
+
toRefresh.push({ account, chainId });
|
|
443
|
+
}
|
|
444
|
+
}
|
|
445
|
+
}
|
|
446
|
+
}
|
|
447
|
+
return toRefresh;
|
|
448
|
+
}, _StakedBalanceDataSource_getToRefreshAll = function _StakedBalanceDataSource_getToRefreshAll() {
|
|
449
|
+
const toRefresh = [];
|
|
450
|
+
for (const subscription of __classPrivateFieldGet(this, _StakedBalanceDataSource_activeSubscriptions, "f").values()) {
|
|
451
|
+
for (const { account, supportedChains, } of subscription.accountsWithSupportedChains) {
|
|
452
|
+
for (const chainId of supportedChains) {
|
|
453
|
+
toRefresh.push({ account, chainId });
|
|
454
|
+
}
|
|
455
|
+
}
|
|
456
|
+
}
|
|
457
|
+
return toRefresh;
|
|
458
|
+
}, _StakedBalanceDataSource_refreshStakedBalanceAfterTransaction =
|
|
459
|
+
/**
|
|
460
|
+
* Fetch staked balance for the given account/chain pairs and push a single
|
|
461
|
+
* DataResponse to all active subscriptions.
|
|
462
|
+
*
|
|
463
|
+
* @param toRefresh - List of { account, chainId } to refresh.
|
|
464
|
+
*/
|
|
465
|
+
async function _StakedBalanceDataSource_refreshStakedBalanceAfterTransaction(toRefresh) {
|
|
466
|
+
const assetsInfo = {};
|
|
467
|
+
const assetsBalance = {};
|
|
468
|
+
for (const { account, chainId } of toRefresh) {
|
|
469
|
+
try {
|
|
470
|
+
const hexChainId = caipChainIdToHex(chainId);
|
|
471
|
+
const contractAddress = (0, evm_rpc_services_1.getStakingContractAddress)(hexChainId);
|
|
472
|
+
if (!contractAddress) {
|
|
473
|
+
continue;
|
|
474
|
+
}
|
|
475
|
+
const input = {
|
|
476
|
+
chainId: hexChainId,
|
|
477
|
+
accountId: account.id,
|
|
478
|
+
accountAddress: account.address,
|
|
479
|
+
};
|
|
480
|
+
const result = await __classPrivateFieldGet(this, _StakedBalanceDataSource_stakedBalanceFetcher, "f").fetchStakedBalance(input);
|
|
481
|
+
const assetId = stakedAssetId(chainId, contractAddress);
|
|
482
|
+
assetsInfo[assetId] = STAKED_ETH_METADATA;
|
|
483
|
+
const existing = assetsBalance[account.id];
|
|
484
|
+
assetsBalance[account.id] = {
|
|
485
|
+
...existing,
|
|
486
|
+
[assetId]: { amount: result.amount },
|
|
487
|
+
};
|
|
488
|
+
}
|
|
489
|
+
catch (error) {
|
|
490
|
+
log('Failed to fetch staked balance in transaction refresh', {
|
|
491
|
+
chainId,
|
|
492
|
+
accountId: account.id,
|
|
493
|
+
error,
|
|
494
|
+
});
|
|
495
|
+
}
|
|
496
|
+
}
|
|
497
|
+
if (Object.keys(assetsBalance).length > 0) {
|
|
498
|
+
const response = { assetsInfo, assetsBalance };
|
|
499
|
+
for (const subscription of __classPrivateFieldGet(this, _StakedBalanceDataSource_activeSubscriptions, "f").values()) {
|
|
500
|
+
subscription.onAssetsUpdate(response)?.catch((error) => {
|
|
501
|
+
log('Failed to report staked balance update after transaction', {
|
|
502
|
+
error,
|
|
503
|
+
});
|
|
504
|
+
});
|
|
505
|
+
}
|
|
506
|
+
}
|
|
507
|
+
}, _StakedBalanceDataSource_initializeActiveChains = function _StakedBalanceDataSource_initializeActiveChains() {
|
|
508
|
+
try {
|
|
509
|
+
const state = __classPrivateFieldGet(this, _StakedBalanceDataSource_messenger, "f").call('NetworkEnablementController:getState');
|
|
510
|
+
__classPrivateFieldGet(this, _StakedBalanceDataSource_instances, "m", _StakedBalanceDataSource_initializeActiveChainsFromEnabledMap).call(this, state?.enabledNetworkMap ?? {});
|
|
511
|
+
}
|
|
512
|
+
catch (error) {
|
|
513
|
+
log('Failed to get NetworkEnablementController state', { error });
|
|
514
|
+
__classPrivateFieldGet(this, _StakedBalanceDataSource_instances, "m", _StakedBalanceDataSource_initializeActiveChainsFromEnabledMap).call(this, {});
|
|
515
|
+
}
|
|
516
|
+
}, _StakedBalanceDataSource_initializeActiveChainsFromEnabledMap = function _StakedBalanceDataSource_initializeActiveChainsFromEnabledMap(enabledNetworkMap) {
|
|
517
|
+
if (!__classPrivateFieldGet(this, _StakedBalanceDataSource_enabled, "f")) {
|
|
518
|
+
const previous = [...this.state.activeChains];
|
|
519
|
+
this.updateActiveChains([], (updatedChains) => __classPrivateFieldGet(this, _StakedBalanceDataSource_onActiveChainsUpdated, "f").call(this, this.getName(), updatedChains, previous));
|
|
520
|
+
return;
|
|
521
|
+
}
|
|
522
|
+
const activeChains = [];
|
|
523
|
+
const eip155Map = enabledNetworkMap.eip155;
|
|
524
|
+
if (eip155Map) {
|
|
525
|
+
for (const caip2 of __classPrivateFieldGet(this, _StakedBalanceDataSource_supportedChainIds, "f")) {
|
|
526
|
+
if (!(0, utils_1.isCaipChainId)(caip2)) {
|
|
527
|
+
continue;
|
|
528
|
+
}
|
|
529
|
+
const { reference } = (0, utils_1.parseCaipChainId)(caip2);
|
|
530
|
+
const storageKey = (0, utils_1.numberToHex)(parseInt(reference, 10));
|
|
531
|
+
if (eip155Map[storageKey]) {
|
|
532
|
+
activeChains.push(caip2);
|
|
533
|
+
}
|
|
534
|
+
}
|
|
535
|
+
}
|
|
536
|
+
const previous = [...this.state.activeChains];
|
|
537
|
+
this.updateActiveChains(activeChains, (updatedChains) => __classPrivateFieldGet(this, _StakedBalanceDataSource_onActiveChainsUpdated, "f").call(this, this.getName(), updatedChains, previous));
|
|
538
|
+
}, _StakedBalanceDataSource_getProvider = function _StakedBalanceDataSource_getProvider(hexChainId) {
|
|
539
|
+
const cached = __classPrivateFieldGet(this, _StakedBalanceDataSource_providerCache, "f").get(hexChainId);
|
|
540
|
+
if (cached) {
|
|
541
|
+
return cached;
|
|
542
|
+
}
|
|
543
|
+
try {
|
|
544
|
+
const networkState = __classPrivateFieldGet(this, _StakedBalanceDataSource_messenger, "f").call('NetworkController:getState');
|
|
545
|
+
const { networkConfigurationsByChainId } = networkState;
|
|
546
|
+
if (!networkConfigurationsByChainId) {
|
|
547
|
+
return undefined;
|
|
548
|
+
}
|
|
549
|
+
const chainConfig = networkConfigurationsByChainId[hexChainId];
|
|
550
|
+
if (!chainConfig) {
|
|
551
|
+
return undefined;
|
|
552
|
+
}
|
|
553
|
+
// Use the network's configured default RPC endpoint (same as RpcDataSource).
|
|
554
|
+
const { rpcEndpoints, defaultRpcEndpointIndex } = chainConfig;
|
|
555
|
+
if (!rpcEndpoints || rpcEndpoints.length === 0) {
|
|
556
|
+
return undefined;
|
|
557
|
+
}
|
|
558
|
+
const index = typeof defaultRpcEndpointIndex === 'number' &&
|
|
559
|
+
defaultRpcEndpointIndex >= 0 &&
|
|
560
|
+
defaultRpcEndpointIndex < rpcEndpoints.length
|
|
561
|
+
? defaultRpcEndpointIndex
|
|
562
|
+
: 0;
|
|
563
|
+
const defaultEndpoint = rpcEndpoints[index];
|
|
564
|
+
const networkClientId = defaultEndpoint?.networkClientId;
|
|
565
|
+
if (!networkClientId) {
|
|
566
|
+
return undefined;
|
|
567
|
+
}
|
|
568
|
+
const networkClient = __classPrivateFieldGet(this, _StakedBalanceDataSource_messenger, "f").call('NetworkController:getNetworkClientById', networkClientId);
|
|
569
|
+
if (!networkClient?.provider) {
|
|
570
|
+
return undefined;
|
|
571
|
+
}
|
|
572
|
+
const provider = new providers_1.Web3Provider(networkClient.provider);
|
|
573
|
+
__classPrivateFieldGet(this, _StakedBalanceDataSource_providerCache, "f").set(hexChainId, provider);
|
|
574
|
+
return provider;
|
|
575
|
+
}
|
|
576
|
+
catch (error) {
|
|
577
|
+
log('Failed to get provider for chain', { hexChainId, error });
|
|
578
|
+
return undefined;
|
|
579
|
+
}
|
|
580
|
+
}, _StakedBalanceDataSource_handleStakedBalanceUpdate = function _StakedBalanceDataSource_handleStakedBalanceUpdate(result) {
|
|
581
|
+
const contractAddress = (0, evm_rpc_services_1.getStakingContractAddress)(result.chainId);
|
|
582
|
+
if (!contractAddress) {
|
|
583
|
+
return;
|
|
584
|
+
}
|
|
585
|
+
const chainIdDecimal = parseInt(result.chainId, 16);
|
|
586
|
+
const caipChainId = `eip155:${chainIdDecimal}`;
|
|
587
|
+
const assetId = stakedAssetId(caipChainId, contractAddress);
|
|
588
|
+
const response = {
|
|
589
|
+
assetsInfo: {
|
|
590
|
+
[assetId]: STAKED_ETH_METADATA,
|
|
591
|
+
},
|
|
592
|
+
assetsBalance: {
|
|
593
|
+
[result.accountId]: {
|
|
594
|
+
[assetId]: { amount: result.balance.amount },
|
|
595
|
+
},
|
|
596
|
+
},
|
|
597
|
+
};
|
|
598
|
+
log('Staked balance update', {
|
|
599
|
+
accountId: result.accountId,
|
|
600
|
+
chainId: caipChainId,
|
|
601
|
+
amount: result.balance.amount,
|
|
602
|
+
});
|
|
603
|
+
for (const subscription of __classPrivateFieldGet(this, _StakedBalanceDataSource_activeSubscriptions, "f").values()) {
|
|
604
|
+
subscription.onAssetsUpdate(response)?.catch((error) => {
|
|
605
|
+
log('Failed to report staked balance update', { error });
|
|
606
|
+
});
|
|
607
|
+
}
|
|
608
|
+
};
|
|
609
|
+
//# sourceMappingURL=StakedBalanceDataSource.cjs.map
|