verdaccio 5.6.2 → 5.8.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -2,6 +2,32 @@
2
2
 
3
3
  All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
4
4
 
5
+ ## [5.8.0](https://github.com/verdaccio/verdaccio/compare/v5.7.1...v5.8.0) (2022-03-12)
6
+
7
+
8
+ ### Features
9
+
10
+ * update ui with new modal banner ([#3062](https://github.com/verdaccio/verdaccio/issues/3062)) ([2ad085a](https://github.com/verdaccio/verdaccio/commit/2ad085a8e2adf3c19b3b2c7172b50f1a9cd6c9df))
11
+
12
+ ### [5.7.1](https://github.com/verdaccio/verdaccio/compare/v5.7.0...v5.7.1) (2022-03-08)
13
+
14
+
15
+ ### Bug Fixes
16
+
17
+ * **deps:** update dependency @verdaccio/ui-theme to v6.0.0-6-next.21 ([#3050](https://github.com/verdaccio/verdaccio/issues/3050)) ([ace754d](https://github.com/verdaccio/verdaccio/commit/ace754ddffb20ba4c465cfec409291d5d4f51142))
18
+ * missing colors on terminal ([#3049](https://github.com/verdaccio/verdaccio/issues/3049)) ([0f51a6c](https://github.com/verdaccio/verdaccio/commit/0f51a6ced5ee453b1cb6d7b375960d4b21ea4834))
19
+ * **deps:** update dependency dayjs to v1.10.8 ([#3036](https://github.com/verdaccio/verdaccio/issues/3036)) ([1221ffd](https://github.com/verdaccio/verdaccio/commit/1221ffd512fb678aee75cbe5f877670c32e1a056))
20
+ * **deps:** update dependency express to v4.17.3 ([#3039](https://github.com/verdaccio/verdaccio/issues/3039)) ([21c66f6](https://github.com/verdaccio/verdaccio/commit/21c66f65c3eae4bc0048056258376300785e87ff))
21
+ * **deps:** update dependency minimatch to v5 ([#3035](https://github.com/verdaccio/verdaccio/issues/3035)) ([2ef97d4](https://github.com/verdaccio/verdaccio/commit/2ef97d48470ee30bef59274472c14b14ba9cb29a))
22
+ * **deps:** update dependency verdaccio-htpasswd to v10.3.0 ([#3038](https://github.com/verdaccio/verdaccio/issues/3038)) ([24830e0](https://github.com/verdaccio/verdaccio/commit/24830e06e8dd7c00f783177a2048be0524ef42aa))
23
+
24
+ ## [5.7.0](https://github.com/verdaccio/verdaccio/compare/v5.6.2...v5.7.0) (2022-03-04)
25
+
26
+
27
+ ### Bug Fixes
28
+
29
+ * **deps:** update dependency @verdaccio/ui-theme to v6.0.0-6-next.20 ([#3028](https://github.com/verdaccio/verdaccio/issues/3028)) ([87e5e74](https://github.com/verdaccio/verdaccio/commit/87e5e74ea472bb107bb0d0c549531cbe4ed626a4))
30
+
5
31
  ### [5.6.2](https://github.com/verdaccio/verdaccio/compare/v5.6.1...v5.6.2) (2022-02-26)
6
32
 
7
33
 
@@ -10,8 +10,7 @@ module.exports = function prettyFactory(options) {
10
10
  // the break line must happens in the prettify component
11
11
  const breakLike = '\n';
12
12
  return inputData => {
13
- // FIXME: review colors by default is true
14
- return (0, _prettifier.printMessage)(inputData, options, true) + breakLike;
13
+ return (0, _prettifier.printMessage)(inputData, options, options.colors) + breakLike;
15
14
  };
16
15
  };
17
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvbG9nZ2VyL2Zvcm1hdHRlci9pbmRleC50cyJdLCJuYW1lcyI6WyJtb2R1bGUiLCJleHBvcnRzIiwicHJldHR5RmFjdG9yeSIsIm9wdGlvbnMiLCJicmVha0xpa2UiLCJpbnB1dERhdGEiXSwibWFwcGluZ3MiOiI7O0FBQUE7O0FBSUE7QUFDQTtBQUNBO0FBQ0E7QUFFQUEsTUFBTSxDQUFDQyxPQUFQLEdBQWlCLFNBQVNDLGFBQVQsQ0FBdUJDLE9BQXZCLEVBQXNFO0FBQ3JGO0FBQ0EsUUFBTUMsU0FBUyxHQUFHLElBQWxCO0FBQ0EsU0FBUUMsU0FBRCxJQUF1QjtBQUM1QjtBQUNBLFdBQU8sOEJBQWFBLFNBQWIsRUFBd0JGLE9BQXhCLEVBQWlDLElBQWpDLElBQXlDQyxTQUFoRDtBQUNELEdBSEQ7QUFJRCxDQVBEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgUHJldHR5T3B0aW9uc0V4dGVuZGVkLCBwcmludE1lc3NhZ2UgfSBmcm9tICcuL3ByZXR0aWZpZXInO1xuXG5leHBvcnQgdHlwZSBQcmV0dHlGYWN0b3J5ID0gKHBhcmFtKSA9PiBzdHJpbmc7XG5cbi8qXG4gb3B0aW9ucyBlZzpcbiB7IG1lc3NhZ2VLZXk6ICdtc2cnLCBsZXZlbEZpcnN0OiB0cnVlLCBwcmV0dHlTdGFtcDogZmFsc2UgfVxuICovXG5cbm1vZHVsZS5leHBvcnRzID0gZnVuY3Rpb24gcHJldHR5RmFjdG9yeShvcHRpb25zOiBQcmV0dHlPcHRpb25zRXh0ZW5kZWQpOiBQcmV0dHlGYWN0b3J5IHtcbiAgLy8gdGhlIGJyZWFrIGxpbmUgbXVzdCBoYXBwZW5zIGluIHRoZSBwcmV0dGlmeSBjb21wb25lbnRcbiAgY29uc3QgYnJlYWtMaWtlID0gJ1xcbic7XG4gIHJldHVybiAoaW5wdXREYXRhKTogc3RyaW5nID0+IHtcbiAgICAvLyBGSVhNRTogcmV2aWV3IGNvbG9ycyBieSBkZWZhdWx0IGlzIHRydWVcbiAgICByZXR1cm4gcHJpbnRNZXNzYWdlKGlucHV0RGF0YSwgb3B0aW9ucywgdHJ1ZSkgKyBicmVha0xpa2U7XG4gIH07XG59O1xuIl19
16
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWIvbG9nZ2VyL2Zvcm1hdHRlci9pbmRleC50cyJdLCJuYW1lcyI6WyJtb2R1bGUiLCJleHBvcnRzIiwicHJldHR5RmFjdG9yeSIsIm9wdGlvbnMiLCJicmVha0xpa2UiLCJpbnB1dERhdGEiLCJjb2xvcnMiXSwibWFwcGluZ3MiOiI7O0FBQUE7O0FBSUE7QUFDQTtBQUNBO0FBQ0E7QUFFQUEsTUFBTSxDQUFDQyxPQUFQLEdBQWlCLFNBQVNDLGFBQVQsQ0FBdUJDLE9BQXZCLEVBQXNFO0FBQ3JGO0FBQ0EsUUFBTUMsU0FBUyxHQUFHLElBQWxCO0FBQ0EsU0FBUUMsU0FBRCxJQUF1QjtBQUM1QixXQUFPLDhCQUFhQSxTQUFiLEVBQXdCRixPQUF4QixFQUFpQ0EsT0FBTyxDQUFDRyxNQUF6QyxJQUFtREYsU0FBMUQ7QUFDRCxHQUZEO0FBR0QsQ0FORCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFByZXR0eU9wdGlvbnNFeHRlbmRlZCwgcHJpbnRNZXNzYWdlIH0gZnJvbSAnLi9wcmV0dGlmaWVyJztcblxuZXhwb3J0IHR5cGUgUHJldHR5RmFjdG9yeSA9IChwYXJhbSkgPT4gc3RyaW5nO1xuXG4vKlxuIG9wdGlvbnMgZWc6XG4geyBtZXNzYWdlS2V5OiAnbXNnJywgbGV2ZWxGaXJzdDogdHJ1ZSwgcHJldHR5U3RhbXA6IGZhbHNlIH1cbiAqL1xuXG5tb2R1bGUuZXhwb3J0cyA9IGZ1bmN0aW9uIHByZXR0eUZhY3Rvcnkob3B0aW9uczogUHJldHR5T3B0aW9uc0V4dGVuZGVkKTogUHJldHR5RmFjdG9yeSB7XG4gIC8vIHRoZSBicmVhayBsaW5lIG11c3QgaGFwcGVucyBpbiB0aGUgcHJldHRpZnkgY29tcG9uZW50XG4gIGNvbnN0IGJyZWFrTGlrZSA9ICdcXG4nO1xuICByZXR1cm4gKGlucHV0RGF0YSk6IHN0cmluZyA9PiB7XG4gICAgcmV0dXJuIHByaW50TWVzc2FnZShpbnB1dERhdGEsIG9wdGlvbnMsIG9wdGlvbnMuY29sb3JzKSArIGJyZWFrTGlrZTtcbiAgfTtcbn07XG4iXX0=
@@ -108,4 +108,4 @@ function printMessage(templateObjects, options, hasColors = true) {
108
108
  const logMessage = getMessage(debugLevel, msg, sub, templateObjects, hasColors);
109
109
  return prettyStamp ? formatLoggingDate(templateObjects.time, logMessage) : logMessage;
110
110
  }
111
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/lib/logger/formatter/prettifier.ts"],"names":["CUSTOM_PAD_LENGTH","FORMAT_DATE","isObject","obj","_","isNull","isArray","formatLoggingDate","time","message","timeFormatted","format","LEVEL_VALUE_MAX","l","levelsColors","Math","max","length","ERROR_FLAG","fillInMsgTemplate","msg","templateOptions","colors","templateRegex","replace","name","str","isError","substr","listAccessors","split","property","id","includes","undefined","getMessage","debugLevel","sub","templateObjects","hasColors","finalMessage","subSystemType","subSystemLevels","color","logString","printMessage","options","prettyStamp","level","logMessage"],"mappings":"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","sourcesContent":["import dayjs from 'dayjs';\nimport { green, red, white } from 'kleur';\nimport _ from 'lodash';\nimport { PrettyOptions } from 'pino';\nimport { inspect } from 'util';\n\nimport { LevelCode, calculateLevel, levelsColors, subSystemLevels } from '../levels';\nimport { padLeft, padRight } from '../utils';\n\nexport const CUSTOM_PAD_LENGTH = 1;\nexport const FORMAT_DATE = 'YYYY-MM-DD HH:mm:ss';\n\nexport function isObject(obj: unknown): boolean {\n  return _.isObject(obj) && _.isNull(obj) === false && _.isArray(obj) === false;\n}\n\nexport function formatLoggingDate(time: number, message): string {\n  const timeFormatted = dayjs(time).format(FORMAT_DATE);\n\n  return `[${timeFormatted}]${message}`;\n}\n\nexport interface PrettyOptionsExtended extends PrettyOptions {\n  prettyStamp: boolean;\n}\nlet LEVEL_VALUE_MAX = 0;\n// eslint-disable-next-line guard-for-in\nfor (const l in levelsColors) {\n  LEVEL_VALUE_MAX = Math.max(LEVEL_VALUE_MAX, l.length);\n}\n\nconst ERROR_FLAG = '!';\n\nexport interface ObjectTemplate {\n  level: LevelCode;\n  msg: string;\n  sub?: string;\n  [key: string]: string | number | object | null | void;\n}\n\nexport function fillInMsgTemplate(msg, templateOptions: ObjectTemplate, colors): string {\n  const templateRegex = /@{(!?[$A-Za-z_][$0-9A-Za-z\\._]*)}/g;\n\n  return msg.replace(templateRegex, (_, name): string => {\n    let str = templateOptions;\n    let isError;\n    if (name[0] === ERROR_FLAG) {\n      name = name.substr(1);\n      isError = true;\n    }\n\n    // object can be @{foo.bar.}\n    const listAccessors = name.split('.');\n    for (let property = 0; property < listAccessors.length; property++) {\n      const id = listAccessors[property];\n      if (isObject(str)) {\n        str = (str as object)[id];\n      }\n    }\n\n    if (typeof str === 'string') {\n      if (colors === false || (str as string).includes('\\n')) {\n        return str;\n      } else if (isError) {\n        return red(str);\n      }\n      return green(str);\n    }\n\n    // object, showHidden, depth, colors\n    return inspect(str, undefined, null, colors);\n  });\n}\n\nfunction getMessage(debugLevel, msg, sub, templateObjects, hasColors) {\n  const finalMessage = fillInMsgTemplate(msg, templateObjects, hasColors);\n\n  const subSystemType = subSystemLevels.color[sub ?? 'default'];\n  if (hasColors) {\n    const logString = `${levelsColors[debugLevel](padRight(debugLevel, LEVEL_VALUE_MAX))}${white(`${subSystemType} ${finalMessage}`)}`;\n\n    return padLeft(logString);\n  }\n  const logString = `${padRight(debugLevel, LEVEL_VALUE_MAX)}${subSystemType} ${finalMessage}`;\n\n  return padRight(logString);\n}\n\nexport function printMessage(templateObjects: ObjectTemplate, options: PrettyOptionsExtended, hasColors = true): string {\n  const { prettyStamp } = options;\n  const { level, msg, sub } = templateObjects;\n  const debugLevel = calculateLevel(level);\n  const logMessage = getMessage(debugLevel, msg, sub, templateObjects, hasColors);\n\n  return prettyStamp ? formatLoggingDate(templateObjects.time as number, logMessage) : logMessage;\n}\n"]}
111
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/lib/logger/formatter/prettifier.ts"],"names":["CUSTOM_PAD_LENGTH","FORMAT_DATE","isObject","obj","_","isNull","isArray","formatLoggingDate","time","message","timeFormatted","format","LEVEL_VALUE_MAX","l","levelsColors","Math","max","length","ERROR_FLAG","fillInMsgTemplate","msg","templateOptions","colors","templateRegex","replace","name","str","isError","substr","listAccessors","split","property","id","includes","undefined","getMessage","debugLevel","sub","templateObjects","hasColors","finalMessage","subSystemType","subSystemLevels","color","logString","printMessage","options","prettyStamp","level","logMessage"],"mappings":"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","sourcesContent":["import dayjs from 'dayjs';\nimport { green, red, white } from 'kleur';\nimport _ from 'lodash';\nimport { PrettyOptions } from 'pino';\nimport { inspect } from 'util';\n\nimport { LevelCode, calculateLevel, levelsColors, subSystemLevels } from '../levels';\nimport { padLeft, padRight } from '../utils';\n\nexport const CUSTOM_PAD_LENGTH = 1;\nexport const FORMAT_DATE = 'YYYY-MM-DD HH:mm:ss';\n\nexport function isObject(obj: unknown): boolean {\n  return _.isObject(obj) && _.isNull(obj) === false && _.isArray(obj) === false;\n}\n\nexport function formatLoggingDate(time: number, message): string {\n  const timeFormatted = dayjs(time).format(FORMAT_DATE);\n\n  return `[${timeFormatted}]${message}`;\n}\n\nexport interface PrettyOptionsExtended extends PrettyOptions {\n  prettyStamp: boolean;\n  colors: boolean;\n}\nlet LEVEL_VALUE_MAX = 0;\n// eslint-disable-next-line guard-for-in\nfor (const l in levelsColors) {\n  LEVEL_VALUE_MAX = Math.max(LEVEL_VALUE_MAX, l.length);\n}\n\nconst ERROR_FLAG = '!';\n\nexport interface ObjectTemplate {\n  level: LevelCode;\n  msg: string;\n  sub?: string;\n  [key: string]: string | number | object | null | void;\n}\n\nexport function fillInMsgTemplate(msg, templateOptions: ObjectTemplate, colors): string {\n  const templateRegex = /@{(!?[$A-Za-z_][$0-9A-Za-z\\._]*)}/g;\n\n  return msg.replace(templateRegex, (_, name): string => {\n    let str = templateOptions;\n    let isError;\n    if (name[0] === ERROR_FLAG) {\n      name = name.substr(1);\n      isError = true;\n    }\n\n    // object can be @{foo.bar.}\n    const listAccessors = name.split('.');\n    for (let property = 0; property < listAccessors.length; property++) {\n      const id = listAccessors[property];\n      if (isObject(str)) {\n        str = (str as object)[id];\n      }\n    }\n\n    if (typeof str === 'string') {\n      if (colors === false || (str as string).includes('\\n')) {\n        return str;\n      } else if (isError) {\n        return red(str);\n      }\n      return green(str);\n    }\n\n    // object, showHidden, depth, colors\n    return inspect(str, undefined, null, colors);\n  });\n}\n\nfunction getMessage(debugLevel, msg, sub, templateObjects, hasColors) {\n  const finalMessage = fillInMsgTemplate(msg, templateObjects, hasColors);\n\n  const subSystemType = subSystemLevels.color[sub ?? 'default'];\n  if (hasColors) {\n    const logString = `${levelsColors[debugLevel](padRight(debugLevel, LEVEL_VALUE_MAX))}${white(`${subSystemType} ${finalMessage}`)}`;\n\n    return padLeft(logString);\n  }\n  const logString = `${padRight(debugLevel, LEVEL_VALUE_MAX)}${subSystemType} ${finalMessage}`;\n\n  return padRight(logString);\n}\n\nexport function printMessage(templateObjects: ObjectTemplate, options: PrettyOptionsExtended, hasColors = true): string {\n  const { prettyStamp } = options;\n  const { level, msg, sub } = templateObjects;\n  const debugLevel = calculateLevel(level);\n  const logMessage = getMessage(debugLevel, msg, sub, templateObjects, hasColors);\n\n  return prettyStamp ? formatLoggingDate(templateObjects.time as number, logMessage) : logMessage;\n}\n"]}
@@ -33,11 +33,7 @@ const DEFAULT_LOG_FORMAT = isProd() ? 'json' : 'pretty';
33
33
 
34
34
  function createLogger(options = {
35
35
  level: 'http'
36
- }, destination = _pino.default.destination(1), format = DEFAULT_LOG_FORMAT, prettyPrintOptions = {
37
- // we hide warning since the prettifier should not be used in production
38
- // https://getpino.io/#/docs/pretty?id=prettifier-api
39
- suppressFlushSyncWarning: true
40
- }) {
36
+ }, destination = _pino.default.destination(1), format = DEFAULT_LOG_FORMAT, prettyPrintOptions) {
41
37
  if (_lodash.default.isNil(format)) {
42
38
  format = DEFAULT_LOG_FORMAT;
43
39
  }
@@ -92,11 +88,12 @@ function getLogger() {
92
88
  const DEFAULT_LOGGER_CONF = {
93
89
  type: 'stdout',
94
90
  format: 'pretty',
95
- level: 'http'
91
+ level: 'http',
92
+ colors: true
96
93
  };
97
94
 
98
95
  function setup(options = [DEFAULT_LOGGER_CONF]) {
99
- var _loggerConfig;
96
+ var _loggerConfig, _loggerConfig2, _loggerConfig3;
100
97
 
101
98
  debug('setup logger');
102
99
  const isLegacyConf = Array.isArray(options);
@@ -120,6 +117,18 @@ function setup(options = [DEFAULT_LOGGER_CONF]) {
120
117
  const pinoConfig = {
121
118
  level: loggerConfig.level
122
119
  };
120
+ let colors = typeof ((_loggerConfig2 = loggerConfig) === null || _loggerConfig2 === void 0 ? void 0 : _loggerConfig2.colors) === 'boolean' ? Boolean((_loggerConfig3 = loggerConfig) === null || _loggerConfig3 === void 0 ? void 0 : _loggerConfig3.colors) : process.stdout.isTTY;
121
+
122
+ if ('EXPERIMENTAL_VERDACCIO_LOGGER_COLORS' in process.env) {
123
+ colors = process.env.EXPERIMENTAL_VERDACCIO_LOGGER_COLORS != 'false';
124
+ }
125
+
126
+ const prettyPrintOptions = {
127
+ // we hide warning since the prettifier should not be used in production
128
+ // https://getpino.io/#/docs/pretty?id=prettifier-api
129
+ suppressFlushSyncWarning: true,
130
+ colors
131
+ };
123
132
 
124
133
  if (loggerConfig.type === 'file') {
125
134
  debug('logging file enabled');
@@ -127,14 +136,14 @@ function setup(options = [DEFAULT_LOGGER_CONF]) {
127
136
  const destination = _pino.default.destination(loggerConfig.path);
128
137
 
129
138
  process.on('SIGUSR2', () => destination.reopen());
130
- exports.logger = logger = createLogger(pinoConfig, destination, loggerConfig.format);
139
+ exports.logger = logger = createLogger(pinoConfig, destination, loggerConfig.format, prettyPrintOptions);
131
140
  } else if (loggerConfig.type === 'rotating-file') {
132
141
  process.emitWarning('rotating-file type is not longer supported, consider use [logrotate] instead');
133
142
  debug('logging stdout enabled');
134
- exports.logger = logger = createLogger(pinoConfig, _pino.default.destination(1), loggerConfig.format);
143
+ exports.logger = logger = createLogger(pinoConfig, _pino.default.destination(1), loggerConfig.format, prettyPrintOptions);
135
144
  } else {
136
145
  debug('logging stdout enabled');
137
- exports.logger = logger = createLogger(pinoConfig, _pino.default.destination(1), loggerConfig.format);
146
+ exports.logger = logger = createLogger(pinoConfig, _pino.default.destination(1), loggerConfig.format, prettyPrintOptions);
138
147
  }
139
148
 
140
149
  if (isProd()) {
@@ -159,4 +168,4 @@ function setup(options = [DEFAULT_LOGGER_CONF]) {
159
168
  process.on('SIGTERM', () => finalHandler(null, 'SIGTERM'));
160
169
  }
161
170
  }
162
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/lib/logger/logger.ts"],"names":["isProd","process","env","NODE_ENV","logger","debug","DEFAULT_LOG_FORMAT","createLogger","options","level","destination","pino","format","prettyPrintOptions","suppressFlushSyncWarning","_","isNil","pinoConfig","customLevels","http","serializers","err","stdSerializers","req","res","Object","assign","prettyPrint","levelFirst","prettyStamp","prettifier","require","DEBUG","on","lvl","val","prevLvl","prevVal","getLogger","emitWarning","DEFAULT_LOGGER_CONF","type","setup","isLegacyConf","Array","isArray","deprecateMessage","loggerConfig","path","reopen","finalHandler","final","finalLogger","event","info","error","exit"],"mappings":"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","sourcesContent":["import buildDebug from 'debug';\nimport { yellow } from 'kleur';\nimport _ from 'lodash';\nimport pino from 'pino';\n\nimport { padLeft } from './utils';\n\nfunction isProd() {\n  return process.env.NODE_ENV === 'production';\n}\n\nexport let logger;\nconst debug = buildDebug('verdaccio:logger');\nconst DEFAULT_LOG_FORMAT = isProd() ? 'json' : 'pretty';\n\nexport type LogPlugin = {\n  dest: string;\n  options?: any[];\n};\n\nexport type LogType = 'file' | 'stdout';\nexport type LogFormat = 'json' | 'pretty-timestamped' | 'pretty';\n\nexport function createLogger(\n  options = { level: 'http' },\n  destination = pino.destination(1),\n  format: LogFormat = DEFAULT_LOG_FORMAT,\n  prettyPrintOptions = {\n    // we hide warning since the prettifier should not be used in production\n    // https://getpino.io/#/docs/pretty?id=prettifier-api\n    suppressFlushSyncWarning: true,\n  }\n) {\n  if (_.isNil(format)) {\n    format = DEFAULT_LOG_FORMAT;\n  }\n\n  let pinoConfig = {\n    customLevels: {\n      http: 25,\n    },\n    ...options,\n    level: options.level,\n    serializers: {\n      err: pino.stdSerializers.err,\n      req: pino.stdSerializers.req,\n      res: pino.stdSerializers.res,\n    },\n  };\n\n  debug('has prettifier? %o', !isProd());\n  // pretty logs are not allowed in production for performance reasons\n  if ((format === DEFAULT_LOG_FORMAT || format !== 'json') && isProd() === false) {\n    pinoConfig = Object.assign({}, pinoConfig, {\n      // more info\n      // https://github.com/pinojs/pino-pretty/issues/37\n      prettyPrint: {\n        levelFirst: true,\n        prettyStamp: format === 'pretty-timestamped',\n        ...prettyPrintOptions,\n      },\n      prettifier: require('./formatter'),\n    });\n  }\n  const logger = pino(pinoConfig, destination);\n\n  if (process.env.DEBUG) {\n    logger.on('level-change', (lvl, val, prevLvl, prevVal) => {\n      debug('%s (%d) was changed to %s (%d)', lvl, val, prevLvl, prevVal);\n    });\n  }\n\n  return logger;\n}\n\nexport function getLogger() {\n  if (_.isNil(logger)) {\n    process.emitWarning('logger is not defined');\n    return;\n  }\n\n  return logger;\n}\n\nconst DEFAULT_LOGGER_CONF: LoggerConfigItem = {\n  type: 'stdout',\n  format: 'pretty',\n  level: 'http',\n};\n\nexport type LoggerConfigItem = {\n  type?: LogType;\n  plugin?: LogPlugin;\n  format?: LogFormat;\n  path?: string;\n  level?: string;\n};\n\nexport type LoggerConfig = LoggerConfigItem[];\n\nexport function setup(options: LoggerConfig | LoggerConfigItem = [DEFAULT_LOGGER_CONF]) {\n  debug('setup logger');\n  const isLegacyConf = Array.isArray(options);\n  if (isLegacyConf) {\n    const deprecateMessage = 'deprecate: multiple logger configuration is deprecated, please check the migration guide.';\n    process.emitWarning(deprecateMessage);\n  }\n\n  // verdaccio 5 does not allow multiple logger configuration\n  // backward compatible, pick only the first option\n  // next major will thrown an error\n  let loggerConfig = isLegacyConf ? options[0] : options;\n  if (!loggerConfig?.level) {\n    loggerConfig = Object.assign(\n      {},\n      {\n        level: 'http',\n      },\n      loggerConfig\n    );\n  }\n  const pinoConfig = { level: loggerConfig.level };\n  if (loggerConfig.type === 'file') {\n    debug('logging file enabled');\n    const destination = pino.destination(loggerConfig.path);\n    process.on('SIGUSR2', () => destination.reopen());\n    logger = createLogger(pinoConfig, destination, loggerConfig.format);\n  } else if (loggerConfig.type === 'rotating-file') {\n    process.emitWarning('rotating-file type is not longer supported, consider use [logrotate] instead');\n    debug('logging stdout enabled');\n    logger = createLogger(pinoConfig, pino.destination(1), loggerConfig.format);\n  } else {\n    debug('logging stdout enabled');\n    logger = createLogger(pinoConfig, pino.destination(1), loggerConfig.format);\n  }\n\n  if (isProd()) {\n    // why only on prod? https://github.com/pinojs/pino/issues/920#issuecomment-710807667\n    const finalHandler = pino.final(logger, (err, finalLogger, event) => {\n      finalLogger.info(`${event} caught`);\n      if (err) {\n        finalLogger.error(err, 'error caused exit');\n      }\n      process.exit(err ? 1 : 0);\n    });\n\n    process.on('uncaughtException', (err) => finalHandler(err, 'uncaughtException'));\n    process.on('unhandledRejection', (err) => finalHandler(err as Error, 'unhandledRejection'));\n    process.on('beforeExit', () => finalHandler(null, 'beforeExit'));\n    process.on('exit', () => finalHandler(null, 'exit'));\n    process.on('uncaughtException', (err) => finalHandler(err, 'uncaughtException'));\n    process.on('SIGINT', () => finalHandler(null, 'SIGINT'));\n    process.on('SIGQUIT', () => finalHandler(null, 'SIGQUIT'));\n    process.on('SIGTERM', () => finalHandler(null, 'SIGTERM'));\n  }\n}\n"]}
171
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../src/lib/logger/logger.ts"],"names":["isProd","process","env","NODE_ENV","logger","debug","DEFAULT_LOG_FORMAT","createLogger","options","level","destination","pino","format","prettyPrintOptions","_","isNil","pinoConfig","customLevels","http","serializers","err","stdSerializers","req","res","Object","assign","prettyPrint","levelFirst","prettyStamp","prettifier","require","DEBUG","on","lvl","val","prevLvl","prevVal","getLogger","emitWarning","DEFAULT_LOGGER_CONF","type","colors","setup","isLegacyConf","Array","isArray","deprecateMessage","loggerConfig","Boolean","stdout","isTTY","EXPERIMENTAL_VERDACCIO_LOGGER_COLORS","suppressFlushSyncWarning","path","reopen","finalHandler","final","finalLogger","event","info","error","exit"],"mappings":"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","sourcesContent":["import buildDebug from 'debug';\nimport { yellow } from 'kleur';\nimport _ from 'lodash';\nimport pino from 'pino';\n\nfunction isProd() {\n  return process.env.NODE_ENV === 'production';\n}\n\nexport let logger;\nconst debug = buildDebug('verdaccio:logger');\nconst DEFAULT_LOG_FORMAT = isProd() ? 'json' : 'pretty';\n\nexport type LogPlugin = {\n  dest: string;\n  options?: any[];\n};\n\nexport type LogType = 'file' | 'stdout';\nexport type LogFormat = 'json' | 'pretty-timestamped' | 'pretty';\n\nexport function createLogger(options = { level: 'http' }, destination = pino.destination(1), format: LogFormat = DEFAULT_LOG_FORMAT, prettyPrintOptions) {\n  if (_.isNil(format)) {\n    format = DEFAULT_LOG_FORMAT;\n  }\n\n  let pinoConfig = {\n    customLevels: {\n      http: 25,\n    },\n    ...options,\n    level: options.level,\n    serializers: {\n      err: pino.stdSerializers.err,\n      req: pino.stdSerializers.req,\n      res: pino.stdSerializers.res,\n    },\n  };\n\n  debug('has prettifier? %o', !isProd());\n  // pretty logs are not allowed in production for performance reasons\n  if ((format === DEFAULT_LOG_FORMAT || format !== 'json') && isProd() === false) {\n    pinoConfig = Object.assign({}, pinoConfig, {\n      // more info\n      // https://github.com/pinojs/pino-pretty/issues/37\n      prettyPrint: {\n        levelFirst: true,\n        prettyStamp: format === 'pretty-timestamped',\n        ...prettyPrintOptions,\n      },\n      prettifier: require('./formatter'),\n    });\n  }\n  const logger = pino(pinoConfig, destination);\n\n  if (process.env.DEBUG) {\n    logger.on('level-change', (lvl, val, prevLvl, prevVal) => {\n      debug('%s (%d) was changed to %s (%d)', lvl, val, prevLvl, prevVal);\n    });\n  }\n\n  return logger;\n}\n\nexport function getLogger() {\n  if (_.isNil(logger)) {\n    process.emitWarning('logger is not defined');\n    return;\n  }\n\n  return logger;\n}\n\nconst DEFAULT_LOGGER_CONF: LoggerConfigItem = {\n  type: 'stdout',\n  format: 'pretty',\n  level: 'http',\n  colors: true,\n};\n\nexport type LoggerConfigItem = {\n  type?: LogType;\n  plugin?: LogPlugin;\n  format?: LogFormat;\n  path?: string;\n  level?: string;\n  colors?: boolean;\n};\n\nexport type LoggerConfig = LoggerConfigItem[];\n\nexport function setup(options: LoggerConfig | LoggerConfigItem = [DEFAULT_LOGGER_CONF]) {\n  debug('setup logger');\n  const isLegacyConf = Array.isArray(options);\n  if (isLegacyConf) {\n    const deprecateMessage = 'deprecate: multiple logger configuration is deprecated, please check the migration guide.';\n    process.emitWarning(deprecateMessage);\n  }\n\n  // verdaccio 5 does not allow multiple logger configuration\n  // backward compatible, pick only the first option\n  // next major will thrown an error\n  let loggerConfig = isLegacyConf ? options[0] : options;\n  if (!loggerConfig?.level) {\n    loggerConfig = Object.assign(\n      {},\n      {\n        level: 'http',\n      },\n      loggerConfig\n    );\n  }\n  const pinoConfig = { level: loggerConfig.level };\n  let colors = typeof loggerConfig?.colors === 'boolean' ? Boolean(loggerConfig?.colors) : process.stdout.isTTY;\n  if ('EXPERIMENTAL_VERDACCIO_LOGGER_COLORS' in process.env) {\n    colors = process.env.EXPERIMENTAL_VERDACCIO_LOGGER_COLORS != 'false';\n  }\n  const prettyPrintOptions = {\n    // we hide warning since the prettifier should not be used in production\n    // https://getpino.io/#/docs/pretty?id=prettifier-api\n    suppressFlushSyncWarning: true,\n    colors,\n  };\n  if (loggerConfig.type === 'file') {\n    debug('logging file enabled');\n    const destination = pino.destination(loggerConfig.path);\n    process.on('SIGUSR2', () => destination.reopen());\n    logger = createLogger(pinoConfig, destination, loggerConfig.format, prettyPrintOptions);\n  } else if (loggerConfig.type === 'rotating-file') {\n    process.emitWarning('rotating-file type is not longer supported, consider use [logrotate] instead');\n    debug('logging stdout enabled');\n    logger = createLogger(pinoConfig, pino.destination(1), loggerConfig.format, prettyPrintOptions);\n  } else {\n    debug('logging stdout enabled');\n    logger = createLogger(pinoConfig, pino.destination(1), loggerConfig.format, prettyPrintOptions);\n  }\n\n  if (isProd()) {\n    // why only on prod? https://github.com/pinojs/pino/issues/920#issuecomment-710807667\n    const finalHandler = pino.final(logger, (err, finalLogger, event) => {\n      finalLogger.info(`${event} caught`);\n      if (err) {\n        finalLogger.error(err, 'error caused exit');\n      }\n      process.exit(err ? 1 : 0);\n    });\n\n    process.on('uncaughtException', (err) => finalHandler(err, 'uncaughtException'));\n    process.on('unhandledRejection', (err) => finalHandler(err as Error, 'unhandledRejection'));\n    process.on('beforeExit', () => finalHandler(null, 'beforeExit'));\n    process.on('exit', () => finalHandler(null, 'exit'));\n    process.on('uncaughtException', (err) => finalHandler(err, 'uncaughtException'));\n    process.on('SIGINT', () => finalHandler(null, 'SIGINT'));\n    process.on('SIGQUIT', () => finalHandler(null, 'SIGQUIT'));\n    process.on('SIGTERM', () => finalHandler(null, 'SIGTERM'));\n  }\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "verdaccio",
3
- "version": "5.6.2",
3
+ "version": "5.8.0",
4
4
  "description": "A lightweight private npm proxy registry",
5
5
  "author": {
6
6
  "name": "Verdaccio Maintainers",
@@ -22,7 +22,7 @@
22
22
  "@verdaccio/local-storage": "10.2.0",
23
23
  "@verdaccio/readme": "10.3.2",
24
24
  "@verdaccio/streams": "10.2.0",
25
- "@verdaccio/ui-theme": "6.0.0-6-next.18",
25
+ "@verdaccio/ui-theme": "6.0.0-6-next.22",
26
26
  "JSONStream": "1.3.5",
27
27
  "async": "3.2.3",
28
28
  "body-parser": "1.19.1",
@@ -30,11 +30,11 @@
30
30
  "compression": "1.7.4",
31
31
  "cookies": "0.8.0",
32
32
  "cors": "2.8.5",
33
- "dayjs": "1.10.7",
33
+ "dayjs": "1.10.8",
34
34
  "debug": "^4.3.3",
35
35
  "envinfo": "7.8.1",
36
36
  "eslint-import-resolver-node": "0.3.6",
37
- "express": "4.17.2",
37
+ "express": "4.17.3",
38
38
  "express-rate-limit": "5.5.1",
39
39
  "fast-safe-stringify": "2.1.1",
40
40
  "handlebars": "4.7.7",
@@ -48,7 +48,7 @@
48
48
  "marked": "4.0.12",
49
49
  "memoizee": "0.4.15",
50
50
  "mime": "3.0.0",
51
- "minimatch": "3.0.4",
51
+ "minimatch": "5.0.1",
52
52
  "mkdirp": "1.0.4",
53
53
  "mv": "2.1.1",
54
54
  "pino": "6.14.0",
@@ -59,7 +59,7 @@
59
59
  "semver": "7.3.5",
60
60
  "validator": "13.7.0",
61
61
  "verdaccio-audit": "10.2.0",
62
- "verdaccio-htpasswd": "10.2.0"
62
+ "verdaccio-htpasswd": "10.3.0"
63
63
  },
64
64
  "devDependencies": {
65
65
  "@babel/cli": "7.16.8",