-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathsetup-database.sh
More file actions
executable file
·117 lines (102 loc) · 4.01 KB
/
setup-database.sh
File metadata and controls
executable file
·117 lines (102 loc) · 4.01 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
115
116
117
#!/bin/bash
echo "🚀 FlairAi Database Setup Guide"
echo "================================"
echo ""
echo "❌ Issue: Read-only transaction error prevents programmatic table creation"
echo "✅ Solution: Use Supabase Dashboard SQL Editor"
echo ""
echo "📋 STEP 1: Open Supabase Dashboard"
echo "URL: https://wrdfqnydraeyvjnpbiri.supabase.co/project/default/sql/new"
echo ""
echo "📋 STEP 2: Copy & Paste Essential Schema"
echo "Copy the SQL below into the SQL Editor:"
echo ""
echo "-- ====================================="
echo "-- ESSENTIAL FLAIRAI TABLES"
echo "-- ====================================="
echo ""
cat << 'EOF'
-- User profiles (extends Supabase auth.users)
CREATE TABLE IF NOT EXISTS profiles (
id UUID PRIMARY KEY REFERENCES auth.users(id) ON DELETE CASCADE,
email VARCHAR(255) UNIQUE NOT NULL,
username VARCHAR(100) UNIQUE,
name VARCHAR(255),
avatar_url TEXT,
gender VARCHAR(20) CHECK (gender IN ('male', 'female', 'non-binary', 'prefer_not_to_say')),
role VARCHAR(50) DEFAULT 'trainee',
settings JSONB DEFAULT '{}',
created_at TIMESTAMP WITH TIME ZONE DEFAULT NOW(),
updated_at TIMESTAMP WITH TIME ZONE DEFAULT NOW()
);
-- AI Agents/Flarebots
CREATE TABLE IF NOT EXISTS flarebots (
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
user_id UUID REFERENCES profiles(id) ON DELETE CASCADE,
name VARCHAR(255) NOT NULL,
personality TEXT,
body_color VARCHAR(7) DEFAULT '#58A6FF',
voice VARCHAR(50) DEFAULT 'Charon',
knowledge_base TEXT,
menu_description TEXT,
is_active BOOLEAN DEFAULT true,
is_public BOOLEAN DEFAULT false,
usage_count INTEGER DEFAULT 0,
settings JSONB DEFAULT '{}',
created_at TIMESTAMP WITH TIME ZONE DEFAULT NOW(),
updated_at TIMESTAMP WITH TIME ZONE DEFAULT NOW()
);
-- Training Sessions
CREATE TABLE IF NOT EXISTS training_sessions (
id UUID PRIMARY KEY DEFAULT gen_random_uuid(),
user_id UUID REFERENCES profiles(id) ON DELETE CASCADE,
flarebot_id UUID REFERENCES flarebots(id) ON DELETE SET NULL,
session_name VARCHAR(255),
scenario_type VARCHAR(100),
status VARCHAR(50) DEFAULT 'active',
duration_seconds INTEGER DEFAULT 0,
score INTEGER,
feedback TEXT,
transcript JSONB DEFAULT '[]',
created_at TIMESTAMP WITH TIME ZONE DEFAULT NOW()
);
-- Enable Row Level Security
ALTER TABLE profiles ENABLE ROW LEVEL SECURITY;
ALTER TABLE flarebots ENABLE ROW LEVEL SECURITY;
ALTER TABLE training_sessions ENABLE ROW LEVEL SECURITY;
-- Profiles policies
CREATE POLICY "Users can view own profile" ON profiles
FOR SELECT USING (auth.uid() = id);
CREATE POLICY "Users can update own profile" ON profiles
FOR UPDATE USING (auth.uid() = id);
CREATE POLICY "Users can insert own profile" ON profiles
FOR INSERT WITH CHECK (auth.uid() = id);
-- Flarebots policies
CREATE POLICY "Users can view own flarebots" ON flarebots
FOR SELECT USING (auth.uid() = user_id);
CREATE POLICY "Users can create flarebots" ON flarebots
FOR INSERT WITH CHECK (auth.uid() = user_id);
CREATE POLICY "Users can update own flarebots" ON flarebots
FOR UPDATE USING (auth.uid() = user_id);
CREATE POLICY "Users can delete own flarebots" ON flarebots
FOR DELETE USING (auth.uid() = user_id);
-- Training sessions policies
CREATE POLICY "Users can view own training sessions" ON training_sessions
FOR SELECT USING (auth.uid() = user_id);
CREATE POLICY "Users can create training sessions" ON training_sessions
FOR INSERT WITH CHECK (auth.uid() = user_id);
CREATE POLICY "Users can update own training sessions" ON training_sessions
FOR UPDATE USING (auth.uid() = user_id);
EOF
echo ""
echo "📋 STEP 3: Click 'RUN' in the SQL Editor"
echo ""
echo "📋 STEP 4: Verify Tables Created"
echo "Go to Table Editor and confirm these tables exist:"
echo " ✅ profiles"
echo " ✅ flarebots"
echo " ✅ training_sessions"
echo ""
echo "🎯 After setup, refresh your FlairAi app and the database errors will disappear!"
echo ""
echo "🔗 Quick Link: https://wrdfqnydraeyvjnpbiri.supabase.co/project/default/sql/new"