2020-05-29 15:33:40 +00:00
|
|
|
#!/bin/sh -e
|
|
|
|
#
|
|
|
|
# 2020 Dennis Camera (dennis.camera@ssrq-sds-fds.ch)
|
|
|
|
#
|
|
|
|
# This file is part of cdist.
|
|
|
|
#
|
|
|
|
# cdist is free software: you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
# cdist is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
#
|
|
|
|
|
2020-09-28 14:43:31 +00:00
|
|
|
drop_awk_comments() { sed '/^[[:blank:]]*#.*$/d;/^$/d' "$@"; }
|
|
|
|
|
2020-09-28 15:37:41 +00:00
|
|
|
state_is=$(cat "${__object:?}/explorer/state")
|
|
|
|
state_should=$(cat "${__object:?}/parameter/state")
|
2020-05-30 16:27:13 +00:00
|
|
|
|
2020-09-28 15:37:41 +00:00
|
|
|
server=${__object_id:?}
|
|
|
|
login=$(cat "${__object:?}/parameter/login")
|
2020-05-30 16:27:13 +00:00
|
|
|
|
2020-09-28 08:59:13 +00:00
|
|
|
|
2020-09-28 15:37:41 +00:00
|
|
|
auth_conf=$(cat "${__object:?}/explorer/auth_conf")
|
2020-09-28 08:59:13 +00:00
|
|
|
test -n "${auth_conf}" || {
|
|
|
|
echo 'Cannot determine path of dma auth.conf' >&2
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
|
2020-06-09 18:53:01 +00:00
|
|
|
if test "${state_is}" = "${state_should}"
|
|
|
|
then
|
|
|
|
# state is as it should
|
|
|
|
exit 0
|
|
|
|
fi
|
|
|
|
|
2020-05-30 16:27:13 +00:00
|
|
|
case $state_should
|
|
|
|
in
|
|
|
|
(present)
|
2020-06-01 17:20:05 +00:00
|
|
|
test -n "${login}" || { echo '--login must be non-empty' >&2; exit 1; }
|
2020-05-31 13:01:40 +00:00
|
|
|
|
2020-06-09 18:53:01 +00:00
|
|
|
if test "${state_is}" = 'absent'
|
2020-05-31 13:18:11 +00:00
|
|
|
then
|
2020-09-28 15:37:41 +00:00
|
|
|
printf 'add authuser %s on %s\n' "${login}" "${server}" >>"${__messages_out:?}"
|
2020-06-09 18:53:01 +00:00
|
|
|
else
|
2020-09-28 15:37:41 +00:00
|
|
|
printf 'set authuser %s on %s\n' "${login}" "${server}" >>"${__messages_out:?}"
|
2020-05-31 13:18:11 +00:00
|
|
|
fi
|
|
|
|
;;
|
2020-05-30 16:27:13 +00:00
|
|
|
(absent)
|
2020-09-28 15:37:41 +00:00
|
|
|
printf 'delete authuser %s on %s\n' "${login}" "${server}" >>"${__messages_out:?}"
|
2020-05-30 16:27:13 +00:00
|
|
|
;;
|
|
|
|
(*)
|
2020-06-11 13:38:34 +00:00
|
|
|
printf 'Invalid --state: %s.\n' "${state_should}" >&2
|
|
|
|
printf 'Acceptable values are: present, absent.\n' >&2
|
2020-05-30 16:27:13 +00:00
|
|
|
exit 1
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
|
2020-05-31 13:01:40 +00:00
|
|
|
|
2020-05-30 16:27:13 +00:00
|
|
|
cat <<EOF
|
2020-05-31 13:01:40 +00:00
|
|
|
test -f "${auth_conf}" || touch "${auth_conf}"
|
|
|
|
|
2020-09-28 15:37:41 +00:00
|
|
|
awk '$(drop_awk_comments "${__type:?}/files/update_dma_auth.awk")' <'${auth_conf}' >'${auth_conf}.tmp' \
|
2020-09-28 14:43:31 +00:00
|
|
|
&& cat '${auth_conf}.tmp' >'${auth_conf}'
|
|
|
|
rm -f '${auth_conf}.tmp'
|
2020-05-30 16:27:13 +00:00
|
|
|
EOF
|