Code:
/ Net / Net / 3.5.50727.3053 / DEVDIV / depot / DevDiv / releases / whidbey / netfxsp / ndp / fx / src / Net / System / Net / Mail / SmtpLoginAuthenticationModule.cs / 5 / SmtpLoginAuthenticationModule.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Net.Mail { using System; using System.Collections; using System.IO; using System.Net; using System.Security.Permissions; #if MAKE_MAILCLIENT_PUBLIC internal #else internal #endif class SmtpLoginAuthenticationModule : ISmtpAuthenticationModule { Hashtable sessions = new Hashtable(); internal SmtpLoginAuthenticationModule() { } #region ISmtpAuthenticationModule Members // Security this method will access NetworkCredential properties that demand UnmanagedCode and Environment Permission [EnvironmentPermission(SecurityAction.Assert, Unrestricted=true)] [SecurityPermission(SecurityAction.Assert, Flags=SecurityPermissionFlag.UnmanagedCode)] public Authorization Authenticate(string challenge, NetworkCredential credential, object sessionCookie) { if(Logging.On)Logging.Enter(Logging.Web, this, "Authenticate", null); try { lock (this.sessions) { NetworkCredential cachedCredential = sessions[sessionCookie] as NetworkCredential; if (cachedCredential == null) { if (credential == null || credential is SystemNetworkCredential) { return null; } sessions[sessionCookie] = credential; string userName = credential.UserName; string domain = credential.Domain; if (domain!=null && domain.Length > 0) { userName = domain + "\\" + userName; } // return new Authorization(Convert.ToBase64String(System.Text.Encoding.ASCII.GetBytes(userName)), false); } else { this.sessions.Remove(sessionCookie); // return new Authorization(Convert.ToBase64String(System.Text.Encoding.ASCII.GetBytes(cachedCredential.Password)), true); } } } finally { if(Logging.On)Logging.Exit(Logging.Web, this, "Authenticate", null); } } public string AuthenticationType { get { return "login"; } } public void CloseContext(object sessionCookie) { // This is a no-op since the context is not // kept open by this module beyond auth completion. } #endregion } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Net.Mail { using System; using System.Collections; using System.IO; using System.Net; using System.Security.Permissions; #if MAKE_MAILCLIENT_PUBLIC internal #else internal #endif class SmtpLoginAuthenticationModule : ISmtpAuthenticationModule { Hashtable sessions = new Hashtable(); internal SmtpLoginAuthenticationModule() { } #region ISmtpAuthenticationModule Members // Security this method will access NetworkCredential properties that demand UnmanagedCode and Environment Permission [EnvironmentPermission(SecurityAction.Assert, Unrestricted=true)] [SecurityPermission(SecurityAction.Assert, Flags=SecurityPermissionFlag.UnmanagedCode)] public Authorization Authenticate(string challenge, NetworkCredential credential, object sessionCookie) { if(Logging.On)Logging.Enter(Logging.Web, this, "Authenticate", null); try { lock (this.sessions) { NetworkCredential cachedCredential = sessions[sessionCookie] as NetworkCredential; if (cachedCredential == null) { if (credential == null || credential is SystemNetworkCredential) { return null; } sessions[sessionCookie] = credential; string userName = credential.UserName; string domain = credential.Domain; if (domain!=null && domain.Length > 0) { userName = domain + "\\" + userName; } // return new Authorization(Convert.ToBase64String(System.Text.Encoding.ASCII.GetBytes(userName)), false); } else { this.sessions.Remove(sessionCookie); // return new Authorization(Convert.ToBase64String(System.Text.Encoding.ASCII.GetBytes(cachedCredential.Password)), true); } } } finally { if(Logging.On)Logging.Exit(Logging.Web, this, "Authenticate", null); } } public string AuthenticationType { get { return "login"; } } public void CloseContext(object sessionCookie) { // This is a no-op since the context is not // kept open by this module beyond auth completion. } #endregion } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.
Link Menu
![Network programming in C#, Network Programming in VB.NET, Network Programming in .NET](/images/book.jpg)
This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- SQLDouble.cs
- StringSource.cs
- DocumentPaginator.cs
- ControlBindingsCollection.cs
- ScopeCompiler.cs
- GenerateHelper.cs
- TableHeaderCell.cs
- ValidatingCollection.cs
- EventSetter.cs
- ClientScriptManager.cs
- ConsumerConnectionPointCollection.cs
- ConfigXmlElement.cs
- ObsoleteAttribute.cs
- DataObjectCopyingEventArgs.cs
- DBConnectionString.cs
- SignatureToken.cs
- BamlWriter.cs
- ProcessHostFactoryHelper.cs
- SchemaNamespaceManager.cs
- GcSettings.cs
- ScriptControlDescriptor.cs
- RootProfilePropertySettingsCollection.cs
- BinaryObjectInfo.cs
- AttachedAnnotationChangedEventArgs.cs
- ModelFunction.cs
- CompletionBookmark.cs
- WindowsPrincipal.cs
- TextEmbeddedObject.cs
- ListenerSessionConnection.cs
- HttpResponseMessageProperty.cs
- BufferedConnection.cs
- SmiTypedGetterSetter.cs
- SafeArrayRankMismatchException.cs
- QueryConverter.cs
- WebRequest.cs
- CreatingCookieEventArgs.cs
- BitmapFrame.cs
- VisualBasicSettingsHandler.cs
- StringUtil.cs
- CrossContextChannel.cs
- AnnouncementSendsAsyncResult.cs
- DocumentReferenceCollection.cs
- WebPartZone.cs
- NodeFunctions.cs
- HttpCapabilitiesSectionHandler.cs
- OperationExecutionFault.cs
- RequestQueue.cs
- Helper.cs
- ApplicationFileCodeDomTreeGenerator.cs
- ConnectionProviderAttribute.cs
- TypeToArgumentTypeConverter.cs
- counter.cs
- ManipulationStartingEventArgs.cs
- PointCollection.cs
- XmlFormatExtensionPointAttribute.cs
- TimeSpanOrInfiniteValidator.cs
- LocatorManager.cs
- SafeHandles.cs
- ServicesUtilities.cs
- GetTokenRequest.cs
- SponsorHelper.cs
- DataGridCommandEventArgs.cs
- RemoteCryptoSignHashRequest.cs
- Model3D.cs
- ByteStack.cs
- PriorityItem.cs
- SQLByte.cs
- RuleSetDialog.cs
- TextPointer.cs
- SignedPkcs7.cs
- FieldNameLookup.cs
- SqlRetyper.cs
- IntellisenseTextBox.cs
- CornerRadius.cs
- SecurityTokenSpecification.cs
- Freezable.cs
- HostingEnvironmentException.cs
- WebEncodingValidatorAttribute.cs
- XPathDocumentIterator.cs
- DSASignatureDeformatter.cs
- ScriptControlManager.cs
- TreeChangeInfo.cs
- TableLayoutPanel.cs
- NamedElement.cs
- RegexMatchCollection.cs
- SystemColors.cs
- MetadataProperty.cs
- IndentTextWriter.cs
- TextureBrush.cs
- ListViewDeleteEventArgs.cs
- _SslSessionsCache.cs
- _BufferOffsetSize.cs
- cookiecollection.cs
- StructuralType.cs
- DataGridViewColumnConverter.cs
- EventLogPermission.cs
- InheritedPropertyChangedEventArgs.cs
- XmlByteStreamReader.cs
- ToolStripInSituService.cs
- ResXFileRef.cs