Files
Umbraco-CMS/src/Umbraco.Tests/TestHelpers/ControllerTesting/AuthenticateEverythingMiddleware.cs

64 lines
2.1 KiB
C#
Raw Normal View History

using System;
2021-02-17 14:17:38 +01:00
using System.Security.Claims;
2017-09-14 19:29:12 +02:00
using System.Threading.Tasks;
using Microsoft.Owin;
using Microsoft.Owin.Security;
using Microsoft.Owin.Security.Infrastructure;
using Owin;
using Umbraco.Core.Security;
2021-02-17 14:17:38 +01:00
using Umbraco.Extensions;
2017-09-14 19:29:12 +02:00
namespace Umbraco.Tests.TestHelpers.ControllerTesting
{
/// <summary>
/// Ensures there's an admin user assigned to the request
/// </summary>
2017-09-14 19:29:12 +02:00
public class AuthenticateEverythingMiddleware : AuthenticationMiddleware<AuthenticationOptions>
{
public AuthenticateEverythingMiddleware(OwinMiddleware next, IAppBuilder app, AuthenticationOptions options)
: base(next, options)
{
}
protected override AuthenticationHandler<AuthenticationOptions> CreateHandler()
{
return new AuthenticateEverythingHandler();
}
public class AuthenticateEverythingHandler : AuthenticationHandler<AuthenticationOptions>
{
protected override Task<AuthenticationTicket> AuthenticateCoreAsync()
{
var securityStamp = Guid.NewGuid().ToString();
2021-02-17 14:17:38 +01:00
var identity = new ClaimsIdentity();
identity.AddRequiredClaims(Core.Constants.Security.SuperUserIdAsString,
"admin",
"Admin",
new[] { -1 },
new[] { -1 },
"en-US",
securityStamp,
new[] { "content", "media", "members" },
new[] { "admin" });
2017-09-14 19:29:12 +02:00
return Task.FromResult(new AuthenticationTicket(
identity,
2017-09-14 19:29:12 +02:00
new AuthenticationProperties()
{
ExpiresUtc = DateTime.Now.AddDays(1)
}));
}
}
public class AuthenticateEverythingAuthenticationOptions : AuthenticationOptions
{
public AuthenticateEverythingAuthenticationOptions()
: base("AuthenticateEverything")
{
AuthenticationMode = AuthenticationMode.Active;
}
}
}
2017-09-23 10:08:18 +02:00
}