The idea is to have a school centered upon on NFTs and NFT permissions. Students join the school and are awarded an NFT. This NFT acts as their Student ID and their source of permissions. The ID NFT will allow them to register for classes or receive school books (represented as other NFTs).
[ ] Soulbond NFT (Student ID)
[ ] Token-gated access to content
[ ] Dynamic metadata (Attendance, Grades, etc) Guide
-
Node v18.18.0 or higher
-
Rust v1.77.2 or higher
-
Anchor CLI 0.30.0 or higher
-
Solana CLI 1.18.9 or higher
git clone <repo-url>
cd <repo-name>
npm install
npm run dev
This is a Solana program written in Rust using the Anchor framework.
You can use any normal anchor commands. Either move to the anchor
directory and run the anchor
command or prefix the command with npm run
, eg: npm run anchor
.
Running this command will create a new keypair in the anchor/target/deploy
directory and save the address to the Anchor config file and update the declare_id!
macro in the ./src/lib.rs
file of the program.
You will manually need to update the constant in anchor/lib/basic-exports.ts
to match the new program id.
npm run anchor keys sync
npm run anchor-build
npm run anchor-localnet
npm run anchor-test
npm run anchor deploy --provider.cluster devnet
This is a React app that uses the Anchor generated client to interact with the Solana program.
Start the web app
npm run dev
Build the web app
npm run build