summaryrefslogtreecommitdiff
path: root/migration/1597459042300-channel-unread.ts
blob: a0f862114de40a2b87be7b110337c8ed4332f4dd (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
import {MigrationInterface, QueryRunner} from "typeorm";

export class channelUnread1597459042300 implements MigrationInterface {
    name = 'channelUnread1597459042300'

    public async up(queryRunner: QueryRunner): Promise<void> {
				await queryRunner.query(`TRUNCATE TABLE "note_unread"`, undefined);
        await queryRunner.query(`ALTER TABLE "channel_following" DROP COLUMN "readCursor"`);
        await queryRunner.query(`ALTER TABLE "note_unread" ADD "isMentioned" boolean NOT NULL`);
        await queryRunner.query(`ALTER TABLE "note_unread" ADD "noteChannelId" character varying(32)`);
        await queryRunner.query(`CREATE INDEX "IDX_25b1dd384bec391b07b74b861c" ON "note_unread" ("isMentioned") `);
        await queryRunner.query(`CREATE INDEX "IDX_89a29c9237b8c3b6b3cbb4cb30" ON "note_unread" ("isSpecified") `);
        await queryRunner.query(`CREATE INDEX "IDX_29e8c1d579af54d4232939f994" ON "note_unread" ("noteUserId") `);
        await queryRunner.query(`CREATE INDEX "IDX_6a57f051d82c6d4036c141e107" ON "note_unread" ("noteChannelId") `);
    }

    public async down(queryRunner: QueryRunner): Promise<void> {
        await queryRunner.query(`DROP INDEX "IDX_6a57f051d82c6d4036c141e107"`);
        await queryRunner.query(`DROP INDEX "IDX_29e8c1d579af54d4232939f994"`);
        await queryRunner.query(`DROP INDEX "IDX_89a29c9237b8c3b6b3cbb4cb30"`);
        await queryRunner.query(`DROP INDEX "IDX_25b1dd384bec391b07b74b861c"`);
        await queryRunner.query(`ALTER TABLE "note_unread" DROP COLUMN "noteChannelId"`);
        await queryRunner.query(`ALTER TABLE "note_unread" DROP COLUMN "isMentioned"`);
        await queryRunner.query(`ALTER TABLE "channel_following" ADD "readCursor" TIMESTAMP WITH TIME ZONE NOT NULL`);
    }

}