Search code examples
asp.net-mvcentity-frameworkasp.net-mvc-4authorize

Data level Authorization filter in ASP.Net MVC Entity Framework application


I was looking for a data level Authorization filter in my ASP.Net MVC 4 Application.
We are using Entity Framework for Data access.

The application need to display all the data but should restrict the access to certain fields in a table based on the user roles.

eg: TASK table { int Id, string TaskName, DateTime StartDate, DateTime EndDate }

This whole data will be displayed to all the users and users have the options to edit the fields also. But should restrict the edit options like as follows
Role Admin can edit all the fields
Role Manager can Edit TaskName but cannot edit StartDate and EndDate
Role Users cannot Edit any of the fields

All these edit will be calling the Edit action in the TaskController.

How can I implement the functionality in my application.


Solution

  • You might try Postsharp. PostSharp allows you to design custom attributes for injecting boilerplate code at compile-time. It should be possible to use it for scenarios such as your example. I've used it for exception handling, logging, caching, & security. It can be applied to any layer or framework.

    See, "Securing Fields and Properties" in the following illustrated example:

    http://www.sharpcrafters.com/solutions/authorization

    Hope it helps.