This commit is contained in:
kunfei 2022-03-09 21:41:52 +08:00
parent edf577a40c
commit 20ca357884
11 changed files with 3383 additions and 35 deletions

View File

@ -0,0 +1,1618 @@
{
"formatVersion": 1,
"database": {
"version": 45,
"identityHash": "63272539e04e405abfd79e27ea55db75",
"entities": [
{
"tableName": "books",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`bookUrl` TEXT NOT NULL DEFAULT '', `tocUrl` TEXT NOT NULL DEFAULT '', `origin` TEXT NOT NULL DEFAULT '', `originName` TEXT NOT NULL DEFAULT '', `name` TEXT NOT NULL DEFAULT '', `author` TEXT NOT NULL DEFAULT '', `kind` TEXT, `customTag` TEXT, `coverUrl` TEXT, `customCoverUrl` TEXT, `intro` TEXT, `customIntro` TEXT, `charset` TEXT, `type` INTEGER NOT NULL DEFAULT 0, `group` INTEGER NOT NULL DEFAULT 0, `latestChapterTitle` TEXT, `latestChapterTime` INTEGER NOT NULL DEFAULT 0, `lastCheckTime` INTEGER NOT NULL DEFAULT 0, `lastCheckCount` INTEGER NOT NULL DEFAULT 0, `totalChapterNum` INTEGER NOT NULL DEFAULT 0, `durChapterTitle` TEXT, `durChapterIndex` INTEGER NOT NULL DEFAULT 0, `durChapterPos` INTEGER NOT NULL DEFAULT 0, `durChapterTime` INTEGER NOT NULL DEFAULT 0, `wordCount` TEXT, `canUpdate` INTEGER NOT NULL DEFAULT 1, `order` INTEGER NOT NULL DEFAULT 0, `originOrder` INTEGER NOT NULL DEFAULT 0, `variable` TEXT, `readConfig` TEXT, PRIMARY KEY(`bookUrl`))",
"fields": [
{
"fieldPath": "bookUrl",
"columnName": "bookUrl",
"affinity": "TEXT",
"notNull": true,
"defaultValue": "''"
},
{
"fieldPath": "tocUrl",
"columnName": "tocUrl",
"affinity": "TEXT",
"notNull": true,
"defaultValue": "''"
},
{
"fieldPath": "origin",
"columnName": "origin",
"affinity": "TEXT",
"notNull": true,
"defaultValue": "''"
},
{
"fieldPath": "originName",
"columnName": "originName",
"affinity": "TEXT",
"notNull": true,
"defaultValue": "''"
},
{
"fieldPath": "name",
"columnName": "name",
"affinity": "TEXT",
"notNull": true,
"defaultValue": "''"
},
{
"fieldPath": "author",
"columnName": "author",
"affinity": "TEXT",
"notNull": true,
"defaultValue": "''"
},
{
"fieldPath": "kind",
"columnName": "kind",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "customTag",
"columnName": "customTag",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "coverUrl",
"columnName": "coverUrl",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "customCoverUrl",
"columnName": "customCoverUrl",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "intro",
"columnName": "intro",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "customIntro",
"columnName": "customIntro",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "charset",
"columnName": "charset",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "type",
"columnName": "type",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
},
{
"fieldPath": "group",
"columnName": "group",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
},
{
"fieldPath": "latestChapterTitle",
"columnName": "latestChapterTitle",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "latestChapterTime",
"columnName": "latestChapterTime",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
},
{
"fieldPath": "lastCheckTime",
"columnName": "lastCheckTime",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
},
{
"fieldPath": "lastCheckCount",
"columnName": "lastCheckCount",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
},
{
"fieldPath": "totalChapterNum",
"columnName": "totalChapterNum",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
},
{
"fieldPath": "durChapterTitle",
"columnName": "durChapterTitle",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "durChapterIndex",
"columnName": "durChapterIndex",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
},
{
"fieldPath": "durChapterPos",
"columnName": "durChapterPos",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
},
{
"fieldPath": "durChapterTime",
"columnName": "durChapterTime",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
},
{
"fieldPath": "wordCount",
"columnName": "wordCount",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "canUpdate",
"columnName": "canUpdate",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "1"
},
{
"fieldPath": "order",
"columnName": "order",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
},
{
"fieldPath": "originOrder",
"columnName": "originOrder",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
},
{
"fieldPath": "variable",
"columnName": "variable",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "readConfig",
"columnName": "readConfig",
"affinity": "TEXT",
"notNull": false
}
],
"primaryKey": {
"columnNames": [
"bookUrl"
],
"autoGenerate": false
},
"indices": [
{
"name": "index_books_name_author",
"unique": true,
"columnNames": [
"name",
"author"
],
"orders": [],
"createSql": "CREATE UNIQUE INDEX IF NOT EXISTS `index_books_name_author` ON `${TABLE_NAME}` (`name`, `author`)"
}
],
"foreignKeys": []
},
{
"tableName": "book_groups",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`groupId` INTEGER NOT NULL, `groupName` TEXT NOT NULL, `cover` TEXT, `order` INTEGER NOT NULL, `show` INTEGER NOT NULL, PRIMARY KEY(`groupId`))",
"fields": [
{
"fieldPath": "groupId",
"columnName": "groupId",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "groupName",
"columnName": "groupName",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "cover",
"columnName": "cover",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "order",
"columnName": "order",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "show",
"columnName": "show",
"affinity": "INTEGER",
"notNull": true
}
],
"primaryKey": {
"columnNames": [
"groupId"
],
"autoGenerate": false
},
"indices": [],
"foreignKeys": []
},
{
"tableName": "book_sources",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`bookSourceUrl` TEXT NOT NULL, `bookSourceName` TEXT NOT NULL, `bookSourceGroup` TEXT, `bookSourceType` INTEGER NOT NULL, `bookUrlPattern` TEXT, `customOrder` INTEGER NOT NULL, `enabled` INTEGER NOT NULL, `enabledExplore` INTEGER NOT NULL, `concurrentRate` TEXT, `header` TEXT, `loginUrl` TEXT, `loginUi` TEXT, `loginCheckJs` TEXT, `bookSourceComment` TEXT, `lastUpdateTime` INTEGER NOT NULL, `respondTime` INTEGER NOT NULL, `weight` INTEGER NOT NULL, `exploreUrl` TEXT, `ruleExplore` TEXT, `searchUrl` TEXT, `ruleSearch` TEXT, `ruleBookInfo` TEXT, `ruleToc` TEXT, `ruleContent` TEXT, PRIMARY KEY(`bookSourceUrl`))",
"fields": [
{
"fieldPath": "bookSourceUrl",
"columnName": "bookSourceUrl",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "bookSourceName",
"columnName": "bookSourceName",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "bookSourceGroup",
"columnName": "bookSourceGroup",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "bookSourceType",
"columnName": "bookSourceType",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "bookUrlPattern",
"columnName": "bookUrlPattern",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "customOrder",
"columnName": "customOrder",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "enabled",
"columnName": "enabled",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "enabledExplore",
"columnName": "enabledExplore",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "concurrentRate",
"columnName": "concurrentRate",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "header",
"columnName": "header",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "loginUrl",
"columnName": "loginUrl",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "loginUi",
"columnName": "loginUi",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "loginCheckJs",
"columnName": "loginCheckJs",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "bookSourceComment",
"columnName": "bookSourceComment",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "lastUpdateTime",
"columnName": "lastUpdateTime",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "respondTime",
"columnName": "respondTime",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "weight",
"columnName": "weight",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "exploreUrl",
"columnName": "exploreUrl",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "ruleExplore",
"columnName": "ruleExplore",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "searchUrl",
"columnName": "searchUrl",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "ruleSearch",
"columnName": "ruleSearch",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "ruleBookInfo",
"columnName": "ruleBookInfo",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "ruleToc",
"columnName": "ruleToc",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "ruleContent",
"columnName": "ruleContent",
"affinity": "TEXT",
"notNull": false
}
],
"primaryKey": {
"columnNames": [
"bookSourceUrl"
],
"autoGenerate": false
},
"indices": [
{
"name": "index_book_sources_bookSourceUrl",
"unique": false,
"columnNames": [
"bookSourceUrl"
],
"orders": [],
"createSql": "CREATE INDEX IF NOT EXISTS `index_book_sources_bookSourceUrl` ON `${TABLE_NAME}` (`bookSourceUrl`)"
}
],
"foreignKeys": []
},
{
"tableName": "chapters",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`url` TEXT NOT NULL, `title` TEXT NOT NULL, `isVolume` INTEGER NOT NULL, `baseUrl` TEXT NOT NULL, `bookUrl` TEXT NOT NULL, `index` INTEGER NOT NULL, `isVip` INTEGER NOT NULL, `isPay` INTEGER NOT NULL, `resourceUrl` TEXT, `tag` TEXT, `start` INTEGER, `end` INTEGER, `startFragmentId` TEXT, `endFragmentId` TEXT, `variable` TEXT, PRIMARY KEY(`url`, `bookUrl`), FOREIGN KEY(`bookUrl`) REFERENCES `books`(`bookUrl`) ON UPDATE NO ACTION ON DELETE CASCADE )",
"fields": [
{
"fieldPath": "url",
"columnName": "url",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "title",
"columnName": "title",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "isVolume",
"columnName": "isVolume",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "baseUrl",
"columnName": "baseUrl",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "bookUrl",
"columnName": "bookUrl",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "index",
"columnName": "index",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "isVip",
"columnName": "isVip",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "isPay",
"columnName": "isPay",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "resourceUrl",
"columnName": "resourceUrl",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "tag",
"columnName": "tag",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "start",
"columnName": "start",
"affinity": "INTEGER",
"notNull": false
},
{
"fieldPath": "end",
"columnName": "end",
"affinity": "INTEGER",
"notNull": false
},
{
"fieldPath": "startFragmentId",
"columnName": "startFragmentId",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "endFragmentId",
"columnName": "endFragmentId",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "variable",
"columnName": "variable",
"affinity": "TEXT",
"notNull": false
}
],
"primaryKey": {
"columnNames": [
"url",
"bookUrl"
],
"autoGenerate": false
},
"indices": [
{
"name": "index_chapters_bookUrl",
"unique": false,
"columnNames": [
"bookUrl"
],
"orders": [],
"createSql": "CREATE INDEX IF NOT EXISTS `index_chapters_bookUrl` ON `${TABLE_NAME}` (`bookUrl`)"
},
{
"name": "index_chapters_bookUrl_index",
"unique": true,
"columnNames": [
"bookUrl",
"index"
],
"orders": [],
"createSql": "CREATE UNIQUE INDEX IF NOT EXISTS `index_chapters_bookUrl_index` ON `${TABLE_NAME}` (`bookUrl`, `index`)"
}
],
"foreignKeys": [
{
"table": "books",
"onDelete": "CASCADE",
"onUpdate": "NO ACTION",
"columns": [
"bookUrl"
],
"referencedColumns": [
"bookUrl"
]
}
]
},
{
"tableName": "replace_rules",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`id` INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, `name` TEXT NOT NULL DEFAULT '', `group` TEXT, `pattern` TEXT NOT NULL DEFAULT '', `replacement` TEXT NOT NULL DEFAULT '', `scope` TEXT, `scopeTitle` INTEGER NOT NULL DEFAULT 0, `scopeContent` INTEGER NOT NULL DEFAULT 1, `isEnabled` INTEGER NOT NULL DEFAULT 1, `isRegex` INTEGER NOT NULL DEFAULT 1, `sortOrder` INTEGER NOT NULL DEFAULT 0)",
"fields": [
{
"fieldPath": "id",
"columnName": "id",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "name",
"columnName": "name",
"affinity": "TEXT",
"notNull": true,
"defaultValue": "''"
},
{
"fieldPath": "group",
"columnName": "group",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "pattern",
"columnName": "pattern",
"affinity": "TEXT",
"notNull": true,
"defaultValue": "''"
},
{
"fieldPath": "replacement",
"columnName": "replacement",
"affinity": "TEXT",
"notNull": true,
"defaultValue": "''"
},
{
"fieldPath": "scope",
"columnName": "scope",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "scopeTitle",
"columnName": "scopeTitle",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
},
{
"fieldPath": "scopeContent",
"columnName": "scopeContent",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "1"
},
{
"fieldPath": "isEnabled",
"columnName": "isEnabled",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "1"
},
{
"fieldPath": "isRegex",
"columnName": "isRegex",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "1"
},
{
"fieldPath": "order",
"columnName": "sortOrder",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
}
],
"primaryKey": {
"columnNames": [
"id"
],
"autoGenerate": true
},
"indices": [
{
"name": "index_replace_rules_id",
"unique": false,
"columnNames": [
"id"
],
"orders": [],
"createSql": "CREATE INDEX IF NOT EXISTS `index_replace_rules_id` ON `${TABLE_NAME}` (`id`)"
}
],
"foreignKeys": []
},
{
"tableName": "searchBooks",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`bookUrl` TEXT NOT NULL, `origin` TEXT NOT NULL, `originName` TEXT NOT NULL, `type` INTEGER NOT NULL, `name` TEXT NOT NULL, `author` TEXT NOT NULL, `kind` TEXT, `coverUrl` TEXT, `intro` TEXT, `wordCount` TEXT, `latestChapterTitle` TEXT, `tocUrl` TEXT NOT NULL, `time` INTEGER NOT NULL, `variable` TEXT, `originOrder` INTEGER NOT NULL, PRIMARY KEY(`bookUrl`), FOREIGN KEY(`origin`) REFERENCES `book_sources`(`bookSourceUrl`) ON UPDATE NO ACTION ON DELETE CASCADE )",
"fields": [
{
"fieldPath": "bookUrl",
"columnName": "bookUrl",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "origin",
"columnName": "origin",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "originName",
"columnName": "originName",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "type",
"columnName": "type",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "name",
"columnName": "name",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "author",
"columnName": "author",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "kind",
"columnName": "kind",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "coverUrl",
"columnName": "coverUrl",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "intro",
"columnName": "intro",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "wordCount",
"columnName": "wordCount",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "latestChapterTitle",
"columnName": "latestChapterTitle",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "tocUrl",
"columnName": "tocUrl",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "time",
"columnName": "time",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "variable",
"columnName": "variable",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "originOrder",
"columnName": "originOrder",
"affinity": "INTEGER",
"notNull": true
}
],
"primaryKey": {
"columnNames": [
"bookUrl"
],
"autoGenerate": false
},
"indices": [
{
"name": "index_searchBooks_bookUrl",
"unique": true,
"columnNames": [
"bookUrl"
],
"orders": [],
"createSql": "CREATE UNIQUE INDEX IF NOT EXISTS `index_searchBooks_bookUrl` ON `${TABLE_NAME}` (`bookUrl`)"
},
{
"name": "index_searchBooks_origin",
"unique": false,
"columnNames": [
"origin"
],
"orders": [],
"createSql": "CREATE INDEX IF NOT EXISTS `index_searchBooks_origin` ON `${TABLE_NAME}` (`origin`)"
}
],
"foreignKeys": [
{
"table": "book_sources",
"onDelete": "CASCADE",
"onUpdate": "NO ACTION",
"columns": [
"origin"
],
"referencedColumns": [
"bookSourceUrl"
]
}
]
},
{
"tableName": "search_keywords",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`word` TEXT NOT NULL, `usage` INTEGER NOT NULL, `lastUseTime` INTEGER NOT NULL, PRIMARY KEY(`word`))",
"fields": [
{
"fieldPath": "word",
"columnName": "word",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "usage",
"columnName": "usage",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "lastUseTime",
"columnName": "lastUseTime",
"affinity": "INTEGER",
"notNull": true
}
],
"primaryKey": {
"columnNames": [
"word"
],
"autoGenerate": false
},
"indices": [
{
"name": "index_search_keywords_word",
"unique": true,
"columnNames": [
"word"
],
"orders": [],
"createSql": "CREATE UNIQUE INDEX IF NOT EXISTS `index_search_keywords_word` ON `${TABLE_NAME}` (`word`)"
}
],
"foreignKeys": []
},
{
"tableName": "cookies",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`url` TEXT NOT NULL, `cookie` TEXT NOT NULL, PRIMARY KEY(`url`))",
"fields": [
{
"fieldPath": "url",
"columnName": "url",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "cookie",
"columnName": "cookie",
"affinity": "TEXT",
"notNull": true
}
],
"primaryKey": {
"columnNames": [
"url"
],
"autoGenerate": false
},
"indices": [
{
"name": "index_cookies_url",
"unique": true,
"columnNames": [
"url"
],
"orders": [],
"createSql": "CREATE UNIQUE INDEX IF NOT EXISTS `index_cookies_url` ON `${TABLE_NAME}` (`url`)"
}
],
"foreignKeys": []
},
{
"tableName": "rssSources",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`sourceUrl` TEXT NOT NULL, `sourceName` TEXT NOT NULL, `sourceIcon` TEXT NOT NULL, `sourceGroup` TEXT, `sourceComment` TEXT, `enabled` INTEGER NOT NULL, `concurrentRate` TEXT, `header` TEXT, `loginUrl` TEXT, `loginUi` TEXT, `loginCheckJs` TEXT, `sortUrl` TEXT, `singleUrl` INTEGER NOT NULL, `articleStyle` INTEGER NOT NULL, `ruleArticles` TEXT, `ruleNextPage` TEXT, `ruleTitle` TEXT, `rulePubDate` TEXT, `ruleDescription` TEXT, `ruleImage` TEXT, `ruleLink` TEXT, `ruleContent` TEXT, `style` TEXT, `enableJs` INTEGER NOT NULL, `loadWithBaseUrl` INTEGER NOT NULL, `customOrder` INTEGER NOT NULL, PRIMARY KEY(`sourceUrl`))",
"fields": [
{
"fieldPath": "sourceUrl",
"columnName": "sourceUrl",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "sourceName",
"columnName": "sourceName",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "sourceIcon",
"columnName": "sourceIcon",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "sourceGroup",
"columnName": "sourceGroup",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "sourceComment",
"columnName": "sourceComment",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "enabled",
"columnName": "enabled",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "concurrentRate",
"columnName": "concurrentRate",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "header",
"columnName": "header",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "loginUrl",
"columnName": "loginUrl",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "loginUi",
"columnName": "loginUi",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "loginCheckJs",
"columnName": "loginCheckJs",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "sortUrl",
"columnName": "sortUrl",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "singleUrl",
"columnName": "singleUrl",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "articleStyle",
"columnName": "articleStyle",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "ruleArticles",
"columnName": "ruleArticles",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "ruleNextPage",
"columnName": "ruleNextPage",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "ruleTitle",
"columnName": "ruleTitle",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "rulePubDate",
"columnName": "rulePubDate",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "ruleDescription",
"columnName": "ruleDescription",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "ruleImage",
"columnName": "ruleImage",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "ruleLink",
"columnName": "ruleLink",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "ruleContent",
"columnName": "ruleContent",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "style",
"columnName": "style",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "enableJs",
"columnName": "enableJs",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "loadWithBaseUrl",
"columnName": "loadWithBaseUrl",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "customOrder",
"columnName": "customOrder",
"affinity": "INTEGER",
"notNull": true
}
],
"primaryKey": {
"columnNames": [
"sourceUrl"
],
"autoGenerate": false
},
"indices": [
{
"name": "index_rssSources_sourceUrl",
"unique": false,
"columnNames": [
"sourceUrl"
],
"orders": [],
"createSql": "CREATE INDEX IF NOT EXISTS `index_rssSources_sourceUrl` ON `${TABLE_NAME}` (`sourceUrl`)"
}
],
"foreignKeys": []
},
{
"tableName": "bookmarks",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`time` INTEGER NOT NULL, `bookName` TEXT NOT NULL, `bookAuthor` TEXT NOT NULL, `chapterIndex` INTEGER NOT NULL, `chapterPos` INTEGER NOT NULL, `chapterName` TEXT NOT NULL, `bookText` TEXT NOT NULL, `content` TEXT NOT NULL, PRIMARY KEY(`time`))",
"fields": [
{
"fieldPath": "time",
"columnName": "time",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "bookName",
"columnName": "bookName",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "bookAuthor",
"columnName": "bookAuthor",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "chapterIndex",
"columnName": "chapterIndex",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "chapterPos",
"columnName": "chapterPos",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "chapterName",
"columnName": "chapterName",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "bookText",
"columnName": "bookText",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "content",
"columnName": "content",
"affinity": "TEXT",
"notNull": true
}
],
"primaryKey": {
"columnNames": [
"time"
],
"autoGenerate": false
},
"indices": [
{
"name": "index_bookmarks_bookName_bookAuthor",
"unique": false,
"columnNames": [
"bookName",
"bookAuthor"
],
"orders": [],
"createSql": "CREATE INDEX IF NOT EXISTS `index_bookmarks_bookName_bookAuthor` ON `${TABLE_NAME}` (`bookName`, `bookAuthor`)"
}
],
"foreignKeys": []
},
{
"tableName": "rssArticles",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`origin` TEXT NOT NULL, `sort` TEXT NOT NULL, `title` TEXT NOT NULL, `order` INTEGER NOT NULL, `link` TEXT NOT NULL, `pubDate` TEXT, `description` TEXT, `content` TEXT, `image` TEXT, `read` INTEGER NOT NULL, `variable` TEXT, PRIMARY KEY(`origin`, `link`))",
"fields": [
{
"fieldPath": "origin",
"columnName": "origin",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "sort",
"columnName": "sort",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "title",
"columnName": "title",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "order",
"columnName": "order",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "link",
"columnName": "link",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "pubDate",
"columnName": "pubDate",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "description",
"columnName": "description",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "content",
"columnName": "content",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "image",
"columnName": "image",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "read",
"columnName": "read",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "variable",
"columnName": "variable",
"affinity": "TEXT",
"notNull": false
}
],
"primaryKey": {
"columnNames": [
"origin",
"link"
],
"autoGenerate": false
},
"indices": [],
"foreignKeys": []
},
{
"tableName": "rssReadRecords",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`record` TEXT NOT NULL, `read` INTEGER NOT NULL, PRIMARY KEY(`record`))",
"fields": [
{
"fieldPath": "record",
"columnName": "record",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "read",
"columnName": "read",
"affinity": "INTEGER",
"notNull": true
}
],
"primaryKey": {
"columnNames": [
"record"
],
"autoGenerate": false
},
"indices": [],
"foreignKeys": []
},
{
"tableName": "rssStars",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`origin` TEXT NOT NULL, `sort` TEXT NOT NULL, `title` TEXT NOT NULL, `starTime` INTEGER NOT NULL, `link` TEXT NOT NULL, `pubDate` TEXT, `description` TEXT, `content` TEXT, `image` TEXT, `variable` TEXT, PRIMARY KEY(`origin`, `link`))",
"fields": [
{
"fieldPath": "origin",
"columnName": "origin",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "sort",
"columnName": "sort",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "title",
"columnName": "title",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "starTime",
"columnName": "starTime",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "link",
"columnName": "link",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "pubDate",
"columnName": "pubDate",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "description",
"columnName": "description",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "content",
"columnName": "content",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "image",
"columnName": "image",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "variable",
"columnName": "variable",
"affinity": "TEXT",
"notNull": false
}
],
"primaryKey": {
"columnNames": [
"origin",
"link"
],
"autoGenerate": false
},
"indices": [],
"foreignKeys": []
},
{
"tableName": "txtTocRules",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`id` INTEGER NOT NULL, `name` TEXT NOT NULL, `rule` TEXT NOT NULL, `serialNumber` INTEGER NOT NULL, `enable` INTEGER NOT NULL, PRIMARY KEY(`id`))",
"fields": [
{
"fieldPath": "id",
"columnName": "id",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "name",
"columnName": "name",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "rule",
"columnName": "rule",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "serialNumber",
"columnName": "serialNumber",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "enable",
"columnName": "enable",
"affinity": "INTEGER",
"notNull": true
}
],
"primaryKey": {
"columnNames": [
"id"
],
"autoGenerate": false
},
"indices": [],
"foreignKeys": []
},
{
"tableName": "readRecord",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`deviceId` TEXT NOT NULL, `bookName` TEXT NOT NULL, `readTime` INTEGER NOT NULL, PRIMARY KEY(`deviceId`, `bookName`))",
"fields": [
{
"fieldPath": "deviceId",
"columnName": "deviceId",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "bookName",
"columnName": "bookName",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "readTime",
"columnName": "readTime",
"affinity": "INTEGER",
"notNull": true
}
],
"primaryKey": {
"columnNames": [
"deviceId",
"bookName"
],
"autoGenerate": false
},
"indices": [],
"foreignKeys": []
},
{
"tableName": "httpTTS",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`id` INTEGER NOT NULL, `name` TEXT NOT NULL, `url` TEXT NOT NULL, `contentType` TEXT, `concurrentRate` TEXT, `loginUrl` TEXT, `loginUi` TEXT, `header` TEXT, `loginCheckJs` TEXT, PRIMARY KEY(`id`))",
"fields": [
{
"fieldPath": "id",
"columnName": "id",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "name",
"columnName": "name",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "url",
"columnName": "url",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "contentType",
"columnName": "contentType",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "concurrentRate",
"columnName": "concurrentRate",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "loginUrl",
"columnName": "loginUrl",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "loginUi",
"columnName": "loginUi",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "header",
"columnName": "header",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "loginCheckJs",
"columnName": "loginCheckJs",
"affinity": "TEXT",
"notNull": false
}
],
"primaryKey": {
"columnNames": [
"id"
],
"autoGenerate": false
},
"indices": [],
"foreignKeys": []
},
{
"tableName": "caches",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`key` TEXT NOT NULL, `value` TEXT, `deadline` INTEGER NOT NULL, PRIMARY KEY(`key`))",
"fields": [
{
"fieldPath": "key",
"columnName": "key",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "value",
"columnName": "value",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "deadline",
"columnName": "deadline",
"affinity": "INTEGER",
"notNull": true
}
],
"primaryKey": {
"columnNames": [
"key"
],
"autoGenerate": false
},
"indices": [
{
"name": "index_caches_key",
"unique": true,
"columnNames": [
"key"
],
"orders": [],
"createSql": "CREATE UNIQUE INDEX IF NOT EXISTS `index_caches_key` ON `${TABLE_NAME}` (`key`)"
}
],
"foreignKeys": []
},
{
"tableName": "ruleSubs",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`id` INTEGER NOT NULL, `name` TEXT NOT NULL, `url` TEXT NOT NULL, `type` INTEGER NOT NULL, `customOrder` INTEGER NOT NULL, `autoUpdate` INTEGER NOT NULL, `update` INTEGER NOT NULL, PRIMARY KEY(`id`))",
"fields": [
{
"fieldPath": "id",
"columnName": "id",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "name",
"columnName": "name",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "url",
"columnName": "url",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "type",
"columnName": "type",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "customOrder",
"columnName": "customOrder",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "autoUpdate",
"columnName": "autoUpdate",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "update",
"columnName": "update",
"affinity": "INTEGER",
"notNull": true
}
],
"primaryKey": {
"columnNames": [
"id"
],
"autoGenerate": false
},
"indices": [],
"foreignKeys": []
},
{
"tableName": "keyboardAssists",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`type` INTEGER NOT NULL DEFAULT 0, `key` TEXT NOT NULL DEFAULT '', `value` TEXT NOT NULL DEFAULT '', `serialNo` INTEGER NOT NULL DEFAULT 0, PRIMARY KEY(`type`, `key`))",
"fields": [
{
"fieldPath": "type",
"columnName": "type",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
},
{
"fieldPath": "key",
"columnName": "key",
"affinity": "TEXT",
"notNull": true,
"defaultValue": "''"
},
{
"fieldPath": "value",
"columnName": "value",
"affinity": "TEXT",
"notNull": true,
"defaultValue": "''"
},
{
"fieldPath": "serialNo",
"columnName": "serialNo",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
}
],
"primaryKey": {
"columnNames": [
"type",
"key"
],
"autoGenerate": false
},
"indices": [],
"foreignKeys": []
}
],
"views": [],
"setupQueries": [
"CREATE TABLE IF NOT EXISTS room_master_table (id INTEGER PRIMARY KEY,identity_hash TEXT)",
"INSERT OR REPLACE INTO room_master_table (id,identity_hash) VALUES(42, '63272539e04e405abfd79e27ea55db75')"
]
}
}

