8 CREATE TABLE playlists(
12 CREATE TABLE subscriptions(
13 channel_id STRING
, -- TODO: rename so it makes sense for playlists
15 type TEXT DEFAULT 'channel' NOT NULL CHECK(type IN ('channel', 'playlist')),
16 PRIMARY KEY (channel_id
, user));
18 id STRING
PRIMARY KEY,
22 crawled DATETIME
DEFAULT CURRENT_TIMESTAMP);
23 CREATE TABLE playlist_videos(
26 PRIMARY KEY (video_id
, playlist_id
));
28 channel_id STRING
PRIMARY KEY, -- TODO: rename so it makes sense for playlists
29 crawled_at DATETIME
DEFAULT CURRENT_TIMESTAMP);
31 channel_id STRING
PRIMARY KEY,
32 subscribed_until DATETIME
DEFAULT CURRENT_TIMESTAMP,
33 pending
BOOLEAN DEFAULT 0);
37 display
TEXT CHECK(display
IN (NULL, 'pinned', 'hidden')),
38 PRIMARY KEY (user, video_id
));
40 rowid INTEGER PRIMARY KEY CHECK (rowid = 0), -- limit to 1 row
49 CREATE TABLE subreddits(
50 subreddit STRING
COLLATE NOCASE
, -- e.g. videos (not /r/...)
52 PRIMARY KEY (subreddit
, user));
59 id INTEGER PRIMARY KEY AUTOINCREMENT
,
61 password TEXT NOT NULL,
62 token TEXT NOT NULL); -- TODO: move into user_tokens table
63 -- CREATE TABLE user_tokens( -- stores retractable url tokens for feeds.
64 -- user_id INTEGER NOT NULL,
65 -- token TEXT NOT NULL);