mirror of
https://github.com/whekin/household-bot.git
synced 2026-03-31 21:04:03 +00:00
32 lines
2.4 KiB
SQL
32 lines
2.4 KiB
SQL
CREATE TABLE "ad_hoc_notifications" (
|
|
"id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL,
|
|
"household_id" uuid NOT NULL,
|
|
"creator_member_id" uuid NOT NULL,
|
|
"assignee_member_id" uuid,
|
|
"original_request_text" text NOT NULL,
|
|
"notification_text" text NOT NULL,
|
|
"timezone" text NOT NULL,
|
|
"scheduled_for" timestamp with time zone NOT NULL,
|
|
"time_precision" text NOT NULL,
|
|
"delivery_mode" text NOT NULL,
|
|
"dm_recipient_member_ids" jsonb DEFAULT '[]'::jsonb NOT NULL,
|
|
"friendly_tag_assignee" integer DEFAULT 0 NOT NULL,
|
|
"status" text DEFAULT 'scheduled' NOT NULL,
|
|
"source_telegram_chat_id" text,
|
|
"source_telegram_thread_id" text,
|
|
"sent_at" timestamp with time zone,
|
|
"cancelled_at" timestamp with time zone,
|
|
"cancelled_by_member_id" uuid,
|
|
"created_at" timestamp with time zone DEFAULT now() NOT NULL,
|
|
"updated_at" timestamp with time zone DEFAULT now() NOT NULL
|
|
);
|
|
--> statement-breakpoint
|
|
ALTER TABLE "ad_hoc_notifications" ADD CONSTRAINT "ad_hoc_notifications_household_id_households_id_fk" FOREIGN KEY ("household_id") REFERENCES "public"."households"("id") ON DELETE cascade ON UPDATE no action;--> statement-breakpoint
|
|
ALTER TABLE "ad_hoc_notifications" ADD CONSTRAINT "ad_hoc_notifications_creator_member_id_members_id_fk" FOREIGN KEY ("creator_member_id") REFERENCES "public"."members"("id") ON DELETE restrict ON UPDATE no action;--> statement-breakpoint
|
|
ALTER TABLE "ad_hoc_notifications" ADD CONSTRAINT "ad_hoc_notifications_assignee_member_id_members_id_fk" FOREIGN KEY ("assignee_member_id") REFERENCES "public"."members"("id") ON DELETE set null ON UPDATE no action;--> statement-breakpoint
|
|
ALTER TABLE "ad_hoc_notifications" ADD CONSTRAINT "ad_hoc_notifications_cancelled_by_member_id_members_id_fk" FOREIGN KEY ("cancelled_by_member_id") REFERENCES "public"."members"("id") ON DELETE set null ON UPDATE no action;--> statement-breakpoint
|
|
CREATE INDEX "ad_hoc_notifications_due_idx" ON "ad_hoc_notifications" USING btree ("status","scheduled_for");--> statement-breakpoint
|
|
CREATE INDEX "ad_hoc_notifications_household_status_idx" ON "ad_hoc_notifications" USING btree ("household_id","status","scheduled_for");--> statement-breakpoint
|
|
CREATE INDEX "ad_hoc_notifications_creator_idx" ON "ad_hoc_notifications" USING btree ("creator_member_id");--> statement-breakpoint
|
|
CREATE INDEX "ad_hoc_notifications_assignee_idx" ON "ad_hoc_notifications" USING btree ("assignee_member_id");--> statement-breakpoint
|