NodeConfig

Struct NodeConfig 

Source
pub struct NodeConfig {
Show 51 fields pub authority_key_pair: AuthorityKeyPairWithPath, pub protocol_key_pair: KeyPairWithPath, pub account_key_pair: KeyPairWithPath, pub network_key_pair: KeyPairWithPath, pub db_path: PathBuf, pub network_address: Multiaddr, pub json_rpc_address: SocketAddr, pub enable_rest_api: bool, pub rest: Option<Config>, pub metrics_address: SocketAddr, pub admin_interface_address: SocketAddr, pub consensus_config: Option<ConsensusConfig>, pub enable_index_processing: bool, pub remove_deprecated_tables: bool, pub jsonrpc_server_type: Option<ServerType>, pub grpc_load_shed: Option<bool>, pub grpc_concurrency_limit: Option<usize>, pub p2p_config: P2pConfig, pub genesis: Genesis, pub migration_tx_data_path: Option<PathBuf>, pub authority_store_pruning_config: AuthorityStorePruningConfig, pub end_of_epoch_broadcast_channel_capacity: usize, pub checkpoint_executor_config: CheckpointExecutorConfig, pub metrics: Option<MetricsConfig>, pub supported_protocol_versions: Option<SupportedProtocolVersions>, pub db_checkpoint_config: DBCheckpointConfig, pub expensive_safety_check_config: ExpensiveSafetyCheckConfig, pub transaction_deny_config: TransactionDenyConfig, pub certificate_deny_config: CertificateDenyConfig, pub state_debug_dump_config: StateDebugDumpConfig, pub state_archive_write_config: StateArchiveConfig, pub state_archive_read_config: Vec<StateArchiveConfig>, pub state_snapshot_write_config: StateSnapshotConfig, pub indexer_max_subscriptions: Option<usize>, pub transaction_kv_store_read_config: TransactionKeyValueStoreReadConfig, pub transaction_kv_store_write_config: Option<TransactionKeyValueStoreWriteConfig>, pub jwk_fetch_interval_seconds: u64, pub zklogin_oauth_providers: BTreeMap<Chain, BTreeSet<String>>, pub authority_overload_config: AuthorityOverloadConfig, pub run_with_range: Option<RunWithRange>, pub policy_config: Option<PolicyConfig>, pub firewall_config: Option<RemoteFirewallConfig>, pub execution_cache: ExecutionCacheType, pub execution_cache_config: ExecutionCacheConfig, pub enable_validator_tx_finalizer: bool, pub verifier_signing_config: VerifierSigningConfig, pub enable_db_write_stall: Option<bool>, pub iota_names_config: Option<IotaNamesConfig>, pub enable_grpc_api: bool, pub grpc_api_config: Option<GrpcApiConfig>, pub chain_override_for_testing: Option<Chain>,
}

Fields§

§authority_key_pair: AuthorityKeyPairWithPath

The public key bytes corresponding to the private key that the validator holds to sign transactions.

§protocol_key_pair: KeyPairWithPath

The public key bytes corresponding to the private key that the validator holds to sign consensus blocks.

§account_key_pair: KeyPairWithPath§network_key_pair: KeyPairWithPath

The public key bytes corresponding to the private key that the validator uses to establish TLS connections.

§db_path: PathBuf§network_address: Multiaddr

The network address for gRPC communication.

Can be overwritten with args listen-address parameters.

§json_rpc_address: SocketAddr§enable_rest_api: bool

Flag to enable the REST API under /api/v1 endpoint on the same interface as json rpc server.

§rest: Option<Config>§metrics_address: SocketAddr

The address for Prometheus metrics.

§admin_interface_address: SocketAddr

The address for the admin interface that is run in the metrics separate runtime and provides access to admin node commands such as logging and tracing options.

§consensus_config: Option<ConsensusConfig>

Configuration struct for the consensus.

§enable_index_processing: bool

Flag to enable index processing for a full node.

If set to true, node creates IndexStore for transaction data including ownership and balance information.

§remove_deprecated_tables: bool§jsonrpc_server_type: Option<ServerType>

Determines the jsonrpc server type as either:

  • ‘websocket’ for a websocket based service (deprecated)
  • ‘http’ for an http based service
  • ‘both’ for both a websocket and http based service (deprecated)
§grpc_load_shed: Option<bool>

Flag to enable gRPC load shedding to manage and mitigate overload conditions by shedding excess load with LoadShedLayer middleware.

§grpc_concurrency_limit: Option<usize>§p2p_config: P2pConfig

Configuration struct for P2P.

§genesis: Genesis

Contains genesis location that might be InPlace for reading all genesis data to memory or InFile, and OnceCell pointer to a genesis struct.

§migration_tx_data_path: Option<PathBuf>

Contains the path where to find the migration blob.

§authority_store_pruning_config: AuthorityStorePruningConfig

Configuration for pruning of the authority store, to define when an old data is removed from the storage space.

§end_of_epoch_broadcast_channel_capacity: usize

Size of the broadcast channel used for notifying other systems of end of epoch.

If unspecified, this will default to 128.

§checkpoint_executor_config: CheckpointExecutorConfig

