Compare commits
2 commits
master
...
feature/sh
Author | SHA1 | Date | |
---|---|---|---|
|
c88e6acc77 | ||
|
bcdfc0eaa3 |
80 changed files with 160 additions and 1557 deletions
|
@ -1,6 +1,7 @@
|
||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
#
|
#
|
||||||
# 2019 Dennis Camera (dennis.camera at ssrq-sds-fds.ch)
|
# 2010-2014 Nico Schottelius (nico-cdist at schottelius.org)
|
||||||
|
# 2012 Steven Armstrong (steven-cdist at armstrong.cc)
|
||||||
#
|
#
|
||||||
# This file is part of cdist.
|
# This file is part of cdist.
|
||||||
#
|
#
|
||||||
|
@ -18,12 +19,7 @@
|
||||||
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
|
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
|
||||||
#
|
#
|
||||||
#
|
#
|
||||||
# Retrieve the running hostname
|
|
||||||
#
|
|
||||||
|
|
||||||
if command -v hostname >/dev/null
|
if command -v uname >/dev/null; then
|
||||||
then
|
uname -n
|
||||||
hostname
|
|
||||||
else
|
|
||||||
uname -n
|
|
||||||
fi
|
fi
|
||||||
|
|
16
cdist/conf/lib/errors.sh
Normal file
16
cdist/conf/lib/errors.sh
Normal file
|
@ -0,0 +1,16 @@
|
||||||
|
__cdist_unsupported_os() {
|
||||||
|
if [ $# -gt 0 ]
|
||||||
|
then
|
||||||
|
os=$1
|
||||||
|
shift
|
||||||
|
else
|
||||||
|
os=$(cat "$__explorer/os")
|
||||||
|
fi
|
||||||
|
printf "Your operating system \"%s\" is currently not supported.\nPlease contribute an implementation for it if you can.\n" "${os}" >&2
|
||||||
|
exit 1
|
||||||
|
}
|
||||||
|
|
||||||
|
__cdist_error() {
|
||||||
|
printf "$@" >&2
|
||||||
|
exit 1
|
||||||
|
}
|
|
@ -61,29 +61,31 @@ EOF
|
||||||
echo "curl -s -L '$uri' | apt-key add -"
|
echo "curl -s -L '$uri' | apt-key add -"
|
||||||
fi
|
fi
|
||||||
elif [ -d "$keydir" ]; then
|
elif [ -d "$keydir" ]; then
|
||||||
|
tmp='/tmp/cdist_apt_key_tmp'
|
||||||
|
|
||||||
# we need to kill gpg after 30 seconds, because gpg
|
# we need to kill gpg after 30 seconds, because gpg
|
||||||
# can get stuck if keyserver is not responding.
|
# can get stuck if keyserver is not responding.
|
||||||
# exporting env var and not exit 1,
|
# exporting env var and not exit 1,
|
||||||
# because we need to clean up and kill dirmngr.
|
# because we need to clean up and kill dirmngr.
|
||||||
cat << EOF
|
cat << EOF
|
||||||
|
|
||||||
gpgtmphome="\$( mktemp -d )"
|
mkdir -m 700 -p "$tmp"
|
||||||
|
|
||||||
if timeout 30s \\
|
if timeout 30s \\
|
||||||
gpg --homedir "\$gpgtmphome" \\
|
gpg --homedir "$tmp" \\
|
||||||
--keyserver "$keyserver" \\
|
--keyserver "$keyserver" \\
|
||||||
--recv-keys "$keyid"
|
--recv-keys "$keyid"
|
||||||
then
|
then
|
||||||
gpg --homedir "\$gpgtmphome" \\
|
gpg --homedir "$tmp" \\
|
||||||
--export "$keyid" \\
|
--export "$keyid" \\
|
||||||
> "$keyfile"
|
> "$keyfile"
|
||||||
else
|
else
|
||||||
export GPG_GOT_STUCK=1
|
export GPG_GOT_STUCK=1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
GNUPGHOME="\$gpgtmphome" gpgconf --kill dirmngr
|
GNUPGHOME="$tmp" gpgconf --kill dirmngr
|
||||||
|
|
||||||
rm -rf "\$gpgtmphome"
|
rm -rf "$tmp"
|
||||||
|
|
||||||
if [ -n "\$GPG_GOT_STUCK" ]
|
if [ -n "\$GPG_GOT_STUCK" ]
|
||||||
then
|
then
|
||||||
|
|
|
@ -35,8 +35,7 @@ owner=$(cat "$__object/parameter/owner")
|
||||||
group=$(cat "$__object/parameter/group")
|
group=$(cat "$__object/parameter/group")
|
||||||
mode=$(cat "$__object/parameter/mode")
|
mode=$(cat "$__object/parameter/mode")
|
||||||
|
|
||||||
[ -f "$__object/parameter/recursive" ] && recursive='--recurse-submodules' || recursive=''
|
[ -f "$__object/parameter/recursive" ] && recursive='--recursive' || recursive=''
|
||||||
[ -f "$__object/parameter/shallow" ] && shallow='--depth 1 --shallow-submodules' || shallow=''
|
|
||||||
|
|
||||||
[ "$state_should" = "$state_is" ] \
|
[ "$state_should" = "$state_is" ] \
|
||||||
&& [ "$owner" = "$owner_is" ] \
|
&& [ "$owner" = "$owner_is" ] \
|
||||||
|
@ -46,7 +45,7 @@ mode=$(cat "$__object/parameter/mode")
|
||||||
case $state_should in
|
case $state_should in
|
||||||
present)
|
present)
|
||||||
if [ "$state_should" != "$state_is" ]; then
|
if [ "$state_should" != "$state_is" ]; then
|
||||||
echo git clone --quiet "$recursive" "$shallow" --branch "$branch" "$source" "$destination"
|
echo git clone --quiet "$recursive" --branch "$branch" "$source" "$destination"
|
||||||
fi
|
fi
|
||||||
if { [ -n "$owner" ] && [ "$owner_is" != "$owner" ]; } || \
|
if { [ -n "$owner" ] && [ "$owner_is" != "$owner" ]; } || \
|
||||||
{ [ -n "$group" ] && [ "$group_is" != "$group" ]; }; then
|
{ [ -n "$group" ] && [ "$group_is" != "$group" ]; }; then
|
||||||
|
|
|
@ -36,11 +36,7 @@ owner
|
||||||
User to chown to.
|
User to chown to.
|
||||||
|
|
||||||
recursive
|
recursive
|
||||||
Passes the --recurse-submodules flag to git when cloning the repository.
|
Passes the --recursive flag to git when cloning the repository.
|
||||||
|
|
||||||
shallow
|
|
||||||
Sets --depth=1 and --shallow-submodules for cloning repositories with big history.
|
|
||||||
|
|
||||||
|
|
||||||
EXAMPLES
|
EXAMPLES
|
||||||
--------
|
--------
|
||||||
|
|
|
@ -1,2 +1 @@
|
||||||
recursive
|
recursive
|
||||||
shallow
|
|
||||||
|
|
|
@ -15,10 +15,6 @@ case $os in
|
||||||
# Differntation not needed anymore
|
# Differntation not needed anymore
|
||||||
apt_source_distribution=stable
|
apt_source_distribution=stable
|
||||||
;;
|
;;
|
||||||
10*)
|
|
||||||
# Differntation not needed anymore
|
|
||||||
apt_source_distribution=stable
|
|
||||||
;;
|
|
||||||
*)
|
*)
|
||||||
echo "Don't know how to install Grafana on $os $os_version. Send us a pull request!" >&2
|
echo "Don't know how to install Grafana on $os $os_version. Send us a pull request!" >&2
|
||||||
exit 1
|
exit 1
|
||||||
|
@ -33,9 +29,10 @@ case $os in
|
||||||
--uri https://packages.grafana.com/oss/deb \
|
--uri https://packages.grafana.com/oss/deb \
|
||||||
--distribution $apt_source_distribution \
|
--distribution $apt_source_distribution \
|
||||||
--component main
|
--component main
|
||||||
|
|
||||||
__package apt-transport-https
|
__package apt-transport-https
|
||||||
require="$require __apt_source/grafana" __apt_update_index
|
|
||||||
require="$require __package/apt-transport-https __apt_update_index" __package grafana
|
require="$require __apt_source/grafana __package/apt-transport-https" __package grafana
|
||||||
require="$require __package/grafana" __start_on_boot grafana-server
|
require="$require __package/grafana" __start_on_boot grafana-server
|
||||||
require="$require __start_on_boot/grafana-server" __process grafana-server --start "service grafana-server start"
|
require="$require __start_on_boot/grafana-server" __process grafana-server --start "service grafana-server start"
|
||||||
;;
|
;;
|
||||||
|
|
|
@ -23,7 +23,7 @@
|
||||||
#
|
#
|
||||||
|
|
||||||
not_supported() {
|
not_supported() {
|
||||||
echo "Your operating system ($("$__explorer/os")) is currently not supported." >&2
|
echo "Your operating system ($(cat "$__explorer/os")) is currently not supported." >&2
|
||||||
echo "Cannot extract group information." >&2
|
echo "Cannot extract group information." >&2
|
||||||
echo "Please contribute an implementation for it if you can." >&2
|
echo "Please contribute an implementation for it if you can." >&2
|
||||||
exit 1
|
exit 1
|
||||||
|
|
|
@ -23,7 +23,7 @@
|
||||||
#
|
#
|
||||||
|
|
||||||
name=$__object_id
|
name=$__object_id
|
||||||
os=$("$__explorer/os")
|
os=$(cat "$__explorer/os")
|
||||||
|
|
||||||
not_supported() {
|
not_supported() {
|
||||||
echo "Your operating system ($os) is currently not supported." >&2
|
echo "Your operating system ($os) is currently not supported." >&2
|
||||||
|
|
|
@ -21,4 +21,4 @@
|
||||||
# Check whether system has hostnamectl
|
# Check whether system has hostnamectl
|
||||||
#
|
#
|
||||||
|
|
||||||
command -v hostnamectl 2>/dev/null || true
|
command -v hostnamectl || true
|
||||||
|
|
18
cdist/conf/type/__podman_compose/gencode-remote → cdist/conf/type/__hostname/explorer/hostname_file
Normal file → Executable file
18
cdist/conf/type/__podman_compose/gencode-remote → cdist/conf/type/__hostname/explorer/hostname_file
Normal file → Executable file
|
@ -1,6 +1,6 @@
|
||||||
#!/bin/sh -e
|
#!/bin/sh
|
||||||
#
|
#
|
||||||
# 2019 Daniel Tschada
|
# 2014 Nico Schottelius (nico-cdist at schottelius.org)
|
||||||
#
|
#
|
||||||
# This file is part of cdist.
|
# This file is part of cdist.
|
||||||
#
|
#
|
||||||
|
@ -17,8 +17,14 @@
|
||||||
# You should have received a copy of the GNU General Public License
|
# You should have received a copy of the GNU General Public License
|
||||||
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
|
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
|
||||||
#
|
#
|
||||||
|
#
|
||||||
|
# Retrieve the contents of /etc/hostname
|
||||||
|
#
|
||||||
|
|
||||||
install="$(cat "$__object/parameter/install")"
|
# Almost any distribution
|
||||||
state="$(cat "$__object/parameter/state")"
|
if [ -f /etc/hostname ]; then
|
||||||
user="$(cat "$__object/parameter/user")"
|
cat /etc/hostname
|
||||||
version="$(cat "$__object/parameter/version")"
|
# SuSE
|
||||||
|
elif [ -f /etc/HOSTNAME ]; then
|
||||||
|
cat /etc/HOSTNAME
|
||||||
|
fi
|
|
@ -1,6 +1,6 @@
|
||||||
#!/bin/sh -e
|
#!/bin/sh
|
||||||
#
|
#
|
||||||
# 2018-2019 Thomas Eckert (tom at it-eckert.de)
|
# 2014 Nico Schottelius (nico-cdist at schottelius.org)
|
||||||
#
|
#
|
||||||
# This file is part of cdist.
|
# This file is part of cdist.
|
||||||
#
|
#
|
||||||
|
@ -16,7 +16,11 @@
|
||||||
#
|
#
|
||||||
# You should have received a copy of the GNU General Public License
|
# You should have received a copy of the GNU General Public License
|
||||||
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
|
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# Retrieve the contents of /etc/hostname
|
||||||
|
#
|
||||||
|
|
||||||
if [ -d /etc/apache2/mods-enabled ]; then
|
if [ -f /etc/sysconfig/network ]; then
|
||||||
ls -1 /etc/apache2/conf-enabled/
|
awk -F= '/^HOSTNAME=/ { print $2 }' /etc/sysconfig/network
|
||||||
fi
|
fi
|
|
@ -1,10 +0,0 @@
|
||||||
#!/bin/sh -e
|
|
||||||
|
|
||||||
command -v getconf >/dev/null || exit 0
|
|
||||||
|
|
||||||
val=$(getconf HOST_NAME_MAX 2>/dev/null) || exit 0
|
|
||||||
|
|
||||||
if test -n "${val}" -a "${val}" != 'undefined'
|
|
||||||
then
|
|
||||||
echo "${val}"
|
|
||||||
fi
|
|
|
@ -2,7 +2,6 @@
|
||||||
#
|
#
|
||||||
# 2014-2017 Steven Armstrong (steven-cdist at armstrong.cc)
|
# 2014-2017 Steven Armstrong (steven-cdist at armstrong.cc)
|
||||||
# 2014 Nico Schottelius (nico-cdist at schottelius.org)
|
# 2014 Nico Schottelius (nico-cdist at schottelius.org)
|
||||||
# 2019 Dennis Camera (dennis.camera at ssrq-sds-fds.ch)
|
|
||||||
#
|
#
|
||||||
# This file is part of cdist.
|
# This file is part of cdist.
|
||||||
#
|
#
|
||||||
|
@ -20,81 +19,60 @@
|
||||||
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
|
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
|
||||||
#
|
#
|
||||||
|
|
||||||
os=$(cat "$__global/explorer/os")
|
if [ -f "$__object/parameter/name" ]; then
|
||||||
name_running=$(cat "$__global/explorer/hostname")
|
name_should="$(cat "$__object/parameter/name")"
|
||||||
has_hostnamectl=$(cat "$__object/explorer/has_hostnamectl")
|
|
||||||
|
|
||||||
|
|
||||||
if test -s "$__object/parameter/name"
|
|
||||||
then
|
|
||||||
name_should=$(cat "$__object/parameter/name")
|
|
||||||
else
|
else
|
||||||
case $os
|
name_should="${__target_host%%.*}"
|
||||||
in
|
|
||||||
# RedHat-derivatives and BSDs
|
|
||||||
centos|fedora|redhat|scientific|freebsd|macosx|netbsd|openbsd)
|
|
||||||
# Hostname is FQDN
|
|
||||||
name_should="${__target_host}"
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
# Hostname is only first component of FQDN
|
|
||||||
name_should="${__target_host%%.*}"
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
os=$(cat "$__global/explorer/os")
|
||||||
|
name_running=$(cat "$__global/explorer/hostname")
|
||||||
|
name_config=$(cat "$__object/explorer/hostname_file")
|
||||||
|
name_sysconfig=$(cat "$__object/explorer/hostname_sysconfig")
|
||||||
|
has_hostnamectl=$(cat "$__object/explorer/has_hostnamectl")
|
||||||
|
|
||||||
################################################################################
|
################################################################################
|
||||||
# Check if the (running) hostname is already correct
|
# If everything is ok -> exit
|
||||||
#
|
#
|
||||||
test "$name_running" != "$name_should" || exit 0
|
case "$os" in
|
||||||
|
archlinux|debian|suse|ubuntu|devuan|coreos|alpine)
|
||||||
|
if [ "$name_config" = "$name_should" ] && [ "$name_running" = "$name_should" ]; then
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
scientific|centos|freebsd|openbsd)
|
||||||
|
if [ "$name_sysconfig" = "$name_should" ] && [ "$name_running" = "$name_should" ]; then
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
echo "Unsupported os: $os" >&2
|
||||||
|
exit 1
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
################################################################################
|
################################################################################
|
||||||
# Setup hostname
|
# Setup hostname
|
||||||
#
|
#
|
||||||
echo 'changed' >>"$__messages_out"
|
echo changed >> "$__messages_out"
|
||||||
|
|
||||||
# Use the good old way to set the hostname.
|
# Use the good old way to set the hostname even on machines running systemd.
|
||||||
case $os
|
case "$os" in
|
||||||
in
|
archlinux|debian|ubuntu|devuan|centos|coreos|alpine)
|
||||||
alpine|debian|devuan|ubuntu)
|
printf "printf '%%s\\\\n' '$name_should' > /etc/hostname\\n"
|
||||||
echo 'hostname -F /etc/hostname'
|
echo "hostname -F /etc/hostname"
|
||||||
;;
|
;;
|
||||||
archlinux)
|
freebsd|openbsd)
|
||||||
echo 'command -v hostnamectl >/dev/null 2>&1' \
|
|
||||||
"&& hostnamectl set-hostname '$name_should'" \
|
|
||||||
"|| hostname '$name_should'"
|
|
||||||
;;
|
|
||||||
centos|fedora|redhat|scientific|freebsd|netbsd|openbsd|gentoo|void)
|
|
||||||
echo "hostname '$name_should'"
|
echo "hostname '$name_should'"
|
||||||
;;
|
;;
|
||||||
macosx)
|
suse)
|
||||||
echo "scutil --set HostName '$name_should'"
|
|
||||||
;;
|
|
||||||
solaris)
|
|
||||||
echo "uname -S '$name_should'"
|
|
||||||
;;
|
|
||||||
slackware|suse|opensuse-leap)
|
|
||||||
# We do not read from /etc/HOSTNAME, because the running
|
|
||||||
# hostname is the first component only while the file contains
|
|
||||||
# the FQDN.
|
|
||||||
echo "hostname '$name_should'"
|
echo "hostname '$name_should'"
|
||||||
;;
|
printf "printf '%%s\\\\n' '$name_should' > /etc/HOSTNAME\\n"
|
||||||
*)
|
|
||||||
# Fall back to set the hostname using hostnamectl, if available.
|
|
||||||
if test -n "$has_hostnamectl"
|
|
||||||
then
|
|
||||||
# Don't use hostnamectl as the primary means to set the hostname for
|
|
||||||
# systemd systems, because it cannot be trusted to work reliably and
|
|
||||||
# exit with non-zero when it fails (e.g. hostname too long,
|
|
||||||
# D-Bus failure, etc.).
|
|
||||||
|
|
||||||
echo "hostnamectl set-hostname \"\$(cat /etc/hostname)\""
|
|
||||||
echo "test \"\$(hostname)\" = \"\$(cat /etc/hostname)\"" \
|
|
||||||
" || hostname -F /etc/hostname"
|
|
||||||
else
|
|
||||||
printf "echo 'Unsupported OS: %s' >&2\nexit 1\n" "$os"
|
|
||||||
fi
|
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
|
if [ "$has_hostnamectl" ]; then
|
||||||
|
# Allow hostnamectl set-hostname to fail silently.
|
||||||
|
# Who the fuck invented a tool that needs dbus to set the hostname anyway ...
|
||||||
|
echo "hostnamectl set-hostname '$name_should' || true"
|
||||||
|
fi
|
||||||
|
|
|
@ -8,10 +8,7 @@ cdist-type__hostname - Set the hostname
|
||||||
|
|
||||||
DESCRIPTION
|
DESCRIPTION
|
||||||
-----------
|
-----------
|
||||||
Sets the hostname on various operating systems.
|
Set's the hostname on various operating systems.
|
||||||
|
|
||||||
**Tip:** For advice on choosing a hostname, see
|
|
||||||
`RFC 1178 <https://tools.ietf.org/html/rfc1178>`_.
|
|
||||||
|
|
||||||
|
|
||||||
REQUIRED PARAMETERS
|
REQUIRED PARAMETERS
|
||||||
|
@ -21,7 +18,7 @@ None.
|
||||||
OPTIONAL PARAMETERS
|
OPTIONAL PARAMETERS
|
||||||
-------------------
|
-------------------
|
||||||
name
|
name
|
||||||
The hostname to set. Defaults to the first segment of __target_host
|
The hostname to set. Defaults to the first segment of __target_host
|
||||||
(${__target_host%%.*})
|
(${__target_host%%.*})
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -2,7 +2,6 @@
|
||||||
#
|
#
|
||||||
# 2012 Steven Armstrong (steven-cdist at armstrong.cc)
|
# 2012 Steven Armstrong (steven-cdist at armstrong.cc)
|
||||||
# 2014 Nico Schottelius (nico-cdist at schottelius.org)
|
# 2014 Nico Schottelius (nico-cdist at schottelius.org)
|
||||||
# 2019 Dennis Camera (dennis.camera at ssrq-sds-fds.ch)
|
|
||||||
#
|
#
|
||||||
# This file is part of cdist.
|
# This file is part of cdist.
|
||||||
#
|
#
|
||||||
|
@ -20,170 +19,50 @@
|
||||||
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
|
# along with cdist. If not, see <http://www.gnu.org/licenses/>.
|
||||||
#
|
#
|
||||||
|
|
||||||
not_supported() {
|
|
||||||
echo "Your operating system ($os) is currently not supported by this type (${__type##*/})." >&2
|
|
||||||
echo "Please contribute an implementation for it if you can." >&2
|
|
||||||
exit 1
|
|
||||||
}
|
|
||||||
|
|
||||||
set_hostname_systemd() {
|
|
||||||
echo "$1" | __file /etc/hostname --source -
|
|
||||||
}
|
|
||||||
|
|
||||||
os=$(cat "$__global/explorer/os")
|
os=$(cat "$__global/explorer/os")
|
||||||
os_version=$(cat "$__global/explorer/os_version")
|
if [ -f "$__object/parameter/name" ]; then
|
||||||
os_major=$(echo "$os_version" | grep -o '^[0-9][0-9]*')
|
name_should="$(cat "$__object/parameter/name")"
|
||||||
|
|
||||||
max_len=$(cat "$__object/explorer/max_len")
|
|
||||||
has_hostnamectl=$(cat "$__object/explorer/has_hostnamectl")
|
|
||||||
|
|
||||||
if test -s "$__object/parameter/name"
|
|
||||||
then
|
|
||||||
name_should=$(cat "$__object/parameter/name")
|
|
||||||
else
|
else
|
||||||
case $os
|
case "$os" in
|
||||||
in
|
openbsd)
|
||||||
# RedHat-derivatives and BSDs
|
name_should="${__target_host}"
|
||||||
centos|fedora|redhat|scientific|freebsd|netbsd|openbsd|slackware)
|
;;
|
||||||
# Hostname is FQDN
|
*)
|
||||||
name_should="${__target_host}"
|
name_should="${__target_host%%.*}"
|
||||||
;;
|
;;
|
||||||
suse|opensuse-leap)
|
|
||||||
# Classic SuSE stores the FQDN in /etc/HOSTNAME, while
|
|
||||||
# systemd does not. The running hostname is the first
|
|
||||||
# component in both cases.
|
|
||||||
# In versions before 15.x, the FQDN is stored in /etc/hostname.
|
|
||||||
if test -n "$has_hostnamectl" && test "$os_major" -ge 15 \
|
|
||||||
&& test "$os_major" -ne 42
|
|
||||||
then
|
|
||||||
name_should="${__target_host%%.*}"
|
|
||||||
else
|
|
||||||
name_should="${__target_host}"
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
# Hostname is only first component of FQDN on all other systems.
|
|
||||||
name_should="${__target_host%%.*}"
|
|
||||||
;;
|
|
||||||
esac
|
esac
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if test -n "$max_len" && test "$(printf '%s' "$name_should" | wc -c)" -gt "$max_len"
|
|
||||||
then
|
|
||||||
printf "Host name too long. Up to %u characters allowed.\n" "${max_len}" >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
case $os
|
not_supported() {
|
||||||
in
|
echo "Your operating system ($os) is currently not supported by this type (${__type##*/})." >&2
|
||||||
alpine|debian|devuan|ubuntu|void)
|
echo "Please contribute an implementation for it if you can." >&2
|
||||||
echo "$name_should" | __file /etc/hostname --source -
|
exit 1
|
||||||
;;
|
}
|
||||||
archlinux)
|
|
||||||
if test -n "$has_hostnamectl"
|
|
||||||
then
|
|
||||||
set_hostname_systemd "$name_should"
|
|
||||||
else
|
|
||||||
echo 'Ancient ArchLinux variants without hostnamectl are not supported.' >&2
|
|
||||||
exit 1
|
|
||||||
# Only for ancient ArchLinux, write to /etc/rc.conf on pre-systemd
|
|
||||||
# versions. There are some versions which use /etc/hostname but not
|
|
||||||
# systemd. It is unclear which ones these are.
|
|
||||||
|
|
||||||
# __key_value '/etc/rc.conf:HOSTNAME' \
|
case "$os" in
|
||||||
# --file /etc/rc.conf \
|
archlinux|debian|suse|ubuntu|devuan|coreos|alpine)
|
||||||
# --delimiter '=' --exact_delimiter \
|
|
||||||
# --key 'HOSTNAME' \
|
|
||||||
# --value "\"$name_should\""
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
centos|fedora|redhat|scientific)
|
|
||||||
if test -z "$has_hostnamectl"
|
|
||||||
then
|
|
||||||
# Only write to /etc/sysconfig/network on non-systemd versions.
|
|
||||||
# On systemd-based versions this entry is ignored.
|
|
||||||
__key_value '/etc/sysconfig/network:HOSTNAME' \
|
|
||||||
--file /etc/sysconfig/network \
|
|
||||||
--delimiter '=' --exact_delimiter \
|
|
||||||
--key HOSTNAME \
|
|
||||||
--value "\"$name_should\""
|
|
||||||
else
|
|
||||||
set_hostname_systemd "$name_should"
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
gentoo)
|
|
||||||
# Only write to /etc/conf.d/hostname on OpenRC-based installations.
|
|
||||||
# On systemd use hostnamectl(1) in gencode-remote.
|
|
||||||
if test -z "$has_hostnamectl"
|
|
||||||
then
|
|
||||||
__key_value '/etc/conf.d/hostname:hostname' \
|
|
||||||
--file /etc/conf.d/hostname \
|
|
||||||
--delimiter '=' --exact_delimiter \
|
|
||||||
--key 'hostname' \
|
|
||||||
--value "\"$name_should\""
|
|
||||||
else
|
|
||||||
set_hostname_systemd "$name_should"
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
freebsd)
|
|
||||||
__key_value '/etc/rc.conf:hostname' \
|
|
||||||
--file /etc/rc.conf \
|
|
||||||
--delimiter '=' --exact_delimiter \
|
|
||||||
--key 'hostname' \
|
|
||||||
--value "\"$name_should\""
|
|
||||||
;;
|
|
||||||
macosx)
|
|
||||||
# handled in gencode-remote
|
# handled in gencode-remote
|
||||||
:
|
:
|
||||||
;;
|
;;
|
||||||
netbsd)
|
scientific|centos)
|
||||||
__key_value '/etc/rc.conf:hostname' \
|
__key_value sysconfig-hostname \
|
||||||
|
--file /etc/sysconfig/network \
|
||||||
|
--delimiter '=' \
|
||||||
|
--key HOSTNAME \
|
||||||
|
--value "$name_should" --exact_delimiter
|
||||||
|
;;
|
||||||
|
freebsd)
|
||||||
|
__key_value rcconf-hostname \
|
||||||
--file /etc/rc.conf \
|
--file /etc/rc.conf \
|
||||||
--delimiter '=' --exact_delimiter \
|
--delimiter '=' \
|
||||||
--key 'hostname' \
|
--key 'hostname' \
|
||||||
--value "\"$name_should\""
|
--value "$name_should"
|
||||||
|
|
||||||
# To avoid confusion, ensure that the hostname is only stored once.
|
|
||||||
__file /etc/myname --state absent
|
|
||||||
;;
|
;;
|
||||||
openbsd)
|
openbsd)
|
||||||
echo "$name_should" | __file /etc/myname --source -
|
echo "$name_should" | __file /etc/myname --source -
|
||||||
;;
|
;;
|
||||||
slackware)
|
|
||||||
# We write the FQDN into /etc/HOSTNAME. But /etc/rc.d/rc.M will only
|
|
||||||
# read the first component from this file and set it as the running
|
|
||||||
# hostname on boot.
|
|
||||||
echo "$name_should" | __file /etc/HOSTNAME --source -
|
|
||||||
;;
|
|
||||||
solaris)
|
|
||||||
echo "$name_should" | __file /etc/nodename --source -
|
|
||||||
;;
|
|
||||||
suse|opensuse-leap)
|
|
||||||
# Modern SuSE provides /etc/HOSTNAME as a symlink for
|
|
||||||
# backwards-compatibility. Unfortunately it cannot be used
|
|
||||||
# here as __file does not follow the symlink.
|
|
||||||
# Therefore, we use the presence of the hostnamectl binary as
|
|
||||||
# an indication of which file to use. This unfortunately does
|
|
||||||
# not work correctly on openSUSE 12.x which provides
|
|
||||||
# hostnamectl but not /etc/hostname.
|
|
||||||
|
|
||||||
if test -n "$has_hostnamectl" -a "$os_major" -gt 12
|
|
||||||
then
|
|
||||||
hostname_file='/etc/hostname'
|
|
||||||
else
|
|
||||||
hostname_file='/etc/HOSTNAME'
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "$name_should" | __file "$hostname_file" --source -
|
|
||||||
;;
|
|
||||||
*)
|
*)
|
||||||
# On other operating systems we fall back to systemd's
|
not_supported
|
||||||
# hostnamectl if available…
|
|
||||||
if test -n "$has_hostnamectl"
|
|
||||||
then
|
|
||||||
set_hostname_systemd "$name_should"
|
|
||||||
else
|
|
||||||
not_supported
|
|
||||||
fi
|
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
|
@ -7,12 +7,6 @@ if [ -z "${certbot_fullpath}" ]; then
|
||||||
os_version="$(cat "${__global}/explorer/os_version")"
|
os_version="$(cat "${__global}/explorer/os_version")"
|
||||||
|
|
||||||
case "$os" in
|
case "$os" in
|
||||||
archlinux)
|
|
||||||
__package certbot
|
|
||||||
;;
|
|
||||||
alpine)
|
|
||||||
__package certbot
|
|
||||||
;;
|
|
||||||
debian)
|
debian)
|
||||||
case "$os_version" in
|
case "$os_version" in
|
||||||
8*)
|
8*)
|
||||||
|
@ -42,7 +36,6 @@ if [ -z "${certbot_fullpath}" ]; then
|
||||||
10*)
|
10*)
|
||||||
__package_apt certbot
|
__package_apt certbot
|
||||||
;;
|
;;
|
||||||
|
|
||||||
*)
|
*)
|
||||||
echo "Unsupported OS version: $os_version" >&2
|
echo "Unsupported OS version: $os_version" >&2
|
||||||
exit 1
|
exit 1
|
||||||
|
|
|
@ -34,9 +34,6 @@ case "$type" in
|
||||||
echo 0
|
echo 0
|
||||||
fi
|
fi
|
||||||
;;
|
;;
|
||||||
alpine)
|
|
||||||
echo 0
|
|
||||||
;;
|
|
||||||
*) echo "Your specified type ($type) is currently not supported." >&2
|
*) echo "Your specified type ($type) is currently not supported." >&2
|
||||||
echo "Please contribute an implementation for it if you can." >&2
|
echo "Please contribute an implementation for it if you can." >&2
|
||||||
;;
|
;;
|
||||||
|
|
|
@ -26,7 +26,6 @@ else
|
||||||
amazon|scientific|centos|fedora|redhat) echo "yum" ;;
|
amazon|scientific|centos|fedora|redhat) echo "yum" ;;
|
||||||
debian|ubuntu|devuan) echo "apt" ;;
|
debian|ubuntu|devuan) echo "apt" ;;
|
||||||
archlinux) echo "pacman" ;;
|
archlinux) echo "pacman" ;;
|
||||||
alpine) echo "apk" ;;
|
|
||||||
*)
|
*)
|
||||||
echo "Don't know how to manage packages on: $os" >&2
|
echo "Don't know how to manage packages on: $os" >&2
|
||||||
exit 1
|
exit 1
|
||||||
|
|
|
@ -47,10 +47,6 @@ case "$type" in
|
||||||
echo "pacman --noprogressbar --sync --refresh"
|
echo "pacman --noprogressbar --sync --refresh"
|
||||||
echo "pacman package database synced (age was: $currage)" >> "$__messages_out"
|
echo "pacman package database synced (age was: $currage)" >> "$__messages_out"
|
||||||
;;
|
;;
|
||||||
alpine)
|
|
||||||
echo "apk update"
|
|
||||||
echo "apk package database updated."
|
|
||||||
;;
|
|
||||||
*)
|
*)
|
||||||
echo "Don't know how to manage packages for type: $type" >&2
|
echo "Don't know how to manage packages for type: $type" >&2
|
||||||
exit 1
|
exit 1
|
||||||
|
|
|
@ -1,61 +0,0 @@
|
||||||
cdist-type__podman_compose(7)
|
|
||||||
=============================
|
|
||||||
|
|
||||||
NAME
|
|
||||||
----
|
|
||||||
cdist-type__podman_compose - install podman-compose
|
|
||||||
|
|
||||||
|
|
||||||
DESCRIPTION
|
|
||||||
-----------
|
|
||||||
Installs podman-compose package.
|
|
||||||
State 'absent' will not remove podman binary itself,
|
|
||||||
only podman-compose binary will be removed
|
|
||||||
|
|
||||||
|
|
||||||
REQUIRED PARAMETERS
|
|
||||||
-------------------
|
|
||||||
install
|
|
||||||
defaults to 'pip'
|
|
||||||
|
|
||||||
|
|
||||||
OPTIONAL PARAMETERS
|
|
||||||
-------------------
|
|
||||||
state
|
|
||||||
'present' or 'absent', defaults to 'present'
|
|
||||||
user
|
|
||||||
the user who owns the file, defaults to 'root'
|
|
||||||
|
|
||||||
|
|
||||||
BOOLEAN PARAMETERS
|
|
||||||
------------------
|
|
||||||
None.
|
|
||||||
|
|
||||||
|
|
||||||
EXAMPLES
|
|
||||||
--------
|
|
||||||
|
|
||||||
.. code-block:: sh
|
|
||||||
|
|
||||||
# Install podman-compose
|
|
||||||
__podman_compose
|
|
||||||
|
|
||||||
# Install latest version via pip
|
|
||||||
__podman_compose --state present --install pip
|
|
||||||
|
|
||||||
# Install latest version via pip and change user
|
|
||||||
__podman_compose --state present --install pip --user root
|
|
||||||
|
|
||||||
# Remove podman-compose
|
|
||||||
__podman_compose --state absent
|
|
||||||
|
|
||||||
|
|
||||||
AUTHORS
|
|
||||||
-------
|
|
||||||
Daniel Tschada <mail--@--moep.name>
|
|
||||||
|
|
||||||
|
|
||||||
COPYING
|
|
||||||
-------
|
|
||||||
Copyright \(C) 2019 Daniel Tschada. Free use of this software is
|
|
||||||
granted under the terms of the GNU General Public License version 3 or later (GPLv3+).
|
|
|
@ -1,50 +0,0 @@
|
||||||
#!/bin/sh -e
|
|
||||||
#
|
|
||||||
# 2019 Daniel Tschada
|
|
||||||
#
|
|
||||||
# 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/>.
|
|
||||||
#
|
|
||||||
|
|
||||||
# shellcheck disable=SC2154
|
|
||||||
# shellcheck disable=SC2034
|
|
||||||
install="$(cat "$__object/parameter/install")"
|
|
||||||
state="$(cat "$__object/parameter/state")"
|
|
||||||
user="$(cat "$__object/parameter/user")"
|
|
||||||
version="$(cat "$__object/parameter/version")"
|
|
||||||
|
|
||||||
# install it with pip
|
|
||||||
if [ "${install}" = "pip" ]; then
|
|
||||||
|
|
||||||
if [ "${state}" = "present" ]; then
|
|
||||||
__package_pip podman-compose --state present --pip /usr/local/bin/podman-compose --runas "${user}"
|
|
||||||
elif [ "${state}" = "absent" ]; then
|
|
||||||
__package_pip podman-compose --state absent
|
|
||||||
else
|
|
||||||
if [ "${state}" != "present" ] -a [ "${state}" != "absent" ]; then
|
|
||||||
echo "Unknown state: ${state}" >&2
|
|
||||||
exit 1
|
|
||||||
else
|
|
||||||
echo "Unknown user: ${user}" >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
else
|
|
||||||
|
|
||||||
echo "Unknown user: ${install}" >&2
|
|
||||||
exit 1
|
|
||||||
|
|
||||||
fi
|
|
|
@ -1 +0,0 @@
|
||||||
pip
|
|
|
@ -1 +0,0 @@
|
||||||
present
|
|
|
@ -1 +0,0 @@
|
||||||
root
|
|
|
@ -1,4 +0,0 @@
|
||||||
install
|
|
||||||
state
|
|
||||||
user
|
|
||||||
version
|
|
|
@ -1 +0,0 @@
|
||||||
install
|
|
|
@ -30,7 +30,6 @@ if [ -f "$__object/parameter/install-from-backports" ]; then
|
||||||
*)
|
*)
|
||||||
echo "--install-from-backports is only supported on Devuan -- ignoring." >&2
|
echo "--install-from-backports is only supported on Devuan -- ignoring." >&2
|
||||||
echo "Send a pull request if you require it." >&2
|
echo "Send a pull request if you require it." >&2
|
||||||
exit 1
|
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
else
|
else
|
||||||
|
@ -61,5 +60,5 @@ require="$require __directory/$storage_path $require_pkg" \
|
||||||
__config_file $CONF \
|
__config_file $CONF \
|
||||||
--source "$config" \
|
--source "$config" \
|
||||||
--group prometheus --mode 640 \
|
--group prometheus --mode 640 \
|
||||||
--onchange "service prometheus-alertmanager restart" # TODO when a config-check tool is available, check config here
|
--onchange "service prometheus-alertmanager reload" # TODO when a config-check tool is available, check config here
|
||||||
|
|
||||||
|
|
|
@ -5,11 +5,9 @@ export GOBIN=/opt/gocode/bin # where to find go binaries
|
||||||
exporter="$(cat "$__object/parameter/exporter")"
|
exporter="$(cat "$__object/parameter/exporter")"
|
||||||
[ -z "$exporter" ] && exporter="$__object_id"
|
[ -z "$exporter" ] && exporter="$__object_id"
|
||||||
|
|
||||||
__user prometheus
|
__user prometheus --system
|
||||||
require="__user/prometheus" __group prometheus
|
|
||||||
require="__group/prometheus" __user_groups prometheus --group prometheus
|
|
||||||
|
|
||||||
require="__user_groups/prometheus"
|
require=""
|
||||||
case $exporter in
|
case $exporter in
|
||||||
node)
|
node)
|
||||||
TEXTFILES=/service/node-exporter/textfiles # path for the textfiles collector
|
TEXTFILES=/service/node-exporter/textfiles # path for the textfiles collector
|
||||||
|
|
|
@ -38,8 +38,7 @@ if [ -f "$__object/parameter/install-from-backports" ]; then
|
||||||
esac
|
esac
|
||||||
else
|
else
|
||||||
__package prometheus
|
__package prometheus
|
||||||
__package prometheus-blackbox-exporter
|
require_pkg="__package/prometheus"
|
||||||
require_pkg="__package/prometheus __package/prometheus-blackbox-exporter"
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
##### PREPARE PATHS AND SUCH ################################################
|
##### PREPARE PATHS AND SUCH ################################################
|
||||||
|
@ -60,7 +59,7 @@ require="$require __directory/$storage_path $require_pkg" \
|
||||||
__config_file $CONF \
|
__config_file $CONF \
|
||||||
--source "$config" \
|
--source "$config" \
|
||||||
--group prometheus --mode 640 \
|
--group prometheus --mode 640 \
|
||||||
--onchange "promtool check config $CONF && service prometheus restart"
|
--onchange "promtool check config $CONF && service prometheus reload"
|
||||||
|
|
||||||
for file in $rule_files; do
|
for file in $rule_files; do
|
||||||
dest=$CONF_DIR/$(basename "$file")
|
dest=$CONF_DIR/$(basename "$file")
|
||||||
|
@ -68,6 +67,6 @@ for file in $rule_files; do
|
||||||
__config_file "$dest" \
|
__config_file "$dest" \
|
||||||
--source "$file" \
|
--source "$file" \
|
||||||
--owner prometheus \
|
--owner prometheus \
|
||||||
--onchange "promtool check rules '$dest' && service prometheus restart"
|
--onchange "promtool check rules '$dest' && service prometheus reload"
|
||||||
done
|
done
|
||||||
|
|
||||||
|
|
|
@ -1,131 +0,0 @@
|
||||||
#!/bin/sh -e
|
|
||||||
#
|
|
||||||
# 2019 Dennis Camera (dennis.camera at 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/>.
|
|
||||||
#
|
|
||||||
#
|
|
||||||
# Check if the given editor is present on the target system and determine its
|
|
||||||
# absolute path.
|
|
||||||
#
|
|
||||||
|
|
||||||
die() {
|
|
||||||
echo "$@" >&2
|
|
||||||
exit 1
|
|
||||||
}
|
|
||||||
|
|
||||||
editor_missing() { die "Editor '$1' is missing on the target system."; }
|
|
||||||
editor_no_alternative() {
|
|
||||||
die "Editor '$1' is not in the alternatives list of the target system." \
|
|
||||||
"$(test -n "${editors}" && printf '\nPlease choose one of:\n\n%s\n' "${editors}")"
|
|
||||||
}
|
|
||||||
|
|
||||||
# No need to check for the path if the file is supposed to be removed.
|
|
||||||
test "$(cat "${__object}/parameter/state")" != 'absent' || exit 0
|
|
||||||
|
|
||||||
|
|
||||||
case $("${__explorer}/os")
|
|
||||||
in
|
|
||||||
debian|devuan|ubuntu)
|
|
||||||
has_alternatives=true
|
|
||||||
|
|
||||||
# NOTE: Old versions do not support `--list`, in this case ignore the errors.
|
|
||||||
# This will require an absolute path to be provided, though.
|
|
||||||
editors=$(update-alternatives --list editor 2>/dev/null)
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
# NOTE: RedHat has an alternatives system but it doesn't usually track
|
|
||||||
# editors and it is a pain to extract the list.
|
|
||||||
has_alternatives=false
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
# Read --editor parameter and check its value since it is "optional"
|
|
||||||
editor=$(cat "${__object}/parameter/editor" 2>/dev/null) || true
|
|
||||||
test -n "${editor}" || die 'Please provide an --editor to configure.'
|
|
||||||
|
|
||||||
case $editor
|
|
||||||
in
|
|
||||||
/*)
|
|
||||||
is_abspath=true
|
|
||||||
;;
|
|
||||||
*/*)
|
|
||||||
die 'Relative editor paths are not supported'
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
is_abspath=false
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
|
|
||||||
if $has_alternatives && test -n "${editors}"
|
|
||||||
then
|
|
||||||
IFS='
|
|
||||||
'
|
|
||||||
if ! $is_abspath
|
|
||||||
then
|
|
||||||
# First, try to resolve the absolute path using $editors.
|
|
||||||
while true
|
|
||||||
do
|
|
||||||
for e in $editors
|
|
||||||
do
|
|
||||||
if test "$(basename "${e}")" = "${editor}"
|
|
||||||
then
|
|
||||||
editor="${e}"
|
|
||||||
break 2 # break out of both loops
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
# Iterating through alternatives did not yield a result
|
|
||||||
editor_no_alternative "${editor}"
|
|
||||||
break
|
|
||||||
done
|
|
||||||
fi
|
|
||||||
|
|
||||||
# Check if editor is present
|
|
||||||
test -f "${editor}" || editor_missing "${editor}"
|
|
||||||
|
|
||||||
for e in $editors
|
|
||||||
do
|
|
||||||
if test "${editor}" = "${e}"
|
|
||||||
then
|
|
||||||
# Editor is part of the alternatives list -> use it!
|
|
||||||
echo "${editor}"
|
|
||||||
exit 0
|
|
||||||
fi
|
|
||||||
done
|
|
||||||
|
|
||||||
editor_no_alternative "${editor}"
|
|
||||||
else
|
|
||||||
# NOTE: This branch is mostly for RedHat-based systems which do
|
|
||||||
# not track editor alternatives. To make this type useful
|
|
||||||
# on RedHat at all we allow an absoloute path to be provided
|
|
||||||
# in any case.
|
|
||||||
|
|
||||||
if $is_abspath
|
|
||||||
then
|
|
||||||
test -x "${editor}" || editor_missing "${editor}"
|
|
||||||
|
|
||||||
echo "${editor}"
|
|
||||||
exit 0
|
|
||||||
else
|
|
||||||
die "The target doesn't list any editor alternatives. " \
|
|
||||||
"Please specify an absolute path or populate the alternatives list."
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
# The script should never reach this statement!
|
|
||||||
exit 1
|
|
|
@ -1,26 +0,0 @@
|
||||||
#!/bin/sh -e
|
|
||||||
#
|
|
||||||
# 2019 Dennis Camera (dennis.camera at 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/>.
|
|
||||||
#
|
|
||||||
#
|
|
||||||
# Determines the primary group of the user.
|
|
||||||
#
|
|
||||||
|
|
||||||
user=$__object_id
|
|
||||||
|
|
||||||
id -gn "${user}" 2>/dev/null
|
|
|
@ -1,33 +0,0 @@
|
||||||
#!/bin/sh -e
|
|
||||||
#
|
|
||||||
# 2019 Dennis Camera (dennis.camera at 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/>.
|
|
||||||
#
|
|
||||||
#
|
|
||||||
# Determines the home folder of the target user.
|
|
||||||
#
|
|
||||||
|
|
||||||
user=$__object_id
|
|
||||||
home=$(getent passwd "${user}" | cut -d':' -f6)
|
|
||||||
|
|
||||||
if ! test -d "${home}"
|
|
||||||
then
|
|
||||||
echo "Cannot find home directory of user ${user}" >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
echo "${home}"
|
|
|
@ -1,78 +0,0 @@
|
||||||
cdist-type__sensible_editor(7)
|
|
||||||
==============================
|
|
||||||
|
|
||||||
NAME
|
|
||||||
----
|
|
||||||
cdist-type__sensible_editor - Select the sensible-editor
|
|
||||||
|
|
||||||
|
|
||||||
DESCRIPTION
|
|
||||||
-----------
|
|
||||||
This cdist type allows you to select the :strong:`sensible-editor` for
|
|
||||||
a given user.
|
|
||||||
|
|
||||||
|
|
||||||
REQUIRED PARAMETERS
|
|
||||||
-------------------
|
|
||||||
editor
|
|
||||||
Name or path of the editor to be selected.
|
|
||||||
On systems other than Debian derivatives an absolute path is required.
|
|
||||||
|
|
||||||
It is permissible to omit this parameter if --state is absent.
|
|
||||||
|
|
||||||
|
|
||||||
OPTIONAL PARAMETERS
|
|
||||||
-------------------
|
|
||||||
state
|
|
||||||
'present', 'absent', or 'exists'. Defaults to 'present', where:
|
|
||||||
|
|
||||||
present
|
|
||||||
the sensible-editor is exactly what is specified in --editor.
|
|
||||||
absent
|
|
||||||
no sensible-editor configuration is present.
|
|
||||||
exists
|
|
||||||
the sensible-editor will be set to what is specified in --editor,
|
|
||||||
unless there already is a configuration on the target system.
|
|
||||||
|
|
||||||
|
|
||||||
EXAMPLES
|
|
||||||
--------
|
|
||||||
|
|
||||||
.. code-block:: sh
|
|
||||||
|
|
||||||
__sensible_editor root --editor /bin/ed # ed(1) is the standard
|
|
||||||
__sensible_editor noob --editor nano
|
|
||||||
|
|
||||||
|
|
||||||
LIMITATIONS
|
|
||||||
-----------
|
|
||||||
|
|
||||||
This type depends upon the :strong:`sensible-editor`\ (1) script which
|
|
||||||
is part of the sensible-utils package.
|
|
||||||
|
|
||||||
Therefore, the following operating systems are supported:
|
|
||||||
* Debian 8 (jessie) or later
|
|
||||||
* Devuan
|
|
||||||
* Ubuntu 8.10 (intrepid) or later
|
|
||||||
* RHEL/CentOS 7 or later (EPEL repo required)
|
|
||||||
* Fedora 21 or later
|
|
||||||
|
|
||||||
Note: on old versions of Ubuntu the sensible-* utils are part of the
|
|
||||||
debianutils package.
|
|
||||||
|
|
||||||
SEE ALSO
|
|
||||||
--------
|
|
||||||
:strong:`select-editor`\ (1), :strong:`sensible-editor`\ (1).
|
|
||||||
|
|
||||||
|
|
||||||
AUTHOR
|
|
||||||
-------
|
|
||||||
Dennis Camera <dennis.camera--@--ssrq-sds-fds.ch>
|
|
||||||
|
|
||||||
|
|
||||||
COPYING
|
|
||||||
-------
|
|
||||||
Copyright \(C) 2019 Dennis Camera.
|
|
||||||
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.
|
|
|
@ -1,94 +0,0 @@
|
||||||
#!/bin/sh -e
|
|
||||||
# -*- mode: sh; indent-tabs-mode: t -*-
|
|
||||||
#
|
|
||||||
# 2019 Dennis Camera (dennis.camera at 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/>.
|
|
||||||
#
|
|
||||||
|
|
||||||
version_ge() {
|
|
||||||
awk -F '[^0-9.]' -v target="${1:?}" '
|
|
||||||
function max(x, y) { return x > y ? x : y; }
|
|
||||||
BEGIN {
|
|
||||||
getline;
|
|
||||||
nx = split($1, x, ".");
|
|
||||||
ny = split(target, y, ".");
|
|
||||||
for (i = 1; i <= max(nx, ny); ++i) {
|
|
||||||
diff = int(x[i]) - int(y[i]);
|
|
||||||
if (diff < 0) exit 1;
|
|
||||||
else if (diff > 0) exit 0;
|
|
||||||
else continue;
|
|
||||||
}
|
|
||||||
}'
|
|
||||||
}
|
|
||||||
|
|
||||||
not_supported() {
|
|
||||||
echo "OS ${os} does not support __sensible_editor." >&2
|
|
||||||
echo 'If it does, please provide a patch.' >&2
|
|
||||||
exit 1
|
|
||||||
}
|
|
||||||
|
|
||||||
os=$(cat "${__global}/explorer/os")
|
|
||||||
os_version=$(cat "${__global}/explorer/os_version")
|
|
||||||
|
|
||||||
state=$(cat "${__object}/parameter/state")
|
|
||||||
user=$__object_id
|
|
||||||
|
|
||||||
if test "${state}" != 'present' && test "${state}" != 'exists' && test "${state}" != 'absent'
|
|
||||||
then
|
|
||||||
echo 'Only "present", "exists", and "absent" are allowed for --state' >&2
|
|
||||||
exit 1
|
|
||||||
fi
|
|
||||||
|
|
||||||
package_name='sensible-utils'
|
|
||||||
|
|
||||||
case $os
|
|
||||||
in
|
|
||||||
debian)
|
|
||||||
pkg_type='apt'
|
|
||||||
;;
|
|
||||||
devuan)
|
|
||||||
pkg_type='apt'
|
|
||||||
;;
|
|
||||||
ubuntu)
|
|
||||||
(echo "${os_version}" | version_ge 10.04) || package_name='debianutils'
|
|
||||||
pkg_type='apt'
|
|
||||||
;;
|
|
||||||
centos|fedora|redhat|scientific)
|
|
||||||
pkg_type='yum'
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
not_supported
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
if test "${state}" != 'absent'
|
|
||||||
then
|
|
||||||
__package "${package_name}" --state present \
|
|
||||||
--type "${pkg_type}"
|
|
||||||
export require="__package/${package_name}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
editor_path=$(cat "${__object}/explorer/editor_path")
|
|
||||||
user_home=$(cat "${__object}/explorer/user_home")
|
|
||||||
group=$(cat "${__object}/explorer/group")
|
|
||||||
|
|
||||||
__file "${user_home}/.selected_editor" --state "${state}" \
|
|
||||||
--owner "${user}" --group "${group}" --mode 0644 \
|
|
||||||
--source - <<EOF
|
|
||||||
# Managed by cdist
|
|
||||||
SELECTED_EDITOR="${editor_path}"
|
|
||||||
EOF
|
|
|
@ -1 +0,0 @@
|
||||||
present
|
|
|
@ -1,2 +0,0 @@
|
||||||
editor
|
|
||||||
state
|
|
|
@ -1,5 +0,0 @@
|
||||||
#!/bin/sh -e
|
|
||||||
|
|
||||||
if [ -d /etc/apache2/mods-enabled ]; then
|
|
||||||
/usr/sbin/apachectl -t -D DUMP_MODULES | awk '/.*_module/ { gsub(/_module.*$/, ""); gsub(/^ /, ""); print }'
|
|
||||||
fi
|
|
|
@ -1,56 +0,0 @@
|
||||||
#!/bin/sh -e
|
|
||||||
#
|
|
||||||
# 2018-2019 Thomas Eckert (tom at it-eckert.de)
|
|
||||||
#
|
|
||||||
# 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/>.
|
|
||||||
|
|
||||||
state=$(cat "$__object/parameter/state")
|
|
||||||
|
|
||||||
os=$(cat "$__global/explorer/os")
|
|
||||||
case "$os" in
|
|
||||||
debian|ubuntu)
|
|
||||||
:
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
echo "Your operating system ($os) is currently not supported by this type (${__type##*/})." >&2
|
|
||||||
echo "Please contribute an implementation for it if you can." >&2
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
if [ "$state" = "present" ]; then
|
|
||||||
if ! grep -q ^rewrite "$__object/explorer/active-modules"; then
|
|
||||||
echo "a2enmod rewrite >/dev/null"
|
|
||||||
echo "mod:rewrite enabled" >> "$__messages_out"
|
|
||||||
fi
|
|
||||||
if ! grep -q "^cgi$" "$__object/explorer/active-modules"; then
|
|
||||||
echo "a2enmod cgi >/dev/null"
|
|
||||||
echo "mod:cgi enabled" >> "$__messages_out"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! grep -q ^xymon.conf "$__object/explorer/active-conf"; then
|
|
||||||
echo "a2enconf xymon >/dev/null"
|
|
||||||
echo "conf:xymon enabled" >> "$__messages_out"
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
if grep -q "^mod:.* enabled" "$__messages_out"; then
|
|
||||||
echo "systemctl restart apache2.service"
|
|
||||||
echo "apache restarted" >> "$__messages_out"
|
|
||||||
elif grep -q "^conf:xymon enabled" "$__messages_out"; then
|
|
||||||
echo "systemctl reload apache2.service"
|
|
||||||
echo "apache reloaded" >> "$__messages_out"
|
|
||||||
fi
|
|
|
@ -1,79 +0,0 @@
|
||||||
cdist-type__xymon_apache(7)
|
|
||||||
===========================
|
|
||||||
|
|
||||||
NAME
|
|
||||||
----
|
|
||||||
cdist-type__xymon_apache - Configure apache2-webserver for Xymon
|
|
||||||
|
|
||||||
|
|
||||||
DESCRIPTION
|
|
||||||
-----------
|
|
||||||
This cdist type installs and configures apache2 to be used "exclusively" (in
|
|
||||||
the sense that no other use is taken care of) with Xymon (the systems and
|
|
||||||
network monitor).
|
|
||||||
|
|
||||||
It depends on `__xymon_server`.
|
|
||||||
|
|
||||||
|
|
||||||
REQUIRED PARAMETERS
|
|
||||||
-------------------
|
|
||||||
None.
|
|
||||||
|
|
||||||
|
|
||||||
OPTIONAL PARAMETERS
|
|
||||||
-------------------
|
|
||||||
state
|
|
||||||
'present', 'absent', defaults to 'present'.
|
|
||||||
|
|
||||||
ipacl
|
|
||||||
IP(-ranges) that have access to the Xymon webpages and CGIs. Apache2-style
|
|
||||||
syntax suitable for `Require ip ...`. Example: `192.168.1.0/24 10.0.0.0/8`
|
|
||||||
|
|
||||||
|
|
||||||
MESSAGES
|
|
||||||
--------
|
|
||||||
mod:rewrite enabled
|
|
||||||
apache module enabled
|
|
||||||
conf:xymon enabled
|
|
||||||
apache config for xymon enabled
|
|
||||||
apache restarted
|
|
||||||
apache2.service was reloaded
|
|
||||||
apache reloaded
|
|
||||||
apache2.service was restarted
|
|
||||||
|
|
||||||
|
|
||||||
EXPLORERS
|
|
||||||
---------
|
|
||||||
active-conf
|
|
||||||
lists apache2 `conf-enabled`
|
|
||||||
active-modules
|
|
||||||
lists active apache2-modules
|
|
||||||
|
|
||||||
|
|
||||||
EXAMPLES
|
|
||||||
--------
|
|
||||||
|
|
||||||
.. code-block:: sh
|
|
||||||
|
|
||||||
# minmal, only localhost-access:
|
|
||||||
__xymon_apache
|
|
||||||
# allow more IPs to access the Xymon-webinterface:
|
|
||||||
__xymon_apache --ipacl "192.168.0.0/16 10.0.0.0/8" --state "present"
|
|
||||||
|
|
||||||
|
|
||||||
SEE ALSO
|
|
||||||
--------
|
|
||||||
:strong:`cdist__xymon_server`\ (7)
|
|
||||||
|
|
||||||
|
|
||||||
AUTHORS
|
|
||||||
-------
|
|
||||||
Thomas Eckert <tom--@--it-eckert.de>
|
|
||||||
|
|
||||||
|
|
||||||
COPYING
|
|
||||||
-------
|
|
||||||
Copyright \(C) 2018-2019 Thomas Eckert. 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.
|
|
|
@ -1,42 +0,0 @@
|
||||||
#!/bin/sh -e
|
|
||||||
#
|
|
||||||
# 2018-2019 Thomas Eckert (tom at it-eckert.de)
|
|
||||||
#
|
|
||||||
# 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/>.
|
|
||||||
|
|
||||||
state=$(cat "$__object/parameter/state")
|
|
||||||
|
|
||||||
os=$(cat "$__global/explorer/os")
|
|
||||||
case "$os" in
|
|
||||||
debian|ubuntu)
|
|
||||||
:
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
echo "Your operating system ($os) is currently not supported by this type (${__type##*/})." >&2
|
|
||||||
echo "Please contribute an implementation for it if you can." >&2
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
__package apache2 --state "$state"
|
|
||||||
|
|
||||||
## edit xymon.conf IP-ranges
|
|
||||||
if [ -f "$__object/parameter/ipacl" ]; then
|
|
||||||
require="__package/xymon" __line /etc/apache2/conf-available/xymon.conf \
|
|
||||||
--line " Require ip $(cat "$__object/parameter/ipacl")" \
|
|
||||||
--after "^[[:space:]]*Require local" \
|
|
||||||
--state "present"
|
|
||||||
fi
|
|
|
@ -1 +0,0 @@
|
||||||
present
|
|
|
@ -1,2 +0,0 @@
|
||||||
state
|
|
||||||
ipacl
|
|
|
@ -1,28 +0,0 @@
|
||||||
#!/bin/sh -e
|
|
||||||
#
|
|
||||||
# 2018-2019 Thomas Eckert (tom at it-eckert.de)
|
|
||||||
#
|
|
||||||
# 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/>.
|
|
||||||
|
|
||||||
servers=$(cat "$__object/parameter/servers")
|
|
||||||
|
|
||||||
if grep -q ^__key_value/CLIENTHOSTNAME "$__messages_in" || grep -q ^__key_value/XYMONSERVERS "$__messages_in" ; then
|
|
||||||
echo "systemctl restart xymon-client"
|
|
||||||
echo "restarted" >> "$__messages_out"
|
|
||||||
cat <<-EOT
|
|
||||||
echo "xymon-client xymon-client/XYMONSERVERS string $servers" | debconf-set-selections
|
|
||||||
EOT
|
|
||||||
fi
|
|
|
@ -1,66 +0,0 @@
|
||||||
cdist-type__xymon_client(7)
|
|
||||||
===========================
|
|
||||||
|
|
||||||
NAME
|
|
||||||
----
|
|
||||||
cdist-type__xymon_client - Install the Xymon client
|
|
||||||
|
|
||||||
|
|
||||||
DESCRIPTION
|
|
||||||
-----------
|
|
||||||
This cdist type installs the Xymon client and configures it to report with
|
|
||||||
FQDN.
|
|
||||||
|
|
||||||
|
|
||||||
REQUIRED PARAMETERS
|
|
||||||
-------------------
|
|
||||||
None.
|
|
||||||
|
|
||||||
|
|
||||||
OPTIONAL PARAMETERS
|
|
||||||
-------------------
|
|
||||||
state
|
|
||||||
'present', 'absent', defaults to 'present'.
|
|
||||||
|
|
||||||
servers
|
|
||||||
One or more IP addresses (space separated) of the Xymon server(s) to report
|
|
||||||
to. While DNS-names are ok it is discouraged, defaults to 127.0.0.1.
|
|
||||||
|
|
||||||
|
|
||||||
BOOLEAN PARAMETERS
|
|
||||||
------------------
|
|
||||||
msgcache
|
|
||||||
Enable xymon `msgcache`. Note: XYMONSERVER has to be `127.0.0.1` for using
|
|
||||||
`msgcache` (see `msgcache (8)` of the xymon documentation for details).
|
|
||||||
|
|
||||||
EXAMPLES
|
|
||||||
--------
|
|
||||||
|
|
||||||
.. code-block:: sh
|
|
||||||
|
|
||||||
# minimal, report to 127.0.0.1
|
|
||||||
__xymon_client
|
|
||||||
|
|
||||||
# specify server:
|
|
||||||
__xymon_client --servers "192.168.1.1"
|
|
||||||
|
|
||||||
# activate `msgcache` for passive client:
|
|
||||||
__xymon_client --msgcache
|
|
||||||
|
|
||||||
|
|
||||||
SEE ALSO
|
|
||||||
--------
|
|
||||||
:strong:`cdist__xymon_server`\ (7), :strong:`xymon`\ (7), :strong:`msgcache`\ (8)
|
|
||||||
|
|
||||||
|
|
||||||
AUTHORS
|
|
||||||
-------
|
|
||||||
Thomas Eckert <tom--@--it-eckert.de>
|
|
||||||
|
|
||||||
|
|
||||||
COPYING
|
|
||||||
-------
|
|
||||||
Copyright \(C) 2018-2019 Thomas Eckert. 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.
|
|
|
@ -1,54 +0,0 @@
|
||||||
#!/bin/sh -e
|
|
||||||
#
|
|
||||||
# 2018-2019 Thomas Eckert (tom at it-eckert.de)
|
|
||||||
#
|
|
||||||
# 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/>.
|
|
||||||
|
|
||||||
state=$(cat "$__object/parameter/state")
|
|
||||||
servers=$(cat "$__object/parameter/servers")
|
|
||||||
|
|
||||||
os=$(cat "$__global/explorer/os")
|
|
||||||
case "$os" in
|
|
||||||
debian|ubuntu)
|
|
||||||
:
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
echo "Your operating system ($os) is currently not supported by this type (${__type##*/})." >&2
|
|
||||||
echo "Please contribute an implementation for it if you can." >&2
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
__package xymon-client --state "$state"
|
|
||||||
|
|
||||||
if [ -f "$__object/parameter/msgcache" ]; then
|
|
||||||
require="__package/xymon-client" __line /etc/xymon/clientlaunch.cfg \
|
|
||||||
--regex DISABLED --state absent
|
|
||||||
fi
|
|
||||||
|
|
||||||
require="__package/xymon-client" __key_value CLIENTHOSTNAME \
|
|
||||||
--file /etc/default/xymon-client \
|
|
||||||
--value "'$__target_hostname'" \
|
|
||||||
--delimiter '=' \
|
|
||||||
--state "$state"
|
|
||||||
require="__package/xymon-client" __key_value XYMONSERVERS \
|
|
||||||
--file /etc/default/xymon-client \
|
|
||||||
--value "'$servers'" \
|
|
||||||
--delimiter '=' \
|
|
||||||
--state "$state"
|
|
||||||
|
|
||||||
## CLI-usage often requires a shell:
|
|
||||||
require="__package/xymon-client" __user xymon --shell "/bin/bash" --state "$state"
|
|
|
@ -1 +0,0 @@
|
||||||
msgcache
|
|
|
@ -1 +0,0 @@
|
||||||
127.0.0.1
|
|
|
@ -1 +0,0 @@
|
||||||
present
|
|
|
@ -1,2 +0,0 @@
|
||||||
state
|
|
||||||
servers
|
|
|
@ -1,23 +0,0 @@
|
||||||
#!/bin/sh -e
|
|
||||||
#
|
|
||||||
# 2018-2019 Thomas Eckert (tom at it-eckert.de)
|
|
||||||
#
|
|
||||||
# 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/>.
|
|
||||||
|
|
||||||
## to speed up config-reload we send a HUP to the server process:
|
|
||||||
cat <<-EOT
|
|
||||||
pkill -HUP xymond || { echo "HUPing xymond failed" >&2; exit 1; }
|
|
||||||
EOT
|
|
|
@ -1,78 +0,0 @@
|
||||||
cdist-type__xymon_config(7)
|
|
||||||
===========================
|
|
||||||
|
|
||||||
NAME
|
|
||||||
----
|
|
||||||
cdist-type__xymon_config - Deploy a Xymon configuration-directory
|
|
||||||
|
|
||||||
|
|
||||||
DESCRIPTION
|
|
||||||
-----------
|
|
||||||
This cdist type deploys a full Xymon configuration directory from the files-dir
|
|
||||||
to the host. This type requires an installed Xymon server, e.g. deployed by
|
|
||||||
`__xymon_server`.
|
|
||||||
|
|
||||||
WARNING: This type _replaces_ the `/etc/xymon/`-directory! The previous
|
|
||||||
contents is replaced/deleted!
|
|
||||||
|
|
||||||
|
|
||||||
REQUIRED PARAMETERS
|
|
||||||
-------------------
|
|
||||||
confdir
|
|
||||||
The directory in `./files/` that contains the `/etc/xymon/`-content to be
|
|
||||||
deployed.
|
|
||||||
|
|
||||||
|
|
||||||
OPTIONAL PARAMETERS
|
|
||||||
-------------------
|
|
||||||
owner
|
|
||||||
passed as-is as `--owner` to `__rsync`
|
|
||||||
|
|
||||||
group
|
|
||||||
passed as-is as `--group` to `__rsync`
|
|
||||||
|
|
||||||
|
|
||||||
OPTIONAL MULTIPLE PARAMETERS
|
|
||||||
----------------------------
|
|
||||||
rsync-opts
|
|
||||||
identical to __rsync type, only `--`-options are supported
|
|
||||||
|
|
||||||
|
|
||||||
REQUIRED FILES
|
|
||||||
--------------
|
|
||||||
The directory specified by `confdir` has to contain a valid xymon-configuration
|
|
||||||
(`/etc/xymon/`) _plus_ the `ext/`-directory that normally resides in
|
|
||||||
`/usr/lib/xymon/server/`.
|
|
||||||
|
|
||||||
|
|
||||||
EXAMPLES
|
|
||||||
--------
|
|
||||||
|
|
||||||
.. code-block:: sh
|
|
||||||
|
|
||||||
__xymon_config --confdir=xymon.example.com
|
|
||||||
# this will replace /etc/xymon/ on the target host with
|
|
||||||
# the contents from __xymon_config/files/xymon.example.com/
|
|
||||||
|
|
||||||
## the same but set ownership to `xymon:xymon` and exclude
|
|
||||||
## the `netrc`-file:
|
|
||||||
__xymon_config --confdir=xymon.example.com \
|
|
||||||
--owner xymon --group xymon \
|
|
||||||
--rsync-opts "exclude=netrc"
|
|
||||||
|
|
||||||
|
|
||||||
SEE ALSO
|
|
||||||
--------
|
|
||||||
:strong:`cdist__xymon_server`\ (7), :strong:`cdist__rsync`\ (7), :strong:`xymon`\ (7)
|
|
||||||
|
|
||||||
AUTHORS
|
|
||||||
-------
|
|
||||||
Thomas Eckert <tom--@--it-eckert.de>
|
|
||||||
|
|
||||||
|
|
||||||
COPYING
|
|
||||||
-------
|
|
||||||
Copyright \(C) 2018-2019 Thomas Eckert. 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.
|
|
|
@ -1,43 +0,0 @@
|
||||||
#!/bin/sh -e
|
|
||||||
#
|
|
||||||
# 2018-2019 Thomas Eckert (tom at it-eckert.de)
|
|
||||||
#
|
|
||||||
# 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/>.
|
|
||||||
|
|
||||||
confdir=$(cat "$__object/parameter/confdir")
|
|
||||||
set --
|
|
||||||
if [ -f "$__object/parameter/owner" ]; then
|
|
||||||
owner=$(cat "$__object/parameter/owner")
|
|
||||||
set -- "$@" "--owner $owner"
|
|
||||||
fi
|
|
||||||
if [ -f "$__object/parameter/group" ]; then
|
|
||||||
group=$(cat "$__object/parameter/group")
|
|
||||||
set -- "$@" "--group $group"
|
|
||||||
fi
|
|
||||||
|
|
||||||
## pass `--rsync-opts` as-is to `__rsync`:
|
|
||||||
if [ -f "$__object/parameter/rsync-opts" ]; then
|
|
||||||
while read -r opts; do
|
|
||||||
# shellcheck disable=SC2089
|
|
||||||
set -- "$@" "--rsync-opts '$opts'"
|
|
||||||
done < "$__object/parameter/rsync-opts"
|
|
||||||
fi
|
|
||||||
|
|
||||||
# shellcheck disable=SC2068,SC2090
|
|
||||||
__rsync /etc/xymon/ \
|
|
||||||
--source "$__type/files/$confdir/" \
|
|
||||||
--rsync-opts "delete" \
|
|
||||||
$@
|
|
|
@ -1,2 +0,0 @@
|
||||||
owner
|
|
||||||
group
|
|
|
@ -1 +0,0 @@
|
||||||
rsync-opts
|
|
|
@ -1 +0,0 @@
|
||||||
confdir
|
|
|
@ -1,26 +0,0 @@
|
||||||
#!/bin/sh -e
|
|
||||||
#
|
|
||||||
# 2018-2019 Thomas Eckert (tom at it-eckert.de)
|
|
||||||
#
|
|
||||||
# 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/>.
|
|
||||||
|
|
||||||
## "move" user-modified dirs to /etc/xymon to be managed by __xymon_config:
|
|
||||||
cat <<-EOT
|
|
||||||
if [ ! -L /usr/lib/xymon/server/ext ]; then
|
|
||||||
mv /usr/lib/xymon/server/ext /etc/xymon
|
|
||||||
ln -s /etc/xymon/ext /usr/lib/xymon/server/
|
|
||||||
fi
|
|
||||||
EOT
|
|
|
@ -1,87 +0,0 @@
|
||||||
cdist-type__xymon_server(7)
|
|
||||||
===========================
|
|
||||||
|
|
||||||
NAME
|
|
||||||
----
|
|
||||||
cdist-type__xymon_server - Install a Xymon server
|
|
||||||
|
|
||||||
|
|
||||||
DESCRIPTION
|
|
||||||
-----------
|
|
||||||
This cdist type installs a Xymon (https://www.xymon.com/) server and (optional)
|
|
||||||
required helper packages.
|
|
||||||
|
|
||||||
This includes the Xymon client as a dependency, so NO NEED to install
|
|
||||||
`__xymon_client` separately.
|
|
||||||
|
|
||||||
To access the webinterface a webserver is required. The cdist-type
|
|
||||||
`__xymon_apache` can be used to install and configure the apache webserver for
|
|
||||||
the use with Xymon.
|
|
||||||
|
|
||||||
Further and day-to-day configuration of Xymon can either be done manually in
|
|
||||||
`/etc/xymon/` or the directory can be deployed and managed by `__xymon_config`.
|
|
||||||
|
|
||||||
|
|
||||||
REQUIRED PARAMETERS
|
|
||||||
-------------------
|
|
||||||
None.
|
|
||||||
|
|
||||||
|
|
||||||
OPTIONAL PARAMETERS
|
|
||||||
-------------------
|
|
||||||
state
|
|
||||||
'present', 'absent', defaults to 'present'. If '--install_helpers' is
|
|
||||||
specified for 'absent' the helper packages will be un-installed.
|
|
||||||
|
|
||||||
|
|
||||||
BOOLEAN PARAMETERS
|
|
||||||
------------------
|
|
||||||
install_helpers
|
|
||||||
Install helper packages used by Xymon (fping, heirloom-mailx, traceroute,
|
|
||||||
ntpdate).
|
|
||||||
|
|
||||||
|
|
||||||
EXAMPLES
|
|
||||||
--------
|
|
||||||
|
|
||||||
.. code-block:: sh
|
|
||||||
|
|
||||||
# minmal
|
|
||||||
__xymon_server
|
|
||||||
|
|
||||||
# the same
|
|
||||||
__xymon_server --state present
|
|
||||||
|
|
||||||
# also install helper packages:
|
|
||||||
__xymon_server --install_helpers
|
|
||||||
|
|
||||||
# examples to give a more complete picture: __xymon_server installed on
|
|
||||||
# `xymon.example.com` w/ IP 192.168.1.1:
|
|
||||||
#
|
|
||||||
# install webserver and grant 2 private subnets access to the webinterface:
|
|
||||||
__xymon_apache --ipacl "192.168.0.0/16 10.0.0.0/8"
|
|
||||||
# deploy server-configuration with __xymon_config:
|
|
||||||
__xymon_config --confdir=xymon.example.com
|
|
||||||
|
|
||||||
# install xymon-client on other machines (not needed on the server):
|
|
||||||
__xymon_client --servers "192.168.1.1"
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
SEE ALSO
|
|
||||||
--------
|
|
||||||
:strong:`cdist__xymon_apache`\ (7), :strong:`cdist__xymon_config`\ (7),
|
|
||||||
:strong:`cdist__xymon_client`\ (7), :strong:`xymon`\ (7)
|
|
||||||
|
|
||||||
|
|
||||||
AUTHORS
|
|
||||||
-------
|
|
||||||
Thomas Eckert <tom--@--it-eckert.de>
|
|
||||||
|
|
||||||
|
|
||||||
COPYING
|
|
||||||
-------
|
|
||||||
Copyright \(C) 2018-2019 Thomas Eckert. 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.
|
|
|
@ -1,50 +0,0 @@
|
||||||
#!/bin/sh -e
|
|
||||||
#
|
|
||||||
# 2018-2019 Thomas Eckert (tom at it-eckert.de)
|
|
||||||
#
|
|
||||||
# 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/>.
|
|
||||||
|
|
||||||
state=$(cat "$__object/parameter/state")
|
|
||||||
if [ -f "$__object/parameter/install_helpers" ]; then
|
|
||||||
install_helpers=1
|
|
||||||
else
|
|
||||||
install_helpers=0
|
|
||||||
fi
|
|
||||||
|
|
||||||
os=$(cat "$__global/explorer/os")
|
|
||||||
case "$os" in
|
|
||||||
debian|ubuntu)
|
|
||||||
:
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
echo "Your operating system ($os) is currently not supported by this type (${__type##*/})." >&2
|
|
||||||
echo "Please contribute an implementation for it if you can." >&2
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
__package xymon --state "$state"
|
|
||||||
|
|
||||||
## install helper-packages/tools used by the xymon server if requested:
|
|
||||||
if [ "$install_helpers" = "1" ]; then
|
|
||||||
__package fping --state "$state"
|
|
||||||
__package heirloom-mailx --state "$state"
|
|
||||||
__package traceroute --state "$state"
|
|
||||||
__package ntpdate --state "$state"
|
|
||||||
fi
|
|
||||||
|
|
||||||
## CLI-usage often requires a shell:
|
|
||||||
require="__package/xymon" __user xymon --shell "/bin/bash" --state "$state"
|
|
|
@ -1 +0,0 @@
|
||||||
install_helpers
|
|
|
@ -1 +0,0 @@
|
||||||
present
|
|
|
@ -1 +0,0 @@
|
||||||
state
|
|
|
@ -56,6 +56,7 @@ gencode-local
|
||||||
__type: full qualified path to the type's dir
|
__type: full qualified path to the type's dir
|
||||||
__files: full qualified path to the files dir
|
__files: full qualified path to the files dir
|
||||||
__target_host_tags: comma spearated list of host tags
|
__target_host_tags: comma spearated list of host tags
|
||||||
|
__lib: full qualified path to the lib dir
|
||||||
|
|
||||||
returns: string containing the generated code or None
|
returns: string containing the generated code or None
|
||||||
|
|
||||||
|
@ -75,6 +76,7 @@ gencode-remote
|
||||||
__type: full qualified path to the type's dir
|
__type: full qualified path to the type's dir
|
||||||
__files: full qualified path to the files dir
|
__files: full qualified path to the files dir
|
||||||
__target_host_tags: comma spearated list of host tags
|
__target_host_tags: comma spearated list of host tags
|
||||||
|
__lib: full qualified path to the lib dir
|
||||||
|
|
||||||
returns: string containing the generated code or None
|
returns: string containing the generated code or None
|
||||||
|
|
||||||
|
@ -107,6 +109,7 @@ class Code(object):
|
||||||
'__target_fqdn': self.target_host[2],
|
'__target_fqdn': self.target_host[2],
|
||||||
'__global': self.local.base_path,
|
'__global': self.local.base_path,
|
||||||
'__files': self.local.files_path,
|
'__files': self.local.files_path,
|
||||||
|
'__lib': self.local.lib_path,
|
||||||
'__target_host_tags': self.local.target_host_tags,
|
'__target_host_tags': self.local.target_host_tags,
|
||||||
'__cdist_log_level': util.log_level_env_var_val(local.log),
|
'__cdist_log_level': util.log_level_env_var_val(local.log),
|
||||||
'__cdist_log_level_name': util.log_level_name_env_var_val(
|
'__cdist_log_level_name': util.log_level_name_env_var_val(
|
||||||
|
|
|
@ -44,6 +44,7 @@ common:
|
||||||
== local.type_path
|
== local.type_path
|
||||||
__files: full qualified path to the files dir
|
__files: full qualified path to the files dir
|
||||||
__target_host_tags: comma spearated list of host tags
|
__target_host_tags: comma spearated list of host tags
|
||||||
|
__lib: full qualified path to the lib dir
|
||||||
|
|
||||||
initial manifest is:
|
initial manifest is:
|
||||||
script: full qualified path to the initial manifest
|
script: full qualified path to the initial manifest
|
||||||
|
@ -111,6 +112,7 @@ class Manifest(object):
|
||||||
'__target_hostname': self.target_host[1],
|
'__target_hostname': self.target_host[1],
|
||||||
'__target_fqdn': self.target_host[2],
|
'__target_fqdn': self.target_host[2],
|
||||||
'__files': self.local.files_path,
|
'__files': self.local.files_path,
|
||||||
|
'__lib': self.local.lib_path,
|
||||||
'__target_host_tags': self.local.target_host_tags,
|
'__target_host_tags': self.local.target_host_tags,
|
||||||
'__cdist_log_level': util.log_level_env_var_val(self.log),
|
'__cdist_log_level': util.log_level_env_var_val(self.log),
|
||||||
'__cdist_log_level_name': util.log_level_name_env_var_val(
|
'__cdist_log_level_name': util.log_level_name_env_var_val(
|
||||||
|
|
|
@ -36,7 +36,7 @@ import cdist.message
|
||||||
from cdist import core
|
from cdist import core
|
||||||
import cdist.exec.util as util
|
import cdist.exec.util as util
|
||||||
|
|
||||||
CONF_SUBDIRS_LINKED = ["explorer", "files", "manifest", "type", ]
|
CONF_SUBDIRS_LINKED = ["explorer", "files", "manifest", "type", "lib", ]
|
||||||
|
|
||||||
|
|
||||||
class Local(object):
|
class Local(object):
|
||||||
|
@ -133,6 +133,7 @@ class Local(object):
|
||||||
os.path.join(self.manifest_path, "init"))
|
os.path.join(self.manifest_path, "init"))
|
||||||
|
|
||||||
self.type_path = os.path.join(self.conf_path, "type")
|
self.type_path = os.path.join(self.conf_path, "type")
|
||||||
|
self.lib_path = os.path.join(self.conf_path, "lib")
|
||||||
|
|
||||||
def _init_object_marker(self):
|
def _init_object_marker(self):
|
||||||
self.object_marker_file = os.path.join(self.base_path, "object_marker")
|
self.object_marker_file = os.path.join(self.base_path, "object_marker")
|
||||||
|
|
|
@ -78,6 +78,7 @@ class Shell(object):
|
||||||
'__manifest': self.local.manifest_path,
|
'__manifest': self.local.manifest_path,
|
||||||
'__explorer': self.local.global_explorer_path,
|
'__explorer': self.local.global_explorer_path,
|
||||||
'__files': self.local.files_path,
|
'__files': self.local.files_path,
|
||||||
|
'__lib': self.local.lib_path,
|
||||||
'__target_host_tags': self.local.target_host_tags,
|
'__target_host_tags': self.local.target_host_tags,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -101,6 +101,7 @@ class CodeTestCase(test.CdistTestCase):
|
||||||
self.cdist_object.object_id)
|
self.cdist_object.object_id)
|
||||||
self.assertEqual(output_dict['__object_name'], self.cdist_object.name)
|
self.assertEqual(output_dict['__object_name'], self.cdist_object.name)
|
||||||
self.assertEqual(output_dict['__files'], self.local.files_path)
|
self.assertEqual(output_dict['__files'], self.local.files_path)
|
||||||
|
self.assertEqual(output_dict['__lib'], self.local.lib_path)
|
||||||
self.assertEqual(output_dict['__target_host_tags'],
|
self.assertEqual(output_dict['__target_host_tags'],
|
||||||
self.local.target_host_tags)
|
self.local.target_host_tags)
|
||||||
self.assertEqual(output_dict['__cdist_log_level'],
|
self.assertEqual(output_dict['__cdist_log_level'],
|
||||||
|
@ -129,6 +130,7 @@ class CodeTestCase(test.CdistTestCase):
|
||||||
self.cdist_object.object_id)
|
self.cdist_object.object_id)
|
||||||
self.assertEqual(output_dict['__object_name'], self.cdist_object.name)
|
self.assertEqual(output_dict['__object_name'], self.cdist_object.name)
|
||||||
self.assertEqual(output_dict['__files'], self.local.files_path)
|
self.assertEqual(output_dict['__files'], self.local.files_path)
|
||||||
|
self.assertEqual(output_dict['__lib'], self.local.lib_path)
|
||||||
self.assertEqual(output_dict['__target_host_tags'],
|
self.assertEqual(output_dict['__target_host_tags'],
|
||||||
self.local.target_host_tags)
|
self.local.target_host_tags)
|
||||||
self.assertEqual(output_dict['__cdist_log_level'],
|
self.assertEqual(output_dict['__cdist_log_level'],
|
||||||
|
|
|
@ -97,6 +97,7 @@ class ManifestTestCase(test.CdistTestCase):
|
||||||
self.local.type_path)
|
self.local.type_path)
|
||||||
self.assertEqual(output_dict['__manifest'], self.local.manifest_path)
|
self.assertEqual(output_dict['__manifest'], self.local.manifest_path)
|
||||||
self.assertEqual(output_dict['__files'], self.local.files_path)
|
self.assertEqual(output_dict['__files'], self.local.files_path)
|
||||||
|
self.assertEqual(output_dict['__lib'], self.local.lib_path)
|
||||||
self.assertEqual(output_dict['__target_host_tags'],
|
self.assertEqual(output_dict['__target_host_tags'],
|
||||||
self.local.target_host_tags)
|
self.local.target_host_tags)
|
||||||
self.assertEqual(output_dict['__cdist_log_level'],
|
self.assertEqual(output_dict['__cdist_log_level'],
|
||||||
|
@ -140,6 +141,7 @@ class ManifestTestCase(test.CdistTestCase):
|
||||||
self.assertEqual(output_dict['__object_id'], cdist_object.object_id)
|
self.assertEqual(output_dict['__object_id'], cdist_object.object_id)
|
||||||
self.assertEqual(output_dict['__object_name'], cdist_object.name)
|
self.assertEqual(output_dict['__object_name'], cdist_object.name)
|
||||||
self.assertEqual(output_dict['__files'], self.local.files_path)
|
self.assertEqual(output_dict['__files'], self.local.files_path)
|
||||||
|
self.assertEqual(output_dict['__lib'], self.local.lib_path)
|
||||||
self.assertEqual(output_dict['__target_host_tags'],
|
self.assertEqual(output_dict['__target_host_tags'],
|
||||||
self.local.target_host_tags)
|
self.local.target_host_tags)
|
||||||
self.assertEqual(output_dict['__cdist_log_level'],
|
self.assertEqual(output_dict['__cdist_log_level'],
|
||||||
|
|
|
@ -2,29 +2,6 @@ Changelog
|
||||||
---------
|
---------
|
||||||
|
|
||||||
next:
|
next:
|
||||||
* Type __xymon_config: Add parameters for ownership and generic rsync options (Thomas Eckert)
|
|
||||||
* Type __xymon_client: Add msgcache parameter to support passive clients (Thomas Eckert)
|
|
||||||
* Type __apt_key: Use mktemp for unique temporary gpg home (Ander Punnar)
|
|
||||||
|
|
||||||
6.1.0: 2019-11-19
|
|
||||||
* Explorer hostname, type __hostname: Support more operating systems, rewrite type and hostname explorer (Dennis Camera)
|
|
||||||
|
|
||||||
6.0.4: 2019-11-19
|
|
||||||
* Doc: Fix typos (Kirill Miazine)
|
|
||||||
|
|
||||||
6.0.3: 2019-10-31
|
|
||||||
* Type __letsencrypt_cert: Add Alpine support (Nico Schottelius)
|
|
||||||
* Type __xymon_client: Fix spelling error in manpage (Dmitry Bogatov)
|
|
||||||
* Build: Support pip from git (Darko Poljak, Ľubomír Kučera)
|
|
||||||
* Type __package_update_index: Add Alpine support (Ahmed Bilal Khalid)
|
|
||||||
|
|
||||||
6.0.2: 2019-10-17
|
|
||||||
* New types: __xymon_server, __xymon_apache, __xymon_config, __xymon_client (Thomas Eckert)
|
|
||||||
* Type __letsencrypt_cert: Add Arch Linux support (Nico Schottelius)
|
|
||||||
* New type: __sensible_editor (Dennis Camera)
|
|
||||||
* Types __grafana_dashboard, __prometheus_alertmanager, __prometheus_exporter, __prometheus_server: Support Debian 10 (Ahmed Bilal Khalid)
|
|
||||||
|
|
||||||
6.0.1: 2019-10-08
|
|
||||||
* Type __group: Support OSes without getent (Dennis Camera)
|
* Type __group: Support OSes without getent (Dennis Camera)
|
||||||
* Type __user: Support OSes without getent (Dennis Camera)
|
* Type __user: Support OSes without getent (Dennis Camera)
|
||||||
* Type __ssh_authorized_keys: Support OSes without getent (Dennis Camera)
|
* Type __ssh_authorized_keys: Support OSes without getent (Dennis Camera)
|
||||||
|
@ -33,8 +10,6 @@ next:
|
||||||
* Explorer os: Unquote value from os-release file (Dennis Camera)
|
* Explorer os: Unquote value from os-release file (Dennis Camera)
|
||||||
* Type __letsencrypt_cert: Support Debian 10* (Ahmed Bilal Khalid)
|
* Type __letsencrypt_cert: Support Debian 10* (Ahmed Bilal Khalid)
|
||||||
* Type __prometheus_server: Add missing exit after unsupported error message (Dominique Roux)
|
* Type __prometheus_server: Add missing exit after unsupported error message (Dominique Roux)
|
||||||
* Type __git: Use --recurse-submodules instead of --recursive (Jonas Hagen)
|
|
||||||
* Type __git: Add --shallow option (Jonas Hagen)
|
|
||||||
|
|
||||||
6.0.0: 2019-10-01
|
6.0.0: 2019-10-01
|
||||||
* Type __letsencrypt_cert: Fix beowulf's spelling (Mondi Ravi)
|
* Type __letsencrypt_cert: Fix beowulf's spelling (Mondi Ravi)
|
||||||
|
|
|
@ -27,7 +27,7 @@ for that. This type will:
|
||||||
- configure nginx.
|
- configure nginx.
|
||||||
|
|
||||||
Our type will not create the actual python application. Its intention is only
|
Our type will not create the actual python application. Its intention is only
|
||||||
to configure hosting for specified user and project. It is up to the user to
|
to configure hosing for specified user and project. It is up to the user to
|
||||||
create his/her applications.
|
create his/her applications.
|
||||||
|
|
||||||
So let's start.
|
So let's start.
|
||||||
|
@ -480,7 +480,7 @@ Creating python bottle application
|
||||||
|
|
||||||
We now need to create Bottle application. As you remember from the beginning
|
We now need to create Bottle application. As you remember from the beginning
|
||||||
of this walkthrough our type does not create the actual python application,
|
of this walkthrough our type does not create the actual python application,
|
||||||
its intention is only to configure hosting for specified user and project.
|
its intention is only to configure hosing for specified user and project.
|
||||||
It is up to the user to create his/her applications.
|
It is up to the user to create his/her applications.
|
||||||
|
|
||||||
Become app user::
|
Become app user::
|
||||||
|
|
|
@ -81,6 +81,10 @@ confdir/files/
|
||||||
Cdist does not care about this directory besides providing access to it.
|
Cdist does not care about this directory besides providing access to it.
|
||||||
It is thought to be a general file storage area.
|
It is thought to be a general file storage area.
|
||||||
|
|
||||||
|
confdir/lib/
|
||||||
|
Cdist does not care about this directory besides providing access to it.
|
||||||
|
It is thought to be a general storage for shell library files.
|
||||||
|
|
||||||
confdir/manifest/init
|
confdir/manifest/init
|
||||||
This is the central entry point.
|
This is the central entry point.
|
||||||
It is an executable (+x bit set) shell script that can use
|
It is an executable (+x bit set) shell script that can use
|
||||||
|
@ -141,6 +145,10 @@ confdir/type/<name>/files
|
||||||
by cdist at any time. It can be used for storing supplementary
|
by cdist at any time. It can be used for storing supplementary
|
||||||
files (like scripts to act as a template or configuration files).
|
files (like scripts to act as a template or configuration files).
|
||||||
|
|
||||||
|
confdir/type/<name>/lib
|
||||||
|
This directory is reserved for user shell library files and will
|
||||||
|
not be used by cdist at any time.
|
||||||
|
|
||||||
out/
|
out/
|
||||||
This directory contains output of cdist and is usually located
|
This directory contains output of cdist and is usually located
|
||||||
in a temporary directory and thus will be removed after the run.
|
in a temporary directory and thus will be removed after the run.
|
||||||
|
@ -235,6 +243,10 @@ __files
|
||||||
Directory that contains content from the "files" subdirectories
|
Directory that contains content from the "files" subdirectories
|
||||||
from the configuration directories.
|
from the configuration directories.
|
||||||
Available for: initial manifest, type manifest, type gencode, shell.
|
Available for: initial manifest, type manifest, type gencode, shell.
|
||||||
|
__lib
|
||||||
|
Directory that contains content from the "lib" subdirectories
|
||||||
|
from the configuration directories.
|
||||||
|
Available for: initial manifest, type manifest, type gencode, shell.
|
||||||
__manifest
|
__manifest
|
||||||
Directory that contains the initial manifest.
|
Directory that contains the initial manifest.
|
||||||
Available for: initial manifest, type manifest, shell.
|
Available for: initial manifest, type manifest, shell.
|
||||||
|
|
|
@ -11,7 +11,7 @@ To upgrade cdist in the current branch use
|
||||||
git pull
|
git pull
|
||||||
|
|
||||||
# Also update the manpages
|
# Also update the manpages
|
||||||
make man
|
./build man
|
||||||
export MANPATH=$MANPATH:$(pwd -P)/doc/man
|
export MANPATH=$MANPATH:$(pwd -P)/doc/man
|
||||||
|
|
||||||
If you stay on a version branche (i.e. 1.0, 1.1., ...), nothing should break.
|
If you stay on a version branche (i.e. 1.0, 1.1., ...), nothing should break.
|
||||||
|
|
|
@ -1,79 +0,0 @@
|
||||||
#!/bin/sh
|
|
||||||
|
|
||||||
num=50000
|
|
||||||
dsthost=localhost
|
|
||||||
|
|
||||||
tmp=$(mktemp -d)
|
|
||||||
remote_tmp=${tmp}-remote
|
|
||||||
|
|
||||||
cd "$tmp"
|
|
||||||
|
|
||||||
create_files() {
|
|
||||||
i=0
|
|
||||||
while [ $i -lt $num ]; do
|
|
||||||
echo $i > file-${i}
|
|
||||||
i=$((i+1))
|
|
||||||
done
|
|
||||||
}
|
|
||||||
|
|
||||||
delete_remote() {
|
|
||||||
ssh "${dsthost}" "rm -rf ${remote_tmp}"
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
tar_remote() {
|
|
||||||
cd "${tmp}"
|
|
||||||
tar c . | ssh "${dsthost}" "mkdir ${remote_tmp}; cd ${remote_tmp}; tar x"
|
|
||||||
}
|
|
||||||
|
|
||||||
cdist_remote()
|
|
||||||
{
|
|
||||||
(
|
|
||||||
while [ $i -lt $num ]; do
|
|
||||||
echo __file ${remote_tmp}/file-${i} --source "${tmp}/file-${i}"
|
|
||||||
i=$((i+1))
|
|
||||||
done
|
|
||||||
) | cdist config -i - -vv "${dsthost}"
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
cdist_remote_parallel()
|
|
||||||
{
|
|
||||||
(
|
|
||||||
while [ $i -lt $num ]; do
|
|
||||||
echo __file ${remote_tmp}/file-${i} --source "${tmp}/file-${i}"
|
|
||||||
i=$((i+1))
|
|
||||||
done
|
|
||||||
) | cdist config -j10 -i - -vv "${dsthost}"
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
echo "Creating ${num} files"
|
|
||||||
time create_files
|
|
||||||
|
|
||||||
echo "scping files"
|
|
||||||
time scp -r "${tmp}" "${dsthost}:$remote_tmp" >/dev/null
|
|
||||||
|
|
||||||
echo "delete remote"
|
|
||||||
time delete_remote
|
|
||||||
|
|
||||||
echo "taring files"
|
|
||||||
time tar_remote
|
|
||||||
|
|
||||||
echo "delete remote"
|
|
||||||
time delete_remote
|
|
||||||
|
|
||||||
echo "cdisting files"
|
|
||||||
time cdist_remote
|
|
||||||
|
|
||||||
echo "delete remote"
|
|
||||||
time delete_remote
|
|
||||||
|
|
||||||
echo "cdisting files (parallel)!"
|
|
||||||
time cdist_remote
|
|
||||||
|
|
||||||
echo "delete remote"
|
|
||||||
time delete_remote
|
|
||||||
|
|
||||||
echo "delete local"
|
|
||||||
rm -rf "$tmp"
|
|
22
setup.py
22
setup.py
|
@ -1,27 +1,7 @@
|
||||||
from distutils.core import setup
|
from distutils.core import setup
|
||||||
from distutils.errors import DistutilsError
|
import cdist
|
||||||
import os
|
import os
|
||||||
import re
|
import re
|
||||||
import subprocess
|
|
||||||
|
|
||||||
|
|
||||||
# We have it only if it is a git cloned repo.
|
|
||||||
build_helper = os.path.join('bin', 'build-helper')
|
|
||||||
# Version file path.
|
|
||||||
version_file = os.path.join('cdist', 'version.py')
|
|
||||||
# If we have build-helper we could be a git repo.
|
|
||||||
if os.path.exists(build_helper):
|
|
||||||
# Try to generate version.py.
|
|
||||||
rv = subprocess.run([build_helper, 'version', ])
|
|
||||||
if rv.returncode != 0:
|
|
||||||
raise DistutilsError("Failed to generate {}".format(version_file))
|
|
||||||
else:
|
|
||||||
# Otherwise, version.py should be present.
|
|
||||||
if not os.path.exists(version_file):
|
|
||||||
raise DistutilsError("Missing version file {}".format(version_file))
|
|
||||||
|
|
||||||
|
|
||||||
import cdist
|
|
||||||
|
|
||||||
|
|
||||||
def data_finder(data_dir):
|
def data_finder(data_dir):
|
||||||
|
|
Loading…
Reference in a new issue