forest/
lib.rs

1// Copyright 2019-2026 ChainSafe Systems
2// SPDX-License-Identifier: Apache-2.0, MIT
3
4#![recursion_limit = "1024"]
5#![cfg_attr(
6    not(test),
7    deny(
8        clippy::todo,
9        clippy::dbg_macro,
10        clippy::indexing_slicing,
11        clippy::get_unwrap
12    )
13)]
14#![cfg_attr(
15    doc,
16    deny(rustdoc::all),
17    allow(
18        // We build with `--document-private-items` on both docs.rs and our
19        // vendored docs.
20        rustdoc::private_intra_doc_links,
21        // See module `doctest_private` below.
22        rustdoc::private_doc_tests,
23        rustdoc::missing_crate_level_docs
24    )
25)]
26
27cfg_if::cfg_if! {
28    if #[cfg(feature = "rustalloc")] {
29    } else if #[cfg(feature = "jemalloc")] {
30        use crate::cli_shared::tikv_jemallocator::Jemalloc;
31        #[global_allocator]
32        static GLOBAL: Jemalloc = Jemalloc;
33    } else if #[cfg(feature = "system-alloc")] {
34        use std::alloc::System;
35        #[global_allocator]
36        static GLOBAL: System = System;
37    }
38}
39
40mod auth;
41mod beacon;
42mod blocks;
43mod chain;
44mod chain_sync;
45mod cid_collections;
46mod cli;
47mod cli_shared;
48mod daemon;
49mod db;
50mod dev;
51mod documentation;
52mod eth;
53mod f3;
54mod fil_cns;
55mod genesis;
56mod health;
57mod interpreter;
58mod ipld;
59mod key_management;
60mod libp2p;
61mod libp2p_bitswap;
62mod lotus_json;
63mod message;
64mod message_pool;
65mod metrics;
66mod networks;
67mod rpc;
68mod shim;
69mod state_manager;
70mod state_migration;
71mod statediff;
72#[cfg(any(test, doc))]
73mod test_utils;
74mod tool;
75mod utils;
76mod wallet;
77
78/// These items are semver-exempt, and exist for forest author use only
79// We want to have doctests, but don't want our internals to be public because:
80// - We don't want to be concerned with library compat
81//   (We want our cargo semver to be _for the command line_).
82// - We don't want to mistakenly export items which we never actually use.
83//
84// So we re-export the relevant items and test with `cargo test --doc --features doctest-private`
85#[cfg(feature = "doctest-private")]
86#[doc(hidden)]
87pub mod doctest_private {
88    pub use crate::{
89        blocks::{CachingBlockHeader, Ticket, TipsetKey},
90        cli::humantoken::{TokenAmountPretty, parse},
91        shim::{
92            address::Address, crypto::Signature, econ::TokenAmount, error::ExitCode,
93            randomness::Randomness, sector::RegisteredSealProof, state_tree::ActorState,
94            version::NetworkVersion,
95        },
96        utils::io::progress_log::WithProgress,
97        utils::{encoding::blake2b_256, encoding::keccak_256, io::read_toml},
98    };
99}
100
101/// These items are semver-exempt, and exist for forest author use only
102// Allow benchmarks of forest internals
103#[cfg(feature = "benchmark-private")]
104#[doc(hidden)]
105pub mod benchmark_private;
106
107/// These items are semver-exempt, and exist for forest author use only
108// Allow interop tests of forest internals
109#[cfg(feature = "interop-tests-private")]
110#[doc(hidden)]
111pub mod interop_tests_private {
112    pub mod libp2p {
113        pub use crate::libp2p::*;
114    }
115    pub mod libp2p_bitswap {
116        pub use crate::libp2p_bitswap::*;
117    }
118    pub mod beacon {
119        pub use crate::beacon::BeaconEntry;
120    }
121}
122
123// These should be made private in https://github.com/ChainSafe/forest/issues/3013
124pub use auth::{JWT_IDENTIFIER, verify_token};
125pub use cli::main::main as forest_main;
126pub use cli_shared::cli::{Client, Config};
127pub use daemon::main::main as forestd_main;
128pub use dev::main::main as forest_dev_main;
129pub use key_management::{
130    ENCRYPTED_KEYSTORE_NAME, FOREST_KEYSTORE_PHRASE_ENV, KEYSTORE_NAME, KeyStore, KeyStoreConfig,
131};
132pub use tool::main::main as forest_tool_main;
133pub use wallet::main::main as forest_wallet_main;
134
135#[cfg(test)]
136fn block_on<T>(f: impl std::future::Future<Output = T>) -> T {
137    tokio::runtime::Builder::new_multi_thread()
138        .enable_all()
139        .build()
140        .unwrap()
141        .block_on(f)
142}