diff --git a/package.json b/package.json index 83ef23a..6bd7d70 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "starknetid.js", - "version": "3.0.4", + "version": "3.0.5", "description": "JavaScript library for Starknet ID", "private": false, "license": "MIT", diff --git a/packages/core/__test__/profile_mainnet.test.ts b/packages/core/__test__/profile_mainnet.test.ts new file mode 100644 index 0000000..fc966f5 --- /dev/null +++ b/packages/core/__test__/profile_mainnet.test.ts @@ -0,0 +1,78 @@ +import { constants, Provider } from "starknet"; +import { StarknetIdNavigator } from "../src"; + +describe("test starknetid.js sdk on mainnet", () => { + jest.setTimeout(90000000); + const provider = new Provider({ + rpc: { + nodeUrl: "https://rpc.starknet.id", + }, + }); + + describe("getProfileData for a profile with a blobert pfp", () => { + test("getProfileData should return an undefined profile picture url", async () => { + const starknetIdNavigator = new StarknetIdNavigator( + provider, + constants.StarknetChainId.SN_MAIN, + ); + expect(starknetIdNavigator).toBeInstanceOf(StarknetIdNavigator); + const profile = await starknetIdNavigator.getProfileData( + "0x06fb5e4e650bb6ceb80923c008e81122129092efc7e6d6f3f5c9ac4eead25355", + false, + ); + const expectedProfile = { + name: "rmz.stark", + twitter: "302521256", + github: undefined, + discord: undefined, + proofOfPersonhood: false, + profilePicture: + "", + }; + expect(profile).toStrictEqual(expectedProfile); + }); + + test("getProfileData with a starkurabu pfp", async () => { + const starknetIdNavigator = new StarknetIdNavigator( + provider, + constants.StarknetChainId.SN_MAIN, + ); + expect(starknetIdNavigator).toBeInstanceOf(StarknetIdNavigator); + const profile = await starknetIdNavigator.getProfileData( + "0x061b6c0a78f9edf13cea17b50719f3344533fadd470b8cb29c2b4318014f52d3", + false, + ); + const expectedProfile = { + name: "fricoben.stark", + twitter: "1255853529866145794", + github: "78437165", + discord: "662387807901188096", + proofOfPersonhood: true, + profilePicture: + "https://img.starkurabu.com/41538374869489910341448844649168906.png", + }; + expect(profile).toStrictEqual(expectedProfile); + }); + + test("getProfileData with a duck pfp", async () => { + const starknetIdNavigator = new StarknetIdNavigator( + provider, + constants.StarknetChainId.SN_MAIN, + ); + expect(starknetIdNavigator).toBeInstanceOf(StarknetIdNavigator); + const profile = await starknetIdNavigator.getProfileData( + "0x029b96adaefdb4299be95cdee599bff6bcca26c4e85a4d8ace79231f4618017f", + ); + const expectedProfile = { + name: "iris.stark", + twitter: undefined, + github: undefined, + discord: undefined, + proofOfPersonhood: false, + profilePicture: + "https://api.briq.construction/v1/preview/starknet-mainnet-dojo/0x6cff01dd5d1e2ec5e792d66bd6edae386bd022b4ffd993c76c08cd000000003.png", + }; + expect(profile).toStrictEqual(expectedProfile); + }); + }); +}); diff --git a/packages/core/package.json b/packages/core/package.json index fded078..adb169b 100644 --- a/packages/core/package.json +++ b/packages/core/package.json @@ -1,6 +1,6 @@ { "name": "starknetid.js", - "version": "3.0.4", + "version": "3.0.5", "keywords": [ "starknet", "starknetid", diff --git a/packages/core/src/starknetIdNavigator/default.ts b/packages/core/src/starknetIdNavigator/default.ts index 626391e..9b84526 100644 --- a/packages/core/src/starknetIdNavigator/default.ts +++ b/packages/core/src/starknetIdNavigator/default.ts @@ -576,7 +576,11 @@ export class StarknetIdNavigator implements StarknetIdNavigatorInterface { // extract nft_image from profile data const profilePicture = profilePictureMetadata - ? await this.fetchImageUrl(profilePictureMetadata) + ? profilePictureMetadata.includes("base64") + ? JSON.parse( + atob(profilePictureMetadata.split(",")[1].slice(0, -1)), + ).image + : await this.fetchImageUrl(profilePictureMetadata) : useDefaultPfp ? `https://starknet.id/api/identicons/${data[1][0].toString()}` : undefined;