diff options
author | Scott Moser <smoser@brickies.net> | 2016-08-22 17:00:50 -0400 |
---|---|---|
committer | Scott Moser <smoser@brickies.net> | 2016-08-22 17:00:50 -0400 |
commit | c0c45eba28e623751d71a7fa3cb27c87300b851e (patch) | |
tree | 67fbb66105b1b81fa92240c59543962d716087e3 /cloudinit/atomic_helper.py | |
parent | c13f800d19884a28c57745f692d1b5221c6c3a6c (diff) | |
parent | 40a2f621b05c11ed6397a1735b6bfff0ea07b097 (diff) | |
download | vyos-cloud-init-c0c45eba28e623751d71a7fa3cb27c87300b851e.tar.gz vyos-cloud-init-c0c45eba28e623751d71a7fa3cb27c87300b851e.zip |
merge from master at 0.7.7-17-g40a2f62
Diffstat (limited to 'cloudinit/atomic_helper.py')
-rw-r--r-- | cloudinit/atomic_helper.py | 20 |
1 files changed, 13 insertions, 7 deletions
diff --git a/cloudinit/atomic_helper.py b/cloudinit/atomic_helper.py index 15319f71..a3cfd942 100644 --- a/cloudinit/atomic_helper.py +++ b/cloudinit/atomic_helper.py @@ -5,21 +5,27 @@ import json import os import tempfile +_DEF_PERMS = 0o644 -def atomic_write_file(path, content, mode='w'): + +def write_file(filename, content, mode=_DEF_PERMS, omode="wb"): + # open filename in mode 'omode', write content, set permissions to 'mode' tf = None try: - tf = tempfile.NamedTemporaryFile(dir=os.path.dirname(path), - delete=False, mode=mode) + tf = tempfile.NamedTemporaryFile(dir=os.path.dirname(filename), + delete=False, mode=omode) tf.write(content) tf.close() - os.rename(tf.name, path) + os.chmod(tf.name, mode) + os.rename(tf.name, filename) except Exception as e: if tf is not None: os.unlink(tf.name) raise e -def atomic_write_json(path, data): - return atomic_write_file(path, json.dumps(data, indent=1, - sort_keys=True) + "\n") +def write_json(filename, data, mode=_DEF_PERMS): + # dump json representation of data to file filename. + return write_file( + filename, json.dumps(data, indent=1, sort_keys=True) + "\n", + omode="w", mode=mode) |