version 1.9, 2011/04/24 01:25:13
|
version 1.20, 2011/06/07 15:17:51
|
Line 195 sub get_distro {
|
Line 195 sub get_distro {
|
$distro = 'centos'.$1; |
$distro = 'centos'.$1; |
$updatecmd = 'yum install LONCAPA-prerequisites'; |
$updatecmd = 'yum install LONCAPA-prerequisites'; |
$installnow = 'yum -y install LONCAPA-prerequisites'; |
$installnow = 'yum -y install LONCAPA-prerequisites'; |
} elsif ($versionstring =~ /Scientific Linux SL release ([\d.]+) /) { |
} elsif ($versionstring =~ /Scientific Linux (SL )?release ([\d.]+) /) { |
my $ver = $1; |
my $ver = $1; |
$ver =~ s/\.\d+$//; |
$ver =~ s/\.\d+$//; |
$distro = 'scientific'.$ver; |
$distro = 'scientific'.$ver; |
Line 219 sub get_distro {
|
Line 219 sub get_distro {
|
} |
} |
} elsif ($versionstring =~ /^SuSE Linux ([\d\.]+) /i) { |
} elsif ($versionstring =~ /^SuSE Linux ([\d\.]+) /i) { |
$distro = 'suse'.$1; |
$distro = 'suse'.$1; |
$updatecmd = 'yast -i LONCAPA-preprequisites'; |
$updatecmd = 'yast -i LONCAPA-prerequisites'; |
} elsif ($versionstring =~ /^openSUSE ([\d\.]+) /i) { |
} elsif ($versionstring =~ /^openSUSE ([\d\.]+) /i) { |
$distro = 'suse'.$1; |
$distro = 'suse'.$1; |
if ($1 >= 10.3 ) { |
if ($1 >= 10.3 ) { |
Line 425 sub check_mysql_running {
|
Line 425 sub check_mysql_running {
|
print_and_log(&mt('MySQL is running.')."\n"); |
print_and_log(&mt('MySQL is running.')."\n"); |
return 1; |
return 1; |
} else { |
} else { |
system("/etc/rc.d/init.d/$mysqldaemon start"); |
system("/etc/init.d/$mysqldaemon start >/dev/null 2>&1 "); |
print_and_log(&mt('Waiting for MySQL to start.')."\n"); |
print_and_log(&mt('Waiting for MySQL to start.')."\n"); |
sleep 5; |
sleep 5; |
if (open (PIPE, "/etc/init.d/$mysqldaemon 2>&1 |")) { |
if (open(PIPE,"ps -ef |grep $process |grep -v grep 2>&1 |")) { |
my $status = <PIPE>; |
$status = <PIPE>; |
close(PIPE); |
close(PIPE); |
chomp($status); |
chomp($status); |
if ($status =~ /\(pid\s+\d\)/) { |
if ($status =~ /^\Q$proc_owner\E\s+\d+\s+/) { |
print_and_log(&mt('MySQL is running.')."\n"); |
print_and_log(&mt('MySQL is running.')."\n"); |
return 1; |
return 1; |
} else { |
} else { |
print_and_log(&mt('Unable to start MySQL.')."\n"); |
print_and_log(&mt('Still waiting for MySQL to start.')."\n"); |
|
sleep 5; |
|
if (open(PIPE,"ps -ef |grep $process |grep -v grep 2>&1 |")) { |
|
$status = <PIPE>; |
|
close(PIPE); |
|
chomp($status); |
|
if ($status =~ /^\Q$proc_owner\E\s+\d+\s+/) { |
|
print_and_log(&mt('MySQL is running.')."\n"); |
|
return 1; |
|
} else { |
|
print_and_log(&mt('Given up waiting for MySQL to start.')."\n"); |
|
} |
|
} |
} |
} |
} else { |
|
print_and_log(&mt('Unable to start MySQL.')."\n"); |
|
} |
} |
} |
} |
} else { |
} else { |
Line 490 sub chkconfig {
|
Line 500 sub chkconfig {
|
my $nrlstr = join('',@norunlevels); |
my $nrlstr = join('',@norunlevels); |
foreach my $type ('apache','mysql','ntp','cups','memcached') { |
foreach my $type ('apache','mysql','ntp','cups','memcached') { |
my $service = $daemon{$type}; |
my $service = $daemon{$type}; |
my $command = $checker_bin.' --list '.$service; |
if ($type eq 'ntp') { |
|
if ($distro =~ /^(?:fedora)(\d+)/) { |
|
my $version = $1; |
|
if ($version >= 15) { |
|
if (!-l "/etc/systemd/system/multi-user.target.wants/ntpd.service") { |
|
$needfix{$type} = 'systemctl enable ntpd.service'; |
|
} |
|
next; |
|
} |
|
} |
|
} |
|
my $command = $checker_bin.' --list '.$service.' 2>/dev/null'; |
if ($type eq 'cups') { |
if ($type eq 'cups') { |
if ($distro =~ /^(?:debian|ubuntu)(\d+)/) { |
if ($distro =~ /^(?:debian|ubuntu)(\d+)/) { |
my $version = $1; |
my $version = $1; |
if (($distro =~ /^ubuntu/) && ($version <= 8)) { |
if (($distro =~ /^ubuntu/) && ($version <= 8)) { |
$command = $checker_bin.' --list cupsys'; |
$command = $checker_bin.' --list cupsys 2>/dev/null'; |
} |
} |
} |
} |
} |
} |
Line 590 sub chkapache {
|
Line 611 sub chkapache {
|
my ($distro,$instdir) = @_; |
my ($distro,$instdir) = @_; |
my $fixapache = 1; |
my $fixapache = 1; |
if ($distro =~ /^(debian|ubuntu)/) { |
if ($distro =~ /^(debian|ubuntu)/) { |
if (!-e "$instdir/debian-ubuntu/apache2.conf") { |
if (!-e "$instdir/debian-ubuntu/loncapa") { |
$fixapache = 0; |
$fixapache = 0; |
print &mt('Warning: No LON-CAPA Apache configuration file found for installation check.')."\n"; |
print &mt('Warning: No LON-CAPA Apache configuration file found for installation check.')."\n"; |
} elsif ((-e "/etc/apache2/sites-available/loncapa") && (-e "$instdir/debian-ubuntu/apache2.conf")) { |
} elsif ((-e "/etc/apache2/sites-available/loncapa") && (-e "$instdir/debian-ubuntu/loncapa")) { |
if (open(PIPE, "diff --brief $instdir/debian-ubuntu/apache2.conf /etc/apache2/sites-available/loncapa |")) { |
if (open(PIPE, "diff --brief $instdir/debian-ubuntu/loncapa /etc/apache2/sites-available/loncapa |")) { |
my $diffres = <PIPE>; |
my $diffres = <PIPE>; |
close(PIPE); |
close(PIPE); |
chomp($diffres); |
chomp($diffres); |
Line 643 sub chkapache {
|
Line 664 sub chkapache {
|
} |
} |
} |
} |
} else { |
} else { |
if (!-e "$instdir/centos-rhes-fedora-sl/httpd.conf") { |
my $configfile = 'httpd.conf'; |
|
if ($distro =~ /^(?:centos|rhes|scientific)(\d+)$/) { |
|
if ($1 > 5) { |
|
$configfile = 'new/httpd.conf'; |
|
} |
|
} elsif ($distro =~ /^fedora(\d+)$/) { |
|
if ($1 > 10) { |
|
$configfile = 'new/httpd.conf'; |
|
} |
|
} |
|
if (!-e "$instdir/centos-rhes-fedora-sl/$configfile") { |
$fixapache = 0; |
$fixapache = 0; |
print &mt('Warning: No LON-CAPA Apache configuration file found for installation check.')."\n"; |
print &mt('Warning: No LON-CAPA Apache configuration file found for installation check.')."\n"; |
} elsif ((-e "/etc/httpd/conf/httpd.conf") && (-e "$instdir/centos-rhes-fedora-sl/httpd.conf")) { |
} elsif ((-e "/etc/httpd/conf/httpd.conf") && (-e "$instdir/centos-rhes-fedora-sl/$configfile")) { |
if (open(PIPE, "diff --brief $instdir/centos-rhes-fedora-sl/httpd.conf /etc/httpd/conf/httpd.conf |")) { |
if (open(PIPE, "diff --brief $instdir/centos-rhes-fedora-sl/$configfile /etc/httpd/conf/httpd.conf |")) { |
my $diffres = <PIPE>; |
my $diffres = <PIPE>; |
close(PIPE); |
close(PIPE); |
chomp($diffres); |
chomp($diffres); |
Line 678 sub chksrvcs {
|
Line 709 sub chksrvcs {
|
chomp($daemonrunning); |
chomp($daemonrunning); |
close(PIPE); |
close(PIPE); |
if ($daemonrunning) { |
if ($daemonrunning) { |
$stopsrvcs{$service} = 1; |
if ($service eq 'memcached') { |
|
my $cmd = '/usr/bin/memcached'; |
|
if ($distro =~ /^(suse|sles)/) { |
|
$cmd = '/usr/sbin/memcached'; |
|
} |
|
unless ($daemonrunning =~ m{^www[^/]+\Q$cmd -m 400 -v\E$}) { |
|
$stopsrvcs{$service} = 1; |
|
} |
|
} else { |
|
$stopsrvcs{$service} = 1; |
|
} |
} |
} |
} |
} |
} |
} |
return \%stopsrvcs; |
return \%stopsrvcs; |
} |
} |
|
|
Line 817 sub check_mysql_setup {
|
Line 858 sub check_mysql_setup {
|
|
|
sub check_mysql_wwwuser { |
sub check_mysql_wwwuser { |
my $mysql_wwwuser; |
my $mysql_wwwuser; |
my $dbhn = DBI->connect("DBI:mysql:database=information_schema",'www','localhostkey'); |
my $dbhn = DBI->connect("DBI:mysql:database=information_schema",'www','localhostkey', |
|
{PrintError => +0}) || return; |
if ($dbhn) { |
if ($dbhn) { |
$mysql_wwwuser = 1; |
$mysql_wwwuser = 1; |
$dbhn->disconnect; |
$dbhn->disconnect; |
Line 1086 if ($localecmd ne '') {
|
Line 1128 if ($localecmd ne '') {
|
exit; |
exit; |
} |
} |
if (!$gotprereqs) { |
if (!$gotprereqs) { |
print "\n".&mt('The LONCAPA-prequisites package is not installed.')."\n". |
print "\n".&mt('The LONCAPA-prerequisites package is not installed.')."\n". |
&mt('The following command can be used to install the package (and dependencies):')."\n\n". |
&mt('The following command can be used to install the package (and dependencies):')."\n\n". |
$updatecmd."\n\n"; |
$updatecmd."\n\n"; |
if ($installnow eq '') { |
if ($installnow eq '') { |
Line 1100 if (!$gotprereqs) {
|
Line 1142 if (!$gotprereqs) {
|
close(PIPE); |
close(PIPE); |
$gotprereqs = &check_prerequisites($packagecmd,$distro); |
$gotprereqs = &check_prerequisites($packagecmd,$distro); |
if (!$gotprereqs) { |
if (!$gotprereqs) { |
print &mt('The LONCAPA-prequisites package is not installed.')."\n". |
print &mt('The LONCAPA-prerequisites package is not installed.')."\n". |
&mt('Stopping execution.')."\n"; |
&mt('Stopping execution.')."\n"; |
exit; |
exit; |
} else { |
} else { |
Line 1110 if (!$gotprereqs) {
|
Line 1152 if (!$gotprereqs) {
|
&check_required($instdir,$dsn); |
&check_required($instdir,$dsn); |
} |
} |
} else { |
} else { |
print &mt('Failed to run command to install LONCAPA-prequisites')."\n"; |
print &mt('Failed to run command to install LONCAPA-prerequisites')."\n"; |
exit; |
exit; |
} |
} |
} else { |
} else { |
Line 1180 if ($callsub{'download'}) {
|
Line 1222 if ($callsub{'download'}) {
|
print &mt('The most recent LON-CAPA release is version: [_1].',$production)."\n". |
print &mt('The most recent LON-CAPA release is version: [_1].',$production)."\n". |
&mt('Download the production release? ~[Y/n~]'); |
&mt('Download the production release? ~[Y/n~]'); |
if (&get_user_selection(1)) { |
if (&get_user_selection(1)) { |
$sourcetarball = $production.'tar.gz'; |
$sourcetarball = 'loncapa-'.$production.'.tar.gz'; |
} |
} |
} |
} |
} elsif ($filetouse ne '') { |
} elsif ($filetouse ne '') { |
Line 1234 if ($callsub{'apache'}) {
|
Line 1276 if ($callsub{'apache'}) {
|
} elsif ($distro =~ /^(debian|ubuntu)/) { |
} elsif ($distro =~ /^(debian|ubuntu)/) { |
©_apache2_debconf($instdir); |
©_apache2_debconf($instdir); |
} else { |
} else { |
©_httpd_conf($instdir); |
©_httpd_conf($instdir,$distro); |
} |
} |
} else { |
} else { |
print_and_log(&mt('Skipping configuration of Apache web server.')."\n"); |
print_and_log(&mt('Skipping configuration of Apache web server.')."\n"); |
Line 1258 if ($callsub{'runlevels'}) {
|
Line 1300 if ($callsub{'runlevels'}) {
|
} |
} |
} |
} |
} |
} |
&update_SuSEfirewall2_setup($instdir); |
if ($distro =~ /^(suse|sles)/) { |
|
&update_SuSEfirewall2_setup($instdir); |
|
} |
} else { |
} else { |
&print_and_log(&mt('Skipping setting override for start-up order of services.')."\n"); |
&print_and_log(&mt('Skipping setting override for start-up order of services.')."\n"); |
} |
} |
Line 1284 if ($callsub{'firewall'}) {
|
Line 1328 if ($callsub{'firewall'}) {
|
} |
} |
} |
} |
} |
} |
|
} elsif ($distro =~ /^scientific/) { |
|
print &mt('Use [_1] to configure the firewall to allow access for [_2].', |
|
'system-config-firewall-tui -- Customize', |
|
'ssh, http')."\n"; |
} else { |
} else { |
print &mt('Use [_1] to configure the firewall to allow access for [_2].', |
print &mt('Use [_1] to configure the firewall to allow access for [_2].', |
'setup -- Firewall confiuration -> Customize', |
'setup -- Firewall configuration -> Customize', |
'ssh, http, https')."\n"; |
'ssh, http, https')."\n"; |
} |
} |
} else { |
} else { |
Line 1296 if ($callsub{'firewall'}) {
|
Line 1344 if ($callsub{'firewall'}) {
|
if ($callsub{'stopsrvcs'}) { |
if ($callsub{'stopsrvcs'}) { |
&kill_extra_services($distro,$recommended->{'stopsrvcs'}); |
&kill_extra_services($distro,$recommended->{'stopsrvcs'}); |
} else { |
} else { |
&print_and_log(&mt('Skipping stopping unnecessary service ([_1] daemon).',"'cups'")."\n"); |
&print_and_log(&mt('Skipping stopping unnecessary service ([_1] daemons).',"'cups','memcached'")."\n"); |
} |
} |
|
|
my ($have_tarball,$updateshown); |
my ($have_tarball,$updateshown); |
Line 1449 ENDPATCH
|
Line 1497 ENDPATCH
|
## Compile patched pwauth |
## Compile patched pwauth |
## |
## |
print_and_log(&mt('Compiling pwauth')."\n"); |
print_and_log(&mt('Compiling pwauth')."\n"); |
my $result = `cd $dir/; make`; |
my $result = `cd $dir/; make 2>/dev/null `; |
my $expected = <<"END"; |
my $expected = <<"END"; |
gcc -g -c -o pwauth.o pwauth.c |
gcc -g -c -o pwauth.o pwauth.c |
gcc -o pwauth -g pwauth.o -lcrypt |
gcc -o pwauth -g pwauth.o -lcrypt |
Line 1498 sub kill_extra_services {
|
Line 1546 sub kill_extra_services {
|
if (($distro =~ /^ubuntu/) && ($version <= 8)) { |
if (($distro =~ /^ubuntu/) && ($version <= 8)) { |
$daemon = 'cupsys'; |
$daemon = 'cupsys'; |
} |
} |
} elsif ($distro =~ /^(?:suse|sles)/) { |
} else { |
$daemon = 'cups'; |
$daemon = 'cups'; |
} |
} |
} |
} |
&print_and_log(`/etc/init.d/$daemon stop`); |
my $cmd = "ps -ef |grep '$daemon' |grep -v grep"; |
|
if (open(PIPE,'-|',$cmd)) { |
|
my $daemonrunning = <PIPE>; |
|
chomp($daemonrunning); |
|
close(PIPE); |
|
if ($daemonrunning) { |
|
&print_and_log(`/etc/init.d/$daemon stop`); |
|
} |
|
} |
&print_and_log(&mt('Removing [_1] from startup.',$service)."\n"); |
&print_and_log(&mt('Removing [_1] from startup.',$service)."\n"); |
if ($distro =~ /^(debian|ubuntu)/) { |
if ($distro =~ /^(debian|ubuntu)/) { |
&print_and_log(`update-rc.d -f $daemon remove`); |
&print_and_log(`update-rc.d -f $daemon remove`); |
} else { |
} else { |
&print_and_log(`chkconfig --del $service`); |
&print_and_log(`/sbin/chkconfig --del $service`); |
} |
} |
} |
} |
} |
} |
Line 1524 sub setup_mysql {
|
Line 1580 sub setup_mysql {
|
} |
} |
push(@mysql_lc_commands,"USE loncapa"); |
push(@mysql_lc_commands,"USE loncapa"); |
push(@mysql_lc_commands,qq{ |
push(@mysql_lc_commands,qq{ |
CREATE TABLE IF NOT EXISTS metadata (title TEXT, author TEXT, subject TEXT, url TEXT, keywords TEXT, version TEXT, notes TEXT, abstract TEXT, mime TEXT, language TEXT, creationdate DATETIME, lastrevisiondate DATETIME, owner TEXT, copyright TEXT, FULLTEXT idx_title (title), FULLTEXT idx_author (author), FULLTEXT idx_subject (subject), FULLTEXT idx_url (url), FULLTEXT idx_keywords (keywords), FULLTEXT idx_version (version), FULLTEXT idx_notes (notes), FULLTEXT idx_abstract (abstract), FULLTEXT idx_mime (mime), FULLTEXT idx_language (language), FULLTEXT idx_owner (owner), FULLTEXT idx_copyright (copyright)) TYPE=MYISAM |
CREATE TABLE IF NOT EXISTS metadata (title TEXT, author TEXT, subject TEXT, url TEXT, keywords TEXT, version TEXT, notes TEXT, abstract TEXT, mime TEXT, language TEXT, creationdate DATETIME, lastrevisiondate DATETIME, owner TEXT, copyright TEXT, domain TEXT, dependencies TEXT, modifyinguser TEXT, authorspace TEXT, lowestgradelevel TEXT, highestgradelevel TEXT, standards TEXT, count INT, course INT, course_list TEXT, goto INT, goto_list TEXT, comefrom INT, comefrom_list TEXT, sequsage INT, sequsage_list TEXT, stdno INT, stdno_list TEXT, avetries FLOAT, avetries_list TEXT, difficulty FLOAT, difficulty_list TEXT, disc FLOAT, disc_list TEXT, clear FLOAT, technical FLOAT, correct FLOAT, helpful FLOAT, depth FLOAT, hostname TEXT, FULLTEXT idx_title (title), FULLTEXT idx_author (author), FULLTEXT idx_subject (subject), FULLTEXT idx_url (url), FULLTEXT idx_keywords (keywords), FULLTEXT idx_version (version), FULLTEXT idx_notes (notes), FULLTEXT idx_abstract (abstract), FULLTEXT idx_mime (mime), FULLTEXT idx_language (language), FULLTEXT idx_owner (owner), FULLTEXT idx_copyright (copyright)) ENGINE=MYISAM |
}); |
}); |
if ($setup_mysql_permissions) { |
if ($setup_mysql_permissions) { |
&setup_mysql_permissions($dbh,$has_pass,@mysql_lc_commands); |
&setup_mysql_permissions($dbh,$has_pass,@mysql_lc_commands); |
Line 1654 sub get_mysql_version {
|
Line 1710 sub get_mysql_version {
|
########################################################### |
########################################################### |
|
|
sub copy_httpd_conf { |
sub copy_httpd_conf { |
my ($instdir) = @_; |
my ($instdir,$distro) = @_; |
|
my $configfile = 'httpd.conf'; |
|
if ($distro =~ /^(?:centos|rhes|scientific)(\d+)$/) { |
|
if ($1 > 5) { |
|
$configfile = 'new/httpd.conf'; |
|
} |
|
} elsif ($distro =~ /^fedora(\d+)$/) { |
|
if ($1 > 10) { |
|
$configfile = 'new/httpd.conf'; |
|
} |
|
} |
print_and_log(&mt('Copying the LON-CAPA [_1] to [_2].',"'httpd.conf'", |
print_and_log(&mt('Copying the LON-CAPA [_1] to [_2].',"'httpd.conf'", |
"'/etc/httpd/conf/httpd.conf'")."\n"); |
"'/etc/httpd/conf/httpd.conf'")."\n"); |
copy "/etc/httpd/conf/httpd.conf","/etc/httpd/conf/httpd.conf.original"; |
copy "/etc/httpd/conf/httpd.conf","/etc/httpd/conf/httpd.conf.original"; |
copy "$instdir/httpd.conf","/etc/httpd/conf/httpd.conf"; |
copy "$instdir/centos-rhes-fedora-sl/$configfile","/etc/httpd/conf/httpd.conf"; |
chmod(0444,"/etc/httpd/conf/httpd.conf"); |
chmod(0444,"/etc/httpd/conf/httpd.conf"); |
print_and_log("\n"); |
print_and_log("\n"); |
} |
} |
|
|
######################################################### |
######################################################### |
## |
## |
## Ubuntu/Debian -- copy our apache2 configuration file to |
## Ubuntu/Debian -- copy our loncapa configuration file to |
## sites-available and set the symlink from sites-enabled. |
## sites-available and set the symlink from sites-enabled. |
## |
## |
######################################################### |
######################################################### |
Line 1681 sub copy_apache2_debconf {
|
Line 1747 sub copy_apache2_debconf {
|
if (-e "$apache2_sites_available_dir/loncapa") { |
if (-e "$apache2_sites_available_dir/loncapa") { |
copy("$apache2_sites_available_dir/loncapa","$apache2_sites_available_dir/loncapa.original"); |
copy("$apache2_sites_available_dir/loncapa","$apache2_sites_available_dir/loncapa.original"); |
} |
} |
copy("$instdir/debian-ubuntu/apache2.conf","$apache2_sites_available_dir/loncapa"); |
copy("$instdir/debian-ubuntu/loncapa","$apache2_sites_available_dir/loncapa"); |
chmod(0444,"$apache2_sites_available_dir/loncapa"); |
chmod(0444,"$apache2_sites_available_dir/loncapa"); |
symlink("$apache2_sites_available_dir/loncapa","$apache2_sites_enabled_dir/000-default"); |
symlink("$apache2_sites_available_dir/loncapa","$apache2_sites_enabled_dir/000-default"); |
my $apache2_mods_enabled_dir = '/etc/apache2/mods-enabled'; |
my $apache2_mods_enabled_dir = '/etc/apache2/mods-enabled'; |