@metamask/assets-controllers 32.0.0 → 34.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 (179) hide show
  1. package/CHANGELOG.md +95 -1
  2. package/dist/AccountTrackerController.js +2 -2
  3. package/dist/AccountTrackerController.mjs +1 -1
  4. package/dist/AssetsContractController.js +6 -6
  5. package/dist/AssetsContractController.mjs +5 -5
  6. package/dist/CurrencyRateController.js +3 -3
  7. package/dist/CurrencyRateController.mjs +2 -2
  8. package/dist/NftController.js +3 -3
  9. package/dist/NftController.mjs +2 -2
  10. package/dist/NftDetectionController.js +2 -2
  11. package/dist/NftDetectionController.mjs +1 -1
  12. package/dist/RatesController/RatesController.js +3 -3
  13. package/dist/RatesController/RatesController.mjs +2 -2
  14. package/dist/RatesController/index.js +3 -3
  15. package/dist/RatesController/index.mjs +2 -2
  16. package/dist/Standards/ERC20Standard.js +3 -3
  17. package/dist/Standards/ERC20Standard.mjs +2 -2
  18. package/dist/Standards/NftStandards/ERC1155/ERC1155Standard.js +3 -3
  19. package/dist/Standards/NftStandards/ERC1155/ERC1155Standard.mjs +2 -2
  20. package/dist/Standards/NftStandards/ERC721/ERC721Standard.js +3 -3
  21. package/dist/Standards/NftStandards/ERC721/ERC721Standard.mjs +2 -2
  22. package/dist/TokenBalancesController.js +2 -2
  23. package/dist/TokenBalancesController.mjs +1 -1
  24. package/dist/TokenDetectionController.js +3 -3
  25. package/dist/TokenDetectionController.mjs +2 -2
  26. package/dist/TokenListController.js +4 -4
  27. package/dist/TokenListController.mjs +3 -3
  28. package/dist/TokenRatesController.js +9 -5
  29. package/dist/TokenRatesController.mjs +10 -6
  30. package/dist/TokensController.js +6 -6
  31. package/dist/TokensController.mjs +5 -5
  32. package/dist/assetsUtil.js +2 -2
  33. package/dist/assetsUtil.mjs +1 -1
  34. package/dist/chunk-2IIQTSLV.mjs +236 -0
  35. package/dist/chunk-2IIQTSLV.mjs.map +1 -0
  36. package/dist/{chunk-4AC3X2U5.js → chunk-2NQRWANM.js} +85 -43
  37. package/dist/chunk-2NQRWANM.js.map +1 -0
  38. package/dist/{chunk-MR6EF4B7.mjs → chunk-2TSAUGE7.mjs} +43 -20
  39. package/dist/chunk-2TSAUGE7.mjs.map +1 -0
  40. package/dist/chunk-354SINOH.js +236 -0
  41. package/dist/chunk-354SINOH.js.map +1 -0
  42. package/dist/{chunk-5W5OO2Q5.mjs → chunk-47CRHAUE.mjs} +2 -2
  43. package/dist/chunk-47CRHAUE.mjs.map +1 -0
  44. package/dist/{chunk-73F3SN5O.mjs → chunk-4JLB5OIJ.mjs} +79 -37
  45. package/dist/chunk-4JLB5OIJ.mjs.map +1 -0
  46. package/dist/{chunk-D3K5MPMW.mjs → chunk-56O7BVZV.mjs} +2 -2
  47. package/dist/{chunk-B5YY22QQ.js → chunk-6PPM4ETZ.js} +3 -3
  48. package/dist/{chunk-WCCLSUOI.mjs → chunk-6VQJFTNC.mjs} +4 -4
  49. package/dist/chunk-6VQJFTNC.mjs.map +1 -0
  50. package/dist/{chunk-CGLUTXI7.js → chunk-7JWDWDXT.js} +190 -107
  51. package/dist/chunk-7JWDWDXT.js.map +1 -0
  52. package/dist/{chunk-JUI3XNEF.js → chunk-7OZL6IDY.js} +16 -9
  53. package/dist/chunk-7OZL6IDY.js.map +1 -0
  54. package/dist/{chunk-YIFA2HXH.js → chunk-F6L3DFOZ.js} +5 -3
  55. package/dist/chunk-F6L3DFOZ.js.map +1 -0
  56. package/dist/{chunk-HDI4L2DD.js → chunk-GHKGU6GK.js} +46 -23
  57. package/dist/chunk-GHKGU6GK.js.map +1 -0
  58. package/dist/{chunk-E4ECCGJV.mjs → chunk-GJCTAKK5.mjs} +197 -99
  59. package/dist/chunk-GJCTAKK5.mjs.map +1 -0
  60. package/dist/{chunk-B6W4CQOR.mjs → chunk-HJ5GXVDT.mjs} +2 -2
  61. package/dist/chunk-HJ5GXVDT.mjs.map +1 -0
  62. package/dist/chunk-HVOIBGYN.js +282 -0
  63. package/dist/chunk-HVOIBGYN.js.map +1 -0
  64. package/dist/{chunk-BOTVAG4A.js → chunk-JBF4XEGR.js} +5 -5
  65. package/dist/{chunk-ASA5RLBY.mjs → chunk-JEIAMJGS.mjs} +2 -2
  66. package/dist/{chunk-CNKVITJO.mjs → chunk-JTXPJ6TK.mjs} +4 -2
  67. package/dist/chunk-JTXPJ6TK.mjs.map +1 -0
  68. package/dist/{chunk-U3DJJN4X.js → chunk-LBJTMJFA.js} +4 -4
  69. package/dist/{chunk-IBK6AXPP.js → chunk-NHFZIY2K.js} +4 -4
  70. package/dist/chunk-NHFZIY2K.js.map +1 -0
  71. package/dist/{chunk-NEXY7SE2.js → chunk-NYVA7ZTQ.js} +2 -2
  72. package/dist/chunk-NYVA7ZTQ.js.map +1 -0
  73. package/dist/{chunk-UEDNQBJN.js → chunk-RPQ737HL.js} +202 -104
  74. package/dist/chunk-RPQ737HL.js.map +1 -0
  75. package/dist/{chunk-B5YVX5IO.mjs → chunk-SBWPU4VT.mjs} +4 -2
  76. package/dist/chunk-SBWPU4VT.mjs.map +1 -0
  77. package/dist/{chunk-ELSMS5S7.js → chunk-T5ZX5BV7.js} +3 -3
  78. package/dist/{chunk-ELSMS5S7.js.map → chunk-T5ZX5BV7.js.map} +1 -1
  79. package/dist/{chunk-HLCGZGPA.mjs → chunk-TWR6P5WG.mjs} +11 -7
  80. package/dist/chunk-TWR6P5WG.mjs.map +1 -0
  81. package/dist/{chunk-LZ5ZGQEX.mjs → chunk-UYH6NWKB.mjs} +2 -2
  82. package/dist/{chunk-Z6TBQQE5.js → chunk-V6DNVROD.js} +4 -4
  83. package/dist/chunk-V6DNVROD.js.map +1 -0
  84. package/dist/{chunk-Q5JRBGWO.mjs → chunk-VELPHITE.mjs} +2 -2
  85. package/dist/chunk-VELPHITE.mjs.map +1 -0
  86. package/dist/{chunk-62T7RKU3.mjs → chunk-W57QXOHJ.mjs} +188 -105
  87. package/dist/chunk-W57QXOHJ.mjs.map +1 -0
  88. package/dist/{chunk-PYMUBJQX.js → chunk-X4RMS365.js} +3 -3
  89. package/dist/chunk-X4RMS365.js.map +1 -0
  90. package/dist/{chunk-Y35SM7TO.mjs → chunk-XQO3EG4J.mjs} +4 -4
  91. package/dist/chunk-XQO3EG4J.mjs.map +1 -0
  92. package/dist/{chunk-QHWKLZUC.js → chunk-XSNGD5US.js} +14 -10
  93. package/dist/chunk-XSNGD5US.js.map +1 -0
  94. package/dist/{chunk-A2DDWXMS.mjs → chunk-Y45HQET7.mjs} +12 -5
  95. package/dist/chunk-Y45HQET7.mjs.map +1 -0
  96. package/dist/chunk-Z7RMCHD4.mjs +282 -0
  97. package/dist/chunk-Z7RMCHD4.mjs.map +1 -0
  98. package/dist/{chunk-WB6KJX4N.js → chunk-ZG5MS2TO.js} +4 -2
  99. package/dist/chunk-ZG5MS2TO.js.map +1 -0
  100. package/dist/crypto-compare-service/crypto-compare.js +2 -2
  101. package/dist/crypto-compare-service/crypto-compare.mjs +1 -1
  102. package/dist/crypto-compare-service/index.js +2 -2
  103. package/dist/crypto-compare-service/index.mjs +1 -1
  104. package/dist/index.js +21 -19
  105. package/dist/index.mjs +21 -19
  106. package/dist/token-prices-service/codefi-v2.js +2 -2
  107. package/dist/token-prices-service/codefi-v2.mjs +1 -1
  108. package/dist/token-prices-service/index.js +2 -2
  109. package/dist/token-prices-service/index.mjs +1 -1
  110. package/dist/token-service.js +3 -3
  111. package/dist/token-service.mjs +2 -2
  112. package/dist/tsconfig.build.tsbuildinfo +1 -1
  113. package/dist/types/AccountTrackerController.d.ts +53 -68
  114. package/dist/types/AccountTrackerController.d.ts.map +1 -1
  115. package/dist/types/AssetsContractController.d.ts.map +1 -1
  116. package/dist/types/CurrencyRateController.d.ts.map +1 -1
  117. package/dist/types/NftController.d.ts +4 -5
  118. package/dist/types/NftController.d.ts.map +1 -1
  119. package/dist/types/NftDetectionController.d.ts +7 -18
  120. package/dist/types/NftDetectionController.d.ts.map +1 -1
  121. package/dist/types/RatesController/RatesController.d.ts.map +1 -1
  122. package/dist/types/TokenBalancesController.d.ts +2 -2
  123. package/dist/types/TokenBalancesController.d.ts.map +1 -1
  124. package/dist/types/TokenDetectionController.d.ts +4 -6
  125. package/dist/types/TokenDetectionController.d.ts.map +1 -1
  126. package/dist/types/TokenListController.d.ts.map +1 -1
  127. package/dist/types/TokenRatesController.d.ts +72 -65
  128. package/dist/types/TokenRatesController.d.ts.map +1 -1
  129. package/dist/types/TokensController.d.ts +4 -6
  130. package/dist/types/TokensController.d.ts.map +1 -1
  131. package/dist/types/assetsUtil.d.ts.map +1 -1
  132. package/dist/types/crypto-compare-service/crypto-compare.d.ts.map +1 -1
  133. package/dist/types/index.d.ts +4 -3
  134. package/dist/types/index.d.ts.map +1 -1
  135. package/dist/types/token-prices-service/abstract-token-prices-service.d.ts +0 -1
  136. package/dist/types/token-prices-service/abstract-token-prices-service.d.ts.map +1 -1
  137. package/dist/types/token-prices-service/codefi-v2.d.ts +1 -1
  138. package/dist/types/token-prices-service/codefi-v2.d.ts.map +1 -1
  139. package/dist/types/token-service.d.ts.map +1 -1
  140. package/package.json +5 -5
  141. package/dist/chunk-4AC3X2U5.js.map +0 -1
  142. package/dist/chunk-543CC74T.mjs +0 -253
  143. package/dist/chunk-543CC74T.mjs.map +0 -1
  144. package/dist/chunk-5W5OO2Q5.mjs.map +0 -1
  145. package/dist/chunk-62T7RKU3.mjs.map +0 -1
  146. package/dist/chunk-65PB33TE.mjs +0 -246
  147. package/dist/chunk-65PB33TE.mjs.map +0 -1
  148. package/dist/chunk-73F3SN5O.mjs.map +0 -1
  149. package/dist/chunk-A2DDWXMS.mjs.map +0 -1
  150. package/dist/chunk-B5YVX5IO.mjs.map +0 -1
  151. package/dist/chunk-B6W4CQOR.mjs.map +0 -1
  152. package/dist/chunk-CGLUTXI7.js.map +0 -1
  153. package/dist/chunk-CNKVITJO.mjs.map +0 -1
  154. package/dist/chunk-E4ECCGJV.mjs.map +0 -1
  155. package/dist/chunk-GU53EI7A.js +0 -246
  156. package/dist/chunk-GU53EI7A.js.map +0 -1
  157. package/dist/chunk-HDI4L2DD.js.map +0 -1
  158. package/dist/chunk-HLCGZGPA.mjs.map +0 -1
  159. package/dist/chunk-IBK6AXPP.js.map +0 -1
  160. package/dist/chunk-JUI3XNEF.js.map +0 -1
  161. package/dist/chunk-MR6EF4B7.mjs.map +0 -1
  162. package/dist/chunk-NEXY7SE2.js.map +0 -1
  163. package/dist/chunk-PYMUBJQX.js.map +0 -1
  164. package/dist/chunk-Q5JRBGWO.mjs.map +0 -1
  165. package/dist/chunk-QFDTOEYR.js +0 -253
  166. package/dist/chunk-QFDTOEYR.js.map +0 -1
  167. package/dist/chunk-QHWKLZUC.js.map +0 -1
  168. package/dist/chunk-UEDNQBJN.js.map +0 -1
  169. package/dist/chunk-WB6KJX4N.js.map +0 -1
  170. package/dist/chunk-WCCLSUOI.mjs.map +0 -1
  171. package/dist/chunk-Y35SM7TO.mjs.map +0 -1
  172. package/dist/chunk-YIFA2HXH.js.map +0 -1
  173. package/dist/chunk-Z6TBQQE5.js.map +0 -1
  174. /package/dist/{chunk-D3K5MPMW.mjs.map → chunk-56O7BVZV.mjs.map} +0 -0
  175. /package/dist/{chunk-B5YY22QQ.js.map → chunk-6PPM4ETZ.js.map} +0 -0
  176. /package/dist/{chunk-BOTVAG4A.js.map → chunk-JBF4XEGR.js.map} +0 -0
  177. /package/dist/{chunk-ASA5RLBY.mjs.map → chunk-JEIAMJGS.mjs.map} +0 -0
  178. /package/dist/{chunk-U3DJJN4X.js.map → chunk-LBJTMJFA.js.map} +0 -0
  179. /package/dist/{chunk-LZ5ZGQEX.mjs.map → chunk-UYH6NWKB.mjs.map} +0 -0