View File

@ -0,0 +1,1618 @@
{
"formatVersion": 1,
"database": {
"version": 46,
"identityHash": "63272539e04e405abfd79e27ea55db75",
"entities": [
{
"tableName": "books",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`bookUrl` TEXT NOT NULL DEFAULT '', `tocUrl` TEXT NOT NULL DEFAULT '', `origin` TEXT NOT NULL DEFAULT '', `originName` TEXT NOT NULL DEFAULT '', `name` TEXT NOT NULL DEFAULT '', `author` TEXT NOT NULL DEFAULT '', `kind` TEXT, `customTag` TEXT, `coverUrl` TEXT, `customCoverUrl` TEXT, `intro` TEXT, `customIntro` TEXT, `charset` TEXT, `type` INTEGER NOT NULL DEFAULT 0, `group` INTEGER NOT NULL DEFAULT 0, `latestChapterTitle` TEXT, `latestChapterTime` INTEGER NOT NULL DEFAULT 0, `lastCheckTime` INTEGER NOT NULL DEFAULT 0, `lastCheckCount` INTEGER NOT NULL DEFAULT 0, `totalChapterNum` INTEGER NOT NULL DEFAULT 0, `durChapterTitle` TEXT, `durChapterIndex` INTEGER NOT NULL DEFAULT 0, `durChapterPos` INTEGER NOT NULL DEFAULT 0, `durChapterTime` INTEGER NOT NULL DEFAULT 0, `wordCount` TEXT, `canUpdate` INTEGER NOT NULL DEFAULT 1, `order` INTEGER NOT NULL DEFAULT 0, `originOrder` INTEGER NOT NULL DEFAULT 0, `variable` TEXT, `readConfig` TEXT, PRIMARY KEY(`bookUrl`))",
"fields": [
{
"fieldPath": "bookUrl",
"columnName": "bookUrl",
"affinity": "TEXT",
"notNull": true,
"defaultValue": "''"
},
{
"fieldPath": "tocUrl",
"columnName": "tocUrl",
"affinity": "TEXT",
"notNull": true,
"defaultValue": "''"
},
{
"fieldPath": "origin",
"columnName": "origin",
"affinity": "TEXT",
"notNull": true,
"defaultValue": "''"
},
{
"fieldPath": "originName",
"columnName": "originName",
"affinity": "TEXT",
"notNull": true,
"defaultValue": "''"
},
{
"fieldPath": "name",
"columnName": "name",
"affinity": "TEXT",
"notNull": true,
"defaultValue": "''"
},
{
"fieldPath": "author",
"columnName": "author",
"affinity": "TEXT",
"notNull": true,
"defaultValue": "''"
},
{
"fieldPath": "kind",
"columnName": "kind",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "customTag",
"columnName": "customTag",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "coverUrl",
"columnName": "coverUrl",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "customCoverUrl",
"columnName": "customCoverUrl",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "intro",
"columnName": "intro",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "customIntro",
"columnName": "customIntro",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "charset",
"columnName": "charset",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "type",
"columnName": "type",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
},
{
"fieldPath": "group",
"columnName": "group",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
},
{
"fieldPath": "latestChapterTitle",
"columnName": "latestChapterTitle",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "latestChapterTime",
"columnName": "latestChapterTime",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
},
{
"fieldPath": "lastCheckTime",
"columnName": "lastCheckTime",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
},
{
"fieldPath": "lastCheckCount",
"columnName": "lastCheckCount",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
},
{
"fieldPath": "totalChapterNum",
"columnName": "totalChapterNum",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
},
{
"fieldPath": "durChapterTitle",
"columnName": "durChapterTitle",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "durChapterIndex",
"columnName": "durChapterIndex",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
},
{
"fieldPath": "durChapterPos",
"columnName": "durChapterPos",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
},
{
"fieldPath": "durChapterTime",
"columnName": "durChapterTime",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
},
{
"fieldPath": "wordCount",
"columnName": "wordCount",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "canUpdate",
"columnName": "canUpdate",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "1"
},
{
"fieldPath": "order",
"columnName": "order",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
},
{
"fieldPath": "originOrder",
"columnName": "originOrder",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
},
{
"fieldPath": "variable",
"columnName": "variable",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "readConfig",
"columnName": "readConfig",
"affinity": "TEXT",
"notNull": false
}
],
"primaryKey": {
"columnNames": [
"bookUrl"
],
"autoGenerate": false
},
"indices": [
{
"name": "index_books_name_author",
"unique": true,
"columnNames": [
"name",
"author"
],
"orders": [],
"createSql": "CREATE UNIQUE INDEX IF NOT EXISTS `index_books_name_author` ON `${TABLE_NAME}` (`name`, `author`)"
}
],
"foreignKeys": []
},
{
"tableName": "book_groups",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`groupId` INTEGER NOT NULL, `groupName` TEXT NOT NULL, `cover` TEXT, `order` INTEGER NOT NULL, `show` INTEGER NOT NULL, PRIMARY KEY(`groupId`))",
"fields": [
{
"fieldPath": "groupId",
"columnName": "groupId",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "groupName",
"columnName": "groupName",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "cover",
"columnName": "cover",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "order",
"columnName": "order",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "show",
"columnName": "show",
"affinity": "INTEGER",
"notNull": true
}
],
"primaryKey": {
"columnNames": [
"groupId"
],
"autoGenerate": false
},
"indices": [],
"foreignKeys": []
},
{
"tableName": "book_sources",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`bookSourceUrl` TEXT NOT NULL, `bookSourceName` TEXT NOT NULL, `bookSourceGroup` TEXT, `bookSourceType` INTEGER NOT NULL, `bookUrlPattern` TEXT, `customOrder` INTEGER NOT NULL, `enabled` INTEGER NOT NULL, `enabledExplore` INTEGER NOT NULL, `concurrentRate` TEXT, `header` TEXT, `loginUrl` TEXT, `loginUi` TEXT, `loginCheckJs` TEXT, `bookSourceComment` TEXT, `lastUpdateTime` INTEGER NOT NULL, `respondTime` INTEGER NOT NULL, `weight` INTEGER NOT NULL, `exploreUrl` TEXT, `ruleExplore` TEXT, `searchUrl` TEXT, `ruleSearch` TEXT, `ruleBookInfo` TEXT, `ruleToc` TEXT, `ruleContent` TEXT, PRIMARY KEY(`bookSourceUrl`))",
"fields": [
{
"fieldPath": "bookSourceUrl",
"columnName": "bookSourceUrl",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "bookSourceName",
"columnName": "bookSourceName",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "bookSourceGroup",
"columnName": "bookSourceGroup",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "bookSourceType",
"columnName": "bookSourceType",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "bookUrlPattern",
"columnName": "bookUrlPattern",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "customOrder",
"columnName": "customOrder",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "enabled",
"columnName": "enabled",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "enabledExplore",
"columnName": "enabledExplore",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "concurrentRate",
"columnName": "concurrentRate",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "header",
"columnName": "header",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "loginUrl",
"columnName": "loginUrl",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "loginUi",
"columnName": "loginUi",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "loginCheckJs",
"columnName": "loginCheckJs",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "bookSourceComment",
"columnName": "bookSourceComment",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "lastUpdateTime",
"columnName": "lastUpdateTime",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "respondTime",
"columnName": "respondTime",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "weight",
"columnName": "weight",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "exploreUrl",
"columnName": "exploreUrl",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "ruleExplore",
"columnName": "ruleExplore",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "searchUrl",
"columnName": "searchUrl",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "ruleSearch",
"columnName": "ruleSearch",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "ruleBookInfo",
"columnName": "ruleBookInfo",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "ruleToc",
"columnName": "ruleToc",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "ruleContent",
"columnName": "ruleContent",
"affinity": "TEXT",
"notNull": false
}
],
"primaryKey": {
"columnNames": [
"bookSourceUrl"
],
"autoGenerate": false
},
"indices": [
{
"name": "index_book_sources_bookSourceUrl",
"unique": false,
"columnNames": [
"bookSourceUrl"
],
"orders": [],
"createSql": "CREATE INDEX IF NOT EXISTS `index_book_sources_bookSourceUrl` ON `${TABLE_NAME}` (`bookSourceUrl`)"
}
],
"foreignKeys": []
},
{
"tableName": "chapters",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`url` TEXT NOT NULL, `title` TEXT NOT NULL, `isVolume` INTEGER NOT NULL, `baseUrl` TEXT NOT NULL, `bookUrl` TEXT NOT NULL, `index` INTEGER NOT NULL, `isVip` INTEGER NOT NULL, `isPay` INTEGER NOT NULL, `resourceUrl` TEXT, `tag` TEXT, `start` INTEGER, `end` INTEGER, `startFragmentId` TEXT, `endFragmentId` TEXT, `variable` TEXT, PRIMARY KEY(`url`, `bookUrl`), FOREIGN KEY(`bookUrl`) REFERENCES `books`(`bookUrl`) ON UPDATE NO ACTION ON DELETE CASCADE )",
"fields": [
{
"fieldPath": "url",
"columnName": "url",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "title",
"columnName": "title",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "isVolume",
"columnName": "isVolume",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "baseUrl",
"columnName": "baseUrl",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "bookUrl",
"columnName": "bookUrl",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "index",
"columnName": "index",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "isVip",
"columnName": "isVip",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "isPay",
"columnName": "isPay",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "resourceUrl",
"columnName": "resourceUrl",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "tag",
"columnName": "tag",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "start",
"columnName": "start",
"affinity": "INTEGER",
"notNull": false
},
{
"fieldPath": "end",
"columnName": "end",
"affinity": "INTEGER",
"notNull": false
},
{
"fieldPath": "startFragmentId",
"columnName": "startFragmentId",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "endFragmentId",
"columnName": "endFragmentId",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "variable",
"columnName": "variable",
"affinity": "TEXT",
"notNull": false
}
],
"primaryKey": {
"columnNames": [
"url",
"bookUrl"
],
"autoGenerate": false
},
"indices": [
{
"name": "index_chapters_bookUrl",
"unique": false,
"columnNames": [
"bookUrl"
],
"orders": [],
"createSql": "CREATE INDEX IF NOT EXISTS `index_chapters_bookUrl` ON `${TABLE_NAME}` (`bookUrl`)"
},
{
"name": "index_chapters_bookUrl_index",
"unique": true,
"columnNames": [
"bookUrl",
"index"
],
"orders": [],
"createSql": "CREATE UNIQUE INDEX IF NOT EXISTS `index_chapters_bookUrl_index` ON `${TABLE_NAME}` (`bookUrl`, `index`)"
}
],
"foreignKeys": [
{
"table": "books",
"onDelete": "CASCADE",
"onUpdate": "NO ACTION",
"columns": [
"bookUrl"
],
"referencedColumns": [
"bookUrl"
]
}
]
},
{
"tableName": "replace_rules",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`id` INTEGER PRIMARY KEY AUTOINCREMENT NOT NULL, `name` TEXT NOT NULL DEFAULT '', `group` TEXT, `pattern` TEXT NOT NULL DEFAULT '', `replacement` TEXT NOT NULL DEFAULT '', `scope` TEXT, `scopeTitle` INTEGER NOT NULL DEFAULT 0, `scopeContent` INTEGER NOT NULL DEFAULT 1, `isEnabled` INTEGER NOT NULL DEFAULT 1, `isRegex` INTEGER NOT NULL DEFAULT 1, `sortOrder` INTEGER NOT NULL DEFAULT 0)",
"fields": [
{
"fieldPath": "id",
"columnName": "id",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "name",
"columnName": "name",
"affinity": "TEXT",
"notNull": true,
"defaultValue": "''"
},
{
"fieldPath": "group",
"columnName": "group",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "pattern",
"columnName": "pattern",
"affinity": "TEXT",
"notNull": true,
"defaultValue": "''"
},
{
"fieldPath": "replacement",
"columnName": "replacement",
"affinity": "TEXT",
"notNull": true,
"defaultValue": "''"
},
{
"fieldPath": "scope",
"columnName": "scope",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "scopeTitle",
"columnName": "scopeTitle",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
},
{
"fieldPath": "scopeContent",
"columnName": "scopeContent",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "1"
},
{
"fieldPath": "isEnabled",
"columnName": "isEnabled",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "1"
},
{
"fieldPath": "isRegex",
"columnName": "isRegex",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "1"
},
{
"fieldPath": "order",
"columnName": "sortOrder",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
}
],
"primaryKey": {
"columnNames": [
"id"
],
"autoGenerate": true
},
"indices": [
{
"name": "index_replace_rules_id",
"unique": false,
"columnNames": [
"id"
],
"orders": [],
"createSql": "CREATE INDEX IF NOT EXISTS `index_replace_rules_id` ON `${TABLE_NAME}` (`id`)"
}
],
"foreignKeys": []
},
{
"tableName": "searchBooks",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`bookUrl` TEXT NOT NULL, `origin` TEXT NOT NULL, `originName` TEXT NOT NULL, `type` INTEGER NOT NULL, `name` TEXT NOT NULL, `author` TEXT NOT NULL, `kind` TEXT, `coverUrl` TEXT, `intro` TEXT, `wordCount` TEXT, `latestChapterTitle` TEXT, `tocUrl` TEXT NOT NULL, `time` INTEGER NOT NULL, `variable` TEXT, `originOrder` INTEGER NOT NULL, PRIMARY KEY(`bookUrl`), FOREIGN KEY(`origin`) REFERENCES `book_sources`(`bookSourceUrl`) ON UPDATE NO ACTION ON DELETE CASCADE )",
"fields": [
{
"fieldPath": "bookUrl",
"columnName": "bookUrl",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "origin",
"columnName": "origin",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "originName",
"columnName": "originName",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "type",
"columnName": "type",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "name",
"columnName": "name",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "author",
"columnName": "author",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "kind",
"columnName": "kind",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "coverUrl",
"columnName": "coverUrl",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "intro",
"columnName": "intro",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "wordCount",
"columnName": "wordCount",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "latestChapterTitle",
"columnName": "latestChapterTitle",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "tocUrl",
"columnName": "tocUrl",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "time",
"columnName": "time",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "variable",
"columnName": "variable",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "originOrder",
"columnName": "originOrder",
"affinity": "INTEGER",
"notNull": true
}
],
"primaryKey": {
"columnNames": [
"bookUrl"
],
"autoGenerate": false
},
"indices": [
{
"name": "index_searchBooks_bookUrl",
"unique": true,
"columnNames": [
"bookUrl"
],
"orders": [],
"createSql": "CREATE UNIQUE INDEX IF NOT EXISTS `index_searchBooks_bookUrl` ON `${TABLE_NAME}` (`bookUrl`)"
},
{
"name": "index_searchBooks_origin",
"unique": false,
"columnNames": [
"origin"
],
"orders": [],
"createSql": "CREATE INDEX IF NOT EXISTS `index_searchBooks_origin` ON `${TABLE_NAME}` (`origin`)"
}
],
"foreignKeys": [
{
"table": "book_sources",
"onDelete": "CASCADE",
"onUpdate": "NO ACTION",
"columns": [
"origin"
],
"referencedColumns": [
"bookSourceUrl"
]
}
]
},
{
"tableName": "search_keywords",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`word` TEXT NOT NULL, `usage` INTEGER NOT NULL, `lastUseTime` INTEGER NOT NULL, PRIMARY KEY(`word`))",
"fields": [
{
"fieldPath": "word",
"columnName": "word",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "usage",
"columnName": "usage",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "lastUseTime",
"columnName": "lastUseTime",
"affinity": "INTEGER",
"notNull": true
}
],
"primaryKey": {
"columnNames": [
"word"
],
"autoGenerate": false
},
"indices": [
{
"name": "index_search_keywords_word",
"unique": true,
"columnNames": [
"word"
],
"orders": [],
"createSql": "CREATE UNIQUE INDEX IF NOT EXISTS `index_search_keywords_word` ON `${TABLE_NAME}` (`word`)"
}
],
"foreignKeys": []
},
{
"tableName": "cookies",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`url` TEXT NOT NULL, `cookie` TEXT NOT NULL, PRIMARY KEY(`url`))",
"fields": [
{
"fieldPath": "url",
"columnName": "url",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "cookie",
"columnName": "cookie",
"affinity": "TEXT",
"notNull": true
}
],
"primaryKey": {
"columnNames": [
"url"
],
"autoGenerate": false
},
"indices": [
{
"name": "index_cookies_url",
"unique": true,
"columnNames": [
"url"
],
"orders": [],
"createSql": "CREATE UNIQUE INDEX IF NOT EXISTS `index_cookies_url` ON `${TABLE_NAME}` (`url`)"
}
],
"foreignKeys": []
},
{
"tableName": "rssSources",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`sourceUrl` TEXT NOT NULL, `sourceName` TEXT NOT NULL, `sourceIcon` TEXT NOT NULL, `sourceGroup` TEXT, `sourceComment` TEXT, `enabled` INTEGER NOT NULL, `concurrentRate` TEXT, `header` TEXT, `loginUrl` TEXT, `loginUi` TEXT, `loginCheckJs` TEXT, `sortUrl` TEXT, `singleUrl` INTEGER NOT NULL, `articleStyle` INTEGER NOT NULL, `ruleArticles` TEXT, `ruleNextPage` TEXT, `ruleTitle` TEXT, `rulePubDate` TEXT, `ruleDescription` TEXT, `ruleImage` TEXT, `ruleLink` TEXT, `ruleContent` TEXT, `style` TEXT, `enableJs` INTEGER NOT NULL, `loadWithBaseUrl` INTEGER NOT NULL, `customOrder` INTEGER NOT NULL, PRIMARY KEY(`sourceUrl`))",
"fields": [
{
"fieldPath": "sourceUrl",
"columnName": "sourceUrl",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "sourceName",
"columnName": "sourceName",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "sourceIcon",
"columnName": "sourceIcon",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "sourceGroup",
"columnName": "sourceGroup",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "sourceComment",
"columnName": "sourceComment",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "enabled",
"columnName": "enabled",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "concurrentRate",
"columnName": "concurrentRate",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "header",
"columnName": "header",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "loginUrl",
"columnName": "loginUrl",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "loginUi",
"columnName": "loginUi",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "loginCheckJs",
"columnName": "loginCheckJs",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "sortUrl",
"columnName": "sortUrl",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "singleUrl",
"columnName": "singleUrl",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "articleStyle",
"columnName": "articleStyle",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "ruleArticles",
"columnName": "ruleArticles",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "ruleNextPage",
"columnName": "ruleNextPage",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "ruleTitle",
"columnName": "ruleTitle",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "rulePubDate",
"columnName": "rulePubDate",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "ruleDescription",
"columnName": "ruleDescription",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "ruleImage",
"columnName": "ruleImage",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "ruleLink",
"columnName": "ruleLink",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "ruleContent",
"columnName": "ruleContent",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "style",
"columnName": "style",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "enableJs",
"columnName": "enableJs",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "loadWithBaseUrl",
"columnName": "loadWithBaseUrl",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "customOrder",
"columnName": "customOrder",
"affinity": "INTEGER",
"notNull": true
}
],
"primaryKey": {
"columnNames": [
"sourceUrl"
],
"autoGenerate": false
},
"indices": [
{
"name": "index_rssSources_sourceUrl",
"unique": false,
"columnNames": [
"sourceUrl"
],
"orders": [],
"createSql": "CREATE INDEX IF NOT EXISTS `index_rssSources_sourceUrl` ON `${TABLE_NAME}` (`sourceUrl`)"
}
],
"foreignKeys": []
},
{
"tableName": "bookmarks",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`time` INTEGER NOT NULL, `bookName` TEXT NOT NULL, `bookAuthor` TEXT NOT NULL, `chapterIndex` INTEGER NOT NULL, `chapterPos` INTEGER NOT NULL, `chapterName` TEXT NOT NULL, `bookText` TEXT NOT NULL, `content` TEXT NOT NULL, PRIMARY KEY(`time`))",
"fields": [
{
"fieldPath": "time",
"columnName": "time",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "bookName",
"columnName": "bookName",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "bookAuthor",
"columnName": "bookAuthor",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "chapterIndex",
"columnName": "chapterIndex",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "chapterPos",
"columnName": "chapterPos",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "chapterName",
"columnName": "chapterName",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "bookText",
"columnName": "bookText",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "content",
"columnName": "content",
"affinity": "TEXT",
"notNull": true
}
],
"primaryKey": {
"columnNames": [
"time"
],
"autoGenerate": false
},
"indices": [
{
"name": "index_bookmarks_bookName_bookAuthor",
"unique": false,
"columnNames": [
"bookName",
"bookAuthor"
],
"orders": [],
"createSql": "CREATE INDEX IF NOT EXISTS `index_bookmarks_bookName_bookAuthor` ON `${TABLE_NAME}` (`bookName`, `bookAuthor`)"
}
],
"foreignKeys": []
},
{
"tableName": "rssArticles",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`origin` TEXT NOT NULL, `sort` TEXT NOT NULL, `title` TEXT NOT NULL, `order` INTEGER NOT NULL, `link` TEXT NOT NULL, `pubDate` TEXT, `description` TEXT, `content` TEXT, `image` TEXT, `read` INTEGER NOT NULL, `variable` TEXT, PRIMARY KEY(`origin`, `link`))",
"fields": [
{
"fieldPath": "origin",
"columnName": "origin",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "sort",
"columnName": "sort",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "title",
"columnName": "title",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "order",
"columnName": "order",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "link",
"columnName": "link",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "pubDate",
"columnName": "pubDate",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "description",
"columnName": "description",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "content",
"columnName": "content",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "image",
"columnName": "image",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "read",
"columnName": "read",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "variable",
"columnName": "variable",
"affinity": "TEXT",
"notNull": false
}
],
"primaryKey": {
"columnNames": [
"origin",
"link"
],
"autoGenerate": false
},
"indices": [],
"foreignKeys": []
},
{
"tableName": "rssReadRecords",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`record` TEXT NOT NULL, `read` INTEGER NOT NULL, PRIMARY KEY(`record`))",
"fields": [
{
"fieldPath": "record",
"columnName": "record",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "read",
"columnName": "read",
"affinity": "INTEGER",
"notNull": true
}
],
"primaryKey": {
"columnNames": [
"record"
],
"autoGenerate": false
},
"indices": [],
"foreignKeys": []
},
{
"tableName": "rssStars",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`origin` TEXT NOT NULL, `sort` TEXT NOT NULL, `title` TEXT NOT NULL, `starTime` INTEGER NOT NULL, `link` TEXT NOT NULL, `pubDate` TEXT, `description` TEXT, `content` TEXT, `image` TEXT, `variable` TEXT, PRIMARY KEY(`origin`, `link`))",
"fields": [
{
"fieldPath": "origin",
"columnName": "origin",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "sort",
"columnName": "sort",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "title",
"columnName": "title",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "starTime",
"columnName": "starTime",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "link",
"columnName": "link",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "pubDate",
"columnName": "pubDate",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "description",
"columnName": "description",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "content",
"columnName": "content",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "image",
"columnName": "image",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "variable",
"columnName": "variable",
"affinity": "TEXT",
"notNull": false
}
],
"primaryKey": {
"columnNames": [
"origin",
"link"
],
"autoGenerate": false
},
"indices": [],
"foreignKeys": []
},
{
"tableName": "txtTocRules",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`id` INTEGER NOT NULL, `name` TEXT NOT NULL, `rule` TEXT NOT NULL, `serialNumber` INTEGER NOT NULL, `enable` INTEGER NOT NULL, PRIMARY KEY(`id`))",
"fields": [
{
"fieldPath": "id",
"columnName": "id",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "name",
"columnName": "name",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "rule",
"columnName": "rule",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "serialNumber",
"columnName": "serialNumber",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "enable",
"columnName": "enable",
"affinity": "INTEGER",
"notNull": true
}
],
"primaryKey": {
"columnNames": [
"id"
],
"autoGenerate": false
},
"indices": [],
"foreignKeys": []
},
{
"tableName": "readRecord",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`deviceId` TEXT NOT NULL, `bookName` TEXT NOT NULL, `readTime` INTEGER NOT NULL, PRIMARY KEY(`deviceId`, `bookName`))",
"fields": [
{
"fieldPath": "deviceId",
"columnName": "deviceId",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "bookName",
"columnName": "bookName",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "readTime",
"columnName": "readTime",
"affinity": "INTEGER",
"notNull": true
}
],
"primaryKey": {
"columnNames": [
"deviceId",
"bookName"
],
"autoGenerate": false
},
"indices": [],
"foreignKeys": []
},
{
"tableName": "httpTTS",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`id` INTEGER NOT NULL, `name` TEXT NOT NULL, `url` TEXT NOT NULL, `contentType` TEXT, `concurrentRate` TEXT, `loginUrl` TEXT, `loginUi` TEXT, `header` TEXT, `loginCheckJs` TEXT, PRIMARY KEY(`id`))",
"fields": [
{
"fieldPath": "id",
"columnName": "id",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "name",
"columnName": "name",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "url",
"columnName": "url",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "contentType",
"columnName": "contentType",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "concurrentRate",
"columnName": "concurrentRate",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "loginUrl",
"columnName": "loginUrl",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "loginUi",
"columnName": "loginUi",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "header",
"columnName": "header",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "loginCheckJs",
"columnName": "loginCheckJs",
"affinity": "TEXT",
"notNull": false
}
],
"primaryKey": {
"columnNames": [
"id"
],
"autoGenerate": false
},
"indices": [],
"foreignKeys": []
},
{
"tableName": "caches",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`key` TEXT NOT NULL, `value` TEXT, `deadline` INTEGER NOT NULL, PRIMARY KEY(`key`))",
"fields": [
{
"fieldPath": "key",
"columnName": "key",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "value",
"columnName": "value",
"affinity": "TEXT",
"notNull": false
},
{
"fieldPath": "deadline",
"columnName": "deadline",
"affinity": "INTEGER",
"notNull": true
}
],
"primaryKey": {
"columnNames": [
"key"
],
"autoGenerate": false
},
"indices": [
{
"name": "index_caches_key",
"unique": true,
"columnNames": [
"key"
],
"orders": [],
"createSql": "CREATE UNIQUE INDEX IF NOT EXISTS `index_caches_key` ON `${TABLE_NAME}` (`key`)"
}
],
"foreignKeys": []
},
{
"tableName": "ruleSubs",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`id` INTEGER NOT NULL, `name` TEXT NOT NULL, `url` TEXT NOT NULL, `type` INTEGER NOT NULL, `customOrder` INTEGER NOT NULL, `autoUpdate` INTEGER NOT NULL, `update` INTEGER NOT NULL, PRIMARY KEY(`id`))",
"fields": [
{
"fieldPath": "id",
"columnName": "id",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "name",
"columnName": "name",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "url",
"columnName": "url",
"affinity": "TEXT",
"notNull": true
},
{
"fieldPath": "type",
"columnName": "type",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "customOrder",
"columnName": "customOrder",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "autoUpdate",
"columnName": "autoUpdate",
"affinity": "INTEGER",
"notNull": true
},
{
"fieldPath": "update",
"columnName": "update",
"affinity": "INTEGER",
"notNull": true
}
],
"primaryKey": {
"columnNames": [
"id"
],
"autoGenerate": false
},
"indices": [],
"foreignKeys": []
},
{
"tableName": "keyboardAssists",
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`type` INTEGER NOT NULL DEFAULT 0, `key` TEXT NOT NULL DEFAULT '', `value` TEXT NOT NULL DEFAULT '', `serialNo` INTEGER NOT NULL DEFAULT 0, PRIMARY KEY(`type`, `key`))",
"fields": [
{
"fieldPath": "type",
"columnName": "type",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
},
{
"fieldPath": "key",
"columnName": "key",
"affinity": "TEXT",
"notNull": true,
"defaultValue": "''"
},
{
"fieldPath": "value",
"columnName": "value",
"affinity": "TEXT",
"notNull": true,
"defaultValue": "''"
},
{
"fieldPath": "serialNo",
"columnName": "serialNo",
"affinity": "INTEGER",
"notNull": true,
"defaultValue": "0"
}
],
"primaryKey": {
"columnNames": [
"type",
"key"
],
"autoGenerate": false
},
"indices": [],
"foreignKeys": []
}
],
"views": [],
"setupQueries": [
"CREATE TABLE IF NOT EXISTS room_master_table (id INTEGER PRIMARY KEY,identity_hash TEXT)",
"INSERT OR REPLACE INTO room_master_table (id,identity_hash) VALUES(42, '63272539e04e405abfd79e27ea55db75')"
]
}
}

