starknet.dart
The goal of this SDK is to be able to interact with StarkNet smart contracts in a type-safe way.
You can also call the JSON-RPC endpoint exposed by the StarkNet full nodes (see the specs).
📚 docs
💬 telegram chat
Motivation
StarkNet is a revolution in the web3 world: it allows to scale Ethereum and offers the best possible UX thanks to unique features like account abstraction or session keys.
But web3 mainstream adoption won't happen unless decentralized applications go to mobile.
That's why it's a priority to build the best possible Starknet SDK for dart applications, thus unlocking the era of Flutter mobile apps on StarkNet.
Roadmap
You can follow the progress of the project directly on the kanban.
Contributing
If you want to contribute to this project or have any suggestion, please check out our Contributor Guide.
Dev Guide
Initial Setup
Refer to the main README for the initial setup.
Run Tests
You can run the tests with the following command:
dart test
To run the tests on devnet use the following command:
NETWORK=devnet dart test -t integration-devnet-040
Release a new version to pub.dev
You simply need to create a PR where you:
- Bump the package version
- Add an entry to the
CHANGELOG
Make sure it passes all the CI tests, then merge it to release a new version of the package.
Generate freezed model classes
To avoid writing too much boilerplate, we use the freezed library to automatically generate serializer logic.
You can run the following command to generate those classes:
dart run build_runner build
Alternatively, you can hit Cmd + Shift + B
in vscode.
Generate docs
To generate docs, run:
dart doc .
For more advanced features, check out the dartdoc package.
Compile cairo contracts
Refer to the main README for compiling cairo contracts.
You can also see compiled contracts in this folder.
Libraries
- starknet
- The Starknet Dart SDK ✨