From 51a24555e5e7af709caa8dab1a5e6c7e7f317b17 Mon Sep 17 00:00:00 2001 From: Scott Moser Date: Wed, 1 Mar 2017 12:12:15 -0500 Subject: tools/ds-identify: make report mode write namespaced results. Now, when ds-identify runs in report mode, it still writes to /run/cloud-init.cfg as search does, but it will namespace the result under the top level 'di_report' entry. --- tools/ds-identify | 25 ++++++++++++++----------- 1 file changed, 14 insertions(+), 11 deletions(-) diff --git a/tools/ds-identify b/tools/ds-identify index 9711a234..fd2a46c8 100755 --- a/tools/ds-identify +++ b/tools/ds-identify @@ -10,8 +10,9 @@ # default setting is: # search,found=all,maybe=all,notfound=disable # -# report: write config to /run/cloud-init/cloud.cfg.report (instead of -# /run/cloud-init/cloud.cfg, which effectively makes this dry-run). +# report: write config to /run/cloud-init/cloud.cfg, but +# namespaced under 'di_report'. Thus cloud-init can still see +# the result, but has no affect. # enable: do nothing # ds-identify writes no config and just exits success # the caller (cloud-init-generator) then enables cloud-init to run @@ -867,15 +868,16 @@ _print_info() { } write_result() { - local runcfg="${PATH_RUN_CI_CFG}" ret="" line="" - if [ "$DI_REPORT" = "true" ]; then - # if report is true, then we write to .report, but touch the other. - : > "$runcfg" - runcfg="$runcfg.report" - fi - for line in "$@"; do - echo "$line" - done > "$runcfg" + local runcfg="${PATH_RUN_CI_CFG}" ret="" line="" pre="" + { + if [ "$DI_REPORT" = "true" ]; then + echo "di_report:" + pre=" " + fi + for line in "$@"; do + echo "${pre}$line"; + done + } > "$runcfg" ret=$? [ $ret -eq 0 ] || { error "failed to write to ${runcfg}" @@ -956,6 +958,7 @@ _read_config() { if [ "$keyname" = "_unset" ]; then return 1 fi + _RET="" return 0 } -- cgit v1.2.3