@metamask/assets-controllers 27.2.0 → 28.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 (123) hide show
  1. package/CHANGELOG.md +17 -1
  2. package/dist/AssetsContractController.js +6 -6
  3. package/dist/AssetsContractController.mjs +5 -5
  4. package/dist/CurrencyRateController.js +3 -3
  5. package/dist/CurrencyRateController.mjs +2 -2
  6. package/dist/NftController.js +3 -5
  7. package/dist/NftController.mjs +2 -4
  8. package/dist/NftDetectionController.js +4 -4
  9. package/dist/NftDetectionController.mjs +3 -3
  10. package/dist/Standards/ERC20Standard.js +3 -3
  11. package/dist/Standards/ERC20Standard.mjs +2 -2
  12. package/dist/Standards/NftStandards/ERC1155/ERC1155Standard.js +3 -3
  13. package/dist/Standards/NftStandards/ERC1155/ERC1155Standard.mjs +2 -2
  14. package/dist/Standards/NftStandards/ERC721/ERC721Standard.js +3 -3
  15. package/dist/Standards/NftStandards/ERC721/ERC721Standard.mjs +2 -2
  16. package/dist/TokenDetectionController.js +3 -3
  17. package/dist/TokenDetectionController.mjs +2 -2
  18. package/dist/TokenListController.js +4 -4
  19. package/dist/TokenListController.mjs +3 -3
  20. package/dist/TokenRatesController.js +4 -4
  21. package/dist/TokenRatesController.mjs +3 -3
  22. package/dist/TokensController.js +6 -6
  23. package/dist/TokensController.mjs +5 -5
  24. package/dist/assetsUtil.js +2 -8
  25. package/dist/assetsUtil.mjs +1 -7
  26. package/dist/{chunk-IFJWX5RY.mjs → chunk-4PAJC7WC.mjs} +93 -132
  27. package/dist/chunk-4PAJC7WC.mjs.map +1 -0
  28. package/dist/{chunk-WIVSZVF4.mjs → chunk-AC5HGIHS.mjs} +3 -3
  29. package/dist/chunk-AC5HGIHS.mjs.map +1 -0
  30. package/dist/{chunk-355MWUUQ.js → chunk-BM7EPTR6.js} +3 -3
  31. package/dist/{chunk-4YU7CT4O.js → chunk-C4JDCQG2.js} +7 -7
  32. package/dist/{chunk-ZKJSG4TA.mjs → chunk-CNICDMRI.mjs} +4 -4
  33. package/dist/chunk-CNICDMRI.mjs.map +1 -0
  34. package/dist/{chunk-VY7TUOK2.js → chunk-D3N35ABH.js} +3 -3
  35. package/dist/{chunk-RELRWIJN.js → chunk-D6BDJYSK.js} +2 -68
  36. package/dist/chunk-D6BDJYSK.js.map +1 -0
  37. package/dist/{chunk-C4PQK53K.js → chunk-DYH5P3VY.js} +5 -2
  38. package/dist/chunk-DYH5P3VY.js.map +1 -0
  39. package/dist/{chunk-NUBQRDKI.js → chunk-E2SLNUD4.js} +11 -11
  40. package/dist/{chunk-VHCPQS4X.js → chunk-GCWWC4X3.js} +5 -5
  41. package/dist/{chunk-KRTEFV4Q.mjs → chunk-IURNPMBB.mjs} +2 -2
  42. package/dist/{chunk-WSOHBBCO.js → chunk-JEGLHDNA.js} +42 -56
  43. package/dist/chunk-JEGLHDNA.js.map +1 -0
  44. package/dist/{chunk-GLZ66IRX.mjs → chunk-KDMDWUVX.mjs} +41 -55
  45. package/dist/chunk-KDMDWUVX.mjs.map +1 -0
  46. package/dist/{chunk-MQ7TIWBK.mjs → chunk-KS4MOA2T.mjs} +2 -2
  47. package/dist/{chunk-H6TOSWUM.js → chunk-LRKDZWS6.js} +3 -3
  48. package/dist/{chunk-CEENXWOB.mjs → chunk-N5H5KDJZ.mjs} +2 -2
  49. package/dist/{chunk-2IZUMKMY.mjs → chunk-NHX4QGOD.mjs} +3 -3
  50. package/dist/{chunk-TCO22VIO.mjs → chunk-PWZE6KJV.mjs} +5 -2
  51. package/dist/chunk-PWZE6KJV.mjs.map +1 -0
  52. package/dist/{chunk-KSGMD24G.js → chunk-Q6TLNHYC.js} +7 -7
  53. package/dist/{chunk-523YP4Z3.mjs → chunk-QQAG6ECS.mjs} +3 -3
  54. package/dist/{chunk-XEZJ5XMV.js → chunk-QVSSEGA5.js} +7 -7
  55. package/dist/chunk-QVSSEGA5.js.map +1 -0
  56. package/dist/{chunk-23F5W3A2.mjs → chunk-QWACHXRH.mjs} +2 -2
  57. package/dist/{chunk-KCUSDOIE.mjs → chunk-RDWXY4OF.mjs} +4 -4
  58. package/dist/{chunk-PD624ZNK.js → chunk-RUPB4ELK.js} +6 -6
  59. package/dist/{chunk-6NO7Z5DL.js → chunk-TGKUZNML.js} +5 -5
  60. package/dist/chunk-TGKUZNML.js.map +1 -0
  61. package/dist/{chunk-AQIXUBTK.js → chunk-UNKIHWZH.js} +93 -132
  62. package/dist/chunk-UNKIHWZH.js.map +1 -0
  63. package/dist/{chunk-76KGJJJV.mjs → chunk-ZM42FNAQ.mjs} +5 -5
  64. package/dist/{chunk-E5PIGGYR.mjs → chunk-ZPAX2HLQ.mjs} +1 -67
  65. package/dist/chunk-ZPAX2HLQ.mjs.map +1 -0
  66. package/dist/crypto-compare.js +2 -2
  67. package/dist/crypto-compare.mjs +1 -1
  68. package/dist/index.js +15 -15
  69. package/dist/index.mjs +18 -18
  70. package/dist/token-service.js +3 -3
  71. package/dist/token-service.mjs +2 -2
  72. package/dist/tsconfig.build.tsbuildinfo +1 -1
  73. package/dist/types/CurrencyRateController.d.ts +7 -7
  74. package/dist/types/CurrencyRateController.d.ts.map +1 -1
  75. package/dist/types/NftController.d.ts +20 -95
  76. package/dist/types/NftController.d.ts.map +1 -1
  77. package/dist/types/NftDetectionController.d.ts +184 -0
  78. package/dist/types/NftDetectionController.d.ts.map +1 -1
  79. package/dist/types/Standards/NftStandards/ERC721/ERC721Standard.d.ts.map +1 -1
  80. package/dist/types/TokenBalancesController.d.ts +10 -10
  81. package/dist/types/TokenBalancesController.d.ts.map +1 -1
  82. package/dist/types/TokenDetectionController.d.ts +9 -9
  83. package/dist/types/TokenDetectionController.d.ts.map +1 -1
  84. package/dist/types/TokenListController.d.ts +12 -12
  85. package/dist/types/TokenListController.d.ts.map +1 -1
  86. package/dist/types/TokensController.d.ts +10 -10
  87. package/dist/types/TokensController.d.ts.map +1 -1
  88. package/dist/types/assetsUtil.d.ts +1 -21
  89. package/dist/types/assetsUtil.d.ts.map +1 -1
  90. package/dist/types/crypto-compare.d.ts.map +1 -1
  91. package/dist/types/token-prices-service/abstract-token-prices-service.d.ts +3 -3
  92. package/dist/types/token-prices-service/abstract-token-prices-service.d.ts.map +1 -1
  93. package/dist/types/token-prices-service/codefi-v2.d.ts +2 -2
  94. package/dist/types/token-prices-service/codefi-v2.d.ts.map +1 -1
  95. package/package.json +12 -12
  96. package/dist/chunk-6NO7Z5DL.js.map +0 -1
  97. package/dist/chunk-AQIXUBTK.js.map +0 -1
  98. package/dist/chunk-C4PQK53K.js.map +0 -1
  99. package/dist/chunk-E5PIGGYR.mjs.map +0 -1
  100. package/dist/chunk-GLZ66IRX.mjs.map +0 -1
  101. package/dist/chunk-IFJWX5RY.mjs.map +0 -1
  102. package/dist/chunk-RELRWIJN.js.map +0 -1
  103. package/dist/chunk-TCO22VIO.mjs.map +0 -1
  104. package/dist/chunk-WIVSZVF4.mjs.map +0 -1
  105. package/dist/chunk-WSOHBBCO.js.map +0 -1
  106. package/dist/chunk-XEZJ5XMV.js.map +0 -1
  107. package/dist/chunk-ZKJSG4TA.mjs.map +0 -1
  108. /package/dist/{chunk-355MWUUQ.js.map → chunk-BM7EPTR6.js.map} +0 -0
  109. /package/dist/{chunk-4YU7CT4O.js.map → chunk-C4JDCQG2.js.map} +0 -0
  110. /package/dist/{chunk-VY7TUOK2.js.map → chunk-D3N35ABH.js.map} +0 -0
  111. /package/dist/{chunk-NUBQRDKI.js.map → chunk-E2SLNUD4.js.map} +0 -0
  112. /package/dist/{chunk-VHCPQS4X.js.map → chunk-GCWWC4X3.js.map} +0 -0
  113. /package/dist/{chunk-KRTEFV4Q.mjs.map → chunk-IURNPMBB.mjs.map} +0 -0
  114. /package/dist/{chunk-MQ7TIWBK.mjs.map → chunk-KS4MOA2T.mjs.map} +0 -0
  115. /package/dist/{chunk-H6TOSWUM.js.map → chunk-LRKDZWS6.js.map} +0 -0
  116. /package/dist/{chunk-CEENXWOB.mjs.map → chunk-N5H5KDJZ.mjs.map} +0 -0
  117. /package/dist/{chunk-2IZUMKMY.mjs.map → chunk-NHX4QGOD.mjs.map} +0 -0
  118. /package/dist/{chunk-KSGMD24G.js.map → chunk-Q6TLNHYC.js.map} +0 -0
  119. /package/dist/{chunk-523YP4Z3.mjs.map → chunk-QQAG6ECS.mjs.map} +0 -0
  120. /package/dist/{chunk-23F5W3A2.mjs.map → chunk-QWACHXRH.mjs.map} +0 -0
  121. /package/dist/{chunk-KCUSDOIE.mjs.map → chunk-RDWXY4OF.mjs.map} +0 -0
  122. /package/dist/{chunk-PD624ZNK.js.map → chunk-RUPB4ELK.js.map} +0 -0
  123. /package/dist/{chunk-76KGJJJV.mjs.map → chunk-ZM42FNAQ.mjs.map} +0 -0
