locals { pg-labels = merge(local.common_labels, { "app.kubernetes.io/component" = "pg" }) } resource "kubectl_manifest" "prj_pg" { yaml_body = join("", concat([<<-EOF apiVersion: postgresql.cnpg.io/v1 kind: Cluster metadata: name: "${var.instance}-${var.component}-pg" namespace: "${var.namespace}" labels: ${jsonencode(local.pg-labels)} spec: instances: ${var.postgres.replicas} imageName: "${var.images.postgresql.registry}/${var.images.postgresql.repository}:${var.images.postgresql.tag}" storage: size: "${var.storage.postgres.size}" bootstrap: initdb: database: "${var.component}" owner: "${var.component}" monitoring: enablePodMonitor: true inheritedMetadata: annotations: "k8up.io/backupcommand": "pg_dump -U postgres -d ${var.component} --clean" "k8up.io/file-extension": ".sql" "k8up.io/backup": "true" EOF ], var.backups.enable&&var.backups.use_barman?[<<-EOF backup: barmanObjectStore: destinationPath: "s3://${var.instance}-${var.namespace}/" endpointURL: "${var.backups.endpoint}/barman" s3Credentials: accessKeyId: name: "${var.backups.secret_name}" key: "${var.backups.key_id_key}" secretAccessKey: name: "${var.backups.secret_name}" key: "${var.backups.secret_key}" EOF ]:[""])) } resource "kubectl_manifest" "prj_pg_backup" { count = var.backups.enable ? 1:0 yaml_body = <<-EOF apiVersion: postgresql.cnpg.io/v1 kind: ScheduledBackup metadata: name: "${var.instance}-${var.component}-pg" namespace: "${var.namespace}" labels: ${jsonencode(local.pg-labels)} spec: schedule: "${var.backups.schedule.db}" backupOwnerReference: self cluster: name: "${var.instance}-${var.component}-pg" EOF }