]> git.meshlink.io Git - meshlink/blobdiff - src/net_setup.c
Use umask() to set file and UNIX socket permissions without race conditions.
[meshlink] / src / net_setup.c
index 334ea5d16886df2b97d5efa27abfd9441fd20680..0fedafa84b66b84bc532179fa6b2b04606b47d0a 100644 (file)
@@ -868,7 +868,12 @@ static bool setup_myself(void) {
 
        unlink(unixsocketname);
 
-       if(bind(unix_fd, (struct sockaddr *)&sa, sizeof sa) < 0) {
+       mode_t mask = umask(0);
+       umask(mask | 077);
+       int result = bind(unix_fd, (struct sockaddr *)&sa, sizeof sa);
+       umask(mask);
+
+       if(result < 0) {
                logger(DEBUG_ALWAYS, LOG_ERR, "Could not bind UNIX socket to %s: %s", unixsocketname, sockstrerror(errno));
                return false;
        }