]> git.wh0rd.org Git - tt-rss.git/blob - schema/ttrss_schema_mysql.sql
schema: remove obsolete releases.rss feed
[tt-rss.git] / schema / ttrss_schema_mysql.sql
1 SET NAMES utf8;
2 SET CHARACTER SET utf8;
3
4 drop table if exists ttrss_error_log;
5 drop table if exists ttrss_plugin_storage;
6 drop table if exists ttrss_linked_feeds;
7 drop table if exists ttrss_linked_instances;
8 drop table if exists ttrss_access_keys;
9 drop table if exists ttrss_user_labels2;
10 drop table if exists ttrss_labels2;
11 drop table if exists ttrss_feedbrowser_cache;
12 drop table if exists ttrss_version;
13 drop table if exists ttrss_labels;
14 drop table if exists ttrss_filters2_actions;
15 drop table if exists ttrss_filters2_rules;
16 drop table if exists ttrss_filters2;
17 drop table if exists ttrss_filters;
18 drop table if exists ttrss_filter_types;
19 drop table if exists ttrss_filter_actions;
20 drop table if exists ttrss_user_prefs;
21 drop table if exists ttrss_prefs;
22 drop table if exists ttrss_prefs_types;
23 drop table if exists ttrss_prefs_sections;
24 drop table if exists ttrss_tags;
25 drop table if exists ttrss_enclosures;
26 drop table if exists ttrss_settings_profiles;
27 drop table if exists ttrss_entry_comments;
28 drop table if exists ttrss_user_entries;
29 drop table if exists ttrss_entries;
30 drop table if exists ttrss_scheduled_updates;
31 drop table if exists ttrss_counters_cache;
32 drop table if exists ttrss_cat_counters_cache;
33 drop table if exists ttrss_feeds;
34 drop table if exists ttrss_archived_feeds;
35 drop table if exists ttrss_feed_categories;
36 drop table if exists ttrss_users;
37 drop table if exists ttrss_themes;
38 drop table if exists ttrss_sessions;
39
40 begin;
41
42 create table ttrss_users (id integer primary key not null auto_increment,
43         login varchar(120) not null unique,
44         pwd_hash varchar(250) not null,
45         last_login datetime default null,
46         access_level integer not null default 0,
47         email varchar(250) not null default '',
48         full_name varchar(250) not null default '',
49         email_digest bool not null default false,
50         last_digest_sent datetime default null,
51         salt varchar(250) not null default '',
52         created datetime default null,
53         twitter_oauth longtext default null,
54         otp_enabled boolean not null default false,
55         resetpass_token varchar(250) default null) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
56
57 insert into ttrss_users (login,pwd_hash,access_level) values ('admin',
58         'SHA1:5baa61e4c9b93f3f0682250b6cf8331b7ee68fd8', 10);
59
60 create table ttrss_feed_categories(id integer not null primary key auto_increment,
61         owner_uid integer not null,
62         title varchar(200) not null,
63         collapsed bool not null default false,
64         order_id integer not null default 0,
65         parent_cat integer,
66         view_settings varchar(250) not null default '',
67         foreign key (parent_cat) references ttrss_feed_categories(id) ON DELETE SET NULL,
68         foreign key (owner_uid) references ttrss_users(id) ON DELETE CASCADE) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
69
70 create table ttrss_archived_feeds (id integer not null primary key,
71         owner_uid integer not null,
72         title varchar(200) not null,
73         feed_url text not null,
74         site_url varchar(250) not null default '',
75         foreign key (owner_uid) references ttrss_users(id) ON DELETE CASCADE) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
76
77 create table ttrss_counters_cache (
78         feed_id integer not null,
79         owner_uid integer not null,
80         value integer not null default 0,
81         updated datetime not null,
82         foreign key (owner_uid) references ttrss_users(id) ON DELETE CASCADE
83 ) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
84
85 create index ttrss_counters_cache_feed_id_idx on ttrss_counters_cache(feed_id);
86 create index ttrss_counters_cache_value_idx on ttrss_counters_cache(value);
87
88 create table ttrss_cat_counters_cache (
89         feed_id integer not null,
90         owner_uid integer not null,
91         value integer not null default 0,
92         updated datetime not null,
93         foreign key (owner_uid) references ttrss_users(id) ON DELETE CASCADE
94 ) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
95
96 create table ttrss_feeds (id integer not null auto_increment primary key,
97         owner_uid integer not null,
98         title varchar(200) not null,
99         cat_id integer default null,
100         feed_url text not null,
101         icon_url varchar(250) not null default '',
102         update_interval integer not null default 0,
103         purge_interval integer not null default 0,
104         last_updated datetime default 0,
105         last_error varchar(250) not null default '',
106         favicon_avg_color varchar(11) default null,
107         site_url varchar(250) not null default '',
108         auth_login varchar(250) not null default '',
109         auth_pass varchar(250) not null default '',
110         parent_feed integer default null,
111         private bool not null default false,
112         rtl_content bool not null default false,
113         hidden bool not null default false,
114         include_in_digest boolean not null default true,
115         cache_images boolean not null default false,
116         hide_images boolean not null default false,
117         cache_content boolean not null default false,
118         auth_pass_encrypted boolean not null default false,
119         last_viewed datetime default null,
120         last_update_started datetime default null,
121         always_display_enclosures boolean not null default false,
122         update_method integer not null default 0,
123         order_id integer not null default 0,
124         mark_unread_on_update boolean not null default false,
125         update_on_checksum_change boolean not null default false,
126         strip_images boolean not null default false,
127         view_settings varchar(250) not null default '',
128         pubsub_state integer not null default 0,
129         favicon_last_checked datetime default null,
130         foreign key (owner_uid) references ttrss_users(id) ON DELETE CASCADE,
131         foreign key (cat_id) references ttrss_feed_categories(id) ON DELETE SET NULL,
132         foreign key (parent_feed) references ttrss_feeds(id) ON DELETE SET NULL) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
133
134 insert into ttrss_feeds (owner_uid, title, feed_url) values
135         (1, 'Tiny Tiny RSS: Forum', 'http://tt-rss.org/forum/rss.php');
136
137 create table ttrss_entries (id integer not null primary key auto_increment,
138         title text not null,
139         guid varchar(255) not null unique,
140         link text not null,
141         updated datetime not null,
142         content longtext not null,
143         content_hash varchar(250) not null,
144         cached_content longtext,
145         no_orig_date bool not null default 0,
146         date_entered datetime not null,
147         date_updated datetime not null,
148         num_comments integer not null default 0,
149         plugin_data longtext,
150         lang varchar(2),
151         comments varchar(250) not null default '',
152         author varchar(250) not null default '') ENGINE=InnoDB DEFAULT CHARSET=UTF8;
153
154 create index ttrss_entries_date_entered_index on ttrss_entries(date_entered);
155 create index ttrss_entries_updated_idx on ttrss_entries(updated);
156
157 create table ttrss_user_entries (
158         int_id integer not null primary key auto_increment,
159         ref_id integer not null,
160         uuid varchar(200) not null,
161         feed_id int,
162         orig_feed_id int,
163         owner_uid integer not null,
164         marked bool not null default 0,
165         published bool not null default 0,
166         tag_cache text not null,
167         label_cache text not null,
168         last_read datetime,
169         score int not null default 0,
170         note longtext,
171         last_marked datetime,
172         last_published datetime,
173         unread bool not null default 1,
174         foreign key (ref_id) references ttrss_entries(id) ON DELETE CASCADE,
175         foreign key (feed_id) references ttrss_feeds(id) ON DELETE CASCADE,
176         foreign key (orig_feed_id) references ttrss_archived_feeds(id) ON DELETE SET NULL,
177         foreign key (owner_uid) references ttrss_users(id) ON DELETE CASCADE) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
178
179 create index ttrss_user_entries_unread_idx on ttrss_user_entries(unread);
180
181 create table ttrss_entry_comments (id integer not null primary key,
182         ref_id integer not null,
183         owner_uid integer not null,
184         private bool not null default 0,
185         date_entered datetime not null,
186         index (ref_id),
187         foreign key (ref_id) references ttrss_entries(id) ON DELETE CASCADE,
188         index (owner_uid),
189         foreign key (owner_uid) references ttrss_users(id) ON DELETE CASCADE) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
190
191 create table ttrss_filter_types (id integer primary key,
192         name varchar(120) unique not null,
193         description varchar(250) not null unique) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
194
195 insert into ttrss_filter_types (id,name,description) values (1, 'title', 'Title');
196 insert into ttrss_filter_types (id,name,description) values (2, 'content', 'Content');
197 insert into ttrss_filter_types (id,name,description) values (3, 'both',
198         'Title or Content');
199 insert into ttrss_filter_types (id,name,description) values (4, 'link',
200         'Link');
201 insert into ttrss_filter_types (id,name,description) values (5, 'date',
202         'Article Date');
203 insert into ttrss_filter_types (id,name,description) values (6, 'author', 'Author');
204 insert into ttrss_filter_types (id,name,description) values (7, 'tag', 'Article Tags');
205
206 create table ttrss_filter_actions (id integer not null primary key,
207         name varchar(120) unique not null,
208         description varchar(250) not null unique) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
209
210 insert into ttrss_filter_actions (id,name,description) values (1, 'filter',
211         'Delete article');
212
213 insert into ttrss_filter_actions (id,name,description) values (2, 'catchup',
214         'Mark as read');
215
216 insert into ttrss_filter_actions (id,name,description) values (3, 'mark',
217         'Set starred');
218
219 insert into ttrss_filter_actions (id,name,description) values (4, 'tag',
220         'Assign tags');
221
222 insert into ttrss_filter_actions (id,name,description) values (5, 'publish',
223         'Publish article');
224
225 insert into ttrss_filter_actions (id,name,description) values (6, 'score',
226         'Modify score');
227
228 insert into ttrss_filter_actions (id,name,description) values (7, 'label',
229         'Assign label');
230
231 insert into ttrss_filter_actions (id,name,description) values (8, 'stop',
232         'Stop / Do nothing');
233
234 create table ttrss_filters2(id integer primary key auto_increment,
235         owner_uid integer not null,
236         match_any_rule boolean not null default false,
237         enabled boolean not null default true,
238         inverse bool not null default false,
239         title varchar(250) not null default '',
240         order_id integer not null default 0,
241         foreign key (owner_uid) references ttrss_users(id) ON DELETE CASCADE) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
242
243 create table ttrss_filters2_rules(id integer primary key auto_increment,
244         filter_id integer not null references ttrss_filters2(id) on delete cascade,
245         reg_exp varchar(250) not null,
246         inverse bool not null default false,
247         filter_type integer not null,
248         feed_id integer default null,
249         cat_id integer default null,
250         cat_filter boolean not null default false,
251         index (filter_id),
252         foreign key (filter_id) references ttrss_filters2(id) on delete cascade,
253         index (filter_type),
254         foreign key (filter_type) references ttrss_filter_types(id) ON DELETE CASCADE,
255         index (feed_id),
256         foreign key (feed_id) references ttrss_feeds(id) ON DELETE CASCADE,
257         index (cat_id),
258         foreign key (cat_id) references ttrss_feed_categories(id) ON DELETE CASCADE) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
259
260 create table ttrss_filters2_actions(id integer primary key auto_increment,
261         filter_id integer not null,
262         action_id integer not null default 1 references ttrss_filter_actions(id) on delete cascade,
263         action_param varchar(250) not null default '',
264         index (filter_id),
265         foreign key (filter_id) references ttrss_filters2(id) on delete cascade,
266         index (action_id),
267         foreign key (action_id) references ttrss_filter_actions(id) ON DELETE CASCADE) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
268
269 create table ttrss_tags (id integer primary key auto_increment,
270         owner_uid integer not null,
271         tag_name varchar(250) not null,
272         post_int_id integer not null,
273         index (post_int_id),
274         foreign key (post_int_id) references ttrss_user_entries(int_id) ON DELETE CASCADE,
275         index (owner_uid),
276         foreign key (owner_uid) references ttrss_users(id) ON DELETE CASCADE) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
277
278 create table ttrss_version (schema_version int not null) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
279
280 insert into ttrss_version values (127);
281
282 create table ttrss_enclosures (id integer primary key auto_increment,
283         content_url text not null,
284         content_type varchar(250) not null,
285         post_id integer not null,
286         title text not null,
287         duration text not null,
288         width integer not null default 0,
289         height integer not null default 0,
290         foreign key (post_id) references ttrss_entries(id) ON DELETE cascade) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
291
292 create table ttrss_settings_profiles(id integer primary key auto_increment,
293         title varchar(250) not null,
294         owner_uid integer not null,
295         index (owner_uid),
296         foreign key (owner_uid) references ttrss_users(id) ON DELETE CASCADE) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
297
298 create table ttrss_prefs_types (id integer not null primary key,
299         type_name varchar(100) not null) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
300
301 insert into ttrss_prefs_types (id, type_name) values (1, 'bool');
302 insert into ttrss_prefs_types (id, type_name) values (2, 'string');
303 insert into ttrss_prefs_types (id, type_name) values (3, 'integer');
304
305 create table ttrss_prefs_sections (id integer not null primary key,
306         order_id integer not null) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
307
308 insert into ttrss_prefs_sections (id, order_id) values (1, 0);
309 insert into ttrss_prefs_sections (id, order_id) values (2, 1);
310 insert into ttrss_prefs_sections (id, order_id) values (3, 3);
311 insert into ttrss_prefs_sections (id, order_id) values (4, 2);
312
313 create table ttrss_prefs (pref_name varchar(250) not null primary key,
314         type_id integer not null,
315         section_id integer not null default 1,
316         access_level integer not null default 0,
317         def_value text not null,
318         foreign key (type_id) references ttrss_prefs_types(id),
319         foreign key (section_id) references ttrss_prefs_sections(id)) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
320
321 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('PURGE_OLD_DAYS', 3, '60', 1);
322 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('DEFAULT_UPDATE_INTERVAL', 3, '30', 1);
323 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('DEFAULT_ARTICLE_LIMIT', 3, '30', 2);
324 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('ALLOW_DUPLICATE_POSTS', 1, 'false', 1);
325 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('ENABLE_FEED_CATS', 1, 'true', 2);
326 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('SHOW_CONTENT_PREVIEW', 1, 'true', 2);
327 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('SHORT_DATE_FORMAT', 2, 'M d, G:i', 3);
328 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('LONG_DATE_FORMAT', 2, 'D, M d Y - G:i', 3);
329 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('COMBINED_DISPLAY_MODE', 1, 'true', 2);
330 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('HIDE_READ_FEEDS', 1, 'false', 2);
331 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('ON_CATCHUP_SHOW_NEXT_FEED', 1, 'false', 2);
332 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('FEEDS_SORT_BY_UNREAD', 1, 'false', 2);
333 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('REVERSE_HEADLINES', 1, 'false', 2);
334 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('DIGEST_ENABLE', 1, 'false', 4);
335 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('CONFIRM_FEED_CATCHUP', 1, 'true', 2);
336 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('CDM_AUTO_CATCHUP', 1, 'false', 2);
337 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('_DEFAULT_VIEW_MODE', 2, 'adaptive', 1);
338 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('_DEFAULT_VIEW_LIMIT', 3, '30', 1);
339 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('_PREFS_ACTIVE_TAB', 2, '', 1);
340 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('STRIP_UNSAFE_TAGS', 1, 'true', 3);
341 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('BLACKLISTED_TAGS', 2, 'main, generic, misc, uncategorized, blog, blogroll, general, news', 3);
342 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('FRESH_ARTICLE_MAX_AGE', 3, '24', 2);
343 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('DIGEST_CATCHUP', 1, 'false', 4);
344 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('CDM_EXPANDED', 1, 'true', 2);
345 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('PURGE_UNREAD_ARTICLES', 1, 'true', 3);
346 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('HIDE_READ_SHOWS_SPECIAL', 1, 'true', 2);
347 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('VFEED_GROUP_BY_FEED', 1, 'false', 2);
348 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('STRIP_IMAGES', 1, 'false', 2);
349 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('_DEFAULT_VIEW_ORDER_BY', 2, 'default', 1);
350 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('ENABLE_API_ACCESS', 1, 'false', 1);
351 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('_COLLAPSED_SPECIAL', 1, 'false', 1);
352 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('_COLLAPSED_LABELS', 1, 'false', 1);
353 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('_COLLAPSED_UNCAT', 1, 'false', 1);
354 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('_COLLAPSED_FEEDLIST', 1, 'false', 1);
355 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('_MOBILE_ENABLE_CATS', 1, 'false', 1);
356 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('_MOBILE_SHOW_IMAGES', 1, 'false', 1);
357 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('_MOBILE_HIDE_READ', 1, 'false', 1);
358 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('_MOBILE_SORT_FEEDS_UNREAD', 1, 'false', 1);
359 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('_THEME_ID', 2, '0', 1);
360 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('USER_TIMEZONE', 2, 'Automatic', 1);
361 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('USER_STYLESHEET', 2, '', 2);
362 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('SORT_HEADLINES_BY_FEED_DATE', 1, 'false', 2);
363 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('_MOBILE_BROWSE_CATS', 1, 'true', 1);
364 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('SSL_CERT_SERIAL', 2, '', 3);
365 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('DIGEST_PREFERRED_TIME', 2, '00:00', 4);
366 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('_PREFS_SHOW_EMPTY_CATS', 1, 'false', 1);
367 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('_DEFAULT_INCLUDE_CHILDREN', 1, 'false', 1);
368 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('AUTO_ASSIGN_LABELS', 1, 'false', 3);
369 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('_ENABLED_PLUGINS', 2, '', 1);
370 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('_MOBILE_REVERSE_HEADLINES', 1, 'false', 1);
371 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('USER_CSS_THEME', 2, '', 2);
372 insert into ttrss_prefs (pref_name,type_id,def_value,section_id) values('USER_LANGUAGE', 2, '', 2);
373
374 update ttrss_prefs set access_level = 1 where pref_name in ('ON_CATCHUP_SHOW_NEXT_FEED',
375         'SORT_HEADLINES_BY_FEED_DATE',
376         'VFEED_GROUP_BY_FEED',
377         'FRESH_ARTICLE_MAX_AGE',
378         'CDM_EXPANDED',
379         'SHOW_CONTENT_PREVIEW',
380         'AUTO_ASSIGN_LABELS',
381         'HIDE_READ_SHOWS_SPECIAL');
382
383 create table ttrss_user_prefs (
384    owner_uid integer not null,
385    pref_name varchar(250),
386    value longtext not null,
387         profile integer,
388         index (profile),
389         foreign key (profile) references ttrss_settings_profiles(id) ON DELETE CASCADE,
390         foreign key (owner_uid) references ttrss_users(id) ON DELETE CASCADE,
391         foreign key (pref_name) references ttrss_prefs(pref_name) ON DELETE CASCADE) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
392
393 create table ttrss_sessions (id varchar(250) not null primary key,
394         data text,
395         expire integer not null,
396         index (expire)) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
397
398 create table ttrss_feedbrowser_cache (
399         feed_url text not null,
400         site_url text not null,
401         title text not null,
402         subscribers integer not null) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
403
404 create table ttrss_labels2 (id integer not null primary key auto_increment,
405         owner_uid integer not null,
406         caption varchar(250) not null,
407         fg_color varchar(15) not null default '',
408         bg_color varchar(15) not null default '',
409         foreign key (owner_uid) references ttrss_users(id) ON DELETE CASCADE
410 ) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
411
412 create table ttrss_user_labels2 (label_id integer not null,
413         article_id integer not null,
414         foreign key (label_id) references ttrss_labels2(id) ON DELETE CASCADE,
415         foreign key (article_id) references ttrss_entries(id) ON DELETE CASCADE
416 ) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
417
418 create table ttrss_access_keys (id integer not null primary key auto_increment,
419         access_key varchar(250) not null,
420         feed_id varchar(250) not null,
421         is_cat bool not null default false,
422         owner_uid integer not null,
423         foreign key (owner_uid) references ttrss_users(id) ON DELETE CASCADE) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
424
425 create table ttrss_linked_instances (id integer not null primary key auto_increment,
426         last_connected datetime not null,
427         last_status_in integer not null,
428         last_status_out integer not null,
429         access_key varchar(250) not null unique,
430         access_url text not null) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
431
432 create table ttrss_linked_feeds (
433         feed_url text not null,
434         site_url text not null,
435         title text not null,
436         created datetime not null,
437         updated datetime not null,
438         instance_id integer not null,
439         subscribers integer not null,
440         foreign key (instance_id) references ttrss_linked_instances(id) ON DELETE CASCADE) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
441
442 create table ttrss_plugin_storage (
443         id integer not null auto_increment primary key,
444         name varchar(100) not null,
445         owner_uid integer not null,
446         content longtext not null,
447         foreign key (owner_uid) references ttrss_users(id) ON DELETE CASCADE) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
448
449 create table ttrss_error_log(
450         id integer not null auto_increment primary key,
451         owner_uid integer,
452         errno integer not null,
453         errstr text not null,
454         filename text not null,
455         lineno integer not null,
456         context text not null,
457         created_at datetime not null,
458         foreign key (owner_uid) references ttrss_users(id) ON DELETE SET NULL) ENGINE=InnoDB DEFAULT CHARSET=UTF8;
459
460 commit;