forked from ungleich-public/cdist-contrib
[type/{__dma,__dma_auth,__mail_alias}] Quote things properly
This commit is contained in:
parent
7e20d13b9f
commit
0932c9ccde
4 changed files with 25 additions and 22 deletions
|
@ -18,7 +18,7 @@
|
||||||
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
|
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
function comment_line(line) {
|
function comment_line(line) {
|
||||||
# returns the position in line at which the comment'\''s text starts
|
# returns the position in line at which the comment's text starts
|
||||||
# (0 if the line is not a comment)
|
# (0 if the line is not a comment)
|
||||||
match(line, /^[ \t]*\#+[ \t]*/)
|
match(line, /^[ \t]*\#+[ \t]*/)
|
||||||
return RSTART ? (RLENGTH + 1) : 0
|
return RSTART ? (RLENGTH + 1) : 0
|
||||||
|
|
|
@ -18,7 +18,8 @@
|
||||||
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
|
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
|
||||||
#
|
#
|
||||||
|
|
||||||
drop_awk_comments() { sed '/^[[:blank:]]*#.*$/d;/^$/d' "$@"; }
|
quote() { printf "'%s'" "$(printf '%s' "$*" | sed -e "s/'/'\\\\''/g")"; }
|
||||||
|
drop_awk_comments() { quote "$(sed '/^[[:blank:]]*#.*$/d;/^$/d' "$@")"; }
|
||||||
|
|
||||||
CONF_PATH=/etc/dma # set in Makefile
|
CONF_PATH=/etc/dma # set in Makefile
|
||||||
|
|
||||||
|
@ -139,13 +140,13 @@ then
|
||||||
# options are grouped by word (the first word in the line) and appended
|
# options are grouped by word (the first word in the line) and appended
|
||||||
# at the end of the file.
|
# at the end of the file.
|
||||||
|
|
||||||
cat <<CODE
|
cat <<-CODE
|
||||||
awk '$(drop_awk_comments "${__type:?}/files/update_dma_conf.awk")' '${dma_conf}' '${dma_conf}' <<'EOF' >'${dma_conf}.tmp' \
|
awk $(drop_awk_comments "${__type:?}/files/update_dma_conf.awk") $(quote "${dma_conf}") $(quote "${dma_conf}") <<'EOF' >$(quote "${dma_conf}.tmp") \
|
||||||
&& cat '${dma_conf}.tmp' >'${dma_conf}'
|
&& cat $(quote "${dma_conf}.tmp") >$(quote "${dma_conf}")
|
||||||
${conf_should}
|
${conf_should}
|
||||||
EOF
|
EOF
|
||||||
rm '${dma_conf}.tmp'
|
rm $(quote "${dma_conf}.tmp")
|
||||||
CODE
|
CODE
|
||||||
|
|
||||||
config_updated=true
|
config_updated=true
|
||||||
echo 'config updated' >>"${__messages_out:?}"
|
echo 'config updated' >>"${__messages_out:?}"
|
||||||
|
|
|
@ -18,7 +18,8 @@
|
||||||
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
|
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
|
||||||
#
|
#
|
||||||
|
|
||||||
drop_awk_comments() { sed '/^[[:blank:]]*#.*$/d;/^$/d' "$@"; }
|
quote() { printf "'%s'" "$(printf '%s' "$*" | sed -e "s/'/'\\\\''/g")"; }
|
||||||
|
drop_awk_comments() { quote "$(sed '/^[[:blank:]]*#.*$/d;/^$/d' "$@")"; }
|
||||||
|
|
||||||
state_is=$(cat "${__object:?}/explorer/state")
|
state_is=$(cat "${__object:?}/explorer/state")
|
||||||
state_should=$(cat "${__object:?}/parameter/state")
|
state_should=$(cat "${__object:?}/parameter/state")
|
||||||
|
@ -63,9 +64,9 @@ esac
|
||||||
|
|
||||||
|
|
||||||
cat <<EOF
|
cat <<EOF
|
||||||
test -f "${auth_conf}" || touch "${auth_conf}"
|
test -f $(quote "${auth_conf}") || touch $(quote "${auth_conf}")
|
||||||
|
|
||||||
awk '$(drop_awk_comments "${__type:?}/files/update_dma_auth.awk")' <'${auth_conf}' >'${auth_conf}.tmp' \
|
awk $(drop_awk_comments "${__type:?}/files/update_dma_auth.awk") <$(quote "${auth_conf}") >$(quote "${auth_conf}.tmp") \
|
||||||
&& cat '${auth_conf}.tmp' >'${auth_conf}'
|
&& cat $(quote "${auth_conf}.tmp") >$(quote "${auth_conf}")
|
||||||
rm -f '${auth_conf}.tmp'
|
rm -f $(quote "${auth_conf}.tmp")
|
||||||
EOF
|
EOF
|
||||||
|
|
|
@ -18,7 +18,8 @@
|
||||||
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
|
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
|
||||||
#
|
#
|
||||||
|
|
||||||
drop_awk_comments() { sed '/^[[:blank:]]*#.*$/d;/^$/d' "$@"; }
|
quote() { printf "'%s'" "$(printf '%s' "$*" | sed -e "s/'/'\\\\''/g")"; }
|
||||||
|
drop_awk_comments() { quote "$(sed '/^[[:blank:]]*#.*$/d;/^$/d' "$@")"; }
|
||||||
|
|
||||||
aliases_file=$(cat "${__object:?}/explorer/aliases_file")
|
aliases_file=$(cat "${__object:?}/explorer/aliases_file")
|
||||||
|
|
||||||
|
@ -30,7 +31,7 @@ test -n "${aliases_file}" || {
|
||||||
|
|
||||||
state_should=$(cat "${__object:?}/parameter/state")
|
state_should=$(cat "${__object:?}/parameter/state")
|
||||||
|
|
||||||
case $state_should
|
case ${state_should}
|
||||||
in
|
in
|
||||||
(present)
|
(present)
|
||||||
if cmp -s "${__object:?}/explorer/aliases" "${__object:?}/parameter/alias"
|
if cmp -s "${__object:?}/explorer/aliases" "${__object:?}/parameter/alias"
|
||||||
|
@ -65,22 +66,22 @@ in
|
||||||
esac
|
esac
|
||||||
|
|
||||||
cat <<EOF
|
cat <<EOF
|
||||||
test -f '${aliases_file}' || touch '${aliases_file}'
|
test -f $(quote "${aliases_file}") || touch $(quote "${aliases_file}")
|
||||||
|
|
||||||
awk '$(drop_awk_comments "${__type:?}/files/update_aliases.awk")' <'${aliases_file}' >'${aliases_file}.tmp' \
|
awk $(drop_awk_comments "${__type:?}/files/update_aliases.awk") <$(quote "${aliases_file}") >$(quote "${aliases_file}.tmp") \
|
||||||
|| {
|
|| {
|
||||||
rm -f '${aliases_file}.tmp'
|
rm -f $(quote "${aliases_file}.tmp")
|
||||||
echo 'Generating new aliases file failed!' >&2
|
echo 'Generating new aliases file failed!' >&2
|
||||||
exit 1
|
exit 1
|
||||||
}
|
}
|
||||||
|
|
||||||
if ! cmp -s '${aliases_file}' '${aliases_file}.tmp'
|
if ! cmp -s $(quote "${aliases_file}") $(quote "${aliases_file}.tmp")
|
||||||
then
|
then
|
||||||
# aliases file was modified, replace:
|
# aliases file was modified, replace:
|
||||||
cat '${aliases_file}.tmp' >'${aliases_file}'
|
cat $(quote "${aliases_file}.tmp") >$(quote "${aliases_file}")
|
||||||
|
|
||||||
# then, run newaliases if present ("missing" on Alpine Linux because of typo)
|
# then, run newaliases if present ("missing" on Alpine Linux because of typo)
|
||||||
command -v newaliases >/dev/null 2>&1 && newaliases || true
|
command -v newaliases >/dev/null 2>&1 && newaliases || true
|
||||||
fi
|
fi
|
||||||
rm -f '${aliases_file}.tmp'
|
rm -f $(quote "${aliases_file}.tmp")
|
||||||
EOF
|
EOF
|
||||||
|
|
Loading…
Reference in a new issue