44 lines
1.9 KiB
SQL
44 lines
1.9 KiB
SQL
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"); |