/whitelist-gated-token-sale

Develop a program using Native Rust or Anchor to allow users to participate in a whitelist-gated sale for a new token. The token price should be static with a limit per wallet address.

Primary LanguageTypeScript

whitelist-gated-token-sale

Develop a program using Native Rust or Anchor to allow users to participate in a whitelist-gated sale for a new token. The token price should be static with a limit per wallet address.

-Create a whitelist-gated sale program using Native Rust or Anchor. -Ensure the token price remains static and set a purchase limit per wallet. -Optional: Create a blink to demonstrate the program.

Getting Started

Prerequisites

  • 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

Installation

Clone the repo

git clone https://github.com/0xGRAV3R/whitelist-gated-token-sale.git
cd whitelist-gated-token-sale

Install Dependencies

npm install

Start the web app

npm run dev

Apps

anchor

This is a Solana program written in Rust using the Anchor framework.

Commands

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.

Sync the program id:

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/counter-exports.ts to match the new program id.

npm run anchor keys sync

Build the program:

npm run anchor-build

Start the test validator with the program deployed:

npm run anchor-localnet

Run the tests

npm run anchor-test

Deploy to Devnet

npm run anchor deploy --provider.cluster devnet

web

This is a React app that uses the Anchor generated client to interact with the Solana program.

Commands

Start the web app

npm run dev

Build the web app

npm run build