From 737267cedca3b05bcb23ac6ab8d5a385b31db75b Mon Sep 17 00:00:00 2001 From: 1848 <> Date: Tue, 7 Aug 2018 22:01:13 +0200 Subject: [PATCH] Moved call to fchmod() on socket from OneServerSocket::Open() to socket_bind_listen() --- src/event/ServerSocket.cxx | 8 -------- src/net/SocketUtil.cxx | 10 ++++++++++ 2 files changed, 10 insertions(+), 8 deletions(-) diff --git a/src/event/ServerSocket.cxx b/src/event/ServerSocket.cxx index 12576d2a2..93e9e911f 100644 --- a/src/event/ServerSocket.cxx +++ b/src/event/ServerSocket.cxx @@ -39,7 +39,6 @@ #include #include -#include #include #include #include @@ -184,13 +183,6 @@ OneServerSocket::Open() SOCK_STREAM, 0, address, 5); -#ifdef HAVE_UN - /* allow everybody to connect */ - - if (!path.IsNull()) - fchmod(_fd.Get(), 0666); -#endif - /* register in the EventLoop */ SetFD(_fd.Release()); diff --git a/src/net/SocketUtil.cxx b/src/net/SocketUtil.cxx index 6882f8958..de2c25917 100644 --- a/src/net/SocketUtil.cxx +++ b/src/net/SocketUtil.cxx @@ -23,6 +23,8 @@ #include "SocketError.hxx" #include "UniqueSocketDescriptor.hxx" +#include + UniqueSocketDescriptor socket_bind_listen(int domain, int type, int protocol, SocketAddress address, @@ -32,6 +34,14 @@ socket_bind_listen(int domain, int type, int protocol, if (!fd.CreateNonBlock(domain, type, protocol)) throw MakeSocketError("Failed to create socket"); + +#ifdef HAVE_UN + if (domain == AF_UNIX) { + /* allow everybody to connect */ + fchmod(fd.Get(), 0666); + } +#endif + if (!fd.SetReuseAddress()) throw MakeSocketError("setsockopt() failed");