Some checks failed
Tests / Go Tests (push) Has been cancelled
Tests / Python Tests (push) Has been cancelled
Tests / Integration Tests (push) Has been cancelled
Tests / Go Lint (push) Has been cancelled
Tests / Python Lint (push) Has been cancelled
Tests / Security Scan (push) Has been cancelled
Tests / All Checks Passed (push) Has been cancelled
Security Scanning / Secret Scanning (push) Has been cancelled
Security Scanning / Dependency Vulnerability Scan (push) Has been cancelled
Security Scanning / Go Security Scan (push) Has been cancelled
Security Scanning / Python Security Scan (push) Has been cancelled
Security Scanning / Node.js Security Scan (push) Has been cancelled
Security Scanning / Docker Image Security (push) Has been cancelled
Security Scanning / Security Summary (push) Has been cancelled
CI/CD Pipeline / Go Tests (push) Has been cancelled
CI/CD Pipeline / Python Tests (push) Has been cancelled
CI/CD Pipeline / Website Tests (push) Has been cancelled
CI/CD Pipeline / Linting (push) Has been cancelled
CI/CD Pipeline / Security Scan (push) Has been cancelled
CI/CD Pipeline / Docker Build & Push (push) Has been cancelled
CI/CD Pipeline / Integration Tests (push) Has been cancelled
CI/CD Pipeline / Deploy to Staging (push) Has been cancelled
CI/CD Pipeline / Deploy to Production (push) Has been cancelled
CI/CD Pipeline / CI Summary (push) Has been cancelled
ci/woodpecker/manual/build-ci-image Pipeline was successful
ci/woodpecker/manual/main Pipeline failed
All services: admin-v2, studio-v2, website, ai-compliance-sdk, consent-service, klausur-service, voice-service, and infrastructure. Large PDFs and compiled binaries excluded via .gitignore.
103 lines
3.4 KiB
Bash
Executable File
103 lines
3.4 KiB
Bash
Executable File
#!/bin/bash
|
|
# =============================================================================
|
|
# Gitea Setup Script
|
|
# =============================================================================
|
|
# Dieses Script richtet Gitea und den Actions Runner für die SBOM Pipeline ein.
|
|
#
|
|
# Voraussetzungen:
|
|
# - Docker und Docker Compose installiert
|
|
# - Zugriff auf Mac Mini (ssh macmini)
|
|
#
|
|
# Verwendung:
|
|
# ./scripts/setup-gitea.sh
|
|
# =============================================================================
|
|
|
|
set -e
|
|
|
|
echo "=========================================="
|
|
echo "Gitea Setup für BreakPilot"
|
|
echo "=========================================="
|
|
|
|
# Farben für Output
|
|
RED='\033[0;31m'
|
|
GREEN='\033[0;32m'
|
|
YELLOW='\033[1;33m'
|
|
NC='\033[0m' # No Color
|
|
|
|
# Prüfen ob wir auf Mac Mini sind oder lokal
|
|
if [ "$(hostname)" = "macmini" ] || [ "$(hostname)" = "Mac-mini" ]; then
|
|
DOCKER_CMD="docker"
|
|
COMPOSE_CMD="docker compose"
|
|
PROJECT_DIR="/Users/benjaminadmin/Projekte/breakpilot-pwa"
|
|
else
|
|
# Remote execution auf Mac Mini
|
|
DOCKER_CMD="ssh macmini /usr/local/bin/docker"
|
|
COMPOSE_CMD="ssh macmini /usr/local/bin/docker compose -f /Users/benjaminadmin/Projekte/breakpilot-pwa/docker-compose.yml"
|
|
PROJECT_DIR="."
|
|
fi
|
|
|
|
echo ""
|
|
echo -e "${YELLOW}1. Starte Gitea Container...${NC}"
|
|
$COMPOSE_CMD up -d gitea
|
|
|
|
echo ""
|
|
echo -e "${YELLOW}2. Warte auf Gitea Startup (30 Sekunden)...${NC}"
|
|
sleep 30
|
|
|
|
echo ""
|
|
echo -e "${YELLOW}3. Prüfe Gitea Health...${NC}"
|
|
HEALTH_CHECK=$(curl -s -o /dev/null -w "%{http_code}" http://macmini:3003/api/healthz 2>/dev/null || echo "000")
|
|
if [ "$HEALTH_CHECK" = "200" ]; then
|
|
echo -e "${GREEN}✓ Gitea ist erreichbar!${NC}"
|
|
else
|
|
echo -e "${RED}✗ Gitea nicht erreichbar (HTTP $HEALTH_CHECK)${NC}"
|
|
echo " Bitte prüfen: docker logs breakpilot-pwa-gitea"
|
|
exit 1
|
|
fi
|
|
|
|
echo ""
|
|
echo -e "${GREEN}=========================================="
|
|
echo "Gitea ist bereit!"
|
|
echo "==========================================${NC}"
|
|
echo ""
|
|
echo "Nächste Schritte (manuell):"
|
|
echo ""
|
|
echo "1. Öffne Gitea im Browser:"
|
|
echo " http://macmini:3003"
|
|
echo ""
|
|
echo "2. Erstelle einen Admin-Account:"
|
|
echo " - Username: admin"
|
|
echo " - Email: admin@breakpilot.de"
|
|
echo " - Passwort: (sicheres Passwort wählen)"
|
|
echo ""
|
|
echo "3. Erstelle ein Repository:"
|
|
echo " - Name: breakpilot-pwa"
|
|
echo " - Visibility: Private"
|
|
echo ""
|
|
echo "4. Aktiviere Gitea Actions:"
|
|
echo " Repository Settings → Actions → Enable Repository Actions"
|
|
echo ""
|
|
echo "5. Erstelle einen Runner Token:"
|
|
echo " Repository Settings → Actions → Runners → Create new Runner"
|
|
echo " → Token kopieren"
|
|
echo ""
|
|
echo "6. Starte den Runner mit Token:"
|
|
echo " export GITEA_RUNNER_TOKEN=<dein-token>"
|
|
echo " docker compose up -d gitea-runner"
|
|
echo ""
|
|
echo "7. Push das Repository zu Gitea:"
|
|
echo " git remote add gitea http://macmini:3003/admin/breakpilot-pwa.git"
|
|
echo " git push gitea main"
|
|
echo ""
|
|
echo "8. Die SBOM Pipeline läuft automatisch bei jedem Push!"
|
|
echo ""
|
|
echo -e "${YELLOW}Hinweis: Die PostgreSQL-Datenbank 'gitea' wird automatisch erstellt.${NC}"
|
|
echo ""
|
|
|
|
# Optional: Gitea DB in PostgreSQL erstellen
|
|
echo -e "${YELLOW}Erstelle Gitea Datenbank in PostgreSQL (falls nicht vorhanden)...${NC}"
|
|
$DOCKER_CMD exec -i breakpilot-pwa-postgres psql -U breakpilot -d postgres -c "CREATE DATABASE gitea;" 2>/dev/null || echo " (Datenbank existiert bereits)"
|
|
|
|
echo ""
|
|
echo -e "${GREEN}Setup abgeschlossen!${NC}"
|