#! /usr/bin/env bash # vim: set filetype=sh ts=4 sw=4 sts=4 et: set -e basedir=$(readlink -f "$(dirname "$0")"/../..) # shellcheck source=lib/shell/functions.inc . "$basedir"/lib/shell/functions.inc opt_dev=0 opt_install=0 opt_syslogng=0 while builtin getopts "distv" opt; do # shellcheck disable=SC2154 case "$opt" in "d") opt_dev=1;; "i") opt_install=1;; "s") opt_syslogng=1;; *) echo "Error $opt"; exit 1;; esac done action_doing "Detecting OS..." action_detail "Found $OS_FAMILY" if [ "$OS_FAMILY" = Linux ]; then action_detail "Found distro $LINUX_DISTRO version $DISTRO_VERSION (major $DISTRO_VERSION_MAJOR), distro like $DISTRO_LIKE" fi action_done action_doing "Checking the list of installed packages..." if echo "$DISTRO_LIKE" | grep -q -w debian; then wanted_list="libcommon-sense-perl libjson-perl libnet-netmask-perl libnet-ip-perl \ libnet-dns-perl libdbd-sqlite3-perl libterm-readkey-perl libdatetime-perl \ fortunes-bofh-excuses sudo fping \ xz-utils sqlite3 binutils acl libtimedate-perl gnupg rsync \ libjson-xs-perl inotify-tools lsof curl libterm-readline-gnu-perl \ libwww-perl libdigest-sha-perl libnet-ssleay-perl \ libnet-server-perl cryptsetup mosh expect openssh-server locales \ coreutils netcat bash libcgi-pm-perl iputils-ping tar" # workaround for debian/armhf: curl fails to validate some SSL certificates, # whereas wget succeeds; this is needed for e.g. install-ttyrec.sh if [ "$(uname -m)" = armv7l ]; then wanted_list="$wanted_list wget" fi [ "$opt_dev" = 1 ] && wanted_list="$wanted_list libperl-critic-perl perltidy shellcheck openssl" if { [ "$LINUX_DISTRO" = debian ] && [ "$DISTRO_VERSION_MAJOR" -lt 9 ]; } || { [ "$LINUX_DISTRO" = ubuntu ] && [ "$DISTRO_VERSION_MAJOR" -le 16 ]; }; then wanted_list="$wanted_list openssh-blacklist openssh-blacklist-extra" fi if { [ "$LINUX_DISTRO" = debian ] && [ "$DISTRO_VERSION_MAJOR" -ge 8 ]; } || { [ "$LINUX_DISTRO" = ubuntu ] && [ "$DISTRO_VERSION_MAJOR" -ge 14 ]; }; then wanted_list="$wanted_list liblinux-prctl-perl libpam-google-authenticator pamtester" fi [ "$opt_syslogng" = 1 ] && wanted_list="$wanted_list syslog-ng syslog-ng-core" if [ "$opt_install" = 1 ]; then export DEBIAN_FRONTEND=noninteractive # shellcheck disable=SC2086 apt-get update && apt-get install -y $wanted_list exit $? fi installed=$(dpkg -l | awk '/^ii/ {print $2}' | cut -d: -f1) install_cmd="apt-get install" elif echo "$DISTRO_LIKE" | grep -q -w rhel; then wanted_list="perl-JSON perl-Net-Netmask perl-Net-IP \ perl-Net-DNS perl-DBD-SQLite perl-TermReadKey \ sudo fping xz sqlite binutils acl gnupg2 rsync perl-DateTime \ perl-JSON-XS inotify-tools lsof curl perl-Term-ReadLine-Gnu \ perl-libwww-perl perl-Digest perl-Net-Server cryptsetup mosh \ expect openssh-server netcat bash perl-CGI perl-Test-Simple passwd \ cracklib-dicts perl-Time-Piece perl-Time-HiRes diffutils \ perl-Sys-Syslog pamtester google-authenticator qrencode-libs \ perl-LWP-Protocol-https findutils tar" if [ "$DISTRO_VERSION_MAJOR" = 7 ]; then wanted_list="$wanted_list fortune-mod coreutils util-linux" else wanted_list="$wanted_list util-linux-user" fi [ "$opt_syslogng" = 1 ] && wanted_list="$wanted_list syslog-ng" if [ "$opt_install" = 1 ]; then if [ "$DISTRO_VERSION_MAJOR" = 8 ]; then # in December 2020, they added "-Linux" to their repo name, so trying both combinations # also try with "Rocky-" for RockyLinux for repo in PowerTools Extras do for prefix in CentOS CentOS-Linux Rocky do test -f /etc/yum.repos.d/$prefix-$repo.repo || continue sed -i -e 's/enabled=.*/enabled=1/g' /etc/yum.repos.d/$prefix-$repo.repo done done fi if command -v dnf >/dev/null; then dnf_or_yum=dnf else dnf_or_yum=yum fi $dnf_or_yum makecache $dnf_or_yum install -y epel-release # shellcheck disable=SC2086 $dnf_or_yum install -y $wanted_list exit 0 fi installed=$(rpm -qa --queryformat '%{NAME}\n') install_cmd="yum install" elif echo "$DISTRO_LIKE" | grep -q -w suse; then wanted_list="perl-common-sense perl-JSON perl-Net-Netmask perl-Net-IP \ perl-Net-DNS perl-DBD-SQLite perl-Term-ReadKey perl-DateTime \ fortune sudo fping perl perl-base \ xz sqlite3 binutils acl gpg2 rsync \ perl-JSON-XS inotify-tools lsof curl perl-TermReadLine-Gnu \ perl-libwww-perl perl-Digest perl-IO-Socket-SSL \ perl-Net-Server cryptsetup mosh expect openssh \ coreutils netcat-openbsd bash perl-CGI iputils \ perl-Time-HiRes perl-Unix-Syslog hostname perl-LWP-Protocol-https \ google-authenticator-libpam tar" [ "$opt_syslogng" = 1 ] && wanted_list="$wanted_list syslog-ng" if [ "$opt_install" = 1 ]; then # shellcheck disable=SC2086 zypper install -y $wanted_list exit $? fi installed=$(rpm -qa --queryformat '%{NAME}\n') install_cmd="zypper install" elif [ "$OS_FAMILY" = FreeBSD ]; then wanted_list="base64 coreutils rsync bash sudo pamtester p5-JSON p5-JSON-XS gnupg \ p5-common-sense p5-DateTime p5-Net-IP p5-DBD-SQLite p5-Net-Netmask lsof \ p5-Term-ReadKey expect fping p5-Net-Server p5-CGI p5-LWP-Protocol-https" install_cmd="pkg add" installed="" for i in $wanted_list do if pkg info -e "$i"; then installed="$installed $i" fi done if [ "$opt_install" = 1 ]; then # shellcheck disable=SC2086 pkg install -y $wanted_list exit $? fi else echo "This script doesn't support this OS yet ($DISTRO_LIKE)" >&2 exit 1 fi missing='' for i in $wanted_list ; do ok=0 for j in $installed ; do [ "$i" = "$j" ] && ok=1 && break done [ $ok = 1 ] || missing="$missing $i" done if [ -n "$missing" ] ; then action_error "Some packages are missing, to install them, use:" action_detail "$install_cmd$missing" else action_done "All needed packages are installed" fi