Some checks failed
CI/CD Pipeline / lint (push) Successful in 3m45s
CI/CD Pipeline / integration-tests (push) Failing after 58s
CI/CD Pipeline / unit-tests (push) Failing after 1m2s
CI/CD Pipeline / e2e-tests (push) Has been skipped
CI/CD Pipeline / build (push) Has been skipped
Regressions fixed: - gateway/src/worker.rs: missing session_manager field in AuthState (M3 regression) - gateway/src/main.rs: same missing field in monolithic gateway - storage/src/handlers.rs: removed unused validate_role (now handled by RlsTransaction) M2 Storage Pillar — verified complete: - StorageBackend trait with full API (put/get/delete/copy/head/list/multipart) - AwsS3Backend implementation with streaming get_object - StorageMode enum (Cloud/SelfHosted) in Config - All routes: CRUD buckets, CRUD objects, copy, move, sign, public URL, health - Bucket constraints: file_size_limit + allowed_mime_types enforced on upload - TUS resumable uploads with S3 multipart (5MB chunking) - Image transforms run via spawn_blocking - docker-compose.pillar-storage.yml, templates/storage-node.yaml - Shared Docker network on all pillar compose files M3 Auth Completeness — verified complete: - POST /logout revokes refresh tokens + Redis sessions - GET /settings returns provider availability - POST /magiclink with hashed token storage - DELETE /user soft-delete with token revocation - Recovery flow accepts new password - Email change requires re-verification via token - OAuth callback redirects with fragment tokens - MFA verify returns aal2 JWT with amr claims - MFA challenge validates factor ownership - SessionManager wired into login/logout - GET /sessions returns active sessions - Configurable ACCESS_TOKEN_LIFETIME - Claims model extended with session_id, aal, amr Tests: 62 passed, 0 failed, 11 ignored (external services) Warnings: 0 Made-with: Cursor
66 lines
1.5 KiB
YAML
66 lines
1.5 KiB
YAML
# MadBase - Pillar: System
|
|
# Control Plane API + Observability Stack (VM, Loki, Grafana)
|
|
|
|
services:
|
|
victoriametrics:
|
|
image: victoriametrics/victoria-metrics:latest
|
|
container_name: madbase_vm
|
|
ports:
|
|
- "8428:8428"
|
|
volumes:
|
|
- madbase_vm_data:/victoria-metrics-data
|
|
- ./config/prometheus.yml:/etc/prometheus/prometheus.yml
|
|
command:
|
|
- "--storageDataPath=/victoria-metrics-data"
|
|
- "--httpListenAddr=:8428"
|
|
- "--promscrape.config=/etc/prometheus/prometheus.yml"
|
|
restart: unless-stopped
|
|
|
|
loki:
|
|
image: grafana/loki:latest
|
|
container_name: madbase_loki
|
|
ports:
|
|
- "3100:3100"
|
|
command: -config.file=/etc/loki/local-config.yaml
|
|
volumes:
|
|
- madbase_loki_data:/loki
|
|
restart: unless-stopped
|
|
|
|
grafana:
|
|
image: grafana/grafana:latest
|
|
container_name: madbase_grafana
|
|
ports:
|
|
- "3030:3000"
|
|
environment:
|
|
- GF_SECURITY_ADMIN_PASSWORD=${GRAFANA_PASSWORD:-admin}
|
|
volumes:
|
|
- madbase_grafana_data:/var/lib/grafana
|
|
depends_on:
|
|
- victoriametrics
|
|
- loki
|
|
restart: unless-stopped
|
|
|
|
control:
|
|
build:
|
|
context: .
|
|
target: control-runtime
|
|
image: madbase/control:latest
|
|
container_name: madbase_control
|
|
ports:
|
|
- "8001:8001"
|
|
environment:
|
|
- DATABASE_URL=${DATABASE_URL}
|
|
- HETZNER_API_KEY=${HETZNER_API_KEY}
|
|
- HETZNER_SSH_KEY_PATH=${HETZNER_SSH_KEY_PATH}
|
|
restart: unless-stopped
|
|
|
|
volumes:
|
|
madbase_vm_data:
|
|
madbase_loki_data:
|
|
madbase_grafana_data:
|
|
|
|
networks:
|
|
default:
|
|
name: madbase
|
|
external: true
|