-- -- Created by SQL::Translator::Producer::PostgreSQL -- Created on Sun Jun 25 18:30:43 2023 -- ; -- -- Table: equipment -- CREATE TABLE "equipment" ( "uuid" uuid NOT NULL, PRIMARY KEY ("uuid") ); ; -- -- Table: inventories -- CREATE TABLE "inventories" ( "uuid" uuid NOT NULL, PRIMARY KEY ("uuid") ); ; -- -- Table: players -- CREATE TABLE "players" ( "uuid" uuid NOT NULL, "username" text NOT NULL, "encrypted_password" text NOT NULL, "email" text NOT NULL, "verified" boolean NOT NULL, "verification_token" text, "register_date" timestamp DEFAULT NOW() NOT NULL, "last_activity" timestamp DEFAULT NOW() NOT NULL, PRIMARY KEY ("uuid"), CONSTRAINT "unique_constraint_email" UNIQUE ("email"), CONSTRAINT "unique_constraint_username" UNIQUE ("username") ); ; -- -- Table: skill_like_lists -- CREATE TABLE "skill_like_lists" ( "uuid" uuid DEFAULT uuid_generate_v4() NOT NULL, PRIMARY KEY ("uuid") ); ; -- -- Table: stats -- CREATE TABLE "stats" ( "uuid" uuid NOT NULL, "health" integer NOT NULL, "mana" integer NOT NULL, "strength" integer NOT NULL, "resistance" integer NOT NULL, "magic" integer NOT NULL, "speed" integer NOT NULL, "intelligence" integer NOT NULL, PRIMARY KEY ("uuid") ); ; -- -- Table: equipment_items -- CREATE TABLE "equipment_items" ( "kind" text NOT NULL, "equipment" uuid NOT NULL, "identifier" text NOT NULL, "quantity" integer NOT NULL, PRIMARY KEY ("kind", "equipment") ); CREATE INDEX "equipment_items_idx_equipment" on "equipment_items" ("equipment"); ; -- -- Table: inventory_items -- CREATE TABLE "inventory_items" ( "uuid" uuid DEFAULT uuid_generate_v4() NOT NULL, "inventory" uuid NOT NULL, "identifier" text NOT NULL, "quantity" integer NOT NULL, PRIMARY KEY ("uuid"), CONSTRAINT "inventory_items_unique_item" UNIQUE ("inventory", "identifier") ); CREATE INDEX "inventory_items_idx_inventory" on "inventory_items" ("inventory"); ; -- -- Table: skill_like_items -- CREATE TABLE "skill_like_items" ( "identifier" text NOT NULL, "owner_list" uuid NOT NULL, "level" integer DEFAULT 1 NOT NULL, PRIMARY KEY ("identifier", "owner_list") ); CREATE INDEX "skill_like_items_idx_owner_list" on "skill_like_items" ("owner_list"); ; -- -- Table: teams -- CREATE TABLE "teams" ( "uuid" uuid NOT NULL, "is_exploring" boolean DEFAULT false NOT NULL, "action_frame" integer DEFAULT 0 NOT NULL, "is_moving" boolean DEFAULT false NOT NULL, "moving_to" jsonb DEFAULT 'null' NOT NULL, "leader" uuid, "name" text NOT NULL, "planet" text NOT NULL, "super_area" text NOT NULL, "area" text NOT NULL, "location" text NOT NULL, "current_battle" uuid, PRIMARY KEY ("uuid"), CONSTRAINT "u_name" UNIQUE ("name") ); CREATE INDEX "teams_idx_leader" on "teams" ("leader"); ; -- -- Table: player_pjs -- CREATE TABLE "player_pjs" ( "uuid" uuid NOT NULL, "owner" uuid NOT NULL, "full_name" text NOT NULL, "short_name" text NOT NULL, "nick" text NOT NULL, "race" text NOT NULL, "team" uuid NOT NULL, "creation_date" timestamp DEFAULT NOW() NOT NULL, "last_activity" timestamp DEFAULT NOW() NOT NULL, "experience" integer DEFAULT 1 NOT NULL, "equipment" uuid NOT NULL, "born_stats" uuid NOT NULL, "training_stats" uuid NOT NULL, "skills" uuid NOT NULL, "spells" uuid NOT NULL, "inventory" uuid NOT NULL, "health" integer NOT NULL, "mana" integer NOT NULL, "combat_target" uuid, "combat_action" text, PRIMARY KEY ("uuid") ); CREATE INDEX "player_pjs_idx_born_stats" on "player_pjs" ("born_stats"); CREATE INDEX "player_pjs_idx_equipment" on "player_pjs" ("equipment"); CREATE INDEX "player_pjs_idx_inventory" on "player_pjs" ("inventory"); CREATE INDEX "player_pjs_idx_owner" on "player_pjs" ("owner"); CREATE INDEX "player_pjs_idx_skills" on "player_pjs" ("skills"); CREATE INDEX "player_pjs_idx_spells" on "player_pjs" ("spells"); CREATE INDEX "player_pjs_idx_team" on "player_pjs" ("team"); CREATE INDEX "player_pjs_idx_training_stats" on "player_pjs" ("training_stats"); ; -- -- Table: player_companion_npcs -- CREATE TABLE "player_companion_npcs" ( "uuid" uuid DEFAULT uuid_generate_v4() NOT NULL, "owner" uuid NOT NULL, "identifier" text NOT NULL, "nick" text, "race" text NOT NULL, "level" integer DEFAULT 1 NOT NULL, "exp" integer DEFAULT 1 NOT NULL, "equipment" uuid NOT NULL, "stats" uuid NOT NULL, "skills" uuid NOT NULL, "spells" uuid NOT NULL, "inventory" uuid NOT NULL, PRIMARY KEY ("uuid") ); CREATE INDEX "player_companion_npcs_idx_equipment" on "player_companion_npcs" ("equipment"); CREATE INDEX "player_companion_npcs_idx_inventory" on "player_companion_npcs" ("inventory"); CREATE INDEX "player_companion_npcs_idx_owner" on "player_companion_npcs" ("owner"); CREATE INDEX "player_companion_npcs_idx_skills" on "player_companion_npcs" ("skills"); CREATE INDEX "player_companion_npcs_idx_spells" on "player_companion_npcs" ("spells"); CREATE INDEX "player_companion_npcs_idx_stats" on "player_companion_npcs" ("stats"); ; -- -- Table: player_pjs_flags -- CREATE TABLE "player_pjs_flags" ( "name" text NOT NULL, "owner" uuid NOT NULL, PRIMARY KEY ("name", "owner") ); CREATE INDEX "player_pjs_flags_idx_owner" on "player_pjs_flags" ("owner"); CREATE INDEX "index_flag" on "player_pjs_flags" ("owner", "name"); ; -- -- Table: player_pjs_known_places -- CREATE TABLE "player_pjs_known_places" ( "owner" uuid NOT NULL, "planet" text NOT NULL, "super_area" text NOT NULL, "area" text NOT NULL, "location" text NOT NULL, PRIMARY KEY ("owner", "planet", "super_area", "area", "location") ); CREATE INDEX "player_pjs_known_places_idx_owner" on "player_pjs_known_places" ("owner"); ; -- -- Table: player_pjs_log -- CREATE TABLE "player_pjs_log" ( "uuid" uuid NOT NULL, "content" jsonb NOT NULL, "owner" uuid NOT NULL, "date" timestamp DEFAULT NOW() NOT NULL, PRIMARY KEY ("uuid") ); CREATE INDEX "player_pjs_log_idx_owner" on "player_pjs_log" ("owner"); CREATE INDEX "index_log" on "player_pjs_log" ("owner", "date"); ; -- -- Foreign Key Definitions -- ; ALTER TABLE "equipment_items" ADD CONSTRAINT "equipment_items_fk_equipment" FOREIGN KEY ("equipment") REFERENCES "equipment" ("uuid") ON DELETE CASCADE ON UPDATE CASCADE DEFERRABLE; ; ALTER TABLE "inventory_items" ADD CONSTRAINT "inventory_items_fk_inventory" FOREIGN KEY ("inventory") REFERENCES "inventories" ("uuid") ON DELETE CASCADE ON UPDATE CASCADE DEFERRABLE; ; ALTER TABLE "skill_like_items" ADD CONSTRAINT "skill_like_items_fk_owner_list" FOREIGN KEY ("owner_list") REFERENCES "skill_like_lists" ("uuid") ON DELETE CASCADE ON UPDATE CASCADE DEFERRABLE; ; ALTER TABLE "teams" ADD CONSTRAINT "teams_fk_leader" FOREIGN KEY ("leader") REFERENCES "player_pjs" ("uuid") DEFERRABLE; ; ALTER TABLE "player_pjs" ADD CONSTRAINT "player_pjs_fk_born_stats" FOREIGN KEY ("born_stats") REFERENCES "stats" ("uuid") DEFERRABLE; ; ALTER TABLE "player_pjs" ADD CONSTRAINT "player_pjs_fk_equipment" FOREIGN KEY ("equipment") REFERENCES "equipment" ("uuid") DEFERRABLE; ; ALTER TABLE "player_pjs" ADD CONSTRAINT "player_pjs_fk_inventory" FOREIGN KEY ("inventory") REFERENCES "inventories" ("uuid") DEFERRABLE; ; ALTER TABLE "player_pjs" ADD CONSTRAINT "player_pjs_fk_owner" FOREIGN KEY ("owner") REFERENCES "players" ("uuid") ON DELETE CASCADE ON UPDATE CASCADE DEFERRABLE; ; ALTER TABLE "player_pjs" ADD CONSTRAINT "player_pjs_fk_skills" FOREIGN KEY ("skills") REFERENCES "skill_like_lists" ("uuid") DEFERRABLE; ; ALTER TABLE "player_pjs" ADD CONSTRAINT "player_pjs_fk_spells" FOREIGN KEY ("spells") REFERENCES "skill_like_lists" ("uuid") DEFERRABLE; ; ALTER TABLE "player_pjs" ADD CONSTRAINT "player_pjs_fk_team" FOREIGN KEY ("team") REFERENCES "teams" ("uuid") ON DELETE CASCADE ON UPDATE CASCADE DEFERRABLE; ; ALTER TABLE "player_pjs" ADD CONSTRAINT "player_pjs_fk_training_stats" FOREIGN KEY ("training_stats") REFERENCES "stats" ("uuid") DEFERRABLE; ; ALTER TABLE "player_companion_npcs" ADD CONSTRAINT "player_companion_npcs_fk_equipment" FOREIGN KEY ("equipment") REFERENCES "equipment" ("uuid") DEFERRABLE; ; ALTER TABLE "player_companion_npcs" ADD CONSTRAINT "player_companion_npcs_fk_inventory" FOREIGN KEY ("inventory") REFERENCES "inventories" ("uuid") DEFERRABLE; ; ALTER TABLE "player_companion_npcs" ADD CONSTRAINT "player_companion_npcs_fk_owner" FOREIGN KEY ("owner") REFERENCES "player_pjs" ("uuid") ON DELETE CASCADE ON UPDATE CASCADE DEFERRABLE; ; ALTER TABLE "player_companion_npcs" ADD CONSTRAINT "player_companion_npcs_fk_skills" FOREIGN KEY ("skills") REFERENCES "skill_like_lists" ("uuid") DEFERRABLE; ; ALTER TABLE "player_companion_npcs" ADD CONSTRAINT "player_companion_npcs_fk_spells" FOREIGN KEY ("spells") REFERENCES "skill_like_lists" ("uuid") DEFERRABLE; ; ALTER TABLE "player_companion_npcs" ADD CONSTRAINT "player_companion_npcs_fk_stats" FOREIGN KEY ("stats") REFERENCES "stats" ("uuid") DEFERRABLE; ; ALTER TABLE "player_pjs_flags" ADD CONSTRAINT "player_pjs_flags_fk_owner" FOREIGN KEY ("owner") REFERENCES "player_pjs" ("uuid") ON DELETE CASCADE ON UPDATE CASCADE DEFERRABLE; ; ALTER TABLE "player_pjs_known_places" ADD CONSTRAINT "player_pjs_known_places_fk_owner" FOREIGN KEY ("owner") REFERENCES "player_pjs" ("uuid") ON DELETE CASCADE ON UPDATE CASCADE DEFERRABLE; ; ALTER TABLE "player_pjs_log" ADD CONSTRAINT "player_pjs_log_fk_owner" FOREIGN KEY ("owner") REFERENCES "player_pjs" ("uuid") ON DELETE CASCADE ON UPDATE CASCADE DEFERRABLE; ;