X-Git-Url: https://code.th-h.de/?p=usenet%2Fnewsstats.git;a=blobdiff_plain;f=install%2Finstall.pl;h=c78dfec8ac5488769c3157d3bb6130d4b02a0c80;hp=d45d9114fc02cf768bf0a13f55eaf69cdb29870b;hb=9c141b0ca758560ceff90d21f148dadc0336d78b;hpb=2832c235b2497a02713b12197ed97fbde3a91e15 diff --git a/install/install.pl b/install/install.pl index d45d911..c78dfec 100755 --- a/install/install.pl +++ b/install/install.pl @@ -28,10 +28,11 @@ use DBI; ################################# Main program ################################# ### read commandline options -my %Options = &ReadOptions(''); +my %Options = &ReadOptions('u:'); ### change working directory to .. (as we're in .../install) chdir dirname($0).'/..'; +my $Path = cwd(); ### read configuration print("Reading configuration.\n"); @@ -82,35 +83,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 + +my $Upgrade = < 0.02 +$DBUpgrade{'0.02'} = <table_info('%', '%', '%', 'TABLE')->fetchall_hashref('TABLE_NAME')}; + +if (!$Options{'u'}) { + ##### 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"; + if ($Options{'u'} < $PackageVersion) { + # Database upgrades for each version + foreach my $UpVersion (sort keys %DBUpgrade) { + if ($UpVersion > $Options{'u'} and $UpVersion <= $PackageVersion) { + print "v$UpVersion: Executing database upgrade ...\n"; + &DoMySQL($DBUpgrade{$UpVersion}); + }; + }; + # Display upgrade instructions for each version + foreach my $UpVersion (sort keys %Instructions) { + if ($UpVersion > $Options{'u'} and $UpVersion <= $PackageVersion) { + print "v$UpVersion: Upgrade Instructions >>>>>\n"; + my $Padding = ' ' x (length($UpVersion) + 3); + $Instructions{$UpVersion} =~ s/^/$Padding/; + print $Instructions{$UpVersion}; + print "<" x (length($UpVersion) + 29) . "\n"; + }; + }; + }; + # Display upgrade instructions + print $Upgrade; +}; + +# close handle +$DBHandle->disconnect; + +exit(0); + +################################# Subroutines ################################## + +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 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}); + return; +}; + +sub DoMySQL() { + my $SQL = shift; + my $DBQuery = $DBHandle->prepare($SQL); + $DBQuery->execute() or warn sprintf("$MySelf: E: Database error: %s\n",$DBI::errstr); + return; +}; + __END__