diff --git a/README.md b/README.md index 738eaf3..8717cde 100644 --- a/README.md +++ b/README.md @@ -13,7 +13,7 @@ Each stack is independently deployable with its own `compose.yml` and `.env`. Al | `watchtower` | Automatic container updates | watchtower | | `umami` | Web analytics | umami, db | | `immich` | Photo & video management | immich, ml, redis, db | -| `blinko` | AI-powered personal notes | blinko, db | +| `affine` | Collaborative workspace & notes | affine, redis, db | | `n8n` | Workflow automation & notification relay | n8n, db | | `gitea` | Git hosting + CI runner | gitea, runner, db | | `coolify` | Deployment platform | coolify, realtime, redis, db | diff --git a/_backup/backup.sh b/_backup/backup.sh index 247a8e1..54c5df0 100755 --- a/_backup/backup.sh +++ b/_backup/backup.sh @@ -33,7 +33,7 @@ mkdir -p "$DUMP_DIR" declare -A DATABASES=( [umami_db]="umami:umami" - [blinko_db]="blinko:blinko" + [affine_db]="affine:affine" [gitea_db]="gitea:gitea" [n8n_db]="n8n:n8n" [immich_db]="immich:immich" diff --git a/affine/.env.example b/affine/.env.example new file mode 100644 index 0000000..14a3270 --- /dev/null +++ b/affine/.env.example @@ -0,0 +1,5 @@ +TRAEFIK_HOST=affine.example.com +NETWORK_NAME=falcon_network +DB_USERNAME=affine +DB_PASSWORD=change_me +DB_DATABASE=affine diff --git a/affine/compose.yml b/affine/compose.yml new file mode 100644 index 0000000..f44798d --- /dev/null +++ b/affine/compose.yml @@ -0,0 +1,87 @@ +services: + affine: + image: ghcr.io/toeverything/affine:stable + container_name: affine + env_file: .env + environment: + REDIS_SERVER_HOST: redis + DATABASE_URL: postgresql://${DB_USERNAME}:${DB_PASSWORD}@postgres:5432/${DB_DATABASE:-affine} + AFFINE_INDEXER_ENABLED: "false" + volumes: + - ../.data/affine/storage:/root/.affine/storage + - ../.data/affine/config:/root/.affine/config + depends_on: + redis: + condition: service_healthy + postgres: + condition: service_healthy + affine_migration: + condition: service_completed_successfully + restart: unless-stopped + labels: + - "traefik.enable=true" + - "traefik.http.middlewares.affine-redirect-web-secure.redirectscheme.scheme=https" + - "traefik.http.routers.affine-web.middlewares=affine-redirect-web-secure" + - "traefik.http.routers.affine-web.rule=Host(`${TRAEFIK_HOST}`)" + - "traefik.http.routers.affine-web.entrypoints=web" + - "traefik.http.routers.affine-web-secure.rule=Host(`${TRAEFIK_HOST}`)" + - "traefik.http.routers.affine-web-secure.tls.certresolver=resolver" + - "traefik.http.routers.affine-web-secure.entrypoints=web-secure" + - "traefik.http.routers.affine-web-secure.middlewares=security-headers@file,no-index@file" + - "traefik.http.services.affine-web-secure.loadbalancer.server.port=3010" + - "traefik.docker.network=${NETWORK_NAME}" + - "com.centurylinklabs.watchtower.enable=true" + networks: + - compose_network + affine_migration: + image: ghcr.io/toeverything/affine:stable + container_name: affine_migration + env_file: .env + command: ['sh', '-c', 'node ./scripts/self-host-predeploy.js'] + environment: + REDIS_SERVER_HOST: redis + DATABASE_URL: postgresql://${DB_USERNAME}:${DB_PASSWORD}@postgres:5432/${DB_DATABASE:-affine} + AFFINE_INDEXER_ENABLED: "false" + volumes: + - ../.data/affine/storage:/root/.affine/storage + - ../.data/affine/config:/root/.affine/config + depends_on: + postgres: + condition: service_healthy + redis: + condition: service_healthy + networks: + - compose_network + redis: + image: redis + container_name: affine_redis + healthcheck: + test: ['CMD', 'redis-cli', '--raw', 'incr', 'ping'] + interval: 10s + timeout: 5s + retries: 5 + restart: unless-stopped + networks: + - compose_network + postgres: + image: pgvector/pgvector:pg16 + container_name: affine_db + environment: + POSTGRES_USER: ${DB_USERNAME} + POSTGRES_PASSWORD: ${DB_PASSWORD} + POSTGRES_DB: ${DB_DATABASE:-affine} + POSTGRES_INITDB_ARGS: --data-checksums + volumes: + - ../.data/affine/db:/var/lib/postgresql/data + healthcheck: + test: ['CMD', 'pg_isready', '-U', "${DB_USERNAME}", '-d', "${DB_DATABASE:-affine}"] + interval: 10s + timeout: 5s + retries: 5 + restart: unless-stopped + networks: + - compose_network +networks: + compose_network: + name: ${NETWORK_NAME} + external: true diff --git a/blinko/.env.example b/blinko/.env.example deleted file mode 100644 index fee7cbc..0000000 --- a/blinko/.env.example +++ /dev/null @@ -1,3 +0,0 @@ -NETWORK_NAME=falcon_network -TRAEFIK_HOST=blinko.example.com -BLINKO_NEXTAUTH_SECRET=change_me diff --git a/blinko/compose.yml b/blinko/compose.yml deleted file mode 100644 index 5d85ae3..0000000 --- a/blinko/compose.yml +++ /dev/null @@ -1,53 +0,0 @@ -services: - blinko: - image: blinkospace/blinko:latest - container_name: blinko - environment: - TZ: ${TIMEZONE:-Europe/Amsterdam} - NODE_ENV: production - NEXTAUTH_URL: https://${TRAEFIK_HOST} - NEXT_PUBLIC_BASE_URL: https://${TRAEFIK_HOST} - NEXTAUTH_SECRET: ${BLINKO_NEXTAUTH_SECRET} - DATABASE_URL: postgresql://blinko:blinko@blinko_db:5432/blinko - volumes: - - ../.data/blinko/app:/app/.blinko - depends_on: - db: - condition: service_healthy - restart: always - labels: - - "traefik.enable=true" - - "traefik.http.middlewares.blinko-redirect-web-secure.redirectscheme.scheme=https" - - "traefik.http.routers.blinko-web.middlewares=blinko-redirect-web-secure" - - "traefik.http.routers.blinko-web.rule=Host(`${TRAEFIK_HOST}`)" - - "traefik.http.routers.blinko-web.entrypoints=web" - - "traefik.http.routers.blinko-web-secure.rule=Host(`${TRAEFIK_HOST}`)" - - "traefik.http.routers.blinko-web-secure.tls.certresolver=resolver" - - "traefik.http.routers.blinko-web-secure.entrypoints=web-secure" - - "traefik.http.routers.blinko-web-secure.middlewares=security-headers@file,no-index@file" - - "traefik.http.services.blinko-web-secure.loadbalancer.server.port=1111" - - "traefik.docker.network=${NETWORK_NAME}" - - "com.centurylinklabs.watchtower.enable=true" - networks: - - compose_network - db: - image: postgres:14-alpine - container_name: blinko_db - environment: - POSTGRES_DB: blinko - POSTGRES_USER: blinko - POSTGRES_PASSWORD: blinko - volumes: - - ../.data/blinko/db:/var/lib/postgresql/data - restart: always - healthcheck: - test: ["CMD-SHELL", "pg_isready -U $${POSTGRES_USER} -d $${POSTGRES_DB}"] - interval: 5s - timeout: 5s - retries: 5 - networks: - - compose_network -networks: - compose_network: - name: ${NETWORK_NAME} - external: true