Skip to main content

linera_core/chain_worker/
config.rs

1// Copyright (c) Zefchain Labs, Inc.
2// SPDX-License-Identifier: Apache-2.0
3
4//! Configuration parameters for the chain worker.
5
6use std::{collections::HashSet, sync::Arc};
7
8use linera_base::{crypto::ValidatorSecretKey, identifiers::ChainId, time::Duration};
9
10use crate::CHAIN_INFO_MAX_RECEIVED_LOG_ENTRIES;
11
12/// Configuration parameters for the chain worker and its owning
13/// [`WorkerState`][`crate::worker::WorkerState`].
14#[derive(Clone)]
15pub struct ChainWorkerConfig {
16    /// A name used for logging.
17    pub nickname: String,
18    /// The signature key pair of the validator. The key may be missing for replicas
19    /// without voting rights (possibly with a partial view of chains).
20    pub key_pair: Option<Arc<ValidatorSecretKey>>,
21    /// Whether inactive chains are allowed in storage.
22    pub allow_inactive_chains: bool,
23    /// Whether the user application services should be long-lived.
24    pub long_lived_services: bool,
25    /// Blocks with a timestamp this far in the future will still be accepted, but the validator
26    /// will wait until that timestamp before voting.
27    pub block_time_grace_period: Duration,
28    /// Idle chain workers free their memory after this duration without requests.
29    /// `None` means no expiry (handle lives forever).
30    pub ttl: Option<Duration>,
31    /// TTL for sender chains. `None` means no expiry.
32    pub sender_chain_ttl: Option<Duration>,
33    /// The size to truncate receive log entries in chain info responses.
34    pub chain_info_max_received_log_entries: usize,
35    /// Maximum number of entries in the block cache.
36    pub block_cache_size: usize,
37    /// Maximum number of entries in the execution state cache.
38    pub execution_state_cache_size: usize,
39    /// Maximum estimated serialized size of bundles in a single `UpdateRecipient`
40    /// cross-chain message. When exceeded, the bundles are split into multiple requests.
41    /// Defaults to `usize::MAX` (no chunking).
42    pub cross_chain_message_chunk_limit: usize,
43    /// Maximum number of cross-chain requests coalesced into a single batch by the
44    /// per-chain driver. Smaller values bound the worst-case write-lock hold time at
45    /// the cost of more lock acquisitions; larger values amortize lock and storage
46    /// overhead better.
47    pub cross_chain_batch_size_limit: usize,
48    /// Whether to attempt recovery via `RevertConfirm` when an inbox gap is detected.
49    pub allow_revert_confirm: bool,
50    /// If set, reset the chain state and re-execute all blocks when the chain
51    /// state is detected to be corrupted — but only if the given duration has
52    /// elapsed since block 0 was last executed (to prevent reset loops).
53    pub reset_on_corrupted_chain_state: Option<Duration>,
54    /// Optional whitelist restricting which chains are eligible for the
55    /// `allow_revert_confirm` and `reset_on_corrupted_chain_state` recovery
56    /// mechanisms. If `None`, every chain is eligible (subject to the
57    /// respective feature flag). If `Some`, only chains in the set are.
58    pub recovery_whitelist: Option<HashSet<ChainId>>,
59}
60
61impl ChainWorkerConfig {
62    /// Configures the `key_pair` in this [`ChainWorkerConfig`].
63    #[cfg(with_testing)]
64    pub fn with_key_pair(mut self, key_pair: Option<ValidatorSecretKey>) -> Self {
65        self.key_pair = key_pair.map(Arc::new);
66        self
67    }
68
69    /// Gets a reference to the [`ValidatorSecretKey`], if available.
70    pub fn key_pair(&self) -> Option<&ValidatorSecretKey> {
71        self.key_pair.as_ref().map(Arc::as_ref)
72    }
73
74    /// Returns whether `chain_id` is allowed to attempt the `RevertConfirm` and
75    /// corrupted-state-reset recovery mechanisms.
76    pub(crate) fn recovery_allowed_for(&self, chain_id: &ChainId) -> bool {
77        self.recovery_whitelist
78            .as_ref()
79            .is_none_or(|set| set.contains(chain_id))
80    }
81}
82
83impl Default for ChainWorkerConfig {
84    fn default() -> Self {
85        Self {
86            nickname: String::new(),
87            key_pair: None,
88            allow_inactive_chains: false,
89            long_lived_services: false,
90            block_time_grace_period: Default::default(),
91            ttl: None,
92            sender_chain_ttl: Some(Duration::from_secs(1)),
93            chain_info_max_received_log_entries: CHAIN_INFO_MAX_RECEIVED_LOG_ENTRIES,
94            block_cache_size: 5000,
95            execution_state_cache_size: 10_000,
96            cross_chain_message_chunk_limit: usize::MAX,
97            cross_chain_batch_size_limit: 1000,
98            allow_revert_confirm: false,
99            reset_on_corrupted_chain_state: None,
100            recovery_whitelist: None,
101        }
102    }
103}