verdaccio 5.1.2 → 5.1.6

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.
package/CHANGELOG.md CHANGED
@@ -2,6 +2,36 @@
2
2
 
3
3
  All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
4
4
 
5
+ ### [5.1.6](https://github.com/verdaccio/verdaccio/compare/v5.1.5...v5.1.6) (2021-09-21)
6
+
7
+
8
+ ### Bug Fixes
9
+
10
+ * update dependencies security update ([#2453](https://github.com/verdaccio/verdaccio/issues/2453)) ([9d7ddd9](https://github.com/verdaccio/verdaccio/commit/9d7ddd9ecd4b69a0d0cb63eb72489ec7118c9d4f))
11
+
12
+ ### [5.1.5](https://github.com/verdaccio/verdaccio/compare/v5.1.4...v5.1.5) (2021-09-17)
13
+
14
+
15
+ ### Bug Fixes
16
+
17
+ * add finish language to ui ([#2443](https://github.com/verdaccio/verdaccio/issues/2443)) ([360bec9](https://github.com/verdaccio/verdaccio/commit/360bec9b5315c0bc1c93ca36e1a1d8f808f0746c))
18
+
19
+ ### [5.1.4](https://github.com/verdaccio/verdaccio/compare/v5.1.3...v5.1.4) (2021-09-07)
20
+
21
+
22
+ ### Bug Fixes
23
+
24
+ * npm7 audit fix and bulk endpoint ([#2426](https://github.com/verdaccio/verdaccio/issues/2426)) ([2c59091](https://github.com/verdaccio/verdaccio/commit/2c590917b10672da102b2352f6ff9c78f073763a))
25
+
26
+ ### [5.1.3](https://github.com/verdaccio/verdaccio/compare/v5.1.2...v5.1.3) (2021-08-20)
27
+
28
+
29
+ ### Bug Fixes
30
+
31
+ * plugin allow_publish (pkg) got a undefined version ([#2315](https://github.com/verdaccio/verdaccio/issues/2315)) ([ecfc4c3](https://github.com/verdaccio/verdaccio/commit/ecfc4c33048a6f2cb1cef179fe9b0a11da389d26))
32
+ * update docker and core dependencies ([#2375](https://github.com/verdaccio/verdaccio/issues/2375)) ([2e995f5](https://github.com/verdaccio/verdaccio/commit/2e995f5981c1a5eca6f43b14e52f06564acf6d8e))
33
+ * update docker base image to v14.17.5 ([d63dcc0](https://github.com/verdaccio/verdaccio/commit/d63dcc02facddd8b6da2a32da067a6acf239e25d))
34
+
5
35
  ### [5.1.2](https://github.com/verdaccio/verdaccio/compare/v5.1.1...v5.1.2) (2021-07-14)
6
36
 
7
37
 
package/README.md CHANGED
@@ -69,10 +69,14 @@ booted in a couple of seconds, fast enough for any CI. Many open source projects
69
69
 
70
70
  ## Talks
71
71
 
72
- [![verdaccio Node.js Dependency Confusion Attacks](https://cdn.verdaccio.dev/readme/devseccon.png)](https://www.youtube.com/watch?v=qTRADSp3Hpo)
72
+ ### **Testing the integrity of your React components by publishing in a private registry - React Finland 2021**.
73
+
74
+ [![beerjscrb](https://cdn.verdaccio.dev/readme/react-finland-2021-jpicado.jpeg)](https://react-finland.fi/schedule/#testing-the-integrity-of-your-react-components-by-publishing-in-a-private-registry)
73
75
 
74
76
  You might want to check out as well our previous talks:
75
77
 
78
+ - [BeerJS Cba Meetup No. 53 May 2021 - **Juan Picado**](https://www.youtube.com/watch?v=6SyjqBmS49Y&ab_channel=BeerJSCba)
79
+ - [Node.js Dependency Confusion Attacks - April 2021 - **Juan Picado\***](https://www.youtube.com/watch?v=qTRADSp3Hpo)
76
80
  - [**OpenJS World 2020** about \*Cover your Projects with a Multi purpose Lightweight Node.js Registry - **Juan Picado\***](https://www.youtube.com/watch?v=oVCjDWeehAQ)
77
81
  - [ViennaJS Meetup - Introduction to Verdaccio by **Priscila Olivera** and **Juan Picado**](https://www.youtube.com/watch?v=hDIFKzmoCa)
78
82
  - [Open Source? trivago - Verdaccio (**Ayush** and **Juan Picado**) January 2020](https://www.youtube.com/watch?v=A5CWxJC9xzc)
@@ -193,7 +193,14 @@ function allow(auth) {
193
193
  return function (req, res, next) {
194
194
  req.pause();
195
195
  const packageName = req.params.scope ? `@${req.params.scope}/${req.params.package}` : req.params.package;
196
- const packageVersion = req.params.filename ? (0, _utils.getVersionFromTarball)(req.params.filename) : undefined;
196
+ let packageVersion = undefined;
197
+
198
+ if (req.params.filename) {
199
+ packageVersion = (0, _utils.getVersionFromTarball)(req.params.filename) || undefined;
200
+ } else if (typeof req.body.versions === 'object') {
201
+ packageVersion = Object.keys(req.body.versions)[0];
202
+ }
203
+
197
204
  const remote = req.remote_user;
198
205
  debug('[middleware/allow][%o] allow for %o', action, remote === null || remote === void 0 ? void 0 : remote.name);
199
206
  auth['allow_' + action]({
@@ -417,4 +424,4 @@ function errorReportingMiddleware(req, res, next) {
417
424
 
418
425
  next();
419
426
  }
420
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/api/middleware.ts"],"names":["debug","match","regexp","req","res","next","value","exec","serveFavicon","config","logoConf","web","favicon","status","_","isEmpty","validator","isURL","require_host","require_valid_protocol","redirect","faviconPath","path","normalize","fs","access","constants","R_OK","err","message","HTTP_STATUS","NOT_FOUND","end","setHeader","createReadStream","pipe","posix","join","__dirname","setSecurityWebHeaders","header","HEADERS","FRAMES_OPTIONS","CSP","CTO","XSS","validateName","name","ErrorCode","getForbidden","validatePackage","media","expect","headers","HEADER_TYPE","CONTENT_TYPE","getCode","UNSUPPORTED_MEDIA","get","encodeScopePackage","url","indexOf","replace","expectJson","body","getBadRequest","antiLoop","via","arr","split","i","length","m","server_id","LOOP_DETECTED","allow","auth","action","pause","packageName","params","scope","package","packageVersion","filename","undefined","remote","remote_user","error","allowed","resume","getInternalError","API_ERROR","PLUGIN_ERROR","final","statusCode","UNAUTHORIZED","getHeader","WWW_AUTH","TOKEN_BASIC","TOKEN_BEARER","isString","isObject","JSON","isNil","locals","_verdaccio_error","stringify","OK","MULTIPLE_CHOICES","ETAG","socket","destroy","send","LOG_STATUS_MESSAGE","LOG_VERDACCIO_ERROR","LOG_VERDACCIO_BYTES","log","_auth","authorization","_cookie","cookie","originalUrl","logger","http","ip","bytesin","experiments","bytesin_off","on","chunk","bytesout","_write","write","buf","apply","arguments","logHasBeenCalled","forwardedFor","remoteAddress","connection","remoteIP","request","method","user","bytes","in","out","_end","errorReportingMiddleware","report_error","BAD_REQUEST","headersSent","UNKNOWN_ERROR","INTERNAL_ERROR","INTERNAL_SERVER_ERROR"],"mappings":"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","sourcesContent":["import fs from 'fs';\nimport path from 'path';\nimport _ from 'lodash';\nimport buildDebug from 'debug';\nimport validator from 'validator';\n\nimport { Config, Package, RemoteUser } from '@verdaccio/types';\nimport { VerdaccioError } from '@verdaccio/commons-api';\nimport { validateName as utilValidateName, validatePackage as utilValidatePackage, getVersionFromTarball, isObject, ErrorCode } from '../lib/utils';\nimport { API_ERROR, HEADER_TYPE, HEADERS, HTTP_STATUS, TOKEN_BASIC, TOKEN_BEARER } from '../lib/constants';\nimport { stringToMD5 } from '../lib/crypto-utils';\nimport { $ResponseExtend, $RequestExtend, $NextFunctionVer, IAuth } from '../../types';\nimport { logger } from '../lib/logger';\n\nconst debug = buildDebug('verdaccio');\n\nexport function match(regexp: RegExp): any {\n  return function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer, value: string): void {\n    if (regexp.exec(value)) {\n      next();\n    } else {\n      next('route');\n    }\n  };\n}\n\nexport function serveFavicon(config: Config) {\n  return function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) {\n    try {\n      // @ts-ignore\n      const logoConf: string = config?.web?.favicon as string;\n      if (logoConf === '') {\n        debug('favicon disabled');\n        res.status(404);\n      } else if (!_.isEmpty(logoConf)) {\n        debug('custom favicon');\n        if (\n          validator.isURL(logoConf, {\n            require_host: true,\n            require_valid_protocol: true,\n          })\n        ) {\n          debug('redirect to %o', logoConf);\n          res.redirect(logoConf);\n          return;\n        } else {\n          const faviconPath = path.normalize(logoConf);\n          debug('serving favicon from %o', faviconPath);\n          fs.access(faviconPath, fs.constants.R_OK, (err) => {\n            if (err) {\n              debug('no read permissions to read: %o, reason:', logoConf, err?.message);\n              return res.status(HTTP_STATUS.NOT_FOUND).end();\n            } else {\n              res.setHeader('content-type', 'image/x-icon');\n              fs.createReadStream(faviconPath).pipe(res);\n              debug('rendered custom ico');\n            }\n          });\n        }\n      } else {\n        res.setHeader('content-type', 'image/x-icon');\n        fs.createReadStream(path.posix.join(__dirname, './web/html/favicon.ico')).pipe(res);\n        debug('rendered ico');\n      }\n    } catch (err) {\n      debug('error triggered, favicon not found');\n      res.status(HTTP_STATUS.NOT_FOUND).end();\n    }\n  };\n}\n\nexport function setSecurityWebHeaders(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n  // disable loading in frames (clickjacking, etc.)\n  res.header(HEADERS.FRAMES_OPTIONS, 'deny');\n  // avoid stablish connections outside of domain\n  res.header(HEADERS.CSP, \"connect-src 'self'\");\n  // https://stackoverflow.com/questions/18337630/what-is-x-content-type-options-nosniff\n  res.header(HEADERS.CTO, 'nosniff');\n  // https://stackoverflow.com/questions/9090577/what-is-the-http-header-x-xss-protection\n  res.header(HEADERS.XSS, '1; mode=block');\n  next();\n}\n\n// flow: express does not match properly\n// flow info https://github.com/flowtype/flow-typed/issues?utf8=%E2%9C%93&q=is%3Aissue+is%3Aopen+express\nexport function validateName(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer, value: string, name: string): void {\n  if (value === '-') {\n    // special case in couchdb usually\n    next('route');\n  } else if (utilValidateName(value)) {\n    next();\n  } else {\n    next(ErrorCode.getForbidden('invalid ' + name));\n  }\n}\n\n// flow: express does not match properly\n// flow info https://github.com/flowtype/flow-typed/issues?utf8=%E2%9C%93&q=is%3Aissue+is%3Aopen+express\nexport function validatePackage(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer, value: string, name: string): void {\n  if (value === '-') {\n    // special case in couchdb usually\n    next('route');\n  } else if (utilValidatePackage(value)) {\n    next();\n  } else {\n    next(ErrorCode.getForbidden('invalid ' + name));\n  }\n}\n\nexport function media(expect: string | null): any {\n  return function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n    if (req.headers[HEADER_TYPE.CONTENT_TYPE] !== expect) {\n      next(ErrorCode.getCode(HTTP_STATUS.UNSUPPORTED_MEDIA, 'wrong content-type, expect: ' + expect + ', got: ' + req.get(HEADER_TYPE.CONTENT_TYPE)));\n    } else {\n      next();\n    }\n  };\n}\n\nexport function encodeScopePackage(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n  if (req.url.indexOf('@') !== -1) {\n    // e.g.: /@org/pkg/1.2.3 -> /@org%2Fpkg/1.2.3, /@org%2Fpkg/1.2.3 -> /@org%2Fpkg/1.2.3\n    req.url = req.url.replace(/^(\\/@[^\\/%]+)\\/(?!$)/, '$1%2F');\n  }\n  next();\n}\n\nexport function expectJson(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n  if (!isObject(req.body)) {\n    return next(ErrorCode.getBadRequest(\"can't parse incoming json\"));\n  }\n  next();\n}\n\nexport function antiLoop(config: Config): Function {\n  return function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n    if (req?.headers?.via != null) {\n      const arr = req.headers.via.split(',');\n\n      for (let i = 0; i < arr.length; i++) {\n        const m = arr[i].match(/\\s*(\\S+)\\s+(\\S+)/);\n        if (m && m[2] === config.server_id) {\n          return next(ErrorCode.getCode(HTTP_STATUS.LOOP_DETECTED, 'loop detected'));\n        }\n      }\n    }\n    next();\n  };\n}\n\nexport function allow(auth: IAuth): Function {\n  return function (action: string): Function {\n    return function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n      req.pause();\n      const packageName = req.params.scope ? `@${req.params.scope}/${req.params.package}` : req.params.package;\n      const packageVersion = req.params.filename ? getVersionFromTarball(req.params.filename) : undefined;\n      const remote: RemoteUser = req.remote_user;\n      debug('[middleware/allow][%o] allow for %o', action, remote?.name);\n      auth['allow_' + action]({ packageName, packageVersion }, remote, function (error, allowed): void {\n        req.resume();\n        if (error) {\n          next(error);\n        } else if (allowed) {\n          next();\n        } else {\n          // last plugin (that's our built-in one) returns either\n          // cb(err) or cb(null, true), so this should never happen\n          throw ErrorCode.getInternalError(API_ERROR.PLUGIN_ERROR);\n        }\n      });\n    };\n  };\n}\n\nexport interface MiddlewareError {\n  error: string;\n}\n\nexport type FinalBody = Package | MiddlewareError | string;\n\nexport function final(body: FinalBody, req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n  if (res.statusCode === HTTP_STATUS.UNAUTHORIZED && !res.getHeader(HEADERS.WWW_AUTH)) {\n    // they say it's required for 401, so...\n    res.header(HEADERS.WWW_AUTH, `${TOKEN_BASIC}, ${TOKEN_BEARER}`);\n  }\n\n  try {\n    if (_.isString(body) || _.isObject(body)) {\n      if (!res.getHeader(HEADERS.CONTENT_TYPE)) {\n        res.header(HEADERS.CONTENT_TYPE, HEADERS.JSON);\n      }\n\n      if (typeof body === 'object' && _.isNil(body) === false) {\n        if (typeof (body as MiddlewareError).error === 'string') {\n          res.locals._verdaccio_error = (body as MiddlewareError).error;\n        }\n        body = JSON.stringify(body, undefined, '  ') + '\\n';\n      }\n\n      // don't send etags with errors\n      if (!res.statusCode || (res.statusCode >= HTTP_STATUS.OK && res.statusCode < HTTP_STATUS.MULTIPLE_CHOICES)) {\n        res.header(HEADERS.ETAG, '\"' + stringToMD5(body as string) + '\"');\n      }\n    } else {\n      // send(null), send(204), etc.\n    }\n  } catch (err) {\n    // if verdaccio sends headers first, and then calls res.send()\n    // as an error handler, we can't report error properly,\n    // and should just close socket\n    if (err.message.match(/set headers after they are sent/)) {\n      if (_.isNil(res.socket) === false) {\n        // @ts-ignore\n        res.socket.destroy();\n      }\n      return;\n    }\n    throw err;\n  }\n\n  res.send(body);\n}\n\nexport const LOG_STATUS_MESSAGE = \"@{status}, user: @{user}(@{remoteIP}), req: '@{request.method} @{request.url}'\";\nexport const LOG_VERDACCIO_ERROR = `${LOG_STATUS_MESSAGE}, error: @{!error}`;\nexport const LOG_VERDACCIO_BYTES = `${LOG_STATUS_MESSAGE}, bytes: @{bytes.in}/@{bytes.out}`;\n\nexport function log(config: Config) {\n  return function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n    const _auth = req.headers.authorization;\n    if (_.isNil(_auth) === false) {\n      req.headers.authorization = '<Classified>';\n    }\n\n    const _cookie = req.get('cookie');\n    if (_.isNil(_cookie) === false) {\n      req.headers.cookie = '<Classified>';\n    }\n\n    req.url = req.originalUrl;\n    // avoid log noise data from static content\n    if (req.originalUrl.match(/static/) === null) {\n      logger.http({ req: req, ip: req.ip }, \"@{ip} requested '@{req.method} @{req.url}'\");\n    }\n    req.originalUrl = req.url;\n\n    if (_.isNil(_auth) === false) {\n      req.headers.authorization = _auth;\n    }\n\n    if (_.isNil(_cookie) === false) {\n      req.headers.cookie = _cookie;\n    }\n\n    let bytesin = 0;\n    if (config?.experiments?.bytesin_off !== true) {\n      req.on('data', function (chunk): void {\n        bytesin += chunk.length;\n      });\n    }\n\n    let bytesout = 0;\n    const _write = res.write;\n    // FIXME: res.write should return boolean\n    // @ts-ignore\n    res.write = function (buf): boolean {\n      bytesout += buf.length;\n      /* eslint prefer-rest-params: \"off\" */\n      // @ts-ignore\n      _write.apply(res, arguments);\n    };\n\n    let logHasBeenCalled = false;\n    const log = function (): void {\n      if (logHasBeenCalled) {\n        return;\n      }\n      logHasBeenCalled = true;\n\n      const forwardedFor = req.get('x-forwarded-for');\n      const remoteAddress = req.connection.remoteAddress;\n      const remoteIP = forwardedFor ? `${forwardedFor} via ${remoteAddress}` : remoteAddress;\n      let message;\n      if (res.locals._verdaccio_error) {\n        message = LOG_VERDACCIO_ERROR;\n      } else {\n        message = LOG_VERDACCIO_BYTES;\n      }\n\n      req.url = req.originalUrl;\n      // avoid log noise data from static content\n      if (req.url.match(/static/) === null) {\n        logger.http(\n          {\n            request: {\n              method: req.method,\n              url: req.url,\n            },\n            user: (req.remote_user && req.remote_user.name) || null,\n            remoteIP,\n            status: res.statusCode,\n            error: res.locals._verdaccio_error,\n            bytes: {\n              in: bytesin,\n              out: bytesout,\n            },\n          },\n          message\n        );\n        req.originalUrl = req.url;\n      }\n    };\n\n    req.on('close', function (): void {\n      log();\n    });\n\n    const _end = res.end;\n    res.end = function (buf): void {\n      if (buf) {\n        bytesout += buf.length;\n      }\n      /* eslint prefer-rest-params: \"off\" */\n      // @ts-ignore\n      _end.apply(res, arguments);\n      log();\n    };\n    next();\n  };\n}\n\n// Middleware\nexport function errorReportingMiddleware(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n  res.locals.report_error =\n    res.locals.report_error ||\n    function (err: VerdaccioError): void {\n      if (err.status && err.status >= HTTP_STATUS.BAD_REQUEST && err.status < 600) {\n        if (!res.headersSent) {\n          res.status(err.status);\n          next({ error: err.message || API_ERROR.UNKNOWN_ERROR });\n        }\n      } else {\n        logger.error({ err: err }, 'unexpected error: @{!err.message}\\n@{err.stack}');\n        if (!res.status || !res.send) {\n          logger.error('this is an error in express.js, please report this');\n          res.destroy();\n        } else if (!res.headersSent) {\n          res.status(HTTP_STATUS.INTERNAL_ERROR);\n          next({ error: API_ERROR.INTERNAL_SERVER_ERROR });\n        } else {\n          // socket should be already closed\n        }\n      }\n    };\n\n  next();\n}\n"]}
427
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/api/middleware.ts"],"names":["debug","match","regexp","req","res","next","value","exec","serveFavicon","config","logoConf","web","favicon","status","_","isEmpty","validator","isURL","require_host","require_valid_protocol","redirect","faviconPath","path","normalize","fs","access","constants","R_OK","err","message","HTTP_STATUS","NOT_FOUND","end","setHeader","createReadStream","pipe","posix","join","__dirname","setSecurityWebHeaders","header","HEADERS","FRAMES_OPTIONS","CSP","CTO","XSS","validateName","name","ErrorCode","getForbidden","validatePackage","media","expect","headers","HEADER_TYPE","CONTENT_TYPE","getCode","UNSUPPORTED_MEDIA","get","encodeScopePackage","url","indexOf","replace","expectJson","body","getBadRequest","antiLoop","via","arr","split","i","length","m","server_id","LOOP_DETECTED","allow","auth","action","pause","packageName","params","scope","package","packageVersion","undefined","filename","versions","Object","keys","remote","remote_user","error","allowed","resume","getInternalError","API_ERROR","PLUGIN_ERROR","final","statusCode","UNAUTHORIZED","getHeader","WWW_AUTH","TOKEN_BASIC","TOKEN_BEARER","isString","isObject","JSON","isNil","locals","_verdaccio_error","stringify","OK","MULTIPLE_CHOICES","ETAG","socket","destroy","send","LOG_STATUS_MESSAGE","LOG_VERDACCIO_ERROR","LOG_VERDACCIO_BYTES","log","_auth","authorization","_cookie","cookie","originalUrl","logger","http","ip","bytesin","experiments","bytesin_off","on","chunk","bytesout","_write","write","buf","apply","arguments","logHasBeenCalled","forwardedFor","remoteAddress","connection","remoteIP","request","method","user","bytes","in","out","_end","errorReportingMiddleware","report_error","BAD_REQUEST","headersSent","UNKNOWN_ERROR","INTERNAL_ERROR","INTERNAL_SERVER_ERROR"],"mappings":"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","sourcesContent":["import fs from 'fs';\nimport path from 'path';\nimport _ from 'lodash';\nimport buildDebug from 'debug';\nimport validator from 'validator';\n\nimport { Config, Package, RemoteUser } from '@verdaccio/types';\nimport { VerdaccioError } from '@verdaccio/commons-api';\nimport { validateName as utilValidateName, validatePackage as utilValidatePackage, getVersionFromTarball, isObject, ErrorCode } from '../lib/utils';\nimport { API_ERROR, HEADER_TYPE, HEADERS, HTTP_STATUS, TOKEN_BASIC, TOKEN_BEARER } from '../lib/constants';\nimport { stringToMD5 } from '../lib/crypto-utils';\nimport { $ResponseExtend, $RequestExtend, $NextFunctionVer, IAuth } from '../../types';\nimport { logger } from '../lib/logger';\n\nconst debug = buildDebug('verdaccio');\n\nexport function match(regexp: RegExp): any {\n  return function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer, value: string): void {\n    if (regexp.exec(value)) {\n      next();\n    } else {\n      next('route');\n    }\n  };\n}\n\nexport function serveFavicon(config: Config) {\n  return function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer) {\n    try {\n      // @ts-ignore\n      const logoConf: string = config?.web?.favicon as string;\n      if (logoConf === '') {\n        debug('favicon disabled');\n        res.status(404);\n      } else if (!_.isEmpty(logoConf)) {\n        debug('custom favicon');\n        if (\n          validator.isURL(logoConf, {\n            require_host: true,\n            require_valid_protocol: true,\n          })\n        ) {\n          debug('redirect to %o', logoConf);\n          res.redirect(logoConf);\n          return;\n        } else {\n          const faviconPath = path.normalize(logoConf);\n          debug('serving favicon from %o', faviconPath);\n          fs.access(faviconPath, fs.constants.R_OK, (err) => {\n            if (err) {\n              debug('no read permissions to read: %o, reason:', logoConf, err?.message);\n              return res.status(HTTP_STATUS.NOT_FOUND).end();\n            } else {\n              res.setHeader('content-type', 'image/x-icon');\n              fs.createReadStream(faviconPath).pipe(res);\n              debug('rendered custom ico');\n            }\n          });\n        }\n      } else {\n        res.setHeader('content-type', 'image/x-icon');\n        fs.createReadStream(path.posix.join(__dirname, './web/html/favicon.ico')).pipe(res);\n        debug('rendered ico');\n      }\n    } catch (err) {\n      debug('error triggered, favicon not found');\n      res.status(HTTP_STATUS.NOT_FOUND).end();\n    }\n  };\n}\n\nexport function setSecurityWebHeaders(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n  // disable loading in frames (clickjacking, etc.)\n  res.header(HEADERS.FRAMES_OPTIONS, 'deny');\n  // avoid stablish connections outside of domain\n  res.header(HEADERS.CSP, \"connect-src 'self'\");\n  // https://stackoverflow.com/questions/18337630/what-is-x-content-type-options-nosniff\n  res.header(HEADERS.CTO, 'nosniff');\n  // https://stackoverflow.com/questions/9090577/what-is-the-http-header-x-xss-protection\n  res.header(HEADERS.XSS, '1; mode=block');\n  next();\n}\n\n// flow: express does not match properly\n// flow info https://github.com/flowtype/flow-typed/issues?utf8=%E2%9C%93&q=is%3Aissue+is%3Aopen+express\nexport function validateName(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer, value: string, name: string): void {\n  if (value === '-') {\n    // special case in couchdb usually\n    next('route');\n  } else if (utilValidateName(value)) {\n    next();\n  } else {\n    next(ErrorCode.getForbidden('invalid ' + name));\n  }\n}\n\n// flow: express does not match properly\n// flow info https://github.com/flowtype/flow-typed/issues?utf8=%E2%9C%93&q=is%3Aissue+is%3Aopen+express\nexport function validatePackage(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer, value: string, name: string): void {\n  if (value === '-') {\n    // special case in couchdb usually\n    next('route');\n  } else if (utilValidatePackage(value)) {\n    next();\n  } else {\n    next(ErrorCode.getForbidden('invalid ' + name));\n  }\n}\n\nexport function media(expect: string | null): any {\n  return function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n    if (req.headers[HEADER_TYPE.CONTENT_TYPE] !== expect) {\n      next(ErrorCode.getCode(HTTP_STATUS.UNSUPPORTED_MEDIA, 'wrong content-type, expect: ' + expect + ', got: ' + req.get(HEADER_TYPE.CONTENT_TYPE)));\n    } else {\n      next();\n    }\n  };\n}\n\nexport function encodeScopePackage(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n  if (req.url.indexOf('@') !== -1) {\n    // e.g.: /@org/pkg/1.2.3 -> /@org%2Fpkg/1.2.3, /@org%2Fpkg/1.2.3 -> /@org%2Fpkg/1.2.3\n    req.url = req.url.replace(/^(\\/@[^\\/%]+)\\/(?!$)/, '$1%2F');\n  }\n  next();\n}\n\nexport function expectJson(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n  if (!isObject(req.body)) {\n    return next(ErrorCode.getBadRequest(\"can't parse incoming json\"));\n  }\n  next();\n}\n\nexport function antiLoop(config: Config): Function {\n  return function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n    if (req?.headers?.via != null) {\n      const arr = req.headers.via.split(',');\n\n      for (let i = 0; i < arr.length; i++) {\n        const m = arr[i].match(/\\s*(\\S+)\\s+(\\S+)/);\n        if (m && m[2] === config.server_id) {\n          return next(ErrorCode.getCode(HTTP_STATUS.LOOP_DETECTED, 'loop detected'));\n        }\n      }\n    }\n    next();\n  };\n}\n\nexport function allow(auth: IAuth): Function {\n  return function (action: string): Function {\n    return function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n      req.pause();\n      const packageName = req.params.scope ? `@${req.params.scope}/${req.params.package}` : req.params.package;\n      let packageVersion: string | undefined = undefined;\n      if (req.params.filename) {\n        packageVersion = getVersionFromTarball(req.params.filename) || undefined;\n      } else if (typeof req.body.versions === 'object') {\n        packageVersion = Object.keys(req.body.versions)[0];\n      }\n      const remote: RemoteUser = req.remote_user;\n      debug('[middleware/allow][%o] allow for %o', action, remote?.name);\n      auth['allow_' + action]({ packageName, packageVersion }, remote, function (error, allowed): void {\n        req.resume();\n        if (error) {\n          next(error);\n        } else if (allowed) {\n          next();\n        } else {\n          // last plugin (that's our built-in one) returns either\n          // cb(err) or cb(null, true), so this should never happen\n          throw ErrorCode.getInternalError(API_ERROR.PLUGIN_ERROR);\n        }\n      });\n    };\n  };\n}\n\nexport interface MiddlewareError {\n  error: string;\n}\n\nexport type FinalBody = Package | MiddlewareError | string;\n\nexport function final(body: FinalBody, req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n  if (res.statusCode === HTTP_STATUS.UNAUTHORIZED && !res.getHeader(HEADERS.WWW_AUTH)) {\n    // they say it's required for 401, so...\n    res.header(HEADERS.WWW_AUTH, `${TOKEN_BASIC}, ${TOKEN_BEARER}`);\n  }\n\n  try {\n    if (_.isString(body) || _.isObject(body)) {\n      if (!res.getHeader(HEADERS.CONTENT_TYPE)) {\n        res.header(HEADERS.CONTENT_TYPE, HEADERS.JSON);\n      }\n\n      if (typeof body === 'object' && _.isNil(body) === false) {\n        if (typeof (body as MiddlewareError).error === 'string') {\n          res.locals._verdaccio_error = (body as MiddlewareError).error;\n        }\n        body = JSON.stringify(body, undefined, '  ') + '\\n';\n      }\n\n      // don't send etags with errors\n      if (!res.statusCode || (res.statusCode >= HTTP_STATUS.OK && res.statusCode < HTTP_STATUS.MULTIPLE_CHOICES)) {\n        res.header(HEADERS.ETAG, '\"' + stringToMD5(body as string) + '\"');\n      }\n    } else {\n      // send(null), send(204), etc.\n    }\n  } catch (err) {\n    // if verdaccio sends headers first, and then calls res.send()\n    // as an error handler, we can't report error properly,\n    // and should just close socket\n    if (err.message.match(/set headers after they are sent/)) {\n      if (_.isNil(res.socket) === false) {\n        // @ts-ignore\n        res.socket.destroy();\n      }\n      return;\n    }\n    throw err;\n  }\n\n  res.send(body);\n}\n\nexport const LOG_STATUS_MESSAGE = \"@{status}, user: @{user}(@{remoteIP}), req: '@{request.method} @{request.url}'\";\nexport const LOG_VERDACCIO_ERROR = `${LOG_STATUS_MESSAGE}, error: @{!error}`;\nexport const LOG_VERDACCIO_BYTES = `${LOG_STATUS_MESSAGE}, bytes: @{bytes.in}/@{bytes.out}`;\n\nexport function log(config: Config) {\n  return function (req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n    const _auth = req.headers.authorization;\n    if (_.isNil(_auth) === false) {\n      req.headers.authorization = '<Classified>';\n    }\n\n    const _cookie = req.get('cookie');\n    if (_.isNil(_cookie) === false) {\n      req.headers.cookie = '<Classified>';\n    }\n\n    req.url = req.originalUrl;\n    // avoid log noise data from static content\n    if (req.originalUrl.match(/static/) === null) {\n      logger.http({ req: req, ip: req.ip }, \"@{ip} requested '@{req.method} @{req.url}'\");\n    }\n    req.originalUrl = req.url;\n\n    if (_.isNil(_auth) === false) {\n      req.headers.authorization = _auth;\n    }\n\n    if (_.isNil(_cookie) === false) {\n      req.headers.cookie = _cookie;\n    }\n\n    let bytesin = 0;\n    if (config?.experiments?.bytesin_off !== true) {\n      req.on('data', function (chunk): void {\n        bytesin += chunk.length;\n      });\n    }\n\n    let bytesout = 0;\n    const _write = res.write;\n    // FIXME: res.write should return boolean\n    // @ts-ignore\n    res.write = function (buf): boolean {\n      bytesout += buf.length;\n      /* eslint prefer-rest-params: \"off\" */\n      // @ts-ignore\n      _write.apply(res, arguments);\n    };\n\n    let logHasBeenCalled = false;\n    const log = function (): void {\n      if (logHasBeenCalled) {\n        return;\n      }\n      logHasBeenCalled = true;\n\n      const forwardedFor = req.get('x-forwarded-for');\n      const remoteAddress = req.connection.remoteAddress;\n      const remoteIP = forwardedFor ? `${forwardedFor} via ${remoteAddress}` : remoteAddress;\n      let message;\n      if (res.locals._verdaccio_error) {\n        message = LOG_VERDACCIO_ERROR;\n      } else {\n        message = LOG_VERDACCIO_BYTES;\n      }\n\n      req.url = req.originalUrl;\n      // avoid log noise data from static content\n      if (req.url.match(/static/) === null) {\n        logger.http(\n          {\n            request: {\n              method: req.method,\n              url: req.url,\n            },\n            user: (req.remote_user && req.remote_user.name) || null,\n            remoteIP,\n            status: res.statusCode,\n            error: res.locals._verdaccio_error,\n            bytes: {\n              in: bytesin,\n              out: bytesout,\n            },\n          },\n          message\n        );\n        req.originalUrl = req.url;\n      }\n    };\n\n    req.on('close', function (): void {\n      log();\n    });\n\n    const _end = res.end;\n    res.end = function (buf): void {\n      if (buf) {\n        bytesout += buf.length;\n      }\n      /* eslint prefer-rest-params: \"off\" */\n      // @ts-ignore\n      _end.apply(res, arguments);\n      log();\n    };\n    next();\n  };\n}\n\n// Middleware\nexport function errorReportingMiddleware(req: $RequestExtend, res: $ResponseExtend, next: $NextFunctionVer): void {\n  res.locals.report_error =\n    res.locals.report_error ||\n    function (err: VerdaccioError): void {\n      if (err.status && err.status >= HTTP_STATUS.BAD_REQUEST && err.status < 600) {\n        if (!res.headersSent) {\n          res.status(err.status);\n          next({ error: err.message || API_ERROR.UNKNOWN_ERROR });\n        }\n      } else {\n        logger.error({ err: err }, 'unexpected error: @{!err.message}\\n@{err.stack}');\n        if (!res.status || !res.send) {\n          logger.error('this is an error in express.js, please report this');\n          res.destroy();\n        } else if (!res.headersSent) {\n          res.status(HTTP_STATUS.INTERNAL_ERROR);\n          next({ error: API_ERROR.INTERNAL_SERVER_ERROR });\n        } else {\n          // socket should be already closed\n        }\n      }\n    };\n\n  next();\n}\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "verdaccio",
3
- "version": "5.1.2",
3
+ "version": "5.1.6",
4
4
  "description": "A lightweight private npm proxy registry",
5
5
  "author": {
6
6
  "name": "Verdaccio Maintainers",
@@ -18,15 +18,15 @@
18
18
  "url": "https://opencollective.com/verdaccio"
19
19
  },
20
20
  "dependencies": {
21
- "@verdaccio/commons-api": "10.0.0",
22
- "@verdaccio/local-storage": "10.0.6",
21
+ "@verdaccio/commons-api": "10.0.1",
22
+ "@verdaccio/local-storage": "10.0.7",
23
23
  "@verdaccio/readme": "10.0.0",
24
24
  "@verdaccio/streams": "10.0.0",
25
- "@verdaccio/ui-theme": "3.1.0",
25
+ "@verdaccio/ui-theme": "3.2.1",
26
26
  "JSONStream": "1.3.5",
27
- "async": "3.2.0",
27
+ "async": "3.2.1",
28
28
  "body-parser": "1.19.0",
29
- "clipanion": "3.0.0",
29
+ "clipanion": "3.0.1",
30
30
  "compression": "1.7.4",
31
31
  "cookies": "0.8.0",
32
32
  "cors": "2.8.5",
@@ -50,14 +50,14 @@
50
50
  "minimatch": "3.0.4",
51
51
  "mkdirp": "1.0.4",
52
52
  "mv": "2.1.1",
53
- "pino": "6.12.0",
53
+ "pino": "6.13.0",
54
54
  "pkginfo": "0.4.1",
55
55
  "prettier-bytes": "^1.0.4",
56
56
  "pretty-ms": "^7.0.1",
57
57
  "request": "2.88.0",
58
58
  "semver": "7.3.5",
59
59
  "validator": "13.6.0",
60
- "verdaccio-audit": "10.0.0",
60
+ "verdaccio-audit": "10.0.2",
61
61
  "verdaccio-htpasswd": "10.0.0"
62
62
  },
63
63
  "devDependencies": {
@@ -132,12 +132,12 @@
132
132
  "puppeteer": "5.5.0",
133
133
  "rimraf": "3.0.2",
134
134
  "selfsigned": "1.10.11",
135
- "standard-version": "9.3.0",
135
+ "standard-version": "9.3.1",
136
136
  "supertest": "6.1.3",
137
- "ts-node": "10.1.0",
137
+ "ts-node": "10.2.0",
138
138
  "typescript": "4.1.3",
139
- "verdaccio-auth-memory": "10.0.0",
140
- "verdaccio-memory": "10.0.0"
139
+ "verdaccio-auth-memory": "10.0.1",
140
+ "verdaccio-memory": "10.0.1"
141
141
  },
142
142
  "keywords": [
143
143
  "private",