mirror of
https://github.com/postgres/postgres.git
synced 2025-07-28 23:42:10 +03:00
Produce a more useful error message for over-length Unix socket paths.
The length of a socket path name is constrained by the size of struct sockaddr_un, and there's not a lot we can do about it since that is a kernel API. However, it would be a good thing if we produced an intelligible error message when the user specifies a socket path that's too long --- and getaddrinfo's standard API is too impoverished to do this in the natural way. So insert explicit tests at the places where we construct a socket path name. Now you'll get an error that makes sense and even tells you what the limit is, rather than something generic like "Non-recoverable failure in name resolution". Per trouble report from Jeremy Drake and a fix idea from Andrew Dunstan.
This commit is contained in:
@ -308,6 +308,14 @@ StreamServerPort(int family, char *hostName, unsigned short portNumber,
|
||||
* that file path
|
||||
*/
|
||||
UNIXSOCK_PATH(unixSocketPath, portNumber, unixSocketDir);
|
||||
if (strlen(unixSocketPath) >= UNIXSOCK_PATH_BUFLEN)
|
||||
{
|
||||
ereport(LOG,
|
||||
(errmsg("Unix-domain socket path \"%s\" is too long (maximum %d bytes)",
|
||||
unixSocketPath,
|
||||
(int) (UNIXSOCK_PATH_BUFLEN - 1))));
|
||||
return STATUS_ERROR;
|
||||
}
|
||||
if (Lock_AF_UNIX(unixSocketDir, unixSocketPath) != STATUS_OK)
|
||||
return STATUS_ERROR;
|
||||
service = unixSocketPath;
|
||||
|
Reference in New Issue
Block a user