UNPKG

verdaccio

Version:

A lightweight private npm proxy registry

131 lines (97 loc) 14.8 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.default = void 0; var _lodash = _interopRequireDefault(require("lodash")); var _express = _interopRequireDefault(require("express")); var _compression = _interopRequireDefault(require("compression")); var _cors = _interopRequireDefault(require("cors")); var _storage = _interopRequireDefault(require("../lib/storage")); var _pluginLoader = _interopRequireDefault(require("../lib/plugin-loader")); var _auth = _interopRequireDefault(require("../lib/auth")); var _utils = require("../lib/utils"); var _constants = require("../lib/constants"); var _config = _interopRequireDefault(require("../lib/config")); var _logger = require("../lib/logger"); var _api = _interopRequireDefault(require("./web/api")); var _web = _interopRequireDefault(require("./web")); var _endpoint = _interopRequireDefault(require("./endpoint")); var _debug = _interopRequireDefault(require("./debug")); var _middleware = require("./middleware"); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } const defineAPI = function (config, storage) { const auth = new _auth.default(config); const app = (0, _express.default)(); // run in production mode by default, just in case // it shouldn't make any difference anyway app.set('env', process.env.NODE_ENV || 'production'); app.use((0, _cors.default)()); // Router setup app.use((0, _middleware.log)(config)); app.use(_middleware.errorReportingMiddleware); app.use(function (req, res, next) { res.setHeader('X-Powered-By', config.user_agent); next(); }); app.use((0, _compression.default)()); app.get('/favicon.ico', function (req, res, next) { req.url = '/-/static/favicon.png'; next(); }); // Hook for tests only if (config._debug) { (0, _debug.default)(app, config.self_path); } // register middleware plugins const plugin_params = { config: config, logger: _logger.logger }; const plugins = (0, _pluginLoader.default)(config, config.middlewares, plugin_params, function (plugin) { return plugin.register_middlewares; }); plugins.forEach(plugin => { plugin.register_middlewares(app, auth, storage); }); // For npm request app.use((0, _endpoint.default)(config, auth, storage)); // For WebUI & WebUI API if (_lodash.default.get(config, 'web.enable', true)) { app.use('/', (0, _web.default)(config, auth, storage)); app.use('/-/verdaccio/', (0, _api.default)(config, auth, storage)); } else { app.get('/', function (req, res, next) { next(_utils.ErrorCode.getNotFound(_constants.API_ERROR.WEB_DISABLED)); }); } // Catch 404 app.get('/*', function (req, res, next) { next(_utils.ErrorCode.getNotFound(_constants.API_ERROR.FILE_NOT_FOUND)); }); app.use(function (err, req, res, next) { if (_lodash.default.isError(err)) { if (err.code === 'ECONNABORT' && res.statusCode === _constants.HTTP_STATUS.NOT_MODIFIED) { return next(); } if (_lodash.default.isFunction(res.report_error) === false) { // in case of very early error this middleware may not be loaded before error is generated // fixing that (0, _middleware.errorReportingMiddleware)(req, res, _lodash.default.noop); } res.report_error(err); } else { // Fall to Middleware.final return next(err); } }); app.use(_middleware.final); return app; }; var _default = async function _default(configHash) { (0, _logger.setup)(configHash.logs); const config = new _config.default(_lodash.default.cloneDeep(configHash)); // register middleware plugins const plugin_params = { config: config, logger: _logger.logger }; const filters = (0, _pluginLoader.default)(config, config.filters || {}, plugin_params, plugin => plugin.filter_metadata); const storage = new _storage.default(config); // waits until init calls have been initialized await storage.init(config, filters); return defineAPI(config, storage); }; exports.default = _default; //# 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","url","_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","report_error","noop","final","configHash","logs","AppConfig","cloneDeep","filters","filter_metadata","Storage","init"],"mappings":";;;;;;;AAAA;;AACA;;AACA;;AACA;;AAGA;;AACA;;AACA;;AACA;;AACA;;AACA;;AAQA;;AACA;;AACA;;AACA;;AACA;;AACA;;;;AAEA,MAAMA,SAAS,GAAG,UAAUC,MAAV,EAA2BC,OAA3B,EAA0D;AAC1E,QAAMC,IAAW,GAAG,IAAIC,aAAJ,CAASH,MAAT,CAApB;AACA,QAAMI,GAAgB,GAAG,uBAAzB,CAF0E,CAG1E;AACA;;AACAA,EAAAA,GAAG,CAACC,GAAJ,CAAQ,KAAR,EAAeC,OAAO,CAACC,GAAR,CAAYC,QAAZ,IAAwB,YAAvC;AACAJ,EAAAA,GAAG,CAACK,GAAJ,CAAQ,oBAAR,EAN0E,CAQ1E;;AACAL,EAAAA,GAAG,CAACK,GAAJ,CAAQ,qBAAIT,MAAJ,CAAR;AACAI,EAAAA,GAAG,CAACK,GAAJ,CAAQC,oCAAR;AACAN,EAAAA,GAAG,CAACK,GAAJ,CAAQ,UAAUE,GAAV,EAA+BC,GAA/B,EAAqDC,IAArD,EAAmF;AACzFD,IAAAA,GAAG,CAACE,SAAJ,CAAc,cAAd,EAA8Bd,MAAM,CAACe,UAArC;AACAF,IAAAA,IAAI;AACL,GAHD;AAKAT,EAAAA,GAAG,CAACK,GAAJ,CAAQ,2BAAR;AAEAL,EAAAA,GAAG,CAACY,GAAJ,CACE,cADF,EAEE,UAAUL,GAAV,EAA+BC,GAA/B,EAAqDC,IAArD,EAAmF;AACjFF,IAAAA,GAAG,CAACM,GAAJ,GAAU,uBAAV;AACAJ,IAAAA,IAAI;AACL,GALH,EAlB0E,CA0B1E;;AACA,MAAIb,MAAM,CAACkB,MAAX,EAAmB;AACjB,wBAAUd,GAAV,EAAeJ,MAAM,CAACmB,SAAtB;AACD,GA7ByE,CA+B1E;;;AACA,QAAMC,aAAa,GAAG;AACpBpB,IAAAA,MAAM,EAAEA,MADY;AAEpBqB,IAAAA,MAAM,EAAEA;AAFY,GAAtB;AAKA,QAAMC,OAAqC,GAAG,2BAC5CtB,MAD4C,EAE5CA,MAAM,CAACuB,WAFqC,EAG5CH,aAH4C,EAI5C,UAAUI,MAAV,EAA8C;AAC5C,WAAOA,MAAM,CAACC,oBAAd;AACD,GAN2C,CAA9C;AAQAH,EAAAA,OAAO,CAACI,OAAR,CAAiBF,MAAD,IAAwC;AACtDA,IAAAA,MAAM,CAACC,oBAAP,CAA4BrB,GAA5B,EAAiCF,IAAjC,EAAuCD,OAAvC;AACD,GAFD,EA7C0E,CAiD1E;;AACAG,EAAAA,GAAG,CAACK,GAAJ,CAAQ,uBAAYT,MAAZ,EAAoBE,IAApB,EAA0BD,OAA1B,CAAR,EAlD0E,CAoD1E;;AACA,MAAI0B,gBAAEX,GAAF,CAAMhB,MAAN,EAAc,YAAd,EAA4B,IAA5B,CAAJ,EAAuC;AACrCI,IAAAA,GAAG,CAACK,GAAJ,CAAQ,GAAR,EAAa,kBAAIT,MAAJ,EAAYE,IAAZ,EAAkBD,OAAlB,CAAb;AACAG,IAAAA,GAAG,CAACK,GAAJ,CAAQ,eAAR,EAAyB,kBAAOT,MAAP,EAAeE,IAAf,EAAqBD,OAArB,CAAzB;AACD,GAHD,MAGO;AACLG,IAAAA,GAAG,CAACY,GAAJ,CAAQ,GAAR,EAAa,UAAUL,GAAV,EAA+BC,GAA/B,EAAqDC,IAArD,EAA6E;AACxFA,MAAAA,IAAI,CAACe,iBAAUC,WAAV,CAAsBC,qBAAUC,YAAhC,CAAD,CAAJ;AACD,KAFD;AAGD,GA5DyE,CA8D1E;;;AACA3B,EAAAA,GAAG,CAACY,GAAJ,CAAQ,IAAR,EAAc,UAAUL,GAAV,EAA+BC,GAA/B,EAAqDC,IAArD,EAA6E;AACzFA,IAAAA,IAAI,CAACe,iBAAUC,WAAV,CAAsBC,qBAAUE,cAAhC,CAAD,CAAJ;AACD,GAFD;AAIA5B,EAAAA,GAAG,CAACK,GAAJ,CAAQ,UACNwB,GADM,EAENtB,GAFM,EAGNC,GAHM,EAINC,IAJM,EAKN;AACA,QAAIc,gBAAEO,OAAF,CAAUD,GAAV,CAAJ,EAAoB;AAClB,UAAIA,GAAG,CAACE,IAAJ,KAAa,YAAb,IAA6BvB,GAAG,CAACwB,UAAJ,KAAmBC,uBAAYC,YAAhE,EAA8E;AAC5E,eAAOzB,IAAI,EAAX;AACD;;AACD,UAAIc,gBAAEY,UAAF,CAAa3B,GAAG,CAAC4B,YAAjB,MAAmC,KAAvC,EAA8C;AAC5C;AACA;AACA,kDAAyB7B,GAAzB,EAA8BC,GAA9B,EAAmCe,gBAAEc,IAArC;AACD;;AACD7B,MAAAA,GAAG,CAAC4B,YAAJ,CAAiBP,GAAjB;AACD,KAVD,MAUO;AACL;AACA,aAAOpB,IAAI,CAACoB,GAAD,CAAX;AACD;AACF,GApBD;AAsBA7B,EAAAA,GAAG,CAACK,GAAJ,CAAQiC,iBAAR;AAEA,SAAOtC,GAAP;AACD,CA5FD;;eA8FgB,wBAAgBuC,UAAhB,EAA+C;AAC7D,qBAAMA,UAAU,CAACC,IAAjB;AACA,QAAM5C,MAAe,GAAG,IAAI6C,eAAJ,CAAclB,gBAAEmB,SAAF,CAAYH,UAAZ,CAAd,CAAxB,CAF6D,CAG7D;;AACA,QAAMvB,aAAa,GAAG;AACpBpB,IAAAA,MAAM,EAAEA,MADY;AAEpBqB,IAAAA,MAAM,EAAEA;AAFY,GAAtB;AAIA,QAAM0B,OAAO,GAAG,2BACd/C,MADc,EAEdA,MAAM,CAAC+C,OAAP,IAAkB,EAFJ,EAGd3B,aAHc,EAIbI,MAAD,IAA2CA,MAAM,CAACwB,eAJpC,CAAhB;AAMA,QAAM/C,OAAwB,GAAG,IAAIgD,gBAAJ,CAAYjD,MAAZ,CAAjC,CAd6D,CAe7D;;AACA,QAAMC,OAAO,CAACiD,IAAR,CAAalD,MAAb,EAAqB+C,OAArB,CAAN;AACA,SAAOhD,SAAS,CAACC,MAAD,EAASC,OAAT,CAAhB;AACD,C","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 {\n  $ResponseExtend,\n  $RequestExtend,\n  $NextFunctionVer,\n  IStorageHandler,\n  IAuth\n} 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 } from './middleware';\n\nconst defineAPI = function (config: IConfig, storage: IStorageHandler): any {\n  const auth: IAuth = new Auth(config);\n  const app: Application = express();\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(\n    '/favicon.ico',\n    function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n      req.url = '/-/static/favicon.png';\n      next();\n    }\n  );\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(\n    config,\n    config.middlewares,\n    plugin_params,\n    function (plugin: IPluginMiddleware<IConfig>) {\n      return plugin.register_middlewares;\n    }\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 (\n    err: HttpError,\n    req: $RequestExtend,\n    res: $ResponseExtend,\n    next: $NextFunctionVer\n  ) {\n    if (_.isError(err)) {\n      if (err.code === 'ECONNABORT' && res.statusCode === HTTP_STATUS.NOT_MODIFIED) {\n        return next();\n      }\n      if (_.isFunction(res.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.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(\n    config,\n    config.filters || {},\n    plugin_params,\n    (plugin: IPluginStorageFilter<IConfig>) => plugin.filter_metadata\n  );\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"]}