File:  [LON-CAPA] / loncom / build / Attic / CHECKRPMS.default
Revision 1.5: download - view: text, annotated - select for diffs
Thu Sep 5 18:09:54 2002 UTC (22 years, 3 months ago) by harris41
Branches: MAIN
CVS tags: HEAD
BUG 719 FIX.  Add commenting and conforming to GNU coding style.

#!/usr/bin/perl

=pod

=head1 NAME

B<CHECKRPMS> - automated status report about RPMs on a system

=head1 SYNOPSIS

./CHECKRPMS

or

perl CHECKRPMS

=head1 DESCRIPTION

This file automates the usage of Martin Siegert's "check-rpms"
script.  It runs through a list of possible mirror sites
until it finds one with a reasonably good FTP connection.

=head2 Future directions

Eventually, this script may have a simple argument format
that allows the user to VIEW, DOWNLOAD, or AUTOUPDATE their
computer.  Or, this script may evolve into an interactive
series of steps:  For example, there may be questions like this:

=over 4

=item *

Do you want to (D)ownload or (A)utoupdate the RPMs
in the list above?

=item *

Specify a download location for the RPMs
(default=/tmp/update_my_rpms/)?

=back

Note that there are no current plans to automate a software upgrade of the
kernel.  This step should be performed by a qualified system administrator.

=head1 AUTHOR

Scott Harrison, sharrison@users.sourceforge.net, 2002

=cut

# =================================================== READ IN COMMAND ARGUMENTS
# ---------------------------------------------------- Process download option.
my $download=shift(@ARGV);
if ($download eq '--download')
  {
    if ($< != 0) # Download mode requires 'root'.
      {
        print('**** ERROR **** Download mode needs to be run as root'."\n");
	exit(1); # Exit with error status.
      }
    `rm -Rf /tmp/loncapa_rpm_updates`;
    $download='-v -dl -d /tmp/loncapa_rpm_updates'; # Part of check-rpms args.
  }
else
  {
    $download='';
  }

# =================================================== GENERAL INITIAL VARIABLES
# ---------------- The FTP servers (and their directory paths) to check against
my @serverpaths_to_try = 
  (
    'mirror.pa.msu.edu/linux/redhat/linux/updates/',
    'rufus.w3.org/linux/redhat/linux/updates/',
    'distro.ibiblio.org/pub/linux/distributions/redhat/updates/',
    'limestone.uoregon.edu/redhat/updates/',
    'opnsrc.support.compaq.com/linux/redhat/updates.redhat.com/',
  );

# --------------------------------------------------- Determine RedHat version.
my $RHversion = (split /\s/, `cat /etc/redhat-release`)[4]; # - 6.2 or 7.3 or ?

 # ------------------------------------------- Use check-rpms command this way.
my $checkcommand = 'check-rpms '.$download.' --rpmuser www -ftp';

my $FTPSERVER; # ------------------------- the server portion of the serverpath
my $FTPUPDATES; # ----------------------------- the actual update root location
my @rpms; # ---------------------------------- this will store the list of RPMs
my $goodoutput; # ------------------------------------ good stuff was returned!
my $reallygoodoutput; # ------------------------------- you are 100% up-to-date

# ----------------------------------------- Find the check-rpms script location
if (-e './check-rpms')
  {
    $commandpre='perl ./'; # Use the check-rpms in the current directory.
  }
elsif (-e 'loncom/build/check-rpms')
  {
    $commandpre='perl loncom/build/'; # Use check-rpms int he loncom/build dir.
  }
else # Cannot find check-rpms, so abort.
  {
    die("**** ERROR **** CANNOT FIND THE check-rpms SCRIPT\n");
  }

# Define the overall check-rpms invocation based on the path to the check-rpms
# command.
$checkcommand = $commandpre.$checkcommand;

# ============== Go through all the servers until a decent connection is found.
# Notify user of current action.
print(<<END);
THIS SCRIPT IS NOW PROBING SEVERAL FTP SERVERS....
PLEASE BE PATIENT, THIS MAY TAKE A FEW MINUTES.
END

