-
Notifications
You must be signed in to change notification settings - Fork 9
Expand file tree
/
Copy pathsupabase_migration_prices.sql
More file actions
114 lines (95 loc) · 4.04 KB
/
supabase_migration_prices.sql
File metadata and controls
114 lines (95 loc) · 4.04 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
102
103
104
105
106
107
108
109
110
111
112
113
114
-- Migration to add price fields to foods and cigarettes tables
-- Run this SQL in your Supabase SQL Editor
-- ============================================================================
-- 1. CREATE FOODS TABLE (if it doesn't exist)
-- ============================================================================
CREATE TABLE IF NOT EXISTS foods (
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
spot_id UUID NOT NULL REFERENCES spots(id) ON DELETE CASCADE,
name TEXT NOT NULL,
image_url TEXT NOT NULL,
added_by UUID NOT NULL REFERENCES profiles(id) ON DELETE CASCADE,
price NUMERIC DEFAULT NULL,
created_at TIMESTAMP WITH TIME ZONE DEFAULT NOW(),
updated_at TIMESTAMP WITH TIME ZONE DEFAULT NOW()
);
CREATE INDEX IF NOT EXISTS foods_spot_id_idx ON foods(spot_id);
CREATE INDEX IF NOT EXISTS foods_added_by_idx ON foods(added_by);
ALTER TABLE foods ENABLE ROW LEVEL SECURITY;
-- Drop existing policies
DO $$
BEGIN
DROP POLICY IF EXISTS "Everyone can read foods" ON foods;
DROP POLICY IF EXISTS "Users can create foods" ON foods;
DROP POLICY IF EXISTS "Authenticated users can create foods" ON foods;
DROP POLICY IF EXISTS "Users can update foods" ON foods;
DROP POLICY IF EXISTS "Users can update own foods" ON foods;
DROP POLICY IF EXISTS "Users can delete foods" ON foods;
DROP POLICY IF EXISTS "Users can delete own foods" ON foods;
DROP POLICY IF EXISTS "Admins can update food prices" ON foods;
END $$;
CREATE POLICY "Everyone can read foods" ON foods FOR SELECT USING (true);
CREATE POLICY "Authenticated users can create foods" ON foods FOR INSERT WITH CHECK (
auth.uid() IS NOT NULL
);
CREATE POLICY "Users can update own foods" ON foods FOR UPDATE USING (
added_by = auth.uid() OR
EXISTS (
SELECT 1 FROM profiles
WHERE profiles.id = auth.uid()
AND profiles.role = 'admin'
)
);
CREATE POLICY "Users can delete own foods" ON foods FOR DELETE USING (
added_by = auth.uid() OR
EXISTS (
SELECT 1 FROM profiles
WHERE profiles.id = auth.uid()
AND profiles.role = 'admin'
)
);
-- ============================================================================
-- 2. ADD PRICE AND NAME FIELDS TO CIGARETTES TABLE
-- ============================================================================
ALTER TABLE cigarettes
ADD COLUMN IF NOT EXISTS name TEXT,
ADD COLUMN IF NOT EXISTS price NUMERIC DEFAULT NULL;
-- Update existing cigarettes to have a default name if null
UPDATE cigarettes SET name = 'Cigarette Pack' WHERE name IS NULL;
-- Drop existing policies
DO $$
BEGIN
DROP POLICY IF EXISTS "Everyone can read cigarettes" ON cigarettes;
DROP POLICY IF EXISTS "Users can create cigarettes" ON cigarettes;
DROP POLICY IF EXISTS "Authenticated users can create cigarettes" ON cigarettes;
DROP POLICY IF EXISTS "Users can update cigarettes" ON cigarettes;
DROP POLICY IF EXISTS "Users can update own cigarettes" ON cigarettes;
DROP POLICY IF EXISTS "Users can delete cigarettes" ON cigarettes;
DROP POLICY IF EXISTS "Users can delete own cigarettes" ON cigarettes;
END $$;
CREATE POLICY "Everyone can read cigarettes" ON cigarettes FOR SELECT USING (true);
CREATE POLICY "Authenticated users can create cigarettes" ON cigarettes FOR INSERT WITH CHECK (
auth.uid() IS NOT NULL
);
CREATE POLICY "Users can update own cigarettes" ON cigarettes FOR UPDATE USING (
added_by = auth.uid() OR
EXISTS (
SELECT 1 FROM profiles
WHERE profiles.id = auth.uid()
AND profiles.role = 'admin'
)
);
CREATE POLICY "Users can delete own cigarettes" ON cigarettes FOR DELETE USING (
added_by = auth.uid() OR
EXISTS (
SELECT 1 FROM profiles
WHERE profiles.id = auth.uid()
AND profiles.role = 'admin'
)
);
-- ============================================================================
-- 3. ADD PRICE FIELD TO DRINKS TABLE (for user-suggested drinks)
-- ============================================================================
ALTER TABLE drinks
ADD COLUMN IF NOT EXISTS price NUMERIC DEFAULT NULL;
SELECT 'Price migration completed successfully! Foods, cigarettes, and drinks now support prices.' as status;