variable "tls_secret_name" {} variable "postgresql_password" {} module "tls_secret" { source = "../setup_tls_secret" namespace = "immich" tls_secret_name = var.tls_secret_name } resource "kubernetes_namespace" "immich" { metadata { name = "immich" # Container comms are broken - seems due to tls # labels = { # "istio-injection" : "enabled" # } } } resource "kubernetes_persistent_volume" "immich-postgresql" { metadata { name = "immich-postgresql" } spec { capacity = { "storage" = "10Gi" } access_modes = ["ReadWriteOnce"] persistent_volume_source { nfs { path = "/mnt/main/immich/data-immich-postgresql" server = "10.0.10.15" } } } } resource "kubernetes_persistent_volume" "immich" { metadata { name = "immich" } spec { capacity = { "storage" = "100Gi" } access_modes = ["ReadWriteOnce"] persistent_volume_source { nfs { path = "/mnt/main/immich/immich" server = "10.0.10.15" } } } } resource "kubernetes_persistent_volume" "immich-typesense-tsdata" { metadata { name = "immich-typesense-tsdata" } spec { capacity = { "storage" = "5Gi" } access_modes = ["ReadWriteOnce"] persistent_volume_source { nfs { path = "/mnt/main/immich/typesense-tsdata" server = "10.0.10.15" } } } } resource "kubernetes_persistent_volume_claim" "immich" { metadata { name = "immich" namespace = "immich" } spec { access_modes = ["ReadWriteOnce"] resources { requests = { "storage" = "20Gi" } } volume_name = "immich" } } # If you're having issuewith typesens container exiting prematurely, increase liveliness check resource "helm_release" "immich" { namespace = "immich" name = "immich" repository = "https://immich-app.github.io/immich-charts" chart = "immich" atomic = true # version = "0.2.0" version = "0.3.1" values = [templatefile("${path.module}/chart_values.tpl", { postgresql_password = var.postgresql_password })] } resource "kubernetes_ingress_v1" "immich" { metadata { name = "immich" namespace = "immich" annotations = { "kubernetes.io/ingress.class" = "nginx" # "nginx.ingress.kubernetes.io/auth-url" : "https://oauth2.viktorbarzin.me/oauth2/auth" # "nginx.ingress.kubernetes.io/auth-signin" : "https://oauth2.viktorbarzin.me/oauth2/start?rd=/redirect/$http_host$escaped_request_uri" "nginx.ingress.kubernetes.io/proxy-body-size" : "100000m" } } spec { tls { hosts = ["immich.viktorbarzin.me"] secret_name = var.tls_secret_name } rule { host = "immich.viktorbarzin.me" http { path { path = "/" backend { service { # name = "immich-proxy" name = "immich-server" # after v1.88 port { # number = 8080 number = 3001 } } } } } } } } resource "kubernetes_ingress_v1" "photos" { metadata { name = "photos" namespace = "immich" annotations = { "kubernetes.io/ingress.class" = "nginx" "nginx.ingress.kubernetes.io/proxy-body-size" : "5000m" } } spec { tls { hosts = ["photos.viktorbarzin.me"] secret_name = var.tls_secret_name } rule { host = "photos.viktorbarzin.me" http { path { path = "/" backend { service { # name = "immich-proxy" name = "immich-server" # after v1.88 port { # number = 8080 number = 3001 } } } } } } } }