locals { annotations = { "vynil.solidite.fr/meta" = "domain-auth" "vynil.solidite.fr/name" = "${var.namespace}-auth" "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" = var.domain-name "issuer" = var.issuer "ingress-class" = var.ingress-class } nextcloud = { for k, v in var.nextcloud : k => v if k!="enable" } } resource "kubernetes_namespace_v1" "files-ns" { count = var.nextcloud.enable ? 1 : 0 metadata { annotations = local.annotations labels = merge(local.common-labels, local.annotations) name = "${var.namespace}-files" } } resource "kubectl_manifest" "nextcloud" { count = var.authentik.enable || var.authentik-ldap.enable || var.authentik-forward.enable ? 1 : 0 depends_on = [kubernetes_namespace_v1.auth-ns] yaml_body = <<-EOF apiVersion: "vynil.solidite.fr/v1" kind: "Install" metadata: name: "nextcloud" namespace: "${var.namespace}-files" labels: ${jsonencode(local.common-labels)} spec: distrib: "${var.distributions.domain}" category: "apps" component: "nextcloud" options: ${jsonencode(merge(local.global, local.nextcloud))} EOF }