install.sql.sqlite.php 3.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108
  1. <?php
  2. global $SQL_CREATE_TABLES;
  3. $SQL_CREATE_TABLES = array(
  4. 'CREATE TABLE IF NOT EXISTS `category` (
  5. `id` INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL,
  6. `name` VARCHAR(255) NOT NULL,
  7. UNIQUE (`name`)
  8. );',
  9. 'CREATE TABLE IF NOT EXISTS `feed` (
  10. `id` INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL,
  11. `url` VARCHAR(511) NOT NULL,
  12. `category` SMALLINT DEFAULT 0,
  13. `name` VARCHAR(255) NOT NULL,
  14. `website` VARCHAR(255),
  15. `description` TEXT,
  16. `lastUpdate` INT(11) DEFAULT 0, -- Until year 2038
  17. `priority` TINYINT(2) NOT NULL DEFAULT 10,
  18. `pathEntries` VARCHAR(511) DEFAULT NULL,
  19. `httpAuth` VARCHAR(511) DEFAULT NULL,
  20. `error` BOOLEAN DEFAULT 0,
  21. `keep_history` MEDIUMINT NOT NULL DEFAULT -2,
  22. `ttl` INT NOT NULL DEFAULT 0,
  23. `attributes` TEXT, -- v1.11.0
  24. `cache_nbEntries` INT DEFAULT 0,
  25. `cache_nbUnreads` INT DEFAULT 0,
  26. FOREIGN KEY (`category`) REFERENCES `category`(`id`) ON DELETE SET NULL ON UPDATE CASCADE,
  27. UNIQUE (`url`)
  28. );',
  29. 'CREATE INDEX IF NOT EXISTS feed_name_index ON `feed`(`name`);',
  30. 'CREATE INDEX IF NOT EXISTS feed_priority_index ON `feed`(`priority`);',
  31. 'CREATE INDEX IF NOT EXISTS feed_keep_history_index ON `feed`(`keep_history`);',
  32. 'CREATE TABLE IF NOT EXISTS `entry` (
  33. `id` BIGINT NOT NULL,
  34. `guid` VARCHAR(760) NOT NULL,
  35. `title` VARCHAR(255) NOT NULL,
  36. `author` VARCHAR(255),
  37. `content` TEXT,
  38. `link` VARCHAR(1023) NOT NULL,
  39. `date` INT(11), -- Until year 2038
  40. `lastSeen` INT(11) DEFAULT 0, -- v1.1.1, Until year 2038
  41. `hash` BINARY(16), -- v1.1.1
  42. `is_read` BOOLEAN NOT NULL DEFAULT 0,
  43. `is_favorite` BOOLEAN NOT NULL DEFAULT 0,
  44. `id_feed` SMALLINT,
  45. `tags` VARCHAR(1023),
  46. PRIMARY KEY (`id`),
  47. FOREIGN KEY (`id_feed`) REFERENCES `feed`(`id`) ON DELETE CASCADE ON UPDATE CASCADE,
  48. UNIQUE (`id_feed`,`guid`)
  49. );',
  50. 'CREATE INDEX IF NOT EXISTS entry_is_favorite_index ON `entry`(`is_favorite`);',
  51. 'CREATE INDEX IF NOT EXISTS entry_is_read_index ON `entry`(`is_read`);',
  52. 'CREATE INDEX IF NOT EXISTS entry_lastSeen_index ON `entry`(`lastSeen`);', //v1.1.1
  53. 'INSERT OR IGNORE INTO `category` (id, name) VALUES(1, "%2$s");',
  54. );
  55. global $SQL_CREATE_TABLE_ENTRYTMP;
  56. $SQL_CREATE_TABLE_ENTRYTMP = array(
  57. 'CREATE TABLE IF NOT EXISTS `entrytmp` ( -- v1.7
  58. `id` BIGINT NOT NULL,
  59. `guid` VARCHAR(760) NOT NULL,
  60. `title` VARCHAR(255) NOT NULL,
  61. `author` VARCHAR(255),
  62. `content` TEXT,
  63. `link` VARCHAR(1023) NOT NULL,
  64. `date` INT(11),
  65. `lastSeen` INT(11) DEFAULT 0,
  66. `hash` BINARY(16),
  67. `is_read` BOOLEAN NOT NULL DEFAULT 0,
  68. `is_favorite` BOOLEAN NOT NULL DEFAULT 0,
  69. `id_feed` SMALLINT,
  70. `tags` VARCHAR(1023),
  71. PRIMARY KEY (`id`),
  72. FOREIGN KEY (`id_feed`) REFERENCES `feed`(`id`) ON DELETE CASCADE ON UPDATE CASCADE,
  73. UNIQUE (`id_feed`,`guid`)
  74. );',
  75. 'CREATE INDEX IF NOT EXISTS entrytmp_date_index ON `entrytmp`(`date`);',
  76. 'CREATE INDEX IF NOT EXISTS `entry_feed_read_index` ON `entry`(`id_feed`,`is_read`);', //v1.7
  77. );
  78. global $SQL_CREATE_TABLE_TAGS;
  79. $SQL_CREATE_TABLE_TAGS = array(
  80. 'CREATE TABLE IF NOT EXISTS `tag` ( -- v1.12
  81. `id` INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL,
  82. `name` VARCHAR(63) NOT NULL,
  83. `attributes` TEXT,
  84. UNIQUE (`name`)
  85. );',
  86. 'CREATE TABLE IF NOT EXISTS `entrytag` (
  87. `id_tag` SMALLINT,
  88. `id_entry` SMALLINT,
  89. PRIMARY KEY (`id_tag`,`id_entry`),
  90. FOREIGN KEY (`id_tag`) REFERENCES `tag` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
  91. FOREIGN KEY (`id_entry`) REFERENCES `entry` (`id`) ON DELETE CASCADE ON UPDATE CASCADE
  92. );',
  93. 'CREATE INDEX entrytag_id_entry_index ON `entrytag` (`id_entry`);',
  94. );
  95. define(
  96. 'SQL_INSERT_FEED',
  97. 'INSERT OR IGNORE INTO `feed` (url, category, name, website, description, ttl)
  98. VALUES(:url, 1, :name, :website, :description, 86400);'
  99. );
  100. define('SQL_DROP_TABLES', 'DROP TABLE IF EXISTS `entrytag`, `tag`, `entrytmp`, `entry`, `feed`, `category`');