CVE-2023-25575
Secured properties in API Platform Core may be accessible within collections
En resumen
API Platform Core tiene una falla donde propiedades protegidas en colecciones pueden ser mostradas a usuarios no autorizados. La verificación de seguridad se almacena en caché después del primer elemento, lo que puede filtrar datos sensibles si las reglas de protección dependen de valores del elemento.
Detalle técnico
CWE-842 afecta endpoints de colección en API Platform Core versiones 2.7, 3.0 y 3.1. El contexto de seguridad se evalúa solo para el primer elemento de la colección y luego se cachea globalmente, causando que elementos posteriores eludan controles de acceso a nivel de propiedad. Los atacantes pueden acceder a propiedades marcadas como seguras en respuestas de colección cuando se utilizan formatos de serialización distintos a JSON-LD.
Resumen generado y traducido por IA a partir de la descripción oficial.
API Platform Core is the server component of API Platform: hypermedia and GraphQL APIs. Resource properties secured with the `security` option of the `ApiPlatform\Metadata\ApiProperty` 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 `ApiPlatform\Metadata\ApiProperty` attribute is used.
CVSS:3.1/AV:N/AC:L/PR:L/UI:N/S:C/C:H/I:N/A:N