server/migrations/20190211042644-create-calendar-event.js
module.exports = {
up: async (queryInterface, Sequelize) => {
await queryInterface.createTable('t_calendar_event', {
id: {
allowNull: false,
primaryKey: true,
type: Sequelize.UUID,
},
calendar_id: {
allowNull: false,
type: Sequelize.UUID,
references: {
model: 't_calendar',
key: 'id',
},
onUpdate: 'CASCADE',
onDelete: 'CASCADE',
},
name: {
allowNull: false,
type: Sequelize.STRING,
},
selector: {
allowNull: false,
unique: true,
type: Sequelize.STRING,
},
external_id: {
unique: true,
type: Sequelize.STRING,
},
location: {
type: Sequelize.STRING,
},
start: {
allowNull: false,
type: Sequelize.DATE,
},
end: {
type: Sequelize.DATE,
},
full_day: {
allowNull: false,
type: Sequelize.BOOLEAN,
defaultValue: false,
},
created_at: {
allowNull: false,
type: Sequelize.DATE,
},
updated_at: {
allowNull: false,
type: Sequelize.DATE,
},
});
await queryInterface.addIndex('t_calendar_event', ['calendar_id']);
await queryInterface.addIndex('t_calendar_event', ['start']);
await queryInterface.addIndex('t_calendar_event', ['end']);
},
down: async (queryInterface, Sequelize) => queryInterface.dropTable('t_calendar_event'),
};