Re: [PoC] Federated Authn/z with OAUTHBEARER

From: Jacob Champion <jacob(dot)champion(at)enterprisedb(dot)com>
To: Peter Eisentraut <peter(at)eisentraut(dot)org>
Cc: Daniel Gustafsson <daniel(at)yesql(dot)se>, Antonin Houska <ah(at)cybertec(dot)at>, PostgreSQL Hackers <pgsql-hackers(at)postgresql(dot)org>
Subject: Re: [PoC] Federated Authn/z with OAUTHBEARER
Date: 2025-01-13 23:21:31
Message-ID: CAOYmi+kZAka0sdxCOBxsQc2ozEZGZKHWU_9nrPXg3sG1NJ-zJw@mail.gmail.com
Views: Raw Message | Whole Thread | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

On Fri, Jan 10, 2025 at 5:27 AM Peter Eisentraut <peter(at)eisentraut(dot)org> wrote:
> Assuming that uintptr_t is the right underlying type for SOCKET, that
> seems ok.

Best I can tell, SOCKET is a UINT_PTR (distinct from PUINT) so I think
that's correct.

> #ifdef WIN32
>
> might not work because WIN32 is defined by the PostgreSQL build system,
> not by the compiler (see src/include/port/win32.h).

Ah, thanks for catching that. Changed to _WIN32.

On Thu, Jan 9, 2025 at 2:44 PM Daniel Gustafsson <daniel(at)yesql(dot)se> wrote:
>
> > On 9 Jan 2025, at 23:35, Jacob Champion <jacob(dot)champion(at)enterprisedb(dot)com> wrote:
> > I'm sure someone's going to complain at some point, but IMNSHO, the
> > fix for them is just to use the same formatting and capitalization as
> > the discovery document, and move on.
>
> Fair enough, I buy that. Maybe the above could be de-opinionated slightly and added as a comment to help others reading the code down the line?

Done!

On Thu, Jan 9, 2025 at 12:40 PM Daniel Gustafsson <daniel(at)yesql(dot)se> wrote:
> Support for oauth seems to be missing from pg_hba_file_rules() which should be
> added in hbafuncs.c:get_hba_options().

Done, and added a basic test for it too.

--

v41 handles the feedback since v40, continues fleshing out
documentation, and splits out three prefactoring patches:
- 0001 moves PG_MAX_AUTH_TOKEN_LENGTH, as discussed upthread
- 0002 handles the non-OAuth-specific changes to require_auth (0005
now highlights the OAuth-specific pieces)
- 0003 adds SASL_ASYNC and its handling code

When I applied Daniel's async_auth_portion patch from earlier, custom
flows began double-freeing their socket descriptors. That made logical
sense but it wasn't immediately clear to me how to fix it, until I
realized that "async authentication state" and "SASL mechanism state"
are two different things with different lifetimes, and my previous
attempts conflated them. 0003 introduces a cleanup_async_auth()
callback, to explicitly free the altsock and its related supporting
allocations as soon as it's no longer needed. Not only does this solve
the double-free, it removes an extra layer of indirection from 0004
and neatly fixes a TODO where the Curl handles were sticking around
for the lifetime of the Postgres connection. Assertions have been
added to keep the new internal API consistent.

pqSocketCheck() was returning ready if it found buffered SSL data,
even if an altsock had been set. I separated the two paths more
completely in 0003.

The FreeBSD 13.3 image started failing to correctly resolve libcurl
package dependencies, leading to missing libssh2 symbols at runtime.
And 13.3 went EOL at the end of 2024 -- which is possibly related to
the breakage? -- so I seemingly cannot perform a `pkg update` to try
to fix things. I've added a hack around this in 0006 that can
hopefully be removed again when our Cirrus images transition to 14.2
[1].

Next email will discuss the architectural bug that Kashif found.

Thanks,
--Jacob

[1] https://github.com/anarazel/pg-vm-images/pull/109

Attachment Content-Type Size
since-v40.diff.txt text/plain 58.2 KB
v41-0001-Move-PG_MAX_AUTH_TOKEN_LENGTH-to-libpq-auth.h.patch application/octet-stream 3.1 KB
v41-0002-require_auth-prepare-for-multiple-SASL-mechanism.patch application/octet-stream 10.4 KB
v41-0003-libpq-handle-asynchronous-actions-during-SASL.patch application/octet-stream 17.2 KB
v41-0004-Add-OAUTHBEARER-SASL-mechanism.patch application/octet-stream 273.0 KB
v41-0005-squash-Add-OAUTHBEARER-SASL-mechanism.patch application/octet-stream 9.5 KB
v41-0006-XXX-fix-libcurl-link-error.patch application/octet-stream 1.1 KB
v41-0007-DO-NOT-MERGE-Add-pytest-suite-for-OAuth.patch application/octet-stream 207.0 KB

In response to

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Michail Nikolaev 2025-01-13 23:33:57 Re: Issue with markers in isolation tester? Or not?
Previous Message Sami Imseih 2025-01-13 23:17:11 Re: New GUC autovacuum_max_threshold ?