psql client does not handle WSAEWOULDBLOCK on Windows - Mailing list pgsql-hackers

From Ning
Subject psql client does not handle WSAEWOULDBLOCK on Windows
Date
Msg-id CAFGqpvg-pRw=cdsUpKYfwY6D3d-m9tw8WMcAEE7HHWfm-oYWvw@mail.gmail.com
Whole thread Raw
Responses Re: psql client does not handle WSAEWOULDBLOCK on Windows
Re: psql client does not handle WSAEWOULDBLOCK on Windows
List pgsql-hackers
Description:
The connection fails with a non-blocking socket error when using psql on
Windows to connect to a PostgreSQL server with GSSAPI enabled. The error is
because the socket error code is obtained by WSAGetLastError() instead of
errno. This causes the value of errno to be incorrect when handling a
non-blocking socket error.

Steps to Reproduce:
1. Compile PostgreSQL client (psql) on Windows.
a. Make sure MIT Kerberos is installed. I use the latest version MIT Kerberos
Version 4.1.
b. Make sure GSSAPI is enabled
2. Attempt to connect to a PostgreSQL server using psql.
a. Set up the Kerberos server and configure the PostgreSQL server by referring
to https://github.com/50wu/kerberos-docker/blob/main/POSTGRES.README.md
b. change the entry to hostgssenc on PostgreSQL server pg_hba.conf and restart
hostgssenc    all    all    0.0.0.0/0    gss    include_realm=0 krb_realm=GPDB.KRB
c. Use the following command to connect to the database server
psql -h <hostname> -U "postgres/krb5-service-example-com.example.com" -d postgres
3. The connection fails with a non-blocking socket error. The error is something like:
psql: error: connection to server at "xxx", port 5432 failed:

Environment:
PostgreSQL version: 16.3
Operating System: Windows 11

Fix Steps:
In the gss_read function of src/interfaces/libpq/fe-secure-gssapi.c, change the
check of the error code to use the SOCK_ERRNO to make sure that EAGAIN,
EWOULDBLOCK and EINTR can be properly handled on Windows and other platforms.

The patch file is attached to this email, please review and consider merging it to
the main code library.

Thanks,
Ning Wu
Attachment

pgsql-hackers by date:

Previous
From: Dilip Kumar
Date:
Subject: Re: Conflict detection and logging in logical replication
Next
From: Bertrand Drouvot
Date:
Subject: Re: Flush pgstats file during checkpoints