From 33e19d38c55aac9a46f6b140b49fd96cf26386c7 Mon Sep 17 00:00:00 2001 From: Collin Duncan <3679940+cgduncan7@users.noreply.github.com> Date: Fri, 28 Jul 2023 19:49:06 +0200 Subject: [PATCH] Adding waitListed property to reservations --- ...90362704039-AddWaitListedToReservations.ts | 33 +++++++++++++++++++ src/reservations/entity.ts | 3 ++ 2 files changed, 36 insertions(+) create mode 100644 database/migrations/1690362704039-AddWaitListedToReservations.ts diff --git a/database/migrations/1690362704039-AddWaitListedToReservations.ts b/database/migrations/1690362704039-AddWaitListedToReservations.ts new file mode 100644 index 0000000..a0ade3a --- /dev/null +++ b/database/migrations/1690362704039-AddWaitListedToReservations.ts @@ -0,0 +1,33 @@ +import { MigrationInterface, QueryRunner } from 'typeorm' + +export class AddWaitListedToReservations1690362704039 + implements MigrationInterface +{ + name = 'AddWaitListedToReservations1690362704039' + + public async up(queryRunner: QueryRunner): Promise { + 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 { + 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"`) + } +} diff --git a/src/reservations/entity.ts b/src/reservations/entity.ts index ad0c9b7..cfc2d1f 100644 --- a/src/reservations/entity.ts +++ b/src/reservations/entity.ts @@ -65,6 +65,9 @@ export class Reservation { @Column('varchar', { length: 255, nullable: false }) opponentName: string + @Column('boolean', { default: false }) + waitListed: boolean + constructor(partial: Partial) { Object.assign(this, partial) }