@audius/fetch-nft
🖼🎑🌠
A utility to fetch and easily display Ethereum & Solana NFTs in a common format given any wallet.
built with ❤️ from the team @Audius.
Installation
npm install @solana/spl-token @solana/web3.js
npm install @audius/fetch-nft
Basic Usage
import { FetchNFTClient } from "@audius/fetch-nft";
const fetchClient = new FetchNFTClient();
fetchClient
.getCollectibles({
ethWallets: ["0x5A8443f456f490dceeAD0922B0Cc89AFd598cec9"],
solWallets: ["GrWNH9qfwrvoCEoTm65hmnSh4z3CD96SfhtfQY6ZKUfY"],
})
.then((res) => console.log(res));
By default, fetch-nft uses the public Opensea API and the Solana mainnet RPC endpoint. To configure API keys and endpoints, see Usage With Configs.
Fetch Client
FetchNFTClient is the primary interface for using the library. When initializing the client, you may optionally pass in configs for the OpenSea and Helius clients used internally.
type OpenSeaClientProps = {
apiEndpoint?: string;
apiKey?: string;
assetLimit?: number;
eventLimit?: number;
};
type HeliusClientCtorProps = {
apiEndpoint?: string;
apiKey?: string;
limit?: number;
};
type FetchNFTClientProps = {
openSeaConfig?: OpenSeaClientCtorProps;
heliusConfig?: HeliusClientCtorProps;
solanaConfig?: {
rpcEndpoint?: string;
metadataProgramId?: string;
};
};
Main Functions
Getting Ethereum collectibles:
FetchNFTClient::getEthereumCollectibles(wallets: string[]) => Promise<CollectibleState>
Getting Solana collectibles:
FetchNFTClient::getSolanaCollectibles(wallets: string[]) => Promise<CollectibleState>
Getting all collectibles:
FetchNFTClient::getCollectibles({
ethWallets?: string[],
solWallets?: string[]
}) => Promise<{
ethCollectibles: CollectibleState
solCollectibles: CollectibleState
}>
Output Types
Collectible
type Collectible = {
id: string;
tokenId: string;
name: Nullable<string>;
description: Nullable<string>;
mediaType: CollectibleMediaType;
frameUrl: Nullable<string>;
imageUrl: Nullable<string>;
gifUrl: Nullable<string>;
videoUrl: Nullable<string>;
threeDUrl: Nullable<string>;
animationUrl: Nullable<string>;
hasAudio: boolean;
isOwned: boolean;
dateCreated: Nullable<string>;
dateLastTransferred: Nullable<string>;
externalLink: Nullable<string>;
permaLink: Nullable<string>;
chain: Chain;
wallet: string;
duration?: number;
assetContractAddress: Nullable<string>;
standard: Nullable<EthTokenStandard>;
collectionSlug: Nullable<string>;
collectionName: Nullable<string>;
collectionImageUrl: Nullable<string>;
solanaChainMetadata?: Nullable<Metadata>;
heliusCollection?: Nullable<HeliusCollection>;
};
CollectibleState
type CollectibleState = {
[wallet: string]: Collectible[];
};
Usage with Configs
import { FetchNFTClient } from '@audius/fetch-nft'
const openSeaConfig = {
apiEndpoint: '...',
apiKey: '...',
assetLimit: 10,
eventLimit: 10
}
const heliusConfig = {
apiEndpoint: '...';
apiKey: '...',
limit: 10
}
const solanaConfig = {
rpcEndpoint: '...',
metadataProgramId: '...'
};
const fetchClient = new FetchNFTClient({ openSeaConfig, heliusConfig, solanaConfig })
fetchClient.getEthereumCollectibles([...]).then(res => console.log(res))
fetchClient.getSolanaCollectibles([...]).then(res => console.log(res))
For more examples, see the /examples directory