UNPKG

verdaccio

Version:

A lightweight private npm proxy registry

172 lines (134 loc) 21.5 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _lodash = _interopRequireDefault(require("lodash")); var _utils = require("../../../lib/utils"); var _middleware = require("../../middleware"); var _constants = require("../../../lib/constants"); var _user = require("../../../utils/user"); var _logger = require("../../../lib/logger"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } 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; } 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; } 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; } const getOrder = (order = 'asc') => { return order === 'asc'; }; function addPackageWebApi(route, storage, auth, config) { const can = (0, _middleware.allow)(auth); const checkAllow = (name, remoteUser) => new Promise((resolve, reject) => { try { auth.allow_access({ packageName: name }, remoteUser, (err, allowed) => { if (err) { resolve(false); } resolve(allowed); }); } catch (err) { reject(err); } }); // Get list of all visible package route.get('/packages', function (req, res, next) { storage.getLocalDatabase(async function (err, packages) { if (err) { throw err; } async function processPackages(packages = []) { const permissions = []; const packgesCopy = packages.slice(); for (const pkg of packgesCopy) { const pkgCopy = _objectSpread({}, pkg); pkgCopy.author = (0, _utils.formatAuthor)(pkg.author); try { if (await checkAllow(pkg.name, req.remote_user)) { if (config.web) { pkgCopy.author.avatar = (0, _user.generateGravatarUrl)(pkgCopy.author.email, config.web.gravatar); } if (!_lodash.default.isNil(pkgCopy.dist) && !_lodash.default.isNull(pkgCopy.dist.tarball)) { pkgCopy.dist.tarball = (0, _utils.getLocalRegistryTarballUri)(pkgCopy.dist.tarball, pkg.name, req, config.url_prefix); } permissions.push(pkgCopy); } } catch (err) { _logger.logger.logger.error({ name: pkg.name, error: err }, 'permission process for @{name} has failed: @{error}'); throw err; } } return permissions; } const { web } = config; // @ts-ignore const order = config.web ? getOrder(web.sort_packages) : true; next((0, _utils.sortByName)(await processPackages(packages), order)); }); }); // Get package readme route.get('/package/readme/(@:scope/)?:package/:version?', can('access'), function (req, res, next) { const packageName = req.params.scope ? (0, _utils.addScope)(req.params.scope, req.params.package) : req.params.package; storage.getPackage({ name: packageName, uplinksLook: true, req, callback: function (err, info) { if (err) { return next(err); } res.set(_constants.HEADER_TYPE.CONTENT_TYPE, _constants.HEADERS.TEXT_PLAIN); next((0, _utils.parseReadme)(info.name, info.readme)); } }); }); route.get('/sidebar/(@:scope/)?:package', can('access'), function (req, res, next) { const packageName = req.params.scope ? (0, _utils.addScope)(req.params.scope, req.params.package) : req.params.package; storage.getPackage({ name: packageName, uplinksLook: true, keepUpLinkData: true, req, callback: function (err, info) { if (_lodash.default.isNil(err)) { const { v } = req.query; let sideBarInfo = _lodash.default.clone(info); sideBarInfo.versions = (0, _utils.convertDistRemoteToLocalTarballUrls)(info, req, config.url_prefix).versions; if ((0, _utils.isVersionValid)(info, v)) { // @ts-ignore sideBarInfo.latest = sideBarInfo.versions[v]; sideBarInfo.latest.author = (0, _utils.formatAuthor)(sideBarInfo.latest.author); } else { var _sideBarInfo; sideBarInfo.latest = sideBarInfo.versions[info[_constants.DIST_TAGS].latest]; if ((_sideBarInfo = sideBarInfo) !== null && _sideBarInfo !== void 0 && _sideBarInfo.latest) { sideBarInfo.latest.author = (0, _utils.formatAuthor)(sideBarInfo.latest.author); } else { res.status(_constants.HTTP_STATUS.NOT_FOUND); res.end(); return; } } sideBarInfo = (0, _utils.deleteProperties)(['readme', '_attachments', '_rev', 'name'], sideBarInfo); if (config.web) { sideBarInfo = (0, _utils.addGravatarSupport)(sideBarInfo, config.web.gravatar); } else { sideBarInfo = (0, _utils.addGravatarSupport)(sideBarInfo); } next(sideBarInfo); } else { res.status(_constants.HTTP_STATUS.NOT_FOUND); res.end(); } } }); }); } var _default = addPackageWebApi; exports.default = _default; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/api/web/endpoint/package.ts"],"names":["getOrder","order","addPackageWebApi","route","storage","auth","config","can","checkAllow","name","remoteUser","Promise","resolve","reject","allow_access","packageName","err","allowed","get","req","res","next","getLocalDatabase","packages","processPackages","permissions","packgesCopy","slice","pkg","pkgCopy","author","remote_user","web","avatar","email","gravatar","_","isNil","dist","isNull","tarball","url_prefix","push","logger","error","sort_packages","params","scope","package","getPackage","uplinksLook","callback","info","set","HEADER_TYPE","CONTENT_TYPE","HEADERS","TEXT_PLAIN","readme","keepUpLinkData","v","query","sideBarInfo","clone","versions","latest","DIST_TAGS","status","HTTP_STATUS","NOT_FOUND","end"],"mappings":"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","sourcesContent":["import _ from 'lodash';\nimport { Router } from 'express';\nimport { Config, Package } from '@verdaccio/types';\nimport {\n  addScope,\n  addGravatarSupport,\n  deleteProperties,\n  sortByName,\n  parseReadme,\n  formatAuthor,\n  convertDistRemoteToLocalTarballUrls,\n  getLocalRegistryTarballUri,\n  isVersionValid\n} from '../../../lib/utils';\nimport { allow } from '../../middleware';\nimport { DIST_TAGS, HEADER_TYPE, HEADERS, HTTP_STATUS } from '../../../lib/constants';\nimport { generateGravatarUrl } from '../../../utils/user';\nimport { logger } from '../../../lib/logger';\nimport {\n  IAuth,\n  $ResponseExtend,\n  $RequestExtend,\n  $NextFunctionVer,\n  IStorageHandler,\n  $SidebarPackage\n} from '../../../../types';\n\nconst getOrder = (order = 'asc') => {\n  return order === 'asc';\n};\n\nexport type PackcageExt = Package & { author: any; dist?: { tarball: string } };\n\nfunction addPackageWebApi(\n  route: Router,\n  storage: IStorageHandler,\n  auth: IAuth,\n  config: Config\n): void {\n  const can = allow(auth);\n\n  const checkAllow = (name, remoteUser): Promise<boolean> =>\n    new Promise((resolve, reject): void => {\n      try {\n        auth.allow_access({ packageName: name }, remoteUser, (err, allowed): void => {\n          if (err) {\n            resolve(false);\n          }\n          resolve(allowed);\n        });\n      } catch (err) {\n        reject(err);\n      }\n    });\n\n  // Get list of all visible package\n  route.get(\n    '/packages',\n    function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n      storage.getLocalDatabase(async function (err, packages): Promise<void> {\n        if (err) {\n          throw err;\n        }\n\n        async function processPackages(packages: PackcageExt[] = []): Promise<any> {\n          const permissions: PackcageExt[] = [];\n          const packgesCopy = packages.slice();\n          for (const pkg of packgesCopy) {\n            const pkgCopy = { ...pkg };\n            pkgCopy.author = formatAuthor(pkg.author);\n            try {\n              if (await checkAllow(pkg.name, req.remote_user)) {\n                if (config.web) {\n                  pkgCopy.author.avatar = generateGravatarUrl(\n                    pkgCopy.author.email,\n                    config.web.gravatar\n                  );\n                }\n                if (!_.isNil(pkgCopy.dist) && !_.isNull(pkgCopy.dist.tarball)) {\n                  pkgCopy.dist.tarball = getLocalRegistryTarballUri(\n                    pkgCopy.dist.tarball,\n                    pkg.name,\n                    req,\n                    config.url_prefix\n                  );\n                }\n                permissions.push(pkgCopy);\n              }\n            } catch (err) {\n              logger.logger.error(\n                { name: pkg.name, error: err },\n                'permission process for @{name} has failed: @{error}'\n              );\n              throw err;\n            }\n          }\n\n          return permissions;\n        }\n\n        const { web } = config;\n        // @ts-ignore\n        const order: boolean = config.web ? getOrder(web.sort_packages) : true;\n\n        next(sortByName(await processPackages(packages), order));\n      });\n    }\n  );\n\n  // Get package readme\n  route.get(\n    '/package/readme/(@:scope/)?:package/:version?',\n    can('access'),\n    function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n      const packageName = req.params.scope\n        ? addScope(req.params.scope, req.params.package)\n        : req.params.package;\n\n      storage.getPackage({\n        name: packageName,\n        uplinksLook: true,\n        req,\n        callback: function (err, info): void {\n          if (err) {\n            return next(err);\n          }\n\n          res.set(HEADER_TYPE.CONTENT_TYPE, HEADERS.TEXT_PLAIN);\n          next(parseReadme(info.name, info.readme));\n        }\n      });\n    }\n  );\n\n  route.get(\n    '/sidebar/(@:scope/)?:package',\n    can('access'),\n    function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n      const packageName: string = req.params.scope\n        ? addScope(req.params.scope, req.params.package)\n        : req.params.package;\n\n      storage.getPackage({\n        name: packageName,\n        uplinksLook: true,\n        keepUpLinkData: true,\n        req,\n        callback: function (err: Error, info: $SidebarPackage): void {\n          if (_.isNil(err)) {\n            const { v } = req.query;\n            let sideBarInfo: any = _.clone(info);\n            sideBarInfo.versions = convertDistRemoteToLocalTarballUrls(\n              info,\n              req,\n              config.url_prefix\n            ).versions;\n            if (isVersionValid(info, v)) {\n              // @ts-ignore\n              sideBarInfo.latest = sideBarInfo.versions[v];\n              sideBarInfo.latest.author = formatAuthor(sideBarInfo.latest.author);\n            } else {\n              sideBarInfo.latest = sideBarInfo.versions[info[DIST_TAGS].latest];\n              if (sideBarInfo?.latest) {\n                sideBarInfo.latest.author = formatAuthor(sideBarInfo.latest.author);\n              } else {\n                res.status(HTTP_STATUS.NOT_FOUND);\n                res.end();\n                return;\n              }\n            }\n            sideBarInfo = deleteProperties(['readme', '_attachments', '_rev', 'name'], sideBarInfo);\n            if (config.web) {\n              sideBarInfo = addGravatarSupport(sideBarInfo, config.web.gravatar);\n            } else {\n              sideBarInfo = addGravatarSupport(sideBarInfo);\n            }\n            next(sideBarInfo);\n          } else {\n            res.status(HTTP_STATUS.NOT_FOUND);\n            res.end();\n          }\n        }\n      });\n    }\n  );\n}\n\nexport default addPackageWebApi;\n"]}