@metamask/assets-controllers 45.1.2 → 46.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (92) hide show
  1. package/CHANGELOG.md +25 -1
  2. package/dist/MultichainBalancesController/BalancesTracker.cjs +122 -0
  3. package/dist/MultichainBalancesController/BalancesTracker.cjs.map +1 -0
  4. package/dist/MultichainBalancesController/BalancesTracker.d.cts +54 -0
  5. package/dist/MultichainBalancesController/BalancesTracker.d.cts.map +1 -0
  6. package/dist/MultichainBalancesController/BalancesTracker.d.mts +54 -0
  7. package/dist/MultichainBalancesController/BalancesTracker.d.mts.map +1 -0
  8. package/dist/MultichainBalancesController/BalancesTracker.mjs +118 -0
  9. package/dist/MultichainBalancesController/BalancesTracker.mjs.map +1 -0
  10. package/dist/MultichainBalancesController/MultichainBalancesController.cjs +194 -0
  11. package/dist/MultichainBalancesController/MultichainBalancesController.cjs.map +1 -0
  12. package/dist/MultichainBalancesController/MultichainBalancesController.d.cts +94 -0
  13. package/dist/MultichainBalancesController/MultichainBalancesController.d.cts.map +1 -0
  14. package/dist/MultichainBalancesController/MultichainBalancesController.d.mts +94 -0
  15. package/dist/MultichainBalancesController/MultichainBalancesController.d.mts.map +1 -0
  16. package/dist/MultichainBalancesController/MultichainBalancesController.mjs +189 -0
  17. package/dist/MultichainBalancesController/MultichainBalancesController.mjs.map +1 -0
  18. package/dist/MultichainBalancesController/Poller.cjs +45 -0
  19. package/dist/MultichainBalancesController/Poller.cjs.map +1 -0
  20. package/dist/MultichainBalancesController/Poller.d.cts +7 -0
  21. package/dist/MultichainBalancesController/Poller.d.cts.map +1 -0
  22. package/dist/MultichainBalancesController/Poller.d.mts +7 -0
  23. package/dist/MultichainBalancesController/Poller.d.mts.map +1 -0
  24. package/dist/MultichainBalancesController/Poller.mjs +41 -0
  25. package/dist/MultichainBalancesController/Poller.mjs.map +1 -0
  26. package/dist/MultichainBalancesController/constants.cjs +45 -0
  27. package/dist/MultichainBalancesController/constants.cjs.map +1 -0
  28. package/dist/MultichainBalancesController/constants.d.cts +29 -0
  29. package/dist/MultichainBalancesController/constants.d.cts.map +1 -0
  30. package/dist/MultichainBalancesController/constants.d.mts +29 -0
  31. package/dist/MultichainBalancesController/constants.d.mts.map +1 -0
  32. package/dist/MultichainBalancesController/constants.mjs +42 -0
  33. package/dist/MultichainBalancesController/constants.mjs.map +1 -0
  34. package/dist/MultichainBalancesController/error.cjs +18 -0
  35. package/dist/MultichainBalancesController/error.cjs.map +1 -0
  36. package/dist/MultichainBalancesController/error.d.cts +7 -0
  37. package/dist/MultichainBalancesController/error.d.cts.map +1 -0
  38. package/dist/MultichainBalancesController/error.d.mts +7 -0
  39. package/dist/MultichainBalancesController/error.d.mts.map +1 -0
  40. package/dist/MultichainBalancesController/error.mjs +13 -0
  41. package/dist/MultichainBalancesController/error.mjs.map +1 -0
  42. package/dist/MultichainBalancesController/index.cjs +13 -0
  43. package/dist/MultichainBalancesController/index.cjs.map +1 -0
  44. package/dist/MultichainBalancesController/index.d.cts +5 -0
  45. package/dist/MultichainBalancesController/index.d.cts.map +1 -0
  46. package/dist/MultichainBalancesController/index.d.mts +5 -0
  47. package/dist/MultichainBalancesController/index.d.mts.map +1 -0
  48. package/dist/MultichainBalancesController/index.mjs +4 -0
  49. package/dist/MultichainBalancesController/index.mjs.map +1 -0
  50. package/dist/MultichainBalancesController/utils.cjs +73 -0
  51. package/dist/MultichainBalancesController/utils.cjs.map +1 -0
  52. package/dist/MultichainBalancesController/utils.d.cts +36 -0
  53. package/dist/MultichainBalancesController/utils.d.cts.map +1 -0
  54. package/dist/MultichainBalancesController/utils.d.mts +36 -0
  55. package/dist/MultichainBalancesController/utils.d.mts.map +1 -0
  56. package/dist/MultichainBalancesController/utils.mjs +66 -0
  57. package/dist/MultichainBalancesController/utils.mjs.map +1 -0
  58. package/dist/TokensController.cjs +6 -4
  59. package/dist/TokensController.cjs.map +1 -1
  60. package/dist/TokensController.d.cts.map +1 -1
  61. package/dist/TokensController.d.mts.map +1 -1
  62. package/dist/TokensController.mjs +6 -4
  63. package/dist/TokensController.mjs.map +1 -1
  64. package/dist/assetsUtil.cjs +16 -1
  65. package/dist/assetsUtil.cjs.map +1 -1
  66. package/dist/assetsUtil.d.cts +7 -0
  67. package/dist/assetsUtil.d.cts.map +1 -1
  68. package/dist/assetsUtil.d.mts +7 -0
  69. package/dist/assetsUtil.d.mts.map +1 -1
  70. package/dist/assetsUtil.mjs +14 -0
  71. package/dist/assetsUtil.mjs.map +1 -1
  72. package/dist/crypto-compare-service/crypto-compare.cjs +5 -2
  73. package/dist/crypto-compare-service/crypto-compare.cjs.map +1 -1
  74. package/dist/crypto-compare-service/crypto-compare.d.cts.map +1 -1
  75. package/dist/crypto-compare-service/crypto-compare.d.mts.map +1 -1
  76. package/dist/crypto-compare-service/crypto-compare.mjs +5 -2
  77. package/dist/crypto-compare-service/crypto-compare.mjs.map +1 -1
  78. package/dist/index.cjs +10 -1
  79. package/dist/index.cjs.map +1 -1
  80. package/dist/index.d.cts +3 -1
  81. package/dist/index.d.cts.map +1 -1
  82. package/dist/index.d.mts +3 -1
  83. package/dist/index.d.mts.map +1 -1
  84. package/dist/index.mjs +4 -1
  85. package/dist/index.mjs.map +1 -1
  86. package/dist/multicall.cjs +16 -3
  87. package/dist/multicall.cjs.map +1 -1
  88. package/dist/multicall.d.cts.map +1 -1
  89. package/dist/multicall.d.mts.map +1 -1
  90. package/dist/multicall.mjs +16 -3
  91. package/dist/multicall.mjs.map +1 -1
  92. package/package.json +16 -10
