Skip to content
Closed
Show file tree
Hide file tree
Changes from 1 commit
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
48 changes: 26 additions & 22 deletions src/builder.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,9 @@
// accordance with one or both of these licenses.

use crate::chain::{ChainSource, DEFAULT_ESPLORA_SERVER_URL};
use crate::config::{default_user_config, Config, EsploraSyncConfig, WALLET_KEYS_SEED_LEN};
use crate::config::{
default_user_config, Config, EsploraSyncConfig, LoggingConfig, WALLET_KEYS_SEED_LEN,
};

use crate::connection::ConnectionManager;
use crate::event::EventQueue;
Expand All @@ -16,7 +18,9 @@ use crate::io::sqlite_store::SqliteStore;
use crate::io::utils::{read_node_metrics, write_node_metrics};
use crate::io::vss_store::VssStore;
use crate::liquidity::LiquiditySource;
use crate::logger::{log_error, log_info, FilesystemLogger, Logger};
use crate::logger::{
default_format, log_error, log_info, FilesystemLogWriter, LdkNodeLogger, Logger,
};
use crate::message_handler::NodeCustomMessageHandler;
use crate::payment::store::PaymentStore;
use crate::peer_store::PeerStore;
Expand All @@ -27,8 +31,8 @@ use crate::types::{
};
use crate::wallet::persist::KVStoreWalletPersister;
use crate::wallet::Wallet;
use crate::Node;
use crate::{io, NodeMetrics};
use crate::{LogLevel, Node};

use lightning::chain::{chainmonitor, BestBlock, Watch};
use lightning::io::Cursor;
Expand Down Expand Up @@ -333,12 +337,6 @@ impl NodeBuilder {
Ok(self)
}

/// Sets the level at which [`Node`] will log messages.
pub fn set_log_level(&mut self, level: LogLevel) -> &mut Self {
self.config.log_level = level;
self
}

