CREATE TABLE "apikey" ( "id" text PRIMARY KEY NOT NULL, "name" text, "start" text, "prefix" text, "key" text NOT NULL, "user_id" text NOT NULL, "refill_interval" integer, "refill_amount" integer, "last_refill_at" timestamp, "enabled" boolean DEFAULT true, "rate_limit_enabled" boolean DEFAULT true, "rate_limit_time_window" integer DEFAULT 86400000, "rate_limit_max" integer DEFAULT 10, "request_count" integer DEFAULT 0, "remaining" integer, "last_request" timestamp, "expires_at" timestamp, "created_at" timestamp NOT NULL, "updated_at" timestamp NOT NULL, "permissions" text, "metadata" text ); --> statement-breakpoint CREATE TABLE "jwks" ( "id" text PRIMARY KEY NOT NULL, "public_key" text NOT NULL, "private_key" text NOT NULL, "created_at" timestamp NOT NULL, "expires_at" timestamp ); --> statement-breakpoint ALTER TABLE "session" ADD COLUMN "impersonated_by" text;--> statement-breakpoint ALTER TABLE "user" ADD COLUMN "role" text;--> statement-breakpoint ALTER TABLE "user" ADD COLUMN "banned" boolean DEFAULT false;--> statement-breakpoint ALTER TABLE "user" ADD COLUMN "ban_reason" text;--> statement-breakpoint ALTER TABLE "user" ADD COLUMN "ban_expires" timestamp;--> statement-breakpoint ALTER TABLE "user" ADD COLUMN "username" text;--> statement-breakpoint ALTER TABLE "user" ADD COLUMN "display_username" text;--> statement-breakpoint ALTER TABLE "user" ADD COLUMN "last_login" timestamp DEFAULT now();--> statement-breakpoint ALTER TABLE "apikey" ADD CONSTRAINT "apikey_user_id_user_id_fk" FOREIGN KEY ("user_id") REFERENCES "public"."user"("id") ON DELETE cascade ON UPDATE no action;--> statement-breakpoint CREATE INDEX "apikey_key_idx" ON "apikey" USING btree ("key");--> statement-breakpoint CREATE INDEX "apikey_userId_idx" ON "apikey" USING btree ("user_id");--> statement-breakpoint ALTER TABLE "user" ADD CONSTRAINT "user_username_unique" UNIQUE("username");