UNPKG

verdaccio

Version:

A lightweight private npm proxy registry

181 lines (149 loc) 17.1 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.setup = setup; exports.logger = void 0; var _prettyTimestamped = require("./logger/format/pretty-timestamped"); var _pretty = require("./logger/format/pretty"); var _json = require("./logger/format/json"); /* eslint-disable */ const cluster = require('cluster'); const Logger = require('bunyan'); const Error = require('http-errors'); const Stream = require('stream'); const pkgJSON = require('../../package.json'); const _ = require('lodash'); const dayjs = require('dayjs'); /** * A RotatingFileStream that modifies the message first */ class VerdaccioRotatingFileStream extends Logger.RotatingFileStream { // We depend on mv so that this is there write(obj) { super.write((0, _json.jsonFormat)(obj, false)); } rotate() { super.rotate(); this.emit('rotated'); } } let logger; exports.logger = logger; const DEFAULT_LOGGER_CONF = [{ type: 'stdout', format: 'pretty', level: 'http' }]; /** * Setup the Buyan logger * @param {*} logs list of log configuration */ function setup(logs, { logStart } = { logStart: true }) { const streams = []; if (logs == null) { logs = DEFAULT_LOGGER_CONF; } logs.forEach(function (target) { let level = target.level || 35; if (level === 'http') { level = 35; } // create a stream for each log configuration if (target.type === 'rotating-file') { if (target.format !== 'json') { throw new Error('Rotating file streams only work with JSON!'); } if (cluster.isWorker) { // https://github.com/trentm/node-bunyan#stream-type-rotating-file throw new Error('Cluster mode is not supported for rotating-file!'); } const stream = new VerdaccioRotatingFileStream( // @ts-ignore _.merge({}, // Defaults can be found here: https://github.com/trentm/node-bunyan#stream-type-rotating-file target.options || {}, { path: target.path, level })); const rotateStream = { type: 'raw', level, stream }; if (logStart) { stream.on('rotated', () => logger.warn('Start of logfile')); } streams.push(rotateStream); } else { const stream = new Stream(); stream.writable = true; let destination; let destinationIsTTY = false; if (target.type === 'file') { // destination stream destination = require('fs').createWriteStream(target.path, { flags: 'a', encoding: 'utf8' }); destination.on('error', function (err) { stream.emit('error', err); }); } else if (target.type === 'stdout' || target.type === 'stderr') { destination = target.type === 'stdout' ? process.stdout : process.stderr; destinationIsTTY = destination.isTTY; } else { throw Error('wrong target type for a log'); } if (target.format === 'pretty') { // making fake stream for pretty printing stream.write = obj => { destination.write((0, _pretty.pretty)(obj, destinationIsTTY)); }; } else if (target.format === 'pretty-timestamped') { // making fake stream for pretty printing stream.write = obj => { destination.write((0, _prettyTimestamped.prettyTimestamped)(obj, destinationIsTTY)); }; } else { stream.write = obj => { destination.write((0, _json.jsonFormat)(obj, destinationIsTTY)); }; } streams.push({ // @ts-ignore type: 'raw', // @ts-ignore level, // @ts-ignore stream: stream }); } }); // buyan default configuration exports.logger = logger = new Logger({ name: pkgJSON.name, streams: streams, serializers: { err: Logger.stdSerializers.err, req: Logger.stdSerializers.req, res: Logger.stdSerializers.res } }); // In case of an empty log file, we ensure there is always something logged. This also helps see if the server // was restarted in any cases if (logStart) { logger.warn('Verdaccio started'); } process.on('SIGUSR2', function () { // https://github.com/trentm/node-bunyan#stream-type-rotating-file if (logger) { /** * Note on log rotation: Often you may be using external log rotation utilities like logrotate on Linux or logadm * on SmartOS/Illumos. In those cases, unless your are ensuring "copy and truncate" semantics * (via copytruncate with logrotate or -c with logadm) then the fd for your 'file' stream will change. */ logger.reopenFileStreams(); } }); } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/lib/logger.ts"],"names":["cluster","require","Logger","Error","Stream","pkgJSON","_","dayjs","VerdaccioRotatingFileStream","RotatingFileStream","write","obj","rotate","emit","logger","DEFAULT_LOGGER_CONF","type","format","level","setup","logs","logStart","streams","forEach","target","isWorker","stream","merge","options","path","rotateStream","on","warn","push","writable","destination","destinationIsTTY","createWriteStream","flags","encoding","err","process","stdout","stderr","isTTY","name","serializers","stdSerializers","req","res","reopenFileStreams"],"mappings":"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","sourcesContent":["/* eslint-disable */\n\nimport { prettyTimestamped } from './logger/format/pretty-timestamped';\nimport { pretty } from './logger/format/pretty';\nimport { jsonFormat } from './logger/format/json';\n\nconst cluster = require('cluster');\nconst Logger = require('bunyan');\nconst Error = require('http-errors');\nconst Stream = require('stream');\nconst pkgJSON = require('../../package.json');\nconst _ = require('lodash');\nconst dayjs = require('dayjs');\n\n/**\n * A RotatingFileStream that modifies the message first\n */\nclass VerdaccioRotatingFileStream extends Logger.RotatingFileStream {\n  // We depend on mv so that this is there\n  write(obj) {\n    super.write(jsonFormat(obj, false));\n  }\n\n  rotate(): void {\n    super.rotate();\n    this.emit('rotated');\n  }\n}\n\nlet logger;\n\nexport interface LoggerTarget {\n  type?: string;\n  format?: string;\n  level?: string;\n  options?: any;\n  path?: string;\n}\n\nconst DEFAULT_LOGGER_CONF = [{ type: 'stdout', format: 'pretty', level: 'http' }];\n\n/**\n * Setup the Buyan logger\n * @param {*} logs list of log configuration\n */\nfunction setup(logs, { logStart } = { logStart: true }) {\n  const streams: any = [];\n  if (logs == null) {\n    logs = DEFAULT_LOGGER_CONF;\n  }\n\n  logs.forEach(function (target: LoggerTarget) {\n    let level = target.level || 35;\n    if (level === 'http') {\n      level = 35;\n    }\n\n    // create a stream for each log configuration\n    if (target.type === 'rotating-file') {\n      if (target.format !== 'json') {\n        throw new Error('Rotating file streams only work with JSON!');\n      }\n      if (cluster.isWorker) {\n        // https://github.com/trentm/node-bunyan#stream-type-rotating-file\n        throw new Error('Cluster mode is not supported for rotating-file!');\n      }\n\n      const stream = new VerdaccioRotatingFileStream(\n        // @ts-ignore\n        _.merge(\n          {},\n          // Defaults can be found here: https://github.com/trentm/node-bunyan#stream-type-rotating-file\n          target.options || {},\n          { path: target.path, level }\n        )\n      );\n\n      const rotateStream = {\n        type: 'raw',\n        level,\n        stream\n      };\n\n      if (logStart) {\n        stream.on('rotated', () => logger.warn('Start of logfile'));\n      }\n\n      streams.push(rotateStream);\n    } else {\n      const stream = new Stream();\n      stream.writable = true;\n\n      let destination;\n      let destinationIsTTY = false;\n      if (target.type === 'file') {\n        // destination stream\n        destination = require('fs').createWriteStream(target.path, {\n          flags: 'a',\n          encoding: 'utf8'\n        });\n        destination.on('error', function (err) {\n          stream.emit('error', err);\n        });\n      } else if (target.type === 'stdout' || target.type === 'stderr') {\n        destination = target.type === 'stdout' ? process.stdout : process.stderr;\n        destinationIsTTY = destination.isTTY;\n      } else {\n        throw Error('wrong target type for a log');\n      }\n\n      if (target.format === 'pretty') {\n        // making fake stream for pretty printing\n        stream.write = (obj) => {\n          destination.write(pretty(obj, destinationIsTTY));\n        };\n      } else if (target.format === 'pretty-timestamped') {\n        // making fake stream for pretty printing\n        stream.write = (obj) => {\n          destination.write(prettyTimestamped(obj, destinationIsTTY));\n        };\n      } else {\n        stream.write = (obj) => {\n          destination.write(jsonFormat(obj, destinationIsTTY));\n        };\n      }\n\n      streams.push({\n        // @ts-ignore\n        type: 'raw',\n        // @ts-ignore\n        level,\n        // @ts-ignore\n        stream: stream\n      });\n    }\n  });\n\n  // buyan default configuration\n  logger = new Logger({\n    name: pkgJSON.name,\n    streams: streams,\n    serializers: {\n      err: Logger.stdSerializers.err,\n      req: Logger.stdSerializers.req,\n      res: Logger.stdSerializers.res\n    }\n  });\n\n  // In case of an empty log file, we ensure there is always something logged. This also helps see if the server\n  // was restarted in any cases\n  if (logStart) {\n    logger.warn('Verdaccio started');\n  }\n\n  process.on('SIGUSR2', function () {\n    // https://github.com/trentm/node-bunyan#stream-type-rotating-file\n    if (logger) {\n      /**\n       * Note on log rotation: Often you may be using external log rotation utilities like logrotate on Linux or logadm\n       * on SmartOS/Illumos. In those cases, unless your are ensuring \"copy and truncate\" semantics\n       * (via copytruncate with logrotate or -c with logadm) then the fd for your 'file' stream will change.\n       */\n      logger.reopenFileStreams();\n    }\n  });\n}\n\nexport { setup, logger };\n"]}