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,2005 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.Collections;
32 using System.Security.Permissions;
35 namespace System.Web {
37 // CAS - no InheritanceDemand here as the class is sealed
38 [AspNetHostingPermission (SecurityAction.LinkDemand, Level = AspNetHostingPermissionLevel.Minimal)]
39 public sealed class TraceContext {
41 TraceManager _traceManager;
43 TraceMode _Mode = TraceMode.Default;
47 Hashtable view_states;
49 Hashtable control_states;
53 public TraceContext (HttpContext Context)
58 internal bool HaveTrace {
64 public bool IsEnabled {
67 return TraceManager.Enabled;
72 if (value && data == null)
73 data = new TraceData ();
79 TraceManager TraceManager
83 if (_traceManager == null)
84 _traceManager = HttpRuntime.TraceManager;
90 public TraceMode TraceMode {
92 return (_Mode == TraceMode.Default) ? TraceManager.TraceMode : _Mode;
99 public void Warn(string msg)
101 Write (String.Empty, msg, null, true);
104 public void Warn(string category, string msg)
106 Write (category, msg, null, true);
109 public void Warn (string category, string msg, Exception error)
111 Write (category, msg, error, true);
114 public void Write (string msg)
116 Write (String.Empty, msg, null, false);
119 public void Write (string category, string msg)
121 Write (category, msg, null, false);
124 public void Write (string category, string msg, Exception error)
126 Write (category, msg, error, false);
129 void Write (string category, string msg, Exception error, bool Warning)
134 data = new TraceData ();
135 data.Write (category, msg, error, Warning);
138 public event TraceContextEventHandler TraceFinished;
140 internal void SaveData ()
143 data = new TraceData ();
145 data.TraceMode = _Context.Trace.TraceMode;
147 SetRequestDetails ();
148 if (_Context.Handler is Page)
150 data.AddControlTree ((Page) _Context.Handler, view_states, control_states, sizes);
152 data.AddControlTree ((Page) _Context.Handler, view_states, sizes);
158 TraceManager.AddTraceData (data);
162 internal void SaveViewState (Control ctrl, object vs)
164 if (view_states == null)
165 view_states = new Hashtable ();
167 view_states [ctrl] = vs;
171 internal void SaveControlState (Control ctrl, object vs) {
172 if (control_states == null)
173 control_states = new Hashtable ();
175 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]);