From 49369545e34e9d16d53c6c62eb8659a590af62ed Mon Sep 17 00:00:00 2001 From: brain Date: Mon, 5 Feb 2007 23:43:44 +0000 Subject: Stuff to make dns work protocol-independent git-svn-id: http://svn.inspircd.org/repository/trunk/inspircd@6506 e03df62e-2008-0410-955e-edbf42e46eb7 --- src/socket.cpp | 28 +++++++++++++++++----------- 1 file changed, 17 insertions(+), 11 deletions(-) (limited to 'src/socket.cpp') diff --git a/src/socket.cpp b/src/socket.cpp index 111299b09..a32a7f98e 100644 --- a/src/socket.cpp +++ b/src/socket.cpp @@ -40,7 +40,7 @@ ListenSocket::ListenSocket(InspIRCd* Instance, int sockfd, insp_sockaddr client, { this->SetFd(sockfd); Instance->Log(DEBUG,"CRAP"); - if (!Instance->BindSocket(this->fd,client,server,port,addr)) + if (!Instance->BindSocket(this->fd,port,addr)) this->fd = -1; #ifdef IPV6 if ((!*addr) || (strchr(addr,':'))) @@ -312,7 +312,7 @@ void irc::sockets::NonBlocking(int s) * It can only bind to IP addresses, if you wish to bind to hostnames * you should first resolve them using class 'Resolver'. */ -bool InspIRCd::BindSocket(int sockfd, insp_sockaddr clientn, insp_sockaddr servern, int port, char* addr) +bool InspIRCd::BindSocket(int sockfd, int port, char* addr, bool dolisten) { /* We allocate 2 of these, because sockaddr_in6 is larger than sockaddr (ugh, hax) */ sockaddr* server = new sockaddr[2]; @@ -404,22 +404,28 @@ bool InspIRCd::BindSocket(int sockfd, insp_sockaddr clientn, insp_sockaddr serve } else { - if (listen(sockfd, Config->MaxConn) == -1) + if (dolisten) { - this->Log(DEFAULT,"ERROR in listen(): %s",strerror(errno)); - return false; + if (listen(sockfd, Config->MaxConn) == -1) + { + this->Log(DEFAULT,"ERROR in listen(): %s",strerror(errno)); + return false; + } + else + { + NonBlocking(sockfd); + return true; + } } else { - NonBlocking(sockfd); return true; } } } - // Open a TCP Socket -int irc::sockets::OpenTCPSocket(char* addr) +int irc::sockets::OpenTCPSocket(char* addr, int socktype) { int sockfd; int on = 1; @@ -429,16 +435,16 @@ int irc::sockets::OpenTCPSocket(char* addr) if (strchr(addr,':') || (!*addr)) { printf("IPV6 OPENTCPSOCKET DO\n"); - sockfd = socket (PF_INET6, SOCK_STREAM, 0); + sockfd = socket (PF_INET6, socktype, 0); } else { printf("IPV6->IPV4 OPENTCPSOCKET DO\n"); - sockfd = socket (PF_INET, SOCK_STREAM, 0); + sockfd = socket (PF_INET, socktype, 0); } if (sockfd < 0) #else - if ((sockfd = socket (PF_INET, SOCK_STREAM, 0)) < 0) + if ((sockfd = socket (PF_INET, socktype, 0)) < 0) #endif { printf("SOCKET FAIL: %s\n", strerror(errno)); -- cgit v1.2.3