-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathrun-migration.js
More file actions
56 lines (47 loc) · 1.92 KB
/
Copy pathrun-migration.js
File metadata and controls
56 lines (47 loc) · 1.92 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
// Script to run database migrations
const { supabase } = require('./services/database');
async function runMigration() {
try {
console.log('Running database migration...');
// Add authentication fields to users table
const queries = [
"ALTER TABLE users ADD COLUMN IF NOT EXISTS email TEXT UNIQUE",
"ALTER TABLE users ADD COLUMN IF NOT EXISTS password_hash TEXT",
"ALTER TABLE users ADD COLUMN IF NOT EXISTS is_active BOOLEAN DEFAULT true",
"ALTER TABLE users ADD COLUMN IF NOT EXISTS email_verified BOOLEAN DEFAULT false",
"ALTER TABLE users ADD COLUMN IF NOT EXISTS verification_token TEXT",
"ALTER TABLE users ADD COLUMN IF NOT EXISTS reset_token TEXT",
"ALTER TABLE users ADD COLUMN IF NOT EXISTS reset_token_expires TIMESTAMP WITH TIME ZONE"
];
for (const query of queries) {
console.log(`Executing: ${query}`);
const { error } = await supabase.rpc('execute_sql', { sql: query });
if (error) {
console.log(`Warning: ${error.message}`);
// Continue with next query
} else {
console.log('Success');
}
}
// Add indexes
const indexes = [
"CREATE INDEX IF NOT EXISTS idx_users_email ON users (email)",
"CREATE INDEX IF NOT EXISTS idx_users_active ON users (is_active)",
"CREATE INDEX IF NOT EXISTS idx_users_email_verified ON users (email_verified)"
];
for (const query of indexes) {
console.log(`Executing: ${query}`);
const { error } = await supabase.rpc('execute_sql', { sql: query });
if (error) {
console.log(`Warning: ${error.message}`);
// Continue with next query
} else {
console.log('Success');
}
}
console.log('Migration completed successfully!');
} catch (error) {
console.error('Migration failed:', error.message);
}
}
runMigration();