From a0845487447cb4a47d8f55c7e9d90c7d4d122a4a Mon Sep 17 00:00:00 2001 From: jbearer Date: Tue, 22 Oct 2024 17:48:54 +0000 Subject: [PATCH] deploy: 4a2dc4648036b604f4df70bb454dc15eda03acdf --- hotshot_query_service/all.html | 2 +- .../trait.AvailabilityDataSource.html | 18 +- .../trait.UpdateAvailabilityData.html | 8 +- .../data_source/fetching/index.html | 2 +- .../fetching/struct.FetchingDataSource.html | 96 ++++----- .../data_source/fetching/struct.Pruner.html | 8 +- .../fetching/trait.AvailabilityProvider.html | 4 +- .../sql/macro.include_migrations.html | 2 +- .../data_source/storage/fs/index.html | 2 +- .../storage/fs/struct.FileSystemStorage.html | 39 ++-- .../fs/struct.FileSystemStorageInner.html | 6 +- .../storage/fs/struct.Transaction.html | 50 ++--- .../data_source/storage/fs/trait.Revert.html | 8 +- .../data_source/storage/no_storage/index.html | 2 +- .../storage/no_storage/struct.NoStorage.html | 10 +- .../no_storage/struct.Transaction.html | 46 ++--- .../no_storage/testing/enum.DataSource.html | 66 +++--- .../no_storage/testing/enum.Storage.html | 2 +- .../no_storage/testing/enum.Transaction.html | 26 +-- .../storage/no_storage/testing/index.html | 2 +- .../storage/pruning/trait.PruneStorage.html | 4 +- .../pruning/trait.PrunedHeightStorage.html | 4 +- .../storage/pruning/trait.PrunerConfig.html | 2 +- .../storage/sql/fn.default_migrations.html | 2 +- .../data_source/storage/sql/fn.query.html | 2 +- .../data_source/storage/sql/fn.query_as.html | 2 +- .../data_source/storage/sql/index.html | 2 +- .../storage/sql/macro.include_migrations.html | 2 +- .../storage/sql/struct.Config.html | 40 ++-- .../storage/sql/struct.Pruner.html | 2 +- .../data_source/storage/sql/struct.Read.html | 4 +- .../storage/sql/struct.SqlStorage.html | 14 +- .../storage/sql/struct.Transaction.html | 30 +-- .../data_source/storage/sql/struct.Write.html | 4 +- .../storage/sql/testing/index.html | 2 +- .../struct.TestMerkleTreeMigration.html | 2 +- .../storage/sql/testing/struct.TmpDb.html | 2 +- .../storage/sql/trait.FixedLengthParams.html | 18 +- .../data_source/storage/sql/trait.Params.html | 40 ++-- .../storage/sql/trait.TransactionMode.html | 9 +- .../data_source/storage/sql/type.Query.html | 2 +- .../data_source/storage/sql/type.QueryAs.html | 2 +- .../storage/trait.AvailabilityStorage.html | 4 +- .../storage/trait.NodeStorage.html | 6 +- .../struct.ExtensibleDataSource.html | 53 ++--- .../data_source/struct.MetricsDataSource.html | 20 +- .../data_source/trait.Transaction.html | 8 +- .../trait.VersionedDataSource.html | 24 +-- hotshot_query_service/enum.QueryError.html | 16 +- .../explorer/trait.ExplorerDataSource.html | 4 +- .../fetching/provider/struct.AnyProvider.html | 2 +- .../fetching/provider/struct.NoFetching.html | 2 +- .../provider/struct.QueryServiceProvider.html | 2 +- .../provider/struct.TestProvider.html | 2 +- .../fn.run_standalone_service.html | 2 +- hotshot_query_service/index.html | 13 +- .../macro.include_migrations.html | 2 +- .../trait.MerklizedStateDataSource.html | 4 +- ...trait.MerklizedStateHeightPersistence.html | 4 +- .../trait.UpdateStateData.html | 4 +- .../node/trait.NodeDataSource.html | 4 +- .../status/data_source/trait.HasMetrics.html | 11 + hotshot_query_service/status/index.html | 2 +- hotshot_query_service/status/sidebar-items.js | 2 +- .../status/trait.HasMetrics.html | 9 + .../status/trait.StatusDataSource.html | 17 +- .../status/trait.UpdateStatusData.html | 4 +- hotshot_query_service/struct.ApiState.html | 4 +- hotshot_query_service/struct.ErrorSnafu.html | 10 +- .../struct.MissingSnafu.html | 10 +- .../struct.NotFoundSnafu.html | 10 +- hotshot_query_service/struct.Options.html | 4 +- .../consensus/trait.DataSourceLifeCycle.html | 4 +- .../testing/mocks/struct.MockTypes.html | 60 +++--- hotshot_query_service/type.Header.html | 2 +- hotshot_query_service/type.Metadata.html | 2 +- hotshot_query_service/type.Payload.html | 2 +- hotshot_query_service/type.QueryResult.html | 2 +- hotshot_query_service/type.SignatureKey.html | 2 +- hotshot_query_service/type.Transaction.html | 2 +- search-index.js | 4 +- .../hotshot_query_service-desc-0-.js | 2 +- .../data_source/extension.rs.html | 20 +- .../data_source/fetching.rs.html | 24 ++- .../data_source/metrics.rs.html | 22 +- .../data_source/storage/fs.rs.html | 30 +++ .../data_source/storage/no_storage.rs.html | 38 +++- .../data_source/storage/sql.rs.html | 34 +++- .../storage/sql/transaction.rs.html | 192 ++++++++++++++++-- src/hotshot_query_service/lib.rs.html | 26 ++- .../status/data_source.rs.html | 10 +- .../panic/unwind_safe/trait.UnwindSafe.js | 4 +- .../status/data_source/trait.HasMetrics.js | 9 + .../fetching/struct.FetchingDataSource.js | 4 +- .../data_source/storage/sql/struct.Config.js | 2 +- 95 files changed, 831 insertions(+), 515 deletions(-) create mode 100644 hotshot_query_service/status/data_source/trait.HasMetrics.html create mode 100644 hotshot_query_service/status/trait.HasMetrics.html create mode 100644 trait.impl/hotshot_query_service/status/data_source/trait.HasMetrics.js diff --git a/hotshot_query_service/all.html b/hotshot_query_service/all.html index 2ef3e2957..150d27d33 100644 --- a/hotshot_query_service/all.html +++ b/hotshot_query_service/all.html @@ -1 +1 @@ -List of all items in this crate

List of all items

Structs

Enums

Traits

Macros

Functions

Type Aliases

Constants

\ No newline at end of file +List of all items in this crate

List of all items

Structs

Enums

Traits

Macros

Functions

Type Aliases

Constants

\ No newline at end of file diff --git a/hotshot_query_service/availability/trait.AvailabilityDataSource.html b/hotshot_query_service/availability/trait.AvailabilityDataSource.html index 680aa9db2..fe3635363 100644 --- a/hotshot_query_service/availability/trait.AvailabilityDataSource.html +++ b/hotshot_query_service/availability/trait.AvailabilityDataSource.html @@ -202,13 +202,13 @@ from: usize, ) -> Pin<Box<dyn Future<Output = BoxStream<'static, VidCommonQueryData<Types>>> + Send + 'async_trait>>
where Self: Sync + 'async_trait, - 'life0: 'async_trait,

Object Safety§

This trait is not object safe.

Implementors§

source§

impl AvailabilityDataSource<MockTypes> for DataSource

source§

type LeafRange<R> = Pin<Box<dyn Stream<Item = Fetch<LeafQueryData<MockTypes>>> + Send>> + 'life0: 'async_trait,

Object Safety§

This trait is not object safe.

Implementors§

source§

impl AvailabilityDataSource<MockTypes> for DataSource

source§

type LeafRange<R> = Pin<Box<dyn Stream<Item = Fetch<LeafQueryData<MockTypes>>> + Send>> where - R: RangeBounds<usize> + Send

source§

type BlockRange<R> = Pin<Box<dyn Stream<Item = Fetch<BlockQueryData<MockTypes>>> + Send>> + R: RangeBounds<usize> + Send

source§

type BlockRange<R> = Pin<Box<dyn Stream<Item = Fetch<BlockQueryData<MockTypes>>> + Send>> where - R: RangeBounds<usize> + Send

source§

type PayloadRange<R> = Pin<Box<dyn Stream<Item = Fetch<PayloadQueryData<MockTypes>>> + Send>> + R: RangeBounds<usize> + Send

source§

type PayloadRange<R> = Pin<Box<dyn Stream<Item = Fetch<PayloadQueryData<MockTypes>>> + Send>> where - R: RangeBounds<usize> + Send

source§

type VidCommonRange<R> = Pin<Box<dyn Stream<Item = Fetch<VidCommonQueryData<MockTypes>>> + Send>> + R: RangeBounds<usize> + Send

source§

type VidCommonRange<R> = Pin<Box<dyn Stream<Item = Fetch<VidCommonQueryData<MockTypes>>> + Send>> where R: RangeBounds<usize> + Send

source§

impl<D, U, Types> AvailabilityDataSource<Types> for ExtensibleDataSource<D, U>
where D: AvailabilityDataSource<Types> + Send + Sync, @@ -222,18 +222,18 @@ where R: RangeBounds<usize> + Send

source§

type VidCommonRange<R> = <D as AvailabilityDataSource<Types>>::VidCommonRange<R> where - R: RangeBounds<usize> + Send

source§

impl<Types, S, P> AvailabilityDataSource<Types> for FetchingDataSource<Types, S, P>
where + R: RangeBounds<usize> + Send

source§

impl<Types, S, P> AvailabilityDataSource<Types> for FetchingDataSource<Types, S, P>
where Types: NodeType, Payload<Types>: QueryablePayload<Types>, S: VersionedDataSource + 'static, for<'a> S::Transaction<'a>: UpdateAvailabilityData<Types>, for<'a> S::ReadOnly<'a>: AvailabilityStorage<Types> + NodeStorage<Types> + PrunedHeightStorage, - P: AvailabilityProvider<Types>,

source§

type LeafRange<R> = Pin<Box<dyn Stream<Item = Fetch<LeafQueryData<Types>>> + Send>> + P: AvailabilityProvider<Types>,

source§

type LeafRange<R> = Pin<Box<dyn Stream<Item = Fetch<LeafQueryData<Types>>> + Send>> where - R: RangeBounds<usize> + Send

source§

type BlockRange<R> = Pin<Box<dyn Stream<Item = Fetch<BlockQueryData<Types>>> + Send>> + R: RangeBounds<usize> + Send

source§

type BlockRange<R> = Pin<Box<dyn Stream<Item = Fetch<BlockQueryData<Types>>> + Send>> where - R: RangeBounds<usize> + Send

source§

type PayloadRange<R> = Pin<Box<dyn Stream<Item = Fetch<PayloadQueryData<Types>>> + Send>> + R: RangeBounds<usize> + Send

source§

type PayloadRange<R> = Pin<Box<dyn Stream<Item = Fetch<PayloadQueryData<Types>>> + Send>> where - R: RangeBounds<usize> + Send

source§

type VidCommonRange<R> = Pin<Box<dyn Stream<Item = Fetch<VidCommonQueryData<Types>>> + Send>> + R: RangeBounds<usize> + Send

source§

type VidCommonRange<R> = Pin<Box<dyn Stream<Item = Fetch<VidCommonQueryData<Types>>> + Send>> where R: RangeBounds<usize> + Send

\ No newline at end of file diff --git a/hotshot_query_service/availability/trait.UpdateAvailabilityData.html b/hotshot_query_service/availability/trait.UpdateAvailabilityData.html index 7313329d5..58d1a3d67 100644 --- a/hotshot_query_service/availability/trait.UpdateAvailabilityData.html +++ b/hotshot_query_service/availability/trait.UpdateAvailabilityData.html @@ -35,17 +35,17 @@ share: Option<VidShare>, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

Implementors§

source§

impl<'a, T> UpdateAvailabilityData<MockTypes> for hotshot_query_service::data_source::storage::no_storage::testing::Transaction<'a, T>
where + 'life0: 'async_trait,

Implementors§

source§

impl<'a, T> UpdateAvailabilityData<MockTypes> for hotshot_query_service::data_source::storage::no_storage::testing::Transaction<'a, T>

source§

impl<'a, Types, T> UpdateAvailabilityData<Types> for hotshot_query_service::data_source::fetching::Transaction<'a, Types, T>
where Types: NodeType, Payload<Types>: QueryablePayload<Types>, - T: UpdateAvailabilityData<Types> + Send + Sync,

source§

impl<'a, Types: NodeType> UpdateAvailabilityData<Types> for hotshot_query_service::data_source::storage::fs::Transaction<RwLockWriteGuard<'a, FileSystemStorageInner<Types>>>
where + T: UpdateAvailabilityData<Types> + Send + Sync,

source§

impl<'a, Types: NodeType> UpdateAvailabilityData<Types> for hotshot_query_service::data_source::storage::fs::Transaction<RwLockWriteGuard<'a, FileSystemStorageInner<Types>>>
where Payload<Types>: QueryablePayload<Types>, - Header<Types>: QueryableHeader<Types>,

source§

impl<'a, Types: NodeType> UpdateAvailabilityData<Types> for hotshot_query_service::data_source::storage::no_storage::Transaction<'a>
where + Header<Types>: QueryableHeader<Types>,

source§

impl<'a, Types: NodeType> UpdateAvailabilityData<Types> for hotshot_query_service::data_source::storage::no_storage::Transaction<'a>
where Payload<Types>: QueryablePayload<Types>,

source§

impl<D, U, Types> UpdateAvailabilityData<Types> for ExtensibleDataSource<D, U>
where D: UpdateAvailabilityData<Types> + Send + Sync, U: Send + Sync, - Types: NodeType,

source§

impl<Types> UpdateAvailabilityData<Types> for hotshot_query_service::data_source::storage::sql::Transaction<Write>
where + Types: NodeType,

source§

impl<Types> UpdateAvailabilityData<Types> for hotshot_query_service::data_source::storage::sql::Transaction<Write>
where Types: NodeType, Payload<Types>: QueryablePayload<Types>, Header<Types>: QueryableHeader<Types>,

\ No newline at end of file diff --git a/hotshot_query_service/data_source/fetching/index.html b/hotshot_query_service/data_source/fetching/index.html index 0f48fbc38..7b5781424 100644 --- a/hotshot_query_service/data_source/fetching/index.html +++ b/hotshot_query_service/data_source/fetching/index.html @@ -1,4 +1,4 @@ -hotshot_query_service::data_source::fetching - Rust

Module hotshot_query_service::data_source::fetching

source ·
Expand description

Asynchronous retrieval of missing data.

+hotshot_query_service::data_source::fetching - Rust

Module hotshot_query_service::data_source::fetching

source ·
Expand description

Asynchronous retrieval of missing data.

FetchingDataSource combines a local storage implementation with a remote data availability provider to create a data sources which caches data locally, but which is capable of fetching missing data from a remote source, either proactively or on demand.

diff --git a/hotshot_query_service/data_source/fetching/struct.FetchingDataSource.html b/hotshot_query_service/data_source/fetching/struct.FetchingDataSource.html index 749e9999b..9d311ee28 100644 --- a/hotshot_query_service/data_source/fetching/struct.FetchingDataSource.html +++ b/hotshot_query_service/data_source/fetching/struct.FetchingDataSource.html @@ -1,4 +1,4 @@ -FetchingDataSource in hotshot_query_service::data_source::fetching - Rust
pub struct FetchingDataSource<Types, S, P>
where +FetchingDataSource in hotshot_query_service::data_source::fetching - Rust
pub struct FetchingDataSource<Types, S, P>
where Types: NodeType,
{ /* private fields */ }
Expand description

The most basic kind of data source.

A data source is constructed modularly by combining a storage implementation with a Fetcher. The former allows the query service to store the @@ -13,14 +13,14 @@ sources can be constructed out of FetchingDataSource by changing the storage and fetcher implementations used, and more complex data sources can be built on top using data source combinators.

-

Implementations§

source§

impl<Types, S, P> FetchingDataSource<Types, S, P>
where +

Implementations§

source§

impl<Types, S, P> FetchingDataSource<Types, S, P>
where Types: NodeType, Payload<Types>: QueryablePayload<Types>, Header<Types>: QueryableHeader<Types>, S: VersionedDataSource + PruneStorage + 'static, for<'a> S::Transaction<'a>: UpdateAvailabilityData<Types>, for<'a> S::ReadOnly<'a>: AvailabilityStorage<Types> + NodeStorage<Types> + PrunedHeightStorage, - P: AvailabilityProvider<Types>,

source

pub fn builder(storage: S, provider: P) -> Builder<Types, S, P>

Build a FetchingDataSource with the given storage and provider.

+ P: AvailabilityProvider<Types>,
source

pub fn builder(storage: S, provider: P) -> Builder<Types, S, P>

Build a FetchingDataSource with the given storage and provider.

source§

impl<Types: NodeType, P> FetchingDataSource<Types, FileSystemStorage<Types>, P>
where Payload<Types>: QueryablePayload<Types>, Header<Types>: QueryableHeader<Types>, @@ -67,70 +67,70 @@ underlying FetchingDataSource, before constructing the SqlDataSource with build. For a convenient constructor that uses the default fetching options, see Config::connect.

-

Trait Implementations§

source§

impl<Types, S, P> AsRef<S> for FetchingDataSource<Types, S, P>
where - Types: NodeType,

source§

fn as_ref(&self) -> &S

Converts this type into a shared reference of the (usually inferred) input type.
source§

impl<Types, S, P> AvailabilityDataSource<Types> for FetchingDataSource<Types, S, P>
where +

Trait Implementations§

source§

impl<Types, S, P> AsRef<S> for FetchingDataSource<Types, S, P>
where + Types: NodeType,

source§

fn as_ref(&self) -> &S

Converts this type into a shared reference of the (usually inferred) input type.
source§

impl<Types, S, P> AvailabilityDataSource<Types> for FetchingDataSource<Types, S, P>
where Types: NodeType, Payload<Types>: QueryablePayload<Types>, S: VersionedDataSource + 'static, for<'a> S::Transaction<'a>: UpdateAvailabilityData<Types>, for<'a> S::ReadOnly<'a>: AvailabilityStorage<Types> + NodeStorage<Types> + PrunedHeightStorage, - P: AvailabilityProvider<Types>,

source§

type LeafRange<R> = Pin<Box<dyn Stream<Item = Fetch<LeafQueryData<Types>>> + Send>> + P: AvailabilityProvider<Types>,

source§

type LeafRange<R> = Pin<Box<dyn Stream<Item = Fetch<LeafQueryData<Types>>> + Send>> where - R: RangeBounds<usize> + Send

source§

type BlockRange<R> = Pin<Box<dyn Stream<Item = Fetch<BlockQueryData<Types>>> + Send>> + R: RangeBounds<usize> + Send

source§

type BlockRange<R> = Pin<Box<dyn Stream<Item = Fetch<BlockQueryData<Types>>> + Send>> where - R: RangeBounds<usize> + Send

source§

type PayloadRange<R> = Pin<Box<dyn Stream<Item = Fetch<PayloadQueryData<Types>>> + Send>> + R: RangeBounds<usize> + Send

source§

type PayloadRange<R> = Pin<Box<dyn Stream<Item = Fetch<PayloadQueryData<Types>>> + Send>> where - R: RangeBounds<usize> + Send

source§

type VidCommonRange<R> = Pin<Box<dyn Stream<Item = Fetch<VidCommonQueryData<Types>>> + Send>> + R: RangeBounds<usize> + Send

source§

type VidCommonRange<R> = Pin<Box<dyn Stream<Item = Fetch<VidCommonQueryData<Types>>> + Send>> where - R: RangeBounds<usize> + Send

source§

fn get_leaf<'life0, 'async_trait, ID>( + R: RangeBounds<usize> + Send

source§

fn get_leaf<'life0, 'async_trait, ID>( &'life0 self, id: ID, ) -> Pin<Box<dyn Future<Output = Fetch<LeafQueryData<Types>>> + Send + 'async_trait>>
where ID: Into<LeafId<Types>> + Send + Sync + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_block<'life0, 'async_trait, ID>( + 'life0: 'async_trait,

source§

fn get_block<'life0, 'async_trait, ID>( &'life0 self, id: ID, ) -> Pin<Box<dyn Future<Output = Fetch<BlockQueryData<Types>>> + Send + 'async_trait>>
where ID: Into<BlockId<Types>> + Send + Sync + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_payload<'life0, 'async_trait, ID>( + 'life0: 'async_trait,

source§

fn get_payload<'life0, 'async_trait, ID>( &'life0 self, id: ID, ) -> Pin<Box<dyn Future<Output = Fetch<PayloadQueryData<Types>>> + Send + 'async_trait>>
where ID: Into<BlockId<Types>> + Send + Sync + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_vid_common<'life0, 'async_trait, ID>( + 'life0: 'async_trait,

source§

fn get_vid_common<'life0, 'async_trait, ID>( &'life0 self, id: ID, ) -> Pin<Box<dyn Future<Output = Fetch<VidCommonQueryData<Types>>> + Send + 'async_trait>>
where ID: Into<BlockId<Types>> + Send + Sync + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_leaf_range<'life0, 'async_trait, R>( + 'life0: 'async_trait,

source§

fn get_leaf_range<'life0, 'async_trait, R>( &'life0 self, range: R, ) -> Pin<Box<dyn Future<Output = Self::LeafRange<R>> + Send + 'async_trait>>
where R: RangeBounds<usize> + Send + 'static + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_block_range<'life0, 'async_trait, R>( + 'life0: 'async_trait,

source§

fn get_block_range<'life0, 'async_trait, R>( &'life0 self, range: R, ) -> Pin<Box<dyn Future<Output = Self::BlockRange<R>> + Send + 'async_trait>>
where R: RangeBounds<usize> + Send + 'static + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_payload_range<'life0, 'async_trait, R>( + 'life0: 'async_trait,

source§

fn get_payload_range<'life0, 'async_trait, R>( &'life0 self, range: R, ) -> Pin<Box<dyn Future<Output = Self::PayloadRange<R>> + Send + 'async_trait>>
where R: RangeBounds<usize> + Send + 'static + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_vid_common_range<'life0, 'async_trait, R>( + 'life0: 'async_trait,

source§

fn get_vid_common_range<'life0, 'async_trait, R>( &'life0 self, range: R, ) -> Pin<Box<dyn Future<Output = Self::VidCommonRange<R>> + Send + 'async_trait>>
where R: RangeBounds<usize> + Send + 'static + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_transaction<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn get_transaction<'life0, 'async_trait>( &'life0 self, hash: TransactionHash<Types>, ) -> Pin<Box<dyn Future<Output = Fetch<TransactionQueryData<Types>>> + Send + 'async_trait>>
where @@ -159,131 +159,133 @@ Types: NodeType,

source§

fn clone(&self) -> Self

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<Types, S, P> Debug for FetchingDataSource<Types, S, P>
where Types: NodeType, S: Debug, - P: Debug,

source§

fn fmt(&self, __f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<Types, S, P> ExplorerDataSource<Types> for FetchingDataSource<Types, S, P>
where + P: Debug,

source§

fn fmt(&self, __f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<Types, S, P> ExplorerDataSource<Types> for FetchingDataSource<Types, S, P>
where Types: NodeType, Payload<Types>: QueryablePayload<Types>, Header<Types>: QueryableHeader<Types> + ExplorerHeader<Types>, Transaction<Types>: ExplorerTransaction, S: VersionedDataSource + 'static, for<'a> S::ReadOnly<'a>: ExplorerStorage<Types>, - P: Send + Sync,

source§

fn get_block_summaries<'life0, 'async_trait>( + P: Send + Sync,

source§

fn get_block_summaries<'life0, 'async_trait>( &'life0 self, request: GetBlockSummariesRequest<Types>, ) -> Pin<Box<dyn Future<Output = Result<Vec<BlockSummary<Types>>, GetBlockSummariesError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

get_block_summaries is a method that retrieves a list of block summaries from the blockchain. The list is generated from the given -GetBlockSummariesRequest.
source§

fn get_block_detail<'life0, 'async_trait>( +GetBlockSummariesRequest.

source§

fn get_block_detail<'life0, 'async_trait>( &'life0 self, request: BlockIdentifier<Types>, ) -> Pin<Box<dyn Future<Output = Result<BlockDetail<Types>, GetBlockDetailError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

get_block_detail is a method that retrieves the details of a specific block from the blockchain. The block is identified by the given -BlockIdentifier.
source§

fn get_transaction_summaries<'life0, 'async_trait>( +BlockIdentifier.

source§

fn get_transaction_summaries<'life0, 'async_trait>( &'life0 self, request: GetTransactionSummariesRequest<Types>, ) -> Pin<Box<dyn Future<Output = Result<Vec<TransactionSummary<Types>>, GetTransactionSummariesError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

get_transaction_summaries is a method that retrieves a list of transaction summaries from the blockchain. The list is generated from -the given GetTransactionSummariesRequest.
source§

fn get_transaction_detail<'life0, 'async_trait>( +the given GetTransactionSummariesRequest.

source§

fn get_transaction_detail<'life0, 'async_trait>( &'life0 self, request: TransactionIdentifier<Types>, ) -> Pin<Box<dyn Future<Output = Result<TransactionDetailResponse<Types>, GetTransactionDetailError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

get_transaction_detail is a method that retrieves the details of a specific transaction from the blockchain. The transaction is identified -by the given TransactionIdentifier.
source§

fn get_explorer_summary<'life0, 'async_trait>( +by the given TransactionIdentifier.

source§

fn get_explorer_summary<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = Result<ExplorerSummary<Types>, GetExplorerSummaryError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

get_explorer_summary is a method that retrieves a summary overview of the blockchain. This is useful for displaying information that -indicates the overall status of the block chain.
source§

fn get_search_results<'life0, 'async_trait>( +indicates the overall status of the block chain.

source§

fn get_search_results<'life0, 'async_trait>( &'life0 self, query: String, ) -> Pin<Box<dyn Future<Output = Result<SearchResult<Types>, GetSearchResultsError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

get_search_results is a method that retrieves the results of a search query against the blockchain. The results are generated from the given -query string.
source§

impl<Types, S, P, State, const ARITY: usize> MerklizedStateDataSource<Types, State, ARITY> for FetchingDataSource<Types, S, P>
where +query string.

source§

impl<Types, S, P> HasMetrics for FetchingDataSource<Types, S, P>
where + Types: NodeType, + S: HasMetrics,

source§

impl<Types, S, P, State, const ARITY: usize> MerklizedStateDataSource<Types, State, ARITY> for FetchingDataSource<Types, S, P>
where Types: NodeType, S: VersionedDataSource + 'static, for<'a> S::ReadOnly<'a>: MerklizedStateStorage<Types, State, ARITY>, P: Send + Sync, State: MerklizedState<Types, ARITY> + 'static, - <State as MerkleTreeScheme>::Commitment: Send,

source§

fn get_path<'life0, 'async_trait>( + <State as MerkleTreeScheme>::Commitment: Send,

source§

fn get_path<'life0, 'async_trait>( &'life0 self, snapshot: Snapshot<Types, State, ARITY>, key: State::Key, ) -> Pin<Box<dyn Future<Output = QueryResult<MerkleProof<State::Entry, State::Key, State::T, ARITY>>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

impl<Types, S, P> MerklizedStateHeightPersistence for FetchingDataSource<Types, S, P>
where + 'life0: 'async_trait,

source§

impl<Types, S, P> MerklizedStateHeightPersistence for FetchingDataSource<Types, S, P>
where Types: NodeType, Payload<Types>: QueryablePayload<Types>, S: VersionedDataSource + 'static, for<'a> S::ReadOnly<'a>: MerklizedStateHeightStorage, - P: Send + Sync,

source§

fn get_last_state_height<'life0, 'async_trait>( + P: Send + Sync,

source§

fn get_last_state_height<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

impl<Types, S, P> NodeDataSource<Types> for FetchingDataSource<Types, S, P>
where + 'life0: 'async_trait,

source§

impl<Types, S, P> NodeDataSource<Types> for FetchingDataSource<Types, S, P>
where Types: NodeType, S: VersionedDataSource + 'static, for<'a> S::ReadOnly<'a>: NodeStorage<Types>, - P: Send + Sync,

source§

fn block_height<'life0, 'async_trait>( + P: Send + Sync,

source§

fn block_height<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn count_transactions<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn count_transactions<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn payload_size<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn payload_size<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn vid_share<'life0, 'async_trait, ID>( + 'life0: 'async_trait,

source§

fn vid_share<'life0, 'async_trait, ID>( &'life0 self, id: ID, ) -> Pin<Box<dyn Future<Output = QueryResult<VidShare>> + Send + 'async_trait>>
where ID: Into<BlockId<Types>> + Send + Sync + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn sync_status<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn sync_status<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<SyncStatus>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

Search the database for missing objects and generate a report.
source§

fn get_header_window<'life0, 'async_trait>( + 'life0: 'async_trait,

Search the database for missing objects and generate a report.
source§

fn get_header_window<'life0, 'async_trait>( &'life0 self, start: impl 'async_trait + Into<WindowStart<Types>> + Send + Sync, end: u64, ) -> Pin<Box<dyn Future<Output = QueryResult<TimeWindowQueryData<Header<Types>>>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

impl<Types, S, P> StatusDataSource for FetchingDataSource<Types, S, P>
where + 'life0: 'async_trait,

source§

impl<Types, S, P> StatusDataSource for FetchingDataSource<Types, S, P>
where Types: NodeType, - S: VersionedDataSource + Send + Sync + 'static, + S: VersionedDataSource + HasMetrics + Send + Sync + 'static, for<'a> S::ReadOnly<'a>: NodeStorage<Types>, - P: Send + Sync,

source§

fn block_height<'life0, 'async_trait>( + P: Send + Sync,

source§

fn block_height<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn metrics(&self) -> &PrometheusMetrics

source§

fn consensus_metrics(&self) -> QueryResult<PrometheusMetrics>

source§

fn elapsed_time_since_last_decide<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn consensus_metrics(&self) -> QueryResult<PrometheusMetrics>

source§

fn elapsed_time_since_last_decide<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<u64>> + Send + 'async_trait>>
where Self: Sync + 'async_trait, - 'life0: 'async_trait,

source§

fn success_rate<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn success_rate<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<f64>> + Send + 'async_trait>>
where Self: Sync + 'async_trait, - 'life0: 'async_trait,

source§

impl<Types, S, P> VersionedDataSource for FetchingDataSource<Types, S, P>
where + 'life0: 'async_trait,

source§

impl<Types, S, P> VersionedDataSource for FetchingDataSource<Types, S, P>
where Types: NodeType, S: VersionedDataSource + Send + Sync, - P: Send + Sync,

source§

type Transaction<'a> = Transaction<'a, Types, <S as VersionedDataSource>::Transaction<'a>> + P: Send + Sync,

source§

type Transaction<'a> = Transaction<'a, Types, <S as VersionedDataSource>::Transaction<'a>> where - Self: 'a

A transaction which can read and modify the data source.
source§

type ReadOnly<'a> = Transaction<'a, Types, <S as VersionedDataSource>::ReadOnly<'a>> + Self: 'a

A transaction which can read and modify the data source.
source§

type ReadOnly<'a> = Transaction<'a, Types, <S as VersionedDataSource>::ReadOnly<'a>> where - Self: 'a

source§

async fn write(&self) -> Result<Self::Transaction<'_>>

Start an atomic transaction on the data source.
source§

async fn read(&self) -> Result<Self::ReadOnly<'_>>

Start a read-only transaction on the data source. Read more

Auto Trait Implementations§

§

impl<Types, S, P> Freeze for FetchingDataSource<Types, S, P>

§

impl<Types, S, P> !RefUnwindSafe for FetchingDataSource<Types, S, P>

§

impl<Types, S, P> Send for FetchingDataSource<Types, S, P>
where + Self: 'a

source§

async fn write(&self) -> Result<Self::Transaction<'_>>

Start an atomic transaction on the data source.
source§

async fn read(&self) -> Result<Self::ReadOnly<'_>>

Start a read-only transaction on the data source. Read more

Auto Trait Implementations§

§

impl<Types, S, P> Freeze for FetchingDataSource<Types, S, P>

§

impl<Types, S, P> !RefUnwindSafe for FetchingDataSource<Types, S, P>

§

impl<Types, S, P> Send for FetchingDataSource<Types, S, P>
where S: Sync + Send, P: Sync + Send,

§

impl<Types, S, P> Sync for FetchingDataSource<Types, S, P>
where S: Sync + Send, @@ -418,8 +420,8 @@ T: Clone,

source§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
§

impl<T> TryConv for T

§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

source§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where - U: TryFrom<T>,

source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<T> UpdateStatusData for T
where - T: StatusDataSource,

source§

fn populate_metrics(&self) -> Box<dyn Metrics>

§

impl<V, T> VZip<V> for T
where + U: TryFrom<T>,

source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<T> UpdateStatusData for T
where + T: StatusDataSource,

source§

fn populate_metrics(&self) -> Box<dyn Metrics>

§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a diff --git a/hotshot_query_service/data_source/fetching/struct.Pruner.html b/hotshot_query_service/data_source/fetching/struct.Pruner.html index 4177c37ef..954d33412 100644 --- a/hotshot_query_service/data_source/fetching/struct.Pruner.html +++ b/hotshot_query_service/data_source/fetching/struct.Pruner.html @@ -1,9 +1,9 @@ -Pruner in hotshot_query_service::data_source::fetching - Rust

Struct hotshot_query_service::data_source::fetching::Pruner

source ·
pub struct Pruner<Types, S, P>
where - Types: NodeType,
{ /* private fields */ }

Trait Implementations§

source§

impl<Types, S, P> Clone for Pruner<Types, S, P>
where - Types: NodeType,

source§

fn clone(&self) -> Self

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<Types, S, P> Debug for Pruner<Types, S, P>
where +Pruner in hotshot_query_service::data_source::fetching - Rust

Struct hotshot_query_service::data_source::fetching::Pruner

source ·
pub struct Pruner<Types, S, P>
where + Types: NodeType,
{ /* private fields */ }

Trait Implementations§

source§

impl<Types, S, P> Clone for Pruner<Types, S, P>
where + Types: NodeType,

source§

fn clone(&self) -> Self

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<Types, S, P> Debug for Pruner<Types, S, P>
where Types: NodeType, S: Debug, - P: Debug,

source§

fn fmt(&self, __f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<Types, S, P> Freeze for Pruner<Types, S, P>

§

impl<Types, S, P> RefUnwindSafe for Pruner<Types, S, P>
where + P: Debug,

source§

fn fmt(&self, __f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<Types, S, P> Freeze for Pruner<Types, S, P>

§

impl<Types, S, P> RefUnwindSafe for Pruner<Types, S, P>

§

impl<Types, S, P> Send for Pruner<Types, S, P>
where diff --git a/hotshot_query_service/data_source/fetching/trait.AvailabilityProvider.html b/hotshot_query_service/data_source/fetching/trait.AvailabilityProvider.html index 13c11a1eb..aac6fe815 100644 --- a/hotshot_query_service/data_source/fetching/trait.AvailabilityProvider.html +++ b/hotshot_query_service/data_source/fetching/trait.AvailabilityProvider.html @@ -1,8 +1,8 @@ -AvailabilityProvider in hotshot_query_service::data_source::fetching - Rust
pub trait AvailabilityProvider<Types: NodeType>:
+AvailabilityProvider in hotshot_query_service::data_source::fetching - Rust
pub trait AvailabilityProvider<Types: NodeType>:
     Provider<Types, LeafRequest>
     + Provider<Types, PayloadRequest>
     + Provider<Types, VidCommonRequest>
     + Sync
     + 'static { }
Expand description

A provider which can be used as a fetcher by the availability service.

-

Implementors§

source§

impl<Types: NodeType, P> AvailabilityProvider<Types> for P
where +

Implementors§

source§

impl<Types: NodeType, P> AvailabilityProvider<Types> for P
where P: Provider<Types, LeafRequest> + Provider<Types, PayloadRequest> + Provider<Types, VidCommonRequest> + Sync + 'static,

\ No newline at end of file diff --git a/hotshot_query_service/data_source/sql/macro.include_migrations.html b/hotshot_query_service/data_source/sql/macro.include_migrations.html index 18ef9f10e..b64f9a77f 100644 --- a/hotshot_query_service/data_source/sql/macro.include_migrations.html +++ b/hotshot_query_service/data_source/sql/macro.include_migrations.html @@ -1,4 +1,4 @@ -include_migrations in hotshot_query_service::data_source::sql - Rust
macro_rules! include_migrations {
+include_migrations in hotshot_query_service::data_source::sql - Rust
macro_rules! include_migrations {
     ($dir:tt) => { ... };
 }
Expand description

Embed migrations from the given directory into the current binary.

The macro invocation include_migrations!(path) evaluates to an expression of type impl Iterator<Item = Migration>. Each migration must be a text file which is an immediate child of diff --git a/hotshot_query_service/data_source/storage/fs/index.html b/hotshot_query_service/data_source/storage/fs/index.html index a55583b92..a73631ad2 100644 --- a/hotshot_query_service/data_source/storage/fs/index.html +++ b/hotshot_query_service/data_source/storage/fs/index.html @@ -1 +1 @@ -hotshot_query_service::data_source::storage::fs - Rust

Module hotshot_query_service::data_source::storage::fs

source ·

Structs§

Traits§

\ No newline at end of file +hotshot_query_service::data_source::storage::fs - Rust

Module hotshot_query_service::data_source::storage::fs

source ·

Structs§

Traits§

\ No newline at end of file diff --git a/hotshot_query_service/data_source/storage/fs/struct.FileSystemStorage.html b/hotshot_query_service/data_source/storage/fs/struct.FileSystemStorage.html index 02fbaf9b4..df3bdd66c 100644 --- a/hotshot_query_service/data_source/storage/fs/struct.FileSystemStorage.html +++ b/hotshot_query_service/data_source/storage/fs/struct.FileSystemStorage.html @@ -1,14 +1,14 @@ -FileSystemStorage in hotshot_query_service::data_source::storage::fs - Rust
pub struct FileSystemStorage<Types: NodeType>
where +FileSystemStorage in hotshot_query_service::data_source::storage::fs - Rust
pub struct FileSystemStorage<Types: NodeType>
where Payload<Types>: QueryablePayload<Types>,
{ /* private fields */ }
Expand description

Storage for the APIs provided in this crate, backed by a remote PostgreSQL database.

-

Implementations§

source§

impl<Types: NodeType> FileSystemStorage<Types>
where +

Implementations§

source§

impl<Types: NodeType> FileSystemStorage<Types>
where Payload<Types>: QueryablePayload<Types>, - Header<Types>: QueryableHeader<Types>,

source

pub async fn create(path: &Path) -> Result<Self, PersistenceError>

Create a new FileSystemStorage with storage at path.

+ Header<Types>: QueryableHeader<Types>,
source

pub async fn create(path: &Path) -> Result<Self, PersistenceError>

Create a new FileSystemStorage with storage at path.

If there is already data at path, it will be archived.

The FileSystemStorage will manage its own persistence synchronization.

-
source

pub async fn open(path: &Path) -> Result<Self, PersistenceError>

Open an existing FileSystemStorage from storage at path.

+
source

pub async fn open(path: &Path) -> Result<Self, PersistenceError>

Open an existing FileSystemStorage from storage at path.

If there is no data at path, a new store will be created.

The FileSystemStorage will manage its own persistence synchronization.

-
source

pub async fn create_with_store( +

source

pub async fn create_with_store( loader: &mut AtomicStoreLoader, ) -> Result<Self, PersistenceError>

Create a new FileSystemStorage using a persistent storage loader.

If there is existing data corresponding to the FileSystemStorage data structures, it will @@ -16,7 +16,7 @@

The FileSystemStorage will register its persistent data structures with loader. The caller is responsible for creating an [AtomicStore] from loader and managing synchronization of the store.

-
source

pub async fn open_with_store( +

source

pub async fn open_with_store( loader: &mut AtomicStoreLoader, ) -> Result<Self, PersistenceError>

Open an existing FileSystemStorage using a persistent storage loader.

If there is no existing data corresponding to the FileSystemStorage data structures, a new @@ -24,10 +24,12 @@

The FileSystemStorage will register its persistent data structures with loader. The caller is responsible for creating an [AtomicStore] from loader and managing synchronization of the store.

-
source

pub async fn skip_version(&self) -> Result<(), PersistenceError>

Advance the version of the persistent store without committing changes to persistent state.

-

Trait Implementations§

source§

impl<Types: Debug + NodeType> Debug for FileSystemStorage<Types>
where - Payload<Types>: QueryablePayload<Types>,

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<Types: NodeType> PruneStorage for FileSystemStorage<Types>
where - Payload<Types>: QueryablePayload<Types>,

source§

type Pruner = ()

source§

fn get_disk_usage<'life0, 'async_trait>( +

source

pub async fn skip_version(&self) -> Result<(), PersistenceError>

Advance the version of the persistent store without committing changes to persistent state.

+

Trait Implementations§

source§

impl<Types: Debug + NodeType> Debug for FileSystemStorage<Types>
where + Payload<Types>: QueryablePayload<Types>,

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<Types> HasMetrics for FileSystemStorage<Types>
where + Types: NodeType, + Payload<Types>: QueryablePayload<Types>,

source§

impl<Types: NodeType> PruneStorage for FileSystemStorage<Types>
where + Payload<Types>: QueryablePayload<Types>,

source§

type Pruner = ()

source§

fn get_disk_usage<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = Result<u64>> + Send + 'async_trait>>
where Self: Sync + 'async_trait, @@ -37,25 +39,20 @@ ) -> Pin<Box<dyn Future<Output = Result<Option<u64>>> + Send + 'async_trait>>
where Self: Sync + 'async_trait, 'life0: 'async_trait, - 'life1: 'async_trait,

source§

impl<Types: NodeType> PrunerConfig for FileSystemStorage<Types>
where - Payload<Types>: QueryablePayload<Types>,

source§

impl<Types: NodeType> VersionedDataSource for FileSystemStorage<Types>
where - Payload<Types>: QueryablePayload<Types>,

source§

type Transaction<'a> = Transaction<RwLockWriteGuard<'a, FileSystemStorageInner<Types>>> + 'life1: 'async_trait,

source§

impl<Types: NodeType> PrunerConfig for FileSystemStorage<Types>
where + Payload<Types>: QueryablePayload<Types>,

source§

impl<Types: NodeType> VersionedDataSource for FileSystemStorage<Types>
where + Payload<Types>: QueryablePayload<Types>,

source§

type Transaction<'a> = Transaction<RwLockWriteGuard<'a, FileSystemStorageInner<Types>>> where - Self: 'a

A transaction which can read and modify the data source.
source§

type ReadOnly<'a> = Transaction<RwLockReadGuard<'a, FileSystemStorageInner<Types>>> + Self: 'a

A transaction which can read and modify the data source.
source§

type ReadOnly<'a> = Transaction<RwLockReadGuard<'a, FileSystemStorageInner<Types>>> where - Self: 'a

source§

async fn write(&self) -> Result<Self::Transaction<'_>>

Start an atomic transaction on the data source.
source§

async fn read(&self) -> Result<Self::ReadOnly<'_>>

Start a read-only transaction on the data source. Read more

Auto Trait Implementations§

§

impl<Types> !Freeze for FileSystemStorage<Types>

§

impl<Types> !RefUnwindSafe for FileSystemStorage<Types>

§

impl<Types> Send for FileSystemStorage<Types>
where + Self: 'a

source§

async fn write(&self) -> Result<Self::Transaction<'_>>

Start an atomic transaction on the data source.
source§

async fn read(&self) -> Result<Self::ReadOnly<'_>>

Start a read-only transaction on the data source. Read more

Auto Trait Implementations§

§

impl<Types> !Freeze for FileSystemStorage<Types>

§

impl<Types> !RefUnwindSafe for FileSystemStorage<Types>

§

impl<Types> Send for FileSystemStorage<Types>
where <Types as NodeType>::BlockPayload: for<'de> Sized,

§

impl<Types> Sync for FileSystemStorage<Types>
where <Types as NodeType>::BlockPayload: for<'de> Sized,

§

impl<Types> Unpin for FileSystemStorage<Types>
where <Types as NodeType>::BlockPayload: for<'de> Sized + Unpin, <Types as NodeType>::BlockHeader: Unpin, <Types as NodeType>::View: Unpin, <<Types as NodeType>::SignatureKey as SignatureKey>::QcType: Unpin, - Types: Unpin,

§

impl<Types> UnwindSafe for FileSystemStorage<Types>
where - <Types as NodeType>::BlockPayload: for<'de> Sized + UnwindSafe, - <Types as NodeType>::BlockHeader: UnwindSafe, - <Types as NodeType>::View: UnwindSafe, - <<Types as NodeType>::SignatureKey as SignatureKey>::QcType: UnwindSafe, - Types: UnwindSafe,

Blanket Implementations§

source§

impl<T> Any for T
where + Types: Unpin,

§

impl<Types> !UnwindSafe for FileSystemStorage<Types>

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> ArchivePointee for T

§

type ArchivedMetadata = ()

The archived version of the pointer metadata for this type.
§

fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata

Converts some archived metadata to the pointer metadata for itself.
§

impl<'a, T, E> AsTaggedExplicit<'a, E> for T
where diff --git a/hotshot_query_service/data_source/storage/fs/struct.FileSystemStorageInner.html b/hotshot_query_service/data_source/storage/fs/struct.FileSystemStorageInner.html index 7a43e9a84..ba8845802 100644 --- a/hotshot_query_service/data_source/storage/fs/struct.FileSystemStorageInner.html +++ b/hotshot_query_service/data_source/storage/fs/struct.FileSystemStorageInner.html @@ -1,6 +1,6 @@ -FileSystemStorageInner in hotshot_query_service::data_source::storage::fs - Rust
pub struct FileSystemStorageInner<Types>
where +FileSystemStorageInner in hotshot_query_service::data_source::storage::fs - Rust
pub struct FileSystemStorageInner<Types>
where Types: NodeType, - Payload<Types>: QueryablePayload<Types>,
{ /* private fields */ }

Trait Implementations§

source§

impl<Types> Debug for FileSystemStorageInner<Types>
where + Payload<Types>: QueryablePayload<Types>,
{ /* private fields */ }

Trait Implementations§

source§

impl<Types> Debug for FileSystemStorageInner<Types>
where Types: NodeType, Payload<Types>: QueryablePayload<Types>, HashMap<LeafHash<Types>, u64>: Debug, @@ -8,7 +8,7 @@ HashMap<TransactionHash<Types>, u64>: Debug, LedgerLog<LeafQueryData<Types>>: Debug, LedgerLog<BlockQueryData<Types>>: Debug, - LedgerLog<(VidCommonQueryData<Types>, Option<VidShare>)>: Debug,

source§

fn fmt(&self, fmt: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<Types> Freeze for FileSystemStorageInner<Types>
where + LedgerLog<(VidCommonQueryData<Types>, Option<VidShare>)>: Debug,

source§

fn fmt(&self, fmt: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more

Auto Trait Implementations§

§

impl<Types> Freeze for FileSystemStorageInner<Types>
where <Types as NodeType>::BlockPayload: for<'de> Sized,

§

impl<Types> RefUnwindSafe for FileSystemStorageInner<Types>
where <Types as NodeType>::BlockPayload: for<'de> Sized + RefUnwindSafe, <Types as NodeType>::BlockHeader: RefUnwindSafe, diff --git a/hotshot_query_service/data_source/storage/fs/struct.Transaction.html b/hotshot_query_service/data_source/storage/fs/struct.Transaction.html index e6c3f068f..51fc8cc03 100644 --- a/hotshot_query_service/data_source/storage/fs/struct.Transaction.html +++ b/hotshot_query_service/data_source/storage/fs/struct.Transaction.html @@ -1,116 +1,116 @@ -Transaction in hotshot_query_service::data_source::storage::fs - Rust
pub struct Transaction<T: Revert> { /* private fields */ }

Trait Implementations§

source§

impl<Types, T> AvailabilityStorage<Types> for Transaction<T>
where +Transaction in hotshot_query_service::data_source::storage::fs - Rust
pub struct Transaction<T: Revert> { /* private fields */ }

Trait Implementations§

source§

impl<Types, T> AvailabilityStorage<Types> for Transaction<T>
where Types: NodeType, Payload<Types>: QueryablePayload<Types>, Header<Types>: QueryableHeader<Types>, - T: Revert + Deref<Target = FileSystemStorageInner<Types>> + Send + Sync,

source§

fn get_leaf<'life0, 'async_trait>( + T: Revert + Deref<Target = FileSystemStorageInner<Types>> + Send + Sync,

source§

fn get_leaf<'life0, 'async_trait>( &'life0 mut self, id: LeafId<Types>, ) -> Pin<Box<dyn Future<Output = QueryResult<LeafQueryData<Types>>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_block<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn get_block<'life0, 'async_trait>( &'life0 mut self, id: BlockId<Types>, ) -> Pin<Box<dyn Future<Output = QueryResult<BlockQueryData<Types>>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_header<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn get_header<'life0, 'async_trait>( &'life0 mut self, id: BlockId<Types>, ) -> Pin<Box<dyn Future<Output = QueryResult<Header<Types>>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_payload<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn get_payload<'life0, 'async_trait>( &'life0 mut self, id: BlockId<Types>, ) -> Pin<Box<dyn Future<Output = QueryResult<PayloadQueryData<Types>>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_vid_common<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn get_vid_common<'life0, 'async_trait>( &'life0 mut self, id: BlockId<Types>, ) -> Pin<Box<dyn Future<Output = QueryResult<VidCommonQueryData<Types>>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_leaf_range<'life0, 'async_trait, R>( + 'life0: 'async_trait,

source§

fn get_leaf_range<'life0, 'async_trait, R>( &'life0 mut self, range: R, ) -> Pin<Box<dyn Future<Output = QueryResult<Vec<QueryResult<LeafQueryData<Types>>>>> + Send + 'async_trait>>
where R: RangeBounds<usize> + Send + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_block_range<'life0, 'async_trait, R>( + 'life0: 'async_trait,

source§

fn get_block_range<'life0, 'async_trait, R>( &'life0 mut self, range: R, ) -> Pin<Box<dyn Future<Output = QueryResult<Vec<QueryResult<BlockQueryData<Types>>>>> + Send + 'async_trait>>
where R: RangeBounds<usize> + Send + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_payload_range<'life0, 'async_trait, R>( + 'life0: 'async_trait,

source§

fn get_payload_range<'life0, 'async_trait, R>( &'life0 mut self, range: R, ) -> Pin<Box<dyn Future<Output = QueryResult<Vec<QueryResult<PayloadQueryData<Types>>>>> + Send + 'async_trait>>
where R: RangeBounds<usize> + Send + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_vid_common_range<'life0, 'async_trait, R>( + 'life0: 'async_trait,

source§

fn get_vid_common_range<'life0, 'async_trait, R>( &'life0 mut self, range: R, ) -> Pin<Box<dyn Future<Output = QueryResult<Vec<QueryResult<VidCommonQueryData<Types>>>>> + Send + 'async_trait>>
where R: RangeBounds<usize> + Send + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_transaction<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn get_transaction<'life0, 'async_trait>( &'life0 mut self, hash: TransactionHash<Types>, ) -> Pin<Box<dyn Future<Output = QueryResult<TransactionQueryData<Types>>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

impl<T: Debug + Revert> Debug for Transaction<T>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<T: Revert> Drop for Transaction<T>

source§

fn drop(&mut self)

Executes the destructor for this type. Read more
source§

impl<Types, T> NodeStorage<Types> for Transaction<T>
where + 'life0: 'async_trait,

source§

impl<T: Debug + Revert> Debug for Transaction<T>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<T: Revert> Drop for Transaction<T>

source§

fn drop(&mut self)

Executes the destructor for this type. Read more
source§

impl<Types, T> NodeStorage<Types> for Transaction<T>
where Types: NodeType, Payload<Types>: QueryablePayload<Types>, Header<Types>: QueryableHeader<Types>, - T: Revert + Deref<Target = FileSystemStorageInner<Types>> + Send,

source§

fn block_height<'life0, 'async_trait>( + T: Revert + Deref<Target = FileSystemStorageInner<Types>> + Send,

source§

fn block_height<'life0, 'async_trait>( &'life0 mut self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn count_transactions<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn count_transactions<'life0, 'async_trait>( &'life0 mut self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn payload_size<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn payload_size<'life0, 'async_trait>( &'life0 mut self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn vid_share<'life0, 'async_trait, ID>( + 'life0: 'async_trait,

source§

fn vid_share<'life0, 'async_trait, ID>( &'life0 mut self, id: ID, ) -> Pin<Box<dyn Future<Output = QueryResult<VidShare>> + Send + 'async_trait>>
where ID: Into<BlockId<Types>> + Send + Sync + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn sync_status<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn sync_status<'life0, 'async_trait>( &'life0 mut self, ) -> Pin<Box<dyn Future<Output = QueryResult<SyncStatus>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

Search the database for missing objects and generate a report.
source§

fn get_header_window<'life0, 'async_trait>( + 'life0: 'async_trait,

Search the database for missing objects and generate a report.
source§

fn get_header_window<'life0, 'async_trait>( &'life0 mut self, start: impl 'async_trait + Into<WindowStart<Types>> + Send + Sync, end: u64, ) -> Pin<Box<dyn Future<Output = QueryResult<TimeWindowQueryData<Header<Types>>>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

impl<'a, Types> Transaction for Transaction<RwLockReadGuard<'a, FileSystemStorageInner<Types>>>
where + 'life0: 'async_trait,

source§

impl<'a, Types> Transaction for Transaction<RwLockReadGuard<'a, FileSystemStorageInner<Types>>>
where Types: NodeType, - Payload<Types>: QueryablePayload<Types>,

source§

async fn commit(self) -> Result<()>

source§

fn revert(self) -> impl Future + Send

source§

impl<'a, Types> Transaction for Transaction<RwLockWriteGuard<'a, FileSystemStorageInner<Types>>>
where + Payload<Types>: QueryablePayload<Types>,

source§

async fn commit(self) -> Result<()>

source§

fn revert(self) -> impl Future + Send

source§

impl<'a, Types> Transaction for Transaction<RwLockWriteGuard<'a, FileSystemStorageInner<Types>>>
where Types: NodeType, - Payload<Types>: QueryablePayload<Types>,

source§

async fn commit(self) -> Result<()>

source§

fn revert(self) -> impl Future + Send

source§

impl<'a, Types: NodeType> UpdateAvailabilityData<Types> for Transaction<RwLockWriteGuard<'a, FileSystemStorageInner<Types>>>
where + Payload<Types>: QueryablePayload<Types>,

source§

async fn commit(self) -> Result<()>

source§

fn revert(self) -> impl Future + Send

source§

impl<'a, Types: NodeType> UpdateAvailabilityData<Types> for Transaction<RwLockWriteGuard<'a, FileSystemStorageInner<Types>>>
where Payload<Types>: QueryablePayload<Types>, - Header<Types>: QueryableHeader<Types>,

source§

fn insert_leaf<'life0, 'async_trait>( + Header<Types>: QueryableHeader<Types>,

source§

fn insert_leaf<'life0, 'async_trait>( &'life0 mut self, leaf: LeafQueryData<Types>, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn insert_block<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn insert_block<'life0, 'async_trait>( &'life0 mut self, block: BlockQueryData<Types>, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn insert_vid<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn insert_vid<'life0, 'async_trait>( &'life0 mut self, common: VidCommonQueryData<Types>, share: Option<VidShare>, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

impl<T: Revert> PrunedHeightStorage for Transaction<T>

Auto Trait Implementations§

§

impl<T> Freeze for Transaction<T>
where + 'life0: 'async_trait,

source§

impl<T: Revert> PrunedHeightStorage for Transaction<T>

Auto Trait Implementations§

§

impl<T> Freeze for Transaction<T>
where T: Freeze,

§

impl<T> RefUnwindSafe for Transaction<T>
where T: RefUnwindSafe,

§

impl<T> Send for Transaction<T>
where T: Send,

§

impl<T> Sync for Transaction<T>
where diff --git a/hotshot_query_service/data_source/storage/fs/trait.Revert.html b/hotshot_query_service/data_source/storage/fs/trait.Revert.html index c37cd1862..7233bff13 100644 --- a/hotshot_query_service/data_source/storage/fs/trait.Revert.html +++ b/hotshot_query_service/data_source/storage/fs/trait.Revert.html @@ -1,8 +1,8 @@ -Revert in hotshot_query_service::data_source::storage::fs - Rust

Trait hotshot_query_service::data_source::storage::fs::Revert

source ·
pub trait Revert {
+Revert in hotshot_query_service::data_source::storage::fs - Rust

Trait hotshot_query_service::data_source::storage::fs::Revert

source ·
pub trait Revert {
     // Required method
     fn revert(&mut self);
-}

Required Methods§

source

fn revert(&mut self)

Implementations on Foreign Types§

source§

impl<'a, Types> Revert for RwLockReadGuard<'a, FileSystemStorageInner<Types>>
where +}

Required Methods§

source

fn revert(&mut self)

Implementations on Foreign Types§

source§

impl<'a, Types> Revert for RwLockReadGuard<'a, FileSystemStorageInner<Types>>
where Types: NodeType, - Payload<Types>: QueryablePayload<Types>,

source§

fn revert(&mut self)

source§

impl<'a, Types> Revert for RwLockWriteGuard<'a, FileSystemStorageInner<Types>>
where + Payload<Types>: QueryablePayload<Types>,

source§

fn revert(&mut self)

source§

impl<'a, Types> Revert for RwLockWriteGuard<'a, FileSystemStorageInner<Types>>
where Types: NodeType, - Payload<Types>: QueryablePayload<Types>,

source§

fn revert(&mut self)

Implementors§

\ No newline at end of file + Payload<Types>: QueryablePayload<Types>,

source§

fn revert(&mut self)

Implementors§

\ No newline at end of file diff --git a/hotshot_query_service/data_source/storage/no_storage/index.html b/hotshot_query_service/data_source/storage/no_storage/index.html index b2627bc2d..7a74965b5 100644 --- a/hotshot_query_service/data_source/storage/no_storage/index.html +++ b/hotshot_query_service/data_source/storage/no_storage/index.html @@ -1 +1 @@ -hotshot_query_service::data_source::storage::no_storage - Rust

Modules§

Structs§

\ No newline at end of file +hotshot_query_service::data_source::storage::no_storage - Rust

Modules§

Structs§

\ No newline at end of file diff --git a/hotshot_query_service/data_source/storage/no_storage/struct.NoStorage.html b/hotshot_query_service/data_source/storage/no_storage/struct.NoStorage.html index e16127b81..3c0a37617 100644 --- a/hotshot_query_service/data_source/storage/no_storage/struct.NoStorage.html +++ b/hotshot_query_service/data_source/storage/no_storage/struct.NoStorage.html @@ -1,8 +1,8 @@ -NoStorage in hotshot_query_service::data_source::storage::no_storage - Rust
pub struct NoStorage { /* private fields */ }
Expand description

Mock storage implementation which doesn’t actually store anything.

+NoStorage in hotshot_query_service::data_source::storage::no_storage - Rust
pub struct NoStorage { /* private fields */ }
Expand description

Mock storage implementation which doesn’t actually store anything.

This is useful for adversarial testing, as it can be used to test the behavior of the query service where data is never available locally and must always be fetched on demand from a peer query service.

-

Trait Implementations§

source§

impl Clone for NoStorage

source§

fn clone(&self) -> NoStorage

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for NoStorage

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for NoStorage

source§

fn default() -> NoStorage

Returns the “default value” for a type. Read more
source§

impl PruneStorage for NoStorage

source§

type Pruner = ()

source§

fn get_disk_usage<'life0, 'async_trait>( +

Trait Implementations§

source§

impl Clone for NoStorage

source§

fn clone(&self) -> NoStorage

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for NoStorage

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for NoStorage

source§

fn default() -> NoStorage

Returns the “default value” for a type. Read more
source§

impl HasMetrics for NoStorage

source§

impl PruneStorage for NoStorage

source§

type Pruner = ()

source§

fn get_disk_usage<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = Result<u64>> + Send + 'async_trait>>
where Self: Sync + 'async_trait, @@ -12,11 +12,11 @@ ) -> Pin<Box<dyn Future<Output = Result<Option<u64>>> + Send + 'async_trait>>
where Self: Sync + 'async_trait, 'life0: 'async_trait, - 'life1: 'async_trait,

source§

impl PrunerConfig for NoStorage

source§

impl VersionedDataSource for NoStorage

source§

type Transaction<'a> = Transaction<'a> + 'life1: 'async_trait,

source§

impl PrunerConfig for NoStorage

source§

impl VersionedDataSource for NoStorage

source§

type Transaction<'a> = Transaction<'a> where - Self: 'a

A transaction which can read and modify the data source.
source§

type ReadOnly<'a> = Transaction<'a> + Self: 'a

A transaction which can read and modify the data source.
source§

type ReadOnly<'a> = Transaction<'a> where - Self: 'a

source§

async fn write(&self) -> Result<Self::Transaction<'_>>

Start an atomic transaction on the data source.
source§

async fn read(&self) -> Result<Self::ReadOnly<'_>>

Start a read-only transaction on the data source. Read more

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where + Self: 'a

source§

async fn write(&self) -> Result<Self::Transaction<'_>>

Start an atomic transaction on the data source.
source§

async fn read(&self) -> Result<Self::ReadOnly<'_>>

Start a read-only transaction on the data source. Read more

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> ArchivePointee for T

§

type ArchivedMetadata = ()

The archived version of the pointer metadata for this type.
§

fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata

Converts some archived metadata to the pointer metadata for itself.
§

impl<'a, T, E> AsTaggedExplicit<'a, E> for T
where diff --git a/hotshot_query_service/data_source/storage/no_storage/struct.Transaction.html b/hotshot_query_service/data_source/storage/no_storage/struct.Transaction.html index ec2edcbd4..1cc7e8543 100644 --- a/hotshot_query_service/data_source/storage/no_storage/struct.Transaction.html +++ b/hotshot_query_service/data_source/storage/no_storage/struct.Transaction.html @@ -1,103 +1,103 @@ -Transaction in hotshot_query_service::data_source::storage::no_storage - Rust
pub struct Transaction<'a> { /* private fields */ }

Trait Implementations§

source§

impl<'a, Types: NodeType> AvailabilityStorage<Types> for Transaction<'a>
where - Payload<Types>: QueryablePayload<Types>,

source§

fn get_leaf<'life0, 'async_trait>( +Transaction in hotshot_query_service::data_source::storage::no_storage - Rust
pub struct Transaction<'a> { /* private fields */ }

Trait Implementations§

source§

impl<'a, Types: NodeType> AvailabilityStorage<Types> for Transaction<'a>
where + Payload<Types>: QueryablePayload<Types>,

source§

fn get_leaf<'life0, 'async_trait>( &'life0 mut self, _id: LeafId<Types>, ) -> Pin<Box<dyn Future<Output = QueryResult<LeafQueryData<Types>>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_block<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn get_block<'life0, 'async_trait>( &'life0 mut self, _id: BlockId<Types>, ) -> Pin<Box<dyn Future<Output = QueryResult<BlockQueryData<Types>>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_header<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn get_header<'life0, 'async_trait>( &'life0 mut self, _id: BlockId<Types>, ) -> Pin<Box<dyn Future<Output = QueryResult<Header<Types>>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_payload<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn get_payload<'life0, 'async_trait>( &'life0 mut self, _id: BlockId<Types>, ) -> Pin<Box<dyn Future<Output = QueryResult<PayloadQueryData<Types>>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_vid_common<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn get_vid_common<'life0, 'async_trait>( &'life0 mut self, _id: BlockId<Types>, ) -> Pin<Box<dyn Future<Output = QueryResult<VidCommonQueryData<Types>>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_leaf_range<'life0, 'async_trait, R>( + 'life0: 'async_trait,

source§

fn get_leaf_range<'life0, 'async_trait, R>( &'life0 mut self, _range: R, ) -> Pin<Box<dyn Future<Output = QueryResult<Vec<QueryResult<LeafQueryData<Types>>>>> + Send + 'async_trait>>
where R: RangeBounds<usize> + Send + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_block_range<'life0, 'async_trait, R>( + 'life0: 'async_trait,

source§

fn get_block_range<'life0, 'async_trait, R>( &'life0 mut self, _range: R, ) -> Pin<Box<dyn Future<Output = QueryResult<Vec<QueryResult<BlockQueryData<Types>>>>> + Send + 'async_trait>>
where R: RangeBounds<usize> + Send + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_payload_range<'life0, 'async_trait, R>( + 'life0: 'async_trait,

source§

fn get_payload_range<'life0, 'async_trait, R>( &'life0 mut self, _range: R, ) -> Pin<Box<dyn Future<Output = QueryResult<Vec<QueryResult<PayloadQueryData<Types>>>>> + Send + 'async_trait>>
where R: RangeBounds<usize> + Send + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_vid_common_range<'life0, 'async_trait, R>( + 'life0: 'async_trait,

source§

fn get_vid_common_range<'life0, 'async_trait, R>( &'life0 mut self, _range: R, ) -> Pin<Box<dyn Future<Output = QueryResult<Vec<QueryResult<VidCommonQueryData<Types>>>>> + Send + 'async_trait>>
where R: RangeBounds<usize> + Send + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_transaction<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn get_transaction<'life0, 'async_trait>( &'life0 mut self, _hash: TransactionHash<Types>, ) -> Pin<Box<dyn Future<Output = QueryResult<TransactionQueryData<Types>>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

impl<'a, Types: NodeType> NodeStorage<Types> for Transaction<'a>
where - Payload<Types>: QueryablePayload<Types>,

source§

fn block_height<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

impl<'a, Types: NodeType> NodeStorage<Types> for Transaction<'a>
where + Payload<Types>: QueryablePayload<Types>,

source§

fn block_height<'life0, 'async_trait>( &'life0 mut self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn count_transactions<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn count_transactions<'life0, 'async_trait>( &'life0 mut self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn payload_size<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn payload_size<'life0, 'async_trait>( &'life0 mut self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn vid_share<'life0, 'async_trait, ID>( + 'life0: 'async_trait,

source§

fn vid_share<'life0, 'async_trait, ID>( &'life0 mut self, _id: ID, ) -> Pin<Box<dyn Future<Output = QueryResult<VidShare>> + Send + 'async_trait>>
where ID: Into<BlockId<Types>> + Send + Sync + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn sync_status<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn sync_status<'life0, 'async_trait>( &'life0 mut self, ) -> Pin<Box<dyn Future<Output = QueryResult<SyncStatus>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

Search the database for missing objects and generate a report.
source§

fn get_header_window<'life0, 'async_trait>( + 'life0: 'async_trait,

Search the database for missing objects and generate a report.
source§

fn get_header_window<'life0, 'async_trait>( &'life0 mut self, _start: impl 'async_trait + Into<WindowStart<Types>> + Send + Sync, _end: u64, ) -> Pin<Box<dyn Future<Output = QueryResult<TimeWindowQueryData<Header<Types>>>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

impl<'a> PrunedHeightStorage for Transaction<'a>

source§

fn load_pruned_height<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

impl<'a> PrunedHeightStorage for Transaction<'a>

source§

fn load_pruned_height<'life0, 'async_trait>( &'life0 mut self, ) -> Pin<Box<dyn Future<Output = Result<Option<u64>>> + Send + 'async_trait>>
where Self: Send + 'async_trait, - 'life0: 'async_trait,

source§

impl<'a> Transaction for Transaction<'a>

source§

async fn commit(self) -> Result<()>

source§

fn revert(self) -> impl Future + Send

source§

impl<'a, Types: NodeType> UpdateAvailabilityData<Types> for Transaction<'a>
where - Payload<Types>: QueryablePayload<Types>,

source§

fn insert_leaf<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

impl<'a> Transaction for Transaction<'a>

source§

async fn commit(self) -> Result<()>

source§

fn revert(self) -> impl Future + Send

source§

impl<'a, Types: NodeType> UpdateAvailabilityData<Types> for Transaction<'a>
where + Payload<Types>: QueryablePayload<Types>,

source§

fn insert_leaf<'life0, 'async_trait>( &'life0 mut self, leaf: LeafQueryData<Types>, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn insert_block<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn insert_block<'life0, 'async_trait>( &'life0 mut self, block: BlockQueryData<Types>, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn insert_vid<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn insert_vid<'life0, 'async_trait>( &'life0 mut self, common: VidCommonQueryData<Types>, _share: Option<VidShare>, diff --git a/hotshot_query_service/data_source/storage/no_storage/testing/enum.DataSource.html b/hotshot_query_service/data_source/storage/no_storage/testing/enum.DataSource.html index a9decb416..d923a7cd1 100644 --- a/hotshot_query_service/data_source/storage/no_storage/testing/enum.DataSource.html +++ b/hotshot_query_service/data_source/storage/no_storage/testing/enum.DataSource.html @@ -1,63 +1,63 @@ -DataSource in hotshot_query_service::data_source::storage::no_storage::testing - Rust
pub enum DataSource {
+DataSource in hotshot_query_service::data_source::storage::no_storage::testing - Rust

Variants§

Trait Implementations§

source§

impl AvailabilityDataSource<MockTypes> for DataSource

source§

type LeafRange<R> = Pin<Box<dyn Stream<Item = Fetch<LeafQueryData<MockTypes>>> + Send>> where - R: RangeBounds<usize> + Send

source§

type BlockRange<R> = Pin<Box<dyn Stream<Item = Fetch<BlockQueryData<MockTypes>>> + Send>> + R: RangeBounds<usize> + Send

source§

type BlockRange<R> = Pin<Box<dyn Stream<Item = Fetch<BlockQueryData<MockTypes>>> + Send>> where - R: RangeBounds<usize> + Send

source§

type PayloadRange<R> = Pin<Box<dyn Stream<Item = Fetch<PayloadQueryData<MockTypes>>> + Send>> + R: RangeBounds<usize> + Send

source§

type PayloadRange<R> = Pin<Box<dyn Stream<Item = Fetch<PayloadQueryData<MockTypes>>> + Send>> where - R: RangeBounds<usize> + Send

source§

type VidCommonRange<R> = Pin<Box<dyn Stream<Item = Fetch<VidCommonQueryData<MockTypes>>> + Send>> + R: RangeBounds<usize> + Send

source§

type VidCommonRange<R> = Pin<Box<dyn Stream<Item = Fetch<VidCommonQueryData<MockTypes>>> + Send>> where - R: RangeBounds<usize> + Send

source§

fn get_leaf<'life0, 'async_trait, ID>( + R: RangeBounds<usize> + Send

source§

fn get_leaf<'life0, 'async_trait, ID>( &'life0 self, id: ID, ) -> Pin<Box<dyn Future<Output = Fetch<LeafQueryData<MockTypes>>> + Send + 'async_trait>>
where ID: Into<LeafId<MockTypes>> + Send + Sync + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_block<'life0, 'async_trait, ID>( + 'life0: 'async_trait,

source§

fn get_block<'life0, 'async_trait, ID>( &'life0 self, id: ID, ) -> Pin<Box<dyn Future<Output = Fetch<BlockQueryData<MockTypes>>> + Send + 'async_trait>>
where ID: Into<BlockId<MockTypes>> + Send + Sync + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_payload<'life0, 'async_trait, ID>( + 'life0: 'async_trait,

source§

fn get_payload<'life0, 'async_trait, ID>( &'life0 self, id: ID, ) -> Pin<Box<dyn Future<Output = Fetch<PayloadQueryData<MockTypes>>> + Send + 'async_trait>>
where ID: Into<BlockId<MockTypes>> + Send + Sync + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_vid_common<'life0, 'async_trait, ID>( + 'life0: 'async_trait,

source§

fn get_vid_common<'life0, 'async_trait, ID>( &'life0 self, id: ID, ) -> Pin<Box<dyn Future<Output = Fetch<VidCommonQueryData<MockTypes>>> + Send + 'async_trait>>
where ID: Into<BlockId<MockTypes>> + Send + Sync + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_leaf_range<'life0, 'async_trait, R>( + 'life0: 'async_trait,

source§

fn get_leaf_range<'life0, 'async_trait, R>( &'life0 self, range: R, ) -> Pin<Box<dyn Future<Output = Self::LeafRange<R>> + Send + 'async_trait>>
where R: RangeBounds<usize> + Send + 'static + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_block_range<'life0, 'async_trait, R>( + 'life0: 'async_trait,

source§

fn get_block_range<'life0, 'async_trait, R>( &'life0 self, range: R, ) -> Pin<Box<dyn Future<Output = Self::BlockRange<R>> + Send + 'async_trait>>
where R: RangeBounds<usize> + Send + 'static + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_payload_range<'life0, 'async_trait, R>( + 'life0: 'async_trait,

source§

fn get_payload_range<'life0, 'async_trait, R>( &'life0 self, range: R, ) -> Pin<Box<dyn Future<Output = Self::PayloadRange<R>> + Send + 'async_trait>>
where R: RangeBounds<usize> + Send + 'static + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_vid_common_range<'life0, 'async_trait, R>( + 'life0: 'async_trait,

source§

fn get_vid_common_range<'life0, 'async_trait, R>( &'life0 self, range: R, ) -> Pin<Box<dyn Future<Output = Self::VidCommonRange<R>> + Send + 'async_trait>>
where R: RangeBounds<usize> + Send + 'static + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn get_transaction<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn get_transaction<'life0, 'async_trait>( &'life0 self, hash: TransactionHash<MockTypes>, ) -> Pin<Box<dyn Future<Output = Fetch<TransactionQueryData<MockTypes>>> + Send + 'async_trait>>
where @@ -82,72 +82,72 @@ from: usize, ) -> Pin<Box<dyn Future<Output = BoxStream<'static, VidCommonQueryData<Types>>> + Send + 'async_trait>>
where Self: Sync + 'async_trait, - 'life0: 'async_trait,

source§

impl Clone for DataSource

source§

fn clone(&self) -> DataSource

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl DataSourceLifeCycle for DataSource

source§

type Storage = Storage

Backing storage for the data source. Read more
source§

fn create<'async_trait>( + 'life0: 'async_trait,

source§

impl Clone for DataSource

source§

fn clone(&self) -> DataSource

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl DataSourceLifeCycle for DataSource

source§

type Storage = Storage

Backing storage for the data source. Read more
source§

fn create<'async_trait>( node_id: usize, ) -> Pin<Box<dyn Future<Output = Self::Storage> + Send + 'async_trait>>
where - Self: 'async_trait,

source§

fn connect<'life0, 'async_trait>( + Self: 'async_trait,

source§

fn connect<'life0, 'async_trait>( db: &'life0 Self::Storage, ) -> Pin<Box<dyn Future<Output = Self> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn reset<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn reset<'life0, 'async_trait>( db: &'life0 Self::Storage, ) -> Pin<Box<dyn Future<Output = Self> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn setup<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn setup<'life0, 'async_trait>( network: &'life0 mut MockNetwork<Self>, ) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

Setup runs after setting up the network but before starting a test.
source§

fn handle_event<'life0, 'life1, 'async_trait>( + 'life0: 'async_trait,

Setup runs after setting up the network but before starting a test.
source§

fn handle_event<'life0, 'life1, 'async_trait>( &'life0 self, event: &'life1 Event<MockTypes>, ) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait, - 'life1: 'async_trait,

source§

impl Debug for DataSource

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl NodeDataSource<MockTypes> for DataSource

source§

fn block_height<'life0, 'async_trait>( + 'life1: 'async_trait,

source§

impl Debug for DataSource

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl HasMetrics for DataSource

source§

impl NodeDataSource<MockTypes> for DataSource

source§

fn block_height<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn count_transactions<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn count_transactions<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn payload_size<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn payload_size<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn vid_share<'life0, 'async_trait, ID>( + 'life0: 'async_trait,

source§

fn vid_share<'life0, 'async_trait, ID>( &'life0 self, id: ID, ) -> Pin<Box<dyn Future<Output = QueryResult<VidShare>> + Send + 'async_trait>>
where ID: Into<BlockId<MockTypes>> + Send + Sync + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn sync_status<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn sync_status<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<SyncStatus>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

Search the database for missing objects and generate a report.
source§

fn get_header_window<'life0, 'async_trait>( + 'life0: 'async_trait,

Search the database for missing objects and generate a report.
source§

fn get_header_window<'life0, 'async_trait>( &'life0 self, start: impl 'async_trait + Into<WindowStart<MockTypes>> + Send + Sync, end: u64, ) -> Pin<Box<dyn Future<Output = QueryResult<TimeWindowQueryData<Header<MockTypes>>>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

impl StatusDataSource for DataSource

source§

fn block_height<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

impl StatusDataSource for DataSource

source§

fn block_height<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn metrics(&self) -> &PrometheusMetrics

source§

fn consensus_metrics(&self) -> QueryResult<PrometheusMetrics>

source§

fn elapsed_time_since_last_decide<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn consensus_metrics(&self) -> QueryResult<PrometheusMetrics>

source§

fn elapsed_time_since_last_decide<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<u64>> + Send + 'async_trait>>
where Self: Sync + 'async_trait, - 'life0: 'async_trait,

source§

fn success_rate<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn success_rate<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<f64>> + Send + 'async_trait>>
where Self: Sync + 'async_trait, - 'life0: 'async_trait,

source§

impl VersionedDataSource for DataSource

source§

type Transaction<'a> = Transaction<'a, <SqlStorage as VersionedDataSource>::Transaction<'a>> + 'life0: 'async_trait,

source§

impl VersionedDataSource for DataSource

source§

type Transaction<'a> = Transaction<'a, <SqlStorage as VersionedDataSource>::Transaction<'a>> where - Self: 'a

A transaction which can read and modify the data source.
source§

type ReadOnly<'a> = Transaction<'a, <SqlStorage as VersionedDataSource>::ReadOnly<'a>> + Self: 'a

A transaction which can read and modify the data source.
source§

type ReadOnly<'a> = Transaction<'a, <SqlStorage as VersionedDataSource>::ReadOnly<'a>> where - Self: 'a

source§

async fn read(&self) -> Result<Self::ReadOnly<'_>>

Start a read-only transaction on the data source. Read more
source§

async fn write(&self) -> Result<Self::Transaction<'_>>

Start an atomic transaction on the data source.

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where + Self: 'a

source§

async fn read(&self) -> Result<Self::ReadOnly<'_>>

Start a read-only transaction on the data source. Read more
source§

async fn write(&self) -> Result<Self::Transaction<'_>>

Start an atomic transaction on the data source.

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> ArchivePointee for T

§

type ArchivedMetadata = ()

The archived version of the pointer metadata for this type.
§

fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata

Converts some archived metadata to the pointer metadata for itself.
§

impl<'a, T, E> AsTaggedExplicit<'a, E> for T
where @@ -275,8 +275,8 @@ T: Clone,

source§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
§

impl<T> TryConv for T

§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

source§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where - U: TryFrom<T>,

source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<T> UpdateStatusData for T
where - T: StatusDataSource,

source§

fn populate_metrics(&self) -> Box<dyn Metrics>

§

impl<V, T> VZip<V> for T
where + U: TryFrom<T>,

source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<T> UpdateStatusData for T
where + T: StatusDataSource,

source§

fn populate_metrics(&self) -> Box<dyn Metrics>

§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a diff --git a/hotshot_query_service/data_source/storage/no_storage/testing/enum.Storage.html b/hotshot_query_service/data_source/storage/no_storage/testing/enum.Storage.html index 869f2a669..01d76222d 100644 --- a/hotshot_query_service/data_source/storage/no_storage/testing/enum.Storage.html +++ b/hotshot_query_service/data_source/storage/no_storage/testing/enum.Storage.html @@ -1,4 +1,4 @@ -Storage in hotshot_query_service::data_source::storage::no_storage::testing - Rust
pub enum Storage {
+Storage in hotshot_query_service::data_source::storage::no_storage::testing - Rust
pub enum Storage {
     Sql(TmpDb),
     NoStorage {
         fetch_from_port: u16,
diff --git a/hotshot_query_service/data_source/storage/no_storage/testing/enum.Transaction.html b/hotshot_query_service/data_source/storage/no_storage/testing/enum.Transaction.html
index 5df1e83a9..79d1b5820 100644
--- a/hotshot_query_service/data_source/storage/no_storage/testing/enum.Transaction.html
+++ b/hotshot_query_service/data_source/storage/no_storage/testing/enum.Transaction.html
@@ -1,48 +1,48 @@
-Transaction in hotshot_query_service::data_source::storage::no_storage::testing - Rust
pub enum Transaction<'a, T> {
+Transaction in hotshot_query_service::data_source::storage::no_storage::testing - Rust
pub enum Transaction<'a, T> {
     Sql(Transaction<'a, MockTypes, T>),
     NoStorage(Transaction<'a, MockTypes, Transaction<'a>>),
-}

Variants§

§

Sql(Transaction<'a, MockTypes, T>)

§

NoStorage(Transaction<'a, MockTypes, Transaction<'a>>)

Trait Implementations§

source§

impl<'a, T> NodeStorage<MockTypes> for Transaction<'a, T>
where - T: NodeStorage<MockTypes> + Send,

source§

fn block_height<'life0, 'async_trait>( +}

Variants§

§

Sql(Transaction<'a, MockTypes, T>)

§

NoStorage(Transaction<'a, MockTypes, Transaction<'a>>)

Trait Implementations§

source§

impl<'a, T> NodeStorage<MockTypes> for Transaction<'a, T>
where + T: NodeStorage<MockTypes> + Send,

source§

fn block_height<'life0, 'async_trait>( &'life0 mut self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn count_transactions<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn count_transactions<'life0, 'async_trait>( &'life0 mut self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn payload_size<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn payload_size<'life0, 'async_trait>( &'life0 mut self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn vid_share<'life0, 'async_trait, ID>( + 'life0: 'async_trait,

source§

fn vid_share<'life0, 'async_trait, ID>( &'life0 mut self, id: ID, ) -> Pin<Box<dyn Future<Output = QueryResult<VidShare>> + Send + 'async_trait>>
where ID: Into<BlockId<MockTypes>> + Send + Sync + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

source§

fn sync_status<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn sync_status<'life0, 'async_trait>( &'life0 mut self, ) -> Pin<Box<dyn Future<Output = QueryResult<SyncStatus>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

Search the database for missing objects and generate a report.
source§

fn get_header_window<'life0, 'async_trait>( + 'life0: 'async_trait,

Search the database for missing objects and generate a report.
source§

fn get_header_window<'life0, 'async_trait>( &'life0 mut self, start: impl 'async_trait + Into<WindowStart<MockTypes>> + Send + Sync, end: u64, ) -> Pin<Box<dyn Future<Output = QueryResult<TimeWindowQueryData<Header<MockTypes>>>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

impl<'a, T> Transaction for Transaction<'a, T>
where - T: Transaction,

source§

async fn commit(self) -> Result<()>

source§

fn revert(self) -> impl Future + Send

source§

impl<'a, T> UpdateAvailabilityData<MockTypes> for Transaction<'a, T>

source§

fn insert_leaf<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

impl<'a, T> Transaction for Transaction<'a, T>
where + T: Transaction,

source§

async fn commit(self) -> Result<()>

source§

fn revert(self) -> impl Future + Send

source§

impl<'a, T> UpdateAvailabilityData<MockTypes> for Transaction<'a, T>

source§

fn insert_leaf<'life0, 'async_trait>( &'life0 mut self, leaf: LeafQueryData<MockTypes>, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn insert_block<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn insert_block<'life0, 'async_trait>( &'life0 mut self, block: BlockQueryData<MockTypes>, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn insert_vid<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn insert_vid<'life0, 'async_trait>( &'life0 mut self, common: VidCommonQueryData<MockTypes>, share: Option<VidShare>, diff --git a/hotshot_query_service/data_source/storage/no_storage/testing/index.html b/hotshot_query_service/data_source/storage/no_storage/testing/index.html index fd1d4c4bc..83cb5c5b7 100644 --- a/hotshot_query_service/data_source/storage/no_storage/testing/index.html +++ b/hotshot_query_service/data_source/storage/no_storage/testing/index.html @@ -1 +1 @@ -hotshot_query_service::data_source::storage::no_storage::testing - Rust

Enums§

\ No newline at end of file +hotshot_query_service::data_source::storage::no_storage::testing - Rust

Enums§

\ No newline at end of file diff --git a/hotshot_query_service/data_source/storage/pruning/trait.PruneStorage.html b/hotshot_query_service/data_source/storage/pruning/trait.PruneStorage.html index 91184ea3e..15680cc6e 100644 --- a/hotshot_query_service/data_source/storage/pruning/trait.PruneStorage.html +++ b/hotshot_query_service/data_source/storage/pruning/trait.PruneStorage.html @@ -24,5 +24,5 @@ ) -> Pin<Box<dyn Future<Output = Result<Option<u64>>> + Send + 'async_trait>>
where Self: Sync + 'async_trait, 'life0: 'async_trait, - 'life1: 'async_trait,

Implementors§

\ No newline at end of file + 'life1: 'async_trait,

Implementors§

\ No newline at end of file diff --git a/hotshot_query_service/data_source/storage/pruning/trait.PrunedHeightStorage.html b/hotshot_query_service/data_source/storage/pruning/trait.PrunedHeightStorage.html index 2ff9c08dc..2a00f6342 100644 --- a/hotshot_query_service/data_source/storage/pruning/trait.PrunedHeightStorage.html +++ b/hotshot_query_service/data_source/storage/pruning/trait.PrunedHeightStorage.html @@ -9,6 +9,6 @@ &'life0 mut self, ) -> Pin<Box<dyn Future<Output = Result<Option<u64>>> + Send + 'async_trait>>
where Self: Send + 'async_trait, - 'life0: 'async_trait,

Object Safety§

This trait is not object safe.

Implementors§

source§

impl<'a> PrunedHeightStorage for hotshot_query_service::data_source::storage::no_storage::Transaction<'a>

source§

impl<'a, Types, T> PrunedHeightStorage for hotshot_query_service::data_source::fetching::Transaction<'a, Types, T>
where + 'life0: 'async_trait,

Object Safety§

This trait is not object safe.

Implementors§

source§

impl<'a> PrunedHeightStorage for hotshot_query_service::data_source::storage::no_storage::Transaction<'a>

source§

impl<'a, Types, T> PrunedHeightStorage for hotshot_query_service::data_source::fetching::Transaction<'a, Types, T>
where Types: NodeType, - T: PrunedHeightStorage + Send,

source§

impl<Mode: TransactionMode> PrunedHeightStorage for hotshot_query_service::data_source::storage::sql::Transaction<Mode>

source§

impl<T: Revert> PrunedHeightStorage for hotshot_query_service::data_source::storage::fs::Transaction<T>

\ No newline at end of file + T: PrunedHeightStorage + Send,
source§

impl<Mode: TransactionMode> PrunedHeightStorage for hotshot_query_service::data_source::storage::sql::Transaction<Mode>

source§

impl<T: Revert> PrunedHeightStorage for hotshot_query_service::data_source::storage::fs::Transaction<T>

\ No newline at end of file diff --git a/hotshot_query_service/data_source/storage/pruning/trait.PrunerConfig.html b/hotshot_query_service/data_source/storage/pruning/trait.PrunerConfig.html index 7d6b238f5..f88690ea0 100644 --- a/hotshot_query_service/data_source/storage/pruning/trait.PrunerConfig.html +++ b/hotshot_query_service/data_source/storage/pruning/trait.PrunerConfig.html @@ -2,5 +2,5 @@ // Provided methods fn set_pruning_config(&mut self, _cfg: PrunerCfg) { ... } fn get_pruning_config(&self) -> Option<PrunerCfg> { ... } -}

Provided Methods§

Implementors§

source§

impl PrunerConfig for NoStorage

source§

impl PrunerConfig for SqlStorage

source§

impl<Types: NodeType> PrunerConfig for FileSystemStorage<Types>
where +}

Provided Methods§

Implementors§

\ No newline at end of file diff --git a/hotshot_query_service/data_source/storage/sql/fn.default_migrations.html b/hotshot_query_service/data_source/storage/sql/fn.default_migrations.html index 02ef2b34a..6b8548db2 100644 --- a/hotshot_query_service/data_source/storage/sql/fn.default_migrations.html +++ b/hotshot_query_service/data_source/storage/sql/fn.default_migrations.html @@ -1,2 +1,2 @@ -default_migrations in hotshot_query_service::data_source::storage::sql - Rust
pub fn default_migrations() -> Vec<Migration>
Expand description

The migrations requied to build the default schema for this version of SqlStorage.

+default_migrations in hotshot_query_service::data_source::storage::sql - Rust
pub fn default_migrations() -> Vec<Migration>
Expand description

The migrations requied to build the default schema for this version of SqlStorage.

\ No newline at end of file diff --git a/hotshot_query_service/data_source/storage/sql/fn.query.html b/hotshot_query_service/data_source/storage/sql/fn.query.html index 9a51e2a29..676a85d04 100644 --- a/hotshot_query_service/data_source/storage/sql/fn.query.html +++ b/hotshot_query_service/data_source/storage/sql/fn.query.html @@ -1 +1 @@ -query in hotshot_query_service::data_source::storage::sql - Rust

Function hotshot_query_service::data_source::storage::sql::query

source ·
pub fn query(sql: &str) -> Query<'_>
\ No newline at end of file +query in hotshot_query_service::data_source::storage::sql - Rust

Function hotshot_query_service::data_source::storage::sql::query

source ·
pub fn query(sql: &str) -> Query<'_>
\ No newline at end of file diff --git a/hotshot_query_service/data_source/storage/sql/fn.query_as.html b/hotshot_query_service/data_source/storage/sql/fn.query_as.html index 022adf27e..d49e49da3 100644 --- a/hotshot_query_service/data_source/storage/sql/fn.query_as.html +++ b/hotshot_query_service/data_source/storage/sql/fn.query_as.html @@ -1,2 +1,2 @@ -query_as in hotshot_query_service::data_source::storage::sql - Rust

Function hotshot_query_service::data_source::storage::sql::query_as

source ·
pub fn query_as<'q, T>(sql: &'q str) -> QueryAs<'q, T>
where +query_as in hotshot_query_service::data_source::storage::sql - Rust

Function hotshot_query_service::data_source::storage::sql::query_as

source ·
pub fn query_as<'q, T>(sql: &'q str) -> QueryAs<'q, T>
where T: for<'r> FromRow<'r, <Db as Database>::Row>,
\ No newline at end of file diff --git a/hotshot_query_service/data_source/storage/sql/index.html b/hotshot_query_service/data_source/storage/sql/index.html index f087c79d1..ee7ae8be6 100644 --- a/hotshot_query_service/data_source/storage/sql/index.html +++ b/hotshot_query_service/data_source/storage/sql/index.html @@ -1,4 +1,4 @@ -hotshot_query_service::data_source::storage::sql - Rust

Module hotshot_query_service::data_source::storage::sql

source ·

Re-exports§

  • pub extern crate sqlx;

Modules§

Macros§

Structs§

source§

impl Config<Postgres>

source

pub fn host(self, host: impl Into<String>) -> Self

Set the hostname of the database server.

+
source§

impl Config<Postgres>

source

pub fn host(self, host: impl Into<String>) -> Self

Set the hostname of the database server.

The default is localhost.

-
source

pub fn port(self, port: u16) -> Self

Set the port on which to connect to the database.

+
source

pub fn port(self, port: u16) -> Self

Set the port on which to connect to the database.

The default is 5432, the default Postgres port.

-
source

pub fn user(self, user: &str) -> Self

Set the DB user to connect as.

-
source

pub fn password(self, password: &str) -> Self

Set a password for connecting to the database.

-
source

pub fn database(self, database: &str) -> Self

Set the name of the database to connect to.

-
source

pub fn tls(self) -> Self

Use TLS for an encrypted connection to the database.

+
source

pub fn user(self, user: &str) -> Self

Set the DB user to connect as.

+
source

pub fn password(self, password: &str) -> Self

Set a password for connecting to the database.

+
source

pub fn database(self, database: &str) -> Self

Set the name of the database to connect to.

+
source

pub fn tls(self) -> Self

Use TLS for an encrypted connection to the database.

Note that an encrypted connection may be established even if this option is not set, as long as both the client and server support it. This option merely causes connection to fail if an encrypted stream cannot be established.

-
source§

impl<DB: Database> Config<DB>

source

pub fn schema(self, schema: impl Into<String>) -> Self

Set the name of the schema to use for queries.

+
source§

impl<DB: Database> Config<DB>

source

pub fn schema(self, schema: impl Into<String>) -> Self

Set the name of the schema to use for queries.

The default schema is named hotshot and is created via the default migrations.

-
source

pub fn reset_schema(self) -> Self

Reset the schema on connection.

+
source

pub fn reset_schema(self) -> Self

Reset the schema on connection.

When this Config is used to connect a SqlDataSource, if this option is set, the relevant schema will first be dropped and then recreated, yielding a completely @@ -36,36 +36,36 @@

This is a particularly useful capability for development and staging environments. Still, it must be used with extreme caution, as using this will irrevocably delete any data pertaining to the query service in the database.

-
source

pub fn migrations(self, migrations: impl IntoIterator<Item = Migration>) -> Self

Add custom migrations to run when connecting to the database.

-
source

pub fn no_migrations(self) -> Self

Skip all migrations when connecting to the database.

-
source

pub fn pruner_cfg(self, cfg: PrunerCfg) -> Result<Self, Error>

Enable pruning with a given configuration.

+
source

pub fn migrations(self, migrations: impl IntoIterator<Item = Migration>) -> Self

Add custom migrations to run when connecting to the database.

+
source

pub fn no_migrations(self) -> Self

Skip all migrations when connecting to the database.

+
source

pub fn pruner_cfg(self, cfg: PrunerCfg) -> Result<Self, Error>

Enable pruning with a given configuration.

If archive was previously specified, this will override it.

-
source

pub fn archive(self) -> Self

Disable pruning and reconstruct previously pruned data.

+
source

pub fn archive(self) -> Self

Disable pruning and reconstruct previously pruned data.

While running without pruning is the default behavior, the default will not try to reconstruct data that was pruned in a previous run where pruning was enabled. This option instructs the service to run without pruning and reconstruct all previously pruned data by fetching from peers.

If pruner_cfg was previously specified, this will override it.

-
source

pub fn idle_connection_timeout(self, timeout: Duration) -> Self

Set the maximum idle time of a connection.

+
source

pub fn idle_connection_timeout(self, timeout: Duration) -> Self

Set the maximum idle time of a connection.

Any connection which has been open and unused longer than this duration will be automatically closed to reduce load on the server.

-
source

pub fn connection_timeout(self, timeout: Duration) -> Self

Set the maximum lifetime of a connection.

+
source

pub fn connection_timeout(self, timeout: Duration) -> Self

Set the maximum lifetime of a connection.

Any connection which has been open longer than this duration will be automatically closed (and, if needed, replaced), even if it is otherwise healthy. It is good practice to refresh even healthy connections once in a while (e.g. daily) in case of resource leaks in the server implementation.

-
source

pub fn min_connections(self, min: u32) -> Self

Set the minimum number of connections to maintain at any time.

+
source

pub fn min_connections(self, min: u32) -> Self

Set the minimum number of connections to maintain at any time.

The data source will, to the best of its ability, maintain at least min open connections at all times. This can be used to reduce the latency hit of opening new connections when at least this many simultaneous connections are frequently needed.

-
source

pub fn max_connections(self, max: u32) -> Self

Set the maximum number of connections to maintain at any time.

+
source

pub fn max_connections(self, max: u32) -> Self

Set the maximum number of connections to maintain at any time.

Once max connections are in use simultaneously, further attempts to acquire a connection (or begin a transaction) will block until one of the existing connections is released.

-

Trait Implementations§

source§

impl<DB> Clone for Config<DB>
where +

Trait Implementations§

source§

impl<DB> Clone for Config<DB>
where DB: Database + Clone, - DB::Connection: Clone,

source§

fn clone(&self) -> Config<DB>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<DB> Debug for Config<DB>
where + DB::Connection: Clone,

source§

fn clone(&self) -> Config<DB>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<DB> Debug for Config<DB>
where DB: Database + Debug, - DB::Connection: Debug,

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for Config<Postgres>

source§

fn default() -> Self

Returns the “default value” for a type. Read more
source§

impl From<PgConnectOptions> for Config<Postgres>

source§

fn from(db_opt: PgConnectOptions) -> Self

Converts to this type from the input type.
source§

impl FromStr for Config<Postgres>

source§

type Err = <PgConnectOptions as FromStr>::Err

The associated error which can be returned from parsing.
source§

fn from_str(s: &str) -> Result<Self, Self::Err>

Parses a string s to return a value of this type. Read more

Auto Trait Implementations§

§

impl<DB> Freeze for Config<DB>
where + DB::Connection: Debug,

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for Config<Postgres>

source§

fn default() -> Self

Returns the “default value” for a type. Read more
source§

impl From<PgConnectOptions> for Config<Postgres>

source§

fn from(db_opt: PgConnectOptions) -> Self

Converts to this type from the input type.
source§

impl FromStr for Config<Postgres>

source§

type Err = <PgConnectOptions as FromStr>::Err

The associated error which can be returned from parsing.
source§

fn from_str(s: &str) -> Result<Self, Self::Err>

Parses a string s to return a value of this type. Read more

Auto Trait Implementations§

§

impl<DB> Freeze for Config<DB>
where <<DB as Database>::Connection as Connection>::Options: Freeze,

§

impl<DB> !RefUnwindSafe for Config<DB>

§

impl<DB> Send for Config<DB>

§

impl<DB> Sync for Config<DB>

§

impl<DB> Unpin for Config<DB>
where <<DB as Database>::Connection as Connection>::Options: Unpin,

§

impl<DB> !UnwindSafe for Config<DB>

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> ArchivePointee for T

§

type ArchivedMetadata = ()

The archived version of the pointer metadata for this type.
§

fn pointer_metadata( diff --git a/hotshot_query_service/data_source/storage/sql/struct.Pruner.html b/hotshot_query_service/data_source/storage/sql/struct.Pruner.html index d943a26fe..c3efb32a4 100644 --- a/hotshot_query_service/data_source/storage/sql/struct.Pruner.html +++ b/hotshot_query_service/data_source/storage/sql/struct.Pruner.html @@ -1,4 +1,4 @@ -Pruner in hotshot_query_service::data_source::storage::sql - Rust

Struct hotshot_query_service::data_source::storage::sql::Pruner

source ·
pub struct Pruner { /* private fields */ }

Trait Implementations§

source§

impl Debug for Pruner

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for Pruner

source§

fn default() -> Pruner

Returns the “default value” for a type. Read more

Auto Trait Implementations§

§

impl Freeze for Pruner

§

impl RefUnwindSafe for Pruner

§

impl Send for Pruner

§

impl Sync for Pruner

§

impl Unpin for Pruner

§

impl UnwindSafe for Pruner

Blanket Implementations§

source§

impl<T> Any for T
where +Pruner in hotshot_query_service::data_source::storage::sql - Rust

Struct hotshot_query_service::data_source::storage::sql::Pruner

source ·
pub struct Pruner { /* private fields */ }

Trait Implementations§

source§

impl Debug for Pruner

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for Pruner

source§

fn default() -> Pruner

Returns the “default value” for a type. Read more

Auto Trait Implementations§

§

impl Freeze for Pruner

§

impl RefUnwindSafe for Pruner

§

impl Send for Pruner

§

impl Sync for Pruner

§

impl Unpin for Pruner

§

impl UnwindSafe for Pruner

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> ArchivePointee for T

§

type ArchivedMetadata = ()

The archived version of the pointer metadata for this type.
§

fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata

Converts some archived metadata to the pointer metadata for itself.
§

impl<'a, T, E> AsTaggedExplicit<'a, E> for T
where diff --git a/hotshot_query_service/data_source/storage/sql/struct.Read.html b/hotshot_query_service/data_source/storage/sql/struct.Read.html index 9d08d2d06..54238d909 100644 --- a/hotshot_query_service/data_source/storage/sql/struct.Read.html +++ b/hotshot_query_service/data_source/storage/sql/struct.Read.html @@ -1,5 +1,5 @@ -Read in hotshot_query_service::data_source::storage::sql - Rust

Struct hotshot_query_service::data_source::storage::sql::Read

source ·
pub struct Read;
Expand description

Marker type indicating a transaction with read-only access to the database.

-

Trait Implementations§

source§

impl Clone for Read

source§

fn clone(&self) -> Read

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for Read

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for Read

source§

fn default() -> Read

Returns the “default value” for a type. Read more
source§

impl TransactionMode for Read

source§

async fn begin(conn: &mut <Db as Database>::Connection) -> Result<()>

source§

impl Copy for Read

Auto Trait Implementations§

§

impl Freeze for Read

§

impl RefUnwindSafe for Read

§

impl Send for Read

§

impl Sync for Read

§

impl Unpin for Read

§

impl UnwindSafe for Read

Blanket Implementations§

source§

impl<T> Any for T
where +Read in hotshot_query_service::data_source::storage::sql - Rust

Struct hotshot_query_service::data_source::storage::sql::Read

source ·
pub struct Read;
Expand description

Marker type indicating a transaction with read-only access to the database.

+

Trait Implementations§

source§

impl Clone for Read

source§

fn clone(&self) -> Read

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for Read

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for Read

source§

fn default() -> Read

Returns the “default value” for a type. Read more
source§

impl TransactionMode for Read

source§

async fn begin(conn: &mut <Db as Database>::Connection) -> Result<()>

source§

fn display() -> &'static str

source§

impl Copy for Read

Auto Trait Implementations§

§

impl Freeze for Read

§

impl RefUnwindSafe for Read

§

impl Send for Read

§

impl Sync for Read

§

impl Unpin for Read

§

impl UnwindSafe for Read

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> ArchivePointee for T

§

type ArchivedMetadata = ()

The archived version of the pointer metadata for this type.
§

fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata

Converts some archived metadata to the pointer metadata for itself.
§

impl<'a, T, E> AsTaggedExplicit<'a, E> for T
where diff --git a/hotshot_query_service/data_source/storage/sql/struct.SqlStorage.html b/hotshot_query_service/data_source/storage/sql/struct.SqlStorage.html index 9aa116b94..39cb7a9b8 100644 --- a/hotshot_query_service/data_source/storage/sql/struct.SqlStorage.html +++ b/hotshot_query_service/data_source/storage/sql/struct.SqlStorage.html @@ -1,6 +1,6 @@ -SqlStorage in hotshot_query_service::data_source::storage::sql - Rust
pub struct SqlStorage { /* private fields */ }
Expand description

Storage for the APIs provided in this crate, backed by a remote PostgreSQL database.

-

Implementations§

source§

impl SqlStorage

source

pub async fn connect<DB: Database>(config: Config<DB>) -> Result<Self, Error>

Connect to a remote database.

-

Trait Implementations§

source§

impl Debug for SqlStorage

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl PruneStorage for SqlStorage

source§

fn prune<'life0, 'life1, 'async_trait>( +SqlStorage in hotshot_query_service::data_source::storage::sql - Rust
pub struct SqlStorage { /* private fields */ }
Expand description

Storage for the APIs provided in this crate, backed by a remote PostgreSQL database.

+

Implementations§

source§

impl SqlStorage

source

pub async fn connect<DB: Database>(config: Config<DB>) -> Result<Self, Error>

Connect to a remote database.

+

Trait Implementations§

source§

impl Debug for SqlStorage

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl HasMetrics for SqlStorage

source§

impl PruneStorage for SqlStorage

source§

fn prune<'life0, 'life1, 'async_trait>( &'life0 self, pruner: &'life1 mut Pruner, ) -> Pin<Box<dyn Future<Output = Result<Option<u64>>> + Send + 'async_trait>>
where @@ -10,15 +10,15 @@ This is because a vacuum operation may be necessary to reclaim more space. PostgreSQL already performs auto vacuuming, so we are not including it here as running a vacuum operation can be resource-intensive.

-

source§

type Pruner = Pruner

source§

fn get_disk_usage<'life0, 'async_trait>( +

source§

type Pruner = Pruner

source§

fn get_disk_usage<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = Result<u64>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

impl PrunerConfig for SqlStorage

source§

impl VersionedDataSource for SqlStorage

source§

type Transaction<'a> = Transaction<Write> + 'life0: 'async_trait,

source§

impl PrunerConfig for SqlStorage

source§

impl VersionedDataSource for SqlStorage

source§

type Transaction<'a> = Transaction<Write> where - Self: 'a

A transaction which can read and modify the data source.
source§

type ReadOnly<'a> = Transaction<Read> + Self: 'a

A transaction which can read and modify the data source.
source§

type ReadOnly<'a> = Transaction<Read> where - Self: 'a

source§

async fn write(&self) -> Result<Transaction<Write>>

Start an atomic transaction on the data source.
source§

async fn read(&self) -> Result<Transaction<Read>>

Start a read-only transaction on the data source. Read more

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where + Self: 'a

source§

async fn write(&self) -> Result<Transaction<Write>>

Start an atomic transaction on the data source.
source§

async fn read(&self) -> Result<Transaction<Read>>

Start a read-only transaction on the data source. Read more

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> ArchivePointee for T

§

type ArchivedMetadata = ()

The archived version of the pointer metadata for this type.
§

fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata

Converts some archived metadata to the pointer metadata for itself.
§

impl<'a, T, E> AsTaggedExplicit<'a, E> for T
where diff --git a/hotshot_query_service/data_source/storage/sql/struct.Transaction.html b/hotshot_query_service/data_source/storage/sql/struct.Transaction.html index 0edb6c52c..52a2311e0 100644 --- a/hotshot_query_service/data_source/storage/sql/struct.Transaction.html +++ b/hotshot_query_service/data_source/storage/sql/struct.Transaction.html @@ -1,4 +1,4 @@ -Transaction in hotshot_query_service::data_source::storage::sql - Rust
pub struct Transaction<Mode> { /* private fields */ }
Expand description

An atomic SQL transaction.

+Transaction in hotshot_query_service::data_source::storage::sql - Rust
pub struct Transaction<Mode> { /* private fields */ }
Expand description

An atomic SQL transaction.

Implementations§

source§

impl<Mode> Transaction<Mode>

source

pub async fn load_header<Types: NodeType>( &mut self, id: impl Into<BlockId<Types>> + Send, @@ -12,27 +12,27 @@

This more ergonomic interface is useful as loading headers is important for many SQL storage functions, not just the AvailabilityStorage interface.

-

source§

impl Transaction<Write>

Low-level, general database queries and mutation.

-
source

pub async fn execute_one<'q, E>(&mut self, statement: E) -> Result<()>
where +

source§

impl Transaction<Write>

Low-level, general database queries and mutation.

+
source

pub async fn execute_one<'q, E>(&mut self, statement: E) -> Result<()>
where E: 'q + Execute<'q, Db>,

Execute a statement that is expected to modify exactly one row.

Returns an error if the database is not modified.

-
source

pub async fn execute_one_with_retries<'q>( +

source

pub async fn execute_one_with_retries<'q>( &mut self, statement: &'q str, params: impl Params<'q> + Clone, ) -> Result<()>

Execute a statement that is expected to modify exactly one row.

Returns an error if the database is not modified. Retries several times before failing.

-
source

pub async fn execute_many<'q, E>(&mut self, statement: E) -> Result<u64>
where +

source

pub async fn execute_many<'q, E>(&mut self, statement: E) -> Result<u64>
where E: 'q + Execute<'q, Db>,

Execute a statement that is expected to modify at least one row.

Returns an error if the database is not modified.

-
source

pub async fn execute_many_with_retries<'q, 'p>( +

source

pub async fn execute_many_with_retries<'q, 'p>( &mut self, statement: &'q str, params: impl Params<'p> + Clone, ) -> Result<u64>
where 'p: 'q,

Execute a statement that is expected to modify at least one row.

Returns an error if the database is not modified. Retries several times before failing.

-
source

pub async fn upsert<'p, const N: usize, R>( +

source

pub async fn upsert<'p, const N: usize, R>( &mut self, table: &str, columns: [&str; N], @@ -98,7 +98,7 @@ hash: TransactionHash<Types>, ) -> Pin<Box<dyn Future<Output = QueryResult<TransactionQueryData<Types>>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

impl<Mode: Debug> Debug for Transaction<Mode>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<Mode> Deref for Transaction<Mode>

source§

type Target = Transaction<'static, Postgres>

The resulting type after dereferencing.
source§

fn deref(&self) -> &Self::Target

Dereferences the value.
source§

impl<Mode> DerefMut for Transaction<Mode>

source§

fn deref_mut(&mut self) -> &mut Self::Target

Mutably dereferences the value.
source§

impl<Mode, Types> ExplorerStorage<Types> for Transaction<Mode>
where + 'life0: 'async_trait,

source§

impl<Mode: Debug> Debug for Transaction<Mode>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<Mode> Deref for Transaction<Mode>

source§

type Target = Transaction<'static, Postgres>

The resulting type after dereferencing.
source§

fn deref(&self) -> &Self::Target

Dereferences the value.
source§

impl<Mode> DerefMut for Transaction<Mode>

source§

fn deref_mut(&mut self) -> &mut Self::Target

Mutably dereferences the value.
source§

impl<Mode, Types> ExplorerStorage<Types> for Transaction<Mode>
where Mode: TransactionMode, Types: NodeType, Payload<Types>: QueryablePayload<Types>, @@ -189,35 +189,35 @@ end: u64, ) -> Pin<Box<dyn Future<Output = QueryResult<TimeWindowQueryData<Header<Types>>>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

impl<Mode: TransactionMode> PrunedHeightStorage for Transaction<Mode>

source§

fn load_pruned_height<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

impl<Mode: TransactionMode> PrunedHeightStorage for Transaction<Mode>

source§

fn load_pruned_height<'life0, 'async_trait>( &'life0 mut self, ) -> Pin<Box<dyn Future<Output = Result<Option<u64>>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

impl<Mode: TransactionMode> Transaction for Transaction<Mode>

source§

async fn commit(self) -> Result<()>

source§

fn revert(self) -> impl Future + Send

source§

impl<Types> UpdateAvailabilityData<Types> for Transaction<Write>
where + 'life0: 'async_trait,

source§

impl<Mode: TransactionMode> Transaction for Transaction<Mode>

source§

async fn commit(self) -> Result<()>

source§

fn revert(self) -> impl Future + Send

source§

impl<Types> UpdateAvailabilityData<Types> for Transaction<Write>
where Types: NodeType, Payload<Types>: QueryablePayload<Types>, - Header<Types>: QueryableHeader<Types>,

source§

fn insert_leaf<'life0, 'async_trait>( + Header<Types>: QueryableHeader<Types>,

source§

fn insert_leaf<'life0, 'async_trait>( &'life0 mut self, leaf: LeafQueryData<Types>, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn insert_block<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn insert_block<'life0, 'async_trait>( &'life0 mut self, block: BlockQueryData<Types>, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn insert_vid<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn insert_vid<'life0, 'async_trait>( &'life0 mut self, common: VidCommonQueryData<Types>, share: Option<VidShare>, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

impl<Types: NodeType, State: MerklizedState<Types, ARITY>, const ARITY: usize> UpdateStateData<Types, State, ARITY> for Transaction<Write>

source§

fn set_last_state_height<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

impl<Types: NodeType, State: MerklizedState<Types, ARITY>, const ARITY: usize> UpdateStateData<Types, State, ARITY> for Transaction<Write>

source§

fn set_last_state_height<'life0, 'async_trait>( &'life0 mut self, height: usize, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn insert_merkle_nodes<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn insert_merkle_nodes<'life0, 'async_trait>( &'life0 mut self, proof: MerkleProof<State::Entry, State::Key, State::T, ARITY>, traversal_path: Vec<usize>, diff --git a/hotshot_query_service/data_source/storage/sql/struct.Write.html b/hotshot_query_service/data_source/storage/sql/struct.Write.html index 13239e638..01768b104 100644 --- a/hotshot_query_service/data_source/storage/sql/struct.Write.html +++ b/hotshot_query_service/data_source/storage/sql/struct.Write.html @@ -1,5 +1,5 @@ -Write in hotshot_query_service::data_source::storage::sql - Rust

Struct hotshot_query_service::data_source::storage::sql::Write

source ·
pub struct Write;
Expand description

Marker type indicating a transaction with read-write access to the database.

-

Trait Implementations§

source§

impl Clone for Write

source§

fn clone(&self) -> Write

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for Write

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for Write

source§

fn default() -> Write

Returns the “default value” for a type. Read more
source§

impl TransactionMode for Write

source§

async fn begin(conn: &mut <Db as Database>::Connection) -> Result<()>

source§

impl Copy for Write

Auto Trait Implementations§

§

impl Freeze for Write

§

impl RefUnwindSafe for Write

§

impl Send for Write

§

impl Sync for Write

§

impl Unpin for Write

§

impl UnwindSafe for Write

Blanket Implementations§

source§

impl<T> Any for T
where +Write in hotshot_query_service::data_source::storage::sql - Rust

Struct hotshot_query_service::data_source::storage::sql::Write

source ·
pub struct Write;
Expand description

Marker type indicating a transaction with read-write access to the database.

+

Trait Implementations§

source§

impl Clone for Write

source§

fn clone(&self) -> Write

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for Write

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for Write

source§

fn default() -> Write

Returns the “default value” for a type. Read more
source§

impl TransactionMode for Write

source§

async fn begin(conn: &mut <Db as Database>::Connection) -> Result<()>

source§

fn display() -> &'static str

source§

impl Copy for Write

Auto Trait Implementations§

§

impl Freeze for Write

§

impl RefUnwindSafe for Write

§

impl Send for Write

§

impl Sync for Write

§

impl Unpin for Write

§

impl UnwindSafe for Write

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> ArchivePointee for T

§

type ArchivedMetadata = ()

The archived version of the pointer metadata for this type.
§

fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata

Converts some archived metadata to the pointer metadata for itself.
§

impl<'a, T, E> AsTaggedExplicit<'a, E> for T
where diff --git a/hotshot_query_service/data_source/storage/sql/testing/index.html b/hotshot_query_service/data_source/storage/sql/testing/index.html index 581a5eb85..b7d90b01e 100644 --- a/hotshot_query_service/data_source/storage/sql/testing/index.html +++ b/hotshot_query_service/data_source/storage/sql/testing/index.html @@ -1 +1 @@ -hotshot_query_service::data_source::storage::sql::testing - Rust
\ No newline at end of file +hotshot_query_service::data_source::storage::sql::testing - Rust
\ No newline at end of file diff --git a/hotshot_query_service/data_source/storage/sql/testing/struct.TestMerkleTreeMigration.html b/hotshot_query_service/data_source/storage/sql/testing/struct.TestMerkleTreeMigration.html index 9997c1eea..cd944d612 100644 --- a/hotshot_query_service/data_source/storage/sql/testing/struct.TestMerkleTreeMigration.html +++ b/hotshot_query_service/data_source/storage/sql/testing/struct.TestMerkleTreeMigration.html @@ -1,4 +1,4 @@ -TestMerkleTreeMigration in hotshot_query_service::data_source::storage::sql::testing - Rust
pub struct TestMerkleTreeMigration;

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where +TestMerkleTreeMigration in hotshot_query_service::data_source::storage::sql::testing - Rust
pub struct TestMerkleTreeMigration;

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> ArchivePointee for T

§

type ArchivedMetadata = ()

The archived version of the pointer metadata for this type.
§

fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata

Converts some archived metadata to the pointer metadata for itself.
§

impl<'a, T, E> AsTaggedExplicit<'a, E> for T
where diff --git a/hotshot_query_service/data_source/storage/sql/testing/struct.TmpDb.html b/hotshot_query_service/data_source/storage/sql/testing/struct.TmpDb.html index a4ccf0fba..e48f0d5a8 100644 --- a/hotshot_query_service/data_source/storage/sql/testing/struct.TmpDb.html +++ b/hotshot_query_service/data_source/storage/sql/testing/struct.TmpDb.html @@ -1,4 +1,4 @@ -TmpDb in hotshot_query_service::data_source::storage::sql::testing - Rust

Struct hotshot_query_service::data_source::storage::sql::testing::TmpDb

source ·
pub struct TmpDb { /* private fields */ }

Implementations§

source§

impl TmpDb

source

pub async fn init() -> Self

source

pub async fn persistent() -> Self

source

pub fn host(&self) -> String

source

pub fn port(&self) -> u16

source

pub fn config(&self) -> Config<Postgres>

source

pub fn stop(&mut self)

source

pub async fn start(&mut self)

Trait Implementations§

source§

impl Debug for TmpDb

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Drop for TmpDb

source§

fn drop(&mut self)

Executes the destructor for this type. Read more

Auto Trait Implementations§

§

impl Freeze for TmpDb

§

impl RefUnwindSafe for TmpDb

§

impl Send for TmpDb

§

impl Sync for TmpDb

§

impl Unpin for TmpDb

§

impl UnwindSafe for TmpDb

Blanket Implementations§

source§

impl<T> Any for T
where +TmpDb in hotshot_query_service::data_source::storage::sql::testing - Rust

Struct hotshot_query_service::data_source::storage::sql::testing::TmpDb

source ·
pub struct TmpDb { /* private fields */ }

Implementations§

source§

impl TmpDb

source

pub async fn init() -> Self

source

pub async fn persistent() -> Self

source

pub fn host(&self) -> String

source

pub fn port(&self) -> u16

source

pub fn config(&self) -> Config<Postgres>

source

pub fn stop(&mut self)

source

pub async fn start(&mut self)

Trait Implementations§

source§

impl Debug for TmpDb

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Drop for TmpDb

source§

fn drop(&mut self)

Executes the destructor for this type. Read more

Auto Trait Implementations§

§

impl Freeze for TmpDb

§

impl RefUnwindSafe for TmpDb

§

impl Send for TmpDb

§

impl Sync for TmpDb

§

impl Unpin for TmpDb

§

impl UnwindSafe for TmpDb

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> ArchivePointee for T

§

type ArchivedMetadata = ()

The archived version of the pointer metadata for this type.
§

fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata

Converts some archived metadata to the pointer metadata for itself.
§

impl<'a, T, E> AsTaggedExplicit<'a, E> for T
where diff --git a/hotshot_query_service/data_source/storage/sql/trait.FixedLengthParams.html b/hotshot_query_service/data_source/storage/sql/trait.FixedLengthParams.html index f49b199d3..ba266d815 100644 --- a/hotshot_query_service/data_source/storage/sql/trait.FixedLengthParams.html +++ b/hotshot_query_service/data_source/storage/sql/trait.FixedLengthParams.html @@ -1,35 +1,35 @@ -FixedLengthParams in hotshot_query_service::data_source::storage::sql - Rust
pub trait FixedLengthParams<'p, const N: usize>: Params<'p> { }
Expand description

A collection of parameters with a statically known length.

+FixedLengthParams in hotshot_query_service::data_source::storage::sql - Rust
pub trait FixedLengthParams<'p, const N: usize>: Params<'p> { }
Expand description

A collection of parameters with a statically known length.

This is a simple trick for enforcing at compile time that a list of parameters has a certain length, such as matching the length of a list of column names. This can prevent easy mistakes like leaving out a parameter. It is implemented for tuples up to length 8.

-

Implementations on Foreign Types§

source§

impl<'p, T1, T2> FixedLengthParams<'p, 2> for (T1, T2)
where +

Implementations on Foreign Types§

source§

impl<'p, T1, T2> FixedLengthParams<'p, 2> for (T1, T2)
where T1: 'p + for<'q> Encode<'q, Db> + Type<Db>, - T2: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

impl<'p, T1, T2, T3> FixedLengthParams<'p, 3> for (T1, T2, T3)
where + T2: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

impl<'p, T1, T2, T3> FixedLengthParams<'p, 3> for (T1, T2, T3)
where T1: 'p + for<'q> Encode<'q, Db> + Type<Db>, T2: 'p + for<'q> Encode<'q, Db> + Type<Db>, - T3: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

impl<'p, T1, T2, T3, T4> FixedLengthParams<'p, 4> for (T1, T2, T3, T4)
where + T3: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

impl<'p, T1, T2, T3, T4> FixedLengthParams<'p, 4> for (T1, T2, T3, T4)
where T1: 'p + for<'q> Encode<'q, Db> + Type<Db>, T2: 'p + for<'q> Encode<'q, Db> + Type<Db>, T3: 'p + for<'q> Encode<'q, Db> + Type<Db>, - T4: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

impl<'p, T1, T2, T3, T4, T5> FixedLengthParams<'p, 5> for (T1, T2, T3, T4, T5)
where + T4: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

impl<'p, T1, T2, T3, T4, T5> FixedLengthParams<'p, 5> for (T1, T2, T3, T4, T5)
where T1: 'p + for<'q> Encode<'q, Db> + Type<Db>, T2: 'p + for<'q> Encode<'q, Db> + Type<Db>, T3: 'p + for<'q> Encode<'q, Db> + Type<Db>, T4: 'p + for<'q> Encode<'q, Db> + Type<Db>, - T5: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

impl<'p, T1, T2, T3, T4, T5, T6> FixedLengthParams<'p, 6> for (T1, T2, T3, T4, T5, T6)
where + T5: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

impl<'p, T1, T2, T3, T4, T5, T6> FixedLengthParams<'p, 6> for (T1, T2, T3, T4, T5, T6)
where T1: 'p + for<'q> Encode<'q, Db> + Type<Db>, T2: 'p + for<'q> Encode<'q, Db> + Type<Db>, T3: 'p + for<'q> Encode<'q, Db> + Type<Db>, T4: 'p + for<'q> Encode<'q, Db> + Type<Db>, T5: 'p + for<'q> Encode<'q, Db> + Type<Db>, - T6: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

impl<'p, T1, T2, T3, T4, T5, T6, T7> FixedLengthParams<'p, 7> for (T1, T2, T3, T4, T5, T6, T7)
where + T6: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

impl<'p, T1, T2, T3, T4, T5, T6, T7> FixedLengthParams<'p, 7> for (T1, T2, T3, T4, T5, T6, T7)
where T1: 'p + for<'q> Encode<'q, Db> + Type<Db>, T2: 'p + for<'q> Encode<'q, Db> + Type<Db>, T3: 'p + for<'q> Encode<'q, Db> + Type<Db>, T4: 'p + for<'q> Encode<'q, Db> + Type<Db>, T5: 'p + for<'q> Encode<'q, Db> + Type<Db>, T6: 'p + for<'q> Encode<'q, Db> + Type<Db>, - T7: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

impl<'p, T1, T2, T3, T4, T5, T6, T7, T8> FixedLengthParams<'p, 8> for (T1, T2, T3, T4, T5, T6, T7, T8)
where + T7: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

impl<'p, T1, T2, T3, T4, T5, T6, T7, T8> FixedLengthParams<'p, 8> for (T1, T2, T3, T4, T5, T6, T7, T8)
where T1: 'p + for<'q> Encode<'q, Db> + Type<Db>, T2: 'p + for<'q> Encode<'q, Db> + Type<Db>, T3: 'p + for<'q> Encode<'q, Db> + Type<Db>, @@ -37,5 +37,5 @@ T5: 'p + for<'q> Encode<'q, Db> + Type<Db>, T6: 'p + for<'q> Encode<'q, Db> + Type<Db>, T7: 'p + for<'q> Encode<'q, Db> + Type<Db>, - T8: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

impl<'p, T> FixedLengthParams<'p, 1> for (T,)
where + T8: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

impl<'p, T> FixedLengthParams<'p, 1> for (T,)
where T: 'p + for<'q> Encode<'q, Db> + Type<Db>,

Implementors§

\ No newline at end of file diff --git a/hotshot_query_service/data_source/storage/sql/trait.Params.html b/hotshot_query_service/data_source/storage/sql/trait.Params.html index f8ec18cea..3ff2c7dd6 100644 --- a/hotshot_query_service/data_source/storage/sql/trait.Params.html +++ b/hotshot_query_service/data_source/storage/sql/trait.Params.html @@ -1,4 +1,4 @@ -Params in hotshot_query_service::data_source::storage::sql - Rust

Trait hotshot_query_service::data_source::storage::sql::Params

source ·
pub trait Params<'p> {
+Params in hotshot_query_service::data_source::storage::sql - Rust

Trait hotshot_query_service::data_source::storage::sql::Params

source ·
pub trait Params<'p> {
     // Required method
     fn bind<'q>(self, q: Query<'q>) -> Query<'q>
        where 'p: 'q;
@@ -26,41 +26,41 @@ 

§Lifetimes

of the query we’re binding to ('q) may be different than the lifetime of the parameters ('p) as long as the parameters outlive the duration of the query (the 'p: 'q) bound on the bind function.

-

Required Methods§

source

fn bind<'q>(self, q: Query<'q>) -> Query<'q>
where - 'p: 'q,

Implementations on Foreign Types§

source§

impl<'p, T1, T2> Params<'p> for (T1, T2)
where +

Required Methods§

source

fn bind<'q>(self, q: Query<'q>) -> Query<'q>
where + 'p: 'q,

Implementations on Foreign Types§

source§

impl<'p, T1, T2> Params<'p> for (T1, T2)
where T1: 'p + for<'q> Encode<'q, Db> + Type<Db>, - T2: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

fn bind<'q>(self, q: Query<'q>) -> Query<'q>
where - 'p: 'q,

source§

impl<'p, T1, T2, T3> Params<'p> for (T1, T2, T3)
where + T2: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

fn bind<'q>(self, q: Query<'q>) -> Query<'q>
where + 'p: 'q,

source§

impl<'p, T1, T2, T3> Params<'p> for (T1, T2, T3)
where T1: 'p + for<'q> Encode<'q, Db> + Type<Db>, T2: 'p + for<'q> Encode<'q, Db> + Type<Db>, - T3: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

fn bind<'q>(self, q: Query<'q>) -> Query<'q>
where - 'p: 'q,

source§

impl<'p, T1, T2, T3, T4> Params<'p> for (T1, T2, T3, T4)
where + T3: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

fn bind<'q>(self, q: Query<'q>) -> Query<'q>
where + 'p: 'q,

source§

impl<'p, T1, T2, T3, T4> Params<'p> for (T1, T2, T3, T4)
where T1: 'p + for<'q> Encode<'q, Db> + Type<Db>, T2: 'p + for<'q> Encode<'q, Db> + Type<Db>, T3: 'p + for<'q> Encode<'q, Db> + Type<Db>, - T4: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

fn bind<'q>(self, q: Query<'q>) -> Query<'q>
where - 'p: 'q,

source§

impl<'p, T1, T2, T3, T4, T5> Params<'p> for (T1, T2, T3, T4, T5)
where + T4: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

fn bind<'q>(self, q: Query<'q>) -> Query<'q>
where + 'p: 'q,

source§

impl<'p, T1, T2, T3, T4, T5> Params<'p> for (T1, T2, T3, T4, T5)
where T1: 'p + for<'q> Encode<'q, Db> + Type<Db>, T2: 'p + for<'q> Encode<'q, Db> + Type<Db>, T3: 'p + for<'q> Encode<'q, Db> + Type<Db>, T4: 'p + for<'q> Encode<'q, Db> + Type<Db>, - T5: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

fn bind<'q>(self, q: Query<'q>) -> Query<'q>
where - 'p: 'q,

source§

impl<'p, T1, T2, T3, T4, T5, T6> Params<'p> for (T1, T2, T3, T4, T5, T6)
where + T5: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

fn bind<'q>(self, q: Query<'q>) -> Query<'q>
where + 'p: 'q,

source§

impl<'p, T1, T2, T3, T4, T5, T6> Params<'p> for (T1, T2, T3, T4, T5, T6)
where T1: 'p + for<'q> Encode<'q, Db> + Type<Db>, T2: 'p + for<'q> Encode<'q, Db> + Type<Db>, T3: 'p + for<'q> Encode<'q, Db> + Type<Db>, T4: 'p + for<'q> Encode<'q, Db> + Type<Db>, T5: 'p + for<'q> Encode<'q, Db> + Type<Db>, - T6: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

fn bind<'q>(self, q: Query<'q>) -> Query<'q>
where - 'p: 'q,

source§

impl<'p, T1, T2, T3, T4, T5, T6, T7> Params<'p> for (T1, T2, T3, T4, T5, T6, T7)
where + T6: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

fn bind<'q>(self, q: Query<'q>) -> Query<'q>
where + 'p: 'q,

source§

impl<'p, T1, T2, T3, T4, T5, T6, T7> Params<'p> for (T1, T2, T3, T4, T5, T6, T7)
where T1: 'p + for<'q> Encode<'q, Db> + Type<Db>, T2: 'p + for<'q> Encode<'q, Db> + Type<Db>, T3: 'p + for<'q> Encode<'q, Db> + Type<Db>, T4: 'p + for<'q> Encode<'q, Db> + Type<Db>, T5: 'p + for<'q> Encode<'q, Db> + Type<Db>, T6: 'p + for<'q> Encode<'q, Db> + Type<Db>, - T7: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

fn bind<'q>(self, q: Query<'q>) -> Query<'q>
where - 'p: 'q,

source§

impl<'p, T1, T2, T3, T4, T5, T6, T7, T8> Params<'p> for (T1, T2, T3, T4, T5, T6, T7, T8)
where + T7: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

fn bind<'q>(self, q: Query<'q>) -> Query<'q>
where + 'p: 'q,

source§

impl<'p, T1, T2, T3, T4, T5, T6, T7, T8> Params<'p> for (T1, T2, T3, T4, T5, T6, T7, T8)
where T1: 'p + for<'q> Encode<'q, Db> + Type<Db>, T2: 'p + for<'q> Encode<'q, Db> + Type<Db>, T3: 'p + for<'q> Encode<'q, Db> + Type<Db>, @@ -68,9 +68,9 @@

§Lifetimes

T5: 'p + for<'q> Encode<'q, Db> + Type<Db>, T6: 'p + for<'q> Encode<'q, Db> + Type<Db>, T7: 'p + for<'q> Encode<'q, Db> + Type<Db>, - T8: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

fn bind<'q>(self, q: Query<'q>) -> Query<'q>
where - 'p: 'q,

source§

impl<'p, T> Params<'p> for (T,)
where - T: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

fn bind<'q>(self, q: Query<'q>) -> Query<'q>
where - 'p: 'q,

source§

impl<'p, T> Params<'p> for Vec<T>
where - T: Params<'p>,

source§

fn bind<'q>(self, q: Query<'q>) -> Query<'q>
where + T8: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

fn bind<'q>(self, q: Query<'q>) -> Query<'q>
where + 'p: 'q,

source§

impl<'p, T> Params<'p> for (T,)
where + T: 'p + for<'q> Encode<'q, Db> + Type<Db>,

source§

fn bind<'q>(self, q: Query<'q>) -> Query<'q>
where + 'p: 'q,

source§

impl<'p, T> Params<'p> for Vec<T>
where + T: Params<'p>,

source§

fn bind<'q>(self, q: Query<'q>) -> Query<'q>
where 'p: 'q,

Implementors§

\ No newline at end of file diff --git a/hotshot_query_service/data_source/storage/sql/trait.TransactionMode.html b/hotshot_query_service/data_source/storage/sql/trait.TransactionMode.html index 8797e1083..f6b49c98e 100644 --- a/hotshot_query_service/data_source/storage/sql/trait.TransactionMode.html +++ b/hotshot_query_service/data_source/storage/sql/trait.TransactionMode.html @@ -1,9 +1,10 @@ -TransactionMode in hotshot_query_service::data_source::storage::sql - Rust
pub trait TransactionMode: Send + Sync {
-    // Required method
+TransactionMode in hotshot_query_service::data_source::storage::sql - Rust
pub trait TransactionMode: Send + Sync {
+    // Required methods
     fn begin(
         conn: &mut <Db as Database>::Connection,
     ) -> impl Future<Output = Result<()>> + Send;
+    fn display() -> &'static str;
 }
Expand description

Trait for marker types indicating what type of access a transaction has to the database.

-

Required Methods§

Required Methods§

source

fn begin( conn: &mut <Db as Database>::Connection, -) -> impl Future<Output = Result<()>> + Send

Object Safety§

This trait is not object safe.

Implementors§

\ No newline at end of file +) -> impl Future<Output = Result<()>> + Send

source

fn display() -> &'static str

Object Safety§

This trait is not object safe.

Implementors§

\ No newline at end of file diff --git a/hotshot_query_service/data_source/storage/sql/type.Query.html b/hotshot_query_service/data_source/storage/sql/type.Query.html index c6ebc4b4b..5dc1375a9 100644 --- a/hotshot_query_service/data_source/storage/sql/type.Query.html +++ b/hotshot_query_service/data_source/storage/sql/type.Query.html @@ -1 +1 @@ -Query in hotshot_query_service::data_source::storage::sql - Rust

Type Alias hotshot_query_service::data_source::storage::sql::Query

source ·
pub type Query<'q> = Query<'q, Db, <Db as Database>::Arguments<'q>>;

Aliased Type§

struct Query<'q> { /* private fields */ }
\ No newline at end of file +Query in hotshot_query_service::data_source::storage::sql - Rust

Type Alias hotshot_query_service::data_source::storage::sql::Query

source ·
pub type Query<'q> = Query<'q, Db, <Db as Database>::Arguments<'q>>;

Aliased Type§

struct Query<'q> { /* private fields */ }
\ No newline at end of file diff --git a/hotshot_query_service/data_source/storage/sql/type.QueryAs.html b/hotshot_query_service/data_source/storage/sql/type.QueryAs.html index 219474d7d..b2070afb4 100644 --- a/hotshot_query_service/data_source/storage/sql/type.QueryAs.html +++ b/hotshot_query_service/data_source/storage/sql/type.QueryAs.html @@ -1 +1 @@ -QueryAs in hotshot_query_service::data_source::storage::sql - Rust

Type Alias hotshot_query_service::data_source::storage::sql::QueryAs

source ·
pub type QueryAs<'q, T> = QueryAs<'q, Db, T, <Db as Database>::Arguments<'q>>;

Aliased Type§

struct QueryAs<'q, T> { /* private fields */ }
\ No newline at end of file +QueryAs in hotshot_query_service::data_source::storage::sql - Rust

Type Alias hotshot_query_service::data_source::storage::sql::QueryAs

source ·
pub type QueryAs<'q, T> = QueryAs<'q, Db, T, <Db as Database>::Arguments<'q>>;

Aliased Type§

struct QueryAs<'q, T> { /* private fields */ }
\ No newline at end of file diff --git a/hotshot_query_service/data_source/storage/trait.AvailabilityStorage.html b/hotshot_query_service/data_source/storage/trait.AvailabilityStorage.html index b080c8ce6..b7b49d5cc 100644 --- a/hotshot_query_service/data_source/storage/trait.AvailabilityStorage.html +++ b/hotshot_query_service/data_source/storage/trait.AvailabilityStorage.html @@ -143,12 +143,12 @@ rolled back, and may also compete for resources being used by the transaction itself. Thus, we only provide AvailabilityStorage, which returns errors if data is not available instead of fetching.

-
source§

impl<'a, Types: NodeType> AvailabilityStorage<Types> for hotshot_query_service::data_source::storage::no_storage::Transaction<'a>
where +
source§

impl<'a, Types: NodeType> AvailabilityStorage<Types> for hotshot_query_service::data_source::storage::no_storage::Transaction<'a>
where Payload<Types>: QueryablePayload<Types>,

source§

impl<Mode, Types> AvailabilityStorage<Types> for hotshot_query_service::data_source::storage::sql::Transaction<Mode>
where Types: NodeType, Mode: TransactionMode, Payload<Types>: QueryablePayload<Types>, - Header<Types>: QueryableHeader<Types>,

source§

impl<Types, T> AvailabilityStorage<Types> for hotshot_query_service::data_source::storage::fs::Transaction<T>
where + Header<Types>: QueryableHeader<Types>,

source§

impl<Types, T> AvailabilityStorage<Types> for hotshot_query_service::data_source::storage::fs::Transaction<T>
where Types: NodeType, Payload<Types>: QueryablePayload<Types>, Header<Types>: QueryableHeader<Types>, diff --git a/hotshot_query_service/data_source/storage/trait.NodeStorage.html b/hotshot_query_service/data_source/storage/trait.NodeStorage.html index 9ed0f85a3..9e3c05206 100644 --- a/hotshot_query_service/data_source/storage/trait.NodeStorage.html +++ b/hotshot_query_service/data_source/storage/trait.NodeStorage.html @@ -63,13 +63,13 @@ ) -> Pin<Box<dyn Future<Output = QueryResult<SyncStatus>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Search the database for missing objects and generate a report.

-

Object Safety§

This trait is not object safe.

Implementors§

source§

impl<'a, T> NodeStorage<MockTypes> for hotshot_query_service::data_source::storage::no_storage::testing::Transaction<'a, T>
where +

Object Safety§

This trait is not object safe.

Implementors§

source§

impl<'a, T> NodeStorage<MockTypes> for hotshot_query_service::data_source::storage::no_storage::testing::Transaction<'a, T>

source§

impl<'a, Types, T> NodeStorage<Types> for hotshot_query_service::data_source::fetching::Transaction<'a, Types, T>
where Types: NodeType, - T: NodeStorage<Types> + Send,

source§

impl<'a, Types: NodeType> NodeStorage<Types> for hotshot_query_service::data_source::storage::no_storage::Transaction<'a>
where + T: NodeStorage<Types> + Send,

source§

impl<'a, Types: NodeType> NodeStorage<Types> for hotshot_query_service::data_source::storage::no_storage::Transaction<'a>
where Payload<Types>: QueryablePayload<Types>,

source§

impl<Mode, Types> NodeStorage<Types> for hotshot_query_service::data_source::storage::sql::Transaction<Mode>
where Mode: TransactionMode, - Types: NodeType,

source§

impl<Types, T> NodeStorage<Types> for hotshot_query_service::data_source::storage::fs::Transaction<T>
where + Types: NodeType,

source§

impl<Types, T> NodeStorage<Types> for hotshot_query_service::data_source::storage::fs::Transaction<T>
where Types: NodeType, Payload<Types>: QueryablePayload<Types>, Header<Types>: QueryableHeader<Types>, diff --git a/hotshot_query_service/data_source/struct.ExtensibleDataSource.html b/hotshot_query_service/data_source/struct.ExtensibleDataSource.html index 27c7e00e8..05d9db97e 100644 --- a/hotshot_query_service/data_source/struct.ExtensibleDataSource.html +++ b/hotshot_query_service/data_source/struct.ExtensibleDataSource.html @@ -1,4 +1,4 @@ -ExtensibleDataSource in hotshot_query_service::data_source - Rust
pub struct ExtensibleDataSource<D, U> { /* private fields */ }
Expand description

Wrapper to add extensibility to an existing data source.

+ExtensibleDataSource in hotshot_query_service::data_source - Rust
pub struct ExtensibleDataSource<D, U> { /* private fields */ }
Expand description

Wrapper to add extensibility to an existing data source.

ExtensibleDataSource adds app-specific data to any existing data source. It implements all the data source traits defined in this crate as long as the underlying data source does so, which means it can be used as state for instantiating the APIs defined in this crate. At the @@ -114,21 +114,21 @@ from: usize, ) -> Pin<Box<dyn Future<Output = BoxStream<'static, VidCommonQueryData<Types>>> + Send + 'async_trait>>

where Self: Sync + 'async_trait, - 'life0: 'async_trait,

source§

impl<D: Clone, U: Clone> Clone for ExtensibleDataSource<D, U>

source§

fn clone(&self) -> ExtensibleDataSource<D, U>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<D, U> DataSourceLifeCycle for ExtensibleDataSource<D, U>
where + 'life0: 'async_trait,

source§

impl<D: Clone, U: Clone> Clone for ExtensibleDataSource<D, U>

source§

fn clone(&self) -> ExtensibleDataSource<D, U>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<D, U> DataSourceLifeCycle for ExtensibleDataSource<D, U>
where D: TestableDataSource, for<'a> D::Transaction<'a>: UpdateDataSource<MockTypes>, - U: Clone + Default + Send + Sync + 'static,

source§

type Storage = <D as DataSourceLifeCycle>::Storage

Backing storage for the data source. Read more
source§

fn create<'async_trait>( + U: Clone + Default + Send + Sync + 'static,

source§

type Storage = <D as DataSourceLifeCycle>::Storage

Backing storage for the data source. Read more
source§

fn create<'async_trait>( node_id: usize, ) -> Pin<Box<dyn Future<Output = Self::Storage> + Send + 'async_trait>>
where - Self: 'async_trait,

source§

fn connect<'life0, 'async_trait>( + Self: 'async_trait,

source§

fn connect<'life0, 'async_trait>( storage: &'life0 Self::Storage, ) -> Pin<Box<dyn Future<Output = Self> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn reset<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn reset<'life0, 'async_trait>( storage: &'life0 Self::Storage, ) -> Pin<Box<dyn Future<Output = Self> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn handle_event<'life0, 'life1, 'async_trait>( + 'life0: 'async_trait,

source§

fn handle_event<'life0, 'life1, 'async_trait>( &'life0 self, event: &'life1 Event<MockTypes>, ) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>
where @@ -138,66 +138,67 @@ _network: &'life0 mut MockNetwork<Self>, ) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

Setup runs after setting up the network but before starting a test.
source§

impl<D: Debug, U: Debug> Debug for ExtensibleDataSource<D, U>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<D, U, Types> ExplorerDataSource<Types> for ExtensibleDataSource<D, U>
where + 'life0: 'async_trait,

Setup runs after setting up the network but before starting a test.
source§

impl<D: Debug, U: Debug> Debug for ExtensibleDataSource<D, U>

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<D, U, Types> ExplorerDataSource<Types> for ExtensibleDataSource<D, U>
where D: ExplorerDataSource<Types> + Sync, U: Send + Sync, Types: NodeType, Payload<Types>: QueryablePayload<Types>, Header<Types>: ExplorerHeader<Types> + QueryableHeader<Types>, - Transaction<Types>: ExplorerTransaction,

source§

fn get_block_detail<'life0, 'async_trait>( + Transaction<Types>: ExplorerTransaction,

source§

fn get_block_detail<'life0, 'async_trait>( &'life0 self, request: BlockIdentifier<Types>, ) -> Pin<Box<dyn Future<Output = Result<BlockDetail<Types>, GetBlockDetailError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

get_block_detail is a method that retrieves the details of a specific block from the blockchain. The block is identified by the given -BlockIdentifier.
source§

fn get_block_summaries<'life0, 'async_trait>( +BlockIdentifier.

source§

fn get_block_summaries<'life0, 'async_trait>( &'life0 self, request: GetBlockSummariesRequest<Types>, ) -> Pin<Box<dyn Future<Output = Result<Vec<BlockSummary<Types>>, GetBlockSummariesError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

get_block_summaries is a method that retrieves a list of block summaries from the blockchain. The list is generated from the given -GetBlockSummariesRequest.
source§

fn get_transaction_detail<'life0, 'async_trait>( +GetBlockSummariesRequest.

source§

fn get_transaction_detail<'life0, 'async_trait>( &'life0 self, request: TransactionIdentifier<Types>, ) -> Pin<Box<dyn Future<Output = Result<TransactionDetailResponse<Types>, GetTransactionDetailError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

get_transaction_detail is a method that retrieves the details of a specific transaction from the blockchain. The transaction is identified -by the given TransactionIdentifier.
source§

fn get_transaction_summaries<'life0, 'async_trait>( +by the given TransactionIdentifier.

source§

fn get_transaction_summaries<'life0, 'async_trait>( &'life0 self, request: GetTransactionSummariesRequest<Types>, ) -> Pin<Box<dyn Future<Output = Result<Vec<TransactionSummary<Types>>, GetTransactionSummariesError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

get_transaction_summaries is a method that retrieves a list of transaction summaries from the blockchain. The list is generated from -the given GetTransactionSummariesRequest.
source§

fn get_explorer_summary<'life0, 'async_trait>( +the given GetTransactionSummariesRequest.

source§

fn get_explorer_summary<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = Result<ExplorerSummary<Types>, GetExplorerSummaryError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

get_explorer_summary is a method that retrieves a summary overview of the blockchain. This is useful for displaying information that -indicates the overall status of the block chain.
source§

fn get_search_results<'life0, 'async_trait>( +indicates the overall status of the block chain.

source§

fn get_search_results<'life0, 'async_trait>( &'life0 self, query: String, ) -> Pin<Box<dyn Future<Output = Result<SearchResult<Types>, GetSearchResultsError>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

get_search_results is a method that retrieves the results of a search query against the blockchain. The results are generated from the given -query string.
source§

impl<D, U, Types, State, const ARITY: usize> MerklizedStateDataSource<Types, State, ARITY> for ExtensibleDataSource<D, U>
where +query string.

source§

impl<D, U> HasMetrics for ExtensibleDataSource<D, U>
where + D: HasMetrics,

source§

impl<D, U, Types, State, const ARITY: usize> MerklizedStateDataSource<Types, State, ARITY> for ExtensibleDataSource<D, U>
where D: MerklizedStateDataSource<Types, State, ARITY> + Sync, U: Send + Sync, Types: NodeType, - State: MerklizedState<Types, ARITY>,

source§

fn get_path<'life0, 'async_trait>( + State: MerklizedState<Types, ARITY>,

source§

fn get_path<'life0, 'async_trait>( &'life0 self, snapshot: Snapshot<Types, State, ARITY>, key: State::Key, ) -> Pin<Box<dyn Future<Output = QueryResult<MerkleProof<State::Entry, State::Key, State::T, ARITY>>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

impl<D, U> MerklizedStateHeightPersistence for ExtensibleDataSource<D, U>
where + 'life0: 'async_trait,

source§

impl<D, U> MerklizedStateHeightPersistence for ExtensibleDataSource<D, U>

source§

fn get_last_state_height<'life0, 'async_trait>( + U: Send + Sync,

source§

fn get_last_state_height<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
where Self: 'async_trait, @@ -232,17 +233,17 @@ end: u64, ) -> Pin<Box<dyn Future<Output = QueryResult<TimeWindowQueryData<Header<Types>>>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

impl<D, U> StatusDataSource for ExtensibleDataSource<D, U>
where + 'life0: 'async_trait,

source§

impl<D, U> StatusDataSource for ExtensibleDataSource<D, U>
where D: StatusDataSource + Send + Sync, - U: Send + Sync,

source§

fn block_height<'life0, 'async_trait>( + U: Send + Sync,

source§

fn block_height<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn metrics(&self) -> &PrometheusMetrics

source§

fn consensus_metrics(&self) -> QueryResult<PrometheusMetrics>

source§

fn elapsed_time_since_last_decide<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn consensus_metrics(&self) -> QueryResult<PrometheusMetrics>

source§

fn elapsed_time_since_last_decide<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<u64>> + Send + 'async_trait>>
where Self: Sync + 'async_trait, - 'life0: 'async_trait,

source§

fn success_rate<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn success_rate<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<f64>> + Send + 'async_trait>>
where Self: Sync + 'async_trait, @@ -265,16 +266,16 @@ share: Option<VidShare>, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

impl<D, U, Types, State, const ARITY: usize> UpdateStateData<Types, State, ARITY> for ExtensibleDataSource<D, U>
where + 'life0: 'async_trait,

source§

impl<D, U, Types, State, const ARITY: usize> UpdateStateData<Types, State, ARITY> for ExtensibleDataSource<D, U>
where D: UpdateStateData<Types, State, ARITY> + Send + Sync, U: Send + Sync, State: MerklizedState<Types, ARITY>, - Types: NodeType,

source§

fn set_last_state_height<'life0, 'async_trait>( + Types: NodeType,

source§

fn set_last_state_height<'life0, 'async_trait>( &'life0 mut self, height: usize, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn insert_merkle_nodes<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn insert_merkle_nodes<'life0, 'async_trait>( &'life0 mut self, path: MerkleProof<State::Entry, State::Key, State::T, ARITY>, traversal_path: Vec<usize>, @@ -437,8 +438,8 @@ ) -> Pin<Box<dyn Future<Output = Result<(), Error>> + Send + 'async_trait>>
where 'life0: 'async_trait, 'life1: 'async_trait, - T: 'async_trait,

Update query state based on a new consensus event. Read more
source§

impl<T> UpdateStatusData for T
where - T: StatusDataSource,

source§

fn populate_metrics(&self) -> Box<dyn Metrics>

§

impl<V, T> VZip<V> for T
where + T: 'async_trait,

Update query state based on a new consensus event. Read more
source§

impl<T> UpdateStatusData for T
where + T: StatusDataSource,

source§

fn populate_metrics(&self) -> Box<dyn Metrics>

§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a diff --git a/hotshot_query_service/data_source/struct.MetricsDataSource.html b/hotshot_query_service/data_source/struct.MetricsDataSource.html index dcd1b9f39..e5be598ba 100644 --- a/hotshot_query_service/data_source/struct.MetricsDataSource.html +++ b/hotshot_query_service/data_source/struct.MetricsDataSource.html @@ -1,4 +1,4 @@ -MetricsDataSource in hotshot_query_service::data_source - Rust
pub struct MetricsDataSource { /* private fields */ }
Expand description

A minimal data source for the status API provided in this crate, with no persistent storage.

+MetricsDataSource in hotshot_query_service::data_source - Rust
pub struct MetricsDataSource { /* private fields */ }
Expand description

A minimal data source for the status API provided in this crate, with no persistent storage.

MetricsDataSource uses the metrics provided by HotShot to implement StatusDataSource. It updates automatically whenever HotShot updates its metrics. All of the state for the metrics data source is kept in memory, so it does not require a persistent storage backend. This makes @@ -17,18 +17,18 @@ panic!(), // Other fields omitted ).await.map_err(Error::internal)?.0;

-

Trait Implementations§

source§

impl Clone for MetricsDataSource

source§

fn clone(&self) -> MetricsDataSource

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl DataSourceLifeCycle for MetricsDataSource

source§

type Storage = PrometheusMetrics

Backing storage for the data source. Read more
source§

fn create<'async_trait>( +

Trait Implementations§

source§

impl Clone for MetricsDataSource

source§

fn clone(&self) -> MetricsDataSource

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl DataSourceLifeCycle for MetricsDataSource

source§

type Storage = PrometheusMetrics

Backing storage for the data source. Read more
source§

fn create<'async_trait>( _node_id: usize, ) -> Pin<Box<dyn Future<Output = Self::Storage> + Send + 'async_trait>>
where - Self: 'async_trait,

source§

fn connect<'life0, 'async_trait>( + Self: 'async_trait,

source§

fn connect<'life0, 'async_trait>( storage: &'life0 Self::Storage, ) -> Pin<Box<dyn Future<Output = Self> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn reset<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn reset<'life0, 'async_trait>( storage: &'life0 Self::Storage, ) -> Pin<Box<dyn Future<Output = Self> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn handle_event<'life0, 'life1, 'async_trait>( + 'life0: 'async_trait,

source§

fn handle_event<'life0, 'life1, 'async_trait>( &'life0 self, _event: &'life1 Event<MockTypes>, ) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>
where @@ -38,15 +38,15 @@ _network: &'life0 mut MockNetwork<Self>, ) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

Setup runs after setting up the network but before starting a test.
source§

impl Debug for MetricsDataSource

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for MetricsDataSource

source§

fn default() -> MetricsDataSource

Returns the “default value” for a type. Read more
source§

impl StatusDataSource for MetricsDataSource

source§

fn block_height<'life0, 'async_trait>( + 'life0: 'async_trait,

Setup runs after setting up the network but before starting a test.
source§

impl Debug for MetricsDataSource

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Default for MetricsDataSource

source§

fn default() -> MetricsDataSource

Returns the “default value” for a type. Read more
source§

impl HasMetrics for MetricsDataSource

source§

impl StatusDataSource for MetricsDataSource

source§

fn block_height<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

source§

fn metrics(&self) -> &PrometheusMetrics

source§

fn consensus_metrics(&self) -> QueryResult<PrometheusMetrics>

source§

fn elapsed_time_since_last_decide<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn consensus_metrics(&self) -> QueryResult<PrometheusMetrics>

source§

fn elapsed_time_since_last_decide<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<u64>> + Send + 'async_trait>>
where Self: Sync + 'async_trait, - 'life0: 'async_trait,

source§

fn success_rate<'life0, 'async_trait>( + 'life0: 'async_trait,

source§

fn success_rate<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<f64>> + Send + 'async_trait>>
where Self: Sync + 'async_trait, @@ -178,8 +178,8 @@ T: Clone,

source§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
§

impl<T> TryConv for T

§

fn try_conv<T>(self) -> Result<T, Self::Error>
where Self: TryInto<T>,

Attempts to convert self into T using TryInto<T>. Read more
source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

source§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for T
where - U: TryFrom<T>,

source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<T> UpdateStatusData for T
where - T: StatusDataSource,

source§

fn populate_metrics(&self) -> Box<dyn Metrics>

§

impl<V, T> VZip<V> for T
where + U: TryFrom<T>,

source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
source§

impl<T> UpdateStatusData for T
where + T: StatusDataSource,

source§

fn populate_metrics(&self) -> Box<dyn Metrics>

§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a diff --git a/hotshot_query_service/data_source/trait.Transaction.html b/hotshot_query_service/data_source/trait.Transaction.html index a67ce3cc4..e758230bd 100644 --- a/hotshot_query_service/data_source/trait.Transaction.html +++ b/hotshot_query_service/data_source/trait.Transaction.html @@ -8,11 +8,11 @@ underlying storage, and are saved if the process restarts. It also allows pending changes to be rolled back (revert) so that they are never written back to storage and are no longer reflected even through the data source object which was used to make the changes.

-

Required Methods§

source

fn commit(self) -> impl Future<Output = Result<()>> + Send

source

fn revert(self) -> impl Future + Send

Object Safety§

This trait is not object safe.

Implementors§

source§

impl<'a> Transaction for hotshot_query_service::data_source::storage::no_storage::Transaction<'a>

source§

impl<'a, T> Transaction for hotshot_query_service::data_source::storage::no_storage::testing::Transaction<'a, T>
where - T: Transaction,

source§

impl<'a, Types> Transaction for hotshot_query_service::data_source::storage::fs::Transaction<RwLockReadGuard<'a, FileSystemStorageInner<Types>>>
where +

Required Methods§

source

fn commit(self) -> impl Future<Output = Result<()>> + Send

source

fn revert(self) -> impl Future + Send

Object Safety§

This trait is not object safe.

Implementors§

source§

impl<'a> Transaction for hotshot_query_service::data_source::storage::no_storage::Transaction<'a>

source§

impl<'a, T> Transaction for hotshot_query_service::data_source::storage::no_storage::testing::Transaction<'a, T>
where + T: Transaction,

source§

impl<'a, Types> Transaction for hotshot_query_service::data_source::storage::fs::Transaction<RwLockReadGuard<'a, FileSystemStorageInner<Types>>>
where Types: NodeType, - Payload<Types>: QueryablePayload<Types>,

source§

impl<'a, Types> Transaction for hotshot_query_service::data_source::storage::fs::Transaction<RwLockWriteGuard<'a, FileSystemStorageInner<Types>>>
where + Payload<Types>: QueryablePayload<Types>,

source§

impl<'a, Types> Transaction for hotshot_query_service::data_source::storage::fs::Transaction<RwLockWriteGuard<'a, FileSystemStorageInner<Types>>>
where Types: NodeType, Payload<Types>: QueryablePayload<Types>,

source§

impl<'a, Types, T> Transaction for hotshot_query_service::data_source::fetching::Transaction<'a, Types, T>
where Types: NodeType, - T: Transaction,

source§

impl<Mode: TransactionMode> Transaction for hotshot_query_service::data_source::storage::sql::Transaction<Mode>

\ No newline at end of file + T: Transaction,
source§

impl<Mode: TransactionMode> Transaction for hotshot_query_service::data_source::storage::sql::Transaction<Mode>

\ No newline at end of file diff --git a/hotshot_query_service/data_source/trait.VersionedDataSource.html b/hotshot_query_service/data_source/trait.VersionedDataSource.html index 567f0fab8..fc0de8099 100644 --- a/hotshot_query_service/data_source/trait.VersionedDataSource.html +++ b/hotshot_query_service/data_source/trait.VersionedDataSource.html @@ -33,17 +33,17 @@ results will not be reflected in a successful read-only transaction which was opened before the write was committed.

Read-only transactions do not need to be committed, and reverting has no effect.

-

Object Safety§

This trait is not object safe.

Implementors§

Object Safety§

This trait is not object safe.

Implementors§

source§

impl VersionedDataSource for DataSource

source§

type Transaction<'a> = Transaction<'a, <SqlStorage as VersionedDataSource>::Transaction<'a>> where - Self: 'a

source§

type ReadOnly<'a> = Transaction<'a, <SqlStorage as VersionedDataSource>::ReadOnly<'a>> + Self: 'a

source§

type ReadOnly<'a> = Transaction<'a, <SqlStorage as VersionedDataSource>::ReadOnly<'a>> where - Self: 'a

source§

impl VersionedDataSource for NoStorage

source§

type Transaction<'a> = Transaction<'a> + Self: 'a

source§

impl VersionedDataSource for NoStorage

source§

type Transaction<'a> = Transaction<'a> where - Self: 'a

source§

type ReadOnly<'a> = Transaction<'a> + Self: 'a

source§

type ReadOnly<'a> = Transaction<'a> where - Self: 'a

source§

impl VersionedDataSource for SqlStorage

source§

type Transaction<'a> = Transaction<Write> + Self: 'a

source§

impl VersionedDataSource for SqlStorage

source§

type Transaction<'a> = Transaction<Write> where - Self: 'a

source§

type ReadOnly<'a> = Transaction<Read> + Self: 'a

source§

type ReadOnly<'a> = Transaction<Read> where Self: 'a

source§

impl<D, U> VersionedDataSource for ExtensibleDataSource<D, U>
where D: VersionedDataSource + Send, @@ -51,16 +51,16 @@ where Self: 'a

source§

type ReadOnly<'a> = <D as VersionedDataSource>::ReadOnly<'a> where - Self: 'a

source§

impl<Types, S, P> VersionedDataSource for FetchingDataSource<Types, S, P>
where + Self: 'a

source§

impl<Types, S, P> VersionedDataSource for FetchingDataSource<Types, S, P>
where Types: NodeType, S: VersionedDataSource + Send + Sync, - P: Send + Sync,

source§

type Transaction<'a> = Transaction<'a, Types, <S as VersionedDataSource>::Transaction<'a>> + P: Send + Sync,

source§

type Transaction<'a> = Transaction<'a, Types, <S as VersionedDataSource>::Transaction<'a>> where - Self: 'a

source§

type ReadOnly<'a> = Transaction<'a, Types, <S as VersionedDataSource>::ReadOnly<'a>> + Self: 'a

source§

type ReadOnly<'a> = Transaction<'a, Types, <S as VersionedDataSource>::ReadOnly<'a>> where - Self: 'a

source§

impl<Types: NodeType> VersionedDataSource for FileSystemStorage<Types>
where - Payload<Types>: QueryablePayload<Types>,

source§

type Transaction<'a> = Transaction<RwLockWriteGuard<'a, FileSystemStorageInner<Types>>> + Self: 'a

source§

impl<Types: NodeType> VersionedDataSource for FileSystemStorage<Types>
where + Payload<Types>: QueryablePayload<Types>,

source§

type Transaction<'a> = Transaction<RwLockWriteGuard<'a, FileSystemStorageInner<Types>>> where - Self: 'a

source§

type ReadOnly<'a> = Transaction<RwLockReadGuard<'a, FileSystemStorageInner<Types>>> + Self: 'a

source§

type ReadOnly<'a> = Transaction<RwLockReadGuard<'a, FileSystemStorageInner<Types>>> where Self: 'a

\ No newline at end of file diff --git a/hotshot_query_service/enum.QueryError.html b/hotshot_query_service/enum.QueryError.html index 8407a8a6a..f19eb48ee 100644 --- a/hotshot_query_service/enum.QueryError.html +++ b/hotshot_query_service/enum.QueryError.html @@ -1,4 +1,4 @@ -QueryError in hotshot_query_service - Rust

Enum hotshot_query_service::QueryError

source ·
pub enum QueryError {
+QueryError in hotshot_query_service - Rust

Enum hotshot_query_service::QueryError

source ·
pub enum QueryError {
     NotFound,
     Missing,
     Error {
@@ -8,16 +8,16 @@
 
§

Missing

The requested resource exists but is not currently available.

In most cases a missing resource can be recovered from DA.

§

Error

There was an error while trying to fetch the requested resource.

-

Fields

§message: String

Implementations§

source§

impl QueryError

source

pub fn status(&self) -> StatusCode

Trait Implementations§

source§

impl Clone for QueryError

source§

fn clone(&self) -> QueryError

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for QueryError

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<'de> Deserialize<'de> for QueryError

source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where - __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
source§

impl Display for QueryError

source§

fn fmt(&self, __snafu_display_formatter: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Error for QueryError
where - Self: Debug + Display,

source§

fn description(&self) -> &str

👎Deprecated since 1.42.0: use the Display impl or to_string()
source§

fn cause(&self) -> Option<&dyn Error>

👎Deprecated since 1.33.0: replaced by Error::source, which can support downcasting
source§

fn source(&self) -> Option<&(dyn Error + 'static)>

Returns the lower-level source of this error, if any. Read more
source§

fn provide<'a>(&'a self, request: &mut Request<'a>)

🔬This is a nightly-only experimental API. (error_generic_member_access)
Provides type-based access to context intended for error reports. Read more
source§

impl ErrorCompat for QueryError

source§

fn backtrace(&self) -> Option<&Backtrace>

Returns a Backtrace that may be printed.
§

fn iter_chain(&self) -> ChainCompat<'_, '_>
where +

Fields

§message: String

Implementations§

source§

impl QueryError

source

pub fn status(&self) -> StatusCode

Trait Implementations§

source§

impl Clone for QueryError

source§

fn clone(&self) -> QueryError

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl Debug for QueryError

source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl<'de> Deserialize<'de> for QueryError

source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where + __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
source§

impl Display for QueryError

source§

fn fmt(&self, __snafu_display_formatter: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
source§

impl Error for QueryError
where + Self: Debug + Display,

source§

fn description(&self) -> &str

👎Deprecated since 1.42.0: use the Display impl or to_string()
source§

fn cause(&self) -> Option<&dyn Error>

👎Deprecated since 1.33.0: replaced by Error::source, which can support downcasting
source§

fn source(&self) -> Option<&(dyn Error + 'static)>

Returns the lower-level source of this error, if any. Read more
source§

fn provide<'a>(&'a self, request: &mut Request<'a>)

🔬This is a nightly-only experimental API. (error_generic_member_access)
Provides type-based access to context intended for error reports. Read more
source§

impl ErrorCompat for QueryError

source§

fn backtrace(&self) -> Option<&Backtrace>

Returns a Backtrace that may be printed.
§

fn iter_chain(&self) -> ChainCompat<'_, '_>
where Self: AsErrorSource,

Returns an iterator for traversing the chain of errors, starting with the current error -and continuing with recursive calls to Error::source. Read more
source§

impl From<Error> for QueryError

source§

fn from(err: Error) -> Self

Converts to this type from the input type.
source§

impl From<QueryError> for Error

source§

fn from(original: QueryError) -> Error

Converts to this type from the input type.
source§

impl From<QueryError> for Error

source§

fn from(original: QueryError) -> Error

Converts to this type from the input type.
source§

impl From<QueryError> for GetBlockDetailError

source§

fn from(value: QueryError) -> Self

Converts to this type from the input type.
source§

impl From<QueryError> for GetBlockSummariesError

source§

fn from(value: QueryError) -> Self

Converts to this type from the input type.
source§

impl From<QueryError> for GetExplorerSummaryError

source§

fn from(value: QueryError) -> Self

Converts to this type from the input type.
source§

impl From<QueryError> for GetSearchResultsError

source§

fn from(value: QueryError) -> Self

Converts to this type from the input type.
source§

impl From<QueryError> for GetTransactionDetailError

source§

fn from(value: QueryError) -> Self

Converts to this type from the input type.
source§

impl From<QueryError> for GetTransactionSummariesError

source§

fn from(value: QueryError) -> Self

Converts to this type from the input type.
source§

impl From<TimestampConversionError> for QueryError

source§

fn from(value: TimestampConversionError) -> Self

Converts to this type from the input type.
source§

impl<__T0> IntoError<QueryError> for ErrorSnafu<__T0>
where +and continuing with recursive calls to Error::source. Read more

source§

impl From<Error> for QueryError

source§

fn from(err: Error) -> Self

Converts to this type from the input type.
source§

impl From<QueryError> for Error

source§

fn from(original: QueryError) -> Error

Converts to this type from the input type.
source§

impl From<QueryError> for Error

source§

fn from(original: QueryError) -> Error

Converts to this type from the input type.
source§

impl From<QueryError> for GetBlockDetailError

source§

fn from(value: QueryError) -> Self

Converts to this type from the input type.
source§

impl From<QueryError> for GetBlockSummariesError

source§

fn from(value: QueryError) -> Self

Converts to this type from the input type.
source§

impl From<QueryError> for GetExplorerSummaryError

source§

fn from(value: QueryError) -> Self

Converts to this type from the input type.
source§

impl From<QueryError> for GetSearchResultsError

source§

fn from(value: QueryError) -> Self

Converts to this type from the input type.
source§

impl From<QueryError> for GetTransactionDetailError

source§

fn from(value: QueryError) -> Self

Converts to this type from the input type.
source§

impl From<QueryError> for GetTransactionSummariesError

source§

fn from(value: QueryError) -> Self

Converts to this type from the input type.
source§

impl From<TimestampConversionError> for QueryError

source§

fn from(value: TimestampConversionError) -> Self

Converts to this type from the input type.
source§

impl<__T0> IntoError<QueryError> for ErrorSnafu<__T0>
where QueryError: Error + ErrorCompat, - __T0: Into<String>,

source§

type Source = NoneError

The underlying error
source§

fn into_error(self, error: Self::Source) -> QueryError

Combine the information to produce the error
source§

impl IntoError<QueryError> for MissingSnafu
where - QueryError: Error + ErrorCompat,

source§

type Source = NoneError

The underlying error
source§

fn into_error(self, error: Self::Source) -> QueryError

Combine the information to produce the error
source§

impl IntoError<QueryError> for NotFoundSnafu
where - QueryError: Error + ErrorCompat,

source§

type Source = NoneError

The underlying error
source§

fn into_error(self, error: Self::Source) -> QueryError

Combine the information to produce the error
source§

impl Serialize for QueryError

source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where + __T0: Into<String>,

source§

type Source = NoneError

The underlying error
source§

fn into_error(self, error: Self::Source) -> QueryError

Combine the information to produce the error
source§

impl IntoError<QueryError> for MissingSnafu
where + QueryError: Error + ErrorCompat,

source§

type Source = NoneError

The underlying error
source§

fn into_error(self, error: Self::Source) -> QueryError

Combine the information to produce the error
source§

impl IntoError<QueryError> for NotFoundSnafu
where + QueryError: Error + ErrorCompat,

source§

type Source = NoneError

The underlying error
source§

fn into_error(self, error: Self::Source) -> QueryError

Combine the information to produce the error
source§

impl Serialize for QueryError

source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for T
where T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> ArchivePointee for T

§

type ArchivedMetadata = ()

The archived version of the pointer metadata for this type.
§

fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, diff --git a/hotshot_query_service/explorer/trait.ExplorerDataSource.html b/hotshot_query_service/explorer/trait.ExplorerDataSource.html index 36f8e2f8b..3bb03a878 100644 --- a/hotshot_query_service/explorer/trait.ExplorerDataSource.html +++ b/hotshot_query_service/explorer/trait.ExplorerDataSource.html @@ -94,13 +94,13 @@ 'life0: 'async_trait,

get_search_results is a method that retrieves the results of a search query against the blockchain. The results are generated from the given query string.

-

Implementors§

source§

impl<D, U, Types> ExplorerDataSource<Types> for ExtensibleDataSource<D, U>
where +

Implementors§

source§

impl<D, U, Types> ExplorerDataSource<Types> for ExtensibleDataSource<D, U>
where D: ExplorerDataSource<Types> + Sync, U: Send + Sync, Types: NodeType, Payload<Types>: QueryablePayload<Types>, Header<Types>: ExplorerHeader<Types> + QueryableHeader<Types>, - Transaction<Types>: ExplorerTransaction,

source§

impl<Types, S, P> ExplorerDataSource<Types> for FetchingDataSource<Types, S, P>

source§

impl<Types, S, P> ExplorerDataSource<Types> for FetchingDataSource<Types, S, P>
where Types: NodeType, Payload<Types>: QueryablePayload<Types>, Header<Types>: QueryableHeader<Types> + ExplorerHeader<Types>, diff --git a/hotshot_query_service/fetching/provider/struct.AnyProvider.html b/hotshot_query_service/fetching/provider/struct.AnyProvider.html index 1dee0ede8..c79d1c2b4 100644 --- a/hotshot_query_service/fetching/provider/struct.AnyProvider.html +++ b/hotshot_query_service/fetching/provider/struct.AnyProvider.html @@ -185,6 +185,6 @@

§Examples

V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a -[WithDispatch] wrapper. Read more
source§

impl<Types, P> AvailabilityProvider<Types> for P
where +[WithDispatch] wrapper. Read more

source§

impl<Types, P> AvailabilityProvider<Types> for P
where Types: NodeType, P: Provider<Types, LeafRequest> + Provider<Types, PayloadRequest> + Provider<Types, VidCommonRequest> + Sync + 'static,

\ No newline at end of file diff --git a/hotshot_query_service/fetching/provider/struct.NoFetching.html b/hotshot_query_service/fetching/provider/struct.NoFetching.html index 1c300bcbd..b539b12d9 100644 --- a/hotshot_query_service/fetching/provider/struct.NoFetching.html +++ b/hotshot_query_service/fetching/provider/struct.NoFetching.html @@ -137,6 +137,6 @@ V: MultiLane<T>,
§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a -[WithDispatch] wrapper. Read more
source§

impl<Types, P> AvailabilityProvider<Types> for P
where +[WithDispatch] wrapper. Read more
source§

impl<Types, P> AvailabilityProvider<Types> for P
where Types: NodeType, P: Provider<Types, LeafRequest> + Provider<Types, PayloadRequest> + Provider<Types, VidCommonRequest> + Sync + 'static,

\ No newline at end of file diff --git a/hotshot_query_service/fetching/provider/struct.QueryServiceProvider.html b/hotshot_query_service/fetching/provider/struct.QueryServiceProvider.html index c14411983..44a5395b4 100644 --- a/hotshot_query_service/fetching/provider/struct.QueryServiceProvider.html +++ b/hotshot_query_service/fetching/provider/struct.QueryServiceProvider.html @@ -151,6 +151,6 @@ V: MultiLane<T>,
§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a -[WithDispatch] wrapper. Read more
source§

impl<Types, P> AvailabilityProvider<Types> for P
where +[WithDispatch] wrapper. Read more
source§

impl<Types, P> AvailabilityProvider<Types> for P
where Types: NodeType, P: Provider<Types, LeafRequest> + Provider<Types, PayloadRequest> + Provider<Types, VidCommonRequest> + Sync + 'static,

\ No newline at end of file diff --git a/hotshot_query_service/fetching/provider/struct.TestProvider.html b/hotshot_query_service/fetching/provider/struct.TestProvider.html index 30a8b3215..c3024ea40 100644 --- a/hotshot_query_service/fetching/provider/struct.TestProvider.html +++ b/hotshot_query_service/fetching/provider/struct.TestProvider.html @@ -156,6 +156,6 @@ V: MultiLane<T>,
§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a -[WithDispatch] wrapper. Read more
source§

impl<Types, P> AvailabilityProvider<Types> for P
where +[WithDispatch] wrapper. Read more
source§

impl<Types, P> AvailabilityProvider<Types> for P
where Types: NodeType, P: Provider<Types, LeafRequest> + Provider<Types, PayloadRequest> + Provider<Types, VidCommonRequest> + Sync + 'static,

\ No newline at end of file diff --git a/hotshot_query_service/fn.run_standalone_service.html b/hotshot_query_service/fn.run_standalone_service.html index 44ff3e25f..aa2d22541 100644 --- a/hotshot_query_service/fn.run_standalone_service.html +++ b/hotshot_query_service/fn.run_standalone_service.html @@ -1,4 +1,4 @@ -run_standalone_service in hotshot_query_service - Rust

Function hotshot_query_service::run_standalone_service

source ·
pub async fn run_standalone_service<Types: NodeType, I: NodeImplementation<Types>, D, ApiVer, HsVer: Versions>(
+run_standalone_service in hotshot_query_service - Rust

Function hotshot_query_service::run_standalone_service

source ·
pub async fn run_standalone_service<Types: NodeType, I: NodeImplementation<Types>, D, ApiVer, HsVer: Versions>(
     options: Options,
     data_source: D,
     hotshot: SystemContextHandle<Types, I, HsVer>,
diff --git a/hotshot_query_service/index.html b/hotshot_query_service/index.html
index 96858fda8..1330c883f 100644
--- a/hotshot_query_service/index.html
+++ b/hotshot_query_service/index.html
@@ -1,4 +1,4 @@
-hotshot_query_service - Rust

Crate hotshot_query_service

source ·
Expand description

The HotShot Query Service is a minimal, generic query service that can be integrated into any +hotshot_query_service - Rust

Crate hotshot_query_service

source ·
Expand description

The HotShot Query Service is a minimal, generic query service that can be integrated into any decentralized application running on the [hotshot] consensus layer. It provides all the features that HotShot itself expects of a query service (such as providing consensus-related data for catchup and synchronization) as well as some application-level features that deal only with @@ -249,15 +249,16 @@

§Composition } // Implement data source trait for status API by delegating to the underlying data source. -#[async_trait] +impl<D: HasMetrics> HasMetrics for AppState<D> { + fn metrics(&self) -> &PrometheusMetrics { + self.hotshot_qs.metrics() + } +} +#[async_trait] impl<D: StatusDataSource + Send + Sync> StatusDataSource for AppState<D> { async fn block_height(&self) -> QueryResult<usize> { self.hotshot_qs.block_height().await } - - fn metrics(&self) -> &PrometheusMetrics { - self.hotshot_qs.metrics() - } } // Implement data source traits for other modules, using additional state from AppState.

diff --git a/hotshot_query_service/macro.include_migrations.html b/hotshot_query_service/macro.include_migrations.html index 1656b67eb..fa3dc5b5b 100644 --- a/hotshot_query_service/macro.include_migrations.html +++ b/hotshot_query_service/macro.include_migrations.html @@ -1,4 +1,4 @@ -include_migrations in hotshot_query_service - Rust

Macro hotshot_query_service::include_migrations

source ·
macro_rules! include_migrations {
+include_migrations in hotshot_query_service - Rust

Macro hotshot_query_service::include_migrations

source ·
macro_rules! include_migrations {
     ($dir:tt) => { ... };
 }
Expand description

Embed migrations from the given directory into the current binary.

The macro invocation include_migrations!(path) evaluates to an expression of type impl Iterator<Item = Migration>. Each migration must be a text file which is an immediate child of diff --git a/hotshot_query_service/merklized_state/trait.MerklizedStateDataSource.html b/hotshot_query_service/merklized_state/trait.MerklizedStateDataSource.html index caa16535f..6ce9ccbbc 100644 --- a/hotshot_query_service/merklized_state/trait.MerklizedStateDataSource.html +++ b/hotshot_query_service/merklized_state/trait.MerklizedStateDataSource.html @@ -17,11 +17,11 @@ key: State::Key, ) -> Pin<Box<dyn Future<Output = QueryResult<MerkleProof<State::Entry, State::Key, State::T, ARITY>>> + Send + 'async_trait>>

where Self: 'async_trait, - 'life0: 'async_trait,

Implementors§

source§

impl<D, U, Types, State, const ARITY: usize> MerklizedStateDataSource<Types, State, ARITY> for ExtensibleDataSource<D, U>
where + 'life0: 'async_trait,

Implementors§

source§

impl<D, U, Types, State, const ARITY: usize> MerklizedStateDataSource<Types, State, ARITY> for ExtensibleDataSource<D, U>
where D: MerklizedStateDataSource<Types, State, ARITY> + Sync, U: Send + Sync, Types: NodeType, - State: MerklizedState<Types, ARITY>,

source§

impl<Types, S, P, State, const ARITY: usize> MerklizedStateDataSource<Types, State, ARITY> for FetchingDataSource<Types, S, P>
where + State: MerklizedState<Types, ARITY>,

source§

impl<Types, S, P, State, const ARITY: usize> MerklizedStateDataSource<Types, State, ARITY> for FetchingDataSource<Types, S, P>
where Types: NodeType, S: VersionedDataSource + 'static, for<'a> S::ReadOnly<'a>: MerklizedStateStorage<Types, State, ARITY>, diff --git a/hotshot_query_service/merklized_state/trait.MerklizedStateHeightPersistence.html b/hotshot_query_service/merklized_state/trait.MerklizedStateHeightPersistence.html index d8b0ae659..3ee37ee3d 100644 --- a/hotshot_query_service/merklized_state/trait.MerklizedStateHeightPersistence.html +++ b/hotshot_query_service/merklized_state/trait.MerklizedStateHeightPersistence.html @@ -9,9 +9,9 @@ &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
where Self: 'async_trait, - 'life0: 'async_trait,

Implementors§

source§

impl<D, U> MerklizedStateHeightPersistence for ExtensibleDataSource<D, U>
where + 'life0: 'async_trait,

Implementors§

source§

impl<D, U> MerklizedStateHeightPersistence for ExtensibleDataSource<D, U>

source§

impl<Types, S, P> MerklizedStateHeightPersistence for FetchingDataSource<Types, S, P>
where + U: Send + Sync,

source§

impl<Types, S, P> MerklizedStateHeightPersistence for FetchingDataSource<Types, S, P>
where Types: NodeType, Payload<Types>: QueryablePayload<Types>, S: VersionedDataSource + 'static, diff --git a/hotshot_query_service/merklized_state/trait.UpdateStateData.html b/hotshot_query_service/merklized_state/trait.UpdateStateData.html index c24f6c833..032cc9443 100644 --- a/hotshot_query_service/merklized_state/trait.UpdateStateData.html +++ b/hotshot_query_service/merklized_state/trait.UpdateStateData.html @@ -30,8 +30,8 @@ 'life0: 'async_trait,

Implementors§

source§

impl<'a, Types, T, State, const ARITY: usize> UpdateStateData<Types, State, ARITY> for hotshot_query_service::data_source::fetching::Transaction<'a, Types, T>
where Types: NodeType, State: MerklizedState<Types, ARITY>, - T: UpdateStateData<Types, State, ARITY> + Send + Sync,

source§

impl<D, U, Types, State, const ARITY: usize> UpdateStateData<Types, State, ARITY> for ExtensibleDataSource<D, U>
where + T: UpdateStateData<Types, State, ARITY> + Send + Sync,

source§

impl<D, U, Types, State, const ARITY: usize> UpdateStateData<Types, State, ARITY> for ExtensibleDataSource<D, U>
where D: UpdateStateData<Types, State, ARITY> + Send + Sync, U: Send + Sync, State: MerklizedState<Types, ARITY>, - Types: NodeType,

source§

impl<Types: NodeType, State: MerklizedState<Types, ARITY>, const ARITY: usize> UpdateStateData<Types, State, ARITY> for hotshot_query_service::data_source::storage::sql::Transaction<Write>

\ No newline at end of file + Types: NodeType,
source§

impl<Types: NodeType, State: MerklizedState<Types, ARITY>, const ARITY: usize> UpdateStateData<Types, State, ARITY> for hotshot_query_service::data_source::storage::sql::Transaction<Write>

\ No newline at end of file diff --git a/hotshot_query_service/node/trait.NodeDataSource.html b/hotshot_query_service/node/trait.NodeDataSource.html index c770dbe60..3f3c9db41 100644 --- a/hotshot_query_service/node/trait.NodeDataSource.html +++ b/hotshot_query_service/node/trait.NodeDataSource.html @@ -63,10 +63,10 @@ ) -> Pin<Box<dyn Future<Output = QueryResult<SyncStatus>> + Send + 'async_trait>>
where Self: 'async_trait, 'life0: 'async_trait,

Search the database for missing objects and generate a report.

-

Object Safety§

This trait is not object safe.

Implementors§

Object Safety§

This trait is not object safe.

Implementors§

source§

impl NodeDataSource<MockTypes> for DataSource

source§

impl<D, U, Types> NodeDataSource<Types> for ExtensibleDataSource<D, U>
where D: NodeDataSource<Types> + Send + Sync, U: Send + Sync, - Types: NodeType,

source§

impl<Types, S, P> NodeDataSource<Types> for FetchingDataSource<Types, S, P>
where + Types: NodeType,

source§

impl<Types, S, P> NodeDataSource<Types> for FetchingDataSource<Types, S, P>
where Types: NodeType, S: VersionedDataSource + 'static, for<'a> S::ReadOnly<'a>: NodeStorage<Types>, diff --git a/hotshot_query_service/status/data_source/trait.HasMetrics.html b/hotshot_query_service/status/data_source/trait.HasMetrics.html new file mode 100644 index 000000000..41a1aed28 --- /dev/null +++ b/hotshot_query_service/status/data_source/trait.HasMetrics.html @@ -0,0 +1,11 @@ + + + + + Redirection + + +

Redirecting to ../../../hotshot_query_service/status/trait.HasMetrics.html...

+ + + \ No newline at end of file diff --git a/hotshot_query_service/status/index.html b/hotshot_query_service/status/index.html index fdc062b0d..65cc6c031 100644 --- a/hotshot_query_service/status/index.html +++ b/hotshot_query_service/status/index.html @@ -10,4 +10,4 @@
  • snapshots of the state right now, with no way to query historical snapshots
  • summary statistics
  • -

    Structs§

    Enums§

    Traits§

    Functions§

    \ No newline at end of file +

    Structs§

    Enums§

    Traits§

    Functions§

    \ No newline at end of file diff --git a/hotshot_query_service/status/sidebar-items.js b/hotshot_query_service/status/sidebar-items.js index 207724974..32d7025ef 100644 --- a/hotshot_query_service/status/sidebar-items.js +++ b/hotshot_query_service/status/sidebar-items.js @@ -1 +1 @@ -window.SIDEBAR_ITEMS = {"enum":["Error"],"fn":["define_api"],"struct":["Options"],"trait":["StatusDataSource","UpdateStatusData"]}; \ No newline at end of file +window.SIDEBAR_ITEMS = {"enum":["Error"],"fn":["define_api"],"struct":["Options"],"trait":["HasMetrics","StatusDataSource","UpdateStatusData"]}; \ No newline at end of file diff --git a/hotshot_query_service/status/trait.HasMetrics.html b/hotshot_query_service/status/trait.HasMetrics.html new file mode 100644 index 000000000..f10599edd --- /dev/null +++ b/hotshot_query_service/status/trait.HasMetrics.html @@ -0,0 +1,9 @@ +HasMetrics in hotshot_query_service::status - Rust

    Trait hotshot_query_service::status::HasMetrics

    source ·
    pub trait HasMetrics {
    +    // Required method
    +    fn metrics(&self) -> &PrometheusMetrics;
    +}

    Required Methods§

    Implementors§

    source§

    impl HasMetrics for DataSource

    source§

    impl HasMetrics for NoStorage

    source§

    impl HasMetrics for SqlStorage

    source§

    impl HasMetrics for MetricsDataSource

    source§

    impl<D, U> HasMetrics for ExtensibleDataSource<D, U>
    where + D: HasMetrics,

    source§

    impl<Types> HasMetrics for FileSystemStorage<Types>
    where + Types: NodeType, + Payload<Types>: QueryablePayload<Types>,

    source§

    impl<Types, S, P> HasMetrics for FetchingDataSource<Types, S, P>
    where + Types: NodeType, + S: HasMetrics,

    \ No newline at end of file diff --git a/hotshot_query_service/status/trait.StatusDataSource.html b/hotshot_query_service/status/trait.StatusDataSource.html index 4afa7b1f3..43c528e40 100644 --- a/hotshot_query_service/status/trait.StatusDataSource.html +++ b/hotshot_query_service/status/trait.StatusDataSource.html @@ -1,11 +1,10 @@ -StatusDataSource in hotshot_query_service::status - Rust

    Trait hotshot_query_service::status::StatusDataSource

    source ·
    pub trait StatusDataSource {
    -    // Required methods
    +StatusDataSource in hotshot_query_service::status - Rust

    Trait hotshot_query_service::status::StatusDataSource

    source ·
    pub trait StatusDataSource: HasMetrics {
    +    // Required method
         fn block_height<'life0, 'async_trait>(
             &'life0 self,
         ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
            where Self: 'async_trait,
                  'life0: 'async_trait;
    -    fn metrics(&self) -> &PrometheusMetrics;
     
         // Provided methods
         fn consensus_metrics(&self) -> QueryResult<PrometheusMetrics> { ... }
    @@ -19,22 +18,22 @@
         ) -> Pin<Box<dyn Future<Output = QueryResult<f64>> + Send + 'async_trait>>
            where Self: Sync + 'async_trait,
                  'life0: 'async_trait { ... }
    -}

    Required Methods§

    source

    fn block_height<'life0, 'async_trait>( +}

    Required Methods§

    source

    fn block_height<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
    where Self: 'async_trait, - 'life0: 'async_trait,

    source

    fn metrics(&self) -> &PrometheusMetrics

    Provided Methods§

    source

    fn consensus_metrics(&self) -> QueryResult<PrometheusMetrics>

    source

    fn elapsed_time_since_last_decide<'life0, 'async_trait>( + 'life0: 'async_trait,

    Provided Methods§

    source

    fn consensus_metrics(&self) -> QueryResult<PrometheusMetrics>

    source

    fn elapsed_time_since_last_decide<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<u64>> + Send + 'async_trait>>
    where Self: Sync + 'async_trait, - 'life0: 'async_trait,

    source

    fn success_rate<'life0, 'async_trait>( + 'life0: 'async_trait,

    source

    fn success_rate<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<f64>> + Send + 'async_trait>>
    where Self: Sync + 'async_trait, - 'life0: 'async_trait,

    Implementors§

    Implementors§

    source§

    impl StatusDataSource for DataSource

    source§

    impl StatusDataSource for MetricsDataSource

    source§

    impl<D, U> StatusDataSource for ExtensibleDataSource<D, U>
    where D: StatusDataSource + Send + Sync, - U: Send + Sync,

    source§

    impl<Types, S, P> StatusDataSource for FetchingDataSource<Types, S, P>
    where + U: Send + Sync,

    source§

    impl<Types, S, P> StatusDataSource for FetchingDataSource<Types, S, P>
    where Types: NodeType, - S: VersionedDataSource + Send + Sync + 'static, + S: VersionedDataSource + HasMetrics + Send + Sync + 'static, for<'a> S::ReadOnly<'a>: NodeStorage<Types>, P: Send + Sync,

    \ No newline at end of file diff --git a/hotshot_query_service/status/trait.UpdateStatusData.html b/hotshot_query_service/status/trait.UpdateStatusData.html index 24da89450..02dbfc2b1 100644 --- a/hotshot_query_service/status/trait.UpdateStatusData.html +++ b/hotshot_query_service/status/trait.UpdateStatusData.html @@ -1,4 +1,4 @@ -UpdateStatusData in hotshot_query_service::status - Rust

    Trait hotshot_query_service::status::UpdateStatusData

    source ·
    pub trait UpdateStatusData {
    +UpdateStatusData in hotshot_query_service::status - Rust

    Trait hotshot_query_service::status::UpdateStatusData

    source ·
    pub trait UpdateStatusData {
         // Required method
         fn populate_metrics(&self) -> Box<dyn Metrics>;
    -}

    Required Methods§

    source

    fn populate_metrics(&self) -> Box<dyn Metrics>

    Implementors§

    \ No newline at end of file +}

    Required Methods§

    source

    fn populate_metrics(&self) -> Box<dyn Metrics>

    Implementors§

    \ No newline at end of file diff --git a/hotshot_query_service/struct.ApiState.html b/hotshot_query_service/struct.ApiState.html index 89185c3f0..475261a16 100644 --- a/hotshot_query_service/struct.ApiState.html +++ b/hotshot_query_service/struct.ApiState.html @@ -1,5 +1,5 @@ -ApiState in hotshot_query_service - Rust

    Struct hotshot_query_service::ApiState

    source ·
    pub struct ApiState<D>(/* private fields */);
    Expand description

    Read-only wrapper for API state which does not require locking.

    -

    Trait Implementations§

    source§

    impl<D: Clone> Clone for ApiState<D>

    source§

    fn clone(&self) -> ApiState<D>

    Returns a copy of the value. Read more
    1.0.0 · source§

    fn clone_from(&mut self, source: &Self)

    Performs copy-assignment from source. Read more
    source§

    impl<D: Debug> Debug for ApiState<D>

    source§

    fn fmt(&self, f: &mut Formatter<'_>) -> Result

    Formats the value using the given formatter. Read more
    source§

    impl<D> Deref for ApiState<D>

    source§

    type Target = Arc<D>

    The resulting type after dereferencing.
    source§

    fn deref(&self) -> &Self::Target

    Dereferences the value.
    source§

    impl<D> From<ApiState<D>> for Arc<D>

    source§

    fn from(original: ApiState<D>) -> Self

    Converts to this type from the input type.
    source§

    impl<D> From<Arc<D>> for ApiState<D>

    source§

    fn from(original: Arc<D>) -> ApiState<D>

    Converts to this type from the input type.
    source§

    impl<D> From<D> for ApiState<D>

    source§

    fn from(d: D) -> Self

    Converts to this type from the input type.
    source§

    impl<D: 'static + Send + Sync> ReadState for ApiState<D>

    source§

    type State = D

    The type of state which this type allows a caller to read.
    source§

    fn read<'life0, 'async_trait, T>( +ApiState in hotshot_query_service - Rust

    Struct hotshot_query_service::ApiState

    source ·
    pub struct ApiState<D>(/* private fields */);
    Expand description

    Read-only wrapper for API state which does not require locking.

    +

    Trait Implementations§

    source§

    impl<D: Clone> Clone for ApiState<D>

    source§

    fn clone(&self) -> ApiState<D>

    Returns a copy of the value. Read more
    1.0.0 · source§

    fn clone_from(&mut self, source: &Self)

    Performs copy-assignment from source. Read more
    source§

    impl<D: Debug> Debug for ApiState<D>

    source§

    fn fmt(&self, f: &mut Formatter<'_>) -> Result

    Formats the value using the given formatter. Read more
    source§

    impl<D> Deref for ApiState<D>

    source§

    type Target = Arc<D>

    The resulting type after dereferencing.
    source§

    fn deref(&self) -> &Self::Target

    Dereferences the value.
    source§

    impl<D> From<ApiState<D>> for Arc<D>

    source§

    fn from(original: ApiState<D>) -> Self

    Converts to this type from the input type.
    source§

    impl<D> From<Arc<D>> for ApiState<D>

    source§

    fn from(original: Arc<D>) -> ApiState<D>

    Converts to this type from the input type.
    source§

    impl<D> From<D> for ApiState<D>

    source§

    fn from(d: D) -> Self

    Converts to this type from the input type.
    source§

    impl<D: 'static + Send + Sync> ReadState for ApiState<D>

    source§

    type State = D

    The type of state which this type allows a caller to read.
    source§

    fn read<'life0, 'async_trait, T>( &'life0 self, op: impl 'async_trait + Send + for<'a> FnOnce(&'a Self::State) -> BoxFuture<'a, T>, ) -> Pin<Box<dyn Future<Output = T> + Send + 'async_trait>>
    where diff --git a/hotshot_query_service/struct.ErrorSnafu.html b/hotshot_query_service/struct.ErrorSnafu.html index cd57e1463..608f26574 100644 --- a/hotshot_query_service/struct.ErrorSnafu.html +++ b/hotshot_query_service/struct.ErrorSnafu.html @@ -1,13 +1,13 @@ -ErrorSnafu in hotshot_query_service - Rust

    Struct hotshot_query_service::ErrorSnafu

    source ·
    pub struct ErrorSnafu<__T0> {
    +ErrorSnafu in hotshot_query_service - Rust

    Struct hotshot_query_service::ErrorSnafu

    source ·
    pub struct ErrorSnafu<__T0> {
         pub message: __T0,
     }
    Expand description

    SNAFU context selector for the QueryError::Error variant

    -

    Fields§

    §message: __T0

    Implementations§

    source§

    impl<__T0> ErrorSnafu<__T0>

    source

    pub fn build(self) -> QueryError
    where +

    Fields§

    §message: __T0

    Implementations§

    source§

    impl<__T0> ErrorSnafu<__T0>

    source

    pub fn build(self) -> QueryError
    where __T0: Into<String>,

    Consume the selector and return the associated error

    -
    source

    pub fn fail<__T>(self) -> Result<__T, QueryError>
    where +

    source

    pub fn fail<__T>(self) -> Result<__T, QueryError>
    where __T0: Into<String>,

    Consume the selector and return a Result with the associated error

    -

    Trait Implementations§

    source§

    impl<__T0: Clone> Clone for ErrorSnafu<__T0>

    source§

    fn clone(&self) -> ErrorSnafu<__T0>

    Returns a copy of the value. Read more
    1.0.0 · source§

    fn clone_from(&mut self, source: &Self)

    Performs copy-assignment from source. Read more
    source§

    impl<__T0: Debug> Debug for ErrorSnafu<__T0>

    source§

    fn fmt(&self, f: &mut Formatter<'_>) -> Result

    Formats the value using the given formatter. Read more
    source§

    impl<__T0> IntoError<QueryError> for ErrorSnafu<__T0>
    where +

    Trait Implementations§

    source§

    impl<__T0: Clone> Clone for ErrorSnafu<__T0>

    source§

    fn clone(&self) -> ErrorSnafu<__T0>

    Returns a copy of the value. Read more
    1.0.0 · source§

    fn clone_from(&mut self, source: &Self)

    Performs copy-assignment from source. Read more
    source§

    impl<__T0: Debug> Debug for ErrorSnafu<__T0>

    source§

    fn fmt(&self, f: &mut Formatter<'_>) -> Result

    Formats the value using the given formatter. Read more
    source§

    impl<__T0> IntoError<QueryError> for ErrorSnafu<__T0>
    where QueryError: Error + ErrorCompat, - __T0: Into<String>,

    source§

    type Source = NoneError

    The underlying error
    source§

    fn into_error(self, error: Self::Source) -> QueryError

    Combine the information to produce the error
    source§

    impl<__T0: Copy> Copy for ErrorSnafu<__T0>

    Auto Trait Implementations§

    §

    impl<__T0> Freeze for ErrorSnafu<__T0>
    where + __T0: Into<String>,

    source§

    type Source = NoneError

    The underlying error
    source§

    fn into_error(self, error: Self::Source) -> QueryError

    Combine the information to produce the error
    source§

    impl<__T0: Copy> Copy for ErrorSnafu<__T0>

    Auto Trait Implementations§

    §

    impl<__T0> Freeze for ErrorSnafu<__T0>
    where __T0: Freeze,

    §

    impl<__T0> RefUnwindSafe for ErrorSnafu<__T0>
    where __T0: RefUnwindSafe,

    §

    impl<__T0> Send for ErrorSnafu<__T0>
    where __T0: Send,

    §

    impl<__T0> Sync for ErrorSnafu<__T0>
    where diff --git a/hotshot_query_service/struct.MissingSnafu.html b/hotshot_query_service/struct.MissingSnafu.html index 7a55c9228..74d9a09ee 100644 --- a/hotshot_query_service/struct.MissingSnafu.html +++ b/hotshot_query_service/struct.MissingSnafu.html @@ -1,8 +1,8 @@ -MissingSnafu in hotshot_query_service - Rust

    Struct hotshot_query_service::MissingSnafu

    source ·
    pub struct MissingSnafu;
    Expand description

    SNAFU context selector for the QueryError::Missing variant

    -

    Implementations§

    source§

    impl MissingSnafu

    source

    pub fn build(self) -> QueryError

    Consume the selector and return the associated error

    -
    source

    pub fn fail<__T>(self) -> Result<__T, QueryError>

    Consume the selector and return a Result with the associated error

    -

    Trait Implementations§

    source§

    impl Clone for MissingSnafu

    source§

    fn clone(&self) -> MissingSnafu

    Returns a copy of the value. Read more
    1.0.0 · source§

    fn clone_from(&mut self, source: &Self)

    Performs copy-assignment from source. Read more
    source§

    impl Debug for MissingSnafu

    source§

    fn fmt(&self, f: &mut Formatter<'_>) -> Result

    Formats the value using the given formatter. Read more
    source§

    impl IntoError<QueryError> for MissingSnafu
    where - QueryError: Error + ErrorCompat,

    source§

    type Source = NoneError

    The underlying error
    source§

    fn into_error(self, error: Self::Source) -> QueryError

    Combine the information to produce the error
    source§

    impl Copy for MissingSnafu

    Auto Trait Implementations§

    Blanket Implementations§

    source§

    impl<T> Any for T
    where +MissingSnafu in hotshot_query_service - Rust

    Struct hotshot_query_service::MissingSnafu

    source ·
    pub struct MissingSnafu;
    Expand description

    SNAFU context selector for the QueryError::Missing variant

    +

    Implementations§

    source§

    impl MissingSnafu

    source

    pub fn build(self) -> QueryError

    Consume the selector and return the associated error

    +
    source

    pub fn fail<__T>(self) -> Result<__T, QueryError>

    Consume the selector and return a Result with the associated error

    +

    Trait Implementations§

    source§

    impl Clone for MissingSnafu

    source§

    fn clone(&self) -> MissingSnafu

    Returns a copy of the value. Read more
    1.0.0 · source§

    fn clone_from(&mut self, source: &Self)

    Performs copy-assignment from source. Read more
    source§

    impl Debug for MissingSnafu

    source§

    fn fmt(&self, f: &mut Formatter<'_>) -> Result

    Formats the value using the given formatter. Read more
    source§

    impl IntoError<QueryError> for MissingSnafu
    where + QueryError: Error + ErrorCompat,

    source§

    type Source = NoneError

    The underlying error
    source§

    fn into_error(self, error: Self::Source) -> QueryError

    Combine the information to produce the error
    source§

    impl Copy for MissingSnafu

    Auto Trait Implementations§

    Blanket Implementations§

    source§

    impl<T> Any for T
    where T: 'static + ?Sized,

    source§

    fn type_id(&self) -> TypeId

    Gets the TypeId of self. Read more
    §

    impl<T> ArchivePointee for T

    §

    type ArchivedMetadata = ()

    The archived version of the pointer metadata for this type.
    §

    fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata

    Converts some archived metadata to the pointer metadata for itself.
    §

    impl<'a, T, E> AsTaggedExplicit<'a, E> for T
    where diff --git a/hotshot_query_service/struct.NotFoundSnafu.html b/hotshot_query_service/struct.NotFoundSnafu.html index da565a585..c0ff10f9a 100644 --- a/hotshot_query_service/struct.NotFoundSnafu.html +++ b/hotshot_query_service/struct.NotFoundSnafu.html @@ -1,8 +1,8 @@ -NotFoundSnafu in hotshot_query_service - Rust

    Struct hotshot_query_service::NotFoundSnafu

    source ·
    pub struct NotFoundSnafu;
    Expand description

    SNAFU context selector for the QueryError::NotFound variant

    -

    Implementations§

    source§

    impl NotFoundSnafu

    source

    pub fn build(self) -> QueryError

    Consume the selector and return the associated error

    -
    source

    pub fn fail<__T>(self) -> Result<__T, QueryError>

    Consume the selector and return a Result with the associated error

    -

    Trait Implementations§

    source§

    impl Clone for NotFoundSnafu

    source§

    fn clone(&self) -> NotFoundSnafu

    Returns a copy of the value. Read more
    1.0.0 · source§

    fn clone_from(&mut self, source: &Self)

    Performs copy-assignment from source. Read more
    source§

    impl Debug for NotFoundSnafu

    source§

    fn fmt(&self, f: &mut Formatter<'_>) -> Result

    Formats the value using the given formatter. Read more
    source§

    impl IntoError<QueryError> for NotFoundSnafu
    where - QueryError: Error + ErrorCompat,

    source§

    type Source = NoneError

    The underlying error
    source§

    fn into_error(self, error: Self::Source) -> QueryError

    Combine the information to produce the error
    source§

    impl Copy for NotFoundSnafu

    Auto Trait Implementations§

    Blanket Implementations§

    source§

    impl<T> Any for T
    where +NotFoundSnafu in hotshot_query_service - Rust

    Struct hotshot_query_service::NotFoundSnafu

    source ·
    pub struct NotFoundSnafu;
    Expand description

    SNAFU context selector for the QueryError::NotFound variant

    +

    Implementations§

    source§

    impl NotFoundSnafu

    source

    pub fn build(self) -> QueryError

    Consume the selector and return the associated error

    +
    source

    pub fn fail<__T>(self) -> Result<__T, QueryError>

    Consume the selector and return a Result with the associated error

    +

    Trait Implementations§

    source§

    impl Clone for NotFoundSnafu

    source§

    fn clone(&self) -> NotFoundSnafu

    Returns a copy of the value. Read more
    1.0.0 · source§

    fn clone_from(&mut self, source: &Self)

    Performs copy-assignment from source. Read more
    source§

    impl Debug for NotFoundSnafu

    source§

    fn fmt(&self, f: &mut Formatter<'_>) -> Result

    Formats the value using the given formatter. Read more
    source§

    impl IntoError<QueryError> for NotFoundSnafu
    where + QueryError: Error + ErrorCompat,

    source§

    type Source = NoneError

    The underlying error
    source§

    fn into_error(self, error: Self::Source) -> QueryError

    Combine the information to produce the error
    source§

    impl Copy for NotFoundSnafu

    Auto Trait Implementations§

    Blanket Implementations§

    source§

    impl<T> Any for T
    where T: 'static + ?Sized,

    source§

    fn type_id(&self) -> TypeId

    Gets the TypeId of self. Read more
    §

    impl<T> ArchivePointee for T

    §

    type ArchivedMetadata = ()

    The archived version of the pointer metadata for this type.
    §

    fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata

    Converts some archived metadata to the pointer metadata for itself.
    §

    impl<'a, T, E> AsTaggedExplicit<'a, E> for T
    where diff --git a/hotshot_query_service/struct.Options.html b/hotshot_query_service/struct.Options.html index 9cb08794b..1392fef6e 100644 --- a/hotshot_query_service/struct.Options.html +++ b/hotshot_query_service/struct.Options.html @@ -1,9 +1,9 @@ -Options in hotshot_query_service - Rust

    Struct hotshot_query_service::Options

    source ·
    pub struct Options {
    +Options in hotshot_query_service - Rust

    Struct hotshot_query_service::Options

    source ·
    pub struct Options {
         pub availability: Options,
         pub node: Options,
         pub status: Options,
         pub port: u16,
    -}

    Fields§

    §availability: Options§node: Options§status: Options§port: u16

    Trait Implementations§

    source§

    impl Default for Options

    source§

    fn default() -> Options

    Returns the “default value” for a type. Read more

    Auto Trait Implementations§

    Blanket Implementations§

    source§

    impl<T> Any for T
    where +}

    Fields§

    §availability: Options§node: Options§status: Options§port: u16

    Trait Implementations§

    source§

    impl Default for Options

    source§

    fn default() -> Options

    Returns the “default value” for a type. Read more

    Auto Trait Implementations§

    Blanket Implementations§

    source§

    impl<T> Any for T
    where T: 'static + ?Sized,

    source§

    fn type_id(&self) -> TypeId

    Gets the TypeId of self. Read more
    §

    impl<T> ArchivePointee for T

    §

    type ArchivedMetadata = ()

    The archived version of the pointer metadata for this type.
    §

    fn pointer_metadata( _: &<T as ArchivePointee>::ArchivedMetadata, ) -> <T as Pointee>::Metadata

    Converts some archived metadata to the pointer metadata for itself.
    §

    impl<'a, T, E> AsTaggedExplicit<'a, E> for T
    where diff --git a/hotshot_query_service/testing/consensus/trait.DataSourceLifeCycle.html b/hotshot_query_service/testing/consensus/trait.DataSourceLifeCycle.html index 0f4cc8236..58606b38e 100644 --- a/hotshot_query_service/testing/consensus/trait.DataSourceLifeCycle.html +++ b/hotshot_query_service/testing/consensus/trait.DataSourceLifeCycle.html @@ -60,7 +60,7 @@ ) -> Pin<Box<dyn Future<Output = ()> + Send + 'async_trait>>
    where Self: 'async_trait, 'life0: 'async_trait,

    Setup runs after setting up the network but before starting a test.

    -

    Object Safety§

    This trait is not object safe.

    Implementors§

    Object Safety§

    This trait is not object safe.

    Implementors§

    \ No newline at end of file + U: Clone + Default + Send + Sync + 'static,

    source§

    impl<P: AvailabilityProvider<MockTypes> + Default> DataSourceLifeCycle for FileSystemDataSource<MockTypes, P>

    source§

    impl<P: AvailabilityProvider<MockTypes> + Default> DataSourceLifeCycle for SqlDataSource<MockTypes, P>

    \ No newline at end of file diff --git a/hotshot_query_service/testing/mocks/struct.MockTypes.html b/hotshot_query_service/testing/mocks/struct.MockTypes.html index a060ad03f..85a7a0b99 100644 --- a/hotshot_query_service/testing/mocks/struct.MockTypes.html +++ b/hotshot_query_service/testing/mocks/struct.MockTypes.html @@ -1,60 +1,60 @@ -MockTypes in hotshot_query_service::testing::mocks - Rust

    Struct hotshot_query_service::testing::mocks::MockTypes

    source ·
    pub struct MockTypes;

    Trait Implementations§

    source§

    impl AvailabilityDataSource<MockTypes> for DataSource

    source§

    type LeafRange<R> = Pin<Box<dyn Stream<Item = Fetch<LeafQueryData<MockTypes>>> + Send>> +MockTypes in hotshot_query_service::testing::mocks - Rust

    Struct hotshot_query_service::testing::mocks::MockTypes

    source ·
    pub struct MockTypes;

    Trait Implementations§

    source§

    impl AvailabilityDataSource<MockTypes> for DataSource

    source§

    type LeafRange<R> = Pin<Box<dyn Stream<Item = Fetch<LeafQueryData<MockTypes>>> + Send>> where - R: RangeBounds<usize> + Send

    source§

    type BlockRange<R> = Pin<Box<dyn Stream<Item = Fetch<BlockQueryData<MockTypes>>> + Send>> + R: RangeBounds<usize> + Send

    source§

    type BlockRange<R> = Pin<Box<dyn Stream<Item = Fetch<BlockQueryData<MockTypes>>> + Send>> where - R: RangeBounds<usize> + Send

    source§

    type PayloadRange<R> = Pin<Box<dyn Stream<Item = Fetch<PayloadQueryData<MockTypes>>> + Send>> + R: RangeBounds<usize> + Send

    source§

    type PayloadRange<R> = Pin<Box<dyn Stream<Item = Fetch<PayloadQueryData<MockTypes>>> + Send>> where - R: RangeBounds<usize> + Send

    source§

    type VidCommonRange<R> = Pin<Box<dyn Stream<Item = Fetch<VidCommonQueryData<MockTypes>>> + Send>> + R: RangeBounds<usize> + Send

    source§

    type VidCommonRange<R> = Pin<Box<dyn Stream<Item = Fetch<VidCommonQueryData<MockTypes>>> + Send>> where - R: RangeBounds<usize> + Send

    source§

    fn get_leaf<'life0, 'async_trait, ID>( + R: RangeBounds<usize> + Send

    source§

    fn get_leaf<'life0, 'async_trait, ID>( &'life0 self, id: ID, ) -> Pin<Box<dyn Future<Output = Fetch<LeafQueryData<MockTypes>>> + Send + 'async_trait>>
    where ID: Into<LeafId<MockTypes>> + Send + Sync + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

    source§

    fn get_block<'life0, 'async_trait, ID>( + 'life0: 'async_trait,

    source§

    fn get_block<'life0, 'async_trait, ID>( &'life0 self, id: ID, ) -> Pin<Box<dyn Future<Output = Fetch<BlockQueryData<MockTypes>>> + Send + 'async_trait>>
    where ID: Into<BlockId<MockTypes>> + Send + Sync + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

    source§

    fn get_payload<'life0, 'async_trait, ID>( + 'life0: 'async_trait,

    source§

    fn get_payload<'life0, 'async_trait, ID>( &'life0 self, id: ID, ) -> Pin<Box<dyn Future<Output = Fetch<PayloadQueryData<MockTypes>>> + Send + 'async_trait>>
    where ID: Into<BlockId<MockTypes>> + Send + Sync + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

    source§

    fn get_vid_common<'life0, 'async_trait, ID>( + 'life0: 'async_trait,

    source§

    fn get_vid_common<'life0, 'async_trait, ID>( &'life0 self, id: ID, ) -> Pin<Box<dyn Future<Output = Fetch<VidCommonQueryData<MockTypes>>> + Send + 'async_trait>>
    where ID: Into<BlockId<MockTypes>> + Send + Sync + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

    source§

    fn get_leaf_range<'life0, 'async_trait, R>( + 'life0: 'async_trait,

    source§

    fn get_leaf_range<'life0, 'async_trait, R>( &'life0 self, range: R, ) -> Pin<Box<dyn Future<Output = Self::LeafRange<R>> + Send + 'async_trait>>
    where R: RangeBounds<usize> + Send + 'static + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

    source§

    fn get_block_range<'life0, 'async_trait, R>( + 'life0: 'async_trait,

    source§

    fn get_block_range<'life0, 'async_trait, R>( &'life0 self, range: R, ) -> Pin<Box<dyn Future<Output = Self::BlockRange<R>> + Send + 'async_trait>>
    where R: RangeBounds<usize> + Send + 'static + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

    source§

    fn get_payload_range<'life0, 'async_trait, R>( + 'life0: 'async_trait,

    source§

    fn get_payload_range<'life0, 'async_trait, R>( &'life0 self, range: R, ) -> Pin<Box<dyn Future<Output = Self::PayloadRange<R>> + Send + 'async_trait>>
    where R: RangeBounds<usize> + Send + 'static + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

    source§

    fn get_vid_common_range<'life0, 'async_trait, R>( + 'life0: 'async_trait,

    source§

    fn get_vid_common_range<'life0, 'async_trait, R>( &'life0 self, range: R, ) -> Pin<Box<dyn Future<Output = Self::VidCommonRange<R>> + Send + 'async_trait>>
    where R: RangeBounds<usize> + Send + 'static + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

    source§

    fn get_transaction<'life0, 'async_trait>( + 'life0: 'async_trait,

    source§

    fn get_transaction<'life0, 'async_trait>( &'life0 self, hash: TransactionHash<MockTypes>, ) -> Pin<Box<dyn Future<Output = Fetch<TransactionQueryData<MockTypes>>> + Send + 'async_trait>>
    where @@ -96,58 +96,58 @@ &mut self, key: Self::Key, proof: &MerkleProof<Self::Entry, Self::Key, Self::T, 8>, -) -> Result<()>

    Insert a forgotten path into the tree.
    source§

    impl NodeDataSource<MockTypes> for DataSource

    source§

    fn block_height<'life0, 'async_trait>( +) -> Result<()>

    Insert a forgotten path into the tree.
    source§

    impl NodeDataSource<MockTypes> for DataSource

    source§

    fn block_height<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
    where Self: 'async_trait, - 'life0: 'async_trait,

    source§

    fn count_transactions<'life0, 'async_trait>( + 'life0: 'async_trait,

    source§

    fn count_transactions<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
    where Self: 'async_trait, - 'life0: 'async_trait,

    source§

    fn payload_size<'life0, 'async_trait>( + 'life0: 'async_trait,

    source§

    fn payload_size<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
    where Self: 'async_trait, - 'life0: 'async_trait,

    source§

    fn vid_share<'life0, 'async_trait, ID>( + 'life0: 'async_trait,

    source§

    fn vid_share<'life0, 'async_trait, ID>( &'life0 self, id: ID, ) -> Pin<Box<dyn Future<Output = QueryResult<VidShare>> + Send + 'async_trait>>
    where ID: Into<BlockId<MockTypes>> + Send + Sync + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

    source§

    fn sync_status<'life0, 'async_trait>( + 'life0: 'async_trait,

    source§

    fn sync_status<'life0, 'async_trait>( &'life0 self, ) -> Pin<Box<dyn Future<Output = QueryResult<SyncStatus>> + Send + 'async_trait>>
    where Self: 'async_trait, - 'life0: 'async_trait,

    Search the database for missing objects and generate a report.
    source§

    fn get_header_window<'life0, 'async_trait>( + 'life0: 'async_trait,

    Search the database for missing objects and generate a report.
    source§

    fn get_header_window<'life0, 'async_trait>( &'life0 self, start: impl 'async_trait + Into<WindowStart<MockTypes>> + Send + Sync, end: u64, ) -> Pin<Box<dyn Future<Output = QueryResult<TimeWindowQueryData<Header<MockTypes>>>> + Send + 'async_trait>>
    where Self: 'async_trait, - 'life0: 'async_trait,

    source§

    impl NodeImplementation<MockTypes> for MockNodeImpl

    source§

    type Network = MemoryNetwork<VerKey>

    The underlying network type
    source§

    type Storage = TestStorage<MockTypes>

    Storage for DA layer interactions
    source§

    type AuctionResultsProvider = TestAuctionResultsProvider<MockTypes>

    The auction results type for Solver interactions
    source§

    impl<'a, T> NodeStorage<MockTypes> for Transaction<'a, T>
    where - T: NodeStorage<MockTypes> + Send,

    source§

    fn block_height<'life0, 'async_trait>( + 'life0: 'async_trait,

    source§

    impl NodeImplementation<MockTypes> for MockNodeImpl

    source§

    type Network = MemoryNetwork<VerKey>

    The underlying network type
    source§

    type Storage = TestStorage<MockTypes>

    Storage for DA layer interactions
    source§

    type AuctionResultsProvider = TestAuctionResultsProvider<MockTypes>

    The auction results type for Solver interactions
    source§

    impl<'a, T> NodeStorage<MockTypes> for Transaction<'a, T>
    where + T: NodeStorage<MockTypes> + Send,

    source§

    fn block_height<'life0, 'async_trait>( &'life0 mut self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
    where Self: 'async_trait, - 'life0: 'async_trait,

    source§

    fn count_transactions<'life0, 'async_trait>( + 'life0: 'async_trait,

    source§

    fn count_transactions<'life0, 'async_trait>( &'life0 mut self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
    where Self: 'async_trait, - 'life0: 'async_trait,

    source§

    fn payload_size<'life0, 'async_trait>( + 'life0: 'async_trait,

    source§

    fn payload_size<'life0, 'async_trait>( &'life0 mut self, ) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
    where Self: 'async_trait, - 'life0: 'async_trait,

    source§

    fn vid_share<'life0, 'async_trait, ID>( + 'life0: 'async_trait,

    source§

    fn vid_share<'life0, 'async_trait, ID>( &'life0 mut self, id: ID, ) -> Pin<Box<dyn Future<Output = QueryResult<VidShare>> + Send + 'async_trait>>
    where ID: Into<BlockId<MockTypes>> + Send + Sync + 'async_trait, Self: 'async_trait, - 'life0: 'async_trait,

    source§

    fn sync_status<'life0, 'async_trait>( + 'life0: 'async_trait,

    source§

    fn sync_status<'life0, 'async_trait>( &'life0 mut self, ) -> Pin<Box<dyn Future<Output = QueryResult<SyncStatus>> + Send + 'async_trait>>
    where Self: 'async_trait, - 'life0: 'async_trait,

    Search the database for missing objects and generate a report.
    source§

    fn get_header_window<'life0, 'async_trait>( + 'life0: 'async_trait,

    Search the database for missing objects and generate a report.
    source§

    fn get_header_window<'life0, 'async_trait>( &'life0 mut self, start: impl 'async_trait + Into<WindowStart<MockTypes>> + Send + Sync, end: u64, @@ -162,18 +162,18 @@ <= operator. Read more

    1.0.0 · source§

    fn gt(&self, other: &Rhs) -> bool

    Tests greater than (for self and other) and is used by the > operator. Read more
    1.0.0 · source§

    fn ge(&self, other: &Rhs) -> bool

    Tests greater than or equal to (for self and other) and is used by the >= operator. Read more
    source§

    impl QueryableHeader<MockTypes> for MockHeader

    source§

    fn timestamp(&self) -> u64

    source§

    impl Serialize for MockTypes

    source§

    fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
    where - __S: Serializer,

    Serialize this value into the given Serde serializer. Read more
    source§

    impl<'a, T> UpdateAvailabilityData<MockTypes> for Transaction<'a, T>

    source§

    fn insert_leaf<'life0, 'async_trait>( + __S: Serializer,

    Serialize this value into the given Serde serializer. Read more
    source§

    impl<'a, T> UpdateAvailabilityData<MockTypes> for Transaction<'a, T>

    source§

    fn insert_leaf<'life0, 'async_trait>( &'life0 mut self, leaf: LeafQueryData<MockTypes>, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
    where Self: 'async_trait, - 'life0: 'async_trait,

    source§

    fn insert_block<'life0, 'async_trait>( + 'life0: 'async_trait,

    source§

    fn insert_block<'life0, 'async_trait>( &'life0 mut self, block: BlockQueryData<MockTypes>, ) -> Pin<Box<dyn Future<Output = Result<()>> + Send + 'async_trait>>
    where Self: 'async_trait, - 'life0: 'async_trait,

    source§

    fn insert_vid<'life0, 'async_trait>( + 'life0: 'async_trait,

    source§

    fn insert_vid<'life0, 'async_trait>( &'life0 mut self, common: VidCommonQueryData<MockTypes>, share: Option<VidShare>, diff --git a/hotshot_query_service/type.Header.html b/hotshot_query_service/type.Header.html index 077ff97f7..4c3e0213d 100644 --- a/hotshot_query_service/type.Header.html +++ b/hotshot_query_service/type.Header.html @@ -1 +1 @@ -Header in hotshot_query_service - Rust

    Type Alias hotshot_query_service::Header

    source ·
    pub type Header<Types> = <Types as NodeType>::BlockHeader;
    \ No newline at end of file +Header in hotshot_query_service - Rust

    Type Alias hotshot_query_service::Header

    source ·
    pub type Header<Types> = <Types as NodeType>::BlockHeader;
    \ No newline at end of file diff --git a/hotshot_query_service/type.Metadata.html b/hotshot_query_service/type.Metadata.html index 4af30ca7d..4f090deb9 100644 --- a/hotshot_query_service/type.Metadata.html +++ b/hotshot_query_service/type.Metadata.html @@ -1 +1 @@ -Metadata in hotshot_query_service - Rust

    Type Alias hotshot_query_service::Metadata

    source ·
    pub type Metadata<Types> = <Payload<Types> as BlockPayload<Types>>::Metadata;
    \ No newline at end of file +Metadata in hotshot_query_service - Rust

    Type Alias hotshot_query_service::Metadata

    source ·
    pub type Metadata<Types> = <Payload<Types> as BlockPayload<Types>>::Metadata;
    \ No newline at end of file diff --git a/hotshot_query_service/type.Payload.html b/hotshot_query_service/type.Payload.html index 1024261d7..1f49af5a7 100644 --- a/hotshot_query_service/type.Payload.html +++ b/hotshot_query_service/type.Payload.html @@ -1 +1 @@ -Payload in hotshot_query_service - Rust

    Type Alias hotshot_query_service::Payload

    source ·
    pub type Payload<Types> = <Types as NodeType>::BlockPayload;
    \ No newline at end of file +Payload in hotshot_query_service - Rust

    Type Alias hotshot_query_service::Payload

    source ·
    pub type Payload<Types> = <Types as NodeType>::BlockPayload;
    \ No newline at end of file diff --git a/hotshot_query_service/type.QueryResult.html b/hotshot_query_service/type.QueryResult.html index 1aaf94247..96c24e624 100644 --- a/hotshot_query_service/type.QueryResult.html +++ b/hotshot_query_service/type.QueryResult.html @@ -1,4 +1,4 @@ -QueryResult in hotshot_query_service - Rust

    Type Alias hotshot_query_service::QueryResult

    source ·
    pub type QueryResult<T> = Result<T, QueryError>;

    Aliased Type§

    enum QueryResult<T> {
    +QueryResult in hotshot_query_service - Rust

    Type Alias hotshot_query_service::QueryResult

    source ·
    pub type QueryResult<T> = Result<T, QueryError>;

    Aliased Type§

    enum QueryResult<T> {
         Ok(T),
         Err(QueryError),
     }

    Variants§

    §1.0.0

    Ok(T)

    Contains the success value

    diff --git a/hotshot_query_service/type.SignatureKey.html b/hotshot_query_service/type.SignatureKey.html index 8990e9641..18a9dacbc 100644 --- a/hotshot_query_service/type.SignatureKey.html +++ b/hotshot_query_service/type.SignatureKey.html @@ -1 +1 @@ -SignatureKey in hotshot_query_service - Rust

    Type Alias hotshot_query_service::SignatureKey

    source ·
    pub type SignatureKey<Types> = <Types as NodeType>::SignatureKey;
    \ No newline at end of file +SignatureKey in hotshot_query_service - Rust

    Type Alias hotshot_query_service::SignatureKey

    source ·
    pub type SignatureKey<Types> = <Types as NodeType>::SignatureKey;
    \ No newline at end of file diff --git a/hotshot_query_service/type.Transaction.html b/hotshot_query_service/type.Transaction.html index ec929febc..f28a96837 100644 --- a/hotshot_query_service/type.Transaction.html +++ b/hotshot_query_service/type.Transaction.html @@ -1,2 +1,2 @@ -Transaction in hotshot_query_service - Rust

    Type Alias hotshot_query_service::Transaction

    source ·
    pub type Transaction<Types> = <Payload<Types> as BlockPayload<Types>>::Transaction;
    Expand description

    Item within a Payload.

    +Transaction in hotshot_query_service - Rust

    Type Alias hotshot_query_service::Transaction

    source ·
    pub type Transaction<Types> = <Payload<Types> as BlockPayload<Types>>::Transaction;
    Expand description

    Item within a Payload.

    \ No newline at end of file diff --git a/search-index.js b/search-index.js index d9441c2b3..790f19fa2 100644 --- a/search-index.js +++ b/search-index.js @@ -1,4 +1,4 @@ -var searchIndex = new Map(JSON.parse('[["hotshot_query_service",{"t":"FPPPGPFPIFPIPFPPFPFIGIKIPIIIINNNNNNNNNNNNNCONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMNNCNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNCNNNNCNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNQNNNNNNNNQQQQQNNNNNNNNNNNNNNNNNNNNNNNCOCCONNNNNNNNNNONHNNNNNCNNOCCNNNNNNNNNNNNNNNNNNNNNNNNNNMNNNNNNNNNCNNNNNNNNNNOOOOOOOOKIGFRFPFGGPFPFPFPPRFPFRIGFRPPFPFRPKKPPFIIIIRFFKFRNNNNNNNNNNNNNNNNNONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNHNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNONNNNNONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMMNNMMMMMMMNNNNNNNNNNNNNNNNNNNONNNONNNNNNNNNNNNNNNNNNNMMMNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMNNNNNNNNNNNNNNNNNNNNOMNNONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNONOOONNNNNNNNNNNNNNONNNNNNNNMNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNOOOOOOOOEFEEFREKRKKNNNNCNNNNNNNNNNNNNMNNNNNNNNNNNNNNCNNNNCNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNCNCNNNNMNNNMNCCCNNNNNNNNNMNNNNMNHHKFFFFNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNIENNNNNNNNNHHHHHHHHHIIFFFIENNNNNNQNCEHKKEKKEKEMMCMMMMMMMMMMMMMMMMMMMCMCCMMFFKFNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMNNNNNNNNNNNNNNNNNNNFFNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNCNNNNNNNNNNNNGPPPPPPGGNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNOKKRFKNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNRRRFRKRIFKKFTKFFIIFRFRFFRFRKRTRRFNNNNNNNNNNMNNMNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNHNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMNNMNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNQQNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMNNHNHNNNNNNNNNNNNNNDNNNCNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNFFNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNIRPFFGIPFFFPPPGFGPPPKKFFFKFPPPFPGPPGPFPGPGPGPGPFPPPPPFPPPPPPFRRPIRPPPPPPPFFPPPFGPPFFGIPFFFGPPPPPPPIRPNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNOOOOOOOOOONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNOOOONHNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNOOMMOOONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNOMMMMMMOOOONNNNNNNNNNNNNNOOOOONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNOOONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMMNOOOOOOOONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMOOOMOOOONNNNNNNNNNNNNNNNNNNNNNNNNNNNNOOONNNNNNNNNNNNNNNNOOOOOOONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNOOOONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNKFKEENNNNNNNNNNNNNNNNNCCMMNNNNNNNNFFKFFNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNFFKRFNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNPRPRRGPRKKKFPPGRKNNONNNNNNNNNNNNNNNNNNNNHNNNNNNNNNNNNNNNNNNNONNNNNNNNNNNMMNNNMNNNNMMNNNNNNNNNNNMNMNNNNNMNNNNNNNNNNNNOOOOFFFFFFGPPPFFNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNOOOOEEPFGPPKFPFPFPFPFFPFGNNNNNNNNNONNNNOMNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMNNHNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNONNNNNNNNNNONNNNNNNNNNNNNNNNNNNNNNNNNNNNMNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNOOOOOONMNNNNNNNNNNOONNNNONOMNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMNNNNNNNNNNOOOOOOOOOOGPFPKKNONNNNMNNNNNNNNNNNHNNNNNNNNNNNNONNNNNNNNNNNNNNMNNMNNNNNNNNNNNNNNNOOFFNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNCCHHKIFISRKNNMMNNNNNNNNNMNNNNNNNNMNNNNNNNNNNIIIIIIFIIIIFFNNNOONNNNNNONNNNNNNNNNNNNONNONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNONNNNOHNNNNONNNONONNNONNONNNNONNNNNNNNNNOOONNNKM","n":["ApiState","Availability","Custom","Err","Error","","ErrorSnafu","Explorer","Header","Leaf","MerklizedState","Metadata","Missing","MissingSnafu","Node","NotFound","NotFoundSnafu","Ok","Options","Payload","QueryError","QueryResult","Resolvable","SignatureKey","Status","Transaction","VidCommitment","VidCommon","VidShare","__clone_box","","","","","","","as_error","","as_error_source","","","","availability","","backtrace","","block_header","block_header_mut","block_payload","borrow","","","","","","","","borrow_mut","","","","","","","","build","","","catch_all","cause","","clone","","","","","","","clone_into","","","","","","","clone_to_uninit","","","","","","","commit","","commitment","","create_random_transaction","data_source","default","deref","","","","","","","","","deref_mut","","","","","","","","description","","deserialize","","","","","","","","","","","drop","","","","","","","","eq","equivalent","","","","explorer","extends_upgrade","fail","","","fetching","fill_block_payload","fill_block_payload_unchecked","fmt","","","","","","","","","","from","","","","","","","","","","","","","","","","","","","from_fd","from_filelike","from_into_filelike","from_into_socketlike","from_quorum_proposal","from_socketlike","genesis","get_hash","hash","header","","","height","in_current_span","","include_migrations","init","","","","","","","","instantiate_availability_tests","instantiate_data_source_tests","instantiate_node_tests","instantiate_persistence_tests","instantiate_status_tests","internal","into","","","","","","","","into_error","","","justify_qc","layout_raw","","","","","","","","load","","merklized_state","message","metrics","node","","parent_commitment","payload_commitment","pointer_metadata","","","","","","","","port","read","run_standalone_service","serialize","","","source","","status","","","","task","testing","to_owned","","","","","","","to_string","","","try_from","","","","","","","","try_into","","","","","","","","try_resolve","","type_id","","","","","","","","types","upgrade_certificate","view_number","vzip","","","","","","","","message","source","","","","","status","message","AvailabilityDataSource","BlockHash","BlockId","BlockQueryData","BlockRange","BlockSummaryQueryData","Custom","CustomSnafu","Error","Fetch","FetchBlock","FetchBlockSnafu","FetchLeaf","FetchLeafSnafu","FetchTransaction","FetchTransactionSnafu","Hash","","InclusionProof","InconsistentLeafError","InvalidTransactionIndex","InvalidTransactionIndexSnafu","Iter","LeafHash","LeafId","LeafQueryData","LeafRange","Number","","Options","PayloadHash","PayloadQueryData","PayloadRange","Pending","QueryableHeader","QueryablePayload","Ready","Request","RequestSnafu","Timestamp","TransactionHash","TransactionInclusionProof","TransactionIndex","","TransactionQueryData","TransactionSummaryQueryData","UpdateAvailabilityData","VidCommonQueryData","VidCommonRange","__clone_box","","","","","","","","","","","","","","","","","api_path","as_error","","as_error_source","","","","backtrace","","block_hash","","","","block_height","borrow","","","","","","","","","","","","","","","","","","","borrow_mut","","","","","","","","","","","","","","","","","","","build","","","","","by_hash","","cause","","clone","","","","","","","","","","","","","","","","","clone_into","","","","","","","","","","","","","","","","","clone_to_uninit","","","","","","","","","","","","","","","","","cmp","","common","compare","","context","data","default","define_api","deref","","","","","","","","","","","","","","","","","","","deref_mut","","","","","","","","","","","","","","","","","","","description","","deserialize","","","","","","","","","","","","","","","","","","","","","","","","","","","drop","","","","","","","","","","","","","","","","","","","enumerate","","","eq","","","","","","","","","equivalent","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","extensions","fail","","","","","fetch_timeout","fmt","","","","","","","","","","","","","","","","","","","","","from","","","","","","","","","","","","","","","","","","","","","","","","","","","from_row","","","","genesis","","","","get_block","get_block_range","get_hash","","get_leaf","get_leaf_range","get_payload","get_payload_range","get_transaction","get_vid_common","get_vid_common_range","hash","","","","","","","header","","","","","","","height","","","","","","in_current_span","","index","","init","","","","","","","","","","","","","","","","","","","insert_block","insert_leaf","insert_vid","internal","into","","","","","","","","","","","","","","","","","","","into_error","","","","","","into_future","is_empty","","","iter","layout_raw","","","","","","","","","","","","","","","","","","","leaf","","len","","map","message","metadata","new","","","nth","","nth_transaction","","nth_transaction_with_proof","","num_transactions","","partial_cmp","","payload","payload_hash","","","pointer_metadata","","","","","","","","","","","","","","","","","","","proof","","","qc","qc_leaf","resolve","resource","","","serialize","","","","","","","","size","","","source","","status","","subscribe_blocks","","subscribe_leaves","","subscribe_payloads","","subscribe_vid_common","","timestamp","to_owned","","","","","","","","","","","","","","","","","to_string","","","","transaction","","","","transaction_by_hash","","","transaction_by_hash_with_proof","","transaction_with_proof","try_from","","","","","","","","","","","","","","","","","","","try_into","","","","","","","","","","","","","","","","","","","try_resolve","type_id","","","","","","","","","","","","","","","","","","","vzip","","","","","","","","","","","","","","","","","","","with_context","with_timeout","height","index","message","resource","","","source","status","AvailabilityProvider","ExtensibleDataSource","FetchingDataSource","FileSystemDataSource","MetricsDataSource","ReadOnly","SqlDataSource","Transaction","","UpdateDataSource","VersionedDataSource","__clone_box","","as_mut","as_ref","availability_tests","block_height","","","borrow","","borrow_mut","","clone","","clone_into","","clone_to_uninit","","commit","connect","","count_transactions","create","","default","deref","","deref_mut","","deserialize","","drop","","fetching","fmt","","from","","fs","get_block","get_block_detail","get_block_range","get_block_summaries","get_explorer_summary","get_header_window","get_last_state_height","get_leaf","get_leaf_range","get_path","get_payload","get_payload_range","get_search_results","get_transaction","get_transaction_detail","get_transaction_summaries","get_vid_common","get_vid_common_range","handle_event","","init","","inner","inner_mut","insert_block","insert_leaf","insert_merkle_nodes","insert_vid","into","","layout_raw","","metrics","","new","node_tests","payload_size","persistence_tests","pointer_metadata","","populate_metrics","","read","","reset","","revert","set_last_state_height","sql","status_tests","storage","sync_status","to_owned","","try_from","","try_into","","type_id","","update","","vid_share","vzip","","write","","test_range","test_update","AvailabilityProvider","Builder","FetchingDataSource","Pruner","Transaction","__clone_box","","as_mut","as_ref","","block_height","","","borrow","","","","borrow_mut","","","","build","builder","clone","","clone_into","","clone_to_uninit","","commit","connect","count_transactions","","create","create_with_store","deref","","","","deref_mut","","","","deserialize","","","","disable_proactive_fetching","drop","","","","fmt","","","from","","","","get_block","","get_block_detail","","get_block_range","","get_block_summaries","","get_explorer_summary","","get_header","get_header_window","","get_last_state_height","","get_leaf","","get_leaf_range","","get_path","","get_payload","","get_payload_range","","get_search_results","","get_transaction","","get_transaction_detail","","get_transaction_summaries","","get_vid_common","","get_vid_common_range","","init","","","","insert_block","insert_leaf","insert_merkle_nodes","insert_vid","into","","","","layout_raw","","","","load_pruned_height","metrics","new","open","open_with_store","payload_size","","pointer_metadata","","","","populate_metrics","read","revert","set_last_state_height","skip_version","sync_status","","to_owned","","try_from","","","","try_into","","","","type_id","","","","update","vid_share","","vzip","","","","with_active_fetch_delay","with_chunk_fetch_delay","with_major_scan_interval","with_major_scan_offset","with_minor_scan_interval","with_proactive_range_chunk_size","with_range_chunk_size","with_rate_limit","with_retry_delay","write","FileSystemDataSource","Transaction","connect","create","","create_with_store","handle_event","open","open_with_store","reset","skip_version","test_counters","test_sync_status","test_timestamp_window","test_vid_monotonicity","test_vid_recovery","test_vid_shares","test_drop_tx","test_reset","test_revert","Builder","Config","Error","Migration","Postgres","SqlDataSource","Transaction","builder","connect","","","create","handle_event","include_migrations","reset","testing","TmpDb","test_metrics","AvailabilityStorage","ExplorerStorage","FileSystemStorage","MerklizedStateHeightStorage","MerklizedStateStorage","NoStorage","NodeStorage","SqlStorage","block_height","count_transactions","fs","get_block","get_block_detail","get_block_range","get_block_summaries","get_explorer_summary","get_header","get_header_window","get_last_state_height","get_leaf","get_leaf_range","get_path","get_payload","get_payload_range","get_search_results","get_transaction","get_transaction_detail","get_transaction_summaries","get_vid_common","get_vid_common_range","no_storage","payload_size","pruning","sql","sync_status","vid_share","FileSystemStorage","FileSystemStorageInner","Revert","Transaction","block_height","borrow","","","borrow_mut","","","commit","","count_transactions","create","create_with_store","deref","","","deref_mut","","","deserialize","","","drop","","","","fmt","","","from","","","get_block","get_block_range","get_header","get_header_window","get_leaf","get_leaf_range","get_payload","get_payload_range","get_transaction","get_vid_common","get_vid_common_range","init","","","insert_block","insert_leaf","insert_vid","into","","","layout_raw","","","open","open_with_store","payload_size","pointer_metadata","","","read","revert","","","skip_version","sync_status","try_from","","","try_into","","","type_id","","","update","vid_share","vzip","","","write","NoStorage","Transaction","__clone_box","block_height","borrow","","borrow_mut","","clone","clone_into","clone_to_uninit","commit","count_transactions","default","deref","","deref_mut","","deserialize","","drop","","fmt","from","","get_block","get_block_range","get_header","get_header_window","get_leaf","get_leaf_range","get_payload","get_payload_range","get_transaction","get_vid_common","get_vid_common_range","init","","insert_block","insert_leaf","insert_vid","into","","layout_raw","","payload_size","pointer_metadata","","read","revert","sync_status","testing","to_owned","try_from","","try_into","","type_id","","update","vid_share","vzip","","write","DataSource","NoStorage","","","Sql","","","Storage","Transaction","__clone_box","block_height","","","borrow","","","borrow_mut","","","clone","clone_into","clone_to_uninit","commit","connect","count_transactions","","create","deref","","","deref_mut","","","deserialize","","","drop","","","fmt","from","","","get_block","get_block_range","get_header_window","","get_leaf","get_leaf_range","get_payload","get_payload_range","get_transaction","get_vid_common","get_vid_common_range","handle_event","init","","","insert_block","insert_leaf","insert_vid","into","","","layout_raw","","","metrics","payload_size","","pointer_metadata","","","populate_metrics","read","reset","revert","setup","sync_status","","to_owned","try_from","","","try_into","","","type_id","","","update","vid_share","","vzip","","","write","fetch_from_port","PruneStorage","PrunedHeightStorage","Pruner","PrunerCfg","PrunerConfig","__clone_box","batch_size","borrow","borrow_mut","clone","clone_into","clone_to_uninit","default","deref","deref_mut","deserialize","drop","fmt","from","get_disk_usage","get_pruning_config","init","interval","into","layout_raw","load_pruned_height","max_usage","minimum_retention","new","pointer_metadata","prune","pruning_threshold","set_pruning_config","target_retention","to_owned","try_from","try_into","type_id","validate","vzip","with_batch_size","with_interval","with_max_usage","with_minimum_retention","with_pruning_threshold","with_target_retention","ArgumentBuffer","Arguments","Column","Config","Connection","Database","","Db","Error","Executor","FixedLengthParams","Migration","NAME","Params","Postgres","Pruner","Query","QueryAs","QueryBuilder","QueryResult","Read","Row","SqlStorage","Sqlite","Statement","Transaction","TransactionManager","TransactionMode","TypeInfo","URL_SCHEMES","Value","ValueRef","Write","__clone_box","","","","applied","applied_on","archive","as_ref","","backtrace","begin","","","bind","","block_height","borrow","","","","","","","","","","","borrow_mut","","","","","","","","","","","bounds_to_where_clause","builder","chain","checksum","cleanup_test","","cleanup_test_dbs","","clone","","","","clone_into","","","","clone_to_uninit","","","","cmp","commit","compare","connect","","connection_timeout","context","count_transactions","create_database","","database","database_exists","","default","","","","","default_migrations","deref","","","","","","","","","","","","","deref_mut","","","","","","","","","","","","","deserialize","","","","","","","","","","","downcast","downcast_mut","downcast_ref","drop","","","","","","","","","","","","drop_database","","eq","equivalent","","","","execute","","execute_many","","","execute_many_with_retries","execute_one","execute_one_with_retries","fetch","","fetch_all","","fetch_many","fetch_one","","fetch_optional","fmt","","","","","","","","","","","","","fmt_value_debug","","force_drop_database","from","","","","","","","","","","","","","","from_str","get_block","get_block_detail","get_block_range","get_block_summaries","get_disk_usage","get_explorer_summary","get_feature_gate","","get_header","get_header_window","get_last_state_height","get_leaf","get_leaf_range","get_path","get_payload","get_payload_range","get_pruning_config","get_search_results","get_transaction","get_transaction_detail","get_transaction_summaries","get_vid_common","get_vid_common_range","header","","header_where_clause","host","idle_connection_timeout","include_dir","include_migrations","init","","","","","","","","","","","insert_block","insert_leaf","insert_merkle_nodes","insert_vid","into","","","","","","","","","","","is","layout_raw","","","","","","","","","","","load_header","load_pruned_height","max_connections","migrations","min_connections","msg","name","new","no_migrations","param_type_for_id","","partial_cmp","password","payload_size","pointer_metadata","","","","","","","","","","","port","prefix","prepare","","prepare_with","prune","pruner_cfg","query","","query_as","","read","reset_schema","return_type_for_id","","revert","root_cause","schema","set_applied","set_last_state_height","set_pruning_config","snapshot","","sql","sqlx","sync_status","test_context","","testing","tls","to_owned","","","","to_string","","try_from","","","","","","","","","","","try_into","","","","","","","","","","","type_id","","","","","","","","","","","unapplied","update","upsert","user","version","vid_share","vzip","","","","","","","","","","","write","TestMerkleTreeMigration","TmpDb","borrow","","borrow_mut","","config","deref","","deref_mut","","deserialize","","drop","","","fmt","from","","host","init","","","into","","layout_raw","","persistent","pointer_metadata","","port","start","stop","try_from","","try_into","","type_id","","vzip","","BalanceAmount","","Block","BlockDetail","BlockDetailResponse","BlockIdentifier","BlockNamespaceId","BlockNotFound","BlockRange","BlockSummary","BlockSummaryResponse","Btc","CryptoEnd","CryptoStart","CurrencyCode","CurrencyMismatchError","Error","Esp","Eth","Eur","ExplorerDataSource","ExplorerHeader","ExplorerHistograms","ExplorerSummary","ExplorerSummaryResponse","ExplorerTransaction","FeeAttribution","FiatCurrencyEnd","FiatCurrencyStart","Gbp","GenesisOverview","GetBlockDetail","GetBlockDetailError","","GetBlockSummaries","GetBlockSummariesError","","GetBlockSummariesRequest","GetExplorerSummary","GetExplorerSummaryError","GetSearchResults","GetSearchResultsError","GetTransactionDetail","GetTransactionDetailError","GetTransactionSummaries","GetTransactionSummariesError","","GetTransactionSummariesRequest","Hash","","Height","HeightAndOffset","IntError","InvalidCurrencyCodeError","InvalidLimit","","InvalidQuery","Jpy","Latest","","MonetaryValue","NamespaceId","","None","ProposerId","","QueryError","","","","","","RollUp","SearchResult","SearchResultResponse","TargetNotFound","","TimeError","Timestamp","TimestampConversionError","TokenEnd","TokenStart","TransactionDetail","TransactionDetailResponse","TransactionIdentifier","TransactionNamespaceId","TransactionNotFound","TransactionRange","TransactionSummariesResponse","TransactionSummary","TransactionSummaryFilter","Unimplemented","","","","","","Usd","WalletAddress","","Xxx","__clone_box","","","","","","","","","","","","","","","","add","as_error","","","","","","","","as_error_source","","","","","","","","","","","","","","","","block_confirmed","block_detail","block_heights","block_reward","block_size","block_summaries","block_time","block_transactions","blocks","","borrow","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","borrow_mut","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","btc","clone","","","","","","","","","","","","","","","","clone_into","","","","","","","","","","","","","","","","clone_to_uninit","","","","","","","","","","","","","","","","cmp","compare","currency","","currency1","currency2","default","define_api","deref","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","deref_mut","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","deserialize","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","drop","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","eq","","","","","","","","","","","","","","equivalent","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","esp","eth","explorer_summary","fee_details","fee_info_account","fee_info_balance","fee_recipient","fees","filter","fmt","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","from","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","from_row","","genesis_overview","get_block_detail","get_block_summaries","get_explorer_summary","get_search_results","get_transaction_detail","get_transaction_summaries","hash","","","","header","","","","","","","","","","","","","","height","","","","histograms","in_current_span","","","","","","","","init","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","into","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","into_resettable","is_crypto","is_fiat","is_token","latest_block","latest_blocks","latest_transactions","layout_raw","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","namespace_id","namespace_ids","new","num_blocks","num_transactions","","","","","offset","","partial_cmp","pointer_metadata","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","proposer_id","","","range","reward_balance","rollups","","search_results","sequencing_fees","serialize","","","","","","","","","","","","","","","","","","","","","","","","","","","","significant_digits","size","","","source","","","","","","","","status","","","","","","","sub","target","","","time","","","","to_owned","","","","","","","","","","","","","","","","to_string","","","","","","","","","","","","","","transaction_detail","transaction_summaries","transactions","","try_from","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","try_into","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","type_id","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","usd","value","vzip","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","Callback","Fetcher","LocalCallback","Provider","Request","__clone_box","borrow","borrow_mut","clone","clone_into","clone_to_uninit","default","deref","deref_mut","deserialize","drop","fmt","from","init","into","layout_raw","pointer_metadata","provider","request","run","","spawn_fetch","to_owned","try_from","try_into","type_id","vzip","with_rate_limit","with_retry_delay","AnyProvider","NoFetching","Provider","QueryServiceProvider","TestProvider","__clone_box","","","","block","borrow","","","","borrow_mut","","","","clone","","","","clone_into","","","","clone_to_uninit","","","","default","","deref","","","","deref_mut","","","","deserialize","","","","drop","","","","fail","fetch","","","","","","","","","fmt","","","","from","","","","init","","","","into","","","","layout_raw","","","","new","","pointer_metadata","","","","to_owned","","","","try_from","","","","try_into","","","","type_id","","","","unblock","unfail","vzip","","","","with_block_provider","with_leaf_provider","with_provider","with_vid_common_provider","LeafRequest","PayloadRequest","Request","Response","VidCommonRequest","__clone_box","","","borrow","","","borrow_mut","","","clone","","","clone_into","","","clone_to_uninit","","","deref","","","deref_mut","","","deserialize","","","drop","","","eq","","","equivalent","","","","","","","","","","","","fmt","","","from","","","","get_hash","","","hash","","","init","","","into","","","layout_raw","","","pointer_metadata","","","to_owned","","","try_from","","","try_into","","","type_id","","","vzip","","","Commit","","Custom","Digest","Entry","Error","Index","Key","MerklizedState","MerklizedStateDataSource","MerklizedStateHeightPersistence","Options","Query","Request","Snapshot","T","UpdateStateData","__clone_box","","api_path","as_error","as_error_source","","backtrace","borrow","","","borrow_mut","","","cause","clone","","clone_into","","clone_to_uninit","","cmp","compare","default","define_api","deref","","","deref_mut","","","description","deserialize","","","","drop","","","eq","equivalent","","","","extensions","fmt","","","","from","","","","","","get_hash","get_last_state_height","get_path","hash","header","","header_state_commitment_field","in_current_span","init","","","insert_merkle_nodes","insert_path","into","","","layout_raw","","","partial_cmp","pointer_metadata","","","serialize","set_last_state_height","source","state_type","status","to_owned","","to_string","","tree_height","try_from","","","try_into","","","type_id","","","vzip","","","message","source","","status","Counter","CounterFamily","Gauge","GaugeFamily","Histogram","HistogramFamily","MetricsError","NoSuchMetric","NoSuchSubgroup","Prometheus","PrometheusMetrics","TextFamily","__clone_box","","","","","","","","add","add_point","as_error","as_error_source","","backtrace","borrow","","","","","","","","","borrow_mut","","","","","","","","","cause","clone","","","","","","","","clone_into","","","","","","","","clone_to_uninit","","","","","","","","counter_family","create","","","","create_counter","create_gauge","create_histogram","create_text","default","deref","","","","","","","","","deref_mut","","","","","","","","","description","deserialize","","","","","","","","","drop","","","","","","","","","export","fmt","","","","","","","","","","from","","","","","","","","","","gauge_family","","get","","","","","get_counter","get_counter_family","get_gauge","get_histogram","get_histogram_family","get_subgroup","header","histogram_family","in_current_span","init","","","","","","","","","into","","","","","","","","","layout_raw","","","","","","","","","mean","pointer_metadata","","","","","","","","","sample_count","set","source","subgroup","sum","text_family","to_owned","","","","","","","","to_string","try_from","","","","","","","","","try_into","","","","","","","","","type_id","","","","","","","","","update","vzip","","","","","","","","","name","namespace","path","source","BlockHash","BlockId","Custom","CustomSnafu","Error","Hash","Height","NodeDataSource","Options","Query","QuerySnafu","QueryVid","QueryVidSnafu","QueryWindow","QueryWindowSnafu","Request","RequestSnafu","SyncStatus","Time","TimeWindowQueryData","WindowStart","__clone_box","","","","","","","","","api_path","as_error","as_error_source","","backtrace","block","block_height","borrow","","","","","","","","","","borrow_mut","","","","","","","","","","build","cause","clone","","","","","","","","","clone_into","","","","","","","","","clone_to_uninit","","","","","","","","","cmp","compare","count_transactions","default","","define_api","deref","","","","","","","","","","deref_mut","","","","","","","","","","description","deserialize","","","","","","","","","","","","","drop","","","","","","","","","","end","eq","","equivalent","","","","","","","","extensions","fail","fmt","","","","","","","","","","from","","","","","","","","","","","","","","","fully_synced","get_hash","get_header_window","hash","header","in_current_span","init","","","","","","","","","","internal","into","","","","","","","","","","into_error","","","","","is_fully_synced","layout_raw","","","","","","","","","","message","missing_blocks","missing_leaves","missing_vid_common","missing_vid_shares","next","partial_cmp","payload_size","pointer_metadata","","","","","","","","","","prev","pruned_height","serialize","","","source","start","status","","sync_status","to_owned","","","","","","","","","to_string","try_from","","","","","","","","","","try_into","","","","","","","","","","type_id","","","","","","","","","","vid_share","vzip","","","","","","","","","","window","block","end","message","source","","","","start","status","Error","Internal","Options","Request","StatusDataSource","UpdateStatusData","__clone_box","api_path","as_error","as_error_source","","backtrace","block_height","borrow","","borrow_mut","","cause","clone","clone_into","clone_to_uninit","consensus_metrics","","default","define_api","deref","","deref_mut","","description","deserialize","","","drop","","elapsed_time_since_last_decide","","extensions","fmt","","from","","","","header","in_current_span","init","","into","","layout_raw","","metrics","pointer_metadata","","populate_metrics","serialize","source","status","success_rate","","to_owned","to_string","try_from","","try_into","","type_id","","vzip","","reason","source","BackgroundTask","Task","__clone_box","borrow","","borrow_mut","","clone","clone_into","clone_to_uninit","deref","","deref_mut","","deserialize","","drop","","","fmt","","from","","init","","into","","join","layout_raw","","pointer_metadata","","spawn","","to_owned","try_from","","try_into","","type_id","","vzip","","consensus","mocks","setup_test","sleep","DataSourceLifeCycle","MockDataSource","MockNetwork","MockSqlDataSource","NUM_NODES","Storage","TestableDataSource","borrow","borrow_mut","connect","create","data_source","data_source_index","deref","deref_mut","deserialize","drop","","from","handle","handle_event","init","","init_with_config","into","layout_raw","num_nodes","pointer_metadata","proposer","reset","setup","shut_down","spawn","start","storage","submit_transaction","try_from","try_into","type_id","vzip","MockAuctionResults","MockBase","MockHeader","MockMembership","MockMerkleTree","MockNetwork","MockNodeImpl","MockPayload","MockQuorumProposal","MockStorage","MockTransaction","MockTypes","MockVersions","__clone_box","","","block_header","block_number","borrow","","","borrow_mut","","","builder_commitment","clone","","","clone_into","","","clone_to_uninit","","","cmp","","compare","","decided_upgrade_certificate","default","","delay_config","deref","","","deref_mut","","","deserialize","","","","","drop","","","eq","","equivalent","","","","","","","","fee_info_account","fee_info_balance","fmt","","","from","","","get_hash","","hash","","header_state_commitment_field","height","init","","","insert_path","into","","","iter","justify_qc","layout_raw","","","len","metadata","mock_transaction","namespace_id","namespace_ids","partial_cmp","","payload_commitment","pointer_metadata","","","proposal_certificate","proposer_id","random","reward_balance","serialize","","should_return_err","state_type","timestamp","","to_owned","","","transaction_with_proof","transactions","tree_height","try_from","","","try_into","","","type_id","","","upgrade_certificate","urls","view_number","vzip","","","HeightIndexed","height"],"q":[[0,"hotshot_query_service"],[307,"hotshot_query_service::Error"],[314,"hotshot_query_service::QueryError"],[315,"hotshot_query_service::availability"],[992,"hotshot_query_service::availability::Error"],[1000,"hotshot_query_service::data_source"],[1117,"hotshot_query_service::data_source::availability_tests"],[1119,"hotshot_query_service::data_source::fetching"],[1280,"hotshot_query_service::data_source::fs"],[1291,"hotshot_query_service::data_source::node_tests"],[1297,"hotshot_query_service::data_source::persistence_tests"],[1300,"hotshot_query_service::data_source::sql"],[1316,"hotshot_query_service::data_source::sql::testing"],[1317,"hotshot_query_service::data_source::status_tests"],[1318,"hotshot_query_service::data_source::storage"],[1354,"hotshot_query_service::data_source::storage::fs"],[1439,"hotshot_query_service::data_source::storage::no_storage"],[1503,"hotshot_query_service::data_source::storage::no_storage::testing"],[1600,"hotshot_query_service::data_source::storage::no_storage::testing::Storage"],[1601,"hotshot_query_service::data_source::storage::pruning"],[1647,"hotshot_query_service::data_source::storage::sql"],[2043,"hotshot_query_service::data_source::storage::sql::testing"],[2084,"hotshot_query_service::explorer"],[3161,"hotshot_query_service::fetching"],[3195,"hotshot_query_service::fetching::provider"],[3305,"hotshot_query_service::fetching::request"],[3395,"hotshot_query_service::merklized_state"],[3511,"hotshot_query_service::merklized_state::Error"],[3515,"hotshot_query_service::metrics"],[3757,"hotshot_query_service::metrics::MetricsError"],[3761,"hotshot_query_service::node"],[4058,"hotshot_query_service::node::Error"],[4067,"hotshot_query_service::status"],[4138,"hotshot_query_service::status::Error"],[4140,"hotshot_query_service::task"],[4183,"hotshot_query_service::testing"],[4187,"hotshot_query_service::testing::consensus"],[4227,"hotshot_query_service::testing::mocks"],[4361,"hotshot_query_service::types"],[4363,"dyn_clone::sealed"],[4364,"core::error"],[4365,"hotshot_query_service::error"],[4366,"std::backtrace"],[4367,"core::option"],[4368,"hotshot_types::data"],[4369,"hotshot_types::traits::node_implementation"],[4370,"alloc::string"],[4371,"core::convert"],[4372,"tide_disco::status"],[4373,"core::clone"],[4374,"committable"],[4375,"hotshot_types::message"],[4376,"hotshot_query_service::resolvable"],[4377,"rand_core"],[4378,"core::result"],[4379,"serde::de"],[4380,"rkyv::with"],[4381,"hotshot_types::simple_vote"],[4382,"hotshot_types::simple_certificate"],[4383,"async_lock::rwlock"],[4384,"alloc::sync"],[4385,"anyhow"],[4386,"core::fmt"],[4387,"hotshot_query_service::explorer::query_data"],[4388,"sqlx_core::error"],[4389,"std::os::fd::owned"],[4390,"io_lifetimes::portability"],[4391,"core::hash"],[4392,"core::marker"],[4393,"color_eyre::section"],[4394,"core::alloc::layout"],[4395,"arc_swap::access"],[4396,"core::future::future"],[4397,"alloc::boxed"],[4398,"core::pin"],[4399,"futures_core::future"],[4400,"core::ops::function"],[4401,"hotshot::types::handle"],[4402,"hotshot_query_service::availability::data_source"],[4403,"hotshot_query_service::node::data_source"],[4404,"hotshot_query_service::status::data_source"],[4405,"hotshot_query_service::data_source::update"],[4406,"vbs::version"],[4407,"serde::ser"],[4408,"core::any"],[4409,"hotshot_query_service::availability::query_data"],[4410,"core::cmp"],[4411,"core::iter::traits::iterator"],[4412,"hotshot_types::vid"],[4413,"hotshot_query_service::availability::fetch"],[4414,"snafu"],[4415,"tide_disco::api"],[4416,"tide_disco::method"],[4417,"tide_disco::request"],[4418,"futures_core::stream"],[4419,"core::ops::range"],[4420,"core::time"],[4421,"hotshot_query_service::data_source::extension"],[4422,"hotshot_query_service::data_source::metrics"],[4423,"hotshot_query_service::explorer::data_source"],[4424,"hotshot_query_service::merklized_state::data_source"],[4425,"hotshot_types::event"],[4426,"core::default"],[4427,"jf_merkle_tree::internal"],[4428,"alloc::vec"],[4429,"hotshot_types::traits::metrics"],[4430,"hotshot_query_service::data_source::fetching::notify_storage"],[4431,"std::path"],[4432,"atomic_store::atomic_store"],[4433,"core::ops::deref"],[4434,"atomic_store::error"],[4435,"time::offset_date_time"],[4436,"refinery_core::runner"],[4437,"sqlx_core::database"],[4438,"hotshot_query_service::data_source::storage::sql::transaction"],[4439,"hotshot_query_service::data_source::storage::sql::queries"],[4440,"hotshot_query_service::data_source::storage::sql::db"],[4441,"sqlx_core::encode"],[4442,"sqlx_core::types"],[4443,"sqlx_postgres::database"],[4444,"sqlx_core::executor"],[4445,"sqlx_sqlite::database"],[4446,"sqlx_core::type_checking"],[4447,"sqlx_postgres::options"],[4448,"core::iter::traits::collect"],[4449,"sqlx_core::from_row"],[4450,"sqlx_core::testing"],[4451,"refinery_core::error"],[4452,"hotshot_query_service::explorer::monetary_value"],[4453,"hotshot_query_service::explorer::currency"],[4454,"hotshot_query_service::explorer::traits"],[4455,"core::num::error"],[4456,"time::error::component_range"],[4457,"clap_builder::builder::resettable"],[4458,"async_lock::semaphore"],[4459,"hotshot_query_service::fetching::provider::testing"],[4460,"hotshot_query_service::fetching::provider::any"],[4461,"hotshot_query_service::fetching::provider::query_service"],[4462,"url"],[4463,"jf_merkle_tree"],[4464,"core::str::traits"],[4465,"ark_serialize"],[4466,"tagged_base64"],[4467,"prometheus::errors"],[4468,"hotshot_query_service::node::query_data"],[4469,"hotshot_types::signature_key"],[4470,"hotshot_types"],[4471,"include_dir_macros"]],"i":"`j0AKd`A``2``2`0`20`1``````2````Ab3AhAjAl4Bf757755`Cf86555584326015843260143288658432615843261584326155Bn66`16954371226954371297669954377126954371266666`6543`6666995437726999999954377712222222262666697697`69543712`````96954371254366954371222`3``1666954371212`69797`971``695437269769543712695437120669543712`6669543712BMbBMdBMfBMhBMjBMl5BMn````Il`Fb```0`0`0`MhMjLj`3`0```421`1`4Nh``04`````1````532K`JnMlKdKfKhMnN`NbKjKlKnL`LbFbOd>1>>11>1?<;::Nh1MhMjK`JnMlKdKfKhMnN`NbKjKlKnL`LbFbNhOdMhMjK`JnMlKdKfKhMnN`NbKjKlKnL`LbFb54321Lj0>1MhMjK`JnMlKdKfKhMnN`NbKjKlKnL`LbFbMhMjK`JnMlKdKfKhMnN`NbKjKlKnL`LbFbMhMjK`JnMlKdKfKhMnN`NbKjKlKnL`LbFbMhMj<10Nh>Od`1032K`JnMlKdKfKhMnN`NbKjKlKnL`LbFbNhOdMhMjK`JnMlKdKfKhMnN`NbKjKlKnL`LbFb=0NhOdMhMjK`0JnMl0Kd0Kf0Kh0Mn0N`0NbKjKlKnL`LbFb0NhOdMhMjK`JnMlKdKfKhMnN`NbKjKlKnL`LbFbLj0=MhMjK`MlKdKfKhMnN`888877776666555544443333222211110000OdKjKlKnL`Lb5>>===0000000>=<;:87>==<;9410:4NhOdMhMjK`6MlKdKfKhMnN`NbKjKlKnL`LbFbAAj001NhOdMhMjK`JnMlKdKfKhMnN`NbKjKlKnL`LbFb654321NhLj0>01OdMhMjK`JnMlKdKfKhMnN`NbKjKlKnL`LbFb>=Lj=Nh3>K`?=222222?;MhMjMl30Kf5Od435Jn3Kd3KhMnN`NbKjKlKnL`LbFbLj0:K`=Nh8761Ml>Kf>=<51?=Jn667Il0000000ABdMhMj846Kd6KhMnN`NbKjKlKnL`LbFb<;?0Lj0Ml;110111NhOdMhMjK`Jn6KdKfKhMnN`NbKjKlKnL`LbFbNhOdMhMjK`JnMlKdKfKhMnN`NbKjKlKnL`LbFbNh0OdMhMjK`JnMlKdKfKhMnN`NbKjKlKnL`LbFbNhOdMhMjK`JnMlKdKfKhMnN`NbKjKlKnL`LbFbNh0BN`0BNbBNdBNfBNhBNj4`````Jb``0``ABhABj11`1101010101010ABl21221121212121`2121`22222222222222222221212222222121212`2`2121322102```221212121AEj333243```````AEnAFhAEl02022AFb132013203323232131333013201320132001321320132131313131311313131313131313131313131301321111013201321303313013233113133201320132013211301320000000003``AGn00000000````````````````AFj0AH`000`0```````````AF`0`AGdAGf10012AGh22AGj33232233`4``44````AHbAHhAG`2102222001021021021022102102222222222221022221021020021020AHd3313213213213332131``AIdAIb01011110010101010110100000000000010000101001100`101010100011`BNlAIfAIh210``0100210210000101002102102102100210001000000000210111210210010210000101002102102101102100BNn``AFd``AIl00000000000001AJ`1111AGl22223212222222222222AJl00`0`ALn`````1``````1`1``1`1`1111`AJhALdALfAJj330Dn00AKn43AJnAKbAKl48AMbAL`39827ALhALj8<325;:4910598<3232<;:9<;:9<;:9<4<91984329325;:90`88<325;:4491088<325;:449108<325;:491088888<325;:491032<<<<<====4444========88<<325;:4910322888<325;:499109444414324444444414444448<599``8<325;:491044448<325;:491088<325;:4910449998<8932<948<325;:49109<===19`5`51932489<4132<`432`9<;:98<8<325;:49108<325;:49108<325;:4910<449<48<325;:49101``BO`ANj1001010101000100100101001000010101010`BC`BAb````AOl```AOd00```000```````000`En`B@d1`0`1`1`1`1`0`AC`AD`10Ff`AOnB@bB@f854`;BCh;`<:3B@`382<``435``::````0````;40382:`=:AO`AOb>22==99<<00;;11B@nBAlBAfB@h1BAn22BAdBAj?>AOd>AC`AD`?>=6B@jFfB@lBAh;AOlAOnB@`B@bB@dB@fEnBAlBAnBB`BBbBBdBBfAO`AObAOdANlAC`AD`AOfAOhAOjB@hB@jFfB@lB@nBA`ACdBAbADbBAdBAfBAhBAjAOlAOnB@`B@bB@dB@fEnBAlBAnBB`BBbBBdBBfANlAO`AObAOd3AC`AD`AOfAOhAOjAOlAOnB@`B@bB@dB@fEn>==>ADb`?>=ANl=<;:9B@hB@jFfB@lB@nBA`ACdBAb9BAdBAfBAhBAjAOlAOnB@`B@bB@dB@fEnBAlBAnBB`BBbBBdBBfAO`AObAOdANlAC`AD`AOfAOhAOjB@hB@jFfB@lB@nBA`ACdBAbADbBAdBAfBAhBAjAOlAOnB@`B@bB@dB@fEnBAlBAnBB`BBbBBdBBfAO`0AOb0AOd0ANl0AC`AD`AOfAOhAOj0B@h0B@j0FfB@l0B@n0BA`0ACdBAb0ADbBAd0BAf0BAh0BAj0AOl0AOn0B@`0B@b0B@d0B@f0En0BAl0BAn0BB`0BBb0BBd0BBf0AO`AObAOdANlAC`AD`AOfAOhAOjB@hB@jFfB@lB@nBA`ACdBAbADbBAdBAfBAhBAjAOlAOnB@`B@bB@dB@fEnBAlBAnBB`BBbBBdBBfAOdANlAC`AD`AOfAOhAOjB@hB@jFfB@lB@nBA`ACd====<<<<;;;;::::9999888877776666555544443333222211110000<=B@lB@nBA`0ACdBAbADbBAdBAfBAhBAjAOlAOnB@`B@bB@dB@fEnBAlBAnBB`BBbBBdBBfAO`AObAOdANlAC`AD`AOfAOhAOjB@hB@jFfB@lB@nBA`ACdBAbADbBAdBAfBAhBAjAOlAOnB@`B@bB@dB@fEnBAlBAnBB`BBbBBdBBfAO`AObAOdANlAC`AD`AOfAOhAOjB@hB@jFfB@lB@nBA`ACdBAbADbBAdBAfBAhBAjAOlAOnB@`B@bB@dB@fEnBAlBAnBB`BBbBBdBBfANl0AO`AObAOd3AC`AD`AOfAOhAOjB@hB@jFfB@lB@nBA`ACdBAbADbBAdBAfBAhBAjAOlAOnB@`B@bB@dB@fEnBAlBAnBB`BBbBBdBBf`````BCj0000000000000000``BClBCn22222222`````BDhBDjBDfBDl1321032103210321032103032103210321032101BDb444333214321432143214321432132432143214321432143212243214444```BD``BDnBEbBE`2102102102102102102102102102102222111100002102100210210210210210210210210210210210ACjAClFd11`21````00`1`20BEf11113013011313131330`3013011301130133333033113011113AChACn55343523AE`563463466344045464645634634634634BObBOdBOf2```````BGn00``AEbBGhBH`BGjBHbBHdBHfBHh648888876543210876543210876543210765432107654321073210777778765432108765432108876543210876543210788765432108876543210776532177777787887654321087654321087654321048765432104587477654321088765432108765432108765432105876543210BOh0BOjBOl``Ej``ACf0``1`1`1`1``0``0BJ`BJbBJdBJfBJhBJjBIn8BJl99993In987165432:987165432:2:98765432:98765432:98765432:88071`987165432:987165432::98877165432::987165432:387888877771298765432::99877165432::::8808::987165432::987165432:654328987165432:28888780987165432:7887::3:2098765432::987165432:987165432:987165432:0987165432:7BOnC@`C@bC@dC@f4332`El`0``0BKb1111J`12122222001`121221221200122122222121212012BKd333113323232323C@hC@j``BKf0BKh10111101010100101010100101010110101010`````````BKj`AIj01100000000010000000011000000000`````````````ADdBKnBKlC@lBLj43243204324324324242C@n530543543554335435355553333115435435353BLl26540654BLn476503`BLh486487654448632448761128768768765CA`6987`BK`","f":"`````````````````````````````{{bd}f}000000{b{{b{h}}}}00000``{{{b{j}}}{{n{{b{l}}}}}}{{{b{A`}}}{{n{{b{l}}}}}}{{{b{{Ab{c}}}}}bAd}{{{b{Af{Ab{c}}}}}{{b{Af}}}Ad}{{{b{{Ab{c}}}}}nAd}{b{{b{c}}}{}}0000000{{{b{Af}}}{{b{Afc}}}{}}0000000{AhA`}{AjA`}{{{Al{c}}}A`{{B`{An}}}}{{BbAn}j}{{{b{j}}}{{n{{b{h}}}}}}{{{b{A`}}}{{n{{b{h}}}}}}{{{b{{Ab{c}}}}}{{Ab{c}}}{BdAd}}{{{b{j}}}j}{{{b{Ah}}}Ah}{{{b{Aj}}}Aj}{{{b{{Al{c}}}}}{{Al{c}}}Bd}{{{b{A`}}}A`}{{{b{{Bf{c}}}}}{{Bf{c}}}Bd}{{b{b{Afc}}}f{}}000000{bf}000000{{{b{{Ab{c}}}}}{{Bh{{Ab{c}}}}}Ad}{{{b{{Ab{c}}}}{b{{Bj{ce}}}}}{{Bh{{Ab{c}}}}}AdBl}{{{b{Bn}}}{{Bh{c}}}C`}{b{{Bh{c}}}{}}{{{b{{Ab{c}}}}{b{AfCb}}Cd}{}Ad}`{{}Cf}{Ch{{b{c}}}{}}000000{{{b{{Bf{c}}}}}{{b{e}}}{}{}}1{Ch{{b{Afc}}}{}}0000000{{{b{j}}}{{b{Cj}}}}{{{b{A`}}}{{b{Cj}}}}{c{{Cl{{Ab{e}}}}}CnAd}{{b{b{Afc}}}{{Cl{{D`{eg}}}}}{}{}{}}{c{{Cl{j}}}Cn}1111{c{{Cl{A`}}}Cn}222{Chf}0000000{{{b{{Ab{c}}}}{b{{Ab{c}}}}}DbAd}{{b{b{c}}}Db{}}000`{{{b{{Ab{c}}}}{b{{Ab{c}}}}{b{{Dl{{Dj{{n{{Dh{c{Dd{c}}Df}}}}}}}}}}}{{Cl{fDn}}}Ad}{Ah{{Cl{cA`}}}{}}{Aj{{Cl{cA`}}}{}}{{{Al{c}}}{{Cl{eA`}}}{{B`{An}}}{}}`{{{b{Af{Ab{c}}}}Ch}{{Cl{fE`}}}Ad}{{{b{Af{Ab{c}}}}}fAd}{{{b{{Ab{c}}}}{b{AfEb}}}{{Cl{fEd}}}Ad}{{{b{{Ab{c}}}}{b{AfEb}}}{{Cl{fEd}}}{EfAd}}{{{b{j}}{b{AfEb}}}Eh}0{{{b{Ah}}{b{AfEb}}}Eh}{{{b{Aj}}{b{AfEb}}}Eh}{{{b{{Al{c}}}}{b{AfEb}}}EhEf}{{{b{A`}}{b{AfEb}}}Eh}0{{{b{{Bf{c}}}}{b{AfEb}}}EhEf}{cc{}}{Ejj}{Elj}{Enj}{{{F`{AnBb}}}j}{Fbj}5{Fdj}666{FfA`}7{FhA`}88{{{Dl{c}}}{{Bf{c}}}{}}{Fjc{}}{c{{Bf{c}}}{}}{Flc{}}0{ceFn{}}{ceG`{}}{{{b{{Gb{c}}}}}{{Ab{c}}}Ad}3{{bb}{{Ab{c}}}Ad}{{{b{c}}{b{e}}}Cd{GdGf}Gh}{{{b{{Ab{c}}}}{b{Afe}}}fAdGj}{c{{Gl{ce}}}{GnH`Hb}{}}00{{{b{{Ab{c}}}}}CdAd}{{}}0`{{}Ch}0000000`````{cjGn}{{}c{}}0000000{{Ahc}A`{}}{{Ajc}A`{}}{{{Al{c}}e}A`{{B`{An}}}{}}{{{b{{Ab{c}}}}}{{Dh{c{Hd{c}}Hf}}}Ad}{{}{{Cl{HhHj}}}}0000000{b}{b{{Hl{c}}}{}}`````{{{b{{Ab{c}}}}}{{Bh{{Ab{c}}}}}Ad}{{{b{{Ab{c}}}}}{}Ad}33333333`{{{b{{Bf{c}}}}i}{{Ib{{I`{Hn}}}}}{H`Hb}{}{}{H`{Ih{{b{e}}}{{Id{{If{g}}}}}}}}{{Cfe{Ij{cgi}}k}{{Cl{fj}}}Ad{{Il{c}}{In{c}}J`JbH`Hb}{{Jd{c}}}BlJf}{{{b{{Ab{c}}}}e}Cl{AdJh}Jj}{{{b{j}}c}ClJj}{{{b{A`}}c}ClJj}{{{b{j}}}{{n{{b{h}}}}}}{{{b{A`}}}{{n{{b{h}}}}}}`{{{b{j}}}Bb}{{{b{A`}}}Bb}```{bc{}}000000{bAn}00{c{{Cl{e}}}{}{}}0000000{{}{{Cl{c}}}{}}0000000{Bn{{Cl{cBn}}}C`}{{}{{Cl{cc}}}{}}{bJl}0000000`{{{b{{Ab{c}}}}}{{n{{Dh{c{Dd{c}}Df}}}}}Ad}{{{b{{Ab{c}}}}}{}Ad}{{}c{}}0000000`````````````````````````````````````````````````````````{{bd}f}0000000000000000`{b{{b{h}}}}00000{{{b{{Jn{c}}}}}{{n{{b{l}}}}}Ad}{{{b{Fb}}}{{n{{b{l}}}}}}{{{b{{K`{c}}}}}{{Kb{c}}}Ad}{{{b{{Kd{c}}}}}{{Kb{c}}}Ad}{{{b{{Kf{c}}}}}{{Kb{c}}}Ad}{{{b{{Kh{c}}}}}{{Kb{c}}}Ad}{{{b{{Kh{c}}}}}CdAd}{b{{b{c}}}{}}000000000000000000{{{b{Af}}}{{b{Afc}}}{}}000000000000000000{{{Kj{c}}}Fb{{B`{An}}}}{{{Kl{c}}}Fb{{B`{An}}}}{{{Kn{c}}}Fb{{B`{An}}}}{{{L`{ce}}}Fb{{B`{Cd}}}{{B`{Cd}}}}{{{Lb{ce}}}Fb{{B`{An}}}{{B`{Bb}}}}{{{b{{Lj{}{{Ld{c}}{Lf{e}}{Lh{g}}}}}}{b{i}}{Bh{k}}}{{n{c}}}{BdEfLlLnM`JhMbH`Hb}{{Mf{}{{Md{c}}}}}{BdEfLlLnJhMbH`Hb}{}{}}0{{{b{{Jn{c}}}}}{{n{{b{h}}}}}Ad}{{{b{Fb}}}{{n{{b{h}}}}}}{{{b{{Mh{c}}}}}{{Mh{c}}}Ad}{{{b{{Mj{c}}}}}{{Mj{c}}}Ad}{{{b{{K`{c}}}}}{{K`{c}}}{BdAd}}{{{b{{Jn{c}}}}}{{Jn{c}}}{BdAd}}{{{b{{Ml{c}}}}}{{Ml{c}}}{BdAd}}{{{b{{Kd{c}}}}}{{Kd{c}}}{BdAd}}{{{b{{Kf{c}}}}}{{Kf{c}}}{BdAd}}{{{b{{Kh{c}}}}}{{Kh{c}}}{BdAd}}{{{b{{Mn{c}}}}}{{Mn{c}}}{BdAd}}{{{b{{N`{c}}}}}{{N`{c}}}{BdAd}}{{{b{Nb}}}Nb}{{{b{{Kj{c}}}}}{{Kj{c}}}Bd}{{{b{{Kl{c}}}}}{{Kl{c}}}Bd}{{{b{{Kn{c}}}}}{{Kn{c}}}Bd}{{{b{{L`{ce}}}}}{{L`{ce}}}BdBd}{{{b{{Lb{ce}}}}}{{Lb{ce}}}BdBd}{{{b{Fb}}}Fb}{{b{b{Afc}}}f{}}0000000000000000{bf}0000000000000000{{{b{{Mh{c}}}}{b{{Mh{c}}}}}NdAd}{{{b{{Mj{c}}}}{b{{Mj{c}}}}}NdAd}{{{b{{Kf{c}}}}}{{b{Nf}}}Ad}{{b{b{c}}}Nd{}}0{{{Nh{c}}g}{{Cl{ce}}}{}{hNj}{{O`{e}{{Nl{Nn}}}}}}{{{b{{Kd{c}}}}}{{b{{Ob{c}}}}}Ad}{{}Od}{{{b{Od}}c}{{Cl{{Of{eFbc}}Oh}}}Jf{H`HbOj}}{Ch{{b{c}}}{}}000000000000000000{Ch{{b{Afc}}}{}}000000000000000000{{{b{{Jn{c}}}}}{{b{Cj}}}Ad}{{{b{Fb}}}{{b{Cj}}}}{{b{b{Afc}}}{{Cl{{D`{eg}}}}}{}{}{}}0000{c{{Cl{{K`{e}}}}}CnAd}11{c{{Cl{{Ml{e}}}}}CnAd}{c{{Cl{{Kd{e}}}}}CnAd}3{c{{Cl{{Kf{e}}}}}CnAd}4{c{{Cl{{Kh{e}}}}}CnAd}55{c{{Cl{{Mn{e}}}}}CnAd}{c{{Cl{{N`{e}}}}}CnAd}77777777{c{{Cl{Fb}}}Cn}{Chf}000000000000000000{{{b{{Lj{}{{Ld{c}}{Lf{e}}{Lh{g}}}}}}{b{i}}}{{I`{Mf}}}{BdEfLlLnM`JhMbH`Hb}{{Mf{}{{Md{c}}}}}{BdEfLlLnJhMbH`Hb}{}}0{{{b{{Ml{c}}}}}{{`{{Mf{}{{Md{{F`{{Ol{c}}{On{c}}}}}}}}}}}Ad}{{{b{{Mh{c}}}}{b{{Mh{c}}}}}DbAd}{{{b{{Mj{c}}}}{b{{Mj{c}}}}}DbAd}{{{b{{K`{c}}}}{b{{K`{c}}}}}Db{LlAd}}{{{b{{Ml{c}}}}{b{{Ml{c}}}}}Db{LlAd}}{{{b{{Kd{c}}}}{b{{Kd{c}}}}}Db{LlAd}}{{{b{{Kf{c}}}}{b{{Kf{c}}}}}Db{LlAd}}{{{b{{Kh{c}}}}{b{{Kh{c}}}}}Db{LlAd}}{{{b{{Mn{c}}}}{b{{Mn{c}}}}}Db{LlAd}}{{{b{{N`{c}}}}{b{{N`{c}}}}}Db{LlAd}}{{b{b{c}}}Db{}}00000000000000000000000000000000000`{{{Kj{c}}}{{Cl{eFb}}}{{B`{An}}}{}}{{{Kl{c}}}{{Cl{eFb}}}{{B`{An}}}{}}{{{Kn{c}}}{{Cl{eFb}}}{{B`{An}}}{}}{{{L`{ce}}}{{Cl{gFb}}}{{B`{Cd}}}{{B`{Cd}}}{}}{{{Lb{ce}}}{{Cl{gFb}}}{{B`{An}}}{{B`{Bb}}}{}}`{{{b{{Mh{c}}}}{b{AfEb}}}EhAd}0{{{b{{Mj{c}}}}{b{AfEb}}}EhAd}0{{{b{{K`{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{Jn{c}}}}{b{AfEb}}}EhAd}{{{b{{Jn{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{Ml{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{Kd{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{Kf{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{Kh{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{Mn{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{N`{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{Nb}}{b{AfEb}}}Eh}{{{b{{Kj{c}}}}{b{AfEb}}}EhEf}{{{b{{Kl{c}}}}{b{AfEb}}}EhEf}{{{b{{Kn{c}}}}{b{AfEb}}}EhEf}{{{b{{L`{ce}}}}{b{AfEb}}}EhEfEf}{{{b{{Lb{ce}}}}{b{AfEb}}}EhEfEf}{{{b{Fb}}{b{AfEb}}}Eh}0{cc{}}0{{{A@`{c}}}{{Mh{c}}}Ad}1{Ch{{Mh{c}}}Ad}2{{{Kb{c}}}{{Mj{c}}}Ad}{Ch{{Mj{c}}}Ad}444{{{Ml{c}}}{{Kd{c}}}Ad}555{{{Ml{c}}}{{Mn{c}}}Ad}666666666{A@bFb}{{{F`{AnBb}}}Fb}{b{{A@d{{K`{c}}}}}Ad}{b{{A@d{{Ml{c}}}}}Ad}{b{{A@d{{Kd{c}}}}}Ad}{b{{A@d{{Kf{c}}}}}Ad}{{bb}{{K`{c}}}Ad}{{bb}{{Ml{c}}}Ad}{{bb}{{Kd{c}}}Ad}{{bb}{{Kf{c}}}Ad}{{{b{{Il{}{{A@f{c}}{A@h{g}}{A@j{i}}{A@l{k}}}}}}m}{{Ib{{I`{Hn}}}}}{{A@n{}{{Md{{Nh{{K`{e}}}}}}}}AA`H`}Ad{{A@n{}{{Md{{Nh{{Ml{e}}}}}}}}AA`H`}{{A@n{}{{Md{{Nh{{Kd{e}}}}}}}}AA`H`}{{A@n{}{{Md{{Nh{{Kf{e}}}}}}}}AA`H`}{{B`{{Mj{e}}}}H`Hb}}{{{b{{Il{}{{A@f{c}}{A@h{g}}{A@j{i}}{A@l{k}}}}}}m}{{Ib{{I`{Hn}}}}}{{A@n{}{{Md{{Nh{{K`{e}}}}}}}}AA`H`}Ad{{A@n{}{{Md{{Nh{{Ml{e}}}}}}}}AA`H`}{{A@n{}{{Md{{Nh{{Kd{e}}}}}}}}AA`H`}{{A@n{}{{Md{{Nh{{Kf{e}}}}}}}}AA`H`}{{AAb{Ch}}H`}}{{{b{c}}{b{e}}}Cd{GdGf}Gh}0{{{b{{Il{}{{A@f{c}}{A@h{g}}{A@j{i}}{A@l{k}}}}}}m}{{Ib{{I`{Hn}}}}}{{A@n{}{{Md{{Nh{{K`{e}}}}}}}}AA`H`}Ad{{A@n{}{{Md{{Nh{{Ml{e}}}}}}}}AA`H`}{{A@n{}{{Md{{Nh{{Kd{e}}}}}}}}AA`H`}{{A@n{}{{Md{{Nh{{Kf{e}}}}}}}}AA`H`}{{B`{{Mh{e}}}}H`Hb}}232{{{b{{Il{}{{A@f{c}}{A@h{g}}{A@j{i}}{A@l{k}}}}}}{AAd{e}}}{{Ib{{I`{Hn}}}}}{{A@n{}{{Md{{Nh{{K`{e}}}}}}}}AA`H`}Ad{{A@n{}{{Md{{Nh{{Ml{e}}}}}}}}AA`H`}{{A@n{}{{Md{{Nh{{Kd{e}}}}}}}}AA`H`}{{A@n{}{{Md{{Nh{{Kf{e}}}}}}}}AA`H`}}43{{{b{{Mh{c}}}}{b{Afe}}}fAdGj}{{{b{{Mj{c}}}}{b{Afe}}}fAdGj}{{{b{{K`{c}}}}}{{A@`{c}}}Ad}{{{b{{Ml{c}}}}}{{Kb{c}}}Ad}{{{b{{Kd{c}}}}}AAfAd}{{{b{{Kh{c}}}}}{{AAd{c}}}Ad}{{{b{{Mn{c}}}}}{{Kb{c}}}Ad}{c{{Gl{ce}}}{GnH`Hb}{}}0{{{b{{K`{c}}}}}{{b{{AAh{c}}}}}Ad}1{{{b{{Ml{c}}}}}{{b{{AAh{c}}}}}Ad}{{{b{{Mn{c}}}}}{{b{{AAh{c}}}}}Ad}3{{{b{{K`{c}}}}}CdAd}{{{b{{Ml{c}}}}}CdAd}{{{b{{Kd{c}}}}}CdAd}{{{b{{Kf{c}}}}}CdAd}{{{b{{Mn{c}}}}}CdAd}`{{}}0{{{b{{Kh{c}}}}}CdAd}`{{}Ch}000000000000000000{{{b{AfAAj}}{Ml{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{AfAAj}}{K`{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{AfAAj}}{Kf{c}}{n{AAl}}}{{Ib{{I`{Hn}}}}}Ad}{cFbGn}{{}c{}}000000000000000000{{Nbc}Fb{}}{{{Kj{c}}e}Fb{{B`{An}}}{}}{{{Kl{c}}e}Fb{{B`{An}}}{}}{{{Kn{c}}e}Fb{{B`{An}}}{}}{{{L`{ce}}g}Fb{{B`{Cd}}}{{B`{Cd}}}{}}{{{Lb{ce}}g}Fb{{B`{An}}}{{B`{Bb}}}{}}{{{Nh{c}}}eH`{}}{{{b{{Lj{}{{Ld{c}}{Lf{e}}{Lh{g}}}}}}{b{i}}}Db{BdEfLlLnM`JhMbH`Hb}{{Mf{}{{Md{c}}}}}{BdEfLlLnJhMbH`Hb}{}}0{{{b{{Ml{c}}}}}DbAd}{{{b{{Lj{}{{Ld{c}}{Lf{e}}{Lh{g}}}}}}{b{i}}}e{BdEfLlLnM`JhMbH`Hb}{{Mf{}{{Md{c}}}}}{BdEfLlLnJhMbH`Hb}{}}{{}{{Cl{HhHj}}}}000000000000000000{{{b{{K`{c}}}}}{{b{{Ab{c}}}}}Ad}`{{{b{{Lj{}{{Ld{c}}{Lf{e}}{Lh{g}}}}}}{b{i}}}Ch{BdEfLlLnM`JhMbH`Hb}{{Mf{}{{Md{c}}}}}{BdEfLlLnJhMbH`Hb}{}}{{{b{{Ml{c}}}}}ChAd}{{{Nh{c}}g}{{Nh{e}}}{}{}{H`{Ih{c}{{Id{e}}}}}}`{{{b{{Ml{c}}}}}{{b{{AAn{c}}}}}Ad}{{{Ab{c}}{AB`{c}}}{{Cl{{K`{c}}{Jn{c}}}}}Ad}{{{AAh{c}}{Ob{c}}}{{Ml{c}}}Ad}{{{AAh{c}}Nf}{{Kf{c}}}Ad}{{{b{{Lj{}{{Ld{c}}{Lf{e}}{Lh{g}}}}}}{b{i}}Ch}{{n{c}}}{BdEfLlLnM`JhMbH`Hb}{{Mf{}{{Md{c}}}}}{BdEfLlLnJhMbH`Hb}{}}0{{{b{{Lj{}{{Ld{c}}{Lf{e}}{Lh{g}}}}}}{b{i}}Ch}{{n{k}}}{BdEfLlLnM`JhMbH`Hb}{{Mf{}{{Md{c}}}}}{BdEfLlLnJhMbH`Hb}{}{}}0{{{b{{Lj{}{{Ld{c}}{Lf{e}}{Lh{g}}}}}}{b{i}}Ch}{{n{{F`{kg}}}}}{BdEfLlLnM`JhMbH`Hb}{{Mf{}{{Md{c}}}}}{BdEfLlLnJhMbH`Hb}{}{}}0{{{b{{Ml{c}}}}}CdAd}{{{b{{Mn{c}}}}}CdAd}{{{b{{Mh{c}}}}{b{{Mh{c}}}}}{{n{Nd}}}Ad}{{{b{{Mj{c}}}}{b{{Mj{c}}}}}{{n{Nd}}}Ad}{{{b{{Ml{c}}}}}{{b{{Ob{c}}}}}Ad}{{{b{{K`{c}}}}}AAfAd}{{{b{{Ml{c}}}}}AAfAd}{{{b{{Kf{c}}}}}AAfAd}{b}000000000000000000{{{b{{Lj{}{{Ld{c}}{Lf{e}}{Lh{g}}}}}}{b{i}}{b{c}}}{{n{g}}}{BdEfLlLnM`JhMbH`Hb}{{Mf{}{{Md{c}}}}}{BdEfLlLnJhMbH`Hb}{}}0{{{b{{Kh{c}}}}}{{b{{ABb{c}}}}}Ad}{{{b{{K`{c}}}}}{{b{{AB`{c}}}}}Ad}`{{{Nh{c}}}cH`}```{{{b{{K`{c}}}}e}ClAdJj}{{{b{{Ml{c}}}}e}ClAdJj}{{{b{{Kd{c}}}}e}ClAdJj}{{{b{{Kf{c}}}}e}ClAdJj}{{{b{{Kh{c}}}}e}ClAdJj}{{{b{{Mn{c}}}}e}ClAdJj}{{{b{{N`{c}}}}e}ClAdJj}{{{b{Fb}}c}ClJj}{{{b{{Ml{c}}}}}CdAd}{{{b{{Kd{c}}}}}CdAd}{{{b{{Mn{c}}}}}CdAd}{{{b{{Jn{c}}}}}{{n{{b{h}}}}}Ad}{{{b{Fb}}}{{n{{b{h}}}}}}{{{b{Fb}}}Bb}`{{{b{{Il{}{{A@f{c}}{A@h{g}}{A@j{i}}{A@l{k}}}}}}Ch}{{Ib{{I`{Hn}}}}}{{A@n{}{{Md{{Nh{{K`{e}}}}}}}}AA`H`}Ad{{A@n{}{{Md{{Nh{{Ml{e}}}}}}}}AA`H`}{{A@n{}{{Md{{Nh{{Kd{e}}}}}}}}AA`H`}{{A@n{}{{Md{{Nh{{Kf{e}}}}}}}}AA`H`}}0000000{{{b{ABd}}}Cd}{bc{}}0000000000000000{bAn}000{{{b{{Lj{}{{Ld{c}}{Lf{e}}{Lh{g}}}}}}{b{i}}{b{c}}}{{n{k}}}{BdEfLlLnM`JhMbH`Hb}{{Mf{}{{Md{c}}}}}{BdEfLlLnJhMbH`Hb}{}{}}0{{{b{{Ml{c}}}}{b{{Ol{c}}}}}{{n{{On{c}}}}}Ad}{{{b{{Kh{c}}}}}{{b{{On{c}}}}}Ad}{{{b{{Lj{}{{Ld{c}}{Lf{e}}{Lh{g}}}}}}{b{i}}{Bh{k}}}{{n{k}}}{BdEfLlLnM`JhMbH`Hb}{{Mf{}{{Md{c}}}}}{BdEfLlLnJhMbH`Hb}{}{}}0{{{b{{Ml{c}}}}{Bh{{On{c}}}}}{{n{{Ol{c}}}}}Ad}{{{b{{Lj{}{{Ld{c}}{Lf{e}}{Lh{g}}}}}}{b{i}}{Bh{k}}}{{n{{F`{kg}}}}}{BdEfLlLnM`JhMbH`Hb}{{Mf{}{{Md{c}}}}}{BdEfLlLnJhMbH`Hb}{}{}}0{{{b{{Lj{}{{Ld{c}}{Lf{e}}{Lh{g}}}}}}{b{i}}{b{c}}}{{n{{F`{kg}}}}}{BdEfLlLnM`JhMbH`Hb}{{Mf{}{{Md{c}}}}}{BdEfLlLnJhMbH`Hb}{}{}}{c{{Cl{e}}}{}{}}000000000000000000{{}{{Cl{c}}}{}}000000000000000000{{{Nh{c}}}{{Cl{c{Nh{c}}}}}{}}{bJl}000000000000000000{{}c{}}000000000000000000{{{Nh{c}}i}{{Cl{ce}}}{}{hNj}{{O`{e}{{Nl{Nn}}}}}{{Ih{}{{Id{g}}}}}}{{{Nh{c}}ABf}{{n{c}}}H`}```````````````````{{bd}f}0{{{b{Af{ABh{ce}}}}}{{b{Afe}}}{}{}}{{{b{{ABh{ce}}}}}{{b{e}}}{}{}}`{{{b{{ABh{ce}}}}}{{Ib{{I`{Hn}}}}}{J`H`Hb}{H`Hb}}{{{b{{ABh{eg}}}}}{{Ib{{I`{Hn}}}}}Ad{{In{c}}H`Hb}{H`Hb}}{{{b{ABj}}}{{Ib{{I`{Hn}}}}}}{b{{b{c}}}{}}0{{{b{Af}}}{{b{Afc}}}{}}0{{{b{{ABh{ce}}}}}{{ABh{ce}}}BdBd}{{{b{ABj}}}ABj}{{b{b{Afc}}}f{}}0{bf}0{ABl{{`{{Hn{}{{Id{{ABn{f}}}}}}H`}}}}{{{b{c}}}{{Ib{{I`{Hn}}}}}{}}09{Ch{{Ib{{I`{Hn}}}}}}0{{}ABj}{Ch{{b{c}}}{}}0{Ch{{b{Afc}}}{}}0{{b{b{Afc}}}{{Cl{{D`{eg}}}}}{}{}{}}0{Chf}0`{{{b{{ABh{ce}}}}{b{AfEb}}}EhEfEf}{{{b{ABj}}{b{AfEb}}}Eh}{cc{}}0`{{{b{{ABh{eg}}}}i}{{Ib{{I`{Hn}}}}}Ad{{Il{c}}H`Hb}{H`Hb}{{B`{{Mj{c}}}}H`Hb}}{{{b{{ABh{eg}}}}{AC`{c}}}{{Ib{{I`{Hn}}}}}Ad{{ACb{c}}Hb}{H`Hb}}{{{b{{ABh{eg}}}}i}{{Ib{{I`{Hn}}}}}Ad{{Il{c}}H`Hb}{H`Hb}{{AAb{Ch}}H`}}{{{b{{ABh{eg}}}}{ACd{c}}}{{Ib{{I`{Hn}}}}}Ad{{ACb{c}}Hb}{H`Hb}}{{{b{{ABh{eg}}}}}{{Ib{{I`{Hn}}}}}Ad{{ACb{c}}Hb}{H`Hb}}{{{b{{ABh{eg}}}}iCd}{{Ib{{I`{Hn}}}}}Ad{{In{c}}H`Hb}{H`Hb}{{B`{{ACf{c}}}}H`Hb}}{{{b{{ABh{ce}}}}}{{Ib{{I`{Hn}}}}}{AChHb}{H`Hb}}{{{b{{ABh{eg}}}}i}{{Ib{{I`{Hn}}}}}Ad{{Il{c}}H`Hb}{H`Hb}{{B`{{Mh{c}}}}H`Hb}}5{{{b{{ABh{gi}}}}{ACj{ce}}}{{Ib{{I`{Hn}}}}}Ad{{ACl{c}}}{{ACn{ce}}Hb}{H`Hb}}86{{{b{{ABh{eg}}}}An}{{Ib{{I`{Hn}}}}}Ad{{ACb{c}}Hb}{H`Hb}}{{{b{{ABh{eg}}}}{AAd{c}}}{{Ib{{I`{Hn}}}}}Ad{{Il{c}}H`Hb}{H`Hb}}{{{b{{ABh{eg}}}}{AD`{c}}}{{Ib{{I`{Hn}}}}}Ad{{ACb{c}}Hb}{H`Hb}}{{{b{{ABh{eg}}}}{ADb{c}}}{{Ib{{I`{Hn}}}}}Ad{{ACb{c}}Hb}{H`Hb}}<:{{{b{{ABh{ce}}}}{b{{ADf{ADd}}}}}{{Ib{{I`{Hn}}}}}ADh{BdADjH`Hb}}{{{b{ABj}}{b{{ADf{ADd}}}}}{{Ib{{I`{Hn}}}}}}{{}Ch}0{{{b{{ABh{ce}}}}}{{b{c}}}{}{}}{{{b{Af{ABh{ce}}}}}{{b{Afc}}}{}{}}{{{b{Af{ABh{eg}}}}{Ml{c}}}{{Ib{{I`{Hn}}}}}Ad{{AAj{c}}H`Hb}{H`Hb}}{{{b{Af{ABh{eg}}}}{K`{c}}}{{Ib{{I`{Hn}}}}}Ad{{AAj{c}}H`Hb}{H`Hb}}{{{b{Af{ABh{gi}}}}ADl{ADn{Ch}}Cd}{{Ib{{I`{Hn}}}}}Ad{{ACl{c}}}{{AE`{ce}}H`Hb}{H`Hb}}{{{b{Af{ABh{eg}}}}{Kf{c}}{n{AAl}}}{{Ib{{I`{Hn}}}}}Ad{{AAj{c}}H`Hb}{H`Hb}}{{}c{}}0{{}{{Cl{HhHj}}}}0{{{b{{ABh{ce}}}}}{{b{AEb}}}{J`H`Hb}{H`Hb}}{{{b{ABj}}}{{b{AEb}}}}{{ce}{{ABh{ce}}}{}{}}`{{{b{{ABh{eg}}}}}{{Ib{{I`{Hn}}}}}Ad{{In{c}}H`Hb}{H`Hb}}`{b}0{b{{I`{AEd}}}}0{{{b{{Jb{}{{AEf{c}}{AEh{e}}}}}}}{{`{{Hn{}{{Id{{ABn{e}}}}}}H`}}}ABlABl}{{{b{{ABh{ce}}}}}{{ABn{g}}}{JbH`}{H`Hb}{}}{{{b{c}}}{{Ib{{I`{Hn}}}}}{}}0{ABl{{`{HnH`}}}}{{{b{Af{ABh{gi}}}}Ch}{{Ib{{I`{Hn}}}}}Ad{{ACl{c}}}{{AE`{ce}}H`Hb}{H`Hb}}```7{bc{}}0{c{{Cl{e}}}{}{}}0{{}{{Cl{c}}}{}}0{bJl}0{{{b{AfAEj}}{b{{ADf{c}}}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{Af}}{b{{ADf{c}}}}}{{Ib{{I`{Hn}}}}}{}}{{{b{{ABh{eg}}}}i}{{Ib{{I`{Hn}}}}}Ad{{In{c}}H`Hb}{H`Hb}{{B`{{Mj{c}}}}H`Hb}}{{}c{}}0{{{b{{Jb{}{{AEf{c}}{AEh{e}}}}}}}{{`{{Hn{}{{Id{{ABn{c}}}}}}H`}}}ABlABl}<{{}f}0`````{{bd}f}0{{{b{Af{AEl{ce}}}}}{{b{Afe}}}Ad{}}{{{b{{AEl{ce}}}}}{{b{e}}}Ad{}}{{{b{{AEn{ceg}}}}}{{b{e}}}Ad{}{}}{{{b{Af{AEl{ce}}}}}{{Ib{{I`{Hn}}}}}Ad{{AF`{c}}H`}}{{{b{{AEn{ceg}}}}}{{Ib{{I`{Hn}}}}}Ad{JbH`Hb}{H`Hb}}{{{b{{AEn{ceg}}}}}{{Ib{{I`{Hn}}}}}AdJb{H`Hb}}{b{{b{c}}}{}}000{{{b{Af}}}{{b{Afc}}}{}}000{{{AFb{ceg}}}{{ABn{{AEn{ceg}}}}}Ad{AFdJb}{{AFf{c}}}}{{cg}{{AFb{ecg}}}{JbAFd}Ad{{AFf{e}}}}{{{b{{AEn{ceg}}}}}{{AEn{ceg}}}Ad{}{}}{{{b{{AFh{ceg}}}}}{{AFh{ceg}}}Ad{}{}}{{b{b{Afc}}}f{}}0{bf}0{{{AEl{ce}}}{{ABn{f}}}AdABl}{{AFje}{{Cl{{AFl{ce}}Dn}}}Ad{{AFf{c}}}}<:{{{b{AFn}}e}{{ABn{{AEn{c{AG`{c}}e}}}}}Ad{{AFf{c}}}}{{{b{AfAGb}}e}{{ABn{{AEn{c{AG`{c}}e}}}}}Ad{{AFf{c}}}}{Ch{{b{c}}}{}}000{Ch{{b{Afc}}}{}}000{{b{b{Afc}}}{{Cl{{D`{eg}}}}}{}{}{}}000{{{AFb{ceg}}}{{AFb{ceg}}}{}{}{}}{Chf}000{{{b{{AEl{ce}}}}{b{AfEb}}}Eh{AdEf}Ef}{{{b{{AEn{ceg}}}}{b{AfEb}}}EhAdEfEf}{{{b{{AFh{ceg}}}}{b{AfEb}}}EhAdEfEf}{cc{}}000{{{b{Af{AEl{ce}}}}{Mj{c}}}{{Ib{{I`{Hn}}}}}Ad{{AGd{c}}}}{{{b{{AEn{ceg}}}}i}{{Ib{{I`{Hn}}}}}AdJb{{AFf{c}}}{{B`{{Mj{c}}}}H`Hb}}{{{b{Af{AEl{ce}}}}{AC`{c}}}{{Ib{{I`{Hn}}}}}Ad{{AGf{c}}H`}}{{{b{{AEn{ceg}}}}{AC`{c}}}{{Ib{{I`{Hn}}}}}AdJb{H`Hb}}{{{b{Af{AEl{ce}}}}g}{{Ib{{I`{Hn}}}}}Ad{{AGd{c}}}{{AAb{Ch}}H`}}{{{b{{AEn{ceg}}}}i}{{Ib{{I`{Hn}}}}}AdJb{{AFf{c}}}{{AAb{Ch}}H`}}{{{b{Af{AEl{ce}}}}{ACd{c}}}{{Ib{{I`{Hn}}}}}Ad{{AGf{c}}H`}}{{{b{{AEn{ceg}}}}{ACd{c}}}{{Ib{{I`{Hn}}}}}AdJb{H`Hb}}{{{b{Af{AEl{ce}}}}}{{Ib{{I`{Hn}}}}}Ad{{AGf{c}}H`}}{{{b{{AEn{ceg}}}}}{{Ib{{I`{Hn}}}}}AdJb{H`Hb}}9{{{b{Af{AEl{ce}}}}gCd}{{Ib{{I`{Hn}}}}}Ad{{AF`{c}}H`}{{B`{{ACf{c}}}}H`Hb}}{{{b{{AEn{ceg}}}}iCd}{{Ib{{I`{Hn}}}}}AdJb{H`Hb}{{B`{{ACf{c}}}}H`Hb}}{{{b{Af{AEl{ce}}}}}{{Ib{{I`{Hn}}}}}Ad{AGhH`}}3{{{b{Af{AEl{ce}}}}{Mh{c}}}{{Ib{{I`{Hn}}}}}Ad{{AGd{c}}}}{{{b{{AEn{ceg}}}}i}{{Ib{{I`{Hn}}}}}AdJb{{AFf{c}}}{{B`{{Mh{c}}}}H`Hb}}:9{{{b{Af{AEl{cg}}}}{ACj{ce}}}{{Ib{{I`{Hn}}}}}Ad{{ACl{c}}}{{AGj{ce}}H`}}{{{b{{AEn{ceg}}}}{ACj{ci}}}{{Ib{{I`{Hn}}}}}AdJb{H`Hb}{{ACl{c}}}}{{{b{Af{AEl{ce}}}}{Mj{c}}}{{Ib{{I`{Hn}}}}}Ad{{AGd{c}}}}{{{b{{AEn{ceg}}}}i}{{Ib{{I`{Hn}}}}}AdJb{{AFf{c}}}{{B`{{Mj{c}}}}H`Hb}}>={{{b{Af{AEl{ce}}}}An}{{Ib{{I`{Hn}}}}}Ad{{AGf{c}}H`}}{{{b{{AEn{ceg}}}}An}{{Ib{{I`{Hn}}}}}AdJb{H`Hb}}{{{b{Af{AEl{ce}}}}{AAd{c}}}{{Ib{{I`{Hn}}}}}Ad{{AGd{c}}}}{{{b{{AEn{ceg}}}}{AAd{c}}}{{Ib{{I`{Hn}}}}}AdJb{{AFf{c}}}}{{{b{Af{AEl{ce}}}}{AD`{c}}}{{Ib{{I`{Hn}}}}}Ad{{AGf{c}}H`}}{{{b{{AEn{ceg}}}}{AD`{c}}}{{Ib{{I`{Hn}}}}}AdJb{H`Hb}}{{{b{Af{AEl{ce}}}}{ADb{c}}}{{Ib{{I`{Hn}}}}}Ad{{AGf{c}}H`}}{{{b{{AEn{ceg}}}}{ADb{c}}}{{Ib{{I`{Hn}}}}}AdJb{H`Hb}}98{{{b{Af{AEl{ce}}}}g}{{Ib{{I`{Hn}}}}}Ad{{AGd{c}}}{{AAb{Ch}}H`}}{{{b{{AEn{ceg}}}}i}{{Ib{{I`{Hn}}}}}AdJb{{AFf{c}}}{{AAb{Ch}}H`}}{{}Ch}000{{{b{Af{AEl{ce}}}}{Ml{c}}}{{Ib{{I`{Hn}}}}}Ad{{AAj{c}}H`Hb}}{{{b{Af{AEl{ce}}}}{K`{c}}}{{Ib{{I`{Hn}}}}}Ad{{AAj{c}}H`Hb}}{{{b{Af{AEl{cg}}}}ADl{ADn{Ch}}Cd}{{Ib{{I`{Hn}}}}}Ad{{ACl{c}}}{{AE`{ce}}H`Hb}}{{{b{Af{AEl{ce}}}}{Kf{c}}{n{AAl}}}{{Ib{{I`{Hn}}}}}Ad{{AAj{c}}H`Hb}}{{}c{}}000{{}{{Cl{HhHj}}}}000{{{b{Af{AEl{ce}}}}}{{Ib{{I`{Hn}}}}}Ad{AGlH`}}{{{b{{AEn{ceg}}}}}{{b{AEb}}}Ad{JbH`Hb}{H`Hb}}{{ce}{{AFb{gce}}}{}{}{}}{{{b{AFn}}e}{{ABn{{AEn{c{AG`{c}}e}}}}}Ad{{AFf{c}}}}{{{b{AfAGb}}e}{{ABn{{AEn{c{AG`{c}}e}}}}}Ad{{AFf{c}}}}{{{b{Af{AEl{ce}}}}}{{Ib{{I`{Hn}}}}}Ad{{AF`{c}}H`}}{{{b{{AEn{ceg}}}}}{{Ib{{I`{Hn}}}}}AdJb{H`Hb}}{b}000{b{{I`{AEd}}}}{{{b{{AEn{ceg}}}}}{{ABn{i}}}Ad{JbH`Hb}{H`Hb}{}}{{{AEl{ce}}}{{`{HnH`}}}AdABl}{{{b{Af{AEl{cg}}}}Ch}{{Ib{{I`{Hn}}}}}Ad{{ACl{c}}}{{AE`{ce}}H`Hb}}{{{b{{AEn{c{AG`{c}}e}}}}}{{ABn{f}}}Ad{{AFf{c}}}}76{bc{}}0{c{{Cl{e}}}{}{}}000{{}{{Cl{c}}}{}}000{bJl}000{{{b{Af}}{b{{ADf{c}}}}}{{Ib{{I`{Hn}}}}}{}}{{{b{Af{AEl{ce}}}}g}{{Ib{{I`{Hn}}}}}Ad{{AF`{c}}H`}{{B`{{Mj{c}}}}H`Hb}}{{{b{{AEn{ceg}}}}i}{{Ib{{I`{Hn}}}}}AdJb{H`Hb}{{B`{{Mj{c}}}}H`Hb}}{{}c{}}000{{{AFb{ceg}}ABf}{{AFb{ceg}}}{}{}{}}0{{{AFb{ceg}}Ch}{{AFb{ceg}}}{}{}{}}010001=``{{{b{c}}}{{Ib{{I`{Hn}}}}}{}}{{{b{AFn}}e}{{ABn{{AGn{ce}}}}}Ad{{AFf{c}}}}{Ch{{Ib{{I`{Hn}}}}}}{{{b{AfAGb}}e}{{ABn{{AGn{ce}}}}}Ad{{AFf{c}}}}{{{b{{AGn{ADdc}}}}{b{{ADf{ADd}}}}}{{Ib{{I`{Hn}}}}}{{AFf{ADd}}ADj}}314{{{b{{AGn{ce}}}}}{{ABn{f}}}Ad{{AFf{c}}}}{{}f}00000000```````{{AFje}{{Cl{{AFl{ce}}Dn}}}Ad{{AFf{c}}}}{{AFje}{{Cl{{AH`{ce}}Dn}}}Ad{{AFf{c}}}}186{{{b{{AH`{ADdc}}}}{b{{ADf{ADd}}}}}{{Ib{{I`{Hn}}}}}{{AFf{ADd}}ADj}}`9``3````````{{{b{AfAF`}}}{{Ib{{I`{Hn}}}}}}0`{{{b{AfAGd}}{Mj{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{AfAGf}}{AC`{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{AfAGd}}c}{{Ib{{I`{Hn}}}}}{{AAb{Ch}}H`}}{{{b{AfAGf}}{ACd{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{AfAGf}}}{{Ib{{I`{Hn}}}}}}4{{{b{AfAF`}}eCd}{{Ib{{I`{Hn}}}}}Ad{{B`{{ACf{c}}}}H`Hb}}{{{b{AfAGh}}}{{Ib{{I`{Hn}}}}}}{{{b{AfAGd}}{Mh{c}}}{{Ib{{I`{Hn}}}}}Ad}5{{{b{AfAGj}}{ACj{ce}}}{{Ib{{I`{Hn}}}}}Ad{{ACl{c}}}}86{{{b{AfAGf}}An}{{Ib{{I`{Hn}}}}}}{{{b{AfAGd}}{AAd{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{AfAGf}}{AD`{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{AfAGf}}{ADb{c}}}{{Ib{{I`{Hn}}}}}Ad}<:`=``={{{b{AfAF`}}e}{{Ib{{I`{Hn}}}}}Ad{{B`{{Mj{c}}}}H`Hb}}````{{{b{Af{AHb{e}}}}}{{Ib{{I`{Hn}}}}}Ad{AHd{AHj{}{{AHf{{AHh{c}}}}}}H`}}{b{{b{c}}}{}}00{{{b{Af}}}{{b{Afc}}}{}}00{{{AHb{{AHl{{AHh{c}}}}}}}{{ABn{f}}}Ad}{{{AHb{{AHn{{AHh{c}}}}}}}{{ABn{f}}}Ad}4{{{b{AFn}}}{{Cl{{AG`{c}}AI`}}}Ad}{{{b{AfAGb}}}{{Cl{{AG`{c}}AI`}}}Ad}{Ch{{b{c}}}{}}00{Ch{{b{Afc}}}{}}00{{b{b{Afc}}}{{Cl{{D`{eg}}}}}{}{}{}}00{Chf}0{{{b{Af{AHb{c}}}}}fAHd}1{{{b{{AHh{c}}}}{b{AfEb}}}EhAd}{{{b{{AG`{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{AHb{c}}}}{b{AfEb}}}Eh{EfAHd}}{cc{}}00{{{b{Af{AHb{e}}}}{Mj{c}}}{{Ib{{I`{Hn}}}}}Ad{AHd{AHj{}{{AHf{{AHh{c}}}}}}H`Hb}}{{{b{Af{AHb{e}}}}g}{{Ib{{I`{Hn}}}}}Ad{AHd{AHj{}{{AHf{{AHh{c}}}}}}H`Hb}{{AAb{Ch}}H`}}1{{{b{Af{AHb{e}}}}gCd}{{Ib{{I`{Hn}}}}}Ad{AHd{AHj{}{{AHf{{AHh{c}}}}}}H`}{{B`{{ACf{c}}}}H`Hb}}{{{b{Af{AHb{e}}}}{Mh{c}}}{{Ib{{I`{Hn}}}}}Ad{AHd{AHj{}{{AHf{{AHh{c}}}}}}H`Hb}}232{{{b{Af{AHb{e}}}}{AAd{c}}}{{Ib{{I`{Hn}}}}}Ad{AHd{AHj{}{{AHf{{AHh{c}}}}}}H`Hb}}43{{}Ch}00{{{b{Af{AHb{{AHl{{AHh{c}}}}}}}}{Ml{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{Af{AHb{{AHl{{AHh{c}}}}}}}}{K`{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{Af{AHb{{AHl{{AHh{c}}}}}}}}{Kf{c}}{n{AAl}}}{{Ib{{I`{Hn}}}}}Ad}{{}c{}}00{{}{{Cl{HhHj}}}}00{{{b{AFn}}}{{Cl{{AG`{c}}AI`}}}Ad}{{{b{AfAGb}}}{{Cl{{AG`{c}}AI`}}}Ad}{{{b{Af{AHb{e}}}}}{{Ib{{I`{Hn}}}}}Ad{AHd{AHj{}{{AHf{{AHh{c}}}}}}H`}}{b}00{{{b{{AG`{c}}}}}{{ABn{e}}}Ad{}}{{{b{AfAHd}}}f}{{{AHb{{AHn{{AHh{c}}}}}}}{{`{HnH`}}}Ad}{{{AHb{{AHl{{AHh{c}}}}}}}{{`{HnH`}}}Ad}{{{b{{AG`{c}}}}}{{Cl{fAI`}}}Ad}6{c{{Cl{e}}}{}{}}00{{}{{Cl{c}}}{}}00{bJl}00{{{b{Af}}{b{{ADf{c}}}}}{{Ib{{I`{Hn}}}}}{}}{{{b{Af{AHb{e}}}}g}{{Ib{{I`{Hn}}}}}Ad{AHd{AHj{}{{AHf{{AHh{c}}}}}}H`}{{B`{{Mj{c}}}}H`Hb}}???9``{{bd}f}{{{b{AfAIb}}}{{Ib{{I`{Hn}}}}}}{b{{b{c}}}{}}0{{{b{Af}}}{{b{Afc}}}{}}0{{{b{AId}}}AId}{{b{b{Afc}}}f{}}{bf}{AIb{{ABn{f}}}}6{{}AId}{Ch{{b{c}}}{}}0{Ch{{b{Afc}}}{}}0{{b{b{Afc}}}{{Cl{{D`{eg}}}}}{}{}{}}0{Chf}0{{{b{AId}}{b{AfEb}}}Eh}{cc{}}0{{{b{AfAIb}}{Mj{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{AfAIb}}c}{{Ib{{I`{Hn}}}}}{{AAb{Ch}}H`}}1{{{b{AfAIb}}eCd}{{Ib{{I`{Hn}}}}}Ad{{B`{{ACf{c}}}}H`Hb}}{{{b{AfAIb}}{Mh{c}}}{{Ib{{I`{Hn}}}}}Ad}232{{{b{AfAIb}}{AAd{c}}}{{Ib{{I`{Hn}}}}}Ad}43{{}Ch}0{{{b{AfAIb}}{Ml{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{AfAIb}}{K`{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{AfAIb}}{Kf{c}}{n{AAl}}}{{Ib{{I`{Hn}}}}}Ad}{{}c{}}0{{}{{Cl{HhHj}}}}0{{{b{AfAIb}}}{{Ib{{I`{Hn}}}}}}{b}0{{{b{AId}}}{{ABn{c}}}{}}{AIb{{`{HnH`}}}}3`{bc{}}{c{{Cl{e}}}{}{}}0{{}{{Cl{c}}}{}}0{bJl}0{{{b{Af}}{b{{ADf{c}}}}}{{Ib{{I`{Hn}}}}}{}}{{{b{AfAIb}}e}{{Ib{{I`{Hn}}}}}Ad{{B`{{Mj{c}}}}H`Hb}};;7`````````{{bd}f}{{{b{Af{AIf{c}}}}}{{Ib{{I`{Hn}}}}}{{AF`{ADd}}H`}}{{{b{AIh}}}{{Ib{{I`{Hn}}}}}}0{b{{b{c}}}{}}00{{{b{Af}}}{{b{Afc}}}{}}00{{{b{AIh}}}AIh}{{b{b{Afc}}}f{}}{bf}{{{AIf{c}}}{{ABn{f}}}ABl}{{{b{c}}}{{Ib{{I`{Hn}}}}}{}}87{Ch{{Ib{{I`{Hn}}}}}}{Ch{{b{c}}}{}}00{Ch{{b{Afc}}}{}}00{{b{b{Afc}}}{{Cl{{D`{eg}}}}}{}{}{}}00{Chf}00{{{b{AIh}}{b{AfEb}}}Eh}{cc{}}00{{{b{AIh}}c}{{Ib{{I`{Hn}}}}}{{B`{{Mj{ADd}}}}H`Hb}}{{{b{AIh}}c}{{Ib{{I`{Hn}}}}}{{AAb{Ch}}H`}}{{{b{Af{AIf{c}}}}eCd}{{Ib{{I`{Hn}}}}}{{AF`{ADd}}H`}{{B`{{ACf{ADd}}}}H`Hb}}{{{b{AIh}}cCd}{{Ib{{I`{Hn}}}}}{{B`{{ACf{ADd}}}}H`Hb}}{{{b{AIh}}c}{{Ib{{I`{Hn}}}}}{{B`{{Mh{ADd}}}}H`Hb}}343{{{b{AIh}}{AAd{ADd}}}{{Ib{{I`{Hn}}}}}}54{{{b{AIh}}{b{{ADf{ADd}}}}}{{Ib{{I`{Hn}}}}}}{{}Ch}00{{{b{Af{AIf{c}}}}{Ml{ADd}}}{{Ib{{I`{Hn}}}}}{{AAj{ADd}}H`Hb}}{{{b{Af{AIf{c}}}}{K`{ADd}}}{{Ib{{I`{Hn}}}}}{{AAj{ADd}}H`Hb}}{{{b{Af{AIf{c}}}}{Kf{ADd}}{n{AAl}}}{{Ib{{I`{Hn}}}}}{{AAj{ADd}}H`Hb}}{{}c{}}00{{}{{Cl{HhHj}}}}00{{{b{AIh}}}{{b{AEb}}}}{{{b{Af{AIf{c}}}}}{{Ib{{I`{Hn}}}}}{{AF`{ADd}}H`}}{{{b{AIh}}}{{Ib{{I`{Hn}}}}}}{b}00{b{{I`{AEd}}}}{{{b{AIh}}}{{ABn{c}}}{}}{{{b{c}}}{{Ib{{I`{Hn}}}}}{}}{{{AIf{c}}}{{`{HnH`}}}ABl}{{{b{Af{AIj{AIh}}}}}{{Ib{{I`{Hn}}}}}}76{bc{}}{c{{Cl{e}}}{}{}}00{{}{{Cl{c}}}{}}00{bJl}00{{{b{Af}}{b{{ADf{c}}}}}{{Ib{{I`{Hn}}}}}{}}{{{b{Af{AIf{c}}}}e}{{Ib{{I`{Hn}}}}}{{AF`{ADd}}H`}{{B`{{Mj{ADd}}}}H`Hb}}{{{b{AIh}}c}{{Ib{{I`{Hn}}}}}{{B`{{Mj{ADd}}}}H`Hb}}{{}c{}}00;``````{{bd}f}{{{b{AIl}}}Cd}{b{{b{c}}}{}}{{{b{Af}}}{{b{Afc}}}{}}{{{b{AIl}}}AIl}{{b{b{Afc}}}f{}}{bf}{{}AIl}{Ch{{b{c}}}{}}{Ch{{b{Afc}}}{}}{{b{b{Afc}}}{{Cl{{D`{eg}}}}}{}{}{}}{Chf}{{{b{AIl}}{b{AfEb}}}Eh}{cc{}}{{{b{{AFd{}{{AIn{c}}}}}}}{{Ib{{I`{Hn}}}}}{ADjH`}}{{{b{AJ`}}}{{n{AIl}}}}{{}Ch}{{{b{AIl}}}ABf}{{}c{}}{{}{{Cl{HhHj}}}}{{{b{AfAGl}}}{{Ib{{I`{Hn}}}}}}{{{b{AIl}}}AJb}4>{b}{{{b{{AFd{}{{AIn{c}}}}}}{b{Afc}}}{{Ib{{I`{Hn}}}}}{ADjH`}}{{{b{AIl}}}{{n{Cd}}}}{{{b{AfAJ`}}AIl}f}8{bc{}}{c{{Cl{e}}}{}{}}{{}{{Cl{c}}}{}}{bJl}{{{b{AIl}}}{{ABn{f}}}}<{{AIlCd}AIl}{{AIlABf}AIl}{{AIlAJb}AIl}121`````````````````````````````````{{bd}f}000{{AJdAnAJfCd}AJh}{{{b{AJh}}}{{n{{b{AJf}}}}}}{{{AJj{c}}}{{AJj{c}}}AJl}{{{b{Dn}}}{{b{h}}}}0{{{b{Dn}}}{{b{l}}}}{{{b{Af}}}{{`{{Hn{}{{Id{{ABn{f}}}}}}H`}}}}{{{b{Af}}}{{ABn{f}}}}0{{AJnAK`}AK`}{{{b{AfAKb}}c}{{AKd{An}}}{{AKh{AKf}}{AKj{AKf}}}}{{{b{Af{AKl{c}}}}}{{Ib{{I`{Hn}}}}}AKn}{b{{b{c}}}{}}0000000000{{{b{Af}}}{{b{Afc}}}{}}0000000000{{{b{AfAKb}}c{b{Cj}}}{{AKd{An}}}{{AAb{Ch}}}}{{{AJj{AL`}}e}{{Cl{{AFl{ce}}Dn}}}Ad{{AFf{c}}}}{{{b{Dn}}}ALb}{{{b{AJh}}}Cd}{{{b{Cj}}}{{Ib{{I`{Hn}}}}}}0{{}{{Ib{{I`{Hn}}}}}}0{{{b{AJh}}}AJh}{{{b{ALd}}}ALd}{{{b{ALf}}}ALf}{{{b{{AJj{c}}}}}{{AJj{c}}}{AJlBd}}{{b{b{Afc}}}f{}}000{bf}000{{{b{AJh}}{b{AJh}}}Nd}{{{AKl{c}}}{{ABn{f}}}AKn}{{b{b{c}}}Nd{}}{{{AJj{AL`}}e}{{Cl{{AH`{ce}}Dn}}}Ad{{AFf{c}}}}{{{AJj{c}}}{{Cl{ALhDn}}}AJl}{{{AJj{c}}ABf}{{AJj{c}}}AJl}{{Dnc}Dn{GnH`Hb}}{{{b{Af{AKl{c}}}}}{{Ib{{I`{Hn}}}}}AKn}??{{{AJj{AL`}}{b{Cj}}}{{AJj{AL`}}}}{{{b{Cj}}}{{Ib{{I`{Hn}}}}}}0{{}AKb}{{}ALd}{{}ALf}{{}{{AJj{AL`}}}}{{}ALj}{{}{{ADn{AJh}}}}{{{b{Dn}}}b}{Ch{{b{c}}}{}}000000{{{b{{AKl{c}}}}}{{b{e}}}{}{}}1111{Ch{{b{Afc}}}{}}{{{b{AfDn}}}{{b{Af}}}}111111{{{b{Af{AKl{c}}}}}{{b{Afe}}}{}{}}2222{{b{b{Afc}}}{{Cl{{D`{eg}}}}}{}{}{}}0000000000{Dn{{Cl{cDn}}}{GnEfH`Hb}}{{{b{AfDn}}}{{n{{b{Afc}}}}}{GnEfH`Hb}}{{{b{Dn}}}{{n{{b{c}}}}}{GnEfH`Hb}}{{{b{AfDn}}}f}{Chf}0000000000{{{b{Cj}}}{{Ib{{I`{Hn}}}}}}0{{{b{AJh}}{b{AJh}}}Db}{{b{b{c}}}Db{}}000{{{ALn{}{{ALl{c}}}}e}{{Ib{{I`{Hn}}}}}AJl{{AM`{c}}}}0{{{ALn{}{{ALl{c}}}}e}{{Ib{{I`{A@n}}}}}AJl{{AM`{c}}}}0{{{b{Af{AKl{ALd}}}}c}{{ABn{Cd}}}{{AM`{AKf}}}}{{{b{Af{AKl{ALd}}}}{b{Cj}}c}{{ABn{Cd}}}{AJnBd}}{{{b{Af{AKl{ALd}}}}c}{{ABn{f}}}{{AM`{AKf}}}}{{{b{Af{AKl{ALd}}}}{b{Cj}}c}{{ABn{f}}}{AJnBd}}44554555{{{b{Dn}}{b{AfEb}}}{{Cl{fEd}}}}0{{{b{AJh}}{b{AfEb}}}{{Cl{fEd}}}}0{{{b{AMb}}{b{AfEb}}}{{Cl{fEd}}}}{{{b{AL`}}{b{AfEb}}}{{Cl{fEd}}}}{{{b{AKb}}{b{AfEb}}}Eh}{{{b{ALd}}{b{AfEb}}}Eh}{{{b{ALf}}{b{AfEb}}}Eh}{{{b{{AKl{c}}}}{b{AfEb}}}EhEf}{{{b{{AJj{c}}}}{b{AfEb}}}Eh{AJlEf}}{{{b{ALh}}{b{AfEb}}}Eh}{{{b{ALj}}{b{AfEb}}}Eh}{b{{AMd{AMb}}}}{b{{AMd{AL`}}}}{{{b{Cj}}}{{Ib{{I`{Hn}}}}}}{Fjc{}}{cc{}}{cDn{hH`Hb}}11111111{AMf{{AJj{AL`}}}}22{{{b{Cj}}}{{Cl{{AJj{AL`}}c}}}{}}{{{b{Af{AKl{c}}}}{Mj{e}}}{{Ib{{I`{Hn}}}}}AKnAd}{{{b{Af{AKl{c}}}}{AC`{e}}}{{Ib{{I`{Hn}}}}}AKnAd}{{{b{Af{AKl{c}}}}e}{{Ib{{I`{Hn}}}}}AKn{{AAb{Ch}}H`}}{{{b{Af{AKl{c}}}}{ACd{e}}}{{Ib{{I`{Hn}}}}}AKnAd}{{{b{ALh}}}{{Ib{{I`{Hn}}}}}}{{{b{Af{AKl{c}}}}}{{Ib{{I`{Hn}}}}}AKn}{b{{n{{b{Cj}}}}}}06{{{b{Af{AKl{c}}}}gCd}{{Ib{{I`{Hn}}}}}AKnAd{{B`{{ACf{e}}}}H`Hb}}2{{{b{Af{AKl{c}}}}{Mh{e}}}{{Ib{{I`{Hn}}}}}AKnAd}6{{{b{Af{AKl{c}}}}{ACj{eg}}}{{Ib{{I`{Hn}}}}}AKnAd{{ACl{e}}}}97{{{b{ALh}}}{{n{AIl}}}}{{{b{Af{AKl{c}}}}An}{{Ib{{I`{Hn}}}}}AKn}{{{b{Af{AKl{c}}}}{AAd{e}}}{{Ib{{I`{Hn}}}}}AKnAd}{{{b{Af{AKl{c}}}}{AD`{e}}}{{Ib{{I`{Hn}}}}}AKnAd}{{{b{Af{AKl{c}}}}{ADb{e}}}{{Ib{{I`{Hn}}}}}AKnAd}><{c{{Gl{ce}}}{GnH`Hb}{}}0{{{b{AfAKb}}{Mj{c}}}{{AKd{An}}}Ad}{{{AJj{AL`}}c}{{AJj{AL`}}}{{B`{An}}}}{{{AJj{c}}ABf}{{AJj{c}}}AJl}``{{}Ch}0000000000{{{b{Af{AKl{ALd}}}}{Ml{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{Af{AKl{ALd}}}}{K`{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{Af{AKl{ALd}}}}ADl{ADn{Ch}}Cd}{{Ib{{I`{Hn}}}}}}{{{b{Af{AKl{ALd}}}}{Kf{c}}{n{AAl}}}{{Ib{{I`{Hn}}}}}Ad}{{}c{}}0000000000{{{b{Dn}}}Db}{{}{{Cl{HhHj}}}}0000000000{{{b{Af{AKl{c}}}}g}{{AKd{{AAh{e}}}}}{}Ad{{B`{{Mj{e}}}}H`}}{{{b{Af{AKl{c}}}}}{{Ib{{I`{Hn}}}}}AKn}{{{AJj{c}}AMh}{{AJj{c}}}AJl}{{{AJj{c}}e}{{AJj{c}}}AJl{{AMj{}{{Md{AJh}}}}}}1{cDn{GnEfH`Hb}}{{{b{AJh}}}{{b{Cj}}}}{cDn{hH`Hb}}{{{AJj{c}}}{{AJj{c}}}AJl}{b{{n{{b{Cj}}}}}}0{{{b{AJh}}{b{AJh}}}{{n{Nd}}}}{{{AJj{AL`}}{b{Cj}}}{{AJj{AL`}}}}9{b}0000000000{{{AJj{AL`}}AJb}{{AJj{AL`}}}}{{{b{AJh}}}{{b{AMl}}}}{{{ALn{}{{ALl{c}}}}{b{Cj}}}{{Ib{{I`{Hn}}}}}AJl}0{{{ALn{}{{ALl{c}}}}{b{Cj}}{b{AMn}}}{{Ib{{I`{Hn}}}}}AJl}{{{b{ALh}}{b{AfALj}}}{{Ib{{I`{Hn}}}}}}{{{AJj{c}}AIl}{{Cl{{AJj{c}}Dn}}}AJl}{{{b{Cj}}}AK`}{{AKb{b{Cj}}}AK`}{{{b{Cj}}}{{AN`{c}}}ANb}{{AKb{b{Cj}}}{{AN`{c}}}ANb}{{{b{ALh}}}{{ABn{{AKl{ALf}}}}}}?>>{{{AKl{c}}}{{`{HnH`}}}AKn}{{{b{Dn}}}{{b{h}}}}{{{AJj{c}}e}{{AJj{c}}}AJl{{B`{An}}}}{{{b{AfAJh}}}f}{{{b{Af{AKl{ALd}}}}Ch}{{Ib{{I`{Hn}}}}}}{{{b{AfALh}}AIl}f}{{{b{Af}}}{{Ib{{I`{Hn}}}}}}0{{{b{AJh}}}{{n{{b{Cj}}}}}}`{{{b{Af{AKl{c}}}}}{{Ib{{I`{Hn}}}}}AKn}{{{b{ANd}}}{{Ib{{I`{Hn}}}}}}0`{{{AJj{AL`}}}{{AJj{AL`}}}}{bc{}}000{bAn}0{c{{Cl{e}}}{}{}}0000000000{{}{{Cl{c}}}{}}0000000000{bJl}0000000000{{{b{Cj}}{b{Cj}}}{{Cl{AJhANf}}}}{{{b{Af}}{b{{ADf{c}}}}}{{Ib{{I`{Hn}}}}}{}}{{{b{Af{AKl{ALd}}}}{b{Cj}}{ANh{{b{Cj}}}}ce}{{ABn{f}}}{{AMj{}{{Md{{b{Cj}}}}}}}AMj}{{{AJj{AL`}}{b{Cj}}}{{AJj{AL`}}}}{{{b{AJh}}}AMh}{{{b{Af{AKl{c}}}}g}{{Ib{{I`{Hn}}}}}AKnAd{{B`{{Mj{e}}}}H`Hb}}{{}c{}}0000000000{{{b{ALh}}}{{ABn{{AKl{ALd}}}}}}``{b{{b{c}}}{}}0{{{b{Af}}}{{b{Afc}}}{}}0{{{b{ANj}}}{{AJj{AL`}}}}{Ch{{b{c}}}{}}0{Ch{{b{Afc}}}{}}0{{b{b{Afc}}}{{Cl{{D`{eg}}}}}{}{}{}}0{Chf}{{{b{AfANj}}}f}1{{{b{ANj}}{b{AfEb}}}Eh}{cc{}}0{{{b{ANj}}}An}{{}Ch}{{}ANj}1>>{{}{{Cl{HhHj}}}}01{b}0{{{b{ANj}}}AJb}88{c{{Cl{e}}}{}{}}0{{}{{Cl{c}}}{}}0{bJl}0{{}c{}}0`````````````````````````````````````````````````````````````````````````````````````````````````````{{bd}f}000000000000000{{ANlANl}c{}}{b{{b{h}}}}00000000000000000000000``````````{b{{b{c}}}{}}0000000000000000000000000000000000{{{b{Af}}}{{b{Afc}}}{}}0000000000000000000000000000000000{ANnANl}{{{b{AO`}}}AO`}{{{b{AOb}}}AOb}{{{b{AOd}}}AOd}{{{b{ANl}}}ANl}{{{b{{AC`{c}}}}}{{AC`{c}}}{BdAd}}{{{b{{AD`{c}}}}}{{AD`{c}}}{BdAd}}{{{b{{AOf{c}}}}}{{AOf{c}}}{BdAd}}{{{b{{AOh{c}}}}}{{AOh{c}}}{BdAd}}{{{b{AOj}}}AOj}{{{b{AOl}}}AOl}{{{b{AOn}}}AOn}{{{b{B@`}}}B@`}{{{b{B@b}}}B@b}{{{b{B@d}}}B@d}{{{b{B@f}}}B@f}{{{b{En}}}En}{{b{b{Afc}}}f{}}000000000000000{bf}000000000000000{{{b{AOd}}{b{AOd}}}Nd}{{b{b{c}}}Nd{}}````{{}{{ADb{c}}}Ad}{c{{Cl{{Of{eEnc}}Oh}}}Jf{H`HbOj}}{Ch{{b{c}}}{}}0000000000000000000000000000000000{Ch{{b{Afc}}}{}}0000000000000000000000000000000000{{b{b{Afc}}}{{Cl{{D`{eg}}}}}{}{}{}}{c{{Cl{AO`}}}Cn}1{c{{Cl{AOb}}}Cn}2{c{{Cl{AOd}}}Cn}3{c{{Cl{ANl}}}Cn}4444{c{{Cl{AOj}}}Cn}55{c{{Cl{{B@h{e}}}}}CnAd}6{c{{Cl{{B@j{e}}}}}CnAd}77{c{{Cl{B@l}}}Cn}{c{{Cl{{B@n{e}}}}}CnAd}99{c{{Cl{{BA`{e}}}}}CnAd}:{c{{Cl{BAb}}}Cn};;;{c{{Cl{BAd}}}Cn}<{c{{Cl{BAf}}}Cn}{c{{Cl{{BAh{e}}}}}CnAd}>>{c{{Cl{{BAj{e}}}}}CnAd}?{c{{Cl{AOl}}}Cn}{{b{b{Afc}}}{{Cl{{D`{eg}}}}}{}{}{}}{c{{Cl{AOn}}}Cn}1{c{{Cl{B@`}}}Cn}{c{{Cl{B@b}}}Cn}33{c{{Cl{B@d}}}Cn}4{c{{Cl{B@f}}}Cn}5{c{{Cl{En}}}Cn}6{c{{Cl{{BAl{e}}}}}CnAd}{c{{Cl{{BAn{e}}}}}CnAd}88{c{{Cl{{BB`{e}}}}}CnAd}9{c{{Cl{{BBb{e}}}}}CnAd}:{c{{Cl{{BBd{e}}}}}CnAd}{c{{Cl{{BBf{e}}}}}CnAd}<{Chf}0000000000000000000000000000000000{{{b{AOd}}{b{AOd}}}Db}{{{b{ANl}}{b{ANl}}}Db}{{{b{{AC`{c}}}}{b{{AC`{c}}}}}Db{LlAd}}{{{b{{AD`{c}}}}{b{{AD`{c}}}}}Db{LlAd}}{{{b{{AOf{c}}}}{b{{AOf{c}}}}}Db{LlAd}}{{{b{{AOh{c}}}}{b{{AOh{c}}}}}Db{LlAd}}{{{b{AOj}}{b{AOj}}}Db}{{{b{{B@h{c}}}}{b{{B@h{c}}}}}Db{LlAd}}{{{b{{B@j{c}}}}{b{{B@j{c}}}}}Db{LlAd}}{{{b{Ff}}{b{Ff}}}Db}{{{b{B@l}}{b{B@l}}}Db}{{{b{{B@n{c}}}}{b{{B@n{c}}}}}Db{LlAd}}{{{b{{BA`{c}}}}{b{{BA`{c}}}}}Db{LlAd}}{{{b{{ACd{c}}}}{b{{ACd{c}}}}}Db{LlAd}}{{b{b{c}}}Db{}}0000000000000000000000000000000000000000000000000000000{ANnANl}0``{{{b{{BC`{}{{BBh{c}}{BBj{e}}{BBl{g}}{BBn{i}}}}}}}e{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}}{{{b{{BC`{}{{BBh{c}}{BBj{e}}{BBl{g}}{BBn{i}}}}}}}c{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}}```{{{b{AO`}}{b{AfEb}}}Eh}0{{{b{AOb}}{b{AfEb}}}Eh}0{{{b{AOd}}{b{AfEb}}}Eh}0{{{b{ANl}}{b{AfEb}}}Eh}0{{{b{{AC`{c}}}}{b{AfEb}}}EhAd}{{{b{{AC`{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{AD`{c}}}}{b{AfEb}}}EhAd}{{{b{{AD`{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{AOf{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{AOh{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{AOj}}{b{AfEb}}}Eh}{{{b{{B@h{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{B@j{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{Ff}}{b{AfEb}}}Eh}0{{{b{B@l}}{b{AfEb}}}Eh}{{{b{{B@n{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{BA`{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{ACd{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{BAb}}{b{AfEb}}}Eh}{{{b{{ADb{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{BAd}}{b{AfEb}}}Eh}{{{b{BAf}}{b{AfEb}}}Eh}{{{b{{BAh{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{BAj{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{AOl}}{b{AfEb}}}Eh}0{{{b{AOn}}{b{AfEb}}}Eh}0{{{b{B@`}}{b{AfEb}}}Eh}0{{{b{B@b}}{b{AfEb}}}Eh}0{{{b{B@d}}{b{AfEb}}}Eh}0{{{b{B@f}}{b{AfEb}}}Eh}0{{{b{En}}{b{AfEb}}}Eh}0{{{b{{BAl{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{BAn{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{BB`{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{BBb{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{BBd{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{BBf{c}}}}{b{AfEb}}}Eh{EfAd}}{cc{}}000{ANnANl}1111111{BCbFf}{BCdFf}333333333333{A`AOl}{FhAOl}{FhAOn}6{A`AOn}{A`B@`}8{FhB@`}{FfB@`}{FhB@b};{A`B@b}{AOnB@d}{A`B@d}{FhB@d}?{B@bB@d}{AOlB@d}{A`B@f}{cc{}}{FhB@f}1{{{B@h{c}}}{{BAl{c}}}Ad}22{{{ADn{{B@j{c}}}}}{{BAn{c}}}Ad}3{{{ADn{{BA`{c}}}}}{{BBb{c}}}Ad}44{{{BAh{c}}}{{BBd{c}}}Ad}5{{{BAj{c}}}{{BBf{c}}}Ad}{b{{A@d{{B@h{c}}}}}Ad}{b{{A@d{{B@j{c}}}}}Ad}`{{{b{ACb}}{AC`{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{ACb}}{ACd{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{ACb}}}{{Ib{{I`{Hn}}}}}}{{{b{ACb}}An}{{Ib{{I`{Hn}}}}}}{{{b{ACb}}{AD`{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{ACb}}{ADb{c}}}{{Ib{{I`{Hn}}}}}Ad}````{c{{Gl{ce}}}{GnH`Hb}{}}0000000000000`````{{}}0000000{{}Ch}0000000000000000000000000000000000{{}c{}}0000000000000000000000000000000000{{}{{BCf{An}}}}{{{b{AOd}}}Db}00```{{}{{Cl{HhHj}}}}0000000000000000000000000000000000{{{b{{BCh{}{{BBn{c}}}}}}}c{BdEfJhMbH`HbLlLn}}{{{b{{BC`{}{{BBh{c}}{BBj{e}}{BBl{g}}{BBn{i}}}}}}}{{ADn{i}}}{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}}{{AOdANn}ANl}````````{{{b{AOd}}{b{AOd}}}{{n{Nd}}}}{b}0000000000000000000000000000000000{{{b{{BC`{}{{BBh{c}}{BBj{e}}{BBl{g}}{BBn{i}}}}}}}g{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}}```{{{b{{BC`{}{{BBh{c}}{BBj{e}}{BBl{g}}{BBn{i}}}}}}}c{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}}````{{{b{AO`}}c}ClJj}{{{b{AOb}}c}ClJj}{{{b{AOd}}c}ClJj}{{{b{ANl}}c}ClJj}{{{b{AOj}}c}ClJj}{{{b{{B@h{c}}}}e}ClAdJj}{{{b{{B@j{c}}}}e}ClAdJj}{{{b{B@l}}c}ClJj}{{{b{{B@n{c}}}}e}ClAdJj}{{{b{{BA`{c}}}}e}ClAdJj}{{{b{BAb}}c}ClJj}{{{b{BAd}}c}ClJj}{{{b{BAf}}c}ClJj}{{{b{{BAh{c}}}}e}ClAdJj}{{{b{{BAj{c}}}}e}ClAdJj}{{{b{AOl}}c}ClJj}{{{b{AOn}}c}ClJj}{{{b{B@`}}c}ClJj}{{{b{B@b}}c}ClJj}{{{b{B@d}}c}ClJj}{{{b{B@f}}c}ClJj}{{{b{En}}c}ClJj}{{{b{{BAl{c}}}}e}ClAdJj}{{{b{{BAn{c}}}}e}ClAdJj}{{{b{{BB`{c}}}}e}ClAdJj}{{{b{{BBb{c}}}}e}ClAdJj}{{{b{{BBd{c}}}}e}ClAdJj}{{{b{{BBf{c}}}}e}ClAdJj}{{{b{AOd}}}Ch}```{{{b{Ff}}}{{n{{b{h}}}}}}{{{b{AOl}}}{{n{{b{h}}}}}}{{{b{AOn}}}{{n{{b{h}}}}}}{{{b{B@`}}}{{n{{b{h}}}}}}{{{b{B@b}}}{{n{{b{h}}}}}}{{{b{B@d}}}{{n{{b{h}}}}}}{{{b{B@f}}}{{n{{b{h}}}}}}{{{b{En}}}{{n{{b{h}}}}}}{{{b{AOl}}}Bb}{{{b{AOn}}}Bb}{{{b{B@`}}}Bb}{{{b{B@b}}}Bb}{{{b{B@d}}}Bb}{{{b{B@f}}}Bb}{{{b{En}}}Bb}{{ANlANl}c{}}```````{bc{}}000000000000000{bAn}0000000000000````{c{{Cl{e}}}{}{}}00{{{b{Cj}}}{{Cl{AOdc}}}{}}1111111{{{Ml{c}}}{{Cl{{B@h{c}}e}}}Ad{}}{{{Ml{c}}}{{Cl{{B@j{c}}e}}}Ad{}}3333{{{F`{{b{{Ml{c}}}}Ch}}}{{Cl{{BA`{c}}e}}}Ad{}}444444444444444444444{{}{{Cl{c}}}{}}0000000000000000000000000000000000{bJl}0000000000000000000000000000000000{ANnANl}`{{}c{}}0000000000000000000000000000000000`````{{bd}f}{b{{b{c}}}{}}{{{b{Af}}}{{b{Afc}}}{}}{{{b{{BCj{ce}}}}}{{BCj{ce}}}{}{}}{{b{b{Afc}}}f{}}{bf}{{}{{BCj{ce}}}{}{}}{Ch{{b{c}}}{}}{Ch{{b{Afc}}}{}}{{b{b{Afc}}}{{Cl{{D`{eg}}}}}{}{}{}}{Chf}{{{b{{BCj{ce}}}}{b{AfEb}}}Eh{}{}}{cc{}}{{}Ch}>{{}{{Cl{HhHj}}}}{b}``{{BClc}f{}}{{BCnc}{{`{{Hn{}{{Id{f}}}}H`}}}{}}{{{b{{BCj{eg}}}}eik}f{}{{BD`{c}}}BCn{{BDb{ce}}}{{AMj{}{{Md{g}}}}H`}}{bc{}}{c{{Cl{e}}}{}{}}{{}{{Cl{c}}}{}}{bJl}{{}c{}}{{{BCj{ce}}{Dl{BDd}}}{{BCj{ce}}}{}{}}{{{BCj{ce}}ABf}{{BCj{ce}}}{}{}}`````{{bd}f}000{{{b{{BDf{c}}}}}f{}}{b{{b{c}}}{}}000{{{b{Af}}}{{b{Afc}}}{}}000{{{b{{BDh{c}}}}}{{BDh{c}}}Ad}{{{b{{BDj{c}}}}}{{BDj{c}}}{BdJf}}{{{b{{BDf{c}}}}}{{BDf{c}}}{}}{{{b{BDl}}}BDl}{{b{b{Afc}}}f{}}000{bf}000{{}{{BDh{c}}}Ad}{{}BDl}{Ch{{b{c}}}{}}000{Ch{{b{Afc}}}{}}000{{b{b{Afc}}}{{Cl{{D`{eg}}}}}{}{}{}}000{Chf}000>{{{b{BDb}}e}{{Ib{{I`{Hn}}}}}{}{{BD`{c}}}}{{{b{{BDh{c}}}}BDn}{{Ib{{I`{Hn}}}}}Ad}{{{b{{BDh{c}}}}BE`}{{Ib{{I`{Hn}}}}}Ad}{{{b{{BDh{c}}}}BEb}{{Ib{{I`{Hn}}}}}Ad}{{{b{{BDj{c}}}}BEb}{{Ib{{I`{Hn}}}}}Jf}{{{b{{BDj{c}}}}BE`}{{Ib{{I`{Hn}}}}}Jf}{{{b{{BDj{c}}}}BDn}{{Ib{{I`{Hn}}}}}Jf}{{{b{{BDf{g}}}}e}{{Ib{{I`{Hn}}}}}Ad{{BD`{c}}}{{BDb{ce}}Hb}}{{{b{BDl}}e}{{Ib{{I`{Hn}}}}}{}{H`{BD`{c}}}}{{{b{{BDh{c}}}}{b{AfEb}}}EhAd}{{{b{{BDj{c}}}}{b{AfEb}}}Eh{EfJf}}{{{b{{BDf{c}}}}{b{AfEb}}}EhEf}{{{b{BDl}}{b{AfEb}}}Eh}{cc{}}000{{}Ch}000{{}c{}}000{{}{{Cl{HhHj}}}}000{{BEdc}{{BDj{c}}}Jf}{c{{BDf{c}}}{}}{b}000{bc{}}000{c{{Cl{e}}}{}{}}000{{}{{Cl{c}}}{}}000{bJl}000{{{b{{BDf{c}}}}}f{}}09999{{{BDh{c}}e}{{BDh{c}}}Ad{{BDb{cBDn}}Ef}}{{{BDh{c}}e}{{BDh{c}}}Ad{{BDb{cBE`}}Ef}}{{{BDh{c}}e}{{BDh{c}}}Ad{{AFf{c}}Ef}}{{{BDh{c}}e}{{BDh{c}}}Ad{{BDb{cBEb}}Ef}}`````{{bd}f}00{b{{b{c}}}{}}00{{{b{Af}}}{{b{Afc}}}{}}00{{{b{BDn}}}BDn}{{{b{BEb}}}BEb}{{{b{BE`}}}BE`}{{b{b{Afc}}}f{}}00{bf}00{Ch{{b{c}}}{}}00{Ch{{b{Afc}}}{}}00{{b{b{Afc}}}{{Cl{{D`{eg}}}}}{}{}{}}00{Chf}00{{{b{BDn}}{b{BDn}}}Db}{{{b{BEb}}{b{BEb}}}Db}{{{b{BE`}}{b{BE`}}}Db}{{b{b{c}}}Db{}}00000000000{{{b{BDn}}{b{AfEb}}}Eh}{{{b{BEb}}{b{AfEb}}}Eh}{{{b{BE`}}{b{AfEb}}}Eh}{cc{}}00{ChBE`}{{{b{c}}{b{e}}}Cd{GdGf}Gh}00{{{b{BDn}}{b{Afc}}}fGj}{{{b{BEb}}{b{Afc}}}fGj}{{{b{BE`}}{b{Afc}}}fGj}{{}Ch}00{{}c{}}00{{}{{Cl{HhHj}}}}00{b}00{bc{}}00{c{{Cl{e}}}{}{}}00{{}{{Cl{c}}}{}}00{bJl}00666`````````````````{{bd}f}0`{b{{b{h}}}}00{{{b{Fd}}}{{n{{b{l}}}}}}{b{{b{c}}}{}}00{{{b{Af}}}{{b{Afc}}}{}}00{{{b{Fd}}}{{n{{b{h}}}}}}{{{b{{ACj{ce}}}}}{{ACj{ce}}}Ad{{ACl{c}}}}{{{b{Fd}}}Fd}{{b{b{Afc}}}f{}}0{bf}0{{{b{{ACj{ce}}}}{b{{ACj{ce}}}}}NdAd{{ACl{c}}}}{{b{b{c}}}Nd{}}{{}BEf}{{{b{BEf}}}{{Cl{{Of{cFde}}Oh}}}{H`HbOj}Jf}{Ch{{b{c}}}{}}00{Ch{{b{Afc}}}{}}00{{{b{Fd}}}{{b{Cj}}}}{{b{b{Afc}}}{{Cl{{D`{eg}}}}}{}{}{}}00{c{{Cl{Fd}}}Cn}{Chf}00{{{b{{ACj{ce}}}}{b{{ACj{ce}}}}}DbAd{{ACl{c}}}}{{b{b{c}}}Db{}}000`{{{b{{ACj{ce}}}}{b{AfEb}}}EhAd{{ACl{c}}}}0{{{b{Fd}}{b{AfEb}}}Eh}0{cc{}}0{A`Fd}{{{F`{AnBb}}}Fd}{A@bFd}3{{{b{c}}{b{e}}}Cd{GdGf}Gh}{{{b{ACh}}}{{Ib{{I`{Hn}}}}}}{{{b{ACn}}{ACj{ce}}}{{Ib{{I`{Hn}}}}}Ad{{ACl{c}}}}{{{b{{ACj{ce}}}}{b{Afg}}}fAd{{ACl{c}}}Gj}{c{{Gl{ce}}}{GnH`Hb}{}}0{{}{{b{Cj}}}}{{}}{{}Ch}00{{{b{AfAE`}}ADl{ADn{Ch}}Cd}{{Ib{{I`{Hn}}}}}}{{{b{Af{ACl{}{{BEh{c}}{BEj{e}}{BEl{g}}{BEn{i}}{BF`{k}}}}}}c{b{{ADl{ecg}}}}}{{ABn{f}}}{BFbH`HbJhBFdBFfMbGnBFhBFj}{BFlH`HbJhMbBFhBFj}{BFnH`}{{BG`{g}}H`{BGd{{b{BGb}}}}GnEf{B`{BGb}}}{{BGf{ecg}}}}{{}c{}}00{{}{{Cl{HhHj}}}}00{{{b{{ACj{ce}}}}{b{{ACj{ce}}}}}{{n{Nd}}}Ad{{ACl{c}}}}{b}00{{{b{Fd}}c}ClJj}{{{b{AfAE`}}Ch}{{Ib{{I`{Hn}}}}}}{{{b{Fd}}}{{n{{b{h}}}}}};{{{b{Fd}}}Bb}{bc{}}0{bAn}0<{c{{Cl{e}}}{}{}}00{{}{{Cl{c}}}{}}00{bJl}00<<<````````````````{{bd}f}0000000{{{b{BGh}}Ch}f}{{{b{BGj}}BGl}f}{b{{b{h}}}}00{{{b{BGn}}}{{n{{b{l}}}}}}{b{{b{c}}}{}}00000000{{{b{Af}}}{{b{Afc}}}{}}00000000{{{b{BGn}}}{{n{{b{h}}}}}}{{{b{AEb}}}AEb}{{{b{BGh}}}BGh}{{{b{BH`}}}BH`}{{{b{BGj}}}BGj}{{{b{BHb}}}BHb}{{{b{BHd}}}BHd}{{{b{BHf}}}BHf}{{{b{BHh}}}BHh}{{b{b{Afc}}}f{}}0000000{bf}0000000{{{b{AEb}}An{ADn{An}}}{{I`{BHj}}}}{{{b{BHb}}{ADn{An}}}{{I`{BHl}}}}{{{b{BHd}}{ADn{An}}}{{I`{BHn}}}}{{{b{BHf}}{ADn{An}}}{{I`{BI`}}}}{{{b{BHh}}{ADn{An}}}f}{{{b{AEb}}An{n{An}}}{{I`{BHl}}}}{{{b{AEb}}An{n{An}}}{{I`{BHn}}}}{{{b{AEb}}An{n{An}}}{{I`{BI`}}}}{{{b{AEb}}An}f}{{}AEb}{Ch{{b{c}}}{}}00000000{Ch{{b{Afc}}}{}}00000000{{{b{BGn}}}{{b{Cj}}}}{{b{b{Afc}}}{{Cl{{D`{eg}}}}}{}{}{}}00000000{Chf}00000000{{{b{AEb}}}{{Cl{Anc}}}{}}{{{b{BGn}}{b{AfEb}}}Eh}0{{{b{AEb}}{b{AfEb}}}Eh}{{{b{BGh}}{b{AfEb}}}Eh}{{{b{BH`}}{b{AfEb}}}Eh}{{{b{BGj}}{b{AfEb}}}Eh}{{{b{BHb}}{b{AfEb}}}Eh}{{{b{BHd}}{b{AfEb}}}Eh}{{{b{BHf}}{b{AfEb}}}Eh}{{{b{BHh}}{b{AfEb}}}Eh}{cc{}}{BIbBGn}11111111{{{b{AEb}}An{ADn{An}}}{{I`{BId}}}}{{{b{AEb}}{b{Cj}}}{{Cl{BHdBGn}}}}{{{b{BGh}}}Ch}{{{b{BH`}}}Ch}{{{b{BHb}}{b{{AMn{c}}}}}BGh{{BIf{Cj}}}}{{{b{BHd}}{b{{AMn{c}}}}}BH`{{BIf{Cj}}}}{{{b{BHf}}{b{{AMn{c}}}}}BGj{{BIf{Cj}}}}{{{b{AEb}}{b{Cj}}}{{Cl{BGhBGn}}}}{{{b{AEb}}{b{Cj}}}{{Cl{BHbBGn}}}}{{{b{AEb}}{b{Cj}}}{{Cl{BH`BGn}}}}{{{b{AEb}}{b{Cj}}}{{Cl{BGjBGn}}}}{{{b{AEb}}{b{Cj}}}{{Cl{BHfBGn}}}}{{{b{AEb}}c}{{Cl{AEbBGn}}}AMj}{c{{Gl{ce}}}{GnH`Hb}{}}{{{b{AEb}}An{ADn{An}}}{{I`{BIh}}}}{{}}{{}Ch}00000000{{}c{}}00000000{{}{{Cl{HhHj}}}}00000000{{{b{BGj}}}BGl}{b}00000000{{{b{BGj}}}Ch}{{{b{BH`}}Ch}f}{{{b{BGn}}}{{n{{b{h}}}}}}{{{b{AEb}}An}{{I`{AEd}}}}5{{{b{AEb}}An{ADn{An}}}{{I`{BIj}}}}{bc{}}0000000{bAn}{c{{Cl{e}}}{}{}}00000000{{}{{Cl{c}}}{}}00000000{bJl}00000000{{{b{BH`}}BIl}f}>>>>>>>>>`````````````````````````{{bd}f}00000000`{b{{b{h}}}}00{{{b{Ej}}}{{n{{b{l}}}}}}`{{{b{In}}}{{Ib{{I`{Hn}}}}}}{b{{b{c}}}{}}000000000{{{b{Af}}}{{b{Afc}}}{}}000000000{{{BIn{ce}}}Ej{{B`{An}}}{{B`{Bb}}}}{{{b{Ej}}}{{n{{b{h}}}}}}{{{b{{ACf{c}}}}}{{ACf{c}}}Ad}{{{b{BJ`}}}BJ`}{{{b{{BJb{c}}}}}{{BJb{c}}}Bd}{{{b{BJd}}}BJd}{{{b{BJf}}}BJf}{{{b{{BJh{c}}}}}{{BJh{c}}}Bd}{{{b{{BJj{ce}}}}}{{BJj{ce}}}BdBd}{{{b{{BIn{ce}}}}}{{BIn{ce}}}BdBd}{{{b{Ej}}}Ej}{{b{b{Afc}}}f{}}00000000{bf}00000000{{{b{BJ`}}{b{BJ`}}}Nd}{{b{b{c}}}Nd{}}{{{b{In}}}{{Ib{{I`{Hn}}}}}}{{}{{BJb{c}}}{}}{{}BJl}{{{b{BJl}}c}{{Cl{{Of{eEjc}}Oh}}}Jf{H`HbOj}}{Ch{{b{c}}}{}}000000000{Ch{{b{Afc}}}{}}000000000{{{b{Ej}}}{{b{Cj}}}}{{b{b{Afc}}}{{Cl{{D`{eg}}}}}{}{}{}}0{c{{Cl{BJ`}}}Cn}{c{{Cl{{BJb{e}}}}}CnBJn}22222222{c{{Cl{Ej}}}Cn}{Chf}000000000`{{{b{BJ`}}{b{BJ`}}}Db}{{{b{{BJb{c}}}}{b{{BJb{c}}}}}DbLl}{{b{b{c}}}Db{}}0000000`{{{BIn{ce}}}{{Cl{gEj}}}{{B`{An}}}{{B`{Bb}}}{}}{{{b{{ACf{c}}}}{b{AfEb}}}EhAd}{{{b{BJ`}}{b{AfEb}}}Eh}{{{b{{BJb{c}}}}{b{AfEb}}}EhEf}{{{b{BJd}}{b{AfEb}}}Eh}{{{b{BJf}}{b{AfEb}}}Eh}{{{b{{BJh{c}}}}{b{AfEb}}}EhEf}{{{b{{BJj{ce}}}}{b{AfEb}}}EhEfEf}{{{b{{BIn{ce}}}}{b{AfEb}}}EhEfEf}{{{b{Ej}}{b{AfEb}}}Eh}0{cc{}}{{{Kb{c}}}{{ACf{c}}}Ad}1{{{b{{BJb{c}}}}}{{n{Cd}}}BK`}22222222{A`Ej}{A@bEj}{{{F`{AnBb}}}Ej}{{}BJ`}{{{b{c}}{b{e}}}Cd{GdGf}Gh}{{{b{In}}eCd}{{Ib{{I`{Hn}}}}}Ad{{B`{{ACf{c}}}}H`Hb}}{{{b{BJ`}}{b{Afc}}}fGj}{c{{Gl{ce}}}{GnH`Hb}{}}{{}}{{}Ch}000000000{cEjGn}{{}c{}}000000000{{BJdc}Ej{}}{{BJfc}Ej{}}{{{BJh{c}}e}Ej{{B`{An}}}{}}{{{BJj{ce}}g}Ej{{B`{An}}}{{B`{Cd}}}{}}{{{BIn{ce}}g}Ej{{B`{An}}}{{B`{Bb}}}{}}{{{b{BJ`}}}Db}{{}{{Cl{HhHj}}}}000000000``````{{{b{BJ`}}{b{BJ`}}}{{n{Nd}}}}{{{b{In}}}{{Ib{{I`{Hn}}}}}}{b}000000000``{{{b{BJ`}}c}ClJj}{{{b{{BJb{c}}}}e}ClJhJj}{{{b{Ej}}c}ClJj}{{{b{Ej}}}{{n{{b{h}}}}}}`{{{b{Ej}}}Bb}`6{bc{}}00000000{bAn}{c{{Cl{e}}}{}{}}000000000{{}{{Cl{c}}}{}}000000000{bJl}000000000{{{b{In}}e}{{Ib{{I`{Hn}}}}}Ad{{B`{{Mj{c}}}}H`Hb}}{{}c{}}000000000````````````````{{bd}f}`{b{{b{h}}}}00{{{b{El}}}{{n{{b{l}}}}}}{{{b{J`}}}{{Ib{{I`{Hn}}}}}}{b{{b{c}}}{}}0{{{b{Af}}}{{b{Afc}}}{}}0{{{b{El}}}{{n{{b{h}}}}}}{{{b{El}}}El}{{b{b{Afc}}}f{}}{bf}{{{b{J`}}}{{AKd{AEb}}}}0{{}BKb}{{{b{BKb}}c}{{Cl{{Of{eElc}}Oh}}}Jf{H`HbOj}}{Ch{{b{c}}}{}}0{Ch{{b{Afc}}}{}}0{{{b{El}}}{{b{Cj}}}}{{b{b{Afc}}}{{Cl{{D`{eg}}}}}{}{}{}}{c{{Cl{El}}}Cn}1{Chf}0??`{{{b{El}}{b{AfEb}}}Eh}0{cc{}}{AnEl}1{A@bEl}{c{{Gl{ce}}}{GnH`Hb}{}}{{}}{{}Ch}0{{}c{}}0{{}{{Cl{HhHj}}}}0{{{b{J`}}}{{b{AEb}}}}{b}0{{{b{BKd}}}{{I`{AEd}}}}{{{b{El}}c}ClJj}{{{b{El}}}{{n{{b{h}}}}}}{{{b{El}}}Bb}{{{b{J`}}}{{Ib{{I`{Hn}}}}}}0{bc{}}{bAn}{c{{Cl{e}}}{}{}}0{{}{{Cl{c}}}{}}0{bJl}0==````{{bd}f}{b{{b{c}}}{}}0{{{b{Af}}}{{b{Afc}}}{}}0{{{b{BKf}}}BKf}{{b{b{Afc}}}f{}}{bf}{Ch{{b{c}}}{}}0{Ch{{b{Afc}}}{}}0{{b{b{Afc}}}{{Cl{{D`{eg}}}}}{}{}{}}0{Chf}{{{b{Af{BKh{c}}}}}fH`}1{{{b{BKf}}{b{AfEb}}}Eh}{{{b{{BKh{c}}}}{b{AfEb}}}EhH`}{cc{}}0{{}Ch}0{{}c{}}0{{{BKh{c}}}cH`}{{}{{Cl{HhHj}}}}0{b}0{{ce}BKfGn{HnH`}}{{cg}{{BKh{e}}}GnH`{{Hn{}{{Id{e}}}}H`}}{bc{}}{c{{Cl{e}}}{}{}}0{{}{{Cl{c}}}{}}0{bJl}099``{{}f}{ABff}```````{b{{b{c}}}{}}{{{b{Af}}}{{b{Afc}}}{}}{{{b{c}}}{{Ib{{I`{Hn}}}}}{}}{Ch{{Ib{{I`{Hn}}}}}}{{{b{{AIj{c}}}}}cBKj}{{{b{{AIj{c}}}}Ch}cBKj}{Ch{{b{c}}}{}}{Ch{{b{Afc}}}{}}{{b{b{Afc}}}{{Cl{{D`{eg}}}}}{}{}{}}{{{b{Af{AIj{c}}}}}fBKj}{Chf}{cc{}}{{{b{{AIj{c}}}}}{{b{{Ij{ADdBKlBKn}}}}}BKj}{{{b{{BKj{}{{BL`{c}}}}}}{b{{ADf{ADd}}}}}{{Ib{{I`{Hn}}}}}{H`Hb}}{{}{{AIj{c}}}{BKjBKd}}{{}Ch}{c{{AIj{e}}}{{Ih{{b{Af{BLd{BLb}}}}}}}{BKjBKd}}{{}c{}}{{}{{Cl{HhHj}}}}{{{b{{AIj{c}}}}}ChBKj}{b}{{{b{{AIj{c}}}}Ch}{{BLf{ADd}}}BKj}{{{b{c}}}{{Ib{{I`{Hn}}}}}{}}{{{b{Af{AIj{{BKj{}{{BL`{c}}}}}}}}}{{Ib{{I`{Hn}}}}}{H`Hb}}{{{AIj{c}}}fBKj}{{{b{Af{AIj{c}}}}eg}fBKjGn{HnH`}}{{{b{Af{AIj{c}}}}}fBKj}{{{b{{AIj{c}}}}}bBKj}{{{b{{AIj{c}}}}BLh}fBKj}{c{{Cl{e}}}{}{}}{{}{{Cl{c}}}{}}{bJl}>`````````````{{bd}f}00``{b{{b{c}}}{}}00{{{b{Af}}}{{b{Afc}}}{}}00`{{{b{ADd}}}ADd}{{{b{BKn}}}BKn}{{{b{BKl}}}BKl}{{b{b{Afc}}}f{}}00{bf}00{{{b{ADd}}{b{ADd}}}Nd}{{{b{BKl}}{b{BKl}}}Nd}{{b{b{c}}}Nd{}}0`{{}ADd}{{}BKl}`{Ch{{b{c}}}{}}00{Ch{{b{Afc}}}{}}00{c{{Cl{ADd}}}Cn}{{b{b{Afc}}}{{Cl{{D`{eg}}}}}{}{}{}}00{c{{Cl{BKl}}}Cn}{Chf}00{{{b{ADd}}{b{ADd}}}Db}{{{b{BKl}}{b{BKl}}}Db}{{b{b{c}}}Db{}}0000000{{{b{BLj}}}c{}}0{{{b{ADd}}{b{AfEb}}}Eh}{{{b{BKn}}{b{AfEb}}}Eh}{{{b{BKl}}{b{AfEb}}}Eh}{cc{}}00{{{b{c}}{b{e}}}Cd{GdGf}Gh}0{{{b{ADd}}{b{Afc}}}fGj}{{{b{BKl}}{b{Afc}}}fGj}{{}{{b{Cj}}}}{{{b{BLj}}}Cd}{{}Ch}00{{{b{AfBLl}}c{b{{ADl{ecg}}}}}{{ABn{f}}}{}{}{}}{{}c{}}00{{{b{BLn}}{b{c}}}e{}{}}`{{}{{Cl{HhHj}}}}00{{{b{BLn}}{b{c}}}Ch{}}`{{{ADn{BM`}}}BLh}{{{b{BLh}}}c{}}{{{b{BLj}}}{{ADn{c}}}{}}{{{b{ADd}}{b{ADd}}}{{n{Nd}}}}{{{b{BKl}}{b{BKl}}}{{n{Nd}}}}`{b}00`{{{b{BLj}}}c{}}`0{{{b{ADd}}c}ClJj}{{{b{BKl}}c}ClJj}`{{}{{b{Cj}}}}{{{b{BLj}}}Cd}`{bc{}}00{{{b{BLn}}{b{c}}{b{e}}}{{n{{F`{gi}}}}}{}{}{}{}}`{{}Ch}{c{{Cl{e}}}{}{}}00{{}{{Cl{c}}}{}}00{bJl}00```{{}c{}}00`{{{b{BK`}}}Cd}","D":"EG`","p":[[1,"reference"],[5,"Private",4363],[1,"unit"],[10,"Error",4364],[6,"Error",0,4365],[5,"Backtrace",4366],[6,"Option",4367],[6,"QueryError",0],[5,"Leaf",0,4368],[10,"NodeType",4369],[0,"mut"],[5,"NotFoundSnafu",0],[5,"MissingSnafu",0],[5,"ErrorSnafu",0],[5,"String",4370],[10,"Into",4371],[5,"StatusCode",4372],[10,"Clone",4373],[5,"ApiState",0],[5,"Commitment",4374],[5,"UpgradeLock",4375],[10,"Versions",4369],[10,"Resolvable",0,4376],[10,"Committable",4374],[10,"RngCore",4377],[1,"u64"],[5,"Options",0],[1,"usize"],[1,"str"],[6,"Result",4378],[10,"Deserializer",4379],[5,"With",4380],[1,"bool"],[5,"UpgradeProposalData",4381],[5,"UpgradeThreshold",4382],[5,"SimpleCertificate",4382],[5,"RwLock",4383],[5,"Arc",4384],[5,"Error",1647,4385],[6,"BlockError",4368],[5,"Formatter",4386],[5,"Error",4386],[10,"Debug",4386],[8,"Result",4386],[6,"Error",3761],[6,"Error",4067],[6,"Error",2084],[1,"tuple"],[6,"Error",315],[6,"Error",3395],[6,"TimestampConversionError",2084,4387],[6,"Error",4388],[1,"never"],[5,"OwnedFd",4389],[10,"IntoFilelike",4390],[10,"IntoSocketlike",4390],[5,"QuorumProposal",4368],[10,"Hash",4391],[10,"Sized",4392],[10,"BuildHasher",4391],[10,"Hasher",4391],[5,"IndentedSection",4393],[10,"Display",4386],[10,"Send",4392],[10,"Sync",4392],[5,"QuorumData",4381],[5,"SuccessThreshold",4382],[5,"Layout",4394],[5,"LayoutError",4394],[5,"DynGuard",4395],[10,"Future",4396],[5,"Box",4397],[5,"Pin",4398],[17,"Output"],[8,"BoxFuture",4399],[10,"FnOnce",4400],[5,"SystemContextHandle",4401],[10,"AvailabilityDataSource",315,4402],[10,"NodeDataSource",3761,4403],[10,"StatusDataSource",4067,4404],[10,"VersionedDataSource",1000,4405],[10,"NodeImplementation",4369],[10,"StaticVersionType",4406],[10,"Serialize",4407],[10,"Serializer",4407],[5,"TypeId",4408],[5,"InconsistentLeafError",315,4409],[5,"LeafQueryData",315,4409],[8,"BlockHash",315,4409],[5,"PayloadQueryData",315,4409],[5,"VidCommonQueryData",315,4409],[5,"TransactionQueryData",315,4409],[5,"FetchLeafSnafu",315],[5,"FetchBlockSnafu",315],[5,"FetchTransactionSnafu",315],[5,"InvalidTransactionIndexSnafu",315],[5,"CustomSnafu",315],[17,"TransactionIndex"],[17,"Iter"],[17,"InclusionProof"],[10,"QueryablePayload",315,4409],[10,"PartialEq",4410],[10,"Eq",4410],[10,"Ord",4410],[10,"DeserializeOwned",4379],[17,"Item"],[10,"Iterator",4411],[6,"LeafId",315,4402],[6,"BlockId",315,4402],[5,"BlockQueryData",315,4409],[5,"BlockSummaryQueryData",315,4409],[5,"TransactionSummaryQueryData",315,4409],[5,"RequestSnafu",315],[6,"Ordering",4410],[8,"VidCommon",0,4412],[6,"Fetch",315,4413],[10,"ErrorCompat",4414],[17,"Source"],[5,"NoneError",4414],[10,"IntoError",4414],[8,"Payload",0],[5,"Options",315],[5,"Api",4415],[6,"ApiError",4415],[10,"ReadState",4416],[8,"TransactionIndex",315,4409],[8,"Transaction",0],[8,"LeafHash",315,4409],[6,"RequestError",4417],[8,"Result",4388],[17,"LeafRange"],[17,"BlockRange"],[17,"PayloadRange"],[17,"VidCommonRange"],[10,"Stream",4418],[10,"Unpin",4392],[10,"RangeBounds",4419],[8,"TransactionHash",315,4409],[8,"VidCommitment",0,4412],[8,"Header",0],[10,"UpdateAvailabilityData",315,4402],[8,"VidShare",0,4412],[8,"Metadata",0],[8,"QuorumCertificate",4382],[8,"TransactionInclusionProof",315,4409],[10,"QueryableHeader",315,4409],[5,"Duration",4420],[5,"ExtensibleDataSource",1000,4421],[5,"MetricsDataSource",1000,4422],[10,"Transaction",1000,4405],[8,"Result",4385],[6,"BlockIdentifier",2084,4387],[10,"ExplorerDataSource",2084,4423],[5,"GetBlockSummariesRequest",2084,4387],[6,"WindowStart",3761,4403],[10,"MerklizedStateHeightPersistence",3395,4424],[6,"Snapshot",3395,4424],[10,"MerklizedState",3395,4424],[10,"MerklizedStateDataSource",3395,4424],[6,"TransactionIdentifier",2084,4387],[5,"GetTransactionSummariesRequest",2084,4387],[5,"MockTypes",4227],[5,"Event",4425],[10,"TestableDataSource",4187],[10,"Default",4426],[5,"MerkleProof",4427],[5,"Vec",4428],[10,"UpdateStateData",3395,4424],[5,"PrometheusMetrics",3515],[10,"Metrics",4429],[17,"Transaction"],[17,"ReadOnly"],[10,"UpdateDataSource",1000,4405],[5,"Transaction",1119,4430],[5,"FetchingDataSource",1119],[10,"NodeStorage",1318],[5,"Builder",1119],[10,"PruneStorage",1601],[10,"AvailabilityProvider",1119],[5,"Pruner",1119],[8,"Config",1300],[8,"Builder",1300],[5,"Path",4431],[5,"FileSystemStorage",1354],[5,"AtomicStoreLoader",4432],[10,"AvailabilityStorage",1318],[10,"ExplorerStorage",1318],[10,"MerklizedStateHeightStorage",1318],[10,"MerklizedStateStorage",1318],[10,"PrunedHeightStorage",1601],[8,"FileSystemDataSource",1280],[8,"SqlDataSource",1300],[5,"Transaction",1354],[10,"Revert",1354],[17,"Target"],[5,"FileSystemStorageInner",1354],[10,"Deref",4433],[5,"RwLockWriteGuard",4383],[5,"RwLockReadGuard",4383],[6,"PersistenceError",4434],[5,"Transaction",1439],[5,"NoStorage",1439],[6,"Transaction",1503],[6,"DataSource",1503],[5,"MockNetwork",4187],[5,"PrunerCfg",1601],[17,"Pruner"],[10,"PrunerConfig",1601],[1,"u16"],[1,"i32"],[5,"OffsetDateTime",4435],[5,"Migration",1647,4436],[5,"Config",1647],[10,"Database",1647,4437],[10,"Params",1647,4438],[8,"Query",1647,4438],[5,"QueryBuilder",1647,4439],[8,"QueryResult",0],[8,"Db",1647,4440],[10,"Encode",4441],[10,"Type",4442],[5,"Transaction",1647,4438],[10,"TransactionMode",1647,4438],[5,"Postgres",1647,4443],[5,"Chain",4385],[5,"Write",1647,4438],[5,"Read",1647,4438],[5,"SqlStorage",1647],[5,"Pruner",1647],[17,"Database"],[10,"Executor",1647,4444],[10,"Execute",4444],[5,"Sqlite",1647,4445],[5,"FmtValue",4446],[5,"PgConnectOptions",4447],[1,"u32"],[10,"IntoIterator",4448],[6,"Type",4436],[1,"slice"],[8,"QueryAs",1647,4438],[10,"FromRow",4449],[5,"TestArgs",4450],[5,"Error",4451],[1,"array"],[5,"TmpDb",2043],[5,"MonetaryValue",2084,4452],[1,"i128"],[5,"CurrencyMismatchError",2084,4453],[5,"InvalidCurrencyCodeError",2084,4453],[6,"CurrencyCode",2084,4453],[5,"BlockRange",2084,4387],[5,"TransactionRange",2084,4387],[5,"Timestamp",2084,4387],[6,"GetBlockDetailError",2084,4387],[6,"GetBlockSummariesError",2084,4387],[6,"GetTransactionDetailError",2084,4387],[6,"GetTransactionSummariesError",2084,4387],[6,"GetExplorerSummaryError",2084,4387],[6,"GetSearchResultsError",2084,4387],[5,"BlockDetail",2084,4387],[5,"BlockSummary",2084,4387],[5,"FeeAttribution",2084,4387],[5,"TransactionDetail",2084,4387],[5,"TransactionSummary",2084,4387],[6,"TransactionSummaryFilter",2084,4387],[5,"GenesisOverview",2084,4387],[5,"ExplorerHistograms",2084,4387],[5,"ExplorerSummary",2084,4387],[5,"SearchResult",2084,4387],[5,"BlockDetailResponse",2084],[5,"BlockSummaryResponse",2084],[5,"TransactionDetailResponse",2084],[5,"TransactionSummariesResponse",2084],[5,"ExplorerSummaryResponse",2084],[5,"SearchResultResponse",2084],[17,"BalanceAmount"],[17,"WalletAddress"],[17,"ProposerId"],[17,"NamespaceId"],[10,"ExplorerHeader",2084,4454],[5,"TryFromIntError",4455],[5,"ComponentRange",4456],[6,"Resettable",4457],[10,"ExplorerTransaction",2084,4454],[5,"Fetcher",3161],[10,"LocalCallback",3161],[10,"Callback",3161],[10,"Request",3305],[10,"Provider",3195],[5,"Semaphore",4458],[5,"TestProvider",3195,4459],[5,"AnyProvider",3195,4460],[5,"QueryServiceProvider",3195,4461],[5,"NoFetching",3195],[5,"PayloadRequest",3305],[5,"LeafRequest",3305],[5,"VidCommonRequest",3305],[5,"Url",4462],[5,"Options",3395],[17,"Key"],[17,"Entry"],[17,"T"],[17,"Commit"],[17,"Digest"],[10,"Index",4463],[10,"ToTraversalPath",4463],[10,"FromStr",4464],[10,"CanonicalSerialize",4465],[10,"CanonicalDeserialize",4465],[10,"Element",4463],[10,"NodeValue",4463],[10,"MerkleCommitment",4463],[5,"TaggedBase64",4466],[10,"TryFrom",4371],[10,"DigestAlgorithm",4463],[5,"Counter",3515],[5,"Histogram",3515],[1,"f64"],[6,"MetricsError",3515],[5,"Gauge",3515],[5,"CounterFamily",3515],[5,"GaugeFamily",3515],[5,"HistogramFamily",3515],[5,"TextFamily",3515],[10,"CounterFamily",4429],[10,"Counter",4429],[10,"Gauge",4429],[10,"Histogram",4429],[6,"Error",4467],[10,"GaugeFamily",4429],[10,"AsRef",4371],[10,"HistogramFamily",4429],[10,"TextFamily",4429],[1,"i64"],[5,"CustomSnafu",3761],[5,"SyncStatus",3761,4468],[5,"TimeWindowQueryData",3761,4468],[5,"RequestSnafu",3761],[5,"QuerySnafu",3761],[5,"QueryVidSnafu",3761],[5,"QueryWindowSnafu",3761],[5,"Options",3761],[10,"Deserialize",4379],[10,"HeightIndexed",4361],[5,"Options",4067],[10,"UpdateStatusData",4067,4404],[5,"BackgroundTask",4140],[5,"Task",4140],[10,"DataSourceLifeCycle",4187],[5,"MockNodeImpl",4227],[5,"MockVersions",4227],[17,"Storage"],[8,"BLSPubKey",4469],[5,"HotShotConfig",4470],[8,"SignatureKey",0],[8,"MockTransaction",4227],[8,"MockHeader",4227],[8,"MockMerkleTree",4227],[8,"MockPayload",4227],[1,"u8"],[15,"Custom",307],[15,"Availability",307],[15,"Node",307],[15,"Status",307],[15,"MerklizedState",307],[15,"Explorer",307],[15,"Error",314],[15,"InvalidTransactionIndex",992],[15,"Custom",992],[15,"FetchLeaf",992],[15,"FetchBlock",992],[15,"FetchTransaction",992],[15,"Request",992],[6,"Storage",1503],[15,"NoStorage",1600],[5,"TestMerkleTreeMigration",2043],[15,"Custom",3511],[15,"Request",3511],[15,"Query",3511],[15,"NoSuchMetric",3757],[15,"NoSuchSubgroup",3757],[15,"Prometheus",3757],[15,"QueryVid",4058],[15,"QueryWindow",4058],[15,"Custom",4058],[15,"Request",4058],[15,"Query",4058],[15,"Internal",4138],[15,"Request",4138],[8,"MockQuorumProposal",4227],[8,"MockStorage",4227],[8,"MockAuctionResults",4227]],"r":[[4,4365],[9,4368],[22,4376],[26,4412],[27,4412],[28,4412],[315,4402],[316,4409],[317,4402],[318,4409],[320,4409],[324,4413],[334,4409],[338,4409],[339,4402],[340,4409],[346,4409],[349,4409],[350,4409],[354,4409],[355,4409],[356,4409],[357,4409],[359,4409],[360,4409],[361,4402],[362,4409],[1000,1119],[1001,4421],[1002,1119],[1003,1280],[1004,4422],[1006,1300],[1007,4405],[1009,4405],[1010,4405],[1123,4430],[1281,1354],[1302,4385],[1303,4436],[1304,4443],[1306,4438],[1313,0],[1316,2043],[1320,1354],[1323,1439],[1325,1647],[1652,4437],[1654,4440],[1655,4385],[1656,4444],[1657,4438],[1658,4436],[1660,4438],[1661,4443],[1663,4438],[1664,4438],[1665,4439],[1667,4438],[1670,4445],[1672,4438],[1674,4438],[1679,4438],[1891,4471],[1892,0],[1963,4438],[1965,4438],[2084,4387],[2087,4387],[2089,4387],[2090,4387],[2092,4387],[2093,4387],[2098,4453],[2099,4453],[2104,4423],[2105,4454],[2106,4387],[2107,4387],[2109,4454],[2110,4387],[2114,4387],[2116,4387],[2119,4387],[2121,4387],[2123,4387],[2125,4387],[2127,4387],[2129,4387],[2131,4387],[2137,4453],[2144,4452],[2148,4387],[2157,4387],[2162,4387],[2163,4387],[2166,4387],[2168,4387],[2169,4387],[2171,4387],[2173,4387],[2174,4387],[2182,4387],[3164,3195],[3165,3305],[3195,4460],[3198,4461],[3199,4459],[3403,4424],[3404,4424],[3405,4424],[3409,4424],[3411,4424],[3761,4409],[3762,4402],[3768,4403],[3778,4468],[3780,4468],[3781,4403],[4071,4404],[4072,4404]],"b":[[92,"impl-Committable-for-Leaf%3CTYPES%3E"],[93,"impl-Leaf%3CTYPES%3E"],[150,"impl-Display-for-Leaf%3CTYPES%3E"],[151,"impl-Debug-for-Leaf%3CTYPES%3E"],[152,"impl-Debug-for-Error"],[153,"impl-Display-for-Error"],[157,"impl-Debug-for-QueryError"],[158,"impl-Display-for-QueryError"],[161,"impl-From%3CError%3E-for-Error"],[162,"impl-From%3CError%3E-for-Error"],[163,"impl-From%3CError%3E-for-Error"],[164,"impl-From%3C(String,+StatusCode)%3E-for-Error"],[165,"impl-From%3CError%3E-for-Error"],[167,"impl-From%3CError%3E-for-Error"],[171,"impl-From%3CTimestampConversionError%3E-for-QueryError"],[173,"impl-From%3CError%3E-for-QueryError"],[176,"impl-From%3CArc%3CD%3E%3E-for-ApiState%3CD%3E"],[178,"impl-From%3CD%3E-for-ApiState%3CD%3E"],[643,"impl-Display-for-LeafId%3CTypes%3E"],[644,"impl-Debug-for-LeafId%3CTypes%3E"],[645,"impl-Debug-for-BlockId%3CTypes%3E"],[646,"impl-Display-for-BlockId%3CTypes%3E"],[648,"impl-Display-for-InconsistentLeafError%3CTypes%3E"],[649,"impl-Debug-for-InconsistentLeafError%3CTypes%3E"],[662,"impl-Display-for-Error"],[663,"impl-Debug-for-Error"],[666,"impl-From%3CCommitment%3CLeaf%3CTypes%3E%3E%3E-for-LeafId%3CTypes%3E"],[668,"impl-From%3Cusize%3E-for-LeafId%3CTypes%3E"],[670,"impl-From%3CCommitment%3C%3CTypes+as+NodeType%3E::BlockHeader%3E%3E-for-BlockId%3CTypes%3E"],[671,"impl-From%3Cusize%3E-for-BlockId%3CTypes%3E"],[689,"impl-From%3CRequestError%3E-for-Error"],[690,"impl-From%3C(String,+StatusCode)%3E-for-Error"],[1016,"impl-StatusDataSource-for-ExtensibleDataSource%3CD,+U%3E"],[1017,"impl-NodeDataSource%3CTypes%3E-for-ExtensibleDataSource%3CD,+U%3E"],[1130,"impl-StatusDataSource-for-FetchingDataSource%3CTypes,+S,+P%3E"],[1131,"impl-NodeDataSource%3CTypes%3E-for-FetchingDataSource%3CTypes,+S,+P%3E"],[1283,"impl-FetchingDataSource%3CTypes,+FileSystemStorage%3CTypes%3E,+P%3E"],[1284,"impl-DataSourceLifeCycle-for-FetchingDataSource%3CMockTypes,+FileSystemStorage%3CMockTypes%3E,+P%3E"],[1309,"impl-FetchingDataSource%3CTypes,+SqlStorage,+P%3E"],[1310,"impl-DataSourceLifeCycle-for-FetchingDataSource%3CMockTypes,+SqlStorage,+P%3E"],[1365,"impl-Transaction-for-Transaction%3CRwLockWriteGuard%3C\'a,+FileSystemStorageInner%3CTypes%3E%3E%3E"],[1366,"impl-Transaction-for-Transaction%3CRwLockReadGuard%3C\'a,+FileSystemStorageInner%3CTypes%3E%3E%3E"],[1420,"impl-Transaction-for-Transaction%3CRwLockReadGuard%3C\'a,+FileSystemStorageInner%3CTypes%3E%3E%3E"],[1421,"impl-Transaction-for-Transaction%3CRwLockWriteGuard%3C\'a,+FileSystemStorageInner%3CTypes%3E%3E%3E"],[1514,"impl-StatusDataSource-for-DataSource"],[1515,"impl-NodeDataSource%3CMockTypes%3E-for-DataSource"],[1687,"impl-AsRef%3Cdyn+Error+%2B+Send+%2B+Sync%3E-for-Error"],[1688,"impl-AsRef%3Cdyn+Error%3E-for-Error"],[1832,"impl-Debug-for-Error"],[1833,"impl-Display-for-Error"],[1834,"impl-Debug-for-Migration"],[1835,"impl-Display-for-Migration"],[2610,"impl-Display-for-CurrencyMismatchError"],[2611,"impl-Debug-for-CurrencyMismatchError"],[2612,"impl-Display-for-InvalidCurrencyCodeError"],[2613,"impl-Debug-for-InvalidCurrencyCodeError"],[2614,"impl-Display-for-CurrencyCode"],[2615,"impl-Debug-for-CurrencyCode"],[2616,"impl-Debug-for-MonetaryValue"],[2617,"impl-Display-for-MonetaryValue"],[2618,"impl-Display-for-BlockIdentifier%3CTypes%3E"],[2619,"impl-Debug-for-BlockIdentifier%3CTypes%3E"],[2620,"impl-Display-for-TransactionIdentifier%3CTypes%3E"],[2621,"impl-Debug-for-TransactionIdentifier%3CTypes%3E"],[2627,"impl-Debug-for-TimestampConversionError"],[2628,"impl-Display-for-TimestampConversionError"],[2639,"impl-Display-for-GetBlockDetailError"],[2640,"impl-Debug-for-GetBlockDetailError"],[2641,"impl-Display-for-GetBlockSummariesError"],[2642,"impl-Debug-for-GetBlockSummariesError"],[2643,"impl-Display-for-GetTransactionDetailError"],[2644,"impl-Debug-for-GetTransactionDetailError"],[2645,"impl-Display-for-GetTransactionSummariesError"],[2646,"impl-Debug-for-GetTransactionSummariesError"],[2647,"impl-Display-for-GetExplorerSummaryError"],[2648,"impl-Debug-for-GetExplorerSummaryError"],[2649,"impl-Display-for-GetSearchResultsError"],[2650,"impl-Debug-for-GetSearchResultsError"],[2651,"impl-Debug-for-Error"],[2652,"impl-Display-for-Error"],[2671,"impl-From%3CTryFromIntError%3E-for-TimestampConversionError"],[2672,"impl-From%3CComponentRange%3E-for-TimestampConversionError"],[2685,"impl-From%3CQueryError%3E-for-GetBlockDetailError"],[2686,"impl-From%3CError%3E-for-GetBlockDetailError"],[2687,"impl-From%3CError%3E-for-GetBlockSummariesError"],[2689,"impl-From%3CQueryError%3E-for-GetBlockSummariesError"],[2690,"impl-From%3CQueryError%3E-for-GetTransactionDetailError"],[2692,"impl-From%3CError%3E-for-GetTransactionDetailError"],[2693,"impl-From%3CTimestampConversionError%3E-for-GetTransactionDetailError"],[2694,"impl-From%3CError%3E-for-GetTransactionSummariesError"],[2696,"impl-From%3CQueryError%3E-for-GetTransactionSummariesError"],[2697,"impl-From%3CGetBlockSummariesError%3E-for-GetExplorerSummaryError"],[2698,"impl-From%3CQueryError%3E-for-GetExplorerSummaryError"],[2699,"impl-From%3CError%3E-for-GetExplorerSummaryError"],[2701,"impl-From%3CGetTransactionSummariesError%3E-for-GetExplorerSummaryError"],[2702,"impl-From%3CGetBlockDetailError%3E-for-GetExplorerSummaryError"],[2703,"impl-From%3CQueryError%3E-for-GetSearchResultsError"],[2705,"impl-From%3CError%3E-for-GetSearchResultsError"],[3245,"impl-Provider%3CTypes,+PayloadRequest%3E-for-AnyProvider%3CTypes%3E"],[3246,"impl-Provider%3CTypes,+LeafRequest%3E-for-AnyProvider%3CTypes%3E"],[3247,"impl-Provider%3CTypes,+VidCommonRequest%3E-for-AnyProvider%3CTypes%3E"],[3248,"impl-Provider%3CTypes,+VidCommonRequest%3E-for-QueryServiceProvider%3CVer%3E"],[3249,"impl-Provider%3CTypes,+LeafRequest%3E-for-QueryServiceProvider%3CVer%3E"],[3250,"impl-Provider%3CTypes,+PayloadRequest%3E-for-QueryServiceProvider%3CVer%3E"],[3456,"impl-Debug-for-Snapshot%3CTypes,+T,+ARITY%3E"],[3457,"impl-Display-for-Snapshot%3CTypes,+T,+ARITY%3E"],[3458,"impl-Debug-for-Error"],[3459,"impl-Display-for-Error"],[3462,"impl-From%3CQueryError%3E-for-Error"],[3463,"impl-From%3C(String,+StatusCode)%3E-for-Error"],[3464,"impl-From%3CRequestError%3E-for-Error"],[3632,"impl-Debug-for-MetricsError"],[3633,"impl-Display-for-MetricsError"],[3652,"impl-Metrics-for-PrometheusMetrics"],[3653,"impl-PrometheusMetrics"],[3918,"impl-Debug-for-Error"],[3919,"impl-Display-for-Error"],[3932,"impl-From%3CQueryError%3E-for-Error"],[3933,"impl-From%3CRequestError%3E-for-Error"],[3934,"impl-From%3C(String,+StatusCode)%3E-for-Error"],[4105,"impl-Display-for-Error"],[4106,"impl-Debug-for-Error"],[4108,"impl-From%3CString%3E-for-Error"],[4110,"impl-From%3CRequestError%3E-for-Error"]],"c":"OjAAAAAAAAA=","e":"OzAAAAEAAFMOHQECAAEABQAAAAgAAQALAAEADwAAABMAAwAYAAEAHgAMACwAAgAyAA8ARQAYAGAAAQBjACwAlwAJAKIABACoAAAArAAAAK4AAACxAAYAuQAAALsABADBAAEAxAANANoAAgDeAAkA6QABAOwAAADvAAkA+gAEAAABAgAEARoAIAEIACwBDwA+AQQARAEAAEYBAABIAQAASgEAAEwBAQBPAQEAUwELAGABAQBjAQMAaAEhAIwBJQC5ATkA9AFYAE8CLQCEAhQAmwIAAJ0CAACfAgEApAIAAKgCAACyAhEAxQIGAM0CDwDeAhcACQMGABIDAAAUAxQAKgMAACwDAQAvAwEANwMaAFUDAQBYAy8AigMAAI4DAACSAyUAuQMlAOEDCADrAwEA7gMBAPQDAwD5AxsAFgQBABoEFgAzBAMAOQQEAD8EAABBBAMARgQFAE4ECABYBAMAXQQCAGMEEQB3BAYAfwQBAIMECwCQBAYAmwQsAMwEBQDVBAkA4AQWAAAFAAACBQEABQUAAAcFAAAKBQAADAUKABsFAAAfBQIAIwUDACkFAQAsBQYANAUAADcFBwBABQAAQwUFAEoFAABMBQwAWwUPAG4FEACCBQIAhwUHAJAFDwChBRUAuQUPAMsFGwDoBR8ACwYRACAGJwBJBgoAVQYCAFoGAQBeBgIAYgYAAGQGCwB2BgAAfwYCAJEGBACYBgEAmwYDAKAGFgC7BhIA0gYCANYGBgDeBiQABgcSACkHEAA7BwAARAcAAEcHDQBWBwoAZgcOAIEHCgCNBwAAlQcCAJkHCwCsBwAArgcAALAHAACyBwIAtwcKAMMHJgDrBwEA7wcdAA8IAwAVCBAAJwgAACsIAQAwCAIANggCAEAIAgBECAAARggBAEkIAABLCAAATQgAAE8IAABRCAAAUwgAAFUIBABbCAUAZAgBAGcIBgBwCAIAdQgBAHoIAQCACAcAiQgQAJsIZwAECTYAPAlMAIoJAwCPCZoALAoBADAKAgA0CgAANgoAADgKAQA7CigAcAoBAH4KAgCCCgEAhQoCAIkKAwCOCgIAkgoAAJQKAACXCgAAmQoAAJwKAACeCgMAqApBAA0LKgA6CysAZwsCAGsLAwBxCwAAdAsWAIwLEQCfC5UANgwjAF0MDQBsDAAAbgwBAHIMAQB1DAYAgQwDAIYMJQCuDAsAvgwDAMYMGQDiDAMA7wwvACINCQAvDRwATg0DAFMNAABVDSoAgQ0DAIcNAgCLDQUAkg0EAJsNCQCmDQQArA0PAMINAwDIDXIAPA4AAEUOAABHDgQAUg4LAGcOTQC2DgUAvQ4AAL8OAADBDgAAww4BAMYOJADsDlgARw8JAFIPAABdDxMAew8qAKcPYQAKEAEADRAAAA8QBAAWEBYALxASAEQQAQBJEAMATxARAGIQCwBvEAQAdRAEAHsQCQCGEA0AlhAFAJ0QLQDOEAkA2xAAAN0QAwDiEAQA6BACAOwQAADuEAIA8hABAPUQAwD6EAkABxECAAsRAAA="}]]')); +var searchIndex = new Map(JSON.parse('[["hotshot_query_service",{"t":"FPPPGPFPIFPIPFPPFPFIGIKIPIIIINNNNNNNNNNNNNCONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMNNCNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNCNNNNCNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNQNNNNNNNNQQQQQNNNNNNNNNNNNNNNNNNNNNNNCOCCONNNNNNNNNNONHNNNNNCNNOCCNNNNNNNNNNNNNNNNNNNNNNNNNNMNNNNNNNNNCNNNNNNNNNNOOOOOOOOKIGFRFPFGGPFPFPFPPRFPFRIGFRPPFPFRPKKPPFIIIIRFFKFRNNNNNNNNNNNNNNNNNONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNHNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNONNNNNONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMMNNMMMMMMMNNNNNNNNNNNNNNNNNNNONNNONNNNNNNNNNNNNNNNNNNMMMNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMNNNNNNNNNNNNNNNNNNNNOMNNONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNONOOONNNNNNNNNNNNNNONNNNNNNNMNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNOOOOOOOOEFEEFREKRKKNNNNCNNNNNNNNNNNNNMNNNNNNNNNNNNNNCNNNNCNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNCNCNNNNMNNNMNCCCNNNNNNNNNMNNNNMNHHKFFFFNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNIENNNNNNNNNHHHHHHHHHIIFFFIENNNNNNQNCEHKKEKKEKEMMCMMMMMMMMMMMMMMMMMMMCMCCMMFFKFNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMNNNNNNNNNNNNNNNNNNNFFNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNCNNNNNNNNNNNNGPPPPPPGGNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNOKKRFKNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNRRRFRKRIFKKFTKFFIIFRFRFFRFRKRTRRFNNNNNNNNNNMNNMNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNHNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMNNMNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNQQNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMNNHNHNNNNNNNNNNNNNNDNNNCNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNFFNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNIRPFFGIPFFFPPPGFGPPPKKFFFKFPPPFPGPPGPFPGPGPGPGPFPPPPPFPPPPPPFRRPIRPPPPPPPFFPPPFGPPFFGIPFFFGPPPPPPPIRPNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNOOOOOOOOOONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNOOOONHNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNOOMMOOONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNOMMMMMMOOOONNNNNNNNNNNNNNOOOOONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNOOONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMMNOOOOOOOONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMOOOMOOOONNNNNNNNNNNNNNNNNNNNNNNNNNNNNOOONNNNNNNNNNNNNNNNOOOOOOONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNOOOONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNKFKEENNNNNNNNNNNNNNNNNCCMMNNNNNNNNFFKFFNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNFFKRFNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNPRPRRGPRKKKFPPGRKNNONNNNNNNNNNNNNNNNNNNNHNNNNNNNNNNNNNNNNNNNONNNNNNNNNNNMMNNNMNNNNMMNNNNNNNNNNNMNMNNNNNMNNNNNNNNNNNNOOOOFFFFFFGPPPFFNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNOOOOEEPFGPPKFPFPFPFPFFPFGNNNNNNNNNONNNNOMNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMNNHNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNONNNNNNNNNNONNNNNNNNNNNNNNNNNNNNNNNNNNNNMNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNOOOOOONMNNNNNNNNNNOONNNNONOMNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNMNNNNNNNNNNOOOOOOOOOOGKPFPKKNONNNNMNNNNNNNNNNNHNNNNNNNNNNNNONNNNNNNNNNNNNNMNNMNNNNNNNNNNNNNNNOOFFNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNCCHHKIFISRKNNMMNNNNNNNNNMNNNNNNNNMNNNNNNNNNNIIIIIIFIIIIFFNNNOONNNNNNONNNNNNNNNNNNNONNONNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNNONNNNOHNNNNONNNONONNNONNONNNNONNNNNNNNNNOOONNNKM","n":["ApiState","Availability","Custom","Err","Error","","ErrorSnafu","Explorer","Header","Leaf","MerklizedState","Metadata","Missing","MissingSnafu","Node","NotFound","NotFoundSnafu","Ok","Options","Payload","QueryError","QueryResult","Resolvable","SignatureKey","Status","Transaction","VidCommitment","VidCommon","VidShare","__clone_box","","","","","","","as_error","","as_error_source","","","","availability","","backtrace","","block_header","block_header_mut","block_payload","borrow","","","","","","","","borrow_mut","","","","","","","","build","","","catch_all","cause","","clone","","","","","","","clone_into","","","","","","","clone_to_uninit","","","","","","","commit","","commitment","","create_random_transaction","data_source","default","deref","","","","","","","","","deref_mut","","","","","","","","description","","deserialize","","","","","","","","","","","drop","","","","","","","","eq","equivalent","","","","explorer","extends_upgrade","fail","","","fetching","fill_block_payload","fill_block_payload_unchecked","fmt","","","","","","","","","","from","","","","","","","","","","","","","","","","","","","from_fd","from_filelike","from_into_filelike","from_into_socketlike","from_quorum_proposal","from_socketlike","genesis","get_hash","hash","header","","","height","in_current_span","","include_migrations","init","","","","","","","","instantiate_availability_tests","instantiate_data_source_tests","instantiate_node_tests","instantiate_persistence_tests","instantiate_status_tests","internal","into","","","","","","","","into_error","","","justify_qc","layout_raw","","","","","","","","load","","merklized_state","message","metrics","node","","parent_commitment","payload_commitment","pointer_metadata","","","","","","","","port","read","run_standalone_service","serialize","","","source","","status","","","","task","testing","to_owned","","","","","","","to_string","","","try_from","","","","","","","","try_into","","","","","","","","try_resolve","","type_id","","","","","","","","types","upgrade_certificate","view_number","vzip","","","","","","","","message","source","","","","","status","message","AvailabilityDataSource","BlockHash","BlockId","BlockQueryData","BlockRange","BlockSummaryQueryData","Custom","CustomSnafu","Error","Fetch","FetchBlock","FetchBlockSnafu","FetchLeaf","FetchLeafSnafu","FetchTransaction","FetchTransactionSnafu","Hash","","InclusionProof","InconsistentLeafError","InvalidTransactionIndex","InvalidTransactionIndexSnafu","Iter","LeafHash","LeafId","LeafQueryData","LeafRange","Number","","Options","PayloadHash","PayloadQueryData","PayloadRange","Pending","QueryableHeader","QueryablePayload","Ready","Request","RequestSnafu","Timestamp","TransactionHash","TransactionInclusionProof","TransactionIndex","","TransactionQueryData","TransactionSummaryQueryData","UpdateAvailabilityData","VidCommonQueryData","VidCommonRange","__clone_box","","","","","","","","","","","","","","","","","api_path","as_error","","as_error_source","","","","backtrace","","block_hash","","","","block_height","borrow","","","","","","","","","","","","","","","","","","","borrow_mut","","","","","","","","","","","","","","","","","","","build","","","","","by_hash","","cause","","clone","","","","","","","","","","","","","","","","","clone_into","","","","","","","","","","","","","","","","","clone_to_uninit","","","","","","","","","","","","","","","","","cmp","","common","compare","","context","data","default","define_api","deref","","","","","","","","","","","","","","","","","","","deref_mut","","","","","","","","","","","","","","","","","","","description","","deserialize","","","","","","","","","","","","","","","","","","","","","","","","","","","drop","","","","","","","","","","","","","","","","","","","enumerate","","","eq","","","","","","","","","equivalent","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","extensions","fail","","","","","fetch_timeout","fmt","","","","","","","","","","","","","","","","","","","","","from","","","","","","","","","","","","","","","","","","","","","","","","","","","from_row","","","","genesis","","","","get_block","get_block_range","get_hash","","get_leaf","get_leaf_range","get_payload","get_payload_range","get_transaction","get_vid_common","get_vid_common_range","hash","","","","","","","header","","","","","","","height","","","","","","in_current_span","","index","","init","","","","","","","","","","","","","","","","","","","insert_block","insert_leaf","insert_vid","internal","into","","","","","","","","","","","","","","","","","","","into_error","","","","","","into_future","is_empty","","","iter","layout_raw","","","","","","","","","","","","","","","","","","","leaf","","len","","map","message","metadata","new","","","nth","","nth_transaction","","nth_transaction_with_proof","","num_transactions","","partial_cmp","","payload","payload_hash","","","pointer_metadata","","","","","","","","","","","","","","","","","","","proof","","","qc","qc_leaf","resolve","resource","","","serialize","","","","","","","","size","","","source","","status","","subscribe_blocks","","subscribe_leaves","","subscribe_payloads","","subscribe_vid_common","","timestamp","to_owned","","","","","","","","","","","","","","","","","to_string","","","","transaction","","","","transaction_by_hash","","","transaction_by_hash_with_proof","","transaction_with_proof","try_from","","","","","","","","","","","","","","","","","","","try_into","","","","","","","","","","","","","","","","","","","try_resolve","type_id","","","","","","","","","","","","","","","","","","","vzip","","","","","","","","","","","","","","","","","","","with_context","with_timeout","height","index","message","resource","","","source","status","AvailabilityProvider","ExtensibleDataSource","FetchingDataSource","FileSystemDataSource","MetricsDataSource","ReadOnly","SqlDataSource","Transaction","","UpdateDataSource","VersionedDataSource","__clone_box","","as_mut","as_ref","availability_tests","block_height","","","borrow","","borrow_mut","","clone","","clone_into","","clone_to_uninit","","commit","connect","","count_transactions","create","","default","deref","","deref_mut","","deserialize","","drop","","fetching","fmt","","from","","fs","get_block","get_block_detail","get_block_range","get_block_summaries","get_explorer_summary","get_header_window","get_last_state_height","get_leaf","get_leaf_range","get_path","get_payload","get_payload_range","get_search_results","get_transaction","get_transaction_detail","get_transaction_summaries","get_vid_common","get_vid_common_range","handle_event","","init","","inner","inner_mut","insert_block","insert_leaf","insert_merkle_nodes","insert_vid","into","","layout_raw","","metrics","","new","node_tests","payload_size","persistence_tests","pointer_metadata","","populate_metrics","","read","","reset","","revert","set_last_state_height","sql","status_tests","storage","sync_status","to_owned","","try_from","","try_into","","type_id","","update","","vid_share","vzip","","write","","test_range","test_update","AvailabilityProvider","Builder","FetchingDataSource","Pruner","Transaction","__clone_box","","as_mut","as_ref","","block_height","","","borrow","","","","borrow_mut","","","","build","builder","clone","","clone_into","","clone_to_uninit","","commit","connect","count_transactions","","create","create_with_store","deref","","","","deref_mut","","","","deserialize","","","","disable_proactive_fetching","drop","","","","fmt","","","from","","","","get_block","","get_block_detail","","get_block_range","","get_block_summaries","","get_explorer_summary","","get_header","get_header_window","","get_last_state_height","","get_leaf","","get_leaf_range","","get_path","","get_payload","","get_payload_range","","get_search_results","","get_transaction","","get_transaction_detail","","get_transaction_summaries","","get_vid_common","","get_vid_common_range","","init","","","","insert_block","insert_leaf","insert_merkle_nodes","insert_vid","into","","","","layout_raw","","","","load_pruned_height","metrics","new","open","open_with_store","payload_size","","pointer_metadata","","","","populate_metrics","read","revert","set_last_state_height","skip_version","sync_status","","to_owned","","try_from","","","","try_into","","","","type_id","","","","update","vid_share","","vzip","","","","with_active_fetch_delay","with_chunk_fetch_delay","with_major_scan_interval","with_major_scan_offset","with_minor_scan_interval","with_proactive_range_chunk_size","with_range_chunk_size","with_rate_limit","with_retry_delay","write","FileSystemDataSource","Transaction","connect","create","","create_with_store","handle_event","open","open_with_store","reset","skip_version","test_counters","test_sync_status","test_timestamp_window","test_vid_monotonicity","test_vid_recovery","test_vid_shares","test_drop_tx","test_reset","test_revert","Builder","Config","Error","Migration","Postgres","SqlDataSource","Transaction","builder","connect","","","create","handle_event","include_migrations","reset","testing","TmpDb","test_metrics","AvailabilityStorage","ExplorerStorage","FileSystemStorage","MerklizedStateHeightStorage","MerklizedStateStorage","NoStorage","NodeStorage","SqlStorage","block_height","count_transactions","fs","get_block","get_block_detail","get_block_range","get_block_summaries","get_explorer_summary","get_header","get_header_window","get_last_state_height","get_leaf","get_leaf_range","get_path","get_payload","get_payload_range","get_search_results","get_transaction","get_transaction_detail","get_transaction_summaries","get_vid_common","get_vid_common_range","no_storage","payload_size","pruning","sql","sync_status","vid_share","FileSystemStorage","FileSystemStorageInner","Revert","Transaction","block_height","borrow","","","borrow_mut","","","commit","","count_transactions","create","create_with_store","deref","","","deref_mut","","","deserialize","","","drop","","","","fmt","","","from","","","get_block","get_block_range","get_header","get_header_window","get_leaf","get_leaf_range","get_payload","get_payload_range","get_transaction","get_vid_common","get_vid_common_range","init","","","insert_block","insert_leaf","insert_vid","into","","","layout_raw","","","metrics","open","open_with_store","payload_size","pointer_metadata","","","read","revert","","","skip_version","sync_status","try_from","","","try_into","","","type_id","","","update","vid_share","vzip","","","write","NoStorage","Transaction","__clone_box","block_height","borrow","","borrow_mut","","clone","clone_into","clone_to_uninit","commit","count_transactions","default","deref","","deref_mut","","deserialize","","drop","","fmt","from","","get_block","get_block_range","get_header","get_header_window","get_leaf","get_leaf_range","get_payload","get_payload_range","get_transaction","get_vid_common","get_vid_common_range","init","","insert_block","insert_leaf","insert_vid","into","","layout_raw","","metrics","payload_size","pointer_metadata","","read","revert","sync_status","testing","to_owned","try_from","","try_into","","type_id","","update","vid_share","vzip","","write","DataSource","NoStorage","","","Sql","","","Storage","Transaction","__clone_box","block_height","","","borrow","","","borrow_mut","","","clone","clone_into","clone_to_uninit","commit","connect","count_transactions","","create","deref","","","deref_mut","","","deserialize","","","drop","","","fmt","from","","","get_block","get_block_range","get_header_window","","get_leaf","get_leaf_range","get_payload","get_payload_range","get_transaction","get_vid_common","get_vid_common_range","handle_event","init","","","insert_block","insert_leaf","insert_vid","into","","","layout_raw","","","metrics","payload_size","","pointer_metadata","","","populate_metrics","read","reset","revert","setup","sync_status","","to_owned","try_from","","","try_into","","","type_id","","","update","vid_share","","vzip","","","write","fetch_from_port","PruneStorage","PrunedHeightStorage","Pruner","PrunerCfg","PrunerConfig","__clone_box","batch_size","borrow","borrow_mut","clone","clone_into","clone_to_uninit","default","deref","deref_mut","deserialize","drop","fmt","from","get_disk_usage","get_pruning_config","init","interval","into","layout_raw","load_pruned_height","max_usage","minimum_retention","new","pointer_metadata","prune","pruning_threshold","set_pruning_config","target_retention","to_owned","try_from","try_into","type_id","validate","vzip","with_batch_size","with_interval","with_max_usage","with_minimum_retention","with_pruning_threshold","with_target_retention","ArgumentBuffer","Arguments","Column","Config","Connection","Database","","Db","Error","Executor","FixedLengthParams","Migration","NAME","Params","Postgres","Pruner","Query","QueryAs","QueryBuilder","QueryResult","Read","Row","SqlStorage","Sqlite","Statement","Transaction","TransactionManager","TransactionMode","TypeInfo","URL_SCHEMES","Value","ValueRef","Write","__clone_box","","","","applied","applied_on","archive","as_ref","","backtrace","begin","","","bind","","block_height","borrow","","","","","","","","","","","borrow_mut","","","","","","","","","","","bounds_to_where_clause","builder","chain","checksum","cleanup_test","","cleanup_test_dbs","","clone","","","","clone_into","","","","clone_to_uninit","","","","cmp","commit","compare","connect","","connection_timeout","context","count_transactions","create_database","","database","database_exists","","default","","","","","default_migrations","deref","","","","","","","","","","","","","deref_mut","","","","","","","","","","","","","deserialize","","","","","","","","","","","display","","","downcast","downcast_mut","downcast_ref","drop","","","","","","","","","","","","drop_database","","eq","equivalent","","","","execute","","execute_many","","","execute_many_with_retries","execute_one","execute_one_with_retries","fetch","","fetch_all","","fetch_many","fetch_one","","fetch_optional","fmt","","","","","","","","","","","","","fmt_value_debug","","force_drop_database","from","","","","","","","","","","","","","","from_str","get_block","get_block_detail","get_block_range","get_block_summaries","get_disk_usage","get_explorer_summary","get_feature_gate","","get_header","get_header_window","get_last_state_height","get_leaf","get_leaf_range","get_path","get_payload","get_payload_range","get_pruning_config","get_search_results","get_transaction","get_transaction_detail","get_transaction_summaries","get_vid_common","get_vid_common_range","header","","header_where_clause","host","idle_connection_timeout","include_dir","include_migrations","init","","","","","","","","","","","insert_block","insert_leaf","insert_merkle_nodes","insert_vid","into","","","","","","","","","","","is","layout_raw","","","","","","","","","","","load_header","load_pruned_height","max_connections","metrics","migrations","min_connections","msg","name","new","no_migrations","param_type_for_id","","partial_cmp","password","payload_size","pointer_metadata","","","","","","","","","","","port","prefix","prepare","","prepare_with","prune","pruner_cfg","query","","query_as","","read","reset_schema","return_type_for_id","","revert","root_cause","schema","set_applied","set_last_state_height","set_pruning_config","snapshot","","sql","sqlx","sync_status","test_context","","testing","tls","to_owned","","","","to_string","","try_from","","","","","","","","","","","try_into","","","","","","","","","","","type_id","","","","","","","","","","","unapplied","update","upsert","user","version","vid_share","vzip","","","","","","","","","","","write","TestMerkleTreeMigration","TmpDb","borrow","","borrow_mut","","config","deref","","deref_mut","","deserialize","","drop","","","fmt","from","","host","init","","","into","","layout_raw","","persistent","pointer_metadata","","port","start","stop","try_from","","try_into","","type_id","","vzip","","BalanceAmount","","Block","BlockDetail","BlockDetailResponse","BlockIdentifier","BlockNamespaceId","BlockNotFound","BlockRange","BlockSummary","BlockSummaryResponse","Btc","CryptoEnd","CryptoStart","CurrencyCode","CurrencyMismatchError","Error","Esp","Eth","Eur","ExplorerDataSource","ExplorerHeader","ExplorerHistograms","ExplorerSummary","ExplorerSummaryResponse","ExplorerTransaction","FeeAttribution","FiatCurrencyEnd","FiatCurrencyStart","Gbp","GenesisOverview","GetBlockDetail","GetBlockDetailError","","GetBlockSummaries","GetBlockSummariesError","","GetBlockSummariesRequest","GetExplorerSummary","GetExplorerSummaryError","GetSearchResults","GetSearchResultsError","GetTransactionDetail","GetTransactionDetailError","GetTransactionSummaries","GetTransactionSummariesError","","GetTransactionSummariesRequest","Hash","","Height","HeightAndOffset","IntError","InvalidCurrencyCodeError","InvalidLimit","","InvalidQuery","Jpy","Latest","","MonetaryValue","NamespaceId","","None","ProposerId","","QueryError","","","","","","RollUp","SearchResult","SearchResultResponse","TargetNotFound","","TimeError","Timestamp","TimestampConversionError","TokenEnd","TokenStart","TransactionDetail","TransactionDetailResponse","TransactionIdentifier","TransactionNamespaceId","TransactionNotFound","TransactionRange","TransactionSummariesResponse","TransactionSummary","TransactionSummaryFilter","Unimplemented","","","","","","Usd","WalletAddress","","Xxx","__clone_box","","","","","","","","","","","","","","","","add","as_error","","","","","","","","as_error_source","","","","","","","","","","","","","","","","block_confirmed","block_detail","block_heights","block_reward","block_size","block_summaries","block_time","block_transactions","blocks","","borrow","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","borrow_mut","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","btc","clone","","","","","","","","","","","","","","","","clone_into","","","","","","","","","","","","","","","","clone_to_uninit","","","","","","","","","","","","","","","","cmp","compare","currency","","currency1","currency2","default","define_api","deref","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","deref_mut","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","deserialize","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","drop","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","eq","","","","","","","","","","","","","","equivalent","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","esp","eth","explorer_summary","fee_details","fee_info_account","fee_info_balance","fee_recipient","fees","filter","fmt","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","from","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","from_row","","genesis_overview","get_block_detail","get_block_summaries","get_explorer_summary","get_search_results","get_transaction_detail","get_transaction_summaries","hash","","","","header","","","","","","","","","","","","","","height","","","","histograms","in_current_span","","","","","","","","init","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","into","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","into_resettable","is_crypto","is_fiat","is_token","latest_block","latest_blocks","latest_transactions","layout_raw","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","namespace_id","namespace_ids","new","num_blocks","num_transactions","","","","","offset","","partial_cmp","pointer_metadata","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","proposer_id","","","range","reward_balance","rollups","","search_results","sequencing_fees","serialize","","","","","","","","","","","","","","","","","","","","","","","","","","","","significant_digits","size","","","source","","","","","","","","status","","","","","","","sub","target","","","time","","","","to_owned","","","","","","","","","","","","","","","","to_string","","","","","","","","","","","","","","transaction_detail","transaction_summaries","transactions","","try_from","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","try_into","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","type_id","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","usd","value","vzip","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","","Callback","Fetcher","LocalCallback","Provider","Request","__clone_box","borrow","borrow_mut","clone","clone_into","clone_to_uninit","default","deref","deref_mut","deserialize","drop","fmt","from","init","into","layout_raw","pointer_metadata","provider","request","run","","spawn_fetch","to_owned","try_from","try_into","type_id","vzip","with_rate_limit","with_retry_delay","AnyProvider","NoFetching","Provider","QueryServiceProvider","TestProvider","__clone_box","","","","block","borrow","","","","borrow_mut","","","","clone","","","","clone_into","","","","clone_to_uninit","","","","default","","deref","","","","deref_mut","","","","deserialize","","","","drop","","","","fail","fetch","","","","","","","","","fmt","","","","from","","","","init","","","","into","","","","layout_raw","","","","new","","pointer_metadata","","","","to_owned","","","","try_from","","","","try_into","","","","type_id","","","","unblock","unfail","vzip","","","","with_block_provider","with_leaf_provider","with_provider","with_vid_common_provider","LeafRequest","PayloadRequest","Request","Response","VidCommonRequest","__clone_box","","","borrow","","","borrow_mut","","","clone","","","clone_into","","","clone_to_uninit","","","deref","","","deref_mut","","","deserialize","","","drop","","","eq","","","equivalent","","","","","","","","","","","","fmt","","","from","","","","get_hash","","","hash","","","init","","","into","","","layout_raw","","","pointer_metadata","","","to_owned","","","try_from","","","try_into","","","type_id","","","vzip","","","Commit","","Custom","Digest","Entry","Error","Index","Key","MerklizedState","MerklizedStateDataSource","MerklizedStateHeightPersistence","Options","Query","Request","Snapshot","T","UpdateStateData","__clone_box","","api_path","as_error","as_error_source","","backtrace","borrow","","","borrow_mut","","","cause","clone","","clone_into","","clone_to_uninit","","cmp","compare","default","define_api","deref","","","deref_mut","","","description","deserialize","","","","drop","","","eq","equivalent","","","","extensions","fmt","","","","from","","","","","","get_hash","get_last_state_height","get_path","hash","header","","header_state_commitment_field","in_current_span","init","","","insert_merkle_nodes","insert_path","into","","","layout_raw","","","partial_cmp","pointer_metadata","","","serialize","set_last_state_height","source","state_type","status","to_owned","","to_string","","tree_height","try_from","","","try_into","","","type_id","","","vzip","","","message","source","","status","Counter","CounterFamily","Gauge","GaugeFamily","Histogram","HistogramFamily","MetricsError","NoSuchMetric","NoSuchSubgroup","Prometheus","PrometheusMetrics","TextFamily","__clone_box","","","","","","","","add","add_point","as_error","as_error_source","","backtrace","borrow","","","","","","","","","borrow_mut","","","","","","","","","cause","clone","","","","","","","","clone_into","","","","","","","","clone_to_uninit","","","","","","","","counter_family","create","","","","create_counter","create_gauge","create_histogram","create_text","default","deref","","","","","","","","","deref_mut","","","","","","","","","description","deserialize","","","","","","","","","drop","","","","","","","","","export","fmt","","","","","","","","","","from","","","","","","","","","","gauge_family","","get","","","","","get_counter","get_counter_family","get_gauge","get_histogram","get_histogram_family","get_subgroup","header","histogram_family","in_current_span","init","","","","","","","","","into","","","","","","","","","layout_raw","","","","","","","","","mean","pointer_metadata","","","","","","","","","sample_count","set","source","subgroup","sum","text_family","to_owned","","","","","","","","to_string","try_from","","","","","","","","","try_into","","","","","","","","","type_id","","","","","","","","","update","vzip","","","","","","","","","name","namespace","path","source","BlockHash","BlockId","Custom","CustomSnafu","Error","Hash","Height","NodeDataSource","Options","Query","QuerySnafu","QueryVid","QueryVidSnafu","QueryWindow","QueryWindowSnafu","Request","RequestSnafu","SyncStatus","Time","TimeWindowQueryData","WindowStart","__clone_box","","","","","","","","","api_path","as_error","as_error_source","","backtrace","block","block_height","borrow","","","","","","","","","","borrow_mut","","","","","","","","","","build","cause","clone","","","","","","","","","clone_into","","","","","","","","","clone_to_uninit","","","","","","","","","cmp","compare","count_transactions","default","","define_api","deref","","","","","","","","","","deref_mut","","","","","","","","","","description","deserialize","","","","","","","","","","","","","drop","","","","","","","","","","end","eq","","equivalent","","","","","","","","extensions","fail","fmt","","","","","","","","","","from","","","","","","","","","","","","","","","fully_synced","get_hash","get_header_window","hash","header","in_current_span","init","","","","","","","","","","internal","into","","","","","","","","","","into_error","","","","","is_fully_synced","layout_raw","","","","","","","","","","message","missing_blocks","missing_leaves","missing_vid_common","missing_vid_shares","next","partial_cmp","payload_size","pointer_metadata","","","","","","","","","","prev","pruned_height","serialize","","","source","start","status","","sync_status","to_owned","","","","","","","","","to_string","try_from","","","","","","","","","","try_into","","","","","","","","","","type_id","","","","","","","","","","vid_share","vzip","","","","","","","","","","window","block","end","message","source","","","","start","status","Error","HasMetrics","Internal","Options","Request","StatusDataSource","UpdateStatusData","__clone_box","api_path","as_error","as_error_source","","backtrace","block_height","borrow","","borrow_mut","","cause","clone","clone_into","clone_to_uninit","consensus_metrics","","default","define_api","deref","","deref_mut","","description","deserialize","","","drop","","elapsed_time_since_last_decide","","extensions","fmt","","from","","","","header","in_current_span","init","","into","","layout_raw","","metrics","pointer_metadata","","populate_metrics","serialize","source","status","success_rate","","to_owned","to_string","try_from","","try_into","","type_id","","vzip","","reason","source","BackgroundTask","Task","__clone_box","borrow","","borrow_mut","","clone","clone_into","clone_to_uninit","deref","","deref_mut","","deserialize","","drop","","","fmt","","from","","init","","into","","join","layout_raw","","pointer_metadata","","spawn","","to_owned","try_from","","try_into","","type_id","","vzip","","consensus","mocks","setup_test","sleep","DataSourceLifeCycle","MockDataSource","MockNetwork","MockSqlDataSource","NUM_NODES","Storage","TestableDataSource","borrow","borrow_mut","connect","create","data_source","data_source_index","deref","deref_mut","deserialize","drop","","from","handle","handle_event","init","","init_with_config","into","layout_raw","num_nodes","pointer_metadata","proposer","reset","setup","shut_down","spawn","start","storage","submit_transaction","try_from","try_into","type_id","vzip","MockAuctionResults","MockBase","MockHeader","MockMembership","MockMerkleTree","MockNetwork","MockNodeImpl","MockPayload","MockQuorumProposal","MockStorage","MockTransaction","MockTypes","MockVersions","__clone_box","","","block_header","block_number","borrow","","","borrow_mut","","","builder_commitment","clone","","","clone_into","","","clone_to_uninit","","","cmp","","compare","","decided_upgrade_certificate","default","","delay_config","deref","","","deref_mut","","","deserialize","","","","","drop","","","eq","","equivalent","","","","","","","","fee_info_account","fee_info_balance","fmt","","","from","","","get_hash","","hash","","header_state_commitment_field","height","init","","","insert_path","into","","","iter","justify_qc","layout_raw","","","len","metadata","mock_transaction","namespace_id","namespace_ids","partial_cmp","","payload_commitment","pointer_metadata","","","proposal_certificate","proposer_id","random","reward_balance","serialize","","should_return_err","state_type","timestamp","","to_owned","","","transaction_with_proof","transactions","tree_height","try_from","","","try_into","","","type_id","","","upgrade_certificate","urls","view_number","vzip","","","HeightIndexed","height"],"q":[[0,"hotshot_query_service"],[307,"hotshot_query_service::Error"],[314,"hotshot_query_service::QueryError"],[315,"hotshot_query_service::availability"],[992,"hotshot_query_service::availability::Error"],[1000,"hotshot_query_service::data_source"],[1117,"hotshot_query_service::data_source::availability_tests"],[1119,"hotshot_query_service::data_source::fetching"],[1280,"hotshot_query_service::data_source::fs"],[1291,"hotshot_query_service::data_source::node_tests"],[1297,"hotshot_query_service::data_source::persistence_tests"],[1300,"hotshot_query_service::data_source::sql"],[1316,"hotshot_query_service::data_source::sql::testing"],[1317,"hotshot_query_service::data_source::status_tests"],[1318,"hotshot_query_service::data_source::storage"],[1354,"hotshot_query_service::data_source::storage::fs"],[1440,"hotshot_query_service::data_source::storage::no_storage"],[1505,"hotshot_query_service::data_source::storage::no_storage::testing"],[1602,"hotshot_query_service::data_source::storage::no_storage::testing::Storage"],[1603,"hotshot_query_service::data_source::storage::pruning"],[1649,"hotshot_query_service::data_source::storage::sql"],[2049,"hotshot_query_service::data_source::storage::sql::testing"],[2090,"hotshot_query_service::explorer"],[3167,"hotshot_query_service::fetching"],[3201,"hotshot_query_service::fetching::provider"],[3311,"hotshot_query_service::fetching::request"],[3401,"hotshot_query_service::merklized_state"],[3517,"hotshot_query_service::merklized_state::Error"],[3521,"hotshot_query_service::metrics"],[3763,"hotshot_query_service::metrics::MetricsError"],[3767,"hotshot_query_service::node"],[4064,"hotshot_query_service::node::Error"],[4073,"hotshot_query_service::status"],[4145,"hotshot_query_service::status::Error"],[4147,"hotshot_query_service::task"],[4190,"hotshot_query_service::testing"],[4194,"hotshot_query_service::testing::consensus"],[4234,"hotshot_query_service::testing::mocks"],[4368,"hotshot_query_service::types"],[4370,"dyn_clone::sealed"],[4371,"core::error"],[4372,"hotshot_query_service::error"],[4373,"std::backtrace"],[4374,"core::option"],[4375,"hotshot_types::data"],[4376,"hotshot_types::traits::node_implementation"],[4377,"alloc::string"],[4378,"core::convert"],[4379,"tide_disco::status"],[4380,"core::clone"],[4381,"hotshot_types::message"],[4382,"committable"],[4383,"hotshot_query_service::resolvable"],[4384,"rand_core"],[4385,"rkyv::with"],[4386,"core::result"],[4387,"serde::de"],[4388,"hotshot_types::simple_vote"],[4389,"hotshot_types::simple_certificate"],[4390,"async_lock::rwlock"],[4391,"alloc::sync"],[4392,"anyhow"],[4393,"core::fmt"],[4394,"hotshot_query_service::explorer::query_data"],[4395,"sqlx_core::error"],[4396,"std::os::fd::owned"],[4397,"io_lifetimes::portability"],[4398,"core::hash"],[4399,"core::marker"],[4400,"color_eyre::section"],[4401,"core::alloc::layout"],[4402,"arc_swap::access"],[4403,"core::future::future"],[4404,"alloc::boxed"],[4405,"core::pin"],[4406,"futures_core::future"],[4407,"core::ops::function"],[4408,"hotshot::types::handle"],[4409,"hotshot_query_service::availability::data_source"],[4410,"hotshot_query_service::node::data_source"],[4411,"hotshot_query_service::status::data_source"],[4412,"hotshot_query_service::data_source::update"],[4413,"vbs::version"],[4414,"serde::ser"],[4415,"core::any"],[4416,"hotshot_query_service::availability::query_data"],[4417,"core::cmp"],[4418,"core::iter::traits::iterator"],[4419,"hotshot_types::vid"],[4420,"hotshot_query_service::availability::fetch"],[4421,"snafu"],[4422,"tide_disco::api"],[4423,"tide_disco::method"],[4424,"tide_disco::request"],[4425,"futures_core::stream"],[4426,"core::ops::range"],[4427,"core::time"],[4428,"hotshot_query_service::data_source::extension"],[4429,"hotshot_query_service::data_source::metrics"],[4430,"hotshot_query_service::explorer::data_source"],[4431,"hotshot_query_service::merklized_state::data_source"],[4432,"hotshot_types::event"],[4433,"core::default"],[4434,"jf_merkle_tree::internal"],[4435,"alloc::vec"],[4436,"hotshot_types::traits::metrics"],[4437,"hotshot_query_service::data_source::fetching::notify_storage"],[4438,"std::path"],[4439,"atomic_store::atomic_store"],[4440,"core::ops::deref"],[4441,"atomic_store::error"],[4442,"time::offset_date_time"],[4443,"refinery_core::runner"],[4444,"sqlx_core::database"],[4445,"hotshot_query_service::data_source::storage::sql::transaction"],[4446,"hotshot_query_service::data_source::storage::sql::queries"],[4447,"hotshot_query_service::data_source::storage::sql::db"],[4448,"sqlx_core::encode"],[4449,"sqlx_core::types"],[4450,"sqlx_postgres::database"],[4451,"sqlx_core::executor"],[4452,"sqlx_sqlite::database"],[4453,"sqlx_core::type_checking"],[4454,"sqlx_postgres::options"],[4455,"core::iter::traits::collect"],[4456,"sqlx_core::from_row"],[4457,"sqlx_core::testing"],[4458,"refinery_core::error"],[4459,"hotshot_query_service::explorer::monetary_value"],[4460,"hotshot_query_service::explorer::currency"],[4461,"hotshot_query_service::explorer::traits"],[4462,"core::num::error"],[4463,"time::error::component_range"],[4464,"clap_builder::builder::resettable"],[4465,"async_lock::semaphore"],[4466,"hotshot_query_service::fetching::provider::testing"],[4467,"hotshot_query_service::fetching::provider::any"],[4468,"hotshot_query_service::fetching::provider::query_service"],[4469,"url"],[4470,"jf_merkle_tree"],[4471,"core::str::traits"],[4472,"ark_serialize"],[4473,"tagged_base64"],[4474,"prometheus::errors"],[4475,"hotshot_query_service::node::query_data"],[4476,"hotshot_types::signature_key"],[4477,"hotshot_types"],[4478,"include_dir_macros"]],"i":"`j0AKf`A``2``2`0`20`1``````2````Ab3AhAjAl4Bf757755`Cf86555584326015843260143288658432615843261584326155Bn66`16954371226954371297669954377126954371266666`6543`6666995437726999999954377712222222262666697697`69543712`````96954371254366954371222`3``1666954371212`69797`971``695437269769543712695437120669543712`6669543712BMdBMfBMhBMjBMlBMn5BN`````Il`Ej```0`0`0`MhMjLj`3`0```421`1`4Nh``04`````1````532K`JnMlKdKfKhMnN`NbKjKlKnL`LbEjOd>1>>11>1?<;::Nh1MhMjK`JnMlKdKfKhMnN`NbKjKlKnL`LbEjNhOdMhMjK`JnMlKdKfKhMnN`NbKjKlKnL`LbEj54321Lj0>1MhMjK`JnMlKdKfKhMnN`NbKjKlKnL`LbEjMhMjK`JnMlKdKfKhMnN`NbKjKlKnL`LbEjMhMjK`JnMlKdKfKhMnN`NbKjKlKnL`LbEjMhMj<10Nh>Od`1032K`JnMlKdKfKhMnN`NbKjKlKnL`LbEjNhOdMhMjK`JnMlKdKfKhMnN`NbKjKlKnL`LbEj=0NhOdMhMjK`0JnMl0Kd0Kf0Kh0Mn0N`0NbKjKlKnL`LbEj0NhOdMhMjK`JnMlKdKfKhMnN`NbKjKlKnL`LbEjLj0=MhMjK`MlKdKfKhMnN`888877776666555544443333222211110000OdKjKlKnL`Lb5>>===0000000>=<;:87>==<;9410:4NhOdMhMjK`6MlKdKfKhMnN`NbKjKlKnL`LbEjAAj001NhOdMhMjK`JnMlKdKfKhMnN`NbKjKlKnL`LbEj654321NhLj0>01OdMhMjK`JnMlKdKfKhMnN`NbKjKlKnL`LbEj>=Lj=Nh3>K`?=222222?;MhMjMl30Kf5Od435Jn3Kd3KhMnN`NbKjKlKnL`LbEjLj0:K`=Nh8761Ml>Kf>=<51?=Jn667Il0000000ABdMhMj846Kd6KhMnN`NbKjKlKnL`LbEj<;?0Lj0Ml;110111NhOdMhMjK`Jn6KdKfKhMnN`NbKjKlKnL`LbEjNhOdMhMjK`JnMlKdKfKhMnN`NbKjKlKnL`LbEjNh0OdMhMjK`JnMlKdKfKhMnN`NbKjKlKnL`LbEjNhOdMhMjK`JnMlKdKfKhMnN`NbKjKlKnL`LbEjNh0BNb0BNdBNfBNhBNjBNl4`````Jb``0``ABhABj11`1101010101010ABl21221121212121`2121`22222222222222222221212222222121212`2`2121322102```221212121AEl333243```````AF`AFjAEn02022AFd132013203323232131333013201320132001321320132131313131311313131313131313131313131301321111013201321303313013233113133201320132013211301320000000003``AH`00000000````````````````AFl0AHb000`0```````````AFb0`AGfAGh10012AGj22AGl33232233`4``44````AHdAHjAGb21022220010210210210221021022222222222210222210210200021020AHf3313213213213332131``AIfAId010111100101010101101000000000000100001011001100`101010100011`BNnAIhAIj210``0100210210000101002102102102100210001000000000210111210210010210000101002102102101102100BO```AFf``AIn00000000000001AJb1111AGn22223212222222222222AJn00`0`AM``````1``````1`1``1`1`1111`AJjALfALhAJl330Dn00AL`43AK`AKdAKn48AMdALb39827ALjALl8<325;:4910598<3232<;:9<;:9<;:9<4<91984329325;:90`88<325;:4491088<325;:449108<325;:49107;:88888<325;:491032<<<<<====4444========88<<325;:4910322888<325;:499109444414324444444414444448<599``8<325;:491044448<325;:491088<325;:49104491998<8932<948<325;:49109<===19`5`51932489<4132<`432`9<;:98<8<325;:49108<325;:49108<325;:4910<449<48<325;:49101``BObANl1001010101000100100101001000010101010`BCbBAd````AOn```AOf00```000```````000`F``B@f1`0`1`1`1`1`0`AC`AD`10Ff`B@`B@dB@h854`;BCj;`<:3B@b382<``435``::````0````;40382:`=:AObAOd>22==99<<00;;11BA`BAnBAhB@j1BB`22BAfBAl?>AOf>AC`AD`?>=6B@lFfB@nBAj;AOnB@`B@bB@dB@fB@hF`BAnBB`BBbBBdBBfBBhAObAOdAOfANnAC`AD`AOhAOjAOlB@jB@lFfB@nBA`BAbACdBAdADbBAfBAhBAjBAlAOnB@`B@bB@dB@fB@hF`BAnBB`BBbBBdBBfBBhANnAObAOdAOf3AC`AD`AOhAOjAOlAOnB@`B@bB@dB@fB@hF`>==>ADb`?>=ANn=<;:9B@jB@lFfB@nBA`BAbACdBAd9BAfBAhBAjBAlAOnB@`B@bB@dB@fB@hF`BAnBB`BBbBBdBBfBBhAObAOdAOfANnAC`AD`AOhAOjAOlB@jB@lFfB@nBA`BAbACdBAdADbBAfBAhBAjBAlAOnB@`B@bB@dB@fB@hF`BAnBB`BBbBBdBBfBBhAOb0AOd0AOf0ANn0AC`AD`AOhAOjAOl0B@j0B@l0FfB@n0BA`0BAb0ACdBAd0ADbBAf0BAh0BAj0BAl0AOn0B@`0B@b0B@d0B@f0B@h0F`0BAn0BB`0BBb0BBd0BBf0BBh0AObAOdAOfANnAC`AD`AOhAOjAOlB@jB@lFfB@nBA`BAbACdBAdADbBAfBAhBAjBAlAOnB@`B@bB@dB@fB@hF`BAnBB`BBbBBdBBfBBhAOfANnAC`AD`AOhAOjAOlB@jB@lFfB@nBA`BAbACd====<<<<;;;;::::9999888877776666555544443333222211110000<=B@nBA`BAb0ACdBAdADbBAfBAhBAjBAlAOnB@`B@bB@dB@fB@hF`BAnBB`BBbBBdBBfBBhAObAOdAOfANnAC`AD`AOhAOjAOlB@jB@lFfB@nBA`BAbACdBAdADbBAfBAhBAjBAlAOnB@`B@bB@dB@fB@hF`BAnBB`BBbBBdBBfBBhAObAOdAOfANnAC`AD`AOhAOjAOlB@jB@lFfB@nBA`BAbACdBAdADbBAfBAhBAjBAlAOnB@`B@bB@dB@fB@hF`BAnBB`BBbBBdBBfBBhANn0AObAOdAOf3AC`AD`AOhAOjAOlB@jB@lFfB@nBA`BAbACdBAdADbBAfBAhBAjBAlAOnB@`B@bB@dB@fB@hF`BAnBB`BBbBBdBBfBBh`````BCl0000000000000000``BCnBD`22222222`````BDjBDlBDhBDn1321032103210321032103032103210321032101BDd444333214321432143214321432132432143214321432143212243214444```BDb`BEbBEdBE`2102102102102102102102102102102222111100002102100210210210210210210210210210210210ACjAClFd11`21````00`1`20BEh11113013011313131330`3013011301130133333033113011113AChACn55343523AE`563463466344045464645634634634634BOdBOfBOh2```````BH`00``AEbBGjBHbBGlBHdBHfBHhBHj648888876543210876543210876543210765432107654321073210777778765432108765432108876543210876543210788765432108876543210776532177777787887654321087654321087654321048765432104587477654321088765432108765432108765432105876543210BOj0BOlBOn``El``ACf0``1`1`1`1``0``0BJbBJdBJfBJhBJjBJlBJ`8BJn99993In987165432:987165432:2:98765432:98765432:98765432:88071`987165432:987165432::98877165432::987165432:387888877771298765432::99877165432::::8808::987165432::987165432:654328987165432:28888780987165432:7887::3:2098765432::987165432:987165432:987165432:0987165432:7C@`C@bC@dC@fC@h4332``Fb`0``0BKd1111J`12122222001`121221221200122122222121212AEd23BKf444224434343434C@jC@l``BKh0BKj10111101010100101010100101010110101010`````````BKl`AIl01100000000010000000011000000000`````````````ADdBL`BKnC@nBLl43243204324324324242CA`530543543554335435355553333115435435353BLn26540654BM`476503`BLj486487654448632448761128768768765CAb6987`BKb","f":"`````````````````````````````{{bd}f}000000{b{{b{h}}}}00000``{{{b{j}}}{{n{{b{l}}}}}}{{{b{A`}}}{{n{{b{l}}}}}}{{{b{{Ab{c}}}}}bAd}{{{b{Af{Ab{c}}}}}{{b{Af}}}Ad}{{{b{{Ab{c}}}}}nAd}{b{{b{c}}}{}}0000000{{{b{Af}}}{{b{Afc}}}{}}0000000{AhA`}{AjA`}{{{Al{c}}}A`{{B`{An}}}}{{BbAn}j}{{{b{j}}}{{n{{b{h}}}}}}{{{b{A`}}}{{n{{b{h}}}}}}{{{b{{Ab{c}}}}}{{Ab{c}}}{BdAd}}{{{b{j}}}j}{{{b{Ah}}}Ah}{{{b{Aj}}}Aj}{{{b{{Al{c}}}}}{{Al{c}}}Bd}{{{b{A`}}}A`}{{{b{{Bf{c}}}}}{{Bf{c}}}Bd}{{b{b{Afc}}}f{}}000000{bf}000000{{{b{{Ab{c}}}}{b{{Bh{ce}}}}}{{Bj{{Ab{c}}}}}AdBl}{{{b{{Ab{c}}}}}{{Bj{{Ab{c}}}}}Ad}{{{b{Bn}}}{{Bj{c}}}C`}{b{{Bj{c}}}{}}{{{b{{Ab{c}}}}{b{AfCb}}Cd}{}Ad}`{{}Cf}{Ch{{b{c}}}{}}000000{{{b{{Bf{c}}}}}{{b{e}}}{}{}}1{Ch{{b{Afc}}}{}}0000000{{{b{j}}}{{b{Cj}}}}{{{b{A`}}}{{b{Cj}}}}{{b{b{Afc}}}{{Cn{{Cl{eg}}}}}{}{}{}}{c{{Cn{{Ab{e}}}}}D`Ad}1{c{{Cn{j}}}D`}222{c{{Cn{A`}}}D`}333{Chf}0000000{{{b{{Ab{c}}}}{b{{Ab{c}}}}}DbAd}{{b{b{c}}}Db{}}000`{{{b{{Ab{c}}}}{b{{Ab{c}}}}{b{{Dl{{Dj{{n{{Dh{c{Dd{c}}Df}}}}}}}}}}}{{Cn{fDn}}}Ad}{Ah{{Cn{cA`}}}{}}{Aj{{Cn{cA`}}}{}}{{{Al{c}}}{{Cn{eA`}}}{{B`{An}}}{}}`{{{b{Af{Ab{c}}}}Ch}{{Cn{fE`}}}Ad}{{{b{Af{Ab{c}}}}}fAd}{{{b{{Ab{c}}}}{b{AfEb}}}{{Cn{fEd}}}{EfAd}}{{{b{{Ab{c}}}}{b{AfEb}}}{{Cn{fEd}}}Ad}{{{b{j}}{b{AfEb}}}Eh}0{{{b{Ah}}{b{AfEb}}}Eh}{{{b{Aj}}{b{AfEb}}}Eh}{{{b{{Al{c}}}}{b{AfEb}}}EhEf}{{{b{A`}}{b{AfEb}}}Eh}0{{{b{{Bf{c}}}}{b{AfEb}}}EhEf}{cc{}}{Ejj}{Elj}{{{En{AnBb}}}j}{F`j}{Fbj}{Fdj}6666{FfA`}7{FhA`}88{{{Dl{c}}}{{Bf{c}}}{}}{Fjc{}}{c{{Bf{c}}}{}}{Flc{}}0{ceFn{}}{ceG`{}}{{{b{{Gb{c}}}}}{{Ab{c}}}Ad}3{{bb}{{Ab{c}}}Ad}{{{b{c}}{b{e}}}Cd{GdGf}Gh}{{{b{{Ab{c}}}}{b{Afe}}}fAdGj}{c{{Gl{ce}}}{GnH`Hb}{}}00{{{b{{Ab{c}}}}}CdAd}{{}}0`{{}Ch}0000000`````{cjGn}{{}c{}}0000000{{Ahc}A`{}}{{Ajc}A`{}}{{{Al{c}}e}A`{{B`{An}}}{}}{{{b{{Ab{c}}}}}{{Dh{c{Hd{c}}Hf}}}Ad}{{}{{Cn{HhHj}}}}0000000{b}{b{{Hl{c}}}{}}`````{{{b{{Ab{c}}}}}{{Bj{{Ab{c}}}}}Ad}{{{b{{Ab{c}}}}}{}Ad}33333333`{{{b{{Bf{c}}}}i}{{Ib{{I`{Hn}}}}}{H`Hb}{}{}{H`{Ih{{b{e}}}{{Id{{If{g}}}}}}}}{{Cfe{Ij{cgi}}k}{{Cn{fj}}}Ad{{Il{c}}{In{c}}J`JbH`Hb}{{Jd{c}}}BlJf}{{{b{{Ab{c}}}}e}Cn{AdJh}Jj}{{{b{j}}c}CnJj}{{{b{A`}}c}CnJj}{{{b{j}}}{{n{{b{h}}}}}}{{{b{A`}}}{{n{{b{h}}}}}}`{{{b{j}}}Bb}{{{b{A`}}}Bb}```{bc{}}000000{bAn}00{c{{Cn{e}}}{}{}}0000000{{}{{Cn{c}}}{}}0000000{Bn{{Cn{cBn}}}C`}{{}{{Cn{cc}}}{}}{bJl}0000000`{{{b{{Ab{c}}}}}{{n{{Dh{c{Dd{c}}Df}}}}}Ad}{{{b{{Ab{c}}}}}{}Ad}{{}c{}}0000000`````````````````````````````````````````````````````````{{bd}f}0000000000000000`{b{{b{h}}}}00000{{{b{{Jn{c}}}}}{{n{{b{l}}}}}Ad}{{{b{Ej}}}{{n{{b{l}}}}}}{{{b{{K`{c}}}}}{{Kb{c}}}Ad}{{{b{{Kd{c}}}}}{{Kb{c}}}Ad}{{{b{{Kf{c}}}}}{{Kb{c}}}Ad}{{{b{{Kh{c}}}}}{{Kb{c}}}Ad}{{{b{{Kh{c}}}}}CdAd}{b{{b{c}}}{}}000000000000000000{{{b{Af}}}{{b{Afc}}}{}}000000000000000000{{{Kj{c}}}Ej{{B`{An}}}}{{{Kl{c}}}Ej{{B`{An}}}}{{{Kn{c}}}Ej{{B`{An}}}}{{{L`{ce}}}Ej{{B`{Cd}}}{{B`{Cd}}}}{{{Lb{ce}}}Ej{{B`{An}}}{{B`{Bb}}}}{{{b{{Lj{}{{Ld{c}}{Lf{e}}{Lh{g}}}}}}{b{i}}{Bj{k}}}{{n{c}}}{BdEfLlLnM`JhMbH`Hb}{{Mf{}{{Md{c}}}}}{BdEfLlLnJhMbH`Hb}{}{}}0{{{b{{Jn{c}}}}}{{n{{b{h}}}}}Ad}{{{b{Ej}}}{{n{{b{h}}}}}}{{{b{{Mh{c}}}}}{{Mh{c}}}Ad}{{{b{{Mj{c}}}}}{{Mj{c}}}Ad}{{{b{{K`{c}}}}}{{K`{c}}}{BdAd}}{{{b{{Jn{c}}}}}{{Jn{c}}}{BdAd}}{{{b{{Ml{c}}}}}{{Ml{c}}}{BdAd}}{{{b{{Kd{c}}}}}{{Kd{c}}}{BdAd}}{{{b{{Kf{c}}}}}{{Kf{c}}}{BdAd}}{{{b{{Kh{c}}}}}{{Kh{c}}}{BdAd}}{{{b{{Mn{c}}}}}{{Mn{c}}}{BdAd}}{{{b{{N`{c}}}}}{{N`{c}}}{BdAd}}{{{b{Nb}}}Nb}{{{b{{Kj{c}}}}}{{Kj{c}}}Bd}{{{b{{Kl{c}}}}}{{Kl{c}}}Bd}{{{b{{Kn{c}}}}}{{Kn{c}}}Bd}{{{b{{L`{ce}}}}}{{L`{ce}}}BdBd}{{{b{{Lb{ce}}}}}{{Lb{ce}}}BdBd}{{{b{Ej}}}Ej}{{b{b{Afc}}}f{}}0000000000000000{bf}0000000000000000{{{b{{Mh{c}}}}{b{{Mh{c}}}}}NdAd}{{{b{{Mj{c}}}}{b{{Mj{c}}}}}NdAd}{{{b{{Kf{c}}}}}{{b{Nf}}}Ad}{{b{b{c}}}Nd{}}0{{{Nh{c}}g}{{Cn{ce}}}{}{hNj}{{O`{e}{{Nl{Nn}}}}}}{{{b{{Kd{c}}}}}{{b{{Ob{c}}}}}Ad}{{}Od}{{{b{Od}}c}{{Cn{{Of{eEjc}}Oh}}}Jf{H`HbOj}}{Ch{{b{c}}}{}}000000000000000000{Ch{{b{Afc}}}{}}000000000000000000{{{b{{Jn{c}}}}}{{b{Cj}}}Ad}{{{b{Ej}}}{{b{Cj}}}}{{b{b{Afc}}}{{Cn{{Cl{eg}}}}}{}{}{}}000{c{{Cn{{K`{e}}}}}D`Ad}11{c{{Cn{{Ml{e}}}}}D`Ad}22{c{{Cn{{Kd{e}}}}}D`Ad}{c{{Cn{{Kf{e}}}}}D`Ad}4{c{{Cn{{Kh{e}}}}}D`Ad}5{c{{Cn{{Mn{e}}}}}D`Ad}66{c{{Cn{{N`{e}}}}}D`Ad}7777777{c{{Cn{Ej}}}D`}{Chf}000000000000000000{{{b{{Lj{}{{Ld{c}}{Lf{e}}{Lh{g}}}}}}{b{i}}}{{I`{Mf}}}{BdEfLlLnM`JhMbH`Hb}{{Mf{}{{Md{c}}}}}{BdEfLlLnJhMbH`Hb}{}}0{{{b{{Ml{c}}}}}{{`{{Mf{}{{Md{{En{{Ol{c}}{On{c}}}}}}}}}}}Ad}{{{b{{Mh{c}}}}{b{{Mh{c}}}}}DbAd}{{{b{{Mj{c}}}}{b{{Mj{c}}}}}DbAd}{{{b{{K`{c}}}}{b{{K`{c}}}}}Db{LlAd}}{{{b{{Ml{c}}}}{b{{Ml{c}}}}}Db{LlAd}}{{{b{{Kd{c}}}}{b{{Kd{c}}}}}Db{LlAd}}{{{b{{Kf{c}}}}{b{{Kf{c}}}}}Db{LlAd}}{{{b{{Kh{c}}}}{b{{Kh{c}}}}}Db{LlAd}}{{{b{{Mn{c}}}}{b{{Mn{c}}}}}Db{LlAd}}{{{b{{N`{c}}}}{b{{N`{c}}}}}Db{LlAd}}{{b{b{c}}}Db{}}00000000000000000000000000000000000`{{{Kj{c}}}{{Cn{eEj}}}{{B`{An}}}{}}{{{Kl{c}}}{{Cn{eEj}}}{{B`{An}}}{}}{{{Kn{c}}}{{Cn{eEj}}}{{B`{An}}}{}}{{{L`{ce}}}{{Cn{gEj}}}{{B`{Cd}}}{{B`{Cd}}}{}}{{{Lb{ce}}}{{Cn{gEj}}}{{B`{An}}}{{B`{Bb}}}{}}`{{{b{{Mh{c}}}}{b{AfEb}}}EhAd}0{{{b{{Mj{c}}}}{b{AfEb}}}EhAd}0{{{b{{K`{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{Jn{c}}}}{b{AfEb}}}EhAd}{{{b{{Jn{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{Ml{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{Kd{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{Kf{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{Kh{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{Mn{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{N`{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{Nb}}{b{AfEb}}}Eh}{{{b{{Kj{c}}}}{b{AfEb}}}EhEf}{{{b{{Kl{c}}}}{b{AfEb}}}EhEf}{{{b{{Kn{c}}}}{b{AfEb}}}EhEf}{{{b{{L`{ce}}}}{b{AfEb}}}EhEfEf}{{{b{{Lb{ce}}}}{b{AfEb}}}EhEfEf}{{{b{Ej}}{b{AfEb}}}Eh}0{cc{}}00{Ch{{Mh{c}}}Ad}{{{A@`{c}}}{{Mh{c}}}Ad}{{{Kb{c}}}{{Mj{c}}}Ad}3{Ch{{Mj{c}}}Ad}4444{{{Ml{c}}}{{Kd{c}}}Ad}555{{{Ml{c}}}{{Mn{c}}}Ad}66666666{A@bEj}{{{En{AnBb}}}Ej}{b{{A@d{{K`{c}}}}}Ad}{b{{A@d{{Ml{c}}}}}Ad}{b{{A@d{{Kd{c}}}}}Ad}{b{{A@d{{Kf{c}}}}}Ad}{{bb}{{K`{c}}}Ad}{{bb}{{Ml{c}}}Ad}{{bb}{{Kd{c}}}Ad}{{bb}{{Kf{c}}}Ad}{{{b{{Il{}{{A@f{c}}{A@h{g}}{A@j{i}}{A@l{k}}}}}}m}{{Ib{{I`{Hn}}}}}{{A@n{}{{Md{{Nh{{K`{e}}}}}}}}AA`H`}Ad{{A@n{}{{Md{{Nh{{Ml{e}}}}}}}}AA`H`}{{A@n{}{{Md{{Nh{{Kd{e}}}}}}}}AA`H`}{{A@n{}{{Md{{Nh{{Kf{e}}}}}}}}AA`H`}{{B`{{Mj{e}}}}H`Hb}}{{{b{{Il{}{{A@f{c}}{A@h{g}}{A@j{i}}{A@l{k}}}}}}m}{{Ib{{I`{Hn}}}}}{{A@n{}{{Md{{Nh{{K`{e}}}}}}}}AA`H`}Ad{{A@n{}{{Md{{Nh{{Ml{e}}}}}}}}AA`H`}{{A@n{}{{Md{{Nh{{Kd{e}}}}}}}}AA`H`}{{A@n{}{{Md{{Nh{{Kf{e}}}}}}}}AA`H`}{{AAb{Ch}}H`}}{{{b{c}}{b{e}}}Cd{GdGf}Gh}0{{{b{{Il{}{{A@f{c}}{A@h{g}}{A@j{i}}{A@l{k}}}}}}m}{{Ib{{I`{Hn}}}}}{{A@n{}{{Md{{Nh{{K`{e}}}}}}}}AA`H`}Ad{{A@n{}{{Md{{Nh{{Ml{e}}}}}}}}AA`H`}{{A@n{}{{Md{{Nh{{Kd{e}}}}}}}}AA`H`}{{A@n{}{{Md{{Nh{{Kf{e}}}}}}}}AA`H`}{{B`{{Mh{e}}}}H`Hb}}232{{{b{{Il{}{{A@f{c}}{A@h{g}}{A@j{i}}{A@l{k}}}}}}{AAd{e}}}{{Ib{{I`{Hn}}}}}{{A@n{}{{Md{{Nh{{K`{e}}}}}}}}AA`H`}Ad{{A@n{}{{Md{{Nh{{Ml{e}}}}}}}}AA`H`}{{A@n{}{{Md{{Nh{{Kd{e}}}}}}}}AA`H`}{{A@n{}{{Md{{Nh{{Kf{e}}}}}}}}AA`H`}}43{{{b{{Mh{c}}}}{b{Afe}}}fAdGj}{{{b{{Mj{c}}}}{b{Afe}}}fAdGj}{{{b{{K`{c}}}}}{{A@`{c}}}Ad}{{{b{{Ml{c}}}}}{{Kb{c}}}Ad}{{{b{{Kd{c}}}}}AAfAd}{{{b{{Kh{c}}}}}{{AAd{c}}}Ad}{{{b{{Mn{c}}}}}{{Kb{c}}}Ad}{c{{Gl{ce}}}{GnH`Hb}{}}0{{{b{{K`{c}}}}}{{b{{AAh{c}}}}}Ad}1{{{b{{Ml{c}}}}}{{b{{AAh{c}}}}}Ad}{{{b{{Mn{c}}}}}{{b{{AAh{c}}}}}Ad}3{{{b{{K`{c}}}}}CdAd}{{{b{{Ml{c}}}}}CdAd}{{{b{{Kd{c}}}}}CdAd}{{{b{{Kf{c}}}}}CdAd}{{{b{{Mn{c}}}}}CdAd}`{{}}0{{{b{{Kh{c}}}}}CdAd}`{{}Ch}000000000000000000{{{b{AfAAj}}{Ml{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{AfAAj}}{K`{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{AfAAj}}{Kf{c}}{n{AAl}}}{{Ib{{I`{Hn}}}}}Ad}{cEjGn}{{}c{}}000000000000000000{{Nbc}Ej{}}{{{Kj{c}}e}Ej{{B`{An}}}{}}{{{Kl{c}}e}Ej{{B`{An}}}{}}{{{Kn{c}}e}Ej{{B`{An}}}{}}{{{L`{ce}}g}Ej{{B`{Cd}}}{{B`{Cd}}}{}}{{{Lb{ce}}g}Ej{{B`{An}}}{{B`{Bb}}}{}}{{{Nh{c}}}eH`{}}{{{b{{Lj{}{{Ld{c}}{Lf{e}}{Lh{g}}}}}}{b{i}}}Db{BdEfLlLnM`JhMbH`Hb}{{Mf{}{{Md{c}}}}}{BdEfLlLnJhMbH`Hb}{}}0{{{b{{Ml{c}}}}}DbAd}{{{b{{Lj{}{{Ld{c}}{Lf{e}}{Lh{g}}}}}}{b{i}}}e{BdEfLlLnM`JhMbH`Hb}{{Mf{}{{Md{c}}}}}{BdEfLlLnJhMbH`Hb}{}}{{}{{Cn{HhHj}}}}000000000000000000{{{b{{K`{c}}}}}{{b{{Ab{c}}}}}Ad}`{{{b{{Lj{}{{Ld{c}}{Lf{e}}{Lh{g}}}}}}{b{i}}}Ch{BdEfLlLnM`JhMbH`Hb}{{Mf{}{{Md{c}}}}}{BdEfLlLnJhMbH`Hb}{}}{{{b{{Ml{c}}}}}ChAd}{{{Nh{c}}g}{{Nh{e}}}{}{}{H`{Ih{c}{{Id{e}}}}}}`{{{b{{Ml{c}}}}}{{b{{AAn{c}}}}}Ad}{{{Ab{c}}{AB`{c}}}{{Cn{{K`{c}}{Jn{c}}}}}Ad}{{{AAh{c}}{Ob{c}}}{{Ml{c}}}Ad}{{{AAh{c}}Nf}{{Kf{c}}}Ad}{{{b{{Lj{}{{Ld{c}}{Lf{e}}{Lh{g}}}}}}{b{i}}Ch}{{n{c}}}{BdEfLlLnM`JhMbH`Hb}{{Mf{}{{Md{c}}}}}{BdEfLlLnJhMbH`Hb}{}}0{{{b{{Lj{}{{Ld{c}}{Lf{e}}{Lh{g}}}}}}{b{i}}Ch}{{n{k}}}{BdEfLlLnM`JhMbH`Hb}{{Mf{}{{Md{c}}}}}{BdEfLlLnJhMbH`Hb}{}{}}0{{{b{{Lj{}{{Ld{c}}{Lf{e}}{Lh{g}}}}}}{b{i}}Ch}{{n{{En{kg}}}}}{BdEfLlLnM`JhMbH`Hb}{{Mf{}{{Md{c}}}}}{BdEfLlLnJhMbH`Hb}{}{}}0{{{b{{Ml{c}}}}}CdAd}{{{b{{Mn{c}}}}}CdAd}{{{b{{Mh{c}}}}{b{{Mh{c}}}}}{{n{Nd}}}Ad}{{{b{{Mj{c}}}}{b{{Mj{c}}}}}{{n{Nd}}}Ad}{{{b{{Ml{c}}}}}{{b{{Ob{c}}}}}Ad}{{{b{{K`{c}}}}}AAfAd}{{{b{{Ml{c}}}}}AAfAd}{{{b{{Kf{c}}}}}AAfAd}{b}000000000000000000{{{b{{Lj{}{{Ld{c}}{Lf{e}}{Lh{g}}}}}}{b{i}}{b{c}}}{{n{g}}}{BdEfLlLnM`JhMbH`Hb}{{Mf{}{{Md{c}}}}}{BdEfLlLnJhMbH`Hb}{}}0{{{b{{Kh{c}}}}}{{b{{ABb{c}}}}}Ad}{{{b{{K`{c}}}}}{{b{{AB`{c}}}}}Ad}`{{{Nh{c}}}cH`}```{{{b{{K`{c}}}}e}CnAdJj}{{{b{{Ml{c}}}}e}CnAdJj}{{{b{{Kd{c}}}}e}CnAdJj}{{{b{{Kf{c}}}}e}CnAdJj}{{{b{{Kh{c}}}}e}CnAdJj}{{{b{{Mn{c}}}}e}CnAdJj}{{{b{{N`{c}}}}e}CnAdJj}{{{b{Ej}}c}CnJj}{{{b{{Ml{c}}}}}CdAd}{{{b{{Kd{c}}}}}CdAd}{{{b{{Mn{c}}}}}CdAd}{{{b{{Jn{c}}}}}{{n{{b{h}}}}}Ad}{{{b{Ej}}}{{n{{b{h}}}}}}{{{b{Ej}}}Bb}`{{{b{{Il{}{{A@f{c}}{A@h{g}}{A@j{i}}{A@l{k}}}}}}Ch}{{Ib{{I`{Hn}}}}}{{A@n{}{{Md{{Nh{{K`{e}}}}}}}}AA`H`}Ad{{A@n{}{{Md{{Nh{{Ml{e}}}}}}}}AA`H`}{{A@n{}{{Md{{Nh{{Kd{e}}}}}}}}AA`H`}{{A@n{}{{Md{{Nh{{Kf{e}}}}}}}}AA`H`}}0000000{{{b{ABd}}}Cd}{bc{}}0000000000000000{bAn}000{{{b{{Lj{}{{Ld{c}}{Lf{e}}{Lh{g}}}}}}{b{i}}{b{c}}}{{n{k}}}{BdEfLlLnM`JhMbH`Hb}{{Mf{}{{Md{c}}}}}{BdEfLlLnJhMbH`Hb}{}{}}0{{{b{{Ml{c}}}}{b{{Ol{c}}}}}{{n{{On{c}}}}}Ad}{{{b{{Kh{c}}}}}{{b{{On{c}}}}}Ad}{{{b{{Lj{}{{Ld{c}}{Lf{e}}{Lh{g}}}}}}{b{i}}{Bj{k}}}{{n{k}}}{BdEfLlLnM`JhMbH`Hb}{{Mf{}{{Md{c}}}}}{BdEfLlLnJhMbH`Hb}{}{}}0{{{b{{Ml{c}}}}{Bj{{On{c}}}}}{{n{{Ol{c}}}}}Ad}{{{b{{Lj{}{{Ld{c}}{Lf{e}}{Lh{g}}}}}}{b{i}}{Bj{k}}}{{n{{En{kg}}}}}{BdEfLlLnM`JhMbH`Hb}{{Mf{}{{Md{c}}}}}{BdEfLlLnJhMbH`Hb}{}{}}0{{{b{{Lj{}{{Ld{c}}{Lf{e}}{Lh{g}}}}}}{b{i}}{b{c}}}{{n{{En{kg}}}}}{BdEfLlLnM`JhMbH`Hb}{{Mf{}{{Md{c}}}}}{BdEfLlLnJhMbH`Hb}{}{}}{c{{Cn{e}}}{}{}}000000000000000000{{}{{Cn{c}}}{}}000000000000000000{{{Nh{c}}}{{Cn{c{Nh{c}}}}}{}}{bJl}000000000000000000{{}c{}}000000000000000000{{{Nh{c}}i}{{Cn{ce}}}{}{hNj}{{O`{e}{{Nl{Nn}}}}}{{Ih{}{{Id{g}}}}}}{{{Nh{c}}ABf}{{n{c}}}H`}```````````````````{{bd}f}0{{{b{Af{ABh{ce}}}}}{{b{Afe}}}{}{}}{{{b{{ABh{ce}}}}}{{b{e}}}{}{}}`{{{b{{ABh{eg}}}}}{{Ib{{I`{Hn}}}}}Ad{{In{c}}H`Hb}{H`Hb}}{{{b{{ABh{ce}}}}}{{Ib{{I`{Hn}}}}}{J`H`Hb}{H`Hb}}{{{b{ABj}}}{{Ib{{I`{Hn}}}}}}{b{{b{c}}}{}}0{{{b{Af}}}{{b{Afc}}}{}}0{{{b{{ABh{ce}}}}}{{ABh{ce}}}BdBd}{{{b{ABj}}}ABj}{{b{b{Afc}}}f{}}0{bf}0{ABl{{`{{Hn{}{{Id{{ABn{f}}}}}}H`}}}}{{{b{c}}}{{Ib{{I`{Hn}}}}}{}}0:{Ch{{Ib{{I`{Hn}}}}}}0{{}ABj}{Ch{{b{c}}}{}}0{Ch{{b{Afc}}}{}}0{{b{b{Afc}}}{{Cn{{Cl{eg}}}}}{}{}{}}0{Chf}0`{{{b{{ABh{ce}}}}{b{AfEb}}}EhEfEf}{{{b{ABj}}{b{AfEb}}}Eh}{cc{}}0`{{{b{{ABh{eg}}}}i}{{Ib{{I`{Hn}}}}}Ad{{Il{c}}H`Hb}{H`Hb}{{B`{{Mj{c}}}}H`Hb}}{{{b{{ABh{eg}}}}{AC`{c}}}{{Ib{{I`{Hn}}}}}Ad{{ACb{c}}Hb}{H`Hb}}{{{b{{ABh{eg}}}}i}{{Ib{{I`{Hn}}}}}Ad{{Il{c}}H`Hb}{H`Hb}{{AAb{Ch}}H`}}{{{b{{ABh{eg}}}}{ACd{c}}}{{Ib{{I`{Hn}}}}}Ad{{ACb{c}}Hb}{H`Hb}}{{{b{{ABh{eg}}}}}{{Ib{{I`{Hn}}}}}Ad{{ACb{c}}Hb}{H`Hb}}{{{b{{ABh{eg}}}}iCd}{{Ib{{I`{Hn}}}}}Ad{{In{c}}H`Hb}{H`Hb}{{B`{{ACf{c}}}}H`Hb}}{{{b{{ABh{ce}}}}}{{Ib{{I`{Hn}}}}}{AChHb}{H`Hb}}{{{b{{ABh{eg}}}}i}{{Ib{{I`{Hn}}}}}Ad{{Il{c}}H`Hb}{H`Hb}{{B`{{Mh{c}}}}H`Hb}}5{{{b{{ABh{gi}}}}{ACj{ce}}}{{Ib{{I`{Hn}}}}}Ad{{ACl{c}}}{{ACn{ce}}Hb}{H`Hb}}86{{{b{{ABh{eg}}}}An}{{Ib{{I`{Hn}}}}}Ad{{ACb{c}}Hb}{H`Hb}}{{{b{{ABh{eg}}}}{AAd{c}}}{{Ib{{I`{Hn}}}}}Ad{{Il{c}}H`Hb}{H`Hb}}{{{b{{ABh{eg}}}}{AD`{c}}}{{Ib{{I`{Hn}}}}}Ad{{ACb{c}}Hb}{H`Hb}}{{{b{{ABh{eg}}}}{ADb{c}}}{{Ib{{I`{Hn}}}}}Ad{{ACb{c}}Hb}{H`Hb}}<:{{{b{{ABh{ce}}}}{b{{ADf{ADd}}}}}{{Ib{{I`{Hn}}}}}ADh{BdADjH`Hb}}{{{b{ABj}}{b{{ADf{ADd}}}}}{{Ib{{I`{Hn}}}}}}{{}Ch}0{{{b{{ABh{ce}}}}}{{b{c}}}{}{}}{{{b{Af{ABh{ce}}}}}{{b{Afc}}}{}{}}{{{b{Af{ABh{eg}}}}{Ml{c}}}{{Ib{{I`{Hn}}}}}Ad{{AAj{c}}H`Hb}{H`Hb}}{{{b{Af{ABh{eg}}}}{K`{c}}}{{Ib{{I`{Hn}}}}}Ad{{AAj{c}}H`Hb}{H`Hb}}{{{b{Af{ABh{gi}}}}ADl{ADn{Ch}}Cd}{{Ib{{I`{Hn}}}}}Ad{{ACl{c}}}{{AE`{ce}}H`Hb}{H`Hb}}{{{b{Af{ABh{eg}}}}{Kf{c}}{n{AAl}}}{{Ib{{I`{Hn}}}}}Ad{{AAj{c}}H`Hb}{H`Hb}}{{}c{}}0{{}{{Cn{HhHj}}}}0{{{b{{ABh{ce}}}}}{{b{AEb}}}AEd{}}{{{b{ABj}}}{{b{AEb}}}}{{ce}{{ABh{ce}}}{}{}}`{{{b{{ABh{eg}}}}}{{Ib{{I`{Hn}}}}}Ad{{In{c}}H`Hb}{H`Hb}}`{b}0{b{{I`{AEf}}}}0{{{b{{Jb{}{{AEh{c}}{AEj{e}}}}}}}{{`{{Hn{}{{Id{{ABn{e}}}}}}H`}}}ABlABl}{{{b{{ABh{ce}}}}}{{ABn{g}}}{JbH`}{H`Hb}{}}{{{b{c}}}{{Ib{{I`{Hn}}}}}{}}0{ABl{{`{HnH`}}}}{{{b{Af{ABh{gi}}}}Ch}{{Ib{{I`{Hn}}}}}Ad{{ACl{c}}}{{AE`{ce}}H`Hb}{H`Hb}}```7{bc{}}0{c{{Cn{e}}}{}{}}0{{}{{Cn{c}}}{}}0{bJl}0{{{b{AfAEl}}{b{{ADf{c}}}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{Af}}{b{{ADf{c}}}}}{{Ib{{I`{Hn}}}}}{}}{{{b{{ABh{eg}}}}i}{{Ib{{I`{Hn}}}}}Ad{{In{c}}H`Hb}{H`Hb}{{B`{{Mj{c}}}}H`Hb}}{{}c{}}0{{{b{{Jb{}{{AEh{c}}{AEj{e}}}}}}}{{`{{Hn{}{{Id{{ABn{c}}}}}}H`}}}ABlABl}<{{}f}0`````{{bd}f}0{{{b{Af{AEn{ce}}}}}{{b{Afe}}}Ad{}}{{{b{{AEn{ce}}}}}{{b{e}}}Ad{}}{{{b{{AF`{ceg}}}}}{{b{e}}}Ad{}{}}{{{b{Af{AEn{ce}}}}}{{Ib{{I`{Hn}}}}}Ad{{AFb{c}}H`}}{{{b{{AF`{ceg}}}}}{{Ib{{I`{Hn}}}}}AdJb{H`Hb}}{{{b{{AF`{ceg}}}}}{{Ib{{I`{Hn}}}}}Ad{JbAEdH`Hb}{H`Hb}}{b{{b{c}}}{}}000{{{b{Af}}}{{b{Afc}}}{}}000{{{AFd{ceg}}}{{ABn{{AF`{ceg}}}}}Ad{AFfJb}{{AFh{c}}}}{{cg}{{AFd{ecg}}}{JbAFf}Ad{{AFh{e}}}}{{{b{{AF`{ceg}}}}}{{AF`{ceg}}}Ad{}{}}{{{b{{AFj{ceg}}}}}{{AFj{ceg}}}Ad{}{}}{{b{b{Afc}}}f{}}0{bf}0{{{AEn{ce}}}{{ABn{f}}}AdABl}{{AFle}{{Cn{{AFn{ce}}Dn}}}Ad{{AFh{c}}}}<;{{{b{AG`}}e}{{ABn{{AF`{c{AGb{c}}e}}}}}Ad{{AFh{c}}}}{{{b{AfAGd}}e}{{ABn{{AF`{c{AGb{c}}e}}}}}Ad{{AFh{c}}}}{Ch{{b{c}}}{}}000{Ch{{b{Afc}}}{}}000{{b{b{Afc}}}{{Cn{{Cl{eg}}}}}{}{}{}}000{{{AFd{ceg}}}{{AFd{ceg}}}{}{}{}}{Chf}000{{{b{{AEn{ce}}}}{b{AfEb}}}Eh{AdEf}Ef}{{{b{{AF`{ceg}}}}{b{AfEb}}}EhAdEfEf}{{{b{{AFj{ceg}}}}{b{AfEb}}}EhAdEfEf}{cc{}}000{{{b{Af{AEn{ce}}}}{Mj{c}}}{{Ib{{I`{Hn}}}}}Ad{{AGf{c}}}}{{{b{{AF`{ceg}}}}i}{{Ib{{I`{Hn}}}}}AdJb{{AFh{c}}}{{B`{{Mj{c}}}}H`Hb}}{{{b{Af{AEn{ce}}}}{AC`{c}}}{{Ib{{I`{Hn}}}}}Ad{{AGh{c}}H`}}{{{b{{AF`{ceg}}}}{AC`{c}}}{{Ib{{I`{Hn}}}}}AdJb{H`Hb}}{{{b{Af{AEn{ce}}}}g}{{Ib{{I`{Hn}}}}}Ad{{AGf{c}}}{{AAb{Ch}}H`}}{{{b{{AF`{ceg}}}}i}{{Ib{{I`{Hn}}}}}AdJb{{AFh{c}}}{{AAb{Ch}}H`}}{{{b{Af{AEn{ce}}}}{ACd{c}}}{{Ib{{I`{Hn}}}}}Ad{{AGh{c}}H`}}{{{b{{AF`{ceg}}}}{ACd{c}}}{{Ib{{I`{Hn}}}}}AdJb{H`Hb}}{{{b{Af{AEn{ce}}}}}{{Ib{{I`{Hn}}}}}Ad{{AGh{c}}H`}}{{{b{{AF`{ceg}}}}}{{Ib{{I`{Hn}}}}}AdJb{H`Hb}}9{{{b{Af{AEn{ce}}}}gCd}{{Ib{{I`{Hn}}}}}Ad{{AFb{c}}H`}{{B`{{ACf{c}}}}H`Hb}}{{{b{{AF`{ceg}}}}iCd}{{Ib{{I`{Hn}}}}}AdJb{H`Hb}{{B`{{ACf{c}}}}H`Hb}}{{{b{Af{AEn{ce}}}}}{{Ib{{I`{Hn}}}}}Ad{AGjH`}}3{{{b{Af{AEn{ce}}}}{Mh{c}}}{{Ib{{I`{Hn}}}}}Ad{{AGf{c}}}}{{{b{{AF`{ceg}}}}i}{{Ib{{I`{Hn}}}}}AdJb{{AFh{c}}}{{B`{{Mh{c}}}}H`Hb}}:9{{{b{Af{AEn{cg}}}}{ACj{ce}}}{{Ib{{I`{Hn}}}}}Ad{{ACl{c}}}{{AGl{ce}}H`}}{{{b{{AF`{ceg}}}}{ACj{ci}}}{{Ib{{I`{Hn}}}}}AdJb{H`Hb}{{ACl{c}}}}{{{b{Af{AEn{ce}}}}{Mj{c}}}{{Ib{{I`{Hn}}}}}Ad{{AGf{c}}}}{{{b{{AF`{ceg}}}}i}{{Ib{{I`{Hn}}}}}AdJb{{AFh{c}}}{{B`{{Mj{c}}}}H`Hb}}>={{{b{Af{AEn{ce}}}}An}{{Ib{{I`{Hn}}}}}Ad{{AGh{c}}H`}}{{{b{{AF`{ceg}}}}An}{{Ib{{I`{Hn}}}}}AdJb{H`Hb}}{{{b{Af{AEn{ce}}}}{AAd{c}}}{{Ib{{I`{Hn}}}}}Ad{{AGf{c}}}}{{{b{{AF`{ceg}}}}{AAd{c}}}{{Ib{{I`{Hn}}}}}AdJb{{AFh{c}}}}{{{b{Af{AEn{ce}}}}{AD`{c}}}{{Ib{{I`{Hn}}}}}Ad{{AGh{c}}H`}}{{{b{{AF`{ceg}}}}{AD`{c}}}{{Ib{{I`{Hn}}}}}AdJb{H`Hb}}{{{b{Af{AEn{ce}}}}{ADb{c}}}{{Ib{{I`{Hn}}}}}Ad{{AGh{c}}H`}}{{{b{{AF`{ceg}}}}{ADb{c}}}{{Ib{{I`{Hn}}}}}AdJb{H`Hb}}98{{{b{Af{AEn{ce}}}}g}{{Ib{{I`{Hn}}}}}Ad{{AGf{c}}}{{AAb{Ch}}H`}}{{{b{{AF`{ceg}}}}i}{{Ib{{I`{Hn}}}}}AdJb{{AFh{c}}}{{AAb{Ch}}H`}}{{}Ch}000{{{b{Af{AEn{ce}}}}{Ml{c}}}{{Ib{{I`{Hn}}}}}Ad{{AAj{c}}H`Hb}}{{{b{Af{AEn{ce}}}}{K`{c}}}{{Ib{{I`{Hn}}}}}Ad{{AAj{c}}H`Hb}}{{{b{Af{AEn{cg}}}}ADl{ADn{Ch}}Cd}{{Ib{{I`{Hn}}}}}Ad{{ACl{c}}}{{AE`{ce}}H`Hb}}{{{b{Af{AEn{ce}}}}{Kf{c}}{n{AAl}}}{{Ib{{I`{Hn}}}}}Ad{{AAj{c}}H`Hb}}{{}c{}}000{{}{{Cn{HhHj}}}}000{{{b{Af{AEn{ce}}}}}{{Ib{{I`{Hn}}}}}Ad{AGnH`}}{{{b{{AF`{ceg}}}}}{{b{AEb}}}AdAEd{}}{{ce}{{AFd{gce}}}{}{}{}}{{{b{AG`}}e}{{ABn{{AF`{c{AGb{c}}e}}}}}Ad{{AFh{c}}}}{{{b{AfAGd}}e}{{ABn{{AF`{c{AGb{c}}e}}}}}Ad{{AFh{c}}}}{{{b{Af{AEn{ce}}}}}{{Ib{{I`{Hn}}}}}Ad{{AFb{c}}H`}}{{{b{{AF`{ceg}}}}}{{Ib{{I`{Hn}}}}}AdJb{H`Hb}}{b}000{b{{I`{AEf}}}}{{{b{{AF`{ceg}}}}}{{ABn{i}}}Ad{JbH`Hb}{H`Hb}{}}{{{AEn{ce}}}{{`{HnH`}}}AdABl}{{{b{Af{AEn{cg}}}}Ch}{{Ib{{I`{Hn}}}}}Ad{{ACl{c}}}{{AE`{ce}}H`Hb}}{{{b{{AF`{c{AGb{c}}e}}}}}{{ABn{f}}}Ad{{AFh{c}}}}76{bc{}}0{c{{Cn{e}}}{}{}}000{{}{{Cn{c}}}{}}000{bJl}000{{{b{Af}}{b{{ADf{c}}}}}{{Ib{{I`{Hn}}}}}{}}{{{b{Af{AEn{ce}}}}g}{{Ib{{I`{Hn}}}}}Ad{{AFb{c}}H`}{{B`{{Mj{c}}}}H`Hb}}{{{b{{AF`{ceg}}}}i}{{Ib{{I`{Hn}}}}}AdJb{H`Hb}{{B`{{Mj{c}}}}H`Hb}}{{}c{}}000{{{AFd{ceg}}ABf}{{AFd{ceg}}}{}{}{}}0{{{AFd{ceg}}Ch}{{AFd{ceg}}}{}{}{}}010001=``{{{b{c}}}{{Ib{{I`{Hn}}}}}{}}{Ch{{Ib{{I`{Hn}}}}}}{{{b{AG`}}e}{{ABn{{AH`{ce}}}}}Ad{{AFh{c}}}}{{{b{AfAGd}}e}{{ABn{{AH`{ce}}}}}Ad{{AFh{c}}}}{{{b{{AH`{ADdc}}}}{b{{ADf{ADd}}}}}{{Ib{{I`{Hn}}}}}{{AFh{ADd}}ADj}}214{{{b{{AH`{ce}}}}}{{ABn{f}}}Ad{{AFh{c}}}}{{}f}00000000```````{{AFle}{{Cn{{AFn{ce}}Dn}}}Ad{{AFh{c}}}}{{AFle}{{Cn{{AHb{ce}}Dn}}}Ad{{AFh{c}}}}187{{{b{{AHb{ADdc}}}}{b{{ADf{ADd}}}}}{{Ib{{I`{Hn}}}}}{{AFh{ADd}}ADj}}`9``3````````{{{b{AfAFb}}}{{Ib{{I`{Hn}}}}}}0`{{{b{AfAGf}}{Mj{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{AfAGh}}{AC`{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{AfAGf}}c}{{Ib{{I`{Hn}}}}}{{AAb{Ch}}H`}}{{{b{AfAGh}}{ACd{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{AfAGh}}}{{Ib{{I`{Hn}}}}}}4{{{b{AfAFb}}eCd}{{Ib{{I`{Hn}}}}}Ad{{B`{{ACf{c}}}}H`Hb}}{{{b{AfAGj}}}{{Ib{{I`{Hn}}}}}}{{{b{AfAGf}}{Mh{c}}}{{Ib{{I`{Hn}}}}}Ad}5{{{b{AfAGl}}{ACj{ce}}}{{Ib{{I`{Hn}}}}}Ad{{ACl{c}}}}86{{{b{AfAGh}}An}{{Ib{{I`{Hn}}}}}}{{{b{AfAGf}}{AAd{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{AfAGh}}{AD`{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{AfAGh}}{ADb{c}}}{{Ib{{I`{Hn}}}}}Ad}<:`=``={{{b{AfAFb}}e}{{Ib{{I`{Hn}}}}}Ad{{B`{{Mj{c}}}}H`Hb}}````{{{b{Af{AHd{e}}}}}{{Ib{{I`{Hn}}}}}Ad{AHf{AHl{}{{AHh{{AHj{c}}}}}}H`}}{b{{b{c}}}{}}00{{{b{Af}}}{{b{Afc}}}{}}00{{{AHd{{AHn{{AHj{c}}}}}}}{{ABn{f}}}Ad}{{{AHd{{AI`{{AHj{c}}}}}}}{{ABn{f}}}Ad}4{{{b{AG`}}}{{Cn{{AGb{c}}AIb}}}Ad}{{{b{AfAGd}}}{{Cn{{AGb{c}}AIb}}}Ad}{Ch{{b{c}}}{}}00{Ch{{b{Afc}}}{}}00{{b{b{Afc}}}{{Cn{{Cl{eg}}}}}{}{}{}}00{Chf}0{{{b{Af{AHd{c}}}}}fAHf}1{{{b{{AHj{c}}}}{b{AfEb}}}EhAd}{{{b{{AGb{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{AHd{c}}}}{b{AfEb}}}Eh{EfAHf}}{cc{}}00{{{b{Af{AHd{e}}}}{Mj{c}}}{{Ib{{I`{Hn}}}}}Ad{AHf{AHl{}{{AHh{{AHj{c}}}}}}H`Hb}}{{{b{Af{AHd{e}}}}g}{{Ib{{I`{Hn}}}}}Ad{AHf{AHl{}{{AHh{{AHj{c}}}}}}H`Hb}{{AAb{Ch}}H`}}1{{{b{Af{AHd{e}}}}gCd}{{Ib{{I`{Hn}}}}}Ad{AHf{AHl{}{{AHh{{AHj{c}}}}}}H`}{{B`{{ACf{c}}}}H`Hb}}{{{b{Af{AHd{e}}}}{Mh{c}}}{{Ib{{I`{Hn}}}}}Ad{AHf{AHl{}{{AHh{{AHj{c}}}}}}H`Hb}}232{{{b{Af{AHd{e}}}}{AAd{c}}}{{Ib{{I`{Hn}}}}}Ad{AHf{AHl{}{{AHh{{AHj{c}}}}}}H`Hb}}43{{}Ch}00{{{b{Af{AHd{{AI`{{AHj{c}}}}}}}}{Ml{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{Af{AHd{{AI`{{AHj{c}}}}}}}}{K`{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{Af{AHd{{AI`{{AHj{c}}}}}}}}{Kf{c}}{n{AAl}}}{{Ib{{I`{Hn}}}}}Ad}{{}c{}}00{{}{{Cn{HhHj}}}}00{{{b{{AGb{c}}}}}{{b{AEb}}}Ad}{{{b{AG`}}}{{Cn{{AGb{c}}AIb}}}Ad}{{{b{AfAGd}}}{{Cn{{AGb{c}}AIb}}}Ad}{{{b{Af{AHd{e}}}}}{{Ib{{I`{Hn}}}}}Ad{AHf{AHl{}{{AHh{{AHj{c}}}}}}H`}}{b}00{{{b{{AGb{c}}}}}{{ABn{e}}}Ad{}}{{{b{AfAHf}}}f}{{{AHd{{AHn{{AHj{c}}}}}}}{{`{HnH`}}}Ad}{{{AHd{{AI`{{AHj{c}}}}}}}{{`{HnH`}}}Ad}{{{b{{AGb{c}}}}}{{Cn{fAIb}}}Ad}6{c{{Cn{e}}}{}{}}00{{}{{Cn{c}}}{}}00{bJl}00{{{b{Af}}{b{{ADf{c}}}}}{{Ib{{I`{Hn}}}}}{}}{{{b{Af{AHd{e}}}}g}{{Ib{{I`{Hn}}}}}Ad{AHf{AHl{}{{AHh{{AHj{c}}}}}}H`}{{B`{{Mj{c}}}}H`Hb}}{{}c{}}00:``{{bd}f}{{{b{AfAId}}}{{Ib{{I`{Hn}}}}}}{b{{b{c}}}{}}0{{{b{Af}}}{{b{Afc}}}{}}0{{{b{AIf}}}AIf}{{b{b{Afc}}}f{}}{bf}{AId{{ABn{f}}}}6{{}AIf}{Ch{{b{c}}}{}}0{Ch{{b{Afc}}}{}}0{{b{b{Afc}}}{{Cn{{Cl{eg}}}}}{}{}{}}0{Chf}0{{{b{AIf}}{b{AfEb}}}Eh}{cc{}}0{{{b{AfAId}}{Mj{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{AfAId}}c}{{Ib{{I`{Hn}}}}}{{AAb{Ch}}H`}}1{{{b{AfAId}}eCd}{{Ib{{I`{Hn}}}}}Ad{{B`{{ACf{c}}}}H`Hb}}{{{b{AfAId}}{Mh{c}}}{{Ib{{I`{Hn}}}}}Ad}232{{{b{AfAId}}{AAd{c}}}{{Ib{{I`{Hn}}}}}Ad}43{{}Ch}0{{{b{AfAId}}{Ml{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{AfAId}}{K`{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{AfAId}}{Kf{c}}{n{AAl}}}{{Ib{{I`{Hn}}}}}Ad}{{}c{}}0{{}{{Cn{HhHj}}}}0{{{b{AIf}}}{{b{AEb}}}}{{{b{AfAId}}}{{Ib{{I`{Hn}}}}}}{b}0{{{b{AIf}}}{{ABn{c}}}{}}{AId{{`{HnH`}}}}3`{bc{}}{c{{Cn{e}}}{}{}}0{{}{{Cn{c}}}{}}0{bJl}0{{{b{Af}}{b{{ADf{c}}}}}{{Ib{{I`{Hn}}}}}{}}{{{b{AfAId}}e}{{Ib{{I`{Hn}}}}}Ad{{B`{{Mj{c}}}}H`Hb}}<<7`````````{{bd}f}{{{b{Af{AIh{c}}}}}{{Ib{{I`{Hn}}}}}{{AFb{ADd}}H`}}{{{b{AIj}}}{{Ib{{I`{Hn}}}}}}0{b{{b{c}}}{}}00{{{b{Af}}}{{b{Afc}}}{}}00{{{b{AIj}}}AIj}{{b{b{Afc}}}f{}}{bf}{{{AIh{c}}}{{ABn{f}}}ABl}{{{b{c}}}{{Ib{{I`{Hn}}}}}{}}87{Ch{{Ib{{I`{Hn}}}}}}{Ch{{b{c}}}{}}00{Ch{{b{Afc}}}{}}00{{b{b{Afc}}}{{Cn{{Cl{eg}}}}}{}{}{}}00{Chf}00{{{b{AIj}}{b{AfEb}}}Eh}{cc{}}00{{{b{AIj}}c}{{Ib{{I`{Hn}}}}}{{B`{{Mj{ADd}}}}H`Hb}}{{{b{AIj}}c}{{Ib{{I`{Hn}}}}}{{AAb{Ch}}H`}}{{{b{Af{AIh{c}}}}eCd}{{Ib{{I`{Hn}}}}}{{AFb{ADd}}H`}{{B`{{ACf{ADd}}}}H`Hb}}{{{b{AIj}}cCd}{{Ib{{I`{Hn}}}}}{{B`{{ACf{ADd}}}}H`Hb}}{{{b{AIj}}c}{{Ib{{I`{Hn}}}}}{{B`{{Mh{ADd}}}}H`Hb}}343{{{b{AIj}}{AAd{ADd}}}{{Ib{{I`{Hn}}}}}}54{{{b{AIj}}{b{{ADf{ADd}}}}}{{Ib{{I`{Hn}}}}}}{{}Ch}00{{{b{Af{AIh{c}}}}{Ml{ADd}}}{{Ib{{I`{Hn}}}}}{{AAj{ADd}}H`Hb}}{{{b{Af{AIh{c}}}}{K`{ADd}}}{{Ib{{I`{Hn}}}}}{{AAj{ADd}}H`Hb}}{{{b{Af{AIh{c}}}}{Kf{ADd}}{n{AAl}}}{{Ib{{I`{Hn}}}}}{{AAj{ADd}}H`Hb}}{{}c{}}00{{}{{Cn{HhHj}}}}00{{{b{AIj}}}{{b{AEb}}}}{{{b{Af{AIh{c}}}}}{{Ib{{I`{Hn}}}}}{{AFb{ADd}}H`}}{{{b{AIj}}}{{Ib{{I`{Hn}}}}}}{b}00{b{{I`{AEf}}}}{{{b{AIj}}}{{ABn{c}}}{}}{{{b{c}}}{{Ib{{I`{Hn}}}}}{}}{{{AIh{c}}}{{`{HnH`}}}ABl}{{{b{Af{AIl{AIj}}}}}{{Ib{{I`{Hn}}}}}}76{bc{}}{c{{Cn{e}}}{}{}}00{{}{{Cn{c}}}{}}00{bJl}00{{{b{Af}}{b{{ADf{c}}}}}{{Ib{{I`{Hn}}}}}{}}{{{b{Af{AIh{c}}}}e}{{Ib{{I`{Hn}}}}}{{AFb{ADd}}H`}{{B`{{Mj{ADd}}}}H`Hb}}{{{b{AIj}}c}{{Ib{{I`{Hn}}}}}{{B`{{Mj{ADd}}}}H`Hb}}{{}c{}}00;``````{{bd}f}{{{b{AIn}}}Cd}{b{{b{c}}}{}}{{{b{Af}}}{{b{Afc}}}{}}{{{b{AIn}}}AIn}{{b{b{Afc}}}f{}}{bf}{{}AIn}{Ch{{b{c}}}{}}{Ch{{b{Afc}}}{}}{{b{b{Afc}}}{{Cn{{Cl{eg}}}}}{}{}{}}{Chf}{{{b{AIn}}{b{AfEb}}}Eh}{cc{}}{{{b{{AFf{}{{AJ`{c}}}}}}}{{Ib{{I`{Hn}}}}}{ADjH`}}{{{b{AJb}}}{{n{AIn}}}}{{}Ch}{{{b{AIn}}}ABf}{{}c{}}{{}{{Cn{HhHj}}}}{{{b{AfAGn}}}{{Ib{{I`{Hn}}}}}}{{{b{AIn}}}AJd}4>{b}{{{b{{AFf{}{{AJ`{c}}}}}}{b{Afc}}}{{Ib{{I`{Hn}}}}}{ADjH`}}{{{b{AIn}}}{{n{Cd}}}}{{{b{AfAJb}}AIn}f}8{bc{}}{c{{Cn{e}}}{}{}}{{}{{Cn{c}}}{}}{bJl}{{{b{AIn}}}{{ABn{f}}}}<{{AInCd}AIn}{{AInABf}AIn}{{AInAJd}AIn}121`````````````````````````````````{{bd}f}000{{AJfAnAJhCd}AJj}{{{b{AJj}}}{{n{{b{AJh}}}}}}{{{AJl{c}}}{{AJl{c}}}AJn}{{{b{Dn}}}{{b{h}}}}0{{{b{Dn}}}{{b{l}}}}{{{b{Af}}}{{`{{Hn{}{{Id{{ABn{f}}}}}}H`}}}}{{{b{Af}}}{{ABn{f}}}}0{{AK`AKb}AKb}{{{b{AfAKd}}c}{{AKf{An}}}{{AKj{AKh}}{AKl{AKh}}}}{{{b{Af{AKn{c}}}}}{{Ib{{I`{Hn}}}}}AL`}{b{{b{c}}}{}}0000000000{{{b{Af}}}{{b{Afc}}}{}}0000000000{{{b{AfAKd}}c{b{Cj}}}{{AKf{An}}}{{AAb{Ch}}}}{{{AJl{ALb}}e}{{Cn{{AFn{ce}}Dn}}}Ad{{AFh{c}}}}{{{b{Dn}}}ALd}{{{b{AJj}}}Cd}{{{b{Cj}}}{{Ib{{I`{Hn}}}}}}0{{}{{Ib{{I`{Hn}}}}}}0{{{b{AJj}}}AJj}{{{b{ALf}}}ALf}{{{b{ALh}}}ALh}{{{b{{AJl{c}}}}}{{AJl{c}}}{AJnBd}}{{b{b{Afc}}}f{}}000{bf}000{{{b{AJj}}{b{AJj}}}Nd}{{{AKn{c}}}{{ABn{f}}}AL`}{{b{b{c}}}Nd{}}{{{AJl{ALb}}e}{{Cn{{AHb{ce}}Dn}}}Ad{{AFh{c}}}}{{{AJl{c}}}{{Cn{ALjDn}}}AJn}{{{AJl{c}}ABf}{{AJl{c}}}AJn}{{Dnc}Dn{GnH`Hb}}{{{b{Af{AKn{c}}}}}{{Ib{{I`{Hn}}}}}AL`}??{{{AJl{ALb}}{b{Cj}}}{{AJl{ALb}}}}{{{b{Cj}}}{{Ib{{I`{Hn}}}}}}0{{}AKd}{{}ALf}{{}ALh}{{}{{AJl{ALb}}}}{{}ALl}{{}{{ADn{AJj}}}}{Ch{{b{c}}}{}}{{{b{Dn}}}b}111111{{{b{{AKn{c}}}}}{{b{e}}}{}{}}2222{Ch{{b{Afc}}}{}}{{{b{AfDn}}}{{b{Af}}}}1111111{{{b{Af{AKn{c}}}}}{{b{Afe}}}{}{}}222{{b{b{Afc}}}{{Cn{{Cl{eg}}}}}{}{}{}}0000000000{{}{{b{Cj}}}}00{Dn{{Cn{cDn}}}{GnEfH`Hb}}{{{b{AfDn}}}{{n{{b{Afc}}}}}{GnEfH`Hb}}{{{b{Dn}}}{{n{{b{c}}}}}{GnEfH`Hb}}{{{b{AfDn}}}f}{Chf}0000000000{{{b{Cj}}}{{Ib{{I`{Hn}}}}}}0{{{b{AJj}}{b{AJj}}}Db}{{b{b{c}}}Db{}}000{{{AM`{}{{ALn{c}}}}e}{{Ib{{I`{Hn}}}}}AJn{{AMb{c}}}}0{{{AM`{}{{ALn{c}}}}e}{{Ib{{I`{A@n}}}}}AJn{{AMb{c}}}}0{{{b{Af{AKn{ALf}}}}c}{{ABn{Cd}}}{{AMb{AKh}}}}{{{b{Af{AKn{ALf}}}}{b{Cj}}c}{{ABn{Cd}}}{AK`Bd}}{{{b{Af{AKn{ALf}}}}c}{{ABn{f}}}{{AMb{AKh}}}}{{{b{Af{AKn{ALf}}}}{b{Cj}}c}{{ABn{f}}}{AK`Bd}}44554555{{{b{Dn}}{b{AfEb}}}{{Cn{fEd}}}}0{{{b{AJj}}{b{AfEb}}}{{Cn{fEd}}}}0{{{b{AMd}}{b{AfEb}}}{{Cn{fEd}}}}{{{b{ALb}}{b{AfEb}}}{{Cn{fEd}}}}{{{b{AKd}}{b{AfEb}}}Eh}{{{b{ALf}}{b{AfEb}}}Eh}{{{b{ALh}}{b{AfEb}}}Eh}{{{b{{AKn{c}}}}{b{AfEb}}}EhEf}{{{b{{AJl{c}}}}{b{AfEb}}}Eh{AJnEf}}{{{b{ALj}}{b{AfEb}}}Eh}{{{b{ALl}}{b{AfEb}}}Eh}{b{{AMf{AMd}}}}{b{{AMf{ALb}}}}{{{b{Cj}}}{{Ib{{I`{Hn}}}}}}{cc{}}{Fjc{}}{cDn{hH`Hb}}22222222{AMh{{AJl{ALb}}}}33{{{b{Cj}}}{{Cn{{AJl{ALb}}c}}}{}}{{{b{Af{AKn{c}}}}{Mj{e}}}{{Ib{{I`{Hn}}}}}AL`Ad}{{{b{Af{AKn{c}}}}{AC`{e}}}{{Ib{{I`{Hn}}}}}AL`Ad}{{{b{Af{AKn{c}}}}e}{{Ib{{I`{Hn}}}}}AL`{{AAb{Ch}}H`}}{{{b{Af{AKn{c}}}}{ACd{e}}}{{Ib{{I`{Hn}}}}}AL`Ad}{{{b{ALj}}}{{Ib{{I`{Hn}}}}}}{{{b{Af{AKn{c}}}}}{{Ib{{I`{Hn}}}}}AL`}{b{{n{{b{Cj}}}}}}06{{{b{Af{AKn{c}}}}gCd}{{Ib{{I`{Hn}}}}}AL`Ad{{B`{{ACf{e}}}}H`Hb}}2{{{b{Af{AKn{c}}}}{Mh{e}}}{{Ib{{I`{Hn}}}}}AL`Ad}6{{{b{Af{AKn{c}}}}{ACj{eg}}}{{Ib{{I`{Hn}}}}}AL`Ad{{ACl{e}}}}97{{{b{ALj}}}{{n{AIn}}}}{{{b{Af{AKn{c}}}}An}{{Ib{{I`{Hn}}}}}AL`}{{{b{Af{AKn{c}}}}{AAd{e}}}{{Ib{{I`{Hn}}}}}AL`Ad}{{{b{Af{AKn{c}}}}{AD`{e}}}{{Ib{{I`{Hn}}}}}AL`Ad}{{{b{Af{AKn{c}}}}{ADb{e}}}{{Ib{{I`{Hn}}}}}AL`Ad}><{c{{Gl{ce}}}{GnH`Hb}{}}0{{{b{AfAKd}}{Mj{c}}}{{AKf{An}}}Ad}{{{AJl{ALb}}c}{{AJl{ALb}}}{{B`{An}}}}{{{AJl{c}}ABf}{{AJl{c}}}AJn}``{{}Ch}0000000000{{{b{Af{AKn{ALf}}}}{Ml{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{Af{AKn{ALf}}}}{K`{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{Af{AKn{ALf}}}}ADl{ADn{Ch}}Cd}{{Ib{{I`{Hn}}}}}}{{{b{Af{AKn{ALf}}}}{Kf{c}}{n{AAl}}}{{Ib{{I`{Hn}}}}}Ad}{{}c{}}0000000000{{{b{Dn}}}Db}{{}{{Cn{HhHj}}}}0000000000{{{b{Af{AKn{c}}}}g}{{AKf{{AAh{e}}}}}{}Ad{{B`{{Mj{e}}}}H`}}{{{b{Af{AKn{c}}}}}{{Ib{{I`{Hn}}}}}AL`}{{{AJl{c}}AMj}{{AJl{c}}}AJn}{{{b{ALj}}}{{b{AEb}}}}{{{AJl{c}}e}{{AJl{c}}}AJn{{AMl{}{{Md{AJj}}}}}}2{cDn{GnEfH`Hb}}{{{b{AJj}}}{{b{Cj}}}}{cDn{hH`Hb}}{{{AJl{c}}}{{AJl{c}}}AJn}{b{{n{{b{Cj}}}}}}0{{{b{AJj}}{b{AJj}}}{{n{Nd}}}}{{{AJl{ALb}}{b{Cj}}}{{AJl{ALb}}}}:{b}0000000000{{{AJl{ALb}}AJd}{{AJl{ALb}}}}{{{b{AJj}}}{{b{AMn}}}}{{{AM`{}{{ALn{c}}}}{b{Cj}}}{{Ib{{I`{Hn}}}}}AJn}0{{{AM`{}{{ALn{c}}}}{b{Cj}}{b{AN`}}}{{Ib{{I`{Hn}}}}}AJn}{{{b{ALj}}{b{AfALl}}}{{Ib{{I`{Hn}}}}}}{{{AJl{c}}AIn}{{Cn{{AJl{c}}Dn}}}AJn}{{{b{Cj}}}AKb}{{AKd{b{Cj}}}AKb}{{{b{Cj}}}{{ANb{c}}}ANd}{{AKd{b{Cj}}}{{ANb{c}}}ANd}{{{b{ALj}}}{{ABn{{AKn{ALh}}}}}}?>>{{{AKn{c}}}{{`{HnH`}}}AL`}{{{b{Dn}}}{{b{h}}}}{{{AJl{c}}e}{{AJl{c}}}AJn{{B`{An}}}}{{{b{AfAJj}}}f}{{{b{Af{AKn{ALf}}}}Ch}{{Ib{{I`{Hn}}}}}}{{{b{AfALj}}AIn}f}{{{b{Af}}}{{Ib{{I`{Hn}}}}}}0{{{b{AJj}}}{{n{{b{Cj}}}}}}`{{{b{Af{AKn{c}}}}}{{Ib{{I`{Hn}}}}}AL`}{{{b{ANf}}}{{Ib{{I`{Hn}}}}}}0`{{{AJl{ALb}}}{{AJl{ALb}}}}{bc{}}000{bAn}0{c{{Cn{e}}}{}{}}0000000000{{}{{Cn{c}}}{}}0000000000{bJl}0000000000{{{b{Cj}}{b{Cj}}}{{Cn{AJjANh}}}}{{{b{Af}}{b{{ADf{c}}}}}{{Ib{{I`{Hn}}}}}{}}{{{b{Af{AKn{ALf}}}}{b{Cj}}{ANj{{b{Cj}}}}ce}{{ABn{f}}}{{AMl{}{{Md{{b{Cj}}}}}}}AMl}{{{AJl{ALb}}{b{Cj}}}{{AJl{ALb}}}}{{{b{AJj}}}AMj}{{{b{Af{AKn{c}}}}g}{{Ib{{I`{Hn}}}}}AL`Ad{{B`{{Mj{e}}}}H`Hb}}{{}c{}}0000000000{{{b{ALj}}}{{ABn{{AKn{ALf}}}}}}``{b{{b{c}}}{}}0{{{b{Af}}}{{b{Afc}}}{}}0{{{b{ANl}}}{{AJl{ALb}}}}{Ch{{b{c}}}{}}0{Ch{{b{Afc}}}{}}0{{b{b{Afc}}}{{Cn{{Cl{eg}}}}}{}{}{}}0{Chf}0{{{b{AfANl}}}f}{{{b{ANl}}{b{AfEb}}}Eh}{cc{}}0{{{b{ANl}}}An}{{}Ch}{{}ANl}1>>{{}{{Cn{HhHj}}}}01{b}0{{{b{ANl}}}AJd}88{c{{Cn{e}}}{}{}}0{{}{{Cn{c}}}{}}0{bJl}0{{}c{}}0`````````````````````````````````````````````````````````````````````````````````````````````````````{{bd}f}000000000000000{{ANnANn}c{}}{b{{b{h}}}}00000000000000000000000``````````{b{{b{c}}}{}}0000000000000000000000000000000000{{{b{Af}}}{{b{Afc}}}{}}0000000000000000000000000000000000{AO`ANn}{{{b{AOb}}}AOb}{{{b{AOd}}}AOd}{{{b{AOf}}}AOf}{{{b{ANn}}}ANn}{{{b{{AC`{c}}}}}{{AC`{c}}}{BdAd}}{{{b{{AD`{c}}}}}{{AD`{c}}}{BdAd}}{{{b{{AOh{c}}}}}{{AOh{c}}}{BdAd}}{{{b{{AOj{c}}}}}{{AOj{c}}}{BdAd}}{{{b{AOl}}}AOl}{{{b{AOn}}}AOn}{{{b{B@`}}}B@`}{{{b{B@b}}}B@b}{{{b{B@d}}}B@d}{{{b{B@f}}}B@f}{{{b{B@h}}}B@h}{{{b{F`}}}F`}{{b{b{Afc}}}f{}}000000000000000{bf}000000000000000{{{b{AOf}}{b{AOf}}}Nd}{{b{b{c}}}Nd{}}````{{}{{ADb{c}}}Ad}{c{{Cn{{Of{eF`c}}Oh}}}Jf{H`HbOj}}{Ch{{b{c}}}{}}0000000000000000000000000000000000{Ch{{b{Afc}}}{}}0000000000000000000000000000000000{c{{Cn{AOb}}}D`}{{b{b{Afc}}}{{Cn{{Cl{eg}}}}}{}{}{}}0{c{{Cn{AOd}}}D`}1{c{{Cn{AOf}}}D`}{c{{Cn{ANn}}}D`}33333{c{{Cn{AOl}}}D`}4{c{{Cn{{B@j{e}}}}}D`Ad}55{c{{Cn{{B@l{e}}}}}D`Ad}66{c{{Cn{B@n}}}D`}7{c{{Cn{{BA`{e}}}}}D`Ad}8{c{{Cn{{BAb{e}}}}}D`Ad}99{c{{Cn{BAd}}}D`}:{c{{Cn{BAf}}}D`};;{c{{Cn{BAh}}}D`}<{c{{Cn{{BAj{e}}}}}D`Ad}={c{{Cn{{BAl{e}}}}}D`Ad}{c{{Cn{AOn}}}D`}?{c{{Cn{B@`}}}D`}{{b{b{Afc}}}{{Cn{{Cl{eg}}}}}{}{}{}}{c{{Cn{B@b}}}D`}1{c{{Cn{B@d}}}D`}22{c{{Cn{B@f}}}D`}{c{{Cn{B@h}}}D`}4{c{{Cn{F`}}}D`}55{c{{Cn{{BAn{e}}}}}D`Ad}6{c{{Cn{{BB`{e}}}}}D`Ad}7{c{{Cn{{BBb{e}}}}}D`Ad}8{c{{Cn{{BBd{e}}}}}D`Ad}{c{{Cn{{BBf{e}}}}}D`Ad}:{c{{Cn{{BBh{e}}}}}D`Ad};{Chf}0000000000000000000000000000000000{{{b{AOf}}{b{AOf}}}Db}{{{b{ANn}}{b{ANn}}}Db}{{{b{{AC`{c}}}}{b{{AC`{c}}}}}Db{LlAd}}{{{b{{AD`{c}}}}{b{{AD`{c}}}}}Db{LlAd}}{{{b{{AOh{c}}}}{b{{AOh{c}}}}}Db{LlAd}}{{{b{{AOj{c}}}}{b{{AOj{c}}}}}Db{LlAd}}{{{b{AOl}}{b{AOl}}}Db}{{{b{{B@j{c}}}}{b{{B@j{c}}}}}Db{LlAd}}{{{b{{B@l{c}}}}{b{{B@l{c}}}}}Db{LlAd}}{{{b{Ff}}{b{Ff}}}Db}{{{b{B@n}}{b{B@n}}}Db}{{{b{{BA`{c}}}}{b{{BA`{c}}}}}Db{LlAd}}{{{b{{BAb{c}}}}{b{{BAb{c}}}}}Db{LlAd}}{{{b{{ACd{c}}}}{b{{ACd{c}}}}}Db{LlAd}}{{b{b{c}}}Db{}}0000000000000000000000000000000000000000000000000000000{AO`ANn}0``{{{b{{BCb{}{{BBj{c}}{BBl{e}}{BBn{g}}{BC`{i}}}}}}}e{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}}{{{b{{BCb{}{{BBj{c}}{BBl{e}}{BBn{g}}{BC`{i}}}}}}}c{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}}```{{{b{AOb}}{b{AfEb}}}Eh}0{{{b{AOd}}{b{AfEb}}}Eh}0{{{b{AOf}}{b{AfEb}}}Eh}0{{{b{ANn}}{b{AfEb}}}Eh}0{{{b{{AC`{c}}}}{b{AfEb}}}EhAd}{{{b{{AC`{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{AD`{c}}}}{b{AfEb}}}EhAd}{{{b{{AD`{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{AOh{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{AOj{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{AOl}}{b{AfEb}}}Eh}{{{b{{B@j{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{B@l{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{Ff}}{b{AfEb}}}Eh}0{{{b{B@n}}{b{AfEb}}}Eh}{{{b{{BA`{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{BAb{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{ACd{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{BAd}}{b{AfEb}}}Eh}{{{b{{ADb{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{BAf}}{b{AfEb}}}Eh}{{{b{BAh}}{b{AfEb}}}Eh}{{{b{{BAj{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{BAl{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{AOn}}{b{AfEb}}}Eh}0{{{b{B@`}}{b{AfEb}}}Eh}0{{{b{B@b}}{b{AfEb}}}Eh}0{{{b{B@d}}{b{AfEb}}}Eh}0{{{b{B@f}}{b{AfEb}}}Eh}0{{{b{B@h}}{b{AfEb}}}Eh}0{{{b{F`}}{b{AfEb}}}Eh}0{{{b{{BAn{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{BB`{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{BBb{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{BBd{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{BBf{c}}}}{b{AfEb}}}Eh{EfAd}}{{{b{{BBh{c}}}}{b{AfEb}}}Eh{EfAd}}{cc{}}00{AO`ANn}11111111{BCdFf}{BCfFf}33333333333{A`AOn}{FhAOn}55{FhB@`}{A`B@`}7{A`B@b}{FfB@b}{FhB@b}{FhB@d};{A`B@d}<{B@dB@f}{FhB@f}{A`B@f}{AOnB@f}{B@`B@f}{FhB@h}{A`B@h}{cc{}}0{{{B@j{c}}}{{BAn{c}}}Ad}1{{{ADn{{B@l{c}}}}}{{BB`{c}}}Ad}22{{{ADn{{BAb{c}}}}}{{BBd{c}}}Ad}33{{{BAj{c}}}{{BBf{c}}}Ad}4{{{BAl{c}}}{{BBh{c}}}Ad}{b{{A@d{{B@j{c}}}}}Ad}{b{{A@d{{B@l{c}}}}}Ad}`{{{b{ACb}}{AC`{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{ACb}}{ACd{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{ACb}}}{{Ib{{I`{Hn}}}}}}{{{b{ACb}}An}{{Ib{{I`{Hn}}}}}}{{{b{ACb}}{AD`{c}}}{{Ib{{I`{Hn}}}}}Ad}{{{b{ACb}}{ADb{c}}}{{Ib{{I`{Hn}}}}}Ad}````{c{{Gl{ce}}}{GnH`Hb}{}}0000000000000`````{{}}0000000{{}Ch}0000000000000000000000000000000000{{}c{}}0000000000000000000000000000000000{{}{{BCh{An}}}}{{{b{AOf}}}Db}00```{{}{{Cn{HhHj}}}}0000000000000000000000000000000000{{{b{{BCj{}{{BC`{c}}}}}}}c{BdEfJhMbH`HbLlLn}}{{{b{{BCb{}{{BBj{c}}{BBl{e}}{BBn{g}}{BC`{i}}}}}}}{{ADn{i}}}{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}}{{AOfAO`}ANn}````````{{{b{AOf}}{b{AOf}}}{{n{Nd}}}}{b}0000000000000000000000000000000000{{{b{{BCb{}{{BBj{c}}{BBl{e}}{BBn{g}}{BC`{i}}}}}}}g{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}}```{{{b{{BCb{}{{BBj{c}}{BBl{e}}{BBn{g}}{BC`{i}}}}}}}c{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}{BdEfJhMbH`HbLlLn}}````{{{b{AOb}}c}CnJj}{{{b{AOd}}c}CnJj}{{{b{AOf}}c}CnJj}{{{b{ANn}}c}CnJj}{{{b{AOl}}c}CnJj}{{{b{{B@j{c}}}}e}CnAdJj}{{{b{{B@l{c}}}}e}CnAdJj}{{{b{B@n}}c}CnJj}{{{b{{BA`{c}}}}e}CnAdJj}{{{b{{BAb{c}}}}e}CnAdJj}{{{b{BAd}}c}CnJj}{{{b{BAf}}c}CnJj}{{{b{BAh}}c}CnJj}{{{b{{BAj{c}}}}e}CnAdJj}{{{b{{BAl{c}}}}e}CnAdJj}{{{b{AOn}}c}CnJj}{{{b{B@`}}c}CnJj}{{{b{B@b}}c}CnJj}{{{b{B@d}}c}CnJj}{{{b{B@f}}c}CnJj}{{{b{B@h}}c}CnJj}{{{b{F`}}c}CnJj}{{{b{{BAn{c}}}}e}CnAdJj}{{{b{{BB`{c}}}}e}CnAdJj}{{{b{{BBb{c}}}}e}CnAdJj}{{{b{{BBd{c}}}}e}CnAdJj}{{{b{{BBf{c}}}}e}CnAdJj}{{{b{{BBh{c}}}}e}CnAdJj}{{{b{AOf}}}Ch}```{{{b{Ff}}}{{n{{b{h}}}}}}{{{b{AOn}}}{{n{{b{h}}}}}}{{{b{B@`}}}{{n{{b{h}}}}}}{{{b{B@b}}}{{n{{b{h}}}}}}{{{b{B@d}}}{{n{{b{h}}}}}}{{{b{B@f}}}{{n{{b{h}}}}}}{{{b{B@h}}}{{n{{b{h}}}}}}{{{b{F`}}}{{n{{b{h}}}}}}{{{b{AOn}}}Bb}{{{b{B@`}}}Bb}{{{b{B@b}}}Bb}{{{b{B@d}}}Bb}{{{b{B@f}}}Bb}{{{b{B@h}}}Bb}{{{b{F`}}}Bb}{{ANnANn}c{}}```````{bc{}}000000000000000{bAn}0000000000000````{c{{Cn{e}}}{}{}}0{{{b{Cj}}}{{Cn{AOfc}}}{}}1111111{{{Ml{c}}}{{Cn{{B@j{c}}e}}}Ad{}}22{{{Ml{c}}}{{Cn{{B@l{c}}e}}}Ad{}}3333{{{En{{b{{Ml{c}}}}Ch}}}{{Cn{{BAb{c}}e}}}Ad{}}44444444444444444444{{}{{Cn{c}}}{}}0000000000000000000000000000000000{bJl}0000000000000000000000000000000000{AO`ANn}`{{}c{}}0000000000000000000000000000000000`````{{bd}f}{b{{b{c}}}{}}{{{b{Af}}}{{b{Afc}}}{}}{{{b{{BCl{ce}}}}}{{BCl{ce}}}{}{}}{{b{b{Afc}}}f{}}{bf}{{}{{BCl{ce}}}{}{}}{Ch{{b{c}}}{}}{Ch{{b{Afc}}}{}}{{b{b{Afc}}}{{Cn{{Cl{eg}}}}}{}{}{}}{Chf}{{{b{{BCl{ce}}}}{b{AfEb}}}Eh{}{}}{cc{}}{{}Ch}>{{}{{Cn{HhHj}}}}{b}``{{BCnc}f{}}{{BD`c}{{`{{Hn{}{{Id{f}}}}H`}}}{}}{{{b{{BCl{eg}}}}eik}f{}{{BDb{c}}}BD`{{BDd{ce}}}{{AMl{}{{Md{g}}}}H`}}{bc{}}{c{{Cn{e}}}{}{}}{{}{{Cn{c}}}{}}{bJl}{{}c{}}{{{BCl{ce}}{Dl{BDf}}}{{BCl{ce}}}{}{}}{{{BCl{ce}}ABf}{{BCl{ce}}}{}{}}`````{{bd}f}000{{{b{{BDh{c}}}}}f{}}{b{{b{c}}}{}}000{{{b{Af}}}{{b{Afc}}}{}}000{{{b{{BDj{c}}}}}{{BDj{c}}}Ad}{{{b{{BDl{c}}}}}{{BDl{c}}}{BdJf}}{{{b{{BDh{c}}}}}{{BDh{c}}}{}}{{{b{BDn}}}BDn}{{b{b{Afc}}}f{}}000{bf}000{{}{{BDj{c}}}Ad}{{}BDn}{Ch{{b{c}}}{}}000{Ch{{b{Afc}}}{}}000{{b{b{Afc}}}{{Cn{{Cl{eg}}}}}{}{}{}}000{Chf}000>{{{b{BDd}}e}{{Ib{{I`{Hn}}}}}{}{{BDb{c}}}}{{{b{{BDj{c}}}}BE`}{{Ib{{I`{Hn}}}}}Ad}{{{b{{BDj{c}}}}BEb}{{Ib{{I`{Hn}}}}}Ad}{{{b{{BDj{c}}}}BEd}{{Ib{{I`{Hn}}}}}Ad}{{{b{{BDl{c}}}}BE`}{{Ib{{I`{Hn}}}}}Jf}{{{b{{BDl{c}}}}BEd}{{Ib{{I`{Hn}}}}}Jf}{{{b{{BDl{c}}}}BEb}{{Ib{{I`{Hn}}}}}Jf}{{{b{{BDh{g}}}}e}{{Ib{{I`{Hn}}}}}Ad{{BDb{c}}}{{BDd{ce}}Hb}}{{{b{BDn}}e}{{Ib{{I`{Hn}}}}}{}{H`{BDb{c}}}}{{{b{{BDj{c}}}}{b{AfEb}}}EhAd}{{{b{{BDl{c}}}}{b{AfEb}}}Eh{EfJf}}{{{b{{BDh{c}}}}{b{AfEb}}}EhEf}{{{b{BDn}}{b{AfEb}}}Eh}{cc{}}000{{}Ch}000{{}c{}}000{{}{{Cn{HhHj}}}}000{{BEfc}{{BDl{c}}}Jf}{c{{BDh{c}}}{}}{b}000{bc{}}000{c{{Cn{e}}}{}{}}000{{}{{Cn{c}}}{}}000{bJl}000{{{b{{BDh{c}}}}}f{}}09999{{{BDj{c}}e}{{BDj{c}}}Ad{{BDd{cBEb}}Ef}}{{{BDj{c}}e}{{BDj{c}}}Ad{{BDd{cBE`}}Ef}}{{{BDj{c}}e}{{BDj{c}}}Ad{{AFh{c}}Ef}}{{{BDj{c}}e}{{BDj{c}}}Ad{{BDd{cBEd}}Ef}}`````{{bd}f}00{b{{b{c}}}{}}00{{{b{Af}}}{{b{Afc}}}{}}00{{{b{BEb}}}BEb}{{{b{BEd}}}BEd}{{{b{BE`}}}BE`}{{b{b{Afc}}}f{}}00{bf}00{Ch{{b{c}}}{}}00{Ch{{b{Afc}}}{}}00{{b{b{Afc}}}{{Cn{{Cl{eg}}}}}{}{}{}}00{Chf}00{{{b{BEb}}{b{BEb}}}Db}{{{b{BEd}}{b{BEd}}}Db}{{{b{BE`}}{b{BE`}}}Db}{{b{b{c}}}Db{}}00000000000{{{b{BEb}}{b{AfEb}}}Eh}{{{b{BEd}}{b{AfEb}}}Eh}{{{b{BE`}}{b{AfEb}}}Eh}{cc{}}0{ChBE`}1{{{b{c}}{b{e}}}Cd{GdGf}Gh}00{{{b{BEb}}{b{Afc}}}fGj}{{{b{BEd}}{b{Afc}}}fGj}{{{b{BE`}}{b{Afc}}}fGj}{{}Ch}00{{}c{}}00{{}{{Cn{HhHj}}}}00{b}00{bc{}}00{c{{Cn{e}}}{}{}}00{{}{{Cn{c}}}{}}00{bJl}00666`````````````````{{bd}f}0`{b{{b{h}}}}00{{{b{Fd}}}{{n{{b{l}}}}}}{b{{b{c}}}{}}00{{{b{Af}}}{{b{Afc}}}{}}00{{{b{Fd}}}{{n{{b{h}}}}}}{{{b{{ACj{ce}}}}}{{ACj{ce}}}Ad{{ACl{c}}}}{{{b{Fd}}}Fd}{{b{b{Afc}}}f{}}0{bf}0{{{b{{ACj{ce}}}}{b{{ACj{ce}}}}}NdAd{{ACl{c}}}}{{b{b{c}}}Nd{}}{{}BEh}{{{b{BEh}}}{{Cn{{Of{cFde}}Oh}}}{H`HbOj}Jf}{Ch{{b{c}}}{}}00{Ch{{b{Afc}}}{}}00{{{b{Fd}}}{{b{Cj}}}}{{b{b{Afc}}}{{Cn{{Cl{eg}}}}}{}{}{}}00{c{{Cn{Fd}}}D`}{Chf}00{{{b{{ACj{ce}}}}{b{{ACj{ce}}}}}DbAd{{ACl{c}}}}{{b{b{c}}}Db{}}000`{{{b{{ACj{ce}}}}{b{AfEb}}}EhAd{{ACl{c}}}}0{{{b{Fd}}{b{AfEb}}}Eh}0{cc{}}0{{{En{AnBb}}}Fd}1{A@bFd}{A`Fd}{{{b{c}}{b{e}}}Cd{GdGf}Gh}{{{b{ACh}}}{{Ib{{I`{Hn}}}}}}{{{b{ACn}}{ACj{ce}}}{{Ib{{I`{Hn}}}}}Ad{{ACl{c}}}}{{{b{{ACj{ce}}}}{b{Afg}}}fAd{{ACl{c}}}Gj}{c{{Gl{ce}}}{GnH`Hb}{}}0{{}{{b{Cj}}}}{{}}{{}Ch}00{{{b{AfAE`}}ADl{ADn{Ch}}Cd}{{Ib{{I`{Hn}}}}}}{{{b{Af{ACl{}{{BEj{c}}{BEl{e}}{BEn{g}}{BF`{i}}{BFb{k}}}}}}c{b{{ADl{ecg}}}}}{{ABn{f}}}{BFdH`HbJhBFfBFhMbGnBFjBFl}{BFnH`HbJhMbBFjBFl}{BG`H`}{{BGb{g}}H`{BGf{{b{BGd}}}}GnEf{B`{BGd}}}{{BGh{ecg}}}}{{}c{}}00{{}{{Cn{HhHj}}}}00{{{b{{ACj{ce}}}}{b{{ACj{ce}}}}}{{n{Nd}}}Ad{{ACl{c}}}}{b}00{{{b{Fd}}c}CnJj}{{{b{AfAE`}}Ch}{{Ib{{I`{Hn}}}}}}{{{b{Fd}}}{{n{{b{h}}}}}};{{{b{Fd}}}Bb}{bc{}}0{bAn}0<{c{{Cn{e}}}{}{}}00{{}{{Cn{c}}}{}}00{bJl}00<<<````````````````{{bd}f}0000000{{{b{BGj}}Ch}f}{{{b{BGl}}BGn}f}{b{{b{h}}}}00{{{b{BH`}}}{{n{{b{l}}}}}}{b{{b{c}}}{}}00000000{{{b{Af}}}{{b{Afc}}}{}}00000000{{{b{BH`}}}{{n{{b{h}}}}}}{{{b{AEb}}}AEb}{{{b{BGj}}}BGj}{{{b{BHb}}}BHb}{{{b{BGl}}}BGl}{{{b{BHd}}}BHd}{{{b{BHf}}}BHf}{{{b{BHh}}}BHh}{{{b{BHj}}}BHj}{{b{b{Afc}}}f{}}0000000{bf}0000000{{{b{AEb}}An{ADn{An}}}{{I`{BHl}}}}{{{b{BHd}}{ADn{An}}}{{I`{BHn}}}}{{{b{BHf}}{ADn{An}}}{{I`{BI`}}}}{{{b{BHh}}{ADn{An}}}{{I`{BIb}}}}{{{b{BHj}}{ADn{An}}}f}{{{b{AEb}}An{n{An}}}{{I`{BHn}}}}{{{b{AEb}}An{n{An}}}{{I`{BI`}}}}{{{b{AEb}}An{n{An}}}{{I`{BIb}}}}{{{b{AEb}}An}f}{{}AEb}{Ch{{b{c}}}{}}00000000{Ch{{b{Afc}}}{}}00000000{{{b{BH`}}}{{b{Cj}}}}{{b{b{Afc}}}{{Cn{{Cl{eg}}}}}{}{}{}}00000000{Chf}00000000{{{b{AEb}}}{{Cn{Anc}}}{}}{{{b{BH`}}{b{AfEb}}}Eh}0{{{b{AEb}}{b{AfEb}}}Eh}{{{b{BGj}}{b{AfEb}}}Eh}{{{b{BHb}}{b{AfEb}}}Eh}{{{b{BGl}}{b{AfEb}}}Eh}{{{b{BHd}}{b{AfEb}}}Eh}{{{b{BHf}}{b{AfEb}}}Eh}{{{b{BHh}}{b{AfEb}}}Eh}{{{b{BHj}}{b{AfEb}}}Eh}{cc{}}{BIdBH`}11111111{{{b{AEb}}{b{Cj}}}{{Cn{BHfBH`}}}}{{{b{AEb}}An{ADn{An}}}{{I`{BIf}}}}{{{b{BGj}}}Ch}{{{b{BHb}}}Ch}{{{b{BHd}}{b{{AN`{c}}}}}BGj{{BIh{Cj}}}}{{{b{BHf}}{b{{AN`{c}}}}}BHb{{BIh{Cj}}}}{{{b{BHh}}{b{{AN`{c}}}}}BGl{{BIh{Cj}}}}{{{b{AEb}}{b{Cj}}}{{Cn{BGjBH`}}}}{{{b{AEb}}{b{Cj}}}{{Cn{BHdBH`}}}}{{{b{AEb}}{b{Cj}}}{{Cn{BHbBH`}}}}{{{b{AEb}}{b{Cj}}}{{Cn{BGlBH`}}}}{{{b{AEb}}{b{Cj}}}{{Cn{BHhBH`}}}}{{{b{AEb}}c}{{Cn{AEbBH`}}}AMl}{c{{Gl{ce}}}{GnH`Hb}{}}{{{b{AEb}}An{ADn{An}}}{{I`{BIj}}}}{{}}{{}Ch}00000000{{}c{}}00000000{{}{{Cn{HhHj}}}}00000000{{{b{BGl}}}BGn}{b}00000000{{{b{BGl}}}Ch}{{{b{BHb}}Ch}f}{{{b{BH`}}}{{n{{b{h}}}}}}{{{b{AEb}}An}{{I`{AEf}}}}5{{{b{AEb}}An{ADn{An}}}{{I`{BIl}}}}{bc{}}0000000{bAn}{c{{Cn{e}}}{}{}}00000000{{}{{Cn{c}}}{}}00000000{bJl}00000000{{{b{BHb}}BIn}f}>>>>>>>>>`````````````````````````{{bd}f}00000000`{b{{b{h}}}}00{{{b{El}}}{{n{{b{l}}}}}}`{{{b{In}}}{{Ib{{I`{Hn}}}}}}{b{{b{c}}}{}}000000000{{{b{Af}}}{{b{Afc}}}{}}000000000{{{BJ`{ce}}}El{{B`{An}}}{{B`{Bb}}}}{{{b{El}}}{{n{{b{h}}}}}}{{{b{{ACf{c}}}}}{{ACf{c}}}Ad}{{{b{BJb}}}BJb}{{{b{{BJd{c}}}}}{{BJd{c}}}Bd}{{{b{BJf}}}BJf}{{{b{BJh}}}BJh}{{{b{{BJj{c}}}}}{{BJj{c}}}Bd}{{{b{{BJl{ce}}}}}{{BJl{ce}}}BdBd}{{{b{{BJ`{ce}}}}}{{BJ`{ce}}}BdBd}{{{b{El}}}El}{{b{b{Afc}}}f{}}00000000{bf}00000000{{{b{BJb}}{b{BJb}}}Nd}{{b{b{c}}}Nd{}}{{{b{In}}}{{Ib{{I`{Hn}}}}}}{{}{{BJd{c}}}{}}{{}BJn}{{{b{BJn}}c}{{Cn{{Of{eElc}}Oh}}}Jf{H`HbOj}}{Ch{{b{c}}}{}}000000000{Ch{{b{Afc}}}{}}000000000{{{b{El}}}{{b{Cj}}}}{{b{b{Afc}}}{{Cn{{Cl{eg}}}}}{}{}{}}{c{{Cn{BJb}}}D`}1{c{{Cn{{BJd{e}}}}}D`BK`}2222222{c{{Cn{El}}}D`}3{Chf}000000000`{{{b{BJb}}{b{BJb}}}Db}{{{b{{BJd{c}}}}{b{{BJd{c}}}}}DbLl}{{b{b{c}}}Db{}}0000000`{{{BJ`{ce}}}{{Cn{gEl}}}{{B`{An}}}{{B`{Bb}}}{}}{{{b{{ACf{c}}}}{b{AfEb}}}EhAd}{{{b{BJb}}{b{AfEb}}}Eh}{{{b{{BJd{c}}}}{b{AfEb}}}EhEf}{{{b{BJf}}{b{AfEb}}}Eh}{{{b{BJh}}{b{AfEb}}}Eh}{{{b{{BJj{c}}}}{b{AfEb}}}EhEf}{{{b{{BJl{ce}}}}{b{AfEb}}}EhEfEf}{{{b{{BJ`{ce}}}}{b{AfEb}}}EhEfEf}{{{b{El}}{b{AfEb}}}Eh}0{{{Kb{c}}}{{ACf{c}}}Ad}{cc{}}00{{{b{{BJd{c}}}}}{{n{Cd}}}BKb}111111{A@bEl}{A`El}{{{En{AnBb}}}El}4{{}BJb}{{{b{c}}{b{e}}}Cd{GdGf}Gh}{{{b{In}}eCd}{{Ib{{I`{Hn}}}}}Ad{{B`{{ACf{c}}}}H`Hb}}{{{b{BJb}}{b{Afc}}}fGj}{c{{Gl{ce}}}{GnH`Hb}{}}{{}}{{}Ch}000000000{cElGn}{{}c{}}000000000{{BJfc}El{}}{{BJhc}El{}}{{{BJj{c}}e}El{{B`{An}}}{}}{{{BJl{ce}}g}El{{B`{An}}}{{B`{Cd}}}{}}{{{BJ`{ce}}g}El{{B`{An}}}{{B`{Bb}}}{}}{{{b{BJb}}}Db}{{}{{Cn{HhHj}}}}000000000``````{{{b{BJb}}{b{BJb}}}{{n{Nd}}}}{{{b{In}}}{{Ib{{I`{Hn}}}}}}{b}000000000``{{{b{BJb}}c}CnJj}{{{b{{BJd{c}}}}e}CnJhJj}{{{b{El}}c}CnJj}{{{b{El}}}{{n{{b{h}}}}}}`{{{b{El}}}Bb}`6{bc{}}00000000{bAn}{c{{Cn{e}}}{}{}}000000000{{}{{Cn{c}}}{}}000000000{bJl}000000000{{{b{In}}e}{{Ib{{I`{Hn}}}}}Ad{{B`{{Mj{c}}}}H`Hb}}{{}c{}}000000000`````````````````{{bd}f}`{b{{b{h}}}}00{{{b{Fb}}}{{n{{b{l}}}}}}{{{b{J`}}}{{Ib{{I`{Hn}}}}}}{b{{b{c}}}{}}0{{{b{Af}}}{{b{Afc}}}{}}0{{{b{Fb}}}{{n{{b{h}}}}}}{{{b{Fb}}}Fb}{{b{b{Afc}}}f{}}{bf}{{{b{J`}}}{{AKf{AEb}}}}0{{}BKd}{{{b{BKd}}c}{{Cn{{Of{eFbc}}Oh}}}Jf{H`HbOj}}{Ch{{b{c}}}{}}0{Ch{{b{Afc}}}{}}0{{{b{Fb}}}{{b{Cj}}}}{{b{b{Afc}}}{{Cn{{Cl{eg}}}}}{}{}{}}{c{{Cn{Fb}}}D`}1{Chf}0??`{{{b{Fb}}{b{AfEb}}}Eh}0{cc{}}0{A@bFb}{AnFb}{c{{Gl{ce}}}{GnH`Hb}{}}{{}}{{}Ch}0{{}c{}}0{{}{{Cn{HhHj}}}}0{{{b{AEd}}}{{b{AEb}}}}{b}0{{{b{BKf}}}{{I`{AEf}}}}{{{b{Fb}}c}CnJj}{{{b{Fb}}}{{n{{b{h}}}}}}{{{b{Fb}}}Bb}{{{b{J`}}}{{Ib{{I`{Hn}}}}}}0{bc{}}{bAn}{c{{Cn{e}}}{}{}}0{{}{{Cn{c}}}{}}0{bJl}0==````{{bd}f}{b{{b{c}}}{}}0{{{b{Af}}}{{b{Afc}}}{}}0{{{b{BKh}}}BKh}{{b{b{Afc}}}f{}}{bf}{Ch{{b{c}}}{}}0{Ch{{b{Afc}}}{}}0{{b{b{Afc}}}{{Cn{{Cl{eg}}}}}{}{}{}}0{Chf}0{{{b{Af{BKj{c}}}}}fH`}{{{b{BKh}}{b{AfEb}}}Eh}{{{b{{BKj{c}}}}{b{AfEb}}}EhH`}{cc{}}0{{}Ch}0{{}c{}}0{{{BKj{c}}}cH`}{{}{{Cn{HhHj}}}}0{b}0{{ce}BKhGn{HnH`}}{{cg}{{BKj{e}}}GnH`{{Hn{}{{Id{e}}}}H`}}{bc{}}{c{{Cn{e}}}{}{}}0{{}{{Cn{c}}}{}}0{bJl}099``{{}f}{ABff}```````{b{{b{c}}}{}}{{{b{Af}}}{{b{Afc}}}{}}{{{b{c}}}{{Ib{{I`{Hn}}}}}{}}{Ch{{Ib{{I`{Hn}}}}}}{{{b{{AIl{c}}}}}cBKl}{{{b{{AIl{c}}}}Ch}cBKl}{Ch{{b{c}}}{}}{Ch{{b{Afc}}}{}}{{b{b{Afc}}}{{Cn{{Cl{eg}}}}}{}{}{}}{{{b{Af{AIl{c}}}}}fBKl}{Chf}{cc{}}{{{b{{AIl{c}}}}}{{b{{Ij{ADdBKnBL`}}}}}BKl}{{{b{{BKl{}{{BLb{c}}}}}}{b{{ADf{ADd}}}}}{{Ib{{I`{Hn}}}}}{H`Hb}}{{}Ch}{{}{{AIl{c}}}{BKlBKf}}{c{{AIl{e}}}{{Ih{{b{Af{BLf{BLd}}}}}}}{BKlBKf}}{{}c{}}{{}{{Cn{HhHj}}}}{{{b{{AIl{c}}}}}ChBKl}{b}{{{b{{AIl{c}}}}Ch}{{BLh{ADd}}}BKl}{{{b{c}}}{{Ib{{I`{Hn}}}}}{}}{{{b{Af{AIl{{BKl{}{{BLb{c}}}}}}}}}{{Ib{{I`{Hn}}}}}{H`Hb}}{{{AIl{c}}}fBKl}{{{b{Af{AIl{c}}}}eg}fBKlGn{HnH`}}{{{b{Af{AIl{c}}}}}fBKl}{{{b{{AIl{c}}}}}bBKl}{{{b{{AIl{c}}}}BLj}fBKl}{c{{Cn{e}}}{}{}}{{}{{Cn{c}}}{}}{bJl}>`````````````{{bd}f}00``{b{{b{c}}}{}}00{{{b{Af}}}{{b{Afc}}}{}}00`{{{b{ADd}}}ADd}{{{b{BL`}}}BL`}{{{b{BKn}}}BKn}{{b{b{Afc}}}f{}}00{bf}00{{{b{ADd}}{b{ADd}}}Nd}{{{b{BKn}}{b{BKn}}}Nd}{{b{b{c}}}Nd{}}0`{{}ADd}{{}BKn}`{Ch{{b{c}}}{}}00{Ch{{b{Afc}}}{}}00{{b{b{Afc}}}{{Cn{{Cl{eg}}}}}{}{}{}}{c{{Cn{ADd}}}D`}11{c{{Cn{BKn}}}D`}{Chf}00{{{b{ADd}}{b{ADd}}}Db}{{{b{BKn}}{b{BKn}}}Db}{{b{b{c}}}Db{}}0000000{{{b{BLl}}}c{}}0{{{b{ADd}}{b{AfEb}}}Eh}{{{b{BL`}}{b{AfEb}}}Eh}{{{b{BKn}}{b{AfEb}}}Eh}{cc{}}00{{{b{c}}{b{e}}}Cd{GdGf}Gh}0{{{b{ADd}}{b{Afc}}}fGj}{{{b{BKn}}{b{Afc}}}fGj}{{}{{b{Cj}}}}{{{b{BLl}}}Cd}{{}Ch}00{{{b{AfBLn}}c{b{{ADl{ecg}}}}}{{ABn{f}}}{}{}{}}{{}c{}}00{{{b{BM`}}{b{c}}}e{}{}}`{{}{{Cn{HhHj}}}}00{{{b{BM`}}{b{c}}}Ch{}}`{{{ADn{BMb}}}BLj}{{{b{BLj}}}c{}}{{{b{BLl}}}{{ADn{c}}}{}}{{{b{ADd}}{b{ADd}}}{{n{Nd}}}}{{{b{BKn}}{b{BKn}}}{{n{Nd}}}}`{b}00`{{{b{BLl}}}c{}}`0{{{b{ADd}}c}CnJj}{{{b{BKn}}c}CnJj}`{{}{{b{Cj}}}}{{{b{BLl}}}Cd}`{bc{}}00{{{b{BM`}}{b{c}}{b{e}}}{{n{{En{gi}}}}}{}{}{}{}}`{{}Ch}{c{{Cn{e}}}{}{}}00{{}{{Cn{c}}}{}}00{bJl}00```{{}c{}}00`{{{b{BKb}}}Cd}","D":"EG`","p":[[1,"reference"],[5,"Private",4370],[1,"unit"],[10,"Error",4371],[6,"Error",0,4372],[5,"Backtrace",4373],[6,"Option",4374],[6,"QueryError",0],[5,"Leaf",0,4375],[10,"NodeType",4376],[0,"mut"],[5,"NotFoundSnafu",0],[5,"MissingSnafu",0],[5,"ErrorSnafu",0],[5,"String",4377],[10,"Into",4378],[5,"StatusCode",4379],[10,"Clone",4380],[5,"ApiState",0],[5,"UpgradeLock",4381],[5,"Commitment",4382],[10,"Versions",4376],[10,"Resolvable",0,4383],[10,"Committable",4382],[10,"RngCore",4384],[1,"u64"],[5,"Options",0],[1,"usize"],[1,"str"],[5,"With",4385],[6,"Result",4386],[10,"Deserializer",4387],[1,"bool"],[5,"UpgradeProposalData",4388],[5,"UpgradeThreshold",4389],[5,"SimpleCertificate",4389],[5,"RwLock",4390],[5,"Arc",4391],[5,"Error",1649,4392],[6,"BlockError",4375],[5,"Formatter",4393],[5,"Error",4393],[10,"Debug",4393],[8,"Result",4393],[6,"Error",315],[6,"Error",3767],[1,"tuple"],[6,"Error",2090],[6,"Error",4073],[6,"Error",3401],[6,"TimestampConversionError",2090,4394],[6,"Error",4395],[1,"never"],[5,"OwnedFd",4396],[10,"IntoFilelike",4397],[10,"IntoSocketlike",4397],[5,"QuorumProposal",4375],[10,"Hash",4398],[10,"Sized",4399],[10,"BuildHasher",4398],[10,"Hasher",4398],[5,"IndentedSection",4400],[10,"Display",4393],[10,"Send",4399],[10,"Sync",4399],[5,"QuorumData",4388],[5,"SuccessThreshold",4389],[5,"Layout",4401],[5,"LayoutError",4401],[5,"DynGuard",4402],[10,"Future",4403],[5,"Box",4404],[5,"Pin",4405],[17,"Output"],[8,"BoxFuture",4406],[10,"FnOnce",4407],[5,"SystemContextHandle",4408],[10,"AvailabilityDataSource",315,4409],[10,"NodeDataSource",3767,4410],[10,"StatusDataSource",4073,4411],[10,"VersionedDataSource",1000,4412],[10,"NodeImplementation",4376],[10,"StaticVersionType",4413],[10,"Serialize",4414],[10,"Serializer",4414],[5,"TypeId",4415],[5,"InconsistentLeafError",315,4416],[5,"LeafQueryData",315,4416],[8,"BlockHash",315,4416],[5,"PayloadQueryData",315,4416],[5,"VidCommonQueryData",315,4416],[5,"TransactionQueryData",315,4416],[5,"FetchLeafSnafu",315],[5,"FetchBlockSnafu",315],[5,"FetchTransactionSnafu",315],[5,"InvalidTransactionIndexSnafu",315],[5,"CustomSnafu",315],[17,"TransactionIndex"],[17,"Iter"],[17,"InclusionProof"],[10,"QueryablePayload",315,4416],[10,"PartialEq",4417],[10,"Eq",4417],[10,"Ord",4417],[10,"DeserializeOwned",4387],[17,"Item"],[10,"Iterator",4418],[6,"LeafId",315,4409],[6,"BlockId",315,4409],[5,"BlockQueryData",315,4416],[5,"BlockSummaryQueryData",315,4416],[5,"TransactionSummaryQueryData",315,4416],[5,"RequestSnafu",315],[6,"Ordering",4417],[8,"VidCommon",0,4419],[6,"Fetch",315,4420],[10,"ErrorCompat",4421],[17,"Source"],[5,"NoneError",4421],[10,"IntoError",4421],[8,"Payload",0],[5,"Options",315],[5,"Api",4422],[6,"ApiError",4422],[10,"ReadState",4423],[8,"TransactionIndex",315,4416],[8,"Transaction",0],[8,"LeafHash",315,4416],[6,"RequestError",4424],[8,"Result",4395],[17,"LeafRange"],[17,"BlockRange"],[17,"PayloadRange"],[17,"VidCommonRange"],[10,"Stream",4425],[10,"Unpin",4399],[10,"RangeBounds",4426],[8,"TransactionHash",315,4416],[8,"VidCommitment",0,4419],[8,"Header",0],[10,"UpdateAvailabilityData",315,4409],[8,"VidShare",0,4419],[8,"Metadata",0],[8,"QuorumCertificate",4389],[8,"TransactionInclusionProof",315,4416],[10,"QueryableHeader",315,4416],[5,"Duration",4427],[5,"ExtensibleDataSource",1000,4428],[5,"MetricsDataSource",1000,4429],[10,"Transaction",1000,4412],[8,"Result",4392],[6,"BlockIdentifier",2090,4394],[10,"ExplorerDataSource",2090,4430],[5,"GetBlockSummariesRequest",2090,4394],[6,"WindowStart",3767,4410],[10,"MerklizedStateHeightPersistence",3401,4431],[6,"Snapshot",3401,4431],[10,"MerklizedState",3401,4431],[10,"MerklizedStateDataSource",3401,4431],[6,"TransactionIdentifier",2090,4394],[5,"GetTransactionSummariesRequest",2090,4394],[5,"MockTypes",4234],[5,"Event",4432],[10,"TestableDataSource",4194],[10,"Default",4433],[5,"MerkleProof",4434],[5,"Vec",4435],[10,"UpdateStateData",3401,4431],[5,"PrometheusMetrics",3521],[10,"HasMetrics",4073,4411],[10,"Metrics",4436],[17,"Transaction"],[17,"ReadOnly"],[10,"UpdateDataSource",1000,4412],[5,"Transaction",1119,4437],[5,"FetchingDataSource",1119],[10,"NodeStorage",1318],[5,"Builder",1119],[10,"PruneStorage",1603],[10,"AvailabilityProvider",1119],[5,"Pruner",1119],[8,"Config",1300],[8,"Builder",1300],[5,"Path",4438],[5,"FileSystemStorage",1354],[5,"AtomicStoreLoader",4439],[10,"AvailabilityStorage",1318],[10,"ExplorerStorage",1318],[10,"MerklizedStateHeightStorage",1318],[10,"MerklizedStateStorage",1318],[10,"PrunedHeightStorage",1603],[8,"FileSystemDataSource",1280],[8,"SqlDataSource",1300],[5,"Transaction",1354],[10,"Revert",1354],[17,"Target"],[5,"FileSystemStorageInner",1354],[10,"Deref",4440],[5,"RwLockReadGuard",4390],[5,"RwLockWriteGuard",4390],[6,"PersistenceError",4441],[5,"Transaction",1440],[5,"NoStorage",1440],[6,"Transaction",1505],[6,"DataSource",1505],[5,"MockNetwork",4194],[5,"PrunerCfg",1603],[17,"Pruner"],[10,"PrunerConfig",1603],[1,"u16"],[1,"i32"],[5,"OffsetDateTime",4442],[5,"Migration",1649,4443],[5,"Config",1649],[10,"Database",1649,4444],[10,"Params",1649,4445],[8,"Query",1649,4445],[5,"QueryBuilder",1649,4446],[8,"QueryResult",0],[8,"Db",1649,4447],[10,"Encode",4448],[10,"Type",4449],[5,"Transaction",1649,4445],[10,"TransactionMode",1649,4445],[5,"Postgres",1649,4450],[5,"Chain",4392],[5,"Write",1649,4445],[5,"Read",1649,4445],[5,"SqlStorage",1649],[5,"Pruner",1649],[17,"Database"],[10,"Executor",1649,4451],[10,"Execute",4451],[5,"Sqlite",1649,4452],[5,"FmtValue",4453],[5,"PgConnectOptions",4454],[1,"u32"],[10,"IntoIterator",4455],[6,"Type",4443],[1,"slice"],[8,"QueryAs",1649,4445],[10,"FromRow",4456],[5,"TestArgs",4457],[5,"Error",4458],[1,"array"],[5,"TmpDb",2049],[5,"MonetaryValue",2090,4459],[1,"i128"],[5,"CurrencyMismatchError",2090,4460],[5,"InvalidCurrencyCodeError",2090,4460],[6,"CurrencyCode",2090,4460],[5,"BlockRange",2090,4394],[5,"TransactionRange",2090,4394],[5,"Timestamp",2090,4394],[6,"GetBlockDetailError",2090,4394],[6,"GetBlockSummariesError",2090,4394],[6,"GetTransactionDetailError",2090,4394],[6,"GetTransactionSummariesError",2090,4394],[6,"GetExplorerSummaryError",2090,4394],[6,"GetSearchResultsError",2090,4394],[5,"BlockDetail",2090,4394],[5,"BlockSummary",2090,4394],[5,"FeeAttribution",2090,4394],[5,"TransactionDetail",2090,4394],[5,"TransactionSummary",2090,4394],[6,"TransactionSummaryFilter",2090,4394],[5,"GenesisOverview",2090,4394],[5,"ExplorerHistograms",2090,4394],[5,"ExplorerSummary",2090,4394],[5,"SearchResult",2090,4394],[5,"BlockDetailResponse",2090],[5,"BlockSummaryResponse",2090],[5,"TransactionDetailResponse",2090],[5,"TransactionSummariesResponse",2090],[5,"ExplorerSummaryResponse",2090],[5,"SearchResultResponse",2090],[17,"BalanceAmount"],[17,"WalletAddress"],[17,"ProposerId"],[17,"NamespaceId"],[10,"ExplorerHeader",2090,4461],[5,"TryFromIntError",4462],[5,"ComponentRange",4463],[6,"Resettable",4464],[10,"ExplorerTransaction",2090,4461],[5,"Fetcher",3167],[10,"LocalCallback",3167],[10,"Callback",3167],[10,"Request",3311],[10,"Provider",3201],[5,"Semaphore",4465],[5,"TestProvider",3201,4466],[5,"AnyProvider",3201,4467],[5,"QueryServiceProvider",3201,4468],[5,"NoFetching",3201],[5,"LeafRequest",3311],[5,"PayloadRequest",3311],[5,"VidCommonRequest",3311],[5,"Url",4469],[5,"Options",3401],[17,"Key"],[17,"Entry"],[17,"T"],[17,"Commit"],[17,"Digest"],[10,"Index",4470],[10,"ToTraversalPath",4470],[10,"FromStr",4471],[10,"CanonicalSerialize",4472],[10,"CanonicalDeserialize",4472],[10,"Element",4470],[10,"NodeValue",4470],[10,"MerkleCommitment",4470],[5,"TaggedBase64",4473],[10,"TryFrom",4378],[10,"DigestAlgorithm",4470],[5,"Counter",3521],[5,"Histogram",3521],[1,"f64"],[6,"MetricsError",3521],[5,"Gauge",3521],[5,"CounterFamily",3521],[5,"GaugeFamily",3521],[5,"HistogramFamily",3521],[5,"TextFamily",3521],[10,"CounterFamily",4436],[10,"Counter",4436],[10,"Gauge",4436],[10,"Histogram",4436],[6,"Error",4474],[10,"GaugeFamily",4436],[10,"AsRef",4378],[10,"HistogramFamily",4436],[10,"TextFamily",4436],[1,"i64"],[5,"CustomSnafu",3767],[5,"SyncStatus",3767,4475],[5,"TimeWindowQueryData",3767,4475],[5,"RequestSnafu",3767],[5,"QuerySnafu",3767],[5,"QueryVidSnafu",3767],[5,"QueryWindowSnafu",3767],[5,"Options",3767],[10,"Deserialize",4387],[10,"HeightIndexed",4368],[5,"Options",4073],[10,"UpdateStatusData",4073,4411],[5,"BackgroundTask",4147],[5,"Task",4147],[10,"DataSourceLifeCycle",4194],[5,"MockNodeImpl",4234],[5,"MockVersions",4234],[17,"Storage"],[8,"BLSPubKey",4476],[5,"HotShotConfig",4477],[8,"SignatureKey",0],[8,"MockTransaction",4234],[8,"MockHeader",4234],[8,"MockMerkleTree",4234],[8,"MockPayload",4234],[1,"u8"],[15,"Custom",307],[15,"Availability",307],[15,"Node",307],[15,"Status",307],[15,"MerklizedState",307],[15,"Explorer",307],[15,"Error",314],[15,"InvalidTransactionIndex",992],[15,"Custom",992],[15,"FetchLeaf",992],[15,"FetchBlock",992],[15,"FetchTransaction",992],[15,"Request",992],[6,"Storage",1505],[15,"NoStorage",1602],[5,"TestMerkleTreeMigration",2049],[15,"Custom",3517],[15,"Request",3517],[15,"Query",3517],[15,"NoSuchMetric",3763],[15,"NoSuchSubgroup",3763],[15,"Prometheus",3763],[15,"QueryVid",4064],[15,"QueryWindow",4064],[15,"Custom",4064],[15,"Request",4064],[15,"Query",4064],[15,"Internal",4145],[15,"Request",4145],[8,"MockQuorumProposal",4234],[8,"MockStorage",4234],[8,"MockAuctionResults",4234]],"r":[[4,4372],[9,4375],[22,4383],[26,4419],[27,4419],[28,4419],[315,4409],[316,4416],[317,4409],[318,4416],[320,4416],[324,4420],[334,4416],[338,4416],[339,4409],[340,4416],[346,4416],[349,4416],[350,4416],[354,4416],[355,4416],[356,4416],[357,4416],[359,4416],[360,4416],[361,4409],[362,4416],[1000,1119],[1001,4428],[1002,1119],[1003,1280],[1004,4429],[1006,1300],[1007,4412],[1009,4412],[1010,4412],[1123,4437],[1281,1354],[1302,4392],[1303,4443],[1304,4450],[1306,4445],[1313,0],[1316,2049],[1320,1354],[1323,1440],[1325,1649],[1654,4444],[1656,4447],[1657,4392],[1658,4451],[1659,4445],[1660,4443],[1662,4445],[1663,4450],[1665,4445],[1666,4445],[1667,4446],[1669,4445],[1672,4452],[1674,4445],[1676,4445],[1681,4445],[1896,4478],[1897,0],[1969,4445],[1971,4445],[2090,4394],[2093,4394],[2095,4394],[2096,4394],[2098,4394],[2099,4394],[2104,4460],[2105,4460],[2110,4430],[2111,4461],[2112,4394],[2113,4394],[2115,4461],[2116,4394],[2120,4394],[2122,4394],[2125,4394],[2127,4394],[2129,4394],[2131,4394],[2133,4394],[2135,4394],[2137,4394],[2143,4460],[2150,4459],[2154,4394],[2163,4394],[2168,4394],[2169,4394],[2172,4394],[2174,4394],[2175,4394],[2177,4394],[2179,4394],[2180,4394],[2188,4394],[3170,3201],[3171,3311],[3201,4467],[3204,4468],[3205,4466],[3409,4431],[3410,4431],[3411,4431],[3415,4431],[3417,4431],[3767,4416],[3768,4409],[3774,4410],[3784,4475],[3786,4475],[3787,4410],[4074,4411],[4078,4411],[4079,4411]],"b":[[92,"impl-Leaf%3CTYPES%3E"],[93,"impl-Committable-for-Leaf%3CTYPES%3E"],[150,"impl-Debug-for-Leaf%3CTYPES%3E"],[151,"impl-Display-for-Leaf%3CTYPES%3E"],[152,"impl-Display-for-Error"],[153,"impl-Debug-for-Error"],[157,"impl-Display-for-QueryError"],[158,"impl-Debug-for-QueryError"],[161,"impl-From%3CError%3E-for-Error"],[162,"impl-From%3CError%3E-for-Error"],[163,"impl-From%3C(String,+StatusCode)%3E-for-Error"],[164,"impl-From%3CError%3E-for-Error"],[165,"impl-From%3CError%3E-for-Error"],[166,"impl-From%3CError%3E-for-Error"],[171,"impl-From%3CTimestampConversionError%3E-for-QueryError"],[173,"impl-From%3CError%3E-for-QueryError"],[176,"impl-From%3CArc%3CD%3E%3E-for-ApiState%3CD%3E"],[178,"impl-From%3CD%3E-for-ApiState%3CD%3E"],[643,"impl-Display-for-LeafId%3CTypes%3E"],[644,"impl-Debug-for-LeafId%3CTypes%3E"],[645,"impl-Debug-for-BlockId%3CTypes%3E"],[646,"impl-Display-for-BlockId%3CTypes%3E"],[648,"impl-Display-for-InconsistentLeafError%3CTypes%3E"],[649,"impl-Debug-for-InconsistentLeafError%3CTypes%3E"],[662,"impl-Debug-for-Error"],[663,"impl-Display-for-Error"],[667,"impl-From%3Cusize%3E-for-LeafId%3CTypes%3E"],[668,"impl-From%3CCommitment%3CLeaf%3CTypes%3E%3E%3E-for-LeafId%3CTypes%3E"],[669,"impl-From%3CCommitment%3C%3CTypes+as+NodeType%3E::BlockHeader%3E%3E-for-BlockId%3CTypes%3E"],[671,"impl-From%3Cusize%3E-for-BlockId%3CTypes%3E"],[689,"impl-From%3CRequestError%3E-for-Error"],[690,"impl-From%3C(String,+StatusCode)%3E-for-Error"],[1016,"impl-NodeDataSource%3CTypes%3E-for-ExtensibleDataSource%3CD,+U%3E"],[1017,"impl-StatusDataSource-for-ExtensibleDataSource%3CD,+U%3E"],[1130,"impl-NodeDataSource%3CTypes%3E-for-FetchingDataSource%3CTypes,+S,+P%3E"],[1131,"impl-StatusDataSource-for-FetchingDataSource%3CTypes,+S,+P%3E"],[1283,"impl-DataSourceLifeCycle-for-FetchingDataSource%3CMockTypes,+FileSystemStorage%3CMockTypes%3E,+P%3E"],[1284,"impl-FetchingDataSource%3CTypes,+FileSystemStorage%3CTypes%3E,+P%3E"],[1309,"impl-FetchingDataSource%3CTypes,+SqlStorage,+P%3E"],[1310,"impl-DataSourceLifeCycle-for-FetchingDataSource%3CMockTypes,+SqlStorage,+P%3E"],[1365,"impl-Transaction-for-Transaction%3CRwLockReadGuard%3C\'a,+FileSystemStorageInner%3CTypes%3E%3E%3E"],[1366,"impl-Transaction-for-Transaction%3CRwLockWriteGuard%3C\'a,+FileSystemStorageInner%3CTypes%3E%3E%3E"],[1421,"impl-Transaction-for-Transaction%3CRwLockReadGuard%3C\'a,+FileSystemStorageInner%3CTypes%3E%3E%3E"],[1422,"impl-Transaction-for-Transaction%3CRwLockWriteGuard%3C\'a,+FileSystemStorageInner%3CTypes%3E%3E%3E"],[1516,"impl-StatusDataSource-for-DataSource"],[1517,"impl-NodeDataSource%3CMockTypes%3E-for-DataSource"],[1689,"impl-AsRef%3Cdyn+Error+%2B+Send+%2B+Sync%3E-for-Error"],[1690,"impl-AsRef%3Cdyn+Error%3E-for-Error"],[1837,"impl-Debug-for-Error"],[1838,"impl-Display-for-Error"],[1839,"impl-Display-for-Migration"],[1840,"impl-Debug-for-Migration"],[2616,"impl-Display-for-CurrencyMismatchError"],[2617,"impl-Debug-for-CurrencyMismatchError"],[2618,"impl-Debug-for-InvalidCurrencyCodeError"],[2619,"impl-Display-for-InvalidCurrencyCodeError"],[2620,"impl-Display-for-CurrencyCode"],[2621,"impl-Debug-for-CurrencyCode"],[2622,"impl-Debug-for-MonetaryValue"],[2623,"impl-Display-for-MonetaryValue"],[2624,"impl-Display-for-BlockIdentifier%3CTypes%3E"],[2625,"impl-Debug-for-BlockIdentifier%3CTypes%3E"],[2626,"impl-Display-for-TransactionIdentifier%3CTypes%3E"],[2627,"impl-Debug-for-TransactionIdentifier%3CTypes%3E"],[2633,"impl-Debug-for-TimestampConversionError"],[2634,"impl-Display-for-TimestampConversionError"],[2645,"impl-Debug-for-GetBlockDetailError"],[2646,"impl-Display-for-GetBlockDetailError"],[2647,"impl-Debug-for-GetBlockSummariesError"],[2648,"impl-Display-for-GetBlockSummariesError"],[2649,"impl-Debug-for-GetTransactionDetailError"],[2650,"impl-Display-for-GetTransactionDetailError"],[2651,"impl-Display-for-GetTransactionSummariesError"],[2652,"impl-Debug-for-GetTransactionSummariesError"],[2653,"impl-Debug-for-GetExplorerSummaryError"],[2654,"impl-Display-for-GetExplorerSummaryError"],[2655,"impl-Display-for-GetSearchResultsError"],[2656,"impl-Debug-for-GetSearchResultsError"],[2657,"impl-Debug-for-Error"],[2658,"impl-Display-for-Error"],[2677,"impl-From%3CTryFromIntError%3E-for-TimestampConversionError"],[2678,"impl-From%3CComponentRange%3E-for-TimestampConversionError"],[2690,"impl-From%3CQueryError%3E-for-GetBlockDetailError"],[2691,"impl-From%3CError%3E-for-GetBlockDetailError"],[2694,"impl-From%3CError%3E-for-GetBlockSummariesError"],[2695,"impl-From%3CQueryError%3E-for-GetBlockSummariesError"],[2697,"impl-From%3CQueryError%3E-for-GetTransactionDetailError"],[2698,"impl-From%3CTimestampConversionError%3E-for-GetTransactionDetailError"],[2699,"impl-From%3CError%3E-for-GetTransactionDetailError"],[2700,"impl-From%3CError%3E-for-GetTransactionSummariesError"],[2702,"impl-From%3CQueryError%3E-for-GetTransactionSummariesError"],[2704,"impl-From%3CGetTransactionSummariesError%3E-for-GetExplorerSummaryError"],[2705,"impl-From%3CError%3E-for-GetExplorerSummaryError"],[2706,"impl-From%3CQueryError%3E-for-GetExplorerSummaryError"],[2707,"impl-From%3CGetBlockDetailError%3E-for-GetExplorerSummaryError"],[2708,"impl-From%3CGetBlockSummariesError%3E-for-GetExplorerSummaryError"],[2709,"impl-From%3CError%3E-for-GetSearchResultsError"],[2710,"impl-From%3CQueryError%3E-for-GetSearchResultsError"],[3251,"impl-Provider%3CTypes,+LeafRequest%3E-for-AnyProvider%3CTypes%3E"],[3252,"impl-Provider%3CTypes,+PayloadRequest%3E-for-AnyProvider%3CTypes%3E"],[3253,"impl-Provider%3CTypes,+VidCommonRequest%3E-for-AnyProvider%3CTypes%3E"],[3254,"impl-Provider%3CTypes,+LeafRequest%3E-for-QueryServiceProvider%3CVer%3E"],[3255,"impl-Provider%3CTypes,+VidCommonRequest%3E-for-QueryServiceProvider%3CVer%3E"],[3256,"impl-Provider%3CTypes,+PayloadRequest%3E-for-QueryServiceProvider%3CVer%3E"],[3462,"impl-Debug-for-Snapshot%3CTypes,+T,+ARITY%3E"],[3463,"impl-Display-for-Snapshot%3CTypes,+T,+ARITY%3E"],[3464,"impl-Display-for-Error"],[3465,"impl-Debug-for-Error"],[3468,"impl-From%3C(String,+StatusCode)%3E-for-Error"],[3470,"impl-From%3CRequestError%3E-for-Error"],[3471,"impl-From%3CQueryError%3E-for-Error"],[3638,"impl-Debug-for-MetricsError"],[3639,"impl-Display-for-MetricsError"],[3658,"impl-PrometheusMetrics"],[3659,"impl-Metrics-for-PrometheusMetrics"],[3924,"impl-Debug-for-Error"],[3925,"impl-Display-for-Error"],[3937,"impl-From%3CRequestError%3E-for-Error"],[3938,"impl-From%3CQueryError%3E-for-Error"],[3939,"impl-From%3C(String,+StatusCode)%3E-for-Error"],[4112,"impl-Display-for-Error"],[4113,"impl-Debug-for-Error"],[4116,"impl-From%3CRequestError%3E-for-Error"],[4117,"impl-From%3CString%3E-for-Error"]],"c":"OjAAAAAAAAA=","e":"OzAAAAEAAFoOGQECAAEABQAAAAgAAQALAAEADwAAABMAAwAYAAEAHgAMACwAAgAyAA8ARQAXAF4AAABgAAEAYwAsAJcACQCiAAUArAAAAK4AAACxAAYAuQAAALsABADBAAEAxAANANoAAgDeAAkA6QABAOwAAADvAAkA+gAEAAABAgAEARoAIAEIACwBDwA+AQQARAEAAEYBAABIAQAASgEAAEwBAQBPAQEAUwELAGABAQBjAQMAaAEhAIwBJQC5ATkA9AFYAE8CLQCEAhQAnAICAKACAAClAgAAqQIAALICEQDFAgYAzQIPAN4CFwAJAwYAEgMAABQDFAAqAwAALAMBAC8DAQA3AxoAVQMBAFgDLwCKAwAAjgMAAJIDJQC5AyUA4QMIAOsDAQDuAwEA9AMDAPkDGwAWBAEAGgQWADMEAwA5BAQAPwQAAEEEAwBGBAUATgQIAFgEAwBdBAIAYwQRAHcEBgB/BAEAgwQLAJAEBgCbBCwAzAQFANUECQDgBBYAAAUAAAIFAgAHBQAACgUAAAwFCgAbBQAAHwUCACMFAwApBQEALAUGADQFAAA3BQcAQAUAAEMFBQBKBQAATAUMAFsFDwBuBRAAggUDAIgFBwCRBQ8AogUVALoFDwDMBRwA6gUfAA0GEQAiBicASwYKAFcGAgBcBgEAYAYCAGQGAABmBgsAeAYAAIEGAgCTBgQAmgYBAJ0GAwCiBhYAvQYSANQGAgDYBgYA4AYnAAsHEgAuBw8APwcBAEkHAABMBw0AWwcKAGsHDgCGBwoAkgcAAJQHAACbBwIAnwcLALIHAAC0BwAAtgcAALgHAgC9BwoAyQcmAPEHAQD1Bx0AFQgDABsIEAAtCAAAMQgBADYIAgA8CAIARggCAEoIAABMCAEATwgAAFEIAABTCAAAVQgAAFcIAABZCAAAWwgEAGEIBQBqCAEAbQgGAHYIAgB7CAEAgAgBAIYIBwCPCBAAoQhnAAoJNgBCCUsAjwkEAJUJmgAyCgEANgoCADoKAQA+CgEAQQooAHYKAQCDCgEAhwoBAIoKAwCPCgAAkQoGAJoKAACcCgAAnwoAAKIKAACkCgMArgpBABMLKgBACysAbQsCAHELAwB3CwAAegsWAJILEQClC5UAPAwjAGMMDQByDAAAdAwBAHgMAQB7DAYAhwwDAIwMJQC0DAsAxAwDAMwMGQDoDAMA9QwvACcNAAApDQgANQ0cAFQNAwBZDQAAWw0qAIcNAwCNDQAAjw0HAJgNBAChDQkArA0EALINDwDIDQMAzg1yAEIOAABMDgUAWA4LAG0OTQC8DgUAww4AAMUOAADHDgAAyQ4BAMwOJADyDlgATQ8KAGIPAgBmDxAAgQ8qAK0PYgAREAEAFRAFAB0QFgA2EBIASxABAFAQAwBWEBEAaRALAHYQBAB8EAQAghAJAI0QDQCdEAUApBAtANUQCQDiEAAA5BADAOkQBADvEAIA8xAAAPUQAgD5EAEA/BADAAERCQAOEQIAEhEAAA=="}]]')); if (typeof exports !== 'undefined') exports.searchIndex = searchIndex; else if (window.initSearch) window.initSearch(searchIndex); -//{"start":39,"fragment_lengths":[107670]} \ No newline at end of file +//{"start":39,"fragment_lengths":[107846]} \ No newline at end of file diff --git a/search.desc/hotshot_query_service/hotshot_query_service-desc-0-.js b/search.desc/hotshot_query_service/hotshot_query_service-desc-0-.js index c51232deb..413369ada 100644 --- a/search.desc/hotshot_query_service/hotshot_query_service-desc-0-.js +++ b/search.desc/hotshot_query_service/hotshot_query_service-desc-0-.js @@ -1 +1 @@ -searchState.loadedDescShard("hotshot_query_service", 0, "The HotShot Query Service is a minimal, generic query …\nRead-only wrapper for API state which does not require …\nContains the error value\nThere was an error while trying to fetch the requested …\nSNAFU context selector for the QueryError::Error variant\nThis is the consensus-internal analogous concept to a …\nThe requested resource exists but is not currently …\nSNAFU context selector for the QueryError::Missing variant\nThe requested resource does not exist or is not known to …\nSNAFU context selector for the QueryError::NotFound variant\nContains the success value\nA reference to a T which can be resolved into a whole T.\nItem within a Payload.\nVID commitment type\nVID common type\nVID share type\nQueries for HotShot chain state.\nThe block header contained in this leaf.\nGet a mutable reference to the block header contained in …\nOptional block payload.\nConsume the selector and return the associated error\nConsume the selector and return the associated error\nConsume the selector and return the associated error\nCalculate the leaf commitment, which is gated on the …\nGet a commitment to the underlying object.\nPersistent storage and sources of data consumed by APIs.\nValidate that a leaf has the right upgrade certificate to …\nConsume the selector and return a Result with the …\nConsume the selector and return a Result with the …\nConsume the selector and return a Result with the …\nFetching missing data from remote providers.\nFill this leaf with the block payload.\nFill this leaf with the block payload, without checking …\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nConstructs a leaf from a given quorum proposal.\nCreate a new leaf from its components.\nHeight of this leaf in the chain.\nEmbed migrations from the given directory into the current …\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nThe QC linking this leaf to its parent in the chain.\nApi for querying merklized state\nA node’s view of a HotShot chain\nCommitment to this leaf’s parent.\nA commitment to the block payload contained in this leaf.\nRun an instance of the HotShot Query service with no …\nQueries for node-specific state and uncommitted data.\nAsync task utilites.\nGet the underlying object if it is available without …\nCommon functionality provided by types used in this crate.\nThe QC linking this leaf to its parent in the chain.\nTime when this leaf was created.\nAn interface for querying a HotShot blockchain.\nA block hash is the hash of the block header.\nSNAFU context selector for the Error::Custom variant\nAn in-progress request to fetch some data.\nSNAFU context selector for the Error::FetchBlock variant\nSNAFU context selector for the Error::FetchLeaf variant\nSNAFU context selector for the Error::FetchTransaction …\nA proof that a certain transaction exists in the block.\nSNAFU context selector for the …\nEnumerate the transactions in this block.\nA block payload whose contents (e.g. individual …\nSNAFU context selector for the Error::Request variant\nAn index which can be used to efficiently retrieve a …\nThe hash of the block containing this transaction.\nThe height of the block containing this transaction.\nConsume the selector and return the associated error\nConsume the selector and return the associated error\nConsume the selector and return the associated error\nConsume the selector and return the associated error\nConsume the selector and return the associated error\nGet the index of the transaction with a given hash, if it …\nGet the index of the transaction with a given hash, if it …\nConvert this Fetch to a Result with the provided error …\nEnumerate the transactions in the block with their indices.\nEnumerate the transactions in the block with their indices.\nAdditional API specification files to merge with …\nConsume the selector and return a Result with the …\nConsume the selector and return a Result with the …\nConsume the selector and return a Result with the …\nConsume the selector and return a Result with the …\nConsume the selector and return a Result with the …\nTimeout for failing requests due to missing data.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the transaction with the given hash.\nThe hash of this transaction.\nThe (0-based) position of this transaction within its …\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nWhether this block is empty of transactions.\nWhether this block is empty of transactions.\nList the transaction indices in the block.\nThe number of transactions in the block.\nTransform the result of this fetch.\nCollect information about a Leaf.\nGet the index of the nth transaction.\nGet the index of the nth transaction.\nGet the nth transaction.\nGet the nth transaction.\nGet the nth transaction, along with an inclusion proof.\nGet the nth transaction, along with an inclusion proof.\nGet an inclusion proof for a transaction with a given …\nGet an inclusion proof for a transaction with a given …\nA proof of inclusion of this transaction in its block.\nWait for the data to become available, if it is not …\nGet a transaction by its block-specific index.\nGet a transaction by its block-specific index.\nThe underlying transaction data.\nGet the transaction with a given hash, if it is in the …\nGet the transaction with a given hash, if it is in the …\nGet the transaction with a given hash, if it is in the …\nGet the transaction with a given hash, if it is in the …\nGet a transaction by its block-specific index, along with …\nGet the requested data if it is available immediately.\nConvert this Fetch to a Result with the provided error …\nWait for the requested data to become available, but only …\nWrapper to add extensibility to an existing data source.\nA minimal data source for the status API provided in this …\nA unit of atomicity for updating a shared data sourec.\nA transaction which can read and modify the data source.\nAn extension trait for types which implement the update …\nA data source with an atomic transaction-based …\nGeneric tests we can instantiate for all the availability …\nAsynchronous retrieval of missing data.\nReturns the argument unchanged.\nReturns the argument unchanged.\nAccess the underlying data source.\nMutably access the underlying data source.\nCalls U::from(self).\nCalls U::from(self).\nGeneric tests we can instantiate for all the node data …\nGeneric tests we can instantiate for any data source with …\nStart a read-only transaction on the data source.\nGeneric tests we can instantiate for all the status data …\nPersistent storage for data sources.\nUpdate query state based on a new consensus event.\nStart an atomic transaction on the data source.\nA provider which can be used as a fetcher by the …\nBuilder for FetchingDataSource with configuration.\nThe most basic kind of data source.\nBuild a FetchingDataSource with these options.\nBuild a FetchingDataSource with the given storage and …\nConnect to a remote database.\nCreate a new FileSystemDataSource with storage at path.\nCreate a new FileSystemDataSource using a persistent …\nRun without proactive fetching.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nConstruct a new builder with the given storage and fetcher …\nOpen an existing FileSystemDataSource from storage at path.\nOpen an existing FileSystemDataSource using a persistent …\nAdvance the version of the persistent store without …\nAdd a delay between active fetches in proactive scans.\nAdds a delay between chunk fetches during proactive scans.\nSet the interval (denominated in minor scans) between …\nSet the offset (denominated in minor scans) before the …\nSet the time interval between minor proactive fetching …\nSet the number of items to process at a time when scanning …\nSet the number of items to process at a time when loading …\nSet the maximum delay between retries of fetches.\nSet the maximum delay between retries of fetches.\nA data source for the APIs provided in this crate, backed …\nCreate a new FileSystemDataSource with storage at path.\nCreate a new FileSystemDataSource using a persistent …\nOpen an existing FileSystemDataSource from storage at path.\nOpen an existing FileSystemDataSource using a persistent …\nAdvance the version of the persistent store without …\nThe Error type, a wrapper around a dynamic error type.\nRepresents a schema migration to be run on the database, …\nPostgreSQL database driver.\nA data source for the APIs provided in this crate, backed …\nConnect to the database, setting options on the underlying …\nConnect to the database with this config.\nConnect to a remote database.\nEmbed migrations from the given directory into the current …\nPersistent storage for a HotShot blockchain.\nAn interface for querying Data and Statistics from the …\nThis trait defines methods that a data source should …\nget_block_detail is a method that retrieves the details of …\nget_block_summaries is a method that retrieves a list of …\nget_explorer_summary is a method that retrieves a summary …\nget_search_results is a method that retrieves the results …\nget_transaction_detail is a method that retrieves the …\nget_transaction_summaries is a method that retrieves a …\nSearch the database for missing objects and generate a …\nStorage for the APIs provided in this crate, backed by a …\nCreate a new FileSystemStorage with storage at path.\nCreate a new FileSystemStorage using a persistent storage …\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nOpen an existing FileSystemStorage from storage at path.\nOpen an existing FileSystemStorage using a persistent …\nAdvance the version of the persistent store without …\nMock storage implementation which doesn’t actually store …\nReturns the argument unchanged.\nReturns the argument unchanged.\nCalls U::from(self).\nCalls U::from(self).\nEither Postgres or no storage.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nNumber of blocks to remove in a single pruning operation.\nReturns the argument unchanged.\nPruning interval\nCalls U::from(self).\nMaximum disk usage (in basis points).\nMinimum data retention period\nDisk space threshold (in bytes).\nTarget data retention period\nThe concrete type used as a buffer for arguments while …\nThe concrete Arguments implementation for this database.\nThe concrete Column implementation for this database.\nPostgres client config.\nThe concrete Connection implementation for this database.\nA database driver.\nThe concrete database backing a SQL data source.\nThe Error type, a wrapper around a dynamic error type.\nA type that contains or can provide a database connection …\nA collection of parameters with a statically known length.\nRepresents a schema migration to be run on the database, …\nThe display name for this database driver.\nA collection of parameters which can be bound to a SQL …\nPostgreSQL database driver.\nHelper type for programatically constructing queries.\nThe concrete QueryResult implementation for this database.\nMarker type indicating a transaction with read-only access …\nThe concrete Row implementation for this database.\nStorage for the APIs provided in this crate, backed by a …\nSqlite database driver.\nThe concrete Statement implementation for this database.\nAn atomic SQL transaction.\nThe concrete TransactionManager implementation for this …\nTrait for marker types indicating what type of access a …\nThe concrete TypeInfo implementation for this database.\nThe schemes for database URLs that should match this …\nThe concrete type used to hold an owned copy of the …\nThe concrete type used to hold a reference to the …\nMarker type indicating a transaction with read-write …\nGet the timestamp from when the Migration was applied. None…\nDisable pruning and reconstruct previously pruned data.\nGet the backtrace for this Error.\nAdd an argument and return its name as a formal parameter …\nConvert range bounds to a SQL WHERE clause constraining a …\nConnect to the database, setting options on the underlying …\nAn iterator of the chain of source errors contained by …\nGet the Migration checksum. Checksum is formed from the …\nConnect to the database with this config.\nConnect to a remote database.\nSet the maximum lifetime of a connection.\nWrap the error value with additional context.\nSet the name of the database to connect to.\nThe migrations requied to build the default schema for …\nAttempt to downcast the error object to a concrete type.\nDowncast this error object by mutable reference.\nDowncast this error object by reference.\nExecute the query and return the total number of rows …\nExecute the query and return the total number of rows …\nExecute multiple queries and return the rows affected from …\nExecute multiple queries and return the rows affected from …\nExecute a statement that is expected to modify at least …\nExecute a statement that is expected to modify at least …\nExecute a statement that is expected to modify exactly one …\nExecute a statement that is expected to modify exactly one …\nExecute the query and return the generated results as a …\nExecute the query and return the generated results as a …\nExecute the query and return all the generated results, …\nExecute the query and return all the generated results, …\nExecute multiple queries and return the generated results …\nExecute the query and returns exactly one row.\nExecute the query and returns exactly one row.\nExecute the query and returns at most one row.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nRetreives a Merkle path from the database\nConstruct a SQL WHERE clause which filters for a header …\nSet the hostname of the database server.\nSet the maximum idle time of a connection.\nEmbed the contents of a directory in your crate.\nEmbed migrations from the given directory into the current …\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nReturns true if E is the type held by this error object.\nLoad a header from storage.\nSet the maximum number of connections to maintain at any …\nAdd custom migrations to run when connecting to the …\nSet the minimum number of connections to maintain at any …\nCreate a new error object from a printable error message.\nGet the Migration Name\nCreate a new error object from any error type.\nSkip all migrations when connecting to the database.\nSet a password for connecting to the database.\nSet the port on which to connect to the database.\nGet the Prefix\nPrepare the SQL query to inspect the type information of …\nPrepare the SQL query to inspect the type information of …\nPrepare the SQL query, with parameter type information, to …\nNote: The prune operation may not immediately free up …\nEnable pruning with a given configuration.\nFinalize the query with a constructed SQL statement.\nFinalize the query with a constructed SQL statement and a …\nReset the schema on connection.\nThe lowest level cause of this error — this error’s …\nSet the name of the schema to use for queries.\nUse TLS for an encrypted connection to the database.\nCreate an unapplied migration, name and version are parsed …\nSet the DB user to connect as.\nGet the Migration version\nReturns the argument unchanged.\nReturns the argument unchanged.\nCalls U::from(self).\nCalls U::from(self).\nBalanceAmount is a type that represents a general balance …\nBlockDetail is a struct that represents the details of a …\nBlockDetailResponse is a struct that represents the …\nBlockIdentifier is an enum that represents multiple ways …\nBlockRange is a struct that represents a range for a …\nBlockSummary is a struct that represents a summary …\nBlockSummaryResponse is a struct that represents the …\nCurrencyCode represents an enumeration of all …\nCurrencyMismatchError is an error that occurs when two …\nError is an enum that represents the various errors that …\nAn interface for querying Data and Statistics from the …\nExplorerHeader is a trait that represents certain …\nExplorerHistograms provides a series of data points that …\nExplorerSummary is a struct that represents an at-a-glance …\nExplorerSummaryResponse is a struct that represents the …\nExplorerTransaction is a trait that allows the Explorer …\nFeeAttribution represents a specific attribution of fees …\nGenesisOverview provides a summary overview of the block …\nGetBlockDetailError represents an error that has occurred …\nGetBlockSummariesError represents an error that has …\nGetBlockSummariesRequest is a struct that represents an …\nGetExplorerSummaryError represents an error that has …\nGetSearchResultsError represents an error that has …\nGetTransactionDetailError represents an error that has …\nGetTransactionSummariesError represents an error that has …\nGetTransactionSummariesRequest is a struct that represents …\nInvalidCurrencyCodeError is an error that occurs when an …\nMonetaryValues is a struct that paris a CurrencyCode with …\nNamespaceId is a type that represents the id of a …\nNamespaceId is a type that represents the id of a …\nProposerId is a type that represents the proposer id of …\nSearchResult is a struct that represents the results of …\nSearchResultResponse is a struct that represents the …\nTimestamp represents a specific point in time that has a …\nTimestampConversionError represents an error that has …\nTransactionDetail is a struct that represents the details …\nTransactionDetailResponse is a struct that represents the …\nTransactionIdentifier is an enum that represents multiple …\nTransactionRange is a struct that represents a range for a …\nTransactionSummariesResponse is a struct that represents …\nTransactionSummary is a struct that represents a summary …\nTransactionSummaryFilter represents the various filters …\nWalletAddress is a type that represents the address of a …\nadd attempts to add the two MonetaryValues together. This …\nbtc is a convenience function to create a MonetaryValue …\ndefine_api is a function that defines the API endpoints …\ndeserialize attempts to convert a string into a …\ndeserialize converts a string representation of a RFC3339 …\nesp is a convenience function to create a MonetaryValue …\neth is a convenience function to create a MonetaryValue …\nThe wallet address of the fee info account contained …\nThe balance amount of the fee info contained within the …\nfmt formats the error into a human readable string\nfmt formats the error into a human readable string\nfmt formats the currency code into a human readable string\nfmt formats the MonetaryValue into a human readable …\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nfrom converts an i128 into a MonetaryValue with the USD …\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nget_block_detail is a method that retrieves the details of …\nget_block_summaries is a method that retrieves a list of …\nget_explorer_summary is a method that retrieves a summary …\nget_search_results is a method that retrieves the results …\nget_transaction_detail is a method that retrieves the …\nget_transaction_summaries is a method that retrieves a …\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nA collection of namespace ids that are contained within …\nnew creates a new MonetaryValue instance with the given …\nThe proposer id of the block as stored within the block …\nThe balance amount of the reward for constructing the …\nserialize converts the error into a struct representation\nserialize converts the error into a struct representation\nserialize converts the MonetaryValue into a String …\nserialize converts the timestamp into a string …\nsignificant_digits represents the total number of …\nsub attempts to subtract the two MonetaryValues together. …\nusd is a convenience function to create a MonetaryValue …\nA callback to process the result of a request.\nManagement of concurrent requests to fetch resources.\nA callback to process the result of a request.\nReturns the argument unchanged.\nCalls U::from(self).\nAsynchronous fetching from external data availability …\nRequests for fetching resources.\nFetch a resource, if it is not already being fetched.\nAdaptor combining multiple data availability providers.\nTrivial Provider where fetching always fails.\nA provider which is able to satisfy requests for data of …\nData availability provider backed by another instance of …\nAdaptor to add test-only functionality to an existing …\nDelay fetch requests until unblock.\nCause subsequent requests to fail.\nFetch a resource.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nAllow blocked fetch requests to proceed.\nStop requests from failing as a result of a previous call …\nAdd a sub-provider which fetches blocks.\nAdd a sub-provider which fetches leaves.\nAdd a sub-provider which fetches both blocks and leaves.\nAdd a sub-provider which fetches VID common data.\nA request for a leaf with a given height.\nA request for a payload with a given commitment.\nA request for a resource.\nThe type of resource that will be returned as a successful …\nA request for VID common data.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nThis trait should be implemented by the MerkleTree that …\nThis trait defines methods that a data source should …\nSnapshot can be queried by block height (index) or merkle …\nThis trait defines methods for updating the storage with …\nAdditional API specification files to merge with …\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nRetrieves the field in the header containing the Merkle …\nInsert a forgotten path into the tree.\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nRetrieves the name of the state being queried.\nGet the height of the tree\nA Counter metric.\nA CounterFamily metric.\nA Gauge metric.\nA GaugeFamily metric.\nA Histogram metric.\nA HistogramFamily metric.\nA Prometheus-based implementation of a Metrics registry.\nA TextFamily metric.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nGet a gauge family in this sub-group by name.\nGet a counter in this sub-group by name.\nGet a counter family in this sub-group by name.\nGet a gauge in this sub-group by name.\nGet a histogram in this sub-group by name.\nGet a histogram family in this sub-group by name.\nGet a (possibly nested) subgroup of this group by its path.\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nSNAFU context selector for the Error::Custom variant\nSNAFU context selector for the Error::Query variant\nSNAFU context selector for the Error::QueryVid variant\nSNAFU context selector for the Error::QueryWindow variant\nSNAFU context selector for the Error::Request variant\nResponse to a /:resource/window query.\nConsume the selector and return the associated error\nAdditional API specification files to merge with …\nConsume the selector and return a Result with the …\nReturns the argument unchanged.\nReturns the argument unchanged.\nThe block height of the block that starts the window.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nSearch the database for missing objects and generate a …\nAdditional API specification files to merge with …\nReturns the argument unchanged.\nReturns the argument unchanged.\nCalls U::from(self).\nCalls U::from(self).\nA background task which is cancelled on Drop\nA task handle which can be joined, but is cancelled on Drop\nReturns the argument unchanged.\nReturns the argument unchanged.\nCalls U::from(self).\nCalls U::from(self).\nWait for the task to complete and get its output.\nSpawn a background task, which will be cancelled when …\nSpawn a task, which will be cancelled when dropped.\nBacking storage for the data source.\nReturns the argument unchanged.\nCalls U::from(self).\nSetup runs after setting up the network but before …\nA type alias for the mock base version\nThe block header to append\nBlock number.\nFast commitment for builder verification\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nPer spec, justification\nblock metdata\nVID commitment to the payload.\nPossible timeout or view sync certificate.\nrandom\nshould_return_err is a testing utility to validate …\nTimestamp when this header was created.\nList of transactions.\nPossible upgrade certificate, which the leader may …\nThe URL of the builder to reach out to.\nCurView from leader when proposing leaf\nTypes which have a notion of “height” within a chain.") \ No newline at end of file +searchState.loadedDescShard("hotshot_query_service", 0, "The HotShot Query Service is a minimal, generic query …\nRead-only wrapper for API state which does not require …\nContains the error value\nThere was an error while trying to fetch the requested …\nSNAFU context selector for the QueryError::Error variant\nThis is the consensus-internal analogous concept to a …\nThe requested resource exists but is not currently …\nSNAFU context selector for the QueryError::Missing variant\nThe requested resource does not exist or is not known to …\nSNAFU context selector for the QueryError::NotFound variant\nContains the success value\nA reference to a T which can be resolved into a whole T.\nItem within a Payload.\nVID commitment type\nVID common type\nVID share type\nQueries for HotShot chain state.\nThe block header contained in this leaf.\nGet a mutable reference to the block header contained in …\nOptional block payload.\nConsume the selector and return the associated error\nConsume the selector and return the associated error\nConsume the selector and return the associated error\nCalculate the leaf commitment, which is gated on the …\nGet a commitment to the underlying object.\nPersistent storage and sources of data consumed by APIs.\nValidate that a leaf has the right upgrade certificate to …\nConsume the selector and return a Result with the …\nConsume the selector and return a Result with the …\nConsume the selector and return a Result with the …\nFetching missing data from remote providers.\nFill this leaf with the block payload.\nFill this leaf with the block payload, without checking …\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nConstructs a leaf from a given quorum proposal.\nCreate a new leaf from its components.\nHeight of this leaf in the chain.\nEmbed migrations from the given directory into the current …\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nThe QC linking this leaf to its parent in the chain.\nApi for querying merklized state\nA node’s view of a HotShot chain\nCommitment to this leaf’s parent.\nA commitment to the block payload contained in this leaf.\nRun an instance of the HotShot Query service with no …\nQueries for node-specific state and uncommitted data.\nAsync task utilites.\nGet the underlying object if it is available without …\nCommon functionality provided by types used in this crate.\nThe QC linking this leaf to its parent in the chain.\nTime when this leaf was created.\nAn interface for querying a HotShot blockchain.\nA block hash is the hash of the block header.\nSNAFU context selector for the Error::Custom variant\nAn in-progress request to fetch some data.\nSNAFU context selector for the Error::FetchBlock variant\nSNAFU context selector for the Error::FetchLeaf variant\nSNAFU context selector for the Error::FetchTransaction …\nA proof that a certain transaction exists in the block.\nSNAFU context selector for the …\nEnumerate the transactions in this block.\nA block payload whose contents (e.g. individual …\nSNAFU context selector for the Error::Request variant\nAn index which can be used to efficiently retrieve a …\nThe hash of the block containing this transaction.\nThe height of the block containing this transaction.\nConsume the selector and return the associated error\nConsume the selector and return the associated error\nConsume the selector and return the associated error\nConsume the selector and return the associated error\nConsume the selector and return the associated error\nGet the index of the transaction with a given hash, if it …\nGet the index of the transaction with a given hash, if it …\nConvert this Fetch to a Result with the provided error …\nEnumerate the transactions in the block with their indices.\nEnumerate the transactions in the block with their indices.\nAdditional API specification files to merge with …\nConsume the selector and return a Result with the …\nConsume the selector and return a Result with the …\nConsume the selector and return a Result with the …\nConsume the selector and return a Result with the …\nConsume the selector and return a Result with the …\nTimeout for failing requests due to missing data.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the transaction with the given hash.\nThe hash of this transaction.\nThe (0-based) position of this transaction within its …\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nWhether this block is empty of transactions.\nWhether this block is empty of transactions.\nList the transaction indices in the block.\nThe number of transactions in the block.\nTransform the result of this fetch.\nCollect information about a Leaf.\nGet the index of the nth transaction.\nGet the index of the nth transaction.\nGet the nth transaction.\nGet the nth transaction.\nGet the nth transaction, along with an inclusion proof.\nGet the nth transaction, along with an inclusion proof.\nGet an inclusion proof for a transaction with a given …\nGet an inclusion proof for a transaction with a given …\nA proof of inclusion of this transaction in its block.\nWait for the data to become available, if it is not …\nGet a transaction by its block-specific index.\nGet a transaction by its block-specific index.\nThe underlying transaction data.\nGet the transaction with a given hash, if it is in the …\nGet the transaction with a given hash, if it is in the …\nGet the transaction with a given hash, if it is in the …\nGet the transaction with a given hash, if it is in the …\nGet a transaction by its block-specific index, along with …\nGet the requested data if it is available immediately.\nConvert this Fetch to a Result with the provided error …\nWait for the requested data to become available, but only …\nWrapper to add extensibility to an existing data source.\nA minimal data source for the status API provided in this …\nA unit of atomicity for updating a shared data sourec.\nA transaction which can read and modify the data source.\nAn extension trait for types which implement the update …\nA data source with an atomic transaction-based …\nGeneric tests we can instantiate for all the availability …\nAsynchronous retrieval of missing data.\nReturns the argument unchanged.\nReturns the argument unchanged.\nAccess the underlying data source.\nMutably access the underlying data source.\nCalls U::from(self).\nCalls U::from(self).\nGeneric tests we can instantiate for all the node data …\nGeneric tests we can instantiate for any data source with …\nStart a read-only transaction on the data source.\nGeneric tests we can instantiate for all the status data …\nPersistent storage for data sources.\nUpdate query state based on a new consensus event.\nStart an atomic transaction on the data source.\nA provider which can be used as a fetcher by the …\nBuilder for FetchingDataSource with configuration.\nThe most basic kind of data source.\nBuild a FetchingDataSource with these options.\nBuild a FetchingDataSource with the given storage and …\nConnect to a remote database.\nCreate a new FileSystemDataSource with storage at path.\nCreate a new FileSystemDataSource using a persistent …\nRun without proactive fetching.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nConstruct a new builder with the given storage and fetcher …\nOpen an existing FileSystemDataSource from storage at path.\nOpen an existing FileSystemDataSource using a persistent …\nAdvance the version of the persistent store without …\nAdd a delay between active fetches in proactive scans.\nAdds a delay between chunk fetches during proactive scans.\nSet the interval (denominated in minor scans) between …\nSet the offset (denominated in minor scans) before the …\nSet the time interval between minor proactive fetching …\nSet the number of items to process at a time when scanning …\nSet the number of items to process at a time when loading …\nSet the maximum delay between retries of fetches.\nSet the maximum delay between retries of fetches.\nA data source for the APIs provided in this crate, backed …\nCreate a new FileSystemDataSource with storage at path.\nCreate a new FileSystemDataSource using a persistent …\nOpen an existing FileSystemDataSource from storage at path.\nOpen an existing FileSystemDataSource using a persistent …\nAdvance the version of the persistent store without …\nThe Error type, a wrapper around a dynamic error type.\nRepresents a schema migration to be run on the database, …\nPostgreSQL database driver.\nA data source for the APIs provided in this crate, backed …\nConnect to the database, setting options on the underlying …\nConnect to the database with this config.\nConnect to a remote database.\nEmbed migrations from the given directory into the current …\nPersistent storage for a HotShot blockchain.\nAn interface for querying Data and Statistics from the …\nThis trait defines methods that a data source should …\nget_block_detail is a method that retrieves the details of …\nget_block_summaries is a method that retrieves a list of …\nget_explorer_summary is a method that retrieves a summary …\nget_search_results is a method that retrieves the results …\nget_transaction_detail is a method that retrieves the …\nget_transaction_summaries is a method that retrieves a …\nSearch the database for missing objects and generate a …\nStorage for the APIs provided in this crate, backed by a …\nCreate a new FileSystemStorage with storage at path.\nCreate a new FileSystemStorage using a persistent storage …\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nOpen an existing FileSystemStorage from storage at path.\nOpen an existing FileSystemStorage using a persistent …\nAdvance the version of the persistent store without …\nMock storage implementation which doesn’t actually store …\nReturns the argument unchanged.\nReturns the argument unchanged.\nCalls U::from(self).\nCalls U::from(self).\nEither Postgres or no storage.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nNumber of blocks to remove in a single pruning operation.\nReturns the argument unchanged.\nPruning interval\nCalls U::from(self).\nMaximum disk usage (in basis points).\nMinimum data retention period\nDisk space threshold (in bytes).\nTarget data retention period\nThe concrete type used as a buffer for arguments while …\nThe concrete Arguments implementation for this database.\nThe concrete Column implementation for this database.\nPostgres client config.\nThe concrete Connection implementation for this database.\nA database driver.\nThe concrete database backing a SQL data source.\nThe Error type, a wrapper around a dynamic error type.\nA type that contains or can provide a database connection …\nA collection of parameters with a statically known length.\nRepresents a schema migration to be run on the database, …\nThe display name for this database driver.\nA collection of parameters which can be bound to a SQL …\nPostgreSQL database driver.\nHelper type for programatically constructing queries.\nThe concrete QueryResult implementation for this database.\nMarker type indicating a transaction with read-only access …\nThe concrete Row implementation for this database.\nStorage for the APIs provided in this crate, backed by a …\nSqlite database driver.\nThe concrete Statement implementation for this database.\nAn atomic SQL transaction.\nThe concrete TransactionManager implementation for this …\nTrait for marker types indicating what type of access a …\nThe concrete TypeInfo implementation for this database.\nThe schemes for database URLs that should match this …\nThe concrete type used to hold an owned copy of the …\nThe concrete type used to hold a reference to the …\nMarker type indicating a transaction with read-write …\nGet the timestamp from when the Migration was applied. None…\nDisable pruning and reconstruct previously pruned data.\nGet the backtrace for this Error.\nAdd an argument and return its name as a formal parameter …\nConvert range bounds to a SQL WHERE clause constraining a …\nConnect to the database, setting options on the underlying …\nAn iterator of the chain of source errors contained by …\nGet the Migration checksum. Checksum is formed from the …\nConnect to the database with this config.\nConnect to a remote database.\nSet the maximum lifetime of a connection.\nWrap the error value with additional context.\nSet the name of the database to connect to.\nThe migrations requied to build the default schema for …\nAttempt to downcast the error object to a concrete type.\nDowncast this error object by mutable reference.\nDowncast this error object by reference.\nExecute the query and return the total number of rows …\nExecute the query and return the total number of rows …\nExecute multiple queries and return the rows affected from …\nExecute multiple queries and return the rows affected from …\nExecute a statement that is expected to modify at least …\nExecute a statement that is expected to modify at least …\nExecute a statement that is expected to modify exactly one …\nExecute a statement that is expected to modify exactly one …\nExecute the query and return the generated results as a …\nExecute the query and return the generated results as a …\nExecute the query and return all the generated results, …\nExecute the query and return all the generated results, …\nExecute multiple queries and return the generated results …\nExecute the query and returns exactly one row.\nExecute the query and returns exactly one row.\nExecute the query and returns at most one row.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nRetreives a Merkle path from the database\nConstruct a SQL WHERE clause which filters for a header …\nSet the hostname of the database server.\nSet the maximum idle time of a connection.\nEmbed the contents of a directory in your crate.\nEmbed migrations from the given directory into the current …\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nReturns true if E is the type held by this error object.\nLoad a header from storage.\nSet the maximum number of connections to maintain at any …\nAdd custom migrations to run when connecting to the …\nSet the minimum number of connections to maintain at any …\nCreate a new error object from a printable error message.\nGet the Migration Name\nCreate a new error object from any error type.\nSkip all migrations when connecting to the database.\nSet a password for connecting to the database.\nSet the port on which to connect to the database.\nGet the Prefix\nPrepare the SQL query to inspect the type information of …\nPrepare the SQL query to inspect the type information of …\nPrepare the SQL query, with parameter type information, to …\nNote: The prune operation may not immediately free up …\nEnable pruning with a given configuration.\nFinalize the query with a constructed SQL statement.\nFinalize the query with a constructed SQL statement and a …\nReset the schema on connection.\nThe lowest level cause of this error — this error’s …\nSet the name of the schema to use for queries.\nUse TLS for an encrypted connection to the database.\nCreate an unapplied migration, name and version are parsed …\nSet the DB user to connect as.\nGet the Migration version\nReturns the argument unchanged.\nReturns the argument unchanged.\nCalls U::from(self).\nCalls U::from(self).\nBalanceAmount is a type that represents a general balance …\nBlockDetail is a struct that represents the details of a …\nBlockDetailResponse is a struct that represents the …\nBlockIdentifier is an enum that represents multiple ways …\nBlockRange is a struct that represents a range for a …\nBlockSummary is a struct that represents a summary …\nBlockSummaryResponse is a struct that represents the …\nCurrencyCode represents an enumeration of all …\nCurrencyMismatchError is an error that occurs when two …\nError is an enum that represents the various errors that …\nAn interface for querying Data and Statistics from the …\nExplorerHeader is a trait that represents certain …\nExplorerHistograms provides a series of data points that …\nExplorerSummary is a struct that represents an at-a-glance …\nExplorerSummaryResponse is a struct that represents the …\nExplorerTransaction is a trait that allows the Explorer …\nFeeAttribution represents a specific attribution of fees …\nGenesisOverview provides a summary overview of the block …\nGetBlockDetailError represents an error that has occurred …\nGetBlockSummariesError represents an error that has …\nGetBlockSummariesRequest is a struct that represents an …\nGetExplorerSummaryError represents an error that has …\nGetSearchResultsError represents an error that has …\nGetTransactionDetailError represents an error that has …\nGetTransactionSummariesError represents an error that has …\nGetTransactionSummariesRequest is a struct that represents …\nInvalidCurrencyCodeError is an error that occurs when an …\nMonetaryValues is a struct that paris a CurrencyCode with …\nNamespaceId is a type that represents the id of a …\nNamespaceId is a type that represents the id of a …\nProposerId is a type that represents the proposer id of …\nSearchResult is a struct that represents the results of …\nSearchResultResponse is a struct that represents the …\nTimestamp represents a specific point in time that has a …\nTimestampConversionError represents an error that has …\nTransactionDetail is a struct that represents the details …\nTransactionDetailResponse is a struct that represents the …\nTransactionIdentifier is an enum that represents multiple …\nTransactionRange is a struct that represents a range for a …\nTransactionSummariesResponse is a struct that represents …\nTransactionSummary is a struct that represents a summary …\nTransactionSummaryFilter represents the various filters …\nWalletAddress is a type that represents the address of a …\nadd attempts to add the two MonetaryValues together. This …\nbtc is a convenience function to create a MonetaryValue …\ndefine_api is a function that defines the API endpoints …\ndeserialize attempts to convert a string into a …\ndeserialize converts a string representation of a RFC3339 …\nesp is a convenience function to create a MonetaryValue …\neth is a convenience function to create a MonetaryValue …\nThe wallet address of the fee info account contained …\nThe balance amount of the fee info contained within the …\nfmt formats the error into a human readable string\nfmt formats the error into a human readable string\nfmt formats the currency code into a human readable string\nfmt formats the MonetaryValue into a human readable …\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nfrom converts an i128 into a MonetaryValue with the USD …\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nget_block_detail is a method that retrieves the details of …\nget_block_summaries is a method that retrieves a list of …\nget_explorer_summary is a method that retrieves a summary …\nget_search_results is a method that retrieves the results …\nget_transaction_detail is a method that retrieves the …\nget_transaction_summaries is a method that retrieves a …\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nA collection of namespace ids that are contained within …\nnew creates a new MonetaryValue instance with the given …\nThe proposer id of the block as stored within the block …\nThe balance amount of the reward for constructing the …\nserialize converts the error into a struct representation\nserialize converts the error into a struct representation\nserialize converts the MonetaryValue into a String …\nserialize converts the timestamp into a string …\nsignificant_digits represents the total number of …\nsub attempts to subtract the two MonetaryValues together. …\nusd is a convenience function to create a MonetaryValue …\nA callback to process the result of a request.\nManagement of concurrent requests to fetch resources.\nA callback to process the result of a request.\nReturns the argument unchanged.\nCalls U::from(self).\nAsynchronous fetching from external data availability …\nRequests for fetching resources.\nFetch a resource, if it is not already being fetched.\nAdaptor combining multiple data availability providers.\nTrivial Provider where fetching always fails.\nA provider which is able to satisfy requests for data of …\nData availability provider backed by another instance of …\nAdaptor to add test-only functionality to an existing …\nDelay fetch requests until unblock.\nCause subsequent requests to fail.\nFetch a resource.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nAllow blocked fetch requests to proceed.\nStop requests from failing as a result of a previous call …\nAdd a sub-provider which fetches blocks.\nAdd a sub-provider which fetches leaves.\nAdd a sub-provider which fetches both blocks and leaves.\nAdd a sub-provider which fetches VID common data.\nA request for a leaf with a given height.\nA request for a payload with a given commitment.\nA request for a resource.\nThe type of resource that will be returned as a successful …\nA request for VID common data.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nThis trait should be implemented by the MerkleTree that …\nThis trait defines methods that a data source should …\nSnapshot can be queried by block height (index) or merkle …\nThis trait defines methods for updating the storage with …\nAdditional API specification files to merge with …\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nRetrieves the field in the header containing the Merkle …\nInsert a forgotten path into the tree.\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nRetrieves the name of the state being queried.\nGet the height of the tree\nA Counter metric.\nA CounterFamily metric.\nA Gauge metric.\nA GaugeFamily metric.\nA Histogram metric.\nA HistogramFamily metric.\nA Prometheus-based implementation of a Metrics registry.\nA TextFamily metric.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nGet a gauge family in this sub-group by name.\nGet a counter in this sub-group by name.\nGet a counter family in this sub-group by name.\nGet a gauge in this sub-group by name.\nGet a histogram in this sub-group by name.\nGet a histogram family in this sub-group by name.\nGet a (possibly nested) subgroup of this group by its path.\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nSNAFU context selector for the Error::Custom variant\nSNAFU context selector for the Error::Query variant\nSNAFU context selector for the Error::QueryVid variant\nSNAFU context selector for the Error::QueryWindow variant\nSNAFU context selector for the Error::Request variant\nResponse to a /:resource/window query.\nConsume the selector and return the associated error\nAdditional API specification files to merge with …\nConsume the selector and return a Result with the …\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nThe block height of the block that starts the window.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nSearch the database for missing objects and generate a …\nAdditional API specification files to merge with …\nReturns the argument unchanged.\nReturns the argument unchanged.\nCalls U::from(self).\nCalls U::from(self).\nA background task which is cancelled on Drop\nA task handle which can be joined, but is cancelled on Drop\nReturns the argument unchanged.\nReturns the argument unchanged.\nCalls U::from(self).\nCalls U::from(self).\nWait for the task to complete and get its output.\nSpawn a background task, which will be cancelled when …\nSpawn a task, which will be cancelled when dropped.\nBacking storage for the data source.\nReturns the argument unchanged.\nCalls U::from(self).\nSetup runs after setting up the network but before …\nA type alias for the mock base version\nThe block header to append\nBlock number.\nFast commitment for builder verification\nReturns the argument unchanged.\nReturns the argument unchanged.\nReturns the argument unchanged.\nCalls U::from(self).\nCalls U::from(self).\nCalls U::from(self).\nPer spec, justification\nblock metdata\nVID commitment to the payload.\nPossible timeout or view sync certificate.\nrandom\nshould_return_err is a testing utility to validate …\nTimestamp when this header was created.\nList of transactions.\nPossible upgrade certificate, which the leader may …\nThe URL of the builder to reach out to.\nCurView from leader when proposing leaf\nTypes which have a notion of “height” within a chain.") \ No newline at end of file diff --git a/src/hotshot_query_service/data_source/extension.rs.html b/src/hotshot_query_service/data_source/extension.rs.html index 3eb2fdbe6..9bd91a789 100644 --- a/src/hotshot_query_service/data_source/extension.rs.html +++ b/src/hotshot_query_service/data_source/extension.rs.html @@ -459,6 +459,11 @@ 459 460 461 +462 +463 +464 +465 +466
    // Copyright (c) 2022 Espresso Systems (espressosys.com)
     // This file is part of the HotShot Query Service library.
     //
    @@ -485,7 +490,7 @@
         },
         metrics::PrometheusMetrics,
         node::{NodeDataSource, SyncStatus, TimeWindowQueryData, WindowStart},
    -    status::StatusDataSource,
    +    status::{HasMetrics, StatusDataSource},
         Header, Payload, QueryResult, Transaction, VidShare,
     };
     use async_trait::async_trait;
    @@ -731,6 +736,15 @@
         }
     }
     
    +impl<D, U> HasMetrics for ExtensibleDataSource<D, U>
    +where
    +    D: HasMetrics,
    +{
    +    fn metrics(&self) -> &PrometheusMetrics {
    +        self.data_source.metrics()
    +    }
    +}
    +
     #[async_trait]
     impl<D, U> StatusDataSource for ExtensibleDataSource<D, U>
     where
    @@ -740,10 +754,6 @@
         async fn block_height(&self) -> QueryResult<usize> {
             self.data_source.block_height().await
         }
    -
    -    fn metrics(&self) -> &PrometheusMetrics {
    -        self.data_source.metrics()
    -    }
     }
     
     #[async_trait]
    diff --git a/src/hotshot_query_service/data_source/fetching.rs.html b/src/hotshot_query_service/data_source/fetching.rs.html
    index f3771cf3c..fbde8620d 100644
    --- a/src/hotshot_query_service/data_source/fetching.rs.html
    +++ b/src/hotshot_query_service/data_source/fetching.rs.html
    @@ -1353,6 +1353,9 @@
     1353
     1354
     1355
    +1356
    +1357
    +1358
     
    // Copyright (c) 2022 Espresso Systems (espressosys.com)
     // This file is part of the HotShot Query Service library.
     //
    @@ -1449,7 +1452,7 @@
         },
         metrics::PrometheusMetrics,
         node::{NodeDataSource, SyncStatus, TimeWindowQueryData, WindowStart},
    -    status::StatusDataSource,
    +    status::{HasMetrics, StatusDataSource},
         task::BackgroundTask,
         types::HeightIndexed,
         Header, Payload, QueryError, QueryResult, VidShare,
    @@ -1685,8 +1688,6 @@
         // implements the asynchronous fetching of a particular object. This is why it gets its own
         // type, wrapped in an [`Arc`] for easy, efficient cloning.
         fetcher: Arc<Fetcher<Types, S, P>>,
    -    // The rest of the data we need for implementing data source traits but not for fetching.
    -    metrics: PrometheusMetrics,
         // The proactive scanner task. This is only saved here so that we can cancel it on drop.
         scanner: Option<BackgroundTask>,
         pruner: Pruner<Types, S, P>,
    @@ -1779,7 +1780,6 @@
                 fetcher,
                 scanner,
                 pruner,
    -            metrics: Default::default(),
             };
     
             Ok(ds)
    @@ -1795,11 +1795,21 @@
         }
     }
     
    +impl<Types, S, P> HasMetrics for FetchingDataSource<Types, S, P>
    +where
    +    Types: NodeType,
    +    S: HasMetrics,
    +{
    +    fn metrics(&self) -> &PrometheusMetrics {
    +        self.as_ref().metrics()
    +    }
    +}
    +
     #[async_trait]
     impl<Types, S, P> StatusDataSource for FetchingDataSource<Types, S, P>
     where
         Types: NodeType,
    -    S: VersionedDataSource + Send + Sync + 'static,
    +    S: VersionedDataSource + HasMetrics + Send + Sync + 'static,
         for<'a> S::ReadOnly<'a>: NodeStorage<Types>,
         P: Send + Sync,
     {
    @@ -1809,10 +1819,6 @@
             })?;
             tx.block_height().await
         }
    -
    -    fn metrics(&self) -> &PrometheusMetrics {
    -        &self.metrics
    -    }
     }
     
     #[async_trait]
    diff --git a/src/hotshot_query_service/data_source/metrics.rs.html b/src/hotshot_query_service/data_source/metrics.rs.html
    index 47d15a445..15972697b 100644
    --- a/src/hotshot_query_service/data_source/metrics.rs.html
    +++ b/src/hotshot_query_service/data_source/metrics.rs.html
    @@ -115,6 +115,12 @@
     115
     116
     117
    +118
    +119
    +120
    +121
    +122
    +123
     
    // Copyright (c) 2022 Espresso Systems (espressosys.com)
     // This file is part of the HotShot Query Service library.
     //
    @@ -129,7 +135,11 @@
     
     #![cfg(feature = "metrics-data-source")]
     
    -use crate::{metrics::PrometheusMetrics, status::StatusDataSource, QueryError, QueryResult};
    +use crate::{
    +    metrics::PrometheusMetrics,
    +    status::{HasMetrics, StatusDataSource},
    +    QueryError, QueryResult,
    +};
     use async_trait::async_trait;
     
     /// A minimal data source for the status API provided in this crate, with no persistent storage.
    @@ -173,6 +183,12 @@
         metrics: PrometheusMetrics,
     }
     
    +impl HasMetrics for MetricsDataSource {
    +    fn metrics(&self) -> &PrometheusMetrics {
    +        &self.metrics
    +    }
    +}
    +
     #[async_trait]
     impl StatusDataSource for MetricsDataSource {
         async fn block_height(&self) -> QueryResult<usize> {
    @@ -185,10 +201,6 @@
                 .get();
             Ok(last_synced_height)
         }
    -
    -    fn metrics(&self) -> &PrometheusMetrics {
    -        &self.metrics
    -    }
     }
     
     #[cfg(any(test, feature = "testing"))]
    diff --git a/src/hotshot_query_service/data_source/storage/fs.rs.html b/src/hotshot_query_service/data_source/storage/fs.rs.html
    index 5c315594f..af38aaba4 100644
    --- a/src/hotshot_query_service/data_source/storage/fs.rs.html
    +++ b/src/hotshot_query_service/data_source/storage/fs.rs.html
    @@ -713,6 +713,21 @@
     713
     714
     715
    +716
    +717
    +718
    +719
    +720
    +721
    +722
    +723
    +724
    +725
    +726
    +727
    +728
    +729
    +730
     
    // Copyright (c) 2022 Espresso Systems (espressosys.com)
     // This file is part of the HotShot Query Service library.
     //
    @@ -742,7 +757,9 @@
             },
         },
         data_source::{update, VersionedDataSource},
    +    metrics::PrometheusMetrics,
         node::{SyncStatus, TimeWindowQueryData, WindowStart},
    +    status::HasMetrics,
         types::HeightIndexed,
         ErrorSnafu, Header, MissingSnafu, NotFoundSnafu, Payload, QueryResult, VidCommitment, VidShare,
     };
    @@ -830,6 +847,7 @@
         Payload<Types>: QueryablePayload<Types>,
     {
         inner: RwLock<FileSystemStorageInner<Types>>,
    +    metrics: PrometheusMetrics,
     }
     
     impl<Types: NodeType> PrunerConfig for FileSystemStorage<Types> where
    @@ -899,6 +917,7 @@
                     block_storage: LedgerLog::create(loader, "blocks", CACHED_BLOCKS_COUNT)?,
                     vid_storage: LedgerLog::create(loader, "vid_common", CACHED_VID_COMMON_COUNT)?,
                 }),
    +            metrics: Default::default(),
             })
         }
     
    @@ -969,6 +988,7 @@
                     vid_storage,
                     top_storage: None,
                 }),
    +            metrics: Default::default(),
             })
         }
     
    @@ -1428,4 +1448,14 @@
     }
     
     impl<T: Revert> PrunedHeightStorage for Transaction<T> {}
    +
    +impl<Types> HasMetrics for FileSystemStorage<Types>
    +where
    +    Types: NodeType,
    +    Payload<Types>: QueryablePayload<Types>,
    +{
    +    fn metrics(&self) -> &PrometheusMetrics {
    +        &self.metrics
    +    }
    +}
     

    \ No newline at end of file diff --git a/src/hotshot_query_service/data_source/storage/no_storage.rs.html b/src/hotshot_query_service/data_source/storage/no_storage.rs.html index 990b619f5..55c8876c1 100644 --- a/src/hotshot_query_service/data_source/storage/no_storage.rs.html +++ b/src/hotshot_query_service/data_source/storage/no_storage.rs.html @@ -721,6 +721,17 @@ 721 722 723 +724 +725 +726 +727 +728 +729 +730 +731 +732 +733 +734
    // Copyright (c) 2022 Espresso Systems (espressosys.com)
     // This file is part of the HotShot Query Service library.
     //
    @@ -745,7 +756,9 @@
             TransactionHash, TransactionQueryData, UpdateAvailabilityData, VidCommonQueryData,
         },
         data_source::{update, VersionedDataSource},
    +    metrics::PrometheusMetrics,
         node::{SyncStatus, TimeWindowQueryData, WindowStart},
    +    status::HasMetrics,
         types::HeightIndexed,
         Header, Payload, QueryError, QueryResult, VidShare,
     };
    @@ -765,6 +778,7 @@
         // A storage implementation must at a minimum keep track of the block height. All other
         // functionality, such as fetching of missing data, stems from that.
         height: Arc<RwLock<u64>>,
    +    metrics: PrometheusMetrics,
     }
     
     pub struct Transaction<'a> {
    @@ -816,6 +830,12 @@
     }
     impl<'a> PrunedHeightStorage for Transaction<'a> {}
     
    +impl HasMetrics for NoStorage {
    +    fn metrics(&self) -> &PrometheusMetrics {
    +        &self.metrics
    +    }
    +}
    +
     #[async_trait]
     impl<'a, Types: NodeType> AvailabilityStorage<Types> for Transaction<'a>
     where
    @@ -969,7 +989,7 @@
             fetching::provider::{NoFetching, QueryServiceProvider},
             metrics::PrometheusMetrics,
             node::NodeDataSource,
    -        status::StatusDataSource,
    +        status::{HasMetrics, StatusDataSource},
             testing::{
                 consensus::{DataSourceLifeCycle, MockNetwork},
                 mocks::{MockBase, MockTypes},
    @@ -1357,6 +1377,15 @@
             }
         }
     
    +    impl HasMetrics for DataSource {
    +        fn metrics(&self) -> &PrometheusMetrics {
    +            match self {
    +                Self::Sql(data_source) => data_source.metrics(),
    +                Self::NoStorage(data_source) => data_source.metrics(),
    +            }
    +        }
    +    }
    +
         #[async_trait]
         impl StatusDataSource for DataSource {
             async fn block_height(&self) -> QueryResult<usize> {
    @@ -1365,13 +1394,6 @@
                     Self::NoStorage(data_source) => StatusDataSource::block_height(data_source).await,
                 }
             }
    -
    -        fn metrics(&self) -> &PrometheusMetrics {
    -            match self {
    -                Self::Sql(data_source) => data_source.metrics(),
    -                Self::NoStorage(data_source) => data_source.metrics(),
    -            }
    -        }
         }
     
         #[async_trait]
    diff --git a/src/hotshot_query_service/data_source/storage/sql.rs.html b/src/hotshot_query_service/data_source/storage/sql.rs.html
    index 09c115201..9a06ff17c 100644
    --- a/src/hotshot_query_service/data_source/storage/sql.rs.html
    +++ b/src/hotshot_query_service/data_source/storage/sql.rs.html
    @@ -1183,6 +1183,20 @@
     1183
     1184
     1185
    +1186
    +1187
    +1188
    +1189
    +1190
    +1191
    +1192
    +1193
    +1194
    +1195
    +1196
    +1197
    +1198
    +1199
     
    // Copyright (c) 2022 Espresso Systems (espressosys.com)
     // This file is part of the HotShot Query Service library.
     //
    @@ -1203,11 +1217,14 @@
             update::Transaction as _,
             VersionedDataSource,
         },
    +    metrics::PrometheusMetrics,
    +    status::HasMetrics,
         QueryError, QueryResult,
     };
     use async_trait::async_trait;
     use chrono::Utc;
     use futures::future::FutureExt;
    +use hotshot_types::traits::metrics::Metrics;
     use itertools::Itertools;
     use sqlx::{
         pool::{Pool, PoolOptions},
    @@ -1235,7 +1252,7 @@
     pub use refinery::Migration;
     pub use transaction::*;
     
    -use self::migrate::Migrator;
    +use self::{migrate::Migrator, transaction::PoolMetrics};
     
     /// Embed migrations from the given directory into the current binary.
     ///
    @@ -1552,6 +1569,8 @@
     #[derive(Debug)]
     pub struct SqlStorage {
         pool: Pool<Db>,
    +    metrics: PrometheusMetrics,
    +    pool_metrics: PoolMetrics,
         pruner_cfg: Option<PrunerCfg>,
     }
     
    @@ -1634,8 +1653,11 @@
                     .await?;
             }
     
    +        let metrics = PrometheusMetrics::default();
             Ok(Self {
                 pool,
    +            pool_metrics: PoolMetrics::new(&*metrics.subgroup("sql".into())),
    +            metrics,
                 pruner_cfg: config.pruner_cfg,
             })
         }
    @@ -1651,6 +1673,12 @@
         }
     }
     
    +impl HasMetrics for SqlStorage {
    +    fn metrics(&self) -> &PrometheusMetrics {
    +        &self.metrics
    +    }
    +}
    +
     impl SqlStorage {
         async fn get_minimum_height(&self) -> QueryResult<Option<u64>> {
             let mut tx = self.read().await.map_err(|err| QueryError::Error {
    @@ -1815,11 +1843,11 @@
             Self: 'a;
     
         async fn write(&self) -> anyhow::Result<Transaction<Write>> {
    -        Transaction::new(&self.pool).await
    +        Transaction::new(&self.pool, self.pool_metrics.clone()).await
         }
     
         async fn read(&self) -> anyhow::Result<Transaction<Read>> {
    -        Transaction::new(&self.pool).await
    +        Transaction::new(&self.pool, self.pool_metrics.clone()).await
         }
     }
     
    diff --git a/src/hotshot_query_service/data_source/storage/sql/transaction.rs.html b/src/hotshot_query_service/data_source/storage/sql/transaction.rs.html
    index d32c831e9..8fc7aa2ca 100644
    --- a/src/hotshot_query_service/data_source/storage/sql/transaction.rs.html
    +++ b/src/hotshot_query_service/data_source/storage/sql/transaction.rs.html
    @@ -703,6 +703,90 @@
     703
     704
     705
    +706
    +707
    +708
    +709
    +710
    +711
    +712
    +713
    +714
    +715
    +716
    +717
    +718
    +719
    +720
    +721
    +722
    +723
    +724
    +725
    +726
    +727
    +728
    +729
    +730
    +731
    +732
    +733
    +734
    +735
    +736
    +737
    +738
    +739
    +740
    +741
    +742
    +743
    +744
    +745
    +746
    +747
    +748
    +749
    +750
    +751
    +752
    +753
    +754
    +755
    +756
    +757
    +758
    +759
    +760
    +761
    +762
    +763
    +764
    +765
    +766
    +767
    +768
    +769
    +770
    +771
    +772
    +773
    +774
    +775
    +776
    +777
    +778
    +779
    +780
    +781
    +782
    +783
    +784
    +785
    +786
    +787
    +788
    +789
     
    // Copyright (c) 2022 Espresso Systems (espressosys.com)
     // This file is part of the HotShot Query Service library.
     //
    @@ -748,7 +832,10 @@
     use derive_more::{Deref, DerefMut};
     use futures::{future::Future, stream::TryStreamExt};
     use hotshot_types::traits::{
    -    block_contents::BlockHeader, node_implementation::NodeType, EncodeBytes,
    +    block_contents::BlockHeader,
    +    metrics::{Counter, Gauge, Histogram, Metrics},
    +    node_implementation::NodeType,
    +    EncodeBytes,
     };
     use itertools::Itertools;
     use jf_merkle_tree::prelude::{MerkleNode, MerkleProof};
    @@ -756,7 +843,7 @@
     use std::{
         collections::{HashMap, HashSet},
         marker::PhantomData,
    -    time::Duration,
    +    time::{Duration, Instant},
     };
     
     pub use sqlx::Executor;
    @@ -788,6 +875,8 @@
         fn begin(
             conn: &mut <Db as Database>::Connection,
         ) -> impl Future<Output = anyhow::Result<()>> + Send;
    +
    +    fn display() -> &'static str;
     }
     
     impl TransactionMode for Write {
    @@ -796,6 +885,10 @@
                 .await?;
             Ok(())
         }
    +
    +    fn display() -> &'static str {
    +        "write"
    +    }
     }
     
     impl TransactionMode for Read {
    @@ -804,6 +897,59 @@
                 .await?;
             Ok(())
         }
    +
    +    fn display() -> &'static str {
    +        "read-only"
    +    }
    +}
    +
    +#[derive(Clone, Copy, Debug)]
    +enum CloseType {
    +    Commit,
    +    Revert,
    +    Drop,
    +}
    +
    +#[derive(Debug)]
    +struct TransactionMetricsGuard<Mode> {
    +    started_at: Instant,
    +    metrics: PoolMetrics,
    +    close_type: CloseType,
    +    _mode: PhantomData<Mode>,
    +}
    +
    +impl<Mode: TransactionMode> TransactionMetricsGuard<Mode> {
    +    fn begin(metrics: PoolMetrics) -> Self {
    +        let started_at = Instant::now();
    +        tracing::trace!(mode = Mode::display(), ?started_at, "begin");
    +        metrics.open_transactions.update(1);
    +
    +        Self {
    +            started_at,
    +            metrics,
    +            close_type: CloseType::Drop,
    +            _mode: Default::default(),
    +        }
    +    }
    +
    +    fn set_closed(&mut self, t: CloseType) {
    +        self.close_type = t;
    +    }
    +}
    +
    +impl<Mode> Drop for TransactionMetricsGuard<Mode> {
    +    fn drop(&mut self) {
    +        self.metrics
    +            .transaction_durations
    +            .add_point((self.started_at.elapsed().as_millis() as f64) / 1000.);
    +        self.metrics.open_transactions.update(-1);
    +        match self.close_type {
    +            CloseType::Commit => self.metrics.commits.add(1),
    +            CloseType::Revert => self.metrics.reverts.add(1),
    +            CloseType::Drop => self.metrics.drops.add(1),
    +        }
    +        tracing::trace!(started_at = ?self.started_at, reason = ?self.close_type, "close");
    +    }
     }
     
     /// An atomic SQL transaction.
    @@ -812,28 +958,28 @@
         #[deref]
         #[deref_mut]
         inner: sqlx::Transaction<'static, Db>,
    -    _mode: PhantomData<Mode>,
    +    metrics: TransactionMetricsGuard<Mode>,
     }
     
     impl<Mode: TransactionMode> Transaction<Mode> {
    -    pub(super) async fn new(pool: &Pool<Db>) -> anyhow::Result<Self> {
    -        let mut tx = pool.begin().await?;
    -        Mode::begin(tx.as_mut()).await?;
    -        Ok(Self {
    -            inner: tx,
    -            _mode: Default::default(),
    -        })
    +    pub(super) async fn new(pool: &Pool<Db>, metrics: PoolMetrics) -> anyhow::Result<Self> {
    +        let mut inner = pool.begin().await?;
    +        let metrics = TransactionMetricsGuard::begin(metrics);
    +        Mode::begin(inner.as_mut()).await?;
    +        Ok(Self { inner, metrics })
         }
     }
     
     impl<Mode: TransactionMode> update::Transaction for Transaction<Mode> {
    -    async fn commit(self) -> anyhow::Result<()> {
    +    async fn commit(mut self) -> anyhow::Result<()> {
             self.inner.commit().await?;
    +        self.metrics.set_closed(CloseType::Commit);
             Ok(())
         }
    -    fn revert(self) -> impl Future + Send {
    +    fn revert(mut self) -> impl Future + Send {
             async move {
                 self.inner.rollback().await.unwrap();
    +            self.metrics.set_closed(CloseType::Revert);
             }
         }
     }
    @@ -1408,4 +1554,26 @@
             Ok(Some(height as u64))
         }
     }
    +
    +#[derive(Clone, Debug)]
    +pub(super) struct PoolMetrics {
    +    open_transactions: Box<dyn Gauge>,
    +    transaction_durations: Box<dyn Histogram>,
    +    commits: Box<dyn Counter>,
    +    reverts: Box<dyn Counter>,
    +    drops: Box<dyn Counter>,
    +}
    +
    +impl PoolMetrics {
    +    pub(super) fn new(metrics: &(impl Metrics + ?Sized)) -> Self {
    +        Self {
    +            open_transactions: metrics.create_gauge("open_transactions".into(), None),
    +            transaction_durations: metrics
    +                .create_histogram("transaction_duration".into(), Some("s".into())),
    +            commits: metrics.create_counter("committed_transactions".into(), None),
    +            reverts: metrics.create_counter("reverted_transactions".into(), None),
    +            drops: metrics.create_counter("dropped_transactions".into(), None),
    +        }
    +    }
    +}
     
    \ No newline at end of file diff --git a/src/hotshot_query_service/lib.rs.html b/src/hotshot_query_service/lib.rs.html index 2facc006b..69e23ef7e 100644 --- a/src/hotshot_query_service/lib.rs.html +++ b/src/hotshot_query_service/lib.rs.html @@ -855,6 +855,9 @@ 855 856 857 +858 +859 +860
    // Copyright (c) 2022 Espresso Systems (espressosys.com)
     // This file is part of the HotShot Query Service library.
     //
    @@ -1126,7 +1129,7 @@
     //! # use hotshot_query_service::node::{
     //! #   NodeDataSource, SyncStatus, TimeWindowQueryData, WindowStart,
     //! # };
    -//! # use hotshot_query_service::status::StatusDataSource;
    +//! # use hotshot_query_service::status::{HasMetrics, StatusDataSource};
     //! # use hotshot_query_service::testing::mocks::MockTypes as AppTypes;
     //! # use std::ops::RangeBounds;
     //! # type AppQueryData = ();
    @@ -1223,15 +1226,16 @@
     //! }
     //!
     //! // Implement data source trait for status API by delegating to the underlying data source.
    +//! impl<D: HasMetrics> HasMetrics for AppState<D> {
    +//!     fn metrics(&self) -> &PrometheusMetrics {
    +//!         self.hotshot_qs.metrics()
    +//!     }
    +//! }
     //! #[async_trait]
     //! impl<D: StatusDataSource + Send + Sync> StatusDataSource for AppState<D> {
     //!     async fn block_height(&self) -> QueryResult<usize> {
     //!         self.hotshot_qs.block_height().await
     //!     }
    -//!
    -//!     fn metrics(&self) -> &PrometheusMetrics {
    -//!         self.hotshot_qs.metrics()
    -//!     }
     //! }
     //!
     //! // Implement data source traits for other modules, using additional state from AppState.
    @@ -1434,7 +1438,7 @@
             data_source::VersionedDataSource,
             metrics::PrometheusMetrics,
             node::{NodeDataSource, SyncStatus, TimeWindowQueryData, WindowStart},
    -        status::StatusDataSource,
    +        status::{HasMetrics, StatusDataSource},
             testing::{
                 consensus::MockDataSource,
                 mocks::{MockHeader, MockPayload, MockTypes},
    @@ -1574,14 +1578,16 @@
         }
     
         // Implement data source trait for status API.
    -    #[async_trait]
    +    impl HasMetrics for CompositeState {
    +        fn metrics(&self) -> &PrometheusMetrics {
    +            self.hotshot_qs.metrics()
    +        }
    +    }
    +    #[async_trait]
         impl StatusDataSource for CompositeState {
             async fn block_height(&self) -> QueryResult<usize> {
                 StatusDataSource::block_height(&self.hotshot_qs).await
             }
    -        fn metrics(&self) -> &PrometheusMetrics {
    -            self.hotshot_qs.metrics()
    -        }
         }
     
         #[async_std::test]
    diff --git a/src/hotshot_query_service/status/data_source.rs.html b/src/hotshot_query_service/status/data_source.rs.html
    index 86d6de199..e6c34d4c0 100644
    --- a/src/hotshot_query_service/status/data_source.rs.html
    +++ b/src/hotshot_query_service/status/data_source.rs.html
    @@ -73,6 +73,8 @@
     73
     74
     75
    +76
    +77
     
    // Copyright (c) 2022 Espresso Systems (espressosys.com)
     // This file is part of the HotShot Query Service library.
     //
    @@ -94,12 +96,14 @@
     use chrono::Utc;
     use hotshot_types::traits::metrics::Metrics;
     
    +pub trait HasMetrics {
    +    fn metrics(&self) -> &PrometheusMetrics;
    +}
    +
     #[async_trait]
    -pub trait StatusDataSource {
    +pub trait StatusDataSource: HasMetrics {
         async fn block_height(&self) -> QueryResult<usize>;
     
    -    fn metrics(&self) -> &PrometheusMetrics;
    -
         fn consensus_metrics(&self) -> QueryResult<PrometheusMetrics> {
             self.metrics()
                 .get_subgroup(["consensus"])
    diff --git a/trait.impl/core/panic/unwind_safe/trait.UnwindSafe.js b/trait.impl/core/panic/unwind_safe/trait.UnwindSafe.js
    index 142672d5b..b6bc90a41 100644
    --- a/trait.impl/core/panic/unwind_safe/trait.UnwindSafe.js
    +++ b/trait.impl/core/panic/unwind_safe/trait.UnwindSafe.js
    @@ -1,9 +1,9 @@
     (function() {
    -    var implementors = Object.fromEntries([["hotshot_query_service",[["impl !UnwindSafe for DataSource",1,["hotshot_query_service::data_source::storage::no_storage::testing::DataSource"]],["impl !UnwindSafe for MetricsError",1,["hotshot_query_service::metrics::MetricsError"]],["impl !UnwindSafe for NoStorage",1,["hotshot_query_service::data_source::storage::no_storage::NoStorage"]],["impl !UnwindSafe for SqlStorage",1,["hotshot_query_service::data_source::storage::sql::SqlStorage"]],["impl !UnwindSafe for MetricsDataSource",1,["hotshot_query_service::data_source::metrics::MetricsDataSource"]],["impl !UnwindSafe for CounterFamily",1,["hotshot_query_service::metrics::CounterFamily"]],["impl !UnwindSafe for GaugeFamily",1,["hotshot_query_service::metrics::GaugeFamily"]],["impl !UnwindSafe for HistogramFamily",1,["hotshot_query_service::metrics::HistogramFamily"]],["impl !UnwindSafe for PrometheusMetrics",1,["hotshot_query_service::metrics::PrometheusMetrics"]],["impl !UnwindSafe for TextFamily",1,["hotshot_query_service::metrics::TextFamily"]],["impl UnwindSafe for Error",1,["hotshot_query_service::availability::Error"]],["impl UnwindSafe for Storage",1,["hotshot_query_service::data_source::storage::no_storage::testing::Storage"]],["impl UnwindSafe for Error",1,["hotshot_query_service::error::Error"]],["impl UnwindSafe for QueryError",1,["hotshot_query_service::QueryError"]],["impl UnwindSafe for CurrencyCode",1,["hotshot_query_service::explorer::currency::CurrencyCode"]],["impl UnwindSafe for Error",1,["hotshot_query_service::explorer::Error"]],["impl UnwindSafe for GetBlockDetailError",1,["hotshot_query_service::explorer::query_data::GetBlockDetailError"]],["impl UnwindSafe for GetBlockSummariesError",1,["hotshot_query_service::explorer::query_data::GetBlockSummariesError"]],["impl UnwindSafe for GetExplorerSummaryError",1,["hotshot_query_service::explorer::query_data::GetExplorerSummaryError"]],["impl UnwindSafe for GetSearchResultsError",1,["hotshot_query_service::explorer::query_data::GetSearchResultsError"]],["impl UnwindSafe for GetTransactionDetailError",1,["hotshot_query_service::explorer::query_data::GetTransactionDetailError"]],["impl UnwindSafe for GetTransactionSummariesError",1,["hotshot_query_service::explorer::query_data::GetTransactionSummariesError"]],["impl UnwindSafe for TimestampConversionError",1,["hotshot_query_service::explorer::query_data::TimestampConversionError"]],["impl UnwindSafe for TransactionSummaryFilter",1,["hotshot_query_service::explorer::query_data::TransactionSummaryFilter"]],["impl UnwindSafe for Error",1,["hotshot_query_service::merklized_state::Error"]],["impl UnwindSafe for Error",1,["hotshot_query_service::node::Error"]],["impl UnwindSafe for Error",1,["hotshot_query_service::status::Error"]],["impl UnwindSafe for Options",1,["hotshot_query_service::availability::Options"]],["impl UnwindSafe for RequestSnafu",1,["hotshot_query_service::availability::RequestSnafu"]],["impl UnwindSafe for PrunerCfg",1,["hotshot_query_service::data_source::storage::pruning::PrunerCfg"]],["impl UnwindSafe for Pruner",1,["hotshot_query_service::data_source::storage::sql::Pruner"]],["impl UnwindSafe for Read",1,["hotshot_query_service::data_source::storage::sql::transaction::Read"]],["impl UnwindSafe for Write",1,["hotshot_query_service::data_source::storage::sql::transaction::Write"]],["impl UnwindSafe for TestMerkleTreeMigration",1,["hotshot_query_service::data_source::storage::sql::testing::TestMerkleTreeMigration"]],["impl UnwindSafe for TmpDb",1,["hotshot_query_service::data_source::storage::sql::testing::TmpDb"]],["impl UnwindSafe for CurrencyMismatchError",1,["hotshot_query_service::explorer::currency::CurrencyMismatchError"]],["impl UnwindSafe for ExplorerHistograms",1,["hotshot_query_service::explorer::query_data::ExplorerHistograms"]],["impl UnwindSafe for FeeAttribution",1,["hotshot_query_service::explorer::query_data::FeeAttribution"]],["impl UnwindSafe for GenesisOverview",1,["hotshot_query_service::explorer::query_data::GenesisOverview"]],["impl UnwindSafe for InvalidCurrencyCodeError",1,["hotshot_query_service::explorer::currency::InvalidCurrencyCodeError"]],["impl UnwindSafe for MonetaryValue",1,["hotshot_query_service::explorer::monetary_value::MonetaryValue"]],["impl UnwindSafe for Timestamp",1,["hotshot_query_service::explorer::query_data::Timestamp"]],["impl UnwindSafe for NoFetching",1,["hotshot_query_service::fetching::provider::NoFetching"]],["impl UnwindSafe for LeafRequest",1,["hotshot_query_service::fetching::request::LeafRequest"]],["impl UnwindSafe for PayloadRequest",1,["hotshot_query_service::fetching::request::PayloadRequest"]],["impl UnwindSafe for VidCommonRequest",1,["hotshot_query_service::fetching::request::VidCommonRequest"]],["impl UnwindSafe for Options",1,["hotshot_query_service::merklized_state::Options"]],["impl UnwindSafe for Counter",1,["hotshot_query_service::metrics::Counter"]],["impl UnwindSafe for Gauge",1,["hotshot_query_service::metrics::Gauge"]],["impl UnwindSafe for Histogram",1,["hotshot_query_service::metrics::Histogram"]],["impl UnwindSafe for Options",1,["hotshot_query_service::node::Options"]],["impl UnwindSafe for QuerySnafu",1,["hotshot_query_service::node::QuerySnafu"]],["impl UnwindSafe for RequestSnafu",1,["hotshot_query_service::node::RequestSnafu"]],["impl UnwindSafe for SyncStatus",1,["hotshot_query_service::node::query_data::SyncStatus"]],["impl UnwindSafe for Options",1,["hotshot_query_service::status::Options"]],["impl UnwindSafe for MissingSnafu",1,["hotshot_query_service::MissingSnafu"]],["impl UnwindSafe for NotFoundSnafu",1,["hotshot_query_service::NotFoundSnafu"]],["impl UnwindSafe for Options",1,["hotshot_query_service::Options"]],["impl UnwindSafe for BackgroundTask",1,["hotshot_query_service::task::BackgroundTask"]],["impl UnwindSafe for MockNodeImpl",1,["hotshot_query_service::testing::mocks::MockNodeImpl"]],["impl UnwindSafe for MockTypes",1,["hotshot_query_service::testing::mocks::MockTypes"]],["impl UnwindSafe for MockVersions",1,["hotshot_query_service::testing::mocks::MockVersions"]],["impl<'a> !UnwindSafe for Transaction<'a>",1,["hotshot_query_service::data_source::storage::no_storage::Transaction"]],["impl<'a, T> !UnwindSafe for Transaction<'a, T>",1,["hotshot_query_service::data_source::storage::no_storage::testing::Transaction"]],["impl<'a, Types, T> !UnwindSafe for Transaction<'a, Types, T>",1,["hotshot_query_service::data_source::fetching::notify_storage::Transaction"]],["impl<'q> !UnwindSafe for QueryBuilder<'q>",1,["hotshot_query_service::data_source::storage::sql::queries::QueryBuilder"]],["impl<D> !UnwindSafe for MockNetwork<D>",1,["hotshot_query_service::testing::consensus::MockNetwork"]],["impl<D> UnwindSafe for ApiState<D>
    where\n D: RefUnwindSafe,
    ",1,["hotshot_query_service::ApiState"]],["impl<D, U> UnwindSafe for ExtensibleDataSource<D, U>
    where\n D: UnwindSafe,\n U: UnwindSafe,
    ",1,["hotshot_query_service::data_source::extension::ExtensibleDataSource"]],["impl<DB> !UnwindSafe for Config<DB>",1,["hotshot_query_service::data_source::storage::sql::Config"]],["impl<Mode> !UnwindSafe for Transaction<Mode>",1,["hotshot_query_service::data_source::storage::sql::transaction::Transaction"]],["impl<P> !UnwindSafe for TestProvider<P>",1,["hotshot_query_service::fetching::provider::testing::TestProvider"]],["impl<T> !UnwindSafe for Fetch<T>",1,["hotshot_query_service::availability::fetch::Fetch"]],["impl<T> UnwindSafe for Transaction<T>
    where\n T: UnwindSafe,
    ",1,["hotshot_query_service::data_source::storage::fs::Transaction"]],["impl<T> UnwindSafe for TimeWindowQueryData<T>
    where\n T: UnwindSafe,
    ",1,["hotshot_query_service::node::query_data::TimeWindowQueryData"]],["impl<T> UnwindSafe for Task<T>",1,["hotshot_query_service::task::Task"]],["impl<T, C> !UnwindSafe for Fetcher<T, C>",1,["hotshot_query_service::fetching::Fetcher"]],["impl<Types> !UnwindSafe for AnyProvider<Types>",1,["hotshot_query_service::fetching::provider::any::AnyProvider"]],["impl<Types> UnwindSafe for BlockId<Types>",1,["hotshot_query_service::availability::data_source::BlockId"]],["impl<Types> UnwindSafe for LeafId<Types>",1,["hotshot_query_service::availability::data_source::LeafId"]],["impl<Types> UnwindSafe for BlockIdentifier<Types>",1,["hotshot_query_service::explorer::query_data::BlockIdentifier"]],["impl<Types> UnwindSafe for TransactionIdentifier<Types>",1,["hotshot_query_service::explorer::query_data::TransactionIdentifier"]],["impl<Types> UnwindSafe for WindowStart<Types>",1,["hotshot_query_service::node::data_source::WindowStart"]],["impl<Types> UnwindSafe for BlockQueryData<Types>
    where\n <Types as NodeType>::BlockHeader: UnwindSafe,\n <Types as NodeType>::BlockPayload: UnwindSafe,
    ",1,["hotshot_query_service::availability::query_data::BlockQueryData"]],["impl<Types> UnwindSafe for BlockSummaryQueryData<Types>
    where\n <Types as NodeType>::BlockHeader: UnwindSafe,
    ",1,["hotshot_query_service::availability::query_data::BlockSummaryQueryData"]],["impl<Types> UnwindSafe for InconsistentLeafError<Types>",1,["hotshot_query_service::availability::query_data::InconsistentLeafError"]],["impl<Types> UnwindSafe for LeafQueryData<Types>
    where\n <Types as NodeType>::View: UnwindSafe,\n <Types as NodeType>::BlockHeader: UnwindSafe,\n <Types as NodeType>::BlockPayload: UnwindSafe,\n <<Types as NodeType>::SignatureKey as SignatureKey>::QcType: UnwindSafe,\n Types: UnwindSafe,
    ",1,["hotshot_query_service::availability::query_data::LeafQueryData"]],["impl<Types> UnwindSafe for PayloadQueryData<Types>
    where\n <Types as NodeType>::BlockPayload: UnwindSafe,
    ",1,["hotshot_query_service::availability::query_data::PayloadQueryData"]],["impl<Types> UnwindSafe for TransactionQueryData<Types>
    where\n <Types as NodeType>::BlockPayload: for<'de> Sized,\n <Types as NodeType>::Transaction: UnwindSafe,\n <<Types as NodeType>::BlockPayload as QueryablePayload<Types>>::InclusionProof: UnwindSafe,
    ",1,["hotshot_query_service::availability::query_data::TransactionQueryData"]],["impl<Types> UnwindSafe for TransactionSummaryQueryData<Types>
    where\n <Types as NodeType>::BlockHeader: UnwindSafe,\n <Types as NodeType>::Transaction: UnwindSafe,
    ",1,["hotshot_query_service::availability::query_data::TransactionSummaryQueryData"]],["impl<Types> UnwindSafe for VidCommonQueryData<Types>",1,["hotshot_query_service::availability::query_data::VidCommonQueryData"]],["impl<Types> UnwindSafe for FileSystemStorage<Types>
    where\n <Types as NodeType>::BlockPayload: for<'de> Sized + UnwindSafe,\n <Types as NodeType>::BlockHeader: UnwindSafe,\n <Types as NodeType>::View: UnwindSafe,\n <<Types as NodeType>::SignatureKey as SignatureKey>::QcType: UnwindSafe,\n Types: UnwindSafe,
    ",1,["hotshot_query_service::data_source::storage::fs::FileSystemStorage"]],["impl<Types> UnwindSafe for FileSystemStorageInner<Types>
    where\n <Types as NodeType>::BlockPayload: for<'de> Sized + UnwindSafe,\n <Types as NodeType>::BlockHeader: UnwindSafe,\n <Types as NodeType>::View: UnwindSafe,\n <<Types as NodeType>::SignatureKey as SignatureKey>::QcType: UnwindSafe,\n Types: UnwindSafe,
    ",1,["hotshot_query_service::data_source::storage::fs::FileSystemStorageInner"]],["impl<Types> UnwindSafe for BlockDetail<Types>
    where\n <Types as NodeType>::BlockHeader: for<'de> Sized,\n <<Types as NodeType>::BlockHeader as ExplorerHeader<Types>>::ProposerId: UnwindSafe,\n <<Types as NodeType>::BlockHeader as ExplorerHeader<Types>>::WalletAddress: UnwindSafe,
    ",1,["hotshot_query_service::explorer::query_data::BlockDetail"]],["impl<Types> UnwindSafe for BlockDetailResponse<Types>
    where\n <Types as NodeType>::BlockHeader: for<'de> Sized,\n <<Types as NodeType>::BlockHeader as ExplorerHeader<Types>>::ProposerId: UnwindSafe,\n <<Types as NodeType>::BlockHeader as ExplorerHeader<Types>>::WalletAddress: UnwindSafe,
    ",1,["hotshot_query_service::explorer::BlockDetailResponse"]],["impl<Types> UnwindSafe for BlockRange<Types>",1,["hotshot_query_service::explorer::query_data::BlockRange"]],["impl<Types> UnwindSafe for BlockSummary<Types>
    where\n <Types as NodeType>::BlockHeader: for<'de> Sized,\n <<Types as NodeType>::BlockHeader as ExplorerHeader<Types>>::ProposerId: UnwindSafe,
    ",1,["hotshot_query_service::explorer::query_data::BlockSummary"]],["impl<Types> UnwindSafe for BlockSummaryResponse<Types>
    where\n <Types as NodeType>::BlockHeader: for<'de> Sized,\n <<Types as NodeType>::BlockHeader as ExplorerHeader<Types>>::ProposerId: UnwindSafe,
    ",1,["hotshot_query_service::explorer::BlockSummaryResponse"]],["impl<Types> UnwindSafe for ExplorerSummary<Types>
    where\n <Types as NodeType>::BlockHeader: for<'de> Sized,\n <<Types as NodeType>::BlockHeader as ExplorerHeader<Types>>::ProposerId: UnwindSafe,\n <<Types as NodeType>::BlockHeader as ExplorerHeader<Types>>::WalletAddress: UnwindSafe,\n <<Types as NodeType>::Transaction as ExplorerTransaction>::NamespaceId: UnwindSafe,
    ",1,["hotshot_query_service::explorer::query_data::ExplorerSummary"]],["impl<Types> UnwindSafe for ExplorerSummaryResponse<Types>
    where\n <Types as NodeType>::BlockHeader: for<'de> Sized,\n <<Types as NodeType>::BlockHeader as ExplorerHeader<Types>>::ProposerId: UnwindSafe,\n <<Types as NodeType>::BlockHeader as ExplorerHeader<Types>>::WalletAddress: UnwindSafe,\n <<Types as NodeType>::Transaction as ExplorerTransaction>::NamespaceId: UnwindSafe,
    ",1,["hotshot_query_service::explorer::ExplorerSummaryResponse"]],["impl<Types> UnwindSafe for GetBlockSummariesRequest<Types>",1,["hotshot_query_service::explorer::query_data::GetBlockSummariesRequest"]],["impl<Types> UnwindSafe for GetTransactionSummariesRequest<Types>",1,["hotshot_query_service::explorer::query_data::GetTransactionSummariesRequest"]],["impl<Types> UnwindSafe for SearchResult<Types>
    where\n <Types as NodeType>::BlockHeader: for<'de> Sized,\n <<Types as NodeType>::BlockHeader as ExplorerHeader<Types>>::ProposerId: UnwindSafe,\n <<Types as NodeType>::Transaction as ExplorerTransaction>::NamespaceId: UnwindSafe,
    ",1,["hotshot_query_service::explorer::query_data::SearchResult"]],["impl<Types> UnwindSafe for SearchResultResponse<Types>
    where\n <Types as NodeType>::BlockHeader: for<'de> Sized,\n <<Types as NodeType>::BlockHeader as ExplorerHeader<Types>>::ProposerId: UnwindSafe,\n <<Types as NodeType>::Transaction as ExplorerTransaction>::NamespaceId: UnwindSafe,
    ",1,["hotshot_query_service::explorer::SearchResultResponse"]],["impl<Types> UnwindSafe for TransactionDetail<Types>",1,["hotshot_query_service::explorer::query_data::TransactionDetail"]],["impl<Types> UnwindSafe for TransactionDetailResponse<Types>
    where\n <Types as NodeType>::Transaction: UnwindSafe,
    ",1,["hotshot_query_service::explorer::TransactionDetailResponse"]],["impl<Types> UnwindSafe for TransactionRange<Types>",1,["hotshot_query_service::explorer::query_data::TransactionRange"]],["impl<Types> UnwindSafe for TransactionSummariesResponse<Types>
    where\n <Types as NodeType>::BlockHeader: for<'de> Sized,\n <<Types as NodeType>::Transaction as ExplorerTransaction>::NamespaceId: UnwindSafe,
    ",1,["hotshot_query_service::explorer::TransactionSummariesResponse"]],["impl<Types> UnwindSafe for TransactionSummary<Types>
    where\n <Types as NodeType>::BlockHeader: for<'de> Sized,\n <<Types as NodeType>::Transaction as ExplorerTransaction>::NamespaceId: UnwindSafe,
    ",1,["hotshot_query_service::explorer::query_data::TransactionSummary"]],["impl<Types, S, P> !UnwindSafe for FetchingDataSource<Types, S, P>",1,["hotshot_query_service::data_source::fetching::FetchingDataSource"]],["impl<Types, S, P> UnwindSafe for Builder<Types, S, P>
    where\n S: UnwindSafe,\n P: UnwindSafe,\n Types: UnwindSafe,
    ",1,["hotshot_query_service::data_source::fetching::Builder"]],["impl<Types, S, P> UnwindSafe for Pruner<Types, S, P>
    where\n Types: UnwindSafe,\n S: UnwindSafe,\n P: UnwindSafe,
    ",1,["hotshot_query_service::data_source::fetching::Pruner"]],["impl<Types, T, const ARITY: usize> UnwindSafe for Snapshot<Types, T, ARITY>
    where\n <T as MerklizedState<Types, ARITY>>::Commit: UnwindSafe,
    ",1,["hotshot_query_service::merklized_state::data_source::Snapshot"]],["impl<Ver> !UnwindSafe for QueryServiceProvider<Ver>",1,["hotshot_query_service::fetching::provider::query_service::QueryServiceProvider"]],["impl<__T0> UnwindSafe for FetchBlockSnafu<__T0>
    where\n __T0: UnwindSafe,
    ",1,["hotshot_query_service::availability::FetchBlockSnafu"]],["impl<__T0> UnwindSafe for FetchLeafSnafu<__T0>
    where\n __T0: UnwindSafe,
    ",1,["hotshot_query_service::availability::FetchLeafSnafu"]],["impl<__T0> UnwindSafe for FetchTransactionSnafu<__T0>
    where\n __T0: UnwindSafe,
    ",1,["hotshot_query_service::availability::FetchTransactionSnafu"]],["impl<__T0> UnwindSafe for QueryVidSnafu<__T0>
    where\n __T0: UnwindSafe,
    ",1,["hotshot_query_service::node::QueryVidSnafu"]],["impl<__T0> UnwindSafe for ErrorSnafu<__T0>
    where\n __T0: UnwindSafe,
    ",1,["hotshot_query_service::ErrorSnafu"]],["impl<__T0, __T1> UnwindSafe for CustomSnafu<__T0, __T1>
    where\n __T0: UnwindSafe,\n __T1: UnwindSafe,
    ",1,["hotshot_query_service::availability::CustomSnafu"]],["impl<__T0, __T1> UnwindSafe for InvalidTransactionIndexSnafu<__T0, __T1>
    where\n __T0: UnwindSafe,\n __T1: UnwindSafe,
    ",1,["hotshot_query_service::availability::InvalidTransactionIndexSnafu"]],["impl<__T0, __T1> UnwindSafe for CustomSnafu<__T0, __T1>
    where\n __T0: UnwindSafe,\n __T1: UnwindSafe,
    ",1,["hotshot_query_service::node::CustomSnafu"]],["impl<__T0, __T1> UnwindSafe for QueryWindowSnafu<__T0, __T1>
    where\n __T0: UnwindSafe,\n __T1: UnwindSafe,
    ",1,["hotshot_query_service::node::QueryWindowSnafu"]]]]]); + var implementors = Object.fromEntries([["hotshot_query_service",[["impl !UnwindSafe for DataSource",1,["hotshot_query_service::data_source::storage::no_storage::testing::DataSource"]],["impl !UnwindSafe for MetricsError",1,["hotshot_query_service::metrics::MetricsError"]],["impl !UnwindSafe for NoStorage",1,["hotshot_query_service::data_source::storage::no_storage::NoStorage"]],["impl !UnwindSafe for SqlStorage",1,["hotshot_query_service::data_source::storage::sql::SqlStorage"]],["impl !UnwindSafe for MetricsDataSource",1,["hotshot_query_service::data_source::metrics::MetricsDataSource"]],["impl !UnwindSafe for CounterFamily",1,["hotshot_query_service::metrics::CounterFamily"]],["impl !UnwindSafe for GaugeFamily",1,["hotshot_query_service::metrics::GaugeFamily"]],["impl !UnwindSafe for HistogramFamily",1,["hotshot_query_service::metrics::HistogramFamily"]],["impl !UnwindSafe for PrometheusMetrics",1,["hotshot_query_service::metrics::PrometheusMetrics"]],["impl !UnwindSafe for TextFamily",1,["hotshot_query_service::metrics::TextFamily"]],["impl UnwindSafe for Error",1,["hotshot_query_service::availability::Error"]],["impl UnwindSafe for Storage",1,["hotshot_query_service::data_source::storage::no_storage::testing::Storage"]],["impl UnwindSafe for Error",1,["hotshot_query_service::error::Error"]],["impl UnwindSafe for QueryError",1,["hotshot_query_service::QueryError"]],["impl UnwindSafe for CurrencyCode",1,["hotshot_query_service::explorer::currency::CurrencyCode"]],["impl UnwindSafe for Error",1,["hotshot_query_service::explorer::Error"]],["impl UnwindSafe for GetBlockDetailError",1,["hotshot_query_service::explorer::query_data::GetBlockDetailError"]],["impl UnwindSafe for GetBlockSummariesError",1,["hotshot_query_service::explorer::query_data::GetBlockSummariesError"]],["impl UnwindSafe for GetExplorerSummaryError",1,["hotshot_query_service::explorer::query_data::GetExplorerSummaryError"]],["impl UnwindSafe for GetSearchResultsError",1,["hotshot_query_service::explorer::query_data::GetSearchResultsError"]],["impl UnwindSafe for GetTransactionDetailError",1,["hotshot_query_service::explorer::query_data::GetTransactionDetailError"]],["impl UnwindSafe for GetTransactionSummariesError",1,["hotshot_query_service::explorer::query_data::GetTransactionSummariesError"]],["impl UnwindSafe for TimestampConversionError",1,["hotshot_query_service::explorer::query_data::TimestampConversionError"]],["impl UnwindSafe for TransactionSummaryFilter",1,["hotshot_query_service::explorer::query_data::TransactionSummaryFilter"]],["impl UnwindSafe for Error",1,["hotshot_query_service::merklized_state::Error"]],["impl UnwindSafe for Error",1,["hotshot_query_service::node::Error"]],["impl UnwindSafe for Error",1,["hotshot_query_service::status::Error"]],["impl UnwindSafe for Options",1,["hotshot_query_service::availability::Options"]],["impl UnwindSafe for RequestSnafu",1,["hotshot_query_service::availability::RequestSnafu"]],["impl UnwindSafe for PrunerCfg",1,["hotshot_query_service::data_source::storage::pruning::PrunerCfg"]],["impl UnwindSafe for Pruner",1,["hotshot_query_service::data_source::storage::sql::Pruner"]],["impl UnwindSafe for Read",1,["hotshot_query_service::data_source::storage::sql::transaction::Read"]],["impl UnwindSafe for Write",1,["hotshot_query_service::data_source::storage::sql::transaction::Write"]],["impl UnwindSafe for TestMerkleTreeMigration",1,["hotshot_query_service::data_source::storage::sql::testing::TestMerkleTreeMigration"]],["impl UnwindSafe for TmpDb",1,["hotshot_query_service::data_source::storage::sql::testing::TmpDb"]],["impl UnwindSafe for CurrencyMismatchError",1,["hotshot_query_service::explorer::currency::CurrencyMismatchError"]],["impl UnwindSafe for ExplorerHistograms",1,["hotshot_query_service::explorer::query_data::ExplorerHistograms"]],["impl UnwindSafe for FeeAttribution",1,["hotshot_query_service::explorer::query_data::FeeAttribution"]],["impl UnwindSafe for GenesisOverview",1,["hotshot_query_service::explorer::query_data::GenesisOverview"]],["impl UnwindSafe for InvalidCurrencyCodeError",1,["hotshot_query_service::explorer::currency::InvalidCurrencyCodeError"]],["impl UnwindSafe for MonetaryValue",1,["hotshot_query_service::explorer::monetary_value::MonetaryValue"]],["impl UnwindSafe for Timestamp",1,["hotshot_query_service::explorer::query_data::Timestamp"]],["impl UnwindSafe for NoFetching",1,["hotshot_query_service::fetching::provider::NoFetching"]],["impl UnwindSafe for LeafRequest",1,["hotshot_query_service::fetching::request::LeafRequest"]],["impl UnwindSafe for PayloadRequest",1,["hotshot_query_service::fetching::request::PayloadRequest"]],["impl UnwindSafe for VidCommonRequest",1,["hotshot_query_service::fetching::request::VidCommonRequest"]],["impl UnwindSafe for Options",1,["hotshot_query_service::merklized_state::Options"]],["impl UnwindSafe for Counter",1,["hotshot_query_service::metrics::Counter"]],["impl UnwindSafe for Gauge",1,["hotshot_query_service::metrics::Gauge"]],["impl UnwindSafe for Histogram",1,["hotshot_query_service::metrics::Histogram"]],["impl UnwindSafe for Options",1,["hotshot_query_service::node::Options"]],["impl UnwindSafe for QuerySnafu",1,["hotshot_query_service::node::QuerySnafu"]],["impl UnwindSafe for RequestSnafu",1,["hotshot_query_service::node::RequestSnafu"]],["impl UnwindSafe for SyncStatus",1,["hotshot_query_service::node::query_data::SyncStatus"]],["impl UnwindSafe for Options",1,["hotshot_query_service::status::Options"]],["impl UnwindSafe for MissingSnafu",1,["hotshot_query_service::MissingSnafu"]],["impl UnwindSafe for NotFoundSnafu",1,["hotshot_query_service::NotFoundSnafu"]],["impl UnwindSafe for Options",1,["hotshot_query_service::Options"]],["impl UnwindSafe for BackgroundTask",1,["hotshot_query_service::task::BackgroundTask"]],["impl UnwindSafe for MockNodeImpl",1,["hotshot_query_service::testing::mocks::MockNodeImpl"]],["impl UnwindSafe for MockTypes",1,["hotshot_query_service::testing::mocks::MockTypes"]],["impl UnwindSafe for MockVersions",1,["hotshot_query_service::testing::mocks::MockVersions"]],["impl<'a> !UnwindSafe for Transaction<'a>",1,["hotshot_query_service::data_source::storage::no_storage::Transaction"]],["impl<'a, T> !UnwindSafe for Transaction<'a, T>",1,["hotshot_query_service::data_source::storage::no_storage::testing::Transaction"]],["impl<'a, Types, T> !UnwindSafe for Transaction<'a, Types, T>",1,["hotshot_query_service::data_source::fetching::notify_storage::Transaction"]],["impl<'q> !UnwindSafe for QueryBuilder<'q>",1,["hotshot_query_service::data_source::storage::sql::queries::QueryBuilder"]],["impl<D> !UnwindSafe for MockNetwork<D>",1,["hotshot_query_service::testing::consensus::MockNetwork"]],["impl<D> UnwindSafe for ApiState<D>
    where\n D: RefUnwindSafe,
    ",1,["hotshot_query_service::ApiState"]],["impl<D, U> UnwindSafe for ExtensibleDataSource<D, U>
    where\n D: UnwindSafe,\n U: UnwindSafe,
    ",1,["hotshot_query_service::data_source::extension::ExtensibleDataSource"]],["impl<DB> !UnwindSafe for Config<DB>",1,["hotshot_query_service::data_source::storage::sql::Config"]],["impl<Mode> !UnwindSafe for Transaction<Mode>",1,["hotshot_query_service::data_source::storage::sql::transaction::Transaction"]],["impl<P> !UnwindSafe for TestProvider<P>",1,["hotshot_query_service::fetching::provider::testing::TestProvider"]],["impl<T> !UnwindSafe for Fetch<T>",1,["hotshot_query_service::availability::fetch::Fetch"]],["impl<T> UnwindSafe for Transaction<T>
    where\n T: UnwindSafe,
    ",1,["hotshot_query_service::data_source::storage::fs::Transaction"]],["impl<T> UnwindSafe for TimeWindowQueryData<T>
    where\n T: UnwindSafe,
    ",1,["hotshot_query_service::node::query_data::TimeWindowQueryData"]],["impl<T> UnwindSafe for Task<T>",1,["hotshot_query_service::task::Task"]],["impl<T, C> !UnwindSafe for Fetcher<T, C>",1,["hotshot_query_service::fetching::Fetcher"]],["impl<Types> !UnwindSafe for FileSystemStorage<Types>",1,["hotshot_query_service::data_source::storage::fs::FileSystemStorage"]],["impl<Types> !UnwindSafe for AnyProvider<Types>",1,["hotshot_query_service::fetching::provider::any::AnyProvider"]],["impl<Types> UnwindSafe for BlockId<Types>",1,["hotshot_query_service::availability::data_source::BlockId"]],["impl<Types> UnwindSafe for LeafId<Types>",1,["hotshot_query_service::availability::data_source::LeafId"]],["impl<Types> UnwindSafe for BlockIdentifier<Types>",1,["hotshot_query_service::explorer::query_data::BlockIdentifier"]],["impl<Types> UnwindSafe for TransactionIdentifier<Types>",1,["hotshot_query_service::explorer::query_data::TransactionIdentifier"]],["impl<Types> UnwindSafe for WindowStart<Types>",1,["hotshot_query_service::node::data_source::WindowStart"]],["impl<Types> UnwindSafe for BlockQueryData<Types>
    where\n <Types as NodeType>::BlockHeader: UnwindSafe,\n <Types as NodeType>::BlockPayload: UnwindSafe,
    ",1,["hotshot_query_service::availability::query_data::BlockQueryData"]],["impl<Types> UnwindSafe for BlockSummaryQueryData<Types>
    where\n <Types as NodeType>::BlockHeader: UnwindSafe,
    ",1,["hotshot_query_service::availability::query_data::BlockSummaryQueryData"]],["impl<Types> UnwindSafe for InconsistentLeafError<Types>",1,["hotshot_query_service::availability::query_data::InconsistentLeafError"]],["impl<Types> UnwindSafe for LeafQueryData<Types>
    where\n <Types as NodeType>::View: UnwindSafe,\n <Types as NodeType>::BlockHeader: UnwindSafe,\n <Types as NodeType>::BlockPayload: UnwindSafe,\n <<Types as NodeType>::SignatureKey as SignatureKey>::QcType: UnwindSafe,\n Types: UnwindSafe,
    ",1,["hotshot_query_service::availability::query_data::LeafQueryData"]],["impl<Types> UnwindSafe for PayloadQueryData<Types>
    where\n <Types as NodeType>::BlockPayload: UnwindSafe,
    ",1,["hotshot_query_service::availability::query_data::PayloadQueryData"]],["impl<Types> UnwindSafe for TransactionQueryData<Types>
    where\n <Types as NodeType>::BlockPayload: for<'de> Sized,\n <Types as NodeType>::Transaction: UnwindSafe,\n <<Types as NodeType>::BlockPayload as QueryablePayload<Types>>::InclusionProof: UnwindSafe,
    ",1,["hotshot_query_service::availability::query_data::TransactionQueryData"]],["impl<Types> UnwindSafe for TransactionSummaryQueryData<Types>
    where\n <Types as NodeType>::BlockHeader: UnwindSafe,\n <Types as NodeType>::Transaction: UnwindSafe,
    ",1,["hotshot_query_service::availability::query_data::TransactionSummaryQueryData"]],["impl<Types> UnwindSafe for VidCommonQueryData<Types>",1,["hotshot_query_service::availability::query_data::VidCommonQueryData"]],["impl<Types> UnwindSafe for FileSystemStorageInner<Types>
    where\n <Types as NodeType>::BlockPayload: for<'de> Sized + UnwindSafe,\n <Types as NodeType>::BlockHeader: UnwindSafe,\n <Types as NodeType>::View: UnwindSafe,\n <<Types as NodeType>::SignatureKey as SignatureKey>::QcType: UnwindSafe,\n Types: UnwindSafe,
    ",1,["hotshot_query_service::data_source::storage::fs::FileSystemStorageInner"]],["impl<Types> UnwindSafe for BlockDetail<Types>
    where\n <Types as NodeType>::BlockHeader: for<'de> Sized,\n <<Types as NodeType>::BlockHeader as ExplorerHeader<Types>>::ProposerId: UnwindSafe,\n <<Types as NodeType>::BlockHeader as ExplorerHeader<Types>>::WalletAddress: UnwindSafe,
    ",1,["hotshot_query_service::explorer::query_data::BlockDetail"]],["impl<Types> UnwindSafe for BlockDetailResponse<Types>
    where\n <Types as NodeType>::BlockHeader: for<'de> Sized,\n <<Types as NodeType>::BlockHeader as ExplorerHeader<Types>>::ProposerId: UnwindSafe,\n <<Types as NodeType>::BlockHeader as ExplorerHeader<Types>>::WalletAddress: UnwindSafe,
    ",1,["hotshot_query_service::explorer::BlockDetailResponse"]],["impl<Types> UnwindSafe for BlockRange<Types>",1,["hotshot_query_service::explorer::query_data::BlockRange"]],["impl<Types> UnwindSafe for BlockSummary<Types>
    where\n <Types as NodeType>::BlockHeader: for<'de> Sized,\n <<Types as NodeType>::BlockHeader as ExplorerHeader<Types>>::ProposerId: UnwindSafe,
    ",1,["hotshot_query_service::explorer::query_data::BlockSummary"]],["impl<Types> UnwindSafe for BlockSummaryResponse<Types>
    where\n <Types as NodeType>::BlockHeader: for<'de> Sized,\n <<Types as NodeType>::BlockHeader as ExplorerHeader<Types>>::ProposerId: UnwindSafe,
    ",1,["hotshot_query_service::explorer::BlockSummaryResponse"]],["impl<Types> UnwindSafe for ExplorerSummary<Types>
    where\n <Types as NodeType>::BlockHeader: for<'de> Sized,\n <<Types as NodeType>::BlockHeader as ExplorerHeader<Types>>::ProposerId: UnwindSafe,\n <<Types as NodeType>::BlockHeader as ExplorerHeader<Types>>::WalletAddress: UnwindSafe,\n <<Types as NodeType>::Transaction as ExplorerTransaction>::NamespaceId: UnwindSafe,
    ",1,["hotshot_query_service::explorer::query_data::ExplorerSummary"]],["impl<Types> UnwindSafe for ExplorerSummaryResponse<Types>
    where\n <Types as NodeType>::BlockHeader: for<'de> Sized,\n <<Types as NodeType>::BlockHeader as ExplorerHeader<Types>>::ProposerId: UnwindSafe,\n <<Types as NodeType>::BlockHeader as ExplorerHeader<Types>>::WalletAddress: UnwindSafe,\n <<Types as NodeType>::Transaction as ExplorerTransaction>::NamespaceId: UnwindSafe,
    ",1,["hotshot_query_service::explorer::ExplorerSummaryResponse"]],["impl<Types> UnwindSafe for GetBlockSummariesRequest<Types>",1,["hotshot_query_service::explorer::query_data::GetBlockSummariesRequest"]],["impl<Types> UnwindSafe for GetTransactionSummariesRequest<Types>",1,["hotshot_query_service::explorer::query_data::GetTransactionSummariesRequest"]],["impl<Types> UnwindSafe for SearchResult<Types>
    where\n <Types as NodeType>::BlockHeader: for<'de> Sized,\n <<Types as NodeType>::BlockHeader as ExplorerHeader<Types>>::ProposerId: UnwindSafe,\n <<Types as NodeType>::Transaction as ExplorerTransaction>::NamespaceId: UnwindSafe,
    ",1,["hotshot_query_service::explorer::query_data::SearchResult"]],["impl<Types> UnwindSafe for SearchResultResponse<Types>
    where\n <Types as NodeType>::BlockHeader: for<'de> Sized,\n <<Types as NodeType>::BlockHeader as ExplorerHeader<Types>>::ProposerId: UnwindSafe,\n <<Types as NodeType>::Transaction as ExplorerTransaction>::NamespaceId: UnwindSafe,
    ",1,["hotshot_query_service::explorer::SearchResultResponse"]],["impl<Types> UnwindSafe for TransactionDetail<Types>",1,["hotshot_query_service::explorer::query_data::TransactionDetail"]],["impl<Types> UnwindSafe for TransactionDetailResponse<Types>
    where\n <Types as NodeType>::Transaction: UnwindSafe,
    ",1,["hotshot_query_service::explorer::TransactionDetailResponse"]],["impl<Types> UnwindSafe for TransactionRange<Types>",1,["hotshot_query_service::explorer::query_data::TransactionRange"]],["impl<Types> UnwindSafe for TransactionSummariesResponse<Types>
    where\n <Types as NodeType>::BlockHeader: for<'de> Sized,\n <<Types as NodeType>::Transaction as ExplorerTransaction>::NamespaceId: UnwindSafe,
    ",1,["hotshot_query_service::explorer::TransactionSummariesResponse"]],["impl<Types> UnwindSafe for TransactionSummary<Types>
    where\n <Types as NodeType>::BlockHeader: for<'de> Sized,\n <<Types as NodeType>::Transaction as ExplorerTransaction>::NamespaceId: UnwindSafe,
    ",1,["hotshot_query_service::explorer::query_data::TransactionSummary"]],["impl<Types, S, P> !UnwindSafe for FetchingDataSource<Types, S, P>",1,["hotshot_query_service::data_source::fetching::FetchingDataSource"]],["impl<Types, S, P> UnwindSafe for Builder<Types, S, P>
    where\n S: UnwindSafe,\n P: UnwindSafe,\n Types: UnwindSafe,
    ",1,["hotshot_query_service::data_source::fetching::Builder"]],["impl<Types, S, P> UnwindSafe for Pruner<Types, S, P>
    where\n Types: UnwindSafe,\n S: UnwindSafe,\n P: UnwindSafe,
    ",1,["hotshot_query_service::data_source::fetching::Pruner"]],["impl<Types, T, const ARITY: usize> UnwindSafe for Snapshot<Types, T, ARITY>
    where\n <T as MerklizedState<Types, ARITY>>::Commit: UnwindSafe,
    ",1,["hotshot_query_service::merklized_state::data_source::Snapshot"]],["impl<Ver> !UnwindSafe for QueryServiceProvider<Ver>",1,["hotshot_query_service::fetching::provider::query_service::QueryServiceProvider"]],["impl<__T0> UnwindSafe for FetchBlockSnafu<__T0>
    where\n __T0: UnwindSafe,
    ",1,["hotshot_query_service::availability::FetchBlockSnafu"]],["impl<__T0> UnwindSafe for FetchLeafSnafu<__T0>
    where\n __T0: UnwindSafe,
    ",1,["hotshot_query_service::availability::FetchLeafSnafu"]],["impl<__T0> UnwindSafe for FetchTransactionSnafu<__T0>
    where\n __T0: UnwindSafe,
    ",1,["hotshot_query_service::availability::FetchTransactionSnafu"]],["impl<__T0> UnwindSafe for QueryVidSnafu<__T0>
    where\n __T0: UnwindSafe,
    ",1,["hotshot_query_service::node::QueryVidSnafu"]],["impl<__T0> UnwindSafe for ErrorSnafu<__T0>
    where\n __T0: UnwindSafe,
    ",1,["hotshot_query_service::ErrorSnafu"]],["impl<__T0, __T1> UnwindSafe for CustomSnafu<__T0, __T1>
    where\n __T0: UnwindSafe,\n __T1: UnwindSafe,
    ",1,["hotshot_query_service::availability::CustomSnafu"]],["impl<__T0, __T1> UnwindSafe for InvalidTransactionIndexSnafu<__T0, __T1>
    where\n __T0: UnwindSafe,\n __T1: UnwindSafe,
    ",1,["hotshot_query_service::availability::InvalidTransactionIndexSnafu"]],["impl<__T0, __T1> UnwindSafe for CustomSnafu<__T0, __T1>
    where\n __T0: UnwindSafe,\n __T1: UnwindSafe,
    ",1,["hotshot_query_service::node::CustomSnafu"]],["impl<__T0, __T1> UnwindSafe for QueryWindowSnafu<__T0, __T1>
    where\n __T0: UnwindSafe,\n __T1: UnwindSafe,
    ",1,["hotshot_query_service::node::QueryWindowSnafu"]]]]]); if (window.register_implementors) { window.register_implementors(implementors); } else { window.pending_implementors = implementors; } })() -//{"start":57,"fragment_lengths":[79884]} \ No newline at end of file +//{"start":57,"fragment_lengths":[78606]} \ No newline at end of file diff --git a/trait.impl/hotshot_query_service/status/data_source/trait.HasMetrics.js b/trait.impl/hotshot_query_service/status/data_source/trait.HasMetrics.js new file mode 100644 index 000000000..5a3a75c99 --- /dev/null +++ b/trait.impl/hotshot_query_service/status/data_source/trait.HasMetrics.js @@ -0,0 +1,9 @@ +(function() { + var implementors = Object.fromEntries([["hotshot_query_service",[]]]); + if (window.register_implementors) { + window.register_implementors(implementors); + } else { + window.pending_implementors = implementors; + } +})() +//{"start":57,"fragment_lengths":[28]} \ No newline at end of file diff --git a/type.impl/hotshot_query_service/data_source/fetching/struct.FetchingDataSource.js b/type.impl/hotshot_query_service/data_source/fetching/struct.FetchingDataSource.js index e0bd7d7bc..e38e7947a 100644 --- a/type.impl/hotshot_query_service/data_source/fetching/struct.FetchingDataSource.js +++ b/type.impl/hotshot_query_service/data_source/fetching/struct.FetchingDataSource.js @@ -1,9 +1,9 @@ (function() { - var type_impls = Object.fromEntries([["hotshot_query_service",[["
    source§

    impl<Types, S, P> AsRef<S> for FetchingDataSource<Types, S, P>
    where\n Types: NodeType,

    source§

    fn as_ref(&self) -> &S

    Converts this type into a shared reference of the (usually inferred) input type.
    ","AsRef","hotshot_query_service::data_source::fs::FileSystemDataSource","hotshot_query_service::data_source::sql::SqlDataSource"],["
    source§

    impl<Types, S, P> AvailabilityDataSource<Types> for FetchingDataSource<Types, S, P>
    where\n Types: NodeType,\n Payload<Types>: QueryablePayload<Types>,\n S: VersionedDataSource + 'static,\n for<'a> S::Transaction<'a>: UpdateAvailabilityData<Types>,\n for<'a> S::ReadOnly<'a>: AvailabilityStorage<Types> + NodeStorage<Types> + PrunedHeightStorage,\n P: AvailabilityProvider<Types>,

    source§

    type LeafRange<R> = Pin<Box<dyn Stream<Item = Fetch<LeafQueryData<Types>>> + Send>>\nwhere\n R: RangeBounds<usize> + Send

    source§

    type BlockRange<R> = Pin<Box<dyn Stream<Item = Fetch<BlockQueryData<Types>>> + Send>>\nwhere\n R: RangeBounds<usize> + Send

    source§

    type PayloadRange<R> = Pin<Box<dyn Stream<Item = Fetch<PayloadQueryData<Types>>> + Send>>\nwhere\n R: RangeBounds<usize> + Send

    source§

    type VidCommonRange<R> = Pin<Box<dyn Stream<Item = Fetch<VidCommonQueryData<Types>>> + Send>>\nwhere\n R: RangeBounds<usize> + Send

    source§

    fn get_leaf<'life0, 'async_trait, ID>(\n &'life0 self,\n id: ID,\n) -> Pin<Box<dyn Future<Output = Fetch<LeafQueryData<Types>>> + Send + 'async_trait>>
    where\n ID: Into<LeafId<Types>> + Send + Sync + 'async_trait,\n Self: 'async_trait,\n 'life0: 'async_trait,

    source§

    fn get_block<'life0, 'async_trait, ID>(\n &'life0 self,\n id: ID,\n) -> Pin<Box<dyn Future<Output = Fetch<BlockQueryData<Types>>> + Send + 'async_trait>>
    where\n ID: Into<BlockId<Types>> + Send + Sync + 'async_trait,\n Self: 'async_trait,\n 'life0: 'async_trait,

    source§

    fn get_payload<'life0, 'async_trait, ID>(\n &'life0 self,\n id: ID,\n) -> Pin<Box<dyn Future<Output = Fetch<PayloadQueryData<Types>>> + Send + 'async_trait>>
    where\n ID: Into<BlockId<Types>> + Send + Sync + 'async_trait,\n Self: 'async_trait,\n 'life0: 'async_trait,

    source§

    fn get_vid_common<'life0, 'async_trait, ID>(\n &'life0 self,\n id: ID,\n) -> Pin<Box<dyn Future<Output = Fetch<VidCommonQueryData<Types>>> + Send + 'async_trait>>
    where\n ID: Into<BlockId<Types>> + Send + Sync + 'async_trait,\n Self: 'async_trait,\n 'life0: 'async_trait,

    source§

    fn get_leaf_range<'life0, 'async_trait, R>(\n &'life0 self,\n range: R,\n) -> Pin<Box<dyn Future<Output = Self::LeafRange<R>> + Send + 'async_trait>>
    where\n R: RangeBounds<usize> + Send + 'static + 'async_trait,\n Self: 'async_trait,\n 'life0: 'async_trait,

    source§

    fn get_block_range<'life0, 'async_trait, R>(\n &'life0 self,\n range: R,\n) -> Pin<Box<dyn Future<Output = Self::BlockRange<R>> + Send + 'async_trait>>
    where\n R: RangeBounds<usize> + Send + 'static + 'async_trait,\n Self: 'async_trait,\n 'life0: 'async_trait,

    source§

    fn get_payload_range<'life0, 'async_trait, R>(\n &'life0 self,\n range: R,\n) -> Pin<Box<dyn Future<Output = Self::PayloadRange<R>> + Send + 'async_trait>>
    where\n R: RangeBounds<usize> + Send + 'static + 'async_trait,\n Self: 'async_trait,\n 'life0: 'async_trait,

    source§

    fn get_vid_common_range<'life0, 'async_trait, R>(\n &'life0 self,\n range: R,\n) -> Pin<Box<dyn Future<Output = Self::VidCommonRange<R>> + Send + 'async_trait>>
    where\n R: RangeBounds<usize> + Send + 'static + 'async_trait,\n Self: 'async_trait,\n 'life0: 'async_trait,

    source§

    fn get_transaction<'life0, 'async_trait>(\n &'life0 self,\n hash: TransactionHash<Types>,\n) -> Pin<Box<dyn Future<Output = Fetch<TransactionQueryData<Types>>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    Returns the transaction with the given hash.
    source§

    fn subscribe_blocks<'life0, 'async_trait>(\n &'life0 self,\n from: usize,\n) -> Pin<Box<dyn Future<Output = BoxStream<'static, BlockQueryData<Types>>> + Send + 'async_trait>>
    where\n Self: Sync + 'async_trait,\n 'life0: 'async_trait,

    source§

    fn subscribe_payloads<'life0, 'async_trait>(\n &'life0 self,\n from: usize,\n) -> Pin<Box<dyn Future<Output = BoxStream<'static, PayloadQueryData<Types>>> + Send + 'async_trait>>
    where\n Self: Sync + 'async_trait,\n 'life0: 'async_trait,

    source§

    fn subscribe_leaves<'life0, 'async_trait>(\n &'life0 self,\n from: usize,\n) -> Pin<Box<dyn Future<Output = BoxStream<'static, LeafQueryData<Types>>> + Send + 'async_trait>>
    where\n Self: Sync + 'async_trait,\n 'life0: 'async_trait,

    source§

    fn subscribe_vid_common<'life0, 'async_trait>(\n &'life0 self,\n from: usize,\n) -> Pin<Box<dyn Future<Output = BoxStream<'static, VidCommonQueryData<Types>>> + Send + 'async_trait>>
    where\n Self: Sync + 'async_trait,\n 'life0: 'async_trait,

    ","AvailabilityDataSource","hotshot_query_service::data_source::fs::FileSystemDataSource","hotshot_query_service::data_source::sql::SqlDataSource"],["
    source§

    impl<Types, S, P> Clone for FetchingDataSource<Types, S, P>
    where\n Types: NodeType,

    source§

    fn clone(&self) -> Self

    Returns a copy of the value. Read more
    1.0.0 · source§

    fn clone_from(&mut self, source: &Self)

    Performs copy-assignment from source. Read more
    ","Clone","hotshot_query_service::data_source::fs::FileSystemDataSource","hotshot_query_service::data_source::sql::SqlDataSource"],["
    source§

    impl<Types, S, P> Debug for FetchingDataSource<Types, S, P>
    where\n Types: NodeType,\n S: Debug,\n P: Debug,

    source§

    fn fmt(&self, __f: &mut Formatter<'_>) -> Result

    Formats the value using the given formatter. Read more
    ","Debug","hotshot_query_service::data_source::fs::FileSystemDataSource","hotshot_query_service::data_source::sql::SqlDataSource"],["
    source§

    impl<Types, S, P> ExplorerDataSource<Types> for FetchingDataSource<Types, S, P>
    where\n Types: NodeType,\n Payload<Types>: QueryablePayload<Types>,\n Header<Types>: QueryableHeader<Types> + ExplorerHeader<Types>,\n Transaction<Types>: ExplorerTransaction,\n S: VersionedDataSource + 'static,\n for<'a> S::ReadOnly<'a>: ExplorerStorage<Types>,\n P: Send + Sync,

    source§

    fn get_block_summaries<'life0, 'async_trait>(\n &'life0 self,\n request: GetBlockSummariesRequest<Types>,\n) -> Pin<Box<dyn Future<Output = Result<Vec<BlockSummary<Types>>, GetBlockSummariesError>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    get_block_summaries is a method that retrieves a list of block\nsummaries from the blockchain. The list is generated from the given\nGetBlockSummariesRequest.
    source§

    fn get_block_detail<'life0, 'async_trait>(\n &'life0 self,\n request: BlockIdentifier<Types>,\n) -> Pin<Box<dyn Future<Output = Result<BlockDetail<Types>, GetBlockDetailError>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    get_block_detail is a method that retrieves the details of a specific\nblock from the blockchain. The block is identified by the given\nBlockIdentifier.
    source§

    fn get_transaction_summaries<'life0, 'async_trait>(\n &'life0 self,\n request: GetTransactionSummariesRequest<Types>,\n) -> Pin<Box<dyn Future<Output = Result<Vec<TransactionSummary<Types>>, GetTransactionSummariesError>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    get_transaction_summaries is a method that retrieves a list of\ntransaction summaries from the blockchain. The list is generated from\nthe given GetTransactionSummariesRequest.
    source§

    fn get_transaction_detail<'life0, 'async_trait>(\n &'life0 self,\n request: TransactionIdentifier<Types>,\n) -> Pin<Box<dyn Future<Output = Result<TransactionDetailResponse<Types>, GetTransactionDetailError>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    get_transaction_detail is a method that retrieves the details of a\nspecific transaction from the blockchain. The transaction is identified\nby the given TransactionIdentifier.
    source§

    fn get_explorer_summary<'life0, 'async_trait>(\n &'life0 self,\n) -> Pin<Box<dyn Future<Output = Result<ExplorerSummary<Types>, GetExplorerSummaryError>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    get_explorer_summary is a method that retrieves a summary overview of\nthe blockchain. This is useful for displaying information that\nindicates the overall status of the block chain.
    source§

    fn get_search_results<'life0, 'async_trait>(\n &'life0 self,\n query: String,\n) -> Pin<Box<dyn Future<Output = Result<SearchResult<Types>, GetSearchResultsError>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    get_search_results is a method that retrieves the results of a search\nquery against the blockchain. The results are generated from the given\nquery string.
    ","ExplorerDataSource","hotshot_query_service::data_source::fs::FileSystemDataSource","hotshot_query_service::data_source::sql::SqlDataSource"],["
    source§

    impl<Types, S, P> FetchingDataSource<Types, S, P>
    where\n Types: NodeType,\n Payload<Types>: QueryablePayload<Types>,\n Header<Types>: QueryableHeader<Types>,\n S: VersionedDataSource + PruneStorage + 'static,\n for<'a> S::Transaction<'a>: UpdateAvailabilityData<Types>,\n for<'a> S::ReadOnly<'a>: AvailabilityStorage<Types> + NodeStorage<Types> + PrunedHeightStorage,\n P: AvailabilityProvider<Types>,

    source

    pub fn builder(storage: S, provider: P) -> Builder<Types, S, P>

    Build a FetchingDataSource with the given storage and provider.

    \n
    ",0,"hotshot_query_service::data_source::fs::FileSystemDataSource","hotshot_query_service::data_source::sql::SqlDataSource"],["
    source§

    impl<Types, S, P, State, const ARITY: usize> MerklizedStateDataSource<Types, State, ARITY> for FetchingDataSource<Types, S, P>
    where\n Types: NodeType,\n S: VersionedDataSource + 'static,\n for<'a> S::ReadOnly<'a>: MerklizedStateStorage<Types, State, ARITY>,\n P: Send + Sync,\n State: MerklizedState<Types, ARITY> + 'static,\n <State as MerkleTreeScheme>::Commitment: Send,

    source§

    fn get_path<'life0, 'async_trait>(\n &'life0 self,\n snapshot: Snapshot<Types, State, ARITY>,\n key: State::Key,\n) -> Pin<Box<dyn Future<Output = QueryResult<MerkleProof<State::Entry, State::Key, State::T, ARITY>>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    ","MerklizedStateDataSource","hotshot_query_service::data_source::fs::FileSystemDataSource","hotshot_query_service::data_source::sql::SqlDataSource"],["
    source§

    impl<Types, S, P> MerklizedStateHeightPersistence for FetchingDataSource<Types, S, P>
    where\n Types: NodeType,\n Payload<Types>: QueryablePayload<Types>,\n S: VersionedDataSource + 'static,\n for<'a> S::ReadOnly<'a>: MerklizedStateHeightStorage,\n P: Send + Sync,

    source§

    fn get_last_state_height<'life0, 'async_trait>(\n &'life0 self,\n) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    ","MerklizedStateHeightPersistence","hotshot_query_service::data_source::fs::FileSystemDataSource","hotshot_query_service::data_source::sql::SqlDataSource"],["
    source§

    impl<Types, S, P> NodeDataSource<Types> for FetchingDataSource<Types, S, P>
    where\n Types: NodeType,\n S: VersionedDataSource + 'static,\n for<'a> S::ReadOnly<'a>: NodeStorage<Types>,\n P: Send + Sync,

    source§

    fn block_height<'life0, 'async_trait>(\n &'life0 self,\n) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    source§

    fn count_transactions<'life0, 'async_trait>(\n &'life0 self,\n) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    source§

    fn payload_size<'life0, 'async_trait>(\n &'life0 self,\n) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    source§

    fn vid_share<'life0, 'async_trait, ID>(\n &'life0 self,\n id: ID,\n) -> Pin<Box<dyn Future<Output = QueryResult<VidShare>> + Send + 'async_trait>>
    where\n ID: Into<BlockId<Types>> + Send + Sync + 'async_trait,\n Self: 'async_trait,\n 'life0: 'async_trait,

    source§

    fn sync_status<'life0, 'async_trait>(\n &'life0 self,\n) -> Pin<Box<dyn Future<Output = QueryResult<SyncStatus>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    Search the database for missing objects and generate a report.
    source§

    fn get_header_window<'life0, 'async_trait>(\n &'life0 self,\n start: impl 'async_trait + Into<WindowStart<Types>> + Send + Sync,\n end: u64,\n) -> Pin<Box<dyn Future<Output = QueryResult<TimeWindowQueryData<Header<Types>>>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    ","NodeDataSource","hotshot_query_service::data_source::fs::FileSystemDataSource","hotshot_query_service::data_source::sql::SqlDataSource"],["
    source§

    impl<Types, S, P> StatusDataSource for FetchingDataSource<Types, S, P>
    where\n Types: NodeType,\n S: VersionedDataSource + Send + Sync + 'static,\n for<'a> S::ReadOnly<'a>: NodeStorage<Types>,\n P: Send + Sync,

    source§

    fn block_height<'life0, 'async_trait>(\n &'life0 self,\n) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    source§

    fn metrics(&self) -> &PrometheusMetrics

    source§

    fn consensus_metrics(&self) -> QueryResult<PrometheusMetrics>

    source§

    fn elapsed_time_since_last_decide<'life0, 'async_trait>(\n &'life0 self,\n) -> Pin<Box<dyn Future<Output = QueryResult<u64>> + Send + 'async_trait>>
    where\n Self: Sync + 'async_trait,\n 'life0: 'async_trait,

    source§

    fn success_rate<'life0, 'async_trait>(\n &'life0 self,\n) -> Pin<Box<dyn Future<Output = QueryResult<f64>> + Send + 'async_trait>>
    where\n Self: Sync + 'async_trait,\n 'life0: 'async_trait,

    ","StatusDataSource","hotshot_query_service::data_source::fs::FileSystemDataSource","hotshot_query_service::data_source::sql::SqlDataSource"],["
    source§

    impl<Types, S, P> VersionedDataSource for FetchingDataSource<Types, S, P>
    where\n Types: NodeType,\n S: VersionedDataSource + Send + Sync,\n P: Send + Sync,

    source§

    type Transaction<'a> = Transaction<'a, Types, <S as VersionedDataSource>::Transaction<'a>>\nwhere\n Self: 'a

    A transaction which can read and modify the data source.
    source§

    type ReadOnly<'a> = Transaction<'a, Types, <S as VersionedDataSource>::ReadOnly<'a>>\nwhere\n Self: 'a

    source§

    async fn write(&self) -> Result<Self::Transaction<'_>>

    Start an atomic transaction on the data source.
    source§

    async fn read(&self) -> Result<Self::ReadOnly<'_>>

    Start a read-only transaction on the data source. Read more
    ","VersionedDataSource","hotshot_query_service::data_source::fs::FileSystemDataSource","hotshot_query_service::data_source::sql::SqlDataSource"]]]]); + var type_impls = Object.fromEntries([["hotshot_query_service",[["
    source§

    impl<Types, S, P> AsRef<S> for FetchingDataSource<Types, S, P>
    where\n Types: NodeType,

    source§

    fn as_ref(&self) -> &S

    Converts this type into a shared reference of the (usually inferred) input type.
    ","AsRef","hotshot_query_service::data_source::fs::FileSystemDataSource","hotshot_query_service::data_source::sql::SqlDataSource"],["
    source§

    impl<Types, S, P> AvailabilityDataSource<Types> for FetchingDataSource<Types, S, P>
    where\n Types: NodeType,\n Payload<Types>: QueryablePayload<Types>,\n S: VersionedDataSource + 'static,\n for<'a> S::Transaction<'a>: UpdateAvailabilityData<Types>,\n for<'a> S::ReadOnly<'a>: AvailabilityStorage<Types> + NodeStorage<Types> + PrunedHeightStorage,\n P: AvailabilityProvider<Types>,

    source§

    type LeafRange<R> = Pin<Box<dyn Stream<Item = Fetch<LeafQueryData<Types>>> + Send>>\nwhere\n R: RangeBounds<usize> + Send

    source§

    type BlockRange<R> = Pin<Box<dyn Stream<Item = Fetch<BlockQueryData<Types>>> + Send>>\nwhere\n R: RangeBounds<usize> + Send

    source§

    type PayloadRange<R> = Pin<Box<dyn Stream<Item = Fetch<PayloadQueryData<Types>>> + Send>>\nwhere\n R: RangeBounds<usize> + Send

    source§

    type VidCommonRange<R> = Pin<Box<dyn Stream<Item = Fetch<VidCommonQueryData<Types>>> + Send>>\nwhere\n R: RangeBounds<usize> + Send

    source§

    fn get_leaf<'life0, 'async_trait, ID>(\n &'life0 self,\n id: ID,\n) -> Pin<Box<dyn Future<Output = Fetch<LeafQueryData<Types>>> + Send + 'async_trait>>
    where\n ID: Into<LeafId<Types>> + Send + Sync + 'async_trait,\n Self: 'async_trait,\n 'life0: 'async_trait,

    source§

    fn get_block<'life0, 'async_trait, ID>(\n &'life0 self,\n id: ID,\n) -> Pin<Box<dyn Future<Output = Fetch<BlockQueryData<Types>>> + Send + 'async_trait>>
    where\n ID: Into<BlockId<Types>> + Send + Sync + 'async_trait,\n Self: 'async_trait,\n 'life0: 'async_trait,

    source§

    fn get_payload<'life0, 'async_trait, ID>(\n &'life0 self,\n id: ID,\n) -> Pin<Box<dyn Future<Output = Fetch<PayloadQueryData<Types>>> + Send + 'async_trait>>
    where\n ID: Into<BlockId<Types>> + Send + Sync + 'async_trait,\n Self: 'async_trait,\n 'life0: 'async_trait,

    source§

    fn get_vid_common<'life0, 'async_trait, ID>(\n &'life0 self,\n id: ID,\n) -> Pin<Box<dyn Future<Output = Fetch<VidCommonQueryData<Types>>> + Send + 'async_trait>>
    where\n ID: Into<BlockId<Types>> + Send + Sync + 'async_trait,\n Self: 'async_trait,\n 'life0: 'async_trait,

    source§

    fn get_leaf_range<'life0, 'async_trait, R>(\n &'life0 self,\n range: R,\n) -> Pin<Box<dyn Future<Output = Self::LeafRange<R>> + Send + 'async_trait>>
    where\n R: RangeBounds<usize> + Send + 'static + 'async_trait,\n Self: 'async_trait,\n 'life0: 'async_trait,

    source§

    fn get_block_range<'life0, 'async_trait, R>(\n &'life0 self,\n range: R,\n) -> Pin<Box<dyn Future<Output = Self::BlockRange<R>> + Send + 'async_trait>>
    where\n R: RangeBounds<usize> + Send + 'static + 'async_trait,\n Self: 'async_trait,\n 'life0: 'async_trait,

    source§

    fn get_payload_range<'life0, 'async_trait, R>(\n &'life0 self,\n range: R,\n) -> Pin<Box<dyn Future<Output = Self::PayloadRange<R>> + Send + 'async_trait>>
    where\n R: RangeBounds<usize> + Send + 'static + 'async_trait,\n Self: 'async_trait,\n 'life0: 'async_trait,

    source§

    fn get_vid_common_range<'life0, 'async_trait, R>(\n &'life0 self,\n range: R,\n) -> Pin<Box<dyn Future<Output = Self::VidCommonRange<R>> + Send + 'async_trait>>
    where\n R: RangeBounds<usize> + Send + 'static + 'async_trait,\n Self: 'async_trait,\n 'life0: 'async_trait,

    source§

    fn get_transaction<'life0, 'async_trait>(\n &'life0 self,\n hash: TransactionHash<Types>,\n) -> Pin<Box<dyn Future<Output = Fetch<TransactionQueryData<Types>>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    Returns the transaction with the given hash.
    source§

    fn subscribe_blocks<'life0, 'async_trait>(\n &'life0 self,\n from: usize,\n) -> Pin<Box<dyn Future<Output = BoxStream<'static, BlockQueryData<Types>>> + Send + 'async_trait>>
    where\n Self: Sync + 'async_trait,\n 'life0: 'async_trait,

    source§

    fn subscribe_payloads<'life0, 'async_trait>(\n &'life0 self,\n from: usize,\n) -> Pin<Box<dyn Future<Output = BoxStream<'static, PayloadQueryData<Types>>> + Send + 'async_trait>>
    where\n Self: Sync + 'async_trait,\n 'life0: 'async_trait,

    source§

    fn subscribe_leaves<'life0, 'async_trait>(\n &'life0 self,\n from: usize,\n) -> Pin<Box<dyn Future<Output = BoxStream<'static, LeafQueryData<Types>>> + Send + 'async_trait>>
    where\n Self: Sync + 'async_trait,\n 'life0: 'async_trait,

    source§

    fn subscribe_vid_common<'life0, 'async_trait>(\n &'life0 self,\n from: usize,\n) -> Pin<Box<dyn Future<Output = BoxStream<'static, VidCommonQueryData<Types>>> + Send + 'async_trait>>
    where\n Self: Sync + 'async_trait,\n 'life0: 'async_trait,

    ","AvailabilityDataSource","hotshot_query_service::data_source::fs::FileSystemDataSource","hotshot_query_service::data_source::sql::SqlDataSource"],["
    source§

    impl<Types, S, P> Clone for FetchingDataSource<Types, S, P>
    where\n Types: NodeType,

    source§

    fn clone(&self) -> Self

    Returns a copy of the value. Read more
    1.0.0 · source§

    fn clone_from(&mut self, source: &Self)

    Performs copy-assignment from source. Read more
    ","Clone","hotshot_query_service::data_source::fs::FileSystemDataSource","hotshot_query_service::data_source::sql::SqlDataSource"],["
    source§

    impl<Types, S, P> Debug for FetchingDataSource<Types, S, P>
    where\n Types: NodeType,\n S: Debug,\n P: Debug,

    source§

    fn fmt(&self, __f: &mut Formatter<'_>) -> Result

    Formats the value using the given formatter. Read more
    ","Debug","hotshot_query_service::data_source::fs::FileSystemDataSource","hotshot_query_service::data_source::sql::SqlDataSource"],["
    source§

    impl<Types, S, P> ExplorerDataSource<Types> for FetchingDataSource<Types, S, P>
    where\n Types: NodeType,\n Payload<Types>: QueryablePayload<Types>,\n Header<Types>: QueryableHeader<Types> + ExplorerHeader<Types>,\n Transaction<Types>: ExplorerTransaction,\n S: VersionedDataSource + 'static,\n for<'a> S::ReadOnly<'a>: ExplorerStorage<Types>,\n P: Send + Sync,

    source§

    fn get_block_summaries<'life0, 'async_trait>(\n &'life0 self,\n request: GetBlockSummariesRequest<Types>,\n) -> Pin<Box<dyn Future<Output = Result<Vec<BlockSummary<Types>>, GetBlockSummariesError>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    get_block_summaries is a method that retrieves a list of block\nsummaries from the blockchain. The list is generated from the given\nGetBlockSummariesRequest.
    source§

    fn get_block_detail<'life0, 'async_trait>(\n &'life0 self,\n request: BlockIdentifier<Types>,\n) -> Pin<Box<dyn Future<Output = Result<BlockDetail<Types>, GetBlockDetailError>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    get_block_detail is a method that retrieves the details of a specific\nblock from the blockchain. The block is identified by the given\nBlockIdentifier.
    source§

    fn get_transaction_summaries<'life0, 'async_trait>(\n &'life0 self,\n request: GetTransactionSummariesRequest<Types>,\n) -> Pin<Box<dyn Future<Output = Result<Vec<TransactionSummary<Types>>, GetTransactionSummariesError>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    get_transaction_summaries is a method that retrieves a list of\ntransaction summaries from the blockchain. The list is generated from\nthe given GetTransactionSummariesRequest.
    source§

    fn get_transaction_detail<'life0, 'async_trait>(\n &'life0 self,\n request: TransactionIdentifier<Types>,\n) -> Pin<Box<dyn Future<Output = Result<TransactionDetailResponse<Types>, GetTransactionDetailError>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    get_transaction_detail is a method that retrieves the details of a\nspecific transaction from the blockchain. The transaction is identified\nby the given TransactionIdentifier.
    source§

    fn get_explorer_summary<'life0, 'async_trait>(\n &'life0 self,\n) -> Pin<Box<dyn Future<Output = Result<ExplorerSummary<Types>, GetExplorerSummaryError>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    get_explorer_summary is a method that retrieves a summary overview of\nthe blockchain. This is useful for displaying information that\nindicates the overall status of the block chain.
    source§

    fn get_search_results<'life0, 'async_trait>(\n &'life0 self,\n query: String,\n) -> Pin<Box<dyn Future<Output = Result<SearchResult<Types>, GetSearchResultsError>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    get_search_results is a method that retrieves the results of a search\nquery against the blockchain. The results are generated from the given\nquery string.
    ","ExplorerDataSource","hotshot_query_service::data_source::fs::FileSystemDataSource","hotshot_query_service::data_source::sql::SqlDataSource"],["
    source§

    impl<Types, S, P> FetchingDataSource<Types, S, P>
    where\n Types: NodeType,\n Payload<Types>: QueryablePayload<Types>,\n Header<Types>: QueryableHeader<Types>,\n S: VersionedDataSource + PruneStorage + 'static,\n for<'a> S::Transaction<'a>: UpdateAvailabilityData<Types>,\n for<'a> S::ReadOnly<'a>: AvailabilityStorage<Types> + NodeStorage<Types> + PrunedHeightStorage,\n P: AvailabilityProvider<Types>,

    source

    pub fn builder(storage: S, provider: P) -> Builder<Types, S, P>

    Build a FetchingDataSource with the given storage and provider.

    \n
    ",0,"hotshot_query_service::data_source::fs::FileSystemDataSource","hotshot_query_service::data_source::sql::SqlDataSource"],["
    source§

    impl<Types, S, P> HasMetrics for FetchingDataSource<Types, S, P>
    where\n Types: NodeType,\n S: HasMetrics,

    ","HasMetrics","hotshot_query_service::data_source::fs::FileSystemDataSource","hotshot_query_service::data_source::sql::SqlDataSource"],["
    source§

    impl<Types, S, P, State, const ARITY: usize> MerklizedStateDataSource<Types, State, ARITY> for FetchingDataSource<Types, S, P>
    where\n Types: NodeType,\n S: VersionedDataSource + 'static,\n for<'a> S::ReadOnly<'a>: MerklizedStateStorage<Types, State, ARITY>,\n P: Send + Sync,\n State: MerklizedState<Types, ARITY> + 'static,\n <State as MerkleTreeScheme>::Commitment: Send,

    source§

    fn get_path<'life0, 'async_trait>(\n &'life0 self,\n snapshot: Snapshot<Types, State, ARITY>,\n key: State::Key,\n) -> Pin<Box<dyn Future<Output = QueryResult<MerkleProof<State::Entry, State::Key, State::T, ARITY>>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    ","MerklizedStateDataSource","hotshot_query_service::data_source::fs::FileSystemDataSource","hotshot_query_service::data_source::sql::SqlDataSource"],["
    source§

    impl<Types, S, P> MerklizedStateHeightPersistence for FetchingDataSource<Types, S, P>
    where\n Types: NodeType,\n Payload<Types>: QueryablePayload<Types>,\n S: VersionedDataSource + 'static,\n for<'a> S::ReadOnly<'a>: MerklizedStateHeightStorage,\n P: Send + Sync,

    source§

    fn get_last_state_height<'life0, 'async_trait>(\n &'life0 self,\n) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    ","MerklizedStateHeightPersistence","hotshot_query_service::data_source::fs::FileSystemDataSource","hotshot_query_service::data_source::sql::SqlDataSource"],["
    source§

    impl<Types, S, P> NodeDataSource<Types> for FetchingDataSource<Types, S, P>
    where\n Types: NodeType,\n S: VersionedDataSource + 'static,\n for<'a> S::ReadOnly<'a>: NodeStorage<Types>,\n P: Send + Sync,

    source§

    fn block_height<'life0, 'async_trait>(\n &'life0 self,\n) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    source§

    fn count_transactions<'life0, 'async_trait>(\n &'life0 self,\n) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    source§

    fn payload_size<'life0, 'async_trait>(\n &'life0 self,\n) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    source§

    fn vid_share<'life0, 'async_trait, ID>(\n &'life0 self,\n id: ID,\n) -> Pin<Box<dyn Future<Output = QueryResult<VidShare>> + Send + 'async_trait>>
    where\n ID: Into<BlockId<Types>> + Send + Sync + 'async_trait,\n Self: 'async_trait,\n 'life0: 'async_trait,

    source§

    fn sync_status<'life0, 'async_trait>(\n &'life0 self,\n) -> Pin<Box<dyn Future<Output = QueryResult<SyncStatus>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    Search the database for missing objects and generate a report.
    source§

    fn get_header_window<'life0, 'async_trait>(\n &'life0 self,\n start: impl 'async_trait + Into<WindowStart<Types>> + Send + Sync,\n end: u64,\n) -> Pin<Box<dyn Future<Output = QueryResult<TimeWindowQueryData<Header<Types>>>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    ","NodeDataSource","hotshot_query_service::data_source::fs::FileSystemDataSource","hotshot_query_service::data_source::sql::SqlDataSource"],["
    source§

    impl<Types, S, P> StatusDataSource for FetchingDataSource<Types, S, P>
    where\n Types: NodeType,\n S: VersionedDataSource + HasMetrics + Send + Sync + 'static,\n for<'a> S::ReadOnly<'a>: NodeStorage<Types>,\n P: Send + Sync,

    source§

    fn block_height<'life0, 'async_trait>(\n &'life0 self,\n) -> Pin<Box<dyn Future<Output = QueryResult<usize>> + Send + 'async_trait>>
    where\n Self: 'async_trait,\n 'life0: 'async_trait,

    source§

    fn consensus_metrics(&self) -> QueryResult<PrometheusMetrics>

    source§

    fn elapsed_time_since_last_decide<'life0, 'async_trait>(\n &'life0 self,\n) -> Pin<Box<dyn Future<Output = QueryResult<u64>> + Send + 'async_trait>>
    where\n Self: Sync + 'async_trait,\n 'life0: 'async_trait,

    source§

    fn success_rate<'life0, 'async_trait>(\n &'life0 self,\n) -> Pin<Box<dyn Future<Output = QueryResult<f64>> + Send + 'async_trait>>
    where\n Self: Sync + 'async_trait,\n 'life0: 'async_trait,

    ","StatusDataSource","hotshot_query_service::data_source::fs::FileSystemDataSource","hotshot_query_service::data_source::sql::SqlDataSource"],["
    source§

    impl<Types, S, P> VersionedDataSource for FetchingDataSource<Types, S, P>
    where\n Types: NodeType,\n S: VersionedDataSource + Send + Sync,\n P: Send + Sync,

    source§

    type Transaction<'a> = Transaction<'a, Types, <S as VersionedDataSource>::Transaction<'a>>\nwhere\n Self: 'a

    A transaction which can read and modify the data source.
    source§

    type ReadOnly<'a> = Transaction<'a, Types, <S as VersionedDataSource>::ReadOnly<'a>>\nwhere\n Self: 'a

    source§

    async fn write(&self) -> Result<Self::Transaction<'_>>

    Start an atomic transaction on the data source.
    source§

    async fn read(&self) -> Result<Self::ReadOnly<'_>>

    Start a read-only transaction on the data source. Read more
    ","VersionedDataSource","hotshot_query_service::data_source::fs::FileSystemDataSource","hotshot_query_service::data_source::sql::SqlDataSource"]]]]); if (window.register_type_impls) { window.register_type_impls(type_impls); } else { window.pending_type_impls = type_impls; } })() -//{"start":55,"fragment_lengths":[97613]} \ No newline at end of file +//{"start":55,"fragment_lengths":[98961]} \ No newline at end of file diff --git a/type.impl/hotshot_query_service/data_source/storage/sql/struct.Config.js b/type.impl/hotshot_query_service/data_source/storage/sql/struct.Config.js index 817ee9fea..2e8bcf2d4 100644 --- a/type.impl/hotshot_query_service/data_source/storage/sql/struct.Config.js +++ b/type.impl/hotshot_query_service/data_source/storage/sql/struct.Config.js @@ -1,5 +1,5 @@ (function() { - var type_impls = Object.fromEntries([["hotshot_query_service",[["
    source§

    impl<DB> Clone for Config<DB>
    where\n DB: Database + Clone,\n DB::Connection: Clone,

    source§

    fn clone(&self) -> Config<DB>

    Returns a copy of the value. Read more
    1.0.0 · source§

    fn clone_from(&mut self, source: &Self)

    Performs copy-assignment from source. Read more
    ","Clone","hotshot_query_service::data_source::sql::Config"],["
    source§

    impl<DB: Database> Config<DB>

    source

    pub fn schema(self, schema: impl Into<String>) -> Self

    Set the name of the schema to use for queries.

    \n

    The default schema is named hotshot and is created via the default migrations.

    \n
    source

    pub fn reset_schema(self) -> Self

    Reset the schema on connection.

    \n

    When this Config is used to connect a\nSqlDataSource, if this option is set, the relevant\nschema will first be dropped and then recreated, yielding a completely\nfresh instance of the query service.

    \n

    This is a particularly useful capability for development and staging environments. Still, it\nmust be used with extreme caution, as using this will irrevocably delete any data pertaining\nto the query service in the database.

    \n
    source

    pub fn migrations(self, migrations: impl IntoIterator<Item = Migration>) -> Self

    Add custom migrations to run when connecting to the database.

    \n
    source

    pub fn no_migrations(self) -> Self

    Skip all migrations when connecting to the database.

    \n
    source

    pub fn pruner_cfg(self, cfg: PrunerCfg) -> Result<Self, Error>

    Enable pruning with a given configuration.

    \n

    If archive was previously specified, this will override it.

    \n
    source

    pub fn archive(self) -> Self

    Disable pruning and reconstruct previously pruned data.

    \n

    While running without pruning is the default behavior, the default will not try to\nreconstruct data that was pruned in a previous run where pruning was enabled. This option\ninstructs the service to run without pruning and reconstruct all previously pruned data by\nfetching from peers.

    \n

    If pruner_cfg was previously specified, this will override it.

    \n
    source

    pub fn idle_connection_timeout(self, timeout: Duration) -> Self

    Set the maximum idle time of a connection.

    \n

    Any connection which has been open and unused longer than this duration will be\nautomatically closed to reduce load on the server.

    \n
    source

    pub fn connection_timeout(self, timeout: Duration) -> Self

    Set the maximum lifetime of a connection.

    \n

    Any connection which has been open longer than this duration will be automatically closed\n(and, if needed, replaced), even if it is otherwise healthy. It is good practice to refresh\neven healthy connections once in a while (e.g. daily) in case of resource leaks in the\nserver implementation.

    \n
    source

    pub fn min_connections(self, min: u32) -> Self

    Set the minimum number of connections to maintain at any time.

    \n

    The data source will, to the best of its ability, maintain at least min open connections\nat all times. This can be used to reduce the latency hit of opening new connections when at\nleast this many simultaneous connections are frequently needed.

    \n
    source

    pub fn max_connections(self, max: u32) -> Self

    Set the maximum number of connections to maintain at any time.

    \n

    Once max connections are in use simultaneously, further attempts to acquire a connection\n(or begin a transaction) will block until one of the existing connections is released.

    \n
    ",0,"hotshot_query_service::data_source::sql::Config"],["
    source§

    impl Config<Postgres>

    source

    pub fn host(self, host: impl Into<String>) -> Self

    Set the hostname of the database server.

    \n

    The default is localhost.

    \n
    source

    pub fn port(self, port: u16) -> Self

    Set the port on which to connect to the database.

    \n

    The default is 5432, the default Postgres port.

    \n
    source

    pub fn user(self, user: &str) -> Self

    Set the DB user to connect as.

    \n
    source

    pub fn password(self, password: &str) -> Self

    Set a password for connecting to the database.

    \n
    source

    pub fn database(self, database: &str) -> Self

    Set the name of the database to connect to.

    \n
    source

    pub fn tls(self) -> Self

    Use TLS for an encrypted connection to the database.

    \n

    Note that an encrypted connection may be established even if this option is not set, as long\nas both the client and server support it. This option merely causes connection to fail if an\nencrypted stream cannot be established.

    \n
    ",0,"hotshot_query_service::data_source::sql::Config"],["
    source§

    impl<DB> Debug for Config<DB>
    where\n DB: Database + Debug,\n DB::Connection: Debug,

    source§

    fn fmt(&self, f: &mut Formatter<'_>) -> Result

    Formats the value using the given formatter. Read more
    ","Debug","hotshot_query_service::data_source::sql::Config"],["
    source§

    impl Default for Config<Postgres>

    source§

    fn default() -> Self

    Returns the “default value” for a type. Read more
    ","Default","hotshot_query_service::data_source::sql::Config"],["
    source§

    impl From<PgConnectOptions> for Config<Postgres>

    source§

    fn from(db_opt: PgConnectOptions) -> Self

    Converts to this type from the input type.
    ","From","hotshot_query_service::data_source::sql::Config"],["
    source§

    impl FromStr for Config<Postgres>

    source§

    type Err = <PgConnectOptions as FromStr>::Err

    The associated error which can be returned from parsing.
    source§

    fn from_str(s: &str) -> Result<Self, Self::Err>

    Parses a string s to return a value of this type. Read more
    ","FromStr","hotshot_query_service::data_source::sql::Config"]]]]); + var type_impls = Object.fromEntries([["hotshot_query_service",[["
    source§

    impl<DB> Clone for Config<DB>
    where\n DB: Database + Clone,\n DB::Connection: Clone,

    source§

    fn clone(&self) -> Config<DB>

    Returns a copy of the value. Read more
    1.0.0 · source§

    fn clone_from(&mut self, source: &Self)

    Performs copy-assignment from source. Read more
    ","Clone","hotshot_query_service::data_source::sql::Config"],["
    source§

    impl<DB: Database> Config<DB>

    source

    pub fn schema(self, schema: impl Into<String>) -> Self

    Set the name of the schema to use for queries.

    \n

    The default schema is named hotshot and is created via the default migrations.

    \n
    source

    pub fn reset_schema(self) -> Self

    Reset the schema on connection.

    \n

    When this Config is used to connect a\nSqlDataSource, if this option is set, the relevant\nschema will first be dropped and then recreated, yielding a completely\nfresh instance of the query service.

    \n

    This is a particularly useful capability for development and staging environments. Still, it\nmust be used with extreme caution, as using this will irrevocably delete any data pertaining\nto the query service in the database.

    \n
    source

    pub fn migrations(self, migrations: impl IntoIterator<Item = Migration>) -> Self

    Add custom migrations to run when connecting to the database.

    \n
    source

    pub fn no_migrations(self) -> Self

    Skip all migrations when connecting to the database.

    \n
    source

    pub fn pruner_cfg(self, cfg: PrunerCfg) -> Result<Self, Error>

    Enable pruning with a given configuration.

    \n

    If archive was previously specified, this will override it.

    \n
    source

    pub fn archive(self) -> Self

    Disable pruning and reconstruct previously pruned data.

    \n

    While running without pruning is the default behavior, the default will not try to\nreconstruct data that was pruned in a previous run where pruning was enabled. This option\ninstructs the service to run without pruning and reconstruct all previously pruned data by\nfetching from peers.

    \n

    If pruner_cfg was previously specified, this will override it.

    \n
    source

    pub fn idle_connection_timeout(self, timeout: Duration) -> Self

    Set the maximum idle time of a connection.

    \n

    Any connection which has been open and unused longer than this duration will be\nautomatically closed to reduce load on the server.

    \n
    source

    pub fn connection_timeout(self, timeout: Duration) -> Self

    Set the maximum lifetime of a connection.

    \n

    Any connection which has been open longer than this duration will be automatically closed\n(and, if needed, replaced), even if it is otherwise healthy. It is good practice to refresh\neven healthy connections once in a while (e.g. daily) in case of resource leaks in the\nserver implementation.

    \n
    source

    pub fn min_connections(self, min: u32) -> Self

    Set the minimum number of connections to maintain at any time.

    \n

    The data source will, to the best of its ability, maintain at least min open connections\nat all times. This can be used to reduce the latency hit of opening new connections when at\nleast this many simultaneous connections are frequently needed.

    \n
    source

    pub fn max_connections(self, max: u32) -> Self

    Set the maximum number of connections to maintain at any time.

    \n

    Once max connections are in use simultaneously, further attempts to acquire a connection\n(or begin a transaction) will block until one of the existing connections is released.

    \n
    ",0,"hotshot_query_service::data_source::sql::Config"],["
    source§

    impl Config<Postgres>

    source

    pub fn host(self, host: impl Into<String>) -> Self

    Set the hostname of the database server.

    \n

    The default is localhost.

    \n
    source

    pub fn port(self, port: u16) -> Self

    Set the port on which to connect to the database.

    \n

    The default is 5432, the default Postgres port.

    \n
    source

    pub fn user(self, user: &str) -> Self

    Set the DB user to connect as.

    \n
    source

    pub fn password(self, password: &str) -> Self

    Set a password for connecting to the database.

    \n
    source

    pub fn database(self, database: &str) -> Self

    Set the name of the database to connect to.

    \n
    source

    pub fn tls(self) -> Self

    Use TLS for an encrypted connection to the database.

    \n

    Note that an encrypted connection may be established even if this option is not set, as long\nas both the client and server support it. This option merely causes connection to fail if an\nencrypted stream cannot be established.

    \n
    ",0,"hotshot_query_service::data_source::sql::Config"],["
    source§

    impl<DB> Debug for Config<DB>
    where\n DB: Database + Debug,\n DB::Connection: Debug,

    source§

    fn fmt(&self, f: &mut Formatter<'_>) -> Result

    Formats the value using the given formatter. Read more
    ","Debug","hotshot_query_service::data_source::sql::Config"],["
    source§

    impl Default for Config<Postgres>

    source§

    fn default() -> Self

    Returns the “default value” for a type. Read more
    ","Default","hotshot_query_service::data_source::sql::Config"],["
    source§

    impl From<PgConnectOptions> for Config<Postgres>

    source§

    fn from(db_opt: PgConnectOptions) -> Self

    Converts to this type from the input type.
    ","From","hotshot_query_service::data_source::sql::Config"],["
    source§

    impl FromStr for Config<Postgres>

    source§

    type Err = <PgConnectOptions as FromStr>::Err

    The associated error which can be returned from parsing.
    source§

    fn from_str(s: &str) -> Result<Self, Self::Err>

    Parses a string s to return a value of this type. Read more
    ","FromStr","hotshot_query_service::data_source::sql::Config"]]]]); if (window.register_type_impls) { window.register_type_impls(type_impls); } else {