@metamask/assets-controllers 38.0.0 → 38.1.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 (372) hide show
  1. package/CHANGELOG.md +37 -1
  2. package/dist/AccountTrackerController.cjs +245 -0
  3. package/dist/AccountTrackerController.cjs.map +1 -0
  4. package/dist/{types/AccountTrackerController.d.ts → AccountTrackerController.d.cts} +6 -6
  5. package/dist/AccountTrackerController.d.cts.map +1 -0
  6. package/dist/AccountTrackerController.d.mts +112 -0
  7. package/dist/AccountTrackerController.d.mts.map +1 -0
  8. package/dist/AccountTrackerController.mjs +244 -8
  9. package/dist/AccountTrackerController.mjs.map +1 -1
  10. package/dist/AssetsContractController.cjs +389 -0
  11. package/dist/AssetsContractController.cjs.map +1 -0
  12. package/dist/{types/AssetsContractController.d.ts → AssetsContractController.d.cts} +9 -9
  13. package/dist/AssetsContractController.d.cts.map +1 -0
  14. package/dist/AssetsContractController.d.mts +277 -0
  15. package/dist/AssetsContractController.d.mts.map +1 -0
  16. package/dist/AssetsContractController.mjs +387 -16
  17. package/dist/AssetsContractController.mjs.map +1 -1
  18. package/dist/CurrencyRateController.cjs +156 -0
  19. package/dist/CurrencyRateController.cjs.map +1 -0
  20. package/dist/{types/CurrencyRateController.d.ts → CurrencyRateController.d.cts} +5 -5
  21. package/dist/CurrencyRateController.d.cts.map +1 -0
  22. package/dist/CurrencyRateController.d.mts +80 -0
  23. package/dist/CurrencyRateController.d.mts.map +1 -0
  24. package/dist/CurrencyRateController.mjs +150 -10
  25. package/dist/CurrencyRateController.mjs.map +1 -1
  26. package/dist/NftController.cjs +1159 -0
  27. package/dist/NftController.cjs.map +1 -0
  28. package/dist/{types/NftController.d.ts → NftController.d.cts} +11 -11
  29. package/dist/NftController.d.cts.map +1 -0
  30. package/dist/NftController.d.mts +424 -0
  31. package/dist/NftController.d.mts.map +1 -0
  32. package/dist/NftController.mjs +1156 -12
  33. package/dist/NftController.mjs.map +1 -1
  34. package/dist/NftDetectionController.cjs +237 -0
  35. package/dist/NftDetectionController.cjs.map +1 -0
  36. package/dist/{types/NftDetectionController.d.ts → NftDetectionController.d.cts} +9 -9
  37. package/dist/NftDetectionController.d.cts.map +1 -0
  38. package/dist/NftDetectionController.d.mts +368 -0
  39. package/dist/NftDetectionController.d.mts.map +1 -0
  40. package/dist/NftDetectionController.mjs +231 -14
  41. package/dist/NftDetectionController.mjs.map +1 -1
  42. package/dist/RatesController/RatesController.cjs +189 -0
  43. package/dist/RatesController/RatesController.cjs.map +1 -0
  44. package/dist/{types/RatesController/RatesController.d.ts → RatesController/RatesController.d.cts} +3 -3
  45. package/dist/RatesController/RatesController.d.cts.map +1 -0
  46. package/dist/RatesController/RatesController.d.mts +44 -0
  47. package/dist/RatesController/RatesController.d.mts.map +1 -0
  48. package/dist/RatesController/RatesController.mjs +183 -12
  49. package/dist/RatesController/RatesController.mjs.map +1 -1
  50. package/dist/RatesController/index.cjs +7 -0
  51. package/dist/RatesController/index.cjs.map +1 -0
  52. package/dist/{types/RatesController/index.d.ts → RatesController/index.d.cts} +3 -3
  53. package/dist/RatesController/index.d.cts.map +1 -0
  54. package/dist/RatesController/index.d.mts +3 -0
  55. package/dist/RatesController/index.d.mts.map +1 -0
  56. package/dist/RatesController/index.mjs +1 -12
  57. package/dist/RatesController/index.mjs.map +1 -1
  58. package/dist/RatesController/types.cjs +3 -0
  59. package/dist/RatesController/types.cjs.map +1 -0
  60. package/dist/{types/RatesController/types.d.ts → RatesController/types.d.cts} +4 -4
  61. package/dist/RatesController/types.d.cts.map +1 -0
  62. package/dist/RatesController/types.d.mts +100 -0
  63. package/dist/RatesController/types.d.mts.map +1 -0
  64. package/dist/RatesController/types.mjs +1 -0
  65. package/dist/RatesController/types.mjs.map +1 -1
  66. package/dist/Standards/ERC20Standard.cjs +124 -0
  67. package/dist/Standards/ERC20Standard.cjs.map +1 -0
  68. package/dist/{types/Standards/ERC20Standard.d.ts → Standards/ERC20Standard.d.cts} +3 -3
  69. package/dist/Standards/ERC20Standard.d.cts.map +1 -0
  70. package/dist/Standards/ERC20Standard.d.mts +49 -0
  71. package/dist/Standards/ERC20Standard.d.mts.map +1 -0
  72. package/dist/Standards/ERC20Standard.mjs +121 -8
  73. package/dist/Standards/ERC20Standard.mjs.map +1 -1
  74. package/dist/Standards/NftStandards/ERC1155/ERC1155Standard.cjs +189 -0
  75. package/dist/Standards/NftStandards/ERC1155/ERC1155Standard.cjs.map +1 -0
  76. package/dist/{types/Standards/NftStandards/ERC1155/ERC1155Standard.d.ts → Standards/NftStandards/ERC1155/ERC1155Standard.d.cts} +3 -3
  77. package/dist/Standards/NftStandards/ERC1155/ERC1155Standard.d.cts.map +1 -0
  78. package/dist/Standards/NftStandards/ERC1155/ERC1155Standard.d.mts +95 -0
  79. package/dist/Standards/NftStandards/ERC1155/ERC1155Standard.d.mts.map +1 -0
  80. package/dist/Standards/NftStandards/ERC1155/ERC1155Standard.mjs +184 -8
  81. package/dist/Standards/NftStandards/ERC1155/ERC1155Standard.mjs.map +1 -1
  82. package/dist/Standards/NftStandards/ERC721/ERC721Standard.cjs +167 -0
  83. package/dist/Standards/NftStandards/ERC721/ERC721Standard.cjs.map +1 -0
  84. package/dist/{types/Standards/NftStandards/ERC721/ERC721Standard.d.ts → Standards/NftStandards/ERC721/ERC721Standard.d.cts} +2 -2
  85. package/dist/Standards/NftStandards/ERC721/ERC721Standard.d.cts.map +1 -0
  86. package/dist/Standards/NftStandards/ERC721/ERC721Standard.d.mts +89 -0
  87. package/dist/Standards/NftStandards/ERC721/ERC721Standard.d.mts.map +1 -0
  88. package/dist/Standards/NftStandards/ERC721/ERC721Standard.mjs +162 -8
  89. package/dist/Standards/NftStandards/ERC721/ERC721Standard.mjs.map +1 -1
  90. package/dist/TokenBalancesController.cjs +136 -0
  91. package/dist/TokenBalancesController.cjs.map +1 -0
  92. package/dist/{types/TokenBalancesController.d.ts → TokenBalancesController.d.cts} +7 -7
  93. package/dist/TokenBalancesController.d.cts.map +1 -0
  94. package/dist/TokenBalancesController.d.mts +82 -0
  95. package/dist/TokenBalancesController.d.mts.map +1 -0
  96. package/dist/TokenBalancesController.mjs +129 -10
  97. package/dist/TokenBalancesController.mjs.map +1 -1
  98. package/dist/TokenDetectionController.cjs +368 -0
  99. package/dist/TokenDetectionController.cjs.map +1 -0
  100. package/dist/{types/TokenDetectionController.d.ts → TokenDetectionController.d.cts} +10 -10
  101. package/dist/TokenDetectionController.d.cts.map +1 -0
  102. package/dist/TokenDetectionController.d.mts +109 -0
  103. package/dist/TokenDetectionController.d.mts.map +1 -0
  104. package/dist/TokenDetectionController.mjs +365 -15
  105. package/dist/TokenDetectionController.mjs.map +1 -1
  106. package/dist/TokenListController.cjs +274 -0
  107. package/dist/TokenListController.cjs.map +1 -0
  108. package/dist/{types/TokenListController.d.ts → TokenListController.d.cts} +5 -5
  109. package/dist/TokenListController.d.cts.map +1 -0
  110. package/dist/TokenListController.d.mts +117 -0
  111. package/dist/TokenListController.d.mts.map +1 -0
  112. package/dist/TokenListController.mjs +267 -12
  113. package/dist/TokenListController.mjs.map +1 -1
  114. package/dist/TokenRatesController.cjs +452 -0
  115. package/dist/TokenRatesController.cjs.map +1 -0
  116. package/dist/{types/TokenRatesController.d.ts → TokenRatesController.d.cts} +8 -8
  117. package/dist/TokenRatesController.d.cts.map +1 -0
  118. package/dist/TokenRatesController.d.mts +170 -0
  119. package/dist/TokenRatesController.d.mts.map +1 -0
  120. package/dist/TokenRatesController.mjs +446 -16
  121. package/dist/TokenRatesController.mjs.map +1 -1
  122. package/dist/TokensController.cjs +678 -0
  123. package/dist/TokensController.cjs.map +1 -0
  124. package/dist/{types/TokensController.d.ts → TokensController.d.cts} +9 -9
  125. package/dist/TokensController.d.cts.map +1 -0
  126. package/dist/TokensController.d.mts +165 -0
  127. package/dist/TokensController.d.mts.map +1 -0
  128. package/dist/TokensController.mjs +675 -14
  129. package/dist/TokensController.mjs.map +1 -1
  130. package/dist/assetsUtil.cjs +358 -0
  131. package/dist/assetsUtil.cjs.map +1 -0
  132. package/dist/{types/assetsUtil.d.ts → assetsUtil.d.cts} +7 -7
  133. package/dist/assetsUtil.d.cts.map +1 -0
  134. package/dist/assetsUtil.d.mts +177 -0
  135. package/dist/assetsUtil.d.mts.map +1 -0
  136. package/dist/assetsUtil.mjs +343 -36
  137. package/dist/assetsUtil.mjs.map +1 -1
  138. package/dist/constants.cjs +10 -0
  139. package/dist/constants.cjs.map +1 -0
  140. package/dist/{types/constants.d.ts → constants.d.cts} +1 -1
  141. package/dist/constants.d.cts.map +1 -0
  142. package/dist/constants.d.mts +6 -0
  143. package/dist/constants.d.mts.map +1 -0
  144. package/dist/constants.mjs +6 -7
  145. package/dist/constants.mjs.map +1 -1
  146. package/dist/crypto-compare-service/crypto-compare.cjs +119 -0
  147. package/dist/crypto-compare-service/crypto-compare.cjs.map +1 -0
  148. package/dist/{types/crypto-compare-service/crypto-compare.d.ts → crypto-compare-service/crypto-compare.d.cts} +1 -1
  149. package/dist/crypto-compare-service/crypto-compare.d.cts.map +1 -0
  150. package/dist/crypto-compare-service/crypto-compare.d.mts +22 -0
  151. package/dist/crypto-compare-service/crypto-compare.d.mts.map +1 -0
  152. package/dist/crypto-compare-service/crypto-compare.mjs +113 -9
  153. package/dist/crypto-compare-service/crypto-compare.mjs.map +1 -1
  154. package/dist/crypto-compare-service/index.cjs +7 -0
  155. package/dist/crypto-compare-service/index.cjs.map +1 -0
  156. package/dist/crypto-compare-service/index.d.cts +2 -0
  157. package/dist/crypto-compare-service/index.d.cts.map +1 -0
  158. package/dist/crypto-compare-service/index.d.mts +2 -0
  159. package/dist/crypto-compare-service/index.d.mts.map +1 -0
  160. package/dist/crypto-compare-service/index.mjs +1 -10
  161. package/dist/crypto-compare-service/index.mjs.map +1 -1
  162. package/dist/index.cjs +51 -0
  163. package/dist/index.cjs.map +1 -0
  164. package/dist/{types/index.d.ts → index.d.cts} +24 -24
  165. package/dist/index.d.cts.map +1 -0
  166. package/dist/index.d.mts +24 -0
  167. package/dist/index.d.mts.map +1 -0
  168. package/dist/index.mjs +13 -80
  169. package/dist/index.mjs.map +1 -1
  170. package/dist/token-prices-service/abstract-token-prices-service.cjs +3 -0
  171. package/dist/token-prices-service/abstract-token-prices-service.cjs.map +1 -0
  172. package/dist/{types/token-prices-service/abstract-token-prices-service.d.ts → token-prices-service/abstract-token-prices-service.d.cts} +2 -2
  173. package/dist/token-prices-service/abstract-token-prices-service.d.cts.map +1 -0
  174. package/dist/token-prices-service/abstract-token-prices-service.d.mts +79 -0
  175. package/dist/token-prices-service/abstract-token-prices-service.d.mts.map +1 -0
  176. package/dist/token-prices-service/abstract-token-prices-service.mjs +1 -0
  177. package/dist/token-prices-service/abstract-token-prices-service.mjs.map +1 -1
  178. package/dist/token-prices-service/codefi-v2.cjs +352 -0
  179. package/dist/token-prices-service/codefi-v2.cjs.map +1 -0
  180. package/dist/{types/token-prices-service/codefi-v2.d.ts → token-prices-service/codefi-v2.d.cts} +3 -3
  181. package/dist/token-prices-service/codefi-v2.d.cts.map +1 -0
  182. package/dist/token-prices-service/codefi-v2.d.mts +97 -0
  183. package/dist/token-prices-service/codefi-v2.d.mts.map +1 -0
  184. package/dist/token-prices-service/codefi-v2.mjs +347 -12
  185. package/dist/token-prices-service/codefi-v2.mjs.map +1 -1
  186. package/dist/token-prices-service/index.cjs +7 -0
  187. package/dist/token-prices-service/index.cjs.map +1 -0
  188. package/dist/token-prices-service/index.d.cts +3 -0
  189. package/dist/token-prices-service/index.d.cts.map +1 -0
  190. package/dist/token-prices-service/index.d.mts +3 -0
  191. package/dist/token-prices-service/index.d.mts.map +1 -0
  192. package/dist/token-prices-service/index.mjs +1 -10
  193. package/dist/token-prices-service/index.mjs.map +1 -1
  194. package/dist/token-service.cjs +130 -0
  195. package/dist/token-service.cjs.map +1 -0
  196. package/dist/{types/token-service.d.ts → token-service.d.cts} +2 -2
  197. package/dist/token-service.d.cts.map +1 -0
  198. package/dist/token-service.d.mts +31 -0
  199. package/dist/token-service.d.mts.map +1 -0
  200. package/dist/token-service.mjs +124 -14
  201. package/dist/token-service.mjs.map +1 -1
  202. package/package.json +21 -16
  203. package/dist/AccountTrackerController.js +0 -10
  204. package/dist/AccountTrackerController.js.map +0 -1
  205. package/dist/AssetsContractController.js +0 -18
  206. package/dist/AssetsContractController.js.map +0 -1
  207. package/dist/CurrencyRateController.js +0 -12
  208. package/dist/CurrencyRateController.js.map +0 -1
  209. package/dist/NftController.js +0 -14
  210. package/dist/NftController.js.map +0 -1
  211. package/dist/NftDetectionController.js +0 -16
  212. package/dist/NftDetectionController.js.map +0 -1
  213. package/dist/RatesController/RatesController.js +0 -14
  214. package/dist/RatesController/RatesController.js.map +0 -1
  215. package/dist/RatesController/index.js +0 -13
  216. package/dist/RatesController/index.js.map +0 -1
  217. package/dist/RatesController/types.js +0 -1
  218. package/dist/RatesController/types.js.map +0 -1
  219. package/dist/Standards/ERC20Standard.js +0 -9
  220. package/dist/Standards/ERC20Standard.js.map +0 -1
  221. package/dist/Standards/NftStandards/ERC1155/ERC1155Standard.js +0 -9
  222. package/dist/Standards/NftStandards/ERC1155/ERC1155Standard.js.map +0 -1
  223. package/dist/Standards/NftStandards/ERC721/ERC721Standard.js +0 -9
  224. package/dist/Standards/NftStandards/ERC721/ERC721Standard.js.map +0 -1
  225. package/dist/TokenBalancesController.js +0 -12
  226. package/dist/TokenBalancesController.js.map +0 -1
  227. package/dist/TokenDetectionController.js +0 -17
  228. package/dist/TokenDetectionController.js.map +0 -1
  229. package/dist/TokenListController.js +0 -14
  230. package/dist/TokenListController.js.map +0 -1
  231. package/dist/TokenRatesController.js +0 -18
  232. package/dist/TokenRatesController.js.map +0 -1
  233. package/dist/TokensController.js +0 -16
  234. package/dist/TokensController.js.map +0 -1
  235. package/dist/assetsUtil.js +0 -38
  236. package/dist/assetsUtil.js.map +0 -1
  237. package/dist/chunk-27KOXCQK.mjs +0 -1
  238. package/dist/chunk-27KOXCQK.mjs.map +0 -1
  239. package/dist/chunk-2TZK6YZA.js +0 -1405
  240. package/dist/chunk-2TZK6YZA.js.map +0 -1
  241. package/dist/chunk-3LPQTUGG.js +0 -434
  242. package/dist/chunk-3LPQTUGG.js.map +0 -1
  243. package/dist/chunk-3QDXAE2D.mjs +0 -178
  244. package/dist/chunk-3QDXAE2D.mjs.map +0 -1
  245. package/dist/chunk-46KUC5FH.mjs +0 -434
  246. package/dist/chunk-46KUC5FH.mjs.map +0 -1
  247. package/dist/chunk-4QZESU46.mjs +0 -530
  248. package/dist/chunk-4QZESU46.mjs.map +0 -1
  249. package/dist/chunk-5QLC2MHV.js +0 -215
  250. package/dist/chunk-5QLC2MHV.js.map +0 -1
  251. package/dist/chunk-7K6PSEAA.js +0 -1
  252. package/dist/chunk-7K6PSEAA.js.map +0 -1
  253. package/dist/chunk-AX522TDL.mjs +0 -85
  254. package/dist/chunk-AX522TDL.mjs.map +0 -1
  255. package/dist/chunk-AZSIKIMK.mjs +0 -429
  256. package/dist/chunk-AZSIKIMK.mjs.map +0 -1
  257. package/dist/chunk-BBCZM5P4.js +0 -300
  258. package/dist/chunk-BBCZM5P4.js.map +0 -1
  259. package/dist/chunk-BZEAPSD5.mjs +0 -215
  260. package/dist/chunk-BZEAPSD5.mjs.map +0 -1
  261. package/dist/chunk-C7LNCQXM.mjs +0 -300
  262. package/dist/chunk-C7LNCQXM.mjs.map +0 -1
  263. package/dist/chunk-CP3HC7AQ.mjs +0 -12
  264. package/dist/chunk-CP3HC7AQ.mjs.map +0 -1
  265. package/dist/chunk-FWKV5FGP.mjs +0 -71
  266. package/dist/chunk-FWKV5FGP.mjs.map +0 -1
  267. package/dist/chunk-GDFLKKDY.js +0 -71
  268. package/dist/chunk-GDFLKKDY.js.map +0 -1
  269. package/dist/chunk-GW6RE66P.mjs +0 -210
  270. package/dist/chunk-GW6RE66P.mjs.map +0 -1
  271. package/dist/chunk-HVOIBGYN.js +0 -282
  272. package/dist/chunk-HVOIBGYN.js.map +0 -1
  273. package/dist/chunk-ISK2VSBB.js +0 -178
  274. package/dist/chunk-ISK2VSBB.js.map +0 -1
  275. package/dist/chunk-JCR4H6YL.js +0 -115
  276. package/dist/chunk-JCR4H6YL.js.map +0 -1
  277. package/dist/chunk-JJX7TMH5.mjs +0 -135
  278. package/dist/chunk-JJX7TMH5.mjs.map +0 -1
  279. package/dist/chunk-JMZ7KWJS.js +0 -157
  280. package/dist/chunk-JMZ7KWJS.js.map +0 -1
  281. package/dist/chunk-JYHAAA6W.mjs +0 -1
  282. package/dist/chunk-JYHAAA6W.mjs.map +0 -1
  283. package/dist/chunk-K7A3EOIM.js +0 -85
  284. package/dist/chunk-K7A3EOIM.js.map +0 -1
  285. package/dist/chunk-KPBNX6GP.mjs +0 -215
  286. package/dist/chunk-KPBNX6GP.mjs.map +0 -1
  287. package/dist/chunk-LKVWPNXY.js +0 -429
  288. package/dist/chunk-LKVWPNXY.js.map +0 -1
  289. package/dist/chunk-MZI3SDQN.js +0 -215
  290. package/dist/chunk-MZI3SDQN.js.map +0 -1
  291. package/dist/chunk-NDUMUEE6.js +0 -812
  292. package/dist/chunk-NDUMUEE6.js.map +0 -1
  293. package/dist/chunk-OBUR4TXH.js +0 -1
  294. package/dist/chunk-OBUR4TXH.js.map +0 -1
  295. package/dist/chunk-RGHTNZQ6.js +0 -12
  296. package/dist/chunk-RGHTNZQ6.js.map +0 -1
  297. package/dist/chunk-S5CFNNOM.mjs +0 -115
  298. package/dist/chunk-S5CFNNOM.mjs.map +0 -1
  299. package/dist/chunk-SK2B36Q4.mjs +0 -1405
  300. package/dist/chunk-SK2B36Q4.mjs.map +0 -1
  301. package/dist/chunk-TFLYM4PY.mjs +0 -291
  302. package/dist/chunk-TFLYM4PY.mjs.map +0 -1
  303. package/dist/chunk-TIFLP53R.js +0 -210
  304. package/dist/chunk-TIFLP53R.js.map +0 -1
  305. package/dist/chunk-TTH3ES66.mjs +0 -1
  306. package/dist/chunk-TTH3ES66.mjs.map +0 -1
  307. package/dist/chunk-UKXD6WUT.mjs +0 -157
  308. package/dist/chunk-UKXD6WUT.mjs.map +0 -1
  309. package/dist/chunk-UUF4E7OG.js +0 -530
  310. package/dist/chunk-UUF4E7OG.js.map +0 -1
  311. package/dist/chunk-V6DNVROD.js +0 -348
  312. package/dist/chunk-V6DNVROD.js.map +0 -1
  313. package/dist/chunk-XC3SOOGC.js +0 -1
  314. package/dist/chunk-XC3SOOGC.js.map +0 -1
  315. package/dist/chunk-XMQA5NLX.mjs +0 -812
  316. package/dist/chunk-XMQA5NLX.mjs.map +0 -1
  317. package/dist/chunk-XQO3EG4J.mjs +0 -348
  318. package/dist/chunk-XQO3EG4J.mjs.map +0 -1
  319. package/dist/chunk-XUI43LEZ.mjs +0 -30
  320. package/dist/chunk-XUI43LEZ.mjs.map +0 -1
  321. package/dist/chunk-YGGUAMHV.js +0 -135
  322. package/dist/chunk-YGGUAMHV.js.map +0 -1
  323. package/dist/chunk-Z4BLTVTB.js +0 -30
  324. package/dist/chunk-Z4BLTVTB.js.map +0 -1
  325. package/dist/chunk-Z7RMCHD4.mjs +0 -282
  326. package/dist/chunk-Z7RMCHD4.mjs.map +0 -1
  327. package/dist/chunk-ZAR4BIOC.js +0 -291
  328. package/dist/chunk-ZAR4BIOC.js.map +0 -1
  329. package/dist/constants.js +0 -8
  330. package/dist/constants.js.map +0 -1
  331. package/dist/crypto-compare-service/crypto-compare.js +0 -10
  332. package/dist/crypto-compare-service/crypto-compare.js.map +0 -1
  333. package/dist/crypto-compare-service/index.js +0 -11
  334. package/dist/crypto-compare-service/index.js.map +0 -1
  335. package/dist/index.js +0 -81
  336. package/dist/index.js.map +0 -1
  337. package/dist/token-prices-service/abstract-token-prices-service.js +0 -1
  338. package/dist/token-prices-service/abstract-token-prices-service.js.map +0 -1
  339. package/dist/token-prices-service/codefi-v2.js +0 -14
  340. package/dist/token-prices-service/codefi-v2.js.map +0 -1
  341. package/dist/token-prices-service/index.js +0 -11
  342. package/dist/token-prices-service/index.js.map +0 -1
  343. package/dist/token-service.js +0 -15
  344. package/dist/token-service.js.map +0 -1
  345. package/dist/tsconfig.build.tsbuildinfo +0 -1
  346. package/dist/types/AccountTrackerController.d.ts.map +0 -1
  347. package/dist/types/AssetsContractController.d.ts.map +0 -1
  348. package/dist/types/CurrencyRateController.d.ts.map +0 -1
  349. package/dist/types/NftController.d.ts.map +0 -1
  350. package/dist/types/NftDetectionController.d.ts.map +0 -1
  351. package/dist/types/RatesController/RatesController.d.ts.map +0 -1
  352. package/dist/types/RatesController/index.d.ts.map +0 -1
  353. package/dist/types/RatesController/types.d.ts.map +0 -1
  354. package/dist/types/Standards/ERC20Standard.d.ts.map +0 -1
  355. package/dist/types/Standards/NftStandards/ERC1155/ERC1155Standard.d.ts.map +0 -1
  356. package/dist/types/Standards/NftStandards/ERC721/ERC721Standard.d.ts.map +0 -1
  357. package/dist/types/TokenBalancesController.d.ts.map +0 -1
  358. package/dist/types/TokenDetectionController.d.ts.map +0 -1
  359. package/dist/types/TokenListController.d.ts.map +0 -1
  360. package/dist/types/TokenRatesController.d.ts.map +0 -1
  361. package/dist/types/TokensController.d.ts.map +0 -1
  362. package/dist/types/assetsUtil.d.ts.map +0 -1
  363. package/dist/types/constants.d.ts.map +0 -1
  364. package/dist/types/crypto-compare-service/crypto-compare.d.ts.map +0 -1
  365. package/dist/types/crypto-compare-service/index.d.ts +0 -2
  366. package/dist/types/crypto-compare-service/index.d.ts.map +0 -1
  367. package/dist/types/index.d.ts.map +0 -1
  368. package/dist/types/token-prices-service/abstract-token-prices-service.d.ts.map +0 -1
  369. package/dist/types/token-prices-service/codefi-v2.d.ts.map +0 -1
  370. package/dist/types/token-prices-service/index.d.ts +0 -3
  371. package/dist/types/token-prices-service/index.d.ts.map +0 -1
  372. package/dist/types/token-service.d.ts.map +0 -1
