This is the Snapshot monorepository containing a Vue frontend, GraphQL API, transaction relayer, and TypeScript SDK.
- ./apps/ui: Snapshot official frontend using Vue 3
- ./apps/api: Multichain indexer for Snapshot X using Checkpoint
- ./apps/mana: Transaction relayer for gasless voting on Snapshot X
- ./packages/sx.js: TypeScript SDK for Snapshot and Snapshot X
yarn
yarn devyarn build
yarn lint
yarn test
yarn test:e2e
yarn typecheck
You can run all local services (api, mana, ui) with single command assuming you have all necessary environment variables set up. Local APIs will only be used for Ethereum Sepolia and Starknet Sepolia.
This command will allow you to select which services you want to run.
yarn dev:interactive
You need to have Docker running on your machine.
In apps/api and apps/mana copy .env.example to .env files.
In apps/mana/.env you need to fill in following empty variables:
- WALLET_SECRET- if you want to use it as relayer (used for both Starknet and Ethereum wallets).
- HERODOTUS_API_KEYand- HERODOTUS_LEGACY_API_KEY- if you want to use L1<->L2 messaging (voting with strategies that use L1 proofs)
If you run yarn dev:interactive it will take long time to sync all the blocks for the first time. To mitigate it you can just change starting block
for indexing here:
- (for Starknet)
- (for Ethereum)sx-monorepo/apps/api/src/evm/config.ts Line 23 in 9f5c784 
If you do that make sure to create a new space, because spaces created before the new starting block you picked won't be available.
Packages are versioned using changesets.
In most cases all you need to do is when adding new changes to versioned packages (right now it's just sx.js)
is to execute yarn changeset, specify package you updated, version bump per semver and description of your changes.
Then commit generated files in your PR.
Once merged changesets actions will create PR that can be used to release and publish those packages.