Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
The hook-std npm package allows you to hook into and modify the standard output (stdout) and standard error (stderr) streams in Node.js. This can be useful for capturing logs, testing console output, or redirecting output for various purposes.
Capture stdout
This feature allows you to capture and manipulate the standard output (stdout) stream. The code sample demonstrates how to capture console.log output and process it.
const hookStd = require('hook-std');
(async () => {
const unhook = hookStd.stdout({silent: true}, output => {
console.log('Captured output:', output);
});
console.log('This will be captured');
await unhook();
})();
Capture stderr
This feature allows you to capture and manipulate the standard error (stderr) stream. The code sample demonstrates how to capture console.error output and process it.
const hookStd = require('hook-std');
(async () => {
const unhook = hookStd.stderr({silent: true}, output => {
console.error('Captured error:', output);
});
console.error('This error will be captured');
await unhook();
})();
Modify stdout
This feature allows you to modify the standard output (stdout) stream before it is printed to the console. The code sample demonstrates how to prepend a string to the console.log output.
const hookStd = require('hook-std');
(async () => {
const unhook = hookStd.stdout(output => {
return 'Modified output: ' + output;
});
console.log('This will be modified');
await unhook();
})();
Modify stderr
This feature allows you to modify the standard error (stderr) stream before it is printed to the console. The code sample demonstrates how to prepend a string to the console.error output.
const hookStd = require('hook-std');
(async () => {
const unhook = hookStd.stderr(output => {
return 'Modified error: ' + output;
});
console.error('This error will be modified');
await unhook();
})();
The capture-console package provides similar functionality to hook-std by allowing you to capture and manipulate stdout and stderr streams. However, it offers a simpler API and fewer customization options compared to hook-std.
The intercept-stdout package allows you to intercept and modify stdout and stderr streams. It is similar to hook-std but focuses more on simplicity and ease of use, with fewer advanced features.
The stdout-stderr package provides utilities to capture and manipulate stdout and stderr streams. It is similar to hook-std but offers a more straightforward API and is designed to be easy to integrate into testing frameworks.
Hook and modify stdout and stderr
npm install hook-std
import assert from 'node:assert';
import {hookStdout} from 'hook-std';
const promise = hookStdout(output => {
promise.unhook();
assert.strictEqual(output.trim(), 'unicorn');
});
console.log('unicorn');
await promise;
You can also unhook using the second transform
method parameter:
import assert from 'node:assert';
import {hookStdout} from 'hook-std';
const promise = hookStdout((output, unhook) => {
unhook();
assert.strictEqual(output.trim(), 'unicorn');
});
console.log('unicorn');
await promise;
Hook streams in streams
option, or stdout and stderr if none are specified.
Returns a Promise
with a unhook()
method which, when called, unhooks both stdout and stderr and resolves the Promise
with an empty result.
Hook stdout.
Returns a Promise
with a unhook()
method which, when called, unhooks stdout and resolves the Promise
with an empty result.
Hook stderr.
Returns a Promise
with a unhook()
method which, when called, unhooks stderr and resolves the Promise
with an empty result.
Type: object
Type: boolean
Default: true
Suppress stdout/stderr output.
Type: boolean
Default: false
Automatically unhook after the first call.
Type: stream.Writable[]
Default: [process.stdout, process.stderr]
The writable streams to hook. This can be useful for libraries allowing users to configure a writable stream to write to.
Type: Function
Receives stdout/stderr as the first argument and the unhook method as the second argument. Return a string to modify it. Optionally, when in silent mode, you may return a boolean
to influence the return value of .write(…)
.
FAQs
Hook and modify stdout and stderr
We found that hook-std demonstrated a not healthy version release cadence and project activity because the last version was released a year ago. It has 1 open source maintainer 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
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.