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.
inv-loggers
Advanced tools
a little server-side library to log things with colors, with a special care for promise chains
in a terminal at your project root:
npm install inv-loggers --save
then in your javascript project:
var log = require('inv-loggers')
or as I prefer, extend your _ object
var _ = require('lodash') // or var _ = require('underscore')
var loggers = require('inv-loggers')
_.extend _, loggers
this is the syntax we will use in the following examples
the basic logger from which all others are just variations
var obj = {a: 1}
_.log(obj, 'that zuper obj')
which in logs, generate something like:
****** that zuper obj ******
{ a: 1 }
-----
with some colors that can't be made visible in this markdown file (in the caseof _.log
, cyan)
And that's pretty much all: a label with fat delimiters and some colors to make your debugging/logs scanning easy
NB: returns the object for convenience
The same but in green
The same but in blue
The same but in yellow
NB: returns undefined to avoid returning an error object
The same but in red, used to log error objects.
It will try to log err.stack
instead of just the err object to get a stack trace in logs when available
NB: returns undefined to avoid returning an error object
The same as error but throws the error object instead of just returning undefined (especially useful used as a partial in a promise chain, see hereafter)
in promise chains, it can be useful to log an object passed at the middle of the chain, but using just those loggers would be sub-optimal, verbose:
getSomeData()
.then(function (result) { return _.log(result, 'some data') })
.then(doSomethingWithIt)
.catch(function (error) { _.error(error, 'some data error')})
so we use partials instead, to which we pass a label and which returns a function with a label pre-set. So we can rewrite this example like so:
getSomeData()
.then(_.Log('some data'))
.then(doSomethingWithIt)
.catch(_.Error('some data error'))
Note here that if we want to be able to log an error generated in this chain but still be able to handle it elsewhere, we need to make sure the error is rethrown, which can be done by replacing the last line with
.catch(_.ErrorRethrow('some data error'))
The partial functions have the same name as the basic functions but simply capitalized: Log, Info, Success, Warn, Error, ErrorRethrow
Capitalizing high-order functions as such is a convention used in my projects as I use very few constructors, but you might thing it is an heretic choice. In this case, don't use this library.
FAQs
loggers and partial loggers
The npm package inv-loggers receives a total of 4 weekly downloads. As such, inv-loggers popularity was classified as not popular.
We found that inv-loggers 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.