by Usher Labs
Welcome to the X (Twitter) NFTs repository!
X NFTs are truly 1 of 1 NFTs, each representing a single X Post (aka. Tweet).
This project is unique due to its focus on cryptography, ensuring:
- Only one NFT can ever be minted for a given Tweet.
- The minting price is based on the Tweet's likes, retweets, replies, and other public metrics.
- No single party can undermine the minting process or tamper with data from X.
- Each NFT is minted only if a zkTLS proof is successfully verified on-chain.
- Anyone can operate a zkTLS Prover of Tweets to mint the NFTs.
X NFTs are minted on the NEAR blockchain and verified on the Aurora blockchain (a NEAR EVM L2 Chain).
X NFTs leverage the pluggable interfaces within the Near Ecosystem:
- Bitte AI provides a chat-first interface for minting and managing NFTs.
- Mintbase offers a marketplace for secondary sales.
- Request a Tweet to be minted via your Bitte Wallet.
- Use AI to generate NFT art or use an automatic snapshot of the Tweet.
- Provide a Twitter handle for notifications once the zkTLS proof is verified on-chain.
- Wait for zkProof verification and NFT minting to complete.
- Brag and bet with your friends on whether your 1-of-1 X NFT will represent a Tweet that will go viral!
To develop or operate the X NFTs project, you will need to:
- Obtain the Verity CLI to run the Verity zkTLS Prover. Details can be requested from Usher Labs via Discord.
- Configure and run the Bitte Plugin.
- Configure and run the Near Indexer / Orchestrator.
TL;DR
To run the repo:
-
Install dependencies:
# Install Rust curl https://sh.rustup.rs -sSf | sh # Install Foundry curl -L https://foundry.paradigm.xyz | bash
- Install the necessary tool-chain to build the program
- Install and run Docker. Docker is necessary for deterministic building of the ZK Prover ELF binary and simplifies the operation of the Orchestrator / Near Indexer.
-
Navigate to the
bitte_plugin
directory. -
Create environment variables:
- See all required env variables: .env.sample.
- Important: Copy the
.env.sample
file toplugin.env
and fill in the values.
-
Run the
bitte_plugin
see. -
Navigate to the
near_indexer
directory. -
Create environment variables:
- See all required env variables: .env.sample.
- Copy the
.env.sample
file to.env
and fill in the values.
-
Set up Near indexer see.
src/bitte_plugin
: The Bitte Plugin includes an API that allows Bitte AI to interact with the X NFTs project.src/near_indexer
: The Near Indexer orchestrates the X NFTs project, including Near NFT Contract Indexing and ZK Prover processes management.src/zkaf
: The zkAF utility generates the ZK Prover ELF binary, loaded intosrc/near_indexer/src/generated/methods.rs
. It includes zkVM logic and code generation for the ZK Verifier Smart Contracts.src/contracts
: The Near Contracts represent the X NFTs project on the Near blockchain.src/contracts/nft
: The Near NFT Contract manages mint intents, cancellations, and verifiable metadata from the ZK Prover.src/contracts/verifier
: The ZK Verifier Contract verifies ZK Proofs on the Aurora blockchain. A Near <> Aurora message prootocol is used to bridge verified proofs from the EVM environment to the NEAR environment.
Please see the Near Contracts Guide for more information on managing the Near contracts.
Please see the ZK Verifier Contracts Guide for more information on deploying the EVM ZK Verifier.