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