1
0
Fork 0
mirror of https://github.com/yarrick/iodine.git synced 2025-04-07 11:07:03 +00:00

Iodine: IPvIodine: IPv66

This commit is contained in:
Julian Kranz 2012-01-27 15:53:01 +01:00 committed by Barak A. Pearlmutter
parent b6fdf35444
commit 27d8481f9c
2 changed files with 39 additions and 7 deletions

View file

@ -186,9 +186,39 @@ client_set_nameserver(const char *cp, int port)
freeaddrinfo(result);
}
#endif
struct in_addr addr;
if (inet_aton(cp, &addr) != 1) {
struct in_addr addr;
struct in6_addr ipv6addr;
if(_v6_connect) {
struct addrinfo hints, *servinfo, *p;
int rv;
memset(&hints, 0, sizeof(struct addrinfo));
hints.ai_family = AF_INET6;
if ((rv = getaddrinfo(cp, NULL, &hints, &servinfo)) != 0) {
fprintf(stderr, "getaddrinfo: %s\n", gai_strerror(rv));
errx(1, "error resolving nameserver '%s'...", cp);
}
for(p = servinfo; p != NULL; p = p->ai_next) {
if(p->ai_family == AF_INET6)
break;
}
//Resolved ordns.he.net to Segmentation fault
if (p == NULL)
errx(1, "error resolving nameserver '%s'...", cp);
memcpy(&ipv6addr, &((struct sockaddr_in6*)p->ai_addr)->sin6_addr, sizeof(ipv6addr));
fprintf(stderr, "Resolved %s to ", cp);
ipv6_print(&ipv6addr, 0);
freeaddrinfo(servinfo);
} else if (inet_aton(cp, &addr) != 1) {
/* try resolving if a domain is given */
struct hostent *host;
const char *err;
@ -231,7 +261,8 @@ setaddr:
memset(&nameserv6, 0, sizeof(nameserv6));
nameserv6.sin6_family = AF_INET6;
nameserv6.sin6_port = htons(port);
inet_pton(AF_INET6, "2620:0:ccc::2", &(nameserv6.sin6_addr));
nameserv6.sin6_addr = ipv6addr;
//inet_pton(AF_INET6, "2620:0:ccc::2", &(nameserv6.sin6_addr));
}
void

View file

@ -315,6 +315,11 @@ main(int argc, char **argv)
/* NOTREACHED */
}
#ifdef LINUX
client_set_v6(v6);
client_set_v6_connect(v6_connect);
#endif
if (nameserv_addr) {
client_set_nameserver(nameserv_addr, DNS_PORT);
} else {
@ -339,10 +344,6 @@ main(int argc, char **argv)
client_set_lazymode(lazymode);
client_set_topdomain(topdomain);
client_set_hostname_maxlen(hostname_maxlen);
#ifdef LINUX
client_set_v6(v6);
client_set_v6_connect(v6_connect);
#endif
if (username != NULL) {
#ifndef WINDOWS32