Merge pull request #65 from stal888/addr-resolve

Add DNS resolving to nTox
This commit is contained in:
irungentoo 2013-07-20 12:05:45 -07:00
commit fe7c7ed0dc
2 changed files with 33 additions and 1 deletions

View File

@ -35,6 +35,31 @@ unsigned char * hex_string_to_bin(char hex_string[])
return val; return val;
} }
int resolve_dnsaddr(char *address, char *port)
{
in_addr_t resolved = 0;
resolved = inet_addr(address);
if (resolved != -1)
{
return resolved;
}
struct addrinfo hints;
memset(&hints, 0, sizeof(hints));
hints.ai_family = AF_INET;
hints.ai_socktype = SOCK_STREAM;
struct addrinfo *server = NULL;
int success = getaddrinfo(address, port, &hints, &server);
if (success != 0) {
printf("failed to resolve %s: %s\n", address, gai_strerror(success));
return -1;
} else {
resolved = ((struct sockaddr_in*)server->ai_addr)->sin_addr.s_addr;
freeaddrinfo(server);
return resolved;
}
}
void line_eval(char lines[HISTORY][STRING_LENGTH], char *line) void line_eval(char lines[HISTORY][STRING_LENGTH], char *line)
{ {
if (line[0] == '/') { if (line[0] == '/') {
@ -245,7 +270,12 @@ int main(int argc, char *argv[])
strcpy(line, ""); strcpy(line, "");
IP_Port bootstrap_ip_port; IP_Port bootstrap_ip_port;
bootstrap_ip_port.port = htons(atoi(argv[2])); bootstrap_ip_port.port = htons(atoi(argv[2]));
bootstrap_ip_port.ip.i = inet_addr(argv[1]); int resolved_address = resolve_dnsaddr(argv[1], argv[2]);
if (resolved_address != -1) {
bootstrap_ip_port.ip.i = resolved_address;
} else {
exit(1);
}
DHT_bootstrap(bootstrap_ip_port, hex_string_to_bin(argv[3])); DHT_bootstrap(bootstrap_ip_port, hex_string_to_bin(argv[3]));
nodelay(stdscr, TRUE); nodelay(stdscr, TRUE);
while(true) { while(true) {

View File

@ -10,6 +10,8 @@
#include <sys/socket.h> #include <sys/socket.h>
#include <netinet/in.h> #include <netinet/in.h>
#include <arpa/inet.h> #include <arpa/inet.h>
#include <sys/types.h>
#include <netdb.h>
#include "../core/Messenger.h" #include "../core/Messenger.h"
#define STRING_LENGTH 256 #define STRING_LENGTH 256
#define HISTORY 50 #define HISTORY 50