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

Download history 77/week @ 2024-09-27 16/week @ 2024-10-04 14/week @ 2024-10-11 8/week @ 2024-10-25 24/week @ 2024-11-01 21/week @ 2024-11-08 65/week @ 2024-11-15 62/week @ 2024-11-22 66/week @ 2024-11-29 93/week @ 2024-12-06 101/week @ 2024-12-13 65/week @ 2024-12-20 33/week @ 2024-12-27 45/week @ 2025-01-03 213/week @ 2025-01-10

374 downloads per month
Used in polkadot-sdk

GPL-3.0-or-later…

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 with max_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 with MAX_TOTAL_SIZE size. To satisfy this, statements are removed from the store starting with the lowest global_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