@@ -1,13 +1,13 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
2
 
3
- var _chunkZ6TBQQE5js = require('./chunk-Z6TBQQE5.js');
3
+ var _chunkV6DNVRODjs = require('./chunk-V6DNVROD.js');
4
4
 
5
5
 
6
- var _chunkWB6KJX4Njs = require('./chunk-WB6KJX4N.js');
6
+ var _chunkZG5MS2TOjs = require('./chunk-ZG5MS2TO.js');
7
7
 
8
8
 
9
9
 
10
- var _chunkNEXY7SE2js = require('./chunk-NEXY7SE2.js');
10
+ var _chunkNYVA7ZTQjs = require('./chunk-NYVA7ZTQ.js');
11
11
 
12
12
 
13
13
 
@@ -25,13 +25,15 @@ var _controllerutils = require('@metamask/controller-utils');
25
25
  var _pollingcontroller = require('@metamask/polling-controller');
26
26
  var _utils = require('@metamask/utils');
27
27
  var _lodash = require('lodash');
28
+ var DEFAULT_INTERVAL = 18e4;
29
+ var controllerName = "TokenRatesController";
28
30
  async function getCurrencyConversionRate({
29
31
  from,
30
32
  to
31
33
  }) {
32
34
  const includeUSDRate = false;
33
35
  try {
34
- const result = await _chunkWB6KJX4Njs.fetchExchangeRate.call(void 0,
36
+ const result = await _chunkZG5MS2TOjs.fetchExchangeRate.call(void 0,
35
37
  to,
36
38
  from,
37
39
  includeUSDRate
@@ -44,38 +46,42 @@ async function getCurrencyConversionRate({
44
46
  throw error;
45
47
  }
46
48
  }
47
- var _pollState, _tokenPricesService, _inProcessExchangeRateUpdates, _getTokenAddresses, getTokenAddresses_fn, _stopPoll, stopPoll_fn, _poll, poll_fn, _fetchAndMapExchangeRates, fetchAndMapExchangeRates_fn, _fetchAndMapExchangeRatesForSupportedNativeCurrency, fetchAndMapExchangeRatesForSupportedNativeCurrency_fn, _fetchAndMapExchangeRatesForUnsupportedNativeCurrency, fetchAndMapExchangeRatesForUnsupportedNativeCurrency_fn;
48
- var TokenRatesController = class extends _pollingcontroller.StaticIntervalPollingControllerV1 {
49
+ var tokenRatesControllerMetadata = {
50
+ marketData: { persist: true, anonymous: false }
51
+ };
52
+ var getDefaultTokenRatesControllerState = () => {
53
+ return {
54
+ marketData: {}
55
+ };
56
+ };
57
+ var _handle, _pollState, _tokenPricesService, _inProcessExchangeRateUpdates, _selectedAccountId, _disabled, _chainId, _ticker, _interval, _allTokens, _allDetectedTokens, _subscribeToTokensStateChange, subscribeToTokensStateChange_fn, _subscribeToNetworkStateChange, subscribeToNetworkStateChange_fn, _subscribeToAccountChange, subscribeToAccountChange_fn, _getTokenAddresses, getTokenAddresses_fn, _getSelectedAccount, getSelectedAccount_fn, _getChainIdAndTicker, getChainIdAndTicker_fn, _getTokensControllerState, getTokensControllerState_fn, _stopPoll, stopPoll_fn, _poll, poll_fn, _fetchAndMapExchangeRates, fetchAndMapExchangeRates_fn, _fetchAndMapExchangeRatesForSupportedNativeCurrency, fetchAndMapExchangeRatesForSupportedNativeCurrency_fn, _fetchAndMapExchangeRatesForUnsupportedNativeCurrency, fetchAndMapExchangeRatesForUnsupportedNativeCurrency_fn;
58
+ var TokenRatesController = class extends _pollingcontroller.StaticIntervalPollingController {
49
59
  /**
50
60
  * Creates a TokenRatesController instance.
51
61
  *
52
62
  * @param options - The controller options.
53
63
  * @param options.interval - The polling interval in ms
54
- * @param options.threshold - The duration in ms before metadata fetched from CoinGecko is considered stale
55
- * @param options.getNetworkClientById - Gets the network client with the given id from the NetworkController.
56
- * @param options.chainId - The chain ID of the current network.
57
- * @param options.ticker - The ticker for the current network.
58
- * @param options.selectedAddress - The current selected address.
59
- * @param options.onPreferencesStateChange - Allows subscribing to preference controller state changes.
60
- * @param options.onTokensStateChange - Allows subscribing to token controller state changes.
61
- * @param options.onNetworkStateChange - Allows subscribing to network state changes.
62
- * @param options.tokenPricesService - An object in charge of retrieving token prices.
63
- * @param config - Initial options used to configure this controller.
64
- * @param state - Initial state to set on this controller.
64
+ * @param options.disabled - Boolean to track if network requests are blocked
65
+ * @param options.tokenPricesService - An object in charge of retrieving token price
66
+ * @param options.messenger - The controller messenger instance for communication
67
+ * @param options.state - Initial state to set on this controller
65
68
  */
66
69
  constructor({
67
- interval = 3 * 60 * 1e3,
68
- threshold = 6 * 60 * 60 * 1e3,
69
- getNetworkClientById,
70
- chainId: initialChainId,
71
- ticker: initialTicker,
72
- selectedAddress: initialSelectedAddress,
73
- onPreferencesStateChange,
74
- onTokensStateChange,
75
- onNetworkStateChange,
76
- tokenPricesService
77
- }, config, state) {
78
- super(config, state);
70
+ interval = DEFAULT_INTERVAL,
71
+ disabled = false,
72
+ tokenPricesService,
73
+ messenger,
74
+ state
75
+ }) {
76
+ super({
77
+ name: controllerName,
78
+ messenger,
79
+ state: { ...getDefaultTokenRatesControllerState(), ...state },
80
+ metadata: tokenRatesControllerMetadata
81
+ });
82
+ _chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _subscribeToTokensStateChange);
83
+ _chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _subscribeToNetworkStateChange);
84
+ _chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _subscribeToAccountChange);
79
85
  /**
80
86
  * Get the user's tokens for the given chain.
81
87
  *
@@ -83,6 +89,9 @@ var TokenRatesController = class extends _pollingcontroller.StaticIntervalPollin
83
89
  * @returns The list of tokens addresses for the current chain
84
90
  */
85
91
  _chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _getTokenAddresses);
92
+ _chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _getSelectedAccount);
93
+ _chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _getChainIdAndTicker);
94
+ _chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _getTokensControllerState);
86
95
  /**
87
96
  * Clear the active polling timer, if present.
88
97
  */
