verdaccio 5.11.0 → 5.12.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,24 @@
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.12.0](https://github.com/verdaccio/verdaccio/compare/v5.11.0...v5.12.0) (2022-06-14)
6
+
7
+
8
+ ### Features
9
+
10
+ * add scope support loading plugins ([#3227](https://github.com/verdaccio/verdaccio/issues/3227)) ([5c50ec9](https://github.com/verdaccio/verdaccio/commit/5c50ec9a2ced21c06ce690bb45af2019a514149d))
11
+
12
+
13
+ ### Bug Fixes
14
+
15
+ * **deps:** update dependency @verdaccio/local-storage to v10.3.0 ([#3223](https://github.com/verdaccio/verdaccio/issues/3223)) ([2b8ac7a](https://github.com/verdaccio/verdaccio/commit/2b8ac7a1aca0c898edad89ea8e3dbb5c33ee8134))
16
+ * **deps:** update dependency async to v3.2.4 ([#3224](https://github.com/verdaccio/verdaccio/issues/3224)) ([c486af2](https://github.com/verdaccio/verdaccio/commit/c486af23eaa583f4c5042f51769f363731bd6f84))
17
+ * **deps:** update dependency dayjs to v1.11.3 ([#3225](https://github.com/verdaccio/verdaccio/issues/3225)) ([325e536](https://github.com/verdaccio/verdaccio/commit/325e536f0323f6c1b17de594afe1fce5d6368624))
18
+ * **deps:** update dependency lru-cache to v7.10.1 ([#3182](https://github.com/verdaccio/verdaccio/issues/3182)) ([7bc60ff](https://github.com/verdaccio/verdaccio/commit/7bc60ffca8109adbdea2462370b7c553129dcdcb))
19
+ * **deps:** update dependency marked to v4.0.17 ([#3226](https://github.com/verdaccio/verdaccio/issues/3226)) ([9d9c086](https://github.com/verdaccio/verdaccio/commit/9d9c086ba36fca787eb97fe70cf6c7eea9128c3c))
20
+ * **deps:** update dependency minimatch to v5.1.0 ([#3183](https://github.com/verdaccio/verdaccio/issues/3183)) ([e5dbd9b](https://github.com/verdaccio/verdaccio/commit/e5dbd9bbd1306ef5856717eb440ba8694c6e81e4))
21
+ * **deps:** update dependency verdaccio-htpasswd to v10.3.1 ([#3220](https://github.com/verdaccio/verdaccio/issues/3220)) ([25a2825](https://github.com/verdaccio/verdaccio/commit/25a2825f8b98d8563ad850e354941fb65a4024af))
22
+
5
23
  ## [5.11.0](https://github.com/verdaccio/verdaccio/compare/v5.10.3...v5.11.0) (2022-06-02)
6
24
 
7
25
 
@@ -5,6 +5,8 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports.default = loadPlugin;
7
7
 
8
+ var _debug = _interopRequireDefault(require("debug"));
9
+
8
10
  var _lodash = _interopRequireDefault(require("lodash"));
9
11
 
10
12
  var _path = _interopRequireDefault(require("path"));
@@ -15,19 +17,27 @@ var _logger = require("./logger");
15
17
 
16
18
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
17
19
 
20
+ const debug = (0, _debug.default)('verdaccio:plugin:loader');
18
21
  /**
19
22
  * Requires a module.
20
23
  * @param {*} path the module's path
21
24
  * @return {Object}
22
25
  */
26
+
23
27
  function tryLoad(path) {
24
28
  try {
29
+ debug('loading plugin %s', path);
25
30
  return require(path);
26
31
  } catch (err) {
27
32
  if (err.code === _constants.MODULE_NOT_FOUND) {
33
+ debug('plugin %s not found', path);
28
34
  return null;
29
35
  }
30
36
 
37
+ _logger.logger.error({
38
+ err: err.msg
39
+ }, 'error loading plugin @{err}');
40
+
31
41
  throw err;
32
42
  }
33
43
  }
@@ -47,6 +57,7 @@ function isES6(plugin) {
47
57
  /**
48
58
  * Load a plugin following the rules
49
59
  * - First try to load from the internal directory plugins (which will disappear soon or later).
60
+ * - If the package is scoped eg: @scope/foo, try to load as a package
50
61
  * - A second attempt from the external plugin directory
51
62
  * - A third attempt from node_modules, in case to have multiple match as for instance verdaccio-ldap
52
63
  * and sinopia-ldap. All verdaccio prefix will have preferences.
@@ -61,6 +72,12 @@ function isES6(plugin) {
61
72
  function loadPlugin(config, pluginConfigs = {}, params, sanityCheck, prefix = 'verdaccio') {
62
73
  return Object.keys(pluginConfigs).map(pluginId => {
63
74
  let plugin;
75
+ const isScoped = pluginId.startsWith('@') && pluginId.includes('/');
76
+ debug('isScoped %s', isScoped);
77
+
78
+ if (isScoped) {
79
+ plugin = tryLoad(pluginId);
80
+ }
64
81
 
65
82
  const localPlugin = _path.default.resolve(__dirname + '/../plugins', pluginId); // try local plugins first
66
83
 
@@ -79,6 +96,12 @@ function loadPlugin(config, pluginConfigs = {}, params, sanityCheck, prefix = 'v
79
96
 
80
97
  if (!plugin) {
81
98
  plugin = tryLoad(_path.default.resolve(pluginDir, `sinopia-${pluginId}`));
99
+
100
+ if (plugin) {
101
+ _logger.logger.warn({
102
+ name: pluginId
103
+ }, `plugin names that start with sinopia-* will be removed in the future, please rename package to verdaccio-*`);
104
+ }
82
105
  }
83
106
  }
84
107
  } // npm package
@@ -90,6 +113,10 @@ function loadPlugin(config, pluginConfigs = {}, params, sanityCheck, prefix = 'v
90
113
  if (!plugin) {
91
114
  plugin = tryLoad(`sinopia-${pluginId}`);
92
115
  }
116
+
117
+ if (plugin) {
118
+ debug('plugin %s is an npm package', pluginId);
119
+ }
93
120
  }
94
121
 
95
122
  if (plugin === null) {
@@ -102,13 +129,21 @@ function loadPlugin(config, pluginConfigs = {}, params, sanityCheck, prefix = 'v
102
129
  }
103
130
 
104
131
  if (plugin === null) {
105
- _logger.logger.error({
106
- content: pluginId,
107
- prefix
108
- }, 'plugin not found. try npm install @{prefix}-@{content}');
132
+ if (isScoped) {
133
+ _logger.logger.error({
134
+ content: pluginId
135
+ }, 'plugin not found. try npm install @{content}');
136
+ } else {
137
+ _logger.logger.error({
138
+ content: pluginId,
139
+ prefix
140
+ }, 'plugin not found. try npm install @{prefix}-@{content}');
141
+ }
109
142
 
110
- throw Error(`
111
- ${prefix}-${pluginId} plugin not found. try "npm install ${prefix}-${pluginId}"`);
143
+ const msg = isScoped ? `
144
+ ${pluginId} plugin not found. try "npm install ${pluginId}"` : `
145
+ ${prefix}-${pluginId} plugin not found. try "npm install ${prefix}-${pluginId}"`;
146
+ throw Error(msg);
112
147
  }
113
148
 
114
149
  if (!isValid(plugin)) {
@@ -122,7 +157,13 @@ function loadPlugin(config, pluginConfigs = {}, params, sanityCheck, prefix = 'v
122
157
 
123
158
 
124
159
  try {
125
- plugin = isES6(plugin) ? new plugin.default(mergeConfig(config, pluginConfigs[pluginId]), params) : plugin(pluginConfigs[pluginId], params);
160
+ if (isES6(plugin)) {
161
+ debug('plugin is ES6');
162
+ plugin = new plugin.default(mergeConfig(config, pluginConfigs[pluginId]), params);
163
+ } else {
164
+ debug('plugin is commonJS');
165
+ plugin = plugin(pluginConfigs[pluginId], params);
166
+ }
126
167
  } catch (error) {
127
168
  plugin = null;
128
169
 
@@ -135,20 +176,32 @@ function loadPlugin(config, pluginConfigs = {}, params, sanityCheck, prefix = 'v
135
176
 
136
177
 
137
178
  if (plugin === null || !sanityCheck(plugin)) {
138
- _logger.logger.error({
139
- content: pluginId,
140
- prefix
141
- }, "@{prefix}-@{content} doesn't look like a valid plugin");
179
+ if (isScoped) {
180
+ _logger.logger.error({
181
+ content: pluginId
182
+ }, "@{content} doesn't look like a valid plugin");
183
+ } else {
184
+ _logger.logger.error({
185
+ content: pluginId,
186
+ prefix
187
+ }, "@{prefix}-@{content} doesn't look like a valid plugin");
188
+ }
142
189
 
143
190
  throw Error(`sanity check has failed, "${pluginId}" is not a valid plugin`);
144
191
  }
145
192
 
146
- _logger.logger.warn({
147
- content: pluginId,
148
- prefix
149
- }, 'Plugin successfully loaded: @{prefix}-@{content}');
193
+ if (isScoped) {
194
+ _logger.logger.info({
195
+ content: pluginId
196
+ }, 'plugin successfully loaded: @{content}');
197
+ } else {
198
+ _logger.logger.info({
199
+ content: pluginId,
200
+ prefix
201
+ }, 'plugin successfully loaded: @{prefix}-@{content}');
202
+ }
150
203
 
151
204
  return plugin;
152
205
  });
153
206
  }
154
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["tryLoad","path","require","err","code","MODULE_NOT_FOUND","mergeConfig","appConfig","pluginConfig","_","merge","isValid","plugin","isFunction","default","isES6","Object","keys","includes","loadPlugin","config","pluginConfigs","params","sanityCheck","prefix","map","pluginId","localPlugin","Path","resolve","__dirname","plugins","pluginDir","externalFilePlugin","match","dirname","self_path","logger","error","content","Error","warn"],"sources":["../../src/lib/plugin-loader.ts"],"sourcesContent":["import _ from 'lodash';\nimport Path from 'path';\n\nimport { Config, IPlugin } from '@verdaccio/types';\n\nimport { MODULE_NOT_FOUND } from './constants';\nimport { logger } from './logger';\n\n/**\n * Requires a module.\n * @param {*} path the module's path\n * @return {Object}\n */\nfunction tryLoad(path: string): any {\n  try {\n    return require(path);\n  } catch (err) {\n    if (err.code === MODULE_NOT_FOUND) {\n      return null;\n    }\n    throw err;\n  }\n}\n\nfunction mergeConfig(appConfig, pluginConfig): Config {\n  return _.merge(appConfig, pluginConfig);\n}\n\nfunction isValid(plugin): boolean {\n  return _.isFunction(plugin) || _.isFunction(plugin.default);\n}\n\nfunction isES6(plugin): boolean {\n  return Object.keys(plugin).includes('default');\n}\n\n// export type PluginGeneric<R, T extends IPlugin<R> = ;\n\n/**\n * Load a plugin following the rules\n * - First try to load from the internal directory plugins (which will disappear soon or later).\n * - A second attempt from the external plugin directory\n * - A third attempt from node_modules, in case to have multiple match as for instance verdaccio-ldap\n * and sinopia-ldap. All verdaccio prefix will have preferences.\n * @param {*} config a reference of the configuration settings\n * @param {*} pluginConfigs\n * @param {*} params a set of params to initialize the plugin\n * @param {*} sanityCheck callback that check the shape that should fulfill the plugin\n * @return {Array} list of plugins\n */\nexport default function loadPlugin<T extends IPlugin<T>>(config: Config, pluginConfigs: any = {}, params: any, sanityCheck: any, prefix: string = 'verdaccio'): any[] {\n  return Object.keys(pluginConfigs).map((pluginId: string): IPlugin<T> => {\n    let plugin;\n\n    const localPlugin = Path.resolve(__dirname + '/../plugins', pluginId);\n    // try local plugins first\n    plugin = tryLoad(localPlugin);\n\n    // try the external plugin directory\n    if (plugin === null && config.plugins) {\n      const pluginDir = config.plugins;\n      const externalFilePlugin = Path.resolve(pluginDir, pluginId);\n      plugin = tryLoad(externalFilePlugin);\n\n      // npm package\n      if (plugin === null && pluginId.match(/^[^\\.\\/]/)) {\n        plugin = tryLoad(Path.resolve(pluginDir, `${prefix}-${pluginId}`));\n        // compatibility for old sinopia plugins\n        if (!plugin) {\n          plugin = tryLoad(Path.resolve(pluginDir, `sinopia-${pluginId}`));\n        }\n      }\n    }\n\n    // npm package\n    if (plugin === null && pluginId.match(/^[^\\.\\/]/)) {\n      plugin = tryLoad(`${prefix}-${pluginId}`);\n      // compatibility for old sinopia plugins\n      if (!plugin) {\n        plugin = tryLoad(`sinopia-${pluginId}`);\n      }\n    }\n\n    if (plugin === null) {\n      plugin = tryLoad(pluginId);\n    }\n\n    // relative to config path\n    if (plugin === null && pluginId.match(/^\\.\\.?($|\\/)/)) {\n      plugin = tryLoad(Path.resolve(Path.dirname(config.self_path), pluginId));\n    }\n\n    if (plugin === null) {\n      logger.error({ content: pluginId, prefix }, 'plugin not found. try npm install @{prefix}-@{content}');\n      throw Error(`\n        ${prefix}-${pluginId} plugin not found. try \"npm install ${prefix}-${pluginId}\"`);\n    }\n\n    if (!isValid(plugin)) {\n      logger.error({ content: pluginId }, '@{prefix}-@{content} plugin does not have the right code structure');\n      throw Error(`\"${pluginId}\" plugin does not have the right code structure`);\n    }\n\n    /* eslint new-cap:off */\n    try {\n      plugin = isES6(plugin) ? new plugin.default(mergeConfig(config, pluginConfigs[pluginId]), params) : plugin(pluginConfigs[pluginId], params);\n    } catch (error) {\n      plugin = null;\n      logger.error({ error, pluginId }, 'error loading a plugin @{pluginId}: @{error}');\n    }\n    /* eslint new-cap:off */\n\n    if (plugin === null || !sanityCheck(plugin)) {\n      logger.error({ content: pluginId, prefix }, \"@{prefix}-@{content} doesn't look like a valid plugin\");\n      throw Error(`sanity check has failed, \"${pluginId}\" is not a valid plugin`);\n    }\n\n    logger.warn({ content: pluginId, prefix }, 'Plugin successfully loaded: @{prefix}-@{content}');\n    return plugin;\n  });\n}\n"],"mappings":"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"}
207
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["debug","buildDebug","tryLoad","path","require","err","code","MODULE_NOT_FOUND","logger","error","msg","mergeConfig","appConfig","pluginConfig","_","merge","isValid","plugin","isFunction","default","isES6","Object","keys","includes","loadPlugin","config","pluginConfigs","params","sanityCheck","prefix","map","pluginId","isScoped","startsWith","localPlugin","Path","resolve","__dirname","plugins","pluginDir","externalFilePlugin","match","warn","name","dirname","self_path","content","Error","info"],"sources":["../../src/lib/plugin-loader.ts"],"sourcesContent":["import buildDebug from 'debug';\nimport _ from 'lodash';\nimport Path from 'path';\n\nimport { Config, IPlugin } from '@verdaccio/types';\n\nimport { MODULE_NOT_FOUND } from './constants';\nimport { logger } from './logger';\n\nconst debug = buildDebug('verdaccio:plugin:loader');\n\n/**\n * Requires a module.\n * @param {*} path the module's path\n * @return {Object}\n */\nfunction tryLoad(path: string): any {\n  try {\n    debug('loading plugin %s', path);\n    return require(path);\n  } catch (err) {\n    if (err.code === MODULE_NOT_FOUND) {\n      debug('plugin %s not found', path);\n      return null;\n    }\n    logger.error({ err: err.msg }, 'error loading plugin @{err}');\n    throw err;\n  }\n}\n\nfunction mergeConfig(appConfig, pluginConfig): Config {\n  return _.merge(appConfig, pluginConfig);\n}\n\nfunction isValid(plugin): boolean {\n  return _.isFunction(plugin) || _.isFunction(plugin.default);\n}\n\nfunction isES6(plugin): boolean {\n  return Object.keys(plugin).includes('default');\n}\n\n// export type PluginGeneric<R, T extends IPlugin<R> = ;\n\n/**\n * Load a plugin following the rules\n * - First try to load from the internal directory plugins (which will disappear soon or later).\n * - If the package is scoped eg: @scope/foo, try to load as a package\n * - A second attempt from the external plugin directory\n * - A third attempt from node_modules, in case to have multiple match as for instance verdaccio-ldap\n * and sinopia-ldap. All verdaccio prefix will have preferences.\n * @param {*} config a reference of the configuration settings\n * @param {*} pluginConfigs\n * @param {*} params a set of params to initialize the plugin\n * @param {*} sanityCheck callback that check the shape that should fulfill the plugin\n * @return {Array} list of plugins\n */\nexport default function loadPlugin<T extends IPlugin<T>>(config: Config, pluginConfigs: any = {}, params: any, sanityCheck: any, prefix: string = 'verdaccio'): any[] {\n  return Object.keys(pluginConfigs).map((pluginId: string): IPlugin<T> => {\n    let plugin;\n    const isScoped: boolean = pluginId.startsWith('@') && pluginId.includes('/');\n    debug('isScoped %s', isScoped);\n    if (isScoped) {\n      plugin = tryLoad(pluginId);\n    }\n\n    const localPlugin = Path.resolve(__dirname + '/../plugins', pluginId);\n    // try local plugins first\n    plugin = tryLoad(localPlugin);\n\n    // try the external plugin directory\n    if (plugin === null && config.plugins) {\n      const pluginDir = config.plugins;\n      const externalFilePlugin = Path.resolve(pluginDir, pluginId);\n      plugin = tryLoad(externalFilePlugin);\n\n      // npm package\n      if (plugin === null && pluginId.match(/^[^\\.\\/]/)) {\n        plugin = tryLoad(Path.resolve(pluginDir, `${prefix}-${pluginId}`));\n        // compatibility for old sinopia plugins\n        if (!plugin) {\n          plugin = tryLoad(Path.resolve(pluginDir, `sinopia-${pluginId}`));\n          if (plugin) {\n            logger.warn({ name: pluginId }, `plugin names that start with sinopia-* will be removed in the future, please rename package to verdaccio-*`);\n          }\n        }\n      }\n    }\n\n    // npm package\n    if (plugin === null && pluginId.match(/^[^\\.\\/]/)) {\n      plugin = tryLoad(`${prefix}-${pluginId}`);\n      // compatibility for old sinopia plugins\n      if (!plugin) {\n        plugin = tryLoad(`sinopia-${pluginId}`);\n      }\n      if (plugin) {\n        debug('plugin %s is an npm package', pluginId);\n      }\n    }\n\n    if (plugin === null) {\n      plugin = tryLoad(pluginId);\n    }\n\n    // relative to config path\n    if (plugin === null && pluginId.match(/^\\.\\.?($|\\/)/)) {\n      plugin = tryLoad(Path.resolve(Path.dirname(config.self_path), pluginId));\n    }\n\n    if (plugin === null) {\n      if (isScoped) {\n        logger.error({ content: pluginId }, 'plugin not found. try npm install @{content}');\n      } else {\n        logger.error({ content: pluginId, prefix }, 'plugin not found. try npm install @{prefix}-@{content}');\n      }\n      const msg = isScoped\n        ? `\n      ${pluginId} plugin not found. try \"npm install ${pluginId}\"`\n        : `\n      ${prefix}-${pluginId} plugin not found. try \"npm install ${prefix}-${pluginId}\"`;\n      throw Error(msg);\n    }\n\n    if (!isValid(plugin)) {\n      logger.error({ content: pluginId }, '@{prefix}-@{content} plugin does not have the right code structure');\n      throw Error(`\"${pluginId}\" plugin does not have the right code structure`);\n    }\n\n    /* eslint new-cap:off */\n    try {\n      if (isES6(plugin)) {\n        debug('plugin is ES6');\n        plugin = new plugin.default(mergeConfig(config, pluginConfigs[pluginId]), params);\n      } else {\n        debug('plugin is commonJS');\n        plugin = plugin(pluginConfigs[pluginId], params);\n      }\n    } catch (error) {\n      plugin = null;\n      logger.error({ error, pluginId }, 'error loading a plugin @{pluginId}: @{error}');\n    }\n    /* eslint new-cap:off */\n\n    if (plugin === null || !sanityCheck(plugin)) {\n      if (isScoped) {\n        logger.error({ content: pluginId }, \"@{content} doesn't look like a valid plugin\");\n      } else {\n        logger.error({ content: pluginId, prefix }, \"@{prefix}-@{content} doesn't look like a valid plugin\");\n      }\n      throw Error(`sanity check has failed, \"${pluginId}\" is not a valid plugin`);\n    }\n\n    if (isScoped) {\n      logger.info({ content: pluginId }, 'plugin successfully loaded: @{content}');\n    } else {\n      logger.info({ content: pluginId, prefix }, 'plugin successfully loaded: @{prefix}-@{content}');\n    }\n    return plugin;\n  });\n}\n"],"mappings":";;;;;;;AAAA;;AACA;;AACA;;AAIA;;AACA;;;;AAEA,MAAMA,KAAK,GAAG,IAAAC,cAAA,EAAW,yBAAX,CAAd;AAEA;AACA;AACA;AACA;AACA;;AACA,SAASC,OAAT,CAAiBC,IAAjB,EAAoC;EAClC,IAAI;IACFH,KAAK,CAAC,mBAAD,EAAsBG,IAAtB,CAAL;IACA,OAAOC,OAAO,CAACD,IAAD,CAAd;EACD,CAHD,CAGE,OAAOE,GAAP,EAAY;IACZ,IAAIA,GAAG,CAACC,IAAJ,KAAaC,2BAAjB,EAAmC;MACjCP,KAAK,CAAC,qBAAD,EAAwBG,IAAxB,CAAL;MACA,OAAO,IAAP;IACD;;IACDK,cAAA,CAAOC,KAAP,CAAa;MAAEJ,GAAG,EAAEA,GAAG,CAACK;IAAX,CAAb,EAA+B,6BAA/B;;IACA,MAAML,GAAN;EACD;AACF;;AAED,SAASM,WAAT,CAAqBC,SAArB,EAAgCC,YAAhC,EAAsD;EACpD,OAAOC,eAAA,CAAEC,KAAF,CAAQH,SAAR,EAAmBC,YAAnB,CAAP;AACD;;AAED,SAASG,OAAT,CAAiBC,MAAjB,EAAkC;EAChC,OAAOH,eAAA,CAAEI,UAAF,CAAaD,MAAb,KAAwBH,eAAA,CAAEI,UAAF,CAAaD,MAAM,CAACE,OAApB,CAA/B;AACD;;AAED,SAASC,KAAT,CAAeH,MAAf,EAAgC;EAC9B,OAAOI,MAAM,CAACC,IAAP,CAAYL,MAAZ,EAAoBM,QAApB,CAA6B,SAA7B,CAAP;AACD,C,CAED;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AACe,SAASC,UAAT,CAA0CC,MAA1C,EAA0DC,aAAkB,GAAG,EAA/E,EAAmFC,MAAnF,EAAgGC,WAAhG,EAAkHC,MAAc,GAAG,WAAnI,EAAuJ;EACpK,OAAOR,MAAM,CAACC,IAAP,CAAYI,aAAZ,EAA2BI,GAA3B,CAAgCC,QAAD,IAAkC;IACtE,IAAId,MAAJ;IACA,MAAMe,QAAiB,GAAGD,QAAQ,CAACE,UAAT,CAAoB,GAApB,KAA4BF,QAAQ,CAACR,QAAT,CAAkB,GAAlB,CAAtD;IACAvB,KAAK,CAAC,aAAD,EAAgBgC,QAAhB,CAAL;;IACA,IAAIA,QAAJ,EAAc;MACZf,MAAM,GAAGf,OAAO,CAAC6B,QAAD,CAAhB;IACD;;IAED,MAAMG,WAAW,GAAGC,aAAA,CAAKC,OAAL,CAAaC,SAAS,GAAG,aAAzB,EAAwCN,QAAxC,CAApB,CARsE,CAStE;;;IACAd,MAAM,GAAGf,OAAO,CAACgC,WAAD,CAAhB,CAVsE,CAYtE;;IACA,IAAIjB,MAAM,KAAK,IAAX,IAAmBQ,MAAM,CAACa,OAA9B,EAAuC;MACrC,MAAMC,SAAS,GAAGd,MAAM,CAACa,OAAzB;;MACA,MAAME,kBAAkB,GAAGL,aAAA,CAAKC,OAAL,CAAaG,SAAb,EAAwBR,QAAxB,CAA3B;;MACAd,MAAM,GAAGf,OAAO,CAACsC,kBAAD,CAAhB,CAHqC,CAKrC;;MACA,IAAIvB,MAAM,KAAK,IAAX,IAAmBc,QAAQ,CAACU,KAAT,CAAe,UAAf,CAAvB,EAAmD;QACjDxB,MAAM,GAAGf,OAAO,CAACiC,aAAA,CAAKC,OAAL,CAAaG,SAAb,EAAyB,GAAEV,MAAO,IAAGE,QAAS,EAA9C,CAAD,CAAhB,CADiD,CAEjD;;QACA,IAAI,CAACd,MAAL,EAAa;UACXA,MAAM,GAAGf,OAAO,CAACiC,aAAA,CAAKC,OAAL,CAAaG,SAAb,EAAyB,WAAUR,QAAS,EAA5C,CAAD,CAAhB;;UACA,IAAId,MAAJ,EAAY;YACVT,cAAA,CAAOkC,IAAP,CAAY;cAAEC,IAAI,EAAEZ;YAAR,CAAZ,EAAiC,4GAAjC;UACD;QACF;MACF;IACF,CA7BqE,CA+BtE;;;IACA,IAAId,MAAM,KAAK,IAAX,IAAmBc,QAAQ,CAACU,KAAT,CAAe,UAAf,CAAvB,EAAmD;MACjDxB,MAAM,GAAGf,OAAO,CAAE,GAAE2B,MAAO,IAAGE,QAAS,EAAvB,CAAhB,CADiD,CAEjD;;MACA,IAAI,CAACd,MAAL,EAAa;QACXA,MAAM,GAAGf,OAAO,CAAE,WAAU6B,QAAS,EAArB,CAAhB;MACD;;MACD,IAAId,MAAJ,EAAY;QACVjB,KAAK,CAAC,6BAAD,EAAgC+B,QAAhC,CAAL;MACD;IACF;;IAED,IAAId,MAAM,KAAK,IAAf,EAAqB;MACnBA,MAAM,GAAGf,OAAO,CAAC6B,QAAD,CAAhB;IACD,CA7CqE,CA+CtE;;;IACA,IAAId,MAAM,KAAK,IAAX,IAAmBc,QAAQ,CAACU,KAAT,CAAe,cAAf,CAAvB,EAAuD;MACrDxB,MAAM,GAAGf,OAAO,CAACiC,aAAA,CAAKC,OAAL,CAAaD,aAAA,CAAKS,OAAL,CAAanB,MAAM,CAACoB,SAApB,CAAb,EAA6Cd,QAA7C,CAAD,CAAhB;IACD;;IAED,IAAId,MAAM,KAAK,IAAf,EAAqB;MACnB,IAAIe,QAAJ,EAAc;QACZxB,cAAA,CAAOC,KAAP,CAAa;UAAEqC,OAAO,EAAEf;QAAX,CAAb,EAAoC,8CAApC;MACD,CAFD,MAEO;QACLvB,cAAA,CAAOC,KAAP,CAAa;UAAEqC,OAAO,EAAEf,QAAX;UAAqBF;QAArB,CAAb,EAA4C,wDAA5C;MACD;;MACD,MAAMnB,GAAG,GAAGsB,QAAQ,GACf;AACX,QAAQD,QAAS,uCAAsCA,QAAS,GAFtC,GAGf;AACX,QAAQF,MAAO,IAAGE,QAAS,uCAAsCF,MAAO,IAAGE,QAAS,GAJ9E;MAKA,MAAMgB,KAAK,CAACrC,GAAD,CAAX;IACD;;IAED,IAAI,CAACM,OAAO,CAACC,MAAD,CAAZ,EAAsB;MACpBT,cAAA,CAAOC,KAAP,CAAa;QAAEqC,OAAO,EAAEf;MAAX,CAAb,EAAoC,oEAApC;;MACA,MAAMgB,KAAK,CAAE,IAAGhB,QAAS,iDAAd,CAAX;IACD;IAED;;;IACA,IAAI;MACF,IAAIX,KAAK,CAACH,MAAD,CAAT,EAAmB;QACjBjB,KAAK,CAAC,eAAD,CAAL;QACAiB,MAAM,GAAG,IAAIA,MAAM,CAACE,OAAX,CAAmBR,WAAW,CAACc,MAAD,EAASC,aAAa,CAACK,QAAD,CAAtB,CAA9B,EAAiEJ,MAAjE,CAAT;MACD,CAHD,MAGO;QACL3B,KAAK,CAAC,oBAAD,CAAL;QACAiB,MAAM,GAAGA,MAAM,CAACS,aAAa,CAACK,QAAD,CAAd,EAA0BJ,MAA1B,CAAf;MACD;IACF,CARD,CAQE,OAAOlB,KAAP,EAAc;MACdQ,MAAM,GAAG,IAAT;;MACAT,cAAA,CAAOC,KAAP,CAAa;QAAEA,KAAF;QAASsB;MAAT,CAAb,EAAkC,8CAAlC;IACD;IACD;;;IAEA,IAAId,MAAM,KAAK,IAAX,IAAmB,CAACW,WAAW,CAACX,MAAD,CAAnC,EAA6C;MAC3C,IAAIe,QAAJ,EAAc;QACZxB,cAAA,CAAOC,KAAP,CAAa;UAAEqC,OAAO,EAAEf;QAAX,CAAb,EAAoC,6CAApC;MACD,CAFD,MAEO;QACLvB,cAAA,CAAOC,KAAP,CAAa;UAAEqC,OAAO,EAAEf,QAAX;UAAqBF;QAArB,CAAb,EAA4C,uDAA5C;MACD;;MACD,MAAMkB,KAAK,CAAE,6BAA4BhB,QAAS,yBAAvC,CAAX;IACD;;IAED,IAAIC,QAAJ,EAAc;MACZxB,cAAA,CAAOwC,IAAP,CAAY;QAAEF,OAAO,EAAEf;MAAX,CAAZ,EAAmC,wCAAnC;IACD,CAFD,MAEO;MACLvB,cAAA,CAAOwC,IAAP,CAAY;QAAEF,OAAO,EAAEf,QAAX;QAAqBF;MAArB,CAAZ,EAA2C,kDAA3C;IACD;;IACD,OAAOZ,MAAP;EACD,CArGM,CAAP;AAsGD"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "verdaccio",
3
- "version": "5.11.0",
3
+ "version": "5.12.0",
4
4
  "description": "A lightweight private npm proxy registry",
5
5
  "author": {
6
6
  "name": "Verdaccio Maintainers",
@@ -19,18 +19,18 @@
19
19
  },
20
20
  "dependencies": {
21
21
  "@verdaccio/commons-api": "10.2.0",
22
- "@verdaccio/local-storage": "10.2.1",
22
+ "@verdaccio/local-storage": "10.3.0",
23
23
  "@verdaccio/readme": "10.3.4",
24
24
  "@verdaccio/streams": "10.2.0",
25
25
  "@verdaccio/ui-theme": "6.0.0-6-next.24",
26
26
  "JSONStream": "1.3.5",
27
- "async": "3.2.3",
27
+ "async": "3.2.4",
28
28
  "body-parser": "1.20.0",
29
29
  "clipanion": "3.1.0",
30
30
  "compression": "1.7.4",
31
31
  "cookies": "0.8.0",
32
32
  "cors": "2.8.5",
33
- "dayjs": "1.11.2",
33
+ "dayjs": "1.11.3",
34
34
  "debug": "^4.3.3",
35
35
  "envinfo": "7.8.1",
36
36
  "eslint-import-resolver-node": "0.3.6",
@@ -43,12 +43,12 @@
43
43
  "jsonwebtoken": "8.5.1",
44
44
  "kleur": "4.1.4",
45
45
  "lodash": "4.17.21",
46
- "lru-cache": "7.9.0",
46
+ "lru-cache": "7.10.1",
47
47
  "lunr-mutable-indexes": "2.3.2",
48
- "marked": "4.0.16",
48
+ "marked": "4.0.17",
49
49
  "memoizee": "0.4.15",
50
50
  "mime": "3.0.0",
51
- "minimatch": "5.0.1",
51
+ "minimatch": "5.1.0",
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.7",
60
60
  "validator": "13.7.0",
61
61
  "verdaccio-audit": "10.2.2",
62
- "verdaccio-htpasswd": "10.3.0"
62
+ "verdaccio-htpasswd": "10.3.1"
63
63
  },
64
64
  "devDependencies": {
65
65
  "@babel/cli": "7.17.10",
@@ -89,7 +89,7 @@
89
89
  "@commitlint/config-conventional": "12.1.4",
90
90
  "@octokit/rest": "18.12.0",
91
91
  "@trivago/prettier-plugin-sort-imports": "3.1.1",
92
- "@types/async": "3.2.12",
92
+ "@types/async": "3.2.13",
93
93
  "@types/express": "4.17.13",
94
94
  "@types/express-rate-limit": "5.1.3",
95
95
  "@types/express-serve-static-core": "4.17.28",
@@ -104,8 +104,9 @@
104
104
  "@types/semver": "7.3.9",
105
105
  "@typescript-eslint/eslint-plugin": "4.33.0",
106
106
  "@typescript-eslint/parser": "4.33.0",
107
- "@verdaccio/eslint-config": "^8.5.0",
108
- "@verdaccio/types": "10.4.2",
107
+ "@verdaccio-scope/verdaccio-auth-foo": "0.0.2",
108
+ "@verdaccio/eslint-config": "^10.0.0",
109
+ "@verdaccio/types": "10.5.1",
109
110
  "all-contributors-cli": "6.20.0",
110
111
  "babel-eslint": "10.1.0",
111
112
  "babel-jest": "26.6.3",
@@ -141,7 +142,7 @@
141
142
  "ts-node": "10.7.0",
142
143
  "typescript": "4.1.3",
143
144
  "verdaccio-auth-memory": "10.2.0",
144
- "verdaccio-memory": "10.2.1"
145
+ "verdaccio-memory": "10.3.0"
145
146
  },
146
147
  "keywords": [
147
148
  "private",