@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 Open Sea and Solana clients used internally.
type OpenSeaClientProps = {
apiEndpoint?: string
apiKey?: string
assetLimit?: number
eventLimit?: number
}
type SolanaClientProps = {
rpcEndpoint?: string
}
type FetchNFTClientProps = {
openSeaConfig?: OpenSeaClientProps,
solanaConfig?: SolanaClientProps
}
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: string | null
description: string | null
mediaType: CollectibleMediaType
frameUrl: string | null
imageUrl: string | null
gifUrl: string | null
videoUrl: string | null
threeDUrl: string | null
isOwned: boolean
dateCreated: string | null
dateLastTransferred: string | null
externalLink: string | null
permaLink: string | null
assetContractAddress: string | null
chain: Chain
wallet: string
}
CollectibleState
type CollectibleState = {
[wallet: string]: Collectible[]
}
Usage with Configs
import { FetchNFTClient } from '@audius/fetch-nft'
const openSeaConfig = {
apiEndpoint: '...',
apiKey: '...',
assetLimit: 50,
eventLimit: 300
}
const solanaConfig = {
rpcEndpoint: '...'
}
const fetchClient = new FetchNFTClient({ openSeaConfig, solanaConfig })
fetchClient.getEthereumCollectibles([...]).then(res => console.log(res))
fetchClient.getSolanaCollectibles([...]).then(res => console.log(res))
For more examples, see the /examples directory