From 121a11d8e5096954e234b11abbb5d91c47a6b781 Mon Sep 17 00:00:00 2001 From: Mukund Sivaraman Date: Mon, 7 Feb 2011 18:00:39 +0530 Subject: [PATCH] Surround IPv6 literals with [] in Host: headers --- src/reqs.c | 24 ++++++++++++++++++------ 1 file changed, 18 insertions(+), 6 deletions(-) diff --git a/src/reqs.c b/src/reqs.c index 569f916..2de43a8 100644 --- a/src/reqs.c +++ b/src/reqs.c @@ -268,6 +268,7 @@ static int establish_http_connection (struct conn_s *connptr, struct request_s *request) { char portbuff[7]; + char dst[sizeof(struct in6_addr)]; /* Build a port string if it's not a standard port */ if (request->port != HTTP_PORT && request->port != HTTP_PORT_SSL) @@ -275,12 +276,23 @@ establish_http_connection (struct conn_s *connptr, struct request_s *request) else portbuff[0] = '\0'; - return write_message (connptr->server_fd, - "%s %s HTTP/1.0\r\n" - "Host: %s%s\r\n" - "Connection: close\r\n", - request->method, request->path, - request->host, portbuff); + if (inet_pton(AF_INET6, request->host, dst) > 0) { + /* host is an IPv6 address literal, so surround it with + * [] */ + return write_message (connptr->server_fd, + "%s %s HTTP/1.0\r\n" + "Host: [%s]%s\r\n" + "Connection: close\r\n", + request->method, request->path, + request->host, portbuff); + } else { + return write_message (connptr->server_fd, + "%s %s HTTP/1.0\r\n" + "Host: %s%s\r\n" + "Connection: close\r\n", + request->method, request->path, + request->host, portbuff); + } } /*