SpiceDB having multiple caveats on resources of the same type may improperly result in no permission
Package
Affected versions
< 1.35.3
Patched versions
1.35.3
Description
Published to the GitHub Advisory Database
Sep 18, 2024
Reviewed
Sep 18, 2024
Published by the National Vulnerability Database
Sep 18, 2024
Last updated
Nov 18, 2024
Background
Multiple caveats over the same indirect subject type on the same relation can result in no permission being returned when permission is expected
For example, given this schema:
If the resource has multiple groups, and each group is caveated, it is possible for the returned permission to be "no permission" when permission is expected.
Impact
Permission is returned as NO_PERMISSION when PERMISSION is expected on the CheckPermission API.
Workarounds
Do not use caveats or do not use caveats on an indirect subject type with multiple entries
References