@@ -1,10 +1,10 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
2
 
3
- var _chunkC4PQK53Kjs = require('./chunk-C4PQK53K.js');
3
+ var _chunkDYH5P3VYjs = require('./chunk-DYH5P3VY.js');
4
4
 
5
5
 
6
6
 
7
- var _chunkRELRWIJNjs = require('./chunk-RELRWIJN.js');
7
+ var _chunkD6BDJYSKjs = require('./chunk-D6BDJYSK.js');
8
8
 
9
9
 
10
10
 
@@ -28,7 +28,7 @@ async function getCurrencyConversionRate({
28
28
  }) {
29
29
  const includeUSDRate = false;
30
30
  try {
31
- const result = await _chunkC4PQK53Kjs.fetchExchangeRate.call(void 0,
31
+ const result = await _chunkDYH5P3VYjs.fetchExchangeRate.call(void 0,
32
32
  to,
33
33
  from,
34
34
  includeUSDRate
@@ -351,9 +351,9 @@ fetchAndMapExchangeRatesForSupportedNativeCurrency_fn = async function({
351
351
  chainId,
352
352
  nativeCurrency
353
353
  }) {
354
- const tokenPricesByTokenAddress = await _chunkRELRWIJNjs.reduceInBatchesSerially.call(void 0, {
354
+ const tokenPricesByTokenAddress = await _chunkD6BDJYSKjs.reduceInBatchesSerially.call(void 0, {
355
355
  values: [...tokenAddresses].sort(),
356
- batchSize: _chunkRELRWIJNjs.TOKEN_PRICES_BATCH_SIZE,
356
+ batchSize: _chunkD6BDJYSKjs.TOKEN_PRICES_BATCH_SIZE,
357
357
  eachBatch: async (allTokenPricesByTokenAddress, batch) => {
358
358
  const tokenPricesByTokenAddressForBatch = await _chunkZ4BLTVTBjs.__privateGet.call(void 0, this, _tokenPricesService).fetchTokenPrices({
359
359
  tokenAddresses: batch,
@@ -415,4 +415,4 @@ var TokenRatesController_default = TokenRatesController;
415
415
 
416
416
 
417
417
  exports.TokenRatesController = TokenRatesController; exports.TokenRatesController_default = TokenRatesController_default;
418
- //# sourceMappingURL=chunk-PD624ZNK.js.map
418
+ //# sourceMappingURL=chunk-RUPB4ELK.js.map
@@ -1,6 +1,6 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true});
2
2
 
3
- var _chunkRELRWIJNjs = require('./chunk-RELRWIJN.js');
3
+ var _chunkD6BDJYSKjs = require('./chunk-D6BDJYSK.js');
4
4
 
5
5
  // src/Standards/NftStandards/ERC721/ERC721Standard.ts
6
6
  var _contracts = require('@ethersproject/contracts');
@@ -73,7 +73,7 @@ var ERC721Standard = class {
73
73
  address
74
74
  );
75
75
  if (!supportsMetadata) {
76
- throw new Error("Contract does not support ERC721 metadata interface.");
76
+ console.error("Contract does not support ERC721 metadata interface.");
77
77
  }
78
78
  return contract.tokenURI(tokenId);
79
79
  };
@@ -133,7 +133,7 @@ var ERC721Standard = class {
133
133
  _controllerutils.safelyExecute.call(void 0, () => this.getAssetName(address)),
134
134
  tokenId ? _controllerutils.safelyExecute.call(void 0,
135
135
  () => this.getTokenURI(address, tokenId).then(
136
- (uri) => uri.startsWith("ipfs://") ? _chunkRELRWIJNjs.getFormattedIpfsUrl.call(void 0, ipfsGateway, uri, true) : uri
136
+ (uri) => uri.startsWith("ipfs://") ? _chunkD6BDJYSKjs.getFormattedIpfsUrl.call(void 0, ipfsGateway, uri, true) : uri
137
137
  )
138
138
  ) : void 0
139
139
  ]);
@@ -144,7 +144,7 @@ var ERC721Standard = class {
144
144
  const object = await response.json();
145
145
  image = object?.image;
146
146
  if (image?.startsWith("ipfs://")) {
147
- image = _chunkRELRWIJNjs.getFormattedIpfsUrl.call(void 0, ipfsGateway, image, true);
147
+ image = _chunkD6BDJYSKjs.getFormattedIpfsUrl.call(void 0, ipfsGateway, image, true);
148
148
  }
149
149
  } catch {
150
150
  }
@@ -175,4 +175,4 @@ var ERC721Standard = class {
175
175
 
176
176
 
177
177
  exports.ERC721Standard = ERC721Standard;
178
- //# sourceMappingURL=chunk-6NO7Z5DL.js.map
178
+ //# sourceMappingURL=chunk-TGKUZNML.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/Standards/NftStandards/ERC721/ERC721Standard.ts"],"names":[],"mappings":"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","sourcesContent":["import { Contract } from '@ethersproject/contracts';\nimport type { Web3Provider } from '@ethersproject/providers';\nimport {\n timeoutFetch,\n ERC721_INTERFACE_ID,\n ERC721_METADATA_INTERFACE_ID,\n ERC721_ENUMERABLE_INTERFACE_ID,\n ERC721,\n safelyExecute,\n} from '@metamask/controller-utils';\nimport { abiERC721 } from '@metamask/metamask-eth-abis';\n\nimport { getFormattedIpfsUrl } from '../../../assetsUtil';\n\nexport class ERC721Standard {\n private readonly provider: Web3Provider;\n\n constructor(provider: Web3Provider) {\n this.provider = provider;\n }\n\n /**\n * Query if contract implements ERC721Metadata interface.\n *\n * @param address - ERC721 asset contract address.\n * @returns Promise resolving to whether the contract implements ERC721Metadata interface.\n */\n contractSupportsMetadataInterface = async (\n address: string,\n ): Promise<boolean> => {\n return this.contractSupportsInterface(\n address,\n ERC721_METADATA_INTERFACE_ID,\n );\n };\n\n /**\n * Query if contract implements ERC721Enumerable interface.\n *\n * @param address - ERC721 asset contract address.\n * @returns Promise resolving to whether the contract implements ERC721Enumerable interface.\n */\n contractSupportsEnumerableInterface = async (\n address: string,\n ): Promise<boolean> => {\n return this.contractSupportsInterface(\n address,\n ERC721_ENUMERABLE_INTERFACE_ID,\n );\n };\n\n /**\n * Query if contract implements ERC721 interface.\n *\n * @param address - ERC721 asset contract address.\n * @returns Promise resolving to whether the contract implements ERC721 interface.\n */\n contractSupportsBase721Interface = async (\n address: string,\n ): Promise<boolean> => {\n return this.contractSupportsInterface(address, ERC721_INTERFACE_ID);\n };\n\n /**\n * Enumerate assets assigned to an owner.\n *\n * @param address - ERC721 asset contract address.\n * @param selectedAddress - Current account public address.\n * @param index - An NFT counter less than `balanceOf(selectedAddress)`.\n * @returns Promise resolving to token identifier for the 'index'th asset assigned to 'selectedAddress'.\n */\n getNftTokenId = async (\n address: string,\n selectedAddress: string,\n index: number,\n ): Promise<string> => {\n const contract = new Contract(address, abiERC721, this.provider);\n return contract.tokenOfOwnerByIndex(selectedAddress, index);\n };\n\n /**\n * Query for tokenURI for a given asset.\n *\n * @param address - ERC721 asset contract address.\n * @param tokenId - ERC721 asset identifier.\n * @returns Promise resolving to the 'tokenURI'.\n */\n getTokenURI = async (address: string, tokenId: string): Promise<string> => {\n const contract = new Contract(address, abiERC721, this.provider);\n const supportsMetadata = await this.contractSupportsMetadataInterface(\n address,\n );\n if (!supportsMetadata) {\n // Do not throw error here, supporting Metadata interface is optional even though majority of ERC721 nfts do support it.\n // This change is made because of instances of NFTs that are ERC404( mixed ERC20 / ERC721 implementation).\n // As of today, ERC404 is unofficial but some people use it, the contract does not support Metadata interface, but it has the tokenURI() fct.\n console.error('Contract does not support ERC721 metadata interface.');\n }\n return contract.tokenURI(tokenId);\n };\n\n /**\n * Query for name for a given asset.\n *\n * @param address - ERC721 asset contract address.\n * @returns Promise resolving to the 'name'.\n */\n getAssetName = async (address: string): Promise<string> => {\n const contract = new Contract(address, abiERC721, this.provider);\n return contract.name();\n };\n\n /**\n * Query for symbol for a given asset.\n *\n * @param address - ERC721 asset contract address.\n * @returns Promise resolving to the 'symbol'.\n */\n getAssetSymbol = async (address: string): Promise<string> => {\n const contract = new Contract(address, abiERC721, this.provider);\n return contract.symbol();\n };\n\n /**\n * Query for owner for a given ERC721 asset.\n *\n * @param address - ERC721 asset contract address.\n * @param tokenId - ERC721 asset identifier.\n * @returns Promise resolving to the owner address.\n */\n async getOwnerOf(address: string, tokenId: string): Promise<string> {\n const contract = new Contract(address, abiERC721, this.provider);\n return contract.ownerOf(tokenId);\n }\n\n /**\n * Query if a contract implements an interface.\n *\n * @param address - Asset contract address.\n * @param interfaceId - Interface identifier.\n * @returns Promise resolving to whether the contract implements `interfaceID`.\n */\n private readonly contractSupportsInterface = async (\n address: string,\n interfaceId: string,\n ): Promise<boolean> => {\n const contract = new Contract(address, abiERC721, this.provider);\n try {\n return await contract.supportsInterface(interfaceId);\n } catch (err) {\n // Mirror previous implementation\n if (\n err instanceof Error &&\n err.message.includes('call revert exception')\n ) {\n return false;\n }\n throw err;\n }\n };\n\n /**\n * Query if a contract implements an interface.\n *\n * @param address - Asset contract address.\n * @param ipfsGateway - The user's preferred IPFS gateway.\n * @param tokenId - tokenId of a given token in the contract.\n * @returns Promise resolving an object containing the standard, tokenURI, symbol and name of the given contract/tokenId pair.\n */\n getDetails = async (\n address: string,\n ipfsGateway: string,\n tokenId?: string,\n ): Promise<{\n standard: string;\n tokenURI: string | undefined;\n symbol: string | undefined;\n name: string | undefined;\n image: string | undefined;\n }> => {\n const isERC721 = await this.contractSupportsBase721Interface(address);\n if (!isERC721) {\n throw new Error(\"This isn't a valid ERC721 contract\");\n }\n\n const [symbol, name, tokenURI] = await Promise.all([\n safelyExecute(() => this.getAssetSymbol(address)),\n safelyExecute(() => this.getAssetName(address)),\n tokenId\n ? safelyExecute(() =>\n this.getTokenURI(address, tokenId).then((uri) =>\n uri.startsWith('ipfs://')\n ? getFormattedIpfsUrl(ipfsGateway, uri, true)\n : uri,\n ),\n )\n : undefined,\n ]);\n\n let image;\n if (tokenURI) {\n try {\n const response = await timeoutFetch(tokenURI);\n const object = await response.json();\n image = object?.image;\n if (image?.startsWith('ipfs://')) {\n image = getFormattedIpfsUrl(ipfsGateway, image, true);\n }\n } catch {\n // ignore\n }\n }\n\n return {\n standard: ERC721,\n tokenURI,\n symbol,\n name,\n image,\n };\n };\n}\n"]}
@@ -1,9 +1,7 @@
1
1
  "use strict";Object.defineProperty(exports, "__esModule", {value: true}); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
2
2
 
3
3
 
4
-
5
-
6
- var _chunkRELRWIJNjs = require('./chunk-RELRWIJN.js');
4
+ var _chunkD6BDJYSKjs = require('./chunk-D6BDJYSK.js');
7
5
 
8
6
  // src/NftController.ts
9
7
  var _address = require('@ethersproject/address');
@@ -26,10 +24,6 @@ var _asyncmutex = require('async-mutex');
26
24
  var _bnjs = require('bn.js'); var _bnjs2 = _interopRequireDefault(_bnjs);
27
25
  var _events = require('events');
28
26
  var _uuid = require('uuid');
29
- var OpenSeaV2ChainIds = /* @__PURE__ */ ((OpenSeaV2ChainIds2) => {
30
- OpenSeaV2ChainIds2["ethereum"] = "ethereum";
31
- return OpenSeaV2ChainIds2;
32
- })(OpenSeaV2ChainIds || {});
33
27
  var ALL_NFTS_STATE_KEY = "allNfts";
34
28
  var ALL_NFTS_CONTRACTS_STATE_KEY = "allNftContracts";
35
29
  var getDefaultNftState = () => {
@@ -104,7 +98,7 @@ var NftController = class extends _basecontroller.BaseControllerV1 {
104
98
  this.onNftAdded = onNftAdded;
105
99
  this.messagingSystem = messenger;
106
100
  onPreferencesStateChange(
107
- ({
101
+ async ({
108
102
  selectedAddress,
109
103
  ipfsGateway,
110
104
  openSeaEnabled,
@@ -116,6 +110,20 @@ var NftController = class extends _basecontroller.BaseControllerV1 {
116
110
  openSeaEnabled,
117
111
  isIpfsGatewayEnabled
118
112
  });
113
+ const needsUpdateNftMetadata = isIpfsGatewayEnabled && ipfsGateway !== "" || openSeaEnabled;
114
+ if (needsUpdateNftMetadata) {
115
+ const { chainId } = this.config;
116
+ const nfts = this.state.allNfts[selectedAddress]?.[chainId] ?? [];
117
+ const nftsToUpdate = nfts.filter(
118
+ (singleNft) => !singleNft.name && !singleNft.description && !singleNft.image
119
+ );
120
+ if (nftsToUpdate.length !== 0) {
121
+ await this.updateNftMetadata({
122
+ nfts: nftsToUpdate,
123
+ userAddress: selectedAddress
124
+ });
125
+ }
126
+ }
119
127
  }
120
128
  );
121
129
  onNetworkStateChange(({ providerConfig }) => {
@@ -123,21 +131,8 @@ var NftController = class extends _basecontroller.BaseControllerV1 {
123
131
  this.configure({ chainId });
124
132
  });
125
133
  }
126
- getNftApi({
127
- contractAddress,
128
- tokenId
129
- }) {
130
- return `${_controllerutils.OPENSEA_PROXY_URL}/chain/${"ethereum" /* ethereum */}/contract/${contractAddress}/nfts/${tokenId}`;
131
- }
132
- getNftContractInformationApi({
133
- contractAddress
134
- }) {
135
- return `${_controllerutils.OPENSEA_PROXY_URL}/chain/${"ethereum" /* ethereum */}/contract/${contractAddress}`;
136
- }
137
- getNftCollectionInformationApi({
138
- collectionSlug
139
- }) {
140
- return `${_controllerutils.OPENSEA_PROXY_URL}/collections/${collectionSlug}`;
134
+ getNftApi() {
135
+ return `${_controllerutils.NFT_API_BASE_URL}/tokens`;
141
136
  }
142
137
  /**
143
138
  * Helper method to update nested state for allNfts and allNftContracts.
@@ -164,20 +159,29 @@ var NftController = class extends _basecontroller.BaseControllerV1 {
164
159
  });
165
160
  }
166
161
  /**
167
- * Request individual NFT information from OpenSea API.
162
+ * Request individual NFT information from NFT API.
168
163
  *
169
164
  * @param contractAddress - Hex address of the NFT contract.
170
165
  * @param tokenId - The NFT identifier.
171
166
  * @returns Promise resolving to the current NFT name and image.
172
167
  */
173
168
  async getNftInformationFromApi(contractAddress, tokenId) {
169
+ const urlParams = new URLSearchParams({
170
+ chainIds: "1",
171
+ tokens: `${contractAddress}:${tokenId}`,
172
+ includeTopBid: "true",
173
+ includeAttributes: "true",
174
+ includeLastSale: "true"
175
+ }).toString();
174
176
  const nftInformation = await _controllerutils.fetchWithErrorHandling.call(void 0, {
175
- url: this.getNftApi({
176
- contractAddress,
177
- tokenId
178
- })
177
+ url: `${this.getNftApi()}?${urlParams}`,
178
+ options: {
179
+ headers: {
180
+ Version: "1"
181
+ }
182
+ }
179
183
  });
180
- if (!nftInformation?.nft) {
184
+ if (!nftInformation?.tokens?.[0]?.token) {
181
185
  return {
182
186
  name: null,
183
187
  description: null,
@@ -186,39 +190,35 @@ var NftController = class extends _basecontroller.BaseControllerV1 {
186
190
  };
187
191
  }
188
192
  const {
189
- num_sales,
190
- background_color,
191
- image_url,
192
- image_preview_url,
193
- image_thumbnail_url,
194
- image_original_url,
195
- animation_url,
196
- animation_original_url,
193
+ image,
194
+ metadata: { imageOriginal } = {},
197
195
  name,
198
196
  description,
199
- external_link,
200
- creator,
201
- last_sale,
202
- asset_contract: { schema_name }
203
- } = _chunkRELRWIJNjs.mapOpenSeaDetailedNftV2ToV1.call(void 0, nftInformation.nft);
197
+ collection,
198
+ kind,
199
+ rarityRank,
200
+ rarity,
201
+ attributes,
202
+ lastSale,
203
+ imageSmall
204
+ } = nftInformation.tokens[0].token;
204
205
  const nftMetadata = Object.assign(
205
206
  {},
206
207
  { name: name || null },
207
208
  { description: description || null },
208
- { image: image_url || null },
209
- creator && { creator },
210
- num_sales && { numberOfSales: num_sales },
211
- background_color && { backgroundColor: background_color },
212
- image_preview_url && { imagePreview: image_preview_url },
213
- image_thumbnail_url && { imageThumbnail: image_thumbnail_url },
214
- image_original_url && { imageOriginal: image_original_url },
215
- animation_url && { animation: animation_url },
216
- animation_original_url && {
217
- animationOriginal: animation_original_url
209
+ { image: image || null },
210
+ collection?.creator && { creator: collection.creator },
211
+ imageOriginal && { imageOriginal },
212
+ imageSmall && { imageThumbnail: imageSmall },
213
+ kind && { standard: kind.toUpperCase() },
214
+ lastSale && { lastSale },
215
+ attributes && { attributes },
216
+ nftInformation.tokens[0].market?.topBid && {
217
+ topBid: nftInformation.tokens[0].market?.topBid
218
218
  },
219
- external_link && { externalLink: external_link },
220
- last_sale && { lastSale: last_sale },
221
- schema_name && { standard: schema_name }
219
+ rarityRank && { rarityRank },
220
+ rarity && { rarity },
221
+ collection && { collection }
222
222
  );
223
223
  return nftMetadata;
224
224
  }
@@ -262,7 +262,7 @@ var NftController = class extends _basecontroller.BaseControllerV1 {
262
262
  };
263
263
  }
264
264
  if (hasIpfsTokenURI) {
265
- tokenURI = _chunkRELRWIJNjs.getFormattedIpfsUrl.call(void 0, ipfsGateway, tokenURI, useIPFSSubdomains);
265
+ tokenURI = _chunkD6BDJYSKjs.getFormattedIpfsUrl.call(void 0, ipfsGateway, tokenURI, useIPFSSubdomains);
266
266
  }
267
267
  try {
268
268
  const object = await _controllerutils.handleFetch.call(void 0, tokenURI);
@@ -334,7 +334,7 @@ var NftController = class extends _basecontroller.BaseControllerV1 {
334
334
  const chainId = this.getCorrectChainId({
335
335
  networkClientId
336
336
  });
337
- const [blockchainMetadata, openSeaMetadata] = await Promise.all([
337
+ const [blockchainMetadata, nftApiMetadata] = await Promise.all([
338
338
  _controllerutils.safelyExecute.call(void 0,
339
339
  () => this.getNftInformationFromTokenURI(
340
340
  contractAddress,
@@ -347,49 +347,14 @@ var NftController = class extends _basecontroller.BaseControllerV1 {
347
347
  ) : void 0
348
348
  ]);
349
349
  return {
350
- ...openSeaMetadata,
351
- name: blockchainMetadata?.name ?? openSeaMetadata?.name ?? null,
352
- description: blockchainMetadata?.description ?? openSeaMetadata?.description ?? null,
353
- image: blockchainMetadata?.image ?? openSeaMetadata?.image ?? null,
354
- standard: blockchainMetadata?.standard ?? openSeaMetadata?.standard ?? null,
350
+ ...nftApiMetadata,
351
+ name: blockchainMetadata?.name ?? nftApiMetadata?.name ?? null,
352
+ description: blockchainMetadata?.description ?? nftApiMetadata?.description ?? null,
353
+ image: blockchainMetadata?.image ?? nftApiMetadata?.image ?? null,
354
+ standard: blockchainMetadata?.standard ?? nftApiMetadata?.standard ?? null,
355
355
  tokenURI: blockchainMetadata?.tokenURI ?? null
356
356
  };
357
357
  }
358
- /**
359
- * Request NFT contract information from OpenSea API.
360
- *
361
- * @param contractAddress - Hex address of the NFT contract.
362
- * @returns Promise resolving to the current NFT name and image.
363
- */
364
- async getNftContractInformationFromApi(contractAddress) {
365
- const apiNftContractObject = await _controllerutils.fetchWithErrorHandling.call(void 0, {
366
- url: this.getNftContractInformationApi({
367
- contractAddress
368
- })
369
- });
370
- if (apiNftContractObject) {
371
- const collection = await _controllerutils.fetchWithErrorHandling.call(void 0, {
372
- url: this.getNftCollectionInformationApi({
373
- collectionSlug: apiNftContractObject.collection
374
- })
375
- });
376
- return _chunkRELRWIJNjs.mapOpenSeaContractV2ToV1.call(void 0, apiNftContractObject, collection);
377
- }
378
- return {
379
- address: contractAddress,
380
- asset_contract_type: null,
381
- created_date: null,
382
- schema_name: null,
383
- symbol: null,
384
- total_supply: null,
385
- description: null,
386
- external_link: null,
387
- collection: {
388
- name: null,
389
- image_url: null
390
- }
391
- };
392
- }
393
358
  /**
394
359
  * Request NFT contract information from the contract itself.
395
360
  *
@@ -409,36 +374,30 @@ var NftController = class extends _basecontroller.BaseControllerV1 {
409
374
  };
410
375
  }
411
376
  /**
412
- * Request NFT contract information from OpenSea API.
377
+ * Request NFT contract information from Blockchain and aggregate with received data from NFTMetadata.
413
378
  *
414
379
  * @param contractAddress - Hex address of the NFT contract.
380
+ * @param nftMetadataFromApi - Received NFT information to be aggregated with blockchain contract information.
415
381
  * @param networkClientId - The networkClientId that can be used to identify the network client to use for this request.
416
382
  * @returns Promise resolving to the NFT contract name, image and description.
417
383
  */
418
- async getNftContractInformation(contractAddress, networkClientId) {
419
- const chainId = this.getCorrectChainId({
420
- networkClientId
421
- });
422
- const [blockchainContractData, openSeaContractData] = await Promise.all([
423
- _controllerutils.safelyExecute.call(void 0,
424
- () => this.getNftContractInformationFromContract(
425
- contractAddress,
426
- networkClientId
427
- )
428
- ),
429
- this.config.openSeaEnabled && chainId === "0x1" ? _controllerutils.safelyExecute.call(void 0,
430
- () => this.getNftContractInformationFromApi(contractAddress)
431
- ) : void 0
432
- ]);
433
- if (blockchainContractData || openSeaContractData) {
384
+ async getNftContractInformation(contractAddress, nftMetadataFromApi, networkClientId) {
385
+ const blockchainContractData = await _controllerutils.safelyExecute.call(void 0,
386
+ () => this.getNftContractInformationFromContract(
387
+ contractAddress,
388
+ networkClientId
389
+ )
390
+ );
391
+ if (blockchainContractData || !Object.values(nftMetadataFromApi).every((value) => value === null)) {
434
392
  return {
435
393
  address: contractAddress,
436
- ...openSeaContractData,
437
394
  ...blockchainContractData,
395
+ schema_name: nftMetadataFromApi?.standard ?? null,
438
396
  collection: {
439
397
  name: null,
440
- image_url: null,
441
- ...openSeaContractData?.collection,
398
+ image_url: nftMetadataFromApi?.collection?.image ?? nftMetadataFromApi?.collection?.imageUrl ?? null,
399
+ tokenCount: nftMetadataFromApi?.collection?.tokenCount ?? null,
400
+ ...nftMetadataFromApi?.collection,
442
401
  ...blockchainContractData?.collection
443
402
  }
444
403
  };
@@ -477,7 +436,7 @@ var NftController = class extends _basecontroller.BaseControllerV1 {
477
436
  (nft) => nft.address.toLowerCase() === tokenAddress.toLowerCase() && nft.tokenId === tokenId
478
437
  );
479
438
  if (existingEntry) {
480
- const differentMetadata = _chunkRELRWIJNjs.compareNftMetadata.call(void 0,
439
+ const differentMetadata = _chunkD6BDJYSKjs.compareNftMetadata.call(void 0,
481
440
  nftMetadata,
482
441
  existingEntry
483
442
  );
@@ -524,6 +483,7 @@ var NftController = class extends _basecontroller.BaseControllerV1 {
524
483
  * @param options - options.
525
484
  * @param options.tokenAddress - Hex address of the NFT contract.
526
485
  * @param options.userAddress - The address of the account where the NFT is being added.
486
+ * @param options.nftMetadata - The retrieved NFTMetadata from API.
527
487
  * @param options.networkClientId - The networkClientId that can be used to identify the network client to use for this request.
528
488
  * @param options.source - Whether the NFT was detected, added manually or suggested by a dapp.
529
489
  * @returns Promise resolving to the current NFT contracts list.
@@ -532,7 +492,8 @@ var NftController = class extends _basecontroller.BaseControllerV1 {
532
492
  tokenAddress,
533
493
  userAddress,
534
494
  networkClientId,
535
- source
495
+ source,
496
+ nftMetadata
536
497
  }) {
537
498
  const releaseLock = await this.mutex.acquire();
538
499
  try {
@@ -550,17 +511,17 @@ var NftController = class extends _basecontroller.BaseControllerV1 {
550
511
  }
551
512
  const contractInformation = await this.getNftContractInformation(
552
513
  tokenAddress,
514
+ nftMetadata,
553
515
  networkClientId
554
516
  );
555
517
  const {
556
518
  asset_contract_type,
557
519
  created_date,
558
- schema_name,
559
520
  symbol,
560
- total_supply,
561
521
  description,
562
522
  external_link,
563
- collection: { name, image_url }
523
+ schema_name,
524
+ collection: { name, image_url, tokenCount }
564
525
  } = contractInformation;
565
526
  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]) => {
566
527
  return key === "address" || key === "collection" || !value;
@@ -574,7 +535,7 @@ var NftController = class extends _basecontroller.BaseControllerV1 {
574
535
  name && { name },
575
536
  image_url && { logo: image_url },
576
537
  symbol && { symbol },
577
- total_supply !== null && typeof total_supply !== "undefined" && { totalSupply: total_supply },
538
+ tokenCount !== null && typeof tokenCount !== "undefined" && { totalSupply: tokenCount },
578
539
  asset_contract_type && { assetContractType: asset_contract_type },
579
540
  created_date && { createdDate: created_date },
580
541
  schema_name && { schemaName: schema_name },
@@ -863,13 +824,14 @@ var NftController = class extends _basecontroller.BaseControllerV1 {
863
824
  } = { userAddress: this.config.selectedAddress }) {
864
825
  tokenAddress = _controllerutils.toChecksumHexAddress.call(void 0, tokenAddress);
865
826
  const chainId = this.getCorrectChainId({ networkClientId });
827
+ nftMetadata = nftMetadata || await this.getNftInformation(tokenAddress, tokenId, networkClientId);
866
828
  const newNftContracts = await this.addNftContract({
867
829
  tokenAddress,
868
830
  userAddress,
869
831
  networkClientId,
870
- source
832
+ source,
833
+ nftMetadata
871
834
  });
872
- nftMetadata = nftMetadata || await this.getNftInformation(tokenAddress, tokenId, networkClientId);
873
835
  const nftContract = newNftContracts.find(
874
836
  (contract) => contract.address.toLowerCase() === tokenAddress.toLowerCase()
875
837
  );
@@ -889,14 +851,14 @@ var NftController = class extends _basecontroller.BaseControllerV1 {
889
851
  * Refetches NFT metadata and updates the state
890
852
  *
891
853
  * @param options - Options for refetching NFT metadata
892
- * @param options.nfts - Array of nfts
893
- * @param options.networkClientId - The networkClientId that can be used to identify the network client to use for this request.
854
+ * @param options.nfts - nfts to update metadata for.
894
855
  * @param options.userAddress - The current user address
856
+ * @param options.networkClientId - The networkClientId that can be used to identify the network client to use for this request.
895
857
  */
896
858
  async updateNftMetadata({
897
859
  nfts,
898
- networkClientId,
899
- userAddress = this.config.selectedAddress
860
+ userAddress = this.config.selectedAddress,
861
+ networkClientId
900
862
  }) {
901
863
  const chainId = this.getCorrectChainId({ networkClientId });
902
864
  const nftsWithChecksumAdr = nfts.map((nft) => {
@@ -1216,6 +1178,5 @@ var NftController_default = NftController;
1216
1178
 
1217
1179
 
1218
1180
 
1219
-
1220
- exports.OpenSeaV2ChainIds = OpenSeaV2ChainIds; exports.getDefaultNftState = getDefaultNftState; exports.NftController = NftController; exports.NftController_default = NftController_default;
1221
- //# sourceMappingURL=chunk-AQIXUBTK.js.map
1181
+ exports.getDefaultNftState = getDefaultNftState; exports.NftController = NftController; exports.NftController_default = NftController_default;
1182
+ //# sourceMappingURL=chunk-UNKIHWZH.js.map