@@ -1,1405 +0,0 @@
1
- import {
2
- compareNftMetadata,
3
- getFormattedIpfsUrl,
4
- hasNewCollectionFields
5
- } from "./chunk-BZEAPSD5.mjs";
6
- import {
7
- __privateAdd,
8
- __privateGet,
9
- __privateMethod,
10
- __privateSet
11
- } from "./chunk-XUI43LEZ.mjs";
12
-
13
- // src/NftController.ts
14
- import { isAddress } from "@ethersproject/address";
15
- import {
16
- BaseController
17
- } from "@metamask/base-controller";
18
- import {
19
- safelyExecute,
20
- handleFetch,
21
- toChecksumHexAddress,
22
- BNToHex,
23
- fetchWithErrorHandling,
24
- IPFS_DEFAULT_GATEWAY_URL,
25
- ERC721,
26
- ERC1155,
27
- ApprovalType,
28
- NFT_API_BASE_URL,
29
- NFT_API_VERSION
30
- } from "@metamask/controller-utils";
31
- import { rpcErrors } from "@metamask/rpc-errors";
32
- import { remove0x } from "@metamask/utils";
33
- import { Mutex } from "async-mutex";
34
- import BN from "bn.js";
35
- import { v4 as random } from "uuid";
36
- var nftControllerMetadata = {
37
- allNftContracts: { persist: true, anonymous: false },
38
- allNfts: { persist: true, anonymous: false },
39
- ignoredNfts: { persist: true, anonymous: false }
40
- };
41
- var ALL_NFTS_STATE_KEY = "allNfts";
42
- var ALL_NFTS_CONTRACTS_STATE_KEY = "allNftContracts";
43
- var controllerName = "NftController";
44
- var getDefaultNftControllerState = () => ({
45
- allNftContracts: {},
46
- allNfts: {},
47
- ignoredNfts: []
48
- });
49
- var _mutex, _selectedAccountId, _chainId, _ipfsGateway, _openSeaEnabled, _useIpfsSubdomains, _isIpfsGatewayEnabled, _onNftAdded, _onNetworkControllerNetworkDidChange, onNetworkControllerNetworkDidChange_fn, _onPreferencesControllerStateChange, onPreferencesControllerStateChange_fn, _onSelectedAccountChange, onSelectedAccountChange_fn, _updateNestedNftState, updateNestedNftState_fn, _getNftCollectionApi, getNftCollectionApi_fn, _getNftInformationFromApi, getNftInformationFromApi_fn, _getNftInformationFromTokenURI, getNftInformationFromTokenURI_fn, _getNftURIAndStandard, getNftURIAndStandard_fn, _getNftInformation, getNftInformation_fn, _getNftContractInformationFromContract, getNftContractInformationFromContract_fn, _getNftContractInformation, getNftContractInformation_fn, _addIndividualNft, addIndividualNft_fn, _addNftContract, addNftContract_fn, _removeAndIgnoreIndividualNft, removeAndIgnoreIndividualNft_fn, _removeIndividualNft, removeIndividualNft_fn, _removeNftContract, removeNftContract_fn, _validateWatchNft, validateWatchNft_fn, _getCorrectChainId, getCorrectChainId_fn, _getAddressOrSelectedAddress, getAddressOrSelectedAddress_fn, _updateNftUpdateForAccount, updateNftUpdateForAccount_fn;
50
- var NftController = class extends BaseController {
51
- /**
52
- * Creates an NftController instance.
53
- *
54
- * @param options - The controller options.
55
- * @param options.chainId - The chain ID of the current network.
56
- * @param options.ipfsGateway - The configured IPFS gateway.
57
- * @param options.openSeaEnabled - Controls whether the OpenSea API is used.
58
- * @param options.useIpfsSubdomains - Controls whether IPFS subdomains are used.
59
- * @param options.isIpfsGatewayEnabled - Controls whether IPFS is enabled or not.
60
- * @param options.onNftAdded - Callback that is called when an NFT is added. Currently used pass data
61
- * for tracking the NFT added event.
62
- * @param options.messenger - The controller messenger.
63
- * @param options.state - Initial state to set on this controller.
64
- */
65
- constructor({
66
- chainId: initialChainId,
67
- ipfsGateway = IPFS_DEFAULT_GATEWAY_URL,
68
- openSeaEnabled = false,
69
- useIpfsSubdomains = true,
70
- isIpfsGatewayEnabled = true,
71
- onNftAdded,
72
- messenger,
73
- state = {}
74
- }) {
75
- super({
76
- name: controllerName,
77
- metadata: nftControllerMetadata,
78
- messenger,
79
- state: {
80
- ...getDefaultNftControllerState(),
81
- ...state
82
- }
83
- });
84
- /**
85
- * Handles the network change on the network controller.
86
- * @param networkState - The new state of the preference controller.
87
- * @param networkState.selectedNetworkClientId - The current selected network client id.
88
- */
89
- __privateAdd(this, _onNetworkControllerNetworkDidChange);
90
- /**
91
- * Handles the state change of the preference controller.
92
- * @param preferencesState - The new state of the preference controller.
93
- * @param preferencesState.ipfsGateway - The configured IPFS gateway.
94
- * @param preferencesState.openSeaEnabled - Controls whether the OpenSea API is used.
95
- * @param preferencesState.isIpfsGatewayEnabled - Controls whether IPFS is enabled or not.
96
- */
97
- __privateAdd(this, _onPreferencesControllerStateChange);
98
- /**
99
- * Handles the selected account change on the accounts controller.
100
- * @param internalAccount - The new selected account.
101
- */
102
- __privateAdd(this, _onSelectedAccountChange);
103
- /**
104
- * Helper method to update nested state for allNfts and allNftContracts.
105
- *
106
- * @param newCollection - the modified piece of state to update in the controller's store
107
- * @param baseStateKey - The root key in the store to update.
108
- * @param passedConfig - An object containing the selectedAddress and chainId that are passed through the auto-detection flow.
109
- * @param passedConfig.userAddress - the address passed through the NFT detection flow to ensure assets are stored to the correct account
110
- * @param passedConfig.chainId - the chainId passed through the NFT detection flow to ensure assets are stored to the correct account
111
- */
112
- __privateAdd(this, _updateNestedNftState);
113
- __privateAdd(this, _getNftCollectionApi);
114
- /**
115
- * Request individual NFT information from NFT API.
116
- *
117
- * @param contractAddress - Hex address of the NFT contract.
118
- * @param tokenId - The NFT identifier.
119
- * @returns Promise resolving to the current NFT name and image.
120
- */
121
- __privateAdd(this, _getNftInformationFromApi);
122
- /**
123
- * Request individual NFT information from contracts that follows Metadata Interface.
124
- *
125
- * @param contractAddress - Hex address of the NFT contract.
126
- * @param tokenId - The NFT identifier.
127
- * @param networkClientId - The networkClientId that can be used to identify the network client to use for this request.
128
- * @returns Promise resolving to the current NFT name and image.
129
- */
130
- __privateAdd(this, _getNftInformationFromTokenURI);
131
- /**
132
- * Retrieve NFT uri with metadata. TODO Update method to use IPFS.
133
- *
134
- * @param contractAddress - NFT contract address.
135
- * @param tokenId - NFT token id.
136
- * @param networkClientId - The networkClientId that can be used to identify the network client to use for this request.
137
- * @returns Promise resolving NFT uri and token standard.
138
- */
139
- __privateAdd(this, _getNftURIAndStandard);
140
- /**
141
- * Request individual NFT information (name, image url and description).
142
- *
143
- * @param contractAddress - Hex address of the NFT contract.
144
- * @param tokenId - The NFT identifier.
145
- * @param networkClientId - The networkClientId that can be used to identify the network client to use for this request.
146
- * @returns Promise resolving to the current NFT name and image.
147
- */
148
- __privateAdd(this, _getNftInformation);
149
- /**
150
- * Request NFT contract information from the contract itself.
151
- *
152
- * @param contractAddress - Hex address of the NFT contract.
153
- * @param networkClientId - The networkClientId that can be used to identify the network client to use for this request.
154
- * @returns Promise resolving to the current NFT name and image.
155
- */
156
- __privateAdd(this, _getNftContractInformationFromContract);
157
- /**
158
- * Request NFT contract information from Blockchain and aggregate with received data from NFTMetadata.
159
- *
160
- * @param contractAddress - Hex address of the NFT contract.
161
- * @param nftMetadataFromApi - Received NFT information to be aggregated with blockchain contract information.
162
- * @param networkClientId - The networkClientId that can be used to identify the network client to use for this request.
163
- * @returns Promise resolving to the NFT contract name, image and description.
164
- */
165
- __privateAdd(this, _getNftContractInformation);
166
- /**
167
- * Adds an individual NFT to the stored NFT list.
168
- *
169
- * @param tokenAddress - Hex address of the NFT contract.
170
- * @param tokenId - The NFT identifier.
171
- * @param nftMetadata - NFT optional information (name, image and description).
172
- * @param nftContract - An object containing contract data of the NFT being added.
173
- * @param chainId - The chainId of the network where the NFT is being added.
174
- * @param userAddress - The address of the account where the NFT is being added.
175
- * @param source - Whether the NFT was detected, added manually or suggested by a dapp.
176
- * @returns A promise resolving to `undefined`.
177
- */
178
- __privateAdd(this, _addIndividualNft);
179
- /**
180
- * Adds an NFT contract to the stored NFT contracts list.
181
- *
182
- * @param options - options.
183
- * @param options.tokenAddress - Hex address of the NFT contract.
184
- * @param options.userAddress - The address of the account where the NFT is being added.
185
- * @param options.nftMetadata - The retrieved NFTMetadata from API.
186
- * @param options.networkClientId - The networkClientId that can be used to identify the network client to use for this request.
187
- * @param options.source - Whether the NFT was detected, added manually or suggested by a dapp.
188
- * @returns Promise resolving to the current NFT contracts list.
189
- */
190
- __privateAdd(this, _addNftContract);
191
- /**
192
- * Removes an individual NFT from the stored token list and saves it in ignored NFTs list.
193
- *
194
- * @param address - Hex address of the NFT contract.
195
- * @param tokenId - Token identifier of the NFT.
196
- * @param options - options.
197
- * @param options.chainId - The chainId of the network where the NFT is being removed.
198
- * @param options.userAddress - The address of the account where the NFT is being removed.
199
- */
200
- __privateAdd(this, _removeAndIgnoreIndividualNft);
201
- /**
202
- * Removes an individual NFT from the stored token list.
203
- *
204
- * @param address - Hex address of the NFT contract.
205
- * @param tokenId - Token identifier of the NFT.
206
- * @param options - options.
207
- * @param options.chainId - The chainId of the network where the NFT is being removed.
208
- * @param options.userAddress - The address of the account where the NFT is being removed.
209
- */
210
- __privateAdd(this, _removeIndividualNft);
211
- /**
212
- * Removes an NFT contract to the stored NFT contracts list.
213
- *
214
- * @param address - Hex address of the NFT contract.
215
- * @param options - options.
216
- * @param options.chainId - The chainId of the network where the NFT is being removed.
217
- * @param options.userAddress - The address of the account where the NFT is being removed.
218
- * @returns Promise resolving to the current NFT contracts list.
219
- */
220
- __privateAdd(this, _removeNftContract);
221
- __privateAdd(this, _validateWatchNft);
222
- // temporary method to get the correct chainId until we remove chainId from the config & the chainId arg from the detection logic
223
- // Just a helper method to prefer the networkClient chainId first then the chainId argument and then finally the config chainId
224
- __privateAdd(this, _getCorrectChainId);
225
- __privateAdd(this, _getAddressOrSelectedAddress);
226
- __privateAdd(this, _updateNftUpdateForAccount);
227
- __privateAdd(this, _mutex, new Mutex());
228
- __privateAdd(this, _selectedAccountId, void 0);
229
- __privateAdd(this, _chainId, void 0);
230
- __privateAdd(this, _ipfsGateway, void 0);
231
- __privateAdd(this, _openSeaEnabled, void 0);
232
- __privateAdd(this, _useIpfsSubdomains, void 0);
233
- __privateAdd(this, _isIpfsGatewayEnabled, void 0);
234
- __privateAdd(this, _onNftAdded, void 0);
235
- __privateSet(this, _selectedAccountId, this.messagingSystem.call(
236
- "AccountsController:getSelectedAccount"
237
- ).id);
238
- __privateSet(this, _chainId, initialChainId);
239
- __privateSet(this, _ipfsGateway, ipfsGateway);
240
- __privateSet(this, _openSeaEnabled, openSeaEnabled);
241
- __privateSet(this, _useIpfsSubdomains, useIpfsSubdomains);
242
- __privateSet(this, _isIpfsGatewayEnabled, isIpfsGatewayEnabled);
243
- __privateSet(this, _onNftAdded, onNftAdded);
244
- this.messagingSystem.subscribe(
245
- "PreferencesController:stateChange",
246
- // TODO: Either fix this lint violation or explain why it's necessary to ignore.
247
- // eslint-disable-next-line @typescript-eslint/no-misused-promises
248
- __privateMethod(this, _onPreferencesControllerStateChange, onPreferencesControllerStateChange_fn).bind(this)
249
- );
250
- this.messagingSystem.subscribe(
251
- "NetworkController:networkDidChange",
252
- __privateMethod(this, _onNetworkControllerNetworkDidChange, onNetworkControllerNetworkDidChange_fn).bind(this)
253
- );
254
- this.messagingSystem.subscribe(
255
- "AccountsController:selectedEvmAccountChange",
256
- // TODO: Either fix this lint violation or explain why it's necessary to ignore.
257
- // eslint-disable-next-line @typescript-eslint/no-misused-promises
258
- __privateMethod(this, _onSelectedAccountChange, onSelectedAccountChange_fn).bind(this)
259
- );
260
- }
261
- getNftApi() {
262
- return `${NFT_API_BASE_URL}/tokens`;
263
- }
264
- /**
265
- * Adds a new suggestedAsset to state. Parameters will be validated according to
266
- * asset type being watched. A `<suggestedNftMeta.id>:pending` hub event will be emitted once added.
267
- *
268
- * @param asset - The asset to be watched. For now ERC721 and ERC1155 tokens are accepted.
269
- * @param asset.address - The address of the asset contract.
270
- * @param asset.tokenId - The ID of the asset.
271
- * @param type - The asset type.
272
- * @param origin - Domain origin to register the asset from.
273
- * @param options - Options bag.
274
- * @param options.networkClientId - The networkClientId that can be used to identify the network client to use for this request.
275
- * @param options.userAddress - The address of the account where the NFT is being added.
276
- * @returns Object containing a Promise resolving to the suggestedAsset address if accepted.
277
- */
278
- async watchNft(asset, type, origin, {
279
- networkClientId,
280
- userAddress
281
- } = {}) {
282
- const addressToSearch = __privateMethod(this, _getAddressOrSelectedAddress, getAddressOrSelectedAddress_fn).call(this, userAddress);
283
- if (!addressToSearch) {
284
- return;
285
- }
286
- await __privateMethod(this, _validateWatchNft, validateWatchNft_fn).call(this, asset, type, addressToSearch);
287
- const nftMetadata = await __privateMethod(this, _getNftInformation, getNftInformation_fn).call(this, asset.address, asset.tokenId, networkClientId);
288
- if (nftMetadata.standard && nftMetadata.standard !== type) {
289
- throw rpcErrors.invalidInput(
290
- `Suggested NFT of type ${nftMetadata.standard} does not match received type ${type}`
291
- );
292
- }
293
- const suggestedNftMeta = {
294
- asset: { ...asset, ...nftMetadata },
295
- type,
296
- id: random(),
297
- time: Date.now(),
298
- interactingAddress: addressToSearch,
299
- origin
300
- };
301
- await this._requestApproval(suggestedNftMeta);
302
- const { address, tokenId } = asset;
303
- const { name, standard, description, image } = nftMetadata;
304
- await this.addNft(address, tokenId, {
305
- nftMetadata: {
306
- name: name ?? null,
307
- description: description ?? null,
308
- image: image ?? null,
309
- standard: standard ?? null
310
- },
311
- userAddress,
312
- source: "dapp" /* Dapp */,
313
- networkClientId
314
- });
315
- }
316
- /**
317
- * Sets an OpenSea API key to retrieve NFT information.
318
- *
319
- * @param openSeaApiKey - OpenSea API key.
320
- */
321
- setApiKey(openSeaApiKey) {
322
- this.openSeaApiKey = openSeaApiKey;
323
- }
324
- /**
325
- * Checks the ownership of a ERC-721 or ERC-1155 NFT for a given address.
326
- *
327
- * @param ownerAddress - User public address.
328
- * @param nftAddress - NFT contract address.
329
- * @param tokenId - NFT token ID.
330
- * @param options - Options bag.
331
- * @param options.networkClientId - The networkClientId that can be used to identify the network client to use for this request.
332
- * @returns Promise resolving the NFT ownership.
333
- */
334
- async isNftOwner(ownerAddress, nftAddress, tokenId, {
335
- networkClientId
336
- } = {}) {
337
- try {
338
- const owner = await this.messagingSystem.call(
339
- "AssetsContractController:getERC721OwnerOf",
340
- nftAddress,
341
- tokenId,
342
- networkClientId
343
- );
344
- return ownerAddress.toLowerCase() === owner.toLowerCase();
345
- } catch {
346
- }
347
- try {
348
- const balance = await this.messagingSystem.call(
349
- "AssetsContractController:getERC1155BalanceOf",
350
- ownerAddress,
351
- nftAddress,
352
- tokenId,
353
- networkClientId
354
- );
355
- return !balance.isZero();
356
- } catch {
357
- }
358
- throw new Error(
359
- `Unable to verify ownership. Possibly because the standard is not supported or the user's currently selected network does not match the chain of the asset in question.`
360
- );
361
- }
362
- /**
363
- * Verifies currently selected address owns entered NFT address/tokenId combo and
364
- * adds the NFT and respective NFT contract to the stored NFT and NFT contracts lists.
365
- *
366
- * @param address - Hex address of the NFT contract.
367
- * @param tokenId - The NFT identifier.
368
- * @param options - an object of arguments
369
- * @param options.userAddress - The address of the current user.
370
- * @param options.networkClientId - The networkClientId that can be used to identify the network client to use for this request.
371
- * @param options.source - Whether the NFT was detected, added manually or suggested by a dapp.
372
- */
373
- async addNftVerifyOwnership(address, tokenId, {
374
- userAddress,
375
- networkClientId,
376
- source
377
- } = {}) {
378
- const addressToSearch = __privateMethod(this, _getAddressOrSelectedAddress, getAddressOrSelectedAddress_fn).call(this, userAddress);
379
- if (!await this.isNftOwner(addressToSearch, address, tokenId, {
380
- networkClientId
381
- })) {
382
- throw new Error("This NFT is not owned by the user");
383
- }
384
- await this.addNft(address, tokenId, {
385
- networkClientId,
386
- userAddress: addressToSearch,
387
- source
388
- });
389
- }
390
- /**
391
- * Adds an NFT and respective NFT contract to the stored NFT and NFT contracts lists.
392
- *
393
- * @param tokenAddress - Hex address of the NFT contract.
394
- * @param tokenId - The NFT identifier.
395
- * @param options - an object of arguments
396
- * @param options.nftMetadata - NFT optional metadata.
397
- * @param options.userAddress - The address of the current user.
398
- * @param options.source - Whether the NFT was detected, added manually or suggested by a dapp.
399
- * @param options.networkClientId - The networkClientId that can be used to identify the network client to use for this request.
400
- * @returns Promise resolving to the current NFT list.
401
- */
402
- async addNft(tokenAddress, tokenId, {
403
- nftMetadata,
404
- userAddress,
405
- source = "custom" /* Custom */,
406
- networkClientId
407
- } = {}) {
408
- const addressToSearch = __privateMethod(this, _getAddressOrSelectedAddress, getAddressOrSelectedAddress_fn).call(this, userAddress);
409
- if (!addressToSearch) {
410
- return;
411
- }
412
- const checksumHexAddress = toChecksumHexAddress(tokenAddress);
413
- const chainId = __privateMethod(this, _getCorrectChainId, getCorrectChainId_fn).call(this, { networkClientId });
414
- nftMetadata = nftMetadata || await __privateMethod(this, _getNftInformation, getNftInformation_fn).call(this, checksumHexAddress, tokenId, networkClientId);
415
- const newNftContracts = await __privateMethod(this, _addNftContract, addNftContract_fn).call(this, {
416
- tokenAddress: checksumHexAddress,
417
- userAddress: addressToSearch,
418
- networkClientId,
419
- source,
420
- nftMetadata
421
- });
422
- const nftContract = newNftContracts.find(
423
- (contract) => contract.address.toLowerCase() === checksumHexAddress.toLowerCase()
424
- );
425
- if (nftContract) {
426
- await __privateMethod(this, _addIndividualNft, addIndividualNft_fn).call(this, checksumHexAddress, tokenId, nftMetadata, nftContract, chainId, addressToSearch, source);
427
- }
428
- }
429
- /**
430
- * Refetches NFT metadata and updates the state
431
- *
432
- * @param options - Options for refetching NFT metadata
433
- * @param options.nfts - nfts to update metadata for.
434
- * @param options.userAddress - The current user address
435
- * @param options.networkClientId - The networkClientId that can be used to identify the network client to use for this request.
436
- */
437
- async updateNftMetadata({
438
- nfts,
439
- userAddress,
440
- networkClientId
441
- }) {
442
- const addressToSearch = __privateMethod(this, _getAddressOrSelectedAddress, getAddressOrSelectedAddress_fn).call(this, userAddress);
443
- const releaseLock = await __privateGet(this, _mutex).acquire();
444
- try {
445
- const chainId = __privateMethod(this, _getCorrectChainId, getCorrectChainId_fn).call(this, { networkClientId });
446
- const nftsWithChecksumAdr = nfts.map((nft) => {
447
- return {
448
- ...nft,
449
- address: toChecksumHexAddress(nft.address)
450
- };
451
- });
452
- const nftMetadataResults = await Promise.all(
453
- nftsWithChecksumAdr.map(async (nft) => {
454
- const resMetadata = await __privateMethod(this, _getNftInformation, getNftInformation_fn).call(this, nft.address, nft.tokenId, networkClientId);
455
- return {
456
- nft,
457
- newMetadata: resMetadata
458
- };
459
- })
460
- );
461
- const nftsWithDifferentMetadata = [];
462
- const { allNfts } = this.state;
463
- const stateNfts = allNfts[addressToSearch]?.[chainId] || [];
464
- nftMetadataResults.forEach((singleNft) => {
465
- const existingEntry = stateNfts.find(
466
- (nft) => nft.address.toLowerCase() === singleNft.nft.address.toLowerCase() && nft.tokenId === singleNft.nft.tokenId
467
- );
468
- if (existingEntry) {
469
- const differentMetadata = compareNftMetadata(
470
- singleNft.newMetadata,
471
- existingEntry
472
- );
473
- if (differentMetadata) {
474
- nftsWithDifferentMetadata.push(singleNft);
475
- }
476
- }
477
- });
478
- if (nftsWithDifferentMetadata.length !== 0) {
479
- nftsWithDifferentMetadata.forEach(
480
- (elm) => this.updateNft(elm.nft, elm.newMetadata, addressToSearch, chainId)
481
- );
482
- }
483
- } finally {
484
- releaseLock();
485
- }
486
- }
487
- /**
488
- * Removes an NFT from the stored token list.
489
- *
490
- * @param address - Hex address of the NFT contract.
491
- * @param tokenId - Token identifier of the NFT.
492
- * @param options - an object of arguments
493
- * @param options.networkClientId - The networkClientId that can be used to identify the network client to use for this request.
494
- * @param options.userAddress - The address of the account where the NFT is being removed.
495
- */
496
- removeNft(address, tokenId, {
497
- networkClientId,
498
- userAddress
499
- } = {}) {
500
- const addressToSearch = __privateMethod(this, _getAddressOrSelectedAddress, getAddressOrSelectedAddress_fn).call(this, userAddress);
501
- const chainId = __privateMethod(this, _getCorrectChainId, getCorrectChainId_fn).call(this, { networkClientId });
502
- const checksumHexAddress = toChecksumHexAddress(address);
503
- __privateMethod(this, _removeIndividualNft, removeIndividualNft_fn).call(this, checksumHexAddress, tokenId, {
504
- chainId,
505
- userAddress: addressToSearch
506
- });
507
- const { allNfts } = this.state;
508
- const nfts = allNfts[addressToSearch]?.[chainId] || [];
509
- const remainingNft = nfts.find(
510
- (nft) => nft.address.toLowerCase() === checksumHexAddress.toLowerCase()
511
- );
512
- if (!remainingNft) {
513
- __privateMethod(this, _removeNftContract, removeNftContract_fn).call(this, checksumHexAddress, {
514
- chainId,
515
- userAddress: addressToSearch
516
- });
517
- }
518
- }
519
- /**
520
- * Removes an NFT from the stored token list and saves it in ignored NFTs list.
521
- *
522
- * @param address - Hex address of the NFT contract.
523
- * @param tokenId - Token identifier of the NFT.
524
- * @param options - an object of arguments
525
- * @param options.networkClientId - The networkClientId that can be used to identify the network client to use for this request.
526
- * @param options.userAddress - The address of the account where the NFT is being removed.
527
- */
528
- removeAndIgnoreNft(address, tokenId, {
529
- networkClientId,
530
- userAddress
531
- } = {}) {
532
- const addressToSearch = __privateMethod(this, _getAddressOrSelectedAddress, getAddressOrSelectedAddress_fn).call(this, userAddress);
533
- const chainId = __privateMethod(this, _getCorrectChainId, getCorrectChainId_fn).call(this, { networkClientId });
534
- const checksumHexAddress = toChecksumHexAddress(address);
535
- __privateMethod(this, _removeAndIgnoreIndividualNft, removeAndIgnoreIndividualNft_fn).call(this, checksumHexAddress, tokenId, {
536
- chainId,
537
- userAddress: addressToSearch
538
- });
539
- const { allNfts } = this.state;
540
- const nfts = allNfts[addressToSearch]?.[chainId] || [];
541
- const remainingNft = nfts.find(
542
- (nft) => nft.address.toLowerCase() === checksumHexAddress.toLowerCase()
543
- );
544
- if (!remainingNft) {
545
- __privateMethod(this, _removeNftContract, removeNftContract_fn).call(this, checksumHexAddress, {
546
- chainId,
547
- userAddress: addressToSearch
548
- });
549
- }
550
- }
551
- /**
552
- * Removes all NFTs from the ignored list.
553
- */
554
- clearIgnoredNfts() {
555
- this.update((state) => {
556
- state.ignoredNfts = [];
557
- });
558
- }
559
- /**
560
- * Checks whether input NFT is still owned by the user
561
- * And updates the isCurrentlyOwned value on the NFT object accordingly.
562
- *
563
- * @param nft - The NFT object to check and update.
564
- * @param batch - A boolean indicating whether this method is being called as part of a batch or single update.
565
- * @param accountParams - The userAddress and chainId to check ownership against
566
- * @param accountParams.userAddress - the address passed through the confirmed transaction flow to ensure assets are stored to the correct account
567
- * @param accountParams.networkClientId - The networkClientId that can be used to identify the network client to use for this request.
568
- * @returns the NFT with the updated isCurrentlyOwned value
569
- */
570
- async checkAndUpdateSingleNftOwnershipStatus(nft, batch, {
571
- userAddress,
572
- networkClientId
573
- } = {}) {
574
- const addressToSearch = __privateMethod(this, _getAddressOrSelectedAddress, getAddressOrSelectedAddress_fn).call(this, userAddress);
575
- const chainId = __privateMethod(this, _getCorrectChainId, getCorrectChainId_fn).call(this, { networkClientId });
576
- const { address, tokenId } = nft;
577
- let isOwned = nft.isCurrentlyOwned;
578
- try {
579
- isOwned = await this.isNftOwner(addressToSearch, address, tokenId, {
580
- networkClientId
581
- });
582
- } catch {
583
- }
584
- const updatedNft = {
585
- ...nft,
586
- isCurrentlyOwned: isOwned
587
- };
588
- if (batch) {
589
- return updatedNft;
590
- }
591
- const { allNfts } = this.state;
592
- const nfts = [...allNfts[addressToSearch]?.[chainId] || []];
593
- const indexToUpdate = nfts.findIndex(
594
- (item) => item.tokenId === tokenId && item.address.toLowerCase() === address.toLowerCase()
595
- );
596
- if (indexToUpdate !== -1) {
597
- nfts[indexToUpdate] = updatedNft;
598
- this.update((state) => {
599
- state.allNfts[addressToSearch] = Object.assign(
600
- {},
601
- state.allNfts[addressToSearch],
602
- {
603
- [chainId]: nfts
604
- }
605
- );
606
- });
607
- __privateMethod(this, _updateNestedNftState, updateNestedNftState_fn).call(this, nfts, ALL_NFTS_STATE_KEY, {
608
- userAddress: addressToSearch,
609
- chainId
610
- });
611
- }
612
- return updatedNft;
613
- }
614
- /**
615
- * Checks whether NFTs associated with current selectedAddress/chainId combination are still owned by the user
616
- * And updates the isCurrentlyOwned value on each accordingly.
617
- * @param options - an object of arguments
618
- * @param options.networkClientId - The networkClientId that can be used to identify the network client to use for this request.
619
- * @param options.userAddress - The address of the account where the NFT ownership status is checked/updated.
620
- */
621
- async checkAndUpdateAllNftsOwnershipStatus({
622
- networkClientId,
623
- userAddress
624
- } = {}) {
625
- const addressToSearch = __privateMethod(this, _getAddressOrSelectedAddress, getAddressOrSelectedAddress_fn).call(this, userAddress);
626
- const chainId = __privateMethod(this, _getCorrectChainId, getCorrectChainId_fn).call(this, { networkClientId });
627
- const { allNfts } = this.state;
628
- const nfts = allNfts[addressToSearch]?.[chainId] || [];
629
- const updatedNfts = await Promise.all(
630
- nfts.map(async (nft) => {
631
- return await this.checkAndUpdateSingleNftOwnershipStatus(nft, true, {
632
- networkClientId,
633
- userAddress
634
- }) ?? nft;
635
- })
636
- );
637
- __privateMethod(this, _updateNestedNftState, updateNestedNftState_fn).call(this, updatedNfts, ALL_NFTS_STATE_KEY, {
638
- userAddress: addressToSearch,
639
- chainId
640
- });
641
- }
642
- /**
643
- * Update NFT favorite status.
644
- *
645
- * @param address - Hex address of the NFT contract.
646
- * @param tokenId - Hex address of the NFT contract.
647
- * @param favorite - NFT new favorite status.
648
- * @param options - an object of arguments
649
- * @param options.networkClientId - The networkClientId that can be used to identify the network client to use for this request.
650
- * @param options.userAddress - The address of the account where the NFT is being removed.
651
- */
652
- updateNftFavoriteStatus(address, tokenId, favorite, {
653
- networkClientId,
654
- userAddress
655
- } = {}) {
656
- const addressToSearch = __privateMethod(this, _getAddressOrSelectedAddress, getAddressOrSelectedAddress_fn).call(this, userAddress);
657
- const chainId = __privateMethod(this, _getCorrectChainId, getCorrectChainId_fn).call(this, { networkClientId });
658
- const { allNfts } = this.state;
659
- const nfts = [...allNfts[addressToSearch]?.[chainId] || []];
660
- const index = nfts.findIndex(
661
- (nft) => nft.address === address && nft.tokenId === tokenId
662
- );
663
- if (index === -1) {
664
- return;
665
- }
666
- const updatedNft = {
667
- ...nfts[index],
668
- favorite
669
- };
670
- nfts[index] = updatedNft;
671
- __privateMethod(this, _updateNestedNftState, updateNestedNftState_fn).call(this, nfts, ALL_NFTS_STATE_KEY, {
672
- chainId,
673
- userAddress: addressToSearch
674
- });
675
- }
676
- /**
677
- * Returns an NFT by the address and token id.
678
- *
679
- * @param address - Hex address of the NFT contract.
680
- * @param tokenId - Number that represents the id of the token.
681
- * @param selectedAddress - Hex address of the user account.
682
- * @param chainId - Id of the current network.
683
- * @returns Object containing the NFT and its position in the array
684
- */
685
- findNftByAddressAndTokenId(address, tokenId, selectedAddress, chainId) {
686
- const { allNfts } = this.state;
687
- const nfts = allNfts[selectedAddress]?.[chainId] || [];
688
- const index = nfts.findIndex(
689
- (nft) => nft.address.toLowerCase() === address.toLowerCase() && nft.tokenId === tokenId
690
- );
691
- if (index === -1) {
692
- return null;
693
- }
694
- return { nft: nfts[index], index };
695
- }
696
- /**
697
- * Update NFT data.
698
- *
699
- * @param nft - NFT object to find the right NFT to updates.
700
- * @param updates - NFT partial object to update properties of the NFT.
701
- * @param selectedAddress - Hex address of the user account.
702
- * @param chainId - Id of the current network.
703
- */
704
- updateNft(nft, updates, selectedAddress, chainId) {
705
- const { allNfts } = this.state;
706
- const nfts = allNfts[selectedAddress]?.[chainId] || [];
707
- const nftInfo = this.findNftByAddressAndTokenId(
708
- nft.address,
709
- nft.tokenId,
710
- selectedAddress,
711
- chainId
712
- );
713
- if (!nftInfo) {
714
- return;
715
- }
716
- const updatedNft = {
717
- ...nft,
718
- ...updates
719
- };
720
- const newNfts = [
721
- ...nfts.slice(0, nftInfo.index),
722
- updatedNft,
723
- ...nfts.slice(nftInfo.index + 1)
724
- ];
725
- __privateMethod(this, _updateNestedNftState, updateNestedNftState_fn).call(this, newNfts, ALL_NFTS_STATE_KEY, {
726
- chainId,
727
- userAddress: selectedAddress
728
- });
729
- }
730
- /**
731
- * Resets the transaction status of an NFT.
732
- *
733
- * @param transactionId - NFT transaction id.
734
- * @param selectedAddress - Hex address of the user account.
735
- * @param chainId - Id of the current network.
736
- * @returns a boolean indicating if the reset was well succeeded or not
737
- */
738
- resetNftTransactionStatusByTransactionId(transactionId, selectedAddress, chainId) {
739
- const { allNfts } = this.state;
740
- const nfts = allNfts[selectedAddress]?.[chainId] || [];
741
- const index = nfts.findIndex(
742
- (nft) => nft.transactionId === transactionId
743
- );
744
- if (index === -1) {
745
- return false;
746
- }
747
- const updatedNft = {
748
- ...nfts[index],
749
- transactionId: void 0
750
- };
751
- const newNfts = [
752
- ...nfts.slice(0, index),
753
- updatedNft,
754
- ...nfts.slice(index + 1)
755
- ];
756
- __privateMethod(this, _updateNestedNftState, updateNestedNftState_fn).call(this, newNfts, ALL_NFTS_STATE_KEY, {
757
- chainId,
758
- userAddress: selectedAddress
759
- });
760
- return true;
761
- }
762
- /**
763
- * Fetches NFT Collection Metadata from the NFT API.
764
- *
765
- * @param contractAddresses - The contract addresses of the NFTs.
766
- * @param chainId - The chain ID of the network where the NFT is located.
767
- * @returns NFT collections metadata.
768
- */
769
- async getNFTContractInfo(contractAddresses, chainId) {
770
- const url = new URL(__privateMethod(this, _getNftCollectionApi, getNftCollectionApi_fn).call(this));
771
- url.searchParams.append("chainId", chainId);
772
- for (const address of contractAddresses) {
773
- url.searchParams.append("contract", address);
774
- }
775
- return await handleFetch(url, {
776
- headers: {
777
- Version: NFT_API_VERSION
778
- }
779
- });
780
- }
781
- async _requestApproval(suggestedNftMeta) {
782
- return this.messagingSystem.call(
783
- "ApprovalController:addRequest",
784
- {
785
- id: suggestedNftMeta.id,
786
- origin: suggestedNftMeta.origin,
787
- type: ApprovalType.WatchAsset,
788
- requestData: {
789
- id: suggestedNftMeta.id,
790
- interactingAddress: suggestedNftMeta.interactingAddress,
791
- asset: {
792
- address: suggestedNftMeta.asset.address,
793
- tokenId: suggestedNftMeta.asset.tokenId,
794
- name: suggestedNftMeta.asset.name,
795
- description: suggestedNftMeta.asset.description,
796
- image: suggestedNftMeta.asset.image,
797
- standard: suggestedNftMeta.asset.standard
798
- }
799
- }
800
- },
801
- true
802
- );
803
- }
804
- };
805
- _mutex = new WeakMap();
806
- _selectedAccountId = new WeakMap();
807
- _chainId = new WeakMap();
808
- _ipfsGateway = new WeakMap();
809
- _openSeaEnabled = new WeakMap();
810
- _useIpfsSubdomains = new WeakMap();
811
- _isIpfsGatewayEnabled = new WeakMap();
812
- _onNftAdded = new WeakMap();
813
- _onNetworkControllerNetworkDidChange = new WeakSet();
814
- onNetworkControllerNetworkDidChange_fn = function({
815
- selectedNetworkClientId
816
- }) {
817
- const {
818
- configuration: { chainId }
819
- } = this.messagingSystem.call(
820
- "NetworkController:getNetworkClientById",
821
- selectedNetworkClientId
822
- );
823
- __privateSet(this, _chainId, chainId);
824
- };
825
- _onPreferencesControllerStateChange = new WeakSet();
826
- onPreferencesControllerStateChange_fn = async function({
827
- ipfsGateway,
828
- openSeaEnabled,
829
- isIpfsGatewayEnabled
830
- }) {
831
- const selectedAccount = this.messagingSystem.call(
832
- "AccountsController:getSelectedAccount"
833
- );
834
- __privateSet(this, _selectedAccountId, selectedAccount.id);
835
- __privateSet(this, _ipfsGateway, ipfsGateway);
836
- __privateSet(this, _openSeaEnabled, openSeaEnabled);
837
- __privateSet(this, _isIpfsGatewayEnabled, isIpfsGatewayEnabled);
838
- const needsUpdateNftMetadata = isIpfsGatewayEnabled && ipfsGateway !== "" || openSeaEnabled;
839
- if (needsUpdateNftMetadata && selectedAccount) {
840
- await __privateMethod(this, _updateNftUpdateForAccount, updateNftUpdateForAccount_fn).call(this, selectedAccount);
841
- }
842
- };
843
- _onSelectedAccountChange = new WeakSet();
844
- onSelectedAccountChange_fn = async function(internalAccount) {
845
- const oldSelectedAccountId = __privateGet(this, _selectedAccountId);
846
- __privateSet(this, _selectedAccountId, internalAccount.id);
847
- const needsUpdateNftMetadata = (__privateGet(this, _isIpfsGatewayEnabled) && __privateGet(this, _ipfsGateway) !== "" || __privateGet(this, _openSeaEnabled)) && oldSelectedAccountId !== internalAccount.id;
848
- if (needsUpdateNftMetadata) {
849
- await __privateMethod(this, _updateNftUpdateForAccount, updateNftUpdateForAccount_fn).call(this, internalAccount);
850
- }
851
- };
852
- _updateNestedNftState = new WeakSet();
853
- updateNestedNftState_fn = function(newCollection, baseStateKey, { userAddress, chainId }) {
854
- if (!userAddress) {
855
- return;
856
- }
857
- this.update((state) => {
858
- const oldState = state[baseStateKey];
859
- const addressState = oldState[userAddress] || {};
860
- const newAddressState = {
861
- ...addressState,
862
- [chainId]: newCollection
863
- };
864
- state[baseStateKey] = {
865
- ...oldState,
866
- [userAddress]: newAddressState
867
- };
868
- });
869
- };
870
- _getNftCollectionApi = new WeakSet();
871
- getNftCollectionApi_fn = function() {
872
- return `${NFT_API_BASE_URL}/collections`;
873
- };
874
- _getNftInformationFromApi = new WeakSet();
875
- getNftInformationFromApi_fn = async function(contractAddress, tokenId) {
876
- const urlParams = new URLSearchParams({
877
- chainIds: "1",
878
- tokens: `${contractAddress}:${tokenId}`,
879
- includeTopBid: "true",
880
- includeAttributes: "true",
881
- includeLastSale: "true"
882
- }).toString();
883
- const nftInformation = await fetchWithErrorHandling({
884
- url: `${this.getNftApi()}?${urlParams}`,
885
- options: {
886
- headers: {
887
- Version: NFT_API_VERSION
888
- }
889
- }
890
- });
891
- const getCollectionParams = new URLSearchParams({
892
- chainId: "1",
893
- id: `${nftInformation?.tokens[0]?.token?.collection?.id}`
894
- }).toString();
895
- const collectionInformation = await fetchWithErrorHandling({
896
- url: `${NFT_API_BASE_URL}/collections?${getCollectionParams}`,
897
- options: {
898
- headers: {
899
- Version: NFT_API_VERSION
900
- }
901
- }
902
- });
903
- if (!nftInformation?.tokens?.[0]?.token) {
904
- return {
905
- name: null,
906
- description: null,
907
- image: null,
908
- standard: null
909
- };
910
- }
911
- const {
912
- image,
913
- metadata: { imageOriginal } = {},
914
- name,
915
- description,
916
- collection,
917
- kind,
918
- rarityRank,
919
- rarity,
920
- attributes,
921
- lastSale,
922
- imageSmall
923
- } = nftInformation.tokens[0].token;
924
- const nftMetadata = Object.assign(
925
- {},
926
- { name: name || null },
927
- { description: description || null },
928
- { image: image || null },
929
- collection?.creator && { creator: collection.creator },
930
- imageOriginal && { imageOriginal },
931
- imageSmall && { imageThumbnail: imageSmall },
932
- kind && { standard: kind.toUpperCase() },
933
- lastSale && { lastSale },
934
- attributes && { attributes },
935
- nftInformation.tokens[0].market?.topBid && {
936
- topBid: nftInformation.tokens[0].market?.topBid
937
- },
938
- rarityRank && { rarityRank },
939
- rarity && { rarity },
940
- (collection || collectionInformation) && {
941
- collection: {
942
- ...collection || {},
943
- creator: collection?.creator || collectionInformation?.collections[0].creator,
944
- openseaVerificationStatus: collectionInformation?.collections[0].openseaVerificationStatus,
945
- contractDeployedAt: collectionInformation?.collections[0].contractDeployedAt,
946
- ownerCount: collectionInformation?.collections[0].ownerCount,
947
- topBid: collectionInformation?.collections[0].topBid
948
- }
949
- }
950
- );
951
- return nftMetadata;
952
- };
953
- _getNftInformationFromTokenURI = new WeakSet();
954
- getNftInformationFromTokenURI_fn = async function(contractAddress, tokenId, networkClientId) {
955
- const result = await __privateMethod(this, _getNftURIAndStandard, getNftURIAndStandard_fn).call(this, contractAddress, tokenId, networkClientId);
956
- let tokenURI = result[0];
957
- const standard = result[1];
958
- const hasIpfsTokenURI = tokenURI.startsWith("ipfs://");
959
- if (hasIpfsTokenURI && !__privateGet(this, _isIpfsGatewayEnabled)) {
960
- return {
961
- image: null,
962
- name: null,
963
- description: null,
964
- standard: standard || null,
965
- favorite: false,
966
- tokenURI: tokenURI ?? null
967
- };
968
- }
969
- const isDisplayNFTMediaToggleEnabled = __privateGet(this, _openSeaEnabled);
970
- if (!hasIpfsTokenURI && !isDisplayNFTMediaToggleEnabled) {
971
- return {
972
- image: null,
973
- name: null,
974
- description: null,
975
- standard: standard || null,
976
- favorite: false,
977
- tokenURI: tokenURI ?? null
978
- };
979
- }
980
- if (hasIpfsTokenURI) {
981
- tokenURI = await getFormattedIpfsUrl(
982
- __privateGet(this, _ipfsGateway),
983
- tokenURI,
984
- __privateGet(this, _useIpfsSubdomains)
985
- );
986
- }
987
- if (tokenURI.startsWith("data:image/")) {
988
- return {
989
- image: tokenURI,
990
- name: null,
991
- description: null,
992
- standard: standard || null,
993
- favorite: false,
994
- tokenURI: tokenURI ?? null
995
- };
996
- }
997
- try {
998
- const object = await handleFetch(tokenURI);
999
- const image = Object.prototype.hasOwnProperty.call(object, "image") ? "image" : (
1000
- /* istanbul ignore next */
1001
- "image_url"
1002
- );
1003
- return {
1004
- image: object[image],
1005
- name: object.name,
1006
- description: object.description,
1007
- standard,
1008
- favorite: false,
1009
- tokenURI: tokenURI ?? null
1010
- };
1011
- } catch {
1012
- return {
1013
- image: null,
1014
- name: null,
1015
- description: null,
1016
- standard: standard || null,
1017
- favorite: false,
1018
- tokenURI: tokenURI ?? null
1019
- };
1020
- }
1021
- };
1022
- _getNftURIAndStandard = new WeakSet();
1023
- getNftURIAndStandard_fn = async function(contractAddress, tokenId, networkClientId) {
1024
- try {
1025
- const uri = await this.messagingSystem.call(
1026
- "AssetsContractController:getERC721TokenURI",
1027
- contractAddress,
1028
- tokenId,
1029
- networkClientId
1030
- );
1031
- return [uri, ERC721];
1032
- } catch {
1033
- }
1034
- try {
1035
- const tokenURI = await this.messagingSystem.call(
1036
- "AssetsContractController:getERC1155TokenURI",
1037
- contractAddress,
1038
- tokenId,
1039
- networkClientId
1040
- );
1041
- if (!tokenURI.includes("{id}")) {
1042
- return [tokenURI, ERC1155];
1043
- }
1044
- const hexTokenId = remove0x(BNToHex(new BN(tokenId))).padStart(64, "0").toLowerCase();
1045
- return [tokenURI.replace("{id}", hexTokenId), ERC1155];
1046
- } catch {
1047
- }
1048
- return ["", ""];
1049
- };
1050
- _getNftInformation = new WeakSet();
1051
- getNftInformation_fn = async function(contractAddress, tokenId, networkClientId) {
1052
- const chainId = __privateMethod(this, _getCorrectChainId, getCorrectChainId_fn).call(this, {
1053
- networkClientId
1054
- });
1055
- const [blockchainMetadata, nftApiMetadata] = await Promise.all([
1056
- safelyExecute(
1057
- () => __privateMethod(this, _getNftInformationFromTokenURI, getNftInformationFromTokenURI_fn).call(this, contractAddress, tokenId, networkClientId)
1058
- ),
1059
- __privateGet(this, _openSeaEnabled) && chainId === "0x1" ? safelyExecute(
1060
- () => __privateMethod(this, _getNftInformationFromApi, getNftInformationFromApi_fn).call(this, contractAddress, tokenId)
1061
- ) : void 0
1062
- ]);
1063
- return {
1064
- ...nftApiMetadata,
1065
- name: blockchainMetadata?.name ?? nftApiMetadata?.name ?? null,
1066
- description: blockchainMetadata?.description ?? nftApiMetadata?.description ?? null,
1067
- image: nftApiMetadata?.image ?? blockchainMetadata?.image ?? null,
1068
- standard: blockchainMetadata?.standard ?? nftApiMetadata?.standard ?? null,
1069
- tokenURI: blockchainMetadata?.tokenURI ?? null
1070
- };
1071
- };
1072
- _getNftContractInformationFromContract = new WeakSet();
1073
- getNftContractInformationFromContract_fn = async function(contractAddress, networkClientId) {
1074
- const [name, symbol] = await Promise.all([
1075
- this.messagingSystem.call(
1076
- "AssetsContractController:getERC721AssetName",
1077
- contractAddress,
1078
- networkClientId
1079
- ),
1080
- this.messagingSystem.call(
1081
- "AssetsContractController:getERC721AssetSymbol",
1082
- contractAddress,
1083
- networkClientId
1084
- )
1085
- ]);
1086
- return {
1087
- collection: { name },
1088
- symbol,
1089
- address: contractAddress
1090
- };
1091
- };
1092
- _getNftContractInformation = new WeakSet();
1093
- getNftContractInformation_fn = async function(contractAddress, nftMetadataFromApi, networkClientId) {
1094
- const blockchainContractData = await safelyExecute(
1095
- () => __privateMethod(this, _getNftContractInformationFromContract, getNftContractInformationFromContract_fn).call(this, contractAddress, networkClientId)
1096
- );
1097
- if (blockchainContractData || !Object.values(nftMetadataFromApi).every((value) => value === null)) {
1098
- return {
1099
- address: contractAddress,
1100
- ...blockchainContractData,
1101
- // TODO: Either fix this lint violation or explain why it's necessary to ignore.
1102
- // eslint-disable-next-line @typescript-eslint/naming-convention
1103
- schema_name: nftMetadataFromApi?.standard ?? null,
1104
- collection: {
1105
- name: null,
1106
- // TODO: Either fix this lint violation or explain why it's necessary to ignore.
1107
- // eslint-disable-next-line @typescript-eslint/naming-convention
1108
- image_url: nftMetadataFromApi?.collection?.image ?? nftMetadataFromApi?.collection?.imageUrl ?? null,
1109
- tokenCount: nftMetadataFromApi?.collection?.tokenCount ?? null,
1110
- ...nftMetadataFromApi?.collection,
1111
- ...blockchainContractData?.collection
1112
- }
1113
- };
1114
- }
1115
- return {
1116
- address: contractAddress,
1117
- // TODO: Either fix this lint violation or explain why it's necessary to ignore.
1118
- // eslint-disable-next-line @typescript-eslint/naming-convention
1119
- asset_contract_type: null,
1120
- // TODO: Either fix this lint violation or explain why it's necessary to ignore.
1121
- // eslint-disable-next-line @typescript-eslint/naming-convention
1122
- created_date: null,
1123
- // TODO: Either fix this lint violation or explain why it's necessary to ignore.
1124
- // eslint-disable-next-line @typescript-eslint/naming-convention
1125
- schema_name: null,
1126
- symbol: null,
1127
- // TODO: Either fix this lint violation or explain why it's necessary to ignore.
1128
- // eslint-disable-next-line @typescript-eslint/naming-convention
1129
- total_supply: null,
1130
- description: null,
1131
- // TODO: Either fix this lint violation or explain why it's necessary to ignore.
1132
- // eslint-disable-next-line @typescript-eslint/naming-convention
1133
- external_link: null,
1134
- // TODO: Either fix this lint violation or explain why it's necessary to ignore.
1135
- // eslint-disable-next-line @typescript-eslint/naming-convention
1136
- collection: { name: null, image_url: null }
1137
- };
1138
- };
1139
- _addIndividualNft = new WeakSet();
1140
- addIndividualNft_fn = async function(tokenAddress, tokenId, nftMetadata, nftContract, chainId, userAddress, source) {
1141
- const releaseLock = await __privateGet(this, _mutex).acquire();
1142
- try {
1143
- const checksumHexAddress = toChecksumHexAddress(tokenAddress);
1144
- const { allNfts } = this.state;
1145
- const nfts = [...allNfts[userAddress]?.[chainId] ?? []];
1146
- const existingEntry = nfts.find(
1147
- (nft) => nft.address.toLowerCase() === checksumHexAddress.toLowerCase() && nft.tokenId === tokenId
1148
- );
1149
- if (existingEntry) {
1150
- const differentMetadata = compareNftMetadata(
1151
- nftMetadata,
1152
- existingEntry
1153
- );
1154
- const hasNewFields = hasNewCollectionFields(nftMetadata, existingEntry);
1155
- if (!differentMetadata && existingEntry.isCurrentlyOwned && !hasNewFields) {
1156
- return;
1157
- }
1158
- const indexToUpdate = nfts.findIndex(
1159
- (nft) => nft.address.toLowerCase() === checksumHexAddress.toLowerCase() && nft.tokenId === tokenId
1160
- );
1161
- if (indexToUpdate !== -1) {
1162
- nfts[indexToUpdate] = {
1163
- ...existingEntry,
1164
- ...nftMetadata
1165
- };
1166
- }
1167
- } else {
1168
- const newEntry = {
1169
- address: checksumHexAddress,
1170
- tokenId,
1171
- favorite: false,
1172
- isCurrentlyOwned: true,
1173
- ...nftMetadata
1174
- };
1175
- nfts.push(newEntry);
1176
- }
1177
- __privateMethod(this, _updateNestedNftState, updateNestedNftState_fn).call(this, nfts, ALL_NFTS_STATE_KEY, {
1178
- chainId,
1179
- userAddress
1180
- });
1181
- if (__privateGet(this, _onNftAdded)) {
1182
- __privateGet(this, _onNftAdded).call(this, {
1183
- address: checksumHexAddress,
1184
- symbol: nftContract.symbol,
1185
- tokenId: tokenId.toString(),
1186
- standard: nftMetadata.standard,
1187
- source
1188
- });
1189
- }
1190
- } finally {
1191
- releaseLock();
1192
- }
1193
- };
1194
- _addNftContract = new WeakSet();
1195
- addNftContract_fn = async function({
1196
- tokenAddress,
1197
- userAddress,
1198
- networkClientId,
1199
- source,
1200
- nftMetadata
1201
- }) {
1202
- const releaseLock = await __privateGet(this, _mutex).acquire();
1203
- try {
1204
- const checksumHexAddress = toChecksumHexAddress(tokenAddress);
1205
- const { allNftContracts } = this.state;
1206
- const chainId = __privateMethod(this, _getCorrectChainId, getCorrectChainId_fn).call(this, {
1207
- networkClientId
1208
- });
1209
- const nftContracts = allNftContracts[userAddress]?.[chainId] || [];
1210
- const existingEntry = nftContracts.find(
1211
- (nftContract) => nftContract.address.toLowerCase() === checksumHexAddress.toLowerCase()
1212
- );
1213
- if (existingEntry) {
1214
- return nftContracts;
1215
- }
1216
- const contractInformation = await __privateMethod(this, _getNftContractInformation, getNftContractInformation_fn).call(this, checksumHexAddress, nftMetadata, networkClientId);
1217
- const {
1218
- // TODO: Either fix this lint violation or explain why it's necessary to ignore.
1219
- // eslint-disable-next-line @typescript-eslint/naming-convention
1220
- asset_contract_type,
1221
- // TODO: Either fix this lint violation or explain why it's necessary to ignore.
1222
- // eslint-disable-next-line @typescript-eslint/naming-convention
1223
- created_date,
1224
- symbol,
1225
- description,
1226
- // TODO: Either fix this lint violation or explain why it's necessary to ignore.
1227
- // eslint-disable-next-line @typescript-eslint/naming-convention
1228
- external_link,
1229
- // TODO: Either fix this lint violation or explain why it's necessary to ignore.
1230
- // eslint-disable-next-line @typescript-eslint/naming-convention
1231
- schema_name,
1232
- // TODO: Either fix this lint violation or explain why it's necessary to ignore.
1233
- // eslint-disable-next-line @typescript-eslint/naming-convention
1234
- collection: { name, image_url, tokenCount }
1235
- } = contractInformation;
1236
- if (source === "detected" /* Detected */ && "address" in contractInformation && typeof contractInformation.address === "string" && "collection" in contractInformation && contractInformation.collection.name === null && "image_url" in contractInformation.collection && contractInformation.collection.image_url === null && Object.entries(contractInformation).every(([key, value]) => {
1237
- return key === "address" || key === "collection" || !value;
1238
- })) {
1239
- return nftContracts;
1240
- }
1241
- const newEntry = Object.assign(
1242
- {},
1243
- { address: checksumHexAddress },
1244
- description && { description },
1245
- name && { name },
1246
- image_url && { logo: image_url },
1247
- symbol && { symbol },
1248
- tokenCount !== null && typeof tokenCount !== "undefined" && { totalSupply: tokenCount },
1249
- asset_contract_type && { assetContractType: asset_contract_type },
1250
- created_date && { createdDate: created_date },
1251
- schema_name && { schemaName: schema_name },
1252
- external_link && { externalLink: external_link }
1253
- );
1254
- const newNftContracts = [...nftContracts, newEntry];
1255
- __privateMethod(this, _updateNestedNftState, updateNestedNftState_fn).call(this, newNftContracts, ALL_NFTS_CONTRACTS_STATE_KEY, {
1256
- chainId,
1257
- userAddress
1258
- });
1259
- return newNftContracts;
1260
- } finally {
1261
- releaseLock();
1262
- }
1263
- };
1264
- _removeAndIgnoreIndividualNft = new WeakSet();
1265
- removeAndIgnoreIndividualNft_fn = function(address, tokenId, {
1266
- chainId,
1267
- userAddress
1268
- }) {
1269
- const checksumHexAddress = toChecksumHexAddress(address);
1270
- const { allNfts, ignoredNfts } = this.state;
1271
- const newIgnoredNfts = [...ignoredNfts];
1272
- const nfts = allNfts[userAddress]?.[chainId] || [];
1273
- const newNfts = nfts.filter((nft) => {
1274
- if (nft.address.toLowerCase() === checksumHexAddress.toLowerCase() && nft.tokenId === tokenId) {
1275
- const alreadyIgnored = newIgnoredNfts.find(
1276
- (c) => c.address === checksumHexAddress && c.tokenId === tokenId
1277
- );
1278
- !alreadyIgnored && newIgnoredNfts.push(nft);
1279
- return false;
1280
- }
1281
- return true;
1282
- });
1283
- __privateMethod(this, _updateNestedNftState, updateNestedNftState_fn).call(this, newNfts, ALL_NFTS_STATE_KEY, {
1284
- userAddress,
1285
- chainId
1286
- });
1287
- this.update((state) => {
1288
- state.ignoredNfts = newIgnoredNfts;
1289
- });
1290
- };
1291
- _removeIndividualNft = new WeakSet();
1292
- removeIndividualNft_fn = function(address, tokenId, { chainId, userAddress }) {
1293
- const checksumHexAddress = toChecksumHexAddress(address);
1294
- const { allNfts } = this.state;
1295
- const nfts = allNfts[userAddress]?.[chainId] || [];
1296
- const newNfts = nfts.filter(
1297
- (nft) => !(nft.address.toLowerCase() === checksumHexAddress.toLowerCase() && nft.tokenId === tokenId)
1298
- );
1299
- __privateMethod(this, _updateNestedNftState, updateNestedNftState_fn).call(this, newNfts, ALL_NFTS_STATE_KEY, {
1300
- userAddress,
1301
- chainId
1302
- });
1303
- };
1304
- _removeNftContract = new WeakSet();
1305
- removeNftContract_fn = function(address, { chainId, userAddress }) {
1306
- const checksumHexAddress = toChecksumHexAddress(address);
1307
- const { allNftContracts } = this.state;
1308
- const nftContracts = allNftContracts[userAddress]?.[chainId] || [];
1309
- const newNftContracts = nftContracts.filter(
1310
- (nftContract) => !(nftContract.address.toLowerCase() === checksumHexAddress.toLowerCase())
1311
- );
1312
- __privateMethod(this, _updateNestedNftState, updateNestedNftState_fn).call(this, newNftContracts, ALL_NFTS_CONTRACTS_STATE_KEY, {
1313
- chainId,
1314
- userAddress
1315
- });
1316
- return newNftContracts;
1317
- };
1318
- _validateWatchNft = new WeakSet();
1319
- validateWatchNft_fn = async function(asset, type, userAddress, { networkClientId } = {}) {
1320
- const { address: contractAddress, tokenId } = asset;
1321
- if (!type) {
1322
- throw rpcErrors.invalidParams("Asset type is required");
1323
- }
1324
- if (type !== ERC721 && type !== ERC1155) {
1325
- throw rpcErrors.invalidParams(
1326
- // TODO: Either fix this lint violation or explain why it's necessary to ignore.
1327
- // eslint-disable-next-line @typescript-eslint/restrict-template-expressions
1328
- `Non NFT asset type ${type} not supported by watchNft`
1329
- );
1330
- }
1331
- if (!contractAddress || !tokenId) {
1332
- throw rpcErrors.invalidParams("Both address and tokenId are required");
1333
- }
1334
- if (!isAddress(contractAddress)) {
1335
- throw rpcErrors.invalidParams("Invalid address");
1336
- }
1337
- if (!/^\d+$/u.test(tokenId)) {
1338
- throw rpcErrors.invalidParams("Invalid tokenId");
1339
- }
1340
- try {
1341
- const isOwner = await this.isNftOwner(
1342
- userAddress,
1343
- contractAddress,
1344
- tokenId,
1345
- { networkClientId }
1346
- );
1347
- if (!isOwner) {
1348
- throw rpcErrors.invalidInput(
1349
- "Suggested NFT is not owned by the selected account"
1350
- );
1351
- }
1352
- } catch (error) {
1353
- if (error instanceof Error) {
1354
- throw rpcErrors.resourceUnavailable(error.message);
1355
- }
1356
- throw error;
1357
- }
1358
- };
1359
- _getCorrectChainId = new WeakSet();
1360
- getCorrectChainId_fn = function({
1361
- networkClientId
1362
- }) {
1363
- if (networkClientId) {
1364
- const {
1365
- configuration: { chainId }
1366
- } = this.messagingSystem.call(
1367
- "NetworkController:getNetworkClientById",
1368
- networkClientId
1369
- );
1370
- return chainId;
1371
- }
1372
- return __privateGet(this, _chainId);
1373
- };
1374
- _getAddressOrSelectedAddress = new WeakSet();
1375
- getAddressOrSelectedAddress_fn = function(address) {
1376
- if (address) {
1377
- return address;
1378
- }
1379
- const selectedAccount = this.messagingSystem.call(
1380
- "AccountsController:getAccount",
1381
- __privateGet(this, _selectedAccountId)
1382
- );
1383
- return selectedAccount?.address || "";
1384
- };
1385
- _updateNftUpdateForAccount = new WeakSet();
1386
- updateNftUpdateForAccount_fn = async function(account) {
1387
- const nfts = this.state.allNfts[account.address]?.[__privateGet(this, _chainId)] ?? [];
1388
- const nftsToUpdate = nfts.filter(
1389
- (singleNft) => !singleNft.name && !singleNft.description && !singleNft.image
1390
- );
1391
- if (nftsToUpdate.length !== 0) {
1392
- await this.updateNftMetadata({
1393
- nfts: nftsToUpdate,
1394
- userAddress: account.address
1395
- });
1396
- }
1397
- };
1398
- var NftController_default = NftController;
1399
-
1400
- export {
1401
- getDefaultNftControllerState,
1402
- NftController,
1403
- NftController_default
1404
- };
1405
- //# sourceMappingURL=chunk-SK2B36Q4.mjs.map