|
5 | 5 |
|
6 | 6 | namespace ServiceStack.Logging.Elmah |
7 | 7 | { |
8 | | - /// <summary> |
9 | | - /// Elmah log factory that wraps another log factory, providing interception facilities on log calls. For Error or Fatal calls, the |
10 | | - /// details will be logged to Elmah in addition to the originally intended logger. For all other log types, only the original logger is |
11 | | - /// used. |
12 | | - /// </summary> |
13 | | - /// <remarks> 9/2/2011. </remarks> |
14 | | - public class ElmahLogFactory : ILogFactory |
15 | | - { |
16 | | - |
17 | | - internal class ErrorFilterConsole : ErrorFilterModule |
| 8 | + /// <summary> |
| 9 | + /// Elmah log factory that wraps another log factory, providing interception facilities on log calls. For Error or Fatal calls, the |
| 10 | + /// details will be logged to Elmah in addition to the originally intended logger. For all other log types, only the original logger is |
| 11 | + /// used. |
| 12 | + /// </summary> |
| 13 | + /// <remarks> 9/2/2011. </remarks> |
| 14 | + public class ElmahLogFactory : ILogFactory |
18 | 15 | { |
19 | | - public void HookFiltering(IExceptionFiltering module) |
20 | | - { |
21 | | - module.Filtering += new ExceptionFilterEventHandler(base.OnErrorModuleFiltering); |
22 | | - } |
23 | | - } |
24 | 16 |
|
25 | | - private readonly ILogFactory logFactory; |
26 | | - private readonly HttpApplication application; |
| 17 | + internal class ErrorFilterConsole : ErrorFilterModule |
| 18 | + { |
| 19 | + public void HookFiltering(IExceptionFiltering module) |
| 20 | + { |
| 21 | + module.Filtering += base.OnErrorModuleFiltering; |
| 22 | + } |
| 23 | + } |
27 | 24 |
|
28 | | - // Filters and modules for HttpApplication-less Elmah logging |
29 | | - private ErrorFilterConsole errorFilter = new ErrorFilterConsole(); |
30 | | - public ErrorMailModule ErrorEmail = new ErrorMailModule(); |
31 | | - public ErrorLogModule ErrorLog = new ErrorLogModule(); |
32 | | - public ErrorTweetModule ErrorTweet = new ErrorTweetModule(); |
| 25 | + private readonly ILogFactory logFactory; |
| 26 | + private readonly HttpApplication application; |
33 | 27 |
|
34 | | - /// <summary> Constructor. </summary> |
35 | | - /// <remarks> 9/2/2011. </remarks> |
36 | | - /// <param name="logFactory"> The log factory that provides the original. </param> |
37 | | - /// <param name="application"> The Http Application to log with. Optional parameter in case of self hosting.</param> |
38 | | - public ElmahLogFactory(ILogFactory logFactory, HttpApplication application = null) |
39 | | - { |
40 | | - if (null == logFactory) { throw new ArgumentNullException("logFactory"); } |
41 | | - if (null == application) |
42 | | - { |
43 | | - application = InitNoContext(); |
44 | | - } |
| 28 | + // Filters and modules for HttpApplication-less Elmah logging |
| 29 | + private ErrorFilterConsole errorFilter = new ErrorFilterConsole(); |
| 30 | + public ErrorMailModule ErrorEmail = new ErrorMailModule(); |
| 31 | + public ErrorLogModule ErrorLog = new ErrorLogModule(); |
| 32 | + public ErrorTweetModule ErrorTweet = new ErrorTweetModule(); |
45 | 33 |
|
46 | | - this.logFactory = logFactory; |
47 | | - this.application = application; |
48 | | - } |
| 34 | + /// <summary> Constructor. </summary> |
| 35 | + /// <remarks> 9/2/2011. </remarks> |
| 36 | + /// <param name="logFactory"> The log factory that provides the original. </param> |
| 37 | + /// <param name="application"> The Http Application to log with. Optional parameter in case of self hosting.</param> |
| 38 | + public ElmahLogFactory(ILogFactory logFactory, HttpApplication application = null) |
| 39 | + { |
| 40 | + if (application == null) |
| 41 | + { |
| 42 | + application = InitNoContext(); |
| 43 | + } |
49 | 44 |
|
50 | | - private HttpApplication InitNoContext() |
51 | | - { |
52 | | - var httpApplication = new HttpApplication(); |
53 | | - errorFilter.Init(httpApplication); |
| 45 | + this.logFactory = logFactory ?? throw new ArgumentNullException(nameof(logFactory)); |
| 46 | + this.application = application; |
| 47 | + } |
54 | 48 |
|
55 | | - (ErrorEmail as IHttpModule).Init(httpApplication); |
56 | | - errorFilter.HookFiltering(ErrorEmail); |
| 49 | + private HttpApplication InitNoContext() |
| 50 | + { |
| 51 | + var httpApplication = new HttpApplication(); |
| 52 | + errorFilter.Init(httpApplication); |
57 | 53 |
|
58 | | - (ErrorLog as IHttpModule).Init(httpApplication); |
59 | | - errorFilter.HookFiltering(ErrorLog); |
| 54 | + (ErrorEmail as IHttpModule).Init(httpApplication); |
| 55 | + errorFilter.HookFiltering(ErrorEmail); |
60 | 56 |
|
61 | | - (ErrorTweet as IHttpModule).Init(httpApplication); |
62 | | - errorFilter.HookFiltering(ErrorTweet); |
63 | | - return httpApplication; |
| 57 | + (ErrorLog as IHttpModule).Init(httpApplication); |
| 58 | + errorFilter.HookFiltering(ErrorLog); |
64 | 59 |
|
65 | | - } |
| 60 | + (ErrorTweet as IHttpModule).Init(httpApplication); |
| 61 | + errorFilter.HookFiltering(ErrorTweet); |
| 62 | + return httpApplication; |
66 | 63 |
|
67 | | - /// <summary> Gets a logger from the wrapped logFactory. </summary> |
68 | | - /// <remarks> 9/2/2011. </remarks> |
69 | | - /// <param name="typeName"> Name of the type. </param> |
70 | | - /// <returns> The logger. </returns> |
71 | | - public ILog GetLogger(string typeName) |
72 | | - { |
73 | | - return new ElmahInterceptingLogger(this.logFactory.GetLogger(typeName), application); |
74 | | - } |
| 64 | + } |
75 | 65 |
|
76 | | - /// <summary> Gets a logger from the wrapped logFactory. </summary> |
77 | | - /// <remarks> 9/2/2011. </remarks> |
78 | | - /// <param name="type"> The type. </param> |
79 | | - /// <returns> The logger. </returns> |
80 | | - public ILog GetLogger(Type type) |
81 | | - { |
82 | | - return new ElmahInterceptingLogger(this.logFactory.GetLogger(type), application); |
| 66 | + /// <summary> Gets a logger from the wrapped logFactory. </summary> |
| 67 | + /// <remarks> 9/2/2011. </remarks> |
| 68 | + /// <param name="typeName"> Name of the type. </param> |
| 69 | + /// <returns> The logger. </returns> |
| 70 | + public ILog GetLogger(string typeName) |
| 71 | + { |
| 72 | + return new ElmahInterceptingLogger(this.logFactory.GetLogger(typeName), application); |
| 73 | + } |
| 74 | + |
| 75 | + /// <summary> Gets a logger from the wrapped logFactory. </summary> |
| 76 | + /// <remarks> 9/2/2011. </remarks> |
| 77 | + /// <param name="type"> The type. </param> |
| 78 | + /// <returns> The logger. </returns> |
| 79 | + public ILog GetLogger(Type type) |
| 80 | + { |
| 81 | + return new ElmahInterceptingLogger(this.logFactory.GetLogger(type), application); |
| 82 | + } |
83 | 83 | } |
84 | | - } |
85 | 84 | } |
0 commit comments