{ "data_version": "4.0", "data_type": "CVE", "data_format": "MITRE", "CVE_data_meta": { "ID": "CVE-2024-10976", "ASSIGNER": "cna@postgresql.org", "STATE": "PUBLIC" }, "description": { "description_data": [ { "lang": "eng", "value": "Incomplete tracking in PostgreSQL of tables with row security allows a reused query to view or change different rows from those intended. CVE-2023-2455 and CVE-2016-2193 fixed most interaction between row security and user ID changes. They missed cases where a subquery, WITH query, security invoker view, or SQL-language function references a table with a row-level security policy. This has the same consequences as the two earlier CVEs. That is to say, it leads to potentially incorrect policies being applied in cases where role-specific policies are used and a given query is planned under one role and then executed under other roles. This scenario can happen under security definer functions or when a common user and query is planned initially and then re-used across multiple SET ROLEs. Applying an incorrect policy may permit a user to complete otherwise-forbidden reads and modifications. This affects only databases that have used CREATE POLICY to define a row security policy. An attacker must tailor an attack to a particular application's pattern of query plan reuse, user ID changes, and role-specific row security policies. Versions before PostgreSQL 17.1, 16.5, 15.9, 14.14, 13.17, and 12.21 are affected." } ] }, "problemtype": { "problemtype_data": [ { "description": [ { "lang": "eng", "value": "Improper Preservation of Consistency Between Independent Representations of Shared State", "cweId": "CWE-1250" } ] } ] }, "affects": { "vendor": { "vendor_data": [ { "vendor_name": "n/a", "product": { "product_data": [ { "product_name": "PostgreSQL", "version": { "version_data": [ { "version_affected": "<", "version_name": "17", "version_value": "17.1" }, { "version_affected": "<", "version_name": "16", "version_value": "16.5" }, { "version_affected": "<", "version_name": "15", "version_value": "15.9" }, { "version_affected": "<", "version_name": "14", "version_value": "14.14" }, { "version_affected": "<", "version_name": "13", "version_value": "13.17" }, { "version_affected": "<", "version_name": "0", "version_value": "12.21" } ] } } ] } } ] } }, "references": { "reference_data": [ { "url": "https://www.postgresql.org/support/security/CVE-2024-10976/", "refsource": "MISC", "name": "https://www.postgresql.org/support/security/CVE-2024-10976/" } ] }, "configuration": [ { "lang": "en", "value": "application uses row security policies that react to the current role, and one database session reaches the same query via multiple roles" } ], "credits": [ { "lang": "en", "value": "The PostgreSQL project thanks Wolfgang Walther for reporting this problem." } ], "impact": { "cvss": [ { "version": "3.1", "vectorString": "CVSS:3.1/AV:N/AC:H/PR:L/UI:N/S:U/C:L/I:L/A:N", "baseScore": 4.2, "baseSeverity": "MEDIUM" } ] } }