Files
yourpart3/install-dependencies-opensuse.sh

254 lines
7.6 KiB
Bash
Executable File

#!/bin/bash
# YourPart Daemon Dependencies Installation Script für OpenSUSE Tumbleweed
# Optimiert für OpenSUSE Tumbleweed mit GCC 13
set -euo pipefail
# Farben für Output
RED='\033[0;31m'
GREEN='\033[0;32m'
YELLOW='\033[1;33m'
BLUE='\033[0;34m'
NC='\033[0m' # No Color
log_info() {
echo -e "${BLUE}[INFO]${NC} $1"
}
log_success() {
echo -e "${GREEN}[SUCCESS]${NC} $1"
}
log_warning() {
echo -e "${YELLOW}[WARNING]${NC} $1"
}
log_error() {
echo -e "${RED}[ERROR]${NC} $1"
}
log_info "Installiere Dependencies für YourPart Daemon auf OpenSUSE Tumbleweed..."
# Prüfe OpenSUSE Version
if ! grep -q "openSUSE Tumbleweed" /etc/os-release; then
log_warning "Dieses Script ist für OpenSUSE Tumbleweed optimiert. Andere Versionen könnten Probleme haben."
fi
# Update Package Lists
log_info "Aktualisiere Paketlisten..."
sudo zypper refresh
# Installiere Build-Tools
log_info "Installiere Build-Tools..."
sudo zypper install -y \
gcc \
gcc-c++ \
cmake \
pkg-config \
git \
curl \
wget \
patterns-devel-C-C++-devel_C_C++
# Installiere GCC 13 (falls verfügbar)
log_info "Prüfe verfügbare GCC Versionen..."
if zypper search gcc13 2>/dev/null | grep -q "gcc13"; then
log_info "Installiere GCC 13..."
sudo zypper install -y gcc13 gcc13-c++
# Setze GCC 13 als Standard
sudo update-alternatives --install /usr/bin/gcc gcc /usr/bin/gcc-13 100
sudo update-alternatives --install /usr/bin/g++ g++ /usr/bin/g++-13 100
log_success "GCC 13 erfolgreich installiert und als Standard gesetzt"
else
log_info "GCC 13 nicht verfügbar, verwende Standard-GCC"
# Prüfe verfügbare GCC Versionen
log_info "Verfügbare GCC Versionen:"
gcc --version | head -1
g++ --version | head -1
fi
# Installiere PostgreSQL Development Libraries
log_info "Installiere PostgreSQL Development Libraries..."
# Prüfe welche PostgreSQL Version bereits installiert ist
if rpm -q postgresql16-devel >/dev/null 2>&1; then
log_info "PostgreSQL 16 Development Libraries bereits installiert"
sudo zypper install -y libpqxx-devel
elif zypper search postgresql16-devel 2>/dev/null | grep -q "postgresql16-devel"; then
log_info "Installiere PostgreSQL 16 Development Libraries..."
sudo zypper install -y \
postgresql16-devel \
libpqxx-devel
elif zypper search postgresql15-devel 2>/dev/null | grep -q "postgresql15-devel"; then
log_info "Verwende PostgreSQL 15..."
sudo zypper install -y \
postgresql15-devel \
libpqxx-devel \
postgresql15-server
else
log_info "Verwende PostgreSQL 14..."
sudo zypper install -y \
postgresql14-devel \
libpqxx-devel \
postgresql14-server
fi
# Installiere libwebsockets
log_info "Installiere libwebsockets..."
# Prüfe ob libwebsockets bereits installiert ist
if rpm -q libwebsockets-devel >/dev/null 2>&1; then
log_info "libwebsockets-devel bereits installiert"
else
sudo zypper install -y libwebsockets-devel
fi
# SSL und Zlib Development Libraries (nur wenn nicht bereits installiert)
if rpm -q libressl-devel >/dev/null 2>&1; then
log_info "LibreSSL Development Libraries bereits installiert"
elif ! rpm -q libopenssl-3-devel >/dev/null 2>&1; then
log_info "Installiere OpenSSL Development Libraries..."
sudo zypper install -y libopenssl-3-devel
fi
if rpm -q zlib-ng-compat-devel >/dev/null 2>&1; then
log_info "Zlib Development Libraries bereits installiert"
elif ! rpm -q zlib-devel >/dev/null 2>&1; then
log_info "Installiere Zlib Development Libraries..."
sudo zypper install -y zlib-ng-compat-devel
fi
# Installiere nlohmann-json
log_info "Installiere nlohmann-json..."
sudo zypper install -y nlohmann_json-devel
# Installiere PostgreSQL Server (falls nicht vorhanden)
log_info "Prüfe PostgreSQL Installation..."
if ! systemctl is-active --quiet postgresql; then
log_info "Installiere und starte PostgreSQL Server..."
# Verwende die gleiche Version wie die Development Libraries
if zypper search postgresql16-server 2>/dev/null | grep -q "postgresql16-server"; then
sudo zypper install -y postgresql16-server
elif zypper search postgresql15-server 2>/dev/null | grep -q "postgresql15-server"; then
sudo zypper install -y postgresql15-server
else
sudo zypper install -y postgresql14-server
fi
# Starte PostgreSQL
sudo systemctl start postgresql
sudo systemctl enable postgresql
log_success "PostgreSQL installiert und gestartet"
else
log_success "PostgreSQL läuft bereits"
fi
# Erstelle Datenbank und Benutzer
log_info "Konfiguriere PostgreSQL..."
sudo -u postgres psql << EOF
-- Erstelle Benutzer falls nicht vorhanden
DO \$\$
BEGIN
IF NOT EXISTS (SELECT FROM pg_catalog.pg_roles WHERE rolname = 'yourpart') THEN
CREATE USER yourpart WITH PASSWORD 'hitomisan';
END IF;
END
\$\$;
-- Erstelle Datenbank falls nicht vorhanden
SELECT 'CREATE DATABASE yp3 OWNER yourpart'
WHERE NOT EXISTS (SELECT FROM pg_database WHERE datname = 'yp3')\gexec
-- Setze Berechtigungen
GRANT ALL PRIVILEGES ON DATABASE yp3 TO yourpart;
\q
EOF
log_success "PostgreSQL konfiguriert"
# Installiere systemd (sollte bereits vorhanden sein)
log_info "Prüfe systemd..."
if ! command -v systemctl &> /dev/null; then
log_error "systemd ist nicht installiert. Bitte installieren Sie OpenSUSE Tumbleweed."
exit 1
fi
log_success "systemd verfügbar"
# Installiere zusätzliche Tools für Monitoring
log_info "Installiere Monitoring-Tools..."
sudo zypper install -y \
htop \
iotop \
net-tools \
lsof
# Konfiguriere Firewall (falls firewalld installiert ist)
if command -v firewall-cmd &> /dev/null; then
log_info "Konfiguriere Firewall..."
sudo firewall-cmd --permanent --add-port=4551/tcp
sudo firewall-cmd --permanent --add-port=22/tcp
sudo firewall-cmd --reload
log_success "Firewall konfiguriert"
fi
# Erstelle Log-Verzeichnis
log_info "Erstelle Log-Verzeichnisse..."
sudo mkdir -p /var/log/yourpart
sudo chmod 755 /var/log/yourpart
# Teste Compiler-Konfiguration
log_info "Teste Compiler-Konfiguration..."
cat > /tmp/test_compile.cpp << 'EOF'
#include <iostream>
#include <string>
#include <vector>
#include <memory>
#include <string_view>
int main() {
std::cout << "C++23 Test erfolgreich!" << std::endl;
// Test C++23 Features
auto lambda = [](auto x) { return x * 2; };
std::vector<std::unique_ptr<int>> vec;
std::string_view sv = "test";
return 0;
}
EOF
if g++ -std=c++23 -o /tmp/test_compile /tmp/test_compile.cpp; then
log_success "C++23 Compilation erfolgreich"
rm -f /tmp/test_compile /tmp/test_compile.cpp
elif g++ -std=c++20 -o /tmp/test_compile /tmp/test_compile.cpp; then
log_success "C++20 Compilation erfolgreich"
rm -f /tmp/test_compile /tmp/test_compile.cpp
else
log_warning "C++23/20 Compilation fehlgeschlagen, verwende C++17"
rm -f /tmp/test_compile /tmp/test_compile.cpp
fi
log_success "Alle Dependencies erfolgreich installiert!"
log_info ""
log_info "Nächste Schritte:"
log_info "1. Führen Sie das deploy.sh Script von Ihrem Entwicklungsrechner aus"
log_info "2. Oder kopieren Sie die Binärdatei manuell und konfigurieren Sie den Service"
log_info ""
log_info "Verfügbare Services:"
log_info "- PostgreSQL: systemctl status postgresql"
log_info "- Firewall: firewall-cmd --list-all"
log_info ""
log_info "Datenbankverbindung:"
log_info "- Host: localhost"
log_info "- Port: 5432"
log_info "- Database: yp3"
log_info "- User: yourpart"
log_info "- Password: hitomisan"
log_info ""
log_info "Compiler-Info:"
log_info "- GCC Version: $(gcc --version | head -1)"
log_info "- G++ Version: $(g++ --version | head -1)"