Configuration for the checkpoint executor for limiting the number of checkpoints to execute concurrently, and to allow for checkpoint post-processing.

§metrics: Option<MetricsConfig>§supported_protocol_versions: Option<SupportedProtocolVersions>

In a iota-node binary, this is set to SupportedProtocolVersions::SYSTEM_DEFAULT in iota-node/src/main.rs. It is present in the config so that it can be changed by tests in order to test protocol upgrades.

§db_checkpoint_config: DBCheckpointConfig

Configuration to manage database checkpoints, including whether to perform checkpoints at the end of an epoch, the path for storing checkpoints, and other related settings.

§expensive_safety_check_config: ExpensiveSafetyCheckConfig

Configuration for enabling/disabling expensive safety checks.

§transaction_deny_config: TransactionDenyConfig

Configuration to specify rules for denying transactions based on objectsIDs, addresses, or enable/disable many features such as publishing new packages or using shared objects.

§certificate_deny_config: CertificateDenyConfig

Config used to deny execution for certificate digests know for crashing or hanging validator nodes.

Should be used for a fast temporary fixes and removed once the issue is fixed.

§state_debug_dump_config: StateDebugDumpConfig

Used to determine how state debug information is dumped when a node forks.

§state_archive_write_config: StateArchiveConfig

Configuration for writing state archive. If ObjectStorage config is provided, ArchiveWriter will be created for checkpoints archival.

§state_archive_read_config: Vec<StateArchiveConfig>§state_snapshot_write_config: StateSnapshotConfig

Determines if snapshot should be uploaded to the remote storage.

§indexer_max_subscriptions: Option<usize>§transaction_kv_store_read_config: TransactionKeyValueStoreReadConfig§transaction_kv_store_write_config: Option<TransactionKeyValueStoreWriteConfig>§jwk_fetch_interval_seconds: u64§zklogin_oauth_providers: BTreeMap<Chain, BTreeSet<String>>§authority_overload_config: AuthorityOverloadConfig

Configuration for defining thresholds and settings for managing system overload conditions in a node.

§run_with_range: Option<RunWithRange>

Specifies the ending epoch for a node for debugging purposes.

Ignored if set by config, can be configured only by cli arguments.

§policy_config: Option<PolicyConfig>§firewall_config: Option<RemoteFirewallConfig>§execution_cache: ExecutionCacheType§execution_cache_config: ExecutionCacheConfig§enable_validator_tx_finalizer: bool§verifier_signing_config: VerifierSigningConfig§enable_db_write_stall: Option<bool>

If a value is set, it determines if writes to DB can stall, which can halt the whole process. By default, write stall is enabled on validators but not on fullnodes.

§iota_names_config: Option<IotaNamesConfig>§enable_grpc_api: bool

Flag to enable the gRPC API.

§grpc_api_config: Option<GrpcApiConfig>§chain_override_for_testing: Option<Chain>

Allow overriding the chain for testing purposes. For instance, it allows you to create a test network that believes it is mainnet or testnet. Attempting to override this value on production networks will result in an error.

Implementations§

Trait Implementations§

Source§

impl Clone for NodeConfig

Source§

fn clone(&self) -> NodeConfig

Returns a duplicate 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 Config for NodeConfig

Source§

fn persisted(self, path: &Path) -> PersistedConfig<Self>

Source§

fn load<P: AsRef<Path>>(path: P) -> Result<Self, Error>

Source§

fn save<P: AsRef<Path>>(&self, path: P) -> Result<(), Error>

Source§

impl Debug for NodeConfig

Source§

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

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

impl<'de> Deserialize<'de> for NodeConfig

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 Serialize for NodeConfig

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<U> As for U

§

fn as_<T>(self) -> T
where T: CastFrom<U>,

Casts self to type T. The semantics of numeric casting with the as operator are followed, so <T as As>::as_::<U> can be used in the same way as T as U for numeric conversions. Read more
§

impl<'a, T, E> AsTaggedExplicit<'a, E> for T
where T: 'a,

§

fn explicit(self, class: Class, tag: u32) -> TaggedParser<'a, Explicit, Self, E>

§

impl<'a, T, E> AsTaggedImplicit<'a, E> for T
where T: 'a,

§

fn implicit( self, class: Class, constructed: bool, tag: u32, ) -> TaggedParser<'a, Implicit, Self, E>

Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
§

impl<T> Conv for T

§

fn conv<T>(self) -> T
where Self: Into<T>,

Converts self into T using Into<T>. Read more
§

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

§

fn convert(self) -> Result<T, Error>

§

fn convert_unchecked(self) -> T

Source§

impl<T> DynClone for T
where T: Clone,

Source§

fn __clone_box(&self, _: Private) -> *mut ()

§

impl<T> FmtForward for T

§

fn fmt_binary(self) -> FmtBinary<Self>
where Self: Binary,

Causes self to use its Binary implementation when Debug-formatted.
§

fn fmt_display(self) -> FmtDisplay<Self>
where Self: Display,

Causes self to use its Display implementation when Debug-formatted.
§

fn fmt_lower_exp(self) -> FmtLowerExp<Self>
where Self: LowerExp,