@@ -138,63 +147,43 @@ var TokenRatesController = class extends _pollingcontroller.StaticIntervalPollin
138
147
  * native currency.
139
148
  */
140
149
  _chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _fetchAndMapExchangeRatesForUnsupportedNativeCurrency);
150
+ _chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _handle, void 0);
141
151
  _chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _pollState, "Inactive" /* Inactive */);
142
152
  _chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _tokenPricesService, void 0);
143
153
  _chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _inProcessExchangeRateUpdates, {});
144
- /**
145
- * Name of this controller used during composition
146
- */
147
- this.name = "TokenRatesController";
148
- this.defaultConfig = {
149
- interval,
150
- threshold,
151
- disabled: false,
152
- nativeCurrency: initialTicker,
153
- chainId: initialChainId,
154
- selectedAddress: initialSelectedAddress,
155
- allTokens: {},
156
- // TODO: initialize these correctly, maybe as part of BaseControllerV2 migration
157
- allDetectedTokens: {}
158
- };
159
- this.defaultState = {
160
- marketData: {}
161
- };
162
- this.initialize();
154
+ _chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _selectedAccountId, void 0);
155
+ _chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _disabled, void 0);
156
+ _chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _chainId, void 0);
157
+ _chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _ticker, void 0);
158
+ _chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _interval, void 0);
159
+ _chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _allTokens, void 0);
160
+ _chunkZ4BLTVTBjs.__privateAdd.call(void 0, this, _allDetectedTokens, void 0);
163
161
  this.setIntervalLength(interval);
164
- this.getNetworkClientById = getNetworkClientById;
165
162
  _chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _tokenPricesService, tokenPricesService);
166
- if (config?.disabled) {
167
- this.configure({ disabled: true }, false, false);
168
- }
169
- onPreferencesStateChange(async ({ selectedAddress }) => {
170
- if (this.config.selectedAddress !== selectedAddress) {
171
- this.configure({ selectedAddress });
172
- if (_chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _pollState) === "Active" /* Active */) {
173
- await this.updateExchangeRates();
174
- }
175
- }
176
- });
177
- onTokensStateChange(async ({ allTokens, allDetectedTokens }) => {
178
- const previousTokenAddresses = _chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _getTokenAddresses, getTokenAddresses_fn).call(this, this.config.chainId);
179
- this.configure({ allTokens, allDetectedTokens });
180
- const newTokenAddresses = _chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _getTokenAddresses, getTokenAddresses_fn).call(this, this.config.chainId);
181
- if (!_lodash.isEqual.call(void 0, previousTokenAddresses, newTokenAddresses) && _chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _pollState) === "Active" /* Active */) {
182
- await this.updateExchangeRates();
183
- }
184
- });
185
- onNetworkStateChange(async ({ selectedNetworkClientId }) => {
186
- const selectedNetworkClient = getNetworkClientById(
187
- selectedNetworkClientId
188
- );
189
- const { chainId, ticker } = selectedNetworkClient.configuration;
190
- if (this.config.chainId !== chainId || this.config.nativeCurrency !== ticker) {
191
- this.update({ ...this.defaultState });
192
- this.configure({ chainId, nativeCurrency: ticker });
193
- if (_chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _pollState) === "Active" /* Active */) {
194
- await this.updateExchangeRates();
195
- }
196
- }
197
- });
163
+ _chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _disabled, disabled);
164
+ _chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _interval, interval);
165
+ const { chainId: currentChainId, ticker: currentTicker } = _chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _getChainIdAndTicker, getChainIdAndTicker_fn).call(this);
166
+ _chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _chainId, currentChainId);
167
+ _chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _ticker, currentTicker);
168
+ _chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _selectedAccountId, _chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _getSelectedAccount, getSelectedAccount_fn).call(this).id);
169
+ const { allTokens, allDetectedTokens } = _chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _getTokensControllerState, getTokensControllerState_fn).call(this);
170
+ _chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _allTokens, allTokens);
171
+ _chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _allDetectedTokens, allDetectedTokens);
172
+ _chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _subscribeToTokensStateChange, subscribeToTokensStateChange_fn).call(this);
173
+ _chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _subscribeToNetworkStateChange, subscribeToNetworkStateChange_fn).call(this);
174
+ _chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _subscribeToAccountChange, subscribeToAccountChange_fn).call(this);
175
+ }
176
+ /**
177
+ * Allows controller to make active and passive polling requests
178
+ */
179
+ enable() {
180
+ _chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _disabled, false);
181
+ }
182
+ /**
183
+ * Blocks controller from making network calls
184
+ */
185
+ disable() {
186
+ _chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _disabled, true);
198
187
  }
