build: add CI
This commit is contained in:
50
.gitea/SECRETS.md
Normal file
50
.gitea/SECRETS.md
Normal 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
|
||||
60
.gitea/workflows/docker-publish.yml
Normal file
60
.gitea/workflows/docker-publish.yml
Normal 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 }}"
|
||||
Reference in New Issue
Block a user