Initial commit: Beeper Bridge Docker Setup with Migration Script

This commit is contained in:
Gemini Bot
2025-12-05 02:54:37 +00:00
commit ccc5fc111c
7 changed files with 180 additions and 0 deletions

46
README.md Normal file
View File

@@ -0,0 +1,46 @@
# Beeper Bridges - Docker Setup
Dieses Projekt verwaltet selbst-gehostete Matrix-Bridges für Beeper mittels Docker Compose.
## Struktur
- \`docker-compose.yml\`: Definition der Dienste (WhatsApp, Telegram, Signal, Google Chat).
- \`data/\`: Persistente Daten für die Bridges (Configs + SQLite Datenbanken).
- \`migrate.sh\`: Hilfsskript zum Importieren bestehender lokaler Installationen.
## Installation & Migration
### 1. Migration bestehender Daten
Wenn du die Bridges vorher manuell (ohne Docker) betrieben hast, nutze das Skript, um Configs und Datenbanken zu importieren. Das Skript passt automatisch die Datenbank-Pfade für Docker an.
\`\`\`bash
./migrate.sh
\`\`\`
### 2. Starten
Startet alle Bridges im Hintergrund.
\`\`\`bash
docker compose up -d
\`\`\`
### 3. Logs prüfen & QR-Code scannen
Falls du dich neu anmelden musst, findest du den QR-Code im Log des jeweiligen Containers:
\`\`\`bash
docker compose logs -f whatsapp
# oder
docker compose logs -f telegram
\`\`\`
Alternativ kannst du im Beeper-Chat mit dem Bridge-Bot \`login\` schreiben.
## Wartung
**Update der Bridges:**
\`\`\`bash
docker compose pull
docker compose up -d
\`\`\`
**Backup:**
Sichere einfach den kompletten \`data/\` Ordner. Er enthält alle Sitzungen und Schlüssel.

0
data/googlechat/.gitkeep Normal file
View File

0
data/signal/.gitkeep Normal file
View File

0
data/telegram/.gitkeep Normal file
View File

0
data/whatsapp/.gitkeep Normal file
View File

51
docker-compose.yml Normal file
View File

@@ -0,0 +1,51 @@
services:
whatsapp:
container_name: beeper-whatsapp
image: dock.mau.dev/mautrix/whatsapp:latest
restart: unless-stopped
volumes:
- ./data/whatsapp:/data
logging:
driver: json-file
options:
max-size: "10m"
max-file: "3"
telegram:
container_name: beeper-telegram
image: dock.mau.dev/mautrix/telegram:latest
restart: unless-stopped
volumes:
- ./data/telegram:/data
logging:
driver: json-file
options:
max-size: "10m"
max-file: "3"
signal:
container_name: beeper-signal
image: dock.mau.dev/mautrix/signal:latest
restart: unless-stopped
volumes:
- ./data/signal:/data
environment:
- UID=1000
- GID=1000
logging:
driver: json-file
options:
max-size: "10m"
max-file: "3"
googlechat:
container_name: beeper-googlechat
image: dock.mau.dev/mautrix/googlechat:latest
restart: unless-stopped
volumes:
- ./data/googlechat:/data
logging:
driver: json-file
options:
max-size: "10m"
max-file: "3"

83
migrate.sh Executable file
View File

@@ -0,0 +1,83 @@
#!/bin/bash
# Farben
GREEN='\033[0;32m'
BLUE='\033[0;34m'
YELLOW='\033[1;33m'
NC='\033[0m' # No Color
echo -e "${BLUE}=== Beeper Bridge Migration Tool ===${NC}"
echo "Dieses Skript kopiert deine alten Daten in die neue Docker-Struktur"
echo "und passt die Pfade in der config.yaml automatisch an."
echo ""
# Funktion zur Migration einer Bridge
migrate_bridge() {
SERVICE_NAME=$1
DEST_DIR="./data/$SERVICE_NAME"
echo -e "${YELLOW}--- Migration für $SERVICE_NAME ---${NC}"
read -p "Gib den PFAD zum ALTEN Ordner von $SERVICE_NAME ein (Enter zum Überspringen): " SOURCE_DIR
# Pfad bereinigen (Tilde expandieren, Slash am Ende entfernen)
SOURCE_DIR="${SOURCE_DIR/#\~/$HOME}"
SOURCE_DIR="${SOURCE_DIR%/}"
if [ -z "$SOURCE_DIR" ]; then
echo "Übersprungen."
return
fi
if [ ! -d "$SOURCE_DIR" ]; then
echo "Fehler: Ordner $SOURCE_DIR existiert nicht!"
return
fi
echo "Kopiere Daten nach $DEST_DIR..."
# 1. Configs kopieren
cp -v "$SOURCE_DIR/config.yaml" "$DEST_DIR/" 2>/dev/null
cp -v "$SOURCE_DIR/registration.yaml" "$DEST_DIR/" 2>/dev/null
# 2. Datenbank finden und kopieren
# Wir suchen nach .db Dateien. Oft heißen sie mautrix-telegram.db oder ähnlich.
DB_FILE=$(find "$SOURCE_DIR" -maxdepth 1 -name "*.db" | head -n 1)
if [ -n "$DB_FILE" ]; then
DB_FILENAME=$(basename "$DB_FILE")
echo "Datenbank gefunden: $DB_FILENAME"
cp -v "$DB_FILE" "$DEST_DIR/bridge.db"
# 3. Config anpassen (SQLite Pfad)
echo "Passe SQLite-Pfad in config.yaml an..."
# Backup erstellen
cp "$DEST_DIR/config.yaml" "$DEST_DIR/config.yaml.bak"
# Ersetze die URI Zeile. Wir suchen nach "uri: sqlite:..." und ersetzen es hard durch den Docker Pfad
sed -i 's|uri: sqlite:.*|uri: sqlite:////data/bridge.db|g' "$DEST_DIR/config.yaml"
echo "Config aktualisiert."
else
echo -e "${YELLOW}Warnung: Keine .db Datei in $SOURCE_DIR gefunden!${NC}"
fi
# 4. Spezielle Ordner kopieren (z.B. Signal data Ordner falls vorhanden)
if [ "$SERVICE_NAME" == "signal" ] && [ -d "$SOURCE_DIR/data" ]; then
echo "Kopiere Signal 'data' Unterordner..."
cp -r "$SOURCE_DIR/data" "$DEST_DIR/"
fi
# 5. Berechtigungen setzen (für Docker User 1000 oft notwendig)
chmod -R 777 "$DEST_DIR"
echo -e "${GREEN}Migration für $SERVICE_NAME abgeschlossen.${NC}"
echo ""
}
# Migration starten
migrate_bridge "whatsapp"
migrate_bridge "telegram"
migrate_bridge "signal"
migrate_bridge "googlechat"
echo -e "${BLUE}=== Fertig ===${NC}"
echo "Du kannst jetzt 'docker compose up -d' starten."