diff --git a/Server/Migrations/PostgreSql/20210217033418_Remove 3rd Party Services.Designer.cs b/Server/Migrations/PostgreSql/20210217033418_Remove 3rd Party Services.Designer.cs
new file mode 100644
index 00000000..68c2f9c5
--- /dev/null
+++ b/Server/Migrations/PostgreSql/20210217033418_Remove 3rd Party Services.Designer.cs
@@ -0,0 +1,856 @@
+//
+using System;
+using Microsoft.EntityFrameworkCore;
+using Microsoft.EntityFrameworkCore.Infrastructure;
+using Microsoft.EntityFrameworkCore.Migrations;
+using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
+using Npgsql.EntityFrameworkCore.PostgreSQL.Metadata;
+using Remotely.Server.Data;
+
+namespace Remotely.Server.Migrations.PostgreSql
+{
+ [DbContext(typeof(PostgreSqlDbContext))]
+ [Migration("20210217033418_Remove 3rd Party Services")]
+ partial class Remove3rdPartyServices
+ {
+ protected override void BuildTargetModel(ModelBuilder modelBuilder)
+ {
+#pragma warning disable 612, 618
+ modelBuilder
+ .UseIdentityByDefaultColumns()
+ .HasAnnotation("Relational:MaxIdentifierLength", 63)
+ .HasAnnotation("ProductVersion", "5.0.2");
+
+ modelBuilder.Entity("DeviceGroupRemotelyUser", b =>
+ {
+ b.Property("DeviceGroupsID")
+ .HasColumnType("text");
+
+ b.Property("UsersId")
+ .HasColumnType("text");
+
+ b.HasKey("DeviceGroupsID", "UsersId");
+
+ b.HasIndex("UsersId");
+
+ b.ToTable("DeviceGroupRemotelyUser");
+ });
+
+ modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityRole", b =>
+ {
+ b.Property("Id")
+ .HasColumnType("text");
+
+ b.Property("ConcurrencyStamp")
+ .IsConcurrencyToken()
+ .HasColumnType("text");
+
+ b.Property("Name")
+ .HasMaxLength(256)
+ .HasColumnType("character varying(256)");
+
+ b.Property("NormalizedName")
+ .HasMaxLength(256)
+ .HasColumnType("character varying(256)");
+
+ b.HasKey("Id");
+
+ b.HasIndex("NormalizedName")
+ .IsUnique()
+ .HasDatabaseName("RoleNameIndex");
+
+ b.ToTable("AspNetRoles");
+ });
+
+ modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityRoleClaim", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("integer")
+ .UseIdentityByDefaultColumn();
+
+ b.Property("ClaimType")
+ .HasColumnType("text");
+
+ b.Property("ClaimValue")
+ .HasColumnType("text");
+
+ b.Property("RoleId")
+ .IsRequired()
+ .HasColumnType("text");
+
+ b.HasKey("Id");
+
+ b.HasIndex("RoleId");
+
+ b.ToTable("AspNetRoleClaims");
+ });
+
+ modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUser", b =>
+ {
+ b.Property("Id")
+ .HasColumnType("text");
+
+ b.Property("AccessFailedCount")
+ .HasColumnType("integer");
+
+ b.Property("ConcurrencyStamp")
+ .IsConcurrencyToken()
+ .HasColumnType("text");
+
+ b.Property("Discriminator")
+ .IsRequired()
+ .HasColumnType("text");
+
+ b.Property("Email")
+ .HasMaxLength(256)
+ .HasColumnType("character varying(256)");
+
+ b.Property("EmailConfirmed")
+ .HasColumnType("boolean");
+
+ b.Property("LockoutEnabled")
+ .HasColumnType("boolean");
+
+ b.Property("LockoutEnd")
+ .HasColumnType("timestamp with time zone");
+
+ b.Property("NormalizedEmail")
+ .HasMaxLength(256)
+ .HasColumnType("character varying(256)");
+
+ b.Property("NormalizedUserName")
+ .HasMaxLength(256)
+ .HasColumnType("character varying(256)");
+
+ b.Property("PasswordHash")
+ .HasColumnType("text");
+
+ b.Property("PhoneNumber")
+ .HasColumnType("text");
+
+ b.Property("PhoneNumberConfirmed")
+ .HasColumnType("boolean");
+
+ b.Property("SecurityStamp")
+ .HasColumnType("text");
+
+ b.Property("TwoFactorEnabled")
+ .HasColumnType("boolean");
+
+ b.Property("UserName")
+ .HasMaxLength(256)
+ .HasColumnType("character varying(256)");
+
+ b.HasKey("Id");
+
+ b.HasIndex("NormalizedEmail")
+ .HasDatabaseName("EmailIndex");
+
+ b.HasIndex("NormalizedUserName")
+ .IsUnique()
+ .HasDatabaseName("UserNameIndex");
+
+ b.ToTable("RemotelyUsers");
+
+ b.HasDiscriminator("Discriminator").HasValue("IdentityUser");
+ });
+
+ modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserClaim", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("integer")
+ .UseIdentityByDefaultColumn();
+
+ b.Property("ClaimType")
+ .HasColumnType("text");
+
+ b.Property("ClaimValue")
+ .HasColumnType("text");
+
+ b.Property("UserId")
+ .IsRequired()
+ .HasColumnType("text");
+
+ b.HasKey("Id");
+
+ b.HasIndex("UserId");
+
+ b.ToTable("AspNetUserClaims");
+ });
+
+ modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserLogin", b =>
+ {
+ b.Property("LoginProvider")
+ .HasMaxLength(128)
+ .HasColumnType("character varying(128)");
+
+ b.Property("ProviderKey")
+ .HasMaxLength(128)
+ .HasColumnType("character varying(128)");
+
+ b.Property("ProviderDisplayName")
+ .HasColumnType("text");
+
+ b.Property("UserId")
+ .IsRequired()
+ .HasColumnType("text");
+
+ b.HasKey("LoginProvider", "ProviderKey");
+
+ b.HasIndex("UserId");
+
+ b.ToTable("AspNetUserLogins");
+ });
+
+ modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserRole", b =>
+ {
+ b.Property("UserId")
+ .HasColumnType("text");
+
+ b.Property("RoleId")
+ .HasColumnType("text");
+
+ b.HasKey("UserId", "RoleId");
+
+ b.HasIndex("RoleId");
+
+ b.ToTable("AspNetUserRoles");
+ });
+
+ modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserToken", b =>
+ {
+ b.Property("UserId")
+ .HasColumnType("text");
+
+ b.Property("LoginProvider")
+ .HasMaxLength(128)
+ .HasColumnType("character varying(128)");
+
+ b.Property("Name")
+ .HasMaxLength(128)
+ .HasColumnType("character varying(128)");
+
+ b.Property("Value")
+ .HasColumnType("text");
+
+ b.HasKey("UserId", "LoginProvider", "Name");
+
+ b.ToTable("AspNetUserTokens");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.Alert", b =>
+ {
+ b.Property("ID")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("text");
+
+ b.Property("CreatedOn")
+ .HasColumnType("timestamp with time zone");
+
+ b.Property("DeviceID")
+ .HasColumnType("text");
+
+ b.Property("Message")
+ .HasColumnType("text");
+
+ b.Property("OrganizationID")
+ .HasColumnType("text");
+
+ b.Property("UserID")
+ .HasColumnType("text");
+
+ b.HasKey("ID");
+
+ b.HasIndex("DeviceID");
+
+ b.HasIndex("OrganizationID");
+
+ b.HasIndex("UserID");
+
+ b.ToTable("Alerts");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.ApiToken", b =>
+ {
+ b.Property("ID")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("text");
+
+ b.Property("LastUsed")
+ .HasColumnType("timestamp with time zone");
+
+ b.Property("Name")
+ .HasMaxLength(200)
+ .HasColumnType("character varying(200)");
+
+ b.Property("OrganizationID")
+ .HasColumnType("text");
+
+ b.Property("Secret")
+ .HasColumnType("text");
+
+ b.Property("Token")
+ .HasColumnType("text");
+
+ b.HasKey("ID");
+
+ b.HasIndex("OrganizationID");
+
+ b.HasIndex("Token");
+
+ b.ToTable("ApiTokens");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.BrandingInfo", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("text");
+
+ b.Property("ButtonForegroundBlue")
+ .HasColumnType("smallint");
+
+ b.Property("ButtonForegroundGreen")
+ .HasColumnType("smallint");
+
+ b.Property("ButtonForegroundRed")
+ .HasColumnType("smallint");
+
+ b.Property("Icon")
+ .HasColumnType("bytea");
+
+ b.Property("Product")
+ .HasMaxLength(25)
+ .HasColumnType("character varying(25)");
+
+ b.Property("TitleBackgroundBlue")
+ .HasColumnType("smallint");
+
+ b.Property("TitleBackgroundGreen")
+ .HasColumnType("smallint");
+
+ b.Property("TitleBackgroundRed")
+ .HasColumnType("smallint");
+
+ b.Property("TitleForegroundBlue")
+ .HasColumnType("smallint");
+
+ b.Property("TitleForegroundGreen")
+ .HasColumnType("smallint");
+
+ b.Property("TitleForegroundRed")
+ .HasColumnType("smallint");
+
+ b.HasKey("Id");
+
+ b.ToTable("BrandingInfo");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.CommandResult", b =>
+ {
+ b.Property("ID")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("text");
+
+ b.Property("CommandMode")
+ .HasColumnType("text");
+
+ b.Property("CommandResults")
+ .HasColumnType("text");
+
+ b.Property("CommandText")
+ .HasColumnType("text");
+
+ b.Property("OrganizationID")
+ .HasColumnType("text");
+
+ b.Property("PSCoreResults")
+ .HasColumnType("text");
+
+ b.Property("SenderConnectionID")
+ .HasColumnType("text");
+
+ b.Property("SenderUserID")
+ .HasColumnType("text");
+
+ b.Property("TargetDeviceIDs")
+ .HasColumnType("text");
+
+ b.Property("TimeStamp")
+ .HasColumnType("timestamp with time zone");
+
+ b.HasKey("ID");
+
+ b.HasIndex("OrganizationID");
+
+ b.ToTable("CommandResults");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.Device", b =>
+ {
+ b.Property("ID")
+ .HasColumnType("text");
+
+ b.Property("AgentVersion")
+ .HasColumnType("text");
+
+ b.Property("Alias")
+ .HasMaxLength(100)
+ .HasColumnType("character varying(100)");
+
+ b.Property("CpuUtilization")
+ .HasColumnType("double precision");
+
+ b.Property("CurrentUser")
+ .HasColumnType("text");
+
+ b.Property("DeviceGroupID")
+ .HasColumnType("text");
+
+ b.Property("DeviceName")
+ .HasColumnType("text");
+
+ b.Property("Drives")
+ .HasColumnType("text");
+
+ b.Property("Is64Bit")
+ .HasColumnType("boolean");
+
+ b.Property("IsOnline")
+ .HasColumnType("boolean");
+
+ b.Property("LastOnline")
+ .HasColumnType("timestamp with time zone");
+
+ b.Property("Notes")
+ .HasColumnType("text");
+
+ b.Property("OSArchitecture")
+ .HasColumnType("integer");
+
+ b.Property("OSDescription")
+ .HasColumnType("text");
+
+ b.Property("OrganizationID")
+ .HasColumnType("text");
+
+ b.Property("Platform")
+ .HasColumnType("text");
+
+ b.Property("ProcessorCount")
+ .HasColumnType("integer");
+
+ b.Property("PublicIP")
+ .HasColumnType("text");
+
+ b.Property("ServerVerificationToken")
+ .HasColumnType("text");
+
+ b.Property("Tags")
+ .HasMaxLength(200)
+ .HasColumnType("character varying(200)");
+
+ b.Property("TotalMemory")
+ .HasColumnType("double precision");
+
+ b.Property("TotalStorage")
+ .HasColumnType("double precision");
+
+ b.Property("UsedMemory")
+ .HasColumnType("double precision");
+
+ b.Property("UsedStorage")
+ .HasColumnType("double precision");
+
+ b.Property("WebRtcSetting")
+ .HasColumnType("integer");
+
+ b.HasKey("ID");
+
+ b.HasIndex("DeviceGroupID");
+
+ b.HasIndex("DeviceName");
+
+ b.HasIndex("OrganizationID");
+
+ b.ToTable("Devices");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.DeviceGroup", b =>
+ {
+ b.Property("ID")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("text");
+
+ b.Property("Name")
+ .HasMaxLength(200)
+ .HasColumnType("character varying(200)");
+
+ b.Property("OrganizationID")
+ .HasColumnType("text");
+
+ b.HasKey("ID");
+
+ b.HasIndex("OrganizationID");
+
+ b.ToTable("DeviceGroups");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.EventLog", b =>
+ {
+ b.Property("ID")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("text");
+
+ b.Property("EventType")
+ .HasColumnType("integer");
+
+ b.Property("Message")
+ .HasColumnType("text");
+
+ b.Property("OrganizationID")
+ .HasColumnType("text");
+
+ b.Property("Source")
+ .HasColumnType("text");
+
+ b.Property("StackTrace")
+ .HasColumnType("text");
+
+ b.Property("TimeStamp")
+ .HasColumnType("timestamp with time zone");
+
+ b.HasKey("ID");
+
+ b.HasIndex("OrganizationID");
+
+ b.ToTable("EventLogs");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.InviteLink", b =>
+ {
+ b.Property("ID")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("text");
+
+ b.Property("DateSent")
+ .HasColumnType("timestamp with time zone");
+
+ b.Property("InvitedUser")
+ .HasColumnType("text");
+
+ b.Property("IsAdmin")
+ .HasColumnType("boolean");
+
+ b.Property("OrganizationID")
+ .HasColumnType("text");
+
+ b.Property("ResetUrl")
+ .HasColumnType("text");
+
+ b.HasKey("ID");
+
+ b.HasIndex("OrganizationID");
+
+ b.ToTable("InviteLinks");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.Organization", b =>
+ {
+ b.Property("ID")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("text");
+
+ b.Property("BrandingInfoId")
+ .HasColumnType("text");
+
+ b.Property("IsDefaultOrganization")
+ .HasColumnType("boolean");
+
+ b.Property("OrganizationName")
+ .HasMaxLength(25)
+ .HasColumnType("character varying(25)");
+
+ b.Property("RelayCode")
+ .HasColumnType("text");
+
+ b.HasKey("ID");
+
+ b.HasIndex("BrandingInfoId");
+
+ b.ToTable("Organizations");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.SharedFile", b =>
+ {
+ b.Property("ID")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("text");
+
+ b.Property("ContentType")
+ .HasColumnType("text");
+
+ b.Property("FileContents")
+ .HasColumnType("bytea");
+
+ b.Property("FileName")
+ .HasColumnType("text");
+
+ b.Property("OrganizationID")
+ .HasColumnType("text");
+
+ b.Property("Timestamp")
+ .HasColumnType("timestamp with time zone");
+
+ b.HasKey("ID");
+
+ b.HasIndex("OrganizationID");
+
+ b.ToTable("SharedFiles");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.RemotelyUser", b =>
+ {
+ b.HasBaseType("Microsoft.AspNetCore.Identity.IdentityUser");
+
+ b.Property("DisplayName")
+ .HasMaxLength(100)
+ .HasColumnType("character varying(100)");
+
+ b.Property("IsAdministrator")
+ .HasColumnType("boolean");
+
+ b.Property("IsServerAdmin")
+ .HasColumnType("boolean");
+
+ b.Property("OrganizationID")
+ .HasColumnType("text");
+
+ b.Property("TempPassword")
+ .HasColumnType("text");
+
+ b.Property("UserOptions")
+ .HasColumnType("text");
+
+ b.HasIndex("OrganizationID");
+
+ b.HasIndex("UserName");
+
+ b.HasDiscriminator().HasValue("RemotelyUser");
+ });
+
+ modelBuilder.Entity("DeviceGroupRemotelyUser", b =>
+ {
+ b.HasOne("Remotely.Shared.Models.DeviceGroup", null)
+ .WithMany()
+ .HasForeignKey("DeviceGroupsID")
+ .OnDelete(DeleteBehavior.Cascade)
+ .IsRequired();
+
+ b.HasOne("Remotely.Shared.Models.RemotelyUser", null)
+ .WithMany()
+ .HasForeignKey("UsersId")
+ .OnDelete(DeleteBehavior.Cascade)
+ .IsRequired();
+ });
+
+ modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityRoleClaim", b =>
+ {
+ b.HasOne("Microsoft.AspNetCore.Identity.IdentityRole", null)
+ .WithMany()
+ .HasForeignKey("RoleId")
+ .OnDelete(DeleteBehavior.Cascade)
+ .IsRequired();
+ });
+
+ modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserClaim", b =>
+ {
+ b.HasOne("Microsoft.AspNetCore.Identity.IdentityUser", null)
+ .WithMany()
+ .HasForeignKey("UserId")
+ .OnDelete(DeleteBehavior.Cascade)
+ .IsRequired();
+ });
+
+ modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserLogin", b =>
+ {
+ b.HasOne("Microsoft.AspNetCore.Identity.IdentityUser", null)
+ .WithMany()
+ .HasForeignKey("UserId")
+ .OnDelete(DeleteBehavior.Cascade)
+ .IsRequired();
+ });
+
+ modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserRole", b =>
+ {
+ b.HasOne("Microsoft.AspNetCore.Identity.IdentityRole", null)
+ .WithMany()
+ .HasForeignKey("RoleId")
+ .OnDelete(DeleteBehavior.Cascade)
+ .IsRequired();
+
+ b.HasOne("Microsoft.AspNetCore.Identity.IdentityUser", null)
+ .WithMany()
+ .HasForeignKey("UserId")
+ .OnDelete(DeleteBehavior.Cascade)
+ .IsRequired();
+ });
+
+ modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserToken", b =>
+ {
+ b.HasOne("Microsoft.AspNetCore.Identity.IdentityUser", null)
+ .WithMany()
+ .HasForeignKey("UserId")
+ .OnDelete(DeleteBehavior.Cascade)
+ .IsRequired();
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.Alert", b =>
+ {
+ b.HasOne("Remotely.Shared.Models.Device", "Device")
+ .WithMany("Alerts")
+ .HasForeignKey("DeviceID");
+
+ b.HasOne("Remotely.Shared.Models.Organization", "Organization")
+ .WithMany("Alerts")
+ .HasForeignKey("OrganizationID");
+
+ b.HasOne("Remotely.Shared.Models.RemotelyUser", "User")
+ .WithMany("Alerts")
+ .HasForeignKey("UserID");
+
+ b.Navigation("Device");
+
+ b.Navigation("Organization");
+
+ b.Navigation("User");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.ApiToken", b =>
+ {
+ b.HasOne("Remotely.Shared.Models.Organization", "Organization")
+ .WithMany("ApiTokens")
+ .HasForeignKey("OrganizationID");
+
+ b.Navigation("Organization");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.CommandResult", b =>
+ {
+ b.HasOne("Remotely.Shared.Models.Organization", "Organization")
+ .WithMany("CommandResults")
+ .HasForeignKey("OrganizationID");
+
+ b.Navigation("Organization");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.Device", b =>
+ {
+ b.HasOne("Remotely.Shared.Models.DeviceGroup", "DeviceGroup")
+ .WithMany("Devices")
+ .HasForeignKey("DeviceGroupID");
+
+ b.HasOne("Remotely.Shared.Models.Organization", "Organization")
+ .WithMany("Devices")
+ .HasForeignKey("OrganizationID");
+
+ b.Navigation("DeviceGroup");
+
+ b.Navigation("Organization");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.DeviceGroup", b =>
+ {
+ b.HasOne("Remotely.Shared.Models.Organization", "Organization")
+ .WithMany("DeviceGroups")
+ .HasForeignKey("OrganizationID");
+
+ b.Navigation("Organization");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.EventLog", b =>
+ {
+ b.HasOne("Remotely.Shared.Models.Organization", "Organization")
+ .WithMany("EventLogs")
+ .HasForeignKey("OrganizationID");
+
+ b.Navigation("Organization");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.InviteLink", b =>
+ {
+ b.HasOne("Remotely.Shared.Models.Organization", "Organization")
+ .WithMany("InviteLinks")
+ .HasForeignKey("OrganizationID");
+
+ b.Navigation("Organization");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.Organization", b =>
+ {
+ b.HasOne("Remotely.Shared.Models.BrandingInfo", "BrandingInfo")
+ .WithMany()
+ .HasForeignKey("BrandingInfoId");
+
+ b.Navigation("BrandingInfo");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.SharedFile", b =>
+ {
+ b.HasOne("Remotely.Shared.Models.Organization", "Organization")
+ .WithMany("SharedFiles")
+ .HasForeignKey("OrganizationID");
+
+ b.Navigation("Organization");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.RemotelyUser", b =>
+ {
+ b.HasOne("Remotely.Shared.Models.Organization", "Organization")
+ .WithMany("RemotelyUsers")
+ .HasForeignKey("OrganizationID");
+
+ b.Navigation("Organization");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.Device", b =>
+ {
+ b.Navigation("Alerts");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.DeviceGroup", b =>
+ {
+ b.Navigation("Devices");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.Organization", b =>
+ {
+ b.Navigation("Alerts");
+
+ b.Navigation("ApiTokens");
+
+ b.Navigation("CommandResults");
+
+ b.Navigation("DeviceGroups");
+
+ b.Navigation("Devices");
+
+ b.Navigation("EventLogs");
+
+ b.Navigation("InviteLinks");
+
+ b.Navigation("RemotelyUsers");
+
+ b.Navigation("SharedFiles");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.RemotelyUser", b =>
+ {
+ b.Navigation("Alerts");
+ });
+#pragma warning restore 612, 618
+ }
+ }
+}
diff --git a/Server/Migrations/PostgreSql/20210217033418_Remove 3rd Party Services.cs b/Server/Migrations/PostgreSql/20210217033418_Remove 3rd Party Services.cs
new file mode 100644
index 00000000..0ba65e20
--- /dev/null
+++ b/Server/Migrations/PostgreSql/20210217033418_Remove 3rd Party Services.cs
@@ -0,0 +1,44 @@
+using Microsoft.EntityFrameworkCore.Migrations;
+
+namespace Remotely.Server.Migrations.PostgreSql
+{
+ public partial class Remove3rdPartyServices : Migration
+ {
+ protected override void Up(MigrationBuilder migrationBuilder)
+ {
+ migrationBuilder.DropColumn(
+ name: "GithubUser",
+ table: "Organizations");
+
+ migrationBuilder.DropColumn(
+ name: "SponsorAmount",
+ table: "Organizations");
+
+ migrationBuilder.DropColumn(
+ name: "UnlockCode",
+ table: "Organizations");
+ }
+
+ protected override void Down(MigrationBuilder migrationBuilder)
+ {
+ migrationBuilder.AddColumn(
+ name: "GithubUser",
+ table: "Organizations",
+ type: "text",
+ nullable: true);
+
+ migrationBuilder.AddColumn(
+ name: "SponsorAmount",
+ table: "Organizations",
+ type: "double precision",
+ nullable: false,
+ defaultValue: 0.0);
+
+ migrationBuilder.AddColumn(
+ name: "UnlockCode",
+ table: "Organizations",
+ type: "text",
+ nullable: true);
+ }
+ }
+}
diff --git a/Server/Migrations/PostgreSql/PostgreSqlDbContextModelSnapshot.cs b/Server/Migrations/PostgreSql/PostgreSqlDbContextModelSnapshot.cs
index a1f44e55..e0b2ae6b 100644
--- a/Server/Migrations/PostgreSql/PostgreSqlDbContextModelSnapshot.cs
+++ b/Server/Migrations/PostgreSql/PostgreSqlDbContextModelSnapshot.cs
@@ -241,6 +241,7 @@ namespace Remotely.Server.Migrations.PostgreSql
modelBuilder.Entity("Remotely.Shared.Models.Alert", b =>
{
b.Property("ID")
+ .ValueGeneratedOnAdd()
.HasColumnType("text");
b.Property("CreatedOn")
@@ -272,6 +273,7 @@ namespace Remotely.Server.Migrations.PostgreSql
modelBuilder.Entity("Remotely.Shared.Models.ApiToken", b =>
{
b.Property("ID")
+ .ValueGeneratedOnAdd()
.HasColumnType("text");
b.Property("LastUsed")
@@ -302,6 +304,7 @@ namespace Remotely.Server.Migrations.PostgreSql
modelBuilder.Entity("Remotely.Shared.Models.BrandingInfo", b =>
{
b.Property("Id")
+ .ValueGeneratedOnAdd()
.HasColumnType("text");
b.Property("ButtonForegroundBlue")
@@ -346,6 +349,7 @@ namespace Remotely.Server.Migrations.PostgreSql
modelBuilder.Entity("Remotely.Shared.Models.CommandResult", b =>
{
b.Property("ID")
+ .ValueGeneratedOnAdd()
.HasColumnType("text");
b.Property("CommandMode")
@@ -475,6 +479,7 @@ namespace Remotely.Server.Migrations.PostgreSql
modelBuilder.Entity("Remotely.Shared.Models.DeviceGroup", b =>
{
b.Property("ID")
+ .ValueGeneratedOnAdd()
.HasColumnType("text");
b.Property("Name")
@@ -494,6 +499,7 @@ namespace Remotely.Server.Migrations.PostgreSql
modelBuilder.Entity("Remotely.Shared.Models.EventLog", b =>
{
b.Property("ID")
+ .ValueGeneratedOnAdd()
.HasColumnType("text");
b.Property("EventType")
@@ -524,6 +530,7 @@ namespace Remotely.Server.Migrations.PostgreSql
modelBuilder.Entity("Remotely.Shared.Models.InviteLink", b =>
{
b.Property("ID")
+ .ValueGeneratedOnAdd()
.HasColumnType("text");
b.Property("DateSent")
@@ -551,14 +558,12 @@ namespace Remotely.Server.Migrations.PostgreSql
modelBuilder.Entity("Remotely.Shared.Models.Organization", b =>
{
b.Property("ID")
+ .ValueGeneratedOnAdd()
.HasColumnType("text");
b.Property("BrandingInfoId")
.HasColumnType("text");
- b.Property("GithubUser")
- .HasColumnType("text");
-
b.Property("IsDefaultOrganization")
.HasColumnType("boolean");
@@ -569,12 +574,6 @@ namespace Remotely.Server.Migrations.PostgreSql
b.Property("RelayCode")
.HasColumnType("text");
- b.Property("SponsorAmount")
- .HasColumnType("double precision");
-
- b.Property("UnlockCode")
- .HasColumnType("text");
-
b.HasKey("ID");
b.HasIndex("BrandingInfoId");
@@ -585,6 +584,7 @@ namespace Remotely.Server.Migrations.PostgreSql
modelBuilder.Entity("Remotely.Shared.Models.SharedFile", b =>
{
b.Property("ID")
+ .ValueGeneratedOnAdd()
.HasColumnType("text");
b.Property("ContentType")
diff --git a/Server/Migrations/SqlServer/20201002214839_InitialCreate.cs b/Server/Migrations/SqlServer/20201002214839_InitialCreate.cs
index feee822b..3f84731c 100644
--- a/Server/Migrations/SqlServer/20201002214839_InitialCreate.cs
+++ b/Server/Migrations/SqlServer/20201002214839_InitialCreate.cs
@@ -1,4 +1,5 @@
using System;
+using Microsoft.EntityFrameworkCore.Metadata;
using Microsoft.EntityFrameworkCore.Migrations;
namespace Remotely.Server.Migrations.SqlServer
@@ -38,7 +39,7 @@ namespace Remotely.Server.Migrations.SqlServer
columns: table => new
{
Id = table.Column(nullable: false)
- .Annotation("SqlServer:Identity", "1, 1"),
+ .Annotation("SqlServer:ValueGenerationStrategy", SqlServerValueGenerationStrategy.IdentityColumn),
RoleId = table.Column(nullable: false),
ClaimType = table.Column(nullable: true),
ClaimValue = table.Column(nullable: true)
@@ -277,7 +278,7 @@ namespace Remotely.Server.Migrations.SqlServer
columns: table => new
{
Id = table.Column(nullable: false)
- .Annotation("SqlServer:Identity", "1, 1"),
+ .Annotation("SqlServer:ValueGenerationStrategy", SqlServerValueGenerationStrategy.IdentityColumn),
UserId = table.Column(nullable: false),
ClaimType = table.Column(nullable: true),
ClaimValue = table.Column(nullable: true)
diff --git a/Server/Migrations/SqlServer/20210217033404_Remove 3rd Party Services.Designer.cs b/Server/Migrations/SqlServer/20210217033404_Remove 3rd Party Services.Designer.cs
new file mode 100644
index 00000000..647bcaa4
--- /dev/null
+++ b/Server/Migrations/SqlServer/20210217033404_Remove 3rd Party Services.Designer.cs
@@ -0,0 +1,858 @@
+//
+using System;
+using Microsoft.EntityFrameworkCore;
+using Microsoft.EntityFrameworkCore.Infrastructure;
+using Microsoft.EntityFrameworkCore.Metadata;
+using Microsoft.EntityFrameworkCore.Migrations;
+using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
+using Remotely.Server.Data;
+
+namespace Remotely.Server.Migrations.SqlServer
+{
+ [DbContext(typeof(SqlServerDbContext))]
+ [Migration("20210217033404_Remove 3rd Party Services")]
+ partial class Remove3rdPartyServices
+ {
+ protected override void BuildTargetModel(ModelBuilder modelBuilder)
+ {
+#pragma warning disable 612, 618
+ modelBuilder
+ .UseIdentityColumns()
+ .HasAnnotation("Relational:MaxIdentifierLength", 128)
+ .HasAnnotation("ProductVersion", "5.0.2");
+
+ modelBuilder.Entity("DeviceGroupRemotelyUser", b =>
+ {
+ b.Property("DeviceGroupsID")
+ .HasColumnType("nvarchar(450)");
+
+ b.Property("UsersId")
+ .HasColumnType("nvarchar(450)");
+
+ b.HasKey("DeviceGroupsID", "UsersId");
+
+ b.HasIndex("UsersId");
+
+ b.ToTable("DeviceGroupRemotelyUser");
+ });
+
+ modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityRole", b =>
+ {
+ b.Property("Id")
+ .HasColumnType("nvarchar(450)");
+
+ b.Property("ConcurrencyStamp")
+ .IsConcurrencyToken()
+ .HasColumnType("nvarchar(max)");
+
+ b.Property("Name")
+ .HasMaxLength(256)
+ .HasColumnType("nvarchar(256)");
+
+ b.Property("NormalizedName")
+ .HasMaxLength(256)
+ .HasColumnType("nvarchar(256)");
+
+ b.HasKey("Id");
+
+ b.HasIndex("NormalizedName")
+ .IsUnique()
+ .HasDatabaseName("RoleNameIndex")
+ .HasFilter("[NormalizedName] IS NOT NULL");
+
+ b.ToTable("AspNetRoles");
+ });
+
+ modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityRoleClaim", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("int")
+ .UseIdentityColumn();
+
+ b.Property("ClaimType")
+ .HasColumnType("nvarchar(max)");
+
+ b.Property("ClaimValue")
+ .HasColumnType("nvarchar(max)");
+
+ b.Property("RoleId")
+ .IsRequired()
+ .HasColumnType("nvarchar(450)");
+
+ b.HasKey("Id");
+
+ b.HasIndex("RoleId");
+
+ b.ToTable("AspNetRoleClaims");
+ });
+
+ modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUser", b =>
+ {
+ b.Property("Id")
+ .HasColumnType("nvarchar(450)");
+
+ b.Property("AccessFailedCount")
+ .HasColumnType("int");
+
+ b.Property("ConcurrencyStamp")
+ .IsConcurrencyToken()
+ .HasColumnType("nvarchar(max)");
+
+ b.Property("Discriminator")
+ .IsRequired()
+ .HasColumnType("nvarchar(max)");
+
+ b.Property("Email")
+ .HasMaxLength(256)
+ .HasColumnType("nvarchar(256)");
+
+ b.Property("EmailConfirmed")
+ .HasColumnType("bit");
+
+ b.Property("LockoutEnabled")
+ .HasColumnType("bit");
+
+ b.Property("LockoutEnd")
+ .HasColumnType("datetimeoffset");
+
+ b.Property("NormalizedEmail")
+ .HasMaxLength(256)
+ .HasColumnType("nvarchar(256)");
+
+ b.Property("NormalizedUserName")
+ .HasMaxLength(256)
+ .HasColumnType("nvarchar(256)");
+
+ b.Property("PasswordHash")
+ .HasColumnType("nvarchar(max)");
+
+ b.Property("PhoneNumber")
+ .HasColumnType("nvarchar(max)");
+
+ b.Property("PhoneNumberConfirmed")
+ .HasColumnType("bit");
+
+ b.Property("SecurityStamp")
+ .HasColumnType("nvarchar(max)");
+
+ b.Property("TwoFactorEnabled")
+ .HasColumnType("bit");
+
+ b.Property("UserName")
+ .HasMaxLength(256)
+ .HasColumnType("nvarchar(256)");
+
+ b.HasKey("Id");
+
+ b.HasIndex("NormalizedEmail")
+ .HasDatabaseName("EmailIndex");
+
+ b.HasIndex("NormalizedUserName")
+ .IsUnique()
+ .HasDatabaseName("UserNameIndex")
+ .HasFilter("[NormalizedUserName] IS NOT NULL");
+
+ b.ToTable("RemotelyUsers");
+
+ b.HasDiscriminator("Discriminator").HasValue("IdentityUser");
+ });
+
+ modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserClaim", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("int")
+ .UseIdentityColumn();
+
+ b.Property("ClaimType")
+ .HasColumnType("nvarchar(max)");
+
+ b.Property("ClaimValue")
+ .HasColumnType("nvarchar(max)");
+
+ b.Property("UserId")
+ .IsRequired()
+ .HasColumnType("nvarchar(450)");
+
+ b.HasKey("Id");
+
+ b.HasIndex("UserId");
+
+ b.ToTable("AspNetUserClaims");
+ });
+
+ modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserLogin", b =>
+ {
+ b.Property("LoginProvider")
+ .HasMaxLength(128)
+ .HasColumnType("nvarchar(128)");
+
+ b.Property("ProviderKey")
+ .HasMaxLength(128)
+ .HasColumnType("nvarchar(128)");
+
+ b.Property("ProviderDisplayName")
+ .HasColumnType("nvarchar(max)");
+
+ b.Property("UserId")
+ .IsRequired()
+ .HasColumnType("nvarchar(450)");
+
+ b.HasKey("LoginProvider", "ProviderKey");
+
+ b.HasIndex("UserId");
+
+ b.ToTable("AspNetUserLogins");
+ });
+
+ modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserRole", b =>
+ {
+ b.Property("UserId")
+ .HasColumnType("nvarchar(450)");
+
+ b.Property("RoleId")
+ .HasColumnType("nvarchar(450)");
+
+ b.HasKey("UserId", "RoleId");
+
+ b.HasIndex("RoleId");
+
+ b.ToTable("AspNetUserRoles");
+ });
+
+ modelBuilder.Entity("Microsoft.AspNetCore.Identity.IdentityUserToken", b =>
+ {
+ b.Property("UserId")
+ .HasColumnType("nvarchar(450)");
+
+ b.Property("LoginProvider")
+ .HasMaxLength(128)
+ .HasColumnType("nvarchar(128)");
+
+ b.Property("Name")
+ .HasMaxLength(128)
+ .HasColumnType("nvarchar(128)");
+
+ b.Property("Value")
+ .HasColumnType("nvarchar(max)");
+
+ b.HasKey("UserId", "LoginProvider", "Name");
+
+ b.ToTable("AspNetUserTokens");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.Alert", b =>
+ {
+ b.Property("ID")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("nvarchar(450)");
+
+ b.Property("CreatedOn")
+ .HasColumnType("datetimeoffset");
+
+ b.Property("DeviceID")
+ .HasColumnType("nvarchar(450)");
+
+ b.Property("Message")
+ .HasColumnType("nvarchar(max)");
+
+ b.Property("OrganizationID")
+ .HasColumnType("nvarchar(450)");
+
+ b.Property("UserID")
+ .HasColumnType("nvarchar(450)");
+
+ b.HasKey("ID");
+
+ b.HasIndex("DeviceID");
+
+ b.HasIndex("OrganizationID");
+
+ b.HasIndex("UserID");
+
+ b.ToTable("Alerts");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.ApiToken", b =>
+ {
+ b.Property("ID")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("nvarchar(450)");
+
+ b.Property("LastUsed")
+ .HasColumnType("datetimeoffset");
+
+ b.Property("Name")
+ .HasMaxLength(200)
+ .HasColumnType("nvarchar(200)");
+
+ b.Property("OrganizationID")
+ .HasColumnType("nvarchar(450)");
+
+ b.Property("Secret")
+ .HasColumnType("nvarchar(max)");
+
+ b.Property("Token")
+ .HasColumnType("nvarchar(450)");
+
+ b.HasKey("ID");
+
+ b.HasIndex("OrganizationID");
+
+ b.HasIndex("Token");
+
+ b.ToTable("ApiTokens");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.BrandingInfo", b =>
+ {
+ b.Property("Id")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("nvarchar(450)");
+
+ b.Property("ButtonForegroundBlue")
+ .HasColumnType("tinyint");
+
+ b.Property("ButtonForegroundGreen")
+ .HasColumnType("tinyint");
+
+ b.Property("ButtonForegroundRed")
+ .HasColumnType("tinyint");
+
+ b.Property("Icon")
+ .HasColumnType("varbinary(max)");
+
+ b.Property("Product")
+ .HasMaxLength(25)
+ .HasColumnType("nvarchar(25)");
+
+ b.Property("TitleBackgroundBlue")
+ .HasColumnType("tinyint");
+
+ b.Property("TitleBackgroundGreen")
+ .HasColumnType("tinyint");
+
+ b.Property("TitleBackgroundRed")
+ .HasColumnType("tinyint");
+
+ b.Property("TitleForegroundBlue")
+ .HasColumnType("tinyint");
+
+ b.Property("TitleForegroundGreen")
+ .HasColumnType("tinyint");
+
+ b.Property("TitleForegroundRed")
+ .HasColumnType("tinyint");
+
+ b.HasKey("Id");
+
+ b.ToTable("BrandingInfo");
+ });
+
+ modelBuilder.Entity("Remotely.Shared.Models.CommandResult", b =>
+ {
+ b.Property("ID")
+ .ValueGeneratedOnAdd()
+ .HasColumnType("nvarchar(450)");
+
+ b.Property("CommandMode")
+ .HasColumnType("nvarchar(max)");
+
+ b.Property("CommandResults")
+ .HasColumnType("nvarchar(max)");
+
+ b.Property("CommandText")
+ .HasColumnType("nvarchar(max)");
+
+ b.Property("OrganizationID")
+ .HasColumnType("nvarchar(450)");
+
+ b.Property("PSCoreResults")
+ .HasColumnType("nvarchar(max)");
+
+ b.Property("SenderConnectionID")
+ .HasColumnType("nvarchar(max)");
+
+ b.Property