pino.js 888 B
Newer Older
Amaury Martiny's avatar
Amaury Martiny committed
// Copyright 2015-2018 Parity Technologies (UK) Ltd.
// This file is part of Parity.
//
// SPDX-License-Identifier: MIT

const { app } = require('electron');
const fs = require('fs');
const { multistream } = require('pino-multi-stream');
const pino = require('pino');

// Pino by default outputs JSON. We prettify that.
const pretty = pino.pretty();
pretty.pipe(process.stdout);

// Create 2 output streams:
// - parity.log file (raw JSON)
// - stdout (prettified output)
const streams = [
  {
    level: 'info',
    stream: fs.createWriteStream(`${app.getPath('userData')}/parity.log`)
  },
  { level: 'info', stream: pretty }
];

/**
Amaury Martiny's avatar
Amaury Martiny committed
 * Usage: const pino = require('../path/to/pino')({ name: 'something' });
Amaury Martiny's avatar
Amaury Martiny committed
 * @param {Object} opts - Options to pass to pino. Defaults to { name: 'electron' }.
Amaury Martiny's avatar
Amaury Martiny committed
 */
Amaury Martiny's avatar
Amaury Martiny committed
module.exports = opts =>
  pino({ name: 'electron', ...opts }, multistream(streams));