SERVERLOOP: foreach my $serverpath (@serverpaths_to_try)
  {
    $serverpath=~/^(.*?)\//; # Pattern match the ip name.
    $FTPSERVER=$1; # Set to the ip name.
    print "Trying $FTPSERVER...\n"; # Notify user of attempts with the ip name.
    `ping -c 1 $FTPSERVER 2>/dev/null`; # Ping ftp server (are you out there?).
    if ($?==0) # If the ftp server can be pinged.
      {
	print "$FTPSERVER found...\n"; # Tell user the ftp server is found.
	`ncftpls ftp://$FTPSERVER`; # Try to access server with ftp protocol.
	if ($?==0) # If the ftp server can be accessed with the ftp protocol.
          {
	    $FTPUPDATES="$serverpath$RHversion/en/os"; # The full update path.
	    # Print the check-rpms command that will be executed.
	    print($checkcommand.' '.$FTPUPDATES."\n");
	    if ($download) # Was CHECKRPMS run in download mode?
              {
		$|=1; # Try to send things immediately to stdout; err umm....
		# Tell the user about the /tmp/loncapa_rpm_updates directory.
		print('**** NOTE ****'.
		      'To check the status of the download, you can '.
		      'periodically inspect the contents of the '.
		      '/tmp/loncapa_rpm_updates directory.  '.
		      'Please be patient; this download may take a while.'.
		      "\n");
		# Do the download.
		print(`$checkcommand $FTPUPDATES 2>\&1`);
		# Tell the user about what action they need to take with the
		# downloaded RPMs.
		print('You may now wish to visit the /tmp/loncapa_rpm_updates'.
		      ' directory and upgrade the RPMs.  '."\n".
		      'If this is a critical server (it is currently being'.
		      ' used for classes) and you do not know how to upgrade'.
		      ' RPMs, you should consult someone who has experience '.
		      'with the "rpm" command.'."\n");
		exit(0); # Assume everything is okay and exit.
	      }
	    @rpms=`$checkcommand $FTPUPDATES 2>\&1`; # Read in list of RPMs.
	    # Create a text string that can be pattern matched.
	    my $rpmtext=join('',@rpms);
	    if ($rpmtext=~/You do not seem to have a/) # No www?
              {
		print "You do not have a 'www' user on your system.\n".
		    "Please add this user and try this command again.\n";
		exit(1);
	      }
	    if ($rpmtext=~/This account is currently not/) # ------------ uh-oh
	      {
		print "...strange error, moving on ($FTPSERVER)\n";
	      }
	    else # --------------------------------------- the output is "good"
	      {
		$goodoutput=$rpmtext;
		unless (@rpms) # If there are no RPMs to update.
		  {
		    $reallygoodoutput=<<END;
**** NOTE **** All RPMS on your system appear to be up to date.
END
		  }
		last SERVERLOOP;
	      }
	  }
	print('...cannot establish an ftp session with '.$FTPSERVER."\n");
      }
    else
      {
	print "...cannot find $FTPSERVER on the network\n";
      }
  }
if (!$goodoutput) # If never received any useable output, assume "no server".
  {
    print "**** ERROR **** Cannot find a working ftp server.\n";
    exit(1);
  }
elsif ($reallygoodoutput) # Everything is peachy keen and up-to-date already.
  {
    print $reallygoodoutput;
  }
else # There are RPMs that need to be updated; show list to user.
  {
    my $rpmcount=scalar(@rpms); # Count up size of RPM list.
    print(<<END); # Print out an advisory warning to user.
**** WARNING **** You need to update at least $rpmcount RPMS shown in
the list below.  THIS IS IMPORTANT FOR SECURITY.

END
    print $goodoutput; # Output the RPM list.
    print(<<END); # Output instructions to user about taking action.

Please visit ftp://$FTPUPDATES
and download the RPMS you need.
For instructions on working with (and upgrading) RPMS, please
visit http://www.rpm.org/max-rpm/.
To automatically download these RPMs to /tmp/loncapa_rpm_updates/,
run the CHECKRPMS command as "./CHECKRPMS --download"
END
  }

FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>