CREATE TABLE "custom_field_values" ( "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL, "custom_field_id" uuid NOT NULL, "ticket_id" uuid NOT NULL, "value" text NOT NULL, "created_at" timestamp with time zone DEFAULT now(), CONSTRAINT "custom_field_values_cf_id_ticket_id_value_unique" UNIQUE("custom_field_id","ticket_id","value") ); --> statement-breakpoint CREATE TABLE "custom_fields" ( "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL, "name" text NOT NULL, "field_type" text NOT NULL, "values" jsonb, "max_values" integer DEFAULT 1 NOT NULL, "pattern" text, "created_at" timestamp with time zone DEFAULT now() ); --> statement-breakpoint CREATE TABLE "lifecycles" ( "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL, "name" text NOT NULL, "definition" jsonb NOT NULL, "created_at" timestamp with time zone DEFAULT now(), CONSTRAINT "lifecycles_name_unique" UNIQUE("name") ); --> statement-breakpoint CREATE TABLE "queue_custom_fields" ( "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL, "queue_id" uuid NOT NULL, "custom_field_id" uuid NOT NULL, "sort_order" integer DEFAULT 0 NOT NULL, CONSTRAINT "queue_custom_fields_queue_id_custom_field_id_unique" UNIQUE("queue_id","custom_field_id") ); --> statement-breakpoint CREATE TABLE "queues" ( "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL, "name" text NOT NULL, "description" text, "lifecycle_id" uuid, "created_at" timestamp with time zone DEFAULT now(), CONSTRAINT "queues_name_unique" UNIQUE("name") ); --> statement-breakpoint CREATE TABLE "scrips" ( "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL, "queue_id" uuid, "name" text NOT NULL, "description" text, "condition_type" text NOT NULL, "condition_config" jsonb DEFAULT '{}'::jsonb NOT NULL, "action_type" text NOT NULL, "action_config" jsonb DEFAULT '{}'::jsonb NOT NULL, "template_id" uuid, "stage" text DEFAULT 'TransactionCreate' NOT NULL, "sort_order" integer DEFAULT 0 NOT NULL, "disabled" boolean DEFAULT false NOT NULL, "created_at" timestamp with time zone DEFAULT now() ); --> statement-breakpoint CREATE TABLE "templates" ( "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL, "name" text NOT NULL, "queue_id" uuid, "subject_template" text NOT NULL, "body_template" text NOT NULL, "created_at" timestamp with time zone DEFAULT now() ); --> statement-breakpoint CREATE TABLE "tickets" ( "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL, "subject" text NOT NULL, "queue_id" uuid NOT NULL, "status" text NOT NULL, "owner_id" uuid, "creator_id" uuid NOT NULL, "created_at" timestamp with time zone DEFAULT now(), "updated_at" timestamp with time zone DEFAULT now(), "started_at" timestamp with time zone, "resolved_at" timestamp with time zone ); --> statement-breakpoint CREATE TABLE "transactions" ( "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL, "ticket_id" uuid NOT NULL, "transaction_type" text NOT NULL, "field" text, "old_value" text, "new_value" text, "data" jsonb, "creator_id" uuid NOT NULL, "created_at" timestamp with time zone DEFAULT now() ); --> statement-breakpoint CREATE TABLE "users" ( "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL, "username" text NOT NULL, "email" text, "created_at" timestamp with time zone DEFAULT now(), CONSTRAINT "users_username_unique" UNIQUE("username") ); --> statement-breakpoint ALTER TABLE "custom_field_values" ADD CONSTRAINT "custom_field_values_custom_field_id_custom_fields_id_fk" FOREIGN KEY ("custom_field_id") REFERENCES "public"."custom_fields"("id") ON DELETE cascade ON UPDATE no action;--> statement-breakpoint ALTER TABLE "custom_field_values" ADD CONSTRAINT "custom_field_values_ticket_id_tickets_id_fk" FOREIGN KEY ("ticket_id") REFERENCES "public"."tickets"("id") ON DELETE cascade ON UPDATE no action;--> statement-breakpoint ALTER TABLE "queue_custom_fields" ADD CONSTRAINT "queue_custom_fields_queue_id_queues_id_fk" FOREIGN KEY ("queue_id") REFERENCES "public"."queues"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint ALTER TABLE "queue_custom_fields" ADD CONSTRAINT "queue_custom_fields_custom_field_id_custom_fields_id_fk" FOREIGN KEY ("custom_field_id") REFERENCES "public"."custom_fields"("id") ON DELETE cascade ON UPDATE no action;--> statement-breakpoint ALTER TABLE "queues" ADD CONSTRAINT "queues_lifecycle_id_lifecycles_id_fk" FOREIGN KEY ("lifecycle_id") REFERENCES "public"."lifecycles"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint ALTER TABLE "scrips" ADD CONSTRAINT "scrips_queue_id_queues_id_fk" FOREIGN KEY ("queue_id") REFERENCES "public"."queues"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint ALTER TABLE "scrips" ADD CONSTRAINT "scrips_template_id_templates_id_fk" FOREIGN KEY ("template_id") REFERENCES "public"."templates"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint ALTER TABLE "templates" ADD CONSTRAINT "templates_queue_id_queues_id_fk" FOREIGN KEY ("queue_id") REFERENCES "public"."queues"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint ALTER TABLE "tickets" ADD CONSTRAINT "tickets_queue_id_queues_id_fk" FOREIGN KEY ("queue_id") REFERENCES "public"."queues"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint ALTER TABLE "tickets" ADD CONSTRAINT "tickets_owner_id_users_id_fk" FOREIGN KEY ("owner_id") REFERENCES "public"."users"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint ALTER TABLE "tickets" ADD CONSTRAINT "tickets_creator_id_users_id_fk" FOREIGN KEY ("creator_id") REFERENCES "public"."users"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint ALTER TABLE "transactions" ADD CONSTRAINT "transactions_ticket_id_tickets_id_fk" FOREIGN KEY ("ticket_id") REFERENCES "public"."tickets"("id") ON DELETE cascade ON UPDATE no action;--> statement-breakpoint ALTER TABLE "transactions" ADD CONSTRAINT "transactions_creator_id_users_id_fk" FOREIGN KEY ("creator_id") REFERENCES "public"."users"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint CREATE INDEX "custom_field_values_ticket_id_idx" ON "custom_field_values" USING btree ("ticket_id");--> statement-breakpoint CREATE INDEX "custom_field_values_custom_field_id_idx" ON "custom_field_values" USING btree ("custom_field_id");--> statement-breakpoint CREATE INDEX "scrips_queue_id_idx" ON "scrips" USING btree ("queue_id");--> statement-breakpoint CREATE INDEX "tickets_queue_id_idx" ON "tickets" USING btree ("queue_id");--> statement-breakpoint CREATE INDEX "tickets_status_idx" ON "tickets" USING btree ("status");--> statement-breakpoint CREATE INDEX "transactions_ticket_id_idx" ON "transactions" USING btree ("ticket_id");--> statement-breakpoint CREATE INDEX "transactions_created_at_idx" ON "transactions" USING btree ("created_at");