version 1.7, 2011/04/23 19:04:42
|
version 1.25, 2013/02/27 19:48:53
|
Line 191 sub get_distro {
|
Line 191 sub get_distro {
|
$distro = 'rhes'.$1; |
$distro = 'rhes'.$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 =~ /CentOS release (\d+)/) { |
} elsif ($versionstring =~ /CentOS(?:| Linux) release (\d+)/) { |
$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 293 sub check_prerequisites {
|
Line 293 sub check_prerequisites {
|
} else { |
} else { |
my $line = <PIPE>; |
my $line = <PIPE>; |
chomp($line); |
chomp($line); |
if ($line =~ /^LONCAPA-prerequisites\-([\d\-]+)\.(\w+)$/) { |
if ($line =~ /^LONCAPA\-prerequisites\-([\d\-]+)\.(?:[.\w]+)$/) { |
$gotprereqs = $1; |
$gotprereqs = $1; |
} |
} |
} |
} |
Line 307 sub check_prerequisites {
|
Line 307 sub check_prerequisites {
|
|
|
sub check_locale { |
sub check_locale { |
my ($distro) = @_; |
my ($distro) = @_; |
my ($fh,$command); |
my ($fh,$langvar,$command); |
|
$langvar = 'LANG'; |
if ($distro =~ /^(ubuntu|debian)/) { |
if ($distro =~ /^(ubuntu|debian)/) { |
if (!open($fh,"</etc/default/locale")) { |
if (!open($fh,"</etc/default/locale")) { |
print &mt('Failed to open: [_1], default locale not checked.', |
print &mt('Failed to open: [_1], default locale not checked.', |
'/etc/default/locale'); |
'/etc/default/locale'); |
} |
} |
|
} elsif ($distro =~ /^(suse|sles)/) { |
|
if (!open($fh,"</etc/sysconfig/language")) { |
|
print &mt('Failed to open: [_1], default locale not checked.', |
|
'/etc/sysconfig/language'); |
|
} |
|
$langvar = 'RC_LANG'; |
|
} elsif ($distro =~ /^fedora(\d+)/) { |
|
if ($1 >= 18) { |
|
if (!open($fh,"</etc/locale.conf")) { |
|
print &mt('Failed to open: [_1], default locale not checked.', |
|
'/etc/locale.conf'); |
|
} |
|
} elsif (!open($fh,"</etc/sysconfig/i18n")) { |
|
print &mt('Failed to open: [_1], default locale not checked.', |
|
'/etc/sysconfig/i18n'); |
|
} |
} else { |
} else { |
if (!open($fh,"</etc/sysconfig/i18n")) { |
if (!open($fh,"</etc/sysconfig/i18n")) { |
print &mt('Failed to open: [_1], default locale not checked.', |
print &mt('Failed to open: [_1], default locale not checked.', |
Line 322 sub check_locale {
|
Line 339 sub check_locale {
|
my @data = <$fh>; |
my @data = <$fh>; |
chomp(@data); |
chomp(@data); |
foreach my $item (@data) { |
foreach my $item (@data) { |
if ($item =~ /^LANG=\"([^\"]*)\"/) { |
if ($item =~ /^\Q$langvar\E=\"?([^\"]*)\"?/) { |
my $default = $1; |
my $default = $1; |
if ($default ne 'en_US.UTF-8') { |
if ($default ne 'en_US.UTF-8') { |
if ($distro =~ /^debian/) { |
if ($distro =~ /^debian/) { |
$command = 'dpkg-reconfigure locales'; |
$command = 'locale-gen en_US.UTF-8'."\n". |
|
'update-locale LANG=en_US.UTF-8'; |
} elsif ($distro =~ /^ubuntu/) { |
} elsif ($distro =~ /^ubuntu/) { |
$command = 'sudo set-language-env -E'; |
$command = 'sudo locale-gen en_US.UTF-8'."\n". |
|
'sudo update-locale LANG=en_US.UTF-8'; |
} elsif ($distro =~ /^(suse|sles)/) { |
} elsif ($distro =~ /^(suse|sles)/) { |
$command = 'yast language'; |
$command = 'yast language'; |
} else { |
} else { |
Line 350 sub check_required {
|
Line 369 sub check_required {
|
} |
} |
my $gotprereqs = &check_prerequisites($packagecmd,$distro); |
my $gotprereqs = &check_prerequisites($packagecmd,$distro); |
if ($gotprereqs eq '') { |
if ($gotprereqs eq '') { |
return ($distro,$gotprereqs); |
return ($distro,$gotprereqs,'',$packagecmd,$updatecmd); |
} |
} |
my $localecmd = &check_locale($distro); |
my $localecmd = &check_locale($distro); |
unless ($localecmd eq '') { |
unless ($localecmd eq '') { |
Line 386 sub check_required {
|
Line 405 sub check_required {
|
} |
} |
} |
} |
($recommended{'firewall'},$apachefw) = &chkfirewall($distro); |
($recommended{'firewall'},$apachefw) = &chkfirewall($distro); |
($recommended{'runlevels'},$tostop) = &chkconfig($distro); |
($recommended{'runlevels'},$tostop) = &chkconfig($distro,$instdir); |
$recommended{'apache'} = &chkapache($distro,$instdir); |
$recommended{'apache'} = &chkapache($distro,$instdir); |
$recommended{'stopsrvcs'} = &chksrvcs($distro,$tostop); |
$recommended{'stopsrvcs'} = &chksrvcs($distro,$tostop); |
($recommended{'download'},$downloadstatus,$filetouse,$production,$testing) |
($recommended{'download'},$downloadstatus,$filetouse,$production,$testing) |
Line 398 sub check_required {
|
Line 417 sub check_required {
|
|
|
sub check_mysql_running { |
sub check_mysql_running { |
my ($distro) = @_; |
my ($distro) = @_; |
|
my $use_systemctl; |
my $mysqldaemon ='mysqld'; |
my $mysqldaemon ='mysqld'; |
if ($distro =~ /^(suse|sles|debian|ubuntu)/) { |
if ($distro =~ /^(suse|sles|debian|ubuntu)/) { |
$mysqldaemon = 'mysql'; |
$mysqldaemon = 'mysql'; |
Line 410 sub check_mysql_running {
|
Line 430 sub check_mysql_running {
|
$proc_owner = 'mysql'; |
$proc_owner = 'mysql'; |
} |
} |
} |
} |
|
if ($distro =~ /^fedora(\d+)/) { |
|
if ($1 >= 16) { |
|
$process = 'mysqld'; |
|
$proc_owner = 'mysql'; |
|
$use_systemctl = 1; |
|
} |
|
} |
if (open(PIPE,"ps -ef |grep $process |grep -v grep 2>&1 |")) { |
if (open(PIPE,"ps -ef |grep $process |grep -v grep 2>&1 |")) { |
my $status = <PIPE>; |
my $status = <PIPE>; |
close(PIPE); |
close(PIPE); |
Line 418 sub check_mysql_running {
|
Line 445 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"); |
if ($use_systemctl) { |
|
system("/bin/systemctl start $mysqldaemon.service >/dev/null 2>&1 "); |
|
} else { |
|
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 442 sub check_mysql_running {
|
Line 483 sub check_mysql_running {
|
} |
} |
|
|
sub chkconfig { |
sub chkconfig { |
my ($distro) = @_; |
my ($distro,$instdir) = @_; |
my (%needfix,%tostop); |
my (%needfix,%tostop,%uses_systemctl); |
my $checker_bin = '/sbin/chkconfig'; |
my $checker_bin = '/sbin/chkconfig'; |
|
my $sysctl_bin = '/bin/systemctl'; |
my %daemon = ( |
my %daemon = ( |
mysql => 'mysqld', |
mysql => 'mysqld', |
apache => 'httpd', |
apache => 'httpd', |
Line 459 sub chkconfig {
|
Line 501 sub chkconfig {
|
@norunlevels = qw/0 2 1 6/; |
@norunlevels = qw/0 2 1 6/; |
$daemon{'mysql'} = 'mysql'; |
$daemon{'mysql'} = 'mysql'; |
$daemon{'apache'} = 'apache2'; |
$daemon{'apache'} = 'apache2'; |
|
$daemon{'ntp'} = 'ntp'; |
if ($distro =~ /^(suse|sles)9/) { |
if ($distro =~ /^(suse|sles)9/) { |
$daemon{'apache'} = 'apache'; |
$daemon{'apache'} = 'apache'; |
} |
} |
Line 473 sub chkconfig {
|
Line 516 sub chkconfig {
|
if (($distro =~ /^ubuntu/) && ($version <= 8)) { |
if (($distro =~ /^ubuntu/) && ($version <= 8)) { |
$daemon{'cups'} = 'cupsys'; |
$daemon{'cups'} = 'cupsys'; |
} |
} |
|
} elsif ($distro =~ /^(?:fedora)(\d+)/) { |
|
my $version = $1; |
|
if ($version >= 15) { |
|
$uses_systemctl{'ntp'} = 1; |
|
} |
|
if ($version >= 16) { |
|
$uses_systemctl{'mysql'} = 1; |
|
$uses_systemctl{'apache'} = 1; |
|
} |
} |
} |
|
my $nocheck; |
if (! -x $checker_bin) { |
if (! -x $checker_bin) { |
|
if ($uses_systemctl{'mysql'} && $uses_systemctl{'apache'}) { |
|
if (! -x $sysctl_bin) { |
|
$nocheck = 1; |
|
} |
|
} else { |
|
$nocheck = 1; |
|
} |
|
} |
|
if ($nocheck) { |
print &mt('Could not check runlevel status for MySQL or Apache')."\n"; |
print &mt('Could not check runlevel status for MySQL or Apache')."\n"; |
return; |
return; |
} |
} |
my $rlstr = join('',@runlevels); |
my $rlstr = join('',@runlevels); |
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 ($uses_systemctl{$type}) { |
if ($type eq 'cups') { |
if (!-l "/etc/systemd/system/multi-user.target.wants/$service.service") { |
if ($distro =~ /^(?:debian|ubuntu)(\d+)/) { |
$needfix{$type} = "systemctl enable $service.service"; |
my $version = $1; |
} |
if (($distro =~ /^ubuntu/) && ($version <= 8)) { |
next; |
$command = $checker_bin.' --list cupsys'; |
} else { |
} |
my $command = $checker_bin.' --list '.$service.' 2>/dev/null'; |
} |
if ($type eq 'cups') { |
} |
if ($distro =~ /^(?:debian|ubuntu)(\d+)/) { |
my $results = `$command`; |
my $version = $1; |
my $tofix; |
if (($distro =~ /^ubuntu/) && ($version <= 8)) { |
if ($results eq '') { |
$command = $checker_bin.' --list cupsys 2>/dev/null'; |
if (($type eq 'apache') || ($type eq 'mysql') || ($type eq 'ntp')) { |
} |
if ($distro =~ /^(debian|ubuntu)/) { |
|
$tofix = "update-rc.d $type defaults"; |
|
} else { |
|
$tofix = "$checker_bin --add $service\n"; |
|
} |
} |
} |
} |
} else { |
my $results = `$command`; |
my %curr_runlevels; |
my $tofix; |
for (my $rl=0; $rl<=6; $rl++) { |
if ($results eq '') { |
if ($results =~ /$rl:on/) { $curr_runlevels{$rl}++; } |
if (($type eq 'apache') || ($type eq 'mysql') || ($type eq 'ntp')) { |
} |
if ($distro =~ /^(debian|ubuntu)/) { |
if (($type eq 'apache') || ($type eq 'mysql') || ($type eq 'ntp')) { |
$tofix = "update-rc.d $type defaults"; |
my $warning; |
} else { |
foreach my $rl (@runlevels) { |
$tofix = "$checker_bin --add $service\n"; |
if (!exists($curr_runlevels{$rl})) { |
|
$warning = 1; |
|
} |
} |
} |
} |
if ($warning) { |
} else { |
$tofix = "$checker_bin --level $rlstr $service on\n"; |
my %curr_runlevels; |
|
for (my $rl=0; $rl<=6; $rl++) { |
|
if ($results =~ /$rl:on/) { $curr_runlevels{$rl}++; } |
|
} |
|
if (($type eq 'apache') || ($type eq 'mysql') || ($type eq 'ntp')) { |
|
my $warning; |
|
foreach my $rl (@runlevels) { |
|
if (!exists($curr_runlevels{$rl})) { |
|
$warning = 1; |
|
} |
|
} |
|
if ($warning) { |
|
$tofix = "$checker_bin --level $rlstr $service on\n"; |
|
} |
|
} elsif (keys(%curr_runlevels) > 0) { |
|
$tostop{$type} = 1; |
} |
} |
} elsif (keys(%curr_runlevels) > 0) { |
|
$tostop{$type} = 1; |
|
} |
} |
} |
if ($tofix) { |
if ($tofix) { |
$needfix{$type} = $tofix; |
$needfix{$type} = $tofix; |
} |
} |
} |
} |
} |
if ($distro =~ /^(suse|sles)([\d\.]+)$/) { |
if ($distro =~ /^(suse|sles)([\d\.]+)$/) { |
Line 534 sub chkconfig {
|
Line 604 sub chkconfig {
|
$major = $version; |
$major = $version; |
} |
} |
if ($major > 10) { |
if ($major > 10) { |
$needfix{'insserv'} = &check_SuSEfirewall2_setup(); |
if (&check_SuSEfirewall2_setup($instdir)) { |
|
$needfix{'insserv'} = 1; |
|
} |
} |
} |
} |
} |
return (\%needfix,\%tostop); |
return (\%needfix,\%tostop); |
Line 580 sub chkapache {
|
Line 652 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/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/apache2.conf")) { |
} elsif ((-e "/etc/apache2/sites-available/loncapa") && (-e "$instdir/debian-ubuntu/loncapa")) { |
if (open(PIPE, "diff --brief $instdir/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 603 sub chkapache {
|
Line 675 sub chkapache {
|
} elsif ($distro =~ /^(?:suse|sles)([\d\.]+)$/) { |
} elsif ($distro =~ /^(?:suse|sles)([\d\.]+)$/) { |
my $apache = 'apache'; |
my $apache = 'apache'; |
if ($1 >= 10) { |
if ($1 >= 10) { |
my $apache = 'apache2'; |
$apache = 'apache2'; |
|
} |
|
if (!-e "$instdir/sles-suse/default-server.conf") { |
|
$fixapache = 0; |
|
print &mt('Warning: No LON-CAPA Apache configuration file found for installation check.')."\n"; |
|
} elsif ((-e "/etc/$apache/default-server.conf") && (-e "$instdir/sles-suse/default-server.conf")) { |
|
if (open(PIPE, "diff --brief $instdir/sles-suse/default-server.conf /etc/$apache/default-server.conf |")) { |
|
my $diffres = <PIPE>; |
|
close(PIPE); |
|
chomp($diffres); |
|
unless ($diffres) { |
|
$fixapache = 0; |
|
} |
|
} |
} |
} |
if (!-e "$instdir/default-server.conf") { |
} elsif ($distro eq 'rhes4') { |
|
if (!-e "$instdir/rhes4/httpd.conf") { |
$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/$apache/default-server.conf") && (-e "$instdir/default-server.conf")) { |
} elsif ((-e "/etc/httpd/conf/httpd.conf") && (-e "$instdir/rhes4/httpd.conf")) { |
if (open(PIPE, "diff --brief $instdir/default-server.conf /etc/$apache/default-server.conf |")) { |
if (open(PIPE, "diff --brief $instdir/rhes4/httpd.conf /etc/httpd/conf/httpd.conf |")) { |
my $diffres = <PIPE>; |
my $diffres = <PIPE>; |
close(PIPE); |
close(PIPE); |
chomp($diffres); |
chomp($diffres); |
Line 619 sub chkapache {
|
Line 705 sub chkapache {
|
} |
} |
} |
} |
} else { |
} else { |
if (!-e "$instdir/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/httpd.conf")) { |
} elsif ((-e "/etc/httpd/conf/httpd.conf") && (-e "$instdir/centos-rhes-fedora-sl/$configfile")) { |
if (open(PIPE, "diff --brief $instdir/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 654 sub chksrvcs {
|
Line 750 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 793 sub check_mysql_setup {
|
Line 899 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 930 sub get_mysql_password {
|
Line 1037 sub get_mysql_password {
|
sub check_SuSEfirewall2_setup { |
sub check_SuSEfirewall2_setup { |
my ($instdir) = @_; |
my ($instdir) = @_; |
my $need_override = 1; |
my $need_override = 1; |
if ((-e "/etc/insserv/overrides/SuSEfirewall2_setup") && (-e "$instdir/SuSEfirewall2_setup")) { |
if ((-e "/etc/insserv/overrides/SuSEfirewall2_setup") && (-e "$instdir/sles-suse/SuSEfirewall2_setup")) { |
if (open(PIPE, "diff --brief $instdir/SuSEfirewall2_setup /etc/insserv/overrides/SuSEfirewall2_setup |")) { |
if (open(PIPE, "diff --brief $instdir/sles-suse/SuSEfirewall2_setup /etc/insserv/overrides/SuSEfirewall2_setup |")) { |
my $diffres = <PIPE>; |
my $diffres = <PIPE>; |
close(PIPE); |
close(PIPE); |
chomp($diffres); |
chomp($diffres); |
Line 1062 if ($localecmd ne '') {
|
Line 1169 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 1076 if (!$gotprereqs) {
|
Line 1183 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 1086 if (!$gotprereqs) {
|
Line 1193 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 1156 if ($callsub{'download'}) {
|
Line 1263 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 1210 if ($callsub{'apache'}) {
|
Line 1317 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 1234 if ($callsub{'runlevels'}) {
|
Line 1341 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 1260 if ($callsub{'firewall'}) {
|
Line 1369 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 1272 if ($callsub{'firewall'}) {
|
Line 1385 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 1425 ENDPATCH
|
Line 1538 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 1474 sub kill_extra_services {
|
Line 1587 sub kill_extra_services {
|
if (($distro =~ /^ubuntu/) && ($version <= 8)) { |
if (($distro =~ /^ubuntu/) && ($version <= 8)) { |
$daemon = 'cupsys'; |
$daemon = 'cupsys'; |
} |
} |
|
} else { |
|
$daemon = 'cups'; |
|
} |
|
} |
|
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(`/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 1498 sub setup_mysql {
|
Line 1621 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 1628 sub get_mysql_version {
|
Line 1751 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 1655 sub copy_apache2_debconf {
|
Line 1788 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/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'; |
Line 1685 sub copy_apache2_suseconf {
|
Line 1818 sub copy_apache2_suseconf {
|
if (!-e "/etc/apache2/default-server.conf.original") { |
if (!-e "/etc/apache2/default-server.conf.original") { |
copy "/etc/apache2/default-server.conf","/etc/apache2/default-server.conf.original"; |
copy "/etc/apache2/default-server.conf","/etc/apache2/default-server.conf.original"; |
} |
} |
copy "$instdir/default-server.conf","/etc/apache2/default-server.conf"; |
copy "$instdir/sles-suse/default-server.conf","/etc/apache2/default-server.conf"; |
chmod(0444,"/etc/apache2/default-server.conf"); |
chmod(0444,"/etc/apache2/default-server.conf"); |
# Make symlink for conf directory (included in loncapa_apache.conf) |
# Make symlink for conf directory (included in loncapa_apache.conf) |
my $can_symlink = (eval { symlink('/etc/apache2','/srv/www/conf'); }, $@ eq ''); |
my $can_symlink = (eval { symlink('/etc/apache2','/srv/www/conf'); }, $@ eq ''); |
Line 1712 sub copy_apache2_conf_files {
|
Line 1845 sub copy_apache2_conf_files {
|
if (!-e "/etc/apache2/uid.conf.original") { |
if (!-e "/etc/apache2/uid.conf.original") { |
copy "/etc/apache2/uid.conf","/etc/apache2/uid.conf.original"; |
copy "/etc/apache2/uid.conf","/etc/apache2/uid.conf.original"; |
} |
} |
copy "$instdir/uid.conf","/etc/apache2/uid.conf"; |
copy "$instdir/sles-suse/uid.conf","/etc/apache2/uid.conf"; |
chmod(0444,"/etc/apache2/uid.conf"); |
chmod(0444,"/etc/apache2/uid.conf"); |
} |
} |
|
|
Line 1727 sub copy_sysconfig_apache2_file {
|
Line 1860 sub copy_sysconfig_apache2_file {
|
if (!-e "/etc/sysconfig/apache2.original") { |
if (!-e "/etc/sysconfig/apache2.original") { |
copy "/etc/sysconfig/apache2","/etc/sysconfig/apache2.original"; |
copy "/etc/sysconfig/apache2","/etc/sysconfig/apache2.original"; |
} |
} |
copy "$instdir/sysconfig_apache2","/etc/sysconfig/apache2"; |
copy "$instdir/sles-suse/sysconfig_apache2","/etc/sysconfig/apache2"; |
chmod(0444,"/etc/sysconfig/apache2"); |
chmod(0444,"/etc/sysconfig/apache2"); |
} |
} |
|
|
Line 1750 sub update_SuSEfirewall2_setup {
|
Line 1883 sub update_SuSEfirewall2_setup {
|
} elsif (!-e "/etc/insserv/overrides/SuSEfirewall2_setup.original") { |
} elsif (!-e "/etc/insserv/overrides/SuSEfirewall2_setup.original") { |
copy "/etc/insserv/overrides/SuSEfirewall2_setup","/etc/insserv/overrides/SuSEfirewall2_setup.original" |
copy "/etc/insserv/overrides/SuSEfirewall2_setup","/etc/insserv/overrides/SuSEfirewall2_setup.original" |
} |
} |
copy "$instdir/SuSEfirewall2_setup","/etc/insserv/overrides/SuSEfirewall2_setup"; |
copy "$instdir/sles-suse/SuSEfirewall2_setup","/etc/insserv/overrides/SuSEfirewall2_setup"; |
chmod(0444,"/etc/insserv/overrides/SuSEfirewall2_setup"); |
chmod(0444,"/etc/insserv/overrides/SuSEfirewall2_setup"); |
} |
} |
|
|
Line 1777 sub get_iptables_rules {
|
Line 1910 sub get_iptables_rules {
|
} |
} |
my $ask_to_enable; |
my $ask_to_enable; |
if (-e "/etc/iptables.loncapa.rules") { |
if (-e "/etc/iptables.loncapa.rules") { |
if (open(PIPE, "diff --brief $instdir/debian/iptables.loncapa.rules /etc/iptables.loncapa.rules |")) { |
if (open(PIPE, "diff --brief $instdir/debian-ubuntu/iptables.loncapa.rules /etc/iptables.loncapa.rules |")) { |
my $diffres = <PIPE>; |
my $diffres = <PIPE>; |
close(PIPE); |
close(PIPE); |
chomp($diffres); |
chomp($diffres); |
Line 1788 sub get_iptables_rules {
|
Line 1921 sub get_iptables_rules {
|
print &mt('Error: unable to open [_1] to compare contents with LON-CAPA supplied file.','/etc/iptables.loncapa.rules')."\n"; |
print &mt('Error: unable to open [_1] to compare contents with LON-CAPA supplied file.','/etc/iptables.loncapa.rules')."\n"; |
} |
} |
} else { |
} else { |
if (-e "$instdir/debian/iptables.loncapa.rules") { |
if (-e "$instdir/debian-ubuntu/iptables.loncapa.rules") { |
copy "$instdir/debian/iptables.loncapa.rules","/etc/iptables.loncapa.rules"; |
copy "$instdir/debian-ubuntu/iptables.loncapa.rules","/etc/iptables.loncapa.rules"; |
chmod(0600,"/etc/iptables.loncapa.rules"); |
chmod(0600,"/etc/iptables.loncapa.rules"); |
} |
} |
} |
} |
if (-e "/etc/iptables.loncapa.rules") { |
if (-e "/etc/iptables.loncapa.rules") { |
if (-e "/etc/network/if-pre-up.d/iptables") { |
if (-e "/etc/network/if-pre-up.d/iptables") { |
if (open(PIPE, "diff --brief $instdir/debian/iptables /etc/network/if-pre-up/iptables |")) { |
if (open(PIPE, "diff --brief $instdir/debian-ubuntu/iptables /etc/network/if-pre-up/iptables |")) { |
my $diffres = <PIPE>; |
my $diffres = <PIPE>; |
close(PIPE); |
close(PIPE); |
chomp($diffres); |
chomp($diffres); |
Line 1806 sub get_iptables_rules {
|
Line 1939 sub get_iptables_rules {
|
print &mt('Error: unable to open [_1] to compare contents with LON-CAPA supplied file.','/etc/network/if-pre-up.d/iptables')."\n"; |
print &mt('Error: unable to open [_1] to compare contents with LON-CAPA supplied file.','/etc/network/if-pre-up.d/iptables')."\n"; |
} |
} |
} else { |
} else { |
copy "$instdir/debian/iptables","/etc/network/if-pre-up.d/iptables"; |
copy "$instdir/debian-ubuntu/iptables","/etc/network/if-pre-up.d/iptables"; |
chmod(0755,"/etc/network/if-pre-up.d/iptables"); |
chmod(0755,"/etc/network/if-pre-up.d/iptables"); |
print_and_log(&mt('Installed script "[_1]" to add iptables rules to block all ports except 22, 80, and 443 when network is enabled during boot.','/etc/network/if-pre-up.d/iptables')); |
print_and_log(&mt('Installed script "[_1]" to add iptables rules to block all ports except 22, 80, and 443 when network is enabled during boot.','/etc/network/if-pre-up.d/iptables')); |
$ask_to_enable = 1; |
$ask_to_enable = 1; |