]> git.netwichtig.de Git - user/henk/code/inspircd.git/commitdiff
Move UNIX socket removal to ListenSocket ctor.
authorMatt Schatz <genius3000@g3k.solutions>
Thu, 1 Aug 2019 10:55:22 +0000 (04:55 -0600)
committerP. Powell <petpow@saberuk.com>
Thu, 1 Aug 2019 12:23:46 +0000 (13:23 +0100)
Doing the removal in BindPorts() would remove the socket
during a rehash and not recreate it. Now it's only removed
if it's about to be created.

src/listensocket.cpp
src/socket.cpp

index 811c6c8aca33ce496a6ceadf71a625d3596549ed..4805b77176e0f2f36c5d423017c2da713c620139 100644 (file)
@@ -29,6 +29,15 @@ ListenSocket::ListenSocket(ConfigTag* tag, const irc::sockets::sockaddrs& bind_t
        : bind_tag(tag)
        , bind_sa(bind_to)
 {
+       // Are we creating a UNIX socket?
+       if (bind_to.family() == AF_UNIX)
+       {
+               // Is 'replace' enabled?
+               const bool replace = tag->getBool("replace");
+               if (replace && irc::sockets::isunix(bind_to.str()))
+                       unlink(bind_to.str().c_str());
+       }
+
        fd = socket(bind_to.family(), SOCK_STREAM, 0);
 
        if (this->fd == -1)
index 26b5aeee3d7aca0a1f2c028d75f103a6a29eed6b..f19af36bb48a9728d2fd49c372e4cfd8c1129860 100644 (file)
@@ -118,10 +118,6 @@ int InspIRCd::BindPorts(FailedPortList& failed_ports)
                                continue;
                        }
 
-                       const bool replace = tag->getBool("replace");
-                       if (replace && irc::sockets::isunix(fullpath))
-                               remove(fullpath.c_str());
-
                        irc::sockets::untosa(fullpath, bindspec);
                        if (!BindPort(tag, bindspec, old_ports))
                                failed_ports.push_back(std::make_pair(bindspec, errno));