The GraphQL directive @parseRefs, intended to parse internal reference tags (e.g., {user:1:email}), can be abused by both authenticated users and unauthenticated guests (if a Public Schema is enabled) to access sensitive attributes of any element in the CMS. The implementation in Elements::parseRefs fails to perform authorization checks, allowing attackers to read data they are not authorized to view.
craft\services\Elements::parseRefs identifies reference tags and resolves them using _getRefTokenReplacement. This method fetches the referenced element and accesses the specified attribute via $element->$attribute.
canView() checks.getElementTypeByRefHandle allows referencing any element type (entry, asset, user, category).__get() to resolve custom field handles, an attacker is not limited to core attributes. They can exfiltrate any custom field data by enumerating the field handle (e.g. {entry:123:privateNotes}).An attacker can enumerate sensitive attributes of administrators or other users.
{user:1:email} or {user:1:photoId}The vulnerability allows reflecting any accessible property of the underlying Element model.
{user:1:username} (Confirmed: returns admin), {user:1:admin}.{user:1:authKey}) exposes full server stack traces in the GraphQL error response (e.g., Exception: No user session token exists with paths like /var/www/html/...).The vulnerability is not limited to Users. Reference tags can target any element type.
{entry:456:myConfidentialField} (Bypasses canView checks).{volume:1:path} can expose internal file system paths.Confirmed locally. The @parseRefs directive is active in the Public Schema. By injecting a payload into a public-facing field (e.g., a "News" entry title), an unauthenticated guest can trigger the resolution and retrieve the sensitive output.
curl -X POST \
-H "Content-Type: application/json" \
-d '{"query": "{ entries { title @parseRefs } }"}'
{"data":{"entries":[{"title":"admin"}]}} (or the email).{user:1:authKey} triggers an internal server error that leaks the full server path in string format.Modify Elements::parseRefs to enforce canView permissions on the resolved element before extracting attributes.
https://github.com/craftcms/cms/commit/4d98a07e47580f1712095825d3e3c4d67bc9f8b9
{
"github_reviewed": true,
"severity": "HIGH",
"nvd_published_at": "2026-03-04T17:16:21Z",
"cwe_ids": [
"CWE-639",
"CWE-862"
],
"github_reviewed_at": "2026-03-03T20:38:55Z"
}