add domain "escape-from-school.de"
All checks were successful
Dynamic Branch Deploy / build-and-deploy (push) Successful in 1m10s
All checks were successful
Dynamic Branch Deploy / build-and-deploy (push) Successful in 1m10s
This commit is contained in:
64
.github/workflows/deploy.yaml
vendored
64
.github/workflows/deploy.yaml
vendored
@@ -3,7 +3,8 @@ on: [push]
|
|||||||
|
|
||||||
env:
|
env:
|
||||||
REGISTRY: git.zb-server.de
|
REGISTRY: git.zb-server.de
|
||||||
BASE_DOMAIN: zb-server.de
|
# WICHTIG: Deine echte Haupt-Domain
|
||||||
|
BASE_DOMAIN: escape-from-school.de
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build-and-deploy:
|
build-and-deploy:
|
||||||
@@ -13,30 +14,44 @@ jobs:
|
|||||||
- name: Checkout Code
|
- name: Checkout Code
|
||||||
uses: actions/checkout@v3
|
uses: actions/checkout@v3
|
||||||
|
|
||||||
# 2. Variablen vorbereiten (VEREINFACHT & KORRIGIERT)
|
# 2. Variablen vorbereiten (MIT HAUPT-DOMAIN LOGIK)
|
||||||
- name: Prepare Environment Variables
|
- name: Prepare Environment Variables
|
||||||
id: prep
|
id: prep
|
||||||
run: |
|
run: |
|
||||||
# Wir nehmen einfach den vollen Repo-Namen (z.B. "User/Repo") und machen ihn klein
|
# 1. Repo und Branch Namen säubern
|
||||||
# Das ist sicherer als cut und owner einzeln zu holen
|
# Voller Pfad für Docker Image (z.B. "user/escape-teacher")
|
||||||
FULL_IMAGE_PATH=$(echo "${{ gitea.repository }}" | tr '[:upper:]' '[:lower:]')
|
FULL_IMAGE_PATH=$(echo "${{ gitea.repository }}" | tr '[:upper:]' '[:lower:]')
|
||||||
|
|
||||||
# Repo Name für K8s (nur der Teil nach dem /)
|
# Nur der Projektname für K8s (z.B. "escape-teacher")
|
||||||
REPO_LOWER=$(echo "$FULL_IMAGE_PATH" | cut -d'/' -f2)
|
REPO_LOWER=$(echo "$FULL_IMAGE_PATH" | cut -d'/' -f2)
|
||||||
|
|
||||||
# Branch Name säubern
|
# Branch Name säubern (Sonderzeichen zu Bindestrichen)
|
||||||
BRANCH_LOWER=$(echo "${{ gitea.ref_name }}" | tr '[:upper:]' '[:lower:]' | sed 's/[^a-z0-9-]/-/g')
|
BRANCH_LOWER=$(echo "${{ gitea.ref_name }}" | tr '[:upper:]' '[:lower:]' | sed 's/[^a-z0-9-]/-/g')
|
||||||
|
|
||||||
# Namespace und URL bauen
|
# 2. Logik: Ist es der Haupt-Branch?
|
||||||
|
if [ "$BRANCH_LOWER" = "main" ] || [ "$BRANCH_LOWER" = "master" ]; then
|
||||||
|
# PRODUKTION:
|
||||||
|
# URL ist direkt die Domain (ohne Subdomain)
|
||||||
|
APP_URL="${{ env.BASE_DOMAIN }}"
|
||||||
|
# Namespace ist nur der Projektname (ohne Branch-Suffix)
|
||||||
|
TARGET_NS="${REPO_LOWER}"
|
||||||
|
echo "Mode: PRODUCTION (Root Domain)"
|
||||||
|
else
|
||||||
|
# ENTWICKLUNG:
|
||||||
|
# URL ist repo-branch.domain.de
|
||||||
|
APP_URL="${REPO_LOWER}-${BRANCH_LOWER}.${{ env.BASE_DOMAIN }}"
|
||||||
|
# Namespace ist repo-branch
|
||||||
TARGET_NS="${REPO_LOWER}-${BRANCH_LOWER}"
|
TARGET_NS="${REPO_LOWER}-${BRANCH_LOWER}"
|
||||||
APP_URL="${TARGET_NS}.${{ env.BASE_DOMAIN }}"
|
echo "Mode: DEVELOPMENT (Subdomain)"
|
||||||
|
fi
|
||||||
|
|
||||||
# Image Tag (Commit Hash)
|
# Image Tag (Commit Hash)
|
||||||
IMAGE_TAG="${{ gitea.sha }}"
|
IMAGE_TAG="${{ gitea.sha }}"
|
||||||
|
|
||||||
# Debug Ausgabe (damit du siehst, ob es geklappt hat)
|
# Debug Ausgabe
|
||||||
echo "DEBUG: Image Path is: $FULL_IMAGE_PATH"
|
echo "DEBUG: Branch: $BRANCH_LOWER"
|
||||||
echo "DEBUG: Target NS is: $TARGET_NS"
|
echo "DEBUG: Namespace: $TARGET_NS"
|
||||||
|
echo "DEBUG: URL: $APP_URL"
|
||||||
|
|
||||||
# In Gitea Actions Environment schreiben
|
# In Gitea Actions Environment schreiben
|
||||||
echo "FULL_IMAGE_PATH=$FULL_IMAGE_PATH" >> $GITHUB_ENV
|
echo "FULL_IMAGE_PATH=$FULL_IMAGE_PATH" >> $GITHUB_ENV
|
||||||
@@ -45,20 +60,16 @@ jobs:
|
|||||||
echo "APP_URL=$APP_URL" >> $GITHUB_ENV
|
echo "APP_URL=$APP_URL" >> $GITHUB_ENV
|
||||||
echo "IMAGE_TAG=$IMAGE_TAG" >> $GITHUB_ENV
|
echo "IMAGE_TAG=$IMAGE_TAG" >> $GITHUB_ENV
|
||||||
|
|
||||||
# 3. Kaniko Build (Mit DEBUG Fix)
|
# 3. Kaniko Build
|
||||||
- name: Build and Push with Kaniko
|
- name: Build and Push with Kaniko
|
||||||
uses: aevea/action-kaniko@v0.12.0
|
uses: aevea/action-kaniko@v0.12.0
|
||||||
with:
|
with:
|
||||||
registry: ${{ env.REGISTRY }}
|
registry: ${{ env.REGISTRY }}
|
||||||
# username/password werden oft nicht gebraucht, wenn Gitea Actions Runner
|
|
||||||
# im selben Netzwerk ist, aber sicher ist sicher:
|
|
||||||
username: ${{ gitea.actor }}
|
username: ${{ gitea.actor }}
|
||||||
password: ${{ secrets.PACKAGE_TOKEN }}
|
password: ${{ secrets.PACKAGE_TOKEN }}
|
||||||
# Hier war der Fehler: Wir nutzen jetzt die vereinfachte Variable
|
|
||||||
image: ${{ env.FULL_IMAGE_PATH }}
|
image: ${{ env.FULL_IMAGE_PATH }}
|
||||||
tag: ${{ env.IMAGE_TAG }}
|
tag: ${{ env.IMAGE_TAG }}
|
||||||
cache: true
|
cache: true
|
||||||
# WICHTIG bei selbst-signierten oder internen Gitea Instanzen:
|
|
||||||
extra_args: --skip-tls-verify-pull --insecure
|
extra_args: --skip-tls-verify-pull --insecure
|
||||||
|
|
||||||
# 4. Setup Kubectl (Interner Trick)
|
# 4. Setup Kubectl (Interner Trick)
|
||||||
@@ -72,24 +83,23 @@ jobs:
|
|||||||
echo "${{ secrets.KUBE_CONFIG }}" > $HOME/.kube/config
|
echo "${{ secrets.KUBE_CONFIG }}" > $HOME/.kube/config
|
||||||
chmod 600 $HOME/.kube/config
|
chmod 600 $HOME/.kube/config
|
||||||
|
|
||||||
# Internal DNS Trick
|
# Internal DNS Trick (für Kommunikation innerhalb des Clusters)
|
||||||
sed -i 's|server: https://.*:6443|server: https://kubernetes.default.svc:443|g' $HOME/.kube/config
|
sed -i 's|server: https://.*:6443|server: https://kubernetes.default.svc:443|g' $HOME/.kube/config
|
||||||
|
|
||||||
# 5. Deploy to Kubernetes
|
# 5. Deploy to Kubernetes
|
||||||
- name: Deploy to Kubernetes
|
- name: Deploy to Kubernetes
|
||||||
run: |
|
run: |
|
||||||
# Namespace
|
# Namespace erstellen (falls nicht existiert)
|
||||||
kubectl create namespace ${{ env.TARGET_NS }} --dry-run=client -o yaml | kubectl apply -f -
|
kubectl create namespace ${{ env.TARGET_NS }} --dry-run=client -o yaml | kubectl apply -f -
|
||||||
|
|
||||||
# Platzhalter ersetzen
|
# Vollen Image Pfad bauen
|
||||||
# Wir bauen den vollen Image-Pfad für die Ersetzung
|
|
||||||
FULL_IMAGE_URL="${{ env.REGISTRY }}/${{ env.FULL_IMAGE_PATH }}:${{ env.IMAGE_TAG }}"
|
FULL_IMAGE_URL="${{ env.REGISTRY }}/${{ env.FULL_IMAGE_PATH }}:${{ env.IMAGE_TAG }}"
|
||||||
|
|
||||||
# Ingress
|
# 1. Ingress anpassen (Hier wird die URL eingesetzt!)
|
||||||
sed -i "s|\${APP_URL}|${{ env.APP_URL }}|g" k8s/ingress.yaml
|
sed -i "s|\${APP_URL}|${{ env.APP_URL }}|g" k8s/ingress.yaml
|
||||||
|
|
||||||
# App Deployment & Secrets
|
# 2. App Deployment anpassen (Image & Secrets)
|
||||||
# HINWEIS: Falls du keine Secrets hast, nimm Fallback-Werte oder entferne die Zeilen
|
# Nutze Secrets oder Fallback-Werte
|
||||||
ADMIN_USER="${{ secrets.ADMIN_USER || 'lehrer' }}"
|
ADMIN_USER="${{ secrets.ADMIN_USER || 'lehrer' }}"
|
||||||
ADMIN_PASS="${{ secrets.ADMIN_PASS || 'geheim123' }}"
|
ADMIN_PASS="${{ secrets.ADMIN_PASS || 'geheim123' }}"
|
||||||
|
|
||||||
@@ -97,15 +107,15 @@ jobs:
|
|||||||
sed -i "s|\${ADMIN_USER}|$ADMIN_USER|g" k8s/app.yaml
|
sed -i "s|\${ADMIN_USER}|$ADMIN_USER|g" k8s/app.yaml
|
||||||
sed -i "s|\${ADMIN_PASS}|$ADMIN_PASS|g" k8s/app.yaml
|
sed -i "s|\${ADMIN_PASS}|$ADMIN_PASS|g" k8s/app.yaml
|
||||||
|
|
||||||
# Apply
|
# Anwenden
|
||||||
echo "Deploying to Namespace: ${{ env.TARGET_NS }}"
|
echo "Deploying Resources to Namespace: ${{ env.TARGET_NS }}"
|
||||||
kubectl apply -f k8s/redis.yaml -n ${{ env.TARGET_NS }}
|
kubectl apply -f k8s/redis.yaml -n ${{ env.TARGET_NS }}
|
||||||
kubectl apply -f k8s/app.yaml -n ${{ env.TARGET_NS }}
|
kubectl apply -f k8s/app.yaml -n ${{ env.TARGET_NS }}
|
||||||
kubectl apply -f k8s/ingress.yaml -n ${{ env.TARGET_NS }}
|
kubectl apply -f k8s/ingress.yaml -n ${{ env.TARGET_NS }}
|
||||||
|
|
||||||
# Force Update
|
# Force Update (damit das neue Image sicher geladen wird)
|
||||||
kubectl rollout restart deployment/escape-game -n ${{ env.TARGET_NS }}
|
kubectl rollout restart deployment/escape-game -n ${{ env.TARGET_NS }}
|
||||||
|
|
||||||
# 6. Summary
|
# 6. Summary
|
||||||
- name: Summary
|
- name: Summary
|
||||||
run: echo "🚀 Deployed to https://${{ env.APP_URL }}"
|
run: echo "🚀 Deployed successfully to https://${{ env.APP_URL }}"
|
||||||
@@ -10,8 +10,7 @@ spec:
|
|||||||
ingressClassName: traefik
|
ingressClassName: traefik
|
||||||
tls:
|
tls:
|
||||||
- hosts:
|
- hosts:
|
||||||
- ${APP_URL} # Wird von CI ersetzt
|
- ${APP_URL}
|
||||||
- "escape-from-school.de"
|
|
||||||
secretName: game-tls-secret
|
secretName: game-tls-secret
|
||||||
rules:
|
rules:
|
||||||
- host: ${APP_URL}
|
- host: ${APP_URL}
|
||||||
@@ -24,13 +23,3 @@ spec:
|
|||||||
name: escape-game
|
name: escape-game
|
||||||
port:
|
port:
|
||||||
number: 80
|
number: 80
|
||||||
- host: "escape-from-school.de"
|
|
||||||
http:
|
|
||||||
paths:
|
|
||||||
- path: /
|
|
||||||
pathType: Prefix
|
|
||||||
backend:
|
|
||||||
service:
|
|
||||||
name: escape-game
|
|
||||||
port:
|
|
||||||
number: 80
|
|
||||||
Reference in New Issue
Block a user