Skip to content

Commit 0c201b5

Browse files
author
Elias Rohrer
committed
Add a new log-level for gossip messages.
1 parent 8d886ee commit 0c201b5

File tree

10 files changed

+80
-30
lines changed

10 files changed

+80
-30
lines changed

lightning/Cargo.toml

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -21,6 +21,7 @@ max_level_error = []
2121
max_level_warn = []
2222
max_level_info = []
2323
max_level_debug = []
24+
max_level_trace = []
2425
# Allow signing of local transactions that may have been revoked or will be revoked, for functional testing (e.g. justice tx handling).
2526
# This is unsafe to use in production because it may result in the counterparty publishing taking our funds.
2627
unsafe_revoked_tx_signing = []

lightning/src/chain/channelmonitor.rs

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -2355,7 +2355,8 @@ impl<Signer: Sign> ChannelMonitorImpl<Signer> {
23552355
let prevout = &tx.input[0].previous_output;
23562356
if prevout.txid == self.funding_info.0.txid && prevout.vout == self.funding_info.0.index as u32 {
23572357
let mut balance_spendable_csv = None;
2358-
log_info!(logger, "Channel closed by funding output spend in txid {}.", log_bytes!(tx.txid()));
2358+
log_info!(logger, "Channel {} closed by funding output spend in txid {}.",
2359+
log_bytes!(self.funding_info.0.to_channel_id()), tx.txid());
23592360
if (tx.input[0].sequence >> 8*3) as u8 == 0x80 && (tx.lock_time >> 8*3) as u8 == 0x20 {
23602361
let (mut new_outpoints, new_outputs) = self.check_spend_counterparty_transaction(&tx, height, &logger);
23612362
if !new_outputs.1.is_empty() {

lightning/src/chain/onchaintx.rs

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -388,7 +388,8 @@ impl<ChannelSigner: Sign> OnchainTxHandler<ChannelSigner> {
388388
let new_timer = Some(cached_request.get_height_timer(cur_height));
389389
if cached_request.is_malleable() {
390390
let predicted_weight = cached_request.package_weight(&self.destination_script);
391-
if let Some((output_value, new_feerate)) = cached_request.compute_package_output(predicted_weight, fee_estimator, logger) {
391+
if let Some((output_value, new_feerate)) =
392+
cached_request.compute_package_output(predicted_weight, self.destination_script.dust_value().as_sat(), fee_estimator, logger) {
392393
assert!(new_feerate != 0);
393394

394395
let transaction = cached_request.finalize_package(self, output_value, self.destination_script.clone(), logger).unwrap();

lightning/src/chain/package.rs

Lines changed: 8 additions & 9 deletions
Original file line numberDiff line numberDiff line change
@@ -636,26 +636,25 @@ impl PackageTemplate {
636636
}
637637
current_height + LOW_FREQUENCY_BUMP_INTERVAL
638638
}
639-
/// Returns value in satoshis to be included as package outgoing output amount and feerate with which package finalization should be done.
640-
pub(crate) fn compute_package_output<F: Deref, L: Deref>(&self, predicted_weight: usize, fee_estimator: &F, logger: &L) -> Option<(u64, u64)>
639+
640+
/// Returns value in satoshis to be included as package outgoing output amount and feerate
641+
/// which was used to generate the value. Will not return less than `dust_limit_sats` for the
642+
/// value.
643+
pub(crate) fn compute_package_output<F: Deref, L: Deref>(&self, predicted_weight: usize, dust_limit_sats: u64, fee_estimator: &F, logger: &L) -> Option<(u64, u64)>
641644
where F::Target: FeeEstimator,
642645
L::Target: Logger,
643646
{
644647
debug_assert!(self.malleability == PackageMalleability::Malleable, "The package output is fixed for non-malleable packages");
645648
let input_amounts = self.package_amount();
649+
assert!(dust_limit_sats as i64 > 0, "Output script must be broadcastable/have a 'real' dust limit.");
646650
// If old feerate is 0, first iteration of this claim, use normal fee calculation
647651
if self.feerate_previous != 0 {
648652
if let Some((new_fee, feerate)) = feerate_bump(predicted_weight, input_amounts, self.feerate_previous, fee_estimator, logger) {
649-
// If new computed fee is superior at the whole claimable amount burn all in fees
650-
if new_fee > input_amounts {
651-
return Some((0, feerate));
652-
} else {
653-
return Some((input_amounts - new_fee, feerate));
654-
}
653+
return Some((cmp::max(input_amounts as i64 - new_fee as i64, dust_limit_sats as i64) as u64, feerate));
655654
}
656655
} else {
657656
if let Some((new_fee, feerate)) = compute_fee_from_spent_amounts(input_amounts, predicted_weight, fee_estimator, logger) {
658-
return Some((input_amounts - new_fee, feerate));
657+
return Some((cmp::max(input_amounts as i64 - new_fee as i64, dust_limit_sats as i64) as u64, feerate));
659658
}
660659
}
661660
None

lightning/src/ln/channelmanager.rs

Lines changed: 2 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -5874,6 +5874,7 @@ impl<'a, Signer: Sign, M: Deref, T: Deref, K: Deref, F: Deref, L: Deref>
58745874
reason: ClosureReason::OutdatedChannelManager
58755875
});
58765876
} else {
5877+
log_info!(args.logger, "Successfully loaded channel {}", log_bytes!(channel.channel_id()));
58775878
if let Some(short_channel_id) = channel.get_short_channel_id() {
58785879
short_to_id.insert(short_channel_id, channel.channel_id());
58795880
}
@@ -5891,6 +5892,7 @@ impl<'a, Signer: Sign, M: Deref, T: Deref, K: Deref, F: Deref, L: Deref>
58915892

58925893
for (ref funding_txo, ref mut monitor) in args.channel_monitors.iter_mut() {
58935894
if !funding_txo_set.contains(funding_txo) {
5895+
log_info!(args.logger, "Broadcasting latest holder commitment transaction for closed channel {}", log_bytes!(funding_txo.to_channel_id()));
58945896
monitor.broadcast_latest_holder_commitment_txn(&args.tx_broadcaster, &args.logger);
58955897
}
58965898
}

lightning/src/ln/functional_test_utils.rs

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -707,6 +707,14 @@ pub fn update_nodes_with_chan_announce<'a, 'b, 'c, 'd>(nodes: &'a Vec<Node<'b, '
707707
macro_rules! check_spends {
708708
($tx: expr, $($spends_txn: expr),*) => {
709709
{
710+
$(
711+
for outp in $spends_txn.output.iter() {
712+
assert!(outp.value >= outp.script_pubkey.dust_value().as_sat(), "Input tx output didn't meet dust limit");
713+
}
714+
)*
715+
for outp in $tx.output.iter() {
716+
assert!(outp.value >= outp.script_pubkey.dust_value().as_sat(), "Spending tx output didn't meet dust limit");
717+
}
710718
let get_output = |out_point: &bitcoin::blockdata::transaction::OutPoint| {
711719
$(
712720
if out_point.txid == $spends_txn.txid() {

lightning/src/ln/peer_handler.rs

Lines changed: 32 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -24,6 +24,7 @@ use ln::channelmanager::{SimpleArcChannelManager, SimpleRefChannelManager};
2424
use util::ser::{VecWriter, Writeable, Writer};
2525
use ln::peer_channel_encryptor::{PeerChannelEncryptor,NextNoiseStep};
2626
use ln::wire;
27+
use ln::wire::Encode;
2728
use util::atomic_counter::AtomicCounter;
2829
use util::events::{MessageSendEvent, MessageSendEventsProvider};
2930
use util::logger::Logger;
@@ -757,7 +758,12 @@ impl<Descriptor: SocketDescriptor, CM: Deref, RM: Deref, L: Deref, CMH: Deref> P
757758
fn enqueue_message<M: wire::Type>(&self, peer: &mut Peer, message: &M) {
758759
let mut buffer = VecWriter(Vec::with_capacity(2048));
759760
wire::write(message, &mut buffer).unwrap(); // crash if the write failed
760-
log_trace!(self.logger, "Enqueueing message {:?} to {}", message, log_pubkey!(peer.their_node_id.unwrap()));
761+
762+
if is_gossip_msg(message.type_id()) {
763+
log_gossip!(self.logger, "Enqueueing message {:?} to {}", message, log_pubkey!(peer.their_node_id.unwrap()));
764+
} else {
765+
log_trace!(self.logger, "Enqueueing message {:?} to {}", message, log_pubkey!(peer.their_node_id.unwrap()))
766+
}
761767
self.enqueue_encoded_message(peer, &buffer.0);
762768
}
763769

@@ -892,7 +898,7 @@ impl<Descriptor: SocketDescriptor, CM: Deref, RM: Deref, L: Deref, CMH: Deref> P
892898
match e {
893899
msgs::DecodeError::UnknownVersion => return Err(PeerHandleError { no_connection_possible: false }),
894900
msgs::DecodeError::UnknownRequiredFeature => {
895-
log_trace!(self.logger, "Got a channel/node announcement with an known required feature flag, you may want to update!");
901+
log_gossip!(self.logger, "Got a channel/node announcement with an unknown required feature flag, you may want to update!");
896902
continue;
897903
}
898904
msgs::DecodeError::InvalidValue => {
@@ -906,7 +912,7 @@ impl<Descriptor: SocketDescriptor, CM: Deref, RM: Deref, L: Deref, CMH: Deref> P
906912
msgs::DecodeError::BadLengthDescriptor => return Err(PeerHandleError { no_connection_possible: false }),
907913
msgs::DecodeError::Io(_) => return Err(PeerHandleError { no_connection_possible: false }),
908914
msgs::DecodeError::UnsupportedCompression => {
909-
log_trace!(self.logger, "We don't support zlib-compressed message fields, ignoring message");
915+
log_gossip!(self.logger, "We don't support zlib-compressed message fields, ignoring message");
910916
continue;
911917
}
912918
}
@@ -953,7 +959,12 @@ impl<Descriptor: SocketDescriptor, CM: Deref, RM: Deref, L: Deref, CMH: Deref> P
953959
peer: &mut Peer,
954960
message: wire::Message<<<CMH as core::ops::Deref>::Target as wire::CustomMessageReader>::CustomMessage>
955961
) -> Result<Option<wire::Message<<<CMH as core::ops::Deref>::Target as wire::CustomMessageReader>::CustomMessage>>, MessageHandlingError> {
956-
log_trace!(self.logger, "Received message {:?} from {}", message, log_pubkey!(peer.their_node_id.unwrap()));
962+
if is_gossip_msg(message.type_id()) {
963+
log_gossip!(self.logger, "Received message {:?} from {}", message, log_pubkey!(peer.their_node_id.unwrap()));
964+
} else {
965+
log_trace!(self.logger, "Received message {:?} from {}", message, log_pubkey!(peer.their_node_id.unwrap()));
966+
}
967+
957968
peer.received_message_since_timer_tick = true;
958969

959970
// Need an Init as first message
@@ -1132,7 +1143,7 @@ impl<Descriptor: SocketDescriptor, CM: Deref, RM: Deref, L: Deref, CMH: Deref> P
11321143
fn forward_broadcast_msg(&self, peers: &mut PeerHolder<Descriptor>, msg: &wire::Message<<<CMH as core::ops::Deref>::Target as wire::CustomMessageReader>::CustomMessage>, except_node: Option<&PublicKey>) {
11331144
match msg {
11341145
wire::Message::ChannelAnnouncement(ref msg) => {
1135-
log_trace!(self.logger, "Sending message to all peers except {:?} or the announced channel's counterparties: {:?}", except_node, msg);
1146+
log_gossip!(self.logger, "Sending message to all peers except {:?} or the announced channel's counterparties: {:?}", except_node, msg);
11361147
let encoded_msg = encode_msg!(msg);
11371148

11381149
for (_, peer) in peers.peers.iter_mut() {
@@ -1143,7 +1154,7 @@ impl<Descriptor: SocketDescriptor, CM: Deref, RM: Deref, L: Deref, CMH: Deref> P
11431154
if peer.pending_outbound_buffer.len() > OUTBOUND_BUFFER_LIMIT_DROP_GOSSIP
11441155
|| peer.msgs_sent_since_pong > BUFFER_DRAIN_MSGS_PER_TICK * FORWARD_INIT_SYNC_BUFFER_LIMIT_RATIO
11451156
{
1146-
log_trace!(self.logger, "Skipping broadcast message to {:?} as its outbound buffer is full", peer.their_node_id);
1157+
log_gossip!(self.logger, "Skipping broadcast message to {:?} as its outbound buffer is full", peer.their_node_id);
11471158
continue;
11481159
}
11491160
if peer.their_node_id.as_ref() == Some(&msg.contents.node_id_1) ||
@@ -1157,7 +1168,7 @@ impl<Descriptor: SocketDescriptor, CM: Deref, RM: Deref, L: Deref, CMH: Deref> P
11571168
}
11581169
},
11591170
wire::Message::NodeAnnouncement(ref msg) => {
1160-
log_trace!(self.logger, "Sending message to all peers except {:?} or the announced node: {:?}", except_node, msg);
1171+
log_gossip!(self.logger, "Sending message to all peers except {:?} or the announced node: {:?}", except_node, msg);
11611172
let encoded_msg = encode_msg!(msg);
11621173

11631174
for (_, peer) in peers.peers.iter_mut() {
@@ -1168,7 +1179,7 @@ impl<Descriptor: SocketDescriptor, CM: Deref, RM: Deref, L: Deref, CMH: Deref> P
11681179
if peer.pending_outbound_buffer.len() > OUTBOUND_BUFFER_LIMIT_DROP_GOSSIP
11691180
|| peer.msgs_sent_since_pong > BUFFER_DRAIN_MSGS_PER_TICK * FORWARD_INIT_SYNC_BUFFER_LIMIT_RATIO
11701181
{
1171-
log_trace!(self.logger, "Skipping broadcast message to {:?} as its outbound buffer is full", peer.their_node_id);
1182+
log_gossip!(self.logger, "Skipping broadcast message to {:?} as its outbound buffer is full", peer.their_node_id);
11721183
continue;
11731184
}
11741185
if peer.their_node_id.as_ref() == Some(&msg.contents.node_id) {
@@ -1181,7 +1192,7 @@ impl<Descriptor: SocketDescriptor, CM: Deref, RM: Deref, L: Deref, CMH: Deref> P
11811192
}
11821193
},
11831194
wire::Message::ChannelUpdate(ref msg) => {
1184-
log_trace!(self.logger, "Sending message to all peers except {:?}: {:?}", except_node, msg);
1195+
log_gossip!(self.logger, "Sending message to all peers except {:?}: {:?}", except_node, msg);
11851196
let encoded_msg = encode_msg!(msg);
11861197

11871198
for (_, peer) in peers.peers.iter_mut() {
@@ -1192,7 +1203,7 @@ impl<Descriptor: SocketDescriptor, CM: Deref, RM: Deref, L: Deref, CMH: Deref> P
11921203
if peer.pending_outbound_buffer.len() > OUTBOUND_BUFFER_LIMIT_DROP_GOSSIP
11931204
|| peer.msgs_sent_since_pong > BUFFER_DRAIN_MSGS_PER_TICK * FORWARD_INIT_SYNC_BUFFER_LIMIT_RATIO
11941205
{
1195-
log_trace!(self.logger, "Skipping broadcast message to {:?} as its outbound buffer is full", peer.their_node_id);
1206+
log_gossip!(self.logger, "Skipping broadcast message to {:?} as its outbound buffer is full", peer.their_node_id);
11961207
continue;
11971208
}
11981209
if except_node.is_some() && peer.their_node_id.as_ref() == except_node {
@@ -1377,7 +1388,7 @@ impl<Descriptor: SocketDescriptor, CM: Deref, RM: Deref, L: Deref, CMH: Deref> P
13771388
// room in the send buffer, put the error message there...
13781389
self.do_attempt_write_data(&mut descriptor, &mut peer);
13791390
} else {
1380-
log_trace!(self.logger, "Handling DisconnectPeer HandleError event in peer_handler for node {} with no message", log_pubkey!(node_id));
1391+
log_gossip!(self.logger, "Handling DisconnectPeer HandleError event in peer_handler for node {} with no message", log_pubkey!(node_id));
13811392
}
13821393
}
13831394
descriptor.disconnect_socket();
@@ -1405,7 +1416,7 @@ impl<Descriptor: SocketDescriptor, CM: Deref, RM: Deref, L: Deref, CMH: Deref> P
14051416
self.enqueue_message(get_peer_for_forwarding!(node_id), msg);
14061417
}
14071418
MessageSendEvent::SendReplyChannelRange { ref node_id, ref msg } => {
1408-
log_trace!(self.logger, "Handling SendReplyChannelRange event in peer_handler for node {} with num_scids={} first_blocknum={} number_of_blocks={}, sync_complete={}",
1419+
log_gossip!(self.logger, "Handling SendReplyChannelRange event in peer_handler for node {} with num_scids={} first_blocknum={} number_of_blocks={}, sync_complete={}",
14091420
log_pubkey!(node_id),
14101421
msg.short_channel_ids.len(),
14111422
msg.first_blocknum,
@@ -1588,6 +1599,15 @@ impl<Descriptor: SocketDescriptor, CM: Deref, RM: Deref, L: Deref, CMH: Deref> P
15881599
}
15891600
}
15901601

1602+
fn is_gossip_msg(type_id: u16) -> bool {
1603+
match type_id {
1604+
msgs::ChannelAnnouncement::TYPE |
1605+
msgs::ChannelUpdate::TYPE |
1606+
msgs::NodeAnnouncement::TYPE |
1607+
_ => false
1608+
}
1609+
}
1610+
15911611
#[cfg(test)]
15921612
mod tests {
15931613
use ln::peer_handler::{PeerManager, MessageHandler, SocketDescriptor, IgnoringMessageHandler};

lightning/src/routing/network_graph.rs

Lines changed: 4 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -299,7 +299,7 @@ where C::Target: chain::Access, L::Target: Logger
299299

300300
fn handle_channel_announcement(&self, msg: &msgs::ChannelAnnouncement) -> Result<bool, LightningError> {
301301
self.network_graph.update_channel_from_announcement(msg, &self.chain_access, &self.secp_ctx)?;
302-
log_trace!(self.logger, "Added channel_announcement for {}{}", msg.contents.short_channel_id, if !msg.contents.excess_data.is_empty() { " with excess uninterpreted data!" } else { "" });
302+
log_gossip!(self.logger, "Added channel_announcement for {}{}", msg.contents.short_channel_id, if !msg.contents.excess_data.is_empty() { " with excess uninterpreted data!" } else { "" });
303303
Ok(msg.contents.excess_data.len() <= MAX_EXCESS_BYTES_FOR_RELAY)
304304
}
305305

@@ -848,7 +848,7 @@ impl NetworkGraph {
848848
Some(node) => {
849849
if let Some(node_info) = node.announcement_info.as_ref() {
850850
if node_info.last_update >= msg.timestamp {
851-
return Err(LightningError{err: "Update older than last processed update".to_owned(), action: ErrorAction::IgnoreAndLog(Level::Trace)});
851+
return Err(LightningError{err: "Update older than last processed update".to_owned(), action: ErrorAction::IgnoreAndLog(Level::Gossip)});
852852
}
853853
}
854854

@@ -977,7 +977,7 @@ impl NetworkGraph {
977977
Self::remove_channel_in_nodes(&mut nodes, &entry.get(), msg.short_channel_id);
978978
*entry.get_mut() = chan_info;
979979
} else {
980-
return Err(LightningError{err: "Already have knowledge of channel".to_owned(), action: ErrorAction::IgnoreAndLog(Level::Trace)})
980+
return Err(LightningError{err: "Already have knowledge of channel".to_owned(), action: ErrorAction::IgnoreAndLog(Level::Gossip)})
981981
}
982982
},
983983
BtreeEntry::Vacant(entry) => {
@@ -1083,7 +1083,7 @@ impl NetworkGraph {
10831083
( $target: expr, $src_node: expr) => {
10841084
if let Some(existing_chan_info) = $target.as_ref() {
10851085
if existing_chan_info.last_update >= msg.timestamp {
1086-
return Err(LightningError{err: "Update older than last processed update".to_owned(), action: ErrorAction::IgnoreAndLog(Level::Trace)});
1086+
return Err(LightningError{err: "Update older than last processed update".to_owned(), action: ErrorAction::IgnoreAndLog(Level::Gossip)});
10871087
}
10881088
chan_was_enabled = existing_chan_info.enabled;
10891089
} else {

lightning/src/util/logger.rs

Lines changed: 12 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -17,11 +17,13 @@
1717
use core::cmp;
1818
use core::fmt;
1919

20-
static LOG_LEVEL_NAMES: [&'static str; 5] = ["TRACE", "DEBUG", "INFO", "WARN", "ERROR"];
20+
static LOG_LEVEL_NAMES: [&'static str; 6] = ["GOSSIP", "TRACE", "DEBUG", "INFO", "WARN", "ERROR"];
2121

2222
/// An enum representing the available verbosity levels of the logger.
2323
#[derive(Copy, Clone, PartialEq, Eq, Debug, Hash)]
2424
pub enum Level {
25+
/// Designates extremely verbose information, including gossip-induced messages
26+
Gossip,
2527
/// Designates very low priority, often extremely verbose, information
2628
Trace,
2729
/// Designates lower priority information
@@ -78,7 +80,7 @@ impl Level {
7880
/// Returns the most verbose logging level.
7981
#[inline]
8082
pub fn max() -> Level {
81-
Level::Trace
83+
Level::Gossip
8284
}
8385
}
8486

@@ -163,13 +165,14 @@ mod tests {
163165
log_info!(self.logger, "This is an info");
164166
log_debug!(self.logger, "This is a debug");
165167
log_trace!(self.logger, "This is a trace");
168+
log_gossip!(self.logger, "This is a gossip");
166169
}
167170
}
168171

169172
#[test]
170173
fn test_logging_macros() {
171174
let mut logger = TestLogger::new();
172-
logger.enable(Level::Trace);
175+
logger.enable(Level::Gossip);
173176
let logger : Arc<Logger> = Arc::new(logger);
174177
let wrapper = WrapperLog::new(Arc::clone(&logger));
175178
wrapper.call_macros();
@@ -189,7 +192,10 @@ mod tests {
189192
assert!(Level::Debug > Level::Trace);
190193
assert!(Level::Debug >= Level::Trace);
191194
assert!(Level::Debug >= Level::Debug);
195+
assert!(Level::Trace > Level::Gossip);
196+
assert!(Level::Trace >= Level::Gossip);
192197
assert!(Level::Trace >= Level::Trace);
198+
assert!(Level::Gossip >= Level::Gossip);
193199

194200
assert!(Level::Error <= Level::Error);
195201
assert!(Level::Warn < Level::Error);
@@ -204,5 +210,8 @@ mod tests {
204210
assert!(Level::Trace < Level::Debug);
205211
assert!(Level::Trace <= Level::Debug);
206212
assert!(Level::Trace <= Level::Trace);
213+
assert!(Level::Gossip < Level::Trace);
214+
assert!(Level::Gossip <= Level::Trace);
215+
assert!(Level::Gossip <= Level::Gossip);
207216
}
208217
}

lightning/src/util/macro_logger.rs

Lines changed: 9 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -174,6 +174,8 @@ macro_rules! log_given_level {
174174
$crate::util::logger::Level::Debug => log_internal!($logger, $lvl, $($arg)*),
175175
#[cfg(not(any(feature = "max_level_off", feature = "max_level_error", feature = "max_level_warn", feature = "max_level_info", feature = "max_level_debug")))]
176176
$crate::util::logger::Level::Trace => log_internal!($logger, $lvl, $($arg)*),
177+
#[cfg(not(any(feature = "max_level_off", feature = "max_level_error", feature = "max_level_warn", feature = "max_level_info", feature = "max_level_debug", feature = "max_level_trace")))]
178+
$crate::util::logger::Level::Gossip => log_internal!($logger, $lvl, $($arg)*),
177179

178180
#[cfg(any(feature = "max_level_off", feature = "max_level_error", feature = "max_level_warn", feature = "max_level_info", feature = "max_level_debug"))]
179181
_ => {
@@ -216,3 +218,10 @@ macro_rules! log_trace {
216218
log_given_level!($logger, $crate::util::logger::Level::Trace, $($arg)*)
217219
)
218220
}
221+
222+
/// Log a gossip log.
223+
macro_rules! log_gossip {
224+
($logger: expr, $($arg:tt)*) => (
225+
log_given_level!($logger, $crate::util::logger::Level::Gossip, $($arg)*);
226+
)
227+
}

0 commit comments

Comments
 (0)