Forbid DROP SCHEMA on temporary namespaces
authorMichael Paquier <michael@paquier.xyz>
Fri, 27 Dec 2019 08:58:43 +0000 (17:58 +0900)
committerMichael Paquier <michael@paquier.xyz>
Fri, 27 Dec 2019 08:58:43 +0000 (17:58 +0900)
commita052f6cbb84e5630d50b68586cecc127e64be639
tree00fff555b3903cc0a1bb9213aad830d6b9108d08
parent7854e07f25be3a3dfa9c94011a30767eca3c10ba
Forbid DROP SCHEMA on temporary namespaces

This operation was possible for the owner of the schema or a superuser.
Down to 9.4, doing this operation would cause inconsistencies in a
session whose temporary schema was dropped, particularly if trying to
create new temporary objects after the drop.  A more annoying
consequence is a crash of autovacuum on an assertion failure when
logging information about an orphaned temp table dropped.  Note that
because of 246a6c8 (present in v11~), which has made the removal of
orphaned temporary tables more aggressive, the failure could be
triggered more easily, but it is possible to reproduce down to 9.4.

Reported-by: Mahendra Singh, Prabhat Sahu
Author: Michael Paquier
Reviewed-by: Kyotaro Horiguchi, Mahendra Singh
Discussion: https://postgr.es/m/CAKYtNAr9Zq=1-ww4etHo-VCC-k120YxZy5OS01VkaLPaDbv2tg@mail.gmail.com
Backpatch-through: 9.4
src/backend/commands/dropcmds.c