You've already forked linux-packaging-mono
							
							
		
			
	
	
		
			196 lines
		
	
	
		
			6.7 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
		
		
			
		
	
	
			196 lines
		
	
	
		
			6.7 KiB
		
	
	
	
		
			C#
		
	
	
	
	
	
|   | //------------------------------------------------------------------------------ | ||
|  | // <copyright file="FormsAuthenticationUserCollection.cs" company="Microsoft"> | ||
|  | //     Copyright (c) Microsoft Corporation.  All rights reserved. | ||
|  | // </copyright> | ||
|  | //------------------------------------------------------------------------------ | ||
|  | 
 | ||
|  | /***************************************************************************** | ||
|  |      From machine.config | ||
|  |         <!-- | ||
|  |         authentication Attributes: | ||
|  |           mode="[Windows|Forms|Passport|None]" | ||
|  |         --> | ||
|  |         <authentication mode="Windows"> | ||
|  | 
 | ||
|  |             <!-- | ||
|  |             forms Attributes: | ||
|  |               name="[cookie name]" - Name of the cookie used for Forms Authentication | ||
|  |               loginUrl="[url]" - Url to redirect client to for Authentication | ||
|  |               protection="[All|None|Encryption|Validation]" - Protection mode for data in cookie | ||
|  |               timeout="[minutes]" - Duration of time for cookie to be valid (reset on each request) | ||
|  |               path="/" - Sets the path for the cookie | ||
|  |               requireSSL="[true|false]" - Should the forms-authentication cookie be sent only over SSL | ||
|  |               slidingExpiration="[true|false]" - Should the forms-authentication-cookie and ticket be re-issued if they are about to expire | ||
|  |               defaultUrl="string" - Page to redirect to after login, if none has been specified | ||
|  |               cookieless="[UseCookies|UseUri|AutoDetect|UseDeviceProfile]" - Use Cookies or the URL path to store the forms authentication ticket | ||
|  |               domain="string" - Domain of the cookie | ||
|  |             --> | ||
|  |             <forms | ||
|  |                     name=".ASPXAUTH" | ||
|  |                     loginUrl="login.aspx" | ||
|  |                     protection="All" | ||
|  |                     timeout="30" | ||
|  |                     path="/" | ||
|  |                     requireSSL="false" | ||
|  |                     slidingExpiration="true" | ||
|  |                     defaultUrl="default.aspx" | ||
|  |                     cookieless="UseDeviceProfile" | ||
|  |                     enableCrossAppRedirects="false" > | ||
|  | 
 | ||
|  |                 <!-- | ||
|  |                 credentials Attributes: | ||
|  |                   passwordFormat="[Clear|SHA1|MD5]" - format of user password value stored in <user> | ||
|  |                 --> | ||
|  |                 <credentials passwordFormat="SHA1"> | ||
|  |                         <!-- <user name="UserName" password="password" /> --> | ||
|  |                 </credentials> | ||
|  | 
 | ||
|  |             </forms> | ||
|  | 
 | ||
|  |             <!-- | ||
|  |             passport Attributes: | ||
|  |                redirectUrl=["url"] - Specifies the page to redirect to, if the page requires authentication, and the user has not signed on with passport | ||
|  |             --> | ||
|  |             <passport redirectUrl="internal" /> | ||
|  | 
 | ||
|  |         </authentication> | ||
|  | 
 | ||
|  |         <authentication mode="Windows"> | ||
|  |             <forms | ||
|  |                     name=".ASPXAUTH" | ||
|  |                     loginUrl="login.aspx" | ||
|  |                     protection="All" | ||
|  |                     timeout="30" | ||
|  |                     path="/" | ||
|  |                     requireSSL="false" | ||
|  |                     slidingExpiration="true" | ||
|  |                     defaultUrl="default.aspx" | ||
|  |                     cookieless="UseDeviceProfile" | ||
|  |                     enableCrossAppRedirects="false" > | ||
|  | 
 | ||
|  |                 <credentials passwordFormat="SHA1"> | ||
|  |                 </credentials> | ||
|  |             </forms> | ||
|  |             <passport redirectUrl="internal" /> | ||
|  |         </authentication> | ||
|  | 
 | ||
|  |     ******************************************************************************/ | ||
|  | 
 | ||
