Support addresses with ':' in git-daemon

If host address could have ':' in it (e.g. numeric IPv6 address), then
host and port could not be uniquely parsed. Fix this by parsing the
"["<host>"]":<port> and "["<host>"]" notations. Currently the built-in
git:// client would send <host>:<port> or <host> for such thing, but
it doesn't matter as due to bugs, resolving address fails if <host>
contains ':'.

Signed-off-by: Ilari Liusvaara <ilari.liusvaara@elisanet.fi>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
maint
Ilari Liusvaara 2010-01-26 20:24:41 +02:00 committed by Junio C Hamano
parent 35eabd1579
commit e8dbd76d57
1 changed files with 30 additions and 4 deletions

View File

@ -445,6 +445,33 @@ static char *xstrdup_tolower(const char *str)
return dup;
}

static void parse_host_and_port(char *hostport, char **host,
char **port)
{
if (*hostport == '[') {
char *end;

end = strchr(hostport, ']');
if (!end)
die("Invalid reqeuest ('[' without ']')");
*end = '\0';
*host = hostport + 1;
if (!end[1])
*port = NULL;
else if (end[1] == ':')
*port = end + 2;
else
die("Garbage after end of host part");
} else {
*host = hostport;
*port = strrchr(hostport, ':');
if (*port) {
*port = '\0';
++*port;
}
}
}

/*
* Read the host as supplied by the client connection.
*/
@ -461,11 +488,10 @@ static void parse_host_arg(char *extra_args, int buflen)
vallen = strlen(val) + 1;
if (*val) {
/* Split <host>:<port> at colon. */
char *host = val;
char *port = strrchr(host, ':');
char *host;
char *port;
parse_host_and_port(val, &host, &port);
if (port) {
*port = 0;
port++;
free(tcp_port);
tcp_port = xstrdup(port);
}