A happy little logger with custom levels, colors, formats, output options and more
npm install sloth-logger
SlothLogger has 5 log types by default and the log level is set to show all logs. The default log types are: error, warn, info, inspect, debug.
By default, logs are output to the console.
const SlothLogger = require("sloth-logger");
const logger = new SlothLogger.Logger();
logger.error("Error Log Line");
logger.debug("Debug Log Line");
logger.info("Line with variable: %s", "stringVar");
[ERROR][3/10/16 12:20:26 PM EST][log.js:47] Error Log Line
[DEBUG][3/10/16 12:20:26 PM EST][log.js:48] Debug Log Line
[INFO][3/10/16 12:59:26 PM EST][log.js:49] Line with variable: stringVar
Each Log Level contains the following properties. New levels are created with these defaults
'destination': process.stdout,
'dateFormat': 'm/dd/yy h:MM:ss TT Z',
'color': 'gray',
'sendEmail': false,
'inspect': false,
'inspectOptions': {},
'logLevelThreshold': 5,
'format': '${logLevelName}[${logDate}][${relativeFilePath}:${line}] ${logMessage}',
'aggregator': null
destination: Takes an instance of an fs.WriteStream or a file path string
dateFormat: Takes a date format. Uses dateformat
color: Takes a color string. Uses colors
sendEmail: Takes a Boolean. States whether individual log entries should be emailed
inspect: Takes a Boolean. States whether to use util.inspect when printing log entry
inspectOptions: Takes an object to pass to the util.inspect function
logLevelThreshold: Takes an integer. Log will only be handled if logLevelThreshold is less than or equal to logger's logLevel
aggregator: Takes an Aggregator. If set, sendEmail option is ignored and emails are only sent when aggregotor.send() is called
format: Takes and ES2015 template literal style string.
fullFilePath: full path to file calling logger
relativeFilePath: path to file relative to the process.cwd
line: line of file calling logger
logDate: formatting text string of date/time. Uses dateformat
logLevelName: name of the log level (i.e. error, warn, etc) enclosed in []
logMessage: formatted message
These settings can be customized when a new SlotLogger is initialized or during runtime.
let logger = new SlothLogger.Logger({
levels: {
info: {
destination: "logs/info.log"
},
warn: {
destination: "logs/warn.log"
},
crit: {
destination: process.stderr,
dateFormat: "m/dd/yy h:MM:ss TT Z",
logLevelThreshold: 0
}
}
});
Note, that if you'd like to add a custom log level, simply add a new object keyed by the name of your new level. The above would create a new logger.crit() function with the specified adjustments to the default log level options.
If you're currently debugging a single file and wish to ignore your debug messages on other files, you can specify a custom log level on a per-file basis.
To do this, you will need to set your logger as a global function
const SlothLogger = require("../index.js");
global.logger = new SlothLogger.Logger({
logLevel: 1
});
Then, at the top of the file that you are debugging, you will specify the log level to a higher number
logger.setLogLevelForThisFile(4);
You can also change the logLevel at runtime if you are debugging a specific section of synchronous code
const SlothLogger = require("../index.js");
global.logger = new SlothLogger.Logger({
logLevel: 1
});
logger.debug("I will not print");
logger.logLevel = 5;
logger.debug("I will print now");
logger.logLevel = 1;
logger.debug("I will not print again");
By providing your logger with email settings, you can set each log type to send an email every time the logger is called.
SlothLogger uses nodemailer version 4.6.7 for mailing. Options for nodemailer transport can be found in their documentation.
const SlothLogger = require("sloth-logger");
const logger = new SlothLogger.Logger({
emailSettings: {
from: "noreply@mycompany.com",
to: "admin@mycompany.com",
transportConfig: {
host: "smtp.mycompany.com",
port: 25
}
}
});
logger.sendEmail("error", true);
You can also set a log aggregator to collect log entries and send them in bulk. sendEmail attributes of log types are ignored if an aggregator is assigned. Log entries will always be emailed and they will only be emailed once send() has been called on the Aggregator.
const SlothLogger = require("sloth-logger");
const logger = new SlothLogger.Logger({
emailSettings: {
from: "noreply@mycompany.com",
to: "admin@mycompany.com",
subject: "Error logs from server",
transportConfig: {
host: "smtp.mycompany.com",
port: 25
}
}
});
const aggregator = new SlothLogger.Aggregator({
emailSettings: {
from: "noreply@mycompany.com",
to: "admin@mycompany.com",
subject: "Aggregated logs from server",
transportConfig: {
host: "smtp.mycompany.com",
port: 25
}
}
});
logger.setLevelProps("error", { aggregator: aggregator });
logger.error("add this line to error log");
aggregator.send(function(err) {
if (err) {
console.error(err);
}
});