Unify remaining DB model classes between SQLite and Postgres.
As part of this, the ban and unban table were renamed to server_* on SQLite to move them in line with Postgres. Data is preserved.
This commit is contained in:
@@ -25,5 +25,10 @@
|
|||||||
<ProjectReference Include="..\Content.Shared.Database\Content.Shared.Database.csproj" />
|
<ProjectReference Include="..\Content.Shared.Database\Content.Shared.Database.csproj" />
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
|
|
||||||
|
<ItemGroup>
|
||||||
|
<Compile Remove="Migrations\Sqlite\20220127164435_UnifyMore.cs" />
|
||||||
|
<Compile Remove="Migrations\Sqlite\20220127164435_UnifyMore.Designer.cs" />
|
||||||
|
</ItemGroup>
|
||||||
|
|
||||||
<Import Project="..\RobustToolbox\MSBuild\Robust.Analyzers.targets" />
|
<Import Project="..\RobustToolbox\MSBuild\Robust.Analyzers.targets" />
|
||||||
</Project>
|
</Project>
|
||||||
|
|||||||
870
Content.Server.Database/Migrations/Postgres/20220127170845_UnifyMore.Designer.cs
generated
Normal file
870
Content.Server.Database/Migrations/Postgres/20220127170845_UnifyMore.Designer.cs
generated
Normal file
@@ -0,0 +1,870 @@
|
|||||||
|
// <auto-generated />
|
||||||
|
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("20220127170845_UnifyMore")]
|
||||||
|
partial class UnifyMore
|
||||||
|
{
|
||||||
|
protected override void BuildTargetModel(ModelBuilder modelBuilder)
|
||||||
|
{
|
||||||
|
#pragma warning disable 612, 618
|
||||||
|
modelBuilder
|
||||||
|
.HasAnnotation("ProductVersion", "6.0.0")
|
||||||
|
.HasAnnotation("Relational:MaxIdentifierLength", 63);
|
||||||
|
|
||||||
|
NpgsqlModelBuilderExtensions.UseIdentityByDefaultColumns(modelBuilder);
|
||||||
|
|
||||||
|
modelBuilder.Entity("Content.Server.Database.Admin", b =>
|
||||||
|
{
|
||||||
|
b.Property<Guid>("UserId")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("uuid")
|
||||||
|
.HasColumnName("user_id");
|
||||||
|
|
||||||
|
b.Property<int?>("AdminRankId")
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("admin_rank_id");
|
||||||
|
|
||||||
|
b.Property<string>("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<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("admin_flag_id");
|
||||||
|
|
||||||
|
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
||||||
|
|
||||||
|
b.Property<Guid>("AdminId")
|
||||||
|
.HasColumnType("uuid")
|
||||||
|
.HasColumnName("admin_id");
|
||||||
|
|
||||||
|
b.Property<string>("Flag")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("text")
|
||||||
|
.HasColumnName("flag");
|
||||||
|
|
||||||
|
b.Property<bool>("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<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("admin_log_id");
|
||||||
|
|
||||||
|
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
||||||
|
|
||||||
|
b.Property<int>("RoundId")
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("round_id");
|
||||||
|
|
||||||
|
b.Property<DateTime>("Date")
|
||||||
|
.HasColumnType("timestamp with time zone")
|
||||||
|
.HasColumnName("date");
|
||||||
|
|
||||||
|
b.Property<short>("Impact")
|
||||||
|
.HasColumnType("smallint")
|
||||||
|
.HasColumnName("impact");
|
||||||
|
|
||||||
|
b.Property<JsonDocument>("Json")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("jsonb")
|
||||||
|
.HasColumnName("json");
|
||||||
|
|
||||||
|
b.Property<string>("Message")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("text")
|
||||||
|
.HasColumnName("message");
|
||||||
|
|
||||||
|
b.Property<int>("Type")
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("type");
|
||||||
|
|
||||||
|
b.HasKey("Id", "RoundId")
|
||||||
|
.HasName("PK_admin_log");
|
||||||
|
|
||||||
|
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<int>("Uid")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("uid");
|
||||||
|
|
||||||
|
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Uid"));
|
||||||
|
|
||||||
|
b.Property<int?>("AdminLogId")
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("admin_log_id");
|
||||||
|
|
||||||
|
b.Property<int?>("AdminLogRoundId")
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("admin_log_round_id");
|
||||||
|
|
||||||
|
b.Property<string>("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<Guid>("PlayerUserId")
|
||||||
|
.HasColumnType("uuid")
|
||||||
|
.HasColumnName("player_user_id");
|
||||||
|
|
||||||
|
b.Property<int>("LogId")
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("log_id");
|
||||||
|
|
||||||
|
b.Property<int>("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.AdminRank", b =>
|
||||||
|
{
|
||||||
|
b.Property<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("admin_rank_id");
|
||||||
|
|
||||||
|
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
||||||
|
|
||||||
|
b.Property<string>("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<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("admin_rank_flag_id");
|
||||||
|
|
||||||
|
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
||||||
|
|
||||||
|
b.Property<int>("AdminRankId")
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("admin_rank_id");
|
||||||
|
|
||||||
|
b.Property<string>("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<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("antag_id");
|
||||||
|
|
||||||
|
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
||||||
|
|
||||||
|
b.Property<string>("AntagName")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("text")
|
||||||
|
.HasColumnName("antag_name");
|
||||||
|
|
||||||
|
b.Property<int>("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<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("assigned_user_id_id");
|
||||||
|
|
||||||
|
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
||||||
|
|
||||||
|
b.Property<Guid>("UserId")
|
||||||
|
.HasColumnType("uuid")
|
||||||
|
.HasColumnName("user_id");
|
||||||
|
|
||||||
|
b.Property<string>("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<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("connection_log_id");
|
||||||
|
|
||||||
|
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
||||||
|
|
||||||
|
b.Property<IPAddress>("Address")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("inet")
|
||||||
|
.HasColumnName("address");
|
||||||
|
|
||||||
|
b.Property<byte[]>("HWId")
|
||||||
|
.HasColumnType("bytea")
|
||||||
|
.HasColumnName("hwid");
|
||||||
|
|
||||||
|
b.Property<DateTime>("Time")
|
||||||
|
.HasColumnType("timestamp with time zone")
|
||||||
|
.HasColumnName("time");
|
||||||
|
|
||||||
|
b.Property<Guid>("UserId")
|
||||||
|
.HasColumnType("uuid")
|
||||||
|
.HasColumnName("user_id");
|
||||||
|
|
||||||
|
b.Property<string>("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<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("job_id");
|
||||||
|
|
||||||
|
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
||||||
|
|
||||||
|
b.Property<string>("JobName")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("text")
|
||||||
|
.HasColumnName("job_name");
|
||||||
|
|
||||||
|
b.Property<int>("Priority")
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("priority");
|
||||||
|
|
||||||
|
b.Property<int>("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<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("player_id");
|
||||||
|
|
||||||
|
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
||||||
|
|
||||||
|
b.Property<DateTime>("FirstSeenTime")
|
||||||
|
.HasColumnType("timestamp with time zone")
|
||||||
|
.HasColumnName("first_seen_time");
|
||||||
|
|
||||||
|
b.Property<IPAddress>("LastSeenAddress")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("inet")
|
||||||
|
.HasColumnName("last_seen_address");
|
||||||
|
|
||||||
|
b.Property<byte[]>("LastSeenHWId")
|
||||||
|
.HasColumnType("bytea")
|
||||||
|
.HasColumnName("last_seen_hwid");
|
||||||
|
|
||||||
|
b.Property<DateTime>("LastSeenTime")
|
||||||
|
.HasColumnType("timestamp with time zone")
|
||||||
|
.HasColumnName("last_seen_time");
|
||||||
|
|
||||||
|
b.Property<string>("LastSeenUserName")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("text")
|
||||||
|
.HasColumnName("last_seen_user_name");
|
||||||
|
|
||||||
|
b.Property<Guid>("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.Preference", b =>
|
||||||
|
{
|
||||||
|
b.Property<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("preference_id");
|
||||||
|
|
||||||
|
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
||||||
|
|
||||||
|
b.Property<string>("AdminOOCColor")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("text")
|
||||||
|
.HasColumnName("admin_ooc_color");
|
||||||
|
|
||||||
|
b.Property<int>("SelectedCharacterSlot")
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("selected_character_slot");
|
||||||
|
|
||||||
|
b.Property<Guid>("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<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("profile_id");
|
||||||
|
|
||||||
|
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
||||||
|
|
||||||
|
b.Property<int>("Age")
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("age");
|
||||||
|
|
||||||
|
b.Property<string>("Backpack")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("text")
|
||||||
|
.HasColumnName("backpack");
|
||||||
|
|
||||||
|
b.Property<string>("CharacterName")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("text")
|
||||||
|
.HasColumnName("char_name");
|
||||||
|
|
||||||
|
b.Property<string>("Clothing")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("text")
|
||||||
|
.HasColumnName("clothing");
|
||||||
|
|
||||||
|
b.Property<string>("EyeColor")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("text")
|
||||||
|
.HasColumnName("eye_color");
|
||||||
|
|
||||||
|
b.Property<string>("FacialHairColor")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("text")
|
||||||
|
.HasColumnName("facial_hair_color");
|
||||||
|
|
||||||
|
b.Property<string>("FacialHairName")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("text")
|
||||||
|
.HasColumnName("facial_hair_name");
|
||||||
|
|
||||||
|
b.Property<string>("Gender")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("text")
|
||||||
|
.HasColumnName("gender");
|
||||||
|
|
||||||
|
b.Property<string>("HairColor")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("text")
|
||||||
|
.HasColumnName("hair_color");
|
||||||
|
|
||||||
|
b.Property<string>("HairName")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("text")
|
||||||
|
.HasColumnName("hair_name");
|
||||||
|
|
||||||
|
b.Property<int>("PreferenceId")
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("preference_id");
|
||||||
|
|
||||||
|
b.Property<int>("PreferenceUnavailable")
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("pref_unavailable");
|
||||||
|
|
||||||
|
b.Property<string>("Sex")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("text")
|
||||||
|
.HasColumnName("sex");
|
||||||
|
|
||||||
|
b.Property<string>("SkinColor")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("text")
|
||||||
|
.HasColumnName("skin_color");
|
||||||
|
|
||||||
|
b.Property<int>("Slot")
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("slot");
|
||||||
|
|
||||||
|
b.Property<string>("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<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("round_id");
|
||||||
|
|
||||||
|
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
||||||
|
|
||||||
|
b.HasKey("Id")
|
||||||
|
.HasName("PK_round");
|
||||||
|
|
||||||
|
b.ToTable("round", (string)null);
|
||||||
|
});
|
||||||
|
|
||||||
|
modelBuilder.Entity("Content.Server.Database.ServerBan", b =>
|
||||||
|
{
|
||||||
|
b.Property<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("server_ban_id");
|
||||||
|
|
||||||
|
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
||||||
|
|
||||||
|
b.Property<ValueTuple<IPAddress, int>?>("Address")
|
||||||
|
.HasColumnType("inet")
|
||||||
|
.HasColumnName("address");
|
||||||
|
|
||||||
|
b.Property<DateTime>("BanTime")
|
||||||
|
.HasColumnType("timestamp with time zone")
|
||||||
|
.HasColumnName("ban_time");
|
||||||
|
|
||||||
|
b.Property<Guid?>("BanningAdmin")
|
||||||
|
.HasColumnType("uuid")
|
||||||
|
.HasColumnName("banning_admin");
|
||||||
|
|
||||||
|
b.Property<DateTime?>("ExpirationTime")
|
||||||
|
.HasColumnType("timestamp with time zone")
|
||||||
|
.HasColumnName("expiration_time");
|
||||||
|
|
||||||
|
b.Property<byte[]>("HWId")
|
||||||
|
.HasColumnType("bytea")
|
||||||
|
.HasColumnName("hwid");
|
||||||
|
|
||||||
|
b.Property<string>("Reason")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("text")
|
||||||
|
.HasColumnName("reason");
|
||||||
|
|
||||||
|
b.Property<Guid?>("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.ServerUnban", b =>
|
||||||
|
{
|
||||||
|
b.Property<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("unban_id");
|
||||||
|
|
||||||
|
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
||||||
|
|
||||||
|
b.Property<int>("BanId")
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("ban_id");
|
||||||
|
|
||||||
|
b.Property<DateTime>("UnbanTime")
|
||||||
|
.HasColumnType("timestamp with time zone")
|
||||||
|
.HasColumnName("unban_time");
|
||||||
|
|
||||||
|
b.Property<Guid?>("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.Whitelist", b =>
|
||||||
|
{
|
||||||
|
b.Property<Guid>("UserId")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("uuid")
|
||||||
|
.HasColumnName("user_id");
|
||||||
|
|
||||||
|
b.HasKey("UserId")
|
||||||
|
.HasName("PK_whitelist");
|
||||||
|
|
||||||
|
b.ToTable("whitelist", (string)null);
|
||||||
|
});
|
||||||
|
|
||||||
|
modelBuilder.Entity("PlayerRound", b =>
|
||||||
|
{
|
||||||
|
b.Property<int>("PlayersId")
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("players_id");
|
||||||
|
|
||||||
|
b.Property<int>("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.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.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("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.Player", b =>
|
||||||
|
{
|
||||||
|
b.Navigation("AdminLogs");
|
||||||
|
});
|
||||||
|
|
||||||
|
modelBuilder.Entity("Content.Server.Database.Preference", b =>
|
||||||
|
{
|
||||||
|
b.Navigation("Profiles");
|
||||||
|
});
|
||||||
|
|
||||||
|
modelBuilder.Entity("Content.Server.Database.Profile", b =>
|
||||||
|
{
|
||||||
|
b.Navigation("Antags");
|
||||||
|
|
||||||
|
b.Navigation("Jobs");
|
||||||
|
});
|
||||||
|
|
||||||
|
modelBuilder.Entity("Content.Server.Database.Round", b =>
|
||||||
|
{
|
||||||
|
b.Navigation("AdminLogs");
|
||||||
|
});
|
||||||
|
|
||||||
|
modelBuilder.Entity("Content.Server.Database.ServerBan", b =>
|
||||||
|
{
|
||||||
|
b.Navigation("Unban");
|
||||||
|
});
|
||||||
|
#pragma warning restore 612, 618
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,19 @@
|
|||||||
|
using Microsoft.EntityFrameworkCore.Migrations;
|
||||||
|
|
||||||
|
#nullable disable
|
||||||
|
|
||||||
|
namespace Content.Server.Database.Migrations.Postgres
|
||||||
|
{
|
||||||
|
public partial class UnifyMore : Migration
|
||||||
|
{
|
||||||
|
protected override void Up(MigrationBuilder migrationBuilder)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void Down(MigrationBuilder migrationBuilder)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -288,6 +288,47 @@ namespace Content.Server.Database.Migrations.Postgres
|
|||||||
b.ToTable("assigned_user_id", (string)null);
|
b.ToTable("assigned_user_id", (string)null);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
modelBuilder.Entity("Content.Server.Database.ConnectionLog", b =>
|
||||||
|
{
|
||||||
|
b.Property<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("connection_log_id");
|
||||||
|
|
||||||
|
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
||||||
|
|
||||||
|
b.Property<IPAddress>("Address")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("inet")
|
||||||
|
.HasColumnName("address");
|
||||||
|
|
||||||
|
b.Property<byte[]>("HWId")
|
||||||
|
.HasColumnType("bytea")
|
||||||
|
.HasColumnName("hwid");
|
||||||
|
|
||||||
|
b.Property<DateTime>("Time")
|
||||||
|
.HasColumnType("timestamp with time zone")
|
||||||
|
.HasColumnName("time");
|
||||||
|
|
||||||
|
b.Property<Guid>("UserId")
|
||||||
|
.HasColumnType("uuid")
|
||||||
|
.HasColumnName("user_id");
|
||||||
|
|
||||||
|
b.Property<string>("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 =>
|
modelBuilder.Entity("Content.Server.Database.Job", b =>
|
||||||
{
|
{
|
||||||
b.Property<int>("Id")
|
b.Property<int>("Id")
|
||||||
@@ -377,129 +418,6 @@ namespace Content.Server.Database.Migrations.Postgres
|
|||||||
b.HasCheckConstraint("LastSeenAddressNotIPv6MappedIPv4", "NOT inet '::ffff:0.0.0.0/96' >>= last_seen_address");
|
b.HasCheckConstraint("LastSeenAddressNotIPv6MappedIPv4", "NOT inet '::ffff:0.0.0.0/96' >>= last_seen_address");
|
||||||
});
|
});
|
||||||
|
|
||||||
modelBuilder.Entity("Content.Server.Database.PostgresConnectionLog", b =>
|
|
||||||
{
|
|
||||||
b.Property<int>("Id")
|
|
||||||
.ValueGeneratedOnAdd()
|
|
||||||
.HasColumnType("integer")
|
|
||||||
.HasColumnName("connection_log_id");
|
|
||||||
|
|
||||||
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
|
||||||
|
|
||||||
b.Property<IPAddress>("Address")
|
|
||||||
.IsRequired()
|
|
||||||
.HasColumnType("inet")
|
|
||||||
.HasColumnName("address");
|
|
||||||
|
|
||||||
b.Property<byte[]>("HWId")
|
|
||||||
.HasColumnType("bytea")
|
|
||||||
.HasColumnName("hwid");
|
|
||||||
|
|
||||||
b.Property<DateTime>("Time")
|
|
||||||
.HasColumnType("timestamp with time zone")
|
|
||||||
.HasColumnName("time");
|
|
||||||
|
|
||||||
b.Property<Guid>("UserId")
|
|
||||||
.HasColumnType("uuid")
|
|
||||||
.HasColumnName("user_id");
|
|
||||||
|
|
||||||
b.Property<string>("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.PostgresServerBan", b =>
|
|
||||||
{
|
|
||||||
b.Property<int>("Id")
|
|
||||||
.ValueGeneratedOnAdd()
|
|
||||||
.HasColumnType("integer")
|
|
||||||
.HasColumnName("server_ban_id");
|
|
||||||
|
|
||||||
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
|
||||||
|
|
||||||
b.Property<ValueTuple<IPAddress, int>?>("Address")
|
|
||||||
.HasColumnType("inet")
|
|
||||||
.HasColumnName("address");
|
|
||||||
|
|
||||||
b.Property<DateTime>("BanTime")
|
|
||||||
.HasColumnType("timestamp with time zone")
|
|
||||||
.HasColumnName("ban_time");
|
|
||||||
|
|
||||||
b.Property<Guid?>("BanningAdmin")
|
|
||||||
.HasColumnType("uuid")
|
|
||||||
.HasColumnName("banning_admin");
|
|
||||||
|
|
||||||
b.Property<DateTime?>("ExpirationTime")
|
|
||||||
.HasColumnType("timestamp with time zone")
|
|
||||||
.HasColumnName("expiration_time");
|
|
||||||
|
|
||||||
b.Property<byte[]>("HWId")
|
|
||||||
.HasColumnType("bytea")
|
|
||||||
.HasColumnName("hwid");
|
|
||||||
|
|
||||||
b.Property<string>("Reason")
|
|
||||||
.IsRequired()
|
|
||||||
.HasColumnType("text")
|
|
||||||
.HasColumnName("reason");
|
|
||||||
|
|
||||||
b.Property<Guid?>("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.PostgresServerUnban", b =>
|
|
||||||
{
|
|
||||||
b.Property<int>("Id")
|
|
||||||
.ValueGeneratedOnAdd()
|
|
||||||
.HasColumnType("integer")
|
|
||||||
.HasColumnName("unban_id");
|
|
||||||
|
|
||||||
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
|
||||||
|
|
||||||
b.Property<int>("BanId")
|
|
||||||
.HasColumnType("integer")
|
|
||||||
.HasColumnName("ban_id");
|
|
||||||
|
|
||||||
b.Property<DateTime>("UnbanTime")
|
|
||||||
.HasColumnType("timestamp with time zone")
|
|
||||||
.HasColumnName("unban_time");
|
|
||||||
|
|
||||||
b.Property<Guid?>("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.Preference", b =>
|
modelBuilder.Entity("Content.Server.Database.Preference", b =>
|
||||||
{
|
{
|
||||||
b.Property<int>("Id")
|
b.Property<int>("Id")
|
||||||
@@ -643,6 +561,88 @@ namespace Content.Server.Database.Migrations.Postgres
|
|||||||
b.ToTable("round", (string)null);
|
b.ToTable("round", (string)null);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
modelBuilder.Entity("Content.Server.Database.ServerBan", b =>
|
||||||
|
{
|
||||||
|
b.Property<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("server_ban_id");
|
||||||
|
|
||||||
|
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
||||||
|
|
||||||
|
b.Property<ValueTuple<IPAddress, int>?>("Address")
|
||||||
|
.HasColumnType("inet")
|
||||||
|
.HasColumnName("address");
|
||||||
|
|
||||||
|
b.Property<DateTime>("BanTime")
|
||||||
|
.HasColumnType("timestamp with time zone")
|
||||||
|
.HasColumnName("ban_time");
|
||||||
|
|
||||||
|
b.Property<Guid?>("BanningAdmin")
|
||||||
|
.HasColumnType("uuid")
|
||||||
|
.HasColumnName("banning_admin");
|
||||||
|
|
||||||
|
b.Property<DateTime?>("ExpirationTime")
|
||||||
|
.HasColumnType("timestamp with time zone")
|
||||||
|
.HasColumnName("expiration_time");
|
||||||
|
|
||||||
|
b.Property<byte[]>("HWId")
|
||||||
|
.HasColumnType("bytea")
|
||||||
|
.HasColumnName("hwid");
|
||||||
|
|
||||||
|
b.Property<string>("Reason")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("text")
|
||||||
|
.HasColumnName("reason");
|
||||||
|
|
||||||
|
b.Property<Guid?>("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.ServerUnban", b =>
|
||||||
|
{
|
||||||
|
b.Property<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("unban_id");
|
||||||
|
|
||||||
|
NpgsqlPropertyBuilderExtensions.UseIdentityByDefaultColumn(b.Property<int>("Id"));
|
||||||
|
|
||||||
|
b.Property<int>("BanId")
|
||||||
|
.HasColumnType("integer")
|
||||||
|
.HasColumnName("ban_id");
|
||||||
|
|
||||||
|
b.Property<DateTime>("UnbanTime")
|
||||||
|
.HasColumnType("timestamp with time zone")
|
||||||
|
.HasColumnName("unban_time");
|
||||||
|
|
||||||
|
b.Property<Guid?>("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.Whitelist", b =>
|
modelBuilder.Entity("Content.Server.Database.Whitelist", b =>
|
||||||
{
|
{
|
||||||
b.Property<Guid>("UserId")
|
b.Property<Guid>("UserId")
|
||||||
@@ -776,18 +776,6 @@ namespace Content.Server.Database.Migrations.Postgres
|
|||||||
b.Navigation("Profile");
|
b.Navigation("Profile");
|
||||||
});
|
});
|
||||||
|
|
||||||
modelBuilder.Entity("Content.Server.Database.PostgresServerUnban", b =>
|
|
||||||
{
|
|
||||||
b.HasOne("Content.Server.Database.PostgresServerBan", "Ban")
|
|
||||||
.WithOne("Unban")
|
|
||||||
.HasForeignKey("Content.Server.Database.PostgresServerUnban", "BanId")
|
|
||||||
.OnDelete(DeleteBehavior.Cascade)
|
|
||||||
.IsRequired()
|
|
||||||
.HasConstraintName("FK_server_unban_server_ban_ban_id");
|
|
||||||
|
|
||||||
b.Navigation("Ban");
|
|
||||||
});
|
|
||||||
|
|
||||||
modelBuilder.Entity("Content.Server.Database.Profile", b =>
|
modelBuilder.Entity("Content.Server.Database.Profile", b =>
|
||||||
{
|
{
|
||||||
b.HasOne("Content.Server.Database.Preference", "Preference")
|
b.HasOne("Content.Server.Database.Preference", "Preference")
|
||||||
@@ -800,6 +788,18 @@ namespace Content.Server.Database.Migrations.Postgres
|
|||||||
b.Navigation("Preference");
|
b.Navigation("Preference");
|
||||||
});
|
});
|
||||||
|
|
||||||
|
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("PlayerRound", b =>
|
modelBuilder.Entity("PlayerRound", b =>
|
||||||
{
|
{
|
||||||
b.HasOne("Content.Server.Database.Player", null)
|
b.HasOne("Content.Server.Database.Player", null)
|
||||||
@@ -841,11 +841,6 @@ namespace Content.Server.Database.Migrations.Postgres
|
|||||||
b.Navigation("AdminLogs");
|
b.Navigation("AdminLogs");
|
||||||
});
|
});
|
||||||
|
|
||||||
modelBuilder.Entity("Content.Server.Database.PostgresServerBan", b =>
|
|
||||||
{
|
|
||||||
b.Navigation("Unban");
|
|
||||||
});
|
|
||||||
|
|
||||||
modelBuilder.Entity("Content.Server.Database.Preference", b =>
|
modelBuilder.Entity("Content.Server.Database.Preference", b =>
|
||||||
{
|
{
|
||||||
b.Navigation("Profiles");
|
b.Navigation("Profiles");
|
||||||
@@ -862,6 +857,11 @@ namespace Content.Server.Database.Migrations.Postgres
|
|||||||
{
|
{
|
||||||
b.Navigation("AdminLogs");
|
b.Navigation("AdminLogs");
|
||||||
});
|
});
|
||||||
|
|
||||||
|
modelBuilder.Entity("Content.Server.Database.ServerBan", b =>
|
||||||
|
{
|
||||||
|
b.Navigation("Unban");
|
||||||
|
});
|
||||||
#pragma warning restore 612, 618
|
#pragma warning restore 612, 618
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
827
Content.Server.Database/Migrations/Sqlite/20220127165122_UnifyMore.Designer.cs
generated
Normal file
827
Content.Server.Database/Migrations/Sqlite/20220127165122_UnifyMore.Designer.cs
generated
Normal file
@@ -0,0 +1,827 @@
|
|||||||
|
// <auto-generated />
|
||||||
|
using System;
|
||||||
|
using Content.Server.Database;
|
||||||
|
using Microsoft.EntityFrameworkCore;
|
||||||
|
using Microsoft.EntityFrameworkCore.Infrastructure;
|
||||||
|
using Microsoft.EntityFrameworkCore.Migrations;
|
||||||
|
using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
|
||||||
|
|
||||||
|
#nullable disable
|
||||||
|
|
||||||
|
namespace Content.Server.Database.Migrations.Sqlite
|
||||||
|
{
|
||||||
|
[DbContext(typeof(SqliteServerDbContext))]
|
||||||
|
[Migration("20220127165122_UnifyMore")]
|
||||||
|
partial class UnifyMore
|
||||||
|
{
|
||||||
|
protected override void BuildTargetModel(ModelBuilder modelBuilder)
|
||||||
|
{
|
||||||
|
#pragma warning disable 612, 618
|
||||||
|
modelBuilder.HasAnnotation("ProductVersion", "6.0.0");
|
||||||
|
|
||||||
|
modelBuilder.Entity("Content.Server.Database.Admin", b =>
|
||||||
|
{
|
||||||
|
b.Property<Guid>("UserId")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("user_id");
|
||||||
|
|
||||||
|
b.Property<int?>("AdminRankId")
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("admin_rank_id");
|
||||||
|
|
||||||
|
b.Property<string>("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<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("admin_flag_id");
|
||||||
|
|
||||||
|
b.Property<Guid>("AdminId")
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("admin_id");
|
||||||
|
|
||||||
|
b.Property<string>("Flag")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("flag");
|
||||||
|
|
||||||
|
b.Property<bool>("Negative")
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.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<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("admin_log_id");
|
||||||
|
|
||||||
|
b.Property<int>("RoundId")
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("round_id");
|
||||||
|
|
||||||
|
b.Property<DateTime>("Date")
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("date");
|
||||||
|
|
||||||
|
b.Property<sbyte>("Impact")
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("impact");
|
||||||
|
|
||||||
|
b.Property<string>("Json")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("jsonb")
|
||||||
|
.HasColumnName("json");
|
||||||
|
|
||||||
|
b.Property<string>("Message")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("message");
|
||||||
|
|
||||||
|
b.Property<int>("Type")
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("type");
|
||||||
|
|
||||||
|
b.HasKey("Id", "RoundId")
|
||||||
|
.HasName("PK_admin_log");
|
||||||
|
|
||||||
|
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<int>("Uid")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("uid");
|
||||||
|
|
||||||
|
b.Property<int?>("AdminLogId")
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("admin_log_id");
|
||||||
|
|
||||||
|
b.Property<int?>("AdminLogRoundId")
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("admin_log_round_id");
|
||||||
|
|
||||||
|
b.Property<string>("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<Guid>("PlayerUserId")
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("player_user_id");
|
||||||
|
|
||||||
|
b.Property<int>("LogId")
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("log_id");
|
||||||
|
|
||||||
|
b.Property<int>("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.AdminRank", b =>
|
||||||
|
{
|
||||||
|
b.Property<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("admin_rank_id");
|
||||||
|
|
||||||
|
b.Property<string>("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<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("admin_rank_flag_id");
|
||||||
|
|
||||||
|
b.Property<int>("AdminRankId")
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("admin_rank_id");
|
||||||
|
|
||||||
|
b.Property<string>("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<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("antag_id");
|
||||||
|
|
||||||
|
b.Property<string>("AntagName")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("antag_name");
|
||||||
|
|
||||||
|
b.Property<int>("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<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("assigned_user_id_id");
|
||||||
|
|
||||||
|
b.Property<Guid>("UserId")
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("user_id");
|
||||||
|
|
||||||
|
b.Property<string>("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<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("connection_log_id");
|
||||||
|
|
||||||
|
b.Property<string>("Address")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("address");
|
||||||
|
|
||||||
|
b.Property<byte[]>("HWId")
|
||||||
|
.HasColumnType("BLOB")
|
||||||
|
.HasColumnName("hwid");
|
||||||
|
|
||||||
|
b.Property<DateTime>("Time")
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("time");
|
||||||
|
|
||||||
|
b.Property<Guid>("UserId")
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("user_id");
|
||||||
|
|
||||||
|
b.Property<string>("UserName")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("user_name");
|
||||||
|
|
||||||
|
b.HasKey("Id")
|
||||||
|
.HasName("PK_connection_log");
|
||||||
|
|
||||||
|
b.HasIndex("UserId");
|
||||||
|
|
||||||
|
b.ToTable("connection_log", (string)null);
|
||||||
|
});
|
||||||
|
|
||||||
|
modelBuilder.Entity("Content.Server.Database.Job", b =>
|
||||||
|
{
|
||||||
|
b.Property<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("job_id");
|
||||||
|
|
||||||
|
b.Property<string>("JobName")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("job_name");
|
||||||
|
|
||||||
|
b.Property<int>("Priority")
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("priority");
|
||||||
|
|
||||||
|
b.Property<int>("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<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("player_id");
|
||||||
|
|
||||||
|
b.Property<DateTime>("FirstSeenTime")
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("first_seen_time");
|
||||||
|
|
||||||
|
b.Property<string>("LastSeenAddress")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("last_seen_address");
|
||||||
|
|
||||||
|
b.Property<byte[]>("LastSeenHWId")
|
||||||
|
.HasColumnType("BLOB")
|
||||||
|
.HasColumnName("last_seen_hwid");
|
||||||
|
|
||||||
|
b.Property<DateTime>("LastSeenTime")
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("last_seen_time");
|
||||||
|
|
||||||
|
b.Property<string>("LastSeenUserName")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("last_seen_user_name");
|
||||||
|
|
||||||
|
b.Property<Guid>("UserId")
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.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);
|
||||||
|
});
|
||||||
|
|
||||||
|
modelBuilder.Entity("Content.Server.Database.Preference", b =>
|
||||||
|
{
|
||||||
|
b.Property<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("preference_id");
|
||||||
|
|
||||||
|
b.Property<string>("AdminOOCColor")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("admin_ooc_color");
|
||||||
|
|
||||||
|
b.Property<int>("SelectedCharacterSlot")
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("selected_character_slot");
|
||||||
|
|
||||||
|
b.Property<Guid>("UserId")
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.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<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("profile_id");
|
||||||
|
|
||||||
|
b.Property<int>("Age")
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("age");
|
||||||
|
|
||||||
|
b.Property<string>("Backpack")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("backpack");
|
||||||
|
|
||||||
|
b.Property<string>("CharacterName")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("char_name");
|
||||||
|
|
||||||
|
b.Property<string>("Clothing")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("clothing");
|
||||||
|
|
||||||
|
b.Property<string>("EyeColor")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("eye_color");
|
||||||
|
|
||||||
|
b.Property<string>("FacialHairColor")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("facial_hair_color");
|
||||||
|
|
||||||
|
b.Property<string>("FacialHairName")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("facial_hair_name");
|
||||||
|
|
||||||
|
b.Property<string>("Gender")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("gender");
|
||||||
|
|
||||||
|
b.Property<string>("HairColor")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("hair_color");
|
||||||
|
|
||||||
|
b.Property<string>("HairName")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("hair_name");
|
||||||
|
|
||||||
|
b.Property<int>("PreferenceId")
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("preference_id");
|
||||||
|
|
||||||
|
b.Property<int>("PreferenceUnavailable")
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("pref_unavailable");
|
||||||
|
|
||||||
|
b.Property<string>("Sex")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("sex");
|
||||||
|
|
||||||
|
b.Property<string>("SkinColor")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("skin_color");
|
||||||
|
|
||||||
|
b.Property<int>("Slot")
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("slot");
|
||||||
|
|
||||||
|
b.Property<string>("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<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("round_id");
|
||||||
|
|
||||||
|
b.HasKey("Id")
|
||||||
|
.HasName("PK_round");
|
||||||
|
|
||||||
|
b.ToTable("round", (string)null);
|
||||||
|
});
|
||||||
|
|
||||||
|
modelBuilder.Entity("Content.Server.Database.ServerBan", b =>
|
||||||
|
{
|
||||||
|
b.Property<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("server_ban_id");
|
||||||
|
|
||||||
|
b.Property<string>("Address")
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("address");
|
||||||
|
|
||||||
|
b.Property<DateTime>("BanTime")
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("ban_time");
|
||||||
|
|
||||||
|
b.Property<Guid?>("BanningAdmin")
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("banning_admin");
|
||||||
|
|
||||||
|
b.Property<DateTime?>("ExpirationTime")
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("expiration_time");
|
||||||
|
|
||||||
|
b.Property<byte[]>("HWId")
|
||||||
|
.HasColumnType("BLOB")
|
||||||
|
.HasColumnName("hwid");
|
||||||
|
|
||||||
|
b.Property<string>("Reason")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("reason");
|
||||||
|
|
||||||
|
b.Property<Guid?>("UserId")
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("user_id");
|
||||||
|
|
||||||
|
b.HasKey("Id")
|
||||||
|
.HasName("PK_server_ban");
|
||||||
|
|
||||||
|
b.HasIndex("Address");
|
||||||
|
|
||||||
|
b.HasIndex("UserId");
|
||||||
|
|
||||||
|
b.ToTable("server_ban", (string)null);
|
||||||
|
|
||||||
|
b.HasCheckConstraint("HaveEitherAddressOrUserIdOrHWId", "address IS NOT NULL OR user_id IS NOT NULL OR hwid IS NOT NULL");
|
||||||
|
});
|
||||||
|
|
||||||
|
modelBuilder.Entity("Content.Server.Database.ServerUnban", b =>
|
||||||
|
{
|
||||||
|
b.Property<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("unban_id");
|
||||||
|
|
||||||
|
b.Property<int>("BanId")
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("ban_id");
|
||||||
|
|
||||||
|
b.Property<DateTime>("UnbanTime")
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("unban_time");
|
||||||
|
|
||||||
|
b.Property<Guid?>("UnbanningAdmin")
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.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.Whitelist", b =>
|
||||||
|
{
|
||||||
|
b.Property<Guid>("UserId")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("user_id");
|
||||||
|
|
||||||
|
b.HasKey("UserId")
|
||||||
|
.HasName("PK_whitelist");
|
||||||
|
|
||||||
|
b.ToTable("whitelist", (string)null);
|
||||||
|
});
|
||||||
|
|
||||||
|
modelBuilder.Entity("PlayerRound", b =>
|
||||||
|
{
|
||||||
|
b.Property<int>("PlayersId")
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("players_id");
|
||||||
|
|
||||||
|
b.Property<int>("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.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.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("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.Player", b =>
|
||||||
|
{
|
||||||
|
b.Navigation("AdminLogs");
|
||||||
|
});
|
||||||
|
|
||||||
|
modelBuilder.Entity("Content.Server.Database.Preference", b =>
|
||||||
|
{
|
||||||
|
b.Navigation("Profiles");
|
||||||
|
});
|
||||||
|
|
||||||
|
modelBuilder.Entity("Content.Server.Database.Profile", b =>
|
||||||
|
{
|
||||||
|
b.Navigation("Antags");
|
||||||
|
|
||||||
|
b.Navigation("Jobs");
|
||||||
|
});
|
||||||
|
|
||||||
|
modelBuilder.Entity("Content.Server.Database.Round", b =>
|
||||||
|
{
|
||||||
|
b.Navigation("AdminLogs");
|
||||||
|
});
|
||||||
|
|
||||||
|
modelBuilder.Entity("Content.Server.Database.ServerBan", b =>
|
||||||
|
{
|
||||||
|
b.Navigation("Unban");
|
||||||
|
});
|
||||||
|
#pragma warning restore 612, 618
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,162 @@
|
|||||||
|
using System;
|
||||||
|
using Microsoft.EntityFrameworkCore.Migrations;
|
||||||
|
|
||||||
|
#nullable disable
|
||||||
|
|
||||||
|
namespace Content.Server.Database.Migrations.Sqlite
|
||||||
|
{
|
||||||
|
public partial class UnifyMore : Migration
|
||||||
|
{
|
||||||
|
protected override void Up(MigrationBuilder migrationBuilder)
|
||||||
|
{
|
||||||
|
migrationBuilder.CreateTable(
|
||||||
|
name: "server_ban",
|
||||||
|
columns: table => new
|
||||||
|
{
|
||||||
|
server_ban_id = table.Column<int>(type: "INTEGER", nullable: false)
|
||||||
|
.Annotation("Sqlite:Autoincrement", true),
|
||||||
|
user_id = table.Column<Guid>(type: "TEXT", nullable: true),
|
||||||
|
address = table.Column<string>(type: "TEXT", nullable: true),
|
||||||
|
hwid = table.Column<byte[]>(type: "BLOB", nullable: true),
|
||||||
|
ban_time = table.Column<DateTime>(type: "TEXT", nullable: false),
|
||||||
|
expiration_time = table.Column<DateTime>(type: "TEXT", nullable: true),
|
||||||
|
reason = table.Column<string>(type: "TEXT", nullable: false),
|
||||||
|
banning_admin = table.Column<Guid>(type: "TEXT", nullable: true)
|
||||||
|
},
|
||||||
|
constraints: table =>
|
||||||
|
{
|
||||||
|
table.PrimaryKey("PK_server_ban", x => x.server_ban_id);
|
||||||
|
table.CheckConstraint("CK_server_ban_HaveEitherAddressOrUserIdOrHWId", "address IS NOT NULL OR user_id IS NOT NULL OR hwid IS NOT NULL");
|
||||||
|
});
|
||||||
|
|
||||||
|
migrationBuilder.CreateTable(
|
||||||
|
name: "server_unban",
|
||||||
|
columns: table => new
|
||||||
|
{
|
||||||
|
unban_id = table.Column<int>(type: "INTEGER", nullable: false)
|
||||||
|
.Annotation("Sqlite:Autoincrement", true),
|
||||||
|
ban_id = table.Column<int>(type: "INTEGER", nullable: false),
|
||||||
|
unbanning_admin = table.Column<Guid>(type: "TEXT", nullable: true),
|
||||||
|
unban_time = table.Column<DateTime>(type: "TEXT", nullable: false)
|
||||||
|
},
|
||||||
|
constraints: table =>
|
||||||
|
{
|
||||||
|
table.PrimaryKey("PK_server_unban", x => x.unban_id);
|
||||||
|
table.ForeignKey(
|
||||||
|
name: "FK_server_unban_server_ban_ban_id",
|
||||||
|
column: x => x.ban_id,
|
||||||
|
principalTable: "server_ban",
|
||||||
|
principalColumn: "server_ban_id",
|
||||||
|
onDelete: ReferentialAction.Cascade);
|
||||||
|
});
|
||||||
|
|
||||||
|
migrationBuilder.Sql(@"
|
||||||
|
INSERT INTO server_ban (server_ban_id, user_id, address, hwid, ban_time, expiration_time, reason, banning_admin)
|
||||||
|
SELECT ban_id, user_id, address, hwid, ban_time, expiration_time, reason, banning_admin
|
||||||
|
FROM ban;");
|
||||||
|
migrationBuilder.Sql("INSERT INTO server_unban SELECT * FROM unban;");
|
||||||
|
|
||||||
|
migrationBuilder.CreateIndex(
|
||||||
|
name: "IX_player_user_id",
|
||||||
|
table: "player",
|
||||||
|
column: "user_id",
|
||||||
|
unique: true);
|
||||||
|
|
||||||
|
migrationBuilder.CreateIndex(
|
||||||
|
name: "IX_connection_log_user_id",
|
||||||
|
table: "connection_log",
|
||||||
|
column: "user_id");
|
||||||
|
|
||||||
|
migrationBuilder.CreateIndex(
|
||||||
|
name: "IX_server_ban_address",
|
||||||
|
table: "server_ban",
|
||||||
|
column: "address");
|
||||||
|
|
||||||
|
migrationBuilder.CreateIndex(
|
||||||
|
name: "IX_server_ban_user_id",
|
||||||
|
table: "server_ban",
|
||||||
|
column: "user_id");
|
||||||
|
|
||||||
|
migrationBuilder.CreateIndex(
|
||||||
|
name: "IX_server_unban_ban_id",
|
||||||
|
table: "server_unban",
|
||||||
|
column: "ban_id",
|
||||||
|
unique: true);
|
||||||
|
|
||||||
|
migrationBuilder.DropTable(
|
||||||
|
name: "unban");
|
||||||
|
|
||||||
|
migrationBuilder.DropTable(
|
||||||
|
name: "ban");
|
||||||
|
}
|
||||||
|
|
||||||
|
protected override void Down(MigrationBuilder migrationBuilder)
|
||||||
|
{
|
||||||
|
migrationBuilder.DropIndex(
|
||||||
|
name: "IX_player_user_id",
|
||||||
|
table: "player");
|
||||||
|
|
||||||
|
migrationBuilder.DropIndex(
|
||||||
|
name: "IX_connection_log_user_id",
|
||||||
|
table: "connection_log");
|
||||||
|
|
||||||
|
migrationBuilder.CreateTable(
|
||||||
|
name: "ban",
|
||||||
|
columns: table => new
|
||||||
|
{
|
||||||
|
ban_id = table.Column<int>(type: "INTEGER", nullable: false)
|
||||||
|
.Annotation("Sqlite:Autoincrement", true),
|
||||||
|
address = table.Column<string>(type: "TEXT", nullable: true),
|
||||||
|
ban_time = table.Column<DateTime>(type: "TEXT", nullable: false),
|
||||||
|
banning_admin = table.Column<Guid>(type: "TEXT", nullable: true),
|
||||||
|
expiration_time = table.Column<DateTime>(type: "TEXT", nullable: true),
|
||||||
|
hwid = table.Column<byte[]>(type: "BLOB", nullable: true),
|
||||||
|
reason = table.Column<string>(type: "TEXT", nullable: false),
|
||||||
|
user_id = table.Column<Guid>(type: "TEXT", nullable: true)
|
||||||
|
},
|
||||||
|
constraints: table =>
|
||||||
|
{
|
||||||
|
table.PrimaryKey("PK_ban", x => x.ban_id);
|
||||||
|
});
|
||||||
|
|
||||||
|
migrationBuilder.CreateTable(
|
||||||
|
name: "unban",
|
||||||
|
columns: table => new
|
||||||
|
{
|
||||||
|
unban_id = table.Column<int>(type: "INTEGER", nullable: false)
|
||||||
|
.Annotation("Sqlite:Autoincrement", true),
|
||||||
|
ban_id = table.Column<int>(type: "INTEGER", nullable: false),
|
||||||
|
unban_time = table.Column<DateTime>(type: "TEXT", nullable: false),
|
||||||
|
unbanning_admin = table.Column<Guid>(type: "TEXT", nullable: true)
|
||||||
|
},
|
||||||
|
constraints: table =>
|
||||||
|
{
|
||||||
|
table.PrimaryKey("PK_unban", x => x.unban_id);
|
||||||
|
table.ForeignKey(
|
||||||
|
name: "FK_unban_ban_ban_id",
|
||||||
|
column: x => x.ban_id,
|
||||||
|
principalTable: "ban",
|
||||||
|
principalColumn: "ban_id",
|
||||||
|
onDelete: ReferentialAction.Cascade);
|
||||||
|
});
|
||||||
|
|
||||||
|
migrationBuilder.Sql(@"
|
||||||
|
INSERT INTO ban (ban_id, user_id, address, hwid, ban_time, expiration_time, reason, banning_admin)
|
||||||
|
SELECT server_ban_id, user_id, address, hwid, ban_time, expiration_time, reason, banning_admin
|
||||||
|
FROM server_ban;");
|
||||||
|
migrationBuilder.Sql(@"INSERT INTO unban SELECT * FROM server_unban;");
|
||||||
|
|
||||||
|
migrationBuilder.DropTable(
|
||||||
|
name: "server_unban");
|
||||||
|
|
||||||
|
migrationBuilder.DropTable(
|
||||||
|
name: "server_ban");
|
||||||
|
|
||||||
|
migrationBuilder.CreateIndex(
|
||||||
|
name: "IX_unban_ban_id",
|
||||||
|
table: "unban",
|
||||||
|
column: "ban_id",
|
||||||
|
unique: true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -267,6 +267,43 @@ namespace Content.Server.Database.Migrations.Sqlite
|
|||||||
b.ToTable("assigned_user_id", (string)null);
|
b.ToTable("assigned_user_id", (string)null);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
modelBuilder.Entity("Content.Server.Database.ConnectionLog", b =>
|
||||||
|
{
|
||||||
|
b.Property<int>("Id")
|
||||||
|
.ValueGeneratedOnAdd()
|
||||||
|
.HasColumnType("INTEGER")
|
||||||
|
.HasColumnName("connection_log_id");
|
||||||
|
|
||||||
|
b.Property<string>("Address")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("address");
|
||||||
|
|
||||||
|
b.Property<byte[]>("HWId")
|
||||||
|
.HasColumnType("BLOB")
|
||||||
|
.HasColumnName("hwid");
|
||||||
|
|
||||||
|
b.Property<DateTime>("Time")
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("time");
|
||||||
|
|
||||||
|
b.Property<Guid>("UserId")
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("user_id");
|
||||||
|
|
||||||
|
b.Property<string>("UserName")
|
||||||
|
.IsRequired()
|
||||||
|
.HasColumnType("TEXT")
|
||||||
|
.HasColumnName("user_name");
|
||||||
|
|
||||||
|
b.HasKey("Id")
|
||||||
|
.HasName("PK_connection_log");
|
||||||
|
|
||||||
|
b.HasIndex("UserId");
|
||||||
|
|
||||||
|
b.ToTable("connection_log", (string)null);
|
||||||
|
});
|
||||||
|
|
||||||
modelBuilder.Entity("Content.Server.Database.Job", b =>
|
modelBuilder.Entity("Content.Server.Database.Job", b =>
|
||||||
{
|
{
|
||||||
b.Property<int>("Id")
|
b.Property<int>("Id")
|
||||||
@@ -344,6 +381,9 @@ namespace Content.Server.Database.Migrations.Sqlite
|
|||||||
|
|
||||||
b.HasIndex("LastSeenUserName");
|
b.HasIndex("LastSeenUserName");
|
||||||
|
|
||||||
|
b.HasIndex("UserId")
|
||||||
|
.IsUnique();
|
||||||
|
|
||||||
b.ToTable("player", (string)null);
|
b.ToTable("player", (string)null);
|
||||||
});
|
});
|
||||||
|
|
||||||
@@ -484,47 +524,12 @@ namespace Content.Server.Database.Migrations.Sqlite
|
|||||||
b.ToTable("round", (string)null);
|
b.ToTable("round", (string)null);
|
||||||
});
|
});
|
||||||
|
|
||||||
modelBuilder.Entity("Content.Server.Database.SqliteConnectionLog", b =>
|
modelBuilder.Entity("Content.Server.Database.ServerBan", b =>
|
||||||
{
|
{
|
||||||
b.Property<int>("Id")
|
b.Property<int>("Id")
|
||||||
.ValueGeneratedOnAdd()
|
.ValueGeneratedOnAdd()
|
||||||
.HasColumnType("INTEGER")
|
.HasColumnType("INTEGER")
|
||||||
.HasColumnName("connection_log_id");
|
.HasColumnName("server_ban_id");
|
||||||
|
|
||||||
b.Property<string>("Address")
|
|
||||||
.IsRequired()
|
|
||||||
.HasColumnType("TEXT")
|
|
||||||
.HasColumnName("address");
|
|
||||||
|
|
||||||
b.Property<byte[]>("HWId")
|
|
||||||
.HasColumnType("BLOB")
|
|
||||||
.HasColumnName("hwid");
|
|
||||||
|
|
||||||
b.Property<DateTime>("Time")
|
|
||||||
.HasColumnType("TEXT")
|
|
||||||
.HasColumnName("time");
|
|
||||||
|
|
||||||
b.Property<Guid>("UserId")
|
|
||||||
.HasColumnType("TEXT")
|
|
||||||
.HasColumnName("user_id");
|
|
||||||
|
|
||||||
b.Property<string>("UserName")
|
|
||||||
.IsRequired()
|
|
||||||
.HasColumnType("TEXT")
|
|
||||||
.HasColumnName("user_name");
|
|
||||||
|
|
||||||
b.HasKey("Id")
|
|
||||||
.HasName("PK_connection_log");
|
|
||||||
|
|
||||||
b.ToTable("connection_log", (string)null);
|
|
||||||
});
|
|
||||||
|
|
||||||
modelBuilder.Entity("Content.Server.Database.SqliteServerBan", b =>
|
|
||||||
{
|
|
||||||
b.Property<int>("Id")
|
|
||||||
.ValueGeneratedOnAdd()
|
|
||||||
.HasColumnType("INTEGER")
|
|
||||||
.HasColumnName("ban_id");
|
|
||||||
|
|
||||||
b.Property<string>("Address")
|
b.Property<string>("Address")
|
||||||
.HasColumnType("TEXT")
|
.HasColumnType("TEXT")
|
||||||
@@ -556,12 +561,18 @@ namespace Content.Server.Database.Migrations.Sqlite
|
|||||||
.HasColumnName("user_id");
|
.HasColumnName("user_id");
|
||||||
|
|
||||||
b.HasKey("Id")
|
b.HasKey("Id")
|
||||||
.HasName("PK_ban");
|
.HasName("PK_server_ban");
|
||||||
|
|
||||||
b.ToTable("ban", (string)null);
|
b.HasIndex("Address");
|
||||||
|
|
||||||
|
b.HasIndex("UserId");
|
||||||
|
|
||||||
|
b.ToTable("server_ban", (string)null);
|
||||||
|
|
||||||
|
b.HasCheckConstraint("HaveEitherAddressOrUserIdOrHWId", "address IS NOT NULL OR user_id IS NOT NULL OR hwid IS NOT NULL");
|
||||||
});
|
});
|
||||||
|
|
||||||
modelBuilder.Entity("Content.Server.Database.SqliteServerUnban", b =>
|
modelBuilder.Entity("Content.Server.Database.ServerUnban", b =>
|
||||||
{
|
{
|
||||||
b.Property<int>("Id")
|
b.Property<int>("Id")
|
||||||
.ValueGeneratedOnAdd()
|
.ValueGeneratedOnAdd()
|
||||||
@@ -581,12 +592,12 @@ namespace Content.Server.Database.Migrations.Sqlite
|
|||||||
.HasColumnName("unbanning_admin");
|
.HasColumnName("unbanning_admin");
|
||||||
|
|
||||||
b.HasKey("Id")
|
b.HasKey("Id")
|
||||||
.HasName("PK_unban");
|
.HasName("PK_server_unban");
|
||||||
|
|
||||||
b.HasIndex("BanId")
|
b.HasIndex("BanId")
|
||||||
.IsUnique();
|
.IsUnique();
|
||||||
|
|
||||||
b.ToTable("unban", (string)null);
|
b.ToTable("server_unban", (string)null);
|
||||||
});
|
});
|
||||||
|
|
||||||
modelBuilder.Entity("Content.Server.Database.Whitelist", b =>
|
modelBuilder.Entity("Content.Server.Database.Whitelist", b =>
|
||||||
@@ -734,14 +745,14 @@ namespace Content.Server.Database.Migrations.Sqlite
|
|||||||
b.Navigation("Preference");
|
b.Navigation("Preference");
|
||||||
});
|
});
|
||||||
|
|
||||||
modelBuilder.Entity("Content.Server.Database.SqliteServerUnban", b =>
|
modelBuilder.Entity("Content.Server.Database.ServerUnban", b =>
|
||||||
{
|
{
|
||||||
b.HasOne("Content.Server.Database.SqliteServerBan", "Ban")
|
b.HasOne("Content.Server.Database.ServerBan", "Ban")
|
||||||
.WithOne("Unban")
|
.WithOne("Unban")
|
||||||
.HasForeignKey("Content.Server.Database.SqliteServerUnban", "BanId")
|
.HasForeignKey("Content.Server.Database.ServerUnban", "BanId")
|
||||||
.OnDelete(DeleteBehavior.Cascade)
|
.OnDelete(DeleteBehavior.Cascade)
|
||||||
.IsRequired()
|
.IsRequired()
|
||||||
.HasConstraintName("FK_unban_ban_ban_id");
|
.HasConstraintName("FK_server_unban_server_ban_ban_id");
|
||||||
|
|
||||||
b.Navigation("Ban");
|
b.Navigation("Ban");
|
||||||
});
|
});
|
||||||
@@ -804,7 +815,7 @@ namespace Content.Server.Database.Migrations.Sqlite
|
|||||||
b.Navigation("AdminLogs");
|
b.Navigation("AdminLogs");
|
||||||
});
|
});
|
||||||
|
|
||||||
modelBuilder.Entity("Content.Server.Database.SqliteServerBan", b =>
|
modelBuilder.Entity("Content.Server.Database.ServerBan", b =>
|
||||||
{
|
{
|
||||||
b.Navigation("Unban");
|
b.Navigation("Unban");
|
||||||
});
|
});
|
||||||
|
|||||||
@@ -37,6 +37,9 @@ namespace Content.Server.Database
|
|||||||
public DbSet<AdminLog> AdminLog { get; set; } = null!;
|
public DbSet<AdminLog> AdminLog { get; set; } = null!;
|
||||||
public DbSet<AdminLogPlayer> AdminLogPlayer { get; set; } = null!;
|
public DbSet<AdminLogPlayer> AdminLogPlayer { get; set; } = null!;
|
||||||
public DbSet<Whitelist> Whitelist { get; set; } = null!;
|
public DbSet<Whitelist> Whitelist { get; set; } = null!;
|
||||||
|
public DbSet<ServerBan> Ban { get; set; } = default!;
|
||||||
|
public DbSet<ServerUnban> Unban { get; set; } = default!;
|
||||||
|
public DbSet<ConnectionLog> ConnectionLog { get; set; } = default!;
|
||||||
|
|
||||||
protected override void OnModelCreating(ModelBuilder modelBuilder)
|
protected override void OnModelCreating(ModelBuilder modelBuilder)
|
||||||
{
|
{
|
||||||
@@ -101,6 +104,32 @@ namespace Content.Server.Database
|
|||||||
|
|
||||||
modelBuilder.Entity<AdminLogPlayer>()
|
modelBuilder.Entity<AdminLogPlayer>()
|
||||||
.HasKey(logPlayer => new {logPlayer.PlayerUserId, logPlayer.LogId, logPlayer.RoundId});
|
.HasKey(logPlayer => new {logPlayer.PlayerUserId, logPlayer.LogId, logPlayer.RoundId});
|
||||||
|
|
||||||
|
modelBuilder.Entity<ServerBan>()
|
||||||
|
.HasIndex(p => p.UserId);
|
||||||
|
|
||||||
|
modelBuilder.Entity<ServerBan>()
|
||||||
|
.HasIndex(p => p.Address);
|
||||||
|
|
||||||
|
modelBuilder.Entity<ServerBan>()
|
||||||
|
.HasIndex(p => p.UserId);
|
||||||
|
|
||||||
|
modelBuilder.Entity<ServerUnban>()
|
||||||
|
.HasIndex(p => p.BanId)
|
||||||
|
.IsUnique();
|
||||||
|
|
||||||
|
modelBuilder.Entity<ServerBan>()
|
||||||
|
.HasCheckConstraint("HaveEitherAddressOrUserIdOrHWId", "address IS NOT NULL OR user_id IS NOT NULL OR hwid IS NOT NULL");
|
||||||
|
|
||||||
|
modelBuilder.Entity<Player>()
|
||||||
|
.HasIndex(p => p.UserId)
|
||||||
|
.IsUnique();
|
||||||
|
|
||||||
|
modelBuilder.Entity<Player>()
|
||||||
|
.HasIndex(p => p.LastSeenUserName);
|
||||||
|
|
||||||
|
modelBuilder.Entity<ConnectionLog>()
|
||||||
|
.HasIndex(p => p.UserId);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -300,4 +329,49 @@ namespace Content.Server.Database
|
|||||||
[Required, Key] public int Uid { get; set; }
|
[Required, Key] public int Uid { get; set; }
|
||||||
public string? Name { get; set; } = default!;
|
public string? Name { get; set; } = default!;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
[Table("server_ban")]
|
||||||
|
public class ServerBan
|
||||||
|
{
|
||||||
|
public int Id { get; set; }
|
||||||
|
public Guid? UserId { get; set; }
|
||||||
|
[Column(TypeName = "inet")] public (IPAddress, int)? Address { get; set; }
|
||||||
|
public byte[]? HWId { get; set; }
|
||||||
|
|
||||||
|
public DateTime BanTime { get; set; }
|
||||||
|
|
||||||
|
public DateTime? ExpirationTime { get; set; }
|
||||||
|
|
||||||
|
public string Reason { get; set; } = null!;
|
||||||
|
public Guid? BanningAdmin { get; set; }
|
||||||
|
|
||||||
|
public ServerUnban? Unban { get; set; }
|
||||||
|
}
|
||||||
|
|
||||||
|
[Table("server_unban")]
|
||||||
|
public class ServerUnban
|
||||||
|
{
|
||||||
|
[Column("unban_id")] public int Id { get; set; }
|
||||||
|
|
||||||
|
public int BanId { get; set; }
|
||||||
|
public ServerBan Ban { get; set; } = null!;
|
||||||
|
|
||||||
|
public Guid? UnbanningAdmin { get; set; }
|
||||||
|
|
||||||
|
public DateTime UnbanTime { get; set; }
|
||||||
|
}
|
||||||
|
|
||||||
|
[Table("connection_log")]
|
||||||
|
public class ConnectionLog
|
||||||
|
{
|
||||||
|
public int Id { get; set; }
|
||||||
|
|
||||||
|
public Guid UserId { get; set; }
|
||||||
|
public string UserName { get; set; } = null!;
|
||||||
|
|
||||||
|
public DateTime Time { get; set; }
|
||||||
|
|
||||||
|
public IPAddress Address { get; set; } = null!;
|
||||||
|
public byte[]? HWId { get; set; }
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,6 +1,4 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.ComponentModel.DataAnnotations.Schema;
|
|
||||||
using System.Net;
|
|
||||||
using Microsoft.EntityFrameworkCore;
|
using Microsoft.EntityFrameworkCore;
|
||||||
using Microsoft.EntityFrameworkCore.Diagnostics;
|
using Microsoft.EntityFrameworkCore.Diagnostics;
|
||||||
using Microsoft.EntityFrameworkCore.Infrastructure;
|
using Microsoft.EntityFrameworkCore.Infrastructure;
|
||||||
@@ -20,11 +18,6 @@ namespace Content.Server.Database
|
|||||||
AppContext.SetSwitch("Npgsql.EnableLegacyTimestampBehavior", true);
|
AppContext.SetSwitch("Npgsql.EnableLegacyTimestampBehavior", true);
|
||||||
}
|
}
|
||||||
|
|
||||||
public DbSet<PostgresServerBan> Ban { get; set; } = default!;
|
|
||||||
public DbSet<PostgresServerUnban> Unban { get; set; } = default!;
|
|
||||||
public DbSet<PostgresConnectionLog> ConnectionLog { get; set; } = default!;
|
|
||||||
|
|
||||||
|
|
||||||
protected override void OnConfiguring(DbContextOptionsBuilder options)
|
protected override void OnConfiguring(DbContextOptionsBuilder options)
|
||||||
{
|
{
|
||||||
if (!InitializedWithOptions)
|
if (!InitializedWithOptions)
|
||||||
@@ -56,43 +49,19 @@ namespace Content.Server.Database
|
|||||||
{
|
{
|
||||||
base.OnModelCreating(modelBuilder);
|
base.OnModelCreating(modelBuilder);
|
||||||
|
|
||||||
modelBuilder.Entity<PostgresServerBan>()
|
|
||||||
.HasIndex(p => p.UserId);
|
|
||||||
|
|
||||||
modelBuilder.Entity<PostgresServerBan>()
|
|
||||||
.HasIndex(p => p.Address);
|
|
||||||
|
|
||||||
modelBuilder.Entity<PostgresServerBan>()
|
|
||||||
.HasIndex(p => p.UserId);
|
|
||||||
|
|
||||||
modelBuilder.Entity<PostgresServerUnban>()
|
|
||||||
.HasIndex(p => p.BanId)
|
|
||||||
.IsUnique();
|
|
||||||
|
|
||||||
// ReSharper disable once CommentTypo
|
// ReSharper disable once CommentTypo
|
||||||
// ReSharper disable once StringLiteralTypo
|
// ReSharper disable once StringLiteralTypo
|
||||||
// Enforce that an address cannot be IPv6-mapped IPv4.
|
// Enforce that an address cannot be IPv6-mapped IPv4.
|
||||||
// So that IPv4 addresses are consistent between separate-socket and dual-stack socket modes.
|
// So that IPv4 addresses are consistent between separate-socket and dual-stack socket modes.
|
||||||
modelBuilder.Entity<PostgresServerBan>()
|
modelBuilder.Entity<ServerBan>()
|
||||||
.HasCheckConstraint("AddressNotIPv6MappedIPv4", "NOT inet '::ffff:0.0.0.0/96' >>= address")
|
.HasCheckConstraint("AddressNotIPv6MappedIPv4", "NOT inet '::ffff:0.0.0.0/96' >>= address");
|
||||||
.HasCheckConstraint("HaveEitherAddressOrUserIdOrHWId", "address IS NOT NULL OR user_id IS NOT NULL OR hwid IS NOT NULL");
|
|
||||||
|
|
||||||
modelBuilder.Entity<Player>()
|
|
||||||
.HasIndex(p => p.UserId)
|
|
||||||
.IsUnique();
|
|
||||||
|
|
||||||
// ReSharper disable once StringLiteralTypo
|
// ReSharper disable once StringLiteralTypo
|
||||||
modelBuilder.Entity<Player>()
|
modelBuilder.Entity<Player>()
|
||||||
.HasCheckConstraint("LastSeenAddressNotIPv6MappedIPv4",
|
.HasCheckConstraint("LastSeenAddressNotIPv6MappedIPv4",
|
||||||
"NOT inet '::ffff:0.0.0.0/96' >>= last_seen_address");
|
"NOT inet '::ffff:0.0.0.0/96' >>= last_seen_address");
|
||||||
|
|
||||||
modelBuilder.Entity<Player>()
|
modelBuilder.Entity<ConnectionLog>()
|
||||||
.HasIndex(p => p.LastSeenUserName);
|
|
||||||
|
|
||||||
modelBuilder.Entity<PostgresConnectionLog>()
|
|
||||||
.HasIndex(p => p.UserId);
|
|
||||||
|
|
||||||
modelBuilder.Entity<PostgresConnectionLog>()
|
|
||||||
.HasCheckConstraint("AddressNotIPv6MappedIPv4",
|
.HasCheckConstraint("AddressNotIPv6MappedIPv4",
|
||||||
"NOT inet '::ffff:0.0.0.0/96' >>= address");
|
"NOT inet '::ffff:0.0.0.0/96' >>= address");
|
||||||
|
|
||||||
@@ -106,49 +75,4 @@ namespace Content.Server.Database
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
[Table("server_ban")]
|
|
||||||
public class PostgresServerBan
|
|
||||||
{
|
|
||||||
public int Id { get; set; }
|
|
||||||
public Guid? UserId { get; set; }
|
|
||||||
[Column(TypeName = "inet")] public (IPAddress, int)? Address { get; set; }
|
|
||||||
public byte[]? HWId { get; set; }
|
|
||||||
|
|
||||||
public DateTime BanTime { get; set; }
|
|
||||||
|
|
||||||
public DateTime? ExpirationTime { get; set; }
|
|
||||||
|
|
||||||
public string Reason { get; set; } = null!;
|
|
||||||
public Guid? BanningAdmin { get; set; }
|
|
||||||
|
|
||||||
public PostgresServerUnban? Unban { get; set; }
|
|
||||||
}
|
|
||||||
|
|
||||||
[Table("server_unban")]
|
|
||||||
public class PostgresServerUnban
|
|
||||||
{
|
|
||||||
[Column("unban_id")] public int Id { get; set; }
|
|
||||||
|
|
||||||
public int BanId { get; set; }
|
|
||||||
public PostgresServerBan Ban { get; set; } = null!;
|
|
||||||
|
|
||||||
public Guid? UnbanningAdmin { get; set; }
|
|
||||||
|
|
||||||
public DateTime UnbanTime { get; set; }
|
|
||||||
}
|
|
||||||
|
|
||||||
[Table("connection_log")]
|
|
||||||
public class PostgresConnectionLog
|
|
||||||
{
|
|
||||||
public int Id { get; set; }
|
|
||||||
|
|
||||||
public Guid UserId { get; set; }
|
|
||||||
public string UserName { get; set; } = null!;
|
|
||||||
|
|
||||||
public DateTime Time { get; set; }
|
|
||||||
|
|
||||||
public IPAddress Address { get; set; } = null!;
|
|
||||||
public byte[]? HWId { get; set; }
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,5 +1,4 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.ComponentModel.DataAnnotations.Schema;
|
|
||||||
using System.Globalization;
|
using System.Globalization;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
using System.Net;
|
using System.Net;
|
||||||
@@ -14,10 +13,6 @@ namespace Content.Server.Database
|
|||||||
{
|
{
|
||||||
public sealed class SqliteServerDbContext : ServerDbContext
|
public sealed class SqliteServerDbContext : ServerDbContext
|
||||||
{
|
{
|
||||||
public DbSet<SqliteServerBan> Ban { get; set; } = default!;
|
|
||||||
public DbSet<SqliteServerUnban> Unban { get; set; } = default!;
|
|
||||||
public DbSet<SqliteConnectionLog> ConnectionLog { get; set; } = default!;
|
|
||||||
|
|
||||||
public SqliteServerDbContext()
|
public SqliteServerDbContext()
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
@@ -47,9 +42,6 @@ namespace Content.Server.Database
|
|||||||
{
|
{
|
||||||
base.OnModelCreating(modelBuilder);
|
base.OnModelCreating(modelBuilder);
|
||||||
|
|
||||||
modelBuilder.Entity<Player>()
|
|
||||||
.HasIndex(p => p.LastSeenUserName);
|
|
||||||
|
|
||||||
var ipConverter = new ValueConverter<IPAddress, string>(
|
var ipConverter = new ValueConverter<IPAddress, string>(
|
||||||
v => v.ToString(),
|
v => v.ToString(),
|
||||||
v => IPAddress.Parse(v));
|
v => IPAddress.Parse(v));
|
||||||
@@ -64,7 +56,7 @@ namespace Content.Server.Database
|
|||||||
);
|
);
|
||||||
|
|
||||||
modelBuilder
|
modelBuilder
|
||||||
.Entity<SqliteServerBan>()
|
.Entity<ServerBan>()
|
||||||
.Property(e => e.Address)
|
.Property(e => e.Address)
|
||||||
.HasColumnType("TEXT")
|
.HasColumnType("TEXT")
|
||||||
.HasConversion(ipMaskConverter);
|
.HasConversion(ipMaskConverter);
|
||||||
@@ -117,45 +109,4 @@ namespace Content.Server.Database
|
|||||||
return JsonDocument.Parse(str);
|
return JsonDocument.Parse(str);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
[Table("ban")]
|
|
||||||
public class SqliteServerBan
|
|
||||||
{
|
|
||||||
public int Id { get; set; }
|
|
||||||
|
|
||||||
public Guid? UserId { get; set; }
|
|
||||||
public (IPAddress address, int mask)? Address { get; set; }
|
|
||||||
public byte[]? HWId { get; set; }
|
|
||||||
|
|
||||||
public DateTime BanTime { get; set; }
|
|
||||||
public DateTime? ExpirationTime { get; set; }
|
|
||||||
public string Reason { get; set; } = null!;
|
|
||||||
public Guid? BanningAdmin { get; set; }
|
|
||||||
|
|
||||||
public SqliteServerUnban? Unban { get; set; }
|
|
||||||
}
|
|
||||||
|
|
||||||
[Table("unban")]
|
|
||||||
public class SqliteServerUnban
|
|
||||||
{
|
|
||||||
[Column("unban_id")] public int Id { get; set; }
|
|
||||||
|
|
||||||
public int BanId { get; set; }
|
|
||||||
public SqliteServerBan Ban { get; set; } = null!;
|
|
||||||
|
|
||||||
public Guid? UnbanningAdmin { get; set; }
|
|
||||||
public DateTime UnbanTime { get; set; }
|
|
||||||
}
|
|
||||||
|
|
||||||
[Table("connection_log")]
|
|
||||||
public class SqliteConnectionLog
|
|
||||||
{
|
|
||||||
public int Id { get; set; }
|
|
||||||
|
|
||||||
public Guid UserId { get; set; }
|
|
||||||
public string UserName { get; set; } = null!;
|
|
||||||
public DateTime Time { get; set; }
|
|
||||||
public string Address { get; set; } = null!;
|
|
||||||
public byte[]? HWId { get; set; }
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -98,13 +98,13 @@ namespace Content.Server.Database
|
|||||||
return bans;
|
return bans;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static IQueryable<PostgresServerBan> MakeBanLookupQuery(
|
private static IQueryable<ServerBan> MakeBanLookupQuery(
|
||||||
IPAddress? address,
|
IPAddress? address,
|
||||||
NetUserId? userId,
|
NetUserId? userId,
|
||||||
ImmutableArray<byte>? hwId,
|
ImmutableArray<byte>? hwId,
|
||||||
DbGuardImpl db)
|
DbGuardImpl db)
|
||||||
{
|
{
|
||||||
IQueryable<PostgresServerBan>? query = null;
|
IQueryable<ServerBan>? query = null;
|
||||||
|
|
||||||
if (userId is { } uid)
|
if (userId is { } uid)
|
||||||
{
|
{
|
||||||
@@ -137,7 +137,7 @@ namespace Content.Server.Database
|
|||||||
return query;
|
return query;
|
||||||
}
|
}
|
||||||
|
|
||||||
private static ServerBanDef? ConvertBan(PostgresServerBan? ban)
|
private static ServerBanDef? ConvertBan(ServerBan? ban)
|
||||||
{
|
{
|
||||||
if (ban == null)
|
if (ban == null)
|
||||||
{
|
{
|
||||||
@@ -170,7 +170,7 @@ namespace Content.Server.Database
|
|||||||
unbanDef);
|
unbanDef);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static ServerUnbanDef? ConvertUnban(PostgresServerUnban? unban)
|
private static ServerUnbanDef? ConvertUnban(ServerUnban? unban)
|
||||||
{
|
{
|
||||||
if (unban == null)
|
if (unban == null)
|
||||||
{
|
{
|
||||||
@@ -193,7 +193,7 @@ namespace Content.Server.Database
|
|||||||
{
|
{
|
||||||
await using var db = await GetDbImpl();
|
await using var db = await GetDbImpl();
|
||||||
|
|
||||||
db.PgDbContext.Ban.Add(new PostgresServerBan
|
db.PgDbContext.Ban.Add(new ServerBan
|
||||||
{
|
{
|
||||||
Address = serverBan.Address,
|
Address = serverBan.Address,
|
||||||
HWId = serverBan.HWId?.ToArray(),
|
HWId = serverBan.HWId?.ToArray(),
|
||||||
@@ -211,7 +211,7 @@ namespace Content.Server.Database
|
|||||||
{
|
{
|
||||||
await using var db = await GetDbImpl();
|
await using var db = await GetDbImpl();
|
||||||
|
|
||||||
db.PgDbContext.Unban.Add(new PostgresServerUnban
|
db.PgDbContext.Unban.Add(new ServerUnban
|
||||||
{
|
{
|
||||||
BanId = serverUnban.BanId,
|
BanId = serverUnban.BanId,
|
||||||
UnbanningAdmin = serverUnban.UnbanningAdmin?.UserId,
|
UnbanningAdmin = serverUnban.UnbanningAdmin?.UserId,
|
||||||
@@ -240,7 +240,7 @@ namespace Content.Server.Database
|
|||||||
{
|
{
|
||||||
await using var db = await GetDbImpl();
|
await using var db = await GetDbImpl();
|
||||||
|
|
||||||
db.PgDbContext.ConnectionLog.Add(new PostgresConnectionLog
|
db.PgDbContext.ConnectionLog.Add(new ConnectionLog
|
||||||
{
|
{
|
||||||
Address = address,
|
Address = address,
|
||||||
Time = DateTime.UtcNow,
|
Time = DateTime.UtcNow,
|
||||||
|
|||||||
@@ -97,7 +97,7 @@ namespace Content.Server.Database
|
|||||||
}
|
}
|
||||||
|
|
||||||
private static bool BanMatches(
|
private static bool BanMatches(
|
||||||
SqliteServerBan ban,
|
ServerBan ban,
|
||||||
IPAddress? address,
|
IPAddress? address,
|
||||||
NetUserId? userId,
|
NetUserId? userId,
|
||||||
ImmutableArray<byte>? hwId)
|
ImmutableArray<byte>? hwId)
|
||||||
@@ -124,7 +124,7 @@ namespace Content.Server.Database
|
|||||||
{
|
{
|
||||||
await using var db = await GetDbImpl();
|
await using var db = await GetDbImpl();
|
||||||
|
|
||||||
db.SqliteDbContext.Ban.Add(new SqliteServerBan
|
db.SqliteDbContext.Ban.Add(new ServerBan
|
||||||
{
|
{
|
||||||
Address = serverBan.Address,
|
Address = serverBan.Address,
|
||||||
Reason = serverBan.Reason,
|
Reason = serverBan.Reason,
|
||||||
@@ -142,7 +142,7 @@ namespace Content.Server.Database
|
|||||||
{
|
{
|
||||||
await using var db = await GetDbImpl();
|
await using var db = await GetDbImpl();
|
||||||
|
|
||||||
db.SqliteDbContext.Unban.Add(new SqliteServerUnban
|
db.SqliteDbContext.Unban.Add(new ServerUnban
|
||||||
{
|
{
|
||||||
BanId = serverUnban.BanId,
|
BanId = serverUnban.BanId,
|
||||||
UnbanningAdmin = serverUnban.UnbanningAdmin?.UserId,
|
UnbanningAdmin = serverUnban.UnbanningAdmin?.UserId,
|
||||||
@@ -163,7 +163,7 @@ namespace Content.Server.Database
|
|||||||
record.LastSeenHWId?.ToImmutableArray());
|
record.LastSeenHWId?.ToImmutableArray());
|
||||||
}
|
}
|
||||||
|
|
||||||
private static ServerBanDef? ConvertBan(SqliteServerBan? ban)
|
private static ServerBanDef? ConvertBan(ServerBan? ban)
|
||||||
{
|
{
|
||||||
if (ban == null)
|
if (ban == null)
|
||||||
{
|
{
|
||||||
@@ -196,7 +196,7 @@ namespace Content.Server.Database
|
|||||||
unban);
|
unban);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static ServerUnbanDef? ConvertUnban(SqliteServerUnban? unban)
|
private static ServerUnbanDef? ConvertUnban(ServerUnban? unban)
|
||||||
{
|
{
|
||||||
if (unban == null)
|
if (unban == null)
|
||||||
{
|
{
|
||||||
@@ -220,9 +220,9 @@ namespace Content.Server.Database
|
|||||||
{
|
{
|
||||||
await using var db = await GetDbImpl();
|
await using var db = await GetDbImpl();
|
||||||
|
|
||||||
db.SqliteDbContext.ConnectionLog.Add(new SqliteConnectionLog
|
db.SqliteDbContext.ConnectionLog.Add(new ConnectionLog
|
||||||
{
|
{
|
||||||
Address = address.ToString(),
|
Address = address,
|
||||||
Time = DateTime.UtcNow,
|
Time = DateTime.UtcNow,
|
||||||
UserId = userId.UserId,
|
UserId = userId.UserId,
|
||||||
UserName = userName,
|
UserName = userName,
|
||||||
|
|||||||
Reference in New Issue
Block a user