2 // System.Web.TraceContext
5 // Patrik Torstensson (Patrik.Torstensson@labs2.com)
6 // Jackson Harper (jackson@ximian.com)
8 // (C) 2002 2003, Patrik Torstensson
9 // Copyright (C) 2003-2009 Novell, Inc (http://www.novell.com)
11 // Permission is hereby granted, free of charge, to any person obtaining
12 // a copy of this software and associated documentation files (the
13 // "Software"), to deal in the Software without restriction, including
14 // without limitation the rights to use, copy, modify, merge, publish,
15 // distribute, sublicense, and/or sell copies of the Software, and to
16 // permit persons to whom the Software is furnished to do so, subject to
17 // the following conditions:
19 // The above copyright notice and this permission notice shall be
20 // included in all copies or substantial portions of the Software.
22 // THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
23 // EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
24 // MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
25 // NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
26 // LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
27 // OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
28 // WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
31 using System.ComponentModel;
32 using System.Collections;
33 using System.Security.Permissions;
38 // CAS - no InheritanceDemand here as the class is sealed
39 [AspNetHostingPermission (SecurityAction.LinkDemand, Level = AspNetHostingPermissionLevel.Minimal)]
40 public sealed class TraceContext
42 static readonly object traceFinishedEvent = new object ();
45 TraceManager _traceManager;
47 TraceMode _Mode = TraceMode.Default;
51 Hashtable view_states;
52 Hashtable control_states;
54 EventHandlerList events = new EventHandlerList ();
56 public event TraceContextEventHandler TraceFinished {
57 add { events.AddHandler (traceFinishedEvent, value); }
58 remove { events.AddHandler (traceFinishedEvent, value); }
61 public TraceContext (HttpContext Context)
66 internal bool HaveTrace {
72 public bool IsEnabled {
75 return TraceManager.Enabled;
80 if (value && data == null)
81 data = new TraceData ();
87 TraceManager TraceManager
91 if (_traceManager == null)
92 _traceManager = HttpRuntime.TraceManager;
98 public TraceMode TraceMode {
100 return (_Mode == TraceMode.Default) ? TraceManager.TraceMode : _Mode;
107 public void Warn(string msg)
109 Write (String.Empty, msg, null, true);
112 public void Warn(string category, string msg)
114 Write (category, msg, null, true);
117 public void Warn (string category, string msg, Exception error)
119 Write (category, msg, error, true);
122 public void Write (string msg)
124 Write (String.Empty, msg, null, false);
127 public void Write (string category, string msg)
129 Write (category, msg, null, false);
132 public void Write (string category, string msg, Exception error)
134 Write (category, msg, error, false);
137 void Write (string category, string msg, Exception error, bool Warning)
142 data = new TraceData ();
143 data.Write (category, msg, error, Warning);
146 internal void SaveData ()
149 data = new TraceData ();
151 data.TraceMode = _Context.Trace.TraceMode;
153 SetRequestDetails ();
154 if (_Context.Handler is Page)
155 data.AddControlTree ((Page) _Context.Handler, view_states, control_states, sizes);
160 TraceManager.AddTraceData (data);
164 internal void SaveViewState (Control ctrl, object vs)
166 if (view_states == null)
167 view_states = new Hashtable ();
169 view_states [ctrl] = vs;
172 internal void SaveControlState (Control ctrl, object vs) {
173 if (control_states == null)
174 control_states = new Hashtable ();
176 control_states [ctrl] = vs;
179 internal void SaveSize (Control ctrl, int size)
182 sizes = new Hashtable ();
187 internal void Render (HtmlTextWriter output)
191 data.Render (output);
194 void SetRequestDetails ()
196 data.RequestPath = _Context.Request.FilePath;
197 data.SessionID = (_Context.Session != null ? _Context.Session.SessionID : String.Empty);
198 data.RequestType = _Context.Request.RequestType;
199 data.RequestTime = _Context.Timestamp;
200 data.StatusCode = _Context.Response.StatusCode;
201 data.RequestEncoding = _Context.Request.ContentEncoding;
202 data.ResponseEncoding = _Context.Response.ContentEncoding;
207 foreach (string key in _Context.Request.Cookies.Keys)
208 data.AddCookie (key, _Context.Request.Cookies [key].Value);
213 foreach (string key in _Context.Request.Headers.Keys)
214 data.AddHeader (key, _Context.Request.Headers [key]);
217 void AddServerVars ()
219 foreach (string key in _Context.Request.ServerVariables)
220 data.AddServerVar (key, _Context.Request.ServerVariables [key]);