#!/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 systemd development libraries log_info "Installiere systemd development libraries..." sudo zypper install -y systemd-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 #include #include #include #include int main() { std::cout << "C++23 Test erfolgreich!" << std::endl; // Test C++23 Features auto lambda = [](auto x) { return x * 2; }; std::vector> 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)"