aboutsummaryrefslogtreecommitdiffstats
path: root/socket.c
diff options
context:
space:
mode:
authorEric S. Raymond <esr@thyrsus.com>1997-09-03 15:45:21 +0000
committerEric S. Raymond <esr@thyrsus.com>1997-09-03 15:45:21 +0000
commitf84776266d1d232ecf11f1cf57900a7abe000b54 (patch)
tree40fc99b36699bf052b6820277fc397e135b52eba /socket.c
parent3097034142b8a8b1d66b538cf8962d5affec962b (diff)
downloadfetchmail-f84776266d1d232ecf11f1cf57900a7abe000b54.tar.gz
fetchmail-f84776266d1d232ecf11f1cf57900a7abe000b54.tar.bz2
fetchmail-f84776266d1d232ecf11f1cf57900a7abe000b54.zip
Prevent buffer spamming.
svn path=/trunk/; revision=1279
Diffstat (limited to 'socket.c')
-rw-r--r--socket.c8
1 files changed, 7 insertions, 1 deletions
diff --git a/socket.c b/socket.c
index 7a30e3a8..5fe0683c 100644
--- a/socket.c
+++ b/socket.c
@@ -53,8 +53,14 @@ int SockOpen(char *host, int clientPort)
else
{
hp = gethostbyname(host);
- if (hp == NULL)
+
+ /*
+ * Add a check to make sure the address has a valid IPv4 or IPv6
+ * length. This prevents buffer spamming by a broken DNS.
+ */
+ if (hp == NULL || (hp->h_length != 4 && hp->h_length != 8))
return -1;
+
memcpy(&ad.sin_addr, hp->h_addr, hp->h_length);
}
ad.sin_port = htons(clientPort);