add merge generator

This commit is contained in:
2026-01-11 06:36:01 +01:00
parent 372676745d
commit ab296592e4
2 changed files with 54 additions and 18 deletions

View File

@@ -5,26 +5,45 @@ metadata:
namespace: argocd-ops
spec:
generators:
- git:
repoURL: https://git.gkdomaine.fr/kubernetes/argocd.git
revision: main
files:
- path: "nextcloud/*/config.json" # Il lit le fichier de config
# Utilise un générateur merge pour combiner :
# 1. Les répertoires Helm existants (détermine quels environnements sont disponibles pour nextcloud)
# 2. Les fichiers de config partagés (pour obtenir name et server)
- merge:
generators:
# Premier générateur : scanne uniquement les répertoires Helm qui existent pour nextcloud
- git:
repoURL: https://git.gkdomaine.fr/kubernetes/argocd.git
revision: main
directories:
- path: "helm/nextcloud/*"
# Deuxième générateur : lit les fichiers de config partagés
# ApplicationSet utilisera seulement les fichiers config.json dont le basename
# correspond à un répertoire Helm trouvé
- git:
repoURL: https://git.gkdomaine.fr/kubernetes/argocd.git
revision: main
files:
- path: "configs/*/config.json"
mergeKeys:
- path.basename
template:
metadata:
# {{path.basename}} sera remplacé par "dev" ou "prd"
name: 'nextcloud-{{path.basename}}'
spec:
project: '{{path.basename}}'
source:
repoURL: https://git.gkdomaine.fr/kubernetes/argocd.git
targetRevision: main
path: '{{path}}' # Utilise le chemin du dossier trouvé
# Utilise le chemin du répertoire Helm (premier générateur)
path: '{{path}}'
helm:
valueFiles:
- values.yaml
destination:
server: '{{server}}' # Il utilise la variable définie dans config.json
# Les variables {{name}} et {{server}} viennent du fichier config.json
# (deuxième générateur du merge)
name: '{{name}}'
server: '{{server}}'
namespace: 'nextcloud-{{path.basename}}'
syncPolicy:
automated: