verdaccio
Version:
A lightweight private npm proxy registry
181 lines (149 loc) • 17.1 kB
JavaScript
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"]}
;