@audius/fetch-nft
A utility to fetch and easily display Ethereum & Solana NFTs in a common format given any wallet
Installation
Using npm:
npm install @audius/fetch-nft
Using yarn:
yarn add @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))
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
}
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
}
const solanaConfig = {
rpcEndpoint: '...'
}
const fetchClient = new FetchNFTClient({ openSeaConfig, solanaConfig })
fetchClient.getEthereumCollectibles([...]).then(res => console.log(res))
fetchClient.getSolanaCollectibles([...]).then(res => console.log(res))