CREATE TABLE "achievements" ( "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL, "user_id" uuid NOT NULL, "achievement_id" text NOT NULL, "unlocked_at" timestamp DEFAULT now() NOT NULL ); --> statement-breakpoint CREATE TABLE "invitations" ( "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL, "code" text NOT NULL, "created_by" uuid NOT NULL, "used_by" uuid, "created_at" timestamp DEFAULT now() NOT NULL, "expires_at" timestamp, CONSTRAINT "invitations_code_unique" UNIQUE("code") ); --> statement-breakpoint CREATE TABLE "leaderboard" ( "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL, "user_id" uuid NOT NULL, "company_name" text NOT NULL, "category" text NOT NULL, "score" integer NOT NULL, "era" text NOT NULL, "tick_count" integer NOT NULL, "submitted_at" timestamp DEFAULT now() NOT NULL ); --> statement-breakpoint CREATE TABLE "saves" ( "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL, "user_id" uuid NOT NULL, "company_name" text NOT NULL, "save_version" integer NOT NULL, "game_data" jsonb NOT NULL, "tick_count" integer DEFAULT 0 NOT NULL, "era" text DEFAULT 'startup' NOT NULL, "created_at" timestamp DEFAULT now() NOT NULL, "updated_at" timestamp DEFAULT now() NOT NULL ); --> statement-breakpoint CREATE TABLE "users" ( "id" uuid PRIMARY KEY DEFAULT gen_random_uuid() NOT NULL, "anon_token" uuid DEFAULT gen_random_uuid() NOT NULL, "username" text, "email" text, "password_hash" text, "role" text DEFAULT 'user' NOT NULL, "must_reset_password" boolean DEFAULT false NOT NULL, "created_at" timestamp DEFAULT now() NOT NULL, "last_seen_at" timestamp DEFAULT now() NOT NULL, CONSTRAINT "users_anon_token_unique" UNIQUE("anon_token"), CONSTRAINT "users_username_unique" UNIQUE("username"), CONSTRAINT "users_email_unique" UNIQUE("email") ); --> statement-breakpoint ALTER TABLE "achievements" ADD CONSTRAINT "achievements_user_id_users_id_fk" FOREIGN KEY ("user_id") REFERENCES "public"."users"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint ALTER TABLE "invitations" ADD CONSTRAINT "invitations_created_by_users_id_fk" FOREIGN KEY ("created_by") REFERENCES "public"."users"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint ALTER TABLE "invitations" ADD CONSTRAINT "invitations_used_by_users_id_fk" FOREIGN KEY ("used_by") REFERENCES "public"."users"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint ALTER TABLE "leaderboard" ADD CONSTRAINT "leaderboard_user_id_users_id_fk" FOREIGN KEY ("user_id") REFERENCES "public"."users"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint ALTER TABLE "saves" ADD CONSTRAINT "saves_user_id_users_id_fk" FOREIGN KEY ("user_id") REFERENCES "public"."users"("id") ON DELETE no action ON UPDATE no action;--> statement-breakpoint CREATE INDEX "achievements_user_id_idx" ON "achievements" USING btree ("user_id");--> statement-breakpoint CREATE INDEX "leaderboard_category_score_idx" ON "leaderboard" USING btree ("category","score");--> statement-breakpoint CREATE INDEX "saves_user_id_idx" ON "saves" USING btree ("user_id");