{{ data_get($resource, 'Names') }}
@@ -152,11 +154,14 @@
-
- @else
- No resources found.
@endif
-
+ @else
+ @if ($activeTab === 'managed')
+ No managed resources found.
+ @elseif ($activeTab === 'unmanaged')
+ No unmanaged resources found.
+ @endif
+ @endif
diff --git a/resources/views/livewire/server/show-private-key.blade.php b/resources/views/livewire/server/show-private-key.blade.php
index 86bf2568e..f84086bff 100644
--- a/resources/views/livewire/server/show-private-key.blade.php
+++ b/resources/views/livewire/server/show-private-key.blade.php
@@ -1,5 +1,5 @@
-
+
Private Key
@@ -9,29 +9,25 @@
-
- @if (data_get($server, 'privateKey.uuid'))
-
- @else
- No private key attached.
- @endif
-
+
+ Change your server's private key.
- Choose another Key
-
+
@forelse ($privateKeys as $private_key)
-
+
{{ $private_key->name }}
{{ $private_key->description }}
+ @if (data_get($server, 'privateKey.uuid') !== $private_key->uuid)
+
+ Use this key
+
+ @else
+
+ Currently used
+
+ @endif
@empty
No private keys found.
diff --git a/resources/views/livewire/server/show.blade.php b/resources/views/livewire/server/show.blade.php
index 4a2729d3c..458d8cd2f 100644
--- a/resources/views/livewire/server/show.blade.php
+++ b/resources/views/livewire/server/show.blade.php
@@ -3,11 +3,75 @@
{{ data_get_str($server, 'name')->limit(10) }} > Server Configurations | Coolify
-
- @if ($server->isFunctional() && $server->isMetricsEnabled())
-
-
+
+
+
+ @if ($server->isFunctional())
+
+ @endif
+
+ @if ($server->isFunctional())
+
+
+
+
+
+ @endif
+ @if (!$server->isLocalhost())
+
+ @endif
- @endif
-
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+ @if ($server->isFunctional() && $server->isMetricsEnabled())
+
+
+
+ @else
+ No metrics available.
+ @endif
+
+ @if (!$server->isLocalhost())
+
+
+
+ @endif
+
+
diff --git a/resources/views/livewire/settings/index.blade.php b/resources/views/livewire/settings/index.blade.php
index f9293e7d7..cb7dfd5ac 100644
--- a/resources/views/livewire/settings/index.blade.php
+++ b/resources/views/livewire/settings/index.blade.php
@@ -41,7 +41,8 @@
-
+
+
+
+
+
DNS Validation
@@ -83,7 +92,7 @@
API
-
- Update
+ Update
@if (!is_null(env('AUTOUPDATE', null)))
@@ -119,6 +128,34 @@
helper="Cron expression for auto update frequency (automatically update coolify). You can use every_minute, hourly, daily, weekly, monthly, yearly.
Default is every day at 00:00" />
@endif
-
+ Advanced
+
+
+
+
+
+ Confirmation Settings
+ @if ($disable_two_step_confirmation)
+
+
+
+ @else
+
+ @endif
+
+ Warning!
+ Disabling two step confirmation reduces security (as anyone can easily delete anything) and increases the
+ risk of accidental actions. This is not recommended for production servers.
+
+
diff --git a/routes/api.php b/routes/api.php
index db07921a4..b63fde871 100644
--- a/routes/api.php
+++ b/routes/api.php
@@ -147,8 +147,11 @@ Route::group([
if (! $server) {
return response()->json(['message' => 'Server not found'], 404);
}
+ if ($server->settings->sentinel_token !== $naked_token) {
+ return response()->json(['message' => 'Unauthorized'], 401);
+ }
$data = request()->all();
- $server->update(['sentinel_update_at' => now()]);
+
PushServerUpdateJob::dispatch($server, $data);
return response()->json(['message' => 'ok'], 200);
diff --git a/storage/pail/.gitignore b/storage/pail/.gitignore
new file mode 100644
index 000000000..d6b7ef32c
--- /dev/null
+++ b/storage/pail/.gitignore
@@ -0,0 +1,2 @@
+*
+!.gitignore
diff --git a/templates/compose/azimutt.yaml b/templates/compose/azimutt.yaml
index 314d4479a..4b498e423 100644
--- a/templates/compose/azimutt.yaml
+++ b/templates/compose/azimutt.yaml
@@ -9,9 +9,9 @@ services:
postgres:
image: postgres:15
environment:
- - POSTGRES_PASSWORD=$SERVICE_PASSWORD_POSTGRES
- - POSTGRES_USER=$SERVICE_USER_POSTGRES
- - POSTGRES_DB=azimutt
+ - POSTGRES_PASSWORD=${SERVICE_PASSWORD_POSTGRES}
+ - POSTGRES_USER=${SERVICE_USER_POSTGRES}
+ - POSTGRES_DB=${POSTGRES_DB:-azimutt}
volumes:
- azimutt-postgres-data:/var/lib/postgresql/data
healthcheck:
@@ -80,8 +80,8 @@ services:
- PHX_SERVER=true
- PHX_HOST=$SERVICE_URL_AZIMUTT
- PORT=${PORT:-4000}
- - DATABASE_URL=ecto://$SERVICE_USER_POSTGRES:$SERVICE_PASSWORD_POSTGRES@postgres/azimutt
- - SECRET_KEY_BASE=$SERVICE_BASE64_64_AZIMUTT
+ - DATABASE_URL=ecto://${SERVICE_USER_POSTGRES}:${SERVICE_PASSWORD_POSTGRES}@postgres/${POSTGRES_DB:-azimutt}
+ - SECRET_KEY_BASE=${SERVICE_BASE64_64_AZIMUTT}
- FILE_STORAGE_ADAPTER=${FILE_STORAGE_ADAPTER:-s3}
- AUTH_PASSWORD=${AUTH_PASSWORD:-true}
- SKIP_ONBOARDING_FUNNEL=${SKIP_ONBOARDING_FUNNEL:-true}
diff --git a/templates/compose/bookstack.yaml b/templates/compose/bookstack.yaml
index 0bfe4f8e9..dd9719471 100644
--- a/templates/compose/bookstack.yaml
+++ b/templates/compose/bookstack.yaml
@@ -10,24 +10,34 @@ services:
environment:
- SERVICE_FQDN_BOOKSTACK_80
- APP_URL=${SERVICE_FQDN_BOOKSTACK}
+ - APP_KEY=${SERVICE_PASSWORD_APPKEY}
- PUID=1000
- PGID=1000
- TZ=${TZ:-Europe/Berlin}
- DB_HOST=mariadb
- DB_PORT=3306
- - DB_USER=${SERVICE_USER_MYSQL}
- - DB_PASS=${SERVICE_PASSWORD_MYSQL}
+ - DB_USERNAME=${SERVICE_USER_MYSQL}
+ - DB_PASSWORD=${SERVICE_PASSWORD_MYSQL}
- DB_DATABASE=${MYSQL_DATABASE:-bookstackapp}
- QUEUE_CONNECTION=${QUEUE_CONNECTION}
# You will need to set up an authentication provider as described at https://www.bookstackapp.com/docs/admin/third-party-auth/.
- GITHUB_APP_ID=${GITHUB_APP_ID}
- GITHUB_APP_SECRET=${GITHUB_APP_SECRET}
+ # SMTP Mail variables as per https://www.bookstackapp.com/docs/admin/email-webhooks/#email-configuration/.
+ - MAIL_DRIVER=${MAIL_DRIVER:-smtp}
+ - MAIL_HOST=${MAIL_HOST}
+ - MAIL_PORT=${MAIL_PORT:-587}
+ - MAIL_ENCRYPTION=${MAIL_ENCRYPTION:-tls}
+ - MAIL_USERNAME=${MAIL_USERNAME}
+ - MAIL_PASSWORD=${MAIL_PASSWORD}
+ - MAIL_FROM=${MAIL_FROM}
+ - MAIL_FROM_NAME=${MAIL_FROM_NAME:-BookStack}
volumes:
- 'bookstack-data:/config'
healthcheck:
test:
- CMD-SHELL
- - 'wget -qO- http://127.0.0.1:80/'
+ - 'curl -f http://127.0.0.1:80/'
interval: 5s
timeout: 20s
retries: 10
diff --git a/templates/compose/calcom.yaml b/templates/compose/calcom.yaml
index c7ea7744c..89f3376ee 100644
--- a/templates/compose/calcom.yaml
+++ b/templates/compose/calcom.yaml
@@ -7,6 +7,7 @@
services:
calcom:
image: calcom.docker.scarf.sh/calcom/cal.com
+ platform: linux/amd64
environment:
# Some variables still uses Calcom previous name, Calendso
#
@@ -21,9 +22,9 @@ services:
- NEXTAUTH_URL=${SERVICE_FQDN_CALCOM}/api/auth
# It is highly recommended that the NEXTAUTH_SECRET must be overridden and very unique
# Use `openssl rand -base64 32` to generate a key
- - NEXTAUTH_SECRET=${NEXTAUTH_SECRET:-$SERVICE_BASE64_CALCOM_SECRET}
+ - NEXTAUTH_SECRET=${SERVICE_BASE64_CALCOMSECRET}
# Encryption key that will be used to encrypt CalDAV credentials, choose a random string, for example with `dd if=/dev/urandom bs=1K count=1 | md5sum`
- - CALENDSO_ENCRYPTION_KEY=${CALENDSO_ENCRYPTION_KEY:-$SERVICE_BASE64_CALCOM_KEY}
+ - CALENDSO_ENCRYPTION_KEY=${SERVICE_BASE64_CALCOMKEY}
- POSTGRES_USER=${SERVICE_USER_POSTGRES}
- POSTGRES_PASSWORD=${SERVICE_PASSWORD_POSTGRES}
- POSTGRES_DB=${POSTGRES_DB:-calendso}
@@ -54,14 +55,11 @@ services:
environment:
- POSTGRES_USER=${SERVICE_USER_POSTGRES}
- POSTGRES_PASSWORD=${SERVICE_PASSWORD_POSTGRES}
- - POSTGRES_DB=${POSTGRES_DATABASE:-calcom}
+ - POSTGRES_DB=${POSTGRES_DB:-calendso}
volumes:
- calcom-postgresql-data:/var/lib/postgresql/data
healthcheck:
- test:
- - CMD-SHELL
- - pg_isready -U ${SERVICE_USER_POSTGRES} -d ${POSTGRES_DATABASE:-calcom}
- interval: 10s
- timeout: 5s
- retries: 5
- restart: unless-stopped
+ test: ["CMD-SHELL", "pg_isready -U $${POSTGRES_USER} -d $${POSTGRES_DB}"]
+ interval: 5s
+ timeout: 20s
+ retries: 10
diff --git a/templates/compose/dify.yaml b/templates/compose/dify.yaml
index a801426c1..fb4e971b5 100644
--- a/templates/compose/dify.yaml
+++ b/templates/compose/dify.yaml
@@ -1,3 +1,4 @@
+# ignore: true
# documentation: https://docs.dify.ai
# slogan: Dify is an open-source LLM app development platform. Dify's intuitive interface combines AI workflow, RAG pipeline, agent capabilities, model management, observability features and more, letting you quickly go from prototype to production.
# tags: ai, weaviate, openai, gpt, llm, lmops, dify, redis, postgres, qdrant, RAG, agent
@@ -335,7 +336,7 @@ services:
# cache_dir ufs /var/spool/squid 100 16 256
# upstream proxy, set to your own upstream proxy IP to avoid SSRF attacks
- # cache_peer 172.1.1.1 parent 3128 0 no-query no-digest no-netdb-exchange default
+ # cache_peer 172.1.1.1 parent 3128 0 no-query no-digest no-netdb-exchange default
################################## Reverse Proxy To Sandbox ################################
http_port 3129 accel vhost
diff --git a/templates/compose/edgedb.yaml b/templates/compose/edgedb.yaml
new file mode 100644
index 000000000..c305895ee
--- /dev/null
+++ b/templates/compose/edgedb.yaml
@@ -0,0 +1,41 @@
+# ignore: true
+# documentation: https://www.edgedb.com
+# slogan: An open-source database designed as a spiritual successor to SQL and the relational paradigm. Powered by the Postgres query engine under the hood.
+# tags: db database sql
+# logo: svgs/edgedb.svg
+# port: 5656
+
+services:
+ edgedb:
+ image: edgedb/edgedb
+ environment:
+ - SERVICE_FQDN_EDGEDB_5656
+ - EDGEDB_SERVER_ADMIN_UI=${EDGEDB_SERVER_ADMIN_UI:-enabled}
+ - EDGEDB_SERVER_BACKEND_DSN=postgres://${SERVICE_USER_POSTGRES}:${SERVICE_PASSWORD_POSTGRES}@postgresql:5432/${POSTGRES_DB:-edgedb}
+ - EDGEDB_SERVER_SECURITY=${EDGEDB_SERVER_SECURITY:-strict}
+ - EDGEDB_SERVER_PASSWORD=${SERVICE_PASSWORD_EDGEDB}
+ - POSTGRES_DB=${POSTGRES_DB:-edgedb}
+ depends_on:
+ postgresql:
+ condition: service_healthy
+ volumes:
+ - edgedb-data:/dbschema
+ healthcheck:
+ test: ["CMD", "curl", "-f", "http://localhost:5656/server/status/alive"]
+ interval: 5s
+ timeout: 20s
+ retries: 10
+
+ postgresql:
+ image: postgres:16-alpine
+ volumes:
+ - edgedb-postgresql-data:/var/lib/postgresql/data
+ environment:
+ - POSTGRES_USER=${SERVICE_USER_POSTGRES}
+ - POSTGRES_PASSWORD=${SERVICE_PASSWORD_POSTGRES}
+ - POSTGRES_DB=${POSTGRES_DB:-edgedb}
+ healthcheck:
+ test: ["CMD-SHELL", "pg_isready -U $${POSTGRES_USER} -d $${POSTGRES_DB}"]
+ interval: 5s
+ timeout: 20s
+ retries: 10
diff --git a/templates/compose/grafana-with-postgresql.yaml b/templates/compose/grafana-with-postgresql.yaml
index 25276468e..0ccdd235d 100644
--- a/templates/compose/grafana-with-postgresql.yaml
+++ b/templates/compose/grafana-with-postgresql.yaml
@@ -39,4 +39,3 @@ services:
interval: 5s
timeout: 20s
retries: 10
-
diff --git a/templates/compose/mindsdb.yaml b/templates/compose/mindsdb.yaml
new file mode 100644
index 000000000..72dc5a2d0
--- /dev/null
+++ b/templates/compose/mindsdb.yaml
@@ -0,0 +1,48 @@
+# documentation: https://docs.mindsdb.com/what-is-mindsdb
+# slogan: MindsDB is the platform for building AI from enterprise data, enabling smarter organizations.
+# tags: mysql, postgresdb, machine-learning, ai
+# logo: svgs/mindsdb.svg
+# port: 47334
+
+services:
+ mindsdb:
+ image: mindsdb/mindsdb:latest
+ environment:
+ - SERVICE_FQDN_MINDSDB_47334
+ - SERVICE_FQDN_API_47335=/api
+ - MINDSDB_DOCKER_ENV=true
+ - MINDSDB_STORAGE_DIR=/mindsdb/var
+ - FLASK_DEBUG=${FLASK_DEBUG:-1} # This will make sure http requests are logged regardless of log level
+ - OPENAI_API_KEY=${OPENAI_API_KEY}
+ - LANGFUSE_HOST=${LANGFUSE_HOST}
+ - LANGFUSE_PUBLIC_KEY=${LANGFUSE_PUBLIC_KEY}
+ - LANGFUSE_SECRET_KEY=${LANGFUSE_SECRET_KEY}
+ - LANGFUSE_RELEASE=${LANGFUSE_RELEASE:-local}
+ - LANGFUSE_DEBUG=${LANGFUSE_DEBUG:-False}
+ - LANGFUSE_TIMEOUT=${LANGFUSE_TIMEOUT:-10}
+ - LANGFUSE_SAMPLE_RATE=${LANGFUSE_SAMPLE_RATE:-1.0}
+ - MINDSDB_DB_CON=postgresql://${SERVICE_USER_POSTGRES}:${SERVICE_PASSWORD_POSTGRES}@postgresql/${POSTGRES_DB:-mindsdb-db}
+ volumes:
+ - mindsdb-data:/mindsdb/var
+ depends_on:
+ postgresql:
+ condition: service_healthy
+ healthcheck:
+ test: ["CMD", "curl", "-f", "http://localhost:47334/api/util/ping"]
+ interval: 30s
+ timeout: 5s
+ retries: 15
+
+ postgresql:
+ image: postgres:16-alpine
+ volumes:
+ - mindsdb-postgresql-data:/var/lib/postgresql/data
+ environment:
+ - POSTGRES_USER=${SERVICE_USER_POSTGRES}
+ - POSTGRES_PASSWORD=${SERVICE_PASSWORD_POSTGRES}
+ - POSTGRES_DB=${POSTGRES_DB:-mindsdb-db}
+ healthcheck:
+ test: ["CMD-SHELL", "pg_isready -U $${POSTGRES_USER} -d $${POSTGRES_DB}"]
+ interval: 10s
+ timeout: 5s
+ retries: 15
diff --git a/templates/compose/mosquitto.yaml b/templates/compose/mosquitto.yaml
new file mode 100644
index 000000000..1ec6f0cdc
--- /dev/null
+++ b/templates/compose/mosquitto.yaml
@@ -0,0 +1,48 @@
+# documentation: https://mosquitto.org/documentation/
+# slogan: Mosquitto is lightweight and suitable for use on all devices, from low-power single-board computers to full servers.
+# tags: mosquitto, mqtt, open-source
+# logo: svgs/mosquitto.svg
+# port: 1883
+
+services:
+ mosquitto:
+ image: eclipse-mosquitto
+ environment:
+ - SERVICE_FQDN_MOSQUITTO_1883
+ - MQTT_USERNAME=${SERVICE_USER_MOSQUITTO}
+ - MQTT_PASSWORD=${SERVICE_PASSWORD_MOSQUITTO}
+ - REQUIRE_CERTIFICATE=${REQUIRE_CERTIFICATE:-false}
+ - ALLOW_ANONYMOUS=${ALLOW_ANONYMOUS:-true}
+ volumes:
+ - mosquitto-config:/mosquitto/config
+ - mosquitto-certs:/certs
+ healthcheck:
+ test: ["CMD-SHELL", "exit 0"]
+ interval: 30s
+ timeout: 10s
+ retries: 3
+
+ entrypoint: 'sh -c "
+ if [ ''$REQUIRE_CERTIFICATE'' = ''true'' ]; then
+ echo ''listener 8883'' > /mosquitto/config/mosquitto.conf &&
+ echo ''cafile /certs/ca.crt'' >> /mosquitto/config/mosquitto.conf &&
+ echo ''certfile /certs/server.crt'' >> /mosquitto/config/mosquitto.conf &&
+ echo ''keyfile /certs/server.key'' >> /mosquitto/config/mosquitto.conf;
+ else
+ echo ''listener 1883'' > /mosquitto/config/mosquitto.conf;
+ fi &&
+ echo ''require_certificate ''$REQUIRE_CERTIFICATE >> /mosquitto/config/mosquitto.conf &&
+ echo ''allow_anonymous ''$ALLOW_ANONYMOUS >> /mosquitto/config/mosquitto.conf &&
+ if [ -n ''$SERVICE_USER_MOSQUITTO''] && [ -n ''$SERVICE_PASSWORD_MOSQUITTO'' ]; then
+ echo ''password_file /mosquitto/config/passwords'' >> /mosquitto/config/mosquitto.conf &&
+ touch /mosquitto/config/passwords &&
+ chmod 0700 /mosquitto/config/passwords &&
+ chown root:root /mosquitto/config/passwords &&
+ mosquitto_passwd -b -c /mosquitto/config/passwords $SERVICE_USER_MOSQUITTO $SERVICE_PASSWORD_MOSQUITTO &&
+ chown mosquitto:mosquitto /mosquitto/config/passwords;
+ fi &&
+ exec mosquitto -c /mosquitto/config/mosquitto.conf
+ "'
+ labels:
+ - traefik.tcp.routers.mqtt.entrypoints=mqtt
+ - traefik.tcp.routers.mqtts.entrypoints=mqtts
diff --git a/templates/compose/peppermint.yaml b/templates/compose/peppermint.yaml
index c079ee48b..228389eb4 100644
--- a/templates/compose/peppermint.yaml
+++ b/templates/compose/peppermint.yaml
@@ -1,3 +1,4 @@
+# ignore: true
# documentation: https://docs.peppermint.sh/
# slogan: Open source helpdesk solution designed to enhance the user experience for teams currently utilizing costly software alternatives
# tags: helpdesk, open-source, peppermint, postgres
diff --git a/templates/compose/plausible.yaml b/templates/compose/plausible.yaml
index e02e92d38..a37dcaf6e 100644
--- a/templates/compose/plausible.yaml
+++ b/templates/compose/plausible.yaml
@@ -10,31 +10,60 @@ services:
command: 'sh -c "sleep 10 && /entrypoint.sh db createdb && /entrypoint.sh db migrate && /entrypoint.sh run"'
environment:
- SERVICE_FQDN_PLAUSIBLE
- - "DATABASE_URL=postgres://postgres:$SERVICE_PASSWORD_POSTGRES@plausible_db/plausible"
- - BASE_URL=$SERVICE_FQDN_PLAUSIBLE
- - SECRET_KEY_BASE=$SERVICE_BASE64_64_PLAUSIBLE
- - TOTP_VAULT_KEY=$SERVICE_REALBASE64_32_TOTP
+ - DATABASE_URL=postgres://${SERVICE_USER_POSTGRES}:${SERVICE_PASSWORD_POSTGRES}@plausible-db:5432/${POSTGRES_DB:-plausible-db}
+ - CLICKHOUSE_DATABASE_URL=http://plausible-events-db:8123/plausible_events_db
+ - BASE_URL=${SERVICE_FQDN_PLAUSIBLE}
+ - SECRET_KEY_BASE=${SERVICE_BASE64_64_PLAUSIBLE}
+ - TOTP_VAULT_KEY=${SERVICE_REALBASE64_32_TOTP}
depends_on:
- - plausible_db
- - plausible_events_db
- - mail
+ plausible-db:
+ condition: service_healthy
+ plausible-events-db:
+ condition: service_healthy
+ mail:
+ condition: service_healthy
+ healthcheck:
+ test:
+ [
+ "CMD",
+ "wget",
+ "--no-verbose",
+ "--tries=1",
+ "--spider",
+ "http://127.0.0.1:8000/api/health",
+ ]
+ interval: 10s
+ timeout: 5s
+ retries: 5
+ start_period: 45s
+
mail:
image: bytemark/smtp
+ platform: linux/amd64
+ healthcheck:
+ test: ["CMD-SHELL", "bash -c ':> /dev/tcp/127.0.0.1/25' || exit 1"]
+ interval: 5s
+ timeout: 10s
+ retries: 20
- plausible_db:
+ plausible-db:
image: "postgres:16-alpine"
volumes:
- - "db-data:/var/lib/postgresql/data"
+ - plausible-postgres-data:/var/lib/postgresql/data
environment:
- - POSTGRES_DB=plausible
- - POSTGRES_PASSWORD=$SERVICE_PASSWORD_POSTGRES
+ - POSTGRES_DB=${POSTGRES_DB:-plausible-db}
+ - POSTGRES_USER=${SERVICE_USER_POSTGRES}
+ - POSTGRES_PASSWORD=${SERVICE_PASSWORD_POSTGRES}
+ healthcheck:
+ test: ["CMD-SHELL", "pg_isready -U $${POSTGRES_USER} -d $${POSTGRES_DB}"]
+ interval: 5s
+ timeout: 20s
+ retries: 10
- plausible_events_db:
+ plausible-events-db:
image: "clickhouse/clickhouse-server:24.3.3.102-alpine"
volumes:
- - type: volume
- source: event-data
- target: /var/lib/clickhouse
+ - plausible-events-data:/var/lib/clickhouse
- type: bind
source: ./clickhouse/clickhouse-config.xml
target: /etc/clickhouse-server/config.d/logging.xml
@@ -49,3 +78,10 @@ services:
nofile:
soft: 262144
hard: 262144
+ healthcheck:
+ test:
+ [
+ "CMD-SHELL",
+ "wget --no-verbose --tries=1 -O - http://127.0.0.1:8123/ping || exit 1",
+ ]
+ start_period: 30s
diff --git a/templates/compose/windmill.yaml b/templates/compose/windmill.yaml
index a14854ba0..1ce3a4652 100644
--- a/templates/compose/windmill.yaml
+++ b/templates/compose/windmill.yaml
@@ -11,10 +11,11 @@ services:
volumes:
- db-data:/var/lib/postgresql/data
environment:
- - POSTGRES_PASSWORD=$SERVICE_PASSWORD_POSTGRES
- - POSTGRES_DB=${POSTGRES_DB:-windmill}
+ - POSTGRES_PASSWORD=${SERVICE_PASSWORD_POSTGRES}
+ - POSTGRES_USER=${SERVICE_USER_POSTGRES}
+ - POSTGRES_DB=${POSTGRES_DB:-windmill-db}
healthcheck:
- test: ["CMD-SHELL", "pg_isready -U postgres"]
+ test: ["CMD-SHELL", "pg_isready -U $${POSTGRES_USER} -d $${POSTGRES_DB}"]
interval: 10s
timeout: 5s
retries: 5
@@ -23,16 +24,16 @@ services:
image: ghcr.io/windmill-labs/windmill:main
environment:
- SERVICE_FQDN_WINDMILL_8000
- - DATABASE_URL=postgres://postgres:$SERVICE_PASSWORD_POSTGRES@db/windmill
- - MODE=${MODE:-server}
- - BASE_URL=$SERVICE_FQDN_WINDMILL
+ - DATABASE_URL=postgres://${SERVICE_USER_POSTGRES}:${SERVICE_PASSWORD_POSTGRES}@db/${POSTGRES_DB:-windmill-db}
+ - MODE=server
+ - BASE_URL=${SERVICE_FQDN_WINDMILL}
depends_on:
db:
condition: service_healthy
volumes:
- worker-logs:/tmp/windmill/logs
healthcheck:
- test: ["CMD", "curl", "-f", "http://localhost:8000/api/version || exit 1"]
+ test: ["CMD", "curl", "-f", "http://localhost:8000/health"]
interval: 30s
timeout: 10s
retries: 3
@@ -40,9 +41,9 @@ services:
windmill-worker-1:
image: ghcr.io/windmill-labs/windmill:main
environment:
- - DATABASE_URL=postgres://postgres:$SERVICE_PASSWORD_POSTGRES@db/windmill
- - MODE=${MODE:-worker}
- - WORKER_GROUP=${WORKER_GROUP:-default}
+ - DATABASE_URL=postgres://${SERVICE_USER_POSTGRES}:${SERVICE_PASSWORD_POSTGRES}@db/${POSTGRES_DB:-windmill-db}
+ - MODE=worker
+ - WORKER_GROUP=default
depends_on:
db:
condition: service_healthy
@@ -51,7 +52,7 @@ services:
- worker-dependency-cache:/tmp/windmill/cache
- worker-logs:/tmp/windmill/logs
healthcheck:
- test: ["CMD", "curl", "-f", "http://localhost:8000/api/version || exit 1"]
+ test: ["CMD-SHELL", "exit 0"]
interval: 30s
timeout: 10s
retries: 3
@@ -59,9 +60,9 @@ services:
windmill-worker-2:
image: ghcr.io/windmill-labs/windmill:main
environment:
- - DATABASE_URL=postgres://postgres:$SERVICE_PASSWORD_POSTGRES@db/windmill
- - MODE=${MODE:-worker}
- - WORKER_GROUP=${WORKER_GROUP:-default}
+ - DATABASE_URL=postgres://${SERVICE_USER_POSTGRES}:${SERVICE_PASSWORD_POSTGRES}@db/${POSTGRES_DB:-windmill-db}
+ - MODE=worker
+ - WORKER_GROUP=default
depends_on:
db:
condition: service_healthy
@@ -70,7 +71,7 @@ services:
- worker-dependency-cache:/tmp/windmill/cache
- worker-logs:/tmp/windmill/logs
healthcheck:
- test: ["CMD", "curl", "-f", "http://localhost:8000/api/version || exit 1"]
+ test: ["CMD-SHELL", "exit 0"]
interval: 30s
timeout: 10s
retries: 3
@@ -78,9 +79,9 @@ services:
windmill-worker-3:
image: ghcr.io/windmill-labs/windmill:main
environment:
- - DATABASE_URL=postgres://postgres:$SERVICE_PASSWORD_POSTGRES@db/windmill
- - MODE=${MODE:-worker}
- - WORKER_GROUP=${WORKER_GROUP:-default}
+ - DATABASE_URL=postgres://${SERVICE_USER_POSTGRES}:${SERVICE_PASSWORD_POSTGRES}@db/${POSTGRES_DB:-windmill-db}
+ - MODE=worker
+ - WORKER_GROUP=default
depends_on:
db:
condition: service_healthy
@@ -89,7 +90,7 @@ services:
- worker-dependency-cache:/tmp/windmill/cache
- worker-logs:/tmp/windmill/logs
healthcheck:
- test: ["CMD", "curl", "-f", "http://localhost:8000/api/version || exit 1"]
+ test: ["CMD-SHELL", "exit 0"]
interval: 30s
timeout: 10s
retries: 3
@@ -97,18 +98,18 @@ services:
windmill-worker-native:
image: ghcr.io/windmill-labs/windmill:main
environment:
- - DATABASE_URL=postgres://postgres:$SERVICE_PASSWORD_POSTGRES@db/windmill
- - MODE=${MODE:-worker}
- - WORKER_GROUP=${WORKER_GROUP:-native}
- - NUM_WORKERS=${NUM_WORKERS:-8}
- - SLEEP_QUEUE=${SLEEP_QUEUE:-200}
+ - DATABASE_URL=postgres://${SERVICE_USER_POSTGRES}:${SERVICE_PASSWORD_POSTGRES}@db/${POSTGRES_DB:-windmill-db}
+ - MODE=worker
+ - WORKER_GROUP=native
+ - NUM_WORKERS=8
+ - SLEEP_QUEUE=200
depends_on:
db:
condition: service_healthy
volumes:
- worker-logs:/tmp/windmill/logs
healthcheck:
- test: ["CMD", "curl", "-f", "http://localhost:8000/api/version || exit 1"]
+ test: ["CMD-SHELL", "exit 0"]
interval: 30s
timeout: 10s
retries: 3
@@ -122,3 +123,4 @@ services:
interval: 30s
timeout: 10s
retries: 3
+ start_period: 20s
\ No newline at end of file
diff --git a/templates/compose/zep.yaml b/templates/compose/zep.yaml
index 75e7558aa..1bc0912a3 100644
--- a/templates/compose/zep.yaml
+++ b/templates/compose/zep.yaml
@@ -1,3 +1,4 @@
+# ignore: true
# documentation: https://help.getzep.com/concepts
# slogan: Zep enhances your AI agent's knowledge through continuous learning from user interactions, enabling personalized experiences and improved accuracy.
# tags: lowcode, nocode, ai, llm, openai, anthropic, machine-learning, rag, agents, chatbot, api, team, bot, flows, memory
diff --git a/templates/service-templates.json b/templates/service-templates.json
index 664eb1ade..cc03e2e1d 100644
--- a/templates/service-templates.json
+++ b/templates/service-templates.json
@@ -162,7 +162,7 @@
"bookstack": {
"documentation": "https://www.bookstackapp.com/docs/?utm_source=coolify.io",
"slogan": "BookStack is a simple, self-hosted, easy-to-use platform for organising and storing information",
- "compose": "c2VydmljZXM6CiAgYm9va3N0YWNrOgogICAgaW1hZ2U6ICdsc2NyLmlvL2xpbnV4c2VydmVyL2Jvb2tzdGFjazpsYXRlc3QnCiAgICBlbnZpcm9ubWVudDoKICAgICAgLSBTRVJWSUNFX0ZRRE5fQk9PS1NUQUNLXzgwCiAgICAgIC0gJ0FQUF9VUkw9JHtTRVJWSUNFX0ZRRE5fQk9PS1NUQUNLfScKICAgICAgLSBQVUlEPTEwMDAKICAgICAgLSBQR0lEPTEwMDAKICAgICAgLSAnVFo9JHtUWjotRXVyb3BlL0Jlcmxpbn0nCiAgICAgIC0gREJfSE9TVD1tYXJpYWRiCiAgICAgIC0gREJfUE9SVD0zMzA2CiAgICAgIC0gJ0RCX1VTRVI9JHtTRVJWSUNFX1VTRVJfTVlTUUx9JwogICAgICAtICdEQl9QQVNTPSR7U0VSVklDRV9QQVNTV09SRF9NWVNRTH0nCiAgICAgIC0gJ0RCX0RBVEFCQVNFPSR7TVlTUUxfREFUQUJBU0U6LWJvb2tzdGFja2FwcH0nCiAgICAgIC0gJ1FVRVVFX0NPTk5FQ1RJT049JHtRVUVVRV9DT05ORUNUSU9OfScKICAgICAgLSAnR0lUSFVCX0FQUF9JRD0ke0dJVEhVQl9BUFBfSUR9JwogICAgICAtICdHSVRIVUJfQVBQX1NFQ1JFVD0ke0dJVEhVQl9BUFBfU0VDUkVUfScKICAgIHZvbHVtZXM6CiAgICAgIC0gJ2Jvb2tzdGFjay1kYXRhOi9jb25maWcnCiAgICBoZWFsdGhjaGVjazoKICAgICAgdGVzdDoKICAgICAgICAtIENNRC1TSEVMTAogICAgICAgIC0gJ3dnZXQgLXFPLSBodHRwOi8vMTI3LjAuMC4xOjgwLycKICAgICAgaW50ZXJ2YWw6IDVzCiAgICAgIHRpbWVvdXQ6IDIwcwogICAgICByZXRyaWVzOiAxMAogICAgZGVwZW5kc19vbjoKICAgICAgbWFyaWFkYjoKICAgICAgICBjb25kaXRpb246IHNlcnZpY2VfaGVhbHRoeQogIG1hcmlhZGI6CiAgICBpbWFnZTogJ2xzY3IuaW8vbGludXhzZXJ2ZXIvbWFyaWFkYjpsYXRlc3QnCiAgICBlbnZpcm9ubWVudDoKICAgICAgLSBQVUlEPTEwMDAKICAgICAgLSBQR0lEPTEwMDAKICAgICAgLSAnVFo9JHtUWjotRXVyb3BlL0Jlcmxpbn0nCiAgICAgIC0gJ01ZU1FMX1JPT1RfUEFTU1dPUkQ9JHtTRVJWSUNFX1BBU1NXT1JEX01ZU1FMUk9PVH0nCiAgICAgIC0gJ01ZU1FMX0RBVEFCQVNFPSR7TVlTUUxfREFUQUJBU0U6LWJvb2tzdGFja30nCiAgICAgIC0gJ01ZU1FMX1VTRVI9JHtTRVJWSUNFX1VTRVJfTVlTUUx9JwogICAgICAtICdNWVNRTF9QQVNTV09SRD0ke1NFUlZJQ0VfUEFTU1dPUkRfTVlTUUx9JwogICAgdm9sdW1lczoKICAgICAgLSAnYm9va3N0YWNrLW1hcmlhZGItZGF0YTovY29uZmlnJwogICAgaGVhbHRoY2hlY2s6CiAgICAgIHRlc3Q6CiAgICAgICAgLSBDTUQKICAgICAgICAtIG15c3FsYWRtaW4KICAgICAgICAtIHBpbmcKICAgICAgICAtICctaCcKICAgICAgICAtIDEyNy4wLjAuMQogICAgICBpbnRlcnZhbDogNXMKICAgICAgdGltZW91dDogMjBzCiAgICAgIHJldHJpZXM6IDEwCg==",
+ "compose": "c2VydmljZXM6CiAgYm9va3N0YWNrOgogICAgaW1hZ2U6ICdsc2NyLmlvL2xpbnV4c2VydmVyL2Jvb2tzdGFjazpsYXRlc3QnCiAgICBlbnZpcm9ubWVudDoKICAgICAgLSBTRVJWSUNFX0ZRRE5fQk9PS1NUQUNLXzgwCiAgICAgIC0gJ0FQUF9VUkw9JHtTRVJWSUNFX0ZRRE5fQk9PS1NUQUNLfScKICAgICAgLSAnQVBQX0tFWT0ke1NFUlZJQ0VfUEFTU1dPUkRfQVBQS0VZfScKICAgICAgLSBQVUlEPTEwMDAKICAgICAgLSBQR0lEPTEwMDAKICAgICAgLSAnVFo9JHtUWjotRXVyb3BlL0Jlcmxpbn0nCiAgICAgIC0gREJfSE9TVD1tYXJpYWRiCiAgICAgIC0gREJfUE9SVD0zMzA2CiAgICAgIC0gJ0RCX1VTRVJOQU1FPSR7U0VSVklDRV9VU0VSX01ZU1FMfScKICAgICAgLSAnREJfUEFTU1dPUkQ9JHtTRVJWSUNFX1BBU1NXT1JEX01ZU1FMfScKICAgICAgLSAnREJfREFUQUJBU0U9JHtNWVNRTF9EQVRBQkFTRTotYm9va3N0YWNrYXBwfScKICAgICAgLSAnUVVFVUVfQ09OTkVDVElPTj0ke1FVRVVFX0NPTk5FQ1RJT059JwogICAgICAtICdHSVRIVUJfQVBQX0lEPSR7R0lUSFVCX0FQUF9JRH0nCiAgICAgIC0gJ0dJVEhVQl9BUFBfU0VDUkVUPSR7R0lUSFVCX0FQUF9TRUNSRVR9JwogICAgICAtICdNQUlMX0RSSVZFUj0ke01BSUxfRFJJVkVSOi1zbXRwfScKICAgICAgLSAnTUFJTF9IT1NUPSR7TUFJTF9IT1NUfScKICAgICAgLSAnTUFJTF9QT1JUPSR7TUFJTF9QT1JUOi01ODd9JwogICAgICAtICdNQUlMX0VOQ1JZUFRJT049JHtNQUlMX0VOQ1JZUFRJT046LXRsc30nCiAgICAgIC0gJ01BSUxfVVNFUk5BTUU9JHtNQUlMX1VTRVJOQU1FfScKICAgICAgLSAnTUFJTF9QQVNTV09SRD0ke01BSUxfUEFTU1dPUkR9JwogICAgICAtICdNQUlMX0ZST009JHtNQUlMX0ZST019JwogICAgICAtICdNQUlMX0ZST01fTkFNRT0ke01BSUxfRlJPTV9OQU1FOi1Cb29rU3RhY2t9JwogICAgdm9sdW1lczoKICAgICAgLSAnYm9va3N0YWNrLWRhdGE6L2NvbmZpZycKICAgIGhlYWx0aGNoZWNrOgogICAgICB0ZXN0OgogICAgICAgIC0gQ01ELVNIRUxMCiAgICAgICAgLSAnY3VybCAtZiBodHRwOi8vMTI3LjAuMC4xOjgwLycKICAgICAgaW50ZXJ2YWw6IDVzCiAgICAgIHRpbWVvdXQ6IDIwcwogICAgICByZXRyaWVzOiAxMAogICAgZGVwZW5kc19vbjoKICAgICAgbWFyaWFkYjoKICAgICAgICBjb25kaXRpb246IHNlcnZpY2VfaGVhbHRoeQogIG1hcmlhZGI6CiAgICBpbWFnZTogJ2xzY3IuaW8vbGludXhzZXJ2ZXIvbWFyaWFkYjpsYXRlc3QnCiAgICBlbnZpcm9ubWVudDoKICAgICAgLSBQVUlEPTEwMDAKICAgICAgLSBQR0lEPTEwMDAKICAgICAgLSAnVFo9JHtUWjotRXVyb3BlL0Jlcmxpbn0nCiAgICAgIC0gJ01ZU1FMX1JPT1RfUEFTU1dPUkQ9JHtTRVJWSUNFX1BBU1NXT1JEX01ZU1FMUk9PVH0nCiAgICAgIC0gJ01ZU1FMX0RBVEFCQVNFPSR7TVlTUUxfREFUQUJBU0U6LWJvb2tzdGFja30nCiAgICAgIC0gJ01ZU1FMX1VTRVI9JHtTRVJWSUNFX1VTRVJfTVlTUUx9JwogICAgICAtICdNWVNRTF9QQVNTV09SRD0ke1NFUlZJQ0VfUEFTU1dPUkRfTVlTUUx9JwogICAgdm9sdW1lczoKICAgICAgLSAnYm9va3N0YWNrLW1hcmlhZGItZGF0YTovY29uZmlnJwogICAgaGVhbHRoY2hlY2s6CiAgICAgIHRlc3Q6CiAgICAgICAgLSBDTUQKICAgICAgICAtIG15c3FsYWRtaW4KICAgICAgICAtIHBpbmcKICAgICAgICAtICctaCcKICAgICAgICAtIDEyNy4wLjAuMQogICAgICBpbnRlcnZhbDogNXMKICAgICAgdGltZW91dDogMjBzCiAgICAgIHJldHJpZXM6IDEwCg==",
"tags": [
"free-and-open-source",
"mfa",
@@ -224,6 +224,21 @@
"minversion": "0.0.0",
"port": "10000"
},
+ "calcom": {
+ "documentation": "https://cal.com/docs?utm_source=coolify.io",
+ "slogan": "Scheduling infrastructure for everyone.",
+ "compose": "c2VydmljZXM6CiAgY2FsY29tOgogICAgaW1hZ2U6IGNhbGNvbS5kb2NrZXIuc2NhcmYuc2gvY2FsY29tL2NhbC5jb20KICAgIHBsYXRmb3JtOiBsaW51eC9hbWQ2NAogICAgZW52aXJvbm1lbnQ6CiAgICAgIC0gU0VSVklDRV9GUUROX0NBTENPTV8zMDAwCiAgICAgIC0gTkVYVF9QVUJMSUNfTElDRU5TRV9DT05TRU5UPWFncmVlCiAgICAgIC0gTk9ERV9FTlY9cHJvZHVjdGlvbgogICAgICAtICdORVhUX1BVQkxJQ19XRUJBUFBfVVJMPSR7U0VSVklDRV9GUUROX0NBTENPTX0nCiAgICAgIC0gJ05FWFRfUFVCTElDX0FQSV9WMl9VUkw9JHtTRVJWSUNFX0ZRRE5fQ0FMQ09NfS9hcGkvdjInCiAgICAgIC0gJ05FWFRBVVRIX1VSTD0ke1NFUlZJQ0VfRlFETl9DQUxDT019L2FwaS9hdXRoJwogICAgICAtICdORVhUQVVUSF9TRUNSRVQ9JHtTRVJWSUNFX0JBU0U2NF9DQUxDT01TRUNSRVR9JwogICAgICAtICdDQUxFTkRTT19FTkNSWVBUSU9OX0tFWT0ke1NFUlZJQ0VfQkFTRTY0X0NBTENPTUtFWX0nCiAgICAgIC0gJ1BPU1RHUkVTX1VTRVI9JHtTRVJWSUNFX1VTRVJfUE9TVEdSRVN9JwogICAgICAtICdQT1NUR1JFU19QQVNTV09SRD0ke1NFUlZJQ0VfUEFTU1dPUkRfUE9TVEdSRVN9JwogICAgICAtICdQT1NUR1JFU19EQj0ke1BPU1RHUkVTX0RCOi1jYWxlbmRzb30nCiAgICAgIC0gREFUQUJBU0VfSE9TVD1wb3N0Z3Jlc3FsCiAgICAgIC0gJ0RBVEFCQVNFX1VSTD1wb3N0Z3Jlc3FsOi8vJHtTRVJWSUNFX1VTRVJfUE9TVEdSRVN9OiR7U0VSVklDRV9QQVNTV09SRF9QT1NUR1JFU31AJHtEQVRBQkFTRV9IT1NUOi1wb3N0Z3Jlc3FsfS8ke1BPU1RHUkVTX0RCOi1jYWxlbmRzb30nCiAgICAgIC0gJ0RBVEFCQVNFX0RJUkVDVF9VUkw9cG9zdGdyZXNxbDovLyR7U0VSVklDRV9VU0VSX1BPU1RHUkVTfToke1NFUlZJQ0VfUEFTU1dPUkRfUE9TVEdSRVN9QCR7REFUQUJBU0VfSE9TVDotcG9zdGdyZXNxbH0vJHtQT1NUR1JFU19EQjotY2FsZW5kc299JwogICAgICAtIENBTENPTV9URUxFTUVUUllfRElTQUJMRUQ9MQogICAgICAtICdFTUFJTF9GUk9NPSR7RU1BSUxfRlJPTX0nCiAgICAgIC0gJ0VNQUlMX0ZST01fTkFNRT0ke0VNQUlMX0ZST01fTkFNRX0nCiAgICAgIC0gJ0VNQUlMX1NFUlZFUl9IT1NUPSR7RU1BSUxfU0VSVkVSX0hPU1R9JwogICAgICAtICdFTUFJTF9TRVJWRVJfUE9SVD0ke0VNQUlMX1NFUlZFUl9QT1JUfScKICAgICAgLSAnRU1BSUxfU0VSVkVSX1VTRVI9JHtFTUFJTF9TRVJWRVJfVVNFUn0nCiAgICAgIC0gJ0VNQUlMX1NFUlZFUl9QQVNTV09SRD0ke0VNQUlMX1NFUlZFUl9QQVNTV09SRH0nCiAgICAgIC0gJ05FWFRfUFVCTElDX0FQUF9OQU1FPSJDYWwuY29tIicKICAgICAgLSAnQUxMT1dFRF9IT1NUTkFNRVM9WyIke1NFUlZJQ0VfRlFETl9DQUxDT019Il0nCiAgICBkZXBlbmRzX29uOgogICAgICAtIHBvc3RncmVzcWwKICBwb3N0Z3Jlc3FsOgogICAgaW1hZ2U6ICdwb3N0Z3JlczoxNi1hbHBpbmUnCiAgICBlbnZpcm9ubWVudDoKICAgICAgLSAnUE9TVEdSRVNfVVNFUj0ke1NFUlZJQ0VfVVNFUl9QT1NUR1JFU30nCiAgICAgIC0gJ1BPU1RHUkVTX1BBU1NXT1JEPSR7U0VSVklDRV9QQVNTV09SRF9QT1NUR1JFU30nCiAgICAgIC0gJ1BPU1RHUkVTX0RCPSR7UE9TVEdSRVNfREI6LWNhbGVuZHNvfScKICAgIHZvbHVtZXM6CiAgICAgIC0gJ2NhbGNvbS1wb3N0Z3Jlc3FsLWRhdGE6L3Zhci9saWIvcG9zdGdyZXNxbC9kYXRhJwogICAgaGVhbHRoY2hlY2s6CiAgICAgIHRlc3Q6CiAgICAgICAgLSBDTUQtU0hFTEwKICAgICAgICAtICdwZ19pc3JlYWR5IC1VICQke1BPU1RHUkVTX1VTRVJ9IC1kICQke1BPU1RHUkVTX0RCfScKICAgICAgaW50ZXJ2YWw6IDVzCiAgICAgIHRpbWVvdXQ6IDIwcwogICAgICByZXRyaWVzOiAxMAo=",
+ "tags": [
+ "calcom",
+ "calendso",
+ "scheduling",
+ "open",
+ "source"
+ ],
+ "logo": "svgs/calcom.svg",
+ "minversion": "0.0.0",
+ "port": "3000"
+ },
"castopod": {
"documentation": "https://docs.castopod.org/main/en/?utm_source=coolify.io",
"slogan": "Castopod is a free & open-source hosting platform made for podcasters who want engage and interact with their audience.",
@@ -407,28 +422,6 @@
"minversion": "0.0.0",
"port": "8080"
},
- "dify": {
- "documentation": "https://docs.dify.ai?utm_source=coolify.io",
- "slogan": "Dify is an open-source LLM app development platform. Dify's intuitive interface combines AI workflow, RAG pipeline, agent capabilities, model management, observability features and more, letting you quickly go from prototype to production.",
- "compose": "x-shared-env:
  LOG_LEVEL: '${LOG_LEVEL:-INFO}'
  DEBUG: '${DEBUG:-false}'
  FLASK_DEBUG: '${FLASK_DEBUG:-false}'
  CONSOLE_WEB_URL: '${CONSOLE_WEB_URL:-}'
  CONSOLE_API_URL: '${CONSOLE_API_URL:-}'
  SERVICE_API_URL: null
  APP_WEB_URL: '${APP_WEB_URL:-}'
  CHECK_UPDATE_URL: '${CHECK_UPDATE_URL:-https://updates.dify.ai}'
  OPENAI_API_BASE: '${OPENAI_API_BASE:-https://api.openai.com/v1}'
  FILES_URL: '${FILES_URL:-}'
  FILES_ACCESS_TIMEOUT: '${FILES_ACCESS_TIMEOUT:-300}'
  APP_MAX_ACTIVE_REQUESTS: '${APP_MAX_ACTIVE_REQUESTS:-0}'
  MIGRATION_ENABLED: '${MIGRATION_ENABLED:-true}'
  DEPLOY_ENV: '${DEPLOY_ENV:-PRODUCTION}'
  DIFY_BIND_ADDRESS: '${DIFY_BIND_ADDRESS:-0.0.0.0}'
  DIFY_PORT: '${DIFY_PORT:-5001}'
  SERVER_WORKER_AMOUNT: '${SERVER_WORKER_AMOUNT:-}'
  SERVER_WORKER_CLASS: '${SERVER_WORKER_CLASS:-}'
  CELERY_WORKER_CLASS: '${CELERY_WORKER_CLASS:-}'
  GUNICORN_TIMEOUT: '${GUNICORN_TIMEOUT:-360}'
  CELERY_WORKER_AMOUNT: '${CELERY_WORKER_AMOUNT:-}'
  CELERY_AUTO_SCALE: '${CELERY_AUTO_SCALE:-false}'
  CELERY_MAX_WORKERS: '${CELERY_MAX_WORKERS:-}'
  CELERY_MIN_WORKERS: '${CELERY_MIN_WORKERS:-}'
  API_TOOL_DEFAULT_CONNECT_TIMEOUT: '${API_TOOL_DEFAULT_CONNECT_TIMEOUT:-10}'
  API_TOOL_DEFAULT_READ_TIMEOUT: '${API_TOOL_DEFAULT_READ_TIMEOUT:-60}'
  DB_USERNAME: $SERVICE_USER_POSTGRES
  DB_PASSWORD: $SERVICE_PASSWORD_POSTGRES
  DB_HOST: '${DB_HOST:-db}'
  DB_PORT: '${DB_PORT:-5432}'
  DB_DATABASE: dify
  SQLALCHEMY_POOL_SIZE: '${SQLALCHEMY_POOL_SIZE:-30}'
  SQLALCHEMY_POOL_RECYCLE: '${SQLALCHEMY_POOL_RECYCLE:-3600}'
  SQLALCHEMY_ECHO: '${SQLALCHEMY_ECHO:-false}'
  POSTGRES_MAX_CONNECTIONS: '${POSTGRES_MAX_CONNECTIONS:-100}'
  POSTGRES_SHARED_BUFFERS: '${POSTGRES_SHARED_BUFFERS:-128MB}'
  POSTGRES_WORK_MEM: '${POSTGRES_WORK_MEM:-4MB}'
  POSTGRES_MAINTENANCE_WORK_MEM: '${POSTGRES_MAINTENANCE_WORK_MEM:-64MB}'
  POSTGRES_EFFECTIVE_CACHE_SIZE: '${POSTGRES_EFFECTIVE_CACHE_SIZE:-4096MB}'
  REDIS_HOST: '${REDIS_HOST:-redis}'
  REDIS_PORT: '${REDIS_PORT:-6379}'
  REDIS_USERNAME: '${REDIS_USERNAME:-}'
  REDIS_PASSWORD: $SERVICE_PASSWORD_REDIS
  REDIS_USE_SSL: '${REDIS_USE_SSL:-false}'
  REDIS_DB: 0
  CELERY_BROKER_URL: 'redis://:$SERVICE_PASSWORD_REDIS@redis:6379/1'
  BROKER_USE_SSL: '${BROKER_USE_SSL:-false}'
  WEB_API_CORS_ALLOW_ORIGINS: '${WEB_API_CORS_ALLOW_ORIGINS:-*}'
  CONSOLE_CORS_ALLOW_ORIGINS: '${CONSOLE_CORS_ALLOW_ORIGINS:-*}'
  STORAGE_TYPE: '${STORAGE_TYPE:-local}'
  STORAGE_LOCAL_PATH: storage
  S3_USE_AWS_MANAGED_IAM: '${S3_USE_AWS_MANAGED_IAM:-false}'
  S3_ENDPOINT: '${S3_ENDPOINT:-}'
  S3_BUCKET_NAME: '${S3_BUCKET_NAME:-}'
  S3_ACCESS_KEY: '${S3_ACCESS_KEY:-}'
  S3_SECRET_KEY: '${S3_SECRET_KEY:-}'
  S3_REGION: '${S3_REGION:-us-east-1}'
  AZURE_BLOB_ACCOUNT_NAME: '${AZURE_BLOB_ACCOUNT_NAME:-}'
  AZURE_BLOB_ACCOUNT_KEY: '${AZURE_BLOB_ACCOUNT_KEY:-}'
  AZURE_BLOB_CONTAINER_NAME: '${AZURE_BLOB_CONTAINER_NAME:-}'
  AZURE_BLOB_ACCOUNT_URL: '${AZURE_BLOB_ACCOUNT_URL:-}'
  GOOGLE_STORAGE_BUCKET_NAME: '${GOOGLE_STORAGE_BUCKET_NAME:-}'
  GOOGLE_STORAGE_SERVICE_ACCOUNT_JSON_BASE64: '${GOOGLE_STORAGE_SERVICE_ACCOUNT_JSON_BASE64:-}'
  ALIYUN_OSS_BUCKET_NAME: '${ALIYUN_OSS_BUCKET_NAME:-}'
  ALIYUN_OSS_ACCESS_KEY: '${ALIYUN_OSS_ACCESS_KEY:-}'
  ALIYUN_OSS_SECRET_KEY: '${ALIYUN_OSS_SECRET_KEY:-}'
  ALIYUN_OSS_ENDPOINT: '${ALIYUN_OSS_ENDPOINT:-}'
  ALIYUN_OSS_REGION: '${ALIYUN_OSS_REGION:-}'
  ALIYUN_OSS_AUTH_VERSION: '${ALIYUN_OSS_AUTH_VERSION:-v4}'
  TENCENT_COS_BUCKET_NAME: '${TENCENT_COS_BUCKET_NAME:-}'
  TENCENT_COS_SECRET_KEY: '${TENCENT_COS_SECRET_KEY:-}'
  TENCENT_COS_SECRET_ID: '${TENCENT_COS_SECRET_ID:-}'
  TENCENT_COS_REGION: '${TENCENT_COS_REGION:-}'
  TENCENT_COS_SCHEME: '${TENCENT_COS_SCHEME:-}'
  OCI_ENDPOINT: '${OCI_ENDPOINT:-}'
  OCI_BUCKET_NAME: '${OCI_BUCKET_NAME:-}'
  OCI_ACCESS_KEY: '${OCI_ACCESS_KEY:-}'
  OCI_SECRET_KEY: '${OCI_SECRET_KEY:-}'
  OCI_REGION: '${OCI_REGION:-}'
  VECTOR_STORE: '${VECTOR_STORE:-weaviate}'
  WEAVIATE_ENDPOINT: '${WEAVIATE_ENDPOINT:-http://weaviate:8080}'
  WEAVIATE_API_KEY: $SERVICE_PASSWORD_WEAVIATE
  RELYT_HOST: '${RELYT_HOST:-db}'
  RELYT_PORT: '${RELYT_PORT:-5432}'
  RELYT_USER: $SERVICE_USER_RELYT
  RELYT_PASSWORD: $SERVICE_PASSWORD_RELYT
  RELYT_DATABASE: '${RELYT_DATABASE:-postgres}'
  TIDB_VECTOR_HOST: '${TIDB_VECTOR_HOST:-tidb}'
  TIDB_VECTOR_PORT: '${TIDB_VECTOR_PORT:-4000}'
  TIDB_VECTOR_USER: $SERVICE_USER_TIDB
  TIDB_VECTOR_PASSWORD: $SERVICE_PASSWORD_TIDB
  TIDB_VECTOR_DATABASE: '${TIDB_VECTOR_DATABASE:-dify}'
  ANALYTICDB_KEY_ID: '${ANALYTICDB_KEY_ID:-}'
  ANALYTICDB_KEY_SECRET: '${ANALYTICDB_KEY_SECRET:-}'
  ANALYTICDB_REGION_ID: '${ANALYTICDB_REGION_ID:-}'
  ANALYTICDB_INSTANCE_ID: '${ANALYTICDB_INSTANCE_ID:-}'
  ANALYTICDB_ACCOUNT: '${ANALYTICDB_ACCOUNT:-}'
  ANALYTICDB_PASSWORD: '${ANALYTICDB_PASSWORD:-}'
  ANALYTICDB_NAMESPACE: '${ANALYTICDB_NAMESPACE:-dify}'
  ANALYTICDB_NAMESPACE_PASSWORD: '${ANALYTICDB_NAMESPACE_PASSWORD:-}'
  TENCENT_VECTOR_DB_URL: '${TENCENT_VECTOR_DB_URL:-http://127.0.0.1}'
  TENCENT_VECTOR_DB_API_KEY: '${TENCENT_VECTOR_DB_API_KEY:-dify}'
  TENCENT_VECTOR_DB_TIMEOUT: '${TENCENT_VECTOR_DB_TIMEOUT:-30}'
  TENCENT_VECTOR_DB_USERNAME: '${TENCENT_VECTOR_DB_USERNAME:-dify}'
  TENCENT_VECTOR_DB_DATABASE: '${TENCENT_VECTOR_DB_DATABASE:-dify}'
  TENCENT_VECTOR_DB_SHARD: '${TENCENT_VECTOR_DB_SHARD:-1}'
  TENCENT_VECTOR_DB_REPLICAS: '${TENCENT_VECTOR_DB_REPLICAS:-2}'
  UPLOAD_FILE_SIZE_LIMIT: '${UPLOAD_FILE_SIZE_LIMIT:-15}'
  UPLOAD_FILE_BATCH_LIMIT: '${UPLOAD_FILE_BATCH_LIMIT:-5}'
  ETL_TYPE: '${ETL_TYPE:-dify}'
  MULTIMODAL_SEND_IMAGE_FORMAT: '${MULTIMODAL_SEND_IMAGE_FORMAT:-base64}'
  UPLOAD_IMAGE_FILE_SIZE_LIMIT: '${UPLOAD_IMAGE_FILE_SIZE_LIMIT:-10}'
  SENTRY_DSN: '${API_SENTRY_DSN:-}'
  SENTRY_TRACES_SAMPLE_RATE: '${API_SENTRY_TRACES_SAMPLE_RATE:-1.0}'
  SENTRY_PROFILES_SAMPLE_RATE: '${API_SENTRY_PROFILES_SAMPLE_RATE:-1.0}'
  NOTION_INTEGRATION_TYPE: '${NOTION_INTEGRATION_TYPE:-public}'
  NOTION_CLIENT_SECRET: '${NOTION_CLIENT_SECRET:-}'
  NOTION_CLIENT_ID: '${NOTION_CLIENT_ID:-}'
  NOTION_INTERNAL_SECRET: '${NOTION_INTERNAL_SECRET:-}'
  MAIL_TYPE: '${MAIL_TYPE:-resend}'
  MAIL_DEFAULT_SEND_FROM: '${MAIL_DEFAULT_SEND_FROM:-}'
  SMTP_SERVER: '${SMTP_SERVER:-}'
  SMTP_PORT: '${SMTP_PORT:-465}'
  SMTP_USERNAME: '${SMTP_USERNAME:-}'
  SMTP_PASSWORD: '${SMTP_PASSWORD:-}'
  SMTP_USE_TLS: '${SMTP_USE_TLS:-true}'
  SMTP_OPPORTUNISTIC_TLS: '${SMTP_OPPORTUNISTIC_TLS:-false}'
  RESEND_API_KEY: '${RESEND_API_KEY:-your-resend-api-key}'
  RESEND_API_URL: 'https://api.resend.com'
  INDEXING_MAX_SEGMENTATION_TOKENS_LENGTH: '${INDEXING_MAX_SEGMENTATION_TOKENS_LENGTH:-1000}'
  INVITE_EXPIRY_HOURS: '${INVITE_EXPIRY_HOURS:-72}'
  RESET_PASSWORD_TOKEN_EXPIRY_HOURS: '${RESET_PASSWORD_TOKEN_EXPIRY_HOURS:-24}'
  CODE_EXECUTION_ENDPOINT: '${CODE_EXECUTION_ENDPOINT:-http://sandbox:8194}'
  CODE_EXECUTION_API_KEY: '${SANDBOX_API_KEY:-dify-sandbox}'
  CODE_MAX_NUMBER: '${CODE_MAX_NUMBER:-9223372036854775807}'
  CODE_MIN_NUMBER: '${CODE_MIN_NUMBER:--9223372036854775808}'
  CODE_MAX_STRING_LENGTH: '${CODE_MAX_STRING_LENGTH:-80000}'
  TEMPLATE_TRANSFORM_MAX_LENGTH: '${TEMPLATE_TRANSFORM_MAX_LENGTH:-80000}'
  CODE_MAX_STRING_ARRAY_LENGTH: '${CODE_MAX_STRING_ARRAY_LENGTH:-30}'
  CODE_MAX_OBJECT_ARRAY_LENGTH: '${CODE_MAX_OBJECT_ARRAY_LENGTH:-30}'
  CODE_MAX_NUMBER_ARRAY_LENGTH: '${CODE_MAX_NUMBER_ARRAY_LENGTH:-1000}'
  SSRF_PROXY_HTTP_URL: '${SSRF_PROXY_HTTP_URL:-http://ssrf_proxy:3128}'
  SSRF_PROXY_HTTPS_URL: '${SSRF_PROXY_HTTPS_URL:-http://ssrf_proxy:3128}'
services:
  api:
    image: 'langgenius/dify-api:latest'
    environment:
      SECRET_KEY: $SERVICE_PASSWORD_64_SECRETKEY
      INIT_PASSWORD: $SERVICE_USER_INITPASSWORD
      LOG_LEVEL: '${LOG_LEVEL:-INFO}'
      DEBUG: '${DEBUG:-false}'
      FLASK_DEBUG: '${FLASK_DEBUG:-false}'
      CONSOLE_WEB_URL: '${CONSOLE_WEB_URL:-}'
      CONSOLE_API_URL: '${CONSOLE_API_URL:-}'
      SERVICE_API_URL: null
      APP_WEB_URL: '${APP_WEB_URL:-}'
      CHECK_UPDATE_URL: '${CHECK_UPDATE_URL:-https://updates.dify.ai}'
      OPENAI_API_BASE: '${OPENAI_API_BASE:-https://api.openai.com/v1}'
      FILES_URL: '${FILES_URL:-}'
      FILES_ACCESS_TIMEOUT: '${FILES_ACCESS_TIMEOUT:-300}'
      APP_MAX_ACTIVE_REQUESTS: '${APP_MAX_ACTIVE_REQUESTS:-0}'
      MIGRATION_ENABLED: '${MIGRATION_ENABLED:-true}'
      DEPLOY_ENV: '${DEPLOY_ENV:-PRODUCTION}'
      DIFY_BIND_ADDRESS: '${DIFY_BIND_ADDRESS:-0.0.0.0}'
      DIFY_PORT: '${DIFY_PORT:-5001}'
      SERVER_WORKER_AMOUNT: '${SERVER_WORKER_AMOUNT:-}'
      SERVER_WORKER_CLASS: '${SERVER_WORKER_CLASS:-}'
      CELERY_WORKER_CLASS: '${CELERY_WORKER_CLASS:-}'
      GUNICORN_TIMEOUT: '${GUNICORN_TIMEOUT:-360}'
      CELERY_WORKER_AMOUNT: '${CELERY_WORKER_AMOUNT:-}'
      CELERY_AUTO_SCALE: '${CELERY_AUTO_SCALE:-false}'
      CELERY_MAX_WORKERS: '${CELERY_MAX_WORKERS:-}'
      CELERY_MIN_WORKERS: '${CELERY_MIN_WORKERS:-}'
      API_TOOL_DEFAULT_CONNECT_TIMEOUT: '${API_TOOL_DEFAULT_CONNECT_TIMEOUT:-10}'
      API_TOOL_DEFAULT_READ_TIMEOUT: '${API_TOOL_DEFAULT_READ_TIMEOUT:-60}'
      DB_USERNAME: $SERVICE_USER_POSTGRES
      DB_PASSWORD: $SERVICE_PASSWORD_POSTGRES
      DB_HOST: '${DB_HOST:-db}'
      DB_PORT: '${DB_PORT:-5432}'
      DB_DATABASE: dify
      SQLALCHEMY_POOL_SIZE: '${SQLALCHEMY_POOL_SIZE:-30}'
      SQLALCHEMY_POOL_RECYCLE: '${SQLALCHEMY_POOL_RECYCLE:-3600}'
      SQLALCHEMY_ECHO: '${SQLALCHEMY_ECHO:-false}'
      POSTGRES_MAX_CONNECTIONS: '${POSTGRES_MAX_CONNECTIONS:-100}'
      POSTGRES_SHARED_BUFFERS: '${POSTGRES_SHARED_BUFFERS:-128MB}'
      POSTGRES_WORK_MEM: '${POSTGRES_WORK_MEM:-4MB}'
      POSTGRES_MAINTENANCE_WORK_MEM: '${POSTGRES_MAINTENANCE_WORK_MEM:-64MB}'
      POSTGRES_EFFECTIVE_CACHE_SIZE: '${POSTGRES_EFFECTIVE_CACHE_SIZE:-4096MB}'
      REDIS_HOST: '${REDIS_HOST:-redis}'
      REDIS_PORT: '${REDIS_PORT:-6379}'
      REDIS_USERNAME: '${REDIS_USERNAME:-}'
      REDIS_PASSWORD: $SERVICE_PASSWORD_REDIS
      REDIS_USE_SSL: '${REDIS_USE_SSL:-false}'
      REDIS_DB: 0
      CELERY_BROKER_URL: 'redis://:$SERVICE_PASSWORD_REDIS@redis:6379/1'
      BROKER_USE_SSL: '${BROKER_USE_SSL:-false}'
      WEB_API_CORS_ALLOW_ORIGINS: '${WEB_API_CORS_ALLOW_ORIGINS:-*}'
      CONSOLE_CORS_ALLOW_ORIGINS: '${CONSOLE_CORS_ALLOW_ORIGINS:-*}'
      STORAGE_TYPE: '${STORAGE_TYPE:-local}'
      STORAGE_LOCAL_PATH: storage
      S3_USE_AWS_MANAGED_IAM: '${S3_USE_AWS_MANAGED_IAM:-false}'
      S3_ENDPOINT: '${S3_ENDPOINT:-}'
      S3_BUCKET_NAME: '${S3_BUCKET_NAME:-}'
      S3_ACCESS_KEY: '${S3_ACCESS_KEY:-}'
      S3_SECRET_KEY: '${S3_SECRET_KEY:-}'
      S3_REGION: '${S3_REGION:-us-east-1}'
      AZURE_BLOB_ACCOUNT_NAME: '${AZURE_BLOB_ACCOUNT_NAME:-}'
      AZURE_BLOB_ACCOUNT_KEY: '${AZURE_BLOB_ACCOUNT_KEY:-}'
      AZURE_BLOB_CONTAINER_NAME: '${AZURE_BLOB_CONTAINER_NAME:-}'
      AZURE_BLOB_ACCOUNT_URL: '${AZURE_BLOB_ACCOUNT_URL:-}'
      GOOGLE_STORAGE_BUCKET_NAME: '${GOOGLE_STORAGE_BUCKET_NAME:-}'
      GOOGLE_STORAGE_SERVICE_ACCOUNT_JSON_BASE64: '${GOOGLE_STORAGE_SERVICE_ACCOUNT_JSON_BASE64:-}'
      ALIYUN_OSS_BUCKET_NAME: '${ALIYUN_OSS_BUCKET_NAME:-}'
      ALIYUN_OSS_ACCESS_KEY: '${ALIYUN_OSS_ACCESS_KEY:-}'
      ALIYUN_OSS_SECRET_KEY: '${ALIYUN_OSS_SECRET_KEY:-}'
      ALIYUN_OSS_ENDPOINT: '${ALIYUN_OSS_ENDPOINT:-}'
      ALIYUN_OSS_REGION: '${ALIYUN_OSS_REGION:-}'
      ALIYUN_OSS_AUTH_VERSION: '${ALIYUN_OSS_AUTH_VERSION:-v4}'
      TENCENT_COS_BUCKET_NAME: '${TENCENT_COS_BUCKET_NAME:-}'
      TENCENT_COS_SECRET_KEY: '${TENCENT_COS_SECRET_KEY:-}'
      TENCENT_COS_SECRET_ID: '${TENCENT_COS_SECRET_ID:-}'
      TENCENT_COS_REGION: '${TENCENT_COS_REGION:-}'
      TENCENT_COS_SCHEME: '${TENCENT_COS_SCHEME:-}'
      OCI_ENDPOINT: '${OCI_ENDPOINT:-}'
      OCI_BUCKET_NAME: '${OCI_BUCKET_NAME:-}'
      OCI_ACCESS_KEY: '${OCI_ACCESS_KEY:-}'
      OCI_SECRET_KEY: '${OCI_SECRET_KEY:-}'
      OCI_REGION: '${OCI_REGION:-}'
      VECTOR_STORE: '${VECTOR_STORE:-weaviate}'
      WEAVIATE_ENDPOINT: '${WEAVIATE_ENDPOINT:-http://weaviate:8080}'
      WEAVIATE_API_KEY: $SERVICE_PASSWORD_WEAVIATE
      RELYT_HOST: '${RELYT_HOST:-db}'
      RELYT_PORT: '${RELYT_PORT:-5432}'
      RELYT_USER: $SERVICE_USER_RELYT
      RELYT_PASSWORD: $SERVICE_PASSWORD_RELYT
      RELYT_DATABASE: '${RELYT_DATABASE:-postgres}'
      TIDB_VECTOR_HOST: '${TIDB_VECTOR_HOST:-tidb}'
      TIDB_VECTOR_PORT: '${TIDB_VECTOR_PORT:-4000}'
      TIDB_VECTOR_USER: $SERVICE_USER_TIDB
      TIDB_VECTOR_PASSWORD: $SERVICE_PASSWORD_TIDB
      TIDB_VECTOR_DATABASE: '${TIDB_VECTOR_DATABASE:-dify}'
      ANALYTICDB_KEY_ID: '${ANALYTICDB_KEY_ID:-}'
      ANALYTICDB_KEY_SECRET: '${ANALYTICDB_KEY_SECRET:-}'
      ANALYTICDB_REGION_ID: '${ANALYTICDB_REGION_ID:-}'
      ANALYTICDB_INSTANCE_ID: '${ANALYTICDB_INSTANCE_ID:-}'
      ANALYTICDB_ACCOUNT: '${ANALYTICDB_ACCOUNT:-}'
      ANALYTICDB_PASSWORD: '${ANALYTICDB_PASSWORD:-}'
      ANALYTICDB_NAMESPACE: '${ANALYTICDB_NAMESPACE:-dify}'
      ANALYTICDB_NAMESPACE_PASSWORD: '${ANALYTICDB_NAMESPACE_PASSWORD:-}'
      TENCENT_VECTOR_DB_URL: '${TENCENT_VECTOR_DB_URL:-http://127.0.0.1}'
      TENCENT_VECTOR_DB_API_KEY: '${TENCENT_VECTOR_DB_API_KEY:-dify}'
      TENCENT_VECTOR_DB_TIMEOUT: '${TENCENT_VECTOR_DB_TIMEOUT:-30}'
      TENCENT_VECTOR_DB_USERNAME: '${TENCENT_VECTOR_DB_USERNAME:-dify}'
      TENCENT_VECTOR_DB_DATABASE: '${TENCENT_VECTOR_DB_DATABASE:-dify}'
      TENCENT_VECTOR_DB_SHARD: '${TENCENT_VECTOR_DB_SHARD:-1}'
      TENCENT_VECTOR_DB_REPLICAS: '${TENCENT_VECTOR_DB_REPLICAS:-2}'
      UPLOAD_FILE_SIZE_LIMIT: '${UPLOAD_FILE_SIZE_LIMIT:-15}'
      UPLOAD_FILE_BATCH_LIMIT: '${UPLOAD_FILE_BATCH_LIMIT:-5}'
      ETL_TYPE: '${ETL_TYPE:-dify}'
      MULTIMODAL_SEND_IMAGE_FORMAT: '${MULTIMODAL_SEND_IMAGE_FORMAT:-base64}'
      UPLOAD_IMAGE_FILE_SIZE_LIMIT: '${UPLOAD_IMAGE_FILE_SIZE_LIMIT:-10}'
      SENTRY_DSN: '${API_SENTRY_DSN:-}'
      SENTRY_TRACES_SAMPLE_RATE: '${API_SENTRY_TRACES_SAMPLE_RATE:-1.0}'
      SENTRY_PROFILES_SAMPLE_RATE: '${API_SENTRY_PROFILES_SAMPLE_RATE:-1.0}'
      NOTION_INTEGRATION_TYPE: '${NOTION_INTEGRATION_TYPE:-public}'
      NOTION_CLIENT_SECRET: '${NOTION_CLIENT_SECRET:-}'
      NOTION_CLIENT_ID: '${NOTION_CLIENT_ID:-}'
      NOTION_INTERNAL_SECRET: '${NOTION_INTERNAL_SECRET:-}'
      MAIL_TYPE: '${MAIL_TYPE:-resend}'
      MAIL_DEFAULT_SEND_FROM: '${MAIL_DEFAULT_SEND_FROM:-}'
      SMTP_SERVER: '${SMTP_SERVER:-}'
      SMTP_PORT: '${SMTP_PORT:-465}'
      SMTP_USERNAME: '${SMTP_USERNAME:-}'
      SMTP_PASSWORD: '${SMTP_PASSWORD:-}'
      SMTP_USE_TLS: '${SMTP_USE_TLS:-true}'
      SMTP_OPPORTUNISTIC_TLS: '${SMTP_OPPORTUNISTIC_TLS:-false}'
      RESEND_API_KEY: '${RESEND_API_KEY:-your-resend-api-key}'
      RESEND_API_URL: 'https://api.resend.com'
      INDEXING_MAX_SEGMENTATION_TOKENS_LENGTH: '${INDEXING_MAX_SEGMENTATION_TOKENS_LENGTH:-1000}'
      INVITE_EXPIRY_HOURS: '${INVITE_EXPIRY_HOURS:-72}'
      RESET_PASSWORD_TOKEN_EXPIRY_HOURS: '${RESET_PASSWORD_TOKEN_EXPIRY_HOURS:-24}'
      CODE_EXECUTION_ENDPOINT: '${CODE_EXECUTION_ENDPOINT:-http://sandbox:8194}'
      CODE_EXECUTION_API_KEY: '${SANDBOX_API_KEY:-dify-sandbox}'
      CODE_MAX_NUMBER: '${CODE_MAX_NUMBER:-9223372036854775807}'
      CODE_MIN_NUMBER: '${CODE_MIN_NUMBER:--9223372036854775808}'
      CODE_MAX_STRING_LENGTH: '${CODE_MAX_STRING_LENGTH:-80000}'
      TEMPLATE_TRANSFORM_MAX_LENGTH: '${TEMPLATE_TRANSFORM_MAX_LENGTH:-80000}'
      CODE_MAX_STRING_ARRAY_LENGTH: '${CODE_MAX_STRING_ARRAY_LENGTH:-30}'
      CODE_MAX_OBJECT_ARRAY_LENGTH: '${CODE_MAX_OBJECT_ARRAY_LENGTH:-30}'
      CODE_MAX_NUMBER_ARRAY_LENGTH: '${CODE_MAX_NUMBER_ARRAY_LENGTH:-1000}'
      SSRF_PROXY_HTTP_URL: '${SSRF_PROXY_HTTP_URL:-http://ssrf_proxy:3128}'
      SSRF_PROXY_HTTPS_URL: '${SSRF_PROXY_HTTPS_URL:-http://ssrf_proxy:3128}'
      MODE: api
    depends_on:
      db:
        condition: service_healthy
      redis:
        condition: service_healthy
    volumes:
      - 'dify-storage:/app/api/storage'
    networks:
      - ssrf_proxy_network
      - default
    healthcheck:
      test:
        - CMD
        - curl
        - '-f'
        - 'http://localhost:5001/health'
      interval: 30s
      timeout: 10s
      retries: 3
      start_period: 40s
  worker:
    image: 'langgenius/dify-api:latest'
    environment:
      LOG_LEVEL: '${LOG_LEVEL:-INFO}'
      DEBUG: '${DEBUG:-false}'
      FLASK_DEBUG: '${FLASK_DEBUG:-false}'
      CONSOLE_WEB_URL: '${CONSOLE_WEB_URL:-}'
      CONSOLE_API_URL: '${CONSOLE_API_URL:-}'
      SERVICE_API_URL: null
      APP_WEB_URL: '${APP_WEB_URL:-}'
      CHECK_UPDATE_URL: '${CHECK_UPDATE_URL:-https://updates.dify.ai}'
      OPENAI_API_BASE: '${OPENAI_API_BASE:-https://api.openai.com/v1}'
      FILES_URL: '${FILES_URL:-}'
      FILES_ACCESS_TIMEOUT: '${FILES_ACCESS_TIMEOUT:-300}'
      APP_MAX_ACTIVE_REQUESTS: '${APP_MAX_ACTIVE_REQUESTS:-0}'
      MIGRATION_ENABLED: '${MIGRATION_ENABLED:-true}'
      DEPLOY_ENV: '${DEPLOY_ENV:-PRODUCTION}'
      DIFY_BIND_ADDRESS: '${DIFY_BIND_ADDRESS:-0.0.0.0}'
      DIFY_PORT: '${DIFY_PORT:-5001}'
      SERVER_WORKER_AMOUNT: '${SERVER_WORKER_AMOUNT:-}'
      SERVER_WORKER_CLASS: '${SERVER_WORKER_CLASS:-}'
      CELERY_WORKER_CLASS: '${CELERY_WORKER_CLASS:-}'
      GUNICORN_TIMEOUT: '${GUNICORN_TIMEOUT:-360}'
      CELERY_WORKER_AMOUNT: '${CELERY_WORKER_AMOUNT:-}'
      CELERY_AUTO_SCALE: '${CELERY_AUTO_SCALE:-false}'
      CELERY_MAX_WORKERS: '${CELERY_MAX_WORKERS:-}'
      CELERY_MIN_WORKERS: '${CELERY_MIN_WORKERS:-}'
      API_TOOL_DEFAULT_CONNECT_TIMEOUT: '${API_TOOL_DEFAULT_CONNECT_TIMEOUT:-10}'
      API_TOOL_DEFAULT_READ_TIMEOUT: '${API_TOOL_DEFAULT_READ_TIMEOUT:-60}'
      DB_USERNAME: $SERVICE_USER_POSTGRES
      DB_PASSWORD: $SERVICE_PASSWORD_POSTGRES
      DB_HOST: '${DB_HOST:-db}'
      DB_PORT: '${DB_PORT:-5432}'
      DB_DATABASE: dify
      SQLALCHEMY_POOL_SIZE: '${SQLALCHEMY_POOL_SIZE:-30}'
      SQLALCHEMY_POOL_RECYCLE: '${SQLALCHEMY_POOL_RECYCLE:-3600}'
      SQLALCHEMY_ECHO: '${SQLALCHEMY_ECHO:-false}'
      POSTGRES_MAX_CONNECTIONS: '${POSTGRES_MAX_CONNECTIONS:-100}'
      POSTGRES_SHARED_BUFFERS: '${POSTGRES_SHARED_BUFFERS:-128MB}'
      POSTGRES_WORK_MEM: '${POSTGRES_WORK_MEM:-4MB}'
      POSTGRES_MAINTENANCE_WORK_MEM: '${POSTGRES_MAINTENANCE_WORK_MEM:-64MB}'
      POSTGRES_EFFECTIVE_CACHE_SIZE: '${POSTGRES_EFFECTIVE_CACHE_SIZE:-4096MB}'
      REDIS_HOST: '${REDIS_HOST:-redis}'
      REDIS_PORT: '${REDIS_PORT:-6379}'
      REDIS_USERNAME: '${REDIS_USERNAME:-}'
      REDIS_PASSWORD: $SERVICE_PASSWORD_REDIS
      REDIS_USE_SSL: '${REDIS_USE_SSL:-false}'
      REDIS_DB: 0
      CELERY_BROKER_URL: 'redis://:$SERVICE_PASSWORD_REDIS@redis:6379/1'
      BROKER_USE_SSL: '${BROKER_USE_SSL:-false}'
      WEB_API_CORS_ALLOW_ORIGINS: '${WEB_API_CORS_ALLOW_ORIGINS:-*}'
      CONSOLE_CORS_ALLOW_ORIGINS: '${CONSOLE_CORS_ALLOW_ORIGINS:-*}'
      STORAGE_TYPE: '${STORAGE_TYPE:-local}'
      STORAGE_LOCAL_PATH: storage
      S3_USE_AWS_MANAGED_IAM: '${S3_USE_AWS_MANAGED_IAM:-false}'
      S3_ENDPOINT: '${S3_ENDPOINT:-}'
      S3_BUCKET_NAME: '${S3_BUCKET_NAME:-}'
      S3_ACCESS_KEY: '${S3_ACCESS_KEY:-}'
      S3_SECRET_KEY: '${S3_SECRET_KEY:-}'
      S3_REGION: '${S3_REGION:-us-east-1}'
      AZURE_BLOB_ACCOUNT_NAME: '${AZURE_BLOB_ACCOUNT_NAME:-}'
      AZURE_BLOB_ACCOUNT_KEY: '${AZURE_BLOB_ACCOUNT_KEY:-}'
      AZURE_BLOB_CONTAINER_NAME: '${AZURE_BLOB_CONTAINER_NAME:-}'
      AZURE_BLOB_ACCOUNT_URL: '${AZURE_BLOB_ACCOUNT_URL:-}'
      GOOGLE_STORAGE_BUCKET_NAME: '${GOOGLE_STORAGE_BUCKET_NAME:-}'
      GOOGLE_STORAGE_SERVICE_ACCOUNT_JSON_BASE64: '${GOOGLE_STORAGE_SERVICE_ACCOUNT_JSON_BASE64:-}'
      ALIYUN_OSS_BUCKET_NAME: '${ALIYUN_OSS_BUCKET_NAME:-}'
      ALIYUN_OSS_ACCESS_KEY: '${ALIYUN_OSS_ACCESS_KEY:-}'
      ALIYUN_OSS_SECRET_KEY: '${ALIYUN_OSS_SECRET_KEY:-}'
      ALIYUN_OSS_ENDPOINT: '${ALIYUN_OSS_ENDPOINT:-}'
      ALIYUN_OSS_REGION: '${ALIYUN_OSS_REGION:-}'
      ALIYUN_OSS_AUTH_VERSION: '${ALIYUN_OSS_AUTH_VERSION:-v4}'
      TENCENT_COS_BUCKET_NAME: '${TENCENT_COS_BUCKET_NAME:-}'
      TENCENT_COS_SECRET_KEY: '${TENCENT_COS_SECRET_KEY:-}'
      TENCENT_COS_SECRET_ID: '${TENCENT_COS_SECRET_ID:-}'
      TENCENT_COS_REGION: '${TENCENT_COS_REGION:-}'
      TENCENT_COS_SCHEME: '${TENCENT_COS_SCHEME:-}'
      OCI_ENDPOINT: '${OCI_ENDPOINT:-}'
      OCI_BUCKET_NAME: '${OCI_BUCKET_NAME:-}'
      OCI_ACCESS_KEY: '${OCI_ACCESS_KEY:-}'
      OCI_SECRET_KEY: '${OCI_SECRET_KEY:-}'
      OCI_REGION: '${OCI_REGION:-}'
      VECTOR_STORE: '${VECTOR_STORE:-weaviate}'
      WEAVIATE_ENDPOINT: '${WEAVIATE_ENDPOINT:-http://weaviate:8080}'
      WEAVIATE_API_KEY: $SERVICE_PASSWORD_WEAVIATE
      RELYT_HOST: '${RELYT_HOST:-db}'
      RELYT_PORT: '${RELYT_PORT:-5432}'
      RELYT_USER: $SERVICE_USER_RELYT
      RELYT_PASSWORD: $SERVICE_PASSWORD_RELYT
      RELYT_DATABASE: '${RELYT_DATABASE:-postgres}'
      TIDB_VECTOR_HOST: '${TIDB_VECTOR_HOST:-tidb}'
      TIDB_VECTOR_PORT: '${TIDB_VECTOR_PORT:-4000}'
      TIDB_VECTOR_USER: $SERVICE_USER_TIDB
      TIDB_VECTOR_PASSWORD: $SERVICE_PASSWORD_TIDB
      TIDB_VECTOR_DATABASE: '${TIDB_VECTOR_DATABASE:-dify}'
      ANALYTICDB_KEY_ID: '${ANALYTICDB_KEY_ID:-}'
      ANALYTICDB_KEY_SECRET: '${ANALYTICDB_KEY_SECRET:-}'
      ANALYTICDB_REGION_ID: '${ANALYTICDB_REGION_ID:-}'
      ANALYTICDB_INSTANCE_ID: '${ANALYTICDB_INSTANCE_ID:-}'
      ANALYTICDB_ACCOUNT: '${ANALYTICDB_ACCOUNT:-}'
      ANALYTICDB_PASSWORD: '${ANALYTICDB_PASSWORD:-}'
      ANALYTICDB_NAMESPACE: '${ANALYTICDB_NAMESPACE:-dify}'
      ANALYTICDB_NAMESPACE_PASSWORD: '${ANALYTICDB_NAMESPACE_PASSWORD:-}'
      TENCENT_VECTOR_DB_URL: '${TENCENT_VECTOR_DB_URL:-http://127.0.0.1}'
      TENCENT_VECTOR_DB_API_KEY: '${TENCENT_VECTOR_DB_API_KEY:-dify}'
      TENCENT_VECTOR_DB_TIMEOUT: '${TENCENT_VECTOR_DB_TIMEOUT:-30}'
      TENCENT_VECTOR_DB_USERNAME: '${TENCENT_VECTOR_DB_USERNAME:-dify}'
      TENCENT_VECTOR_DB_DATABASE: '${TENCENT_VECTOR_DB_DATABASE:-dify}'
      TENCENT_VECTOR_DB_SHARD: '${TENCENT_VECTOR_DB_SHARD:-1}'
      TENCENT_VECTOR_DB_REPLICAS: '${TENCENT_VECTOR_DB_REPLICAS:-2}'
      UPLOAD_FILE_SIZE_LIMIT: '${UPLOAD_FILE_SIZE_LIMIT:-15}'
      UPLOAD_FILE_BATCH_LIMIT: '${UPLOAD_FILE_BATCH_LIMIT:-5}'
      ETL_TYPE: '${ETL_TYPE:-dify}'
      MULTIMODAL_SEND_IMAGE_FORMAT: '${MULTIMODAL_SEND_IMAGE_FORMAT:-base64}'
      UPLOAD_IMAGE_FILE_SIZE_LIMIT: '${UPLOAD_IMAGE_FILE_SIZE_LIMIT:-10}'
      SENTRY_DSN: '${API_SENTRY_DSN:-}'
      SENTRY_TRACES_SAMPLE_RATE: '${API_SENTRY_TRACES_SAMPLE_RATE:-1.0}'
      SENTRY_PROFILES_SAMPLE_RATE: '${API_SENTRY_PROFILES_SAMPLE_RATE:-1.0}'
      NOTION_INTEGRATION_TYPE: '${NOTION_INTEGRATION_TYPE:-public}'
      NOTION_CLIENT_SECRET: '${NOTION_CLIENT_SECRET:-}'
      NOTION_CLIENT_ID: '${NOTION_CLIENT_ID:-}'
      NOTION_INTERNAL_SECRET: '${NOTION_INTERNAL_SECRET:-}'
      MAIL_TYPE: '${MAIL_TYPE:-resend}'
      MAIL_DEFAULT_SEND_FROM: '${MAIL_DEFAULT_SEND_FROM:-}'
      SMTP_SERVER: '${SMTP_SERVER:-}'
      SMTP_PORT: '${SMTP_PORT:-465}'
      SMTP_USERNAME: '${SMTP_USERNAME:-}'
      SMTP_PASSWORD: '${SMTP_PASSWORD:-}'
      SMTP_USE_TLS: '${SMTP_USE_TLS:-true}'
      SMTP_OPPORTUNISTIC_TLS: '${SMTP_OPPORTUNISTIC_TLS:-false}'
      RESEND_API_KEY: '${RESEND_API_KEY:-your-resend-api-key}'
      RESEND_API_URL: 'https://api.resend.com'
      INDEXING_MAX_SEGMENTATION_TOKENS_LENGTH: '${INDEXING_MAX_SEGMENTATION_TOKENS_LENGTH:-1000}'
      INVITE_EXPIRY_HOURS: '${INVITE_EXPIRY_HOURS:-72}'
      RESET_PASSWORD_TOKEN_EXPIRY_HOURS: '${RESET_PASSWORD_TOKEN_EXPIRY_HOURS:-24}'
      CODE_EXECUTION_ENDPOINT: '${CODE_EXECUTION_ENDPOINT:-http://sandbox:8194}'
      CODE_EXECUTION_API_KEY: '${SANDBOX_API_KEY:-dify-sandbox}'
      CODE_MAX_NUMBER: '${CODE_MAX_NUMBER:-9223372036854775807}'
      CODE_MIN_NUMBER: '${CODE_MIN_NUMBER:--9223372036854775808}'
      CODE_MAX_STRING_LENGTH: '${CODE_MAX_STRING_LENGTH:-80000}'
      TEMPLATE_TRANSFORM_MAX_LENGTH: '${TEMPLATE_TRANSFORM_MAX_LENGTH:-80000}'
      CODE_MAX_STRING_ARRAY_LENGTH: '${CODE_MAX_STRING_ARRAY_LENGTH:-30}'
      CODE_MAX_OBJECT_ARRAY_LENGTH: '${CODE_MAX_OBJECT_ARRAY_LENGTH:-30}'
      CODE_MAX_NUMBER_ARRAY_LENGTH: '${CODE_MAX_NUMBER_ARRAY_LENGTH:-1000}'
      SSRF_PROXY_HTTP_URL: '${SSRF_PROXY_HTTP_URL:-http://ssrf_proxy:3128}'
      SSRF_PROXY_HTTPS_URL: '${SSRF_PROXY_HTTPS_URL:-http://ssrf_proxy:3128}'
      MODE: worker
    depends_on:
      db:
        condition: service_healthy
      redis:
        condition: service_healthy
    volumes:
      - 'dify-storage:/app/api/storage'
    networks:
      - ssrf_proxy_network
      - default
    healthcheck:
      test:
        - CMD-SHELL
        - 'celery inspect ping'
      interval: 30s
      timeout: 10s
      retries: 3
      start_period: 40s
  web:
    image: 'langgenius/dify-web:latest'
    environment:
      - SERVICE_FQDN_WEB_3000
      - 'CONSOLE_API_URL=${SERVICE_FQDN_WEB}'
      - 'APP_API_URL=${SERVICE_FQDN_API}'
      - 'SENTRY_DSN=${WEB_SENTRY_DSN:-}'
      - 'NEXT_TELEMETRY_DISABLED=${NEXT_TELEMETRY_DISABLED:-0}'
    healthcheck:
      test:
        - CMD
        - wget
        - '--spider'
        - '-q'
        - 'http://web:3000'
      interval: 30s
      timeout: 10s
      retries: 3
      start_period: 40s
  db:
    image: 'postgres:15-alpine'
    environment:
      POSTGRES_USER: $SERVICE_USER_POSTGRES
      POSTGRES_PASSWORD: $SERVICE_PASSWORD_POSTGRES
      POSTGRES_DB: dify
      PGDATA: /var/lib/postgresql/data/pgdata
    command: "postgres -c 'max_connections=${POSTGRES_MAX_CONNECTIONS:-100}'\n         -c 'shared_buffers=${POSTGRES_SHARED_BUFFERS:-128MB}'\n         -c 'work_mem=${POSTGRES_WORK_MEM:-4MB}'\n         -c 'maintenance_work_mem=${POSTGRES_MAINTENANCE_WORK_MEM:-64MB}'\n         -c 'effective_cache_size=${POSTGRES_EFFECTIVE_CACHE_SIZE:-4096MB}'\n"
    volumes:
      - 'dify-db-data:/var/lib/postgresql/data'
    healthcheck:
      test:
        - CMD
        - pg_isready
        - '-U'
        - $SERVICE_USER_POSTGRES
        - '-d'
        - dify
      interval: 10s
      timeout: 5s
      retries: 5
  redis:
    image: 'redis:6-alpine'
    environment:
      REDIS_PASSWORD: $SERVICE_PASSWORD_REDIS
    volumes:
      - 'dify-redis-data:/data'
    command: 'redis-server --requirepass "$SERVICE_PASSWORD_REDIS"'
    healthcheck:
      test:
        - CMD
        - redis-cli
        - '-a'
        - $SERVICE_PASSWORD_REDIS
        - ping
  sandbox:
    image: 'langgenius/dify-sandbox:latest'
    restart: always
    environment:
      API_KEY: '${SANDBOX_API_KEY:-dify-sandbox}'
      GIN_MODE: '${SANDBOX_GIN_MODE:-release}'
      WORKER_TIMEOUT: '${SANDBOX_WORKER_TIMEOUT:-15}'
      ENABLE_NETWORK: '${SANDBOX_ENABLE_NETWORK:-true}'
      HTTP_PROXY: '${SANDBOX_HTTP_PROXY:-http://ssrf_proxy:3128}'
      HTTPS_PROXY: '${SANDBOX_HTTPS_PROXY:-http://ssrf_proxy:3128}'
      SANDBOX_PORT: '${SANDBOX_PORT:-8194}'
    volumes:
      - './volumes/sandbox/dependencies:/dependencies'
    networks:
      - ssrf_proxy_network
      - default
    healthcheck:
      test:
        - CMD-SHELL
        - "bash -c ':> /dev/tcp/127.0.0.1/8194' || exit 1"
      interval: 5s
      timeout: 20s
      retries: 3
  ssrf_proxy:
    image: 'ubuntu/squid:latest'
    volumes:
      -
        type: bind
        source: ./ssrf_proxy/squid.conf.template
        target: /etc/squid/squid.conf.template
        read_only: true
        content: "acl localnet src 0.0.0.1-0.255.255.255\t# RFC 1122 \"this\" network (LAN)\nacl localnet src 10.0.0.0/8\t\t# RFC 1918 local private network (LAN)\nacl localnet src 100.64.0.0/10\t\t# RFC 6598 shared address space (CGN)\nacl localnet src 169.254.0.0/16 \t# RFC 3927 link-local (directly plugged) machines\nacl localnet src 172.16.0.0/12\t\t# RFC 1918 local private network (LAN)\nacl localnet src 192.168.0.0/16\t\t# RFC 1918 local private network (LAN)\nacl localnet src fc00::/7       \t# RFC 4193 local private network range\nacl localnet src fe80::/10      \t# RFC 4291 link-local (directly plugged) machines\nacl SSL_ports port 443\nacl Safe_ports port 80\t\t# http\nacl Safe_ports port 21\t\t# ftp\nacl Safe_ports port 443\t\t# https\nacl Safe_ports port 70\t\t# gopher\nacl Safe_ports port 210\t\t# wais\nacl Safe_ports port 1025-65535\t# unregistered ports\nacl Safe_ports port 280\t\t# http-mgmt\nacl Safe_ports port 488\t\t# gss-http\nacl Safe_ports port 591\t\t# filemaker\nacl Safe_ports port 777\t\t# multiling http\nacl CONNECT method CONNECT\nhttp_access deny !Safe_ports\nhttp_access deny CONNECT !SSL_ports\nhttp_access allow localhost manager\nhttp_access deny manager\nhttp_access allow localhost\ninclude /etc/squid/conf.d/*.conf\nhttp_access deny all\n\n################################## Proxy Server ################################\nhttp_port 3128\ncoredump_dir ${COREDUMP_DIR}\nrefresh_pattern ^ftp:\t\t1440\t20%\t10080\nrefresh_pattern ^gopher:\t1440\t0%\t1440\nrefresh_pattern -i (/cgi-bin/|\\?) 0\t0%\t0\nrefresh_pattern \\/(Packages|Sources)(|\\.bz2|\\.gz|\\.xz)$ 0 0% 0 refresh-ims\nrefresh_pattern \\/Release(|\\.gpg)$ 0 0% 0 refresh-ims\nrefresh_pattern \\/InRelease$ 0 0% 0 refresh-ims\nrefresh_pattern \\/(Translation-.*)(|\\.bz2|\\.gz|\\.xz)$ 0 0% 0 refresh-ims\nrefresh_pattern .\t\t0\t20%\t4320\n\n\n# cache_dir ufs /var/spool/squid 100 16 256\n# upstream proxy, set to your own upstream proxy IP to avoid SSRF attacks\n# cache_peer 172.1.1.1 parent 3128 0 no-query no-digest no-netdb-exchange default \n\n################################## Reverse Proxy To Sandbox ################################\nhttp_port 3129 accel vhost\ncache_peer ${SANDBOX_HOST} parent ${SANDBOX_PORT} 0 no-query originserver\nacl src_all src all\nhttp_access allow src_all\n"
      -
        type: bind
        source: ./ssrf_proxy/docker-entrypoint.sh
        target: /docker-entrypoint.sh
        read_only: true
        content: "#!/bin/bash\n\n# Modified based on Squid OCI image entrypoint\n\n# This entrypoint aims to forward the squid logs to stdout to assist users of\n# common container related tooling (e.g., kubernetes, docker-compose, etc) to\n# access the service logs.\n\n# Moreover, it invokes the squid binary, leaving all the desired parameters to\n# be provided by the \"command\" passed to the spawned container. If no command\n# is provided by the user, the default behavior (as per the CMD statement in\n# the Dockerfile) will be to use Ubuntu's default configuration [1] and run\n# squid with the \"-NYC\" options to mimic the behavior of the Ubuntu provided\n# systemd unit.\n\n# [1] The default configuration is changed in the Dockerfile to allow local\n# network connections. See the Dockerfile for further information.\n\necho \"[ENTRYPOINT] re-create snakeoil self-signed certificate removed in the build process\"\nif [ ! -f /etc/ssl/private/ssl-cert-snakeoil.key ]; then\n    /usr/sbin/make-ssl-cert generate-default-snakeoil --force-overwrite > /dev/null 2>&1\nfi\n\ntail -F /var/log/squid/access.log 2>/dev/null &\ntail -F /var/log/squid/error.log 2>/dev/null &\ntail -F /var/log/squid/store.log 2>/dev/null &\ntail -F /var/log/squid/cache.log 2>/dev/null &\n\n# Replace environment variables in the template and output to the squid.conf\necho \"[ENTRYPOINT] replacing environment variables in the template\"\nawk '{\n    while(match($0, /\\${[A-Za-z_][A-Za-z_0-9]*}/)) {\n        var = substr($0, RSTART+2, RLENGTH-3)\n        val = ENVIRON[var]\n        $0 = substr($0, 1, RSTART-1) val substr($0, RSTART+RLENGTH)\n    }\n    print\n}' /etc/squid/squid.conf.template > /etc/squid/squid.conf\n\n/usr/sbin/squid -Nz\necho \"[ENTRYPOINT] starting squid\"\n/usr/sbin/squid -f /etc/squid/squid.conf -NYC 1\n"
      - 'ssrf_proxy_var_log_squid:/var/log/squid'
      - 'ssrf_proxy_var_spool_squid:/var/spool/squid'
    entrypoint:
      - /bin/sh
      - /docker-entrypoint.sh
    environment:
      HTTP_PORT: '${SSRF_HTTP_PORT:-3128}'
      COREDUMP_DIR: '${SSRF_COREDUMP_DIR:-/var/spool/squid}'
      REVERSE_PROXY_PORT: '${SSRF_REVERSE_PROXY_PORT:-8194}'
      SANDBOX_HOST: '${SSRF_SANDBOX_HOST:-sandbox}'
      SANDBOX_PORT: '${SANDBOX_PORT:-8194}'
    networks:
      - ssrf_proxy_network
      - default
    healthcheck:
      test:
        - CMD
        - squid
        - '-k'
        - check
      interval: 30s
      timeout: 10s
      retries: 3
      start_period: 40s
  nginx:
    image: 'nginx:latest'
    volumes:
      -
        type: bind
        source: ./nginx/nginx.conf.template
        target: /etc/nginx/nginx.conf.template
        read_only: true
        content: "# Please do not directly edit this file. Instead, modify the .env variables related to NGINX configuration.\n\nuser  nginx;\n    worker_processes  ${NGINX_WORKER_PROCESSES};\n\n    error_log  /var/log/nginx/error.log notice;\n    pid        /var/run/nginx.pid;\n\n\n    events {\n        worker_connections  1024;\n    }\n\n\n    http {\n        include       /etc/nginx/mime.types;\n        default_type  application/octet-stream;\n\n        log_format  main  '$remote_addr - $remote_user [$time_local] \"$request\" '\n                          '$status $body_bytes_sent \"$http_referer\" '\n                          '\"$http_user_agent\" \"$http_x_forwarded_for\"';\n\n        access_log  /var/log/nginx/access.log  main;\n\n        sendfile        on;\n        #tcp_nopush     on;\n\n        keepalive_timeout  ${NGINX_KEEPALIVE_TIMEOUT};\n\n        #gzip  on;\n        client_max_body_size ${NGINX_CLIENT_MAX_BODY_SIZE};\n\n        include /etc/nginx/conf.d/*.conf;\n    }\n"
      -
        type: bind
        source: ./nginx/proxy.conf.template
        target: /etc/nginx/proxy.conf.template
        read_only: true
        content: "# Please do not directly edit this file. Instead, modify the .env variables related to NGINX configuration.\n  proxy_set_header Host $host;\n  proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;\n  proxy_set_header X-Forwarded-Proto $scheme;\n  proxy_http_version 1.1;\n  proxy_set_header Connection \"\";\n  proxy_buffering off;\n  proxy_read_timeout ${NGINX_PROXY_READ_TIMEOUT};\n  proxy_send_timeout ${NGINX_PROXY_SEND_TIMEOUT};\n"
      -
        type: bind
        source: ./nginx/https.conf.template
        target: /etc/nginx/https.conf.template
        read_only: true
        content: "# Please do not directly edit this file. Instead, modify the .env variables related to NGINX configuration.\n\nlisten ${NGINX_SSL_PORT} ssl;\nssl_certificate ${SSL_CERTIFICATE_PATH};\nssl_certificate_key ${SSL_CERTIFICATE_KEY_PATH};\nssl_protocols ${NGINX_SSL_PROTOCOLS};\nssl_prefer_server_ciphers on;\nssl_session_cache shared:SSL:10m;\nssl_session_timeout 10m;\n"
      -
        type: bind
        source: ./nginx/docker-entrypoint.sh
        target: /docker-entrypoint-mount.sh
        read_only: true
        content: "#!/bin/bash\n\nif [ \"${NGINX_HTTPS_ENABLED}\" = \"true\" ]; then\n    # Check if the certificate and key files for the specified domain exist\n    if [ -n \"${CERTBOT_DOMAIN}\" ] && \\\n      [ -f \"/etc/letsencrypt/live/${CERTBOT_DOMAIN}/${NGINX_SSL_CERT_FILENAME}\" ] && \\\n      [ -f \"/etc/letsencrypt/live/${CERTBOT_DOMAIN}/${NGINX_SSL_CERT_KEY_FILENAME}\" ]; then\n        SSL_CERTIFICATE_PATH=\"/etc/letsencrypt/live/${CERTBOT_DOMAIN}/${NGINX_SSL_CERT_FILENAME}\"\n        SSL_CERTIFICATE_KEY_PATH=\"/etc/letsencrypt/live/${CERTBOT_DOMAIN}/${NGINX_SSL_CERT_KEY_FILENAME}\"\n    else\n        SSL_CERTIFICATE_PATH=\"/etc/ssl/${NGINX_SSL_CERT_FILENAME}\"\n        SSL_CERTIFICATE_KEY_PATH=\"/etc/ssl/${NGINX_SSL_CERT_KEY_FILENAME}\"\n    fi\n    export SSL_CERTIFICATE_PATH\n    export SSL_CERTIFICATE_KEY_PATH\n\n    # set the HTTPS_CONFIG environment variable to the content of the https.conf.template\n    HTTPS_CONFIG=$(envsubst < /etc/nginx/https.conf.template)\n    export HTTPS_CONFIG\n    # Substitute the HTTPS_CONFIG in the default.conf.template with content from https.conf.template\n    envsubst '${HTTPS_CONFIG}' < /etc/nginx/conf.d/default.conf.template > /etc/nginx/conf.d/default.conf\nfi\n\nif [ \"${NGINX_ENABLE_CERTBOT_CHALLENGE}\" = \"true\" ]; then\n    ACME_CHALLENGE_LOCATION='location /.well-known/acme-challenge/ { root /var/www/html; }'\nelse\n    ACME_CHALLENGE_LOCATION=''\nfi\nexport ACME_CHALLENGE_LOCATION\n\nenv_vars=$(printenv | cut -d= -f1 | sed 's/^/$/g' | paste -sd, -)\n\nenvsubst \"$env_vars\" < /etc/nginx/nginx.conf.template > /etc/nginx/nginx.conf\nenvsubst \"$env_vars\" < /etc/nginx/proxy.conf.template > /etc/nginx/proxy.conf\n\nenvsubst < /etc/nginx/conf.d/default.conf.template > /etc/nginx/conf.d/default.conf\n\n# Start Nginx using the default entrypoint\nexec nginx -g 'daemon off;'\n"
      -
        type: bind
        source: ./nginx/default.conf.template
        target: /etc/nginx/conf.d/default.conf.template
        read_only: true
        content: "# Please do not directly edit this file. Instead, modify the .env variables related to NGINX configuration.\n\nserver {\n    listen ${NGINX_PORT};\n    server_name ${NGINX_SERVER_NAME};\n\n    location /console/api {\n      proxy_pass http://api:5001;\n      include proxy.conf;\n    }\n\n    location /api {\n      proxy_pass http://api:5001;\n      include proxy.conf;\n    }\n\n    location /v1 {\n      proxy_pass http://api:5001;\n      include proxy.conf;\n    }\n\n    location /files {\n      proxy_pass http://api:5001;\n      include proxy.conf;\n    }\n\n    location / {\n      proxy_pass http://web:3000;\n      include proxy.conf;\n    }\n\n    # placeholder for acme challenge location\n    ${ACME_CHALLENGE_LOCATION}\n\n    # placeholder for https config defined in https.conf.template\n    ${HTTPS_CONFIG}\n}\n"
      - './nginx/ssl:/etc/ssl'
      - './volumes/certbot/conf/live:/etc/letsencrypt/live'
      - './volumes/certbot/conf:/etc/letsencrypt'
      - './volumes/certbot/www:/var/www/html'
    entrypoint:
      - sh
      - '-c'
      - "cp /docker-entrypoint-mount.sh /docker-entrypoint.sh && sed -i 's/\r$$//' /docker-entrypoint.sh && chmod +x /docker-entrypoint.sh && /docker-entrypoint.sh"
    environment:
      NGINX_SERVER_NAME: $SERVICE_FQDN_NGINX
      NGINX_HTTPS_ENABLED: '${NGINX_HTTPS_ENABLED:-false}'
      NGINX_SSL_PORT: '${NGINX_SSL_PORT:-443}'
      NGINX_PORT: '${NGINX_PORT:-80}'
      NGINX_SSL_CERT_FILENAME: '${NGINX_SSL_CERT_FILENAME:-dify.crt}'
      NGINX_SSL_CERT_KEY_FILENAME: '${NGINX_SSL_CERT_KEY_FILENAME:-dify.key}'
      NGINX_SSL_PROTOCOLS: '${NGINX_SSL_PROTOCOLS:-TLSv1.1 TLSv1.2 TLSv1.3}'
      NGINX_WORKER_PROCESSES: '${NGINX_WORKER_PROCESSES:-auto}'
      NGINX_CLIENT_MAX_BODY_SIZE: '${NGINX_CLIENT_MAX_BODY_SIZE:-15M}'
      NGINX_KEEPALIVE_TIMEOUT: '${NGINX_KEEPALIVE_TIMEOUT:-65}'
      NGINX_PROXY_READ_TIMEOUT: '${NGINX_PROXY_READ_TIMEOUT:-3600s}'
      NGINX_PROXY_SEND_TIMEOUT: '${NGINX_PROXY_SEND_TIMEOUT:-3600s}'
      NGINX_ENABLE_CERTBOT_CHALLENGE: '${NGINX_ENABLE_CERTBOT_CHALLENGE:-false}'
      CERTBOT_DOMAIN: '${CERTBOT_DOMAIN:-}'
    depends_on:
      - api
      - web
    healthcheck:
      test:
        - CMD
        - nginx
        - '-t'
      interval: 30s
      timeout: 10s
      retries: 3
      start_period: 40s
  weaviate:
    image: 'semitechnologies/weaviate:1.19.0'
    profiles:
      - ''
      - weaviate
    volumes:
      - 'dify-weaviate-data:/var/lib/weaviate'
    environment:
      PERSISTENCE_DATA_PATH: '${WEAVIATE_PERSISTENCE_DATA_PATH:-/var/lib/weaviate}'
      QUERY_DEFAULTS_LIMIT: '${WEAVIATE_QUERY_DEFAULTS_LIMIT:-25}'
      AUTHENTICATION_ANONYMOUS_ACCESS_ENABLED: '${WEAVIATE_AUTHENTICATION_ANONYMOUS_ACCESS_ENABLED:-false}'
      DEFAULT_VECTORIZER_MODULE: '${WEAVIATE_DEFAULT_VECTORIZER_MODULE:-none}'
      CLUSTER_HOSTNAME: '${WEAVIATE_CLUSTER_HOSTNAME:-node1}'
      AUTHENTICATION_APIKEY_ENABLED: '${WEAVIATE_AUTHENTICATION_APIKEY_ENABLED:-true}'
      AUTHENTICATION_APIKEY_ALLOWED_KEYS: $SERVICE_PASSWORD_WEAVIATE
      AUTHENTICATION_APIKEY_USERS: $SERVICE_USER_WEAVIATE
      AUTHORIZATION_ADMINLIST_ENABLED: '${WEAVIATE_AUTHORIZATION_ADMINLIST_ENABLED:-true}'
      AUTHORIZATION_ADMINLIST_USERS: $SERVICE_USER_WEAVIATE
    healthcheck:
      test:
        - CMD
        - wget
        - '--spider'
        - '-q'
        - 'http://localhost:8080/v1/.well-known/live'
      interval: 30s
      timeout: 10s
      retries: 3
      start_period: 40s
networks:
  ssrf_proxy_network:
    driver: bridge
    internal: true
volumes:
  ssrf_proxy_var_log_squid: null
  ssrf_proxy_var_spool_squid: null
",
- "tags": [
- "ai",
- "weaviate",
- "openai",
- "gpt",
- "llm",
- "lmops",
- "dify",
- "redis",
- "postgres",
- "qdrant",
- "rag",
- "agent"
- ],
- "logo": "svgs/dify.png",
- "minversion": "0.0.0",
- "port": "3000"
- },
"directus-with-postgresql": {
"documentation": "https://directus.io?utm_source=coolify.io",
"slogan": "Directus wraps databases with a dynamic API, and provides an intuitive app for managing its content.",
@@ -1523,6 +1516,20 @@
"minversion": "0.0.0",
"port": "8081"
},
+ "mindsdb": {
+ "documentation": "https://docs.mindsdb.com/what-is-mindsdb?utm_source=coolify.io",
+ "slogan": "MindsDB is the platform for building AI from enterprise data, enabling smarter organizations.",
+ "compose": "c2VydmljZXM6CiAgbWluZHNkYjoKICAgIGltYWdlOiAnbWluZHNkYi9taW5kc2RiOmxhdGVzdCcKICAgIGVudmlyb25tZW50OgogICAgICAtIFNFUlZJQ0VfRlFETl9NSU5EU0RCXzQ3MzM0CiAgICAgIC0gU0VSVklDRV9GUUROX0FQSV80NzMzNT0vYXBpCiAgICAgIC0gTUlORFNEQl9ET0NLRVJfRU5WPXRydWUKICAgICAgLSBNSU5EU0RCX1NUT1JBR0VfRElSPS9taW5kc2RiL3ZhcgogICAgICAtICdGTEFTS19ERUJVRz0ke0ZMQVNLX0RFQlVHOi0xfScKICAgICAgLSAnT1BFTkFJX0FQSV9LRVk9JHtPUEVOQUlfQVBJX0tFWX0nCiAgICAgIC0gJ0xBTkdGVVNFX0hPU1Q9JHtMQU5HRlVTRV9IT1NUfScKICAgICAgLSAnTEFOR0ZVU0VfUFVCTElDX0tFWT0ke0xBTkdGVVNFX1BVQkxJQ19LRVl9JwogICAgICAtICdMQU5HRlVTRV9TRUNSRVRfS0VZPSR7TEFOR0ZVU0VfU0VDUkVUX0tFWX0nCiAgICAgIC0gJ0xBTkdGVVNFX1JFTEVBU0U9JHtMQU5HRlVTRV9SRUxFQVNFOi1sb2NhbH0nCiAgICAgIC0gJ0xBTkdGVVNFX0RFQlVHPSR7TEFOR0ZVU0VfREVCVUc6LUZhbHNlfScKICAgICAgLSAnTEFOR0ZVU0VfVElNRU9VVD0ke0xBTkdGVVNFX1RJTUVPVVQ6LTEwfScKICAgICAgLSAnTEFOR0ZVU0VfU0FNUExFX1JBVEU9JHtMQU5HRlVTRV9TQU1QTEVfUkFURTotMS4wfScKICAgICAgLSAnTUlORFNEQl9EQl9DT049cG9zdGdyZXNxbDovLyR7U0VSVklDRV9VU0VSX1BPU1RHUkVTfToke1NFUlZJQ0VfUEFTU1dPUkRfUE9TVEdSRVN9QHBvc3RncmVzcWwvJHtQT1NUR1JFU19EQjotbWluZHNkYi1kYn0nCiAgICB2b2x1bWVzOgogICAgICAtICdtaW5kc2RiLWRhdGE6L21pbmRzZGIvdmFyJwogICAgZGVwZW5kc19vbjoKICAgICAgcG9zdGdyZXNxbDoKICAgICAgICBjb25kaXRpb246IHNlcnZpY2VfaGVhbHRoeQogICAgaGVhbHRoY2hlY2s6CiAgICAgIHRlc3Q6CiAgICAgICAgLSBDTUQKICAgICAgICAtIGN1cmwKICAgICAgICAtICctZicKICAgICAgICAtICdodHRwOi8vbG9jYWxob3N0OjQ3MzM0L2FwaS91dGlsL3BpbmcnCiAgICAgIGludGVydmFsOiAzMHMKICAgICAgdGltZW91dDogNXMKICAgICAgcmV0cmllczogMTUKICBwb3N0Z3Jlc3FsOgogICAgaW1hZ2U6ICdwb3N0Z3JlczoxNi1hbHBpbmUnCiAgICB2b2x1bWVzOgogICAgICAtICdtaW5kc2RiLXBvc3RncmVzcWwtZGF0YTovdmFyL2xpYi9wb3N0Z3Jlc3FsL2RhdGEnCiAgICBlbnZpcm9ubWVudDoKICAgICAgLSAnUE9TVEdSRVNfVVNFUj0ke1NFUlZJQ0VfVVNFUl9QT1NUR1JFU30nCiAgICAgIC0gJ1BPU1RHUkVTX1BBU1NXT1JEPSR7U0VSVklDRV9QQVNTV09SRF9QT1NUR1JFU30nCiAgICAgIC0gJ1BPU1RHUkVTX0RCPSR7UE9TVEdSRVNfREI6LW1pbmRzZGItZGJ9JwogICAgaGVhbHRoY2hlY2s6CiAgICAgIHRlc3Q6CiAgICAgICAgLSBDTUQtU0hFTEwKICAgICAgICAtICdwZ19pc3JlYWR5IC1VICQke1BPU1RHUkVTX1VTRVJ9IC1kICQke1BPU1RHUkVTX0RCfScKICAgICAgaW50ZXJ2YWw6IDEwcwogICAgICB0aW1lb3V0OiA1cwogICAgICByZXRyaWVzOiAxNQo=",
+ "tags": [
+ "mysql",
+ "postgresdb",
+ "machine-learning",
+ "ai"
+ ],
+ "logo": "svgs/mindsdb.svg",
+ "minversion": "0.0.0",
+ "port": "47334"
+ },
"minecraft": {
"documentation": "https://github.com/itzg/docker-minecraft-server?utm_source=coolify.io",
"slogan": "Minecraft Server that will automatically download selected version at startup.",
@@ -1583,6 +1590,19 @@
"minversion": "0.0.0",
"port": "8080"
},
+ "mosquitto": {
+ "documentation": "https://mosquitto.org/documentation/?utm_source=coolify.io",
+ "slogan": "Mosquitto is lightweight and suitable for use on all devices, from low-power single-board computers to full servers.",
+ "compose": "c2VydmljZXM6CiAgbW9zcXVpdHRvOgogICAgaW1hZ2U6IGVjbGlwc2UtbW9zcXVpdHRvCiAgICBlbnZpcm9ubWVudDoKICAgICAgLSBTRVJWSUNFX0ZRRE5fTU9TUVVJVFRPXzE4ODMKICAgICAgLSAnTVFUVF9VU0VSTkFNRT0ke1NFUlZJQ0VfVVNFUl9NT1NRVUlUVE99JwogICAgICAtICdNUVRUX1BBU1NXT1JEPSR7U0VSVklDRV9QQVNTV09SRF9NT1NRVUlUVE99JwogICAgICAtICdSRVFVSVJFX0NFUlRJRklDQVRFPSR7UkVRVUlSRV9DRVJUSUZJQ0FURTotZmFsc2V9JwogICAgICAtICdBTExPV19BTk9OWU1PVVM9JHtBTExPV19BTk9OWU1PVVM6LXRydWV9JwogICAgdm9sdW1lczoKICAgICAgLSAnbW9zcXVpdHRvLWNvbmZpZzovbW9zcXVpdHRvL2NvbmZpZycKICAgICAgLSAnbW9zcXVpdHRvLWNlcnRzOi9jZXJ0cycKICAgIGhlYWx0aGNoZWNrOgogICAgICB0ZXN0OgogICAgICAgIC0gQ01ELVNIRUxMCiAgICAgICAgLSAnZXhpdCAwJwogICAgICBpbnRlcnZhbDogMzBzCiAgICAgIHRpbWVvdXQ6IDEwcwogICAgICByZXRyaWVzOiAzCiAgICBlbnRyeXBvaW50OiAic2ggLWMgXCIgaWYgWyAnJFJFUVVJUkVfQ0VSVElGSUNBVEUnID0gJ3RydWUnIF07IHRoZW4gZWNobyAnbGlzdGVuZXIgODg4MycgPiAvbW9zcXVpdHRvL2NvbmZpZy9tb3NxdWl0dG8uY29uZiAmJiBlY2hvICdjYWZpbGUgL2NlcnRzL2NhLmNydCcgPj4gL21vc3F1aXR0by9jb25maWcvbW9zcXVpdHRvLmNvbmYgJiYgZWNobyAnY2VydGZpbGUgL2NlcnRzL3NlcnZlci5jcnQnID4+IC9tb3NxdWl0dG8vY29uZmlnL21vc3F1aXR0by5jb25mICYmIGVjaG8gJ2tleWZpbGUgIC9jZXJ0cy9zZXJ2ZXIua2V5JyA+PiAvbW9zcXVpdHRvL2NvbmZpZy9tb3NxdWl0dG8uY29uZjsgZWxzZSBlY2hvICdsaXN0ZW5lciAxODgzJyA+IC9tb3NxdWl0dG8vY29uZmlnL21vc3F1aXR0by5jb25mOyBmaSAmJiBlY2hvICdyZXF1aXJlX2NlcnRpZmljYXRlICckUkVRVUlSRV9DRVJUSUZJQ0FURSA+PiAvbW9zcXVpdHRvL2NvbmZpZy9tb3NxdWl0dG8uY29uZiAmJiBlY2hvICdhbGxvd19hbm9ueW1vdXMgJyRBTExPV19BTk9OWU1PVVMgPj4gL21vc3F1aXR0by9jb25maWcvbW9zcXVpdHRvLmNvbmYgJiYgaWYgWyAtbiAnJFNFUlZJQ0VfVVNFUl9NT1NRVUlUVE8nXSAmJiBbIC1uICckU0VSVklDRV9QQVNTV09SRF9NT1NRVUlUVE8nIF07IHRoZW4gZWNobyAncGFzc3dvcmRfZmlsZSAvbW9zcXVpdHRvL2NvbmZpZy9wYXNzd29yZHMnID4+IC9tb3NxdWl0dG8vY29uZmlnL21vc3F1aXR0by5jb25mICYmIHRvdWNoIC9tb3NxdWl0dG8vY29uZmlnL3Bhc3N3b3JkcyAmJiBjaG1vZCAwNzAwIC9tb3NxdWl0dG8vY29uZmlnL3Bhc3N3b3JkcyAmJiBjaG93biByb290OnJvb3QgL21vc3F1aXR0by9jb25maWcvcGFzc3dvcmRzICYmIG1vc3F1aXR0b19wYXNzd2QgLWIgLWMgL21vc3F1aXR0by9jb25maWcvcGFzc3dvcmRzICRTRVJWSUNFX1VTRVJfTU9TUVVJVFRPICRTRVJWSUNFX1BBU1NXT1JEX01PU1FVSVRUTyAmJiBjaG93biBtb3NxdWl0dG86bW9zcXVpdHRvIC9tb3NxdWl0dG8vY29uZmlnL3Bhc3N3b3JkczsgZmkgJiYgZXhlYyBtb3NxdWl0dG8gLWMgL21vc3F1aXR0by9jb25maWcvbW9zcXVpdHRvLmNvbmYgXCIiCiAgICBsYWJlbHM6CiAgICAgIC0gdHJhZWZpay50Y3Aucm91dGVycy5tcXR0LmVudHJ5cG9pbnRzPW1xdHQKICAgICAgLSB0cmFlZmlrLnRjcC5yb3V0ZXJzLm1xdHRzLmVudHJ5cG9pbnRzPW1xdHRzCg==",
+ "tags": [
+ "mosquitto",
+ "mqtt",
+ "open-source"
+ ],
+ "logo": "svgs/mosquitto.svg",
+ "minversion": "0.0.0",
+ "port": "1883"
+ },
"n8n-with-postgresql": {
"documentation": "https://n8n.io?utm_source=coolify.io",
"slogan": "n8n is an extendable workflow automation tool.",
@@ -1908,20 +1928,6 @@
"logo": "svgs/coolify.png",
"minversion": "0.0.0"
},
- "peppermint": {
- "documentation": "https://docs.peppermint.sh/?utm_source=coolify.io",
- "slogan": "Open source helpdesk solution designed to enhance the user experience for teams currently utilizing costly software alternatives",
- "compose": "c2VydmljZXM6CiAgcG9zdGdyZXM6CiAgICBpbWFnZTogJ3Bvc3RncmVzOjE2LWFscGluZScKICAgIHZvbHVtZXM6CiAgICAgIC0gJ3BlcHBlcm1pbnQtcG9zdGdyZXNxbC1kYXRhOi92YXIvbGliL3Bvc3RncmVzcWwvZGF0YScKICAgIGVudmlyb25tZW50OgogICAgICAtICdQT1NUR1JFU19VU0VSPSR7U0VSVklDRV9VU0VSX1BPU1RHUkVTfScKICAgICAgLSAnUE9TVEdSRVNfUEFTU1dPUkQ9JHtTRVJWSUNFX1BBU1NXT1JEX1BPU1RHUkVTfScKICAgICAgLSAnUE9TVEdSRVNfREI9JHtQT1NUR1JFU19EQjotcGVwcGVybWludC1kYn0nCiAgICBoZWFsdGhjaGVjazoKICAgICAgdGVzdDoKICAgICAgICAtIENNRC1TSEVMTAogICAgICAgIC0gJ3BnX2lzcmVhZHkgLVUgJCR7UE9TVEdSRVNfVVNFUn0gLWQgJCR7UE9TVEdSRVNfREJ9JwogICAgICBpbnRlcnZhbDogNXMKICAgICAgdGltZW91dDogMjBzCiAgICAgIHJldHJpZXM6IDEwCiAgcGVwcGVybWludDoKICAgIGltYWdlOiAncGVwcGVybGFicy9wZXBwZXJtaW50OmxhdGVzdCcKICAgIGRlcGVuZHNfb246CiAgICAgIHBvc3RncmVzOgogICAgICAgIGNvbmRpdGlvbjogc2VydmljZV9oZWFsdGh5CiAgICBoZWFsdGhjaGVjazoKICAgICAgdGVzdDoKICAgICAgICAtIENNRAogICAgICAgIC0gY3VybAogICAgICAgIC0gJy1mJwogICAgICAgIC0gJ2h0dHA6Ly8xMjcuMC4wLjE6MzAwMCcKICAgICAgaW50ZXJ2YWw6IDJzCiAgICAgIHRpbWVvdXQ6IDEwcwogICAgICByZXRyaWVzOiAxNQogICAgZW52aXJvbm1lbnQ6CiAgICAgIC0gU0VSVklDRV9GUUROX1BFUFBFUk1JTlRfMzAwMAogICAgICAtIFNFUlZJQ0VfRlFETl9QRVBQRVJNSU5UXzUwMDMKICAgICAgLSAnREJfVVNFUk5BTUU9JHtTRVJWSUNFX1VTRVJfUE9TVEdSRVN9JwogICAgICAtICdEQl9QQVNTV09SRD0ke1NFUlZJQ0VfUEFTU1dPUkRfUE9TVEdSRVN9JwogICAgICAtIERCX0hPU1Q9cG9zdGdyZXMKICAgICAgLSAnREJfTkFNRT0ke1BPU1RHUkVTX0RCOi1wZXBwZXJtaW50LWRifScKICAgICAgLSAnU0VDUkVUPSR7U0VSVklDRV9QQVNTV09SRF9QRVBQRVJNSU5UfScKICAgICAgLSAnQVBJX1VSTD0ke1NFUlZJQ0VfRlFETl9QRVBQRVJNSU5UXzUwMDN9Jwo=",
- "tags": [
- "helpdesk",
- "open-source",
- "peppermint",
- "postgres"
- ],
- "logo": "svgs/peppermint.png",
- "minversion": "0.0.0",
- "port": "3000"
- },
"phpmyadmin": {
"documentation": "https://phpmyadmin.net?utm_source=coolify.io",
"slogan": "phpMyAdmin is a web-based database management tool for administering your MySQL and MariaDB databases through a user-friendly interface.",
@@ -2624,7 +2630,7 @@
"windmill": {
"documentation": "https://www.windmill.dev/docs/?utm_source=coolify.io",
"slogan": "Windmill is a developer platform to build production-grade multi-steps automations and internal apps.",
- "compose": "c2VydmljZXM6CiAgZGI6CiAgICBpbWFnZTogJ3Bvc3RncmVzOjE2JwogICAgc2htX3NpemU6IDFnCiAgICB2b2x1bWVzOgogICAgICAtICdkYi1kYXRhOi92YXIvbGliL3Bvc3RncmVzcWwvZGF0YScKICAgIGVudmlyb25tZW50OgogICAgICAtIFBPU1RHUkVTX1BBU1NXT1JEPSRTRVJWSUNFX1BBU1NXT1JEX1BPU1RHUkVTCiAgICAgIC0gJ1BPU1RHUkVTX0RCPSR7UE9TVEdSRVNfREI6LXdpbmRtaWxsfScKICAgIGhlYWx0aGNoZWNrOgogICAgICB0ZXN0OgogICAgICAgIC0gQ01ELVNIRUxMCiAgICAgICAgLSAncGdfaXNyZWFkeSAtVSBwb3N0Z3JlcycKICAgICAgaW50ZXJ2YWw6IDEwcwogICAgICB0aW1lb3V0OiA1cwogICAgICByZXRyaWVzOiA1CiAgd2luZG1pbGwtc2VydmVyOgogICAgaW1hZ2U6ICdnaGNyLmlvL3dpbmRtaWxsLWxhYnMvd2luZG1pbGw6bWFpbicKICAgIGVudmlyb25tZW50OgogICAgICAtIFNFUlZJQ0VfRlFETl9XSU5ETUlMTF84MDAwCiAgICAgIC0gJ0RBVEFCQVNFX1VSTD1wb3N0Z3JlczovL3Bvc3RncmVzOiRTRVJWSUNFX1BBU1NXT1JEX1BPU1RHUkVTQGRiL3dpbmRtaWxsJwogICAgICAtICdNT0RFPSR7TU9ERTotc2VydmVyfScKICAgICAgLSBCQVNFX1VSTD0kU0VSVklDRV9GUUROX1dJTkRNSUxMCiAgICBkZXBlbmRzX29uOgogICAgICBkYjoKICAgICAgICBjb25kaXRpb246IHNlcnZpY2VfaGVhbHRoeQogICAgdm9sdW1lczoKICAgICAgLSAnd29ya2VyLWxvZ3M6L3RtcC93aW5kbWlsbC9sb2dzJwogICAgaGVhbHRoY2hlY2s6CiAgICAgIHRlc3Q6CiAgICAgICAgLSBDTUQKICAgICAgICAtIGN1cmwKICAgICAgICAtICctZicKICAgICAgICAtICdodHRwOi8vbG9jYWxob3N0OjgwMDAvYXBpL3ZlcnNpb24gfHwgZXhpdCAxJwogICAgICBpbnRlcnZhbDogMzBzCiAgICAgIHRpbWVvdXQ6IDEwcwogICAgICByZXRyaWVzOiAzCiAgd2luZG1pbGwtd29ya2VyLTE6CiAgICBpbWFnZTogJ2doY3IuaW8vd2luZG1pbGwtbGFicy93aW5kbWlsbDptYWluJwogICAgZW52aXJvbm1lbnQ6CiAgICAgIC0gJ0RBVEFCQVNFX1VSTD1wb3N0Z3JlczovL3Bvc3RncmVzOiRTRVJWSUNFX1BBU1NXT1JEX1BPU1RHUkVTQGRiL3dpbmRtaWxsJwogICAgICAtICdNT0RFPSR7TU9ERTotd29ya2VyfScKICAgICAgLSAnV09SS0VSX0dST1VQPSR7V09SS0VSX0dST1VQOi1kZWZhdWx0fScKICAgIGRlcGVuZHNfb246CiAgICAgIGRiOgogICAgICAgIGNvbmRpdGlvbjogc2VydmljZV9oZWFsdGh5CiAgICB2b2x1bWVzOgogICAgICAtICcvdmFyL3J1bi9kb2NrZXIuc29jazovdmFyL3J1bi9kb2NrZXIuc29jaycKICAgICAgLSAnd29ya2VyLWRlcGVuZGVuY3ktY2FjaGU6L3RtcC93aW5kbWlsbC9jYWNoZScKICAgICAgLSAnd29ya2VyLWxvZ3M6L3RtcC93aW5kbWlsbC9sb2dzJwogICAgaGVhbHRoY2hlY2s6CiAgICAgIHRlc3Q6CiAgICAgICAgLSBDTUQKICAgICAgICAtIGN1cmwKICAgICAgICAtICctZicKICAgICAgICAtICdodHRwOi8vbG9jYWxob3N0OjgwMDAvYXBpL3ZlcnNpb24gfHwgZXhpdCAxJwogICAgICBpbnRlcnZhbDogMzBzCiAgICAgIHRpbWVvdXQ6IDEwcwogICAgICByZXRyaWVzOiAzCiAgd2luZG1pbGwtd29ya2VyLTI6CiAgICBpbWFnZTogJ2doY3IuaW8vd2luZG1pbGwtbGFicy93aW5kbWlsbDptYWluJwogICAgZW52aXJvbm1lbnQ6CiAgICAgIC0gJ0RBVEFCQVNFX1VSTD1wb3N0Z3JlczovL3Bvc3RncmVzOiRTRVJWSUNFX1BBU1NXT1JEX1BPU1RHUkVTQGRiL3dpbmRtaWxsJwogICAgICAtICdNT0RFPSR7TU9ERTotd29ya2VyfScKICAgICAgLSAnV09SS0VSX0dST1VQPSR7V09SS0VSX0dST1VQOi1kZWZhdWx0fScKICAgIGRlcGVuZHNfb246CiAgICAgIGRiOgogICAgICAgIGNvbmRpdGlvbjogc2VydmljZV9oZWFsdGh5CiAgICB2b2x1bWVzOgogICAgICAtICcvdmFyL3J1bi9kb2NrZXIuc29jazovdmFyL3J1bi9kb2NrZXIuc29jaycKICAgICAgLSAnd29ya2VyLWRlcGVuZGVuY3ktY2FjaGU6L3RtcC93aW5kbWlsbC9jYWNoZScKICAgICAgLSAnd29ya2VyLWxvZ3M6L3RtcC93aW5kbWlsbC9sb2dzJwogICAgaGVhbHRoY2hlY2s6CiAgICAgIHRlc3Q6CiAgICAgICAgLSBDTUQKICAgICAgICAtIGN1cmwKICAgICAgICAtICctZicKICAgICAgICAtICdodHRwOi8vbG9jYWxob3N0OjgwMDAvYXBpL3ZlcnNpb24gfHwgZXhpdCAxJwogICAgICBpbnRlcnZhbDogMzBzCiAgICAgIHRpbWVvdXQ6IDEwcwogICAgICByZXRyaWVzOiAzCiAgd2luZG1pbGwtd29ya2VyLTM6CiAgICBpbWFnZTogJ2doY3IuaW8vd2luZG1pbGwtbGFicy93aW5kbWlsbDptYWluJwogICAgZW52aXJvbm1lbnQ6CiAgICAgIC0gJ0RBVEFCQVNFX1VSTD1wb3N0Z3JlczovL3Bvc3RncmVzOiRTRVJWSUNFX1BBU1NXT1JEX1BPU1RHUkVTQGRiL3dpbmRtaWxsJwogICAgICAtICdNT0RFPSR7TU9ERTotd29ya2VyfScKICAgICAgLSAnV09SS0VSX0dST1VQPSR7V09SS0VSX0dST1VQOi1kZWZhdWx0fScKICAgIGRlcGVuZHNfb246CiAgICAgIGRiOgogICAgICAgIGNvbmRpdGlvbjogc2VydmljZV9oZWFsdGh5CiAgICB2b2x1bWVzOgogICAgICAtICcvdmFyL3J1bi9kb2NrZXIuc29jazovdmFyL3J1bi9kb2NrZXIuc29jaycKICAgICAgLSAnd29ya2VyLWRlcGVuZGVuY3ktY2FjaGU6L3RtcC93aW5kbWlsbC9jYWNoZScKICAgICAgLSAnd29ya2VyLWxvZ3M6L3RtcC93aW5kbWlsbC9sb2dzJwogICAgaGVhbHRoY2hlY2s6CiAgICAgIHRlc3Q6CiAgICAgICAgLSBDTUQKICAgICAgICAtIGN1cmwKICAgICAgICAtICctZicKICAgICAgICAtICdodHRwOi8vbG9jYWxob3N0OjgwMDAvYXBpL3ZlcnNpb24gfHwgZXhpdCAxJwogICAgICBpbnRlcnZhbDogMzBzCiAgICAgIHRpbWVvdXQ6IDEwcwogICAgICByZXRyaWVzOiAzCiAgd2luZG1pbGwtd29ya2VyLW5hdGl2ZToKICAgIGltYWdlOiAnZ2hjci5pby93aW5kbWlsbC1sYWJzL3dpbmRtaWxsOm1haW4nCiAgICBlbnZpcm9ubWVudDoKICAgICAgLSAnREFUQUJBU0VfVVJMPXBvc3RncmVzOi8vcG9zdGdyZXM6JFNFUlZJQ0VfUEFTU1dPUkRfUE9TVEdSRVNAZGIvd2luZG1pbGwnCiAgICAgIC0gJ01PREU9JHtNT0RFOi13b3JrZXJ9JwogICAgICAtICdXT1JLRVJfR1JPVVA9JHtXT1JLRVJfR1JPVVA6LW5hdGl2ZX0nCiAgICAgIC0gJ05VTV9XT1JLRVJTPSR7TlVNX1dPUktFUlM6LTh9JwogICAgICAtICdTTEVFUF9RVUVVRT0ke1NMRUVQX1FVRVVFOi0yMDB9JwogICAgZGVwZW5kc19vbjoKICAgICAgZGI6CiAgICAgICAgY29uZGl0aW9uOiBzZXJ2aWNlX2hlYWx0aHkKICAgIHZvbHVtZXM6CiAgICAgIC0gJ3dvcmtlci1sb2dzOi90bXAvd2luZG1pbGwvbG9ncycKICAgIGhlYWx0aGNoZWNrOgogICAgICB0ZXN0OgogICAgICAgIC0gQ01ECiAgICAgICAgLSBjdXJsCiAgICAgICAgLSAnLWYnCiAgICAgICAgLSAnaHR0cDovL2xvY2FsaG9zdDo4MDAwL2FwaS92ZXJzaW9uIHx8IGV4aXQgMScKICAgICAgaW50ZXJ2YWw6IDMwcwogICAgICB0aW1lb3V0OiAxMHMKICAgICAgcmV0cmllczogMwogIGxzcDoKICAgIGltYWdlOiAnZ2hjci5pby93aW5kbWlsbC1sYWJzL3dpbmRtaWxsLWxzcDpsYXRlc3QnCiAgICB2b2x1bWVzOgogICAgICAtICdsc3AtY2FjaGU6L3Jvb3QvLmNhY2hlJwogICAgaGVhbHRoY2hlY2s6CiAgICAgIHRlc3Q6CiAgICAgICAgLSBDTUQtU0hFTEwKICAgICAgICAtICdleGl0IDAnCiAgICAgIGludGVydmFsOiAzMHMKICAgICAgdGltZW91dDogMTBzCiAgICAgIHJldHJpZXM6IDMK",
+ "compose": "c2VydmljZXM6CiAgZGI6CiAgICBpbWFnZTogJ3Bvc3RncmVzOjE2JwogICAgc2htX3NpemU6IDFnCiAgICB2b2x1bWVzOgogICAgICAtICdkYi1kYXRhOi92YXIvbGliL3Bvc3RncmVzcWwvZGF0YScKICAgIGVudmlyb25tZW50OgogICAgICAtICdQT1NUR1JFU19QQVNTV09SRD0ke1NFUlZJQ0VfUEFTU1dPUkRfUE9TVEdSRVN9JwogICAgICAtICdQT1NUR1JFU19VU0VSPSR7U0VSVklDRV9VU0VSX1BPU1RHUkVTfScKICAgICAgLSAnUE9TVEdSRVNfREI9JHtQT1NUR1JFU19EQjotd2luZG1pbGwtZGJ9JwogICAgaGVhbHRoY2hlY2s6CiAgICAgIHRlc3Q6CiAgICAgICAgLSBDTUQtU0hFTEwKICAgICAgICAtICdwZ19pc3JlYWR5IC1VICQke1BPU1RHUkVTX1VTRVJ9IC1kICQke1BPU1RHUkVTX0RCfScKICAgICAgaW50ZXJ2YWw6IDEwcwogICAgICB0aW1lb3V0OiA1cwogICAgICByZXRyaWVzOiA1CiAgd2luZG1pbGwtc2VydmVyOgogICAgaW1hZ2U6ICdnaGNyLmlvL3dpbmRtaWxsLWxhYnMvd2luZG1pbGw6bWFpbicKICAgIGVudmlyb25tZW50OgogICAgICAtIFNFUlZJQ0VfRlFETl9XSU5ETUlMTF84MDAwCiAgICAgIC0gJ0RBVEFCQVNFX1VSTD1wb3N0Z3JlczovLyR7U0VSVklDRV9VU0VSX1BPU1RHUkVTfToke1NFUlZJQ0VfUEFTU1dPUkRfUE9TVEdSRVN9QGRiLyR7UE9TVEdSRVNfREI6LXdpbmRtaWxsLWRifScKICAgICAgLSBNT0RFPXNlcnZlcgogICAgICAtICdCQVNFX1VSTD0ke1NFUlZJQ0VfRlFETl9XSU5ETUlMTH0nCiAgICBkZXBlbmRzX29uOgogICAgICBkYjoKICAgICAgICBjb25kaXRpb246IHNlcnZpY2VfaGVhbHRoeQogICAgdm9sdW1lczoKICAgICAgLSAnd29ya2VyLWxvZ3M6L3RtcC93aW5kbWlsbC9sb2dzJwogICAgaGVhbHRoY2hlY2s6CiAgICAgIHRlc3Q6CiAgICAgICAgLSBDTUQKICAgICAgICAtIGN1cmwKICAgICAgICAtICctZicKICAgICAgICAtICdodHRwOi8vbG9jYWxob3N0OjgwMDAvaGVhbHRoJwogICAgICBpbnRlcnZhbDogMzBzCiAgICAgIHRpbWVvdXQ6IDEwcwogICAgICByZXRyaWVzOiAzCiAgd2luZG1pbGwtd29ya2VyLTE6CiAgICBpbWFnZTogJ2doY3IuaW8vd2luZG1pbGwtbGFicy93aW5kbWlsbDptYWluJwogICAgZW52aXJvbm1lbnQ6CiAgICAgIC0gJ0RBVEFCQVNFX1VSTD1wb3N0Z3JlczovLyR7U0VSVklDRV9VU0VSX1BPU1RHUkVTfToke1NFUlZJQ0VfUEFTU1dPUkRfUE9TVEdSRVN9QGRiLyR7UE9TVEdSRVNfREI6LXdpbmRtaWxsLWRifScKICAgICAgLSBNT0RFPXdvcmtlcgogICAgICAtIFdPUktFUl9HUk9VUD1kZWZhdWx0CiAgICBkZXBlbmRzX29uOgogICAgICBkYjoKICAgICAgICBjb25kaXRpb246IHNlcnZpY2VfaGVhbHRoeQogICAgdm9sdW1lczoKICAgICAgLSAnL3Zhci9ydW4vZG9ja2VyLnNvY2s6L3Zhci9ydW4vZG9ja2VyLnNvY2snCiAgICAgIC0gJ3dvcmtlci1kZXBlbmRlbmN5LWNhY2hlOi90bXAvd2luZG1pbGwvY2FjaGUnCiAgICAgIC0gJ3dvcmtlci1sb2dzOi90bXAvd2luZG1pbGwvbG9ncycKICAgIGhlYWx0aGNoZWNrOgogICAgICB0ZXN0OgogICAgICAgIC0gQ01ELVNIRUxMCiAgICAgICAgLSAnZXhpdCAwJwogICAgICBpbnRlcnZhbDogMzBzCiAgICAgIHRpbWVvdXQ6IDEwcwogICAgICByZXRyaWVzOiAzCiAgd2luZG1pbGwtd29ya2VyLTI6CiAgICBpbWFnZTogJ2doY3IuaW8vd2luZG1pbGwtbGFicy93aW5kbWlsbDptYWluJwogICAgZW52aXJvbm1lbnQ6CiAgICAgIC0gJ0RBVEFCQVNFX1VSTD1wb3N0Z3JlczovLyR7U0VSVklDRV9VU0VSX1BPU1RHUkVTfToke1NFUlZJQ0VfUEFTU1dPUkRfUE9TVEdSRVN9QGRiLyR7UE9TVEdSRVNfREI6LXdpbmRtaWxsLWRifScKICAgICAgLSBNT0RFPXdvcmtlcgogICAgICAtIFdPUktFUl9HUk9VUD1kZWZhdWx0CiAgICBkZXBlbmRzX29uOgogICAgICBkYjoKICAgICAgICBjb25kaXRpb246IHNlcnZpY2VfaGVhbHRoeQogICAgdm9sdW1lczoKICAgICAgLSAnL3Zhci9ydW4vZG9ja2VyLnNvY2s6L3Zhci9ydW4vZG9ja2VyLnNvY2snCiAgICAgIC0gJ3dvcmtlci1kZXBlbmRlbmN5LWNhY2hlOi90bXAvd2luZG1pbGwvY2FjaGUnCiAgICAgIC0gJ3dvcmtlci1sb2dzOi90bXAvd2luZG1pbGwvbG9ncycKICAgIGhlYWx0aGNoZWNrOgogICAgICB0ZXN0OgogICAgICAgIC0gQ01ELVNIRUxMCiAgICAgICAgLSAnZXhpdCAwJwogICAgICBpbnRlcnZhbDogMzBzCiAgICAgIHRpbWVvdXQ6IDEwcwogICAgICByZXRyaWVzOiAzCiAgd2luZG1pbGwtd29ya2VyLTM6CiAgICBpbWFnZTogJ2doY3IuaW8vd2luZG1pbGwtbGFicy93aW5kbWlsbDptYWluJwogICAgZW52aXJvbm1lbnQ6CiAgICAgIC0gJ0RBVEFCQVNFX1VSTD1wb3N0Z3JlczovLyR7U0VSVklDRV9VU0VSX1BPU1RHUkVTfToke1NFUlZJQ0VfUEFTU1dPUkRfUE9TVEdSRVN9QGRiLyR7UE9TVEdSRVNfREI6LXdpbmRtaWxsLWRifScKICAgICAgLSBNT0RFPXdvcmtlcgogICAgICAtIFdPUktFUl9HUk9VUD1kZWZhdWx0CiAgICBkZXBlbmRzX29uOgogICAgICBkYjoKICAgICAgICBjb25kaXRpb246IHNlcnZpY2VfaGVhbHRoeQogICAgdm9sdW1lczoKICAgICAgLSAnL3Zhci9ydW4vZG9ja2VyLnNvY2s6L3Zhci9ydW4vZG9ja2VyLnNvY2snCiAgICAgIC0gJ3dvcmtlci1kZXBlbmRlbmN5LWNhY2hlOi90bXAvd2luZG1pbGwvY2FjaGUnCiAgICAgIC0gJ3dvcmtlci1sb2dzOi90bXAvd2luZG1pbGwvbG9ncycKICAgIGhlYWx0aGNoZWNrOgogICAgICB0ZXN0OgogICAgICAgIC0gQ01ELVNIRUxMCiAgICAgICAgLSAnZXhpdCAwJwogICAgICBpbnRlcnZhbDogMzBzCiAgICAgIHRpbWVvdXQ6IDEwcwogICAgICByZXRyaWVzOiAzCiAgd2luZG1pbGwtd29ya2VyLW5hdGl2ZToKICAgIGltYWdlOiAnZ2hjci5pby93aW5kbWlsbC1sYWJzL3dpbmRtaWxsOm1haW4nCiAgICBlbnZpcm9ubWVudDoKICAgICAgLSAnREFUQUJBU0VfVVJMPXBvc3RncmVzOi8vJHtTRVJWSUNFX1VTRVJfUE9TVEdSRVN9OiR7U0VSVklDRV9QQVNTV09SRF9QT1NUR1JFU31AZGIvJHtQT1NUR1JFU19EQjotd2luZG1pbGwtZGJ9JwogICAgICAtIE1PREU9d29ya2VyCiAgICAgIC0gV09SS0VSX0dST1VQPW5hdGl2ZQogICAgICAtIE5VTV9XT1JLRVJTPTgKICAgICAgLSBTTEVFUF9RVUVVRT0yMDAKICAgIGRlcGVuZHNfb246CiAgICAgIGRiOgogICAgICAgIGNvbmRpdGlvbjogc2VydmljZV9oZWFsdGh5CiAgICB2b2x1bWVzOgogICAgICAtICd3b3JrZXItbG9nczovdG1wL3dpbmRtaWxsL2xvZ3MnCiAgICBoZWFsdGhjaGVjazoKICAgICAgdGVzdDoKICAgICAgICAtIENNRC1TSEVMTAogICAgICAgIC0gJ2V4aXQgMCcKICAgICAgaW50ZXJ2YWw6IDMwcwogICAgICB0aW1lb3V0OiAxMHMKICAgICAgcmV0cmllczogMwogIGxzcDoKICAgIGltYWdlOiAnZ2hjci5pby93aW5kbWlsbC1sYWJzL3dpbmRtaWxsLWxzcDpsYXRlc3QnCiAgICB2b2x1bWVzOgogICAgICAtICdsc3AtY2FjaGU6L3Jvb3QvLmNhY2hlJwogICAgaGVhbHRoY2hlY2s6CiAgICAgIHRlc3Q6CiAgICAgICAgLSBDTUQtU0hFTEwKICAgICAgICAtICdleGl0IDAnCiAgICAgIGludGVydmFsOiAzMHMKICAgICAgdGltZW91dDogMTBzCiAgICAgIHJldHJpZXM6IDMKICAgICAgc3RhcnRfcGVyaW9kOiAyMHMK",
"tags": [
"windmill",
"workflow",
@@ -2677,31 +2683,6 @@
"logo": "svgs/wordpress.svg",
"minversion": "0.0.0"
},
- "zep": {
- "documentation": "https://help.getzep.com/concepts?utm_source=coolify.io",
- "slogan": "Zep enhances your AI agent's knowledge through continuous learning from user interactions, enabling personalized experiences and improved accuracy.",
- "compose": "services:
  postgres:
    image: 'ghcr.io/getzep/postgres:postgres-15'
    shm_size: 128mb
    environment:
      - 'POSTGRES_USER=${SERVICE_USER_POSTGRES}'
      - 'POSTGRES_PASSWORD=${SERVICE_PASSWORD_POSTGRES}'
    volumes:
      - 'pg_data:/var/lib/postgresql/data'
    healthcheck:
      test:
        - CMD-SHELL
        - 'pg_isready -h localhost -U $${POSTGRES_USER} -d postgres'
      interval: 5s
      timeout: 5s
      retries: 5
  nlp:
    image: 'ghcr.io/getzep/zep-nlp-server:0.4'
    environment:
      - SERVICE_FQDN_NLP_5557
      - 'ZEP_OPENAI_API_KEY=${OPENAI_API_KEY}'
      - 'ZEP_AUTH_SECRET=${SERVICE_PASSWORD_AUTHSECRET}'
      - 'ZEP_SERVER_WEB_ENABLED=${ZEP_SERVER_WEB_ENABLED:-false}'
    healthcheck:
      test: "timeout 10s bash -c ':> /dev/tcp/127.0.0.1/5557' || exit 1"
      interval: 10s
      timeout: 5s
      retries: 5
      start_period: 45s
  zep:
    image: 'ghcr.io/getzep/zep:latest'
    depends_on:
      postgres:
        condition: service_healthy
      nlp:
        condition: service_healthy
    environment:
      - SERVICE_FQDN_ZEP_8000
      - 'ZEP_STORE_POSTGRES_DSN=postgres://${SERVICE_USER_POSTGRES}:${SERVICE_PASSWORD_POSTGRES}@postgres:5432/postgres?sslmode=disable'
      - 'ZEP_NLP_SERVER_URL=http://nlp:5557'
      - 'ZEP_EXTRACTORS_DOCUMENTS_EMBEDDINGS_SERVICE=${EXTRACTORS_DOCUMENTS_EMBEDDINGS_SERVICE:-openai}'
      - 'ZEP_EXTRACTORS_DOCUMENTS_EMBEDDINGS_DIMENSIONS=${EXTRACTORS_DOCUMENTS_EMBEDDINGS_DIMENSIONS:-1536}'
      - 'ZEP_EXTRACTORS_MESSAGES_EMBEDDINGS_SERVICE=${EXTRACTORS_MESSAGES_EMBEDDINGS_SERVICE:-openai}'
      - 'ZEP_EXTRACTORS_MESSAGES_EMBEDDINGS_DIMENSIONS=${EXTRACTORS_MESSAGES_EMBEDDINGS_DIMENSIONS:-1536}'
      - 'ZEP_EXTRACTORS_MESSAGES_SUMMARIZER_EMBEDDINGS_SERVICE=${EXTRACTORS_MESSAGES_SUMMARIZER_EMBEDDINGS_SERVICE:-openai}'
      - 'ZEP_EXTRACTORS_MESSAGES_SUMMARIZER_EMBEDDINGS_DIMENSIONS=${EXTRACTORS_MESSAGES_SUMMARIZER_EMBEDDINGS_DIMENSIONS:-1536}'
      - 'ZEP_OPENAI_API_KEY=${OPENAI_API_KEY}'
      - 'ZEP_AUTH_SECRET=${SERVICE_PASSWORD_AUTHSECRET}'
      - 'ZEP_SERVER_WEB_ENABLED=${ZEP_SERVER_WEB_ENABLED:-false}'
    volumes:
      -
        type: bind
        source: ./config.yaml
        target: /app/config.yaml
        content: "llm:\n  # openai or anthropic\n  service: \"openai\"\n  # OpenAI: gpt-3.5-turbo, gpt-4, gpt-3.5-turbo-1106, gpt-3.5-turbo-16k, gpt-4-32k, gpt-4o-mini, gpt-4o-mini-2024-07-18; Anthropic: claude-instant-1 or claude-2\n  model: \"gpt-4o-mini\"\n  ## OpenAI-specific settings\n  # Only used for Azure OpenAI API\n  azure_openai_endpoint:\n  # for Azure OpenAI API deployment, the model may be deployed with custom deployment names\n  # set the deployment names if you encounter in logs HTTP 404 errors:\n  #   \"The API deployment for this resource does not exist.\"\n  azure_openai:\n  # llm.model name is used as deployment name as reasonable default if not set\n  # assuming base model is deployed with deployment name matching model name\n  #   llm_deployment: \"gpt-4o-mini-customname\"\n  # embeddings deployment is required when Zep is configured to use OpenAI embeddings\n  #   embedding_deployment: \"text-embedding-ada-002-customname\"\n  # Use only with an alternate OpenAI-compatible API endpoint\n    llm_deployment:\n    embedding_deployment:\n  openai_endpoint:\n  openai_org_id:\nnlp:\n  server_url: \"http://localhost:5557\"\nmemory:\n  message_window: 12\nextractors:\n  documents:\n    embeddings:\n      enabled: true\n      chunk_size: 1000\n      dimensions: 384\n      service: \"local\"\n#      dimensions: 1536\n#      service: \"openai\"\n  messages:\n    summarizer:\n      enabled: true\n      entities:\n        enabled: true\n      embeddings:\n        enabled: true\n        dimensions: 384\n        service: \"local\"\n    entities:\n      enabled: true\n    intent:\n      enabled: true\n    embeddings:\n      enabled: true\n      dimensions: 384\n      service: \"local\"\n#      dimensions: 1536\n#      service: \"openai\"\nstore:\n  type: \"postgres\"\n  postgres:\n    dsn: \"postgres://postgres:postgres@localhost:5432/?sslmode=disable\"\nserver:\n  # Specify the host to listen on. Defaults to 0.0.0.0\n  host: 0.0.0.0\n  port: 8000\n  # Is the Web UI enabled?\n  # Warning: The Web UI is not secured by authentication and should not be enabled if\n  # Zep is exposed to the public internet.\n  web_enabled: true\n  # The maximum size of a request body, in bytes. Defaults to 5MB.\n  max_request_size: 5242880\nauth:\n  # Set to true to enable authentication\n  required: true\n  # Do not use this secret in production. The ZEP_AUTH_SECRET environment variable should be\n  # set to a cryptographically secure secret. See the Zep docs for details.\n  secret: \"do-not-use-this-secret-in-production\"\ndata:\n  #  PurgeEvery is the period between hard deletes, in minutes.\n  #  If set to 0 or undefined, hard deletes will not be performed.\n  purge_every: 60\nlog:\n  level: \"info\"\nopentelemetry:\n  enabled: false\n# Custom Prompts Configuration\n# Allows customization of extractor prompts.\ncustom_prompts:\n  summarizer_prompts:\n    # Anthropic Guidelines:\n    # - Use XML-style tags like <current_summary> as element identifiers.\n    # - Include {{.PrevSummary}} and {{.MessagesJoined}} as template variables.\n    # - Clearly explain model instructions, e.g., \"Review content inside <current_summary></current_summary> tags\".\n    # - Provide a clear example within the prompt.\n    #\n    # Example format:\n    # anthropic: |\n    #   <YOUR INSTRUCTIONS HERE>\n    #   <example>\n    #     <PROVIDE AN EXAMPLE>\n    #   </example>\n    #   <current_summary>{{.PrevSummary}}</current_summary>\n    #   <new_lines>{{.MessagesJoined}}</new_lines>\n    #   Response without preamble.\n    #\n    # If left empty, the default Anthropic summary prompt from zep/pkg/extractors/prompts.go will be used.\n    anthropic: |\n\n    # OpenAI summarizer prompt configuration.\n    # Guidelines:\n    # - Include {{.PrevSummary}} and {{.MessagesJoined}} as template variables.\n    # - Provide a clear example within the prompt.\n    #\n    # Example format:\n    # openai: |\n    #   <YOUR INSTRUCTIONS HERE>\n    #   Example:\n    #     <PROVIDE AN EXAMPLE>\n    #   Current summary: {{.PrevSummary}}\n    #   New lines of conversation: {{.MessagesJoined}}\n    #   New summary:`\n    #\n    # If left empty, the default OpenAI summary prompt from zep/pkg/extractors/prompts.go will be used.\n    openai: |"
    healthcheck:
      test: "timeout 10s bash -c ':> /dev/tcp/127.0.0.1/8000' || exit 1"
      interval: 5s
      timeout: 10s
      retries: 3
      start_period: 40s
",
- "tags": [
- "lowcode",
- "nocode",
- "ai",
- "llm",
- "openai",
- "anthropic",
- "machine-learning",
- "rag",
- "agents",
- "chatbot",
- "api",
- "team",
- "bot",
- "flows",
- "memory"
- ],
- "logo": "svgs/zep.png",
- "minversion": "0.0.0",
- "port": "8000"
- },
"zipline": {
"documentation": "https://github.com/diced/zipline?utm_source=coolify.io",
"slogan": "A ShareX/file upload server that is easy to use, packed with features, and with an easy setup!",
diff --git a/tests/Browser/ExampleTest.php b/tests/Browser/ExampleTest.php
deleted file mode 100644
index 15dc8f5f1..000000000
--- a/tests/Browser/ExampleTest.php
+++ /dev/null
@@ -1,20 +0,0 @@
-browse(function (Browser $browser) {
- $browser->visit('/')
- ->assertSee('Laravel');
- });
- }
-}
diff --git a/tests/Browser/LoginTest.php b/tests/Browser/LoginTest.php
new file mode 100644
index 000000000..cac9a65fe
--- /dev/null
+++ b/tests/Browser/LoginTest.php
@@ -0,0 +1,32 @@
+browse(function (Browser $browser) use ($password, $email) {
+ $browser->visit('/login')
+ ->type('email', $email)
+ ->type('password', $password)
+ ->press('Login')
+ ->assertPathIs('/')
+ ->screenshot('login');
+ });
+ }
+}
diff --git a/tests/DuskTestCase.php b/tests/DuskTestCase.php
index 8628871a1..98e90fa79 100644
--- a/tests/DuskTestCase.php
+++ b/tests/DuskTestCase.php
@@ -39,7 +39,7 @@ abstract class DuskTestCase extends BaseTestCase
})->all());
return RemoteWebDriver::create(
- $_ENV['DUSK_DRIVER_URL'] ?? 'http://localhost:9515',
+ 'http://localhost:4444',
DesiredCapabilities::chrome()->setCapability(
ChromeOptions::CAPABILITY,
$options
@@ -50,23 +50,8 @@ abstract class DuskTestCase extends BaseTestCase
/**
* Determine if the browser window should start maximized.
*/
- protected function shouldStartMaximized(): bool
- {
- return isset($_SERVER['DUSK_START_MAXIMIZED']) ||
- isset($_ENV['DUSK_START_MAXIMIZED']);
- }
-
- /**
- * Determine whether the Dusk command has disabled headless mode.
- */
- protected function hasHeadlessDisabled(): bool
- {
- return isset($_SERVER['DUSK_HEADLESS_DISABLED']) ||
- isset($_ENV['DUSK_HEADLESS_DISABLED']);
- }
-
protected function baseUrl()
{
- return rtrim(config('app.url'), '/');
+ return 'http://localhost:8000';
}
}
diff --git a/versions.json b/versions.json
index 7d8a9b2d1..e24038001 100644
--- a/versions.json
+++ b/versions.json
@@ -1,7 +1,7 @@
{
"coolify": {
"v4": {
- "version": "4.0.0-beta.361"
+ "version": "4.0.0-beta.360"
},
"nightly": {
"version": "4.0.0-beta.362"
@@ -11,6 +11,9 @@
},
"realtime": {
"version": "1.0.3"
+ },
+ "sentinel": {
+ "version": "next"
}
}
}
|