You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
387 lines
11 KiB
387 lines
11 KiB
3 years ago
|
{
|
||
|
"formatVersion": 1,
|
||
|
"database": {
|
||
|
"version": 4,
|
||
|
"identityHash": "f593c030a1a8b5af8e13c6ac6a0926a9",
|
||
|
"entities": [
|
||
|
{
|
||
|
"tableName": "authors",
|
||
|
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`id` INTEGER NOT NULL, `name` TEXT NOT NULL, `image_url` TEXT NOT NULL, PRIMARY KEY(`id`))",
|
||
|
"fields": [
|
||
|
{
|
||
|
"fieldPath": "id",
|
||
|
"columnName": "id",
|
||
|
"affinity": "INTEGER",
|
||
|
"notNull": true
|
||
|
},
|
||
|
{
|
||
|
"fieldPath": "name",
|
||
|
"columnName": "name",
|
||
|
"affinity": "TEXT",
|
||
|
"notNull": true
|
||
|
},
|
||
|
{
|
||
|
"fieldPath": "imageUrl",
|
||
|
"columnName": "image_url",
|
||
|
"affinity": "TEXT",
|
||
|
"notNull": true
|
||
|
}
|
||
|
],
|
||
|
"primaryKey": {
|
||
|
"columnNames": [
|
||
|
"id"
|
||
|
],
|
||
|
"autoGenerate": false
|
||
|
},
|
||
|
"indices": [
|
||
|
{
|
||
|
"name": "index_authors_name",
|
||
|
"unique": true,
|
||
|
"columnNames": [
|
||
|
"name"
|
||
|
],
|
||
|
"orders": [],
|
||
|
"createSql": "CREATE UNIQUE INDEX IF NOT EXISTS `index_authors_name` ON `${TABLE_NAME}` (`name`)"
|
||
|
}
|
||
|
],
|
||
|
"foreignKeys": []
|
||
|
},
|
||
|
{
|
||
|
"tableName": "episodes_authors",
|
||
|
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`episode_id` INTEGER NOT NULL, `author_id` INTEGER NOT NULL, PRIMARY KEY(`episode_id`, `author_id`), FOREIGN KEY(`episode_id`) REFERENCES `episodes`(`id`) ON UPDATE NO ACTION ON DELETE CASCADE , FOREIGN KEY(`author_id`) REFERENCES `authors`(`id`) ON UPDATE NO ACTION ON DELETE CASCADE )",
|
||
|
"fields": [
|
||
|
{
|
||
|
"fieldPath": "episodeId",
|
||
|
"columnName": "episode_id",
|
||
|
"affinity": "INTEGER",
|
||
|
"notNull": true
|
||
|
},
|
||
|
{
|
||
|
"fieldPath": "authorId",
|
||
|
"columnName": "author_id",
|
||
|
"affinity": "INTEGER",
|
||
|
"notNull": true
|
||
|
}
|
||
|
],
|
||
|
"primaryKey": {
|
||
|
"columnNames": [
|
||
|
"episode_id",
|
||
|
"author_id"
|
||
|
],
|
||
|
"autoGenerate": false
|
||
|
},
|
||
|
"indices": [],
|
||
|
"foreignKeys": [
|
||
|
{
|
||
|
"table": "episodes",
|
||
|
"onDelete": "CASCADE",
|
||
|
"onUpdate": "NO ACTION",
|
||
|
"columns": [
|
||
|
"episode_id"
|
||
|
],
|
||
|
"referencedColumns": [
|
||
|
"id"
|
||
|
]
|
||
|
},
|
||
|
{
|
||
|
"table": "authors",
|
||
|
"onDelete": "CASCADE",
|
||
|
"onUpdate": "NO ACTION",
|
||
|
"columns": [
|
||
|
"author_id"
|
||
|
],
|
||
|
"referencedColumns": [
|
||
|
"id"
|
||
|
]
|
||
|
}
|
||
|
]
|
||
|
},
|
||
|
{
|
||
|
"tableName": "episodes",
|
||
|
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`id` INTEGER NOT NULL, `name` TEXT NOT NULL, `publish_date` INTEGER NOT NULL, `alternate_video` TEXT, `alternate_audio` TEXT, PRIMARY KEY(`id`))",
|
||
|
"fields": [
|
||
|
{
|
||
|
"fieldPath": "id",
|
||
|
"columnName": "id",
|
||
|
"affinity": "INTEGER",
|
||
|
"notNull": true
|
||
|
},
|
||
|
{
|
||
|
"fieldPath": "name",
|
||
|
"columnName": "name",
|
||
|
"affinity": "TEXT",
|
||
|
"notNull": true
|
||
|
},
|
||
|
{
|
||
|
"fieldPath": "publishDate",
|
||
|
"columnName": "publish_date",
|
||
|
"affinity": "INTEGER",
|
||
|
"notNull": true
|
||
|
},
|
||
|
{
|
||
|
"fieldPath": "alternateVideo",
|
||
|
"columnName": "alternate_video",
|
||
|
"affinity": "TEXT",
|
||
|
"notNull": false
|
||
|
},
|
||
|
{
|
||
|
"fieldPath": "alternateAudio",
|
||
|
"columnName": "alternate_audio",
|
||
|
"affinity": "TEXT",
|
||
|
"notNull": false
|
||
|
}
|
||
|
],
|
||
|
"primaryKey": {
|
||
|
"columnNames": [
|
||
|
"id"
|
||
|
],
|
||
|
"autoGenerate": false
|
||
|
},
|
||
|
"indices": [],
|
||
|
"foreignKeys": []
|
||
|
},
|
||
|
{
|
||
|
"tableName": "news_resources_authors",
|
||
|
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`news_resource_id` INTEGER NOT NULL, `author_id` INTEGER NOT NULL, PRIMARY KEY(`news_resource_id`, `author_id`), FOREIGN KEY(`news_resource_id`) REFERENCES `news_resources`(`id`) ON UPDATE NO ACTION ON DELETE CASCADE , FOREIGN KEY(`author_id`) REFERENCES `authors`(`id`) ON UPDATE NO ACTION ON DELETE CASCADE )",
|
||
|
"fields": [
|
||
|
{
|
||
|
"fieldPath": "newsResourceId",
|
||
|
"columnName": "news_resource_id",
|
||
|
"affinity": "INTEGER",
|
||
|
"notNull": true
|
||
|
},
|
||
|
{
|
||
|
"fieldPath": "authorId",
|
||
|
"columnName": "author_id",
|
||
|
"affinity": "INTEGER",
|
||
|
"notNull": true
|
||
|
}
|
||
|
],
|
||
|
"primaryKey": {
|
||
|
"columnNames": [
|
||
|
"news_resource_id",
|
||
|
"author_id"
|
||
|
],
|
||
|
"autoGenerate": false
|
||
|
},
|
||
|
"indices": [],
|
||
|
"foreignKeys": [
|
||
|
{
|
||
|
"table": "news_resources",
|
||
|
"onDelete": "CASCADE",
|
||
|
"onUpdate": "NO ACTION",
|
||
|
"columns": [
|
||
|
"news_resource_id"
|
||
|
],
|
||
|
"referencedColumns": [
|
||
|
"id"
|
||
|
]
|
||
|
},
|
||
|
{
|
||
|
"table": "authors",
|
||
|
"onDelete": "CASCADE",
|
||
|
"onUpdate": "NO ACTION",
|
||
|
"columns": [
|
||
|
"author_id"
|
||
|
],
|
||
|
"referencedColumns": [
|
||
|
"id"
|
||
|
]
|
||
|
}
|
||
|
]
|
||
|
},
|
||
|
{
|
||
|
"tableName": "news_resources",
|
||
|
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`id` INTEGER NOT NULL, `episode_id` INTEGER NOT NULL, `title` TEXT NOT NULL, `content` TEXT NOT NULL, `url` TEXT NOT NULL, `header_image_url` TEXT, `publish_date` INTEGER NOT NULL, `type` TEXT NOT NULL, PRIMARY KEY(`id`), FOREIGN KEY(`episode_id`) REFERENCES `episodes`(`id`) ON UPDATE NO ACTION ON DELETE CASCADE )",
|
||
|
"fields": [
|
||
|
{
|
||
|
"fieldPath": "id",
|
||
|
"columnName": "id",
|
||
|
"affinity": "INTEGER",
|
||
|
"notNull": true
|
||
|
},
|
||
|
{
|
||
|
"fieldPath": "episodeId",
|
||
|
"columnName": "episode_id",
|
||
|
"affinity": "INTEGER",
|
||
|
"notNull": true
|
||
|
},
|
||
|
{
|
||
|
"fieldPath": "title",
|
||
|
"columnName": "title",
|
||
|
"affinity": "TEXT",
|
||
|
"notNull": true
|
||
|
},
|
||
|
{
|
||
|
"fieldPath": "content",
|
||
|
"columnName": "content",
|
||
|
"affinity": "TEXT",
|
||
|
"notNull": true
|
||
|
},
|
||
|
{
|
||
|
"fieldPath": "url",
|
||
|
"columnName": "url",
|
||
|
"affinity": "TEXT",
|
||
|
"notNull": true
|
||
|
},
|
||
|
{
|
||
|
"fieldPath": "headerImageUrl",
|
||
|
"columnName": "header_image_url",
|
||
|
"affinity": "TEXT",
|
||
|
"notNull": false
|
||
|
},
|
||
|
{
|
||
|
"fieldPath": "publishDate",
|
||
|
"columnName": "publish_date",
|
||
|
"affinity": "INTEGER",
|
||
|
"notNull": true
|
||
|
},
|
||
|
{
|
||
|
"fieldPath": "type",
|
||
|
"columnName": "type",
|
||
|
"affinity": "TEXT",
|
||
|
"notNull": true
|
||
|
}
|
||
|
],
|
||
|
"primaryKey": {
|
||
|
"columnNames": [
|
||
|
"id"
|
||
|
],
|
||
|
"autoGenerate": false
|
||
|
},
|
||
|
"indices": [],
|
||
|
"foreignKeys": [
|
||
|
{
|
||
|
"table": "episodes",
|
||
|
"onDelete": "CASCADE",
|
||
|
"onUpdate": "NO ACTION",
|
||
|
"columns": [
|
||
|
"episode_id"
|
||
|
],
|
||
|
"referencedColumns": [
|
||
|
"id"
|
||
|
]
|
||
|
}
|
||
|
]
|
||
|
},
|
||
|
{
|
||
|
"tableName": "news_resources_topics",
|
||
|
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`news_resource_id` INTEGER NOT NULL, `topic_id` INTEGER NOT NULL, PRIMARY KEY(`news_resource_id`, `topic_id`), FOREIGN KEY(`news_resource_id`) REFERENCES `news_resources`(`id`) ON UPDATE NO ACTION ON DELETE CASCADE , FOREIGN KEY(`topic_id`) REFERENCES `topics`(`id`) ON UPDATE NO ACTION ON DELETE CASCADE )",
|
||
|
"fields": [
|
||
|
{
|
||
|
"fieldPath": "newsResourceId",
|
||
|
"columnName": "news_resource_id",
|
||
|
"affinity": "INTEGER",
|
||
|
"notNull": true
|
||
|
},
|
||
|
{
|
||
|
"fieldPath": "topicId",
|
||
|
"columnName": "topic_id",
|
||
|
"affinity": "INTEGER",
|
||
|
"notNull": true
|
||
|
}
|
||
|
],
|
||
|
"primaryKey": {
|
||
|
"columnNames": [
|
||
|
"news_resource_id",
|
||
|
"topic_id"
|
||
|
],
|
||
|
"autoGenerate": false
|
||
|
},
|
||
|
"indices": [],
|
||
|
"foreignKeys": [
|
||
|
{
|
||
|
"table": "news_resources",
|
||
|
"onDelete": "CASCADE",
|
||
|
"onUpdate": "NO ACTION",
|
||
|
"columns": [
|
||
|
"news_resource_id"
|
||
|
],
|
||
|
"referencedColumns": [
|
||
|
"id"
|
||
|
]
|
||
|
},
|
||
|
{
|
||
|
"table": "topics",
|
||
|
"onDelete": "CASCADE",
|
||
|
"onUpdate": "NO ACTION",
|
||
|
"columns": [
|
||
|
"topic_id"
|
||
|
],
|
||
|
"referencedColumns": [
|
||
|
"id"
|
||
|
]
|
||
|
}
|
||
|
]
|
||
|
},
|
||
|
{
|
||
|
"tableName": "topics",
|
||
|
"createSql": "CREATE TABLE IF NOT EXISTS `${TABLE_NAME}` (`id` INTEGER NOT NULL, `name` TEXT NOT NULL, `shortDescription` TEXT NOT NULL, `longDescription` TEXT NOT NULL DEFAULT '', `url` TEXT NOT NULL DEFAULT '', `imageUrl` TEXT NOT NULL DEFAULT '', PRIMARY KEY(`id`))",
|
||
|
"fields": [
|
||
|
{
|
||
|
"fieldPath": "id",
|
||
|
"columnName": "id",
|
||
|
"affinity": "INTEGER",
|
||
|
"notNull": true
|
||
|
},
|
||
|
{
|
||
|
"fieldPath": "name",
|
||
|
"columnName": "name",
|
||
|
"affinity": "TEXT",
|
||
|
"notNull": true
|
||
|
},
|
||
|
{
|
||
|
"fieldPath": "shortDescription",
|
||
|
"columnName": "shortDescription",
|
||
|
"affinity": "TEXT",
|
||
|
"notNull": true
|
||
|
},
|
||
|
{
|
||
|
"fieldPath": "longDescription",
|
||
|
"columnName": "longDescription",
|
||
|
"affinity": "TEXT",
|
||
|
"notNull": true,
|
||
|
"defaultValue": "''"
|
||
|
},
|
||
|
{
|
||
|
"fieldPath": "url",
|
||
|
"columnName": "url",
|
||
|
"affinity": "TEXT",
|
||
|
"notNull": true,
|
||
|
"defaultValue": "''"
|
||
|
},
|
||
|
{
|
||
|
"fieldPath": "imageUrl",
|
||
|
"columnName": "imageUrl",
|
||
|
"affinity": "TEXT",
|
||
|
"notNull": true,
|
||
|
"defaultValue": "''"
|
||
|
}
|
||
|
],
|
||
|
"primaryKey": {
|
||
|
"columnNames": [
|
||
|
"id"
|
||
|
],
|
||
|
"autoGenerate": false
|
||
|
},
|
||
|
"indices": [
|
||
|
{
|
||
|
"name": "index_topics_name",
|
||
|
"unique": true,
|
||
|
"columnNames": [
|
||
|
"name"
|
||
|
],
|
||
|
"orders": [],
|
||
|
"createSql": "CREATE UNIQUE INDEX IF NOT EXISTS `index_topics_name` ON `${TABLE_NAME}` (`name`)"
|
||
|
}
|
||
|
],
|
||
|
"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, 'f593c030a1a8b5af8e13c6ac6a0926a9')"
|
||
|
]
|
||
|
}
|
||
|
}
|