domain-diag/ddiag.sh

98 lines
1.7 KiB
Bash
Raw Normal View History

2022-04-07 21:28:08 +03:00
#!/bin/bash
set -euo pipefail
. shell-terminfo
terminfo_init
verbose=1
msg_fail()
{
echo -n $*:" ["
color_text "FAIL" red
echo "]"
}
msg_warn()
{
echo -n $*:" ["
color_text "WARN" yellow
echo "]"
}
msg_done()
{
echo -n $*:" ["
color_text "DONE" green
echo "]"
}
2022-04-07 22:09:25 +03:00
run_by_root()
{
local msg=
if test "$1" = '-m'; then
shift
msg="$1"
shift
fi
if test `id -u` != 0; then
echo -n "Running not by root, SKIP: "
echo $*
else
test -z "$msg" ||
echo -n "$msg: "
$*
fi
}
2022-04-07 21:28:08 +03:00
run()
{
local func="$1"
local msg_error=msg_fail
[ "${func#test_}" = "$func" ] ||
msg_error=msg_warn
if test -z $verbose; then
$func >/dev/null 2>&1
else
echo "--- $func ---"
$func
2022-04-07 21:33:14 +03:00
fi && (test -z $verbose || echo ---; msg_done "$2") || (test -z $verbose || echo ---; $msg_error "$2")
test -z $verbose || echo ---
test -z $verbose || echo
2022-04-07 21:28:08 +03:00
}
check_hostnamectl()
{
local static_host="$(hostnamectl --static)"
local transient_host="$(hostname)"
hostnamectl
test "$static_host" = "$transient_host"
}
test_hostname()
{
local host=`hostname`
test "$host" != "${host/.}"
}
2022-04-07 22:09:25 +03:00
check_system_auth()
{
local auth=$(/usr/sbin/control system-auth)
echo "control system_auth: $auth"
readlink -f /etc/pam.d/system-auth
cat /etc/pam.d/system-auth
test -n "$auth" -a "$auth" != "unknown"
}
2022-04-07 22:15:49 +03:00
test_domain_system_auth()
{
local auth=$(/usr/sbin/control system-auth)
test -n "$auth" -a "$auth" != "local"
}
2022-04-07 21:28:08 +03:00
run check_hostnamectl "Check hostnamectl"
run test_hostname "Test hostname is FQDN"
2022-04-07 22:09:25 +03:00
run check_system_auth "System authentication"
2022-04-07 22:15:49 +03:00
run test_domain_system_auth "Domain system authentication"