X-Git-Url: https://code.th-h.de/?p=usenet%2Fnewsstats.git;a=blobdiff_plain;f=install%2Finstall.pl;h=61e8ef1ee8a3ab27bb35307316ac76235f0e3a08;hp=d45d9114fc02cf768bf0a13f55eaf69cdb29870b;hb=1fa947994652e526566d286e1527e2b58860cc83;hpb=2832c235b2497a02713b12197ed97fbde3a91e15 diff --git a/install/install.pl b/install/install.pl index d45d911..61e8ef1 100755 --- a/install/install.pl +++ b/install/install.pl @@ -6,7 +6,7 @@ # # It is part of the NewsStats package. # -# Copyright (c) 2010 Thomas Hochstein +# Copyright (c) 2010-2012 Thomas Hochstein # # It can be redistributed and/or modified under the same terms under # which Perl itself is published. @@ -24,18 +24,24 @@ use NewsStats qw(:DEFAULT); use Cwd; use DBI; +use Getopt::Long qw(GetOptions); +Getopt::Long::config ('bundling'); ################################# Main program ################################# ### read commandline options -my %Options = &ReadOptions(''); +my ($OptUpdate); +GetOptions ('u|update=s' => \$OptUpdate, + 'h|help' => \&ShowPOD, + 'V|version' => \&ShowVersion) or exit 1; ### change working directory to .. (as we're in .../install) chdir dirname($0).'/..'; +my $Path = cwd(); ### read configuration print("Reading configuration.\n"); -my %Conf = %{ReadConfig('newsstats.conf')}; +my %Conf = %{ReadConfig($HomePath.'/newsstats.conf')}; ##### -------------------------------------------------------------------------- ##### Database table definitions @@ -82,35 +88,12 @@ CREATE TABLE IF NOT EXISTS `$Conf{'DBTableGrps'}` ( ) ENGINE=MyISAM DEFAULT CHARSET=utf8 COMMENT='Postings per newsgroup'; GRPS -##### --------------------------- End of definitions --------------------------- - -### create database tables -print "-----\nStarting database table generation.\n"; -# DB init -my $DBHandle = InitDB(\%Conf,1); - -# read tables -my %TablesInDB = %{$DBHandle->table_info('%', '%', '%', 'TABLE')->fetchall_hashref('TABLE_NAME')}; - -# check for tables and create them, if they don't exist yet -foreach my $Table (keys %DBCreate) { - if (defined($TablesInDB{$Conf{$Table}})) { - printf("Database table %s.%s already exists, skipping ....\n",$Conf{'DBDatabase'},$Conf{$Table}); - next; - }; - my $DBQuery = $DBHandle->prepare($DBCreate{$Table}); - $DBQuery->execute() or die sprintf("$MySelf: E: Can't create table %s in database %s: %s%\n",$Table,$Conf{'DBDatabase'},$DBI::errstr); - printf("Database table %s.%s created succesfully.\n",$Conf{'DBDatabase'},$Conf{$Table}); -}; - -# close handle -$DBHandle->disconnect; -print "Database table generation done.\n"; +##### -------------------------------------------------------------------------- +##### Installation / upgrade instructions +##### -------------------------------------------------------------------------- -### output information on other necessary steps -my $Path = cwd(); -print < -TODO +INSTALL -__END__ +my $Upgrade = < [B<-Vh>] +### DB init, read list of tables +print "Reading database information.\n"; +my $DBHandle = InitDB(\%Conf,1); +my %TablesInDB = + %{$DBHandle->table_info('%', '%', '%', 'TABLE')->fetchall_hashref('TABLE_NAME')}; + +if (!$OptUpdate) { + ##### installation mode + print "----------\nStarting database table generation.\n"; + # check for tables and create them, if they don't exist yet + foreach my $Table (keys %DBCreate) { + &CreateTable($Table); + }; + print "Database table generation done.\n"; + + # Display install instructions + print $Install; +} else { + ##### upgrade mode + print "----------\nStarting upgrade process.\n"; + $PackageVersion = '0.03'; + if ($OptUpdate < $PackageVersion) { + if ($OptUpdate < 0.02) { + # 0.01 -> 0.02 + # &DoMySQL('...;'); + # print "v0.02: Database upgrades ...\n"; + # &PrintInstructions('0.02',<<" INSTRUCTIONS"); + # INSTRUCTIONS + }; + }; + # Display general upgrade instructions + print $Upgrade; +}; -=head1 REQUIREMENTS +# close handle +$DBHandle->disconnect; -See doc/README: Perl 5.8.x itself and the following modules from CPAN: +exit(0); -=over 2 +################################# Subroutines ################################## -=item - +sub CreateTable { + my $Table = shift; + if (defined($TablesInDB{$Conf{$Table}})) { + printf("Database table %s.%s already exists, skipping ....\n", + $Conf{'DBDatabase'},$Conf{$Table}); + return; + }; + my $DBQuery = $DBHandle->prepare($DBCreate{$Table}); + $DBQuery->execute() or + &Bleat(2, sprintf("Can't create table %s in database %s: %s%\n",$Table, + $Conf{'DBDatabase'},$DBI::errstr)); + printf("Database table %s.%s created succesfully.\n", + $Conf{'DBDatabase'},$Conf{$Table}); + return; +}; -Config::Auto +sub DoMySQL { + my $SQL = shift; + my $DBQuery = $DBHandle->prepare($SQL); + $DBQuery->execute() or &Bleat(1, sprintf("Database error: %s\n",$DBI::errstr)); + return; +}; -=item - +sub PrintInstructions { + my ($UpVersion,$Instructions) = @_; + print "v$UpVersion: Upgrade Instructions >>>>>\n"; + my $Padding = ' ' x (length($UpVersion) + 3); + $Instructions =~ s/^ /$Padding/mg; + print $Instructions; + print "<" x (length($UpVersion) + 29) . "\n"; +}; -DBI -=back +__END__ + +################################ Documentation ################################# + +=head1 NAME + +install - installation script + +=head1 SYNOPSIS + +B [B<-Vh> [--update I] + +=head1 REQUIREMENTS + +See L. =head1 DESCRIPTION @@ -185,23 +243,27 @@ This script will create database tables as necessary and configured. =head2 Configuration -F will read its configuration from F via +B will read its configuration from F via Config::Auto. -See doc/INSTALL for an overview of possible configuration options. +See L for an overview of possible configuration options. =head1 OPTIONS =over 3 -=item B<-V> (version) +=item B<-V>, B<--version> -Print out version and copyright information on B and exit. +Print out version and copyright information and exit. -=item B<-h> (help) +=item B<-h>, B<--help> Print this man page and exit. +=item B<-u>, B<--update> I + +Don't do a fresh install, but update from I. + =back =head1 FILES @@ -218,7 +280,7 @@ Library functions for the NewsStats package. =item F -Runtime configuration file for B. +Runtime configuration file. =back @@ -233,11 +295,11 @@ bug tracker at L! =item - -doc/README +L =item - -doc/INSTALL +L =back @@ -249,7 +311,7 @@ Thomas Hochstein =head1 COPYRIGHT AND LICENSE -Copyright (c) 2010 Thomas Hochstein +Copyright (c) 2010-2012 Thomas Hochstein This program is free software; you may redistribute it and/or modify it under the same terms as Perl itself.