From: Tom Lane Date: Sun, 27 Sep 2009 03:43:10 +0000 (+0000) Subject: Make libpq reject non-numeric and out-of-range port numbers with a suitable X-Git-Tag: REL8_5_ALPHA2~59 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=61be11ff088c1e2b22c7e2af6f93ccdc286dba01;p=postgresql Make libpq reject non-numeric and out-of-range port numbers with a suitable error message, rather than blundering on and failing with something opaque. Sam Mason --- diff --git a/src/interfaces/libpq/fe-connect.c b/src/interfaces/libpq/fe-connect.c index 41c753a4f8..1be948505e 100644 --- a/src/interfaces/libpq/fe-connect.c +++ b/src/interfaces/libpq/fe-connect.c @@ -8,7 +8,7 @@ * * * IDENTIFICATION - * $PostgreSQL: pgsql/src/interfaces/libpq/fe-connect.c,v 1.376 2009/07/24 17:58:31 tgl Exp $ + * $PostgreSQL: pgsql/src/interfaces/libpq/fe-connect.c,v 1.377 2009/09/27 03:43:10 tgl Exp $ * *------------------------------------------------------------------------- */ @@ -817,7 +817,16 @@ connectDBStart(PGconn *conn) /* Set up port number as a string */ if (conn->pgport != NULL && conn->pgport[0] != '\0') + { portnum = atoi(conn->pgport); + if (portnum < 1 || portnum > 65535) + { + appendPQExpBuffer(&conn->errorMessage, + libpq_gettext("invalid port number: \"%s\"\n"), + conn->pgport); + goto connect_errReturn; + } + } else portnum = DEF_PGPORT; snprintf(portstr, sizeof(portstr), "%d", portnum);