Click here to Skip to main content
15,885,953 members
Articles / Web Development / ASP.NET

Extending ASP.NET role based Security with Custom Security Module (Permission Based, Page Level Authorization)

Rate me:
Please Sign up or sign in to vote.
4.80/5 (18 votes)
11 Nov 2011Ms-PL5 min read 107.8K   9.3K   74  
This project intends to extend the default ASP.NET role based Security to include Permission Based / Page Level Authorization Layer. Works with both ASP.NET and ASP.NET MVC. Permission rules to Allow/Deny access to website resources (like "Folder/File.aspx" or "Controller/Action") are stored in DB.
using System;
using System.Collections.Generic;
using System.ComponentModel;
using Iesi.Collections;
////using Iesi.Collections.Generic;
using Aadhaar.Data.Entity.Components;


using Aadhaar.Data.Entity;

namespace Aadhaar.Data.Entity 
{    
	/// <summary>
	/// An object representation of the Users table
	/// </summary>
	[Serializable]
	public class Users
	{
		protected System.Guid _Id;

		private Applications _Application;
		private readonly ISet _FKaspnetPeUserI693CA210 = new HashedSet();
		private readonly ISet _FKroleactionsusers = new HashedSet();
		private System.String _UserName;
		private System.String _LoweredUserName;
		private System.String _MobileAlias;
		private System.Boolean _IsAnonymous;
		private System.DateTime _LastActivityDate;
		private readonly ISet _FKaspnetUsUserI49C3F6B7 = new HashedSet();

		public virtual Applications Application
		{
			get
			{
				return _Application;
			}
			set
			{
				_Application = value;
			}
		}
		public virtual ISet FKaspnetPeUserI693CA210
		{
			get
			{
				return _FKaspnetPeUserI693CA210;
			}
		}

		public virtual ISet FKroleactionsusers
		{
			get
			{
				return _FKroleactionsusers;
			}
		}

		public virtual System.Guid Id
		{
			get
			{
				return _Id;
			}
			set
			{
				_Id = value;
			}
		}

		public virtual System.String UserName
		{
			get
			{
				return _UserName;
			}
			set
			{
				if (value == null)
				{
					throw new BusinessException("UserNameRequired", "UserName must not be null.");
				}
				_UserName = value;
			}
		}

		public virtual System.String LoweredUserName
		{
			get
			{
				return _LoweredUserName;
			}
			set
			{
				if (value == null)
				{
					throw new BusinessException("LoweredUserNameRequired", "LoweredUserName must not be null.");
				}
				_LoweredUserName = value;
			}
		}

		public virtual System.String MobileAlias
		{
			get
			{
				return _MobileAlias;
			}
			set
			{
				_MobileAlias = value;
			}
		}

		public virtual System.Boolean IsAnonymous
		{
			get
			{
				return _IsAnonymous;
			}
			set
			{
				_IsAnonymous = value;
			}
		}

		public virtual System.DateTime LastActivityDate
		{
			get
			{
				return _LastActivityDate;
			}
			set
			{
				_LastActivityDate = value;
			}
		}

		public virtual ISet FKaspnetUsUserI49C3F6B7
		{
			get
			{
				return _FKaspnetUsUserI49C3F6B7;
			}
		}


		protected bool Equals(Users entity)
		{
			if (entity == null) return false;
			if (!base.Equals(entity)) return false;
			if (!Equals(_Id, entity._Id)) return false;
			return true;
		}

		public override bool Equals(object obj)
		{
			if (ReferenceEquals(this, obj)) return true;
			return Equals(obj as Users);
		}

		public override int GetHashCode()
		{
			int result = base.GetHashCode();
			result = 29*result + _Id.GetHashCode();
			return result;
		}

	}
}

By viewing downloads associated with this article you agree to the Terms of Service and the article's licence.

If a file you wish to view isn't highlighted, and is a text file (not binary), please let us know and we'll add colourisation support for it.

License

This article, along with any associated source code and files, is licensed under The Microsoft Public License (Ms-PL)


Written By
Software Developer (Senior)
Singapore Singapore
I love programming, reading, and meditation. I like to explore management and productivity.

Comments and Discussions