mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-13 22:41:32 -05:00
639c0d0627
closes #1398 closes #1399 closes #1400 - added schema.js with database version '000' - refactored migration to use schema.js - if new table is added to schema.js and databaseVersion is increased, table will be added - if new table is deleted to schema.js and databaseVersion is increased, table will be deleted - alter table from issue #1400 is delayed until knex supports column modification - changed import pre checks to work again (will be refactored separately) - added basic PostgreSQL support (Attention: not supported/tested) - changed error handling in server.js
117 lines
No EOL
6.6 KiB
JavaScript
117 lines
No EOL
6.6 KiB
JavaScript
var db = {
|
|
posts: {
|
|
id: {type: 'increments', nullable: false, primary: true},
|
|
uuid: {type: 'string', maxlength: 36, nullable: false},
|
|
title: {type: 'string', maxlength: 150, nullable: false},
|
|
slug: {type: 'string', maxlength: 150, nullable: false, unique: true},
|
|
markdown: {type: 'text', maxlength: 16777215, nullable: true},
|
|
html: {type: 'text', maxlength: 16777215, nullable: true},
|
|
image: {type: 'text', maxlength: 2000, nullable: true},
|
|
featured: {type: 'bool', nullable: false, defaultTo: false},
|
|
page: {type: 'bool', nullable: false, defaultTo: false},
|
|
status: {type: 'string', maxlength: 150, nullable: false, defaultTo: 'draft'},
|
|
language: {type: 'string', maxlength: 6, nullable: false, defaultTo: 'en_US'},
|
|
meta_title: {type: 'string', maxlength: 150, nullable: true},
|
|
meta_description: {type: 'string', maxlength: 200, nullable: true},
|
|
author_id: {type: 'integer', nullable: false},
|
|
created_at: {type: 'dateTime', nullable: false},
|
|
created_by: {type: 'integer', nullable: false},
|
|
updated_at: {type: 'dateTime', nullable: true},
|
|
updated_by: {type: 'integer', nullable: true},
|
|
published_at: {type: 'dateTime', nullable: true},
|
|
published_by: {type: 'integer', nullable: true}
|
|
},
|
|
users: {
|
|
id: {type: 'increments', nullable: false, primary: true},
|
|
uuid: {type: 'string', maxlength: 36, nullable: false},
|
|
name: {type: 'string', maxlength: 150, nullable: false, unique: true},
|
|
slug: {type: 'string', maxlength: 150, nullable: false},
|
|
password: {type: 'string', maxlength: 60, nullable: false},
|
|
email: {type: 'string', maxlength: 254, nullable: false, unique: true},
|
|
image: {type: 'text', maxlength: 2000, nullable: true},
|
|
cover: {type: 'text', maxlength: 2000, nullable: true},
|
|
bio: {type: 'string', maxlength: 200, nullable: true},
|
|
website: {type: 'text', maxlength: 2000, nullable: true},
|
|
location: {type: 'text', maxlength: 65535, nullable: true},
|
|
accessibility: {type: 'text', maxlength: 65535, nullable: true},
|
|
status: {type: 'string', maxlength: 150, nullable: false, defaultTo: 'active'},
|
|
language: {type: 'string', maxlength: 6, nullable: false, defaultTo: 'en_US'},
|
|
meta_title: {type: 'string', maxlength: 150, nullable: true},
|
|
meta_description: {type: 'string', maxlength: 200, nullable: true},
|
|
last_login: {type: 'dateTime', nullable: true},
|
|
created_at: {type: 'dateTime', nullable: false},
|
|
created_by: {type: 'integer', nullable: false},
|
|
updated_at: {type: 'dateTime', nullable: true},
|
|
updated_by: {type: 'integer', nullable: true}
|
|
},
|
|
roles: {
|
|
id: {type: 'increments', nullable: false, primary: true},
|
|
uuid: {type: 'string', maxlength: 36, nullable: false},
|
|
name: {type: 'string', maxlength: 150, nullable: false},
|
|
description: {type: 'string', maxlength: 200, nullable: true},
|
|
created_at: {type: 'dateTime', nullable: false},
|
|
created_by: {type: 'integer', nullable: false},
|
|
updated_at: {type: 'dateTime', nullable: true},
|
|
updated_by: {type: 'integer', nullable: true}
|
|
},
|
|
roles_users: {
|
|
id: {type: 'increments', nullable: false, primary: true},
|
|
role_id: {type: 'integer', nullable: false},
|
|
user_id: {type: 'integer', nullable: false}
|
|
},
|
|
permissions: {
|
|
id: {type: 'increments', nullable: false, primary: true},
|
|
uuid: {type: 'string', maxlength: 36, nullable: false},
|
|
name: {type: 'string', maxlength: 150, nullable: false},
|
|
object_type: {type: 'string', maxlength: 150, nullable: false},
|
|
action_type: {type: 'string', maxlength: 150, nullable: false},
|
|
object_id: {type: 'integer', nullable: true},
|
|
created_at: {type: 'dateTime', nullable: false},
|
|
created_by: {type: 'integer', nullable: false},
|
|
updated_at: {type: 'dateTime', nullable: true},
|
|
updated_by: {type: 'integer', nullable: true}
|
|
},
|
|
permissions_users: {
|
|
id: {type: 'increments', nullable: false, primary: true},
|
|
user_id: {type: 'integer', nullable: false},
|
|
permission_id: {type: 'integer', nullable: false}
|
|
},
|
|
permissions_roles: {
|
|
id: {type: 'increments', nullable: false, primary: true},
|
|
role_id: {type: 'integer', nullable: false},
|
|
permission_id: {type: 'integer', nullable: false}
|
|
},
|
|
settings: {
|
|
id: {type: 'increments', nullable: false, primary: true},
|
|
uuid: {type: 'string', maxlength: 36, nullable: false},
|
|
key: {type: 'string', maxlength: 150, nullable: false, unique: true},
|
|
value: {type: 'text', maxlength: 65535, nullable: true},
|
|
type: {type: 'string', maxlength: 150, nullable: false, defaultTo: 'core'},
|
|
created_at: {type: 'dateTime', nullable: false},
|
|
created_by: {type: 'integer', nullable: false},
|
|
updated_at: {type: 'dateTime', nullable: true},
|
|
updated_by: {type: 'integer', nullable: true}
|
|
},
|
|
tags: {
|
|
id: {type: 'increments', nullable: false, primary: true},
|
|
uuid: {type: 'string', maxlength: 36, nullable: false},
|
|
name: {type: 'string', maxlength: 150, nullable: false},
|
|
slug: {type: 'string', maxlength: 150, nullable: false, unique: true},
|
|
description: {type: 'string', maxlength: 200, nullable: true},
|
|
parent_id: {type: 'integer', nullable: true},
|
|
meta_title: {type: 'string', maxlength: 150, nullable: true},
|
|
meta_description: {type: 'string', maxlength: 200, nullable: true},
|
|
created_at: {type: 'dateTime', nullable: false},
|
|
created_by: {type: 'integer', nullable: false},
|
|
updated_at: {type: 'dateTime', nullable: true},
|
|
updated_by: {type: 'integer', nullable: true}
|
|
},
|
|
posts_tags: {
|
|
id: {type: 'increments', nullable: false, primary: true},
|
|
post_id: {type: 'integer', nullable: false, unsigned: true, references: 'id', inTable: 'posts'},
|
|
tag_id: {type: 'integer', nullable: false, unsigned: true, references: 'id', inTable: 'tags'}
|
|
}
|
|
};
|
|
|
|
|
|
module.exports = db; |