build: add CI
Some checks failed
Build and Publish Docker Images / build-and-push (backend) (push) Failing after 13m48s
Build and Publish Docker Images / build-and-push (frontend) (push) Failing after 6m35s

This commit is contained in:
2025-08-29 06:24:49 +02:00
parent 2934224787
commit ff867fd219
2 changed files with 110 additions and 0 deletions

50
.gitea/SECRETS.md Normal file
View File

@@ -0,0 +1,50 @@
# Secrets Gitea requis pour le workflow Docker
## Configuration des secrets dans Gitea
Pour que le workflow de publication Docker fonctionne, vous devez configurer les secrets suivants dans votre dépôt Gitea :
### Secrets obligatoires
1. **`REGISTRY_URL`**
- URL complète de votre registry Docker interne
- Exemple : `registry.example.com:5000` ou `harbor.mycompany.com`
2. **`REGISTRY_USERNAME`**
- Nom d'utilisateur pour l'authentification sur le registry
- Doit avoir les permissions de push sur le namespace
3. **`REGISTRY_PASSWORD`**
- Mot de passe ou token d'accès pour le registry
- Utiliser un token d'accès plutôt qu'un mot de passe si possible
### Secrets optionnels
4. **`REGISTRY_NAMESPACE`** (optionnel)
- Namespace/organisation sur le registry
- Valeur par défaut : `zebra-power`
- Exemple : `myorg`, `infrastructure`, etc.
## Comment configurer les secrets dans Gitea
1. Aller dans **Settings** > **Secrets** de votre dépôt
2. Cliquer sur **New secret**
3. Ajouter chaque secret avec son nom exact et sa valeur
## Images Docker publiées
Le workflow publiera automatiquement :
- `{REGISTRY_URL}/{NAMESPACE}/zebra-backend:latest`
- `{REGISTRY_URL}/{NAMESPACE}/zebra-frontend:latest`
Plus les tags spécifiques :
- Tags de branche (ex: `main`)
- Tags de version (ex: `v1.0.0`)
- Tags de commit avec timestamp
## Déclencheurs du workflow
- **Push vers `main`** : Publication avec tag `latest`
- **Création de tags `v*`** : Publication avec le tag de version
- **Manuel** : Exécution manuelle via l'interface Gitea

View File

@@ -0,0 +1,60 @@
name: Build and Publish Docker Images
on:
push:
branches:
- main
tags:
- 'v*'
workflow_dispatch:
env:
REGISTRY: ${{ secrets.REGISTRY_URL }}
NAMESPACE: ${{ secrets.REGISTRY_NAMESPACE || 'zebra-power' }}
jobs:
build-and-push:
runs-on: ubuntu-latest
strategy:
matrix:
service: [backend, frontend]
steps:
- name: Checkout code
uses: actions/checkout@v4
- name: Set up Docker Buildx
uses: docker/setup-buildx-action@v3
- name: Log in to Docker Registry
uses: docker/login-action@v3
with:
registry: ${{ env.REGISTRY }}
username: ${{ secrets.REGISTRY_USERNAME }}
password: ${{ secrets.REGISTRY_PASSWORD }}
- name: Extract metadata
id: meta
uses: docker/metadata-action@v5
with:
images: ${{ env.REGISTRY }}/${{ env.NAMESPACE }}/zebra-${{ matrix.service }}
tags: |
type=ref,event=branch
type=ref,event=pr
type=ref,event=tag
type=raw,value=latest,enable={{is_default_branch}}
type=sha,prefix={{branch}}-,suffix=-{{date 'YYYYMMDD-HHmmss'}},enable={{is_default_branch}}
- name: Build and push Docker image
uses: docker/build-push-action@v5
with:
context: ./${{ matrix.service }}
file: ./${{ matrix.service }}/Dockerfile
push: true
tags: ${{ steps.meta.outputs.tags }}
labels: ${{ steps.meta.outputs.labels }}
cache-from: type=gha
cache-to: type=gha,mode=max
platforms: linux/amd64,linux/arm64
- name: Image digest
run: echo "Image pushed with digest ${{ steps.build.outputs.digest }}"