]>
Commit | Line | Data |
---|---|---|
1 | import * as Sequelize from 'sequelize' | |
2 | import * as Promise from 'bluebird' | |
3 | ||
4 | function up (utils: { | |
5 | transaction: Sequelize.Transaction, | |
6 | queryInterface: Sequelize.QueryInterface, | |
7 | sequelize: Sequelize.Sequelize, | |
8 | db: any | |
9 | }): Promise<void> { | |
10 | const q = utils.queryInterface | |
11 | ||
12 | const query = 'INSERT INTO "VideoFiles" ("videoId", "resolution", "size", "extname", "infoHash", "createdAt", "updatedAt") ' + | |
13 | 'SELECT "id" AS "videoId", 0 AS "resolution", 0 AS "size", ' + | |
14 | '"extname"::"text"::"enum_VideoFiles_extname" as "extname", "infoHash", "createdAt", "updatedAt" ' + | |
15 | 'FROM "Videos"' | |
16 | ||
17 | return utils.db.VideoFile.sync() | |
18 | .then(() => utils.sequelize.query(query)) | |
19 | .then(() => { | |
20 | return q.removeColumn('Videos', 'extname') | |
21 | }) | |
22 | .then(() => { | |
23 | return q.removeColumn('Videos', 'infoHash') | |
24 | }) | |
25 | } | |
26 | ||
27 | function down (options) { | |
28 | throw new Error('Not implemented.') | |
29 | } | |
30 | ||
31 | export { | |
32 | up, | |
33 | down | |
34 | } |