Add role store to service collection. Updated tests with new role methods.
This commit is contained in:
@@ -1,4 +1,4 @@
|
||||
using System;
|
||||
using System;
|
||||
using System.Collections.Generic;
|
||||
using Umbraco.Cms.Core.Models;
|
||||
|
||||
|
||||
@@ -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);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -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>
|
||||
|
||||
@@ -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);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -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>
|
||||
|
||||
@@ -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);
|
||||
}
|
||||
|
||||
|
||||
@@ -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)
|
||||
|
||||
@@ -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));
|
||||
|
||||
@@ -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" />
|
||||
|
||||
Reference in New Issue
Block a user