-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathdatabase_schema.sql
More file actions
72 lines (66 loc) · 2.5 KB
/
database_schema.sql
File metadata and controls
72 lines (66 loc) · 2.5 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
-- Database Schema for Envoyou API
-- Compatible with PostgreSQL and SQLite
-- Users table
CREATE TABLE IF NOT EXISTS users (
id TEXT PRIMARY KEY,
email TEXT UNIQUE NOT NULL,
password_hash TEXT NOT NULL,
name TEXT,
company TEXT,
job_title TEXT,
avatar_url TEXT,
timezone TEXT DEFAULT 'Asia/Jakarta',
email_verified BOOLEAN DEFAULT FALSE,
email_verification_token TEXT,
email_verification_expires TIMESTAMP,
password_reset_token TEXT,
password_reset_expires TIMESTAMP,
two_factor_secret TEXT,
two_factor_enabled BOOLEAN DEFAULT FALSE,
auth_provider TEXT, -- 'google', 'github', etc.
auth_provider_id TEXT, -- ID from the OAuth provider
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
last_login TIMESTAMP
);
-- Migration: Add OAuth fields to users table (run this if upgrading existing database)
-- ALTER TABLE users ADD COLUMN auth_provider TEXT;
-- ALTER TABLE users ADD COLUMN auth_provider_id TEXT;
-- API Keys table
CREATE TABLE IF NOT EXISTS api_keys (
id TEXT PRIMARY KEY,
user_id TEXT NOT NULL,
name TEXT NOT NULL,
key_hash TEXT NOT NULL UNIQUE,
prefix TEXT NOT NULL UNIQUE,
permissions TEXT NOT NULL DEFAULT '["read"]',
is_active BOOLEAN DEFAULT TRUE,
last_used TIMESTAMP,
usage_count INTEGER DEFAULT 0,
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
updated_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
FOREIGN KEY (user_id) REFERENCES users(id) ON DELETE CASCADE
);
-- Sessions table
CREATE TABLE IF NOT EXISTS sessions (
id TEXT PRIMARY KEY,
user_id TEXT NOT NULL,
token_hash TEXT NOT NULL UNIQUE,
device_info TEXT,
ip_address TEXT,
location TEXT,
expires_at TIMESTAMP,
created_at TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
last_active TIMESTAMP DEFAULT CURRENT_TIMESTAMP,
FOREIGN KEY (user_id) REFERENCES users(id) ON DELETE CASCADE
);
-- Indexes for better performance
CREATE INDEX IF NOT EXISTS idx_users_email ON users(email);
CREATE INDEX IF NOT EXISTS idx_api_keys_user_id ON api_keys(user_id);
CREATE INDEX IF NOT EXISTS idx_api_keys_prefix ON api_keys(prefix);
CREATE INDEX IF NOT EXISTS idx_sessions_user_id ON sessions(user_id);
CREATE INDEX IF NOT EXISTS idx_sessions_token_hash ON sessions(token_hash);
CREATE INDEX IF NOT EXISTS idx_sessions_expires_at ON sessions(expires_at);
-- Sample data for testing (optional)
-- INSERT INTO users (id, email, password_hash, name, email_verified, created_at)
-- VALUES ('user_123', 'admin@envoyou.com', '$2b$12$hashedpassword', 'Admin User', TRUE, CURRENT_TIMESTAMP);