diff --git a/README.md b/README.md index b310860..cdfa03c 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 | -| `joplin` | Note sync server | joplin, db | +| `blinko` | AI-powered personal notes | blinko, db | | `mattermost` | Team chat | mattermost, 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 e9e4e06..f51e234 100755 --- a/_backup/backup.sh +++ b/_backup/backup.sh @@ -33,7 +33,7 @@ mkdir -p "$DUMP_DIR" declare -A DATABASES=( [umami_db]="umami:umami" - [joplin_db]="joplin:joplin" + [blinko_db]="blinko:blinko" [gitea_db]="gitea:gitea" [mattermost_db]="mattermost:mattermost" [sexy_db]="directus:directus" diff --git a/blinko/compose.yml b/blinko/compose.yml new file mode 100644 index 0000000..8a26c75 --- /dev/null +++ b/blinko/compose.yml @@ -0,0 +1,54 @@ +--- +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" + - "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 diff --git a/joplin/compose.yml b/joplin/compose.yml deleted file mode 100644 index 678484c..0000000 --- a/joplin/compose.yml +++ /dev/null @@ -1,59 +0,0 @@ ---- -services: - joplin: - image: joplin/server:latest - container_name: joplin - environment: - TZ: ${TIMEZONE:-Europe/Amsterdam} - APP_PORT: 22300 - APP_BASE_URL: https://${TRAEFIK_HOST} - DB_CLIENT: pg - POSTGRES_HOST: joplin_db - POSTGRES_PORT: 5432 - POSTGRES_DATABASE: joplin - POSTGRES_USER: joplin - POSTGRES_PASSWORD: joplin - MAILER_ENABLED: 1 - MAILER_HOST: mailpit - MAILER_PORT: 1025 - MAILER_SECURE: 0 - depends_on: - db: - condition: service_healthy - restart: always - labels: - - "traefik.enable=true" - - "traefik.http.middlewares.joplin-redirect-web-secure.redirectscheme.scheme=https" - - "traefik.http.routers.joplin-web.middlewares=joplin-redirect-web-secure" - - "traefik.http.routers.joplin-web.rule=Host(`${TRAEFIK_HOST}`)" - - "traefik.http.routers.joplin-web.entrypoints=web" - - "traefik.http.routers.joplin-web-secure.rule=Host(`${TRAEFIK_HOST}`)" - - "traefik.http.routers.joplin-web-secure.tls.certresolver=resolver" - - "traefik.http.routers.joplin-web-secure.entrypoints=web-secure" - - "traefik.http.routers.joplin-web-secure.middlewares=security-headers@file" - - "traefik.http.services.joplin-web-secure.loadbalancer.server.port=22300" - - "traefik.docker.network=${NETWORK_NAME}" - - "com.centurylinklabs.watchtower.enable=true" - networks: - - compose_network - db: - image: postgres:16-alpine - container_name: joplin_db - environment: - POSTGRES_DB: joplin - POSTGRES_USER: joplin - POSTGRES_PASSWORD: joplin - volumes: - - ../.data/joplin/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