crdt_sync
A Dart-native turnkey solution for painless network synchronization.
crdt_sync
takes care of the network plumbing between your app and backend to build products that are:
- Offline-first: Apps primarily work with a local store independent of network connectivity.
- Real-time: When online, the local store immediately and continuously synchronizes with the backend.
- Efficient: Synchronization relies on delta changesets to optimize the amount of data sent over the wire.
- Portable: All communication happens over a single standard WebSocket making it compatible with most network configurations.
This library is compatible with the crdt
package and all of its implementations. It uses a standard communication protocol which abstracts the underlying storage method. This results in the dubious ability to synchronize SQL nodes with No-SQL ones. I don't judge.
See crdt for more details and a list of existing implementations.
Usage
You'll most likely want to use a persistent crdt
store, however the following sample code uses an ephemeral MapCrdt
for the sake of simplicity:
final crdt = MapCrdt(['chat']);
Server
Start listening for connections:
listen(crdt, 8080);
Alternatively, you can use upgrade()
to adopt an HttpRequest
, or CrdtSync.server()
to manage a WebSocket
directly making it easy to integrate with Shelf and other server frameworks.
See tudo_server for a real world example.
Client
Instantiate a CrdtSyncClient
and order it to start connecting:
final client = CrdtSyncClient(crdt, Uri.parse('ws://localhost:8080'));
client.connect();
Once connect()
is called, the client will continuously attempt to establish or resume a connection until it succeeds, or until disconnect()
is called.
See the included example for a more complete solution, or tudo for a real-world application.
Features and bugs
Please file feature requests and bugs in the issue tracker.