name: Build and Deploy on: push: branches: - kub-stage env: REGISTRY: gitea-svc:3000 IMAGE_NAME: admin/frontoffice jobs: build: runs-on: ubuntu-latest container: image: docker:latest options: --privileged steps: - name: Install dependencies run: | apk add --no-cache git curl # Install kubectl curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/linux/amd64/kubectl" chmod +x kubectl mv kubectl /usr/local/bin/ - name: Setup Docker daemon for insecure registry run: | mkdir -p /etc/docker cat > /etc/docker/daemon.json </dev/null 2>&1 && break || sleep 2 done docker info - name: Checkout code run: | git clone --depth 1 --branch kub-stage http://gitea-svc:3000/admin/FrontOffice.git . git log -1 --format="%H %s" - name: Build Docker Image run: | cd src docker build -f FrontOffice.Main/Dockerfile \ -t ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ github.sha }} \ -t ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:latest \ . - name: Push to Registry run: | echo "${{ secrets.REGISTRY_PASSWORD }}" | docker login ${{ env.REGISTRY }} -u admin --password-stdin docker push ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:${{ github.sha }} docker push ${{ env.REGISTRY }}/${{ env.IMAGE_NAME }}:latest - name: Deploy to Kubernetes run: | # Setup kubeconfig mkdir -p ~/.kube echo "${{ secrets.KUBECONFIG }}" | base64 -d > ~/.kube/config # Restart deployment to pull new image kubectl rollout restart deployment/frontoffice || echo "Deployment doesn't exist yet" # Wait for rollout to complete kubectl rollout status deployment/frontoffice --timeout=5m || echo "Deployment rollout pending"