Re: postgres_fdw, dblink, and CREATE SUBSCRIPTION security
| От | Jacob Champion | 
|---|---|
| Тема | Re: postgres_fdw, dblink, and CREATE SUBSCRIPTION security | 
| Дата | |
| Msg-id | CAAWbhmi-PvUif0c5V=p99Bc4TA20nTim7K4o0x6HXnRVGKpo9A@mail.gmail.com обсуждение исходный текст | 
| Ответ на | Re: postgres_fdw, dblink, and CREATE SUBSCRIPTION security (Robert Haas <robertmhaas@gmail.com>) | 
| Ответы | Re: postgres_fdw, dblink, and CREATE SUBSCRIPTION security | 
| Список | pgsql-hackers | 
On Mon, Jan 30, 2023 at 2:21 PM Robert Haas <robertmhaas@gmail.com> wrote: > On Mon, Jan 30, 2023 at 4:12 PM Jacob Champion <jchampion@timescale.com> wrote: > > For our case, assuming that connections have side effects, one > > solution could be for the client to signal to the server that the > > connection should use in-band authentication only; i.e. fail the > > connection if the credentials provided aren't good enough by > > themselves to authenticate the client. (This has some overlap with > > SASL negotiation, maybe.) > > I'm not an expert on this stuff, but to me that feels like a weak and > fuzzy concept. If the client is going to tell the server something, > I'd much rather have it say something like "i'm proxying a request > from my local user rhaas, who authenticated using such and such a > method and connected from such and such an IP yadda yadda". That feels > to me like really clear communication that the server can then be > configured to something about via pg_hba.conf or similar. Saying "use > in-band authentication only", to me, feels much murkier. As the > recipient of that message, I don't know exactly what to do about it, > and it feels like whatever heuristic I adopt might end up being wrong > and something bad happens anyway. Is it maybe just a matter of terminology? If a proxy tells the server, "This user is logging in. Here's the password I have for them. DO NOT authenticate using anything else," and the HBA says to use ident auth for that user, then the server fails the connection. That's what I mean by in-band -- the proxy says, "here are the credentials for this connection." That's it. Alternatively, if you really don't like making this server-side: any future "connection side effects" we add, such as logon triggers, could either be opted into by the client or explicitly invoked by the client after it's happy with the authentication exchange. Or it could be disabled at the server side for forms of ambient authn. (This is getting closer to HTTP's method safety concept.) > > I agree. (But for the record, I think that an outbound proxy filter is > > also insufficient. Someone, somewhere, is going to want to safely > > proxy through localhost _and_ have peer authentication set up.) > > Well then they're indeed going to need some way to distinguish a > proxied connection from a non-proxied one. You can't send identical > connection requests in different scenarios and get different > results.... Yeah. Most of these solutions require explicitly labelling things that were implicit before. > I think what we really need here is an example or three of a proposed > configuration file syntax. I think it would be good if we could pick a > syntax that doesn't require a super-complicated parser Agreed. The danger from my end is, I'm trained on configuration formats that have infinite bells and whistles. I don't really want to go too crazy with it. > and that maybe > has something in common with our existing configuration file syntaxes. > But if we have to invent something new, then we can do that. Okay. Personally I'd like - the ability to set options globally (so filters are optional) - the ability to maintain many options for a specific scope (host? IP range?) without making my config lines grow without bound - the ability to audit a configuration without trusting its comments But getting all of my wishlist into a sane configuration format that handles all the use cases is the tricky part. I'll think about it. --Jacob
В списке pgsql-hackers по дате отправления: