Advisory Database
  • Advisories
  • Dependency Scanning
  1. npm
  2. ›
  3. serve
  4. ›
  5. GMS-2020-775

GMS-2020-775: Byass due to validation before canonicalization in serve

September 1, 2020

Versions of serve before 6.5.2 are vulnerable to the bypass of the ignore functionality. The bypass is possible because validation happens before canonicalization of paths and filenames.

Example: Here we have a server that ignores the file test.txt.

const serve = require('serve')
const server = serve(__dirname, {
      port: 1337,
      ignore: ['test.txt']
})

Using the URL encoded form of a letter (%65 instead of e) attacker can bypass the ignore control accessing the file.

curl http://localhost:1337/t%65st.txt

Additionally this technique can be used to get directory listings of ignored directories.

Recommendation

Update to version 6.5.2 or later.

References

  • github.com/advisories/GHSA-wm7q-rxch-43mx
  • hackerone.com/reports/308721
  • www.npmjs.com/advisories/594

Code Behaviors & Features

Detect and mitigate GMS-2020-775 with GitLab Dependency Scanning

Secure your software supply chain by verifying that all open source dependencies used in your projects contain no disclosed vulnerabilities. Learn more about Dependency Scanning →

Affected versions

All versions before 6.5.2

Fixed versions

  • 6.5.2

Solution

Upgrade to version 6.5.2 or above.

Source file

npm/serve/GMS-2020-775.yml

Spotted a mistake? Edit the file on GitLab.

  • Site Repo
  • About GitLab
  • Terms
  • Privacy Statement
  • Contact

Page generated Wed, 14 May 2025 12:15:20 +0000.