Dynamic NFT Metadata on Polybase
HC
data:image/s3,"s3://crabby-images/8593d/8593da57ddda0f49c3695ebb46e66b41d2d23c49" alt=""
Shaki
•
Mar 24, 2023
With dynamic NFT metadata stored on Polybase, you can build new kinds of utility or gaming NFTs that need faster and cheaper NFT metadata updates. Here’s a step-by-step walkthrough of how you can store your NFT metadata using Polybase.
Create an ERC-721 token
Open a terminal and make a directory for building your ERC-721 token.
data:image/s3,"s3://crabby-images/74db3/74db30f2b1a8796219589e58793985775c76b7d1" alt="directory-terminal"
Navigate into the nftMetadata directory, install the following dependencies
data:image/s3,"s3://crabby-images/4d35c/4d35cee5ddb9c671f3c96ca5529fbefd5fccca07" alt="install-dependencies"
Under the contracts folder, create a new file "myToken.sol" and add the following code to it.
data:image/s3,"s3://crabby-images/cdb0e/cdb0ebbb1ffa48971a900294bf0e821c2a3592b2" alt="myToken.sol"
Update the truffle-config.js file with the following code.
data:image/s3,"s3://crabby-images/a69c7/a69c7018eb7da5e1fa9759822dfa3d4c13ad8677" alt="edit-truffle.js"
You should store your Mnemonic phrase & Infura API key in the .env file that you need to create in this repository!
Your .env file would look like this.
data:image/s3,"s3://crabby-images/45b41/45b4144c4622bb7bf746548777654b7a63da49d6" alt="Your-dotenv-file"
Compile and deploy your contracts
data:image/s3,"s3://crabby-images/9d1c3/9d1c3a296fca834b990b29769aa80923043f6b82" alt="compile-smart-contract"
Once you have compiled the smart contract we need to migrate it over to the Goerli network! Add a new file 1_deploy_contract.js under the migrations folder and update it with the following script.
data:image/s3,"s3://crabby-images/0884d/0884dc096dbde167bf6a9dbaf65e876042ee1d6a" alt="migration-script"
Now save this code, navigate to the terminal, and type in the following command.
data:image/s3,"s3://crabby-images/53da0/53da05c2b2028a03987c61ca65bdadf3580d7cd6" alt="migrate-network"
This would deploy your NFT in the Goerli test network. Make sure you recharge your Goerli testnet wallet before migrating it.
Creating a collection in Polybase
Now login to Polybase Explorer & add create a new app. You would be taken to the default boilerplate. Remove that code and paste the code given below. You can find this code in our docs.
data:image/s3,"s3://crabby-images/f887f/f887ff7a6064152532a5622a1caee0a4ec74ab92" alt="polybase-collection-schema"
Save the collection. Once you have done this head over to your terminal.
Install Polybase SDK
data:image/s3,"s3://crabby-images/37ab8/37ab822d253ecddcb5075d5b992f176b3b798c39" alt="install-polybase-sdk"
Add a mintnft.js file to your directory.
data:image/s3,"s3://crabby-images/924a8/924a8c65cad95705973ed8d17fe62255073e0229" alt="define-values-of-metadata"
Navigate to the terminal and run this command.
data:image/s3,"s3://crabby-images/14e20/14e207263df6e32d4c9afea20c2ced449e016583" alt="mint-nft.js"
Kudos! You have created your first record in the Polybase database. Here's a video where Shaki walks you through how to store your NFT metadata on Polybase.