From 656e19351668cb5ada005d4e9e7e6d1f787990e2 Mon Sep 17 00:00:00 2001 From: brain Date: Thu, 2 Feb 2006 16:34:34 +0000 Subject: *UNTESTED DO NOT USE YET* - async dns for InspSocket as test - removing requirement on nss_dns.so.1 git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@3017 e03df62e-2008-0410-955e-edbf42e46eb7 --- src/dns.cpp | 14 ++++++++++ src/inspircd.cpp | 3 --- src/socket.cpp | 78 +++++++++++++++++++++++++++++++++++--------------------- 3 files changed, 63 insertions(+), 32 deletions(-) (limited to 'src') diff --git a/src/dns.cpp b/src/dns.cpp index f6bba28da..67c309f41 100644 --- a/src/dns.cpp +++ b/src/dns.cpp @@ -735,6 +735,20 @@ bool DNS::ForwardLookup(std::string host) return true; } +bool DNS::ForwardLookupWithFD(std::string host, int &fd) +{ + ServerInstance->stats->statsDns++; + this->myfd = dns_getip4(host.c_str()); + fd = this->myfd; + if (this->myfd == -1) + { + + } + log(DEBUG,"DNS: ForwardLookupWithFD, fd=%d",this->myfd); + ServerInstance->SE->AddFd(this->myfd,true,X_ESTAB_MODULE); + return true; +} + bool DNS::HasResult(int fd) { return (fd == this->myfd); diff --git a/src/inspircd.cpp b/src/inspircd.cpp index a3297f921..6f61fbb31 100644 --- a/src/inspircd.cpp +++ b/src/inspircd.cpp @@ -21,11 +21,9 @@ using namespace std; #include "inspircd_config.h" #include "inspircd.h" #include "inspircd_io.h" -#include #include #include #include -#include #include #include #ifdef GCC3 @@ -480,7 +478,6 @@ bool InspIRCd::LoadModule(const char* filename) { log(DEFAULT,"Unable to load %s: %s",modfile,factory[MODCOUNT+1]->LastError()); snprintf(MODERR,MAXBUF,"Loader/Linker error: %s",factory[MODCOUNT+1]->LastError()); - MODCOUNT--; return false; } if (factory[MODCOUNT+1]->factory) diff --git a/src/socket.cpp b/src/socket.cpp index 160f0f652..9c2f5a362 100644 --- a/src/socket.cpp +++ b/src/socket.cpp @@ -88,50 +88,67 @@ InspSocket::InspSocket(std::string host, int port, bool listening, unsigned long } } } else { - char* ip; this->host = host; - hostent* hoste = gethostbyname(host.c_str()); - if (!hoste) { - ip = (char*)host.c_str(); - } else { - struct in_addr* ia = (in_addr*)hoste->h_addr; - ip = inet_ntoa(*ia); + + if (this->dns.ForwardLookupWithFD(host,fd)) + { + timeout_end = time(NULL)+maxtime; + timeout = false; + this->state = I_RESOLVING; } + else + { + this->state = I_ERROR; + this->OnError(I_ERR_RESOLVE); + return; + } +} - this->IP = ip; +bool InspSocket::DoResolve() +{ + if (this->dns.HasResult()) + { + std::string res_ip = dns.GetResultIP(); + + if (res_ip != "") + { + this->IP = ip; + } + else + { + this->IP = this->host; + } - timeout_end = time(NULL)+maxtime; - timeout = false; - if ((this->fd = socket(AF_INET, SOCK_STREAM, 0)) == -1) + if ((this->fd = socket(AF_INET, SOCK_STREAM, 0)) == -1) { this->state = I_ERROR; this->OnError(I_ERR_SOCKET); - return; + return false; } this->port = port; - inet_aton(ip,&addy); - addr.sin_family = AF_INET; - addr.sin_addr = addy; - addr.sin_port = htons(this->port); + inet_aton(ip,&addy); + addr.sin_family = AF_INET; + addr.sin_addr = addy; + addr.sin_port = htons(this->port); - int flags; - flags = fcntl(this->fd, F_GETFL, 0); - fcntl(this->fd, F_SETFL, flags | O_NONBLOCK); + int flags; + flags = fcntl(this->fd, F_GETFL, 0); + fcntl(this->fd, F_SETFL, flags | O_NONBLOCK); - if(connect(this->fd, (sockaddr*)&this->addr,sizeof(this->addr)) == -1) - { - if (errno != EINPROGRESS) - { + if(connect(this->fd, (sockaddr*)&this->addr,sizeof(this->addr)) == -1) + { + if (errno != EINPROGRESS) + { this->Close(); this->OnError(I_ERR_CONNECT); this->state = I_ERROR; - return; - } - } - this->state = I_CONNECTING; + return false; + } + } + this->state = I_CONNECTING; ServerInstance->SE->AddFd(this->fd,false,X_ESTAB_MODULE); socket_ref[this->fd] = this; - return; + return true; } } @@ -203,7 +220,7 @@ void InspSocket::FlushWriteBuffer() bool InspSocket::Timeout(time_t current) { - if ((this->state == I_CONNECTING) && (current > timeout_end)) + if (((this->state == I_RESOLVING) || (this->state == I_CONNECTING)) && (current > timeout_end)) { // for non-listening sockets, the timeout can occur // which causes termination of the connection after @@ -226,6 +243,9 @@ bool InspSocket::Poll() switch (this->state) { + case I_RESOLVING: + return this->DoResolve(); + break; case I_CONNECTING: this->SetState(I_CONNECTED); /* Our socket was in write-state, so delete it and re-add it -- cgit v1.2.3