locals { annotations = { "vynil.solidite.fr/meta" = "domain-monitor" "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" = "monitor.${var.domain-name}" "issuer" = var.issuer "ingress-class" = var.ingress-class "backups" = var.backups "app-group" = var.app-group } grafana = { for k, v in var.grafana : k => v if k!="enable" } prometheus = { for k, v in var.prometheus : k => v if k!="enable" } alertmanager = { for k, v in var.alertmanager : k => v if k!="enable" } loki = { for k, v in var.loki : k => v if k!="enable" } promtail = { for k, v in var.promtail : k => v if k!="enable" } alerts-core = { for k, v in var.alerts-core : k => v if k!="enable" } alerts-containers = { for k, v in var.alerts-containers : k => v if k!="enable" } nodeExporter = { for k, v in var.node-exporter : k => v if k!="enable" } kubeStateMetrics = merge({"cluster-admin" = true}, { for k, v in var.kube-state-metrics : k => v if k!="enable" }) monitorControlPlan = merge({"cluster-admin" = true}, { for k, v in var.monitor-control-plan : k => v if k!="enable" }) dashboards-cluster = { for k, v in var.dashboards-cluster : k => v if k!="enable" } dashboards-minimal = { for k, v in var.dashboards-minimal : k => v if k!="enable" } dashboards-namespace = { for k, v in var.dashboards-namespace : k => v if k!="enable" } dashboards-workload = { for k, v in var.dashboards-workload : k => v if k!="enable" } } resource "kubernetes_namespace_v1" "monitor-ns" { count = ( var.grafana.enable || var.loki.enable || var.promtail.enable || var.prometheus.enable || var.alertmanager.enable || var.node-exporter.enable || var.kube-state-metrics.enable || var.monitor-control-plan.enable )? 1 : 0 metadata { annotations = local.annotations labels = merge(local.common-labels, local.annotations) name = "${var.namespace}-monitor" } } resource "kubectl_manifest" "alertmanager" { count = var.alertmanager.enable ? 1 : 0 depends_on = [kubernetes_namespace_v1.monitor-ns] yaml_body = <<-EOF apiVersion: "vynil.solidite.fr/v1" kind: "Install" metadata: name: "alertmanager" namespace: "${kubernetes_namespace_v1.monitor-ns[0].metadata[0].name}" labels: ${jsonencode(local.common-labels)} spec: distrib: "${var.distributions.domain}" category: "monitor" component: "alertmanager" options: ${jsonencode(merge(local.global, local.alertmanager))} EOF } resource "kubectl_manifest" "prometheus" { count = var.prometheus.enable ? 1 : 0 yaml_body = <<-EOF apiVersion: "vynil.solidite.fr/v1" kind: "Install" metadata: name: "prometheus" namespace: "${kubernetes_namespace_v1.monitor-ns[0].metadata[0].name}" labels: ${jsonencode(local.common-labels)} spec: distrib: "${var.distributions.domain}" category: "monitor" component: "prometheus" options: ${jsonencode(merge(local.global, local.prometheus))} EOF } resource "kubectl_manifest" "nodeExporter" { count = var.node-exporter.enable ? 1 : 0 yaml_body = <<-EOF apiVersion: "vynil.solidite.fr/v1" kind: "Install" metadata: name: "node-exporter" namespace: "${kubernetes_namespace_v1.monitor-ns[0].metadata[0].name}" labels: ${jsonencode(local.common-labels)} spec: distrib: "${var.distributions.domain}" category: "monitor" component: "node-exporter" options: ${jsonencode(merge(local.global, local.nodeExporter))} EOF } resource "kubectl_manifest" "kubeStateMetrics" { count = var.kube-state-metrics.enable ? 1 : 0 depends_on = [kubernetes_namespace_v1.monitor-ns] yaml_body = <<-EOF apiVersion: "vynil.solidite.fr/v1" kind: "Install" metadata: name: "kube-state-metrics" namespace: "${kubernetes_namespace_v1.monitor-ns[0].metadata[0].name}" labels: ${jsonencode(local.common-labels)} spec: distrib: "${var.distributions.domain}" category: "monitor" component: "kube-state-metrics" options: ${jsonencode(merge(local.global, local.kubeStateMetrics))} EOF } resource "kubectl_manifest" "monitorControlPlan" { count = var.monitor-control-plan.enable ? 1 : 0 depends_on = [kubernetes_namespace_v1.monitor-ns] yaml_body = <<-EOF apiVersion: "vynil.solidite.fr/v1" kind: "Install" metadata: name: "monitor-control-plan" namespace: "${kubernetes_namespace_v1.monitor-ns[0].metadata[0].name}" labels: ${jsonencode(local.common-labels)} spec: distrib: "${var.distributions.domain}" category: "monitor" component: "monitor-control-plan" options: ${jsonencode(merge(local.global, local.monitorControlPlan))} EOF } resource "kubectl_manifest" "alerts-core" { count = var.alerts-core.enable ? 1 : 0 depends_on = [kubernetes_namespace_v1.monitor-ns] yaml_body = <<-EOF apiVersion: "vynil.solidite.fr/v1" kind: "Install" metadata: name: "alerts-core" namespace: "${kubernetes_namespace_v1.monitor-ns[0].metadata[0].name}" labels: ${jsonencode(local.common-labels)} spec: distrib: "${var.distributions.domain}" category: "monitor" component: "alerts-core" options: ${jsonencode(merge(local.global, local.alerts-core))} EOF } resource "kubectl_manifest" "alerts-containers" { count = var.alerts-containers.enable ? 1 : 0 depends_on = [kubernetes_namespace_v1.monitor-ns] yaml_body = <<-EOF apiVersion: "vynil.solidite.fr/v1" kind: "Install" metadata: name: "alerts-containers" namespace: "${kubernetes_namespace_v1.monitor-ns[0].metadata[0].name}" labels: ${jsonencode(local.common-labels)} spec: distrib: "${var.distributions.domain}" category: "monitor" component: "alerts-containers" options: ${jsonencode(merge(local.global, local.alerts-containers))} EOF } resource "kubectl_manifest" "dashboards-cluster" { count = var.dashboards-cluster.enable ? 1 : 0 yaml_body = <<-EOF apiVersion: "vynil.solidite.fr/v1" kind: "Install" metadata: name: "dashboards-cluster" namespace: "${kubernetes_namespace_v1.monitor-ns[0].metadata[0].name}" labels: ${jsonencode(local.common-labels)} spec: distrib: "${var.distributions.domain}" category: "monitor" component: "dashboards-cluster" options: ${jsonencode(merge(local.global, local.dashboards-cluster))} EOF } resource "kubectl_manifest" "dashboards-minimal" { count = var.dashboards-minimal.enable ? 1 : 0 yaml_body = <<-EOF apiVersion: "vynil.solidite.fr/v1" kind: "Install" metadata: name: "dashboards-minimal" namespace: "${kubernetes_namespace_v1.monitor-ns[0].metadata[0].name}" labels: ${jsonencode(local.common-labels)} spec: distrib: "${var.distributions.domain}" category: "monitor" component: "dashboards-minimal" options: ${jsonencode(merge(local.global, local.dashboards-minimal))} EOF } resource "kubectl_manifest" "dashboards-namespace" { count = var.dashboards-namespace.enable ? 1 : 0 yaml_body = <<-EOF apiVersion: "vynil.solidite.fr/v1" kind: "Install" metadata: name: "dashboards-namespace" namespace: "${kubernetes_namespace_v1.monitor-ns[0].metadata[0].name}" labels: ${jsonencode(local.common-labels)} spec: distrib: "${var.distributions.domain}" category: "monitor" component: "dashboards-namespace" options: ${jsonencode(merge(local.global, local.dashboards-namespace))} EOF } resource "kubectl_manifest" "dashboards-workload" { count = var.dashboards-workload.enable ? 1 : 0 yaml_body = <<-EOF apiVersion: "vynil.solidite.fr/v1" kind: "Install" metadata: name: "dashboards-workload" namespace: "${kubernetes_namespace_v1.monitor-ns[0].metadata[0].name}" labels: ${jsonencode(local.common-labels)} spec: distrib: "${var.distributions.domain}" category: "monitor" component: "dashboards-workload" options: ${jsonencode(merge(local.global, local.dashboards-workload))} EOF } resource "kubectl_manifest" "grafana" { count = var.grafana.enable ? 1 : 0 yaml_body = <<-EOF apiVersion: "vynil.solidite.fr/v1" kind: "Install" metadata: name: "grafana" namespace: "${kubernetes_namespace_v1.monitor-ns[0].metadata[0].name}" labels: ${jsonencode(local.common-labels)} spec: distrib: "${var.distributions.domain}" category: "monitor" component: "grafana" options: ${jsonencode(merge(local.global, local.grafana))} EOF } resource "kubectl_manifest" "promtail" { count = var.promtail.enable ? 1 : 0 yaml_body = <<-EOF apiVersion: "vynil.solidite.fr/v1" kind: "Install" metadata: name: "promtail" namespace: "${kubernetes_namespace_v1.monitor-ns[0].metadata[0].name}" labels: ${jsonencode(local.common-labels)} spec: distrib: "${var.distributions.domain}" category: "monitor" component: "promtail" options: ${jsonencode(merge(local.global, local.promtail))} EOF } resource "kubectl_manifest" "loki" { count = var.loki.enable ? 1 : 0 yaml_body = <<-EOF apiVersion: "vynil.solidite.fr/v1" kind: "Install" metadata: name: "loki" namespace: "${kubernetes_namespace_v1.monitor-ns[0].metadata[0].name}" labels: ${jsonencode(local.common-labels)} spec: distrib: "${var.distributions.domain}" category: "monitor" component: "loki" options: ${jsonencode(merge(local.global, local.loki))} EOF }