verdaccio 5.25.0 → 5.26.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.
@@ -55,7 +55,7 @@ function _default(route, auth, storage, config) {
55
55
  metadata = (0, _tarball.convertDistRemoteToLocalTarballUrls)(metadata, {
56
56
  protocol: req.protocol,
57
57
  headers: req.headers,
58
- host: req.host,
58
+ host: req.hostname,
59
59
  remoteAddress: req.socket.remoteAddress
60
60
  }, config.url_prefix);
61
61
  let queryVersion = req.params.version;
@@ -111,4 +111,4 @@ function _default(route, auth, storage, config) {
111
111
  }
112
112
  });
113
113
  }
114
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_lodash","_interopRequireDefault","require","_middleware","_tarball","_constants","_logger","_utils","_string","obj","__esModule","default","downloadStream","packageName","filename","storage","req","res","stream","getTarball","on","content","header","err","locals","report_error","HEADERS","CONTENT_TYPE","OCTET_STREAM","pipe","redirectOrDownloadStream","config","tarballUrlRedirect","_","get","hasLocalTarball","then","context","tarballUrl","template","redirect","catch","_default","route","auth","can","allow","beforeAll","params","message","logger","trace","afterAll","next","abbreviated","getByQualityPriorityValue","getPackageMetaCallback","metadata","convertDistRemoteToLocalTarballUrls","protocol","headers","host","remoteAddress","socket","url_prefix","queryVersion","version","isNil","setHeader","JSON","getVersion","DIST_TAGS","ErrorCode","getNotFound","API_ERROR","VERSION_NOT_EXIST","getPackage","name","package","uplinksLook","callback","scopedPackage","undefined"],"sources":["../../../../src/api/endpoint/api/package.ts"],"sourcesContent":["import { Router } from 'express';\nimport _ from 'lodash';\n\nimport { allow } from '@verdaccio/middleware';\nimport { convertDistRemoteToLocalTarballUrls } from '@verdaccio/tarball';\nimport { Config, Package } from '@verdaccio/types';\n\nimport Auth from '../../../lib/auth';\nimport { API_ERROR, DIST_TAGS, HEADERS } from '../../../lib/constants';\nimport { logger } from '../../../lib/logger';\nimport Storage from '../../../lib/storage';\nimport { ErrorCode, getVersion } from '../../../lib/utils';\nimport { $NextFunctionVer, $RequestExtend, $ResponseExtend } from '../../../types';\nimport { getByQualityPriorityValue } from '../../../utils/string';\n\nconst downloadStream = (\n  packageName: string,\n  filename: string,\n  storage: any,\n  req: $RequestExtend,\n  res: $ResponseExtend\n): void => {\n  const stream = storage.getTarball(packageName, filename);\n\n  stream.on('content-length', function (content): void {\n    res.header('Content-Length', content);\n  });\n\n  stream.on('error', function (err): void {\n    return res.locals.report_error(err);\n  });\n\n  res.header(HEADERS.CONTENT_TYPE, HEADERS.OCTET_STREAM);\n  stream.pipe(res);\n};\n\nconst redirectOrDownloadStream = (\n  packageName: string,\n  filename: string,\n  storage: any,\n  req: $RequestExtend,\n  res: $ResponseExtend,\n  config: Config\n): void => {\n  const tarballUrlRedirect = _.get(config, 'experiments.tarball_url_redirect');\n  storage\n    .hasLocalTarball(packageName, filename)\n    .then((hasLocalTarball) => {\n      if (hasLocalTarball) {\n        const context = { packageName, filename };\n        const tarballUrl =\n          typeof tarballUrlRedirect === 'function'\n            ? tarballUrlRedirect(context)\n            : _.template(tarballUrlRedirect)(context);\n        res.redirect(tarballUrl);\n      } else {\n        downloadStream(packageName, filename, storage, req, res);\n      }\n    })\n    .catch((err) => {\n      res.locals.report_error(err);\n    });\n};\n\nexport default function (route: Router, auth: Auth, storage: Storage, config: Config): void {\n  const can = allow(auth, {\n    beforeAll: (params, message) => logger.trace(params, message),\n    afterAll: (params, message) => logger.trace(params, message),\n  });\n  // TODO: anonymous user?\n  route.get(\n    '/:package/:version?',\n    can('access'),\n    function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n      const abbreviated =\n        getByQualityPriorityValue(req.get('Accept')) === 'application/vnd.npm.install-v1+json';\n      const getPackageMetaCallback = function (err, metadata: Package): void {\n        if (err) {\n          return next(err);\n        }\n        metadata = convertDistRemoteToLocalTarballUrls(\n          metadata,\n          {\n            protocol: req.protocol,\n            headers: req.headers as any,\n            host: req.host,\n            remoteAddress: req.socket.remoteAddress,\n          },\n          config.url_prefix\n        );\n\n        let queryVersion = req.params.version;\n        if (_.isNil(queryVersion)) {\n          if (abbreviated) {\n            res.setHeader(HEADERS.CONTENT_TYPE, 'application/vnd.npm.install-v1+json');\n          } else {\n            res.setHeader(HEADERS.CONTENT_TYPE, HEADERS.JSON);\n          }\n\n          return next(metadata);\n        }\n\n        let version = getVersion(metadata, queryVersion);\n        if (_.isNil(version) === false) {\n          res.setHeader(HEADERS.CONTENT_TYPE, HEADERS.JSON);\n          return next(version);\n        }\n\n        if (_.isNil(metadata[DIST_TAGS]) === false) {\n          if (_.isNil(metadata[DIST_TAGS][queryVersion]) === false) {\n            queryVersion = metadata[DIST_TAGS][queryVersion];\n            version = getVersion(metadata, queryVersion);\n            if (_.isNil(version) === false) {\n              res.setHeader(HEADERS.CONTENT_TYPE, HEADERS.JSON);\n              return next(version);\n            }\n          }\n        }\n        return next(ErrorCode.getNotFound(`${API_ERROR.VERSION_NOT_EXIST}: ${req.params.version}`));\n      };\n\n      storage.getPackage({\n        name: req.params.package,\n        uplinksLook: true,\n        req,\n        abbreviated,\n        callback: getPackageMetaCallback,\n      });\n    }\n  );\n\n  route.get(\n    '/:scopedPackage/-/:scope/:filename',\n    can('access'),\n    function (req: $RequestExtend, res: $ResponseExtend): void {\n      const { scopedPackage, filename } = req.params;\n      if (_.get(config, 'experiments.tarball_url_redirect') === undefined) {\n        downloadStream(scopedPackage, filename, storage, req, res);\n      } else {\n        redirectOrDownloadStream(scopedPackage, filename, storage, req, res, config);\n      }\n    }\n  );\n\n  route.get(\n    '/:package/-/:filename',\n    can('access'),\n    function (req: $RequestExtend, res: $ResponseExtend): void {\n      if (_.get(config, 'experiments.tarball_url_redirect') === undefined) {\n        downloadStream(req.params.package, req.params.filename, storage, req, res);\n      } else {\n        redirectOrDownloadStream(\n          req.params.package,\n          req.params.filename,\n          storage,\n          req,\n          res,\n          config\n        );\n      }\n    }\n  );\n}\n"],"mappings":"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"}
114
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_lodash","_interopRequireDefault","require","_middleware","_tarball","_constants","_logger","_utils","_string","obj","__esModule","default","downloadStream","packageName","filename","storage","req","res","stream","getTarball","on","content","header","err","locals","report_error","HEADERS","CONTENT_TYPE","OCTET_STREAM","pipe","redirectOrDownloadStream","config","tarballUrlRedirect","_","get","hasLocalTarball","then","context","tarballUrl","template","redirect","catch","_default","route","auth","can","allow","beforeAll","params","message","logger","trace","afterAll","next","abbreviated","getByQualityPriorityValue","getPackageMetaCallback","metadata","convertDistRemoteToLocalTarballUrls","protocol","headers","host","hostname","remoteAddress","socket","url_prefix","queryVersion","version","isNil","setHeader","JSON","getVersion","DIST_TAGS","ErrorCode","getNotFound","API_ERROR","VERSION_NOT_EXIST","getPackage","name","package","uplinksLook","callback","scopedPackage","undefined"],"sources":["../../../../src/api/endpoint/api/package.ts"],"sourcesContent":["import { Router } from 'express';\nimport _ from 'lodash';\n\nimport { allow } from '@verdaccio/middleware';\nimport { convertDistRemoteToLocalTarballUrls } from '@verdaccio/tarball';\nimport { Config, Package } from '@verdaccio/types';\n\nimport Auth from '../../../lib/auth';\nimport { API_ERROR, DIST_TAGS, HEADERS } from '../../../lib/constants';\nimport { logger } from '../../../lib/logger';\nimport Storage from '../../../lib/storage';\nimport { ErrorCode, getVersion } from '../../../lib/utils';\nimport { $NextFunctionVer, $RequestExtend, $ResponseExtend } from '../../../types';\nimport { getByQualityPriorityValue } from '../../../utils/string';\n\nconst downloadStream = (\n  packageName: string,\n  filename: string,\n  storage: any,\n  req: $RequestExtend,\n  res: $ResponseExtend\n): void => {\n  const stream = storage.getTarball(packageName, filename);\n\n  stream.on('content-length', function (content): void {\n    res.header('Content-Length', content);\n  });\n\n  stream.on('error', function (err): void {\n    return res.locals.report_error(err);\n  });\n\n  res.header(HEADERS.CONTENT_TYPE, HEADERS.OCTET_STREAM);\n  stream.pipe(res);\n};\n\nconst redirectOrDownloadStream = (\n  packageName: string,\n  filename: string,\n  storage: any,\n  req: $RequestExtend,\n  res: $ResponseExtend,\n  config: Config\n): void => {\n  const tarballUrlRedirect = _.get(config, 'experiments.tarball_url_redirect');\n  storage\n    .hasLocalTarball(packageName, filename)\n    .then((hasLocalTarball) => {\n      if (hasLocalTarball) {\n        const context = { packageName, filename };\n        const tarballUrl =\n          typeof tarballUrlRedirect === 'function'\n            ? tarballUrlRedirect(context)\n            : _.template(tarballUrlRedirect)(context);\n        res.redirect(tarballUrl);\n      } else {\n        downloadStream(packageName, filename, storage, req, res);\n      }\n    })\n    .catch((err) => {\n      res.locals.report_error(err);\n    });\n};\n\nexport default function (route: Router, auth: Auth, storage: Storage, config: Config): void {\n  const can = allow(auth, {\n    beforeAll: (params, message) => logger.trace(params, message),\n    afterAll: (params, message) => logger.trace(params, message),\n  });\n  // TODO: anonymous user?\n  route.get(\n    '/:package/:version?',\n    can('access'),\n    function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n      const abbreviated =\n        getByQualityPriorityValue(req.get('Accept')) === 'application/vnd.npm.install-v1+json';\n      const getPackageMetaCallback = function (err, metadata: Package): void {\n        if (err) {\n          return next(err);\n        }\n        metadata = convertDistRemoteToLocalTarballUrls(\n          metadata,\n          {\n            protocol: req.protocol,\n            headers: req.headers as any,\n            host: req.hostname,\n            remoteAddress: req.socket.remoteAddress,\n          },\n          config.url_prefix\n        );\n\n        let queryVersion = req.params.version;\n        if (_.isNil(queryVersion)) {\n          if (abbreviated) {\n            res.setHeader(HEADERS.CONTENT_TYPE, 'application/vnd.npm.install-v1+json');\n          } else {\n            res.setHeader(HEADERS.CONTENT_TYPE, HEADERS.JSON);\n          }\n\n          return next(metadata);\n        }\n\n        let version = getVersion(metadata, queryVersion);\n        if (_.isNil(version) === false) {\n          res.setHeader(HEADERS.CONTENT_TYPE, HEADERS.JSON);\n          return next(version);\n        }\n\n        if (_.isNil(metadata[DIST_TAGS]) === false) {\n          if (_.isNil(metadata[DIST_TAGS][queryVersion]) === false) {\n            queryVersion = metadata[DIST_TAGS][queryVersion];\n            version = getVersion(metadata, queryVersion);\n            if (_.isNil(version) === false) {\n              res.setHeader(HEADERS.CONTENT_TYPE, HEADERS.JSON);\n              return next(version);\n            }\n          }\n        }\n        return next(ErrorCode.getNotFound(`${API_ERROR.VERSION_NOT_EXIST}: ${req.params.version}`));\n      };\n\n      storage.getPackage({\n        name: req.params.package,\n        uplinksLook: true,\n        req,\n        abbreviated,\n        callback: getPackageMetaCallback,\n      });\n    }\n  );\n\n  route.get(\n    '/:scopedPackage/-/:scope/:filename',\n    can('access'),\n    function (req: $RequestExtend, res: $ResponseExtend): void {\n      const { scopedPackage, filename } = req.params;\n      if (_.get(config, 'experiments.tarball_url_redirect') === undefined) {\n        downloadStream(scopedPackage, filename, storage, req, res);\n      } else {\n        redirectOrDownloadStream(scopedPackage, filename, storage, req, res, config);\n      }\n    }\n  );\n\n  route.get(\n    '/:package/-/:filename',\n    can('access'),\n    function (req: $RequestExtend, res: $ResponseExtend): void {\n      if (_.get(config, 'experiments.tarball_url_redirect') === undefined) {\n        downloadStream(req.params.package, req.params.filename, storage, req, res);\n      } else {\n        redirectOrDownloadStream(\n          req.params.package,\n          req.params.filename,\n          storage,\n          req,\n          res,\n          config\n        );\n      }\n    }\n  );\n}\n"],"mappings":"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"}
@@ -1 +1 @@
1
- export default function (route: any, auth: any, storage: any): void;
1
+ export default function (route: any): void;
@@ -6,101 +6,14 @@ Object.defineProperty(exports, "__esModule", {
6
6
  exports.default = _default;
7
7
  var _constants = require("../../../lib/constants");
8
8
  var _logger = require("../../../lib/logger");
9
- function _default(route, auth, storage) {
9
+ function _default(route) {
10
10
  // searching packages
11
- route.get('/-/all(/since)?', function (req, res, next) {
12
- let received_end = false;
13
- let response_finished = false;
14
- let processing_pkgs = 0;
15
- let firstPackage = true;
16
- _logger.logger.warn('/-/all search endpoint is deprecated, might be removed in the next major release');
17
- res.status(200);
18
- res.set(_constants.HEADERS.CONTENT_TYPE, _constants.HEADERS.JSON_CHARSET);
19
-
20
- /*
21
- * Offical NPM registry (registry.npmjs.org) no longer return whole database,
22
- * They only return packages matched with keyword in `referer: search pkg-name`,
23
- * And NPM client will request server in every search.
24
- *
25
- * The magic number 99999 was sent by NPM registry. Modify it may caused strange
26
- * behaviour in the future.
27
- *
28
- * BTW: NPM will not return result if user-agent does not contain string 'npm',
29
- * See: method 'request' in up-storage.js
30
- *
31
- * If there is no cache in local, NPM will request /-/all, then get response with
32
- * _updated: 99999, 'Date' in response header was Mon, 10 Oct 1983 00:12:48 GMT,
33
- * this will make NPM always query from server
34
- *
35
- * Data structure also different, whel request /-/all, response is an object, but
36
- * when request /-/all/since, response is an array
37
- */
38
- const respShouldBeArray = req.path.endsWith('/since');
39
- if (!respShouldBeArray) {
40
- res.set('Date', 'Mon, 10 Oct 1983 00:12:48 GMT');
41
- }
42
- const check_finish = function () {
43
- if (!received_end) {
44
- return;
45
- }
46
- if (processing_pkgs) {
47
- return;
48
- }
49
- if (response_finished) {
50
- return;
51
- }
52
- response_finished = true;
53
- if (respShouldBeArray) {
54
- res.end(']\n');
55
- } else {
56
- res.end('}\n');
57
- }
58
- };
59
- if (respShouldBeArray) {
60
- res.write('[');
61
- } else {
62
- res.write('{"_updated":' + 99999);
63
- }
64
- const stream = storage.search(req.query.startkey || 0, {
65
- req: req
66
- });
67
- stream.on('data', function each(pkg) {
68
- processing_pkgs++;
69
- auth.allow_access({
70
- packageName: pkg.name
71
- }, req.remote_user, function (err, allowed) {
72
- processing_pkgs--;
73
- if (err) {
74
- if (err.status && String(err.status).match(/^4\d\d$/)) {
75
- // auth plugin returns 4xx user error,
76
- // that's equivalent of !allowed basically
77
- allowed = false;
78
- } else {
79
- stream.abort(err);
80
- }
81
- }
82
- if (allowed) {
83
- if (respShouldBeArray) {
84
- res.write(`${firstPackage ? '' : ','}${JSON.stringify(pkg)}\n`);
85
- if (firstPackage) {
86
- firstPackage = false;
87
- }
88
- } else {
89
- res.write(',\n' + JSON.stringify(pkg.name) + ':' + JSON.stringify(pkg));
90
- }
91
- }
92
- check_finish();
93
- });
94
- });
95
- stream.on('error', function (err) {
96
- _logger.logger.error('search `/-/all endpoint has failed @{err}', err);
97
- received_end = true;
98
- check_finish();
99
- });
100
- stream.on('end', function () {
101
- received_end = true;
102
- check_finish();
11
+ route.get('/-/all(/since)?', function (_req, res) {
12
+ _logger.logger.warn('search endpoint has been removed, please use search v1');
13
+ res.status(_constants.HTTP_STATUS.NOT_FOUND);
14
+ res.json({
15
+ error: 'not found, endpoint removed'
103
16
  });
104
17
  });
105
18
  }
106
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_constants","require","_logger","_default","route","auth","storage","get","req","res","next","received_end","response_finished","processing_pkgs","firstPackage","logger","warn","status","set","HEADERS","CONTENT_TYPE","JSON_CHARSET","respShouldBeArray","path","endsWith","check_finish","end","write","stream","search","query","startkey","on","each","pkg","allow_access","packageName","name","remote_user","err","allowed","String","match","abort","JSON","stringify","error"],"sources":["../../../../src/api/endpoint/api/search.ts"],"sourcesContent":["import { API_ERROR, HEADERS } from '../../../lib/constants';\nimport { logger } from '../../../lib/logger';\nimport { ErrorCode } from '../../../lib/utils';\n\nexport default function (route, auth, storage): void {\n  // searching packages\n  route.get('/-/all(/since)?', function (req, res, next) {\n    let received_end = false;\n    let response_finished = false;\n    let processing_pkgs = 0;\n    let firstPackage = true;\n    logger.warn('/-/all search endpoint is deprecated, might be removed in the next major release');\n    res.status(200);\n    res.set(HEADERS.CONTENT_TYPE, HEADERS.JSON_CHARSET);\n\n    /*\n     * Offical NPM registry (registry.npmjs.org) no longer return whole database,\n     * They only return packages matched with keyword in `referer: search pkg-name`,\n     * And NPM client will request server in every search.\n     *\n     * The magic number 99999 was sent by NPM registry. Modify it may caused strange\n     * behaviour in the future.\n     *\n     * BTW: NPM will not return result if user-agent does not contain string 'npm',\n     * See: method 'request' in up-storage.js\n     *\n     * If there is no cache in local, NPM will request /-/all, then get response with\n     * _updated: 99999, 'Date' in response header was Mon, 10 Oct 1983 00:12:48 GMT,\n     * this will make NPM always query from server\n     *\n     * Data structure also different, whel request /-/all, response is an object, but\n     * when request /-/all/since, response is an array\n     */\n    const respShouldBeArray = req.path.endsWith('/since');\n    if (!respShouldBeArray) {\n      res.set('Date', 'Mon, 10 Oct 1983 00:12:48 GMT');\n    }\n    const check_finish = function (): void {\n      if (!received_end) {\n        return;\n      }\n      if (processing_pkgs) {\n        return;\n      }\n      if (response_finished) {\n        return;\n      }\n      response_finished = true;\n      if (respShouldBeArray) {\n        res.end(']\\n');\n      } else {\n        res.end('}\\n');\n      }\n    };\n\n    if (respShouldBeArray) {\n      res.write('[');\n    } else {\n      res.write('{\"_updated\":' + 99999);\n    }\n\n    const stream = storage.search(req.query.startkey || 0, { req: req });\n\n    stream.on('data', function each(pkg) {\n      processing_pkgs++;\n\n      auth.allow_access({ packageName: pkg.name }, req.remote_user, function (err, allowed) {\n        processing_pkgs--;\n\n        if (err) {\n          if (err.status && String(err.status).match(/^4\\d\\d$/)) {\n            // auth plugin returns 4xx user error,\n            // that's equivalent of !allowed basically\n            allowed = false;\n          } else {\n            stream.abort(err);\n          }\n        }\n\n        if (allowed) {\n          if (respShouldBeArray) {\n            res.write(`${firstPackage ? '' : ','}${JSON.stringify(pkg)}\\n`);\n            if (firstPackage) {\n              firstPackage = false;\n            }\n          } else {\n            res.write(',\\n' + JSON.stringify(pkg.name) + ':' + JSON.stringify(pkg));\n          }\n        }\n\n        check_finish();\n      });\n    });\n\n    stream.on('error', function (err) {\n      logger.error('search `/-/all endpoint has failed @{err}', err);\n      received_end = true;\n      check_finish();\n    });\n\n    stream.on('end', function () {\n      received_end = true;\n      check_finish();\n    });\n  });\n}\n"],"mappings":"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"}
19
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfY29uc3RhbnRzIiwicmVxdWlyZSIsIl9sb2dnZXIiLCJfZGVmYXVsdCIsInJvdXRlIiwiZ2V0IiwiX3JlcSIsInJlcyIsImxvZ2dlciIsIndhcm4iLCJzdGF0dXMiLCJIVFRQX1NUQVRVUyIsIk5PVF9GT1VORCIsImpzb24iLCJlcnJvciJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9hcGkvZW5kcG9pbnQvYXBpL3NlYXJjaC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIVFRQX1NUQVRVUyB9IGZyb20gJy4uLy4uLy4uL2xpYi9jb25zdGFudHMnO1xuaW1wb3J0IHsgbG9nZ2VyIH0gZnJvbSAnLi4vLi4vLi4vbGliL2xvZ2dlcic7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIChyb3V0ZSk6IHZvaWQge1xuICAvLyBzZWFyY2hpbmcgcGFja2FnZXNcbiAgcm91dGUuZ2V0KCcvLS9hbGwoL3NpbmNlKT8nLCBmdW5jdGlvbiAoX3JlcSwgcmVzKSB7XG4gICAgbG9nZ2VyLndhcm4oJ3NlYXJjaCBlbmRwb2ludCBoYXMgYmVlbiByZW1vdmVkLCBwbGVhc2UgdXNlIHNlYXJjaCB2MScpO1xuICAgIHJlcy5zdGF0dXMoSFRUUF9TVEFUVVMuTk9UX0ZPVU5EKTtcbiAgICByZXMuanNvbih7IGVycm9yOiAnbm90IGZvdW5kLCBlbmRwb2ludCByZW1vdmVkJyB9KTtcbiAgfSk7XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLElBQUFBLFVBQUEsR0FBQUMsT0FBQTtBQUNBLElBQUFDLE9BQUEsR0FBQUQsT0FBQTtBQUVlLFNBQUFFLFNBQVVDLEtBQUssRUFBUTtFQUNwQztFQUNBQSxLQUFLLENBQUNDLEdBQUcsQ0FBQyxpQkFBaUIsRUFBRSxVQUFVQyxJQUFJLEVBQUVDLEdBQUcsRUFBRTtJQUNoREMsY0FBTSxDQUFDQyxJQUFJLENBQUMsd0RBQXdELENBQUM7SUFDckVGLEdBQUcsQ0FBQ0csTUFBTSxDQUFDQyxzQkFBVyxDQUFDQyxTQUFTLENBQUM7SUFDakNMLEdBQUcsQ0FBQ00sSUFBSSxDQUFDO01BQUVDLEtBQUssRUFBRTtJQUE4QixDQUFDLENBQUM7RUFDcEQsQ0FBQyxDQUFDO0FBQ0oifQ==
@@ -4,7 +4,6 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.default = _default;
7
- var _cookies = _interopRequireDefault(require("cookies"));
8
7
  var _express = _interopRequireDefault(require("express"));
9
8
  var _lodash = _interopRequireDefault(require("lodash"));
10
9
  var _config = require("@verdaccio/config");
@@ -80,17 +79,6 @@ function _default(route, auth, config) {
80
79
  ok: _constants.API_MESSAGE.LOGGED_OUT
81
80
  });
82
81
  });
83
-
84
- // placeholder 'cause npm require to be authenticated to publish
85
- // we do not do any real authentication yet
86
- userRouter.post('/_session', _cookies.default.express(), function (req, res, next) {
87
- res.cookies.set('AuthSession', String(Math.random()), (0, _utils.createSessionToken)());
88
- next({
89
- ok: true,
90
- name: 'somebody',
91
- roles: []
92
- });
93
- });
94
82
  route.use(userRouter);
95
83
  }
96
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_cookies","_interopRequireDefault","require","_express","_lodash","_config","_middleware","_utils","_authUtils","_constants","_logger","_utils2","obj","__esModule","default","_default","route","auth","config","userRouter","express","Router","get","rateLimit","userRateLimit","req","res","next","status","HTTP_STATUS","OK","ok","getAuthenticatedMessage","remote_user","name","put","password","body","remoteName","_","isNil","authenticate","callbackAuthenticate","err","user","logger","error","ErrorCode","getCode","UNAUTHORIZED","API_ERROR","BAD_USERNAME_PASSWORD","restoredRemoteUser","createRemoteUser","groups","token","getApiToken","CREATED","set","HEADERS","CACHE_CONTROL","validatePassword","BAD_REQUEST","PASSWORD_SHORT","add_user","INTERNAL_ERROR","message","getConflict","undefined","delete","API_MESSAGE","LOGGED_OUT","post","Cookies","cookies","String","Math","random","createSessionToken","roles","use"],"sources":["../../../../src/api/endpoint/api/user.ts"],"sourcesContent":["import Cookies from 'cookies';\nimport express, { Response, Router } from 'express';\nimport _ from 'lodash';\n\nimport { createRemoteUser } from '@verdaccio/config';\nimport { rateLimit } from '@verdaccio/middleware';\nimport { Config, RemoteUser } from '@verdaccio/types';\nimport { createSessionToken, getAuthenticatedMessage } from '@verdaccio/utils';\n\nimport Auth from '../../../lib/auth';\nimport { getApiToken, validatePassword } from '../../../lib/auth-utils';\nimport { API_ERROR, API_MESSAGE, HEADERS, HTTP_STATUS } from '../../../lib/constants';\nimport { logger } from '../../../lib/logger';\nimport { ErrorCode } from '../../../lib/utils';\nimport { $NextFunctionVer, $RequestExtend, $ResponseExtend } from '../../../types';\n\nexport default function (route: Router, auth: Auth, config: Config): void {\n  /* eslint new-cap:off */\n  const userRouter = express.Router();\n\n  userRouter.get(\n    '/-/user/:org_couchdb_user',\n    rateLimit(config?.userRateLimit),\n    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\n  userRouter.put(\n    '/-/user/:org_couchdb_user/:_rev?/:revision?',\n    rateLimit(config?.userRateLimit),\n    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(\n          name,\n          password,\n          async function callbackAuthenticate(err, user): Promise<void> {\n            if (err) {\n              logger.error(\n                { name, err },\n                'authenticating for user @{username} failed. Error: @{err.message}'\n              );\n              return next(\n                ErrorCode.getCode(HTTP_STATUS.UNAUTHORIZED, API_ERROR.BAD_USERNAME_PASSWORD)\n              );\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        );\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(\n                ErrorCode.getCode(err.status, err.message) || ErrorCode.getConflict(err.message)\n              );\n            }\n            return next(err);\n          }\n\n          const token =\n            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\n  userRouter.delete(\n    '/-/user/token/*',\n    rateLimit(config?.userRateLimit),\n    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\n  // placeholder 'cause npm require to be authenticated to publish\n  // we do not do any real authentication yet\n  userRouter.post(\n    '/_session',\n    Cookies.express(),\n    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\n  route.use(userRouter);\n}\n"],"mappings":"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"}
84
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_express","_interopRequireDefault","require","_lodash","_config","_middleware","_utils","_authUtils","_constants","_logger","_utils2","obj","__esModule","default","_default","route","auth","config","userRouter","express","Router","get","rateLimit","userRateLimit","req","res","next","status","HTTP_STATUS","OK","ok","getAuthenticatedMessage","remote_user","name","put","password","body","remoteName","_","isNil","authenticate","callbackAuthenticate","err","user","logger","error","ErrorCode","getCode","UNAUTHORIZED","API_ERROR","BAD_USERNAME_PASSWORD","restoredRemoteUser","createRemoteUser","groups","token","getApiToken","CREATED","set","HEADERS","CACHE_CONTROL","validatePassword","BAD_REQUEST","PASSWORD_SHORT","add_user","INTERNAL_ERROR","message","getConflict","undefined","delete","API_MESSAGE","LOGGED_OUT","use"],"sources":["../../../../src/api/endpoint/api/user.ts"],"sourcesContent":["import Cookies from 'cookies';\nimport express, { Response, Router } from 'express';\nimport _ from 'lodash';\n\nimport { createRemoteUser } from '@verdaccio/config';\nimport { rateLimit } from '@verdaccio/middleware';\nimport { Config, RemoteUser } from '@verdaccio/types';\nimport { createSessionToken, getAuthenticatedMessage } from '@verdaccio/utils';\n\nimport Auth from '../../../lib/auth';\nimport { getApiToken, validatePassword } from '../../../lib/auth-utils';\nimport { API_ERROR, API_MESSAGE, HEADERS, HTTP_STATUS } from '../../../lib/constants';\nimport { logger } from '../../../lib/logger';\nimport { ErrorCode } from '../../../lib/utils';\nimport { $NextFunctionVer, $RequestExtend, $ResponseExtend } from '../../../types';\n\nexport default function (route: Router, auth: Auth, config: Config): void {\n  /* eslint new-cap:off */\n  const userRouter = express.Router();\n\n  userRouter.get(\n    '/-/user/:org_couchdb_user',\n    rateLimit(config?.userRateLimit),\n    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\n  userRouter.put(\n    '/-/user/:org_couchdb_user/:_rev?/:revision?',\n    rateLimit(config?.userRateLimit),\n    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(\n          name,\n          password,\n          async function callbackAuthenticate(err, user): Promise<void> {\n            if (err) {\n              logger.error(\n                { name, err },\n                'authenticating for user @{username} failed. Error: @{err.message}'\n              );\n              return next(\n                ErrorCode.getCode(HTTP_STATUS.UNAUTHORIZED, API_ERROR.BAD_USERNAME_PASSWORD)\n              );\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        );\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(\n                ErrorCode.getCode(err.status, err.message) || ErrorCode.getConflict(err.message)\n              );\n            }\n            return next(err);\n          }\n\n          const token =\n            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\n  userRouter.delete(\n    '/-/user/token/*',\n    rateLimit(config?.userRateLimit),\n    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\n  route.use(userRouter);\n}\n"],"mappings":";;;;;;AACA,IAAAA,QAAA,GAAAC,sBAAA,CAAAC,OAAA;AACA,IAAAC,OAAA,GAAAF,sBAAA,CAAAC,OAAA;AAEA,IAAAE,OAAA,GAAAF,OAAA;AACA,IAAAG,WAAA,GAAAH,OAAA;AAEA,IAAAI,MAAA,GAAAJ,OAAA;AAGA,IAAAK,UAAA,GAAAL,OAAA;AACA,IAAAM,UAAA,GAAAN,OAAA;AACA,IAAAO,OAAA,GAAAP,OAAA;AACA,IAAAQ,OAAA,GAAAR,OAAA;AAA+C,SAAAD,uBAAAU,GAAA,WAAAA,GAAA,IAAAA,GAAA,CAAAC,UAAA,GAAAD,GAAA,KAAAE,OAAA,EAAAF,GAAA;AAGhC,SAAAG,SAAUC,KAAa,EAAEC,IAAU,EAAEC,MAAc,EAAQ;EACxE;EACA,MAAMC,UAAU,GAAGC,gBAAO,CAACC,MAAM,CAAC,CAAC;EAEnCF,UAAU,CAACG,GAAG,CACZ,2BAA2B,EAC3B,IAAAC,qBAAS,EAACL,MAAM,aAANA,MAAM,uBAANA,MAAM,CAAEM,aAAa,CAAC,EAChC,UAAUC,GAAmB,EAAEC,GAAa,EAAEC,IAAsB,EAAQ;IAC1ED,GAAG,CAACE,MAAM,CAACC,sBAAW,CAACC,EAAE,CAAC;IAC1BH,IAAI,CAAC;MACHI,EAAE,EAAE,IAAAC,8BAAuB,EAACP,GAAG,CAACQ,WAAW,CAACC,IAAI;IAClD,CAAC,CAAC;EACJ,CACF,CAAC;EAEDf,UAAU,CAACgB,GAAG,CACZ,6CAA6C,EAC7C,IAAAZ,qBAAS,EAACL,MAAM,aAANA,MAAM,uBAANA,MAAM,CAAEM,aAAa,CAAC,EAChC,UAAUC,GAAmB,EAAEC,GAAa,EAAEC,IAAsB,EAAQ;IAC1E,MAAM;MAAEO,IAAI;MAAEE;IAAS,CAAC,GAAGX,GAAG,CAACY,IAAI;IACnC,MAAMC,UAAU,GAAGb,GAAG,CAACQ,WAAW,CAACC,IAAI;IAEvC,IAAIK,eAAC,CAACC,KAAK,CAACF,UAAU,CAAC,KAAK,KAAK,IAAIC,eAAC,CAACC,KAAK,CAACN,IAAI,CAAC,KAAK,KAAK,IAAII,UAAU,KAAKJ,IAAI,EAAE;MACnFjB,IAAI,CAACwB,YAAY,CACfP,IAAI,EACJE,QAAQ,EACR,eAAeM,oBAAoBA,CAACC,GAAG,EAAEC,IAAI,EAAiB;QAC5D,IAAID,GAAG,EAAE;UACPE,cAAM,CAACC,KAAK,CACV;YAAEZ,IAAI;YAAES;UAAI,CAAC,EACb,mEACF,CAAC;UACD,OAAOhB,IAAI,CACToB,iBAAS,CAACC,OAAO,CAACnB,sBAAW,CAACoB,YAAY,EAAEC,oBAAS,CAACC,qBAAqB,CAC7E,CAAC;QACH;QAEA,MAAMC,kBAA8B,GAAG,IAAAC,wBAAgB,EAACnB,IAAI,EAAEU,IAAI,CAACU,MAAM,IAAI,EAAE,CAAC;QAChF,MAAMC,KAAK,GAAG,MAAM,IAAAC,sBAAW,EAACvC,IAAI,EAAEC,MAAM,EAAEkC,kBAAkB,EAAEhB,QAAQ,CAAC;QAE3EV,GAAG,CAACE,MAAM,CAACC,sBAAW,CAAC4B,OAAO,CAAC;QAC/B/B,GAAG,CAACgC,GAAG,CAACC,kBAAO,CAACC,aAAa,EAAE,oBAAoB,CAAC;QACpD,OAAOjC,IAAI,CAAC;UACVI,EAAE,EAAE,IAAAC,8BAAuB,EAACP,GAAG,CAACQ,WAAW,CAACC,IAAI,CAAC;UACjDqB;QACF,CAAC,CAAC;MACJ,CACF,CAAC;IACH,CAAC,MAAM;MACL,IAAI,IAAAM,2BAAgB,EAACzB,QAAQ,CAAC,KAAK,KAAK,EAAE;QACxC;QACA,OAAOT,IAAI,CAACoB,iBAAS,CAACC,OAAO,CAACnB,sBAAW,CAACiC,WAAW,EAAEZ,oBAAS,CAACa,cAAc,CAAC,CAAC;MACnF;MAEA9C,IAAI,CAAC+C,QAAQ,CAAC9B,IAAI,EAAEE,QAAQ,EAAE,gBAAgBO,GAAG,EAAEC,IAAI,EAAiB;QACtE,IAAID,GAAG,EAAE;UACP,IAAIA,GAAG,CAACf,MAAM,IAAIC,sBAAW,CAACiC,WAAW,IAAInB,GAAG,CAACf,MAAM,GAAGC,sBAAW,CAACoC,cAAc,EAAE;YACpF;YACA;YACA;YACA,OAAOtC,IAAI,CACToB,iBAAS,CAACC,OAAO,CAACL,GAAG,CAACf,MAAM,EAAEe,GAAG,CAACuB,OAAO,CAAC,IAAInB,iBAAS,CAACoB,WAAW,CAACxB,GAAG,CAACuB,OAAO,CACjF,CAAC;UACH;UACA,OAAOvC,IAAI,CAACgB,GAAG,CAAC;QAClB;QAEA,MAAMY,KAAK,GACTrB,IAAI,IAAIE,QAAQ,GAAG,MAAM,IAAAoB,sBAAW,EAACvC,IAAI,EAAEC,MAAM,EAAE0B,IAAI,EAAER,QAAQ,CAAC,GAAGgC,SAAS;QAEhF3C,GAAG,CAACQ,WAAW,GAAGW,IAAI;QACtBlB,GAAG,CAACE,MAAM,CAACC,sBAAW,CAAC4B,OAAO,CAAC;QAC/B/B,GAAG,CAACgC,GAAG,CAACC,kBAAO,CAACC,aAAa,EAAE,oBAAoB,CAAC;QACpD,OAAOjC,IAAI,CAAC;UACVI,EAAE,EAAG,SAAQN,GAAG,CAACY,IAAI,CAACH,IAAK,WAAU;UACrCqB;QACF,CAAC,CAAC;MACJ,CAAC,CAAC;IACJ;EACF,CACF,CAAC;EAEDpC,UAAU,CAACkD,MAAM,CACf,iBAAiB,EACjB,IAAA9C,qBAAS,EAACL,MAAM,aAANA,MAAM,uBAANA,MAAM,CAAEM,aAAa,CAAC,EAChC,UAAUC,GAAmB,EAAEC,GAAa,EAAEC,IAAsB,EAAQ;IAC1ED,GAAG,CAACE,MAAM,CAACC,sBAAW,CAACC,EAAE,CAAC;IAC1BH,IAAI,CAAC;MACHI,EAAE,EAAEuC,sBAAW,CAACC;IAClB,CAAC,CAAC;EACJ,CACF,CAAC;EAEDvD,KAAK,CAACwD,GAAG,CAACrD,UAAU,CAAC;AACvB"}
@@ -11,4 +11,4 @@ export interface Profile {
11
11
  cidr_whitelist: string[] | null;
12
12
  fullname: string;
13
13
  }
14
- export default function (auth: Auth, config: ConfigYaml): Router;
14
+ export default function (router: Router, auth: Auth, config: ConfigYaml): void;
@@ -4,15 +4,13 @@ Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
6
  exports.default = _default;
7
- var _express = require("express");
8
7
  var _lodash = _interopRequireDefault(require("lodash"));
9
8
  var _middleware = require("@verdaccio/middleware");
10
9
  var _authUtils = require("../../../../lib/auth-utils");
11
10
  var _constants = require("../../../../lib/constants");
12
11
  var _utils = require("../../../../lib/utils");
13
12
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
14
- function _default(auth, config) {
15
- const profileRoute = (0, _express.Router)(); /* eslint new-cap: 0 */
13
+ function _default(router, auth, config) {
16
14
  function buildProfile(name) {
17
15
  return {
18
16
  tfa: false,
@@ -25,7 +23,7 @@ function _default(auth, config) {
25
23
  fullname: ''
26
24
  };
27
25
  }
28
- profileRoute.get('/user', (0, _middleware.rateLimit)(config === null || config === void 0 ? void 0 : config.userRateLimit), function (req, res, next) {
26
+ router.get('/-/npm/v1/user', (0, _middleware.rateLimit)(config === null || config === void 0 ? void 0 : config.userRateLimit), function (req, res, next) {
29
27
  if (_lodash.default.isNil(req.remote_user.name) === false) {
30
28
  return next(buildProfile(req.remote_user.name));
31
29
  }
@@ -34,7 +32,7 @@ function _default(auth, config) {
34
32
  message: _constants.API_ERROR.MUST_BE_LOGGED
35
33
  });
36
34
  });
37
- profileRoute.post('/user', (0, _middleware.rateLimit)(config === null || config === void 0 ? void 0 : config.userRateLimit), function (req, res, next) {
35
+ router.post('/-/npm/v1/user', (0, _middleware.rateLimit)(config === null || config === void 0 ? void 0 : config.userRateLimit), function (req, res, next) {
38
36
  if (_lodash.default.isNil(req.remote_user.name)) {
39
37
  res.status(_constants.HTTP_STATUS.UNAUTHORIZED);
40
38
  return next({
@@ -70,6 +68,5 @@ function _default(auth, config) {
70
68
  return next(_utils.ErrorCode.getCode(_constants.HTTP_STATUS.INTERNAL_ERROR, _constants.APP_ERROR.PROFILE_ERROR));
71
69
  }
72
70
  });
73
- return profileRoute;
74
71
  }
75
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_express","require","_lodash","_interopRequireDefault","_middleware","_authUtils","_constants","_utils","obj","__esModule","default","_default","auth","config","profileRoute","Router","buildProfile","name","tfa","email","email_verified","created","updated","cidr_whitelist","fullname","get","rateLimit","userRateLimit","req","res","next","_","isNil","remote_user","status","HTTP_STATUS","UNAUTHORIZED","message","API_ERROR","MUST_BE_LOGGED","post","password","body","validatePassword","new","ErrorCode","getCode","PASSWORD_SHORT","changePassword","old","err","isUpdated","isNull","getConflict","getInternalError","INTERNAL_SERVER_ERROR","SERVICE_UNAVAILABLE","SUPPORT_ERRORS","TFA_DISABLED","INTERNAL_ERROR","APP_ERROR","PROFILE_ERROR"],"sources":["../../../../../src/api/endpoint/api/v1/profile.ts"],"sourcesContent":["import { Response, Router } from 'express';\nimport _ from 'lodash';\n\nimport { rateLimit } from '@verdaccio/middleware';\nimport { ConfigYaml } from '@verdaccio/types';\n\nimport Auth from '../../../../lib/auth';\nimport { validatePassword } from '../../../../lib/auth-utils';\nimport { API_ERROR, APP_ERROR, HTTP_STATUS, SUPPORT_ERRORS } from '../../../../lib/constants';\nimport { ErrorCode } from '../../../../lib/utils';\nimport { $NextFunctionVer, $RequestExtend } from '../../../../types';\n\nexport interface Profile {\n  tfa: boolean;\n  name: string;\n  email: string;\n  email_verified: boolean;\n  created: string;\n  updated: string;\n  cidr_whitelist: string[] | null;\n  fullname: string;\n}\n\nexport default function (auth: Auth, config: ConfigYaml): Router {\n  const profileRoute = Router(); /* eslint new-cap: 0 */\n  function buildProfile(name: string): Profile {\n    return {\n      tfa: false,\n      name,\n      email: '',\n      email_verified: false,\n      created: '',\n      updated: '',\n      cidr_whitelist: null,\n      fullname: '',\n    };\n  }\n\n  profileRoute.get(\n    '/user',\n    rateLimit(config?.userRateLimit),\n    function (req: $RequestExtend, res: Response, next: $NextFunctionVer): void {\n      if (_.isNil(req.remote_user.name) === false) {\n        return next(buildProfile(req.remote_user.name));\n      }\n\n      res.status(HTTP_STATUS.UNAUTHORIZED);\n      return next({\n        message: API_ERROR.MUST_BE_LOGGED,\n      });\n    }\n  );\n\n  profileRoute.post(\n    '/user',\n    rateLimit(config?.userRateLimit),\n    function (req: $RequestExtend, res: Response, next: $NextFunctionVer): void {\n      if (_.isNil(req.remote_user.name)) {\n        res.status(HTTP_STATUS.UNAUTHORIZED);\n        return next({\n          message: API_ERROR.MUST_BE_LOGGED,\n        });\n      }\n\n      const { password, tfa } = req.body;\n      const { name } = req.remote_user;\n\n      if (_.isNil(password) === false) {\n        if (validatePassword(password.new) === false) {\n          /* eslint new-cap:off */\n          return next(ErrorCode.getCode(HTTP_STATUS.UNAUTHORIZED, API_ERROR.PASSWORD_SHORT));\n          /* eslint new-cap:off */\n        }\n\n        auth.changePassword(\n          name,\n          password.old,\n          password.new,\n          (err, isUpdated): $NextFunctionVer => {\n            if (_.isNull(err) === false) {\n              return next(\n                ErrorCode.getCode(err.status, err.message) || ErrorCode.getConflict(err.message)\n              );\n            }\n\n            if (isUpdated) {\n              return next(buildProfile(req.remote_user.name));\n            }\n            return next(ErrorCode.getInternalError(API_ERROR.INTERNAL_SERVER_ERROR));\n          }\n        );\n      } else if (_.isNil(tfa) === false) {\n        return next(\n          ErrorCode.getCode(HTTP_STATUS.SERVICE_UNAVAILABLE, SUPPORT_ERRORS.TFA_DISABLED)\n        );\n      } else {\n        return next(ErrorCode.getCode(HTTP_STATUS.INTERNAL_ERROR, APP_ERROR.PROFILE_ERROR));\n      }\n    }\n  );\n\n  return profileRoute;\n}\n"],"mappings":"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"}
72
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_lodash","_interopRequireDefault","require","_middleware","_authUtils","_constants","_utils","obj","__esModule","default","_default","router","auth","config","buildProfile","name","tfa","email","email_verified","created","updated","cidr_whitelist","fullname","get","rateLimit","userRateLimit","req","res","next","_","isNil","remote_user","status","HTTP_STATUS","UNAUTHORIZED","message","API_ERROR","MUST_BE_LOGGED","post","password","body","validatePassword","new","ErrorCode","getCode","PASSWORD_SHORT","changePassword","old","err","isUpdated","isNull","getConflict","getInternalError","INTERNAL_SERVER_ERROR","SERVICE_UNAVAILABLE","SUPPORT_ERRORS","TFA_DISABLED","INTERNAL_ERROR","APP_ERROR","PROFILE_ERROR"],"sources":["../../../../../src/api/endpoint/api/v1/profile.ts"],"sourcesContent":["import { Response, Router } from 'express';\nimport _ from 'lodash';\n\nimport { rateLimit } from '@verdaccio/middleware';\nimport { ConfigYaml } from '@verdaccio/types';\n\nimport Auth from '../../../../lib/auth';\nimport { validatePassword } from '../../../../lib/auth-utils';\nimport { API_ERROR, APP_ERROR, HTTP_STATUS, SUPPORT_ERRORS } from '../../../../lib/constants';\nimport { ErrorCode } from '../../../../lib/utils';\nimport { $NextFunctionVer, $RequestExtend } from '../../../../types';\n\nexport interface Profile {\n  tfa: boolean;\n  name: string;\n  email: string;\n  email_verified: boolean;\n  created: string;\n  updated: string;\n  cidr_whitelist: string[] | null;\n  fullname: string;\n}\n\nexport default function (router: Router, auth: Auth, config: ConfigYaml) {\n  function buildProfile(name: string): Profile {\n    return {\n      tfa: false,\n      name,\n      email: '',\n      email_verified: false,\n      created: '',\n      updated: '',\n      cidr_whitelist: null,\n      fullname: '',\n    };\n  }\n\n  router.get(\n    '/-/npm/v1/user',\n    rateLimit(config?.userRateLimit),\n    function (req: $RequestExtend, res: Response, next: $NextFunctionVer): void {\n      if (_.isNil(req.remote_user.name) === false) {\n        return next(buildProfile(req.remote_user.name));\n      }\n\n      res.status(HTTP_STATUS.UNAUTHORIZED);\n      return next({\n        message: API_ERROR.MUST_BE_LOGGED,\n      });\n    }\n  );\n\n  router.post(\n    '/-/npm/v1/user',\n    rateLimit(config?.userRateLimit),\n    function (req: $RequestExtend, res: Response, next: $NextFunctionVer): void {\n      if (_.isNil(req.remote_user.name)) {\n        res.status(HTTP_STATUS.UNAUTHORIZED);\n        return next({\n          message: API_ERROR.MUST_BE_LOGGED,\n        });\n      }\n\n      const { password, tfa } = req.body;\n      const { name } = req.remote_user;\n\n      if (_.isNil(password) === false) {\n        if (validatePassword(password.new) === false) {\n          /* eslint new-cap:off */\n          return next(ErrorCode.getCode(HTTP_STATUS.UNAUTHORIZED, API_ERROR.PASSWORD_SHORT));\n          /* eslint new-cap:off */\n        }\n\n        auth.changePassword(\n          name,\n          password.old,\n          password.new,\n          (err, isUpdated): $NextFunctionVer => {\n            if (_.isNull(err) === false) {\n              return next(\n                ErrorCode.getCode(err.status, err.message) || ErrorCode.getConflict(err.message)\n              );\n            }\n\n            if (isUpdated) {\n              return next(buildProfile(req.remote_user.name));\n            }\n            return next(ErrorCode.getInternalError(API_ERROR.INTERNAL_SERVER_ERROR));\n          }\n        );\n      } else if (_.isNil(tfa) === false) {\n        return next(\n          ErrorCode.getCode(HTTP_STATUS.SERVICE_UNAVAILABLE, SUPPORT_ERRORS.TFA_DISABLED)\n        );\n      } else {\n        return next(ErrorCode.getCode(HTTP_STATUS.INTERNAL_ERROR, APP_ERROR.PROFILE_ERROR));\n      }\n    }\n  );\n}\n"],"mappings":"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"}
@@ -5,4 +5,4 @@ import Storage from '../../../../lib/storage';
5
5
  export type NormalizeToken = Token & {
6
6
  created: string;
7
7
  };
8
- export default function (auth: Auth, storage: Storage, config: Config): Router;
8
+ export default function (router: Router, auth: Auth, storage: Storage, config: Config): void;
@@ -5,7 +5,6 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports.default = _default;
7
7
  var _debug = _interopRequireDefault(require("debug"));
8
- var _express = require("express");
9
8
  var _lodash = _interopRequireDefault(require("lodash"));
10
9
  var _middleware = require("@verdaccio/middleware");
11
10
  var _utils = require("@verdaccio/utils");
@@ -27,9 +26,8 @@ function normalizeToken(token) {
27
26
  }
28
27
 
29
28
  // https://github.com/npm/npm-profile/blob/latest/lib/index.js
30
- function _default(auth, storage, config) {
31
- const tokenRoute = (0, _express.Router)(); /* eslint new-cap: 0 */
32
- tokenRoute.get('/tokens', (0, _middleware.rateLimit)(config === null || config === void 0 ? void 0 : config.userRateLimit), async function (req, res, next) {
29
+ function _default(router, auth, storage, config) {
30
+ router.get('/-/npm/v1/tokens', (0, _middleware.rateLimit)(config === null || config === void 0 ? void 0 : config.userRateLimit), async function (req, res, next) {
33
31
  const {
34
32
  name
35
33
  } = req.remote_user;
@@ -56,7 +54,7 @@ function _default(auth, storage, config) {
56
54
  }
57
55
  return next(_utils2.ErrorCode.getUnauthorized());
58
56
  });
59
- tokenRoute.post('/tokens', (0, _middleware.rateLimit)(config === null || config === void 0 ? void 0 : config.userRateLimit), function (req, res, next) {
57
+ router.post('/-/npm/v1/tokens', (0, _middleware.rateLimit)(config === null || config === void 0 ? void 0 : config.userRateLimit), function (req, res, next) {
60
58
  const {
61
59
  password,
62
60
  readonly,
@@ -115,7 +113,7 @@ function _default(auth, storage, config) {
115
113
  }
116
114
  });
117
115
  });
118
- tokenRoute.delete('/tokens/token/:tokenKey', (0, _middleware.rateLimit)(config === null || config === void 0 ? void 0 : config.userRateLimit), async (req, res, next) => {
116
+ router.delete('/-/npm/v1/tokens/token/:tokenKey', (0, _middleware.rateLimit)(config === null || config === void 0 ? void 0 : config.userRateLimit), async (req, res, next) => {
119
117
  const {
120
118
  params: {
121
119
  tokenKey
@@ -142,6 +140,5 @@ function _default(auth, storage, config) {
142
140
  }
143
141
  return next(_utils2.ErrorCode.getUnauthorized());
144
142
  });
145
- return tokenRoute;
146
143
  }
147
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_debug","_interopRequireDefault","require","_express","_lodash","_middleware","_utils","_authUtils","_constants","_logger","_utils2","obj","__esModule","default","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty","getOwnPropertyDescriptors","defineProperties","defineProperty","value","_toPropertyKey","configurable","writable","arg","_toPrimitive","String","input","hint","prim","Symbol","toPrimitive","undefined","res","call","TypeError","Number","debug","buildDebug","normalizeToken","token","created","Date","toISOString","_default","auth","storage","config","tokenRoute","Router","get","rateLimit","userRateLimit","req","next","name","remote_user","_","isNil","tokens","readTokens","user","totalTokens","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","getApiToken","stringToMD5","maskedToken","mask","getTime","cidr","set","HEADERS","CACHE_CONTROL","delete","params","tokenKey","deleteToken","info"],"sources":["../../../../../src/api/endpoint/api/v1/token.ts"],"sourcesContent":["import buildDebug from 'debug';\nimport { Response, Router } from 'express';\nimport _ from 'lodash';\n\nimport { rateLimit } from '@verdaccio/middleware';\nimport { Config, RemoteUser, Token } from '@verdaccio/types';\nimport { stringToMD5 } from '@verdaccio/utils';\n\nimport Auth from '../../../../lib/auth';\nimport { getApiToken } from '../../../../lib/auth-utils';\nimport { HEADERS, HTTP_STATUS, SUPPORT_ERRORS } from '../../../../lib/constants';\nimport { logger } from '../../../../lib/logger';\nimport Storage from '../../../../lib/storage';\nimport { ErrorCode, mask } from '../../../../lib/utils';\nimport { $NextFunctionVer, $RequestExtend } 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 (auth: Auth, storage: Storage, config: Config): Router {\n  const tokenRoute = Router(); /* eslint new-cap: 0 */\n  tokenRoute.get(\n    '/tokens',\n    rateLimit(config?.userRateLimit),\n    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: any) {\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\n  tokenRoute.post(\n    '/tokens',\n    rateLimit(config?.userRateLimit),\n    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(\n            ErrorCode.getCode(HTTP_STATUS.NOT_IMPLEMENTED, SUPPORT_ERRORS.STORAGE_NOT_IMPLEMENT)\n          );\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: any) {\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\n  tokenRoute.delete(\n    '/tokens/token/:tokenKey',\n    rateLimit(config?.userRateLimit),\n    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: any) {\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\n  return tokenRoute;\n}\n"],"mappings":"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"}
144
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_debug","_interopRequireDefault","require","_lodash","_middleware","_utils","_authUtils","_constants","_logger","_utils2","obj","__esModule","default","ownKeys","object","enumerableOnly","keys","Object","getOwnPropertySymbols","symbols","filter","sym","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","target","i","arguments","length","source","forEach","key","_defineProperty","getOwnPropertyDescriptors","defineProperties","defineProperty","value","_toPropertyKey","configurable","writable","arg","_toPrimitive","String","input","hint","prim","Symbol","toPrimitive","undefined","res","call","TypeError","Number","debug","buildDebug","normalizeToken","token","created","Date","toISOString","_default","router","auth","storage","config","get","rateLimit","userRateLimit","req","next","name","remote_user","_","isNil","tokens","readTokens","user","totalTokens","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","getApiToken","stringToMD5","maskedToken","mask","getTime","cidr","set","HEADERS","CACHE_CONTROL","delete","params","tokenKey","deleteToken","info"],"sources":["../../../../../src/api/endpoint/api/v1/token.ts"],"sourcesContent":["import buildDebug from 'debug';\nimport { Response, Router } from 'express';\nimport _ from 'lodash';\n\nimport { rateLimit } from '@verdaccio/middleware';\nimport { Config, RemoteUser, Token } from '@verdaccio/types';\nimport { stringToMD5 } from '@verdaccio/utils';\n\nimport Auth from '../../../../lib/auth';\nimport { getApiToken } from '../../../../lib/auth-utils';\nimport { HEADERS, HTTP_STATUS, SUPPORT_ERRORS } from '../../../../lib/constants';\nimport { logger } from '../../../../lib/logger';\nimport Storage from '../../../../lib/storage';\nimport { ErrorCode, mask } from '../../../../lib/utils';\nimport { $NextFunctionVer, $RequestExtend } 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 (router: Router, auth: Auth, storage: Storage, config: Config) {\n  router.get(\n    '/-/npm/v1/tokens',\n    rateLimit(config?.userRateLimit),\n    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: any) {\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\n  router.post(\n    '/-/npm/v1/tokens',\n    rateLimit(config?.userRateLimit),\n    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(\n            ErrorCode.getCode(HTTP_STATUS.NOT_IMPLEMENTED, SUPPORT_ERRORS.STORAGE_NOT_IMPLEMENT)\n          );\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: any) {\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\n  router.delete(\n    '/-/npm/v1/tokens/token/:tokenKey',\n    rateLimit(config?.userRateLimit),\n    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: any) {\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}\n"],"mappings":"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"}
@@ -5,19 +5,10 @@ Object.defineProperty(exports, "__esModule", {
5
5
  });
6
6
  exports.default = _default;
7
7
  function _default(route) {
8
- route.get('/whoami', (req, res, next) => {
9
- if (req.get('referer') === 'whoami') {
10
- next({
11
- username: req.remote_user.name
12
- });
13
- } else {
14
- next('route');
15
- }
16
- });
17
8
  route.get('/-/whoami', (req, res, next) => {
18
9
  next({
19
10
  username: req.remote_user.name
20
11
  });
21
12
  });
22
13
  }
23
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfZGVmYXVsdCIsInJvdXRlIiwiZ2V0IiwicmVxIiwicmVzIiwibmV4dCIsInVzZXJuYW1lIiwicmVtb3RlX3VzZXIiLCJuYW1lIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2FwaS9lbmRwb2ludC9hcGkvd2hvYW1pLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFJlc3BvbnNlLCBSb3V0ZXIgfSBmcm9tICdleHByZXNzJztcblxuaW1wb3J0IHsgJE5leHRGdW5jdGlvblZlciwgJFJlcXVlc3RFeHRlbmQgfSBmcm9tICcuLi8uLi8uLi90eXBlcyc7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIChyb3V0ZTogUm91dGVyKTogdm9pZCB7XG4gIHJvdXRlLmdldCgnL3dob2FtaScsIChyZXE6ICRSZXF1ZXN0RXh0ZW5kLCByZXM6IFJlc3BvbnNlLCBuZXh0OiAkTmV4dEZ1bmN0aW9uVmVyKTogdm9pZCA9PiB7XG4gICAgaWYgKHJlcS5nZXQoJ3JlZmVyZXInKSA9PT0gJ3dob2FtaScpIHtcbiAgICAgIG5leHQoeyB1c2VybmFtZTogcmVxLnJlbW90ZV91c2VyLm5hbWUgfSk7XG4gICAgfSBlbHNlIHtcbiAgICAgIG5leHQoJ3JvdXRlJyk7XG4gICAgfVxuICB9KTtcblxuICByb3V0ZS5nZXQoJy8tL3dob2FtaScsIChyZXE6ICRSZXF1ZXN0RXh0ZW5kLCByZXM6IFJlc3BvbnNlLCBuZXh0OiAkTmV4dEZ1bmN0aW9uVmVyKTogYW55ID0+IHtcbiAgICBuZXh0KHsgdXNlcm5hbWU6IHJlcS5yZW1vdGVfdXNlci5uYW1lIH0pO1xuICB9KTtcbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBSWUsU0FBQUEsU0FBVUMsS0FBYSxFQUFRO0VBQzVDQSxLQUFLLENBQUNDLEdBQUcsQ0FBQyxTQUFTLEVBQUUsQ0FBQ0MsR0FBbUIsRUFBRUMsR0FBYSxFQUFFQyxJQUFzQixLQUFXO0lBQ3pGLElBQUlGLEdBQUcsQ0FBQ0QsR0FBRyxDQUFDLFNBQVMsQ0FBQyxLQUFLLFFBQVEsRUFBRTtNQUNuQ0csSUFBSSxDQUFDO1FBQUVDLFFBQVEsRUFBRUgsR0FBRyxDQUFDSSxXQUFXLENBQUNDO01BQUssQ0FBQyxDQUFDO0lBQzFDLENBQUMsTUFBTTtNQUNMSCxJQUFJLENBQUMsT0FBTyxDQUFDO0lBQ2Y7RUFDRixDQUFDLENBQUM7RUFFRkosS0FBSyxDQUFDQyxHQUFHLENBQUMsV0FBVyxFQUFFLENBQUNDLEdBQW1CLEVBQUVDLEdBQWEsRUFBRUMsSUFBc0IsS0FBVTtJQUMxRkEsSUFBSSxDQUFDO01BQUVDLFFBQVEsRUFBRUgsR0FBRyxDQUFDSSxXQUFXLENBQUNDO0lBQUssQ0FBQyxDQUFDO0VBQzFDLENBQUMsQ0FBQztBQUNKIn0=
14
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfZGVmYXVsdCIsInJvdXRlIiwiZ2V0IiwicmVxIiwicmVzIiwibmV4dCIsInVzZXJuYW1lIiwicmVtb3RlX3VzZXIiLCJuYW1lIl0sInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2FwaS9lbmRwb2ludC9hcGkvd2hvYW1pLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFJlc3BvbnNlLCBSb3V0ZXIgfSBmcm9tICdleHByZXNzJztcblxuaW1wb3J0IHsgJE5leHRGdW5jdGlvblZlciwgJFJlcXVlc3RFeHRlbmQgfSBmcm9tICcuLi8uLi8uLi90eXBlcyc7XG5cbmV4cG9ydCBkZWZhdWx0IGZ1bmN0aW9uIChyb3V0ZTogUm91dGVyKTogdm9pZCB7XG4gIHJvdXRlLmdldCgnLy0vd2hvYW1pJywgKHJlcTogJFJlcXVlc3RFeHRlbmQsIHJlczogUmVzcG9uc2UsIG5leHQ6ICROZXh0RnVuY3Rpb25WZXIpOiBhbnkgPT4ge1xuICAgIG5leHQoeyB1c2VybmFtZTogcmVxLnJlbW90ZV91c2VyLm5hbWUgfSk7XG4gIH0pO1xufVxuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7QUFJZSxTQUFBQSxTQUFVQyxLQUFhLEVBQVE7RUFDNUNBLEtBQUssQ0FBQ0MsR0FBRyxDQUFDLFdBQVcsRUFBRSxDQUFDQyxHQUFtQixFQUFFQyxHQUFhLEVBQUVDLElBQXNCLEtBQVU7SUFDMUZBLElBQUksQ0FBQztNQUFFQyxRQUFRLEVBQUVILEdBQUcsQ0FBQ0ksV0FBVyxDQUFDQztJQUFLLENBQUMsQ0FBQztFQUMxQyxDQUFDLENBQUM7QUFDSiJ9
@@ -12,8 +12,9 @@ var _publish = _interopRequireDefault(require("./api/publish"));
12
12
  var _search = _interopRequireDefault(require("./api/search"));
13
13
  var _stars = _interopRequireDefault(require("./api/stars"));
14
14
  var _user = _interopRequireDefault(require("./api/user"));
15
- var _v = _interopRequireDefault(require("./api/v1"));
15
+ var _profile = _interopRequireDefault(require("./api/v1/profile"));
16
16
  var _search2 = _interopRequireDefault(require("./api/v1/search"));
17
+ var _token = _interopRequireDefault(require("./api/v1/token"));
17
18
  var _whoami = _interopRequireDefault(require("./api/whoami"));
18
19
  function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
19
20
  const {
@@ -48,17 +49,17 @@ function _default(config, auth, storage) {
48
49
  app.use(antiLoop(config));
49
50
  // encode / in a scoped package name to be matched as a single parameter in routes
50
51
  app.use(encodeScopePackage);
51
- // for "npm whoami"
52
52
  (0, _whoami.default)(app);
53
- (0, _package.default)(app, auth, storage, config);
54
- (0, _search.default)(app, auth, storage);
53
+ (0, _profile.default)(app, auth, config);
54
+ (0, _search.default)(app);
55
+ (0, _user.default)(app, auth, config);
55
56
  (0, _distTags.default)(app, auth, storage);
56
57
  (0, _publish.default)(app, auth, storage, config);
57
58
  (0, _ping.default)(app);
58
59
  (0, _stars.default)(app, storage);
59
60
  (0, _search2.default)(app, auth, storage);
60
- (0, _user.default)(app, auth, config);
61
- app.use((0, _v.default)(auth, storage, config));
61
+ (0, _token.default)(app, auth, storage, config);
62
+ (0, _package.default)(app, auth, storage, config);
62
63
  return app;
63
64
  }
64
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfZXhwcmVzcyIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwiX2Rpc3RUYWdzIiwiX3BhY2thZ2UiLCJfcGluZyIsIl9wdWJsaXNoIiwiX3NlYXJjaCIsIl9zdGFycyIsIl91c2VyIiwiX3YiLCJfc2VhcmNoMiIsIl93aG9hbWkiLCJvYmoiLCJfX2VzTW9kdWxlIiwiZGVmYXVsdCIsIm1hdGNoIiwidmFsaWRhdGVOYW1lIiwidmFsaWRhdGVQYWNrYWdlIiwiZW5jb2RlU2NvcGVQYWNrYWdlIiwiYW50aUxvb3AiLCJfZGVmYXVsdCIsImNvbmZpZyIsImF1dGgiLCJzdG9yYWdlIiwiYXBwIiwiZXhwcmVzcyIsIlJvdXRlciIsInBhcmFtIiwidXNlIiwiYXBpSldUbWlkZGxld2FyZSIsImpzb24iLCJzdHJpY3QiLCJsaW1pdCIsIm1heF9ib2R5X3NpemUiLCJ3aG9hbWkiLCJwa2ciLCJzZWFyY2giLCJkaXN0VGFncyIsInB1Ymxpc2giLCJwaW5nIiwic3RhcnMiLCJ2MVNlYXJjaCIsInVzZXIiLCJucG1WMSJdLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hcGkvZW5kcG9pbnQvaW5kZXgudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGV4cHJlc3MgZnJvbSAnZXhwcmVzcyc7XG5cbmltcG9ydCB7IENvbmZpZyB9IGZyb20gJ0B2ZXJkYWNjaW8vdHlwZXMnO1xuXG5pbXBvcnQgQXV0aCBmcm9tICcuLi8uLi9saWIvYXV0aCc7XG5pbXBvcnQgU3RvcmFnZSBmcm9tICcuLi8uLi9saWIvc3RvcmFnZSc7XG5pbXBvcnQgZGlzdFRhZ3MgZnJvbSAnLi9hcGkvZGlzdC10YWdzJztcbmltcG9ydCBwa2cgZnJvbSAnLi9hcGkvcGFja2FnZSc7XG5pbXBvcnQgcGluZyBmcm9tICcuL2FwaS9waW5nJztcbmltcG9ydCBwdWJsaXNoIGZyb20gJy4vYXBpL3B1Ymxpc2gnO1xuaW1wb3J0IHNlYXJjaCBmcm9tICcuL2FwaS9zZWFyY2gnO1xuaW1wb3J0IHN0YXJzIGZyb20gJy4vYXBpL3N0YXJzJztcbmltcG9ydCB1c2VyIGZyb20gJy4vYXBpL3VzZXInO1xuaW1wb3J0IG5wbVYxIGZyb20gJy4vYXBpL3YxJztcbmltcG9ydCB2MVNlYXJjaCBmcm9tICcuL2FwaS92MS9zZWFyY2gnO1xuaW1wb3J0IHdob2FtaSBmcm9tICcuL2FwaS93aG9hbWknO1xuXG5jb25zdCB7XG4gIG1hdGNoLFxuICB2YWxpZGF0ZU5hbWUsXG4gIHZhbGlkYXRlUGFja2FnZSxcbiAgZW5jb2RlU2NvcGVQYWNrYWdlLFxuICBhbnRpTG9vcCxcbn0gPSByZXF1aXJlKCdAdmVyZGFjY2lvL21pZGRsZXdhcmUnKTtcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gKGNvbmZpZzogQ29uZmlnLCBhdXRoOiBBdXRoLCBzdG9yYWdlOiBTdG9yYWdlKSB7XG4gIC8qIGVzbGludCBuZXctY2FwOm9mZiAqL1xuICBjb25zdCBhcHAgPSBleHByZXNzLlJvdXRlcigpO1xuICAvKiBlc2xpbnQgbmV3LWNhcDpvZmYgKi9cbiAgLy8gdmFsaWRhdGUgYWxsIG9mIHRoZXNlIHBhcmFtcyBhcyBhIHBhY2thZ2UgbmFtZVxuICAvLyB0aGlzIG1pZ2h0IGJlIHRvbyBoYXJzaCwgc28gYXNrIGlmIGl0IGNhdXNlcyB0cm91YmxlXG4gIGFwcC5wYXJhbSgncGFja2FnZScsIHZhbGlkYXRlUGFja2FnZSk7XG4gIGFwcC5wYXJhbSgnZmlsZW5hbWUnLCB2YWxpZGF0ZU5hbWUpO1xuICBhcHAucGFyYW0oJ3RhZycsIHZhbGlkYXRlTmFtZSk7XG4gIGFwcC5wYXJhbSgndmVyc2lvbicsIHZhbGlkYXRlTmFtZSk7XG4gIGFwcC5wYXJhbSgncmV2aXNpb24nLCB2YWxpZGF0ZU5hbWUpO1xuICBhcHAucGFyYW0oJ3Rva2VuJywgdmFsaWRhdGVOYW1lKTtcblxuICAvLyB0aGVzZSBjYW4ndCBiZSBzYWZlbHkgcHV0IGludG8gZXhwcmVzcyB1cmwgZm9yIHNvbWUgcmVhc29uXG4gIC8vIFRPRE86IEZvciBzb21lIHJlYXNvbj8gd2hhdCByZWFzb24/XG4gIGFwcC5wYXJhbSgnX3JldicsIG1hdGNoKC9eLXJldiQvKSk7XG4gIGFwcC5wYXJhbSgnb3JnX2NvdWNoZGJfdXNlcicsIG1hdGNoKC9eb3JnXFwuY291Y2hkYlxcLnVzZXI6LykpO1xuXG4gIGFwcC51c2UoYXV0aC5hcGlKV1RtaWRkbGV3YXJlKCkpO1xuICBhcHAudXNlKGV4cHJlc3MuanNvbih7IHN0cmljdDogZmFsc2UsIGxpbWl0OiBjb25maWcubWF4X2JvZHlfc2l6ZSB8fCAnMTBtYicgfSkpO1xuICBhcHAudXNlKGFudGlMb29wKGNvbmZpZykpO1xuICAvLyBlbmNvZGUgLyBpbiBhIHNjb3BlZCBwYWNrYWdlIG5hbWUgdG8gYmUgbWF0Y2hlZCBhcyBhIHNpbmdsZSBwYXJhbWV0ZXIgaW4gcm91dGVzXG4gIGFwcC51c2UoZW5jb2RlU2NvcGVQYWNrYWdlKTtcbiAgLy8gZm9yIFwibnBtIHdob2FtaVwiXG4gIHdob2FtaShhcHApO1xuICBwa2coYXBwLCBhdXRoLCBzdG9yYWdlLCBjb25maWcpO1xuICBzZWFyY2goYXBwLCBhdXRoLCBzdG9yYWdlKTtcbiAgZGlzdFRhZ3MoYXBwLCBhdXRoLCBzdG9yYWdlKTtcbiAgcHVibGlzaChhcHAsIGF1dGgsIHN0b3JhZ2UsIGNvbmZpZyk7XG4gIHBpbmcoYXBwKTtcbiAgc3RhcnMoYXBwLCBzdG9yYWdlKTtcbiAgdjFTZWFyY2goYXBwLCBhdXRoLCBzdG9yYWdlKTtcbiAgdXNlcihhcHAsIGF1dGgsIGNvbmZpZyk7XG4gIGFwcC51c2UobnBtVjEoYXV0aCwgc3RvcmFnZSwgY29uZmlnKSk7XG4gIHJldHVybiBhcHA7XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7OztBQUFBLElBQUFBLFFBQUEsR0FBQUMsc0JBQUEsQ0FBQUMsT0FBQTtBQU1BLElBQUFDLFNBQUEsR0FBQUYsc0JBQUEsQ0FBQUMsT0FBQTtBQUNBLElBQUFFLFFBQUEsR0FBQUgsc0JBQUEsQ0FBQUMsT0FBQTtBQUNBLElBQUFHLEtBQUEsR0FBQUosc0JB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
65
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJfZXhwcmVzcyIsIl9pbnRlcm9wUmVxdWlyZURlZmF1bHQiLCJyZXF1aXJlIiwiX2Rpc3RUYWdzIiwiX3BhY2thZ2UiLCJfcGluZyIsIl9wdWJsaXNoIiwiX3NlYXJjaCIsIl9zdGFycyIsIl91c2VyIiwiX3Byb2ZpbGUiLCJfc2VhcmNoMiIsIl90b2tlbiIsIl93aG9hbWkiLCJvYmoiLCJfX2VzTW9kdWxlIiwiZGVmYXVsdCIsIm1hdGNoIiwidmFsaWRhdGVOYW1lIiwidmFsaWRhdGVQYWNrYWdlIiwiZW5jb2RlU2NvcGVQYWNrYWdlIiwiYW50aUxvb3AiLCJfZGVmYXVsdCIsImNvbmZpZyIsImF1dGgiLCJzdG9yYWdlIiwiYXBwIiwiZXhwcmVzcyIsIlJvdXRlciIsInBhcmFtIiwidXNlIiwiYXBpSldUbWlkZGxld2FyZSIsImpzb24iLCJzdHJpY3QiLCJsaW1pdCIsIm1heF9ib2R5X3NpemUiLCJ3aG9hbWkiLCJwcm9maWxlIiwic2VhcmNoIiwidXNlciIsImRpc3RUYWdzIiwicHVibGlzaCIsInBpbmciLCJzdGFycyIsInYxU2VhcmNoIiwidG9rZW4iLCJwa2ciXSwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYXBpL2VuZHBvaW50L2luZGV4LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBleHByZXNzIGZyb20gJ2V4cHJlc3MnO1xuXG5pbXBvcnQgeyBDb25maWcgfSBmcm9tICdAdmVyZGFjY2lvL3R5cGVzJztcblxuaW1wb3J0IEF1dGggZnJvbSAnLi4vLi4vbGliL2F1dGgnO1xuaW1wb3J0IFN0b3JhZ2UgZnJvbSAnLi4vLi4vbGliL3N0b3JhZ2UnO1xuaW1wb3J0IGRpc3RUYWdzIGZyb20gJy4vYXBpL2Rpc3QtdGFncyc7XG5pbXBvcnQgcGtnIGZyb20gJy4vYXBpL3BhY2thZ2UnO1xuaW1wb3J0IHBpbmcgZnJvbSAnLi9hcGkvcGluZyc7XG5pbXBvcnQgcHVibGlzaCBmcm9tICcuL2FwaS9wdWJsaXNoJztcbmltcG9ydCBzZWFyY2ggZnJvbSAnLi9hcGkvc2VhcmNoJztcbmltcG9ydCBzdGFycyBmcm9tICcuL2FwaS9zdGFycyc7XG5pbXBvcnQgdXNlciBmcm9tICcuL2FwaS91c2VyJztcbmltcG9ydCBwcm9maWxlIGZyb20gJy4vYXBpL3YxL3Byb2ZpbGUnO1xuaW1wb3J0IHYxU2VhcmNoIGZyb20gJy4vYXBpL3YxL3NlYXJjaCc7XG5pbXBvcnQgdG9rZW4gZnJvbSAnLi9hcGkvdjEvdG9rZW4nO1xuaW1wb3J0IHdob2FtaSBmcm9tICcuL2FwaS93aG9hbWknO1xuXG5jb25zdCB7XG4gIG1hdGNoLFxuICB2YWxpZGF0ZU5hbWUsXG4gIHZhbGlkYXRlUGFja2FnZSxcbiAgZW5jb2RlU2NvcGVQYWNrYWdlLFxuICBhbnRpTG9vcCxcbn0gPSByZXF1aXJlKCdAdmVyZGFjY2lvL21pZGRsZXdhcmUnKTtcblxuZXhwb3J0IGRlZmF1bHQgZnVuY3Rpb24gKGNvbmZpZzogQ29uZmlnLCBhdXRoOiBBdXRoLCBzdG9yYWdlOiBTdG9yYWdlKSB7XG4gIC8qIGVzbGludCBuZXctY2FwOm9mZiAqL1xuICBjb25zdCBhcHAgPSBleHByZXNzLlJvdXRlcigpO1xuICAvKiBlc2xpbnQgbmV3LWNhcDpvZmYgKi9cbiAgLy8gdmFsaWRhdGUgYWxsIG9mIHRoZXNlIHBhcmFtcyBhcyBhIHBhY2thZ2UgbmFtZVxuICAvLyB0aGlzIG1pZ2h0IGJlIHRvbyBoYXJzaCwgc28gYXNrIGlmIGl0IGNhdXNlcyB0cm91YmxlXG4gIGFwcC5wYXJhbSgncGFja2FnZScsIHZhbGlkYXRlUGFja2FnZSk7XG4gIGFwcC5wYXJhbSgnZmlsZW5hbWUnLCB2YWxpZGF0ZU5hbWUpO1xuICBhcHAucGFyYW0oJ3RhZycsIHZhbGlkYXRlTmFtZSk7XG4gIGFwcC5wYXJhbSgndmVyc2lvbicsIHZhbGlkYXRlTmFtZSk7XG4gIGFwcC5wYXJhbSgncmV2aXNpb24nLCB2YWxpZGF0ZU5hbWUpO1xuICBhcHAucGFyYW0oJ3Rva2VuJywgdmFsaWRhdGVOYW1lKTtcblxuICAvLyB0aGVzZSBjYW4ndCBiZSBzYWZlbHkgcHV0IGludG8gZXhwcmVzcyB1cmwgZm9yIHNvbWUgcmVhc29uXG4gIC8vIFRPRE86IEZvciBzb21lIHJlYXNvbj8gd2hhdCByZWFzb24/XG4gIGFwcC5wYXJhbSgnX3JldicsIG1hdGNoKC9eLXJldiQvKSk7XG4gIGFwcC5wYXJhbSgnb3JnX2NvdWNoZGJfdXNlcicsIG1hdGNoKC9eb3JnXFwuY291Y2hkYlxcLnVzZXI6LykpO1xuXG4gIGFwcC51c2UoYXV0aC5hcGlKV1RtaWRkbGV3YXJlKCkpO1xuICBhcHAudXNlKGV4cHJlc3MuanNvbih7IHN0cmljdDogZmFsc2UsIGxpbWl0OiBjb25maWcubWF4X2JvZHlfc2l6ZSB8fCAnMTBtYicgfSkpO1xuICBhcHAudXNlKGFudGlMb29wKGNvbmZpZykpO1xuICAvLyBlbmNvZGUgLyBpbiBhIHNjb3BlZCBwYWNrYWdlIG5hbWUgdG8gYmUgbWF0Y2hlZCBhcyBhIHNpbmdsZSBwYXJhbWV0ZXIgaW4gcm91dGVzXG4gIGFwcC51c2UoZW5jb2RlU2NvcGVQYWNrYWdlKTtcbiAgd2hvYW1pKGFwcCk7XG4gIHByb2ZpbGUoYXBwLCBhdXRoLCBjb25maWcpO1xuICBzZWFyY2goYXBwKTtcbiAgdXNlcihhcHAsIGF1dGgsIGNvbmZpZyk7XG4gIGRpc3RUYWdzKGFwcCwgYXV0aCwgc3RvcmFnZSk7XG4gIHB1Ymxpc2goYXBwLCBhdXRoLCBzdG9yYWdlLCBjb25maWcpO1xuICBwaW5nKGFwcCk7XG4gIHN0YXJzKGFwcCwgc3RvcmFnZSk7XG4gIHYxU2VhcmNoKGFwcCwgYXV0aCwgc3RvcmFnZSk7XG4gIHRva2VuKGFwcCwgYXV0aCwgc3RvcmFnZSwgY29uZmlnKTtcbiAgcGtnKGFwcCwgYXV0aCwgc3RvcmFnZSwgY29uZmlnKTtcbiAgcmV0dXJuIGFwcDtcbn1cbiJdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQUEsSUFBQUEsUUFBQSxHQUFBQyxzQkFBQSxDQUFBQyxPQUFBO0FBTUEsSUFBQUMsU0FBQSxHQUFBRixzQkFBQSxDQUFBQyxPQUFBO0FBQ0Es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
@@ -1,3 +1,4 @@
1
+ import express from 'express';
1
2
  export declare function loadTheme(config: any): any;
2
- declare const _default: (configHash: any) => Promise<any>;
3
+ declare const _default: (configHash: any) => Promise<express.Application>;
3
4
  export default _default;