pgsql: Disallow "=" in names of reloptions and foreign-data options.

Поиск
Список
Период
Сортировка
От Tom Lane
Тема pgsql: Disallow "=" in names of reloptions and foreign-data options.
Дата
Msg-id E1uMAkQ-00040l-2h@gemulon.postgresql.org
обсуждение исходный текст
Список pgsql-committers
Disallow "=" in names of reloptions and foreign-data options.

We store values for these options as array elements with the syntax
"name=value", hence a name containing "=" confuses matters when
it's time to read the array back in.  Since validation of the
options is often done (long) after this conversion to array format,
that leads to confusing and off-point error messages.  We can
improve matters by rejecting names containing "=" up-front.

(Probably a better design would have involved pairs of array
elements, but it's too late now --- and anyway, there's no
evident use-case for option names like this.  We already
reject such names in some other contexts such as GUCs.)

Reported-by: Chapman Flack <jcflack@acm.org>
Author: Tom Lane <tgl@sss.pgh.pa.us>
Reviewed-by: Chapman Flack <jcflack@acm.org>
Discussion: https://postgr.es/m/6830EB30.8090904@acm.org
Backpatch-through: 13

Branch
------
REL_13_STABLE

Details
-------
https://git.postgresql.org/pg/commitdiff/cd31eaaebc406d043f5dc240f8849d640490e707

Modified Files
--------------
contrib/file_fdw/input/file_fdw.source  |  2 ++
contrib/file_fdw/output/file_fdw.source |  5 +++++
src/backend/access/common/reloptions.c  | 17 +++++++++++++----
src/backend/commands/foreigncmds.c      | 15 +++++++++++++--
4 files changed, 33 insertions(+), 6 deletions(-)


В списке pgsql-committers по дате отправления: