Skip to main content

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
78mod prelude {
79    pub use crate::{
80        db::Blockstore,
81        utils::{ShallowClone, get_size::CidWrapper},
82    };
83    pub use anyhow::Context as _;
84    pub use cid::Cid;
85    pub use itertools::Itertools as _;
86    pub use std::{ops::Deref as _, sync::Arc};
87}
88
89/// These items are semver-exempt, and exist for forest author use only
90// We want to have doctests, but don't want our internals to be public because:
91// - We don't want to be concerned with library compat
92//   (We want our cargo semver to be _for the command line_).
93// - We don't want to mistakenly export items which we never actually use.
94//
95// So we re-export the relevant items and test with `cargo test --doc --features doctest-private`
96#[cfg(feature = "doctest-private")]
97#[doc(hidden)]
98pub mod doctest_private {
99    pub use crate::{
100        blocks::{CachingBlockHeader, Ticket, TipsetKey},
101        cli::humantoken::{TokenAmountPretty, parse},
102        shim::{
103            address::Address, crypto::Signature, econ::TokenAmount, error::ExitCode,
104            randomness::Randomness, sector::RegisteredSealProof, state_tree::ActorState,
105            version::NetworkVersion,
106        },
107        utils::io::progress_log::WithProgress,
108        utils::net::{DownloadFileOption, download_to},
109        utils::{encoding::blake2b_256, encoding::keccak_256, io::read_toml},
110    };
111}
112
113/// These items are semver-exempt, and exist for forest author use only
114// Allow benchmarks of forest internals
115#[cfg(feature = "benchmark-private")]
116#[doc(hidden)]
117pub mod benchmark_private;
118
119/// These items are semver-exempt, and exist for forest author use only
120// Allow interop tests of forest internals
121#[cfg(feature = "interop-tests-private")]
122#[doc(hidden)]
123pub mod interop_tests_private {
124    pub mod libp2p {
125        pub use crate::libp2p::*;
126    }
127    pub mod libp2p_bitswap {
128        pub use crate::libp2p_bitswap::*;
129    }
130    pub mod beacon {
131        pub use crate::beacon::BeaconEntry;
132    }
133}
134
135// These should be made private in https://github.com/ChainSafe/forest/issues/3013
136pub use auth::{JWT_IDENTIFIER, verify_token};
137pub use cli::main::main as forest_main;
138pub use cli_shared::cli::{Client, Config};
139pub use daemon::main::main as forestd_main;
140pub use dev::main::main as forest_dev_main;
141pub use key_management::{
142    ENCRYPTED_KEYSTORE_NAME, FOREST_KEYSTORE_PHRASE_ENV, KEYSTORE_NAME, KeyStore, KeyStoreConfig,
143};
144pub use tool::main::main as forest_tool_main;
145pub use wallet::main::main as forest_wallet_main;