mirror of
https://github.com/lingble/twenty.git
synced 2025-11-06 23:57:56 +00:00
Updates for v20+ and misc terraform bug fixes. Also refactored to use terraform variables instead of locals which helps with readability and ease of use for new users. Terraform validation is currently passing:  Additionally added [terraform-docs](https://terraform-docs.io/) to generate a more helpful README for terraform specific configuration. Raw K8s manifests were updated with changes for v20+ as well. --------- Co-authored-by: Félix Malfait <felix.malfait@gmail.com>
168 lines
3.7 KiB
HCL
168 lines
3.7 KiB
HCL
resource "kubernetes_deployment" "twentycrm_server" {
|
|
metadata {
|
|
name = "${var.twentycrm_app_name}-server"
|
|
namespace = kubernetes_namespace.twentycrm.metadata.0.name
|
|
labels = {
|
|
app = "${var.twentycrm_app_name}-server"
|
|
}
|
|
}
|
|
|
|
spec {
|
|
replicas = var.twentycrm_server_replicas
|
|
selector {
|
|
match_labels = {
|
|
app = "${var.twentycrm_app_name}-server"
|
|
}
|
|
}
|
|
|
|
strategy {
|
|
type = "RollingUpdate"
|
|
rolling_update {
|
|
max_surge = "1"
|
|
max_unavailable = "1"
|
|
}
|
|
}
|
|
|
|
template {
|
|
metadata {
|
|
labels = {
|
|
app = "${var.twentycrm_app_name}-server"
|
|
}
|
|
}
|
|
|
|
spec {
|
|
container {
|
|
image = var.twentycrm_server_image
|
|
name = var.twentycrm_app_name
|
|
stdin = true
|
|
tty = true
|
|
|
|
security_context {
|
|
allow_privilege_escalation = true
|
|
privileged = true
|
|
run_as_user = 1000
|
|
}
|
|
|
|
env {
|
|
name = "PORT"
|
|
value = "3000"
|
|
}
|
|
env {
|
|
name = "DEBUG_MODE"
|
|
value = false
|
|
}
|
|
|
|
env {
|
|
name = "SERVER_URL"
|
|
value = var.twentycrm_app_hostname
|
|
}
|
|
|
|
env {
|
|
name = "FRONT_BASE_URL"
|
|
value = var.twentycrm_app_hostname
|
|
}
|
|
|
|
env {
|
|
name = "PG_DATABASE_URL"
|
|
value = "postgres://twenty:${var.twentycrm_pgdb_admin_password}@${var.twentycrm_app_name}-db.${kubernetes_namespace.twentycrm.metadata.0.name}.svc.cluster.local/default"
|
|
}
|
|
|
|
env {
|
|
name = "ENABLE_DB_MIGRATIONS"
|
|
value = "true"
|
|
}
|
|
|
|
env {
|
|
name = "SIGN_IN_PREFILLED"
|
|
value = "true"
|
|
}
|
|
|
|
env {
|
|
name = "STORAGE_TYPE"
|
|
value = "local"
|
|
}
|
|
env {
|
|
name = "MESSAGE_QUEUE_TYPE"
|
|
value = "pg-boss"
|
|
}
|
|
env {
|
|
name = "ACCESS_TOKEN_SECRET"
|
|
value_from {
|
|
secret_key_ref {
|
|
name = "tokens"
|
|
key = "accessToken"
|
|
}
|
|
}
|
|
}
|
|
|
|
env {
|
|
name = "LOGIN_TOKEN_SECRET"
|
|
value_from {
|
|
secret_key_ref {
|
|
name = "tokens"
|
|
key = "loginToken"
|
|
}
|
|
}
|
|
}
|
|
|
|
env {
|
|
name = "REFRESH_TOKEN_SECRET"
|
|
value_from {
|
|
secret_key_ref {
|
|
name = "tokens"
|
|
key = "refreshToken"
|
|
}
|
|
}
|
|
}
|
|
|
|
env {
|
|
name = "FILE_TOKEN_SECRET"
|
|
value_from {
|
|
secret_key_ref {
|
|
name = "tokens"
|
|
key = "fileToken"
|
|
}
|
|
}
|
|
}
|
|
|
|
port {
|
|
container_port = 3000
|
|
protocol = "TCP"
|
|
}
|
|
|
|
resources {
|
|
requests = {
|
|
cpu = "250m"
|
|
memory = "256Mi"
|
|
}
|
|
limits = {
|
|
cpu = "1000m"
|
|
memory = "1024Mi"
|
|
}
|
|
}
|
|
|
|
volume_mount {
|
|
name = "server-data"
|
|
mount_path = var.twentycrm_server_data_mount_path
|
|
}
|
|
}
|
|
|
|
volume {
|
|
name = "server-data"
|
|
|
|
persistent_volume_claim {
|
|
claim_name = kubernetes_persistent_volume_claim.server.metadata.0.name
|
|
}
|
|
}
|
|
|
|
dns_policy = "ClusterFirst"
|
|
restart_policy = "Always"
|
|
}
|
|
}
|
|
}
|
|
depends_on = [
|
|
kubernetes_deployment.twentycrm_db,
|
|
kubernetes_secret.twentycrm_tokens
|
|
]
|
|
}
|