CVE-2026-8417
Description
Concrete CMS 9.5.0 and below does not validate a CSRF token before processing requests to /dashboard/extend/update/do_update/<pkgHandle>. The do_update() method in concrete/controllers/single_page/dashboard/extend/update.php checks only canInstallPackages() before executing upgradeCoreData() and upgrade() on the named package's controller. Because the endpoint is a state-changing GET route with no token enforcement, an attacker can force an authenticated administrator to trigger a package upgrade via a single cross-site navigation.In order to be vulnerable, the victim must be passing canInstallPackages() and and a target package must already be already installed. The Concrete CMS security team gave this vulnerability a CVSS v.4.0 score of 7.5 with vector CVSS:4.0/AV:N/AC:H/AT:P/PR:N/UI:A/VC:H/VI:H/VA:H/SC:N/SI:N/SA:N. Thanks https://github.com/maru1009 for reporting.
Predictions
Heuristic predictions, AS-IS, for prioritization only.
Mitigations
Vendor advisory: ff5b8ace-8b95-4078-9743-eac1ca5451de — https://documentation.concretecms.org/9-x/developers/introduction/version-history/951-release-notes
Application impact
| Vendor | Product | Versions | Fixed |
|---|---|---|---|
| concretecms | concrete_cms | {"endExcluding":"9.5.1"} | 9.5.1 |
References
CWEs
CWE-352
Verify integrity in audit chain (admin only). AS-IS.