verdaccio 5.3.2 → 5.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +18 -0
- package/README.md +6 -5
- package/build/api/endpoint/api/user.js +15 -5
- package/build/api/endpoint/api/v1/index.js +26 -0
- package/build/api/endpoint/api/v1/profile.js +12 -4
- package/build/api/endpoint/api/v1/token.js +14 -5
- package/build/api/endpoint/index.js +4 -7
- package/build/api/index.js +11 -5
- package/build/api/rate-limiter.js +24 -0
- package/build/api/web/api.js +4 -16
- package/build/api/web/endpoint/index.js +45 -0
- package/build/api/web/endpoint/package.js +10 -5
- package/build/api/web/endpoint/search.js +8 -2
- package/build/api/web/endpoint/user.js +9 -3
- package/build/api/web/index.js +5 -2
- package/build/lib/auth-utils.js +11 -4
- package/build/lib/config.js +15 -6
- package/build/lib/constants.js +5 -4
- package/build/lib/up-storage.js +6 -3
- package/build/lib/utils.js +11 -2
- package/conf/default.yaml +3 -1
- package/conf/docker.yaml +3 -1
- package/package.json +14 -8
package/CHANGELOG.md
CHANGED
|
@@ -2,6 +2,24 @@
|
|
|
2
2
|
|
|
3
3
|
All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
|
|
4
4
|
|
|
5
|
+
## [5.4.0](https://github.com/verdaccio/verdaccio/compare/v5.3.2...v5.4.0) (2021-12-24)
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
### Features
|
|
9
|
+
|
|
10
|
+
* add cache-control header to endpoints ([#2791](https://github.com/verdaccio/verdaccio/issues/2791)) ([fd3ad1e](https://github.com/verdaccio/verdaccio/commit/fd3ad1e546f5293e862d767f23b3714e6dd5dc8c))
|
|
11
|
+
* add rate limit to user api endpoints ([#2800](https://github.com/verdaccio/verdaccio/issues/2800)) ([#2799](https://github.com/verdaccio/verdaccio/issues/2799)) ([f64e403](https://github.com/verdaccio/verdaccio/commit/f64e403f0a1d710a0d866ca2db480199c83a3609))
|
|
12
|
+
* add rate limit to web endpoints ([#2799](https://github.com/verdaccio/verdaccio/issues/2799)) ([c91d6be](https://github.com/verdaccio/verdaccio/commit/c91d6beb8bde1c5f275d7f570209cf723dce47c5))
|
|
13
|
+
* allow override user rate limit and user agent ([#2803](https://github.com/verdaccio/verdaccio/issues/2803)) ([5b1264c](https://github.com/verdaccio/verdaccio/commit/5b1264c733ea249efc38e963f0e99fb093d61406))
|
|
14
|
+
* jwt default time new set ([#2787](https://github.com/verdaccio/verdaccio/issues/2787)) ([1c17d09](https://github.com/verdaccio/verdaccio/commit/1c17d0986ea551b427994f8392a9d8ef29ba88e9))
|
|
15
|
+
* user agent is the client by default ([#2793](https://github.com/verdaccio/verdaccio/issues/2793)) ([e5d79ce](https://github.com/verdaccio/verdaccio/commit/e5d79ce8f00a18f0c0646b761f22dc608b5baf87))
|
|
16
|
+
|
|
17
|
+
|
|
18
|
+
### Bug Fixes
|
|
19
|
+
|
|
20
|
+
* **deps:** update dependency @verdaccio/commons-api to v10.1.0 ([#2789](https://github.com/verdaccio/verdaccio/issues/2789)) ([c5c0ef8](https://github.com/verdaccio/verdaccio/commit/c5c0ef8750abeb50d933c639a2041d25a889820b))
|
|
21
|
+
* **deps:** update dependency body-parser to v1.19.1 ([#2788](https://github.com/verdaccio/verdaccio/issues/2788)) ([46e583f](https://github.com/verdaccio/verdaccio/commit/46e583f683520b3a69dbd14ed43146492c0e80be))
|
|
22
|
+
|
|
5
23
|
### [5.3.2](https://github.com/verdaccio/verdaccio/compare/v5.3.1...v5.3.2) (2021-12-16)
|
|
6
24
|
|
|
7
25
|
|
package/README.md
CHANGED
|
@@ -69,15 +69,16 @@ booted in a couple of seconds, fast enough for any CI. Many open source projects
|
|
|
69
69
|
|
|
70
70
|
## Talks
|
|
71
71
|
|
|
72
|
-
### **
|
|
72
|
+
### **Using Docker and Verdaccio to make Integration Testing Easy - Docker All Hands #4 December - 2021**.
|
|
73
73
|
|
|
74
|
-
[](https://www.youtube.com/watch?v=zRI0skF1f8I)
|
|
75
75
|
|
|
76
76
|
You might want to check out as well our previous talks:
|
|
77
77
|
|
|
78
|
-
- [
|
|
79
|
-
- [
|
|
80
|
-
- [
|
|
78
|
+
- [**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
|
+
- [BeerJS Cba Meetup No. 53 May 2021 - **Juan Picado** React Finland - 2021](https://www.youtube.com/watch?v=6SyjqBmS49Y&ab_channel=BeerJSCba)
|
|
80
|
+
- [Node.js Dependency Confusion Attacks - April 2021 - **Juan Picado**](https://www.youtube.com/watch?v=qTRADSp3Hpo)
|
|
81
|
+
- [**OpenJS World 2020** about \*Cover your Projects with a Multi purpose Lightweight Node.js Registry - **Juan Picado**](https://www.youtube.com/watch?v=oVCjDWeehAQ)
|
|
81
82
|
- [ViennaJS Meetup - Introduction to Verdaccio by **Priscila Olivera** and **Juan Picado**](https://www.youtube.com/watch?v=hDIFKzmoCa)
|
|
82
83
|
- [Open Source? trivago - Verdaccio (**Ayush** and **Juan Picado**) January 2020](https://www.youtube.com/watch?v=A5CWxJC9xzc)
|
|
83
84
|
- [GitNation Open Source Stage - How we have built a Node.js Registry with React - **Juan Picado** December 2019](https://www.youtube.com/watch?v=gpjC8Qp9B9A)
|
|
@@ -9,6 +9,8 @@ var _lodash = _interopRequireDefault(require("lodash"));
|
|
|
9
9
|
|
|
10
10
|
var _cookies = _interopRequireDefault(require("cookies"));
|
|
11
11
|
|
|
12
|
+
var _express = _interopRequireDefault(require("express"));
|
|
13
|
+
|
|
12
14
|
var _utils = require("../../../lib/utils");
|
|
13
15
|
|
|
14
16
|
var _constants = require("../../../lib/constants");
|
|
@@ -17,16 +19,21 @@ var _authUtils = require("../../../lib/auth-utils");
|
|
|
17
19
|
|
|
18
20
|
var _logger = require("../../../lib/logger");
|
|
19
21
|
|
|
22
|
+
var _rateLimiter = require("../../rate-limiter");
|
|
23
|
+
|
|
20
24
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
21
25
|
|
|
22
26
|
function _default(route, auth, config) {
|
|
23
|
-
|
|
27
|
+
/* eslint new-cap:off */
|
|
28
|
+
const userRouter = _express.default.Router();
|
|
29
|
+
|
|
30
|
+
userRouter.get('/-/user/:org_couchdb_user', (0, _rateLimiter.limiter)(config === null || config === void 0 ? void 0 : config.userRateLimit), function (req, res, next) {
|
|
24
31
|
res.status(_constants.HTTP_STATUS.OK);
|
|
25
32
|
next({
|
|
26
33
|
ok: (0, _authUtils.getAuthenticatedMessage)(req.remote_user.name)
|
|
27
34
|
});
|
|
28
35
|
});
|
|
29
|
-
|
|
36
|
+
userRouter.put('/-/user/:org_couchdb_user/:_rev?/:revision?', (0, _rateLimiter.limiter)(config === null || config === void 0 ? void 0 : config.userRateLimit), function (req, res, next) {
|
|
30
37
|
const {
|
|
31
38
|
name,
|
|
32
39
|
password
|
|
@@ -47,6 +54,7 @@ function _default(route, auth, config) {
|
|
|
47
54
|
const restoredRemoteUser = (0, _authUtils.createRemoteUser)(name, user.groups || []);
|
|
48
55
|
const token = await (0, _authUtils.getApiToken)(auth, config, restoredRemoteUser, password);
|
|
49
56
|
res.status(_constants.HTTP_STATUS.CREATED);
|
|
57
|
+
res.set(_constants.HEADERS.CACHE_CONTROL, 'no-cache, no-store');
|
|
50
58
|
return next({
|
|
51
59
|
ok: (0, _authUtils.getAuthenticatedMessage)(req.remote_user.name),
|
|
52
60
|
token
|
|
@@ -73,6 +81,7 @@ function _default(route, auth, config) {
|
|
|
73
81
|
const token = name && password ? await (0, _authUtils.getApiToken)(auth, config, user, password) : undefined;
|
|
74
82
|
req.remote_user = user;
|
|
75
83
|
res.status(_constants.HTTP_STATUS.CREATED);
|
|
84
|
+
res.set(_constants.HEADERS.CACHE_CONTROL, 'no-cache, no-store');
|
|
76
85
|
return next({
|
|
77
86
|
ok: `user '${req.body.name}' created`,
|
|
78
87
|
token
|
|
@@ -80,7 +89,7 @@ function _default(route, auth, config) {
|
|
|
80
89
|
});
|
|
81
90
|
}
|
|
82
91
|
});
|
|
83
|
-
|
|
92
|
+
userRouter.delete('/-/user/token/*', (0, _rateLimiter.limiter)(config === null || config === void 0 ? void 0 : config.userRateLimit), function (req, res, next) {
|
|
84
93
|
res.status(_constants.HTTP_STATUS.OK);
|
|
85
94
|
next({
|
|
86
95
|
ok: _constants.API_MESSAGE.LOGGED_OUT
|
|
@@ -88,7 +97,7 @@ function _default(route, auth, config) {
|
|
|
88
97
|
}); // placeholder 'cause npm require to be authenticated to publish
|
|
89
98
|
// we do not do any real authentication yet
|
|
90
99
|
|
|
91
|
-
|
|
100
|
+
userRouter.post('/_session', _cookies.default.express(), function (req, res, next) {
|
|
92
101
|
res.cookies.set('AuthSession', String(Math.random()), (0, _authUtils.createSessionToken)());
|
|
93
102
|
next({
|
|
94
103
|
ok: true,
|
|
@@ -96,5 +105,6 @@ function _default(route, auth, config) {
|
|
|
96
105
|
roles: []
|
|
97
106
|
});
|
|
98
107
|
});
|
|
108
|
+
route.use(userRouter);
|
|
99
109
|
}
|
|
100
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/api/endpoint/api/user.ts"],"names":["route","auth","config","get","req","res","next","status","HTTP_STATUS","OK","ok","remote_user","name","put","password","body","remoteName","_","isNil","authenticate","callbackAuthenticate","err","user","logger","error","ErrorCode","getCode","UNAUTHORIZED","API_ERROR","BAD_USERNAME_PASSWORD","restoredRemoteUser","groups","token","CREATED","BAD_REQUEST","PASSWORD_SHORT","add_user","INTERNAL_ERROR","message","getConflict","undefined","delete","API_MESSAGE","LOGGED_OUT","post","Cookies","express","cookies","set","String","Math","random","roles"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport Cookies from 'cookies';\n\nimport { Config, RemoteUser } from '@verdaccio/types';\nimport { Response, Router } from 'express';\nimport { ErrorCode } from '../../../lib/utils';\nimport { API_ERROR, API_MESSAGE, HTTP_STATUS } from '../../../lib/constants';\nimport { createRemoteUser, createSessionToken, getApiToken, getAuthenticatedMessage, validatePassword } from '../../../lib/auth-utils';\nimport { logger } from '../../../lib/logger';\n\nimport { $RequestExtend, $ResponseExtend, $NextFunctionVer, IAuth } from '../../../../types';\n\nexport default function (route: Router, auth: IAuth, config: Config): void {\n  route.get('/-/user/:org_couchdb_user', function (req: $RequestExtend, res: Response, next: $NextFunctionVer): void {\n    res.status(HTTP_STATUS.OK);\n    next({\n      ok: getAuthenticatedMessage(req.remote_user.name),\n    });\n  });\n\n  route.put('/-/user/:org_couchdb_user/:_rev?/:revision?', function (req: $RequestExtend, res: Response, next: $NextFunctionVer): void {\n    const { name, password } = req.body;\n    const remoteName = req.remote_user.name;\n\n    if (_.isNil(remoteName) === false && _.isNil(name) === false && remoteName === name) {\n      auth.authenticate(name, password, async function callbackAuthenticate(err, user): Promise<void> {\n        if (err) {\n          logger.error({ name, err }, 'authenticating for user @{username} failed. Error: @{err.message}');\n          return next(ErrorCode.getCode(HTTP_STATUS.UNAUTHORIZED, API_ERROR.BAD_USERNAME_PASSWORD));\n        }\n\n        const restoredRemoteUser: RemoteUser = createRemoteUser(name, user.groups || []);\n        const token = await getApiToken(auth, config, restoredRemoteUser, password);\n\n        res.status(HTTP_STATUS.CREATED);\n\n        return next({\n          ok: getAuthenticatedMessage(req.remote_user.name),\n          token,\n        });\n      });\n    } else {\n      if (validatePassword(password) === false) {\n        // eslint-disable-next-line new-cap\n        return next(ErrorCode.getCode(HTTP_STATUS.BAD_REQUEST, API_ERROR.PASSWORD_SHORT()));\n      }\n\n      auth.add_user(name, password, async function (err, user): Promise<void> {\n        if (err) {\n          if (err.status >= HTTP_STATUS.BAD_REQUEST && err.status < HTTP_STATUS.INTERNAL_ERROR) {\n            // With npm registering is the same as logging in,\n            // and npm accepts only an 409 error.\n            // So, changing status code here.\n            return next(ErrorCode.getCode(err.status, err.message) || ErrorCode.getConflict(err.message));\n          }\n          return next(err);\n        }\n\n        const token = name && password ? await getApiToken(auth, config, user, password) : undefined;\n\n        req.remote_user = user;\n        res.status(HTTP_STATUS.CREATED);\n        return next({\n          ok: `user '${req.body.name}' created`,\n          token,\n        });\n      });\n    }\n  });\n\n  route.delete('/-/user/token/*', function (req: $RequestExtend, res: Response, next: $NextFunctionVer): void {\n    res.status(HTTP_STATUS.OK);\n    next({\n      ok: API_MESSAGE.LOGGED_OUT,\n    });\n  });\n\n  // placeholder 'cause npm require to be authenticated to publish\n  // we do not do any real authentication yet\n  route.post('/_session', Cookies.express(), function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n    res.cookies.set('AuthSession', String(Math.random()), createSessionToken());\n\n    next({\n      ok: true,\n      name: 'somebody',\n      roles: [],\n    });\n  });\n}\n"]}
|
|
110
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/api/endpoint/api/user.ts"],"names":["route","auth","config","userRouter","express","Router","get","userRateLimit","req","res","next","status","HTTP_STATUS","OK","ok","remote_user","name","put","password","body","remoteName","_","isNil","authenticate","callbackAuthenticate","err","user","logger","error","ErrorCode","getCode","UNAUTHORIZED","API_ERROR","BAD_USERNAME_PASSWORD","restoredRemoteUser","groups","token","CREATED","set","HEADERS","CACHE_CONTROL","BAD_REQUEST","PASSWORD_SHORT","add_user","INTERNAL_ERROR","message","getConflict","undefined","delete","API_MESSAGE","LOGGED_OUT","post","Cookies","cookies","String","Math","random","roles","use"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport Cookies from 'cookies';\n\nimport { Config, RemoteUser } from '@verdaccio/types';\nimport express, { Response, Router } from 'express';\nimport { ErrorCode } from '../../../lib/utils';\nimport { API_ERROR, API_MESSAGE, HEADERS, HTTP_STATUS } from '../../../lib/constants';\nimport { createRemoteUser, createSessionToken, getApiToken, getAuthenticatedMessage, validatePassword } from '../../../lib/auth-utils';\nimport { logger } from '../../../lib/logger';\n\nimport { $RequestExtend, $ResponseExtend, $NextFunctionVer, IAuth } from '../../../../types';\nimport { limiter } from '../../rate-limiter';\n\nexport default function (route: Router, auth: IAuth, config: Config): void {\n  /* eslint new-cap:off */\n  const userRouter = express.Router();\n\n  userRouter.get('/-/user/:org_couchdb_user', limiter(config?.userRateLimit), function (req: $RequestExtend, res: Response, next: $NextFunctionVer): void {\n    res.status(HTTP_STATUS.OK);\n    next({\n      ok: getAuthenticatedMessage(req.remote_user.name),\n    });\n  });\n\n  userRouter.put('/-/user/:org_couchdb_user/:_rev?/:revision?', limiter(config?.userRateLimit), function (req: $RequestExtend, res: Response, next: $NextFunctionVer): void {\n    const { name, password } = req.body;\n    const remoteName = req.remote_user.name;\n\n    if (_.isNil(remoteName) === false && _.isNil(name) === false && remoteName === name) {\n      auth.authenticate(name, password, async function callbackAuthenticate(err, user): Promise<void> {\n        if (err) {\n          logger.error({ name, err }, 'authenticating for user @{username} failed. Error: @{err.message}');\n          return next(ErrorCode.getCode(HTTP_STATUS.UNAUTHORIZED, API_ERROR.BAD_USERNAME_PASSWORD));\n        }\n\n        const restoredRemoteUser: RemoteUser = createRemoteUser(name, user.groups || []);\n        const token = await getApiToken(auth, config, restoredRemoteUser, password);\n\n        res.status(HTTP_STATUS.CREATED);\n        res.set(HEADERS.CACHE_CONTROL, 'no-cache, no-store');\n        return next({\n          ok: getAuthenticatedMessage(req.remote_user.name),\n          token,\n        });\n      });\n    } else {\n      if (validatePassword(password) === false) {\n        // eslint-disable-next-line new-cap\n        return next(ErrorCode.getCode(HTTP_STATUS.BAD_REQUEST, API_ERROR.PASSWORD_SHORT()));\n      }\n\n      auth.add_user(name, password, async function (err, user): Promise<void> {\n        if (err) {\n          if (err.status >= HTTP_STATUS.BAD_REQUEST && err.status < HTTP_STATUS.INTERNAL_ERROR) {\n            // With npm registering is the same as logging in,\n            // and npm accepts only an 409 error.\n            // So, changing status code here.\n            return next(ErrorCode.getCode(err.status, err.message) || ErrorCode.getConflict(err.message));\n          }\n          return next(err);\n        }\n\n        const token = name && password ? await getApiToken(auth, config, user, password) : undefined;\n\n        req.remote_user = user;\n        res.status(HTTP_STATUS.CREATED);\n        res.set(HEADERS.CACHE_CONTROL, 'no-cache, no-store');\n        return next({\n          ok: `user '${req.body.name}' created`,\n          token,\n        });\n      });\n    }\n  });\n\n  userRouter.delete('/-/user/token/*', limiter(config?.userRateLimit), function (req: $RequestExtend, res: Response, next: $NextFunctionVer): void {\n    res.status(HTTP_STATUS.OK);\n    next({\n      ok: API_MESSAGE.LOGGED_OUT,\n    });\n  });\n\n  // placeholder 'cause npm require to be authenticated to publish\n  // we do not do any real authentication yet\n  userRouter.post('/_session', Cookies.express(), function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n    res.cookies.set('AuthSession', String(Math.random()), createSessionToken());\n\n    next({\n      ok: true,\n      name: 'somebody',\n      roles: [],\n    });\n  });\n\n  route.use(userRouter);\n}\n"]}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
|
|
8
|
+
var _express = require("express");
|
|
9
|
+
|
|
10
|
+
var _profile = _interopRequireDefault(require("./profile"));
|
|
11
|
+
|
|
12
|
+
var _token = _interopRequireDefault(require("./token"));
|
|
13
|
+
|
|
14
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
15
|
+
|
|
16
|
+
var _default = (auth, storage, config) => {
|
|
17
|
+
const route = (0, _express.Router)();
|
|
18
|
+
/* eslint new-cap: 0 */
|
|
19
|
+
|
|
20
|
+
route.use('/-/npm/v1/', (0, _profile.default)(auth, config));
|
|
21
|
+
route.use('/-/npm/v1/', (0, _token.default)(auth, storage, config));
|
|
22
|
+
return route;
|
|
23
|
+
};
|
|
24
|
+
|
|
25
|
+
exports.default = _default;
|
|
26
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9hcGkvZW5kcG9pbnQvYXBpL3YxL2luZGV4LnRzIl0sIm5hbWVzIjpbImF1dGgiLCJzdG9yYWdlIiwiY29uZmlnIiwicm91dGUiLCJ1c2UiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFBQTs7QUFDQTs7QUFDQTs7OztlQUVlLENBQUNBLElBQUQsRUFBT0MsT0FBUCxFQUFnQkMsTUFBaEIsS0FBMkI7QUFDeEMsUUFBTUMsS0FBSyxHQUFHLHNCQUFkO0FBQXdCOztBQUN4QkEsRUFBQUEsS0FBSyxDQUFDQyxHQUFOLENBQVUsWUFBVixFQUF3QixzQkFBUUosSUFBUixFQUFjRSxNQUFkLENBQXhCO0FBQ0FDLEVBQUFBLEtBQUssQ0FBQ0MsR0FBTixDQUFVLFlBQVYsRUFBd0Isb0JBQU1KLElBQU4sRUFBWUMsT0FBWixFQUFxQkMsTUFBckIsQ0FBeEI7QUFDQSxTQUFPQyxLQUFQO0FBQ0QsQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFJlc3BvbnNlLCBSb3V0ZXIgfSBmcm9tICdleHByZXNzJztcbmltcG9ydCBwcm9maWxlIGZyb20gJy4vcHJvZmlsZSc7XG5pbXBvcnQgdG9rZW4gZnJvbSAnLi90b2tlbic7XG5cbmV4cG9ydCBkZWZhdWx0IChhdXRoLCBzdG9yYWdlLCBjb25maWcpID0+IHtcbiAgY29uc3Qgcm91dGUgPSBSb3V0ZXIoKTsgLyogZXNsaW50IG5ldy1jYXA6IDAgKi9cbiAgcm91dGUudXNlKCcvLS9ucG0vdjEvJywgcHJvZmlsZShhdXRoLCBjb25maWcpKTtcbiAgcm91dGUudXNlKCcvLS9ucG0vdjEvJywgdG9rZW4oYXV0aCwgc3RvcmFnZSwgY29uZmlnKSk7XG4gIHJldHVybiByb3V0ZTtcbn07XG4iXX0=
|
|
@@ -7,15 +7,22 @@ exports.default = _default;
|
|
|
7
7
|
|
|
8
8
|
var _lodash = _interopRequireDefault(require("lodash"));
|
|
9
9
|
|
|
10
|
+
var _express = require("express");
|
|
11
|
+
|
|
10
12
|
var _constants = require("../../../../lib/constants");
|
|
11
13
|
|
|
12
14
|
var _utils = require("../../../../lib/utils");
|
|
13
15
|
|
|
14
16
|
var _authUtils = require("../../../../lib/auth-utils");
|
|
15
17
|
|
|
18
|
+
var _rateLimiter = require("../../../rate-limiter");
|
|
19
|
+
|
|
16
20
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
17
21
|
|
|
18
|
-
function _default(
|
|
22
|
+
function _default(auth, config) {
|
|
23
|
+
const profileRoute = (0, _express.Router)();
|
|
24
|
+
/* eslint new-cap: 0 */
|
|
25
|
+
|
|
19
26
|
function buildProfile(name) {
|
|
20
27
|
return {
|
|
21
28
|
tfa: false,
|
|
@@ -29,7 +36,7 @@ function _default(route, auth) {
|
|
|
29
36
|
};
|
|
30
37
|
}
|
|
31
38
|
|
|
32
|
-
|
|
39
|
+
profileRoute.get('/user', (0, _rateLimiter.limiter)(config === null || config === void 0 ? void 0 : config.userRateLimit), function (req, res, next) {
|
|
33
40
|
if (_lodash.default.isNil(req.remote_user.name) === false) {
|
|
34
41
|
return next(buildProfile(req.remote_user.name));
|
|
35
42
|
}
|
|
@@ -39,7 +46,7 @@ function _default(route, auth) {
|
|
|
39
46
|
message: _constants.API_ERROR.MUST_BE_LOGGED
|
|
40
47
|
});
|
|
41
48
|
});
|
|
42
|
-
|
|
49
|
+
profileRoute.post('/user', (0, _rateLimiter.limiter)(config === null || config === void 0 ? void 0 : config.userRateLimit), function (req, res, next) {
|
|
43
50
|
if (_lodash.default.isNil(req.remote_user.name)) {
|
|
44
51
|
res.status(_constants.HTTP_STATUS.UNAUTHORIZED);
|
|
45
52
|
return next({
|
|
@@ -79,5 +86,6 @@ function _default(route, auth) {
|
|
|
79
86
|
return next(_utils.ErrorCode.getCode(_constants.HTTP_STATUS.INTERNAL_ERROR, _constants.APP_ERROR.PROFILE_ERROR));
|
|
80
87
|
}
|
|
81
88
|
});
|
|
89
|
+
return profileRoute;
|
|
82
90
|
}
|
|
83
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
91
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9hcGkvZW5kcG9pbnQvYXBpL3YxL3Byb2ZpbGUudHMiXSwibmFtZXMiOlsiYXV0aCIsImNvbmZpZyIsInByb2ZpbGVSb3V0ZSIsImJ1aWxkUHJvZmlsZSIsIm5hbWUiLCJ0ZmEiLCJlbWFpbCIsImVtYWlsX3ZlcmlmaWVkIiwiY3JlYXRlZCIsInVwZGF0ZWQiLCJjaWRyX3doaXRlbGlzdCIsImZ1bGxuYW1lIiwiZ2V0IiwidXNlclJhdGVMaW1pdCIsInJlcSIsInJlcyIsIm5leHQiLCJfIiwiaXNOaWwiLCJyZW1vdGVfdXNlciIsInN0YXR1cyIsIkhUVFBfU1RBVFVTIiwiVU5BVVRIT1JJWkVEIiwibWVzc2FnZSIsIkFQSV9FUlJPUiIsIk1VU1RfQkVfTE9HR0VEIiwicG9zdCIsInBhc3N3b3JkIiwiYm9keSIsIm5ldyIsIkVycm9yQ29kZSIsImdldENvZGUiLCJQQVNTV09SRF9TSE9SVCIsImNoYW5nZVBhc3N3b3JkIiwib2xkIiwiZXJyIiwiaXNVcGRhdGVkIiwiaXNOdWxsIiwiZ2V0Q29uZmxpY3QiLCJnZXRJbnRlcm5hbEVycm9yIiwiSU5URVJOQUxfU0VSVkVSX0VSUk9SIiwiU0VSVklDRV9VTkFWQUlMQUJMRSIsIlNVUFBPUlRfRVJST1JTIiwiVEZBX0RJU0FCTEVEIiwiSU5URVJOQUxfRVJST1IiLCJBUFBfRVJST1IiLCJQUk9GSUxFX0VSUk9SIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBQ0E7O0FBR0E7Ozs7QUFhZSxrQkFBVUEsSUFBVixFQUF1QkMsTUFBdkIsRUFBdUM7QUFDcEQsUUFBTUMsWUFBWSxHQUFHLHNCQUFyQjtBQUErQjs7QUFDL0IsV0FBU0MsWUFBVCxDQUFzQkMsSUFBdEIsRUFBNkM7QUFDM0MsV0FBTztBQUNMQyxNQUFBQSxHQUFHLEVBQUUsS0FEQTtBQUVMRCxNQUFBQSxJQUZLO0FBR0xFLE1BQUFBLEtBQUssRUFBRSxFQUhGO0FBSUxDLE1BQUFBLGNB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NEI7QUFDakMsYUFBT1csSUFBSSxDQUFDYyxpQkFBVUMsT0FBVixDQUFrQlYsdUJBQVlvQixtQkFBOUIsRUFBbURDLDBCQUFlQyxZQUFsRSxDQUFELENBQVg7QUFDRCxLQUZNLE1BRUE7QUFDTCxhQUFPM0IsSUFBSSxDQUFDYyxpQkFBVUMsT0FBVixDQUFrQlYsdUJBQVl1QixjQUE5QixFQUE4Q0MscUJBQVVDLGFBQXhELENBQUQsQ0FBWDtBQUNEO0FBQ0YsR0FqQ0Q7QUFtQ0EsU0FBTzVDLFlBQVA7QUFDRCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBfIGZyb20gJ2xvZGFzaCc7XG5pbXBvcnQgeyBSZXNwb25zZSwgUm91dGVyIH0gZnJvbSAnZXhwcmVzcyc7XG5pbXBvcnQgeyBBUElfRVJST1IsIEFQUF9FUlJPUiwgSFRUUF9TVEFUVVMsIFNVUFBPUlRfRVJST1JTIH0gZnJvbSAnLi4vLi4vLi4vLi4vbGliL2NvbnN0YW50cyc7XG5pbXBvcnQgeyBFcnJvckNvZGUgfSBmcm9tICcuLi8uLi8uLi8uLi9saWIvdXRpbHMnO1xuaW1wb3J0IHsgdmFsaWRhdGVQYXNzd29yZCB9IGZyb20gJy4uLy4uLy4uLy4uL2xpYi9hdXRoLXV0aWxzJztcblxuaW1wb3J0IHsgJE5leHRGdW5jdGlvblZlciwgJFJlcXVlc3RFeHRlbmQsIElBdXRoIH0gZnJvbSAnLi4vLi4vLi4vLi4vLi4vdHlwZXMnO1xuaW1wb3J0IHsgbGltaXRlciB9IGZyb20gJy4uLy4uLy4uL3JhdGUtbGltaXRlcic7XG5cbmV4cG9ydCBpbnRlcmZhY2UgUHJvZmlsZSB7XG4gIHRmYTogYm9vbGVhbjtcbiAgbmFtZTogc3RyaW5nO1xuICBlbWFpbDogc3RyaW5nO1xuICBlbWFpbF92ZXJpZmllZDogYm9vbGVhbjtcbiAgY3JlYXRlZDogc3RyaW5nO1xuICB1cGRhdGVkOiBzdHJpbmc7XG4gIGNpZHJfd2hpdGVsaXN0OiBzdHJpbmdbXSB8IG51bGw7XG4gIGZ1bGxuYW1lOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIChhdXRoOiBJQXV0aCwgY29uZmlnKTogUm91dGVyIHtcbiAgY29uc3QgcHJvZmlsZVJvdXRlID0gUm91dGVyKCk7IC8qIGVzbGludCBuZXctY2FwOiAwICovXG4gIGZ1bmN0aW9uIGJ1aWxkUHJvZmlsZShuYW1lOiBzdHJpbmcpOiBQcm9maWxlIHtcbiAgICByZXR1cm4ge1xuICAgICAgdGZhOiBmYWxzZSxcbiAgICAgIG5hbWUsXG4gICAgICBlbWFpbDogJycsXG4gICAgICBlbWFpbF92ZXJpZmllZDogZmFsc2UsXG4gICAgICBjcmVhdGVkOiAnJyxcbiAgICAgIHVwZGF0ZWQ6ICcnLFxuICAgICAgY2lkcl93aGl0ZWxpc3Q6IG51bGwsXG4gICAgICBmdWxsbmFtZTogJycsXG4gICAgfTtcbiAgfVxuXG4gIHByb2ZpbGVSb3V0ZS5nZXQoJy91c2VyJywgbGltaXRlcihjb25maWc/LnVzZXJSYXRlTGltaXQpLCBmdW5jdGlvbiAocmVxOiAkUmVxdWVzdEV4dGVuZCwgcmVzOiBSZXNwb25zZSwgbmV4dDogJE5leHRGdW5jdGlvblZlcik6IHZvaWQge1xuICAgIGlmIChfLmlzTmlsKHJlcS5yZW1vdGVfdXNlci5uYW1lKSA9PT0gZmFsc2UpIHtcbiAgICAgIHJldHVybiBuZXh0KGJ1aWxkUHJvZmlsZShyZXEucmVtb3RlX3VzZXIubmFtZSkpO1xuICAgIH1cblxuICAgIHJlcy5zdGF0dXMoSFRUUF9TVEFUVVMuVU5BVVRIT1JJWkVEKTtcbiAgICByZXR1cm4gbmV4dCh7XG4gICAgICBtZXNzYWdlOiBBUElfRVJST1IuTVVTVF9CRV9MT0dHRUQsXG4gICAgfSk7XG4gIH0pO1xuXG4gIHByb2ZpbGVSb3V0ZS5wb3N0KCcvdXNlcicsIGxpbWl0ZXIoY29uZmlnPy51c2VyUmF0ZUxpbWl0KSwgZnVuY3Rpb24gKHJlcTogJFJlcXVlc3RFeHRlbmQsIHJlczogUmVzcG9uc2UsIG5leHQ6ICROZXh0RnVuY3Rpb25WZXIpOiB2b2lkIHtcbiAgICBpZiAoXy5pc05pbChyZXEucmVtb3RlX3VzZXIubmFtZSkpIHtcbiAgICAgIHJlcy5zdGF0dXMoSFRUUF9TVEFUVVMuVU5BVVRIT1JJWkVEKTtcbiAgICAgIHJldHVybiBuZXh0KHtcbiAgICAgICAgbWVzc2FnZTogQVBJX0VSUk9SLk1VU1RfQkVfTE9HR0VELFxuICAgICAgfSk7XG4gICAgfVxuXG4gICAgY29uc3QgeyBwYXNzd29yZCwgdGZhIH0gPSByZXEuYm9keTtcbiAgICBjb25zdCB7IG5hbWUgfSA9IHJlcS5yZW1vdGVfdXNlcjtcblxuICAgIGlmIChfLmlzTmlsKHBhc3N3b3JkKSA9PT0gZmFsc2UpIHtcbiAgICAgIGlmICh2YWxpZGF0ZVBhc3N3b3JkKHBhc3N3b3JkLm5ldykgPT09IGZhbHNlKSB7XG4gICAgICAgIC8qIGVzbGludCBuZXctY2FwOm9mZiAqL1xuICAgICAgICByZXR1cm4gbmV4dChFcnJvckNvZGUuZ2V0Q29kZShIVFRQX1NUQVRVUy5VTkFVVEhPUklaRUQsIEFQSV9FUlJPUi5QQVNTV09SRF9TSE9SVCgpKSk7XG4gICAgICAgIC8qIGVzbGludCBuZXctY2FwOm9mZiAqL1xuICAgICAgfVxuXG4gICAgICBhdXRoLmNoYW5nZVBhc3N3b3JkKG5hbWUsIHBhc3N3b3JkLm9sZCwgcGFzc3dvcmQubmV3LCAoZXJyLCBpc1VwZGF0ZWQpOiAkTmV4dEZ1bmN0aW9uVmVyID0+IHtcbiAgICAgICAgaWYgKF8uaXNOdWxsKGVycikgPT09IGZhbHNlKSB7XG4gICAgICAgICAgcmV0dXJuIG5leHQoRXJyb3JDb2RlLmdldENvZGUoZXJyLnN0YXR1cywgZXJyLm1lc3NhZ2UpIHx8IEVycm9yQ29kZS5nZXRDb25mbGljdChlcnIubWVzc2FnZSkpO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKGlzVXBkYXRlZCkge1xuICAgICAgICAgIHJldHVybiBuZXh0KGJ1aWxkUHJvZmlsZShyZXEucmVtb3RlX3VzZXIubmFtZSkpO1xuICAgICAgICB9XG4gICAgICAgIHJldHVybiBuZXh0KEVycm9yQ29kZS5nZXRJbnRlcm5hbEVycm9yKEFQSV9FUlJPUi5JTlRFUk5BTF9TRVJWRVJfRVJST1IpKTtcbiAgICAgIH0pO1xuICAgIH0gZWxzZSBpZiAoXy5pc05pbCh0ZmEpID09PSBmYWxzZSkge1xuICAgICAgcmV0dXJuIG5leHQoRXJyb3JDb2RlLmdldENvZGUoSFRUUF9TVEFUVVMuU0VSVklDRV9VTkFWQUlMQUJMRSwgU1VQUE9SVF9FUlJPUlMuVEZBX0RJU0FCTEVEKSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHJldHVybiBuZXh0KEVycm9yQ29kZS5nZXRDb2RlKEhUVFBfU1RBVFVTLklOVEVSTkFMX0VSUk9SLCBBUFBfRVJST1IuUFJPRklMRV9FUlJPUikpO1xuICAgIH1cbiAgfSk7XG5cbiAgcmV0dXJuIHByb2ZpbGVSb3V0ZTtcbn1cbiJdfQ==
|
|
@@ -9,6 +9,8 @@ var _lodash = _interopRequireDefault(require("lodash"));
|
|
|
9
9
|
|
|
10
10
|
var _debug = _interopRequireDefault(require("debug"));
|
|
11
11
|
|
|
12
|
+
var _express = require("express");
|
|
13
|
+
|
|
12
14
|
var _constants = require("../../../../lib/constants");
|
|
13
15
|
|
|
14
16
|
var _utils = require("../../../../lib/utils");
|
|
@@ -19,6 +21,8 @@ var _cryptoUtils = require("../../../../lib/crypto-utils");
|
|
|
19
21
|
|
|
20
22
|
var _logger = require("../../../../lib/logger");
|
|
21
23
|
|
|
24
|
+
var _rateLimiter = require("../../../rate-limiter");
|
|
25
|
+
|
|
22
26
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
23
27
|
|
|
24
28
|
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
@@ -36,8 +40,11 @@ function normalizeToken(token) {
|
|
|
36
40
|
} // https://github.com/npm/npm-profile/blob/latest/lib/index.js
|
|
37
41
|
|
|
38
42
|
|
|
39
|
-
function _default(
|
|
40
|
-
|
|
43
|
+
function _default(auth, storage, config) {
|
|
44
|
+
const tokenRoute = (0, _express.Router)();
|
|
45
|
+
/* eslint new-cap: 0 */
|
|
46
|
+
|
|
47
|
+
tokenRoute.get('/tokens', (0, _rateLimiter.limiter)(config === null || config === void 0 ? void 0 : config.userRateLimit), async function (req, res, next) {
|
|
41
48
|
const {
|
|
42
49
|
name
|
|
43
50
|
} = req.remote_user;
|
|
@@ -68,7 +75,7 @@ function _default(route, auth, storage, config) {
|
|
|
68
75
|
|
|
69
76
|
return next(_utils.ErrorCode.getUnauthorized());
|
|
70
77
|
});
|
|
71
|
-
|
|
78
|
+
tokenRoute.post('/tokens', (0, _rateLimiter.limiter)(config === null || config === void 0 ? void 0 : config.userRateLimit), function (req, res, next) {
|
|
72
79
|
const {
|
|
73
80
|
password,
|
|
74
81
|
readonly,
|
|
@@ -115,6 +122,7 @@ function _default(route, auth, storage, config) {
|
|
|
115
122
|
};
|
|
116
123
|
await storage.saveToken(saveToken);
|
|
117
124
|
debug('token %o was created for user %o', key, name);
|
|
125
|
+
res.set(_constants.HEADERS.CACHE_CONTROL, 'no-cache, no-store');
|
|
118
126
|
return next(normalizeToken({
|
|
119
127
|
token,
|
|
120
128
|
user: name,
|
|
@@ -132,7 +140,7 @@ function _default(route, auth, storage, config) {
|
|
|
132
140
|
}
|
|
133
141
|
});
|
|
134
142
|
});
|
|
135
|
-
|
|
143
|
+
tokenRoute.delete('/tokens/token/:tokenKey', (0, _rateLimiter.limiter)(config === null || config === void 0 ? void 0 : config.userRateLimit), async (req, res, next) => {
|
|
136
144
|
const {
|
|
137
145
|
params: {
|
|
138
146
|
tokenKey
|
|
@@ -165,5 +173,6 @@ function _default(route, auth, storage, config) {
|
|
|
165
173
|
|
|
166
174
|
return next(_utils.ErrorCode.getUnauthorized());
|
|
167
175
|
});
|
|
176
|
+
return tokenRoute;
|
|
168
177
|
}
|
|
169
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/api/endpoint/api/v1/token.ts"],"names":["debug","normalizeToken","token","created","Date","toISOString","route","auth","storage","config","get","req","res","next","name","remote_user","_","isNil","tokens","readTokens","user","totalTokens","length","status","HTTP_STATUS","OK","objects","map","urls","error","logger","msg","ErrorCode","getCode","INTERNAL_ERROR","message","getUnauthorized","post","password","readonly","cidr_whitelist","body","isBoolean","isArray","BAD_DATA","SUPPORT_ERRORS","PARAMETERS_NOT_VALID","authenticate","err","errorCode","UNAUTHORIZED","isFunction","saveToken","NOT_IMPLEMENTED","STORAGE_NOT_IMPLEMENT","key","maskedToken","getTime","cidr","delete","params","tokenKey","deleteToken","info"],"mappings":";;;;;;;AAAA;;AACA;;AAGA;;AACA;;AACA;;AACA;;AACA;;;;;;;;;;AAIA,MAAMA,KAAK,GAAG,oBAAW,iBAAX,CAAd;;AAKA,SAASC,cAAT,CAAwBC,KAAxB,EAAsD;AACpD,yCACKA,KADL;AAEEC,IAAAA,OAAO,EAAE,IAAIC,IAAJ,CAASF,KAAK,CAACC,OAAf,EAAwBE,WAAxB;AAFX;AAID,C,CAED;;;AACe,kBAAUC,KAAV,EAAyBC,IAAzB,EAAsCC,OAAtC,EAAgEC,MAAhE,EAAsF;AACnGH,EAAAA,KAAK,CAACI,GAAN,CAAU,kBAAV,EAA8B,gBAAgBC,GAAhB,EAAqCC,GAArC,EAAoDC,IAApD,EAA4E;AACxG,UAAM;AAAEC,MAAAA;AAAF,QAAWH,GAAG,CAACI,WAArB;;AAEA,QAAIC,gBAAEC,KAAF,CAAQH,IAAR,MAAkB,KAAtB,EAA6B;AAC3B,UAAI;AACF,cAAMI,MAAM,GAAG,MAAMV,OAAO,CAACW,UAAR,CAAmB;AAAEC,UAAAA,IAAI,EAAEN;AAAR,SAAnB,CAArB;AACA,cAAMO,WAAW,GAAGH,MAAM,CAACI,MAA3B;AACAtB,QAAAA,KAAK,CAAC,0BAAD,EAA6BqB,WAA7B,CAAL;AACAT,QAAAA,GAAG,CAACW,MAAJ,CAAWC,uBAAYC,EAAvB;AACA,eAAOZ,IAAI,CAAC;AACVa,UAAAA,OAAO,EAAER,MAAM,CAACS,GAAP,CAAW1B,cAAX,CADC;AAEV2B,UAAAA,IAAI,EAAE;AACJf,YAAAA,IAAI,EAAE,EADF,CACM;;AADN;AAFI,SAAD,CAAX;AAMD,OAXD,CAWE,OAAOgB,KAAP,EAAc;AACdC,uBAAOD,KAAP,CAAa;AAAEA,UAAAA,KAAK,EAAEA,KAAK,CAACE;AAAf,SAAb,EAAmC,iCAAnC;;AACA,eAAOlB,IAAI,CAACmB,iBAAUC,OAAV,CAAkBT,uBAAYU,cAA9B,EAA8CL,KAAK,CAACM,OAApD,CAAD,CAAX;AACD;AACF;;AACD,WAAOtB,IAAI,CAACmB,iBAAUI,eAAV,EAAD,CAAX;AACD,GArBD;AAuBA9B,EAAAA,KAAK,CAAC+B,IAAN,CAAW,kBAAX,EAA+B,UAAU1B,GAAV,EAA+BC,GAA/B,EAA8CC,IAA9C,EAAsE;AACnG,UAAM;AAAEyB,MAAAA,QAAF;AAAYC,MAAAA,QAAZ;AAAsBC,MAAAA;AAAtB,QAAyC7B,GAAG,CAAC8B,IAAnD;AACA,UAAM;AAAE3B,MAAAA;AAAF,QAAWH,GAAG,CAACI,WAArB;;AAEA,QAAI,CAACC,gBAAE0B,SAAF,CAAYH,QAAZ,CAAD,IAA0B,CAACvB,gBAAE2B,OAAF,CAAUH,cAAV,CAA/B,EAA0D;AACxD,aAAO3B,IAAI,CAACmB,iBAAUC,OAAV,CAAkBT,uBAAYoB,QAA9B,EAAwCC,0BAAeC,oBAAvD,CAAD,CAAX;AACD;;AAEDvC,IAAAA,IAAI,CAACwC,YAAL,CAAkBjC,IAAlB,EAAwBwB,QAAxB,EAAkC,OAAOU,GAAP,EAAY5B,IAAZ,KAAiC;AACjE,UAAI4B,GAAJ,EAAS;AACP,cAAMC,SAAS,GAAGD,GAAG,CAACb,OAAJ,GAAcX,uBAAY0B,YAA1B,GAAyC1B,uBAAYU,cAAvE;AACA,eAAOrB,IAAI,CAACmB,iBAAUC,OAAV,CAAkBgB,SAAlB,EAA6BD,GAAG,CAACb,OAAjC,CAAD,CAAX;AACD;;AAEDxB,MAAAA,GAAG,CAACI,WAAJ,GAAkBK,IAAlB;;AAEA,UAAI,CAACJ,gBAAEmC,UAAF,CAAa3C,OAAO,CAAC4C,SAArB,CAAL,EAAsC;AACpC,eAAOvC,IAAI,CAACmB,iBAAUC,OAAV,CAAkBT,uBAAY6B,eAA9B,EAA+CR,0BAAeS,qBAA9D,CAAD,CAAX;AACD;;AAED,UAAI;AACF,cAAMpD,KAAK,GAAG,MAAM,4BAAYK,IAAZ,EAAkBE,MAAlB,EAA0BW,IAA1B,EAAgCkB,QAAhC,CAApB;AACA,cAAMiB,GAAG,GAAG,8BAAYrD,KAAZ,CAAZ,CAFE,CAGF;;AACA,cAAMsD,WAAW,GAAG,iBAAKtD,KAAL,EAAY,CAAZ,CAApB;AACA,cAAMC,OAAO,GAAG,IAAIC,IAAJ,GAAWqD,OAAX,EAAhB;AAEA;AACR;AACA;AACA;;AACQ,cAAML,SAAgB,GAAG;AACvBhC,UAAAA,IAAI,EAAEN,IADiB;AAEvBZ,UAAAA,KAAK,EAAEsD,WAFgB;AAGvBD,UAAAA,GAHuB;AAIvBG,UAAAA,IAAI,EAAElB,cAJiB;AAKvBD,UAAAA,QALuB;AAMvBpC,UAAAA;AANuB,SAAzB;AASA,cAAMK,OAAO,CAAC4C,SAAR,CAAkBA,SAAlB,CAAN;AACApD,QAAAA,KAAK,CAAC,kCAAD,EAAqCuD,GAArC,EAA0CzC,IAA1C,CAAL;AACA,eAAOD,IAAI,CACTZ,cAAc,CAAC;AACbC,UAAAA,KADa;AAEbkB,UAAAA,IAAI,EAAEN,IAFO;AAGbyC,UAAAA,GAAG,EAAEH,SAAS,CAACG,GAHF;AAIbG,UAAAA,IAAI,EAAElB,cAJO;AAKbD,UAAAA,QALa;AAMbpC,UAAAA,OAAO,EAAEiD,SAAS,CAACjD;AANN,SAAD,CADL,CAAX;AAUD,OAhCD,CAgCE,OAAO0B,KAAP,EAAc;AACdC,uBAAOD,KAAP,CAAa;AAAEA,UAAAA,KAAK,EAAEA,KAAK,CAACE;AAAf,SAAb,EAAmC,qCAAnC;;AACA,eAAOlB,IAAI,CAACmB,iBAAUC,OAAV,CAAkBT,uBAAYU,cAA9B,EAA8CL,KAAK,CAACM,OAApD,CAAD,CAAX;AACD;AACF,KAhDD;AAiDD,GAzDD;AA2DA7B,EAAAA,KAAK,CAACqD,MAAN,CAAa,kCAAb,EAAiD,OAAOhD,GAAP,EAA4BC,GAA5B,EAA2CC,IAA3C,KAAsE;AACrH,UAAM;AACJ+C,MAAAA,MAAM,EAAE;AAAEC,QAAAA;AAAF;AADJ,QAEFlD,GAFJ;AAGA,UAAM;AAAEG,MAAAA;AAAF,QAAWH,GAAG,CAACI,WAArB;;AAEA,QAAIC,gBAAEC,KAAF,CAAQH,IAAR,MAAkB,KAAtB,EAA6B;AAC3Bd,MAAAA,KAAK,CAAC,iCAAD,EAAoCc,IAApC,CAAL;;AACA,UAAI;AACF,cAAMN,OAAO,CAACsD,WAAR,CAAoBhD,IAApB,EAA0B+C,QAA1B,CAAN;;AACA/B,uBAAOiC,IAAP,CAAY;AAAEF,UAAAA,QAAF;AAAY/C,UAAAA;AAAZ,SAAZ,EAAgC,mDAAhC;;AACA,eAAOD,IAAI,CAAC,EAAD,CAAX;AACD,OAJD,CAIE,OAAOgB,KAAP,EAAc;AACdC,uBAAOD,KAAP,CAAa;AAAEA,UAAAA,KAAK,EAAEA,KAAK,CAACE;AAAf,SAAb,EAAmC,qCAAnC;;AACA,eAAOlB,IAAI,CAACmB,iBAAUC,OAAV,CAAkBT,uBAAYU,cAA9B,EAA8CL,KAAK,CAACM,OAApD,CAAD,CAAX;AACD;AACF;;AACD,WAAOtB,IAAI,CAACmB,iBAAUI,eAAV,EAAD,CAAX;AACD,GAlBD;AAmBD","sourcesContent":["import _ from 'lodash';\nimport buildDebug from 'debug';\nimport { Response, Router } from 'express';\nimport { Config, RemoteUser, Token } from '@verdaccio/types';\nimport { HTTP_STATUS, SUPPORT_ERRORS } from '../../../../lib/constants';\nimport { ErrorCode, mask } from '../../../../lib/utils';\nimport { getApiToken } from '../../../../lib/auth-utils';\nimport { stringToMD5 } from '../../../../lib/crypto-utils';\nimport { logger } from '../../../../lib/logger';\n\nimport { $NextFunctionVer, $RequestExtend, IAuth, IStorageHandler } from '../../../../../types';\n\nconst debug = buildDebug('verdaccio:token');\nexport type NormalizeToken = Token & {\n  created: string;\n};\n\nfunction normalizeToken(token: Token): NormalizeToken {\n  return {\n    ...token,\n    created: new Date(token.created).toISOString(),\n  };\n}\n\n// https://github.com/npm/npm-profile/blob/latest/lib/index.js\nexport default function (route: Router, auth: IAuth, storage: IStorageHandler, config: Config): void {\n  route.get('/-/npm/v1/tokens', async function (req: $RequestExtend, res: Response, next: $NextFunctionVer) {\n    const { name } = req.remote_user;\n\n    if (_.isNil(name) === false) {\n      try {\n        const tokens = await storage.readTokens({ user: name });\n        const totalTokens = tokens.length;\n        debug('token list retrieved: %o', totalTokens);\n        res.status(HTTP_STATUS.OK);\n        return next({\n          objects: tokens.map(normalizeToken),\n          urls: {\n            next: '', // TODO: pagination?\n          },\n        });\n      } catch (error) {\n        logger.error({ error: error.msg }, 'token list has failed: @{error}');\n        return next(ErrorCode.getCode(HTTP_STATUS.INTERNAL_ERROR, error.message));\n      }\n    }\n    return next(ErrorCode.getUnauthorized());\n  });\n\n  route.post('/-/npm/v1/tokens', function (req: $RequestExtend, res: Response, next: $NextFunctionVer) {\n    const { password, readonly, cidr_whitelist } = req.body;\n    const { name } = req.remote_user;\n\n    if (!_.isBoolean(readonly) || !_.isArray(cidr_whitelist)) {\n      return next(ErrorCode.getCode(HTTP_STATUS.BAD_DATA, SUPPORT_ERRORS.PARAMETERS_NOT_VALID));\n    }\n\n    auth.authenticate(name, password, async (err, user: RemoteUser) => {\n      if (err) {\n        const errorCode = err.message ? HTTP_STATUS.UNAUTHORIZED : HTTP_STATUS.INTERNAL_ERROR;\n        return next(ErrorCode.getCode(errorCode, err.message));\n      }\n\n      req.remote_user = user;\n\n      if (!_.isFunction(storage.saveToken)) {\n        return next(ErrorCode.getCode(HTTP_STATUS.NOT_IMPLEMENTED, SUPPORT_ERRORS.STORAGE_NOT_IMPLEMENT));\n      }\n\n      try {\n        const token = await getApiToken(auth, config, user, password);\n        const key = stringToMD5(token);\n        // TODO: use a utility here\n        const maskedToken = mask(token, 5);\n        const created = new Date().getTime();\n\n        /**\n         * cidr_whitelist: is not being used, we pass it through\n         * token: we do not store the real token (it is generated once and retrieved to the user), just a mask of it.\n         */\n        const saveToken: Token = {\n          user: name,\n          token: maskedToken,\n          key,\n          cidr: cidr_whitelist,\n          readonly,\n          created,\n        };\n\n        await storage.saveToken(saveToken);\n        debug('token %o was created for user %o', key, name);\n        return next(\n          normalizeToken({\n            token,\n            user: name,\n            key: saveToken.key,\n            cidr: cidr_whitelist,\n            readonly,\n            created: saveToken.created,\n          })\n        );\n      } catch (error) {\n        logger.error({ error: error.msg }, 'token creation has failed: @{error}');\n        return next(ErrorCode.getCode(HTTP_STATUS.INTERNAL_ERROR, error.message));\n      }\n    });\n  });\n\n  route.delete('/-/npm/v1/tokens/token/:tokenKey', async (req: $RequestExtend, res: Response, next: $NextFunctionVer) => {\n    const {\n      params: { tokenKey },\n    } = req;\n    const { name } = req.remote_user;\n\n    if (_.isNil(name) === false) {\n      debug('%o has requested remove a token', name);\n      try {\n        await storage.deleteToken(name, tokenKey);\n        logger.info({ tokenKey, name }, 'token id @{tokenKey} was revoked for user @{name}');\n        return next({});\n      } catch (error) {\n        logger.error({ error: error.msg }, 'token creation has failed: @{error}');\n        return next(ErrorCode.getCode(HTTP_STATUS.INTERNAL_ERROR, error.message));\n      }\n    }\n    return next(ErrorCode.getUnauthorized());\n  });\n}\n"]}
|
|
178
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../../src/api/endpoint/api/v1/token.ts"],"names":["debug","normalizeToken","token","created","Date","toISOString","auth","storage","config","tokenRoute","get","userRateLimit","req","res","next","name","remote_user","_","isNil","tokens","readTokens","user","totalTokens","length","status","HTTP_STATUS","OK","objects","map","urls","error","logger","msg","ErrorCode","getCode","INTERNAL_ERROR","message","getUnauthorized","post","password","readonly","cidr_whitelist","body","isBoolean","isArray","BAD_DATA","SUPPORT_ERRORS","PARAMETERS_NOT_VALID","authenticate","err","errorCode","UNAUTHORIZED","isFunction","saveToken","NOT_IMPLEMENTED","STORAGE_NOT_IMPLEMENT","key","maskedToken","getTime","cidr","set","HEADERS","CACHE_CONTROL","delete","params","tokenKey","deleteToken","info"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport buildDebug from 'debug';\nimport { Response, Router } from 'express';\nimport { Config, RemoteUser, Token } from '@verdaccio/types';\nimport { HEADERS, HTTP_STATUS, SUPPORT_ERRORS } from '../../../../lib/constants';\nimport { ErrorCode, mask } from '../../../../lib/utils';\nimport { getApiToken } from '../../../../lib/auth-utils';\nimport { stringToMD5 } from '../../../../lib/crypto-utils';\nimport { logger } from '../../../../lib/logger';\n\nimport { $NextFunctionVer, $RequestExtend, IAuth, IStorageHandler } from '../../../../../types';\nimport { limiter } from '../../../rate-limiter';\n\nconst debug = buildDebug('verdaccio:token');\nexport type NormalizeToken = Token & {\n  created: string;\n};\n\nfunction normalizeToken(token: Token): NormalizeToken {\n  return {\n    ...token,\n    created: new Date(token.created).toISOString(),\n  };\n}\n\n// https://github.com/npm/npm-profile/blob/latest/lib/index.js\nexport default function (auth: IAuth, storage: IStorageHandler, config: Config): Router {\n  const tokenRoute = Router(); /* eslint new-cap: 0 */\n  tokenRoute.get('/tokens', limiter(config?.userRateLimit), async function (req: $RequestExtend, res: Response, next: $NextFunctionVer) {\n    const { name } = req.remote_user;\n\n    if (_.isNil(name) === false) {\n      try {\n        const tokens = await storage.readTokens({ user: name });\n        const totalTokens = tokens.length;\n        debug('token list retrieved: %o', totalTokens);\n        res.status(HTTP_STATUS.OK);\n        return next({\n          objects: tokens.map(normalizeToken),\n          urls: {\n            next: '', // TODO: pagination?\n          },\n        });\n      } catch (error) {\n        logger.error({ error: error.msg }, 'token list has failed: @{error}');\n        return next(ErrorCode.getCode(HTTP_STATUS.INTERNAL_ERROR, error.message));\n      }\n    }\n    return next(ErrorCode.getUnauthorized());\n  });\n\n  tokenRoute.post('/tokens', limiter(config?.userRateLimit), function (req: $RequestExtend, res: Response, next: $NextFunctionVer) {\n    const { password, readonly, cidr_whitelist } = req.body;\n    const { name } = req.remote_user;\n\n    if (!_.isBoolean(readonly) || !_.isArray(cidr_whitelist)) {\n      return next(ErrorCode.getCode(HTTP_STATUS.BAD_DATA, SUPPORT_ERRORS.PARAMETERS_NOT_VALID));\n    }\n\n    auth.authenticate(name, password, async (err, user: RemoteUser) => {\n      if (err) {\n        const errorCode = err.message ? HTTP_STATUS.UNAUTHORIZED : HTTP_STATUS.INTERNAL_ERROR;\n        return next(ErrorCode.getCode(errorCode, err.message));\n      }\n\n      req.remote_user = user;\n\n      if (!_.isFunction(storage.saveToken)) {\n        return next(ErrorCode.getCode(HTTP_STATUS.NOT_IMPLEMENTED, SUPPORT_ERRORS.STORAGE_NOT_IMPLEMENT));\n      }\n\n      try {\n        const token = await getApiToken(auth, config, user, password);\n        const key = stringToMD5(token);\n        // TODO: use a utility here\n        const maskedToken = mask(token, 5);\n        const created = new Date().getTime();\n\n        /**\n         * cidr_whitelist: is not being used, we pass it through\n         * token: we do not store the real token (it is generated once and retrieved to the user), just a mask of it.\n         */\n        const saveToken: Token = {\n          user: name,\n          token: maskedToken,\n          key,\n          cidr: cidr_whitelist,\n          readonly,\n          created,\n        };\n\n        await storage.saveToken(saveToken);\n        debug('token %o was created for user %o', key, name);\n        res.set(HEADERS.CACHE_CONTROL, 'no-cache, no-store');\n        return next(\n          normalizeToken({\n            token,\n            user: name,\n            key: saveToken.key,\n            cidr: cidr_whitelist,\n            readonly,\n            created: saveToken.created,\n          })\n        );\n      } catch (error) {\n        logger.error({ error: error.msg }, 'token creation has failed: @{error}');\n        return next(ErrorCode.getCode(HTTP_STATUS.INTERNAL_ERROR, error.message));\n      }\n    });\n  });\n\n  tokenRoute.delete('/tokens/token/:tokenKey', limiter(config?.userRateLimit), async (req: $RequestExtend, res: Response, next: $NextFunctionVer) => {\n    const {\n      params: { tokenKey },\n    } = req;\n    const { name } = req.remote_user;\n\n    if (_.isNil(name) === false) {\n      debug('%o has requested remove a token', name);\n      try {\n        await storage.deleteToken(name, tokenKey);\n        logger.info({ tokenKey, name }, 'token id @{tokenKey} was revoked for user @{name}');\n        return next({});\n      } catch (error) {\n        logger.error({ error: error.msg }, 'token creation has failed: @{error}');\n        return next(ErrorCode.getCode(HTTP_STATUS.INTERNAL_ERROR, error.message));\n      }\n    }\n    return next(ErrorCode.getUnauthorized());\n  });\n\n  return tokenRoute;\n}\n"]}
|
|
@@ -25,9 +25,7 @@ var _package = _interopRequireDefault(require("./api/package"));
|
|
|
25
25
|
|
|
26
26
|
var _stars = _interopRequireDefault(require("./api/stars"));
|
|
27
27
|
|
|
28
|
-
var
|
|
29
|
-
|
|
30
|
-
var _token = _interopRequireDefault(require("./api/v1/token"));
|
|
28
|
+
var _v = _interopRequireDefault(require("./api/v1"));
|
|
31
29
|
|
|
32
30
|
var _search2 = _interopRequireDefault(require("./api/v1/search"));
|
|
33
31
|
|
|
@@ -71,15 +69,14 @@ function _default(config, auth, storage) {
|
|
|
71
69
|
|
|
72
70
|
(0, _whoami.default)(app);
|
|
73
71
|
(0, _package.default)(app, auth, storage, config);
|
|
74
|
-
(0, _profile.default)(app, auth);
|
|
75
72
|
(0, _search.default)(app, auth, storage);
|
|
76
|
-
(0, _user.default)(app, auth, config);
|
|
77
73
|
(0, _distTags.default)(app, auth, storage);
|
|
78
74
|
(0, _publish.default)(app, auth, storage, config);
|
|
79
75
|
(0, _ping.default)(app);
|
|
80
76
|
(0, _stars.default)(app, storage);
|
|
81
77
|
(0, _search2.default)(app, auth, storage);
|
|
82
|
-
(0,
|
|
78
|
+
(0, _user.default)(app, auth, config);
|
|
79
|
+
app.use((0, _v.default)(auth, storage, config));
|
|
83
80
|
return app;
|
|
84
81
|
}
|
|
85
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
82
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hcGkvZW5kcG9pbnQvaW5kZXgudHMiXSwibmFtZXMiOlsibWF0Y2giLCJ2YWxpZGF0ZU5hbWUiLCJ2YWxpZGF0ZVBhY2thZ2UiLCJlbmNvZGVTY29wZVBhY2thZ2UiLCJhbnRpTG9vcCIsInJlcXVpcmUiLCJjb25maWciLCJhdXRoIiwic3RvcmFnZSIsImFwcCIsImV4cHJlc3MiLCJSb3V0ZXIiLCJwYXJhbSIsInVzZSIsImFwaUpXVG1pZGRsZXdhcmUiLCJib2R5UGFyc2VyIiwianNvbiIsInN0cmljdCIsImxpbWl0IiwibWF4X2JvZHlfc2l6ZSJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUVBOztBQUNBOztBQUVBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOztBQUNBOzs7O0FBRUEsTUFBTTtBQUFFQSxFQUFBQSxLQUFGO0FBQVNDLEVBQUFBLFlBQVQ7QUFBdUJDLEVBQUFBLGVBQXZCO0FBQXdDQyxFQUFBQSxrQkFBeEM7QUFBNERDLEVBQUFBO0FBQTVELElBQXlFQyxPQUFPLENBQUMsZUFBRCxDQUF0Rjs7QUFFZSxrQkFBVUMsTUFBVixFQUEwQkMsSUFBMUIsRUFBdUNDLE9BQXZDLEVBQWlFO0FBQzlFO0FBQ0EsUUFBTUMsR0FBRyxHQUFHQyxpQkFBUUMsTUFBUixFQUFaO0FBQ0E7QUFDQTtBQUNBOzs7QUFDQUYsRUFBQUEsR0FBRyxDQUFDRyxLQUFKLENBQVUsU0FBVixFQUFxQlYsZUFBckI7QUFDQU8sRUFBQUEsR0FBRyxDQUFDRyxLQUFKLENBQVUsVUFBVixFQUFzQlgsWUFBdEI7QUFDQVEsRUFBQUEsR0FBRyxDQUFDRyxLQUFKLENBQVUsS0FBVixFQUFpQlgsWUFBakI7QUFDQVEsRUFBQUEsR0FBRyxDQUFDRyxLQUFKLENBQVUsU0FBVixFQUFxQlgsWUFBckI7QUFDQVEsRUFBQUEsR0FBRyxDQUFDRyxLQUFKLENBQVUsVUFBVixFQUFzQlgsWUFBdEI7QUFDQVEsRUFBQUEsR0FBRyxDQUFDRyxLQUFKLENBQVUsT0FBVixFQUFtQlgsWUFBbkIsRUFYOEUsQ0FhOUU7QUFDQTs7QUFDQVEsRUFBQUEsR0FBRyxDQUFDRyxLQUFKLENBQVUsTUFBVixFQUFrQlosS0FBSyxDQUFDLFFBQUQsQ0FBdkI7QUFDQVMsRUFBQUEsR0FBRyxDQUFDRyxLQUFKLENBQVUsa0JBQVYsRUFBOEJaLEtBQUssQ0FBQyxzQkFBRCxDQUFuQztBQUNBUyxFQUFBQSxHQUFHLENBQUNHLEtBQUosQ0FBVSxVQUFWLEVBQXNCWixLQUFLLENBQUMsSUFBRCxDQUEzQjtBQUVBUyxFQUFBQSxHQUFHLENBQUNJLEdBQUosQ0FBUU4sSUFBSSxDQUFDTyxnQkFBTCxFQUFSO0FBQ0FMLEVBQUFBLEdBQUcsQ0FBQ0ksR0FBSixDQUFRRSxvQkFBV0MsSUFBWCxDQUFnQjtBQUFFQyxJQUFBQSxNQUFNLEVBQUUsS0FBVjtBQUFpQkMsSUFBQUEsS0FBSyxFQUFFWixNQUFNLENBQUNhLGFBQVAsSUFBd0I7QUFBaEQsR0FBaEIsQ0FBUjtBQUNBVixFQUFBQSxHQUFHLENBQUNJLEdBQUosQ0FBUVQsUUFBUSxDQUFDRSxNQUFELENBQWhCLEVBckI4RSxDQXNCOUU7O0FBQ0FHLEVBQUFBLEdBQUcsQ0FBQ0ksR0FBSixDQUFRVixrQkFBUixFQXZCOEUsQ0F3QjlFOztBQUNBLHVCQUFPTSxHQUFQO0FBQ0Esd0JBQUlBLEdBQUosRUFBU0YsSUFBVCxFQUFlQyxPQUFmLEVBQXdCRixNQUF4QjtBQUNBLHVCQUFPRyxHQUFQLEVBQVlGLElBQVosRUFBa0JDLE9BQWxCO0FBQ0EseUJBQVNDLEdBQVQsRUFBY0YsSUFBZCxFQUFvQkMsT0FBcEI7QUFDQSx3QkFBUUMsR0FBUixFQUFhRixJQUFiLEVBQW1CQyxPQUFuQixFQUE0QkYsTUFBNUI7QUFDQSxxQkFBS0csR0FBTDtBQUNBLHNCQUFNQSxHQUFOLEVBQVdELE9BQVg7QUFDQSx3QkFBU0MsR0FBVCxFQUFjRixJQUFkLEVBQW9CQyxPQUFwQjtBQUNBLHFCQUFLQyxHQUFMLEVBQVVGLElBQVYsRUFBZ0JELE1BQWhCO0FBQ0FHLEVBQUFBLEdBQUcsQ0FBQ0ksR0FBSixDQUFRLGdCQUFNTixJQUFOLEVBQVlDLE9BQVosRUFBcUJGLE1BQXJCLENBQVI7QUFDQSxTQUFPRyxHQUFQO0FBQ0QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb25maWcgfSBmcm9tICdAdmVyZGFjY2lvL3R5cGVzJztcbmltcG9ydCBfIGZyb20gJ2xvZGFzaCc7XG5pbXBvcnQgZXhwcmVzcyBmcm9tICdleHByZXNzJztcbmltcG9ydCBib2R5UGFyc2VyIGZyb20gJ2JvZHktcGFyc2VyJztcbmltcG9ydCB7IElBdXRoLCBJU3RvcmFnZUhhbmRsZXIgfSBmcm9tICcuLi8uLi8uLi90eXBlcyc7XG5pbXBvcnQgd2hvYW1pIGZyb20gJy4vYXBpL3dob2FtaSc7XG5pbXBvcnQgcGluZyBmcm9tICcuL2FwaS9waW5nJztcbmltcG9ydCB1c2VyIGZyb20gJy4vYXBpL3VzZXInO1xuaW1wb3J0IGRpc3RUYWdzIGZyb20gJy4vYXBpL2Rpc3QtdGFncyc7XG5pbXBvcnQgcHVibGlzaCBmcm9tICcuL2FwaS9wdWJsaXNoJztcbmltcG9ydCBzZWFyY2ggZnJvbSAnLi9hcGkvc2VhcmNoJztcbmltcG9ydCBwa2cgZnJvbSAnLi9hcGkvcGFja2FnZSc7XG5pbXBvcnQgc3RhcnMgZnJvbSAnLi9hcGkvc3RhcnMnO1xuaW1wb3J0IG5wbVYxIGZyb20gJy4vYXBpL3YxJztcbmltcG9ydCB2MVNlYXJjaCBmcm9tICcuL2FwaS92MS9zZWFyY2gnO1xuXG5jb25zdCB7IG1hdGNoLCB2YWxpZGF0ZU5hbWUsIHZhbGlkYXRlUGFja2FnZSwgZW5jb2RlU2NvcGVQYWNrYWdlLCBhbnRpTG9vcCB9ID0gcmVxdWlyZSgnLi4vbWlkZGxld2FyZScpO1xuXG5leHBvcnQgZGVmYXVsdCBmdW5jdGlvbiAoY29uZmlnOiBDb25maWcsIGF1dGg6IElBdXRoLCBzdG9yYWdlOiBJU3RvcmFnZUhhbmRsZXIpIHtcbiAgLyogZXNsaW50IG5ldy1jYXA6b2ZmICovXG4gIGNvbnN0IGFwcCA9IGV4cHJlc3MuUm91dGVyKCk7XG4gIC8qIGVzbGludCBuZXctY2FwOm9mZiAqL1xuICAvLyB2YWxpZGF0ZSBhbGwgb2YgdGhlc2UgcGFyYW1zIGFzIGEgcGFja2FnZSBuYW1lXG4gIC8vIHRoaXMgbWlnaHQgYmUgdG9vIGhhcnNoLCBzbyBhc2sgaWYgaXQgY2F1c2VzIHRyb3VibGVcbiAgYXBwLnBhcmFtKCdwYWNrYWdlJywgdmFsaWRhdGVQYWNrYWdlKTtcbiAgYXBwLnBhcmFtKCdmaWxlbmFtZScsIHZhbGlkYXRlTmFtZSk7XG4gIGFwcC5wYXJhbSgndGFnJywgdmFsaWRhdGVOYW1lKTtcbiAgYXBwLnBhcmFtKCd2ZXJzaW9uJywgdmFsaWRhdGVOYW1lKTtcbiAgYXBwLnBhcmFtKCdyZXZpc2lvbicsIHZhbGlkYXRlTmFtZSk7XG4gIGFwcC5wYXJhbSgndG9rZW4nLCB2YWxpZGF0ZU5hbWUpO1xuXG4gIC8vIHRoZXNlIGNhbid0IGJlIHNhZmVseSBwdXQgaW50byBleHByZXNzIHVybCBmb3Igc29tZSByZWFzb25cbiAgLy8gVE9ETzogRm9yIHNvbWUgcmVhc29uPyB3aGF0IHJlYXNvbj9cbiAgYXBwLnBhcmFtKCdfcmV2JywgbWF0Y2goL14tcmV2JC8pKTtcbiAgYXBwLnBhcmFtKCdvcmdfY291Y2hkYl91c2VyJywgbWF0Y2goL15vcmdcXC5jb3VjaGRiXFwudXNlcjovKSk7XG4gIGFwcC5wYXJhbSgnYW55dGhpbmcnLCBtYXRjaCgvLiovKSk7XG5cbiAgYXBwLnVzZShhdXRoLmFwaUpXVG1pZGRsZXdhcmUoKSk7XG4gIGFwcC51c2UoYm9keVBhcnNlci5qc29uKHsgc3RyaWN0OiBmYWxzZSwgbGltaXQ6IGNvbmZpZy5tYXhfYm9keV9zaXplIHx8ICcxMG1iJyB9KSk7XG4gIGFwcC51c2UoYW50aUxvb3AoY29uZmlnKSk7XG4gIC8vIGVuY29kZSAvIGluIGEgc2NvcGVkIHBhY2thZ2UgbmFtZSB0byBiZSBtYXRjaGVkIGFzIGEgc2luZ2xlIHBhcmFtZXRlciBpbiByb3V0ZXNcbiAgYXBwLnVzZShlbmNvZGVTY29wZVBhY2thZ2UpO1xuICAvLyBmb3IgXCJucG0gd2hvYW1pXCJcbiAgd2hvYW1pKGFwcCk7XG4gIHBrZyhhcHAsIGF1dGgsIHN0b3JhZ2UsIGNvbmZpZyk7XG4gIHNlYXJjaChhcHAsIGF1dGgsIHN0b3JhZ2UpO1xuICBkaXN0VGFncyhhcHAsIGF1dGgsIHN0b3JhZ2UpO1xuICBwdWJsaXNoKGFwcCwgYXV0aCwgc3RvcmFnZSwgY29uZmlnKTtcbiAgcGluZyhhcHApO1xuICBzdGFycyhhcHAsIHN0b3JhZ2UpO1xuICB2MVNlYXJjaChhcHAsIGF1dGgsIHN0b3JhZ2UpO1xuICB1c2VyKGFwcCwgYXV0aCwgY29uZmlnKTtcbiAgYXBwLnVzZShucG1WMShhdXRoLCBzdG9yYWdlLCBjb25maWcpKTtcbiAgcmV0dXJuIGFwcDtcbn1cbiJdfQ==
|
package/build/api/index.js
CHANGED
|
@@ -49,10 +49,16 @@ const defineAPI = function (config, storage) {
|
|
|
49
49
|
|
|
50
50
|
app.use((0, _middleware.log)(config));
|
|
51
51
|
app.use(_middleware.errorReportingMiddleware);
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
next
|
|
55
|
-
|
|
52
|
+
|
|
53
|
+
if (config.user_agent) {
|
|
54
|
+
app.use(function (req, res, next) {
|
|
55
|
+
res.setHeader('X-Powered-By', (0, _utils.getUserAgent)(config.user_agent));
|
|
56
|
+
next();
|
|
57
|
+
});
|
|
58
|
+
} else {
|
|
59
|
+
app.disable('x-powered-by');
|
|
60
|
+
}
|
|
61
|
+
|
|
56
62
|
app.use((0, _compression.default)());
|
|
57
63
|
app.get('/-/static/favicon.ico', (0, _middleware.serveFavicon)(config)); // Hook for tests only
|
|
58
64
|
|
|
@@ -125,4 +131,4 @@ var _default = async function _default(configHash) {
|
|
|
125
131
|
};
|
|
126
132
|
|
|
127
133
|
exports.default = _default;
|
|
128
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/api/index.ts"],"names":["defineAPI","config","storage","auth","Auth","app","set","process","env","NODE_ENV","use","errorReportingMiddleware","req","res","next","setHeader","user_agent","get","_debug","self_path","plugin_params","logger","plugins","middlewares","plugin","register_middlewares","forEach","_","ErrorCode","getNotFound","API_ERROR","WEB_DISABLED","FILE_NOT_FOUND","err","isError","code","statusCode","HTTP_STATUS","NOT_MODIFIED","isFunction","locals","report_error","noop","final","configHash","logs","AppConfig","cloneDeep","filters","filter_metadata","Storage","init"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport express, { Application } from 'express';\nimport compression from 'compression';\nimport cors from 'cors';\nimport { HttpError } from 'http-errors';\nimport { Config as IConfig, IPluginMiddleware, IPluginStorageFilter } from '@verdaccio/types';\nimport Storage from '../lib/storage';\nimport loadPlugin from '../lib/plugin-loader';\nimport Auth from '../lib/auth';\nimport { ErrorCode } from '../lib/utils';\nimport { API_ERROR, HTTP_STATUS } from '../lib/constants';\nimport AppConfig from '../lib/config';\nimport { $ResponseExtend, $RequestExtend, $NextFunctionVer, IStorageHandler, IAuth } from '../../types';\nimport { setup, logger } from '../lib/logger';\nimport webAPI from './web/api';\nimport web from './web';\nimport apiEndpoint from './endpoint';\nimport hookDebug from './debug';\nimport { log, final, errorReportingMiddleware, serveFavicon } from './middleware';\n\nconst defineAPI = function (config: IConfig, storage: IStorageHandler): any {\n  const auth: IAuth = new Auth(config);\n  const app: Application = express();\n\n  // run in production mode by default, just in case\n  // it shouldn't make any difference anyway\n  app.set('env', process.env.NODE_ENV || 'production');\n  app.use(cors());\n\n  // Router setup\n  app.use(log(config));\n  app.use(errorReportingMiddleware);\n  app.use(function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n    res.setHeader('X-Powered-By', config.user_agent);\n    next();\n  });\n\n  app.use(compression());\n\n  app.get('/-/static/favicon.ico', serveFavicon(config));\n\n  // Hook for tests only\n  if (config._debug) {\n    hookDebug(app, config.self_path);\n  }\n\n  // register middleware plugins\n  const plugin_params = {\n    config: config,\n    logger: logger,\n  };\n\n  const plugins: IPluginMiddleware<IConfig>[] = loadPlugin(config, config.middlewares, plugin_params, function (plugin: IPluginMiddleware<IConfig>) {\n    return plugin.register_middlewares;\n  });\n  plugins.forEach((plugin: IPluginMiddleware<IConfig>) => {\n    plugin.register_middlewares(app, auth, storage);\n  });\n\n  // For  npm request\n  app.use(apiEndpoint(config, auth, storage));\n\n  // For WebUI & WebUI API\n  if (_.get(config, 'web.enable', true)) {\n    app.use('/', web(config, auth, storage));\n    app.use('/-/verdaccio/', webAPI(config, auth, storage));\n  } else {\n    app.get('/', function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) {\n      next(ErrorCode.getNotFound(API_ERROR.WEB_DISABLED));\n    });\n  }\n\n  // Catch 404\n  app.get('/*', function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) {\n    next(ErrorCode.getNotFound(API_ERROR.FILE_NOT_FOUND));\n  });\n\n  app.use(function (err: HttpError, req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) {\n    if (_.isError(err)) {\n      if (err.code === 'ECONNABORT' && res.statusCode === HTTP_STATUS.NOT_MODIFIED) {\n        return next();\n      }\n      if (_.isFunction(res.locals.report_error) === false) {\n        // in case of very early error this middleware may not be loaded before error is generated\n        // fixing that\n        errorReportingMiddleware(req, res, _.noop);\n      }\n      res.locals.report_error(err);\n    } else {\n      // Fall to Middleware.final\n      return next(err);\n    }\n  });\n\n  app.use(final);\n\n  return app;\n};\n\nexport default (async function (configHash: any): Promise<any> {\n  setup(configHash.logs);\n  const config: IConfig = new AppConfig(_.cloneDeep(configHash));\n  // register middleware plugins\n  const plugin_params = {\n    config: config,\n    logger: logger,\n  };\n  const filters = loadPlugin(config, config.filters || {}, plugin_params, (plugin: IPluginStorageFilter<IConfig>) => plugin.filter_metadata);\n  const storage: IStorageHandler = new Storage(config);\n  // waits until init calls have been initialized\n  await storage.init(config, filters);\n  return defineAPI(config, storage);\n});\n"]}
|
|
134
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/api/index.ts"],"names":["defineAPI","config","storage","auth","Auth","app","set","process","env","NODE_ENV","use","errorReportingMiddleware","user_agent","req","res","next","setHeader","disable","get","_debug","self_path","plugin_params","logger","plugins","middlewares","plugin","register_middlewares","forEach","_","ErrorCode","getNotFound","API_ERROR","WEB_DISABLED","FILE_NOT_FOUND","err","isError","code","statusCode","HTTP_STATUS","NOT_MODIFIED","isFunction","locals","report_error","noop","final","configHash","logs","AppConfig","cloneDeep","filters","filter_metadata","Storage","init"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport express, { Application } from 'express';\nimport compression from 'compression';\nimport cors from 'cors';\nimport { HttpError } from 'http-errors';\nimport { Config as IConfig, IPluginMiddleware, IPluginStorageFilter } from '@verdaccio/types';\nimport Storage from '../lib/storage';\nimport loadPlugin from '../lib/plugin-loader';\nimport Auth from '../lib/auth';\nimport { ErrorCode, getUserAgent } from '../lib/utils';\nimport { API_ERROR, HTTP_STATUS } from '../lib/constants';\nimport AppConfig from '../lib/config';\nimport { $ResponseExtend, $RequestExtend, $NextFunctionVer, IStorageHandler, IAuth } from '../../types';\nimport { setup, logger } from '../lib/logger';\nimport webAPI from './web/api';\nimport web from './web';\nimport apiEndpoint from './endpoint';\nimport hookDebug from './debug';\nimport { log, final, errorReportingMiddleware, serveFavicon } from './middleware';\n\nconst defineAPI = function (config: IConfig, storage: IStorageHandler): any {\n  const auth: IAuth = new Auth(config);\n  const app: Application = express();\n\n  // run in production mode by default, just in case\n  // it shouldn't make any difference anyway\n  app.set('env', process.env.NODE_ENV || 'production');\n  app.use(cors());\n\n  // Router setup\n  app.use(log(config));\n  app.use(errorReportingMiddleware);\n  if (config.user_agent) {\n    app.use(function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n      res.setHeader('X-Powered-By', getUserAgent(config.user_agent));\n      next();\n    });\n  } else {\n    app.disable('x-powered-by');\n  }\n\n  app.use(compression());\n\n  app.get('/-/static/favicon.ico', serveFavicon(config));\n\n  // Hook for tests only\n  if (config._debug) {\n    hookDebug(app, config.self_path);\n  }\n\n  // register middleware plugins\n  const plugin_params = {\n    config: config,\n    logger: logger,\n  };\n\n  const plugins: IPluginMiddleware<IConfig>[] = loadPlugin(config, config.middlewares, plugin_params, function (plugin: IPluginMiddleware<IConfig>) {\n    return plugin.register_middlewares;\n  });\n  plugins.forEach((plugin: IPluginMiddleware<IConfig>) => {\n    plugin.register_middlewares(app, auth, storage);\n  });\n\n  // For  npm request\n  app.use(apiEndpoint(config, auth, storage));\n\n  // For WebUI & WebUI API\n  if (_.get(config, 'web.enable', true)) {\n    app.use('/', web(config, auth, storage));\n    app.use('/-/verdaccio/', webAPI(config, auth, storage));\n  } else {\n    app.get('/', function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) {\n      next(ErrorCode.getNotFound(API_ERROR.WEB_DISABLED));\n    });\n  }\n\n  // Catch 404\n  app.get('/*', function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) {\n    next(ErrorCode.getNotFound(API_ERROR.FILE_NOT_FOUND));\n  });\n\n  app.use(function (err: HttpError, req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) {\n    if (_.isError(err)) {\n      if (err.code === 'ECONNABORT' && res.statusCode === HTTP_STATUS.NOT_MODIFIED) {\n        return next();\n      }\n      if (_.isFunction(res.locals.report_error) === false) {\n        // in case of very early error this middleware may not be loaded before error is generated\n        // fixing that\n        errorReportingMiddleware(req, res, _.noop);\n      }\n      res.locals.report_error(err);\n    } else {\n      // Fall to Middleware.final\n      return next(err);\n    }\n  });\n\n  app.use(final);\n\n  return app;\n};\n\nexport default (async function (configHash: any): Promise<any> {\n  setup(configHash.logs);\n  const config: IConfig = new AppConfig(_.cloneDeep(configHash));\n  // register middleware plugins\n  const plugin_params = {\n    config: config,\n    logger: logger,\n  };\n  const filters = loadPlugin(config, config.filters || {}, plugin_params, (plugin: IPluginStorageFilter<IConfig>) => plugin.filter_metadata);\n  const storage: IStorageHandler = new Storage(config);\n  // waits until init calls have been initialized\n  await storage.init(config, filters);\n  return defineAPI(config, storage);\n});\n"]}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.limiter = void 0;
|
|
7
|
+
|
|
8
|
+
var _expressRateLimit = _interopRequireDefault(require("express-rate-limit"));
|
|
9
|
+
|
|
10
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
11
|
+
|
|
12
|
+
function ownKeys(object, enumerableOnly) { var keys = Object.keys(object); if (Object.getOwnPropertySymbols) { var symbols = Object.getOwnPropertySymbols(object); if (enumerableOnly) { symbols = symbols.filter(function (sym) { return Object.getOwnPropertyDescriptor(object, sym).enumerable; }); } keys.push.apply(keys, symbols); } return keys; }
|
|
13
|
+
|
|
14
|
+
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { ownKeys(Object(source), true).forEach(function (key) { _defineProperty(target, key, source[key]); }); } else if (Object.getOwnPropertyDescriptors) { Object.defineProperties(target, Object.getOwnPropertyDescriptors(source)); } else { ownKeys(Object(source)).forEach(function (key) { Object.defineProperty(target, key, Object.getOwnPropertyDescriptor(source, key)); }); } } return target; }
|
|
15
|
+
|
|
16
|
+
function _defineProperty(obj, key, value) { if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
17
|
+
|
|
18
|
+
const limiter = rateLimitOptions => {
|
|
19
|
+
// @ts-ignore
|
|
20
|
+
return new _expressRateLimit.default(_objectSpread({}, rateLimitOptions));
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
exports.limiter = limiter;
|
|
24
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9hcGkvcmF0ZS1saW1pdGVyLnRzIl0sIm5hbWVzIjpbImxpbWl0ZXIiLCJyYXRlTGltaXRPcHRpb25zIiwiUmF0ZUxpbWl0Il0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBQUE7Ozs7Ozs7Ozs7QUFHQSxNQUFNQSxPQUFPLEdBQUlDLGdCQUFELElBQXFDO0FBQ25EO0FBQ0EsU0FBTyxJQUFJQyx5QkFBSixtQkFDRkQsZ0JBREUsRUFBUDtBQUdELENBTEQiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmF0ZUxpbWl0IGZyb20gJ2V4cHJlc3MtcmF0ZS1saW1pdCc7XG5pbXBvcnQgeyBSYXRlTGltaXQgYXMgUmF0ZUxpbWl0VHlwZSB9IGZyb20gJ0B2ZXJkYWNjaW8vdHlwZXMnO1xuXG5jb25zdCBsaW1pdGVyID0gKHJhdGVMaW1pdE9wdGlvbnM6IFJhdGVMaW1pdFR5cGUpID0+IHtcbiAgLy8gQHRzLWlnbm9yZVxuICByZXR1cm4gbmV3IFJhdGVMaW1pdCh7XG4gICAgLi4ucmF0ZUxpbWl0T3B0aW9ucyxcbiAgfSk7XG59O1xuXG5leHBvcnQgeyBsaW1pdGVyIH07XG4iXX0=
|
package/build/api/web/api.js
CHANGED
|
@@ -13,11 +13,7 @@ var _search = _interopRequireDefault(require("../../lib/search"));
|
|
|
13
13
|
|
|
14
14
|
var _middleware = require("../middleware");
|
|
15
15
|
|
|
16
|
-
var
|
|
17
|
-
|
|
18
|
-
var _package = _interopRequireDefault(require("./endpoint/package"));
|
|
19
|
-
|
|
20
|
-
var _search2 = _interopRequireDefault(require("./endpoint/search"));
|
|
16
|
+
var _endpoint = _interopRequireDefault(require("./endpoint"));
|
|
21
17
|
|
|
22
18
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
23
19
|
|
|
@@ -31,11 +27,9 @@ const route = (0, _express.Router)();
|
|
|
31
27
|
function _default(config, auth, storage) {
|
|
32
28
|
_search.default.configureStorage(storage); // validate all of these params as a package name
|
|
33
29
|
// this might be too harsh, so ask if it causes trouble
|
|
34
|
-
// $FlowFixMe
|
|
35
30
|
|
|
36
31
|
|
|
37
|
-
route.param('package', _middleware.validatePackage);
|
|
38
|
-
|
|
32
|
+
route.param('package', _middleware.validatePackage);
|
|
39
33
|
route.param('filename', _middleware.validateName);
|
|
40
34
|
route.param('version', _middleware.validateName);
|
|
41
35
|
route.param('anything', (0, _middleware.match)(/.*/));
|
|
@@ -44,13 +38,7 @@ function _default(config, auth, storage) {
|
|
|
44
38
|
}));
|
|
45
39
|
route.use(auth.webUIJWTmiddleware());
|
|
46
40
|
route.use(_middleware.setSecurityWebHeaders);
|
|
47
|
-
(0,
|
|
48
|
-
(0, _search2.default)(route, storage, auth);
|
|
49
|
-
(0, _user.default)(route, auth, config); // What are you looking for? logout? client side will remove token when user click logout,
|
|
50
|
-
// or it will auto expire after 24 hours.
|
|
51
|
-
// This token is different with the token send to npm client.
|
|
52
|
-
// We will/may replace current token with JWT in next major release, and it will not expire at all(configurable).
|
|
53
|
-
|
|
41
|
+
route.use((0, _endpoint.default)(auth, storage, config));
|
|
54
42
|
return route;
|
|
55
43
|
}
|
|
56
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
44
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hcGkvd2ViL2FwaS50cyJdLCJuYW1lcyI6WyJyb3V0ZSIsImNvbmZpZyIsImF1dGgiLCJzdG9yYWdlIiwiU2VhcmNoIiwiY29uZmlndXJlU3RvcmFnZSIsInBhcmFtIiwidmFsaWRhdGVQYWNrYWdlIiwidmFsaWRhdGVOYW1lIiwidXNlIiwiYm9keVBhcnNlciIsInVybGVuY29kZWQiLCJleHRlbmRlZCIsIndlYlVJSldUbWlkZGxld2FyZSIsInNldFNlY3VyaXR5V2ViSGVhZGVycyJdLCJtYXBwaW5ncyI6Ijs7Ozs7OztBQUFBOztBQUNBOztBQUVBOztBQUNBOztBQUVBOzs7O0FBRUEsTUFBTUEsS0FBSyxHQUFHLHNCQUFkO0FBQXdCOztBQUV4QjtBQUNBO0FBQ0E7O0FBQ2Usa0JBQVVDLE1BQVYsRUFBMEJDLElBQTFCLEVBQXVDQyxPQUF2QyxFQUF5RTtBQUN0RkMsa0JBQU9DLGdCQUFQLENBQXdCRixPQUF4QixFQURzRixDQUV0RjtBQUNBOzs7QUFDQUgsRUFBQUEsS0FBSyxDQUFDTSxLQUFOLENBQVksU0FBWixFQUF1QkMsMkJBQXZCO0FBQ0FQLEVBQUFBLEtBQUssQ0FBQ00sS0FBTixDQUFZLFVBQVosRUFBd0JFLHdCQUF4QjtBQUNBUixFQUFBQSxLQUFLLENBQUNNLEtBQU4sQ0FBWSxTQUFaLEVBQXVCRSx3QkFBdkI7QUFDQVIsRUFBQUEsS0FBSyxDQUFDTSxLQUFOLENBQVksVUFBWixFQUF3Qix1QkFBTSxJQUFOLENBQXhCO0FBRUFOLEVBQUFBLEtBQUssQ0FBQ1MsR0FBTixDQUFVQyxvQkFBV0MsVUFBWCxDQUFzQjtBQUFFQyxJQUFBQSxRQUFRLEVBQUU7QUFBWixHQUF0QixDQUFWO0FBQ0FaLEVBQUFBLEtBQUssQ0FBQ1MsR0FBTixDQUFVUCxJQUFJLENBQUNXLGtCQUFMLEVBQVY7QUFDQWIsRUFBQUEsS0FBSyxDQUFDUyxHQUFOLENBQVVLLGlDQUFWO0FBQ0FkLEVBQUFBLEtBQUssQ0FBQ1MsR0FBTixDQUFVLHVCQUFPUCxJQUFQLEVBQWFDLE9BQWIsRUFBc0JGLE1BQXRCLENBQVY7QUFDQSxTQUFPRCxLQUFQO0FBQ0QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBSb3V0ZXIgfSBmcm9tICdleHByZXNzJztcbmltcG9ydCBib2R5UGFyc2VyIGZyb20gJ2JvZHktcGFyc2VyJztcbmltcG9ydCB7IENvbmZpZyB9IGZyb20gJ0B2ZXJkYWNjaW8vdHlwZXMnO1xuaW1wb3J0IFNlYXJjaCBmcm9tICcuLi8uLi9saWIvc2VhcmNoJztcbmltcG9ydCB7IG1hdGNoLCB2YWxpZGF0ZU5hbWUsIHZhbGlkYXRlUGFja2FnZSwgc2V0U2VjdXJpdHlXZWJIZWFkZXJzIH0gZnJvbSAnLi4vbWlkZGxld2FyZSc7XG5pbXBvcnQgeyBJQXV0aCwgSVN0b3JhZ2VIYW5kbGVyIH0gZnJvbSAnLi4vLi4vLi4vdHlwZXMnO1xuaW1wb3J0IHdlYkFwaSBmcm9tICcuL2VuZHBvaW50JztcblxuY29uc3Qgcm91dGUgPSBSb3V0ZXIoKTsgLyogZXNsaW50IG5ldy1jYXA6IDAgKi9cblxuLypcbiBUaGlzIGZpbGUgaW5jbHVkZSBhbGwgdmVyZGFjY2lvIG9ubHkgQVBJKFdlYiBVSSksIGZvciBucG0gQVBJIHBsZWFzZSBzZWUgLi4vZW5kcG9pbnQvXG4qL1xuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gKGNvbmZpZzogQ29uZmlnLCBhdXRoOiBJQXV0aCwgc3RvcmFnZTogSVN0b3JhZ2VIYW5kbGVyKTogUm91dGVyIHtcbiAgU2VhcmNoLmNvbmZpZ3VyZVN0b3JhZ2Uoc3RvcmFnZSk7XG4gIC8vIHZhbGlkYXRlIGFsbCBvZiB0aGVzZSBwYXJhbXMgYXMgYSBwYWNrYWdlIG5hbWVcbiAgLy8gdGhpcyBtaWdodCBiZSB0b28gaGFyc2gsIHNvIGFzayBpZiBpdCBjYXVzZXMgdHJvdWJsZVxuICByb3V0ZS5wYXJhbSgncGFja2FnZScsIHZhbGlkYXRlUGFja2FnZSk7XG4gIHJvdXRlLnBhcmFtKCdmaWxlbmFtZScsIHZhbGlkYXRlTmFtZSk7XG4gIHJvdXRlLnBhcmFtKCd2ZXJzaW9uJywgdmFsaWRhdGVOYW1lKTtcbiAgcm91dGUucGFyYW0oJ2FueXRoaW5nJywgbWF0Y2goLy4qLykpO1xuXG4gIHJvdXRlLnVzZShib2R5UGFyc2VyLnVybGVuY29kZWQoeyBleHRlbmRlZDogZmFsc2UgfSkpO1xuICByb3V0ZS51c2UoYXV0aC53ZWJVSUpXVG1pZGRsZXdhcmUoKSk7XG4gIHJvdXRlLnVzZShzZXRTZWN1cml0eVdlYkhlYWRlcnMpO1xuICByb3V0ZS51c2Uod2ViQXBpKGF1dGgsIHN0b3JhZ2UsIGNvbmZpZykpO1xuICByZXR1cm4gcm91dGU7XG59XG4iXX0=
|