4
0

install.sql.sqlite.php 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. <?php
  2. $GLOBALS['SQL_CREATE_DB'] = <<<'SQL'
  3. SELECT 1; -- Do nothing for SQLite
  4. SQL;
  5. $GLOBALS['SQL_CREATE_TABLES'] = <<<'SQL'
  6. CREATE TABLE IF NOT EXISTS `category` (
  7. `id` INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL,
  8. `name` VARCHAR(191) NOT NULL,
  9. `kind` SMALLINT DEFAULT 0, -- 1.20.0
  10. `lastUpdate` BIGINT DEFAULT 0, -- 1.20.0
  11. `error` BIGINT DEFAULT 0, -- Date, v1.29.0
  12. `attributes` TEXT, -- v1.15.0
  13. UNIQUE (`name`)
  14. );
  15. CREATE TABLE IF NOT EXISTS `feed` (
  16. `id` INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL,
  17. `url` VARCHAR(32768) NOT NULL,
  18. `kind` SMALLINT DEFAULT 0, -- 1.20.0
  19. `category` INTEGER DEFAULT 0, -- 1.20.0
  20. `name` VARCHAR(191) NOT NULL,
  21. `website` VARCHAR(32768),
  22. `description` TEXT,
  23. `lastUpdate` BIGINT DEFAULT 0,
  24. `priority` TINYINT(2) NOT NULL DEFAULT 10,
  25. `pathEntries` VARCHAR(4096) DEFAULT NULL,
  26. `httpAuth` VARCHAR(1024) DEFAULT NULL,
  27. `error` BIGINT DEFAULT 0, -- Date, v1.29.0
  28. `ttl` INT NOT NULL DEFAULT 0,
  29. `attributes` TEXT, -- v1.11.0
  30. `cache_nbEntries` INT DEFAULT 0,
  31. `cache_nbUnreads` INT DEFAULT 0,
  32. FOREIGN KEY (`category`) REFERENCES `category`(`id`) ON DELETE SET NULL ON UPDATE CASCADE
  33. );
  34. CREATE INDEX IF NOT EXISTS feed_name_index ON `feed`(`name`);
  35. CREATE INDEX IF NOT EXISTS feed_priority_index ON `feed`(`priority`);
  36. CREATE TABLE IF NOT EXISTS `entry` (
  37. `id` BIGINT NOT NULL,
  38. `guid` VARCHAR(767) NOT NULL,
  39. `title` VARCHAR(8192) NOT NULL,
  40. `author` VARCHAR(1024),
  41. `content` TEXT,
  42. `link` VARCHAR(16383) NOT NULL,
  43. `date` BIGINT,
  44. `lastSeen` BIGINT DEFAULT 0,
  45. `lastModified` BIGINT, -- v1.29.0
  46. `lastUserModified` BIGINT, -- v1.28.0
  47. `hash` BINARY(16), -- v1.1.1
  48. `is_read` BOOLEAN NOT NULL DEFAULT 0,
  49. `is_favorite` BOOLEAN NOT NULL DEFAULT 0,
  50. `id_feed` INTEGER, -- 1.20.0
  51. `tags` VARCHAR(2048),
  52. `attributes` TEXT, -- v1.20.0
  53. PRIMARY KEY (`id`),
  54. FOREIGN KEY (`id_feed`) REFERENCES `feed`(`id`) ON DELETE CASCADE ON UPDATE CASCADE,
  55. UNIQUE (`id_feed`,`guid`)
  56. );
  57. CREATE INDEX IF NOT EXISTS entry_is_favorite_index ON `entry`(`is_favorite`);
  58. CREATE INDEX IF NOT EXISTS entry_is_read_index ON `entry`(`is_read`);
  59. CREATE INDEX IF NOT EXISTS entry_lastSeen_index ON `entry`(`lastSeen`); -- //v1.1.1
  60. CREATE INDEX IF NOT EXISTS entry_last_modified_index ON `entry` (`lastModified`);
  61. CREATE INDEX IF NOT EXISTS entry_last_user_modified_index ON `entry` (`lastUserModified`);
  62. CREATE INDEX IF NOT EXISTS entry_feed_read_index ON `entry`(`id_feed`,`is_read`); -- v1.7
  63. INSERT OR IGNORE INTO `category` (id, name) VALUES(1, 'Uncategorized');
  64. CREATE TABLE IF NOT EXISTS `entrytmp` ( -- v1.7
  65. `id` BIGINT NOT NULL,
  66. `guid` VARCHAR(767) NOT NULL,
  67. `title` VARCHAR(8192) NOT NULL,
  68. `author` VARCHAR(1024),
  69. `content` TEXT,
  70. `link` VARCHAR(16383) NOT NULL,
  71. `date` BIGINT,
  72. `lastSeen` BIGINT DEFAULT 0,
  73. `hash` BINARY(16),
  74. `is_read` BOOLEAN NOT NULL DEFAULT 0,
  75. `is_favorite` BOOLEAN NOT NULL DEFAULT 0,
  76. `id_feed` INTEGER, -- 1.20.0
  77. `tags` VARCHAR(2048),
  78. `attributes` TEXT, -- v1.20.0
  79. PRIMARY KEY (`id`),
  80. FOREIGN KEY (`id_feed`) REFERENCES `feed`(`id`) ON DELETE CASCADE ON UPDATE CASCADE,
  81. UNIQUE (`id_feed`,`guid`)
  82. );
  83. CREATE INDEX IF NOT EXISTS entrytmp_date_index ON `entrytmp`(`date`);
  84. CREATE TABLE IF NOT EXISTS `tag` ( -- v1.12
  85. `id` INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL,
  86. `name` VARCHAR(191) NOT NULL,
  87. `attributes` TEXT,
  88. UNIQUE (`name`)
  89. );
  90. CREATE TABLE IF NOT EXISTS `entrytag` (
  91. `id_tag` INTEGER, -- 1.20.0
  92. `id_entry` BIGINT,
  93. PRIMARY KEY (`id_tag`,`id_entry`),
  94. FOREIGN KEY (`id_tag`) REFERENCES `tag` (`id`) ON DELETE CASCADE ON UPDATE CASCADE,
  95. FOREIGN KEY (`id_entry`) REFERENCES `entry` (`id`) ON DELETE CASCADE ON UPDATE CASCADE
  96. );
  97. CREATE INDEX IF NOT EXISTS entrytag_id_entry_index ON `entrytag` (`id_entry`);
  98. SQL;
  99. $GLOBALS['ALTER_TABLE_ENTRY_LAST_USER_MODIFIED'] = <<<'SQL'
  100. ALTER TABLE `entry` ADD COLUMN `lastUserModified` BIGINT; -- 1.28.0
  101. CREATE INDEX IF NOT EXISTS entry_last_user_modified_index ON `entry` (`lastUserModified`);
  102. SQL;
  103. $GLOBALS['ALTER_TABLE_ENTRY_LAST_MODIFIED'] = <<<'SQL'
  104. ALTER TABLE `entry` ADD COLUMN `lastModified` BIGINT; -- 1.29.0
  105. CREATE INDEX IF NOT EXISTS entry_last_modified_index ON `entry` (`lastModified`);
  106. SQL;
  107. $GLOBALS['SQL_DROP_TABLES'] = <<<'SQL'
  108. DROP TABLE IF EXISTS `entrytag`;
  109. DROP TABLE IF EXISTS `tag`;
  110. DROP TABLE IF EXISTS `entrytmp`;
  111. DROP TABLE IF EXISTS `entry`;
  112. DROP TABLE IF EXISTS `feed`;
  113. DROP TABLE IF EXISTS `category`;
  114. SQL;
  115. $GLOBALS['SQL_UPDATE_MINOR'] = <<<'SQL'
  116. SQL;