postgres_fdw: set search_path to 'pg_catalog' while deparsing constants.
authorTom Lane <tgl@sss.pgh.pa.us>
Sun, 17 Jul 2022 21:27:50 +0000 (17:27 -0400)
committerTom Lane <tgl@sss.pgh.pa.us>
Sun, 17 Jul 2022 21:27:50 +0000 (17:27 -0400)
commit0a7ccee8fe9ffaff09ad45f4890a3457c69e80b7
tree2c2397e5c72f91f8cbd2b82d5e76a11666433b48
parente993166d71878a11a177b3ade601320d03f12cdf
postgres_fdw: set search_path to 'pg_catalog' while deparsing constants.

The motivation for this is to ensure successful transmission of the
values of constants of regconfig and other reg* types.  The remote
will be reading them with search_path = 'pg_catalog', so schema
qualification is necessary when referencing objects in other schemas.

Per bug #17483 from Emmanuel Quincerot.  Back-patch to all supported
versions.  (There's some other stuff to do here, but it's less
back-patchable.)

Discussion: https://postgr.es/m/1423433.1652722406@sss.pgh.pa.us
contrib/postgres_fdw/expected/postgres_fdw.out
contrib/postgres_fdw/postgres_fdw.c
contrib/postgres_fdw/sql/postgres_fdw.sql