Dokploy

Libredesk

Open source, self-hosted customer support desk. Single binary app.

Libredesk logo

Configuration

services:
  libredesk:
    image: libredesk/libredesk:latest
    restart: unless-stopped
    ports:
      - 9000
    environment:
      # If the password is set during first docker-compose up, the system user password will be set to this value.
      # You can always set system user password later by running `docker exec -it libredesk_app ./libredesk --set-system-user-password`.
      LIBREDESK_SYSTEM_USER_PASSWORD: ${LIBREDESK_SYSTEM_USER_PASSWORD:-}
    depends_on:
      - db
      - redis
    volumes:
      - ../files/uploads:/libredesk/uploads:rw
      - ../files/config.toml:/libredesk/config.toml
    command: [ sh, -c, "./libredesk --install --idempotent-install --yes --config /libredesk/config.toml && ./libredesk --upgrade --yes --config /libredesk/config.toml && ./libredesk --config /libredesk/config.toml" ]

  # PostgreSQL database
  db:
    image: postgres:17-alpine
    restart: unless-stopped
    ports:
      # Only bind on the local interface. To connect to Postgres externally, change this to 0.0.0.0
      - 5432
    environment:
      # Set these environment variables to configure the database, defaults to libredesk.
      POSTGRES_USER: ${POSTGRES_USER}
      POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}
      POSTGRES_DB: ${POSTGRES_DB}
    healthcheck:
      test: [ "CMD-SHELL", "pg_isready -U ${POSTGRES_USER:-libredesk} -d ${POSTGRES_DB:-libredesk}" ]
      interval: 10s
      timeout: 5s
      retries: 6
    volumes:
      - postgres-data:/var/lib/postgresql/data

  # Redis
  redis:
    image: redis:7-alpine
    restart: unless-stopped
    ports:
      # Only bind on the local interface.
      - 6379
    volumes:
      - redis-data:/data

volumes:
  postgres-data:
  redis-data:
[variables]
libredesk_domain = "${domain}"

libredesk_system_user_password = "${base64:32}"

pg_username = "${username}"
pg_password = "${password:16}"
pg_database = "libredesk"

[config]
env = [
    "LIBREDESK_SYSTEM_USER_PASSWORD=${libredesk_system_user_password}",
    "POSTGRES_USER=${pg_username}",
    "POSTGRES_PASSWORD=${pg_password}",
    "POSTGRES_DB=${pg_database}",
]

[[config.domains]]
serviceName = "libredesk"
port = 9000
host = "${libredesk_domain}"

[[config.mounts]]
filePath = "config.toml"
content = """

[app]
# Log level: info, debug, warn, error, fatal
log_level = "debug"
# Environment: dev, prod.
# Setting to "dev" will enable color logging in terminal.
env = "dev"
# Whether to automatically check for application updates on start up, app updates are shown as a banner in the admin panel.
check_updates = true

# HTTP server.
[app.server]
# Address to bind the HTTP server to.
address = "0.0.0.0:9000"
# Unix socket path (leave empty to use TCP address instead)
socket = ""
# Do NOT disable secure cookies in production environment if you don't know exactly what you're doing!
disable_secure_cookies = false
# Request read and write timeouts.
read_timeout = "5s"
write_timeout = "5s"
# Maximum request body size in bytes (100MB)
# If you are using proxy, you may need to configure them to allow larger request bodies.
max_body_size = 104857600
# Size of the read buffer for incoming requests
read_buffer_size = 4096
# Keepalive settings.
keepalive_timeout = "10s"

# File upload provider to use, either `fs` or `s3`.
[upload]
provider = "fs"

# Filesystem provider.
[upload.fs]
# Directory where uploaded files are stored, make sure this directory exists and is writable by the application.
upload_path = 'uploads'

# S3 provider.
[upload.s3]
# S3 endpoint URL (required only for non-AWS S3-compatible providers like MinIO).
# Leave empty to use default AWS endpoints.
url = ""

# AWS S3 credentials, keep empty to use attached IAM roles.
access_key = ""
secret_key = ""

# AWS region, e.g., "us-east-1", "eu-west-1", etc.
region = "ap-south-1"
# S3 bucket name where files will be stored.
bucket = "bucket-name"
# Optional prefix path within the S3 bucket where files will be stored.
# Example, if set to "uploads/media", files will be stored under that path.
# Useful for organizing files inside a shared bucket.
bucket_path = ""
# S3 signed URL expiry duration (e.g., "30m", "1h")
expiry = "30m"

# Postgres.
[db]
# If running locally, use `localhost`.
host = "db"
# Database port, default is 5432.
port = 5432
# Update the following values with your database credentials.
user = "${pg_username}"
password = "${pg_password}"
database = "${pg_database}"
ssl_mode = "disable"
# Maximum number of open database connections
max_open = 30
# Maximum number of idle connections in the pool
max_idle = 30
# Maximum time a connection can be reused before being closed
max_lifetime = "300s"

# Redis.
[redis]
# If running locally, use `localhost:6379`.
address = "redis:6379"
password = ""
db = 0

[message]
# Number of workers processing outgoing message queue
outgoing_queue_workers = 10
# Number of workers processing incoming message queue
incoming_queue_workers = 10
# How often to scan for outgoing messages to process, keep it low to process messages quickly.
message_outgoing_scan_interval = "50ms"
# Maximum number of messages that can be queued for incoming processing
incoming_queue_size = 5000
# Maximum number of messages that can be queued for outgoing processing
outgoing_queue_size = 5000

[notification]
# Number of concurrent notification workers
concurrency = 2
# Maximum number of notifications that can be queued
queue_size = 2000

[automation]
# Number of workers processing automation rules
worker_count = 10

[autoassigner]
# How often to run automatic conversation assignment
autoassign_interval = "5m"

[webhook]
# Number of webhook delivery workers
workers = 5
# Maximum number of webhook deliveries that can be queued
queue_size = 10000
# HTTP timeout for webhook requests
timeout = "15s"

[conversation]
# How often to check for conversations to unsnooze
unsnooze_interval = "5m"

[sla]
# How often to evaluate SLA compliance for conversations
evaluation_interval = "5m"

"""

