#!/bin/sh # # koha-create -- Create a new Koha instance. # Copyright 2010 Catalyst IT, Ltd # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY; without even the implied warranty of # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the # GNU General Public License for more details. # # You should have received a copy of the GNU General Public License # along with this program. If not, see . set -e die() { echo "$@" 1>&2 exit 1 } generate_config_file() { touch "$2" chown "root:$username" "$2" chmod 0640 "$2" sed -e "s/__KOHASITE__/$name/g" \ -e "s/__OPACPORT__/80/g" \ -e "s/__INTRAPORT__/$INTRAPORT/g" \ -e "s/__OPACSERVER__/$domain/g" \ -e "s/__INTRASERVER__/$intradomain/g" \ -e "s/__ZEBRA_PASS__/$zebrapwd/g" \ -e "s/__DB_NAME__/$mysqldb/g" \ -e "s/__DB_USER__/$mysqluser/g" \ -e "s/__DB_PASS__/$mysqlpwd/g" \ -e "s/__UNIXUSER__/$username/g" \ -e "s/__UNIXGROUP__/$username/g" \ "/etc/koha/$1" > "$2" } # Set defaults and read config file, if it exists. DOMAIN="" INTRAPORT="8080" INTRAPREFIX="" INTRASUFFIX="" DEFAULTSQL="" if [ -e /etc/koha/koha-sites.conf ] then . /etc/koha/koha-sites.conf fi # Parse command line. [ "$#" = 1 ] || die "Usage: $0 instancename" name="$1" domain="$name$DOMAIN" if [ "$INTRAPORT" = 80 ] || [ "$INTRAPORT" = "" ] then intradomain="$INTRAPREFIX$name$INTRASUFFIX$DOMAIN" else intradomain="$INTRAPREFIX$name$INTRASUFFIX$DOMAIN:$INTRAPORT" fi # Create new user and group. username="$name-koha" if getent passwd "$username" > /dev/null then die "User $username already exists." fi if getent group "$username" > /dev/null then die "Group $username already exists." fi adduser --no-create-home --disabled-login --gecos "Koha instance $username" \ --quiet "$username" # Create the site-specific directories. koha-create-dirs "$name" # Generate Zebra database password. zebrapwd="$(pwgen -1)" # Set up MySQL database for this instance. mysqldb="koha_$name" mysqluser="koha_$name" mysqlpwd="$(pwgen -1)" mysql --defaults-extra-file=/etc/mysql/debian.cnf <) { print md5_base64($_), "\n"; }') mysql --defaults-extra-file=/etc/mysql/debian.cnf <