Skip to content

bB-Foundation/bb-contracts

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

3 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

bB Smart Contracts

bB is a mobile gaming and social dApp for Gen Z and young Millennials, incentivizing real-world community action through interactive quests. Partnering with major brands, NGOs, influencers, and research institutions, bB blends gaming with social impact.

Players complete quests across five pillars—Health & Fitness, Nutrition & Health, Environment, The Arts, and Education—earning tokenized rewards (gems) that can be traded for progression and prizes.

Requirements

Before you begin, you need to install the following tools:

Starknet-devnet version

To ensure the proper functioning of bB, your local starknet-devnet version must be 0.2.0. To accomplish this, first check your local starknet-devnet version:

starknet-devnet --version

If your local starknet-devnet version is not 0.2.0, you need to install it.

Scarb version

To ensure the proper functioning of bB, your local Scarb version must be 2.8.3. To accomplish this, first check your local Scarb version:

scarb --version

If your local Scarb version is not 2.8.3, you need to install it.

Starknet Foundry version

To ensure the proper functioning of the tests on bB, your Starknet Foundry version must be 0.31.0. To accomplish this, first check your Starknet Foundry version:

snforge --version

If your Starknet Foundry version is not 0.31.0, you need to install it.

Compatible versions

  • Starknet-devnet - v0.2.0
  • Scarb - v2.8.3
  • Snforge - v0.31.0
  • Cairo - v2.8.2
  • Rpc - v0.7.1

Quickstart with Starknet-Devnet

To get started with bB, follow the steps below:

  1. Clone this repo and install dependencies
git clone https://github.com/bB-Foundation/bb-contracts.git
cd bb-contracts
yarn install
  1. Run a local network in the first terminal.
yarn chain

To run a fork : yarn chain --fork-network <URL> [--fork-block <BLOCK_NUMBER>]

This command starts a local Starknet network using Devnet. The network runs on your local machine and can be used for testing and development.

  1. On a second terminal, deploy the sample contract:
yarn deploy

This command deploys a sample smart contract to the local network. The contract is located in contracts/src and can be modified to suit your needs. The yarn deploy command uses the deploy script located in scripts/deploy.ts to deploy the contract to the network. You can also customize the deploy script.

By default bB takes the first prefunded account from starknet-devnet as a deployer address,

  1. On a third terminal, start your NextJS app:
yarn start

Visit your app on: http://localhost:3000. You can interact with your smart contract using the Debug Contracts page.

  1. Check your environment variables. We have a yarn postinstall script that helps to fill in your environment variables. If the environment variable does not exist, you can fill them it manually to get the app running!

Quickstart with Sepolia Testnet

  1. Make sure you alredy cloned this repo and installed dependencies.

  2. Prepare your environment variables.

Find the .env file and fill the env variables related to Sepolia testnet with your own wallet account contract address and private key.

  1. Change your default network to Sepolia testnet.

  2. Get some testnet tokens

You will need to get some ETH or STRK Sepolia tokens to deploy your contract to Sepolia testnet.

Some popular faucets are Starknet Faucet and Blastapi Starknet Sepolia Eth

  1. Open a terminal, deploy the sample contract to Sepolia testnet:
yarn deploy --network sepolia

RPC specific version

To ensure the proper functioning of the bB with Testnet or Mainnet, your RPC version must be 0.7.1. This repository contains a .env.example file, where we provided the default RPC URL for the Starknet Testnet: RPC_URL_SEPOLIA=https://starknet-sepolia.public.blastapi.io/rpc/v0_7. Let's verify this RPC version is 0.7.1 by calling a POST request in an API platform like Postman or Insommia . Your API endpoint should be https://starknet-sepolia.public.blastapi.io/rpc/v0_7 and the body should be:

{
 "jsonrpc":"2.0",
 "method":"starknet_specVersion",
 "id":1
}

You have to paste the endpoint and body in the API platform and click on the Send button. If the response is 0.7.1, then you are good to go. Otherwise, you have to get the correct RPC URL endpoint.

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published