Add role store to service collection. Updated tests with new role methods.

This commit is contained in:
Emma Garland
2021-03-06 10:53:34 +00:00
parent e124ee336a
commit 3d53690048
9 changed files with 290 additions and 102 deletions

View File

@@ -1,4 +1,4 @@
using System;
using System;
using System.Collections.Generic;
using Umbraco.Cms.Core.Models;

View File

@@ -1,7 +1,4 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Security.Claims;
using System.Threading;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Identity;
@@ -13,35 +10,27 @@ namespace Umbraco.Cms.Core.Security
/// <summary>
/// A custom user store that uses Umbraco member data
/// </summary>
public class MemberRoleStore : RoleStoreBase<IdentityRole<string>, string, IdentityUserRole<string>, IdentityRoleClaim<string>>
public class MemberRoleStore<TRole> : IRoleStore<TRole> where TRole : IdentityRole
{
private readonly IMemberGroupService _memberGroupService;
private bool _disposed;
public MemberRoleStore(IMemberGroupService memberGroupService, IdentityErrorDescriber describer)
: base(describer) => _memberGroupService = memberGroupService ?? throw new ArgumentNullException(nameof(memberGroupService));
public MemberRoleStore(IMemberGroupService memberGroupService, IdentityErrorDescriber errorDescriber)
{
_memberGroupService = memberGroupService ?? throw new ArgumentNullException(nameof(memberGroupService));
ErrorDescriber = errorDescriber ?? throw new ArgumentNullException(nameof(errorDescriber));
}
/// <summary>
/// Gets or sets the <see cref="IdentityErrorDescriber"/> for any error that occurred with the current operation.
/// </summary>
public IdentityErrorDescriber ErrorDescriber { get; set; }
/// <inheritdoc />
public override IQueryable<IdentityRole<string>> Roles
{
get
{
IEnumerable<IMemberGroup> memberGroups = _memberGroupService.GetAll();
var identityRoles = new List<IdentityRole<string>>();
foreach (IMemberGroup group in memberGroups)
{
IdentityRole<string> identityRole = MapFromMemberGroup(group);
identityRoles.Add(identityRole);
}
return identityRoles.AsQueryable();
}
}
/// <inheritdoc />
public override Task<IdentityResult> CreateAsync(
IdentityRole<string> role,
CancellationToken cancellationToken = new CancellationToken())
public Task<IdentityResult> CreateAsync(TRole role, CancellationToken cancellationToken = new CancellationToken())
{
cancellationToken.ThrowIfCancellationRequested();
ThrowIfDisposed();
if (role == null)
{
throw new ArgumentNullException(nameof(role));
@@ -61,9 +50,10 @@ namespace Umbraco.Cms.Core.Security
/// <inheritdoc />
public override Task<IdentityResult> UpdateAsync(IdentityRole<string> role,
CancellationToken cancellationToken = new CancellationToken())
public Task<IdentityResult> UpdateAsync(TRole role, CancellationToken cancellationToken = new CancellationToken())
{
cancellationToken.ThrowIfCancellationRequested();
ThrowIfDisposed();
if (role == null)
{
throw new ArgumentNullException(nameof(role));
@@ -93,9 +83,10 @@ namespace Umbraco.Cms.Core.Security
}
/// <inheritdoc />
public override Task<IdentityResult> DeleteAsync(IdentityRole<string> role,
CancellationToken cancellationToken = new CancellationToken())
public Task<IdentityResult> DeleteAsync(TRole role, CancellationToken cancellationToken = new CancellationToken())
{
cancellationToken.ThrowIfCancellationRequested();
ThrowIfDisposed();
if (role == null)
{
throw new ArgumentNullException(nameof(role));
@@ -122,9 +113,60 @@ namespace Umbraco.Cms.Core.Security
}
/// <inheritdoc />
public override Task<IdentityRole<string>> FindByIdAsync(string id,
CancellationToken cancellationToken = new CancellationToken())
public Task<string> GetRoleIdAsync(TRole role, CancellationToken cancellationToken)
{
cancellationToken.ThrowIfCancellationRequested();
ThrowIfDisposed();
if (role == null)
{
throw new ArgumentNullException(nameof(role));
}
return Task.FromResult(role.Id);
}
public Task<string> GetRoleNameAsync(TRole role, CancellationToken cancellationToken)
{
cancellationToken.ThrowIfCancellationRequested();
ThrowIfDisposed();
if (!int.TryParse(role.Id, out int roleId))
{
return null;
}
IMemberGroup memberGroup = _memberGroupService.GetById(roleId);
return Task.FromResult(memberGroup?.Name);
}
public Task SetRoleNameAsync(TRole role, string roleName, CancellationToken cancellationToken)
{
cancellationToken.ThrowIfCancellationRequested();
ThrowIfDisposed();
return null;
}
public Task<string> GetNormalizedRoleNameAsync(TRole role, CancellationToken cancellationToken)
{
cancellationToken.ThrowIfCancellationRequested();
ThrowIfDisposed();
return null;
}
public Task SetNormalizedRoleNameAsync(TRole role, string normalizedName, CancellationToken cancellationToken)
{
cancellationToken.ThrowIfCancellationRequested();
ThrowIfDisposed();
return null;
}
/// <inheritdoc />
public Task<TRole> FindByIdAsync(string id, CancellationToken cancellationToken = new CancellationToken())
{
cancellationToken.ThrowIfCancellationRequested();
ThrowIfDisposed();
if (!int.TryParse(id, out int roleId))
{
return null;
@@ -136,39 +178,34 @@ namespace Umbraco.Cms.Core.Security
}
/// <inheritdoc />
public override Task<IdentityRole<string>> FindByNameAsync(string normalizedName,
CancellationToken cancellationToken = new CancellationToken())
public Task<TRole> FindByNameAsync(string name, CancellationToken cancellationToken = new CancellationToken())
{
IMemberGroup memberGroup = _memberGroupService.GetByName(normalizedName);
cancellationToken.ThrowIfCancellationRequested();
ThrowIfDisposed();
if (name == null)
{
throw new ArgumentNullException(nameof(name));
}
IMemberGroup memberGroup = _memberGroupService.GetByName(name);
return Task.FromResult(memberGroup == null ? null : MapFromMemberGroup(memberGroup));
}
///TODO: are we implementing these claims methods?
/// <inheritdoc />
public override Task<IList<Claim>> GetClaimsAsync(IdentityRole<string> role, CancellationToken cancellationToken = new CancellationToken()) => throw new System.NotImplementedException();
/// <inheritdoc />
public override Task AddClaimAsync(IdentityRole<string> role, Claim claim, CancellationToken cancellationToken = new CancellationToken()) => throw new System.NotImplementedException();
/// <inheritdoc />
public override Task RemoveClaimAsync(IdentityRole<string> role, Claim claim, CancellationToken cancellationToken = new CancellationToken()) => throw new System.NotImplementedException();
/// <summary>
/// Maps a member group to an identity role
/// </summary>
/// <param name="memberGroup"></param>
/// <returns></returns>
private IdentityRole<string> MapFromMemberGroup(IMemberGroup memberGroup)
private TRole MapFromMemberGroup(IMemberGroup memberGroup)
{
var result = new IdentityRole
{
Id = memberGroup.Id.ToString(),
Name = memberGroup.Name
//TODO: Are we interested in NormalizedRoleName?
};
return result;
return result as TRole;
}
/// <summary>
@@ -177,7 +214,7 @@ namespace Umbraco.Cms.Core.Security
/// <param name="role"></param>
/// <param name="memberGroup"></param>
/// <returns></returns>
private bool MapToMemberGroup(IdentityRole<string> role, IMemberGroup memberGroup)
private bool MapToMemberGroup(TRole role, IMemberGroup memberGroup)
{
var anythingChanged = false;
@@ -189,5 +226,21 @@ namespace Umbraco.Cms.Core.Security
return anythingChanged;
}
public void Dispose()
{
//TODO: is any dispose action necessary here or is this all managed by the IOC container?
}
/// <summary>
/// Throws if this class has been disposed.
/// </summary>
protected void ThrowIfDisposed()
{
if (_disposed)
{
throw new ObjectDisposedException(GetType().Name);
}
}
}
}

View File

@@ -1,4 +1,4 @@
using System;
using System;
using System.Collections.Generic;
using System.Linq;
using Microsoft.Extensions.Logging;
@@ -130,6 +130,25 @@ namespace Umbraco.Cms.Core.Services.Implement
}
}
public void GetByRole(IMemberGroup memberGroup)
{
using (var scope = ScopeProvider.CreateScope())
{
var deleteEventArgs = new DeleteEventArgs<IMemberGroup>(memberGroup);
if (scope.Events.DispatchCancelable(Deleting, this, deleteEventArgs))
{
scope.Complete();
return;
}
_memberGroupRepository.Delete(memberGroup);
scope.Complete();
deleteEventArgs.CanCancel = false;
scope.Events.Dispatch(Deleted, this, deleteEventArgs);
}
}
/// <summary>
/// Occurs before Delete of a member group
/// </summary>

View File

@@ -1,5 +1,4 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading;
using System.Threading.Tasks;
@@ -7,7 +6,6 @@ using Microsoft.AspNetCore.Identity;
using Moq;
using NUnit.Framework;
using Umbraco.Cms.Core.Models;
using Umbraco.Cms.Core.Scoping;
using Umbraco.Cms.Core.Security;
using Umbraco.Cms.Core.Services;
@@ -19,19 +17,19 @@ namespace Umbraco.Cms.Tests.UnitTests.Umbraco.Infrastructure.Security
private Mock<IMemberGroupService> _mockMemberGroupService;
private IdentityErrorDescriber ErrorDescriber => new IdentityErrorDescriber();
public MemberRoleStore CreateSut()
public MemberRoleStore<IdentityRole> CreateSut()
{
_mockMemberGroupService = new Mock<IMemberGroupService>();
return new MemberRoleStore(
return new MemberRoleStore<IdentityRole>(
_mockMemberGroupService.Object,
ErrorDescriber);
}
[Test]
public void GivenICreateAMemberRole_AndTheGroupIsNull_ThenIShouldGetAFailedResultAsync()
public void GivenICreateAMemberRole_AndTheGroupIsNull_ThenIShouldGetAnArgumentException()
{
// arrange
MemberRoleStore sut = CreateSut();
MemberRoleStore<IdentityRole> sut = CreateSut();
CancellationToken fakeCancellationToken = new CancellationToken() { };
// act
@@ -46,8 +44,8 @@ namespace Umbraco.Cms.Tests.UnitTests.Umbraco.Infrastructure.Security
public async Task GivenICreateAMemberRole_AndTheGroupIsPopulatedCorrectly_ThenIShouldGetASuccessResultAsync()
{
// arrange
MemberRoleStore sut = CreateSut();
var fakeRole = new IdentityRole<string>()
MemberRoleStore<IdentityRole> sut = CreateSut();
var fakeRole = new IdentityRole
{
Id = "777",
Name = "testname"
@@ -74,8 +72,8 @@ namespace Umbraco.Cms.Tests.UnitTests.Umbraco.Infrastructure.Security
public async Task GivenIUpdateAMemberRole_AndTheGroupExistsWithTheSameName_ThenIShouldGetASuccessResultAsyncButNoUpdatesMade()
{
// arrange
MemberRoleStore sut = CreateSut();
var fakeRole = new IdentityRole<string>()
MemberRoleStore<IdentityRole> sut = CreateSut();
var fakeRole = new IdentityRole
{
Id = "777",
Name = "fakeGroupName"
@@ -103,8 +101,8 @@ namespace Umbraco.Cms.Tests.UnitTests.Umbraco.Infrastructure.Security
public async Task GivenIUpdateAMemberRole_AndTheGroupExistsWithADifferentSameName_ThenIShouldGetASuccessResultAsyncWithUpdatesMade()
{
// arrange
MemberRoleStore sut = CreateSut();
var fakeRole = new IdentityRole<string>()
MemberRoleStore<IdentityRole> sut = CreateSut();
var fakeRole = new IdentityRole
{
Id = "777",
Name = "fakeGroup777"
@@ -133,8 +131,8 @@ namespace Umbraco.Cms.Tests.UnitTests.Umbraco.Infrastructure.Security
public async Task GivenIUpdateAMemberRole_AndTheGroupDoesntExist_ThenIShouldGetAFailureResultAsync()
{
// arrange
MemberRoleStore sut = CreateSut();
var fakeRole = new IdentityRole<string>()
MemberRoleStore<IdentityRole> sut = CreateSut();
var fakeRole = new IdentityRole
{
Id = "777",
Name = "testname"
@@ -157,31 +155,29 @@ namespace Umbraco.Cms.Tests.UnitTests.Umbraco.Infrastructure.Security
public async Task GivenIUpdateAMemberRole_AndTheIdCannotBeParsedToAnInt_ThenIShouldGetAFailureResultAsync()
{
// arrange
MemberRoleStore sut = CreateSut();
var fakeRole = new IdentityRole<string>()
MemberRoleStore<IdentityRole> sut = CreateSut();
var fakeRole = new IdentityRole
{
Id = "7a77",
Name = "testname"
};
var fakeCancellationToken = new CancellationToken() { };
bool raiseEvents = false;
// act
IdentityResult identityResult = await sut.UpdateAsync(fakeRole, fakeCancellationToken);
// assert
Assert.IsTrue(identityResult.Succeeded == false);
Assert.IsTrue(identityResult.Errors.Any(x => x.Code == "DefaultError" && x.Description == "An unknown failure has occurred."));
_mockMemberGroupService.VerifyNoOtherCalls();
}
[Test]
public async Task GivenIDeleteAMemberRole_AndItExists_ThenTheMemberGroupShouldBeDeleted_AndIShouldGetASuccessResultAsync()
{
// arrange
MemberRoleStore sut = CreateSut();
var fakeRole = new IdentityRole<string>()
MemberRoleStore<IdentityRole> sut = CreateSut();
var fakeRole = new IdentityRole
{
Id = "777",
Name = "testname"
@@ -201,14 +197,15 @@ namespace Umbraco.Cms.Tests.UnitTests.Umbraco.Infrastructure.Security
Assert.IsTrue(!identityResult.Errors.Any());
_mockMemberGroupService.Verify(x => x.GetById(777));
_mockMemberGroupService.Verify(x => x.Delete(mockMemberGroup));
_mockMemberGroupService.VerifyNoOtherCalls();
}
[Test]
public async Task GivenIDeleteAMemberRole_AndTheIdCannotBeParsedToAnInt_ThenTheMemberGroupShouldNotBeDeleted_AndIShouldGetAFailResultAsync()
{
// arrange
MemberRoleStore sut = CreateSut();
var fakeRole = new IdentityRole<string>()
MemberRoleStore<IdentityRole> sut = CreateSut();
var fakeRole = new IdentityRole
{
Id = "7a77",
Name = "testname"
@@ -225,6 +222,7 @@ namespace Umbraco.Cms.Tests.UnitTests.Umbraco.Infrastructure.Security
// assert
Assert.IsTrue(identityResult.Succeeded == false);
Assert.IsTrue(identityResult.Errors.Any(x => x.Code == "DefaultError" && x.Description == "An unknown failure has occurred."));
_mockMemberGroupService.VerifyNoOtherCalls();
}
@@ -232,8 +230,8 @@ namespace Umbraco.Cms.Tests.UnitTests.Umbraco.Infrastructure.Security
public async Task GivenIDeleteAMemberRole_AndItDoesntExist_ThenTheMemberGroupShouldNotBeDeleted_AndIShouldGetAFailResultAsync()
{
// arrange
MemberRoleStore sut = CreateSut();
var fakeRole = new IdentityRole<string>()
MemberRoleStore<IdentityRole> sut = CreateSut();
var fakeRole = new IdentityRole
{
Id = "777",
Name = "testname"
@@ -251,43 +249,142 @@ namespace Umbraco.Cms.Tests.UnitTests.Umbraco.Infrastructure.Security
Assert.IsTrue(identityResult.Succeeded == false);
Assert.IsTrue(identityResult.Errors.Any(x=>x.Code == "InvalidRoleName" && x.Description == "Role name 'testname' is invalid."));
_mockMemberGroupService.Verify(x => x.GetById(777));
_mockMemberGroupService.VerifyNoOtherCalls();
}
[Test]
public async Task GivenIGetAllMemberRoles_ThenIShouldGetAllMemberGroups_AndASuccessResultAsync()
public async Task GivenIFindAMemberRoleByRoleId_AndRoleIdExists_ThenIShouldGetASuccessResultAsync()
{
// arrange
MemberRoleStore sut = CreateSut();
MemberRoleStore<IdentityRole> sut = CreateSut();
var fakeRole = new IdentityRole<string>("fakeGroupName")
{
Id = "777"
};
IEnumerable<IdentityRole<string>> expected = new List<IdentityRole<string>>()
int fakeRoleId = 777;
IMemberGroup mockMemberGroup = Mock.Of<IMemberGroup>(m =>
m.Name == "fakeGroupName" &&
m.CreatorId == 123 &&
m.Id == 777);
var fakeCancellationToken = new CancellationToken() { };
_mockMemberGroupService.Setup(x => x.GetById(fakeRoleId)).Returns(mockMemberGroup);
// act
IdentityRole actual = await sut.FindByIdAsync(fakeRole.Id, fakeCancellationToken);
// assert
Assert.AreEqual(fakeRole.Name, actual.Name);
Assert.AreEqual(fakeRole.Id, actual.Id);
_mockMemberGroupService.Verify(x => x.GetById(fakeRoleId));
_mockMemberGroupService.VerifyNoOtherCalls();
}
[Test]
public void GivenIFindAMemberRoleByRoleId_AndIdCannotBeParsedToAnInt_ThenIShouldGetAFailureResultAsync()
{
fakeRole
// arrange
MemberRoleStore<IdentityRole> sut = CreateSut();
var fakeRole = new IdentityRole
{
Id = "7a77",
Name = "testname"
};
var fakeCancellationToken = new CancellationToken() { };
// act
Task<IdentityRole> actual = sut.FindByIdAsync(fakeRole.Id, fakeCancellationToken);
// assert
Assert.IsNull(actual);
_mockMemberGroupService.VerifyNoOtherCalls();
}
[Test]
public async Task GivenIFindAMemberRoleByRoleName_AndRoleNameExists_ThenIShouldGetASuccessResultAsync()
{
// arrange
MemberRoleStore<IdentityRole> sut = CreateSut();
var fakeRole = new IdentityRole("fakeGroupName")
{
Id = "777"
};
IMemberGroup mockMemberGroup = Mock.Of<IMemberGroup>(m =>
m.Name == "fakeGroupName" && m.CreatorId == 123 && m.Id == 777);
m.Name == "fakeGroupName" &&
m.CreatorId == 123 &&
m.Id == 777);
IEnumerable<IMemberGroup> fakeMemberGroups = new List<IMemberGroup>()
{
mockMemberGroup
};
_mockMemberGroupService.Setup(x => x.GetAll()).Returns(fakeMemberGroups);
_mockMemberGroupService.Setup(x => x.GetByName(fakeRole.Name)).Returns(mockMemberGroup);
// act
IQueryable<IdentityRole<string>> actual = sut.Roles;
IdentityRole actual = await sut.FindByNameAsync(fakeRole.Name);
// assert
Assert.AreEqual(expected.AsQueryable().First().Id, actual.First().Id);
Assert.AreEqual(expected.AsQueryable().First().Name, actual.First().Name);
//Always null:
//Assert.AreEqual(expected.AsQueryable().First().NormalizedName, actual.First().NormalizedName);
//Always different:
//Assert.AreEqual(expected.AsQueryable().First().ConcurrencyStamp, actual.First().ConcurrencyStamp);
_mockMemberGroupService.Verify(x => x.GetAll());
Assert.AreEqual(fakeRole.Name, actual.Name);
Assert.AreEqual(fakeRole.Id, actual.Id);
_mockMemberGroupService.Verify(x => x.GetByName(fakeRole.Name));
}
[Test]
public void GivenIFindAMemberRoleByRoleName_AndTheNameIsNull_ThenIShouldGetAnArgumentException()
{
// arrange
MemberRoleStore<IdentityRole> sut = CreateSut();
var fakeRole = new IdentityRole
{
Id = "777"
};
var fakeCancellationToken = new CancellationToken() { };
// act
Action actual = () => sut.FindByNameAsync(fakeRole.Name, fakeCancellationToken);
// assert
Assert.That(actual, Throws.ArgumentNullException);
_mockMemberGroupService.VerifyNoOtherCalls();
}
[Test]
public void GivenIGetAMemberRoleId_AndTheRoleIsNull_ThenIShouldGetAnArgumentException()
{
// arrange
MemberRoleStore<IdentityRole> sut = CreateSut();
var fakeCancellationToken = new CancellationToken() { };
// act
Action actual = () => sut.GetRoleIdAsync(null, fakeCancellationToken);
// assert
Assert.That(actual, Throws.ArgumentNullException);
}
[Test]
public void GivenIGetAMemberRoleId_AndTheRoleIsNotNull_ThenIShouldGetTheMemberRole()
{
// arrange
MemberRoleStore<IdentityRole> sut = CreateSut();
var fakeRole = new IdentityRole("fakeGroupName")
{
Id = "777"
};
string fakeRoleId = fakeRole.Id;
var fakeCancellationToken = new CancellationToken();
// act
Task<string> actual = sut.GetRoleIdAsync(fakeRole, fakeCancellationToken);
// assert
Assert.That(actual, Throws.ArgumentNullException);
// assert
Assert.AreEqual(fakeRoleId, actual.Result);
}
}
}

View File

@@ -38,4 +38,10 @@
<None Remove="umbraco\Data\TEMP\TypesCache\umbraco-types.DESKTOP-EU212M2.hash" />
</ItemGroup>
<ItemGroup>
<Reference Include="Umbraco.Infrastructure">
<HintPath>..\Umbraco.Web\bin\Debug\Umbraco.Infrastructure.dll</HintPath>
</Reference>
</ItemGroup>
</Project>

View File

@@ -28,13 +28,13 @@ namespace Umbraco.Cms.Web.BackOffice.Controllers
private readonly IMemberGroupService _memberGroupService;
private readonly UmbracoMapper _umbracoMapper;
private readonly ILocalizedTextService _localizedTextService;
private readonly RoleManager<IdentityRole<string>> _roleManager;
private readonly RoleManager<IdentityRole> _roleManager;
public MemberGroupController(
IMemberGroupService memberGroupService,
UmbracoMapper umbracoMapper,
ILocalizedTextService localizedTextService,
RoleManager<IdentityRole<string>> roleManager
RoleManager<IdentityRole> roleManager
)
{
_memberGroupService = memberGroupService ?? throw new ArgumentNullException(nameof(memberGroupService));
@@ -105,7 +105,7 @@ namespace Umbraco.Cms.Web.BackOffice.Controllers
foreach (int id in ids)
{
Task<IdentityRole<string>> role = _roleManager.FindByIdAsync(id.ToString());
Task<IdentityRole> role = _roleManager.FindByIdAsync(id.ToString());
roles.Add(role.Result);
}

View File

@@ -4,6 +4,7 @@ using Microsoft.AspNetCore.Identity;
using Microsoft.Extensions.Configuration;
using Microsoft.Extensions.DependencyInjection;
using Microsoft.Extensions.DependencyInjection.Extensions;
using Microsoft.Extensions.Options;
using SixLabors.ImageSharp.Memory;
using SixLabors.ImageSharp.Web.Caching;
using SixLabors.ImageSharp.Web.Commands;
@@ -62,12 +63,23 @@ namespace Umbraco.Extensions
/// <summary>
/// Adds the services required for using Members Identity
/// </summary>
public static void AddMembersIdentity(this IServiceCollection services) =>
public static void AddMembersIdentity(this IServiceCollection services)
{
services.BuildMembersIdentity()
.AddDefaultTokenProviders()
.AddMemberManager<IMemberManager, MemberManager>()
//.AddRoles<IdentityRole>()
.AddUserStore<MemberUserStore>()
.AddMembersManager<IMemberManager, MemberManager>();
.AddRoleStore<MemberRoleStore<IdentityRole>>()
.AddRoleValidator<RoleValidator<IdentityRole>>()
.AddRoleManager<RoleManager<IdentityRole>>();
//services.AddScoped<IUserClaimsPrincipalFactory<MemberIdentityUser>>(
// s => new UserClaimsPrincipalFactory<MemberIdentityUser, IdentityRole>(
// s.GetService<MemberManager>(),
// s.GetService<RoleManager<IdentityRole>>(),
// s.GetService<IOptions<IdentityOptions>>()));
}
private static MemberIdentityBuilder BuildMembersIdentity(this IServiceCollection services)
{
@@ -75,7 +87,7 @@ namespace Umbraco.Extensions
services.TryAddScoped<IUserValidator<MemberIdentityUser>, UserValidator<MemberIdentityUser>>();
services.TryAddScoped<IPasswordValidator<MemberIdentityUser>, PasswordValidator<MemberIdentityUser>>();
services.TryAddScoped<IPasswordHasher<MemberIdentityUser>, PasswordHasher<MemberIdentityUser>>();
return new MemberIdentityBuilder(services);
return new MemberIdentityBuilder(typeof(IdentityRole), services);
}
private static void RemoveIntParamenterIfValueGreatherThen(IDictionary<string, string> commands, string parameter, int maxValue)

View File

@@ -12,10 +12,10 @@ namespace Umbraco.Extensions
/// <summary>
/// Adds a <see cref="UserManager{TUser}"/> for the <seealso cref="MemberIdentityUser"/>.
/// </summary>
/// <typeparam name="TInterface">The usermanager interface</typeparam>
/// <typeparam name="TUserManager">The usermanager type</typeparam>
/// <typeparam name="TInterface">The member manager interface</typeparam>
/// <typeparam name="TUserManager">The member manager type</typeparam>
/// <returns>The current <see cref="IdentityBuilder"/> instance.</returns>
public static IdentityBuilder AddMembersManager<TInterface, TUserManager>(this IdentityBuilder identityBuilder)
public static IdentityBuilder AddMemberManager<TInterface, TUserManager>(this IdentityBuilder identityBuilder)
where TUserManager : UserManager<MemberIdentityUser>, TInterface
{
identityBuilder.Services.AddScoped(typeof(TInterface), typeof(TUserManager));

View File

@@ -22,6 +22,7 @@
</ItemGroup>
<ItemGroup>
<PackageReference Include="Microsoft.AspNet.Identity.Core" Version="2.2.3" />
<PackageReference Include="Microsoft.AspNetCore.Mvc.NewtonsoftJson" Version="5.0.2" />
<PackageReference Include="Microsoft.AspNetCore.Mvc.Razor.RuntimeCompilation" Version="5.0.2" />
<PackageReference Include="MiniProfiler.AspNetCore.Mvc" Version="4.2.22" />