-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathsupabase_schema.sql
More file actions
101 lines (89 loc) · 3.75 KB
/
supabase_schema.sql
File metadata and controls
101 lines (89 loc) · 3.75 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
-- CREATE TABLE FOR SCAN STATES AND RESULTS
CREATE TABLE IF NOT EXISTS public.scan_states (
scan_id TEXT PRIMARY KEY,
status TEXT NOT NULL,
message TEXT,
progress_percent INTEGER DEFAULT 0,
repo_size TEXT,
estimated_time TEXT,
result JSONB, -- Stores the full ScanResult object as JSON
created_at TIMESTAMPTZ DEFAULT NOW(),
updated_at TIMESTAMPTZ DEFAULT NOW()
);
-- ADD MISSING COLUMNS TO SCAN_STATES (IDEMPOTENT)
DO $$
BEGIN
IF NOT EXISTS (SELECT 1 FROM information_schema.columns WHERE table_name='scan_states' AND column_name='user_id') THEN
ALTER TABLE public.scan_states ADD COLUMN user_id TEXT;
END IF;
IF NOT EXISTS (SELECT 1 FROM information_schema.columns WHERE table_name='scan_states' AND column_name='health_score') THEN
ALTER TABLE public.scan_states ADD COLUMN health_score INTEGER DEFAULT 0;
END IF;
IF NOT EXISTS (SELECT 1 FROM information_schema.columns WHERE table_name='scan_states' AND column_name='repository_name') THEN
ALTER TABLE public.scan_states ADD COLUMN repository_name TEXT;
END IF;
END $$;
-- ENABLE ROW LEVEL SECURITY (RLS)
ALTER TABLE public.scan_states ENABLE ROW LEVEL SECURITY;
-- CREATE POLICIES (IDEMPOTENT)
DROP POLICY IF EXISTS "Allow authenticated read" ON public.scan_states;
CREATE POLICY "Allow authenticated read" ON public.scan_states
FOR SELECT TO authenticated USING (true);
DROP POLICY IF EXISTS "Allow authenticated insert" ON public.scan_states;
CREATE POLICY "Allow authenticated insert" ON public.scan_states
FOR INSERT TO authenticated WITH CHECK (true);
DROP POLICY IF EXISTS "Allow authenticated update" ON public.scan_states;
CREATE POLICY "Allow authenticated update" ON public.scan_states
FOR UPDATE TO authenticated USING (true);
-- Function to handle timestamp updates
CREATE OR REPLACE FUNCTION handle_updated_at()
RETURNS TRIGGER AS $$
BEGIN
NEW.updated_at = NOW();
RETURN NEW;
END;
$$ LANGUAGE plpgsql;
DROP TRIGGER IF EXISTS set_updated_at ON public.scan_states;
CREATE TRIGGER set_updated_at
BEFORE UPDATE ON public.scan_states
FOR EACH ROW
EXECUTE FUNCTION handle_updated_at();
-- BILLING & SUBSCRIPTION SCHEMA (IDEMPOTENT)
CREATE TABLE IF NOT EXISTS public.users (
id UUID PRIMARY KEY, -- This should correspond to auth.users.id
email TEXT,
display_name TEXT
);
DO $$
BEGIN
IF NOT EXISTS (SELECT 1 FROM information_schema.columns WHERE table_schema='public' AND table_name='users' AND column_name='plan_type') THEN
ALTER TABLE public.users ADD COLUMN plan_type VARCHAR(20) DEFAULT 'FREE';
END IF;
IF NOT EXISTS (SELECT 1 FROM information_schema.columns WHERE table_schema='public' AND table_name='users' AND column_name='scans_this_month') THEN
ALTER TABLE public.users ADD COLUMN scans_this_month INT DEFAULT 0;
END IF;
IF NOT EXISTS (SELECT 1 FROM information_schema.columns WHERE table_schema='public' AND table_name='users' AND column_name='plan_reset_date') THEN
ALTER TABLE public.users ADD COLUMN plan_reset_date DATE;
END IF;
END $$;
-- TEAMS SCHEMA
CREATE TABLE IF NOT EXISTS public.teams (
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
name VARCHAR(255) NOT NULL,
owner_id UUID REFERENCES public.users(id)
);
CREATE TABLE IF NOT EXISTS public.team_members (
team_id UUID REFERENCES public.teams(id) ON DELETE CASCADE,
user_id UUID REFERENCES public.users(id) ON DELETE CASCADE,
role VARCHAR(20) DEFAULT 'member',
PRIMARY KEY (team_id, user_id)
);
-- API KEYS SCHEMA
CREATE TABLE IF NOT EXISTS public.api_keys (
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
user_id UUID REFERENCES public.users(id) ON DELETE CASCADE,
key_hash VARCHAR(255) NOT NULL,
name VARCHAR(100),
created_at TIMESTAMP WITH TIME ZONE DEFAULT NOW(),
last_used_at TIMESTAMP WITH TIME ZONE
);