[tor-commits] [chutney/master] Another python3 fix, about directory permissions made by os.makedirs
nickm at torproject.org
nickm at torproject.org
Mon Mar 11 00:33:44 UTC 2019
commit 49087abb2aba3c8acafd16287cc158f55d5ca6de
Author: Nick Mathewson <nickm at torproject.org>
Date: Thu Feb 28 12:52:56 2019 -0500
Another python3 fix, about directory permissions made by os.makedirs
In python3, os.makedir()'s mode argument doesn't affect any
directory created except the last one in the path.
---
lib/chutney/TorNet.py | 8 ++++++++
1 file changed, 8 insertions(+)
diff --git a/lib/chutney/TorNet.py b/lib/chutney/TorNet.py
index 82d50cf..ddcdc87 100644
--- a/lib/chutney/TorNet.py
+++ b/lib/chutney/TorNet.py
@@ -45,6 +45,10 @@ def mkdir_p(d, mode=448):
448 is the decimal representation of the octal number 0700. Since
python2 only supports 0700 and python3 only supports 0o700, we can use
neither.
+
+ Note that python2 and python3 differ in how they create the
+ permissions for the intermediate directories. In python3, 'mode'
+ only sets the mode for the last directory created.
"""
try:
os.makedirs(d, mode=mode)
@@ -485,6 +489,8 @@ class LocalNodeBuilder(NodeBuilder):
"""Create the data directory (with keys subdirectory) for this node.
"""
datadir = self._env['dir']
+ # We do this separately to make sure the permissions are correct.
+ mkdir_p(datadir)
mkdir_p(os.path.join(datadir, 'keys'))
def _makeHiddenServiceDir(self):
@@ -495,6 +501,8 @@ class LocalNodeBuilder(NodeBuilder):
path to the hidden service directory.
"""
datadir = self._env['dir']
+ # We do this separately to make sure the permissions are correct.
+ mkdir_p(datadir)
mkdir_p(os.path.join(datadir, self._env['hs_directory']))
def _genAuthorityKey(self):
More information about the tor-commits
mailing list