Code:
/ 4.0 / 4.0 / 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. //------------------------------------------------------------------------------ //// 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
- BitmapEffectGeneralTransform.cs
- TypeNameParser.cs
- SpellCheck.cs
- DeviceContexts.cs
- BaseValidatorDesigner.cs
- SecureStringHasher.cs
- ElapsedEventArgs.cs
- TraceHandlerErrorFormatter.cs
- DbParameterCollectionHelper.cs
- InstallerTypeAttribute.cs
- InputQueueChannelAcceptor.cs
- PropertyContainer.cs
- ConfigsHelper.cs
- ResourceDescriptionAttribute.cs
- SmtpNegotiateAuthenticationModule.cs
- CorrelationToken.cs
- EnumConverter.cs
- FlowLayoutSettings.cs
- CircleHotSpot.cs
- WindowsToolbarItemAsMenuItem.cs
- TextElementAutomationPeer.cs
- DocumentScope.cs
- SQLDecimalStorage.cs
- SqlDependencyListener.cs
- FloatSumAggregationOperator.cs
- ToolboxItemWrapper.cs
- KeyTimeConverter.cs
- ReferenceEqualityComparer.cs
- DataRowExtensions.cs
- BitmapEffectInputData.cs
- ResourceLoader.cs
- ContentElement.cs
- InputScope.cs
- WorkItem.cs
- SystemIPInterfaceProperties.cs
- MenuEventArgs.cs
- ConsoleTraceListener.cs
- TextLineBreak.cs
- Triplet.cs
- LineSegment.cs
- SpecialFolderEnumConverter.cs
- ObjectTag.cs
- httpstaticobjectscollection.cs
- BevelBitmapEffect.cs
- ValueType.cs
- IPipelineRuntime.cs
- BufferModeSettings.cs
- Identifier.cs
- PageParserFilter.cs
- TextRange.cs
- WindowsEditBox.cs
- SecurityVersion.cs
- PageEventArgs.cs
- StreamUpdate.cs
- PowerModeChangedEventArgs.cs
- FixedPageStructure.cs
- FamilyMapCollection.cs
- IndentedTextWriter.cs
- EntityType.cs
- TemplateKey.cs
- Range.cs
- JsonDeserializer.cs
- TransactionScope.cs
- ProgramPublisher.cs
- CodeArrayIndexerExpression.cs
- _AutoWebProxyScriptEngine.cs
- SerializationSectionGroup.cs
- DataTableExtensions.cs
- WebBrowserNavigatingEventHandler.cs
- Figure.cs
- ProjectionPathBuilder.cs
- EventDescriptor.cs
- ProcessModelSection.cs
- TiffBitmapDecoder.cs
- SqlUserDefinedTypeAttribute.cs
- BadImageFormatException.cs
- Condition.cs
- EmulateRecognizeCompletedEventArgs.cs
- activationcontext.cs
- DataTablePropertyDescriptor.cs
- CounterCreationData.cs
- RunClient.cs
- UdpRetransmissionSettings.cs
- AuthenticationModuleElement.cs
- FileEnumerator.cs
- PointAnimationBase.cs
- DivideByZeroException.cs
- TableNameAttribute.cs
- TakeQueryOptionExpression.cs
- OletxTransactionManager.cs
- WorkflowOwnerAsyncResult.cs
- AsyncDataRequest.cs
- ServiceDescriptions.cs
- IndentedWriter.cs
- CodeObject.cs
- WindowsEditBoxRange.cs
- XmlSerializationReader.cs
- OverflowException.cs
- WindowsAuthenticationEventArgs.cs
- RuntimeConfigLKG.cs