The db now returns datetime objects instead of strings in some cases. Added format_date() helper function that handles both datetime and string values, and replaced all [:10] date slicing with calls to this helper. Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
69 lines
1.6 KiB
YAML
69 lines
1.6 KiB
YAML
version: "3.8"
|
|
|
|
services:
|
|
postgres:
|
|
image: postgres:16-alpine
|
|
environment:
|
|
POSTGRES_USER: artdag
|
|
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD:-artdag}
|
|
POSTGRES_DB: artdag
|
|
volumes:
|
|
- postgres_data:/var/lib/postgresql/data
|
|
networks:
|
|
- internal
|
|
healthcheck:
|
|
test: ["CMD-SHELL", "pg_isready -U artdag"]
|
|
interval: 5s
|
|
timeout: 5s
|
|
retries: 5
|
|
|
|
ipfs:
|
|
image: ipfs/kubo:latest
|
|
ports:
|
|
- "4002:4001" # Swarm TCP (4002 external, L1 uses 4001)
|
|
- "4002:4001/udp" # Swarm UDP
|
|
volumes:
|
|
- ipfs_data:/data/ipfs
|
|
networks:
|
|
- internal
|
|
- externalnet # For gateway access
|
|
deploy:
|
|
replicas: 1
|
|
restart_policy:
|
|
condition: on-failure
|
|
|
|
l2-server:
|
|
image: git.rose-ash.com/art-dag/l2-server:latest
|
|
env_file:
|
|
- .env
|
|
environment:
|
|
- ARTDAG_DATA=/data/l2
|
|
- DATABASE_URL=postgresql://artdag:${POSTGRES_PASSWORD:-artdag}@postgres:5432/artdag
|
|
- IPFS_API=/dns/ipfs/tcp/5001
|
|
- ANCHOR_BACKUP_DIR=/data/anchors
|
|
# ARTDAG_DOMAIN, ARTDAG_USER, JWT_SECRET from .env file
|
|
volumes:
|
|
- l2_data:/data/l2 # Still needed for RSA keys
|
|
- anchor_backup:/data/anchors # Persistent anchor proofs (survives DB wipes)
|
|
networks:
|
|
- internal
|
|
- externalnet
|
|
depends_on:
|
|
- postgres
|
|
- ipfs
|
|
deploy:
|
|
replicas: 1
|
|
restart_policy:
|
|
condition: on-failure
|
|
|
|
volumes:
|
|
l2_data:
|
|
postgres_data:
|
|
ipfs_data:
|
|
anchor_backup: # Persistent - don't delete when resetting DB
|
|
|
|
networks:
|
|
internal:
|
|
externalnet:
|
|
external: true
|