adding new project pipelines

This commit is contained in:
2026-03-20 21:26:05 -03:00
parent 3938d1a2b9
commit 794e314fa7
6 changed files with 297 additions and 0 deletions

View File

@@ -0,0 +1,84 @@
name: Mindforge API Build and Deploy
on:
push:
branches:
- main
paths:
- "Mindforge.API/**"
- ".gitea/workflows/**"
workflow_dispatch: {}
env:
REGISTRY_HOST: git.ivanch.me
REGISTRY_USERNAME: ivanch
IMAGE_API: ${{ env.REGISTRY_HOST }}/ivanch/mindforge-api
KUBE_CONFIG: ${{ secrets.KUBE_CONFIG }}
jobs:
build_mindforge_api:
name: Build Mindforge API Image
runs-on: ubuntu-22.04
steps:
- name: Check out repository
uses: actions/checkout@v2
- name: Log in to Container Registry
run: |
echo "${{ secrets.REGISTRY_PASSWORD }}" \
| docker login "${{ env.REGISTRY_HOST }}" \
-u "${{ env.REGISTRY_USERNAME }}" \
--password-stdin
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Build and Push Multi-Arch Image
uses: docker/build-push-action@v6
with:
push: true
context: Mindforge.API
platforms: linux/amd64,linux/arm64
tags: |
${{ env.IMAGE_API }}:latest
deploy_mindforge_api:
name: Deploy Mindforge API (internal)
runs-on: ubuntu-amd64
needs: build_mindforge_api
steps:
- name: Check KUBE_CONFIG validity
run: |
if [ -z "${KUBE_CONFIG}" ] || [ "${KUBE_CONFIG}" = "" ] || [ "${KUBE_CONFIG// }" = "" ]; then
echo "KUBE_CONFIG is not set or is empty."
exit 1
fi
- name: Check out repository
uses: actions/checkout@v2
- name: Download and install dependencies
run: |
apt-get update -y
apt-get install -y curl
curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/linux/amd64/kubectl"
install -m 0755 kubectl /usr/local/bin/kubectl
kubectl version --client
- name: Set up kubeconfig
run: |
cd Mindforge.API/deploy
echo "$KUBE_CONFIG" > kubeconfig.yaml
env:
KUBE_CONFIG: ${{ env.KUBE_CONFIG }}
- name: Check connection to cluster
run: |
cd Mindforge.API/deploy
kubectl --kubeconfig=kubeconfig.yaml cluster-info
- name: Apply mindforge-api deployment
run: |
cd Mindforge.API/deploy
kubectl --kubeconfig=kubeconfig.yaml apply -f mindforge-api.yaml

View File

@@ -0,0 +1,86 @@
name: Mindforge Web Build and Deploy
on:
push:
branches:
- main
paths:
- "Mindforge.Web/**"
- ".gitea/workflows/**"
workflow_dispatch: {}
env:
REGISTRY_HOST: git.ivanch.me
REGISTRY_USERNAME: ivanch
IMAGE_WEB: ${{ env.REGISTRY_HOST }}/ivanch/mindforge-web
KUBE_CONFIG: ${{ secrets.KUBE_CONFIG }}
jobs:
build_mindforge_web:
name: Build Mindforge Web Image
runs-on: ubuntu-22.04
steps:
- name: Check out repository
uses: actions/checkout@v2
- name: Log in to Container Registry
run: |
echo "${{ secrets.REGISTRY_PASSWORD }}" \
| docker login "${{ env.REGISTRY_HOST }}" \
-u "${{ env.REGISTRY_USERNAME }}" \
--password-stdin
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Build and Push Multi-Arch Image
uses: docker/build-push-action@v6
with:
push: true
context: Mindforge.Web
platforms: linux/amd64,linux/arm64
build-args: |
VITE_API_BASE_URL=${{ secrets.VITE_API_BASE_URL }}
tags: |
${{ env.IMAGE_WEB }}:latest
deploy_mindforge_web:
name: Deploy Mindforge Web (internal)
runs-on: ubuntu-amd64
needs: build_mindforge_web
steps:
- name: Check KUBE_CONFIG validity
run: |
if [ -z "${KUBE_CONFIG}" ] || [ "${KUBE_CONFIG}" = "" ] || [ "${KUBE_CONFIG// }" = "" ]; then
echo "KUBE_CONFIG is not set or is empty."
exit 1
fi
- name: Check out repository
uses: actions/checkout@v2
- name: Download and install dependencies
run: |
apt-get update -y
apt-get install -y curl
curl -LO "https://dl.k8s.io/release/$(curl -L -s https://dl.k8s.io/release/stable.txt)/bin/linux/amd64/kubectl"
install -m 0755 kubectl /usr/local/bin/kubectl
kubectl version --client
- name: Set up kubeconfig
run: |
cd Mindforge.Web/deploy
echo "$KUBE_CONFIG" > kubeconfig.yaml
env:
KUBE_CONFIG: ${{ env.KUBE_CONFIG }}
- name: Check connection to cluster
run: |
cd Mindforge.Web/deploy
kubectl --kubeconfig=kubeconfig.yaml cluster-info
- name: Apply mindforge-web deployment
run: |
cd Mindforge.Web/deploy
kubectl --kubeconfig=kubeconfig.yaml apply -f mindforge-web.yaml