199
188
  /**
200
189
  * Start (or restart) polling.
@@ -215,10 +204,9 @@ var TokenRatesController = class extends _pollingcontroller.StaticIntervalPollin
215
204
  * Updates exchange rates for all tokens.
216
205
  */
217
206
  async updateExchangeRates() {
218
- const { chainId, nativeCurrency } = this.config;
219
207
  await this.updateExchangeRatesByChainId({
220
- chainId,
221
- nativeCurrency
208
+ chainId: _chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _chainId),
209
+ nativeCurrency: _chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _ticker)
222
210
  });
223
211
  }
224
212
  /**
@@ -232,7 +220,7 @@ var TokenRatesController = class extends _pollingcontroller.StaticIntervalPollin
232
220
  chainId,
233
221
  nativeCurrency
234
222
  }) {
235
- if (this.disabled) {
223
+ if (_chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _disabled)) {
236
224
  return;
237
225
  }
238
226
  const tokenAddresses = _chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _getTokenAddresses, getTokenAddresses_fn).call(this, chainId);
@@ -258,8 +246,8 @@ var TokenRatesController = class extends _pollingcontroller.StaticIntervalPollin
258
246
  ...contractInformations ?? {}
259
247
  }
260
248
  };
261
- this.update({
262
- marketData
249
+ this.update((state) => {
250
+ state.marketData = marketData;
263
251
  });
264
252
  updateSucceeded();
265
253
  } catch (error) {
@@ -276,21 +264,98 @@ var TokenRatesController = class extends _pollingcontroller.StaticIntervalPollin
276
264
  * @returns The controller state.
277
265
  */
278
266
  async _executePoll(networkClientId) {
279
- const networkClient = this.getNetworkClientById(networkClientId);
267
+ const networkClient = this.messagingSystem.call(
268
+ "NetworkController:getNetworkClientById",
269
+ networkClientId
270
+ );
280
271
  await this.updateExchangeRatesByChainId({
281
272
  chainId: networkClient.configuration.chainId,
282
273
  nativeCurrency: networkClient.configuration.ticker
283
274
  });
284
275
  }
285
276
  };
277
+ _handle = new WeakMap();
286
278
  _pollState = new WeakMap();
287
279
  _tokenPricesService = new WeakMap();
288
280
  _inProcessExchangeRateUpdates = new WeakMap();
281
+ _selectedAccountId = new WeakMap();
282
+ _disabled = new WeakMap();
283
+ _chainId = new WeakMap();
284
+ _ticker = new WeakMap();
285
+ _interval = new WeakMap();
286
+ _allTokens = new WeakMap();
287
+ _allDetectedTokens = new WeakMap();
288
+ _subscribeToTokensStateChange = new WeakSet();
289
+ subscribeToTokensStateChange_fn = function() {
290
+ this.messagingSystem.subscribe(
291
+ "TokensController:stateChange",
292
+ // TODO: Either fix this lint violation or explain why it's necessary to ignore.
293
+ // eslint-disable-next-line @typescript-eslint/no-misused-promises
294
+ async ({ allTokens, allDetectedTokens }) => {
295
+ const previousTokenAddresses = _chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _getTokenAddresses, getTokenAddresses_fn).call(this, _chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _chainId));
296
+ _chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _allTokens, allTokens);
297
+ _chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _allDetectedTokens, allDetectedTokens);
298
+ const newTokenAddresses = _chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _getTokenAddresses, getTokenAddresses_fn).call(this, _chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _chainId));
299
+ if (!_lodash.isEqual.call(void 0, previousTokenAddresses, newTokenAddresses) && _chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _pollState) === "Active" /* Active */) {
300
+ await this.updateExchangeRates();
301
+ }
302
+ },
303
+ ({ allTokens, allDetectedTokens }) => {
304
+ return { allTokens, allDetectedTokens };
305
+ }
306
+ );
307
+ };
308
+ _subscribeToNetworkStateChange = new WeakSet();
309
+ subscribeToNetworkStateChange_fn = function() {
310
+ this.messagingSystem.subscribe(
311
+ "NetworkController:stateChange",
312
+ // TODO: Either fix this lint violation or explain why it's necessary to ignore.
313
+ // eslint-disable-next-line @typescript-eslint/no-misused-promises
314
+ async ({ selectedNetworkClientId }) => {
315
+ const {
316
+ configuration: { chainId, ticker }
317
+ } = this.messagingSystem.call(
318
+ "NetworkController:getNetworkClientById",
319
+ selectedNetworkClientId
320
+ );
321
+ if (_chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _chainId) !== chainId || _chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _ticker) !== ticker) {
322
+ this.update((state) => {
323
+ state.marketData = {};
324
+ });
325
+ _chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _chainId, chainId);
326
+ _chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _ticker, ticker);
327
+ if (_chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _pollState) === "Active" /* Active */) {
328
+ await this.updateExchangeRates();
329
+ }
330
+ }
331
+ }
332
+ );
333
+ };
334
+ _subscribeToAccountChange = new WeakSet();
335
+ subscribeToAccountChange_fn = function() {
336
+ this.messagingSystem.subscribe(
337
+ "AccountsController:selectedEvmAccountChange",
338
+ // TODO: Either fix this lint violation or explain why it's necessary to ignore.
339
+ // eslint-disable-next-line @typescript-eslint/no-misused-promises
340
+ async (selectedAccount) => {
341
+ if (_chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _selectedAccountId) !== selectedAccount.id) {
342
+ _chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _selectedAccountId, selectedAccount.id);
343
+ if (_chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _pollState) === "Active" /* Active */) {
344
+ await this.updateExchangeRates();
345
+ }
346
+ }
347
+ }
348
+ );
349
+ };
289
350
  _getTokenAddresses = new WeakSet();
290
351
  getTokenAddresses_fn = function(chainId) {
291
- const { allTokens, allDetectedTokens } = this.config;
292
- const tokens = allTokens[chainId]?.[this.config.selectedAddress] || [];
293
- const detectedTokens = allDetectedTokens[chainId]?.[this.config.selectedAddress] || [];
352
+ const selectedAccount = this.messagingSystem.call(
353
+ "AccountsController:getAccount",
354
+ _chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _selectedAccountId)
355
+ );
356
+ const selectedAddress = selectedAccount?.address ?? "";
357
+ const tokens = _chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _allTokens)[chainId]?.[selectedAddress] || [];
358
+ const detectedTokens = _chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _allDetectedTokens)[chainId]?.[selectedAddress] || [];
294
359
  return [
295
360
  ...new Set(
296
361
  [...tokens, ...detectedTokens].map(
@@ -299,18 +364,49 @@ getTokenAddresses_fn = function(chainId) {
299
364
  )
300
365
  ].sort();
301
366
  };
367
+ _getSelectedAccount = new WeakSet();
368
+ getSelectedAccount_fn = function() {
369
+ const selectedAccount = this.messagingSystem.call(
370
+ "AccountsController:getSelectedAccount"
371
+ );
372
+ return selectedAccount;
373
+ };
374
+ _getChainIdAndTicker = new WeakSet();
375
+ getChainIdAndTicker_fn = function() {
376
+ const { selectedNetworkClientId } = this.messagingSystem.call(
377
+ "NetworkController:getState"
378
+ );
379
+ const networkClient = this.messagingSystem.call(
380
+ "NetworkController:getNetworkClientById",
381
+ selectedNetworkClientId
382
+ );
383
+ return {
384
+ chainId: networkClient.configuration.chainId,
385
+ ticker: networkClient.configuration.ticker
386
+ };
387
+ };
388
+ _getTokensControllerState = new WeakSet();
389
+ getTokensControllerState_fn = function() {
390
+ const { allTokens, allDetectedTokens } = this.messagingSystem.call(
391
+ "TokensController:getState"
392
+ );
393
+ return {
394
+ allTokens,
395
+ allDetectedTokens
396
+ };
397
+ };
302
398
  _stopPoll = new WeakSet();
303
399
  stopPoll_fn = function() {
304
- if (this.handle) {
305
- clearTimeout(this.handle);
400
+ if (_chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _handle)) {
401
+ clearTimeout(_chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _handle));
306
402
  }
307
403
  };
308
404
  _poll = new WeakSet();
309
405
  poll_fn = async function() {
310
406
  await _controllerutils.safelyExecute.call(void 0, () => this.updateExchangeRates());
311
- this.handle = setTimeout(() => {
407
+ _chunkZ4BLTVTBjs.__privateSet.call(void 0, this, _handle, setTimeout(() => {
312
408
  _chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _poll, poll_fn).call(this);
313
- }, this.config.interval);
409
+ }, _chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _interval)));
314
410
  };
