1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
#![allow(clippy::derive_partial_eq_without_eq)]

mod configuration;
pub mod explorer;
mod fragment_node;
mod legacy;
mod logger;
mod process;
mod remote;
mod rest;
mod starter;
mod verifier;

pub mod grpc;

pub use self::{
    configuration::{
        get_available_port, Block0ConfigurationBuilder, EitherHashOrBlock0, NodeConfigBuilder,
        NodeConfigManager, SecretModelFactory,
    },
    explorer::{
        compare_schema as compare_explorer_schema, Explorer, ExplorerError, ExplorerProcess,
    },
    fragment_node::{FragmentNode, FragmentNodeError, MemPoolCheck},
    legacy::{
        download_last_n_releases, get_jormungandr_bin, version_0_8_19, BackwardCompatibleRest,
        LegacyConfigError, LegacyNodeConfig, LegacyNodeConfigBuilder, LegacyNodeConfigConverter,
        LegacyNodeConfigManager, Version,
    },
    logger::{JormungandrLogger, Level as LogLevel},
    process::*,
    remote::{RemoteJormungandr, RemoteJormungandrBuilder},
    rest::{uri_from_socket_addr, JormungandrRest, RawRest, RestError, RestSettings},
    starter::{
        ConfigurableNodeConfig, ConfiguredStarter, FaketimeConfig, JormungandrBootstrapper,
        JormungandrParams, LeadershipMode, NodeBlock0, PersistenceMode, Starter, StartupError,
        StartupVerificationMode, TestingDirectory,
    },
    verifier::{assert_accepted_rejected, assert_bad_request, JormungandrStateVerifier},
};
use thiserror::Error;
pub type NodeAlias = String;

#[derive(Error, Debug)]
pub enum JormungandrError {
    #[error("error in logs. Error lines: {error_lines}, full content:{logs}")]
    ErrorInLogs { logs: String, error_lines: String },
    #[error("error in stderr: {stderr}")]
    StdErr { stderr: String },
    #[error("error(s) in log detected: port already in use")]
    PortAlreadyInUse,
}