From 49c8fef9e77c3fb82620f741706e0438fcdc2ce9 Mon Sep 17 00:00:00 2001 From: arensb Date: Wed, 30 Oct 2002 14:06:29 +0000 Subject: [PATCH] (added) Ancillary files for new installer. --- Make.conf.in | 30 ++++++ Makefile | 105 +++++++++++++++++++++ install-sh | 251 +++++++++++++++++++++++++++++++++++++++++++++++++++ koha.conf.in | 16 ++++ 4 files changed, 402 insertions(+) create mode 100644 Make.conf.in create mode 100644 Makefile create mode 100755 install-sh create mode 100644 koha.conf.in diff --git a/Make.conf.in b/Make.conf.in new file mode 100644 index 0000000000..32e6d73996 --- /dev/null +++ b/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@ diff --git a/Makefile b/Makefile new file mode 100644 index 0000000000..58e141abd4 --- /dev/null +++ b/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 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: diff --git a/install-sh b/install-sh new file mode 100755 index 0000000000..e9de23842d --- /dev/null +++ b/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 diff --git a/koha.conf.in b/koha.conf.in new file mode 100644 index 0000000000..dc3f208ca1 --- /dev/null +++ b/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 = -- 2.39.2