API Platform Core is the server component of API Platform: hypermedia and GraphQL APIs. Resource properties secured with the security
option of the ApiPlatformMetadataApiProperty
attribute can be disclosed to unauthorized users. The problem affects most serialization formats, including raw JSON, which is enabled by default when installing API Platform. Custom serialization formats may also be impacted. Only collection endpoints are affected by the issue, item endpoints are not. The JSON-LD format is not affected by the issue. The result of the security rule is only executed for the first item of the collection. The result of the rule is then cached and reused for the next items. This bug can leak data to unauthorized users when the rule depends on the value of a property of the item. This bug can also hide properties that should be displayed to authorized users. This issue impacts the 2.7, 3.0 and 3.1 branches. Please upgrade to versions 2.7.10, 3.0.12 or 3.1.3. As a workaround, replace the cache_key
of the context array of the Serializer inside a custom normalizer that works on objects if the security option of the ApiPlatformMetadataApiProperty
attribute is used.
The product performs an authorization check when an actor attempts to access a resource or perform an action, but it does not correctly perform the check. This allows attackers to bypass intended access restrictions.
Name | Vendor | Start Version | End Version |
---|---|---|---|
Core | Api-platform | 2.6.0 (including) | 2.7.10 (excluding) |
Core | Api-platform | 3.0.0 (including) | 3.0.12 (excluding) |
Core | Api-platform | 3.1.0 (including) | 3.1.3 (excluding) |
Assuming a user with a given identity, authorization is the process of determining whether that user can access a given resource, based on the user’s privileges and any permissions or other access-control specifications that apply to the resource. When access control checks are incorrectly applied, users are able to access data or perform actions that they should not be allowed to perform. This can lead to a wide range of problems, including information exposures, denial of service, and arbitrary code execution.