mirror of
https://github.com/martinrotter/rssguard.git
synced 2025-01-07 13:42:02 +01:00
185 lines
6.4 KiB
SQL
185 lines
6.4 KiB
SQL
DROP TABLE IF EXISTS Information;
|
|
-- !
|
|
CREATE TABLE IF NOT EXISTS Information (
|
|
id INTEGER PRIMARY KEY,
|
|
inf_key TEXT NOT NULL,
|
|
inf_value TEXT NOT NULL
|
|
);
|
|
-- !
|
|
INSERT INTO Information VALUES (1, 'schema_version', '21');
|
|
-- !
|
|
CREATE TABLE IF NOT EXISTS Accounts (
|
|
id INTEGER PRIMARY KEY,
|
|
type TEXT NOT NULL CHECK (type != ''),
|
|
proxy_type INTEGER NOT NULL CHECK (proxy_type >= 0) DEFAULT 0,
|
|
proxy_host TEXT,
|
|
proxy_port INTEGER,
|
|
proxy_username TEXT,
|
|
proxy_password TEXT
|
|
);
|
|
-- !
|
|
CREATE TABLE IF NOT EXISTS TtRssAccounts (
|
|
id INTEGER,
|
|
username TEXT NOT NULL,
|
|
password TEXT,
|
|
auth_protected INTEGER(1) NOT NULL CHECK (auth_protected >= 0 AND auth_protected <= 1) DEFAULT 0,
|
|
auth_username TEXT,
|
|
auth_password TEXT,
|
|
url TEXT NOT NULL,
|
|
force_update INTEGER(1) NOT NULL CHECK (force_update >= 0 AND force_update <= 1) DEFAULT 0,
|
|
update_only_unread INTEGER(1) NOT NULL CHECK (update_only_unread >= 0 AND update_only_unread <= 1) DEFAULT 0,
|
|
|
|
FOREIGN KEY (id) REFERENCES Accounts (id)
|
|
);
|
|
-- !
|
|
CREATE TABLE IF NOT EXISTS OwnCloudAccounts (
|
|
id INTEGER,
|
|
username TEXT NOT NULL,
|
|
password TEXT,
|
|
url TEXT NOT NULL,
|
|
force_update INTEGER(1) NOT NULL CHECK (force_update >= 0 AND force_update <= 1) DEFAULT 0,
|
|
msg_limit INTEGER NOT NULL DEFAULT -1 CHECK (msg_limit >= -1),
|
|
update_only_unread INTEGER(1) NOT NULL CHECK (update_only_unread >= 0 AND update_only_unread <= 1) DEFAULT 0,
|
|
|
|
FOREIGN KEY (id) REFERENCES Accounts (id)
|
|
);
|
|
-- !
|
|
CREATE TABLE IF NOT EXISTS InoreaderAccounts (
|
|
id INTEGER,
|
|
username TEXT NOT NULL,
|
|
app_id TEXT,
|
|
app_key TEXT,
|
|
redirect_url TEXT,
|
|
refresh_token TEXT,
|
|
msg_limit INTEGER NOT NULL DEFAULT -1 CHECK (msg_limit >= -1),
|
|
|
|
FOREIGN KEY (id) REFERENCES Accounts (id)
|
|
);
|
|
-- !
|
|
CREATE TABLE IF NOT EXISTS GmailAccounts (
|
|
id INTEGER,
|
|
username TEXT NOT NULL,
|
|
app_id TEXT,
|
|
app_key TEXT,
|
|
redirect_url TEXT,
|
|
refresh_token TEXT,
|
|
msg_limit INTEGER NOT NULL DEFAULT -1 CHECK (msg_limit >= -1),
|
|
|
|
FOREIGN KEY (id) REFERENCES Accounts (id)
|
|
);
|
|
-- !
|
|
CREATE TABLE IF NOT EXISTS GoogleReaderApiAccounts (
|
|
id INTEGER,
|
|
type INTEGER NOT NULL CHECK (type >= 1),
|
|
username TEXT NOT NULL,
|
|
password TEXT,
|
|
url TEXT NOT NULL,
|
|
msg_limit INTEGER NOT NULL DEFAULT -1 CHECK (msg_limit >= -1),
|
|
|
|
FOREIGN KEY (id) REFERENCES Accounts (id)
|
|
);
|
|
-- !
|
|
CREATE TABLE IF NOT EXISTS FeedlyAccounts (
|
|
id INTEGER,
|
|
username TEXT NOT NULL,
|
|
developer_access_token TEXT,
|
|
refresh_token TEXT,
|
|
msg_limit INTEGER NOT NULL DEFAULT -1 CHECK (msg_limit >= -1),
|
|
|
|
FOREIGN KEY (id) REFERENCES Accounts (id)
|
|
);
|
|
-- !
|
|
DROP TABLE IF EXISTS Categories;
|
|
-- !
|
|
CREATE TABLE IF NOT EXISTS Categories (
|
|
id INTEGER PRIMARY KEY,
|
|
parent_id INTEGER NOT NULL,
|
|
title TEXT NOT NULL CHECK (title != ''),
|
|
description TEXT,
|
|
date_created INTEGER,
|
|
icon BLOB,
|
|
account_id INTEGER NOT NULL,
|
|
custom_id TEXT,
|
|
|
|
FOREIGN KEY (account_id) REFERENCES Accounts (id)
|
|
);
|
|
-- !
|
|
DROP TABLE IF EXISTS Feeds;
|
|
-- !
|
|
CREATE TABLE IF NOT EXISTS Feeds (
|
|
id INTEGER PRIMARY KEY,
|
|
title TEXT NOT NULL CHECK (title != ''),
|
|
description TEXT,
|
|
date_created INTEGER,
|
|
icon BLOB,
|
|
category INTEGER NOT NULL CHECK (category >= -1),
|
|
encoding TEXT,
|
|
source_type INTEGER,
|
|
url TEXT,
|
|
post_process TEXT,
|
|
protected INTEGER(1) NOT NULL CHECK (protected >= 0 AND protected <= 1),
|
|
username TEXT,
|
|
password TEXT,
|
|
update_type INTEGER(1) NOT NULL CHECK (update_type >= 0),
|
|
update_interval INTEGER NOT NULL CHECK (update_interval >= 1) DEFAULT 15,
|
|
type INTEGER,
|
|
account_id INTEGER NOT NULL,
|
|
custom_id TEXT,
|
|
|
|
FOREIGN KEY (account_id) REFERENCES Accounts (id)
|
|
);
|
|
-- !
|
|
DROP TABLE IF EXISTS Messages;
|
|
-- !
|
|
CREATE TABLE IF NOT EXISTS Messages (
|
|
id INTEGER PRIMARY KEY,
|
|
is_read INTEGER(1) NOT NULL CHECK (is_read >= 0 AND is_read <= 1) DEFAULT 0,
|
|
is_deleted INTEGER(1) NOT NULL CHECK (is_deleted >= 0 AND is_deleted <= 1) DEFAULT 0,
|
|
is_important INTEGER(1) NOT NULL CHECK (is_important >= 0 AND is_important <= 1) DEFAULT 0,
|
|
feed TEXT NOT NULL,
|
|
title TEXT NOT NULL CHECK (title != ''),
|
|
url TEXT,
|
|
author TEXT,
|
|
date_created INTEGER NOT NULL CHECK (date_created != 0),
|
|
contents TEXT,
|
|
is_pdeleted INTEGER(1) NOT NULL CHECK (is_pdeleted >= 0 AND is_pdeleted <= 1) DEFAULT 0,
|
|
enclosures TEXT,
|
|
account_id INTEGER NOT NULL,
|
|
custom_id TEXT,
|
|
custom_hash TEXT,
|
|
|
|
FOREIGN KEY (account_id) REFERENCES Accounts (id)
|
|
);
|
|
-- !
|
|
CREATE TABLE IF NOT EXISTS MessageFilters (
|
|
id INTEGER PRIMARY KEY,
|
|
name TEXT NOT NULL CHECK (name != ''),
|
|
script TEXT NOT NULL CHECK (script != '')
|
|
);
|
|
-- !
|
|
CREATE TABLE IF NOT EXISTS MessageFiltersInFeeds (
|
|
filter INTEGER NOT NULL,
|
|
feed_custom_id TEXT NOT NULL,
|
|
account_id INTEGER NOT NULL,
|
|
|
|
FOREIGN KEY (filter) REFERENCES MessageFilters (id) ON DELETE CASCADE,
|
|
FOREIGN KEY (account_id) REFERENCES Accounts (id) ON DELETE CASCADE
|
|
);
|
|
-- !
|
|
CREATE TABLE IF NOT EXISTS Labels (
|
|
id INTEGER PRIMARY KEY,
|
|
name TEXT NOT NULL CHECK (name != ''),
|
|
color VARCHAR(7),
|
|
custom_id TEXT,
|
|
account_id INTEGER NOT NULL,
|
|
|
|
FOREIGN KEY (account_id) REFERENCES Accounts (id)
|
|
);
|
|
-- !
|
|
CREATE TABLE IF NOT EXISTS LabelsInMessages (
|
|
label TEXT NOT NULL, /* Custom ID of label. */
|
|
message TEXT NOT NULL, /* Custom ID of message. */
|
|
account_id INTEGER NOT NULL,
|
|
|
|
FOREIGN KEY (account_id) REFERENCES Accounts (id) ON DELETE CASCADE
|
|
); |