locals { annotations = { "vynil.solidite.fr/meta" = "domain-ci" "vynil.solidite.fr/name" = var.namespace "vynil.solidite.fr/domain" = var.domain_name "vynil.solidite.fr/issuer" = var.issuer "vynil.solidite.fr/ingress" = var.ingress_class } global = { "domain" = var.namespace "domain_name" = "admin.${var.domain_name}" "issuer" = var.issuer "ingress_class" = var.ingress_class "backups" = var.backups "app_group" = var.app_group } traefik = { for k, v in var.traefik : k => v if k!="enable" } dns = { for k, v in var.dns : k => v if k!="enable" } api = { for k, v in var.api : k => v if k!="enable" } okd = merge({"cluster-admin" = true}, { for k, v in var.okd : k => v if k!="enable" }) gramo = merge({"cluster-admin" = true}, { for k, v in var.gramo : k => v if k!="enable" }) } resource "kubernetes_namespace_v1" "infra-ns" { count = ( var.dns.enable || var.okd.enable || var.gramo.enable )? 1 : 0 metadata { annotations = local.annotations labels = merge(local.common-labels, local.annotations) name = "${var.namespace}-infra" } } resource "kubectl_manifest" "dns" { count = var.dns.enable ? 1 : 0 depends_on = [kubernetes_namespace_v1.infra-ns] yaml_body = <<-EOF apiVersion: "vynil.solidite.fr/v1" kind: "Install" metadata: name: "dns" namespace: "${kubernetes_namespace_v1.infra-ns[0].metadata[0].name}" labels: ${jsonencode(local.common-labels)} spec: distrib: "${var.distributions.domain}" category: "share" component: "dns" options: ${jsonencode(merge(local.global, local.dns))} EOF } resource "kubectl_manifest" "traefik" { count = var.traefik.enable ? 1 : 0 yaml_body = <<-EOF apiVersion: "vynil.solidite.fr/v1" kind: "Install" metadata: name: "${var.namespace}" namespace: "${var.traefik.namespace}" labels: ${jsonencode(local.common-labels)} spec: distrib: "${var.distributions.domain}" category: "apps" component: "traefik-ui" options: ${jsonencode(merge(local.global, local.traefik))} EOF } resource "kubectl_manifest" "k8s_api" { count = var.api.enable ? 1 : 0 yaml_body = <<-EOF apiVersion: "vynil.solidite.fr/v1" kind: "Install" metadata: name: "k8s-api-${var.namespace}" namespace: "default" labels: ${jsonencode(local.common-labels)} spec: distrib: "${var.distributions.domain}" category: "apps" component: "k8s-api" options: ${jsonencode(merge(local.global, local.api))} EOF } resource "kubectl_manifest" "okd" { count = var.okd.enable ? 1 : 0 depends_on = [kubernetes_namespace_v1.infra-ns] yaml_body = <<-EOF apiVersion: "vynil.solidite.fr/v1" kind: "Install" metadata: name: "infra-okd" namespace: "${kubernetes_namespace_v1.infra-ns[0].metadata[0].name}" labels: ${jsonencode(local.common-labels)} spec: distrib: "${var.distributions.domain}" category: "apps" component: "okd" options: ${jsonencode(merge(local.global, local.okd))} EOF } resource "kubectl_manifest" "gramo" { count = var.gramo.enable ? 1 : 0 depends_on = [kubernetes_namespace_v1.infra-ns] yaml_body = <<-EOF apiVersion: "vynil.solidite.fr/v1" kind: "Install" metadata: name: "infra-gramo" namespace: "${kubernetes_namespace_v1.infra-ns[0].metadata[0].name}" labels: ${jsonencode(local.common-labels)} spec: distrib: "${var.distributions.domain}" category: "apps" component: "gramo" options: ${jsonencode(merge(local.global, local.gramo))} EOF }