import {
  MigrationInterface,
  QueryRunner,
  Table,
  TableColumn,
  TableForeignKey,
} from 'typeorm';

export class CreateUsersTable1712750869147 implements MigrationInterface {
  public async up(queryRunner: QueryRunner): Promise<void> {
    await queryRunner.createTable(
      new Table({
        name: 'users',
        columns: [
          {
            name: 'id',
            type: 'uuid',
            isPrimary: true,
            default: 'uuid_generate_v4()',
            isNullable: false,
            isGenerated: true,
          },
          {
            name: 'first_name',
            type: 'varchar',
          },
          {
            name: 'last_name',
            type: 'varchar',
          },
          {
            name: 'password',
            type: 'varchar',
          },
          {
            name: 'email',
            type: 'varchar',
            isUnique: true,
          },
          {
            name: 'contact_no',
            type: 'numeric',
            isUnique: true,
          },
          {
            name: 'profile_picture',
            type: 'varchar',
            isNullable: true,
          },
          {
            name: 'course_id',
            type: 'uuid',
            isNullable: true,
          },
          {
            name: 'job_id',
            type: 'uuid',
            isNullable: true,
          },
          {
            name: 'city_id',
            type: 'uuid',
            isNullable: true,
          },
          {
            name: 'batch',
            type: 'integer[]',
            isNullable: true,
          },
          {
            name: 'access_token',
            type: 'varchar',
            isNullable: true,
          },
          {
            name: 'access_token_expiry',
            type: 'varchar',
            isNullable: true,
          },
          {
            name: 'refresh_token',
            type: 'varchar',
            isNullable: true,
          },
          {
            name: 'refresh_token_expiry',
            type: 'varchar',
            isNullable: true,
          },
          {
            name: 'status',
            type: 'smallint',
            default: 0,
            isNullable: false,
          },
          {
            name: 'is_admin',
            type: 'smallint',
            default: 0,
            isNullable: false,
          },
          {
            name: 'date_of_birth',
            type: 'date',
            isNullable: true,
          },
          {
            name: 'designation',
            type: 'varchar',
            isNullable: true,
          },
          {
            name: 'company_name',
            type: 'varchar',
            isNullable: true,
          },
          {
            name: 'company_address',
            type: 'varchar',
            isNullable: true,
          },
          {
            name: 'password_reset_token',
            type: 'varchar',
            isNullable: true,
          },
          {
            name: 'password_reset_token_expiry',
            type: 'varchar',
            isNullable: true,
          },
          {
            name: 'updated_at',
            type: 'timestamp',
            default: 'CURRENT_TIMESTAMP',
          },
          {
            name: 'created_at',
            type: 'timestamp',
            default: 'CURRENT_TIMESTAMP',
          },
          {
            name: 'deleted_at',
            type: 'timestamp',
            isNullable: true,
          },
        ],
      }),
    );

    await queryRunner.createForeignKey(
      'users',
      new TableForeignKey({
        columnNames: ['course_id'],
        referencedColumnNames: ['id'],
        referencedTableName: 'courses',
        onDelete: 'CASCADE',
      }),
    );
    await queryRunner.createForeignKey(
      'users',
      new TableForeignKey({
        columnNames: ['job_id'],
        referencedColumnNames: ['id'],
        referencedTableName: 'job_types',
        onDelete: 'CASCADE',
      }),
    );
    await queryRunner.createForeignKey(
      'users',
      new TableForeignKey({
        columnNames: ['city_id'],
        referencedColumnNames: ['id'],
        referencedTableName: 'cities',
        onDelete: 'CASCADE',
      }),
    );

    await queryRunner.query(`INSERT INTO users (
      first_name,
      last_name,
      password,
      email,
      contact_no,
      status,
      is_admin,
      updated_at,
      created_at
  ) VALUES (
      'admin',
      'user',
      '$2a$10$JALy5j01oGciWvRDAJIdWu8S0xIRUZsYGiaQl0BNFTDohpv0MNhn6',
      'admin@admin.com',
      '1234567890',
      1,
      1,
      CURRENT_TIMESTAMP,
      CURRENT_TIMESTAMP
  );
`);
  }

  public async down(queryRunner: QueryRunner): Promise<void> {
    await queryRunner.dropForeignKey('users', 'city_id');
    await queryRunner.dropForeignKey('users', 'job_id');
    await queryRunner.dropForeignKey('users', 'course_id');
    await queryRunner.dropTable('users');
  }
}
