verdaccio 5.8.0 β†’ 5.10.1

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,46 @@
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.10.1](https://github.com/verdaccio/verdaccio/compare/v5.10.0...v5.10.1) (2022-05-05)
6
+
7
+
8
+ ### Bug Fixes
9
+
10
+ * duplicated groups on use jwt tokens ([#3151](https://github.com/verdaccio/verdaccio/issues/3151)) ([51803c3](https://github.com/verdaccio/verdaccio/commit/51803c34776ca1e868399ede4f17a087c9a39bc5))
11
+
12
+ ## [5.10.0](https://github.com/verdaccio/verdaccio/compare/v5.9.0...v5.10.0) (2022-04-26)
13
+
14
+
15
+ ### Features
16
+
17
+ * **deps:** update dependency @verdaccio/ui-theme to v6.0.0-6-next.24 (5.x) ([#3130](https://github.com/verdaccio/verdaccio/issues/3130)) ([da01a14](https://github.com/verdaccio/verdaccio/commit/da01a14e70de722aab0c99bb81997886fae35727))
18
+
19
+
20
+ ### Bug Fixes
21
+
22
+ * **deps:** update dependency @verdaccio/local-storage to v10.2.1 ([#3118](https://github.com/verdaccio/verdaccio/issues/3118)) ([0f9d6ec](https://github.com/verdaccio/verdaccio/commit/0f9d6eca34476505df95e67acd2f77fbce3a1c96))
23
+ * **deps:** update dependency @verdaccio/readme to v10.3.3 ([#3119](https://github.com/verdaccio/verdaccio/issues/3119)) ([78b9c8b](https://github.com/verdaccio/verdaccio/commit/78b9c8b33ee1c1894d654b69b8c88631c5139cc9))
24
+ * **deps:** update dependency body-parser to v1.20.0 ([#3123](https://github.com/verdaccio/verdaccio/issues/3123)) ([954886d](https://github.com/verdaccio/verdaccio/commit/954886d2db32088ea246dd3b5748c25ac56c30b0))
25
+ * **deps:** update dependency dayjs to v1.11.1 ([#3131](https://github.com/verdaccio/verdaccio/issues/3131)) ([27035f9](https://github.com/verdaccio/verdaccio/commit/27035f9403261b342d9d3a3826e6b92c45de1954))
26
+ * **deps:** update dependency lru-cache to v7 ([#3124](https://github.com/verdaccio/verdaccio/issues/3124)) ([7ceaa17](https://github.com/verdaccio/verdaccio/commit/7ceaa1799c80a6cde23255affbfe076f6e44cb9d))
27
+ * **deps:** update dependency marked to v4.0.14 ([#3120](https://github.com/verdaccio/verdaccio/issues/3120)) ([8a60050](https://github.com/verdaccio/verdaccio/commit/8a60050b8b4594aae0d3c942b23aaf33f857ebcf))
28
+ * **deps:** update dependency semver to v7.3.7 ([#3121](https://github.com/verdaccio/verdaccio/issues/3121)) ([157d5c5](https://github.com/verdaccio/verdaccio/commit/157d5c5ce415d81500bdc71435ccf30b19631aef))
29
+ * **deps:** update dependency verdaccio-audit to v10.2.1 ([#3122](https://github.com/verdaccio/verdaccio/issues/3122)) ([decd7f1](https://github.com/verdaccio/verdaccio/commit/decd7f1e5cfc48bbf159f1ac42ecaa7861e6a5f9))
30
+
31
+ ## [5.9.0](https://github.com/verdaccio/verdaccio/compare/v5.8.0...v5.9.0) (2022-04-12)
32
+
33
+
34
+ ### Features
35
+
36
+ * **web:** add a config item to web,let the developer can select whether enable the html cache ([#3110](https://github.com/verdaccio/verdaccio/issues/3110)) ([b30ba81](https://github.com/verdaccio/verdaccio/commit/b30ba81b86d3fa11a18bdb32a7adf162f16794e0))
37
+
38
+
39
+ ### Bug Fixes
40
+
41
+ * **deps:** update dependency @verdaccio/ui-theme to v6.0.0-6-next.23 ([#3106](https://github.com/verdaccio/verdaccio/issues/3106)) ([b963f7d](https://github.com/verdaccio/verdaccio/commit/b963f7db2a2273983c0d5b4792a84601be732823))
42
+ * **deps:** update dependency body-parser to v1.19.2 ([#3087](https://github.com/verdaccio/verdaccio/issues/3087)) ([8cee85f](https://github.com/verdaccio/verdaccio/commit/8cee85f811effe5ba95458f18381beddaa2850dc))
43
+ * **deps:** update dependency dayjs to v1.11.0 ([#3094](https://github.com/verdaccio/verdaccio/issues/3094)) ([4cc1877](https://github.com/verdaccio/verdaccio/commit/4cc18773b73e387ef362de6438965ca198114bcb))
44
+
5
45
  ## [5.8.0](https://github.com/verdaccio/verdaccio/compare/v5.7.1...v5.8.0) (2022-03-12)
6
46
 
7
47
 
package/README.md CHANGED
@@ -39,9 +39,9 @@ Are you still using **Verdaccio 4**?. Check the [migration guide](https://verdac
39
39
 
40
40
  ## Donations
41
41
 
42
- Verdaccio is run by **volunteers**; nobody is working full-time on it. If you find this project to be useful and would like to support its development, consider making a donation - **your logo might end up in this readme.** πŸ˜‰
42
+ Verdaccio is run by **volunteers**; nobody is working full-time on it. If you find this project to be useful and would like to support its development and maintenance.
43
43
 
44
- **[Donate](https://github.com/sponsors/verdaccio)** πŸ’΅πŸ‘πŸ» starting from _$1/month_ or just one single contribution.
44
+ You can donate **[GitHub Sponsors](https://github.com/sponsors/verdaccio)** or **[Open Collective](https://opencollective.com/verdaccio)** πŸ’΅πŸ‘πŸ» starting from _$1/month_ or just one single contribution.
45
45
 
46
46
  ## What does Verdaccio do for me?
47
47
 
@@ -67,14 +67,22 @@ If you want to use a modified version of some 3rd-party package (for example, yo
67
67
  Verdaccio has proved to be a lightweight registry that can be
68
68
  booted in a couple of seconds, fast enough for any CI. Many open source projects use verdaccio for end to end testing, to mention some examples, **create-react-app**, **mozilla neutrino**, **pnpm**, **storybook**, **alfresco** or **eclipse theia**. You can read more in dedicated article to E2E in our blog.
69
69
 
70
- ## Talks
70
+ ## Next talks
71
71
 
72
- ### **Using Docker and Verdaccio to make Integration Testing Easy - Docker All Hands #4 December - 2021**.
72
+ - [**Deep dive into Verdaccio, a lightweight Node.js registry - June 29th 2022**](https://www.nodetlv.com/)
73
+ - [**How to improve your workflows with Verdaccio, your private Node.js registry - Global Summit for Node.js - May 18th 2022**](https://events.geekle.us/nodejs/)
73
74
 
74
- [![docker](https://cdn.verdaccio.dev/readme/docker-all-hands-jpicado-talk.jpg)](https://www.youtube.com/watch?v=zRI0skF1f8I)
75
+ ## The latest talk
76
+
77
+ <div>
78
+ <a href="https://portal.gitnation.org/contents/five-ways-of-taking-advantage-of-verdaccio-your-private-and-proxy-nodejs-registry">
79
+ <img src="https://cdn.verdaccio.dev/readme/nodejscongress2022.jpg" alt="nodejs" width="300"/>
80
+ </a>
81
+ </div>
75
82
 
76
83
  You might want to check out as well our previous talks:
77
84
 
85
+ - [Using Docker and Verdaccio to make Integration Testing Easy - Docker All Hands #4 December - **Juan Picado** - 2021](https://www.youtube.com/watch?v=zRI0skF1f8I)
78
86
  - [**Juan Picado** – Testing the integrity of React components by publishing in a private registry](https://www.youtube.com/watch?v=bRKZbrlQqLY&t=16s&ab_channel=ReactFinland)
79
87
  - [BeerJS Cba Meetup No. 53 May 2021 - **Juan Picado** React Finland - 2021](https://www.youtube.com/watch?v=6SyjqBmS49Y&ab_channel=BeerJSCba)
80
88
  - [Node.js Dependency Confusion Attacks - April 2021 - **Juan Picado**](https://www.youtube.com/watch?v=qTRADSp3Hpo)
@@ -68,7 +68,7 @@ function resolveLogo(config, req) {
68
68
  }
69
69
 
70
70
  function renderHTML(config, manifest, manifestFiles, req, res) {
71
- var _config$i18n$web, _config$i18n, _config$web$darkMode, _config$web6, _config$web$title, _config$web7, _config$web$scope, _config$web8, _config$web$pkgManage, _config$web9, _validatePrimaryColor, _config$web10;
71
+ var _config$i18n$web, _config$i18n, _config$web6, _config$web$darkMode, _config$web7, _config$web$title, _config$web8, _config$web$scope, _config$web9, _config$web$pkgManage, _config$web10, _validatePrimaryColor, _config$web11;
72
72
 
73
73
  const {
74
74
  url_prefix
@@ -76,24 +76,37 @@ function renderHTML(config, manifest, manifestFiles, req, res) {
76
76
  const base = (0, _utils.getPublicUrl)(config === null || config === void 0 ? void 0 : config.url_prefix, req);
77
77
  const basename = new _url.URL(base).pathname;
78
78
  const language = (_config$i18n$web = config === null || config === void 0 ? void 0 : (_config$i18n = config.i18n) === null || _config$i18n === void 0 ? void 0 : _config$i18n.web) !== null && _config$i18n$web !== void 0 ? _config$i18n$web : DEFAULT_LANGUAGE;
79
- const darkMode = (_config$web$darkMode = config === null || config === void 0 ? void 0 : (_config$web6 = config.web) === null || _config$web6 === void 0 ? void 0 : _config$web6.darkMode) !== null && _config$web$darkMode !== void 0 ? _config$web$darkMode : false;
80
- const title = (_config$web$title = config === null || config === void 0 ? void 0 : (_config$web7 = config.web) === null || _config$web7 === void 0 ? void 0 : _config$web7.title) !== null && _config$web$title !== void 0 ? _config$web$title : _constants.WEB_TITLE;
81
- const scope = (_config$web$scope = config === null || config === void 0 ? void 0 : (_config$web8 = config.web) === null || _config$web8 === void 0 ? void 0 : _config$web8.scope) !== null && _config$web$scope !== void 0 ? _config$web$scope : '';
79
+ const needHtmlCache = [undefined, null].includes(config === null || config === void 0 ? void 0 : (_config$web6 = config.web) === null || _config$web6 === void 0 ? void 0 : _config$web6.html_cache) ? true : config.web.html_cache;
80
+ const darkMode = (_config$web$darkMode = config === null || config === void 0 ? void 0 : (_config$web7 = config.web) === null || _config$web7 === void 0 ? void 0 : _config$web7.darkMode) !== null && _config$web$darkMode !== void 0 ? _config$web$darkMode : false;
81
+ const title = (_config$web$title = config === null || config === void 0 ? void 0 : (_config$web8 = config.web) === null || _config$web8 === void 0 ? void 0 : _config$web8.title) !== null && _config$web$title !== void 0 ? _config$web$title : _constants.WEB_TITLE;
82
+ const scope = (_config$web$scope = config === null || config === void 0 ? void 0 : (_config$web9 = config.web) === null || _config$web9 === void 0 ? void 0 : _config$web9.scope) !== null && _config$web$scope !== void 0 ? _config$web$scope : '';
82
83
  const login = (0, _utils.hasLogin)(config);
83
84
  const logoURI = resolveLogo(config, req);
84
- const pkgManagers = (_config$web$pkgManage = config === null || config === void 0 ? void 0 : (_config$web9 = config.web) === null || _config$web9 === void 0 ? void 0 : _config$web9.pkgManagers) !== null && _config$web$pkgManage !== void 0 ? _config$web$pkgManage : ['yarn', 'pnpm', 'npm'];
85
+ const pkgManagers = (_config$web$pkgManage = config === null || config === void 0 ? void 0 : (_config$web10 = config.web) === null || _config$web10 === void 0 ? void 0 : _config$web10.pkgManagers) !== null && _config$web$pkgManage !== void 0 ? _config$web$pkgManage : ['yarn', 'pnpm', 'npm'];
85
86
  const version = pkgJSON.version;
86
- const primaryColor = (_validatePrimaryColor = validatePrimaryColor(config === null || config === void 0 ? void 0 : (_config$web10 = config.web) === null || _config$web10 === void 0 ? void 0 : _config$web10.primary_color)) !== null && _validatePrimaryColor !== void 0 ? _validatePrimaryColor : '#4b5e40';
87
+ const primaryColor = (_validatePrimaryColor = validatePrimaryColor(config === null || config === void 0 ? void 0 : (_config$web11 = config.web) === null || _config$web11 === void 0 ? void 0 : _config$web11.primary_color)) !== null && _validatePrimaryColor !== void 0 ? _validatePrimaryColor : '#4b5e40';
87
88
  const {
88
89
  scriptsBodyAfter,
89
90
  metaScripts,
90
- scriptsbodyBefore
91
+ scriptsbodyBefore,
92
+ showInfo,
93
+ showSettings,
94
+ showThemeSwitch,
95
+ showFooter,
96
+ showSearch,
97
+ showDownloadTarball
91
98
  } = Object.assign({}, {
92
99
  scriptsBodyAfter: [],
93
100
  bodyBefore: [],
94
101
  metaScripts: []
95
102
  }, config === null || config === void 0 ? void 0 : config.web);
96
103
  const options = {
104
+ showInfo,
105
+ showSettings,
106
+ showThemeSwitch,
107
+ showFooter,
108
+ showSearch,
109
+ showDownloadTarball,
97
110
  darkMode,
98
111
  url_prefix,
99
112
  basename,
@@ -123,8 +136,11 @@ function renderHTML(config, manifest, manifestFiles, req, res) {
123
136
  scriptsbodyBefore
124
137
  }, manifest);
125
138
  debug('template :: %o', webPage);
126
- cache.set('template', webPage);
127
- debug('set template cache');
139
+
140
+ if (needHtmlCache) {
141
+ cache.set('template', webPage);
142
+ debug('set template cache');
143
+ }
128
144
  } else {
129
145
  debug('reuse template cache');
130
146
  }
@@ -136,4 +152,4 @@ function renderHTML(config, manifest, manifestFiles, req, res) {
136
152
  res.send(webPage);
137
153
  debug('render web');
138
154
  }
139
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/api/web/html/renderHTML.ts"],"names":["pkgJSON","require","DEFAULT_LANGUAGE","cache","LRU","max","maxAge","debug","defaultManifestFiles","js","ico","validatePrimaryColor","primaryColor","isHex","test","resolveLogo","config","req","isLocalFile","web","logo","url_prefix","path","basename","renderHTML","manifest","manifestFiles","res","base","URL","pathname","language","i18n","darkMode","title","WEB_TITLE","scope","login","logoURI","pkgManagers","version","primary_color","scriptsBodyAfter","metaScripts","scriptsbodyBefore","Object","assign","bodyBefore","options","webPage","get","set","error","Error","stack","setHeader","HEADERS","TEXT_HTML","send"],"mappings":"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","sourcesContent":["import buildDebug from 'debug';\nimport LRU from 'lru-cache';\nimport path from 'path';\nimport { URL } from 'url';\n\nimport { HEADERS } from '@verdaccio/commons-api';\n\nimport { WEB_TITLE } from '../../../lib/constants';\nimport { getPublicUrl, hasLogin, isHTTPProtocol } from '../../../lib/utils';\nimport renderTemplate from './template';\n\nconst pkgJSON = require('../../../../package.json');\nconst DEFAULT_LANGUAGE = 'es-US';\nconst cache = new LRU({ max: 500, maxAge: 1000 * 60 * 60 });\n\nconst debug = buildDebug('verdaccio');\n\nconst defaultManifestFiles = {\n  js: ['runtime.js', 'vendors.js', 'main.js'],\n  ico: 'favicon.ico',\n};\n\nexport function validatePrimaryColor(primaryColor) {\n  const isHex = /^#+([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/i.test(primaryColor);\n  if (!isHex) {\n    debug('invalid primary color %o', primaryColor);\n    return;\n  }\n\n  return primaryColor;\n}\n\nexport function resolveLogo(config, req) {\n  const isLocalFile = config?.web?.logo && !isHTTPProtocol(config?.web?.logo);\n\n  if (isLocalFile) {\n    return `${getPublicUrl(config?.url_prefix, req)}-/static/${path.basename(config?.web?.logo)}`;\n  } else if (isHTTPProtocol(config?.web?.logo)) {\n    return config?.web?.logo;\n  } else {\n    return '';\n  }\n}\n\nexport default function renderHTML(config, manifest, manifestFiles, req, res) {\n  const { url_prefix } = config;\n  const base = getPublicUrl(config?.url_prefix, req);\n  const basename = new URL(base).pathname;\n  const language = config?.i18n?.web ?? DEFAULT_LANGUAGE;\n  const darkMode = config?.web?.darkMode ?? false;\n  const title = config?.web?.title ?? WEB_TITLE;\n  const scope = config?.web?.scope ?? '';\n  const login = hasLogin(config);\n  const logoURI = resolveLogo(config, req);\n  const pkgManagers = config?.web?.pkgManagers ?? ['yarn', 'pnpm', 'npm'];\n  const version = pkgJSON.version;\n  const primaryColor = validatePrimaryColor(config?.web?.primary_color) ?? '#4b5e40';\n  const { scriptsBodyAfter, metaScripts, scriptsbodyBefore } = Object.assign(\n    {},\n    {\n      scriptsBodyAfter: [],\n      bodyBefore: [],\n      metaScripts: [],\n    },\n    config?.web\n  );\n  const options = {\n    darkMode,\n    url_prefix,\n    basename,\n    base,\n    primaryColor,\n    version,\n    pkgManagers,\n    login,\n    logo: logoURI,\n    title,\n    scope,\n    language,\n  };\n\n  let webPage;\n\n  try {\n    webPage = cache.get('template');\n\n    if (!webPage) {\n      debug('web options %o', options);\n      debug('web manifestFiles %o', manifestFiles);\n      webPage = renderTemplate(\n        {\n          manifest: manifestFiles ?? defaultManifestFiles,\n          options,\n          scriptsBodyAfter,\n          metaScripts,\n          scriptsbodyBefore,\n        },\n        manifest\n      );\n      debug('template :: %o', webPage);\n      cache.set('template', webPage);\n      debug('set template cache');\n    } else {\n      debug('reuse template cache');\n    }\n  } catch (error) {\n    throw new Error(`theme could not be load, stack ${error.stack}`);\n  }\n  res.setHeader('Content-Type', HEADERS.TEXT_HTML);\n  res.send(webPage);\n  debug('render web');\n}\n"]}
155
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/api/web/html/renderHTML.ts"],"names":["pkgJSON","require","DEFAULT_LANGUAGE","cache","LRU","max","maxAge","debug","defaultManifestFiles","js","ico","validatePrimaryColor","primaryColor","isHex","test","resolveLogo","config","req","isLocalFile","web","logo","url_prefix","path","basename","renderHTML","manifest","manifestFiles","res","base","URL","pathname","language","i18n","needHtmlCache","undefined","includes","html_cache","darkMode","title","WEB_TITLE","scope","login","logoURI","pkgManagers","version","primary_color","scriptsBodyAfter","metaScripts","scriptsbodyBefore","showInfo","showSettings","showThemeSwitch","showFooter","showSearch","showDownloadTarball","Object","assign","bodyBefore","options","webPage","get","set","error","Error","stack","setHeader","HEADERS","TEXT_HTML","send"],"mappings":"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","sourcesContent":["import buildDebug from 'debug';\nimport LRU from 'lru-cache';\nimport path from 'path';\nimport { URL } from 'url';\n\nimport { HEADERS } from '@verdaccio/commons-api';\n\nimport { WEB_TITLE } from '../../../lib/constants';\nimport { getPublicUrl, hasLogin, isHTTPProtocol } from '../../../lib/utils';\nimport renderTemplate from './template';\n\nconst pkgJSON = require('../../../../package.json');\nconst DEFAULT_LANGUAGE = 'es-US';\nconst cache = new LRU({ max: 500, maxAge: 1000 * 60 * 60 });\n\nconst debug = buildDebug('verdaccio');\n\nconst defaultManifestFiles = {\n  js: ['runtime.js', 'vendors.js', 'main.js'],\n  ico: 'favicon.ico',\n};\n\nexport function validatePrimaryColor(primaryColor) {\n  const isHex = /^#+([a-fA-F0-9]{6}|[a-fA-F0-9]{3})$/i.test(primaryColor);\n  if (!isHex) {\n    debug('invalid primary color %o', primaryColor);\n    return;\n  }\n\n  return primaryColor;\n}\n\nexport function resolveLogo(config, req) {\n  const isLocalFile = config?.web?.logo && !isHTTPProtocol(config?.web?.logo);\n\n  if (isLocalFile) {\n    return `${getPublicUrl(config?.url_prefix, req)}-/static/${path.basename(config?.web?.logo)}`;\n  } else if (isHTTPProtocol(config?.web?.logo)) {\n    return config?.web?.logo;\n  } else {\n    return '';\n  }\n}\n\nexport default function renderHTML(config, manifest, manifestFiles, req, res) {\n  const { url_prefix } = config;\n  const base = getPublicUrl(config?.url_prefix, req);\n  const basename = new URL(base).pathname;\n  const language = config?.i18n?.web ?? DEFAULT_LANGUAGE;\n  const needHtmlCache = [undefined, null].includes(config?.web?.html_cache) ? true : config.web.html_cache;\n  const darkMode = config?.web?.darkMode ?? false;\n  const title = config?.web?.title ?? WEB_TITLE;\n  const scope = config?.web?.scope ?? '';\n  const login = hasLogin(config);\n  const logoURI = resolveLogo(config, req);\n  const pkgManagers = config?.web?.pkgManagers ?? ['yarn', 'pnpm', 'npm'];\n  const version = pkgJSON.version;\n  const primaryColor = validatePrimaryColor(config?.web?.primary_color) ?? '#4b5e40';\n  const { scriptsBodyAfter, metaScripts, scriptsbodyBefore, showInfo, showSettings, showThemeSwitch, showFooter, showSearch, showDownloadTarball } = Object.assign(\n    {},\n    {\n      scriptsBodyAfter: [],\n      bodyBefore: [],\n      metaScripts: [],\n    },\n    config?.web\n  );\n  const options = {\n    showInfo,\n    showSettings,\n    showThemeSwitch,\n    showFooter,\n    showSearch,\n    showDownloadTarball,\n    darkMode,\n    url_prefix,\n    basename,\n    base,\n    primaryColor,\n    version,\n    pkgManagers,\n    login,\n    logo: logoURI,\n    title,\n    scope,\n    language,\n  };\n\n  let webPage;\n\n  try {\n    webPage = cache.get('template');\n    if (!webPage) {\n      debug('web options %o', options);\n      debug('web manifestFiles %o', manifestFiles);\n      webPage = renderTemplate(\n        {\n          manifest: manifestFiles ?? defaultManifestFiles,\n          options,\n          scriptsBodyAfter,\n          metaScripts,\n          scriptsbodyBefore,\n        },\n        manifest\n      );\n      debug('template :: %o', webPage);\n      if (needHtmlCache) {\n        cache.set('template', webPage);\n        debug('set template cache');\n      }\n    } else {\n      debug('reuse template cache');\n    }\n  } catch (error) {\n    throw new Error(`theme could not be load, stack ${error.stack}`);\n  }\n  res.setHeader('Content-Type', HEADERS.TEXT_HTML);\n  res.send(webPage);\n  debug('render web');\n}\n"]}
@@ -51,7 +51,7 @@ minLength = _constants.DEFAULT_MIN_LIMIT_PASSWORD) {
51
51
 
52
52
  function createRemoteUser(name, pluginGroups) {
53
53
  const isGroupValid = Array.isArray(pluginGroups);
54
- const groups = (isGroupValid ? pluginGroups : []).concat([_constants.ROLES.$ALL, _constants.ROLES.$AUTH, _constants.ROLES.DEPRECATED_ALL, _constants.ROLES.DEPRECATED_AUTH, _constants.ROLES.ALL]);
54
+ const groups = Array.from(new Set((isGroupValid ? pluginGroups : []).concat([_constants.ROLES.$ALL, _constants.ROLES.$AUTH, _constants.ROLES.DEPRECATED_ALL, _constants.ROLES.DEPRECATED_AUTH, _constants.ROLES.ALL])));
55
55
  return {
56
56
  name,
57
57
  groups,
@@ -312,4 +312,4 @@ function getMiddlewareCredentials(security, secret, authorizationHeader) {
312
312
  return verifyJWTPayload(token, secret);
313
313
  }
314
314
  }
315
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/lib/auth-utils.ts"],"names":["debug","validatePassword","password","minLength","DEFAULT_MIN_LIMIT_PASSWORD","length","createRemoteUser","name","pluginGroups","isGroupValid","Array","isArray","groups","concat","ROLES","$ALL","$AUTH","DEPRECATED_ALL","DEPRECATED_AUTH","ALL","real_groups","createAnonymousRemoteUser","undefined","$ANONYMOUS","DEPRECATED_ANONYMOUS","allow_action","action","user","pkg","callback","groupAccess","hasPermission","some","group","includes","logger","info","remote","ErrorCode","getForbidden","getUnauthorized","handleSpecialUnpublish","isUnpublishMissing","_","isNil","hasGroups","getDefaultPlugins","authenticate","_user","_password","cb","API_ERROR","BAD_USERNAME_PASSWORD","add_user","getConflict","allow_access","allow_publish","allow_unpublish","createSessionToken","tenHoursTime","expires","Date","now","defaultWebTokenOptions","sign","expiresIn","TIME_EXPIRATION_1H","verify","defaultApiTokenConf","legacy","defaultUserRateLimiting","windowMs","max","defaultSecurity","web","api","getSecurity","config","security","merge","getAuthenticatedMessage","buildUserBuffer","Buffer","from","isAESLegacy","jwt","getApiToken","auth","remoteUser","aesPassword","Promise","resolve","aesEncrypt","toString","jwtEncrypt","parseAuthTokenHeader","authorizationHeader","parts","split","scheme","token","parseBasicPayload","credentials","index","indexOf","slice","parseAESCredentials","secret","toUpperCase","TOKEN_BASIC","TOKEN_BEARER","tokenAsBuffer","expireReasons","verifyJWTPayload","payload","error","getCode","HTTP_STATUS","UNAUTHORIZED","message","isAuthHeaderValid","authorization","getMiddlewareCredentials","parsedCredentials","isString"],"mappings":"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","sourcesContent":["import buildDebug from 'debug';\nimport _ from 'lodash';\n\nimport { APITokenOptions, Callback, Config, IPluginAuth, JWTOptions, Package, RemoteUser, Security } from '@verdaccio/types';\n\nimport { AuthMiddlewarePayload, AuthTokenHeader, BasicPayload, CookieSessionToken, IAuthWebUI } from '../../types';\nimport { logger } from '../lib/logger';\nimport { API_ERROR, DEFAULT_MIN_LIMIT_PASSWORD, HTTP_STATUS, ROLES, TIME_EXPIRATION_1H, TOKEN_BASIC, TOKEN_BEARER } from './constants';\nimport { aesDecrypt, verifyPayload } from './crypto-utils';\nimport { ErrorCode, convertPayloadToBase64 } from './utils';\n\nconst debug = buildDebug('verdaccio');\n\nexport function validatePassword(\n  password: string, // pragma: allowlist secret\n  minLength: number = DEFAULT_MIN_LIMIT_PASSWORD\n): boolean {\n  return typeof password === 'string' && password.length >= minLength;\n}\n\n/**\n * Create a RemoteUser object\n * @return {Object} { name: xx, pluginGroups: [], real_groups: [] }\n */\nexport function createRemoteUser(name: string, pluginGroups: string[]): RemoteUser {\n  const isGroupValid: boolean = Array.isArray(pluginGroups);\n  const groups = (isGroupValid ? pluginGroups : []).concat([ROLES.$ALL, ROLES.$AUTH, ROLES.DEPRECATED_ALL, ROLES.DEPRECATED_AUTH, ROLES.ALL]);\n\n  return {\n    name,\n    groups,\n    real_groups: pluginGroups,\n  };\n}\n\n/**\n * Builds an anonymous remote user in case none is logged in.\n * @return {Object} { name: xx, groups: [], real_groups: [] }\n */\nexport function createAnonymousRemoteUser(): RemoteUser {\n  return {\n    name: undefined,\n    // groups without '$' are going to be deprecated eventually\n    groups: [ROLES.$ALL, ROLES.$ANONYMOUS, ROLES.DEPRECATED_ALL, ROLES.DEPRECATED_ANONYMOUS],\n    real_groups: [],\n  };\n}\n\nexport function allow_action(action: string): Function {\n  return function (user: RemoteUser, pkg: Package, callback: Callback): void {\n    debug('[auth/allow_action]: user: %o', user?.name);\n    const { name, groups } = user;\n    const groupAccess = pkg[action];\n    const hasPermission = groupAccess.some((group) => name === group || groups.includes(group));\n    debug('[auth/allow_action]: hasPermission? %o} for user: %o', hasPermission, user?.name);\n\n    if (hasPermission) {\n      logger.info({ remote: user.name }, `auth/allow_action: access granted to: @{user}`);\n      return callback(null, true);\n    }\n\n    if (name) {\n      callback(ErrorCode.getForbidden(`user ${name} is not allowed to ${action} package ${pkg.name}`));\n    } else {\n      callback(ErrorCode.getUnauthorized(`authorization required to ${action} package ${pkg.name}`));\n    }\n  };\n}\n\n/**\n *\n */\nexport function handleSpecialUnpublish(): any {\n  return function (user: RemoteUser, pkg: Package, callback: Callback): void {\n    const action = 'unpublish';\n    // verify whether the unpublish prop has been defined\n    const isUnpublishMissing: boolean = _.isNil(pkg[action]);\n    const hasGroups: boolean = isUnpublishMissing ? false : pkg[action].length > 0;\n    debug('fallback unpublish for @{name} has groups: %o for %o', hasGroups, user?.name);\n    if (isUnpublishMissing || hasGroups === false) {\n      return callback(null, undefined);\n    }\n    debug('allow_action for %o for %o has groups: %o for %o', action, user?.name, hasGroups, user);\n    return allow_action(action)(user, pkg, callback);\n  };\n}\n\nexport function getDefaultPlugins(logger: any): IPluginAuth<Config> {\n  return {\n    authenticate(_user: string, _password: string, cb: Callback): void {\n      // pragma: allowlist secret\n      cb(ErrorCode.getForbidden(API_ERROR.BAD_USERNAME_PASSWORD));\n    },\n\n    add_user(_user: string, _password: string, cb: Callback): void {\n      // pragma: allowlist secret\n      return cb(ErrorCode.getConflict(API_ERROR.BAD_USERNAME_PASSWORD));\n    },\n\n    // FIXME: allow_action and allow_publish should be in the @verdaccio/types\n    // @ts-ignore\n    allow_access: allow_action('access', logger),\n    // @ts-ignore\n    allow_publish: allow_action('publish', logger),\n    allow_unpublish: handleSpecialUnpublish(),\n  };\n}\n\nexport function createSessionToken(): CookieSessionToken {\n  const tenHoursTime = 10 * 60 * 60 * 1000;\n\n  return {\n    // npmjs.org sets 10h expire\n    expires: new Date(Date.now() + tenHoursTime),\n  };\n}\n\nconst defaultWebTokenOptions: JWTOptions = {\n  sign: {\n    // The expiration token for the website is 1 hour\n    expiresIn: TIME_EXPIRATION_1H,\n  },\n  verify: {},\n};\n\nconst defaultApiTokenConf: APITokenOptions = {\n  legacy: true,\n};\n\n// we limit max 1000 request per 15 minutes on user endpoints\nexport const defaultUserRateLimiting = {\n  windowMs: 15 * 60 * 1000, // 15 minutes\n  max: 1000,\n};\n\nexport const defaultSecurity: Security = {\n  web: defaultWebTokenOptions,\n  api: defaultApiTokenConf,\n};\n\nexport function getSecurity(config: Config): Security {\n  if (_.isNil(config.security) === false) {\n    return _.merge(defaultSecurity, config.security);\n  }\n\n  return defaultSecurity;\n}\n\nexport function getAuthenticatedMessage(user: string): string {\n  return `you are authenticated as '${user}'`;\n}\n\nexport function buildUserBuffer(name: string, password: string): Buffer {\n  return Buffer.from(`${name}:${password}`, 'utf8');\n}\n\nexport function isAESLegacy(security: Security): boolean {\n  const { legacy, jwt } = security.api;\n\n  return _.isNil(legacy) === false && _.isNil(jwt) && legacy === true;\n}\n\nexport async function getApiToken(auth: IAuthWebUI, config: Config, remoteUser: RemoteUser, aesPassword: string): Promise<string> {\n  const security: Security = getSecurity(config);\n  if (isAESLegacy(security)) {\n    // fallback all goes to AES encryption\n    return await new Promise((resolve): void => {\n      resolve(auth.aesEncrypt(buildUserBuffer(remoteUser.name as string, aesPassword)).toString('base64'));\n    });\n  }\n  // i am wiling to use here _.isNil but flow does not like it yet.\n  const { jwt } = security.api;\n\n  if (jwt && jwt.sign) {\n    return await auth.jwtEncrypt(remoteUser, jwt.sign);\n  }\n  return await new Promise((resolve): void => {\n    resolve(auth.aesEncrypt(buildUserBuffer(remoteUser.name as string, aesPassword)).toString('base64'));\n  });\n}\n\nexport function parseAuthTokenHeader(authorizationHeader: string): AuthTokenHeader {\n  const parts = authorizationHeader.split(' ');\n  const [scheme, token] = parts;\n\n  return { scheme, token };\n}\n\nexport function parseBasicPayload(credentials: string): BasicPayload {\n  const index = credentials.indexOf(':');\n  if (index < 0) {\n    return;\n  }\n\n  const user: string = credentials.slice(0, index);\n  const password: string = credentials.slice(index + 1);\n\n  return { user, password };\n}\n\nexport function parseAESCredentials(authorizationHeader: string, secret: string) {\n  const { scheme, token } = parseAuthTokenHeader(authorizationHeader);\n\n  // basic is deprecated and should not be enforced\n  if (scheme.toUpperCase() === TOKEN_BASIC.toUpperCase()) {\n    const credentials = convertPayloadToBase64(token).toString();\n\n    return credentials;\n  } else if (scheme.toUpperCase() === TOKEN_BEARER.toUpperCase()) {\n    const tokenAsBuffer = convertPayloadToBase64(token);\n    const credentials = aesDecrypt(tokenAsBuffer, secret).toString('utf8');\n\n    return credentials;\n  }\n}\n\nexport const expireReasons: string[] = ['JsonWebTokenError', 'TokenExpiredError'];\n\nexport function verifyJWTPayload(token: string, secret: string): RemoteUser {\n  try {\n    const payload: RemoteUser = verifyPayload(token, secret);\n\n    return payload;\n  } catch (error) {\n    // #168 this check should be removed as soon AES encrypt is removed.\n    if (expireReasons.includes(error.name)) {\n      // it might be possible the jwt configuration is enabled and\n      // old tokens fails still remains in usage, thus\n      // we return an anonymous user to force log in.\n      return createAnonymousRemoteUser();\n    }\n    throw ErrorCode.getCode(HTTP_STATUS.UNAUTHORIZED, error.message);\n  }\n}\n\nexport function isAuthHeaderValid(authorization: string): boolean {\n  return authorization.split(' ').length === 2;\n}\n\nexport function getMiddlewareCredentials(security: Security, secret: string, authorizationHeader: string): AuthMiddlewarePayload {\n  if (isAESLegacy(security)) {\n    const credentials = parseAESCredentials(authorizationHeader, secret);\n    if (!credentials) {\n      return;\n    }\n\n    const parsedCredentials = parseBasicPayload(credentials);\n    if (!parsedCredentials) {\n      return;\n    }\n\n    return parsedCredentials;\n  }\n  const { scheme, token } = parseAuthTokenHeader(authorizationHeader);\n\n  if (_.isString(token) && scheme.toUpperCase() === TOKEN_BEARER.toUpperCase()) {\n    return verifyJWTPayload(token, secret);\n  }\n}\n"]}
315
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/lib/auth-utils.ts"],"names":["debug","validatePassword","password","minLength","DEFAULT_MIN_LIMIT_PASSWORD","length","createRemoteUser","name","pluginGroups","isGroupValid","Array","isArray","groups","from","Set","concat","ROLES","$ALL","$AUTH","DEPRECATED_ALL","DEPRECATED_AUTH","ALL","real_groups","createAnonymousRemoteUser","undefined","$ANONYMOUS","DEPRECATED_ANONYMOUS","allow_action","action","user","pkg","callback","groupAccess","hasPermission","some","group","includes","logger","info","remote","ErrorCode","getForbidden","getUnauthorized","handleSpecialUnpublish","isUnpublishMissing","_","isNil","hasGroups","getDefaultPlugins","authenticate","_user","_password","cb","API_ERROR","BAD_USERNAME_PASSWORD","add_user","getConflict","allow_access","allow_publish","allow_unpublish","createSessionToken","tenHoursTime","expires","Date","now","defaultWebTokenOptions","sign","expiresIn","TIME_EXPIRATION_1H","verify","defaultApiTokenConf","legacy","defaultUserRateLimiting","windowMs","max","defaultSecurity","web","api","getSecurity","config","security","merge","getAuthenticatedMessage","buildUserBuffer","Buffer","isAESLegacy","jwt","getApiToken","auth","remoteUser","aesPassword","Promise","resolve","aesEncrypt","toString","jwtEncrypt","parseAuthTokenHeader","authorizationHeader","parts","split","scheme","token","parseBasicPayload","credentials","index","indexOf","slice","parseAESCredentials","secret","toUpperCase","TOKEN_BASIC","TOKEN_BEARER","tokenAsBuffer","expireReasons","verifyJWTPayload","payload","error","getCode","HTTP_STATUS","UNAUTHORIZED","message","isAuthHeaderValid","authorization","getMiddlewareCredentials","parsedCredentials","isString"],"mappings":"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","sourcesContent":["import buildDebug from 'debug';\nimport _ from 'lodash';\n\nimport { APITokenOptions, Callback, Config, IPluginAuth, JWTOptions, Package, RemoteUser, Security } from '@verdaccio/types';\n\nimport { AuthMiddlewarePayload, AuthTokenHeader, BasicPayload, CookieSessionToken, IAuthWebUI } from '../../types';\nimport { logger } from '../lib/logger';\nimport { API_ERROR, DEFAULT_MIN_LIMIT_PASSWORD, HTTP_STATUS, ROLES, TIME_EXPIRATION_1H, TOKEN_BASIC, TOKEN_BEARER } from './constants';\nimport { aesDecrypt, verifyPayload } from './crypto-utils';\nimport { ErrorCode, convertPayloadToBase64 } from './utils';\n\nconst debug = buildDebug('verdaccio');\n\nexport function validatePassword(\n  password: string, // pragma: allowlist secret\n  minLength: number = DEFAULT_MIN_LIMIT_PASSWORD\n): boolean {\n  return typeof password === 'string' && password.length >= minLength;\n}\n\n/**\n * Create a RemoteUser object\n * @return {Object} { name: xx, pluginGroups: [], real_groups: [] }\n */\nexport function createRemoteUser(name: string, pluginGroups: string[]): RemoteUser {\n  const isGroupValid: boolean = Array.isArray(pluginGroups);\n  const groups = Array.from(new Set((isGroupValid ? pluginGroups : []).concat([ROLES.$ALL, ROLES.$AUTH, ROLES.DEPRECATED_ALL, ROLES.DEPRECATED_AUTH, ROLES.ALL])));\n\n  return {\n    name,\n    groups,\n    real_groups: pluginGroups,\n  };\n}\n\n/**\n * Builds an anonymous remote user in case none is logged in.\n * @return {Object} { name: xx, groups: [], real_groups: [] }\n */\nexport function createAnonymousRemoteUser(): RemoteUser {\n  return {\n    name: undefined,\n    // groups without '$' are going to be deprecated eventually\n    groups: [ROLES.$ALL, ROLES.$ANONYMOUS, ROLES.DEPRECATED_ALL, ROLES.DEPRECATED_ANONYMOUS],\n    real_groups: [],\n  };\n}\n\nexport function allow_action(action: string): Function {\n  return function (user: RemoteUser, pkg: Package, callback: Callback): void {\n    debug('[auth/allow_action]: user: %o', user?.name);\n    const { name, groups } = user;\n    const groupAccess = pkg[action];\n    const hasPermission = groupAccess.some((group) => name === group || groups.includes(group));\n    debug('[auth/allow_action]: hasPermission? %o} for user: %o', hasPermission, user?.name);\n\n    if (hasPermission) {\n      logger.info({ remote: user.name }, `auth/allow_action: access granted to: @{user}`);\n      return callback(null, true);\n    }\n\n    if (name) {\n      callback(ErrorCode.getForbidden(`user ${name} is not allowed to ${action} package ${pkg.name}`));\n    } else {\n      callback(ErrorCode.getUnauthorized(`authorization required to ${action} package ${pkg.name}`));\n    }\n  };\n}\n\n/**\n *\n */\nexport function handleSpecialUnpublish(): any {\n  return function (user: RemoteUser, pkg: Package, callback: Callback): void {\n    const action = 'unpublish';\n    // verify whether the unpublish prop has been defined\n    const isUnpublishMissing: boolean = _.isNil(pkg[action]);\n    const hasGroups: boolean = isUnpublishMissing ? false : pkg[action].length > 0;\n    debug('fallback unpublish for @{name} has groups: %o for %o', hasGroups, user?.name);\n    if (isUnpublishMissing || hasGroups === false) {\n      return callback(null, undefined);\n    }\n    debug('allow_action for %o for %o has groups: %o for %o', action, user?.name, hasGroups, user);\n    return allow_action(action)(user, pkg, callback);\n  };\n}\n\nexport function getDefaultPlugins(logger: any): IPluginAuth<Config> {\n  return {\n    authenticate(_user: string, _password: string, cb: Callback): void {\n      // pragma: allowlist secret\n      cb(ErrorCode.getForbidden(API_ERROR.BAD_USERNAME_PASSWORD));\n    },\n\n    add_user(_user: string, _password: string, cb: Callback): void {\n      // pragma: allowlist secret\n      return cb(ErrorCode.getConflict(API_ERROR.BAD_USERNAME_PASSWORD));\n    },\n\n    // FIXME: allow_action and allow_publish should be in the @verdaccio/types\n    // @ts-ignore\n    allow_access: allow_action('access', logger),\n    // @ts-ignore\n    allow_publish: allow_action('publish', logger),\n    allow_unpublish: handleSpecialUnpublish(),\n  };\n}\n\nexport function createSessionToken(): CookieSessionToken {\n  const tenHoursTime = 10 * 60 * 60 * 1000;\n\n  return {\n    // npmjs.org sets 10h expire\n    expires: new Date(Date.now() + tenHoursTime),\n  };\n}\n\nconst defaultWebTokenOptions: JWTOptions = {\n  sign: {\n    // The expiration token for the website is 1 hour\n    expiresIn: TIME_EXPIRATION_1H,\n  },\n  verify: {},\n};\n\nconst defaultApiTokenConf: APITokenOptions = {\n  legacy: true,\n};\n\n// we limit max 1000 request per 15 minutes on user endpoints\nexport const defaultUserRateLimiting = {\n  windowMs: 15 * 60 * 1000, // 15 minutes\n  max: 1000,\n};\n\nexport const defaultSecurity: Security = {\n  web: defaultWebTokenOptions,\n  api: defaultApiTokenConf,\n};\n\nexport function getSecurity(config: Config): Security {\n  if (_.isNil(config.security) === false) {\n    return _.merge(defaultSecurity, config.security);\n  }\n\n  return defaultSecurity;\n}\n\nexport function getAuthenticatedMessage(user: string): string {\n  return `you are authenticated as '${user}'`;\n}\n\nexport function buildUserBuffer(name: string, password: string): Buffer {\n  return Buffer.from(`${name}:${password}`, 'utf8');\n}\n\nexport function isAESLegacy(security: Security): boolean {\n  const { legacy, jwt } = security.api;\n\n  return _.isNil(legacy) === false && _.isNil(jwt) && legacy === true;\n}\n\nexport async function getApiToken(auth: IAuthWebUI, config: Config, remoteUser: RemoteUser, aesPassword: string): Promise<string> {\n  const security: Security = getSecurity(config);\n  if (isAESLegacy(security)) {\n    // fallback all goes to AES encryption\n    return await new Promise((resolve): void => {\n      resolve(auth.aesEncrypt(buildUserBuffer(remoteUser.name as string, aesPassword)).toString('base64'));\n    });\n  }\n  // i am wiling to use here _.isNil but flow does not like it yet.\n  const { jwt } = security.api;\n\n  if (jwt && jwt.sign) {\n    return await auth.jwtEncrypt(remoteUser, jwt.sign);\n  }\n  return await new Promise((resolve): void => {\n    resolve(auth.aesEncrypt(buildUserBuffer(remoteUser.name as string, aesPassword)).toString('base64'));\n  });\n}\n\nexport function parseAuthTokenHeader(authorizationHeader: string): AuthTokenHeader {\n  const parts = authorizationHeader.split(' ');\n  const [scheme, token] = parts;\n\n  return { scheme, token };\n}\n\nexport function parseBasicPayload(credentials: string): BasicPayload {\n  const index = credentials.indexOf(':');\n  if (index < 0) {\n    return;\n  }\n\n  const user: string = credentials.slice(0, index);\n  const password: string = credentials.slice(index + 1);\n\n  return { user, password };\n}\n\nexport function parseAESCredentials(authorizationHeader: string, secret: string) {\n  const { scheme, token } = parseAuthTokenHeader(authorizationHeader);\n\n  // basic is deprecated and should not be enforced\n  if (scheme.toUpperCase() === TOKEN_BASIC.toUpperCase()) {\n    const credentials = convertPayloadToBase64(token).toString();\n\n    return credentials;\n  } else if (scheme.toUpperCase() === TOKEN_BEARER.toUpperCase()) {\n    const tokenAsBuffer = convertPayloadToBase64(token);\n    const credentials = aesDecrypt(tokenAsBuffer, secret).toString('utf8');\n\n    return credentials;\n  }\n}\n\nexport const expireReasons: string[] = ['JsonWebTokenError', 'TokenExpiredError'];\n\nexport function verifyJWTPayload(token: string, secret: string): RemoteUser {\n  try {\n    const payload: RemoteUser = verifyPayload(token, secret);\n\n    return payload;\n  } catch (error) {\n    // #168 this check should be removed as soon AES encrypt is removed.\n    if (expireReasons.includes(error.name)) {\n      // it might be possible the jwt configuration is enabled and\n      // old tokens fails still remains in usage, thus\n      // we return an anonymous user to force log in.\n      return createAnonymousRemoteUser();\n    }\n    throw ErrorCode.getCode(HTTP_STATUS.UNAUTHORIZED, error.message);\n  }\n}\n\nexport function isAuthHeaderValid(authorization: string): boolean {\n  return authorization.split(' ').length === 2;\n}\n\nexport function getMiddlewareCredentials(security: Security, secret: string, authorizationHeader: string): AuthMiddlewarePayload {\n  if (isAESLegacy(security)) {\n    const credentials = parseAESCredentials(authorizationHeader, secret);\n    if (!credentials) {\n      return;\n    }\n\n    const parsedCredentials = parseBasicPayload(credentials);\n    if (!parsedCredentials) {\n      return;\n    }\n\n    return parsedCredentials;\n  }\n  const { scheme, token } = parseAuthTokenHeader(authorizationHeader);\n\n  if (_.isString(token) && scheme.toUpperCase() === TOKEN_BEARER.toUpperCase()) {\n    return verifyJWTPayload(token, secret);\n  }\n}\n"]}
package/build/lib/auth.js CHANGED
@@ -516,7 +516,7 @@ class Auth {
516
516
  groups
517
517
  } = user;
518
518
  const realGroupsValidated = _lodash.default.isNil(real_groups) ? [] : real_groups;
519
- const groupedGroups = _lodash.default.isNil(groups) ? real_groups : groups.concat(realGroupsValidated);
519
+ const groupedGroups = _lodash.default.isNil(groups) ? real_groups : Array.from(new Set([...groups.concat(realGroupsValidated)]));
520
520
  const payload = {
521
521
  real_groups: realGroupsValidated,
522
522
  name,
@@ -538,4 +538,4 @@ class Auth {
538
538
 
539
539
  var _default = Auth;
540
540
  exports.default = _default;
541
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/lib/auth.ts"],"names":["debug","Auth","constructor","config","logger","secret","plugins","_loadPlugin","_applyDefaultPlugins","pluginOptions","auth","plugin","authenticate","allow_access","allow_publish","push","changePassword","username","password","newPassword","cb","validPlugins","_","filter","isFunction","isEmpty","ErrorCode","getInternalError","SUPPORT_ERRORS","PLUGIN_MISSING_INTERFACE","isNil","err","profile","error","info","slice","self","next","shift","groups","length","isString","TypeError","isGroupValid","isArray","API_ERROR","BAD_FORMAT_USER_GROUP","add_user","user","method","warn","ok","message","packageName","packageVersion","callback","pkgAllowAcces","name","version","pkg","Object","assign","packages","allow_unpublish","arguments","isError","apiJWTmiddleware","helpers","createAnonymousRemoteUser","createRemoteUser","req","res","_next","pause","resume","remote_user","_isRemoteUserValid","authorization","headers","getBadRequest","BAD_AUTH_HEADER","security","_handleAESMiddleware","_handleJWTAPIMiddleware","scheme","token","toUpperCase","TOKEN_BASIC","credentials","toString","getForbidden","BAD_USERNAME_PASSWORD","isUndefined","webUIJWTmiddleware","status","statusCode","send","replace","TOKEN_BEARER","jwtEncrypt","signOptions","real_groups","realGroupsValidated","groupedGroups","concat","payload","aesEncrypt","buf"],"mappings":"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","sourcesContent":["import buildDebug from 'debug';\nimport { NextFunction } from 'express';\nimport _ from 'lodash';\n\nimport { VerdaccioError } from '@verdaccio/commons-api';\nimport { AllowAccess, AuthPluginPackage, Callback, Config, IPluginAuth, JWTSignOptions, Logger, PackageAccess, RemoteUser, Security } from '@verdaccio/types';\n\nimport { $RequestExtend, $ResponseExtend, AESPayload, IAuth } from '../../types';\nimport loadPlugin from '../lib/plugin-loader';\nimport {\n  createAnonymousRemoteUser,\n  createRemoteUser,\n  getDefaultPlugins,\n  getMiddlewareCredentials,\n  getSecurity,\n  isAESLegacy,\n  isAuthHeaderValid,\n  parseAuthTokenHeader,\n  parseBasicPayload,\n  verifyJWTPayload,\n} from './auth-utils';\nimport { getMatchedPackagesSpec } from './config-utils';\nimport { API_ERROR, SUPPORT_ERRORS, TOKEN_BASIC, TOKEN_BEARER } from './constants';\nimport { aesEncrypt, signPayload } from './crypto-utils';\nimport { logger } from './logger';\nimport { ErrorCode, convertPayloadToBase64 } from './utils';\n\nconst debug = buildDebug('verdaccio:auth');\n\nclass Auth implements IAuth {\n  public config: Config;\n  public logger: Logger;\n  public secret: string; // pragma: allowlist secret\n  public plugins: IPluginAuth<Config>[];\n\n  public constructor(config: Config) {\n    this.config = config;\n    this.logger = logger;\n    this.secret = config.secret;\n    this.plugins = this._loadPlugin(config);\n    this._applyDefaultPlugins();\n  }\n\n  private _loadPlugin(config: Config): IPluginAuth<Config>[] {\n    const pluginOptions = {\n      config,\n      logger: this.logger,\n    };\n\n    return loadPlugin<IPluginAuth<Config>>(config, config.auth, pluginOptions, (plugin: IPluginAuth<Config>): boolean => {\n      const { authenticate, allow_access, allow_publish } = plugin;\n      // @ts-ignore\n      return authenticate || allow_access || allow_publish;\n    });\n  }\n\n  private _applyDefaultPlugins(): void {\n    this.plugins.push(getDefaultPlugins(this.logger));\n  }\n\n  public changePassword(\n    username: string,\n    password: string, // pragma: allowlist secret\n    newPassword: string, // pragma: allowlist secret\n    cb: Callback\n  ): void {\n    const validPlugins = _.filter(this.plugins, (plugin) => _.isFunction(plugin.changePassword));\n\n    if (_.isEmpty(validPlugins)) {\n      return cb(ErrorCode.getInternalError(SUPPORT_ERRORS.PLUGIN_MISSING_INTERFACE));\n    }\n\n    for (const plugin of validPlugins) {\n      if (_.isNil(plugin) || _.isFunction(plugin.changePassword) === false) {\n        debug('auth plugin does not implement changePassword, trying next one');\n        continue;\n      } else {\n        debug('updating password for %o', username);\n        plugin.changePassword!(username, password, newPassword, (err, profile): void => {\n          if (err) {\n            this.logger.error(\n              { username, err },\n              `An error has been produced\n            updating the password for @{username}. Error: @{err.message}`\n            );\n            return cb(err);\n          }\n          this.logger.info({ username }, 'updated password for @{username} was successful');\n          return cb(null, profile);\n        });\n      }\n    }\n  }\n\n  public authenticate(username: string, password: string, cb: Callback): void {\n    const plugins = this.plugins.slice(0);\n    const self = this;\n    (function next(): void {\n      const plugin = plugins.shift() as IPluginAuth<Config>;\n      if (_.isFunction(plugin.authenticate) === false) {\n        return next();\n      }\n      debug('authenticating %o', username);\n      plugin.authenticate(username, password, function (err, groups): void {\n        if (err) {\n          self.logger.error({ username, err }, 'authenticating for user @{username} failed. Error: @{err.message}');\n          return cb(err);\n        }\n\n        // Expect: SKIP if groups is falsey and not an array\n        //         with at least one item (truthy length)\n        // Expect: CONTINUE otherwise (will error if groups is not\n        //         an array, but this is current behavior)\n        // Caveat: STRING (if valid) will pass successfully\n        //         bug give unexpected results\n        // Info: Cannot use `== false to check falsey values`\n        if (!!groups && groups.length !== 0) {\n          // TODO: create a better understanding of expectations\n          if (_.isString(groups)) {\n            throw new TypeError('plugin group error: invalid type for function');\n          }\n          const isGroupValid: boolean = _.isArray(groups);\n          if (!isGroupValid) {\n            throw new TypeError(API_ERROR.BAD_FORMAT_USER_GROUP);\n          }\n          debug('authentication for user %o was successfully. Groups: %o', username, groups);\n          return cb(err, createRemoteUser(username, groups));\n        }\n        next();\n      });\n    })();\n  }\n\n  public add_user(user: string, password: string, cb: Callback): void {\n    const self = this;\n    const plugins = this.plugins.slice(0);\n    debug('add user %o', user);\n    (function next(): void {\n      const plugin = plugins.shift() as IPluginAuth<Config>;\n      let method = 'adduser';\n      if (_.isFunction(plugin[method]) === false) {\n        method = 'add_user';\n        self.logger.warn('the plugin method add_user in the auth plugin is deprecated and will be removed in next major release, notify to the plugin author');\n      }\n\n      if (_.isFunction(plugin[method]) === false) {\n        next();\n      } else {\n        // p.add_user() execution\n        plugin[method](user, password, function (err, ok): void {\n          if (err) {\n            self.logger.error({ user, err: err.message }, 'the user @{user} could not being added. Error: @{err}');\n            return cb(err);\n          }\n          if (ok) {\n            self.logger.info({ user }, 'the user @{user} has been added');\n            return self.authenticate(user, password, cb);\n          }\n          next();\n        });\n      }\n    })();\n  }\n\n  /**\n   * Allow user to access a package.\n   */\n  public allow_access({ packageName, packageVersion }: AuthPluginPackage, user: RemoteUser, callback: Callback): void {\n    const plugins = this.plugins.slice(0);\n    const self = this;\n    const pkgAllowAcces: AllowAccess = { name: packageName, version: packageVersion };\n    const pkg = Object.assign({}, pkgAllowAcces, getMatchedPackagesSpec(packageName, this.config.packages)) as AllowAccess & PackageAccess;\n    debug('allow access for %o', packageName);\n\n    (function next(): void {\n      const plugin: IPluginAuth<Config> = plugins.shift() as IPluginAuth<Config>;\n\n      if (_.isNil(plugin) || _.isFunction(plugin.allow_access) === false) {\n        return next();\n      }\n\n      plugin.allow_access!(user, pkg, function (err, ok: boolean): void {\n        if (err) {\n          self.logger.error({ packageName, err }, 'forbidden access for @{packageName}. Error: @{err.message}');\n          return callback(err);\n        }\n\n        if (ok) {\n          self.logger.info({ packageName }, 'allowed access for @{packageName}');\n          return callback(null, ok);\n        }\n\n        next(); // cb(null, false) causes next plugin to roll\n      });\n    })();\n  }\n\n  public allow_unpublish({ packageName, packageVersion }: AuthPluginPackage, user: RemoteUser, callback: Callback): void {\n    const pkg = Object.assign({ name: packageName, version: packageVersion }, getMatchedPackagesSpec(packageName, this.config.packages));\n    debug('allow unpublish for %o', packageName);\n    for (const plugin of this.plugins) {\n      if (_.isNil(plugin) || _.isFunction(plugin.allow_unpublish) === false) {\n        debug('allow unpublish for %o plugin does not implement allow_unpublish', packageName);\n        continue;\n      } else {\n        plugin.allow_unpublish!(user, pkg, (err, ok: boolean): void => {\n          if (err) {\n            this.logger.error({ packageName, user: user?.name }, '@{user} forbidden publish for @{packageName}, it will fallback on unpublish permissions');\n            return callback(err);\n          }\n\n          if (_.isNil(ok) === true) {\n            debug('we bypass unpublish for %o, publish will handle the access', packageName);\n            // @ts-ignore\n            // eslint-disable-next-line\n            return this.allow_publish(...arguments);\n          }\n\n          if (ok) {\n            this.logger.info({ packageName, user: user?.name }, '@{user} allowed unpublish for @{packageName}');\n            return callback(null, ok);\n          }\n        });\n      }\n    }\n  }\n\n  /**\n   * Allow user to publish a package.\n   */\n  public allow_publish({ packageName, packageVersion }: AuthPluginPackage, user: RemoteUser, callback: Callback): void {\n    const plugins = this.plugins.slice(0);\n    const self = this;\n    const pkg = Object.assign({ name: packageName, version: packageVersion }, getMatchedPackagesSpec(packageName, this.config.packages));\n    debug('allow publish for %o init | plugins: %o', packageName, plugins);\n    (function next(): void {\n      const plugin = plugins.shift();\n\n      if (_.isNil(plugin) || _.isFunction(plugin.allow_publish) === false) {\n        debug('allow publish for %o plugin does not implement allow_publish', packageName);\n        return next();\n      }\n\n      // @ts-ignore\n      plugin.allow_publish(user, pkg, (err: VerdaccioError, ok: boolean): void => {\n        if (_.isNil(err) === false && _.isError(err)) {\n          self.logger.error({ packageName, user: user?.name }, '@{user} is forbidden publish for @{packageName}');\n          return callback(err);\n        }\n\n        if (ok) {\n          self.logger.info({ packageName, user: user?.name }, '@{user} is allowed publish for @{packageName}');\n          return callback(null, ok);\n        }\n        debug('allow publish skip validation for %o', packageName);\n        next(); // cb(null, false) causes next plugin to roll\n      });\n    })();\n  }\n\n  public apiJWTmiddleware(): Function {\n    const plugins = this.plugins.slice(0);\n    const helpers = { createAnonymousRemoteUser, createRemoteUser };\n    for (const plugin of plugins) {\n      if (plugin.apiJWTmiddleware) {\n        return plugin.apiJWTmiddleware(helpers);\n      }\n    }\n\n    return (req: $RequestExtend, res: $ResponseExtend, _next: NextFunction): void => {\n      req.pause();\n\n      const next = function (err: VerdaccioError | void): void {\n        req.resume();\n        // uncomment this to reject users with bad auth headers\n        // return _next.apply(null, arguments)\n        // swallow error, user remains unauthorized\n        // set remoteUserError to indicate that user was attempting authentication\n        if (err) {\n          req.remote_user.error = err.message;\n        }\n        return _next();\n      };\n\n      if (this._isRemoteUserValid(req.remote_user)) {\n        return next();\n      }\n\n      // in case auth header does not exist we return anonymous function\n      req.remote_user = createAnonymousRemoteUser();\n\n      const { authorization } = req.headers;\n      if (_.isNil(authorization)) {\n        return next();\n      }\n\n      if (!isAuthHeaderValid(authorization)) {\n        debug('api middleware auth heather is not valid');\n        return next(ErrorCode.getBadRequest(API_ERROR.BAD_AUTH_HEADER));\n      }\n\n      const security: Security = getSecurity(this.config);\n      const { secret } = this.config;\n\n      if (isAESLegacy(security)) {\n        debug('api middleware using legacy auth token');\n        this._handleAESMiddleware(req, security, secret, authorization, next);\n      } else {\n        debug('api middleware using JWT auth token');\n        this._handleJWTAPIMiddleware(req, security, secret, authorization, next);\n      }\n    };\n  }\n\n  private _handleJWTAPIMiddleware(req: $RequestExtend, security: Security, secret: string, authorization: string, next: Function): void {\n    const { scheme, token } = parseAuthTokenHeader(authorization);\n    if (scheme.toUpperCase() === TOKEN_BASIC.toUpperCase()) {\n      // this should happen when client tries to login with an existing user\n      const credentials = convertPayloadToBase64(token).toString();\n      const { user, password } = parseBasicPayload(credentials) as AESPayload;\n      this.authenticate(user, password, (err, user): void => {\n        if (!err) {\n          req.remote_user = user;\n          next();\n        } else {\n          req.remote_user = createAnonymousRemoteUser();\n          next(err);\n        }\n      });\n    } else {\n      // jwt handler\n      const credentials: any = getMiddlewareCredentials(security, secret, authorization);\n      if (credentials) {\n        // if the signature is valid we rely on it\n        req.remote_user = credentials;\n        next();\n      } else {\n        // with JWT throw 401\n        next(ErrorCode.getForbidden(API_ERROR.BAD_USERNAME_PASSWORD));\n      }\n    }\n  }\n\n  private _handleAESMiddleware(req: $RequestExtend, security: Security, secret: string, authorization: string, next: Function): void {\n    const credentials: any = getMiddlewareCredentials(security, secret, authorization);\n    if (credentials) {\n      const { user, password } = credentials;\n      this.authenticate(user, password, (err, user): void => {\n        if (!err) {\n          req.remote_user = user;\n          next();\n        } else {\n          req.remote_user = createAnonymousRemoteUser();\n          next(err);\n        }\n      });\n    } else {\n      // we force npm client to ask again with basic authentication\n      return next(ErrorCode.getBadRequest(API_ERROR.BAD_AUTH_HEADER));\n    }\n  }\n\n  private _isRemoteUserValid(remote_user: RemoteUser): boolean {\n    return _.isUndefined(remote_user) === false && _.isUndefined(remote_user.name) === false;\n  }\n\n  /**\n   * JWT middleware for WebUI\n   */\n  public webUIJWTmiddleware(): Function {\n    return (req: $RequestExtend, res: $ResponseExtend, _next: NextFunction): void => {\n      if (this._isRemoteUserValid(req.remote_user)) {\n        return _next();\n      }\n\n      req.pause();\n      const next = (err: VerdaccioError | void): void => {\n        req.resume();\n        if (err) {\n          // req.remote_user.error = err.message;\n          res.status(err.statusCode).send(err.message);\n        }\n\n        return _next();\n      };\n\n      const { authorization } = req.headers;\n      if (_.isNil(authorization)) {\n        return next();\n      }\n\n      if (!isAuthHeaderValid(authorization)) {\n        return next(ErrorCode.getBadRequest(API_ERROR.BAD_AUTH_HEADER));\n      }\n\n      const token = (authorization || '').replace(`${TOKEN_BEARER} `, '');\n      if (!token) {\n        return next();\n      }\n\n      let credentials;\n      try {\n        credentials = verifyJWTPayload(token, this.config.secret);\n      } catch (err) {\n        // FIXME: intended behaviour, do we want it?\n      }\n\n      if (this._isRemoteUserValid(credentials)) {\n        const { name, groups } = credentials;\n        // $FlowFixMe\n        req.remote_user = createRemoteUser(name, groups);\n      } else {\n        req.remote_user = createAnonymousRemoteUser();\n      }\n\n      next();\n    };\n  }\n\n  public async jwtEncrypt(user: RemoteUser, signOptions: JWTSignOptions): Promise<string> {\n    const { real_groups, name, groups } = user;\n    const realGroupsValidated = _.isNil(real_groups) ? [] : real_groups;\n    const groupedGroups = _.isNil(groups) ? real_groups : groups.concat(realGroupsValidated);\n    const payload: RemoteUser = {\n      real_groups: realGroupsValidated,\n      name,\n      groups: groupedGroups,\n    };\n\n    const token: string = await signPayload(payload, this.secret, signOptions);\n\n    return token;\n  }\n\n  /**\n   * Encrypt a string.\n   */\n  public aesEncrypt(buf: Buffer): Buffer {\n    return aesEncrypt(buf, this.secret);\n  }\n}\n\nexport default Auth;\n"]}
541
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/lib/auth.ts"],"names":["debug","Auth","constructor","config","logger","secret","plugins","_loadPlugin","_applyDefaultPlugins","pluginOptions","auth","plugin","authenticate","allow_access","allow_publish","push","changePassword","username","password","newPassword","cb","validPlugins","_","filter","isFunction","isEmpty","ErrorCode","getInternalError","SUPPORT_ERRORS","PLUGIN_MISSING_INTERFACE","isNil","err","profile","error","info","slice","self","next","shift","groups","length","isString","TypeError","isGroupValid","isArray","API_ERROR","BAD_FORMAT_USER_GROUP","add_user","user","method","warn","ok","message","packageName","packageVersion","callback","pkgAllowAcces","name","version","pkg","Object","assign","packages","allow_unpublish","arguments","isError","apiJWTmiddleware","helpers","createAnonymousRemoteUser","createRemoteUser","req","res","_next","pause","resume","remote_user","_isRemoteUserValid","authorization","headers","getBadRequest","BAD_AUTH_HEADER","security","_handleAESMiddleware","_handleJWTAPIMiddleware","scheme","token","toUpperCase","TOKEN_BASIC","credentials","toString","getForbidden","BAD_USERNAME_PASSWORD","isUndefined","webUIJWTmiddleware","status","statusCode","send","replace","TOKEN_BEARER","jwtEncrypt","signOptions","real_groups","realGroupsValidated","groupedGroups","Array","from","Set","concat","payload","aesEncrypt","buf"],"mappings":"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","sourcesContent":["import buildDebug from 'debug';\nimport { NextFunction } from 'express';\nimport _ from 'lodash';\n\nimport { VerdaccioError } from '@verdaccio/commons-api';\nimport { AllowAccess, AuthPluginPackage, Callback, Config, IPluginAuth, JWTSignOptions, Logger, PackageAccess, RemoteUser, Security } from '@verdaccio/types';\n\nimport { $RequestExtend, $ResponseExtend, AESPayload, IAuth } from '../../types';\nimport loadPlugin from '../lib/plugin-loader';\nimport {\n  createAnonymousRemoteUser,\n  createRemoteUser,\n  getDefaultPlugins,\n  getMiddlewareCredentials,\n  getSecurity,\n  isAESLegacy,\n  isAuthHeaderValid,\n  parseAuthTokenHeader,\n  parseBasicPayload,\n  verifyJWTPayload,\n} from './auth-utils';\nimport { getMatchedPackagesSpec } from './config-utils';\nimport { API_ERROR, SUPPORT_ERRORS, TOKEN_BASIC, TOKEN_BEARER } from './constants';\nimport { aesEncrypt, signPayload } from './crypto-utils';\nimport { logger } from './logger';\nimport { ErrorCode, convertPayloadToBase64 } from './utils';\n\nconst debug = buildDebug('verdaccio:auth');\n\nclass Auth implements IAuth {\n  public config: Config;\n  public logger: Logger;\n  public secret: string; // pragma: allowlist secret\n  public plugins: IPluginAuth<Config>[];\n\n  public constructor(config: Config) {\n    this.config = config;\n    this.logger = logger;\n    this.secret = config.secret;\n    this.plugins = this._loadPlugin(config);\n    this._applyDefaultPlugins();\n  }\n\n  private _loadPlugin(config: Config): IPluginAuth<Config>[] {\n    const pluginOptions = {\n      config,\n      logger: this.logger,\n    };\n\n    return loadPlugin<IPluginAuth<Config>>(config, config.auth, pluginOptions, (plugin: IPluginAuth<Config>): boolean => {\n      const { authenticate, allow_access, allow_publish } = plugin;\n      // @ts-ignore\n      return authenticate || allow_access || allow_publish;\n    });\n  }\n\n  private _applyDefaultPlugins(): void {\n    this.plugins.push(getDefaultPlugins(this.logger));\n  }\n\n  public changePassword(\n    username: string,\n    password: string, // pragma: allowlist secret\n    newPassword: string, // pragma: allowlist secret\n    cb: Callback\n  ): void {\n    const validPlugins = _.filter(this.plugins, (plugin) => _.isFunction(plugin.changePassword));\n\n    if (_.isEmpty(validPlugins)) {\n      return cb(ErrorCode.getInternalError(SUPPORT_ERRORS.PLUGIN_MISSING_INTERFACE));\n    }\n\n    for (const plugin of validPlugins) {\n      if (_.isNil(plugin) || _.isFunction(plugin.changePassword) === false) {\n        debug('auth plugin does not implement changePassword, trying next one');\n        continue;\n      } else {\n        debug('updating password for %o', username);\n        plugin.changePassword!(username, password, newPassword, (err, profile): void => {\n          if (err) {\n            this.logger.error(\n              { username, err },\n              `An error has been produced\n            updating the password for @{username}. Error: @{err.message}`\n            );\n            return cb(err);\n          }\n          this.logger.info({ username }, 'updated password for @{username} was successful');\n          return cb(null, profile);\n        });\n      }\n    }\n  }\n\n  public authenticate(username: string, password: string, cb: Callback): void {\n    const plugins = this.plugins.slice(0);\n    const self = this;\n    (function next(): void {\n      const plugin = plugins.shift() as IPluginAuth<Config>;\n      if (_.isFunction(plugin.authenticate) === false) {\n        return next();\n      }\n      debug('authenticating %o', username);\n      plugin.authenticate(username, password, function (err, groups): void {\n        if (err) {\n          self.logger.error({ username, err }, 'authenticating for user @{username} failed. Error: @{err.message}');\n          return cb(err);\n        }\n\n        // Expect: SKIP if groups is falsey and not an array\n        //         with at least one item (truthy length)\n        // Expect: CONTINUE otherwise (will error if groups is not\n        //         an array, but this is current behavior)\n        // Caveat: STRING (if valid) will pass successfully\n        //         bug give unexpected results\n        // Info: Cannot use `== false to check falsey values`\n        if (!!groups && groups.length !== 0) {\n          // TODO: create a better understanding of expectations\n          if (_.isString(groups)) {\n            throw new TypeError('plugin group error: invalid type for function');\n          }\n          const isGroupValid: boolean = _.isArray(groups);\n          if (!isGroupValid) {\n            throw new TypeError(API_ERROR.BAD_FORMAT_USER_GROUP);\n          }\n          debug('authentication for user %o was successfully. Groups: %o', username, groups);\n          return cb(err, createRemoteUser(username, groups));\n        }\n        next();\n      });\n    })();\n  }\n\n  public add_user(user: string, password: string, cb: Callback): void {\n    const self = this;\n    const plugins = this.plugins.slice(0);\n    debug('add user %o', user);\n    (function next(): void {\n      const plugin = plugins.shift() as IPluginAuth<Config>;\n      let method = 'adduser';\n      if (_.isFunction(plugin[method]) === false) {\n        method = 'add_user';\n        self.logger.warn('the plugin method add_user in the auth plugin is deprecated and will be removed in next major release, notify to the plugin author');\n      }\n\n      if (_.isFunction(plugin[method]) === false) {\n        next();\n      } else {\n        // p.add_user() execution\n        plugin[method](user, password, function (err, ok): void {\n          if (err) {\n            self.logger.error({ user, err: err.message }, 'the user @{user} could not being added. Error: @{err}');\n            return cb(err);\n          }\n          if (ok) {\n            self.logger.info({ user }, 'the user @{user} has been added');\n            return self.authenticate(user, password, cb);\n          }\n          next();\n        });\n      }\n    })();\n  }\n\n  /**\n   * Allow user to access a package.\n   */\n  public allow_access({ packageName, packageVersion }: AuthPluginPackage, user: RemoteUser, callback: Callback): void {\n    const plugins = this.plugins.slice(0);\n    const self = this;\n    const pkgAllowAcces: AllowAccess = { name: packageName, version: packageVersion };\n    const pkg = Object.assign({}, pkgAllowAcces, getMatchedPackagesSpec(packageName, this.config.packages)) as AllowAccess & PackageAccess;\n    debug('allow access for %o', packageName);\n\n    (function next(): void {\n      const plugin: IPluginAuth<Config> = plugins.shift() as IPluginAuth<Config>;\n\n      if (_.isNil(plugin) || _.isFunction(plugin.allow_access) === false) {\n        return next();\n      }\n\n      plugin.allow_access!(user, pkg, function (err, ok: boolean): void {\n        if (err) {\n          self.logger.error({ packageName, err }, 'forbidden access for @{packageName}. Error: @{err.message}');\n          return callback(err);\n        }\n\n        if (ok) {\n          self.logger.info({ packageName }, 'allowed access for @{packageName}');\n          return callback(null, ok);\n        }\n\n        next(); // cb(null, false) causes next plugin to roll\n      });\n    })();\n  }\n\n  public allow_unpublish({ packageName, packageVersion }: AuthPluginPackage, user: RemoteUser, callback: Callback): void {\n    const pkg = Object.assign({ name: packageName, version: packageVersion }, getMatchedPackagesSpec(packageName, this.config.packages));\n    debug('allow unpublish for %o', packageName);\n    for (const plugin of this.plugins) {\n      if (_.isNil(plugin) || _.isFunction(plugin.allow_unpublish) === false) {\n        debug('allow unpublish for %o plugin does not implement allow_unpublish', packageName);\n        continue;\n      } else {\n        plugin.allow_unpublish!(user, pkg, (err, ok: boolean): void => {\n          if (err) {\n            this.logger.error({ packageName, user: user?.name }, '@{user} forbidden publish for @{packageName}, it will fallback on unpublish permissions');\n            return callback(err);\n          }\n\n          if (_.isNil(ok) === true) {\n            debug('we bypass unpublish for %o, publish will handle the access', packageName);\n            // @ts-ignore\n            // eslint-disable-next-line\n            return this.allow_publish(...arguments);\n          }\n\n          if (ok) {\n            this.logger.info({ packageName, user: user?.name }, '@{user} allowed unpublish for @{packageName}');\n            return callback(null, ok);\n          }\n        });\n      }\n    }\n  }\n\n  /**\n   * Allow user to publish a package.\n   */\n  public allow_publish({ packageName, packageVersion }: AuthPluginPackage, user: RemoteUser, callback: Callback): void {\n    const plugins = this.plugins.slice(0);\n    const self = this;\n    const pkg = Object.assign({ name: packageName, version: packageVersion }, getMatchedPackagesSpec(packageName, this.config.packages));\n    debug('allow publish for %o init | plugins: %o', packageName, plugins);\n    (function next(): void {\n      const plugin = plugins.shift();\n\n      if (_.isNil(plugin) || _.isFunction(plugin.allow_publish) === false) {\n        debug('allow publish for %o plugin does not implement allow_publish', packageName);\n        return next();\n      }\n\n      // @ts-ignore\n      plugin.allow_publish(user, pkg, (err: VerdaccioError, ok: boolean): void => {\n        if (_.isNil(err) === false && _.isError(err)) {\n          self.logger.error({ packageName, user: user?.name }, '@{user} is forbidden publish for @{packageName}');\n          return callback(err);\n        }\n\n        if (ok) {\n          self.logger.info({ packageName, user: user?.name }, '@{user} is allowed publish for @{packageName}');\n          return callback(null, ok);\n        }\n        debug('allow publish skip validation for %o', packageName);\n        next(); // cb(null, false) causes next plugin to roll\n      });\n    })();\n  }\n\n  public apiJWTmiddleware(): Function {\n    const plugins = this.plugins.slice(0);\n    const helpers = { createAnonymousRemoteUser, createRemoteUser };\n    for (const plugin of plugins) {\n      if (plugin.apiJWTmiddleware) {\n        return plugin.apiJWTmiddleware(helpers);\n      }\n    }\n\n    return (req: $RequestExtend, res: $ResponseExtend, _next: NextFunction): void => {\n      req.pause();\n\n      const next = function (err: VerdaccioError | void): void {\n        req.resume();\n        // uncomment this to reject users with bad auth headers\n        // return _next.apply(null, arguments)\n        // swallow error, user remains unauthorized\n        // set remoteUserError to indicate that user was attempting authentication\n        if (err) {\n          req.remote_user.error = err.message;\n        }\n        return _next();\n      };\n\n      if (this._isRemoteUserValid(req.remote_user)) {\n        return next();\n      }\n\n      // in case auth header does not exist we return anonymous function\n      req.remote_user = createAnonymousRemoteUser();\n\n      const { authorization } = req.headers;\n      if (_.isNil(authorization)) {\n        return next();\n      }\n\n      if (!isAuthHeaderValid(authorization)) {\n        debug('api middleware auth heather is not valid');\n        return next(ErrorCode.getBadRequest(API_ERROR.BAD_AUTH_HEADER));\n      }\n\n      const security: Security = getSecurity(this.config);\n      const { secret } = this.config;\n\n      if (isAESLegacy(security)) {\n        debug('api middleware using legacy auth token');\n        this._handleAESMiddleware(req, security, secret, authorization, next);\n      } else {\n        debug('api middleware using JWT auth token');\n        this._handleJWTAPIMiddleware(req, security, secret, authorization, next);\n      }\n    };\n  }\n\n  private _handleJWTAPIMiddleware(req: $RequestExtend, security: Security, secret: string, authorization: string, next: Function): void {\n    const { scheme, token } = parseAuthTokenHeader(authorization);\n    if (scheme.toUpperCase() === TOKEN_BASIC.toUpperCase()) {\n      // this should happen when client tries to login with an existing user\n      const credentials = convertPayloadToBase64(token).toString();\n      const { user, password } = parseBasicPayload(credentials) as AESPayload;\n      this.authenticate(user, password, (err, user): void => {\n        if (!err) {\n          req.remote_user = user;\n          next();\n        } else {\n          req.remote_user = createAnonymousRemoteUser();\n          next(err);\n        }\n      });\n    } else {\n      // jwt handler\n      const credentials: any = getMiddlewareCredentials(security, secret, authorization);\n      if (credentials) {\n        // if the signature is valid we rely on it\n        req.remote_user = credentials;\n        next();\n      } else {\n        // with JWT throw 401\n        next(ErrorCode.getForbidden(API_ERROR.BAD_USERNAME_PASSWORD));\n      }\n    }\n  }\n\n  private _handleAESMiddleware(req: $RequestExtend, security: Security, secret: string, authorization: string, next: Function): void {\n    const credentials: any = getMiddlewareCredentials(security, secret, authorization);\n    if (credentials) {\n      const { user, password } = credentials;\n      this.authenticate(user, password, (err, user): void => {\n        if (!err) {\n          req.remote_user = user;\n          next();\n        } else {\n          req.remote_user = createAnonymousRemoteUser();\n          next(err);\n        }\n      });\n    } else {\n      // we force npm client to ask again with basic authentication\n      return next(ErrorCode.getBadRequest(API_ERROR.BAD_AUTH_HEADER));\n    }\n  }\n\n  private _isRemoteUserValid(remote_user: RemoteUser): boolean {\n    return _.isUndefined(remote_user) === false && _.isUndefined(remote_user.name) === false;\n  }\n\n  /**\n   * JWT middleware for WebUI\n   */\n  public webUIJWTmiddleware(): Function {\n    return (req: $RequestExtend, res: $ResponseExtend, _next: NextFunction): void => {\n      if (this._isRemoteUserValid(req.remote_user)) {\n        return _next();\n      }\n\n      req.pause();\n      const next = (err: VerdaccioError | void): void => {\n        req.resume();\n        if (err) {\n          // req.remote_user.error = err.message;\n          res.status(err.statusCode).send(err.message);\n        }\n\n        return _next();\n      };\n\n      const { authorization } = req.headers;\n      if (_.isNil(authorization)) {\n        return next();\n      }\n\n      if (!isAuthHeaderValid(authorization)) {\n        return next(ErrorCode.getBadRequest(API_ERROR.BAD_AUTH_HEADER));\n      }\n\n      const token = (authorization || '').replace(`${TOKEN_BEARER} `, '');\n      if (!token) {\n        return next();\n      }\n\n      let credentials;\n      try {\n        credentials = verifyJWTPayload(token, this.config.secret);\n      } catch (err) {\n        // FIXME: intended behaviour, do we want it?\n      }\n\n      if (this._isRemoteUserValid(credentials)) {\n        const { name, groups } = credentials;\n        // $FlowFixMe\n        req.remote_user = createRemoteUser(name, groups);\n      } else {\n        req.remote_user = createAnonymousRemoteUser();\n      }\n\n      next();\n    };\n  }\n\n  public async jwtEncrypt(user: RemoteUser, signOptions: JWTSignOptions): Promise<string> {\n    const { real_groups, name, groups } = user;\n    const realGroupsValidated = _.isNil(real_groups) ? [] : real_groups;\n    const groupedGroups = _.isNil(groups) ? real_groups : Array.from(new Set([...groups.concat(realGroupsValidated)]));\n    const payload: RemoteUser = {\n      real_groups: realGroupsValidated,\n      name,\n      groups: groupedGroups,\n    };\n\n    const token: string = await signPayload(payload, this.secret, signOptions);\n\n    return token;\n  }\n\n  /**\n   * Encrypt a string.\n   */\n  public aesEncrypt(buf: Buffer): Buffer {\n    return aesEncrypt(buf, this.secret);\n  }\n}\n\nexport default Auth;\n"]}
package/conf/default.yaml CHANGED
@@ -1,16 +1,20 @@
1
1
  #
2
- # This is the default config file. It allows all users to do anything,
3
- # so don't use it on production systems.
2
+ # This is the default configuration file. It allows all users to do anything,
3
+ # please read carefully the documentation and best practices to
4
+ # improve security.
4
5
  #
5
6
  # Look here for more config file examples:
6
- # https://github.com/verdaccio/verdaccio/tree/master/conf
7
+ # https://github.com/verdaccio/verdaccio/tree/5.x/conf
7
8
  #
9
+ # Read about the best practices
10
+ # https://verdaccio.org/docs/best
8
11
 
9
12
  # path to a directory with all packages
10
13
  storage: ./storage
11
14
  # path to a directory with plugins to include
12
15
  plugins: ./plugins
13
16
 
17
+ # https://verdaccio.org/docs/webui
14
18
  web:
15
19
  title: Verdaccio
16
20
  # comment out to disable gravatar support
@@ -19,17 +23,32 @@ web:
19
23
  # sort_packages: asc
20
24
  # convert your UI to the dark side
21
25
  # darkMode: true
22
- # logo: http://somedomain/somelogo.png
23
- # favicon: http://somedomain/favicon.ico | /path/favicon.ico
24
- # rateLimit:
25
- # windowMs: 1000
26
- # max: 10000
27
-
28
- # translate your registry, api i18n not available yet
29
- # i18n:
30
- # list of the available translations https://github.com/verdaccio/ui/tree/master/i18n/translations
31
- # web: en-US
26
+ # html_cache: true
27
+ # by default all features are displayed
28
+ # login: true
29
+ # showInfo: true
30
+ # showSettings: true
31
+ # In combination with darkMode you can force specific theme
32
+ # showThemeSwitch: true
33
+ # showFooter: true
34
+ # showSearch: true
35
+ # showRaw: true
36
+ # showDownloadTarball: true
37
+ # HTML tags injected after manifest <scripts/>
38
+ # scriptsBodyAfter:
39
+ # - '<script type="text/javascript" src="https://my.company.com/customJS.min.js"></script>'
40
+ # HTML tags injected before ends </head>
41
+ # metaScripts:
42
+ # - '<script type="text/javascript" src="https://code.jquery.com/jquery-3.5.1.slim.min.js"></script>'
43
+ # - '<script type="text/javascript" src="https://browser.sentry-cdn.com/5.15.5/bundle.min.js"></script>'
44
+ # - '<meta name="robots" content="noindex" />'
45
+ # HTML tags injected first child at <body/>
46
+ # bodyBefore:
47
+ # - '<div id="myId">html before webpack scripts</div>'
48
+ # Public path for template manifest scripts (only manifest)
49
+ # publicPath: http://somedomain.org/
32
50
 
51
+ # https://verdaccio.org/docs/configuration#authentication
33
52
  auth:
34
53
  htpasswd:
35
54
  file: ./htpasswd
@@ -37,11 +56,15 @@ auth:
37
56
  # You can set this to -1 to disable registration.
38
57
  # max_users: 1000
39
58
 
59
+ # https://verdaccio.org/docs/configuration#uplinks
40
60
  # a list of other known repositories we can talk to
41
61
  uplinks:
42
62
  npmjs:
43
63
  url: https://registry.npmjs.org/
44
64
 
65
+ # Learn how to protect your packages
66
+ # https://verdaccio.org/docs/protect-your-dependencies/
67
+ # https://verdaccio.org/docs/configuration#packages
45
68
  packages:
46
69
  '@*/*':
47
70
  # scoped packages
@@ -66,16 +89,88 @@ packages:
66
89
  # if package is not available locally, proxy requests to 'npmjs' registry
67
90
  proxy: npmjs
68
91
 
92
+ # To improve your security configuration and avoid dependency confusion
93
+ # consider removing the proxy property for private packages
94
+ # https://verdaccio.org/docs/best#remove-proxy-to-increase-security-at-private-packages
95
+
96
+ # https://verdaccio.org/docs/configuration#server
69
97
  # You can specify HTTP/1.1 server keep alive timeout in seconds for incoming connections.
70
98
  # A value of 0 makes the http server behave similarly to Node.js versions prior to 8.0.0, which did not have a keep-alive timeout.
71
99
  # WORKAROUND: Through given configuration you can workaround following issue https://github.com/verdaccio/verdaccio/issues/301. Set to 0 in case 60 is not enough.
72
100
  server:
73
101
  keepAliveTimeout: 60
74
102
 
103
+ # https://verdaccio.org/docs/configuration#offline-publish
104
+ # publish:
105
+ # allow_offline: false
106
+
107
+ # https://verdaccio.org/docs/configuration#url-prefix
108
+ # url_prefix: /verdaccio/
109
+ # VERDACCIO_PUBLIC_URL='https://somedomain.org';
110
+ # url_prefix: '/my_prefix'
111
+ # // url -> https://somedomain.org/my_prefix/
112
+ # VERDACCIO_PUBLIC_URL='https://somedomain.org';
113
+ # url_prefix: '/'
114
+ # // url -> https://somedomain.org/
115
+ # VERDACCIO_PUBLIC_URL='https://somedomain.org/first_prefix';
116
+ # url_prefix: '/second_prefix'
117
+ # // url -> https://somedomain.org/second_prefix/'
118
+
119
+ # https://verdaccio.org/docs/configuration#security
120
+ # security:
121
+ # api:
122
+ # legacy: true
123
+ # jwt:
124
+ # sign:
125
+ # expiresIn: 29d
126
+ # verify:
127
+ # someProp: [value]
128
+ # web:
129
+ # sign:
130
+ # expiresIn: 1h # 1 hour by default
131
+ # verify:
132
+ # someProp: [value]
133
+
134
+ # https://verdaccio.org/docs/configuration#user-rate-limit
135
+ # userRateLimit:
136
+ # windowMs: 50000
137
+ # max: 1000
138
+
139
+ # https://verdaccio.org/docs/configuration#max-body-size
140
+ # max_body_size: 10mb
141
+
142
+ # https://verdaccio.org/docs/configuration#listen-port
143
+ # listen:
144
+ # - localhost:4873 # default value
145
+ # - http://localhost:4873 # same thing
146
+ # - 0.0.0.0:4873 # listen on all addresses (INADDR_ANY)
147
+ # - https://example.org:4873 # if you want to use https
148
+ # - "[::1]:4873" # ipv6
149
+ # - unix:/tmp/verdaccio.sock # unix socket
150
+
151
+ # The HTTPS configuration is useful if you do not consider use a HTTP Proxy
152
+ # https://verdaccio.org/docs/configuration#https
153
+ # https:
154
+ # key: ./path/verdaccio-key.pem
155
+ # cert: ./path/verdaccio-cert.pem
156
+ # ca: ./path/verdaccio-csr.pem
157
+
158
+ # https://verdaccio.org/docs/configuration#proxy
159
+ # http_proxy: http://something.local/
160
+ # https_proxy: https://something.local/
161
+
162
+ # https://verdaccio.org/docs/configuration#notifications
163
+ # notify:
164
+ # method: POST
165
+ # headers: [{ "Content-Type": "application/json" }]
166
+ # endpoint: https://usagge.hipchat.com/v2/room/3729485/notification?auth_token=mySecretToken
167
+ # content: '{"color":"green","message":"New package published: * {{ name }}*","notify":true,"message_format":"text"}'
168
+
75
169
  middlewares:
76
170
  audit:
77
171
  enabled: true
78
172
 
173
+ # https://verdaccio.org/docs/logger
79
174
  # log settings
80
175
  logs: { type: stdout, format: pretty, level: http }
81
176
  #experiments:
@@ -91,6 +186,7 @@ logs: { type: stdout, format: pretty, level: http }
91
186
  # return signedUrl;
92
187
  # }
93
188
 
94
- # This affect the web and api (not developed yet)
95
- #i18n:
96
- #web: en-US
189
+ # translate your registry, api i18n not available yet
190
+ # i18n:
191
+ # list of the available translations https://github.com/verdaccio/verdaccio/blob/master/packages/plugins/ui-theme/src/i18n/ABOUT_TRANSLATIONS.md
192
+ # web: en-US
package/conf/docker.yaml CHANGED
@@ -1,40 +1,58 @@
1
1
  #
2
- # This is the config file used for the docker images.
3
- # It allows all users to do anything, so don't use it on production systems.
2
+ # This is the default configuration file. It allows all users to do anything,
3
+ # please read carefully the documentation and best practices to
4
+ # improve security.
4
5
  #
5
6
  # Do not configure host and port under `listen` in this file
6
7
  # as it will be ignored when using docker.
7
8
  # see https://verdaccio.org/docs/en/docker#docker-and-custom-port-configuration
8
9
  #
9
10
  # Look here for more config file examples:
10
- # https://github.com/verdaccio/verdaccio/tree/master/conf
11
+ # https://github.com/verdaccio/verdaccio/tree/5.x/conf
11
12
  #
13
+ # Read about the best practices
14
+ # https://verdaccio.org/docs/best
12
15
 
13
16
  # path to a directory with all packages
14
17
  storage: /verdaccio/storage/data
15
18
  # path to a directory with plugins to include
16
19
  plugins: /verdaccio/plugins
17
20
 
21
+ # https://verdaccio.org/docs/webui
18
22
  web:
19
- # WebUI is enabled as default, if you want disable it, just uncomment this line
20
- #enable: false
21
23
  title: Verdaccio
22
24
  # comment out to disable gravatar support
23
25
  # gravatar: false
24
26
  # by default packages are ordercer ascendant (asc|desc)
25
27
  # sort_packages: asc
28
+ # convert your UI to the dark side
26
29
  # darkMode: true
27
- # logo: http://somedomain/somelogo.png
28
- # favicon: http://somedomain/favicon.ico | /path/favicon.ico
29
- # rateLimit:
30
- # windowMs: 1000
31
- # max: 10000
32
-
33
- # translate your registry, api i18n not available yet
34
- # i18n:
35
- # list of the available translations https://github.com/verdaccio/ui/tree/master/i18n/translations
36
- # web: en-US
30
+ # html_cache: true
31
+ # by default all features are displayed
32
+ # login: true
33
+ # showInfo: true
34
+ # showSettings: true
35
+ # In combination with darkMode you can force specific theme
36
+ # showThemeSwitch: true
37
+ # showFooter: true
38
+ # showSearch: true
39
+ # showRaw: true
40
+ # showDownloadTarball: true
41
+ # HTML tags injected after manifest <scripts/>
42
+ # scriptsBodyAfter:
43
+ # - '<script type="text/javascript" src="https://my.company.com/customJS.min.js"></script>'
44
+ # HTML tags injected before ends </head>
45
+ # metaScripts:
46
+ # - '<script type="text/javascript" src="https://code.jquery.com/jquery-3.5.1.slim.min.js"></script>'
47
+ # - '<script type="text/javascript" src="https://browser.sentry-cdn.com/5.15.5/bundle.min.js"></script>'
48
+ # - '<meta name="robots" content="noindex" />'
49
+ # HTML tags injected first child at <body/>
50
+ # bodyBefore:
51
+ # - '<div id="myId">html before webpack scripts</div>'
52
+ # Public path for template manifest scripts (only manifest)
53
+ # publicPath: http://somedomain.org/
37
54
 
55
+ # https://verdaccio.org/docs/configuration#authentication
38
56
  auth:
39
57
  htpasswd:
40
58
  file: /verdaccio/storage/htpasswd
@@ -42,11 +60,15 @@ auth:
42
60
  # You can set this to -1 to disable registration.
43
61
  # max_users: 1000
44
62
 
63
+ # https://verdaccio.org/docs/configuration#uplinks
45
64
  # a list of other known repositories we can talk to
46
65
  uplinks:
47
66
  npmjs:
48
67
  url: https://registry.npmjs.org/
49
68
 
69
+ # Learn how to protect your packages
70
+ # https://verdaccio.org/docs/protect-your-dependencies/
71
+ # https://verdaccio.org/docs/configuration#packages
50
72
  packages:
51
73
  '@*/*':
52
74
  # scoped packages
@@ -71,16 +93,88 @@ packages:
71
93
  # if package is not available locally, proxy requests to 'npmjs' registry
72
94
  proxy: npmjs
73
95
 
96
+ # To improve your security configuration and avoid dependency confusion
97
+ # consider removing the proxy property for private packages
98
+ # https://verdaccio.org/docs/best#remove-proxy-to-increase-security-at-private-packages
99
+
100
+ # https://verdaccio.org/docs/configuration#server
74
101
  # You can specify HTTP/1.1 server keep alive timeout in seconds for incoming connections.
75
102
  # A value of 0 makes the http server behave similarly to Node.js versions prior to 8.0.0, which did not have a keep-alive timeout.
76
103
  # WORKAROUND: Through given configuration you can workaround following issue https://github.com/verdaccio/verdaccio/issues/301. Set to 0 in case 60 is not enough.
77
104
  server:
78
105
  keepAliveTimeout: 60
79
106
 
107
+ # https://verdaccio.org/docs/configuration#offline-publish
108
+ # publish:
109
+ # allow_offline: false
110
+
111
+ # https://verdaccio.org/docs/configuration#url-prefix
112
+ # url_prefix: /verdaccio/
113
+ # VERDACCIO_PUBLIC_URL='https://somedomain.org';
114
+ # url_prefix: '/my_prefix'
115
+ # // url -> https://somedomain.org/my_prefix/
116
+ # VERDACCIO_PUBLIC_URL='https://somedomain.org';
117
+ # url_prefix: '/'
118
+ # // url -> https://somedomain.org/
119
+ # VERDACCIO_PUBLIC_URL='https://somedomain.org/first_prefix';
120
+ # url_prefix: '/second_prefix'
121
+ # // url -> https://somedomain.org/second_prefix/'
122
+
123
+ # https://verdaccio.org/docs/configuration#security
124
+ # security:
125
+ # api:
126
+ # legacy: true
127
+ # jwt:
128
+ # sign:
129
+ # expiresIn: 29d
130
+ # verify:
131
+ # someProp: [value]
132
+ # web:
133
+ # sign:
134
+ # expiresIn: 1h # 1 hour by default
135
+ # verify:
136
+ # someProp: [value]
137
+
138
+ # https://verdaccio.org/docs/configuration#user-rate-limit
139
+ # userRateLimit:
140
+ # windowMs: 50000
141
+ # max: 1000
142
+
143
+ # https://verdaccio.org/docs/configuration#max-body-size
144
+ # max_body_size: 10mb
145
+
146
+ # https://verdaccio.org/docs/configuration#listen-port
147
+ # listen:
148
+ # - localhost:4873 # default value
149
+ # - http://localhost:4873 # same thing
150
+ # - 0.0.0.0:4873 # listen on all addresses (INADDR_ANY)
151
+ # - https://example.org:4873 # if you want to use https
152
+ # - "[::1]:4873" # ipv6
153
+ # - unix:/tmp/verdaccio.sock # unix socket
154
+
155
+ # The HTTPS configuration is useful if you do not consider use a HTTP Proxy
156
+ # https://verdaccio.org/docs/configuration#https
157
+ # https:
158
+ # key: ./path/verdaccio-key.pem
159
+ # cert: ./path/verdaccio-cert.pem
160
+ # ca: ./path/verdaccio-csr.pem
161
+
162
+ # https://verdaccio.org/docs/configuration#proxy
163
+ # http_proxy: http://something.local/
164
+ # https_proxy: https://something.local/
165
+
166
+ # https://verdaccio.org/docs/configuration#notifications
167
+ # notify:
168
+ # method: POST
169
+ # headers: [{ "Content-Type": "application/json" }]
170
+ # endpoint: https://usagge.hipchat.com/v2/room/3729485/notification?auth_token=mySecretToken
171
+ # content: '{"color":"green","message":"New package published: * {{ name }}*","notify":true,"message_format":"text"}'
172
+
80
173
  middlewares:
81
174
  audit:
82
175
  enabled: true
83
176
 
177
+ # https://verdaccio.org/docs/logger
84
178
  # log settings
85
179
  logs: { type: stdout, format: pretty, level: http }
86
180
  #experiments:
@@ -94,6 +188,7 @@ logs: { type: stdout, format: pretty, level: http }
94
188
  # return signedUrl;
95
189
  # }
96
190
 
97
- # This affect the web and api (not developed yet)
98
- #i18n:
99
- #web: en-US
191
+ # translate your registry, api i18n not available yet
192
+ # i18n:
193
+ # list of the available translations https://github.com/verdaccio/verdaccio/blob/master/packages/plugins/ui-theme/src/i18n/ABOUT_TRANSLATIONS.md
194
+ # web: en-US
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "verdaccio",
3
- "version": "5.8.0",
3
+ "version": "5.10.1",
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.0",
23
- "@verdaccio/readme": "10.3.2",
22
+ "@verdaccio/local-storage": "10.2.1",
23
+ "@verdaccio/readme": "10.3.3",
24
24
  "@verdaccio/streams": "10.2.0",
25
- "@verdaccio/ui-theme": "6.0.0-6-next.22",
25
+ "@verdaccio/ui-theme": "6.0.0-6-next.24",
26
26
  "JSONStream": "1.3.5",
27
27
  "async": "3.2.3",
28
- "body-parser": "1.19.1",
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.10.8",
33
+ "dayjs": "1.11.1",
34
34
  "debug": "^4.3.3",
35
35
  "envinfo": "7.8.1",
36
36
  "eslint-import-resolver-node": "0.3.6",
@@ -43,9 +43,9 @@
43
43
  "jsonwebtoken": "8.5.1",
44
44
  "kleur": "4.1.4",
45
45
  "lodash": "4.17.21",
46
- "lru-cache": "6.0.0",
46
+ "lru-cache": "7.8.1",
47
47
  "lunr-mutable-indexes": "2.3.2",
48
- "marked": "4.0.12",
48
+ "marked": "4.0.14",
49
49
  "memoizee": "0.4.15",
50
50
  "mime": "3.0.0",
51
51
  "minimatch": "5.0.1",
@@ -56,35 +56,35 @@
56
56
  "prettier-bytes": "^1.0.4",
57
57
  "pretty-ms": "^7.0.1",
58
58
  "request": "2.88.0",
59
- "semver": "7.3.5",
59
+ "semver": "7.3.7",
60
60
  "validator": "13.7.0",
61
- "verdaccio-audit": "10.2.0",
61
+ "verdaccio-audit": "10.2.1",
62
62
  "verdaccio-htpasswd": "10.3.0"
63
63
  },
64
64
  "devDependencies": {
65
- "@babel/cli": "7.16.8",
66
- "@babel/core": "7.16.10",
65
+ "@babel/cli": "7.17.6",
66
+ "@babel/core": "7.17.8",
67
67
  "@babel/node": "7.16.8",
68
68
  "@babel/plugin-proposal-class-properties": "7.16.7",
69
- "@babel/plugin-proposal-decorators": "7.16.7",
69
+ "@babel/plugin-proposal-decorators": "7.17.8",
70
70
  "@babel/plugin-proposal-export-namespace-from": "7.16.7",
71
71
  "@babel/plugin-proposal-function-sent": "7.16.7",
72
72
  "@babel/plugin-proposal-json-strings": "7.16.7",
73
73
  "@babel/plugin-proposal-nullish-coalescing-operator": "7.16.7",
74
74
  "@babel/plugin-proposal-numeric-separator": "7.16.7",
75
- "@babel/plugin-proposal-object-rest-spread": "7.16.7",
75
+ "@babel/plugin-proposal-object-rest-spread": "7.17.3",
76
76
  "@babel/plugin-proposal-optional-chaining": "7.16.7",
77
77
  "@babel/plugin-proposal-throw-expressions": "7.16.7",
78
78
  "@babel/plugin-syntax-dynamic-import": "7.8.3",
79
79
  "@babel/plugin-syntax-import-meta": "7.10.4",
80
80
  "@babel/plugin-transform-async-to-generator": "7.16.8",
81
81
  "@babel/plugin-transform-classes": "7.16.7",
82
- "@babel/plugin-transform-runtime": "7.16.10",
82
+ "@babel/plugin-transform-runtime": "7.17.0",
83
83
  "@babel/polyfill": "^7.12.1",
84
84
  "@babel/preset-env": "7.16.11",
85
85
  "@babel/preset-typescript": "7.16.7",
86
- "@babel/register": "7.16.9",
87
- "@babel/runtime": "7.16.7",
86
+ "@babel/register": "7.17.7",
87
+ "@babel/runtime": "7.17.8",
88
88
  "@commitlint/cli": "12.1.4",
89
89
  "@commitlint/config-conventional": "12.1.4",
90
90
  "@octokit/rest": "18.12.0",
@@ -95,7 +95,7 @@
95
95
  "@types/express-serve-static-core": "4.17.28",
96
96
  "@types/http-errors": "1.8.2",
97
97
  "@types/jest": "26.0.24",
98
- "@types/lodash": "4.14.178",
98
+ "@types/lodash": "4.14.182",
99
99
  "@types/mime": "2.0.3",
100
100
  "@types/minimatch": "3.0.5",
101
101
  "@types/node": "14.14.37",
@@ -121,7 +121,7 @@
121
121
  "eslint-plugin-jest": "24.7.0",
122
122
  "eslint-plugin-simple-import-sort": "7.0.0",
123
123
  "eslint-plugin-verdaccio": "9.6.1",
124
- "fs-extra": "10.0.0",
124
+ "fs-extra": "10.1.0",
125
125
  "husky": "6.0.0",
126
126
  "jest": "26.6.3",
127
127
  "jest-config": "26.6.3",
@@ -138,7 +138,7 @@
138
138
  "selfsigned": "1.10.14",
139
139
  "standard-version": "9.3.2",
140
140
  "supertest": "6.2.2",
141
- "ts-node": "10.4.0",
141
+ "ts-node": "10.7.0",
142
142
  "typescript": "4.1.3",
143
143
  "verdaccio-auth-memory": "10.2.0",
144
144
  "verdaccio-memory": "10.2.0"