mirror of
https://github.com/bitwarden/server.git
synced 2025-01-19 21:21:22 +01:00
b13dda2799
* EF Database Support Init (#1221) * scaffolding for ef support * deleted old postgres repos * added tables to oncreate * updated all the things to .NET 5 * Addition to #1221: Migrated DockerFiles from dotnet/3.1 to 5.0 (#1223) * Migrated DockerFiles from dotnet/3.1 to 5.0 * Migrated SSO/Dockerfile from dotnet 3.1 to 5.0 Co-authored-by: Daniel James Smith <djsmith85@users.noreply.github.com> * EFDatabaseSupport: Updated links and description in README.md and SETUP.md (#1232) * Updated requirements in README.md * Updated link to documentation of app-secrets * upgraded dotnet version to 5.0 * Ef database support implementation examples (#1265) * mostly finished testing the user repo * finished testing user repo * finished org, user, ssoconfig, and ssouser ef implementations * removed unused prop * fixed a sql file * fixed a spacing issue * fixed a spacing issue * removed extra database creation * refactoring * MsSql => SqlServer * refactoring * code review fixes * build fix * code review * continued attempts to fix the the build * skipped another test * finished all create test * initial pass at several repos * continued building out repos * initial pass at several repos * initial pass at device repo * initial pass at collection repo * initial run of all Entity Framework implementations * signup, signin, create/edit ciphers works * sync working * all web vault pages seem to load with 100% 200s * bulkcopy, folders, and favorites * group and collection management * sso, groups, emergency access, send * get basic creates matching on all repos * got everything building again post merge * removed some IDE config files * cleanup * no more notimplemented methods in the cipher repo * no more not implementeds everywhere * cleaned up schema/navigation properties and fixed tests * removed a sql comment that was written in c# style * fixed build issues from merge * removed unsupported db providers * formatting * code review refactors * naming cleanup for queries * added provider methods * cipher repo cleanup * implemented several missing procedures from the EF implementation surround account revision dates, keys, and storage * fixed the build * added a null check * consolidated some cipher repo methods * formatting fix * cleaned up indentation of queries * removed .idea file * generated postgres migrations * added mysql migrations * formatting * Bug Fixes & Formatting * Formatting * fixed a bug with bulk import when using MySql * code review fixes * fixed the build * implemented new methods * formatting * fixed the build * cleaned up select statements in ef queries * formatting * formatting * formatting Co-authored-by: Daniel James Smith <djsmith85@users.noreply.github.com>
193 lines
7.8 KiB
C#
193 lines
7.8 KiB
C#
using System;
|
|
using System.Collections.Generic;
|
|
using System.Linq;
|
|
using System.Text.Json;
|
|
using AutoFixture;
|
|
using Bit.Core.Enums;
|
|
using Bit.Core.Models.Business;
|
|
using Bit.Core.Models.Data;
|
|
using TableModel = Bit.Core.Models.Table;
|
|
using Bit.Core.Test.AutoFixture.Attributes;
|
|
using Bit.Core.Test.AutoFixture.GlobalSettingsFixtures;
|
|
using Bit.Core.Utilities;
|
|
using AutoFixture.Kernel;
|
|
using Bit.Core.Models;
|
|
using Bit.Core.Test.AutoFixture.EntityFrameworkRepositoryFixtures;
|
|
using Bit.Core.Repositories.EntityFramework;
|
|
|
|
namespace Bit.Core.Test.AutoFixture.OrganizationFixtures
|
|
{
|
|
public class Organization : ICustomization
|
|
{
|
|
public bool UseGroups { get; set; }
|
|
|
|
public void Customize(IFixture fixture)
|
|
{
|
|
var organizationId = Guid.NewGuid();
|
|
var maxConnections = (short)new Random().Next(10, short.MaxValue);
|
|
|
|
fixture.Customize<Core.Models.Table.Organization>(composer => composer
|
|
.With(o => o.Id, organizationId)
|
|
.With(o => o.MaxCollections, maxConnections)
|
|
.With(o => o.UseGroups, UseGroups));
|
|
|
|
fixture.Customize<Core.Models.Table.Collection>(composer =>
|
|
composer
|
|
.With(c => c.OrganizationId, organizationId));
|
|
|
|
fixture.Customize<TableModel.Group>(composer => composer.With(g => g.OrganizationId, organizationId));
|
|
}
|
|
}
|
|
|
|
internal class OrganizationBuilder: ISpecimenBuilder
|
|
{
|
|
public object Create(object request, ISpecimenContext context)
|
|
{
|
|
if (context == null)
|
|
{
|
|
throw new ArgumentNullException(nameof(context));
|
|
}
|
|
|
|
var type = request as Type;
|
|
if (type == null || type != typeof(TableModel.Organization))
|
|
{
|
|
return new NoSpecimen();
|
|
}
|
|
|
|
var fixture = new Fixture();
|
|
var providers = fixture.Create<Dictionary<TwoFactorProviderType, TwoFactorProvider>>();
|
|
var organization = new Fixture().WithAutoNSubstitutions().Create<TableModel.Organization>();
|
|
organization.SetTwoFactorProviders(providers);
|
|
return organization;
|
|
}
|
|
}
|
|
|
|
internal class PaidOrganization : ICustomization
|
|
{
|
|
public PlanType CheckedPlanType { get; set; }
|
|
public void Customize(IFixture fixture)
|
|
{
|
|
var validUpgradePlans = StaticStore.Plans.Where(p => p.Type != Enums.PlanType.Free && !p.Disabled).Select(p => p.Type).ToList();
|
|
var lowestActivePaidPlan = validUpgradePlans.First();
|
|
CheckedPlanType = CheckedPlanType.Equals(Enums.PlanType.Free) ? lowestActivePaidPlan : CheckedPlanType;
|
|
validUpgradePlans.Remove(lowestActivePaidPlan);
|
|
fixture.Customize<Core.Models.Table.Organization>(composer => composer
|
|
.With(o => o.PlanType, CheckedPlanType));
|
|
fixture.Customize<OrganizationUpgrade>(composer => composer
|
|
.With(ou => ou.Plan, validUpgradePlans.First())) ;
|
|
}
|
|
}
|
|
|
|
internal class FreeOrganizationUpgrade : ICustomization
|
|
{
|
|
public void Customize(IFixture fixture)
|
|
{
|
|
fixture.Customize<Core.Models.Table.Organization>(composer => composer
|
|
.With(o => o.PlanType, PlanType.Free));
|
|
|
|
var plansToIgnore = new List<PlanType> { PlanType.Free, PlanType.Custom };
|
|
var selectedPlan = StaticStore.Plans.Last(p => !plansToIgnore.Contains(p.Type) && !p.Disabled);
|
|
|
|
fixture.Customize<OrganizationUpgrade>(composer => composer
|
|
.With(ou => ou.Plan, selectedPlan.Type)
|
|
.With(ou => ou.PremiumAccessAddon, selectedPlan.HasPremiumAccessOption));
|
|
fixture.Customize<Core.Models.Table.Organization>(composer => composer
|
|
.Without(o => o.GatewaySubscriptionId));
|
|
}
|
|
}
|
|
|
|
internal class OrganizationInvite : ICustomization
|
|
{
|
|
public OrganizationUserType InviteeUserType { get; set; }
|
|
public OrganizationUserType InvitorUserType { get; set; }
|
|
public string PermissionsBlob { get; set; }
|
|
public void Customize(IFixture fixture)
|
|
{
|
|
var organizationId = new Guid();
|
|
PermissionsBlob = PermissionsBlob ?? JsonSerializer.Serialize(new Permissions(), new JsonSerializerOptions
|
|
{
|
|
PropertyNamingPolicy = JsonNamingPolicy.CamelCase,
|
|
});
|
|
fixture.Customize<Core.Models.Table.Organization>(composer => composer
|
|
.With(o => o.Id, organizationId)
|
|
.With(o => o.Seats, (short)100));
|
|
fixture.Customize<TableModel.OrganizationUser>(composer => composer
|
|
.With(ou => ou.OrganizationId, organizationId)
|
|
.With(ou => ou.Type, InvitorUserType)
|
|
.With(ou => ou.Permissions, PermissionsBlob));
|
|
fixture.Customize<OrganizationUserInvite>(composer => composer
|
|
.With(oi => oi.Type, InviteeUserType));
|
|
}
|
|
}
|
|
|
|
internal class EfOrganization: ICustomization
|
|
{
|
|
public void Customize(IFixture fixture)
|
|
{
|
|
fixture.Customizations.Add(new IgnoreVirtualMembersCustomization());
|
|
fixture.Customizations.Add(new GlobalSettingsBuilder());
|
|
fixture.Customizations.Add(new OrganizationBuilder());
|
|
fixture.Customizations.Add(new EfRepositoryListBuilder<OrganizationRepository>());
|
|
}
|
|
}
|
|
|
|
internal class PaidOrganizationAutoDataAttribute : CustomAutoDataAttribute
|
|
{
|
|
public PaidOrganizationAutoDataAttribute(int planType = 0) : base(new SutProviderCustomization(),
|
|
new PaidOrganization { CheckedPlanType = (PlanType)planType })
|
|
{ }
|
|
}
|
|
|
|
internal class InlinePaidOrganizationAutoDataAttribute : InlineCustomAutoDataAttribute
|
|
{
|
|
public InlinePaidOrganizationAutoDataAttribute(params object[] values) : base(new[] { typeof(SutProviderCustomization),
|
|
typeof(PaidOrganization) }, values)
|
|
{ }
|
|
}
|
|
|
|
internal class FreeOrganizationUpgradeAutoDataAttribute : CustomAutoDataAttribute
|
|
{
|
|
public FreeOrganizationUpgradeAutoDataAttribute() : base(new SutProviderCustomization(), new FreeOrganizationUpgrade())
|
|
{ }
|
|
}
|
|
|
|
internal class InlineFreeOrganizationUpgradeAutoDataAttribute : InlineCustomAutoDataAttribute
|
|
{
|
|
public InlineFreeOrganizationUpgradeAutoDataAttribute(params object[] values) : base(new[] { typeof(SutProviderCustomization),
|
|
typeof(FreeOrganizationUpgrade) }, values)
|
|
{ }
|
|
}
|
|
|
|
internal class OrganizationInviteAutoDataAttribute : CustomAutoDataAttribute
|
|
{
|
|
public OrganizationInviteAutoDataAttribute(int inviteeUserType = 0, int invitorUserType = 0, string permissionsBlob = null) : base(new SutProviderCustomization(),
|
|
new OrganizationInvite
|
|
{
|
|
InviteeUserType = (OrganizationUserType)inviteeUserType,
|
|
InvitorUserType = (OrganizationUserType)invitorUserType,
|
|
PermissionsBlob = permissionsBlob,
|
|
})
|
|
{ }
|
|
}
|
|
|
|
internal class InlineOrganizationInviteAutoDataAttribute : InlineCustomAutoDataAttribute
|
|
{
|
|
public InlineOrganizationInviteAutoDataAttribute(params object[] values) : base(new[] { typeof(SutProviderCustomization),
|
|
typeof(OrganizationInvite) }, values)
|
|
{ }
|
|
}
|
|
|
|
internal class EfOrganizationAutoDataAttribute : CustomAutoDataAttribute
|
|
{
|
|
public EfOrganizationAutoDataAttribute() : base(new SutProviderCustomization(), new EfOrganization())
|
|
{ }
|
|
}
|
|
|
|
internal class InlineEfOrganizationAutoDataAttribute : InlineCustomAutoDataAttribute
|
|
{
|
|
public InlineEfOrganizationAutoDataAttribute(params object[] values) : base(new[] { typeof(SutProviderCustomization),
|
|
typeof(EfOrganization) }, values)
|
|
{ }
|
|
}
|
|
}
|