Browse Source

(added) Ancillary files for new installer.

3.0.x
arensb 20 years ago
parent
commit
49c8fef9e7
  1. 30
      Make.conf.in
  2. 105
      Makefile
  3. 251
      install-sh
  4. 16
      koha.conf.in

30
Make.conf.in

@ -0,0 +1,30 @@
# Make.conf -*- Makefile -*-
# This file is generated automatically from Make.conf.in by
# safe-installer.
# $Id$
# Useful utilities
PERL = @prog_perl@
MYSQL = @prog_mysql@
MYSQLADMIN = @prog_mysqladmin@
MYSQLDUMP = @prog_mysqldump@
# MySQL administration
DBA_USER = @dba_user@
# Koha database administration
DB_NAME = @db_name@
DB_HOST = @db_host@
DB_USER = @db_user@
# Path to koha.conf file, one for the intranet, the other for the OPAC
# site.
KOHA_CONF_INTRA = @koha_conf_intra@
KOHA_CONF_OPAC = @koha_conf_opac@
OPAC_HOST = @opac_host@
OPAC_REALHOSTS = @opac_realhosts@
INTRA_HOST = @intra_host@
INTRA_REALHOSTS = @intra_realhosts@

105
Makefile

@ -0,0 +1,105 @@
### Commands
# STTY
# CHOWN
# CHMOD
# PERL
# MYSQL
# MYSQLADMIN
# INSTALL BSD-compatible install tool
### MySQL database administration
# DBA_NAME Name of MySQL administrator
# DBA_PASSWD MySQL administrator password
### Koha database
# DB_NAME Koha database name
# DB_USER Koha database user
# DB_PASSWD Koha database user's password
### OPAC site
# OPAC_DOC_URL Root of tree containing HTML documents
# OPAC_CGI_URL Root of CGI tree
# OPAC_DOC_DIR Where to install HTML files
# OPAC_CGI_DIR Where to install CGI scripts
### OPAC site
# INTRA_DOC_URL Root of tree containing HTML documents
# INTRA_CGI_URL Root of CGI tree
# INTRA_DOC_DIR Where to install HTML files
# INTRA_CGI_DIR Where to install CGI scripts
# Prefer 'install-sh -d' over 'mkdir', because 'install-sh' will
# create directories recursively if they don't exist. But not all
# Unices support 'mkdir -p'.
MKDIR = ./install-sh -d
# XXX - Add 'clean:' target.
include Make.conf
all:
@echo "Please use one of the following:"
@echo " config Configuration script"
@echo " install-db Install the database"
@echo " install-opac Install the OPAC web site"
@echo " install-intra Install the intranet web site"
config configure Make.conf koha.conf.new:
./safe-installer
# XXX - Need to create the Koha user(s) and grant permissions before
# creating the database itself.
# Create the database.
#
# Given the semantics of the MySQL arguments, if $(DBA_PASSWD) isn't
# set, the user will be prompted for them (repeatedly).
#
# First, this runs 'mysqladmin status' to make sure that the current
# user can really connect to the database and do stuff. This really
# isn't a good test, since it really only checks that $(DBA_PASSWD)
# corresponds to $(DBA_USER), and that $(DBA_USER) is authorized to
# read a little bit, but it's better than nothing.
#
# Next, this runs 'mysqldump' on the database we want to create. If
# this exits with a zero status, then everything went well, which
# means that the database already exists. If 'mysqladmin' succeeded
# but 'mysqldump' failed, we figure it must be because the database
# doesn't exist yet, so we need to create it.
create-db: koha.mysql
@echo "Checking authorization to connect to MySQL"
@echo "You may be prompted for the database administrator's password"
$(MYSQLADMIN) "-u$(DBA_USER)" "-p$(DBA_PASSWD)" status >/dev/null 2>&1
@echo "Checking whether $(DB_NAME) already exists"
@echo "$(MYSQLDUMP) -d -u$(DBA_USER) -p$(DBA_PASSWD) $(DB_NAME) >/dev/null"
@if $(MYSQLDUMP) -d "-u$(DBA_USER)" "-p$(DBA_PASSWD)" $(DB_NAME) >/dev/null 2>&1; then \
echo "Database $(DB_NAME) already exists"; \
else \
echo "Creating database $(DB_NAME)"; \
echo "$(MYSQLADMIN) -u$(DBA_USER) -p<password> create $(DB_NAME)"; \
$(MYSQLADMIN) "-u$(DBA_USER)" "-p$(DBA_PASSWD)" create $(DB_NAME); \
echo "Adding tables to $(DB_NAME)"; \
$(MYSQL) "-u$(DBA_USER)" "-p$(DBA_PASSWD)" $(DB_NAME) < koha.mysql; \
fi
# After ensuring that the database exists, bring it up to date.
# XXX - Currently, the sample data set assumes the v1.2 database,
# which is different from what 'updater/updatedatabase' will create.
# Hence, if the user wants to install the sample data, it'll be
# necessary to install it before running 'updater/updatedatabase'.
install-db: create-db
@echo "Updating database as necessary"
KOHA_CONF=koha.conf.new ./updater/updatedatabase
install-opac: install-opac-html install-opac-cgi
install-opac-html:
install-opac-cgi:
install-intra: install-intra-html install-intra-cgi
install-intra-html:
install-intra-cgi:

