Grav is a file-based Web-platform built in PHP. Grav is subject to a server side template injection (SSTI) vulnerability. The fix for another SSTI vulnerability using `|map`, `|filter` and `|reduce` twigs implemented in the commit `71bbed1` introduces bypass of the denylist due to incorrect return value from `isDangerousFunction()`, which allows to execute the payload prepending double backslash (`\`). The `isDangerousFunction()` check in version 1.7.42 and onwards retuns `false` value instead of `true` when the “ symbol is found in the `$name`. This vulnerability can be exploited if the attacker has access to: 1. an Administrator account, or 2. a non-administrator, user account that has Admin panel access and Create/Update page permissions. A fix for this vulnerability has been introduced in commit `b4c6210` and is included in release version `1.7.42.2`. Users are advised to upgrade. There are no known workarounds for this vulnerability.
.This CVE has a CVSS3.1 score of 7.2 and a Base Severity of HIGH.
Info | Details |
---|---|
CVE ID | CVE-2023-37897 |
CVE State | PUBLISHED |
BaseScore | 7.2 |
BaseSeverity | HIGH |
VectorString | CVSS:3.1/AV:N/AC:L/PR:H/UI:N/S:U/C:H/I:H/A:H |
Version | NA |
References for CVE-2023-37897 :
https://github.com/getgrav/grav/security/advisories/GHSA-9436-3gmp-4f53
https://github.com/getgrav/grav/commit/71bbed12f950de8335006d7f91112263d8504f1b
https://github.com/getgrav/grav/commit/b4c62101a43051fc7f5349c7d0a5b6085375c1d7
Metric Type | Metric Score |
---|---|
AttackVector(AV) | NETWORK |
AttackComplexity(AC) | LOW |
PrivilegesRequired(PR) | HIGH |
UserInteraction(UI) | NONE |
Scope(S) | UNCHANGED |
Confidentiality(C) | HIGH |
Availability(A) | HIGH |
Integrity(I) | HIGH |