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
- SerTrace.cs
- XmlNodeReader.cs
- IndentedTextWriter.cs
- InvalidProgramException.cs
- RowUpdatedEventArgs.cs
- UnknownWrapper.cs
- VisualTarget.cs
- SqlTopReducer.cs
- HttpContext.cs
- SqlError.cs
- FixedMaxHeap.cs
- EventData.cs
- Html32TextWriter.cs
- CodeCatchClauseCollection.cs
- ElementUtil.cs
- AsyncWaitHandle.cs
- GZipStream.cs
- SeekableMessageNavigator.cs
- EndEvent.cs
- ToolStripSettings.cs
- TextFindEngine.cs
- storepermission.cs
- PropertyCollection.cs
- ExceptionRoutedEventArgs.cs
- MeasurementDCInfo.cs
- TransportSecurityProtocol.cs
- RotateTransform.cs
- COMException.cs
- InboundActivityHelper.cs
- FontSourceCollection.cs
- SafeBitVector32.cs
- NewItemsContextMenuStrip.cs
- FormViewUpdateEventArgs.cs
- SendMessageRecord.cs
- IsolatedStorage.cs
- QilBinary.cs
- RtfFormatStack.cs
- SQLMembershipProvider.cs
- StrokeSerializer.cs
- XmlUtil.cs
- SecurityTokenParameters.cs
- RegexTree.cs
- ScrollBarAutomationPeer.cs
- ColumnResizeUndoUnit.cs
- sqlstateclientmanager.cs
- EditorPartCollection.cs
- HierarchicalDataBoundControl.cs
- GlobalizationSection.cs
- ItemCollectionEditor.cs
- safesecurityhelperavalon.cs
- SourceLineInfo.cs
- DataServiceContext.cs
- DataGridRow.cs
- CommandID.cs
- DataTableNewRowEvent.cs
- IgnoreSectionHandler.cs
- ZipIOLocalFileBlock.cs
- ComponentManagerBroker.cs
- SchemaMerger.cs
- DuplicateWaitObjectException.cs
- OLEDB_Enum.cs
- EntitySqlQueryCacheEntry.cs
- SecureUICommand.cs
- CultureTableRecord.cs
- PageStatePersister.cs
- WriteStateInfoBase.cs
- SignatureToken.cs
- XmlRootAttribute.cs
- OneWayBindingElementImporter.cs
- InkCanvasSelection.cs
- PointLightBase.cs
- MaskedTextProvider.cs
- DockPatternIdentifiers.cs
- SecurityException.cs
- FunctionNode.cs
- ReferenceEqualityComparer.cs
- HMACRIPEMD160.cs
- DependencySource.cs
- securitycriticaldataformultiplegetandset.cs
- CngProperty.cs
- DecimalConverter.cs
- MsmqActivation.cs
- Deserializer.cs
- CriticalFinalizerObject.cs
- DesignerObjectListAdapter.cs
- VersionPair.cs
- MatrixStack.cs
- HyperLinkField.cs
- CategoryGridEntry.cs
- ParenExpr.cs
- AttachedPropertyMethodSelector.cs
- NullableLongSumAggregationOperator.cs
- HtmlToClrEventProxy.cs
- DesignerActionList.cs
- WebPartTransformer.cs
- JulianCalendar.cs
- AttachInfo.cs
- ValidatingPropertiesEventArgs.cs
- X509CertificateClaimSet.cs
- ExcCanonicalXml.cs