Compare commits
29 Commits
f460703e37
...
renovate/p
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
6c855009d6 | ||
| 1f541189a6 | |||
| d706fcdcd8 | |||
| 819f145200 | |||
| 9598316e7d | |||
| 8a04ba27d4 | |||
|
|
6aec3c1f25 | ||
|
|
0128da950f | ||
|
|
7277c47ad9 | ||
|
|
003b9db402 | ||
|
|
29446b72c3 | ||
|
|
0e2c6a889a | ||
| def08d6c00 | |||
| f37d9e1a68 | |||
|
|
4e0012ba18 | ||
|
|
ebfe68c838 | ||
| 279f35f7e9 | |||
| c724d43e4d | |||
| f7a90f823d | |||
| faaca0dd64 | |||
| e06cc2e7b7 | |||
|
|
5f834bab2f | ||
|
|
52477db4ad | ||
|
|
74bdd11775 | ||
|
|
8168134448 | ||
|
|
70b8b4bf7c | ||
|
|
f0631f3e3d | ||
| e827dd1bc9 | |||
|
|
9b592465f7 |
@@ -1,6 +1,6 @@
|
|||||||
services:
|
services:
|
||||||
audiobookshelf:
|
audiobookshelf:
|
||||||
image: ghcr.io/advplyr/audiobookshelf:2.30.0
|
image: ghcr.io/advplyr/audiobookshelf:2.31.0
|
||||||
restart: always
|
restart: always
|
||||||
ports:
|
ports:
|
||||||
- 13378:80
|
- 13378:80
|
||||||
|
|||||||
@@ -1,4 +1,3 @@
|
|||||||
version: '3.8'
|
|
||||||
services:
|
services:
|
||||||
# Redis service for RQ (task queue)
|
# Redis service for RQ (task queue)
|
||||||
audiomuse-ai-redis:
|
audiomuse-ai-redis:
|
||||||
@@ -14,7 +13,7 @@ services:
|
|||||||
|
|
||||||
# PostgreSQL database service
|
# PostgreSQL database service
|
||||||
audiomuse-ai-postgres:
|
audiomuse-ai-postgres:
|
||||||
image: postgres:15-alpine
|
image: postgres:18-alpine
|
||||||
container_name: audiomuse-postgres
|
container_name: audiomuse-postgres
|
||||||
env_file:
|
env_file:
|
||||||
- .env
|
- .env
|
||||||
@@ -32,7 +31,7 @@ services:
|
|||||||
|
|
||||||
# AudioMuse-AI Flask application service
|
# AudioMuse-AI Flask application service
|
||||||
audiomuse-ai-flask:
|
audiomuse-ai-flask:
|
||||||
image: ghcr.io/neptunehub/audiomuse-ai:latest # Reflects deployment.yaml
|
image: ghcr.io/neptunehub/audiomuse-ai:0.8.2 # Reflects deployment.yaml
|
||||||
container_name: audiomuse-ai-flask-app
|
container_name: audiomuse-ai-flask-app
|
||||||
ports:
|
ports:
|
||||||
- "8013:8000"
|
- "8013:8000"
|
||||||
@@ -70,7 +69,7 @@ services:
|
|||||||
|
|
||||||
# AudioMuse-AI RQ Worker service
|
# AudioMuse-AI RQ Worker service
|
||||||
audiomuse-ai-worker:
|
audiomuse-ai-worker:
|
||||||
image: ghcr.io/neptunehub/audiomuse-ai:latest # Reflects deployment.yaml
|
image: ghcr.io/neptunehub/audiomuse-ai:0.8.2 # Reflects deployment.yaml
|
||||||
container_name: audiomuse-ai-worker-instance
|
container_name: audiomuse-ai-worker-instance
|
||||||
env_file:
|
env_file:
|
||||||
- .env
|
- .env
|
||||||
|
|||||||
@@ -10,7 +10,6 @@ include:
|
|||||||
- pihole/docker-compose.yml
|
- pihole/docker-compose.yml
|
||||||
- pingvin/docker-compose.yml
|
- pingvin/docker-compose.yml
|
||||||
- pocketid/docker-compose.yml
|
- pocketid/docker-compose.yml
|
||||||
- postgres/docker-compose.yml
|
|
||||||
- spliit/docker-compose.yml
|
- spliit/docker-compose.yml
|
||||||
- shlink/docker-compose.yml
|
- shlink/docker-compose.yml
|
||||||
- synapse/docker-compose.yml
|
- synapse/docker-compose.yml
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
services:
|
services:
|
||||||
gitea:
|
gitea:
|
||||||
container_name: gitea
|
container_name: gitea
|
||||||
image: gitea/gitea:1.25.1-rootless
|
image: gitea/gitea:1.25.2-rootless
|
||||||
restart: always
|
restart: always
|
||||||
volumes:
|
volumes:
|
||||||
- ${GITEA_DATA_LOCATION}:/var/lib/gitea
|
- ${GITEA_DATA_LOCATION}:/var/lib/gitea
|
||||||
|
|||||||
@@ -1,48 +0,0 @@
|
|||||||
services:
|
|
||||||
immich-server:
|
|
||||||
container_name: immich_server
|
|
||||||
image: ghcr.io/immich-app/immich-server:v2.2.3
|
|
||||||
volumes:
|
|
||||||
- ${UPLOAD_LOCATION}:/data
|
|
||||||
- /etc/localtime:/etc/localtime:ro
|
|
||||||
env_file:
|
|
||||||
- .env
|
|
||||||
environment:
|
|
||||||
DB_HOSTNAME: shared-postgres
|
|
||||||
DB_PORT: 5432
|
|
||||||
DB_USERNAME: ${IMMICH_POSTGRES_USER}
|
|
||||||
DB_PASSWORD: ${IMMICH_POSTGRES_PASSWORD}
|
|
||||||
DB_DATABASE_NAME: ${IMMICH_POSTGRES_DB}
|
|
||||||
ports:
|
|
||||||
- '2283:2283'
|
|
||||||
depends_on:
|
|
||||||
shared-postgres:
|
|
||||||
condition: service_healthy
|
|
||||||
redis:
|
|
||||||
condition: service_started
|
|
||||||
restart: always
|
|
||||||
networks:
|
|
||||||
- postgres-network
|
|
||||||
|
|
||||||
immich-machine-learning:
|
|
||||||
container_name: immich_machine_learning
|
|
||||||
image: ghcr.io/immich-app/immich-machine-learning:v2.2.3
|
|
||||||
volumes:
|
|
||||||
- model-cache:/cache
|
|
||||||
env_file:
|
|
||||||
- .env
|
|
||||||
restart: always
|
|
||||||
|
|
||||||
redis:
|
|
||||||
container_name: immich_redis
|
|
||||||
image: docker.io/redis:7.4-alpine@sha256:1bf97f21f01b0e7bd4b7b34a26d3b9d8086e41e70c10f262e8a9e0b49b5116a0
|
|
||||||
healthcheck:
|
|
||||||
test: redis-cli ping || exit 1
|
|
||||||
restart: always
|
|
||||||
|
|
||||||
volumes:
|
|
||||||
model-cache:
|
|
||||||
|
|
||||||
networks:
|
|
||||||
postgres-network:
|
|
||||||
external: true
|
|
||||||
@@ -34,7 +34,7 @@ services:
|
|||||||
|
|
||||||
redis:
|
redis:
|
||||||
container_name: immich_redis
|
container_name: immich_redis
|
||||||
image: docker.io/valkey/valkey:8@sha256:81db6d39e1bba3b3ff32bd3a1b19a6d69690f94a3954ec131277b9a26b95b3aa
|
image: docker.io/valkey/valkey:9@sha256:fb8d272e529ea567b9bf1302245796f21a2672b8368ca3fcb938ac334e613c8f
|
||||||
healthcheck:
|
healthcheck:
|
||||||
test: redis-cli ping || exit 1
|
test: redis-cli ping || exit 1
|
||||||
restart: always
|
restart: always
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
services:
|
services:
|
||||||
jellyfin:
|
jellyfin:
|
||||||
image: jellyfin/jellyfin:10.11.3
|
image: jellyfin/jellyfin:10.11.5
|
||||||
user: ${JELLYFIN_USER_UID}:${JELLYFIN_USER_GID}
|
user: ${JELLYFIN_USER_UID}:${JELLYFIN_USER_GID}
|
||||||
network_mode: 'host'
|
network_mode: 'host'
|
||||||
restart: always
|
restart: always
|
||||||
|
|||||||
@@ -1,47 +0,0 @@
|
|||||||
services:
|
|
||||||
nextcloud_db:
|
|
||||||
# Remove this service - using shared-postgres instead
|
|
||||||
|
|
||||||
nextcloud:
|
|
||||||
image: nextcloud:31.0.9
|
|
||||||
restart: always
|
|
||||||
ports:
|
|
||||||
- 8081:80
|
|
||||||
volumes:
|
|
||||||
- ${NEXTCLOUD_DATA_DIR}:/var/www/html
|
|
||||||
environment:
|
|
||||||
- POSTGRES_HOST=shared-postgres
|
|
||||||
- POSTGRES_PORT=5432
|
|
||||||
- POSTGRES_DB=${NEXTCLOUD_POSTGRES_DB}
|
|
||||||
- POSTGRES_USER=${NEXTCLOUD_POSTGRES_USER}
|
|
||||||
- POSTGRES_PASSWORD=${NEXTCLOUD_POSTGRES_PASSWORD}
|
|
||||||
- REDIS_HOST=nextcloud-redis
|
|
||||||
- REDIS_PORT=6379
|
|
||||||
- NEXTCLOUD_TRUSTED_DOMAINS=${NEXTCLOUD_DOMAIN}
|
|
||||||
depends_on:
|
|
||||||
shared-postgres:
|
|
||||||
condition: service_healthy
|
|
||||||
networks:
|
|
||||||
- nextcloud
|
|
||||||
- postgres-network
|
|
||||||
|
|
||||||
cron:
|
|
||||||
image: nextcloud:31.0.9
|
|
||||||
container_name: nextcloud-cron
|
|
||||||
volumes:
|
|
||||||
- ${NEXTCLOUD_DATA_DIR}:/var/www/html
|
|
||||||
entrypoint: /cron.sh
|
|
||||||
restart: always
|
|
||||||
networks:
|
|
||||||
- nextcloud
|
|
||||||
|
|
||||||
nextcloud-redis:
|
|
||||||
image: redis:7
|
|
||||||
restart: always
|
|
||||||
networks:
|
|
||||||
- nextcloud
|
|
||||||
|
|
||||||
networks:
|
|
||||||
nextcloud:
|
|
||||||
postgres-network:
|
|
||||||
external: true
|
|
||||||
@@ -13,7 +13,7 @@ services:
|
|||||||
networks:
|
networks:
|
||||||
- nextcloud
|
- nextcloud
|
||||||
nextcloud:
|
nextcloud:
|
||||||
image: nextcloud:32.0.1
|
image: nextcloud:32.0.3
|
||||||
restart: always
|
restart: always
|
||||||
ports:
|
ports:
|
||||||
- 8081:80
|
- 8081:80
|
||||||
@@ -32,7 +32,7 @@ services:
|
|||||||
networks:
|
networks:
|
||||||
- nextcloud
|
- nextcloud
|
||||||
cron:
|
cron:
|
||||||
image: nextcloud:32.0.1
|
image: nextcloud:32.0.3
|
||||||
container_name: nextcloud-cron
|
container_name: nextcloud-cron
|
||||||
volumes:
|
volumes:
|
||||||
- ${NEXTCLOUD_DATA_DIR}:/var/www/html
|
- ${NEXTCLOUD_DATA_DIR}:/var/www/html
|
||||||
|
|||||||
@@ -1,54 +0,0 @@
|
|||||||
services:
|
|
||||||
broker:
|
|
||||||
image: docker.io/library/redis:7
|
|
||||||
restart: always
|
|
||||||
volumes:
|
|
||||||
- ${PAPERLESS_REDIS_DATA_DIR}:/data
|
|
||||||
|
|
||||||
paperless:
|
|
||||||
image: ghcr.io/paperless-ngx/paperless-ngx:2.18.4
|
|
||||||
restart: always
|
|
||||||
depends_on:
|
|
||||||
shared-postgres:
|
|
||||||
condition: service_healthy
|
|
||||||
broker:
|
|
||||||
condition: service_started
|
|
||||||
gotenberg:
|
|
||||||
condition: service_started
|
|
||||||
tika:
|
|
||||||
condition: service_started
|
|
||||||
ports:
|
|
||||||
- "8070:8000"
|
|
||||||
volumes:
|
|
||||||
- ${PAPERLESS_DATA_DIR}:/usr/src/paperless/data
|
|
||||||
- ${PAPERLESS_MEDIA_DIR}:/usr/src/paperless/media
|
|
||||||
- ${PAPERLESS_EXPORT_DIR}/export:/usr/src/paperless/export
|
|
||||||
- ${PAPERLESS_CONSUME_DIR}:/usr/src/paperless/consume
|
|
||||||
env_file: .env
|
|
||||||
environment:
|
|
||||||
PAPERLESS_REDIS: redis://broker:6379
|
|
||||||
PAPERLESS_DBHOST: shared-postgres
|
|
||||||
PAPERLESS_DBPORT: 5432
|
|
||||||
PAPERLESS_DBNAME: ${PAPERLESS_POSTGRES_DB}
|
|
||||||
PAPERLESS_DBUSER: ${PAPERLESS_POSTGRES_USER}
|
|
||||||
PAPERLESS_DBPASS: ${PAPERLESS_POSTGRES_PASSWORD}
|
|
||||||
PAPERLESS_TIKA_ENABLED: 1
|
|
||||||
PAPERLESS_TIKA_GOTENBERG_ENDPOINT: http://gotenberg:3000
|
|
||||||
PAPERLESS_TIKA_ENDPOINT: http://tika:9998
|
|
||||||
PAPERLESS_APPS: "allauth.socialaccount.providers.openid_connect"
|
|
||||||
USE_X_FORWARD_HOST: true
|
|
||||||
USE_X_FORWARDED_PORT: true
|
|
||||||
PAPERLESS_DISABLE_REGULAR_LOGIN: true
|
|
||||||
PAPERLESS_REDIRECT_LOGIN_TO_SSO: true
|
|
||||||
networks:
|
|
||||||
- postgres-network
|
|
||||||
|
|
||||||
gotenberg:
|
|
||||||
# ... existing gotenberg configuration ...
|
|
||||||
|
|
||||||
tika:
|
|
||||||
# ... existing tika configuration ...
|
|
||||||
|
|
||||||
networks:
|
|
||||||
postgres-network:
|
|
||||||
external: true
|
|
||||||
@@ -2,7 +2,7 @@
|
|||||||
services:
|
services:
|
||||||
pihole:
|
pihole:
|
||||||
container_name: pihole
|
container_name: pihole
|
||||||
image: pihole/pihole:2025.11.0
|
image: pihole/pihole:2025.11.1
|
||||||
ports:
|
ports:
|
||||||
# DNS Ports
|
# DNS Ports
|
||||||
- "53:53/tcp"
|
- "53:53/tcp"
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
services:
|
services:
|
||||||
pocket-id:
|
pocket-id:
|
||||||
image: ghcr.io/pocket-id/pocket-id:v1.15.0
|
image: ghcr.io/pocket-id/pocket-id:v1.16.0
|
||||||
restart: always
|
restart: always
|
||||||
env_file: .env
|
env_file: .env
|
||||||
ports:
|
ports:
|
||||||
|
|||||||
@@ -1,2 +0,0 @@
|
|||||||
SHARED_DB_PASSWORD=
|
|
||||||
SHARED_DB_DATA_DIR=
|
|
||||||
@@ -1,35 +0,0 @@
|
|||||||
services:
|
|
||||||
shared-postgres:
|
|
||||||
image: ghcr.io/immich-app/postgres:14-vectorchord0.3.0-pgvectors0.2.0
|
|
||||||
container_name: shared-postgres
|
|
||||||
restart: always
|
|
||||||
env_file:
|
|
||||||
# Env files for all services using this shared database
|
|
||||||
- ../spliit/.env
|
|
||||||
- ../shlink/.env
|
|
||||||
- ../immich/.env
|
|
||||||
- ../nextcloud/.env
|
|
||||||
- ../paperless/.env
|
|
||||||
- ../synapse/.env
|
|
||||||
environment:
|
|
||||||
POSTGRES_USER: postgres
|
|
||||||
POSTGRES_PASSWORD: ${SHARED_DB_PASSWORD}
|
|
||||||
POSTGRES_DB: postgres
|
|
||||||
POSTGRES_INITDB_ARGS: '--encoding=UTF-8 --locale=C --data-checksums'
|
|
||||||
volumes:
|
|
||||||
- ${SHARED_DB_DATA_DIR}:/var/lib/postgresql/data
|
|
||||||
- ./init-scripts:/docker-entrypoint-initdb.d:ro
|
|
||||||
ports:
|
|
||||||
- "5431:5432"
|
|
||||||
healthcheck:
|
|
||||||
test: ["CMD-SHELL", "pg_isready -U postgres"]
|
|
||||||
interval: 10s
|
|
||||||
timeout: 5s
|
|
||||||
retries: 5
|
|
||||||
networks:
|
|
||||||
- postgres-network
|
|
||||||
|
|
||||||
networks:
|
|
||||||
postgres-network:
|
|
||||||
name: postgres-network
|
|
||||||
driver: bridge
|
|
||||||
@@ -1,73 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
set -e
|
|
||||||
|
|
||||||
# This script initializes all databases and users for the homelab services
|
|
||||||
# It runs automatically when the PostgreSQL container starts for the first time
|
|
||||||
|
|
||||||
echo "Creating databases and users for homelab services..."
|
|
||||||
|
|
||||||
# Function to create database and user with restricted permissions
|
|
||||||
create_db_and_user() {
|
|
||||||
local db_name=$1
|
|
||||||
local db_user=$2
|
|
||||||
local db_password=$3
|
|
||||||
|
|
||||||
echo "Creating database: $db_name with user: $db_user"
|
|
||||||
|
|
||||||
psql -v ON_ERROR_STOP=1 --username "$POSTGRES_USER" --dbname "$POSTGRES_DB" <<-EOSQL
|
|
||||||
-- Create database
|
|
||||||
CREATE DATABASE "$db_name";
|
|
||||||
|
|
||||||
-- Create user with password
|
|
||||||
CREATE USER "$db_user" WITH ENCRYPTED PASSWORD '$db_password';
|
|
||||||
|
|
||||||
-- Grant connection to the specific database only
|
|
||||||
GRANT CONNECT ON DATABASE "$db_name" TO "$db_user";
|
|
||||||
|
|
||||||
-- Make user owner of the database
|
|
||||||
ALTER DATABASE "$db_name" OWNER TO "$db_user";
|
|
||||||
|
|
||||||
-- Connect to the specific database to set schema permissions
|
|
||||||
\c "$db_name"
|
|
||||||
|
|
||||||
-- Grant schema permissions
|
|
||||||
GRANT ALL ON SCHEMA public TO "$db_user";
|
|
||||||
GRANT ALL PRIVILEGES ON ALL TABLES IN SCHEMA public TO "$db_user";
|
|
||||||
GRANT ALL PRIVILEGES ON ALL SEQUENCES IN SCHEMA public TO "$db_user";
|
|
||||||
GRANT ALL PRIVILEGES ON ALL FUNCTIONS IN SCHEMA public TO "$db_user";
|
|
||||||
|
|
||||||
-- Set default privileges for future objects
|
|
||||||
ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT ALL ON TABLES TO "$db_user";
|
|
||||||
ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT ALL ON SEQUENCES TO "$db_user";
|
|
||||||
ALTER DEFAULT PRIVILEGES IN SCHEMA public GRANT ALL ON FUNCTIONS TO "$db_user";
|
|
||||||
|
|
||||||
-- Switch back to postgres database
|
|
||||||
\c postgres
|
|
||||||
EOSQL
|
|
||||||
}
|
|
||||||
|
|
||||||
# Create databases for each service
|
|
||||||
# Using environment variables that will be set in your .env file
|
|
||||||
|
|
||||||
# Spliit
|
|
||||||
create_db_and_user "${SPLIIT_POSTGRES_DB}" "${SPLIIT_POSTGRES_USER}" "${SPLIIT_POSTGRES_PASSWORD}"
|
|
||||||
|
|
||||||
# Shlink
|
|
||||||
create_db_and_user "${SHLINK_POSTGRES_DB}" "${SHLINK_POSTGRES_USER}" "${SHLINK_POSTGRES_PASSWORD}"
|
|
||||||
|
|
||||||
# Immich
|
|
||||||
create_db_and_user "${IMMICH_POSTGRES_DB}" "${IMMICH_POSTGRES_USER}" "${IMMICH_POSTGRES_PASSWORD}"
|
|
||||||
|
|
||||||
# Nextcloud
|
|
||||||
create_db_and_user "${NEXTCLOUD_POSTGRES_DB}" "${NEXTCLOUD_POSTGRES_USER}" "${NEXTCLOUD_POSTGRES_PASSWORD}"
|
|
||||||
|
|
||||||
# Paperless
|
|
||||||
create_db_and_user "${PAPERLESS_POSTGRES_DB}" "${PAPERLESS_POSTGRES_USER}" "${PAPERLESS_POSTGRES_PASSWORD}"
|
|
||||||
|
|
||||||
# Matrix and co
|
|
||||||
create_db_and_user "${SYNAPSE_POSTGRES_DB}" "${SYNAPSE_POSTGRES_USER}" "${SYNAPSE_POSTGRES_PASSWORD}"
|
|
||||||
create_db_and_user "${MAS_POSTGRES_DB}" "${MAS_POSTGRES_USER}" "${MAS_POSTGRES_PASSWORD}"
|
|
||||||
create_db_and_user "${MAUTRIX_SIGNAL_POSTGRES_DB}" "${MAUTRIX_SIGNAL_POSTGRES_USER}" "${MAUTRIX_SIGNAL_POSTGRES_PASSWORD}"
|
|
||||||
create_db_and_user "${MAUTRIX_WHATSAPP_POSTGRES_DB}" "${MAUTRIX_WHATSAPP_POSTGRES_USER}" "${MAUTRIX_WHATSAPP_POSTGRES_PASSWORD}"
|
|
||||||
|
|
||||||
echo "Database initialization completed successfully!"
|
|
||||||
@@ -1,35 +0,0 @@
|
|||||||
#!/bin/bash
|
|
||||||
set -e
|
|
||||||
|
|
||||||
# Enable vector extensions for Immich database
|
|
||||||
echo "Enabling vector extensions for Immich database..."
|
|
||||||
|
|
||||||
psql -v ON_ERROR_STOP=1 --username "$POSTGRES_USER" --dbname "${IMMICH_POSTGRES_DB}" <<-EOSQL
|
|
||||||
-- Create extensions as superuser
|
|
||||||
CREATE EXTENSION IF NOT EXISTS vectors;
|
|
||||||
CREATE EXTENSION IF NOT EXISTS earthdistance CASCADE;
|
|
||||||
|
|
||||||
-- Grant usage on the extension schemas to immich user
|
|
||||||
GRANT USAGE ON SCHEMA vectors TO ${IMMICH_POSTGRES_USER};
|
|
||||||
GRANT USAGE ON SCHEMA earthdistance TO ${IMMICH_POSTGRES_USER};
|
|
||||||
|
|
||||||
-- Grant all privileges on extension objects to immich user
|
|
||||||
GRANT ALL PRIVILEGES ON ALL TABLES IN SCHEMA vectors TO ${IMMICH_POSTGRES_USER};
|
|
||||||
GRANT ALL PRIVILEGES ON ALL SEQUENCES IN SCHEMA vectors TO ${IMMICH_POSTGRES_USER};
|
|
||||||
GRANT ALL PRIVILEGES ON ALL FUNCTIONS IN SCHEMA vectors TO ${IMMICH_POSTGRES_USER};
|
|
||||||
|
|
||||||
GRANT ALL PRIVILEGES ON ALL TABLES IN SCHEMA earthdistance TO ${IMMICH_POSTGRES_USER};
|
|
||||||
GRANT ALL PRIVILEGES ON ALL SEQUENCES IN SCHEMA earthdistance TO ${IMMICH_POSTGRES_USER};
|
|
||||||
GRANT ALL PRIVILEGES ON ALL FUNCTIONS IN SCHEMA earthdistance TO ${IMMICH_POSTGRES_USER};
|
|
||||||
|
|
||||||
-- Set default privileges for future extension objects
|
|
||||||
ALTER DEFAULT PRIVILEGES IN SCHEMA vectors GRANT ALL ON TABLES TO ${IMMICH_POSTGRES_USER};
|
|
||||||
ALTER DEFAULT PRIVILEGES IN SCHEMA vectors GRANT ALL ON SEQUENCES TO ${IMMICH_POSTGRES_USER};
|
|
||||||
ALTER DEFAULT PRIVILEGES IN SCHEMA vectors GRANT ALL ON FUNCTIONS TO ${IMMICH_POSTGRES_USER};
|
|
||||||
|
|
||||||
ALTER DEFAULT PRIVILEGES IN SCHEMA earthdistance GRANT ALL ON TABLES TO ${IMMICH_POSTGRES_USER};
|
|
||||||
ALTER DEFAULT PRIVILEGES IN SCHEMA earthdistance GRANT ALL ON SEQUENCES TO ${IMMICH_POSTGRES_USER};
|
|
||||||
ALTER DEFAULT PRIVILEGES IN SCHEMA earthdistance GRANT ALL ON FUNCTIONS TO ${IMMICH_POSTGRES_USER};
|
|
||||||
EOSQL
|
|
||||||
|
|
||||||
echo "Immich vector extensions enabled successfully!"
|
|
||||||
@@ -23,7 +23,9 @@
|
|||||||
"matrixdotorg/synapse",
|
"matrixdotorg/synapse",
|
||||||
"ghcr.io/element-hq/matrix-authentication-service",
|
"ghcr.io/element-hq/matrix-authentication-service",
|
||||||
"dock.mau.dev/mautrix/whatsapp",
|
"dock.mau.dev/mautrix/whatsapp",
|
||||||
"dock.mau.dev/mautrix/signal"
|
"dock.mau.dev/mautrix/signal",
|
||||||
|
"ghcr.io/element-hq/lk-jwt-service",
|
||||||
|
"livekit/livekit-server"
|
||||||
]
|
]
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
|||||||
@@ -1,27 +0,0 @@
|
|||||||
services:
|
|
||||||
shlink:
|
|
||||||
image: shlinkio/shlink:4.6
|
|
||||||
container_name: shlink
|
|
||||||
restart: always
|
|
||||||
ports:
|
|
||||||
- "8085:8080"
|
|
||||||
environment:
|
|
||||||
DEFAULT_DOMAIN: ${SHLINK_DOMAIN}
|
|
||||||
IS_HTTPS_ENABLED: ${SHLINK_IS_HTTPS_ENABLED}
|
|
||||||
GEOLITE_LICENSE_KEY: ${SHLINK_GEOIP_LICENSE_KEY}
|
|
||||||
INITIAL_API_KEY: ${SHLINK_API_KEY}
|
|
||||||
DB_DRIVER: postgres
|
|
||||||
DB_HOST: shared-postgres
|
|
||||||
DB_PORT: 5432
|
|
||||||
DB_NAME: ${SHLINK_POSTGRES_DB}
|
|
||||||
DB_USER: ${SHLINK_POSTGRES_USER}
|
|
||||||
DB_PASSWORD: ${SHLINK_POSTGRES_PASSWORD}
|
|
||||||
depends_on:
|
|
||||||
shared-postgres:
|
|
||||||
condition: service_healthy
|
|
||||||
networks:
|
|
||||||
- postgres-network
|
|
||||||
|
|
||||||
networks:
|
|
||||||
postgres-network:
|
|
||||||
external: true
|
|
||||||
@@ -18,7 +18,7 @@ services:
|
|||||||
depends_on:
|
depends_on:
|
||||||
- shlink_db
|
- shlink_db
|
||||||
shlink_db:
|
shlink_db:
|
||||||
image: postgres:17
|
image: postgres:18
|
||||||
container_name: shlink_db
|
container_name: shlink_db
|
||||||
restart: always
|
restart: always
|
||||||
volumes:
|
volumes:
|
||||||
|
|||||||
@@ -1,24 +0,0 @@
|
|||||||
services:
|
|
||||||
spliit:
|
|
||||||
image: ghcr.io/spliit-app/spliit:1.19.0
|
|
||||||
restart: always
|
|
||||||
ports:
|
|
||||||
- 3001:3000
|
|
||||||
depends_on:
|
|
||||||
shared-postgres:
|
|
||||||
condition: service_healthy
|
|
||||||
env_file:
|
|
||||||
- .env
|
|
||||||
environment:
|
|
||||||
TZ: ${TZ}
|
|
||||||
POSTGRES_HOST: shared-postgres
|
|
||||||
POSTGRES_PORT: 5432
|
|
||||||
POSTGRES_DB: ${SPLIIT_POSTGRES_DB}
|
|
||||||
POSTGRES_USER: ${SPLIIT_POSTGRES_USER}
|
|
||||||
POSTGRES_PASSWORD: ${SPLIIT_POSTGRES_PASSWORD}
|
|
||||||
networks:
|
|
||||||
- postgres-network
|
|
||||||
|
|
||||||
networks:
|
|
||||||
postgres-network:
|
|
||||||
external: true
|
|
||||||
@@ -1,6 +1,7 @@
|
|||||||
services:
|
services:
|
||||||
spliit:
|
spliit:
|
||||||
image: ghcr.io/spliit-app/spliit:1.19.1
|
#image: ghcr.io/spliit-app/spliit:1.19.1
|
||||||
|
image: petersmit27/spliit:latest
|
||||||
restart: always
|
restart: always
|
||||||
ports:
|
ports:
|
||||||
- 3001:3000
|
- 3001:3000
|
||||||
@@ -15,7 +16,7 @@ services:
|
|||||||
POSTGRES_USER: ${SPLIIT_POSTGRES_USER}
|
POSTGRES_USER: ${SPLIIT_POSTGRES_USER}
|
||||||
POSTGRES_PASSWORD: ${SPLIIT_POSTGRES_PASSWORD}
|
POSTGRES_PASSWORD: ${SPLIIT_POSTGRES_PASSWORD}
|
||||||
spliit_db:
|
spliit_db:
|
||||||
image: postgres:17
|
image: postgres:18
|
||||||
restart: always
|
restart: always
|
||||||
volumes:
|
volumes:
|
||||||
- ${SPLIIT_POSTGRES_DIR}:/var/lib/postgresql/data
|
- ${SPLIIT_POSTGRES_DIR}:/var/lib/postgresql/data
|
||||||
|
|||||||
@@ -1,105 +0,0 @@
|
|||||||
services:
|
|
||||||
element-call-auth-service:
|
|
||||||
image: ghcr.io/element-hq/lk-jwt-service:0.3.0
|
|
||||||
container_name: element-call-jwt
|
|
||||||
hostname: auth-server
|
|
||||||
environment:
|
|
||||||
- LK_JWT_PORT=8080
|
|
||||||
- LIVEKIT_URL=https://${LIVEKIT_DOMAIN}/livekit/sfu
|
|
||||||
- LIVEKIT_KEY=devkey
|
|
||||||
- LIVEKIT_SECRET=${LIVEKIT_SECRET_KEY}
|
|
||||||
- LIVEKIT_FULL_ACCESS_HOMESERVERS=${MATRIX_DOMAIN}
|
|
||||||
restart: always
|
|
||||||
ports:
|
|
||||||
- 8071:8080
|
|
||||||
|
|
||||||
element-call-livekit:
|
|
||||||
image: livekit/livekit-server:v1.9.3
|
|
||||||
command: --config /etc/livekit.yaml
|
|
||||||
ports:
|
|
||||||
- "7880:7880/tcp"
|
|
||||||
- "7881:7881/tcp"
|
|
||||||
- "7882:7882/tcp"
|
|
||||||
- "50100-50200:50100-50200/udp"
|
|
||||||
restart: always
|
|
||||||
volumes:
|
|
||||||
- ${LIVEKIT_CONFIG_DIR}/config.yaml:/etc/livekit.yaml:ro
|
|
||||||
|
|
||||||
mautrix-signal:
|
|
||||||
container_name: mautrix-signal
|
|
||||||
image: dock.mau.dev/mautrix/signal:v0.2511.0
|
|
||||||
restart: always
|
|
||||||
volumes:
|
|
||||||
- ${MAUTRIX_SIGNAL_DATA_DIR}:/data
|
|
||||||
depends_on:
|
|
||||||
shared-postgres:
|
|
||||||
condition: service_healthy
|
|
||||||
environment:
|
|
||||||
# Configure database connection for mautrix-signal
|
|
||||||
MAUTRIX_SIGNAL_DATABASE_TYPE: postgres
|
|
||||||
MAUTRIX_SIGNAL_DATABASE_URI: postgresql://${MAUTRIX_SIGNAL_POSTGRES_USER}:${MAUTRIX_SIGNAL_POSTGRES_PASSWORD}@shared-postgres:5432/${MAUTRIX_SIGNAL_POSTGRES_DB}?sslmode=disable
|
|
||||||
networks:
|
|
||||||
- postgres-network
|
|
||||||
|
|
||||||
mautrix-whatsapp:
|
|
||||||
container_name: mautrix-whatsapp
|
|
||||||
image: dock.mau.dev/mautrix/whatsapp:v0.2511.0
|
|
||||||
restart: always
|
|
||||||
volumes:
|
|
||||||
- ${MAUTRIX_WHATSAPP_DATA_DIR}:/data
|
|
||||||
depends_on:
|
|
||||||
shared-postgres:
|
|
||||||
condition: service_healthy
|
|
||||||
environment:
|
|
||||||
# Configure database connection for mautrix-whatsapp
|
|
||||||
MAUTRIX_WHATSAPP_DATABASE_TYPE: postgres
|
|
||||||
MAUTRIX_WHATSAPP_DATABASE_URI: postgresql://${MAUTRIX_WHATSAPP_POSTGRES_USER}:${MAUTRIX_WHATSAPP_POSTGRES_PASSWORD}@shared-postgres:5432/${MAUTRIX_WHATSAPP_POSTGRES_DB}?sslmode=disable
|
|
||||||
networks:
|
|
||||||
- postgres-network
|
|
||||||
|
|
||||||
mas:
|
|
||||||
image: ghcr.io/element-hq/matrix-authentication-service:1.6.0
|
|
||||||
restart: always
|
|
||||||
working_dir: /config
|
|
||||||
volumes:
|
|
||||||
- ${MAS_CONFIG_DIR}:/config
|
|
||||||
environment:
|
|
||||||
MAS_CONFIG: /config/config.yaml
|
|
||||||
# Database connection will be configured in the MAS config file
|
|
||||||
MAS_DATABASE_URL: postgresql://${MAS_POSTGRES_USER}:${MAS_POSTGRES_PASSWORD}@shared-postgres:5432/${MAS_POSTGRES_DB}?sslmode=disable
|
|
||||||
ports:
|
|
||||||
- "8090:8090"
|
|
||||||
depends_on:
|
|
||||||
shared-postgres:
|
|
||||||
condition: service_healthy
|
|
||||||
networks:
|
|
||||||
- postgres-network
|
|
||||||
|
|
||||||
synapse:
|
|
||||||
container_name: synapse
|
|
||||||
image: matrixdotorg/synapse:v1.142.1
|
|
||||||
restart: always
|
|
||||||
volumes:
|
|
||||||
- ${SYNAPSE_CONFIG_DIR}:/data
|
|
||||||
ports:
|
|
||||||
- "8008:8008"
|
|
||||||
environment:
|
|
||||||
# Synapse database connection will be configured in homeserver.yaml
|
|
||||||
SYNAPSE_DATABASE_HOST: shared-postgres
|
|
||||||
SYNAPSE_DATABASE_PORT: 5432
|
|
||||||
SYNAPSE_DATABASE_USER: ${SYNAPSE_POSTGRES_USER}
|
|
||||||
SYNAPSE_DATABASE_PASSWORD: ${SYNAPSE_POSTGRES_PASSWORD}
|
|
||||||
SYNAPSE_DATABASE_NAME: ${SYNAPSE_POSTGRES_DB}
|
|
||||||
depends_on:
|
|
||||||
shared-postgres:
|
|
||||||
condition: service_healthy
|
|
||||||
mas:
|
|
||||||
condition: service_started
|
|
||||||
mautrix-whatsapp:
|
|
||||||
condition: service_started
|
|
||||||
networks:
|
|
||||||
- postgres-network
|
|
||||||
|
|
||||||
networks:
|
|
||||||
postgres-network:
|
|
||||||
external: true
|
|
||||||
@@ -1,6 +1,6 @@
|
|||||||
services:
|
services:
|
||||||
element-call-auth-service:
|
element-call-auth-service:
|
||||||
image: ghcr.io/element-hq/lk-jwt-service:0.3.0
|
image: ghcr.io/element-hq/lk-jwt-service:0.4.0
|
||||||
container_name: element-call-jwt
|
container_name: element-call-jwt
|
||||||
hostname: auth-server
|
hostname: auth-server
|
||||||
environment:
|
environment:
|
||||||
@@ -13,7 +13,7 @@ services:
|
|||||||
ports:
|
ports:
|
||||||
- 8071:8080
|
- 8071:8080
|
||||||
element-call-livekit:
|
element-call-livekit:
|
||||||
image: livekit/livekit-server:v1.9.3
|
image: livekit/livekit-server:v1.9.8
|
||||||
command: --config /etc/livekit.yaml
|
command: --config /etc/livekit.yaml
|
||||||
ports:
|
ports:
|
||||||
- "7880:7880/tcp"
|
- "7880:7880/tcp"
|
||||||
@@ -25,7 +25,7 @@ services:
|
|||||||
- ${LIVEKIT_CONFIG_DIR}/config.yaml:/etc/livekit.yaml:ro
|
- ${LIVEKIT_CONFIG_DIR}/config.yaml:/etc/livekit.yaml:ro
|
||||||
mautrix-signal:
|
mautrix-signal:
|
||||||
container_name: mautrix-signal
|
container_name: mautrix-signal
|
||||||
image: dock.mau.dev/mautrix/signal:v0.2511.0
|
image: dock.mau.dev/mautrix/signal:v0.2512.0
|
||||||
restart: always
|
restart: always
|
||||||
volumes:
|
volumes:
|
||||||
- ${MAUTRIX_SIGNAL_DATA_DIR}:/data
|
- ${MAUTRIX_SIGNAL_DATA_DIR}:/data
|
||||||
@@ -42,7 +42,7 @@ services:
|
|||||||
- 5439:5432
|
- 5439:5432
|
||||||
mautrix-whatsapp:
|
mautrix-whatsapp:
|
||||||
container_name: mautrix-whatsapp
|
container_name: mautrix-whatsapp
|
||||||
image: dock.mau.dev/mautrix/whatsapp:v0.2511.0
|
image: dock.mau.dev/mautrix/whatsapp:v0.2512.0
|
||||||
#image: petersmit27/mautrix-whatsapp:latest
|
#image: petersmit27/mautrix-whatsapp:latest
|
||||||
restart: always
|
restart: always
|
||||||
volumes:
|
volumes:
|
||||||
@@ -61,7 +61,7 @@ services:
|
|||||||
ports:
|
ports:
|
||||||
- 5440:5432
|
- 5440:5432
|
||||||
mas:
|
mas:
|
||||||
image: ghcr.io/element-hq/matrix-authentication-service:1.6.0
|
image: ghcr.io/element-hq/matrix-authentication-service:1.8.0
|
||||||
restart: always
|
restart: always
|
||||||
working_dir: /config
|
working_dir: /config
|
||||||
volumes:
|
volumes:
|
||||||
@@ -97,7 +97,7 @@ services:
|
|||||||
- 5442:5432
|
- 5442:5432
|
||||||
synapse:
|
synapse:
|
||||||
container_name: synapse
|
container_name: synapse
|
||||||
image: matrixdotorg/synapse:v1.142.1
|
image: matrixdotorg/synapse:v1.144.0
|
||||||
restart: always
|
restart: always
|
||||||
volumes:
|
volumes:
|
||||||
- ${SYNAPSE_CONFIG_DIR}:/data
|
- ${SYNAPSE_CONFIG_DIR}:/data
|
||||||
|
|||||||
Reference in New Issue
Block a user