--- loncom/build/CHECKRPMS 2011/10/19 03:21:29 1.15 +++ loncom/build/CHECKRPMS 2019/10/23 20:34:39 1.19 @@ -3,7 +3,7 @@ # The LearningOnline Network with CAPA # Checks status of RPM packages on system. # -# $Id: CHECKRPMS,v 1.15 2011/10/19 03:21:29 raeburn Exp $ +# $Id: CHECKRPMS,v 1.19 2019/10/23 20:34:39 raeburn Exp $ # # Copyright Michigan State University Board of Trustees # @@ -32,7 +32,7 @@ =head1 NAME -B - automated status report about RPMs (RHEL/Fedora/CentOS/SuSE) +B - automated status report about RPMs (RHEL/Fedora/CentOS/Oracle Linux/SuSE/SLES) or debs (Debian/Ubuntu) on a system. =head1 DESCRIPTION @@ -42,10 +42,12 @@ to LON-CAPA systems. distprobe is used t The utility which is used to complete the check depends on the distro: -fedora, rhel >= 5, centos, scientific - yum +fedora < 22; rhel (5, 6, 7); centos/scientific/oracle linux <=7 - yum +fedora >= 22 - dnf +rhel/centos/oracle linux >= 8 - dnf suse 9.X and sles9 - you -suse 10.2,10.3,11.1,11.2,11.3,11.4,sles11 - zypper -sles10,suse10.1 - rug +suse 10.2, 10.3, 11.X and 12.X; sles (>= 11) - zypper +sles10, suse10.1 - rug rhel 4 - up2date debian, ubuntu - apt-get others - check-rpms @@ -92,10 +94,17 @@ if ($docroot ne '') { } my ($cmd,$send,$addsubj); -if ($distro =~ /^fedora\d+$/) { - $cmd = 'yum update'; - &prepare_msg($tmpfile,$cmd); - ($send,$addsubj) = &check_with_yum($tmpfile); +if ($distro =~ /^fedora(\d+)$/) { + my $version =$1; + if ($version > 21) { + $cmd = 'dnf update'; + &prepare_msg($tmpfile,$cmd); + ($send,$addsubj) = &check_with_yum_or_dnf($tmpfile,'dnf'); + } else { + $cmd = 'yum update'; + &prepare_msg($tmpfile,$cmd); + ($send,$addsubj) = &check_with_yum_or_dnf($tmpfile,'yum'); + } } elsif ($distro =~ /^(suse|sles)9\.?\d?$/) { $cmd = 'you'; &prepare_msg($tmpfile,$cmd); @@ -126,19 +135,26 @@ if ($distro =~ /^fedora\d+$/) { $cmd ='up2date -u --nox'; &prepare_msg($tmpfile,$cmd); ($send,$addsubj) = &check_with_up2date($tmpfile); - } elsif ($version > 4) { + } elsif ($version <= 7) { $cmd = 'yum update'; &prepare_msg($tmpfile,$cmd); - ($send,$addsubj) = &check_with_yum($tmpfile); + ($send,$addsubj) = &check_with_yum_or_dnf($tmpfile,'yum'); + } else { + $cmd = 'dnf update'; + &prepare_msg($tmpfile,$cmd); + ($send,$addsubj) = &check_with_yum_or_dnf($tmpfile,'dnf'); + } +} elsif ($distro =~ /^(?:centos|scientific|oracle)(\d+)$/) { + my $version = $1; + if ($version <= 7) { + $cmd = 'yum update'; + &prepare_msg($tmpfile,$cmd); + ($send,$addsubj) = &check_with_yum_or_dnf($tmpfile,'yum'); + } else { + $cmd = 'dnf update'; + &prepare_msg($tmpfile,$cmd); + ($send,$addsubj) = &check_with_yum_or_dnf($tmpfile,'dnf'); } -} elsif ($distro =~ /^centos\d+$/) { - $cmd = 'yum update'; - &prepare_msg($tmpfile,$cmd); - ($send,$addsubj) = &check_with_yum($tmpfile); -} elsif ($distro =~ /^scientific\d+$/) { - $cmd = 'yum update'; - &prepare_msg($tmpfile,$cmd); - ($send,$addsubj) = &check_with_yum($tmpfile); } elsif ($distro =~ /^(debian|ubuntu)\d+/) { $cmd = 'apt-get upgrade'; &prepare_msg($tmpfile,$cmd); @@ -154,7 +170,7 @@ if ($send) { if ($< == 0) { system("chown www:www $docroot/lon-status/checkrpms.txt"); } - chmod(0600,$docroot/lon-status/checkrpms.txt"); + chmod(0600,"$docroot/lon-status/checkrpms.txt"); } system(qq{mail -s '$subj' "$emailto" < $tmpfile}); } @@ -218,21 +234,26 @@ sub check_with_you { return ($sendflag,$append_to_subj); } -sub check_with_yum { - my ($tmpfile) = @_; - my $yum = '/usr/bin/yum'; +sub check_with_yum_or_dnf { + my ($tmpfile,$progname) = @_; + my $path_to_exec = '/usr/bin/'; + if ($progname eq 'dnf') { + $path_to_exec .= $progname; + } else { + $path_to_exec .= 'yum'; + } my $sendflag = 0; my $append_to_subj; # - # Execute yum command - my $command = $yum.' check-update '.'>>'.$tmpfile; + # Execute command + my $command = $path_to_exec.' check-update '.'>>'.$tmpfile; system($command); my $returnvalue = $?>>8; # - # Determine status of yum run + # Determine status of yum or dnf run if (100 == $returnvalue) { $sendflag = 1; $append_to_subj = ' RPMS to upgrade'; @@ -240,7 +261,7 @@ sub check_with_yum { $sendflag = 1; $append_to_subj = ' Error running RPM update script'; } else { - # yum returned 0, so everything is up to date. + # yum or dnf returned 0, so everything is up to date. } return ($sendflag,$append_to_subj); }