verdaccio
Version:
A lightweight private npm proxy registry
152 lines (148 loc) • 24 kB
JavaScript
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.createServerFactory = createServerFactory;
exports.displayExperimentsInfoBox = displayExperimentsInfoBox;
exports.runServer = runServer;
var _constants = _interopRequireDefault(require("constants"));
var _debug = _interopRequireDefault(require("debug"));
var _fs = _interopRequireDefault(require("fs"));
var _http = _interopRequireDefault(require("http"));
var _https = _interopRequireDefault(require("https"));
var _lodash = _interopRequireWildcard(require("lodash"));
var _path = _interopRequireDefault(require("path"));
var _index = _interopRequireDefault(require("../api/index"));
var _utils = require("./cli/utils");
var _configPath = _interopRequireDefault(require("./config-path"));
var _constants2 = require("./constants");
var _utils2 = require("./utils");
function _getRequireWildcardCache(e) { if ("function" != typeof WeakMap) return null; var r = new WeakMap(), t = new WeakMap(); return (_getRequireWildcardCache = function (e) { return e ? t : r; })(e); }
function _interopRequireWildcard(e, r) { if (!r && e && e.__esModule) return e; if (null === e || "object" != typeof e && "function" != typeof e) return { default: e }; var t = _getRequireWildcardCache(r); if (t && t.has(e)) return t.get(e); var n = { __proto__: null }, a = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var u in e) if ("default" !== u && {}.hasOwnProperty.call(e, u)) { var i = a ? Object.getOwnPropertyDescriptor(e, u) : null; i && (i.get || i.set) ? Object.defineProperty(n, u, i) : n[u] = e[u]; } return n.default = e, t && t.set(e, n), n; }
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); }
const debug = (0, _debug.default)('verdaccio');
const logger = require('./logger');
function displayExperimentsInfoBox(flags) {
if (!flags) {
return;
}
const experimentList = Object.keys(flags);
if (experimentList.length >= 1) {
logger.warn(
// eslint-disable-next-line max-len
`experiments are enabled, it is recommended do not use experiments in production comment out this section to disable it`);
experimentList.forEach(experiment => {
// eslint-disable-next-line max-len
logger.info(`support for experiment [${experiment}] ${flags[experiment] ? 'is enabled' : ' is disabled'}`);
});
}
}
/**
* Exposes a server factory to be instantiated programmatically.
*
const app = await runServer(); // default configuration
const app = await runServer('./config/config.yaml');
const app = await runServer({ configuration });
app.listen(4000, (event) => {
// do something
});
* @param config
*/
async function runServer(config) {
let configurationParsed;
if (config === undefined || typeof config === 'string') {
const configPathLocation = (0, _configPath.default)(config);
configurationParsed = (0, _utils2.parseConfigFile)(configPathLocation);
if (!configurationParsed.self_path) {
configurationParsed.self_path = _path.default.resolve(configPathLocation);
}
} else if (_lodash.default.isObject(config)) {
configurationParsed = config;
if (!configurationParsed.self_path) {
throw new Error('self_path is required, please provide a valid root path for storage');
}
} else {
throw new Error(_constants2.API_ERROR.CONFIG_BAD_FORMAT);
}
const addresses = (0, _utils.getListListenAddresses)(undefined, configurationParsed.listen);
if (addresses.length > 1) {
process.emitWarning('You have specified multiple listen addresses, using this method only the first will be used');
}
const app = await (0, _index.default)(configurationParsed);
return createServerFactory(configurationParsed, addresses[0], app);
}
/**
* Return a native HTTP/HTTPS server instance
* @param config
* @param addr
* @param app
*/
function createServerFactory(config, addr, app) {
let serverFactory;
if (addr.proto === 'https') {
debug('https enabled');
try {
let httpsOptions = {
// disable insecure SSLv2 and SSLv3
secureOptions: _constants.default.SSL_OP_NO_SSLv2 | _constants.default.SSL_OP_NO_SSLv3
};
const keyCertConfig = config.https;
const pfxConfig = config.https;
// https must either have key and cert or a pfx and (optionally) a passphrase
if (!(keyCertConfig.key && keyCertConfig.cert || pfxConfig.pfx)) {
throw Error('bad format https configuration');
}
if (pfxConfig.pfx) {
const {
pfx,
passphrase
} = pfxConfig;
httpsOptions = (0, _lodash.assign)(httpsOptions, {
pfx: _fs.default.readFileSync(pfx),
passphrase: passphrase || ''
});
} else {
const {
key,
cert,
ca
} = keyCertConfig;
httpsOptions = (0, _lodash.assign)(httpsOptions, _objectSpread({
key: _fs.default.readFileSync(key),
cert: _fs.default.readFileSync(cert)
}, ca && {
ca: _fs.default.readFileSync(ca)
}));
}
// TODO: enable http2 as feature
// if (config.server.http2) <-- check if force http2
serverFactory = _https.default.createServer(httpsOptions, app);
} catch (err) {
throw new Error(`cannot create https server: ${err.message}`);
}
} else {
// http
debug('http enabled');
serverFactory = _http.default.createServer(app);
}
if (config.server && typeof config.server.keepAliveTimeout !== 'undefined' &&
// @ts-ignore
config.server.keepAliveTimeout !== 'null') {
// library definition for node is not up to date (doesn't contain recent 8.0 changes)
serverFactory.keepAliveTimeout = config.server.keepAliveTimeout * 1000;
}
// FIXE: I could not find the reason of this code.
unlinkAddressPath(addr);
return serverFactory;
}
function unlinkAddressPath(addr) {
if (addr.path && _fs.default.existsSync(addr.path)) {
_fs.default.unlinkSync(addr.path);
}
}
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_constants","_interopRequireDefault","require","_debug","_fs","_http","_https","_lodash","_interopRequireWildcard","_path","_index","_utils","_configPath","_constants2","_utils2","_getRequireWildcardCache","e","WeakMap","r","t","__esModule","default","has","get","n","__proto__","a","Object","defineProperty","getOwnPropertyDescriptor","u","hasOwnProperty","call","i","set","ownKeys","keys","getOwnPropertySymbols","o","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","_toPropertyKey","value","configurable","writable","_toPrimitive","Symbol","toPrimitive","TypeError","String","Number","debug","buildDebug","logger","displayExperimentsInfoBox","flags","experimentList","warn","experiment","info","runServer","config","configurationParsed","undefined","configPathLocation","findConfigFile","parseConfigFile","self_path","path","resolve","_","isObject","Error","API_ERROR","CONFIG_BAD_FORMAT","addresses","getListListenAddresses","listen","process","emitWarning","app","endPointAPI","createServerFactory","addr","serverFactory","proto","httpsOptions","secureOptions","constants","SSL_OP_NO_SSLv2","SSL_OP_NO_SSLv3","keyCertConfig","https","pfxConfig","key","cert","pfx","passphrase","assign","fs","readFileSync","ca","createServer","err","message","http","server","keepAliveTimeout","unlinkAddressPath","existsSync","unlinkSync"],"sources":["../../src/lib/run-server.ts"],"sourcesContent":["import constants from 'constants';\nimport buildDebug from 'debug';\nimport fs from 'fs';\nimport http from 'http';\nimport https from 'https';\nimport _, { assign } from 'lodash';\nimport path from 'path';\n\nimport { Config, HttpsConfKeyCert, HttpsConfPfx } from '@verdaccio/types';\n\nimport endPointAPI from '../api/index';\nimport { getListListenAddresses } from './cli/utils';\nimport findConfigFile from './config-path';\nimport { API_ERROR } from './constants';\nimport { parseConfigFile } from './utils';\n\nconst debug = buildDebug('verdaccio');\n\nconst logger = require('./logger');\n\nexport function displayExperimentsInfoBox(flags) {\n  if (!flags) {\n    return;\n  }\n\n  const experimentList = Object.keys(flags);\n  if (experimentList.length >= 1) {\n    logger.warn(\n      // eslint-disable-next-line max-len\n      `experiments are enabled, it is recommended do not use experiments in production comment out this section to disable it`\n    );\n    experimentList.forEach((experiment) => {\n      // eslint-disable-next-line max-len\n      logger.info(\n        `support for experiment [${experiment}] ${\n          flags[experiment] ? 'is enabled' : ' is disabled'\n        }`\n      );\n    });\n  }\n}\n\n/**\n * Exposes a server factory to be instantiated programmatically.\n *\n    const app = await runServer(); // default configuration\n    const app = await runServer('./config/config.yaml');\n    const app = await runServer({ configuration });\n    app.listen(4000, (event) => {\n      // do something\n    });\n * @param config\n */\nexport async function runServer(config?: string): Promise<any> {\n  let configurationParsed: ReturnType<any>;\n  if (config === undefined || typeof config === 'string') {\n    const configPathLocation = findConfigFile(config);\n    configurationParsed = parseConfigFile(configPathLocation);\n    if (!configurationParsed.self_path) {\n      configurationParsed.self_path = path.resolve(configPathLocation);\n    }\n  } else if (_.isObject(config)) {\n    configurationParsed = config;\n    if (!configurationParsed.self_path) {\n      throw new Error('self_path is required, please provide a valid root path for storage');\n    }\n  } else {\n    throw new Error(API_ERROR.CONFIG_BAD_FORMAT);\n  }\n\n  const addresses = getListListenAddresses(undefined, configurationParsed.listen);\n  if (addresses.length > 1) {\n    process.emitWarning(\n      'You have specified multiple listen addresses, using this method only the first will be used'\n    );\n  }\n\n  const app = await endPointAPI(configurationParsed);\n  return createServerFactory(configurationParsed, addresses[0], app);\n}\n\n/**\n * Return a native HTTP/HTTPS server instance\n * @param config\n * @param addr\n * @param app\n */\nexport function createServerFactory(config: Config, addr, app) {\n  let serverFactory;\n  if (addr.proto === 'https') {\n    debug('https enabled');\n    try {\n      let httpsOptions = {\n        // disable insecure SSLv2 and SSLv3\n        secureOptions: constants.SSL_OP_NO_SSLv2 | constants.SSL_OP_NO_SSLv3,\n      };\n\n      const keyCertConfig = config.https as HttpsConfKeyCert;\n      const pfxConfig = config.https as HttpsConfPfx;\n\n      // https must either have key and cert or a pfx and (optionally) a passphrase\n      if (!((keyCertConfig.key && keyCertConfig.cert) || pfxConfig.pfx)) {\n        throw Error('bad format https configuration');\n      }\n\n      if (pfxConfig.pfx) {\n        const { pfx, passphrase } = pfxConfig;\n        httpsOptions = assign(httpsOptions, {\n          pfx: fs.readFileSync(pfx),\n          passphrase: passphrase || '',\n        });\n      } else {\n        const { key, cert, ca } = keyCertConfig;\n        httpsOptions = assign(httpsOptions, {\n          key: fs.readFileSync(key),\n          cert: fs.readFileSync(cert),\n          ...(ca && {\n            ca: fs.readFileSync(ca),\n          }),\n        });\n      }\n      // TODO: enable http2 as feature\n      // if (config.server.http2) <-- check if force http2\n      serverFactory = https.createServer(httpsOptions, app);\n    } catch (err: any) {\n      throw new Error(`cannot create https server: ${err.message}`);\n    }\n  } else {\n    // http\n    debug('http enabled');\n    serverFactory = http.createServer(app);\n  }\n\n  if (\n    config.server &&\n    typeof config.server.keepAliveTimeout !== 'undefined' &&\n    // @ts-ignore\n    config.server.keepAliveTimeout !== 'null'\n  ) {\n    // library definition for node is not up to date (doesn't contain recent 8.0 changes)\n    serverFactory.keepAliveTimeout = config.server.keepAliveTimeout * 1000;\n  }\n  // FIXE: I could not find the reason of this code.\n  unlinkAddressPath(addr);\n\n  return serverFactory;\n}\n\nfunction unlinkAddressPath(addr) {\n  if (addr.path && fs.existsSync(addr.path)) {\n    fs.unlinkSync(addr.path);\n  }\n}\n"],"mappings":"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","ignoreList":[]}
;