2017-07-05 13:26:25 +02:00
|
|
|
import * as Sequelize from 'sequelize'
|
|
|
|
import * as Promise from 'bluebird'
|
2018-07-25 22:01:25 +02:00
|
|
|
import { Migration } from '../../models/migrations'
|
2017-07-05 13:26:25 +02:00
|
|
|
|
|
|
|
function up (utils: {
|
|
|
|
transaction: Sequelize.Transaction,
|
|
|
|
queryInterface: Sequelize.QueryInterface,
|
|
|
|
sequelize: Sequelize.Sequelize
|
|
|
|
}): Promise<void> {
|
2017-02-18 11:56:28 +01:00
|
|
|
const q = utils.queryInterface
|
|
|
|
|
|
|
|
const data = {
|
|
|
|
type: Sequelize.STRING(400),
|
|
|
|
allowNull: false,
|
|
|
|
defaultValue: ''
|
2018-07-25 22:01:25 +02:00
|
|
|
} as Migration.String
|
2017-07-05 13:26:25 +02:00
|
|
|
return q.addColumn('Users', 'email', data)
|
|
|
|
.then(() => {
|
2017-02-18 11:56:28 +01:00
|
|
|
const query = 'UPDATE "Users" SET "email" = CONCAT("username", \'@example.com\')'
|
2017-07-05 13:26:25 +02:00
|
|
|
return utils.sequelize.query(query, { transaction: utils.transaction })
|
|
|
|
})
|
|
|
|
.then(() => {
|
2017-02-18 11:56:28 +01:00
|
|
|
data.defaultValue = null
|
|
|
|
|
2017-07-05 13:26:25 +02:00
|
|
|
return q.changeColumn('Users', 'email', data)
|
|
|
|
})
|
2017-02-18 11:56:28 +01:00
|
|
|
}
|
|
|
|
|
2017-07-11 16:01:56 +02:00
|
|
|
function down (options) {
|
2017-02-18 11:56:28 +01:00
|
|
|
throw new Error('Not implemented.')
|
|
|
|
}
|
2017-05-15 22:22:03 +02:00
|
|
|
|
|
|
|
export {
|
|
|
|
up,
|
|
|
|
down
|
|
|
|
}
|