Security News
The Risks of Misguided Research in Supply Chain Security
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.
strong-log-transformer
Advanced tools
Stream transformer that prefixes lines with timestamps and other things.
The strong-log-transformer package is a tool designed for processing and transforming log data. It provides functionalities such as filtering, formatting, and modifying log entries, making it useful for developers who need to manage and analyze log output from various sources.
Log Filtering
This feature allows users to filter log entries based on specific criteria such as log level. In the provided code sample, the logTransformer.filter function is used to create a filter stream that only passes through log entries with a level of 'error'.
const logTransformer = require('strong-log-transformer');
const filter = logTransformer.filter({level: 'error'});
process.stdin.pipe(filter).pipe(process.stdout);
Log Formatting
This feature enables users to format log entries in a customizable way. In the example, the logTransformer.format function is used to add a timestamp tag to each log entry, enhancing readability and providing a time context for log analysis.
const logTransformer = require('strong-log-transformer');
const format = logTransformer.format({tag: 'timestamp'});
process.stdin.pipe(format).pipe(process.stdout);
Log Modification
This feature provides the capability to modify log entries programmatically. The code sample demonstrates how to use the logTransformer.transform function to create a transformation stream that converts all log messages to uppercase, allowing for custom log manipulation.
const logTransformer = require('strong-log-transformer');
const modify = logTransformer.transform(function(log) {
log.message = log.message.toUpperCase();
return log;
});
process.stdin.pipe(modify).pipe(process.stdout);
Bunyan is a simple and fast JSON logging library for node.js services. It provides similar functionalities to strong-log-transformer, such as log filtering and formatting, but it is more focused on creating JSON logs for easier processing and analysis.
Winston is a multi-transport async logging library for Node.js. Like strong-log-transformer, it allows for log filtering, formatting, and modification. However, Winston offers more flexibility with its transport system, which supports logging to multiple destinations out of the box.
Morgan is an HTTP request logger middleware for node.js. It is similar to strong-log-transformer in its ability to format log entries, but it is specifically designed for logging HTTP requests in web applications, making it more specialized.
A stream filter for performing common log stream transformations like timestamping and joining multi-line messages.
This is not a logger! But it may be useful for rolling your own logger.
Install strong-log-transformer and add it to your dependencies list.
npm install --save strong-log-transformer
When installed globally the sl-log-transformer
CLI utility is exposed. It is
primarily used for testing, but it can also be used as an alternative to
awk or sed for jobs such as timestamping every line of another process's
output. This can be useful for cron jobs, for example.
$ npm install -g strong-log-transformer
$ sl-log-tranformer --help
Usage: sl-log-transformer [options]
Stream transformer that prefixes lines with timestamps and other things.
OPTIONS:
--format FORMAT default: "text"
--tag TAG default: ""
--mergeMultiline default: off
--timeStamp default: off
In order to keep things flowing when line merging is enabled (disabled by
default) there is a sliding 10ms timeout for flushing the buffer. This means
that whitespace leading lines are only considered part of the previous line if
they arrive within 10ms of the previous line, which should be reasonable
considering the lines were likely written in the same write()
.
Here's an example using the transformer to annotate log messages from cluster workers.
var cluster = require('cluster');
if (cluster.isMaster) {
// Make sure workers get their own stdout/stderr streams
cluster.setupMaster({silent: true});
// require log transformer module
var transformer = require('strong-log-transformer');
// Following the 12-factor app model, we pipe to stdout, but we could easily
// pipe to any other stream(s), such as a FileStream for a log file.
// stdout is plain line-oriented logs, but we want to add timestamps
var info = transformer({ timeStamp: true,
tag: 'INFO' });
// stderr will only be used for strack traces on crash, which are multi-line
var error = transformer({ timeStamp: true,
tag: 'ERROR',
mergeMultiline: true });
// Each worker's stdout/stderr gets piped into our info and erro transformers
cluster.on('fork', function(worker) {
console.error('connecting worker');
worker.process.stdout.pipe(info).pipe(process.stdout);
worker.process.stderr.pipe(error).pipe(process.stdout);
});
//... cluster fork logic goes here ...
cluster.fork();
} else {
//... worker code here ...
console.log('new worker, this line will be timestamped!');
throw new Error('This will generate a multi-line message!');
}
When we run the example code as example.js
we get:
$ node example.js
connecting worker
2014-06-08T18:54:00.920Z INFO new worker, this line will be timestamped!
2014-06-08T18:54:00.926Z ERROR /Users/ryan/work/strong-log-transformer/e.js:33\n throw new Error('This will generate a multi-line message!');\n ^
2014-06-08T18:54:00.926Z ERROR Error: This will generate a multi-line message!\n at null._onTimeout (/Users/ryan/work/strong-log-transformer/e.js:33:11)\n at Timer.listOnTimeout [as ontimeout] (timers.js:110:15)
FAQs
Stream transformer that prefixes lines with timestamps and other things.
The npm package strong-log-transformer receives a total of 2,693,007 weekly downloads. As such, strong-log-transformer popularity was classified as popular.
We found that strong-log-transformer demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 17 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
Snyk's use of malicious npm packages for research raises ethical concerns, highlighting risks in public deployment, data exfiltration, and unauthorized testing.
Research
Security News
Socket researchers found several malicious npm packages typosquatting Chalk and Chokidar, targeting Node.js developers with kill switches and data theft.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.