NFT wallet
This is an NFT wallet example dapp that utilizes minted NFTs from the Rust dip721-nft-container. Among some of its essential features, the wallet can register NFTs, transfer out NFTs, and check how many NFTs it contains. This dapp includes a frontend UI for interaction.
Prerequisites
- Install the IC
SDK. For local testing,
dfx >= 0.22.0
is required. - Clone the example dapp project:
git clone https://github.com/dfinity/examples
Step 1: Setup project environment
You can deploy the dapp using the start.sh
script:
cd examples/rust/nft-wallet
./start.sh
This script installs dependencies as well as a local Internet Identity, then deploys the NFT wallet locally.
Alternatively, the dapp can be deployed manually with the commands:
dfx start --background
cd internet-identity
npm install
II_FETCH_ROOT_KEY=1 dfx deploy
cd ..
./deploy.sh
If you'd like to deploy on the mainnet, run the command:
./deploy.sh --network ic
Step 2: Make calls against NFT wallet canister
For example, to to transfer an NFT use the command:
dfx canister call nftwallet transfer '(record {canister = principal "<NFT canister id>"; index = 1:nat64}, principal "<recipient canister id>", opt true)'