buid: alter database structure and migrations - add filters
This commit is contained in:
parent
60cb0083f5
commit
16134e1719
@ -1,5 +0,0 @@
|
|||||||
-- CreateTable
|
|
||||||
CREATE TABLE "TestModel" (
|
|
||||||
"id" INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
|
|
||||||
"name" TEXT
|
|
||||||
);
|
|
@ -1,10 +0,0 @@
|
|||||||
/*
|
|
||||||
Warnings:
|
|
||||||
|
|
||||||
- You are about to drop the `TestModel` table. If the table is not empty, all the data it contains will be lost.
|
|
||||||
|
|
||||||
*/
|
|
||||||
-- DropTable
|
|
||||||
PRAGMA foreign_keys=off;
|
|
||||||
DROP TABLE "TestModel";
|
|
||||||
PRAGMA foreign_keys=on;
|
|
@ -1,18 +0,0 @@
|
|||||||
-- CreateTable
|
|
||||||
CREATE TABLE "Feed" (
|
|
||||||
"id" INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
|
|
||||||
"name" TEXT NOT NULL,
|
|
||||||
"url" TEXT NOT NULL,
|
|
||||||
"guild_id" TEXT NOT NULL,
|
|
||||||
"active" BOOLEAN NOT NULL,
|
|
||||||
"created_at" DATETIME NOT NULL,
|
|
||||||
"updated_at" DATETIME NOT NULL
|
|
||||||
);
|
|
||||||
|
|
||||||
-- CreateTable
|
|
||||||
CREATE TABLE "Channel" (
|
|
||||||
"id" INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
|
|
||||||
"channel_id" TEXT NOT NULL,
|
|
||||||
"feedId" INTEGER NOT NULL,
|
|
||||||
CONSTRAINT "Channel_feedId_fkey" FOREIGN KEY ("feedId") REFERENCES "Feed" ("id") ON DELETE RESTRICT ON UPDATE CASCADE
|
|
||||||
);
|
|
@ -1,17 +0,0 @@
|
|||||||
-- RedefineTables
|
|
||||||
PRAGMA defer_foreign_keys=ON;
|
|
||||||
PRAGMA foreign_keys=OFF;
|
|
||||||
CREATE TABLE "new_Feed" (
|
|
||||||
"id" INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
|
|
||||||
"name" TEXT NOT NULL,
|
|
||||||
"url" TEXT NOT NULL,
|
|
||||||
"guild_id" TEXT NOT NULL,
|
|
||||||
"active" BOOLEAN NOT NULL,
|
|
||||||
"created_at" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
|
||||||
"updated_at" DATETIME NOT NULL
|
|
||||||
);
|
|
||||||
INSERT INTO "new_Feed" ("active", "created_at", "guild_id", "id", "name", "updated_at", "url") SELECT "active", "created_at", "guild_id", "id", "name", "updated_at", "url" FROM "Feed";
|
|
||||||
DROP TABLE "Feed";
|
|
||||||
ALTER TABLE "new_Feed" RENAME TO "Feed";
|
|
||||||
PRAGMA foreign_keys=ON;
|
|
||||||
PRAGMA defer_foreign_keys=OFF;
|
|
45
prisma/migrations/20250428225814_init/migration.sql
Normal file
45
prisma/migrations/20250428225814_init/migration.sql
Normal file
@ -0,0 +1,45 @@
|
|||||||
|
-- CreateTable
|
||||||
|
CREATE TABLE "Feed" (
|
||||||
|
"id" INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
|
||||||
|
"name" TEXT NOT NULL,
|
||||||
|
"url" TEXT NOT NULL,
|
||||||
|
"guild_id" TEXT NOT NULL,
|
||||||
|
"active" BOOLEAN NOT NULL,
|
||||||
|
"created_at" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||||||
|
"updated_at" DATETIME NOT NULL
|
||||||
|
);
|
||||||
|
|
||||||
|
-- CreateTable
|
||||||
|
CREATE TABLE "Channel" (
|
||||||
|
"id" INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
|
||||||
|
"channel_id" TEXT NOT NULL,
|
||||||
|
"feedId" INTEGER NOT NULL,
|
||||||
|
CONSTRAINT "Channel_feedId_fkey" FOREIGN KEY ("feedId") REFERENCES "Feed" ("id") ON DELETE RESTRICT ON UPDATE CASCADE
|
||||||
|
);
|
||||||
|
|
||||||
|
-- CreateTable
|
||||||
|
CREATE TABLE "Filter" (
|
||||||
|
"id" INTEGER NOT NULL PRIMARY KEY AUTOINCREMENT,
|
||||||
|
"guild_id" TEXT NOT NULL,
|
||||||
|
"name" TEXT NOT NULL,
|
||||||
|
"value" TEXT NOT NULL,
|
||||||
|
"matching_algorithm" TEXT NOT NULL,
|
||||||
|
"is_insensitive" BOOLEAN NOT NULL,
|
||||||
|
"is_whitelist" BOOLEAN NOT NULL,
|
||||||
|
"created_at" DATETIME NOT NULL DEFAULT CURRENT_TIMESTAMP,
|
||||||
|
"updated_at" DATETIME NOT NULL
|
||||||
|
);
|
||||||
|
|
||||||
|
-- CreateTable
|
||||||
|
CREATE TABLE "_FeedToFilter" (
|
||||||
|
"A" INTEGER NOT NULL,
|
||||||
|
"B" INTEGER NOT NULL,
|
||||||
|
CONSTRAINT "_FeedToFilter_A_fkey" FOREIGN KEY ("A") REFERENCES "Feed" ("id") ON DELETE CASCADE ON UPDATE CASCADE,
|
||||||
|
CONSTRAINT "_FeedToFilter_B_fkey" FOREIGN KEY ("B") REFERENCES "Filter" ("id") ON DELETE CASCADE ON UPDATE CASCADE
|
||||||
|
);
|
||||||
|
|
||||||
|
-- CreateIndex
|
||||||
|
CREATE UNIQUE INDEX "_FeedToFilter_AB_unique" ON "_FeedToFilter"("A", "B");
|
||||||
|
|
||||||
|
-- CreateIndex
|
||||||
|
CREATE INDEX "_FeedToFilter_B_index" ON "_FeedToFilter"("B");
|
@ -17,9 +17,10 @@ model Feed {
|
|||||||
url String
|
url String
|
||||||
guild_id String
|
guild_id String
|
||||||
active Boolean
|
active Boolean
|
||||||
created_at DateTime @default(now())
|
created_at DateTime @default(now())
|
||||||
updated_at DateTime @updatedAt
|
updated_at DateTime @updatedAt
|
||||||
channels Channel[]
|
channels Channel[]
|
||||||
|
filters Filter[]
|
||||||
}
|
}
|
||||||
|
|
||||||
model Channel {
|
model Channel {
|
||||||
@ -28,3 +29,24 @@ model Channel {
|
|||||||
Feed Feed @relation(fields: [feedId], references: [id])
|
Feed Feed @relation(fields: [feedId], references: [id])
|
||||||
feedId Int
|
feedId Int
|
||||||
}
|
}
|
||||||
|
|
||||||
|
model Filter {
|
||||||
|
id Int @id @default(autoincrement())
|
||||||
|
guild_id String
|
||||||
|
name String
|
||||||
|
value String
|
||||||
|
matching_algorithm MatchingAlgorithms
|
||||||
|
is_insensitive Boolean
|
||||||
|
is_whitelist Boolean
|
||||||
|
created_at DateTime @default(now())
|
||||||
|
updated_at DateTime @updatedAt
|
||||||
|
feeds Feed[]
|
||||||
|
}
|
||||||
|
|
||||||
|
enum MatchingAlgorithms {
|
||||||
|
ANY
|
||||||
|
ALL
|
||||||
|
EXACT
|
||||||
|
REGEX
|
||||||
|
FUZZY
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user