View File

@ -17,14 +17,18 @@ val appDb by lazy {
}
@Database(
version = 44,
version = 46,
exportSchema = true,
entities = [Book::class, BookGroup::class, BookSource::class, BookChapter::class,
ReplaceRule::class, SearchBook::class, SearchKeyword::class, Cookie::class,
RssSource::class, Bookmark::class, RssArticle::class, RssReadRecord::class,
RssStar::class, TxtTocRule::class, ReadRecord::class, HttpTTS::class, Cache::class,
RuleSub::class],
autoMigrations = [AutoMigration(from = 43, to = 44)]
RuleSub::class, KeyboardAssist::class],
autoMigrations = [
AutoMigration(from = 43, to = 44),
AutoMigration(from = 44, to = 45),
AutoMigration(from = 45, to = 46)
]
)
abstract class AppDatabase : RoomDatabase() {
@ -45,6 +49,7 @@ abstract class AppDatabase : RoomDatabase() {
abstract val httpTTSDao: HttpTTSDao
abstract val cacheDao: CacheDao
abstract val ruleSubDao: RuleSubDao
abstract val keyboardAssistsDao: KeyboardAssistsDao
companion object {

View File

@ -0,0 +1,23 @@
package io.legado.app.data.dao
import androidx.room.*
import io.legado.app.data.entities.KeyboardAssist
@Dao
interface KeyboardAssistsDao {
@get:Query("select * from keyboardAssists")
val all: List<KeyboardAssist>
@Query("select * from keyboardAssists where type = :type")
fun getByType(type: Int): List<KeyboardAssist>
@Insert(onConflict = OnConflictStrategy.REPLACE)
fun insert(vararg keyboardAssist: KeyboardAssist)
@Update
fun update(vararg keyboardAssist: KeyboardAssist)
@Delete
fun delete(vararg keyboardAssist: KeyboardAssist)
}

View File

@ -2,6 +2,7 @@ package io.legado.app.data.entities
import android.os.Parcelable
import androidx.room.*
import io.legado.app.constant.AppLog
import io.legado.app.constant.AppPattern
import io.legado.app.constant.BookType
import io.legado.app.data.appDb
@ -24,36 +25,82 @@ import kotlin.math.min
indices = [Index(value = ["name", "author"], unique = true)]
)
data class Book(
// 详情页Url(本地书源存储完整文件路径)
@PrimaryKey
override var bookUrl: String = "", // 详情页Url(本地书源存储完整文件路径)
var tocUrl: String = "", // 目录页Url (toc=table of Contents)
var origin: String = BookType.local, // 书源URL(默认BookType.local)
var originName: String = "", //书源名称 or 本地书籍文件名
override var name: String = "", // 书籍名称(书源获取)
override var author: String = "", // 作者名称(书源获取)
override var kind: String? = null, // 分类信息(书源获取)
var customTag: String? = null, // 分类信息(用户修改)
var coverUrl: String? = null, // 封面Url(书源获取)
var customCoverUrl: String? = null, // 封面Url(用户修改)
var intro: String? = null, // 简介内容(书源获取)
var customIntro: String? = null, // 简介内容(用户修改)
var charset: String? = null, // 自定义字符集名称(仅适用于本地书籍)
var type: Int = 0, // 0:text 1:audio
var group: Long = 0, // 自定义分组索引号
var latestChapterTitle: String? = null, // 最新章节标题
var latestChapterTime: Long = System.currentTimeMillis(), // 最新章节标题更新时间
var lastCheckTime: Long = System.currentTimeMillis(), // 最近一次更新书籍信息的时间
var lastCheckCount: Int = 0, // 最近一次发现新章节的数量
var totalChapterNum: Int = 0, // 书籍目录总数
var durChapterTitle: String? = null, // 当前章节名称
var durChapterIndex: Int = 0, // 当前章节索引
var durChapterPos: Int = 0, // 当前阅读的进度(首行字符的索引位置)
var durChapterTime: Long = System.currentTimeMillis(), // 最近一次阅读书籍的时间(打开正文的时间)
@ColumnInfo(defaultValue = "")
override var bookUrl: String = "",
// 目录页Url (toc=table of Contents)
@ColumnInfo(defaultValue = "")
var tocUrl: String = "",
// 书源URL(默认BookType.local)
@ColumnInfo(defaultValue = "")
var origin: String = BookType.local,
//书源名称 or 本地书籍文件名
@ColumnInfo(defaultValue = "")
var originName: String = "",
// 书籍名称(书源获取)
@ColumnInfo(defaultValue = "")
override var name: String = "",
// 作者名称(书源获取)
@ColumnInfo(defaultValue = "")
override var author: String = "",
// 分类信息(书源获取)
override var kind: String? = null,
// 分类信息(用户修改)
var customTag: String? = null,
// 封面Url(书源获取)
var coverUrl: String? = null,
// 封面Url(用户修改)
var customCoverUrl: String? = null,
// 简介内容(书源获取)
var intro: String? = null,
// 简介内容(用户修改)
var customIntro: String? = null,
// 自定义字符集名称(仅适用于本地书籍)
var charset: String? = null,
// 0:text 1:audio 3:image
@ColumnInfo(defaultValue = "0")
var type: Int = 0,
// 自定义分组索引号
@ColumnInfo(defaultValue = "0")
var group: Long = 0,
// 最新章节标题
var latestChapterTitle: String? = null,
// 最新章节标题更新时间
@ColumnInfo(defaultValue = "0")
var latestChapterTime: Long = System.currentTimeMillis(),
// 最近一次更新书籍信息的时间
@ColumnInfo(defaultValue = "0")
var lastCheckTime: Long = System.currentTimeMillis(),
// 最近一次发现新章节的数量
@ColumnInfo(defaultValue = "0")
var lastCheckCount: Int = 0,
// 书籍目录总数
@ColumnInfo(defaultValue = "0")
var totalChapterNum: Int = 0,
// 当前章节名称
var durChapterTitle: String? = null,
// 当前章节索引
@ColumnInfo(defaultValue = "0")
var durChapterIndex: Int = 0,
// 当前阅读的进度(首行字符的索引位置)
@ColumnInfo(defaultValue = "0")
var durChapterPos: Int = 0,
// 最近一次阅读书籍的时间(打开正文的时间)
@ColumnInfo(defaultValue = "0")
var durChapterTime: Long = System.currentTimeMillis(),
override var wordCount: String? = null,
var canUpdate: Boolean = true, // 刷新书架时更新书籍信息
var order: Int = 0, // 手动排序
var originOrder: Int = 0, //书源排序
var variable: String? = null, // 自定义书籍变量信息(用于书源规则检索书籍信息)
// 刷新书架时更新书籍信息
@ColumnInfo(defaultValue = "1")
var canUpdate: Boolean = true,
// 手动排序
@ColumnInfo(defaultValue = "0")
var order: Int = 0,
//书源排序
@ColumnInfo(defaultValue = "0")
var originOrder: Int = 0,
// 自定义书籍变量信息(用于书源规则检索书籍信息)
var variable: String? = null,
var readConfig: ReadConfig? = null
) : Parcelable, BaseBook {
@ -98,6 +145,10 @@ data class Book(
override fun putVariable(key: String, value: String?) {
if (value != null) {
if (value.length > 1000) {
AppLog.put("${name}设置变量长度超过1000,设置失败")
return
}
variableMap[key] = value
} else {
variableMap.remove(key)

View File

@ -7,6 +7,7 @@ import androidx.room.Ignore
import androidx.room.Index
import com.github.liuyueyi.quick.transfer.ChineseUtils
import io.legado.app.R
import io.legado.app.constant.AppLog
import io.legado.app.constant.AppPattern
import io.legado.app.help.config.AppConfig
import io.legado.app.model.analyzeRule.AnalyzeUrl
@ -56,6 +57,10 @@ data class BookChapter(
override fun putVariable(key: String, value: String?) {
if (value != null) {
if (value.length > 1000) {
AppLog.put("${title}设置变量长度超过1000,设置失败")
return
}
variableMap[key] = value
} else {
variableMap.remove(key)

View File

@ -0,0 +1,16 @@
package io.legado.app.data.entities
import androidx.room.ColumnInfo
import androidx.room.Entity
@Entity(tableName = "keyboardAssists", primaryKeys = ["type", "key"])
data class KeyboardAssist(
@ColumnInfo(defaultValue = "0")
val type: Int = 0,
@ColumnInfo(defaultValue = "")
val key: String,
@ColumnInfo(defaultValue = "")
val value: String,
@ColumnInfo(defaultValue = "0")
val serialNo: Int
)

View File

@ -1,4 +0,0 @@
package io.legado.app.data.entities
class KeyboardHelp {
}

View File

@ -2,6 +2,7 @@ package io.legado.app.data.entities
import androidx.room.Entity
import androidx.room.Ignore
import io.legado.app.constant.AppLog
import io.legado.app.model.analyzeRule.RuleDataInterface
import io.legado.app.utils.GSON
import io.legado.app.utils.fromJsonObject
@ -42,6 +43,10 @@ data class RssArticle(
override fun putVariable(key: String, value: String?) {
if (value != null) {
if (value.length > 1000) {
AppLog.put("${title}设置变量长度超过1000,设置失败")
return
}
variableMap[key] = value
} else {
variableMap.remove(key)

View File

@ -2,6 +2,7 @@ package io.legado.app.data.entities
import androidx.room.Entity
import androidx.room.Ignore
import io.legado.app.constant.AppLog
import io.legado.app.model.analyzeRule.RuleDataInterface
import io.legado.app.utils.GSON
import io.legado.app.utils.fromJsonObject
@ -34,6 +35,10 @@ data class RssStar(
override fun putVariable(key: String, value: String?) {
if (value != null) {
if (value.length > 1000) {
AppLog.put("${title}设置变量长度超过1000,设置失败")
return
}
variableMap[key] = value
} else {
variableMap.remove(key)

View File

@ -1,5 +1,7 @@
package io.legado.app.model.analyzeRule
import io.legado.app.constant.AppLog
class RuleData : RuleDataInterface {
override val variableMap by lazy {
@ -8,6 +10,10 @@ class RuleData : RuleDataInterface {
override fun putVariable(key: String, value: String?) {
if (value != null) {
if (value.length > 1000) {
AppLog.put("设置变量长度超过1000,设置失败")
return
}
variableMap[key] = value
} else {
variableMap.remove(key)