#!/bin/bash # Mit diesem Skript lässt sich auf einem Ubuntu-System eine OrderSprinter-System bestehend aus Kernapplikation, # Javaprinter, TSEConnector (Simulationsmodus) sowie nächtlichem Backup auf einem angeschlossenen USB-Stick # einrichten. # Das Skript sollte auf einem frischen Ubuntu-System ausgeführt werden, da es bestehende Daten und Konfigurationen # ändert. # Da in diesem Skript feste Zugangsdaten verwendet werden (die in der aktuellen Version nicht im Skript geändert # werden dürfen!), sollte man das System (nach der Installation) vor einem produktiven Betrieb anpassen: # 1. Fernzugriffscode (im javaprinter.bat und in der Konfiguration) # 2. DB-Zugangsdaten in der MySQL-DB und in der config.json und config1.json # 3. Benutzerzugangspasswörter der Benuter innerhalb der Applikation # Allgemeine Zugangsdaten zur Datenbank. Diese Werte können frei geändert werden. Allerdings darf das Passwort keine # Zeichen enthalten, die in der URL als Argumenttrenner verwendet werden (?,&). Die Passwörter werden dem Intaller # im Klartext übergeben und landen in der Regel im Log des Webservers. dbadminpassword="anadminpass_1" db="ordersprinter" dbuser="os_" dbuserpassword="dbpass" tabprefix="os_" remoteaccesscode="please_change" # OrderSprinter-Version version="2_0_4" # Warnhinweis an den Anwender mit der Möglichkeit des Abbruchs echo "Dieses Skript ist für die Ausführung auf einem frisch aufgesetzten" echo "Ubuntu-System geschrieben worden." echo "Man kann es auch auf einem bereits in Benutzung befindlichen Ubuntu-" echo "System verwenden, allerdings kann es dabei zu Datenverlust kommen:" echo "" echo "Das Installationsskript löscht möglicherweise bereits vorhandene Daten" echo "im Dokumentenverzeichnis des Webservers. Außerdem werden Daten in" echo "verschiedene Verzeichnisse geschrieben (z.B. /usr/local/bin) und" echo "Konfigurationsdateien abgeändert (z.B. php.ini), und Services" echo "angelegt." echo "Es wird eine Datenbank angelegt und eine möglicherweise bereits" echo "DB-Konfiguration sowie eine Datenbank mit Namen '$db'" echo "überschrieben!" echo "" echo "Es können andere als die vordefinierten Zugangsdaten zur Datenbank" echo "verwendet werden. Dazu sind die Werte für die Variablen in diesem " echo "Skript anzupassen (dbadminpassword,db,dbuser,dbusertpassword," echo "tabprefix)." echo "" echo "Das Skript muss als root ausgeführt werden!" echo "" if [[ $EUID -ne 0 ]]; then echo "Das Skript wurde nicht mit root-Rechten gestartet. Die Ausführung muss abgebrochen werden." exit 1 fi read -p "Skript wirklich ausführen (j/n)?" runscript case "$runscript" in j|J ) runscript=1;; * ) runscript=0;; esac echo "Das Skript kann alleine stehend aufgerufen werden und die Version ${version} downloaden" echo "und installieren. Andererseite kann man auch die neueste Version der OrderSprinter-Suite" echo "downloaden, in ein Verzeichnis entpacken und das dortige Skript ausführen." read -p "Wird das Skript im Verzeichnis des entpackten Download der OrderSprinter-Suite aufgerufen (j/n)?" calllocation case "$calllocation" in j|J ) calllocation=1;; * ) calllocation=0;; esac if [[ $runscript -eq 0 ]] then echo "Skriptausführung abgebrochen" exit fi # Frage wegen Installationsumfang insertsamplecontent=0 read -p "Beispieldaten einfügen (Benutzer, Raumplan usw.) (j/n)?" samplecontent case "$samplecontent" in j|J ) insertsamplecontent=1;; * ) insertsamplecontent=0;; esac # Frage Benutzer, ob das TSE-Modul installiert werden soll install_tse=0 read -p "TSEConnector einrichten (j/n)?" choice case "$choice" in j|J ) install_tse=1;; * ) install_tse=0;; esac # Frage Benutzer, ob regelmäßiges Backup azf einen angeschlossenen USB-Stick stattfinden soll autobackup=0 read -p "Regelmäßiges nächtliches Backup um 4 Uhr auf angeschlossenen USB-Stick (j/n)?" dobackup case "$dobackup" in j|J ) autobackup=1;; * ) autobackup=0;; esac # Calculate availabe RAM that can be assigned to PHP process ramsize=$(eval "free -t | grep -oP '\d+' | sed '1!d'") avail=$((ramsize/1000-500))M echo "Assigning $avail of memory for PHP processes" # Download der OrderSprinter-Applikation und Entpacken in ein temporäres Verzeichnis echo "Download der OrderSprinter-Suite ($version)" rm -r /tmp/ordersprinter 2> /dev/null mkdir /tmp/ordersprinter if [[ $calllocation -eq 0 ]] then wget -O /tmp/ordersprinter/os.zip 2>>/dev/null "https://www.ordersprinter.de/ordersprinter-${version}.zip?edition=ubuntu" cd /tmp/ordersprinter echo "Entpacken der OrderSprinter-Suite" unzip -q os.zip else scriptpath="$( cd "$(dirname "$0")" >/dev/null 2>&1 ; pwd -P )" cp -R ${scriptpath}/../* /tmp/ordersprinter fi # Installation der Umgebung echo "Update der Umgebung. Dies wird eine Zeitlang dauern..." echo "Paketlisten neu einlesen und aktualisieren..." apt-get -y update echo "Neuen Versionen von Paketen installieren, falls Aktualisierungen vorhanden sind..." apt-get -y upgrade echo "Installation von Webserver und Datenbank..." apt-get -qq -y install unzip apache2 libapache2-mod-php php mariadb-server php-mysql php-gd php-curl php-zip php-xml default-jre mysqladmin -u root password $dbadminpassword # Konfigurationswerte echo "Anpassen einiger Konfigurationswerte" sed -i -e "s/memory_limit.*/memory_limit = $avail/" /etc/php/7.4/apache2/php.ini sed -i -e "s/max_execution_time.*/max_execution_time = 600/" /etc/php/7.4/apache2/php.ini sed -i -e "s/post_max_size.*/post_max_size = 10000M/" /etc/php/7.4/apache2/php.ini sed -i -e "s/upload_max_filesize.*/upload_max_filesize = 10000M/" /etc/php/7.4/apache2/php.ini service apache2 reload sleep 3s echo "Create database" mysql -uroot -p$dbadminpassword -e "DROP DATABASE IF EXISTS $db"; mysql -uroot -p$dbadminpassword -e "CREATE DATABASE $db DEFAULT CHARACTER SET utf8 DEFAULT COLLATE utf8_general_ci"; mysql -uroot -p$dbadminpassword -e "DROP USER IF EXISTS $dbuser@localhost"; mysql -uroot -p$dbadminpassword -e "CREATE USER $dbuser@localhost IDENTIFIED BY '$dbuserpassword'"; mysql -uroot -p$dbadminpassword -e "GRANT ALL ON $db.* TO $dbuser@localhost"; echo "Copy files to webserver doc directory" rm -r /var/www/html/index.html cp -R /tmp/ordersprinter/webapp/* /var/www/html/ chown -R www-data:www-data /var/www/html chmod -R u+w /var/www/html cd /var/www/html/php echo "Konfiguration des Datenbankzugangs" sed -i -e "s/defined('MYSQL_USER').*/defined('MYSQL_USER') || define ('MYSQL_USER', '$dbuser');/" config.php sed -i -e "s/defined('MYSQL_PASSWORD').*/defined('MYSQL_PASSWORD') || define ('MYSQL_PASSWORD', '$dbuserpassword');/" config.php sed -i -e "s/defined('MYSQL_DB').*/defined('MYSQL_DB') || define ('MYSQL_DB', '$db');/" config.php sed -i -e "s/defined('TAB_PREFIX').*/defined('TAB_PREFIX') || define ('TAB_PREFIX', '$tabprefix');/" config.php echo "Default-Installation der Kernapplikation" wget -O /tmp/loginstall.txt 2>>/dev/null "http://localhost/install/installer.php?command=defaultinstall&db=${db}&dbuser=${dbuser}&dbpass=${dbuserpassword}&prefix=${tabprefix}" if [[ $insertsamplecontent -eq 1 ]] then echo "Beispieldaten einfügen" wget -O /tmp/logsamplecontent.txt 2>>/dev/null "http://localhost/install/installer.php?command=defaultinsertsamplecontent&db=${db}&dbuser=${dbuser}&dbpass=${dbuserpassword}&prefix=${tabprefix}" fi echo "Löschen des Installationsverzeichnisses" rm -r /var/www/html/install echo "Druckserver einrichten" cp -R /tmp/ordersprinter/printserver/javaprinter /usr/local/bin echo "#!/bin/sh" > /usr/local/bin/javaprinter.bat echo "/usr/bin/java -jar /usr/local/bin/javaprinter/javaprinter.jar -configfile=/usr/local/bin/javaprinter/config.json &" >> /usr/local/bin/javaprinter.bat chmod +x /usr/local/bin/javaprinter.bat printf "[Unit]\n" > /etc/systemd/system/javaprinter.service printf "Description=OrderSprinter-Javaprinter\n\n" >> /etc/systemd/system/javaprinter.service printf "[Service]\n" >> /etc/systemd/system/javaprinter.service printf "Type=forking\n" >> /etc/systemd/system/javaprinter.service printf "ExecStart=/usr/local/bin/javaprinter.bat\n\n" >> /etc/systemd/system/javaprinter.service printf "[Install]\n" >> /etc/systemd/system/javaprinter.service printf "WantedBy=multi-user.target\n" >> /etc/systemd/system/javaprinter.service systemctl enable javaprinter.service systemctl start javaprinter if [[ $install_tse -eq 1 ]] then # TSE echo "TSE Setup" cp -R /tmp/ordersprinter/tseconnector /usr/local/bin echo "#!/bin/sh" > /usr/local/bin/tseconnector.bat echo "/usr/bin/java -Djava.library.path=/usr/local/bin/tseconnector/swissbit/nativelibs/linux64 -jar /usr/local/bin/tseconnector/swissbit/tseconnector.jar pass=123 port=8000 supplier=swissbit mountpount=/mnt/SWISSBIT mode=simulate &" >> /usr/local/bin/tseconnector.bat chmod +x /usr/local/bin/tseconnector.bat printf "[Unit]\n" > /etc/systemd/system/tseconnector.service printf "Description=OrderSprinter-TSEConnector\n\n" >> /etc/systemd/system/tseconnector.service printf "[Service]\n" >> /etc/systemd/system/tseconnector.service printf "Type=forking\n" >> /etc/systemd/system/tseconnector.service printf "ExecStart=/usr/local/bin/tseconnector.bat\n\n" >> /etc/systemd/system/tseconnector.service printf "[Install]\n" >> /etc/systemd/system/tseconnector.service printf "WantedBy=multi-user.target\n" >> /etc/systemd/system/tseconnector.service systemctl enable tseconnector.service systemctl start tseconnector # Lasst und nun den TSEConnector aktivieren: mysql -uroot -p$dbadminpassword -e "UPDATE ${db}.${tabprefix}config SET setting='1' WHERE name='usetse'"; # In Deutschland gibt es eine Bonausgabepflicht: mysql -uroot -p$dbadminpassword -e "UPDATE ${db}.${tabprefix}config SET setting='1' WHERE name='forceprint'"; fi if [[ $autobackup -eq 1 ]] then echo "Nächtliches Backup einrichten" cp /tmp/ordersprinter/scripts/backup-db-linux.sh /usr/local/bin/ sed -i -e "s/Benutzer/$dbuser/" /usr/local/bin/backup-db-linux.sh sed -i -e "s/DasPasswort/$dbuserpassword/" /usr/local/bin/backup-db-linux.sh sed -i -e "s/123/$remoteaccesscode/" /usr/local/bin/backup-db-linux.sh sed -i -e "s/localhost\/ordersprinter/localhost/" /usr/local/bin/backup-db-linux.sh mysql -uroot -p$dbadminpassword -e "UPDATE ${db}.${tabprefix}config SET setting='$remoteaccesscode' WHERE name='remoteaccesscode'"; # Passe die Crontab an, damit der Job jede Nacht um 4 Uhr läuft cp /etc/crontab /tmp/crontab # Entferne einen Eintrag von einem möglicherweise vorherigen Scriptlauf sed -i -e "/.*backup-db-linux.*/d" /tmp/crontab # Lösche letzte Zeile (sollte ein Hash sein) sed '$d' /tmp/crontab > /tmp/crontab_without_last_line; mv /tmp/crontab_without_last_line /tmp/crontab # Füge neuen Eintrag hinzu (nächtliche Sicherung um 4 Uhr) echo "0 4 * * * root /usr/local/bin/backup-db-linux.sh > /dev/null 2>&1" >> /tmp/crontab echo "#" >> /tmp/crontab cp /tmp/crontab /etc/crontab fi printf "\n\nInstallation abgeschlossen:\n===========================\n" printf "Der Druckserver ist eingerichtet und startet automatisch. Je nach Drucker und Anbindung kann\n" printf "eine weitere Konfiguration erforderlich sein.\n" printf "Aufruf der OrderSprinter-Applikation im Browser über http://localhost bzw. http://${HOSTNAME}\n" printf "Der TSEConnector befindet sich im Simulationsmodus. Für einen Normalbetrieb muss die\n" printf "Befehlszeile in /usr/local/bin/tseconnector.bat abgeändert werden (mode=normal).\n" printf "Alle eingerichteten Benutzer haben das Passwort 123, ebenso ist der Kassenbon-Stornocode 123.\n"