GHSA-9wfj-c55w-j9qr

Suggest an improvement
Source
https://github.com/advisories/GHSA-9wfj-c55w-j9qr
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/04/GHSA-9wfj-c55w-j9qr/GHSA-9wfj-c55w-j9qr.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-9wfj-c55w-j9qr
Aliases
  • CVE-2026-32870
Published
2026-04-23T21:21:17Z
Modified
2026-05-05T16:05:15.377246Z
Severity
  • 6.9 (Medium) CVSS_V4 - CVSS:4.0/AV:N/AC:L/AT:P/PR:N/UI:N/VC:N/VI:N/VA:N/SC:N/SI:H/SA:N CVSS Calculator
Summary
Kirby has XML injection in its XML creator toolkit
Details

TL;DR

This vulnerability only affects Kirby sites that use the Xml data handler (e.g. Data::encode($string, 'xml')) or the Xml::create(), Xml::tag() or Xml::value() method(s) in site or plugin code. The Kirby core does not use any of the affected methods.

If consumers use an affected method and cannot rule out input to these methods controlled by an attacker, Kirby strongly recommends that they update to a patch release.


Introduction

XML strings contain structured data in tags and attributes. Depending on the used XML schema, this data can carry specific meaning that can lead to actions in other systems that parse and act on the XML data. Tags and attributes are detected based on their specific syntax, which includes characters such as <, >, ", and &. If these characters are to be used verbatim in text within the XML string, they can be escaped using a <![CDATA[ ]]> block.

XML injection is an attack on a system generating or parsing XML files. By injecting special characters into input data, XML output with a malicious meaning could be generated by a vulnerable system.

Impact

Kirby's Xml::value() method has special handling for <![CDATA[ ]]> blocks. If the input value is already valid CDATA, it is not escaped a second time but allowed to pass through. However it was possible to trick this check into allowing values that only contained a valid CDATA block but also contained other structured data outside of the CDATA block. This structured data would then also be allowed to pass through, circumventing the value protection.

The Xml::value() method is used in Xml::tag(), Xml::create() and in the Xml data handler (e.g. Data::encode($string, 'xml')).

Both the vulnerable methods and the data handler are not used in the Kirby core. However they may be used in site or plugin code, e.g. to create XML strings from input data. If those generated files are passed to another implementation that assigns specific meaning to the XML schema, manipulation of this system's behavior is possible.

Kirby sites that don't use XML generation in site or plugin code are not affected.

Patches

The problem has been patched in Kirby 4.9.0 and Kirby 5.4.0. Please update to one of these or a later version to fix the vulnerability.

In all of the mentioned releases, Kirby has added additional checks that only allow unchanged CDATA passthrough if the entire string is made up of valid CDATA blocks and no structured data. This protects all uses of the method against the described vulnerability.

Credits

Kirby thanks to Patrick Falb (@dapatrese) at FORMER 03 for responsibly reporting the identified issue.

Database specific
{
    "github_reviewed": true,
    "severity": "MODERATE",
    "nvd_published_at": "2026-04-24T01:16:11Z",
    "cwe_ids": [
        "CWE-91"
    ],
    "github_reviewed_at": "2026-04-23T21:21:17Z"
}
References

Affected packages

Packagist / getkirby/cms

Package

Name
getkirby/cms
Purl
pkg:composer/getkirby/cms

Affected ranges

Type
ECOSYSTEM
Events
Introduced
0Unknown introduced version / All previous versions are affected
Fixed
4.9.0

Affected versions

