#region Copyright & License
//
// Copyright 2001-2005 The Apache Software Foundation
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
#endregion
// .NET Compact Framework 1.0 has no support for ASP.NET
// SSCLI 1.0 has no support for ASP.NET
#if !NETCF && !SSCLI
using System.Web;
using log4net.Layout;
using log4net.Core;
namespace log4net.Appender
{
///
///
/// Appends log events to the ASP.NET system.
///
///
///
///
/// Diagnostic information and tracing messages that you specify are appended to the output
/// of the page that is sent to the requesting browser. Optionally, you can view this information
/// from a separate trace viewer (Trace.axd) that displays trace information for every page in a
/// given application.
///
///
/// Trace statements are processed and displayed only when tracing is enabled. You can control
/// whether tracing is displayed to a page, to the trace viewer, or both.
///
///
/// The logging event is passed to the or
/// method depending on the level of the logging event.
///
///
/// Nicko Cadell
/// Gert Driesen
public class AspNetTraceAppender : AppenderSkeleton
{
#region Public Instances Constructors
///
/// Initializes a new instance of the class.
///
///
///
/// Default constructor.
///
///
public AspNetTraceAppender()
{
}
#endregion // Public Instances Constructors
#region Override implementation of AppenderSkeleton
///
/// Write the logging event to the ASP.NET trace
///
/// the event to log
///
///
/// Write the logging event to the ASP.NET trace
/// HttpContext.Current.Trace
/// ().
///
///
override protected void Append(LoggingEvent loggingEvent)
{
// check if log4net is running in the context of an ASP.NET application
if (HttpContext.Current != null)
{
// check if tracing is enabled for the current context
if (HttpContext.Current.Trace.IsEnabled)
{
if (loggingEvent.Level >= Level.Warn)
{
HttpContext.Current.Trace.Warn(loggingEvent.LoggerName, RenderLoggingEvent(loggingEvent));
}
else
{
HttpContext.Current.Trace.Write(loggingEvent.LoggerName, RenderLoggingEvent(loggingEvent));
}
}
}
}
///
/// This appender requires a to be set.
///
/// true
///
///
/// This appender requires a to be set.
///
///
override protected bool RequiresLayout
{
get { return true; }
}
#endregion // Override implementation of AppenderSkeleton
}
}
#endif // !NETCF && !SSCLI