Re: encode/decode support for base64url

From: Florents Tselai <florents(dot)tselai(at)gmail(dot)com>
To: "Chao (Evan) Li" <li(dot)evan(dot)chao(at)gmail(dot)com>
Cc: Daniel Gustafsson <daniel(at)yesql(dot)se>, Masahiko Sawada <sawada(dot)mshk(at)gmail(dot)com>, "David E(dot) Wheeler" <david(at)justatheory(dot)com>, Aleksander Alekseev <aleksander(at)tigerdata(dot)com>, PostgreSQL Hackers <pgsql-hackers(at)postgresql(dot)org>, Cary Huang <cary(dot)huang(at)highgo(dot)ca>, Przemysław Sztoch <przemyslaw(at)sztoch(dot)pl>
Subject: Re: encode/decode support for base64url
Date: 2025-09-19 06:45:21
Message-ID: 3604BF95-0CD2-444A-B9F5-2117D7BE795A@gmail.com
Views: Whole Thread | Raw Message | Download mbox | Resend email
Thread:
Lists: pgsql-hackers

> On 19 Sep 2025, at 6:50 AM, Chao Li <li(dot)evan(dot)chao(at)gmail(dot)com> wrote:

Great to see you around Evan!

>
> I reviewed and tested this patch. Overall looks good to me. Actually, I think this patched fixed a bug of current implementation of base64 encoding by moving the logic of handling newline into “if (pos<0)”.

IIUC what you mean, I can’t confirm that.

Both existing and new implementation handle new lines the same

SELECT decode(E'QUFB\nQUFB', 'base64url');
decode
----------------
\x414141414141
(1 row)

>
> Just a few small comments:
>
>> On Sep 19, 2025, at 03:19, Daniel Gustafsson <daniel(at)yesql(dot)se> wrote:
>>
>> <v9-0001-Add-support-for-base64url-encoding-and-decoding.patch>
>
>
> 1.
> ```
> + * Helper for decoding base64 or base64url. When url is passed as true the
> + * input will be encoded using base64url. len bytes in src is encoded into
> + * dst.
> + */
> ```
>
> It’s not common to use two white-spaces after “.”, usually we need only one.

I agree with this

>
> 2.
> ```
> + /* handle remainder */
> if (pos != 2)
> ```
>
> The comment is understandable, but slightly vague: remainder of what?
>
> Maybe rephrase to “handle remaining bytes in buf”.

Agree too.

>
> 3.
> ```
> ereport(ERROR,
> (errcode(ERRCODE_INVALID_PARAMETER_VALUE),
> - errmsg("unexpected \"=\" while decoding base64 sequence")));
> + errmsg("unexpected \"=\" while decoding %s sequence", url ? "base64url" : "base64")));
> ```
>
> This is a normal usage that injects sub-strings based on condition. However, PG doesn’t like that, see here: https://www.postgresql.org/docs/devel/nls-programmer.html#NLS-GUIDELINES

Well, that’s a very interesting catch.
I’ll let a comitter confirm & advise.

In response to

Responses

Browse pgsql-hackers by date

  From Date Subject
Next Message Chao Li 2025-09-19 06:45:22 Fix jsonb_from_cstring parameter type for length
Previous Message Michael Paquier 2025-09-19 06:36:30 Re: [PATCH] Add tests for Bitmapset