3.*
3.0.0
3.0.1-rc.1
3.0.1
3.0.2-rc.1
3.0.2
3.0.3-rc.1
3.0.3-rc.2
3.0.3-rc.3
3.0.3
3.1.0-rc.1
3.1.0
3.1.1
3.1.2-rc.1
3.1.2
3.1.3-rc.1
3.1.3
3.1.4-rc.1
3.1.4
3.2.0-rc.1
3.2.0-rc.2
3.2.0-rc.3
3.2.0-rc.4
3.2.0
3.2.1-rc.1
3.2.1
3.2.2
3.2.3-rc.1
3.2.3
3.2.4-rc.1
3.2.4
3.2.5-rc.1
3.2.5-rc.2
3.2.5
3.3.0-rc.1
3.3.0-rc.2
3.3.0-rc.3
3.3.0-rc.4
3.3.0-rc.5
3.3.0
3.3.1-rc.1
3.3.1
3.3.2-rc.1
3.3.2
3.3.3-rc.1
3.3.3
3.3.4-rc.1
3.3.4
3.3.5-rc.1
3.3.5
3.3.6
3.4.0-rc.1
3.4.0-rc.2
3.4.0-rc.3
3.4.0
3.4.1-rc.1
3.4.1
3.4.2
3.4.3-rc.1
3.4.3
3.4.4-rc.1
3.4.4
3.4.5
3.5.0-rc.1
3.5.0-rc.2
3.5.0-rc.3
3.5.0-rc.4
3.5.0-rc.5
3.5.0-rc.6
3.5.0-rc.7
3.5.0
3.5.1-rc.1
3.5.1
3.5.2-rc.1
3.5.2
3.5.3
3.5.3.1
3.5.4
3.5.5-rc.1
3.5.5
3.5.6-rc.1
3.5.6
3.5.7-rc.1
3.5.7
3.5.7.1
3.5.8
3.5.8.1
3.5.8.2
3.5.8.3
3.5.8.4
3.6.0-alpha.1
3.6.0-alpha.2
3.6.0-alpha.3
3.6.0-alpha.4
3.6.0-beta.1
3.6.0-beta.2
3.6.0-beta.3
3.6.0-rc.1
3.6.0-rc.2
3.6.0-rc.3
3.6.0-rc.4
3.6.0-rc.5
3.6.0
3.6.1
3.6.1.1
3.6.2-rc.1
3.6.2-rc.2
3.6.2-rc.3
3.6.2
3.6.3-rc.1
3.6.3-rc.2
3.6.3
3.6.3.1
3.6.4-rc.1
3.6.4
3.6.5-rc.1
3.6.5
3.6.6-rc.1
3.6.6
3.6.6.1
3.6.6.2
3.6.6.3
3.6.6.4
3.6.6.5
3.6.6.6
3.7.0-rc.1
3.7.0-rc.2
3.7.0-rc.3
3.7.0
3.7.0.1
3.7.0.2
3.7.1-rc.1
3.7.1
3.7.2-rc.1
3.7.2
3.7.2.1
3.7.3-rc.1
3.7.3
3.7.4-rc.1
3.7.4
3.7.5
3.7.5.1
3.7.5.2
3.7.5.3
3.7.5.4
3.7.5.5
3.8.0-rc.1
3.8.0-rc.2
3.8.0-rc.3
3.8.0
3.8.1-rc.1
3.8.1
3.8.1.1
3.8.2-rc.1
3.8.2
3.8.3-rc.1
3.8.3-rc.2
3.8.3
3.8.4
3.8.4.1
3.8.4.2
3.8.4.3
3.8.4.4
3.9.0-rc.1
3.9.0-rc.2
3.9.0
3.9.1-rc.1
3.9.1
3.9.2-rc.1
3.9.2
3.9.3-rc.1
3.9.3
3.9.4-rc.1
3.9.4
3.9.5-rc.1
3.9.5
3.9.6-rc.1
3.9.6
3.9.6.1
3.9.7-rc.1
3.9.7
3.9.8-rc.1
3.9.8
3.9.8.1
3.9.8.2
3.9.8.3
3.10.0
3.10.0.1
3.10.1
3.10.1.1
3.10.1.2
4.*
4.0.0-alpha.1
4.0.0-alpha.2
4.0.0-alpha.3
4.0.0-alpha.4
4.0.0-alpha.5
4.0.0-alpha.6
4.0.0-alpha.7
4.0.0-beta.1
4.0.0-beta.2
4.0.0-beta.3
4.0.0-rc.1
4.0.0-rc.2
4.0.0-rc.3
4.0.0-rc.4
4.0.0
4.0.1
4.0.2
4.0.3
4.1.0-rc.1
4.1.0-rc.2
4.1.0-rc.3
4.1.0
4.1.1
4.1.2
4.2.0-rc.1
4.2.0
4.3.0-rc.1
4.3.0
4.3.1
4.4.0-rc.1
4.4.0
4.4.1
4.5.0-rc.1
4.5.0
4.6.0-rc.1
4.6.0
4.6.1
4.7.0-rc.1
4.7.0
4.7.1
4.7.2
4.8.0-rc.1
4.8.0

Database specific

source
"https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/04/GHSA-9wfj-c55w-j9qr/GHSA-9wfj-c55w-j9qr.json"

Packagist / getkirby/cms

Package

Name
getkirby/cms
Purl
pkg:composer/getkirby/cms

Affected ranges

Type
ECOSYSTEM
Events
Introduced
5.0.0
Fixed
5.4.0

Affected versions

5.*
5.0.0
5.0.1
5.0.2
5.0.3
5.0.4
5.1.0-rc.1
5.1.0
5.1.1
5.1.2
5.1.3
5.1.4
5.2.0-rc.1
5.2.0
5.2.1
5.2.2
5.2.3
5.3.0-rc.1
5.3.0
5.3.1
5.3.2
5.3.3

Database specific

source
"https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/04/GHSA-9wfj-c55w-j9qr/GHSA-9wfj-c55w-j9qr.json"