/// Builds a [`Node`] instance with a [`SqliteStore`] backend and according to the options
/// previously configured.
pub fn build(&self) -> Result<Node, BuildError> {
Expand Down Expand Up @@ -734,7 +732,7 @@ fn build_with_store_internal(
config: Arc<Config>, chain_data_source_config: Option<&ChainDataSourceConfig>,
gossip_source_config: Option<&GossipSourceConfig>,
liquidity_source_config: Option<&LiquiditySourceConfig>, seed_bytes: [u8; 64],
logger: Arc<FilesystemLogger>, kv_store: Arc<DynStore>,
logger: Arc<LdkNodeLogger>, kv_store: Arc<DynStore>,
) -> Result<Node, BuildError> {
// Initialize the status fields.
let is_listening = Arc::new(AtomicBool::new(false));
Expand Down Expand Up @@ -1233,21 +1231,27 @@ fn build_with_store_internal(

/// Sets up the node logger, creating a new log file if it does not exist, or utilizing
/// the existing log file.
fn setup_logger(config: &Config) -> Result<Arc<FilesystemLogger>, BuildError> {
let log_file_path = match &config.log_file_path {
Some(log_dir) => String::from(log_dir),
None => format!("{}/{}", config.storage_dir_path.clone(), "ldk_node.log"),
};

Ok(Arc::new(
FilesystemLogger::new(log_file_path, config.log_level)
.map_err(|_| BuildError::LoggerSetupFailed)?,
))
fn setup_logger(config: &Config) -> Result<Arc<LdkNodeLogger>, BuildError> {
match config.logging_config {
LoggingConfig::Custom(ref logger) => Ok(logger.clone()),
LoggingConfig::Filesystem { ref log_dir, log_level } => {
let filesystem_log_writer = FilesystemLogWriter::new(log_dir.clone())
.map_err(|_| BuildError::LoggerSetupFailed)?;
Ok(Arc::new(
LdkNodeLogger::new(
log_level,
Box::new(default_format),
Box::new(move |s| filesystem_log_writer.write(s)),
)
.map_err(|_| BuildError::LoggerSetupFailed)?,
))
},
}
}

fn seed_bytes_from_config(
config: &Config, entropy_source_config: Option<&EntropySourceConfig>,
logger: Arc<FilesystemLogger>,
logger: Arc<LdkNodeLogger>,
) -> Result<[u8; 64], BuildError> {
match entropy_source_config {
Some(EntropySourceConfig::SeedBytes(bytes)) => Ok(bytes.clone()),
Expand All @@ -1269,7 +1273,7 @@ fn seed_bytes_from_config(
}

fn derive_vss_xprv(
config: Arc<Config>, seed_bytes: &[u8; 64], logger: Arc<FilesystemLogger>,
config: Arc<Config>, seed_bytes: &[u8; 64], logger: Arc<LdkNodeLogger>,
) -> Result<Xpriv, BuildError> {
use bitcoin::key::Secp256k1;

Expand Down
14 changes: 7 additions & 7 deletions src/chain/mod.rs
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,7 @@ use crate::fee_estimator::{
ConfirmationTarget, OnchainFeeEstimator,
};
use crate::io::utils::write_node_metrics;
use crate::logger::{log_bytes, log_error, log_info, log_trace, FilesystemLogger, Logger};
use crate::logger::{log_bytes, log_error, log_info, log_trace, LdkNodeLogger, Logger};
use crate::types::{Broadcaster, ChainMonitor, ChannelManager, DynStore, Sweeper, Wallet};
use crate::{Error, NodeMetrics};

Expand Down Expand Up @@ -112,13 +112,13 @@ pub(crate) enum ChainSource {
esplora_client: EsploraAsyncClient,
onchain_wallet: Arc<Wallet>,
onchain_wallet_sync_status: Mutex<WalletSyncStatus>,
tx_sync: Arc<EsploraSyncClient<Arc<FilesystemLogger>>>,
tx_sync: Arc<EsploraSyncClient<Arc<LdkNodeLogger>>>,
lightning_wallet_sync_status: Mutex<WalletSyncStatus>,
fee_estimator: Arc<OnchainFeeEstimator>,
tx_broadcaster: Arc<Broadcaster>,
kv_store: Arc<DynStore>,
config: Arc<Config>,
logger: Arc<FilesystemLogger>,
logger: Arc<LdkNodeLogger>,
node_metrics: Arc<RwLock<NodeMetrics>>,
},
BitcoindRpc {
Expand All @@ -131,7 +131,7 @@ pub(crate) enum ChainSource {
tx_broadcaster: Arc<Broadcaster>,
kv_store: Arc<DynStore>,
config: Arc<Config>,
logger: Arc<FilesystemLogger>,
logger: Arc<LdkNodeLogger>,
node_metrics: Arc<RwLock<NodeMetrics>>,
},
}
Expand All @@ -140,7 +140,7 @@ impl ChainSource {
pub(crate) fn new_esplora(
server_url: String, sync_config: EsploraSyncConfig, onchain_wallet: Arc<Wallet>,
fee_estimator: Arc<OnchainFeeEstimator>, tx_broadcaster: Arc<Broadcaster>,
kv_store: Arc<DynStore>, config: Arc<Config>, logger: Arc<FilesystemLogger>,
kv_store: Arc<DynStore>, config: Arc<Config>, logger: Arc<LdkNodeLogger>,
node_metrics: Arc<RwLock<NodeMetrics>>,
) -> Self {
let mut client_builder = esplora_client::Builder::new(&server_url);
Expand Down Expand Up @@ -170,7 +170,7 @@ impl ChainSource {
host: String, port: u16, rpc_user: String, rpc_password: String,
onchain_wallet: Arc<Wallet>, fee_estimator: Arc<OnchainFeeEstimator>,
tx_broadcaster: Arc<Broadcaster>, kv_store: Arc<DynStore>, config: Arc<Config>,
logger: Arc<FilesystemLogger>, node_metrics: Arc<RwLock<NodeMetrics>>,
logger: Arc<LdkNodeLogger>, node_metrics: Arc<RwLock<NodeMetrics>>,
) -> Self {
let bitcoind_rpc_client =
Arc::new(BitcoindRpcClient::new(host, port, rpc_user, rpc_password));
Expand Down Expand Up @@ -1123,7 +1123,7 @@ impl Filter for ChainSource {

fn periodically_archive_fully_resolved_monitors(
channel_manager: Arc<ChannelManager>, chain_monitor: Arc<ChainMonitor>,
kv_store: Arc<DynStore>, logger: Arc<FilesystemLogger>, node_metrics: Arc<RwLock<NodeMetrics>>,
kv_store: Arc<DynStore>, logger: Arc<LdkNodeLogger>, node_metrics: Arc<RwLock<NodeMetrics>>,
) -> Result<(), Error> {
let mut locked_node_metrics = node_metrics.write().unwrap();
let cur_height = channel_manager.current_best_block().height;
Expand Down
38 changes: 33 additions & 5 deletions src/config.rs
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@

//! Objects for configuring the node.

use crate::logger::LdkNodeLogger;
use crate::payment::SendingParameters;

use lightning::ln::msgs::SocketAddress;
Expand Down Expand Up @@ -108,6 +109,9 @@ pub struct Config {
/// If set to `None`, logs can be found in `ldk_node.log` in the [`Config::storage_dir_path`]
/// directory.
pub log_file_path: Option<String>,
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This needs to be dropped/moved, too, as it only makes sense for the filesystem writer.

/// In the default configuration logs can be found in the `logs` subdirectory in
/// [`Config::storage_dir_path`], and the log level is set to [`DEFAULT_LOG_LEVEL`].
pub logging_config: LoggingConfig,
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

As mentioned in the original PR, we can't do this as it likely won't be really compatible with bindings and also doesn't match how we handle other things.

Rather, we'd need to add three builder methods to allow configuring the three modes:

a) set_logger_file/set_logger_filesystem taking a FilesystemLogger config object allowing to set loglevel and path (also exposed in the bindings builder)
b) set_logger_facade to use the log facade
c) set_logger_custom taking an Arc<dyn LogWriter + Send + Sync> (also exposed in the bindings builder)

That said, we'd likely want to keep something like LoggingConfig as an internal config object, similar to ChainSourceConfig, EntropySourceConfig, etc.
That is, the API would be controlled by Builder methods, but the 'state' is kept in that object and used to setup in Builder::build.

/// The used Bitcoin network.
pub network: Network,
/// The addresses on which the node will listen for incoming connections.
Expand All @@ -133,10 +137,6 @@ pub struct Config {
/// Channels with available liquidity less than the required amount times this value won't be
/// used to send pre-flight probes.
pub probing_liquidity_limit_multiplier: u64,
/// The level at which we log messages.
///
/// Any messages below this level will be excluded from the logs.
pub log_level: LogLevel,
/// Configuration options pertaining to Anchor channels, i.e., channels for which the
/// `option_anchors_zero_fee_htlc_tx` channel type is negotiated.
///
Expand Down Expand Up @@ -169,18 +169,46 @@ impl Default for Config {
Self {
storage_dir_path: DEFAULT_STORAGE_DIR_PATH.to_string(),
log_file_path: None,
logging_config: LoggingConfig::default(),
network: DEFAULT_NETWORK,
listening_addresses: None,
trusted_peers_0conf: Vec::new(),
probing_liquidity_limit_multiplier: DEFAULT_PROBING_LIQUIDITY_LIMIT_MULTIPLIER,
log_level: DEFAULT_LOG_LEVEL,
anchor_channels_config: Some(AnchorChannelsConfig::default()),
sending_parameters: None,
node_alias: None,
}
}
}

/// Configuration options for logging.
#[derive(Debug, Clone)]
pub enum LoggingConfig {
/// An opinionated filesystem logger.
///
/// This logger will always write at `{log_dir}/ldk_node_latest.log`, which is a symlink to the
/// most recent log file, which is created and timestamped at initialization.
Filesystem {
/// The absolute path where logs are stored.
log_dir: String,
/// The level at which we log messages.
///
/// Any messages below this level will be excluded from the logs.
log_level: LogLevel,
},
/// A custom logger.
Custom(std::sync::Arc<LdkNodeLogger>),
}

impl Default for LoggingConfig {
fn default() -> Self {
Self::Filesystem {
log_dir: format!("{}/{}", DEFAULT_STORAGE_DIR_PATH, "logs"),
log_level: DEFAULT_LOG_LEVEL,
}
}
}

/// Configuration options pertaining to 'Anchor' channels, i.e., channels for which the
/// `option_anchors_zero_fee_htlc_tx` channel type is negotiated.
///
Expand Down
8 changes: 4 additions & 4 deletions src/gossip.rs
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
// accordance with one or both of these licenses.

use crate::config::RGS_SYNC_TIMEOUT_SECS;
use crate::logger::{log_trace, FilesystemLogger, Logger};
use crate::logger::{log_trace, LdkNodeLogger, Logger};
use crate::types::{GossipSync, Graph, P2PGossipSync, RapidGossipSync};
use crate::Error;

Expand All @@ -24,12 +24,12 @@ pub(crate) enum GossipSource {
gossip_sync: Arc<RapidGossipSync>,
server_url: String,
latest_sync_timestamp: AtomicU32,
logger: Arc<FilesystemLogger>,
logger: Arc<LdkNodeLogger>,
},
}

impl GossipSource {
pub fn new_p2p(network_graph: Arc<Graph>, logger: Arc<FilesystemLogger>) -> Self {
pub fn new_p2p(network_graph: Arc<Graph>, logger: Arc<LdkNodeLogger>) -> Self {
let gossip_sync = Arc::new(P2PGossipSync::new(
network_graph,
None::<Arc<dyn UtxoLookup + Send + Sync>>,
Expand All @@ -40,7 +40,7 @@ impl GossipSource {

pub fn new_rgs(
server_url: String, latest_sync_timestamp: u32, network_graph: Arc<Graph>,
logger: Arc<FilesystemLogger>,
logger: Arc<LdkNodeLogger>,
) -> Self {
let gossip_sync = Arc::new(RapidGossipSync::new(network_graph, Arc::clone(&logger)));
let latest_sync_timestamp = AtomicU32::new(latest_sync_timestamp);
Expand Down
6 changes: 3 additions & 3 deletions src/io/utils.rs
Original file line number Diff line number Diff line change
Expand Up @@ -13,7 +13,7 @@ use crate::fee_estimator::OnchainFeeEstimator;
use crate::io::{
NODE_METRICS_KEY, NODE_METRICS_PRIMARY_NAMESPACE, NODE_METRICS_SECONDARY_NAMESPACE,
};
use crate::logger::{log_error, FilesystemLogger};
use crate::logger::{log_error, LdkNodeLogger};
use crate::peer_store::PeerStore;
use crate::sweep::DeprecatedSpendableOutputInfo;
use crate::types::{Broadcaster, DynStore, KeysManager, Sweeper};
Expand Down Expand Up @@ -226,7 +226,7 @@ where
pub(crate) fn read_output_sweeper(
broadcaster: Arc<Broadcaster>, fee_estimator: Arc<OnchainFeeEstimator>,
chain_data_source: Arc<ChainSource>, keys_manager: Arc<KeysManager>, kv_store: Arc<DynStore>,
logger: Arc<FilesystemLogger>,
logger: Arc<LdkNodeLogger>,
) -> Result<Sweeper, std::io::Error> {
let mut reader = Cursor::new(kv_store.read(
OUTPUT_SWEEPER_PERSISTENCE_PRIMARY_NAMESPACE,
Expand Down Expand Up @@ -600,7 +600,7 @@ impl_read_write_change_set_type!(

// Reads the full BdkWalletChangeSet or returns default fields
pub(crate) fn read_bdk_wallet_change_set(
kv_store: Arc<DynStore>, logger: Arc<FilesystemLogger>,
kv_store: Arc<DynStore>, logger: Arc<LdkNodeLogger>,
) -> Result<Option<BdkWalletChangeSet>, std::io::Error> {
let mut change_set = BdkWalletChangeSet::default();

Expand Down
14 changes: 7 additions & 7 deletions src/lib.rs
Original file line number Diff line number Diff line change
Expand Up @@ -142,7 +142,7 @@ use types::{
};
pub use types::{ChannelDetails, PeerDetails, UserChannelId};

use logger::{log_error, log_info, log_trace, FilesystemLogger, Logger};
use logger::{log_error, log_info, log_trace, LdkNodeLogger, Logger};

use lightning::chain::BestBlock;
use lightning::events::bump_transaction::Wallet as LdkWallet;
Expand Down Expand Up @@ -180,23 +180,23 @@ pub struct Node {
wallet: Arc<Wallet>,
chain_source: Arc<ChainSource>,
tx_broadcaster: Arc<Broadcaster>,
event_queue: Arc<EventQueue<Arc<FilesystemLogger>>>,
event_queue: Arc<EventQueue<Arc<LdkNodeLogger>>>,
channel_manager: Arc<ChannelManager>,
chain_monitor: Arc<ChainMonitor>,
output_sweeper: Arc<Sweeper>,
peer_manager: Arc<PeerManager>,
onion_messenger: Arc<OnionMessenger>,
connection_manager: Arc<ConnectionManager<Arc<FilesystemLogger>>>,
connection_manager: Arc<ConnectionManager<Arc<LdkNodeLogger>>>,
keys_manager: Arc<KeysManager>,
network_graph: Arc<Graph>,
gossip_source: Arc<GossipSource>,
liquidity_source: Option<Arc<LiquiditySource<Arc<FilesystemLogger>>>>,
liquidity_source: Option<Arc<LiquiditySource<Arc<LdkNodeLogger>>>>,
kv_store: Arc<DynStore>,
logger: Arc<FilesystemLogger>,
logger: Arc<LdkNodeLogger>,
_router: Arc<Router>,
scorer: Arc<Mutex<Scorer>>,
peer_store: Arc<PeerStore<Arc<FilesystemLogger>>>,
payment_store: Arc<PaymentStore<Arc<FilesystemLogger>>>,
peer_store: Arc<PeerStore<Arc<LdkNodeLogger>>>,
payment_store: Arc<PaymentStore<Arc<LdkNodeLogger>>>,
is_listening: Arc<AtomicBool>,
node_metrics: Arc<RwLock<NodeMetrics>>,
}
Expand Down
Loading