//
using System;
using Bit.Infrastructure.EntityFramework.Repositories;
using Microsoft.EntityFrameworkCore;
using Microsoft.EntityFrameworkCore.Infrastructure;
using Microsoft.EntityFrameworkCore.Metadata;
using Microsoft.EntityFrameworkCore.Migrations;
using Microsoft.EntityFrameworkCore.Storage.ValueConversion;
#nullable disable
namespace Bit.MySqlMigrations.Migrations
{
[DbContext(typeof(DatabaseContext))]
[Migration("20240828101433_FinalFlexibleCollectionsDataMigrations")]
partial class FinalFlexibleCollectionsDataMigrations
{
///
protected override void BuildTargetModel(ModelBuilder modelBuilder)
{
#pragma warning disable 612, 618
modelBuilder
.HasAnnotation("ProductVersion", "8.0.8")
.HasAnnotation("Relational:MaxIdentifierLength", 64);
MySqlModelBuilderExtensions.AutoIncrementColumns(modelBuilder);
modelBuilder.Entity("Bit.Infrastructure.EntityFramework.AdminConsole.Models.Organization", b =>
{
b.Property("Id")
.HasColumnType("char(36)");
b.Property("AllowAdminAccessToAllCollectionItems")
.HasColumnType("tinyint(1)")
.HasDefaultValue(true);
b.Property("BillingEmail")
.IsRequired()
.HasMaxLength(256)
.HasColumnType("varchar(256)");
b.Property("BusinessAddress1")
.HasMaxLength(50)
.HasColumnType("varchar(50)");
b.Property("BusinessAddress2")
.HasMaxLength(50)
.HasColumnType("varchar(50)");
b.Property("BusinessAddress3")
.HasMaxLength(50)
.HasColumnType("varchar(50)");
b.Property("BusinessCountry")
.HasMaxLength(2)
.HasColumnType("varchar(2)");
b.Property("BusinessName")
.HasMaxLength(50)
.HasColumnType("varchar(50)");
b.Property("BusinessTaxNumber")
.HasMaxLength(30)
.HasColumnType("varchar(30)");
b.Property("CreationDate")
.HasColumnType("datetime(6)");
b.Property("Enabled")
.HasColumnType("tinyint(1)");
b.Property("ExpirationDate")
.HasColumnType("datetime(6)");
b.Property("Gateway")
.HasColumnType("tinyint unsigned");
b.Property("GatewayCustomerId")
.HasMaxLength(50)
.HasColumnType("varchar(50)");
b.Property("GatewaySubscriptionId")
.HasMaxLength(50)
.HasColumnType("varchar(50)");
b.Property("Identifier")
.HasMaxLength(50)
.HasColumnType("varchar(50)");
b.Property("LicenseKey")
.HasMaxLength(100)
.HasColumnType("varchar(100)");
b.Property("LimitCollectionCreationDeletion")
.HasColumnType("tinyint(1)")
.HasDefaultValue(true);
b.Property("MaxAutoscaleSeats")
.HasColumnType("int");
b.Property("MaxAutoscaleSmSeats")
.HasColumnType("int");
b.Property("MaxAutoscaleSmServiceAccounts")
.HasColumnType("int");
b.Property("MaxCollections")
.HasColumnType("smallint");
b.Property("MaxStorageGb")
.HasColumnType("smallint");
b.Property("Name")
.IsRequired()
.HasMaxLength(50)
.HasColumnType("varchar(50)");
b.Property("OwnersNotifiedOfAutoscaling")
.HasColumnType("datetime(6)");
b.Property("Plan")
.IsRequired()
.HasMaxLength(50)
.HasColumnType("varchar(50)");
b.Property("PlanType")
.HasColumnType("tinyint unsigned");
b.Property("PrivateKey")
.HasColumnType("longtext");
b.Property("PublicKey")
.HasColumnType("longtext");
b.Property("ReferenceData")
.HasColumnType("longtext");
b.Property("RevisionDate")
.HasColumnType("datetime(6)");
b.Property("Seats")
.HasColumnType("int");
b.Property("SelfHost")
.HasColumnType("tinyint(1)");
b.Property("SmSeats")
.HasColumnType("int");
b.Property("SmServiceAccounts")
.HasColumnType("int");
b.Property("Status")
.HasColumnType("tinyint unsigned");
b.Property("Storage")
.HasColumnType("bigint");
b.Property("TwoFactorProviders")
.HasColumnType("longtext");
b.Property("Use2fa")
.HasColumnType("tinyint(1)");
b.Property("UseApi")
.HasColumnType("tinyint(1)");
b.Property("UseCustomPermissions")
.HasColumnType("tinyint(1)");
b.Property("UseDirectory")
.HasColumnType("tinyint(1)");
b.Property("UseEvents")
.HasColumnType("tinyint(1)");
b.Property("UseGroups")
.HasColumnType("tinyint(1)");
b.Property("UseKeyConnector")
.HasColumnType("tinyint(1)");
b.Property("UsePasswordManager")
.HasColumnType("tinyint(1)");
b.Property("UsePolicies")
.HasColumnType("tinyint(1)");
b.Property("UseResetPassword")
.HasColumnType("tinyint(1)");
b.Property("UseScim")
.HasColumnType("tinyint(1)");
b.Property("UseSecretsManager")
.HasColumnType("tinyint(1)");
b.Property("UseSso")
.HasColumnType("tinyint(1)");
b.Property("UseTotp")
.HasColumnType("tinyint(1)");
b.Property("UsersGetPremium")
.HasColumnType("tinyint(1)");
b.HasKey("Id");
b.HasIndex("Id", "Enabled")
.HasAnnotation("Npgsql:IndexInclude", new[] { "UseTotp" });
b.ToTable("Organization", (string)null);
});
modelBuilder.Entity("Bit.Infrastructure.EntityFramework.AdminConsole.Models.Policy", b =>
{
b.Property("Id")
.HasColumnType("char(36)");
b.Property("CreationDate")
.HasColumnType("datetime(6)");
b.Property("Data")
.HasColumnType("longtext");
b.Property("Enabled")
.HasColumnType("tinyint(1)");
b.Property("OrganizationId")
.HasColumnType("char(36)");
b.Property("RevisionDate")
.HasColumnType("datetime(6)");
b.Property("Type")
.HasColumnType("tinyint unsigned");
b.HasKey("Id");
b.HasIndex("OrganizationId")
.HasAnnotation("SqlServer:Clustered", false);
b.HasIndex("OrganizationId", "Type")
.IsUnique()
.HasAnnotation("SqlServer:Clustered", false);
b.ToTable("Policy", (string)null);
});
modelBuilder.Entity("Bit.Infrastructure.EntityFramework.AdminConsole.Models.Provider.Provider", b =>
{
b.Property("Id")
.HasColumnType("char(36)");
b.Property("BillingEmail")
.HasColumnType("longtext");
b.Property("BillingPhone")
.HasColumnType("longtext");
b.Property("BusinessAddress1")
.HasColumnType("longtext");
b.Property("BusinessAddress2")
.HasColumnType("longtext");
b.Property("BusinessAddress3")
.HasColumnType("longtext");
b.Property("BusinessCountry")
.HasColumnType("longtext");
b.Property("BusinessName")
.HasColumnType("longtext");
b.Property("BusinessTaxNumber")
.HasColumnType("longtext");
b.Property("CreationDate")
.HasColumnType("datetime(6)");
b.Property("Enabled")
.HasColumnType("tinyint(1)");
b.Property("Gateway")
.HasColumnType("tinyint unsigned");
b.Property("GatewayCustomerId")
.HasColumnType("longtext");
b.Property("GatewaySubscriptionId")
.HasColumnType("longtext");
b.Property("Name")
.HasColumnType("longtext");
b.Property("RevisionDate")
.HasColumnType("datetime(6)");
b.Property("Status")
.HasColumnType("tinyint unsigned");
b.Property("Type")
.HasColumnType("tinyint unsigned");
b.Property("UseEvents")
.HasColumnType("tinyint(1)");
b.HasKey("Id");
b.ToTable("Provider", (string)null);
});
modelBuilder.Entity("Bit.Infrastructure.EntityFramework.AdminConsole.Models.Provider.ProviderOrganization", b =>
{
b.Property("Id")
.HasColumnType("char(36)");
b.Property("CreationDate")
.HasColumnType("datetime(6)");
b.Property("Key")
.HasColumnType("longtext");
b.Property("OrganizationId")
.HasColumnType("char(36)");
b.Property("ProviderId")
.HasColumnType("char(36)");
b.Property("RevisionDate")
.HasColumnType("datetime(6)");
b.Property("Settings")
.HasColumnType("longtext");
b.HasKey("Id");
b.HasIndex("OrganizationId");
b.HasIndex("ProviderId");
b.ToTable("ProviderOrganization", (string)null);
});
modelBuilder.Entity("Bit.Infrastructure.EntityFramework.AdminConsole.Models.Provider.ProviderUser", b =>
{
b.Property("Id")
.HasColumnType("char(36)");
b.Property("CreationDate")
.HasColumnType("datetime(6)");
b.Property("Email")
.HasColumnType("longtext");
b.Property("Key")
.HasColumnType("longtext");
b.Property("Permissions")
.HasColumnType("longtext");
b.Property("ProviderId")
.HasColumnType("char(36)");
b.Property("RevisionDate")
.HasColumnType("datetime(6)");
b.Property("Status")
.HasColumnType("tinyint unsigned");
b.Property("Type")
.HasColumnType("tinyint unsigned");
b.Property("UserId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("ProviderId");
b.HasIndex("UserId");
b.ToTable("ProviderUser", (string)null);
});
modelBuilder.Entity("Bit.Infrastructure.EntityFramework.Auth.Models.AuthRequest", b =>
{
b.Property("Id")
.HasColumnType("char(36)");
b.Property("AccessCode")
.HasMaxLength(25)
.HasColumnType("varchar(25)");
b.Property("Approved")
.HasColumnType("tinyint(1)");
b.Property("AuthenticationDate")
.HasColumnType("datetime(6)");
b.Property("CreationDate")
.HasColumnType("datetime(6)");
b.Property("Key")
.HasColumnType("longtext");
b.Property("MasterPasswordHash")
.HasColumnType("longtext");
b.Property("OrganizationId")
.HasColumnType("char(36)");
b.Property("PublicKey")
.HasColumnType("longtext");
b.Property("RequestDeviceIdentifier")
.HasMaxLength(50)
.HasColumnType("varchar(50)");
b.Property("RequestDeviceType")
.HasColumnType("tinyint unsigned");
b.Property("RequestIpAddress")
.HasMaxLength(50)
.HasColumnType("varchar(50)");
b.Property("ResponseDate")
.HasColumnType("datetime(6)");
b.Property("ResponseDeviceId")
.HasColumnType("char(36)");
b.Property("Type")
.HasColumnType("tinyint unsigned");
b.Property("UserId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("OrganizationId");
b.HasIndex("ResponseDeviceId");
b.HasIndex("UserId");
b.ToTable("AuthRequest", (string)null);
});
modelBuilder.Entity("Bit.Infrastructure.EntityFramework.Auth.Models.EmergencyAccess", b =>
{
b.Property("Id")
.HasColumnType("char(36)");
b.Property("CreationDate")
.HasColumnType("datetime(6)");
b.Property("Email")
.HasMaxLength(256)
.HasColumnType("varchar(256)");
b.Property("GranteeId")
.HasColumnType("char(36)");
b.Property("GrantorId")
.HasColumnType("char(36)");
b.Property("KeyEncrypted")
.HasColumnType("longtext");
b.Property("LastNotificationDate")
.HasColumnType("datetime(6)");
b.Property("RecoveryInitiatedDate")
.HasColumnType("datetime(6)");
b.Property("RevisionDate")
.HasColumnType("datetime(6)");
b.Property("Status")
.HasColumnType("tinyint unsigned");
b.Property("Type")
.HasColumnType("tinyint unsigned");
b.Property("WaitTimeDays")
.HasColumnType("int");
b.HasKey("Id");
b.HasIndex("GranteeId");
b.HasIndex("GrantorId");
b.ToTable("EmergencyAccess", (string)null);
});
modelBuilder.Entity("Bit.Infrastructure.EntityFramework.Auth.Models.Grant", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
MySqlPropertyBuilderExtensions.UseMySqlIdentityColumn(b.Property("Id"));
b.Property("ClientId")
.IsRequired()
.HasMaxLength(200)
.HasColumnType("varchar(200)");
b.Property("ConsumedDate")
.HasColumnType("datetime(6)");
b.Property("CreationDate")
.HasColumnType("datetime(6)");
b.Property("Data")
.IsRequired()
.HasColumnType("longtext");
b.Property("Description")
.HasMaxLength(200)
.HasColumnType("varchar(200)");
b.Property("ExpirationDate")
.HasColumnType("datetime(6)");
b.Property("Key")
.IsRequired()
.HasMaxLength(200)
.HasColumnType("varchar(200)");
b.Property("SessionId")
.HasMaxLength(100)
.HasColumnType("varchar(100)");
b.Property("SubjectId")
.HasMaxLength(200)
.HasColumnType("varchar(200)");
b.Property("Type")
.IsRequired()
.HasMaxLength(50)
.HasColumnType("varchar(50)");
b.HasKey("Id")
.HasName("PK_Grant")
.HasAnnotation("SqlServer:Clustered", true);
b.HasIndex("ExpirationDate")
.HasAnnotation("SqlServer:Clustered", false);
b.HasIndex("Key")
.IsUnique();
b.ToTable("Grant", (string)null);
});
modelBuilder.Entity("Bit.Infrastructure.EntityFramework.Auth.Models.SsoConfig", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("bigint");
MySqlPropertyBuilderExtensions.UseMySqlIdentityColumn(b.Property("Id"));
b.Property("CreationDate")
.HasColumnType("datetime(6)");
b.Property("Data")
.HasColumnType("longtext");
b.Property("Enabled")
.HasColumnType("tinyint(1)");
b.Property("OrganizationId")
.HasColumnType("char(36)");
b.Property("RevisionDate")
.HasColumnType("datetime(6)");
b.HasKey("Id");
b.HasIndex("OrganizationId");
b.ToTable("SsoConfig", (string)null);
});
modelBuilder.Entity("Bit.Infrastructure.EntityFramework.Auth.Models.SsoUser", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("bigint");
MySqlPropertyBuilderExtensions.UseMySqlIdentityColumn(b.Property("Id"));
b.Property("CreationDate")
.HasColumnType("datetime(6)");
b.Property("ExternalId")
.HasMaxLength(50)
.HasColumnType("varchar(50)");
b.Property("OrganizationId")
.HasColumnType("char(36)");
b.Property("UserId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("OrganizationId")
.HasAnnotation("SqlServer:Clustered", false);
b.HasIndex("UserId");
b.HasIndex("OrganizationId", "ExternalId")
.IsUnique()
.HasAnnotation("Npgsql:IndexInclude", new[] { "UserId" })
.HasAnnotation("SqlServer:Clustered", false);
b.HasIndex("OrganizationId", "UserId")
.IsUnique()
.HasAnnotation("SqlServer:Clustered", false);
b.ToTable("SsoUser", (string)null);
});
modelBuilder.Entity("Bit.Infrastructure.EntityFramework.Auth.Models.WebAuthnCredential", b =>
{
b.Property("Id")
.HasColumnType("char(36)");
b.Property("AaGuid")
.HasColumnType("char(36)");
b.Property("Counter")
.HasColumnType("int");
b.Property("CreationDate")
.HasColumnType("datetime(6)");
b.Property("CredentialId")
.HasMaxLength(256)
.HasColumnType("varchar(256)");
b.Property("EncryptedPrivateKey")
.HasMaxLength(2000)
.HasColumnType("varchar(2000)");
b.Property("EncryptedPublicKey")
.HasMaxLength(2000)
.HasColumnType("varchar(2000)");
b.Property("EncryptedUserKey")
.HasMaxLength(2000)
.HasColumnType("varchar(2000)");
b.Property("Name")
.HasMaxLength(50)
.HasColumnType("varchar(50)");
b.Property("PublicKey")
.HasMaxLength(256)
.HasColumnType("varchar(256)");
b.Property("RevisionDate")
.HasColumnType("datetime(6)");
b.Property("SupportsPrf")
.HasColumnType("tinyint(1)");
b.Property("Type")
.HasMaxLength(20)
.HasColumnType("varchar(20)");
b.Property("UserId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("UserId");
b.ToTable("WebAuthnCredential", (string)null);
});
modelBuilder.Entity("Bit.Infrastructure.EntityFramework.Billing.Models.ProviderInvoiceItem", b =>
{
b.Property("Id")
.HasColumnType("char(36)");
b.Property("AssignedSeats")
.HasColumnType("int");
b.Property("ClientId")
.HasColumnType("char(36)");
b.Property("ClientName")
.IsRequired()
.HasMaxLength(50)
.HasColumnType("varchar(50)");
b.Property("Created")
.HasColumnType("datetime(6)");
b.Property("InvoiceId")
.IsRequired()
.HasMaxLength(50)
.HasColumnType("varchar(50)");
b.Property("InvoiceNumber")
.HasMaxLength(50)
.HasColumnType("varchar(50)");
b.Property("PlanName")
.IsRequired()
.HasMaxLength(50)
.HasColumnType("varchar(50)");
b.Property("ProviderId")
.HasColumnType("char(36)");
b.Property("Total")
.HasColumnType("decimal(65,30)");
b.Property("UsedSeats")
.HasColumnType("int");
b.HasKey("Id");
b.HasIndex("ProviderId");
b.ToTable("ProviderInvoiceItem", (string)null);
});
modelBuilder.Entity("Bit.Infrastructure.EntityFramework.Billing.Models.ProviderPlan", b =>
{
b.Property("Id")
.HasColumnType("char(36)");
b.Property("AllocatedSeats")
.HasColumnType("int");
b.Property("PlanType")
.HasColumnType("tinyint unsigned");
b.Property("ProviderId")
.HasColumnType("char(36)");
b.Property("PurchasedSeats")
.HasColumnType("int");
b.Property("SeatMinimum")
.HasColumnType("int");
b.HasKey("Id");
b.HasIndex("ProviderId");
b.HasIndex("Id", "PlanType")
.IsUnique();
b.ToTable("ProviderPlan", (string)null);
});
modelBuilder.Entity("Bit.Infrastructure.EntityFramework.Models.Cache", b =>
{
b.Property("Id")
.HasMaxLength(449)
.HasColumnType("varchar(449)");
b.Property("AbsoluteExpiration")
.HasColumnType("datetime(6)");
b.Property("ExpiresAtTime")
.HasColumnType("datetime(6)");
b.Property("SlidingExpirationInSeconds")
.HasColumnType("bigint");
b.Property("Value")
.IsRequired()
.HasColumnType("longblob");
b.HasKey("Id")
.HasAnnotation("SqlServer:Clustered", true);
b.HasIndex("ExpiresAtTime")
.HasAnnotation("SqlServer:Clustered", false);
b.ToTable("Cache", (string)null);
});
modelBuilder.Entity("Bit.Infrastructure.EntityFramework.Models.Collection", b =>
{
b.Property("Id")
.HasColumnType("char(36)");
b.Property("CreationDate")
.HasColumnType("datetime(6)");
b.Property("ExternalId")
.HasMaxLength(300)
.HasColumnType("varchar(300)");
b.Property("Name")
.IsRequired()
.HasColumnType("longtext");
b.Property("OrganizationId")
.HasColumnType("char(36)");
b.Property("RevisionDate")
.HasColumnType("datetime(6)");
b.HasKey("Id");
b.HasIndex("OrganizationId");
b.ToTable("Collection", (string)null);
});
modelBuilder.Entity("Bit.Infrastructure.EntityFramework.Models.CollectionCipher", b =>
{
b.Property("CollectionId")
.HasColumnType("char(36)");
b.Property("CipherId")
.HasColumnType("char(36)");
b.HasKey("CollectionId", "CipherId");
b.HasIndex("CipherId");
b.ToTable("CollectionCipher", (string)null);
});
modelBuilder.Entity("Bit.Infrastructure.EntityFramework.Models.CollectionGroup", b =>
{
b.Property("CollectionId")
.HasColumnType("char(36)");
b.Property("GroupId")
.HasColumnType("char(36)");
b.Property("HidePasswords")
.HasColumnType("tinyint(1)");
b.Property("Manage")
.HasColumnType("tinyint(1)");
b.Property("ReadOnly")
.HasColumnType("tinyint(1)");
b.HasKey("CollectionId", "GroupId");
b.HasIndex("GroupId");
b.ToTable("CollectionGroups");
});
modelBuilder.Entity("Bit.Infrastructure.EntityFramework.Models.CollectionUser", b =>
{
b.Property("CollectionId")
.HasColumnType("char(36)");
b.Property("OrganizationUserId")
.HasColumnType("char(36)");
b.Property("HidePasswords")
.HasColumnType("tinyint(1)");
b.Property("Manage")
.HasColumnType("tinyint(1)");
b.Property("ReadOnly")
.HasColumnType("tinyint(1)");
b.HasKey("CollectionId", "OrganizationUserId");
b.HasIndex("OrganizationUserId");
b.ToTable("CollectionUsers");
});
modelBuilder.Entity("Bit.Infrastructure.EntityFramework.Models.Device", b =>
{
b.Property("Id")
.ValueGeneratedOnAdd()
.HasColumnType("char(36)");
b.Property("CreationDate")
.HasColumnType("datetime(6)");
b.Property("EncryptedPrivateKey")
.HasColumnType("longtext");
b.Property("EncryptedPublicKey")
.HasColumnType("longtext");
b.Property("EncryptedUserKey")
.HasColumnType("longtext");
b.Property("Identifier")
.IsRequired()
.HasMaxLength(50)
.HasColumnType("varchar(50)");
b.Property("Name")
.IsRequired()
.HasMaxLength(50)
.HasColumnType("varchar(50)");
b.Property("PushToken")
.HasMaxLength(255)
.HasColumnType("varchar(255)");
b.Property("RevisionDate")
.HasColumnType("datetime(6)");
b.Property("Type")
.HasColumnType("tinyint unsigned");
b.Property("UserId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("Identifier")
.HasAnnotation("SqlServer:Clustered", false);
b.HasIndex("UserId")
.HasAnnotation("SqlServer:Clustered", false);
b.HasIndex("UserId", "Identifier")
.IsUnique()
.HasAnnotation("SqlServer:Clustered", false);
b.ToTable("Device", (string)null);
});
modelBuilder.Entity("Bit.Infrastructure.EntityFramework.Models.Event", b =>
{
b.Property("Id")
.HasColumnType("char(36)");
b.Property("ActingUserId")
.HasColumnType("char(36)");
b.Property("CipherId")
.HasColumnType("char(36)");
b.Property("CollectionId")
.HasColumnType("char(36)");
b.Property("Date")
.HasColumnType("datetime(6)");
b.Property("DeviceType")
.HasColumnType("tinyint unsigned");
b.Property("DomainName")
.HasColumnType("longtext");
b.Property("GroupId")
.HasColumnType("char(36)");
b.Property("InstallationId")
.HasColumnType("char(36)");
b.Property("IpAddress")
.HasMaxLength(50)
.HasColumnType("varchar(50)");
b.Property("OrganizationId")
.HasColumnType("char(36)");
b.Property("OrganizationUserId")
.HasColumnType("char(36)");
b.Property("PolicyId")
.HasColumnType("char(36)");
b.Property("ProviderId")
.HasColumnType("char(36)");
b.Property("ProviderOrganizationId")
.HasColumnType("char(36)");
b.Property("ProviderUserId")
.HasColumnType("char(36)");
b.Property("SecretId")
.HasColumnType("char(36)");
b.Property("ServiceAccountId")
.HasColumnType("char(36)");
b.Property("SystemUser")
.HasColumnType("tinyint unsigned");
b.Property("Type")
.HasColumnType("int");
b.Property("UserId")
.HasColumnType("char(36)");
b.HasKey("Id");
b.HasIndex("Date", "OrganizationId", "ActingUserId", "CipherId")
.HasAnnotation("SqlServer:Clustered", false);
b.ToTable("Event", (string)null);
});
modelBuilder.Entity("Bit.Infrastructure.EntityFramework.Models.Group", b =>
{
b.Property("Id")
.HasColumnType("char(36)");
b.Property("AccessAll")
.ValueGeneratedOnAdd()
.HasColumnType("tinyint(1)")
.HasDefaultValue(false);
b.Property("CreationDate")
.HasColumnType("datetime(6)");
b.Property("ExternalId")
.HasMaxLength(300)
.HasColumnType("varchar(300)");
b.Property("Name")
.IsRequired()
.HasMaxLength(100)
.HasColumnType("varchar(100)");
b.Property("OrganizationId")
.HasColumnType("char(36)");
b.Property("RevisionDate")
.HasColumnType("datetime(6)");
b.HasKey("Id");
b.HasIndex("OrganizationId");
b.ToTable("Group", (string)null);
});
modelBuilder.Entity("Bit.Infrastructure.EntityFramework.Models.GroupUser", b =>
{
b.Property("GroupId")
.HasColumnType("char(36)");
b.Property("OrganizationUserId")
.HasColumnType("char(36)");
b.HasKey("GroupId", "OrganizationUserId");
b.HasIndex("OrganizationUserId");
b.ToTable("GroupUser", (string)null);
});
modelBuilder.Entity("Bit.Infrastructure.EntityFramework.Models.Installation", b =>
{
b.Property("Id")
.HasColumnType("char(36)");
b.Property("CreationDate")
.HasColumnType("datetime(6)");
b.Property("Email")
.IsRequired()
.HasMaxLength(256)
.HasColumnType("varchar(256)");
b.Property("Enabled")
.HasColumnType("tinyint(1)");
b.Property("Key")
.IsRequired()
.HasMaxLength(150)
.HasColumnType("varchar(150)");
b.HasKey("Id");
b.ToTable("Installation", (string)null);
});
modelBuilder.Entity("Bit.Infrastructure.EntityFramework.Models.OrganizationApiKey", b =>
{
b.Property("Id")
.HasColumnType("char(36)");
b.Property("ApiKey")
.IsRequired()
.HasMaxLength(30)
.HasColumnType("varchar(30)");
b.Property("OrganizationId")
.HasColumnType("char(36)");
b.Property("RevisionDate")
.HasColumnType("datetime(6)");
b.Property("Type")
.HasColumnType("tinyint unsigned");
b.HasKey("Id");
b.HasIndex("OrganizationId");
b.ToTable("OrganizationApiKey", (string)null);
});
modelBuilder.Entity("Bit.Infrastructure.EntityFramework.Models.OrganizationConnection", b =>
{
b.Property