1655124805662-init_database.ts 1.5 KB

12345678910111213141516171819202122232425
  1. import { MigrationInterface, QueryRunner } from 'typeorm'
  2. export class initDatabase1655124805662 implements MigrationInterface {
  3. name = 'initDatabase1655124805662'
  4. public async up(queryRunner: QueryRunner): Promise<void> {
  5. await queryRunner.query(
  6. 'CREATE TABLE `predicates` (`uuid` varchar(36) NOT NULL, `name` varchar(255) NOT NULL, `authority` varchar(255) NOT NULL, `status` varchar(32) NOT NULL, `job_uuid` varchar(36) NULL, PRIMARY KEY (`uuid`)) ENGINE=InnoDB',
  7. )
  8. await queryRunner.query(
  9. 'CREATE TABLE `jobs` (`uuid` varchar(36) NOT NULL, `user_identifier` varchar(255) NOT NULL, `user_identifier_type` varchar(32) NOT NULL, `status` varchar(32) NOT NULL, `created_at` bigint NOT NULL, `scheduled_at` bigint NOT NULL, INDEX `index_jobs_on_user_identifier` (`user_identifier`), INDEX `index_on_scheduled_status` (`status`, `scheduled_at`), PRIMARY KEY (`uuid`)) ENGINE=InnoDB',
  10. )
  11. await queryRunner.query(
  12. 'ALTER TABLE `predicates` ADD CONSTRAINT `FK_0b28dbc0986c27765681a7b5faf` FOREIGN KEY (`job_uuid`) REFERENCES `jobs`(`uuid`) ON DELETE CASCADE ON UPDATE NO ACTION',
  13. )
  14. }
  15. public async down(queryRunner: QueryRunner): Promise<void> {
  16. await queryRunner.query('ALTER TABLE `predicates` DROP FOREIGN KEY `FK_0b28dbc0986c27765681a7b5faf`')
  17. await queryRunner.query('DROP INDEX `index_on_scheduled_status` ON `jobs`')
  18. await queryRunner.query('DROP INDEX `index_jobs_on_user_identifier` ON `jobs`')
  19. await queryRunner.query('DROP TABLE `jobs`')
  20. await queryRunner.query('DROP TABLE `predicates`')
  21. }
  22. }