- insp_inaddr n;
- ConfigReader Conf;
-
- log(DEBUG,"In InspSocket::BindAddr()");
- for (int j =0; j < Conf.Enumerate("bind"); j++)
- {
- std::string Type = Conf.ReadValue("bind","type",j);
- std::string IP = Conf.ReadValue("bind","address",j);
- if (Type == "servers")
- {
- if ((IP != "*") && (IP != "127.0.0.1") && (IP != ""))
- {
- insp_sockaddr s;
- char resolved_addr[MAXBUF];
-
- if (insp_aton(IP.c_str(),&n) < 1)
- {
- /* If they gave a hostname, bind to the IP it resolves to */
- log(DEBUG,"Resolving host %s",IP.c_str());
- if (CleanAndResolve(resolved_addr, IP.c_str(), true, 1))
- {
- log(DEBUG,"Resolved host %s to %s",IP.c_str(),resolved_addr);
- IP = resolved_addr;
- }
- }
-
- if (insp_aton(IP.c_str(),&n) > 0)
- {
- log(DEBUG,"Found an IP to bind to: %s",IP.c_str());
-#ifdef IPV6
- s.sin6_addr = n;
- s.sin6_family = AF_FAMILY;
-#else
- s.sin_addr = n;
- s.sin_family = AF_FAMILY;
-#endif
- if (bind(this->fd,(struct sockaddr*)&s,sizeof(s)) < 0)
- {
- log(DEBUG,"Cant bind()");
- this->state = I_ERROR;
- this->OnError(I_ERR_BIND);
- this->fd = -1;
- return false;
- }
- log(DEBUG,"bind() reports outbound fd bound to ip %s",IP.c_str());
- return true;
- }
- else
- {
- log(DEBUG,"Address '%s' was not an IP address",IP.c_str());
- }
- }
- }
- }
- log(DEBUG,"Found no suitable IPs to bind, binding INADDR_ANY");