package/CHANGELOG.md CHANGED
@@ -7,6 +7,29 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
7
7
 
8
8
  ## [Unreleased]
9
9
 
10
+ ## [46.0.0]
11
+
12
+ ### Added
13
+
14
+ - Add new `MultichainBalancesController` ([#4965](https://github.com/MetaMask/core/pull/4965))
15
+ - This controller has been migrated from the MetaMask extension codebase.
16
+ - Added utility function `getKeyByValue` ([#5099](https://github.com/MetaMask/core/pull/5099))
17
+
18
+ ### Changed
19
+
20
+ - **BREAKING:** Bump `@metamask/accounts-controller` peer dependency from `^20.0.0` to `^21.0.0` ([#5140](https://github.com/MetaMask/core/pull/5140))
21
+ - Bump `@metamask/base-controller` from `^7.0.0` to `^7.1.1` ([#5079](https://github.com/MetaMask/core/pull/5079)), ([#5135](https://github.com/MetaMask/core/pull/5135))
22
+ - Bump `@metamask/keyring-api` from `^12.0.0` to `^13.0.0` ([#5066](https://github.com/MetaMask/core/pull/5066))
23
+ - Bump `@metamask/utils` to `^11.0.1` ([#5080](https://github.com/MetaMask/core/pull/5080))
24
+ - Bump `@metamask/rpc-errors` to `^7.0.2` ([#5080](https://github.com/MetaMask/core/pull/5080))
25
+
26
+ ### Fixed
27
+
28
+ - Fix Mantle price when calling `fetchMultiExchangeRate` ([#5099](https://github.com/MetaMask/core/pull/5099))
29
+ - Fix multicall revert in `TokenBalancesController` ([#5083](https://github.com/MetaMask/core/pull/5083))
30
+ - `TokenBalancesController` was fixed to fetch erc20 token balances even if there's an invalid token in state whose address does not point to a smart contract.
31
+ - Fix state changes for `ignoreTokens` for non-selected networks ([#5014](https://github.com/MetaMask/core/pull/5014))
32
+
10
33
  ## [45.1.2]
11
34
 
12
35
  ### Changed
@@ -1300,7 +1323,8 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
1300
1323
 
1301
1324
  - Use Ethers for AssetsContractController ([#845](https://github.com/MetaMask/core/pull/845))
1302
1325
 
1303
- [Unreleased]: https://github.com/MetaMask/core/compare/@metamask/assets-controllers@45.1.2...HEAD
1326
+ [Unreleased]: https://github.com/MetaMask/core/compare/@metamask/assets-controllers@46.0.0...HEAD
1327
+ [46.0.0]: https://github.com/MetaMask/core/compare/@metamask/assets-controllers@45.1.2...@metamask/assets-controllers@46.0.0
1304
1328
  [45.1.2]: https://github.com/MetaMask/core/compare/@metamask/assets-controllers@45.1.1...@metamask/assets-controllers@45.1.2
1305
1329
  [45.1.1]: https://github.com/MetaMask/core/compare/@metamask/assets-controllers@45.1.0...@metamask/assets-controllers@45.1.1
1306
1330
  [45.1.0]: https://github.com/MetaMask/core/compare/@metamask/assets-controllers@45.0.0...@metamask/assets-controllers@45.1.0
@@ -0,0 +1,122 @@
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 _BalancesTracker_instances, _BalancesTracker_poller, _BalancesTracker_updateBalance, _BalancesTracker_balances, _BalancesTracker_isBalanceOutdated;
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.BalancesTracker = void 0;
16
+ const Poller_1 = require("./Poller.cjs");
17
+ const BALANCES_TRACKING_INTERVAL = 5000; // Every 5s in milliseconds.
18
+ class BalancesTracker {
19
+ constructor(updateBalanceCallback) {
20
+ _BalancesTracker_instances.add(this);
21
+ _BalancesTracker_poller.set(this, void 0);
22
+ _BalancesTracker_updateBalance.set(this, void 0);
23
+ _BalancesTracker_balances.set(this, {});
24
+ __classPrivateFieldSet(this, _BalancesTracker_updateBalance, updateBalanceCallback, "f");
25
+ __classPrivateFieldSet(this, _BalancesTracker_poller, new Poller_1.Poller(() => this.updateBalances(), BALANCES_TRACKING_INTERVAL), "f");
26
+ }
27
+ /**
28
+ * Starts the tracking process.
29
+ */
30
+ start() {
31
+ __classPrivateFieldGet(this, _BalancesTracker_poller, "f").start();
32
+ }
33
+ /**
34
+ * Stops the tracking process.
35
+ */
36
+ stop() {
37
+ __classPrivateFieldGet(this, _BalancesTracker_poller, "f").stop();
38
+ }
39
+ /**
40
+ * Checks if an account ID is being tracked.
41
+ *
42
+ * @param accountId - The account ID.
43
+ * @returns True if the account is being tracked, false otherwise.
44
+ */
45
+ isTracked(accountId) {
46
+ return Object.prototype.hasOwnProperty.call(__classPrivateFieldGet(this, _BalancesTracker_balances, "f"), accountId);
47
+ }
48
+ /**
49
+ * Asserts that an account ID is being tracked.
50
+ *
51
+ * @param accountId - The account ID.
52
+ * @throws If the account ID is not being tracked.
53
+ */
54
+ assertBeingTracked(accountId) {
55
+ if (!this.isTracked(accountId)) {
56
+ throw new Error(`Account is not being tracked: ${accountId}`);
57
+ }
58
+ }
59
+ /**
60
+ * Starts tracking a new account ID. This method has no effect on already tracked
61
+ * accounts.
62
+ *
63
+ * @param accountId - The account ID.
64
+ * @param blockTime - The block time (used when refreshing the account balances).
65
+ */
66
+ track(accountId, blockTime) {
67
+ // Do not overwrite current info if already being tracked!
68
+ if (!this.isTracked(accountId)) {
69
+ __classPrivateFieldGet(this, _BalancesTracker_balances, "f")[accountId] = {
70
+ lastUpdated: 0,
71
+ blockTime,
72
+ };
73
+ }
74
+ }
75
+ /**
76
+ * Stops tracking a tracked account ID.
77
+ *
78
+ * @param accountId - The account ID.
79
+ * @throws If the account ID is not being tracked.
80
+ */
81
+ untrack(accountId) {
82
+ this.assertBeingTracked(accountId);
83
+ delete __classPrivateFieldGet(this, _BalancesTracker_balances, "f")[accountId];
84
+ }
85
+ /**
86
+ * Update the balances for a tracked account ID.
87
+ *
88
+ * @param accountId - The account ID.
89
+ * @throws If the account ID is not being tracked.
90
+ */
91
+ async updateBalance(accountId) {
92
+ this.assertBeingTracked(accountId);
93
+ // We check if the balance is outdated (by comparing to the block time associated
94
+ // with this kind of account).
95
+ //
96
+ // This might not be super accurate, but we could probably compute this differently
97
+ // and try to sync with the "real block time"!
98
+ const info = __classPrivateFieldGet(this, _BalancesTracker_balances, "f")[accountId];
99
+ if (__classPrivateFieldGet(this, _BalancesTracker_instances, "m", _BalancesTracker_isBalanceOutdated).call(this, info)) {
100
+ await __classPrivateFieldGet(this, _BalancesTracker_updateBalance, "f").call(this, accountId);
101
+ __classPrivateFieldGet(this, _BalancesTracker_balances, "f")[accountId].lastUpdated = Date.now();
102
+ }
103
+ }
104
+ /**
105
+ * Update the balances of all tracked accounts (only if the balances
106
+ * is considered outdated).
107
+ */
108
+ async updateBalances() {
109
+ await Promise.allSettled(Object.keys(__classPrivateFieldGet(this, _BalancesTracker_balances, "f")).map(async (accountId) => {
110
+ await this.updateBalance(accountId);
111
+ }));
112
+ }
113
+ }
114
+ exports.BalancesTracker = BalancesTracker;
115
+ _BalancesTracker_poller = new WeakMap(), _BalancesTracker_updateBalance = new WeakMap(), _BalancesTracker_balances = new WeakMap(), _BalancesTracker_instances = new WeakSet(), _BalancesTracker_isBalanceOutdated = function _BalancesTracker_isBalanceOutdated({ lastUpdated, blockTime }) {
116
+ return (
117
+ // Never been updated:
118
+ lastUpdated === 0 ||
119
+ // Outdated:
120
+ Date.now() - lastUpdated >= blockTime);
121
+ };
122
+ //# sourceMappingURL=BalancesTracker.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BalancesTracker.cjs","sourceRoot":"","sources":["../../src/MultichainBalancesController/BalancesTracker.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,yCAAkC;AAOlC,MAAM,0BAA0B,GAAG,IAAI,CAAC,CAAC,4BAA4B;AAErE,MAAa,eAAe;IAO1B,YAAY,qBAA2D;;QANvE,0CAAgB;QAEhB,iDAAqD;QAErD,oCAAyC,EAAE,EAAC;QAG1C,uBAAA,IAAI,kCAAkB,qBAAqB,MAAA,CAAC;QAE5C,uBAAA,IAAI,2BAAW,IAAI,eAAM,CACvB,GAAG,EAAE,CAAC,IAAI,CAAC,cAAc,EAAE,EAC3B,0BAA0B,CAC3B,MAAA,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,KAAK;QACH,uBAAA,IAAI,+BAAQ,CAAC,KAAK,EAAE,CAAC;IACvB,CAAC;IAED;;OAEG;IACH,IAAI;QACF,uBAAA,IAAI,+BAAQ,CAAC,IAAI,EAAE,CAAC;IACtB,CAAC;IAED;;;;;OAKG;IACH,SAAS,CAAC,SAAiB;QACzB,OAAO,MAAM,CAAC,SAAS,CAAC,cAAc,CAAC,IAAI,CAAC,uBAAA,IAAI,iCAAU,EAAE,SAAS,CAAC,CAAC;IACzE,CAAC;IAED;;;;;OAKG;IACH,kBAAkB,CAAC,SAAiB;QAClC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE;YAC9B,MAAM,IAAI,KAAK,CAAC,iCAAiC,SAAS,EAAE,CAAC,CAAC;SAC/D;IACH,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,SAAiB,EAAE,SAAiB;QACxC,0DAA0D;QAC1D,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE;YAC9B,uBAAA,IAAI,iCAAU,CAAC,SAAS,CAAC,GAAG;gBAC1B,WAAW,EAAE,CAAC;gBACd,SAAS;aACV,CAAC;SACH;IACH,CAAC;IAED;;;;;OAKG;IACH,OAAO,CAAC,SAAiB;QACvB,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC;QACnC,OAAO,uBAAA,IAAI,iCAAU,CAAC,SAAS,CAAC,CAAC;IACnC,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,aAAa,CAAC,SAAiB;QACnC,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC;QAEnC,iFAAiF;QACjF,8BAA8B;QAC9B,EAAE;QACF,mFAAmF;QACnF,8CAA8C;QAC9C,MAAM,IAAI,GAAG,uBAAA,IAAI,iCAAU,CAAC,SAAS,CAAC,CAAC;QACvC,IAAI,uBAAA,IAAI,sEAAmB,MAAvB,IAAI,EAAoB,IAAI,CAAC,EAAE;YACjC,MAAM,uBAAA,IAAI,sCAAe,MAAnB,IAAI,EAAgB,SAAS,CAAC,CAAC;YACrC,uBAAA,IAAI,iCAAU,CAAC,SAAS,CAAC,CAAC,WAAW,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;SACpD;IACH,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,cAAc;QAClB,MAAM,OAAO,CAAC,UAAU,CACtB,MAAM,CAAC,IAAI,CAAC,uBAAA,IAAI,iCAAU,CAAC,CAAC,GAAG,CAAC,KAAK,EAAE,SAAS,EAAE,EAAE;YAClD,MAAM,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;QACtC,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;CAkBF;AAjID,0CAiIC;iQARoB,EAAE,WAAW,EAAE,SAAS,EAAe;IACxD,OAAO;IACL,sBAAsB;IACtB,WAAW,KAAK,CAAC;QACjB,YAAY;QACZ,IAAI,CAAC,GAAG,EAAE,GAAG,WAAW,IAAI,SAAS,CACtC,CAAC;AACJ,CAAC","sourcesContent":["import { Poller } from './Poller';\n\ntype BalanceInfo = {\n lastUpdated: number;\n blockTime: number;\n};\n\nconst BALANCES_TRACKING_INTERVAL = 5000; // Every 5s in milliseconds.\n\nexport class BalancesTracker {\n #poller: Poller;\n\n #updateBalance: (accountId: string) => Promise<void>;\n\n #balances: Record<string, BalanceInfo> = {};\n\n constructor(updateBalanceCallback: (accountId: string) => Promise<void>) {\n this.#updateBalance = updateBalanceCallback;\n\n this.#poller = new Poller(\n () => this.updateBalances(),\n BALANCES_TRACKING_INTERVAL,\n );\n }\n\n /**\n * Starts the tracking process.\n */\n start(): void {\n this.#poller.start();\n }\n\n /**\n * Stops the tracking process.\n */\n stop(): void {\n this.#poller.stop();\n }\n\n /**\n * Checks if an account ID is being tracked.\n *\n * @param accountId - The account ID.\n * @returns True if the account is being tracked, false otherwise.\n */\n isTracked(accountId: string) {\n return Object.prototype.hasOwnProperty.call(this.#balances, accountId);\n }\n\n /**\n * Asserts that an account ID is being tracked.\n *\n * @param accountId - The account ID.\n * @throws If the account ID is not being tracked.\n */\n assertBeingTracked(accountId: string) {\n if (!this.isTracked(accountId)) {\n throw new Error(`Account is not being tracked: ${accountId}`);\n }\n }\n\n /**\n * Starts tracking a new account ID. This method has no effect on already tracked\n * accounts.\n *\n * @param accountId - The account ID.\n * @param blockTime - The block time (used when refreshing the account balances).\n */\n track(accountId: string, blockTime: number) {\n // Do not overwrite current info if already being tracked!\n if (!this.isTracked(accountId)) {\n this.#balances[accountId] = {\n lastUpdated: 0,\n blockTime,\n };\n }\n }\n\n /**\n * Stops tracking a tracked account ID.\n *\n * @param accountId - The account ID.\n * @throws If the account ID is not being tracked.\n */\n untrack(accountId: string) {\n this.assertBeingTracked(accountId);\n delete this.#balances[accountId];\n }\n\n /**\n * Update the balances for a tracked account ID.\n *\n * @param accountId - The account ID.\n * @throws If the account ID is not being tracked.\n */\n async updateBalance(accountId: string) {\n this.assertBeingTracked(accountId);\n\n // We check if the balance is outdated (by comparing to the block time associated\n // with this kind of account).\n //\n // This might not be super accurate, but we could probably compute this differently\n // and try to sync with the \"real block time\"!\n const info = this.#balances[accountId];\n if (this.#isBalanceOutdated(info)) {\n await this.#updateBalance(accountId);\n this.#balances[accountId].lastUpdated = Date.now();\n }\n }\n\n /**\n * Update the balances of all tracked accounts (only if the balances\n * is considered outdated).\n */\n async updateBalances() {\n await Promise.allSettled(\n Object.keys(this.#balances).map(async (accountId) => {\n await this.updateBalance(accountId);\n }),\n );\n }\n\n /**\n * Checks if the balance is outdated according to the provided data.\n *\n * @param param - The balance info.\n * @param param.lastUpdated - The last updated timestamp.\n * @param param.blockTime - The block time.\n * @returns True if the balance is outdated, false otherwise.\n */\n #isBalanceOutdated({ lastUpdated, blockTime }: BalanceInfo): boolean {\n return (\n // Never been updated:\n lastUpdated === 0 ||\n // Outdated:\n Date.now() - lastUpdated >= blockTime\n );\n }\n}\n"]}
@@ -0,0 +1,54 @@
1
+ export declare class BalancesTracker {
2
+ #private;
3
+ constructor(updateBalanceCallback: (accountId: string) => Promise<void>);
4
+ /**
5
+ * Starts the tracking process.
6
+ */
7
+ start(): void;
8
+ /**
9
+ * Stops the tracking process.
10
+ */
11
+ stop(): void;
12
+ /**
13
+ * Checks if an account ID is being tracked.
14
+ *
15
+ * @param accountId - The account ID.
16
+ * @returns True if the account is being tracked, false otherwise.
17
+ */
18
+ isTracked(accountId: string): boolean;
19
+ /**
20
+ * Asserts that an account ID is being tracked.
21
+ *
22
+ * @param accountId - The account ID.
23
+ * @throws If the account ID is not being tracked.
24
+ */
25
+ assertBeingTracked(accountId: string): void;
26
+ /**
27
+ * Starts tracking a new account ID. This method has no effect on already tracked
28
+ * accounts.
29
+ *
30
+ * @param accountId - The account ID.
31
+ * @param blockTime - The block time (used when refreshing the account balances).
32
+ */
33
+ track(accountId: string, blockTime: number): void;
34
+ /**
35
+ * Stops tracking a tracked account ID.
36
+ *
37
+ * @param accountId - The account ID.
38
+ * @throws If the account ID is not being tracked.
39
+ */
40
+ untrack(accountId: string): void;
41
+ /**
42
+ * Update the balances for a tracked account ID.
43
+ *
44
+ * @param accountId - The account ID.
45
+ * @throws If the account ID is not being tracked.
46
+ */
47
+ updateBalance(accountId: string): Promise<void>;
48
+ /**
49
+ * Update the balances of all tracked accounts (only if the balances
50
+ * is considered outdated).
51
+ */
52
+ updateBalances(): Promise<void>;
53
+ }
54
+ //# sourceMappingURL=BalancesTracker.d.cts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BalancesTracker.d.cts","sourceRoot":"","sources":["../../src/MultichainBalancesController/BalancesTracker.ts"],"names":[],"mappings":"AASA,qBAAa,eAAe;;gBAOd,qBAAqB,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC;IASvE;;OAEG;IACH,KAAK,IAAI,IAAI;IAIb;;OAEG;IACH,IAAI,IAAI,IAAI;IAIZ;;;;;OAKG;IACH,SAAS,CAAC,SAAS,EAAE,MAAM;IAI3B;;;;;OAKG;IACH,kBAAkB,CAAC,SAAS,EAAE,MAAM;IAMpC;;;;;;OAMG;IACH,KAAK,CAAC,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM;IAU1C;;;;;OAKG;IACH,OAAO,CAAC,SAAS,EAAE,MAAM;IAKzB;;;;;OAKG;IACG,aAAa,CAAC,SAAS,EAAE,MAAM;IAerC;;;OAGG;IACG,cAAc;CAwBrB"}
@@ -0,0 +1,54 @@
1
+ export declare class BalancesTracker {
2
+ #private;
3
+ constructor(updateBalanceCallback: (accountId: string) => Promise<void>);
4
+ /**
5
+ * Starts the tracking process.
6
+ */
7
+ start(): void;
8
+ /**
9
+ * Stops the tracking process.
10
+ */
11
+ stop(): void;
12
+ /**
13
+ * Checks if an account ID is being tracked.
14
+ *
15
+ * @param accountId - The account ID.
16
+ * @returns True if the account is being tracked, false otherwise.
17
+ */
18
+ isTracked(accountId: string): boolean;
19
+ /**
20
+ * Asserts that an account ID is being tracked.
21
+ *
22
+ * @param accountId - The account ID.
23
+ * @throws If the account ID is not being tracked.
24
+ */
25
+ assertBeingTracked(accountId: string): void;
26
+ /**
27
+ * Starts tracking a new account ID. This method has no effect on already tracked
28
+ * accounts.
29
+ *
30
+ * @param accountId - The account ID.
31
+ * @param blockTime - The block time (used when refreshing the account balances).
32
+ */
33
+ track(accountId: string, blockTime: number): void;
34
+ /**
35
+ * Stops tracking a tracked account ID.
36
+ *
37
+ * @param accountId - The account ID.
38
+ * @throws If the account ID is not being tracked.
39
+ */
40
+ untrack(accountId: string): void;
41
+ /**
42
+ * Update the balances for a tracked account ID.
43
+ *
44
+ * @param accountId - The account ID.
45
+ * @throws If the account ID is not being tracked.
46
+ */
47
+ updateBalance(accountId: string): Promise<void>;
48
+ /**
49
+ * Update the balances of all tracked accounts (only if the balances
50
+ * is considered outdated).
51
+ */
52
+ updateBalances(): Promise<void>;
53
+ }
54
+ //# sourceMappingURL=BalancesTracker.d.mts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BalancesTracker.d.mts","sourceRoot":"","sources":["../../src/MultichainBalancesController/BalancesTracker.ts"],"names":[],"mappings":"AASA,qBAAa,eAAe;;gBAOd,qBAAqB,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC;IASvE;;OAEG;IACH,KAAK,IAAI,IAAI;IAIb;;OAEG;IACH,IAAI,IAAI,IAAI;IAIZ;;;;;OAKG;IACH,SAAS,CAAC,SAAS,EAAE,MAAM;IAI3B;;;;;OAKG;IACH,kBAAkB,CAAC,SAAS,EAAE,MAAM;IAMpC;;;;;;OAMG;IACH,KAAK,CAAC,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM;IAU1C;;;;;OAKG;IACH,OAAO,CAAC,SAAS,EAAE,MAAM;IAKzB;;;;;OAKG;IACG,aAAa,CAAC,SAAS,EAAE,MAAM;IAerC;;;OAGG;IACG,cAAc;CAwBrB"}
@@ -0,0 +1,118 @@
1
+ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
2
+ if (kind === "m") throw new TypeError("Private method is not writable");
3
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
4
+ 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");
5
+ return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
6
+ };
7
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
8
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
9
+ 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");
10
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
11
+ };
12
+ var _BalancesTracker_instances, _BalancesTracker_poller, _BalancesTracker_updateBalance, _BalancesTracker_balances, _BalancesTracker_isBalanceOutdated;
13
+ import { Poller } from "./Poller.mjs";
14
+ const BALANCES_TRACKING_INTERVAL = 5000; // Every 5s in milliseconds.
15
+ export class BalancesTracker {
16
+ constructor(updateBalanceCallback) {
17
+ _BalancesTracker_instances.add(this);
18
+ _BalancesTracker_poller.set(this, void 0);
19
+ _BalancesTracker_updateBalance.set(this, void 0);
20
+ _BalancesTracker_balances.set(this, {});
21
+ __classPrivateFieldSet(this, _BalancesTracker_updateBalance, updateBalanceCallback, "f");
22
+ __classPrivateFieldSet(this, _BalancesTracker_poller, new Poller(() => this.updateBalances(), BALANCES_TRACKING_INTERVAL), "f");
23
+ }
24
+ /**
25
+ * Starts the tracking process.
26
+ */
27
+ start() {
28
+ __classPrivateFieldGet(this, _BalancesTracker_poller, "f").start();
29
+ }
30
+ /**
31
+ * Stops the tracking process.
32
+ */
33
+ stop() {
34
+ __classPrivateFieldGet(this, _BalancesTracker_poller, "f").stop();
35
+ }
36
+ /**
37
+ * Checks if an account ID is being tracked.
38
+ *
39
+ * @param accountId - The account ID.
40
+ * @returns True if the account is being tracked, false otherwise.
41
+ */
42
+ isTracked(accountId) {
43
+ return Object.prototype.hasOwnProperty.call(__classPrivateFieldGet(this, _BalancesTracker_balances, "f"), accountId);
44
+ }
45
+ /**
46
+ * Asserts that an account ID is being tracked.
47
+ *
48
+ * @param accountId - The account ID.
49
+ * @throws If the account ID is not being tracked.
50
+ */
51
+ assertBeingTracked(accountId) {
52
+ if (!this.isTracked(accountId)) {
53
+ throw new Error(`Account is not being tracked: ${accountId}`);
54
+ }
55
+ }
56
+ /**
57
+ * Starts tracking a new account ID. This method has no effect on already tracked
58
+ * accounts.
59
+ *
60
+ * @param accountId - The account ID.
61
+ * @param blockTime - The block time (used when refreshing the account balances).
62
+ */
63
+ track(accountId, blockTime) {
64
+ // Do not overwrite current info if already being tracked!
65
+ if (!this.isTracked(accountId)) {
66
+ __classPrivateFieldGet(this, _BalancesTracker_balances, "f")[accountId] = {
67
+ lastUpdated: 0,
68
+ blockTime,
69
+ };
70
+ }
71
+ }
72
+ /**
73
+ * Stops tracking a tracked account ID.
74
+ *
75
+ * @param accountId - The account ID.
76
+ * @throws If the account ID is not being tracked.
77
+ */
78
+ untrack(accountId) {
79
+ this.assertBeingTracked(accountId);
80
+ delete __classPrivateFieldGet(this, _BalancesTracker_balances, "f")[accountId];
81
+ }
82
+ /**
83
+ * Update the balances for a tracked account ID.
84
+ *
85
+ * @param accountId - The account ID.
86
+ * @throws If the account ID is not being tracked.
87
+ */
88
+ async updateBalance(accountId) {
89
+ this.assertBeingTracked(accountId);
90
+ // We check if the balance is outdated (by comparing to the block time associated
91
+ // with this kind of account).
92
+ //
93
+ // This might not be super accurate, but we could probably compute this differently
94
+ // and try to sync with the "real block time"!
95
+ const info = __classPrivateFieldGet(this, _BalancesTracker_balances, "f")[accountId];
96
+ if (__classPrivateFieldGet(this, _BalancesTracker_instances, "m", _BalancesTracker_isBalanceOutdated).call(this, info)) {
97
+ await __classPrivateFieldGet(this, _BalancesTracker_updateBalance, "f").call(this, accountId);
98
+ __classPrivateFieldGet(this, _BalancesTracker_balances, "f")[accountId].lastUpdated = Date.now();
99
+ }
100
+ }
101
+ /**
102
+ * Update the balances of all tracked accounts (only if the balances
103
+ * is considered outdated).
104
+ */
105
+ async updateBalances() {
106
+ await Promise.allSettled(Object.keys(__classPrivateFieldGet(this, _BalancesTracker_balances, "f")).map(async (accountId) => {
107
+ await this.updateBalance(accountId);
108
+ }));
109
+ }
110
+ }
111
+ _BalancesTracker_poller = new WeakMap(), _BalancesTracker_updateBalance = new WeakMap(), _BalancesTracker_balances = new WeakMap(), _BalancesTracker_instances = new WeakSet(), _BalancesTracker_isBalanceOutdated = function _BalancesTracker_isBalanceOutdated({ lastUpdated, blockTime }) {
112
+ return (
113
+ // Never been updated:
114
+ lastUpdated === 0 ||
115
+ // Outdated:
116
+ Date.now() - lastUpdated >= blockTime);
117
+ };
118
+ //# sourceMappingURL=BalancesTracker.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BalancesTracker.mjs","sourceRoot":"","sources":["../../src/MultichainBalancesController/BalancesTracker.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,OAAO,EAAE,MAAM,EAAE,qBAAiB;AAOlC,MAAM,0BAA0B,GAAG,IAAI,CAAC,CAAC,4BAA4B;AAErE,MAAM,OAAO,eAAe;IAO1B,YAAY,qBAA2D;;QANvE,0CAAgB;QAEhB,iDAAqD;QAErD,oCAAyC,EAAE,EAAC;QAG1C,uBAAA,IAAI,kCAAkB,qBAAqB,MAAA,CAAC;QAE5C,uBAAA,IAAI,2BAAW,IAAI,MAAM,CACvB,GAAG,EAAE,CAAC,IAAI,CAAC,cAAc,EAAE,EAC3B,0BAA0B,CAC3B,MAAA,CAAC;IACJ,CAAC;IAED;;OAEG;IACH,KAAK;QACH,uBAAA,IAAI,+BAAQ,CAAC,KAAK,EAAE,CAAC;IACvB,CAAC;IAED;;OAEG;IACH,IAAI;QACF,uBAAA,IAAI,+BAAQ,CAAC,IAAI,EAAE,CAAC;IACtB,CAAC;IAED;;;;;OAKG;IACH,SAAS,CAAC,SAAiB;QACzB,OAAO,MAAM,CAAC,SAAS,CAAC,cAAc,CAAC,IAAI,CAAC,uBAAA,IAAI,iCAAU,EAAE,SAAS,CAAC,CAAC;IACzE,CAAC;IAED;;;;;OAKG;IACH,kBAAkB,CAAC,SAAiB;QAClC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE;YAC9B,MAAM,IAAI,KAAK,CAAC,iCAAiC,SAAS,EAAE,CAAC,CAAC;SAC/D;IACH,CAAC;IAED;;;;;;OAMG;IACH,KAAK,CAAC,SAAiB,EAAE,SAAiB;QACxC,0DAA0D;QAC1D,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,EAAE;YAC9B,uBAAA,IAAI,iCAAU,CAAC,SAAS,CAAC,GAAG;gBAC1B,WAAW,EAAE,CAAC;gBACd,SAAS;aACV,CAAC;SACH;IACH,CAAC;IAED;;;;;OAKG;IACH,OAAO,CAAC,SAAiB;QACvB,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC;QACnC,OAAO,uBAAA,IAAI,iCAAU,CAAC,SAAS,CAAC,CAAC;IACnC,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,aAAa,CAAC,SAAiB;QACnC,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,CAAC;QAEnC,iFAAiF;QACjF,8BAA8B;QAC9B,EAAE;QACF,mFAAmF;QACnF,8CAA8C;QAC9C,MAAM,IAAI,GAAG,uBAAA,IAAI,iCAAU,CAAC,SAAS,CAAC,CAAC;QACvC,IAAI,uBAAA,IAAI,sEAAmB,MAAvB,IAAI,EAAoB,IAAI,CAAC,EAAE;YACjC,MAAM,uBAAA,IAAI,sCAAe,MAAnB,IAAI,EAAgB,SAAS,CAAC,CAAC;YACrC,uBAAA,IAAI,iCAAU,CAAC,SAAS,CAAC,CAAC,WAAW,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;SACpD;IACH,CAAC;IAED;;;OAGG;IACH,KAAK,CAAC,cAAc;QAClB,MAAM,OAAO,CAAC,UAAU,CACtB,MAAM,CAAC,IAAI,CAAC,uBAAA,IAAI,iCAAU,CAAC,CAAC,GAAG,CAAC,KAAK,EAAE,SAAS,EAAE,EAAE;YAClD,MAAM,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;QACtC,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;CAkBF;iQARoB,EAAE,WAAW,EAAE,SAAS,EAAe;IACxD,OAAO;IACL,sBAAsB;IACtB,WAAW,KAAK,CAAC;QACjB,YAAY;QACZ,IAAI,CAAC,GAAG,EAAE,GAAG,WAAW,IAAI,SAAS,CACtC,CAAC;AACJ,CAAC","sourcesContent":["import { Poller } from './Poller';\n\ntype BalanceInfo = {\n lastUpdated: number;\n blockTime: number;\n};\n\nconst BALANCES_TRACKING_INTERVAL = 5000; // Every 5s in milliseconds.\n\nexport class BalancesTracker {\n #poller: Poller;\n\n #updateBalance: (accountId: string) => Promise<void>;\n\n #balances: Record<string, BalanceInfo> = {};\n\n constructor(updateBalanceCallback: (accountId: string) => Promise<void>) {\n this.#updateBalance = updateBalanceCallback;\n\n this.#poller = new Poller(\n () => this.updateBalances(),\n BALANCES_TRACKING_INTERVAL,\n );\n }\n\n /**\n * Starts the tracking process.\n */\n start(): void {\n this.#poller.start();\n }\n\n /**\n * Stops the tracking process.\n */\n stop(): void {\n this.#poller.stop();\n }\n\n /**\n * Checks if an account ID is being tracked.\n *\n * @param accountId - The account ID.\n * @returns True if the account is being tracked, false otherwise.\n */\n isTracked(accountId: string) {\n return Object.prototype.hasOwnProperty.call(this.#balances, accountId);\n }\n\n /**\n * Asserts that an account ID is being tracked.\n *\n * @param accountId - The account ID.\n * @throws If the account ID is not being tracked.\n */\n assertBeingTracked(accountId: string) {\n if (!this.isTracked(accountId)) {\n throw new Error(`Account is not being tracked: ${accountId}`);\n }\n }\n\n /**\n * Starts tracking a new account ID. This method has no effect on already tracked\n * accounts.\n *\n * @param accountId - The account ID.\n * @param blockTime - The block time (used when refreshing the account balances).\n */\n track(accountId: string, blockTime: number) {\n // Do not overwrite current info if already being tracked!\n if (!this.isTracked(accountId)) {\n this.#balances[accountId] = {\n lastUpdated: 0,\n blockTime,\n };\n }\n }\n\n /**\n * Stops tracking a tracked account ID.\n *\n * @param accountId - The account ID.\n * @throws If the account ID is not being tracked.\n */\n untrack(accountId: string) {\n this.assertBeingTracked(accountId);\n delete this.#balances[accountId];\n }\n\n /**\n * Update the balances for a tracked account ID.\n *\n * @param accountId - The account ID.\n * @throws If the account ID is not being tracked.\n */\n async updateBalance(accountId: string) {\n this.assertBeingTracked(accountId);\n\n // We check if the balance is outdated (by comparing to the block time associated\n // with this kind of account).\n //\n // This might not be super accurate, but we could probably compute this differently\n // and try to sync with the \"real block time\"!\n const info = this.#balances[accountId];\n if (this.#isBalanceOutdated(info)) {\n await this.#updateBalance(accountId);\n this.#balances[accountId].lastUpdated = Date.now();\n }\n }\n\n /**\n * Update the balances of all tracked accounts (only if the balances\n * is considered outdated).\n */\n async updateBalances() {\n await Promise.allSettled(\n Object.keys(this.#balances).map(async (accountId) => {\n await this.updateBalance(accountId);\n }),\n );\n }\n\n /**\n * Checks if the balance is outdated according to the provided data.\n *\n * @param param - The balance info.\n * @param param.lastUpdated - The last updated timestamp.\n * @param param.blockTime - The block time.\n * @returns True if the balance is outdated, false otherwise.\n */\n #isBalanceOutdated({ lastUpdated, blockTime }: BalanceInfo): boolean {\n return (\n // Never been updated:\n lastUpdated === 0 ||\n // Outdated:\n Date.now() - lastUpdated >= blockTime\n );\n }\n}\n"]}
@@ -0,0 +1,194 @@
1
+ "use strict";
2
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
3
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
4
+ 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");
5
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
6
+ };
7
+ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
8
+ if (kind === "m") throw new TypeError("Private method is not writable");
9
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
10
+ 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");
11
+ return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
12
+ };
13
+ var _MultichainBalancesController_instances, _MultichainBalancesController_tracker, _MultichainBalancesController_listMultichainAccounts, _MultichainBalancesController_listAccounts, _MultichainBalancesController_getAccount, _MultichainBalancesController_updateBalance, _MultichainBalancesController_isNonEvmAccount, _MultichainBalancesController_handleOnAccountAdded, _MultichainBalancesController_handleOnAccountRemoved, _MultichainBalancesController_getBalances, _MultichainBalancesController_getClient;
14
+ Object.defineProperty(exports, "__esModule", { value: true });
15
+ exports.MultichainBalancesController = exports.getDefaultMultichainBalancesControllerState = void 0;
16
+ const base_controller_1 = require("@metamask/base-controller");
17
+ const keyring_api_1 = require("@metamask/keyring-api");
18
+ const keyring_snap_client_1 = require("@metamask/keyring-snap-client");
19
+ const snaps_utils_1 = require("@metamask/snaps-utils");
20
+ const _1 = require("./index.cjs");
21
+ const utils_1 = require("./utils.cjs");
22
+ const controllerName = 'MultichainBalancesController';
23
+ /**
24
+ * Constructs the default {@link MultichainBalancesController} state. This allows
25
+ * consumers to provide a partial state object when initializing the controller
26
+ * and also helps in constructing complete state objects for this controller in
27
+ * tests.
28
+ *
29
+ * @returns The default {@link MultichainBalancesController} state.
30
+ */
31
+ function getDefaultMultichainBalancesControllerState() {
32
+ return { balances: {} };
33
+ }
34
+ exports.getDefaultMultichainBalancesControllerState = getDefaultMultichainBalancesControllerState;
35
+ /**
36
+ * {@link MultichainBalancesController}'s metadata.
37
+ *
38
+ * This allows us to choose if fields of the state should be persisted or not
39
+ * using the `persist` flag; and if they can be sent to Sentry or not, using
40
+ * the `anonymous` flag.
41
+ */
42
+ const balancesControllerMetadata = {
43
+ balances: {
44
+ persist: true,
45
+ anonymous: false,
46
+ },
47
+ };
48
+ /**
49
+ * The MultichainBalancesController is responsible for fetching and caching account
50
+ * balances.
51
+ */
52
+ class MultichainBalancesController extends base_controller_1.BaseController {
53
+ constructor({ messenger, state = {}, }) {
54
+ super({
55
+ messenger,
56
+ name: controllerName,
57
+ metadata: balancesControllerMetadata,
58
+ state: {
59
+ ...getDefaultMultichainBalancesControllerState(),
60
+ ...state,
61
+ },
62
+ });
63
+ _MultichainBalancesController_instances.add(this);
64
+ _MultichainBalancesController_tracker.set(this, void 0);
65
+ __classPrivateFieldSet(this, _MultichainBalancesController_tracker, new _1.BalancesTracker(async (accountId) => await __classPrivateFieldGet(this, _MultichainBalancesController_instances, "m", _MultichainBalancesController_updateBalance).call(this, accountId)), "f");
66
+ // Register all non-EVM accounts into the tracker
67
+ for (const account of __classPrivateFieldGet(this, _MultichainBalancesController_instances, "m", _MultichainBalancesController_listAccounts).call(this)) {
68
+ if (__classPrivateFieldGet(this, _MultichainBalancesController_instances, "m", _MultichainBalancesController_isNonEvmAccount).call(this, account)) {
69
+ __classPrivateFieldGet(this, _MultichainBalancesController_tracker, "f").track(account.id, (0, utils_1.getBlockTimeForAccount)(account.type));
70
+ }
71
+ }
72
+ this.messagingSystem.subscribe('AccountsController:accountAdded', (account) => __classPrivateFieldGet(this, _MultichainBalancesController_instances, "m", _MultichainBalancesController_handleOnAccountAdded).call(this, account));
73
+ this.messagingSystem.subscribe('AccountsController:accountRemoved', (account) => __classPrivateFieldGet(this, _MultichainBalancesController_instances, "m", _MultichainBalancesController_handleOnAccountRemoved).call(this, account));
74
+ }
75
+ /**
76
+ * Starts the polling process.
77
+ */
78
+ start() {
79
+ __classPrivateFieldGet(this, _MultichainBalancesController_tracker, "f").start();
80
+ }
81
+ /**
82
+ * Stops the polling process.
83
+ */
84
+ stop() {
85
+ __classPrivateFieldGet(this, _MultichainBalancesController_tracker, "f").stop();
86
+ }
87
+ /**
88
+ * Updates the balances of one account. This method doesn't return
89
+ * anything, but it updates the state of the controller.
90
+ *
91
+ * @param accountId - The account ID.
92
+ */
93
+ async updateBalance(accountId) {
94
+ // NOTE: No need to track the account here, since we start tracking those when
95
+ // the "AccountsController:accountAdded" is fired.
96
+ await __classPrivateFieldGet(this, _MultichainBalancesController_tracker, "f").updateBalance(accountId);
97
+ }
98
+ /**
99
+ * Updates the balances of all supported accounts. This method doesn't return
100
+ * anything, but it updates the state of the controller.
101
+ */
102
+ async updateBalances() {
103
+ await __classPrivateFieldGet(this, _MultichainBalancesController_tracker, "f").updateBalances();
104
+ }
105
+ }
106
+ exports.MultichainBalancesController = MultichainBalancesController;
107
+ _MultichainBalancesController_tracker = new WeakMap(), _MultichainBalancesController_instances = new WeakSet(), _MultichainBalancesController_listMultichainAccounts = function _MultichainBalancesController_listMultichainAccounts() {
108
+ return this.messagingSystem.call('AccountsController:listMultichainAccounts');
109
+ }, _MultichainBalancesController_listAccounts = function _MultichainBalancesController_listAccounts() {
110
+ const accounts = __classPrivateFieldGet(this, _MultichainBalancesController_instances, "m", _MultichainBalancesController_listMultichainAccounts).call(this);
111
+ return accounts.filter((account) => __classPrivateFieldGet(this, _MultichainBalancesController_instances, "m", _MultichainBalancesController_isNonEvmAccount).call(this, account));
112
+ }, _MultichainBalancesController_getAccount = function _MultichainBalancesController_getAccount(accountId) {
113
+ const account = __classPrivateFieldGet(this, _MultichainBalancesController_instances, "m", _MultichainBalancesController_listAccounts).call(this).find((multichainAccount) => multichainAccount.id === accountId);
114
+ if (!account) {
115
+ throw new Error(`Unknown account: ${accountId}`);
116
+ }
117
+ return account;
118
+ }, _MultichainBalancesController_updateBalance =
119
+ /**
120
+ * Updates the balances of one account. This method doesn't return
121
+ * anything, but it updates the state of the controller.
122
+ *
123
+ * @param accountId - The account ID.
124
+ */
125
+ async function _MultichainBalancesController_updateBalance(accountId) {
126
+ const account = __classPrivateFieldGet(this, _MultichainBalancesController_instances, "m", _MultichainBalancesController_getAccount).call(this, accountId);
127
+ if (account.metadata.snap) {
128
+ const scope = (0, utils_1.getScopeForAccount)(account);
129
+ const assetTypes = _1.NETWORK_ASSETS_MAP[scope];
130
+ const accountBalance = await __classPrivateFieldGet(this, _MultichainBalancesController_instances, "m", _MultichainBalancesController_getBalances).call(this, account.id, account.metadata.snap.id, assetTypes);
131
+ this.update((state) => {
132
+ state.balances[accountId] = accountBalance;
133
+ });
134
+ }
135
+ }, _MultichainBalancesController_isNonEvmAccount = function _MultichainBalancesController_isNonEvmAccount(account) {
136
+ return (!(0, keyring_api_1.isEvmAccountType)(account.type) &&
137
+ // Non-EVM accounts are backed by a Snap for now
138
+ account.metadata.snap !== undefined);
139
+ }, _MultichainBalancesController_handleOnAccountAdded =
140
+ /**
141
+ * Handles changes when a new account has been added.
142
+ *
143
+ * @param account - The new account being added.
144
+ */
145
+ async function _MultichainBalancesController_handleOnAccountAdded(account) {
146
+ if (!__classPrivateFieldGet(this, _MultichainBalancesController_instances, "m", _MultichainBalancesController_isNonEvmAccount).call(this, account)) {
147
+ // Nothing to do here for EVM accounts
148
+ return;
149
+ }
150
+ __classPrivateFieldGet(this, _MultichainBalancesController_tracker, "f").track(account.id, (0, utils_1.getBlockTimeForAccount)(account.type));
151
+ // NOTE: Unfortunately, we cannot update the balance right away here, because
152
+ // messenger's events are running synchronously and fetching the balance is
153
+ // asynchronous.
154
+ // Updating the balance here would resume at some point but the event emitter
155
+ // will not `await` this (so we have no real control "when" the balance will
156
+ // really be updated), see:
157
+ // - https://github.com/MetaMask/core/blob/v213.0.0/packages/accounts-controller/src/AccountsController.ts#L1036-L1039
158
+ }, _MultichainBalancesController_handleOnAccountRemoved =
159
+ /**
160
+ * Handles changes when a new account has been removed.
161
+ *
162
+ * @param accountId - The account ID being removed.
163
+ */
164
+ async function _MultichainBalancesController_handleOnAccountRemoved(accountId) {
165
+ if (__classPrivateFieldGet(this, _MultichainBalancesController_tracker, "f").isTracked(accountId)) {
166
+ __classPrivateFieldGet(this, _MultichainBalancesController_tracker, "f").untrack(accountId);
167
+ }
168
+ if (accountId in this.state.balances) {
169
+ this.update((state) => {
170
+ delete state.balances[accountId];
171
+ });
172
+ }
173
+ }, _MultichainBalancesController_getBalances =
174
+ /**
175
+ * Get the balances for an account.
176
+ *
177
+ * @param accountId - ID of the account to get balances for.
178
+ * @param snapId - ID of the Snap which manages the account.
179
+ * @param assetTypes - Array of asset types to get balances for.
180
+ * @returns A map of asset types to balances.
181
+ */
182
+ async function _MultichainBalancesController_getBalances(accountId, snapId, assetTypes) {
183
+ return await __classPrivateFieldGet(this, _MultichainBalancesController_instances, "m", _MultichainBalancesController_getClient).call(this, snapId).getAccountBalances(accountId, assetTypes);
184
+ }, _MultichainBalancesController_getClient = function _MultichainBalancesController_getClient(snapId) {
185
+ return new keyring_snap_client_1.KeyringClient({
186
+ send: async (request) => (await this.messagingSystem.call('SnapController:handleRequest', {
187
+ snapId: snapId,
188
+ origin: 'metamask',
189
+ handler: snaps_utils_1.HandlerType.OnKeyringRequest,
190
+ request,
191
+ })),
192
+ });
193
+ };
194
+ //# sourceMappingURL=MultichainBalancesController.cjs.map