Causes self to use its LowerExp implementation when Debug-formatted.
§

fn fmt_lower_hex(self) -> FmtLowerHex<Self>
where Self: LowerHex,

Causes self to use its LowerHex implementation when Debug-formatted.
§

fn fmt_octal(self) -> FmtOctal<Self>
where Self: Octal,

Causes self to use its Octal implementation when Debug-formatted.
§

fn fmt_pointer(self) -> FmtPointer<Self>
where Self: Pointer,

Causes self to use its Pointer implementation when Debug-formatted.
§

fn fmt_upper_exp(self) -> FmtUpperExp<Self>
where Self: UpperExp,

Causes self to use its UpperExp implementation when Debug-formatted.
§

fn fmt_upper_hex(self) -> FmtUpperHex<Self>
where Self: UpperHex,

Causes self to use its UpperHex implementation when Debug-formatted.
§

fn fmt_list(self) -> FmtList<Self>
where &'a Self: for<'a> IntoIterator,

Formats each item in a sequence. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> FromRef<T> for T
where T: Clone,

§

fn from_ref(input: &T) -> T

Converts to this type from a reference to the input type.
§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

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

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
§

impl<T> IntoRequest<T> for T

§

fn into_request(self) -> Request<T>

Wrap the input message T in a Request
§

impl<T> IntoRequest<T> for T

§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
§

impl<L> LayerExt<L> for L

§

fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>
where L: Layer<S>,

Applies the layer to a service and wraps it in [Layered].
§

impl<T> Pipe for T
where T: ?Sized,

§

fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> R
where Self: Sized,

Pipes by value. This is generally the method you want to use. Read more
§

fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> R
where R: 'a,

Borrows self and passes that borrow into the pipe function. Read more
§

fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> R
where R: 'a,

Mutably borrows self and passes that borrow into the pipe function. Read more
§

fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
where Self: Borrow<B>, B: 'a + ?Sized, R: 'a,

Borrows self, then passes self.borrow() into the pipe function. Read more
§

fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
where Self: BorrowMut<B>, B: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.borrow_mut() into the pipe function. Read more
§

fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
where Self: AsRef<U>, U: 'a + ?Sized, R: 'a,

Borrows self, then passes self.as_ref() into the pipe function.
§

fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
where Self: AsMut<U>, U: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.as_mut() into the pipe function.
§

fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
where Self: Deref<Target = T>, T: 'a + ?Sized, R: 'a,

Borrows self, then passes self.deref() into the pipe function.
§

fn pipe_deref_mut<'a, T, R>( &'a mut self, func: impl FnOnce(&'a mut T) -> R, ) -> R
where Self: DerefMut<Target = T> + Deref, T: 'a + ?Sized, R: 'a,

Mutably borrows self, then passes self.deref_mut() into the pipe function.
§

impl<T> Pointable for T

§

const ALIGN: usize

The alignment of pointer.
§

type Init = T

The type for initializers.
§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
§

impl<T> PolicyExt for T
where T: ?Sized,

§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns [Action::Follow] only if self and other return Action::Follow. Read more
§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns [Action::Follow] if either self or other returns Action::Follow. Read more
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
§

impl<T> Tap for T

§

fn tap(self, func: impl FnOnce(&Self)) -> Self

Immutable access to a value. Read more
§

fn tap_mut(self, func: impl FnOnce(&mut Self)) -> Self

Mutable access to a value. Read more
§

fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Immutable access to the Borrow<B> of a value. Read more
§

fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Mutable access to the BorrowMut<B> of a value. Read more
§

fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Immutable access to the AsRef<R> view of a value. Read more
§

fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Mutable access to the AsMut<R> view of a value. Read more
§

fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Immutable access to the Deref::Target of a value. Read more
§

fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Mutable access to the Deref::Target of a value. Read more
§

fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self

Calls .tap() only in debug builds, and is erased in release builds.
§

fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self

Calls .tap_mut() only in debug builds, and is erased in release builds.
§

fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
where Self: Borrow<B>, B: ?Sized,

Calls .tap_borrow() only in debug builds, and is erased in release builds.
§

fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
where Self: BorrowMut<B>, B: ?Sized,

Calls .tap_borrow_mut() only in debug builds, and is erased in release builds.
§

fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
where Self: AsRef<R>, R: ?Sized,

Calls .tap_ref() only in debug builds, and is erased in release builds.
§

fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
where Self: AsMut<R>, R: ?Sized,

Calls .tap_ref_mut() only in debug builds, and is erased in release builds.
§

fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
where Self: Deref<Target = T>, T: ?Sized,

Calls .tap_deref() only in debug builds, and is erased in release builds.
§

fn tap_deref_mut_dbg<T>(self, func: impl FnOnce(&mut T)) -> Self
where Self: DerefMut<Target = T> + Deref, T: ?Sized,

Calls .tap_deref_mut() only in debug builds, and is erased in release builds.
Source§

impl<T> ToOwned for T
where 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.
§

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 [WithDispatch] wrapper. Read more
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,

§

impl<T> ErasedDestructor for T
where T: 'static,

§

impl<T> MaybeSendSync for T