-- 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");