2022-04-07 21:28:08 +03:00
#!/bin/bash
set -euo pipefail
. shell-terminfo
terminfo_init
verbose = 1
msg_fail( )
{
2022-04-08 02:20:51 +03:00
echo -n " \ $* : [ "
2022-04-07 21:28:08 +03:00
color_text "FAIL" red
echo "]"
}
msg_warn( )
{
2022-04-08 02:20:51 +03:00
echo -n " \ $* : [ "
2022-04-07 21:28:08 +03:00
color_text "WARN" yellow
echo "]"
}
msg_done( )
{
2022-04-08 02:20:51 +03:00
echo -n " \ $* : [ "
2022-04-07 21:28:08 +03:00
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 $*
2022-04-08 01:18:40 +03:00
return 2
2022-04-07 22:09:25 +03:00
else
test -z " $msg " ||
echo -n " $msg : "
2022-04-08 01:18:40 +03:00
$* || return 1
2022-04-07 22:09:25 +03:00
fi
}
2022-04-07 21:28:08 +03:00
run( )
{
2022-04-08 01:18:40 +03:00
local retval = 126
2022-04-07 21:28:08 +03:00
local func = " $1 "
2022-04-08 02:20:51 +03:00
local msg = $( printf "/--- %-70s ---" " $func " )
2022-04-08 01:18:40 +03:00
2022-04-07 21:28:08 +03:00
if test -z $verbose ; then
2022-04-08 01:18:40 +03:00
$func >/dev/null 2>& 1 && retval = 0 || retval = $?
2022-04-07 21:28:08 +03:00
else
2022-04-08 02:20:51 +03:00
color_message " $msg " bold white
2022-04-08 01:18:40 +03:00
$func && retval = 0 || retval = $?
fi
2022-04-08 02:20:51 +03:00
test -z $verbose || echo "\------------------------------------------------------------------------------"
2022-04-08 01:18:40 +03:00
case " $retval " in
0) msg_done " $2 " ; ;
2) msg_warn " $2 " ; ;
*) msg_fail " $2 " ; ;
esac
2022-04-08 02:20:51 +03:00
test -z $verbose || color_message " \----------------------------------------------------------------------------" bold white
2022-04-07 21:33:14 +03:00
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`
2022-04-08 01:18:40 +03:00
test " $host " != " ${ host /. } " || return 2
2022-04-07 21:28:08 +03:00
}
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
2022-04-08 02:20:51 +03:00
SYSTEM_AUTH = " $auth "
2022-04-07 22:09:25 +03:00
test -n " $auth " -a " $auth " != "unknown"
}
2022-04-07 22:15:49 +03:00
test_domain_system_auth( )
{
2022-04-08 02:20:51 +03:00
test -n " $SYSTEM_AUTH " ||
SYSTEM_AUTH = local
test " $SYSTEM_AUTH " != "local" || return 2
}
is_system_auth_local( )
{
test " $SYSTEM_AUTH " = "local"
2022-04-07 22:15:49 +03:00
}
2022-04-07 23:00:52 +03:00
check_krb5_conf_ccache( )
{
local ccache = $( /usr/sbin/control krb5-conf-ccache)
echo " control krb5-conf-ccache: $ccache "
test -n " $ccache " -a " $ccache " != "unknown"
}
test_keyring_krb5_conf_ccache( )
{
local ccache = $( /usr/sbin/control krb5-conf-ccache)
2022-04-08 01:18:40 +03:00
test -n " $ccache " -a " $ccache " = = "keyring" || return 2
2022-04-07 23:00:52 +03:00
}
2022-04-07 23:33:54 +03:00
check_krb5_conf_kdc_lookup( )
{
local retval = 0
echo -n "/etc/krb5.conf: dns_lookup_kdc "
if grep -q '^\s*dns_lookup_kdc\s*=\s*\([Tt][Rr][Uu][Ee]\|1\|[Yy][Ee][Ss]\)\s*$' /etc/krb5.conf; then
echo "is enabled"
else
if grep -q '^\s*dns_lookup_kdc\s*=' /etc/krb5.conf; then
echo "is disabled"
retval = 1
else
echo "is enabled by default"
2022-04-08 01:18:40 +03:00
retval = 2
2022-04-07 23:33:54 +03:00
fi
fi
return $retval
}
2022-04-07 23:40:33 +03:00
check_krb5_keytab_exists( )
{
2022-04-08 02:20:51 +03:00
local retval = 0
2022-04-07 23:40:33 +03:00
ls -la /etc/krb5.keytab
2022-04-08 02:20:51 +03:00
if ! test -e /etc/krb5.keytab; then
is_system_auth_local && retval = 2 || retval = 1
fi
return $retval
2022-04-07 23:40:33 +03:00
}
2022-04-08 01:18:40 +03:00
check_keytab_credential_list( )
{
2022-04-08 02:20:51 +03:00
local retval = 0
if ! run_by_root klist -ke; then
is_system_auth_local && retval = 2 || retval = 1
fi
return $retval
2022-04-08 01:18:40 +03:00
}
2022-04-08 02:20:51 +03:00
run check_hostnamectl "Check hostname persistance"
run test_hostname "Test hostname is FQDN (not short)"
run check_system_auth "System authentication method"
run test_domain_system_auth "Domain system authentication enabled"
run check_krb5_conf_ccache "Kerberos credential cache status"
run test_keyring_krb5_conf_ccache "Using keyring as kerberos credential cache"
run check_krb5_conf_kdc_lookup "Check DNS lookup kerberos KDC status"
2022-04-08 01:18:40 +03:00
run check_krb5_keytab_exists "Check machine crendetial cache is exists"
2022-04-08 02:20:51 +03:00
run check_keytab_credential_list "Check machine credentials list in keytab"