Re: Bizarre behavior in libpq's searching of ~/.pgpass - Mailing list pgsql-hackers

From Tom Lane
Subject Re: Bizarre behavior in libpq's searching of ~/.pgpass
Date
Msg-id 11455.1533047501@sss.pgh.pa.us
Whole thread Raw
In response to Re: Bizarre behavior in libpq's searching of ~/.pgpass  (Robert Haas <robertmhaas@gmail.com>)
Responses Re: Bizarre behavior in libpq's searching of ~/.pgpass  (Tom Lane <tgl@sss.pgh.pa.us>)
List pgsql-hackers
Robert Haas <robertmhaas@gmail.com> writes:
> On Fri, Jul 27, 2018 at 11:38 PM, Tom Lane <tgl@sss.pgh.pa.us> wrote:
>> I noticed that there's some strange coding in libpq's choice of
>> what hostname to use for searching ~/.pgpass for a password.

> Yeah, that's bad code.  The intent was that if you set host=a,b you
> probably want to use either 'a' or 'b' as the thing to look up in
> .pgpass, not 'a,b', but the implementation leaves something to be
> desired.

Right.  Closely related to that is that the existing code in
passwordFromFile behaves differently for null vs. empty hostname.
This is bad on its face, because nowhere else in libpq do we treat
empty-string parameters differently from unset ones, but it's particularly
a mess for the comma-separated-list case because then it's impossible
for one of the alternatives to be NULL.  In the already-posted patch
I fixed that so that an empty alternative is replaced by DefaultHost
in passwordFromFile, and likewise for port (though I think the latter
case may be unreachable).

But now that I look at it, it seems like the code in connectOptions2
has also Gotten It Wrong.  Shouldn't the replacement of "unspecified"
cases by DEFAULT_PGSOCKET_DIR/DefaultHost also happen on an entry-by-
entry basis, so that "host=foo," would behave as though the empty
entry were "localhost"?

            regards, tom lane


pgsql-hackers by date:

Previous
From: Robert Haas
Date:
Subject: Re: Usability fail with psql's \dp command
Next
From: Robert Haas
Date:
Subject: Re: BUG #15182: Canceling authentication due to timeout aka Denial ofService Attack