import { MigrationInterface, QueryRunner, Table, TableForeignKey } from 'typeorm'; export class CreateQueryUsers1747763331564 implements MigrationInterface { public async up(queryRunner: QueryRunner): Promise { await queryRunner.createTable( new Table({ name: 'query_users', columns: [ { name: 'id', type: 'uuid', isGenerated: true, default: 'gen_random_uuid()', isPrimary: true, }, { name: 'query_permissions_id', type: 'uuid', isNullable: false, }, { name: 'user_id', type: 'uuid', isNullable: true, }, { name: 'permission_groups_id', type: 'uuid', isNullable: true, }, { name: 'created_at', type: 'timestamp', isNullable: false, default: 'now()', }, ], }), true ); await queryRunner.createForeignKey( 'query_users', new TableForeignKey({ columnNames: ['query_permissions_id'], referencedColumnNames: ['id'], referencedTableName: 'query_permissions', onDelete: 'CASCADE', }) ); await queryRunner.createForeignKey( 'query_users', new TableForeignKey({ columnNames: ['user_id'], referencedColumnNames: ['id'], referencedTableName: 'users', onDelete: 'CASCADE', }) ); await queryRunner.createForeignKey( 'query_users', new TableForeignKey({ columnNames: ['permission_groups_id'], referencedColumnNames: ['id'], referencedTableName: 'permission_groups', onDelete: 'CASCADE', }) ); } public async down(queryRunner: QueryRunner): Promise { await queryRunner.dropTable('query_users'); } }