Files
crawler/docker-compose.yml
primal f4afb29980 Migrate from SQLite to PostgreSQL
- Replace modernc.org/sqlite with jackc/pgx/v5
- Update all SQL queries for PostgreSQL syntax ($1, $2 placeholders)
- Use snake_case column names throughout
- Replace SQLite FTS5 with PostgreSQL tsvector/tsquery full-text search
- Add connection pooling with pgxpool
- Support Docker secrets for database password
- Add trigger to normalize feed URLs (strip https://, http://, www.)
- Fix anchor feed detection regex to avoid false positives
- Connect app container to atproto network for PostgreSQL access
- Add version indicator to dashboard UI

Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
2026-01-28 20:38:13 -05:00

49 lines
1.6 KiB
YAML

services:
app-1440-news:
build: .
container_name: app-1440-news
restart: unless-stopped
stop_grace_period: 30s
env_file:
- pds.env
environment:
DB_HOST: atproto-postgres
DB_PORT: 5432
DB_USER: news_1440
DB_PASSWORD_FILE: /run/secrets/db_password
DB_NAME: news_1440
secrets:
- db_password
volumes:
- ./vertices.txt.gz:/app/vertices.txt.gz:ro
networks:
- proxy
- atproto
labels:
- "traefik.enable=true"
# Production: HTTPS with Let's Encrypt
- "traefik.http.routers.app-1440-news.rule=Host(`app.1440.news`)"
- "traefik.http.routers.app-1440-news.entrypoints=https"
- "traefik.http.routers.app-1440-news.tls.certresolver=letsencrypt-dns"
# Production: HTTP to HTTPS redirect
- "traefik.http.routers.app-1440-news-redirect.rule=Host(`app.1440.news`)"
- "traefik.http.routers.app-1440-news-redirect.entrypoints=http"
- "traefik.http.routers.app-1440-news-redirect.middlewares=https-redirect"
- "traefik.http.middlewares.https-redirect.redirectscheme.scheme=https"
- "traefik.http.middlewares.https-redirect.redirectscheme.permanent=true"
# Local development: HTTP only
- "traefik.http.routers.app-1440-news-local.rule=Host(`app.1440.localhost`)"
- "traefik.http.routers.app-1440-news-local.entrypoints=http"
# Shared service
- "traefik.http.services.app-1440-news.loadbalancer.server.port=4321"
secrets:
db_password:
file: ../postgres/secrets/news_1440_password.txt
networks:
proxy:
external: true
atproto:
external: true