BUG #16775: Problem building with Kerberos (--with-gssapi) support on Windows
The following bug has been logged on the website:
Bug reference: 16775
Logged by: Uwe Benner
Email address: uwe.benner@posteo.de
PostgreSQL version: 12.5
Operating system: Windows 10
Description:
Hello there!
I am building postgres from source on Windows, because I need a 32bit
version, and wanted to have kerberos support a.k.a. `--with-gssapi`
activated.
When compiling, it complains about the line 493 in file
src/backend/be-secure-gssapi.c [0]https://git.postgresql.org/gitweb/?p=postgresql.git;a=blob;f=src/backend/libpq/be-secure-gssapi.c;h=5a73302b7b9ea65dc8a3d57d232d473ef54ce2c1;hb=HEAD#l493
```
493 setenv("KRB5_KTNAME", pg_krb_server_keyfile, 1);
```
which seams reasonable, since it seams to be the linux api call. Is it
supposed to be the linux api or does postgres itself define a setenv
function somewhere else?
Is it okay to fix it like this?
```
#ifndef WIN32
setenv("KRB5_KTNAME", pg_krb_server_keyfile, 1);
#else
SetEnvironmentVariable("KRB5_KTNAME", pg_krb_server_keyfile);
#endif
```
Or should `pg_setenv`[1]https://git.postgresql.org/gitweb/?p=postgresql.git;a=blob;f=src/bin/pg_upgrade/util.c;h=a16c794261b598326253f2665eaea9039724ac45;hb=HEAD#l246 or something like tat be called instead? `putenv`
would be another, more or less cross platform safe option, but it's
deprecated[2]https://docs.microsoft.com/en-us/cpp/c-runtime-library/reference/putenv?view=msvc-160 in Windows and `_putenv`/`_putenv_s` should be used instead.
And another thing, can you check if the call to `SetEnvironmentVariableA` in
the function `pg_setenv`[1]https://git.postgresql.org/gitweb/?p=postgresql.git;a=blob;f=src/bin/pg_upgrade/util.c;h=a16c794261b598326253f2665eaea9039724ac45;hb=HEAD#l246 is right? I think it's a typo and should call
`SetEnvironmentVariable`.
Thanks in advance
Uwe Benner
[0]: https://git.postgresql.org/gitweb/?p=postgresql.git;a=blob;f=src/backend/libpq/be-secure-gssapi.c;h=5a73302b7b9ea65dc8a3d57d232d473ef54ce2c1;hb=HEAD#l493
https://git.postgresql.org/gitweb/?p=postgresql.git;a=blob;f=src/backend/libpq/be-secure-gssapi.c;h=5a73302b7b9ea65dc8a3d57d232d473ef54ce2c1;hb=HEAD#l493
[1]: https://git.postgresql.org/gitweb/?p=postgresql.git;a=blob;f=src/bin/pg_upgrade/util.c;h=a16c794261b598326253f2665eaea9039724ac45;hb=HEAD#l246
https://git.postgresql.org/gitweb/?p=postgresql.git;a=blob;f=src/bin/pg_upgrade/util.c;h=a16c794261b598326253f2665eaea9039724ac45;hb=HEAD#l246
[2]: https://docs.microsoft.com/en-us/cpp/c-runtime-library/reference/putenv?view=msvc-160
https://docs.microsoft.com/en-us/cpp/c-runtime-library/reference/putenv?view=msvc-160
PG Bug reporting form <noreply@postgresql.org> writes:
I am building postgres from source on Windows, because I need a 32bit
version, and wanted to have kerberos support a.k.a. `--with-gssapi`
activated.
When compiling, it complains about the line 493 in file
src/backend/be-secure-gssapi.c [0]
493 setenv("KRB5_KTNAME", pg_krb_server_keyfile, 1);
Huh, is there suddenly some great groundswell of interest in
GSSAPI on Windows? Anywhere, see near-duplicate report from
earlier today:
/messages/by-id/16773-c0bb1bc300bde127@postgresql.org
and the earlier discussions that links to.
regards, tom lane
Am 14.12.2020 um 23:11 schrieb Tom Lane <tgl@sss.pgh.pa.us>:
PG Bug reporting form <noreply@postgresql.org> writes:
I am building postgres from source on Windows, because I need a 32bit
version, and wanted to have kerberos support a.k.a. `--with-gssapi`
activated.
When compiling, it complains about the line 493 in file
src/backend/be-secure-gssapi.c [0]
493 setenv("KRB5_KTNAME", pg_krb_server_keyfile, 1);Huh, is there suddenly some great groundswell of interest in
GSSAPI on Windows? Anywhere, see near-duplicate report from
earlier today:/messages/by-id/16773-c0bb1bc300bde127@postgresql.org
and the earlier discussions that links to.
regards, tom lane
Hah I don't think so.
Anyways thanks for the link!
Kind regards,
Uwe Benner