postgresql/contrib/pg_prewarm
Nathan Bossart 208927e656 Fix privilege checks for pg_prewarm() on indexes.
pg_prewarm() currently checks for SELECT privileges on the target
relation.  However, indexes do not have access rights of their own,
so a role may be denied permission to prewarm an index despite
having the SELECT privilege on its parent table.  This commit fixes
this by locking the parent table before the index (to avoid
deadlocks) and checking for SELECT on the parent table.  Note that
the code is largely borrowed from
amcheck_lock_relation_and_check().

An obvious downside of this change is the extra AccessShareLock on
the parent table during prewarming, but that isn't expected to
cause too much trouble in practice.

Author: Ayush Vatsa <ayushvatsa1810@gmail.com>
Co-authored-by: Nathan Bossart <nathandbossart@gmail.com>
Reviewed-by: Tom Lane <tgl@sss.pgh.pa.us>
Reviewed-by: Jeff Davis <pgsql@j-davis.com>
Discussion: https://postgr.es/m/CACX%2BKaMz2ZoOojh0nQ6QNBYx8Ak1Dkoko%3DD4FSb80BYW%2Bo8CHQ%40mail.gmail.com
Backpatch-through: 13
2025-10-17 11:36:50 -05:00
..
expected Fix assertion failure in pg_prewarm() on objects without storage. 2025-05-29 17:50:32 +09:00
sql Fix assertion failure in pg_prewarm() on objects without storage. 2025-05-29 17:50:32 +09:00
t Fix privilege checks for pg_prewarm() on indexes. 2025-10-17 11:36:50 -05:00
.gitignore Add a regression test for contrib/pg_prewarm. 2022-08-01 17:59:44 -04:00
autoprewarm.c bufmgr: Remove freelist, always use clock-sweep 2025-09-05 12:25:59 -04:00
Makefile Fix assertion failure in pg_prewarm() on objects without storage. 2025-05-29 17:50:32 +09:00
meson.build Fix assertion failure in pg_prewarm() on objects without storage. 2025-05-29 17:50:32 +09:00
pg_prewarm--1.0--1.1.sql Update pg_prewarm extension for parallel query. 2016-06-09 17:18:18 -04:00
pg_prewarm--1.1--1.2.sql pg_prewarm: Add automatic prewarm feature. 2017-08-21 14:17:39 -04:00
pg_prewarm--1.1.sql Update pg_prewarm extension for parallel query. 2016-06-09 17:18:18 -04:00
pg_prewarm.c Fix privilege checks for pg_prewarm() on indexes. 2025-10-17 11:36:50 -05:00
pg_prewarm.control pg_prewarm: Add automatic prewarm feature. 2017-08-21 14:17:39 -04:00