Advisory Database
  • Advisories
  • Dependency Scanning
  1. npm
  2. ›
  3. loopback-connector-mongodb
  4. ›
  5. GMS-2019-37

GMS-2019-37: NoSQL Injection in loopback-connector-mongodb

June 4, 2019 (updated August 4, 2021)

Versions of loopback-connector-mongodb are vulnerable to NoSQL injection.

MongoDB Connector for LoopBack fails to properly sanitize a filter passed to query the database by allowing the dangerous $where property to be passed to the MongoDB Driver. The Driver allows the special $where property in a filter to execute JavaScript (client can pass in a malicious script) on the database Driver. This is an intended feature of MongoDB unless disabled (instructions here).

A proof of concept malicious query:

GET /POST filter={"where": {"$where": "function(){sleep(5000); return this.title.contains('Hello');}"}}

The above makes the database sleep for 5 seconds and then returns all “Posts” with the title containing the word Hello.

Update to or later.

References

  • github.com/advisories/GHSA-m734-r4g6-34f9
  • github.com/strongloop/loopback-connector-mongodb/commit/ee24cd08b8ccc32711264831c71b1da628df357b
  • github.com/strongloop/loopback-connector-mongodb/issues/403
  • github.com/strongloop/loopback-connector-mongodb/pull/452
  • loopback.io/doc/en/lb3/Security-advisory-08-15-2018.html
  • www.npmjs.com/advisories/696

Code Behaviors & Features

Detect and mitigate GMS-2019-37 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 3.6.0

Fixed versions

  • 3.6.0

Solution

Upgrade to version 3.6.0 or above.

Source file

npm/loopback-connector-mongodb/GMS-2019-37.yml

Spotted a mistake? Edit the file on GitLab.

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

Page generated Wed, 14 May 2025 12:16:08 +0000.