Merge branch 'feature/assets-s3-sharing'
CI / test (push) Successful in 3s

Integrate asset metadata/storage support, TypeScript client asset APIs, docs updates, and the Leaflet demo while resolving conflicts with recent challenge IP/login persistence changes on main.

Made-with: Cursor
This commit is contained in:
2026-03-02 21:23:31 +00:00
29 changed files with 2128 additions and 69 deletions
+58
View File
@@ -19,6 +19,42 @@ services:
start_period: 10s
restart: unless-stopped
minio:
image: minio/minio:latest
container_name: momswap-backend-minio
environment:
MINIO_ROOT_USER: "${S3_ACCESS_KEY:-momswap}"
MINIO_ROOT_PASSWORD: "${S3_SECRET_KEY:-momswap-secret}"
command: server /data --console-address ":9001"
volumes:
- ./var/minio:/data
ports:
- "8774:9001"
healthcheck:
test: ["CMD", "curl", "-f", "http://localhost:9000/minio/health/live"]
interval: 10s
timeout: 5s
retries: 10
start_period: 10s
restart: unless-stopped
minio-init:
image: minio/mc:latest
container_name: momswap-backend-minio-init
environment:
S3_ACCESS_KEY: "${S3_ACCESS_KEY:-momswap}"
S3_SECRET_KEY: "${S3_SECRET_KEY:-momswap-secret}"
S3_BUCKET: "${S3_BUCKET:-momswap-assets}"
depends_on:
minio:
condition: service_healthy
entrypoint: >
/bin/sh -c "
mc alias set local http://minio:9000 $$S3_ACCESS_KEY $$S3_SECRET_KEY &&
mc mb --ignore-existing local/$$S3_BUCKET
"
restart: "no"
api:
build:
context: .
@@ -32,12 +68,23 @@ services:
ADDR: ":8122"
ADMIN_PUBLIC_KEY: "${ADMIN_PUBLIC_KEY:-}"
DATABASE_URL: "postgres://${POSTGRES_USER:-momswap}:${POSTGRES_PASSWORD:-momswap}@db:5432/${POSTGRES_DB:-momswap}?sslmode=disable"
S3_ENDPOINT: "${S3_ENDPOINT:-minio:9000}"
S3_BUCKET: "${S3_BUCKET:-momswap-assets}"
S3_REGION: "${S3_REGION:-us-east-1}"
S3_ACCESS_KEY: "${S3_ACCESS_KEY:-momswap}"
S3_SECRET_KEY: "${S3_SECRET_KEY:-momswap-secret}"
S3_USE_PATH_STYLE: "${S3_USE_PATH_STYLE:-true}"
S3_USE_TLS: "${S3_USE_TLS:-false}"
volumes:
- ./etc:/app/etc:ro
- ./var/logs:/app/var/logs
depends_on:
db:
condition: service_healthy
minio:
condition: service_healthy
minio-init:
condition: service_completed_successfully
ports:
- "8122:8122"
restart: unless-stopped
@@ -56,12 +103,23 @@ services:
ADDR: ":8122"
ADMIN_PUBLIC_KEY: "${ADMIN_PUBLIC_KEY:-}"
DATABASE_URL: "postgres://${POSTGRES_USER:-momswap}:${POSTGRES_PASSWORD:-momswap}@db:5432/${POSTGRES_DB:-momswap}?sslmode=disable"
S3_ENDPOINT: "${S3_ENDPOINT:-minio:9000}"
S3_BUCKET: "${S3_BUCKET:-momswap-assets}"
S3_REGION: "${S3_REGION:-us-east-1}"
S3_ACCESS_KEY: "${S3_ACCESS_KEY:-momswap}"
S3_SECRET_KEY: "${S3_SECRET_KEY:-momswap-secret}"
S3_USE_PATH_STYLE: "${S3_USE_PATH_STYLE:-true}"
S3_USE_TLS: "${S3_USE_TLS:-false}"
volumes:
- ./etc:/src/etc:ro
- ./var/logs:/src/var/logs
depends_on:
db:
condition: service_healthy
minio:
condition: service_healthy
minio-init:
condition: service_completed_successfully
ports:
- "8122:8122"
restart: unless-stopped