1f52f53cf7
Build backend images / build content-svc (push) Failing after 51s
Build backend images / build file-svc (push) Failing after 53s
Build backend images / build gateway (push) Failing after 1m1s
Build backend images / build identity-svc (push) Failing after 48s
Build backend images / build notification-svc (push) Failing after 42s
Build backend images / build render-svc (push) Failing after 47s
Build backend images / build studio-svc (push) Failing after 1m13s
Business rule: each user has a daily render limit. Admin-stop refunds the used
charge (not the user's fault); a user's own cancel does not.
- identity: ConsumeRenderChargeAsync / RefundRenderChargeAsync on DailyRemainRenderCount
with lazy daily reset (mig 24: daily_renders_reset_at). Convention: max=0 ⇒ UNLIMITED,
so existing 0/0 users keep rendering until an admin sets a real limit.
- identity InternalController (service-token): POST /v1/internal/render-charge/{consume,refund}
- render-svc: identityclient + on Create consume (block 429 when limit reached, fail-open
on identity outage); on admin Stop refund the job owner; user /cancel unchanged
- compose: IDENTITY_URL for render-svc, ServiceToken for identity-svc
Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
12 lines
559 B
SQL
12 lines
559 B
SQL
-- =====================================================================
|
|
-- IDENTITY SCHEMA — Part 24: daily render-quota reset timestamp
|
|
-- Supports lazy daily reset of DailyRemainRenderCount. Convention:
|
|
-- max_daily_render_count = 0 ⇒ UNLIMITED (no enforcement) — so existing
|
|
-- users (all 0/0) keep rendering until an admin sets a real limit.
|
|
-- =====================================================================
|
|
|
|
SET search_path TO identity, public;
|
|
|
|
ALTER TABLE identity.users
|
|
ADD COLUMN IF NOT EXISTS daily_renders_reset_at TIMESTAMPTZ;
|