|  | namespace System.Web.Configuration { | ||
|  |     using System; | ||
|  |     using System.Xml; | ||
|  |     using System.Configuration; | ||
|  |     using System.Collections.Specialized; | ||
|  |     using System.Collections; | ||
|  |     using System.Globalization; | ||
|  |     using System.IO; | ||
|  |     using System.Text; | ||
|  |     using System.Web.Util; | ||
|  |     using System.ComponentModel; | ||
|  |     using System.Security.Permissions; | ||
|  | 
 | ||
|  |     [ConfigurationCollection(typeof(FormsAuthenticationUser), AddItemName = "user", | ||
|  |      CollectionType = ConfigurationElementCollectionType.BasicMap)] | ||
|  |     public sealed class FormsAuthenticationUserCollection : ConfigurationElementCollection { | ||
|  |         private static ConfigurationPropertyCollection _properties; | ||
|  | 
 | ||
|  |         static FormsAuthenticationUserCollection() { | ||
|  |             _properties = new ConfigurationPropertyCollection(); | ||
|  |         } | ||
|  | 
 | ||
|  |         public FormsAuthenticationUserCollection() { | ||
|  |         } | ||
|  |          | ||
|  |         // public properties | ||
|  |         public String[] AllKeys { | ||
|  |             get { | ||
|  |                 return StringUtil.ObjectArrayToStringArray(BaseGetAllKeys()); | ||
|  |             } | ||
|  |         } | ||
|  |          | ||
|  |         public new FormsAuthenticationUser this[string name] { | ||
|  |             get { | ||
|  |                 return (FormsAuthenticationUser)BaseGet(name); | ||
|  |             } | ||
|  |             // Having a setter here would be strange in that you could write | ||
|  |             //  collection["Name1"] = new FormsAuthenticationUser("differentName"... | ||
|  |             // | ||
|  |         } | ||
|  | 
 | ||
|  |         protected override ConfigurationPropertyCollection Properties { | ||
|  |             get { | ||
|  |                 return _properties; | ||
|  |             } | ||
|  |         } | ||
|  | 
 | ||
|  |         public FormsAuthenticationUser this[int index] { | ||
|  |             get { | ||
|  |                 return (FormsAuthenticationUser)BaseGet(index); | ||
|  |             } | ||
|  |             set { | ||
|  |                 BaseAdd(index, value); | ||
|  |             } | ||
|  |         } | ||
|  |          | ||
|  |         // Protected Overrides | ||
|  |         protected override ConfigurationElement CreateNewElement() { | ||
|  |             return new FormsAuthenticationUser(); | ||
|  |         } | ||
|  |          | ||
|  |         protected override Object GetElementKey(ConfigurationElement element) { | ||
|  |             return ((FormsAuthenticationUser)element).Name; | ||
|  |         } | ||
|  |          | ||
|  |         protected override string ElementName { | ||
|  |             get { | ||
|  |                 return "user"; | ||
|  |             } | ||
|  |         } | ||
|  | 
 | ||
|  |         protected override bool ThrowOnDuplicate { | ||
|  |             get { | ||
|  |                 return true; | ||
|  |             } | ||
|  |         } | ||
|  | 
 | ||
|  |         public override ConfigurationElementCollectionType CollectionType { | ||
|  |             get { | ||
|  |                 return ConfigurationElementCollectionType.BasicMap; | ||
|  |             } | ||
|  |         } | ||
|  | 
 | ||
|  |         // public methods | ||
|  |         public void Add(FormsAuthenticationUser user) { | ||
|  |             BaseAdd(user); | ||
|  |         } | ||
|  |          | ||
|  |         public void Clear() { | ||
|  |             BaseClear(); | ||
|  |         } | ||
|  |          | ||
|  |         public FormsAuthenticationUser Get(int index) { | ||
|  |             return (FormsAuthenticationUser)BaseGet(index); | ||
|  |         } | ||
|  |          | ||
|  |         public FormsAuthenticationUser Get(string name) { | ||
|  |             return (FormsAuthenticationUser)BaseGet(name); | ||
|  |         } | ||
|  |          | ||
|  |         public String GetKey(int index) { | ||
|  |             return (String) BaseGetKey(index); | ||
|  |         } | ||
|  |          | ||
|  |         public void Remove(string name) { | ||
|  |             BaseRemove(name); | ||
|  |         } | ||
|  |          | ||
|  |         public void RemoveAt(int index) { | ||
|  |             BaseRemoveAt(index); | ||
|  |         } | ||
|  | 
 | ||
|  |         public void Set(FormsAuthenticationUser user) { | ||
|  |             BaseAdd(user, false); | ||
|  |         } | ||
|  |     } | ||
|  | } |