Explorar o código

Explicitly chmod AF_UNIX sockets to 0600 when *GroupWritable isn't specified

Andrea Shepard %!s(int64=10) %!d(string=hai) anos
pai
achega
066acaf6b9
Modificáronse 1 ficheiros con 10 adicións e 0 borrados
  1. 10 0
      src/or/connection.c

+ 10 - 0
src/or/connection.c

@@ -1244,6 +1244,16 @@ connection_listener_new(const struct sockaddr *listensockaddr,
         log_warn(LD_FS,"Unable to make %s group-writable.", address);
         goto err;
       }
+    } else if ((type == CONN_TYPE_CONTROL_LISTENER &&
+                !(options->ControlSocketsGroupWritable)) ||
+               (type == CONN_TYPE_AP_LISTENER &&
+                !(options->SocksSocketsGroupWritable))) {
+      /* We need to use chmod; fchmod doesn't work on sockets on all
+       * platforms. */
+      if (chmod(address, 0600) < 0) {
+        log_warn(LD_FS,"Unable to make %s group-writable.", address);
+        goto err;
+      }
     }
 
     if (listen(s, SOMAXCONN) < 0) {