315
411
  _fetchAndMapExchangeRates = new WeakSet();
316
412
  fetchAndMapExchangeRates_fn = async function({
@@ -346,9 +442,9 @@ fetchAndMapExchangeRatesForSupportedNativeCurrency_fn = async function({
346
442
  nativeCurrency
347
443
  }) {
348
444
  let contractNativeInformations;
349
- const tokenPricesByTokenAddress = await _chunkNEXY7SE2js.reduceInBatchesSerially.call(void 0, {
445
+ const tokenPricesByTokenAddress = await _chunkNYVA7ZTQjs.reduceInBatchesSerially.call(void 0, {
350
446
  values: [...tokenAddresses].sort(),
351
- batchSize: _chunkNEXY7SE2js.TOKEN_PRICES_BATCH_SIZE,
447
+ batchSize: _chunkNYVA7ZTQjs.TOKEN_PRICES_BATCH_SIZE,
352
448
  eachBatch: async (allTokenPricesByTokenAddress, batch) => {
353
449
  const tokenPricesByTokenAddressForBatch = await _chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _tokenPricesService).fetchTokenPrices({
354
450
  tokenAddresses: batch,
@@ -370,9 +466,9 @@ fetchAndMapExchangeRatesForSupportedNativeCurrency_fn = async function({
370
466
  currency: nativeCurrency
371
467
  });
372
468
  contractNativeInformations = {
373
- [_chunkZ6TBQQE5js.ZERO_ADDRESS]: {
469
+ [_chunkV6DNVRODjs.ZERO_ADDRESS]: {
374
470
  currency: nativeCurrency,
375
- ...contractNativeInformationsNative[_chunkZ6TBQQE5js.ZERO_ADDRESS]
471
+ ...contractNativeInformationsNative[_chunkV6DNVRODjs.ZERO_ADDRESS]
376
472
  }
377
473
  };
378
474
  }
@@ -380,7 +476,7 @@ fetchAndMapExchangeRatesForSupportedNativeCurrency_fn = async function({
380
476
  (obj, [tokenAddress, token]) => {
381
477
  obj = {
382
478
  ...obj,
383
- [tokenAddress.toLowerCase()]: { ...token }
479
+ [tokenAddress]: { ...token }
384
480
  };
385
481
  return obj;
386
482
  },
@@ -398,7 +494,7 @@ fetchAndMapExchangeRatesForUnsupportedNativeCurrency_fn = async function({
398
494
  ] = await Promise.all([
399
495
  _chunkZ4BLTVTBjs.__privateMethod.call(void 0, this, _fetchAndMapExchangeRatesForSupportedNativeCurrency, fetchAndMapExchangeRatesForSupportedNativeCurrency_fn).call(this, {
400
496
  tokenAddresses,
401
- chainId: this.config.chainId,
497
+ chainId: _chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _chainId),
402
498
  nativeCurrency: _controllerutils.FALL_BACK_VS_CURRENCY
403
499
  }),
404
500
  getCurrencyConversionRate({
@@ -416,7 +512,7 @@ fetchAndMapExchangeRatesForUnsupportedNativeCurrency_fn = async function({
416
512
  ...acc,
417
513
  [tokenAddress]: {
418
514
  ...token,
419
- value: token.value ? token.value * fallbackCurrencyToNativeCurrencyConversionRate : void 0
515
+ price: token.price ? token.price * fallbackCurrencyToNativeCurrencyConversionRate : void 0
420
516
  }
421
517
  };
422
518
  return acc;
@@ -428,5 +524,7 @@ var TokenRatesController_default = TokenRatesController;
428
524
 
429
525
 
430
526
 
431
- exports.TokenRatesController = TokenRatesController; exports.TokenRatesController_default = TokenRatesController_default;
432
- //# sourceMappingURL=chunk-UEDNQBJN.js.map
527
+
528
+
529
+ exports.controllerName = controllerName; exports.getDefaultTokenRatesControllerState = getDefaultTokenRatesControllerState; exports.TokenRatesController = TokenRatesController; exports.TokenRatesController_default = TokenRatesController_default;
530
+ //# sourceMappingURL=chunk-RPQ737HL.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/TokenRatesController.ts"],"names":[],"mappings":"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","sourcesContent":["import type {\n AccountsControllerGetAccountAction,\n AccountsControllerGetSelectedAccountAction,\n AccountsControllerSelectedEvmAccountChangeEvent,\n} from '@metamask/accounts-controller';\nimport type {\n ControllerGetStateAction,\n ControllerStateChangeEvent,\n RestrictedControllerMessenger,\n} from '@metamask/base-controller';\nimport {\n safelyExecute,\n toChecksumHexAddress,\n FALL_BACK_VS_CURRENCY,\n toHex,\n} from '@metamask/controller-utils';\nimport type { InternalAccount } from '@metamask/keyring-api';\nimport type {\n NetworkClientId,\n NetworkControllerGetNetworkClientByIdAction,\n NetworkControllerGetStateAction,\n NetworkControllerStateChangeEvent,\n} from '@metamask/network-controller';\nimport { StaticIntervalPollingController } from '@metamask/polling-controller';\nimport { createDeferredPromise, type Hex } from '@metamask/utils';\nimport { isEqual } from 'lodash';\n\nimport { reduceInBatchesSerially, TOKEN_PRICES_BATCH_SIZE } from './assetsUtil';\nimport { fetchExchangeRate as fetchNativeCurrencyExchangeRate } from './crypto-compare-service';\nimport type { AbstractTokenPricesService } from './token-prices-service/abstract-token-prices-service';\nimport { ZERO_ADDRESS } from './token-prices-service/codefi-v2';\nimport type {\n TokensControllerGetStateAction,\n TokensControllerStateChangeEvent,\n TokensControllerState,\n} from './TokensController';\n\n/**\n * @type Token\n *\n * Token representation\n * @property address - Hex address of the token contract\n * @property decimals - Number of decimals the token uses\n * @property symbol - Symbol of the token\n * @property aggregators - An array containing the token's aggregators\n * @property image - Image of the token, url or bit32 image\n * @property hasBalanceError - 'true' if there is an error while updating the token balance\n * @property isERC721 - 'true' if the token is a ERC721 token\n * @property name - Name of the token\n */\nexport type Token = {\n address: string;\n decimals: number;\n symbol: string;\n aggregators?: string[];\n image?: string;\n hasBalanceError?: boolean;\n isERC721?: boolean;\n name?: string;\n};\n\nconst DEFAULT_INTERVAL = 180000;\n\nexport type ContractExchangeRates = {\n [address: string]: number | undefined;\n};\n\ntype MarketDataDetails = {\n tokenAddress: `0x${string}`;\n currency: string;\n allTimeHigh: number;\n allTimeLow: number;\n circulatingSupply: number;\n dilutedMarketCap: number;\n high1d: number;\n low1d: number;\n marketCap: number;\n marketCapPercentChange1d: number;\n price: number;\n priceChange1d: number;\n pricePercentChange1d: number;\n pricePercentChange1h: number;\n pricePercentChange1y: number;\n pricePercentChange7d: number;\n pricePercentChange14d: number;\n pricePercentChange30d: number;\n pricePercentChange200d: number;\n totalVolume: number;\n};\n\n/**\n * Represents a mapping of token contract addresses to their market data.\n */\nexport type ContractMarketData = Record<Hex, MarketDataDetails>;\n\nenum PollState {\n Active = 'Active',\n Inactive = 'Inactive',\n}\n\n/**\n * The external actions available to the {@link TokenRatesController}.\n */\nexport type AllowedActions =\n | TokensControllerGetStateAction\n | NetworkControllerGetNetworkClientByIdAction\n | NetworkControllerGetStateAction\n | AccountsControllerGetAccountAction\n | AccountsControllerGetSelectedAccountAction;\n\n/**\n * The external events available to the {@link TokenRatesController}.\n */\nexport type AllowedEvents =\n | TokensControllerStateChangeEvent\n | NetworkControllerStateChangeEvent\n | AccountsControllerSelectedEvmAccountChangeEvent;\n\n/**\n * The name of the {@link TokenRatesController}.\n */\nexport const controllerName = 'TokenRatesController';\n\n/**\n * @type TokenRatesState\n *\n * Token rates controller state\n * @property marketData - Market data for tokens, keyed by chain ID and then token contract address.\n */\nexport type TokenRatesControllerState = {\n marketData: Record<Hex, Record<Hex, MarketDataDetails>>;\n};\n\n/**\n * The action that can be performed to get the state of the {@link TokenRatesController}.\n */\nexport type TokenRatesControllerGetStateAction = ControllerGetStateAction<\n typeof controllerName,\n TokenRatesControllerState\n>;\n\n/**\n * The actions that can be performed using the {@link TokenRatesController}.\n */\nexport type TokenRatesControllerActions = TokenRatesControllerGetStateAction;\n\n/**\n * The event that {@link TokenRatesController} can emit.\n */\nexport type TokenRatesControllerStateChangeEvent = ControllerStateChangeEvent<\n typeof controllerName,\n TokenRatesControllerState\n>;\n\n/**\n * The events that {@link TokenRatesController} can emit.\n */\nexport type TokenRatesControllerEvents = TokenRatesControllerStateChangeEvent;\n\n/**\n * The messenger of the {@link TokenRatesController} for communication.\n */\nexport type TokenRatesControllerMessenger = RestrictedControllerMessenger<\n typeof controllerName,\n TokenRatesControllerActions | AllowedActions,\n TokenRatesControllerEvents | AllowedEvents,\n AllowedActions['type'],\n AllowedEvents['type']\n>;\n\n/**\n * Uses the CryptoCompare API to fetch the exchange rate between one currency\n * and another, i.e., the multiplier to apply the amount of one currency in\n * order to convert it to another.\n *\n * @param args - The arguments to this function.\n * @param args.from - The currency to convert from.\n * @param args.to - The currency to convert to.\n * @returns The exchange rate between `fromCurrency` to `toCurrency` if one\n * exists, or null if one does not.\n */\nasync function getCurrencyConversionRate({\n from,\n to,\n}: {\n from: string;\n to: string;\n}) {\n const includeUSDRate = false;\n try {\n const result = await fetchNativeCurrencyExchangeRate(\n to,\n from,\n includeUSDRate,\n );\n return result.conversionRate;\n } catch (error) {\n if (\n error instanceof Error &&\n error.message.includes('market does not exist for this coin pair')\n ) {\n return null;\n }\n throw error;\n }\n}\n\nconst tokenRatesControllerMetadata = {\n marketData: { persist: true, anonymous: false },\n};\n\n/**\n * Get the default {@link TokenRatesController} state.\n *\n * @returns The default {@link TokenRatesController} state.\n */\nexport const getDefaultTokenRatesControllerState =\n (): TokenRatesControllerState => {\n return {\n marketData: {},\n };\n };\n\n/**\n * Controller that passively polls on a set interval for token-to-fiat exchange rates\n * for tokens stored in the TokensController\n */\nexport class TokenRatesController extends StaticIntervalPollingController<\n typeof controllerName,\n TokenRatesControllerState,\n TokenRatesControllerMessenger\n> {\n #handle?: ReturnType<typeof setTimeout>;\n\n #pollState = PollState.Inactive;\n\n #tokenPricesService: AbstractTokenPricesService;\n\n #inProcessExchangeRateUpdates: Record<`${Hex}:${string}`, Promise<void>> = {};\n\n #selectedAccountId: string;\n\n #disabled: boolean;\n\n #chainId: Hex;\n\n #ticker: string;\n\n #interval: number;\n\n #allTokens: TokensControllerState['allTokens'];\n\n #allDetectedTokens: TokensControllerState['allDetectedTokens'];\n\n /**\n * Creates a TokenRatesController instance.\n *\n * @param options - The controller options.\n * @param options.interval - The polling interval in ms\n * @param options.disabled - Boolean to track if network requests are blocked\n * @param options.tokenPricesService - An object in charge of retrieving token price\n * @param options.messenger - The controller messenger instance for communication\n * @param options.state - Initial state to set on this controller\n */\n constructor({\n interval = DEFAULT_INTERVAL,\n disabled = false,\n tokenPricesService,\n messenger,\n state,\n }: {\n interval?: number;\n disabled?: boolean;\n tokenPricesService: AbstractTokenPricesService;\n messenger: TokenRatesControllerMessenger;\n state?: Partial<TokenRatesControllerState>;\n }) {\n super({\n name: controllerName,\n messenger,\n state: { ...getDefaultTokenRatesControllerState(), ...state },\n metadata: tokenRatesControllerMetadata,\n });\n\n this.setIntervalLength(interval);\n this.#tokenPricesService = tokenPricesService;\n this.#disabled = disabled;\n this.#interval = interval;\n\n const { chainId: currentChainId, ticker: currentTicker } =\n this.#getChainIdAndTicker();\n this.#chainId = currentChainId;\n this.#ticker = currentTicker;\n\n this.#selectedAccountId = this.#getSelectedAccount().id;\n\n const { allTokens, allDetectedTokens } = this.#getTokensControllerState();\n this.#allTokens = allTokens;\n this.#allDetectedTokens = allDetectedTokens;\n\n this.#subscribeToTokensStateChange();\n\n this.#subscribeToNetworkStateChange();\n\n this.#subscribeToAccountChange();\n }\n\n #subscribeToTokensStateChange() {\n this.messagingSystem.subscribe(\n 'TokensController:stateChange',\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/no-misused-promises\n async ({ allTokens, allDetectedTokens }) => {\n const previousTokenAddresses = this.#getTokenAddresses(this.#chainId);\n this.#allTokens = allTokens;\n this.#allDetectedTokens = allDetectedTokens;\n\n const newTokenAddresses = this.#getTokenAddresses(this.#chainId);\n if (\n !isEqual(previousTokenAddresses, newTokenAddresses) &&\n this.#pollState === PollState.Active\n ) {\n await this.updateExchangeRates();\n }\n },\n ({ allTokens, allDetectedTokens }) => {\n return { allTokens, allDetectedTokens };\n },\n );\n }\n\n #subscribeToNetworkStateChange() {\n this.messagingSystem.subscribe(\n 'NetworkController:stateChange',\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/no-misused-promises\n async ({ selectedNetworkClientId }) => {\n const {\n configuration: { chainId, ticker },\n } = this.messagingSystem.call(\n 'NetworkController:getNetworkClientById',\n selectedNetworkClientId,\n );\n\n if (this.#chainId !== chainId || this.#ticker !== ticker) {\n this.update((state) => {\n state.marketData = {};\n });\n this.#chainId = chainId;\n this.#ticker = ticker;\n if (this.#pollState === PollState.Active) {\n await this.updateExchangeRates();\n }\n }\n },\n );\n }\n\n #subscribeToAccountChange() {\n this.messagingSystem.subscribe(\n 'AccountsController:selectedEvmAccountChange',\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/no-misused-promises\n async (selectedAccount) => {\n if (this.#selectedAccountId !== selectedAccount.id) {\n this.#selectedAccountId = selectedAccount.id;\n if (this.#pollState === PollState.Active) {\n await this.updateExchangeRates();\n }\n }\n },\n );\n }\n\n /**\n * Get the user's tokens for the given chain.\n *\n * @param chainId - The chain ID.\n * @returns The list of tokens addresses for the current chain\n */\n #getTokenAddresses(chainId: Hex): Hex[] {\n const selectedAccount = this.messagingSystem.call(\n 'AccountsController:getAccount',\n this.#selectedAccountId,\n );\n const selectedAddress = selectedAccount?.address ?? '';\n const tokens = this.#allTokens[chainId]?.[selectedAddress] || [];\n const detectedTokens =\n this.#allDetectedTokens[chainId]?.[selectedAddress] || [];\n\n return [\n ...new Set(\n [...tokens, ...detectedTokens].map((token) =>\n toHex(toChecksumHexAddress(token.address)),\n ),\n ),\n ].sort();\n }\n\n /**\n * Allows controller to make active and passive polling requests\n */\n enable(): void {\n this.#disabled = false;\n }\n\n /**\n * Blocks controller from making network calls\n */\n disable(): void {\n this.#disabled = true;\n }\n\n /**\n * Start (or restart) polling.\n */\n async start() {\n this.#stopPoll();\n this.#pollState = PollState.Active;\n await this.#poll();\n }\n\n /**\n * Stop polling.\n */\n stop() {\n this.#stopPoll();\n this.#pollState = PollState.Inactive;\n }\n\n #getSelectedAccount(): InternalAccount {\n const selectedAccount = this.messagingSystem.call(\n 'AccountsController:getSelectedAccount',\n );\n\n return selectedAccount;\n }\n\n #getChainIdAndTicker(): {\n chainId: Hex;\n ticker: string;\n } {\n const { selectedNetworkClientId } = this.messagingSystem.call(\n 'NetworkController:getState',\n );\n const networkClient = this.messagingSystem.call(\n 'NetworkController:getNetworkClientById',\n selectedNetworkClientId,\n );\n return {\n chainId: networkClient.configuration.chainId,\n ticker: networkClient.configuration.ticker,\n };\n }\n\n #getTokensControllerState(): {\n allTokens: TokensControllerState['allTokens'];\n allDetectedTokens: TokensControllerState['allDetectedTokens'];\n } {\n const { allTokens, allDetectedTokens } = this.messagingSystem.call(\n 'TokensController:getState',\n );\n\n return {\n allTokens,\n allDetectedTokens,\n };\n }\n\n /**\n * Clear the active polling timer, if present.\n */\n #stopPoll() {\n if (this.#handle) {\n clearTimeout(this.#handle);\n }\n }\n\n /**\n * Poll for exchange rate updates.\n */\n async #poll() {\n await safelyExecute(() => this.updateExchangeRates());\n\n // Poll using recursive `setTimeout` instead of `setInterval` so that\n // requests don't stack if they take longer than the polling interval\n this.#handle = setTimeout(() => {\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/no-floating-promises\n this.#poll();\n }, this.#interval);\n }\n\n /**\n * Updates exchange rates for all tokens.\n */\n async updateExchangeRates() {\n await this.updateExchangeRatesByChainId({\n chainId: this.#chainId,\n nativeCurrency: this.#ticker,\n });\n }\n\n /**\n * Updates exchange rates for all tokens.\n *\n * @param options - The options to fetch exchange rates.\n * @param options.chainId - The chain ID.\n * @param options.nativeCurrency - The ticker for the chain.\n */\n async updateExchangeRatesByChainId({\n chainId,\n nativeCurrency,\n }: {\n chainId: Hex;\n nativeCurrency: string;\n }) {\n if (this.#disabled) {\n return;\n }\n\n const tokenAddresses = this.#getTokenAddresses(chainId);\n\n const updateKey: `${Hex}:${string}` = `${chainId}:${nativeCurrency}`;\n if (updateKey in this.#inProcessExchangeRateUpdates) {\n // This prevents redundant updates\n // This promise is resolved after the in-progress update has finished,\n // and state has been updated.\n await this.#inProcessExchangeRateUpdates[updateKey];\n return;\n }\n\n const {\n promise: inProgressUpdate,\n resolve: updateSucceeded,\n reject: updateFailed,\n } = createDeferredPromise({ suppressUnhandledRejection: true });\n this.#inProcessExchangeRateUpdates[updateKey] = inProgressUpdate;\n\n try {\n const contractInformations = await this.#fetchAndMapExchangeRates({\n tokenAddresses,\n chainId,\n nativeCurrency,\n });\n\n const marketData = {\n [chainId]: {\n ...(contractInformations ?? {}),\n },\n };\n\n this.update((state) => {\n state.marketData = marketData;\n });\n updateSucceeded();\n } catch (error: unknown) {\n updateFailed(error);\n throw error;\n } finally {\n delete this.#inProcessExchangeRateUpdates[updateKey];\n }\n }\n\n /**\n * Uses the token prices service to retrieve exchange rates for tokens in a\n * particular currency.\n *\n * If the price API does not support the given chain ID, returns an empty\n * object.\n *\n * If the price API does not support the given currency, retrieves exchange\n * rates in a known currency instead, then converts those rates using the\n * exchange rate between the known currency and desired currency.\n *\n * @param args - The arguments to this function.\n * @param args.tokenAddresses - Addresses for tokens.\n * @param args.chainId - The EIP-155 ID of the chain where the tokens live.\n * @param args.nativeCurrency - The native currency in which to request\n * exchange rates.\n * @returns A map from token address to its exchange rate in the native\n * currency, or an empty map if no exchange rates can be obtained for the\n * chain ID.\n */\n async #fetchAndMapExchangeRates({\n tokenAddresses,\n chainId,\n nativeCurrency,\n }: {\n tokenAddresses: Hex[];\n chainId: Hex;\n nativeCurrency: string;\n }): Promise<ContractMarketData> {\n if (!this.#tokenPricesService.validateChainIdSupported(chainId)) {\n return tokenAddresses.reduce((obj, tokenAddress) => {\n obj = {\n ...obj,\n [tokenAddress]: undefined,\n };\n\n return obj;\n }, {});\n }\n\n if (this.#tokenPricesService.validateCurrencySupported(nativeCurrency)) {\n return await this.#fetchAndMapExchangeRatesForSupportedNativeCurrency({\n tokenAddresses,\n chainId,\n nativeCurrency,\n });\n }\n\n return await this.#fetchAndMapExchangeRatesForUnsupportedNativeCurrency({\n tokenAddresses,\n nativeCurrency,\n });\n }\n\n /**\n * Updates token rates for the given networkClientId\n *\n * @param networkClientId - The network client ID used to get a ticker value.\n * @returns The controller state.\n */\n async _executePoll(networkClientId: NetworkClientId): Promise<void> {\n const networkClient = this.messagingSystem.call(\n 'NetworkController:getNetworkClientById',\n networkClientId,\n );\n await this.updateExchangeRatesByChainId({\n chainId: networkClient.configuration.chainId,\n nativeCurrency: networkClient.configuration.ticker,\n });\n }\n\n /**\n * Retrieves prices in the given currency for the given tokens on the given\n * chain. Ensures that token addresses are checksum addresses.\n *\n * @param args - The arguments to this function.\n * @param args.tokenAddresses - Addresses for tokens.\n * @param args.chainId - The EIP-155 ID of the chain where the tokens live.\n * @param args.nativeCurrency - The native currency in which to request\n * prices.\n * @returns A map of the token addresses (as checksums) to their prices in the\n * native currency.\n */\n async #fetchAndMapExchangeRatesForSupportedNativeCurrency({\n tokenAddresses,\n chainId,\n nativeCurrency,\n }: {\n tokenAddresses: Hex[];\n chainId: Hex;\n nativeCurrency: string;\n }): Promise<ContractMarketData> {\n let contractNativeInformations;\n const tokenPricesByTokenAddress = await reduceInBatchesSerially<\n Hex,\n Awaited<ReturnType<AbstractTokenPricesService['fetchTokenPrices']>>\n >({\n values: [...tokenAddresses].sort(),\n batchSize: TOKEN_PRICES_BATCH_SIZE,\n eachBatch: async (allTokenPricesByTokenAddress, batch) => {\n const tokenPricesByTokenAddressForBatch =\n await this.#tokenPricesService.fetchTokenPrices({\n tokenAddresses: batch,\n chainId,\n currency: nativeCurrency,\n });\n\n return {\n ...allTokenPricesByTokenAddress,\n ...tokenPricesByTokenAddressForBatch,\n };\n },\n initialResult: {},\n });\n contractNativeInformations = tokenPricesByTokenAddress;\n\n // fetch for native token\n if (tokenAddresses.length === 0) {\n const contractNativeInformationsNative =\n await this.#tokenPricesService.fetchTokenPrices({\n tokenAddresses: [],\n chainId,\n currency: nativeCurrency,\n });\n\n contractNativeInformations = {\n [ZERO_ADDRESS]: {\n currency: nativeCurrency,\n ...contractNativeInformationsNative[ZERO_ADDRESS],\n },\n };\n }\n return Object.entries(contractNativeInformations).reduce(\n (obj, [tokenAddress, token]) => {\n obj = {\n ...obj,\n [tokenAddress]: { ...token },\n };\n\n return obj;\n },\n {},\n );\n }\n\n /**\n * If the price API does not support a given native currency, then we need to\n * convert it to a fallback currency and feed that currency into the price\n * API, then convert the prices to our desired native currency.\n *\n * @param args - The arguments to this function.\n * @param args.tokenAddresses - Addresses for tokens.\n * @param args.nativeCurrency - The native currency in which to request\n * prices.\n * @returns A map of the token addresses (as checksums) to their prices in the\n * native currency.\n */\n async #fetchAndMapExchangeRatesForUnsupportedNativeCurrency({\n tokenAddresses,\n nativeCurrency,\n }: {\n tokenAddresses: Hex[];\n nativeCurrency: string;\n }): Promise<ContractMarketData> {\n const [\n contractExchangeInformations,\n fallbackCurrencyToNativeCurrencyConversionRate,\n ] = await Promise.all([\n this.#fetchAndMapExchangeRatesForSupportedNativeCurrency({\n tokenAddresses,\n chainId: this.#chainId,\n nativeCurrency: FALL_BACK_VS_CURRENCY,\n }),\n getCurrencyConversionRate({\n from: FALL_BACK_VS_CURRENCY,\n to: nativeCurrency,\n }),\n ]);\n\n if (fallbackCurrencyToNativeCurrencyConversionRate === null) {\n return {};\n }\n\n const updatedContractExchangeRates = Object.entries(\n contractExchangeInformations,\n ).reduce((acc, [tokenAddress, token]) => {\n acc = {\n ...acc,\n [tokenAddress]: {\n ...token,\n price: token.price\n ? token.price * fallbackCurrencyToNativeCurrencyConversionRate\n : undefined,\n },\n };\n return acc;\n }, {});\n\n return updatedContractExchangeRates;\n }\n}\n\nexport default TokenRatesController;\n"]}
@@ -1,6 +1,6 @@
1
1
  import {
2
2
  fetchMultiExchangeRate
3
- } from "./chunk-CNKVITJO.mjs";
3
+ } from "./chunk-JTXPJ6TK.mjs";
4
4
  import {
5
5
  __privateAdd,
6
6
  __privateGet,
@@ -72,6 +72,8 @@ var RatesController = class extends BaseController {
72
72
  * // Execute criticalLogic within a lock.
73
73
  * const result = await this.#withLock(criticalLogic);
74
74
  */
75
+ // TODO: Either fix this lint violation or explain why it's necessary to ignore.
76
+ // eslint-disable-next-line @typescript-eslint/naming-convention
75
77
  __privateAdd(this, _withLock);
76
78
  /**
77
79
  * Executes the polling operation to update rates.
@@ -199,4 +201,4 @@ export {
199
201
  Cryptocurrency,
200
202
  RatesController
201
203
  };
202
- //# sourceMappingURL=chunk-B5YVX5IO.mjs.map
204
+ //# sourceMappingURL=chunk-SBWPU4VT.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/RatesController/RatesController.ts"],"sourcesContent":["import { BaseController } from '@metamask/base-controller';\nimport { Mutex } from 'async-mutex';\n\nimport { fetchMultiExchangeRate as defaultFetchExchangeRate } from '../crypto-compare-service';\nimport type {\n ConversionRates,\n RatesControllerState,\n RatesControllerOptions,\n RatesControllerMessenger,\n} from './types';\n\nexport const name = 'RatesController';\n\nexport enum Cryptocurrency {\n Btc = 'btc',\n}\n\nconst DEFAULT_INTERVAL = 180000;\n\nconst metadata = {\n fiatCurrency: { persist: true, anonymous: true },\n rates: { persist: true, anonymous: true },\n cryptocurrencies: { persist: true, anonymous: true },\n};\n\nconst defaultState = {\n fiatCurrency: 'usd',\n rates: {\n [Cryptocurrency.Btc]: {\n conversionDate: 0,\n conversionRate: '0',\n },\n },\n cryptocurrencies: [Cryptocurrency.Btc],\n};\n\nexport class RatesController extends BaseController<\n typeof name,\n RatesControllerState,\n RatesControllerMessenger\n> {\n readonly #mutex = new Mutex();\n\n readonly #fetchMultiExchangeRate;\n\n readonly #includeUsdRate;\n\n #intervalLength: number;\n\n #intervalId: NodeJS.Timeout | undefined;\n\n /**\n * Creates a RatesController instance.\n *\n * @param options - Constructor options.\n * @param options.includeUsdRate - Keep track of the USD rate in addition to the current currency rate.\n * @param options.interval - The polling interval, in milliseconds.\n * @param options.messenger - A reference to the messaging system.\n * @param options.state - Initial state to set on this controller.\n * @param options.fetchMultiExchangeRate - Fetches the exchange rate from an external API. This option is primarily meant for use in unit tests.\n */\n constructor({\n interval = DEFAULT_INTERVAL,\n messenger,\n state,\n includeUsdRate,\n fetchMultiExchangeRate = defaultFetchExchangeRate,\n }: RatesControllerOptions) {\n super({\n name,\n metadata,\n messenger,\n state: { ...defaultState, ...state },\n });\n this.#includeUsdRate = includeUsdRate;\n this.#fetchMultiExchangeRate = fetchMultiExchangeRate;\n this.#intervalLength = interval;\n }\n\n /**\n * Executes a function `callback` within a mutex lock to ensure that only one instance of `callback` runs at a time across all invocations of `#withLock`.\n * This method is useful for synchronizing access to a resource or section of code that should not be executed concurrently.\n *\n * @template R - The return type of the function `callback`.\n * @param callback - A callback to execute once the lock is acquired. This callback can be synchronous or asynchronous.\n * @returns A promise that resolves to the result of the function `callback`. The promise is fulfilled once `callback` has completed execution.\n * @example\n * async function criticalLogic() {\n * // Critical logic code goes here.\n * }\n *\n * // Execute criticalLogic within a lock.\n * const result = await this.#withLock(criticalLogic);\n */\n // TODO: Either fix this lint violation or explain why it's necessary to ignore.\n // eslint-disable-next-line @typescript-eslint/naming-convention\n async #withLock<R>(callback: () => R) {\n const releaseLock = await this.#mutex.acquire();\n try {\n return callback();\n } finally {\n releaseLock();\n }\n }\n\n /**\n * Executes the polling operation to update rates.\n */\n async #executePoll(): Promise<void> {\n await this.#updateRates();\n }\n\n /**\n * Updates the rates by fetching new data.\n */\n async #updateRates(): Promise<void> {\n await this.#withLock(async () => {\n const { fiatCurrency, cryptocurrencies } = this.state;\n const response: Record<\n Cryptocurrency,\n Record<string, string>\n > = await this.#fetchMultiExchangeRate(\n fiatCurrency,\n cryptocurrencies,\n this.#includeUsdRate,\n );\n\n const updatedRates: ConversionRates = {};\n for (const [cryptocurrency, values] of Object.entries(response)) {\n updatedRates[cryptocurrency] = {\n conversionDate: Date.now(),\n conversionRate: values[fiatCurrency],\n ...(this.#includeUsdRate && { usdConversionRate: values.usd }),\n };\n }\n\n this.update(() => {\n return {\n ...this.state,\n rates: updatedRates,\n };\n });\n });\n }\n\n /**\n * Starts the polling process.\n */\n async start(): Promise<void> {\n if (this.#intervalId) {\n return;\n }\n\n this.messagingSystem.publish(`${name}:pollingStarted`);\n\n this.#intervalId = setInterval(() => {\n this.#executePoll().catch(console.error);\n }, this.#intervalLength);\n }\n\n /**\n * Stops the polling process.\n */\n async stop(): Promise<void> {\n if (!this.#intervalId) {\n return;\n }\n\n clearInterval(this.#intervalId);\n this.#intervalId = undefined;\n this.messagingSystem.publish(`${name}:pollingStopped`);\n }\n\n /**\n * Returns the current list of cryptocurrency.\n * @returns The cryptocurrency list.\n */\n getCryptocurrencyList(): Cryptocurrency[] {\n const { cryptocurrencies } = this.state;\n return cryptocurrencies;\n }\n\n /**\n * Sets the list of supported cryptocurrencies.\n * @param list - The list of supported cryptocurrencies.\n */\n async setCryptocurrencyList(list: Cryptocurrency[]): Promise<void> {\n await this.#withLock(() => {\n this.update(() => {\n return {\n ...this.state,\n fromCurrencies: list,\n };\n });\n });\n }\n\n /**\n * Sets the internal fiat currency and update rates accordingly.\n * @param fiatCurrency - The fiat currency.\n */\n async setFiatCurrency(fiatCurrency: string): Promise<void> {\n if (fiatCurrency === '') {\n throw new Error('The currency can not be an empty string');\n }\n\n await this.#withLock(() => {\n this.update(() => {\n return {\n ...defaultState,\n fiatCurrency,\n };\n });\n });\n await this.#updateRates();\n }\n}\n"],"mappings":"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","names":["Cryptocurrency","fetchMultiExchangeRate"]}
@@ -1,6 +1,6 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
2
 
3
- var _chunkWB6KJX4Njs = require('./chunk-WB6KJX4N.js');
3
+ var _chunkZG5MS2TOjs = require('./chunk-ZG5MS2TO.js');
4
4
 
5
5
  // src/CurrencyRateController.ts
6
6
 
@@ -40,7 +40,7 @@ var CurrencyRateController = class extends _pollingcontroller.StaticIntervalPoll
40
40
  interval = 18e4,
41
41
  messenger,
42
42
  state,
43
- fetchExchangeRate: fetchExchangeRate2 = _chunkWB6KJX4Njs.fetchExchangeRate
43
+ fetchExchangeRate: fetchExchangeRate2 = _chunkZG5MS2TOjs.fetchExchangeRate
44
44
  }) {
45
45
  super({
46
46
  name,
@@ -154,4 +154,4 @@ var CurrencyRateController_default = CurrencyRateController;
154
154
 
155
155
 
156
156
  exports.CurrencyRateController = CurrencyRateController; exports.CurrencyRateController_default = CurrencyRateController_default;
157
- //# sourceMappingURL=chunk-ELSMS5S7.js.map
157
+ //# sourceMappingURL=chunk-T5ZX5BV7.js.map