diff --git a/Content.Server.Database/Migrations/Postgres/20240606175154_ReturnLastReadRules.Designer.cs b/Content.Server.Database/Migrations/Postgres/20240606175154_ReturnLastReadRules.Designer.cs
deleted file mode 100644
index e82e58bf5ce..00000000000
--- a/Content.Server.Database/Migrations/Postgres/20240606175154_ReturnLastReadRules.Designer.cs
+++ /dev/null
@@ -1,1913 +0,0 @@
-//
-using System;
-using System.Net;
-using System.Text.Json;
-using Content.Server.Database;
-using Microsoft.EntityFrameworkCore;
-using Microsoft.EntityFrameworkCore.Infrastructure;
-using Microsoft.EntityFrameworkCore.Migrations;
-using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
-using Npgsql.EntityFrameworkCore.PostgreSQL.Metadata;
-using NpgsqlTypes;
-
-#nullable disable
-
-namespace Content.Server.Database.Migrations.Postgres
-{
- [DbContext(typeof(PostgresServerDbContext))]
- [Migration("20240606175154_ReturnLastReadRules")]
- partial class ReturnLastReadRules
- {
- ///
- protected override void BuildTargetModel(ModelBuilder modelBuilder)
- {
-#pragma warning disable 612, 618
- modelBuilder
- .HasAnnotation("ProductVersion", "8.0.0")
- .HasAnnotation("Relational:MaxIdentifierLength", 63);
-
- NpgsqlModelBuilderExtensions.UseIdentityByDefaultColumns(modelBuilder);
-
- modelBuilder.Entity("Content.Server.Database.Admin", b =>
- {
- b.Property("UserId")
- .ValueGeneratedOnAdd()
- .HasColumnType("uuid")
- .HasColumnName("user_id");
-
- b.Property("AdminRankId")
- .HasColumnType("integer")
- .HasColumnName("admin_rank_id");
-
- b.Property("Title")
- .HasColumnType("text")
- .HasColumnName("title");
-
- b.HasKey("UserId")
- .HasName("PK_admin");
-
- b.HasIndex("AdminRankId")
- .HasDatabaseName("IX_admin_admin_rank_id");
-
- b.ToTable("admin", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.AdminFlag", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("admin_flag_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("AdminId")
- .HasColumnType("uuid")
- .HasColumnName("admin_id");
-
- b.Property("Flag")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("flag");
-
- b.Property("Negative")
- .HasColumnType("boolean")
- .HasColumnName("negative");
-
- b.HasKey("Id")
- .HasName("PK_admin_flag");
-
- b.HasIndex("AdminId")
- .HasDatabaseName("IX_admin_flag_admin_id");
-
- b.HasIndex("Flag", "AdminId")
- .IsUnique();
-
- b.ToTable("admin_flag", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.AdminLog", b =>
- {
- b.Property("RoundId")
- .HasColumnType("integer")
- .HasColumnName("round_id");
-
- b.Property("Id")
- .HasColumnType("integer")
- .HasColumnName("admin_log_id");
-
- b.Property("Date")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("date");
-
- b.Property("Impact")
- .HasColumnType("smallint")
- .HasColumnName("impact");
-
- b.Property("Json")
- .IsRequired()
- .HasColumnType("jsonb")
- .HasColumnName("json");
-
- b.Property("Message")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("message");
-
- b.Property("Type")
- .HasColumnType("integer")
- .HasColumnName("type");
-
- b.HasKey("RoundId", "Id")
- .HasName("PK_admin_log");
-
- b.HasIndex("Date");
-
- b.HasIndex("Message")
- .HasAnnotation("Npgsql:TsVectorConfig", "english");
-
- NpgsqlIndexBuilderExtensions.HasMethod(b.HasIndex("Message"), "GIN");
-
- b.HasIndex("Type")
- .HasDatabaseName("IX_admin_log_type");
-
- b.ToTable("admin_log", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.AdminLogPlayer", b =>
- {
- b.Property("RoundId")
- .HasColumnType("integer")
- .HasColumnName("round_id");
-
- b.Property("LogId")
- .HasColumnType("integer")
- .HasColumnName("log_id");
-
- b.Property("PlayerUserId")
- .HasColumnType("uuid")
- .HasColumnName("player_user_id");
-
- b.HasKey("RoundId", "LogId", "PlayerUserId")
- .HasName("PK_admin_log_player");
-
- b.HasIndex("PlayerUserId")
- .HasDatabaseName("IX_admin_log_player_player_user_id");
-
- b.ToTable("admin_log_player", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.AdminMessage", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("admin_messages_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("CreatedAt")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("created_at");
-
- b.Property("CreatedById")
- .HasColumnType("uuid")
- .HasColumnName("created_by_id");
-
- b.Property("Deleted")
- .HasColumnType("boolean")
- .HasColumnName("deleted");
-
- b.Property("DeletedAt")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("deleted_at");
-
- b.Property("DeletedById")
- .HasColumnType("uuid")
- .HasColumnName("deleted_by_id");
-
- b.Property("Dismissed")
- .HasColumnType("boolean")
- .HasColumnName("dismissed");
-
- b.Property("ExpirationTime")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("expiration_time");
-
- b.Property("LastEditedAt")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("last_edited_at");
-
- b.Property("LastEditedById")
- .HasColumnType("uuid")
- .HasColumnName("last_edited_by_id");
-
- b.Property("Message")
- .IsRequired()
- .HasMaxLength(4096)
- .HasColumnType("character varying(4096)")
- .HasColumnName("message");
-
- b.Property("PlayerUserId")
- .HasColumnType("uuid")
- .HasColumnName("player_user_id");
-
- b.Property("PlaytimeAtNote")
- .HasColumnType("interval")
- .HasColumnName("playtime_at_note");
-
- b.Property("RoundId")
- .HasColumnType("integer")
- .HasColumnName("round_id");
-
- b.Property("Seen")
- .HasColumnType("boolean")
- .HasColumnName("seen");
-
- b.HasKey("Id")
- .HasName("PK_admin_messages");
-
- b.HasIndex("CreatedById");
-
- b.HasIndex("DeletedById");
-
- b.HasIndex("LastEditedById");
-
- b.HasIndex("PlayerUserId")
- .HasDatabaseName("IX_admin_messages_player_user_id");
-
- b.HasIndex("RoundId")
- .HasDatabaseName("IX_admin_messages_round_id");
-
- b.ToTable("admin_messages", null, t =>
- {
- t.HasCheckConstraint("NotDismissedAndSeen", "NOT dismissed OR seen");
- });
- });
-
- modelBuilder.Entity("Content.Server.Database.AdminNote", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("admin_notes_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("CreatedAt")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("created_at");
-
- b.Property("CreatedById")
- .HasColumnType("uuid")
- .HasColumnName("created_by_id");
-
- b.Property("Deleted")
- .HasColumnType("boolean")
- .HasColumnName("deleted");
-
- b.Property("DeletedAt")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("deleted_at");
-
- b.Property("DeletedById")
- .HasColumnType("uuid")
- .HasColumnName("deleted_by_id");
-
- b.Property("ExpirationTime")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("expiration_time");
-
- b.Property("LastEditedAt")
- .IsRequired()
- .HasColumnType("timestamp with time zone")
- .HasColumnName("last_edited_at");
-
- b.Property("LastEditedById")
- .HasColumnType("uuid")
- .HasColumnName("last_edited_by_id");
-
- b.Property("Message")
- .IsRequired()
- .HasMaxLength(4096)
- .HasColumnType("character varying(4096)")
- .HasColumnName("message");
-
- b.Property("PlayerUserId")
- .HasColumnType("uuid")
- .HasColumnName("player_user_id");
-
- b.Property("PlaytimeAtNote")
- .HasColumnType("interval")
- .HasColumnName("playtime_at_note");
-
- b.Property("RoundId")
- .HasColumnType("integer")
- .HasColumnName("round_id");
-
- b.Property("Secret")
- .HasColumnType("boolean")
- .HasColumnName("secret");
-
- b.Property("Severity")
- .HasColumnType("integer")
- .HasColumnName("severity");
-
- b.HasKey("Id")
- .HasName("PK_admin_notes");
-
- b.HasIndex("CreatedById");
-
- b.HasIndex("DeletedById");
-
- b.HasIndex("LastEditedById");
-
- b.HasIndex("PlayerUserId")
- .HasDatabaseName("IX_admin_notes_player_user_id");
-
- b.HasIndex("RoundId")
- .HasDatabaseName("IX_admin_notes_round_id");
-
- b.ToTable("admin_notes", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.AdminRank", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("admin_rank_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("Name")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("name");
-
- b.HasKey("Id")
- .HasName("PK_admin_rank");
-
- b.ToTable("admin_rank", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.AdminRankFlag", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("admin_rank_flag_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("AdminRankId")
- .HasColumnType("integer")
- .HasColumnName("admin_rank_id");
-
- b.Property("Flag")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("flag");
-
- b.HasKey("Id")
- .HasName("PK_admin_rank_flag");
-
- b.HasIndex("AdminRankId");
-
- b.HasIndex("Flag", "AdminRankId")
- .IsUnique();
-
- b.ToTable("admin_rank_flag", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.AdminWatchlist", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("admin_watchlists_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("CreatedAt")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("created_at");
-
- b.Property("CreatedById")
- .HasColumnType("uuid")
- .HasColumnName("created_by_id");
-
- b.Property("Deleted")
- .HasColumnType("boolean")
- .HasColumnName("deleted");
-
- b.Property("DeletedAt")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("deleted_at");
-
- b.Property("DeletedById")
- .HasColumnType("uuid")
- .HasColumnName("deleted_by_id");
-
- b.Property("ExpirationTime")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("expiration_time");
-
- b.Property("LastEditedAt")
- .IsRequired()
- .HasColumnType("timestamp with time zone")
- .HasColumnName("last_edited_at");
-
- b.Property("LastEditedById")
- .HasColumnType("uuid")
- .HasColumnName("last_edited_by_id");
-
- b.Property("Message")
- .IsRequired()
- .HasMaxLength(4096)
- .HasColumnType("character varying(4096)")
- .HasColumnName("message");
-
- b.Property("PlayerUserId")
- .HasColumnType("uuid")
- .HasColumnName("player_user_id");
-
- b.Property("PlaytimeAtNote")
- .HasColumnType("interval")
- .HasColumnName("playtime_at_note");
-
- b.Property("RoundId")
- .HasColumnType("integer")
- .HasColumnName("round_id");
-
- b.HasKey("Id")
- .HasName("PK_admin_watchlists");
-
- b.HasIndex("CreatedById");
-
- b.HasIndex("DeletedById");
-
- b.HasIndex("LastEditedById");
-
- b.HasIndex("PlayerUserId")
- .HasDatabaseName("IX_admin_watchlists_player_user_id");
-
- b.HasIndex("RoundId")
- .HasDatabaseName("IX_admin_watchlists_round_id");
-
- b.ToTable("admin_watchlists", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.Antag", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("antag_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("AntagName")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("antag_name");
-
- b.Property("ProfileId")
- .HasColumnType("integer")
- .HasColumnName("profile_id");
-
- b.HasKey("Id")
- .HasName("PK_antag");
-
- b.HasIndex("ProfileId", "AntagName")
- .IsUnique();
-
- b.ToTable("antag", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.AssignedUserId", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("assigned_user_id_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("UserId")
- .HasColumnType("uuid")
- .HasColumnName("user_id");
-
- b.Property("UserName")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("user_name");
-
- b.HasKey("Id")
- .HasName("PK_assigned_user_id");
-
- b.HasIndex("UserId")
- .IsUnique();
-
- b.HasIndex("UserName")
- .IsUnique();
-
- b.ToTable("assigned_user_id", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.ConnectionLog", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("connection_log_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("Address")
- .IsRequired()
- .HasColumnType("inet")
- .HasColumnName("address");
-
- b.Property("Denied")
- .HasColumnType("smallint")
- .HasColumnName("denied");
-
- b.Property("HWId")
- .HasColumnType("bytea")
- .HasColumnName("hwid");
-
- b.Property("ServerId")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasDefaultValue(0)
- .HasColumnName("server_id");
-
- b.Property("Time")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("time");
-
- b.Property("UserId")
- .HasColumnType("uuid")
- .HasColumnName("user_id");
-
- b.Property("UserName")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("user_name");
-
- b.HasKey("Id")
- .HasName("PK_connection_log");
-
- b.HasIndex("ServerId")
- .HasDatabaseName("IX_connection_log_server_id");
-
- b.HasIndex("UserId");
-
- b.ToTable("connection_log", null, t =>
- {
- t.HasCheckConstraint("AddressNotIPv6MappedIPv4", "NOT inet '::ffff:0.0.0.0/96' >>= address");
- });
- });
-
- modelBuilder.Entity("Content.Server.Database.Job", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("job_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("JobName")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("job_name");
-
- b.Property("Priority")
- .HasColumnType("integer")
- .HasColumnName("priority");
-
- b.Property("ProfileId")
- .HasColumnType("integer")
- .HasColumnName("profile_id");
-
- b.HasKey("Id")
- .HasName("PK_job");
-
- b.HasIndex("ProfileId");
-
- b.HasIndex("ProfileId", "JobName")
- .IsUnique();
-
- b.HasIndex(new[] { "ProfileId" }, "IX_job_one_high_priority")
- .IsUnique()
- .HasFilter("priority = 3");
-
- b.ToTable("job", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.PlayTime", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("play_time_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("PlayerId")
- .HasColumnType("uuid")
- .HasColumnName("player_id");
-
- b.Property("TimeSpent")
- .HasColumnType("interval")
- .HasColumnName("time_spent");
-
- b.Property("Tracker")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("tracker");
-
- b.HasKey("Id")
- .HasName("PK_play_time");
-
- b.HasIndex("PlayerId", "Tracker")
- .IsUnique();
-
- b.ToTable("play_time", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.Player", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("player_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("FirstSeenTime")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("first_seen_time");
-
- b.Property("LastReadRules")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("last_read_rules");
-
- b.Property("LastSeenAddress")
- .IsRequired()
- .HasColumnType("inet")
- .HasColumnName("last_seen_address");
-
- b.Property("LastSeenHWId")
- .HasColumnType("bytea")
- .HasColumnName("last_seen_hwid");
-
- b.Property("LastSeenTime")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("last_seen_time");
-
- b.Property("LastSeenUserName")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("last_seen_user_name");
-
- b.Property("UserId")
- .HasColumnType("uuid")
- .HasColumnName("user_id");
-
- b.HasKey("Id")
- .HasName("PK_player");
-
- b.HasAlternateKey("UserId")
- .HasName("ak_player_user_id");
-
- b.HasIndex("LastSeenUserName");
-
- b.HasIndex("UserId")
- .IsUnique();
-
- b.ToTable("player", null, t =>
- {
- t.HasCheckConstraint("LastSeenAddressNotIPv6MappedIPv4", "NOT inet '::ffff:0.0.0.0/96' >>= last_seen_address");
- });
- });
-
- modelBuilder.Entity("Content.Server.Database.Preference", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("preference_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("AdminOOCColor")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("admin_ooc_color");
-
- b.Property("SelectedCharacterSlot")
- .HasColumnType("integer")
- .HasColumnName("selected_character_slot");
-
- b.Property("UserId")
- .HasColumnType("uuid")
- .HasColumnName("user_id");
-
- b.HasKey("Id")
- .HasName("PK_preference");
-
- b.HasIndex("UserId")
- .IsUnique();
-
- b.ToTable("preference", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.Profile", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("profile_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("Age")
- .HasColumnType("integer")
- .HasColumnName("age");
-
- b.Property("CharacterName")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("char_name");
-
- b.Property("EyeColor")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("eye_color");
-
- b.Property("FacialHairColor")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("facial_hair_color");
-
- b.Property("FacialHairName")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("facial_hair_name");
-
- b.Property("FlavorText")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("flavor_text");
-
- b.Property("Gender")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("gender");
-
- b.Property("HairColor")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("hair_color");
-
- b.Property("HairName")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("hair_name");
-
- b.Property("Markings")
- .HasColumnType("jsonb")
- .HasColumnName("markings");
-
- b.Property("PreferenceId")
- .HasColumnType("integer")
- .HasColumnName("preference_id");
-
- b.Property("PreferenceUnavailable")
- .HasColumnType("integer")
- .HasColumnName("pref_unavailable");
-
- b.Property("Sex")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("sex");
-
- b.Property("SkinColor")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("skin_color");
-
- b.Property("Slot")
- .HasColumnType("integer")
- .HasColumnName("slot");
-
- b.Property("SpawnPriority")
- .HasColumnType("integer")
- .HasColumnName("spawn_priority");
-
- b.Property("Species")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("species");
-
- b.HasKey("Id")
- .HasName("PK_profile");
-
- b.HasIndex("PreferenceId")
- .HasDatabaseName("IX_profile_preference_id");
-
- b.HasIndex("Slot", "PreferenceId")
- .IsUnique();
-
- b.ToTable("profile", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.ProfileLoadout", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("profile_loadout_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("LoadoutName")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("loadout_name");
-
- b.Property("ProfileLoadoutGroupId")
- .HasColumnType("integer")
- .HasColumnName("profile_loadout_group_id");
-
- b.HasKey("Id")
- .HasName("PK_profile_loadout");
-
- b.HasIndex("ProfileLoadoutGroupId");
-
- b.ToTable("profile_loadout", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.ProfileLoadoutGroup", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("profile_loadout_group_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("GroupName")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("group_name");
-
- b.Property("ProfileRoleLoadoutId")
- .HasColumnType("integer")
- .HasColumnName("profile_role_loadout_id");
-
- b.HasKey("Id")
- .HasName("PK_profile_loadout_group");
-
- b.HasIndex("ProfileRoleLoadoutId");
-
- b.ToTable("profile_loadout_group", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.ProfileRoleLoadout", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("profile_role_loadout_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("ProfileId")
- .HasColumnType("integer")
- .HasColumnName("profile_id");
-
- b.Property("RoleName")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("role_name");
-
- b.HasKey("Id")
- .HasName("PK_profile_role_loadout");
-
- b.HasIndex("ProfileId");
-
- b.ToTable("profile_role_loadout", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.RoleWhitelist", b =>
- {
- b.Property("PlayerUserId")
- .HasColumnType("uuid")
- .HasColumnName("player_user_id");
-
- b.Property("RoleId")
- .HasColumnType("text")
- .HasColumnName("role_id");
-
- b.HasKey("PlayerUserId", "RoleId")
- .HasName("PK_role_whitelists");
-
- b.ToTable("role_whitelists", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.Round", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("round_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("ServerId")
- .HasColumnType("integer")
- .HasColumnName("server_id");
-
- b.Property("StartDate")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("start_date");
-
- b.HasKey("Id")
- .HasName("PK_round");
-
- b.HasIndex("ServerId")
- .HasDatabaseName("IX_round_server_id");
-
- b.HasIndex("StartDate");
-
- b.ToTable("round", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.Server", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("server_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("Name")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("name");
-
- b.HasKey("Id")
- .HasName("PK_server");
-
- b.ToTable("server", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.ServerBan", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("server_ban_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("Address")
- .HasColumnType("inet")
- .HasColumnName("address");
-
- b.Property("AutoDelete")
- .HasColumnType("boolean")
- .HasColumnName("auto_delete");
-
- b.Property("BanTime")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("ban_time");
-
- b.Property("BanningAdmin")
- .HasColumnType("uuid")
- .HasColumnName("banning_admin");
-
- b.Property("ExemptFlags")
- .HasColumnType("integer")
- .HasColumnName("exempt_flags");
-
- b.Property("ExpirationTime")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("expiration_time");
-
- b.Property("HWId")
- .HasColumnType("bytea")
- .HasColumnName("hwid");
-
- b.Property("Hidden")
- .HasColumnType("boolean")
- .HasColumnName("hidden");
-
- b.Property("LastEditedAt")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("last_edited_at");
-
- b.Property("LastEditedById")
- .HasColumnType("uuid")
- .HasColumnName("last_edited_by_id");
-
- b.Property("PlayerUserId")
- .HasColumnType("uuid")
- .HasColumnName("player_user_id");
-
- b.Property("PlaytimeAtNote")
- .HasColumnType("interval")
- .HasColumnName("playtime_at_note");
-
- b.Property("Reason")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("reason");
-
- b.Property("RoundId")
- .HasColumnType("integer")
- .HasColumnName("round_id");
-
- b.Property("Severity")
- .HasColumnType("integer")
- .HasColumnName("severity");
-
- b.HasKey("Id")
- .HasName("PK_server_ban");
-
- b.HasIndex("Address");
-
- b.HasIndex("BanningAdmin");
-
- b.HasIndex("LastEditedById");
-
- b.HasIndex("PlayerUserId")
- .HasDatabaseName("IX_server_ban_player_user_id");
-
- b.HasIndex("RoundId")
- .HasDatabaseName("IX_server_ban_round_id");
-
- b.ToTable("server_ban", null, t =>
- {
- t.HasCheckConstraint("AddressNotIPv6MappedIPv4", "NOT inet '::ffff:0.0.0.0/96' >>= address");
-
- t.HasCheckConstraint("HaveEitherAddressOrUserIdOrHWId", "address IS NOT NULL OR player_user_id IS NOT NULL OR hwid IS NOT NULL");
- });
- });
-
- modelBuilder.Entity("Content.Server.Database.ServerBanExemption", b =>
- {
- b.Property("UserId")
- .ValueGeneratedOnAdd()
- .HasColumnType("uuid")
- .HasColumnName("user_id");
-
- b.Property("Flags")
- .HasColumnType("integer")
- .HasColumnName("flags");
-
- b.HasKey("UserId")
- .HasName("PK_server_ban_exemption");
-
- b.ToTable("server_ban_exemption", null, t =>
- {
- t.HasCheckConstraint("FlagsNotZero", "flags != 0");
- });
- });
-
- modelBuilder.Entity("Content.Server.Database.ServerBanHit", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("server_ban_hit_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("BanId")
- .HasColumnType("integer")
- .HasColumnName("ban_id");
-
- b.Property("ConnectionId")
- .HasColumnType("integer")
- .HasColumnName("connection_id");
-
- b.HasKey("Id")
- .HasName("PK_server_ban_hit");
-
- b.HasIndex("BanId")
- .HasDatabaseName("IX_server_ban_hit_ban_id");
-
- b.HasIndex("ConnectionId")
- .HasDatabaseName("IX_server_ban_hit_connection_id");
-
- b.ToTable("server_ban_hit", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.ServerRoleBan", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("server_role_ban_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("Address")
- .HasColumnType("inet")
- .HasColumnName("address");
-
- b.Property("BanTime")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("ban_time");
-
- b.Property("BanningAdmin")
- .HasColumnType("uuid")
- .HasColumnName("banning_admin");
-
- b.Property("ExpirationTime")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("expiration_time");
-
- b.Property("HWId")
- .HasColumnType("bytea")
- .HasColumnName("hwid");
-
- b.Property("Hidden")
- .HasColumnType("boolean")
- .HasColumnName("hidden");
-
- b.Property("LastEditedAt")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("last_edited_at");
-
- b.Property("LastEditedById")
- .HasColumnType("uuid")
- .HasColumnName("last_edited_by_id");
-
- b.Property("PlayerUserId")
- .HasColumnType("uuid")
- .HasColumnName("player_user_id");
-
- b.Property("PlaytimeAtNote")
- .HasColumnType("interval")
- .HasColumnName("playtime_at_note");
-
- b.Property("Reason")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("reason");
-
- b.Property("RoleId")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("role_id");
-
- b.Property("RoundId")
- .HasColumnType("integer")
- .HasColumnName("round_id");
-
- b.Property("Severity")
- .HasColumnType("integer")
- .HasColumnName("severity");
-
- b.HasKey("Id")
- .HasName("PK_server_role_ban");
-
- b.HasIndex("Address");
-
- b.HasIndex("BanningAdmin");
-
- b.HasIndex("LastEditedById");
-
- b.HasIndex("PlayerUserId")
- .HasDatabaseName("IX_server_role_ban_player_user_id");
-
- b.HasIndex("RoundId")
- .HasDatabaseName("IX_server_role_ban_round_id");
-
- b.ToTable("server_role_ban", null, t =>
- {
- t.HasCheckConstraint("AddressNotIPv6MappedIPv4", "NOT inet '::ffff:0.0.0.0/96' >>= address");
-
- t.HasCheckConstraint("HaveEitherAddressOrUserIdOrHWId", "address IS NOT NULL OR player_user_id IS NOT NULL OR hwid IS NOT NULL");
- });
- });
-
- modelBuilder.Entity("Content.Server.Database.ServerRoleUnban", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("role_unban_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("BanId")
- .HasColumnType("integer")
- .HasColumnName("ban_id");
-
- b.Property("UnbanTime")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("unban_time");
-
- b.Property("UnbanningAdmin")
- .HasColumnType("uuid")
- .HasColumnName("unbanning_admin");
-
- b.HasKey("Id")
- .HasName("PK_server_role_unban");
-
- b.HasIndex("BanId")
- .IsUnique();
-
- b.ToTable("server_role_unban", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.ServerUnban", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("unban_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("BanId")
- .HasColumnType("integer")
- .HasColumnName("ban_id");
-
- b.Property("UnbanTime")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("unban_time");
-
- b.Property("UnbanningAdmin")
- .HasColumnType("uuid")
- .HasColumnName("unbanning_admin");
-
- b.HasKey("Id")
- .HasName("PK_server_unban");
-
- b.HasIndex("BanId")
- .IsUnique();
-
- b.ToTable("server_unban", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.Trait", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("trait_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("ProfileId")
- .HasColumnType("integer")
- .HasColumnName("profile_id");
-
- b.Property("TraitName")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("trait_name");
-
- b.HasKey("Id")
- .HasName("PK_trait");
-
- b.HasIndex("ProfileId", "TraitName")
- .IsUnique();
-
- b.ToTable("trait", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.UploadedResourceLog", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("uploaded_resource_log_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("Data")
- .IsRequired()
- .HasColumnType("bytea")
- .HasColumnName("data");
-
- b.Property("Date")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("date");
-
- b.Property("Path")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("path");
-
- b.Property("UserId")
- .HasColumnType("uuid")
- .HasColumnName("user_id");
-
- b.HasKey("Id")
- .HasName("PK_uploaded_resource_log");
-
- b.ToTable("uploaded_resource_log", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.Whitelist", b =>
- {
- b.Property("UserId")
- .ValueGeneratedOnAdd()
- .HasColumnType("uuid")
- .HasColumnName("user_id");
-
- b.HasKey("UserId")
- .HasName("PK_whitelist");
-
- b.ToTable("whitelist", (string)null);
- });
-
- modelBuilder.Entity("PlayerRound", b =>
- {
- b.Property("PlayersId")
- .HasColumnType("integer")
- .HasColumnName("players_id");
-
- b.Property("RoundsId")
- .HasColumnType("integer")
- .HasColumnName("rounds_id");
-
- b.HasKey("PlayersId", "RoundsId")
- .HasName("PK_player_round");
-
- b.HasIndex("RoundsId")
- .HasDatabaseName("IX_player_round_rounds_id");
-
- b.ToTable("player_round", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.Admin", b =>
- {
- b.HasOne("Content.Server.Database.AdminRank", "AdminRank")
- .WithMany("Admins")
- .HasForeignKey("AdminRankId")
- .OnDelete(DeleteBehavior.SetNull)
- .HasConstraintName("FK_admin_admin_rank_admin_rank_id");
-
- b.Navigation("AdminRank");
- });
-
- modelBuilder.Entity("Content.Server.Database.AdminFlag", b =>
- {
- b.HasOne("Content.Server.Database.Admin", "Admin")
- .WithMany("Flags")
- .HasForeignKey("AdminId")
- .OnDelete(DeleteBehavior.Cascade)
- .IsRequired()
- .HasConstraintName("FK_admin_flag_admin_admin_id");
-
- b.Navigation("Admin");
- });
-
- modelBuilder.Entity("Content.Server.Database.AdminLog", b =>
- {
- b.HasOne("Content.Server.Database.Round", "Round")
- .WithMany("AdminLogs")
- .HasForeignKey("RoundId")
- .OnDelete(DeleteBehavior.Cascade)
- .IsRequired()
- .HasConstraintName("FK_admin_log_round_round_id");
-
- b.Navigation("Round");
- });
-
- modelBuilder.Entity("Content.Server.Database.AdminLogPlayer", b =>
- {
- b.HasOne("Content.Server.Database.Player", "Player")
- .WithMany("AdminLogs")
- .HasForeignKey("PlayerUserId")
- .HasPrincipalKey("UserId")
- .OnDelete(DeleteBehavior.Cascade)
- .IsRequired()
- .HasConstraintName("FK_admin_log_player_player_player_user_id");
-
- b.HasOne("Content.Server.Database.AdminLog", "Log")
- .WithMany("Players")
- .HasForeignKey("RoundId", "LogId")
- .OnDelete(DeleteBehavior.Cascade)
- .IsRequired()
- .HasConstraintName("FK_admin_log_player_admin_log_round_id_log_id");
-
- b.Navigation("Log");
-
- b.Navigation("Player");
- });
-
- modelBuilder.Entity("Content.Server.Database.AdminMessage", b =>
- {
- b.HasOne("Content.Server.Database.Player", "CreatedBy")
- .WithMany("AdminMessagesCreated")
- .HasForeignKey("CreatedById")
- .HasPrincipalKey("UserId")
- .OnDelete(DeleteBehavior.SetNull)
- .HasConstraintName("FK_admin_messages_player_created_by_id");
-
- b.HasOne("Content.Server.Database.Player", "DeletedBy")
- .WithMany("AdminMessagesDeleted")
- .HasForeignKey("DeletedById")
- .HasPrincipalKey("UserId")
- .OnDelete(DeleteBehavior.SetNull)
- .HasConstraintName("FK_admin_messages_player_deleted_by_id");
-
- b.HasOne("Content.Server.Database.Player", "LastEditedBy")
- .WithMany("AdminMessagesLastEdited")
- .HasForeignKey("LastEditedById")
- .HasPrincipalKey("UserId")
- .OnDelete(DeleteBehavior.SetNull)
- .HasConstraintName("FK_admin_messages_player_last_edited_by_id");
-
- b.HasOne("Content.Server.Database.Player", "Player")
- .WithMany("AdminMessagesReceived")
- .HasForeignKey("PlayerUserId")
- .HasPrincipalKey("UserId")
- .OnDelete(DeleteBehavior.Cascade)
- .HasConstraintName("FK_admin_messages_player_player_user_id");
-
- b.HasOne("Content.Server.Database.Round", "Round")
- .WithMany()
- .HasForeignKey("RoundId")
- .HasConstraintName("FK_admin_messages_round_round_id");
-
- b.Navigation("CreatedBy");
-
- b.Navigation("DeletedBy");
-
- b.Navigation("LastEditedBy");
-
- b.Navigation("Player");
-
- b.Navigation("Round");
- });
-
- modelBuilder.Entity("Content.Server.Database.AdminNote", b =>
- {
- b.HasOne("Content.Server.Database.Player", "CreatedBy")
- .WithMany("AdminNotesCreated")
- .HasForeignKey("CreatedById")
- .HasPrincipalKey("UserId")
- .OnDelete(DeleteBehavior.SetNull)
- .HasConstraintName("FK_admin_notes_player_created_by_id");
-
- b.HasOne("Content.Server.Database.Player", "DeletedBy")
- .WithMany("AdminNotesDeleted")
- .HasForeignKey("DeletedById")
- .HasPrincipalKey("UserId")
- .OnDelete(DeleteBehavior.SetNull)
- .HasConstraintName("FK_admin_notes_player_deleted_by_id");
-
- b.HasOne("Content.Server.Database.Player", "LastEditedBy")
- .WithMany("AdminNotesLastEdited")
- .HasForeignKey("LastEditedById")
- .HasPrincipalKey("UserId")
- .OnDelete(DeleteBehavior.SetNull)
- .HasConstraintName("FK_admin_notes_player_last_edited_by_id");
-
- b.HasOne("Content.Server.Database.Player", "Player")
- .WithMany("AdminNotesReceived")
- .HasForeignKey("PlayerUserId")
- .HasPrincipalKey("UserId")
- .OnDelete(DeleteBehavior.Cascade)
- .HasConstraintName("FK_admin_notes_player_player_user_id");
-
- b.HasOne("Content.Server.Database.Round", "Round")
- .WithMany()
- .HasForeignKey("RoundId")
- .HasConstraintName("FK_admin_notes_round_round_id");
-
- b.Navigation("CreatedBy");
-
- b.Navigation("DeletedBy");
-
- b.Navigation("LastEditedBy");
-
- b.Navigation("Player");
-
- b.Navigation("Round");
- });
-
- modelBuilder.Entity("Content.Server.Database.AdminRankFlag", b =>
- {
- b.HasOne("Content.Server.Database.AdminRank", "Rank")
- .WithMany("Flags")
- .HasForeignKey("AdminRankId")
- .OnDelete(DeleteBehavior.Cascade)
- .IsRequired()
- .HasConstraintName("FK_admin_rank_flag_admin_rank_admin_rank_id");
-
- b.Navigation("Rank");
- });
-
- modelBuilder.Entity("Content.Server.Database.AdminWatchlist", b =>
- {
- b.HasOne("Content.Server.Database.Player", "CreatedBy")
- .WithMany("AdminWatchlistsCreated")
- .HasForeignKey("CreatedById")
- .HasPrincipalKey("UserId")
- .OnDelete(DeleteBehavior.SetNull)
- .HasConstraintName("FK_admin_watchlists_player_created_by_id");
-
- b.HasOne("Content.Server.Database.Player", "DeletedBy")
- .WithMany("AdminWatchlistsDeleted")
- .HasForeignKey("DeletedById")
- .HasPrincipalKey("UserId")
- .OnDelete(DeleteBehavior.SetNull)
- .HasConstraintName("FK_admin_watchlists_player_deleted_by_id");
-
- b.HasOne("Content.Server.Database.Player", "LastEditedBy")
- .WithMany("AdminWatchlistsLastEdited")
- .HasForeignKey("LastEditedById")
- .HasPrincipalKey("UserId")
- .OnDelete(DeleteBehavior.SetNull)
- .HasConstraintName("FK_admin_watchlists_player_last_edited_by_id");
-
- b.HasOne("Content.Server.Database.Player", "Player")
- .WithMany("AdminWatchlistsReceived")
- .HasForeignKey("PlayerUserId")
- .HasPrincipalKey("UserId")
- .OnDelete(DeleteBehavior.Cascade)
- .HasConstraintName("FK_admin_watchlists_player_player_user_id");
-
- b.HasOne("Content.Server.Database.Round", "Round")
- .WithMany()
- .HasForeignKey("RoundId")
- .HasConstraintName("FK_admin_watchlists_round_round_id");
-
- b.Navigation("CreatedBy");
-
- b.Navigation("DeletedBy");
-
- b.Navigation("LastEditedBy");
-
- b.Navigation("Player");
-
- b.Navigation("Round");
- });
-
- modelBuilder.Entity("Content.Server.Database.Antag", b =>
- {
- b.HasOne("Content.Server.Database.Profile", "Profile")
- .WithMany("Antags")
- .HasForeignKey("ProfileId")
- .OnDelete(DeleteBehavior.Cascade)
- .IsRequired()
- .HasConstraintName("FK_antag_profile_profile_id");
-
- b.Navigation("Profile");
- });
-
- modelBuilder.Entity("Content.Server.Database.ConnectionLog", b =>
- {
- b.HasOne("Content.Server.Database.Server", "Server")
- .WithMany("ConnectionLogs")
- .HasForeignKey("ServerId")
- .OnDelete(DeleteBehavior.SetNull)
- .IsRequired()
- .HasConstraintName("FK_connection_log_server_server_id");
-
- b.Navigation("Server");
- });
-
- modelBuilder.Entity("Content.Server.Database.Job", b =>
- {
- b.HasOne("Content.Server.Database.Profile", "Profile")
- .WithMany("Jobs")
- .HasForeignKey("ProfileId")
- .OnDelete(DeleteBehavior.Cascade)
- .IsRequired()
- .HasConstraintName("FK_job_profile_profile_id");
-
- b.Navigation("Profile");
- });
-
- modelBuilder.Entity("Content.Server.Database.Profile", b =>
- {
- b.HasOne("Content.Server.Database.Preference", "Preference")
- .WithMany("Profiles")
- .HasForeignKey("PreferenceId")
- .OnDelete(DeleteBehavior.Cascade)
- .IsRequired()
- .HasConstraintName("FK_profile_preference_preference_id");
-
- b.Navigation("Preference");
- });
-
- modelBuilder.Entity("Content.Server.Database.ProfileLoadout", b =>
- {
- b.HasOne("Content.Server.Database.ProfileLoadoutGroup", "ProfileLoadoutGroup")
- .WithMany("Loadouts")
- .HasForeignKey("ProfileLoadoutGroupId")
- .OnDelete(DeleteBehavior.Cascade)
- .IsRequired()
- .HasConstraintName("FK_profile_loadout_profile_loadout_group_profile_loadout_group~");
-
- b.Navigation("ProfileLoadoutGroup");
- });
-
- modelBuilder.Entity("Content.Server.Database.ProfileLoadoutGroup", b =>
- {
- b.HasOne("Content.Server.Database.ProfileRoleLoadout", "ProfileRoleLoadout")
- .WithMany("Groups")
- .HasForeignKey("ProfileRoleLoadoutId")
- .OnDelete(DeleteBehavior.Cascade)
- .IsRequired()
- .HasConstraintName("FK_profile_loadout_group_profile_role_loadout_profile_role_loa~");
-
- b.Navigation("ProfileRoleLoadout");
- });
-
- modelBuilder.Entity("Content.Server.Database.ProfileRoleLoadout", b =>
- {
- b.HasOne("Content.Server.Database.Profile", "Profile")
- .WithMany("Loadouts")
- .HasForeignKey("ProfileId")
- .OnDelete(DeleteBehavior.Cascade)
- .IsRequired()
- .HasConstraintName("FK_profile_role_loadout_profile_profile_id");
-
- b.Navigation("Profile");
- });
-
- modelBuilder.Entity("Content.Server.Database.RoleWhitelist", b =>
- {
- b.HasOne("Content.Server.Database.Player", "Player")
- .WithMany("JobWhitelists")
- .HasForeignKey("PlayerUserId")
- .HasPrincipalKey("UserId")
- .OnDelete(DeleteBehavior.Cascade)
- .IsRequired()
- .HasConstraintName("FK_role_whitelists_player_player_user_id");
-
- b.Navigation("Player");
- });
-
- modelBuilder.Entity("Content.Server.Database.Round", b =>
- {
- b.HasOne("Content.Server.Database.Server", "Server")
- .WithMany("Rounds")
- .HasForeignKey("ServerId")
- .OnDelete(DeleteBehavior.Cascade)
- .IsRequired()
- .HasConstraintName("FK_round_server_server_id");
-
- b.Navigation("Server");
- });
-
- modelBuilder.Entity("Content.Server.Database.ServerBan", b =>
- {
- b.HasOne("Content.Server.Database.Player", "CreatedBy")
- .WithMany("AdminServerBansCreated")
- .HasForeignKey("BanningAdmin")
- .HasPrincipalKey("UserId")
- .OnDelete(DeleteBehavior.SetNull)
- .HasConstraintName("FK_server_ban_player_banning_admin");
-
- b.HasOne("Content.Server.Database.Player", "LastEditedBy")
- .WithMany("AdminServerBansLastEdited")
- .HasForeignKey("LastEditedById")
- .HasPrincipalKey("UserId")
- .OnDelete(DeleteBehavior.SetNull)
- .HasConstraintName("FK_server_ban_player_last_edited_by_id");
-
- b.HasOne("Content.Server.Database.Round", "Round")
- .WithMany()
- .HasForeignKey("RoundId")
- .HasConstraintName("FK_server_ban_round_round_id");
-
- b.Navigation("CreatedBy");
-
- b.Navigation("LastEditedBy");
-
- b.Navigation("Round");
- });
-
- modelBuilder.Entity("Content.Server.Database.ServerBanHit", b =>
- {
- b.HasOne("Content.Server.Database.ServerBan", "Ban")
- .WithMany("BanHits")
- .HasForeignKey("BanId")
- .OnDelete(DeleteBehavior.Cascade)
- .IsRequired()
- .HasConstraintName("FK_server_ban_hit_server_ban_ban_id");
-
- b.HasOne("Content.Server.Database.ConnectionLog", "Connection")
- .WithMany("BanHits")
- .HasForeignKey("ConnectionId")
- .OnDelete(DeleteBehavior.Cascade)
- .IsRequired()
- .HasConstraintName("FK_server_ban_hit_connection_log_connection_id");
-
- b.Navigation("Ban");
-
- b.Navigation("Connection");
- });
-
- modelBuilder.Entity("Content.Server.Database.ServerRoleBan", b =>
- {
- b.HasOne("Content.Server.Database.Player", "CreatedBy")
- .WithMany("AdminServerRoleBansCreated")
- .HasForeignKey("BanningAdmin")
- .HasPrincipalKey("UserId")
- .OnDelete(DeleteBehavior.SetNull)
- .HasConstraintName("FK_server_role_ban_player_banning_admin");
-
- b.HasOne("Content.Server.Database.Player", "LastEditedBy")
- .WithMany("AdminServerRoleBansLastEdited")
- .HasForeignKey("LastEditedById")
- .HasPrincipalKey("UserId")
- .OnDelete(DeleteBehavior.SetNull)
- .HasConstraintName("FK_server_role_ban_player_last_edited_by_id");
-
- b.HasOne("Content.Server.Database.Round", "Round")
- .WithMany()
- .HasForeignKey("RoundId")
- .HasConstraintName("FK_server_role_ban_round_round_id");
-
- b.Navigation("CreatedBy");
-
- b.Navigation("LastEditedBy");
-
- b.Navigation("Round");
- });
-
- modelBuilder.Entity("Content.Server.Database.ServerRoleUnban", b =>
- {
- b.HasOne("Content.Server.Database.ServerRoleBan", "Ban")
- .WithOne("Unban")
- .HasForeignKey("Content.Server.Database.ServerRoleUnban", "BanId")
- .OnDelete(DeleteBehavior.Cascade)
- .IsRequired()
- .HasConstraintName("FK_server_role_unban_server_role_ban_ban_id");
-
- b.Navigation("Ban");
- });
-
- modelBuilder.Entity("Content.Server.Database.ServerUnban", b =>
- {
- b.HasOne("Content.Server.Database.ServerBan", "Ban")
- .WithOne("Unban")
- .HasForeignKey("Content.Server.Database.ServerUnban", "BanId")
- .OnDelete(DeleteBehavior.Cascade)
- .IsRequired()
- .HasConstraintName("FK_server_unban_server_ban_ban_id");
-
- b.Navigation("Ban");
- });
-
- modelBuilder.Entity("Content.Server.Database.Trait", b =>
- {
- b.HasOne("Content.Server.Database.Profile", "Profile")
- .WithMany("Traits")
- .HasForeignKey("ProfileId")
- .OnDelete(DeleteBehavior.Cascade)
- .IsRequired()
- .HasConstraintName("FK_trait_profile_profile_id");
-
- b.Navigation("Profile");
- });
-
- modelBuilder.Entity("PlayerRound", b =>
- {
- b.HasOne("Content.Server.Database.Player", null)
- .WithMany()
- .HasForeignKey("PlayersId")
- .OnDelete(DeleteBehavior.Cascade)
- .IsRequired()
- .HasConstraintName("FK_player_round_player_players_id");
-
- b.HasOne("Content.Server.Database.Round", null)
- .WithMany()
- .HasForeignKey("RoundsId")
- .OnDelete(DeleteBehavior.Cascade)
- .IsRequired()
- .HasConstraintName("FK_player_round_round_rounds_id");
- });
-
- modelBuilder.Entity("Content.Server.Database.Admin", b =>
- {
- b.Navigation("Flags");
- });
-
- modelBuilder.Entity("Content.Server.Database.AdminLog", b =>
- {
- b.Navigation("Players");
- });
-
- modelBuilder.Entity("Content.Server.Database.AdminRank", b =>
- {
- b.Navigation("Admins");
-
- b.Navigation("Flags");
- });
-
- modelBuilder.Entity("Content.Server.Database.ConnectionLog", b =>
- {
- b.Navigation("BanHits");
- });
-
- modelBuilder.Entity("Content.Server.Database.Player", b =>
- {
- b.Navigation("AdminLogs");
-
- b.Navigation("AdminMessagesCreated");
-
- b.Navigation("AdminMessagesDeleted");
-
- b.Navigation("AdminMessagesLastEdited");
-
- b.Navigation("AdminMessagesReceived");
-
- b.Navigation("AdminNotesCreated");
-
- b.Navigation("AdminNotesDeleted");
-
- b.Navigation("AdminNotesLastEdited");
-
- b.Navigation("AdminNotesReceived");
-
- b.Navigation("AdminServerBansCreated");
-
- b.Navigation("AdminServerBansLastEdited");
-
- b.Navigation("AdminServerRoleBansCreated");
-
- b.Navigation("AdminServerRoleBansLastEdited");
-
- b.Navigation("AdminWatchlistsCreated");
-
- b.Navigation("AdminWatchlistsDeleted");
-
- b.Navigation("AdminWatchlistsLastEdited");
-
- b.Navigation("AdminWatchlistsReceived");
-
- b.Navigation("JobWhitelists");
- });
-
- modelBuilder.Entity("Content.Server.Database.Preference", b =>
- {
- b.Navigation("Profiles");
- });
-
- modelBuilder.Entity("Content.Server.Database.Profile", b =>
- {
- b.Navigation("Antags");
-
- b.Navigation("Jobs");
-
- b.Navigation("Loadouts");
-
- b.Navigation("Traits");
- });
-
- modelBuilder.Entity("Content.Server.Database.ProfileLoadoutGroup", b =>
- {
- b.Navigation("Loadouts");
- });
-
- modelBuilder.Entity("Content.Server.Database.ProfileRoleLoadout", b =>
- {
- b.Navigation("Groups");
- });
-
- modelBuilder.Entity("Content.Server.Database.Round", b =>
- {
- b.Navigation("AdminLogs");
- });
-
- modelBuilder.Entity("Content.Server.Database.Server", b =>
- {
- b.Navigation("ConnectionLogs");
-
- b.Navigation("Rounds");
- });
-
- modelBuilder.Entity("Content.Server.Database.ServerBan", b =>
- {
- b.Navigation("BanHits");
-
- b.Navigation("Unban");
- });
-
- modelBuilder.Entity("Content.Server.Database.ServerRoleBan", b =>
- {
- b.Navigation("Unban");
- });
-#pragma warning restore 612, 618
- }
- }
-}
diff --git a/Content.Server.Database/Migrations/Postgres/20240606175154_ReturnLastReadRules.cs b/Content.Server.Database/Migrations/Postgres/20240606175154_ReturnLastReadRules.cs
deleted file mode 100644
index af4e5ad4c40..00000000000
--- a/Content.Server.Database/Migrations/Postgres/20240606175154_ReturnLastReadRules.cs
+++ /dev/null
@@ -1,29 +0,0 @@
-using System;
-using Microsoft.EntityFrameworkCore.Migrations;
-
-#nullable disable
-
-namespace Content.Server.Database.Migrations.Postgres
-{
- ///
- public partial class ReturnLastReadRules : Migration
- {
- ///
- protected override void Up(MigrationBuilder migrationBuilder)
- {
- migrationBuilder.AddColumn(
- name: "last_read_rules",
- table: "player",
- type: "timestamp with time zone",
- nullable: true);
- }
-
- ///
- protected override void Down(MigrationBuilder migrationBuilder)
- {
- migrationBuilder.DropColumn(
- name: "last_read_rules",
- table: "player");
- }
- }
-}
diff --git a/Content.Server.Database/Migrations/Postgres/20240623005121_BanTemplate.Designer.cs b/Content.Server.Database/Migrations/Postgres/20240623005121_BanTemplate.Designer.cs
deleted file mode 100644
index 5d89f3dd29b..00000000000
--- a/Content.Server.Database/Migrations/Postgres/20240623005121_BanTemplate.Designer.cs
+++ /dev/null
@@ -1,1960 +0,0 @@
-//
-using System;
-using System.Net;
-using System.Text.Json;
-using Content.Server.Database;
-using Microsoft.EntityFrameworkCore;
-using Microsoft.EntityFrameworkCore.Infrastructure;
-using Microsoft.EntityFrameworkCore.Migrations;
-using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
-using Npgsql.EntityFrameworkCore.PostgreSQL.Metadata;
-using NpgsqlTypes;
-
-#nullable disable
-
-namespace Content.Server.Database.Migrations.Postgres
-{
- [DbContext(typeof(PostgresServerDbContext))]
- [Migration("20240623005121_BanTemplate")]
- partial class BanTemplate
- {
- ///
- protected override void BuildTargetModel(ModelBuilder modelBuilder)
- {
-#pragma warning disable 612, 618
- modelBuilder
- .HasAnnotation("ProductVersion", "8.0.0")
- .HasAnnotation("Relational:MaxIdentifierLength", 63);
-
- NpgsqlModelBuilderExtensions.UseIdentityByDefaultColumns(modelBuilder);
-
- modelBuilder.Entity("Content.Server.Database.Admin", b =>
- {
- b.Property("UserId")
- .ValueGeneratedOnAdd()
- .HasColumnType("uuid")
- .HasColumnName("user_id");
-
- b.Property("AdminRankId")
- .HasColumnType("integer")
- .HasColumnName("admin_rank_id");
-
- b.Property("Title")
- .HasColumnType("text")
- .HasColumnName("title");
-
- b.HasKey("UserId")
- .HasName("PK_admin");
-
- b.HasIndex("AdminRankId")
- .HasDatabaseName("IX_admin_admin_rank_id");
-
- b.ToTable("admin", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.AdminFlag", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("admin_flag_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("AdminId")
- .HasColumnType("uuid")
- .HasColumnName("admin_id");
-
- b.Property("Flag")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("flag");
-
- b.Property("Negative")
- .HasColumnType("boolean")
- .HasColumnName("negative");
-
- b.HasKey("Id")
- .HasName("PK_admin_flag");
-
- b.HasIndex("AdminId")
- .HasDatabaseName("IX_admin_flag_admin_id");
-
- b.HasIndex("Flag", "AdminId")
- .IsUnique();
-
- b.ToTable("admin_flag", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.AdminLog", b =>
- {
- b.Property("RoundId")
- .HasColumnType("integer")
- .HasColumnName("round_id");
-
- b.Property("Id")
- .HasColumnType("integer")
- .HasColumnName("admin_log_id");
-
- b.Property("Date")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("date");
-
- b.Property("Impact")
- .HasColumnType("smallint")
- .HasColumnName("impact");
-
- b.Property("Json")
- .IsRequired()
- .HasColumnType("jsonb")
- .HasColumnName("json");
-
- b.Property("Message")
- .IsRequired()
- .HasColumnType("text")
- .HasColumnName("message");
-
- b.Property("Type")
- .HasColumnType("integer")
- .HasColumnName("type");
-
- b.HasKey("RoundId", "Id")
- .HasName("PK_admin_log");
-
- b.HasIndex("Date");
-
- b.HasIndex("Message")
- .HasAnnotation("Npgsql:TsVectorConfig", "english");
-
- NpgsqlIndexBuilderExtensions.HasMethod(b.HasIndex("Message"), "GIN");
-
- b.HasIndex("Type")
- .HasDatabaseName("IX_admin_log_type");
-
- b.ToTable("admin_log", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.AdminLogPlayer", b =>
- {
- b.Property("RoundId")
- .HasColumnType("integer")
- .HasColumnName("round_id");
-
- b.Property("LogId")
- .HasColumnType("integer")
- .HasColumnName("log_id");
-
- b.Property("PlayerUserId")
- .HasColumnType("uuid")
- .HasColumnName("player_user_id");
-
- b.HasKey("RoundId", "LogId", "PlayerUserId")
- .HasName("PK_admin_log_player");
-
- b.HasIndex("PlayerUserId")
- .HasDatabaseName("IX_admin_log_player_player_user_id");
-
- b.ToTable("admin_log_player", (string)null);
- });
-
- modelBuilder.Entity("Content.Server.Database.AdminMessage", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("admin_messages_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("CreatedAt")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("created_at");
-
- b.Property("CreatedById")
- .HasColumnType("uuid")
- .HasColumnName("created_by_id");
-
- b.Property("Deleted")
- .HasColumnType("boolean")
- .HasColumnName("deleted");
-
- b.Property("DeletedAt")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("deleted_at");
-
- b.Property("DeletedById")
- .HasColumnType("uuid")
- .HasColumnName("deleted_by_id");
-
- b.Property("Dismissed")
- .HasColumnType("boolean")
- .HasColumnName("dismissed");
-
- b.Property("ExpirationTime")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("expiration_time");
-
- b.Property("LastEditedAt")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("last_edited_at");
-
- b.Property("LastEditedById")
- .HasColumnType("uuid")
- .HasColumnName("last_edited_by_id");
-
- b.Property("Message")
- .IsRequired()
- .HasMaxLength(4096)
- .HasColumnType("character varying(4096)")
- .HasColumnName("message");
-
- b.Property("PlayerUserId")
- .HasColumnType("uuid")
- .HasColumnName("player_user_id");
-
- b.Property("PlaytimeAtNote")
- .HasColumnType("interval")
- .HasColumnName("playtime_at_note");
-
- b.Property("RoundId")
- .HasColumnType("integer")
- .HasColumnName("round_id");
-
- b.Property("Seen")
- .HasColumnType("boolean")
- .HasColumnName("seen");
-
- b.HasKey("Id")
- .HasName("PK_admin_messages");
-
- b.HasIndex("CreatedById");
-
- b.HasIndex("DeletedById");
-
- b.HasIndex("LastEditedById");
-
- b.HasIndex("PlayerUserId")
- .HasDatabaseName("IX_admin_messages_player_user_id");
-
- b.HasIndex("RoundId")
- .HasDatabaseName("IX_admin_messages_round_id");
-
- b.ToTable("admin_messages", null, t =>
- {
- t.HasCheckConstraint("NotDismissedAndSeen", "NOT dismissed OR seen");
- });
- });
-
- modelBuilder.Entity("Content.Server.Database.AdminNote", b =>
- {
- b.Property("Id")
- .ValueGeneratedOnAdd()
- .HasColumnType("integer")
- .HasColumnName("admin_notes_id");
-
- NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id"));
-
- b.Property("CreatedAt")
- .HasColumnType("timestamp with time zone")
- .HasColumnName("created_at");
-
- b.Property("CreatedById")
- .HasColumnType("uuid")
- .HasColumnName("created_by_id");
-
- b.Property("Deleted")
- .HasColumnType("boolean")
- .HasColumnName("deleted");
-
- b.Property