mirror of
https://github.com/embarklabs/subspace.git
synced 2025-02-21 10:58:25 +00:00
21 lines
1.3 KiB
Markdown
21 lines
1.3 KiB
Markdown
# How it works?
|
|
|
|
### Setup
|
|
data:image/s3,"s3://crabby-images/34cee/34cee0980b6b4654a762b6e35ef4d7829006fb57" alt="First Usage - Setup"
|
|
1. A ÐApp requests `Subspace` to track an event, property, or balance.
|
|
2. `Subspace` creates a observable for that event, and a web3 subscription to retrieve events from the chain
|
|
3. The ÐApp subscribes to the observable to receive events.
|
|
|
|
### Receiving events
|
|
data:image/s3,"s3://crabby-images/f5ae2/f5ae2f1f200502f2863efbf8018214212196d2bf" alt="First Usage - Receiving events"
|
|
Depending on the filter parameters used to track the events, once an event is found, it is stored in `localStorage` and it is also pushed to the observable which delivers it to the ÐApp subscription.
|
|
|
|
### Tracking already known events
|
|
After restarting the ÐApp, either by executing it again in case of a console application or refreshing the browser the behavior of `Subspace` will change:
|
|
data:image/s3,"s3://crabby-images/4d491/4d4913c0c6e8283560263e770f5e48087e28b44f" alt="Second Usage - Setup"
|
|
1. The Dapp will request `Subspace` to track an event it already knows, creating an observable and subscription for that event
|
|
2. It will retrieve events that were previously stored in localStorage and deliver them to the DApp subscription, avoiding having to query the chain for the old events again.
|
|
|
|
data:image/s3,"s3://crabby-images/da2cf/da2cff74b8bee2a4b998196f34aa0e8d51c578ab" alt="Second Usage - Receiving events"
|
|
The web3 subscription created previously will start from the last known block instead of beginning from scratch. New events will be delivered normally from this step
|