[Top][All Lists]
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[Koha-devel] Regressions in the latest CVS
From: |
address@hidden via news-to-mail gateway |
Subject: |
[Koha-devel] Regressions in the latest CVS |
Date: |
Mon Jan 13 15:16:04 2003 |
Hi,
there are regressions in the CVS (bugs 129 and 146 re-appeared).
I tried to make my old patch work in the current CVS version
(leaving out some things that other people corrected in some
other way).
Please check the patch & commit to CVS if ok. Some of the fixes
are quoting related; quoting bugs are usually considered security
holes, though quoting bugs in an installer are just nuisances and
won't affect everyone.
In the patch there is a change in the way /etc is referenced;
I did this because if this is not done the $::etcdir variable
is basically pointless.
Perhaps my patches are too big, but it is rather difficult to
make small patches when I need to make the installer work before
I test anything. I can't know if my patch works until I make it
all work.
------------ cut here --------- 8< --------------------------
diff -u koha-1.3.2.orig/Install.pm koha-1.3.2/Install.pm
--- koha-1.3.2.orig/Install.pm Thu Jan 9 12:40:22 2003
+++ koha-1.3.2/Install.pm Sun Jan 12 23:28:16 2003
@@ -28,6 +28,7 @@
@ISA = qw(Exporter);
@EXPORT = qw( &checkperlmodules
+ &checkabortedinstall
&getmessage
&showmessage
&releasecandidatewarning
@@ -134,7 +135,7 @@
= Koha already installed =
==========================
-It looks like Koha is already installed on your system (/etc/koha.conf exists
+It looks like Koha is already installed on your system (%s/koha.conf exists
already). If you would like to upgrade your system to %s, please use
the koha.upgrade script in this directory.
@@ -178,7 +179,7 @@
This release of Koha has a new authentication module. If you are not already
using basic authentication on your intranet, you will be required to log in to
access some of the features of the intranet. You can log in using the userid
-and password from the /etc/koha.conf configuration file at any time. Use the
+and password from the %s/koha.conf configuration file at any time. Use the
"Members" module to add passwords for other accounts and set their permissions.
Press the <ENTER> key to continue: |;
@@ -219,6 +220,34 @@
#
+# Assuming that Koha will be installed on a modern Unix with symlinks,
+# it is possible to code the installer so that aborted installs can be
+# detected. In case of such an event we can do our best to "roll back"
+# the aborted install.
+#
+# FIXME: The "roll back" is not complete!
+#
+
+sub checkabortedinstall {
+ if (-l("$::etcdir/koha.conf")
+ && readlink("$::etcdir/koha.conf") =~ /\.tmp$/
+ ) {
+ print qq|
+I have detected that you tried to install Koha before, but the installation
+was aborted. I will try to continue, but there might be problems if the
+database is already created.
+
+|;
+ print "Please press <ENTER> to continue: ";
+ <STDIN>;
+
+ # Remove the symlink after the <STDIN>, so the user can back out
+ unlink "$::etcdir/koha.conf"
+ || die "Failed to remove incomplete $::etcdir/koha.conf: $!\n";
+ }
+}
+
+#
# Test for Perl and Modules
#
#
@@ -507,6 +536,8 @@
Please provide the name of the user, who will have full administrative rights
to the %s database, when authenticating from %s.
+This user will also be used to access Koha's INTRANET interface.
+
Database user [%s]: |;
$messages->{'DatabasePassword'}->{en}=qq|
@@ -602,7 +633,7 @@
I was not able to determine the user that Apache is running as. This
information is necessary in order to set the access privileges correctly on
-/etc/koha.conf. This user should be set in one of the Apache configuration
+%s/koha.conf. This user should be set in one of the Apache configuration
files using the "User" directive.
Enter the Apache userid: |;
@@ -637,7 +668,7 @@
if ($#confpossibilities==-1) {
my $message=getmessage('NoApacheConfFiles');
my $choice='';
- until (-f $choice) {
+ until (-f $::realhttpdconf) {
$choice=showmessage($message, "free", 1);
if (-f $choice) {
$::realhttpdconf=$choice;
@@ -660,7 +691,7 @@
} else {
$::realhttpdconf=$confpossibilities[0];
}
- unless (open (HTTPDCONF, $::realhttpdconf)) {
+ unless (open (HTTPDCONF, "<$::realhttpdconf")) {
warn "Insufficient privileges to open $::realhttpdconf for reading.\n";
sleep 4;
}
@@ -676,7 +707,7 @@
unless ($::httpduser) {
- my $message=getmessage('EnterApacheUser');
+ my $message=getmessage('EnterApacheUser', [$::etcdir]);
until (length($::httpduser) && getpwnam($::httpduser)) {
$::httpduser=showmessage($message, "free", '');
if (length($::httpduser)>0) {
@@ -807,11 +838,12 @@
Press <ENTER> to continue: |;
sub updateapacheconf {
- my $logfiledir=`grep ^ErrorLog $::realhttpdconf`;
+ my $logfiledir=`grep ^ErrorLog "$::realhttpdconf"`;
chomp $logfiledir;
if ($logfiledir) {
- $logfiledir=~m#ErrorLog (.*)/[^/]*$#;
+ $logfiledir=~m#ErrorLog (.*)/[^/]*$#
+ or die "Can't parse ErrorLog directive\n";
$logfiledir=$1;
}
@@ -824,7 +856,7 @@
my $httpdconf;
my $envmodule=0;
my $includesmodule=0;
- open HC, $::realhttpdconf;
+ open HC, "<$::realhttpdconf";
while (<HC>) {
if (/^\s*#\s*LoadModule env_module /) {
s/^\s*#\s*//;
@@ -856,7 +888,7 @@
- if (`grep 'VirtualHost $::servername' $::realhttpdconf`) {
+ if (`grep 'VirtualHost $::servername' "$::realhttpdconf"`) {
showmessage(getmessage('ApacheAlreadyConfigured', [$::realhttpdconf,
$::realhttpdconf]), 'PressEnter');
return;
} else {
@@ -933,6 +965,10 @@
I can set it up so that the Intranet/Librarian site is password protected using
Apache's Basic Authorization.
+This is going to be phased out very soon. However, setting this up can provide
+an extra layer of security before the new authentication system is completely
+in place.
+
Would you like to do this ([Y]/N): |;
$messages->{'BasicAuthUsername'}->{en}="Please enter a userid for intranet
access [%s]: ";
@@ -954,7 +990,7 @@
($apacheauthpassword) =
showmessage(getmessage('BasicAuthPasswordWasBlank'), 'none', '', 1);
}
}
- open AUTH, ">/etc/kohaintranet.pass";
+ open AUTH, ">$::etcdir/kohaintranet.pass";
my
$chars='ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789';
my $salt=substr($chars, int(rand(length($chars))),1);
$salt.=substr($chars, int(rand(length($chars))),1);
@@ -964,7 +1000,7 @@
print SITE <<EOP
<Directory $::intranetdir>
- AuthUserFile /etc/kohaintranet.pass
+ AuthUserFile $::etcdir/kohaintranet.pass
AuthType Basic
AuthName "Koha Intranet (for librarians only)"
Require valid-user
@@ -1018,7 +1054,7 @@
hostname=$::hostname
user=$::user
pass=$::pass
-includes=$::intranetdir/htdocs/includes
+includes=$::opacdir/htdocs/includes
intranetdir=$::intranetdir
opacdir=$::opacdir
kohalogdir=$::kohalogdir
@@ -1026,6 +1062,8 @@
httpduser=$::httpduser
intrahtdocs=$::intranetdir/htdocs/intranet-tmpl
opachtdocs=$::opacdir/htdocs/opac-tmpl
+#XXX I had: intrahtdocs=$::intranetdir/cgi-bin/koha-tmpl/intranet-tmpl
+#XXX I had: opachtdocs=$::intranetdir/cgi-bin/koha-tmpl/opac-tmpl
|;
close(SITES);
umask($old_umask);
@@ -1049,7 +1087,7 @@
To allow us to create the koha database please supply your
mysql server's root user password:
-Enter MySql root user password: |;
+Enter MySQL root user password: |;
$messages->{'InvalidMysqlRootPassword'}->{en}="Invalid Password. Please try
again.";
@@ -1058,7 +1096,7 @@
= CREATING DATABASE =
=====================
-Creating the MySql database for Koha...
+Creating the MySQL database for Koha...
|;
@@ -1227,6 +1265,9 @@
|;
sub updatedatabase {
+ # At this point, $::etcdir/koha.conf must exist, for C4::Context
+ # We must somehow temporarily enable $::etcdir/koha.conf. A symlink can
+ # do this & at the same time facilitate detection of aborted installs.
my $result=system ("perl -I $::intranetdir/modules
scripts/updater/updatedatabase");
if ($result) {
print "Problem updating database...\n";
@@ -1236,11 +1277,11 @@
my $response=showmessage(getmessage('UpdateMarcTables'), 'restrictchar
123', '1');
if ($response == 1) {
- system("cat script/misc/marc_datas/marc21_en/structure_def.sql
| $::mysqldir/bin/mysql -u$::mysqluser -p$::mysqlpass $::dbname");
+ system("cat scripts/misc/marc_datas/marc21_en/structure_def.sql
| $::mysqldir/bin/mysql -u$::mysqluser $::mysqlpass_quoted $::dbname");
}
if ($response == 2) {
- system("cat
scripts/misc/marc_datas/unimarc_fr/structure_def.sql | $::mysqldir/bin/mysql
-u$::mysqluser -p$::mysqlpass $::dbname");
- system("cat scripts/misc/lang-datas/fr/stopwords.sql |
$::mysqldir/bin/mysql -u$::mysqluser -p$::mysqlpass $::dbname");
+ system("cat
scripts/misc/marc_datas/unimarc_fr/structure_def.sql | $::mysqldir/bin/mysql
-u$::mysqluser $::mysqlpass_quoted $::dbname");
+ system("cat scripts/misc/lang-datas/fr/stopwords.sql |
$::mysqldir/bin/mysql -u$::mysqluser $::mysqlpass_quoted $::dbname");
}
my $result=system ("perl -I $::intranetdir/modules
scripts/marc/updatedb2marc.pl");
@@ -1249,16 +1290,14 @@
exit;
}
- print "\n\nFinished updating database. Press <ENTER> to continue...";
+ print "\n\nFinished basic updating of database. Press <ENTER> to
continue...";
<STDIN>;
}
sub populatedatabase {
my $response=showmessage(getmessage('SampleData'), 'yn', 'n');
if ($response =~/^y/i) {
- system("gunzip sampledata-1.2.gz");
- system("cat sampledata-1.2 | $::mysqldir/bin/mysql
-u$::mysqluser $::mysqlpass_quoted $::dbname");
- system("gzip -9 sampledata-1.2");
+ system("gunzip -d < sampledata-1.2.gz | $::mysqldir/bin/mysql
-u$::mysqluser $::mysqlpass_quoted $::dbname");
system("$::mysqldir/bin/mysql -u$::mysqluser
$::mysqlpass_quoted $::dbname -e \"insert into branches
(branchcode,branchname,issuing) values ('MAIN', 'Main Library', 1)\"");
system("$::mysqldir/bin/mysql -u$::mysqluser
$::mysqlpass_quoted $::dbname -e \"insert into branchrelations
(branchcode,categorycode) values ('MAIN', 'IS')\"");
system("$::mysqldir/bin/mysql -u$::mysqluser
$::mysqlpass_quoted $::dbname -e \"insert into branchrelations
(branchcode,categorycode) values ('MAIN', 'CU')\"");
@@ -1333,7 +1372,7 @@
sub loadconfigfile {
my %configfile;
- open (KC, "/etc/koha.conf");
+ open (KC, "<$::etcdir/koha.conf");
while (<KC>) {
chomp;
(next) if (/^\s*#/);
diff -u koha-1.3.2.orig/installer.pl koha-1.3.2/installer.pl
--- koha-1.3.2.orig/installer.pl Sun Jan 5 00:40:29 2003
+++ koha-1.3.2/installer.pl Sun Jan 12 22:17:48 2003
@@ -35,7 +35,7 @@
releasecandidatewarning();
}
-#checkabortedinstall();
+checkabortedinstall();
if (-e "$::etcdir/koha.conf") {
$::installedversion=`grep kohaversion= $::etcdir/koha.conf`;
------------ cut here --------- 8< --------------------------
Best regards,
--
Ambrose Li <address@hidden>
http://ada.dhs.org/~acli/cmcc/ http://www.cccgt.org/
DRM is theft - We are the stakeholders
- [Koha-devel] Regressions in the latest CVS,
address@hidden via news-to-mail gateway <=