Figure 1 SubVT system (click for the large version)
1. Block Processor/Indexer (code)
- Subscribes to the finalized blocks on the Substrate node using the SubVT Substrate client.
- Fetches and stores the events and extrinsics (only the ones that are of interest to SubVT, such as validate extrinsics, offline and rewarded events etc.) of each block in the PostgreSQL network database.
- Stores era, era validator, era staker, total era points, era point per validator and more data as it moves block by block.
NOTIFY
s the PostgreSQL network database. Notification generator subscribes to this notification, and scans the persisted block data for possible notification cases.
2. Network Status Updater (code)
- With every new finalized block, fetches the network status data from the Subtrate node and stores it in the Redis
in-memory database, and makes a
PUBLISH
call so that Redis can notify the network status server and notification server to carry out their related operations on the fresh network status data. - Network status data contains finalized and best block numbers and hashes, active era and current epoch, active and inactive validator counts, total stake, minimum/maximum/average/median validator stakes, and more information.
3. Network Status WS Server (code)
- Specified here.
- Subscribes to the Redis notifications from the network status updater.
- Accepts incoming WebSocket pub/sub connections through the configured port.
- Provides two RPC methods:
subscribe_networkStatus
andunsubscribe_networkStatus
. - Sends the complete network status data to the client on initial subscription, and then only sends the updated parts of the network status data after each new finalized block as long as the client remains connected.
- Designed to provide data to the SubVT network status screen.
4. Validator List Updater (code)
- Every few blocks, fetches the complete inactive and active validator data from the Substrate node.
- Also fetches the indexed validator data from the PostgreSQL network database such as account discovered/killed at, slashes, era reward points if active, heartbeat events, 1KV if exists, etc.
- Prepares validator details and validator summary data, and stores all this data in Redis along with the hashes for each record, so that any component observing the records can figure out whether the records have changed by comparing the hashes, without the need to fetch the complete data.
PUBLISH
es a Redis notification after the successful processing on a finalized block.
4. Active Validator List WS Server (code)
- Specified here.
- Serves the active validator list.
- Subscribes to the Redis event published by the validator list updater.
- Accepts incoming WebSocket pub/sub connections through the configured port.
- Provides two RPC methods:
subscribe_validatorList
andunsubscribe_validatorList
. - Sends the complete validator list data to the client on initial subscription, and then only sends the updated parts of the validator list data after each update from the validator list updater as long as the client remains connected.
- Designed to provide data to the SubVT active and inactive validator list screens.
5. Inactive Validator List WS Server (code)
- Same as the previous, but serves the inactive validator list.
6. Validator Details WS Server (code)
- Specified here.
- Subscribes to the Redis event published by the validator list updater.
- Accepts incoming WebSocket pub/sub connections through the configured port.
- Provides two RPC methods:
subscribe_validatorDetails
andunsubscribe_validatorDetails
, former with the validator account id in hex format as the first parameter. - Send the complete validator details data to the client on initial subscription, and then only sends the updated parts of the validator details data after each update from the validator list updater as long as the client remains connected.
7. 1KV Updater (code)
- Fetches the complete candidate data from the 1KV backend (only Polkadot or Kusama).
- Stores the candidate data in the PostgreSQL network database.
- Data is then used to generate 1KV-related notifications, also served by the validator list and validator details services.
8. Telemetry Processor (code)
- Subscribed to the Telemetry feed of the configured Telemetry server (possibly W3F or Polkadot Telemetry servers).
- Stores node data, and utilizes TimescaleDB extension for PostgreSQL to store node statistics (transaction count, peer count), hardware (upload/download bandwidth) time-series data.
- Provides data to the notification generator component, which does regular checks on the time-series data for possible notification cases.
9. Notification Generator (code)
- Processes the indexed block (PostgreSQL), validator list (Redis) and Telemetry time-series (TimescaleDB) data for possible notifications.
- Requires notification rules to be defined by the system or users.
- Persists notifications into the PostgreSQL application database, soon to be processed by the notification sender.
10. Notification Processor (code)
- Processes the notifications persisted by the notification generator, and sends notifications to the appropriate channels (APNS, FCM, email, SMS, GSM, Telegram, etc.) as defined by the notification rules.
- Uses different templates for different channels to generate notification content.
11. Report REST Service (code)
- Specified here, viewable here.
- Public REST services that serves era and era-validator reports.
- Gets its data completely from the PostgreSQL network database.
12. Application REST Service (code)
- Specified here, viewable here.
- SubVT application-related public and secure REST services such as:
GET
network list.GET
notification types.GET
notification channels.POST
new user.POST
new notification channel for user (e.g. add a new email address or phone number for SMS).POST
new notification rule for user.DELETE
one of the user's notification rules.POST
new validator for the user (i.e. bookmark).- And many more.
12. Telegram Bot (code)
A super-powered upgrade for the now-deprecated 1KV Bot. Please view the bot readme for the live bot links and complete list of commands and notifications.
Current model builds on top of the initial proposal, and is perfectly feasible as shown by the current implementation.