@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.
- package/CHANGELOG.md +17 -1
- package/dist/AssetsContractController.js +6 -6
- package/dist/AssetsContractController.mjs +5 -5
- package/dist/CurrencyRateController.js +3 -3
- package/dist/CurrencyRateController.mjs +2 -2
- package/dist/NftController.js +3 -5
- package/dist/NftController.mjs +2 -4
- package/dist/NftDetectionController.js +4 -4
- package/dist/NftDetectionController.mjs +3 -3
- package/dist/Standards/ERC20Standard.js +3 -3
- package/dist/Standards/ERC20Standard.mjs +2 -2
- package/dist/Standards/NftStandards/ERC1155/ERC1155Standard.js +3 -3
- package/dist/Standards/NftStandards/ERC1155/ERC1155Standard.mjs +2 -2
- package/dist/Standards/NftStandards/ERC721/ERC721Standard.js +3 -3
- package/dist/Standards/NftStandards/ERC721/ERC721Standard.mjs +2 -2
- package/dist/TokenDetectionController.js +3 -3
- package/dist/TokenDetectionController.mjs +2 -2
- package/dist/TokenListController.js +4 -4
- package/dist/TokenListController.mjs +3 -3
- package/dist/TokenRatesController.js +4 -4
- package/dist/TokenRatesController.mjs +3 -3
- package/dist/TokensController.js +6 -6
- package/dist/TokensController.mjs +5 -5
- package/dist/assetsUtil.js +2 -8
- package/dist/assetsUtil.mjs +1 -7
- package/dist/{chunk-IFJWX5RY.mjs → chunk-4PAJC7WC.mjs} +93 -132
- package/dist/chunk-4PAJC7WC.mjs.map +1 -0
- package/dist/{chunk-WIVSZVF4.mjs → chunk-AC5HGIHS.mjs} +3 -3
- package/dist/chunk-AC5HGIHS.mjs.map +1 -0
- package/dist/{chunk-355MWUUQ.js → chunk-BM7EPTR6.js} +3 -3
- package/dist/{chunk-4YU7CT4O.js → chunk-C4JDCQG2.js} +7 -7
- package/dist/{chunk-ZKJSG4TA.mjs → chunk-CNICDMRI.mjs} +4 -4
- package/dist/chunk-CNICDMRI.mjs.map +1 -0
- package/dist/{chunk-VY7TUOK2.js → chunk-D3N35ABH.js} +3 -3
- package/dist/{chunk-RELRWIJN.js → chunk-D6BDJYSK.js} +2 -68
- package/dist/chunk-D6BDJYSK.js.map +1 -0
- package/dist/{chunk-C4PQK53K.js → chunk-DYH5P3VY.js} +5 -2
- package/dist/chunk-DYH5P3VY.js.map +1 -0
- package/dist/{chunk-NUBQRDKI.js → chunk-E2SLNUD4.js} +11 -11
- package/dist/{chunk-VHCPQS4X.js → chunk-GCWWC4X3.js} +5 -5
- package/dist/{chunk-KRTEFV4Q.mjs → chunk-IURNPMBB.mjs} +2 -2
- package/dist/{chunk-WSOHBBCO.js → chunk-JEGLHDNA.js} +42 -56
- package/dist/chunk-JEGLHDNA.js.map +1 -0
- package/dist/{chunk-GLZ66IRX.mjs → chunk-KDMDWUVX.mjs} +41 -55
- package/dist/chunk-KDMDWUVX.mjs.map +1 -0
- package/dist/{chunk-MQ7TIWBK.mjs → chunk-KS4MOA2T.mjs} +2 -2
- package/dist/{chunk-H6TOSWUM.js → chunk-LRKDZWS6.js} +3 -3
- package/dist/{chunk-CEENXWOB.mjs → chunk-N5H5KDJZ.mjs} +2 -2
- package/dist/{chunk-2IZUMKMY.mjs → chunk-NHX4QGOD.mjs} +3 -3
- package/dist/{chunk-TCO22VIO.mjs → chunk-PWZE6KJV.mjs} +5 -2
- package/dist/chunk-PWZE6KJV.mjs.map +1 -0
- package/dist/{chunk-KSGMD24G.js → chunk-Q6TLNHYC.js} +7 -7
- package/dist/{chunk-523YP4Z3.mjs → chunk-QQAG6ECS.mjs} +3 -3
- package/dist/{chunk-XEZJ5XMV.js → chunk-QVSSEGA5.js} +7 -7
- package/dist/chunk-QVSSEGA5.js.map +1 -0
- package/dist/{chunk-23F5W3A2.mjs → chunk-QWACHXRH.mjs} +2 -2
- package/dist/{chunk-KCUSDOIE.mjs → chunk-RDWXY4OF.mjs} +4 -4
- package/dist/{chunk-PD624ZNK.js → chunk-RUPB4ELK.js} +6 -6
- package/dist/{chunk-6NO7Z5DL.js → chunk-TGKUZNML.js} +5 -5
- package/dist/chunk-TGKUZNML.js.map +1 -0
- package/dist/{chunk-AQIXUBTK.js → chunk-UNKIHWZH.js} +93 -132
- package/dist/chunk-UNKIHWZH.js.map +1 -0
- package/dist/{chunk-76KGJJJV.mjs → chunk-ZM42FNAQ.mjs} +5 -5
- package/dist/{chunk-E5PIGGYR.mjs → chunk-ZPAX2HLQ.mjs} +1 -67
- package/dist/chunk-ZPAX2HLQ.mjs.map +1 -0
- package/dist/crypto-compare.js +2 -2
- package/dist/crypto-compare.mjs +1 -1
- package/dist/index.js +15 -15
- package/dist/index.mjs +18 -18
- package/dist/token-service.js +3 -3
- package/dist/token-service.mjs +2 -2
- package/dist/tsconfig.build.tsbuildinfo +1 -1
- package/dist/types/CurrencyRateController.d.ts +7 -7
- package/dist/types/CurrencyRateController.d.ts.map +1 -1
- package/dist/types/NftController.d.ts +20 -95
- package/dist/types/NftController.d.ts.map +1 -1
- package/dist/types/NftDetectionController.d.ts +184 -0
- package/dist/types/NftDetectionController.d.ts.map +1 -1
- package/dist/types/Standards/NftStandards/ERC721/ERC721Standard.d.ts.map +1 -1
- package/dist/types/TokenBalancesController.d.ts +10 -10
- package/dist/types/TokenBalancesController.d.ts.map +1 -1
- package/dist/types/TokenDetectionController.d.ts +9 -9
- package/dist/types/TokenDetectionController.d.ts.map +1 -1
- package/dist/types/TokenListController.d.ts +12 -12
- package/dist/types/TokenListController.d.ts.map +1 -1
- package/dist/types/TokensController.d.ts +10 -10
- package/dist/types/TokensController.d.ts.map +1 -1
- package/dist/types/assetsUtil.d.ts +1 -21
- package/dist/types/assetsUtil.d.ts.map +1 -1
- package/dist/types/crypto-compare.d.ts.map +1 -1
- package/dist/types/token-prices-service/abstract-token-prices-service.d.ts +3 -3
- package/dist/types/token-prices-service/abstract-token-prices-service.d.ts.map +1 -1
- package/dist/types/token-prices-service/codefi-v2.d.ts +2 -2
- package/dist/types/token-prices-service/codefi-v2.d.ts.map +1 -1
- package/package.json +12 -12
- package/dist/chunk-6NO7Z5DL.js.map +0 -1
- package/dist/chunk-AQIXUBTK.js.map +0 -1
- package/dist/chunk-C4PQK53K.js.map +0 -1
- package/dist/chunk-E5PIGGYR.mjs.map +0 -1
- package/dist/chunk-GLZ66IRX.mjs.map +0 -1
- package/dist/chunk-IFJWX5RY.mjs.map +0 -1
- package/dist/chunk-RELRWIJN.js.map +0 -1
- package/dist/chunk-TCO22VIO.mjs.map +0 -1
- package/dist/chunk-WIVSZVF4.mjs.map +0 -1
- package/dist/chunk-WSOHBBCO.js.map +0 -1
- package/dist/chunk-XEZJ5XMV.js.map +0 -1
- package/dist/chunk-ZKJSG4TA.mjs.map +0 -1
- /package/dist/{chunk-355MWUUQ.js.map → chunk-BM7EPTR6.js.map} +0 -0
- /package/dist/{chunk-4YU7CT4O.js.map → chunk-C4JDCQG2.js.map} +0 -0
- /package/dist/{chunk-VY7TUOK2.js.map → chunk-D3N35ABH.js.map} +0 -0
- /package/dist/{chunk-NUBQRDKI.js.map → chunk-E2SLNUD4.js.map} +0 -0
- /package/dist/{chunk-VHCPQS4X.js.map → chunk-GCWWC4X3.js.map} +0 -0
- /package/dist/{chunk-KRTEFV4Q.mjs.map → chunk-IURNPMBB.mjs.map} +0 -0
- /package/dist/{chunk-MQ7TIWBK.mjs.map → chunk-KS4MOA2T.mjs.map} +0 -0
- /package/dist/{chunk-H6TOSWUM.js.map → chunk-LRKDZWS6.js.map} +0 -0
- /package/dist/{chunk-CEENXWOB.mjs.map → chunk-N5H5KDJZ.mjs.map} +0 -0
- /package/dist/{chunk-2IZUMKMY.mjs.map → chunk-NHX4QGOD.mjs.map} +0 -0
- /package/dist/{chunk-KSGMD24G.js.map → chunk-Q6TLNHYC.js.map} +0 -0
- /package/dist/{chunk-523YP4Z3.mjs.map → chunk-QQAG6ECS.mjs.map} +0 -0
- /package/dist/{chunk-23F5W3A2.mjs.map → chunk-QWACHXRH.mjs.map} +0 -0
- /package/dist/{chunk-KCUSDOIE.mjs.map → chunk-RDWXY4OF.mjs.map} +0 -0
- /package/dist/{chunk-PD624ZNK.js.map → chunk-RUPB4ELK.js.map} +0 -0
- /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
|
|
3
|
+
var _chunkDYH5P3VYjs = require('./chunk-DYH5P3VY.js');
|
|
4
4
|
|
|
5
5
|
|
|
6
6
|
|
|
7
|
-
var
|
|
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
|
|
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
|
|
354
|
+
const tokenPricesByTokenAddress = await _chunkD6BDJYSKjs.reduceInBatchesSerially.call(void 0, {
|
|
355
355
|
values: [...tokenAddresses].sort(),
|
|
356
|
-
batchSize:
|
|
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-
|
|
418
|
+
//# sourceMappingURL=chunk-RUPB4ELK.js.map
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";Object.defineProperty(exports, "__esModule", {value: true});
|
|
2
2
|
|
|
3
|
-
var
|
|
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
|
-
|
|
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://") ?
|
|
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 =
|
|
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-
|
|
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
|
-
|
|
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
|
|
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
|
-
|
|
177
|
-
|
|
178
|
-
|
|
177
|
+
url: `${this.getNftApi()}?${urlParams}`,
|
|
178
|
+
options: {
|
|
179
|
+
headers: {
|
|
180
|
+
Version: "1"
|
|
181
|
+
}
|
|
182
|
+
}
|
|
179
183
|
});
|
|
180
|
-
if (!nftInformation?.
|
|
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
|
-
|
|
190
|
-
|
|
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
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
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:
|
|
209
|
-
creator && { creator },
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
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
|
-
|
|
220
|
-
|
|
221
|
-
|
|
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 =
|
|
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,
|
|
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
|
-
...
|
|
351
|
-
name: blockchainMetadata?.name ??
|
|
352
|
-
description: blockchainMetadata?.description ??
|
|
353
|
-
image: blockchainMetadata?.image ??
|
|
354
|
-
standard: blockchainMetadata?.standard ??
|
|
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
|
|
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
|
|
420
|
-
|
|
421
|
-
|
|
422
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
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
|
-
|
|
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 =
|
|
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
|
-
|
|
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
|
-
|
|
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 -
|
|
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
|
-
|
|
899
|
-
|
|
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
|
-
|
|
1221
|
-
//# sourceMappingURL=chunk-AQIXUBTK.js.map
|
|
1181
|
+
exports.getDefaultNftState = getDefaultNftState; exports.NftController = NftController; exports.NftController_default = NftController_default;
|
|
1182
|
+
//# sourceMappingURL=chunk-UNKIHWZH.js.map
|