GHSA-f582-6gf6-gx4g

Suggest an improvement
Source
https://github.com/advisories/GHSA-f582-6gf6-gx4g
Import Source
https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/03/GHSA-f582-6gf6-gx4g/GHSA-f582-6gf6-gx4g.json
JSON Data
https://api.osv.dev/v1/vulns/GHSA-f582-6gf6-gx4g
Aliases
  • CVE-2026-33162
Published
2026-03-24T17:28:40Z
Modified
2026-03-25T21:19:13.690387Z
Severity
  • 4.9 (Medium) CVSS_V4 - CVSS:4.0/AV:N/AC:L/AT:N/PR:L/UI:N/VC:N/VI:H/VA:N/SC:N/SI:N/SA:N/E:U CVSS Calculator
Summary
Craft CMS has an authorization bypass which allows any control panel user to move entries without permissions
Details

Summary

An authenticated control panel user with only accessCp can move entries across sections via POST /actions/entries/move-to-section, even when they do not have saveEntries:{sectionUid} permission for either source or destination section.

Details

Root-cause analysis

  1. actionMoveToSection accepts sectionId and entryIds, loads entries, and iterates: Craft::$app->getEntries()->moveEntryToSection($entry, $section).
  2. The endpoint does not enforce per-entry or per-section authorization checks.
  3. moveEntryToSection() also does not enforce current-user authorization.
  4. There is a permission check in actionMoveToSectionModalData for building UI options, but that check is not enforced in the actual endpoint.
  5. Therefore, a direct POST request can bypass UI filtering and perform unauthorized entry moves.

    Impact

  • This is an authorization bypass permitting unauthorized content changes.
  • Authenticated low-privileged control panel users can move entries they should not be able to manage, violating integrity and potentially disrupting routing/editorial controls.
Database specific
{
    "github_reviewed": true,
    "github_reviewed_at": "2026-03-24T17:28:40Z",
    "cwe_ids": [
        "CWE-285",
        "CWE-862"
    ],
    "nvd_published_at": "2026-03-24T18:16:10Z",
    "severity": "MODERATE"
}
References

Affected packages

Packagist / craftcms/cms

Package

Name
craftcms/cms
Purl
pkg:composer/craftcms/cms

Affected ranges

Type
ECOSYSTEM
Events
Introduced
5.3.0
Fixed
5.9.14

Affected versions

5.*
5.3.0
5.3.0.1
5.3.0.2
5.3.0.3
5.3.1
5.3.2
5.3.3
5.3.4
5.3.5
5.3.6
5.4.0
5.4.0.1
5.4.1
5.4.2
5.4.3
5.4.4
5.4.5
5.4.5.1
5.4.6
5.4.7
5.4.7.1
5.4.8
5.4.9
5.4.10
5.4.10.1
5.5.0
5.5.0.1
5.5.1
5.5.1.1
5.5.2
5.5.3
5.5.4
5.5.5
5.5.6
5.5.6.1
5.5.7
5.5.8
5.5.9
5.5.10
5.6.0
5.6.0.1
5.6.0.2
5.6.1
5.6.2
5.6.3
5.6.4
5.6.5
5.6.5.1
5.6.6
5.6.7
5.6.8
5.6.9
5.6.9.1
5.6.10
5.6.10.1
5.6.10.2
5.6.11
5.6.12
5.6.13
5.6.14
5.6.15
5.6.16
5.6.17
5.7.0-beta.1
5.7.0-beta.2
5.7.0
5.7.1
5.7.1.1
5.7.2
5.7.3
5.7.4
5.7.5
5.7.6
5.7.7
5.7.8
5.7.8.1
5.7.8.2
5.7.9
5.7.10
5.7.11
5.8.0
5.8.1
5.8.2
5.8.3
5.8.4
5.8.5
5.8.6
5.8.7
5.8.8
5.8.9
5.8.10
5.8.11
5.8.12
5.8.13
5.8.13.1
5.8.13.2
5.8.14
5.8.15
5.8.16
5.8.17
5.8.18
5.8.19
5.8.20
5.8.21
5.8.22
5.8.23
5.9.0-beta.1
5.9.0-beta.2
5.9.0
5.9.1
5.9.2
5.9.3
5.9.4
5.9.5
5.9.6
5.9.7
5.9.8
5.9.9
5.9.10
5.9.11
5.9.12
5.9.13

Database specific

last_known_affected_version_range
"<= 5.9.13"
source
"https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/03/GHSA-f582-6gf6-gx4g/GHSA-f582-6gf6-gx4g.json"