pgsql: Re-validate connection string in libpqrcv_connect().

Поиск
Список
Период
Сортировка
От Jeff Davis
Тема pgsql: Re-validate connection string in libpqrcv_connect().
Дата
Msg-id E1rOPIq-001842-VG@gemulon.postgresql.org
обсуждение исходный текст
Ответы Re: pgsql: Re-validate connection string in libpqrcv_connect().  (Jeff Davis <pgsql@j-davis.com>)
Список pgsql-committers
Re-validate connection string in libpqrcv_connect().

A superuser may create a subscription with password_required=true, but
which uses a connection string without a password.

Previously, if the owner of such a subscription was changed to a
non-superuser, the non-superuser was able to utilize a password from
another source (like a password file or the PGPASSWORD environment
variable), which should not have been allowed.

This commit adds a step to re-validate the connection string before
connecting.

Reported-by: Jeff Davis
Author: Vignesh C
Reviewed-by: Peter Smith, Robert Haas, Amit Kapila
Discussion: https://www.postgresql.org/message-id/flat/e5892973ae2a80a1a3e0266806640dae3c428100.camel%40j-davis.com
Backpatch-through: 16

Branch
------
master

Details
-------
https://git.postgresql.org/pg/commitdiff/5c31669058b5550b4b3d623c07bc4203c11b8316

Modified Files
--------------
doc/src/sgml/ref/create_subscription.sgml          | 11 +--
.../libpqwalreceiver/libpqwalreceiver.c            |  9 +++
src/test/subscription/t/027_nosuperuser.pl         | 80 ++++++++++++++++++++++
3 files changed, 95 insertions(+), 5 deletions(-)


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

Предыдущее
От: Peter Eisentraut
Дата:
Сообщение: pgsql: Refactor ATExecAddColumn() to use BuildDescForRelation()
Следующее
От: Jeff Davis
Дата:
Сообщение: pgsql: Re-validate connection string in libpqrcv_connect().