In ASP.NET MVC 4 and below we just add the following in Global.asax:
GlobalFilters.Filters.Add(new AuthorizeAttribute() { Roles = "Admin, SuperUser" });
Any idea how to do this in ASP.NET Core MVC?
From docs:
You can register a filter globally (for all controllers and actions) by adding it to the
MvcOptions.Filters
collection in theConfigureServices
method in theStartup
class:
You can not add AuthorizeAttribute
into MvcOptions.Filters
. Create an AuthorizationPolicy
and use AuthorizeFilter
:
var policy = new AuthorizationPolicyBuilder()
.RequireAuthenticatedUser()
.RequireRole("Admin", "SuperUser")
.Build();
services.AddMvc(options =>
{
options.Filters.Add(new AuthorizeFilter(policy));
});