install.sql.sqlite.php 3.8 KB

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