From eb7c788def6f9f6a8ffea4aad6097933e080da68618a8aee41404f8f2d2aa33f Mon Sep 17 00:00:00 2001 From: Axel Braun Date: Sat, 16 Jun 2018 09:40:51 +0000 Subject: [PATCH 01/12] OBS-URL: https://build.opensuse.org/package/show/Application:ERP:GNUHealth:Factory/gnuhealth?expand=0&rev=5 --- openSUSE_gnuhealth_setup | 322 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 322 insertions(+) create mode 100644 openSUSE_gnuhealth_setup diff --git a/openSUSE_gnuhealth_setup b/openSUSE_gnuhealth_setup new file mode 100644 index 0000000..3fddb4c --- /dev/null +++ b/openSUSE_gnuhealth_setup @@ -0,0 +1,322 @@ +#!/bin/bash + +# GNU Health installation script for openSUSE +# Version agnostic to GNU Health + +############################################################################## +# +# GNU Health Installer for openSUSE +# +# Copyright (C) 2018 Axel Braun +# +# 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 . +# +############################################################################## + +#----------------------------------------------------------------------------- +# Variables declaration +#----------------------------------------------------------------------------- + +#GNU Health installer for openSUSE version +VERSION="0.1" + +# Colors constants +NONE="$(tput sgr0)" +RED="$(tput setaf 1)" +GREEN="$(tput setaf 2)" +YELLOW="\n$(tput setaf 3)" +WHITE="\n$(tput setaf 7)" + +# Params +#ROOT_PW="root" +DB_NAME="GNUHEALTH" +DB_ADMIN_PWD="admin" +DB_USER="tryton" +DB_CONFIG="/var/lib/pgsql/data/pg_hba.conf" +GH_START="y" + +#----------------------------------------------------------------------------- +# Functions +#----------------------------------------------------------------------------- + +message() +{ + local UTC="$(date -u +'%Y-%m-%d %H:%M:%S')" + + case $1 in + ERROR ) echo -e "\e[00;31m${UTC} [ERROR] $2\e[00m";; + WARNING ) echo -e "\e[0;33m${UTC} [WARNING] $2\e[m" ;; + INFO ) echo -e "\e[0;36m${UTC} [INFO] $2\e[m" ;; + esac +} + +help() +{ + cat << EOF + +This is GNU Health Setup for openSUSE ${VERSION} + +usage: `basename $0` command + +Command: + + version : Show version + setup : Setup a GNU Health server + help : shows this message + +EOF + exit 0 +} + +show_version () { + case $1 in + version) message "INFO" "This is is GNU Health setup for openSUSE V ${VERSION}"; exit 0;; + esac + +} + +bailout() { + message "INFO" "Bailing out !" + message "INFO" "Cleaning up temporary file" + rm -rf /tmp/pw +# if [ -e ${BASEDIR}/.installation_ok ];then +# message "WARNING" "Previous successful installation found. NOT removing base dir at ${BASEDIR}" +# else +# message "INFO" "removing base dir at ${BASEDIR}" +# rm -rf ${BASEDIR} +# fi + exit 1 +} + +#----------------------------------------------------------------------------- +# go-ahead: perform update +#----------------------------------------------------------------------------- + +go_ahead() { + +# login as root, start postgres + +echo "Starting database...." + +systemctl start postgresql || bailout + +echo "Database started" + +# su -postgres || bailout +#then as postgres, and change parameter + +echo "Changing postgres trust method" + +sudo -u postgres sed -i -e 's/\(\(local\|host\).*all.*all.*\)\(peer\|ident\)/\1trust/g' ${DB_CONFIG} || bailout + +echo "Postgres trust method changed" + +echo "Create database user" +#create user +sudo -u postgres psql -c "CREATE USER tryton WITH CREATEDB;" || bailout + +echo "Database user created" + +echo "Creating database ${DB_NAME}" +# create database +sudo -u postgres createdb ${DB_NAME} --encoding='UTF8' --owner=tryton || bailout + +echo "Database created" +#exit as postgres +#exit + +echo "Restarting database" + +systemctl restart postgresql || bailout + +# login as user tryton +#su tryton -s /bin/bash + +echo "Initializing database - this may take a while" + +echo ${DB_ADMIN_PWD} > /tmp/pw || bailout + +sudo -u tryton env TRYTONPASSFILE=/tmp/pw trytond-admin -c /etc/tryton/trytond.conf --all -d ${DB_NAME} --password || bailout + +rm /tmp/pw || bailout + + +if [ $GH_START = "y" ]; then +echo "Enabling GNU Health at boot time" + +systemctl enable postgresql +systemctl enable gnuhealth + +fi + +echo "All done" + +} + +#----------------------------------------------------------------------------- +# Call user parameter +#----------------------------------------------------------------------------- + +get_root_pw() { + Y='' + read -p "Please enter root-password [$ROOT_PW] " Y + + if [ ! -e $Y ]; then + ROOT_PW=$Y + fi + message "INFO" "root-password is $ROOT_PW" +} + +get_db_name() { + Y='' + read -p "Please enter name for new database [$DB_NAME] " Y + if [ ! -e $Y ]; then + DB_NAME=$Y + fi + message "INFO" "DB-Name is $DB_NAME" +} + +get_db_admin() { + Y='' + read -p "Please enter admin-password for new database [$DB_ADMIN_PWD] " Y + if [ ! -e $Y ]; then + DB_ADMIN_PWD=$Y + fi + message "INFO" "DB Admin password is $DB_ADMIN_PWD" +} + +get_db_user() { + Y='' + read -p "Please enter database user [$DB_USER] " Y + if [ ! -e $Y ]; then + DB_USER=$Y + fi + message "INFO" "DB User is $DB_USER" +} + +get_db_file() { + Y='' + read -p "Please enter database config file [$DB_CONFIG] " Y + if [ ! -e $Y ]; then + DB_CONFIG=$Y + fi + message "INFO" "DB config path & file $DB_CONFIG" +} + +get_GH_start() { + Y='' + read -p "Shall GNU Health start automatically? [$GH_START] " Y + if [ ! -e $Y ]; then + GH_START=$Y + fi + message "INFO" "GNU Health start at boot $GH_START" +} + + +#----------------------------------------------------------------------------- +# verify input +#----------------------------------------------------------------------------- + +verify_input() { + echo ; + message "INFO" "DB Name is ..............$DB_NAME" + message "INFO" "DB Admin password is ....$DB_ADMIN_PWD" + message "INFO" "DB User is ..............$DB_USER" + message "INFO" "DB config path & file is $DB_CONFIG" + message "INFO" "GNU Health start at boot $GH_START" + read -p "Are these values correct? [y]es/[n]o/[a]bort " VAL + +} + +#----------------------------------------------------------------------------- +# Install +#----------------------------------------------------------------------------- + +setup() { + +# check is it runs as root + wai=`whoami` + + if [ $wai != "root" ]; then + message "ERROR" " This script must run as user 'root'" + bailout + fi + + VAL="n" + message "INFO" "Starting GNU Health setup for openSUSE V ${VERSION} ..." + message "INFO" "If the value displayed is OK, just hit to confirm" + + while [ ${VAL} != "y" ]; do + # (1) Get root password +# get_root_pw + + # (2) get Database name + get_db_name + + # (3) change login + get_db_admin + + message "WARNING" "Change the following parameter only if you know what you are doing..." + + # (4) DB user + get_db_user + + # (5) DB config file and path + get_db_file + + # (6) enable GNUHealth at start? + get_GH_start + + # (7) check if all are valid + verify_input + + # request input until all is OK: + if [ -e ${VAL} ]; then + message "ERROR" "Please enter y, n or a" + verify_input + else + + if [ ${VAL} = "y" ]; then + go_ahead + exit 0 + fi + if [ ${VAL} = "a" ]; then + exit 1 + fi + fi + done + +} + +#----------------------------------------------------------------------------- +# Parse command line +#----------------------------------------------------------------------------- + + +parse_command_line() +{ + if [ $# -eq 0 ]; then + help + fi + + case $1 in + version) show_version $@;; + update-deps) install_python_dependencies $@;; + setup) setup $@;; + help) help;; + *) echo $1: Unrecognized command; exit 1;; + esac +} + +parse_command_line "$@" From c28611211b9fe97b7cba55b7ba34fed07cc5b42f153d8a87d84b3906f5997928 Mon Sep 17 00:00:00 2001 From: Axel Braun Date: Sun, 17 Jun 2018 15:30:45 +0000 Subject: [PATCH 02/12] OBS-URL: https://build.opensuse.org/package/show/Application:ERP:GNUHealth:Factory/gnuhealth?expand=0&rev=6 --- openSUSE_gnuhealth_setup | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/openSUSE_gnuhealth_setup b/openSUSE_gnuhealth_setup index 3fddb4c..d26bd56 100644 --- a/openSUSE_gnuhealth_setup +++ b/openSUSE_gnuhealth_setup @@ -24,12 +24,18 @@ # ############################################################################## +#----------------------------------------------------------------------------- +# Change log +#----------------------------------------------------------------------------- +# V 0.2 20180617 Axel Replace tryton with ${DB_USER} + + #----------------------------------------------------------------------------- # Variables declaration #----------------------------------------------------------------------------- #GNU Health installer for openSUSE version -VERSION="0.1" +VERSION="0.2" # Colors constants NONE="$(tput sgr0)" @@ -124,13 +130,13 @@ echo "Postgres trust method changed" echo "Create database user" #create user -sudo -u postgres psql -c "CREATE USER tryton WITH CREATEDB;" || bailout +sudo -u postgres psql -c "CREATE USER ${DB_USER} WITH CREATEDB;" echo "Database user created" echo "Creating database ${DB_NAME}" # create database -sudo -u postgres createdb ${DB_NAME} --encoding='UTF8' --owner=tryton || bailout +sudo -u postgres createdb ${DB_NAME} --encoding='UTF8' --owner=${DB_USER} || bailout echo "Database created" #exit as postgres From 8278e711deeb1edab5f6646498b2894f91128f42f66d9177cc6378cfb0e9a5b1 Mon Sep 17 00:00:00 2001 From: Axel Braun Date: Wed, 20 Jun 2018 09:18:47 +0000 Subject: [PATCH 03/12] - gnuhealth-control: added info about backup file openSUSE-gnuhealth-setup added OBS-URL: https://build.opensuse.org/package/show/Application:ERP:GNUHealth:Factory/gnuhealth?expand=0&rev=7 --- gnuhealth-control | 14 +- gnuhealth.changes | 6 + gnuhealth.spec | 5 +- openSUSE-gnuhealth-setup | 328 ++++++++++++++++++++++++++++++++++++++ openSUSE_gnuhealth_setup | 331 +-------------------------------------- 5 files changed, 349 insertions(+), 335 deletions(-) create mode 100644 openSUSE-gnuhealth-setup diff --git a/gnuhealth-control b/gnuhealth-control index a9eddab..13430a8 100644 --- a/gnuhealth-control +++ b/gnuhealth-control @@ -24,7 +24,7 @@ # ############################################################################## -VERSION="3.2.2-openSUSE" +VERSION="3.2.3-openSUSE" TRYTON_URL="http://downloads.tryton.org" GNUHEALTH_URL="http://ftp.gnu.org/gnu/health" @@ -177,17 +177,19 @@ do_backup() gzip "${BACKDIR}/backup_${DB}_${BACKDATE}" || bailout cli_msg "INFO" "Compressing GNU Health Attachment directory" | tee -a $INFOFILE - - tar -cvzf "${BACKDIR}/gnuhealth_${DB}_fs_backup_${BACKDATE}.tar.gz" /var/lib/tryton || bailout +#AB - start + BACKUP_NAME=gnuhealth_${DB}_fs_backup_${BACKDATE}.tar.gz +# tar -cvzf "${BACKDIR}/gnuhealth_${DB}_fs_backup_${BACKDATE}.tar.gz" /var/lib/tryton || bailout + tar -cvzf "${BACKDIR}/${BACKUP_NAME}" /var/lib/tryton || bailout cli_msg "INFO" "Creating tarball with compressed DB and GNU Health Attachment directory" | tee -a $INFOFILE tar -cvf "${BACKDIR}/gnuhealth_${DB}_with_fs_backup_${BACKDATE}.tar" \ - ${BACKDIR}/backup_${DB}_${BACKDATE}.gz ${BACKDIR}/gnuhealth_${DB}_fs_backup_${BACKDATE}.tar.gz \ + ${BACKDIR}/backup_${DB}_${BACKDATE}.gz ${BACKDIR}/$BACKUP_NAME} \ || bailout - cli_msg "INFO" "Backup Successful" | tee -a $INFOFILE - + cli_msg "INFO" "Backup successfully written to ${BACKDIR}/${BACKUP_NAME}" | tee -a $INFOFILE +#AB - END #Remove lock file rm $LOCKFILE diff --git a/gnuhealth.changes b/gnuhealth.changes index ed60f82..e20c384 100644 --- a/gnuhealth.changes +++ b/gnuhealth.changes @@ -1,3 +1,9 @@ +------------------------------------------------------------------- +Wed Jun 20 09:17:23 UTC 2018 - axel.braun@gmx.de + +- gnuhealth-control: added info about backup file + openSUSE-gnuhealth-setup added + ------------------------------------------------------------------- Tue Jun 5 12:13:54 UTC 2018 - axel.braun@gmx.de diff --git a/gnuhealth.spec b/gnuhealth.spec index f7bff1e..e796a31 100644 --- a/gnuhealth.spec +++ b/gnuhealth.spec @@ -34,11 +34,12 @@ Source1: GNUHealth.README.SUSE Source2: gnuhealth-control Source3: gnuhealth.service Source4: gnuhealth-webdav@.service +Source4: openSUSE-gnuhealth-setup BuildArch: noarch Summary: A Health and Hospital Information System -License: GPL-3.0+ +License: GPL-3.0-or-later Group: Productivity/Office/Management Requires: proteus @@ -118,6 +119,7 @@ done mkdir -p -m 755 %{buildroot}%{_bindir} install -p -m 755 gnuhealth-control %{buildroot}%{_bindir}/gnuhealth-control +install -p -m 755 %{S:4} %{buildroot}%{_bindir}/openSUSE-gnuhealth-setup mkdir -p $RPM_BUILD_ROOT%{_unitdir} install -p -m 644 %{SOURCE3} $RPM_BUILD_ROOT%{_unitdir}/%{name}.service @@ -152,6 +154,7 @@ EOF %files %defattr(744,root,root) %{_bindir}/gnuhealth-control +%{_bindir}/openSUSE-gnuhealth-setup %{_unitdir}/%{name}.service %{_unitdir}/%{name}-webdav@.service %defattr(-,root,root) diff --git a/openSUSE-gnuhealth-setup b/openSUSE-gnuhealth-setup new file mode 100644 index 0000000..d26bd56 --- /dev/null +++ b/openSUSE-gnuhealth-setup @@ -0,0 +1,328 @@ +#!/bin/bash + +# GNU Health installation script for openSUSE +# Version agnostic to GNU Health + +############################################################################## +# +# GNU Health Installer for openSUSE +# +# Copyright (C) 2018 Axel Braun +# +# 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 . +# +############################################################################## + +#----------------------------------------------------------------------------- +# Change log +#----------------------------------------------------------------------------- +# V 0.2 20180617 Axel Replace tryton with ${DB_USER} + + +#----------------------------------------------------------------------------- +# Variables declaration +#----------------------------------------------------------------------------- + +#GNU Health installer for openSUSE version +VERSION="0.2" + +# Colors constants +NONE="$(tput sgr0)" +RED="$(tput setaf 1)" +GREEN="$(tput setaf 2)" +YELLOW="\n$(tput setaf 3)" +WHITE="\n$(tput setaf 7)" + +# Params +#ROOT_PW="root" +DB_NAME="GNUHEALTH" +DB_ADMIN_PWD="admin" +DB_USER="tryton" +DB_CONFIG="/var/lib/pgsql/data/pg_hba.conf" +GH_START="y" + +#----------------------------------------------------------------------------- +# Functions +#----------------------------------------------------------------------------- + +message() +{ + local UTC="$(date -u +'%Y-%m-%d %H:%M:%S')" + + case $1 in + ERROR ) echo -e "\e[00;31m${UTC} [ERROR] $2\e[00m";; + WARNING ) echo -e "\e[0;33m${UTC} [WARNING] $2\e[m" ;; + INFO ) echo -e "\e[0;36m${UTC} [INFO] $2\e[m" ;; + esac +} + +help() +{ + cat << EOF + +This is GNU Health Setup for openSUSE ${VERSION} + +usage: `basename $0` command + +Command: + + version : Show version + setup : Setup a GNU Health server + help : shows this message + +EOF + exit 0 +} + +show_version () { + case $1 in + version) message "INFO" "This is is GNU Health setup for openSUSE V ${VERSION}"; exit 0;; + esac + +} + +bailout() { + message "INFO" "Bailing out !" + message "INFO" "Cleaning up temporary file" + rm -rf /tmp/pw +# if [ -e ${BASEDIR}/.installation_ok ];then +# message "WARNING" "Previous successful installation found. NOT removing base dir at ${BASEDIR}" +# else +# message "INFO" "removing base dir at ${BASEDIR}" +# rm -rf ${BASEDIR} +# fi + exit 1 +} + +#----------------------------------------------------------------------------- +# go-ahead: perform update +#----------------------------------------------------------------------------- + +go_ahead() { + +# login as root, start postgres + +echo "Starting database...." + +systemctl start postgresql || bailout + +echo "Database started" + +# su -postgres || bailout +#then as postgres, and change parameter + +echo "Changing postgres trust method" + +sudo -u postgres sed -i -e 's/\(\(local\|host\).*all.*all.*\)\(peer\|ident\)/\1trust/g' ${DB_CONFIG} || bailout + +echo "Postgres trust method changed" + +echo "Create database user" +#create user +sudo -u postgres psql -c "CREATE USER ${DB_USER} WITH CREATEDB;" + +echo "Database user created" + +echo "Creating database ${DB_NAME}" +# create database +sudo -u postgres createdb ${DB_NAME} --encoding='UTF8' --owner=${DB_USER} || bailout + +echo "Database created" +#exit as postgres +#exit + +echo "Restarting database" + +systemctl restart postgresql || bailout + +# login as user tryton +#su tryton -s /bin/bash + +echo "Initializing database - this may take a while" + +echo ${DB_ADMIN_PWD} > /tmp/pw || bailout + +sudo -u tryton env TRYTONPASSFILE=/tmp/pw trytond-admin -c /etc/tryton/trytond.conf --all -d ${DB_NAME} --password || bailout + +rm /tmp/pw || bailout + + +if [ $GH_START = "y" ]; then +echo "Enabling GNU Health at boot time" + +systemctl enable postgresql +systemctl enable gnuhealth + +fi + +echo "All done" + +} + +#----------------------------------------------------------------------------- +# Call user parameter +#----------------------------------------------------------------------------- + +get_root_pw() { + Y='' + read -p "Please enter root-password [$ROOT_PW] " Y + + if [ ! -e $Y ]; then + ROOT_PW=$Y + fi + message "INFO" "root-password is $ROOT_PW" +} + +get_db_name() { + Y='' + read -p "Please enter name for new database [$DB_NAME] " Y + if [ ! -e $Y ]; then + DB_NAME=$Y + fi + message "INFO" "DB-Name is $DB_NAME" +} + +get_db_admin() { + Y='' + read -p "Please enter admin-password for new database [$DB_ADMIN_PWD] " Y + if [ ! -e $Y ]; then + DB_ADMIN_PWD=$Y + fi + message "INFO" "DB Admin password is $DB_ADMIN_PWD" +} + +get_db_user() { + Y='' + read -p "Please enter database user [$DB_USER] " Y + if [ ! -e $Y ]; then + DB_USER=$Y + fi + message "INFO" "DB User is $DB_USER" +} + +get_db_file() { + Y='' + read -p "Please enter database config file [$DB_CONFIG] " Y + if [ ! -e $Y ]; then + DB_CONFIG=$Y + fi + message "INFO" "DB config path & file $DB_CONFIG" +} + +get_GH_start() { + Y='' + read -p "Shall GNU Health start automatically? [$GH_START] " Y + if [ ! -e $Y ]; then + GH_START=$Y + fi + message "INFO" "GNU Health start at boot $GH_START" +} + + +#----------------------------------------------------------------------------- +# verify input +#----------------------------------------------------------------------------- + +verify_input() { + echo ; + message "INFO" "DB Name is ..............$DB_NAME" + message "INFO" "DB Admin password is ....$DB_ADMIN_PWD" + message "INFO" "DB User is ..............$DB_USER" + message "INFO" "DB config path & file is $DB_CONFIG" + message "INFO" "GNU Health start at boot $GH_START" + read -p "Are these values correct? [y]es/[n]o/[a]bort " VAL + +} + +#----------------------------------------------------------------------------- +# Install +#----------------------------------------------------------------------------- + +setup() { + +# check is it runs as root + wai=`whoami` + + if [ $wai != "root" ]; then + message "ERROR" " This script must run as user 'root'" + bailout + fi + + VAL="n" + message "INFO" "Starting GNU Health setup for openSUSE V ${VERSION} ..." + message "INFO" "If the value displayed is OK, just hit to confirm" + + while [ ${VAL} != "y" ]; do + # (1) Get root password +# get_root_pw + + # (2) get Database name + get_db_name + + # (3) change login + get_db_admin + + message "WARNING" "Change the following parameter only if you know what you are doing..." + + # (4) DB user + get_db_user + + # (5) DB config file and path + get_db_file + + # (6) enable GNUHealth at start? + get_GH_start + + # (7) check if all are valid + verify_input + + # request input until all is OK: + if [ -e ${VAL} ]; then + message "ERROR" "Please enter y, n or a" + verify_input + else + + if [ ${VAL} = "y" ]; then + go_ahead + exit 0 + fi + if [ ${VAL} = "a" ]; then + exit 1 + fi + fi + done + +} + +#----------------------------------------------------------------------------- +# Parse command line +#----------------------------------------------------------------------------- + + +parse_command_line() +{ + if [ $# -eq 0 ]; then + help + fi + + case $1 in + version) show_version $@;; + update-deps) install_python_dependencies $@;; + setup) setup $@;; + help) help;; + *) echo $1: Unrecognized command; exit 1;; + esac +} + +parse_command_line "$@" diff --git a/openSUSE_gnuhealth_setup b/openSUSE_gnuhealth_setup index d26bd56..25611e8 100644 --- a/openSUSE_gnuhealth_setup +++ b/openSUSE_gnuhealth_setup @@ -1,328 +1,3 @@ -#!/bin/bash - -# GNU Health installation script for openSUSE -# Version agnostic to GNU Health - -############################################################################## -# -# GNU Health Installer for openSUSE -# -# Copyright (C) 2018 Axel Braun -# -# 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 . -# -############################################################################## - -#----------------------------------------------------------------------------- -# Change log -#----------------------------------------------------------------------------- -# V 0.2 20180617 Axel Replace tryton with ${DB_USER} - - -#----------------------------------------------------------------------------- -# Variables declaration -#----------------------------------------------------------------------------- - -#GNU Health installer for openSUSE version -VERSION="0.2" - -# Colors constants -NONE="$(tput sgr0)" -RED="$(tput setaf 1)" -GREEN="$(tput setaf 2)" -YELLOW="\n$(tput setaf 3)" -WHITE="\n$(tput setaf 7)" - -# Params -#ROOT_PW="root" -DB_NAME="GNUHEALTH" -DB_ADMIN_PWD="admin" -DB_USER="tryton" -DB_CONFIG="/var/lib/pgsql/data/pg_hba.conf" -GH_START="y" - -#----------------------------------------------------------------------------- -# Functions -#----------------------------------------------------------------------------- - -message() -{ - local UTC="$(date -u +'%Y-%m-%d %H:%M:%S')" - - case $1 in - ERROR ) echo -e "\e[00;31m${UTC} [ERROR] $2\e[00m";; - WARNING ) echo -e "\e[0;33m${UTC} [WARNING] $2\e[m" ;; - INFO ) echo -e "\e[0;36m${UTC} [INFO] $2\e[m" ;; - esac -} - -help() -{ - cat << EOF - -This is GNU Health Setup for openSUSE ${VERSION} - -usage: `basename $0` command - -Command: - - version : Show version - setup : Setup a GNU Health server - help : shows this message - -EOF - exit 0 -} - -show_version () { - case $1 in - version) message "INFO" "This is is GNU Health setup for openSUSE V ${VERSION}"; exit 0;; - esac - -} - -bailout() { - message "INFO" "Bailing out !" - message "INFO" "Cleaning up temporary file" - rm -rf /tmp/pw -# if [ -e ${BASEDIR}/.installation_ok ];then -# message "WARNING" "Previous successful installation found. NOT removing base dir at ${BASEDIR}" -# else -# message "INFO" "removing base dir at ${BASEDIR}" -# rm -rf ${BASEDIR} -# fi - exit 1 -} - -#----------------------------------------------------------------------------- -# go-ahead: perform update -#----------------------------------------------------------------------------- - -go_ahead() { - -# login as root, start postgres - -echo "Starting database...." - -systemctl start postgresql || bailout - -echo "Database started" - -# su -postgres || bailout -#then as postgres, and change parameter - -echo "Changing postgres trust method" - -sudo -u postgres sed -i -e 's/\(\(local\|host\).*all.*all.*\)\(peer\|ident\)/\1trust/g' ${DB_CONFIG} || bailout - -echo "Postgres trust method changed" - -echo "Create database user" -#create user -sudo -u postgres psql -c "CREATE USER ${DB_USER} WITH CREATEDB;" - -echo "Database user created" - -echo "Creating database ${DB_NAME}" -# create database -sudo -u postgres createdb ${DB_NAME} --encoding='UTF8' --owner=${DB_USER} || bailout - -echo "Database created" -#exit as postgres -#exit - -echo "Restarting database" - -systemctl restart postgresql || bailout - -# login as user tryton -#su tryton -s /bin/bash - -echo "Initializing database - this may take a while" - -echo ${DB_ADMIN_PWD} > /tmp/pw || bailout - -sudo -u tryton env TRYTONPASSFILE=/tmp/pw trytond-admin -c /etc/tryton/trytond.conf --all -d ${DB_NAME} --password || bailout - -rm /tmp/pw || bailout - - -if [ $GH_START = "y" ]; then -echo "Enabling GNU Health at boot time" - -systemctl enable postgresql -systemctl enable gnuhealth - -fi - -echo "All done" - -} - -#----------------------------------------------------------------------------- -# Call user parameter -#----------------------------------------------------------------------------- - -get_root_pw() { - Y='' - read -p "Please enter root-password [$ROOT_PW] " Y - - if [ ! -e $Y ]; then - ROOT_PW=$Y - fi - message "INFO" "root-password is $ROOT_PW" -} - -get_db_name() { - Y='' - read -p "Please enter name for new database [$DB_NAME] " Y - if [ ! -e $Y ]; then - DB_NAME=$Y - fi - message "INFO" "DB-Name is $DB_NAME" -} - -get_db_admin() { - Y='' - read -p "Please enter admin-password for new database [$DB_ADMIN_PWD] " Y - if [ ! -e $Y ]; then - DB_ADMIN_PWD=$Y - fi - message "INFO" "DB Admin password is $DB_ADMIN_PWD" -} - -get_db_user() { - Y='' - read -p "Please enter database user [$DB_USER] " Y - if [ ! -e $Y ]; then - DB_USER=$Y - fi - message "INFO" "DB User is $DB_USER" -} - -get_db_file() { - Y='' - read -p "Please enter database config file [$DB_CONFIG] " Y - if [ ! -e $Y ]; then - DB_CONFIG=$Y - fi - message "INFO" "DB config path & file $DB_CONFIG" -} - -get_GH_start() { - Y='' - read -p "Shall GNU Health start automatically? [$GH_START] " Y - if [ ! -e $Y ]; then - GH_START=$Y - fi - message "INFO" "GNU Health start at boot $GH_START" -} - - -#----------------------------------------------------------------------------- -# verify input -#----------------------------------------------------------------------------- - -verify_input() { - echo ; - message "INFO" "DB Name is ..............$DB_NAME" - message "INFO" "DB Admin password is ....$DB_ADMIN_PWD" - message "INFO" "DB User is ..............$DB_USER" - message "INFO" "DB config path & file is $DB_CONFIG" - message "INFO" "GNU Health start at boot $GH_START" - read -p "Are these values correct? [y]es/[n]o/[a]bort " VAL - -} - -#----------------------------------------------------------------------------- -# Install -#----------------------------------------------------------------------------- - -setup() { - -# check is it runs as root - wai=`whoami` - - if [ $wai != "root" ]; then - message "ERROR" " This script must run as user 'root'" - bailout - fi - - VAL="n" - message "INFO" "Starting GNU Health setup for openSUSE V ${VERSION} ..." - message "INFO" "If the value displayed is OK, just hit to confirm" - - while [ ${VAL} != "y" ]; do - # (1) Get root password -# get_root_pw - - # (2) get Database name - get_db_name - - # (3) change login - get_db_admin - - message "WARNING" "Change the following parameter only if you know what you are doing..." - - # (4) DB user - get_db_user - - # (5) DB config file and path - get_db_file - - # (6) enable GNUHealth at start? - get_GH_start - - # (7) check if all are valid - verify_input - - # request input until all is OK: - if [ -e ${VAL} ]; then - message "ERROR" "Please enter y, n or a" - verify_input - else - - if [ ${VAL} = "y" ]; then - go_ahead - exit 0 - fi - if [ ${VAL} = "a" ]; then - exit 1 - fi - fi - done - -} - -#----------------------------------------------------------------------------- -# Parse command line -#----------------------------------------------------------------------------- - - -parse_command_line() -{ - if [ $# -eq 0 ]; then - help - fi - - case $1 in - version) show_version $@;; - update-deps) install_python_dependencies $@;; - setup) setup $@;; - help) help;; - *) echo $1: Unrecognized command; exit 1;; - esac -} - -parse_command_line "$@" +# To unify the gnuhealth-commands, the script was renamed to +# openSUSE-gnuhealth-setup +# please use this file instead. Thank you! From ef4b6bf7fd260b678db6375fc92f51636044204aad632a136c80f6ecb2a99cb5 Mon Sep 17 00:00:00 2001 From: Axel Braun Date: Wed, 20 Jun 2018 09:28:00 +0000 Subject: [PATCH 04/12] OBS-URL: https://build.opensuse.org/package/show/Application:ERP:GNUHealth:Factory/gnuhealth?expand=0&rev=8 --- gnuhealth.spec | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/gnuhealth.spec b/gnuhealth.spec index e796a31..cf20906 100644 --- a/gnuhealth.spec +++ b/gnuhealth.spec @@ -34,7 +34,7 @@ Source1: GNUHealth.README.SUSE Source2: gnuhealth-control Source3: gnuhealth.service Source4: gnuhealth-webdav@.service -Source4: openSUSE-gnuhealth-setup +Source5: openSUSE-gnuhealth-setup BuildArch: noarch @@ -119,7 +119,7 @@ done mkdir -p -m 755 %{buildroot}%{_bindir} install -p -m 755 gnuhealth-control %{buildroot}%{_bindir}/gnuhealth-control -install -p -m 755 %{S:4} %{buildroot}%{_bindir}/openSUSE-gnuhealth-setup +install -p -m 755 %{S:5} %{buildroot}%{_bindir}/openSUSE-gnuhealth-setup mkdir -p $RPM_BUILD_ROOT%{_unitdir} install -p -m 644 %{SOURCE3} $RPM_BUILD_ROOT%{_unitdir}/%{name}.service From bafbf39d98f907269fb5b8e21ae00460155ccdb3c592c6355ffeb7572b6601d0 Mon Sep 17 00:00:00 2001 From: Axel Braun Date: Fri, 13 Jul 2018 07:12:25 +0000 Subject: [PATCH 05/12] Accepting request 622426 from home:DocB:branches:Application:ERP:GNUHealth:Factory - openSUSE-gnuhealth-setup: User tryton set to SUPERUSER OBS-URL: https://build.opensuse.org/request/show/622426 OBS-URL: https://build.opensuse.org/package/show/Application:ERP:GNUHealth:Factory/gnuhealth?expand=0&rev=10 --- gnuhealth.changes | 5 +++++ openSUSE-gnuhealth-setup | 7 ++++--- 2 files changed, 9 insertions(+), 3 deletions(-) diff --git a/gnuhealth.changes b/gnuhealth.changes index e20c384..24a2dc4 100644 --- a/gnuhealth.changes +++ b/gnuhealth.changes @@ -1,3 +1,8 @@ +------------------------------------------------------------------- +Thu Jul 12 19:34:44 UTC 2018 - axel.braun@gmx.de + +- openSUSE-gnuhealth-setup: User tryton set to SUPERUSER + ------------------------------------------------------------------- Wed Jun 20 09:17:23 UTC 2018 - axel.braun@gmx.de diff --git a/openSUSE-gnuhealth-setup b/openSUSE-gnuhealth-setup index d26bd56..21d4177 100644 --- a/openSUSE-gnuhealth-setup +++ b/openSUSE-gnuhealth-setup @@ -28,6 +28,7 @@ # Change log #----------------------------------------------------------------------------- # V 0.2 20180617 Axel Replace tryton with ${DB_USER} +# V 0.3 20180712 Axel Set user 'tryton' to superuser (otherwise installation of DMO-DB fails) #----------------------------------------------------------------------------- @@ -35,7 +36,7 @@ #----------------------------------------------------------------------------- #GNU Health installer for openSUSE version -VERSION="0.2" +VERSION="0.3" # Colors constants NONE="$(tput sgr0)" @@ -130,7 +131,7 @@ echo "Postgres trust method changed" echo "Create database user" #create user -sudo -u postgres psql -c "CREATE USER ${DB_USER} WITH CREATEDB;" +sudo -u postgres psql -c "CREATE USER ${DB_USER} WITH SUPERUSER;" echo "Database user created" @@ -153,7 +154,7 @@ echo "Initializing database - this may take a while" echo ${DB_ADMIN_PWD} > /tmp/pw || bailout -sudo -u tryton env TRYTONPASSFILE=/tmp/pw trytond-admin -c /etc/tryton/trytond.conf --all -d ${DB_NAME} --password || bailout +sudo -u tryton env TRYTONPASSFILE=/tmp/pw trytond-admin -c /etc/tryton/trytond.conf --all -v -d ${DB_NAME} --password || bailout rm /tmp/pw || bailout From 8a12e9a6e5512d24e1ea1e7034330643ad50e62c1b419d864512e74487c931ac Mon Sep 17 00:00:00 2001 From: Axel Braun Date: Tue, 17 Jul 2018 07:11:21 +0000 Subject: [PATCH 06/12] OBS-URL: https://build.opensuse.org/package/show/Application:ERP:GNUHealth:Factory/gnuhealth?expand=0&rev=11 --- openSUSE_gnuhealth_setup | 3 --- 1 file changed, 3 deletions(-) delete mode 100644 openSUSE_gnuhealth_setup diff --git a/openSUSE_gnuhealth_setup b/openSUSE_gnuhealth_setup deleted file mode 100644 index 25611e8..0000000 --- a/openSUSE_gnuhealth_setup +++ /dev/null @@ -1,3 +0,0 @@ -# To unify the gnuhealth-commands, the script was renamed to -# openSUSE-gnuhealth-setup -# please use this file instead. Thank you! From 6dd64f903ef7ab46168df17e3992ca1e092dc6d3605944a16863370e75d9e636 Mon Sep 17 00:00:00 2001 From: Axel Braun Date: Tue, 17 Jul 2018 07:16:34 +0000 Subject: [PATCH 07/12] OBS-URL: https://build.opensuse.org/package/show/Application:ERP:GNUHealth:Factory/gnuhealth?expand=0&rev=12 --- GNUHealth.README.SUSE | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/GNUHealth.README.SUSE b/GNUHealth.README.SUSE index 37b8180..74ddc7a 100644 --- a/GNUHealth.README.SUSE +++ b/GNUHealth.README.SUSE @@ -6,6 +6,17 @@ How to get it running (Without reading the instructions) You have already installed the package gnuhealth and found this documentation. Good. +As very easy and convenient way to do all required settings, log in as user root and run openSUSE-gnuhealth-setup: + +> su +> openSUSE-gnuhealth-setup setup + +You can follow the proposals given, anyway, **it is not recommended to use default settings for a production environment** + + +The above setup-program automates the steps below, which you could do as well manually, if desired. +(If you have run openSUSE-gnuhealth-setup, the below steps are not needed additionally!) + 1) Log in as root and start the database > su > systemctl start postgresql From 808d1602dcc2ea7b74f61e2f57152ee383b3c8409f16ae8ae3dcd9e26f11a27b Mon Sep 17 00:00:00 2001 From: Axel Braun Date: Tue, 17 Jul 2018 07:19:27 +0000 Subject: [PATCH 08/12] OBS-URL: https://build.opensuse.org/package/show/Application:ERP:GNUHealth:Factory/gnuhealth?expand=0&rev=13 --- gnuhealth.changes | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/gnuhealth.changes b/gnuhealth.changes index 24a2dc4..c05e19b 100644 --- a/gnuhealth.changes +++ b/gnuhealth.changes @@ -1,7 +1,8 @@ ------------------------------------------------------------------- -Thu Jul 12 19:34:44 UTC 2018 - axel.braun@gmx.de +Tue Jul 17 07:19:15 UTC 2018 - axel.braun@gmx.de - openSUSE-gnuhealth-setup: User tryton set to SUPERUSER + Documentation updated ------------------------------------------------------------------- Wed Jun 20 09:17:23 UTC 2018 - axel.braun@gmx.de From 15d6baa3c74b9eacaf8491e9579b483381fe1b1891edbe5bc31cdac2682e4d77 Mon Sep 17 00:00:00 2001 From: Axel Braun Date: Tue, 17 Jul 2018 07:20:51 +0000 Subject: [PATCH 09/12] OBS-URL: https://build.opensuse.org/package/show/Application:ERP:GNUHealth:Factory/gnuhealth?expand=0&rev=14 --- gnuhealth.spec | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gnuhealth.spec b/gnuhealth.spec index cf20906..4b29524 100644 --- a/gnuhealth.spec +++ b/gnuhealth.spec @@ -154,7 +154,7 @@ EOF %files %defattr(744,root,root) %{_bindir}/gnuhealth-control -%{_bindir}/openSUSE-gnuhealth-setup +%{_sbindir}/openSUSE-gnuhealth-setup %{_unitdir}/%{name}.service %{_unitdir}/%{name}-webdav@.service %defattr(-,root,root) From 24b267b9a71e6f3de415f2d677b054f1c3f8e4c815d59e9e74bea1ce3f046b33 Mon Sep 17 00:00:00 2001 From: Axel Braun Date: Thu, 19 Jul 2018 12:57:22 +0000 Subject: [PATCH 10/12] OBS-URL: https://build.opensuse.org/package/show/Application:ERP:GNUHealth:Factory/gnuhealth?expand=0&rev=15 --- gnuhealth.spec | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/gnuhealth.spec b/gnuhealth.spec index 4b29524..8b0ed35 100644 --- a/gnuhealth.spec +++ b/gnuhealth.spec @@ -119,7 +119,7 @@ done mkdir -p -m 755 %{buildroot}%{_bindir} install -p -m 755 gnuhealth-control %{buildroot}%{_bindir}/gnuhealth-control -install -p -m 755 %{S:5} %{buildroot}%{_bindir}/openSUSE-gnuhealth-setup +install -p -m 755 %{S:5} %{buildroot}%{_sbindir}/openSUSE-gnuhealth-setup mkdir -p $RPM_BUILD_ROOT%{_unitdir} install -p -m 644 %{SOURCE3} $RPM_BUILD_ROOT%{_unitdir}/%{name}.service From 03a7de92ee9e59a462b813edc17a2922364358b35b3e9f239ec128207c6061f2 Mon Sep 17 00:00:00 2001 From: Axel Braun Date: Thu, 19 Jul 2018 13:11:08 +0000 Subject: [PATCH 11/12] OBS-URL: https://build.opensuse.org/package/show/Application:ERP:GNUHealth:Factory/gnuhealth?expand=0&rev=16 --- gnuhealth.spec | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/gnuhealth.spec b/gnuhealth.spec index 8b0ed35..cf20906 100644 --- a/gnuhealth.spec +++ b/gnuhealth.spec @@ -119,7 +119,7 @@ done mkdir -p -m 755 %{buildroot}%{_bindir} install -p -m 755 gnuhealth-control %{buildroot}%{_bindir}/gnuhealth-control -install -p -m 755 %{S:5} %{buildroot}%{_sbindir}/openSUSE-gnuhealth-setup +install -p -m 755 %{S:5} %{buildroot}%{_bindir}/openSUSE-gnuhealth-setup mkdir -p $RPM_BUILD_ROOT%{_unitdir} install -p -m 644 %{SOURCE3} $RPM_BUILD_ROOT%{_unitdir}/%{name}.service @@ -154,7 +154,7 @@ EOF %files %defattr(744,root,root) %{_bindir}/gnuhealth-control -%{_sbindir}/openSUSE-gnuhealth-setup +%{_bindir}/openSUSE-gnuhealth-setup %{_unitdir}/%{name}.service %{_unitdir}/%{name}-webdav@.service %defattr(-,root,root) From 2d425ed8838a403781467b8612dfb9e8dd34c5c4113f013297a7a525570432f2 Mon Sep 17 00:00:00 2001 From: Axel Braun Date: Fri, 20 Jul 2018 07:59:31 +0000 Subject: [PATCH 12/12] Accepting request 624216 from home:DocB:branches:Application:ERP:GNUHealth:Factory Warning in setup script added OBS-URL: https://build.opensuse.org/request/show/624216 OBS-URL: https://build.opensuse.org/package/show/Application:ERP:GNUHealth:Factory/gnuhealth?expand=0&rev=17 --- openSUSE-gnuhealth-setup | 11 ++++++----- 1 file changed, 6 insertions(+), 5 deletions(-) diff --git a/openSUSE-gnuhealth-setup b/openSUSE-gnuhealth-setup index 21d4177..ce67a6a 100644 --- a/openSUSE-gnuhealth-setup +++ b/openSUSE-gnuhealth-setup @@ -27,16 +27,16 @@ #----------------------------------------------------------------------------- # Change log #----------------------------------------------------------------------------- -# V 0.2 20180617 Axel Replace tryton with ${DB_USER} -# V 0.3 20180712 Axel Set user 'tryton' to superuser (otherwise installation of DMO-DB fails) - +# V 0.2 20180617 Axel Replace tryton with ${DB_USER} +# V 0.3 20180712 Axel Set user 'tryton' to superuser (otherwise installation of DEMO-DB fails) +# V 0.32 20180720 Axel Warning for production use added #----------------------------------------------------------------------------- # Variables declaration #----------------------------------------------------------------------------- #GNU Health installer for openSUSE version -VERSION="0.3" +VERSION="0.31" # Colors constants NONE="$(tput sgr0)" @@ -154,7 +154,7 @@ echo "Initializing database - this may take a while" echo ${DB_ADMIN_PWD} > /tmp/pw || bailout -sudo -u tryton env TRYTONPASSFILE=/tmp/pw trytond-admin -c /etc/tryton/trytond.conf --all -v -d ${DB_NAME} --password || bailout +sudo -u tryton env TRYTONPASSFILE=/tmp/pw trytond-admin -c /etc/tryton/trytond.conf --all -d ${DB_NAME} --password || bailout rm /tmp/pw || bailout @@ -168,6 +168,7 @@ systemctl enable gnuhealth fi echo "All done" +message "WARNING" "Please review your setup before using the system in production!" }