41 lines
1.3 KiB

#include <common/gen_status_wire.h>
#include <lightningd/log_status.h>
bool log_status_msg(struct log *log,
const struct node_id *node_id,
const u8 *msg)
{
char *entry, *who;
u8 *data;
struct node_id *suggested_node_id;
enum log_level level;
bool call_notifier;
if (fromwire_status_log(msg, msg, &level, &suggested_node_id, &entry)) {
/* If there's not already a node_id (global subdirs), they can
* set it */
if (!node_id)
node_id = suggested_node_id;
/* No per-peer daemon should claim a different peer! */
else if (suggested_node_id
&& !node_id_eq(node_id, suggested_node_id))
return false;
if (level != LOG_IO_IN && level != LOG_IO_OUT) {
call_notifier = (level == LOG_BROKEN ||
level == LOG_UNUSUAL)? true : false;
log_(log, level, node_id, call_notifier, "%s", entry);
return true;
}
/* FIXME: This would be far more efficient to copy to log in place, rather than doing the additional allocation in fromwire. */
} else if (fromwire_status_io(msg, msg, &level, &suggested_node_id,
&who, &data)) {
if (level == LOG_IO_IN || level == LOG_IO_OUT) {
if (!node_id)
node_id = suggested_node_id;
log_io(log, level, node_id, who, data, tal_count(data));
return true;
}
}
return false;
}