summaryrefslogtreecommitdiff
path: root/packages/backend/migration
diff options
context:
space:
mode:
authorHazelnoot <acomputerdog@gmail.com>2025-05-24 19:10:41 -0400
committerHazelnoot <acomputerdog@gmail.com>2025-05-28 21:31:40 -0400
commit59099a2b2a1d570334df3a0770450c8b4b1522c6 (patch)
tree8c5f31f77e95078badca06d4597ee5e7be63e522 /packages/backend/migration
parentpopulate block fields when registering a new instance (diff)
downloadsharkey-59099a2b2a1d570334df3a0770450c8b4b1522c6.tar.gz
sharkey-59099a2b2a1d570334df3a0770450c8b4b1522c6.tar.bz2
sharkey-59099a2b2a1d570334df3a0770450c8b4b1522c6.zip
add foreign keys to note/user where instance is referenced
Diffstat (limited to 'packages/backend/migration')
-rw-r--r--packages/backend/migration/1748128176881-add_instance_foreign_keys.js30
1 files changed, 30 insertions, 0 deletions
diff --git a/packages/backend/migration/1748128176881-add_instance_foreign_keys.js b/packages/backend/migration/1748128176881-add_instance_foreign_keys.js
new file mode 100644
index 0000000000..da2de14f18
--- /dev/null
+++ b/packages/backend/migration/1748128176881-add_instance_foreign_keys.js
@@ -0,0 +1,30 @@
+/*
+ * SPDX-FileCopyrightText: hazelnoot and other Sharkey contributors
+ * SPDX-License-Identifier: AGPL-3.0-only
+ */
+
+/**
+ * @typedef {import('typeorm').MigrationInterface} MigrationInterface
+ */
+
+/**
+ * @class
+ * @implements {MigrationInterface}
+ */
+export class AddInstanceForeignKeys1748128176881 {
+ name = 'AddInstanceForeignKeys1748128176881'
+
+ async up(queryRunner) {
+ await queryRunner.query(`ALTER TABLE "user" ADD CONSTRAINT "FK_user_host" FOREIGN KEY ("host") REFERENCES "instance"("host") ON DELETE CASCADE ON UPDATE NO ACTION`);
+ await queryRunner.query(`ALTER TABLE "note" ADD CONSTRAINT "FK_note_userHost" FOREIGN KEY ("userHost") REFERENCES "instance"("host") ON DELETE CASCADE ON UPDATE NO ACTION`);
+ await queryRunner.query(`ALTER TABLE "note" ADD CONSTRAINT "FK_note_replyUserHost" FOREIGN KEY ("replyUserHost") REFERENCES "instance"("host") ON DELETE CASCADE ON UPDATE NO ACTION`);
+ await queryRunner.query(`ALTER TABLE "note" ADD CONSTRAINT "FK_note_renoteUserHost" FOREIGN KEY ("renoteUserHost") REFERENCES "instance"("host") ON DELETE CASCADE ON UPDATE NO ACTION`);
+ }
+
+ async down(queryRunner) {
+ await queryRunner.query(`ALTER TABLE "note" DROP CONSTRAINT "FK_note_renoteUserHost"`);
+ await queryRunner.query(`ALTER TABLE "note" DROP CONSTRAINT "FK_note_replyUserHost"`);
+ await queryRunner.query(`ALTER TABLE "note" DROP CONSTRAINT "FK_note_userHost"`);
+ await queryRunner.query(`ALTER TABLE "user" DROP CONSTRAINT "FK_user_host"`);
+ }
+}