23 releases (major breaking)
new 20.0.0 | Jan 13, 2025 |
---|---|
19.0.1 | Sep 26, 2024 |
19.0.0 | Jul 18, 2024 |
17.0.0 | Jun 21, 2024 |
0.1.0-dev.2 | Jul 27, 2023 |
#541 in Magic Beans
374 downloads per month
Used in polkadot-sdk
1.5MB
20K
SLoC
Substrate statement store implementation.
License: GPL-3.0-or-later WITH Classpath-exception-2.0
Release
Polkadot SDK Stable 2412
lib.rs
:
Disk-backed statement store.
This module contains an implementation of sp_statement_store::StatementStore
which is backed
by a database.
Constraint management.
Each time a new statement is inserted into the store, it is first validated with the runtime
Validation function computes global_priority
, 'max_count' and max_size
for a statement.
The following constraints are then checked:
- For a given account id, there may be at most
max_count
statements withmax_size
total data size. To satisfy this, statements for this account ID are removed from the store starting with the lowest priority until a constraint is satisfied. - There may not be more than
MAX_TOTAL_STATEMENTS
total statements withMAX_TOTAL_SIZE
size. To satisfy this, statements are removed from the store starting with the lowestglobal_priority
until a constraint is satisfied.
When a new statement is inserted that would not satisfy constraints in the first place, no
statements are deleted and Ignored
result is returned.
The order in which statements with the same priority are deleted is unspecified.
Statement expiration.
Each time a statement is removed from the store (Either evicted by higher priority statement or
explicitly with the remove
function) the statement is marked as expired. Expired statements
can't be added to the store for Options::purge_after_sec
seconds. This is to prevent old
statements from being propagated on the network.
Dependencies
~68MB
~1M SLoC