62a5121ffe
Build backend images / build content-svc (push) Failing after 56s
Build backend images / build file-svc (push) Failing after 54s
Build backend images / build gateway (push) Failing after 1m1s
Build backend images / build identity-svc (push) Failing after 55s
Build backend images / build notification-svc (push) Failing after 54s
Build backend images / build render-svc (push) Failing after 52s
Build backend images / build studio-svc (push) Failing after 1m2s
Modeled on the legacy DivineGateWeb admin (CRM + Security/* actions):
- identity-svc AdminService + AdminController (admin-gated):
- GET /v1/admin/crm/analytics — signups/buyers/conversion/revenue + daily series
(from identity.users + identity.payments)
- GET/PUT /v1/users/{id}/crm — tags / note / pipeline status (user_crm table, mig 20)
- power-actions: POST /v1/users/{id}/{balance,password,charge,moderator,grant-plan}
- admin UI: /admin/crm dashboard (funnel cards + daily signup/revenue bars);
per-user "مدیریت" modal in Users (balance, render charge, plan days, password,
moderator, CRM notes)
Co-Authored-By: Claude Opus 4.8 <noreply@anthropic.com>
16 lines
695 B
SQL
16 lines
695 B
SQL
-- =====================================================================
|
|
-- IDENTITY SCHEMA — Part 20: CRM notes/tags per customer
|
|
-- Lightweight CRM overlay on identity.users (tags, free-form note, pipeline status).
|
|
-- Acquisition/conversion analytics are computed live from users + payments.
|
|
-- =====================================================================
|
|
|
|
SET search_path TO identity, public;
|
|
|
|
CREATE TABLE IF NOT EXISTS user_crm (
|
|
user_id UUID PRIMARY KEY,
|
|
tags TEXT[] NOT NULL DEFAULT '{}',
|
|
note TEXT,
|
|
status TEXT NOT NULL DEFAULT 'new', -- new | contacted | customer | churned
|
|
updated_at TIMESTAMPTZ NOT NULL DEFAULT NOW()
|
|
);
|