Don't let libpq PGEVT_CONNRESET callbacks break a PGconn.
authorTom Lane <tgl@sss.pgh.pa.us>
Fri, 18 Feb 2022 16:43:04 +0000 (11:43 -0500)
committerTom Lane <tgl@sss.pgh.pa.us>
Fri, 18 Feb 2022 16:43:04 +0000 (11:43 -0500)
commit2e372869aa38a9d6e4552c192da4454b17e01e38
tree06260ae8cfe7281c7b0d158069ca773ca3d7439c
parentce1e7a2f716919652c280937087b24937677f8b3
Don't let libpq PGEVT_CONNRESET callbacks break a PGconn.

As currently implemented, failure of a PGEVT_CONNRESET callback
forces the PGconn into the CONNECTION_BAD state (without closing
the socket, which is inconsistent with other failure paths), and
prevents later callbacks from being called.  This seems highly
questionable, and indeed is questioned by comments in the source.

Instead, let's just ignore the result value of PGEVT_CONNRESET
calls.  Like the preceding commit, this converts event callbacks
into "pure observers" that cannot affect libpq's processing logic.

Discussion: https://postgr.es/m/3185105.1644960083@sss.pgh.pa.us
doc/src/sgml/libpq.sgml
src/interfaces/libpq/fe-connect.c