Add Cloudflare Pages configuration and D1 init script
This commit is contained in:
@@ -0,0 +1,142 @@
|
||||
-- ========================================
|
||||
-- KatelyaTV Cloudflare D1 数据库初始化脚本
|
||||
-- 版本: 2025-09-05 (适配当前代码结构)
|
||||
-- ========================================
|
||||
|
||||
-- 1. 用户表 (必需)
|
||||
CREATE TABLE IF NOT EXISTS users (
|
||||
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
||||
username TEXT UNIQUE NOT NULL,
|
||||
password_hash TEXT NOT NULL,
|
||||
salt TEXT NOT NULL,
|
||||
created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
|
||||
last_login DATETIME,
|
||||
login_count INTEGER DEFAULT 0,
|
||||
is_active BOOLEAN DEFAULT 1,
|
||||
role TEXT DEFAULT 'user'
|
||||
);
|
||||
|
||||
-- 2. 用户设置表 (成人内容过滤必需)
|
||||
CREATE TABLE IF NOT EXISTS user_settings (
|
||||
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
||||
username TEXT UNIQUE NOT NULL,
|
||||
filter_adult_content BOOLEAN DEFAULT 1,
|
||||
can_disable_filter BOOLEAN DEFAULT 1,
|
||||
managed_by_admin BOOLEAN DEFAULT 0,
|
||||
last_filter_change DATETIME,
|
||||
created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
|
||||
updated_at DATETIME DEFAULT CURRENT_TIMESTAMP,
|
||||
FOREIGN KEY (username) REFERENCES users(username) ON DELETE CASCADE
|
||||
);
|
||||
|
||||
-- 3. 播放记录表 (观看历史)
|
||||
CREATE TABLE IF NOT EXISTS play_records (
|
||||
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
||||
username TEXT NOT NULL,
|
||||
video_id TEXT NOT NULL,
|
||||
video_title TEXT,
|
||||
video_url TEXT,
|
||||
video_cover TEXT,
|
||||
current_time REAL DEFAULT 0,
|
||||
duration REAL DEFAULT 0,
|
||||
progress REAL DEFAULT 0,
|
||||
episode_index INTEGER DEFAULT 0,
|
||||
episode_url TEXT,
|
||||
last_watched DATETIME DEFAULT CURRENT_TIMESTAMP,
|
||||
watch_count INTEGER DEFAULT 1,
|
||||
created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
|
||||
updated_at DATETIME DEFAULT CURRENT_TIMESTAMP,
|
||||
FOREIGN KEY (username) REFERENCES users(username) ON DELETE CASCADE,
|
||||
UNIQUE(username, video_id)
|
||||
);
|
||||
|
||||
-- 4. 收藏表
|
||||
CREATE TABLE IF NOT EXISTS favorites (
|
||||
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
||||
username TEXT NOT NULL,
|
||||
video_id TEXT NOT NULL,
|
||||
video_title TEXT,
|
||||
video_cover TEXT,
|
||||
video_url TEXT,
|
||||
rating REAL,
|
||||
year TEXT,
|
||||
area TEXT,
|
||||
category TEXT,
|
||||
actors TEXT,
|
||||
director TEXT,
|
||||
description TEXT,
|
||||
added_at DATETIME DEFAULT CURRENT_TIMESTAMP,
|
||||
UNIQUE(username, video_id),
|
||||
FOREIGN KEY (username) REFERENCES users(username) ON DELETE CASCADE
|
||||
);
|
||||
|
||||
-- 5. 搜索历史表
|
||||
CREATE TABLE IF NOT EXISTS search_history (
|
||||
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
||||
username TEXT NOT NULL,
|
||||
keyword TEXT NOT NULL,
|
||||
search_time DATETIME DEFAULT CURRENT_TIMESTAMP,
|
||||
FOREIGN KEY (username) REFERENCES users(username) ON DELETE CASCADE
|
||||
);
|
||||
|
||||
-- 6. 跳过配置表 (跳过片头片尾)
|
||||
CREATE TABLE IF NOT EXISTS skip_configs (
|
||||
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
||||
username TEXT NOT NULL,
|
||||
video_id TEXT NOT NULL,
|
||||
skip_start INTEGER DEFAULT 0,
|
||||
skip_end INTEGER DEFAULT 0,
|
||||
created_at DATETIME DEFAULT CURRENT_TIMESTAMP,
|
||||
updated_at DATETIME DEFAULT CURRENT_TIMESTAMP,
|
||||
UNIQUE(username, video_id),
|
||||
FOREIGN KEY (username) REFERENCES users(username) ON DELETE CASCADE
|
||||
);
|
||||
|
||||
-- ========================================
|
||||
-- 索引优化
|
||||
-- ========================================
|
||||
|
||||
CREATE INDEX IF NOT EXISTS idx_users_username ON users(username);
|
||||
CREATE INDEX IF NOT EXISTS idx_user_settings_username ON user_settings(username);
|
||||
CREATE INDEX IF NOT EXISTS idx_play_records_username ON play_records(username);
|
||||
CREATE INDEX IF NOT EXISTS idx_play_records_last_watched ON play_records(last_watched);
|
||||
CREATE INDEX IF NOT EXISTS idx_favorites_username ON favorites(username);
|
||||
CREATE INDEX IF NOT EXISTS idx_search_history_username ON search_history(username);
|
||||
CREATE INDEX IF NOT EXISTS idx_skip_configs_username ON skip_configs(username);
|
||||
|
||||
-- ========================================
|
||||
-- 触发器
|
||||
-- ========================================
|
||||
|
||||
-- 自动更新 user_settings 时间戳
|
||||
CREATE TRIGGER IF NOT EXISTS update_user_settings_timestamp
|
||||
AFTER UPDATE ON user_settings
|
||||
FOR EACH ROW
|
||||
BEGIN
|
||||
UPDATE user_settings SET updated_at = CURRENT_TIMESTAMP WHERE username = NEW.username;
|
||||
END;
|
||||
|
||||
-- 新用户注册时创建默认设置
|
||||
CREATE TRIGGER IF NOT EXISTS create_default_user_settings
|
||||
AFTER INSERT ON users
|
||||
FOR EACH ROW
|
||||
BEGIN
|
||||
INSERT OR IGNORE INTO user_settings (username, filter_adult_content, can_disable_filter, managed_by_admin)
|
||||
VALUES (NEW.username, 1, 1, 0);
|
||||
END;
|
||||
|
||||
-- 更新播放记录时间戳
|
||||
CREATE TRIGGER IF NOT EXISTS update_play_records_timestamp
|
||||
AFTER UPDATE ON play_records
|
||||
FOR EACH ROW
|
||||
BEGIN
|
||||
UPDATE play_records SET updated_at = CURRENT_TIMESTAMP WHERE id = NEW.id;
|
||||
END;
|
||||
|
||||
-- 更新跳过配置时间戳
|
||||
CREATE TRIGGER IF NOT EXISTS update_skip_configs_timestamp
|
||||
AFTER UPDATE ON skip_configs
|
||||
FOR EACH ROW
|
||||
BEGIN
|
||||
UPDATE skip_configs SET updated_at = CURRENT_TIMESTAMP WHERE id = NEW.id;
|
||||
END;
|
||||
+27
-1
@@ -1,4 +1,30 @@
|
||||
{
|
||||
"cache_time": 7200,
|
||||
"api_site": {}
|
||||
"api_site": {
|
||||
"hnzy": {
|
||||
"api": "https://hnzyapi.com/api.php/provide/vod",
|
||||
"name": "火鸟资源",
|
||||
"is_adult": false
|
||||
},
|
||||
"lzzy": {
|
||||
"api": "https://api.liangzizy.com/inc/apijson_vod.php",
|
||||
"name": "量子资源",
|
||||
"is_adult": false
|
||||
},
|
||||
"ffzy": {
|
||||
"api": "https://ffzyapi.com/api.php/provide/vod",
|
||||
"name": "非凡资源",
|
||||
"is_adult": false
|
||||
},
|
||||
"ykzy": {
|
||||
"api": "https://api.yongjiuzy.cc/provide/vod",
|
||||
"name": "永久资源",
|
||||
"is_adult": false
|
||||
},
|
||||
"bdzy": {
|
||||
"api": "https://api.1080zyku.com/inc/apijson_vod.php",
|
||||
"name": "百度资源",
|
||||
"is_adult": false
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user