Skip to content

Releases: pinojs/pino

v6.13.3

22 Sep 13:14
Compare
Choose a tag to compare
  • Disable 100% coverage check

Full Changelog: v6.13.2...v6.13.3

v7.0.0-rc.6

21 Sep 10:33
Compare
Choose a tag to compare
v7.0.0-rc.6 Pre-release
Pre-release

What's Changed

Full Changelog: v7.0.0-rc.5...v7.0.0-rc.6

v7.0.0-rc.5

19 Sep 22:51
Compare
Choose a tag to compare
v7.0.0-rc.5 Pre-release
Pre-release

What's Changed

  • Removed deprecated options in pino.child() by @mcollina in #1124
  • Update the options.level documentation of the child logger by @marcbachmann in #1125
  • fix: make pino.final sync flushes when no handler provided (#1126) by @javiertury in #1127
  • Removed multistream prettyPrint deprecation and clean up docs by @mcollina in #1123
  • dep: removes fast-safe-stringify dep by @leorossi in #1129
  • Remove whitespace from markdown files by @justinpage in #1131
  • build(deps): bump pino-abstract-transport from 0.2.0 to 0.3.0 by @dependabot in #1130
  • build(deps-dev): update pino-pretty requirement from ^v7.0.0 to ^v7.0.1 by @dependabot in #1132
  • added file.js to package.json

New Contributors

Full Changelog: v7.0.0-rc.4...v7.0.0-rc.5

v7.0.0-rc.4

08 Sep 16:34
Compare
Choose a tag to compare
v7.0.0-rc.4 Pre-release
Pre-release

What's Changed

Full Changelog: v7.0.0-rc.3...v7.0.0-rc.4

v6.13.2

06 Sep 13:51
Compare
Choose a tag to compare

What's Changed

  • Support the newer pino-pretty as well as the older in v6.x by @mcollina in #1117

Full Changelog: v6.13.1...v6.13.2

v7.0.0-rc.3

20 Aug 13:53
Compare
Choose a tag to compare
v7.0.0-rc.3 Pre-release
Pre-release

What's Changed

New Contributors

Full Changelog: v7.0.0-rc.2...v7.0.0-rc.3

v6.13.1

20 Aug 23:39
Compare
Choose a tag to compare
  • Reduce verbosity of deprecation warnings #1092

v7.0.0-rc.2

23 Jul 16:27
Compare
Choose a tag to compare
v7.0.0-rc.2 Pre-release
Pre-release

πŸ“š PR:

  • fix: transport async function example (#1071)
  • refactor: update typings (#1073)
  • Make sure that the main thread stays alive to process stdout. (#1075)

v7.0.0-rc.1

21 Jul 08:33
Compare
Choose a tag to compare
v7.0.0-rc.1 Pre-release
Pre-release

v7.0.0-rc.1

  • First release of the v7 Release Candidate series.

All v7.0.0 release notes are included.

v7.0.0 release notes

New Features

pino.transport()

Create a a stream that routes logs to a worker thread that
wraps around a Pino Transport.

const pino = require('pino')
const transport = pino.transport({
  target: 'some-transport',
  options: { some: 'options for', the: 'transport' }
})
pino(transport)

Multiple transports may also be defined, and specific levels can be logged to each transport:

const pino = require('pino')
const transports = pino.transport({
  targets: [{
    level: 'info',
    target: 'some-transport',
    options: { some: 'options for', the: 'transport' }
  }, {
    level: 'trace',
    target: '#pino/file',
    options: { destination: '/path/to/store/logs' }
  }]
})
pino(transports)

For more on transports, how they work, and how to create them see the Transports documentation.

`pino.multistream()``

We have embedded a part of pino-multi-stream into pino itself, so you would be able to write to multiple streams from the same pino instance:

var fs = require('fs')
var pino = require('pino')
var streams = [
  {stream: fs.createWriteStream('/tmp/info.stream.out')},
  {level: 'debug', stream: fs.createWriteStream('/tmp/debug.stream.out')},
  {level: 'fatal', stream: fs.createWriteStream('/tmp/fatal.stream.out')}
]

var log = pino({
  level: 'debug' // this MUST be set at the lowest level of all the destinations
}, pino.multistream(streams))

log.debug('this will be written to /tmp/debug.stream.out')
log.info('this will be written to /tmp/debug.stream.out and /tmp/info.stream.out')
log.fatal('this will be written to /tmp/debug.stream.out, /tmp/info.stream.out and /tmp/fatal.stream.out')

This differs from pino.transport() as all the streams will be executed within the main thread, i.e. the one that created the pino instance.

Added TypeScript types

Types have been added to the the project, so you can now use pino with TypeScript without downloading any additional types: you should remove @types/pino from your project. The following typescript example would now work correctly:

import { pino } from "pino";

const log = pino();

log.info("hello world");
log.error("this is at error level");
log.info("the answer is %d", 42);
log.info({ obj: 42 }, "hello world");
log.info({ obj: 42, b: 2 }, "hello world");
log. info({ obj: { aa: "bbb" } }, "another");

Breaking Changes

Dropped Node.js v10.x

Node.js v10 went out of LTS/Maintenance in April 2021.
We are dropping support.

Apply err serializer everywhere

We will start applying the err serializer also to Error objects passed in as first argument to log methods, e.g. log.info(new Error('kaboom')) will pass through the serializer.

Pull Requests

  • removed all outstanding deprecations (#1057)
  • pino.transport() (#1003)
  • Add pino.multistream (#1004)
  • Add TS types (#913)
  • Apply err serializer everywhere. (#896)
  • Make the nestedKey only take effect in the serialized object and fix error detection and serialization #885

v6.13.0

21 Jul 08:04
Compare
Choose a tag to compare

πŸ“š PR:

  • refactor: deprecate child bindings apply options (#1067)
  • docs: fix an incorrect links in docs/lts.md (#1069)
  • build(deps): bump actions/setup-node from 2.1.5 to 2.2.0 (#1047)