diff --git a/packages/assets-controllers/src/NftController.test.ts b/packages/assets-controllers/src/NftController.test.ts index 05e2961643..61d6c54ab7 100644 --- a/packages/assets-controllers/src/NftController.test.ts +++ b/packages/assets-controllers/src/NftController.test.ts @@ -1679,6 +1679,34 @@ describe('NftController', () => { }); }); + it('should return image when tokenURI fetched is an encoded data URL', async () => { + const testTokenUriEncoded = + ''; + const { nftController } = setupController({ + options: { + getERC721AssetName: jest.fn().mockResolvedValue('KudosToken'), + getERC721AssetSymbol: jest.fn().mockResolvedValue('KDO'), + getERC721TokenURI: jest.fn().mockResolvedValue(testTokenUriEncoded), + }, + defaultSelectedAccount: OWNER_ACCOUNT, + }); + await nftController.addNft(ERC721_KUDOSADDRESS, ERC721_KUDOS_TOKEN_ID); + + expect( + nftController.state.allNfts[OWNER_ACCOUNT.address][ChainId.mainnet][0], + ).toStrictEqual({ + address: ERC721_KUDOSADDRESS, + image: testTokenUriEncoded, + name: null, + description: null, + tokenId: ERC721_KUDOS_TOKEN_ID, + standard: ERC721, + favorite: false, + isCurrentlyOwned: true, + tokenURI: testTokenUriEncoded, + }); + }); + it('should add NFT by provider type', async () => { const tokenURI = 'https://url/'; const mockGetERC721TokenURI = jest.fn().mockResolvedValue(tokenURI); diff --git a/packages/assets-controllers/src/NftController.ts b/packages/assets-controllers/src/NftController.ts index 8b79b778d8..050cdcfe6e 100644 --- a/packages/assets-controllers/src/NftController.ts +++ b/packages/assets-controllers/src/NftController.ts @@ -644,6 +644,16 @@ export class NftController extends BaseController< this.#useIpfsSubdomains, ); } + if (tokenURI.startsWith('data:image/')) { + return { + image: tokenURI, + name: null, + description: null, + standard: standard || null, + favorite: false, + tokenURI: tokenURI ?? null, + }; + } try { const object = await handleFetch(tokenURI);