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 +40 -0
- package/README.md +13 -5
- package/build/api/web/html/renderHTML.js +26 -10
- package/build/lib/auth-utils.js +2 -2
- package/build/lib/auth.js +2 -2
- package/conf/default.yaml +112 -16
- package/conf/docker.yaml +113 -18
- package/package.json +20 -20
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
|
|
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
|
-
**[
|
|
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
|
-
##
|
|
70
|
+
## Next talks
|
|
71
71
|
|
|
72
|
-
|
|
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
|
-
|
|
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$
|
|
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
|
|
80
|
-
const
|
|
81
|
-
const
|
|
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$
|
|
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$
|
|
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
|
-
|
|
127
|
-
|
|
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"]}
|
package/build/lib/auth-utils.js
CHANGED
|
@@ -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":";;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;AACA;;AAKA;;AACA;;AACA;;AACA;;;;AAEA,MAAMA,KAAK,GAAG,oBAAW,WAAX,CAAd;;AAEO,SAASC,gBAAT,CACLC,QADK,EACa;AAClBC,SAAiB,GAAGC,qCAFf,EAGI;AACT,SAAO,OAAOF,QAAP,KAAoB,QAApB,IAAgCA,QAAQ,CAACG,MAAT,IAAmBF,SAA1D;AACD;AAED;AACA;AACA;AACA;;;AACO,SAASG,gBAAT,CAA0BC,IAA1B,EAAwCC,YAAxC,EAA4E;AACjF,QAAMC,YAAqB,GAAGC,KAAK,CAACC,OAAN,CAAcH,YAAd,CAA9B;AACA,QAAMI,MAAM,GAAGF,KAAK,CAACG,IAAN,CAAW,IAAIC,GAAJ,CAAQ,CAACL,YAAY,GAAGD,YAAH,GAAkB,EAA/B,EAAmCO,MAAnC,CAA0C,CAACC,iBAAMC,IAAP,EAAaD,iBAAME,KAAnB,EAA0BF,iBAAMG,cAAhC,EAAgDH,iBAAMI,eAAtD,EAAuEJ,iBAAMK,GAA7E,CAA1C,CAAR,CAAX,CAAf;AAEA,SAAO;AACLd,IAAAA,IADK;AAELK,IAAAA,MAFK;AAGLU,IAAAA,WAAW,EAAEd;AAHR,GAAP;AAKD;AAED;AACA;AACA;AACA;;;AACO,SAASe,yBAAT,GAAiD;AACtD,SAAO;AACLhB,IAAAA,IAAI,EAAEiB,SADD;AAEL;AACAZ,IAAAA,MAAM,EAAE,CAACI,iBAAMC,IAAP,EAAaD,iBAAMS,UAAnB,EAA+BT,iBAAMG,cAArC,EAAqDH,iBAAMU,oBAA3D,CAHH;AAILJ,IAAAA,WAAW,EAAE;AAJR,GAAP;AAMD;;AAEM,SAASK,YAAT,CAAsBC,MAAtB,EAAgD;AACrD,SAAO,UAAUC,IAAV,EAA4BC,GAA5B,EAA0CC,QAA1C,EAAoE;AACzE/B,IAAAA,KAAK,CAAC,+BAAD,EAAkC6B,IAAlC,aAAkCA,IAAlC,uBAAkCA,IAAI,CAAEtB,IAAxC,CAAL;AACA,UAAM;AAAEA,MAAAA,IAAF;AAAQK,MAAAA;AAAR,QAAmBiB,IAAzB;AACA,UAAMG,WAAW,GAAGF,GAAG,CAACF,MAAD,CAAvB;AACA,UAAMK,aAAa,GAAGD,WAAW,CAACE,IAAZ,CAAkBC,KAAD,IAAW5B,IAAI,KAAK4B,KAAT,IAAkBvB,MAAM,CAACwB,QAAP,CAAgBD,KAAhB,CAA9C,CAAtB;AACAnC,IAAAA,KAAK,CAAC,sDAAD,EAAyDiC,aAAzD,EAAwEJ,IAAxE,aAAwEA,IAAxE,uBAAwEA,IAAI,CAAEtB,IAA9E,CAAL;;AAEA,QAAI0B,aAAJ,EAAmB;AACjBI,qBAAOC,IAAP,CAAY;AAAEC,QAAAA,MAAM,EAAEV,IAAI,CAACtB;AAAf,OAAZ,EAAoC,+CAApC;;AACA,aAAOwB,QAAQ,CAAC,IAAD,EAAO,IAAP,CAAf;AACD;;AAED,QAAIxB,IAAJ,EAAU;AACRwB,MAAAA,QAAQ,CAACS,iBAAUC,YAAV,CAAwB,QAAOlC,IAAK,sBAAqBqB,MAAO,YAAWE,GAAG,CAACvB,IAAK,EAApF,CAAD,CAAR;AACD,KAFD,MAEO;AACLwB,MAAAA,QAAQ,CAACS,iBAAUE,eAAV,CAA2B,6BAA4Bd,MAAO,YAAWE,GAAG,CAACvB,IAAK,EAAlF,CAAD,CAAR;AACD;AACF,GAjBD;AAkBD;AAED;AACA;AACA;;;AACO,SAASoC,sBAAT,GAAuC;AAC5C,SAAO,UAAUd,IAAV,EAA4BC,GAA5B,EAA0CC,QAA1C,EAAoE;AACzE,UAAMH,MAAM,GAAG,WAAf,CADyE,CAEzE;;AACA,UAAMgB,kBAA2B,GAAGC,gBAAEC,KAAF,CAAQhB,GAAG,CAACF,MAAD,CAAX,CAApC;;AACA,UAAMmB,SAAkB,GAAGH,kBAAkB,GAAG,KAAH,GAAWd,GAAG,CAACF,MAAD,CAAH,CAAYvB,MAAZ,GAAqB,CAA7E;AACAL,IAAAA,KAAK,CAAC,sDAAD,EAAyD+C,SAAzD,EAAoElB,IAApE,aAAoEA,IAApE,uBAAoEA,IAAI,CAAEtB,IAA1E,CAAL;;AACA,QAAIqC,kBAAkB,IAAIG,SAAS,KAAK,KAAxC,EAA+C;AAC7C,aAAOhB,QAAQ,CAAC,IAAD,EAAOP,SAAP,CAAf;AACD;;AACDxB,IAAAA,KAAK,CAAC,kDAAD,EAAqD4B,MAArD,EAA6DC,IAA7D,aAA6DA,IAA7D,uBAA6DA,IAAI,CAAEtB,IAAnE,EAAyEwC,SAAzE,EAAoFlB,IAApF,CAAL;AACA,WAAOF,YAAY,CAACC,MAAD,CAAZ,CAAqBC,IAArB,EAA2BC,GAA3B,EAAgCC,QAAhC,CAAP;AACD,GAXD;AAYD;;AAEM,SAASiB,iBAAT,CAA2BX,MAA3B,EAA6D;AAClE,SAAO;AACLY,IAAAA,YAAY,CAACC,KAAD,EAAgBC,SAAhB,EAAmCC,EAAnC,EAAuD;AACjE;AACAA,MAAAA,EAAE,CAACZ,iBAAUC,YAAV,CAAuBY,qBAAUC,qBAAjC,CAAD,CAAF;AACD,KAJI;;AAMLC,IAAAA,QAAQ,CAACL,KAAD,EAAgBC,SAAhB,EAAmCC,EAAnC,EAAuD;AAC7D;AACA,aAAOA,EAAE,CAACZ,iBAAUgB,WAAV,CAAsBH,qBAAUC,qBAAhC,CAAD,CAAT;AACD,KATI;;AAWL;AACA;AACAG,IAAAA,YAAY,EAAE9B,YAAY,CAAC,QAAD,EAAWU,MAAX,CAbrB;AAcL;AACAqB,IAAAA,aAAa,EAAE/B,YAAY,CAAC,SAAD,EAAYU,MAAZ,CAftB;AAgBLsB,IAAAA,eAAe,EAAEhB,sBAAsB;AAhBlC,GAAP;AAkBD;;AAEM,SAASiB,kBAAT,GAAkD;AACvD,QAAMC,YAAY,GAAG,KAAK,EAAL,GAAU,EAAV,GAAe,IAApC;AAEA,SAAO;AACL;AACAC,IAAAA,OAAO,EAAE,IAAIC,IAAJ,CAASA,IAAI,CAACC,GAAL,KAAaH,YAAtB;AAFJ,GAAP;AAID;;AAED,MAAMI,sBAAkC,GAAG;AACzCC,EAAAA,IAAI,EAAE;AACJ;AACAC,IAAAA,SAAS,EAAEC;AAFP,GADmC;AAKzCC,EAAAA,MAAM,EAAE;AALiC,CAA3C;AAQA,MAAMC,mBAAoC,GAAG;AAC3CC,EAAAA,MAAM,EAAE;AADmC,CAA7C,C,CAIA;;AACO,MAAMC,uBAAuB,GAAG;AACrCC,EAAAA,QAAQ,EAAE,KAAK,EAAL,GAAU,IADiB;AACX;AAC1BC,EAAAA,GAAG,EAAE;AAFgC,CAAhC;;AAKA,MAAMC,eAAyB,GAAG;AACvCC,EAAAA,GAAG,EAAEX,sBADkC;AAEvCY,EAAAA,GAAG,EAAEP;AAFkC,CAAlC;;;AAKA,SAASQ,WAAT,CAAqBC,MAArB,EAA+C;AACpD,MAAIlC,gBAAEC,KAAF,CAAQiC,MAAM,CAACC,QAAf,MAA6B,KAAjC,EAAwC;AACtC,WAAOnC,gBAAEoC,KAAF,CAAQN,eAAR,EAAyBI,MAAM,CAACC,QAAhC,CAAP;AACD;;AAED,SAAOL,eAAP;AACD;;AAEM,SAASO,uBAAT,CAAiCrD,IAAjC,EAAuD;AAC5D,SAAQ,6BAA4BA,IAAK,GAAzC;AACD;;AAEM,SAASsD,eAAT,CAAyB5E,IAAzB,EAAuCL,QAAvC,EAAiE;AACtE,SAAOkF,MAAM,CAACvE,IAAP,CAAa,GAAEN,IAAK,IAAGL,QAAS,EAAhC,EAAmC,MAAnC,CAAP;AACD;;AAEM,SAASmF,WAAT,CAAqBL,QAArB,EAAkD;AACvD,QAAM;AAAET,IAAAA,MAAF;AAAUe,IAAAA;AAAV,MAAkBN,QAAQ,CAACH,GAAjC;AAEA,SAAOhC,gBAAEC,KAAF,CAAQyB,MAAR,MAAoB,KAApB,IAA6B1B,gBAAEC,KAAF,CAAQwC,GAAR,CAA7B,IAA6Cf,MAAM,KAAK,IAA/D;AACD;;AAEM,eAAegB,WAAf,CAA2BC,IAA3B,EAA6CT,MAA7C,EAA6DU,UAA7D,EAAqFC,WAArF,EAA2H;AAChI,QAAMV,QAAkB,GAAGF,WAAW,CAACC,MAAD,CAAtC;;AACA,MAAIM,WAAW,CAACL,QAAD,CAAf,EAA2B;AACzB;AACA,WAAO,MAAM,IAAIW,OAAJ,CAAaC,OAAD,IAAmB;AAC1CA,MAAAA,OAAO,CAACJ,IAAI,CAACK,UAAL,CAAgBV,eAAe,CAACM,UAAU,CAAClF,IAAZ,EAA4BmF,WAA5B,CAA/B,EAAyEI,QAAzE,CAAkF,QAAlF,CAAD,CAAP;AACD,KAFY,CAAb;AAGD,GAP+H,CAQhI;;;AACA,QAAM;AAAER,IAAAA;AAAF,MAAUN,QAAQ,CAACH,GAAzB;;AAEA,MAAIS,GAAG,IAAIA,GAAG,CAACpB,IAAf,EAAqB;AACnB,WAAO,MAAMsB,IAAI,CAACO,UAAL,CAAgBN,UAAhB,EAA4BH,GAAG,CAACpB,IAAhC,CAAb;AACD;;AACD,SAAO,MAAM,IAAIyB,OAAJ,CAAaC,OAAD,IAAmB;AAC1CA,IAAAA,OAAO,CAACJ,IAAI,CAACK,UAAL,CAAgBV,eAAe,CAACM,UAAU,CAAClF,IAAZ,EAA4BmF,WAA5B,CAA/B,EAAyEI,QAAzE,CAAkF,QAAlF,CAAD,CAAP;AACD,GAFY,CAAb;AAGD;;AAEM,SAASE,oBAAT,CAA8BC,mBAA9B,EAA4E;AACjF,QAAMC,KAAK,GAAGD,mBAAmB,CAACE,KAApB,CAA0B,GAA1B,CAAd;AACA,QAAM,CAACC,MAAD,EAASC,KAAT,IAAkBH,KAAxB;AAEA,SAAO;AAAEE,IAAAA,MAAF;AAAUC,IAAAA;AAAV,GAAP;AACD;;AAEM,SAASC,iBAAT,CAA2BC,WAA3B,EAA8D;AACnE,QAAMC,KAAK,GAAGD,WAAW,CAACE,OAAZ,CAAoB,GAApB,CAAd;;AACA,MAAID,KAAK,GAAG,CAAZ,EAAe;AACb;AACD;;AAED,QAAM3E,IAAY,GAAG0E,WAAW,CAACG,KAAZ,CAAkB,CAAlB,EAAqBF,KAArB,CAArB;AACA,QAAMtG,QAAgB,GAAGqG,WAAW,CAACG,KAAZ,CAAkBF,KAAK,GAAG,CAA1B,CAAzB;AAEA,SAAO;AAAE3E,IAAAA,IAAF;AAAQ3B,IAAAA;AAAR,GAAP;AACD;;AAEM,SAASyG,mBAAT,CAA6BV,mBAA7B,EAA0DW,MAA1D,EAA0E;AAC/E,QAAM;AAAER,IAAAA,MAAF;AAAUC,IAAAA;AAAV,MAAoBL,oBAAoB,CAACC,mBAAD,CAA9C,CAD+E,CAG/E;;AACA,MAAIG,MAAM,CAACS,WAAP,OAAyBC,uBAAYD,WAAZ,EAA7B,EAAwD;AACtD,UAAMN,WAAW,GAAG,mCAAuBF,KAAvB,EAA8BP,QAA9B,EAApB;AAEA,WAAOS,WAAP;AACD,GAJD,MAIO,IAAIH,MAAM,CAACS,WAAP,OAAyBE,wBAAaF,WAAb,EAA7B,EAAyD;AAC9D,UAAMG,aAAa,GAAG,mCAAuBX,KAAvB,CAAtB;AACA,UAAME,WAAW,GAAG,6BAAWS,aAAX,EAA0BJ,MAA1B,EAAkCd,QAAlC,CAA2C,MAA3C,CAApB;AAEA,WAAOS,WAAP;AACD;AACF;;AAEM,MAAMU,aAAuB,GAAG,CAAC,mBAAD,EAAsB,mBAAtB,CAAhC;;;AAEA,SAASC,gBAAT,CAA0Bb,KAA1B,EAAyCO,MAAzC,EAAqE;AAC1E,MAAI;AACF,UAAMO,OAAmB,GAAG,gCAAcd,KAAd,EAAqBO,MAArB,CAA5B;AAEA,WAAOO,OAAP;AACD,GAJD,CAIE,OAAOC,KAAP,EAAc;AACd;AACA,QAAIH,aAAa,CAAC7E,QAAd,CAAuBgF,KAAK,CAAC7G,IAA7B,CAAJ,EAAwC;AACtC;AACA;AACA;AACA,aAAOgB,yBAAyB,EAAhC;AACD;;AACD,UAAMiB,iBAAU6E,OAAV,CAAkBC,uBAAYC,YAA9B,EAA4CH,KAAK,CAACI,OAAlD,CAAN;AACD;AACF;;AAEM,SAASC,iBAAT,CAA2BC,aAA3B,EAA2D;AAChE,SAAOA,aAAa,CAACvB,KAAd,CAAoB,GAApB,EAAyB9F,MAAzB,KAAoC,CAA3C;AACD;;AAEM,SAASsH,wBAAT,CAAkC3C,QAAlC,EAAsD4B,MAAtD,EAAsEX,mBAAtE,EAA0H;AAC/H,MAAIZ,WAAW,CAACL,QAAD,CAAf,EAA2B;AACzB,UAAMuB,WAAW,GAAGI,mBAAmB,CAACV,mBAAD,EAAsBW,MAAtB,CAAvC;;AACA,QAAI,CAACL,WAAL,EAAkB;AAChB;AACD;;AAED,UAAMqB,iBAAiB,GAAGtB,iBAAiB,CAACC,WAAD,CAA3C;;AACA,QAAI,CAACqB,iBAAL,EAAwB;AACtB;AACD;;AAED,WAAOA,iBAAP;AACD;;AACD,QAAM;AAAExB,IAAAA,MAAF;AAAUC,IAAAA;AAAV,MAAoBL,oBAAoB,CAACC,mBAAD,CAA9C;;AAEA,MAAIpD,gBAAEgF,QAAF,CAAWxB,KAAX,KAAqBD,MAAM,CAACS,WAAP,OAAyBE,wBAAaF,WAAb,EAAlD,EAA8E;AAC5E,WAAOK,gBAAgB,CAACb,KAAD,EAAQO,MAAR,CAAvB;AACD;AACF","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
|
|
3
|
-
#
|
|
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/
|
|
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
|
-
#
|
|
23
|
-
#
|
|
24
|
-
#
|
|
25
|
-
#
|
|
26
|
-
#
|
|
27
|
-
|
|
28
|
-
#
|
|
29
|
-
#
|
|
30
|
-
#
|
|
31
|
-
#
|
|
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
|
-
#
|
|
95
|
-
#i18n:
|
|
96
|
-
#
|
|
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
|
|
3
|
-
#
|
|
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/
|
|
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
|
-
#
|
|
28
|
-
#
|
|
29
|
-
#
|
|
30
|
-
#
|
|
31
|
-
#
|
|
32
|
-
|
|
33
|
-
#
|
|
34
|
-
#
|
|
35
|
-
#
|
|
36
|
-
#
|
|
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
|
-
#
|
|
98
|
-
#i18n:
|
|
99
|
-
#
|
|
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.
|
|
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.
|
|
23
|
-
"@verdaccio/readme": "10.3.
|
|
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.
|
|
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.
|
|
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.
|
|
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": "
|
|
46
|
+
"lru-cache": "7.8.1",
|
|
47
47
|
"lunr-mutable-indexes": "2.3.2",
|
|
48
|
-
"marked": "4.0.
|
|
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.
|
|
59
|
+
"semver": "7.3.7",
|
|
60
60
|
"validator": "13.7.0",
|
|
61
|
-
"verdaccio-audit": "10.2.
|
|
61
|
+
"verdaccio-audit": "10.2.1",
|
|
62
62
|
"verdaccio-htpasswd": "10.3.0"
|
|
63
63
|
},
|
|
64
64
|
"devDependencies": {
|
|
65
|
-
"@babel/cli": "7.
|
|
66
|
-
"@babel/core": "7.
|
|
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.
|
|
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.
|
|
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.
|
|
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.
|
|
87
|
-
"@babel/runtime": "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.
|
|
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.
|
|
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.
|
|
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"
|