using System; using System.Threading.Tasks; using Microsoft.Owin; using Microsoft.Owin.Security; using Microsoft.Owin.Security.Infrastructure; using Owin; using Umbraco.Core.BackOffice; namespace Umbraco.Tests.TestHelpers.ControllerTesting { /// /// Ensures there's an admin user assigned to the request /// public class AuthenticateEverythingMiddleware : AuthenticationMiddleware { public AuthenticateEverythingMiddleware(OwinMiddleware next, IAppBuilder app, AuthenticationOptions options) : base(next, options) { } protected override AuthenticationHandler CreateHandler() { return new AuthenticateEverythingHandler(); } public class AuthenticateEverythingHandler : AuthenticationHandler { protected override Task AuthenticateCoreAsync() { var securityStamp = Guid.NewGuid().ToString(); var identity = new UmbracoBackOfficeIdentity( -1, "admin", "Admin", new []{-1}, new[] { -1 }, "en-US", securityStamp, new[] { "content", "media", "members" }, new[] { "admin" }); return Task.FromResult(new AuthenticationTicket(identity, new AuthenticationProperties() { ExpiresUtc = DateTime.Now.AddDays(1) })); } } public class AuthenticateEverythingAuthenticationOptions : AuthenticationOptions { public AuthenticateEverythingAuthenticationOptions() : base("AuthenticateEverything") { AuthenticationMode = AuthenticationMode.Active; } } } }