In my ASP.NET MVC application, I’m trying to figure out whether the user has access to a particular controller, restricted by the authorize data annotation as follows
[Authorize(Roles = "user")]
I’m attempting to override OnAuthorization in order to check:-
- If the request is authenticated (which works great)
- If the user is authorised to access the requested view (which doesn’t work)
My user roles are stored in a SessionManager object I’ve created – SessionManager.ActiveUser.Roles
Here’s what I have in the form of pseudo-code but if anybody could help me get this right, I’d really appreciate it.
public class HomeBaseController : Controller
{
protected override void OnAuthorization(AuthorizationContext context)
{
if (context.HttpContext.User.Identity.IsAuthenticated)
{
// these values combined are our roleName
bool isAuthorised = context.HttpContext.User.IsInRole(context.RequestContext.HttpContext.User.Identity.);
if (!context.HttpContext.User.IsInRole(---the roles associated with the requested controller action (e.g. user)---))
{
var url = new UrlHelper(context.RequestContext);
var logonUrl = url.Action("LogOn", "SSO", new { reason = "youAreAuthorisedButNotAllowedToViewThisPage" });
context.Result = new RedirectResult(logonUrl);
return;
}
}
}
As far as overriding OnAuthorization according to ProASP.NET MVC3 Book they do not recommend overriding it since the default implementation of this method securely handles content cached using OutputCache Filter.
If you are looking for Custom Authentication (using Forms Auth) and Authorization (Using Role provider logic then below is how I secured my application.
EDIT: The following logic uses in-built forms authentication and roles manager. Once user is authenticated and authorized the User Identity can be used to check both the authentication (User.Identity.IsAuthenticated) and the roles User.IsInRole(“admin”)
In Web.Config:
For Role Authorization Extend RoleProvider and override methods as required.
In Your controller Now you can use this:
For Authentication I have implemented my custom Authentication Check but I still use Forms Authentication: