annotate Source/Aspects/LoggingAspect.cs @ 0:f990fcb411a9

Копия текущей версии из github
author cin
date Thu, 27 Mar 2014 21:46:09 +0400
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
1 using System;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
2 using System.Diagnostics;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
3 using System.Globalization;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
4 using System.IO;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
5 using System.Collections;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
6 using System.Text;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
7
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
8 namespace BLToolkit.Aspects
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
9 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
10 public delegate void LogOperation(InterceptCallInfo interceptCallInfo, LoggingAspect.Parameters parameters);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
11 public delegate void LogOutput (string logText, string fileName);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
12
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
13 /// <summary>
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
14 /// http://www.bltoolkit.net/Doc/Aspects/index.htm
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
15 /// </summary>
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
16 public class LoggingAspect : Interceptor
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
17 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
18 public class Parameters
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
19 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
20 public string FileName;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
21 public int MinCallTime;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
22 public bool LogExceptions;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
23 public bool LogParameters;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
24 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
25
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
26 private string _instanceFileName;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
27 private int? _instanceMinCallTime;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
28 private bool? _instanceLogExceptions;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
29 private bool? _instanceLogParameters;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
30 private readonly Parameters _parameters = new Parameters();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
31
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
32 public override void Init(CallMethodInfo info, string configString)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
33 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
34 base.Init(info, configString);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
35
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
36 string[] ps = configString.Split(';');
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
37
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
38 foreach (string p in ps)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
39 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
40 string[] vs = p.Split('=');
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
41
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
42 if (vs.Length == 2)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
43 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
44 switch (vs[0].ToLower().Trim())
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
45 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
46 case "filename": _instanceFileName = vs[1].Trim(); break;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
47 case "mincalltime": _instanceMinCallTime = int. Parse(vs[1].Trim()); break;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
48 case "logexceptions": _instanceLogExceptions = bool.Parse(vs[1].Trim()); break;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
49 case "logparameters": _instanceLogParameters = bool.Parse(vs[1].Trim()); break;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
50 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
51 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
52 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
53 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
54
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
55 protected override void OnFinally(InterceptCallInfo info)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
56 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
57 if (IsEnabled)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
58 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
59 _parameters.FileName = _instanceFileName ?? FileName;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
60 _parameters.MinCallTime = _instanceMinCallTime ?? MinCallTime;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
61 _parameters.LogExceptions = _instanceLogExceptions ?? LogExceptions;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
62 _parameters.LogParameters = _instanceLogParameters ?? LogParameters;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
63
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
64 LogOperation(info, _parameters);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
65 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
66 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
67
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
68 #region Parameters
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
69
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
70 private static bool _logParameters = true;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
71 public static bool LogParameters
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
72 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
73 get { return _logParameters; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
74 set { _logParameters = value; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
75 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
76
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
77 private static bool _logExceptions = true;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
78 public static bool LogExceptions
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
79 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
80 get { return _logExceptions; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
81 set { _logExceptions = value; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
82 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
83
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
84 private static int _minCallTime;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
85 public static int MinCallTime
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
86 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
87 get { return _minCallTime; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
88 set { _minCallTime = value; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
89 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
90
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
91 private static string _fileName;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
92 public static string FileName
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
93 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
94 get { return _fileName; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
95 set { _fileName = value; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
96 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
97
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
98 private static bool _isEnabled = true;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
99 public static bool IsEnabled
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
100 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
101 get { return _isEnabled; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
102 set { _isEnabled = value; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
103 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
104
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
105 #endregion
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
106
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
107 #region LogOperation
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
108
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
109 private static LogOperation _logOperation = LogOperationInternal;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
110 public static LogOperation LogOperation
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
111 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
112 get { return _logOperation; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
113 set { _logOperation = value ?? LogOperationInternal; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
114 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
115
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
116 private static void LogOperationInternal(InterceptCallInfo info, Parameters parameters)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
117 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
118 DateTime end = DateTime.Now;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
119 int time = (int)((end - info.BeginCallTime).TotalMilliseconds);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
120
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
121 if (info.Exception != null && parameters.LogExceptions ||
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
122 info.Exception == null && time >= parameters.MinCallTime)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
123 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
124 string callParameters = null;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
125 int plen = info.ParameterValues.Length;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
126
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
127 if (parameters.LogParameters && plen > 0)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
128 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
129 StringBuilder sb = new StringBuilder();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
130 object[] values = info.ParameterValues;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
131
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
132 FormatParameter(values[0], sb);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
133 for (int i = 1; i < plen; i++)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
134 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
135 FormatParameter(values[i], sb.Append(", "));
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
136 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
137
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
138 callParameters = sb.ToString();
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
139 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
140
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
141 string exText = null;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
142
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
143 if (info.Exception != null)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
144 exText = string.Format(
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
145 " with exception '{0}' - \"{1}\"",
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
146 info.Exception.GetType().FullName,
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
147 info.Exception.Message);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
148
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
149 LogOutput(
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
150 string.Format("{0}: {1}.{2}({3}) - {4} ms{5}{6}.",
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
151 end,
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
152 info.CallMethodInfo.MethodInfo.DeclaringType.FullName,
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
153 info.CallMethodInfo.MethodInfo.Name,
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
154 callParameters,
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
155 time,
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
156 info.Cached? " from cache": null,
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
157 exText),
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
158 parameters.FileName);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
159 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
160 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
161
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
162 private static void FormatParameter(object parameter, StringBuilder sb)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
163 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
164 if (parameter == null)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
165 sb.Append("<null>");
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
166 else if (parameter is string)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
167 sb.Append('"').Append((string)parameter).Append('"');
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
168 else if (parameter is char)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
169 sb.Append('\'').Append((char)parameter).Append('\'');
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
170 else if (parameter is IEnumerable)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
171 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
172 sb.Append('[');
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
173 bool first = true;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
174 foreach (object item in (IEnumerable)parameter)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
175 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
176 FormatParameter(item, first? sb: sb.Append(','));
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
177 first = false;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
178 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
179 sb.Append(']');
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
180 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
181 else if (parameter is IFormattable)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
182 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
183 IFormattable formattable = (IFormattable)parameter;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
184 sb.Append(formattable.ToString(null, CultureInfo.InvariantCulture));
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
185 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
186 else
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
187 sb.Append(parameter.ToString());
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
188 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
189
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
190 #endregion
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
191
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
192 #region LogOuput
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
193
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
194 private static LogOutput _logOutput = LogOutputInternal;
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
195 public static LogOutput LogOutput
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
196 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
197 get { return _logOutput; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
198 set { _logOutput = value ?? LogOutputInternal; }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
199 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
200
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
201 private static void LogOutputInternal(string logText, string fileName)
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
202 {
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
203 if (string.IsNullOrEmpty(fileName))
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
204 Debug.WriteLine(logText);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
205 else
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
206 using (StreamWriter sw = new StreamWriter(fileName, true))
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
207 sw.WriteLine(logText);
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
208 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
209
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
210 #endregion
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
211 }
f990fcb411a9 Копия текущей версии из github
cin
parents:
diff changeset
212 }