2020-12-23 11:35:49 +01:00
|
|
|
// Copyright (c) Umbraco.
|
|
|
|
|
// See LICENSE for more details.
|
|
|
|
|
|
|
|
|
|
using System.Text.Encodings.Web;
|
2020-09-02 18:10:29 +10:00
|
|
|
using System.Threading.Tasks;
|
|
|
|
|
using Microsoft.AspNetCore.Authentication;
|
|
|
|
|
using Microsoft.Extensions.Logging;
|
|
|
|
|
using Microsoft.Extensions.Options;
|
2022-06-21 08:09:38 +02:00
|
|
|
using Umbraco.Cms.Core;
|
2021-02-09 10:22:42 +01:00
|
|
|
using Umbraco.Cms.Core.Mapping;
|
|
|
|
|
using Umbraco.Cms.Core.Models.Membership;
|
2021-02-15 12:01:12 +01:00
|
|
|
using Umbraco.Cms.Core.Security;
|
2021-02-09 10:22:42 +01:00
|
|
|
using Umbraco.Cms.Core.Services;
|
2021-02-10 11:11:18 +01:00
|
|
|
using Umbraco.Cms.Web.BackOffice.Security;
|
2020-09-02 18:10:29 +10:00
|
|
|
|
2022-06-21 08:09:38 +02:00
|
|
|
namespace Umbraco.Cms.Tests.Integration.TestServerTest;
|
|
|
|
|
|
|
|
|
|
public class TestAuthHandler : AuthenticationHandler<AuthenticationSchemeOptions>
|
2020-09-02 18:10:29 +10:00
|
|
|
{
|
2022-06-21 08:09:38 +02:00
|
|
|
public const string TestAuthenticationScheme = "Test";
|
|
|
|
|
|
|
|
|
|
private readonly IBackOfficeSignInManager _backOfficeSignInManager;
|
|
|
|
|
|
|
|
|
|
private readonly BackOfficeIdentityUser _fakeUser;
|
|
|
|
|
|
|
|
|
|
public TestAuthHandler(
|
|
|
|
|
IOptionsMonitor<AuthenticationSchemeOptions> options,
|
|
|
|
|
ILoggerFactory logger,
|
|
|
|
|
UrlEncoder encoder,
|
|
|
|
|
IBackOfficeSignInManager backOfficeSignInManager,
|
|
|
|
|
IUserService userService,
|
|
|
|
|
IUmbracoMapper umbracoMapper)
|
2023-10-12 13:58:51 +02:00
|
|
|
: base(options, logger, encoder)
|
2020-09-02 18:10:29 +10:00
|
|
|
{
|
2022-06-21 08:09:38 +02:00
|
|
|
_backOfficeSignInManager = backOfficeSignInManager;
|
|
|
|
|
|
|
|
|
|
var user = userService.GetUserById(Constants.Security.SuperUserId);
|
|
|
|
|
_fakeUser = umbracoMapper.Map<IUser, BackOfficeIdentityUser>(user);
|
|
|
|
|
_fakeUser.SecurityStamp = "Needed";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
protected override async Task<AuthenticateResult> HandleAuthenticateAsync()
|
|
|
|
|
{
|
|
|
|
|
var principal = await _backOfficeSignInManager.CreateUserPrincipalAsync(_fakeUser);
|
|
|
|
|
var ticket = new AuthenticationTicket(principal, TestAuthenticationScheme);
|
|
|
|
|
|
|
|
|
|
return AuthenticateResult.Success(ticket);
|
2020-09-02 18:10:29 +10:00
|
|
|
}
|
|
|
|
|
}
|