From e8e2c32bc758bec9e3da00e89a9345c8fe39db04 Mon Sep 17 00:00:00 2001 From: JerryImMouse Date: Wed, 7 Aug 2024 14:19:27 +0500 Subject: [PATCH] get back traits --- .../Postgres/20200929113117_Init.cs | 6 - .../20220816163319_Traits.Designer.cs | 1066 +++++++++++++++++ .../Postgres/20220816163319_Traits.cs | 44 + 3 files changed, 1110 insertions(+), 6 deletions(-) create mode 100644 Content.Server.Database/Migrations/Postgres/20220816163319_Traits.Designer.cs create mode 100644 Content.Server.Database/Migrations/Postgres/20220816163319_Traits.cs diff --git a/Content.Server.Database/Migrations/Postgres/20200929113117_Init.cs b/Content.Server.Database/Migrations/Postgres/20200929113117_Init.cs index eea30ffa1ce..34e7206af76 100644 --- a/Content.Server.Database/Migrations/Postgres/20200929113117_Init.cs +++ b/Content.Server.Database/Migrations/Postgres/20200929113117_Init.cs @@ -218,12 +218,6 @@ protected override void Up(MigrationBuilder migrationBuilder) column: "user_id", unique: true); - migrationBuilder.CreateIndex( - name: "IX_preference_user_id", - table: "preference", - column: "user_id", - unique: true); - migrationBuilder.CreateIndex( name: "IX_profile_preference_id", table: "profile", diff --git a/Content.Server.Database/Migrations/Postgres/20220816163319_Traits.Designer.cs b/Content.Server.Database/Migrations/Postgres/20220816163319_Traits.Designer.cs new file mode 100644 index 00000000000..1d911981142 --- /dev/null +++ b/Content.Server.Database/Migrations/Postgres/20220816163319_Traits.Designer.cs @@ -0,0 +1,1066 @@ +// +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; + +#nullable disable + +namespace Content.Server.Database.Migrations.Postgres +{ + [DbContext(typeof(PostgresServerDbContext))] + [Migration("20220816163319_Traits")] + partial class Traits + { + protected override void BuildTargetModel(ModelBuilder modelBuilder) + { +#pragma warning disable 612, 618 + modelBuilder + .HasAnnotation("ProductVersion", "6.0.5") + .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("Id") + .ValueGeneratedOnAdd() + .HasColumnType("integer") + .HasColumnName("admin_log_id"); + NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Id")); + b.Property("RoundId") + .HasColumnType("integer") + .HasColumnName("round_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("Id", "RoundId") + .HasName("PK_admin_log"); + b.HasIndex("Date"); + b.HasIndex("Message") + .HasAnnotation("Npgsql:TsVectorConfig", "english"); + NpgsqlIndexBuilderExtensions.HasMethod(b.HasIndex("Message"), "GIN"); + b.HasIndex("RoundId") + .HasDatabaseName("IX_admin_log_round_id"); + b.HasIndex("Type") + .HasDatabaseName("IX_admin_log_type"); + b.ToTable("admin_log", (string)null); + }); + + modelBuilder.Entity("Content.Server.Database.AdminLogEntity", b => + { + b.Property("Uid") + .ValueGeneratedOnAdd() + .HasColumnType("integer") + .HasColumnName("uid"); + NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property("Uid")); + b.Property("AdminLogId") + .HasColumnType("integer") + .HasColumnName("admin_log_id"); + b.Property("AdminLogRoundId") + .HasColumnType("integer") + .HasColumnName("admin_log_round_id"); + b.Property("Name") + .HasColumnType("text") + .HasColumnName("name"); + b.HasKey("Uid") + .HasName("PK_admin_log_entity"); + b.HasIndex("AdminLogId", "AdminLogRoundId") + .HasDatabaseName("IX_admin_log_entity_admin_log_id_admin_log_round_id"); + b.ToTable("admin_log_entity", (string)null); + }); + + modelBuilder.Entity("Content.Server.Database.AdminLogPlayer", b => + { + b.Property("PlayerUserId") + .HasColumnType("uuid") + .HasColumnName("player_user_id"); + b.Property("LogId") + .HasColumnType("integer") + .HasColumnName("log_id"); + b.Property("RoundId") + .HasColumnType("integer") + .HasColumnName("round_id"); + b.HasKey("PlayerUserId", "LogId", "RoundId") + .HasName("PK_admin_log_player"); + b.HasIndex("LogId", "RoundId"); + b.ToTable("admin_log_player", (string)null); + }); + + 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("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("RoundId") + .HasColumnType("integer") + .HasColumnName("round_id"); + b.Property("ShownToPlayer") + .HasColumnType("boolean") + .HasColumnName("shown_to_player"); + 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") + .HasDatabaseName("IX_admin_rank_flag_admin_rank_id"); + b.HasIndex("Flag", "AdminRankId") + .IsUnique(); + b.ToTable("admin_rank_flag", (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("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("UserId"); + b.ToTable("connection_log", (string)null); + b.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") + .HasDatabaseName("IX_job_profile_id"); + 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.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", (string)null); + b.HasCheckConstraint("LastSeenAddressNotIPv6MappedIPv4", "NOT inet '::ffff:0.0.0.0/96' >>= last_seen_address"); + }); + + 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.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("Backpack") + .IsRequired() + .HasColumnType("text") + .HasColumnName("backpack"); + b.Property("CharacterName") + .IsRequired() + .HasColumnType("text") + .HasColumnName("char_name"); + b.Property("Clothing") + .IsRequired() + .HasColumnType("text") + .HasColumnName("clothing"); + 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("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.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.HasKey("Id") + .HasName("PK_round"); + b.HasIndex("ServerId") + .HasDatabaseName("IX_round_server_id"); + 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("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("Reason") + .IsRequired() + .HasColumnType("text") + .HasColumnName("reason"); + b.Property("UserId") + .HasColumnType("uuid") + .HasColumnName("user_id"); + b.HasKey("Id") + .HasName("PK_server_ban"); + b.HasIndex("Address"); + b.HasIndex("UserId"); + b.ToTable("server_ban", (string)null); + b.HasCheckConstraint("AddressNotIPv6MappedIPv4", "NOT inet '::ffff:0.0.0.0/96' >>= address"); + b.HasCheckConstraint("HaveEitherAddressOrUserIdOrHWId", "address IS NOT NULL OR user_id IS NOT NULL OR hwid IS NOT NULL"); + }); + + 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("Reason") + .IsRequired() + .HasColumnType("text") + .HasColumnName("reason"); + b.Property("RoleId") + .IsRequired() + .HasColumnType("text") + .HasColumnName("role_id"); + b.Property("UserId") + .HasColumnType("uuid") + .HasColumnName("user_id"); + b.HasKey("Id") + .HasName("PK_server_role_ban"); + b.HasIndex("Address"); + b.HasIndex("UserId"); + b.ToTable("server_role_ban", (string)null); + b.HasCheckConstraint("AddressNotIPv6MappedIPv4", "NOT inet '::ffff:0.0.0.0/96' >>= address"); + b.HasCheckConstraint("HaveEitherAddressOrUserIdOrHWId", "address IS NOT NULL OR 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") + .HasDatabaseName("IX_trait_profile_id"); + 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.AdminLogEntity", b => + { + b.HasOne("Content.Server.Database.AdminLog", null) + .WithMany("Entities") + .HasForeignKey("AdminLogId", "AdminLogRoundId") + .HasConstraintName("FK_admin_log_entity_admin_log_admin_log_id_admin_log_round_id"); + }); + + 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("LogId", "RoundId") + .OnDelete(DeleteBehavior.Cascade) + .IsRequired() + .HasConstraintName("FK_admin_log_player_admin_log_log_id_round_id"); + b.Navigation("Log"); + b.Navigation("Player"); + }); + + modelBuilder.Entity("Content.Server.Database.AdminNote", b => + { + b.HasOne("Content.Server.Database.Player", "CreatedBy") + .WithMany("AdminNotesCreated") + .HasForeignKey("CreatedById") + .HasPrincipalKey("UserId") + .OnDelete(DeleteBehavior.Cascade) + .IsRequired() + .HasConstraintName("FK_admin_notes_player_created_by_id"); + b.HasOne("Content.Server.Database.Player", "DeletedBy") + .WithMany("AdminNotesDeleted") + .HasForeignKey("DeletedById") + .HasPrincipalKey("UserId") + .HasConstraintName("FK_admin_notes_player_deleted_by_id"); + b.HasOne("Content.Server.Database.Player", "LastEditedBy") + .WithMany("AdminNotesLastEdited") + .HasForeignKey("LastEditedById") + .HasPrincipalKey("UserId") + .OnDelete(DeleteBehavior.Cascade) + .IsRequired() + .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) + .IsRequired() + .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.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.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.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.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.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("Entities"); + 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("AdminNotesCreated"); + b.Navigation("AdminNotesDeleted"); + b.Navigation("AdminNotesLastEdited"); + b.Navigation("AdminNotesReceived"); + }); + + 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("Traits"); + }); + + modelBuilder.Entity("Content.Server.Database.Round", b => + { + b.Navigation("AdminLogs"); + }); + + modelBuilder.Entity("Content.Server.Database.Server", b => + { + 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/20220816163319_Traits.cs b/Content.Server.Database/Migrations/Postgres/20220816163319_Traits.cs new file mode 100644 index 00000000000..d182c9960fe --- /dev/null +++ b/Content.Server.Database/Migrations/Postgres/20220816163319_Traits.cs @@ -0,0 +1,44 @@ +using Microsoft.EntityFrameworkCore.Migrations; +using Npgsql.EntityFrameworkCore.PostgreSQL.Metadata; + +#nullable disable + +namespace Content.Server.Database.Migrations.Postgres +{ + public partial class Traits : Migration + { + protected override void Up(MigrationBuilder migrationBuilder) + { + migrationBuilder.CreateTable( + name: "trait", + columns: table => new + { + trait_id = table.Column(type: "integer", nullable: false) + .Annotation("Npgsql:ValueGenerationStrategy", NpgsqlValueGenerationStrategy.IdentityByDefaultColumn), + profile_id = table.Column(type: "integer", nullable: false), + trait_name = table.Column(type: "text", nullable: false) + }, + constraints: table => + { + table.PrimaryKey("PK_trait", x => x.trait_id); + table.ForeignKey( + name: "FK_trait_profile_profile_id", + column: x => x.profile_id, + principalTable: "profile", + principalColumn: "profile_id", + onDelete: ReferentialAction.Cascade); + }); + + migrationBuilder.CreateIndex( + name: "IX_trait_profile_id", + table: "trait", + column: "profile_id"); + } + + protected override void Down(MigrationBuilder migrationBuilder) + { + migrationBuilder.DropTable( + name: "trait"); + } + } +}