Description
Improper input validation on the `contains` LoopBack filter may allow for arbitrary SQL injection. When the extended filter property `contains` is permitted to be interpreted by the Postgres connector, it is possible to inject arbitrary SQL which may affect the confidentiality and integrity of data stored on the connected database. A patch was released in version 5.5.1. This affects users who does any of the following: - Connect to the database via the DataSource with `allowExtendedProperties: true` setting OR - Uses the connector's CRUD methods directly OR - Uses the connector's other methods to interpret the LoopBack filter. Users who are unable to upgrade should do the following if applicable: - Remove `allowExtendedProperties: true` DataSource setting - Add `allowExtendedProperties: false` DataSource setting - When passing directly to the connector functions, manually sanitize the user input for the `contains` LoopBack filter beforehand.
Remediation
References
https://github.com/loopbackio/loopback-connector-postgresql/commit/d57406c6737692a3a106b58a35406290cddb23e5
https://github.com/loopbackio/loopback-connector-postgresql/security/advisories/GHSA-j259-6c58-9m58
Related Vulnerabilities
CVE-2021-30246 Vulnerability in maven package org.webjars.bower:jsrsasign
CVE-2019-14863 Vulnerability in maven package org.webjars.bower:angular
CVE-2022-35915 Vulnerability in npm package @openzeppelin/contracts
CVE-2021-3757 Vulnerability in npm package immer
CVE-2021-28168 Vulnerability in maven package org.glassfish.jersey.core:jersey-common