Development Stage Warning: The contracts in this repository are currently under development. Use them at your own risk.
This repository contains EVM contracts that form the foundation of the DappyKit ecosystem. These contracts are designed to allow billions of users to use DappyKit without any scaling, speed, or cost issues with transactions.
The core idea is to give users a choice in how they interact with smart contracts:
- Fully Decentralized: By using their own node infrastructure and paying for each operation individually.
- Through a Gateway: Gateways accept user modifications in the form of signed data, package them into a data block, and store a reference to it. This approach saves users' finances, as gateways pay for the transaction to store the reference only.
- Hybrid Approach: Users can use their own infrastructure in combination with gateways for greater flexibility and cost optimization.
The following contracts are available in the repository:
SocialConnections.sol
: Designed to store references to data about people's social connections.FilesystemChanges.sol
: Intended for storing references to data about changes in people's file systems.UserVerification.sol
: Used to issue a verification token to the user, confirming their registration in an external system.
Contract | Superchain Address |
---|---|
SocialConnections.sol | 0x99583220489a0e4217911ECf50680918F6a8B958 |
FilesystemChanges.sol | 0x30C974bE6581e3a00595d0b7C1ba7A8A91413e1f |
Contract | Address |
---|---|
UserVerification.sol - Google | 0xf9bEDeCc559EC47D0Ffb7341dcaefc74450612A7 |
UserVerification.sol - Farcaster | 0x02e4227ed20379db2999511609b8e2b28f73f0e0 |
UserVerification.sol - Telegram | 0x1bf480128191963ba004f325fc02363ca0bb1fff |
# install dependencies
npm ci
# test the contracts
npx hardhat test
# localhost
npx hardhat node # start a local node
npm run deploy-all-localhost
# OP Sepolia
npm run deploy-all-testnet-op
# OP Mainnet
npm run deploy-all-mainnet
# copy and fill the env file with the correct data
cp example.env .env
# deploy all the contracts to the test node
npm run deploy-test
# the deployed addresses will be saved in `dappy-contracts/deployed-contracts.json`
# copy and fill the env file with the correct data
cp example.env .env
# deploy all the contracts to Optimism Sepolia
npm run deploy-op-sepolia
# verify on Sourcify and Etherscan
npx hardhat verify --network testnet DEPLOYED_CONTRACT_ADDRESS
# the deployed addresses will be saved in `./deployed-contracts.json`
# copy and fill the env file with the correct data
cp example.env .env
# deploy all the contracts to Optimism Mainnet
npm run deploy-op-mainnet
# verify on Sourcify and Etherscan
npx hardhat verify --network mainnet DEPLOYED_CONTRACT_ADDRESS
# the deployed addresses will be saved in `./deployed-contracts.json`