33 lines
		
	
	
	
		
			1.9 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			33 lines
		
	
	
	
		
			1.9 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import { MigrationInterface, QueryRunner } from 'typeorm'
 | |
| 
 | |
| export class AddWaitListedToReservations1690362704039
 | |
| 	implements MigrationInterface
 | |
| {
 | |
| 	name = 'AddWaitListedToReservations1690362704039'
 | |
| 
 | |
| 	public async up(queryRunner: QueryRunner): Promise<void> {
 | |
| 		await queryRunner.query(
 | |
| 			`CREATE TABLE "temporary_reservations" ("id" varchar PRIMARY KEY NOT NULL, "username" varchar(64) NOT NULL, "password" varchar(255) NOT NULL, "dateRangeStart" datetime NOT NULL, "dateRangeEnd" datetime NOT NULL, "opponentId" varchar(32) NOT NULL, "opponentName" varchar(255) NOT NULL, "waitListed" boolean NOT NULL DEFAULT (0))`,
 | |
| 		)
 | |
| 		await queryRunner.query(
 | |
| 			`INSERT INTO "temporary_reservations"("id", "username", "password", "dateRangeStart", "dateRangeEnd", "opponentId", "opponentName") SELECT "id", "username", "password", "dateRangeStart", "dateRangeEnd", "opponentId", "opponentName" FROM "reservations"`,
 | |
| 		)
 | |
| 		await queryRunner.query(`DROP TABLE "reservations"`)
 | |
| 		await queryRunner.query(
 | |
| 			`ALTER TABLE "temporary_reservations" RENAME TO "reservations"`,
 | |
| 		)
 | |
| 	}
 | |
| 
 | |
| 	public async down(queryRunner: QueryRunner): Promise<void> {
 | |
| 		await queryRunner.query(
 | |
| 			`ALTER TABLE "reservations" RENAME TO "temporary_reservations"`,
 | |
| 		)
 | |
| 		await queryRunner.query(
 | |
| 			`CREATE TABLE "reservations" ("id" varchar PRIMARY KEY NOT NULL, "username" varchar(64) NOT NULL, "password" varchar(255) NOT NULL, "dateRangeStart" datetime NOT NULL, "dateRangeEnd" datetime NOT NULL, "opponentId" varchar(32) NOT NULL, "opponentName" varchar(255) NOT NULL)`,
 | |
| 		)
 | |
| 		await queryRunner.query(
 | |
| 			`INSERT INTO "reservations"("id", "username", "password", "dateRangeStart", "dateRangeEnd", "opponentId", "opponentName") SELECT "id", "username", "password", "dateRangeStart", "dateRangeEnd", "opponentId", "opponentName" FROM "temporary_reservations"`,
 | |
| 		)
 | |
| 		await queryRunner.query(`DROP TABLE "temporary_reservations"`)
 | |
| 	}
 | |
| }
 | 