Base64

To import this template in Dokploy: create a Compose service → AdvancedBase64 import and paste the content below:

{
  "compose": "services:\n  libredesk:\n    image: libredesk/libredesk:latest\n    restart: unless-stopped\n    ports:\n      - 9000\n    environment:\n      # If the password is set during first docker-compose up, the system user password will be set to this value.\n      # You can always set system user password later by running `docker exec -it libredesk_app ./libredesk --set-system-user-password`.\n      LIBREDESK_SYSTEM_USER_PASSWORD: ${LIBREDESK_SYSTEM_USER_PASSWORD:-}\n    depends_on:\n      - db\n      - redis\n    volumes:\n      - ../files/uploads:/libredesk/uploads:rw\n      - ../files/config.toml:/libredesk/config.toml\n    command: [ sh, -c, \"./libredesk --install --idempotent-install --yes --config /libredesk/config.toml && ./libredesk --upgrade --yes --config /libredesk/config.toml && ./libredesk --config /libredesk/config.toml\" ]\n\n  # PostgreSQL database\n  db:\n    image: postgres:17-alpine\n    restart: unless-stopped\n    ports:\n      # Only bind on the local interface. To connect to Postgres externally, change this to 0.0.0.0\n      - 5432\n    environment:\n      # Set these environment variables to configure the database, defaults to libredesk.\n      POSTGRES_USER: ${POSTGRES_USER}\n      POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}\n      POSTGRES_DB: ${POSTGRES_DB}\n    healthcheck:\n      test: [ \"CMD-SHELL\", \"pg_isready -U ${POSTGRES_USER:-libredesk} -d ${POSTGRES_DB:-libredesk}\" ]\n      interval: 10s\n      timeout: 5s\n      retries: 6\n    volumes:\n      - postgres-data:/var/lib/postgresql/data\n\n  # Redis\n  redis:\n    image: redis:7-alpine\n    restart: unless-stopped\n    ports:\n      # Only bind on the local interface.\n      - 6379\n    volumes:\n      - redis-data:/data\n\nvolumes:\n  postgres-data:\n  redis-data:",
  "config": "[variables]\nlibredesk_domain = \"${domain}\"\n\nlibredesk_system_user_password = \"${base64:32}\"\n\npg_username = \"${username}\"\npg_password = \"${password:16}\"\npg_database = \"libredesk\"\n\n[config]\nenv = [\n    \"LIBREDESK_SYSTEM_USER_PASSWORD=${libredesk_system_user_password}\",\n    \"POSTGRES_USER=${pg_username}\",\n    \"POSTGRES_PASSWORD=${pg_password}\",\n    \"POSTGRES_DB=${pg_database}\",\n]\n\n[[config.domains]]\nserviceName = \"libredesk\"\nport = 9000\nhost = \"${libredesk_domain}\"\n\n[[config.mounts]]\nfilePath = \"config.toml\"\ncontent = \"\"\"\n\n[app]\n# Log level: info, debug, warn, error, fatal\nlog_level = \"debug\"\n# Environment: dev, prod.\n# Setting to \"dev\" will enable color logging in terminal.\nenv = \"dev\"\n# Whether to automatically check for application updates on start up, app updates are shown as a banner in the admin panel.\ncheck_updates = true\n\n# HTTP server.\n[app.server]\n# Address to bind the HTTP server to.\naddress = \"0.0.0.0:9000\"\n# Unix socket path (leave empty to use TCP address instead)\nsocket = \"\"\n# Do NOT disable secure cookies in production environment if you don't know exactly what you're doing!\ndisable_secure_cookies = false\n# Request read and write timeouts.\nread_timeout = \"5s\"\nwrite_timeout = \"5s\"\n# Maximum request body size in bytes (100MB)\n# If you are using proxy, you may need to configure them to allow larger request bodies.\nmax_body_size = 104857600\n# Size of the read buffer for incoming requests\nread_buffer_size = 4096\n# Keepalive settings.\nkeepalive_timeout = \"10s\"\n\n# File upload provider to use, either `fs` or `s3`.\n[upload]\nprovider = \"fs\"\n\n# Filesystem provider.\n[upload.fs]\n# Directory where uploaded files are stored, make sure this directory exists and is writable by the application.\nupload_path = 'uploads'\n\n# S3 provider.\n[upload.s3]\n# S3 endpoint URL (required only for non-AWS S3-compatible providers like MinIO).\n# Leave empty to use default AWS endpoints.\nurl = \"\"\n\n# AWS S3 credentials, keep empty to use attached IAM roles.\naccess_key = \"\"\nsecret_key = \"\"\n\n# AWS region, e.g., \"us-east-1\", \"eu-west-1\", etc.\nregion = \"ap-south-1\"\n# S3 bucket name where files will be stored.\nbucket = \"bucket-name\"\n# Optional prefix path within the S3 bucket where files will be stored.\n# Example, if set to \"uploads/media\", files will be stored under that path.\n# Useful for organizing files inside a shared bucket.\nbucket_path = \"\"\n# S3 signed URL expiry duration (e.g., \"30m\", \"1h\")\nexpiry = \"30m\"\n\n# Postgres.\n[db]\n# If running locally, use `localhost`.\nhost = \"db\"\n# Database port, default is 5432.\nport = 5432\n# Update the following values with your database credentials.\nuser = \"${pg_username}\"\npassword = \"${pg_password}\"\ndatabase = \"${pg_database}\"\nssl_mode = \"disable\"\n# Maximum number of open database connections\nmax_open = 30\n# Maximum number of idle connections in the pool\nmax_idle = 30\n# Maximum time a connection can be reused before being closed\nmax_lifetime = \"300s\"\n\n# Redis.\n[redis]\n# If running locally, use `localhost:6379`.\naddress = \"redis:6379\"\npassword = \"\"\ndb = 0\n\n[message]\n# Number of workers processing outgoing message queue\noutgoing_queue_workers = 10\n# Number of workers processing incoming message queue\nincoming_queue_workers = 10\n# How often to scan for outgoing messages to process, keep it low to process messages quickly.\nmessage_outgoing_scan_interval = \"50ms\"\n# Maximum number of messages that can be queued for incoming processing\nincoming_queue_size = 5000\n# Maximum number of messages that can be queued for outgoing processing\noutgoing_queue_size = 5000\n\n[notification]\n# Number of concurrent notification workers\nconcurrency = 2\n# Maximum number of notifications that can be queued\nqueue_size = 2000\n\n[automation]\n# Number of workers processing automation rules\nworker_count = 10\n\n[autoassigner]\n# How often to run automatic conversation assignment\nautoassign_interval = \"5m\"\n\n[webhook]\n# Number of webhook delivery workers\nworkers = 5\n# Maximum number of webhook deliveries that can be queued\nqueue_size = 10000\n# HTTP timeout for webhook requests\ntimeout = \"15s\"\n\n[conversation]\n# How often to check for conversations to unsnooze\nunsnooze_interval = \"5m\"\n\n[sla]\n# How often to evaluate SLA compliance for conversations\nevaluation_interval = \"5m\"\n\n\"\"\""
}

Tags

storage, object-storage


Version: latest

On this page