Re: [PoC] Federated Authn/z with OAUTHBEARER - Mailing list pgsql-hackers
From | Jacob Champion |
---|---|
Subject | Re: [PoC] Federated Authn/z with OAUTHBEARER |
Date | |
Msg-id | CAOYmi+=2cArQoSSRdAYwx2TBSHL5r0UhX28Q-5TP=0g-sxBXCA@mail.gmail.com Whole thread Raw |
In response to | Re: [PoC] Federated Authn/z with OAUTHBEARER (Peter Eisentraut <peter@eisentraut.org>) |
Responses |
Re: [PoC] Federated Authn/z with OAUTHBEARER
Re: [PoC] Federated Authn/z with OAUTHBEARER |
List | pgsql-hackers |
On Tue, Apr 15, 2025 at 5:31 AM Peter Eisentraut <peter@eisentraut.org> wrote: > On 10.04.25 01:08, Jacob Champion wrote: > > Christoph noted that this was also confusing from the packaging side, > > earlier, Since Christoph has withdrawn the request, I will drop -0002. However, I'll go ahead and put some of my opinions down on paper here: > The general idea, at least on the Autoconf side, is that --with-FOO > means enable all the features that require library FOO. I don't think this is particularly user-friendly if it's not obvious what feature is enabled by FOO. LDAP? PAM? Sure. SSL? Eh, I think the pgcrypto coupling is a little strange -- that's not implied by "SSL" at all! -- but it's not problematic enough to complain loudly. --with-gssapi selects... some dependency... which may or may not come from a particular library. --with-bsd-auth doesn't add any library dependencies at all, instead depending on the kernel, but it makes sense. But there's no connection between "libcurl" and "OAuth Device Authorization flow" in anyone's mind except the people who have worked on that feature. If the argument is that we'd need to switch to --enable-oauth-client rather than --with-oauth-client, that works for me. But I don't quite understand the desire to stick to the existing configuration methodology for something that's very different from an end-user perspective. > The naming system you propose has problems: > > First, what if we add another kind of "oauth-client" that doesn't use > libcurl, how would you extend the set of options? With an extension to the values that you can provide to --with-oauth-client, similarly to what was originally proposed for --with-ssl. > Second, what if we add some kind of oauth plugin for the server that > uses libcurl, how would you extend the set of options? With a new option. But let me turn this around, because we currently have the opposite problem: if someone comes in and adds a completely new feature depending on libcurl, and you want OAuth but you do not want that new feature -- or vice-versa -- what do you do? In other words, what if your concern is not with libcurl, but with the feature itself? > But worse, what you are hiding is the information what > dependencies you are pulling in, which is the actual reason for the > options. (If there was no external dependency, there would be no option > at all.) I'm not sure I agree, either practically or philosophically. I like to see the build dependencies, definitely, but I also like to see the features. (Meson will make both things visible separately, for that matter.) > This seems unnecessarily complicated and inconsistent. Once you have > made the choice of taking the libcurl dependency, why not build > everything that requires it? Simply because the end user or packager might not want to. In any case -- I won't die on this particular hill, and I'm happy to continue forward with 0001 alone. Thanks! --Jacob
pgsql-hackers by date: