Code:
/ Dotnetfx_Vista_SP2 / Dotnetfx_Vista_SP2 / 8.0.50727.4016 / DEVDIV / depot / DevDiv / releases / whidbey / NetFxQFE / ndp / fx / src / xsp / System / Web / Security / BackStopAuthenticationModule.cs / 1 / BackStopAuthenticationModule.cs
//------------------------------------------------------------------------------ //// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.Security { using System.Collections.Specialized; using System.Runtime.Serialization; using System.Security.Principal; using System.Security.Permissions; using System.Threading; using System.Web; ////// [AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)] public sealed class DefaultAuthenticationModule : IHttpModule { private DefaultAuthenticationEventHandler _eventHandler; ///[To be supplied.] ////// [SecurityPermission(SecurityAction.Demand, Unrestricted=true)] public DefaultAuthenticationModule() { } ////// Initializes a new instance of the ////// class. /// /// public event DefaultAuthenticationEventHandler Authenticate { add { // WOS 1709222: DefaultAuthentication_Authenticate is not supported in integrated mode. if (HttpRuntime.UseIntegratedPipeline) { throw new PlatformNotSupportedException(SR.GetString(SR.Method_Not_Supported_By_Iis_Integrated_Mode, "DefaultAuthentication.Authenticate")); } _eventHandler += value; } remove { _eventHandler -= value; } } ///[To be supplied.] ////// public void Dispose() { } ///[To be supplied.] ////// public void Init(HttpApplication app) { // adding this module back to IIS7 // it needs to run between Windows auth in PostAuthn // and RoleManager (or anyone else who needs the principal) // so ordering is important // If the subscribed event changes, WindowsAuthenticationModule // needs work, too. if (HttpRuntime.UseIntegratedPipeline) { app.PostAuthenticateRequest += new EventHandler(this.OnEnter); } else { app.DefaultAuthentication += new EventHandler(this.OnEnter); } } //////////////////////////////////////////////////////////// // OnAuthenticate: Custom Authentication modules can override // this method to create a custom IPrincipal object from // a DefaultIdentity void OnAuthenticate(DefaultAuthenticationEventArgs e) { //////////////////////////////////////////////////////////// // If there are event handlers, invoke the handlers if (_eventHandler != null) { _eventHandler(this, e); } } //////////////////////////////////////////////////////////// // AddOnAuthenticate and RemoveOnAuthenticate: Use these // methods to hook up event handlers to handle the // OnAuthenticate Event void OnEnter(Object source, EventArgs eventArgs) { HttpApplication app; HttpContext context; app = (HttpApplication)source; context = app.Context; //////////////////////////////////////////////////////////// // Step 1: Check if authentication failed if (context.Response.StatusCode > 200) { // Invalid credentials if (context.Response.StatusCode == 401) WriteErrorMessage(context); app.CompleteRequest(); return; } //////////////////////////////////////////////////////////// // Step 2: If no auth module has created an IPrincipal, then fire // OnAuthentication event if (context.User == null) { OnAuthenticate (new DefaultAuthenticationEventArgs(context) ); if (context.Response.StatusCode > 200) { // Invalid credentials if (context.Response.StatusCode == 401) WriteErrorMessage(context); app.CompleteRequest(); return; } } //////////////////////////////////////////////////////////// // Step 3: Attach an anonymous user to this request, if none // of the authentication modules created a user if (context.User == null) { context.SetPrincipalNoDemand(new GenericPrincipal(new GenericIdentity(String.Empty, String.Empty), new String[0]), false /*needToSetNativePrincipal*/); } Thread.CurrentPrincipal = context.User; } ///////////////////////////////////////////////////////////////////////////// void WriteErrorMessage(HttpContext context) { context.Response.Write(AuthFailedErrorFormatter.GetErrorText()); // In Integrated pipeline, ask for handler headers to be generated. This would be unnecessary // if we just threw an access denied exception, and used the standard error mechanism context.Response.GenerateResponseHeadersForHandler(); } } ////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////// internal class AuthFailedErrorFormatter : ErrorFormatter { private static string _strErrorText; private static object _syncObject = new object(); internal AuthFailedErrorFormatter() { } internal /*public*/ static string GetErrorText() { if (_strErrorText != null) return _strErrorText; lock(_syncObject) { if (_strErrorText == null) _strErrorText = (new AuthFailedErrorFormatter()).GetErrorMessage(); } return _strErrorText; } protected override string ErrorTitle { get { return SR.GetString(SR.Assess_Denied_Title);} } protected override string Description { get { return SR.GetString(SR.Assess_Denied_Description1); //"An error occurred while accessing the resources required to serve this request. This typically happens when you provide the wrong user-name and/or password."; } } protected override string MiscSectionTitle { get { return SR.GetString(SR.Assess_Denied_MiscTitle1);} //"Error message 401.1";} } protected override string MiscSectionContent { get { string miscContent = SR.GetString(SR.Assess_Denied_MiscContent1); AdaptiveMiscContent.Add(miscContent); return miscContent; //return "Logon credentials provided were not recognized. Make sure you are providing the correct user-name and password. Otherwise, ask the web server's administrator for help."; } } protected override string ColoredSquareTitle { get { return null;} } protected override string ColoredSquareContent { get { return null;} } protected override bool ShowSourceFileInfo { get { return false;} } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007. //------------------------------------------------------------------------------ //[To be supplied.] ///// Copyright (c) Microsoft Corporation. All rights reserved. // //----------------------------------------------------------------------------- namespace System.Web.Security { using System.Collections.Specialized; using System.Runtime.Serialization; using System.Security.Principal; using System.Security.Permissions; using System.Threading; using System.Web; ////// [AspNetHostingPermission(SecurityAction.LinkDemand, Level=AspNetHostingPermissionLevel.Minimal)] public sealed class DefaultAuthenticationModule : IHttpModule { private DefaultAuthenticationEventHandler _eventHandler; ///[To be supplied.] ////// [SecurityPermission(SecurityAction.Demand, Unrestricted=true)] public DefaultAuthenticationModule() { } ////// Initializes a new instance of the ////// class. /// /// public event DefaultAuthenticationEventHandler Authenticate { add { // WOS 1709222: DefaultAuthentication_Authenticate is not supported in integrated mode. if (HttpRuntime.UseIntegratedPipeline) { throw new PlatformNotSupportedException(SR.GetString(SR.Method_Not_Supported_By_Iis_Integrated_Mode, "DefaultAuthentication.Authenticate")); } _eventHandler += value; } remove { _eventHandler -= value; } } ///[To be supplied.] ////// public void Dispose() { } ///[To be supplied.] ////// public void Init(HttpApplication app) { // adding this module back to IIS7 // it needs to run between Windows auth in PostAuthn // and RoleManager (or anyone else who needs the principal) // so ordering is important // If the subscribed event changes, WindowsAuthenticationModule // needs work, too. if (HttpRuntime.UseIntegratedPipeline) { app.PostAuthenticateRequest += new EventHandler(this.OnEnter); } else { app.DefaultAuthentication += new EventHandler(this.OnEnter); } } //////////////////////////////////////////////////////////// // OnAuthenticate: Custom Authentication modules can override // this method to create a custom IPrincipal object from // a DefaultIdentity void OnAuthenticate(DefaultAuthenticationEventArgs e) { //////////////////////////////////////////////////////////// // If there are event handlers, invoke the handlers if (_eventHandler != null) { _eventHandler(this, e); } } //////////////////////////////////////////////////////////// // AddOnAuthenticate and RemoveOnAuthenticate: Use these // methods to hook up event handlers to handle the // OnAuthenticate Event void OnEnter(Object source, EventArgs eventArgs) { HttpApplication app; HttpContext context; app = (HttpApplication)source; context = app.Context; //////////////////////////////////////////////////////////// // Step 1: Check if authentication failed if (context.Response.StatusCode > 200) { // Invalid credentials if (context.Response.StatusCode == 401) WriteErrorMessage(context); app.CompleteRequest(); return; } //////////////////////////////////////////////////////////// // Step 2: If no auth module has created an IPrincipal, then fire // OnAuthentication event if (context.User == null) { OnAuthenticate (new DefaultAuthenticationEventArgs(context) ); if (context.Response.StatusCode > 200) { // Invalid credentials if (context.Response.StatusCode == 401) WriteErrorMessage(context); app.CompleteRequest(); return; } } //////////////////////////////////////////////////////////// // Step 3: Attach an anonymous user to this request, if none // of the authentication modules created a user if (context.User == null) { context.SetPrincipalNoDemand(new GenericPrincipal(new GenericIdentity(String.Empty, String.Empty), new String[0]), false /*needToSetNativePrincipal*/); } Thread.CurrentPrincipal = context.User; } ///////////////////////////////////////////////////////////////////////////// void WriteErrorMessage(HttpContext context) { context.Response.Write(AuthFailedErrorFormatter.GetErrorText()); // In Integrated pipeline, ask for handler headers to be generated. This would be unnecessary // if we just threw an access denied exception, and used the standard error mechanism context.Response.GenerateResponseHeadersForHandler(); } } ////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////// ////////////////////////////////////////////////////////////////// internal class AuthFailedErrorFormatter : ErrorFormatter { private static string _strErrorText; private static object _syncObject = new object(); internal AuthFailedErrorFormatter() { } internal /*public*/ static string GetErrorText() { if (_strErrorText != null) return _strErrorText; lock(_syncObject) { if (_strErrorText == null) _strErrorText = (new AuthFailedErrorFormatter()).GetErrorMessage(); } return _strErrorText; } protected override string ErrorTitle { get { return SR.GetString(SR.Assess_Denied_Title);} } protected override string Description { get { return SR.GetString(SR.Assess_Denied_Description1); //"An error occurred while accessing the resources required to serve this request. This typically happens when you provide the wrong user-name and/or password."; } } protected override string MiscSectionTitle { get { return SR.GetString(SR.Assess_Denied_MiscTitle1);} //"Error message 401.1";} } protected override string MiscSectionContent { get { string miscContent = SR.GetString(SR.Assess_Denied_MiscContent1); AdaptiveMiscContent.Add(miscContent); return miscContent; //return "Logon credentials provided were not recognized. Make sure you are providing the correct user-name and password. Otherwise, ask the web server's administrator for help."; } } protected override string ColoredSquareTitle { get { return null;} } protected override string ColoredSquareContent { get { return null;} } protected override bool ShowSourceFileInfo { get { return false;} } } } // File provided for Reference Use Only by Microsoft Corporation (c) 2007.[To be supplied.] ///
Link Menu

This book is available now!
Buy at Amazon US or
Buy at Amazon UK
- RefExpr.cs
- DataControlPagerLinkButton.cs
- PageHandlerFactory.cs
- CacheVirtualItemsEvent.cs
- Clock.cs
- ServiceModelDictionary.cs
- GroupItemAutomationPeer.cs
- JpegBitmapDecoder.cs
- FixedSOMFixedBlock.cs
- ResourceAssociationType.cs
- ProfileEventArgs.cs
- UIElement.cs
- ZipIOLocalFileBlock.cs
- ProgressBar.cs
- WmpBitmapEncoder.cs
- DeviceContext2.cs
- GridPattern.cs
- LineGeometry.cs
- XmlSchemaAppInfo.cs
- XmlBinaryReader.cs
- LocalFileSettingsProvider.cs
- ListItemCollection.cs
- TemplateEditingService.cs
- DescendentsWalker.cs
- Int32RectConverter.cs
- LogExtentCollection.cs
- PenContexts.cs
- ContentDisposition.cs
- PartitionerQueryOperator.cs
- ImageDrawing.cs
- RawUIStateInputReport.cs
- ObjectListItem.cs
- Queue.cs
- SystemInfo.cs
- TargetPerspective.cs
- CompleteWizardStep.cs
- ServiceObjectContainer.cs
- ContentType.cs
- MdiWindowListStrip.cs
- KeyPressEvent.cs
- HttpHeaderCollection.cs
- RandomNumberGenerator.cs
- SoapUnknownHeader.cs
- PeerCollaboration.cs
- URLIdentityPermission.cs
- OletxDependentTransaction.cs
- TextEncodedRawTextWriter.cs
- UTF32Encoding.cs
- ModuleBuilderData.cs
- UmAlQuraCalendar.cs
- MetafileHeader.cs
- DirectionalLight.cs
- PointUtil.cs
- HttpModuleAction.cs
- XmlObjectSerializerWriteContextComplex.cs
- NativeMethods.cs
- HorizontalAlignConverter.cs
- TimeoutException.cs
- GridEntry.cs
- ZipPackage.cs
- SrgsDocumentParser.cs
- DecimalAnimationUsingKeyFrames.cs
- ContentHostHelper.cs
- PeerOutputChannel.cs
- WebZone.cs
- MetadataPropertyAttribute.cs
- Int32RectConverter.cs
- CallbackHandler.cs
- TokenBasedSet.cs
- ColumnPropertiesGroup.cs
- RuntimeConfigurationRecord.cs
- Object.cs
- BamlWriter.cs
- ExeConfigurationFileMap.cs
- SHA1CryptoServiceProvider.cs
- ConfigsHelper.cs
- BindingBase.cs
- FunctionNode.cs
- PersonalizationProviderHelper.cs
- X509CertificateClaimSet.cs
- SqlBuilder.cs
- HtmlInputFile.cs
- FormViewPagerRow.cs
- MsmqIntegrationSecurity.cs
- XmlAggregates.cs
- Enum.cs
- VisualBrush.cs
- TemplateBindingExpressionConverter.cs
- SQLSingleStorage.cs
- PrtCap_Builder.cs
- Parsers.cs
- EventSource.cs
- JournalNavigationScope.cs
- ExpressionDumper.cs
- NodeInfo.cs
- safemediahandle.cs
- DataObjectCopyingEventArgs.cs
- MethodCallConverter.cs
- EncoderExceptionFallback.cs
- DataGridViewTextBoxCell.cs