summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorPhilip Hazel <ph10@hermes.cam.ac.uk>2006-11-13 12:29:30 +0000
committerPhilip Hazel <ph10@hermes.cam.ac.uk>2006-11-13 12:29:30 +0000
commita401ddaade963ef861a77bf16a1876c5c43e7f92 (patch)
tree750cfef1e96e042bfbaaf85187f8bea2e069eb30 /src
parent194cc0e4ae3487900036c6bd208c0784d4e6e814 (diff)
Add timeout to connect() for Unix domain socket in ${readsocket.
Diffstat (limited to 'src')
-rw-r--r--src/src/expand.c15
1 files changed, 13 insertions, 2 deletions
diff --git a/src/src/expand.c b/src/src/expand.c
index d049466f1..234a33ff5 100644
--- a/src/src/expand.c
+++ b/src/src/expand.c
@@ -1,4 +1,4 @@
-/* $Cambridge: exim/src/src/expand.c,v 1.70 2006/11/13 12:07:46 ph10 Exp $ */
+/* $Cambridge: exim/src/src/expand.c,v 1.71 2006/11/13 12:29:30 ph10 Exp $ */
/*************************************************
* Exim - an Internet mail transport agent *
@@ -3914,6 +3914,7 @@ while (*s != 0)
else
{
+ int rc;
if ((fd = socket(PF_UNIX, SOCK_STREAM, 0)) == -1)
{
expand_string_message = string_sprintf("failed to create socket: %s",
@@ -3924,12 +3925,22 @@ while (*s != 0)
sockun.sun_family = AF_UNIX;
sprintf(sockun.sun_path, "%.*s", (int)(sizeof(sockun.sun_path)-1),
sub_arg[0]);
- if(connect(fd, (struct sockaddr *)(&sockun), sizeof(sockun)) == -1)
+
+ sigalrm_seen = FALSE;
+ alarm(timeout);
+ rc = connect(fd, (struct sockaddr *)(&sockun), sizeof(sockun));
+ alarm(0);
+ if (rc < 0)
{
expand_string_message = string_sprintf("failed to connect to socket "
"%s: %s", sub_arg[0], strerror(errno));
goto SOCK_FAIL;
}
+ if (sigalrm_seen)
+ {
+ expand_string_message = US "socket connect timed out";
+ goto SOCK_FAIL;
+ }
}
DEBUG(D_expand) debug_printf("connected to socket %s\n", sub_arg[0]);