251
install-sh

@ -0,0 +1,251 @@
#!/bin/sh
#
# install - install a program, script, or datafile
# This comes from X11R5 (mit/util/scripts/install.sh).
#
# Copyright 1991 by the Massachusetts Institute of Technology
#
# Permission to use, copy, modify, distribute, and sell this software and its
# documentation for any purpose is hereby granted without fee, provided that
# the above copyright notice appear in all copies and that both that
# copyright notice and this permission notice appear in supporting
# documentation, and that the name of M.I.T. not be used in advertising or
# publicity pertaining to distribution of the software without specific,
# written prior permission. M.I.T. makes no representations about the
# suitability of this software for any purpose. It is provided "as is"
# without express or implied warranty.
#
# Calling this script install-sh is preferred over install.sh, to prevent
# `make' implicit rules from creating a file called install from it
# when there is no Makefile.
#
# This script is compatible with the BSD install script, but was written
# from scratch. It can only install one file at a time, a restriction
# shared with many OS's install programs.
# set DOITPROG to echo to test this script
# Don't use :- since 4.3BSD and earlier shells don't like it.
doit="${DOITPROG-}"
# put in absolute paths if you don't have them in your path; or use env. vars.
mvprog="${MVPROG-mv}"
cpprog="${CPPROG-cp}"
chmodprog="${CHMODPROG-chmod}"
chownprog="${CHOWNPROG-chown}"
chgrpprog="${CHGRPPROG-chgrp}"
stripprog="${STRIPPROG-strip}"
rmprog="${RMPROG-rm}"
mkdirprog="${MKDIRPROG-mkdir}"
transformbasename=""
transform_arg=""
instcmd="$mvprog"
chmodcmd="$chmodprog 0755"
chowncmd=""
chgrpcmd=""
stripcmd=""
rmcmd="$rmprog -f"
mvcmd="$mvprog"
src=""
dst=""
dir_arg=""
while [ x"$1" != x ]; do
case $1 in
-c) instcmd="$cpprog"
shift
continue;;
-d) dir_arg=true
shift
continue;;
-m) chmodcmd="$chmodprog $2"
shift
shift
continue;;
-o) chowncmd="$chownprog $2"
shift
shift
continue;;
-g) chgrpcmd="$chgrpprog $2"
shift
shift
continue;;
-s) stripcmd="$stripprog"
shift
continue;;
-t=*) transformarg=`echo $1 | sed 's/-t=//'`
shift
continue;;
-b=*) transformbasename=`echo $1 | sed 's/-b=//'`
shift
continue;;
*) if [ x"$src" = x ]
then
src=$1
else
# this colon is to work around a 386BSD /bin/sh bug
:
dst=$1
fi
shift
continue;;
esac
done
if [ x"$src" = x ]
then
echo "install: no input file specified"
exit 1
else
true
fi
if [ x"$dir_arg" != x ]; then
dst=$src
src=""
if [ -d $dst ]; then
instcmd=:
chmodcmd=""
else
instcmd=mkdir
fi
else
# Waiting for this to be detected by the "$instcmd $src $dsttmp" command
# might cause directories to be created, which would be especially bad
# if $src (and thus $dsttmp) contains '*'.
if [ -f $src -o -d $src ]
then
true
else
echo "install: $src does not exist"
exit 1
fi
if [ x"$dst" = x ]
then
echo "install: no destination specified"
exit 1
else
true
fi
# If destination is a directory, append the input filename; if your system
# does not like double slashes in filenames, you may need to add some logic
if [ -d $dst ]
then
dst="$dst"/`basename $src`
else
true
fi
fi
## this sed command emulates the dirname command
dstdir=`echo $dst | sed -e 's,[^/]*$,,;s,/$,,;s,^$,.,'`
# Make sure that the destination directory exists.
# this part is taken from Noah Friedman's mkinstalldirs script
# Skip lots of stat calls in the usual case.
if [ ! -d "$dstdir" ]; then
defaultIFS='
'
IFS="${IFS-${defaultIFS}}"
oIFS="${IFS}"
# Some sh's can't handle IFS=/ for some reason.
IFS='%'
set - `echo ${dstdir} | sed -e 's@/@%@g' -e 's@^%@/@'`
IFS="${oIFS}"
pathcomp=''
while [ $# -ne 0 ] ; do
pathcomp="${pathcomp}${1}"
shift
if [ ! -d "${pathcomp}" ] ;
then
$mkdirprog "${pathcomp}"
else
true
fi
pathcomp="${pathcomp}/"
done
fi
if [ x"$dir_arg" != x ]
then
$doit $instcmd $dst &&
if [ x"$chowncmd" != x ]; then $doit $chowncmd $dst; else true ; fi &&
if [ x"$chgrpcmd" != x ]; then $doit $chgrpcmd $dst; else true ; fi &&
if [ x"$stripcmd" != x ]; then $doit $stripcmd $dst; else true ; fi &&
if [ x"$chmodcmd" != x ]; then $doit $chmodcmd $dst; else true ; fi
else
# If we're going to rename the final executable, determine the name now.
if [ x"$transformarg" = x ]
then
dstfile=`basename $dst`
else
dstfile=`basename $dst $transformbasename |
sed $transformarg`$transformbasename
fi
# don't allow the sed command to completely eliminate the filename
if [ x"$dstfile" = x ]
then
dstfile=`basename $dst`
else
true
fi
# Make a temp file name in the proper directory.
dsttmp=$dstdir/#inst.$$#
# Move or copy the file name to the temp name
$doit $instcmd $src $dsttmp &&
trap "rm -f ${dsttmp}" 0 &&
# and set any options; do chmod last to preserve setuid bits
# If any of these fail, we abort the whole thing. If we want to
# ignore errors from any of these, just make sure not to ignore
# errors from the above "$doit $instcmd $src $dsttmp" command.
if [ x"$chowncmd" != x ]; then $doit $chowncmd $dsttmp; else true;fi &&
if [ x"$chgrpcmd" != x ]; then $doit $chgrpcmd $dsttmp; else true;fi &&
if [ x"$stripcmd" != x ]; then $doit $stripcmd $dsttmp; else true;fi &&
if [ x"$chmodcmd" != x ]; then $doit $chmodcmd $dsttmp; else true;fi &&
# Now rename the file to the real destination.
$doit $rmcmd -f $dstdir/$dstfile &&
$doit $mvcmd $dsttmp $dstdir/$dstfile
fi &&
exit 0

16
koha.conf.in

@ -0,0 +1,16 @@
# koha.conf
# This is the Koha configuration file.
# $Id$
# Database access
database = @db_name@
hostname = @db_host@
user = @db_user@
pass = @db_passwd@
# XXX
#includes =
#opachtdocs =
#intrahtdocs =
#templatedirectory =
Loading…
Cancel
Save