summaryrefslogtreecommitdiff
path: root/cloudinit
diff options
context:
space:
mode:
authorJoshua Harlow <harlowja@yahoo-inc.com>2012-06-16 07:32:51 -0700
committerJoshua Harlow <harlowja@yahoo-inc.com>2012-06-16 07:32:51 -0700
commit1156f457d8832649145e23074e35e3bea36d5948 (patch)
treefe55d1d5708fc0608724e9e6486fbfec7b4983a4 /cloudinit
parent5c34aa4ec384c25056b76e71cae9afabd00f793b (diff)
downloadvyos-cloud-init-1156f457d8832649145e23074e35e3bea36d5948.tar.gz
vyos-cloud-init-1156f457d8832649145e23074e35e3bea36d5948.zip
1. Add in one function that will do output redirection from config for a given mode.
2. Adjust the usage of items() to iteritems() which will help translation to python 3.
Diffstat (limited to 'cloudinit')
-rw-r--r--cloudinit/util.py24
1 files changed, 19 insertions, 5 deletions
diff --git a/cloudinit/util.py b/cloudinit/util.py
index 1f884df8..15444fed 100644
--- a/cloudinit/util.py
+++ b/cloudinit/util.py
@@ -225,7 +225,7 @@ def read_conf(fname):
def clean_filename(fn):
- for (k, v) in FN_REPLACEMENTS.items():
+ for (k, v) in FN_REPLACEMENTS.iteritems():
fn = fn.replace(k, v)
return fn.strip()
@@ -344,6 +344,11 @@ def get_cfg_by_path(yobj, keyp, default=None):
return cur
+def fixup_output(cfg, mode):
+ (outfmt, errfmt) = get_output_cfg(cfg, mode)
+ redirect_output(outfmt, errfmt)
+
+
# redirect_output(outfmt, errfmt, orig_out, orig_err)
# replace orig_out and orig_err with filehandles specified in outfmt or errfmt
# fmt can be:
@@ -353,8 +358,14 @@ def get_cfg_by_path(yobj, keyp, default=None):
#
# with a '|', arguments are passed to shell, so one level of
# shell escape is required.
-def redirect_output(outfmt, errfmt, o_out=sys.stdout, o_err=sys.stderr):
+def redirect_output(outfmt, errfmt, o_out=None, o_err=None):
+ if not o_out:
+ o_out = sys.stdout
+ if not o_err:
+ o_err = sys.stderr
+
if outfmt:
+ LOG.debug("Redirecting %s to %s", o_out, outfmt)
(mode, arg) = outfmt.split(" ", 1)
if mode == ">" or mode == ">>":
owith = "ab"
@@ -365,15 +376,18 @@ def redirect_output(outfmt, errfmt, o_out=sys.stdout, o_err=sys.stderr):
proc = subprocess.Popen(arg, shell=True, stdin=subprocess.PIPE)
new_fp = proc.stdin
else:
- raise TypeError("Invalid type for outfmt: %s" % outfmt)
+ raise TypeError("Invalid type for output format: %s" % outfmt)
if o_out:
os.dup2(new_fp.fileno(), o_out.fileno())
+
if errfmt == outfmt:
+ LOG.debug("Redirecting %s to %s", o_err, outfmt)
os.dup2(new_fp.fileno(), o_err.fileno())
return
if errfmt:
+ LOG.debug("Redirecting %s to %s", o_err, errfmt)
(mode, arg) = errfmt.split(" ", 1)
if mode == ">" or mode == ">>":
owith = "ab"
@@ -384,7 +398,7 @@ def redirect_output(outfmt, errfmt, o_out=sys.stdout, o_err=sys.stderr):
proc = subprocess.Popen(arg, shell=True, stdin=subprocess.PIPE)
new_fp = proc.stdin
else:
- raise TypeError("Invalid type for errfmt: %s" % errfmt)
+ raise TypeError("Invalid type for error format: %s" % errfmt)
if o_err:
os.dup2(new_fp.fileno(), o_err.fileno())
@@ -912,7 +926,7 @@ def chownbyname(fname, user=None, group=None):
# output: "| logger -p"
# error: "> /dev/null"
# this returns the specific 'mode' entry, cleanly formatted, with value
-def get_output_cfg(cfg, mode="init"):
+def get_output_cfg(cfg, mode):
ret = [None, None]
if not cfg or not 'output' in cfg:
return ret