Code:
/ 4.0 / 4.0 / untmp / DEVDIV_TFS / Dev10 / Releases / RTMRel / ndp / fx / src / xsp / System / Extensions / ClientServices / ClientFormsIdentity.cs / 1305376 / ClientFormsIdentity.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.ClientServices { using System; using System.Net; using System.Security.Principal; using System.Runtime.InteropServices; using System.Security; using System.Web.Security; using System.Diagnostics.CodeAnalysis; public class ClientFormsIdentity : IIdentity, IDisposable { public string Name { get { return _Name; }} public bool IsAuthenticated { get { return _IsAuthenticated; }} public string AuthenticationType { get { return _AuthenticationType; } } public CookieContainer AuthenticationCookies { get { return _AuthenticationCookies; } } public MembershipProvider Provider { get { return _Provider; } } public ClientFormsIdentity(string name, string password, MembershipProvider provider, string authenticationType, bool isAuthenticated, CookieContainer authenticationCookies) { _Name = name; _AuthenticationType = authenticationType; _IsAuthenticated = isAuthenticated; _AuthenticationCookies = authenticationCookies; _Password = GetSecureStringFromString(password); _Provider = provider; } public void RevalidateUser() { if (_Disposed) { throw new ObjectDisposedException(this.GetType().FullName); } _Provider.ValidateUser(_Name, GetStringFromSecureString(_Password)); } public void Dispose() { Dispose(true); GC.SuppressFinalize(this); } protected virtual void Dispose(bool disposing) { if (disposing) { if (_Password != null) { _Password.Dispose(); } } _Disposed = true; } private string _Name; private bool _IsAuthenticated; private string _AuthenticationType; private CookieContainer _AuthenticationCookies; private SecureString _Password; private MembershipProvider _Provider; private bool _Disposed; private static SecureString GetSecureStringFromString(string password) { char[] passwordChars = password.ToCharArray(); SecureString ss = new SecureString(); for (int iter = 0; iter < passwordChars.Length; iter++) ss.AppendChar(passwordChars[iter]); ss.MakeReadOnly(); return ss; } [SuppressMessage("Microsoft.Security", "CA2122:DoNotIndirectlyExposeMethodsWithLinkDemands", Justification="Reviewed and approved by feature crew")] [SecuritySafeCritical] private static string GetStringFromSecureString(SecureString securePass) { IntPtr bstr = IntPtr.Zero; try { bstr = Marshal.SecureStringToBSTR(securePass); return Marshal.PtrToStringBSTR(bstr); } finally { if (bstr != IntPtr.Zero) Marshal.FreeBSTR(bstr); } } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- Trustee.cs
- DataTable.cs
- RegistryKey.cs
- TextBoxLine.cs
- XmlLinkedNode.cs
- WaitHandleCannotBeOpenedException.cs
- EntityDataReader.cs
- SmiEventSink_Default.cs
- SynchronizationHandlesCodeDomSerializer.cs
- SqlConnectionFactory.cs
- GACIdentityPermission.cs
- SoapProcessingBehavior.cs
- RegexCode.cs
- SmiEventSink_DeferedProcessing.cs
- DesignConnection.cs
- VirtualPathUtility.cs
- SafeRightsManagementHandle.cs
- TraceHwndHost.cs
- MobileUserControl.cs
- MasterPage.cs
- CacheEntry.cs
- Comparer.cs
- RotationValidation.cs
- RegexCode.cs
- ScrollChrome.cs
- FormatVersion.cs
- VariableQuery.cs
- TrustSection.cs
- DmlSqlGenerator.cs
- ConnectionPoint.cs
- ITreeGenerator.cs
- DataGridViewEditingControlShowingEventArgs.cs
- contentDescriptor.cs
- FloaterBaseParagraph.cs
- ItemChangedEventArgs.cs
- SQLMembershipProvider.cs
- SmiGettersStream.cs
- MailWebEventProvider.cs
- BindingList.cs
- Highlights.cs
- AstNode.cs
- Frame.cs
- WebBrowserSiteBase.cs
- BorderGapMaskConverter.cs
- FormCollection.cs
- XsltArgumentList.cs
- SocketSettings.cs
- TagPrefixCollection.cs
- TimeZone.cs
- CompilerInfo.cs
- XmlUnspecifiedAttribute.cs
- ObjectStorage.cs
- ViewBase.cs
- ClusterUtils.cs
- GPRECT.cs
- QuaternionValueSerializer.cs
- SafeSecurityHandles.cs
- EnvelopedPkcs7.cs
- DataFormats.cs
- CodeAccessPermission.cs
- _NegotiateClient.cs
- ElementAtQueryOperator.cs
- StoryFragments.cs
- ApplyImportsAction.cs
- CustomErrorsSectionWrapper.cs
- OutputCacheSection.cs
- ContentPresenter.cs
- CompositeActivityValidator.cs
- XmlSchemaComplexContentRestriction.cs
- URI.cs
- EventWaitHandle.cs
- SuppressMergeCheckAttribute.cs
- Dynamic.cs
- StateItem.cs
- DockPattern.cs
- MarkupObject.cs
- SecurityAlgorithmSuite.cs
- NamespaceEmitter.cs
- ExtensionFile.cs
- PinnedBufferMemoryStream.cs
- DomNameTable.cs
- Evidence.cs
- TraceShell.cs
- RuntimeIdentifierPropertyAttribute.cs
- CompressStream.cs
- Stack.cs
- DaylightTime.cs
- ObjectQuery.cs
- HandledMouseEvent.cs
- XmlSerializationGeneratedCode.cs
- DataGridViewRowsRemovedEventArgs.cs
- WebBodyFormatMessageProperty.cs
- RemoteWebConfigurationHostServer.cs
- BaseValidator.cs
- sqlpipe.cs
- HandlerBase.cs
- PermissionSet.cs
- BlockingCollection.cs
- AnimationException.cs
- HotSpotCollectionEditor.cs