Moving AllowAnonymous attribute to Authorization

This commit is contained in:
Ajay Bhargav Baaskaran 2015-10-15 12:35:36 -07:00
parent f4a6d634b5
commit 6bd97c7c30
11 changed files with 63 additions and 20 deletions

View File

@ -2,6 +2,7 @@
// Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information.
using System;
using Microsoft.AspNet.Authorization;
using Microsoft.AspNet.Mvc;
using Microsoft.AspNet.Mvc.Filters;
using MvcSample.Web.Filters;

View File

@ -1,9 +1,9 @@
// Copyright (c) .NET Foundation. All rights reserved.
// Copyright (c) .NET Foundation. All rights reserved.
// Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information.
namespace Microsoft.AspNet.Mvc.Filters
{
public interface IAllowAnonymous : IFilterMetadata
public interface IAllowAnonymousFilter : IFilterMetadata
{
}
}

View File

@ -1,13 +0,0 @@
// Copyright (c) .NET Foundation. All rights reserved.
// Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information.
using System;
using Microsoft.AspNet.Mvc.Filters;
namespace Microsoft.AspNet.Mvc
{
[AttributeUsage(AttributeTargets.Class | AttributeTargets.Method, AllowMultiple = false, Inherited = true)]
public class AllowAnonymousAttribute : Attribute, IAllowAnonymous
{
}
}

View File

@ -38,21 +38,31 @@ namespace Microsoft.AspNet.Mvc.ApplicationModels
{
policy = AuthorizationPolicy.Combine(
_authorizationOptions,
controllerModel.Attributes.OfType<AuthorizeAttribute>());
controllerModel.Attributes.OfType<IAuthorizeData>());
if (policy != null)
{
controllerModel.Filters.Add(new AuthorizeFilter(policy));
}
foreach (var attribute in controllerModel.Attributes.OfType<IAllowAnonymous>())
{
controllerModel.Filters.Add(new AllowAnonymousFilter());
}
foreach (var actionModel in controllerModel.Actions)
{
policy = AuthorizationPolicy.Combine(
_authorizationOptions,
actionModel.Attributes.OfType<AuthorizeAttribute>());
actionModel.Attributes.OfType<IAuthorizeData>());
if (policy != null)
{
actionModel.Filters.Add(new AuthorizeFilter(policy));
}
foreach (var attribute in actionModel.Attributes.OfType<IAllowAnonymous>())
{
actionModel.Filters.Add(new AllowAnonymousFilter());
}
}
}
}

View File

@ -0,0 +1,13 @@
// Copyright (c) .NET Foundation. All rights reserved.
// Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information.
namespace Microsoft.AspNet.Mvc.Filters
{
/// <summary>
/// An implementation of <see cref="IAllowAnonymousFilter"/>
/// </summary>
public class AllowAnonymousFilter : IAllowAnonymousFilter
{
}
}

View File

@ -4,6 +4,7 @@
using System;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNet.Authorization;
using Microsoft.AspNet.Mvc.Internal;
namespace Microsoft.AspNet.Mvc.Filters
@ -36,7 +37,7 @@ namespace Microsoft.AspNet.Mvc.Filters
throw new ArgumentNullException(nameof(context));
}
return context.Filters.Any(item => item is IAllowAnonymous);
return context.Filters.Any(item => item is IAllowAnonymousFilter);
}
protected virtual void Fail(AuthorizationContext context)

View File

@ -64,7 +64,7 @@ namespace Microsoft.AspNet.Mvc.Filters
}
// Allow Anonymous skips all authorization
if (context.Filters.Any(item => item is IAllowAnonymous))
if (context.Filters.Any(item => item is IAllowAnonymousFilter))
{
return;
}

View File

@ -56,6 +56,26 @@ namespace Microsoft.AspNet.Mvc.ApplicationModels
Assert.Equal(3, authorizeFilters.First().Policy.Requirements.Count);
}
[Fact]
public void CreateControllerModelAndActionModel_AllowAnonymousAttributeAddsAllowAnonymousFilter()
{
// Arrange
var provider = new AuthorizationApplicationModelProvider(new TestOptionsManager<AuthorizationOptions>());
var defaultProvider = new DefaultApplicationModelProvider(new TestOptionsManager<MvcOptions>());
var context = new ApplicationModelProviderContext(new[] { typeof(AnonymousController).GetTypeInfo() });
defaultProvider.OnProvidersExecuting(context);
// Act
provider.OnProvidersExecuting(context);
// Assert
var controller = Assert.Single(context.Result.Controllers);
Assert.Single(controller.Filters, f => f is AllowAnonymousFilter);
var action = Assert.Single(controller.Actions);
Assert.Single(action.Filters, f => f is AllowAnonymousFilter);
}
private class BaseController
{
[Authorize(Policy = "Base")]
@ -76,5 +96,14 @@ namespace Microsoft.AspNet.Mvc.ApplicationModels
public class AccountController
{
}
[AllowAnonymous]
public class AnonymousController
{
[AllowAnonymous]
public void SomeAction()
{
}
}
}
}

View File

@ -64,7 +64,7 @@ namespace Microsoft.AspNet.Mvc.Filters
var authorizationContext = GetAuthorizationContext(services => services.AddAuthorization(),
anonymous: true);
authorizationContext.Filters.Add(new AllowAnonymousAttribute());
authorizationContext.Filters.Add(new AllowAnonymousFilter());
// Act
await authorizeFilter.OnAuthorizationAsync(authorizationContext);

View File

@ -1,6 +1,7 @@
// Copyright (c) .NET Foundation. All rights reserved.
// Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information.
using Microsoft.AspNet.Authorization;
using Microsoft.AspNet.Mvc;
namespace AntiforgeryTokenWebSite

View File

@ -2,6 +2,7 @@
// Licensed under the Apache License, Version 2.0. See License.txt in the project root for license information.
using System;
using Microsoft.AspNet.Authorization;
using Microsoft.AspNet.Mvc;
namespace FiltersWebSite