1 // Copyright 2004-2007 Castle Project - http://www.castleproject.org/
3 // Licensed under the Apache License, Version 2.0 (the "License");
4 // you may not use this file except in compliance with the License.
5 // You may obtain a copy of the License at
7 // http://www.apache.org/licenses/LICENSE-2.0
9 // Unless required by applicable law or agreed to in writing, software
10 // distributed under the License is distributed on an "AS IS" BASIS,
11 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12 // See the License for the specific language governing permissions and
13 // limitations under the License.
15 namespace Castle
.MonoRail
.Framework
.Extensions
.ExceptionChaining
17 using Castle
.Core
.Logging
;
20 /// Handles that logs the exception using the the logger factory.
22 public class LoggingExceptionHandler
: AbstractExceptionHandler
25 /// Implementors should perform the action
26 /// on the exception. Note that the exception
27 /// is available in <see cref="IRailsEngineContext.LastException"/>
29 /// <param name="context"></param>
30 public override void Process(IRailsEngineContext context
)
32 ILoggerFactory factory
= (ILoggerFactory
) context
.GetService(typeof(ILoggerFactory
));
33 ILogger logger
= factory
.Create(context
.CurrentController
.GetType());
35 logger
.Error(BuildStandardMessage(context
));