-- CreateTable CREATE TABLE "user" ( "id" TEXT NOT NULL, "name" TEXT NOT NULL, "email" TEXT NOT NULL, "email_verified" BOOLEAN NOT NULL DEFAULT false, "image" TEXT, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updated_at" TIMESTAMP(3) NOT NULL, "role" TEXT, "banned" BOOLEAN DEFAULT false, "ban_reason" TEXT, "ban_expires" TIMESTAMP(3), "must_change_password" BOOLEAN DEFAULT false, CONSTRAINT "user_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "session" ( "id" TEXT NOT NULL, "expires_at" TIMESTAMP(3) NOT NULL, "token" TEXT NOT NULL, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updated_at" TIMESTAMP(3) NOT NULL, "ip_address" TEXT, "user_agent" TEXT, "user_id" TEXT NOT NULL, CONSTRAINT "session_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "account" ( "id" TEXT NOT NULL, "account_id" TEXT NOT NULL, "provider_id" TEXT NOT NULL, "user_id" TEXT NOT NULL, "access_token" TEXT, "refresh_token" TEXT, "id_token" TEXT, "access_token_expires_at" TIMESTAMP(3), "refresh_token_expires_at" TIMESTAMP(3), "scope" TEXT, "password" TEXT, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updated_at" TIMESTAMP(3) NOT NULL, CONSTRAINT "account_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "verification" ( "id" TEXT NOT NULL, "identifier" TEXT NOT NULL, "value" TEXT NOT NULL, "expires_at" TIMESTAMP(3) NOT NULL, "created_at" TIMESTAMP(3) DEFAULT CURRENT_TIMESTAMP, "updated_at" TIMESTAMP(3), CONSTRAINT "verification_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "organizations" ( "id" TEXT NOT NULL, "name" TEXT NOT NULL, "slug" TEXT NOT NULL, "plan" TEXT NOT NULL DEFAULT 'pilot', "logo_url" TEXT, "primary_color" TEXT NOT NULL DEFAULT '#E63946', "secondary_color" TEXT, "contact_email" TEXT, "avv_accepted" BOOLEAN NOT NULL DEFAULT false, "avv_accepted_at" TIMESTAMP(3), "landing_page_title" TEXT, "landing_page_text" TEXT, "landing_page_section_title" TEXT, "landing_page_button_text" TEXT, "landing_page_hero_image" TEXT, "landing_page_hero_overlay_opacity" INTEGER DEFAULT 50, "landing_page_features" JSONB, "landing_page_footer" JSONB, "app_store_url" TEXT, "play_store_url" TEXT, "ai_enabled" BOOLEAN NOT NULL DEFAULT false, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "organizations_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "members" ( "id" TEXT NOT NULL, "org_id" TEXT NOT NULL, "user_id" TEXT, "name" TEXT NOT NULL, "betrieb" TEXT NOT NULL, "sparte" TEXT NOT NULL, "ort" TEXT NOT NULL, "telefon" TEXT, "email" TEXT NOT NULL, "status" TEXT NOT NULL DEFAULT 'aktiv', "ist_ausbildungsbetrieb" BOOLEAN NOT NULL DEFAULT false, "seit" INTEGER, "avatar_url" TEXT, "push_token" TEXT, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updated_at" TIMESTAMP(3) NOT NULL, CONSTRAINT "members_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "user_roles" ( "id" TEXT NOT NULL, "org_id" TEXT NOT NULL, "user_id" TEXT NOT NULL, "role" TEXT NOT NULL, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "user_roles_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "news" ( "id" TEXT NOT NULL, "org_id" TEXT NOT NULL, "author_id" TEXT, "title" TEXT NOT NULL, "body" TEXT NOT NULL, "kategorie" TEXT NOT NULL, "published_at" TIMESTAMP(3), "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "news_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "news_reads" ( "id" TEXT NOT NULL, "news_id" TEXT NOT NULL, "user_id" TEXT NOT NULL, "read_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "news_reads_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "news_attachments" ( "id" TEXT NOT NULL, "news_id" TEXT NOT NULL, "name" TEXT NOT NULL, "storage_path" TEXT NOT NULL, "mime_type" TEXT, "size_bytes" INTEGER, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "news_attachments_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "stellen" ( "id" TEXT NOT NULL, "org_id" TEXT NOT NULL, "member_id" TEXT NOT NULL, "sparte" TEXT NOT NULL, "stellen_anz" INTEGER NOT NULL DEFAULT 1, "verguetung" TEXT, "lehrjahr" TEXT, "beschreibung" TEXT, "kontakt_email" TEXT NOT NULL, "kontakt_name" TEXT, "aktiv" BOOLEAN NOT NULL DEFAULT true, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updated_at" TIMESTAMP(3) NOT NULL, CONSTRAINT "stellen_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "termine" ( "id" TEXT NOT NULL, "org_id" TEXT NOT NULL, "titel" TEXT NOT NULL, "datum" TIMESTAMP(3) NOT NULL, "uhrzeit" TEXT, "ende_datum" TIMESTAMP(3), "ende_uhrzeit" TEXT, "ort" TEXT, "adresse" TEXT, "typ" TEXT NOT NULL, "beschreibung" TEXT, "max_teilnehmer" INTEGER, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "termine_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "termin_anmeldungen" ( "id" TEXT NOT NULL, "termin_id" TEXT NOT NULL, "member_id" TEXT NOT NULL, "angemeldet_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "termin_anmeldungen_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "conversations" ( "id" TEXT NOT NULL, "org_id" TEXT NOT NULL, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, "updated_at" TIMESTAMP(3) NOT NULL, CONSTRAINT "conversations_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "conversation_members" ( "id" TEXT NOT NULL, "conversation_id" TEXT NOT NULL, "member_id" TEXT NOT NULL, "last_read_at" TIMESTAMP(3), CONSTRAINT "conversation_members_pkey" PRIMARY KEY ("id") ); -- CreateTable CREATE TABLE "messages" ( "id" TEXT NOT NULL, "conversation_id" TEXT NOT NULL, "sender_id" TEXT NOT NULL, "body" TEXT NOT NULL, "created_at" TIMESTAMP(3) NOT NULL DEFAULT CURRENT_TIMESTAMP, CONSTRAINT "messages_pkey" PRIMARY KEY ("id") ); -- CreateIndex CREATE UNIQUE INDEX "user_email_key" ON "user"("email"); -- CreateIndex CREATE UNIQUE INDEX "session_token_key" ON "session"("token"); -- CreateIndex CREATE UNIQUE INDEX "organizations_slug_key" ON "organizations"("slug"); -- CreateIndex CREATE UNIQUE INDEX "members_user_id_key" ON "members"("user_id"); -- CreateIndex CREATE INDEX "members_org_id_idx" ON "members"("org_id"); -- CreateIndex CREATE INDEX "members_status_idx" ON "members"("status"); -- CreateIndex CREATE UNIQUE INDEX "user_roles_org_id_user_id_key" ON "user_roles"("org_id", "user_id"); -- CreateIndex CREATE INDEX "news_org_id_idx" ON "news"("org_id"); -- CreateIndex CREATE INDEX "news_published_at_idx" ON "news"("published_at"); -- CreateIndex CREATE UNIQUE INDEX "news_reads_news_id_user_id_key" ON "news_reads"("news_id", "user_id"); -- CreateIndex CREATE INDEX "stellen_org_id_idx" ON "stellen"("org_id"); -- CreateIndex CREATE INDEX "stellen_aktiv_idx" ON "stellen"("aktiv"); -- CreateIndex CREATE INDEX "termine_org_id_idx" ON "termine"("org_id"); -- CreateIndex CREATE INDEX "termine_datum_idx" ON "termine"("datum"); -- CreateIndex CREATE UNIQUE INDEX "termin_anmeldungen_termin_id_member_id_key" ON "termin_anmeldungen"("termin_id", "member_id"); -- CreateIndex CREATE INDEX "conversations_org_id_idx" ON "conversations"("org_id"); -- CreateIndex CREATE UNIQUE INDEX "conversation_members_conversation_id_member_id_key" ON "conversation_members"("conversation_id", "member_id"); -- CreateIndex CREATE INDEX "messages_conversation_id_idx" ON "messages"("conversation_id"); -- AddForeignKey ALTER TABLE "session" ADD CONSTRAINT "session_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "account" ADD CONSTRAINT "account_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "members" ADD CONSTRAINT "members_org_id_fkey" FOREIGN KEY ("org_id") REFERENCES "organizations"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "members" ADD CONSTRAINT "members_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "user"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "user_roles" ADD CONSTRAINT "user_roles_org_id_fkey" FOREIGN KEY ("org_id") REFERENCES "organizations"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "user_roles" ADD CONSTRAINT "user_roles_user_id_fkey" FOREIGN KEY ("user_id") REFERENCES "user"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "news" ADD CONSTRAINT "news_org_id_fkey" FOREIGN KEY ("org_id") REFERENCES "organizations"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "news" ADD CONSTRAINT "news_author_id_fkey" FOREIGN KEY ("author_id") REFERENCES "members"("id") ON DELETE SET NULL ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "news_reads" ADD CONSTRAINT "news_reads_news_id_fkey" FOREIGN KEY ("news_id") REFERENCES "news"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "news_attachments" ADD CONSTRAINT "news_attachments_news_id_fkey" FOREIGN KEY ("news_id") REFERENCES "news"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "stellen" ADD CONSTRAINT "stellen_org_id_fkey" FOREIGN KEY ("org_id") REFERENCES "organizations"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "stellen" ADD CONSTRAINT "stellen_member_id_fkey" FOREIGN KEY ("member_id") REFERENCES "members"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "termine" ADD CONSTRAINT "termine_org_id_fkey" FOREIGN KEY ("org_id") REFERENCES "organizations"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "termin_anmeldungen" ADD CONSTRAINT "termin_anmeldungen_termin_id_fkey" FOREIGN KEY ("termin_id") REFERENCES "termine"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "termin_anmeldungen" ADD CONSTRAINT "termin_anmeldungen_member_id_fkey" FOREIGN KEY ("member_id") REFERENCES "members"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "conversation_members" ADD CONSTRAINT "conversation_members_conversation_id_fkey" FOREIGN KEY ("conversation_id") REFERENCES "conversations"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "conversation_members" ADD CONSTRAINT "conversation_members_member_id_fkey" FOREIGN KEY ("member_id") REFERENCES "members"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "messages" ADD CONSTRAINT "messages_conversation_id_fkey" FOREIGN KEY ("conversation_id") REFERENCES "conversations"("id") ON DELETE CASCADE ON UPDATE CASCADE; -- AddForeignKey ALTER TABLE "messages" ADD CONSTRAINT "messages_sender_id_fkey" FOREIGN KEY ("sender_id") REFERENCES "members"("id") ON DELETE CASCADE ON UPDATE CASCADE;