A
download RolePrincipal.cs
Language: C#
Copyright: (C) 2005 Novell, Inc (http://www.novell.com) (C) 2003 Ben Maurer
LOC: 106
Project Info
mcs
Server: Mono
Type: svn
...em.Web\System.Web.Security\
   ...ConnectionProtection.cs
   ...ryMembershipProvider.cs
   ...ntificationEventArgs.cs
   ...ficationEventHandler.cs
   ...IdentificationModule.cs
   CookieProtection.cs
   ...henticationEventArgs.cs
   ...ticationEventHandler.cs
   ...AuthenticationModule.cs
   FileAuthorizationModule.cs
   FormsAuthentication.cs
   ...henticationEventArgs.cs
   ...ticationEventHandler.cs
   ...AuthenticationModule.cs
   ...AuthenticationTicket.cs
   FormsIdentity.cs
   Membership.cs
   MembershipCreateStatus.cs
   ...pCreateUserException.cs
   MembershipOnlineStatus.cs
   ...hipPasswordException.cs
   ...ershipPasswordFormat.cs
   MembershipProvider.cs
   ...ipProviderCollection.cs
   MembershipSortOptions.cs
   MembershipUser.cs
   ...ershipUserCollection.cs
   ...PasswordEventHandler.cs
   ...henticationEventArgs.cs
   ...ticationEventHandler.cs
   ...AuthenticationModule.cs
   PassportIdentity.cs
   RoleManagerEventArgs.cs
   RoleManagerEventHandler.cs
   RoleManagerModule.cs
   RolePrincipal.cs
   RoleProvider.cs
   RoleProviderCollection.cs
   Roles.cs
   SqlMembershipProvider.cs
   SqlRoleProvider.cs
   UrlAuthorizationModule.cs
   ...atePasswordEventArgs.cs
   ...henticationEventArgs.cs
   ...ticationEventHandler.cs
   ...AuthenticationModule.cs

//
// System.Web.Security.RolePrincipal
//
// Authors:
//	Ben Maurer (bmaurer@users.sourceforge.net)
//	Sebastien Pouliot  <sebastien@ximian.com>
//
// (C) 2003 Ben Maurer
// Copyright (C) 2005 Novell, Inc (http://www.novell.com)
//
// Permission is hereby granted, free of charge, to any person obtaining
// a copy of this software and associated documentation files (the
// "Software"), to deal in the Software without restriction, including
// without limitation the rights to use, copy, modify, merge, publish,
// distribute, sublicense, and/or sell copies of the Software, and to
// permit persons to whom the Software is furnished to do so, subject to
// the following conditions:
// 
// The above copyright notice and this permission notice shall be
// included in all copies or substantial portions of the Software.
// 
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
// EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
// MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
// NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
// LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
// OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
// WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
//

#if NET_2_0

using System.Collections.Specialized;
using System.Security.Permissions;
using System.Security.Principal;

namespace System.Web.Security {

	[Serializable]
	[AspNetHostingPermission (SecurityAction.LinkDemand, Level = AspNetHostingPermissionLevel.Minimal)]
	public sealed class RolePrincipal : IPrincipal {

		private IIdentity identity;
		private bool listChanged;
		string[] cachedArray;
		private HybridDictionary cachedRoles;
		private RoleProvider provider;

		public RolePrincipal (IIdentity identity)
		{
			if (identity == null)
				throw new ArgumentNullException ("identity");
			this.identity = identity;
			this.provider = Roles.Provider;
		}

		[MonoTODO]
		public RolePrincipal (IIdentity identity, string encryptedTicket)
			: this (identity)
		{
			throw new NotImplementedException ();
		}

		public RolePrincipal (string providerName, IIdentity identity)
			: this (identity)
		{
			if (providerName == null)
				throw new ArgumentNullException ("providerName");

			this.provider = Roles.Providers[providerName];
		}

		[MonoTODO]
		public RolePrincipal (string providerName, IIdentity identity, string encryptedTicket)
			: this (identity)
		{
			if (providerName == null)
				throw new ArgumentNullException ("providerName");

			this.provider = Roles.Providers[providerName];

			throw new NotImplementedException ();
		}

		public string [] GetRoles ()
		{
			if (!identity.IsAuthenticated)
				return new string[0];

			if (cachedRoles == null) {
				cachedArray = provider.GetRolesForUser (identity.Name);
				cachedRoles = new HybridDictionary (true);

				foreach (string r in cachedArray)
					cachedRoles.Add(r, r);
			}

			return cachedArray;
		}
		
		public bool IsInRole (string role)
		{
			if (!identity.IsAuthenticated)
				return false;

			GetRoles ();

			return cachedRoles[role] != null;
		}
		
		[MonoTODO]
		public string ToEncryptedTicket ()
		{
			throw new NotImplementedException ();
		}
		
		public bool CachedListChanged {
			get { return listChanged; }
		}
		
		[MonoTODO]
		public string CookiePath {
			get { throw new NotImplementedException (); }
		}
		
		[MonoTODO]
		public bool Expired {
			get { throw new NotImplementedException (); }
		}
		
		[MonoTODO]
		public DateTime ExpireDate {
			get { throw new NotImplementedException (); }
		}
		
		public IIdentity Identity {
			get { return identity; }
		}
		
		public bool IsRoleListCached {
			get { return cachedRoles != null; }
		}
		
		[MonoTODO]
		public DateTime IssueDate {
			get { throw new NotImplementedException (); }
		}
		
		public string ProviderName {
			get { return provider.Name; }
		}
		
		public int Version {
			get { return 1; }
		}

		public void SetDirty ()
		{
			listChanged = true;
			cachedRoles = null;
			cachedArray = null;
		}
	}
}
#endif

About Koders | Resources | Downloads | Support | Black Duck | Terms of Service | DMCA | Privacy Policy | Contact Us