node: change get_or_create_config to strip whitespace and accept a filemode= argument
authorBrian Warner <warner@lothar.com>
Tue, 28 Aug 2007 02:23:50 +0000 (19:23 -0700)
committerBrian Warner <warner@lothar.com>
Tue, 28 Aug 2007 02:23:50 +0000 (19:23 -0700)
src/allmydata/node.py

index 40f48da2404c84800825f45dc294d1532a89b855..aec6a70f96a28fbab3938d5474068e2685138d5b 100644 (file)
@@ -78,7 +78,7 @@ class Node(service.MultiService):
                 return None
             raise
 
-    def get_or_create_config(self, name, default_fn, mode="w"):
+    def get_or_create_config(self, name, default_fn, mode="w", filemode=None):
         """Try to get the (string) contents of a config file, and return it.
         Any leading or trailing whitespace will be stripped from the data.
 
@@ -95,10 +95,15 @@ class Node(service.MultiService):
                 value = default_fn()
             fn = os.path.join(self.basedir, name)
             try:
-                open(fn, mode).write(value)
+                f = open(fn, mode)
+                f.write(value)
+                f.close()
+                if filemode is not None:
+                    os.chmod(fn, filemode)
             except EnvironmentError, e:
                 self.log("Unable to write config file '%s'" % fn)
                 self.log(e)
+            value = value.strip()
         return value
 
     def write_config(self, name, value, mode="w"):