UNPKG

verdaccio

Version:

A lightweight private npm proxy registry

104 lines (102 loc) 14 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.allow_action = allow_action; exports.defaultSecurity = void 0; exports.getDefaultPlugins = getDefaultPlugins; exports.getSecurity = getSecurity; exports.handleSpecialUnpublish = handleSpecialUnpublish; exports.validatePassword = validatePassword; var _debug = _interopRequireDefault(require("debug")); var _lodash = _interopRequireDefault(require("lodash")); var _constants = require("./constants"); var _logger = require("./logger"); var _utils = require("./utils"); function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; } const debug = (0, _debug.default)('verdaccio'); function validatePassword(password, // pragma: allowlist secret minLength = _constants.DEFAULT_MIN_LIMIT_PASSWORD) { return typeof password === 'string' && password.length >= minLength; } function allow_action(action) { return function (user, pkg, callback) { debug('[auth/allow_action]: user: %o', user === null || user === void 0 ? void 0 : user.name); const { name, groups } = user; const groupAccess = pkg[action]; const hasPermission = groupAccess.some(group => name === group || groups.includes(group)); debug('[auth/allow_action]: hasPermission? %o} for user: %o', hasPermission, user === null || user === void 0 ? void 0 : user.name); if (hasPermission) { _logger.logger.info({ user: user.name }, `auth/allow_action: access granted to: @{user}`); return callback(null, true); } if (name) { callback(_utils.ErrorCode.getForbidden(`user ${name} is not allowed to ${action} package ${pkg.name}`)); } else { callback(_utils.ErrorCode.getUnauthorized(`authorization required to ${action} package ${pkg.name}`)); } }; } /** * */ function handleSpecialUnpublish() { return function (user, pkg, callback) { const action = 'unpublish'; // verify whether the unpublish prop has been defined const isUnpublishMissing = _lodash.default.isNil(pkg[action]); const hasGroups = isUnpublishMissing ? false : pkg[action].length > 0; debug('fallback unpublish for @{name} has groups: %o for %o', hasGroups, user === null || user === void 0 ? void 0 : user.name); if (isUnpublishMissing || hasGroups === false) { return callback(null, undefined); } debug('allow_action for %o for %o has groups: %o for %o', action, user === null || user === void 0 ? void 0 : user.name, hasGroups, user); return allow_action(action)(user, pkg, callback); }; } function getDefaultPlugins(logger) { return { authenticate(_user, _password, cb) { // pragma: allowlist secret cb(_utils.ErrorCode.getForbidden(_constants.API_ERROR.BAD_USERNAME_PASSWORD)); }, add_user(_user, _password, cb) { // pragma: allowlist secret return cb(_utils.ErrorCode.getConflict(_constants.API_ERROR.BAD_USERNAME_PASSWORD)); }, // FIXME: allow_action and allow_publish should be in the @verdaccio/types // @ts-ignore allow_access: allow_action('access', logger), // @ts-ignore allow_publish: allow_action('publish', logger), allow_unpublish: handleSpecialUnpublish() }; } const defaultWebTokenOptions = { sign: { // The expiration token for the website is 1 hour expiresIn: _constants.TIME_EXPIRATION_1H }, verify: {} }; const defaultApiTokenConf = { legacy: true, migrateToSecureLegacySignature: false }; const defaultSecurity = exports.defaultSecurity = { web: defaultWebTokenOptions, api: defaultApiTokenConf }; function getSecurity(config) { if (_lodash.default.isNil(config.security) === false) { return _lodash.default.merge(defaultSecurity, config.security); } return defaultSecurity; } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_debug","_interopRequireDefault","require","_lodash","_constants","_logger","_utils","e","__esModule","default","debug","buildDebug","validatePassword","password","minLength","DEFAULT_MIN_LIMIT_PASSWORD","length","allow_action","action","user","pkg","callback","name","groups","groupAccess","hasPermission","some","group","includes","logger","info","ErrorCode","getForbidden","getUnauthorized","handleSpecialUnpublish","isUnpublishMissing","_","isNil","hasGroups","undefined","getDefaultPlugins","authenticate","_user","_password","cb","API_ERROR","BAD_USERNAME_PASSWORD","add_user","getConflict","allow_access","allow_publish","allow_unpublish","defaultWebTokenOptions","sign","expiresIn","TIME_EXPIRATION_1H","verify","defaultApiTokenConf","legacy","migrateToSecureLegacySignature","defaultSecurity","exports","web","api","getSecurity","config","security","merge"],"sources":["../../src/lib/auth-utils.ts"],"sourcesContent":["import buildDebug from 'debug';\nimport _ from 'lodash';\n\nimport { pluginUtils } from '@verdaccio/core';\nimport {\n  APITokenOptions,\n  Callback,\n  Config,\n  JWTOptions,\n  Package,\n  RemoteUser,\n  Security,\n} from '@verdaccio/types';\n\nimport { API_ERROR, DEFAULT_MIN_LIMIT_PASSWORD, TIME_EXPIRATION_1H } from './constants';\nimport { logger } from './logger';\nimport { ErrorCode } from './utils';\n\nconst debug = buildDebug('verdaccio');\n\nexport function validatePassword(\n  password: string, // pragma: allowlist secret\n  minLength: number = DEFAULT_MIN_LIMIT_PASSWORD\n): boolean {\n  return typeof password === 'string' && password.length >= minLength;\n}\n\nexport function allow_action(action: string): Function {\n  return function (user: RemoteUser, pkg: Package, callback: Callback): void {\n    debug('[auth/allow_action]: user: %o', user?.name);\n    const { name, groups } = user;\n    const groupAccess = pkg[action];\n    const hasPermission = groupAccess.some((group) => name === group || groups.includes(group));\n    debug('[auth/allow_action]: hasPermission? %o} for user: %o', hasPermission, user?.name);\n\n    if (hasPermission) {\n      logger.info({ user: user.name }, `auth/allow_action: access granted to: @{user}`);\n      return callback(null, true);\n    }\n\n    if (name) {\n      callback(\n        ErrorCode.getForbidden(`user ${name} is not allowed to ${action} package ${pkg.name}`)\n      );\n    } else {\n      callback(\n        ErrorCode.getUnauthorized(`authorization required to ${action} package ${pkg.name}`)\n      );\n    }\n  };\n}\n\n/**\n *\n */\nexport function handleSpecialUnpublish(): any {\n  return function (user: RemoteUser, pkg: Package, callback: Callback): void {\n    const action = 'unpublish';\n    // verify whether the unpublish prop has been defined\n    const isUnpublishMissing: boolean = _.isNil(pkg[action]);\n    const hasGroups: boolean = isUnpublishMissing ? false : pkg[action].length > 0;\n    debug('fallback unpublish for @{name} has groups: %o for %o', hasGroups, user?.name);\n    if (isUnpublishMissing || hasGroups === false) {\n      return callback(null, undefined);\n    }\n    debug('allow_action for %o for %o has groups: %o for %o', action, user?.name, hasGroups, user);\n    return allow_action(action)(user, pkg, callback);\n  };\n}\n\nexport function getDefaultPlugins(logger: any): pluginUtils.Auth<Config> {\n  return {\n    authenticate(_user: string, _password: string, cb: Callback): void {\n      // pragma: allowlist secret\n      cb(ErrorCode.getForbidden(API_ERROR.BAD_USERNAME_PASSWORD));\n    },\n\n    add_user(_user: string, _password: string, cb: Callback): void {\n      // pragma: allowlist secret\n      return cb(ErrorCode.getConflict(API_ERROR.BAD_USERNAME_PASSWORD));\n    },\n\n    // FIXME: allow_action and allow_publish should be in the @verdaccio/types\n    // @ts-ignore\n    allow_access: allow_action('access', logger),\n    // @ts-ignore\n    allow_publish: allow_action('publish', logger),\n    allow_unpublish: handleSpecialUnpublish(),\n  };\n}\n\nconst defaultWebTokenOptions: JWTOptions = {\n  sign: {\n    // The expiration token for the website is 1 hour\n    expiresIn: TIME_EXPIRATION_1H,\n  },\n  verify: {},\n};\n\nconst defaultApiTokenConf: APITokenOptions = {\n  legacy: true,\n  migrateToSecureLegacySignature: false,\n};\n\nexport const defaultSecurity: Security = {\n  web: defaultWebTokenOptions,\n  api: defaultApiTokenConf,\n};\n\nexport function getSecurity(config: Config): Security {\n  if (_.isNil(config.security) === false) {\n    return _.merge(defaultSecurity, config.security);\n  }\n\n  return defaultSecurity;\n}\n"],"mappings":"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","ignoreList":[]}