libpq-oauth: a mid-beta naming check
От | Jacob Champion |
---|---|
Тема | libpq-oauth: a mid-beta naming check |
Дата | |
Msg-id | CAOYmi+m5L=-S8QuZgLcSdHyXreVDCVr2NBbCZVcdVzE8B2y5Xg@mail.gmail.com обсуждение исходный текст |
Ответ на | Re: [PoC] Federated Authn/z with OAUTHBEARER (Jacob Champion <jacob.champion@enterprisedb.com>) |
Ответы |
Re: libpq-oauth: a mid-beta naming check
|
Список | pgsql-hackers |
On Wed, Apr 30, 2025 at 10:59 AM Jacob Champion <jacob.champion@enterprisedb.com> wrote: > > I still see the choice of naming (with its forced-ABI break > every major version) as needing more scrutiny, and probably worth a > Revisit entry. It is now time to revisit. = The Status Quo = The libpq-oauth module is loaded on-demand, during the first use of OAuth authentication, so users who don't want the behavior don't have to install it. This module is named "libpq-oauth-18.so" for the PG18 release. So libpq v18 will always load the 18 OAuth behavior, libpq v19 will load the 19 OAuth behavior, etc. Builds on HEAD have already switched to -19, which is not yet any different from -18. The internal API injects some libpq internals into the libpq-oauth module. The ABI for this is assumed to break during each major version release, so I don't have to watch the boundary like a hawk, and other maintainers hopefully won't be saddled with breakage reports if I get hit by a bus. (This is another advantage to using the -MAJOR naming scheme.) And pg_conn in particular is given more protections: we can still change its member offsets in minor versions without any ABI breakage. During major-version upgrades, if a packager doesn't provide a side-by-side installation of the -18 and -19 modules, there is a hazard: an already-loaded v18 libpq might find that the -18 module no longer exists on disk, which would require a restart of the affected application to pick up the v19 libpq. This is not really a consequence of the -MAJOR naming scheme -- it's a consequence of delay-loaded libraries that go through an ABI version bump -- but the naming scheme makes the problem extremely visible. The annoying part is that, if 19 doesn't change anything in the OAuth flow compared to 18, I will basically have made busywork for our packagers for no reason. But my goal for v19 is to replace the internally coupled API with a public API, so that users can swap in their own flows for use with our utilities. As far as I know, that work necessarily includes designing a stable ABI and figuring out a trusted place that users can put their plugins into. If we can do both, I think we can get rid of the -MAJOR versioning scheme entirely, because our use case will have been subsumed by the more general framework. So, as we approach Beta 3: can anyone think of a way that this plan will fail? Thanks, --Jacob
В списке pgsql-hackers по дате отправления: