Parse Server's LiveQuery bypasses CLP pointer permission enforcement
High severity
GitHub Reviewed
Published
Mar 20, 2026
in
parse-community/parse-server
•
Updated Mar 30, 2026
Package
Affected versions
>= 9.0.0, < 9.6.0-alpha.42
< 8.6.53
Patched versions
9.6.0-alpha.42
8.6.53
Description
Published to the GitHub Advisory Database
Mar 20, 2026
Reviewed
Mar 20, 2026
Published by the National Vulnerability Database
Mar 24, 2026
Last updated
Mar 30, 2026
Impact
Parse Server's LiveQuery WebSocket interface does not enforce Class-Level Permission (CLP) pointer permissions (
readUserFieldsandpointerFields). Any authenticated user can subscribe to LiveQuery events and receive real-time updates for all objects in classes protected by pointer permissions, regardless of whether the pointer fields on those objects point to the subscribing user. This bypasses the intended read access control, allowing unauthorized access to potentially sensitive data that is correctly restricted via the REST API.Patches
The LiveQuery server now enforces pointer permissions on each event. After the existing check passes (which defers pointer permissions by design), the fix checks whether any configured pointer field on the object points to the subscribing user. Events for objects that don't match are silently skipped, consistent with how ACL mismatches are handled.
Workarounds
Use ACLs on individual objects to restrict read access instead of relying solely on CLP pointer permissions. ACLs are enforced by LiveQuery.
References